@font-face{
  font-family:'Savannah (TT)';
  src:url('https://d1tntvpcrzvon2.cloudfront.net/static-assets/fonts/savannah-regular.woff2') format('woff2'),
      url('https://d1tntvpcrzvon2.cloudfront.net/static-assets/fonts/savannah-regular.woff') format('woff'),
      url('https://d1tntvpcrzvon2.cloudfront.net/static-assets/fonts/savannah-regular.otf') format('opentype'),
      url('https://d1tntvpcrzvon2.cloudfront.net/static-assets/fonts/savannah-regular.ttf') format('truetype');
  font-weight:400;
  font-style:normal;
}
@font-face{
  font-family:'Savannah Alt';
  src:url('https://d1tntvpcrzvon2.cloudfront.net/static-assets/fonts/Savannah-Alt-Regular.woff2') format('woff2'),
      url('https://d1tntvpcrzvon2.cloudfront.net/static-assets/fonts/Savannah-Alt-Regular.woff') format('woff'),
      url('https://d1tntvpcrzvon2.cloudfront.net/static-assets/fonts/Savannah-Alt-Regular.otf') format('opentype'),
      url('https://d1tntvpcrzvon2.cloudfront.net/static-assets/fonts/Savannah-Alt-Regular.ttf') format('truetype');
  font-weight:normal;
  font-style:normal;
}
@font-face{
  font-family:'circular';
  src:url('https://d1tntvpcrzvon2.cloudfront.net/static-assets/fonts/CircularXXWeb-Regular.woff2') format('woff2'),
      url('https://d1tntvpcrzvon2.cloudfront.net/static-assets/fonts/CircularXXWeb-Regular.woff') format('woff');
  font-weight:400;
  font-style:normal;
  font-stretch:normal;
  font-display:swap;
}
@font-face{
  font-family:'circular';
  src:url('https://d1tntvpcrzvon2.cloudfront.net/static-assets/fonts/CircularXXWeb-Medium.woff2') format('woff2'),
      url('https://d1tntvpcrzvon2.cloudfront.net/static-assets/fonts/CircularXXWeb-Medium.woff') format('woff');
  font-weight:600;
  font-style:normal;
  font-stretch:normal;
  font-display:swap;
}
@font-face{
  font-family:'circular';
  src:url('https://d1tntvpcrzvon2.cloudfront.net/static-assets/fonts/CircularXXWeb-MediumItalic.woff2') format('woff2'),
      url('https://d1tntvpcrzvon2.cloudfront.net/static-assets/fonts/CircularXXWeb-MediumItalic.woff') format('woff');
  font-weight:400;
  font-style:italic;
  font-stretch:normal;
  font-display:swap;
}


:root, .btn-primary {
  --bs-link-hover-color: black;
  --bs-btn-hover-bg: black;
  --bs-btn-hover-border-color: black;
  --bs-btn-bg: black;
}
.card {
  --bs-card-border-color: black;
}


html, body { margin: 0; padding: 0; height: 100%; }
h1, h2, h3, h4, h5, h6 { margin: 0; font-weight: 100; }
p { margin-bottom: 1rem; }
p:last-child { margin-bottom: 0rem; }

@keyframes fadein {
  from { opacity: 0; }
  to   { opacity: 1; }
}

html {
  font: 130%/1.3 circular, "Helvetica Neue", Helvetica, sans-serif;
  letter-spacing: 1px;
  font-weight: 200;
  background: #111111;
	background-size: cover;
}
body{
  background-color: transparent !important;
}
body::before {
	content: "";
	position: fixed;
	background: #111111;
	background-size: cover !important;
	width: 100vw;
	height: 100vh;
	top: 0;
	left: 0;
	opacity: 0;
	transition: opacity 2s;
}
body.home.bg-loaded::before {
  opacity: 1;
	background: url("/images/background.jpg") fixed no-repeat center center #111111;
}
body.home::before {
  background: url("/images/video-background-low.jpg") fixed no-repeat center center #111111;
  opacity: 1;
}
body.home.video-error::before {
  background: url("/images/background-low.jpg") fixed no-repeat center center #111111;
}
body.home.video-error.bg-loaded::before {
  opacity: 1;
	background: url("/images/background.jpg") fixed no-repeat center center #111111;
}

