.elementor-kit-17{--e-global-color-primary:#15557E;--e-global-color-secondary:#3EB06D;--e-global-color-text:#414343;--e-global-color-accent:#3EB06D;--e-global-color-0345671:#FFFFFF;--e-global-color-7350eca:#000000;--e-global-typography-primary-font-family:"Lato";--e-global-typography-primary-font-weight:600;--e-global-typography-secondary-font-family:"Lato";--e-global-typography-secondary-font-weight:400;--e-global-typography-text-font-family:"Lato";--e-global-typography-text-font-weight:400;--e-global-typography-accent-font-family:"Lato";--e-global-typography-accent-font-weight:500;font-family:"Lato", Sans-serif;font-size:18px;font-weight:400;line-height:1.7em;}.elementor-kit-17 button,.elementor-kit-17 input[type="button"],.elementor-kit-17 input[type="submit"],.elementor-kit-17 .elementor-button{background-color:var( --e-global-color-primary );font-size:16px;font-weight:700;text-decoration:none;color:var( --e-global-color-0345671 );border-radius:0px 0px 0px 0px;padding:14px 34px 14px 34px;}.elementor-kit-17 button:hover,.elementor-kit-17 button:focus,.elementor-kit-17 input[type="button"]:hover,.elementor-kit-17 input[type="button"]:focus,.elementor-kit-17 input[type="submit"]:hover,.elementor-kit-17 input[type="submit"]:focus,.elementor-kit-17 .elementor-button:hover,.elementor-kit-17 .elementor-button:focus{background-color:var( --e-global-color-text );color:var( --e-global-color-0345671 );}.elementor-kit-17 e-page-transition{background-color:#FFBC7D;}.elementor-kit-17 a{color:var( --e-global-color-primary );text-decoration:underline;}.elementor-kit-17 h1{font-size:46px;font-weight:500;}.elementor-kit-17 h2{color:var( --e-global-color-primary );font-weight:700;text-transform:none;}.elementor-kit-17 h3{font-family:"Lato", Sans-serif;font-size:28px;font-weight:600;text-transform:none;}.elementor-kit-17 h4{font-family:"Lato", Sans-serif;font-weight:600;}.elementor-section.elementor-section-boxed > .elementor-container{max-width:1140px;}.e-con{--container-max-width:1140px;}.elementor-widget:not(:last-child){--kit-widget-spacing:20px;}.elementor-element{--widgets-spacing:20px 20px;--widgets-spacing-row:20px;--widgets-spacing-column:20px;}{}h1.entry-title{display:var(--page-title-display);}.site-header .site-branding{flex-direction:column;align-items:stretch;}.site-header{padding-inline-end:0px;padding-inline-start:0px;}.site-footer .site-branding{flex-direction:column;align-items:stretch;}@media(max-width:1200px){.elementor-section.elementor-section-boxed > .elementor-container{max-width:1024px;}.e-con{--container-max-width:1024px;}}@media(max-width:767px){.elementor-kit-17 h1{font-size:41px;}.elementor-kit-17 h2{font-size:30px;}.elementor-kit-17 h3{font-size:24px;}.elementor-section.elementor-section-boxed > .elementor-container{max-width:767px;}.e-con{--container-max-width:767px;}}/* Start custom CSS */.cusm-lang-switcher{
  display:flex;
  align-items:center;
  gap:12px;
  flex-wrap:nowrap;
}

.cusm-lang-switcher .lang-switch-link{
  display:inline-block;
  white-space:nowrap;
  text-decoration:none;
}

.cusm-lang-switcher .lang-switch-select{
  display:inline-block;
  width:auto;
  min-width:140px;
  max-width:180px;
  white-space:nowrap;
  margin:0;
}

/* container */
.cusm-lang-switcher{
  display:flex;
  align-items:center;   /* vertical centering */
  gap:12px;
  height:100%;
}

/* English link */
.cusm-lang-switcher .lang-switch-link{
  background:#15557E;
  color:#fff;
  padding:8px 14px;
  text-decoration:none;
  display:flex;
  align-items:center;
  height:38px;
}

