.elementor-75231 .elementor-element.elementor-element-c8fadf8{--display:flex;--margin-top:0px;--margin-bottom:0px;--margin-left:0px;--margin-right:0px;--padding-top:0px;--padding-bottom:0px;--padding-left:0px;--padding-right:0px;}:root{--page-title-display:none;}.elementor-widget .tippy-tooltip .tippy-content{text-align:center;}/* Start custom CSS *//* DSN Quiz (Gravity Forms) page-scoped CSS for Elementor
   Paste into: Elementor Page -> Advanced -> Custom CSS
   Expects the Gravity Form to have CSS class: dsn-quiz-form
*/

/* Container */
body.elementor-page-75231 .dsn-quiz-form_wrapper{
  max-width: 860px;
  margin: 0 auto;
}

/* Card feel for the whole form */
body.elementor-page-75231 .dsn-quiz-form_wrapper form{
  background: #fff;
  border: 1px solid rgba(17,24,39,0.10);
  border-radius: 16px;
  box-shadow: 0 12px 30px rgba(17,24,39,0.08);
  padding: 28px;
}

/* Normalize typography (fixes “Email” label mismatch + heading consistency) */
body.elementor-page-75231 .dsn-quiz-form_wrapper,
body.elementor-page-75231 .dsn-quiz-form_wrapper .gfield_label,
body.elementor-page-75231 .dsn-quiz-form_wrapper .gfield_html h3,
body.elementor-page-75231 .dsn-quiz-form_wrapper .gfield_html p{
  font-family: inherit !important;
}

/* Progress bar polish (no clipping) */
body.elementor-page-75231 .dsn-quiz-form_wrapper .gf_progressbar_wrapper{
  margin: 0 0 18px 0;
}
body.elementor-page-75231 .dsn-quiz-form_wrapper .gf_progressbar_title{
  font-weight: 600;
  color: #4B5563;
  margin-bottom: 10px;
}
body.elementor-page-75231 .dsn-quiz-form_wrapper .gf_progressbar{
  height: 18px;
  border-radius: 999px;
  overflow: hidden;
  background: rgba(17,24,39,0.10);
}
body.elementor-page-75231 .dsn-quiz-form_wrapper .gf_progressbar_percentage{
  height: 18px;
  border-radius: 999px;
  background: #2563EB;
  display: flex;
  align-items: center;
  justify-content: center;
  line-height: 18px;
  font-size: 12px;
  font-weight: 700;
}
body.elementor-page-75231 .dsn-quiz-form_wrapper .gf_progressbar_percentage span{
  line-height: 18px;
}

/* Field spacing + labels */
body.elementor-page-75231 .dsn-quiz-form_wrapper .gfield{
  margin-top: 14px;
}
body.elementor-page-75231 .dsn-quiz-form_wrapper .gfield_label{
  font-size: 18px;
  line-height: 1.35;
  font-weight: 750;
  color: #111827;
  margin-bottom: 10px;
}
body.elementor-page-75231 .dsn-quiz-form_wrapper .gfield_required{
  color: #DC2626;
}
body.elementor-page-75231 .dsn-quiz-form_wrapper .gfield_description{
  color: #4B5563;
}

/* Pillar HTML blocks: consistent typography + centering */
body.elementor-page-75231 .dsn-quiz-form_wrapper .gfield_html{
  margin-top: 18px;
  margin-bottom: 8px; /* tightened */
}
body.elementor-page-75231 .dsn-quiz-form_wrapper .gfield_html h3{
  font-size: 22px;
  font-weight: 800;
  letter-spacing: -0.01em;
  color: #111827;
  margin: 10px 0 8px 0;
  text-align: center;
}
body.elementor-page-75231 .dsn-quiz-form_wrapper .gfield_html p{
  font-size: 16px;
  line-height: 1.55;
  color: #4B5563;
  margin: 0 auto 0 auto;
  text-align: center;
  max-width: 720px;
}
body.elementor-page-75231 .dsn-quiz-form_wrapper .gfield_html hr{
  border: 0;
  border-top: 1px solid rgba(17,24,39,0.10);
  margin: 16px auto 0 auto;
  max-width: 760px;
}

