@font-face {
	font-family: 'divine-regular';
	src: url('../webfonts/divine-webfont.woff2') format('woff2'),
		 url('../webfonts/divine-webfont.woff') format('woff');
	font-weight: normal;
	font-style: normal;

}

/* -- Global Styles -- */

:root {
	--max-width: 1260px;
	--page-pad: 60px;
	--sans: 'news-gothic-std', sans-serif;
	--serif: 'EB Garamond', serif;
}


html,
body {
	width: 100%;
	height: 100%;
	margin: 0;
	padding: 0;
}
 
body { 
	position: relative;
	overflow-x: hidden;
	font-size: 13px;
	line-height: 19px;
	background: black;
	font-family: 'news-gothic-std';
	font-family: var(--sans);
}

a {
	outline: none;
	text-decoration: none;
}

::selection {
	background: #18CFCD;
	color: #FFF;
}

::-moz-selection {
	background: #18CFCD; 
}

p {
	margin: 30px 0;
	font-family: 'EB Garamond';
	font-family: var(--serif);
}

img {
	border: 0;
}

hr {
	border: 0;
	height: 0;
	border-top: 1px solid black;
	margin: 40px 0;	
}

h1 {
	font-size: 50px;
	line-height: 60px;
	margin: 0;
	padding: 0;
	font-family: var(--sans);
	font-weight: bold;
	color: white;
}

h2 {
	margin: 0 0 30px;
	padding-top: 10px;
	font-size: 34px;
	line-height: 40px;
	font-weight: bold;
	font-family: var(--sans);
}

h3 {
	margin: 10px 0 30px;
	font-size: 26px;
	line-height: 30px;
	letter-spacing: 0.01em;
	font-weight: bold;
	font-family: var(--sans);
}

h4 {
	margin: 10px 0;
	font-size: 22px;
	line-height: 25px;
	font-weight: bold;
	font-family: var(--sans);
}

h5 {
	margin: 10px 0 30px;
	font-size: 19px;
	line-height: 22px;
	font-weight: bold;
	font-family: var(--sans);	
}

h6 {
	margin: 5px 0 25px;
	padding-top: 4px;
	font-size: 16px;
	line-height: 19px;
	letter-spacing: .04em;
	font-weight: bold;
	font-family: var(--sans);
	border-top: 1px solid black;
}

h6 a {
	color: var(--blue);
	text-decoration: underline;
}

label {
	font-size: 16px;
	line-height: 19px;	
	font-family: var(--sans);
}

textarea,
input[type=text],
input[type=email],
input[type=password],
input[type=tel],
button {
	display: block;
	box-sizing: border-box;
	width: 100%;
	margin: 0;
	height: 49px;
	padding: 6px 20px;
	font-size: 16px;
	font-weight: bold;
	font-family: var(--sans);
	border: 0;
	border-top: 1px solid black;
	background: #F6F6F6;
	box-shadow: inset 0 0 3px #CCC;
	-webkit-appearance: none;
	-webkit-border-radius: 0;
}

.button {
	display: block;
	padding: 10px 0 0;
	font-size: 16px;
	line-height: 20px;
	font-weight: bold;
	color: black;
	font-family: var(--sans);
	border-top: 1px solid black;
	cursor: pointer;
}

.button * {
	stroke: black;
}

textarea::placeholder,
input::placeholder,
span.placeholder {
	color: black;
	opacity: 1;
}

textarea:focus::placeholder,
input:focus::placeholder {
	color: var(--gray);
}

textarea {
	height: 100px;	
}

button {
	height: 40px;
	border-top: 1px solid var(--gray);
	background: white;
	color: var(--gray);
	box-shadow: none;
	text-align: left;
	padding-left: 0;
	cursor: pointer;
}

button * {
	stroke: var(--gray);
}

button svg {
	margin-left: 5px;
}

blockquote {
	margin: 20px 0;
}

figure {
	margin: 0;	
}

blockquote {
	margin: 50px 0;
	font-family: var(--serif);
	font-size: 44px;
	line-height: 50px;
	font-weight: normal;	
}

form h3 {
	margin-top: 60px;	
}

form h4 {
	margin: 20px 0;
}

form button {
	border-color: var(--pink);
	color: var(--pink);
}

form button * {
	stroke: var(--pink);
}

.form-split {
	display: flex;
	gap: 15px;	
}

.form-split > * {
	flex-basis: 50%;
}

.form-date {
	display: flex;
	gap: 15px;	
}

.form-date > * {
	flex-basis: 20%;
}

.form-date > *:first-child {
	flex-basis: 60%;
}

.form-radio {
	width: 12px;
	height: 12px;
	padding: 6px;
	border: 0;
	background: #F6F6F6;
	box-shadow: inset 0 1px 3px rgba(0,0,0,.15);
}	

.form-checkbox {
	width: 12px;
	height: 12px;
	padding: 4px;
	border: 0;
	background: #F6F6F6;
	box-shadow: inset 0 1px 3px rgba(0,0,0,.15);
}

.form-select {
	height: auto;
	font-size: 16px;
	line-height: 19px;	
}

.form-select-trigger {
	height: 49px;
	padding: 0;
	border: 0;
	border-top: 1px solid black;
	line-height: 49px;
	background: #F6F6F6 url('../images/common/arrow-down.svg') center right 10px no-repeat;
	box-shadow: inset 0 0 3px #CCC;
	font-weight: bold;
}

.form-select-trigger span {
	height: auto;
	padding: 0 20px;
}

.form-select-open .form-select-trigger {
	background: #F6F6F6 url('../images/common/arrow-up.svg') center right 10px no-repeat;
}

.form-select-list {
	box-sizing: border-box;
	border: 0;
	border-bottom: 1px solid black;
	background: #F6F6F6;
}

.form-select-list span {
	padding: 10px 20px;
}

.form-desc {
	margin-top: 6px;
	margin-bottom: 4px;
	font-size: 14px;
	line-height: 17px;
	text-align: right;	
	font-family: var(--sans);
	color: var(--gray);
}

@keyframes move-in-label {
  from {
	margin-top: -10px;
	opacity: 0;
  }
  to {
	margin-top: -20px;
	opacity: 1;
  }
}

.form-item {
	padding-bottom: 32px;	
}

.form-error {
	font-weight: bold;
	font-size: 20px;
	line-height: 26px;
	letter-spacing: .02em;
	color: var(--red);
}

.form-item-label {
	position: absolute;	
	height: 20px;
	line-height: 20px;
	margin-top: -20px;
	font-size: 12px;
	font-weight: bold;
	color: var(--gray);
	animation-name: move-in-label;
	animation-duration: .3s;
}

.form-item .form-error {
	position: absolute;	
	height: 20px;
	line-height: 20px;
	margin-top: -20px;
	font-size: 12px;
	font-weight: bold;
}


.logo {
	display: block;
	position: relative;
	width: 195px;
	height: 90px;
	background: url('../images/common/logo-text.svg') left bottom no-repeat;
}

.logo-icon {
	display: block;
	width: 50px;
	height: 50px;
	margin-left: 5px;
	background: url('../images/common/logo-icon.svg') no-repeat;
}

.logo-text {
	display: none;
}


#symbols {
	display: none;	
}

/* -- Wrapper -- */

#wrapper {
	position: relative;
	box-sizing: border-box;
	padding-top: 202px;
	background: black;
}

.active-alert #wrapper {
	padding-top: 242px;
}


/* -- Header -- */

header {
	position: absolute;
	z-index: 999;
	top: 0;
	width: 100%;
	min-height: 201px;
	background: rgba(0,0,0,.88);
	border-bottom: 1px solid #444;
	transition: background 1s;
}

#alert {
	display: block;
	padding: 10px 20px;
	background: blue;
	font-size: 13px;
	line-height: 20px;
	font-weight: bold;
	text-align: center;
	color: white;
}

#alert span {
	display: inline-block;
	max-width: var(--max-width);
}

#alert a {
	color: white;
	text-decoration: underline;
}

