html,body {
    margin: 0;
    padding: 0;
    background-color: whitesmoke;
    -webkit-text-size-adjust: 100%;
    -webkit-tap-highlight-color: rgba(0,0,0,0);
}
a {
    color: #3498DB;
    text-decoration: none;
}
#payment-banner {
    position: fixed;
    top: 0;
    left: 0;
    width: 100%;
    height: 44px;
    line-height: 44px;
    text-align: center;
    font-family: Lato;
    -moz-osx-font-smoothing: grayscale;
    -webkit-font-smoothing: antialiased;
    color: #fff;
    background-color: #3498DB;
    overflow: hidden;
    z-index: 2;
}
    #payment-banner p {
        margin: 0;
    }
    #payment-banner a {
        color: #fff;
    }
    #payment-banner .lessons-left:before {
        content: attr(data-value);
    }
    [data-value="1"] ~ .plural {
        display: none;
    }
    #payment-banner button {
        margin-left: 20px;
        border-radius: 5px;
        border: 0;
        padding: 0 8px;
        height: 32px;
        font-size: 14px;
        font-family: Lato;
        color: #3498DB;
        background-color: #fff;
        cursor: pointer;
        position: relative;
        top: -1px;
    }
@media (max-width: 479px) {
    #payment-banner {
        font-size: 14px;
    }
        #payment-banner button {
            font-size: 12px;
            margin-left: 10px;
        }
}
#payment-banner + #header {
    top: 44px;
}
#payment-banner ~ #body {
    top: 88px;
}
#header, #body {
    transition: top 0.4s ease;
    -webkit-transition: top 0.4s ease;
}
#header {
    position: fixed;
    top: 0;
    left: 0;
    height: 44px;
    background-color: #fff;
    color: #666;
    width: 100%;
    font-family: Lato;
    font-size: 14px;
    font-weight: 400;
    -webkit-font-smoothing: antialiased;
    -moz-osx-font-smoothing: grayscale;
    line-height: 44px;
    white-space: nowrap;
    box-shadow: rgba(100, 100, 100, 0.247059) 0px 1px 3px 0px;
    z-index: 2;
    user-select: none;
}
    #logo {
        background-image: url('logo.png');
        background-repeat: no-repeat;
        background-size: auto 28px;
        background-position: 6px center;
        width: 44px;
        height: 44px;
        float: left;
    }
    #links {
        float: left;
        padding: 0 8.88%;
    }
        .link {
            float: left;
            padding: 0 20px;
            cursor: pointer;
        }
        .link:hover {
            background-color: #fafafa;
        }
            body.lessons .link.lessons,
            body.docents .link.docents, 
            body.classes .link.classes,
            body.grade .link.grade,
            body.lesson-ideas .link.resources,
            body.find-content .link.resources,
            body.text-sources .link.resources, 
            body.tools-to-embed .link.resources,
            body.examples .link.resources {
                border-bottom: 3px solid #559;
                height: 41px;
            }
        .resources-dropdown {
            display: none;
            position: absolute;
            top: 44px;
            left: calc(8.88% + 302px);
            padding: 5px 0;
            background-color: white;
            box-shadow: rgba(100, 100, 100, 0.247059) 0 1px 3px 2px;
            border-radius: 0 0 2px 2px;
        }
            .resources-dropdown > .link {
                float: none;
            }
        .link.resources.clicked {
            background-color: #f0f0f0;
        }
        .link.resources.clicked + .resources-dropdown {
            display: block;
        }
        .link.email-support {
            display: block;
            color: inherit;
        }
        .public-library {
            display: none;
        }
        .teacher .public-library {
            display: block;
        }
    @media (min-width: 768px) {
        .teacher .resources-dropdown {
            left: calc(8.88% + 426px);
        }
        .resources-dropdown .public-library {
            display: none;
        }
        .teacher .invite-contacts, .teacher .install-extension {
            left: calc(50% + 231px);
        }
    }
    @media (max-width: 767px) {
        #links > .public-library {
            display: none !important;
        }
    }
    @media (max-width: 577px) {
        #links {
            padding: 0px calc(50% - 232px);
        }
        .resources-dropdown {
            left: calc(50% + 70px);
        }
    }
    @media (max-width: 479px) {
        #logo, #profile {
            display: none;
        }
        #links {
            padding: 0;
            width: 100%;
        }
            #links > .link {
                padding: 0;
                width: 25%;
                text-align: center;
            }
            .resources-dropdown {
                left: auto;
                right: 0;
            }
    }
    @media (max-width: 359px) {
        #links > .link {
            width: 24%;
            font-size: 14px;
        }
        #links > .link.resources {
            width: 28%;
        }
    }
    #search {
        float: left;
        position: relative;
    }
        #search > i.fa {
            position: absolute;
            top: 14px;
            left: 7px;
            color: #aaa;
        }
        #searchbar {
            font-size: 14px;
            font-family: Lato;
            font-weight: 300;
            border-radius: 5px;
            border: 0px none;
            padding: 5px;
            padding-left: 30px;
            width: 225px;
            background-color: whitesmoke;
        }
    #profile {
        float: right;
        height: 32px;
        width: 32px;
        margin: 6px;
        border-radius: 16px;
        cursor: pointer;
    }
    /*
    #profile {
        height: 44px;
        float: left;
        margin-left: 20px;
        cursor: pointer;
    }
        #profile > i.fa {
            line-height: 44px;
        }
        #profile > i.fa:first-of-type {
            height: 44px;
            width: 44px;
            float: left;
            font-size: 25px;
            text-align: center;
        }
        #profile > i.fa:last-of-type {
            height: 44px;
            width: auto;
            float: left;
            font-size: 15px;
            text-align: center;
            padding-right: 12px;
        }
    #profile:hover {
        background-color: #840;
    }
    */
#body {
    position: absolute;
    top: 44px;
    left: 0;
    width: 100%;
    font-family: Lato;
    font-size: 15px;
    font-weight: 300;
    display: none;
}
    #body .container {
        display: none;
    }
    body.docents #body .container.docents,
    body.classes #body .container.classes,
    body.grade #body .container.grade,
    body.lesson-ideas #body .container.lesson-ideas,
    body.find-content #body .container.find-content,
    body.text-sources #body .container.text-sources,
    body.tools-to-embed #body .container.tools-to-embed,
    body.examples #body .container.examples {
        display: block;
    }
.container {
    width: 100%;
    max-width: 900px;
    margin: auto;
    position: relative;
}
.container.docents,
.container.classes {
    padding: 0 8px;
    box-sizing: border-box;
}
.container.docents h1,
.container.classes h1 {
    margin-left: 0;
}
.container h1 {
    font-family: Raleway;
    font-size: 32px;
    font-weight: 400;
    margin: 0.67em 0.25em;
}
    h1 > i.fa {
        margin-left: 10px;
        font-size: 24px;
        position: relative;
        padding: 10px;
        top: -5px;
        cursor: pointer;
        display: inline;
    }
    .docents > h1 > i.fa {
        display: none;
    }
    .teacher .docents > h1 > i.fa {
        display: inline;
    }
    h1 > .new-docent, h1 > .new-folder, h1 > .new-course {
        position: absolute;
        margin-left: 20px;
    }
    .teacher h1 > .new-folder {
        margin-left: 176px;
    }
    h1 > .new-docent, h1 > .new-folder {
        display: none;
    }
    .teacher h1 > .new-docent, .teacher h1 > .new-folder.show, .can-use-folders h1 > .new-folder.show {
        display: inline;
    }
    .docents > h1 > .fa.fa-chevron-right {
        font-size: 12px;
        margin: 0 8px;
        vertical-align: bottom;
        line-height: 32px;
        opacity: 0.5;
    }
    .docents > h1 > span:first-child {
        cursor: pointer;
    }
    .docents > h1 > .folder-name {
        font-size: 18px;
        font-family: Lato;
        vertical-align: bottom;
        line-height: 32px;
        cursor: pointer;
    }
    .docents > h1:before {
        content: '\00a0';
        float: right;
        width: 110px;
    }
