  .faculty-schedule-table {
    float: none; 
    display: table; 
}
.faculty-schedule-table > div { 
    float: none; 
    display: table-row; 
}
.faculty-schedule-table > div > div { 
    float: none; 
    display: table-cell;
    padding: 5px;
    width:auto;
    vertical-align:top;
}
h3, h4 { margin: 10px 0 2px 0; }

/* Jolie's custom styling for schedule redesign*/
/* version 11/06/21*/
@import url('https://fonts.googleapis.com/css2?family=Cabin:ital,wght@0,400;0,500;0,600;0,700;1,400;1,500;1,600;1,700&display=swap');


main.fh_schedule {
    transition: all 0.1s linear;
    font-family: Cabin, Helvetica, Arial, sans-serif;
}

main.fh_schedule p,
main.fh_schedule h3,
main.fh_schedule h4,
main.fh_schedule div,
main.fh_schedule a,
main.fh_schedule button {
    font-family: Cabin, Helvetica, Arial, sans-serif;
}

.fh_schedbox {
    width: 100%;
    /* height: 0; */
    display: none;
    background-color: #ebebeb;
    overflow: scroll;
    transition: all 0.1s linear;
    margin-left: 20px;
    padding: 20px;
}

input:checked~.fh_schedbox {
    display: block;
}

@media(max-width: 699px) {
    .fh_searchtop-grid {
        display: grid;
        grid-template-columns: auto;
        width: 100%;
    }
	.fh_searchtop-grid2 {
        display: grid;
        grid-template-columns: auto;
        width: 100%;
    }
}

@media (min-width: 700px) {
    .fh_searchtop-grid {
        display: grid;
        grid-template-columns: 250px auto 170px;
        gap: 2px;
        padding: 2px;
        width: 100%;
    }
	.fh_searchtop-grid2 {
        display: grid;
        grid-template-columns: auto 260px;
        gap: 2px;
        padding: 2px;
        width: 100%;
    }
}


.fh_search-label {
    margin-bottom: 0px;
    font-weight: 400;
    font-size: 1.3rem;
    padding-left: 6px;
}

/* Style the search field */
/* input[type=text] */
form.fh_sched-search #fh_srchTxt {
    padding: 7px;
    font-size: 14px;
    border: 1px solid #d1d1d1;
    width: 100%;
    background: #fff;
    margin-bottom: 0px;
    height: 36px;
}



#filtr-othertext input {
    border: 1px solid #d1d1d1;
    background: #fff;
    width: 100%;
}

#filtr-othertext ::-webkit-input-placeholder {
    /* Edge */
    color: #8f8f8f;
    font-size: 11px;
    padding-left: 4px;
}

#filtr-othertext :-ms-input-placeholder {
    /* Internet Explorer */
    color: #8f8f8f;
    font-size: 11px;
    padding-left: 4px;
}

#filtr-othertext ::placeholder {
    color: #8f8f8f;
    font-size: 11px;
    padding-left: 4px;
}

/* #filtr-dow {
    display: grid;
    grid-template-columns: repeat(8, fit-content(90px));
} */

#filtr-dow div {
    overflow: hidden;
}

#filtr-dow :nth-child(5) {
    min-width: 80px;
}



.fh_srch-criteria {
    padding-left: 11px;
}

.fh_found {
    padding-left: 11px;
}



.fh_subject-grid select {
    padding: 7px;
    font-size: 14px;
    border: 1px solid #d1d1d1;
    height: 36px;
    width: 100%;
    background: #fff;
    color: #333;
    margin-bottom: 0px;
}

.fh_searchtop-grid2 .fh_subject-grid select {
    padding: 7px;
    font-size: 14px;
    border: 1px solid #d1d1d1;
    width: 100%;
    background: #fff;
    color: #333;
    margin-bottom: 0px;
	height:92px;
}

form.fh_sched-search select,
form.fh_sched-search input{
	border-radius: 0px;
}

.fh_switch {
    position: relative;
    display: inline-block;
    width: 62px;
    height: 25px;
    margin-top: 2px;
}

.fh_switch input {
    opacity: 0;
    width: 0;
    height: 0;
}

.fh_slider {
    position: absolute;
    cursor: pointer;
    top: 0;
    left: 0;
    right: 0;
    bottom: 0;
    background-color: #666;
    -webkit-transition: .4s;
    transition: .4s;
}

