@import url('https://fonts.googleapis.com/css2?family=Heebo:wght@300,400,500');

:root {
	--heading-font: "Heebo", sans-serif;
	--paragraph-font: Arial;

	--dark-text-color: #333;
	--light-text-color: white;


	--primary: #70B684;
	--secondary: #9E6F38;
	--light-gray: #EFEFEF;
	--light-green: #70B684;
	--dark-green: #477355;
	--yellow: #F2A800;
	--brown: #9E6F38;
	--blue: #1981C4;
	--dark-gray: #5f5f5f;
	
	--holidays-in-canada: #1981C4;
	--exams: #A1C435;
	--career-coaching: #607D8B;
	--board-and-school-council-meetings: #673ab7;
	--cultural-days: #ff9800;
	--school-closed: #d54011;
	--staff-only: #795548;
	--events: #31cfc0;
}

body {
	font-size: 16px;
	/* overflow-y: hidden; */
	max-width: 2560px;
	margin: auto;
	font-family: var(--paragraph-font);
}

html {
	/* overflow-y: scroll; */
	scroll-behavior: smooth;
}

#skip a {
    position: absolute;
    left: -10000px;
    top: auto;
    width: 1px;
    height: 1px;
    overflow: hidden;
}

#skip a:focus {
    position:static;
    width:auto;
    height:auto;
}

/* Headings */

h1,
h2,
h3,
h4,
h5,
h6 {
	font-family: var(--heading-font);
}

h1 {
	font-size: 2.5rem;
}

h2 {
	font-size: 2rem;
}

h3 {
	font-weight: 500;
	font-size: 1.5rem;
}

h4 {
	font-weight: 500;
	line-height: 1.2;
}

h5 {
	font-size: 1rem;
	font-weight: 400;
}

ul {
	list-style: none;
}

ul, ol {
	padding: 0;
	margin: 0;
}

p {
	font-family: var(--paragraph-font);
	line-height: 2;
	font-size: 1rem;
}

a {
	text-decoration: none;
	font-family: var(--heading-font);
	font-weight: 400;
	color: var(--secondary);
	transition: all .2s ease-in-out; 
}

input {
	font-family: var(--paragraph-font)
}

/* Backgrounds */

.bg-light-green {
	background-color: var(--light-green);
}

.bg-dark-green {
	background-color: var(--dark-green);
}

.bg-blue {
	background-color: var(--blue);
}

.bg-yellow {
	background-color: var(--yellow);
}

.bg-secondary {
	background-color: var(--brown);
}

.text-white {
	color: white;
}

.font-bold {
	font-weight: 500;
}

.btn, input[type="submit"] {
	padding: 12px 30px;
	border-radius: 100px;
}

.btn-primary {
	background-color: var(--primary);
	color: var(--light-text-color);
}

.btn-view-more {
	color: var(--secondary);
}

.no-margin {
	margin: 0px !important;
}

.no-padding {
	padding: 0 !important;
}

.pt-50 {
	padding-top: 50px;
}

.pb-50 {
	padding-bottom: 50px;
}

.mt-10 {
	margin-top: 10px;
}

.container-fluid {
	margin: 0;
}

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

.row {
	padding: 0;
	margin-left: -10px;
	margin-right: -10px;
}

.col-xs,
.col-xs-1,
.col-xs-2,
.col-xs-3,
.col-xs-4,
.col-xs-5,
.col-xs-6,
.col-xs-7,
.col-xs-8,
.col-xs-9,
.col-xs-10,
.col-xs-11,
.col-xs-12 {
	padding-left: 10px;
	padding-right: 10px;
}

.col-md,
.col-md-1,
.col-md-2,
.col-md-3,
.col-md-4,
.col-md-5,
.col-md-6,
.col-md-7,
.col-md-8,
.col-md-9,
.col-md-10,
.col-md-11,
.col-md-12 {
	padding-left: 10px;
	padding-right: 10px;
}

.display-block {
	display: block !important;
}

.editor-table td > * {
	display: block;
}

/* Top Bar */

.top-bar {
	display: flex;
	align-items: center;
	justify-content: right;
	position:relative;
}

.top-bar .top-bar-icon {
	display: flex;
	align-items: center;
	justify-content: center;
	width: 45px;
	height: 45px;
	color: white;
	font-size: 1rem;
}

.top-bar .top-bar ul li {
	padding: 0;
	margin: 0;
	display: inline-block;
}

.top-bar .search-bar-wrapper {
	display: flex;
	align-items: center;
	background-color: var(--light-gray);
	padding: 0;
	position: relative;
}

.top-bar #search-form,
.top-bar #search-api-form {
	margin: 0;
	display: flex;
	flex-direction: row;
	align-items: center;
	background-color: var(--light-gray);
    width: 100%;
}

.top-bar #search-term,
.top-bar #search-term-clone,
.top-bar .search-box {
	margin: 0;
	height: 100%;
	box-sizing: border-box;
	border: none;
	outline: none;
	width: calc(100% - 40px);
	padding: 13px 16px;
	background-color: var(--light-gray);
	font-family: var(--paragraph-font);
    flex-grow: 1;
}

.top-bar #search-term::placeholder,
.top-bar #search-term-clone::placeholder,
.top-bar .search-box::placeholder {
	font-size: .75rem;
}

.top-bar .search-bar-wrapper .search-icon {
	background-color: var(--light-gray);
	font-size: 1.2rem;
	position: absolute;
	margin-left: 0;
	padding-left: 10px;
	height: 100%;
	display: flex;
	color: var(--light-green);
	align-items: center;
	left: auto;
    right: 0;
    appearance: none;
    border: none;
    background: none;
	cursor: pointer;
}

.top-bar .search-bar-wrapper label {
	display: none;
}

.top-bar .search-bar-wrapper .filter-icon {
    color: var(--light-green);
    font-size: 1.2rem;
    padding-right: 0.5rem;
    cursor: pointer;
}

.top-bar #search-form input[type="submit"],
.top-bar #search-api-form input[type="submit"] {
    background: var(--light-green);
    color: white;
    border-radius: 0;
    min-height: 45px;
    padding: 12px 16px;
}

/* Search filters */
.search-row {
    display: flex;
    align-items: center;
    flex-grow: 1;
    width: 100%;
}

.search-filters {
    display: none;
    position: absolute;
    background: var(--light-gray);
    width: 226.9px;
    left: 0;
    right: 0;
    top: 100%;
    padding: 0.5rem;
    z-index: 100;
}

.filter-group {
    margin: 0.5rem 0;
}

/* Main Nav */

.navbar {
	background-color: var(--primary);
	position: relative;
}

.navbar .nav-content-wrapper {
	display: flex;
	flex-direction: column;
	width: 100%;
}

.navbar .nav-toggle {
	color: white;
	padding: 20px 0px;
	font-size: 1.2rem;
	display: none;
}

.navbar ul {
	display: flex;
	align-items: center;
	justify-content: right;
	height: 100%;
}

.navbar ul li {
	display: inline-block;
	margin: 0 10px;
}

.navbar ul li a {
	display: block;
	padding: 20px 0px;
	color: var(--light-text-color);
}

.navbar .logo-wrapper {
	position: relative;
	display: flex;
	align-items: center;
	z-index: 10; /*was 2*/
}

/* .navbar img {
	position: absolute;
	width: 100px;
	transform: translateY(-25%);
	top: 0;
} */

.navbar .logo-link {
    position: absolute;
    width: 80px;
    height: 80px;
    transform: translateY(-17%);
    top: 0;
    background: white;
    border-radius: 50%;
    border: 1px solid #000000;
    display: flex;
    aspect-ratio: 1/1;
    flex-direction: column;
    justify-content: center;
}

.navbar .logo-link img {
    padding: .5rem;
}

.navbar .logo-link.no-bg img {
    padding: 0;
}