.new-docent, .new-folder, .new-course {
    width: 136px;
    height: 36px;
    line-height: 36px;
    background-color: #559;
    color: white;
    font-family: Lato;
    font-size: 16px;
    font-weight: 700;
    -webkit-font-smoothing: antialiased;
    -moz-osx-font-smoothing: grayscale;
    padding: 0;
    border: 0;
    border-radius: 5px;
    box-shadow: rgba(100, 100, 100, 0.247059) 0px 1px 3px 0px;
    cursor: pointer;
    outline: 0;
}
    .new-docent > i.fa, .new-folder > i.fa, .new-course > i.fa {
        margin-right: 8px;
        margin-left: -4px;
    }
@media (max-width: 440px) {
    .teacher h1 > .new-folder.show {
        display: none;
    }
}
.new-course {
    width: 130px;
}
h3 {
    font-weight: 400;
    font-size: 17px;
}
.modal {
    height: 100%;
    width: 100%;
    background-color: rgba(0, 0, 0, 0.4);
    position: fixed;
    top: 0;
    left: 0;
    display: none;
    overflow: auto;
    z-index: 4;
}
    .modal-dialog {
        margin: 0 auto;
        position: relative;
        top: 33%;
        transform: translateY(-33%);
        -webkit-transform: translateY(-33%);
        background-color: #F5F5F5;
        border-radius: 8px;
        padding: 20px;
        height: auto;
        font-family: Lato;
        font-weight: 300;
    }
    .modal-dialog.overflowing {
        margin: 44px auto;
        top: 0;
        transform: none;
        -webkit-transform: none;
    }
        .modal-input {
            font-family: Lato;
            font-size: 14px;
            font-weight: 400;
            padding: 10px;
            width: 100%;
            margin-top: 5px;
            box-sizing: border-box;
            -webkit-box-sizing: border-box;
        }
        .modal-confirm, .modal-cancel {
            font-size: 14px;
            font-family: Lato;
            height: 44px;
            width: 70px;
            background-color: #3498DB;
            color: #F5F5F5;
            border: 0;
            border-radius: 4px;
            position: absolute;
            bottom: 20px;
            right: 20px;
            cursor: pointer;
        }
        .modal-cancel {
            left: 20px;
            right: auto;
            background-color: #555;
        }
        .modal-close {
            position: absolute;
            top: 0;
            right: 0;
            width: 36px;
            height: 36px;
            padding: 0;
            border: 0;
            background-color: transparent;
            color: #aaa;
            cursor: pointer;
            line-height: 1;
        }
    .docent-assign-dialog {
        width: 300px;
        border-radius: 15px;
        padding: 10px 5px;
        font-weight: 400;
    }
        .docent-assign-title {
            font-family: Lato;
            font-size: 18px;
            height: 32px;
            font-weight: 400;
            margin: 8px;
            -webkit-font-smoothing: antialiased;
            -moz-osx-font-smoothing: grayscale;
        }
        .docent-assign-info {
            font-family: Lato;
            padding: 5px 0px;
            margin: 0px 10px;
            color: #3498DB;
            font-size: 14px;
        }
        .docent-assign-note {
            margin: 6px 12px;
            font-size: 14px;
            color: #333;
        }
        .docent-assign-new-course {
            color: #3498DB;
        }
        .docent-assign-select {
            margin: 10px 6px;
            background-color: #fff;
            min-height: 160px;
            max-height: 320px;
            overflow-y: auto;
            border: 1px solid #ccc;
            border-radius: 6px;
        }
        .docent-assign-new-course,
        .docent-assign-option {
            font-family: Lato;
            line-height: 24px;
            padding: 10px;
            padding-right: 36px;
            margin: 0;
            /*margin: 0 5px;
            border-radius: 5px;*/
            cursor: pointer;
        }
        .docent-assigned {
            background-color: #E1F0FA;/*rgba(52, 152, 219, 0.15);*/
            position: relative;
        }
            .docent-assigned:after {
                content: '\f00c';
                font-family: FontAwesome;
                position: absolute;
                right: 0;
                top: 50%;
                transform: translateY(-50%);
                -webkit-transform: translateY(-50%);
                text-align: center;
                width: 36px;
                color: #3498DB;
            }
        .docent-assigned + .docent-assigned {
            box-shadow: 0 -10px 0 0 #E1F0FA;
            /*box-shadow: 0 -10px 0 0 #D8E7F1;*/
        }
        .docent-assign-dialog > hr {
            border: 0;
            border-top: 1px solid #ccc;
        }
        .docent-assign-dialog > hr + .docent-assign-info {
            text-align: center;
        }
        .docent-assign-confirm {
            position: static;
            width: 104px;
            margin: 8px;
            float: left;
        }
        .docent-assign-dialog .share-to-google-classroom {
            margin: 8px;
            font-size: 14px;
            width: 44px;
            position: static;
            background-position: center;
            padding: 0;
            float: left;
        }
        .docent-assign-dialog .teams-share-button {
            height: 44px;
            width: 44px;
            border-radius: 5px;
            border: 1px solid #CCC;
            background-color: #FBFBFB;
            padding: 0;
            margin: 8px;
            cursor: pointer;
            float: left;
        }
            .docent-assign-dialog .teams-share-button img {
                padding: 3.75px 5px;
            }
        .docent-assign-dialog .docent-assign-copy-link {
            height: 44px;
            width: 44px;
            border-radius: 5px;
            border: 1px solid #CCC;
            background-color: #FBFBFB;
            padding: 0;
            margin: 8px;
            font-size: 21px;
            line-height: 44px;
            cursor: pointer;
        }
        .docent-assign-hidden-link {
            float: left;
            height: 1px;
            padding: 0;
            border: 0;
            opacity: 0;
        }
    .share-to-google-classroom-dialog {
        width: 335px;
        max-width: 100%;
        box-sizing: border-box;
    }
        .share-to-google-classroom-title {
            background-image: url('https://insertlearning.com/images/google-classroom.png');
            background-size: 32px 32px;
            background-repeat: no-repeat;
            background-position: 0 center;
            font-size: 18px;
            height: 32px;
            font-weight: 400;
            -moz-osx-font-smoothing: grayscale;
            -webkit-font-smoothing: antialiased;
            line-height: 32px;
            padding-left: 44px;
            margin-bottom: 15px;
        }
        .share-to-google-classroom-select {
            margin-top: -5px;
            margin-bottom: 10px;
            font-weight: 400;
            -moz-osx-font-smoothing: grayscale;
            -webkit-font-smoothing: antialiased;
            overflow-y: auto;
            max-height: calc(100vh - 140px);
        }
            .share-to-google-classroom-option {
                background-color: white;
                padding: 10px;
                margin: 5px 0;
                border-radius: 5px;
                width: 100%;
                display: inline-block;
                cursor: pointer;
                border: 1px solid #ccc;
                box-sizing: border-box;
            }
                .share-to-google-classroom-option:before {
                    display: inline-block;
                    font-family: FontAwesome;
                    font-size: 16px;
                    margin-right: 10px;
                    width: 1.28571429em;
                    text-align: center;
                    -moz-osx-font-smoothing: grayscale;
                    -webkit-font-smoothing: antialiased;
                    content: '\f096';
                    color: #888;
                }
            .share-to-google-classroom-option.selected {
                border-color: #3498DB;
                background-color: #F0F8FF;
            }
                .share-to-google-classroom-option.selected:before {
                    content: '\f14a';
                    color: #3498DB;
                }
        .share-to-google-classroom-confirm {
            height: 40px;
            border-radius: 5px;
            border: 0;
            color: #fff;
            background-color: #2BA367;
            width: 100%;
            font-size: 16px;
            font-family: Lato;
            font-weight: 400;
            -moz-osx-font-smoothing: grayscale;
            -webkit-font-smoothing: antialiased;
            cursor: pointer;
        }
        .share-to-google-classroom-schedule-toggle {
            width: 40px;
            height: 40px;
            border: 0;
            padding: 0;
            color: #fff;
            background-color: #2BA367;
            cursor: pointer;
            border-radius: 0 5px 5px 0;
            float: right;
        }
        .share-to-google-classroom-schedule-toggle + .share-to-google-classroom-confirm {
            width: calc(100% - 41px);
            border-radius: 5px 0 0 5px;
        }
        .share-to-google-classroom-schedule-input {
            display: none;
            border: 1px solid #ccc;
            border-radius: 5px;
            margin-top: 15px;
            -webkit-appearance: none;
        }
        .share-to-google-classroom-schedule-input[type="date"] {
            width: 54%
        }
        .share-to-google-classroom-schedule-input[type="time"] {
            width: 43%;
            float: right;
        }
        .share-to-google-classroom-schedule-input.error {
            outline: 0;
            box-shadow: red 0px 0px 1px 1px;
        }
        .share-to-google-classroom-schedule-toggle.fa-calendar-minus-o + .share-to-google-classroom-confirm {
            font-size: 0;
        }
            .share-to-google-classroom-schedule-toggle.fa-calendar-minus-o + .share-to-google-classroom-confirm:before {
                content: 'Schedule for these classes';
                font-size: 16px;
            }
        .share-to-google-classroom-schedule-toggle.fa-calendar-minus-o ~ .share-to-google-classroom-schedule-input {
            display: inline-block;
        }
    .share-dialog {
        width: 340px;
    }
        .share-title {
            margin-top: 0;
        }
        .share-info {
            font-size: 14px;
        }
        .share-publicly {
            font-size: 14px;
            cursor: pointer;
            text-align: right;
            margin-top: -16px;
            margin-bottom: 5px;
            display: block;
        }
        .share-input {
            margin-top: 0;
            -moz-osx-font-smoothing: grayscale;
            -webkit-font-smoothing: antialiased;
        }
        .share-social {
            text-align: center;
            font-size: 40px;
            margin-top: 15px;
        }
            .share-social > .fa {
                margin: 0 15px;
                cursor: pointer;
            }
            .share-social > .fa-facebook-square {
                color: #3b5998;
            }
            .share-social > .fa-twitter-square {
                color: #55acee;
            }
            .share-social > .fa-envelope-square {
                color: gray;
            }
        .student#dashboard ~ .share-modal .share-title,
        .student#dashboard ~ .share-modal .share-info {
            position: relative;
            visibility: hidden;
        }
            .student#dashboard ~ .share-modal .share-title:before,
            .student#dashboard ~ .share-modal .share-info:before {
                content: 'Share with your teacher';
                position: absolute;
                visibility: visible;
            }
        .student#dashboard ~ .share-modal .share-info {
            margin-bottom: 0;    
        }
            .student#dashboard ~ .share-modal .share-info:before {
                content: 'Copy/paste this link and send it to your teacher so they can view your work or make a copy of it.';
            }
        .student#dashboard ~ .share-modal .share-publicly,
        .student#dashboard ~ .share-modal .share-social {
            display: none;
        }