#header-wrap {
	position: relative;
	padding: 20px;
	padding-left: var(--page-pad);
	padding-right: var(--page-pad);
	max-width: var(--max-width);
	margin: auto;
}

header.compact {
	position: fixed;
	min-height: 91px;
	background: black;
}

@keyframes fade-in-logo {
  from {
	opacity: 0;
  }
  to {
	opacity: 1;
  }
}

header.compact .logo {
	position: absolute;
	height: 50px;
	width: 50px;
	background: none;
	animation-name: fade-in-logo;
	animation-duration: .3s;
}

header #nav-menu {
	padding-left: 0;
	padding-top: 18px;
	transition: padding-left .2s;
}

header .menu-trigger {
	border: 0;
	padding-top: 0;
	padding-bottom: 0;
}

header.compact #nav-menu {
	padding-top: 0;
	padding-right: 0;
	padding-left: 80px;	
}

header nav {
	font-weight: 700;
	font-size: 16px;
	line-height: 20px;
}

header nav ul {
	display: flex;
	list-style: none;
	padding: 0;
	margin: 0;
	font-family: 'news-gothic-std';
	font-family: var(--sans);
}

header nav > ul li {
	margin: 0;
	padding: 0 32px 0 0;
}

header nav ul.submenu {
	position: absolute;
	display: none;
	visibility: hidden;
	padding: 28px 0 50px;
}

header nav ul.submenu li {
	margin: 0;
	padding: 2px 0;
	font-size: 16px;
	line-height: 22px;
}

header nav ul.submenu a {
	color: white;
}

header nav#primary-nav li:nth-child(1) .menu-trigger {
	color: var(--blk-blue);	
}

header nav#primary-nav li:nth-child(1) .menu-trigger * {
	stroke: var(--blk-blue);	
}

header nav#primary-nav li:nth-child(2) .menu-trigger {
	color: var(--blk-green);	
}

header nav#primary-nav li:nth-child(2) .menu-trigger * {
	stroke: var(--blk-green);	
}

header nav#primary-nav li:nth-child(3) .menu-trigger {
	color: var(--blk-orange);	
}

header nav#primary-nav li:nth-child(3) .menu-trigger * {
	stroke: var(--blk-orange);	
}

header nav#primary-nav li:nth-child(4) .menu-trigger {
	color: var(--blk-purple);	
}

header nav#primary-nav li:nth-child(4) .menu-trigger * {
	stroke: var(--blk-purple);	
}

header nav#primary-nav li:nth-child(5) .menu-trigger {
	color: var(--blk-teal);	
}

header nav#primary-nav li:nth-child(5) .menu-trigger * {
	stroke: var(--blk-teal);	
}

header nav#primary-nav li:nth-child(6) .menu-trigger {
	color: var(--blk-yellow);	
}

header nav#primary-nav li:nth-child(6) .menu-trigger * {
	stroke: var(--blk-yellow);	
}

header nav#primary-nav li:nth-child(7) .menu-trigger {
	color: var(--blk-red);	
}

header nav#primary-nav li:nth-child(7) .menu-trigger * {
	stroke: var(--blk-red);	
}

header nav#primary-nav .menu-trigger:hover {
	filter: brightness(120%);
}

header nav#secondary-nav {
	margin-top: 15px;
	font-size: 13px;
	line-height: 16px;
	letter-spacing: 1px;
	text-transform: uppercase;
}

header nav#secondary-nav ul li {
	padding-right: 27px;
}

header nav#secondary-nav ul li a {
	color: white;
	padding-right: 0;
}

header nav#secondary-nav ul li a#nav-search {
	padding-right: 16px;
	background: url('../images/common/search-icon.svg') right 2px no-repeat;	
}

header #menu-button {
	display: none;
	position: absolute;
	left: calc(100vw - 70px);
	top: 29px;
}

header #menu-button #menu-open-svg {
	margin-top: 5px;
}

header #menu-button #menu-close-svg {
	display: none;
}

header #menu-button.close #menu-open-svg {
	display: none;
}

header #menu-button.close #menu-close-svg {
	display: block;
}

header .support-button {
	display: block;
	position: absolute;
	right: var(--page-pad);
	top: 35px;
	padding: 12px 15px 12px 42px;
	font-size: 16px;
	line-height: 20px;
	font-weight: bold;
	color: white;
	background: #3DB8A4 url('../images/common/icon-heart.svg') 12px 13px no-repeat;
	transition: opacity 1s;
	transition-delay: 1s;
}

header .support-button:hover {
	background-color: #4CCEB9;
}

header.compact .support-button {
	display: none;
}


/* -- Content & Page -- */

#content {
	position: relative;
	width: 100%;
	background: white;
	color: black;
	min-height: 800px;
	overflow-x: hidden;
}

.page {
	padding: 40px 0 75px;	
}

.page-header {
	position: relative;
	z-index: 10;
	padding: 80px 20px 40px;
	padding-left: var(--page-pad);
	padding-right: var(--page-pad);
	background: black;	
}

.page-header h1 {
	max-width: var(--max-width);
	margin: 0 auto;	
}

.page-header-back {
	background: black;	
}

.page-header-back .back-header {
	max-width: var(--max-width);
	margin: 0 auto;
	padding: 10px 20px;
	padding-left: var(--page-pad);
	padding-right: var(--page-pad);	
}

.page-header-back .back-header a:hover {
	filter: brightness(120%);
}

.page-header-back .page-header {
	border-top:  1px solid #444;
	padding-top: 40px;
}

.page-header-small {
	padding: 35px 20px 25px;
	padding-left: var(--page-pad);
	padding-right: var(--page-pad);
	background: black;	
}

.page-header-small h1 {
	max-width: var(--max-width);
	margin: 0 auto;
	font-size: 26px;
	line-height: 30px;
	font-weight: bold;
	font-family: var(--sans);	
}

.control-header {
	max-width: var(--max-width);
	margin: 0 auto;
	display: flex;
	gap: 20px;
	align-items: center;
}

.control-header  h1 {
	flex-grow: 1;
	margin-left: 0;
	margin-right: 0;
}

.control-header .controls {
	position: relative;
	flex-shrink: 1;
	display: flex;
	gap: 30px;
}

.controls .control {
	position: relative;
	display: block;
	box-sizing: border-box;
	min-width: 200px;
	flex-grow: 1;
	font-size: 13px;
	line-height: 20px;
	font-weight: bold;
	color: white;
	border-top: 1px solid white;
	border-bottom:  1px solid white;
}

.controls .toggle-button {
	display: block;
	padding: 9px 0;
	color: var(--blk-orange);
	border-color: var(--blk-orange);
}

.controls .toggle-button .icon {
	display: block;
	float: right;
	width: 20px;
	height: 20px;
}

.controls .toggle-button .icon span {
	display: block;
	background: var(--blk-orange);
}

.controls .toggle-button.selected {
	color: black;
	padding: 9px 10px;
	background: var(--bg-orange);
	border-color: var(--bg-orange);
}

.controls .toggle-button.selected .icon span {
	background: black;
}

.controls .dropdown-menu {
	max-width: 250px;
	border-color: var(--blk-pink);
}

.controls .dropdown-menu > a {
	height: 20px;
	padding: 9px 20px 9px 0;
	overflow: hidden;
	text-overflow: ellipsis;
	white-space: nowrap;
	color: var(--blk-pink);
}

.controls .dropdown-menu > a * {
	stroke: var(--blk-pink);
}

.controls .dropdown-menu > a svg {
	position: absolute;
	right: 0;
	top: 50%;
	margin-top: -4px;
	transition: transform .3s;
}

.controls .dropdown-menu > a:focus svg {
	transform: rotate(180deg);
}

.controls .dropdown-menu ul {
	position: absolute;
	width: 100%;
	list-style: none;
	margin: 0;
	margin-top: 1px;
	padding: 0;
	background: black;	
}

.controls .dropdown-menu ul::-webkit-scrollbar {
	width: 12px;
}