.navbar .logo-link.bg-red {
    background: #D42D12;
}

.navbar .logo-link.no-bg {
    background: none;
    border: none;
    padding: 0;
}

.site-name {
    color: white;
    text-transform: uppercase;
    position: absolute;
    left: 115px;
    top: 50%;
    transform: translateY(-50%);
    max-width: 250px;
    font-size: .95rem;
}

/* Navigation Dropdown */
.navbar ul li .nav-link {
    display: flex;
    align-items: center;
	justify-content: space-between;
	gap: 5px;
}

.navbar .main-dropdown-ul a {
	padding: 5px 0;
	color: var(--dark-text-color);
}

.navbar .main-dropdown-ul a:hover {
	color: var(--primary)
}

.navbar .main-dropdown-ul li {
	margin: 0;
	display: block;
}

.navbar .main-dropdown i {
	color: white;
	width: 25%;
    text-align: right;
	transition: all .2s ease-in-out;
}

.navbar .main-dropdown {
	position: relative;
	cursor: pointer;
}

.navbar .main-dropdown-ul {
	transition: all .2s ease-in-out;
	transform: scaleY(0);
	transform-origin: top;
	opacity: 0;
	height: 0;
    padding: 0;
	background: #EFEFEF;
}

@media (max-width: 991px){
	.navbar .main-dropdown-ul.active {
		transform: scaleY(1);
		opacity: 1;
		height: auto;
		padding: 0.5rem 1rem;
	} 
}

@media (min-width: 992px){
	.navbar ul li .nav-link {
		justify-content: flex-start;
	}
	.navbar .main-dropdown-ul {
		display: unset;
		position: absolute;
		top: 100%;
    	width: 14rem;
    	max-width: 350px;
		left: 0;
		padding: 1rem;
		z-index: 100;
    	height: fit-content;
	}
	
	.navbar .main-dropdown i {
		width: fit-content;
	}
	
	.navbar .main-dropdown:nth-last-of-type(3) .main-dropdown-ul,
	.navbar .main-dropdown:nth-last-of-type(2) .main-dropdown-ul,
	.navbar .main-dropdown:last-of-type .main-dropdown-ul {
		left: auto;
		right: 0;
	}
	
	.navbar .main-dropdown:hover .main-dropdown-ul{
		transform: scaleY(1);
		opacity: 1;
	}
	
	.navbar .main-dropdown:hover i {
		transform: rotate(180deg);
	}
	
	.navbar .main-dropdown-ul.two-col {
		/*display: flex;
		flex-wrap: wrap;
		align-items: flex-start;
		justify-content: flex-start;
		width: 25rem;
		max-width: unset;
		gap: 0.5rem;
		column-gap: 1rem;*/
		column-count: 2;
		width: 25rem;
		max-width: unset;
	}
	
	.navbar .main-dropdown-ul.two-col li {
		/*width: calc(50% - 0.5rem);*/
		break-inside: avoid;
	}
}

/* Nav Apps */
.nav-app-icon {
    display: flex;
    flex-direction: column;
    justify-content: center;
	cursor: pointer;
}

.nav-app-dropdown {
	display: none;
    position: absolute;
    top: calc(100%);
	/*left: 0;*/
    right: 0;
    z-index: 100;
    background: var(--light-gray);
    padding: 1.5rem 2rem;
	width: fit-content;
	border-top: 1px solid var(--light-green);
}

.app-links {
	display: flex;
    flex-direction: column;
    gap: 0.75rem;
}

.app-link {
	color: var(--dark-text-color);
}

.app-link:hover,
.app-link:focus {
	color: var(--primary);
}

/* Header */

header .banner-item {
	height: 400px;
	padding: 32px;
	position: relative;
	background-size: cover !important;
	overflow: hidden;
}

header .banner-item-inner {
    position: relative;
    width: 100%;
    height: 100%;
    background-size: cover !important;
}

header .banner-item-inner.district {
    position: relative;
    width: 100%;
    height: calc(50% - 2px);
    background-size: cover !important;
    margin-bottom: 4px;
}

header .banner-item.banner-2 {
    padding: 0;
}