@media (max-width: 400px) {
    .share-dialog {
        width: 270px;
    }
}
    .rename-dialog {
        width: 481px;
        max-width: calc(100% - 40px);
    }
    .rename-course-modal .rename-dialog {
        width: 320px;
    }
        .rename-dialog > label {
            font-weight: 400;
        }
        .rename-course-modal label {
            visibility: hidden;
        }
            .rename-course-modal label:before {
                content: 'Name of Class:';
                visibility: visible;
                font-weight: 300;
            }
        .rename-input {
            resize: none;
            border: 1px solid #ccc;
            border-radius: 4px;
            margin-bottom: 16px;
            height: 64px;
            font-size: 17px;
            font-weight: 300;
        }
        .rename-course-modal .rename-input {
            visibility: visible;
            font-weight: 400;
            margin-bottom: 52px;
        }
        .lesson-metadata {
            margin-bottom: 22px;    
        }
            .lesson-metadata p {
                font-weight: 400;
            }
            .lesson-metadata label {
                display: inline-block;
                padding-left: 16px;
                margin-bottom: 10px;
                cursor: pointer;
            }
            .subject-area label {
                padding-right: 16px;
            }
            .grade-level label {
                margin-bottom: 10px;
                width: 65px;
                box-sizing: border-box;
            }
            .rename-dialog input[type="checkbox"] {
                cursor: pointer;
            }
        .lesson-metadata-custom-tags input {
            margin-bottom: 32px;
            font-weight: 300;
            font-size: 15px;
            border: 1px solid #ccc;
            border-radius: 4px;
        }
        .rename-dialog .lesson-metadata-public-library {
            font-weight: 300;
            font-size: 15px;
            padding: 7px 0;
            display: inline-block;
            cursor: pointer;
        }
        @media (max-width: 375px) {
            .rename-dialog .lesson-metadata-public-library {
                margin-bottom: 60px;   
            }
        }
        .rename-course-modal .lesson-metadata,
        .rename-course-modal .lesson-metadata-public-library,
        .rename-course-modal .lesson-metadata-custom-tags {
            display: none;
        }
        .rename-cancel, .rename-confirm {
            height: 36px;
            -webkit-font-smoothing: antialiased;
            -moz-osx-font-smoothing: grayscale;
        }
        .rename-cancel {
            left: auto;
            right: 110px;
        }
    .move-dialog {
        max-width: 600px;
    }
        .move-dialog h3 {
            margin-top: 0;
        }
        .folder-tree {
            background-color: #fff;
            border: 1px solid #ccc;
            padding: 5px;
            border-radius: 5px;
            height: 486px;
            overflow: auto;
            margin-bottom: 64px;
            max-height: calc(100vh - 154px);
        }
            .folder-tree ul {
                list-style: none;
                padding-left: 20px;
                display: none;
                margin: 0;
            }
            .folder-tree > ul {
                display: block;
                padding-left: 0;
            }
            .folder-tree span {
                display: block;
                line-height: 180%;
                cursor: pointer;
                position: relative;
                font-weight: 400;
                padding: 5px;
                padding-left: 25px;
            }
                .folder-tree ul .fa:first-child {
                    position: absolute;
                    top: 0;
                    left: 5px;
                    line-height: 40px;
                }
                .folder-tree .fa-folder-o {
                    margin-right: 2px;
                }
            .folder-tree .selected {
                background-color: #E1F0FB;
                border-radius: 2px;
            }
            .folder-tree > span {
                padding-left: 5px;
            }
        .move-dialog .modal-cancel {
            left: auto;
            right: 110px;
        }
@media (max-width: 760px) and (max-height: 730px) {
    .move-dialog .modal-cancel {
        left: calc(50% - 80px);
    }
    .move-dialog .modal-confirm {
        right: calc(50% - 80px);
    }
}
    .move-access-dialog {
        max-width: 300px;
    }
        .move-access-dialog h3 {
            margin-top: 0;
        }
        .move-access-dialog p {
            margin-bottom: 64px;
            line-height: 160%;
        }
        .move-access-dialog .modal-cancel {
            left: auto;
            right: 110px;
        }
    .create-docent-dialog {
        width: 260px;
    }
        .create-docent-title {
            margin-top: 0;
            margin-bottom: 24px;
            text-align: center;
        }
        .create-docent-half-width {
            text-align: center;
            padding: 0 28px;
        }
            .create-docent-with-search {
                position: relative;
                display: inline-block;
                color: #757575;
                background-color: white;
                font-weight: 400;
                line-height: 36px;
                margin: 40px 0 10px;
                padding: 0 44px 0 8px;
                border-radius: 2px;
                box-shadow: rgba(100, 100, 100, 0.247059) 0px 1px 3px 0px;
                text-align: left;
                width: 205px;
                box-sizing: border-box;
                -webkit-box-sizing: border-box;
                -webkit-font-smoothing: antialiased;
                -moz-osx-font-smoothing: grayscale;
            }
            .create-docent-with-search:after {
                content: '\f002';
                font-family: FontAwesome;
                font-size: 18px;
                color: #3498DB;
                position: absolute;
                right: 0;
                line-height: 36px;
                width: 36px;
                text-align: center;
            }
