body {
	background-image: url("../images/bg.png");
	background-repeat: no-repeat;
	background-size: contain;
	color: #3F3F3F;
	font-family: "Congenial Ultra Light";
	font-size: 16px;
	letter-spacing: 1px;
	min-height: 700px;
}

.hide {
	display: none;
}

.show {
	display: block;
}

/* general */
.btn{
	background-color: #3F3F3F;
	border-color: #3F3F3F;
	border-radius: 2px;
	color: white;
	font-weight: bold;
	letter-spacing: 2px;
	padding: 12px 20px;
	text-transform: uppercase;
}

.btn:hover {
	background-color: #656565;
}

.btn:active {
	background-color: #2B2B2B !important;
}

.btn-wide {
	padding: 12px 36px;
}

h1 {
	font-family: "Edwardian Script";
	font-size: 60px;
	font-weight: 400;
	letter-spacing: 3px;
	margin-bottom: 50px;
}

h2 {
	font-size: 40px;
	letter-spacing: 2px;
}

h3 {
	font-size: 20px;
	font-weight: 400;
	letter-spacing: 2px;
}

h4 {
	font-size: 20px;
	letter-spacing: 2px;
}

p {
	font-weight: 500;
	text-align: justify;
}

#container {
		margin-top: max(20vw, 120px);
	}

@media (min-width: 800px) {
	h1 {
		font-size: 84px;;
	}
}

#content {
	align-content: center;
	max-width: 600px;
	margin: 0 auto 80px;
}

#content.full-width {
	max-width: none;
}


#login input {
	letter-spacing: 2px;
	margin: 20px auto 25px;
	text-align: center;
	text-transform: uppercase;
	width: 162px;
}

#login button {
	margin-top: 30px;
}

#header {
	margin-bottom: 60px;
}

#header h3 {
	margin-bottom: 50px;
}

#header #menu .nav-item a{
	color: #3F3F3F;
}

#footer {
	margin-bottom: 50px;
}

#footer hr {
	width: 100px;
}

#home .date {
	border-right: 1px solid black;
}

#home .rsvp-btn {
	margin-top: 50px;
}

#home .headline {
	margin-bottom: 50px;
}

#home .headline h2 {
	margin-bottom: 30px;
}

#home .headline span {
	font-size: 14px;
}

#home .program .container {
	margin: 35px 0;
}

#home .program td{
	color: #3F3F3F;
	font-size: 20px;
	padding: 35px 0;
	vertical-align: middle;
}

#home td.empty {
	padding: 0;
}

#home td.program-time {
	padding-right: 20px;
	text-align: right;
	width: 50%;
}

#home td.program-item {
	padding-left: 20px;
	text-align: left;
	width: 50%;
}

#home .program-item p {
	margin-bottom: 0;
}

#our-story h2 {
	margin-bottom: 20px;
}

#our-story .img-fluid {
	border-radius: 8px;
	margin: 14px auto 30px;
}


#wedding-party .row{
	margin-bottom: 20px;
}

#wedding-party .col {
	display: grid;
	max-width: 220px;
	margin: auto;
}

#wedding-party img {
	border-radius: 100%;
	margin: 0 auto 20px;
	width:150px;
}

#wedding-party .name {
	font-size: 20px;
}

#wedding-party .deets {
	font-size: 14px;
}

#travel .travel-item {
	margin-bottom: 50px;
}

#travel h3 {
	font-size: 24px;
	font-weight: bold;
	margin-bottom: 20px;
}

#travel img{
	margin: 20px 0 30px;
}

#travel ul {
	text-align: left;
}

#travel li {
	padding-left: 10px;
}

#accommodation thead {
	text-transform: uppercase;
}

#accommodation thead th {
	background-color: #3F3F3F;
}

#accommodation tbody th {
	color: #3F3F3F;
}

#accommodation tbody td {
	color: #3F3F3F;
}

#accommodation .accommodation-item {
	margin-bottom: 60px;
}

#accommodation .btn {
	margin: 0 10px;
}

#registry h2 {
	margin-bottom: 50px;
}

#q-and-a h4 {
	font-weight: bold;
	margin-bottom: 20px;
}