.fh_slider:before {
    position: absolute;
    content: "";
    height: 20px;
    width: 20px;
    left: 2px;
    bottom: 3px;
    background-color: white;
    -webkit-transition: .4s;
    transition: .4s;
}

input:checked+.fh_slider {
    background-color: #ae122a;
}

input:focus+.fh_slider {
    box-shadow: 0 0 1px #ae122a;
}

input:checked+.fh_slider:before {
    -webkit-transform: translateX(38px);
    -ms-transform: translateX(38px);
    transform: translateX(38px);
}

/* Rounded sliders */
.fh_slider {
    border-radius: 24px;
}

.fh_slider:before {
    border-radius: 50%;
}

.fh_toggle-grid {
    display: grid;
    grid-template-columns: 6fr 4fr;
    text-align: center;
    justify-items: center;
    align-items: center;
    justify-content: space-evenly;
    border: 1px solid #d1d1d1;
    background-color: #fff;
    padding: 2px;
    height: 36px;
}


input#fh_togtext {
    line-height: 18px;
    font-size: 16px;
	font-weight: 600;
    font-family: Cabin, Helvetica, Arial, sans-serif;
    margin: 0px;
    text-align: center;
    border: 0;
    padding: 7px;
    width: 100%;
    background: #fff;
}



/* Style the submit button */

.fh_grid5050>div {
    display: flex;
    align-items: flex-end;
    align-self: flex-end;
    justify-content: flex-end;
}

.fh_srch-btn {
    font-family: Cabin, Helvetica, Arial, sans-serif;
    width: 100px;
    height: 40px;
    padding: 7px;
    Margin: 7px 0px 7px 0px;
    background: #fff;
    color: #ae122a;
    font-size: 15px;
    font-weight: 500;
    border: 1px solid #ae122a;
    border-radius: 50px;
    cursor: pointer;
    /* 	box-shadow: 2px -4px 3px #ae122a; */
}

.fh_srch-btn:hover {
    background: #ae122a;
    color: #fff;
}

.fh_reset-btn {
    font-family: Cabin, Helvetica, Arial, sans-serif;
    /*     float: right; */
    text-align: center;
    width: 100px;
    height: 40px;
    padding: 7px;
    Margin: 7px 0px 7px 0px;
    background: #fff;
    color: #000 !important;
    font-size: 15px;
    font-weight: 500;
    /* text-decoration-color: #000 !important; */
    border: 1px solid #9c9c9c;
    border-radius: 50px;
    cursor: pointer;
}

.fh_reset-btn:hover {
    background: #d6d6d6;
    color: #fff;
}

/* Clear floats */
form.fh_sched-search::after {
    content: "";
    clear: both;
    /* 	display: table; */
}

.fh_dept-title {
    background-color: #333;
}

.fh_dept-title p {
    color: #fff;
    font-size: 16px;
    font-weight: 600;
    margin: 10px;
}



.fh_url a {
    text-decoration: underline;
    text-decoration-style: solid;
    text-decoration-color: #fff;
    color: #fff;
}

.fh_url a:hover {
    text-decoration-style: solid;
    text-decoration-color: #fff;
    font-weight: 400;
    color: #fff;
}

.fh_grid6030 {
    display: grid;
    grid-template-columns: 2fr 1fr;
    gap: 0px;
    padding: 0px;
    width: 100%;
    align-items: center;
}
.fh_grid2575 {
    display: grid;
    grid-template-columns: 1fr 3fr;
    gap: 4px;
    background-color: #ebebeb;
    padding: 0px 4px 4px;
}
.fh_reset-btn-simple {
    /*     width: 70px; */
    float: right;
}

.fh_grid3 {
    display: grid;
    grid-template-columns: 30% 25% auto;
    gap: 0px;
    padding: 0px;
    width: 100%;
}

.fh_seats {
    text-align: right;
    margin-right: 10px;
}
@media(max-width: 699px) {
	.fh_grid5050 {
		display: grid;
		grid-template-columns: 1fr;
		gap: 2px;
		padding: 3px;
		width: 100%;
		align-items: center;
		transition: all 0.1s linear;
	}
	.fh_dept-title p {
		text-align: center;
	}
}
@media(min-width: 700px) {
	.fh_grid5050 {
		display: grid;
		grid-template-columns: 1fr 1fr;
		gap: 2px;
		padding: 3px;
		width: 100%;
		align-items: center;
		transition: all 0.1s linear;
	}
	.fh_dept-title >p {
		text-align: left;
	}
	.fh_dept-title .fh_url {
		text-align: right;
		padding-right: 15px;
	}
}

