.large-content-text {
    font-size: 17px;
}

.outline .chapter-title {
    font-size: 18px;
}


.courses-page h1,
.course-details-page h1 {
    text-align: center;
    padding-bottom: 10px;
}

.courses-page h1 {
    padding-bottom: 0px;
    /*margin-bottom: 0px;*/
    padding-left: 30px;
}

.courses-page h2 {
    text-align: center;
    color: #2aabd2;
}

.course-in-list h3 {
    font-size: 16px;
    margin-top: 5px;
    margin-bottom: 5px;
    font-weight: 500;
    color: white;
    min-height: 38px;
}


.course-list {
    text-align: center;
}

.course-in-list img {
    width: 250px;
    margin-right: 20px;
    border-radius: 5px;
}

.course-in-list {
    border: 2px solid #333;
    border-radius: 5px;
    padding: 5px;
    margin: 5px 5px 15px;
    background-color: #282828;
    font-size: 18px;
    width: 275px;
    min-height: 200px;
    vertical-align: top;
    display: inline-block;
    text-align: center;
}

@media screen and (min-width: 0px) and (max-width: 800px) {
    .course-in-list {
        /*border: 2px solid white;*/
        padding: 3px;
        margin: 5px;
        width: 240px;
        font-size: 12px;
        min-height: 160px;
    }

    .course-in-list img {
        width: 150px;
    }

    .course-in-list h3 {
        font-size: 13px;
        font-weight: normal;
    }
}

@media screen and (min-width: 1050px) and (max-width: 1199px) {
    .course-in-list {
        /*border: 2px solid green;*/
        padding: 5px;
        margin: 5px;
        width: 280px;
    }
}

@media screen and (min-width: 1200px) {
    .course-in-list {
        /*border: 2px solid yellow;*/
        padding: 10px;
        margin: 15px;
        width: 300px;
    }
}

.course-in-list .course-title {
    min-height: 45px;
}

.course-in-list .label-coming-soon {
    text-align: center;
    white-space: nowrap;
    margin-top: 5px;
    display: inline-block;
}

.course-in-list .image-container {
    width: 250px;
    /*margin-right: 20px;*/
    margin-bottom: 10px;
    border-radius: 5px;
    display: inline-block;
}

.bundle-in-list .price_and_duration {
    margin-top: 20px;
    text-align: center;
    color: #2aabd2;

    font-size: 16px;
    font-weight: 500;
}

.bundle-in-list a,
.course-in-list a {
    color: #ddd;
}

.bundle-in-list a:hover,
.course-in-list a:hover {
    text-decoration: none;
}

.bundle-list {
    text-align: center;
}

.bundle-in-list {
    border: 2px solid #383838;
    border-radius: 5px;
    padding: 20px;
    margin: 20px;
    background-color: #333;
    font-size: 18px;
    max-width: 600px;
    display: inline-block;
}

.bundle-in-list .bundle-desc {
    text-align: left;
    font-size: 14px;
}

.bundle-in-list .bundle-desc a {
    color: #2aabd2;
}

.bundle-in-list img {
    width: 250px;
    float: left;
    margin-right: 20px;
    border-radius: 5px;
    vertical-align: middle;
}

.bundle-in-list h2,
.bundle-in-list h3 {
    margin-top: -5px;
    font-size: 24px;
    text-align: center;
}

.chapter {
    background: #191919;
}

.outline .lecture {
    background: transparent;
}

.outline .table > tbody > tr.lecture > td {
    background: transparent;
}

.player .chapter {
    background-color: transparent;
}


.explore-page .chapter {
    background: #eee;
}

.explore-page .outline .chapter-title a,
.explore-page .outline .chapter-title span {
    color: #3b6d85;
}

.outline .table > tbody > tr.chapter > td {
    padding: 10px;
    border-top: 1px solid #333;
}

.outline .table > tbody > tr.chapter:hover > td {
    background-color: #333;
}

.explore-page .outline .table > tbody > tr.chapter > td {
    border-bottom: 2px solid #ddd;
}

.chapter h3 a {
    font-size: 28px;
    color: white;
    font-weight: bold;
}

.chapter h4 a {
    font-weight: normal;
}

.courses-page .summary {
    font-size: 24px;
    text-align: center;
    margin-bottom: 20px;
}

.course-list .revealed-description {
    display: none;
}

.price_and_duration {
    /*margin-left: 130px;*/
    text-align: center;
    /* font-weight: inherit from parent (Bulma version) */
    font-size: 13px;
    /*margin-bottom: 10px;*/
    color: #99CFE8;
}