#q-and-a p {
	font-size: 14px;
	line-height: 1.75;
	margin-bottom: 50px;
}

#rsvp .intro {
	font-size: 20px;
}

#rsvp form {
	margin-top: 50px;
}

#rsvp h2 {
	font-size: 24px;
	margin-bottom: 50px;
	text-decoration: underline;
}

#rsvp h3 {
	font-size: 20px;
	margin-bottom: 30px;
}

#rsvp .rsvp-guest {
	border: 1px solid #666;
	border-radius: 6px;
	padding: 50px 20px;
	margin-bottom: 20px;
}

@media (min-width: 600px) {
	#rsvp .rsvp-guest {
		padding: 50px 50px;
	}
}

#rsvp .rsvp-item {
	margin-bottom: 50px;
}

#rsvp .plus-one-name input {
	max-width: 200px;
}

#rsvp .rsvp-item.with-msg {
	margin-bottom: 0;
}

#rsvp .form-check-inline {
	margin-bottom: 1rem;
}


#rsvp .option.no-pad{
	padding-left: 0;
}

#rsvp .msg {
	color: #DAA520;
	min-height: 50px;
	padding: 13px 0;
}

#rsvp .msg-invalid {
	color: #E53935;
}

#rsvp .submit-msg {
	font-weight: bold;
}

#rsvp input[type="radio"] {
	display: none;
}

/* NOTE: is there a way to group radio and checkbox? */
#rsvp input[type="checkbox"] {
	display: none;
}

#rsvp .form-check-label {
  border: 1px solid #666;
  border-radius: 8px;
  color: #666;
  cursor: pointer;
  min-width: 100px;
  padding: 10px 20px;
}

#rsvp input[type="radio"]:hover ~ label {
  background-color: #EEE;
}

#rsvp input[type="radio"]:checked ~ label {
  background-color: #FBF5E4;
  border-color: #DAA520;
  color: #DAA520;
}

#rsvp input[type="checkbox"]:hover ~ label {
  background-color: #EEE;
}


@media (pointer: coarse) {
	#rsvp input[type="checkbox"]:hover ~ label {
	  background-color: revert-layer;
	}
}

#rsvp input[type="checkbox"]:checked ~ label {
  background-color: #FBF5E4;
  border-color: #DAA520;
  color: #DAA520;
}

#rsvp textarea {
	height: 100px;
}

#rsvp .rsvp-email {
	max-width: 300px;
	margin: auto;
}

#rsvp .additional-question {
	margin: 30px auto 50px;
}

#rsvp .additional-question h5 {
	font-size: 16px;
	margin-bottom: 10px;
}

#rsvp .large-label {
	max-width: 300px;
}

#rsvp .large-label .text {
	font-size: 13px;
}

#rsvp .dont-worry {
	display: block;
	font-size: 14px;
}

#rsvp .dont-worry strong {
	white-space: nowrap;
}

.spinner {
  width: 50px;
  height: 24px;
  text-align: center;
  font-size: 10px;
}

.spinner > div {
  background-color: white;
  height: 100%;
  width: 6px;
  display: inline-block;
  
  -webkit-animation: sk-stretchdelay 1.2s infinite ease-in-out;
  animation: sk-stretchdelay 1.2s infinite ease-in-out;
}

.spinner .rect2 {
  -webkit-animation-delay: -1.1s;
  animation-delay: -1.1s;
}

.spinner .rect3 {
  -webkit-animation-delay: -1.0s;
  animation-delay: -1.0s;
}

.spinner .rect4 {
  -webkit-animation-delay: -0.9s;
  animation-delay: -0.9s;
}

.spinner .rect5 {
  -webkit-animation-delay: -0.8s;
  animation-delay: -0.8s;
}

@-webkit-keyframes sk-stretchdelay {
  0%, 40%, 100% { -webkit-transform: scaleY(0.4) }  
  20% { -webkit-transform: scaleY(1.0) }
}

@keyframes sk-stretchdelay {
  0%, 40%, 100% { 
    transform: scaleY(0.4);
    -webkit-transform: scaleY(0.4);
  }  20% { 
    transform: scaleY(1.0);
    -webkit-transform: scaleY(1.0);
  }
}

#guestlist table {
	font-size: 12px;
}