#bg-main {
    background-color: #131313;
    min-height: 100vh;
    width: 100%;
}

@media (min-width: 768px)  {
    #bg-main {
        background-image: url("/img/payment/join/bg.jpg");
        background-size: cover;
        background-position: center top;
        background-repeat: no-repeat;
    }
}

h3, .h3 {
  font-weight: 500;
}

.price-select {
    background: #FFF;
    color: #131313;
    cursor: pointer;
    border: 1px solid #DE127C;
}

.price-select:hover,
.price-select.selected {
    background: #DE127C;
    color: #FFFFFF;
}

.price-select .fs-5 {
    min-height: 60px;
    color: #DE127C;
}
.price-select.selected .fs-5{
    color: #FFF;
}

.price-select input {
    display:none;
}

.price-select .join-title {
    font-weight: 600;
}
.price-select:not(:hover, .selected) .join-title {
    color: #DE127C;
}

.p-prov {
    font-size: 0px;
}
.p-prov label {
    width: 150px;
}
.p-prov label:first-of-type {
    border-top-right-radius: 0px;
    border-bottom-right-radius: 0px;
}
.p-prov label:last-of-type {
    border-top-left-radius: 0px;
    border-bottom-left-radius: 0px;    
}

.p-prov .btn-check + .btn {
    color: rgba(102, 102, 102, 0.8);
    background-color: transparent;
    border-color: #BBBBBB;
}

.btn-check:checked + .btn {
    color: #FFFFFF;
    background-color: #DE127C;
    border-color: #DE127C;
}

/* join page only */
#join {
    max-width: 786px;
    border-radius: 10px;
}
@media (max-width: 768px)  {
    #join {
        max-width: 600px;
    }
}

#join div {
    font-family: 'Montserrat', sans-serif;    
}

#join form#register-form .btn,
#join form#login-form .btn,
#join form#login-form .form-check {
    display: none;
}

#join .p-prov .btn-check + .btn {
    color: rgba(255, 255, 255, 0.6);
    background-color: transparent;
    border-color: rgba(255, 255, 255, 0.6);
}

#join .btn-check:checked + .btn {
    color: #FFFFFF;
    background-color: #DE127C;
    border-color: #DE127C;
}

#join .price-select {
    border: 4px solid transparent;
}

#join .price-select:hover {
    border: 4px solid #FF0F8C;
}
#join .price-select:not(.selected):hover {
    background: #FFFFFF;
    color: #131313;
}
#join .price-select:not(.selected):hover .fs-5 {
    color: #DE127C;
}

/* from main css, need to fix */
input:focus ~ .floating-label, input:not(:placeholder-shown) ~ .floating-label {
  top: 5px;
  left: 25px;
  font-size: 11px;
  opacity: 1;
  color: #9B9B9B;
}
.floating-label {
  font-family: 'Montserrat', sans-serif;
  position: absolute;
  pointer-events: none;
  left: 25px;
  top: 11px;
  transition: 0.2s ease all;
  color: #9B9B9B;
  font-size: 1rem;
  font-weight: 400;
}

#join a:not(.btn) {
  color: #FFF;
  text-decoration: none;
}
#join a:not(.btn):hover {
  text-decoration: underline;
}
