@import url("https://fonts.googleapis.com/css?family=Lato:300,400,700|Droid+Serif:300,400,700");

      :root {
        --font: Lato;
        --alt-font: Droid Serif;
        --accent-color: #5a1580;
        --secondary-color: #b0b2bd;
        --link-color: #a9a9a9;
        --accent-highlight-color: #5a1580;
        --accent-highlight-background-color: #f3e6fb;
        --accent-tinted-color-70: #ceb9d9;
        --accent-tinted-color-80: #ded0e6;
        --accent-tinted-color-90: #efe8f2;
        --accent-contrast-color: #fff;
        --accent-contrast-tinted-background-color: #b3b3b3;
        --accent-hover-color: #791cac;
        --secondary-hover-color: #9497a6;
        --secondary-contrast-color: #111;
        --link-hover-color: #767676;
      }
      

.company__logo {text-indent: 100%;white-space: nowrap;overflow: hidden;background: url('https://d36ai2hkxl16us.cloudfront.net/thoughtindustries/image/upload/a_exif,c_fit,t_ti_company_logo_hires_v3/v1/course-uploads/736085e6-2b15-4baf-8b62-886204268a5f/tnqtoif3re69-RSN_onlinecourseslogo-2024-retina-200px-square.jpg') no-repeat center left;background-size: contain;} .company__logo span.h4 {visibility: hidden;}
/********************* GLOBAL **********************/
a[target="_blank"]:after {
  content: url(data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAAAoAAAAKCAYAAACNMs+9AAAAQElEQVR42qXKwQkAIAxDUUdxtO6/RBQkQZvSi8I/pL4BoGw/XPkh4XigPmsUgh0626AjRsgxHTkUThsG2T/sIlzdTsp52kSS1wAAAABJRU5ErkJggg==);
  margin: 0 3px 0 5px;
}

/*Whole Page Container*/
.container {
  max-width: 100%;
  width: 100%;
}

/*Main Content Area*/
.home__content {
  padding-left: 0;
  padding-right:0;
}

/*Default Para Styles*/
p, li {
  color: #262626;
  font-size: 16px;
  max-width: 800px;
  font-weight: 300 !important;
}

/*Centred Paragraph*/
p.p-centered {
  margin-left: auto;
  margin-right: auto;
}

/*Stand First Para*/
p.p-l {
  color: #262626;
  font-size: 1.125rem;
  line-height: 1.75rem;
  font-weight: 300;
}

/*Standard Link Styling*/
.link-standard {
  color: #262626;
  text-decoration: none;
  padding-bottom: 4px;
  font-size: 1rem;
  line-height: 1.5rem;
  font-weight: 300;
  border-bottom: 1px solid #262626;
  transition: all 0.5s;
}

.link-standard:hover,.link-standard:focus {
  border-bottom: 3px solid #262626;
  color: #262626;
}

/* Default Heading Text */
.support h1.h2.widget__title,.page h1.h2.widget__title,.catalog h1.h2.widget__title {
  font-size: 2.375rem;
  line-height: 2.75rem;
  font-weight: 300;
  color: #262626;
  margin: 36px 0;
}

/*** Mainly for Product Page***/
h1.h2.widget__title {
  font-size: 1.875rem;
  line-height: 2.25rem;
  font-weight: 400;
  color: #262626;
}

.page h2 {
  padding-top: 1.5rem;
}

@media only screen and (min-width: 768px) {
  .support h1.h2.widget__title,.page h1.h2.widget__title,.catalog h1.h2.widget__title {
    font-size: 3.125rem;
    line-height: 3.625rem;
  }
}

/*** SITE HEADER & FOOTER ***/
/*Constrain header and footer width, and center align*/
header.header,footer.footer {
  max-width: 1400px;
  margin-left: auto;
  margin-right: auto;
  box-shadow: none;
  z-index: 2;
}

/*Style Sitewide title text*/
p.company__school-name {
  text-transform: none;
  color: #5a1580;
  font-size: 5vw;
  margin: 0 10% 2% 10%;
  line-height: 1.5em;
  font-weight: 400;
}

.header__inner {
  border-bottom: 1px solid #e9e9e9;
  text-align: center;
}