/* Tighten spacing between pillar block and first question */
body.elementor-page-75231 .dsn-quiz-form_wrapper .gfield_html + .gfield{
  margin-top: 6px;
}

/* Inputs */
body.elementor-page-75231 .dsn-quiz-form_wrapper input[type="text"],
body.elementor-page-75231 .dsn-quiz-form_wrapper input[type="email"]{
  border: 1px solid rgba(17,24,39,0.16);
  border-radius: 12px;
  padding: 14px 14px;
  font-size: 16px;
}
body.elementor-page-75231 .dsn-quiz-form_wrapper input[type="text"]:focus,
body.elementor-page-75231 .dsn-quiz-form_wrapper input[type="email"]:focus{
  outline: none;
  border-color: rgba(37,99,235,0.55);
  box-shadow: 0 0 0 4px rgba(37,99,235,0.12);
}

/* Radio options as selectable pill buttons */
body.elementor-page-75231 .dsn-quiz-form_wrapper .gfield_radio{
  display: flex;
  gap: 12px;
  flex-wrap: wrap;
  margin-top: 10px;
}
body.elementor-page-75231 .dsn-quiz-form_wrapper .gfield_radio li{
  margin: 0;
  position: relative;
}

/* Hide native radio visually (still accessible) */
body.elementor-page-75231 .dsn-quiz-form_wrapper .gfield_radio input[type="radio"]{
  position: absolute;
  opacity: 0;
  pointer-events: none;
}

/* Style labels (desktop pill style) */
body.elementor-page-75231 .dsn-quiz-form_wrapper .gfield_radio label{
  display: inline-flex;
  align-items: center;
  justify-content: center;
  padding: 12px 14px;
  border-radius: 999px;
  border: 1px solid rgba(17,24,39,0.14);
  background: rgba(17,24,39,0.02);
  font-weight: 650;
  color: #111827;
  cursor: pointer;
  user-select: none;
  transition: transform 120ms ease, box-shadow 120ms ease, background 120ms ease, border-color 120ms ease;
}
body.elementor-page-75231 .dsn-quiz-form_wrapper .gfield_radio label:hover{
  transform: translateY(-1px);
  box-shadow: 0 10px 18px rgba(17,24,39,0.08);
}

/* Selected state (typical GF markup: input + label) */
body.elementor-page-75231 .dsn-quiz-form_wrapper .gfield_radio input[type="radio"]:checked + label{
  background: rgba(37,99,235,0.10);
  border-color: rgba(37,99,235,0.55);
  box-shadow: 0 0 0 4px rgba(37,99,235,0.12);
}

/* Page navigation buttons */
body.elementor-page-75231 .dsn-quiz-form_wrapper .gform_page_footer{
  margin-top: 22px;
  padding-top: 18px;
  border-top: 1px solid rgba(17,24,39,0.10);
  display: flex;
  gap: 12px;
  justify-content: flex-start;
}

/* Next/Submit = primary */
body.elementor-page-75231 .dsn-quiz-form_wrapper .gform_next_button,
body.elementor-page-75231 .dsn-quiz-form_wrapper .gform_button,
body.elementor-page-75231 .dsn-quiz-form_wrapper input[type="submit"]{
  background: #2563EB !important;
  border: none !important;
  color: #fff !important;
  border-radius: 12px !important;
  padding: 14px 18px !important;
  font-weight: 750 !important;
  font-size: 15px !important;
  box-shadow: 0 12px 24px rgba(37,99,235,0.30) !important;
  transition: transform 120ms ease, box-shadow 120ms ease;
}
body.elementor-page-75231 .dsn-quiz-form_wrapper .gform_next_button:hover,
body.elementor-page-75231 .dsn-quiz-form_wrapper .gform_button:hover,
body.elementor-page-75231 .dsn-quiz-form_wrapper input[type="submit"]:hover{
  transform: translateY(-2px);
  box-shadow: 0 16px 28px rgba(37,99,235,0.36) !important;
}