header .banner-item::after,
header .banner-item-inner::after {
	position: absolute;
	width: 100%;
	height: 100%;
	background: transparent linear-gradient(180deg, #00000000 0%, #000000 100%) 0% 0% no-repeat padding-box;
	top: 0;
	bottom: 0;
	left: 0;
	right: 0;
	content: "";
	opacity: 0.8;
	transition: .2s;
}

header .banner-item.banner-2::after {
    content: none;
}

header .banner-item .btn {
	opacity: 0;
	transition: .2s;
	margin-left: 30px;
}

header .banner-item.banner-1:hover::after,
header .banner-item-inner:hover::after {
	opacity: .4;
}

header .banner-item.banner-1 {
	border-right: 4px solid white;
}

header .banner-item .text-wrapper {
	position: absolute;
	bottom: 0;
	left: 0;
	z-index: 2;
	margin-bottom: 0;
	transition: .2s;
}

header .banner-item.banner-1:hover .text-wrapper {
	margin-bottom: 60px;
}

header .banner-item-inner:hover .text-wrapper {
	margin-bottom: 40px;
}

header .banner-item.banner-1:hover .btn,
header .banner-item-inner:hover .btn {
	opacity: 1;
}

header .banner-item .text-wrapper h1 {
	color: white;
}

header .banner-item .text-wrapper h1,
header .banner-item .text-wrapper h2 {
	margin-bottom: 30px;
	margin-left: 30px;
	margin-right: 60px;
}

header .banner-item .text-wrapper h2 {
	font-size: 2.5rem;
	color: white;
}

header .banner-item .vertical-scroll-wrapper {
	position: absolute;
	right: 0px;
	bottom: 30px;
	transform: translateY(-146px);
	z-index: 2;
}

header .banner-item .vertical-scroll-wrapper .scroll-text {
	text-align: center;
	position: absolute;
	transform: rotate(90deg);
	transform-origin: 0 0;
	width: 150px;
	background-color: var(--light-green);
	padding: 13px;
	font-size: 1rem;
	color: var(--light-text-color);
}

header .banner-item .vertical-scroll-wrapper .scroll-text i {
	vertical-align: middle;
	margin-left: 8px;
	font-size: 1rem;
}

/* What's New & Upcoming Events */

.news-section a .news-item {
	height: 10rem;
	position: relative;
	background-size: cover !important;
	border-radius: 10px;
	margin-bottom: 20px;
	padding-left: 30px;
	padding-right: 30px;
    background-repeat: no-repeat;
    background-position: center center;
    background-color: var(--light-green);
}

.news-section a .news-item::after {
	position: absolute;
	width: 100%;
	height: 100%;
	background: transparent linear-gradient(180deg, #00000000 0%, #000000 100%) 0% 0% no-repeat padding-box;
	top: 0;
	bottom: 0;
	left: 0;
	right: 0;
	content: "";
	opacity: 0.9;
	transition: .2s;
	border-radius: 10px;
}

.news-section a .news-item:hover::after {
	opacity: .5;
}

.news-section a .news-item h3 {
	font-weight: 600;
}

.news-section a .news-item h3,
.news-section a .news-item h4 {
	color: white;
	position: absolute;
	bottom: 0;
	margin-right: 30px;
	margin-bottom: 30px;
	z-index: 2;
	overflow: hidden;
	display: -webkit-box;
	-webkit-line-clamp: 3;
	-webkit-box-orient: vertical;
}

.news-section .spotlight .news-item {
	height: 336px;
}

.news-section.school-news .news-item {
	height: 240px;
}

.news-section.news-archive {
	margin-top: 20px;
}

.news-section .btn-view-more {
	display: block;
	text-align: right;
}

.news-section .events-wrapper {
	margin-bottom: 10px;
}

.news-section .events-wrapper .event-item {
	display: flex;
	align-items: center;
	color: var(--dark-text-color);
	height: 100%;
	margin-top: -4px;
	margin-bottom: 13.5px;
}

.news-section .events-wrapper .event-item .event-date-wrapper {
	background: var(--primary);
	color: var(--light-text-color);
	text-align: center;
	padding: 1rem 1.1rem;
	display: flex;
	flex-direction: column;
	justify-content: center;
	border-radius: 10px;
	font-weight: 500;
	font-size: 1.2rem;
	min-width: 31.05px;
}

.news-section .events-wrapper .event-item .event-date-wrapper .month {
	font-size: .9rem;
	text-transform: uppercase;
}

.news-section .events-wrapper .event-item .event-text-wrapper {
	margin: 1rem;
	display: flex;
	flex-direction: column;
	justify-content: center;
}

.news-section .events-wrapper .event-item .event-text-wrapper h4 {
    font-weight: 600;
	margin: 0;
	margin-bottom: 10px;
	overflow: hidden;
	display: -webkit-box;
	-webkit-line-clamp: 1;
	-webkit-box-orient: vertical;
}

.news-section .events-wrapper .event-item .event-text-wrapper h5 {
	margin: 0;
}

/* Masonry */

.masonry {
	position: relative;
	width: 100%;
	height: 100%;
	padding-bottom: 2.5px;
}

.masonry .swiper-button-prev,
.swiper-rtl .swiper-button-next {
	color: white;
}

.masonry .swiper-button-next,
.swiper-rtl .swiper-button-prev {
	color: white;
}

.masonry .masonry-grid {
	display: flex;
}

.masonry .masonry-grid .grid-half {
	display: flex;
	flex-direction: column;
	width: 50%;
}

.masonry .masonry-grid .grid-whole {
	display: flex;
	width: 100%;
}

.masonry .masonry-grid .image {
	height: 250px;
	margin: 2.5px;
}

.masonry .masonry-grid .image.width-40 {
	width: 40%;
}

.masonry .masonry-grid .image.width-60 {
	width: 60%;
}

.masonry .masonry-grid .image.width-100 {
	width: 100%;
	height: 400px;
}


/* Footer */

footer .top-content {
	position: relative;
	overflow: hidden;
}

footer .trees {
	width: 125%;
	bottom: 0;
	margin-bottom: -40px;
	position: absolute;
	z-index: 1;
	text-align: center;
}

footer .trees img {
	width: 100%;
	margin: 0 auto;
	transform: translateX(-15%);
}

footer .cta .text-wrapper {
	text-align: center;
	padding: 50px 0;
}

footer .cta .text-wrapper h2 {
	position: relative;
	z-index: 2;
}

footer .cta .text-wrapper a {
	position: relative;
	z-index: 2;
}

footer .cta .text-wrapper hr {
	margin-top: 80px;
	background-color: #538463;
	height: 3px;
	border: 0;
	position: relative;
	z-index: 0;
}


footer .content {
	margin-top: 30px;
	padding-bottom: 50px;
	position: relative;
	z-index: 2;
}

footer .address .text-wrapper h3 {
	margin-top: 0;
}

footer .address .text-wrapper p {
	line-height: 1.5;
}

footer .address .text-wrapper a {
	color: white;
}

footer .address .text-wrapper ul li:first-child p {
	line-height: 2;
	margin-right: 20px;
}

footer .social-links {
	margin-top: 30px;
}

footer .social-links li {
	display: inline-block;
	margin: 0 2px;
}

footer .social-links .icon-wrapper {
	width: 50px;
	height: 50px;
	border-radius: 100%;
	border: 2px solid white;
	display: flex;
	align-items: center;
	justify-content: center;
    transition: all .3s ease-in-out;
}

footer .social-links .icon-wrapper:hover,
footer .social-links .icon-wrapper:focus {
	background-color: white;
    color: var(--dark-green);
}

footer .social-links .icon-wrapper i {
	font-size: 1.25rem;
}

footer .quicklinks-wrapper h4 {
	margin-top: 0;
}

footer .quicklinks-wrapper .footer-links li {
	margin-bottom: 16px;
}

footer .quicklinks-wrapper .footer-links li a {
	color: white;
	font-size: 1rem;
}

footer .tabs-container {
    display: flex;
}

footer .tabs-wrapper .tabs-nav li {
	display: inline-block;
	margin-right: 10px;
}

footer .tabs-wrapper .tabs-nav li h4 {
	margin-top: 0;
	padding-bottom: 10px;
	cursor: pointer;
}

footer .tabs-wrapper .tabs-nav li h4.active {
	border-bottom: 2px solid white;
}

footer .tabs-wrapper .tab-content {
	margin-top: -20px;
	opacity: 0;
	transition: opacity 0.5s;
    display: block;
    visibility: hidden;
    margin-right: -100%;
    width: 100%;
}

footer .tabs-wrapper .tab-content.active {
	display: block;
    opacity: 1;
    visibility: visible;
}

footer .quicklinks-wrapper {
	flex-direction: column;
}

/* For Schools Only - START */

footer .district-link-wrapper {
	display: flex;
	justify-content: right;
	margin-top: 30px;
}

footer .district-link-wrapper .text-wrapper {
	margin-right: 30px;
	text-align: right;
	display: flex;
	flex-direction: column;
	justify-content: center;
}

footer .district-link-wrapper .text-wrapper h4 {
	margin-top: 0px;
}

footer .district-link-wrapper .text-wrapper a {
	color: white;
}

footer .district-link-wrapper .img-wrapper {
	display: flex;
	align-items: center;
}

footer .district-link-wrapper .img-wrapper img {
	width: 80px;
	margin: 0 auto;
}

footer .tabs-wrapper .tab-content {
	margin-top: -20px;
	opacity: 0;
	transition: opacity 0.5s;
    display: block;
    visibility: hidden;
    margin-right: -100%;
    width: 100%;
}

footer .tabs-wrapper .tab-content.active {
	display: block;
    opacity: 1;
    visibility: visible;
}

@media(max-width: 991px){
    footer .tabs-wrapper .tab-content {
        display: none;
    }

    footer .tabs-wrapper .tab-content.active {
        display: block;
    }
}

/* END */

footer .copyright {
	background-color: var(--secondary);
	text-align: center;
	position: relative;
	z-index: 2;
}

footer .copyright a {
    color: white;
}

footer .copyright span {
	margin: 0 8px;
}

footer #full-year {
    margin: 0;
}

footer .copyright span i {
	font-size: 0.4rem;
	vertical-align: middle;
}

.footer-ul {
    list-style: revert;
    margin-left: 1rem;
    line-height: 2;
    margin-top: 1rem;
}

/* Header Secondary */

header.secondary {
	text-align: center;
	position: relative;
	overflow: hidden;
}

header.secondary h1 {
	position: relative;
	z-index: 1;
}

header.secondary .trees {
	position: absolute;
	width: 40%;
	right: 0;
	bottom: 0;
	margin-bottom: -20px;
	z-index: 1;
	opacity: .2;
}

header.secondary.bg-img {
	padding: 100px 0;
}

header.secondary.bg-img::after {
	position: absolute;
	width: 100%;
	height: 100%;
	background: transparent linear-gradient(180deg, #00000000 0%, #000000 100%) 0% 0% no-repeat padding-box;
	top: 0;
	bottom: 0;
	left: 0;
	right: 0;
	content: "";
	opacity: 0.8;
	transition: .2s;
}

header.secondary.bg-img .trees {
	display: none;
}

/* Sub Page Content */

.content .sidebar {
	z-index: 4;
	margin-top: -58.5px;
}

.content .sidebar .top {
	display: flex;
	align-items: center;
    justify-content: space-between;
	padding: 20px 38px;
	background-color: var(--secondary);
}

.sidenav-icon {
    color: white;
    margin-left: 16px;
    font-size: 1.2rem;
}

.content .sidebar .top a {
	color: white;
}

.content .sidebar .top a i {
	margin-right: 10px;
}

.content .sidebar .no-top {
	display: none;
}

.content .sidebar .bottom {
	padding: 20px 55px;
	background-color: var(--dark-green);
}

.content .sidebar .no-top + .bottom {
	margin-top: 58.5px;
}

.content .sidebar .bottom ul li {
	display: flex;
}

.content .sidebar .bottom ul li a {
	color: white;
	padding: 10px;
}

.content .sidebar .bottom .active a {
	font-weight: 500;
	color: var(--light-green);
}

.content .rich-text-wrapper {
	margin-left: 5%;
	margin-right: 5%;
}

.content .rich-text-wrapper p {
	color: var(--dark-text-color);
}

/* Sub Page (rich text & DCT) Content Styles */

img {
	height: auto;
	max-width: 100%;	
	object-fit: cover;
}

figcaption {
	font-size: 0.8rem;
	font-family: var(--paragraph-font);
}

blockquote {
	background: var(--light-gray);
	border-left: 5px solid var(--primary);
	padding: 1.5rem;
	margin: 0 0 0.5rem;
	position: relative;
	font-weight: 300;
	border-radius: 2px;
}

/*blockquote p:last-of-type {
margin-bottom: 0;
}*/

hr {
	border: 0;
	height: 1px;
	background-color: #e6e6e6;
	margin: 2rem 0;	
	clear: both;
}

/* Table Styles */
.table {
	margin: 0 0 2rem;
	overflow-x: auto;
}

.table th a {
	color: white;
}

.table th a:hover,
.table th a:focus {
	text-decoration: underline;
}

.table table {
	border-radius: 5px;
	font-weight: normal;
	border: 1px solid #F5F5F5;
	border-collapse: collapse;
	width: 100%;
	max-width: 100%;
	white-space: normal;
	background-color: white;
	font-family: var(--paragraph-font);
}

.table table td, 
.table table th {
	padding: 10px 15px;
}

.table table td {
	border-right: 1px solid #F5F5F5;
}

.table table td:last-of-type {
	border-right: 0;
}

.table table thead th {
	color: #ffffff;
	background: var(--primary) !important;
	font-family: var(--heading-font);
}

.table table thead th > * {
	color: #ffffff;
}

.table table thead th:nth-child(odd) {
	color: #ffffff;
	background: var(--dark-green) !important;
}

.table table tr:nth-child(even) {
	background: var(--light-gray);
}

.table h3 {
	margin: .5rem 0;
}

.table img {
	width: 100%;
}

/* Collapsible box - rich text editor */
.collapsible-box {
	width: 100%;
	margin-bottom: 1rem;
}

.collapsible-box .material-icons {
	color: var(--primary);
}

.collapsible-box-description { 
	display: none;
	margin: 0 0.5rem;
	padding: 1rem 0;
}

.collapsible-box-title {
	background-color: var(--light-gray);
	display: flex;
	align-items: center;
	padding: .5rem;
	margin: 0;
	cursor: pointer;
}

.collapsible-box-title i {
	margin-right: .5rem;
}

.collapsible-bottom-icon {
	cursor: pointer;
}

/* Collapsible boxes - lexical rte */
.editor details summary {
    background-color: var(--light-gray);
    display: flex;
    align-items: center;
    padding: 1rem .5rem;
	margin: 0;
	cursor: pointer;
    transition: all .3s ease-in-out;
}

.editor details summary i {
    font-weight: var(--font-bold);
    color: var(--primary);
    margin-right: .5rem;
}

.editor details {
    margin-bottom: 1rem;
    transition: all .3s ease-in-out;
}

.editor div[data-lexical-collapsible-content]{
    padding: 1rem;
}

/* Lists */
.page-content .rich-text-wrapper ul {
	list-style: unset;
}

.page-content .rich-text-wrapper ul, .page-content .rich-text-wrapper ol {
	padding: 0 0 0 1.5rem;
	font-family: var(--paragraph-font);
	margin: 1rem 0;
}

.page-content .rich-text-wrapper ul ::marker, .page-content .rich-text-wrapper ol ::marker {
	color: var(--light-green);
	font-weight: 500;
}

.page-content .rich-text-wrapper li {
	padding-left: 0.5rem;
}

/* Page Headings */
.page-content .rich-text-wrapper h1, .page-content h2, .page-content h3 {
	color: var(--dark-green)
}

.page-content .rich-text-wrapper h1 {
	font-size: 2rem;
}

.page-content h2 {
	font-size: 1.5rem;
}

.page-content h3 {
	font-size: 1.2rem;
}

.page-content h4 {
	font-size: 1rem;
}

.page-content .rich-text-wrapper a {
	font-family: var(--paragraph-font)
}

.page-content .rich-text-wrapper a:hover,
.page-content .rich-text-wrapper a:focus {
	filter: brightness(90%)
}

/* Contact */
.content .contact-wrapper ul {
	list-style: none;
	padding: 0;
}

.content .contact-wrapper li {
	padding: 0;
}

.contact-form {
	font-family: var(--paragraph-font);
	margin-top: 35px;
}

/* Form Styles */
input[type="submit"] {
	border: 0;
	font-family: var(--heading-font);
}

input[type="submit"]:hover,
input[type="submit"]:focus {
	filter: brightness(85%);
}

.input { margin-bottom: 15px }
.input-field { position: relative; margin-bottom: 15px }
.input-field label {
	box-sizing: border-box;
	padding: 0px 5px;
	cursor: text;
	position: absolute;
	left: 10px;
	top: -12px;
	background: #ffffff;
	font-size: 0.8rem;
	color: #aaaaaa;
	font-family: var(--heading-font);
}

.input-field input[type="text"], 
.input-field input[type="password"], 
.input-field input[type="date"], 
.input-field input[type="tel"], 
.input-field input[type="email"], 
.input-field input[type="search"], 
textarea {
	width: 100%;
	height: 50px;
	box-sizing: border-box;
	border: solid 1px #e4e4e4;
	border-radius: 4px;
	transition: 0.5s;
	padding-left: 10px;
}

.input-field textarea { 
	/*margin-top: 10px;*/ 
	padding-top: 15px; 
	min-height: 180px;
}

.input-field input[type="text"]:focus, 
.input-field input[type="password"]:focus, 
.input-field input[type="date"]:focus, 
.input-field input[type="tel"]:focus, 
.input-field input[type="email"]:focus, 
.input-field textarea:focus, 
.input-field select:focus {
	border: solid 1px #0274bb; 
	outline: none; 
	transition: 0.5s;
}

.input-field select {
	width: 100%;
	height: 50px;
	box-sizing: border-box;
	border: solid 1px #e4e4e4;
	border-radius: 4px;
	transition: 0.5s;
	padding-left: 10px;
}

.input-field:focus { 
	border: solid 10px blue; 
}

.error { 
	color: #ee3340; 
	border: solid 2px #f15d43 !important; 
}

.g-recaptcha {
	margin-bottom: 20px;
}

/* CM Calendar */
#calendar {
	font-size: 16px;
	font-family: var(--paragraph-font);
}

#calendar a {
	color: var(--dark-text-color);
}