/**
@media (min-width: 568px) {
    .create-docent-dialog {
        width: 568px;
        box-sizing: border-box;
        -webkit-box-sizing: border-box;
    }
        .create-docent-half-width {
            width: 50%;
            float: left;
            box-sizing: border-box;
            -webkit-box-sizing: border-box;
        }
            .create-docent-with-search {
                margin: 60px 0;
            }
        .create-docent-dialog:after {
            content: '';
            clear: both;
            display: table;
        }
}
/**/
    .enroll-dialog {
        width: 180px;
        height: 110px;
    }
        .enroll-dialog > label {
            display: block;
            text-align: center;
        }
        .enroll-input {
            width: auto;
            font-size: 14px;
            font-family: Menlo,Consolas,monospace;
            margin-left: 10px;
            margin-top: 0;
            padding: 10px;
        }
        .enroll-cancel, .enroll-confirm {
            width: 80px;
        }
    .create-course-dialog {
        height: 206px;
        width: 226px;
    }
        .create-course-input {
            font-size: 17px;
        }
        .create-course-confirm, .create-course-cancel {
            width: 103px;
            bottom: 88px;
        }
        .import-from-google-classroom,
        .share-to-google-classroom {
            height: 44px;
            border-radius: 5px;
            border: 1px solid #CCC;
            font-family: Lato;
            font-size: 12px;
            background-color: #FBFBFB;
            background-image: url('https://insertlearning.com/images/google-classroom.png');
            background-size: 32px 32px;
            background-repeat: no-repeat;
            background-position: 10px center;
            padding: 0;
            padding-left: 40px;
            width: 226px;
            position: absolute;
            bottom: 20px;
            left: 20px;
            cursor: pointer;
        }
        /*
        .share-to-google-classroom[disabled] {
            cursor: default;
            pointer-events: none;
            opacity: 0.2;
        }
        */
    .import-course-dialog {
        width: 196px;
        height: 92px;
    }
        .import-course-dialog .select2-container {
            width: 100% !important;
        }
        .import-course-confirm, .import-course-cancel {
            width: 88px;
        }
        .import-course-confirm[disabled] {
            cursor: default;
            pointer-events: none;
            opacity: 0.2;
        }
    .roster-dialog {
        width: 480px;
        max-width: 80%;
        max-width: calc(100% - 80px);
        padding: 12px 20px;
        min-height: 24px;
    }
    .roster-dialog.overflowing {
        margin: 60px auto;
    }
        .roster-dialog h4 {
            margin: 8px;
            font-size: 16px;
            font-weight: 400;
        }
            .roster-dialog .fa-plus-circle {
                cursor: pointer;
                padding: 12px;
                display: inline;
            }
        .roster-dialog ul {
            list-style: none;
            margin: 0;
            font-size: 18px;
            padding-left: 24px;
        }
            .roster-dialog li {
                margin: 1em 0;
                padding-right: 4em;
            }
                .roster-dialog .fa-user-times {
                    color: #ccc;
                    cursor: pointer;
                    position: absolute;
                    right: 35px;
                    height: 40px;
                    line-height: 40px;
                    width: 40px;
                    text-align: center;
                    transform: translateY(-10px);
                }
            .roster-dialog li.hover {
                background-color: rgba(204, 51, 51, 0.1);
                margin: -0.5em;
                padding: 0.5em;
                border-radius: 5px;
                margin-right: 0.5em;
                padding-right: 3.5em;
            }
                .roster-dialog .fa-user-times:hover {
                    color: #c33;
                }
            .roster-dialog li.hover:first-of-type {
                margin-top: 0.5em;
            }
            .roster-dialog li.hover:last-of-type {
                margin-bottom: 0.5em;
            }
            .roster-dialog .offer-invite {
                position: relative;
                right: 0;
                margin: 25px auto 10px;
                transform: none;
                -webkit-transform: none;
                min-width: 155px;
            }
            .teacher-roster .roster-dialog .offer-invite {
                display: block;
            }
            .roster-dialog .offer-invite:before {
                content: '';
            }
            .roster-dialog .offer-invite .fa {
                margin-right: 4px;
            }
    .invite-teacher-dialog {
        width: 240px;
        height: 130px;
    }
        .invite-teacher-cancel,
        .invite-teacher-confirm {
            width: 110px;
        }
    .new-user-dialog {
        width: 290px;
        height: 155px;
        padding: 0;
        border-radius: 10px;
    }
        .new-user-dialog > p {
            position: absolute;
            top: 15px;
            left: 0;
            font-family: Lato;
            font-weight: 400;
            line-height: 180%;
            font-size: 15px;
            padding: 0;
            text-align: center;
            width: 100%;
            margin: 0;
        }
        .signup-as-student,
        .signup-as-teacher {
            height: 50px;
            border-radius: 10px;
            border: 0;
            color: white;
            background-color: #ed6f23;
            font-family: Lato;
            font-size: 14px;
            cursor: pointer;
            outline: 0;
            position: absolute;
            bottom: 20px;
            left: 10%;
            width: 35%;
        }
        .signup-as-teacher {
            right: 10%;
            left: auto;
            background-color: #3498DB;
        }
    .teacher-role-dialog {
        width: 280px;
    }
        .teacher-role-dialog p {
            margin-top: 24px;
            font-size: 18px;
            margin-bottom: 12px;
        }
        .teacher-role-dialog p:first-of-type {
            margin-top: 0;
        }
        .teacher-role-dialog label {
            display: block;
            margin: 8px;
            cursor: pointer;
        }
        .teacher-role-dialog input {
            margin-right: 8px;
            cursor: pointer;
        }
        /* Dumb selector, should be able to do better */
        .teacher-role-dialog p ~ p ~ p ~ label {
            display: inline-block;
        }
        .teacher-role-confirm {
            font-family: Lato;
            font-size: 15px;
            color: whitesmoke;
            font-weight: 400;
            -moz-osx-font-smoothing: grayscale;
            -webkit-font-smoothing: antialiased;
            background-color: #3498DB;
            position: relative;
            left: 50%;
            transform: translateX(-50%);
            height: 36px;
            width: 80px;
            border: 0;
            border-radius: 4px;
            margin-top: 12px;
            cursor: pointer;
        }
@media (max-height: 640px) {
    .teacher-role-dialog {
        top: 0;
        transform: none;
        -webkit-transform: none;
    }
}
    .tutorial-dialog {
        width: 380px;
        max-width: 100%;
        box-sizing: border-box;
    }
        .tutorial-dialog p {
            font-size: 17px;
            margin-top: 0;
            margin-bottom: 12px;
        }
        .tutorial-dialog a {
            font-size: 17px;
            word-break: break-all;
        }
    .settings-dialog {
        height: auto;
        width: 280px;/*320px*/
    }
    /*.student.settings-dialog {
        height: 125px;
    }*/
        .settings-personal {
            height: 96px;/*72px*/
        }
            .settings-personal-picture {
                float: left;
                height: 100%;
                width: auto;
                border-radius: 50%;
            }
            .settings-personal-info {
                position: relative;
                top: 50%;
                display: inline-block;
                transform: translateY(-50%);
                padding: 0px 15px;
                width: calc(100% - 96px);/* - 72px */
                box-sizing: border-box;
            }
                .settings-personal-name {
                    font-weight: 400;
                    margin: 8px 0;
                }
                .settings-personal-email {
                    margin: 8px 0;
                    word-break: break-all;
                }
        .settings-section {
            margin: 18px 0;
        }
            .settings-section p {
                margin-bottom: 8px;
            }
            .settings-section label,
            .settings-section span {
                font-size: 15px;
                padding: 8px 16px;
                display: inline-block;
            }
                .settings-section label {
                    cursor: pointer;
                }
                .settings-section input {
                    margin-right: 8px;
                    cursor: pointer;
                }
            .settings-section .settings-change-card,
            .settings-section .settings-subscribe-now {
                color: #3498DB;
                padding-top: 0;
                cursor: pointer;
                text-decoration: underline;
            }
        .student .settings-section {
            display: none;
        }
        .student .settings-personal + .settings-section {
            display: block;
        }
        .teacher.disable-usertype-switching .settings-personal + .settings-section label:first-of-type,
        .student.disable-usertype-switching .settings-personal + .settings-section label:last-of-type,
        .disable-usertype-switching input[name="user-type"] {
            display: none;
        }
        .settings-dialog > .sign-out {
            margin-bottom: 0;
            width: 90px;
            border-radius: 5px;
            height: 36px;
        }
    .delete-dialog,
    .warning-dialog {
        width: 200px;
        height: 110px;
    }
        .delete-info,
        .warning-info {
            margin: 0;
            line-height: 140%;
            text-align: center;
        }
        .warning-info:before {
            content: 'This will delete student answers and responses.';
        }
        .delete-course-name ,
        .warning-dialog > label {
            display: none;
        }
        .delete-confirm, .delete-cancel,
        .warning-confirm, .warning-cancel {
            width: 90px;
        }
        .delete-confirm,
        .warning-confirm {
            background-color: #c33;
        }
    .warning-delete-course {
        width: 240px;
        height: auto;
    }
        .warning-delete-course > .delete-course-name {
            display: block;
            margin-top: 0;
            font-weight: 400;
            font-size: 16px;
        }
            .delete-course-name:before {
                content: 'Delete ';
            }
            .delete-course-name:after {
                content: '?';
            }
        .warning-delete-course .warning-info:before {
            content: 'This will delete your class roster along with all student answers and responses for this class.';
        }
        .warning-delete-course label {
            margin: 20px 0;
            margin-bottom: 70px;
            display: inline-block;
        }
        .delete-course-input {
            font-size: 17px;
        }
        .warning-delete-course button {
            width: 110px;
        }
        .warning-confirm[disabled] {
            cursor: default;
            pointer-events: none;
            opacity: 0.2;
        }
    .signin-troubleshooting-dialog {
        width: 400px;
        max-width: 80%;
        line-height: 160%;
    }
        .signin-troubleshooting-title {
            margin: 0;
        }

