html { font: normal 12px/18px "Poppins"; margin: 0; padding: 0; }
body { margin: 0; padding: 0; color: #111; }

.content {
    background: url(bg-0.jpg); background-size: cover;
	position: fixed; left: 0; top: 0; width: 100vw; height: 100vh; overflow-y: auto;
}

.row {
	display: grid;
    grid-template-columns: repeat(12, minmax(0, 1fr));
}

.row > div {
	padding: 1rem;
}

.col-0 { display: none; }
.col-1 { grid-column: auto / span 1; }
.col-2 { grid-column: auto / span 2; }
.col-3 { grid-column: auto / span 3; }
.col-4 { grid-column: auto / span 4; }
.col-5 { grid-column: auto / span 5; }
.col-6 { grid-column: auto / span 6; }
.col-7 { grid-column: auto / span 7; }
.col-8 { grid-column: auto / span 8; }
.col-9 { grid-column: auto / span 9; }
.col-10 { grid-column: auto / span 10; }
.col-11 { grid-column: auto / span 11; }
.col-12 { grid-column: auto / span 12; }

.px-2 { padding-left: 2rem !important; padding-right: 2rem !important; }

@media screen and (min-width: 672px) {
	.col-sm-1 { grid-column: auto / span 1 !important; display: block; }
	.col-sm-2 { grid-column: auto / span 2 !important; display: block; }
	.col-sm-3 { grid-column: auto / span 3 !important; display: block; }
	.col-sm-4 { grid-column: auto / span 4 !important; display: block; }
	.col-sm-5 { grid-column: auto / span 5 !important; display: block; }
	.col-sm-6 { grid-column: auto / span 6 !important; display: block; }
	.col-sm-7 { grid-column: auto / span 7 !important; display: block; }
	.col-sm-8 { grid-column: auto / span 8 !important; display: block; }
	.col-sm-9 { grid-column: auto / span 9 !important; display: block; }
	.col-sm-10 { grid-column: auto / span 10 !important; display: block; }
	.col-sm-11 { grid-column: auto / span 11 !important; display: block; }
	.col-sm-12 { grid-column: auto / span 12 !important; display: block; }
}

@media screen and (min-width: 990px) {
	.col-md-1 { grid-column: auto / span 1 !important; display: block; }
	.col-md-2 { grid-column: auto / span 2 !important; display: block; }
	.col-md-3 { grid-column: auto / span 3 !important; display: block; }
	.col-md-4 { grid-column: auto / span 4 !important; display: block; }
	.col-md-5 { grid-column: auto / span 5 !important; display: block; }
	.col-md-6 { grid-column: auto / span 6 !important; display: block; }
	.col-md-7 { grid-column: auto / span 7 !important; display: block; }
	.col-md-8 { grid-column: auto / span 8 !important; display: block; }
	.col-md-9 { grid-column: auto / span 9 !important; display: block; }
	.col-md-10 { grid-column: auto / span 10 !important; display: block; }
	.col-md-11 { grid-column: auto / span 11 !important; display: block; }
	.col-md-12 { grid-column: auto / span 12 !important; display: block; }
}

@media screen and (min-width: 1296px) {
	.col-lg-1 { grid-column: auto / span 1 !important; display: block; }
	.col-lg-2 { grid-column: auto / span 2 !important; display: block; }
	.col-lg-3 { grid-column: auto / span 3 !important; display: block; }
	.col-lg-4 { grid-column: auto / span 4 !important; display: block; }
	.col-lg-5 { grid-column: auto / span 5 !important; display: block; }
	.col-lg-6 { grid-column: auto / span 6 !important; display: block; }
	.col-lg-7 { grid-column: auto / span 7 !important; display: block; }
	.col-lg-8 { grid-column: auto / span 8 !important; display: block; }
	.col-lg-9 { grid-column: auto / span 9 !important; display: block; }
	.col-lg-10 { grid-column: auto / span 10 !important; display: block; }
	.col-lg-11 { grid-column: auto / span 11 !important; display: block; }
	.col-lg-12 { grid-column: auto / span 12 !important; display: block; }
}

/* *** */
.w-200 { font-weight: 200 !important; }
.w-500 { font-weight: 500 !important; }
.w-700 { font-weight: 700 !important; }

.heading {
	display: block; font-size: 2.5rem; font-weight: 700; line-height: 1.2; padding: 2rem 0; color: #fff;
}

.subtitle {
    display: block; font-size: 2.5rem; margin-bottom: 2.5rem; font-weight: 200; text-transform: uppercase; color: #fff;
}

.list > span {
    display: list-item; margin-bottom: 0.8rem; font-size: 1.3rem; margin-left: 3rem;
}

b > b.a {
    font-weight: 700; color: #fdd52d;
}

/* *** */
form {
    box-sizing: border-box;
}

form p {
    position: relative;
}

form p > label {
    font-size: 1.2rem; margin-bottom: 0.5rem; font-weight: 300; transition: all 0.2s ease; pointer-events: none;
}

form p > label.over {
    position: absolute; left: 1rem; top: 50%; transform: translateY(-55%);
}

form p > label > span {
    color: #f00; margin-left: 0.2rem;
}

form p > input, form p > select, form p > textarea {
    width: 100%; font-family: "Poppins"; background: #fff; border: 3px solid #fff; border-radius: 0.4rem;
    padding: 1.8rem 1rem 0.3rem 0.8rem; box-sizing: border-box; font-size: 1.2rem; box-shadow: 0 0 1rem rgba(0,0,0,0.25);
}

select option {
	font-family: "Poppins";
}

form p > input:focus, form p > select:focus, form p > textarea:focus {
    border: 3px solid #fa8; outline: none !important;
}

form p > input:focus + label, form p > input:not(:placeholder-shown) + label, form p > select + label, form p > textarea + label {
    font-size: 1.1rem; top: 1.5rem !important; transition: all 0.2s ease; color: #333;
}

.box {
    background: rgba(255,255,255,0.25); padding: 2.5rem 2rem; border-radius: 0.5rem;
	box-shadow: 0 0 2rem rgba(0,0,0,0.25);
}

.box.alt {
    background: rgba(0,0,0,0.30);
}

span.note {
	display: block; color: #000; margin-bottom: 2rem; font-size: 1em;
	border-left: 4px solid #000; padding-left: 1rem;
}

/* ** */
button {
    display: block; width: 100%; padding: 1rem 2rem 0.8rem 2rem; font-size: 1.3rem;
    background: #2dfdd5; border: none; border-radius: 1rem; border-bottom: 0.5rem solid #0dddb5;
}

button:active {
    padding: 1.3rem 2rem 0.8rem 2rem; border-radius: 1rem; border-top: 0.2rem solid rgba(0,0,0,0.5); border-bottom: none;
    background: #1dedc5;
}

button > * {
    display: inline-block; vertical-align: middle; font-family: "Poppins";
}

label:not(.over) {
    display: block; margin-bottom: 0.5rem; margin-top: 1.6rem !important;
}

label:not(.over) + select, label:not(.over) + textarea, label:not(.over) + input {
    padding: 0.5rem 1rem 0.5rem 0.8rem !important;
}

span.field-error {
    display: block; margin-top: -0.9rem; color: #f00;
    background: #ffeeee; padding: 0.5rem 1.0rem; border-radius: 0 0 0.5rem 0.5rem;
}

.x-hidden {
    display: none;
}

.message.success {
    background: #dfd; font-size: 1.3rem; padding: 2rem; color: #080;
    border-left: 14px solid #8f8; margin-bottom: 1rem;
    border-radius: 0.5rem;
}

.message.error {
    background: #fdd; font-size: 1.3rem; padding: 2rem; color: #800;
    border-left: 14px solid #f88; margin-bottom: 1rem;
    border-radius: 0.5rem;
}

.message.success:not(.x-hidden) + button {
    display: none !important;
}

.loading {
    text-align: center; background: #fff; padding: 0.8rem; border-radius: 1rem;
}

.loading > * {
    display: inline-block; vertical-align: middle;
}

.loading img {
    width: 3rem;
}

.loading span {
    font-size: 1.3rem; margin-left: 1rem;
}

r-form:not(.busy) .loading, r-form.busy button {
	display: none;
}
