/*
Theme Name: Portal
Author: SiteOrigin
Author URI: http://siteorigin.com/
Theme URI: http://siteorigin.com/theme/portal/
Description: At its core, Portal is a minimal blog theme, but it'll work perfectly as photography and portfolio theme. It integrates with our Page Builder plugin, so you can use it to build anything from a single landing page to a full business website. We built Portal with speed in mind. It ships with fully optimized Javascript and image spritemaps - drastically cutting load times.
Version: 1.0.5
License: GNU General Public License 2.0
License URI: license.txt
Tags: flexible-width, custom-background, custom-menu, featured-images, theme-options, threaded-comments, translation-ready
*/

/* =Reset
-------------------------------------------------------------- */

html,
body,
div,
span,
applet,
object,
iframe,
h1,
h2,
h3,
h4,
h5,
h6,
p,
blockquote,
pre,
a,
abbr,
acronym,
address,
big,
cite,
code,
del,
dfn,
em,
font,
ins,
kbd,
q,
s,
samp,
small,
strike,
strong,
sub,
sup,
tt,
var,
dl,
dt,
dd,

fieldset,
form,
label,
legend,
table,
caption,
tbody,
tfoot,
thead,
tr,
th,
td {
	border: 0;
	font-family: 'Outfit', 'Noto Sans', sans-serif;
	margin: 0;
	outline: 0;
	padding: 0;
	vertical-align: baseline;
}

h1, h2, h3, h4, h5, h6 {
	color: var(--color-secondary);
	margin-bottom: 0.5rem;
}

body {
	background: #fff;
}

article,
aside,
details,
figcaption,
figure,
footer,
header,
hgroup,
nav,
section {
	display: block;
}



table {
	border-collapse: separate; /* tables still need 'cellspacing="0"' in the markup */ 
	border-spacing: 0;
}

caption,
th,
td {
	font-weight: normal;
	text-align: left;
}

blockquote:before,
blockquote:after,
q:before,
q:after {
	content: "";
}

blockquote,
q {
	quotes: "" "";
}

a:focus {
	outline: thin dotted;
}

a:hover,
a:active {
	outline: 0; /* Improves readability when focused and also mouse hovered in all browsers people.opera.com/patrickl/experiments/keyboard/test */ 
}

a img {
	border: 0;
}


/* =Global
----------------------------------------------- */

/* Custom color variables */
:root {
	--color-primary: #005A9C;
	--color-secondary: #0078C1;
	--color-dark-blue: #065087;
	--color-highlight: #CD1041;
    --color-bg-grey: #F2F2F2;
}

.back-primary {
	background-color: var(--color-primary);
}

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

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

.back-highlight {
	background-color: var(--color-highlight);
}

/* Consistent fonts across all elements */
body,
button,
input,
select,
textarea {
	color: #7E7E7E;
	font-family: 'Outfit', 'Noto Sans', sans-serif;
	font-size: 15px;
	line-height: 1.5em;
}

h1,
h2,
h3,
h4,
h5,
h6 {
	font-family: 'Outfit', 'Noto Sans', sans-serif;
}

/* Text elements */

p {
	margin-bottom: 1.5em;
}




/* =The Header and Page Container
----------------------------------------------- */

#masthead .logo-container {
	background-color: var(--color-dark-blue);
	padding: .5rem 0;
	max-width: 375px;
	width: 100%;
}

#masthead .logo-container a img {
	max-width: 250px;
	height: auto;
}

#masthead .utility-bar {
	background-color: var(--color-primary);
	padding: 1.25rem 2.5rem;
}

#masthead .utility-bar form {
	width: 100%;
	position: relative;
}

#masthead form#searchform input[type="text"] {
	width: 100%;
	height: 40px;
	padding: 0.5rem 1rem;
	border: none;
	border-radius: 4px;
	background-color: #EAEAEA;
	color: #979797;
	font-size: 0.875rem;
}

#masthead .utility-bar form span {
	position: absolute
}

#masthead .utility-bar .profile {
	max-width: 20%;
	margin-left: 3rem;
}

#masthead .utility-bar .profile .profile-pic .avatar {
	border-radius: 50%;
	margin-right: 0.625rem;
}

#masthead .utility-bar .profile a {
	text-decoration: none;
}

#masthead .utility-bar .profile .username {
	color: #ffffff;
}

.col-3:has(nav),
#masthead .logo-container { 
    box-shadow: 2px 4px 12px 0px rgba(0, 0, 0, 0.2);
    z-index: 1000;
}

#main .desktop-sidebar {
	background: #FFF;
	box-shadow: 2px 4px 12px 0 rgba(0, 0, 0, 0.20);
}

#main .sidebar {
	max-width: 375px;
	width: 100%;
	z-index: 10;
}

#main nav .quick-links .quick-links-menu {
	margin: 0 1.25rem;
}

#main nav .quick-links .quick-link {
	margin-bottom: 1.25rem;
}

#main nav .quick-links .quick-link a {
	text-decoration: none;
}