.status-message {
    position: fixed;
    border-radius: 5px;
    color: #fff;
    background-color: rgba(0, 0, 0, 0.8);
    font-family: Lato, sans-serif;
    font-size: 16px;
    font-weight: 400;
    -webkit-font-smoothing: antialiased;
    -moz-osx-font-smoothing: grayscale;
    padding: 5px 10px;
    left: 50%;
    text-align: center;
    top: 33%;
    display: none;
    transform: translate(-50%, -33%);
    -webkit-transform: translate(-50%, -33%);
    z-index: 5;
}


.course,
.course-invite {
    margin: 12px 0;
    padding: 11px 20px 15px;
    width: calc(100% - 40px);
    min-height: 50px;
    position: relative;
    background-color: #fff;
    border-radius: 2px;
    box-shadow: 0px 1px 3px 0px rgba(100, 100, 100, 0.247);
}
    .course h3,
    .course-invite h3 {
        margin: 0;
        display: inline-block;
        max-width: 33%;
        min-width: 21px;
        min-height: 21px;
    }
    .course h3:focus {
        background-color: #FFF;
        box-shadow: 0 0 0 5px #fff, 0 0 0 6px #ccc;
        border-radius: 1px;
        outline: 0;
        cursor: text;
    }
        .course h3 > i.fa {
            font-size: 18px;
            padding: 13px;
            position: absolute;
            top: -10px;
            cursor: pointer;
        }
    .course p,
    .course-invite p {
        font-size: 13px;
        user-select: none;
        -webkit-user-select: none;
        margin-bottom: 0;
    }
        .course p > span,
        .course-invite p > span {
            margin-left: 15px;
            margin-right: 15px;
            display: inline-block;
            font-family: Menlo, Consolas, monospace;
            user-select: all;
            -webkit-user-select: all;
        }
        .course p > i.fa {
            cursor: pointer;
        }
    .course-students {
        display: none;
    }
    .course-teachers {
        list-style: none;
        padding: 0;
        margin: -10px 0 -15px;
        position: relative;
        right: 270px;
        width: 21%;
        float: right;
        display: none;
    }
        .course-teachers > li {
            margin: 5px 0;
            overflow: hidden;
            white-space: nowrap;
            text-overflow: ellipsis;
        }
@media (max-width: 767px) {
    .course-teachers {
        display: none;
    }
}
    .view-roster,
    .offer-invite,
    .accept-invite {
        height: 44px;
        border-radius: 5px;
        border: 0;
        padding: 0;
        color: white;
        font-family: Lato;
        font-size: 14px;
        cursor: pointer;
        outline: 0;
        background-color: #36AE4F;
        position: absolute;
        top: 50%;
        right: 55px;
        transform: translateY(-50%);
        -webkit-transform: translateY(-50%);
        min-width: 93px;
        display: none;
    }
        .view-roster:before {
            content: 'View Roster';
        }
    .offer-invite,
    .accept-invite {
        background-color: #3498DB;
        min-width: 127px;
    }
        .accept-invite:before {
            content: 'Accept Invitation';
        }
    .offer-invite {
        right: 153px;
    }
        .offer-invite:before {
            content: 'Invite Co-Teacher';
        }
    .delete-course,
    .reject-invite {
        height: 44px;
        width: 44px;
        font-size: 18px;
        border: 0;
        padding: 0;
        background-color: inherit;
        cursor: pointer;
        color: #888;
        outline: 0;
        position: absolute;
        top: 50%;
        right: 6px;
        transform: translateY(-50%);
        -webkit-transform: translateY(-50%);
        display: none;
    }
    .accept-invite,
    .reject-invite {
        display: inline-block;
    }
    .student#dashboard .course-teachers,
    .student#dashboard .view-roster,
    .student#dashboard .offer-invite,
    .student#dashboard .delete-course,
    .student#dashboard .course-invite {
        display: none;
    }
@media (max-width: 479px) {
    .view-roster,
    .offer-invite,
    .accept-invite,
    .delete-course,
    .reject-invite {
        position: static;
        transform: none;
        margin: 14px 5px 0 0;
    }
    .course h3,
    .course-invite h3 {
        max-width: none;
        padding-right: 55px;
    }
    .course-stats {
        display: none;
    }
}

/* 2/27/17 Experiment */
.course-stats {
    position: absolute;
    top: 50%;
    transform: translateY(-50%);
    width: 50px;
    line-height: 1;
    font-size: 14px;
    font-weight: 400;
    -webkit-font-smoothing: antialiased;
    -moz-osx-font-smoothing: grayscale;
    color: #888;
    cursor: pointer;
}
    .course-stats > span {
        font-size: 21px;
        color: #555;
    }
.course-stats:hover {
    color: rgba(52, 152, 219, 0.75);
}
    .course-stats:hover > span {
        color: #3498DB;
    }
.course-stats-lessons {
    left: 42%;
}
.course-stats-students {
    left: 60%;
}
.course-stats-teachers {
    left: 78%;
}
.student .course-stats-lessons {
    left: 56%;
}
/**/

#large-access-code {
    background-color: #F5F5F5;
    text-align: center;
}
    #large-access-code .modal-close {
        right: 5px;
        font-size: 44px;
        width: 44px;
        height: 44px;
        color: #555;
        font-family: Lato;
    }
    #large-access-code > span.code {
        font-size: 26vw;
        position: relative;
        top: 50%;
        transform: translateY(-50%);
        -webkit-transform: translateY(-50%);
        display: inline-block;
        font-family: Menlo, Consolas, monospace;
    }
    #large-access-code > span.instructions {
        font-family: Lato;
        font-size: 2.6vw;
        position: absolute;
        left: 0;
        top: 20px;
        width: 100%;
        padding-left: 10px;
        padding-right: 50px;
        box-sizing: border-box;
    }
@media (min-aspect-ratio: 5/2) {
    #large-access-code > span.instructions {
        display: none;
    }
}

#signinButtonContainer {
    text-align: center;
    width: 100%;
    padding: 44px 0;
    position: absolute;
    top: 44px;
}
#signinButton {
    display: block;
    min-height: 40px;
}
.custom.g-signin2 {
    background-color: #427FED;
    color: white;
    height: 40px;
    line-height: 40px;
    border-radius: 4px;
    font-family: Lato;
    font-size: 14px;
    width: 190px;
    display: inline-block;
    cursor: pointer;
    box-shadow: 0 2px 4px 0 rgba(0,0,0,0.25);
    transition: box-shadow 0.218s ease;
}
.custom.g-signin2[disabled] {
    cursor: wait;
}
.custom.g-signin2:not([disabled]):hover {
    box-shadow: 0px 0px 3px 3px rgba(66, 133, 244, 0.3);
}
    .custom.g-signin2:before {
        display: block;
        float: left;
        line-height: 42px;
        width: 40px;
        font-size: 22px;
        font-family: FontAwesome;
        content: '\f1a0';
        margin-right: -10px;
    }
    .custom.g-signin2:after {
        content: 'Sign in with Google';
    }
    .custom.g-signin2 > div {
        display: none;
    }