@media only screen and (min-width: 770px) {
  p.company__school-name {
    margin: auto;
    text-align: center;
    font-size: 18px;
    width: 280px;
    position: absolute;
    top: 60px;
    left: 50%;
    transform: translateX(-50%);
  }
  .header__inner {
    text-align: initial;
  }
  nav.top-bar {
    margin-top: 50px;
  }
}

@media only screen and (min-width: 1400px) {
  p.company__school-name {
    width: 500px;
    top: 20px;
    font-size: 32px;
  }
}

/*** MAIN NAV ***/

.company__school-name__divider {
  border: none;
}
.top-bar-section li a:hover {
  background: #d8d0ed !important;
}
.top-bar-section li a {
  background: #fff !important;
}

@media only screen and (min-width: 769px) {
  nav.top-bar .top-bar-section ul {
      display: flex;
      justify-content: space-between;
      width: 100%;
  }
  nav.top-bar .top-bar-section ul li a {
    font-size: 14px;
  }
  .header li.has-dropdown.hover ul.dropdown {
    box-shadow: 0 6px 6px grey;
  }
  nav.top-bar .top-bar-section ul li a {
    font-size: 0.9rem;
    font-weight: 700;
  }
  nav.top-bar .top-bar-section .dropdown li a {
    font-weight: normal;
    font-size: 0.9rem;
  }
}
@media only screen and (min-width: 900px) {
  nav.top-bar .top-bar-section ul li a {
    font-size: 1rem;
  }
}
@media only screen and (min-width: 1450px) {
  nav.top-bar .top-bar-section ul {
   display: inline;
   width: auto;
  }
}

/*** PAGE ROWS ***/
.home:not(.catalog) .row > div,.home:not(.catalog) .row div.row {
    max-width: 1400px;
    margin-left: auto;
    margin-right: auto;
    padding-left: 1rem;
    padding-right: 1rem;
}

.home:not(.catalog) .row > div.narrowRow {
    max-width: 800px;
}

/* Fix Built In Slider */
li.testimonial-container {
  max-width: 100%;
}

/********************* HOMEPAGE ********************/
/*** Homepage Carousel ***/
.keyFeaturesBanner {
  margin: 22px 0;
}
.keyFeaturesBanner ul {
  list-style: none;
  display: flex;
  justify-content: space-between;
  padding: 0 10%;
  margin: 0;
}
.keyFeaturesBanner ul li {
    max-width: 20%;
    text-align: center;
    font-weight: 600;
}

@media only screen and (max-width: 1026px) {
  .keyFeaturesBanner ul {
    display: block;
    height: 50px;
    padding: 10px 10%;
  }
  .keyFeaturesBanner ul li {
    opacity: 0;
    text-align: center;
    max-width:100%;
    height:0px;
  }
  .keyFeaturesBanner ul li.active {
    opacity: 1;
    height:50px;
  }
}

/*** Homepage Blocks ***/
.wideRow {
  background: #f0f2f6;
}

.featuredContainer {
  display: grid;
  grid-template-columns: 1fr;
  grid-template-areas: "head" "featured" "course1";
  max-width: 1400px;
  margin-left: auto;
  margin-right: auto;
  grid-gap: 16px;
  padding-left: 1rem;
  padding-right: 1rem;
  padding-bottom: 20px;
}

@media only screen and (min-width: 700px) {
  .featuredContainer {
    grid-template-columns: 1fr 1fr;
    grid-template-areas: "head head" "featured course1";
  }
    .featuredContainer .prod {
    margin: 4%;
  }
}
@media only screen and (min-width: 1000px) {
  .featuredContainer {
    grid-template-columns: 1fr 1fr 1fr;
    grid-template-areas: "head head head" "featured featured course1";
  }

  .featuredContainer.testFeaturedContainer {
    grid-template-columns: 1fr 1fr;
    grid-template-areas: "head head" "featured course1";
  }

}
@media only screen and (min-width: 1950px) {
  .featuredContainer,.featuredContainer.testFeaturedContainer {
    grid-template-columns: 1fr 1fr 1fr 1fr;
    grid-template-areas: "head head head head" "featured featured course1 course1" "featured featured course1 course1";
  }

  .featuredContainer.testFeaturedContainer.featuredCourseContainer {
    grid-template-areas: "head head head head" "featured featured course1 course1" "featured featured course1 course1";
  }

  .featuredContainer.testFeaturedContainer.featuredCourseContainer .prod.featured {
    grid-area: featured;
  }

  .featuredContainer.testFeaturedContainer.featuredCourseContainer .prod:not(.showdesc) p {
    display: none;
  }

}

