html {
	-ms-text-size-adjust: 100%;
	-webkit-box-sizing: border-box;
	-webkit-text-size-adjust: 100%;
	box-sizing: border-box;
	color: rgba(0, 0, 0, 0.87);
	line-height: 1.5;
	font-family: -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, Oxygen-Sans, Ubuntu, Cantarell, "Helvetica Neue", sans-serif;
	font-weight: normal;
}
body, html {
	background: #f5f5f5;
}
body {
	caret-color: transparent;
	margin: 0;	/* VOD*/
}

#hider {
	background: #000;
	height: 100%;
	min-height: 100vh;
	left: 0px;
	opacity: 0.5;
	position: absolute;
	top: 0px;
	width: 100vw;
	z-index: 100;
}
#loader {
	align-items: center;
	display: flex;
	height: 100%;
	justify-content: center;
	left: 0px;
	min-height: 100vh;
	position: absolute;
	top: 0px;
	width: 100vw;
	z-index: 100;
}

*, ::before, ::after {
	-webkit-box-sizing: inherit;
	box-sizing: inherit;
}
input {
	caret-color: #000;
}
@media only screen and (min-width: 0) {
	html {
		font-size: 14px;
	}
	.desktop-only {
		display: none;
	}
	.mobile-only {
		display: block;
	}
}
@media only screen and (min-width: 992px) {
	html {
		font-size: 14.5px;
	}
	.desktop-only {
		display: block;
	}
	.mobile-only {
		display: none;
	}
}
@media only screen and (min-width: 1200px) {
	html {
		font-size: 15px;
	}
}
.hidden {
	display: none;
}
a, .create-link {
	color: #0056a4;
	text-decoration: none;
}
#sysMsg {
    position: fixed;
    top: 0;
    left: 50%;
    transform: translateX(-50%);
    background-color: rgba(0, 0, 0, 0.8);
    color: #ffffff;
    font-family: 'Courier New', Courier, monospace;
    padding: 1em 1.5em;
    border-radius: 0.25em;
    box-shadow: 0 0.25em 0.75em rgba(0, 0, 0, 0.5);
    z-index: 0;
    opacity: 0;
    transition: opacity 0.5s ease, display 1s ease;
}
#sysMsg.msg-displaying {
	opacity: 1;
    z-index: 1000;
}
.successMsg {
	color: rgba(76, 175, 80, 0.9);
}
.warnMsg {
	color: rgba(255, 152, 0, 0.9);
}
.errorMsg {
	color: rgba(244, 67, 54, 0.9);
}
header {
	background: -o-linear-gradient(bottom, #d7ecff, rgba(215, 236, 255, 0.1));
	background: -webkit-gradient(linear, left bottom, left top, from(#d7ecff), to(rgba(215, 236, 255, 0.1)));
	background: -webkit-linear-gradient(bottom, #d7ecff, rgba(215, 236, 255, 0.1));
	background: linear-gradient(0deg, #d7ecff, rgba(215, 236, 255, 0.1));
	background-color: #d7ecff;
	background-position: 50% center;
	background-repeat: no-repeat;
	background-size: cover;
	display: block;
	padding: 5em 5em 0 5em;
}
#header {
	-ms-flex-pack: justify;
	-ms-flex-wrap: wrap;
	-webkit-box-pack: justify;
	display: -ms-flexbox;
	display: -webkit-box;
	display: flex;
	flex-wrap: wrap;
	justify-content: space-between;
	margin: 0 auto;
	max-width: 1400px;
	position: relative;
}
#logo {
	-ms-flex: 0 0 calc(33% - 8em);
	-webkit-box-flex: 0;
	background-color: transparent;
	background-image: url('/images/KWA-Logo.png');
	background-repeat: no-repeat;
	background-position: center left;
	background-size: contain;
	display: block;
	flex: 0 0 calc(33% - 8em);
	height: 8em;
	width: calc(33% - 8em);
}
#grant {
	background: url('/images/Kompetenzzentrum_Weiterbildung.png');
	background-position: center;
	background-repeat: no-repeat;
	background-size: contain;
	height: 150px;
	position: absolute;
	right: -3em;
	top: -3em;
	width: 150px;
	z-index: 1;
}
#main {
	background: -webkit-gradient(linear, left top, left bottom, from(#d7ecff), color-stop(#d7ecff), color-stop(8rem, #f5f5f5), to(#f5f5f5));
	background: -webkit-linear-gradient(#d7ecff 0%, #d7ecff 8rem, #f5f5f5 8rem, #f5f5f5 100%);
	background: -o-linear-gradient(#d7ecff 0%, #d7ecff 8rem, #f5f5f5 8rem, #f5f5f5 100%);
	background: linear-gradient(#d7ecff 0%, #d7ecff 8rem, #f5f5f5 8rem, #f5f5f5 100%);
	padding: 0 5em;
}
#main-wrapper {
	-ms-flex-pack: justify;
	-webkit-box-pack: justify;
	display: -ms-flexbox;
	display: -webkit-box;
	display: flex;
	justify-content: space-between;
	max-width: 1400px;
	margin: 0 auto;
	position: relative;
}
#login-indicator {
	font-size: 13px;
	margin-left: 0.5em;
	margin-right: 0.5em;
	margin-top: 2em;
}
#login-indicator-mobile {
	display: none;
	font-size: 13px;
}
#menu-links {
	-ms-flex: 0 0 calc(33% - 3em);
	-ms-flex-order: 1;
	-webkit-box-ordinal-group: 2;
	-webkit-box-flex: 0;
	display: block;
	flex: 0 0 calc(33% - 3em);
	padding: 8em 0 0 0;
	min-width: 15em;
}
#menu-links-internal {
	-ms-flex: 0 0 calc(33% - 3em);
	-ms-flex-order: 1;
	-webkit-box-ordinal-group: 2;
	-webkit-box-flex: 0;
	display: block;
	flex: 0 0 calc(33% - 3em);
	padding: 2.4em 0 0 0;
	min-width: 15em;
}
#menu-links-internal-mobile {
	background-color: #d7ecff;
	display: none;
}
.mobile-only {
	z-index: 10000;
}
.menu-link {
	background: none;
	color: #0056a4;
	cursor: pointer;
	display: block;
	padding: 1em;
	border-bottom: 1px solid #d7ecff;
}
.menu-intern {
	border-bottom: 1px solid rgba(76, 175, 80, 0.75);
}
.menu-link:hover, .menu-active, .submenu-active {
	background: #fff;
	border-bottom: 1px solid #0056a4;
	color: #000;
}
.submenu {
	margin-left: 1em;
}
#mBtn {
	cursor: pointer;
	display: none;
	font-size: 32px;
}
#detach-btn, #attach-btn {
	cursor: pointer;
	position: absolute;
	right: 2em;
	top: 1em;
}
#detach-btn {
    z-index: 1000;
}
#attach-btn {
    z-index: 5000;
}
#p-window h3 {
    z-index: 4000;
}
#reduce-visibility {
    background-color: #000;
    height: 100vh;
    left: 0px;
    opacity: 0.6;
    position: fixed;
    top: 0px;
    width: 100vw;
    z-index: 2000;
}
#p-window {
    background: #fff;
    height: 100vh;
    left: 10vw;
    overflow-y: auto;
    padding-left: 1em;
    padding-right: 1em;
    position: fixed;
    top: 0px;
    width: 80vw;
    z-index: 3000;
}
main {
	-webkit-box-shadow: 0 1px 3px rgba(0, 0, 0, 0.12), 0 1px 2px rgba(0, 0, 0, 0.24);
	background: #fff;
	border-radius: 2px;
	box-shadow: 0 1px 3px rgba(0, 0, 0, 0.12), 0 1px 2px rgba(0, 0, 0, 0.24);
	display: block;
	padding-bottom: 1em;
	padding-left: 1em;
	padding-right: 1em;
	position: relative;
	width: 100%;
	z-index: 2;
}
.main-form {
	padding-bottom: 2em;
}
.tooltip:hover:after {
	content: attr(data-tooltip);
}
.main-form input {
	caret-color: #000;
}
#p-window .main-form {
	height: 90vh;
}
.main-form details summary {
	cursor: pointer;
	margin-bottom: 0.5em;
}
.flexbox {
	align-items: center;
	display: flex;
	flex-flow: wrap;
	justify-content: space-between;
}
.flexbox div {
	min-width: 48%;
	padding: 0.25em;
	margin-bottom: 0.5em;
}
div .single-line {
	min-width: 100%;
}
.main-form label {
	display: block;
	font-weight: bold;
}
.main-form label {
	display: block;
	font-weight: bold;
}
.main-form input[type='text'] {
	height: 2em;
	width: calc(100% - 0.5em - 1px);
}
.main-form input[type='password'] {
	height: 2em;
	width: calc(100% - 0.5em - 1px);
}
.main-form input[type='number'] {
	height: 2em;
	width: calc(100% - 0.5em - 1px);
}
.main-form input[type='date'] {
	height: 2em;
	width: calc(100% - 0.5em - 1px);
}
.main-form input[type='tel'] {
	height: 2em;
	width: calc(100% - 0.5em - 1px);
}
.main-form input[type='email'] {
	height: 2em;
	width: calc(100% - 0.5em - 1px);
}
.main-form select {
	width: 100%;*/
	height: 2em;
	width: calc(100% - 0.5em - 4px);
}
.main-form input[type='submit']:disabled {
	background: #555;
}
.main-form input[type='submit'], .submit-btn {
	background: #0056a4;
	border: none;
	border-radius: 2px;
	color: #fff;
	font-size: 1.1em;
	padding: 0.33em 0.66em;
	box-shadow: 0px 1px 2px #b0b0b0;
}
.cb-label {
	font-weight: bold;
}
.f-required {
	font-weight: normal;
	color: #f00;
}
.f-description {
	color: #666;
	font-size: smaller;
}
#add-site label {
	display: inline-block;
	margin-bottom: 0.5em;
	min-width: 15em;
}
#add-site input {
	margin-bottom: 0.5em;
	width: 15em;
}
#add-site select {
	margin-bottom: 0.5em;
	width: 15.6em;
}
.search {
	text-align: right;
	width: 100%;
}
.members-list-options {
	text-align: center;
}
.list-options-button {
	background: #fff;
	border: none;
	border-radius: 2px;
	color: #fff;
	cursor: pointer;
	box-shadow: 0px 1px 2px transparent;
	padding: 0;
	height: 1em;
}
.list-options-button:hover {
	-webkit-filter: invert(100%);
    filter: invert(100%);
	box-shadow: 0px 1px 2px #b0b0b0;
}
.list-table {
	display: table;
	width: 100%;
}
.list-head {
	font-weight: bold;
}
.list-head, .list-row {
	display: table-row;
}
.list-row:nth-of-type(2n) {
	background: #f5f5f5;
}
.list-cell {
	display: table-cell;
	padding: 4px;
}
.list-row .staff-list-name, .list-row .members-list-name, .list-link, .curriHlLnk {
	cursor: pointer;
}
.list-row.green {
	border: 1px solid #2fbb2f;
	color: #2fbb2f;
}
.list-row.red {
	border: 1px solid #f00;
	color: #f00;
}
footer {
	margin: 0 auto;
	max-width: 1400px;
}
#footer-partner h4 {
	font-size: 2rem;
	font-weight: 400;
	margin-top: 2em;
}
#footer-partner-links {
	-ms-flex-pack: justify;
	-ms-flex-wrap: wrap;
	-webkit-box-pack: justify;
	display: -ms-flexbox;
	display: -webkit-box;
	display: flex;
	flex-wrap: wrap;
	justify-content: space-between;
	position: relative;
	top: -2em;
}
#footer-partner-links a {
	display: inline-block;
	height: 5rem;
	width: calc(20% - 2rem);
}
.footer-partner-link {
	width: 100%;
	height: 100%;
	background-size: contain;
	background-repeat: no-repeat;
	background-position: center center;
	filter: grayscale(100%);
}
#footer-links-external {
	-ms-flex-pack: justify;
	-webkit-box-pack: justify;
	border-top: 1px solid #d7ecff;
	display: -ms-flexbox;
	display: -webkit-box;
	display: flex;
	justify-content: space-between;
	padding: 1em 0 3em 0;
}
#footer a {
	text-decoration: none;
	color: #0056a4;
}
#footer-content {
	border-top: 1px solid #d7ecff;
	padding: 1em 0 3em 0;
}
footer hr {
	color: #000;
	width: 98.4%;
	margin: auto;
}
#footer-left, #footer-right {
	display: inline-block;
}
#footer-left {
	text-align: left;
	width: 49.65%;
}
#footer-right {
	text-align: right;
	width: 50%;
}
#footer-right a {
	margin-left: 2em;
}
#user-profile figure img {
	max-height: 250px;
}
#user-profile details summary {
	cursor: pointer;
}
#user-profile-infos {
	align-items: last baseline;
	display: flex;
	flex-wrap: nowrap;
}
.formfield-invalid {
	border: 1px solid #f00;
}
.formfield-valid {
	border: 1px solid #d7ecff;
}
.formfield-CB-invalid {
	outline: 1px solid #f00;
}
.formfield-CB-valid {
	outline: 1px solid transparent;
}
.inner-vtop {
	vertical-align: top;
}
#curriculumArea {
	display: flex;
	flex-wrap: wrap;
	justify-content: space-between;
	margin: 0 auto;
	max-width: 79em;
	overflow: hidden;
	position: relative;
}
.inlined {
	display: inline-block;
}
.text-right {
	text-align: right;
}
.no-wrap {
	white-space: nowrap;
}
#curriculum-view-control {
	cursor: pointer;
	position: absolute;
	top: 1em;
	right: 4em;
}
#caHeadline {
	cursor: pointer;
}
#tileMenu {
	display: flex;
	justify-content: space-evenly;
}
.tileMenuSingle > div {
	margin: 0px auto;
}
.tile {
	border: 2px solid #d7ecff;
	color: #333;
	cursor: pointer;
	font-family: Arial, Helvetica, sans-serif;
	font-size: 1rem;
	font-weight: bold;
	margin-bottom: 1em;
	margin-top: 1em;
	max-width: calc(100% / 4 - 1em);
	min-height: 3em;
	min-width: 14.5em;
	overflow: hidden;
	position: relative;
	text-align: center;
	width: calc(100% / 4 - 1em);
}
.progressBar {
	border-radius: 5px;
	height: 4px;
	line-height: 8px;
	margin: 0.5em;
	overflow: hidden;
	padding: 0;
	position: relative;
	width: calc(100% - 1em);
	z-index: 3;
}
.percentBox {
	display: inline-block;
	height: 8px;
	line-height: 8px;
	width: 0.25%;
}
.percentFinished {
	background: #32cd32;
}
.percentUnfinished {
	background: #f2f2f2;
}
.tile-background {
	height: 100%;
	left: 0px;
	position: absolute;
	top: 0px;
	width: 100%;
	z-index: 1;
}
.tileFinished {
	/*background-color: #22af22;*/
}
.tileUnfinished {
	/*background-color: #e86100;*/
}
.hovered {
	background-color: #d7ecff;
}
.hovered-border {
	/*border: 1px solid #000;
	box-shadow: 2px 8px 8px #000;*/
}
.tile-text {
	align-items: center;
	display: flex;
	height: calc(100% - 4px - 2em);
	justify-content: center;
	margin: 0.5em;
	position: relative;
	z-index: 3;
}
.tile-control {
	height: 100%;
	left: 0px;
	position: absolute;
	top: 0px;
	width: 100%;
	z-index: 4;
}
@keyframes fadeOut {
	0% {
		opacity: 1;
	}
	50% {
		opacity: 0.5;
	}
	100% {
		opacity: 0;
		visibility: hidden;
	}
}
@keyframes fadeIn {
	0% {
		opacity: 0;
	}
	50% {
		opacity: 0.5;
	}
	100% {
		opacity: 1;
	}
}
.subjectTileSelected {
	box-shadow: 2px 8px 8px transparent;
	cursor: unset;
	display: none;
	flex: 1 1 78em;
	max-height: auto;
	max-width: 100%;
	transition: flex 2s;
	width: 100%;
}
.subjectTileSelectedSecond, .contentTileSelectedSecond {
	display: none;
	flex: 1 1 30%;
	max-height: auto;
	max-width: calc(50% - 1.5em);
	transition: flex 2s;
	width: calc(45% - 1em);
}
.subjectTileSelectedSecond {
	cursor: pointer;
}
.contentTileSelectedSecond {
	cursor: unset;
}
.contentTiles {
	display: flex;
	flex-wrap: wrap;
	max-width: 79em;
	width: 100%;
	overflow: hidden;
	margin: 0 auto;
	justify-content: space-between;
	position: relative;
	padding: 0;
}
.subjectTileSelectedSecond:hover,
.contentTileSelected:hover {
	background-color: #000;
}
#curriculumArea details {
	margin: 0 auto;
	max-width: 97%;
}
#curriculumArea details summary {
	cursor: pointer;
}
.formRow {
	margin-bottom: 0.5em;
}
.formRow label {
	display: inline-block;
	font-weight: bold;
	min-width: 11em;
}
.formRow select, .formRow textarea {
	min-width: 15em;
}
.folders {
	display: flex;
	flex-wrap: wrap;
	max-width: 79em;
	width: 100%;
	overflow: hidden;
	margin: 0 auto;
	justify-content: space-evenly;
}
.folder {
	position: relative;
	flex-grow: 1;
	border: 1px solid #d7ecff;
	color: #000;
	min-height: 50vh;
	max-height: 50vh;
	margin: 1em;
	text-align: left;
	overflow-x: hidden;
	overflow-y: scroll;
	font-size: 0.8em;
	padding: 0.5em;
	flex: 0.5 1 45%;
}
.folder div {
	margin-bottom: 1em;
}
.folder div span {
	cursor: pointer;
	font-size: 1.2em;
}
.folder div span:hover {
	text-decoration: underline;
}
.folder h2 img {
	position: relative;
	top: 0.1em;
	width: 1.5em;
	height: 1.5em;
	margin-right: 0.2em;
}
.folder div span img {
	position: relative;
	top: 0.1em;
	width: 1.2em;
	height: 1.2em;
	margin-right: 0.2em;
}
.folder-teacher {
	border: 1px dotted #000;
	margin-bottom: 1em;
	margin-left: 1em;
	margin-right: 1em;
	padding: 0.5em;
}
.dropping {
	background: #eee;
	border: 2px solid #00f;
}