#signin-trouble {
    display: block;
    margin: 20px auto;
    height: 32px;
    background-color: white;
    border: 0;
    border-radius: 4px;
    box-shadow: 0px 1px 3px 0px rgba(100, 100, 100, 0.247);
    cursor: pointer;
}
.microsoft-signin {
    background-image: url('../microsoft_signin.svg');
    height: 41px;
    width: 215px;
    cursor: pointer;
    margin: 30px;
    border: 0;
    display: none;
}
/*
.find-content-for-lessons, .public-library {
    position: absolute;
    top: 10px;
    left: 196px;
    font-weight: 400;
    text-decoration: underline;
    cursor: pointer;
    display: none;
}
.public-library {
    left: 310px;
}
.public-library:before {
    content: '|';
    position: absolute;
    left: -16px;
    color: #000;
    text-decoration: none;
    pointer-events: none;
}
@media (min-width: 500px) {
    .teacher .find-content-for-lessons {
        display: block;
    }
}
@media (min-width: 667px) {
    .teacher .public-library {
        display: block;
    }
}
*/
.no-docents-message,
.no-courses-message,
.not-enrolled-message {
    display: none;
    padding: 1px 0;
    margin: 32px 0;
    background-color: #fff;
    border-radius: 2px;
    box-shadow: rgba(100, 100, 100, 0.247059) 0px 1px 3px 0px;
    text-align: center;
}
.teacher .show.no-docents-message,
.teacher .show.no-courses-message,
.student .show.not-enrolled-message {
    display: block;
}
    .no-docents-message > ol,
    .no-courses-message > p,
    .not-enrolled-message > p {
        width: 215px;
        margin: auto;
        line-height: 175%;
        font-size: 16px;
        text-align: left;
    }
    .no-courses-message > p,
    .not-enrolled-message > p {
        width: 300px;
        line-height: 160%;
        text-align: center;
    }
    .no-docents-message > .new-docent,
    .no-courses-message > .new-course,
    .not-enrolled-message > .new-course {
        margin: 20px;
    }
.onboarding {
    text-align: center;
    display: none;
}
.teacher .show.no-docents-message + .onboarding,
.teacher .docent-wrapper + .onboarding {
    display: block;
}
.docent-wrapper + .onboarding {
    margin-top: 37px;
}
.onboarding a {
    font-weight: 400;
    -webkit-font-smoothing: antialiased;
    -moz-osx-font-smoothing: grayscale;
}
.examples-container {
    width: 100%;
    min-height: 170px;
}
.videos-container {
    width: 100%;
    min-height: 155px;
}
.examples-container > .example-docent,
.videos-container > .video-tutorial {
    background-position: center;
    background-size: auto 100%;
    height: 125px;
    border-radius: 5px;
    width: 24%;
    margin: 0 0.5%;
    float: left;
    position: relative;
    -webkit-font-smoothing: antialiased;
    -moz-osx-font-smoothing: grayscale;
    color: #222;
    white-space: nowrap;
    cursor: pointer;
}
.videos-container > .video-tutorial {
    background-size: 100% auto;
    background-repeat: no-repeat;
    background-color: white;
}
.first.video-tutorial {
    background-image: url("https://insertlearning.com/v1/thumbnails/video.getting-started.png");
}
.second.video-tutorial {
    background-image: url("https://insertlearning.com/v1/thumbnails/video.google-docs.png")
}
.third.video-tutorial {
    background-image: url("https://insertlearning.com/v1/thumbnails/video.embed-tools.png");
}
.fourth.video-tutorial {
    background-image: url("https://insertlearning.com/v1/thumbnails/video.lms-integration.png");
}
.example-subject, .video-title {
    position: absolute;
    left: 0;
    bottom: -25px;
    width: 100%;
    line-height: 25px;
    font-weight: 400;
}
.example-subject:after {
    content: '(9th-12th)';
    vertical-align: top;
    font-size: 10px;
    margin-left: 5px;
}
.example-domain {
    position: absolute;
    left: 0;
    width: 100%;
    bottom: -37.5px;
    line-height: 1;
    font-size: 12.5px;
}
.examples-container + .examples-container {
    margin-top: 10px;
}
.examples-container + .examples-container .example-subject:after {
    content: '(6th-8th)';
}
@media (max-width: 567px) {
    .examples-container {
        width: 50%;
        min-height: 725px;
        float: left;
    }
    .examples-container > .example-docent {
        width: 80%;
        margin: 0 10% 55px;
    }
    .examples-container + .examples-container {
        margin-top: 0;
    }
    .videos-container {
        min-height: 320px;
    }
    .videos-container > .video-tutorial {
        width: 40%;
        margin: 0 5% 45px;
    }
}
@media (max-width: 480px) {
    .examples-container > .example-docent {
        width: 96%;
        margin: 0 2% 55px;
    }
    .videos-container > .video-tutorial {
        width: 48%;
        margin: 0 1% 45px;
    }
}
.no-assignments-message {
    display: none;
    padding: 0 10px;
    line-height: 175%;
}
.student .show.no-assignments-message {
    display: block;
}

.docents-filter {
    position: absolute;
    top: 5px;
    right: 6px;
    width: 37.5%;
}
.teacher .docents-filter {
    max-width: calc(100% - 467px);
}
.docents-filter[disabled] {
    opacity: 0;
    pointer-events: none;
}
@media (max-width: 639px) {
    .teacher .docents-filter {
        position: relative;
        top: auto;
        right: auto;
        width: 100%;
        max-width: none;
        margin-bottom: 20px;
    }
}

.close-folder {
    position: absolute;
    top: 3px;
    right: 6px;
    background-color: transparent;
    border: 0;
    height: 40px;
    font-size: 14px;
    color: #555;
    font-family: Lato;
    cursor: pointer;
    display: none;
}
.close-folder .fa {
    margin-right: 6px;
}
.empty-folder {
    position: relative;
    top: 25px;
    text-align: center;
    font-weight: 400;
    opacity: 0.4;
}
.empty-folder:before {
    content: 'This folder is empty';
}

.docent-wrapper {
    min-height: 74px;
    position: relative;
    overflow: hidden;
    width: 100%;
    padding: 1px 0;
    margin: 12px 0;
    background-color: #fff;
    border-radius: 2px;
    box-shadow: rgba(100, 100, 100, 0.247059) 0px 1px 3px 0px;
}
@media (max-width: 567px) {
    .docent-wrapper {
        max-height: 74px;
    }
}
.docent-wrapper[data-folder] {
    display: none;
}
.docent-image {
    height: 64px;
    width: 64px;
    float: left;
    background-position: center center;
    background-size: auto 100%;
    margin: 5px 10px;
}
.docent-image.fa-folder {
    font-size: 48px;
    line-height: 64px;
    text-align: center;
    color: #3498DB;
}
.docent-detail {
    width: 450px;
    float: left;
    max-width: calc(100% - 353px);
}
@media (max-width: 567px) {
    .docent-detail {
        max-width: calc(100% - 207px);
    }
}
    .docent-title {
        padding: 5px 0;
        font-size: 17px;
        display: block;
        color: #000;
        text-decoration: none;
        max-height: 41px;
        overflow: hidden;
    }
    .docent-url {
        font-size: 14px;
        color: #555;
        display: block;
        text-decoration: none;
        overflow: hidden;
        text-overflow: ellipsis;
    }
.docent-courses {
    width: 190px;
    float: left;
    padding: 5px 25px 0;
    max-width: calc(100% - 710px);
    min-width: 93px;
}
@media (max-width: 567px) {
    .docent-courses {
        display: none;
    }
}
    .docent-course {
        font-weight: 400;
        margin-bottom: 5px;
    }
.docent-mark, .docent-done, .docent-assign, .docent-share {
    height: 44px;
    border-radius: 5px;
    border: 0;
    color: white;
    background-color: #ed6f23;
    font-family: Lato;
    font-size: 14px;
    cursor: pointer;
    margin: 15px 8px;
    outline: 0;
    padding: 0;
    width: 104px;
}
    .docent-mark:before {
        content: 'Mark as Done';
    }
.docent-done {
    background-color: #fff;
    border: 1px solid rgba(54, 174, 79, 0.4);
    width: 88px;
    font-size: 22px;
    color: #36ae4f;
    margin: 15px 16px;
}
    .docent-done:before {
        content: 'Done';
        font-size: 16px;
        transform: translateY(-2px);
        display: inline-block;
    }
    .docent-done:after {
        content: '\f00c';
        font-family: FontAwesome;
        display: inline-block;
        font-weight: normal;
        -webkit-font-smoothing: antialiased;
        -moz-osx-font-smoothing: grayscale;
        margin-left: 6px;
    }