#main nav .quick-links .quick-link .link-icon {
	height: 3.125rem;
	width: 3.125rem;
	border-radius: 50%;
	margin-right: 0.625rem;
}

#main nav .quick-links .quick-link .link-icon img {
	width: 60%;
	height: auto;
}

#main nav .quick-links .quick-link .link-title {
	font-weight: 600;
	color: var(--color-secondary);
}

#main nav div h2 {
    margin: 2rem 1.25rem;
    color: var(--color-highlight);
    text-transform: uppercase;
    font-size: 0.8125rem;
    font-weight: bold;
}

#main nav div h2 {
	margin-left: 1.875rem;
}

#main nav div ul li {
    padding: 0.75rem 1.875rem;
	white-space: nowrap;
}

#main nav div ul li a {
    color: var(--color-secondary);
    font-weight: 600;
    size: 1rem;
    text-decoration: none;
}

#main nav div ul li.active {
	background: #DAF1FF;
}

#main nav .departments .departments-menu {
	padding: 0;
	list-style: none;
}

#main nav .departments .departments-menu .menu-item .department-icon {
	display: inline-block;
	height: 1.5rem;
	width: 1.5rem;
	background-size: cover;
	background-position: center;
	margin-right: 0.625rem;
}

#main nav .departments .departments-menu .menu-item .document-count {
	background-color: #eaeaea;
	border-radius: 12px;
	color: #7e7e7e;
	height: 1.5rem;
	min-width: 1.625rem;
	padding: 0 0.5rem;
}

#main nav .looking-for .looking-for-menu {
	padding: 0;
	list-style: none;
}

#main nav .looking-for .looking-for-menu .menu-item::before {
	content: url("images/arrow-right.svg");
	position:relative;
	vertical-align: middle;
	margin-right: .75rem;
	height: 1.5rem;
	width: 1.5rem;
}

#main nav .events .upcoming-events-list .event-item {
	white-space: normal;
}

#main nav .events .upcoming-events-list .event-item .event-icon {
	background-color: var(--color-secondary);
	height: 1.75rem;
	width: 1.75rem;
	min-width: 1.75rem;
	border-radius: 50%;
}

#main nav .events .upcoming-events-list .event-item .event-icon img {
	width: 1rem;
	height: auto;
}

#main nav .events a.btn {
	margin: 0.75rem 1.875rem;
	color: #fff;
}

#main nav .events a.btn:hover {
	background-color: var(--color-highlight);
	color: #fff;
}

#main nav .partners .partner {
	border: 1px solid #f2f2f2;
	margin: 0 1.25rem 1.25rem 1.875rem;
	padding: 1.25rem 1.75rem;
	box-shadow: 0px 0.57px 2.87px 0px #00000033;
}

#main nav .partners .partner img {
	max-width: 100%;
	height: auto;
}

.mobile-header,
.mobile-sidebar {
	display: none;
}

@media (max-width: 992px) {
	.desktop-header,
	.desktop-sidebar {
		display: none;
	}

	.mobile-header,
	.mobile-sidebar {
		display: block;
	}

	#masthead .mobile-header {
		background-color: var(--color-primary);
		position: relative;
	}

	#masthead .mobile-header .logo-container {
		background-color: transparent;
		box-shadow: none;
		padding: 0;
	}

	#masthead .mobile-header .logo-container a img {
		max-width: 8.875rem;
		height: auto;
	}

	#masthead .mobile-header .utility-bar {
		padding: 0;
	}

	#masthead .mobile-header .utility-bar .hamburger .hamburger-toggle,
	#masthead .mobile-header .utility-bar .search-button .search-toggle {
		height: 1.5rem;
		width: 1.5rem;
		background: none;
		border: none;
		cursor: pointer;
	}

	#masthead .mobile-header .utility-bar .profile {
		max-width: 100%;
		margin-left: 0;
	}

	#masthead .mobile-header .utility-bar .profile .profile-pic .avatar,
	#masthead .mobile-header .utility-bar .search-button .search-toggle {
		margin-right: 1.25rem;
	}

	#masthead .mobile-header .header-top {
		background-color: var(--color-primary);
		z-index: 100;
		position: sticky;
		padding: 0.3125rem 0.625rem;
	}

	#masthead .mobile-header .search-bar {
		position: absolute;
		top: 0;
		transition: top 0.3s ease;
		padding: 0.25rem 0.625rem 0.25rem 0.625rem;
		z-index: 10;
		background-color: var(--color-primary);
		width: 100%;
	}

	#masthead .mobile-header .search-bar.active {
		top: 48px; /* Height of header-top */
	}

	#main .mobile-sidebar {
		max-width: 24.1875rem;
		width: 100%;
		background-color: #fff;
		z-index: 1000;
		height: 100vh;
		position: fixed;
		right: -100vw; /* Hide off-screen */
		transition: right 0.3s ease;
		overflow-y: auto;
		overflow-x: hidden;
		padding-bottom: 50px;
	}

	#main .mobile-sidebar.active {
		right: 0; /* Slide in */
	}

	#primary.sidebar-open {
		position: static;
		width: 100%; /* Prevent background scrolling */
	}

	#overlay {
		display: block;
		opacity: 0;
		position: fixed;
		left: 0;
		width: 100%;
		height: 100%;
		background-color: rgba(0, 0, 0, 0.4);
		z-index: 9; /* Behind the sidebar */
		transition: opacity ease-in-out 0.3s;
		pointer-events: none;
	}

	#overlay.active {
		opacity: 1;
		pointer-events: auto; /* Allow clicks */
	}
}