.controls .dropdown-menu ul::-webkit-scrollbar-track {
	background: black;
}

.controls .dropdown-menu ul::-webkit-scrollbar-thumb {
	background-color: #666;  
	border-radius: 6px; 
	border: 3px solid black;
}

.controls .dropdown-menu > a:focus + ul {
	padding: 10px 0;
}

.controls .dropdown-menu ul li {
	position: relative;
	margin: 0;
	padding: 0;
}

.controls .dropdown-menu ul li a {
	position: relative;
	display: block;
	padding: 5px;
	height: 20px;
	overflow: hidden;
	text-overflow: ellipsis;
	white-space: nowrap;
	color: var(--blk-pink);
}

.controls .dropdown-menu ul li a:hover {
	color: white;
}

.page-layout {
	max-width: var(--max-width);
	padding: 0 20px;
	padding-left: var(--page-pad);
	padding-right: var(--page-pad);
	margin: 0 auto;
	font-size: 24px;
	line-height: 30px;
}

.page-layout h2 {
	border-top: 1px solid black;
	padding-top: 10px;
	margin-top: 80px;
}

.page-layout p {
	max-width: 630px;
	font-size: 24px;
	line-height: 30px;
}

.page-layout li {
	/*margin-bottom: 30px;*/
}

.page-content {
	margin: 60px 0;
	font-family: var(--serif);
}

.page-content > h2:first-child {
	margin-top: 0;
}

.page-content p,
.page-content ol,
.page-content ul {
	max-width: 630px;
	font-size: 24px;
	line-height: 30px;
}

.page-content li {
	/*margin-bottom: 30px;*/
}

.page-content figure img {
	display: block;
	width: 100%;
	max-width: 630px;
	height: auto;
}

.page-content a {
	color: #000;
	text-decoration: underline;
}

.page-content a:hover {
	color: var(--blue);
}

.page-alert {
	display: flex;
	color: white;
	padding: 15px;
	gap: 20px;
	margin-bottom: 40px;
	border-radius: 3px;
	background: var(--darkblue);
}

.page-alert-alt {
	background: url('../images/common/alert-bg.jpg');
	background-size: cover;
} 

.page-alert > div {
	max-width: 290px;
	flex-grow: 1;
	font-weight: bold;
}

.page-alert .title {
	font-size: 25px;
	line-height: 27px;
	cursor: default;
}

.page-alert .text {
	max-width: 310px;
	font-size: 16px;
	line-height: 20px;
	cursor: default;
}

.page-alert .button {
	border-color: white;
	color: white;
}

.page-alert .button * {
	stroke: white;
}

.page-intro {
	display: flex;
	gap: 30px;
}

.page-intro > .text {
	flex-basis: 33%;
}

.page-intro.page-intro-half > .text {
	flex-basis: 50%;
}

.page-intro .text {
	font-size: 21px;
	line-height: 27px;
	border-top: 1px solid black;
}

.page-intro .text h2 {
	border-top: 0;
	margin-top: 0;
	margin-bottom: 20px;
}

.page-intro .text h6 {
	border-top: 0;
	margin-top: 20px;
}

.page-intro .text {
	font-family: var(--serif);
	font-size: 21px;
	line-height: 27px;	
}

.page-intro .text p {
	font-size: 21px;
	line-height: 27px;
	margin-top: 20px;
}

.page-intro .text p:last-child {
	margin-bottom: 0;
}

.page-intro figure {
	position: relative;
	flex-basis: 66%;	
}

.page-intro.page-intro-half figure {
	flex-basis: 50%;	
}

.page-intro figure img {
	display: block;
	width: 100%;
	height: auto;
	margin-bottom: 7px;
}

.page-intro figure iframe {

}

.page-form {
	max-width: 630px;
	margin: auto;
}

.page-purchase {
	position: relative;	
}

.page-purchase > button {
	position: absolute;
	width: auto;
	right: 0;
	top: 10px;
	border: 0;
	padding-right: 5px;
}


.page-more {
	margin-top: 35px;	
}

.page-more .button {
	color: var(--red);
	border-color: var(--red);
}

.page-more .button * {
	stroke: var(--red);
}

.page-more-alt .button {
	color: var(--bondi);
	border-color: var(--bondi);
}

.page-more-alt .button * {
	stroke: var(--bondi);
}

.next-page a {
	border-color: var(--green);	
	color: var(--green);
}

.next-page a  * {
	stroke: var(--green);
}

.pagination {
	position: relative;
	height: 56px;
	border: 1px solid var(--green);	
	border-left: 0;
	border-right: 0;
}

.pagination * {
	stroke: var(--green);
}

.pagination a {
	display: block;
}

.pagination a.prev {
	position: absolute;
	left: 0;
	top: 15px;
}

.pagination a.next {
	position: absolute;
	right: 0;
	top: 15px;
}

.expand {
	position: relative;	
}

.expand button {
	position: relative;
	height: auto;
	font-size: 26px;
	line-height: 30px;
	padding: 10px 30px;
}

.expand button svg {
	position: absolute;
	height: auto;
	top: 15px;
	left: 1px;
	transition: transform .3s;
}

.expand.show button svg {
	transform: rotate(90deg);
}

.expand .expand-content {
	display: none;
	box-sizing: border-box;
	padding: 0 30px 30px 30px;
	font-size: 21px;
	line-height: 27px;
}

.expand .expand-content .columns {
	flex-direction: row-reverse;
}

.expand .expand-image img {
	display: block;
	width: 100%;
	max-width: 630px;
	height: auto;
	margin: 20px 0 30px;
}

.expand .expand-content p {
	font-size: 21px;
	line-height: 27px;
}

.expand .expand-content p:first-child {
	margin-top: 15px;
}

.expand .expand-content p:last-child {
	margin-bottom: 15px;
}

.expand .expand-content a {
	color: black;
	text-decoration: underline;
}

.expand .expand-content a:hover {
	color: var(--blue);
}

.more-group li:nth-child(6n - 5) .button,
.expand-group .expand:nth-child(6n - 5) button {
	border-top: 1px solid var(--red);
	color: var(--red);
}

.more-group li:nth-child(6n - 5) .button *,
.expand-group .expand:nth-child(6n - 5) button * {
	stroke: var(--red);
}

.more-group li:nth-child(6n - 4) .button,
.expand-group .expand:nth-child(6n - 4) button {
	border-top: 1px solid var(--teal);
	color: var(--teal);
}

.more-group li:nth-child(6n - 4) .button *,
.expand-group .expand:nth-child(6n - 4) button * {
	stroke: var(--teal);
}

.more-group li:nth-child(6n - 3) .button,
.expand-group .expand:nth-child(6n - 3) button {
	border-top: 1px solid var(--purple);
	color: var(--purple);
}

.more-group li:nth-child(6n - 3) .button *,
.expand-group .expand:nth-child(6n - 3) button * {
	stroke: var(--purple);
}

.more-group li:nth-child(6n - 2) .button,
.expand-group .expand:nth-child(6n - 2) button {
	border-top: 1px solid var(--orange);
	color: var(--orange);
}

.more-group li:nth-child(6n - 2) .button *,
.expand-group .expand:nth-child(6n - 2) button * {
	stroke: var(--orange);
}

.more-group li:nth-child(6n - 1) .button,
.expand-group .expand:nth-child(6n - 1) button {
	border-top: 1px solid var(--blue);
	color: var(--blue);
}

.more-group li:nth-child(6n - 1) .button *,
.expand-group .expand:nth-child(6n - 1) button * {
	stroke: var(--blue);
}

.more-group li:nth-child(6n - 6) .button,
.expand-group .expand:nth-child(6n - 6) button {
	border-top: 1px solid var(--pink);
	color: var(--pink);
}

.more-group li:nth-child(6n - 6) .button *,
.expand-group .expand:nth-child(6n - 6) button * {
	stroke: var(--pink);
}

.caption,
figcaption {
	margin-top: 10px;
	font-family: var(--serif);
	font-size: 16px;
	line-height: 18px;
	font-style: italic;
	font-weight: normal;
}

