/*
 * This is the corrected CSS for your website.
 * The primary change is in the .program-benefits ul selector.
 * It now uses a fluid grid layout with `minmax` to automatically
 * adjust the number of columns based on screen width, which
 * prevents horizontal overflow on tablets and other smaller screens.
 */

.program-benefits ul {
  /* The key change: This creates a flexible grid that can fit as many columns
   * as possible. Each column will be at least 250px wide, but can stretch
   * to fill the available space (1fr). This makes the layout fully responsive.
   */
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(250px, 1fr));
  gap: 0.75rem 2rem; /* row gap, column gap */
  list-style-type: disc;
  padding-left: 1.5rem;
}

.program-benefits {
    background-color: whitesmoke;
    padding: .62em;
    border-radius: 4px;
    margin-bottom: 15px;
}

.program-benefits p {
  font-weight: 600;
  margin-bottom: 0.75rem;
}
                html {
  -webkit-text-size-adjust: 100%;
  -ms-text-size-adjust: 100%;
  font-family: sans-serif;
}

body {
  margin: 0;
}

svg:not(:root) {
  overflow: hidden;
}

input {
  color: inherit;
  font: inherit;
  margin: 0;
}

input::-moz-focus-inner {
  border: 0;
  padding: 0;
}

input {
  line-height: normal;
}

@font-face {
  font-family: webflow-icons;
  src: url("data:application/x-font-ttf;charset=utf-8;base64,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") format("truetype");
  font-weight: normal;
  font-style: normal;
}

* {
  box-sizing: border-box;
}

html {
  height: 100%;
}

body {
  color: #333;
  background-color: #fff;
  min-height: 100%;
  margin: 0;
  font-family: Arial, sans-serif;
  font-size: 14px;
  line-height: 20px;
}

h2, h3, h4 {
  margin-bottom: 10px;
  font-weight: bold;
}

h2 {
  margin-top: 20px;
  font-size: 32px;
  line-height: 36px;
}

h3 {
  margin-top: 20px;
  font-size: 24px;
  line-height: 30px;
}

h4 {
  margin-top: 10px;
  font-size: 18px;
  line-height: 24px;
}

p {
  margin-top: 0;
  margin-bottom: 10px;
}

ul {
  margin-top: 0;
  margin-bottom: 10px;
  padding-left: 40px;
}

.w-embed:before, .w-embed:after {
  content: " ";
  grid-area: 1 / 1 / 2 / 2;
  display: table;
}

.w-embed:after {
  clear: both;
}

.w-richtext:before, .w-richtext:after {
  content: " ";
  grid-area: 1 / 1 / 2 / 2;
  display: table;
}

.w-richtext:after {
  clear: both;
}


.w-dyn-hide {
  display: none !important;
}

:root {
  --black-900: #0c0407;
  --_letter-spacing---ls-3: -.03em;
  --_font-size---fz-72: 72px;
  --_line-height---lh-100: 100%;
  --_font-size---fz-60: 60px;
  --_line-height---lh-120: 120%;
  --_font-size---fz-48: 48px;
  --_font-size---fz-16: 16px;
  --_line-height---lh-110: 110%;
  --_letter-spacing---ls-5: -.05em;
  --_font-size---fz-50: 50px;
  --_font-size---fz-40: 40px;
  --_font-size---fz-32: 32px;
  --_font-size---fz-14: 14px;
  --_line-height---lh-150: 150%;
  --info: #3469f9;
  --secondary: #333;
  --error: #fc372d;
  --light-1: #111;
  --success: #46d64b;
  --warning: #ffb600;
  --transparent: transparent;
  --_font-size---fz-12: 12px;
  --_line-height---lh-116: 116%;
  --_letter-spacing---ls-1: -.01em;
  --_font-size---fz-26: 26px;
  --_font-size---fz-24: 24px;
  --_font-size---fz-22: 22px;
  --_letter-spacing---ls-0: 0em;
  --white: white;
  --_font-family---poppins: Poppins, sans-serif;
  --_letter-spacing---ls-4: -.04em;
  --_font-size---fz-18: 18px;
  --_font-size---fz-20: 20px;
  --black-700: #4c4c4c;
  --black-500: grey;
  --_line-height---lh-112: 112%;
  --light-2: #f6f6f6;
  --black-600: #666;
  --black-100: #e5e5e5;
  --_font-family---inter: Inter, sans-serif;
  --light-3: #e0e0e0;
  --_font-size---fz-36: 36px;
  --_line-height---lh-109: 109%;
  --_line-height---lh-130: 130%;
  --black: #000;
  --_line-height---lh-140: 140%;
  --_letter-spacing---ls-2: -.02em;
  --_letter-spacing---ls-6: -.06em;
  --_line-height---lh-90: 90%;
  --_letter-spacing---ls-7: -.07em;
  --_line-height---lh-80: 80%;
  --_letter-spacing---ls-8: -.08em;
  --_line-height---lh-70: 70%;
}