footer .footer-logo {
	box-shadow: 2px 4px 12px 0px rgba(0, 0, 0, 0.2);
    z-index: 1000;
	background-color: var(--color-dark-blue);
    padding: .5rem 0;
    max-width: 375px;
    width: 100%;
}

@media (max-width: 992px) {
	footer .footer-logo {
		max-width:100%;
	}
}

footer .footer-logo a img {
	max-width: 250px;
	height: auto;
}

footer .footer-menu {
	background-color: var(--color-primary);
	padding: 1.25rem 2.5rem;
}

footer .footer-menu #menu-footer-menu {
	list-style: none;
	padding: 0;
	margin: 0;
}

footer .footer-menu #menu-footer-menu .menu-item {
	display: inline;
	margin-right: 1.5rem;
}

footer .footer-menu #menu-footer-menu .menu-item a {
	color:#fff;
	text-decoration: none;
	font-weight: 400;
	font-size: 0.875rem;
}

/* Archive */

.archive .department-section .department-icon {
	height: 2rem;
	width: 2rem;
	background-size: cover;
	background-position: center;
	background-repeat: no-repeat;
	margin-right: 0.625rem;
}

.archive .department-section .department-title {
	font-weight: 600;
	color: var(--color-secondary);
	font-size: 1.5rem;
}

.archive .department-section a.btn {
	color: var(--color-secondary);
	font-weight: 600;
}

@media (max-width: 992px) {
	.archive .department-section .department-icon {
		height: 1.5rem;
		width: 1.5rem;
	}

	.archive .department-section .department-title {
		font-size: 1.125rem;
	}
}

.filter-bar {
	background-color: var(--color-highlight);
	height: 3.75rem;
}

.filter-bar .message p {
	color: #fff;
	font-size: 1.25rem;
	font-weight: 600;
}

.filter-bar .form form {
	width: 100%;
}

.filter-bar .form form .form-group {
	overflow: hidden;
	white-space: nowrap;
}

.filter-bar .form form .form-group:nth-of-type(2) {
	margin-left: 1.25rem;
}

.filter-bar .form form .form-group label {
	color: #fff;
	margin-right: 0.5rem;
	font-weight: 600;
	font-size: 1rem;
}

.filter-bar .form form .form-group select {
	max-width: 10rem;
	width: 100%;
}

@media (max-width: 1200px) {
	.filter-bar .message {
		display: none;
	}
}

@media (max-width: 576px) {
	.filter-bar .form form .form-group label,
	.filter-bar .form form .form-group select {
		font-size: 0.75rem;
	}

	.filter-bar .form form .form-group:nth-of-type(2) {
		margin-left: 0.5rem;
	}
}

@media (max-width: 365px) {
	.filter-bar .form form .form-group label,
	.filter-bar .form form .form-group select {
		font-size: 0.625rem;
	}
}

.pagination-nav .pagination .page-item .page-link {
	margin: 0 0.375rem;
	background: #fff;
	color: var(--color-secondary);
	border-radius: 6px;
	height: 60px;
	width: 60px;
	border: none;
	font-size: 1.5rem;
	font-weight: 500;
	display: flex;
	justify-content: center;
	align-items: center;
}

.pagination-nav .pagination .page-item.active .page-link {
	background: var(--color-secondary);
	color: #fff;
}


/* BLOCKS */

#heroSlider .carousel-inner .carousel-item {
	max-height: 400px;
	min-height: 400px;
	height: 100%;
	width: 100%;
	background-size: cover;
	background-position: center;
	background-repeat: no-repeat;
	padding: 4.5rem 2.5rem;
}

#heroSlider .carousel-inner .carousel-item .slide-overlay {
	position: absolute;
	top: 0;
	left: 0;
	width: 100%;
	height: 100%;
	background: linear-gradient(270deg, rgba(255, 255, 255, 0.00) 28.79%, rgba(255, 255, 255, 0.95) 61.4%, #FFF 79.92%, #FFF 100%);
	z-index: 1;
}

#heroSlider .carousel-inner .carousel-item .container {
	position: relative;
	z-index: 2;
}

#heroSlider .carousel-inner .carousel-item .featured-label {
	margin-bottom: 1.5rem;
}

#heroSlider .carousel-inner .carousel-item .featured-label img {
	margin-right: .5rem;
}

#heroSlider .carousel-inner .carousel-item .featured-label p {
	color: var(--color-highlight);
	font-size: .75rem;
	font-weight: 700;
}

#heroSlider .carousel-inner .carousel-item h2 {
	font-weight: 600;
	font-size: 2.375rem;
	color: var(--color-primary);
	margin-bottom: 0.625rem;
	max-width: 500px;
}