#calendar .fc-daygrid-event-harness a {
	color: var(--dark-gray);
}

#calendar .fc-daygrid-event-harness .fc-h-event {
	background: var(--dark-gray);
	border-color: var(--dark-gray);
}
#calendar .fc-view-harness {
	background: #fff;
	margin-bottom: 2rem;
}

#calendar .fc-col-header {
	margin-bottom: 0;
}

.fc-scrollgrid-sync-table {
	margin-bottom: 0;
}

.fc-col-header-cell-cushion,
.fc-daygrid-day-number {
	color: inherit;
}

.fc-h-event .fc-event-title-container,
.fc-daygrid-dot-event .fc-event-title {
	white-space: normal;
}

.fc-daygrid-dot-event {
	align-items: flex-start!important;
	flex-wrap: wrap;
} 

.fc-daygrid-event-dot {
	margin: 3px 4px!important;
}

.fc-daygrid-block-event .fc-event-time {
	display: none;
}

.fc-daygrid-dot-event .fc-event-title {
	padding: 0;
}

#calendar .fc-daygrid-event .fc-daygrid-event-dot,
.fc .fc-event .fc-list-event-dot {
    border-color: var(--dark-gray);
}

#calendar .fc-h-event,
#calendar .fc-v-event {
	background: var(--dark-gray);
	border-color: var(--dark-gray);
}