.featuredContainer .blockHero {
  width: 100%;
}

.featuredContainer h2 {
  font-weight: 700;
  color: #333;
  margin: 30px 0 20px 0;
}

.featuredContainer .head .btn {
  margin-top: 20px;
}

.featuredContainer .head {
  margin-bottom: 20px;
  text-align: center;
  grid-area: head;
  color: #333;
}

.featuredContainer .prod {
  border: none;
  background: white;
  padding: 0;
  display: grid;
  margin: 1rem;
  position: relative;
  grid-template-rows: min-content auto auto;
}

.featuredContainer .prod h3 {
  text-transform: uppercase;
  text-align: left;
  margin: 10px;
  margin-left: 15px;
  margin-right: 15px;
  height: 40px;
  color: #5a1580;
  font-size: 16px;
  font-weight: 700;
}
.featuredContainer .prod h3:hover {
  color: #d8d0ed;
}

.featuredContainer .prod p {
  margin: 15px;
}

.featuredContainer .featuredInfo {
  align-self: end;
}

.featuredContainer .prod a {
  color: white;
}

/*Watch Preview Button*/
.featuredContainer .prod .btn.btn--primary.abs {
  position: absolute;
  right: 10px;
  top: 10px;
  background: none;
  color: #5a1580;
  font-weight: 600;
}

.featuredContainer .prod .btn.btn--primary.abs:hover {
  background: #5a1580;
  color: white;
}

/*Featured Block Prices etc*/
.featuredInfo {
    margin: 14px 15px;
}
.prod .prices {
    float: left;
    width: 50%;
}
.prod .prices span {
  display: block;
}
.prod .gbpPrice {
  font-weight: 700;
}
.prod .dollarPrice {
  font-size: 13px;
}
.prod .link {
    width: 50%;
    float: right;
    text-align: right;
}
.prod .link a:hover {
  color: #d8d0ed;
}
/*Bestseller Flash*/
.prod .bestSeller {
    position: absolute;
    top: -10px;
    float: none;
    width: 60px;
    left: 20px;
}

/********************** RSN Links *********************/
.homepageLinkContainer { 
  padding: 2rem;
  width: 100%;
  text-align: center; 
}

@media only screen and (min-width: 700px) {
  .homepageLinkContainer {
    float: left; 
    width:50%; 
    max-width: 90%; 
  }
}

/********************** Homepage Signup *********************/
.homepageSignup {
    display: grid;
    grid-template-columns: 1fr;
    grid-gap: 0;
    margin: 2%;
}
.homepageSignup .signupLeft {
  background: #5a1580;
  padding: 10%;
  text-align: center;
  display: grid;
  align-items:center;
}

.homepageSignup #customForm {
  background: #d8d0ed;
  padding: 10%;
  height: 100%;
  display: flex;
  flex-direction: column;
  justify-content: center;
}
.signupLeft p, .signupLeft h2 {
  color: white;
}
.signupLeft h2 {
  font-family: Lato !important;
  font-size: 26px;
}
.signupLeft p {
  font-size: 16px;
  letter-spacing: 0.05em;
  font-weight: 300;
}

.homepageSignup input[type="email"] {
    margin-top: 10px;
  width: 100%;
}
.signupChannel {
    display: grid;
    grid-template-columns: 1fr 9fr;
    margin-top: 5px;
}
.signupFormTerms {
  font-size: 12px;
}

@media only screen and (min-width: 700px) {
  .homepageSignup {
    grid-template-columns: 1fr 1fr;
  }
}

@media only screen and (min-width: 1000px) {
  .signupLeft h2 {
    font-size: calc( 10px + 2vw );
  }
  .signupLeft p {
    font-size: calc( 8px + 1.2vw );
  }
}