body.rsvp::before {
	background: url("/images/background-low.jpg") fixed no-repeat center center #111111;
}
body.rsvp.bg-loaded::before {
  opacity: 1;
	background: url("/images/background.jpg") fixed no-repeat center center #111111;	
}

html.page-dress-code {
  background: url("/images/dragon.jpg") fixed no-repeat center center #111111;
  background-size: cover;
}

html.page-thank-you,
html.page-thanks {
  background: url("/images/thank-you-l.jpg") fixed no-repeat center top #111111;
  background-size: cover;
}
/*html.page-thank-you nav,
html.page-thanks nav {
  visibility: hidden;
  pointer-events: none;
}*/
html.page-thank-you body,
html.page-thanks body {
  margin: 0 !important;
}

@keyframes slide {
  0% {
    background-position: 0vw 0vh;
  }
  100% {
    background-position: 1000vw 1000vh;
  }
}
html.page-our-story {
	background: url("/images/collage-1-low.jpg") scroll repeat center center #111111 !important;
	animation: slide 300s linear infinite;
	background-size: cover;
}
html.page-our-story.bg-loaded {
  animation: none;
}
body.our-story.bg-loaded::before {
  opacity: 1;
	background: url("/images/collage-1.jpg") scroll repeat center center #111111;
	animation: slide 300s linear infinite;
}
@media {
  body.our-story.bg-loaded::before {
    transform: rotate(-7deg) scale(1.15);
    overflow-x: hidden;
  }
}

body.schedule::before {
	background: url("/images/stairs-low.jpg") fixed no-repeat center center #111111;
}
body.schedule.bg-loaded::before {
  opacity: 1;
	background: url("/images/stairs.jpg") fixed no-repeat center center #111111;
}

body.wedding-party::before {
	background: url("/images/kiss-front-low.jpg") fixed no-repeat center center #111111;
}
body.wedding-party.bg-loaded::before {
  opacity: 1;
	background: url("/images/kiss-front.jpg") fixed no-repeat center center #111111;
}

body.travel::before {
	background: url("/images/bike-love-lg-low.jpg") fixed no-repeat center center #111111;
}
body.travel.bg-loaded::before {
  opacity: 1;
	background: url("/images/bike-love-lg.jpg") fixed no-repeat center center #111111;
}

html.page-registry {
  background: url("/images/abbey-ground.jpg") fixed no-repeat center center #111111;
  background-size: cover;
}

html.page-see-and-do {
  background: url("/images/sky-abbey.jpg") fixed no-repeat center center #111111;
  background-size: cover;
}

.nowrap {
  white-space: nowrap;
}
.small-fancy {
	font-family: Georgia !important;
	transform: scale(0.75) rotate(0deg) !important;
	display: inline-block;
	letter-spacing: -1px;
}

.script-font {
  font-family: la-bohemienne, sans-serif !important;
  font-weight: 400 !important;
  font-style: normal !important;
}

.raleway-bold {
  font-family: raleway, sans-serif;
  font-weight: 700;
  font-style: normal;
}
.raleway-regular {
  font-family: raleway, sans-serif;
  font-weight: 400;
  font-style: normal;
}
.raleway-italic {
  font-family: raleway, sans-serif;
  font-weight: 400;
  font-style: italic;
}
.raleway-bold-italic {
  font-family: raleway, sans-serif;
  font-weight: 700;
  font-style: italic;
}