#heroSlider .carousel-inner .carousel-item h3 {
	font-size: 1.5rem;
	color: var(--color-primary);
	margin-bottom: 0.6225rem;
	font-weight: 300;
}

#heroSlider .carousel-inner .carousel-item p.excerpt {
	margin-bottom: 1rem;
	max-width: 26rem;
}

#heroSlider .carousel-inner .carousel-item a.btn {
	border-radius: 3px;
	color: #fff;
	font-weight: 700;
	font-size: 1.125rem;
	padding: 0.875rem 1.5rem;
	display: flex;
	align-items: center;
	justify-content: center;
	width: fit-content;
}

#heroSlider .carousel-inner .carousel-item a.btn .icon-arrow-right {
	margin-left: 0.5rem;
}

#heroSlider .carousel-inner .carousel-item a.btn .icon-arrow-right img {
	width: 1.25rem;
	height: auto;
}

#heroSlider .carousel-inner .carousel-item a.btn:hover {
	background-color: var(--color-highlight);
	color: #fff;
}

#heroSlider .carousel-indicators button {
	background: #fff;
	width: 0.75rem;
	height: 0.75rem;
	border-radius: 50%;
	margin: 0 2px;
	opacity: 1;
	border: none;
}

#heroSlider .carousel-indicators button.active {
	background: var(--color-highlight);
	-webkit-transition: width 0.5s ease-out;
    -moz-transition: width 0.5s ease-out;
    -o-transition: width 0.5s ease-out;
    transition: width 0.5s ease-out;
	border-radius: 12px;
	border: 1px solid #fff;
	width: 2.75rem;
}

@media (max-width: 576px) {

	#heroSlider .carousel-indicators {
		display: none;
	}

	#heroSlider .carousel-inner .carousel-item {
		padding: 0.625rem 1rem;
		min-height: 200px;	
	}

	#heroSlider .carousel-inner .carousel-item .slide-overlay {
		display: none;
	}

	#heroSlider .carousel-inner .carousel-item .container {
		padding: 1.25rem;
		border-radius: 8px;
		background: rgba(255, 255, 255, 0.90);
		backdrop-filter: blur(2px);
		display: flex;
		flex-direction: column;
		align-items: center;
		justify-content: center;
		max-width: 200px;
		margin: 0;
	}

	#heroSlider .carousel-inner .carousel-item .featured-label {
		margin-bottom: 0.625rem;
		justify-content: center;
	}

	#heroSlider .carousel-inner .carousel-item .featured-label img {
		max-height: 1rem;
		width: auto;
	}

	#heroSlider .carousel-inner .carousel-item .featured-label p {
		font-size: 0.625rem;
	}

	#heroSlider .carousel-inner .carousel-item h2 {
		font-size: 1.25rem;
		margin-bottom: 0.625rem;
		text-align: center;
	}

	#heroSlider .carousel-inner .carousel-item h3 {
		font-size: 1rem;
		margin-bottom: 0.625rem;
		text-align: center;
	}

	#heroSlider .carousel-inner .carousel-item .excerpt {
		display: none;
	}

	#heroSlider .carousel-inner .carousel-item a.btn {
		font-size: 0.625rem;
		padding: 0.5rem 1rem;
	}

}

.featured-posts {
	padding: 2.75rem 2.5rem;
	background: #FFF;
	box-shadow: 0 2px 10px 0 rgba(0, 0, 0, 0.20);
	position: relative;
	z-index: 1;
}

.featured-posts .featured-post .thumbnail {
	height: 7.875rem;
	width: 7.875rem;
	background-size: cover;
	background-position: center;
	background-repeat: no-repeat;
	border-radius: 6px;
}

.featured-posts .featured-post .content {
	margin-left: 1.25rem;
}

.featured-posts .featured-post .content .post-title {
	margin-bottom: 0.625rem;
}

.featured-posts .featured-post .content .post-title a {
	color: var(--color-primary);
	text-decoration: none;
	font-size: 1.25rem;
	font-style: normal;
	font-weight: 600;
	margin-bottom: 0.625rem;
}

.featured-posts .featured-post .excerpt {
	margin-bottom: 0.875rem;
	overflow: hidden;
   display: -webkit-box;
   -webkit-line-clamp: 2; /* number of lines to show */
           line-clamp: 2; 
   -webkit-box-orient: vertical;
}

.featured-posts .featured-post .meta .posted {
	margin-right: 1.25rem;
}

.featured-posts .featured-post .meta div span img {
	margin-right: 0.625rem;
	width: 1rem;
	height: auto;
}

@media (max-width: 1200px) {
	.featured-posts .featured-post {
		padding: 0.75rem 0;
	}

	.featured-posts .col-12:first-child .featured-post {
		border-bottom: 1px solid #d9d9d9;
	}
}

@media (max-width: 576px) {
	.featured-posts {
		padding: 0.75rem 0.625rem;
	}

	.featured-posts .featured-post .content .post-title a {
		font-size: 1rem;
		margin-bottom: 0.5rem;
	}

	.featured-posts .featured-post .content .excerpt {
		font-size: 0.75rem;
		margin-bottom: 0.8125rem;
	}

	.featured-posts .featured-post .meta {
		font-size: 0.75rem;
	}
}