ul.grid {
	display: grid;
	max-width: initial;
	list-style: none;
	margin: 70px 0;
	padding: 0;
	grid-template-columns: 1fr 1fr;
	gap: 30px;
	font-size: 21px;
	line-height: 27px;
}

ul.grid > li {
	min-height: 20px;
	margin: 0;
	padding: 30px 50px 30px 30px;
	background: var(--bg-pink);
}

ul.grid > li:nth-child(4n - 3) {
	background: var(--bg-orange);
}

ul.grid > li:nth-child(4n - 2) {
	background: var(--bg-blue);
}

ul.grid > li:nth-child(4n - 1) {
	background: var(--bg-purple);
}

ul.grid p {
	font-size: 21px;
	line-height: 27px;
}

ul.grid h2,
ul.grid h3,
ul.grid h4 {
	margin: 0;
	font-size: 26px;
	line-height: 30px;
}

ul.grid a {
	color: black;
	text-decoration: underline;
}

.columns {
	display: flex;
	gap: 30px;
	margin-bottom: 60px;
}

.columns > .column {
	width: 50%;	
}

.column figure img {
	display: block;
	width: 100%;
	height: auto;	
}

.divine {
	font-family: 'divine-regular';
	font-weight: normal;
}

.summary {
	margin: 10px 0;
	font-family: var(--serif);
	font-size: 16px;
	line-height: 20px;
	letter-spacing: .01em;
}

.summary p {
	font-size: 16px;
	line-height: 20px;
}

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

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

.details {
	font-size: 16px;
	line-height: 19px;
	font-weight: bold;
	font-family: var(--sans);
}

.article-layout {
	max-width: 830px;
	margin: 0 auto;
	padding: 50px 20px;
	padding-left: var(--page-pad);
	padding-right: var(--page-pad);	
	font-size: 24px;
	line-height: 30px;
}

.article-layout h2 {
	border-top: 1px solid black;
	padding-top: 10px;
	margin-top: 80px;
}

.article-layout > h2:first-child {
	margin-top: 0;
}

.article-layout figure {
	margin: 35px 0;	
}

.article-layout figure:first-child {
	margin-top: 0;	
}

.article-layout figure img {
	display: block;
	width: 100%;
	height: auto;	
}

.article-layout a[id] {
	position: relative;
	scroll-margin-top: 150px;
}

.article-feature {
	max-width: var(--max-width);
	padding-left: var(--page-pad);
	padding-right: var(--page-pad);
	margin: 0 auto 70px;
}

.article-layout p,
.article-layout ul,
.article-layout ol {
	font-size: 24px;
	line-height: 30px;
	max-width: 630px;
	margin-left: auto;
	margin-right: auto;
	font-family: var(--serif);
}

.article-layout li {
	/*margin-bottom: 30px;*/
	margin-left: 30px;
}

.article-layout ul.grid {
	max-width: 100%;
	font-size: 17px;
	line-height: 21px;
	font-family: var(--sans);
}

.article-layout ul.grid > li {
	padding: 20px 15px 30px;
	margin-bottom: 30px;
	margin-left: 0;
}

.article-layout h3,
.article-layout h4 {
	max-width: 630px;
	margin-left: auto;
	margin-right: auto;
}

.article-layout a {
	color: black;
	text-decoration: underline;
}

.article-layout a:hover {
	color: var(--blue);
}

.article-layout p a.button {
	color: var(--blue);
	border-color: var(--blue);
	text-decoration: none;
}

.article-layout p a.button * {
	stroke: var(--blue);
}

.article-layout .page-form p,
.article-layout .page-form ol,
.article-layout .page-form ul {
	width: auto;
	margin-left: 0;
	margin-right: 0;	
}

.article-layout .page-form form {
	margin-top: 60px;
}


ul.image-list {
	list-style: none;
	margin: 0;
	padding: 0;
	max-width: initial;
}

.image-list-2,
.image-list-2-alt,
.image-list-3 {
	display: flex;
	gap: 30px;
}

.image-list li {
	position: relative;
	display: flex;
	gap: 20px;
	margin: 0;
	padding: 0 0 30px;
}

.image-list-2 li,
.image-list-3 li {
	display: block;
	padding-bottom: 70px;
	flex-basis: 50%;
}

.image-list-2-alt li {
	padding-bottom: 70px;
	flex-basis: 50%;
}

.image-list-3 li {
	flex-basis: 33.3%;	
}

.image-list-2 .text,
.image-list-3 .text {
	min-height: 100px;
}

.image-list li figure {
	flex-basis: 40%;
	margin-bottom: 15px;
}

.image-list li figure img {
	display: block;
	width: 100%;
	height: auto;
}

.image-list li .text {
	flex-basis: 60%;
	flex-grow: 1;
}

.image-list li .tags {
	margin-bottom: 15px;
	font-weight: bold;
	font-size: 16px;
	line-height: 19px;
}

.image-list li .tags a {
	display: inline-block;
	margin-right: 10px;
}

.image-list li:nth-child(5n - 4) .tags a,
.image-list li:nth-child(5n - 4) .button,
.image-list li:nth-child(5n - 4) .title a:hover {
	color: var(--blue);
	border-color: var(--blue); 
}

.image-list li:nth-child(5n - 4) .button * {
	stroke: var(--blue);
}

.image-list li:nth-child(5n - 3) .tags a,
.image-list li:nth-child(5n - 3) .button,
.image-list li:nth-child(5n - 3) .title a:hover {
	color: var(--teal);
	border-color: var(--teal);
}

.image-list li:nth-child(5n - 3) .button * {
	stroke: var(--teal);
}

.image-list li:nth-child(5n - 2) .tags a,
.image-list li:nth-child(5n - 2) .button,
.image-list li:nth-child(5n - 2) .title a:hover {
	color: var(--orange);
	border-color: var(--orange); 
}

.image-list li:nth-child(5n - 2) .button * {
	stroke: var(--orange);
}

.image-list li:nth-child(5n - 1) .tags a,
.image-list li:nth-child(5n - 1) .button,
.image-list li:nth-child(5n - 1) .title a:hover {
	color: var(--bondi);
	border-color: var(--bondi);
}

.image-list li:nth-child(5n - 1) .button * {
	stroke: var(--bondi);
}

.image-list li:nth-child(5n - 5) .tags a,
.image-list li:nth-child(5n - 5) .button,
.image-list li:nth-child(5n - 5) .title a:hover {
	color: var(--pink);
	border-color: color: var(--pink);
}

.image-list li:nth-child(5n - 5) .button * {
	stroke: var(--pink);
}

.image-list li .title {
	margin-top: 0;
	margin-bottom: 15px;
}

.image-list li .title a {
	color: black;
}

.image-list li .title a:hover {
	color: var(--blue);
}


.video-audio {
	background: black;
	color: white;
}

.video-audio-layout {
	display: flex;
	max-width: var(--max-width);
	margin: auto;
	padding: 75px 20px;
	padding-left: var(--page-pad);
	padding-right: var(--page-pad);
	flex-direction: row-reverse;
	gap: 30px;
}

.video-audio-layout .button:hover {
	filter: brightness(120%);	
}

.video-audio-layout .info {
	position: relative;
	display: flex;
	flex-direction: column;
	flex-basis: calc(33.3% - 20px);
	border-top: 1px solid white;
}

.video-audio-layout .text {
	flex-grow: 1;
	padding-right: 10%;
}

.video-audio-layout h2 {
	margin: 0;
}

.video-audio-layout .details {
	margin-top: 30px;
	font-size: 16px;
	line-height: 20px;
	letter-spacing: .02em;
	font-weight: bold;
}

.video-audio-layout .summary p {
	font-size: 16px;
	line-height: 20px;
}

.video-audio-layout .media {
	position: relative;
	flex-basis: calc(66.6% - 20px);
	flex-grow: 1;
}

.video-audio-layout .media .image img {
	display: block;
	width: 100%;
	height: auto;
}