.buy-cta .price_and_duration,
.explore-page.course-details-page .buy-cta .price_and_duration {
    color: black;
}

.course-details-page .buy-cta .price_and_duration {
    color: white;
}

.price_and_duration a {
    color: #337ab7;
}


.course-list .price,
.course-list .free-course {
    font-size: 13px;
}

.price_and_duration.owner .label,
.price_and_duration.owner .tag {
    font-size: 85%;
    margin-left: 5px;
    margin-right: 5px;
    margin-top: 0px;
}

.course-image-full {
    text-align: center;
    margin-bottom: 10px;
}

.course-image-full img {
    width: 500px;
    border-radius: 5px;
}

@media (max-width: 600px) {
    .course-image-full img {
        width: 300px;
        border-radius: 5px;
    }
}

.buy-cta {
    text-align: center;
    /*margin-left: 220px;*/
}

.main-text .buy-cta a {
    color: white;
}

/*Just a bit to bump the version*/

.outline h3, .outline h4 {
    font-family: "Work Sans", "Helvetica Neue", Helvetica, Arial, sans-serif;
    font-weight: 500;
}

.outline .table > tbody > tr.lecture:hover > td {
    background-color: #333;
}

.outline .lecture-title-column a,
.outline .lecture-title-column > span {
    margin-left: 30px;
    display: block;
    padding: 3px;
    /*color: #3b6d85;*/
    color: #5BC0DE;
}

.modal .modal-header,
.buy-course-dialog .modal-header {
    background-color: #555;
    text-align: center;
    border-top-left-radius: 5px;
    border-top-right-radius: 5px;
}

.stripe-button-el {
    padding: 20px;
!important;

}

/* ************* buy_dialog *************** */
#buy_dialog {
}

.modal .modal-header,
.modal .modal-footer,
#buy_dialog .modal-header,
#buy_dialog .modal-footer {
    background-color: #ddd;
    color: #191919;
}

.modal .modal-header,
#buy_dialog .modal-header {
    border-top-left-radius: 5px;
    border-top-right-radius: 5px;
}

.modal .modal-header h4.modal-title,
#buy_dialog .modal-header h4.modal-title {
    font-size: 24px;
}

.modal .modal-footer,
#buy_dialog .modal-footer {
    border-bottom-left-radius: 5px;
    border-bottom-right-radius: 5px;
}

.modal .modal-body,
#buy_dialog .modal-body {
    color: #ddd;
    background: #222;
    font-weight: normal;
    font-size: 18px;
}

.modal .modal-body .top-cta,
#buy_dialog .modal-body .top-cta {
    text-align: center;
}

.modal .modal-body .top-cta .btn-container,
#buy_dialog .modal-body .top-cta .btn-container {
    display: inline-block;
    padding: 10px;
}

.modal .body-txt,
#buy_dialog .body-txt {
    max-width: 550px;
    margin-right: auto;
    margin-left: auto;
}

.player .modal .body-txt {
    max-width: 90%;
}

.modal .body-txt div,
#buy_dialog .body-txt div {
    margin-bottom: 1em;
}

.table.borderless td, .table.borderless th {
    border: none;
}

.outline .chapter-title a {
    color: white;
}


.outline .chapter-title i {
    margin-right: 7px;
}

.outline .watched,
.outline .watched .chapter-title a {
    color: #999;
}

.outline .chapter .time-column {
    font-size: 18px;
}

.outline .table {
    margin-bottom: 0px;
    width: 100%;
    background: transparent;
}

.outline .table > tbody {
    background: transparent;
}

.outline .table > tbody > tr > td {
    vertical-align: middle;
    padding: 0px;
    background: transparent;
}

.outline .table > tbody > tr > td.time-column {
    vertical-align: middle;
    text-align: right;
    white-space: nowrap;
    padding-right: 10px;
    color: #aaa;
}

.outline .watched .time-column {
    color: #999;
}

.outline .table > tbody > tr > td.expando-column {
    text-align: right;
    padding: 0px;
    cursor: pointer;
}

.outline .table > tbody > tr > td.expando-column .expand-up {
    color: white;
}

.outline .table > tbody > tr > td.expando-column .expand-down {
    color: #999;
}

.outline {
    /* border-top: 1px solid #666; */
    margin-top: 0px;
    padding-top: 0px;
}

.course-details-page .github {
    text-align: center;
}

.course-details-page .office_hours {
    text-align: center;
}