.docent-assign {
    background-color: #3498DB;
    margin: 15px 0;
    display: none;
    width: 71px;
    float: left;
}
.docent-share {
    background-color: #ED6F23;
    margin: 15px 0;
    margin-left: 5px;
    width: 44px;
    font-size: 21px;
}
.teacher#dashboard .docent-assign {
    display: inline-block;
}
    .docent-assign:before {
        content: 'Assign';
    }
.student#dashboard .docent-share {
    background-color: #3498DB;
    margin-left: -19px;
    padding-right: 46px;
    width: 90px;
    position: relative;
    /**
    padding-right: 40px;
    width: 76px;
    font-size: 16px;
    /**/
    display: inline-block;
}
    .student#dashboard .docent-share:after {
        content: 'Share';
        font-size: 14px;
        position: absolute;
        right: 14px;
        top: 13px;
        /**
        right: 10px;
        /**/
    }
@media (max-width: 567px) {
    .student#dashboard .docent-share {
        width: 44px;
        padding-right: 0;
        margin-left: 24px;
    }
        .student#dashboard .docent-share:after {
            content: '';
        }
}
.docent-delete {
    position: absolute;
    top: 16px;
    right: 0;
    width: 44px;
    height: 44px;
    font-size: 21px;
    border-radius: 4px;
    border: 0;
    color: #888;
    background-color: #F5F5F5;
    line-height: 44px;
    text-align: center;
    cursor: pointer;
    display: none;
    outline: 0;
}
.docent-options,
.course-options {
    position: absolute;
    top: 16px;
    right: 6px;
    width: 44px;
    height: 44px;
    background: #fff url(ellipsis.svg) no-repeat center;
    cursor: pointer;
    border: 0;
    outline: 0;
    padding: 0;
    border-radius: 22px;
}
.docent-options.clicked,
.course-options.clicked {
    background-color: whitesmoke;
}
.docent-options-list,
.course-options-list,
.new-course-list {
    position: absolute;
    right: 6px;
    background-color: #fff;
    color: #333;
    font-size: 14px;
    font-family: Lato;
    font-weight: 400;
    border-radius: 2px;
    box-shadow: rgba(100, 100, 100, 0.247059) 0 1px 3px 2px;
    padding: 5px 0;
    overflow: hidden;
    visibility: hidden;
}
    .docent-options-list-item,
    .course-options-list-item,
    .new-course-list-item {
        padding: 15px 20px;
        padding-right: 25px;
        cursor: pointer;
        margin: 0;
        line-height: 1;
        white-space: nowrap;
    }
        .docent-options-list-item > .fa,
        .course-options-list-item > .fa {
            margin-right: 10px;
        }
    .docent-options-list-item:hover,
    .course-options-list-item:hover,
    .new-course-list-item:hover {
        background-color: whitesmoke;
    }
.new-course-list {
    right: auto;
    top: 38px;
    left: 138px;
    height: 0;
    width: 138px;
    transition: height 0.2s ease, width 0.2s ease;
    user-select: none;
}
.new-course-list.visible {
    visibility: visible;
    height: 88px;
    width: 138px;
    z-index: 1;
}
/*
@media (min-width: 989px) {
    .docent-delete {
        display: block;
    }
}
*/
@media (max-width: 988px) {
    .docent-options-list,
    .course-options-list,
    .new-course-list {
        z-index: 20;
    }
}
.docent-share {
    display: none;
}

.submit-grades-to-google-classroom {
    position: absolute;
    right: 3px;
    top: 3px;
    font-size: 15px;
    font-family: Lato;
    border-radius: 5px;
    border: 0px;
    background-color: #2BA367;
    -moz-osx-font-smoothing: grayscale;
    -webkit-font-smoothing: antialiased;
    cursor: pointer;
    color: white;
    padding: 6px;
}

.filters {
    position: relative;
}
.filters > div {
    margin: 14px;
    margin-top: 0;
    display: block;
    position: relative;
}
    .filters > div > span {
        display: inline-block;
        width: 120px;
    }
    .filters select {
        width: 400px;
        max-width: calc(100% - 125px);
    }
    .select2-container * {
        font-family: Lato;
        font-weight: 400;
        font-size: 14px;
    }
    .filters .select2-container {
        max-width: calc(100% - 125px);
    }
    body .select2-container--default .select2-results__option--highlighted[aria-selected] {
        background-color: #3498DB;
    }
    body .select2-container--default .select2-results__option[id$="unassigned"],
    body .select2-container--default .select2-selection__rendered[title="(unassigned)"] {
        font-style: italic;
    }
.student#dashboard .filters div:nth-of-type(n+3) {
    display: none;
}
#grade-summary-info {
    position: absolute;
    right: 5px;
    bottom: 0;
    display: none;
}
    #grade-summary-info:before {
        margin-right: 10px;
    }
    #grade-summary-info:after {
        content: ' %';
        font-size: 0.75em;
    }
#grade-summary-info.for-course,
#grade-summary-info.for-student,
#grade-summary-info.for-self {
    display: inline;
}
#grade-summary-info.for-course {
    transform: translateY(-25px);
}
    #grade-summary-info.for-course:before {
        content: 'Class Average: ';
    }
    #grade-summary-info.for-student:before {
        content: 'Student Score: ';
    }
    #grade-summary-info.for-self:before,
    .student#dashboard #grade-summary-info:before {
        content: 'Score: ';
    }
#download-csv, #csv-requirement {
    position: absolute;
    right: 5px;
    bottom: 0;
    display: none;
    font-size: 14px;
}
#download-csv {
    color: blue;
    text-decoration: underline;
    cursor: pointer;
}
#csv-requirement {
    cursor: default;
}
.teacher .for-course + #download-csv,
.teacher .download-csv + #download-csv,
.teacher #grade-summary-info.csv-requirement ~ #csv-requirement {
    display: inline;
}
@media (max-width: 699px) {
    #grade-summary-info,
    #csv-requirement,
    #download-csv {
        top: -30px;
        bottom: auto;
    }
    .submit-grades-to-google-classroom {
        visibility: hidden;
    }
}

/*table {
    border-collapse: collapse;
    width: 100%;
    border: 1px solid black;
}
td, th {
    border: 1px solid black;
    padding: 8px;
}
.student#dashboard table .student {
    display: none;
}
tr:first-of-type {
    background-color: #3498DB;
    color: whitesmoke;
}*/
.row .fa-ul {
    margin-top: 0;
    margin-bottom: 0;
}
.row .fa-times:before {
    color: red;
}
.row .fa-check:before {
    color: green;
}/*
.row .score {
    outline: 0;
    text-align: right;
}
.row .maxscore {
    text-align: center;
}*/
.docent-necessary-message {
    text-align: center;
}

/* New Grades UI */
.table .question {
    background-color: #3498DB;
    color: #fff;
    padding: 5px 35px;
    font-size: 16px;
    font-weight: 700;
    position: relative;
    min-height: 29px;
    line-height: 29px;
    -webkit-font-smoothing: antialiased;
    -moz-osx-font-smoothing: grayscale;
    margin-top: 29px;
    border-radius: 10px 10px 0 0;
}
    .table .question .maxscore {
        float: right;
        margin-right: -20px;
        margin-left: 20px;
        font-weight: 400;
    }
        .table .question .maxscore:after {
            content: ' pts';
        }
    .table .question:before {
        width: 24px;
        font-size: 24px;
        line-height: 28px;
        position: absolute;
        top: 5px;
        left: 5px;
        text-align: center;
        margin-right: 5px;
        font-family: FontAwesome;
        content: "\f128";
        display: inline-block;
        font-weight: normal;
        -webkit-font-smoothing: antialiased;
        -moz-osx-font-smoothing: grayscale;
        color: #fff;
    }
    .table .question * {
        color: inherit !important;
        font-family: inherit !important;
    }