/* Previous = secondary */
body.elementor-page-75231 .dsn-quiz-form_wrapper .gform_previous_button{
  background: rgba(17,24,39,0.06) !important;
  border: 1px solid rgba(17,24,39,0.10) !important;
  color: #111827 !important;
  border-radius: 12px !important;
  padding: 14px 18px !important;
  font-weight: 750 !important;
}

/* Mobile UX polish (no desktop impact) */
@media (max-width: 640px){

  /* Tighten header spacing on mobile */
  body.elementor-page-75231 .dsn-quiz-form_wrapper form{
    padding: 20px;
  }
  body.elementor-page-75231 .dsn-quiz-form_wrapper .gfield_html{
    margin-top: 14px;
    margin-bottom: 6px;
  }
  body.elementor-page-75231 .dsn-quiz-form_wrapper .gfield_html h3{
    margin: 6px 0 6px 0;
    font-size: 20px;
  }
  body.elementor-page-75231 .dsn-quiz-form_wrapper .gfield_html p{
    font-size: 15px;
  }
  body.elementor-page-75231 .dsn-quiz-form_wrapper .gfield_html + .gfield{
    margin-top: 8px;
  }

  /* Question label slightly smaller */
  body.elementor-page-75231 .dsn-quiz-form_wrapper .gfield_label{
    font-size: 16px;
    line-height: 1.35;
  }

  /* 2-column options grid */
  body.elementor-page-75231 .dsn-quiz-form_wrapper .gfield_radio{
    gap: 10px;
    justify-content: space-between;
  }
  body.elementor-page-75231 .dsn-quiz-form_wrapper .gfield_radio li{
    flex: 1 1 calc(50% - 10px);
    max-width: calc(50% - 10px);
  }

  /* Key fix: remove bubble/circle look on mobile */
  body.elementor-page-75231 .dsn-quiz-form_wrapper .gfield_radio label{
    width: 100%;
    min-height: 56px;
    border-radius: 16px !important;
    justify-content: center;
    text-align: center;
    padding: 12px 10px;
    line-height: 1.15;
    white-space: normal;
  }

  /* Extra-small screens: 1 column */
  @media (max-width: 420px){
    body.elementor-page-75231 .dsn-quiz-form_wrapper .gfield_radio li{
      flex-basis: 100%;
      max-width: 100%;
    }
    body.elementor-page-75231 .dsn-quiz-form_wrapper .gfield_radio label{
      justify-content: flex-start;
      text-align: left;
      min-height: 52px;
      padding: 12px 12px;
    }
  }

  /* Buttons: stay on one row */
  body.elementor-page-75231 .dsn-quiz-form_wrapper .gform_page_footer{
    display: flex;
    flex-wrap: nowrap;
    gap: 10px;
    align-items: stretch;
  }
  body.elementor-page-75231 .dsn-quiz-form_wrapper .gform_previous_button{
    width: 40% !important;
    padding: 14px 12px !important;
    text-align: center;
  }
  body.elementor-page-75231 .dsn-quiz-form_wrapper .gform_next_button,
  body.elementor-page-75231 .dsn-quiz-form_wrapper input[type="submit"]{
    width: 60% !important;
    padding: 14px 12px !important;
    text-align: center;
  }
}

/* FINAL mobile override: force radio choices into a real 2-column grid */
@media (max-width: 640px){

  body.elementor-page-75231 .dsn-quiz-form_wrapper .gfield_radio{
    display: grid !important;
    grid-template-columns: 1fr 1fr !important;
    gap: 12px !important;
    justify-content: initial !important;
    align-items: stretch !important;
    padding: 0 !important;
    margin: 10px 0 0 0 !important;
  }

  body.elementor-page-75231 .dsn-quiz-form_wrapper .gfield_radio li{
    width: auto !important;
    max-width: none !important;
    margin: 0 !important;
  }

  body.elementor-page-75231 .dsn-quiz-form_wrapper .gfield_radio label{
    width: 100% !important;
    min-height: 56px !important;
    border-radius: 16px !important; /* kills the bubble look */
    padding: 12px 10px !important;
    line-height: 1.15 !important;
    text-align: center !important;
    justify-content: center !important;
    white-space: normal !important;
  }
}