.well.office_hours {
    margin-top: 20px;
    background-color: #1a1a1a;
    border: 1px solid #2a2a2a;
    padding-top: 5px;
    color: #ccc;
    border-radius: 10px;
    font-size: 16px;
    max-width: 500px;
    margin-right: auto;
    margin-left: auto;
}

.well.office_hours h2 {
    font-size: 18px;
}

.course-details-page.explore-page .github {
    text-align: left;
    margin-bottom: 30px;
    font-weight: bold;
}

.transcript-listing .transcript-text {
    font-size: 18px;
    padding-left: 40px;
    padding-right: 40px;
    line-height: 1.5em;
}

.transcript-listing .transcript-text .transcript-line {
    margin-bottom: 15px;
}

.transcript-from-course-btn {
    float: right;
}

.outline .lecture-title-column a
.outline .lecture-title-column > span {
    border-radius: 5px;
    padding-left: 5px;
}

.main-text .lecture.watched a.lecture-link,
.main-text .transcript-column.watched a {
    color: #aaa;
    /*text-decoration: line-through;*/
}

.main-text .transcript-column {
    text-align: right;
    width: 50px;
    padding-right: 0;
}

.transcript-column i {
    vertical-align: middle;
}

.transcript-column a {
    color: #aaa;
}

.transcript-column.watched a {
    color: #999;
}

.main-text .time-column {
    text-align: right;
    padding-right: 10px;
}

.outline .lecture .time-column {
    color: #aaa;
}

.outline .lecture.watched .time-column {
    color: #999;
}

.outline .lecture .lecture-duration {
    color: #aaa;
}

.outline .lecture.watched .lecture-duration {
    color: #999;
}

.transcripts h1 {
    font-size: 28px;
    font-weight: normal;
}

.transcripts .price_and_duration .btn,
.transcripts .price_and_duration .button {
    margin: 10px;
}

.transcript-listing .tx_text {
    color: #ddd;
}

.transcript-listing .tx_time {
    color: #444;
    margin-right: 5px;
}

.main-text .course-actions a.btn,
.main-text .course-actions a.button {
    color: black;
    text-shadow: 0px 0px 2px rgba(255, 255, 255, 1);
    font-weight: bold;
    margin-bottom: 5px;
}

/* Override default styling for colored buttons */
.main-text .course-actions a.button.is-info-blue,
.main-text .course-actions a.button.is-success-green {
    color: #fff !important;
    text-shadow: 0 1px 1px rgba(0, 0, 0, 0.5);
}

.course-actions {
    text-align: center;
    padding: 20px;
    padding-bottom: 0px;
}

.courses-page.full-page-content {
    max-width: 2000px;
}

/* Search form styling for course details page */
form#search_form {
    display: flex;
    justify-content: center;
    margin-top: 10px;
    margin-bottom: 10px;
    width: 75%;
    max-width: 600px;
    margin-left: auto;
    margin-right: auto;
}

form#search_form .input {
    flex: 1;
    border-top-right-radius: 0;
    border-bottom-right-radius: 0;
}

form#search_form .button {
    border-top-left-radius: 0;
    border-bottom-left-radius: 0;
}

.course-list .free-course {
    color: lightgreen;
}


.not-for-sale {
    font-weight: bold;
    font-size: 1.5em;
    color: yellow;
}


.active-bundle-note {
    font-size: 15px;
    color: #d27e3c;
    margin-top: 10px;
    max-width: 620px;
    margin-left: auto;
    margin-right: auto;
}

.main-text .buy-cta .active-bundle-note a {
    color: #2aabd2;
}

.carbon-offset {
    /*margin-top: 25px;*/
    color: grey;
    font-size: 11px;
    text-align: center;
}

.carbon-offset img {
    height: 20px;
    opacity: .6;
    vertical-align: middle;
    margin-top: -5px;
}

.carbon-offset span {
    display: inline-block;
}


.authors-of-course {
    text-align: center;
    font-size: 11px;
}

.course-author {
    display: inline-block;
    margin-left: 10px;
    margin-right: 10px;
    text-align: center;

}

.course-author img {
    max-width: 75px;
}

.courses-page hr {
    margin-top: 10px;
    margin-bottom: 5px;
    border-top: 1px solid #444;
}

.courses-page .release-date {
    color: yellow;
    font-size: 12px;
}

.courses-page .recent-courses .course-in-list {
    background: #1b6d85;
    border: none;
}

.courses-page .subscribe-to-courses-rss {
    /*text-align: center;*/
    /*margin-bottom: 0px;*/
    /*float: right;*/
    display: inline-block;
    padding-top: 5px;
}

.courses-page .subscribe-to-courses-rss a {
    color: orange;
}