.popular-section,
.recent {
	margin: 2.5rem 0;
}

.block-title .department-icon {
	height: 2rem;
	width: 2rem;
	background-size: cover;
	background-position: center;
	background-repeat: no-repeat;
	margin-right: 0.625rem;
}

.block-title .department-title {
	font-weight: 600;
	color: var(--color-secondary);
	font-size: 1.5rem;
}

#announcement {
	border: 1px solid #FDE68A;
	background: #FFFBEB;
	box-shadow: 0 0 6px 0 rgba(0, 0, 0, 0.24);
	padding: 1.25rem 1.5rem;
	display: none;
	justify-content: space-between;
	align-items: center;
}

#announcement .content {
	color: #92400d;
	line-height: normal;
}

#announcement .content .icon {
	margin-right: 1.25rem;
}

#announcement .content span p {
	margin: 0;
}

#announcement .close button {
	background: transparent;
	border: none;
	cursor: pointer;
}

@media (max-width: 992px) {
	#announcement {
		padding: 0.8125rem 0.5rem;
	}

	#announcement .content {
		font-size: 0.625rem;
		padding-right: 1.5rem;
	}

	#announcement .content .icon {
		margin-right: 0.75rem;
	}
}

#primary {
    background-color: var(--color-bg-grey);
    height: 100%;
}

#breadcrumbs {
	padding: 0.75rem;
	border-bottom: 1px solid #979797;
}

#breadcrumbs a,
#breadcrumbs span {
	color: #7e7e7e;
	font-size: 0.875rem;
	text-decoration: none;
}

#breadcrumbs span.current {
	font-weight: 600;
}

#breadcrumbs span.divider {
	margin: 0 0.75rem;
}

#breadcrumbs a:hover {
	text-decoration: underline;
	text-decoration-color: #979797;
}

#breadcrumbs span.home {
	margin-right: 0.75rem;
}

@media (max-width: 992px) {
	#breadcrumbs {
		display: none;
	}
}

/* Document Card */

.doc-card {
	border-radius: 4px;
	background: #FFF;
	box-shadow: 0 2px 10px 0 rgba(0, 0, 0, 0.20);
	min-width: 335px;
	width: 30%;
	margin: 0.625rem;
	height: -webkit-fill-available;
}

.doc-card .article-header {
	padding: 1.25rem;
	border-bottom: 1px solid #EAEAEA;
	min-height: 14.375rem;
	background-size: cover;
	background-position: center;
	background-repeat: no-repeat;
	border-top-left-radius: 4px;
	border-top-right-radius: 4px;
	display: block;
	text-decoration: none;
	color: inherit;
	transition: opacity 0.3s ease;
	-webkit-transition: opacity 0.3s ease;
	-moz-transition: opacity 0.3s ease;
}

.doc-card .article-header:hover {
	opacity: 0.9;
}

.doc-card .article-header .badge {
	padding: 2px 23px;
	height: 1.5rem;
	flex-shrink: 0;
	border-radius: 99px;
	background: var(--color-secondary);
	font-size: 0.75rem;
}

.doc-card .article-header .document-type {
	min-width: 2.25rem;
	height: 2.25rem;
	border-radius: 4px;
	background: var(--color-highlight);
}

.doc-card .article-body {
	padding: 1.25rem;
	min-height: 5.25rem;
}

.doc-card .article-body h3 {
	font-size: 1rem;
	color: var(--color-primary);
	font-weight: 500; 
}

.doc-card .article-body h3 a {
	color: var(--color-primary);
	text-decoration: none;
}

.doc-card .article-footer {
	padding: 0 1.25rem 1.25rem 1.25rem;
	min-height: 3rem;
}

.doc-card .article-footer hr {
	margin: 0 0 0.625rem 0;
}

.doc-card .article-footer p {
	margin: 0;
	font-size: 0.8725rem;
	color: #7E7E7E;
	font-weight: 500;
}

.doc-card .article-footer .views img {
	margin-right: 0.375rem;
}

.doc-card .article-footer .meta .department {
	margin-right: 0.5rem;
	text-align: right;
}

.doc-card .article-footer .meta .department #text {
	display: none;
}

.doc-card .article-footer .meta .posted {
	margin-left: 0.5rem;
}

@media (max-width: 576px) {
	.doc-card {
		width:100%;
		height: fit-content;
	}
}

@media (max-width: 370px) {
	.doc-card {
		min-width: 100%;
	}
}

/* SINGLE DOC */

.single-document .document.type-document {
	border-radius: 4px;
	background: #FFF;
	box-shadow: 0 2px 10px 0 rgba(0, 0, 0, 0.20);
}

.single-document .document .document-utility {
	border-bottom: 1px solid #d9d9d9;
}

.single-document .document .document-utility .tabs .tab {
	padding: 1.125rem 2.375rem;
	cursor: pointer;
}