/* Calendar Filter */	
.calendar-filters-container {
	display: block;
	margin-bottom: 2rem;
	background: var(--light-gray);
	padding: 1.5rem;
}

.calendar-filters-container p {
	margin-top: 0;
}

.calendar-filters-heading h3 {
	margin-top: 0;
	font-size: 1.375rem;
}

.target-calendar-filters {
	display: flex;
	flex-wrap: wrap;
	gap: 1rem;
}

.filter-checkbox-wrapper {
	padding: 0.5rem 1rem;
	border-radius: 5px;
}

.filter-checkbox-wrapper label {
	text-transform: capitalize;
}

.filter-checkbox-wrapper:first-of-type {
	padding-left: 0;
}

/* Calendar Legend */
.filter-checkbox-wrapper.--holidays-in-canada {
	background: var(--holidays-in-canada);
	color: white;
}

#calendar .fc-daygrid-event.--holidays-in-canada .fc-daygrid-event-dot,
.fc .fc-event.--holidays-in-canada .fc-list-event-dot,
#calendar .fc-daygrid-event.--holidays-in-canada {
	border-color: var(--holidays-in-canada);
	color: var(--holidays-in-canada);
}

#calendar .fc-daygrid-event.--holidays-in-canada .fc-event-main{
	background: var(--holidays-in-canada);
}

#calendar .fc-v-event.--holidays-in-canada {
	background: var(--holidays-in-canada);
	border-color: var(--holidays-in-canada);
}

.filter-checkbox-wrapper.--exams {
	background: var(--exams);
	color: white;
}

#calendar .fc-daygrid-event.--exams .fc-daygrid-event-dot,
.fc .fc-event.--exams .fc-list-event-dot,
#calendar .fc-daygrid-event.--exams {
	border-color: var(--exams);
	color: var(--exams);
}

#calendar .fc-daygrid-event.--exams .fc-event-main{
	background: var(--exams);
}

#calendar .fc-v-event.--exams {
	background: var(--exams);
	border-color: var(--exams);
}

.filter-checkbox-wrapper.--board-and-school-council-meetings {
	background: var(--board-and-school-council-meetings);
	color: white;
}

#calendar .fc-daygrid-event.--board-and-school-council-meetings .fc-daygrid-event-dot,
.fc .fc-event.--board-and-school-council-meetings .fc-list-event-dot,
#calendar .fc-daygrid-event.--board-and-school-council-meetings {
	border-color: var(--board-and-school-council-meetings);
	color: var(--board-and-school-council-meetings);
}

#calendar .fc-daygrid-event.--board-and-school-council-meetings .fc-event-main{
	background: var(--board-and-school-council-meetings);
}

#calendar .fc-v-event.--board-and-school-council-meetings {
	background: var(--board-and-school-council-meetings);
	border-color: var(--board-and-school-council-meetings);
}

.filter-checkbox-wrapper.--career-coaching {
	background: var(--career-coaching);
	color: white;
}

#calendar .fc-daygrid-event.--career-coaching .fc-daygrid-event-dot,
.fc .fc-event.--career-coaching .fc-list-event-dot,
#calendar .fc-daygrid-event.--career-coaching {
	border-color: var(--career-coaching);
	color: var(--career-coaching);
}

#calendar .fc-daygrid-event.--career-coaching .fc-event-main{
	background: var(--career-coaching);
}

#calendar .fc-v-event.--career-coaching {
	background: var(--career-coaching);
	border-color: var(--career-coaching);
}

.filter-checkbox-wrapper.--cultural-days {
	background: var(--cultural-days);
	color: white;
}

#calendar .fc-daygrid-event.--cultural-days .fc-daygrid-event-dot,
.fc .fc-event.--cultural-days .fc-list-event-dot,
#calendar .fc-daygrid-event.--cultural-days {
	border-color: var(--cultural-days);
	color: var(--cultural-days);
}

#calendar .fc-daygrid-event.--cultural-days .fc-event-main{
	background: var(--cultural-days);
}

#calendar .fc-v-event.--cultural-days {
	background: var(--cultural-days);
	border-color: var(--cultural-days);
}

.filter-checkbox-wrapper.--school-closed {
	background: var(--school-closed);
	color: white;
}

#calendar .fc-daygrid-event.--school-closed .fc-daygrid-event-dot,
.fc .fc-event.--school-closed .fc-list-event-dot,
#calendar .fc-daygrid-event.--school-closed {
	border-color: var(--school-closed);
	color: var(--school-closed);
}

#calendar .fc-daygrid-event.--school-closed .fc-event-main{
	background: var(--school-closed);
}

#calendar .fc-v-event.--school-closed {
	background: var(--school-closed);
	border-color: var(--school-closed);
}

.filter-checkbox-wrapper.--staff-only {
	background: var(--staff-only);
	color: white;
}

#calendar .fc-daygrid-event.--staff-only .fc-daygrid-event-dot,
.fc .fc-event.--staff-only .fc-list-event-dot,
#calendar .fc-daygrid-event.--staff-only {
	border-color: var(--staff-only);
	color: var(--staff-only);
}

#calendar .fc-daygrid-event.--staff-only .fc-event-main{
	background: var(--staff-only);
}

#calendar .fc-v-event.--staff-only {
	background: var(--staff-only);
	border-color: var(--staff-only);
}

.filter-checkbox-wrapper.--events {
	background: var(--events);
	color: white;
}

#calendar .fc-daygrid-event.--events .fc-daygrid-event-dot,
.fc .fc-event.--events .fc-list-event-dot,
#calendar .fc-daygrid-event.--events {
	border-color: var(--events);
	color: var(--events);
}

#calendar .fc-daygrid-event.--events .fc-event-main{
	background: var(--events);
}

#calendar .fc-v-event.--events {
	background: var(--events);
	border-color: var(--events);
}

.calendar-subscribe {
    margin-bottom: 1.5rem;
    margin-left: auto;
    width: fit-content;
}

.btn-subscribe {
    cursor: pointer;;
}

.download-cal-buttons {
    display: flex;
    gap: 1rem;
    flex-wrap: wrap;
}


/* General DCT Template */

.page-content .rich-text-wrapper .dct-template ul {
	padding-left: 0;
	margin-bottom: 0;
}

.page-content .rich-text-wrapper .dct-template li {
	padding-left: 0;
}

.dct-template .text-right {
	text-align: right;
}

.dct-template .text-center {
	text-align: center;
}

.dct-template .intro-content {
	background: var(--light-gray);
	padding: 1rem 1.5rem;	
	margin-bottom: 2rem;
	display: flex;
	justify-content: space-between;
	align-items: center;
}

.dct-template .intro-content img {
	max-width: 150px;
	width: 100%;
}

.content-row {
	margin-bottom: 2rem;
}

.content-row.border-top {
	padding-top: 4rem;
	margin-top: 4rem;
	border-top: 1px solid #e3e3e3;
}

