/* login */

.login {
    margin-top:1em;
    text-align:center;
}

.login #loginform {
    max-width: 400px;
    margin: 0 auto;
    text-align:center;
    background: var(--color-white);
    box-shadow: var(--box-shadow);
    padding: 0 20px;
    height:0;
    overflow:hidden;
    transition:height .3s ease-in-out, padding .3s ease-in-out;
}
.login #loginform.open {
    padding: 20px;
}
.login #loginform label {
    text-align:left;
    width:100%;
    display: inline-block;
}


/* archive */

.corsi-online-archive > .category {
    box-shadow: var(--box-shadow);
    padding: 1em 2em;
    overflow: hidden;
    height: 5.5em;
    margin-bottom: 2em;
    transition: height .3s ease-in-out;
}
.corsi-online-archive > .category.always-open {
    height:auto;
}
.corsi-online-archive .wp-block-column {
    padding: 1em 2em;
}
.corsi-online-archive h2,
.corsi-online-docenti h2 {
    font-size:2rem;
    text-align: center;
    border-bottom: 1px solid var(--color-light-grey);
    padding: 2em 0 1em;
}
.corsi-online-archive h3 {
    text-align: center;
    border-bottom: 1px solid var(--color-light-grey);
    position: sticky;
    top: 0;
    background: var(--color-white);
    padding: 1em 0;
    z-index:10;
    cursor:pointer;
}
.corsi-online-archive h3 .count {
    font-weight: normal;
}
.corsi-online-archive .category h3 .icon {
    transition:transform .3s ease-in-out;
}
.corsi-online-archive .category.open h3 .icon {
    transform:rotate(180deg);
}
.corsi-online-archive ul {
    list-style:none;
    padding:0;
    margin:0;
}
.corsi-online-archive ul li {
    margin-bottom:3em;
    position:relative;
}
a.corsi-online-preview {
    display: block;
    color: var(--color-black);
    text-decoration: none;
    position:relative;
}
.corsi-online-preview .author {
    color: #5876CC;
    margin: .5em 0;
    display:inline-block;
}
.corsi-online-preview .title {
    font-family:'Raleway';
    font-size:1.2em;
    margin-bottom:.3em;
    font-weight:bold;
    color: #5876CC;
    width: 80%;
    line-height: 1.2;
}
.corsi-online-preview:hover .author,
.corsi-online-preview:hover .title {
    color:#10917D;
}
.corsi-online-preview .info {
    color: #12695B;
    margin: .5em 0;
}
.corsi-online-preview:hover .info {
    color: #2CB98F;
}
.corsi-online-preview .description {
    margin-left:2em;
}
.corsi-online-preview .is-new {
    color:var(--color-white);
    background:#10917D;
    font-size:.9em;
    padding:.2em .8em;
    border-radius: 2px;
    display:inline-block;
	margin-left: 1em;
}
.corsi-online-preview .is-started {
    color:var(--color-white);
    background:#E2B500;
    font-size:.9em;
    padding:.2em .8em;
    border-radius: 2px;
    display:inline-block;
	margin-left: 1em;
}

.corsi-online-docenti {
    background: var(--color-xlight-grey);
    margin-top: 55px;
    box-shadow: -600px 0 0 0 var(--color-xlight-grey), 600px 0 0 0 var(--color-xlight-grey);
    padding: 0 0 50px;
}
.corsi-online-docenti .page-container {
    min-height:auto;
}
.corsi-online-docenti .author-preview {
    padding: 20px;
    border: 1px solid var(--color-light-grey);
    margin: 10px;
    border-radius: var(--border-radius);
    box-shadow: var(--box-shadow);
    height: calc(100% - 20px);
}



/* single page */

.corsi-title {
    text-align:center;
    max-width: 1000px;
    margin: 0 auto;
}
.corsi-title h1 {
    font-size: 4rem;
    margin: .5em 0;
}
.corsi-title .excerpt {
    font-size: 1.5rem;
    color: #5876CC;
}