.single-document .document .document-utility .tabs .tab.active {
	border-bottom: 4px solid var(--color-secondary);
	color: var(--color-secondary);
	font-weight: 600;
}

.single-document .document .document-utility .tools {
	padding: 0 1.25rem;
}

.single-document .document .tools .tool {
	color: var(--color-secondary);
	cursor: pointer;
}

.single-document .document .tools .tool a {
	text-decoration: none;
	color: var(--color-secondary);
}

.single-document .document .tools .tool:hover {
	text-decoration: underline;
}

.single-document .document .tools .tool img {
	margin-right: 0.375rem;
}

.single-document .document .tools .tool {
	margin-left: 2.5rem;
}

.single-document .document .tools .tool #favourite-btn,
.single-document .document .tools .tool #favourite-btn-mobile {
	color: var(--color-highlight);
	border: 1px solid var(--color-highlight);
	padding: 0.5rem 1rem;
	border-radius: 3px;
	font-weight: 600;
	background: #fff;
}

.single-document .document .tools .tool #favourite-btn.favourite,
.single-document .document .tools .tool #favourite-btn-mobile.favourite {
	background: var(--color-highlight);
	color: #fff;
}

.single-document .document .document-overview {
	min-height: 34rem;
	padding: 1.25rem;
}

.single-document .document .document-overview .tools-mobile {
	display: none !important;
}

.single-document .document .document-overview h1 {
	color: #0078C1;
	font-family: Outfit;
	font-size: 2rem;
	font-style: normal;
	font-weight: 600;
	line-height: normal;
	margin-bottom: 0.625rem
}

.single-document .document .document-overview .stats {
	margin-bottom: 1.25rem;
}

.single-document .document .document-overview .views img {
	margin-right: 0.375rem;
}

.single-document .document .document-overview .views p {
	margin: 0 1.25rem 0 0;
    font-size: 0.8725rem;
    color: #7E7E7E;
    font-weight: 500;
}

.single-document .document .document-overview .meta .department {
	margin-right: 0.5rem;
	color: #7E7E7E;
	font-size: 0.8725rem;
	font-weight: 500;
}

.single-document .document .document-overview .meta .posted {
	margin-left: 0.5rem;
	color: #7E7E7E;
	font-size: 0.8725rem;
	font-weight: 500;
}

.single-document .document .document-overview .tab-content {
	display: none;
}

.single-document .document .document-overview .tab-content.active {
	display: block;
}

.single-document .document .document-download a.btn {
	color: #fff;
	font-size: 1.125rem;
	font-weight: 700;
	padding: 0.875rem 1.5rem;
	border-radius: 3px;
	text-decoration: none;
	display: flex;
	align-items: center;
	justify-content: center;
	margin-right: 0.75rem;
	margin-bottom: 0.75rem;
	width: fit-content;
}

.single-document .document .document-download a.btn:hover {
	background-color: var(--color-highlight);
	color: #fff;
}

.single-document .document .document-download a.btn .icon-arrow-right img {
	width: 1.25rem;
	height: auto;
	margin-left: 0.5rem;
}

.single-document .document .document-footer {
	padding: 1.25rem;
}

.single-document .document .document-footer .badges {
	display: flex;
	flex-wrap: wrap;
	gap: 0.5rem;
}

.single-document .document .document-footer .badges .badge {
	color: #7e7e7e;
	font-size: 0.875rem;
	padding: 0.25rem 0.75rem;
	border-radius: 12px;
	display: flex;
	justify-content: center;
	align-items: center;
	height: 1.5rem;
}

.single-document .document-video video,
.single-document .document-video iframe {
	border-radius: 6px;
	margin-bottom: 1.25rem;
}

.single-document .document-video.google-embed iframe {
	top: 0;
	left: 0;
	width: 100%;
	height: 100%;
	aspect-ratio: auto 16 / 9;
}

@media(max-width: 992px) {
	.single-document .document .document-overview .tools-mobile {
		display: flex !important;
		margin-bottom: 0.625rem;
	}

	.single-document .document .document-utility .tools-desktop {
		display: none !important;
	}

	.single-document .document .document-overview .tools-mobile .tool {
		margin: 0rem 2.5rem 0.5rem 0;
	}
}

@media(max-width: 576px) {
	.single-document .document .document-overview .tools-mobile {
		flex-wrap: wrap;
	}

	.single-document .document .document-overview .tools-mobile .tool {
		margin: 0rem 0.75rem 0.5rem 0;
	}
}

/* Search widget */

#searchsubmit {
	height: 20px;
	width: 20px;
	background: url(images/sprites/search-icon.png) no-repeat center center;
	background-size: contain;
	border: none;
	cursor: pointer;
	display: inline-block;
	vertical-align: middle;
	position: absolute;
	right: 1rem;
	transform: translateY(50%);
}

.textwidget p:first-child {
	margin-top: 0;
}

.textwidget p:last-child {
	margin-bottom: 0;
}

.search-results .search-results-section .department-icon {
	background-size: cover;
    background-position: center;
    background-repeat: no-repeat;
    margin-right: 0.625rem;
}