@media (min-width: 768px) {
  body::before {
  	position: fixed;
  }
  body::before {
    display: block;
  }
  html {
    background: linear-gradient(#aca9a9, #eee8e8) fixed no-repeat 0 0 #eee8e8;
  }
}
body.scroll-to-view::after {
	content: "scroll down ↓";
	content: "Scroll up ↑";
	position: fixed;
	bottom: 14%;
	left: 50%;
	transform: translate(-50%);
	white-space: pre-wrap;
	color: white;
	text-align: center;
	pointer-events: none;
	padding: 1rem;
	transition: opacity 1s;
}
body.scroll-to-view::after {
	content: "Scroll down ↓";
	content: "Scroll up ↑";
	position: fixed;
	bottom: 15px;
	left: 50%;
	transform: translate(-50%);
	white-space: pre-wrap;
	white-space: nowrap;
	color: white;
	text-align: center;
	pointer-events: none;
	padding: 1rem;
	transition: opacity 1s;
	background-color: #0000008a;
	border-radius: 100px;
	overflow: visible;
	height: 3rem;
	line-height: 0.8rem;
	animation-name: bounce-7;
  animation-timing-function: cubic-bezier(0.280, 0.840, 0.420, 1);
  animation-duration: 1.5s;
  animation-iteration-count: 2;
  animation-delay: 4s;
  transform-origin:  bottom center; 
}
@keyframes bounce-7 {
  0%   { transform: scale(1,1)      translateY(0) translate(-50%); }
  10%  { transform: scale(1.1,.9)   translateY(0) translate(-50%); }
  30%  { transform: scale(.9,1.1)   translateY(-30px) translate(-50%); }
  50%  { transform: scale(1.05,.95) translateY(0) translate(-50%); }
  57%  { transform: scale(1,1)      translateY(-7px) translate(-50%); }
  64%  { transform: scale(1,1)      translateY(0) translate(-50%); }
  100% { transform: scale(1,1)      translateY(0) translate(-50%); }
}
body.scroll-to-view.scrolled-5::after {
  opacity: 0;
  animation-name: none;
}

body.home.scroll-to-view::after {
	content: "Scroll down to RSVP ↓";
	content: "Scroll up to RSVP ↑";
}

a, a:active, a:visited {
  color: black;
  text-decoration: none;
  border-bottom: 1px dotted black;
}

a.has-img {
  border: none !important;
}
a[onclick] {
  cursor: pointer;
}


.mw-320, .mw-480, .mw-768 {
  max-width: 320px;
  margin-left: auto;
  margin-right: auto;
}
.mw-480 {
  max-width: 480px;
}
.mw-768 {
  max-width: 768px;
}


.underscored {
	border-bottom: 2px solid #DDDDDD;
	padding-bottom: 2rem;
}

#bg-video {
	display: block;
	position: fixed;
	top: 0;
	background: transparent;
	width: 100%;
	height: 100%;
	height: 100vh;
	object-fit: cover;
	pointer-events: none;
}
body.scrolled #bg-video {
  mix-blend-mode: luminosity;
}
body.video-error #bg-video {
  display: none;
}
.video-hidden {
  opacity: 0;
  transition: opacity 1s;
}
.video-playing.video-hidden {
  opacity: 1;
}
body.scroll-to-view main {
  margin-top: 100%;
	margin-top: 100vh;
	margin-top: calc(100vh + 2rem);
/* 	padding-bottom: 50%; */
}
html.page-see-and-do main {
  position: relative;
}
body.scroll-to-view.not-home main {
	margin-top: calc(100vh + 2rem - 200px);
}
main > section {
	margin: 1rem auto;
	margin: 0.75rem auto;
	width: 80%;
	width: calc(100% - 1.5rem);
	background-color: white;
	padding: 2rem;
	position: relative;
	max-width: 1200px;
}
main.section-max-480 > section {
	max-width: 480px;
}

body.home main > section,
body main > section.tlct {
  padding-top: 0;
  overflow: visible;
  margin-top: 3rem;
}
body.home main > section::before,
body main > section.tlct::before {
  content: "";
  position: absolute;
  top: -2rem;
  height: 2rem;
  left: 0;
  width: 100%;
  background: url("/images/pad-top.png") scroll no-repeat 0 0 #FFFFFF66;
}

