.payment_details {
  background-color: #fff;
}

.payment_details * {
  font-family: Open Sans, "Open Sans", "Helvetica Neue", Helvetica, Arial, sans-serif;
  font-size: 16px;
  font-weight: 500;
}

.payment_details .row {
  display: -ms-flexbox;
  display: flex;
  margin: 15px 0px 30px;
}

.payment_details .header {
	text-transform: uppercase;
	padding: 0;
	margin: 0;
	height: 30px;
}

.payment_details .field {
  position: relative;
  width: 100%;
  height: 50px;
  margin: 0 10px 0 0;
}

.payment_details .field.half-width {
  width: 50%;
}

.payment_details .field.quarter-width {
  width: calc(25% - 10px);
}

.payment_details select.input {
	border: 1px solid #ddd;
	border-radius: 3px;
	color: #5E8C16;
}

.payment_details label.cvv {
  float: left !important;
}

.payment_details span.cvv {
    padding: 0px 10px;
    font-size: 12px;
    display: flex;
    margin-bottom: 3px;
    width: auto;
    font-weight: 300;
}

#signup_cvv_show {
	padding: 0px 5px;
	font-size: small;
}

.payment_details .input {
  position: absolute;
  width: 100%;
  left: 0;
  bottom: 0;
  padding: 3px 5px;
  color: #32325d;
  background-color: transparent;
  border: 1px solid #ddd;
  border-radius: 3px;
}

.payment_details .input::-webkit-input-placeholder {
  color: transparent;
  transition: color 0.3s cubic-bezier(0.165, 0.84, 0.44, 1);
}

.payment_details .input::-moz-placeholder {
  color: transparent;
  transition: color 0.3s cubic-bezier(0.165, 0.84, 0.44, 1);
}

.payment_details .input:-ms-input-placeholder {
  color: transparent;
  transition: color 0.3s cubic-bezier(0.165, 0.84, 0.44, 1);
}

.payment_details .input.focused,
.payment_details .input:not(.empty) {
  opacity: 1;
}

.payment_details .input.focused::-webkit-input-placeholder,
.payment_details .input:not(.empty)::-webkit-input-placeholder {
  color: #cfd7df;
}

.payment_details .input.focused::-moz-placeholder,
.payment_details .input:not(.empty)::-moz-placeholder {
  color: #cfd7df;
}

.payment_details .input.focused:-ms-input-placeholder,
.payment_details .input:not(.empty):-ms-input-placeholder {
  color: #cfd7df;
}

.payment_details .input.focused + label {
  color: #5E8C16;
}

.payment_details .input.invalid + label {
  color: #ffa27b;
}

.payment_details .input.focused + label + .baseline {
  background-color: #5E8C16;
}

.payment_details .input.focused.invalid + label + .baseline {
  background-color: #e25950;
}

.payment_details input:-webkit-autofill {
  -webkit-text-fill-color: #5E8C16;
  transition: background-color 100000000s;
  -webkit-animation: 1ms void-animation-out;
}

.payment_details .StripeElement--webkit-autofill {
  background: transparent !important;
}

.payment_details input {
  -webkit-animation: 1ms void-animation-out;
}

.payment_details .payment-error {
	display: none;
}

.payment_details .payment-error.visible {
	display: block;
}

.payment_details .payment-error svg {
  margin-top: 0 !important;
}

.payment_details .payment-error svg .base {
  fill: #e25950;
}

.payment_details .payment-error svg .glyph {
  fill: #fff;
}

.payment_details .payment-error .message {
  color: #e25950;
}

.payment_details label.error {
	bottom: -25px;
	color: #e25950;
	line-height: 25px;
	margin-top: 30px;
}

#cc_number,#cc_expiry,#cc_cvv,#cc_zip
{
  position:absolute;
  top:18px;
  z-index:-1;
  border:none;
  color:transparent;
  font-size:1%;
}