.w-commerce-commerceaddtocartform {
  margin: 0 0 15px;
}

.w-commerce-commerceaddtocartbutton {
  color: #fff;
  cursor: pointer;
  -webkit-appearance: none;
  appearance: none;
  background-color: #3898ec;
  border-width: 0;
  border-radius: 0;
  align-items: center;
  padding: 9px 15px;
  text-decoration: none;
  display: flex;
}

.w-commerce-commercebuynowbutton {
  color: #fff;
  cursor: pointer;
  -webkit-appearance: none;
  appearance: none;
  background-color: #3898ec;
  border-width: 0;
  border-radius: 0;
  align-items: center;
  margin-top: 10px;
  padding: 9px 15px;
  text-decoration: none;
  display: inline-block;
}

.w-commerce-commerceaddtocartoutofstock {
  background-color: #ddd;
  margin-top: 10px;
  padding: 10px;
}

.w-commerce-commerceaddtocarterror {
  background-color: #ffdede;
  margin-top: 10px;
  padding: 10px;
}

body {
  color: #111;
  letter-spacing: var(--_letter-spacing---ls-3);
  background-color: #111;
  font-family: Inter, sans-serif;
  font-size: 16px;
  font-weight: 400;
  line-height: 80%;
}

h2 {
  color: #111;
  font-family: Poppins, sans-serif;
  font-size: var(--_font-size---fz-60);
  line-height: var(--_line-height---lh-120);
  margin-top: 0;
  margin-bottom: 0;
  font-weight: 600;
}

h3 {
    color: #111;
    font-family: 'Schabo Condensed';
    font-size: xxx-large !important;
    line-height: var(--_line-height---lh-120);
    margin-top: 0;
    margin-bottom: 0;
    font-weight: 100;
    text-transform: uppercase;
}

h4 {
  margin-top: 0;
  margin-bottom: 0;
  font-size: 18px;
  font-weight: 700;
  line-height: 24px;
}

p {
  color: #111;
  font-size: var(--_font-size---fz-16);
  margin-bottom: 0;
  line-height: 150%;
}

ul {
  margin-top: 0;
  margin-bottom: 10px;
  padding-left: 40px;
}

.blog-rich-text h2 {
      font-size: var(--_font-size---fz-32);
    margin-bottom: 16px;
    font-family: 'Schabo Condensed';
    letter-spacing: initial;
    font-weight: 100;
    text-transform: uppercase;
}

.blog-rich-text p {
  color: #111;
  font-size: var(--_font-size---fz-16);
  line-height: var(--_line-height---lh-150);
  letter-spacing: var(--_letter-spacing---ls-0);
  margin-bottom: 16px;
}

.blog-rich-text ul {
  padding-left: 25px;
}

.blog-rich-text li {
      font-size: initial;
    line-height: var(--_line-height---lh-150);
    letter-spacing: var(--_letter-spacing---ls-1);
    margin-bottom: 16px;
    font-weight: 600;
    color: #111;
}