.file-entry {
	overflow: hidden;
	position: relative;
	width: 100%;
	white-space: nowrap;
	text-overflow: ellipsis;
}
.vertical-middle {
	align-items: center;
	display: flex;
	justify-content: center:
}
.finish-btn {
	background: #0f0fff;
	border-radius: 3px;
	box-shadow: 2px 8px 8px transparent;
	color: #fff;
	cursor: pointer;
	display: inline-block;
	margin-left: 1em;
	padding: 0.25em 1em;
	position: absolute;
	right: 0px;
}
.finish-btn:hover {
	background: #22af22;
	box-shadow: 2px 8px 8px #000;
}
.finished-icon {
	box-shadow: 2px 8px 8px transparent;
	display: inline-block;
	margin-left: 1em;
	padding: 0.25em 1em;
	position: absolute;
	right: 0px;
}
.delete-btn {
	background: #ff0f0f;
	border-radius: 3px;
	box-shadow: 2px 8px 8px transparent;
	color: #fff;
	cursor: pointer;
	display: inline-block;
	margin-left: 1em;
	padding: 0.25em 1em;
	position: absolute;
	right: 0px;
}
.delete-btn:hover {
	background: #af2222;
	box-shadow: 2px 8px 8px #000;
}
.event-list-date {
	width: 17em;
	text-align: center;
}
.event-list-free {
	text-align: right;
}
#event-scheduler-box {
	min-width: 100%;
}
.scheduler-day {
}
.hidden-day {
	display: none;
}
.scheduler-day-menu {
	text-align: center;
}
.num-link {
	display: inline-block;
	cursor: pointer;
	text-decoration: underline;
}
.num-link-active {
	cursor: default;
	text-decoration: none;
	font-weight: bold;
}
.schedule-table {
	border: 1px solid #000;
    border-collapse: collapse;
	border-radius: calc(1em / 3);
	margin-bottom: 2em;
	margin-top: 2em;
	min-height: 5em;
	width: 100%;
}
.scheduler-field {
	font-size: 0.9rem;
}
.room-info {
	color: #f33;
}
.scheduler-desktop-only {
	display: table-cell;
}
.scheduler-mobile-only {
	display: none;
}
.scheduler-day-head .event-date, .scheduler-day-row .event-time {
	background-color: rgba(30, 30, 30, 0.1);
	text-align: center;
	width: 7em;
}
.scheduler-day-row .scheduler-field, .scheduler-day-row .scheduler-line {
	vertical-align: top;
}
.scheduler-day-row:last-of-type .scheduler-field, .scheduler-day-row:last-of-type .scheduler-line {
	border-bottom: none;
}
.scheduler-line {
	background: #fff;
}
.scheduler-field, .scheduler-line {
	border-bottom: 1px solid #000;
	padding: 0.25em;
	position: relative;
}
.scheduler-field {
	border-right: 1px solid #000;
}
.scheduler-field:last-of-type {
	border-right: none;
}
.scheduler-field:nth-of-type(2n) {
	background-color: #d7ecff;
}
#booked-message {
	font-weight: bold;
	border-bottom: 1px solid #d7ecff;
}
#participated-message {
	font-weight: bold;
	border-bottom: 1px solid #d7ecff;
}
.hlSummary {
	cursor: pointer;
	font-weight: bold;
}
.flexdetail {
	align-items: center;
	display: flex;
	flex-flow: wrap;
	justify-content: space-between;
	margin-bottom: 1em;
}
.eLabel {
	border-bottom: 1px solid #000;
}
.right {
	text-align: right;
}
.center {
	text-align: center;
}
#btnBuy {
	background: #d7ecff;
	border: 1px solid transparent;
	border-radius: 0.25em;
	color: #000;
	cursor: pointer;
	font-size: 1.2em;
	margin-bottom: 2em;
	margin-top: 2em;
	padding: 1em;
	text-align: center;
}
#btnBuy:hover {
	border: 1px solid #000;
	font-weight: bold;
}
.sRegBtn {
	position: absolute;
	right: 0.5em;
	top: 1.5em;
}
.btnJoin {
	background: #d7ecff;
	border: 1px solid transparent;
	border-radius: 0.25em;
	color: #000;
	cursor: pointer;
	padding: 0.5em 1em;
	text-align: center;
	width: 6em;
}
.btnJoin:hover {
	border: 1px solid #000;
	font-weight: bold;
}
.curriculum-content-teacher {
	cursor: pointer;
	display: block;
	margin-left: 1em;
}
.curriFile {
	display: inline-flex;
	align-items: center;
}
.event-headline {
	display: inline-block;
}
.event-info {
	display: inline-block;
}
.list-item {
	display: inline-block;
}
.link {
	cursor: pointer;
	border-bottom: 1px solid transparent;
	color: #0056a4;
}
.link:hover {
	border-bottom: 1px solid #0056a4;
}
.detail-row div:first-of-type {
	margin-left: 0;
}
.te-label {
	display: inline-block;
	font-weight: bold;
	margin-left: 1em;
	vertical-align: top;
	width: 9.75em;
}
#waitScreen {
	background: #000;
	height: 100vh;
	left: 0px;
	opacity: 0.3;
	position: fixed;
	top: 0px;
	width: 110vw;
	z-index: 10000;
}
.folder-teacher div:last-of-type {
	margin-bottom: 2em;
}
.folderContainer {
	width: 50em;
}
#user-academic-grade-suggestion-box {
	border-radius: calc(1em / 3);
	border-bottom: 1px solid #d7ecff;
	border-left: 1px solid #d7ecff;
	border-right: 1px solid #d7ecff;
	max-height: 10em;
	overflow-y: auto;
}
#user-academic-grade-suggestion-box .highlight {
	background-color: #d7ecff;
	font-weight: bold;
}