.video-audio-layout .buttons {
	flex-shrink: 1;
}

.video-audio-layout .button {
	margin-top: 15px;
	border-color: var(--blk-red);
	color: var(--blk-red);	
}

.video-audio-layout .button * {
	stroke: var(--blk-red);
}

.video-audio-layout .button:nth-child(4n - 2) {
	border-color: var(--blk-pink);
	color: var(--blk-pink);
}

.video-audio-layout .button:nth-child(4n - 2) * {
	stroke: var(--blk-pink);	
}

.video-audio-layout .button:nth-child(4n - 1) {
	border-color: var(--blk-green);
	color: var(--blk-green);
}

.video-audio-layout .button:nth-child(4n - 1) * {
	stroke: var(--blk-green);	
}

.video-audio-layout .button:nth-child(4n - 4) {
	border-color: var(--blk-peach);
	color: var(--blk-peach);
}

.video-audio-layout .button:nth-child(4n - 4) * {
	stroke: var(--blk-peach);	
}


@keyframes bounce-arrow {
  from {
	margin-left: 10px;
	margin-right: 0;
  }
  to {
	margin-left: 0;
	margin-right: 10px;
  }
}

@keyframes bounce-arrow-out {
  from {
	margin-left: 10px;
  }
  to {
	margin-left: 15px;
  }
}

.menu-trigger {
	display: block;
	position: relative;
	padding: 5px 0;
	padding-right: 17px;
	font-weight: bold;
	font-size: 16px;
	line-height: 20px;
	border-top: 1px solid black;
	cursor: pointer;
}

.menu-trigger svg {
	position: absolute;
	display: block;
	right: 0;
	top: 50%;
	margin-top: -4px;
	transition: transform .3s;
}

.menu-open .menu-trigger svg,
#content .menu-trigger:focus svg {
	transform: rotate(180deg);
}

.menu-trigger * {
	stroke: black;
}



.button-bottom {
	position: absolute;
	bottom: 0;
	width: 100%;	
}

.button svg {
	float: right;
	margin-left: 10px;
	margin-right: 0;
}

.button:hover svg {
	animation-name: bounce-arrow;
	animation-duration: .25s;
	animation-direction: alternate;
	animation-iteration-count: 2;
}

.button-inline {
	width: auto;
	display: inline-block;
	border-top: 0;
}

.button-inline svg {
	margin-top: 2px;
}

.button-inline:hover svg {
	animation-name: bounce-arrow-out;
	animation-duration: .25s;
	animation-direction: alternate;
	animation-iteration-count: 2;
}

.button-list {
	margin: 40px 0 0;
	font-family: var(--sans);
}

.button-list .button {
	position: relative;
	padding-bottom: 20px;
	text-decoration: none;
}

.button-list .button svg {
	position: absolute;
	right: 0;
	top: 12px;
}

.button-list .button .title {
	display: block;
	padding-right: 30px;
	font-size: 16px;
	line-height: 21px;
}

.button-list .button .detail {
	display: block;
	padding-right: 30px;
	padding-top: 2px;
	font-size: 13px;
	line-height: 18px;
}


.button-back {
	display: inline-block;
	position: relative;
	padding: 0;
	color: var(--blk-teal);
	font-size: 16px;
	padding-left: 27px;
	font-weight: bold;
}

.button-back svg {
	position: absolute;
	left: 0;
	top: 2px;
}

.button-back * {
	stroke: var(--blk-teal);
}

.button-more {
	padding: 16px 0;
	font-size: 22px;
	line-height: 24px;
	border-bottom: 1px solid black;
}	

.button-more svg {
	width: 24px;
	height: 18px;
	margin-top: 2px;
}

.button-more svg * {
	transform: scale(.70);	
}

.button-more-sm {
	padding: 16px 0;
	font-size: 22px;
	line-height: 24px;
}	

.heading-button-list ul {
	list-style: none;
	margin: 70px 0;
	padding: 0;	
}

.heading-button-list ul h4 {
	box-sizing: border-box;
	max-width: 800px;
	padding-right: 50px;
}

.heading-button-list ul .button svg {
	margin-top: 14px;
}

.heading-button-list li:nth-child(6n - 5) .button:hover {
	color: var(--magenta);
}

.heading-button-list li:nth-child(6n - 5) .button:hover * {
	stroke: var(--magenta);
}

.heading-button-list li:nth-child(6n - 4) .button:hover {
	color: var(--bondi);
}

.heading-button-list li:nth-child(6n - 4) .button:hover * {
	stroke: var(--bondi);
}

.heading-button-list li:nth-child(6n - 3) .button:hover {
	color: var(--orange);
}

.heading-button-list li:nth-child(6n - 3) .button:hover * {
	stroke: var(--orange);
}

.heading-button-list li:nth-child(6n - 2) .button:hover {
	color: var(--pink);
}

.heading-button-list li:nth-child(6n - 2) .button:hover * {
	stroke: var(--pink);
}

.heading-button-list li:nth-child(6n - 1) .button:hover {
	color: var(--blue);
}

.heading-button-list li:nth-child(6n - 1) .button:hover * {
	stroke: var(--blue);
}

.heading-button-list li:nth-child(6n - 6) .button:hover {
	color: var(--red);
}

.heading-button-list li:nth-child(6n - 6) .button:hover * {
	stroke: var(--red);
}






ul.more-group {
	list-style: none;
	margin: 0;
	padding: 0;
	max-width: initial;
}

.more-group li {
	margin: 0;
	padding: 0;
}

.more-group .button-more {
	border-bottom: 0;	
}

.more-group .summary {
	max-width: 630px;
	margin: 0 0 50px;
	font-size: 21px;
	line-height: 27px;
}

.more-group .summary p {
	margin-top: 0;
	font-size: inherit;
	line-height: inherit;
}

.image-buttons {
	margin: 75px 0;
}

.image-buttons ul {
	list-style: none;
	margin: 0;
	padding: 0;
	max-width: initial;
	display: grid;
	gap: 30px;
	grid-template-columns: 1fr 1fr 1fr 1fr;
}

.image-buttons-2 ul {
	grid-template-columns: 1fr 1fr;
}

.image-buttons-3 ul {
	grid-template-columns: 1fr 1fr 1fr;
}

.image-buttons li {
	posistion: relative;
	margin: 0;
	padding: 0;
}

.image-buttons li a {
	position: relative;
	font-size: 26px;
	line-height: 28px;
}

.image-buttons-imageless li a {
	padding-bottom: 10px;
	border-bottom: 1px solid black;
}

.image-buttons-imageless li a .text {
	height: 30px;
}

.image-buttons .text {
	display: block;
	height: 59px;
	padding-right: 35px;
	overflow: hidden;
}

.image-buttons-3 .text {
	padding-right: 50px;
}

.image-buttons-2 .text {
	padding-right: 70px;
}

.image-buttons .restricted-height {
	height: 30px;
}

.image-buttons svg {
	position: absolute;
	right: 0;
	margin-top: 3px;
	margin-left: 5px;
}

.image-buttons li a:hover svg {
	animation-name: bounce-arrow;
	animation-duration: .25s;
	animation-direction: alternate;
	animation-iteration-count: 2;
}

.image-buttons img {
	display: block;
	width: 100%;
	height: auto;
	margin-top: 10px;
}

.image-buttons .details {
	margin: 25px 0 20px;
	font-size: 13px;
	line-height: 20px;
	color: black;
}

.image-buttons .summary {
	margin: 20px 0;
	font-weight: normal;
	font-size: 16px;
	line-height: 21px;
	color: black;
}


.image-buttons li:nth-child(6n - 5) .button {
	color: var(--magenta);
	border-color: var(--magenta);
}

.image-buttons li:nth-child(6n - 5) .button * {
	stroke: var(--magenta);
}

.image-buttons li:nth-child(6n - 4) .button {
	color: var(--orange);
	border-color: var(--orange);
}

.image-buttons li:nth-child(6n - 4) .button * {
	stroke: var(--orange);
}