.content-row.border-top-bottom {
	padding: 4rem 0;
	margin: 3rem 0;
	border-top: 1px solid #e3e3e3;
	border-bottom: 1px solid #e3e3e3;
}

.content-row.border-bottom {
	padding-bottom: 4rem;
	margin-bottom: 3rem;
	border-bottom: 1px solid #e3e3e3;
}

/*.content-row.border-top > div *:first-child,
.content-row.border-top-bottom > div *:first-child  {
margin-top: 0;
}

.content-row.border-bottom > div *:last-child,
.content-row.border-top-bottom > div *:last-child {
margin-bottom: 0;
}*/

.content-row img {
	display: block;
	width: 100%;
}

.dct-template .btn {
	margin: 0.75rem 0;
	display: inline-block;
}

.responsive-video {
	position: relative;
	padding-bottom: 56.25%; /* 16:9 */
	height: 0;
	margin-bottom: 1.5rem;
}

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

.useful-links-wrapper {
	margin-top: 1.3125rem;
	margin-bottom: 5rem;
}

.useful-link {
	line-height: 1;
	margin-top: 2rem;
	text-align: center;
}

.page-content-inner .useful-link a {
	display: block;
	padding: 1.5rem 1rem;
	color: white;
}

.useful-link i {
	display: block;
	font-size: 40px;
	margin-bottom: 12px;
}

.useful-link span {
	font-size: 1.25rem;
	font-weight: bold;	
}

.useful-link i,
.useful-link span {
	-webkit-transition: all .2s ease-in-out;
	-moz-transition: all .2s ease-in-out;
	-ms-transition: all .2s ease-in-out;
	-o-transition: all .2s ease-in-out;
	transition: all .2s ease-in-out;
}

.useful-link a:hover i,
.useful-link a:focus i {
	opacity: 0.8;
}

.useful-link a:hover span,
.useful-link a:focus span {
	border-bottom: 1px solid;
}

.simple-links-wrapper {
	margin-top: 50px;
}

.simple-links-wrapper h5 {
	margin-bottom: .75rem;
}

.simple-links-wrapper .simple-link {
	margin: 0 0 .5rem;  
}

.simple-links-wrapper .pre-link {
	margin: 1rem 0 0.5rem 0;
}

.btn.btn-link {
	padding: 0;
}

.documents-section {
	margin-top: 1.3125rem;
	margin-bottom: 5rem;
}

.documents-section ul {
	list-style: none !important;
	margin: 0;
	padding: 0;
	box-shadow: rgb(149 157 165 / 20%) 0px 8px 24px;
}

.documents-section ul li {
	padding: 0.75rem 1rem !important;
	margin: 0;
}

.documents-section ul li:nth-child(2n) {
	background: #f5f5f5;
}

.content-boxes .col-xs-12 {
	margin: 0.5rem 0;
}

.content-box {
	/*height: 100%;
	color: var(--dark-text-color);*/
	background: var(--light-gray);
	padding: 1rem;
	border-bottom: 5px solid var(--primary);
	display: block;
}

.content-box h3 {
	margin-top: 0;
}

.content-box img {
	width: 100%;
	aspect-ratio: 16/9;
}

/* Content Tabs */
#content-tabs {
	margin-top: 50px;
}

.ui-widget.ui-widget-content,.ui-widget-content  {
	border: none; 
	background: transparent;
	font-family: var(--paragraph-font);
	margin: 0;
}

/* Tab Header */
.ui-widget-header {
	border: none;
	background: transparent;
}

.ui-tabs .ui-tabs-nav {
	padding: 0;
	display: flex;
	flex-wrap: wrap;
	row-gap: .5rem;
	border-bottom: 2px solid var(--primary);
	border-radius: 0;
}

.ui-tabs .ui-tabs-nav li {
	font-weight: 700;
	border: none;
	background: var(--light-gray);
	transition: all .2s ease-in-out;
	margin: 0 .5rem 0 0;
	border-radius: 0;
	cursor: pointer;
}

.ui-tabs .ui-tabs-nav li:hover {
	filter: brightness(1.02);
}

.ui-tabs .ui-tabs-nav li.ui-tabs-active {
	margin-bottom: 0;
	padding-bottom: 0;
	background: var(--primary);
	border: none;
}

/* Tab Content */
.ui-tabs .ui-tabs-panel {
	padding: 1rem 0.25rem;
	margin-top: 0;
}

.ui-widget-content a {
	color: var(--secondary);
}

.ui-widget-content .btn {
	margin-top: 1rem;
	display: inline-block;
}

.ui-widget-content .btn-primary {
	color: white;
}

.ui-widget-content img {
	max-height: 500px;
}

/*.ui-widget-content .btn-link {
color: var(--primary);
}*/

/*.tab-item-content {
padding: 1rem 0;
}*/

.ui-tabs .ui-tabs-nav .ui-tabs-anchor {
	white-space: pre-wrap;
}

/* Photo Gallery */
.gallery-wrapper {
	margin-top: 50px;
}

.gallery-item {
	margin-bottom: 1rem;
}
.gallery-item img {
	min-height: unset;
	aspect-ratio: 4/3;
	width: 100%;
}

.pswp__custom-caption {
	text-align: center;
	font-size: 16px;
	color: #fff;
	width: fit-content;
	max-width: 800px;
	padding: .5rem 1rem;
	position: absolute;
	left: 50%;
	bottom: 1rem;
	transform: translateX(-50%);
}

@media (min-width: 62em) and (max-width: 99em) {
	.useful-link span {
		font-size: 0.9rem;
	}
}

/* Staff Directory */

.profiles, .school-finder {
	padding-top: 30px;
}

.profiles .search-bar-wrapper, .school-finder .search-bar-wrapper {
	display: flex;
	align-items: center;
	background-color: var(--light-gray);
	padding: 0;
	position: relative;
	height: 45px;
	width: 300px;
}

.profiles .search-bar-wrapper i, .school-finder .search-bar-wrapper i {
	background-color: var(--light-gray);
	font-size: 1.2rem;
	position: absolute;
	padding-left: 10px;
	height: 100%;
	display: flex;
	color: var(--primary);
	align-items: center;
}

.profiles #search-form, .school-finder #search-form {
	margin: 0;
	display: flex;
	flex-direction: row;
	align-items: center;
	background-color: var(--light-gray);
}

.profiles #search-term {
	margin: 0;
	height: 100%;
	box-sizing: border-box;
	border: none;
	outline: none;
	width: 200px;
	position: absolute;
	top: 0;
	bottom: 0;
	left: 30px;
	padding-left: 10px;
	background-color: var(--light-gray);
	font-family: var(--paragraph-font);
}

.profiles #search-term::placeholder {
	font-size: .75rem;
}

.profiles .profile-item {
	display: flex;
	margin-bottom: 2rem;
}

.profiles .intro-content {
	margin-top: 2rem;
	margin-bottom: 3rem;
}

.profiles .intro-content p {
	margin-bottom: .5rem;
}

.profiles img {
	height: 80px;
	width: 80px;
	max-width: unset;
	border-radius: 1000px;
}

.profiles img.placeholder {
	opacity: 0.75;
}

.profiles .profile-text {
	margin-left: 20px;
}

.profiles .profile-text p {
	margin-bottom: 0;
	margin-top: 5px;
}

.profiles .profile-text h2, .profiles .profile-text h4 {
	margin: 10px 0;
}

.page-content .doc-links {
	list-style: none;
	padding-left: 0;
}

.doc-links li {
	padding-bottom: .5rem;
}

/* Transportation */
.flex-row-between {
	display: flex;
	flex-direction: row;
	justify-content: space-between;
	flex-wrap: nowrap;
	align-items: center;
}

#transportation-column-container {
	align-items: flex-start;
}