/* *********************************************
* Course tags
*/

.courses-page .topic-tags {

    margin-top: 30px;
    margin-bottom: 20px;
    /*border: 1px solid gray;*/
    /*border-radius: 5px;*/
    /*background-color: #373737;*/
    /*padding: 10px;*/

    .btn.tag {
        background-color: transparent;
        border: 1px solid #aaa;
        margin-top: 5px;
        margin-bottom: 5px;
        font-size: 12px;
        cursor: pointer;
    }

    .btn.tag:hover {
        background-color: #1b6d85;
        color: white;
    }

    .btn.tag.selected {
        background-color: orange;
        border-color: #976200;
        color: white;
        font-weight: bold;
    }

    .btn.tag.selected:hover {
        background-color: #d38a00;
    }

    .btn.tag.highlight-green {
        background-color: #187e14;
        border-color: #21a51c;
        color: #fff;
        font-weight: bold;
    }

    .btn.tag.highlight-green:hover {
        background-color: #115e0e;
    }

    .btn.tag.highlight-white {
        background-color: #eee;
        border-color: #aaa;
        color: #333;
        font-weight: bold;
    }

    .btn.tag.highlight-white:hover {
        background-color: #ddd;
    }
}

/* *********************************************
* End of Course tags ^^^^^^^^^^^^^^
*/


.course-image-full iframe, .course-image-full img, .course-image-full video {
    width: 640px;
    /*height: 360px;*/
    border-radius: 5px;
}

@media (max-width: 750px) {
    .course-image-full iframe, .course-image-full img, .course-image-full video {
        width: 500px;
        height: 282px;
    }
}

@media (max-width: 600px) {
    .course-image-full iframe, .course-image-full img, .course-image-full video {
        width: 300px;
        height: 169px;
    }
}

@media (max-width: 400px) {
    .course-image-full iframe, .course-image-full img, .course-image-full video {
        width: 150px;
        height: 85px;
    }
}

a.transcript-action {
    cursor: pointer;
}

a.transcript-action span {
    color: #aaa;
}

.inline-transcript {
    padding: 10px;
    padding-left: 60px;
    font-size: 12px;
    color: #222;
    line-height: 1.5em;
}

/* Remove hover effect from expanded transcript rows */
.table tbody tr:has(.inline-transcript):hover td,
.table tbody tr:has(.inline-transcript):hover th {
    background-color: transparent !important;
}

.explore-page .main-text a.tx-title {
    font-weight: bold;
    color: #222;
    margin-bottom: 10px;
    display: inline-block;
    cursor: pointer;
}

.chapter-title h3, .explore-page .lecture h4 {
    padding: 0;
    margin: 0;
    font-weight: 600;
    font-family: "Inter", "IBM Plex Sans", tahoma, serif;
}

.chapter-title h3 {
    font-size: 18px;
}

.explore-page .lecture h4 {
    font-size: 16px;
    display: block;
    padding: 3px;
}

/* ************ Light-themed modals for explore/course pages ********************* */
/* Need to Login Modal - white/light theme */
.explore-page #need-to-login.modal .modal-background,
#need-to-login.modal .modal-background {
    background-color: rgba(0, 0, 0, 0.7) !important;
}

.explore-page #need-to-login.modal .modal-card,
#need-to-login.modal .modal-card {
    background-color: white !important;
    max-width: 420px !important;
    border-radius: 8px !important;
    box-shadow: 0 4px 20px rgba(0, 0, 0, 0.3) !important;
}

.explore-page #need-to-login.modal .modal-card-head,
#need-to-login.modal .modal-card-head {
    background-color: #f5f5f5 !important;
    border-bottom: 1px solid #ddd !important;
    padding: 12px 20px !important;
}

.explore-page #need-to-login.modal .modal-card-title,
#need-to-login.modal .modal-card-title {
    color: #333 !important;
    font-size: 18px !important;
    font-weight: 600 !important;
}

.explore-page #need-to-login.modal .modal-card-head .delete,
#need-to-login.modal .modal-card-head .delete {
    background-color: #999 !important;
}

.explore-page #need-to-login.modal .modal-card-body,
#need-to-login.modal .modal-card-body {
    background-color: white !important;
    padding: 20px !important;
    color: #444 !important;
    font-size: 14px !important;
    line-height: 1.5 !important;
}

.explore-page #need-to-login.modal .modal-card-body div,
.explore-page #need-to-login.modal .modal-card-body span,
.explore-page #need-to-login.modal .modal-card-body p,
#need-to-login.modal .modal-card-body div,
#need-to-login.modal .modal-card-body span,
#need-to-login.modal .modal-card-body p {
    color: #444 !important;
    font-weight: normal !important;
}