.clearfix::after {
	content: " ";
	display: block;
	clear: both;
}
nav {
	font-family: "Helvetica Neue", Helvetica, sans-serif;
	position: relative;
	top: 15px;
	top: 0;
	color: white;
	padding: 1rem 0;
	width: 100%;
	background-color: #24232342;
	transition: background-color 1s;
}
body.not-home.scroll-to-view nav {
  z-index: 1;
}
body.scroll-to-view nav {
	background: linear-gradient(#232222, #200c07);
	background: linear-gradient(#24232342, #24232300) transparent;
	position: fixed;
}
body.scroll-to-view.scrolled-to-nav nav {
  background-color: #232222;
}
body.scroll-to-view nav img {
  transition: height 0.5s, width 0.5s, margin-top 0.5s, margin-bottom 0.5s;
  display: inline-block;
}
body.scroll-to-view.scrolled-to-nav nav img {
  height: 80px;
  margin-top: -15px;
  margin-bottom: -15px;
}
@media(min-width:768px) {
  xbody.front nav {
  	background: linear-gradient(#232222, #200c07);
  	background: linear-gradient(#24232342, #24232300) transparent;
  }
}
.float-right {
	float: right;
}
.float-left {
	float: left;
}
nav a, nav a:visited, nav a:active {
	color: white;
	text-decoration: none;
	font-size: 0.75rem;
	padding: 0 0.25rem 0.25rem 0.25rem;
	transition: color 0.5s;
	border-bottom: none;
	font-weight: 300;
}
nav a {
  text-shadow: 2px 0 3px rgba(0,0,0,0.25);
}
nav a[href].active {
	color: white;
	border-bottom: 2px solid white;
}



/*
@media (min-width: 768px) {
  #links a,
  #links a:visited,
  #links a:active {
  	color: white;
  	text-decoration: none;
  	font-size: 0.75rem;
  	padding: 0 0.25rem 0.25rem 0.25rem;
  	transition: color 0.5s;
  	border-bottom: none;
  	font-weight: bold;
  	font-family: Didot;
  	font-style: italic;
  	text-transform: uppercase;
  	letter-spacing: -1px;
  	transform: rotate(-21deg);
  	position: relative;
  	display: inline-block;
  	margin: 0 -7px;
  	font-size: 1rem;
  }
}
*/




section.titled {
	text-align: center;
	font-size: 1rem;
	background-color: transparent;
	color: white;
	text-shadow: 0 0 5px #0000001f;
	letter-spacing: 0px;
}
section.titled h1 {
	line-height: 3rem;
	font-weight: bold;
	text-transform: uppercase;
}
section.titled h1 {
	line-height: 3rem;
	font-weight: bold;
	text-transform: uppercase;
	display: inline-block;
	background-color: black;
	padding: 0 1rem;
	background-color: #0000002b;
	text-shadow: 0 0 3px #000000a1;
	border: 2px solid white;
}

body.scroll-to-view section.titled h1 {
  position: relative;
	top: -38px;
}

section.titled h1 {
	color: black;
	background-color: white;
	text-shadow: none;
	border: none;
}

.break-word {
  word-break: break-word;
}

#links {
	line-height: 1.5rem;
}
#links, body.menu::after {
  display: none;
}
body.menu #links {
  display: block;
  float: none;
}
body.menu #links a {
	display: block;
	padding: 0.25rem 0;
	text-align: center;
	font-size: 1rem;
}
body.menu #hamburger::before, body.menu #hamburger::after {
  display: none;
}
body.menu #hamburger span {
	height: auto;
	font-size: 2rem;
	line-height: 1rem;
	background-color: transparent;
	text-align: center;
}
#hamburger {
	display: inline-block;
	margin: auto;
	padding: 0;
	font-size: 0;
	line-height: 0;
	width: 2.5rem;
	left: 50%;
	position: relative;
	transform: translateX(-50%);
	top: 5px;
}
#hamburger::before, #hamburger::after, #hamburger span {
	background-color: white;
	height: 1px;
	width: 100%;
	content: "";
	display: inline-block;
	font-size: 0;
	line-height: 0;
	margin: 2px 0;
}
@media(min-width: 768px) {
  #hamburger {
    display: none;
  }
  #links {
    display: block;
  }
}


.frd-fmly, .fam-only {
	font-size: 1rem;
	line-height: 2rem;
	background-color: #ecc5c5;
	color: white;
	padding: 0.25rem 0.5rem;
}
.frd-fmly {
  
}

.block-center {
  display: block;
  text-align: center;
  margin-left: auto;
  margin-right: auto;
  position: relative;
  max-width: 100%;
}
.mobile {
  display: inline-block !important;
}
.block-center.mobile {
  display: block !important;
}
.desktop {
  display: none !important;
}
@media(min-width: 768px) {
  .mobile {
    display: none !important;
  }
  .desktop {
    display: inline-block !important;
  }
  .block-center.desktop {
    display: block !important;
  }
}

