
/* CSS clear based on http://meyerweb.com/eric/tools/css/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, img, ins, kbd, q, s, samp, small, strike, strong, sub, sup, tt, var, b, u, i, center, dl,
dt, dd, ol, ul, li, fieldset, form, label, legend, table, caption, tbody, tfoot, thead, tr, th, td, article, aside,
canvas, details, embed,  figure, figcaption, footer, header, hgroup,  menu, nav, output, ruby, section, summary, time,
mark, audio, video {
	padding: 0; margin: 0; border: 0; font-size: 100%; font: inherit; vertical-align: baseline;
}


/* HTML5 display-role reset for older browsers and specific declarations */

article, aside, details, figcaption, figure, footer, header, hgroup, menu, nav, section {
	display: block;
}

ol, ul {
	list-style: none;
}

blockquote, q {
	quotes: none;
}

blockquote:before, blockquote:after, q:before, q:after {
	content: ''; content: none;
}

table {
	border-spacing: 0; border-collapse: collapse;
}

.cf:before,
.cf:after {
	content: " ";
	display: table;
}

.cf:after {
	clear: both;
}


/* Main definitions */

html {
	box-sizing: border-box;
}

*, *:before, *:after {
	box-sizing: inherit;
}

body {
	padding: 0; margin: 0;
	position: relative;
	background: #101010 url('../images/bgd-black.png');
}

body, td, p  {
	color: #fff;
	font-family: "Roboto", Arial, "Helvetica Neue", Helvetica, sans-serif; font-size: 13px; line-height: 1.6em; font-weight: 400;
 }

b, strong {
	font-weight: 700;
}

i, em {
	font-style: italic;
}

a, a:visited {
	color: #cda558;
	text-decoration: none;
}

a:hover, a:active {
	color: #c4850a;
	text-decoration: none;
}

p {
	margin-bottom: 1em;
	text-align: justify;
}

h2 {
	font-family: "Roboto", Arial, "Helvetica Neue", Helvetica, sans-serif; font-size: 29px; line-height: 1.2em; font-weight: 700; text-align: center;
}

h3 {
	font-family: "Roboto", Arial, "Helvetica Neue", Helvetica, sans-serif; font-size: 25px; line-height: 1.2em; font-weight: 400; text-align: center;
}

h4 {
	font-family: "Roboto", Arial, "Helvetica Neue", Helvetica, sans-serif; font-size: 18px; line-height: 1.2em; font-weight: 400; text-align: center;
}


/* Form wrappers */

.form-background {
	position: relative;
	background: url("../images/bgd-desktop-01.jpg") center center no-repeat; background-size: cover;
}

@media(max-width: 699px) {
	.form-background {
		background: url("../images/bgd-mobile-01.png") center top no-repeat; background-size: auto;
	}
}

.form-darken {
	background: url("../images/bgd-darken.png") center center repeat-y;
}

@media(max-width: 699px) {
	.form-darken {
		background: none;
	}
}

.form-wrapper {
	width: 100%; max-width: 920px;
	padding-top: 35px; padding-bottom: 35px; margin: 0 auto;
	text-align: center;
}

@media(max-width: 999px) {
	.form-wrapper {
		max-width: calc(100% - 40px); min-height: 0;
	}
}


/* Logo section */

.heading-wrapper p {
	margin-top: -8px;
	font-size: 1.3em; font-weight: 400; text-align: center;
}

.heading-wrapper p .accent {
	color: #cda558;
	font-weight: 700;
}

.heading-wrapper hr {
	width: 120px;
	margin: 0 auto 30px auto; 
	background-color: #fff;
}


/* Form section */

.form-information {
	margin: 20px 0 30px 0;
	font-size: 16px; font-weight: 400; text-align: center;
}

.form-fields {
	width: 100%;
	display: flex; gap: 30px;
	margin: 0 auto;
}

.field-wrapper {
	display: flex; flex: 1; flex-direction: column; 
}

.field-wrapper .field-heading p {
	margin-top: -8px;
	font-size: 1.3em; font-weight: 400; text-align: center;
}

.field-wrapper .field-heading p .accent {
	color: #cda558;
	font-weight: 700;
}

@media(max-width: 699px) {
	.form-fields {
		flex-direction: column; gap: 0;
	}
}

.form-fields .field-wrapper input[type="text"] {
	width: 100%;
	padding: 10px 12px;
	background: #fff; border: 0 none; border-radius: 3px;
	font-size: 20px; line-height: 18px; text-align: left;
}

.form-fields .field-wrapper > span {
	display: block;
	margin-bottom: 10px;
}

.form-fields .field-wrapper .label {
	font-size: 16px; font-weight: 400;
}

.form-fields .field-wrapper .disclaimer {
	color: #c0c0c0;
	margin-left: auto; margin-right: auto;
	font-size: 12px; line-height: 17px;
}

@media(max-width: 699px) {
	.form-fields .field-wrapper .disclaimer {
		max-width: 250px;
	}
}