.bus-container-route {
	height:105px;
	margin:1vh;
	padding:1vw;
	background: #F5F5F5;
}
h5.bus-route-name {
	font-size: 1.1rem;
	font-weight: 500;
}
.bus-on-time {
	border-left: 10px solid #7BBE2E;
}

.bus-on-time h5 {
	padding-top: 6px;
}
.status-on-time {
	color:#7BBE2E!important;
	font-weight:600;
	font-size: 1.2rem;
	padding-top: 6px;
}
.bus-cancelled {
	border-left: 10px solid #E05B2A;
}
.status-cancelled {
	color: #E05B2A!important;
	font-weight:600;
	font-size: 1.2rem;
}
.bus-delayed {
	border-left: 10px solid #F5B61F;
}
.status-delayed {
	color: #F5B61F!important;
	font-weight:600;
	font-size: 1.2rem;
}
.bus-grid-row {
	display: grid;
	grid-template-columns: 20% 20% 5% 20% 20% 15% 
}

.last-updated {
	font-size: 1rem;
}
.tooltip {
	display: flex;
	align-items: center;
}

.tooltip i {
	margin-right: 10px;
}

@media (max-width: 62em) {
	.flex-row-between {
		flex-wrap: wrap;
	}
	.bus-container-route {
		height:auto;
		width: 100%;
	}
	.bus-container-route h5 p {
		font-size: 0.9rem !important;
	}
	.bus-route-name {
		font-size:1rem;
	}
	.last-updated {
		font-size:1rem;
	}
	.bus-pad-side {
		padding-left:10px;
		padding-right:10px;
	}
	#transportation-column-container {
		display:flex;
		flex-direction:column;
	}
}

/* School Finder */
/* see staff directory for search styling */

/*.school-finder #school-tags {
margin: 0;
height: 100%;
box-sizing: border-box;
border: none;
outline: none;
width: 100%;
position: absolute;
top: 0;
bottom: 0;
left: 30px;
padding-left: 10px;
background-color: var(--light-gray);
font-family: var(--paragraph-font);
}

.school-finder #school-tags::placeholder {
font-size: .75rem;
}*/

#school-finder-app p {
	margin-bottom: .5rem;
}
#legend {
	list-style: none;
	margin: 2rem 0;
	padding: 0;  
}
#legend li {
	display: inline-block;
	padding: 5px 10px;
	margin: 0 5px;
	background: #efefef;
	border-radius: 50px;
	font-size: 0.75rem;
}
#legend i { 
	vertical-align: middle;
	margin-left: -5px;
} 
#legend .elementary { color: #f15d43 }
#legend .junior-high-school { color: #67DEDE }
#legend .high-school { color: #6B95FE}
#legend .other { color: #FF9900 }

/* Search Results */
.container.pad-side > .row > h1 {
	width: 100%;
	margin-top: 50px;
}
.search-results {
	display: flex;
	flex-wrap: wrap;
	gap: 1rem;
	margin-bottom: 50px;
    width: 100%;
}

.search-result {
	border: 1px dashed #c3c3c3;
	padding: 1rem 1rem 0;
	flex-basis: 100%;
	max-width: 100%;
}

.search-result a {
	display: flex;
	column-gap: 1rem;	
	color: var(--dark-text-color);
}

.search-description strong {
	color: var(--primary);
}

.error-page-container .input-buttons {
	margin: auto;
}


/* News and Event Article */
.article-date.news-date p, .article-date.event-date {
	color: var(--dark-green);
	font-family: var(--heading-font);
	font-weight: 500;
}

.article-date.event-date {
	display: flex;
	align-items: center;
}

.article-date.event-date .format-date {
	margin-left: 10px;
}

/* Documents */
.cm-documents-directory a {
	color: var(--secondary);
}

/* Custom Alerts Styling */
#popup-container .modal-content {
	position: absolute;
	top: 50%;
	left: 0;
    right: 0;
	margin: auto;
	transform: translateY(-50%);
	padding: 0;
	background: var(--dark-green);
	color: white;
	text-align: left;
	border-radius: 10px;
    border: none;
}

#popup-container .popupContent > * {
	padding-left: 2rem;
}

#popup-container .popupContent > h2 {
	font-size: 2rem;
}

#popup-container button {
    position: absolute;
    right: 0.5rem;
    top: 0.5rem;
}

#popup-container button i {
	background: none;
}

#popup-container .popupImage img {
    height: 100%;
	border-radius: 0 10px 10px 0;
	display: block;
}

#popup-container .popupImage {
	position: relative;
}

#popup-container .popupImage::after {
	content: '';
	width: calc(100% - 2rem);
    height: 100%;
    background: rgba(29, 29, 29, 0.15);
	border-radius: 0 10px 10px 0;
    position: absolute;
    left: 1rem;
    right: 0;
    top: 0;
}

.banner-alert-wrapper {
    font-size: 1.5rem;
    background: var(--yellow);
    border: none;
    color: white;
    text-align: left;
	padding: 0;
	width: 100%;
	margin-bottom: 3px;
}

.banner-alert-wrapper p {
	display: inline;
	font-size: 1rem;
	margin: 0;
	font-family: var(--heading-font);
	line-height: 1.4;
}

#bannerAnchor {
	color: white;
	padding-left: .5rem;
	font-weight: 500;
	font-size: 1rem;
}

.alert-title {
	font-weight: 500;
}

#tablist.swiper-wrapper {
    text-align: center;
}

.alert-slide {
    display: flex;
    flex-direction: column;
    justify-content: center;
    height: auto;
}

.alert-text {
    display: flex;
    justify-content: center;
    gap: .5rem;
	width: calc(100% - 80px);
    margin: 1rem auto;
}

.alert-text .icon-col i {
	margin-top: 5px;
	font-size: 1rem;
}

.alert-text .text-col {
	text-align: left;
}

.alert-button-next:after,
.alert-button-prev:after {
    color: white;
    font-size: 1rem;
}

@media (max-width: 48em){
	#popup-container .popupContent, 
	#popup-container .popupImage {
		flex-basis: 100%;
    	max-width: 100%;
	}
	
	#popup-container .popupContent > * {
		padding-left: 1rem;
		padding-right: 1rem;
	}
	
	#popup-container .popupContent > h2 {
		margin-top: 2rem;
	}
	
	#popup-container .popupImage img {
		border-radius: 0 0 10px 10px;
	}
	
	#popup-container .popupImage::after {
		border-radius: 0 0 10px 10px;
	}
}

@media (min-width: 62em) {
	#popup-container .modal-content {
		position: absolute;
		top: 50%;
		margin: auto;
		transform: translateY(-50%);
		left: 0;
		right: 0;
	}
	
	#popup-container .popupContent > h2 {
		font-size: 3rem;
	}
	
	.banner-alert-wrapper {
		grid-template-columns: 4rem auto;
	}
	
	.alert-icon i {
		font-size: 3rem;
	}
	
	.alert-text {
		width: 80%;
		margin: 1rem auto;
	}
}

/* Landing Page Template */
.row.landing {
    row-gap: 1rem;
    flex-wrap: wrap;
	list-style: none;
	padding-left: 0;
	margin-top: 1rem;
}

.landing-page-padding {
	background: var(--light-gray);
	color: var(--primary);
	border-bottom: 5px solid var(--primary);
	min-height: 120px;
    display: flex;
    flex-direction: column;
    justify-content: center;
    text-align: center;
}

.landing-item {
	list-style: none;
}

@media all and (min-width: 62em) {
	.landing-page-padding {
		min-height: 160px;
	}
}

/* Support Template */
.intro-content.support {
    background: #303030;
    padding: 2rem .5rem;
}

.intro-content.support h2,
.intro-content.support p {
	color: white;
	margin: 0;
}

.intro-content.support a {
	color: var(--light-green)
}
.support-links {
	margin: 1.5rem 0;
	row-gap: 1.5rem;
}