/********************* STATIC PAGES START ********************/
/********************* ABOUT US ********************/
section.aboutUsGrid {
  max-width: 1400px;
  display: grid;
  margin-left: auto;
  margin-right: auto;
  grid-gap: 2rem;
  padding: 1rem;
}

section.aboutUsGrid .aboutUsGridItem h2 {
  padding-top: 0;
}

@media only screen and (min-width: 900px) {
  section.aboutUsGrid {
    grid-template-columns: 1fr 1fr;
  }

  section.aboutUsGrid #txtReverse {
    grid-row: 2;
    grid-column: 2;
  }

  section.aboutUsGrid #imgReverse {
    grid-row: 2;
    grid-column: 1;
  }
}

@media only screen and (min-width: 1200px) {
  div.aboutUsGridItem {
    align-self: center;
  }
}

/********************* FREQUENTLY ASKED QUESTIONS (FAQ) ********************/

button.accordion {
  background-color: #f0f2f6;
  display: flex;
  width: 100%;
  text-align: left;
  margin: 16px 0 0 0;
  border: none;
  font-size: 1.25rem;
  align-items: center;
  justify-content: space-between;
  padding: 0.5rem;
  font-weight: 400;
  color: #262626;
  font-family: Droid serif;
}

button.accordion:after  {
  content:"\203A";
  float: right;
  transform: rotate(90deg);
  font-size: 1.25rem;
  margin: 0.5rem;
}

button.accordion.active:after  {
  transform: rotate(270deg);
}

.accordion + .accordion-panel {
  background-color: #f0f2f6;
  max-height: 0;
  overflow: hidden;
  transition: all 0.5s ease;
}

.accordion.active + .accordion-panel {
  max-height: 800px;
  padding-top: 1rem;
}

.accordion + .accordion-panel p,.accordion + .accordion-panel h3 {
  margin-left: 0.5rem;
  margin-right: 0.5rem;
}


/********************* SUPPORT PAGE ********************/

form#zsWebToCase_14285000000188280 input[type=text],form#zsWebToCase_14285000000188280 textarea {
  border: 1px solid #757575;
  color: #262626;
  font-weight: 300;
  font-size: 1rem;
  font-family: Lato;
}

form#zsWebToCase_14285000000188280 input[type=text] {
  width: 300px;
}

form#zsWebToCase_14285000000188280 input[type=text]:active,form#zsWebToCase_14285000000188280 input[type=text]:focus
,form#zsWebToCase_14285000000188280 textarea:active,form#zsWebToCase_14285000000188280 textarea:focus {
  border: 2px solid #5a1580;
}

/************Delivery Page*******************/
.narrowPara {
  width: 100%;
  max-width: 700px;
}

/**********Hide RRP in catalog page*************/
.catalog-item .catalog-grid-item__suggested-price {
  display: none;
}
@media only screen and (max-width: 768px) {
  .catalog .p-centered {
    margin: 1rem;
  }
}

/*********Learner Dashboard*********/

.dashboardTitle {
  text-align: center;
}
.dashboardTitle .ember-view {
  background: #d8d0ed;
}
.dashboardTitle .widget__title,.dashboardTitle .ember-view.editor-content p {
  color: #333;
  font-family: Lato !important;
  padding: 10px 0 0 0;
}
.header--dashboard .company__school-name {
  display: none;
}
.header--dashboard .header__inner {
    text-align: left;
}
.header--dashboard .header__inner:after {
  content: "LEARNER DASHBOARD";
  text-align: center;
  width: 100%;
  display: block;
  font-size:24px;
  color: #5a1580;
}

@media only screen and (min-width: 768px) {
  .header--dashboard .header__inner:after {
    position: absolute;
    right: 50%;
    top: 50%;
    transform: translate(50%, 50%);
  }
}
@media only screen and (min-width: 1350px) {
   .header--dashboard .header__inner:after {
     font-size: 32px;
     top: 40%;
   }
}
/********************* STATIC PAGES END ********************/

/********************* COURSE DETAIL PAGE*******************/
/*** TOP AREA START***/
/***Change collection to course***/
h5.enroll__title:before {content: "Enroll in this Course Today";}
h5.enroll__title span, .collection__courses span {display: none;}
.collection__courses:before{content: "What's Included?";}
.catalog-grid-item__source strong {display: none;}