.explore-page #need-to-login.modal .dialog-content,
#need-to-login.modal .dialog-content {
    text-align: center !important;
}

.explore-page #need-to-login.modal .modal-card-body .button,
#need-to-login.modal .modal-card-body .button {
    color: white !important;
    margin: 5px !important;
    font-size: 14px !important;
}

/* Give as Gift Modal - white/light theme */
.explore-page #give-as-gift.modal .modal-background,
#give-as-gift.modal .modal-background {
    background-color: rgba(0, 0, 0, 0.7) !important;
}

.explore-page #give-as-gift.modal .modal-card,
#give-as-gift.modal .modal-card {
    background-color: white !important;
    max-width: 520px !important;
    border-radius: 8px !important;
    box-shadow: 0 4px 20px rgba(0, 0, 0, 0.3) !important;
}

.explore-page #give-as-gift.modal .modal-card-head,
#give-as-gift.modal .modal-card-head {
    background-color: #f5f5f5 !important;
    border-bottom: 1px solid #ddd !important;
    padding: 12px 20px !important;
}

.explore-page #give-as-gift.modal .modal-card-title,
#give-as-gift.modal .modal-card-title {
    color: #333 !important;
    font-size: 18px !important;
    font-weight: 600 !important;
}

.explore-page #give-as-gift.modal .modal-card-head .delete,
#give-as-gift.modal .modal-card-head .delete {
    background-color: #999 !important;
}

.explore-page #give-as-gift.modal .modal-card-body,
#give-as-gift.modal .modal-card-body {
    background-color: white !important;
    padding: 20px !important;
}

.explore-page #give-as-gift.modal .modal-card-body,
.explore-page #give-as-gift.modal .modal-card-body div,
.explore-page #give-as-gift.modal .modal-card-body span,
.explore-page #give-as-gift.modal .modal-card-body p,
.explore-page #give-as-gift.modal .modal-card-body em,
#give-as-gift.modal .modal-card-body,
#give-as-gift.modal .modal-card-body div,
#give-as-gift.modal .modal-card-body span,
#give-as-gift.modal .modal-card-body p,
#give-as-gift.modal .modal-card-body em {
    color: #444 !important;
    font-weight: normal !important;
    font-size: 14px !important;
}

.explore-page #give-as-gift.modal .modal-card-body h2,
#give-as-gift.modal .modal-card-body h2 {
    color: #333 !important;
    font-size: 16px !important;
    font-weight: 600 !important;
    margin-bottom: 15px !important;
    text-align: center !important;
}

.explore-page #give-as-gift.modal .top-cta,
#give-as-gift.modal .top-cta {
    padding: 0 !important;
}

.explore-page #give-as-gift.modal .step-container,
#give-as-gift.modal .step-container {
    text-align: left !important;
    margin: 12px 0 !important;
    padding: 12px 15px !important;
    background-color: #f8f9fa !important;
    border-radius: 6px !important;
    border-left: 3px solid #5bc0de !important;
}

.explore-page #give-as-gift.modal .step-container .step,
#give-as-gift.modal .step-container .step {
    color: #337ab7 !important;
    font-size: 15px !important;
    font-weight: 600 !important;
    display: block !important;
    margin-bottom: 6px !important;
}

.explore-page #give-as-gift.modal .step-container em,
#give-as-gift.modal .step-container em {
    font-style: italic !important;
    color: #d9534f !important;
    font-weight: 500 !important;
}

.explore-page #give-as-gift.modal .modal-card-body .button,
#give-as-gift.modal .modal-card-body .button {
    color: white !important;
    margin-top: 8px !important;
    font-size: 13px !important;
}

.explore-page #give-as-gift.modal .modal-card-foot,
#give-as-gift.modal .modal-card-foot {
    background-color: #f5f5f5 !important;
    border-top: 1px solid #ddd !important;
    padding: 10px 20px !important;
}

.explore-page #give-as-gift.modal .modal-card-foot .button,
#give-as-gift.modal .modal-card-foot .button {
    font-size: 13px !important;
    color: #333 !important;
}

.explore-page #give-as-gift.modal .modal-card-foot .button.is-info-blue,
#give-as-gift.modal .modal-card-foot .button.is-info-blue {
    color: #fff !important;
}

.contact-info {
    font-size: 16px;
}

.contact-info a {
    color: #337ab7;
}

.contact-info a:hover {
    color: #23527c;
}