.image-buttons li:nth-child(6n - 3) .button {
	color: var(--purple);
	border-color: var(--purple);
}

.image-buttons li:nth-child(6n - 3) .button * {
	stroke: var(--purple);
}

.image-buttons li:nth-child(6n - 2) .button {
	color: var(--grass);
	border-color: var(--grass);
}

.image-buttons li:nth-child(6n - 2) .button * {
	stroke: var(--grass);
}

.image-buttons li:nth-child(6n - 1) .button {
	color: var(--blue);
	border-color: var(--blue);
}

.image-buttons li:nth-child(6n - 1) .button * {
	stroke: var(--blue);
}

.image-buttons li:nth-child(6n - 6) .button {
	color: var(--red);
	border-color: var(--red);
}

.image-buttons li:nth-child(6n - 6) .button * {
	stroke: var(--red);
}

.image-buttons-3 li:nth-child(3n - 2) .button {
	color: var(--grass);
	border-top-color: var(--grass);
}

.image-buttons-3 li:nth-child(3n - 2) .button * {
	stroke: var(--grass);
}

.image-buttons-3 li:nth-child(3n - 1) .button {
	color: var(--bondi);
	border-top-color: var(--bondi);
}

.image-buttons-3 li:nth-child(3n - 1) .button * {
	stroke: var(--bondi);
}

.image-buttons-3 li:nth-child(3n - 3) .button {
	color: var(--purple);
	border-top-color: var(--purple);
}

.image-buttons-3 li:nth-child(3n - 3) .button * {
	stroke: var(--purple);
}


.filters {
	width: 100%;
	font-size: 13px;
	line-height: 20px;
	font-weight: bold;	
}

.filters h5 {
	margin: 0 0 12px;
	font-size: 13px;
	line-height: 20px;
}

.filters ul {
	list-style: none;
	margin: 0;
	padding: 0;
	max-width: 850px;
}

.filters ul li {
	display: inline-block;
	margin: 0 15px 0 -10px;
	padding: 3px 0;
}

.filters ul li a {
	display: inline-block;
	padding: 4px 10px 3px;
}

.filters ul li:nth-child(10n - 9) a {
	color: var(--teal);
}

.filters ul li:nth-child(10n - 8) a {
	color: var(--red);
}

.filters ul li:nth-child(10n - 7) a {
	color: var(--blue);
}

.filters ul li:nth-child(10n - 6) a {
	color: var(--orange);
}

.filters ul li:nth-child(10n - 5) a {
	color: var(--green);
}

.filters ul li:nth-child(10n - 4) a {
	color: var(--purple);
}

.filters ul li:nth-child(10n - 3) a {
	color: var(--blue);
}

.filters ul li:nth-child(10n - 2) a {
	color: var(--bondi);
}

.filters ul li:nth-child(10n - 1) a {
	color: var(--magenta);
}

.filters ul li:nth-child(10n - 10) a {
	color: var(--pink);
}

.filters ul li a.selected {
	background: var(--bg-pink);
	color: black;
}


/* -- Video Player -- */

/*
.video-player {
	position: relative;
	height: 0;
	padding-bottom: 60%;
	background: #333;
}

.video-player iframe {
	position: absolute;
	width: 100%;
	height: 100%;
}
*/

/* -- Audio Player -- */

.audio-player {
	position: relative;
	background: #1E1E1E;
}

.audio-player .mejs__mediaelement {
	background: #1E1E1E;
}

.audio-player .mejs__controls {
	background: none !important;
	bottom: initial;
	padding: 25px;
}

.audio-player .mejs__playpause-button {
	width: 60px;
	height: 60px;
	background: var(--blk-red);
	border-radius: 50%;
	margin-top: -10px;
}

.audio-player .mejs__playpause-button:hover {
	filter: brightness(110%);
}

.audio-player .mejs__playpause-button button {
	width: 60px;
	height: 60px;
	margin: 0;
	padding: 0;
	background: url('../images/common/play-invert.svg') 20px center no-repeat;
	background-size: 27px auto;
}

.audio-player .mejs__playpause-button.mejs__pause button {
	background: url('../images/common/pause-invert.svg') center center no-repeat;
	background-size: 24px auto;
}

.audio-player .mejs__button>button:focus {
	outline: none;	
}

.audio-player .mejs__playpause-button button svg {
	display: none;
}

.audio-player .mejs__currenttime-container {
	padding-left: 20px;	
}

.audio-player .mejs__duration-container {
	padding-right: 30px;	
}

.audio-player .mejs__time-slider {
	margin-top: 8px;
}

.audio-player .mejs__time-buffering, 
.audio-player .mejs__time-current,
.audio-player .mejs__time-hovered, 
.audio-player .mejs__time-loaded, 
.audio-player .mejs__time-marker, 
.audio-player .mejs__time-total {
	border-radius: 0;
	height: 6px;
}

.audio-player .mejs__time-loaded {
	background: #4E4E4E;
}

.audio-player .mejs__time-total {
	background: #4E4E4E;
}

.audio-player .mejs__time-current {
	background: var(--magenta);
}

.audio-player .mejs__time-handle {
	background: transparent;
	border-color: transparent;
}

.audio-player .mejs__time-handle span {
	background: transparent;
	border-color: transparent;
}

.audio-player .mejs__horizontal-volume-total {
	background: #4E4E4E;
	border-radius: 0;
	height: 6px;
	border: 0;
	margin-top: 2px;
	padding: 0;
}

.audio-player .mejs__horizontal-volume-current {
	background: white;
	border-radius: 0;
	height: 6px;
	padding: 0;
}

.audio-player .mejs__mute {
	display: none;	
}

.audio-player .audio-description {
	padding: 0 30px 30px;
	font-weight: bold;
	font-size: 13px;
	line-height: 20px;
}

.audio-player .audio-description {
	padding: 0 30px 30px;
	font-weight: bold;
	font-size: 13px;
	line-height: 20px;
}

.audio-player .audio-title {
	max-width: 600px;
	padding-right: 30px;
}

.audio-player .audio-download {
	text-align: right;
}

.audio-player .audio-download a {
	color: var(--blk-red);
}

.audio-player .audio-download a:hover {
	filter: brightness(110%);
}

.audio-player .audio-download a img {
	display: block;
	float: right;
	margin: 3px 0 0 8px;
}

.audio-player .audio-detail {
	max-width: 600px;
}





/* -- Carousel -- */

.slider-controls {
	position: relative;
	z-index: 3;
	width: calc(100% - 120px) !important;
	max-width: var(--max-width) !important;
	margin: 0 auto;
	text-align: right;
}

.slider-page {
	display: flex;
	position: absolute;
	right: 120px;
	left: initial;
	height: 12px;
	width: auto;
	margin: 0;
	padding-top: 8px;
}

.slider-page div {
	width: 12px;
	height: 12px;
	border: 0;
	border-radius: 50%;
	margin: 0 5px;
	background: #C4C4C4;
	cursor: pointer;
}

.slider-page div.selected {
	background: black;
}

.slider-page div span {
	display: none;
}

.slider-next {
	position: absolute;
	top: 5px !important;
	right: 0;
	width: 24px;
	height: 18px;
	margin: 0;
	border: 0;
	background: url('../images/common/carousel-arrow-right.svg') no-repeat;
	cursor: pointer;
}

.slider-prev {
	position: absolute;
	top: 5px !important;
	right: 75px;
	left: initial;
	margin: 0;
	border: 0;
	width: 24px;
	height: 18px;
	background: url('../images/common/carousel-arrow-left.svg') no-repeat;
	cursor: pointer;
}

.play-toggle {
	position: absolute;
	top: 5px !important;
	right: 41px;
	width: 18px;
	height: 18px;
	background: url('../images/common/pause.svg') center center no-repeat;
	cursor: pointer;
}

.play-toggle.paused {
	background: url('../images/common/play.svg') center center no-repeat;
}