#title,
section .section-title,
body.home h5 {
	font-family: Savannah Alt;
}
.section-title {
	font-size: 2rem;
/* 	text-align: center; */
}
#title {
  font-size: 1.25rem;
}
@media(min-width: 768px) {
  #title {
    font-size: 1.75rem;
  }
}
#title .mobile {
	font-size: 2rem;
}


.savanah {
  font-family: Savannah Alt !important;
}
.b-0 {
  border: none !important;
  text-decoration: none !important;
}


.gallery {
	width: calc(100% + 4rem);
	margin: -2rem 0 1rem -2rem;
	position: relative;
}
.gallery-scroller {
	white-space: nowrap;
	overflow-x: auto;
	overflow-y: hidden;
	scroll-snap-type: x mandatory;
}
@media(min-width: 768px) {
  .gallery {
  	float: right;
  	width: 50%;
  	margin: 0 0 0 1rem;
  	cursor: pointer;
  	overflow: hidden;
  }
  .gallery-scroller {
    overflow: hidden;
  }
}
.gallery-scroller img {
	width: 100%;
	height: auto;
	display: inline-block;
	background-position: center center;
	background-repeat: no-repeat;
	background-size: cover;
	scroll-snap-align: start;
}
@media(min-width: 768px) {
  .gallery-scroller {
  	scroll-snap-type: none;
  }
  .gallery-scroller img {
  	scroll-snap-align: none;
  }
}


.color-white {
  color: white !important;
}



.dots {
	position: absolute;
	bottom: 10px;
	left: 0;
	width: 100%;
	pointer-events: none;
	text-align: center;
}
.dots span {
	background-color: white;
	width: 10px;
	height: 10px;
	display: inline-block;
	border-radius: 50%;
	margin: 4px;
	opacity: 0.4;
}
.gallery[data-page="0"] .dots span:nth-child(1),
.gallery[data-page="1"] .dots span:nth-child(2),
.gallery[data-page="2"] .dots span:nth-child(3),
.gallery[data-page="3"] .dots span:nth-child(4),
.gallery[data-page="4"] .dots span:nth-child(5),
.gallery[data-page="5"] .dots span:nth-child(6),
.gallery[data-page="6"] .dots span:nth-child(7),
.gallery[data-page="7"] .dots span:nth-child(8),
.gallery[data-page="8"] .dots span:nth-child(9),
.gallery[data-page="9"] .dots span:nth-child(10),
.gallery[data-page="10"] .dots span:nth-child(11),
.gallery[data-page="11"] .dots span:nth-child(12),
.gallery[data-page="12"] .dots span:nth-child(13),
.gallery[data-page="13"] .dots span:nth-child(14),
.gallery[data-page="14"] .dots span:nth-child(15) {
	opacity: 1.0;
}







#rsvp #h2 {
	margin-top: 2rem;
}
#rsvp #h2:first-child {
	margin-top: 0;
}
#rsvp input[type="text"] {
	padding: 1em 1em;
	font-size: 1em;
	display: block;
	width: calc(100% - 60px);
	margin: 0.75rem 0 1.5rem 0;
}
#rsvp input[type="number"] {
	width: auto;
	padding: 0.5rem 1rem;
	font-size: 1em;
	border-radius: 6rem;
	border: 1px solid black;
	display: block;
	width: 3rem;
}
#rsvp em {
	color: white;
	font-weight: bold;
	font-size: 16px;
}
#submit-btn {
	width: calc(100% - 2rem);
	background: linear-gradient(-45deg, #ffaaaa54, #c67979e8);
	color: white;
	padding: 0.5rem 1rem;
	margin: 2rem 0 0 0;
	font-size: 2rem;
	cursor: pointer;
	border-radius: 0 0 10px 10px;
}
#submit-btn.disabled {
  opacity: 0.5;
  pointer-events: none;
}
#rsvp h4 {
	margin-top: 1rem;
	font-weight: 200;
	color: #A4A4A4;
	border-bottom: 1px solid #DDD;
	padding-bottom: 0.5rem;
	margin-bottom: 0.5rem;
}
#party-size-label {
	margin-top: 1rem;
	margin-bottom: 0.5rem;
}
p.success {
	border: 2px solid green;
	padding: 0.5rem 1rem;
	color: green;
	font-style: italic;
	font-weight: bold;
	letter-spacing: 0;
}
p.error {
	border: 2px solid red;
	padding: 0.5rem 1rem;
	color: red;
	font-style: italic;
	font-weight: bold;
	letter-spacing: 0;
}