.corsi-title .author {
    font-size:1.4em;
}
.corsi-title .author a {
    text-decoration:none;
}
.corsi-title .author img {
    border-radius: 4em;
    width: 3em;
    height: 3em;
    border: 4px solid var(--color-light-grey);
    margin-right: .4em;
    object-fit: cover;
}

.lessons {
    position:relative;
    margin:50px 0 20px 0;
    padding:30px 0;
    border-top:1px solid var(--color-light-grey);
    border-bottom:1px solid var(--color-light-grey);
    text-align: center;
    font-size: 1.1em;
}
.lessons::before,
.lessons::after {
    content: '';
    position: absolute;
    top: -2px;
    left: 30%;
    width: 40%;
    height: 3px;
    background: #5876CC;
}
.lessons::after {
    top:auto;
    bottom:-2px;
}

.duration {
    color:var(--color-grey);
    font-size:.8rem;
    margin:0 .5em;
    display:inline-block;
    white-space: nowrap;
}

.categories {
    margin-top: 10px;
    text-align:center;
}
.categories ul {
    margin:0;
    padding:0;
    list-style:none;
}
.categories ul li {
    display:inline-block;
    white-space: nowrap;
}

.membership-status {
    margin: 30px auto;
    font-size: 1.1em;
}
.membership-active {
    text-align: center;
    background: #FDCD09;
    padding: 1em;
}

.cta-subscribe {
    padding: 30px;
    text-align: center;
    background: #FDCD09;
}
.cta-subscribe .membership-stats {
    font-weight: bold;
    font-size: 1.2em;
    display: inline-block;
    padding: .5em;
    margin: 0 auto 1em auto;
}
.cta-subscribe .plan {
    margin: 2em 0 0 0;
    padding:20px;
    box-shadow:var(--box-shadow);
    transition:background-color .3s ease-in-out;
    border-radius:var(--border-radius);
    border: 1px solid var(--color-white);
}
.cta-subscribe .plan:hover {
    background:var(--color-white);
}
.cta-subscribe h3 {
    margin: 0;
}
.cta-subscribe.horizontal h2 {
    font-size: 2rem;
    margin-bottom: 0;
}
.cta-subscribe.horizontal .cta-content {
    display: flex;
    justify-content: space-around;
    align-items: center;
}
.cta-subscribe .membership-stats {
    font-size: 1.5rem;
    border-top: 1px solid #10917D;
    border-bottom: 1px solid #10917D;
    padding: .5em 0;
    margin: 0 0 .5em 0;
}
.cta-subscribe.horizontal .cta-actions {
    flex-basis: 40%;
    padding:0;
}
.cta-subscribe .cta-actions .wp-block-columns {
    margin-bottom: 0;
}


/* archives */

.archive-title {
    padding: 55px 55px 0;
    text-align: center;
}


/* video player */
.course-browser {
    position:relative;
    margin-top:50px;
}
.course-video-container {
    position:relative;
    width:100%;
    height:0;
    padding-bottom:56%;
    background:var(--color-black);
}

.course-video-container iframe {
    position:absolute;
    top:0;
    left:0;
    width:100%;
    height:100%;
}


/* course nav menu */
.course-menu {
	background:var(--color-light-grey);
	color:var(--color-white);
	width:100%;
	height:100%;
	overflow:auto;
    padding: 2em;
    font-size: 1.2rem;
}
.course-menu ol {
	padding:0 0 0 1.4em;
	margin:0;
}
.course-menu a {
    text-decoration:none;
}
.course-menu ol li {
	transition:height .3s ease-in-out;
    text-indent: -1.6em;
}
.course-menu ol li.selected {
	font-weight:bold;
}

.course-materials {
    height:0;
    transition:height .3s ease-in-out;
    background:var(--color-xlight-grey);
    overflow:hidden;
}