.search-results .search-results-section .department-title {
	font-weight: 600;
	color: var(--color-secondary);
	font-size: 1.5rem;
}


/* Events Widget List */
.tribe-events-widget-events-list .department-icon {
	height: 2rem;
    width: 2rem;
	background-size: cover;
	background-position: center;
	background-repeat: no-repeat;
	margin-right: 0.625rem;
}

.tribe-events-widget-events-list .department-title {
	font-weight: 600;
    color: var(--color-secondary);
    font-size: 1.5rem;
}

.tribe-events-widget-events-list .tribe-events-widget-events-list__events {
	background: #fff;
	border-radius: 4px;
	box-shadow: 0 2px 10px 0 rgba(0, 0, 0, 0.20);
	padding: 0 1.25rem
}

.tribe-events-widget-events-list .tribe-events-widget-events-list__events .tribe-events-widget-events-list__event-row,
.tribe-events-calendar-list .tribe-events-widget-events-list__event-row {
	padding: 1.25rem 0;
	margin-bottom: 0 !important;
}

/* Add bottom border to all event rows except the last one */
.tribe-events-widget-events-list__events .tribe-events-widget-events-list__event-row:not(:last-child),
.tribe-events-calendar-list .tribe-events-widget-events-list__event-row:not(:last-child) {
    border-bottom: 1px solid #d9d9d9;
}

/* Remove border if there's only one event */
.tribe-events-widget-events-list__events .tribe-events-widget-events-list__event-row:only-child,
.tribe-events-calendar-list .tribe-events-widget-events-list__event-row:only-child {
    border-bottom: none;
}

.tribe-events-widget-events-list .tribe-events-widget-events-list__events .tribe-events-widget-events-list__event-row .tribe-events-widget-events-list__event-date-tag,
.tribe-events-calendar-list .tribe-events-widget-events-list__event-row .tribe-events-widget-events-list__event-date-tag {
	border-radius: 4px;
	border: 1px solid #d9d9d9;
	padding: 0.625rem;
	margin-right: 1.25rem;
}

.tribe-events-widget-events-list .tribe-events-widget-events-list__events .tribe-events-widget-events-list__event-row .tribe-events-widget-events-list__event-date-tag time .tribe-events-widget-events-list__event-date-tag-month,
.tribe-events-calendar-list .tribe-events-widget-events-list__event-row .tribe-events-widget-events-list__event-date-tag time .tribe-events-widget-events-list__event-date-tag-month {
	color: var(--color-secondary);
	font-weight: 500;
	font-size: 0.8125rem;
	text-transform: uppercase;
	margin-bottom: 0.25rem;
	line-height: normal;
}

.tribe-events-widget-events-list .tribe-events-widget-events-list__events .tribe-events-widget-events-list__event-row .tribe-events-widget-events-list__event-date-tag time .tribe-events-widget-events-list__event-date-tag-daynum,
.tribe-events-calendar-list .tribe-events-widget-events-list__event-row .tribe-events-widget-events-list__event-date-tag time .tribe-events-widget-events-list__event-date-tag-daynum {
	color: var(--color-highlight);
	font-size: 2rem;
	font-weight: 500;
	line-height: normal;
}

.tribe-events-widget-events-list .tribe-events-widget-events-list__events .tribe-events-widget-events-list__event-row .tribe-events-widget-events-list__event-wrapper h3 a,
.tribe-events-calendar-list .tribe-events-widget-events-list__event-row .tribe-events-widget-events-list__event-wrapper h3 a {
	color: var(--color-secondary);
	font-size: 1.25rem;
	font-style: normal;
	font-weight: 500;
	line-height: normal;
	text-decoration: none;
	margin-bottom: 0.5rem;
}

.tribe-events-widget-events-list .tribe-events-widget-events-list__events .tribe-events-widget-events-list__event-row .tribe-events-widget-events-list__event-wrapper .tribe-events-widget-events-list__event-datetime-wrapper time .time-icon img,
.tribe-events-calendar-list .tribe-events-widget-events-list__event-row .tribe-events-widget-events-list__event-wrapper .tribe-events-widget-events-list__event-datetime-wrapper time .time-icon img {
	width: 1rem;
	height: auto;
}

.tribe-events-widget-events-list .tribe-events-widget-events-list__events .tribe-events-widget-events-list__event-row a.btn,
.tribe-events-calendar-list .tribe-events-widget-events-list__event-row a.btn {
	height: 30px;
	min-width: 180px;
	background-color: var(--color-highlight);
	border-radius: 3px;	
	padding: 0 1rem;
}

.tribe-events-widget-events-list .tribe-events-widget-events-list__events .tribe-events-widget-events-list__event-row a.btn .add-calendar,
.tribe-events-calendar-list .tribe-events-widget-events-list__event-row a.btn .add-calendar {
	margin-right:0.625rem;
}

.tribe-events-widget-events-list .tribe-events-widget-events-list__events .tribe-events-widget-events-list__event-row a.btn .add-calendar img,
.tribe-events-calendar-list .tribe-events-widget-events-list__event-row a.btn .add-calendar img {
	height: 1rem;
	width: 1rem;
}