.search-bar-wrapper.support {
	margin-bottom: 1.5rem;
}

/* Image Carousel and Text Template */
.gallery-slide img {
	aspect-ratio: 3/1;
	width: 100%;
    display: block;
}

.gallery-swiper .swiper-button-next:after,
.gallery-swiper .swiper-button-prev:after {
    color: white;
    font-size: 2rem;
}

.schools-select {
    display: flex;
    flex-wrap: wrap;
    gap: 1rem;
    align-items: center;
    justify-content: center;
}

#schools-dropdown {
	position:relative;
	padding: .75rem;
	cursor: pointer;
	border-radius: 5px;
	border: none;
    font-size: .9rem;
	background-color: var(--light-gray);
	max-width: 12rem;
	appearance: none;
	-webkit-appearance: none;
}
.custom-select {
	position: relative;
}
.custom-select::after {
	position: absolute;
	right: .5rem;
	font-family: "Font Awesome 5 Free";
	font-weight: 900;
	content: "\f078";
	top: 50%;
	transform: translateY(-50%);
	font-size: .6rem;
    color: var(--dark-text-color);
	pointer-events: none;
}

/* PD Page */
.pd-list,
.pd-list * {
    box-sizing: border-box;
}

.pd-list {
    row-gap: 20px;
}

.icon-text {
    display: flex;
    align-items: center;
    gap: .5rem;
    margin-bottom: .5rem;
}

.icon-text i {
    min-width: 20px;
    font-size: .9rem;
    color: var(--dark-green);
}

.pd-buttons {
    display: flex;
    flex-wrap: wrap;
    gap: 1rem;
    margin-top: 2rem;
}

.pd-buttons a {
    display: block;
    width: fit-content;
}

.pd-card {
    border: 4px solid #EFEFEF;
    padding: 1.5rem;
    height: 100%;
    display: flex;
    flex-direction: column;
    justify-content: space-between;
}

.page-content .pd-title {
    margin-top: 0;
    color: var(--dark-text-color);
}

.pd-details {
    margin-top: 1rem;
}

.pd-date, .pd-time {
    margin-top: 0;
    margin-bottom: 0;
    line-height: 1.5;
}

.pd-desc-link {
    margin: 1rem 0;
    font-weight: 600;
    display: block;
}

.pd-tag {
    border-radius: 2px;
    padding: 3px 6px;
    background-color: var(--dark-gray);
    color: white;

}

.pd-tag.--Literacy {
    background: #33ADF2;
}

.pd-tag.--Indigenous-Education {
    background: #F28333;
}

.pd-tag.--Numeracy {
    background: #3BC325;
}

.pd-header-info {
    display: flex;
    flex-wrap: wrap;
    justify-content: space-between;
    align-items: flex-end;
    border-bottom: 2px solid var(--dark-green);
    padding-bottom: 1.5rem;
}

.pd-search-wrapper {
    background: var(--light-gray);
    padding: 2rem 1.5rem 2rem;
}

.pd-search-wrapper h4 {
    margin-top: 0;
    margin-bottom: .75rem;
}

.pd-search-wrapper input[type="search"] {
    border: none;
    border-radius: 0;
    height: auto;
    padding: .75rem 1.5rem .75rem .75rem;
    font-size: .9rem;
}

.pd-search-wrapper .search-row {
    position: relative;
}

.pd-search-wrapper .search-icon {
    position: absolute;
    right: .5rem;
    color: var(--dark-green);
}

/* Modal */
/* General Styling */
body.lb-disable-scrolling {
    overflow: hidden;
    height: 100vh;
}

.main-content-wrapper {
	margin: auto;
}

.modal-trigger {
	cursor: pointer;
}

.modal-wrapper {
    display: none;
    position: fixed;
    z-index: 700;
    left: 0;
    top: 0;
    width: 100%;
    height: 100%;
    overflow: auto;
    background-color: rgba(67, 67, 69, 0.9);
    margin: 0!important;
}

.modal-info {
	margin: 0 auto;
    width: 90%;
    position: absolute;
    top: 5rem;
    left: 0;
    right: 0;
    padding: 2rem 1rem;
	max-height: 85dvh;
    background-color: white;
    overflow: auto;
}

.close-icon {
    font-size: 1.5rem;
    cursor: pointer;
    color: white;
    position: absolute;
    right: 2rem;
    top: 2rem;
}

.pd-modal-content {
    border: 4px solid #487357;
}

.pd-modal-content .btn {
    display: block;
    width: fit-content;
    margin: 1rem 0 0 auto;
}

/* Transportation Page */
#transportation-container, 
#transportation-container * {
    box-sizing: border-box;
}

#transportation-container {
    display: flex;
    flex-wrap: wrap;
    gap: 1rem;
}

#transportation-container h5 {
    padding-top: 0;
}

#transportation-container .bus-area {
    width: 100%;
}

#transportation-container .bus-container-route {
    width: 100%;
    height: auto;
    margin: 0;
    padding: 1rem;
}

#transportation-container .bus-status {
    margin-top: .5rem;
    margin-bottom: 0;
}

.transportation-filters {
    display: flex;
    flex-wrap: wrap;
    gap: 1rem;
    align-items: center;
    margin-bottom: 2rem;
}

#search-buses {
    width: 100%;
    border: solid 1px #e4e4e4;
    transition: 0.5s;
    padding: .75rem;
}


#search-buses::placeholder {
  color: black;
}


.checkbox-cancelled {
    color: #E05B2A;
    font-weight: 600;
}

.checkbox-cancelled label {
    margin-left: 6px;
}

#select-area {
    border: solid 1px #e4e4e4;
    background-image: linear-gradient(45deg, transparent 50%, black 50%), linear-gradient(135deg, black 50%, transparent 50%);
    background-position: calc(100% - 20px) calc(1em + 3px), calc(100% - 15px) calc(1em + 3px), calc(100% - 2.5em) 0.5em;
    background-size: 5px 5px, 5px 5px, 1px 1.5em;
    background-repeat: no-repeat;
    appearance: none;
    -webkit-appearance: none;
    -moz-appearance: none;
    padding: .75rem 40px .75rem 16px;
    font-size: 16px;
    width: 100%;
}

.bus-area h3 {
    margin-bottom: .5rem;
}

.cm-edit {
	display: flex;
	align-items: center;
	gap: .5rem;
	margin-bottom: 1rem;
}

.cm-logo {
	width: 20px;
}

.nav-app-dropdown.account {
	min-width: 150px;
}

/* Quicklinks on Home page */
.quicklinks {
	background-color: var(--blue);
	color: white;
	padding: 1.5rem 1rem;
}

.quicklinks-wrapper {
	display: flex;
	flex-direction: column;
	justify-content: center;
	align-items: center;
	row-gap: 1.5rem;
	gap: 1rem;
}

.quicklink {
	color: white;
	font-weight: 500;
	line-height: 1.6;
	position: relative;
	display: block;
	font-size: 1.2rem;
	padding-bottom: 1rem;
}

.quicklink:hover,
.quicklink:focus {
	color: var(--yellow);
}

@media (min-width: 48em) {
	.quicklinks-wrapper {
		width: 90%;
		margin: auto;
		flex-direction: row;
		column-gap: 0;
	}

	.quicklinks a::after {
		content: "";
		width: 1.5px;
		height: 25px;
		background-color: rgba(255, 255, 255, 0.5);
		position: absolute;
		right: 0;
		top: 50%;
		transform: translateY(-50%);
	}

	.quicklinks a:last-of-type:after {
		content: none
	}

	.quicklink {
		padding: 0 1rem;
	}
}

@media (min-width: 75em) {
	.quicklinks-wrapper {
		width: 70%;
	}

	.quicklink {
		padding: 0 2rem;
	}
}

@media (min-width: 99em) {
	.quicklink {
		padding: 0 3rem;
	}
}