.fh_grid5050>.fh_seats {
    text-align: right;
}

.fh_sched-grid-2-8-2 {
    display: grid;
    grid-template-columns: 2fr 8fr 2fr;
    gap: 0px;
    /*     background-color: #ebebeb; */
    padding: 0px;
    margin: 5px 1%;
    width: 99%;
}



.fh_grid-id,
.fh_grid-title,
.fh_grid-units {
    background-color: #ae122a;
}



.fh_panel-group {
    margin: 1px 1% 0px 1%;
    width: 99%;
}

.panel-group#fh_accordion-fltr {
    width: 99%;
    margin: 1px auto 7px 4px;
}

#fh_fltr-headingOne.panel-heading {
    padding-left: 7px;
    height: 38px;
    background-color: #efefef;
    background-image: none;
    background-repeat: no-repeat;
}

.fh_panel-group>.panel>.panel-heading {
    padding: 7px 15px 0px 12px;
    height: 38px;
    background-color: #efefef;
    background-image: none;
    background-repeat: no-repeat;
}

#fh_panel-title {
    font-family: Cabin, Helvetica, Arial, sans-serif;
    color: #ae122a;
    font-weight: 400;
    font-size: large;
    padding: 12px;
    margin-bottom: 0px !important;
}

.fh_panel-head:before {
    /* symbol for "opening" panels */
    content: "\25BC";
}

.fh_panel-head.collapsed:before {
    /* symbol for "collapsed" panels */
    content: '\25BA';
}

.fh_panel-desc.collapsed:before {
    /* symbol for "collapsed" panels */
    content: '\25BA';
}

.fh_panel-desc:before {
    /* symbol for "opening" panels */
    content: "\25BC";
}



h3.fh_course-id,
h3.fh_course-head,
.fh_course-units {
    font-family: Cabin, Helvetica, Arial, sans-serif;
    color: #ffffff;
    font-size: 2rem;
    line-height: 2.2rem;
    margin-top: 10px;
    font-weight: 500;
    vertical-align: middle;
    text-align: center;
    text-shadow: none;
}

h3.fh_course-id {
    text-align: left;
    padding-left: 10px;
}

.fh_course-units {
    text-align: right;
    padding-right: 10px;
}

.fh_link-title {
    text-decoration: underline;
    text-decoration-style: solid;
    text-decoration-color: #fff;
    font-size: .95em;
    font-weight: bold;
    color: #fff;
}

.fh_link-title:visited {
    color: #fff;
}

.fh_link-title:hover {
    text-decoration-style: solid;
    text-decoration-color: #fff;
    font-weight: 200;
    color: #fff;
}


h4.fh_sectionID {
    color: #575757;
    font-size: 1.7rem;
}

.fh_sched-wrap {
    box-shadow: rgba(0, 0, 0, 0.16) 0px 10px 36px 0px, rgba(0, 0, 0, 0.06) 0px 0px 0px 1px;
    background-color: #fff;
    margin: 20px 1% 10px 1%;
    padding: 5px 15px 15px;

    /*     border-radius: 8px; */
    width: 99%;
    transition: all 0.1s linear;
}



.fh_sched-grid-auto {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(85px, 1fr));
    gap: 4px;
    background-color: #ebebeb;
    padding: 4px;
}



.fh_sched-grid-item {
    background-color: #fff;
    text-align: center;
    padding: 0px 0px 10px;
    font-family: Cabin, Helvetica, Arial, sans-serif;
    line-height: 14px;
}

.fh_sched-row2 {
    padding-top: 0px;
    margin-top: 0px;
}


@media(max-width: 699px) {
    .fh_sched-row2-label {
        display: block;
    }
}
@media(min-width: 700px) {
    .fh_sched-row2-label {
        display: none;
    }
    .fh_sched-row2 .fh_sched-grid-item {
        padding-top: 15px;
    }
}
.fh_sched-grid-item a {
    font-style: normal;
    font-weight: 500;
}

div.fh_special-head2>p {
    text-align: Center;
    font-weight: 500;
    font-size: 16px;
}

.fh_footnote {
    font-size: 1.5rem;
    font-style: italic;
    padding: 15px 10px 0px;
    clear: both;
}

.fh_sched-item-head {
    background-color: #575757;
    color: #fff;
    width: 100%;
    margin: 0px;
    margin-bottom: 15px;
    padding: 2px;
}

