.hidden { display: none }

ul.actions.fit {
	width: calc(100% + 0.5em);
	margin-left: -0.5em;
	margin-bottom: 0.5em;
}
ul.actions li { padding-left: 0.5em }
	@media screen and (max-width: 480px) {
		ul.actions:not(.fixed) {
			margin-left: -0.25em;
		}
		ul.actions:not(.fixed) {
			-moz-flex-direction: unset;
			-webkit-flex-direction: unset;
			-ms-flex-direction: unset;
			flex-direction: unset;
		}
		ul.actions:not(.fixed) li {
			padding: 0 0 0 0.5em;
		}
	}

form#join-form {
	margin-bottom: 2em;
	box-shadow: 0px 0px 0px 0.5px rgba(50, 50, 93, 0.1),  0px 2px 5px 0px rgba(50, 50, 93, 0.1), 0px 1px 1.5px 0px rgba(0, 0, 0, 0.07);
	background-color: #f7f7f7;
	padding: 1.63em 2em 1.5em;
	max-width: 600px;
}

	form#join-form h2 {
		margin: 0 0 1.125em;
		padding: 0;
	}
		form#join-form h2:after { border: none }

	@media screen and (max-width: 980px) {
		form#join-form {
			padding: 1.25em 1em 1.5em;
		}
		form#join-form h2 {
			text-align: center;
			font-size: 1.5em;
			line-height: 1.25;
		}
	}

	form#join-form input[type="text"], form#join-form select, div.StripeElement#ccnbr, div.StripeElement#ccexp, div.StripeElement#cccvc {
		font-size: 18px !important;
		border: 1px solid #e6e6e6;
		background-color: #fff;
	}
		div.StripeElement#ccnbr, div.StripeElement#ccexp, div.StripeElement#cccvc {
   			display: block;
			color: inherit;
			outline: 0;
			padding: 0.75em 1em;
			text-decoration: none;
			width: 100%;
		}
			div#panel-3 > ul:nth-child(2) > li:nth-child(1) { width: 116% }
			div#panel-3 > ul:nth-child(2) > li:nth-child(2) { width: 86% }
			div#panel-3 > ul:nth-child(2) > li:nth-child(3) { width: 98% }

		@media screen and (max-width: 480px) {
			div.StripeElement#ccnbr, div.StripeElement#ccexp, div.StripeElement#cccvc, form#join-form input#cczip  {
				padding: 0.75em 0.75em
			}
		}

	form#join-form button, form#join-form a.button {
		margin-top:	0.25em;
		font-size: 18px !important;
		width: 100%;
	}

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

	input[type="checkbox"] {
		margin-bottom: 1em;
	}
	input[type="checkbox"] + label {
		line-height: 1.4;
	}
	input[type="checkbox"] + label:before, input[type="radio"] + label:before {
		background: white;
	}

	label.btn {
		border: 0;
		border-radius: 0;
		cursor: pointer;
		display: inline-block;
		font-size: 18px !important;
		font-family: "Raleway", Helvetica, sans-serif;
		font-weight: 600;
		height: 2.75em;
		line-height: 2.75em;
		text-align: center;
		text-decoration: none;
		text-transform: uppercase;
		white-space: nowrap;

		background-color: transparent;
		color: #444 !important;
		xxbox-shadow: inset 0 0 0 1px #444;
		border: 1px solid #e6e6e6;

		background-color: #fff;
		margin: 0;
	}
		@media screen and (max-width: 480px) {
			label.btn[for=frequency_m],label.btn[for=frequency_o]  { font-size: 17px !important }
		}
		label.btn.active, select#category.active {
			background-color: #007cdc;
			color: #fff !important;
			border-color: #444;
		}

.join-form-error {
	margin: 1.2em 0 0.9em;
	line-height: 1.4;
	color: #d00;
}

#dollar-amount {
	position: relative;
}
	#dollar-amount span:first-child {
		position: absolute;
		top: 0.55em;
		left: 1.45em;
		width: 0.75em;
		font-size: 18px !important;
		font-family: Raleway, Helvetica, sans-serif;
		font-weight: 600;
	}
		@media screen and (max-width: 480px) {
			#dollar-amount span:first-child {
				top: 0.65em;
				left: 1.25em;
			}
		}
	#dollar-amount input {
		text-align: center;
		font: 1rem Raleway, Helvetica, sans-serif;
		font-weight: 600;
		xxpadding-top: 0.2rem;
	}
		#dollar-amount.active input {
			background-color: #007cdc !important;
			color: #fff !important;
			border-color: #444 !important;
		}
			#dollar-amount.active span:first-child { color: #fff !important }

#panel-1 p {
	margin-bottom: 1em;
}
	#panel-1 p:first-child {
		margin-bottom: 0.45em;
	}
		@media screen and (max-width: 480px) {
			#panel-1 p:first-child {
				margin-bottom: 0.7em;
			}
		}


#panel-3-change-amount {
	font-size: 0.925em;
	text-align: center;
	margin-top: 0.5em;
	text-decoration: underline;
	cursor: pointer;
	color: #777;
}

span.hrt {
	display: inline-block;
	margin-right: 0.3rem;
	color: #ccc;
}

p.secure-note {
	font-size: 0.8125rem;
	color: #6a6a6a;
	margin: 1.45em 0 0;
	text-align: center;
	line-height: 1.35;
}

p.tax-notice {
	font-size: 0.8658em;
	color: #6a6a6a;
}