/* Extra-small phones: switch to 1 column */
@media (max-width: 420px){

  body.elementor-page-75231 .dsn-quiz-form_wrapper .gfield_radio{
    grid-template-columns: 1fr !important;
  }

  body.elementor-page-75231 .dsn-quiz-form_wrapper .gfield_radio label{
    text-align: left !important;
    justify-content: flex-start !important;
    padding: 12px 12px !important;
  }
}

/* Tighten gap between pillar intro (HTML field) and the next question */
body.elementor-page-75231 .dsn-quiz-form_wrapper .gfield_html{
  margin-bottom: 0 !important;
  padding-bottom: 0 !important;
}

body.elementor-page-75231 .dsn-quiz-form_wrapper .gfield_html + .gfield{
  margin-top: 0 !important;
  padding-top: 0 !important;
}

/* Some themes add spacing inside the field content wrapper */
body.elementor-page-75231 .dsn-quiz-form_wrapper .gfield_html + .gfield .ginput_container{
  margin-top: 0 !important;
  padding-top: 0 !important;
}

/* Also tighten the question label itself (often has extra top margin) */
body.elementor-page-75231 .dsn-quiz-form_wrapper .gfield_html + .gfield .gfield_label{
  margin-top: 0 !important;
}

/* ---------- FIX: Bonus (dsn-compact-choices) Desktop Layout ---------- */

@media (min-width: 768px) {

  /* Allow natural sizing instead of equal-width distribution */
  .gform_wrapper .dsn-compact-choices .gfield_radio {
    display: flex;
    flex-wrap: wrap;
    gap: 14px;
    justify-content: flex-start;
  }

  /* Remove any flex-grow or forced width rules */
  .gform_wrapper .dsn-compact-choices .gfield_radio li {
    flex: 0 0 auto !important;
    width: auto !important;
    margin: 0 !important;
  }

  /* Keep pill sizing visually balanced */
  .gform_wrapper .dsn-compact-choices .gfield_radio label {
    min-width: 130px;
    padding: 12px 18px;
  }
}

/* Put “Take the quiz” above the progress bar (GF title/description) */
body.elementor-page-75231 #gform_wrapper_276 .gform_title{
  font-size: 22px;
  font-weight: 800;
  margin: 0 0 8px 0;
  text-align: center;
}

body.elementor-page-75231 #gform_wrapper_276 .gform_description{
  font-size: 16px;
  line-height: 1.55;
  color: #4B5563;
  margin: 0 0 14px 0;
  text-align: center;
  max-width: 720px;
}

/* Card should wrap title/description + progress + fields */
body.elementor-page-75231 .dsn-quiz-form_wrapper{
  background: #fff;
  border: 1px solid rgba(17,24,39,0.10);
  border-radius: 16px;
  box-shadow: 0 12px 30px rgba(17,24,39,0.08);
  padding: 28px;
}

/* Prevent double card styling */
body.elementor-page-75231 .dsn-quiz-form_wrapper form{
  background: transparent;
  border: 0;
  border-radius: 0;
  box-shadow: none;
  padding: 0;
}

/* Show GF title/description only on Page 1 */
body.elementor-page-75231 #gform_wrapper_276.gform_page_2 .gform_title,
body.elementor-page-75231 #gform_wrapper_276.gform_page_2 .gform_description,
body.elementor-page-75231 #gform_wrapper_276.gform_page_3 .gform_title,
body.elementor-page-75231 #gform_wrapper_276.gform_page_3 .gform_description,
body.elementor-page-75231 #gform_wrapper_276.gform_page_4 .gform_title,
body.elementor-page-75231 #gform_wrapper_276.gform_page_4 .gform_description,
body.elementor-page-75231 #gform_wrapper_276.gform_page_5 .gform_title,
body.elementor-page-75231 #gform_wrapper_276.gform_page_5 .gform_description,
body.elementor-page-75231 #gform_wrapper_276.gform_page_6 .gform_title,
body.elementor-page-75231 #gform_wrapper_276.gform_page_6 .gform_description,
body.elementor-page-75231 #gform_wrapper_276.gform_page_7 .gform_title,
body.elementor-page-75231 #gform_wrapper_276.gform_page_7 .gform_description{
  display: none !important;
}