.fh_section-head {
    display: grid;
    grid-template-columns: 1fr 2fr 1fr;
    gap: 4px;
    padding: 4px;
}

.fh_section-head>.fh_sessid-head {
    text-align: left;
}

.fh_section-head>.fh_sessid-head>p {
    padding: 0px;
    margin: 0px;
}

.fh_section-head>.fh_sess-dates {
    text-align: center;
}

.fh_section-head>.fh_sess-dates>p {
    padding: 0px;
    margin: 0px;
}

.fh_section-head>.fh_sess-open {
    text-align: right;
}

#fh_colps-filters>div.panel-body {
    min-height: 486px;
    padding: 7px;
    background-color: rgb(226, 226, 226);
}


@media(max-width: 699px) {
    .fh_filter-grid-auto {
        display: grid;
        grid-template-columns: auto;
        /* grid-auto-flow: dense; */
        gap: 8px;
        padding: 0px 5px 10px;
    }

    .fh_filter-grid-item fieldset {
        background-color: #fff;
        border: 1px solid rgb(196, 196, 196);
        width: 100%;
        display: grid;
        grid-template-columns: repeat(auto-fit, minmax(150px, 1fr));
        gap: 5px;
    }
}

@media (min-width: 700px) {
    .fh_filter-grid-auto {
        display: grid;
        grid-template-columns: auto;
        /* grid-auto-flow: dense; */
        gap: 8px;
        padding: 0px 5px 10px;
        width: 100%
    }

    .fh_filter-grid-item fieldset {
        background-color: #fff;
        border: 1px solid rgb(196, 196, 196);
        width: 100%;
        display: grid;
        grid-template-columns: repeat(auto-fit, minmax(150px, 1fr));
        gap: 5px;
    }
}

.fh_radio-row {
    padding-top: 0px;
}


.fh_filter-grid-item legend {
    text-align: left;
    font-family: Cabin, Helvetica, Arial, sans-serif;
    font-size: 1em;
    font-weight: 500;
    margin: 0px;
    background-color: #fff;
    padding: 2px 4px 0px 3px;
    /* border-radius: 5px; */
    border: 1px solid rgb(196, 196, 196);
    border-bottom: 0;
}



.fh_filter-grid-item>div {
    margin-top: 7px;
}

.fh_filter-grid-item label {
    text-align: left;
    font-family: Cabin, Helvetica, Arial, sans-serif;
    font-size: .9em;
    font-weight: 200;
    margin: 0px;
    /* padding: 0px 5px 5px; */
/*     overflow: hidden;
    text-overflow: ellipsis; */
}

.fh_table-wrap {
    overflow-x: scroll;
}


.fh_filt-count {
    font-family: Cabin, Helvetica, Arial, sans-serif;
    font-size: 1.3rem;
    font-weight: 600;
}


.fh_details-list li {
    box-sizing: border-box;
    color: #333;
    display: flex;
    font-family: Cabin, Helvetica, Arial, sans-serif;
    line-height: 18px;
    list-style: none;
    margin: 0;
    padding: 7px;
    position: relative;
    text-align: left;
}



.fh_detail-label {
    border-radius: .25em;
    box-sizing: border-box;
    color: #374049;
    display: inline;
    font-family: Cabin, Helvetica, Arial, sans-serif;
    font-size: 1.5rem;
    font-weight: 600;
    left: 0;
    line-height: 1.34;
    list-style: none;
    margin-right: 30px;
    max-width: 140px;
    min-width: 140px;
    padding: 0;
    position: relative;
    text-align: left;
    top: 0;
    vertical-align: baseline;
    white-space: nowrap;
}

.fh_guide1 {
    margin-bottom: 0px;
}

.fh_guide2 {
    padding-top: 0px !important;
}

@media (min-width: 320px) and (max-width: 767px) {
    .fh_details-list li {
        margin-bottom: 1em;
        flex-direction: column;
    }
}

/* Tooltip container */
.fh_tooltip {
    position: relative;
    display: inline-block;
    border-bottom: 1px dotted black;
    /* If you want dots under the hoverable text */
    /* 	width: fit-content; */
    width: intrinsic;
    /* Safari/WebKit uses a non-standard name */
    width: -moz-max-content;
    /* Firefox/Gecko */
    width: -webkit-max-content;
    /* Chrome */
    width: max-content;
}