.c-title {
  font-size: var(--_font-size---fz-48);
  line-height: var(--_line-height---lh-112);
  letter-spacing: var(--_letter-spacing---ls-3);
}

.error-message {
  background-color: #fe444326;
  border-radius: 12px;
  line-height: 120%;
}

.p-details-layout {
  grid-column-gap: 0px;
  grid-row-gap: 40px;
  justify-content: space-between;
  align-items: flex-start;
  display: flex;
}

.p-details-left {
    background-color: #fff;
      width: 100%;
    padding: .62em;
    margin: .62em;
    border-radius: 4px;
    border: 1px solid #e0e0e0;
}

.p-details-right {
    background-color: var(--white);
    border: 1px solid #e0e0e0;
    max-width: 360px;
    position: sticky;
    top: 20px;
    width: 100%;
    padding: .62em;
    margin: .62em;
    border-radius: 4px;
}

.p-details-right-title {
  font-size: var(--_font-size---fz-24);
}

.p-details-right-title-wrap {
  margin-bottom: 24px;
}

.p-details-right-list {
  grid-column-gap: 20px;
  grid-row-gap: 20px;
  flex-flow: column;
  margin-bottom: 32px;
  display: flex;
}

.p-details-right-list-item {
  grid-column-gap: 4px;
  grid-row-gap: 4px;
  justify-content: flex-start;
  align-items: center;
  display: flex;
}

.p-details-right-list-item-icon {
  color: var(--black-700);
  width: 20px;
  height: 20px;
}

.p-details-right-list-item-text {
  color: var(--black-700);
  line-height: 120%;
}

.p-details-right-price {
  grid-column-gap: 20px;
  grid-row-gap: 20px;
  justify-content: flex-start;
  align-items: center;
  margin-bottom: 32px;
  display: flex;
}

.p-details-right-price-regular {
  font-family: Poppins, sans-serif;
  font-size: var(--_font-size---fz-32);
  font-weight: 600;
  line-height: 120%;
}

.p-details-right-price-discount {
  color: var(--black-500);
  font-size: 18px;
}

.info-message {
  background-color: var(--light-3);
  border-radius: 12px;
}

.add-to-cart-default {
  margin-bottom: 0;
}

.p-details-right-add-to-cart {
  background-color: #111;
  border-radius: 4px;
  justify-content: center;
  align-items: center;
  width: 100%;
  margin-top: 15px;
  padding-top: 12px;
  padding-bottom: 12px;
  font-size: 14px;
  font-weight: 600;
  line-height: 120%;
  transition: all .3s linear;
  text-transform: uppercase;
}

.p-details-right-add-to-cart:hover {
  background-color: var(--secondary);
}

.course-curriculum-wrapper {
  margin-top: 26px;
}

.course-item {
  background-color: var(--white);
  border: 1px solid #e0e0e0;
  border-radius: 10px;
  padding: 40px 32px;
}

.course-item-title-wrap {
  grid-column-gap: 12px;
  grid-row-gap: 12px;
  flex: 1;
  justify-content: flex-start;
  align-items: center;
  display: flex;
}

.course-item-heading-wrap {
  grid-column-gap: 20px;
  grid-row-gap: 20px;
  cursor: pointer;
  justify-content: space-between;
  align-items: center;
  display: flex;
}

.course-item-count-wrap {
  flex: none;
}

.course-item-body-wrap {
  color: var(--black-700);
  font-size: var(--_font-size---fz-16);
  line-height: var(--_line-height---lh-150);
  letter-spacing: var(--_letter-spacing---ls-0);
  width: 100%;
  padding-bottom: 0;
}

.course-item-body-text-wrap {
  padding-top: 32px;
}

.course-item-title {
  font-family: var(--_font-family---poppins);
  color: #111;
  font-size: var(--_font-size---fz-24);
  line-height: var(--_line-height---lh-112);
  letter-spacing: var(--_letter-spacing---ls-4);
  margin-top: 0;
  margin-bottom: 0;
  font-weight: 600;
}