.feature-box {
	display: grid;
	grid-template: 'header image image' 'text image image';
	grid-template-rows: auto 1fr;
	grid-template-columns: 1fr 1fr 1fr;
	gap: 30px;
	width: 100%;
	padding: 30px;
	margin-left: -30px;
	background-color: var(--bg-purple);	
}

.feature-box-reverse {
	grid-template: 'image image header' 'image image text';
	grid-template-rows: auto 1fr;
	grid-template-columns: 1fr 1fr 1fr;
}


.feature-box .header {
	grid-area: header;
	margin: 0 0 -10px;
	font-size: 34px;
	line-height: 40px;
	font-weight: bold;
	border-top: 1px solid black;
}

.feature-box figure {
	grid-area: image;
}

.feature-box figure img {
	display: block;
	width: 100%;
	height: auto;
}

.feature-box .text {
	position: relative;
	grid-area: text;
	padding-bottom: 50px;
}

.feature-box h3 {
	margin: 0;
	margin-bottom: 20px;
}

.feature-box .details {
	margin-bottom: 20px;
}

.feature-box .summary {
	font-size: 21px;
	line-height: 27px;
}

.feature-box .summary p {
	font-size: 21px;
	line-height: 27px;
	margin-top: 0;
}

.feature-box .button {
	margin-bottom: 5px;
}

.feature-box-white {
	background-color: white;
}

.feature-box-white .button {
	border-top-color: var(--purple);
	color: var(--purple);
}

.feature-box-white .button * {
	stroke: var(--purple);
}

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

.feature-box-blue .button {
	border-top-color: var(--blue);
	color: var(--blue);
}

.feature-box-blue .button * {
	stroke: var(--blue);
}

.feature-box-purple {
	background-color: var(--bg-purple);
}

.feature-box-purple .button {
	border-top-color: var(--purple);
	color: var(--purple);
}

.feature-box-purple .button * {
	stroke: var(--purple);
}

.feature-box-orange {
	background-color: var(--bg-orange);
}

.feature-box-orange .button {
	border-top-color: var(--orange);
	color: var(--orange);
}

.feature-box-orange .button * {
	stroke: var(--orange);
}

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

.feature-box-green .button {
	border-top-color: var(--green);
	color: var(--green);
}

.feature-box-green .button * {
	stroke: var(--green);
}

.feature-box-pink {
	background-color: var(--bg-pink);
}

.feature-box-pink .button {
	border-top-color: var(--pink);
	color: var(--pink);
}

.feature-box-pink .button * {
	stroke: var(--pink);
}

.feature-box-carousel {
	margin-bottom: 20px;
}

.feature-box-carousel ul {
	list-style: none;
	margin: 0;
	padding: 0;
}

.feature-box-carousel li {
	margin: 0;
	padding-left: var(--page-pad);
	padding-right: var(--page-pad);
}

.shaded-box {
	position: relative;
	margin: 40px 0 60px;
	border-bottom: 1px solid black;
}

.shaded-box .text {
	padding: 12px 25% 40px 15px;	
}

.shaded-box a {
	color: black;
}

.shaded-box h3 {
	margin: 0;
}

.shaded-box .button {
	position: absolute;
	bottom: -25px;
	left: 0;
}

.shaded-box-yellow {
	background: var(--bg-yellow);
	border-color: var(--orange);
}

.shaded-box-yellow a.button {
	color: var(--orange);
}

.shaded-box-yellow a.button * {
	stroke: var(--orange);
}

.shaded-box-red {
	background: var(--bg-pink);	
	border-color: var(--red);
}

.shaded-box-red a.button {
	color: var(--red);
}

.shaded-box-red a.button * {
	stroke: var(--red);
}

.shaded-box-green {
	background: var(--bg-green);	
	border-color: var(--green);
}

.shaded-box-green a.button {
	color: var(--green);
}

.shaded-box-green a.button * {
	stroke: var(--green);
}

.shaded-box-purple {
	background: var(--bg-purple);	
	border-color: var(--purple);
}

.shaded-box-purple a.button {
	color: var(--purple);
}

.shaded-box-purple a.button * {
	stroke: var(--purple);
}

.ui-scrollpane {
	height: 550px;
}

.ui-scrollpane ul {
	gap: 30px;
}

.ui-scrollpane li {
	padding: 0 0 40px;
	flex-basis: 293px;
}

.ui-scrollpane li a {
	color: black;
}

.ui-scrollpane li img {
	display: block;
}

.ui-scrollpane li h4 {
	min-height: 50px;
	margin: 15px 0;
}

.ui-scrollpane li .date {
	display: block;
	font-size: 13px;
	line-height: 20px;
	font-weight: bold;
}

.ui-scrollpane li .summary {
	font-size: 16px;
	line-height: 20px;
	margin: 15px 0;
}

.ui-scrollpane li:nth-child(5n - 4) .button {
	color: var(--blue);
	border-top: 1px solid var(--blue);
}

.ui-scrollpane li:nth-child(5n - 4) .button * {
	stroke: var(--blue);
}

.ui-scrollpane li:nth-child(5n - 3) .button {
	color: var(--teal);
	border-top: 1px solid var(--teal);
}

.ui-scrollpane li:nth-child(5n - 3) .button * {
	stroke: var(--teal);
}

.ui-scrollpane li:nth-child(5n - 2) .button {
	color: var(--pink);
	border-top: 1px solid var(--pink);
}

.ui-scrollpane li:nth-child(5n - 2) .button * {
	stroke: var(--pink);
}

.ui-scrollpane li:nth-child(5n - 1) .button {
	color: var(--magenta);
	border-top: 1px solid var(--magenta);
}

.ui-scrollpane li:nth-child(5n - 1) .button * {
	stroke: var(--magenta);
}

.ui-scrollpane li:nth-child(5n - 5) .button {
	color: var(--green);
	border-top: 1px solid var(--green);
}

.ui-scrollpane li:nth-child(5n - 5) .button * {
	stroke: var(--green);
}



.timeline {
	list-style: none;
	margin: 60px 0;
	padding: 0;	
}

.timeline li {
	display: flex;
	gap: 30px;
	flex-direction: row-reverse;
	margin: 0;
	padding: 10px 0 30px;
	border-top: 1px solid black;
}

.timeline li .text {
	flex-basis: 50%;
}

.timeline li .image {
	flex-basis: 50%;
}

.timeline li figure {
	display: table;
}

.timeline li figure img {
	display: block;
	margin-bottom: 7px;
}

.timeline li figure figcaption {
	display: table-caption;
	caption-side: bottom;
}

.timeline h2 {
	padding-top: 0;
	margin: 0;
	border: none;
}

.timeline p {
	margin-top: 20px;
}





.email-capture {
	display: flex;
	gap: 10px;
	flex-flow: row wrap;
}

.email-capture div {
	position: relative;
	flex-basis: 100%;
	flex-grow: 1;
}

.email-capture div.half {
	flex-basis: 40%;
	flex-shrink: 1;
}

.email-capture div:nth-child(5n - 4) input {
	border-top: 1px solid var(--blue);
	color: var(--blue);
}

.email-capture div:nth-child(5n - 4) input::placeholder {
	color: var(--blue);
}

.email-capture div:nth-child(5n - 3) input {
	border-top: 1px solid var(--green);
	color: var(--green);
}

.email-capture div:nth-child(5n - 3) input::placeholder {
	color: var(--green);
}

.email-capture div:nth-child(5n - 2) input {
	border-top: 1px solid var(--red);
	color: var(--red);
}

.email-capture div:nth-child(5n - 2) input::placeholder {
	color: var(--red);
}

.email-capture div:nth-child(5n - 1) input {
	border-top: 1px solid var(--pink);
	color: var(--pink);
}

.email-capture div:nth-child(5n - 1) input::placeholder {
	color: var(--pink);
}

.email-capture div:nth-child(5n - 5) input {
	border-top: 1px solid var(--teal);
	color: var(--teal);
}

.email-capture div:nth-child(5n - 5) input::placeholder {
	color: var(--teal);
}


