/*
 Theme Name:   GeneratePress Child
 Theme URI:    https://osaweso.me
 Description:  Child theme for GeneratePress
 Author:       Osaweso
 Author URI:   https://osaweso.me
 Template:     generatepress
 Version:      2.0.0
 Text Domain:  generatepress-child
*/


/* =========================================================
   Design System Tokens
   Source: vault/Work/osAwesome/osawesome-design-system.md
   Last synced: 2026-03-18
   ========================================================= */

:root {
  /* Primary brand — nav, links, key UI accents */
  --blue:         #419AD2;
  --blue-dark:    #2F7DB8;
  --blue-light:   #E8F5FC;   /* Alice Blue — section backgrounds */

  /* Dark sections, nav bg, footer bg */
  --charcoal:     #444C56;
  --charcoal-mid: #5A6270;   /* Body text */

  /* Secondary text, borders, muted elements */
  --steel:        #A6AFBC;
  --slate:        #C7D2DC;   /* Card surfaces, borders */

  /* Accent only — labels, checkmarks, pills, Forum link */
  --green:        #82B541;
  --green-dark:   #6E9A38;
  --green-light:  #EAF3DE;

  /* CTA buttons ONLY */
  --orange:       #F55C44;
  --orange-dark:  #D94E38;

  --white:        #ffffff;
  --border:       #C7D2DC;

  /* Error states */
  --red:          #C0392B;
  --red-light:    #FDECEA;

  /* Utility */
  --radius-sm:    4px;
  --radius-md:    8px;
  --radius-lg:    12px;
  --shadow-sm:    0 1px 2px rgba(68, 76, 86, 0.04);
  --shadow-md:    0 4px 16px rgba(68, 76, 86, 0.06);
}


/* =========================================================
   Global
   ========================================================= */

body,
button,
input,
select,
textarea {
  font-family: 'DM Sans', sans-serif;
}

body {
  background: var(--white);
  color: var(--charcoal-mid);
}

a {
  color: var(--blue);
  text-decoration: none;
  transition: color 0.18s ease;
}

a:hover,
a:focus {
  color: var(--blue-dark);
}

h1, h2, h3, h4, h5, h6 {
  color: var(--charcoal);
}

h1, h2 {
  font-weight: 600;
}

p,
li,
.entry-content,
.woocommerce-result-count,
.woocommerce-breadcrumb {
  color: var(--charcoal-mid);
}

/* =========================================================
   Header / Navigation
   ========================================================= */

.site-header {
  background: var(--white);
  border-bottom: 1px solid var(--border);
  box-shadow: 0 1px 0 rgba(68, 76, 86, 0.03);
}
.inside-header {
    padding: 24px;
}


/* =========================================================
   Main Content Containers
   ========================================================= */

/* remove page margins globally */
.separate-containers .site-main {
    margin: 0 0 60px 0;	
}

.grid-container {
    max-width: 100%;
}

#content {
    max-width: 1200px;
    margin: 0 auto;
}

/* .inside-article {
    padding: 0 !important;
} */ 

.inside-article {
    padding-bottom: 0 !important;
}

main#main {
    min-height: 400px;
}

/* Hide page title globally */
header.entry-header {
	display: none;
}

.separate-containers .inside-article,
.separate-containers .comments-area,
.separate-containers .page-header,
.one-container .container,
.separate-containers .paging-navigation,
.inside-page-header {
  background: transparent;
}

/* Full-width block breakout */
.no-sidebar.separate-containers .entry-content .alignfull {
  margin-left: calc(-50vw + 50%);
  margin-right: calc(-50vw + 50%);
  max-width: 100vw;
  width: 100vw;
}

body.no-sidebar.separate-containers {
  overflow-x: hidden;
}

.site-main .wp-block-group__inner-container,
.inside-article {
  padding-top: 48px;
  padding-bottom: 48px;
}


/* =========================================================
   Breadcrumbs / Titles
   ========================================================= */

.woocommerce-breadcrumb {
  margin-bottom: 18px;
  font-size: 14px;
  color: var(--steel);
}

.woocommerce-breadcrumb a {
  color: var(--charcoal-mid);
}

/* Site breadcrumbs (pages) */
.oa-breadcrumbs {
  max-width: 1200px;
  margin: 16px auto 0;
  padding: 0 20px;
  font-size: 13px;
  color: #8B9DAF;
}
.oa-breadcrumbs a {
  color: var(--blue);
  text-decoration: none;
}
.oa-breadcrumbs a:hover {
  text-decoration: underline;
}
.oa-bc-sep {
  margin: 0 6px;
  color: #C7D2DC;
}
.oa-bc-current {
  color: #6B7B8D;
}

.woocommerce-products-header__title.page-title,
.entry-title {
  color: var(--charcoal);
  margin-bottom: 12px;
}


/* =========================================================
   Forms / Inputs
   ========================================================= */

.woocommerce .woocommerce-ordering select,
select,
input[type="text"],
input[type="email"],
input[type="url"],
input[type="password"],
input[type="search"],
input[type="tel"],
input[type="number"],
textarea {
  background: var(--white);
  border: 1px solid var(--border);
  color: var(--charcoal);
  border-radius: var(--radius-sm);
  padding: 10px 12px;
  box-shadow: none;
}

.woocommerce .woocommerce-ordering select:focus,
select:focus,
input:focus,
textarea:focus {
  outline: none;
  border-color: var(--blue);
  box-shadow: 0 0 0 3px rgba(65, 154, 210, 0.12);
}

.woocommerce-result-count,
.woocommerce-ordering {
  margin-bottom: 28px;
}


/* =========================================================
   Product Grid (WooCommerce)
   ========================================================= */

.woocommerce ul.products {
  margin-top: 20px;
}

.woocommerce ul.products li.product,
.woocommerce-page ul.products li.product {
  background: var(--white);
  border: 1px solid var(--border);
  border-radius: var(--radius-lg);
  padding: 22px;
  box-shadow: var(--shadow-sm);
  transition: transform 0.18s ease, box-shadow 0.18s ease, border-color 0.18s ease;
}

.woocommerce ul.products li.product:hover,
.woocommerce-page ul.products li.product:hover {
  transform: translateY(-2px);
  box-shadow: var(--shadow-md);
  border-color: var(--steel);
}

.woocommerce ul.products li.product a img {
  border-radius: var(--radius-md);
  margin-bottom: 12px;
  background: var(--blue-light);
}

.woocommerce ul.products li.product .woocommerce-loop-product__title {
  color: var(--charcoal);
  font-size: 24px;
  line-height: 1.25;
  margin-bottom: 10px;
}

.woocommerce ul.products li.product .price {
  color: var(--charcoal-mid);
  font-weight: 500;
  margin-bottom: 18px;
}

.woocommerce ul.products li.product .price .amount {
  color: var(--charcoal);
  font-weight: 700;
}

.woocommerce ul.products li.product .from,
.woocommerce ul.products li.product .subscription-details {
  color: var(--steel);
}


/* =========================================================
   Buttons
   ========================================================= */
button[type="submit"],
button.btn,
button.button,
html input[type="button"],
input[type="reset"],
input[type="submit"],
a.button,
a.wp-block-button__link:not(.has-background),
.woocommerce a.button,
.woocommerce button.button,
.woocommerce input.button {
  background: #dcdfe2;
  color: #3b4450;
  border: 0;
  border-radius: var(--radius-sm);
  padding: 12px 18px;
  font-weight: 600;
  -webkit-box-shadow: 0 3px 0 0 #b1b2b3;
  -moz-box-shadow: 0 3px 0 0 #b1b2b3;
  box-shadow: 0 2px 0 0 #b1b2b3;
  transition: transform 0.15s ease, background-color 0.18s ease, box-shadow 0.18s ease;
}

button[type="submit"]:hover,
button.btn:hover,
button.button:hover,
html input[type="button"]:hover,
input[type="reset"]:hover,
input[type="submit"]:hover,
a.button:hover,
a.wp-block-button__link:not(.has-background):hover,
.woocommerce a.button:hover,
.woocommerce button.button:hover,
.woocommerce input.button:hover,
button[type="submit"]:focus,
button.btn:focus,
button.button:focus,
html input[type="button"]:focus,
input[type="reset"]:focus,
input[type="submit"]:focus,
a.button:focus,
.woocommerce a.button:focus,
.woocommerce button.button:focus,
.woocommerce input.button:focus {
  background: #cdd0d4;
  color: #3b4450;
  animation: pulse 0.8s ease-in-out;
  -webkit-box-shadow: 0 3px 0 0 #b1b2b3;
  -moz-box-shadow: 0 3px 0 0 #b1b2b3;
  box-shadow: 0 2px 0 0 #b1b2b3;
}


/* =========================================================
   Notices / Alerts (WooCommerce)
   ========================================================= */

.woocommerce-info,
.woocommerce-message {
  box-shadow: none;
  padding: 16px 18px 16px 20px;
  border-radius: 0 5px 5px 0;
  background: #ffffff;
  border: 1px solid rgba(65, 154, 210, .3);
  border-left: 4px solid var(--blue);
  color: #1e5782;
}

.woocommerce-error {
  background: #fff7f5;
  border: 1px solid #F1C7BB;
  border-radius: var(--radius-md);
  box-shadow: none;
  padding: 16px 18px 16px 20px;
  color: var(--charcoal);
}

.woocommerce-error::before,
.woocommerce-info::before,
.woocommerce-message::before {
  content: '' !important;
}


/* ---------------------------------------------------------
   WooCommerce Forms (login, register, edit-account, etc.)
   --------------------------------------------------------- */

.woocommerce-account .woocommerce form.login,
.woocommerce-account .woocommerce form.register,
.woocommerce-account .woocommerce form.woocommerce-ResetPassword,
.woocommerce-account .woocommerce form.woocommerce-EditAccountForm {
  max-width: 480px;
}


/* =========================================================
   Stats Bar (charcoal dark section)
   ========================================================= */

.home .site-main .wp-block-group__inner-container {
    padding-top: 0;
    padding-bottom: 0;
}

.oa-stats-bar {
  display: flex;
  justify-content: center;
  flex-wrap: wrap;
  gap: 0;
  max-width: 900px;
  margin: 0 auto;
  padding: 28px 48px;
}

.oa-stats-bar.pre-footer.full-width {
    padding: 74px 0 0 0;
}

.oa-stat {
  position: relative;
  text-align: center;
  padding: 8px 32px;
}

.oa-stat:not(:last-child)::after {
  content: "";
  position: absolute;
  top: 12px;
  right: 0;
  width: 1px;
  height: calc(100% - 24px);
  background: rgba(255, 255, 255, 0.08);
}

.oa-stat-num {
  font-size: 24px;
  font-weight: 700;
  line-height: 1.1;
  color: var(--green);
  margin-bottom: 4px;
}

.oa-stat-label {
  font-size: 11px;
  font-weight: 600;
  letter-spacing: .08em;
  text-transform: uppercase;
  color: rgba(255, 255, 255, 0.5);
}


/* =========================================================
   Accordion (FAQs)
   ========================================================= */

.oa-accordion {
  display: flex;
  flex-direction: column;
  border: 1px solid var(--border);
  border-radius: var(--radius-md);
  overflow: hidden;
  background: var(--white);
  margin-bottom: 48px;
}

.oa-accordion-item {
  border-bottom: 1px solid var(--border);
}

.oa-accordion-item:last-child {
  border-bottom: none;
}

.oa-accordion-trigger {
  all: unset;
  box-sizing: border-box;
  width: 100%;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 16px;
  padding: 22px 28px;
  background: var(--white);
  cursor: pointer;
  text-align: left;
  font-family: inherit;
  font-size: 16px;
  font-weight: 600;
  color: var(--charcoal);
  line-height: 1.4;
  transition: background 0.2s, color 0.2s;
}

.oa-accordion-trigger:hover,
.oa-accordion-trigger:focus {
  background: var(--blue-light);
  color: var(--blue-dark);
  transform: none;
  box-shadow: none;
}

.oa-accordion-trigger.open {
  background: var(--blue-light);
  color: var(--blue-dark);
}

.oa-accordion-icon {
  flex-shrink: 0;
  width: 20px;
  height: 20px;
  color: var(--steel);
  transition: transform 0.3s ease, color 0.2s;
}

.oa-accordion-trigger.open .oa-accordion-icon {
  transform: rotate(45deg);
  color: var(--blue);
}

.oa-accordion-body {
  display: grid;
  grid-template-rows: 0fr;
  transition: grid-template-rows 0.3s ease;
}

.oa-accordion-body.open {
  grid-template-rows: 1fr;
}

.oa-accordion-body-inner {
  overflow: hidden;
}

.oa-accordion-body-content {
  padding: 20px 28px 0 28px;
  font-size: 15px;
  line-height: 1.75;
  color: var(--charcoal-mid);
  border-top: 1px solid var(--border);
}

.oa-accordion-body-content p + p {
  margin-top: 12px;
}

.oa-accordion-body-content ul {
  margin: 8px 0;
  padding-left: 20px;
}

.oa-accordion-body-content li {
  margin-bottom: 4px;
  font-size: 14px;
}

.oa-accordion-body-content code,
.oa-accordion-body-content pre {
  background: var(--blue-light);
  border: 1px solid var(--border);
  border-radius: var(--radius-sm);
  padding: 12px 16px;
  font-size: 13px;
  display: block;
  margin-top: 12px;
  overflow-x: auto;
}

.oa-faq-section-heading {
  font-size: 13px;
  font-weight: 700;
  letter-spacing: .09em;
  text-transform: uppercase;
  color: var(--blue);
  margin: 0 0 16px;
  padding: 0;
}

.oa-faq-section-heading:not(:first-child) {
  margin-top: 56px;
}


/* =========================================================
   Legal Pages
   ========================================================= */

.legal-page {
  max-width: 760px;
  margin: 0 auto;
  line-height: 1.75;
}

.legal-page h1 { margin-bottom: 8px; }
.legal-page h2 { margin-top: 32px; margin-bottom: 12px; }
.legal-page h3 { margin-top: 24px; margin-bottom: 8px; }
.legal-page p { margin-bottom: 16px; }
.legal-page ul { margin-bottom: 16px; padding-left: 20px; }
.legal-page li { margin-bottom: 6px; }
.legal-page hr { border: none; border-top: 1px solid var(--border); margin: 32px 0; }


/* =========================================================
   Footer
   ========================================================= */




/* =========================================================
   Component Library (.oa-* reusable classes)
   Used by: compare pages (99+), use-case pages (101-105),
            and future marketing pages.
   ========================================================= */

/* ---- Layout ---- */

.oa-page *,
.oa-page *::before,
.oa-page *::after { box-sizing: border-box; margin: 0; padding: 0; }

/* Restore accordion styles inside .oa-page (the wildcard reset above clobbers them) */
.oa-page .oa-accordion { margin-bottom: 48px; }
.oa-page .oa-accordion-trigger { padding: 22px 28px; gap: 16px; }
.oa-page .oa-accordion-body-content { padding: 20px 28px 24px; }
.oa-page .oa-accordion-body-content p + p { margin-top: 12px; }
.oa-page .oa-accordion-body-content ul { margin: 8px 0; padding-left: 20px; }
.oa-page .oa-accordion-body-content li { margin-bottom: 4px; }

.oa-page {
  font-family: 'DM Sans', sans-serif;
  font-size: 17px;
  line-height: 1.65;
  color: var(--charcoal-mid);
  background: var(--white);
  -webkit-font-smoothing: antialiased;
}

.oa-page h1, .oa-page h2, .oa-page h3, .oa-page h4 {
  font-family: "Plus Jakarta Sans", sans-serif;
  color: var(--charcoal);
  line-height: 1.2;
  margin: 0;
}

.oa-page p { margin: 0; }

.oa-wrap { max-width: 1100px; margin: 0 auto; padding: 0 48px; }
.oa-wrap p, .oa-wrap li { font-size: 17px; line-height: 1.75; color: var(--charcoal-mid); }
.oa-wrap p { margin-bottom: 20px; }
.oa-wrap h2 { font-family: "Plus Jakarta Sans", sans-serif; font-size: 32px; color: var(--charcoal); margin-bottom: 16px; }
.oa-hero-title { font-size: 42px; }
.oa-callout {
  background: var(--green-light);
  border-left: 4px solid var(--green);
  border-radius: 8px;
  padding: 28px 32px;
  margin-bottom: 28px;
}
.oa-callout p {
  font-family: "Plus Jakarta Sans", sans-serif;
  font-size: 19px;
  font-weight: 600;
  color: var(--charcoal);
  line-height: 1.6;
  margin: 0;
}
.oa-cta-footer {
  text-align: center;
  padding: 48px 20px;
}
.oa-cta-footer h2 { font-size: 28px; color: #fff; }
.oa-cta-link {
  color: var(--orange);
  font-weight: 600;
  text-decoration: none;
}

.oa-section { padding: 88px 0; }
.oa-section--alice { background: var(--blue-light); }
.oa-section--charcoal { background: var(--charcoal); color: rgba(255,255,255,.65); }
.oa-section--charcoal h2 { color: var(--white); }
.oa-section--charcoal .oa-eyebrow { color: var(--green); }
.oa-section--charcoal .oa-section-body,
.oa-section--charcoal .oa-section-body p { color: rgba(255,255,255,.65); }
.oa-section--green-light { background: var(--green-light); }

/* ---- Typography ---- */

.oa-eyebrow {
  font-family: "Plus Jakarta Sans", sans-serif;
  font-size: 12px;
  font-weight: 700;
  letter-spacing: .09em;
  text-transform: uppercase;
  color: var(--blue);
  margin-bottom: 12px;
}

.oa-on-dark .oa-eyebrow { color: var(--green); }

.oa-section-header { margin-bottom: 40px; }
.oa-section-header h2 { font-size: 38px; font-weight: 600; margin-bottom: 12px; }

.oa-section-body {
  font-family: 'DM Sans', sans-serif; font-size: 17px;
}
button,
input,
select,
textarea {
  font-family: 'DM Sans', sans-serif; font-size: 17px;
}
.oa-section-body p { margin-bottom: 20px; }

/* ---- Hero ---- */

.oa-hero { padding: 100px 0 0 0; text-align: center; }
.oa-hero h1 { font-size: 52px; font-weight: 600; margin-bottom: 20px; }
.oa-hero .oa-subtitle { font-size: 19px; color: var(--charcoal-mid); margin-bottom: 36px; line-height: 1.6; }
.oa-hero-graphic { max-width: 480px; width: 100%; margin-top: 12px; }

/* Per-page hero graphic sizing */
.page-id-102 .oa-hero-graphic { max-width: 800px; } /* Education — panoramic aspect ratio */
.page-id-104 .oa-hero-graphic { max-width: 420px; } /* MSP — squarer aspect ratio */
.page-id-105 .oa-hero-graphic { max-width: 460px; } /* Nonprofits — squarer aspect ratio */

/* ---- Buttons ---- */

.oa-btn {
  display: inline-block;
  font-family: "Plus Jakarta Sans", sans-serif;
  font-size: 15px;
  font-weight: 600;
  letter-spacing: .02em;
  text-decoration: none;
  border-radius: 4px;
  padding: 13px 28px;
  transition: all 0.2s ease;
  cursor: pointer;
  border: none;
}

.oa-btn-orange { background: var(--orange); color: var(--white); box-shadow: 0 3px 0 rgba(160,60,40,.9); }
.oa-btn-orange:hover { background: var(--orange-dark); color: var(--white); }
.oa-btn-white { background: var(--white); color: var(--blue-dark); }
.oa-btn-white:hover { background: #f0f4f8; }
.oa-btn-white-outline { background: transparent; color: var(--white); border: 2px solid rgba(255,255,255,.5); }
.oa-btn-white-outline:hover { border-color: rgba(255,255,255,.8); color: var(--white); }
.oa-btn-group { display: flex; gap: 16px; flex-wrap: wrap; }

/* ---- Feature Grid ---- */

.oa-feature-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 1px;
  background: var(--slate);
  border-radius: 10px;
  overflow: hidden;
  margin: 32px 0;
}

.oa-feature-cell { background: var(--white); padding: 48px; }

.oa-feature-cell h4 {
  font-size: 16px;
  font-weight: 600;
  margin-bottom: 8px;
  display: flex;
  align-items: center;
  gap: 10px;
}

.oa-feature-cell h4::before {
  content: "";
  width: 8px;
  height: 8px;
  background: var(--green);
  border-radius: 50%;
  flex-shrink: 0;
}

.oa-feature-cell p { font-size: 15px; line-height: 1.55; margin: 0; color: var(--charcoal-mid); }

/* ---- Comparison Table ---- */

.oa-comp-table {
  width: 100%;
  border-collapse: collapse;
  margin: 32px 0;
  font-size: 15px;
  background: #fff;
  box-shadow: 0 1px 4px rgba(0,0,0,0.06), 0 4px 16px rgba(0,0,0,0.04);
  border-radius: 8px;
  overflow: hidden;
}

.oa-comp-table thead th {
  background: var(--charcoal);
  color: var(--white);
  font-family: "Plus Jakarta Sans", sans-serif;
  font-weight: 600;
  font-size: 14px;
  padding: 14px 18px;
  text-align: left;
  border: none;
}

.oa-comp-table thead th.ours { background: var(--blue-dark); }

.oa-comp-table tbody td {
  padding: 13px 18px;
  border-bottom: 1px solid var(--slate);
  vertical-align: top;
  color: var(--charcoal-mid);
  background: var(--white);
}

.oa-comp-table tbody td.ours { background: var(--blue-light); font-weight: 500; }
.oa-comp-table tbody td:first-child { font-weight: 500; color: var(--charcoal); }
.oa-comp-table tbody tr:last-child td { border-bottom: none; }

.oa-section--charcoal .oa-comp-table {
  box-shadow: none;
  border-radius: 10px;
  border: 1px solid rgba(255,255,255,.08);
}

.oa-yes { color: var(--green); font-weight: 700; font-size: 20px; }
.oa-no { color: var(--slate); font-weight: 700; font-size: 20px; }
.oa-warn { color: var(--orange); font-weight: 700; font-size: 20px; }
.oa-price-highlight { font-weight: 700; color: var(--blue-dark); }

/* ---- FAQ Accordion ---- */

.oa-faq-list { margin-top: 32px; }

.oa-faq-item {
  border: 1px solid var(--border);
  border-radius: 10px;
  margin-bottom: 12px;
  overflow: hidden;
  transition: border-color 0.2s;
  background: #fff;
}

.oa-faq-item:hover { border-color: var(--blue); }

.oa-faq-q {
  all: unset;
  box-sizing: border-box;
  width: 100%;
  padding: 22px 28px;
  font-family: "Plus Jakarta Sans", sans-serif;
  font-size: 16px;
  font-weight: 600;
  color: var(--charcoal);
  text-align: left;
  cursor: pointer;
  display: flex;
  justify-content: space-between;
  align-items: center;
}

.oa-faq-q:hover,
.oa-faq-q:focus {
  color: var(--blue-dark);
}

.oa-faq-q::after { content: "+"; font-size: 22px; font-weight: 400; color: var(--blue); transition: transform 0.2s; }
.oa-faq-item.open .oa-faq-q::after { content: "\2212"; }

.oa-faq-a {
  display: none;
  padding: 0 28px 22px;
  font-size: 15px;
  line-height: 1.65;
  color: var(--charcoal-mid);
}

.oa-faq-item.open .oa-faq-a { display: block; }

/* ---- Trust Strip ---- */

.oa-trust-strip { text-align: center; }

.oa-trust-logos {
  display: flex;
  align-items: center;
  justify-content: center;
  flex-wrap: wrap;
  gap: 40px 52px;
  margin-top: 32px;
}

.oa-trust-logos img {
  display: block;
  height: 40px;
  width: auto;
  filter: brightness(0) invert(1);
  opacity: 0.35;
}

/* ---- Footer CTA ---- */


/* ---- Callout Boxes ---- */

.oa-callout {
  border-radius: 0 10px 10px 0;
  padding: 20px 24px;
  margin: 32px 0;
  font-size: 15px;
  line-height: 1.6;
}

.oa-callout strong { color: var(--charcoal); }
.oa-callout p { margin-bottom: 12px; }
.oa-callout p:last-child { margin-bottom: 0; }

.oa-callout-green { background: var(--green-light); border-left: 4px solid var(--green); }
.oa-callout-orange { background: #fff7f5; border-left: 4px solid var(--orange); }
.oa-callout-blue { background: var(--blue-light); border-left: 4px solid var(--blue); }
.oa-section--alice .oa-callout-blue { background: #fff; }

/* ---- Cost Card Grid ---- */

.oa-cost-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 20px; margin: 32px 0; }

.oa-cost-card {
  background: var(--white);
  border: 1px solid var(--border);
  border-radius: 10px;
  padding: 28px 28px 24px;
}

.oa-cost-card h4 { font-size: 16px; font-weight: 600; margin-bottom: 8px; }
.oa-cost-card p { font-size: 15px; line-height: 1.55; margin: 0 0 10px; color: var(--charcoal-mid); }
.oa-cost-card p:last-child { margin-bottom: 0; }

/* ---- Tagline ---- */

.oa-tagline {
  font-family: "Plus Jakarta Sans", sans-serif;
  font-size: 18px;
  font-weight: 600;
  color: var(--charcoal);
  margin-top: 20px;
}

/* ---- Component Library Responsive ---- */

@media (max-width: 768px) {
  .oa-wrap { padding: 0 24px; }
  .oa-section { padding: 56px 0; }
  .oa-hero { padding: 64px 0 84px; }
  .oa-hero h1 { font-size: 34px; }
  .oa-section-header h2 { font-size: 28px; }
  .oa-cost-grid { grid-template-columns: 1fr; }
  .oa-feature-grid { grid-template-columns: 1fr; }
  .oa-comp-table { font-size: 13px; }
  .oa-comp-table thead th,
  .oa-comp-table tbody td { padding: 10px 12px; }
  .oa-faq-q { padding: 18px 20px; font-size: 15px; }
  .oa-faq-a { padding: 0 20px 18px; }
}

/* ==========================================================================
   osAwesome Design System — Component Library
   Source: component library HTML files (palette, icons, component-lab-v5, etc.)
   Inserted: 2026-03-22

   These classes are the canonical design system. New pages should use these.
   Existing .oa-* prefixed classes (above) remain for live compare/use-case pages.
   ========================================================================== */


/* --- Typography Scale --- */


h2.heading {
  font-family: 'Plus Jakarta Sans', sans-serif;
  font-size: 38px;
  line-height: 1.18;
  color: var(--charcoal);
  margin-bottom: 16px;
  max-width: 680px;
}

.body-text {
  font-size: 16px;
  color: var(--charcoal-mid);
  max-width: 640px;
  line-height: 1.75;
  margin-bottom: 16px;
}

.section-title {
  font-family: 'Plus Jakarta Sans', sans-serif;
  font-size: 22px;
  font-weight: 700;
  color: var(--charcoal);
  letter-spacing: -.01em;
  margin-bottom: 28px;
}

.wrap {
  max-width: 1100px;
  margin: 0 auto;
  padding: 0 48px;
}

.browser-list {
  display: flex;
  gap: 16px;
  flex-wrap: wrap;
  margin-top: 12px;
}

.browser-item {
  display: flex;
  align-items: center;
  gap: 6px;
  font-size: 14px;
  color: var(--charcoal-mid);
  font-weight: 500;
}

.browser-item svg {
  color: var(--blue);
  width: 16px;
  height: 16px;
}
.t-display {
  font-family: 'Plus Jakarta Sans', sans-serif;
  font-size: 52px;
  line-height: 1.08;
  color: var(--charcoal);
  font-weight: 500;
}

.t-h2 {
  font-family: 'Plus Jakarta Sans', sans-serif;
  font-size: 38px;
  line-height: 1.18;
  color: var(--charcoal);
}

.t-h3 {
  font-size: 17px;
  font-weight: 600;
  color: var(--charcoal);
}

.t-body,
button,
input,
select,
textarea {
  font-family: 'DM Sans', sans-serif;
  font-size: 16px;
  color: var(--charcoal-mid);
  line-height: 1.75;
  max-width: 640px;
}

.t-small {
  font-size: 14px;
  color: var(--charcoal-mid);
}

.t-fine {
  font-size: 12px;
  color: var(--steel);
  font-style: italic;
}

.t-label-blue {
  font-size: 12px;
  font-weight: 700;
  letter-spacing: .09em;
  text-transform: uppercase;
  color: var(--blue);
}

.t-label-green {
  font-size: 12px;
  font-weight: 700;
  letter-spacing: .09em;
  text-transform: uppercase;
  color: var(--green);
}


/* --- Buttons --- */

@keyframes pulse-orange {
  0%, 100% { transform: scale(1); }
  50% { transform: scale(1.04); }
}

@keyframes pulse-ghost {
  0%, 100% { transform: scale(1); }
  50% { transform: scale(1.02); }
}

.btn {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  font-family: 'Plus Jakarta Sans', sans-serif;
  font-size: 15px;
  font-weight: 600;
  text-decoration: none;
  cursor: pointer;
  border: none;
  line-height: 1;
  letter-spacing: .08em;
  border-radius: var(--radius-sm);
}

.btn svg {
  width: 16px;
  height: 16px;
}

body a.btn.btn-orange, .btn-orange {
  background: var(--orange);
  color: white !important;
  padding: 13px 28px;
  box-shadow: 0 3px 0 rgba(160, 60, 40, .9);
}

body a.btn.btn-orange:hover {
  animation: pulse-orange .35s ease;
  background: var(--orange-dark);
  color: white !important;
}

body a.btn.btn-grey, .btn-grey {
  background: #dcdfe2;
  color: #3b4450 !important;
  padding: 13px 28px;
  box-shadow: 0 3px 0 0 #8d8f91;
}
body a.btn.btn-grey:hover {
  animation: pulse-ghost .35s ease;
  background: #cdd0d4;
  color: #3b4450 !important;
}

body a.btn.btn-blue {
    background: var(--blue);
    color: white !important;
    padding: 13px 28px;
    box-shadow: 0 3px 0 rgb(59 118 163);
}
body a.btn.btn-blue:hover {
  animation: pulse-orange .35s ease;
  background: var(--blue-dark);
  color: white !important;
}

.btn-ghost {
  background: white;
  color: var(--charcoal);
  padding: 13px 28px;
  border: 1px solid var(--border);
}

.btn-ghost:hover {
  animation: pulse-ghost .35s ease;
  background: var(--blue-light);
}

.btn-ghost-blue {
  background: white;
  color: var(--blue-dark);
  padding: 13px 28px;
  border: 1px solid var(--blue);
}

.btn-ghost-blue:hover {
  animation: pulse-ghost .35s ease;
  background: var(--blue-light);
}

.btn-ghost-white {
  background: transparent;
  color: white;
  padding: 13px 28px;
  border: 1px solid rgba(255, 255, 255, .35);
}

.btn-ghost-white:hover {
  animation: pulse-ghost .35s ease;
  border-color: white;
}

.btn-white {
  background: white;
  color: var(--blue-dark);
  padding: 13px 28px;
}

.btn-white:hover {
  animation: pulse-ghost .35s ease;
}

.btn-white-outline {
  border: 2px solid rgba(255, 255, 255, .5);
  color: white;
  padding: 13px 28px;
  background: transparent;
}

.btn-white-outline:hover {
  animation: pulse-ghost .35s ease;
  border-color: white;
}

.btn-sm {
  padding: 8px 18px;
  font-size: 13px;
}

.btn-row {
  display: flex;
  gap: 12px;
  flex-wrap: wrap;
  align-items: center;
}


/* --- Labels & Tags --- */

.label {
  font-family: 'Plus Jakarta Sans', sans-serif;
  font-size: 12px;
  font-weight: 700;
  letter-spacing: .09em;
  text-transform: uppercase;
  color: var(--blue);
  margin-bottom: 12px;
}

.label.green {
  color: var(--green);
}

.eyebrow {
  font-family: 'Plus Jakarta Sans', sans-serif;
  font-size: 11px;
  font-weight: 700;
  letter-spacing: .1em;
  text-transform: uppercase;
  color: var(--green);
  margin-bottom: 10px;
}

.act-label {
  display: inline-block;
  background: #c8d1e1;
  color: #596576;
  font-size: 11px;
  font-weight: 700;
  letter-spacing: .12em;
  text-transform: uppercase;
  padding: 5px 14px;
  border-radius: 20px;
}

.tag {
  display: inline-block;
  background: var(--blue-light);
  border: 1px solid var(--slate);
  border-radius: 20px;
  font-size: 11px;
  font-weight: 600;
  color: var(--blue-dark);
  padding: 2px 10px;
}

.unique-pill {
  display: inline-block;
  background: rgba(130, 181, 65, .2);
  color: var(--green);
  font-size: 11px;
  font-weight: 700;
  padding: 4px 12px;
  border-radius: 20px;
  letter-spacing: .06em;
  text-transform: uppercase;
  margin-top: 8px;
}

.option-tag {
  display: inline-block;
  font-family: 'Plus Jakarta Sans', sans-serif;
  font-size: 10px;
  font-weight: 700;
  letter-spacing: .1em;
  text-transform: uppercase;
  color: #747474;
  background: #e5e5e5;
  padding: 3px 10px;
  border-radius: 3px;
  margin-bottom: 28px;
}

a.option-tag {
  text-decoration: none;
  color: #747474;
  transition: color .15s, background .15s;
}

a.option-tag:hover {
  color: var(--blue-dark);
  background: var(--blue-light);
}

.option-tag.child {
  margin-left: 0;
  margin-bottom: 0;
  background: #8bb52a;
  color: #fff;
}


/* --- Cards --- */

.card-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(280px, 1fr));
  gap: 16px;
  margin-top: 32px;
}

.card {
  background: white;
  border: 1px solid var(--border);
  border-radius: 10px;
  padding: 28px;
  transition: box-shadow .2s, border-color .2s;
}

.card:hover {
  border-color: var(--blue);
  box-shadow: 0 4px 16px rgba(65,154,210,.15);
}

.card.highlighted {
  border-color: var(--blue);
  background: var(--blue-light);
}

.card-icon {
  width: 40px;
  height: 40px;
  background: var(--blue-light);
  border-radius: var(--radius-md);
  display: flex;
  align-items: center;
  justify-content: center;
  margin-bottom: 12px;
}

.card.highlighted .card-icon {
  background: white;
}

.card-icon svg {
  width: 20px;
  height: 20px;
  stroke: var(--blue);
  fill: none;
  stroke-width: 1.75;
  stroke-linecap: round;
  stroke-linejoin: round;
}

.card.highlighted .card-icon svg {
  stroke: var(--blue-dark);
}

.card-label {
  font-size: 11px;
  font-weight: 700;
  letter-spacing: .09em;
  text-transform: uppercase;
  color: var(--steel);
  margin-bottom: 8px;
}

.card.highlighted .card-label {
  color: var(--blue-dark);
}

.card h3 {
  font-size: 17px;
  font-weight: 600;
  color: var(--charcoal);
  margin-bottom: 8px;
}

.card p {
  font-size: 14px;
  color: var(--charcoal-mid);
  line-height: 1.65;
  margin-bottom: 10px;
}

.card .card-fine {
  font-size: 12px;
  color: var(--steel);
  font-style: italic;
  margin-top: 4px;
}

.card .card-link {
  font-size: 13px;
  font-weight: 600;
  color: var(--blue-dark);
  text-decoration: none;
  display: inline-flex;
  align-items: center;
  gap: 4px;
  margin-top: 6px;
}

.card .card-link:hover {
  text-decoration: underline;
}

.card .card-meta {
  display: flex;
  align-items: center;
  gap: 8px;
  margin-top: 12px;
  padding-top: 12px;
  border-top: 1px solid var(--border);
  font-size: 12px;
  color: var(--steel);
  flex-wrap: wrap;
}

.card.highlighted .tag {
  background: white;
  border-color: var(--blue);
}

.card.highlighted .card-meta {
  border-color: rgba(65, 154, 210, .25);
}


/* --- Feature Grid --- */

.feature-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(300px, 1fr));
  gap: 1px;
  background: #E8EDF0;
  border-radius: var(--radius-lg);
  overflow: hidden;
  margin-top: 32px;
}

.feature-item {
  background: white;
  padding: 20px 24px;
}

.feature-item h3 {
  font-size: 16px;
  font-weight: 600;
  color: var(--charcoal);
  margin-bottom: 6px;
  display: flex;
  align-items: center;
  gap: 10px;
}

.feature-dot {
  width: 6px;
  height: 6px;
  background: var(--green);
  border-radius: 50%;
  flex-shrink: 0;
}

.feature-item p {
  font-size: 14px;
  color: var(--charcoal-mid);
  line-height: 1.65;
}

.plugin-note {
  font-size: 12px;
  color: var(--steel);
  font-style: italic;
  margin-top: 6px;
}

/* Feature cards (icon variants) */
.feature-demo {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 16px;
  margin-top: 20px;
}

.feature-card {
  border: 1px solid var(--border);
  border-radius: 10px;
  padding: 24px;
  position: relative;
  overflow: hidden;
}

.feature-card h3 {
  font-family: 'Plus Jakarta Sans', sans-serif;
  font-size: 15px;
  font-weight: 600;
  color: var(--charcoal);
  margin-bottom: 6px;
}

.feature-card p {
  font-size: 13px;
  color: var(--steel);
  line-height: 1.65;
}

.fc-dot-row {
  display: flex;
  align-items: center;
  gap: 10px;
  margin-bottom: 10px;
}

.fc-dot-row h3 { margin: 0; }

.fc-dot {
  width: 7px;
  height: 7px;
  background: var(--green);
  border-radius: 50%;
  flex-shrink: 0;
}

.fc-icon-box {
  width: 40px;
  height: 40px;
  background: var(--blue-light);
  border-radius: var(--radius-md);
  display: flex;
  align-items: center;
  justify-content: center;
  margin-bottom: 14px;
}

.fc-icon-box svg {
  width: 20px;
  height: 20px;
  color: var(--blue-dark);
  stroke-width: 1.75;
}

.fc-dot-icon-row {
  display: flex;
  align-items: center;
  gap: 8px;
  margin-bottom: 10px;
}

.fc-dot-icon-row h3 { margin: 0; flex: 1; }

.fc-dot-icon-row svg {
  width: 15px;
  height: 15px;
  color: var(--blue);
  opacity: .7;
  flex-shrink: 0;
  stroke-width: 2;
}

.fc-bg-icon {
  position: absolute;
  bottom: -12px;
  right: -12px;
  opacity: .07;
  pointer-events: none;
}

.fc-bg-icon svg {
  width: 72px;
  height: 72px;
  color: var(--blue-dark);
  stroke-width: 1.25;
}


/* --- Stats Bar --- */

.stats-bar {
  background: var(--charcoal);
  padding: 32px 48px;
  display: flex;
  justify-content: center;
  gap: 72px;
  flex-wrap: wrap;
}

.stat {
  text-align: center;
}

.stat-num {
  font-family: 'Plus Jakarta Sans', sans-serif;
  font-size: 32px;
  font-weight: 600;
  color: var(--green);
  line-height: 1;
}

.stat-label {
  font-size: 11px;
  color: rgba(255, 255, 255, .4);
  text-transform: uppercase;
  letter-spacing: .08em;
  margin-top: 6px;
}


/* --- Callouts --- */

.callout {
  display: flex;
  flex-direction: column;
  align-items: flex-start;
  gap: 12px;
  border-radius: 0 10px 10px 0;
  padding: 20px 24px;
  margin-bottom: 12px;
}

.callout h3 {
  font-size: 18px;
  font-weight: 600;
  margin-bottom: 10px;
}

.callout p {
  font-size: 14px;
  line-height: 1.7;
}

.callout p + p { margin: 0; }
#post-132292 .callout.callout-blue { margin-bottom: 48px; }
.page-id-132292 { background-color: #E8F5FC; }
.page-id-132292 #gform_wrapper_5 { max-width: 640px; margin: 0 auto; }
#post-132292 .callout.callout-blue p { margin: 0; }

.callout-orange {
  background: #fff7f5;
  border: 1px solid #f5cfc4;
  border-left: 4px solid var(--orange);
}

.callout-orange h3 { color: var(--charcoal); }
.callout-orange p { color: var(--charcoal-mid); }

.callout-green {
  background: var(--green-light);
  border: 1px solid rgba(130, 181, 65, .35);
  border-left: 4px solid var(--green);
}

.callout-green h3 { color: var(--green-dark); }
.callout-green p { color: #4a6a2a; }

.callout-blue {
  background: var(--blue-light);
  border: 1px solid rgba(65, 154, 210, .3);
  border-left: 4px solid var(--blue);
}

.callout-blue h3 { color: var(--blue-dark); }
.callout-blue p { color: #2a5a80; }

.callout-red {
  background: #fdecea;
  border: 1px solid rgba(192, 57, 43, .25);
  border-left: 4px solid var(--red);
}

.callout-red h3 { color: var(--red); }
.callout-red p { color: #8a2020; }

/* Callout with icon + content layout */
.callout svg {
  width: 18px;
  height: 18px;
  flex-shrink: 0;
  margin-top: 2px;
}

.callout-content h4 {
  font-family: 'Plus Jakarta Sans', sans-serif;
  font-size: 14px;
  font-weight: 600;
  margin-bottom: 4px;
}

.callout-content p {
  font-size: 13px;
  line-height: 1.6;
  margin: 0;
}

.callout-green svg { color: var(--green); }
.callout-green h4 { color: var(--green-dark); }
.callout-green .callout-content p { color: #4a6a2a; }
.callout-blue svg { color: var(--blue); }
.callout-blue h4 { color: var(--blue-dark); }
.callout-blue .callout-content p { color: #2a5a80; }
.callout-orange svg { color: var(--orange); }
.callout-orange h4 { color: var(--charcoal); }
.callout-orange .callout-content p { color: var(--charcoal-mid); }
.callout-red svg { color: var(--red); }
.callout-red h4 { color: #6c1d15; }
.callout-red .callout-content p { color: #8a2020; }

.callout-inline {
  background: var(--green-light);
  border-left: 3px solid var(--green);
  border-radius: 0 8px 8px 0;
  padding: 14px 18px;
  margin: 20px 0;
  font-size: 14px;
  color: #3a6a1a;
  line-height: 1.6;
}

.callout-inline strong { color: var(--green-dark); }


/* --- Comparison Table --- */

.table-wrap {
  overflow-x: auto;
  margin-top: 32px;
}

.table-wrap table {
  width: 100%;
  border-collapse: collapse;
  font-size: 13px;
}

.table-wrap thead th {
  background: var(--charcoal);
  color: rgba(255, 255, 255, .6);
  padding: 13px 16px;
  text-align: left;
  font-weight: 500;
  white-space: nowrap;
}

.table-wrap thead th.ours {
  background: var(--blue-dark);
  color: white;
}

.table-wrap tbody td {
  padding: 11px 16px;
  border-bottom: 1px solid #eee;
  vertical-align: middle;
}

.table-wrap tbody tr:last-child td { border-bottom: none; }
.table-wrap tbody td:first-child { font-weight: 500; color: var(--charcoal); }

.table-wrap tbody td.ours {
  background: var(--blue-light);
  font-weight: 500;
  color: var(--blue-dark);
}

.chk { color: var(--green); font-weight: 600; }
.no  { color: var(--slate); }
.warn { color: var(--orange); font-size: 12px; }

.tradeoffs {
  background: var(--blue-light);
  border-radius: 10px;
  padding: 24px 28px;
  margin-top: 20px;
}

.tradeoffs p {
  font-size: 14px;
  color: var(--charcoal-mid);
  line-height: 1.7;
}

.tradeoffs p + p { margin-top: 8px; }


/* --- Before/After --- */

.before-after {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 24px;
  margin-top: 32px;
}

.panel {
  border-radius: 10px;
  overflow: hidden;
}

.panel-label {
  padding: 10px 16px;
  font-family: 'Plus Jakarta Sans', sans-serif;
  font-size: 11px;
  font-weight: 700;
  letter-spacing: .06em;
  text-transform: uppercase;
}

.panel-before {
  background: #f8f8f8;
  border: 1px solid #ddd;
}

.panel-before .panel-label {
  background: #eee;
  color: #888;
}

.panel-after {
  background: var(--charcoal);
}

.panel-after .panel-label {
  background: rgba(65, 154, 210, .2);
  color: var(--blue);
}

.panel-content { padding: 16px; }

.vanilla-nav {
  background: #e9ecef;
  padding: 6px 10px;
  display: flex;
  gap: 12px;
  font-size: 10px;
  color: #666;
  border-bottom: 1px solid #ddd;
  margin: -16px -16px 12px;
}

.vanilla-table {
  width: 100%;
  border-collapse: collapse;
  font-size: 10px;
  color: #333;
}

.vanilla-table th {
  background: #dee2e6;
  padding: 4px 6px;
  text-align: left;
  font-weight: normal;
  border: 1px solid #ccc;
}

.vanilla-table td {
  padding: 4px 6px;
  border: 1px solid #ddd;
}

.vanilla-table tr:nth-child(even) td { background: #f8f9fa; }

/* Before/After row styles */
.awe-row {
  display: flex;
  align-items: center;
  gap: 8px;
  padding: 8px 10px;
  border-radius: 5px;
  margin-bottom: 3px;
  font-size: 11px;
}

.awe-row.urgent { background: rgba(220,53,69,.15); border-left: 3px solid #dc3545; }
.awe-row.high { background: rgba(245,92,68,.15); border-left: 3px solid var(--orange); }
.awe-row.normal { background: rgba(255,255,255,.04); border-left: 3px solid rgba(255,255,255,.1); }

.awe-dot { width: 7px; height: 7px; border-radius: 50%; flex-shrink: 0; }
.awe-dot.new-reply { background: var(--green); animation: pulse 2s infinite; }
.awe-dot.urgent { background: #dc3545; }
.awe-dot.none { background: rgba(255,255,255,.2); }

.awe-subject {
  flex: 1;
  font-weight: 500;
  overflow: hidden;
  white-space: nowrap;
  text-overflow: ellipsis;
  font-size: 11px;
  color: white;
}

.ptag {
  font-size: 9px;
  padding: 2px 6px;
  border-radius: 3px;
  font-weight: 700;
  flex-shrink: 0;
}

.ptag.urgent { background: rgba(220,53,69,.3); color: #ff8a8a; }
.ptag.new { background: rgba(130,181,65,.3); color: var(--green); }


/* --- Dark Blocks --- */

.dark-block {
  background: var(--charcoal);
  border-radius: 14px;
  padding: 56px 48px;
}

.dark-block .label { color: var(--green); }

.dark-block h2 {
  font-family: 'Plus Jakarta Sans', sans-serif;
  font-size: 34px;
  color: white;
  margin-bottom: 12px;
  line-height: 1.2;
}

.dark-block p {
  color: rgba(255, 255, 255, .65);
  font-size: 15px;
  line-height: 1.75;
  margin-bottom: 12px;
}

/* SHIFT+O keyboard demo */
.shifto-block {
  display: grid;
  grid-template-columns: 1fr auto;
  gap: 48px;
  align-items: center;
}

.kbd-demo {
  background: rgba(255, 255, 255, .06);
  border: 1px solid rgba(255, 255, 255, .1);
  border-radius: var(--radius-lg);
  padding: 32px 40px;
  text-align: center;
  flex-shrink: 0;
}

.kbd {
  display: inline-block;
  background: rgba(255, 255, 255, .12);
  border: 1px solid rgba(255, 255, 255, .25);
  border-bottom: 3px solid rgba(255, 255, 255, .12);
  border-radius: 6px;
  padding: 10px 20px;
  font-family: monospace;
  font-size: 22px;
  font-weight: 600;
  color: white;
  letter-spacing: .08em;
  margin-bottom: 14px;
}

.toggle-preview {
  display: flex;
  gap: 10px;
  margin-top: 14px;
}

.toggle-pane {
  flex: 1;
  border-radius: 6px;
  padding: 10px 12px;
  font-size: 11px;
  text-align: center;
}

.toggle-pane.ours {
  background: rgba(65, 154, 210, .15);
  border: 1px solid rgba(65, 154, 210, .3);
  color: var(--blue);
}

.toggle-pane.vanilla {
  background: rgba(255, 255, 255, .05);
  border: 1px solid rgba(255, 255, 255, .1);
  color: rgba(255, 255, 255, .4);
}

.toggle-pane-name {
  font-weight: 600;
  display: block;
  margin-bottom: 2px;
}

/* Flow diagram */
.flow-diagram {
  display: flex;
  align-items: center;
  justify-content: center;
  flex-wrap: wrap;
  margin-top: 32px;
}

.flow-step {
  background: rgba(255, 255, 255, .07);
  border: 1px solid rgba(255, 255, 255, .15);
  border-radius: 10px;
  padding: 20px 28px;
  text-align: center;
  min-width: 150px;
}

.flow-step.highlight {
  background: rgba(65, 154, 210, .15);
  border-color: rgba(65, 154, 210, .4);
}

.flow-step-icon { font-size: 24px; margin-bottom: 8px; }

.flow-step-meta {
  font-size: 10px;
  color: rgba(255, 255, 255, .4);
  text-transform: uppercase;
  letter-spacing: .06em;
  margin-bottom: 4px;
}

.flow-step-name { font-size: 14px; font-weight: 500; color: white; }
.flow-step.highlight .flow-step-name { color: var(--blue); }

.flow-arrow {
  color: var(--blue);
  font-size: 22px;
  padding: 0 10px;
  opacity: .7;
}


/* --- Accordions --- */

.accordion {
  display: flex;
  flex-direction: column;
  border: 1px solid var(--border);
  border-radius: 10px;
  overflow: hidden;
  background: white;
}

.accordion-item {
  border-bottom: 1px solid var(--border);
}

.accordion-item:last-child { border-bottom: none; }

.accordion-trigger {
  all: unset;
  box-sizing: border-box;
  width: 100%;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 16px;
  padding: 22px 28px;
  background: white;
  cursor: pointer;
  text-align: left;
  font-family: 'Plus Jakarta Sans', sans-serif;
  font-size: 16px;
  font-weight: 600;
  color: var(--charcoal);
  line-height: 1.4;
  transition: background .2s, color .2s;
}

.accordion-trigger:hover {
  background: var(--blue-light);
  color: var(--blue-dark);
}

.accordion-trigger.open {
  background: var(--blue-light);
  color: var(--blue-dark);
}

.accordion-icon {
  flex-shrink: 0;
  width: 20px;
  height: 20px;
  color: var(--steel);
  transition: transform .3s ease, color .2s;
}

.accordion-trigger.open .accordion-icon {
  transform: rotate(45deg);
  color: var(--blue);
}

.accordion-body {
  display: grid;
  grid-template-rows: 0fr;
  transition: grid-template-rows .3s ease;
}

.accordion-body.open {
  grid-template-rows: 1fr;
}

.accordion-body-inner {
  overflow: hidden;
}

.accordion-body-content {
  padding: 20px 28px 24px;
  font-size: 15px;
  line-height: 1.75;
  color: var(--charcoal-mid);
  border-top: 1px solid var(--border);
}

.accordion-body-content p + p { margin-top: 12px; }

/* Version pills (inside accordions) */
.version-list {
  display: flex;
  flex-wrap: wrap;
  gap: 6px;
  margin-top: 12px;
}

.version-pill {
  background: var(--blue-light);
  border: 1px solid var(--slate);
  border-radius: 20px;
  font-size: 12px;
  font-weight: 600;
  color: var(--blue-dark);
  padding: 3px 12px;
  font-family: 'Plus Jakarta Sans', sans-serif;
}

.version-pill.latest {
  background: var(--green);
  border-color: var(--green);
  color: white;
}

/* Minimal accordion variant */
.accordion-minimal {
  border: none;
  border-radius: 0;
}

.accordion-minimal .accordion-item {
  border-bottom: 1px solid var(--border);
}

.accordion-minimal .accordion-item:first-child {
  border-top: 1px solid var(--border);
}

.accordion-minimal .accordion-trigger {
  background: transparent;
  padding: 20px 0;
}

.accordion-minimal .accordion-trigger:hover,
.accordion-minimal .accordion-trigger.open {
  background: transparent;
  color: var(--blue);
}

.accordion-minimal .accordion-body-content {
  border-top: none;
  padding: 0 0 20px;
}


/* --- Forms --- */


.states-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(260px, 1fr));
  gap: 20px;
}
.field { margin-bottom: 20px; }

/* Form input enhancements */
input::placeholder,
textarea::placeholder { color: var(--steel); }

input:hover,
textarea:hover,
select:hover { border-color: var(--steel); }

textarea { resize: vertical; min- line-height: 1.6; }

input:disabled,
textarea:disabled,
select:disabled {
  background: var(--blue-light);
  color: var(--steel);
  border-color: var(--border);
  cursor: not-allowed;
}

.field-row {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 20px;
  margin-bottom: 20px;
}

.field label {
  display: block;
  font-family: 'Plus Jakarta Sans', sans-serif;
  font-size: 13px;
  font-weight: 600;
  color: var(--charcoal);
  margin-bottom: 6px;
}

.field label .required { color: var(--orange); margin-left: 2px; }
.field label .optional { color: var(--steel); font-weight: 400; margin-left: 4px; font-size: 12px; }

.help-text {
  font-size: 12px;
  color: var(--steel);
  margin-top: 5px;
  line-height: 1.5;
}

/* Input with icon */
.input-wrap { position: relative; }
.input-wrap input { padding-left: 38px; }

.input-wrap .input-icon {
  position: absolute;
  left: 12px;
  top: 50%;
  transform: translateY(-50%);
  width: 16px;
  height: 16px;
  color: var(--steel);
  pointer-events: none;
}

.input-wrap.has-suffix input { padding-right: 38px; }

.input-suffix {
  position: absolute;
  right: 12px;
  top: 50%;
  transform: translateY(-50%);
  font-size: 13px;
  color: var(--steel);
}

/* Select wrapper */
.select-wrap { position: relative; }
.select-wrap select { padding-right: 36px; cursor: pointer; }

.select-wrap::after {
  content: '';
  position: absolute;
  right: 14px;
  top: 50%;
  transform: translateY(-50%);
  width: 0;
  height: 0;
  border-left: 4px solid transparent;
  border-right: 4px solid transparent;
  border-top: 5px solid var(--steel);
  pointer-events: none;
}

/* Validation states */
.field.success input,
.field.success textarea,
.field.success select {
  border-color: var(--green);
  background: var(--green-light);
}

.field.success input:focus,
.field.success textarea:focus {
  box-shadow: 0 0 0 3px rgba(130, 181, 65, .15);
}

.field.error input,
.field.error textarea,
.field.error select {
  border-color: var(--red);
  background: var(--red-light);
}

.field.error input:focus,
.field.error textarea:focus {
  box-shadow: 0 0 0 3px rgba(192, 57, 43, .12);
}

.field-message {
  display: flex;
  align-items: center;
  gap: 5px;
  font-size: 12px;
  margin-top: 5px;
  line-height: 1.4;
}

.field-message svg { width: 13px; height: 13px; flex-shrink: 0; }
.field.error .field-message { color: var(--red); }
.field.success .field-message { color: var(--green); }

/* Checkbox & radio */
.check-group,
.radio-group {
  display: flex;
  flex-direction: column;
  gap: 10px;
}

.check-item,
.radio-item {
  display: flex;
  align-items: flex-start;
  gap: 10px;
  cursor: pointer;
}

.check-item input[type="checkbox"],
.radio-item input[type="radio"] {
  width: 17px;
  height: 17px;
  min-width: 17px;
  margin-top: 2px;
  padding: 0;
  border: 1.5px solid var(--border);
  border-radius: 3px;
  background: white;
  cursor: pointer;
  accent-color: var(--blue);
}

.radio-item input[type="radio"] { border-radius: 50%; }

.check-item label,
.radio-item label {
  font-size: 14px;
  font-weight: 400;
  color: var(--charcoal-mid);
  margin: 0;
  cursor: pointer;
  line-height: 1.5;
}

.check-item label strong,
.radio-item label strong {
  color: var(--charcoal);
  font-weight: 600;
}

/* File upload */
.file-upload {
  border: 2px dashed var(--border);
  border-radius: var(--radius-md);
  padding: 28px;
  text-align: center;
  cursor: pointer;
  transition: border-color .15s, background .15s;
}

.file-upload:hover {
  border-color: var(--blue);
  background: var(--blue-light);
}

.file-upload input[type="file"] { display: none; }

.file-upload-icon { color: var(--steel); margin-bottom: 10px; }
.file-upload-icon svg { width: 32px; height: 32px; }
.file-upload p { font-size: 14px; color: var(--charcoal-mid); margin-bottom: 4px; }
.file-upload p strong { color: var(--blue); }
.file-upload small { font-size: 12px; color: var(--steel); }

/* Form card layout */
.form-card {
  background: white;
  border: 1px solid var(--border);
  border-radius: 10px;
  padding: 36px;
}

.form-card h3 {
  font-family: 'Plus Jakarta Sans', sans-serif;
  font-size: 20px;
  font-weight: 700;
  color: var(--charcoal);
  letter-spacing: -.01em;
  margin-bottom: 6px;
}

.form-card .form-subtitle {
  font-size: 14px;
  color: var(--steel);
  margin-bottom: 28px;
  padding-bottom: 24px;
  border-bottom: 1px solid var(--border);
}

.form-actions {
  display: flex;
  gap: 12px;
  align-items: center;
  margin-top: 28px;
  padding-top: 24px;
  border-top: 1px solid var(--border);
}


/* --- Stats & Credibility --- */

.section-intro {
  font-size: 15px;
  color: var(--charcoal-mid);
  line-height: 1.75;
  max-width: 640px;
  margin-bottom: 32px;
}

/* Variant A — Four stats in a row */
.stats-row-a {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 0;
  border: 1px solid var(--border);
  border-radius: 10px;
  overflow: hidden;
}

.stat-a {
  padding: 32px 24px;
  text-align: center;
  border-right: 1px solid var(--border);
}

.stat-a:last-child { border-right: none; }

.stat-a-num {
  font-family: 'Plus Jakarta Sans', sans-serif;
  font-size: 36px;
  font-weight: 700;
  color: var(--blue-dark);
  line-height: 1;
  letter-spacing: -.02em;
}

.stat-a-label {
  font-size: 13px;
  color: var(--steel);
  margin-top: 8px;
  line-height: 1.4;
}

/* Variant B — Stats with supporting copy */
.stats-b {
  display: grid;
  grid-template-columns: auto 1fr;
  gap: 64px;
  align-items: center;
  padding: 48px;
  background: var(--blue-light);
  border-radius: 14px;
}

.stats-b-numbers {
  display: flex;
  flex-direction: column;
  gap: 32px;
}

.stat-b-num {
  font-family: 'Plus Jakarta Sans', sans-serif;
  font-size: 42px;
  font-weight: 700;
  color: var(--blue-dark);
  line-height: 1;
  letter-spacing: -.02em;
}

.stat-b-label {
  font-size: 13px;
  color: var(--steel);
  margin-top: 4px;
}

.stats-b-copy h3 {
  font-family: 'Plus Jakarta Sans', sans-serif;
  font-size: 22px;
  font-weight: 700;
  color: var(--charcoal);
  letter-spacing: -.01em;
  margin-bottom: 12px;
}

.stats-b-copy p {
  font-size: 15px;
  color: var(--charcoal-mid);
  line-height: 1.75;
}

.stats-b-copy p + p { margin-top: 12px; }

/* Variant C — Inline stats strip */
.stats-c {
  display: flex;
  gap: 40px;
  flex-wrap: wrap;
  padding: 28px 0;
  border-top: 1px solid var(--border);
  border-bottom: 1px solid var(--border);
  margin: 32px 0;
}

.stat-c {
  display: flex;
  align-items: baseline;
  gap: 8px;
}

.stat-c-num {
  font-family: 'Plus Jakarta Sans', sans-serif;
  font-size: 28px;
  font-weight: 700;
  color: var(--charcoal);
  letter-spacing: -.02em;
}

.stat-c-label {
  font-size: 13px;
  color: var(--steel);
}

/* Variant D — Stats + icon cards */
.stats-d {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 16px;
}

.stat-d {
  background: white;
  border: 1px solid var(--border);
  border-radius: 10px;
  padding: 24px;
}

.stat-d-icon {
  width: 36px;
  height: 36px;
  background: var(--blue-light);
  border-radius: var(--radius-md);
  display: flex;
  align-items: center;
  justify-content: center;
  margin-bottom: 12px;
}

.stat-d-icon svg {
  width: 18px;
  height: 18px;
  color: var(--blue-dark);
}

.stat-d-num {
  font-family: 'Plus Jakarta Sans', sans-serif;
  font-size: 32px;
  font-weight: 700;
  color: var(--charcoal);
  line-height: 1;
  letter-spacing: -.02em;
  margin-bottom: 6px;
}

.stat-d-label {
  font-size: 13px;
  color: var(--steel);
  line-height: 1.4;
}

/* Variant E — Green accent numbers, centered */
.stats-e {
  text-align: center;
  padding: 48px 0;
}

.stats-e-eyebrow {
  font-family: 'Plus Jakarta Sans', sans-serif;
  font-size: 12px;
  font-weight: 700;
  letter-spacing: .09em;
  text-transform: uppercase;
  color: var(--steel);
  margin-bottom: 32px;
}

.stats-e-grid {
  display: flex;
  justify-content: center;
  gap: 64px;
  flex-wrap: wrap;
}

.stat-e-num {
  font-family: 'Plus Jakarta Sans', sans-serif;
  font-size: 48px;
  font-weight: 700;
  color: var(--green);
  line-height: 1;
  letter-spacing: -.02em;
}

.stat-e-label {
  font-size: 13px;
  color: var(--steel);
  margin-top: 8px;
}

/* Variant F — Credibility with context copy */
.stats-f {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 32px;
}

.stat-f {
  padding: 28px 0;
  border-top: 3px solid var(--blue);
}

.stat-f-num {
  font-family: 'Plus Jakarta Sans', sans-serif;
  font-size: 40px;
  font-weight: 700;
  color: var(--charcoal);
  line-height: 1;
  letter-spacing: -.02em;
  margin-bottom: 8px;
}

.stat-f-label {
  font-size: 15px;
  font-weight: 600;
  color: var(--charcoal);
  margin-bottom: 6px;
  font-family: 'Plus Jakarta Sans', sans-serif;
}

.stat-f-detail {
  font-size: 13px;
  color: var(--steel);
  line-height: 1.6;
}

/* Variant G — Dark bg stats */
.stats-g {
  background: var(--charcoal);
  border-radius: 14px;
  padding: 40px 48px;
  display: flex;
  justify-content: space-between;
  gap: 32px;
  flex-wrap: wrap;
}

.stat-g { text-align: center; }

.stat-g-num {
  font-family: 'Plus Jakarta Sans', sans-serif;
  font-size: 36px;
  font-weight: 700;
  color: var(--green);
  line-height: 1;
  letter-spacing: -.02em;
}

.stat-g-label {
  font-size: 11px;
  color: rgba(255, 255, 255, .4);
  text-transform: uppercase;
  letter-spacing: .08em;
  margin-top: 6px;
}


/* --- Testimonials --- */

/* Attribution */
.attr {
  margin-top: 16px;
  display: flex;
  align-items: center;
  gap: 12px;
}

.attr-name {
  font-family: 'Plus Jakarta Sans', sans-serif;
  font-size: 14px;
  font-weight: 700;
  color: var(--charcoal);
}

.attr-role {
  font-size: 13px;
  color: var(--steel);
  margin-top: 1px;
}

/* Stars */
.stars {
  display: flex;
  gap: 2px;
  margin-bottom: 14px;
}

.stars svg {
  width: 14px;
  height: 14px;
  fill: #F0B429;
  color: #F0B429;
}

/* Avatar */
.avatar {
  width: 44px;
  height: 44px;
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
  font-family: 'Plus Jakarta Sans', sans-serif;
  font-size: 15px;
  font-weight: 700;
  color: white;
  flex-shrink: 0;
}

.avatar-row {
  display: flex;
  gap: 20px;
  align-items: flex-start;
  flex-wrap: wrap;
  margin-top: 20px;
}

.avatar-group {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 6px;
}

.avatar-name {
  font-size: 12px;
  color: var(--steel);
}

/* Variant A — Bordered cards, 3-up grid */
.cards-3 {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 20px;
}

.t-card {
  background: white;
  border: 1px solid var(--border);
  border-radius: 10px;
  padding: 28px;
}

.t-card blockquote {
  font-size: 15px;
  line-height: 1.75;
  color: var(--charcoal-mid);
  font-style: italic;
}

.t-card blockquote::before {
  content: '\201C';
  font-size: 40px;
  line-height: 0;
  vertical-align: -14px;
  color: var(--slate);
  font-style: normal;
  margin-right: 2px;
}

/* Variant B — Featured single quote */
.t-featured {
  background: var(--blue-light);
  border-radius: 14px;
  padding: 56px 64px;
  position: relative;
}

.t-featured::before {
  content: '\201C';
  position: absolute;
  top: 24px;
  left: 40px;
  font-size: 120px;
  line-height: 1;
  color: var(--slate);
  font-family: Georgia, serif;
  opacity: .5;
}

.t-featured blockquote {
  font-family: 'Plus Jakarta Sans', sans-serif;
  font-size: 22px;
  font-weight: 500;
  line-height: 1.55;
  color: var(--charcoal);
  font-style: italic;
  position: relative;
  z-index: 1;
  max-width: 760px;
}

/* Variant C — Dark background, centered */
.t-dark {
  background: var(--charcoal);
  border-radius: 14px;
  padding: 64px 48px;
  text-align: center;
}

.t-dark blockquote {
  font-family: 'Plus Jakarta Sans', sans-serif;
  font-size: 20px;
  font-weight: 500;
  line-height: 1.6;
  color: rgba(255, 255, 255, .85);
  font-style: italic;
  max-width: 680px;
  margin: 0 auto;
}

.t-dark .attr { justify-content: center; }
.t-dark .attr-name { color: white; }
.t-dark .attr-role { color: rgba(255, 255, 255, .45); }

/* Variant D — Left-border pull quote */
.t-pull {
  border-left: 4px solid var(--blue);
  padding: 8px 0 8px 28px;
}

.t-pull blockquote {
  font-family: 'Plus Jakarta Sans', sans-serif;
  font-size: 18px;
  font-weight: 500;
  line-height: 1.6;
  color: var(--charcoal);
  font-style: italic;
  margin-bottom: 12px;
}

.t-pull .attr { margin-top: 0; }

/* Variant E — Two-column asymmetric */
.t-asymm {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 32px;
  align-items: start;
}

.t-asymm-primary {
  background: var(--charcoal);
  border-radius: var(--radius-lg);
  padding: 40px;
}

.t-asymm-primary blockquote {
  font-family: 'Plus Jakarta Sans', sans-serif;
  font-size: 18px;
  font-weight: 500;
  line-height: 1.65;
  color: rgba(255, 255, 255, .85);
  font-style: italic;
  margin-bottom: 20px;
}

.t-asymm-primary .attr-name { color: white; }
.t-asymm-primary .attr-role { color: rgba(255, 255, 255, .45); }

.t-asymm-secondary {
  display: flex;
  flex-direction: column;
  gap: 16px;
}

.t-card-sm {
  background: white;
  border: 1px solid var(--border);
  border-radius: 10px;
  padding: 22px 24px;
}

.t-card-sm blockquote {
  font-size: 14px;
  line-height: 1.7;
  color: var(--charcoal-mid);
  font-style: italic;
  margin-bottom: 14px;
}

.t-card-sm blockquote::before {
  content: '\201C';
  font-size: 28px;
  line-height: 0;
  vertical-align: -10px;
  color: var(--slate);
  font-style: normal;
  margin-right: 2px;
}

.t-card-sm .avatar { width: 36px; height: 36px; font-size: 13px; }
.t-card-sm .attr-name { font-size: 13px; }
.t-card-sm .attr-role { font-size: 12px; }


/* --- Trust Strip --- */

.trust-strip {
  max-width: 1100px;
  margin: 60px auto;
  padding: 0 24px;
  text-align: center;
}

.trust-strip__heading {
  font-size: 15px;
  font-weight: 500;
  letter-spacing: 0.02em;
  color: #6b7280;
  margin-bottom: 40px;
  text-transform: uppercase;
}

.trust-strip__logos {
  display: flex;
  align-items: center;
  justify-content: center;
  flex-wrap: wrap;
  gap: 40px 52px;
}

.trust-strip__logo {
  display: flex;
  align-items: center;
  justify-content: center;
  flex-shrink: 0;
}

.trust-strip__logo img {
  display: block;
  width: auto;
  filter: grayscale(100%);
  opacity: 0.7;
  transition: opacity 0.3s ease, filter 0.3s ease;
}

.trust-strip__logo img:hover { opacity: 1; }

/* Per-logo height tuning */
.trust-strip__logo--bmw img { height: 90px; }
.trust-strip__logo.trust-strip__logo--bmw img { opacity: 0.65; }
.trust-strip__logo--booz img { height: 39px; }
.trust-strip__logo.trust-strip__logo--booz img { opacity: 0.8; }
.trust-strip__logo--lindt img { height: 51px; }
.trust-strip__logo--texas-dps img { height: 100px; }
.trust-strip__logo--cambridge img { height: 100px; }
.trust-strip__logo.trust-strip__logo--cambridge img { opacity: 0.9; }
.trust-strip__logo--oxford img { height: 64px; }
.trust-strip__logo.trust-strip__logo--oxford img { opacity: 0.9; }

@media (max-width: 768px) {
  .trust-strip__logos { gap: 28px 36px; }
  .trust-strip__logo--bmw img { height: 68px; }
  .trust-strip__logo--booz img { height: 30px; }
  .trust-strip__logo--lindt img { height: 38px; }
  .trust-strip__logo--texas-dps img { height: 75px; }
  .trust-strip__logo--cambridge img { height: 75px; }
  .trust-strip__logo--oxford img { height: 48px; }
}


/* --- Secondary CTAs --- */

/* Variant A — Inline banner, white bg */
.cta-a {
  border: 1px solid var(--border);
  border-radius: 10px;
  padding: 32px 40px;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 32px;
  flex-wrap: wrap;
}

.cta-a-text h3 {
  font-family: 'Plus Jakarta Sans', sans-serif;
  font-size: 18px;
  font-weight: 700;
  color: var(--charcoal);
  letter-spacing: -.01em;
  margin-bottom: 4px;
}

.cta-a-text p {
  font-size: 14px;
  color: var(--steel);
}

/* Variant B — Alice Blue full-width band */
.cta-b {
  background: var(--blue-light);
  padding: 48px 0;
  text-align: center;
}

.cta-b h3 {
  font-family: 'Plus Jakarta Sans', sans-serif;
  font-size: 24px;
  font-weight: 700;
  color: var(--charcoal);
  letter-spacing: -.02em;
  margin-bottom: 8px;
}

.cta-b p {
  font-size: 15px;
  color: var(--charcoal-mid);
  margin-bottom: 28px;
  max-width: 500px;
  margin-left: auto;
  margin-right: auto;
}

.cta-b .pricing-note {
  font-size: 13px;
  color: var(--steel);
  margin-top: 16px;
}

/* Variant C — Blue background band */
.cta-c {
  background: var(--blue-dark);
  padding: 48px 0;
  text-align: center;
}

.cta-c h3 {
  font-family: 'Plus Jakarta Sans', sans-serif;
  font-size: 24px;
  font-weight: 700;
  color: white;
  letter-spacing: -.02em;
  margin-bottom: 8px;
}

.cta-c p {
  font-size: 15px;
  color: rgba(255, 255, 255, .7);
  margin-bottom: 28px;
  max-width: 500px;
  margin-left: auto;
  margin-right: auto;
}

.cta-c .pricing-note {
  font-size: 13px;
  color: rgba(255, 255, 255, .4);
  margin-top: 16px;
  font-weight: 100;
}

/* Variant D — Split: text left, buttons right, Alice Blue */
.cta-d {
  background: var(--blue-light);
  padding: 48px 0;
}

.cta-d-inner {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 40px;
  flex-wrap: wrap;
}

.cta-d h3 {
  font-family: 'Plus Jakarta Sans', sans-serif;
  font-size: 22px;
  font-weight: 700;
  color: var(--charcoal);
  letter-spacing: -.01em;
  margin-bottom: 6px;
}

.cta-d p {
  font-size: 14px;
  color: var(--charcoal-mid);
  max-width: 460px;
  line-height: 1.6;
}

/* Variant E — Charcoal, split layout */
.cta-e {
  background: var(--charcoal);
  padding: 48px 0;
}

.cta-e-inner {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 40px;
  flex-wrap: wrap;
}

.cta-e h3 {
  font-family: 'Plus Jakarta Sans', sans-serif;
  font-size: 22px;
  font-weight: 700;
  color: white;
  letter-spacing: -.01em;
  margin-bottom: 6px;
}

.cta-e p {
  font-size: 14px;
  color: rgba(255, 255, 255, .55);
  max-width: 460px;
  line-height: 1.6;
}

/* Variant F — Minimal inline, borderless */
.cta-f {
  padding: 32px 0;
  display: flex;
  align-items: center;
  gap: 24px;
  border-top: 1px solid var(--border);
  border-bottom: 1px solid var(--border);
}

.cta-f p {
  font-size: 15px;
  color: var(--charcoal-mid);
  flex: 1;
}

.cta-f p strong { color: var(--charcoal); }

/* Variant G — Card with icon, centered, Alice Blue bg */
.cta-g {
  background: var(--blue-light);
  border-radius: 14px;
  padding: 48px;
  text-align: center;
  border: 1px solid var(--slate);
}

.cta-g-icon {
  width: 56px;
  height: 56px;
  background: white;
  border-radius: var(--radius-lg);
  display: flex;
  align-items: center;
  justify-content: center;
  margin: 0 auto 20px;
  border: 1px solid var(--border);
}

.cta-g-icon svg {
  width: 26px;
  height: 26px;
  color: var(--blue-dark);
}

.cta-g h3 {
  font-family: 'Plus Jakarta Sans', sans-serif;
  font-size: 22px;
  font-weight: 700;
  color: var(--charcoal);
  letter-spacing: -.01em;
  margin-bottom: 8px;
}

.cta-g p {
  font-size: 15px;
  color: var(--charcoal-mid);
  max-width: 420px;
  margin: 0 auto 28px;
  line-height: 1.7;
}

.cta-g .pricing-note {
  font-size: 12px;
  color: var(--steel);
  margin-top: 14px;
}

/* Footer CTA */
.footer-cta {
  background: var(--charcoal);
  padding: 80px 48px;
  text-align: center;
}

.footer-cta h2 {
  font-family: 'Plus Jakarta Sans', sans-serif;
  font-size: 42px;
  color: white;
  margin-bottom: 12px;
}

.footer-cta p {
  color: rgba(255, 255, 255, .6);
  font-size: 16px;
  margin-bottom: 32px;
  max-width: 500px;
  margin-left: auto;
  margin-right: auto;
}

.footer-cta .btn-row { justify-content: center; }

.pricing-note {
  margin-top: 24px;
  color: rgba(255, 255, 255, .67);
  font-size: 14px;
  font-weight: 100;
}


/* --- Split Layouts --- */

.split {
  max-width: 1100px;
  margin: 0 auto;
  padding: 80px 48px;
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 80px;
  align-items: center;
}

.split.reverse { direction: rtl; }
.split.reverse > * { direction: ltr; }
.split.narrow-gap { gap: 56px; }
.split.wide { grid-template-columns: 5fr 4fr; }
.split.wide-reverse { grid-template-columns: 4fr 5fr; }

.split-visual { position: relative; }

h2.split-heading {
  font-family: 'Plus Jakarta Sans', sans-serif;
  font-size: 32px;
  font-weight: 700;
  line-height: 1.12;
  color: var(--charcoal);
  letter-spacing: -.02em;
  margin-bottom: 12px;
}

.split-body,
.split-body button,
.split-body input,
.split-body select,
.split-body textarea {
  font-family: 'DM Sans', sans-serif;
  font-size: 16px;
  color: var(--charcoal-mid);
  line-height: 1.75;
  margin-bottom: 12px;
  max-width: 520px;
}

.split-body + .split-body,
.split-body + .split-body button,
.split-body + .split-body input,
.split-body + .split-body select,
.split-body + .split-body textarea {
  font-family: 'DM Sans', sans-serif; margin-top: -4px; }

.split-fine {
  font-size: 13px;
  color: var(--steel);
  line-height: 1.65;
  margin-bottom: 12px;
  max-width: 480px;
}

/* Feature list (check marks) */
.feature-list {
  display: flex;
  flex-direction: column;
  gap: 12px;
  margin: 20px 0;
}

.feature-list-item {
  display: flex;
  align-items: flex-start;
  gap: 12px;
  font-size: 15px;
  color: var(--charcoal-mid);
  line-height: 1.5;
}

.feature-list-item svg {
  width: 16px;
  height: 16px;
  color: var(--green);
  flex-shrink: 0;
  margin-top: 2px;
}

/* Stat pills */
.stat-pills {
  display: flex;
  gap: 12px;
  flex-wrap: wrap;
  margin: 20px 0;
}

.stat-pill {
  background: var(--blue-light);
  border: 1px solid var(--slate);
  border-radius: var(--radius-md);
  padding: 14px 20px;
}

.stat-pill-num {
  font-family: 'Plus Jakarta Sans', sans-serif;
  font-size: 24px;
  font-weight: 700;
  color: var(--blue-dark);
  line-height: 1;
}

.stat-pill-label {
  font-size: 12px;
  color: var(--steel);
  margin-top: 4px;
}

/* Section backgrounds for splits */
.section-alt { background: var(--blue-light); }

.section-dark { background: var(--charcoal); }
.section-dark .split-heading,
.section-dark h2.split-heading { color: white; }
.section-dark .split-body,
button,
input,
select,
textarea {
  font-family: 'DM Sans', sans-serif; color: rgba(255, 255, 255, .65); }
.section-dark .split-fine { color: rgba(255, 255, 255, .4); }
.section-dark .label { color: var(--green); }
.section-dark .feature-list-item { color: rgba(255, 255, 255, .65); }
.section-dark .callout-inline { background: rgba(130, 181, 65, .12); border-color: var(--green); color: rgba(255, 255, 255, .75); }
.section-dark .callout-inline strong { color: var(--green); }


/* --- Background Options --- */

/* Page mock container */
.page-mock {
  max-width: 900px;
  margin: 40px auto;
  display: flex;
  flex-direction: column;
  gap: 0;
  border: 1px solid rgba(0,0,0,.12);
  border-radius: 12px;
  overflow: hidden;
  box-shadow: 0 8px 40px rgba(0,0,0,.15);
}

.section-mock {
  padding: 52px 64px;
  position: relative;
}

.section-tag {
  position: absolute;
  top: 16px;
  right: 20px;
  font-size: 10px;
  font-weight: 700;
  letter-spacing: .08em;
  text-transform: uppercase;
  opacity: .5;
  font-family: monospace;
}

.section-h2 {
  font-family: 'Plus Jakarta Sans', sans-serif;
  font-size: 32px;
  font-weight: 600;
  line-height: 1.18;
  margin-bottom: 12px;
}

.section-body {
  font-size: 15px;
  line-height: 1.75;
  max-width: 520px;
}

.mini-cards {
  display: flex;
  gap: 12px;
  margin-top: 24px;
}

.mini-card {
  flex: 1;
  border-radius: 8px;
  padding: 16px;
  font-size: 13px;
}

.btn-mock {
  display: inline-block;
  padding: 11px 24px;
  border-radius: 4px;
  font-size: 14px;
  font-weight: 600;
  margin-top: 24px;
}

/* Light section backgrounds */
.s-white { background: #ffffff; }
.s-white .section-h2 { color: var(--charcoal); }
.s-white .section-body { color: var(--charcoal-mid); }
.s-white .section-tag { color: #999; }
.s-white .mini-card { background: var(--blue-light); border: 1px solid var(--border); color: var(--charcoal-mid); }
.s-white .mini-card strong { color: var(--charcoal); display: block; margin-bottom: 4px; font-size: 14px; }

.s-blue-light { background: var(--blue-light); }
.s-blue-light .section-h2 { color: var(--charcoal); }
.s-blue-light .section-body { color: var(--charcoal-mid); }
.s-blue-light .section-tag { color: #999; }
.s-blue-light .mini-card { background: white; border: 1px solid var(--border); color: var(--charcoal-mid); }
.s-blue-light .mini-card strong { color: var(--charcoal); display: block; margin-bottom: 4px; font-size: 14px; }

.s-green-light { background: var(--green-light); }
.s-green-light .eyebrow { color: var(--green-dark); }
.s-green-light .section-h2 { color: var(--charcoal); }
.s-green-light .section-body { color: var(--charcoal-mid); }
.s-green-light .section-tag { color: #8a9a6a; }
.s-green-light .mini-card { background: white; border: 1px solid rgba(130,181,65,.3); color: var(--charcoal-mid); }
.s-green-light .mini-card strong { color: var(--charcoal); display: block; margin-bottom: 4px; font-size: 14px; }

.s-cream { background: #FAF8F4; }
.s-cream .section-h2 { color: var(--charcoal); }
.s-cream .section-body { color: var(--charcoal-mid); }
.s-cream .section-tag { color: #bbb; }
.s-cream .mini-card { background: white; border: 1px solid #e8e2d8; color: var(--charcoal-mid); }
.s-cream .mini-card strong { color: var(--charcoal); display: block; margin-bottom: 4px; font-size: 14px; }

.s-orange-light { background: #FFF7F5; }
.s-orange-light .eyebrow { color: var(--orange); }
.s-orange-light .section-h2 { color: var(--charcoal); }
.s-orange-light .section-body { color: var(--charcoal-mid); }
.s-orange-light .section-tag { color: #c4a090; }
.s-orange-light .mini-card { background: white; border: 1px solid #f5d8cc; color: var(--charcoal-mid); }
.s-orange-light .mini-card strong { color: var(--charcoal); display: block; margin-bottom: 4px; font-size: 14px; }

/* Dark section backgrounds */
.s-charcoal { background: var(--charcoal); }
.s-charcoal .eyebrow { color: var(--green); }
.s-charcoal .section-h2 { color: white; }
.s-charcoal .section-body { color: rgba(255,255,255,.6); }
.s-charcoal .section-tag { color: rgba(255,255,255,.25); }
.s-charcoal .mini-card { background: rgba(255,255,255,.07); border: 1px solid rgba(255,255,255,.12); color: rgba(255,255,255,.6); }
.s-charcoal .mini-card strong { color: white; display: block; margin-bottom: 4px; font-size: 14px; }

.s-blue-dark { background: var(--blue-dark); }
.s-blue-dark .eyebrow { color: rgba(255,255,255,.5); }
.s-blue-dark .section-h2 { color: white; }
.s-blue-dark .section-body { color: rgba(255,255,255,.7); }
.s-blue-dark .section-tag { color: rgba(255,255,255,.3); }
.s-blue-dark .mini-card { background: rgba(255,255,255,.1); border: 1px solid rgba(255,255,255,.15); color: rgba(255,255,255,.7); }
.s-blue-dark .mini-card strong { color: white; display: block; margin-bottom: 4px; font-size: 14px; }

.s-forest { background: #1E2A1E; }
.s-forest .eyebrow { color: var(--green); }
.s-forest .section-h2 { color: white; }
.s-forest .section-body { color: rgba(255,255,255,.6); }
.s-forest .section-tag { color: rgba(255,255,255,.2); }
.s-forest .mini-card { background: rgba(255,255,255,.07); border: 1px solid rgba(130,181,65,.2); color: rgba(255,255,255,.6); }
.s-forest .mini-card strong { color: white; display: block; margin-bottom: 4px; font-size: 14px; }

/* Token reference notes panel */
.notes-panel {
  max-width: 900px;
  margin: 32px auto 64px;
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(200px, 1fr));
  gap: 12px;
}

.note-card {
  background: white;
  border: 1px solid var(--border);
  border-radius: 8px;
  padding: 16px;
}

.note-swatch {
  height: 40px;
  border-radius: 5px;
  margin-bottom: 12px;
  border: 1px solid rgba(0,0,0,.08);
}

.note-hex {
  font-family: monospace;
  font-size: 12px;
  color: var(--charcoal-mid);
  margin-bottom: 4px;
}

.note-name {
  font-size: 14px;
  font-weight: 600;
  color: var(--charcoal);
  margin-bottom: 4px;
}

.note-use {
  font-size: 12px;
  color: var(--charcoal-mid);
  line-height: 1.5;
}

.note-status {
  display: inline-block;
  font-size: 10px;
  font-weight: 700;
  letter-spacing: .06em;
  text-transform: uppercase;
  padding: 2px 8px;
  border-radius: 3px;
  margin-top: 8px;
}

.status-approved { background: var(--green-light); color: #4b7a23; }
.status-candidate { background: #FFF7F5; color: #b85c35; }
.status-avoid { background: #fde8e8; color: #b83232; }
.status-sparingly { background: #fff8e0; color: #9a7a10; }

.section-divider {
  max-width: 900px;
  margin: 0 auto;
  padding: 12px 0;
  font-size: 11px;
  font-weight: 700;
  letter-spacing: .1em;
  text-transform: uppercase;
  color: rgba(0,0,0,.35);
}

/* --- Icons --- */

/* --- Color Palette Page --- */

.palette-main {
  display: flex;
  width: 100%;
  max-width: 900px;
  height: 200px;
  border-radius: 12px;
  overflow: hidden;
  box-shadow: 0 8px 32px rgba(0,0,0,0.3);
  margin-bottom: 48px;
}

.palette-main .swatch {
  flex: 1;
  display: flex;
  align-items: center;
  justify-content: center;
  transition: flex 0.2s ease;
  cursor: pointer;
}

.palette-main .swatch:hover { flex: 1.15; }

.swatch-inner {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 3px;
  background: rgba(0,0,0,0.25);
  padding: 6px 10px;
  border-radius: 6px;
  backdrop-filter: blur(4px);
}

.swatch.light .swatch-inner { background: rgba(0,0,0,0.1); }

.hex {
  font-size: 12px;
  font-weight: 600;
  font-family: 'SF Mono', 'Fira Code', Consolas, monospace;
  color: #fff;
  letter-spacing: 0.5px;
}

.swatch.light .hex { color: #222; }

.swatch-name {
  font-size: 9px;
  color: rgba(255,255,255,0.6);
}

.swatch.light .swatch-name { color: rgba(0,0,0,0.45); }

.swatch.copied .swatch-inner { background: rgba(0,0,0,0.5); }
.swatch.copied .hex::after { content: " \2713"; font-family: sans-serif; }

.group {
  margin-bottom: 56px;
  max-width: 900px;
}

.divider {
  border: none;
  border-top: 1px solid var(--border);
  margin: 56px 0;
}

.group-title {
  font-family: 'Plus Jakarta Sans', sans-serif;
  font-size: 16px;
  font-weight: 700;
  color: var(--charcoal);
  margin-bottom: 20px;
  padding-bottom: 12px;
  border-bottom: 1px solid var(--border);
}

.group-label {
  font-size: 11px;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.12em;
  color: var(--steel);
  margin-bottom: 12px;
}

.group-grid {
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
}

.chip {
  width: 100px;
  height: 80px;
  border-radius: 8px;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: flex-end;
  padding-bottom: 8px;
  cursor: pointer;
  position: relative;
  transition: transform 0.15s;
}

.chip:hover { transform: scale(1.05); }

.chip-name {
  font-size: 9px;
  font-weight: 500;
  letter-spacing: 0.02em;
  margin-bottom: 3px;
  color: rgba(255,255,255,0.7);
}

.chip.light .chip-name { color: rgba(0,0,0,0.5); }

.chip-hex {
  font-size: 10px;
  font-weight: 600;
  font-family: 'SF Mono', 'Fira Code', Consolas, monospace;
  letter-spacing: 0.3px;
  user-select: all;
  padding: 2px 6px;
  border-radius: 4px;
  background: rgba(0,0,0,0.2);
  color: #fff;
}

.chip.light .chip-hex {
  background: rgba(0,0,0,0.08);
  color: #333;
}

.chip.copied .chip-hex { background: rgba(0,0,0,0.5); color: #fff; }
.chip.copied.light .chip-hex { background: rgba(0,0,0,0.35); color: #fff; }
.chip.copied .chip-hex::after { content: " \2713"; font-family: sans-serif; }

.chip.retired {
  opacity: 0.45;
  position: relative;
}

.chip.retired::after {
  content: "\2715";
  position: absolute;
  top: 6px;
  right: 8px;
  font-size: 12px;
  color: rgba(255,255,255,0.6);
  font-weight: 700;
}

.chip.retired.light::after { color: rgba(0,0,0,0.35); }


.icon-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(110px, 1fr));
  gap: 8px;
}

.icon-item {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 10px;
  padding: 20px 12px 14px;
  border: 1px solid var(--border);
  border-radius: var(--radius-md);
  cursor: pointer;
  transition: background .12s, border-color .12s;
}

.icon-item:hover {
  background: var(--blue-light);
  border-color: var(--blue);
}

.icon-item svg {
  width: 22px;
  height: 22px;
  color: var(--charcoal);
  stroke-width: 1.75;
}

.icon-item:hover svg { color: var(--blue-dark); }

.icon-name {
  font-family: 'Plus Jakarta Sans', sans-serif;
  font-size: 10px;
  font-weight: 600;
  color: var(--steel);
  text-align: center;
  line-height: 1.3;
}

.icon-item:hover .icon-name { color: var(--blue-dark); }


/* Icon colours in context */
.color-row {
  display: flex;
  align-items: center;
  gap: 20px;
  flex-wrap: wrap;
  margin-top: 20px;
}

.color-item {
  display: flex;
  align-items: center;
  gap: 8px;
  font-size: 13px;
  color: var(--charcoal-mid);
}

.color-item svg {
  width: 20px;
  height: 20px;
  flex-shrink: 0;
}
/* Icon sizes */
.size-row {
  display: flex;
  align-items: flex-end;
  gap: 32px;
  flex-wrap: wrap;
  margin-top: 20px;
}

.size-item {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 10px;
}

.size-item svg { color: var(--charcoal); }

.size-label {
  font-family: 'Plus Jakarta Sans', sans-serif;
  font-size: 11px;
  color: var(--steel);
  text-align: center;
}


/* --- Plugin Grid --- */

.plugin-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(200px, 1fr));
  gap: 10px;
  margin-top: 28px;
}

.plugin-item {
  background: white;
  border: 1px solid var(--border);
  border-radius: var(--radius-md);
  padding: 14px 16px;
  display: flex;
  align-items: flex-start;
  gap: 12px;
}

.plugin-bullet {
  width: 8px;
  height: 8px;
  background: var(--green);
  border-radius: 50%;
  margin-top: 5px;
  flex-shrink: 0;
}

.plugin-name {
  font-size: 14px;
  font-weight: 500;
  color: var(--charcoal);
}

.plugin-desc {
  font-size: 12px;
  color: var(--steel);
  margin-top: 2px;
}

.plugin-banner {
  margin-top: 16px;
  padding: 14px 20px;
  background: var(--blue-light);
  border: 1px solid rgba(65, 154, 210, .2);
  border-radius: var(--radius-md);
  font-size: 14px;
  color: var(--blue-dark);
  font-weight: 500;
  text-align: center;
}

/* Language pills */
.lang-pills {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  margin-top: 20px;
}

.lang-pill {
  background: white;
  border: 1px solid var(--border);
  border-radius: 20px;
  padding: 4px 14px;
  font-size: 13px;
  color: var(--charcoal-mid);
}

.lang-pill.rtl {
  background: var(--green-light);
  border-color: var(--green);
  color: var(--green-dark);
  font-weight: 600;
}



/* --- Before/After (split layout variant) --- */

.ba-wrap {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 12px;
}

.ba-panel { border-radius: 8px; overflow: hidden; }

.ba-label {
  font-family: 'Plus Jakarta Sans', sans-serif;
  font-size: 10px;
  font-weight: 700;
  letter-spacing: .08em;
  text-transform: uppercase;
  padding: 8px 12px;
}

.ba-vanilla { background: #f8f8f8; border: 1px solid #ddd; }
.ba-vanilla .ba-label { background: #eee; color: #888; }
.ba-awesome { background: var(--charcoal); }
.ba-awesome .ba-label { background: rgba(65,154,210,.15); color: var(--blue); }
.ba-body { padding: 12px; }
/* --- Mock Screen (for split layout demos) --- */

.mock-screen {
  background: var(--charcoal);
  border-radius: 10px;
  overflow: hidden;
  box-shadow: 0 20px 60px rgba(0, 0, 0, .18);
}

.mock-bar {
  background: rgba(255, 255, 255, .06);
  padding: 10px 16px;
  display: flex;
  align-items: center;
  gap: 8px;
  border-bottom: 1px solid rgba(255, 255, 255, .06);
}

.mock-dot {
  width: 10px;
  height: 10px;
  border-radius: 50%;
}

.mock-content { padding: 20px; }

.mock-dot-sm {
  width: 7px;
  height: 7px;
  border-radius: 50%;
  flex-shrink: 0;
}

.mock-dot-sm.pulse {
  background: var(--green);
  animation: pulse 2s infinite;
}

.mock-dot-sm.urgent { background: #dc3545; }
.mock-dot-sm.none { background: rgba(255,255,255,.2); }

.mock-row {
  display: flex;
  align-items: center;
  gap: 10px;
  padding: 10px 12px;
  border-radius: 6px;
  margin-bottom: 4px;
  font-size: 12px;
}

.mock-row.urgent { background: rgba(220, 53, 69, .18); border-left: 3px solid #dc3545; }
.mock-row.high { background: rgba(245, 92, 68, .12); border-left: 3px solid var(--orange); }
.mock-row.normal { background: rgba(255, 255, 255, .03); border-left: 3px solid rgba(255, 255, 255, .08); }

.mock-subject {
  flex: 1;
  font-weight: 500;
  color: white;
  font-size: 11px;
  overflow: hidden;
  white-space: nowrap;
  text-overflow: ellipsis;
}

.mock-badge {
  font-size: 9px;
  padding: 2px 6px;
  border-radius: 3px;
  font-weight: 700;
  flex-shrink: 0;
  font-family: 'Plus Jakarta Sans', sans-serif;
}

.mock-badge.new { background: rgba(130, 181, 65, .3); color: var(--green); }
.mock-badge.urgent { background: rgba(220, 53, 69, .3); color: #ff8a8a; }

.mock-stats {
  display: flex;
  gap: 12px;
  margin-top: 16px;
}

.mock-stat {
  flex: 1;
  background: rgba(255, 255, 255, .05);
  border-radius: 6px;
  padding: 10px;
  text-align: center;
}

.mock-stat-num {
  font-family: 'Plus Jakarta Sans', sans-serif;
  font-size: 18px;
  font-weight: 700;
  color: var(--green);
}

.mock-stat-label {
  font-size: 9px;
  color: rgba(255, 255, 255, .35);
  text-transform: uppercase;
  letter-spacing: .06em;
  margin-top: 2px;
}

/* Visual placeholder */
.visual-box {
  background: var(--blue-light);
  border: 1px solid var(--slate);
  border-radius: var(--radius-lg);
  aspect-ratio: 4/3;
  display: flex;
  align-items: center;
  justify-content: center;
}

.visual-box svg {
  width: 48px;
  height: 48px;
  color: var(--steel);
}

/* TCO note */
.tco-note {
  margin-top: 16px;
  padding: 18px 24px;
  background: #fff7f5;
  border-left: 3px solid var(--orange);
  border-radius: 0 8px 8px 0;
  font-size: 14px;
  color: var(--charcoal-mid);
  line-height: 1.6;
}

.tco-note strong { color: var(--charcoal); }


/* --- Responsive: Design System Components --- */

@media (max-width: 768px) {
  .before-after,
  .shifto-block,
  .t-asymm { grid-template-columns: 1fr; }

  .stats-bar { gap: 32px; padding: 24px; }

  .split { grid-template-columns: 1fr; gap: 40px; padding: 48px 24px; }
  .split.reverse { direction: ltr; }
  .split.wide,
  .split.wide-reverse { grid-template-columns: 1fr; }

  .cards-3 { grid-template-columns: 1fr; }
  .stats-row-a { grid-template-columns: repeat(2, 1fr); }
  .stats-d { grid-template-columns: repeat(2, 1fr); }
  .stats-f { grid-template-columns: 1fr; }
  .stats-b { grid-template-columns: 1fr; gap: 32px; }
  .feature-demo { grid-template-columns: 1fr; }

  .t-featured { padding: 32px 24px; }
  .t-dark { padding: 40px 24px; }
  .footer-cta { padding: 48px 24px; }

  .trust-strip__logos { gap: 28px 36px; }
}


/* =========================================================
   Page-Specific Overrides
   ========================================================= */

/* FAQs page layout */

/* Design system reference pages — hide theme-generated title */


body.page-id-125414 {
  background: #31373e;
}

body.page-id-125427 {
  background: #e9f5fc;
}

body.page-id-125415 {
  background: #c8d2dc;
  color: var(--charcoal-mid);
}

body.page-id-125415 .option-tag {
  background: rgba(255,255,255,.5);
  color: #555;
}

body.page-id-125415 a.option-tag:hover {
  background: rgba(255,255,255,.7);
  color: var(--blue-dark);
}

body.page-id-125415 .t-body {
  color: var(--charcoal);
}

body.page-id-125415 .section-divider {
  color: rgba(0,0,0,.45);
}
.ds-ref-page {
  max-width: 1000px;
  margin: 0 auto;
  padding: 48px 48px 96px;
}

.ds-ref-page.ds-full-width {
  max-width: none;
  padding-left: 0;
  padding-right: 0;
}

/* Component Library index page */
.hub-content {
  max-width: 960px;
  margin: 0 auto;
  padding: 40px 32px 64px;
}

.category {
  margin-bottom: 40px;
}

.category-label {
  font-size: 11px;
  font-weight: 700;
  letter-spacing: .1em;
  text-transform: uppercase;
  color: var(--steel);
  margin-bottom: 14px;
  padding-bottom: 6px;
  border-bottom: 1px solid var(--border);
}

.card-title {
  font-family: 'Plus Jakarta Sans', sans-serif;
  font-size: 16px;
  font-weight: 600;
  margin-bottom: 6px;
  color: var(--charcoal);
}

.card-desc {
  font-size: 13px;
  color: var(--charcoal-mid);
  line-height: 1.5;
}

.card-arrow {
  display: inline-block;
  margin-top: 10px;
  font-size: 12px;
  font-weight: 600;
  color: var(--blue);
  letter-spacing: .04em;

.hub-content .card-grid {
  grid-template-columns: repeat(auto-fill, minmax(260px, 1fr));
  margin-top: 0;
}

.hub-content .card {
  padding: 20px 22px;
  text-decoration: none;
  display: block;
  color: var(--charcoal);
}
}

.ds-ref-page ~ .entry-header,
.entry-content:has(.ds-ref-page) ~ .entry-header,
article:has(.ds-ref-page) .entry-title { display: none; } {
  max-width: 900px;
  margin: 50px auto 0 auto;
}




/* =========================================================
   Utility: Panel
   ========================================================= */

.oa-panel {
  background: var(--blue-light);
  border: 1px solid var(--border);
  border-radius: var(--radius-lg);
  padding: 24px;
}


/* =========================================================
   Responsive
   ========================================================= */

@media (max-width: 768px) {
  .woocommerce ul.products li.product,
  .woocommerce-page ul.products li.product {
    padding: 18px;
  }

  .woocommerce ul.products li.product .woocommerce-loop-product__title {
    font-size: 22px;
  }

  .site-main .wp-block-group__inner-container,
  .inside-article {
    padding-top: 32px;
    padding-bottom: 32px;
  }


  .oa-accordion-trigger {
    padding: 18px 20px;
    font-size: 15px;
  }

  .oa-accordion-body-content {
    padding: 16px 20px 20px;
  }
}

@media (max-width: 640px) {
  .oa-stats-bar {
    max-width: 400px;
    padding: 24px 24px;
  }

  .oa-stat {
    flex: 0 0 50%;
    padding: 10px 0;
  }

  .oa-stat:nth-child(2)::after {
    display: none;
  }

  .oa-stat-num {
    font-size: 22px;
  }
}

@media (max-width: 360px) {
  .oa-stats-bar {
    max-width: 320px;
    padding: 20px 12px;
  }

  .oa-stat {
    padding: 8px 0;
  }

  .oa-stat-num {
    font-size: 19px;
  }

  .oa-stat-label {
    font-size: 10px;
    letter-spacing: .05em;
  }
}

@media (max-width: 320px) {
  .oa-stat {
    flex: 0 0 100%;
  }

  .oa-stat::after {
    display: none !important;
  }
}


@media (min-width: 769px) {
	li#mega-menu-item-78 a, 
	li#mega-menu-item-80 a {
		align-items: center !important;
		font-family: 'Plus Jakarta Sans', sans-serif !important;
		font-size: 14px !important;
		font-weight: 600 !important;
		text-decoration: none !important;
		cursor: pointer !important;
		border: none !important;
		line-height: 1 !important;
		letter-spacing: .08em !important;
		background: #dcdfe2 !important;
		color: #3b4450 !important;
		padding: 13px 28px !important;
		border-radius: 4px !important;
		box-shadow: 0 3px 0 0 #b1b2b3 !important;
		width: fit-content !important;
		margin: 10px !important;
		min-width: 175px !important;
	}
	.mega-menu-item-78 a.mega-menu-link svg,
	.mega-menu-item-80 a.mega-menu-link svg {
		display: inline-block;
		position: relative;
		top: 1px;
	}
}






/* =========================================================
   Animations
   ========================================================= */
   
:root {
  --animate-duration: 1s;
  --animate-delay: 1s;
  --animate-repeat: 1;
}
.animate__animated {
  -webkit-animation-duration: 1s;
  animation-duration: 1s;
  -webkit-animation-duration: var(--animate-duration);
  animation-duration: var(--animate-duration);
  -webkit-animation-fill-mode: both;
  animation-fill-mode: both;
}
.animate__animated.animate__infinite {
  -webkit-animation-iteration-count: infinite;
  animation-iteration-count: infinite;
}
.animate__animated.animate__repeat-1 {
  -webkit-animation-iteration-count: 1;
  animation-iteration-count: 1;
  -webkit-animation-iteration-count: var(--animate-repeat);
  animation-iteration-count: var(--animate-repeat);
}
.animate__animated.animate__repeat-2 {
  -webkit-animation-iteration-count: 2;
  animation-iteration-count: 2;
  -webkit-animation-iteration-count: calc(var(--animate-repeat) * 2);
  animation-iteration-count: calc(var(--animate-repeat) * 2);
}
.animate__animated.animate__repeat-3 {
  -webkit-animation-iteration-count: 3;
  animation-iteration-count: 3;
  -webkit-animation-iteration-count: calc(var(--animate-repeat) * 3);
  animation-iteration-count: calc(var(--animate-repeat) * 3);
}
.animate__animated.animate__delay-1s {
  -webkit-animation-delay: 1s;
  animation-delay: 1s;
  -webkit-animation-delay: var(--animate-delay);
  animation-delay: var(--animate-delay);
}
.animate__animated.animate__delay-2s {
  -webkit-animation-delay: 2s;
  animation-delay: 2s;
  -webkit-animation-delay: calc(var(--animate-delay) * 2);
  animation-delay: calc(var(--animate-delay) * 2);
}
.animate__animated.animate__delay-3s {
  -webkit-animation-delay: 3s;
  animation-delay: 3s;
  -webkit-animation-delay: calc(var(--animate-delay) * 3);
  animation-delay: calc(var(--animate-delay) * 3);
}
.animate__animated.animate__delay-4s {
  -webkit-animation-delay: 4s;
  animation-delay: 4s;
  -webkit-animation-delay: calc(var(--animate-delay) * 4);
  animation-delay: calc(var(--animate-delay) * 4);
}
.animate__animated.animate__delay-5s {
  -webkit-animation-delay: 5s;
  animation-delay: 5s;
  -webkit-animation-delay: calc(var(--animate-delay) * 5);
  animation-delay: calc(var(--animate-delay) * 5);
}
.animate__animated.animate__faster {
  -webkit-animation-duration: 0.5s;
  animation-duration: 0.5s;
  -webkit-animation-duration: calc(var(--animate-duration) / 2);
  animation-duration: calc(var(--animate-duration) / 2);
}
.animate__animated.animate__fast {
  -webkit-animation-duration: 0.8s;
  animation-duration: 0.8s;
  -webkit-animation-duration: calc(var(--animate-duration) * 0.8);
  animation-duration: calc(var(--animate-duration) * 0.8);
}
.animate__animated.animate__slow {
  -webkit-animation-duration: 2s;
  animation-duration: 2s;
  -webkit-animation-duration: calc(var(--animate-duration) * 2);
  animation-duration: calc(var(--animate-duration) * 2);
}
.animate__animated.animate__slower {
  -webkit-animation-duration: 3s;
  animation-duration: 3s;
  -webkit-animation-duration: calc(var(--animate-duration) * 3);
  animation-duration: calc(var(--animate-duration) * 3);
}
.oa-marquee-row:hover .oa-marquee-track {
  animation-play-state: paused;
}

@media (prefers-reduced-motion: reduce), print {
  .animate__animated {
    -webkit-animation-duration: 1ms !important;
    animation-duration: 1ms !important;
    -webkit-transition-duration: 1ms !important;
    transition-duration: 1ms !important;
    -webkit-animation-iteration-count: 1 !important;
    animation-iteration-count: 1 !important;
  }
  .animate__animated[class*="Out"] {
    opacity: 0;
  }
}
@-webkit-keyframes pulse {
  0% {
    -webkit-transform: scaleX(1);
    transform: scaleX(1);
  }
  50% {
    -webkit-transform: scale3d(1.05, 1.05, 1.05);
    transform: scale3d(1.05, 1.05, 1.05);
  }
  to {
    -webkit-transform: scaleX(1);
    transform: scaleX(1);
  }
}
@keyframes pulse {
  0% {
    -webkit-transform: scaleX(1);
    transform: scaleX(1);
  }
  50% {
    -webkit-transform: scale3d(1.05, 1.05, 1.05);
    transform: scale3d(1.05, 1.05, 1.05);
  }
  to {
    -webkit-transform: scaleX(1);
    transform: scaleX(1);
  }
}
.animate__pulse {
  -webkit-animation-name: pulse;
  animation-name: pulse;
  -webkit-animation-timing-function: ease-in-out;
  animation-timing-function: ease-in-out;
}

.site-logo:hover,
.mega-demo-buttons a,
li#mega-menu-item-132014 a:hover,
li#mega-menu-item-132019 a:hover, 
li#mega-menu-item-132020 a:hover {
    -webkit-animation-name: hvr-pop;
    animation-name: pulse;
    -webkit-animation-duration: 0.3s;
    animation-duration: 0.3s;
    -webkit-animation-timing-function: linear;
    animation-timing-function: linear;
    -webkit-animation-iteration-count: 1;
    animation-iteration-count: 1;
}

/* =========================================================
   Trust Strip Marquee — Home Page
   Dual-row infinite scroll, Kayako-style
   ========================================================= */

.oa-marquee-section {
  background: var(--charcoal);
  padding: 64px 0 84px;
  overflow: hidden;
}

.oa-marquee-section .oa-marquee-header {
  text-align: center;
  margin: 36px 0 76px 0;
  padding: 0 24px;
}

.oa-marquee-section .oa-marquee-eyebrow {
  font-family: "Plus Jakarta Sans", sans-serif;
  font-size: 12px;
  font-weight: 700;
  letter-spacing: .09em;
  text-transform: uppercase;
  color: var(--green);
  margin-bottom: 12px;
}

.oa-marquee-section .oa-marquee-heading {
  font-family: "Plus Jakarta Sans", sans-serif;
  font-size: 32px;
  font-weight: 700;
  line-height: 1.2;
  color: var(--white);
  margin: 0;
}

.oa-marquee-section .oa-marquee-sub {
  font-size: 16px;
  color: rgba(255,255,255,.5);
  margin-top: 8px;
}

/* Track — the scrolling container */
.oa-marquee-track {
  display: flex;
  align-items: center;
  width: max-content;
  gap: 60px;
  padding: 0 26px;
}

/* Row wrappers */
.oa-marquee-row {

  margin-bottom: 28px;
}
.oa-marquee-row:last-child {
  margin-bottom: 0;
}

/* Animation — row 1 scrolls left, row 2 scrolls right */
.oa-marquee-row--left .oa-marquee-track {
  animation: marqueeLeft 180s linear infinite;
}
.oa-marquee-row--right .oa-marquee-track {
  animation: marqueeRight 200s linear infinite;
}

@keyframes marqueeLeft {
  0%   { transform: translateX(0); }
  100% { transform: translateX(-50%); }
}
@keyframes marqueeRight {
  0%   { transform: translateX(-50%); }
  100% { transform: translateX(0); }
}

/* Logo images */
.oa-marquee-track img {
  display: block;
  height: 40px;
  width: auto;

  opacity: 0.4;
  flex-shrink: 0;
  transition: opacity 0.3s ease;
}
.oa-marquee-section:not(.oa-marquee-section--white) .oa-marquee-track img:hover {
  filter: brightness(0) invert(1);
  opacity: 0.7;
}

/* Pause on hover */

/* Per-logo height tuning */
.oa-marquee-track img[alt="Apple"]                 { height: 48px; opacity: .45; }
.oa-marquee-track img[alt="Nokia"]                 { height: 26px; opacity: .45; margin: 7px 0 0 0; }
.oa-marquee-track img[alt="Verizon"]               { height: 30px; opacity: .45; }
.oa-marquee-track img[alt="Honeywell"]             { height: 30px; opacity: .45; margin: 10px 0 0 0; }
.oa-marquee-track img[alt="BMW"]                   { height: 68px; opacity: .4; margin: 6px 0 0 0; }
.oa-marquee-track img[alt="Toyota"]                { height: 34px; opacity: .4; margin: 4px 0 0 0; }
.oa-marquee-track img[alt="Booz Allen Hamilton"]   { height: 37px; opacity: .5; margin: 6px 0 0 0; }
.oa-marquee-track img[alt="Columbia University"]    { height: 80px; opacity: .45; margin: 4px 0 0 0; }
.oa-marquee-track img[alt="University of Oxford"]   { height: 54px; opacity: .5; margin: 11px 0 0 0; }
.oa-marquee-track img[alt="University of Cambridge"]{ height: 53px; opacity: 0.45; position: relative; margin: 10px 0 0 0; }
.oa-marquee-track img[alt="Lindt"]                 { height: 44px; opacity: .4; }

.oa-marquee-track img[alt="Ohio State"]            { height: 95px; opacity: .45; }
.oa-marquee-track img[alt="Wisconsin"]             { height: 54px; opacity: .45; }
.oa-marquee-track img[alt="Alabama"]               { height: 48px; opacity: .45; }
.oa-marquee-track img[alt="Colorado State"]        { height: 58px; opacity: .45; }
.oa-marquee-track img[alt="LSU"]                   { height: 85px; opacity: .45; margin: -6px 0 0 0; }
.oa-marquee-track img[alt="FAMU"]                  { height: 42px; opacity: .35; margin: 10px 0 0 0; }
.oa-marquee-track img[alt="Texas DPS"]             { height: 65px; opacity: .4; }
.oa-marquee-track img[alt="Malaysia"]              { height: 92px; opacity: .4; }
.oa-marquee-track img[alt="NTRA Egypt"]            { height: 56px; opacity: .45; margin: 0; }
.oa-marquee-track img[alt="Gordonstoun"]           { height: 87px; opacity: .38; margin: -5px 0 0 0; }
.oa-marquee-track img[alt="Schaeffler"]          { height: 21px; opacity: .45; margin: 8px 0 0 0; }
.oa-marquee-track img[alt="Max Planck"]           { height: 70px; opacity: .45; }
.oa-marquee-track img[alt="German Red Cross"]     { height: 60px; opacity: .35; margin: 10px 0 0 0; }

/* Mobile adjustments */
@media (max-width: 768px) {
  .oa-marquee-section {
    padding: 48px 0 40px;
  }
  .oa-marquee-section .oa-marquee-heading {
    font-size: 24px;
  }
  .oa-marquee-track {
    gap: 36px;
  }
  .oa-marquee-track img {
    height: 32px !important;
  }
  .oa-marquee-row {
    margin-bottom: 20px;
  }
}

/* Reduced motion — respect user preference */
@media (prefers-reduced-motion: reduce) {
  .oa-marquee-row--left .oa-marquee-track,
  .oa-marquee-row--right .oa-marquee-track {
    animation: none;
  }
}

/* White variant of marquee */
.oa-marquee-section--white {
  background: var(--white);
}
.oa-marquee-section--white .oa-marquee-eyebrow {
  color: var(--blue);
}
.oa-marquee-section--white .oa-marquee-heading {
  color: var(--charcoal);
}
.oa-marquee-section--white .oa-marquee-sub {
  color: var(--charcoal-mid);
}
.oa-marquee-section--white .oa-marquee-track img {
  filter: none;
  opacity: 0.55;
}
.oa-marquee-section--white .oa-marquee-track img[alt="Ohio State"] { opacity: .8; }
.oa-marquee-section--white .oa-marquee-track img:hover {

  opacity: 0.85;
}

/* =========================================================
   Compare Page: vs Zendesk
   ========================================================= */
  :root {
    --blue:         #419AD2;
    --blue-dark:    #2F7DB8;
    --blue-light:   #E8F5FC;
    --charcoal:     #444C56;
    --charcoal-mid: #5A6270;
    --steel:        #A6AFBC;
    --slate:        #C7D2DC;
    --green:        #82B541;
    --green-dark:   #6E9A38;
    --green-light:  #EAF3DE;
    --orange:       #F55C44;
    --orange-dark:  #D94E38;
    --white:        #ffffff;
    --border:       #C7D2DC;

  /* Error states */
  --red:          #C0392B;
  --red-light:    #FDECEA;
  }

  .page-vs-zendesk *,
  .page-vs-zendesk *::before,
  .page-vs-zendesk *::after { box-sizing: border-box; margin: 0; padding: 0; }

  .page-vs-zendesk {
    font-family: 'DM Sans', sans-serif;
    font-size: 17px;
    line-height: 1.65;
    color: var(--charcoal-mid);
    background: var(--white);
    -webkit-font-smoothing: antialiased;
  }

  .page-vs-zendesk h1,
  .page-vs-zendesk h2,
  .page-vs-zendesk h3,
  .page-vs-zendesk h4 {
    font-family: "Plus Jakarta Sans", sans-serif;
    color: var(--charcoal);
    line-height: 1.2;
    margin: 0;
  }

  .page-vs-zendesk p { margin: 0; }

  .page-vs-zendesk .wrap {
    max-width: 1100px;
    margin: 0 auto;
    padding: 0 48px;
  }

  /* ── Eyebrow ── */
  .page-vs-zendesk .eyebrow {
    font-family: "Plus Jakarta Sans", sans-serif;
    font-size: 12px;
    font-weight: 700;
    letter-spacing: .09em;
    text-transform: uppercase;
    color: var(--blue);
    margin-bottom: 12px;
  }
  .page-vs-zendesk .on-dark .eyebrow { color: var(--green); }

  /* ── Buttons ── */
  .page-vs-zendesk .btn {
    display: inline-block;
    font-family: "Plus Jakarta Sans", sans-serif;
    font-size: 15px;
    font-weight: 600;
    letter-spacing: .02em;
    text-decoration: none;
    border-radius: 4px;
    padding: 13px 28px;
    transition: all 0.2s ease;
    cursor: pointer;
    border: none;
  }
  .page-vs-zendesk .btn-orange {
    background: var(--orange);
    color: var(--white);
    box-shadow: 0 3px 0 rgba(160,60,40,.9);
  }
  .page-vs-zendesk .btn-orange:hover { background: var(--orange-dark); }
  .page-vs-zendesk .btn-grey {
    background: #dcdfe2;
    color: #3b4450;
    letter-spacing: .1em;
    box-shadow: 0 2px 0 0 #b1b2b3;
  }
  .page-vs-zendesk .btn-grey:hover { background: #cdd0d4; }
  .page-vs-zendesk .btn-white {
    background: var(--white);
    color: var(--blue-dark);
  }
  .page-vs-zendesk .btn-white:hover { background: #f0f4f8; }
  .page-vs-zendesk .btn-white-outline {
    background: transparent;
    color: var(--white);
    border: 2px solid rgba(255,255,255,.5);
  }
  .page-vs-zendesk .btn-white-outline:hover { border-color: rgba(255,255,255,.8); }
  .page-vs-zendesk .btn-group { display: flex; gap: 16px; flex-wrap: wrap; }

  /* ── Sections ── */
  .page-vs-zendesk .section { padding: 88px 0; }
  .page-vs-zendesk .section--alice { background: var(--blue-light); }
  .page-vs-zendesk .section--charcoal { background: var(--charcoal); color: rgba(255,255,255,.65); }
  .page-vs-zendesk .section--charcoal h2 { color: var(--white); }
  .page-vs-zendesk .section--charcoal .eyebrow { color: var(--green); }

  .page-vs-zendesk .section-header { margin-bottom: 40px; }
  .page-vs-zendesk .section-header h2 { font-size: 38px; font-weight: 600; margin-bottom: 12px; }
  .page-vs-zendesk .section-body,
button,
input,
select,
textarea {
  font-family: 'DM Sans', sans-serif; font-size: 17px; }
  .page-vs-zendesk .section-body p { margin-bottom: 20px; }

  /* ── Hero ── */
  .page-vs-zendesk .hero {
    padding: 100px 0 0 0;
    text-align: center;
  }
  .page-vs-zendesk .hero h1 {
    font-size: 52px;
    font-weight: 700;
    margin-bottom: 20px;
  }
  .page-vs-zendesk .hero .subtitle {
    font-size: 19px;
    color: var(--charcoal-mid);
    margin-bottom: 36px;
    line-height: 1.6;
  }
  .page-vs-zendesk .hero-graphic {
    max-width: 421px;
    width: 100%;
    margin-top: 12px;
  }

  /* ── Comparison Tables ── */
  .page-vs-zendesk .comp-table {
    width: 100%;
    border-collapse: collapse;
    margin: 32px 0;
    font-size: 15px;
    background: #fff;
    box-shadow: 0 1px 4px rgba(0,0,0,0.06), 0 4px 16px rgba(0,0,0,0.04);
    border-radius: 8px;
    overflow: hidden;
  }
  .page-vs-zendesk .comp-table thead th {
    background: var(--charcoal);
    color: var(--white);
    font-family: "Plus Jakarta Sans", sans-serif;
    font-weight: 600;
    font-size: 14px;
    padding: 14px 18px;
    text-align: left;
    border: none;
  }
  .page-vs-zendesk .comp-table thead th.ours {
    background: var(--blue-dark);
  }
  .page-vs-zendesk .comp-table tbody td {
    padding: 13px 18px;
    border-bottom: 1px solid var(--slate);
    border-top: none;
    border-left: none;
    border-right: none;
    vertical-align: top;
  }
  .page-vs-zendesk .comp-table tbody td.ours {
    background: var(--blue-light);
    font-weight: 500;
  }
  .page-vs-zendesk .comp-table tbody td:first-child {
    font-weight: 500;
    color: var(--charcoal);
  }
  .page-vs-zendesk .comp-table tbody tr:last-child td { border-bottom: none; }
  .page-vs-zendesk .price-highlight { font-weight: 700; color: var(--blue-dark); }

  /* ── Hidden Costs Cards ── */
  .page-vs-zendesk .cost-grid {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 20px;
    margin: 32px 0;
  }
  .page-vs-zendesk .cost-card {
    background: var(--white);
    border: 1px solid var(--border);
    border-radius: 10px;
    padding: 28px 28px 24px;
  }
  .page-vs-zendesk .cost-card h4 {
    font-size: 16px;
    font-weight: 600;
    margin-bottom: 8px;
  }
  .page-vs-zendesk .cost-card p {
    font-size: 15px;
    line-height: 1.55;
    margin: 0;
    color: var(--charcoal-mid);
  }

  /* ── Callout Boxes ── */
  .page-vs-zendesk .callout {
  display: flex;
  align-items: flex-start;
  gap: 12px;
    border-radius: 0 10px 10px 0;
    padding: 20px 24px;
    margin: 32px 0;
    font-size: 15px;
    line-height: 1.6;
  }
  .page-vs-zendesk .callout-orange {
    background: #fff7f5;
    border-left: 4px solid var(--orange);
  }
  .page-vs-zendesk .callout-blue {
    background: var(--blue-light);
    border-left: 4px solid var(--blue);
  }
  .page-vs-zendesk .callout strong { color: var(--charcoal); }
  .page-vs-zendesk .callout-emphasis { zoom: 1.2; }
  .page-vs-zendesk .callout p { margin-bottom: 12px; }
  .page-vs-zendesk .callout p:last-child { margin-bottom: 0; }

  /* ── Feature Grid ── */
  .page-vs-zendesk .feature-grid {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 1px;
    background: var(--slate);
    border-radius: 10px;
    overflow: hidden;
    margin: 32px 0;
  }
  .page-vs-zendesk .feature-cell {
    background: var(--white);
    padding: 20px 24px;
  }
  .page-vs-zendesk .feature-cell h4 {
    font-size: 16px;
    font-weight: 600;
    margin-bottom: 8px;
    display: flex;
    align-items: center;
    gap: 10px;
  }
  .page-vs-zendesk .feature-cell h4::before {
    content: "";
    width: 8px;
    height: 8px;
    background: var(--green);
    border-radius: 50%;
    flex-shrink: 0;
  }
  .page-vs-zendesk .feature-cell p {
    font-size: 15px;
    line-height: 1.55;
    margin: 0;
    color: var(--charcoal-mid);
  }

  /* ── Check/X marks in tables ── */
  .page-vs-zendesk .yes { color: var(--green); font-weight: 700; font-size: 20px; }
  .page-vs-zendesk .no { color: var(--slate); font-weight: 700; font-size: 20px; }
  .page-vs-zendesk .warn { color: var(--orange); font-weight: 700; font-size: 20px; }

  /* ── FAQ Accordion ── */
  .page-vs-zendesk .faq-list { margin-top: 32px; }
  .page-vs-zendesk .faq-item {
    border: 1px solid var(--border);
    border-radius: 10px;
    margin-bottom: 12px;
    overflow: hidden;
    transition: border-color 0.2s;
  }
  .page-vs-zendesk .faq-item:hover { border-color: var(--blue); }
  .page-vs-zendesk .faq-q {
    width: 100%;
    background: none;
    border: none;
    padding: 22px 28px;
    font-family: "Plus Jakarta Sans", sans-serif;
    font-size: 16px;
    font-weight: 600;
    color: var(--charcoal);
    text-align: left;
    cursor: pointer;
    display: flex;
    justify-content: space-between;
    align-items: center;
  }
  .page-vs-zendesk .faq-q::after {
    content: "+";
    font-size: 22px;
    font-weight: 400;
    color: var(--blue);
    transition: transform 0.2s;
  }
  .page-vs-zendesk .faq-item.open .faq-q::after {
    content: "−";
  }
  .page-vs-zendesk .faq-a {
    display: none;
    padding: 0 28px 22px;
    font-size: 15px;
    line-height: 1.65;
    color: var(--charcoal-mid);
  }
  .page-vs-zendesk .faq-item.open .faq-a { display: block; }

  /* ── Trust Strip ── */
  .page-vs-zendesk .trust-logos {
    display: flex;
    align-items: center;
    justify-content: center;
    flex-wrap: wrap;
    gap: 40px 52px;
    margin-top: 32px;
  }
  .page-vs-zendesk .trust-logos img {
    display: block;
    height: 40px;
    width: auto;
    filter: brightness(0) invert(1);
    opacity: 0.35;
  }

  /* ── Footer CTA ── */
/* ── Tagline ── */
  .page-vs-zendesk .tagline {
    font-family: "Plus Jakarta Sans", sans-serif;
    font-size: 18px;
    font-weight: 600;
    color: var(--charcoal);
    margin-top: 20px;
  }
  .page-vs-zendesk .section--charcoal .tagline { color: rgba(255,255,255,.5); }

  /* ── Responsive ── */
  @media (max-width: 768px) {
    .page-vs-zendesk .wrap { padding: 0 24px; }
    .page-vs-zendesk .section { padding: 56px 0; }
    .page-vs-zendesk .hero { padding: 64px 0 84px; }
    .page-vs-zendesk .hero h1 { font-size: 34px; }
    .page-vs-zendesk .section-header h2 { font-size: 28px; }
    .page-vs-zendesk .cost-grid { grid-template-columns: 1fr; }
    .page-vs-zendesk .feature-grid { grid-template-columns: 1fr; }
    .page-vs-zendesk .comp-table { font-size: 13px; }
    .page-vs-zendesk .comp-table thead th,
    .page-vs-zendesk .comp-table tbody td { padding: 10px 12px; }
  }
  @media (max-width: 400px) {
    .page-vs-zendesk .comp-table {
      margin-left: -20px;
      margin-right: -20px;
      border-radius: 0;
    }
    .page-vs-zendesk .comp-table th {
      font-size: 95% !important;
    }
  }


/* ═══════════════════════════════════════════
   Compare Page: vs Zammad
   ═══════════════════════════════════════════ */

  :root {
    --blue:         #419AD2;
    --blue-dark:    #2F7DB8;
    --blue-light:   #E8F5FC;
    --charcoal:     #444C56;
    --charcoal-mid: #5A6270;
    --steel:        #A6AFBC;
    --slate:        #C7D2DC;
    --green:        #82B541;
    --green-dark:   #6E9A38;
    --green-light:  #EAF3DE;
    --orange:       #F55C44;
    --orange-dark:  #D94E38;
    --white:        #ffffff;
    --border:       #C7D2DC;

  /* Error states */
  --red:          #C0392B;
  --red-light:    #FDECEA;
  }

  .page-vs-zammad *,
  .page-vs-zammad *::before,
  .page-vs-zammad *::after { box-sizing: border-box; margin: 0; padding: 0; }

  .page-vs-zammad {
    font-family: 'DM Sans', sans-serif;
    font-size: 17px;
    line-height: 1.65;
    color: var(--charcoal-mid);
    background: var(--white);
    -webkit-font-smoothing: antialiased;
  }

  .page-vs-zammad h1,
  .page-vs-zammad h2,
  .page-vs-zammad h3,
  .page-vs-zammad h4 {
    font-family: "Plus Jakarta Sans", sans-serif;
    color: var(--charcoal);
    line-height: 1.2;
    margin: 0;
  }

  .page-vs-zammad p { margin: 0; }

  .page-vs-zammad .wrap {
    max-width: 1100px;
    margin: 0 auto;
    padding: 0 48px;
  }

  /* ── Eyebrow ── */
  .page-vs-zammad .eyebrow {
    font-family: "Plus Jakarta Sans", sans-serif;
    font-size: 12px;
    font-weight: 700;
    letter-spacing: .09em;
    text-transform: uppercase;
    color: var(--blue);
    margin-bottom: 12px;
  }
  .page-vs-zammad .on-dark .eyebrow { color: var(--green); }

  /* ── Buttons ── */
  .page-vs-zammad .btn {
    display: inline-block;
    font-family: "Plus Jakarta Sans", sans-serif;
    font-size: 15px;
    font-weight: 600;
    letter-spacing: .02em;
    text-decoration: none;
    border-radius: 4px;
    padding: 13px 28px;
    transition: all 0.2s ease;
    cursor: pointer;
    border: none;
  }
  .page-vs-zammad .btn-orange {
    background: var(--orange);
    color: var(--white);
    box-shadow: 0 3px 0 rgba(160,60,40,.9);
  }
  .page-vs-zammad .btn-orange:hover { background: var(--orange-dark); }
  .page-vs-zammad .btn-grey {
    background: #dcdfe2;
    color: #3b4450;
    letter-spacing: .1em;
    box-shadow: 0 2px 0 0 #b1b2b3;
  }
  .page-vs-zammad .btn-grey:hover { background: #cdd0d4; }
  .page-vs-zammad .btn-white {
    background: var(--white);
    color: var(--blue-dark);
  }
  .page-vs-zammad .btn-white:hover { background: #f0f4f8; }
  .page-vs-zammad .btn-white-outline {
    background: transparent;
    color: var(--white);
    border: 2px solid rgba(255,255,255,.5);
  }
  .page-vs-zammad .btn-white-outline:hover { border-color: rgba(255,255,255,.8); }
  .page-vs-zammad .btn-group { display: flex; gap: 16px; flex-wrap: wrap; }

  /* ── Sections ── */
  .page-vs-zammad .section { padding: 88px 0; }
  .page-vs-zammad .section--alice { background: var(--blue-light); }
  .page-vs-zammad .section--charcoal { background: var(--charcoal); color: rgba(255,255,255,.65); }
  .page-vs-zammad .section--charcoal h2 { color: var(--white); }
  .page-vs-zammad .section--charcoal .eyebrow { color: var(--green); }

  .page-vs-zammad .section-header { margin-bottom: 40px; }
  .page-vs-zammad .section-header h2 { font-size: 38px; font-weight: 600; margin-bottom: 12px; }
  .page-vs-zammad .section-body,
button,
input,
select,
textarea {
  font-family: 'DM Sans', sans-serif; font-size: 17px; }
  .page-vs-zammad .section-body p { margin-bottom: 20px; }

  /* ── Hero ── */
  .page-vs-zammad .hero {
    padding: 100px 0 0 0;
    text-align: center;
  }
  .page-vs-zammad .hero h1 {
    font-size: 52px;
    font-weight: 700;
    margin-bottom: 20px;
  }
  .page-vs-zammad .hero .subtitle {
    font-size: 19px;
    color: var(--charcoal-mid);
    margin-bottom: 36px;
    line-height: 1.6;
  }
  .page-vs-zammad .hero-graphic {
    max-width: 349px;
    width: 100%;
    margin-top: 12px;
  }

  /* ── Comparison Tables ── */
  .page-vs-zammad .comp-table {
    width: 100%;
    border-collapse: collapse;
    margin: 32px 0;
    font-size: 15px;
    background: #fff;
    box-shadow: 0 1px 4px rgba(0,0,0,0.06), 0 4px 16px rgba(0,0,0,0.04);
    border-radius: 8px;
    overflow: hidden;
  }
  .page-vs-zammad .comp-table thead th {
    background: var(--charcoal);
    color: var(--white);
    font-family: "Plus Jakarta Sans", sans-serif;
    font-weight: 600;
    font-size: 14px;
    padding: 14px 18px;
    text-align: left;
    border: none;
  }
  .page-vs-zammad .comp-table thead th.ours {
    background: var(--blue-dark);
  }
  .page-vs-zammad .comp-table tbody td {
    padding: 13px 18px;
    border-bottom: 1px solid var(--slate);
    border-top: none;
    border-left: none;
    border-right: none;
    vertical-align: top;
  }
  .page-vs-zammad .comp-table tbody td.ours {
    background: var(--blue-light);
    font-weight: 500;
  }
  .page-vs-zammad .comp-table tbody td:first-child {
    font-weight: 500;
    color: var(--charcoal);
  }
  .page-vs-zammad .comp-table tbody tr:last-child td { border-bottom: none; }
  .page-vs-zammad .price-highlight { font-weight: 700; color: var(--blue-dark); }

  /* ── Cost Cards ── */
  .page-vs-zammad .cost-grid {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 20px;
    margin: 32px 0;
  }
  .page-vs-zammad .cost-card {
    background: var(--white);
    border: 1px solid var(--border);
    border-radius: 10px;
    padding: 28px 28px 24px;
  }
  .page-vs-zammad .cost-card h4 {
    font-size: 16px;
    font-weight: 600;
    margin-bottom: 8px;
  }
  .page-vs-zammad .cost-card p {
    font-size: 15px;
    line-height: 1.55;
    margin: 0;
    color: var(--charcoal-mid);
  }

  /* ── Callout Boxes ── */
  .page-vs-zammad .callout {
  display: flex;
  align-items: flex-start;
  gap: 12px;
    border-radius: 0 10px 10px 0;
    padding: 20px 24px;
    margin: 32px 0;
    font-size: 15px;
    line-height: 1.6;
  }
  .page-vs-zammad .callout-orange {
    background: #fff7f5;
    border-left: 4px solid var(--orange);
  }
  .page-vs-zammad .callout-blue {
    background: var(--blue-light);
    border-left: 4px solid var(--blue);
  }
  .page-vs-zammad .section--alice .callout-blue {
    background: #fff;
  }
  .page-vs-zammad .callout strong { color: var(--charcoal); }
  .page-vs-zammad .callout-emphasis { zoom: 1.2; }
  .page-vs-zammad .callout p { margin-bottom: 12px; }
  .page-vs-zammad .callout p:last-child { margin-bottom: 0; }

  /* ── Feature Grid ── */
  .page-vs-zammad .feature-grid {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 1px;
    background: var(--slate);
    border-radius: 10px;
    overflow: hidden;
    margin: 32px 0;
  }
  .page-vs-zammad .feature-cell {
    background: var(--white);
    padding: 20px 24px;
  }
  .page-vs-zammad .feature-cell h4 {
    font-size: 16px;
    font-weight: 600;
    margin-bottom: 8px;
    display: flex;
    align-items: center;
    gap: 10px;
  }
  .page-vs-zammad .feature-cell h4::before {
    content: "";
    width: 8px;
    height: 8px;
    background: var(--green);
    border-radius: 50%;
    flex-shrink: 0;
  }
  .page-vs-zammad .feature-cell p {
    font-size: 15px;
    line-height: 1.55;
    margin: 0;
    color: var(--charcoal-mid);
  }

  /* ── Check/X marks in tables ── */
  .page-vs-zammad .yes { color: var(--green); font-weight: 700; font-size: 20px; }
  .page-vs-zammad .no { color: var(--slate); font-weight: 700; font-size: 20px; }
  .page-vs-zammad .warn { color: var(--orange); font-weight: 700; font-size: 20px; }

  /* ── FAQ Accordion ── */
  .page-vs-zammad .faq-list { margin-top: 32px; }
  .page-vs-zammad .faq-item {
    border: 1px solid var(--border);
    border-radius: 10px;
    margin-bottom: 12px;
    overflow: hidden;
    transition: border-color 0.2s;
  }
  .page-vs-zammad .faq-item:hover { border-color: var(--blue); }
  .page-vs-zammad .faq-q {
    width: 100%;
    background: none;
    border: none;
    padding: 22px 28px;
    font-family: "Plus Jakarta Sans", sans-serif;
    font-size: 16px;
    font-weight: 600;
    color: var(--charcoal);
    text-align: left;
    cursor: pointer;
    display: flex;
    justify-content: space-between;
    align-items: center;
  }
  .page-vs-zammad .faq-q::after {
    content: "+";
    font-size: 22px;
    font-weight: 400;
    color: var(--blue);
    transition: transform 0.2s;
  }
  .page-vs-zammad .faq-item.open .faq-q::after {
    content: "−";
  }
  .page-vs-zammad .faq-a {
    display: none;
    padding: 0 28px 22px;
    font-size: 15px;
    line-height: 1.65;
    color: var(--charcoal-mid);
  }
  .page-vs-zammad .faq-item.open .faq-a { display: block; }

  /* ── Trust Strip ── */
  .page-vs-zammad .trust-logos {
    display: flex;
    align-items: center;
    justify-content: center;
    flex-wrap: wrap;
    gap: 40px 52px;
    margin-top: 32px;
  }
  .page-vs-zammad .trust-logos img {
    display: block;
    height: 40px;
    width: auto;
    filter: brightness(0) invert(1);
    opacity: 0.35;
  }

  /* ── Footer CTA ── */
/* ── Tagline ── */
  .page-vs-zammad .tagline {
    font-family: "Plus Jakarta Sans", sans-serif;
    font-size: 18px;
    font-weight: 600;
    color: var(--charcoal);
    margin-top: 20px;
  }

  /* ── Responsive ── */
  @media (max-width: 768px) {
    .page-vs-zammad .wrap { padding: 0 24px; }
    .page-vs-zammad .section { padding: 56px 0; }
    .page-vs-zammad .hero { padding: 64px 0 56px; }
    .page-vs-zammad .hero h1 { font-size: 34px; }
    .page-vs-zammad .section-header h2 { font-size: 28px; }
    .page-vs-zammad .cost-grid { grid-template-columns: 1fr; }
    .page-vs-zammad .feature-grid { grid-template-columns: 1fr; }
    .page-vs-zammad .comp-table { font-size: 13px; }
    .page-vs-zammad .comp-table thead th,
    .page-vs-zammad .comp-table tbody td { padding: 10px 12px; }
  }


/* ══════════════════════════════════════════════════
   Compare Page: vs Freshdesk
   ══════════════════════════════════════════════════ */

  :root {
    --blue:         #419AD2;
    --blue-dark:    #2F7DB8;
    --blue-light:   #E8F5FC;
    --charcoal:     #444C56;
    --charcoal-mid: #5A6270;
    --steel:        #A6AFBC;
    --slate:        #C7D2DC;
    --green:        #82B541;
    --green-dark:   #6E9A38;
    --green-light:  #EAF3DE;
    --orange:       #F55C44;
    --orange-dark:  #D94E38;
    --white:        #ffffff;
    --border:       #C7D2DC;

  /* Error states */
  --red:          #C0392B;
  --red-light:    #FDECEA;
  }

  .page-vs-freshdesk *,
  .page-vs-freshdesk *::before,
  .page-vs-freshdesk *::after { box-sizing: border-box; margin: 0; padding: 0; }

  .page-vs-freshdesk {
    font-family: 'DM Sans', sans-serif;
    font-size: 17px;
    line-height: 1.65;
    color: var(--charcoal-mid);
    background: var(--white);
    -webkit-font-smoothing: antialiased;
  }

  .page-vs-freshdesk h1,
  .page-vs-freshdesk h2,
  .page-vs-freshdesk h3,
  .page-vs-freshdesk h4 {
    font-family: "Plus Jakarta Sans", sans-serif;
    color: var(--charcoal);
    line-height: 1.2;
    margin: 0;
  }

  .page-vs-freshdesk p { margin: 0; }

  .page-vs-freshdesk .wrap {
    max-width: 1100px;
    margin: 0 auto;
    padding: 0 48px;
  }

  /* ── Eyebrow ── */
  .page-vs-freshdesk .eyebrow {
    font-family: "Plus Jakarta Sans", sans-serif;
    font-size: 12px;
    font-weight: 700;
    letter-spacing: .09em;
    text-transform: uppercase;
    color: var(--blue);
    margin-bottom: 12px;
  }
  .page-vs-freshdesk .on-dark .eyebrow { color: var(--green); }

  /* ── Buttons ── */
  .page-vs-freshdesk .btn {
    display: inline-block;
    font-family: "Plus Jakarta Sans", sans-serif;
    font-size: 15px;
    font-weight: 600;
    letter-spacing: .02em;
    text-decoration: none;
    border-radius: 4px;
    padding: 13px 28px;
    transition: all 0.2s ease;
    cursor: pointer;
    border: none;
  }
  .page-vs-freshdesk .btn-orange {
    background: var(--orange);
    color: var(--white);
    box-shadow: 0 3px 0 rgba(160,60,40,.9);
  }
  .page-vs-freshdesk .btn-orange:hover { background: var(--orange-dark); }
  .page-vs-freshdesk .btn-grey {
    background: #dcdfe2;
    color: #3b4450;
    letter-spacing: .1em;
    box-shadow: 0 2px 0 0 #b1b2b3;
  }
  .page-vs-freshdesk .btn-grey:hover { background: #cdd0d4; }
  .page-vs-freshdesk .btn-white {
    background: var(--white);
    color: var(--blue-dark);
  }
  .page-vs-freshdesk .btn-white:hover { background: #f0f4f8; }
  .page-vs-freshdesk .btn-white-outline {
    background: transparent;
    color: var(--white);
    border: 2px solid rgba(255,255,255,.5);
  }
  .page-vs-freshdesk .btn-white-outline:hover { border-color: rgba(255,255,255,.8); }
  .page-vs-freshdesk .btn-group { display: flex; gap: 16px; flex-wrap: wrap; }

  /* ── Sections ── */
  .page-vs-freshdesk .section { padding: 88px 0; }
  .page-vs-freshdesk .section--alice { background: var(--blue-light); }
  .page-vs-freshdesk .section--charcoal { background: var(--charcoal); color: rgba(255,255,255,.65); }
  .page-vs-freshdesk .section--charcoal h2 { color: var(--white); }
  .page-vs-freshdesk .section--charcoal .eyebrow { color: var(--green); }

  .page-vs-freshdesk .section-header { margin-bottom: 40px; }
  .page-vs-freshdesk .section-header h2 { font-size: 38px; font-weight: 600; margin-bottom: 12px; }
  .page-vs-freshdesk .section-body,
button,
input,
select,
textarea {
  font-family: 'DM Sans', sans-serif; font-size: 17px; }
  .page-vs-freshdesk .section-body p { margin-bottom: 20px; }

  /* ── Hero ── */
  .page-vs-freshdesk .hero {
    padding: 100px 0 0 0;
    text-align: center;
  }
  .page-vs-freshdesk .hero h1 {
    font-size: 52px;
    font-weight: 700;
    margin-bottom: 20px;
  }
  .page-vs-freshdesk .hero .subtitle {
    font-size: 19px;
    color: var(--charcoal-mid);
    margin-bottom: 36px;
    line-height: 1.6;
  }
  .page-vs-freshdesk .hero-graphic {
    max-width: 349px;
    width: 100%;
    margin-top: 12px;
  }

  /* ── Comparison Tables ── */
  .page-vs-freshdesk .comp-table {
    width: 100%;
    border-collapse: collapse;
    margin: 32px 0;
    font-size: 15px;
    background: #fff;
    box-shadow: 0 1px 4px rgba(0,0,0,0.06), 0 4px 16px rgba(0,0,0,0.04);
    border-radius: 8px;
    overflow: hidden;
  }
  .page-vs-freshdesk .comp-table thead th {
    background: var(--charcoal);
    color: var(--white);
    font-family: "Plus Jakarta Sans", sans-serif;
    font-weight: 600;
    font-size: 14px;
    padding: 14px 18px;
    text-align: left;
    border: none;
  }
  .page-vs-freshdesk .comp-table thead th.ours {
    background: var(--blue-dark);
  }
  .page-vs-freshdesk .comp-table tbody td {
    padding: 13px 18px;
    border-bottom: 1px solid var(--slate);
    border-top: none;
    border-left: none;
    border-right: none;
    vertical-align: top;
  }
  .page-vs-freshdesk .comp-table tbody td.ours {
    background: var(--blue-light);
    font-weight: 500;
  }
  .page-vs-freshdesk .comp-table tbody td:first-child {
    font-weight: 500;
    color: var(--charcoal);
  }
  .page-vs-freshdesk .comp-table tbody tr:last-child td { border-bottom: none; }
  .page-vs-freshdesk .price-highlight { font-weight: 700; color: var(--blue-dark); }

  /* ── Cost Cards ── */
  .page-vs-freshdesk .cost-grid {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 20px;
    margin: 32px 0;
  }
  .page-vs-freshdesk .cost-card {
    background: var(--white);
    border: 1px solid var(--border);
    border-radius: 10px;
    padding: 28px 28px 24px;
  }
  .page-vs-freshdesk .cost-card h4 {
    font-size: 16px;
    font-weight: 600;
    margin-bottom: 8px;
  }
  .page-vs-freshdesk .cost-card p {
    font-size: 15px;
    line-height: 1.55;
    margin: 0;
    color: var(--charcoal-mid);
  }

  /* ── Callout Boxes ── */
  .page-vs-freshdesk .callout {
  display: flex;
  align-items: flex-start;
  gap: 12px;
    border-radius: 0 10px 10px 0;
    padding: 20px 24px;
    margin: 32px 0;
    font-size: 15px;
    line-height: 1.6;
  }
  .page-vs-freshdesk .callout-orange {
    background: #fff7f5;
    border-left: 4px solid var(--orange);
  }
  .page-vs-freshdesk .callout-blue {
    background: var(--blue-light);
    border-left: 4px solid var(--blue);
  }
  .page-vs-freshdesk .section--alice .callout-blue {
    background: #fff;
  }
  .page-vs-freshdesk .callout strong { color: var(--charcoal); }
  .page-vs-freshdesk .callout-emphasis { zoom: 1.2; }
  .page-vs-freshdesk .callout p { margin-bottom: 12px; }
  .page-vs-freshdesk .callout p:last-child { margin-bottom: 0; }

  /* ── Feature Grid ── */
  .page-vs-freshdesk .feature-grid {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 1px;
    background: var(--slate);
    border-radius: 10px;
    overflow: hidden;
    margin: 32px 0;
  }
  .page-vs-freshdesk .feature-cell {
    background: var(--white);
    padding: 20px 24px;
  }
  .page-vs-freshdesk .feature-cell h4 {
    font-size: 16px;
    font-weight: 600;
    margin-bottom: 8px;
    display: flex;
    align-items: center;
    gap: 10px;
  }
  .page-vs-freshdesk .feature-cell h4::before {
    content: "";
    width: 8px;
    height: 8px;
    background: var(--green);
    border-radius: 50%;
    flex-shrink: 0;
  }
  .page-vs-freshdesk .feature-cell p {
    font-size: 15px;
    line-height: 1.55;
    margin: 0;
    color: var(--charcoal-mid);
  }

  /* ── Check/X marks in tables ── */
  .page-vs-freshdesk .yes { color: var(--green); font-weight: 700; font-size: 20px; }
  .page-vs-freshdesk .no { color: var(--slate); font-weight: 700; font-size: 20px; }
  .page-vs-freshdesk .warn { color: var(--orange); font-weight: 700; font-size: 20px; }

  /* ── Product Cards (Section 3) ── */
  .page-vs-freshdesk .product-grid {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 20px;
    margin: 32px 0;
  }
  .page-vs-freshdesk .product-card {
    background: var(--white);
    border: 1px solid var(--border);
    border-radius: 10px;
    padding: 28px 28px 24px;
  }
  .page-vs-freshdesk .product-card h4 {
    font-size: 16px;
    font-weight: 600;
    margin-bottom: 4px;
  }
  .page-vs-freshdesk .product-card .product-price {
    font-family: "Plus Jakarta Sans", sans-serif;
    font-size: 13px;
    font-weight: 600;
    color: var(--steel);
    letter-spacing: .02em;
    margin-bottom: 10px;
  }
  .page-vs-freshdesk .product-card p {
    font-size: 15px;
    line-height: 1.55;
    color: var(--charcoal-mid);
  }

  /* ── FAQ Accordion ── */
  .page-vs-freshdesk .faq-list { margin-top: 32px; }
  .page-vs-freshdesk .faq-item {
    border: 1px solid var(--border);
    border-radius: 10px;
    margin-bottom: 12px;
    overflow: hidden;
    transition: border-color 0.2s;
  }
  .page-vs-freshdesk .faq-item:hover { border-color: var(--blue); }
  .page-vs-freshdesk .faq-q {
    width: 100%;
    background: none;
    border: none;
    padding: 22px 28px;
    font-family: "Plus Jakarta Sans", sans-serif;
    font-size: 16px;
    font-weight: 600;
    color: var(--charcoal);
    text-align: left;
    cursor: pointer;
    display: flex;
    justify-content: space-between;
    align-items: center;
  }
  .page-vs-freshdesk .faq-q::after {
    content: "+";
    font-size: 22px;
    font-weight: 400;
    color: var(--blue);
    transition: transform 0.2s;
  }
  .page-vs-freshdesk .faq-item.open .faq-q::after {
    content: "−";
  }
  .page-vs-freshdesk .faq-a {
    display: none;
    padding: 0 28px 22px;
    font-size: 15px;
    line-height: 1.65;
    color: var(--charcoal-mid);
  }
  .page-vs-freshdesk .faq-item.open .faq-a { display: block; }

  /* ── Trust Strip ── */
  .page-vs-freshdesk .trust-logos {
    display: flex;
    align-items: center;
    justify-content: center;
    flex-wrap: wrap;
    gap: 40px 52px;
    margin-top: 32px;
  }
  .page-vs-freshdesk .trust-logos img {
    display: block;
    height: 40px;
    width: auto;
    filter: brightness(0) invert(1);
    opacity: 0.35;
  }

  /* ── Footer CTA ── */
/* ── Tagline ── */
  .page-vs-freshdesk .tagline {
    font-family: "Plus Jakarta Sans", sans-serif;
    font-size: 18px;
    font-weight: 600;
    color: var(--charcoal);
    margin-top: 20px;
  }

  /* ── Archiving Note ── */
  .page-vs-freshdesk .archiving-note {
    background: #fff7f5;
    border-left: 4px solid var(--orange);
    border-radius: 0 10px 10px 0;
    padding: 24px 28px;
    margin-top: 32px;
    font-size: 15px;
    line-height: 1.6;
  }
  .page-vs-freshdesk .archiving-note strong { color: var(--charcoal); }

  /* ── Responsive ── */
  @media (max-width: 768px) {
    .page-vs-freshdesk .wrap { padding: 0 24px; }
    .page-vs-freshdesk .section { padding: 56px 0; }
    .page-vs-freshdesk .hero { padding: 64px 0 56px; }
    .page-vs-freshdesk .hero h1 { font-size: 34px; }
    .page-vs-freshdesk .section-header h2 { font-size: 28px; }
    .page-vs-freshdesk .cost-grid { grid-template-columns: 1fr; }
    .page-vs-freshdesk .product-grid { grid-template-columns: 1fr; }
    .page-vs-freshdesk .feature-grid { grid-template-columns: 1fr; }
    .page-vs-freshdesk .comp-table { font-size: 13px; }
    .page-vs-freshdesk .comp-table thead th,
    .page-vs-freshdesk .comp-table tbody td { padding: 10px 12px; }
  }

/* ══════════════════════════════════════════════════════════
   Compare Page: vs vanilla osTicket
   ══════════════════════════════════════════════════════════ */
:root {
    --blue:         #419AD2;
    --blue-dark:    #2F7DB8;
    --blue-light:   #E8F5FC;
    --charcoal:     #444C56;
    --charcoal-mid: #5A6270;
    --steel:        #A6AFBC;
    --slate:        #C7D2DC;
    --green:        #82B541;
    --green-dark:   #6E9A38;
    --green-light:  #EAF3DE;
    --orange:       #F55C44;
    --orange-dark:  #D94E38;
    --white:        #ffffff;
    --border:       #C7D2DC;

  /* Error states */
  --red:          #C0392B;
  --red-light:    #FDECEA;
  }

  .page-vs-osticket *, .page-vs-osticket *::before, .page-vs-osticket *::after { box-sizing: border-box; margin: 0; padding: 0; }
  .page-vs-osticket { font-family: 'DM Sans', sans-serif; font-size: 17px; line-height: 1.65; color: var(--charcoal-mid); background: var(--white); -webkit-font-smoothing: antialiased; }
  .page-vs-osticket h1, .page-vs-osticket h2, .page-vs-osticket h3, .page-vs-osticket h4 { font-family: "Plus Jakarta Sans", sans-serif; color: var(--charcoal); line-height: 1.2; margin: 0; }
  .page-vs-osticket p { margin: 0; }
  .page-vs-osticket .wrap { max-width: 1100px; margin: 0 auto; padding: 0 48px; }

  .page-vs-osticket .eyebrow { font-family: "Plus Jakarta Sans", sans-serif; font-size: 12px; font-weight: 700; letter-spacing: .09em; text-transform: uppercase; color: var(--blue); margin-bottom: 12px; }
  .page-vs-osticket .on-dark .eyebrow { color: var(--green); }

  .page-vs-osticket .btn { display: inline-block; font-family: "Plus Jakarta Sans", sans-serif; font-size: 15px; font-weight: 600; letter-spacing: .02em; text-decoration: none; border-radius: 4px; padding: 13px 28px; transition: all 0.2s ease; cursor: pointer; border: none; }
  .page-vs-osticket .btn-orange { background: var(--orange); color: var(--white); box-shadow: 0 3px 0 rgba(160,60,40,.9); }
  .page-vs-osticket .btn-orange:hover { background: var(--orange-dark); }
  .page-vs-osticket .btn-white { background: var(--white); color: var(--blue-dark); }
  .page-vs-osticket .btn-white:hover { background: #f0f4f8; }
  .page-vs-osticket .btn-white-outline { background: transparent; color: var(--white); border: 2px solid rgba(255,255,255,.5); }
  .page-vs-osticket .btn-white-outline:hover { border-color: rgba(255,255,255,.8); }
  .page-vs-osticket .btn-group { display: flex; gap: 16px; flex-wrap: wrap; }

  .page-vs-osticket .section { padding: 88px 0; }
  .page-vs-osticket .section--alice { background: var(--blue-light); }
  .page-vs-osticket .section--charcoal { background: var(--charcoal); color: rgba(255,255,255,.65); }
  .page-vs-osticket .section--charcoal h2 { color: var(--white); }
  .page-vs-osticket .section--charcoal .eyebrow { color: var(--green); }

  .page-vs-osticket .section-header { margin-bottom: 40px; }
  .page-vs-osticket .section-header h2 { font-size: 38px; font-weight: 600; margin-bottom: 12px; }
  .page-vs-osticket .section-body,
button,
input,
select,
textarea {
  font-family: 'DM Sans', sans-serif; font-size: 17px; }
  .page-vs-osticket .section-body p { margin-bottom: 20px; }

  .page-vs-osticket .hero { padding: 100px 0 0 0; text-align: center; }
  .page-vs-osticket .hero h1 { font-size: 52px; font-weight: 600; margin-bottom: 20px; }
  .page-vs-osticket .hero .subtitle { font-size: 19px; color: var(--charcoal-mid); margin-bottom: 36px; line-height: 1.6; }
  .page-vs-osticket .hero-graphic { max-width: 480px; width: 100%; margin-top: 12px; }

  .page-vs-osticket .feature-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 1px; background: var(--slate); border-radius: 10px; overflow: hidden; margin: 32px 0; }
  .page-vs-osticket .feature-cell { background: var(--white); padding: 20px 24px; }
  .page-vs-osticket .feature-cell h4 { font-size: 16px; font-weight: 600; margin-bottom: 8px; display: flex; align-items: center; gap: 10px; }
  .page-vs-osticket .feature-cell h4::before { content: ""; width: 8px; height: 8px; background: var(--green); border-radius: 50%; flex-shrink: 0; }
  .page-vs-osticket .feature-cell p { font-size: 15px; line-height: 1.55; margin: 0; color: var(--charcoal-mid); }

  .page-vs-osticket .callout {
  display: flex;
  align-items: flex-start;
  gap: 12px; border-radius: 0 10px 10px 0; padding: 20px 24px; margin: 32px 0; font-size: 15px; line-height: 1.6; }
  .page-vs-osticket .callout-green { background: var(--green-light); border-left: 4px solid var(--green); }
  .page-vs-osticket .callout strong { color: var(--charcoal); }
  .page-vs-osticket .callout p { margin-bottom: 12px; }
  .page-vs-osticket .callout p:last-child { margin-bottom: 0; }

  /* ── Before/After panel ── */
  .page-vs-osticket .before-after { display: grid; grid-template-columns: 1fr 1fr; gap: 24px; margin: 32px 0; }
  .page-vs-osticket .before-after-panel { border-radius: 10px; overflow: hidden; text-align: center; }
  .page-vs-osticket .before-after-panel img { width: 100%; display: block; }
  .page-vs-osticket .before-after-label { font-family: "Plus Jakarta Sans", sans-serif; font-size: 13px; font-weight: 700; letter-spacing: .09em; text-transform: uppercase; padding: 14px; }
  .page-vs-osticket .before-label { background: rgba(255,255,255,.1); color: rgba(255,255,255,.5); }
  .page-vs-osticket .after-label { background: rgba(255,255,255,.1); color: var(--green); }

  .page-vs-osticket .faq-list { margin-top: 32px; }
  .page-vs-osticket .faq-item { border: 1px solid var(--border); border-radius: 10px; margin-bottom: 12px; overflow: hidden; transition: border-color 0.2s; }
  .page-vs-osticket .faq-item:hover { border-color: var(--blue); }
  .page-vs-osticket .faq-q { width: 100%; background: none; border: none; padding: 22px 28px; font-family: "Plus Jakarta Sans", sans-serif; font-size: 16px; font-weight: 600; color: var(--charcoal); text-align: left; cursor: pointer; display: flex; justify-content: space-between; align-items: center; }
  .page-vs-osticket .faq-q::after { content: "+"; font-size: 22px; font-weight: 400; color: var(--blue); transition: transform 0.2s; }
  .page-vs-osticket .faq-item.open .faq-q::after { content: "−"; }
  .page-vs-osticket .faq-a { display: none; padding: 0 28px 22px; font-size: 15px; line-height: 1.65; color: var(--charcoal-mid); }
  .page-vs-osticket .faq-item.open .faq-a { display: block; }

  .page-vs-osticket .trust-logos { display: flex; align-items: center; justify-content: center; flex-wrap: wrap; gap: 40px 52px; margin-top: 32px; }
  .page-vs-osticket .trust-logos img { display: block; height: 40px; width: auto; filter: brightness(0) invert(1); opacity: 0.35; }

@media (max-width: 768px) {
    .page-vs-osticket .wrap { padding: 0 24px; }
    .page-vs-osticket .section { padding: 56px 0; }
    .page-vs-osticket .hero { padding: 64px 0 56px; }
    .page-vs-osticket .hero h1 { font-size: 34px; }
    .page-vs-osticket .section-header h2 { font-size: 28px; }
    .page-vs-osticket .feature-grid { grid-template-columns: 1fr; }
    .page-vs-osticket .before-after { grid-template-columns: 1fr; }
  }


/* ═══════════════════════════════════════════════════
   Compare Page: vs SupportPal
   ═══════════════════════════════════════════════════ */

:root {
    --blue:         #419AD2;
    --blue-dark:    #2F7DB8;
    --blue-light:   #E8F5FC;
    --charcoal:     #444C56;
    --charcoal-mid: #5A6270;
    --steel:        #A6AFBC;
    --slate:        #C7D2DC;
    --green:        #82B541;
    --green-dark:   #6E9A38;
    --green-light:  #EAF3DE;
    --orange:       #F55C44;
    --orange-dark:  #D94E38;
    --white:        #ffffff;
    --border:       #C7D2DC;

  /* Error states */
  --red:          #C0392B;
  --red-light:    #FDECEA;
  }

  .page-vs-supportpal *,
  .page-vs-supportpal *::before,
  .page-vs-supportpal *::after { box-sizing: border-box; margin: 0; padding: 0; }

  .page-vs-supportpal {
    font-family: 'DM Sans', sans-serif;
    font-size: 17px;
    line-height: 1.65;
    color: var(--charcoal-mid);
    background: var(--white);
    -webkit-font-smoothing: antialiased;
  }

  .page-vs-supportpal h1, .page-vs-supportpal h2, .page-vs-supportpal h3, .page-vs-supportpal h4 {
    font-family: "Plus Jakarta Sans", sans-serif;
    color: var(--charcoal);
    line-height: 1.2;
    margin: 0;
  }

  .page-vs-supportpal p { margin: 0; }

  .page-vs-supportpal .wrap { max-width: 1100px; margin: 0 auto; padding: 0 48px; }

  .page-vs-supportpal .eyebrow { font-family: "Plus Jakarta Sans", sans-serif; font-size: 12px; font-weight: 700; letter-spacing: .09em; text-transform: uppercase; color: var(--blue); margin-bottom: 12px; }
  .page-vs-supportpal .on-dark .eyebrow { color: var(--green); }

  .page-vs-supportpal .btn { display: inline-block; font-family: "Plus Jakarta Sans", sans-serif; font-size: 15px; font-weight: 600; letter-spacing: .02em; text-decoration: none; border-radius: 4px; padding: 13px 28px; transition: all 0.2s ease; cursor: pointer; border: none; }
  .page-vs-supportpal .btn-orange { background: var(--orange); color: var(--white); box-shadow: 0 3px 0 rgba(160,60,40,.9); }
  .page-vs-supportpal .btn-orange:hover { background: var(--orange-dark); }
  .page-vs-supportpal .btn-white { background: var(--white); color: var(--blue-dark); }
  .page-vs-supportpal .btn-white:hover { background: #f0f4f8; }
  .page-vs-supportpal .btn-white-outline { background: transparent; color: var(--white); border: 2px solid rgba(255,255,255,.5); }
  .page-vs-supportpal .btn-white-outline:hover { border-color: rgba(255,255,255,.8); }
  .page-vs-supportpal .btn-group { display: flex; gap: 16px; flex-wrap: wrap; }

  .page-vs-supportpal .section { padding: 88px 0; }
  .page-vs-supportpal .section--alice { background: var(--blue-light); }
  .page-vs-supportpal .section--charcoal { background: var(--charcoal); color: rgba(255,255,255,.65); }
  .page-vs-supportpal .section--charcoal h2 { color: var(--white); }
  .page-vs-supportpal .section--charcoal .eyebrow { color: var(--green); }

  .page-vs-supportpal .section-header { margin-bottom: 40px; }
  .page-vs-supportpal .section-header h2 { font-size: 38px; font-weight: 600; margin-bottom: 12px; }
  .page-vs-supportpal .section-body,
button,
input,
select,
textarea {
  font-family: 'DM Sans', sans-serif; font-size: 17px; }
  .page-vs-supportpal .section-body p { margin-bottom: 20px; }

  .page-vs-supportpal .hero { padding: 100px 0 0 0; text-align: center; }
  .page-vs-supportpal .hero h1 { font-size: 52px; font-weight: 600; margin-bottom: 20px; }
  .page-vs-supportpal .hero .subtitle { font-size: 19px; color: var(--charcoal-mid); margin-bottom: 36px; line-height: 1.6; }
  .page-vs-supportpal .hero-graphic { max-width: 349px; width: 100%; margin-top: 12px; }

  .page-vs-supportpal .comp-table { width: 100%; border-collapse: collapse; margin: 32px 0; font-size: 15px; background: #fff; box-shadow: 0 1px 4px rgba(0,0,0,0.06), 0 4px 16px rgba(0,0,0,0.04); border-radius: 8px; overflow: hidden; }
  .page-vs-supportpal .comp-table thead th { background: var(--charcoal); color: var(--white); font-family: "Plus Jakarta Sans", sans-serif; font-weight: 600; font-size: 14px; padding: 14px 18px; text-align: left; border: none; }
  .page-vs-supportpal .comp-table thead th.ours { background: var(--blue-dark); }
  .page-vs-supportpal .comp-table tbody td { padding: 13px 18px; border-bottom: 1px solid var(--slate); vertical-align: top; }
  .page-vs-supportpal .comp-table tbody td.ours { background: var(--blue-light); font-weight: 500; }
  .page-vs-supportpal .comp-table tbody td:first-child { font-weight: 500; color: var(--charcoal); }
  .page-vs-supportpal .comp-table tbody tr:last-child td { border-bottom: none; }
  .page-vs-supportpal .price-highlight { font-weight: 700; color: var(--blue-dark); }

  .page-vs-supportpal .cost-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 20px; margin: 32px 0; }
  .page-vs-supportpal .cost-card { background: var(--white); border: 1px solid var(--border); border-radius: 10px; padding: 28px 28px 24px; }
  .page-vs-supportpal .cost-card h4 { font-size: 16px; font-weight: 600; margin-bottom: 8px; }
  .page-vs-supportpal .cost-card p { font-size: 15px; line-height: 1.55; margin: 0 0 10px; color: var(--charcoal-mid); }
  .page-vs-supportpal .cost-card p:last-child { margin-bottom: 0; }
  .page-vs-supportpal .cost-card em { color: var(--steel); font-style: italic; }

  .page-vs-supportpal .callout {
  display: flex;
  align-items: flex-start;
  gap: 12px; border-radius: 0 10px 10px 0; padding: 20px 24px; margin: 32px 0; font-size: 15px; line-height: 1.6; }
  .page-vs-supportpal .callout-orange { background: #fff7f5; border-left: 4px solid var(--orange); }
  .page-vs-supportpal .callout-blue { background: var(--blue-light); border-left: 4px solid var(--blue); }
  .page-vs-supportpal .section--alice .callout-blue { background: #fff; }
  .page-vs-supportpal .callout strong { color: var(--charcoal); }
  .page-vs-supportpal .callout p { margin-bottom: 12px; }
  .page-vs-supportpal .callout p:last-child { margin-bottom: 0; }

  .page-vs-supportpal .feature-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 1px; background: var(--slate); border-radius: 10px; overflow: hidden; margin: 32px 0; }
  .page-vs-supportpal .feature-cell { background: var(--white); padding: 20px 24px; }
  .page-vs-supportpal .feature-cell h4 { font-size: 16px; font-weight: 600; margin-bottom: 8px; display: flex; align-items: center; gap: 10px; }
  .page-vs-supportpal .feature-cell h4::before { content: ""; width: 8px; height: 8px; background: var(--green); border-radius: 50%; flex-shrink: 0; }
  .page-vs-supportpal .feature-cell p { font-size: 15px; line-height: 1.55; margin: 0; color: var(--charcoal-mid); }

  .page-vs-supportpal .yes { color: var(--green); font-weight: 700; font-size: 20px; }
  .page-vs-supportpal .no { color: var(--slate); font-weight: 700; font-size: 20px; }
  .page-vs-supportpal .warn { color: var(--orange); font-weight: 700; font-size: 20px; }

  .page-vs-supportpal .faq-list { margin-top: 32px; }
  .page-vs-supportpal .faq-item { border: 1px solid var(--border); border-radius: 10px; margin-bottom: 12px; overflow: hidden; transition: border-color 0.2s; }
  .page-vs-supportpal .faq-item:hover { border-color: var(--blue); }
  .page-vs-supportpal .faq-q { width: 100%; background: none; border: none; padding: 22px 28px; font-family: "Plus Jakarta Sans", sans-serif; font-size: 16px; font-weight: 600; color: var(--charcoal); text-align: left; cursor: pointer; display: flex; justify-content: space-between; align-items: center; }
  .page-vs-supportpal .faq-q::after { content: "+"; font-size: 22px; font-weight: 400; color: var(--blue); transition: transform 0.2s; }
  .page-vs-supportpal .faq-item.open .faq-q::after { content: "−"; }
  .page-vs-supportpal .faq-a { display: none; padding: 0 28px 22px; font-size: 15px; line-height: 1.65; color: var(--charcoal-mid); }
  .page-vs-supportpal .faq-item.open .faq-a { display: block; }

  .page-vs-supportpal .trust-logos { display: flex; align-items: center; justify-content: center; flex-wrap: wrap; gap: 40px 52px; margin-top: 32px; }
  .page-vs-supportpal .trust-logos img { display: block; height: 40px; width: auto; filter: brightness(0) invert(1); opacity: 0.35; }

.page-vs-supportpal .tagline { font-family: "Plus Jakarta Sans", sans-serif; font-size: 18px; font-weight: 600; color: var(--charcoal); margin-top: 20px; }

  @media (max-width: 768px) {
    .page-vs-supportpal .wrap { padding: 0 24px; }
    .page-vs-supportpal .section { padding: 56px 0; }
    .page-vs-supportpal .hero { padding: 64px 0 56px; }
    .page-vs-supportpal .hero h1 { font-size: 34px; }
    .page-vs-supportpal .section-header h2 { font-size: 28px; }
    .page-vs-supportpal .cost-grid { grid-template-columns: 1fr; }
    .page-vs-supportpal .feature-grid { grid-template-columns: 1fr; }
    .page-vs-supportpal .comp-table { font-size: 13px; }
    .page-vs-supportpal .comp-table thead th, .page-vs-supportpal .comp-table tbody td { padding: 10px 12px; }
  }

/* =========================================================
   Split Layout (text + image side by side)
   ========================================================= */
.oa-split {
  display: flex;
  gap: 48px;
  align-items: center;
}
.oa-split-text {
  flex: 1;
}
.oa-split-image {
  flex: 1;
  text-align: center;
}
.oa-split-image img {
  max-width: 100%;
  border-radius: 10px;
}

@media (max-width: 500px) {
  .oa-split {
    flex-direction: column;
    gap: 0;
  }
  .oa-split-text {
    display: flex;
    flex-direction: column;
  }
  .oa-split-text h3 {
    order: 1;
  }
  .oa-split-image {
    order: 2;
    width: 100%;
    margin: 16px 0;
  }
  .oa-split-text p {
    order: 3;
  }
}



/* ---------------------------------------------------------
   Contact Form Gating Banners
   --------------------------------------------------------- */

.osa-contact-banner {
  border-radius: var(--radius-md);
  padding: 20px 24px;
  margin-bottom: 24px;
}

.osa-contact-guest {
  background: var(--green-light);
  border: 1px solid #D5E5C2;
}

.osa-contact-expired {
  background: #fff7f5;
  border: 1px solid #F1C7BB;
}

.osa-contact-expired .oa-btn {
  margin-top: 12px;
}



/* =========================================================
   Contact Form (Gravity Forms ID 1)
   ========================================================= */

/* Page loading overlay */
#gform_1 .gform-loader {
  position: fixed;
  top: 0; left: 0;
  width: 100%; height: 100%;
  display: flex;
  align-items: center;
  justify-content: center;
  z-index: 9999;
  background: transparent;
  border: none !important;
  border-radius: 0 !important;
  block-size: 100% !important;
  inline-size: 100% !important;
  font-size: 0 !important;
  animation: none !important;
}

/* Field labels */
#gform_1 .gfield_label {
  font-size: 20px;
}

/* Hide field label on page 1 (intro heading handles it) */
#gform_page_1_1 .gfield_label {
  display: none;
}

/* ── Hide native radio field (replaced by card selector) ── */
#field_1_4 { display: none !important; }

/* ── Card-style topic selector (page 1) ── */

.osa-contact-selector { max-width: 1100px; width: 100%; text-align: center; }

.osa-step-badge {
  display: inline-block;
  font-family: 'Plus Jakarta Sans', sans-serif;
  font-size: 12px; font-weight: 600; letter-spacing: 0.08em;
  color: #419AD2; background: #e0eef8;
  padding: 5px 14px; border-radius: 20px; margin-bottom: 20px;
}

.osa-contact-selector h3 {
  font-family: 'Plus Jakarta Sans', sans-serif;
  font-weight: 700; font-size: 32px; color: #444C56; margin: 0 0 12px;
}

.osa-contact-selector .osa-subtitle {
  font-size: 15px; color: #6E747C; margin-bottom: 36px; line-height: 1.5;
}

.osa-card-grid {
  display: flex; gap: 16px; justify-content: center; margin-bottom: 28px;
}

.osa-card {
  flex: 1; max-width: 200px; background: #fff;
  border: 1.5px solid #D6D8DC; border-radius: 14px;
  padding: 28px 16px 22px; cursor: pointer;
  transition: border-color 0.2s, box-shadow 0.2s, transform 0.15s;
  position: relative; display: flex; flex-direction: column;
  align-items: center; text-align: center;
}

.osa-card:hover {
  border-color: #8BBDE0;
  box-shadow: 0 4px 16px rgba(65,154,210,0.1);
  transform: translateY(-2px);
}

.osa-card.selected {
  border-color: #419AD2;
  box-shadow: 0 0 0 2px rgba(65,154,210,0.15), 0 4px 16px rgba(65,154,210,0.1);
}

.osa-card .osa-checkmark {
  position: absolute; top: -8px; right: -8px; width: 26px; height: 26px;
  background: #419AD2; border-radius: 50%;
  display: flex; align-items: center; justify-content: center;
  opacity: 0; transform: scale(0.6); transition: opacity 0.2s, transform 0.2s;
}

.osa-card.selected .osa-checkmark { opacity: 1; transform: scale(1); }

.osa-checkmark svg { width: 14px; height: 14px; }

.osa-card .osa-icon-circle {
  width: 56px; height: 56px; border-radius: 50%;
  display: flex; align-items: center; justify-content: center;
  margin-bottom: 16px; transition: background 0.2s;
}

.osa-card .osa-icon-circle svg { width: 26px; height: 26px; }

.osa-card[data-topic="presales"] .osa-icon-circle     { background: #E9F5FC; }
.osa-card[data-topic="presales"] .osa-icon-circle svg  { color: #419AD2; }
.osa-card[data-topic="strategy"] .osa-icon-circle     { background: #EDF5E4; }
.osa-card[data-topic="strategy"] .osa-icon-circle svg  { color: #82B541; }
.osa-card[data-topic="billing"] .osa-icon-circle      { background: #E9F5FC; }
.osa-card[data-topic="billing"] .osa-icon-circle svg   { color: #419AD2; }
.osa-card[data-topic="techsupport"] .osa-icon-circle  { background: #EDEEF0; }
.osa-card[data-topic="techsupport"] .osa-icon-circle svg { color: #444C56; }
.osa-card[data-topic="other"] .osa-icon-circle        { background: #E9F5FC; }
.osa-card[data-topic="other"] .osa-icon-circle svg     { color: #419AD2; }

.osa-card .osa-card-title {
  font-family: 'Plus Jakarta Sans', sans-serif;
  font-weight: 600; font-size: 15px; color: #444C56; margin-bottom: 6px;
}

.osa-card .osa-card-desc {
  font-size: 13px; color: #8B9099; line-height: 1.4; margin-bottom: 14px; flex: 1;
}

.osa-card .osa-arrow-circle {
  width: 32px; height: 32px; border-radius: 50%;
  border: 1.5px solid #D6D8DC;
  display: flex; align-items: center; justify-content: center;
  transition: background 0.2s, border-color 0.2s;
}

.osa-card .osa-arrow-circle svg {
  width: 14px; height: 14px; color: #A8ADB5; transition: color 0.2s;
}

.osa-card.selected .osa-arrow-circle { background: #419AD2; border-color: #419AD2; }
.osa-card.selected .osa-arrow-circle svg { color: #fff; }

.osa-card .osa-chevron { display: none; }

.osa-reassurance {
  display: flex; align-items: center; justify-content: center;
  gap: 8px; font-size: 14px; color: #6E747C;
}

.osa-reassurance .osa-shield {
  width: 20px; height: 20px; color: #82B541; flex-shrink: 0;
}

/* Card gate message (tech support gating) */
#osa-card-gate-msg {
  text-align: left;
  padding: 28px 24px;
  background: #fff;
  border: 1.5px solid #D6D8DC;
  border-radius: 14px;
  margin-top: 20px;
  font-size: 15px;
  line-height: 1.7;
  color: #444C56;
}

#osa-card-gate-msg h4 {
  margin: 0 0 12px;
  font-family: 'Plus Jakarta Sans', sans-serif;
  font-size: 20px; font-weight: 600; color: #444C56;
}

#osa-card-gate-msg p { margin: 0 0 20px; }

#osa-card-gate-msg .osa-gate-buttons {
  display: flex; gap: 12px; flex-wrap: wrap; margin: 0 0 24px;
}

#osa-card-gate-msg .osa-gate-btn {
  display: inline-block; padding: 10px 24px;
  border-radius: 6px; text-decoration: none;
  font-weight: 500; font-size: 14px; color: #fff;
}

#osa-card-gate-msg .osa-gate-btn-primary { background: #419AD2; }
#osa-card-gate-msg .osa-gate-btn-secondary { background: #A6AFBC; }
#osa-card-gate-msg .osa-gate-btn-renew { background: #F55C44; }

#osa-card-gate-msg .osa-gate-chatty {
  display: flex; align-items: flex-start; gap: 12px;
  padding: 16px 20px; background: #f0f4f8; border-radius: 10px;
}

#osa-card-gate-msg .osa-gate-chatty img {
  width: 32px; height: 32px; flex-shrink: 0; border-radius: 0;
}

/* ── Responsive: card grid ── */

@media (max-width: 768px) {
  .osa-contact-selector h3 { font-size: 24px; }
  .osa-contact-selector .osa-subtitle { margin-bottom: 24px; }
  .osa-card-grid { flex-direction: column; gap: 10px; }
  .osa-card {
    max-width: 100%; flex-direction: row; align-items: center;
    text-align: left; padding: 16px 18px; border-radius: 12px;
  }
  .osa-card .osa-icon-circle {
    width: 44px; height: 44px; margin-bottom: 0;
    margin-right: 14px; flex-shrink: 0;
  }
  .osa-card .osa-icon-circle svg { width: 22px; height: 22px; }
  .osa-card .osa-card-text { flex: 1; min-width: 0; }
  .osa-card .osa-card-title { font-size: 15px; margin-bottom: 2px; }
  .osa-card .osa-card-desc { font-size: 13px; margin-bottom: 0; }
  .osa-card .osa-arrow-circle { display: none; }
  .osa-card .osa-chevron {
    display: flex; align-items: center; justify-content: center;
    margin-left: 12px; flex-shrink: 0;
  }
  .osa-card .osa-chevron svg {
    width: 18px; height: 18px; color: #A8ADB5; transition: color 0.2s;
  }
  .osa-card.selected .osa-chevron svg { color: #419AD2; }
  .osa-card .osa-checkmark { top: -6px; right: -6px; width: 22px; height: 22px; }
  .osa-checkmark svg { width: 12px; height: 12px; }
}

@media (min-width: 769px) and (max-width: 1050px) {
  .osa-card-grid { flex-wrap: wrap; }
  .osa-card { max-width: calc(33.333% - 12px); flex: 0 0 calc(33.333% - 12px); }
}

/* ── Hide Next button until selection ── */

#gform_1 .gform_page_footer.gform_page_footer--hidden {
  visibility: hidden;
  opacity: 0;
}

/* ── Footer buttons ── */

#gform_1 .gform_page_footer {
  margin-top: 20px;
  padding: 0;
  display: flex;
  justify-content: flex-end;
  gap: 12px;
  
  overflow: hidden;
}

/* ── Clickable step navigation ── */

#gform_1 .gf_page_steps .gf_step.gf_step_completed,
#gform_1 .gf_page_steps .gf_step.gf_step_active,
#gform_1 .gf_page_steps .gf_step.gf_step_previous {
  cursor: pointer;
}

#gform_1 .gf_page_steps .gf_step.gf_step_completed:hover .gf_step_number,
#gform_1 .gf_page_steps .gf_step.gf_step_previous:hover .gf_step_number {
  background-color: #419AD2;
  color: #fff;
  transition: background-color 0.2s;
}

#gform_1 .gf_page_steps .gf_step.gf_step_completed:hover .gf_step_label,
#gform_1 .gf_page_steps .gf_step.gf_step_previous:hover .gf_step_label {
  text-decoration: underline;
}

/* ── Theme Information paste textarea ── */

#field_1_22 textarea {
  height: 52px !important;
  min-height: 52px !important;
  resize: none;
}

/* Browser field suffix */
#field_1_30 .gfield_label::after {
  content: " (If applicable)";
  font-weight: 400;
  font-size: 80%;
}

/* ── "Take me to the Forum" button ── */

/* ── Forum / Contact Developer buttons ── */
div#gf5-support-buttons {
  display: flex;
  gap: 12px;
  flex-wrap: wrap;
  margin-top: 16px;
}
div#gf5-support-buttons a[href="/community/"] {
  display: inline-block;
  background: #419AD2;
  color: #fff;
  padding: 10px 22px;
  border-radius: 4px;
  border: none;
  text-decoration: none;
  font-family: 'Plus Jakarta Sans', sans-serif;
  font-weight: 600;
  font-size: 14px;
  letter-spacing: .08em;
  box-shadow: 0 2px 0 0 #2F7DB8;
}
div#gf5-support-buttons a[href="/community/"]:hover {
  background: #2F7DB8;
}
button#gf5-contact-dev-btn {
  background: #dcdfe2;
  color: #3b4450;
  padding: 10px 22px;
  border-radius: 4px;
  border: none;
  font-family: 'Plus Jakarta Sans', sans-serif;
  font-weight: 600;
  font-size: 14px;
  letter-spacing: .08em;
  cursor: pointer;
  box-shadow: 0 2px 0 0 #b1b2b3;
}
button#gf5-contact-dev-btn:hover {
  background: #c8ccd0;
}

/* ── Page 1 intro heading ── */
#gform_1 .gf5-intro {
  text-align: center;
  padding: 24px 0 0 0;
}
#gform_1 .gf5-intro h3 {
  margin: 0 0 6px;
  font-family: 'Plus Jakarta Sans', sans-serif;
  font-size: 20px;
  font-weight: 700;
  color: #444C56;
}
#gform_1 .gf5-intro p,
#gform_1 #field_1_37 p {
  margin: 0 auto;
  color: #5A6270;
  font-size: 15px;
  text-align: center;
}

/* ── Pages 2 & 3 category heading ── */
.gf5-page-heading {
  text-align: center;
  padding: 20px 0 8px 0;
}
.gf5-page-heading h3 {
  margin: 0 0 4px;
  font-family: 'Plus Jakarta Sans', sans-serif;
  font-size: 20px;
  font-weight: 700;
  color: #444C56;
}
.gf5-page-heading p {
  font-size: 14px;
  color: #5A6270;
  margin: 0;
}

/* ── Callout boxes (info/blue style per design system) ── */
.gf5-nudge,
.gf5-tips,
.gf5-presales-nudge {
  background: #E8F5FC;
  border-left: 4px solid #419AD2;
  border-radius: 0 10px 10px 0;
  padding: 20px 24px;
  margin: 12px 0;
  font-size: 14px;
  line-height: 1.6;
  color: #444C56;
}
.gf5-nudge strong,
.gf5-presales-nudge strong {
  font-weight: 600;
  font-size: 14px;
}
.gf5-presales-nudge a {
  font-weight: 600;
  color: #419AD2;
}
.gf5-presales-nudge a:hover {
  color: #2F7DB8;
}

.gf5-tips ul {
  margin: 8px 0 4px 20px;
  font-size: 14px;
}
.gf5-tips .gf5-warning {
  color: #D94E38;
  font-size: 13px;
}
.gf5-tips img {
  max-width: 100%;
  margin-top: 8px;
  border-radius: 6px;
}

/* ── Billing note (orange/alert callout per design system) ── */
.gf5-billing-note {
  background: #fff7f5;
  border-left: 4px solid #F55C44;
  border-radius: 0 10px 10px 0;
  padding: 20px 24px;
  margin: 12px 0;
  font-size: 14px;
  line-height: 1.6;
  color: #444C56;
}
.gf5-billing-note strong {
  font-weight: 600;
  font-size: 14px;
}

/* ── "Other" nudge ── */
.gf5-other-nudge {
  padding: 8px 0;
  font-size: 14px;
  color: #5A6270;
}
.gf5-other-nudge strong {
  font-weight: 600;
  color: #444C56;
}

/* ── Info chooser cards (paste vs manual) ── */
#gf5-info-chooser p {
  margin: 0 0 12px;
  font-size: 14px;
  color: #5A6270;
}
#gf5-info-chooser .gf5-chooser-buttons {
  display: flex;
  gap: 12px;
  flex-wrap: wrap;
}
#gf5-info-chooser .gf5-chooser-btn {
  flex: 1;
  min-width: 200px;
  padding: 14px 20px;
  background: #fff;
  border: 1.5px solid #C7D2DC;
  border-radius: 8px;
  cursor: pointer;
  text-align: left;
  font-size: 14px;
  font-family: inherit;
  transition: border-color 0.15s;
}
#gf5-info-chooser .gf5-chooser-btn:hover {
  border-color: #419AD2;
}
#gf5-info-chooser .gf5-chooser-btn.active {
  border-color: #419AD2;
  background: #E8F5FC;
}
#gf5-info-chooser .gf5-chooser-btn strong {
  display: block;
  margin-bottom: 4px;
  font-weight: 600;
  font-size: 14px;
  color: #444C56;
}
#gf5-info-chooser .gf5-chooser-btn span {
  font-size: 13px;
  color: #A6AFBC;
}

/* ── Manual entry note ── */
.gf5-manual-note {
  font-size: 13px;
  color: #A6AFBC;
  margin: 0 0 8px;
}

.gf5-manual-note {
  font-size: 0.85em;
  color: #666;
  margin: 4px 0 8px;
}

/* Support buttons container */
#gf5-support-buttons {
  text-align: center;
  margin-top: 8px;
}

/* Center the radio choices */

/* Center and style step indicators */
.gform_wrapper.gravity-theme .gf_page_steps {
  border-bottom: 1px solid #e5e7eb;
  margin-bottom: 12px;
  width: fit-content;
  margin: 0 auto;
}

textarea#input_1_9 {
  max-width: 100% !important;
}

.gform_page {
  max-width: 800px;
  margin: 0 auto;
}

#gform_page_1_1 {
  max-width: 1200px;
  margin: 0 auto;
}

/* ── Strategy Session fields ── */
#gform_1 .gf_left_half input[type="text"],
#gform_1 .gf_left_half select,
#gform_1 .gf_right_half input[type="text"],
#gform_1 .gf_right_half select {
  width: 100%;
}

input#input_1_42 {
  width: 100% !important;
}

fieldset#field_1_4 {
  max-width: 647px;
  /* background: #ccc; */
  margin: 0 auto;
}

/* Chatbot header font */
#osa-header-title {
  font-family: 'Lato', sans-serif !important;
}

#osa-chatbot-header svg {
  width: 26px;
  height: 24px;
}

#osa-header-title {
  font-family: 'Lato', sans-serif !important;
  font-size: 18px;
  font-weight: 300;
  padding: 3px 0 0 0;
}

#osa-chatbot button[aria-label="Close"] {
  color: #fff !important;
  padding: 14px 0 0 0;
  opacity: 0.8;
}

#send-message-button {
  align-self: center;
}

/* Chatbot send button - vertically center in input row */
#send-message-button {
  align-items: center !important;
  display: inline-flex !important;
}

#send-message-button svg {
  margin: 0 !important;
}

/* =========================================================
   Installation Instructions Form (GF ID 2)
   ========================================================= */

/* Field labels - match old site style */
#gform_2 .gfield_label {
  font-size: 24px;
  font-weight: 400;
  color: #555;
}

/* Radio options spacing */
#gform_2 .gfield_radio {
  display: flex;
  flex-direction: column;
  gap: 8px;
  margin-top: 12px;
}

#gform_2 .gfield_radio .gchoice {
  padding: 4px 0 4px 8px;
}

#gform_2 .gfield_radio .gchoice input[type="radio"] {
  margin-right: 10px;
  transform: scale(1.15);
}

#gform_2 .gfield_radio .gchoice label {
  font-size: 16px;
  cursor: pointer;
}

/* Hide submit button - form auto-advances */
#gform_2 .gform_footer {
  display: none;
}

/* Instructions buttons at end of conditional logic */
#gform_2 .gfield_html button[type="button"] {
  background: #dcdfe2;
  color: #3b4450;
  border: 0;
  border-radius: var(--radius-sm);
  padding: 12px 18px;
  font-weight: 600;
  font-size: 16px;
  cursor: pointer;
  -webkit-box-shadow: 0 3px 0 0 #b1b2b3;
  -moz-box-shadow: 0 3px 0 0 #b1b2b3;
  box-shadow: 0 2px 0 0 #b1b2b3;
  transition: transform 0.15s ease, background-color 0.18s ease;
}

#gform_2 .gfield_html button[type="button"]:hover {
  background: #cdd0d4;
  animation: pulse 0.8s ease-in-out;
}

.page-id-6377 .entry-content {
  max-width: 1200px;
  margin: 0 auto;
  padding: 2em 0;
}

.page-id-6377 input {
  margin: 0;
}

.page-id-6377 .gform-body.gform_body button {
  min-width: 200px;
  margin-top: 30px;
}

/* =========================================================
   Terminal Block (Ubuntu-inspired purple)
   ========================================================= */

.osa-terminal {
  background: #300a24;
  border-radius: 8px;
  margin: 20px 0;
  overflow: hidden;
  font-family: 'SF Mono', 'Fira Code', 'Cascadia Code', 'Ubuntu Mono', Consolas, monospace;
}

.osa-terminal-header {
  background: #3c1130;
  padding: 8px 14px;
  display: flex;
  align-items: center;
  gap: 6px;
}

.osa-terminal-dot {
  width: 12px;
  height: 12px;
  border-radius: 50%;
}

.osa-terminal-dot.red { background: #e05f56; }
.osa-terminal-dot.yellow { background: #f2bd3a; }
.osa-terminal-dot.green { background: #57c038; }

.osa-terminal-title {
  flex: 1;
  text-align: center;
  font-size: 12px;
  font-weight: 600;
  color: rgba(255, 255, 255, 0.5);
  letter-spacing: 0.05em;
  margin-right: 36px;
}

.osa-terminal-body {
  padding: 16px 20px;
  margin: 0;
  font-size: 14px;
  line-height: 1.7;
  color: #e8e0e4;
  overflow-x: auto;
}

.osa-terminal-comment {
  color: #7a6073;
}

.osa-terminal-prompt {
  color: #82B541;
  font-weight: 700;
}

.osa-terminal-cmd {
  color: #a98fd0;
}

/* =========================================================
   Simple Inline Accordion (old-site style)
   ========================================================= */

.osa-simple-accordion {
  list-style: none;
  padding: 0;
  margin: 8px 0 16px 20px;
}

.osa-simple-accordion li {
  margin-bottom: 4px;
}

.osa-simple-toggle {
  color: var(--blue);
  text-decoration: none;
  font-weight: 600;
  cursor: pointer;
  display: inline-block;
  padding: 4px 0;
}

.osa-simple-toggle::before {
  content: '+ ';
  font-weight: 700;
  font-size: 14px;
}

.osa-simple-toggle.open::before {
  content: '− ';
}

.osa-simple-toggle:hover {
  text-decoration: underline;
}

.osa-simple-body {
  display: none;
  padding: 6px 0 6px 18px;
}

.osa-simple-body.open {
  display: block;
}


.page-id-6377 .inside-article {
  max-width: 1000px;
  margin: 0 auto;
  position: relative;
}

.page-id-6377 .inside-article::after {
  content: '';
  position: absolute;
  top: 20px;
  right: 20px;
  width: 150px;
  height: 150px;
  background: url('/wp-content/uploads/rocket-avatar-2026.png') no-repeat center / contain;
  opacity: 0.85;
  pointer-events: none;
}

.page-id-132303 .inside-article {
  max-width: 1000px;
  margin: 0 auto;
  position: relative;
}

.page-id-132303 .inside-article::after {
  content: '';
  position: absolute;
  top: 20px;
  right: 20px;
  width: 150px;
  height: 150px;
  background: url('/wp-content/uploads/rocket-avatar-2026.png') no-repeat center / contain;
  opacity: 0.85;
  pointer-events: none;
}


/* ── Tool comparison cards ── */
.tool-card {
  display: flex;
  align-items: center;
  gap: 16px;
  padding: 16px 20px;
  border: 1px solid var(--slate);
  border-radius: 8px;
  margin-bottom: 10px;
  transition: all .15s ease;
}
.tool-card:hover { border-color: var(--blue); box-shadow: 0 2px 8px rgba(65,154,210,.08); }
.tool-icon {
  width: 44px;
  height: 44px;
  border-radius: 8px;
  background: var(--blue-light);
  display: flex;
  align-items: center;
  justify-content: center;
  flex-shrink: 0;
}
.tool-icon svg { width: 22px; height: 22px; color: var(--blue); }
.tool-name {
  font-family: 'Plus Jakarta Sans', sans-serif;
  font-size: 15px;
  font-weight: 600;
  color: var(--charcoal);
}
.tool-meta {
  font-size: 13px;
  color: var(--steel);
}
.tool-badge {
  display: inline-block;
  font-family: 'Plus Jakarta Sans', sans-serif;
  font-size: 10px;
  font-weight: 700;
  letter-spacing: .06em;
  text-transform: uppercase;
  padding: 3px 8px;
  border-radius: 3px;
  background: var(--green-light);
  color: var(--green-dark);
  margin-left: 8px;
}

/* =========================================================
   Clear Browser Cache page (ID 109) + reusable doc styles
   ========================================================= */

.page-id-109 .inside-article {
  max-width: 1200px;
  margin: 0 auto;
}

/* Subtitle */
.osa-subtitle {
  font-size: 17px;
  color: var(--steel);
  margin-bottom: 32px;
}

/* Callout boxes */
.osa-callout {
  padding: 20px 24px;
  border-radius: 0 10px 10px 0;
  margin: 24px 0;
  font-size: 15px;
}
.osa-callout-blue { background: #E8F5FC; border-left: 4px solid var(--blue); }
.osa-callout-green { background: var(--green-light); border-left: 4px solid var(--green); }
.osa-callout-orange { background: #fff7f5; border-left: 4px solid var(--orange); }
.osa-callout strong { color: var(--charcoal); }

/* Keyboard shortcut */
kbd {
  display: inline-block;
  font-family: 'SF Mono', 'Fira Code', Consolas, monospace;
  font-size: 12px;
  padding: 2px 8px;
  background: #f4f5f7;
  border: 1px solid #d0d4da;
  border-bottom-width: 2px;
  border-radius: 4px;
  color: var(--charcoal);
  line-height: 1.6;
}

/* Browser quick-jump tabs */
.osa-browser-tabs {
  display: flex;
  gap: 8px;
  margin-bottom: 32px;
  flex-wrap: wrap;
}
.osa-browser-tab {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  padding: 8px 18px;
  border-radius: 6px;
  border: 1px solid var(--slate);
  background: var(--white);
  font-family: 'Plus Jakarta Sans', sans-serif;
  font-size: 13px;
  font-weight: 600;
  color: var(--charcoal-mid);
  text-decoration: none;
  transition: all .15s ease;
}
.osa-browser-tab:hover { border-color: var(--blue); color: var(--blue); background: var(--blue-light); }

/* Numbered step list */
.osa-steps {
  margin-bottom: 20px;
  padding-left: 0;
  counter-reset: step;
  list-style: none;
}
.osa-steps li {
  counter-increment: step;
  padding: 10px 0 10px 44px;
  position: relative;
  border-bottom: 1px solid #eef1f4;
}
.osa-steps li:last-child { border-bottom: none; }
.osa-steps li::before {
  content: counter(step);
  position: absolute;
  left: 0;
  top: 10px;
  width: 28px;
  height: 28px;
  border-radius: 50%;
  background: var(--blue-light);
  color: var(--blue);
  font-family: 'Plus Jakarta Sans', sans-serif;
  font-size: 13px;
  font-weight: 700;
  display: flex;
  align-items: center;
  justify-content: center;
  line-height: 1;
}

/* ── Doc layout with sidebar TOC ── */
.osa-doc-layout {
  display: grid;
  grid-template-columns: 160px 1fr;
  gap: 40px;
  align-items: start;
}

.osa-doc-sidebar {
  position: sticky;
  top: 32px;
  padding-top: 8px;
}

.osa-doc-sidebar-title {
  font-family: 'Plus Jakarta Sans', sans-serif;
  font-size: 11px;
  font-weight: 700;
  letter-spacing: .1em;
  text-transform: uppercase;
  color: var(--steel);
  margin-bottom: 12px;
}

.osa-doc-sidebar-nav {
  list-style: none;
  padding: 0;
  margin: 0;
}

.osa-doc-sidebar-nav li {
  margin-bottom: 2px;
}

.osa-doc-sidebar-nav a {
  font-family: 'Plus Jakarta Sans', sans-serif;
  font-size: 13px;
  font-weight: 500;
  color: var(--charcoal-mid);
  text-decoration: none;
  display: block;
  padding: 5px 10px;
  border-radius: 4px;
  border-left: 3px solid transparent;
  transition: all .15s ease;
}

.osa-doc-sidebar-nav a:hover {
  color: var(--blue);
  background: var(--blue-light);
}

.osa-doc-sidebar-nav a.active {
  color: var(--blue);
  border-left-color: var(--blue);
  background: var(--blue-light);
  font-weight: 600;
}

.osa-doc-main h2[id] {
  scroll-margin-top: 24px;
}

@media (max-width: 768px) {
  .osa-doc-layout {
    grid-template-columns: 1fr;
    gap: 0;
  }
  .osa-doc-sidebar {
    display: none;
  }
}

h2#chrome + .osa-steps code {
  zoom: 1.5;
  background: #eaeaea;
  width: 24px;
  height: 24px;
  padding: 0 7px;
}

/* =========================================================
   Logo Tips page + Tip Cards
   ========================================================= */

.page-id-125512 .inside-article {
  max-width: 1000px;
  margin: 0 auto;
}

.tip-card {
  background: var(--white);
  border: 1px solid var(--slate);
  border-radius: 10px;
  overflow: hidden;
  margin-bottom: 32px;
}

.tip-card-header {
  display: flex;
  align-items: center;
  gap: 12px;
  padding: 16px 24px;
  background: var(--blue-light);
  border-bottom: 1px solid #e2eaf0;
}

.tip-number {
  width: 32px;
  height: 32px;
  border-radius: 50%;
  background: var(--blue);
  color: white;
  font-family: 'Plus Jakarta Sans', sans-serif;
  font-size: 14px;
  font-weight: 700;
  display: flex;
  align-items: center;
  justify-content: center;
  flex-shrink: 0;
}

.tip-title {
  font-family: 'Plus Jakarta Sans', sans-serif;
  font-size: 17px;
  font-weight: 700;
  color: var(--charcoal);
}

.tip-card-body {
  padding: 24px;
}

.tip-card-body p {
  margin-bottom: 20px;
}

.tip-card-body p:last-child { margin-bottom: 0; }

.visual-compare {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 20px;
  margin: 20px 0;
}

.visual-box {
  border-radius: 8px;
  overflow: hidden;
  border: 1px solid var(--slate);
  text-align: center;
}

.visual-box.bad { border-color: #f0c4be; }
.visual-box.good { border-color: #b8d99a; }

.visual-box-img {
  padding: 24px;
  background: #e8f5fc;
  min-height: 80px;
  display: flex;
  align-items: center;
  justify-content: center;
}

.visual-box-label {
  font-family: 'Plus Jakarta Sans', sans-serif;
  font-size: 12px;
  font-weight: 700;
  letter-spacing: .06em;
  text-transform: uppercase;
  padding: 8px 12px;
}

.visual-box.bad .visual-box-label { background: #fff0ed; color: var(--orange); }
.visual-box.good .visual-box-label { background: var(--green-light); color: var(--green-dark); }

@media (max-width: 768px) {
  .visual-compare { grid-template-columns: 1fr; }
}

/* =========================================================
   Troubleshooting page (ID 108)
   ========================================================= */

.page-id-108 .inside-article {
  max-width: 1200px;
  margin: 0 auto;
}

/* Requirements list */
.osa-req-list {
  list-style: none;
  padding: 0;
  margin: 16px 0;
}
.osa-req-list li {
  padding: 8px 0 8px 28px;
  position: relative;
  border-bottom: 1px solid #eef1f4;
}
.osa-req-list li:last-child { border-bottom: none; }
.osa-req-list li::before {
  content: '';
  position: absolute;
  left: 4px;
  top: 15px;
  width: 8px;
  height: 8px;
  border-radius: 50%;
  background: var(--green);
}

/* Resource links grid */
.osa-resource-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 10px;
  margin: 16px 0;
}

.osa-resource-link {
  display: flex;
  align-items: center;
  gap: 12px;
  padding: 14px 18px;
  border: 1px solid var(--slate);
  border-radius: 8px;
  text-decoration: none;
  transition: all .15s ease;
}
.osa-resource-link:hover {
  border-color: var(--blue);
  box-shadow: 0 2px 8px rgba(65,154,210,.08);
  text-decoration: none;
}

.osa-resource-icon {
  width: 36px;
  height: 36px;
  border-radius: 8px;
  background: var(--blue-light);
  display: flex;
  align-items: center;
  justify-content: center;
  flex-shrink: 0;
}
.osa-resource-icon svg { width: 18px; height: 18px; color: var(--blue); }

.osa-resource-label {
  font-family: 'Plus Jakarta Sans', sans-serif;
  font-size: 14px;
  font-weight: 600;
  color: var(--charcoal);
}

@media (max-width: 768px) {
  .osa-resource-grid { grid-template-columns: 1fr; }
}

/* =========================================================
   Feature Request Board
   ========================================================= */

.osa-feature-board {
  max-width: 100%;
}

.osa-fb-submit-bar {
  margin-bottom: 20px;
  text-align: right;
}

.osa-fb-submit-btn {
  display: inline-block;
  background: var(--blue);
  color: var(--white);
  padding: 10px 20px;
  border-radius: var(--radius-sm);
  font-weight: 600;
  font-size: 14px;
  text-decoration: none;
  transition: background .15s ease;
}
.osa-fb-submit-btn:hover { background: var(--blue-dark); color: var(--white); }

/* Filters */
.osa-fb-filters {
  display: flex;
  gap: 6px;
  margin-bottom: 24px;
  flex-wrap: wrap;
}

.osa-fb-filter {
  background: none;
  border: 1px solid var(--slate);
  border-radius: 20px;
  padding: 6px 16px;
  font-family: 'Plus Jakarta Sans', sans-serif;
  font-size: 13px;
  font-weight: 600;
  color: var(--charcoal-mid);
  cursor: pointer;
  transition: all .15s ease;
}
.osa-fb-filter:hover { border-color: var(--blue); color: var(--blue); }
.osa-fb-filter.active {
  background: var(--blue);
  border-color: var(--blue);
  color: var(--white);
}

/* List items */
.osa-fb-list {
  display: flex;
  flex-direction: column;
  gap: 10px;
}

.osa-fb-item {
  display: flex;
  gap: 16px;
  padding: 20px;
  border: 1px solid var(--slate);
  border-radius: 8px;
  transition: all .15s ease;
  align-items: flex-start;
}
.osa-fb-item:hover { border-color: var(--blue); box-shadow: 0 2px 8px rgba(65,154,210,.08); }

/* Vote button */
.osa-fb-vote {
  display: flex;
  flex-direction: column;
  align-items: center;
  min-width: 50px;
  padding: 8px 0;
  border: 1px solid var(--slate);
  border-radius: 8px;
  cursor: pointer;
  transition: all .15s ease;
  flex-shrink: 0;
  user-select: none;
}
.osa-fb-vote:hover { border-color: var(--blue); background: var(--blue-light); }
.osa-fb-vote.voted {
  border-color: var(--blue);
  background: var(--blue);
  color: var(--white);
}
.osa-fb-vote.voted .osa-fb-arrow,
.osa-fb-vote.voted .osa-fb-count { color: var(--white); }

.osa-fb-arrow {
  font-size: 14px;
  line-height: 1;
  color: var(--blue);
}

.osa-fb-count {
  font-family: 'Plus Jakarta Sans', sans-serif;
  font-size: 16px;
  font-weight: 700;
  color: var(--charcoal);
  line-height: 1.2;
}

/* Content */
.osa-fb-content { flex: 1; min-width: 0; }

.osa-fb-title {
  font-family: 'Plus Jakarta Sans', sans-serif;
  font-size: 16px;
  font-weight: 700;
  color: var(--charcoal);
  margin-bottom: 4px;
}

.osa-fb-excerpt {
  font-size: 14px;
  color: var(--charcoal-mid);
  margin-bottom: 8px;
  line-height: 1.5;
}

.osa-fb-meta {
  display: flex;
  gap: 12px;
  align-items: center;
  flex-wrap: wrap;
}

.osa-fb-status {
  font-family: 'Plus Jakarta Sans', sans-serif;
  font-size: 11px;
  font-weight: 700;
  letter-spacing: .06em;
  text-transform: uppercase;
  padding: 3px 10px;
  border-radius: 3px;
}
.osa-fb-status--submitted { background: #f0f3f6; color: var(--steel); }
.osa-fb-status--under-review { background: #E8F5FC; color: var(--blue); }
.osa-fb-status--planned { background: #fef8ee; color: #b8860b; }
.osa-fb-status--in-progress { background: #fff0ed; color: var(--orange); }
.osa-fb-status--shipped { background: var(--green-light); color: var(--green-dark); }

.osa-fb-date,
.osa-fb-comments {
  font-size: 12px;
  color: var(--steel);
}

/* Submit form */
.osa-fb-submit-form {
  margin-top: 32px;
  padding: 24px;
  border: 1px solid var(--slate);
  border-radius: 8px;
  background: var(--blue-light);
}

.osa-fb-submit-form h3 {
  font-family: 'Plus Jakarta Sans', sans-serif;
  font-size: 18px;
  margin-bottom: 16px;
  color: var(--charcoal);
}

.osa-fb-submit-form input[type="text"],
.osa-fb-submit-form textarea {
  width: 100%;
  margin-bottom: 12px;
  padding: 10px 14px;
  border: 1px solid var(--slate);
  border-radius: var(--radius-sm);
  font-size: 15px;
}

/* Login prompt */
.osa-fb-login-prompt {
  margin-top: 24px;
  padding: 20px;
  text-align: center;
  background: var(--blue-light);
  border-radius: 8px;
  font-size: 15px;
}

@media (max-width: 768px) {
  .osa-fb-item { flex-direction: column; }
  .osa-fb-vote { flex-direction: row; gap: 8px; min-width: auto; padding: 6px 16px; }
}

.page-id-125516 .inside-article {
  max-width: 1000px;
  margin: 0 auto;
}


/* =========================================================
   PRE-FOOTERS
   ========================================================= */

/* Pre-footer: charcoal CTA band above site footer */
.pre-footer, .section.pre-footer, .oa-section.pre-footer {
  background: var(--charcoal);
  padding: 100px 0 20px 0;
  text-align: center;
  color: rgba(255,255,255,.65);
}
.pre-footer .wrap { text-align: center; }
.pre-footer h2, .pre-footer h2.section-heading { font-size: 30px; font-weight: 600; color: #fff; margin-bottom: 12px; }
.pre-footer p { color: rgba(255,255,255,.6); font-size: 16px; max-width: 560px; margin: 0 auto 28px; }
.pre-footer .section-label,
.pre-footer .oa-eyebrow,
.pre-footer .eyebrow { color: var(--green); margin-bottom: 12px; }
.pre-footer .pricing-hint,
.pre-footer .plan-note { margin-top: 20px; font-size: 13px; color: rgba(255,255,255,.4); }

.pre-footer .btn {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  font-family: 'Plus Jakarta Sans', sans-serif;
  font-size: 15px;
  font-weight: 600;
  text-decoration: none;
  cursor: pointer;
  border: none;
  line-height: 1;
  letter-spacing: .08em;
  padding: 13px 28px;
  border-radius: 4px;
}
.pre-footer .btn-orange { background: var(--orange); color: white; box-shadow: 0 3px 0 rgba(160,60,40,.9); }
.pre-footer .btn-orange:hover { background: var(--orange-dark); text-decoration: none; }
.pre-footer .btn-orange { background: var(--orange); color: white; box-shadow: 0 3px 0 rgba(160,60,40,.9); }
.pre-footer .btn-orange:hover { background: var(--orange-dark); }
.pre-footer .btn-white { background: white; color: var(--blue-dark); }
.pre-footer .btn-white:hover { opacity: .9; }
.pre-footer .btn-white-outline { border: 2px solid rgba(255,255,255,.5); color: white; background: transparent; }
.pre-footer .btn-white-outline:hover { border-color: white; text-decoration: none; }
.pre-footer .btn-row,
.pre-footer .btn-group { display: flex; gap: 12px; flex-wrap: wrap; align-items: center; justify-content: center; }

/* ── Pricing page pre-footer: override .osa-pricing scoped specificity ── */
.osa-pricing .pre-footer { background: var(--charcoal); padding: 80px 0; margin-left: calc(-50vw + 50%); margin-right: calc(-50vw + 50%); width: 100vw; max-width: 100vw; }
.osa-pricing .pre-footer .section-label { color: var(--green); text-transform: uppercase; }
.the-pitch h2.section-heading {
  font-size: 34px; line-height: 1.18; font-weight: 600;
  color: white; margin-bottom: 16px;
  max-width: 600px; margin-left: auto; margin-right: auto;
}
.osa-pricing .pre-footer p { color: rgba(255,255,255,.6); }
.osa-pricing .pre-footer .btn-white-outline {
  display: inline-flex; align-items: center; gap: 8px; width: auto;
  border: 2px solid rgba(255,255,255,.5); color: #ffffff; background: transparent;
  letter-spacing: .08em;
}
.osa-pricing .pre-footer .btn-white-outline:hover { border-color: #ffffff; }
.osa-pricing .pre-footer .plan-note { margin-top: 20px; font-size: 13px; color: rgba(255,255,255,.4); }
.osa-pricing .pre-footer h2 .money { text-shadow: 2px 2px 2px #2b3037; }

body:has(.pre-footer) .site-main {
  margin-bottom: 0;
}

/* =========================================================
   .full-width — break colored sections out of container padding
   ========================================================= */

.full-width {
  margin-left: calc(-50vw + 50%);
  margin-right: calc(-50vw + 50%);
  padding-left: 40px;
  padding-right: 40px;
  width: 100vw;
  max-width: 100vw;
  overflow-x: clip;
}

@media (max-width: 768px) {
  .full-width {
    padding-left: 30px;
    padding-right: 30px;
  }
}
















/* ── Installation instruction page comments ── */
.parent-pageid-6311 .comments-area {
  padding-left: 200px;
  max-width: 1200px;
  margin: 0 auto;
}

@media (max-width: 768px) {
  .parent-pageid-6311 .comments-area {
    padding-left: 0;
  }
}

/* Installation instruction page headers */
#installation-header-top {
  font-family: 'Plus Jakarta Sans', sans-serif;
  font-size: 32px;
  font-weight: 700;
  color: var(--charcoal);
  margin-bottom: 4px;
}

#installation-header-bottom {
  font-family: 'Plus Jakarta Sans', sans-serif;
  font-size: 17px;
  color: var(--steel);
  margin-bottom: 32px;
}

.parent-pageid-6311 header.entry-header {
  display: none;
}

/* ── Installation instruction page typography ── */
.parent-pageid-6311 .osa-doc-main h1 {
  font-family: 'Plus Jakarta Sans', sans-serif;
  font-size: 20px !important;
  font-weight: 700;
  color: var(--charcoal);
  margin: 32px 0 12px;
  line-height: 1.4;
}

.parent-pageid-6311 .osa-doc-main h2 {
  font-family: 'Plus Jakarta Sans', sans-serif;
  font-size: 18px !important;
  font-weight: 600;
  color: var(--charcoal);
  margin: 28px 0 12px;
  padding-top: 20px;
  border-top: 1px solid #eef1f4;
  line-height: 1.4;
}

.parent-pageid-6311 .osa-doc-main h2:first-of-type {
  border-top: none;
  padding-top: 0;
  margin-top: 0;
}

.parent-pageid-6311 .osa-doc-main h3 {
  font-family: 'Plus Jakarta Sans', sans-serif;
  font-size: 16px;
  font-weight: 600;
  color: var(--charcoal);
  margin: 20px 0 8px;
}

.parent-pageid-6311 .osa-doc-main p {
  font-size: 15px;
  line-height: 1.7;
  margin-bottom: 14px;
}

.parent-pageid-6311 .osa-doc-main img {
  max-width: 100%;
  height: auto;
  border-radius: 6px;
  margin: 12px 0;
}

.parent-pageid-6311 .osa-doc-main code {
  font-size: 13px;
}

.parent-pageid-6311 .osa-doc-main h2 code {
    font-size: 19px;
    margin: 0 5px;
}

.parent-pageid-6311 .inside-article {
  max-width: 1200px;
  margin: 0 auto;
}


/* =========================================================
   TCO Calculator Page
   ========================================================= */

.page-tco-calculator *,
.page-tco-calculator *::before,
.page-tco-calculator *::after { box-sizing: border-box; margin: 0; padding: 0; }

.page-tco-calculator {
  font-family: 'DM Sans', sans-serif;
  color: var(--charcoal);
  line-height: 1.7;
  font-size: 16px;
}

.page-tco-calculator h1,
.page-tco-calculator h2,
.page-tco-calculator h3 {
  font-family: 'Plus Jakarta Sans', sans-serif;
  color: var(--charcoal);
}

.page-tco-calculator p { margin: 0; }

.page-tco-calculator .wrap {
  max-width: 900px;
  margin: 0 auto;
  padding: 0 32px;
}

/* Hero */
.page-tco-calculator .hero {
  padding: 80px 0 48px;
  text-align: center;
}

.page-tco-calculator .eyebrow {
  font-size: 12px;
  font-weight: 700;
  letter-spacing: .09em;
  text-transform: uppercase;
  color: var(--blue);
  margin-bottom: 16px;
}

.page-tco-calculator .hero h1 {
  font-size: 44px;
  font-weight: 600;
  line-height: 1.12;
  margin-bottom: 20px;
}

.page-tco-calculator .hero .subtitle {
  font-size: 18px;
  color: var(--charcoal-mid);
  max-width: 620px;
  margin: 0 auto;
  line-height: 1.7;
}

/* Calc card */
.page-tco-calculator .calc-section { padding: 0 0 64px; }

.page-tco-calculator .calc-card {
  background: #F4F8FB;
  border: 1px solid var(--border);
  border-radius: 14px;
  padding: 40px 48px;
}

.page-tco-calculator .calc-inputs {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 24px;
  margin-bottom: 36px;
}

.page-tco-calculator .input-group {
  display: flex;
  flex-direction: column;
  gap: 8px;
}

.page-tco-calculator .input-group label {
  font-family: 'Plus Jakarta Sans', sans-serif;
  font-size: 14px;
  font-weight: 600;
  color: var(--charcoal);
}

.page-tco-calculator .input-group .input-hint {
  font-size: 12px;
  color: var(--steel);
  margin-top: -4px;
}

.page-tco-calculator .input-group select,
.page-tco-calculator .input-group input[type="number"] {
  font-family: 'DM Sans', sans-serif;
  font-size: 16px;
  padding: 12px 16px;
  border: 1px solid var(--border);
  border-radius: 6px;
  background: white;
  color: var(--charcoal);
  outline: none;
  transition: border-color .2s;
}

.page-tco-calculator .input-group select:focus,
.page-tco-calculator .input-group input:focus {
  border-color: var(--blue);
  box-shadow: 0 0 0 3px rgba(65, 154, 210, 0.12);
}

.page-tco-calculator .input-group input[type="number"] { -moz-appearance: textfield; }
.page-tco-calculator .input-group input::-webkit-outer-spin-button,
.page-tco-calculator .input-group input::-webkit-inner-spin-button { -webkit-appearance: none; }

/* Slider */
.page-tco-calculator .slider-row {
  display: flex;
  align-items: center;
  gap: 16px;
}

.page-tco-calculator .slider-row input[type="range"] {
  flex: 1;
  -webkit-appearance: none;
  height: 6px;
  border-radius: 3px;
  background: var(--slate);
  outline: none;
  border: none;
  box-shadow: none;
  padding: 0;
}

.page-tco-calculator .slider-row input[type="range"]:focus {
  box-shadow: none;
}

.page-tco-calculator .slider-row input[type="range"]::-webkit-slider-thumb {
  -webkit-appearance: none;
  width: 22px;
  height: 22px;
  border-radius: 50%;
  background: var(--blue);
  cursor: pointer;
  border: 3px solid white;
  box-shadow: 0 1px 4px rgba(0,0,0,.2);
}

.page-tco-calculator .slider-row input[type="range"]::-moz-range-thumb {
  width: 22px;
  height: 22px;
  border-radius: 50%;
  background: var(--blue);
  cursor: pointer;
  border: 3px solid white;
  box-shadow: 0 1px 4px rgba(0,0,0,.2);
}

.page-tco-calculator .agent-count {
  font-family: 'Plus Jakarta Sans', sans-serif;
  font-size: 28px;
  font-weight: 700;
  color: var(--blue-dark);
  min-width: 56px;
  text-align: right;
}

/* Result cards */
.page-tco-calculator .results {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 20px;
  margin-bottom: 28px;
}

.page-tco-calculator .result-card {
  border-radius: 10px;
  padding: 28px;
  text-align: center;
}

.page-tco-calculator .result-card.them {
  background: #fdf8f7;
  border: 1px solid #f0d8d0;
}

.page-tco-calculator .result-card.us {
  background: var(--green-light);
  border: 1px solid rgba(130,181,65,.3);
}

.page-tco-calculator .result-card .result-label {
  font-size: 12px;
  font-weight: 700;
  letter-spacing: .08em;
  text-transform: uppercase;
  margin-bottom: 8px;
}

.page-tco-calculator .result-card.them .result-label { color: var(--orange-dark); }
.page-tco-calculator .result-card.us .result-label { color: var(--green-dark); }

.page-tco-calculator .result-card .result-amount {
  font-family: 'Plus Jakarta Sans', sans-serif;
  font-size: 36px;
  font-weight: 700;
  line-height: 1.1;
  margin-bottom: 6px;
}

.page-tco-calculator .result-card.them .result-amount { color: var(--orange-dark); }
.page-tco-calculator .result-card.us .result-amount { color: var(--green-dark); }

.page-tco-calculator .result-card .result-detail {
  font-size: 13px;
  color: var(--charcoal-mid);
  line-height: 1.5;
}

.page-tco-calculator .result-card .result-breakdown {
  font-size: 12px;
  color: var(--steel);
  margin-top: 8px;
  line-height: 1.6;
}

/* Visual bar comparison */
.page-tco-calculator .bar-compare { margin: 28px 0; }

.page-tco-calculator .bar-row {
  display: flex;
  align-items: center;
  gap: 12px;
  margin-bottom: 12px;
}

.page-tco-calculator .bar-label {
  font-size: 13px;
  font-weight: 600;
  color: var(--charcoal);
  min-
  text-align: right;
}

.page-tco-calculator .bar-track {
  flex: 1;
  height: 32px;
  background: #f0f2f4;
  border-radius: 6px;
  overflow: hidden;
  position: relative;
}

.page-tco-calculator .bar-fill {
  height: 100%;
  border-radius: 6px;
  transition: width .6s ease;
  display: flex;
  align-items: center;
  padding-left: 12px;
  font-size: 12px;
  font-weight: 600;
  color: white;
  min-width: 60px;
}

.page-tco-calculator .bar-fill.them { background: linear-gradient(90deg, var(--orange), var(--orange-dark)); }
.page-tco-calculator .bar-fill.us { background: linear-gradient(90deg, var(--green), var(--green-dark)); }

/* Savings bar */
.page-tco-calculator .savings-bar {
  background: var(--charcoal);
  border-radius: 10px;
  padding: 24px 32px;
  display: flex;
  align-items: center;
  justify-content: space-between;
  flex-wrap: wrap;
  gap: 16px;
  margin-bottom: 8px;
}

.page-tco-calculator .savings-text {
  color: rgba(255,255,255,.6);
  font-size: 15px;
}

.page-tco-calculator .savings-text strong {
  color: var(--green);
  font-family: 'Plus Jakarta Sans', sans-serif;
  font-size: 22px;
  font-weight: 700;
}

.page-tco-calculator .savings-percent {
  font-family: 'Plus Jakarta Sans', sans-serif;
  font-size: 48px;
  font-weight: 700;
  color: var(--green);
  line-height: 1;
}

/* Fine print */
.page-tco-calculator .calc-notes {
  font-size: 12px;
  color: var(--steel);
  line-height: 1.6;
  margin-top: 20px;
  padding-top: 20px;
  border-top: 1px solid var(--border);
}

.page-tco-calculator .calc-notes p { margin-bottom: 4px; }

/* Content sections */
.page-tco-calculator .section { padding: 56px 0; }
.page-tco-calculator .section + .section { border-top: 1px solid #eef1f3; }

.page-tco-calculator .section h2 {
  font-size: 30px;
  font-weight: 600;
  line-height: 1.2;
  margin-bottom: 16px;
}

.page-tco-calculator .section p {
  color: var(--charcoal-mid);
  line-height: 1.75;
  margin-bottom: 16px;
}

/* Included table */
.page-tco-calculator .included-table {
  width: 100%;
  border-collapse: collapse;
  margin: 24px 0;
  font-size: 14px;
}

.page-tco-calculator .included-table thead th {
  background: var(--charcoal);
  color: rgba(255,255,255,.6);
  padding: 12px 16px;
  text-align: left;
  font-weight: 500;
}

.page-tco-calculator .included-table thead th:first-child { border-radius: 6px 0 0 0; }
.page-tco-calculator .included-table thead th:last-child { border-radius: 0 6px 0 0; }
.page-tco-calculator .included-table thead th.ours { background: var(--blue-dark); color: white; }

.page-tco-calculator .included-table tbody td {
  padding: 10px 16px;
  border-bottom: 1px solid #eee;
  color: var(--charcoal-mid);
}

.page-tco-calculator .included-table tbody td:first-child {
  font-weight: 500;
  color: var(--charcoal);
}

.page-tco-calculator .chk { color: var(--green); font-weight: 600; }
.page-tco-calculator .extra { color: var(--orange); font-size: 12px; }

/* Callout */
.page-tco-calculator .callout-blue {
  background: white;
  border: 1px solid rgba(65,154,210,.3);
  border-left: 4px solid var(--blue);
  border-radius: 0 10px 10px 0;
  padding: 24px 28px;
  margin: 28px 0;
}

.page-tco-calculator .callout-blue p {
  color: #2a5a80;
  font-size: 15px;
  margin-bottom: 0;
}

.page-tco-calculator .callout-blue strong { color: var(--blue-dark); }

/* Buttons */
.page-tco-calculator .pricing-hint {
  color: rgba(255,255,255,.35);
  font-size: 13px;
  margin-top: 20px;
}

.page-tco-calculator .three-yr-savings {
  text-align: center;
  font-size: 15px;
  margin-top: 24px;
}

.page-tco-calculator .three-yr-savings strong {
  color: var(--green);
  font-size: 20px;
}

/* Responsive */
@media (max-width: 680px) {
  .page-tco-calculator .hero h1 { font-size: 32px; }
  .page-tco-calculator .calc-inputs { grid-template-columns: 1fr; }
  .page-tco-calculator .results { grid-template-columns: 1fr; }
  .page-tco-calculator .savings-bar { flex-direction: column; text-align: center; }
  .page-tco-calculator .bar-label { min-width: 80px; font-size: 11px; }
  .page-tco-calculator .calc-card { padding: 28px 24px; }
}



/* Dark CTA */
.page-tco-calculator .dark-section {
  margin-left: calc(-50vw + 50%);
  margin-right: calc(-50vw + 50%);
  margin-top: 56px;
  margin-bottom: 0;
  max-width: 100vw;
  width: 100vw;
  background: var(--charcoal);
  padding: 64px 0;
  overflow-x: clip;
}

.page-tco-calculator .dark-section .wrap { text-align: center; }
.page-tco-calculator .dark-section .eyebrow { color: var(--green); margin-bottom: 12px; }

.page-tco-calculator .dark-section h2 {
  font-size: 30px;
  font-weight: 600;
  color: white;
  margin-bottom: 16px;
}

.page-tco-calculator .dark-section p {
  color: rgba(255,255,255,.6);
  font-size: 16px;
  max-width: 560px;
  margin: 0 auto 28px;
}

.page-tco-calculator .dark-section .btn-row,
.page-tco-calculator .dark-section .btn-group {
  display: flex;
  gap: 12px;
  flex-wrap: wrap;
  align-items: center;
  justify-content: center;
}

.page-tco-calculator .dark-section .pricing-hint { margin-top: 20px; font-size: 13px; color: rgba(255,255,255,.4); }
.page-tco-calculator .btn {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  font-family: "Plus Jakarta Sans", sans-serif;
  font-size: 15px;
  font-weight: 600;
  text-decoration: none;
  cursor: pointer;
  border: none;
  line-height: 1;
  letter-spacing: .08em;
  padding: 13px 28px;
  border-radius: 4px;
}

.page-tco-calculator .btn-orange {
  background: var(--orange);
  color: white;
  box-shadow: 0 3px 0 rgba(160,60,40,.9);
}
.page-tco-calculator .btn-orange:hover { background: var(--orange-dark); }

.page-tco-calculator .btn-white { background: white; color: var(--blue-dark); }
.page-tco-calculator .btn-white:hover { opacity: .9; }

.page-tco-calculator .btn-white-outline {
  border: 2px solid rgba(255,255,255,.5);
  color: white;
  background: transparent;
}
.page-tco-calculator .btn-white-outline:hover { border-color: white; }



/* =========================================================
   Why Self-Hosted Page
   ========================================================= */

.page-why-self-hosted *,
.page-why-self-hosted *::before,
.page-why-self-hosted *::after { box-sizing: border-box; margin: 0; padding: 0; }

.page-why-self-hosted {
  font-family: 'DM Sans', sans-serif;
  color: var(--charcoal);
  line-height: 1.7;
  font-size: 16px;
}

.page-why-self-hosted h1,
.page-why-self-hosted h2,
.page-why-self-hosted h3 {
  font-family: 'Plus Jakarta Sans', sans-serif;
  color: var(--charcoal);
}

.page-why-self-hosted p { margin: 0; }

.page-why-self-hosted .wrap {
  max-width: 820px;
  margin: 0 auto;
  padding: 0 32px;
}

.page-why-self-hosted .eyebrow {
  font-family: 'Plus Jakarta Sans', sans-serif;
  font-size: 12px;
  font-weight: 700;
  letter-spacing: .09em;
  text-transform: uppercase;
  color: var(--blue);
  margin-bottom: 12px;
}

/* Hero */
.page-why-self-hosted .hero {
  padding: 80px 0 60px;
  text-align: center;
}

.page-why-self-hosted .hero h1 {
  font-size: 44px;
  font-weight: 600;
  line-height: 1.12;
  margin-bottom: 20px;
}

.page-why-self-hosted .hero .subtitle {
  font-size: 18px;
  color: var(--charcoal-mid);
  max-width: 600px;
  margin: 0 auto;
  line-height: 1.7;
}

.page-why-self-hosted .hero .hero-graphic {
  width: 500px;
  height: auto;
  margin: 44px 0 0 0;
}

/* Sections */
.page-why-self-hosted .section {
  padding: 56px 0;
}

.page-why-self-hosted .section + .section {
  border-top: 1px solid #eef1f3;
}

.page-why-self-hosted .section h2 {
  font-size: 30px;
  font-weight: 600;
  line-height: 1.2;
  margin-bottom: 16px;
}

.page-why-self-hosted .section p {
  color: var(--charcoal-mid);
  line-height: 1.75;
  margin-bottom: 16px;
}

.page-why-self-hosted .section p:last-child { margin-bottom: 0; }

/* Section-alt (blue-light full-width band) */
.page-why-self-hosted .section-alt {
  background: var(--blue-light);
  padding: 56px 0;
  margin-left: calc(-50vw + 50%);
  margin-right: calc(-50vw + 50%);
  max-width: 100vw;
  width: 100vw;
}

.page-why-self-hosted .section-alt h2 {
  font-size: 30px;
  font-weight: 600;
  line-height: 1.2;
  margin-bottom: 16px;
}

.page-why-self-hosted .section-alt p {
  color: var(--charcoal-mid);
  line-height: 1.75;
  margin-bottom: 16px;
}

.page-why-self-hosted .section-alt p:last-child { margin-bottom: 0; }

/* Pull quote */
.page-why-self-hosted .pull-quote {
  border-left: 4px solid var(--blue);
  padding: 20px 28px;
  margin: 28px 0;
  background: white;
  border-radius: 0 8px 8px 0;
}

.page-why-self-hosted .pull-quote p {
  font-size: 17px;
  font-weight: 500;
  color: var(--charcoal);
  line-height: 1.6;
  margin-bottom: 0;
}

/* Compare grid */
.page-why-self-hosted .compare-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 20px;
  margin: 32px 0;
}

.page-why-self-hosted .compare-card {
  border-radius: 10px;
  padding: 28px;
}

.page-why-self-hosted .compare-card.cloud {
  background: #fdf8f7;
  border: 1px solid #f0d8d0;
}

.page-why-self-hosted .compare-card.self {
  background: var(--green-light);
  border: 1px solid rgba(130,181,65,.3);
}

.page-why-self-hosted .compare-card h3 {
  font-size: 17px;
  font-weight: 600;
  margin-bottom: 12px;
}

.page-why-self-hosted .compare-card.cloud h3 { color: var(--orange-dark); }
.page-why-self-hosted .compare-card.self h3 { color: var(--green-dark); }

.page-why-self-hosted .compare-card ul {
  list-style: none;
  padding: 0;
}

.page-why-self-hosted .compare-card ul li {
  font-size: 14px;
  line-height: 1.7;
  padding: 4px 0 4px 20px;
  position: relative;
}

.page-why-self-hosted .compare-card.cloud ul li { color: var(--charcoal-mid); }
.page-why-self-hosted .compare-card.self ul li { color: #4a6a2a; }

.page-why-self-hosted .compare-card ul li::before {
  position: absolute;
  left: 0;
  font-weight: 600;
}

.page-why-self-hosted .compare-card.cloud ul li::before { content: "\2717"; color: var(--orange); }
.page-why-self-hosted .compare-card.self ul li::before { content: "\2713"; color: var(--green); }

/* Split layout with cost stack */
.page-why-self-hosted .split {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 56px;
  align-items: center;
}

.page-why-self-hosted .split-text p { max-width: 100%; }

.page-why-self-hosted .cost-stack {
  display: flex;
  flex-direction: column;
  gap: 12px;
}

.page-why-self-hosted .cost-row {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 14px 20px;
  border-radius: 8px;
  border: 1px solid var(--slate);
  background: white;
}

.page-why-self-hosted .cost-row.ours {
  border-color: var(--blue);
  background: var(--blue-light);
}

.page-why-self-hosted .cost-label {
  font-family: 'Plus Jakarta Sans', sans-serif;
  font-size: 14px;
  font-weight: 600;
  color: var(--charcoal);
}

.page-why-self-hosted .cost-price {
  font-family: 'Plus Jakarta Sans', sans-serif;
  font-size: 14px;
  font-weight: 700;
  color: var(--charcoal-mid);
}

.page-why-self-hosted .cost-row.ours .cost-price { color: var(--blue); }

.page-why-self-hosted .cost-note {
  font-size: 13px;
  color: var(--steel);
  text-align: right;
  margin-top: 4px;
}

.page-why-self-hosted .cost-heading {
  font-family: 'Plus Jakarta Sans', sans-serif;
  font-size: 11px;
  font-weight: 700;
  letter-spacing: .08em;
  text-transform: uppercase;
  color: var(--steel);
  margin-bottom: 4px;
}

/* TCO Blue Band */
.page-why-self-hosted .section-blue-band {
  background: var(--blue);
  padding: 48px 0;
  margin-left: calc(-50vw + 50%);
  margin-right: calc(-50vw + 50%);
  max-width: 100vw;
  width: 100vw;
}

.page-why-self-hosted .section-blue-band h3 {
  font-size: 22px;
  font-weight: 700;
  color: var(--white);
  margin-bottom: 10px;
}

.page-why-self-hosted .new-badge {
  display: inline-block;
  font-family: 'Plus Jakarta Sans', sans-serif;
  font-size: 11px;
  font-weight: 800;
  letter-spacing: .06em;
  color: #034c12;
  background: #00ff33;
  padding: 3px 10px;
  border-radius: 4px;
  transform: rotate(-4deg);
  margin-right: 8px;
  vertical-align: middle;
  position: relative;
  top: 1px;
  box-shadow: 0 2px 6px rgba(0,0,0,.15);
}

.page-why-self-hosted .section-blue-band p {
  color: rgba(255,255,255,.8);
  font-size: 15px;
  max-width: 540px;
  margin: 0 0 24px;
  line-height: 1.6;
}

.page-why-self-hosted .tco-band-layout {
  display: flex;
  align-items: center;
  gap: 40px;
  justify-content: center;
}

.page-why-self-hosted .tco-band-img {
  flex-shrink: 0;
}

.page-why-self-hosted .tco-band-img img {
  width: 160px;
  height: auto;
  margin: 20px 0 0 0;
  border-radius: 8px;
  filter: drop-shadow(0 4px 16px rgba(0,0,0,.3));
}

.page-why-self-hosted .tco-band-text { text-align: left; }

/* Compliance table */
.page-why-self-hosted .compliance-table {
  width: 100%;
  border-collapse: collapse;
  margin: 28px 0;
  font-size: 14px;
}

.page-why-self-hosted .compliance-table thead th {
  background: var(--charcoal);
  color: rgba(255,255,255,.6);
  padding: 12px 16px;
  text-align: left;
  font-weight: 500;
}

.page-why-self-hosted .compliance-table thead th:first-child { border-radius: 6px 0 0 0; }
.page-why-self-hosted .compliance-table thead th:last-child { border-radius: 0 6px 0 0; }
.page-why-self-hosted .compliance-table thead th.self { background: var(--blue-dark); color: white; }
.page-why-self-hosted .compliance-table thead th.cloud { background: var(--charcoal-mid); }

.page-why-self-hosted .compliance-table tbody td {
  padding: 11px 16px;
  border-bottom: 1px solid #eee;
  vertical-align: middle;
  color: var(--charcoal-mid);
}

.page-why-self-hosted .compliance-table tbody td:first-child {
  font-weight: 500;
  color: var(--charcoal);
}

.page-why-self-hosted .chk { color: var(--green); font-weight: 600; }
.page-why-self-hosted .warn { color: var(--orange); font-size: 12px; }

/* Timeline */
.page-why-self-hosted .timeline {
  margin: 32px 0;
  padding-left: 28px;
  border-left: 3px solid var(--blue-light);
}

.page-why-self-hosted .timeline-item {
  padding: 0 0 28px 14px;
  position: relative;
}

.page-why-self-hosted .timeline-item:last-child { padding-bottom: 0; }

.page-why-self-hosted .timeline-item::before {
  content: none;
}

.page-why-self-hosted .timeline-wrap {
  background: #87b537;
  width: 40px;
  height: 40px;
  border-radius: 50%;
  position: absolute;
  left: -49px;
  top: 0;
}

.page-why-self-hosted .timeline-item .timeline-icon {
  position: relative;
  left: 9px;
  top: 9px;
  width: 22px;
  height: 22px;
  color: #ffffff;
}

.page-why-self-hosted .timeline-item h3 {
  font-size: 16px;
  font-weight: 600;
  color: var(--charcoal);
  margin-bottom: 4px;
}

.page-why-self-hosted .timeline-item p {
  font-size: 14px;
  color: var(--charcoal-mid);
  line-height: 1.65;
  margin-bottom: 0;
}

/* Trade-off cards */
.page-why-self-hosted .tradeoff-cards {
  display: flex;
  flex-direction: column;
  gap: 16px;
  margin-top: 28px;
}

.page-why-self-hosted .tradeoff-card {
  padding: 20px 24px;
  border-radius: 8px;
  border: 1px solid var(--slate);
  background: white;
}

.page-why-self-hosted .tradeoff-card h3 {
  font-size: 15px;
  font-weight: 700;
  color: var(--charcoal);
  margin-bottom: 6px;
}

.page-why-self-hosted .tradeoff-card p {
  font-size: 14.5px;
  line-height: 1.6;
  color: var(--charcoal-mid);
  margin-bottom: 0;
}

/* Callouts */
.page-why-self-hosted .callout-green {
  background: var(--green-light);
  border: 1px solid rgba(130,181,65,.35);
  border-left: 4px solid var(--green);
  border-radius: 0 10px 10px 0;
  padding: 24px 28px;
  margin: 32px 0 0;
}

.page-why-self-hosted .callout-green p {
  color: #4a6a2a;
  font-size: 15px;
  margin-bottom: 0;
}

.page-why-self-hosted .callout-green strong { color: var(--green-dark); }

.page-why-self-hosted .callout-blue {
  background: var(--blue-light);
  border: 1px solid rgba(65,154,210,.3);
  border-left: 4px solid var(--blue);
  border-radius: 0 10px 10px 0;
  padding: 24px 28px;
  margin: 28px 0;
}

.page-why-self-hosted .callout-blue p {
  color: #2a5a80;
  font-size: 15px;
  margin-bottom: 0;
}

.page-why-self-hosted .callout-blue strong { color: var(--blue-dark); }

/* Dark CTA */
.page-why-self-hosted .dark-section {
  margin-left: calc(-50vw + 50%);
  margin-right: calc(-50vw + 50%);
  margin-top: 56px;
  margin-bottom: 0;
  max-width: 100vw;
  width: 100vw;
  background: var(--charcoal);
  padding: 64px 0;
  overflow-x: clip;
}

.page-why-self-hosted .dark-section .wrap { text-align: center; }
.page-why-self-hosted .dark-section .eyebrow { color: var(--green); margin-bottom: 12px; }

.page-why-self-hosted .dark-section h2 {
  font-size: 30px;
  font-weight: 600;
  color: white;
  margin-bottom: 16px;
}

.page-why-self-hosted .dark-section p {
  color: rgba(255,255,255,.6);
  font-size: 16px;
  max-width: 560px;
  margin: 0 auto 28px;
}

.page-why-self-hosted .dark-section .btn-row,
.page-why-self-hosted .dark-section .btn-group {
  display: flex;
  gap: 12px;
  flex-wrap: wrap;
  align-items: center;
  justify-content: center;
}

.page-why-self-hosted .dark-section .pricing-hint { margin-top: 20px; font-size: 13px; color: rgba(255,255,255,.4); }
.page-why-self-hosted .btn {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  font-family: "Plus Jakarta Sans", sans-serif;
  font-size: 15px;
  font-weight: 600;
  text-decoration: none;
  cursor: pointer;
  border: none;
  line-height: 1;
  letter-spacing: .08em;
  padding: 13px 28px;
  border-radius: 4px;
}

.page-why-self-hosted .btn-white { background: white; color: var(--blue-dark); }
.page-why-self-hosted .btn-white:hover { opacity: .9; }

.page-why-self-hosted .btn-white-outline {
  border: 2px solid rgba(255,255,255,.5);
  color: white;
  background: transparent;
}
.page-why-self-hosted .btn-white-outline:hover { border-color: white; }





/* Buttons */
.page-why-self-hosted .pricing-hint {
  color: rgba(255,255,255,.35);
  font-size: 13px;
  margin-top: 20px;
}

/* Responsive */
@media (max-width: 680px) {
  .page-why-self-hosted .hero h1 { font-size: 32px; }
  .page-why-self-hosted .compare-grid { grid-template-columns: 1fr; }
  .page-why-self-hosted .split { grid-template-columns: 1fr; gap: 32px; }
  .page-why-self-hosted .section h2 { font-size: 24px; }
  .page-why-self-hosted .tco-band-layout { flex-direction: column; text-align: center; }
  .page-why-self-hosted .tco-band-text { text-align: center; }
}


/* =========================================================
   VAT & Invoicing Page — Invoice Mockup
   ========================================================= */

.vat-invoice-mock {
  background: #fafbfc;
  border: 1px solid var(--border);
  border-radius: 10px;
  padding: 36px 40px;
  margin: 28px 0;
  font-size: 13px;
  color: var(--charcoal-mid);
}

.vat-invoice-mock-header {
  display: flex;
  justify-content: space-between;
  align-items: flex-start;
  margin-bottom: 28px;
  padding-bottom: 20px;
  border-bottom: 2px solid var(--charcoal);
}

.vat-invoice-mock-brand {
  font-family: 'Plus Jakarta Sans', sans-serif;
  font-size: 18px;
  font-weight: 700;
  color: var(--charcoal);
}

.vat-invoice-mock-brand small {
  display: block;
  font-size: 11px;
  font-weight: 400;
  color: var(--steel);
  margin-top: 2px;
}

.vat-invoice-mock-number { text-align: right; }
.vat-invoice-mock-number strong { font-size: 16px; color: var(--charcoal); display: block; }
.vat-invoice-mock-number span { font-size: 12px; color: var(--steel); }

.vat-invoice-mock-parties {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 32px;
  margin-bottom: 28px;
}

.vat-party-label {
  font-size: 10px;
  font-weight: 700;
  letter-spacing: .1em;
  text-transform: uppercase;
  color: var(--steel);
  margin-bottom: 6px;
}

.vat-invoice-mock-party p {
  font-size: 13px;
  line-height: 1.6;
  margin-bottom: 0;
  color: var(--charcoal-mid);
}

.vat-invoice-mock-items {
  width: 100%;
  border-collapse: collapse;
  margin-bottom: 20px;
}

.vat-invoice-mock-items thead th {
  font-size: 10px;
  font-weight: 700;
  letter-spacing: .08em;
  text-transform: uppercase;
  color: var(--steel);
  text-align: left;
  padding: 8px 0;
  border-bottom: 1px solid var(--border);
  background: transparent;
}

.vat-invoice-mock-items thead th:last-child { text-align: right; }

.vat-invoice-mock-items tbody td {
  padding: 10px 0;
  border-bottom: 1px solid #eef1f3;
  font-size: 13px;
}

.vat-invoice-mock-items tbody td:last-child {
  text-align: right;
  font-weight: 600;
  color: var(--charcoal);
}

.vat-invoice-mock-total { text-align: right; padding-top: 12px; }
.vat-total-line { font-size: 13px; color: var(--steel); margin-bottom: 4px; }
.vat-total-amount { font-family: 'Plus Jakarta Sans', sans-serif; font-size: 22px; font-weight: 700; color: var(--charcoal); }

.vat-invoice-mock-footer {
  margin-top: 24px;
  padding-top: 16px;
  border-top: 1px solid var(--border);
  font-size: 11px;
  color: var(--steel);
}

@media (max-width: 680px) {
  .vat-invoice-mock-parties { grid-template-columns: 1fr; }
  .vat-invoice-mock { padding: 24px; }
}


/* =========================================================
   HIPAA Compliance Page
   ========================================================= */

.page-hipaa *,
.page-hipaa *::before,
.page-hipaa *::after { box-sizing: border-box; margin: 0; padding: 0; }

.page-hipaa {
  font-family: 'DM Sans', sans-serif;
  color: var(--charcoal-mid);
  line-height: 1.7;
  font-size: 16px;
}

.page-hipaa h1,
.page-hipaa h2 {
  font-family: 'Plus Jakarta Sans', sans-serif;
  color: var(--charcoal);
}

.page-hipaa p { margin: 0; }

.page-hipaa .wrap {
  max-width: 900px;
  margin: 0 auto;
  padding: 0 32px;
}

.page-hipaa .eyebrow {
  font-family: 'Plus Jakarta Sans', sans-serif;
  font-size: 12px;
  font-weight: 700;
  letter-spacing: .09em;
  text-transform: uppercase;
  color: var(--blue);
  margin-bottom: 12px;
}

/* Hero */
.page-hipaa .hero {
  padding: 80px 0 64px;
  text-align: center;
}

.page-hipaa .hero h1 {
  font-size: 44px;
  font-weight: 700;
  line-height: 1.15;
  margin-bottom: 16px;
}

.page-hipaa .hero .subtitle {
  font-size: 17px;
  color: var(--charcoal-mid);
  max-width: 620px;
  margin: 0 auto;
  line-height: 1.65;
}

.page-hipaa .hero .hero-graphic {
  width: 500px;
  height: auto;
  margin: 44px 0 0 0;
}

/* Sections */
.page-hipaa .section { padding: 64px 0; }

.page-hipaa .section-alt {
  background: var(--blue-light);
  margin-left: calc(-50vw + 50%);
  margin-right: calc(-50vw + 50%);
  max-width: 100vw;
  width: 100vw;
  padding: 64px 0;
}

.page-hipaa .section h2,
.page-hipaa .section-alt h2 {
  font-size: 30px;
  font-weight: 700;
  line-height: 1.25;
  margin-bottom: 16px;
}

.page-hipaa .section p,
.page-hipaa .section-alt p {
  color: var(--charcoal-mid);
  line-height: 1.75;
  margin-bottom: 16px;
  max-width: 780px;
}

/* Callouts */
.page-hipaa .callout {
  padding: 20px 24px;
  border-radius: 0 10px 10px 0;
  margin: 24px 0;
  font-size: 15px;
  max-width: 780px;
}

.page-hipaa .callout p { margin-bottom: 0; }

.page-hipaa .callout-orange { background: #fff7f5; border-left: 4px solid var(--orange); }

.page-hipaa .wrap .callout.callout-orange {
  margin: 60px 0 0 0 !important;
}
.page-hipaa .callout-orange strong { color: var(--orange-dark); font-weight: 500; }
.page-hipaa .callout-blue { background: #ffffff; border-left: 4px solid var(--blue); }
.page-hipaa .callout-blue strong { color: var(--blue-dark); }
.page-hipaa .callout-green { background: var(--green-light); border-left: 4px solid var(--green); }
.page-hipaa .callout-green strong { color: var(--green-dark); }

/* HIPAA Alignment Table */
.page-hipaa .hipaa-table {
  width: 100%;
  border-collapse: collapse;
  margin: 28px 0;
  font-size: 14.5px;
  background: var(--white);
  border-radius: 8px;
  overflow: hidden;
  box-shadow: 0 1px 4px rgba(0,0,0,.06);
}

.page-hipaa .hipaa-table thead th {
  padding: 14px 20px;
  text-align: left;
  font-family: 'Plus Jakarta Sans', sans-serif;
  font-weight: 600;
  font-size: 13px;
}

.page-hipaa .hipaa-table thead th:first-child {
  background: var(--charcoal);
  color: rgba(255,255,255,.7);
  border-radius: 8px 0 0 0;
}

.page-hipaa .hipaa-table thead th:last-child {
  background: var(--blue-dark);
  color: white;
  border-radius: 0 8px 0 0;
}

.page-hipaa .hipaa-table tbody td {
  padding: 12px 20px;
  border-bottom: 1px solid #eef1f4;
  vertical-align: top;
}

.page-hipaa .hipaa-table tbody td:first-child {
  font-weight: 600;
  color: var(--charcoal);
  width: 200px;
}

.page-hipaa .hipaa-table tbody td:last-child { color: var(--charcoal-mid); }
.page-hipaa .hipaa-table tbody tr:last-child td { border-bottom: none; }
.page-hipaa .chk { color: var(--green); font-weight: 700; margin-right: 6px; }

/* Comparison Table */
.page-hipaa .compare-table {
  width: 100%;
  border-collapse: collapse;
  margin: 28px 0;
  font-size: 14px;
  background: var(--white);
  border-radius: 8px;
  overflow: hidden;
  box-shadow: 0 1px 4px rgba(0,0,0,.06);
}

.page-hipaa .compare-table thead th {
  padding: 12px 16px;
  text-align: left;
  font-family: 'Plus Jakarta Sans', sans-serif;
  font-weight: 600;
  font-size: 12px;
  letter-spacing: .04em;
  background: var(--charcoal);
  color: rgba(255,255,255,.6);
}

.page-hipaa .compare-table thead th:first-child { border-radius: 8px 0 0 0; }
.page-hipaa .compare-table thead th:last-child { border-radius: 0 8px 0 0; }
.page-hipaa .compare-table thead th.ours { background: var(--blue-dark); color: white; }

.page-hipaa .compare-table tbody td {
  padding: 11px 16px;
  border-bottom: 1px solid #eef1f4;
  color: var(--charcoal-mid);
}

.page-hipaa .compare-table tbody td:first-child { font-weight: 500; color: var(--charcoal); }
.page-hipaa .compare-table tbody tr:last-child td { border-bottom: none; }
.page-hipaa .warn { color: var(--orange); font-size: 12px; }
.page-hipaa .good { color: var(--green); font-weight: 600; }

/* FAQ Accordion */
.page-hipaa .faq-list { margin-top: 28px; }

.page-hipaa .faq-item {
  border: 1px solid var(--slate);
  border-radius: 8px;
  margin-bottom: 10px;
  overflow: hidden;
  background: var(--white);
}

.page-hipaa .faq-trigger {
  background: none;
  border: none;
  padding: 16px 20px;
  width: 100%;
  text-align: left;
  font-family: 'Plus Jakarta Sans', sans-serif;
  font-size: 15px;
  font-weight: 600;
  color: var(--charcoal);
  cursor: pointer;
  display: flex;
  align-items: center;
  gap: 12px;
  transition: background .15s ease;
  box-shadow: none;
}

.page-hipaa .faq-trigger:hover { background: var(--blue-light); }

.page-hipaa .faq-icon {
  width: 22px;
  height: 22px;
  border-radius: 50%;
  background: var(--blue-light);
  color: var(--blue);
  display: flex;
  align-items: center;
  justify-content: center;
  flex-shrink: 0;
  font-size: 14px;
  transition: transform .2s ease, background .2s ease;
}

.page-hipaa .faq-item.open .faq-icon { transform: rotate(45deg); background: var(--blue); color: white; }
.page-hipaa .faq-item.open .faq-trigger { background: var(--blue-light); }

.page-hipaa .faq-body {
  display: none;
  padding: 0 20px 20px 54px;
  font-size: 15px;
  line-height: 1.7;
  color: var(--charcoal-mid);
}

.page-hipaa .faq-item.open .faq-body { display: block; }

.page-hipaa .dark-section {
  margin-left: calc(-50vw + 50%);
  margin-right: calc(-50vw + 50%);
  margin-top: 0;
  margin-bottom: 0;
  max-width: 100vw;
  width: 100vw;
  background: var(--charcoal);
  padding: 72px 0;
  text-align: center;
  overflow-x: clip;
}

.page-hipaa .dark-section h2 {
  font-size: 30px;
  font-weight: 700;
  color: white;
  margin-bottom: 12px;
}

.page-hipaa .dark-section p {
  color: rgba(255,255,255,.6);
  font-size: 16px;
  margin: 0 auto 28px;
  max-width: 560px;
}

.page-hipaa .dark-section .btn-group { display: flex; gap: 12px; justify-content: center; flex-wrap: wrap; }
.page-hipaa .dark-section .pricing-hint { margin-top: 20px; font-size: 13px; color: rgba(255,255,255,.4); }

.dark-section.full-width {
  padding-top: 130px;
  margin-bottom: -60px;
}
/* Standardized CTA button group — used in both .pre-footer and .dark-section pre-footers */
.pre-footer .btn-group,
.dark-section.full-width .btn-group { display: flex; gap: 17px; flex-wrap: wrap; align-items: center; justify-content: center; }

.pre-footer .btn-group .btn,
.dark-section.full-width .btn-group .btn {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  font-family: "Plus Jakarta Sans", sans-serif;
  font-size: 15px;
  font-weight: 600;
  letter-spacing: .08em;
  text-decoration: none;
  cursor: pointer;
  border: none;
  line-height: 1;
  padding: 14px 28px 13px;
  border-radius: 4px;
  border: 2px solid rgba(255,255,255,.5);
  color: white;
  background: transparent;
}

.pre-footer .btn-group .btn:hover,
.dark-section.full-width .btn-group .btn:hover { border-color: white; text-decoration: none; background: #0000001f; }

.pre-footer .btn-group .btn svg,
.dark-section.full-width .btn-group .btn svg { width: 20px; height: 20px; position: relative; top: -1px; }

.pre-footer .btn-group .btn svg.lucide-arrow-right,
.dark-section.full-width .btn-group .btn svg.lucide-arrow-right { top: 1px; }

@keyframes shimmer-glow {
  0%   { background-position: 200% center; }
  100% { background-position: -200% center; }
}

.dark-section.full-width a[href="/product/pricing/"].btn-white-outline,
.pre-footer a[href="/product/pricing/"].btn-white-outline {
  transition: all 1s ease;
  position: relative;
  overflow: hidden;
}

.dark-section.full-width a[href="/product/pricing/"].btn-white-outline:hover,
.pre-footer a[href="/product/pricing/"].btn-white-outline:hover {
  border-color: transparent;
  color: #fff;
  background: linear-gradient(
    135deg,
    #6d28d9 0%,
    #9333ea 18%,
    #c026d3 34%,
    #a855f7 48%,
    #7c3aed 62%,
    #9333ea 76%,
    #c026d3 90%,
    #6d28d9 100%
  );
  background-size: 300% 100%;
  animation: shimmer-glow 5s linear infinite;
  box-shadow:
    0 0 14px rgba(147, 51, 234, 0.3),
    0 0 28px rgba(124, 58, 237, 0.12);
  text-shadow: 0 1px 0 rgba(0, 0, 0, 0.45), 0 -1px 0 rgba(255, 255, 255, 0.2);
  -webkit-text-stroke: 0;
}

.dark-section.full-width a[href="/product/pricing/"].btn-white-outline:hover svg,
.pre-footer a[href="/product/pricing/"].btn-white-outline:hover svg {
  filter: drop-shadow(0 1px 0 rgba(0, 0, 0, 0.45)) drop-shadow(0 -1px 0 rgba(255, 255, 255, 0.16));
}
.page-hipaa .btn {
  font-family: "Plus Jakarta Sans", sans-serif;
  display: inline-block;
  padding: 13px 28px;
  border-radius: 4px;
  font-size: 15px;
  font-weight: 600;
  letter-spacing: .08em;
  text-decoration: none;
  cursor: pointer;
  border: none;
}

.page-hipaa .btn-orange { background: var(--orange); color: white; box-shadow: 0 3px 0 rgba(160,60,40,.9); }
.page-hipaa .btn-orange:hover { background: var(--orange-dark); text-decoration: none; }
.page-hipaa .btn-white-outline { background: transparent; color: white; border: 2px solid rgba(255,255,255,.5); }
.page-hipaa .btn-white-outline:hover { border-color: white; text-decoration: none; }





/* Cross-links */
.page-hipaa .cross-links {
  display: flex;
  gap: 12px;
  flex-wrap: wrap;
  margin-top: 24px;
}

.page-hipaa .cross-link {
  font-family: 'Plus Jakarta Sans', sans-serif;
  font-size: 13px;
  font-weight: 600;
  color: var(--blue);
  padding: 8px 16px;
  border: 1px solid var(--slate);
  border-radius: 6px;
  text-decoration: none;
  transition: all .15s ease;
}

.page-hipaa .cross-link:hover { border-color: var(--blue); background: var(--blue-light); text-decoration: none; }

/* Dark CTA */
/* Responsive */
@media (max-width: 768px) {
  .page-hipaa .hero h1 { font-size: 32px; }
  .page-hipaa .section h2,
  .page-hipaa .section-alt h2 { font-size: 24px; }
  .page-hipaa .dark-section { padding: 48px 0; }
}

/* Legal pages — constrained width */
.page-id-216 .entry-content,
.page-id-217 .entry-content,
.page-id-218 .entry-content,
.page-id-219 .entry-content,
.page-id-125677 .entry-content {
  max-width: 1000px;
  margin: 0 auto;
}

/* =========================================================
   Forum (wpForo)
   ========================================================= */

#wpforo #wpforo-wrap {
  margin: 0px;
}

.wpft-forum .inside-article {
  padding-top: 0;
}

.wpft-forum .entry-content:not(:first-child) {
    margin-top: var(--osa-s6);
}

div#wpforo-poweredby {
  display: none;
}

.wpft-forum .site-main {
  margin-bottom: 40px !important;
}




/* =========================================================
   MAX MEGA MENU
   ========================================================= */
   
/* Max Mega Menu base */
#mega-menu-wrap-primary #mega-menu-primary {
  background: var(--white);
}


li.mega-menu-item {  /*TEMP FOR POSITIONING*/
    /* border: 1px solid #000 !important;  */
}

#mega-menu-wrap-primary #mega-menu-primary > li.mega-menu-item {
    margin: 0 24px 0 0;
}
#mega-menu-wrap-primary #mega-menu-primary > li.mega-menu-item.mega-cta {
    margin-right: 0;
}

#mega-menu-wrap-primary #mega-menu-primary > li.mega-menu-item > a.mega-menu-link {
  color: var(--charcoal);
  font-weight: 500;
  font-size: 14px;
  line-height: 40px;
  padding: 0;
  transition: color 0.18s ease, background-color 0.18s ease;9409
  
}

#mega-menu-wrap-primary #mega-menu-primary > li.mega-menu-megamenu > ul.mega-sub-menu {
    background-color: #f1f1f1;
}

@media only screen and (min-width: 769px) {
  #mega-menu-wrap-primary #mega-menu-primary > li.mega-menu-item > a.mega-menu-link:hover,
  #mega-menu-wrap-primary #mega-menu-primary > li.mega-menu-item > a.mega-menu-link:focus {
    font-weight: 500 !important;
  }
}

#mega-menu-wrap-primary #mega-menu-primary > li.mega-menu-item > a.mega-menu-link:hover,
#mega-menu-wrap-primary #mega-menu-primary > li.mega-menu-item > a.mega-menu-link:focus {
  color: var(--green-dark);
}

#mega-menu-wrap-primary #mega-menu-primary > li.mega-menu-item.mega-toggle-on > a.mega-menu-link {
  color: var(--green-dark) !important;
  font-weight: 500;
}

#mega-menu-wrap-primary #mega-menu-primary > li.mega-menu-item.mega-current-menu-item > a.mega-menu-link,
#mega-menu-wrap-primary #mega-menu-primary > li.mega-menu-item.mega-current-menu-ancestor > a.mega-menu-link {
  color: var(--green-dark);
}

/* Mega menu positioning */

@media (min-width: 769px) {
#mega-menu-wrap-primary #mega-menu-primary[data-effect="fade_up"] li.mega-menu-item.mega-toggle-on > ul.mega-sub-menu {
    top: 61px !important;
    background: #fff;
    border: 1px solid #cccccc47;
    border-top: initial;
    color: #666;
    font-family: inherit;
    font-size: 14px;
    font-weight: normal;
    margin: 0;
    padding: 0;
    box-shadow: rgba(14, 63, 126, 0.04) 0px 0px 18px 6px, rgba(42, 51, 69, 0.04) 0px 1px 1px -0.5px, rgba(42, 51, 70, 0.04) 0px 3px 3px -1.5px, rgba(42, 51, 70, 0.04) 0px 6px 6px -3px, rgba(14, 63, 126, 0.04) 0px 12px 12px -6px, rgba(14, 63, 126, 0.04) 0px 24px 24px -12px;
}
}
#mega-menu-wrap-primary #mega-menu-primary > li.mega-menu-megamenu > ul.mega-sub-menu li.mega-menu-column-standard li.mega-menu-item > a.mega-menu-link:hover, #mega-menu-wrap-primary #mega-menu-primary > li.mega-menu-megamenu > ul.mega-sub-menu li.mega-menu-column-standard li.mega-menu-item > a.mega-menu-link:focus, #mega-menu-wrap-primary #mega-menu-primary > li.mega-menu-megamenu > ul.mega-sub-menu li.mega-menu-column > ul.mega-sub-menu > li.mega-menu-item li.mega-menu-item > a.mega-menu-link:hover, #mega-menu-wrap-primary #mega-menu-primary > li.mega-menu-megamenu > ul.mega-sub-menu li.mega-menu-column > ul.mega-sub-menu > li.mega-menu-item li.mega-menu-item > a.mega-menu-link:focus {
	color: var(--green-dark);
}

/* resources*/
#mega-menu-wrap-primary #mega-menu-primary > li.mega-menu-megamenu > ul.mega-sub-menu li.mega-menu-column-standard li.mega-menu-item > a.mega-menu-link, 
#mega-menu-wrap-primary #mega-menu-primary > li.mega-menu-megamenu > ul.mega-sub-menu li.mega-menu-column > ul.mega-sub-menu > li.mega-menu-item li.mega-menu-item > a.mega-menu-link {
    color: #666;
    font-family: inherit;
    font-size: 14px;
    font-weight: normal;
    margin: 0px 0px 0px 0px;
    padding: 4px 0;
}
#mega-menu-wrap-primary #mega-menu-primary > li.mega-menu-megamenu > ul.mega-sub-menu li.mega-menu-column-standard > a.mega-menu-link, 
#mega-menu-wrap-primary #mega-menu-primary > li.mega-menu-megamenu > ul.mega-sub-menu li.mega-menu-column > ul.mega-sub-menu > li.mega-menu-item > a.mega-menu-link {
    font-family: "Plus Jakarta Sans", sans-serif;
    color: var(--charcoal);
    line-height: 1.2;
    margin: 5px 0 10px 0;
    font-size: 14px;
}
li#mega-menu-161-0-0,
li#mega-menu-161-0-2 {
    width: 37% !important;
}
li#mega-menu-161-0-1 {
    width: 26% !important;
}
/* demos */
#mega-menu-wrap-primary #mega-menu-primary[data-effect="fade_up"] li#mega-menu-item-84 > ul.mega-sub-menu {
    width: fit-content;
}
#mega-menu-wrap-primary #mega-menu-primary > li.mega-menu-flyout ul.mega-sub-menu li.mega-menu-item a.mega-menu-link {
    background-color: #fff;
}
#mega-menu-wrap-primary #mega-menu-primary > li.mega-menu-flyout ul.mega-sub-menu li.mega-menu-item a.mega-menu-link:hover,
#mega-menu-wrap-primary #mega-menu-primary > li.mega-menu-flyout ul.mega-sub-menu li.mega-menu-item a.mega-menu-link:focus {
    background-color: transparent !important;
    color: var(--green-dark) !important;
    transform: none !important;
}

/* Product & Services flyout submenus — breathing room */
#mega-menu-wrap-primary #mega-menu-primary > li.mega-menu-flyout ul.mega-sub-menu {
    padding: 8px 6px 6px 6px;
    margin-top: 21px;
	background-color: #f1f1f1;
}


#mega-menu-wrap-primary #mega-menu-primary li.mega-menu-item-has-children > a.mega-menu-link > span.mega-indicator:after {
  margin: 2px 0 0 -4px;
}
#mega-menu-wrap-primary #mega-menu-primary > li.mega-menu-flyout ul.mega-sub-menu li.mega-menu-item a.mega-menu-link {
	background-color: #f1f1f1;
}

#mega-menu-item-132059 a {
    padding-top: 3px !important;
}
#mega-menu-wrap-primary #mega-menu-primary li.mega-menu-item-has-children > a.mega-menu-link > span.mega-indicator:after {
	margin: 1px -2px 0 -5px;
}










/* Icon-only nav items (Home, Account, Cart) */
#mega-menu-wrap-primary #mega-menu-primary > li.mega-menu-item.menu-icon-home > a.mega-menu-link,
#mega-menu-wrap-primary #mega-menu-primary > li.mega-menu-item.menu-icon-account > a.mega-menu-link,
#mega-menu-wrap-primary #mega-menu-primary > li.mega-menu-item.menu-icon-cart > a.mega-menu-link {
  font-size: 0 !important;
  display: flex;
  align-items: center;
  overflow: hidden;
}

#mega-menu-wrap-primary #mega-menu-primary li.mega-menu-item a.mega-menu-link:before {
  margin: 0;
}

#mega-menu-wrap-primary #mega-menu-primary > li.mega-menu-item a svg {
    width: 16px;
    height: 16px;
}

/* nav icons need less padding for visual consistency */
li#mega-menu-item-76 a, 
li#mega-menu-item-77 a {
    padding-left: 0 !important;
}

li#mega-menu-item-132019 a svg,
li#mega-menu-item-132020 a svg {
    display: none;
}


/* Get Started CTA button in nav */

#mega-menu-wrap-primary #mega-menu-primary > li.mega-menu-item.mega-cta > a.mega-menu-link {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  height: 38px;
  padding: 0 15px;
  background: var(--orange);
  color: var(--white) !important;
  border-radius: var(--radius-sm);
  font-weight: 500;
  font-size: 14px;
  text-decoration: none;
  box-shadow: 0 2px 0 rgba(160, 60, 40, 0.9);
  transition: all 0.18s ease;
}



/* ═══════════════════════════════════════════════════════
   osAwesome — Resources Mega Menu
   All CSS in one file, matched to live DOM
   ═══════════════════════════════════════════════════════ */

#mega-menu-wrap-primary #mega-menu-primary > li.mega-menu-megamenu > ul.mega-sub-menu {
    width: 96.7vw;
    margin: 20px 1vw 0 1vw !important;
}

@media (min-width: 2800px) {
	#mega-menu-wrap-primary #mega-menu-primary > li.mega-menu-megamenu > ul.mega-sub-menu {
		width: 42vw;
		margin: 0 29vw !important;
	}
}


/* ── Panel container ── */

#mega-sub-menu-161 {
  background: #fff !important;
  box-shadow: 0 8px 30px rgba(0,0,0,.10);
  border-radius: 0 0 10px 10px;
  padding: 0 !important;
}


/* ── Column containers ── */

#mega-sub-menu-132007 > li.mega-menu-column-standard,
#mega-sub-menu-132008 > li.mega-menu-column-standard {
    padding: 22px 14px 27px 34px !important;
}

li#mega-menu-item-custom_html-2 .textwidget.custom-html-widget,
li#mega-menu-item-custom_html-3 .textwidget.custom-html-widget {
    height: 100%;
}
li#mega-menu-item-custom_html-2 .mega-featured,
li#mega-menu-item-custom_html-3 .mega-featured {
    height: 100%;
    display: flex;
    flex-direction: column;
}


/* ── Column dividers ── */

#mega-sub-menu-161 > li.mega-menu-column-standard + li.mega-menu-column-standard {
  border-left: 1px solid #e8eaed;
}


/* ── Column headers (Compare, Use Cases, Docs, Learn) ── */

#mega-menu-item-120 > a.mega-menu-link,
#mega-menu-item-121 > a.mega-menu-link,
#mega-menu-item-122 > a.mega-menu-link,
#mega-menu-item-125683 > a.mega-menu-link {
  font-size: 13px !important;
  font-weight: 700 !important;
  text-transform: uppercase;
  letter-spacing: 1px;
  color: #8a919c !important;
  margin-bottom: 12px !important;
  pointer-events: none;
}


/* ── Menu links ── */

#mega-sub-menu-161 li.mega-has-description > a.mega-menu-link {
  padding: 0 !important;
  margin: 0 0 13px 0 !important;
  line-height: 1.2;
  transition: color .15s;
}

#mega-sub-menu-161 span.mega-menu-title {
  font-size: 13px !important;
  font-weight: 500;
  color: #444C56;
}

#mega-sub-menu-161 a.mega-menu-link:hover span.mega-menu-title {
  color: #6E9A38 !important;
}


/* ── Description text ── */

#mega-sub-menu-161 span.mega-menu-description {
  display: block !important;
  font-size: 11px !important;
  font-weight: 400;
  color: #8a919c !important;
  line-height: 1.3;
  padding-top: 0;
}

#mega-menu-wrap-primary #mega-menu-primary > li.mega-menu-megamenu > ul.mega-sub-menu .mega-description-group .mega-menu-description {
    margin: 0;
    font-style: initial;
}


/* ── "NEW" badge on TCO Calculator ── */

#mega-menu-item-125684 > a.mega-menu-link span.mega-menu-title::after {
  content: "NEW";
  display: inline-block;
  background: #6E9A38;
  color: #fff;
  font-size: 9px;
  font-weight: 700;
  padding: 1px 5px;
  border-radius: 3px;
  margin-left: 5px;
  vertical-align: middle;
  letter-spacing: .4px;
}


/* ── Column header icons ── */

#mega-menu-item-120 > a.mega-menu-link::before,
#mega-menu-item-121 > a.mega-menu-link::before,
#mega-menu-item-122 > a.mega-menu-link::before,
#mega-menu-item-125683 > a.mega-menu-link::before {
  content: '';
  display: inline-block;
  width: 15px;
  height: 15px;
  margin-right: 7px;
  vertical-align: middle;
  background-size: contain;
  background-repeat: no-repeat;
}

/* Scale (Compare) */
#mega-menu-item-120 > a.mega-menu-link::before {
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%235A6270' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='m16 16 3-8 3 8c-.87.65-1.92 1-3 1s-2.13-.35-3-1z'/%3E%3Cpath d='m2 16 3-8 3 8c-.87.65-1.92 1-3 1s-2.13-.35-3-1z'/%3E%3Cpath d='M7 21h10'/%3E%3Cpath d='M12 3v18'/%3E%3Cpath d='M3 7h2c2 0 5-1 7-2 2 1 5 2 7 2h2'/%3E%3C/svg%3E");
}

/* Layers (Use Cases) */
#mega-menu-item-121 > a.mega-menu-link::before {
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%235A6270' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='m12.83 2.18a2 2 0 0 0-1.66 0L2.6 6.08a1 1 0 0 0 0 1.83l8.58 3.91a2 2 0 0 0 1.66 0l8.58-3.9a1 1 0 0 0 0-1.84Z'/%3E%3Cpath d='m22 17.65-9.17 4.16a2 2 0 0 1-1.66 0L2 17.65'/%3E%3Cpath d='m22 12.65-9.17 4.16a2 2 0 0 1-1.66 0L2 12.65'/%3E%3C/svg%3E");
}

/* File-text (Docs) */
#mega-menu-item-122 > a.mega-menu-link::before {
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%235A6270' stroke-width='2'%3E%3Cpath d='M19.5 14.25v-2.625a3.375 3.375 0 00-3.375-3.375h-1.5A1.125 1.125 0 0113.5 7.125v-1.5a3.375 3.375 0 00-3.375-3.375H8.25m0 12.75h7.5m-7.5 3H12M10.5 2.25H5.625c-.621 0-1.125.504-1.125 1.125v17.25c0 .621.504 1.125 1.125 1.125h12.75c.621 0 1.125-.504 1.125-1.125V11.25a9 9 0 00-9-9z'/%3E%3C/svg%3E");
}

/* Book-open (Learn) */
#mega-menu-item-125683 > a.mega-menu-link::before {
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%235A6270' stroke-width='2'%3E%3Cpath d='M12 6.042A8.967 8.967 0 006 3.75c-1.052 0-2.062.18-3 .512v14.25A8.987 8.987 0 016 18c2.305 0 4.408.867 6 2.292m0-14.25a8.966 8.966 0 016-2.292c1.052 0 2.062.18 3 .512v14.25A8.987 8.987 0 0018 18a8.967 8.967 0 00-6 2.292m0-14.25v14.25'/%3E%3C/svg%3E");
}


/* ── Featured sidebar (Column 5) ── */


#mega-menu-item-custom_html-3 {
  padding: 22px 20px !important;
  border-left: 1px solid #e8eaed;
  display: flex !important;
  flex-direction: column;
}
#mega-menu-item-custom_html-3 .textwidget.custom-html-widget {
  display: flex;
  flex-direction: column;
  flex: 1;
}
#mega-menu-item-custom_html-3 .mega-featured-card {
  flex: 1;
  display: flex;
  flex-direction: column;
  justify-content: center;
}
#mega-menu-item-custom_html-2 {
  padding: 22px 20px !important;
  border-left: 1px solid #e8eaed;
}

#mega-menu-item-custom_html-2,
#mega-menu-item-custom_html-3 {
  background: #c7d2dc4d !important;
}

.mega-featured {
  display: flex;
  flex-direction: column;
  gap: 16px;
}

.mega-featured-label {
  font-size: 12px;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 1px;
  color: #6E9A38;
}

/* Demo buttons in featured widget */
.mega-demo-buttons {
  display: flex;
  flex-direction: column;
  gap: 8px;
  margin-bottom: 14px;
}
.mega-demo-btn {
  display: flex;
  align-items: center;
  gap: 10px;
  padding: 12px 16px;
  background: #f7f8f9;
  border: 1px solid #e8eaed;
  border-radius: 8px;
  color: #444C56;
  font-size: 14px;
  font-weight: 500;
  text-decoration: none;
  transition: border-color 0.15s, background 0.15s;
}

.mega-demo-buttons a {
    align-items: center !important;
    font-family: 'Plus Jakarta Sans', sans-serif !important;
    font-size: 14px !important;
    font-weight: 600 !important;
    text-decoration: none !important;
    cursor: pointer !important;
    border: none !important;
    line-height: 1 !important;
    letter-spacing: .08em !important;
    background: #A6AFBC;
    color: #ffffff !important;
    padding: 13px 28px !important;
    border-radius: 4px !important;
    /* box-shadow: 0 3px 0 0 #176190 !important; */
    width: fit-content !important;
    margin: 0;
    min-width: 175px !important;
    transition: all 0.18s ease;
}
.mega-demo-buttons a:first-of-type {
    margin: 0 0 6px 0;
}
.mega-demo-btn:hover {
    border-color: #419AD2;
    background: #419AD2;
    color: #444C56;
    transform: scale(1.03);
}
.mega-demo-btn {
  transition: transform 0.2s ease, border-color 0.2s ease, background 0.2s ease;
}
.mega-demo-btn svg {
  width: 18px;
  height: 18px;
  stroke: #ffffff;
  flex-shrink: 0;
    position: relative;
    top: 1px;
}

.mega-featured-card {
    background: #fff;
    border-radius: 8px;
    padding: 16px;
    border: 1px solid #e8eaed;
    margin: 0 6px 0 -6px;
}

.mega-featured-card h4 {
  font-size: 12px !important;
  font-weight: 600 !important;
  color: #444C56 !important;
  margin: 0 0 6px 0 !important;
  line-height: 1.35;
}

.mega-featured-card p {
  font-size: 13px !important;
  color: #8a919c !important;
  line-height: 1.45;
  margin: 0 !important;
}

.mega-featured-link {
  display: inline-block;
  margin-top: 8px;
  font-size: 11px;
  font-weight: 600;
  color: #6E9A38 !important;
  text-decoration: none;
}

.mega-featured-link:hover {
  text-decoration: underline;
}

a.mega-featured-link {
    font-size: 13px;
}


#mega-menu-item-custom_html-2 {
  padding: 22px 20px !important;
  border-left: 1px solid #e8eaed;
}

#mega-menu-item-custom_html-2,
#mega-menu-item-custom_html-3 {
  background: #c7d2dc4d !important;
}

.mega-featured {
  display: flex;
  flex-direction: column;
  gap: 16px;
}

.mega-featured-label {
  font-size: 12px;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 1px;
  color: #6E9A38;
}

.mega-featured-card {
    background: #fff;
    border-radius: 8px;
    padding: 16px;
    border: 1px solid #e8eaed;
    margin: 0 6px 0 -6px;
}

.mega-featured-card h4 {
  font-size: 12px !important;
  font-weight: 600 !important;
  color: #444C56 !important;
  margin: 0 0 6px 0 !important;
  line-height: 1.35;
}

.mega-featured-card p {
  font-size: 13px !important;
  color: #8a919c !important;
  line-height: 1.45;
  margin: 0 !important;
}

.mega-featured-link {
  display: inline-block;
  margin-top: 8px;
  font-size: 11px;
  font-weight: 600;
  color: #6E9A38 !important;
  text-decoration: none;
}

.mega-featured-link:hover {
  text-decoration: underline;
}

a.mega-featured-link {
    font-size: 13px;
}


/* ── Footer banner (full-width row) ── */

#mega-menu-item-custom_html-3 {
  border-top: 1px solid #e8eaed;
  padding: 0 !important;
}

.mega-menu-footer {
    display: flex;
    align-items: center;
    justify-content: space-between;
    margin: -10px 0 10px 0;
    padding: 0 4px 0 0px;
    font-size: 12px;
    color: #8a919c;
}

.mega-menu-footer a {
  color: #6E9A38 !important;
  font-weight: 600;
  text-decoration: none;
    font-size: 13px;
}

.mega-menu-footer a:hover {
  text-decoration: underline;
}

.mega-menu-footer span a {
    margin: -5px 0 0 -1px;
}



/* Mega Menu Mobile */

/* override Generate Press setting */
@media (max-width: 768px) {
    .has-inline-mobile-toggle .header-widget,.has-inline-mobile-toggle #site-navigation {
        flex-basis: initial;
    }
    .main-navigation ul,.gen-sidebar-nav,.main-navigation:not(.slideout-navigation):not(.toggled) .main-nav > ul,.has-inline-mobile-toggle #site-navigation .inside-navigation > *:not(.navigation-search):not(.main-nav) {
        display: block;
    }
	button.menu-toggle {
		display: none !important;
	}	
}


@media (max-width: 768px) {
  #mega-menu-wrap-primary #mega-menu-primary {
    top: 82px !important;
	}
	button.mega-close {
		display: none !important;
	}
}




/* ═══════════════════════════════════════════════════════
   MOBILE — Variant B (Promoted Categories)
   Breakpoint: 768px  ← change this value if you update
   the Max Mega Menu responsive breakpoint setting

   All selectors prefixed with #mega-menu-wrap-primary
   to match MMM's own specificity pattern (double-ID).
   This ensures our rules beat every MMM base style.
   ═══════════════════════════════════════════════════════ */

@media (max-width: 768px) {


  /* ──────────────────────────────────────────────────
     0. FLEX REORDER
     The DOM order is: Home, Features, FAQs, Forum,
     Resources, Demos, Account, Cart, Get Started.
     We reorder so icon items (Home, Account, Cart)
     sit together as a horizontal row at the top,
     and Get Started drops to the bottom as the CTA.
     ────────────────────────────────────────────────── */

  #mega-menu-wrap-primary #mega-menu-primary {
    display: flex !important;
    flex-direction: row !important;  /* MMM mobile sets column — must override */
    flex-wrap: wrap !important;
    overflow-y: auto !important;     /* allow vertical scrolling when menu is tall */
    /* Note: we leave overflow-x alone (MMM sets hidden).
       Slide_left items are now position:static so they
       don't need overflow-x:visible to avoid clipping. */
    scrollbar-width: none !important;    /* Firefox: hide scrollbar */
    -ms-overflow-style: none !important; /* IE/Edge: hide scrollbar */
  }

  /* Chrome/Safari: hide the vertical scrollbar (saves ~15px right gap) */
  #mega-menu-wrap-primary #mega-menu-primary::-webkit-scrollbar {
    display: none !important;
  }

  /* Icon row: Home (#74), Account (#76), Cart (#77)
     All get order:1 so they group at top. Flex renders
     them in DOM source order: Home → Account → Cart. */
  #mega-menu-wrap-primary #mega-menu-primary > li#mega-menu-item-74,
  #mega-menu-wrap-primary #mega-menu-primary > li#mega-menu-item-76,
  #mega-menu-wrap-primary #mega-menu-primary > li#mega-menu-item-77 {
    order: 1 !important;
    width: 33.333% !important;
    flex: none !important;
    display: block !important;
    clear: none !important;
    float: none !important;
  }

  /* Icon row links: centered icon, equal height,
     grey side rails on outer edges.
     height: auto overrides MMM's height: 40px reset. */
  #mega-menu-wrap-primary #mega-menu-primary > li#mega-menu-item-74 > a.mega-menu-link,
  #mega-menu-wrap-primary #mega-menu-primary > li#mega-menu-item-76 > a.mega-menu-link,
  #mega-menu-wrap-primary #mega-menu-primary > li#mega-menu-item-77 > a.mega-menu-link {
    display: flex !important;
    align-items: center !important;
    justify-content: center !important;
    height: auto !important;
    min-height: 52px !important;
    padding: 0 !important;
    border: 0 !important;
    border-bottom: 1px solid #e8eaed !important;
    line-height: normal !important;
  }

  /* Grey rail on left edge of Home (first icon) */
  #mega-menu-wrap-primary #mega-menu-primary > li#mega-menu-item-74 > a.mega-menu-link {
    border-left: 5px solid #A6AFBC !important;
  }

  /* Divider between icon items */
  #mega-menu-wrap-primary #mega-menu-primary > li#mega-menu-item-76 > a.mega-menu-link {
    border-left: 1px solid #e8eaed !important;
    border-right: 1px solid #e8eaed !important;
  }

  /* Grey rail on right edge of Cart (last icon) */
  #mega-menu-wrap-primary #mega-menu-primary > li#mega-menu-item-77 > a.mega-menu-link {
    border-right: 5px solid #A6AFBC !important;
  }

  /* Icon sizing inside the row */
  #mega-menu-wrap-primary #mega-menu-item-74 svg,
  #mega-menu-wrap-primary #mega-menu-item-76 svg,
  #mega-menu-wrap-primary #mega-menu-item-77 svg {
    width: 20px !important;
    height: 20px !important;
  }

  /* Text nav items: Features, FAQs, Forum — full width */
  #mega-menu-wrap-primary #mega-menu-primary > li#mega-menu-item-73 {
    order: 2 !important; width: 100% !important; clear: none !important;
  }
  #mega-menu-wrap-primary #mega-menu-primary > li#mega-menu-item-72 {
    order: 3 !important; width: 100% !important; clear: none !important;
  }
  #mega-menu-wrap-primary #mega-menu-primary > li#mega-menu-item-75 {
    order: 4 !important; width: 100% !important; clear: none !important;
  }

  /* Resources (contains the category group)
     position: static neutralizes MMM's slide_left effect which
     offsets this item to x=375 as an off-canvas panel.
     display: block overrides MMM's display: list-item. */
  #mega-menu-wrap-primary #mega-menu-primary > li#mega-menu-item-161 {
    order: 5 !important; width: 100% !important; clear: none !important;
    position: static !important; display: block !important;
  }

  /* Demos — same slide_left fix (was at x=750) */
  #mega-menu-wrap-primary #mega-menu-primary > li#mega-menu-item-84 {
    order: 6 !important; width: 100% !important; clear: none !important;
    position: static !important; display: block !important;
  }

  /* Get Started CTA — last — same slide_left fix (was at x=765) */
  #mega-menu-wrap-primary #mega-menu-primary > li#mega-menu-item-70 {
    order: 7 !important; width: 100% !important; clear: none !important;
    position: static !important; display: block !important;
  }


  /* ──────────────────────────────────────────────────
     1. GREY SIDE RAILS
     Standard top-level nav items get grey (#A6AFBC)
     5px side borders for the tab-like appearance.
     height: auto overrides MMM's height: 40px reset.
     ────────────────────────────────────────────────── */

  #mega-menu-wrap-primary #mega-menu-primary > li#mega-menu-item-73 > a.mega-menu-link,
  #mega-menu-wrap-primary #mega-menu-primary > li#mega-menu-item-72 > a.mega-menu-link,
  #mega-menu-wrap-primary #mega-menu-primary > li#mega-menu-item-75 > a.mega-menu-link {
    border: 0 !important;
    border-left: 5px solid #A6AFBC !important;
    border-right: 5px solid #A6AFBC !important;
    border-bottom: 1px solid #e8eaed !important;
    height: auto !important;
    min-height: 48px !important;
    line-height: normal !important;
    display: flex !important;
    align-items: center !important;
    padding: 0 16px !important;
  }


  /* ──────────────────────────────────────────────────
     2. HIDE RESOURCES PARENT
     Hide the "Resources" toggle link. The mega panel
     is forced open so the category columns appear
     inline as top-level accordion items.
     ────────────────────────────────────────────────── */

  #mega-menu-wrap-primary #mega-menu-primary > li#mega-menu-item-161 > a.mega-menu-link {
    display: none !important;
  }

  /* Force the Resources panel visible, strip
     desktop styling (shadow, radius, columns).
     left: auto overrides MMM's inline left offset. */
  #mega-menu-wrap-primary #mega-menu-primary #mega-sub-menu-161 {
    display: block !important;
    visibility: visible !important;
    opacity: 1 !important;
    position: static !important;
    left: auto !important;
    box-shadow: none !important;
    border-radius: 0 !important;
    background: transparent !important;
    padding: 0 !important;
    width: 100% !important;
    max-height: none !important;
    overflow: visible !important;
    transform: none !important;
  }

  /* Kill the desktop column layout — stack vertically */
  #mega-menu-wrap-primary #mega-sub-menu-161 > li.mega-menu-item {
    display: block !important;
    width: 100% !important;
    float: none !important;
    clear: none !important;
    padding: 0 !important;
  }

  /* Remove desktop column dividers */
  #mega-menu-wrap-primary #mega-sub-menu-161 > li.mega-menu-item
    + li.mega-menu-item {
    border-left: none !important;
  }


  /* ──────────────────────────────────────────────────
     3. CATEGORY HEADERS → TOP-LEVEL NAV ITEMS
     Compare (#120), Use Cases (#121), Docs (#122),
     Learn (#125683) get restyled from desktop's
     grey uppercase headers into normal tappable
     nav items with blue (#419AD2) side rails and
     a subtle background tint (#c7d2dc4d).
     ────────────────────────────────────────────────── */

  #mega-menu-wrap-primary #mega-menu-item-120 > a.mega-menu-link,
  #mega-menu-wrap-primary #mega-menu-item-121 > a.mega-menu-link,
  #mega-menu-wrap-primary #mega-menu-item-122 > a.mega-menu-link,
  #mega-menu-wrap-primary #mega-menu-item-125683 > a.mega-menu-link {
    /* Reset desktop header styles */
    font-size: 15px !important;
    font-weight: 500 !important;
    text-transform: none !important;
    letter-spacing: normal !important;
    color: #444C56 !important;
    margin: 0 !important;
    pointer-events: auto !important;

    /* Mobile nav item sizing */
    display: flex !important;
    align-items: center !important;
    height: auto !important;
    min-height: 48px !important;
    padding: 0 20px !important;
    line-height: normal !important;

    /* Blue side rails for category items */
    border: 0 !important;
    border-left: 5px solid #419AD2 !important;
    border-right: 5px solid #419AD2 !important;
    border-bottom: 1px solid #b6bbc1 !important;

    /* Category group background tint */
    background: #c7d2dc4d !important;
  }

  /* Top border on first category (Compare) to
     separate it from Forum above */
  #mega-menu-wrap-primary #mega-menu-item-120 > a.mega-menu-link {
    border-top: 1px solid #b6bbc1 !important;
  }

  /* Hide desktop SVG header icons on mobile */
  #mega-menu-wrap-primary #mega-menu-item-120 > a.mega-menu-link::before,
  #mega-menu-wrap-primary #mega-menu-item-121 > a.mega-menu-link::before,
  #mega-menu-wrap-primary #mega-menu-item-122 > a.mega-menu-link::before,
  #mega-menu-wrap-primary #mega-menu-item-125683 > a.mega-menu-link::before {
    display: none !important;
  }


  /* ──────────────────────────────────────────────────
     4. SUB-LINKS (actual page links)
     White background, green (#87B537) side rails,
     56px touch targets, blue active/tap state.
     ────────────────────────────────────────────────── */

  #mega-menu-wrap-primary #mega-sub-menu-120 > li > a.mega-menu-link,
  #mega-menu-wrap-primary #mega-sub-menu-121 > li > a.mega-menu-link,
  #mega-menu-wrap-primary #mega-sub-menu-122 > li > a.mega-menu-link,
  #mega-menu-wrap-primary #mega-sub-menu-125683 > li > a.mega-menu-link {
    display: flex !important;
    align-items: center !important;
    padding: 0 26px !important;
    margin: 0 !important;
    height: auto !important;
    min-height: 56px !important;
    line-height: 1.3 !important;
    background: #ffffff !important;
    border: 0 !important;
    border-left: 5px solid #87B537 !important;
    border-right: 5px solid #87B537 !important;
    border-bottom: 1px solid rgb(202 207 218 / 62%) !important;
  }

  /* Active/tap state — blue flash */
  #mega-menu-wrap-primary #mega-sub-menu-120 > li > a.mega-menu-link:active,
  #mega-menu-wrap-primary #mega-sub-menu-121 > li > a.mega-menu-link:active,
  #mega-menu-wrap-primary #mega-sub-menu-122 > li > a.mega-menu-link:active,
  #mega-menu-wrap-primary #mega-sub-menu-125683 > li > a.mega-menu-link:active {
    color: #419AD2 !important;
    background: rgb(81 155 212 / 32%) !important;
  }

  /* Link title — larger for mobile readability */
  #mega-menu-wrap-primary #mega-sub-menu-120 span.mega-menu-title,
  #mega-menu-wrap-primary #mega-sub-menu-121 span.mega-menu-title,
  #mega-menu-wrap-primary #mega-sub-menu-122 span.mega-menu-title,
  #mega-menu-wrap-primary #mega-sub-menu-125683 span.mega-menu-title {
    font-size: 14px !important;
    font-weight: 400 !important;
    color: #444C56 !important;
  }

  /* Disable desktop green hover on mobile */
  #mega-menu-wrap-primary #mega-sub-menu-120 a.mega-menu-link:hover span.mega-menu-title,
  #mega-menu-wrap-primary #mega-sub-menu-121 a.mega-menu-link:hover span.mega-menu-title,
  #mega-menu-wrap-primary #mega-sub-menu-122 a.mega-menu-link:hover span.mega-menu-title,
  #mega-menu-wrap-primary #mega-sub-menu-125683 a.mega-menu-link:hover span.mega-menu-title {
    color: #444C56 !important;
  }


  /* ──────────────────────────────────────────────────
     5. HIDE DESCRIPTIONS
     Desktop-only. On mobile they bloat menu height
     without adding value at the touch-target scale.
     ────────────────────────────────────────────────── */

  #mega-menu-wrap-primary #mega-sub-menu-161 span.mega-menu-description {
    display: none !important;
  }


  /* ──────────────────────────────────────────────────
     6. HIDE FEATURED SIDEBAR & FOOTER BANNER
     Featured cards are promotional, not navigational.
     The desktop footer banner is replaced by the
     existing Get Started CTA (#mega-menu-item-70).
     ────────────────────────────────────────────────── */

  #mega-menu-wrap-primary #mega-sub-menu-161 > li#mega-menu-item-custom_html-2,
  #mega-menu-wrap-primary #mega-sub-menu-161 > li#mega-menu-item-custom_html-3 {
    display: none !important;
  }


  /* ──────────────────────────────────────────────────
     7. DEMOS — SIDE-BY-SIDE SPLIT
     Demos (#84) already has Client Demo (#78) and
     Staff Demo (#80) as sub-items with SVG icons.
     Hide the parent "Demos" toggle and show the two
     items as a horizontal 50/50 row.
     ────────────────────────────────────────────────── */

  /* Hide the "Demos" parent toggle */
  #mega-menu-wrap-primary #mega-menu-primary > li#mega-menu-item-84 > a.mega-menu-link {
    display: none !important;
  }

  /* Force Demos sub-menu open as a flex row */
  #mega-menu-wrap-primary #mega-menu-primary #mega-sub-menu-84 {
    display: flex !important;
    visibility: visible !important;
    opacity: 1 !important;
    position: static !important;
    width: 100% !important;
    max-height: none !important;
    overflow: visible !important;
    border-bottom: 1px solid #e8eaed !important;
    transform: none !important;
  }

  /* Each demo item: half width, centered */
  #mega-menu-wrap-primary #mega-sub-menu-84 > li#mega-menu-item-78,
  #mega-menu-wrap-primary #mega-sub-menu-84 > li#mega-menu-item-80 {
    flex: 1 !important;
    width: 50% !important;
    clear: none !important;
  }

  #mega-menu-wrap-primary #mega-sub-menu-84 > li#mega-menu-item-78 > a.mega-menu-link,
  #mega-menu-wrap-primary #mega-sub-menu-84 > li#mega-menu-item-80 > a.mega-menu-link {
    display: flex !important;
    align-items: center !important;
    justify-content: center !important;
    gap: 8px;
    height: auto !important;
    min-height: 48px !important;
    padding: 0 10px !important;
    font-size: 14px !important;
    font-weight: 500 !important;
    color: #444C56 !important;
    border: 0 !important;
    line-height: normal !important;
  }

  /* Grey rail on left edge of Client Demo */
  #mega-menu-wrap-primary #mega-sub-menu-84 > li#mega-menu-item-78 > a.mega-menu-link {
    border-left: 5px solid #A6AFBC !important;
  }

  /* Divider between the two demos */
  #mega-menu-wrap-primary #mega-sub-menu-84 > li#mega-menu-item-80 {
    border-left: 1px solid #e8eaed !important;
  }

  /* Grey rail on right edge of Staff Demo */
  #mega-menu-wrap-primary #mega-sub-menu-84 > li#mega-menu-item-80 > a.mega-menu-link {
    border-right: 5px solid #A6AFBC !important;
  }

  /* Demo icons: size down to match mockup */
  #mega-menu-wrap-primary #mega-menu-item-78 svg,
  #mega-menu-wrap-primary #mega-menu-item-80 svg {
    width: 16px !important;
    height: 16px !important;
  }


  /* ──────────────────────────────────────────────────
     8. GET STARTED CTA
     #mega-menu-item-70 already has class "mega-cta".
     Restyle as a full-width orange button at the
     bottom of the menu.
     ────────────────────────────────────────────────── */

  #mega-menu-wrap-primary #mega-menu-primary > li#mega-menu-item-70 {
    padding: 16px 20px 8px !important;
  }

  #mega-menu-wrap-primary #mega-menu-primary > li#mega-menu-item-70 > a.mega-menu-link {
    display: block !important;
    background: #F55C44 !important;
    color: #fff !important;
    font-size: 15px !important;
    font-weight: 600 !important;
    padding: 14px 24px !important;
    border-radius: 8px !important;
    text-align: center !important;
    text-decoration: none !important;
    height: auto !important;
    min-height: auto !important;
    border: none !important;
    line-height: normal !important;
  }

  #mega-menu-wrap-primary #mega-menu-primary > li#mega-menu-item-70 > a.mega-menu-link:active {
    background: #e04d38 !important;
  }


} /* end @media (max-width: 768px) */

@media (max-width: 768px) {
  #mega-menu-wrap-primary .mega-menu-toggle.mega-menu-open:after {
    display: none !important;
  }
}

/* Fix MMM mobile menu hidden by GP's inline-mobile-toggle system */
@media (max-width: 768px) {
  .has-inline-mobile-toggle #site-navigation .inside-navigation #mega-menu-wrap-primary {
    display: block !important;
  }
  #mega-menu-wrap-primary .mega-menu-toggle {
    display: flex !important;
  }
  /* Hide GP's own toggle since MMM provides one */
  .has-inline-mobile-toggle #site-navigation .inside-navigation > button.menu-toggle {
    display: none !important;
  }
}

/* Mobile mega menu collapse animation */
@media (max-width: 768px) {
  #mega-menu-wrap-primary #mega-menu-primary > li.mega-menu-megamenu > ul.mega-sub-menu > li.mega-menu-item-has-children > ul.mega-sub-menu {
    overflow: hidden;
    max-height: 0;
    opacity: 0;
    padding: 0;
    margin: 0;
    transition: max-height 0.35s ease-in-out, opacity 0.3s ease;
  }
  #mega-menu-wrap-primary #mega-menu-primary > li.mega-menu-megamenu > ul.mega-sub-menu > li.mega-menu-item-has-children.mega-mobile-open > ul.mega-sub-menu {
    max-height: 600px;
    opacity: 1;

    margin: revert;
  }
}

/* CTA button visible in mobile menu */
@media (max-width: 768px) {
  #mega-menu-wrap-primary #mega-menu-primary > li.mega-menu-item.mega-cta {
    margin: 0 15px 10px;
    display: block !important;
  }
  #mega-menu-wrap-primary #mega-menu-primary > li.mega-menu-item.mega-cta > a.mega-menu-link {
    display: flex;
    width: 100%;
    justify-content: center;
  }
}

/* Fix mobile menu panel position and scroll */
@media (max-width: 768px) {
  #mega-menu-wrap-primary .mega-menu-toggle + #mega-menu-primary {
    top: 82px !important;
    height: auto !important;
    max-height: calc(100dvh - 82px) !important;
  }
}

/* Hamburger icon spacing */
@media only screen and (max-width: 768px) {
    .inside-header {
        padding: 24px 17px 24px 24px;
    }
    #mega-menu-wrap-primary .mega-menu-toggle .mega-toggle-blocks-right .mega-toggle-block {
        margin: 0;
    }
}




/* System Requirements page */
.page-id-125694 .inside-article {
  max-width: 1000px;
  margin: 0 auto;
}

/* Split block (logo left, text right) */
.osa-split-block {
  display: flex;
  align-items: center;
  gap: 48px;
  margin-bottom: 40px;
}

.osa-split-left {
  flex-shrink: 0;
}

.osa-split-right {
  flex: 1;
}

.osa-eyebrow {
  display: block;
  font-family: 'Plus Jakarta Sans', sans-serif;
  font-size: 12px;
  font-weight: 700;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: var(--blue);
  margin-bottom: 8px;
}

/* Comparison table (reuse compare page style) */
.osa-comp-table {
  width: 100%;
  border-collapse: collapse;
  margin: 24px 0;
  font-size: 14px;
}

.osa-comp-table thead th {
  background: var(--charcoal);
  color: rgba(255,255,255,.6);
  padding: 13px 16px;
  text-align: center;
  font-weight: 500;
  white-space: nowrap;
}

.osa-comp-table thead th:first-child {
  text-align: left;
  border-radius: 6px 0 0 0;
}

.osa-comp-table thead th:last-child {
  border-radius: 0 6px 0 0;
}

.osa-comp-table thead th.ours {
  background: var(--blue-dark);
  color: #ffffff;
}

.osa-comp-table tbody td {
  padding: 12px 16px;
  border-bottom: 1px solid #eee;
  vertical-align: middle;
  text-align: center;
  color: var(--charcoal-mid);
}

.osa-comp-table tbody td:first-child {
  text-align: left;
  font-weight: 500;
  color: var(--charcoal);
}

.osa-comp-table tbody td.ours {
  background: #F4F8FB;
  font-weight: 500;
  color: var(--green-dark);
}

.osa-comp-table tbody tr:last-child td {
  border-bottom: none;
}

@media (max-width: 768px) {
  .osa-split-block {
    flex-direction: column;
    gap: 24px;
    text-align: center;
  }
}

/* Professional Installation + Hire a Pro pages */
.page-id-125691 .inside-article,
.page-id-125692 .inside-article {
  max-width: 1000px;
  margin: 0 auto;
}

span.access {
  font-weight: 600;
}

/* Hire a Pro form - email field width */
#gform_4 .gfield--type-email input {
  width: 50%;
}
@media (max-width: 640px) {
  #gform_4 .gfield--type-email input {
    width: 100%;
  }
}



/* =========================================================
   WooCommerce — Single Product Page
   ========================================================= */

.single-product .product {
  max-width: 720px;
  margin: 0 auto;
}

.single-product .product .product_title {
  font-family: 'Plus Jakarta Sans', sans-serif;
  font-size: 32px;
  font-weight: 700;
  color: var(--charcoal);
  margin-bottom: 8px;
}

.single-product .product .woocommerce-product-details__short-description {
  font-size: 16px;
  line-height: 1.7;
  color: var(--charcoal-mid);
  margin-bottom: 24px;
}

.single-product .product .price {
  font-size: 22px;
  font-weight: 600;
  color: var(--charcoal);
  margin-bottom: 24px;
}

.single-product .product .price .amount {
  font-weight: 700;
}

.single-product .product .price .subscription-details {
  font-size: 14px;
  font-weight: 400;
  color: var(--steel);
}

/* Variation selector */
.single-product .variations {
  margin-bottom: 20px;
}

.single-product .variations td.label {
  font-weight: 600;
  color: var(--charcoal);
  padding: 8px 12px 8px 0;
  vertical-align: middle;
}

.single-product .variations td.value select {
  min-width: 200px;
  padding: 10px 12px;
  border: 1px solid var(--border);
  border-radius: var(--radius-sm);
}

/* Add to cart button — orange CTA */
.single-product .product .single_add_to_cart_button {
  background: var(--orange) !important;
  color: var(--white) !important;
  box-shadow: 0 3px 0 0 var(--orange-dark) !important;
  font-weight: 600;
  padding: 14px 32px;
  font-size: 15px;
  border-radius: var(--radius-sm);
  transition: transform 0.15s ease, background-color 0.18s ease;
}

.single-product .product .single_add_to_cart_button:hover {
  background: var(--orange-dark) !important;
  transform: translateY(-1px);
}

/* Product image */
.single-product .product .woocommerce-product-gallery__image img {
  border-radius: var(--radius-lg);
  background: var(--blue-light);
}

/* Tabs */
.single-product .woocommerce-tabs {
  margin-top: 40px;
}

.single-product .woocommerce-tabs ul.tabs {
  border-bottom: 2px solid var(--border);
  padding: 0;
  margin: 0 0 24px;
}

.single-product .woocommerce-tabs ul.tabs li {
  border: none;
  background: transparent;
  border-radius: 0;
  margin: 0;
  padding: 0;
}

.single-product .woocommerce-tabs ul.tabs li a {
  font-family: 'Plus Jakarta Sans', sans-serif;
  font-weight: 600;
  font-size: 14px;
  color: var(--steel);
  padding: 10px 20px;
  border-bottom: 2px solid transparent;
  margin-bottom: -2px;
  transition: color 0.18s ease, border-color 0.18s ease;
}

.single-product .woocommerce-tabs ul.tabs li a:hover {
  color: var(--charcoal);
}

.single-product .woocommerce-tabs ul.tabs li.active a {
  color: var(--blue);
  border-bottom-color: var(--blue);
}

/* Related products - hide on single product (we only have 2 products) */
.single-product .related.products {
  display: none;
}


/* =========================================================
   WooCommerce — Block Checkout
   ========================================================= */

/* Hide product images in cart and checkout */
.wc-block-cart-item__image,
.wc-block-components-order-summary-item__image {
  display: none !important;
}

/* Constrain checkout width */
.wc-block-checkout {
  max-width: 1100px;
  margin: 0 auto;
  font-family: 'DM Sans', sans-serif;
}

/* Section headings */
.wc-block-checkout .wc-block-components-checkout-step__title {
  font-family: 'Plus Jakarta Sans', sans-serif;
  font-weight: 700;
  font-size: 18px;
  color: var(--charcoal);
}

.wc-block-checkout .wc-block-components-checkout-step__description {
  color: var(--charcoal-mid);
  font-size: 14px;
}

/* Step numbers */
.wc-block-checkout .wc-block-components-checkout-step__heading::before {
  color: var(--blue);
}

/* Form fields */
.wc-block-checkout .wc-block-components-text-input input,
.wc-block-checkout .wc-block-components-textarea textarea,
.wc-block-checkout .wc-block-components-combobox .components-combobox-control input,
.wc-block-checkout .wc-blocks-components-select__select {
  border: 1px solid var(--border) !important;
  border-radius: var(--radius-sm) !important;
  font-family: 'DM Sans', sans-serif;
}

.wc-block-checkout .wc-block-components-text-input input:focus,
.wc-block-checkout .wc-block-components-textarea textarea:focus,
.wc-block-checkout .wc-blocks-components-select__select:focus {
  border-color: var(--blue) !important;
  box-shadow: 0 0 0 3px rgba(65, 154, 210, 0.12) !important;
}

/* Checkout select dropdowns: override inherited max-width from global select rules */
.wc-block-checkout .wc-blocks-components-select__select {
  max-width: 100% !important;
}
/* Dropdowns: kill leaked margin-bottom from global select rule */
.wc-block-checkout .wc-blocks-components-select__select {
  margin-bottom: 0 !important;
}

/* Labels */
.wc-block-checkout .wc-block-components-text-input label {
  color: var(--charcoal-mid);
  font-size: 14px;
}

/* Order summary sidebar */
.wc-block-checkout .wc-block-components-order-summary {
  background: var(--blue-light);
  border: 1px solid #D5E2ED;
  border-radius: var(--radius-lg);
  padding: 24px;
}

.wc-block-checkout .wc-block-components-order-summary .wc-block-components-order-summary-item__description .wc-block-components-product-name {
  font-family: 'Plus Jakarta Sans', sans-serif;
  font-weight: 600;
  color: var(--charcoal);
}

.wc-block-checkout .wc-block-components-order-summary-item__description .wc-block-components-product-metadata__description {
  color: var(--charcoal-mid);
  font-size: 13px;
}

/* Totals */
.wc-block-checkout .wc-block-components-totals-wrapper {
  border-color: #D5E2ED;
}

.wc-block-checkout .wc-block-components-totals-footer-item .wc-block-components-totals-item__label,
.wc-block-checkout .wc-block-components-totals-footer-item .wc-block-components-totals-item__value {
  font-family: 'Plus Jakarta Sans', sans-serif;
  font-weight: 700;
  font-size: 18px;
  color: var(--charcoal);
}

/* Place order button — orange CTA */
.wc-block-checkout .wc-block-components-checkout-place-order-button {
  background: var(--orange) !important;
  color: var(--white) !important;
  box-shadow: 0 3px 0 0 var(--orange-dark);
  border: none !important;
  border-radius: var(--radius-sm) !important;
  font-family: 'Plus Jakarta Sans', sans-serif;
  font-weight: 700;
  font-size: 16px;
  padding: 10px 20px;
  transition: transform 0.15s ease, background-color 0.18s ease;
}

.wc-block-checkout .wc-block-components-checkout-place-order-button:hover {
  background: var(--orange-dark) !important;
  transform: translateY(-1px);
}

/* Express payment */
.wc-block-checkout .wc-block-components-express-payment {
  border-color: var(--border);
  border-radius: var(--radius-md);
}

.wc-block-checkout .wc-block-components-express-payment__title-container {
  font-family: 'Plus Jakarta Sans', sans-serif;
}

/* Payment method selection */
.wc-block-checkout .wc-block-components-radio-control__option {
  border-color: var(--border);
  border-radius: var(--radius-md);
}

.wc-block-checkout .wc-block-components-radio-control__option--checked {
  border-color: var(--blue);
  background: rgba(65, 154, 210, 0.03);
}

/* Trust signals (added via PHP hook) */
.osa-checkout-trust {
  display: flex;
  gap: 16px;
  margin-top: 16px;
  padding: 16px 0;
}

.osa-checkout-trust .osa-trust-item {
  display: flex;
  align-items: center;
  gap: 8px;
  font-size: 13px;
  font-weight: 500;
  color: var(--charcoal-mid);
}

.osa-checkout-trust .osa-trust-item svg {
  width: 16px;
  height: 16px;
  color: var(--green);
  flex-shrink: 0;
}

/* Coupon form */
.wc-block-checkout .wc-block-components-totals-coupon .wc-block-components-totals-coupon__button {
  background: var(--blue);
  color: var(--white);
  border: none;
  border-radius: var(--radius-sm);
  font-weight: 600;
}

.wc-block-checkout .wc-block-components-totals-coupon .wc-block-components-totals-coupon__button:hover {
  background: var(--blue-dark);
}

/* Validation errors */
.wc-block-checkout .wc-block-components-validation-error {
  color: var(--red);
  font-size: 13px;
}

.wc-block-checkout .has-error .wc-block-components-text-input input {
  border-color: var(--red) !important;
}

/* Return to cart link */
.wc-block-checkout .wc-block-components-checkout-return-to-cart-button {
  color: var(--blue);
  font-weight: 500;
}

.wc-block-checkout .wc-block-components-checkout-return-to-cart-button:hover {
  color: var(--blue-dark);
}


/* =========================================================
   WooCommerce — Thank You / Order Confirmation
   ========================================================= */

dl.wc-block-components-additional-fields-list dd {
  margin: 0;
}

.woocommerce-order-received .woocommerce-order {
  max-width: 720px;
  margin: 0 auto;
}

.woocommerce-order-received .woocommerce-thankyou-order-received {
  font-family: 'Plus Jakarta Sans', sans-serif;
  font-size: 24px;
  font-weight: 600;
  color: var(--charcoal);
  text-align: center;
  margin-bottom: 50px;
}

p.order-again {
  display: none;
}

section.wc-block-order-confirmation-additional-fields-wrapper {
  margin-top: 30px;
}

/* Order overview */
.woocommerce-order-received .woocommerce-order-overview {
  background: var(--blue-light);
  border: 1px solid #D5E2ED;
  border-radius: var(--radius-lg);
  padding: 24px 28px;
  list-style: none;
  display: flex;
  flex-wrap: wrap;
  gap: 20px;
  margin: 24px 0;
}

.woocommerce-order-received .woocommerce-order-overview li {
  flex: 1 1 140px;
  padding: 0;
  border: none;
}

.woocommerce-order-received .woocommerce-order-overview li strong {
  display: block;
  font-family: 'Plus Jakarta Sans', sans-serif;
  font-weight: 700;
  color: var(--charcoal);
  font-size: 16px;
}

/* Order details table */
.woocommerce-order-received .woocommerce-table--order-details {
  border: 1px solid var(--border);
  border-radius: var(--radius-md);
  overflow: hidden;
  border-collapse: separate;
  border-spacing: 0;
  width: 100%;
}

.woocommerce-order-received .woocommerce-table--order-details thead {
  background: var(--charcoal);
}

.woocommerce-order-received .woocommerce-table--order-details thead th {
  color: var(--white);
  font-family: 'Plus Jakarta Sans', sans-serif;
  font-weight: 600;
  font-size: 13px;
  text-transform: uppercase;
  letter-spacing: 0.04em;
  padding: 12px 16px;
  border: none;
}

.woocommerce-order-received .woocommerce-table--order-details td {
  padding: 14px 16px;
  border-bottom: 1px solid var(--border);
  color: var(--charcoal-mid);
  font-size: 14px;
}

.woocommerce-order-received .woocommerce-table--order-details tfoot th,
.woocommerce-order-received .woocommerce-table--order-details tfoot td {
  padding: 12px 16px;
  border-top: 1px solid var(--border);
  font-weight: 600;
  color: var(--charcoal);
}

/* Download link in confirmation */
.woocommerce-order-received .woocommerce-order-downloads a.woocommerce-MyAccount-downloads-file {
  display: inline-block;
  background: var(--blue);
  color: var(--white);
  padding: 10px 20px;
  border-radius: var(--radius-sm);
  font-weight: 600;
  font-size: 14px;
  box-shadow: 0 2px 0 0 var(--blue-dark);
  transition: background 0.18s ease;
}

.woocommerce-order-received .woocommerce-order-downloads a.woocommerce-MyAccount-downloads-file:hover {
  background: var(--blue-dark);
}

/* What's next section (added via PHP hook) */
.osa-whats-next {
  background: var(--blue-light);
  border: 1px solid #D5E2ED;
  border-radius: var(--radius-lg);
  padding: 32px;
  margin-top: 32px;
}

.osa-whats-next h3 {
  font-family: 'Plus Jakarta Sans', sans-serif;
  font-weight: 700;
  font-size: 20px;
  color: var(--charcoal);
  margin: 0 0 16px;
}

.osa-whats-next ul {
  list-style: none;
  padding: 0;
  margin: 0;
  display: grid;
  gap: 12px;
}

.osa-whats-next li {
  display: flex;
  align-items: flex-start;
  gap: 10px;
  font-size: 15px;
  color: var(--charcoal-mid);
  line-height: 1.5;
}

.osa-whats-next li svg {
  width: 18px;
  height: 18px;
  color: var(--green);
  flex-shrink: 0;
  margin-top: 2px;
}

.osa-whats-next li a {
  font-weight: 600;
}


/* =========================================================
   WooCommerce — My Account Navigation
   ========================================================= */

.woocommerce-account .woocommerce-MyAccount-navigation {
  background: var(--white);
  border: 1px solid var(--border);
  border-radius: var(--radius-lg);
  overflow: hidden;
  box-shadow: var(--shadow-sm);
}

.woocommerce-account .woocommerce-MyAccount-navigation ul {
  list-style: none;
  padding: 0;
  margin: 0;
}

.woocommerce-account .woocommerce-MyAccount-navigation ul li {
  border-bottom: 1px solid var(--border);
}

.woocommerce-account .woocommerce-MyAccount-navigation ul li:last-child {
  border-bottom: none;
}

.woocommerce-account .woocommerce-MyAccount-navigation ul li a {
  display: block;
  padding: 14px 20px;
  font-size: 14px;
  font-weight: 500;
  color: var(--charcoal-mid);
  transition: background 0.15s ease, color 0.15s ease;
}

.woocommerce-account .woocommerce-MyAccount-navigation ul li a:hover {
  background: var(--blue-light);
  color: var(--charcoal);
}

.woocommerce-account .woocommerce-MyAccount-navigation ul li.is-active a {
  background: var(--blue-light);
  color: var(--blue);
  font-weight: 600;
  border-left: 3px solid var(--blue);
}


/* =========================================================
   WooCommerce — My Account Content Area
   ========================================================= */

.woocommerce-account .woocommerce-MyAccount-content {
  color: var(--charcoal-mid);
  font-size: 15px;
  line-height: 1.7;
}

/* Dashboard welcome */
.woocommerce-account .woocommerce-MyAccount-content > p:first-child {
  font-size: 16px;
  margin-bottom: 24px;
}

/* Quick links on dashboard (added via PHP hook) */
.osa-dashboard-links {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(200px, 1fr));
  gap: 12px;
  margin: 24px 0;
}

.osa-dashboard-links a {
  display: flex;
  align-items: center;
  gap: 10px;
  padding: 16px 18px;
  background: var(--white);
  border: 1px solid var(--border);
  border-radius: var(--radius-md);
  font-weight: 600;
  font-size: 14px;
  color: var(--charcoal);
  transition: border-color 0.15s ease, box-shadow 0.15s ease, transform 0.15s ease;
}

.osa-dashboard-links a:hover {
  border-color: var(--blue);
  box-shadow: var(--shadow-md);
  transform: translateY(-1px);
  color: var(--blue);
}

.osa-dashboard-links a svg {
  width: 20px;
  height: 20px;
  color: var(--blue);
  flex-shrink: 0;
}


/* =========================================================
   WooCommerce — My Account Tables (Orders, Subscriptions, Downloads)
   ========================================================= */

.woocommerce-account table.woocommerce-orders-table,
.woocommerce-account table.woocommerce-MyAccount-subscriptions,
.woocommerce-account table.woocommerce-table--order-downloads,
.woocommerce-account table.woocommerce-table--order-details,
.woocommerce-account table.shop_table {
  border: 1px solid var(--border);
  border-radius: var(--radius-md);
  overflow: hidden;
  border-collapse: separate;
  border-spacing: 0;
  width: 100%;
  font-size: 14px;
}

.woocommerce-account table.shop_table thead {
  background: var(--charcoal);
}

.woocommerce-account table.shop_table thead th {
  color: var(--white);
  font-family: 'Plus Jakarta Sans', sans-serif;
  font-weight: 600;
  font-size: 12px;
  text-transform: uppercase;
  letter-spacing: 0.05em;
  padding: 12px 16px;
  border: none;
  white-space: nowrap;
}

.woocommerce-account table.shop_table tbody td {
  padding: 14px 16px;
  border-bottom: 1px solid var(--border);
  color: var(--charcoal-mid);
  vertical-align: middle;
}

.woocommerce-account table.shop_table tbody tr:last-child td {
  border-bottom: none;
}

.woocommerce-account table.shop_table tbody tr:hover {
  background: rgba(65, 154, 210, 0.02);
}

/* Action buttons in tables */
.woocommerce-account table.shop_table .woocommerce-button,
.woocommerce-account table.shop_table a.button {
  padding: 6px 14px !important;
  font-size: 12px !important;
  font-weight: 600;
  border-radius: var(--radius-sm);
}

.woocommerce-account table.shop_table a.button.view {
  background: var(--blue) !important;
  color: var(--white) !important;
  box-shadow: 0 2px 0 0 var(--blue-dark) !important;
}

.woocommerce-account table.shop_table a.button.view:hover {
  background: var(--blue-dark) !important;
}

.woocommerce-account table.shop_table a.button.pay {
  background: var(--orange) !important;
  color: var(--white) !important;
  box-shadow: 0 2px 0 0 var(--orange-dark) !important;
}

.woocommerce-account table.shop_table a.button.cancel {
  background: transparent !important;
  color: var(--red) !important;
  box-shadow: none !important;
  border: 1px solid var(--red) !important;
}


/* =========================================================
   WooCommerce — Status Badges
   ========================================================= */

/* Order status */
.woocommerce-account .woocommerce-orders-table__cell-order-status,
.woocommerce-account .subscription-status {
  font-weight: 600;
  font-size: 12px;
  text-transform: uppercase;
  letter-spacing: 0.04em;
}

/* Subscription status badges */
.woocommerce-account .subscription-status {
  display: inline-block;
  padding: 4px 10px;
  border-radius: 20px;
  font-size: 11px;
  font-weight: 700;
  letter-spacing: 0.05em;
  text-transform: uppercase;
}

/* Active */
.woocommerce-account td[data-title="Status"] .subscription-status.active,
.woocommerce-account .subscription-status.woocommerce-status--active {
  background: var(--green-light);
  color: var(--green-dark);
}

/* On hold */
.woocommerce-account td[data-title="Status"] .subscription-status.on-hold,
.woocommerce-account .subscription-status.woocommerce-status--on-hold {
  background: #FFF3E0;
  color: #E65100;
}

/* Cancelled */
.woocommerce-account td[data-title="Status"] .subscription-status.cancelled,
.woocommerce-account .subscription-status.woocommerce-status--cancelled {
  background: var(--red-light);
  color: var(--red);
}

/* Expired */
.woocommerce-account td[data-title="Status"] .subscription-status.expired,
.woocommerce-account .subscription-status.woocommerce-status--expired {
  background: #F5F5F5;
  color: var(--steel);
}

/* Pending */
.woocommerce-account td[data-title="Status"] .subscription-status.pending,
.woocommerce-account .subscription-status.woocommerce-status--pending {
  background: var(--blue-light);
  color: var(--blue);
}

/* Order status badges (text-based, from orders table) */
.woocommerce-orders-table__cell-order-status {
  font-weight: 600;
  font-size: 13px;
}


/* =========================================================
   WooCommerce — Subscriptions Detail Page
   ========================================================= */

.woocommerce-account .woocommerce-subscription-details .shop_table {
  margin-bottom: 32px;
}

.woocommerce-account .subscription_details dt {
  font-weight: 600;
  color: var(--charcoal);
}

.woocommerce-account .subscription_details dd {
  color: var(--charcoal-mid);
  margin-bottom: 12px;
}

.woocommerce-account .subscription-actions {
  display: flex;
  gap: 8px;
  flex-wrap: wrap;
  margin-top: 16px;
}


/* =========================================================
   WooCommerce — Downloads Page
   ========================================================= */

.woocommerce-account .woocommerce-table--order-downloads td.download-product {
  font-weight: 600;
  color: var(--charcoal);
}

.woocommerce-account .woocommerce-table--order-downloads .download-file a {
  display: inline-block;
  background: var(--blue);
  color: var(--white);
  padding: 8px 16px;
  border-radius: var(--radius-sm);
  font-weight: 600;
  font-size: 13px;
  box-shadow: 0 2px 0 0 var(--blue-dark);
  transition: background 0.18s ease;
}

.woocommerce-account .woocommerce-table--order-downloads .download-file a:hover {
  background: var(--blue-dark);
}


/* =========================================================
   WooCommerce — Login / Registration Forms
   ========================================================= */
   
body.page-id-9.wpf-guest {
    background: var(--blue-light);
}

article#post-9 .entry-content:not(:first-child) {
    margin-top: 0;
}

.woocommerce-account:not(.logged-in) .entry-content > .woocommerce {
  max-width: 480px;
  margin: 0 auto;
}

form.woocommerce-ResetPassword.lost_reset_password p.woocommerce-form-row.woocommerce-form-row--first.form-row.form-row-first {
    width: 100%;
}

/* Login form card */
.woocommerce-account .woocommerce form.login,
.woocommerce-account .woocommerce form.register {
  background: var(--white);
  border: 1px solid var(--border);
  border-radius: var(--radius-lg);
  padding: 32px;
  box-shadow: var(--shadow-sm);
}

.woocommerce-account .woocommerce form.login h2,
.woocommerce-account .woocommerce form.register h2 {
  font-family: 'Plus Jakarta Sans', sans-serif;
  font-size: 24px;
  font-weight: 700;
  color: var(--charcoal);
  margin-bottom: 24px;
  text-align: center;
}

/* Logo above login form */
.woocommerce-account:not(.logged-in) .woocommerce::before {
  content: '';
  display: block;
  width: 48px;
  height: 48px;
  margin: 0 auto 20px;
  background: url('/wp-content/uploads/2026/03/logo.svg') no-repeat center / contain;
}

/* Form labels */
.woocommerce-account .woocommerce form.login label,
.woocommerce-account .woocommerce form.register label {
  font-weight: 500;
  font-size: 14px;
  color: var(--charcoal);
  margin-bottom: 4px;
}

/* Form inputs */
.woocommerce-account .woocommerce form.login input.input-text,
.woocommerce-account .woocommerce form.register input.input-text {
  width: 100%;
  padding: 12px 14px;
  border: 1px solid var(--border);
  border-radius: var(--radius-sm);
  font-size: 15px;
}

/* Login/Register button */
.woocommerce-account .woocommerce form.login .woocommerce-form-login__submit, .woocommerce-account .woocommerce form.register .woocommerce-form-register__submit {
    width: 100%;
    /* background: var(--orange) !important; */
    /* color: var(--white) !important; */
    /* box-shadow: 0 3px 0 0 var(--orange-dark) !important; */
    font-size: 15px;
    padding: 14px;
    margin-top: 8px;
    background: #dcdfe2;
    color: #3b4450;
    padding: 13px 28px;
    border-radius: 4px;
    box-shadow: 0 3px 0 0 #b1b2b3;
}

/* Remember me checkbox */
.woocommerce-account .woocommerce form.login .woocommerce-form__label-for-checkbox {
  display: flex;
  align-items: center;
  gap: 6px;
  font-size: 14px;
  color: var(--charcoal-mid);
}

input#rememberme {
    position: relative;
    top: 8px;
}

/* Lost password link */
.woocommerce-account .woocommerce form.login .woocommerce-LostPassword {
  text-align: center;
  margin-top: 16px;
}

.woocommerce-account .woocommerce form.login .woocommerce-LostPassword a {
  font-size: 14px;
  color: var(--blue);
}

/* Password reset form */
.woocommerce-account .woocommerce form.woocommerce-ResetPassword {
  background: var(--white);
  border: 1px solid var(--border);
  border-radius: var(--radius-lg);
  padding: 32px;
  box-shadow: var(--shadow-sm);
}


/* =========================================================
   WooCommerce — Edit Account / Addresses
   ========================================================= */

.woocommerce-account .woocommerce form.woocommerce-EditAccountForm {
  background: var(--white);
  border: 1px solid var(--border);
  border-radius: var(--radius-lg);
  padding: 32px;
  box-shadow: var(--shadow-sm);
}

.woocommerce-account .woocommerce form.woocommerce-EditAccountForm fieldset {
  border: 1px solid var(--border);
  border-radius: var(--radius-md);
  padding: 24px;
  margin-top: 24px;
}

.woocommerce-account .woocommerce form.woocommerce-EditAccountForm fieldset legend {
  font-family: 'Plus Jakarta Sans', sans-serif;
  font-weight: 600;
  font-size: 16px;
  color: var(--charcoal);
  padding: 0 8px;
}

/* Addresses page */
.woocommerce-account .woocommerce-Addresses.col2-set {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 20px;
  overflow: visible;
}

.woocommerce-account .woocommerce-Addresses.col2-set::before,
.woocommerce-account .woocommerce-Addresses.col2-set::after {
  display: none;
}

.woocommerce-account .col2-set .col-1,
.woocommerce-account .col2-set .col-2 {
  float: none;
  width: 100%;
  max-width: 100%;
  margin: 0;
  padding: 0;
}

.woocommerce-account .woocommerce-Addresses .woocommerce-Address {
  background: var(--white);
  border: 1px solid var(--border);
  border-radius: var(--radius-lg);
  padding: 24px;
  box-shadow: var(--shadow-sm);
  width: auto;
  float: none;
}

.woocommerce-account .woocommerce-Addresses .woocommerce-Address header {
  display: flex;
  justify-content: space-between;
  align-items: center;
  margin-bottom: 12px;
  padding-bottom: 12px;
  border-bottom: 1px solid var(--border);
}

.woocommerce-account .woocommerce-Addresses .woocommerce-Address header h2 {
  font-family: 'Plus Jakarta Sans', sans-serif;
  font-weight: 700;
  font-size: 16px;
  color: var(--charcoal);
  margin: 0;
}

.woocommerce-account .woocommerce-Addresses .woocommerce-Address header a {
  font-size: 13px;
  font-weight: 600;
  color: var(--blue);
  white-space: nowrap;
}

.woocommerce-account .woocommerce-Addresses .woocommerce-Address address {
  color: var(--charcoal-mid);
  font-size: 14px;
  line-height: 1.7;
}

/* Edit address form */
.woocommerce-account form.woocommerce-address-fields {
  max-width: 560px;
}

.woocommerce-account form.woocommerce-address-fields .form-row label {
  font-weight: 500;
  font-size: 14px;
  color: var(--charcoal);
}

.woocommerce-account form.woocommerce-address-fields .form-row input.input-text,
.woocommerce-account form.woocommerce-address-fields .form-row select {
  width: 100%;
  padding: 10px 12px;
}

/* Save button */
.woocommerce-account form.woocommerce-address-fields button[type="submit"],
.woocommerce-account form.woocommerce-EditAccountForm button[type="submit"] {
  background: var(--blue) !important;
  color: var(--white) !important;
  box-shadow: 0 2px 0 0 var(--blue-dark) !important;
}

.woocommerce-account form.woocommerce-address-fields button[type="submit"]:hover,
.woocommerce-account form.woocommerce-EditAccountForm button[type="submit"]:hover {
  background: var(--blue-dark) !important;
}


/* =========================================================
   WooCommerce — View Order Detail
   ========================================================= */

.woocommerce-account .woocommerce-order-details {
  margin-bottom: 32px;
}

.woocommerce-account .woocommerce-order-details h2,
.woocommerce-account .woocommerce-customer-details h2,
.woocommerce-account .woocommerce-order-downloads h2 {
  font-family: 'Plus Jakarta Sans', sans-serif;
  font-size: 20px;
  font-weight: 700;
  color: var(--charcoal);
  margin-bottom: 16px;
}


/* =========================================================
   WooCommerce — Responsive
   ========================================================= */

@media (max-width: 768px) {
  /* Checkout */
  .wc-block-checkout .wc-block-components-order-summary {
    padding: 16px;
  }

  .osa-checkout-trust {
    flex-direction: column;
    gap: 8px;
  }

  /* Thank you page */
  .woocommerce-order-received .woocommerce-order-overview {
    flex-direction: column;
    gap: 12px;
  }

  .osa-whats-next {
    padding: 24px;
  }

  /* My Account */
  .woocommerce-account .woocommerce-Addresses {
    grid-template-columns: 1fr;
  }

  .osa-dashboard-links {
    grid-template-columns: 1fr;
  }

  /* Tables — stack on mobile */
  .woocommerce-account table.shop_table thead {
    display: none;
  }

  .woocommerce-account table.shop_table tbody tr {
    display: block;
    border-bottom: 1px solid var(--border);
    padding: 12px 0;
  }

  .woocommerce-account table.shop_table tbody td {
    display: flex;
    justify-content: space-between;
    align-items: center;
    padding: 6px 16px;
    border-bottom: none;
    font-size: 14px;
  }

  .woocommerce-account table.shop_table tbody td::before {
    content: attr(data-title);
    font-weight: 600;
    color: var(--charcoal);
    font-size: 12px;
    text-transform: uppercase;
    letter-spacing: 0.04em;
    margin-right: 12px;
    flex-shrink: 0;
  }

  /* Login form full width on mobile */
  .woocommerce-account:not(.logged-in) .entry-content > .woocommerce {
    max-width: 100%;
    padding: 0 16px;
  }
}

@media (max-width: 480px) {
  .single-product .product .product_title {
    font-size: 26px;
  }

  .woocommerce-order-received .woocommerce-thankyou-order-received {
  font-weight: 600;
  margin-bottom: 50px;
    font-size: 20px;
  }
}

a.wcs-switch-link.button {
    margin: 0 0 0 13px;
}

.order_item p.woo-sl-key, .order_item p.woo-sl-info, .product-name p.woo-sl-key, .product-name p.woo-sl-info {
    display: none;
}

form.woocommerce-EditAccountForm.edit-account fieldset {
    margin: 0 0 2em 0;
}
form.woocommerce-EditAccountForm.edit-account fieldset + div.clear + p {
    margin: 0;
}

.osa-badge {
    display: inline-block;
    padding: 3px 10px;
    border-radius: 3px;
    font-size: 11px;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: .05em;
}
.osa-badge-active {
    background: var(--green-light, #EAF3DE);
    color: var(--green-dark, #6E9A38);
    border-radius: 20px;
}
.osa-badge-expired {
    background: #FDF0E9;
    color: #C0512D;
    border-radius: 20px;
}

/* ── Renewal Card ── */
.osa-renewal-card {
    flex-wrap: wrap;
    background: #F4F8FB;
    border-radius: 8px;
    padding: 24px 28px;
    margin: 20px 0 8px;
    display: flex;
    justify-content: space-between;
    align-items: center;
    gap: 20px;
}
.osa-renewal-card.osa-renewal-expired {
    background: #FDF8F5;
}
.osa-renewal-card.osa-renewal-none {
    background: #F5F5F5;
}
.osa-renewal-tier {
    font-family: 'Plus Jakarta Sans', sans-serif;
    font-weight: 600;
    font-size: 16px;
    color: var(--charcoal, #444C56);
}
.osa-renewal-lapsed {
    font-weight: 400;
    font-size: 14px;
    color: #999;
}
.osa-renewal-date {
    font-size: 14px;
    color: var(--charcoal-mid, #6B7280);
    margin-top: 4px;
}
.osa-renewal-actions {
    display: flex;
    gap: 12px;
    align-items: center;
    flex-shrink: 0;
}
.btn-blue-flat {
    display: inline-block;
    padding: 10px 22px;
    box-shadow: initial;
    background: #419AD2;
    color: #ffffff !important;
    border-radius: 6px;
    font-weight: 600;
    font-size: 14px;
    text-decoration: none !important;
    white-space: nowrap;
    transition: background 0.15s ease;
}
.btn-blue-flat:hover {
    background: #2F7DB8;
    color: #ffffff !important;
}
.btn-grey-flat {
    display: inline-block;
    padding: 10px 22px;
    background: #A6AFBC;
    color: #ffffff !important;
    box-shadow: initial;
    border-radius: 6px;
    font-weight: 600;
    font-size: 14px;
    text-decoration: none !important;
    white-space: nowrap;
    transition: background 0.15s ease;
}
.btn-grey-flat:hover {
    background: #929aA6;
    color: #ffffff !important;
}
.osa-renewal-fine {
    width: 100%;
    font-size: 12px;
    color: #999;
    margin-top: 8px;
    text-align: right;
}
.osa-renewal-fine a {
    color: var(--blue, #419AD2);
}
@media (max-width: 600px) {
    .osa-renewal-card {
    flex-wrap: wrap;
        flex-direction: column;
        align-items: flex-start;
    }
    .osa-renewal-actions {
        width: 100%;
    }
    .btn-blue-flat {
        flex: 1;
        text-align: center;
    }
}

.my_account_licences .woocommerce-button.button.view {
    display: none;
}

.woocommerce-account table.shop_table thead {
    background: #519bd4;
}

.woocommerce-account:not(.logged-in) .woocommerce::before {
    display: none;
}


/* =========================================================
   404 Page
   ========================================================= */

body.error404 {
    background: #454c5657;
}

.error404 #primary {
    background-image: url(http://osaweso.me/wp-content/uploads/robot.png);
    background-repeat: no-repeat;
    background-size: 260px;
    background-position: bottom -4px left 30px;
}

.error404 .entry-content {
    max-width: 449px;
    margin: 7vw auto;
}

.error404 .entry-content input.search-field {
    width: 386px;
}

.error404 .entry-content p {
    white-space: nowrap;
    letter-spacing: .1em;
    width: fit-content;
    margin: 0 auto 4vw auto;
    font-size: 3em;
    color: #72767b;
    font-family: Menlo, Consolas, Monaco, monospace;
    font-weight: 100;
    display: block;
}

.error404 .entry-content button {
    background: #419AD2;
}



/* =========================================================
   Search overlay
   ========================================================= */

/* Nav search icon */
.oa-nav-search-toggle > a {
  display: flex;
  align-items: center;
}
.oa-nav-search-toggle > a svg {
  stroke: var(--charcoal-mid);
  transition: stroke 0.2s;
}
.oa-nav-search-toggle > a:hover svg {
  stroke: var(--blue);
}

/* Overlay */
.oa-search-overlay {
  position: fixed;
  inset: 0;
  z-index: 10000;
  background: rgba(0,0,0,0.6);
  display: flex;
  align-items: flex-start;
  justify-content: center;
  padding-top: 120px;
  opacity: 0;
  visibility: hidden;
  transition: opacity 0.25s, visibility 0.25s;
}
.oa-search-overlay.active {
  opacity: 1;
  visibility: visible;
}
.oa-search-overlay-inner {
  position: relative;
  width: 90%;
  max-width: 640px;
}
.oa-search-overlay form {
  display: flex;
  background: var(--white);
  border-radius: 8px;
  overflow: hidden;
  box-shadow: 0 8px 32px rgba(0,0,0,0.2);
}
.oa-search-overlay input[type="search"] {
  flex: 1;
  border: none;
  padding: 16px 20px;
  font-size: 18px;
  outline: none;
  background: transparent;
  color: var(--charcoal);

}
.oa-search-overlay form button[type="submit"] {
  background: var(--blue);
  border: none;
  padding: 16px 20px;
  cursor: pointer;
  color: white;
  display: flex;
  align-items: center;
  border-radius: 0;    
}
.oa-search-overlay form button[type="submit"]:hover {
  background: var(--blue-dark);
}
.oa-search-close {
    display: none;
}

@media (min-width: 769px) and (max-width: 969px) {
	.inside-header {
		padding: 24px;
	}	
	.site-header .header-image {
		width: 160px;
	}
	#mega-menu-wrap-primary #mega-menu-primary > li.mega-menu-item.mega-cta > a.mega-menu-link {
		height: 32px;
		padding: 0 8px;
	}
	#mega-menu-wrap-primary #mega-menu-primary > li.mega-menu-item {
		margin: 0 14px 0 0;
	}	
}



.page-id-132099 .oa-bc-sep {
    margin: 0 6px;
    color: #727b83;
}


@media (max-width: 979px) {
	.chatty-intro {
		text-align: left !important;
		margin-bottom: 35px;
	}
	.chatty-intro p {
		display: none;
	}
	#chatty-page {
		max-width: 540px;
		margin: 0 auto;
		padding: 40px 20px 24px;
		background: url(https://osaweso.me/wp-content/uploads/chatty-09-white.png);
        background-repeat: no-repeat;
        background-size: 100px;
        background-position: top -16px right -1px;
	}
	.page-id-132099 .oa-breadcrumbs {
		display: none;
	}
}

@media (min-width: 980px) {
	.chatty-intro {
		text-align: left !important;
		margin-bottom: 35px;
	}
	.page-id-132099 .entry-content {
		background: url(https://osaweso.me/wp-content/uploads/chatty-03.png);
		background-repeat: no-repeat;
		background-size: 262px;
		background-position: bottom -196px right;
	}
}

/* =========================================================
   Contact Form – osAwesome Design System Overrides
   Scoped to .osa-contact-form / #gform_1
   ========================================================= */

/* ── Typography: labels ── */
.osa-contact-form #gform_1 .gfield_label,
.osa-contact-form #gform_1 .gform-field-label,
.osa-contact-form .gform_wrapper.gravity-theme .gfield_label {
  font-family: 'Plus Jakarta Sans', sans-serif;
  font-size: 13px;
  font-weight: 600;
  color: #444C56;
  letter-spacing: 0;
}

/* ── Required indicator ── */
.osa-contact-form #gform_1 .gfield_required,
.osa-contact-form .gform_wrapper.gravity-theme .gfield_required {
  color: #F55C44;
}

/* ── Optional indicator ── */
.osa-contact-form #gform_1 .gfield_description.gfield_description--above,
.osa-contact-form #gform_1 .gfield_label .gf_optional {
  color: #A6AFBC;
  font-weight: 400;
  font-size: 12px;
}

/* ── Help / description text ── */
.osa-contact-form #gform_1 .gfield_description,
.osa-contact-form .gform_wrapper.gravity-theme .gfield_description {
  font-size: 12px;
  color: #A6AFBC;
}

/* ── Headings inside the form ── */
.osa-contact-form #gform_1 h2,
.osa-contact-form #gform_1 h3,
.osa-contact-form #gform_1 h4,
.osa-contact-form #gform_1 .gsection_title {
  font-family: 'Plus Jakarta Sans', sans-serif;
  font-weight: 700;
}

/* ── Input fields ── */
.osa-contact-form #gform_1 input[type="text"],
.osa-contact-form #gform_1 input[type="email"],
.osa-contact-form #gform_1 input[type="url"],
.osa-contact-form #gform_1 input[type="tel"],
.osa-contact-form #gform_1 input[type="number"],
.osa-contact-form #gform_1 input[type="password"],
.osa-contact-form #gform_1 select,
.osa-contact-form #gform_1 textarea {
  font-family: "Segoe UI", "Dejavu Sans", Optima, Arial, sans-serif;
  font-size: 15px;
  border: 1px solid #C7D2DC;
  border-radius: 5px;
  padding: 10px 14px;
  color: inherit;
  transition: border-color 0.2s, box-shadow 0.2s;
}

/* ── Input hover ── */
.osa-contact-form #gform_1 input[type="text"]:hover,
.osa-contact-form #gform_1 input[type="email"]:hover,
.osa-contact-form #gform_1 input[type="url"]:hover,
.osa-contact-form #gform_1 input[type="tel"]:hover,
.osa-contact-form #gform_1 input[type="number"]:hover,
.osa-contact-form #gform_1 input[type="password"]:hover,
.osa-contact-form #gform_1 select:hover,
.osa-contact-form #gform_1 textarea:hover {
  border-color: #A6AFBC;
}

/* ── Input focus ── */
.osa-contact-form #gform_1 input[type="text"]:focus,
.osa-contact-form #gform_1 input[type="email"]:focus,
.osa-contact-form #gform_1 input[type="url"]:focus,
.osa-contact-form #gform_1 input[type="tel"]:focus,
.osa-contact-form #gform_1 input[type="number"]:focus,
.osa-contact-form #gform_1 input[type="password"]:focus,
.osa-contact-form #gform_1 select:focus,
.osa-contact-form #gform_1 textarea:focus {
  border-color: #419AD2;
  box-shadow: 0 0 0 3px rgba(65, 154, 210, .15);
  outline: none;
}

/* ── Placeholder ── */
.osa-contact-form #gform_1 input::placeholder,
.osa-contact-form #gform_1 textarea::placeholder {
  color: #A6AFBC;
}

/* ── Radio & checkbox inputs ── */
.osa-contact-form #gform_1 input[type="radio"],
.osa-contact-form #gform_1 input[type="checkbox"] {
  width: 17px;
  height: 17px;
  border: 1.5px solid #C7D2DC;
  accent-color: #419AD2;
}

/* ── Radio & checkbox labels ── */
.osa-contact-form #gform_1 .gfield_radio label,
.osa-contact-form #gform_1 .gfield_checkbox label,
.osa-contact-form .gform_wrapper.gravity-theme .gchoice label {
  font-size: 14px;
  font-weight: 400;
  color: #5A6270;
}

.osa-contact-form #gform_1 .gfield_radio label strong,
.osa-contact-form #gform_1 .gfield_checkbox label strong {
  font-weight: 600;
  color: #444C56;
}

/* ── Grey button (next / previous) ── */
/* ── Previous / Next buttons (btn-grey-flat style) ── */
.osa-contact-form #gform_1 .gform_next_button,
.osa-contact-form #gform_1 .gform_previous_button {
  padding: 10px 22px;
  background: #A6AFBC;
  color: #ffffff !important;
  box-shadow: initial;
  border-radius: 6px;
  font-weight: 600;
  font-size: 14px;
  border: none;
  cursor: pointer;
  transition: background 0.15s;
}
.osa-contact-form #gform_1 .gform_next_button:hover,
.osa-contact-form #gform_1 .gform_previous_button:hover {
  background: #929aA6;
  color: #ffffff !important;
}

/* ── Submit button (btn-blue-flat style) ── */
.osa-contact-form #gform_1 input[type="submit"],
.osa-contact-form #gform_1 button[type="submit"],
.osa-contact-form #gform_1 .gform_button {
  padding: 10px 22px;
  background: #419AD2;
  color: #ffffff !important;
  box-shadow: initial;
  border-radius: 6px;
  font-weight: 600;
  font-size: 14px;
  border: none;
  cursor: pointer;
  transition: background 0.15s;
}
.osa-contact-form #gform_1 input[type="submit"]:hover,
.osa-contact-form #gform_1 button[type="submit"]:hover,
.osa-contact-form #gform_1 .gform_button:hover {
  background: #2F7DB8;
  color: #ffffff !important;
}


/* ── Override GF / GP bold leak ── */
.osa-contact-form .gform_wrapper.gravity-theme .gfield_label,
.osa-contact-form .gform_wrapper.gravity-theme .ginput_complex label,
.osa-contact-form .gform_wrapper.gravity-theme .gfield_description {
  font-weight: 600;
}
.osa-contact-form .gform_wrapper.gravity-theme .ginput_complex label {
  font-weight: 400;
}

div#gform_confirmation_message_1 {
    text-align: center;
    height: 340px;
    background-image: url(https://osaweso.me/wp-content/uploads/support-ticket-opened.png);
    background-size: 430px;
    background-position: bottom center;
    background-repeat: no-repeat;
}

.osa-contact-form #gform_1 .gform_next_button, .osa-contact-form #gform_1 .gform_previous_button {
    padding: 13px 22px;
    font-size: 15px;
}

input#gform_submit_button_1 {
    margin-left: initial;
}

article#post-94 .entry-content {
    margin-top: 0 !important;
}

/* ── Mobile adjustments ── */
@media (max-width: 767px) {
  .osa-contact-form .gform_wrapper {
    padding: 20px 16px;
    border-radius: 8px;
  }
}