/* Tooltip text */
.fh_tooltip .fh_tooltiptext {
    visibility: hidden;
    width: 160px;
    background-color: black;
    color: #fff;
    text-align: left;
    padding: 7px;
    border-radius: 6px;

    /* Position the tooltip text - see examples below! */
    position: absolute;
    z-index: 1;
}

/* Show the tooltip text when you mouse over the tooltip container */
.fh_tooltip:hover .fh_tooltiptext {
    visibility: visible;
}

/* .fh_tooltip .fh_tooltiptext {
  top: -5px;
  left: 105%;
} */

.fh_tooltip .fh_tooltiptext::after {
    content: " ";
    position: absolute;
    top: 50%;
    right: 100%;
    /* To the left of the tooltip */
    margin-top: -5px;
    border-width: 5px;
    border-style: solid;
    border-color: transparent black transparent transparent;
}

/* Progress Bar design  */
.fh_centergrid {
    display: flex;
    text-align: center;
    align-items: center;
    align-self: center;
    justify-content: center;
}

img.fh_hidden {
    display: none;
    margin: 0px auto;
    text-align: center;
    align-items: center;
    align-self: center;

    justify-content: center;
}

.fh_issue-link {
    text-align: right;
    font-size: 12px;
    font-weight: 400;

}

.fh_issue-link>a {
    text-align: right;
    font-size: 12px;
    font-weight: 400;

}


span.iOER.iOER-blue {
    background-color: #0816ca;
    border-collapse: collapse;
    border-radius: 100%;
    border-width: 0;
    box-sizing: border-box;
    color: #fff;
    display: inline-block;
    font-family: Inconsolata, monospace;
    font-size: 12px;
    font-weight: 400;
    height: 20px;
    line-height: 20px;
    margin: 0 3px 0 0;
    padding: 0;
    text-align: center;
    vertical-align: baseline;
    width: 20px;
}

span.iOER.iOER-blue abbr {
    border-collapse: collapse;
    border-width: 0;
    box-sizing: border-box;
    color: #fff;
    margin: 0;
    padding: 0;
    text-align: center;
    text-decoration: none;
    vertical-align: baseline;
}
span.iOER.iOER-green {
    background-color: #086960;
    border-collapse: collapse;
    border-radius: 100%;
    border-width: 0;
    box-sizing: border-box;
    color: #fff;
    display: inline-block;
    font-family: Inconsolata, monospace;
    font-size: 12px;
    font-weight: 400;
    height: 20px;
    line-height: 20px;
    margin: 0 3px 0 0;
    padding: 0;
    text-align: center;
    vertical-align: baseline;
    width: 20px;
}

span.iOER.iOER-green abbr {
    border-collapse: collapse;
    border-width: 0;
    box-sizing: border-box;
    color: #fff;
    margin: 0;
    padding: 0;
    text-align: center;
    text-decoration: none;
    vertical-align: baseline;
}



/* Add Animation */
@-webkit-keyframes animatetop {
    from {
        top: -300px;
        opacity: 0
    }

    to {
        top: 0;
        opacity: 1
    }
}

@keyframes animatetop {
    from {
        top: -300px;
        opacity: 0
    }

    to {
        top: 0;
        opacity: 1
    }
}

#schedule_results * {
	font-family: 'Lato', sans-serif;
}

#schedule_results .fh_url a {
    font-weight: bold;
    color:#ffffff;
}

#schedule_results .fh_url a:hover {
    text-decoration:none;
}
#schedule_results .fh_course-head, #schedule_results .fh_course-id, #schedule_results .fh_course-units {
    font-size: 1.6rem;
    font-weight: bold;
    color: #000000;
}

#schedule_results a, #schedule_results a:visited {
    color: #000000;
}

#schedule_results .section {
    background-color: #F0F0F0;
    border: 1px solid #e6e6e6;
    border-radius: 5px;
}

#schedule_results .section:hover {
    background-color:white
}

#schedule_results .tang {
font-size: 1.6rem;
    color: #000000;
    padding: 0.5rem 0 0.5rem 0;
}

#schedule_results h4 {
    font-size: unset;
    font-weight: unset;
    color: unset;
    margin-top: unset;
}

#schedule_results .meetlines {
    display: inline;
    padding: 0 0 0.5rem 1.5rem;
    max-width: 75%;
}

#schedule_results p {
    font-weight: unset;
}

#schedule_results .meet-availability {
    display: inline;
    max-width: 25%;
    text-align: right;
    padding-right: 1rem;
}

#schedule_results .fh_link-title, #schedule_results .fh_link-title:visited {
    color: #fff;
}