/* Tighten top padding on pages 2+ (removes the blank band) */
body.elementor-page-75231 .dsn-quiz-form_wrapper.dsn-quiz-page-2plus{
  padding-top: 4px !important;
}

/* Remove extra space under buttons (all pages) */
body.elementor-page-75231 #gform_wrapper_276 .gform_page_footer{
  margin-bottom: 0 !important;
  padding-bottom: 0 !important;
}

/* Kill margin from last field before footer */
body.elementor-page-75231 #gform_wrapper_276 .gfield:last-of-type{
  margin-bottom: 0 !important;
}

/* Tighten bottom padding of the card slightly */
body.elementor-page-75231 .dsn-quiz-form_wrapper{
  padding-bottom: 18px !important;
}

/* Remove extra bottom spacing on this page */
body.elementor-page-75231 {
  margin-bottom: 0 !important;
  padding-bottom: 0 !important;
}

/* Remove bottom space from last Elementor section */
body.elementor-page-75231 .elementor-section:last-of-type {
  margin-bottom: 0 !important;
  padding-bottom: 0 !important;
}

/* Remove bottom margin from last widget */
body.elementor-page-75231 .elementor-widget:last-of-type {
  margin-bottom: 0 !important;
}

/* If theme adds space below content */
body.page .site-content,
body.page #content {
  margin-bottom: 0 !important;
  padding-bottom: 0 !important;
}

/* Remove bottom margin from the last thing inside the hero */
body.elementor-page-75231 .dsn-quiz-hero3 > :last-child{
  margin-bottom: 0 !important;
}

/* Remove bottom margin from the last thing inside the hero inner */
body.elementor-page-75231 .dsn-quiz-hero3 .dsn-quiz-hero3-inner > :last-child{
  margin-bottom: 0 !important;
}

/* If GF wrapper has a bottom margin */
body.elementor-page-75231 #gform_wrapper_276{
  margin-bottom: 0 !important;
}

/* Make the hero fill the screen so there’s no awkward dead space */
body.elementor-page-75231 .dsn-quiz-hero3{
  min-height: 100vh;
  display: flex;
  align-items: center; /* vertically centers content */
}

/* Keep inner content from stretching too wide */
body.elementor-page-75231 .dsn-quiz-hero3 .dsn-quiz-hero3-inner{
  width: 100%;
}

/* Mobile: avoid browser address bar weirdness */
@media (max-width: 768px){
  body.elementor-page-75231 .dsn-quiz-hero3{
    min-height: 100svh; /* better on mobile browsers */
    align-items: flex-start;
    padding-top: 36px;
  }
}

/* Truly center the GF description */
body.elementor-page-75231 #gform_wrapper_276 .gform_description{
  text-align: center !important;
  margin-left: auto !important;
  margin-right: auto !important;
  max-width: 720px; /* optional, keeps it visually balanced */
}

/* Desktop: 5 equal columns so the row visually aligns with the 4-option rows */
@media (min-width: 768px){

  body.elementor-page-75231 .dsn-quiz-form_wrapper .dsn-compact-choices .gfield_radio{
    display: grid !important;
    grid-template-columns: repeat(5, minmax(0, 1fr)) !important;
    gap: 24px !important; /* match your other row spacing */
    align-items: stretch !important;
    justify-items: stretch !important;
  }

  body.elementor-page-75231 .dsn-quiz-form_wrapper .dsn-compact-choices .gfield_radio .gchoice{
    margin: 0 !important;
    width: auto !important;
  }

  /* Make each pill fill its column so edges read clean */
  body.elementor-page-75231 .dsn-quiz-form_wrapper .dsn-compact-choices .gfield_radio label{
    width: 100% !important;
    justify-content: center !important;
    text-align: center !important;
    white-space: nowrap; /* keeps them tidy on desktop */
    padding: 12px 10px !important;
  }
}/* End custom CSS */