/*
#rsvps li:last-child, #rsvps {
	margin-bottom: 0 !important;
}
#rsvps {
	padding: 0;
}
#rsvps li {
    list-style: none;
    background-color: #C6DEEC;
    padding: 0rem 1rem;
    color: #487793;
}
#rsvps li:first-child {
    border-radius: 1rem 1rem 0 0;
    padding-top: 0.75rem;
}
#rsvps li:last-child {
    padding-bottom: 0.75rem;
    border-radius: 0 0 1rem 1rem;
}
#rsvps h3 {
	font-weight: 300;
}

#rsvp {
  border-radius: 1rem;
	border: 1px solid black;
	padding: 1rem;
	margin-top: 1rem;
}
#rsvp > section {
	border-radius: 1rem;
	border: 1px solid black;
	padding: 1rem;
	margin-top: 1rem;
}
span.total {
	border-radius: 1rem;
	background-color: #76a8c6;
	color: white;
	font-size: ;
	font-weight: bold;
	padding: 1px 9px;
	text-align: center;
}
#rsvp > section > h1 {
	border-bottom: 1px solid black;
	padding-bottom: 0.5rem;
	margin-bottom: 0.5rem;
}
*/





#qr {
	width: 300px;
	margin-top: 100px;
	border-radius: 0 40px;
}
iframe.snazzymaps {
  border-radius: 10px;
}


.iframe-fluid {
  position: relative;
  display: block;
  width: 100%;
  height: 100%;
}
.fullscreen-img {
	position: fixed;
	z-index: 999999999;
	top: 30px;
	left: 30px;
	bottom: 30px;
	right: 30px;
	width: calc(100% - 60px);
	cursor: pointer;
	height: calc(100% - 60px);
	overflow-y: auto;
	box-shadow: 0 0 75px black;
	background-color: white;
	text-align: center;
}
.fullscreen-img img {
  max-width: 100%;
  height: auto;
  display: inline-block;
}


body.rsvp main > section {
  
}
iframe {
	border: none;
	width: 100%;
}
.iframe-crop {
  overflow: hidden;
  position: relative;
}
.max-width-767 {
  /*max-width: 767px;*/
}
iframe#rsvp-iframe.max-width-767 {
	/*max-width: calc(767px + 70px);*/
}
.iframe-crop > iframe#rsvp-iframe {
	position: relative;
	top: -200px;
	/*margin-bottom: -500px;*/
	height: 1785px;
	/*left: -35px;*/
	/*width: calc(100% + 70px);*/
	background-color: transparent;
	min-width: 320px;
}

.iframe-crop.rsvp-iframe {
	/*width: calc(100% - 70px);*/
	margin: auto;
	/*height: 425px;
	width: 300px;*/
}
@media(min-width: 480px) {
  .iframe-crop.rsvp-iframe {
  	/*height: 340px;
  	width: 430px;*/
  }
}
@media(min-width: 768px) {
  .iframe-crop.rsvp-iframe {
  	/*height: 310px;
    width: 600px;*/
  }
}
@media(min-width: 993px) {
  .iframe-crop.rsvp-iframe {
  	margin: auto;
  	/*height: 315px;
  	width: 685px;*/
  }
}
body.rsvp main > section.rsvp-form {
	background-color: transparent;
}
@media(max-width: 767px) {
  body.rsvp main > section.iframe-section {
    padding: 0;
    width: 100%;
    margin: 0;
  }
}



.pr-0 {
  padding-right: 0 !important;
}
.card .col-md-4 {
	position: relative;
	background-color: #262626;
	border-radius: var(--bs-border-radius) 0 0 var(--bs-border-radius);
	overflow: hidden;
	text-align: center;
}