/*Reverse the Main Content and Sidebar*/
div.course__detail__container {
  display: flex;
  flex-direction: column-reverse;
  border: none;
  max-width: 100%;
}

.course__detail__container .course__detail__content,.course__detail__container .course__detail__sidebar {
  width: 100%;
  margin-bottom: 0;
  padding: 0 !important;
}

.course__detail__container .course__detail__description {
  padding: 0 !important;
  background: none !important;
}

.course__detail__container .btn.btn--primary {
  float: none;
  padding: 10px 40px;
}

.sidebarTitle,.course__detail__container .sidebarImage,.course__detail__container .row,.course__detail__container .course__includes,.sidebarTitle div,.sidebarImage div,.course__detail__container .h5.course__includes__title {
  margin: 0;
  padding: 0 !important;
}

.course__detail__container .enroll__title,.course__detail__container hr {
  display: none;
}

.course__detail__container .course__detail__header,.course__detail__container .collection__courses {
  display: none;
}

.course__detail__container .widget__subtitle,.course__detail__container .widget__title {
  text-align: left;
}

/*Change RRP to Estimated Dollar Price*/
.course__detail__container .srp:before {
  content:"$";
  font-size: 1.1rem;
}
.course__detail__container .srp:after {
  content:" (estimated)";
  font-size: 1.1rem;
}
.course__detail__container .srp .strikethrough {
  /*display: inline-block;*/
  text-decoration: none;
  font-size: 1.1rem;
}
.course__detail__container .srp span:first-of-type {
  display: none;
}
.course__detail__container .srp .strikethrough:first-letter {
  font-size: 0;
}
.course__detail__container .srp {
  font-size: 1.5rem;
}

/*Hide Normal Image*/
.course__detail__content .course__detail__asset {
  display: none;
}

/*New images and Thumbs*/
.imageThumbs .thumbCont {
  display: flex;
  justify-content: space-between;
  margin-top: 0.75rem;
}
.discount-group .imageThumbs .thumbCont img {
  max-height: 100%;
  max-width: 20%;
  cursor: pointer;
}
.discount-group .heroImages .heroImg {
  width: 100%;
}
.discount-group .imageThumbs img.active {
  border: 2px solid  #5a1580;
}
.discount-group .imageThumbs img:focus,.imageThumbs img:focus-visible {
  border: 2px solid #5a1580;
  outline: none;
}
.discount-group .imageThumbs img:hover {
  border: 2px solid #5a1580;
}
.discount-group .heroImg.hdn {
  display: none;
}

.discount-group .enroll__secondary-actions button.btn.btn--small.btn--default.btn--link {
  padding: 10px 40px !important;
  border: 2px solid #5A1580;
  margin-top: 10px;
  border-radius: 2px;
  color: #5A1580;
  width: 100%;
  text-align: center;
}

.discount-group .enroll__secondary-actions button.btn.btn--small.btn--default.btn--link:hover {
  background: #5a1580 !important;
  color: white;
}

/***Grid Layout***/
.course__detail__container .course__detail__sidebar .layout__content--sidebar {
  display: grid;
  grid-template-columns: 1fr;
  grid-template-areas: "video" "description" "images" "buy";
  grid-gap: 2rem;
  max-width: 1400px;
  margin: auto;
  padding-left: 1rem;
  padding-right: 1rem;
  padding-bottom: 2rem;
  margin-bottom: 1.5rem;
}

.layout__content--sidebar .widget--html_standard:first-of-type {
  grid-area: video;
}

.layout__content--sidebar .widget--html_standard:nth-of-type(2) {
  grid-area: description;
}

.layout__content--sidebar .widget--html_standard:last-of-type {
  grid-area: images;
}

.widget--discount-group-purchase {
  grid-area: buy;
  align-self: end;
}

@media only screen and (min-width: 765px) {
  .course__detail__container .enroll__price {
    width: 100%;
    float: none;
  }
  .discount-group .enroll__secondary-actions button.btn.btn--small.btn--default.btn--link {
      width: auto;
  }
}