.table .row {
    border: 1px solid #3498DB;
    border-top: 0;
    padding: 20px;
    position: relative;
    line-height: 29px;
    background-color: #fff;
}
@media (min-width: 641px) {
.table .row {
    font-weight: 400;
    -webkit-font-smoothing: antialiased;
    -moz-osx-font-smoothing: grayscale;
    color: #333;
}
    .table .row .student {
        position: absolute;
        top: 50%;
        left: 15px;
        line-height: 20px;
        width: 125px;
        transform: translateY(-50%);
        max-height: calc(100% - 10px);
        overflow: hidden;
        text-overflow: ellipsis;
    }
}
@media (max-width: 640px) {
    .table .row .student {
        position: relative;
        top: -10px;
        display: inline-block;
        font-weight: 400;
    }
        .table .row .student span {
            display: none;
        }
}
    .table .row .answer {
        width: 100%;
        display: inline-block;
        font-size: 16px;
        padding: 0 80px 0 160px;
        box-sizing: border-box;
    }
        .table .row .answer .fa-li {
            line-height: inherit;
            top: 0;
        }
    .table .row .answer:empty:before {
        content: 'no answer';
        opacity: 0.4;
        font-style: italic;
    }
    .table .row .feedback {
        display: block;
        margin-top: 10px;
        margin-left: 160px;
        width: calc(100% - 320px);
        padding: 5px 10px;
        font-size: 16px;
        color: #333;
        background-color: #f5f5f5;
        border: 1px solid #ccc;
        border-radius: 5px;
        position: relative;
    }
    .table .row .feedback:empty:before {
        content: 'Provide some feedback...';
        opacity: 0.4;
        cursor: text;
    }
    .table .row .feedback[contenteditable="false"]:empty {
        display: none;
    }
    .table .row .feedback[contenteditable="false"]:before {
        content: attr(data-name);
        display: block;
        font-size: 12px;
        font-weight: 400;
        text-decoration: underline;
        color: #000;
        line-height: 24px;
        margin-top: -2px;
        margin-bottom: 2px;
    }
    .table .row .feedback[contenteditable="false"]:after {
        content: attr(data-time);
        font-size: 12px;
        position: absolute;
        top: 5px;
        right: 10px;
        line-height: 20px;
    }
@media (max-width: 640px) {
    .table .row .answer {
        padding: 0;
    }
    .table .row .feedback {
        margin-left: 0;
        width: calc(100% - 20px);
        font-weight: 400;
    }
}
    .table .row :focus {
        outline: 0;
        box-shadow: 0 0 1px 1px #6af;
        border-color: #6af !important;
    }
    .table .row .score {
        outline: 0;
        text-align: right;
        position: absolute;
        top: 50%;
        transform: translateY(-50%);
        width: 50px;
        right: 15px;
        min-height: 20px;
        padding: 5px;
    }
    .table .row input.score {
        font-family: Lato;
        border: 1px solid #ccc;
        background-color: #f5f5f5;
        border-radius: 5px;
        font-size: 15px;
        -webkit-appearance: none;
        -webkit-font-smoothing: antialiased;
        -moz-osx-font-smoothing: grayscale;
    }
    .table .row .score-submitted {
        position: absolute;
        right: 14px;
        top: 50%;
        font-size: 14px;
        transform: translateY(33.33%);
    }
    .table .row .score-submitted:before,
    .table .row .feedback-submitted:after {
        content: 'Submitted'
    }
    .table .row .feedback-submitted {
        position: absolute;
        right: 160px;
        bottom: -4px;
        font-size: 14px;
    }
@media (max-width: 640px) {
    .table .row .score {
        top: 10px;
        transform: none;
    }
    .table .row .score-submitted {
        top: 24px;
    }
    .table .row .score-submitted,
    .table .row .feedback-submitted {
        font-weight: 400;
        font-size: 12px;
        right: 18px;
    }
}
.table .last.row {
    border-radius: 0 0 10px 10px;
}
.table .fixed.question {
    position: fixed;
    top: 29px;
    width: 900px;
    box-sizing: border-box;
    max-width: 100%;
    box-shadow: 0px -10px 0px 10px whitesmoke;
    z-index: 1;
}
.table .fixed.question + .row {
    margin-top: 68px;
}
#payment-banner ~ #body .table .fixed.question {
    top: 73px;
}
/**/

[disabled] {
    opacity: 0.5;
    cursor: wait;
}

.ask-us {
    height: 32px;
    min-width: 107px;
    background-color: #559;
    color: whitesmoke;
    border-radius: 8px;
    border: 0;
    font-family: Lato;
    font-size: 14px;
    font-weight: 400;
    position: absolute;
    top: 3px;
    left: 100px;
    cursor: pointer;
    outline: 0;
    -webkit-font-smoothing: antialiased;
    -moz-osx-font-smoothing: grayscale;
}
.student .ask-us {
    display: none;
}
.help-documentation {
    padding: 0 25px;
}
    .help-documentation > p {
        line-height: 175%;
    }
    .help-student-only,
    .student .help-teacher-only {
        display: none;
    }
    .student .help-student-only {
        display: block;
    }
.sign-out {
    background-color: #3498DB;
    color: #FFF;
    border-radius: 8px;
    border: 0;
    font-family: Lato;
    font-weight: 400;
    font-size: 14px;
    height: 32px;
    min-width: 67px;
    margin: 16px auto;
    display: block;
    cursor: pointer;
    -moz-osx-font-smoothing: grayscale;
    -webkit-font-smoothing: antialiased;
}
.student .newsletter-opt-in {
    display: none;
}
.newsletter-opt-in {
    text-align: center;
    margin-bottom: 18px;
}
    .newsletter-opt-in label,
    .newsletter-opt-in input {
        cursor: pointer;
    }
.switch-user-type {
    font-size: 13px;
    display: block;
    text-align: center;
    color: #3498DB;
    text-decoration: underline;
    cursor: pointer;
    font-weight: 400;
    -moz-osx-font-smoothing: grayscale;
    -webkit-font-smoothing: antialiased;
}
    .switch-user-type:before {
        content: 'Switch to a student account';   
    }
    .student .switch-user-type:before {
        content: 'Switch to a teacher account';   
    }

.tools-to-embed iframe,
.examples iframe {
    width: 100%;
    height: 2500px;
    border: 1px solid #ccc;
    background-color: white;
}

.invite-contacts, .install-extension {
    font-family: Lato;
    font-size: 12px;
    background-color: #E1F0FA;/*rgba(52, 152, 219, 0.15);*/
    color: #333;
    -moz-osx-font-smoothing: grayscale;
    -webkit-font-smoothing: antialiased;
    position: absolute;
    top: 6px;
    height: 32px;
    border: 0;
    border-radius: 5px;
    cursor: pointer;
    padding: 0;
    min-width: 105px;
    outline: 0;
    line-height: normal;
    left: calc(50% + 160px);
}
.invite-contacts {
    display: none;
}
.teacher .invite-contacts {
    display: inline-block;
}
.install-extension {
    background-color: #ED236F;
    color: #fff;
}
[data-extension-version] .install-extension {
    display: none;
}
@media (max-width: 639px) {
    #dashboard .invite-contacts, .install-extension {
        display: none;
    }
}
#payment-iframe {
    display: none;
    position: fixed;
    top: 0;
    left: 0;
    height: 100%;
    width: 100%;
    border: 0;
    z-index: 4;
}

.activating {
    position: fixed;
    top: 33%;
    left: 50%;
    transform: translate(-50%, -33%);
    -webkit-transform: translate(-50%, -33%);
    border-radius: 5px;
    color: #fff;
    background-color: #666;
    font-family: Lato, sans-serif;
    font-weight: 400;
    -moz-osx-font-smoothing: grayscale;
    -webkit-font-smoothing: antialiased;
    text-align: center;
    margin: 0;
    font-size: 24px;
    padding: 8px 12px;
    line-height: 28px;
}
    .activating > .fa {
        margin-right: 8px;
        margin-left: 0;
        height: auto;
        width: auto;
    }

.survey-footer {
    position: fixed;
    bottom: -100%;
    height: 150px;
    width: 100%;
    left: 0;
    background-color: white;
    box-shadow: 0 1px 3px 0 rgba(0,0,0,0.4);
    transition: bottom 0.4s ease;
    font-family: Lato;
}
.survey-close {
    height: 44px;
    width: 44px;
    line-height: 44px;
    font-size: 28px;
    text-align: center;
    position: absolute;
    right: 0;
    cursor: pointer;
    color: #555;
}
.survey-description {
    text-align: center;
    position: relative;
    top: 50%;
    transform: translateY(-50%);
    line-height: 150%;
    font-size: 18px;
    padding: 0 10px;
}