/* -- Share Page -- */

.share-page {
	display: flex;
	border-top: 1px solid black;
	margin: 75px 0 0;	
	min-height: 125px;
}

.share-page h2 {
	border: none;
	margin: 0;
	padding-top: 6px;
	font-size: 34px;
	line-height: 40px;
	cursor: default;
}

.share-page ul {
	margin: 10px 0 0 16px;
	padding: 0;
	list-style: none;
	display: flex;
	gap: 4px;
}

.share-page ul li {
	margin: 0;
	padding: 0;
}

.share-page ul li a {
	display: block;
	width: 30px;
	height: 30px;
}

.share-page ul li a:hover {
	opacity: .5;
}

.share-page ul li a span {
	display: none;
}

.share-page ul li a.share-facebook {
	background: url('../images/common/share-facebook.png') center center no-repeat;
	background-size: 100% 100%;
}

.share-page ul li a.share-instagram {
	background: url('../images/common/share-instagram.png') center center no-repeat;
	background-size: 100% 100%;
}

.share-page ul li a.share-twitter {
	background: url('../images/common/share-twitter.png') center center no-repeat;
	background-size: 100% 100%;
}

.share-page ul li a.share-email {
	background: url('../images/common/share-email.png') center center no-repeat;
	background-size: 100% 100%;
}

.title-hover-colors li:nth-child(6n - 5) .title a:hover {
	color: var(--magenta);
}

.title-hover-colors li:nth-child(6n - 4) .title a:hover {
	color: var(--bondi);
}

.title-hover-colors li:nth-child(6n - 3) .title a:hover {
	color: var(--orange);
}

.title-hover-colors li:nth-child(6n - 2) .title a:hover {
	color: var(--pink);
}

.title-hover-colors li:nth-child(6n - 1) .title a:hover {
	color: var(--blue);
}

.title-hover-colors li:nth-child(6n - 6) .title a:hover {
	color: var(--red);
}

.title-hover-colors-blk li:nth-child(6n - 5) .title a:hover {
	color: var(--blk-peach);
}

.title-hover-colors-blk li:nth-child(6n - 4) .title a:hover {
	color: var(--blk-teal);
}

.title-hover-colors-blk li:nth-child(6n - 3) .title a:hover {
	color: var(--blk-orange);
}

.title-hover-colors-blk li:nth-child(6n - 2) .title a:hover {
	color: var(--blk-yellow);
}

.title-hover-colors-blk li:nth-child(6n - 1) .title a:hover {
	color: var(--blk-blue);
}

.title-hover-colors-blk li:nth-child(6n - 6) .title a:hover {
	color: var(---blk-green);
}


/* -- Map Embed -- */

.sjmap {
	position: relative;
	background: #F2F2F2;
	width: 100%;
	margin: 0 0 50px;
	overflow: hidden;
	-webkit-user-select: none;
}

.sjmap-error {
	padding: 150px 0;
	text-align: center;
	font-size: 16px;
	color: gray;	
}

.sjmap-lock {
	overflow: hidden;
}

.sjmap .marker {
	width: 22px;
	height: 22px;
	text-align: center;
	line-height: 22px;
	margin-left: -11px;
	margin-top: -11px;
	position: absolute;
	z-index: 3;
	background: #ff9A00;
	color: white;
	font-weight: bold;
	font-size: 12px;
	border-radius: 50%;
	cursor: pointer;
	transition: background .1s;
	-webkit-user-select: none;
}

.sjmap .marker:nth-child(12n - 11) {
	background-color: var(--red);
}

.sjmap .marker:nth-child(12n - 10) {
	background-color: var(--teal);
}

.sjmap .marker:nth-child(12n - 9) {
	background-color: var(--orange);
}

.sjmap .marker:nth-child(12n - 8) {
	background-color: var(--blue);
}

.sjmap .marker:nth-child(12n - 7) {
	background-color: var(--grass);
}

.sjmap .marker:nth-child(12n - 6) {
	background-color: var(--magenta);
}

.sjmap .marker:nth-child(12n - 5) {
	background-color: var(--darkblue);
}

.sjmap .marker:nth-child(12n - 4) {
	background-color: var(--bondi);
}

.sjmap .marker:nth-child(12n - 3) {
	background-color: var(--pink);
}

.sjmap .marker:nth-child(12n - 2) {
	background-color: var(--royalblue);
}

.sjmap .marker:nth-child(12n - 1) {
	background-color: var(--green);
}

.sjmap .marker:nth-child(12n - 12) {
	background-color: var(--purple);
}

.sjmap .marker p {
	display: inline;
	width: auto;
	margin: 0;
	padding: 0;
}

.sjmap .marker:hover {
	filter: brightness(110%);
}

.sjmap .active,
.sjmap .active:hover {
	background-color: #000;
}

.sjmap-zoom {
	position: absolute;
	z-index: 5;
	top: 20px;
	right: 20px;
}

.sjmap-zoom div {
	width: 30px;
	height: 30px;
	background: var(--blk-orange);
	margin-bottom: 5px;
	cursor: pointer;
	color: #FFF;
	text-align: center;
	font-weight: bold;
	font-size: 26px;
	line-height: 26px;
	transition: background .2s;
	-webkit-user-select: none;
}

.sjmap-zoom div:hover {
	background-color: #ffae00;
}

.sjmap-content {
	position: absolute;
	z-index: 2;
	background-size: 100% 100%;
	-webkit-user-select: none;
}

#sjmap-overlay {
	position: absolute;
	z-index: 99;
	left: -9999px;
	top: -9999px;
	width: 200px;
	margin-top: 10px;
	margin-left: 10px;
	font-size: 12px;
	background: #FFF;
	border: 1px solid #C5C7C9;
	-webkit-user-select: none;
}

#sjmap-overlay img {
	width: 100%;
	height: auto;
}

#sjmap-overlay .sjmap-title {
	padding: 16px;
	padding-bottom: 8px;
	font-weight: bold;
}

#sjmap-overlay .sjmap-description {
	padding: 16px;
	padding-top: 0;
}



/* -- Footer -- */

footer {
	background: black;
	color: white;
	font-weight: bold;
	font-family: var(--sans);
	font-size: 16px;
	line-height: 20px;
}

footer a {
	color: white;	
}

footer .logo {
	margin-bottom: 40px;
}

footer .address {
	padding-right: 20px;
}

footer .address a {
	display: inline-block;
	color: var(--gray);
}

footer .address a:hover {
	color: white;
}

#footer-main {
	max-width: var(--max-width);
	display: flex;
	margin: auto;
	padding: 88px 20px 170px;
	padding-left: var(--page-pad);
	padding-right: var(--page-pad);
}

#footer-main > div {
	flex-basis: 33.3%;
}

#footer-links {
	text-transform: uppercase;
}

#footer-links ul {
	list-style: none;
	margin: 0;
	padding: 0 0 0 30%;
}

#footer-links ul li {
	margin: 0;
	padding: 2px 0 3px;
}


#footer-links li:nth-child(6n - 5) a:hover {
	color: var(--blk-yellow);
}

#footer-links li:nth-child(6n - 4) a:hover {
	color: var(--blk-teal);
}

#footer-links li:nth-child(6n - 3) a:hover {
	color: var(--blk-orange);
}

#footer-links li:nth-child(6n - 2) a:hover {
	color: var(--blk-red);
}

#footer-links li:nth-child(6n - 1) a:hover {
	color: var(--blk-green);
}

#footer-links li:nth-child(6n - 6) a:hover {
	color: var(--blk-purple);
}


#footer-bottom {
	padding: 20px;
	padding-left: var(--page-pad);
	padding-right: var(--page-pad);
	background: var(--bg-green);
	color: black;
}

#footer-bottom a {
	color: black;	
}

#footer-bottom-cols {
	display: flex;
	width: 100%;
	max-width: var(--max-width);
	margin: auto;
}

#footer-bottom-cols > div {
	flex-grow: 1;
}

#footer-bottom .site-by {
	text-align: right;
}