@media only screen and (min-width: 1026px) {
  .discount-group .course__detail__container .course__detail__sidebar .layout__content--sidebar {
    grid-template-columns: repeat(2, 1fr);
    grid-template-areas: "video video" "description images" "buy images";
  }
}
/***TOP AREA END***/
/***PRODUCT TABS START***/
.discount-group .tabs {
  padding-left: 1rem;
  padding-right: 1rem;
  border-bottom: none;
}

.productDescription .tabLabel {
  display: none;
}
.productDescription .mobLabel {
  display: block;
  margin: 2px 0;
  padding-left: 5px;
  height: 50px;
  line-height: 50px;
}
.productDescription .mobLabel,.productDescription .tabLabel {
  background: #5A1580;
  cursor: pointer;
  color: white;
  font-family: Droid Serif;
  font-size: 18px;
}

.discount-group .mobLabel h2 {
  margin: 0;
  color: white;
  display: inline;
  font-weight: 400;
  font-size: 1.5rem;
}

.productDescription .tabContent {
  display: none;
  padding: 5px;
}
.productDescription .tabContent#kitContent {
  columns: 1;
}
.discount-group .course__detail__content {
  margin-top: 24px;
  max-width: 1400px;
  margin-left: auto;
  margin-right: auto;
}
.discount-group .mobLabel.open h2 {
    color: #5A1580;
}
.discount-group .tabLabel h2 {
  margin: 0;
  display: inline-block;
  color: white;
  font-size: 1.125rem;
  font-weight: 400;
}
.discount-group .tabLabel.open h2 {
  color: #5A1580;
}
.discount-group .tabLabel.open {
  background: #F0F0FA;
}
.discount-group .tabLabel.open:after {
    content: " ";
    position: absolute;
    width: 50%;
    top: 60px;
    left: 25%;
    border-bottom: 5px solid #d8d0ed;
}
.videoContainer {
  position: relative;
  width: 100%;
  height: 0;
  padding-bottom: 56.25%;
}
.video {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
}
.col2 {
  width: 100%;
}
.col2 img {
  width: 100%;
  height: 100%;
}

/*Reviews Tab*/
.review .rating {
  color: #5A1580;
  font-size: 24px;
}
.review hr {
  display: block !important;
  border-bottom: 1px solid #5A1580 !important;
}

@media only screen and (max-width: 767px) {
  .productDescription .open + .tabContent {
    display: block;
  }
  .productDescription .mobLabel:after {
    float: right;
    padding-right: 10px;
    font-size: 20px;
    content: "\002B ";
  }
  .productDescription .mobLabel.open:after {
    float: right;
    padding-right: 10px;
    font-size: 20px;
    content: "\2212";
  }
  .productDescription .tabSwitch:checked + .tabLabel, .productDescription .mobLabel.open {
    background: #F0F0FA;
    color: #5A1580;
}
}
@media only screen and (min-width: 768px) {
  .col2 {
    width: 50%;
    float: left;
  }
  .productDescription .mobLabel {
    display: none;
  }
  .productDescription .tabLabel {
    display: unset;
    float: left;
    width: calc(25% - 3px);
    margin: 0 2px;
    text-align: center;
    height: 80px;
    line-height: 80px;
    position: relative;
  }
  .productDescription .tabLabel:first-of-type {
    margin-left: 0;
  }
  .productDescription .tabLabel.last {
    margin-right: 0;
  }
  .productDescription .tabContent {background: #F0F0FA;}
  .productDescription .tabContent#aboutContent {columns: 2;}
  .discount-group .productDescription .tabContent {padding: 2rem;}
  .discount-group .productDescription .tabContent.open {display: block;}
}
@media only screen and (min-width: 1000px) {
  .productDescription .tabContent#aboutContent {
    columns: 3;
  }
}

/*****Coming Soon Page******/
.page .comingSoonHeader {
  display: grid;
  grid-template-columns: 1fr;
  padding: 20px 10px;
    grid-gap: 20px;
}
@media only screen and (max-width: 768px) {
.page .comingSoonInfo .row {
    display: flex;
    flex-direction: column-reverse;
}
}

@media only screen and (min-width: 1026px) {
.page .comingSoonHeader {
  grid-template-columns: 1fr 1fr;
  padding: 50px 0px;

}
}