.card-text {
	border: none;
	font-size: 0.75rem;
	border-radius: 0;
}
.card-title {
	line-height: 1rem;
	font-weight: var(--bs-btn-font-weight);
}
/*
.person.expanded .card-title {
	font-size: 0.75rem;
}
*/
.card-title .btn {
	font-size: 0.75rem;
	white-space: nowrap;
	line-height: 1rem;
	cursor: pointer;
	font-weight: 100;
}
.person.expanded img {
	position: absolute;
	top: 0;
	height: 100%;
	width: auto !important;
	left: 50%;
	transform: translateX(-50%);
	display: block;
	max-width: 1000000%;
}
.bio {
	border-top: 1px #DDD solid;
}
.bio span::before {
	content: "“";
  font-size: 2rem;
  font-family: Georgia;
  line-height: 0;
  position: relative;
  bottom: -0.75rem;
  padding: 5px;
}
.bio span::after {
	content: "”";
  font-size: 2rem;
  font-family: Georgia;
  line-height: 0;
  position: relative;
  bottom: -0.75rem;
  padding: 5px;
}
.person .btn > i {
  font-size: 1rem;
  font-style: normal;
}
.person .btn,
.person .btn:active,
.person .btn:focus,
.person .btn:hover {
  border: none !important;
  background: transparent;
}
.person .btn:hover {
  color: #999;
}
.person .btn {
	font-size: 0.75rem;
	display: block;
	margin: 1rem auto 0 auto;
}
@media(min-width: 768px) {
  .person .btn {
  	position: absolute;
  	bottom: 0;
  	right: 0;
  	margin: 0;
  }
}
.person.expanded .btn {
	position: absolute;
	bottom: 0;
	right: 0;
	margin: 0;
}
.person .btn > i,
.person.expanded .btn > * {
  display: none;
}
.person.expanded .btn > i {
  display: inline;
}
.person.expanded .btn {
	position: absolute;
	top: 0;
	right: 0;
	bottom: auto;
	background-color: white;
	border-radius: 0 7px;
}
@media(max-width: 767px) {
  .card .col-md-4 {
    border-radius: var(--bs-border-radius) var(--bs-border-radius) 0 0;
  }
}
@media(min-width:400px) and (max-width: 509px) {
  .person img {
  	width: 100%;
  	height: auto;
  }
}











.timeline {
  border-left: 5px solid black;
  position: relative;
  list-style: none;
  max-width: 320px;
}

.timeline .timeline-item {
  position: relative;
}



.timeline .timeline-item::after, .timeline .timeline-item::before {
  position: absolute;
	display: block;
	top: 6.5px;
	top: 0;
	background-color: black;
	left: -56px;
	border-radius: 50%;
	height: 24px;
	width: 24px;
	content: "";
}
.timeline .timeline-item::after {
	background-color: white;
	top: 11px;
	top: 4.5px;
	left: -51.5px;
	height: 15px;
	width: 15px;
}
.timeline p {
}
.timeline .timeline-item > div > *,
.timeline .timeline-item > * {
	position: relative;
	top: -5px;
}
@keyframes bgBlinker {
  50% {
    background-color: red;
  }
}
@keyframes colorBlinker {
  50% {
    color: red;
  }
}
.timeline .timeline-item.active::after {
  animation: bgBlinker 1s linear infinite;
}
.timeline .timeline-item.active * {
  animation: colorBlinker 1s linear infinite;
}





.countdown .time {
	font-size: 2rem;
	padding: 0 1rem;
	font-weight: 100;
	display: block;
}
.countdown .label {
	font-family: Savannah Alt;
	font-size: 2rem;
	display: block;
}
.countdown .wrapper {
	padding: 1rem;
	text-align: center;
}




#sig {
	max-width: 50%;
	display: block;
	margin: 1rem auto;
}


p.indent {
  text-indent: 2rem;
}



img.section-image-cap {
	width: calc(100% + 4rem);
	position: relative;
	transform: translate(calc(-2rem), calc(-2rem));
}
.transportation {
	position: absolute;
	top: 0.5rem;
	right: 0.5rem;
	background-color: white;
	width: 2rem;
	height: 2rem;
	text-align: center;
	line-height: 2rem;
	border-radius: 50%;
}


.list-group-item[style] {
  background: none scroll no-repeat 0 0 transparent;
  background-size: contain;
  padding-left: 3rem;
}

.list-group-item > * > img {
	width: 3rem;
	height: 3rem;
	display: inline-block;
	border-radius: 50%;
	object-fit: cover;
	margin-right: .5rem;
}




.inline-copy-code {
	border: none;
	padding: inherit;
	display: inline-block;
	width: 7em;
	text-align: center;
	cursor: pointer;
}