.course-item-item-icon-wrap {
  z-index: 1;
  flex: none;
  position: relative;
}

.course-item-item-icon {
  width: 32px;
  height: 32px;
}

.course-item-count {
  color: #111;
  font-size: 20px;
  font-weight: 600;
  line-height: 24px;
}

.course-item-body-rich-text ul {
  grid-column-gap: 26px;
  grid-row-gap: 26px;
  flex-flow: column;
  margin-bottom: 20px;
  padding-left: 0;
  list-style-type: none;
  display: flex;
}

.course-item-body-rich-text li {
  grid-column-gap: 10px;
  grid-row-gap: 10px;
  color: #111;
  font-size: var(--_font-size---fz-18);
  line-height: var(--_line-height---lh-120);
  background-image: url("https://cdn.prod.website-files.com/6849280035517f36c39dbcc9/686063241d65e408d603caea_video.svg");
  background-position: 0%;
  background-repeat: no-repeat;
  background-size: 24px;
  flex-flow: wrap;
  justify-content: space-between;
  padding-left: 36px;
  display: flex;
}

.course-item-body-rich-text a {
  color: #111;
  font-weight: 600;
  text-decoration: none;
}

.course-item-body-rich-text a:hover {
  color: var(--secondary);
}

.course-curriculum-cms-list {
  grid-column-gap: 8px;
  grid-row-gap: 8px;
  flex-flow: column;
  display: flex;
}

.course-title-wrap {
  margin-bottom: 16px;
}

.course-meta {
  grid-column-gap: 8px;
  grid-row-gap: 8px;
  justify-content: flex-start;
  align-items: center;
  margin-bottom: 28px;
  display: flex;
}

.course-meta-item {
  color: var(--black-700);
  line-height: 120%;
}

.course-meta-separator {
  background-color: #e0e0e0;
  width: 1px;
  height: 14px;
}

@media screen and (max-width: 991px) {
  p {
    font-size: var(--_font-size---fz-16);
  }

  .blog-rich-text h2 {
    font-size: var(--_font-size---fz-26);
  }

  .c-title {
    font-size: var(--_font-size---fz-40);
    line-height: var(--_line-height---lh-120);
  }

  .p-details-layout {
    flex-flow: column;
  }

  .p-details-right {
    max-width: -webkit-fill-available;
    padding: 20px;
    position: static;
  }

  .p-details-right-list, .p-details-right-price {
    margin-bottom: 20px;
  }

  .course-item {
    border-radius: 12px;
    padding: 20px;
  }

  .course-item-body-text-wrap {
    padding-top: 20px;
  }

  .course-item-title {
    font-size: var(--_font-size---fz-20);
  }

  .course-item-body-rich-text li {
    font-size: var(--_font-size---fz-16);
  }

  .course-meta {
    margin-bottom: 20px;
  }
}

/* * The original media query for .program-benefits ul is no longer needed
 * because the new `minmax` approach handles all screen sizes dynamically.
 * I have kept the other media queries from your original code.
 */
@media screen and (max-width: 767px) {
  .blog-rich-text h2 {
    font-size: var(--_font-size---fz-24);
  }

  .c-title {
    font-size: var(--_font-size---fz-32);
    line-height: var(--_line-height---lh-120);
  }

  .course-item-title {
    font-size: var(--_font-size---fz-20);
  }
}

@media screen and (max-width: 479px) {

  .c-title {
    font-size: var(--_font-size---fz-26);
  }

  .course-item-title {
    font-size: var(--_font-size---fz-18);
  }

  .course-item-body-rich-text li {
    grid-column-gap: 5px;
    grid-row-gap: 5px;
    line-height: var(--_line-height---lh-150);
    background-position: 0 2px;
    background-size: 24px;
    flex-flow: column;
    justify-content: space-between;
    align-items: flex-start;
    padding-left: 30px;
  }
}