#mentor-block {
	align-items: flex-start;
	display: flex;
}
.mentor-profile-image {
	display: block;
	margin: 0px auto;
	max-height: 250px;
}
#mentor-block figcaption {
	display: none;
	font-size: 1.5rem;
	font-weight: bold;
	text-align: center;
}
#mentor-data {
	flex: content;
	width: 60%;
}
.profile-table {
	display: table;
	width: 100%;
}
.profile-row {
	display: table-row;
}
.profile-cell {
	display: table-cell;
}
.lTitle {
	font-weight: bold;
}
#map {
	height: 20rem;
	margin-top: 1rem;
	width: 100%;
}
.fullLine {
	margin-top: 1rem;
	width: 100%;
}
#board-entry-add {
	margin-bottom: 1em;
}
#board-content-input {
	height: 8rem;
	caret-color: #000;
}

#alerter {
	position: fixed;
	top: 0px;
	left: 20%;
	height: 100%;
	width: 60%;
	min-width: 680px;
	background: #fff;
	color: #000;
	z-index: 10000;
	padding: 1em;
	overflow-x: hidden;
	overflow-y: auto;
}
#alerter-btns {
	display: flex;
	flex-wrap: nowrap;
	justify-content: center;
	flex-direction: row;
}
#alerter-btns > div {
	border: 1px solid #aaa;
	color: #aaa;
	cursor: pointer;
}
#alerter-btns > div:hover {
	border: 1px solid #fff;
	color: #fff;
}
#user-academic-grades {
	display: flex;
}
#user-academic-grades div, .user-academic-grade-box {
	background-color: #d7ecff;
	border-radius: 1em;
	margin: 0px 1em 0px 0px;
	min-width: 1em;
	padding-left: 0.5em;
	padding-right: 0.5em;
	width: auto;
}
.grade-deleter {
	color: #f00;
	cursor: pointer;
	font-size: 12px;
	vertical-align: super;
}
#pageToSmall {
	display: none;
}
#pageToSmall img {
	width: 100vw;
}
#sg-selector {
	position: relative;
	display: none;
}
.blue-selector {
	background-color: #d7ecff;
	border: none;
	border-radius: 0.25em;
	right: 1.25em;
	padding: 0.5em 1em;
	position: absolute;
}
@media only screen and (max-width: 259px) {
	#sysMsg, #page {
		display: none;
	}
	#pageToSmall {
		display: block;
	}
}
@media only screen and (min-width: 260px) and (max-width: 639px) {
	header {
		height: 10em;
		padding: 1em 1em 0 1em;
	}
	#header {
		display: block;
	}
	#logo {
		position: absolute;
		right: 0em;
		top: -1.5em;
		width: 51%;
		z-index: 10001;
	}
	#grant {
		display: none;
		top: -0.5em;
		right: -0.5em;
		z-index: 10001;
	}
	#login-indicator {
		display: none;
	}
	#login-indicator-mobile {
		display: block;
		position: absolute;
		top: 1.5em;
		left: 0px;
		margin: 0px;
		max-width: 50%;
	}
	nav.mobile-only {
		position: absolute;
		top: 5.5em;
	}
	#mBtn {
		display: inline-block;
	}
	#menu-links-internal-mobile {
		left: -1em;
		padding-bottom: 1em;
		padding-left: 1em;
		position: absolute;
		top: 2.5em;
		width: 100vw;
	}
	.menu-link {
		font-size: 18px;
		padding: 0.75em 0 0 0;
		width: calc(100vw - 2em);
	}
	#main {
		padding: 0;
	}
	#detach-btn {
		display: none;
	}
	#sg-selector {
		display: inline-block;
	}
	.scheduler-desktop-only {
		display: none;
	}
	.scheduler-mobile-only {
		display: inline-block;
	}
	.scheduler-field {
		background-color: #d7ecff;
	}
	footer {
		padding: 0 1em 0 1em;
		position: relative;
		top: -3em;
	}
	#footer-partner-links {
		justify-content: center;
		top: -3em;
	}
	#footer-partner-links a {
		height: 7em;
		padding: 0 0.5em 0.5em;
		width: calc((100vw - 2em) / 2);
	}
	#footer-links-external {
		flex-flow: wrap;
		padding: 0;
		position: relative;
		top: -3em;
		width: 100vw;
	}
	ul {
		position: relative;
		left: -1em;
	}
	#footer-content {
		align-items: center;
		display: flex;
		justify-content: center;
		padding: 1em 0 0 0;
		position: relative;
		top: -3em;
	}
	#footer-content a {
		display: block;
	}
	#footer-right {
		width: 48%;
	}
}
@media only screen and (min-width: 480px) and (max-width: 639px) {
	#logo {
		top: 0px;
	}
}