/* Join options - desktop */

@media(min-width: 1000px) {
	.join-options {
		display: flex; justify-content: center; gap: 10px;
		padding-top: 20px;
	}
	
	.join-option {
		width: 100%; position: relative;
		cursor: pointer;
	}
	
	.join-option input {
		display: none;
	}
	
	.join-option .description {
		width: 100%; display: block; position: relative;
		padding: 25px 0px 30px 0px;
		background: #fff; border-radius: 3px;
	}
	
	.join-option:nth-child(2)  .description {
		padding: 45px 0px 50px 0px;
		margin-top: -20px
	}
	
	.join-option .description:hover {
		transform: scale(1.035);
	}
	
	.join-option .description .option-price {
		width: 100%;
		margin: 10px 0 15px 0;
		color: #000;
		font-weight: 700; text-align: center;
	}
	
	.join-option .description .option-price .dollars {
		font-size: 76px; line-height: 76px; letter-spacing: -2px;
	}
	
	.join-option .description .option-price .cents {
		display: inline-block;
		margin-left: 5px;
		border-bottom: 4px solid #000;
		font-size: 32px; line-height: 32px; letter-spacing: -1px;
		transform: translate(0, -30px);
	}
	
	.join-option .description .option-price .dollarsign {
		margin-right: 4px;
		letter-spacing: -1px;
		font-size: 32px; line-height: 32px;
	}
	
	.join-option .description .option-price .time {
		margin-left: -45px;
		font-size: 12px; font-weight: 500; font-style: italic;
	}
	
	.join-option .description .option-button {
		margin-top: 30px;
		text-align: center;
	}
	
	.join-option .description .option-button span {
		padding: 12px 16px;
		background-image: linear-gradient(to bottom right, #cda558, #c4850a); border-radius: 3px; color: #fff;
		font-size: 16px; line-height: 16px; font-weight: 500;
	}
	
	.join-option .description .option-title {
		color: #c4850a;
		font-size: 28px; line-height: 28px; font-weight: 700; letter-spacing: -1px; text-align: center;
	}
	
	.join-option .description .option-title .access {
		color: #000;
		font-size: 22px;
	}
	
	.join-option .description .option-info > span {
		display: inline-block; color: #000;
		margin-bottom: 3px;
		font-size: 15px; line-height: 20px; font-weight: 500; letter-spacing: -0.5px; text-align: center;
	}
	
	.join-option .description .option-info .unlimited {
		padding-left: 20px;
		background: url("../images/icon-unlimited.png") left center no-repeat; color: #c4850a;
	}
	
	.join-option.active .description {
		background-image: linear-gradient(to bottom right, #cb8626, #a45500);
	}
	
	.join-option.active .description .option-price,
	.join-option.active .description .option-price .cents,
	.join-option.active .description .option-title,
	.join-option.active .description .option-title .access,
	.join-option.active .description .option-info > span {
		color: #fff; border-color: #fff;
	}
	
	.join-option.active .description .option-title {
		color: #ffff44;
	}
	
	.join-option.active .description .option-info .unlimited {
		background: url("../images/icon-unlimited-inv.png") left center no-repeat;
	}

	.join-option.active .description .option-button span {
		background-image: linear-gradient(to bottom right, #ffffff, #e7e7e7); color: #b4750a;
	}
}


/* Join options - mobile */

@media(max-width: 999px) {
	.join-option {
		position: relative;
		margin-bottom: 20px;
		cursor: pointer;
	}
	
	.join-option input {
		display: none;
	}
	
	.join-option .description {
		width: 100%; height: 100px; display: block; position: relative;
		background: #fff; border-radius: 3px;
	}
	
	.join-option .description:hover {
		transform: scale(1.035);
	}
	
	@media(max-width: 699px) {
		.join-option .description:hover {
			transform: none;
		}
	}
	
	.join-option .description .option-price {
		position: absolute; right: 15px; top: 12px;
		padding-right: 48px;
		color: #000;
		font-weight: 700;
	}
	
	.join-option .description .option-price .dollars {
		font-size: 76px; line-height: 76px; letter-spacing: -2px;
	}
	
	.join-option .description .option-price .cents {
		display: block; position: absolute; right: 0px; top: 6px;
		letter-spacing: -1px;
		border-bottom: 4px solid #000;
		font-size: 32px; line-height: 32px;
	}
	
	.join-option .description .option-price .dollarsign {
		margin-right: 4px;
		letter-spacing: -1px;
		font-size: 32px; line-height: 32px;
	}
	
	.join-option .description .option-price .time {
		display: block; position: absolute; right: 1px; bottom: 7px;
		font-size: 12px; font-weight: 500; font-style: italic;
	}
	
	@media(max-width: 699px) {
		.join-option .description .option-price {
			top: 14px;
			padding-right: 38px;
		}
	
		.join-option .description .option-price .dollars {
			font-size: 32px; line-height: 32px;
		}
	
		.join-option .description .option-price .cents {
			top: 3px; right: 10px;
			font-size: 18px; line-height: 18px;
			border: 0 none;
		}
	
		.join-option .description .option-price .dollarsign {
			margin-right: 3px;
			font-size: 22px; line-height: 22px;
		}
	
		.join-option .description .option-price .time {
			right: -3px; bottom: -1px;
			font-size: 10px;
		}
	}
	
	.join-option .description .option-button {
		display: none;
	}

	.join-option .description .option-title {
		position: absolute; left: 15px; top: 14px;
		color: #c4850a;
		font-size: 32px; line-height: 32px; font-weight: 700; letter-spacing: -1px;
	}
	
	.join-option .description .option-title .access {
		color: #000;
		font-size: 24px;
	}
	
	@media(max-width: 699px) {
		.join-option .description .option-title .access {
			display: none;
		}
	}
	
	.join-option .description .option-info {
		position: absolute; left: 15px; top: 50px;
	}
	
	.join-option .description .option-info > span {
		display: block;
		color: #000;
		font-size: 15px; line-height: 20px; font-weight: 500; letter-spacing: -0.5px; text-align: left;
	}
	
	@media(max-width: 699px) {
		.join-option .description .option-info > span {
			font-size: 14px;
		}
	}
	
	.join-option .description .option-info .unlimited {
		padding-left: 20px;
		background: url("../images/icon-unlimited.png") left center no-repeat; color: #c4850a;
	}
	
	.join-option.active .description {
		background-image: linear-gradient(to bottom right, #cb8626, #a45500);
	}
	
	.join-option.active .description .option-price,
	.join-option.active .description .option-price .cents,
	.join-option.active .description .option-title,
	.join-option.active .description .option-title .access,
	.join-option.active .description .option-info > span {
		color: #fff; border-color: #fff;
	}
	
	.join-option.active .description .option-title {
		color: #ffff44;
	}
	
	.join-option.active .description .option-info .unlimited {
		background: url("../images/icon-unlimited-inv.png") left center no-repeat;
	}
}


/* Payment options */

.payment-options {
	margin-top: 25px;
	text-align: center;
}

.payment-option {
	display: inline-block;
	margin: 6px 8px;
	font-size: 21px; line-height: 25px;
}


/* Submit button */

.join-submit {
	width: 100%; max-width: 620px;
	margin: 25px auto 0 auto;
}

.join-submit input {
	width: 100%; display: block;
	padding: 20px 10px;
	background: #c4850a; border: 0 none; border-radius: 3px; color: #171717; cursor: pointer;
	font-family: "Roboto", Arial, "Helvetica Neue", Helvetica, sans-serif; font-size: 30px; line-height: 1.2em; font-weight: 700; text-transform: uppercase; text-align: center;
	transition: background-color 0.25s;
}

.join-submit input:hover {
	background-color: #cda558;
	transition: background-color 0.25s;
}

.mail-option {
	padding: 0 15px; margin: 25px 0 15px 0;
	font-size: 14px; line-height: 1.5em; text-align: center;
}


/* Form message */

.instructions {
	width: 100%; max-width: 620px;
	margin: 40px auto 0 auto;
}

.instructions p {
	margin: 15px 0;
	font-size: 15px; line-height: 1.6em; text-align: justify;
}

.instructions ul {
	padding: 12px 18px; margin: 15px 0;
	background: rgba(255, 255, 255, 0.35); border: 1px solid rgba(0, 0, 0, 0.15);
	font-size: 18px; line-height: 26px; text-align: left;
}

.instructions ul li {
	margin: 2px 0;
}

.instructions ul li .label {
	width: 130px; display: inline-block;
	font-size: 14px; text-align: right; text-transform: uppercase;
}

.instructions ul li .value {
	display: inline-block;
	margin-left: 10px;
	font-weight: 700; text-align: left;
}

.form-errors {
	margin: 20px;
	color: #eb0060;
	font-size: 15px; line-height: 1.6em; font-weight: 700; text-align: center;
}


/* Form list */

.form-list-item {
	margin: 15px 0;
	font-size: 17px; line-height: 1.6em; text-align: center;
}

.form-list-item span {
	display: block;
}


/* Footer section */

.footer-section {
    padding: 20px 60px 0 60px;
    border-top: 5px solid #303030;
    font-size: 13px; line-height: 20px;
}

.footer-section .disclaimer {
    width: calc(100% - 240px); max-width: 700px; display: block; float: left;
    text-align: justify;
}

.footer-section .links {
    width: 200px; display: block; float: right;
    text-align: right;
}

.footer-section a:last-child {
    margin-left: 8px;
}

@media(max-width: 699px) {
	.footer-section {
		padding: 20px 20px 0 20px;
	}

	.footer-section .disclaimer {
		width: 100%; float: none;
	}

	.footer-section .links {
		width: 100%; float: none;
		margin-top: 20px;
		text-align: center;
	}
}