/* dropdown */
.cusm-lang-switcher .lang-switch-select{
  background:#15557E;
  color:#fff;
  border:1px solid rgba(255,255,255,0.4);
  padding:6px 10px;
  height:38px;
}

/* dropdown arrow contrast */
.cusm-lang-switcher .lang-switch-select option{
  color:#000;
}


.elementor-widget-text-editor a {color: #15557E;text-decoration:underline;}
.elementor-widget-text-editor ul, .elementor-widget-text-editor ol {margin-bottom: 20px;}
[type=button], [type=submit], button {border:none;}
bad

/* ===== CUSM Gravity Forms Page 2 styling ===== */

/* Hide empty sections (we add these classes in PHP) */
.gform_wrapper .gfield.gf-hidden,
.gform_wrapper .gfield.cusm-field-hidden {
  display: none !important;
}

/* Page 2: checkbox list layout */
.gform_wrapper .gfield_checkbox li {
  margin: 10px 0;
}

/* Keep checkbox + text aligned nicely */
.gform_wrapper .gfield_checkbox li label {
  display: inline-block;
  line-height: 1.35;
  margin-left: 8px;
  vertical-align: top;
  max-width: 900px;
}

/* Measure title + definition stack */
.cusm-measure-title {
  display: block;
  font-weight: 700;
}

.cusm-def {
  display: block;
  font-size: 12.5px;
  opacity: 0.85;
  margin-top: 3px;
}

@media print {
  .cusm-results-tools { display: none !important; } /* hides print link */
  header, footer, .site-header, .site-footer { display: none !important; } /* theme-dependent */
  a { text-decoration: none; }
}

@media print {
  body { background: #fff !important; }
  .cusm-plan-results { max-width: none; margin: 0; }

  /* Keep each measure from splitting awkwardly */
  .cusm-measure { break-inside: avoid; page-break-inside: avoid; }

  /* Tighter headings for print */
  .cusm-domain { margin-top: 20px; }
  .cusm-subtheme { margin-top: 12px; }
  .cusm-indicator { margin-top: 10px; }
}


@media print {
  /* Hide Hello Elementor header/footer + Elementor header/footer templates */
  header.site-header,
  footer.site-footer,
  .elementor-location-header,
  .elementor-location-footer {
    display: none !important;
  }

  /* Hide any nav / buttons you don’t want */
  .cusm-results-tools {
    display: none !important;
  }

  /* Use full width for print */
  body, html {
    background: #fff !important;
  }
  .cusm-plan-results {
    max-width: none !important;
    margin: 0 !important;
  }

  /* Prevent awkward splitting */
  .cusm-measure {
    break-inside: avoid;
    page-break-inside: avoid;
  }
}

/* Page 2 – force multi-line label */
.gform_wrapper .gchoice label .cusm-measure-title,
.gform_wrapper .gchoice label .cusm-def{
  display:block !important;
}

.gform_wrapper .gchoice label .cusm-measure-title{
  font-weight:700;
  margin:0 0 2px 0;
}

.gform_wrapper .gchoice label .cusm-def{
  font-size:12.5px;
  opacity:.85;
  margin:0;
}

/* Gravity Forms — primary accent color */
:root{
  --gf-accent: #15557E;
  --gf-accent-hover: #0f3f5d; /* optional darker hover */
}

/* Links inside Gravity Forms */
.gform_wrapper a,
.gform_wrapper .gfield_description a,
.gform_wrapper .ginput_container a {
  color: var(--gf-accent);
}
.gform_wrapper a:hover,
.gform_wrapper a:focus {
  color: var(--gf-accent-hover);
}

/* Buttons (Gravity Forms inputs + button elements) */
.gform_wrapper .gform_button,
.gform_wrapper .gform_next_button,
.gform_wrapper .gform_previous_button,
.gform_wrapper .gform_save_link,
.gform_wrapper button,
.gform_wrapper input[type="submit"],
.gform_wrapper input[type="button"],
.gform_wrapper input[type="reset"] {
  background-color: var(--gf-accent);
  border-color: var(--gf-accent);
  color: #fff;
}

/* Button hover/focus */
.gform_wrapper .gform_button:hover,
.gform_wrapper .gform_next_button:hover,
.gform_wrapper .gform_previous_button:hover,
.gform_wrapper .gform_save_link:hover,
.gform_wrapper button:hover,
.gform_wrapper input[type="submit"]:hover,
.gform_wrapper input[type="button"]:hover,
.gform_wrapper input[type="reset"]:hover,
.gform_wrapper .gform_button:focus,
.gform_wrapper .gform_next_button:focus,
.gform_wrapper .gform_previous_button:focus,
.gform_wrapper button:focus,
.gform_wrapper input[type="submit"]:focus,
.gform_wrapper input[type="button"]:focus,
.gform_wrapper input[type="reset"]:focus {
  background-color: var(--gf-accent-hover);
  border-color: var(--gf-accent-hover);
  color: #fff;
}

/* Focus rings to match (accessibility-friendly) */
.gform_wrapper input:focus,
.gform_wrapper select:focus,
.gform_wrapper textarea:focus,
.gform_wrapper button:focus,
.gform_wrapper input[type="submit"]:focus,
.gform_wrapper input[type="button"]:focus {
  outline: 2px solid rgba(21, 85, 126, 0.35);
  outline-offset: 2px;
  box-shadow: 0 0 0 3px rgba(21, 85, 126, 0.20);
}

/* Progress bar (Gravity Forms "Progress Indicator") */
.gform_wrapper .gf_progressbar_percentage,
.gform_wrapper .gf_progressbar_percentage span {
  background: var(--gf-accent) !important;
  color: #fff;
}

/* Progress steps (if using the step-style indicator) */
.gform_wrapper .gf_page_steps .gf_step_active .gf_step_number,
.gform_wrapper .gf_page_steps .gf_step_completed .gf_step_number {
  background: var(--gf-accent);
  border-color: var(--gf-accent);
  color: #fff;
}
.gform_wrapper .gf_page_steps .gf_step_active .gf_step_label,
.gform_wrapper .gf_page_steps .gf_step_completed .gf_step_label {
  color: var(--gf-accent);
}

/* Optional: required asterisk + validation message accent */
.gform_wrapper .gfield_required,
.gform_wrapper .validation_message,
.gform_wrapper .gform_validation_errors a {
  color: var(--gf-accent);
}


/* Gravity Forms 2.8+ (Orbital / Theme Framework) */
.gform_wrapper,
.gform-theme--framework {

  /* Primary brand color */
  --gf-color-primary: #15557E;
  --gf-color-primary-rgb: 21, 85, 126;

  /* Button states */
  --gf-color-primary-hover: #0f3f5d;
  --gf-color-primary-focus: #0f3f5d;

  /* Progress / steps */
  --gf-progressbar-background-color: #15557E;
  --gf-progressbar-text-color: #ffffff;
}

/* Hard override for all Gravity Forms buttons */
.gform_wrapper .gform-theme-button,
.gform_wrapper .gform_button,
.gform_wrapper button,
.gform_wrapper input[type="submit"],
.gform_wrapper input[type="button"] {
  background-color: #15557E !important;
  border-color: #15557E !important;
  color: #ffffff !important;
}

.gform_wrapper .gform-theme-button:hover,
.gform_wrapper button:hover,
.gform_wrapper input[type="submit"]:hover,
.gform_wrapper input[type="button"]:hover {
  background-color: #0f3f5d !important;
  border-color: #0f3f5d !important;
}

/* Gravity Forms — heading cleanup */
.gform_wrapper h2,
.gform_wrapper h3 {
  padding: 0;
  margin-left: 0;
  margin-right: 0;
}

/* h2 divider styling */
.gform_wrapper h2 {
  border-bottom: 1px solid #15557E;
  padding-bottom: 0.25em; /* optional breathing room under text */
  margin-bottom: 0.0em;
}

.gform_wrapper h2:not(:first-child),
.gform_wrapper h3:not(:first-child) {
  margin-top: 0em;
}


/* Gravity Forms — tighten heading + field spacing */

/* H2 spacing */
.gform_wrapper h2 {
  margin-top: 2rem;        /* space from previous section */
  margin-bottom: -0.75rem;  /* tighter gap to H3 */
}

/* H3 spacing */
.gform_wrapper h3 {
  margin-top: 0;
  margin-bottom: -1.5rem;   /* tight gap to checkboxes */
  padding: 0;
}

/* Reduce space before checkbox groups */
.gform_wrapper .gfield {
  margin-top: 0.5rem;
}

/* Allow breathing room AFTER checkbox groups */
.gform_wrapper .gfield + h3 {
  margin-top: 0rem;
}

/* Optional: tighten checkbox list itself */
.gform_wrapper .gfield_checkbox,
.gform_wrapper .gfield_radio {
  margin-top: 0.25rem;
}

/* Gravity Forms — headings inside HTML fields only */
.gform_wrapper .gfield_html h2,
.gform_wrapper .gfield_html h3 {
  margin-bottom: 0;
}

.gform_wrapper .gfield_html h1 {
  margin-top: 20px ; margin-bottom: 0px;
}

/* FORM 1 — PAGE 2 ONLY — section/group legends + labels */
html body #gform_wrapper_1 #gform_page_1_2 legend.gfield_label.gform-field-label,
html body #gform_wrapper_1 #gform_page_1_2 .gfield > label.gfield_label {
  font-size: 30px !important;
  font-weight: 600 !important;
  text-transform: uppercase !important;
  color: #333 !important;
  line-height: 1.15 !important;
}

/* ===== CUSM Results Renderer: global tokens ===== */
.cusm-plan-results {
  --cusm-accent: #15557E;
  --cusm-text: #222;
  --cusm-muted: #555;
  --cusm-border: rgba(0,0,0,0.16);
  --cusm-soft: rgba(21,85,126,0.16);
}

/* ===== Print header styling (optional but helps) ===== */
.cusm-print-header {
  margin: 0 0 18px;
  padding: 12px 0 18px;
  border-bottom: 2px solid var(--cusm-soft);
}
.cusm-print-title {
  font-size: 26px;
  font-weight: 700;
  color: var(--cusm-text);
  line-height: 1.15;
}
.cusm-print-subtitle {
  margin-top: 6px;
  font-size: 14px;
  color: var(--cusm-muted);
}

/* ===== Tools row ===== */
.cusm-plan-results .cusm-results-tools {
  display: flex;
  justify-content: flex-end;
  margin: 0 0 18px;
  padding: 0 0 12px;
  border-bottom: 1px solid var(--cusm-soft);
}
.cusm-plan-results .cusm-results-tools a {
  color: var(--cusm-accent);
  font-weight: 600;
  text-decoration: none;
}
.cusm-plan-results .cusm-results-tools a:hover {
  text-decoration: underline;
}

/* ===== Hierarchy + separation ===== */
.cusm-plan-results h2.cusm-domain {
  margin: 28px 0 10px;
  padding-bottom: 10px;
  border-bottom: 2px solid var(--cusm-accent);
  color: var(--cusm-accent);
  letter-spacing: 0.2px;
}

.cusm-plan-results h3.cusm-subtheme {
  background: none;
  border: none;
  padding: 0;
  margin: 16px 0 10px;

  font-size: 18px;        /* slightly smaller */
  font-weight: 600;
  color: #333;
}

/* CUSM Results — emphasize H4 (indicator) headings */
.cusm-plan-results h4.cusm-indicator {
  font-size: 15px;        /* up from ~13px */
  font-weight: 700;
  letter-spacing: 0.05em;
  margin: 18px 0 12px;
  color: #222;
}

/* ===== Measure "cards" (wraps the Elementor template output) ===== */
.cusm-plan-results .cusm-measure {
  margin: 14px 0 18px;
  padding: 0px;
  border: 1px solid var(--cusm-border);
  border-left: 6px solid var(--cusm-accent);
  border-radius: 12px;
  background: #fff;
  box-shadow: 0 1px 0 rgba(0,0,0,0.04);
}

/* Tighten the first/last elements inside the measure block */
.cusm-plan-results .cusm-measure > :first-child {
  margin-top: 0 !important;
}
.cusm-plan-results .cusm-measure > :last-child {
  margin-bottom: 0 !important;
}

/* Make links inside measures match accent */
.cusm-plan-results .cusm-measure a {
  color: var(--cusm-accent);
}


.cusm-core-badge{
  display:inline-block;
  margin-left:8px;
  padding:2px 8px;
  border-radius:999px;
  font-size:11px;
  line-height:1.2;
  font-weight:600;
  background: #15557E;   /* blue pill */
  color: #FFFFFF;        /* white text */

  vertical-align:middle;
  white-space:nowrap;
}

/* Core Indicator badge (GF refine screen) */
.gform_wrapper .cusm-core-badge,
body .cusm-core-badge{
  display: inline-block !important;
  padding: 2px 8px !important;
  margin: 0 0 0 8px !important;
  border-radius: 999px !important;

  font-size: 11px !important;
  line-height: 1.2 !important;
  font-weight: 700 !important;
  text-transform: none !important;

background: #15557E;   /* blue pill */
  color: #FFFFFF;        /* white text */

  vertical-align: baseline !important;
  white-space: nowrap !important;
}

/* Keep the measure title line from breaking before the badge */
.gform_wrapper .gfield_checkbox label,
.gform_wrapper .gfield_radio label{
  display: inline !important;
}

/* Put badge on same line as the Elementor heading inside the measure card */
.cusm-measure .elementor-widget-heading,
.cusm-measure .elementor-widget-heading .elementor-heading-title{
  display: inline !important;
}

.cusm-measure .cusm-core-badge{
  margin-left: 8px !important;
}

/* 1) Keep the accordion container full width */
.btn-accordion {
  width: 100%;
}

/* 2) Make the clickable header look like a button and only as wide as its content */
.btn-accordion .elementor-accordion-item .elementor-tab-title {
  display: inline-flex;          /* shrink-to-fit */
  width: auto;
  align-items: center;
  gap: .5rem;
  padding: 12px 18px;
  border: 1px solid #cfd4dc;
  border-radius: 6px;
  background: #fff;
  cursor: pointer;
}

/* If Elementor forces it block-level, this helps */
.btn-accordion .elementor-accordion-item {
  width: 100%;
}

/* 3) Ensure the content area opens full width under it */
.btn-accordion .elementor-tab-content {
  width: 100%;
  display: block;
  margin-top: 14px;
  padding: 18px;
  border: 1px solid #e4e7ec;
  border-radius: 6px;
}

/* Optional: hover/focus states */
.btn-accordion .elementor-tab-title:hover {
  background: #f6f7f9;
}

.btn-accordion .elementor-tab-title:focus {
  outline: 2px solid rgba(0,0,0,.15);
  outline-offset: 2px;
}

/* Center the trigger text */
.tooltip-trigger {
  position: relative;
  display: inline-block;
  text-align: center;
  cursor: help;
  text-decoration: underline;
  font-weight: 600; 
  color: #1f2a44;
  
}
.tooltip-trigger:hover {color: #777;}

/* Tooltip box */
.tooltip-content {
  position: absolute;
  bottom: 100%;                /* position above text */
  left: 50%;
  transform: translateX(-50%) translateY(-10px);  /* center horizontally + spacing */
  
  background: #1f2a44;
  color: #ffffff;
  padding: 12px 16px;
  border-radius: 8px;

  max-width: 300px;
  width: max-content;
  box-sizing: border-box;

  font-size: 14px;
  line-height: 1.5;

  opacity: 0;
  visibility: hidden;
  transition: opacity 0.2s ease, transform 0.2s ease;

  z-index: 999;
  text-align: center;
}

/* Show on hover */
.tooltip-trigger:hover .tooltip-content {
  opacity: 1;
  visibility: visible;
  transform: translateX(-50%) translateY(-14px);
}

:target::before {
  content: "";
  display: block;
  height: 250px;
  margin-top: -250px;
  visibility: hidden;
  pointer-events: none;
}

.cusm-core-badge{
	display:inline-block;
	margin-left:8px;
	padding:2px 8px;
	border-radius:999px;
	font-size:11px;
	line-height:1.2;
	font-weight:600;
	background:#15557E;
	color:#fff;
	vertical-align:middle;
	white-space:nowrap;
}/* End custom CSS */