.tribe-events-widget-events-list .tribe-events-widget-events-list__events .tribe-events-widget-events-list__event-row a.btn p,
.tribe-events-calendar-list .tribe-events-widget-events-list__event-row a.btn p {
	color: #fff;
	font-size: 0.875rem;
	font-weight: 700;
}

.tribe-events-widget-events-list .tribe-events-widget-events-list__view-more a,
.tribe-events-calendar-list .tribe-events-widget-events-list__view-more a {
	width: fit-content;
	color: #fff !important;
	padding: .25rem 1rem;
	border-radius: 4px;
	background-color: var(--color-highlight) !important;
}

.tribe-events-widget-events-list .tribe-events-widget-events-list__view-more a:hover {
	background-color: var(--color-highlight);
	color: #fff;
}


/* ALL EVENTS PAGE */

.tribe-common .tribe-common-l-container {
	border-radius: 4px;
    background: #FFF;
    box-shadow: 0 2px 10px 0 rgba(0, 0, 0, 0.20);
	margin: 0;
	padding: 1.25rem !important;
	min-height: 0px !important;
	width: 100%;
	max-width: 100% !important;
}

.tribe-common .tribe-common-l-container .tribe-events-c-top-bar__datepicker-button {
	height: 30px;
	color: #fff;
	font-weight: 700;
	border: none;
	border-radius: 4px;
	background-color: var(--color-highlight);
	padding: 0 1rem;
	font-size: 1rem;
}

.tribe-events-calendar-list .tribe-events-widget-events-list__event-row .tribe-events-widget-events-list__event-date-tag {
	width: 80px;
	height: fit-content;
}

.tribe-events-calendar-list .tribe-events-widget-events-list__event-row .tribe-events-widget-events-list__event-date-tag .tribe-events-widget-events-list__event-date-tag-datetime {
	display: flex;
    flex-direction: column;
    height: 100%;
    text-align: center;
}


/* SINGLE EVENT PAGE */

.single-tribe_events #content #tribe-events-pg-template {
	padding: 0px;
}

.single-tribe_events #content #tribe-events-content {
	border-radius: 4px;
	background: #FFF;
	box-shadow: 0 2px 10px 0 rgba(0, 0, 0, 0.20);
	padding: 1.25rem;
}

.single-tribe_events #content h1 {
	color: var(--color-secondary);
	font-size: 2rem;
	font-weight: 600;
	line-height: normal;
	margin-bottom: 0.625rem;
}

.single-tribe_events #content .event-time {
	margin-bottom: 1.25rem;
}

.single-tribe_events #content .tribe-events-back a {
	color: #fff;
	background-color: var(--color-highlight);
	font-weight: 700;
	text-decoration: none;
	padding: 0.5rem 1rem;
	border-radius: 4px;
	font-size: 0.875rem;
}

.single-tribe_events #content .tribe-events-c-subscribe-dropdown {
	margin: 0;
}

.single-tribe_events #content .tribe-events-c-subscribe-dropdown__button {
	background-color: var(--color-highlight);
	border: none;
	width: fit-content;
	border-radius: 4px;
}

.single-tribe_events #content .tribe-events-c-subscribe-dropdown__button button {
	background-color: var(--color-highlight);
	color: #fff;
	font-weight: 700;
	border: none;
	width: fit-content;
}

.single-tribe_events #content .tribe-events-c-subscribe-dropdown__button .tribe-common-c-svgicon--caret-down {
	color: #fff;
	height: 1.5rem;
}

.single-tribe_events #content .tribe-events-c-subscribe-dropdown__content {
	width: fit-content;
	border: 1px solid rgba(0,0,0,0.2);
	border-radius: 4px;
	box-shadow: 0 5px 10px rgba(0, 0, 0, 0.20);
	margin-top: 0.25rem;
} 

.single-tribe_events #content .tribe-events-c-subscribe-dropdown__content .tribe-events-c-subscribe-dropdown__list .tribe-events-c-subscribe-dropdown__list-item {
	width: 100%;
	text-align: center;
}

.single-tribe_events #content .tribe-events-c-subscribe-dropdown__content .tribe-events-c-subscribe-dropdown__list .tribe-events-c-subscribe-dropdown__list-item:not(:last-child) {
	border-bottom: 1px solid rgba(0,0,0,0.2);
}

.single-tribe_events #content .tribe-events-c-subscribe-dropdown__content .tribe-events-c-subscribe-dropdown__list .tribe-events-c-subscribe-dropdown__list-item a {
	color: var(--color-secondary);
	font-weight: 700;
	text-decoration: none;
	padding: 0.5rem 1rem;
	display: block;
}

.single-tribe_events #content .tribe-events-single-section-title {
	font-size: 1.25rem;
	color: var(--color-secondary);
	font-weight: 600;
}

/* PAGE */

.page-template-default .content-area .article,
.page-template-template-full .content-area .article  {
	border-radius: 4px;
    background: #FFF;
    box-shadow: 0 2px 10px 0 rgba(0, 0, 0, 0.20);
}