/* --------- 

	TABLE OF CONTENTS

		RESET
		VARIABLES
		UTILITY
		ALL
		HEADER
		HEADER FINAL
		BREADCRUMBS
		CLUB
		DESTAQUES
		PLAN
		CONFIRM
		PLAN SUMMARY
		PAY
		PERSONAL DATA
		MB REF
		REDIRECT
		LEGAL
		SERVICES
		PASSWORD RECOVER
		PROMO REJOINER 
		FOOTER
		MODAL
		CARD
		QUERIES

 --------- */

/* --------- RESET --------- */
body,
p,
h1,
h2,
h3,
h4,
h5,
h6,
ul,
ol,
li {
	margin: 0;
	padding: 0;
}
img {
	max-width: 100%;
	display: block;
}
html {
	height: 100%;
}
* {
	margin: 0;
	padding: 0;
	box-sizing: border-box;
}

/* --------- VARIABLES --------- */
:root {
	--title-font: 'Lato', Helvetica, sans-serif;

	/* colors */
	--color-white: #ffff;
	--color-black: #222;
	--color-real-black: #000;
	--color-grey: #4d4d4d;
	--color-light-grey: #ededed;
	--color-blue: #06c;
	--color-light-blue: rgba(0, 123, 255, 0.25);
	--color-green: #99ffcc;
	--color-light-green: #c4fce5;
	--color-pastel: #faf7f2;
}

/* --------- UTILITY --------- */
.hidden {
	display: none !important;
}

.invisible {
	visibility: hidden;
}

.text-left {
	text-align: left;
}

/* --------- ALL --------- */
::selection {
	background: #06c;
	color: #fff;
}
::-moz-selection {
	background: #06c;
	color: #fff;
}

body {
	font-family: var(--title-font);
	font-size: 10px;
	-webkit-font-smoothing: antialiased;
	-moz-osx-font-smoothing: auto;
}

h1 {
	font-size: 2.5rem;
}

h2 {
	font-size: 1.2rem;
	font-weight: 900;
	letter-spacing: .5px;
}

main {
	padding-bottom: 60px;
}

/* buttons */
.btn {
	border-radius: 30px;
}

.btn:focus,
button:focus {
	border-color: rgba(0, 123, 255, 0.25);
	border-radius: 30px;
	box-shadow: 0 0 0 0.2rem rgba(0, 123, 255, 0.25);
	outline: none;
}

.btn-primary.disabled,
.btn-primary:disabled {
	background: var(--color-light-grey);
	border-color: var(--color-light-grey);
}

.btn-primary,
.nav-pills .nav-link.active,
.nav-pills .show > .nav-link {
	background: var(--color-blue);
	border-color: var(--color-blue);
}

.btn-primary:hover {
	background: var(--color-black);
	border-color: var(--color-black);
}

.btn-outline-primary {
	color: var(--color-blue);
	border-color: var(--color-blue);
}
.btn-outline-primary:hover {
	color: #fff;
	background: var(--color-blue);
}
.btn-group-sm > .btn,
.btn-sm {
	padding: .25rem 1rem;
}

/* form */
form {
	min-height: 260px;
	display: flex;
	flex-flow: column;
	justify-content: space-between;
}

form .form-control,
.custom-select {
	border-radius: 10px;
	border-color: var(--color-light-blue);
}

form .form-control::placeholder,
.custom-select::placeholder {
	color: var(--color-black);
}

/* alertas */
.alert {
	margin: 0;
	font-size: 1.4em;
}

.alert-danger {
	color: #222;
	background-color: #fff;
	border: 7px solid #ff6262;
	border-radius: 0;
}
.alert-success {
	color: #222;
	background-color: #fff;
	border: 7px solid #9fc;
	border-radius: 0;
}
.alert-info {
	color: #222;
	background-color: #fff;
	border: 7px solid #d9edf7;
	border-radius: 0;
}
.alert-warning {
	color: #222;
	background-color: #fff;
	border: 7px solid #faebcc;
	border-radius: 0;
}
.alert.alert-header {
	display: block;
	padding: 15px 20px;
	font-weight: bold;
	color: #fff;
	text-align: center;
	background-color: #222;
}

.no-d {
	-webkit-user-select: none;
	-webkit-user-drag: none;
	-webkit-app-region: no-drag;
}

/* boxes */
.box {
	border-radius: 20px;
	font-size: 1.4em;
}
.box.pastel {
	background: var(--color-pastel);
}
.box.white {
	background: var(--color-white);
	border: 4px solid var(--color-pastel);
}

.box .box-header,
.box .box-body {
	padding: 2rem;
	max-width: 24rem;
	margin: auto;
}
.box .box-header {
	border-bottom: 2px solid #fff;
	padding-bottom: 1rem;
}
.box h3 {
	color: var(--color-blue);
	text-align: center;
	font-size: 1.6em;
}

.box .logo {
	width: 8rem;
	margin: 1rem auto 2rem;
}

.box .icon {
	fill: var(--color-blue);
}

.box label {
	font-size: 1rem;
}

@media only screen and (min-width: 768px) {
	main > section:first-of-type {
		margin-top: 4rem;
	}
}

/* --------- HEADER --------- */
header#header {
	position: absolute;
	top: 0;
	left: 0;
	width: 100%;
	height: 60px;
	background-color: var(--color-white);
	padding: 10px;
	display: flex;
	align-items: center;
	justify-content: center;
	z-index: 3;
}

header#header svg {
	width: 60px;
	height: 60px;
	fill: var(--color-blue);
}

header#header h2 {
	font-size: 21px;
	color: var(--color-white);
	font-weight: 400;
	text-transform: uppercase;
	letter-spacing: .5px;
}

header#header div:last-of-type {
	text-align: right;
}

header#header p {
	font-size: 11px;
	font-weight: 400;
	color: #000;
	text-transform: uppercase;
	letter-spacing: .5px;
}

header#header p span {
	color: var(--color-white);
}

header#header .btn-call {
	color: #fff;
	font-size: .8rem;
	line-height: 1rem;
	text-align: left;
	letter-spacing: .5px;
	background: transparent;
	border: none;
	display: flex;
	justify-content: center;
	align-items: center;
}

header#header .btn-call span {
	font-size: 1rem;
	display: inline;
}

header#header .btn-call span strong {
	font-size: 1.5rem;
}

.title {
	text-align: center;
	margin: 1rem auto;
}
.title p {
	font-size: .8rem;
}
.title hr {
	width: 25%;
	margin: 0 auto;
	margin-bottom: .5rem;
	display: block;
	height: 1px;
	border: 0;
	border-top: 3px solid var(--color-blue);
}

.title .logo {
	width: 8rem;
	margin: .5rem auto 2rem;
}

@media (min-width: 768px) {
	header#header {
		position: fixed;
		width: unset;
		top: 20px;
		left: -13px;
		padding: 0;
	}

	header#header svg {
		width: 100px;
		height: 100px;
	}
}

/* --------- HEADER FINAL --------- */
#join header#header-final {
	background: var(--color-blue);
	text-align: center;
	color: var(--color-white);
	padding: 40px 0;
}

#join header#header-final svg {
	width: 100px;
	height: 100px;
	position: absolute;
	top: 0;
	left: 0;
	fill: var(--color-blue);
	margin-bottom: 1.5rem;
}

#join header#header-final .center {
	display: grid;
	place-content: center;
}

#join header#header-final h1 {
	font-size: 3rem;
	font-weight: 900;
	line-height: 1;
	letter-spacing: 1px;
	text-transform: uppercase;
	margin-bottom: .2rem;
}

#join header#header-final h2 {
	text-transform: uppercase;
	margin-bottom: 1rem;
	letter-spacing: 1px;
}

#join header#header-final p {
	font-size: 16px;
	font-weight: 400;
}

#join header#header-final .full {
	height: calc(100vh - 80px);
	display: flex;
	justify-content: center;
	align-items: center;
}

#join header#header-final .full > .row {
	width: 100%;
}

#join header#header-final .full .flex {
	display: flex;
	flex-flow: column;
	justify-content: center;
}

#join #final-form .card,
#join #summary .card {
	border-radius: 20px;
	border: 4px solid var(--color-pastel);
}

#join #final-form .card {
	min-height: 460px;
	border: none;
	box-shadow: 0px 30px 50px -25px rgba(0, 0, 0, 0.3);
}

#join #final-form label {
	display: flex;
	align-items: center;
	justify-content: space-between;
	font-size: 1rem;
}

#join #final-form label a {
	height: 30px;
}

#join #final-form label button {
	padding: 0;
}

#join #final-form label svg {
	width: 30px;
	height: 30px;
	fill: var(--color-light-blue);
	transition: all, .3s;
}

#join #final-form label svg:hover {
	fill: var(--color-blue);
}

#join #summary .card ul {
	list-style: none;
	margin-bottom: 2rem;
}

#join #summary .card ul li {
	display: flex;
	justify-content: space-between;
	border-bottom: 1px solid var(--color-light-blue);
	padding: 3px;
	font-size: 14px;
}

#join #summary .card ul li span:first-of-type {
	width: calc(100% / 3);
}

#join #summary .card ul li span:last-of-type {
	margin-left: .5rem;
	width: calc((100% / 3) * 2);
}

/* final form v2 */
#join #final-form .card-header {
	background: var(--color-pastel);
	border: none;
	display: flex;
	align-items: center;
	justify-content: center;
	padding: 1rem 4rem 0;
}
#join #final-form .card-header svg {
	fill: var(--color-blue);
	width: 8rem;
	height: 8rem;
}

#join #final-form .card-body {
	display: flex;
	align-items: center;
	justify-content: center;
	flex-flow: column;
	background: var(--color-pastel);
	text-align: center;
	padding: 0 4rem;
}

#join #final-form .card-body h2 {
	font-size: 1.8em;
	color: var(--color-blue);
}
#join #final-form .card-body p {
	font-size: 1rem;
}
#join #final-form .card-body form {
	margin-top: 1rem;
}

#join #final-form .card-footer {
	background: var(--color-pastel);
	padding: 2rem 6rem;
}

@media only screen and (min-width: 768px) {
	#join header#header-final {
		text-align: left;
	}
}

/* --------- BREADCRUMBS --------- */
#breadcrumbs {
	margin: 60px 0 40px;
}

.breadcrumbs {
	display: table;
	list-style-type: none;
	table-layout: fixed;
	width: 100%;
	margin-top: 1rem;
}

.breadcrumbs__text {
	position: relative;
	text-decoration: none;
	color: var(--color-light-grey);
	font-size: .6rem;
	letter-spacing: 1px;
	text-transform: uppercase;
}

@media (min-width: 768px) {
	#breadcrumbs {
		padding: 20px 0;
		margin: 0 auto;
	}
	.breadcrumbs__text {
		font-size: .75rem;
	}
}

.breadcrumbs__icon {
	position: relative;
	display: block;
	top: -2px;
	height: 20px;
	width: 20px;
	margin: 0 auto -11px;
	left: 0;
	right: 0;
	background-color: #fff;
	border: 2px solid var(--color-white);
	border-radius: 50%;
	color: #fff;
	z-index: 1;
}

.breadcrumbs__icon svg {
	width: 30px;
	height: 30px;
	fill: var(--color-pastel);
	position: absolute;
	top: 1px;
	left: 1px;
	transform: translate(-28%, -24%);
}

.breadcrumbs__track--completed .breadcrumbs__text,
.breadcrumbs__track--current .breadcrumbs__text {
	color: var(--color-blue);
}

.breadcrumbs__link {
	text-decoration: none;
	display: block;
	width: 100%;
}

.breadcrumbs__track {
	display: table-cell;
	line-height: 2em;
	position: relative;
	text-align: center;
	border-bottom: 2px solid var(--color-pastel);
}

.breadcrumbs__track--completed {
	border-bottom: 2px solid var(--color-blue);
}

.breadcrumbs__track--completed .breadcrumbs__icon {
	border: 3px solid var(--color-white);
	background-color: var(--color-white);
	cursor: pointer;
}

.breadcrumbs__track--completed .breadcrumbs__icon svg {
	fill: var(--color-blue);
}

.breadcrumbs__track--current {
	border-bottom: 2px solid var(--color-blue);
}

.breadcrumbs__track--current .breadcrumbs__icon svg {
	fill: var(--color-blue);
}

.breadcrumbs__track--current:after {
	content: "";
	display: block;
	position: absolute;
	width: 50%;
	background: var(--color-pastel);
	top: 43px;
	right: 0;
	height: 2px;
}

.breadcrumbs__track:first-child:before,
.breadcrumbs__track:last-child:before {
	position: absolute;
	width: 50%;
	background: var(--color-white);
	top: 42px;
	height: 4px;
	display: block;
	content: "";
}

.breadcrumbs__track:first-child:before {
	left: 0;
}

.breadcrumbs__track:last-child:before {
	right: 0;
	z-index: 1;
}

/* --------- CLUB --------- */
#club .club-info {
	background: var(--color-pastel);
	border-radius: 20px;
	padding: .5rem;
}

#club .club-info .row {
	visibility: hidden;
}
#club .club-info.show .row {
	visibility: visible;
}

#club .club-info ul {
	list-style-type: none;
	color: var(--color-grey);
	font-size: .75rem;
}

#club .club-info ul li {
	display: flex;
	align-items: center;
	width: 100%;
}

#club .club-info ul li span:first-child {
	width: 40px;
}

#club .club-info ul li span {
	width: calc(100% - 40px);
}

#club .club-info ul li svg {
	display: inline-block;
	margin-right: 10px;
	line-height: 1.5;
	width: 30px;
	height: 30px;
	fill: var(--color-blue);
}

#club #banner img {
	border-radius: 10px;
	margin-bottom: 2rem;
}

/* --------- PLAN --------- */

#plan .nav-tabs {
	border: none;
}

#plan .nav-link {
	margin-bottom: 2rem;
	border-radius: 30px;
	transition: all .3s;
	font-size: 1.4em;
}

#plan .nav-link:hover {
	background: var(--color-blue);
	color: var(--color-white);
}

#plan #nav-tabContent form .select-form {
	width: 100%;
	margin: 0 auto;
}

#plan #nav-um-treino .card,
#plan #nav-nutricao .card {
	text-align: center;
	border: 3px solid var(--color-pastel);
	background: var(--color-pastel);
	border-radius: 20px;
	width: 100%;
	margin: 1rem auto;
}

#plan #nav-tabContent .card h1 {
	font-size: 1.2rem;
	letter-spacing: 1px;
	text-transform: uppercase;
	font-weight: 900;
	color: var(--color-blue);
}

#plan #nav-tabContent .card ul {
	list-style: none;
	text-align: left;
	margin-top: 1rem;
}
#plan #nav-tabContent .card li svg {
	width: 1rem;
	height: 1rem;
	fill: var(--color-blue);
}

#plan #nav-tabContent .card hr {
	border: 1.5px solid var(--color-blue);
	width: 30%;
	margin: .5rem auto;
}

#plan #nav-tabContent .card a.btn {
	padding: 3px 15px;
}

#plan #nav-tabContent .card p.price {
	font-size: 1.5rem;
	font-weight: 900;
	margin-top: 1rem;
}

#plan #nav-tabContent .card ul.partners {
	display: flex;
	flex-wrap: wrap;
}

#plan #nav-tabContent .card ul.partners li {
	width: calc(100% / 2);
	padding: 4px;
}

#plan #nav-tabContent .card ul.partners li img {
	border-radius: 10px;
	filter: grayscale(1);
	transform: scale(.95);
	transition: all, .3s;
}

#plan #nav-tabContent .card ul.partners li:hover img {
	filter: grayscale(0);
	transform: scale(1);
	box-shadow: 0 0 10px #9e9e9e;
}

/* --------- DESTAQUES --------- */

.destaques {
	width: 100%;
	margin: 1rem auto;
	z-index: 2;
	background: var(--color-white);
	border-radius: 30px;
	padding: 1rem;
}

.destaques h2 {
	margin-bottom: 1rem;
}

.destaques button {
	width: 100%;
	padding: 5px 5px 5px 20px;
	border: none;
	border-radius: 30px;
	border: 1px solid var(--color-light-blue);
	text-align: left;
	line-height: 1.3;
	letter-spacing: .2px;
	display: flex;
	align-items: center;
	justify-content: space-between;
	color: var(--color-blue);
	background-color: var(--color-pastel);
	margin-top: .5rem;
}

.destaques button svg {
	width: 40px;
	height: 40px;
	margin-left: 10px;
	fill: var(--color-light-blue);
	opacity: .7;
	transform: rotate(45deg);
	transition: all, .2s;
}

.destaques button[aria-expanded="true"] {
	border-bottom-left-radius: 0;
	border-bottom-right-radius: 0;
	border-bottom-color: var(--color-pastel);
}

.destaques button[aria-expanded="true"] svg {
	transform: rotate(90deg);
}

.destaques .collapse {
	width: 100%;
	border: none;
	border-radius: 0 0 30px 30px;
	padding: 1rem 2rem;
	background-color: var(--color-pastel);
	line-height: 1.2;
	border: 1px solid var(--color-light-blue);
	border-top-color: var(--color-pastel);
}

.destaques .collapse ul {
	display: flex;
	flex-wrap: wrap;
	margin-top: .5rem;
	list-style: none;
}

.destaques .collapse ul li {
	padding: 5px 10px;
	margin: 5px;
	border: 3px solid var(--color-white);
	border-radius: 10px;
	transition: all, .3s;
}

.destaques .collapse ul li:hover {
	background-color: var(--color-grey);
	color: var(--color-white);
}

/* personalização do btn promo */
#promo {
	position: sticky;
	top: 0;
	left: 0;
}

#promo button {
	background-color: var(--color-black);
	border: 1px solid var(--color-black);
	color: var(--color-white);
	font-weight: 900;
}

#promo button svg {
	fill: var(--color-grey);
}

#promo .collapse {
	background: var(--color-black);
	color: var(--color-white);
	border: 1px solid var(--color-black);
	border-top-color: var(--color-black);
}

#promo .collapse p.lead {
	font-weight: 900;
	letter-spacing: .5px;
	margin-bottom: .5rem;
}

#promo .collapse p.rules {
	color: var(--color-light-grey);
	font-size: .7rem;
}

/* --------- PLAN --------- */
#plan #plan-display {
	margin: .5rem 0;
}
#plan #plan-display span.label {
	text-align: center;
	font-size: 12px;
	line-height: 1;
	letter-spacing: .5px;
	padding: .3rem 0;
	border: none;
	border-bottom: 1px solid var(--color-black);
	background-color: var(--color-white);
	display: block;
	width: 100%;
	transition: all, .3s;
}

#plan #plan-display span.label.off {
	opacity: .3;
}

#plan #plan-display .container {
	padding: 0;
}

#plan #plan-display .container .row > div {
	text-align: center;
}

#plan #plan-display .services {
	display: flex;
	flex-flow: column;
	margin-top: 36px;
	margin-right: 3px;
}

/* -------- OLD VERSION 
#plan #plan-display .services button,
#plan #plan-display .services span {
	font-size: 14px;
	color: var(--color-black);
	text-align: left;
	line-height: 1.2;
	background-color: transparent;
	border: none;
	border-bottom: 1px solid var(--color-light-blue);
	width: 100%;
	height: 30px;
	display: block;
	position: relative;
	transition: all, .3s;
}

#plan #plan-display .services button:first-of-type {
	border-top: 1px solid var(--color-light-blue);
}

#plan #plan-display .services span.promo {
	text-transform: uppercase;
	color: var(--color-blue);
	font-weight: 900;
	font-size: 14px;
	letter-spacing: .5px;
	display: flex;
	align-items: center;
	height: 33px;
}

#plan #plan-display .services span.price {
	height: 44px;
	display: flex;
	align-items: center;
}

-------- */

#plan #plan-display .services button,
#plan #plan-display .services span {
	font-size: 13px;
	color: var(--color-blue);
	text-align: center;
	line-height: 1.2;
	background-color: var(--color-pastel);
	border: 1px solid var(--color-pastel);
	width: 100%;
	height: 24px;
	display: block;
	position: relative;
	transition: all, .3s;
	border-radius: 15px;
	margin: 2px 0;
	display: flex;
	justify-content: center;
	align-items: center;
	z-index: 2;
}

#plan #plan-display .services .promo {
	text-transform: uppercase;
	color: var(--color-white);
	background: var(--color-black);
	font-weight: 900;
	font-size: 14px;
	letter-spacing: .5px;
	display: flex;
	align-items: center;
	justify-content: center;
}

#plan #plan-display .services span.price {
	height: 40px;
	display: flex;
	align-items: center;
	justify-content: center;
	color: var(--color-black);
	background: var(--color-white);
	border-color: var(--color-white);
}

#plan #plan-display .services button:hover {
	text-decoration: none;
	color: var(--color-white);
	background: var(--color-blue);
	transform: scale(1.2);
	box-shadow: 0 0 10px 2px rgba(96, 125, 139, 0.3);
}

#plan #plan-display .services button:hover svg {
	fill: var(--color-pastel);
}

/* -------- OLD VERSION 
#plan #plan-display .services button svg {
	width: 12px;
	height: 12px;
	position: absolute;
	top: 50%;
	right: 0;
	transform: translateY(-50%);
	fill: var(--color-grey);
}
-------- */

#plan #plan-display .services button svg {
	width: 20px;
	height: 20px;
	position: absolute;
	top: 50%;
	right: 0;
	transform: translateY(-50%) rotate(45deg);
	fill: var(--color-white);
}

#plan #plan-display .services button.promo svg {
	fill: var(--color-grey);
	transition: all, .3s;
}

#plan #plan-display .services button.promo:hover svg {
	fill: var(--color-pastel);
}

#plan #plan-display .btn {
	padding: 0 !important;
	line-height: 1;
}

#plan #plan-display .package > span:first-of-type {
	display: block;
	padding: 0;
}

#plan #plan-display .package > span:last-of-type {
	border-bottom: none;
	display: block;
	padding: 0 10px 10px 10px;
}

#plan #plan-display .package span > span {
	display: flex;
	align-items: center;
	justify-content: center;
	height: 28px;
	border-bottom: 1px solid var(--color-light-blue);
	font-size: .9rem;
	line-height: 1;
	text-transform: uppercase;
	letter-spacing: .5px;
}

#plan #plan-display .package .check label {
	margin: 0;
}

#plan #plan-display .package .check svg,
#plan #plan-display .package .class svg {
	width: 25px;
	height: 25px;
}

#plan #plan-display .package .check input {
	display: none;
}

#plan #plan-display .package .check input + label {
	width: 26px;
	height: 26px;
	border: 1px solid var(--color-grey);
	background: var(--color-white);
	border-radius: 8px;
}

#plan #plan-display .package .check input:checked + label {
	content: url("../img/icones/sprite/i-x-check.svg");
	border-color: var(--color-black);
}

#plan #plan-display .package .shop {
	max-height: 50px;
	display: none;
}

#plan #plan-display .package .shop svg {
	fill: var(--color-blue);
	width: 50px;
	height: 50px;
	opacity: .2;
}

#plan #plan-display .package.active .shop svg {
	opacity: 1;
}

#plan #plan-display .package .pricing {
	display: flex;
	flex-flow: column;
	height: 44px;
}

#plan #plan-display .package .price {
	font-size: 20px;
	font-weight: 900;
	border-bottom: none;
	height: 24px;
}

#plan #plan-display .package .promo {
	color: var(--color-grey);
	height: 20px;
	border-bottom: none;
}

#plan #plan-display .package .promo-time {
	flex-flow: column;
}
#plan #plan-display .package .promo-time > span {
	border: none;
}
#plan #plan-display .package .promo-time > span:nth-child(2) {
	font-size: .7rem;
}

#plan #plan-display .btn-group {
	width: 100%;
}

#plan #plan-display .btn-group .package {
	display: block;
	width: calc(100% / 3);
	margin-bottom: 0;
	color: var(--color-grey);
	border-radius: 12px;
	border-color: var(--color-white);
	opacity: .7;
}

#plan #plan-display .btn-group .package.active {
	color: var(--color-black);
	background: var(--color-blue);
	opacity: 1;
}

#plan #plan-display .package.active span > span {
	color: var(--color-white);
	border-bottom-color: var(--color-light-blue);
}

#plan #plan-display .package.active .check svg,
#plan #plan-display .package.active .class svg {
	fill: var(--color-white);
}

#plan #plan-display .package .check svg.promo-1,
#plan #plan-display .package.active .check svg.promo-1 {
	fill: #00bcd4;
}

#plan #plan-display .package .check svg.promo-2,
#plan #plan-display .package.active .check svg.promo-2 {
	fill: #ff5722;
}

#plan #plan-display .btn-group .package input[type=radio] {
	display: none;
}

#plan #plan-display .btn-group .package button.promo-label {
	position: absolute;
	top: 0;
	left: 50%;
	width: 70%;
	height: 18px;
	background-color: var(--color-black);
	color: var(--color-white);
	font-size: 10px;
	font-weight: 900;
	text-transform: uppercase;
	border-radius: 11px;
	border: none;
	transform: translate(-50%, -50%);
}

#plan #plan-display .btn-group .package button.promo-label.show {
	opacity: .5;
}

#plan #plan-display .btn-group .package span.name {
	font-weight: 900;
	font-size: 1.2rem;
	line-height: 1;
	padding-top: 10px;
	margin-bottom: .5rem;
	text-transform: uppercase;
	border-bottom: none;
	display: block;
}

#plan #plan-display .btn-group .package span.name > span {
	font-size: 1rem;
	display: inline;
}

#plan #plan-display .btn-group .package.active span.name {
	color: var(--color-white);
}

#plan #plan-display .btn-group .package.active span.time {
	color: var(--color-white);
}

#plan .nutri-info p {
	color: var(--color-grey);
	font-size: 13px;
	line-height: 1.2;
	letter-spacing: .2px;
	margin-top: 1rem;
	text-align: center;
}

#plan .label-price {
	font-size: .8rem;
	color: var(--color-blue);
	background: var(--color-pastel);
	border-radius: 10px;
	padding: 2px;
}

#plan .label-price svg {
	width: 20px;
	height: 20px;
	fill: var(--color-blue);
	transform: rotate(-90deg);
}
#join.confirm .alert,
#plan .alert {
	font-size: .8rem;
	line-height: 1.2;
	text-align: center;
	border: none;
	transition: .5s;
}

#plan .alert.alert-danger {
	background: #ffeae8;
	border-radius: .5em;
}
#plan .alert.alert-success {
	background: #d3f7e5;
	border-radius: 1em;
}

#promo-field {
	border: 4px solid var(--color-pastel);
	border-radius: 20px;
	padding: 2rem;
}

#promo-field label {
	font-size: 1.4em;
}

#promo-field .card {
	border: 1px solid var(--color-grey);
	max-width: 18rem;
}

#promo-field .card label {
	font-size: 1em;
	text-transform: uppercase;
	padding: .25rem 2rem;
	margin-top: 1rem;
}
#promo-field .card label.active {
	background: #000;
}

#promo-field .code-list {
	list-style: none;
	font-size: 1.4em;
	margin-top: 2rem;
}

#promo-field .code-list li {
	border-top: 1px solid var(--color-light-grey);
	border-bottom: 1px solid var(--color-light-grey);
	padding: .2rem 0;
	display: flex;
	align-items: center;
	justify-content: space-between;
}

#promo-field .code-list li button svg {
	width: 1rem;
	height: 1rem;
}

#join.confirm .alert {
	background-color: var(--color-black);
	border-color: var(--color-blue);
	color: var(--color-light-grey);
}

#ex-member .box-body {
	display: flex;
	align-items: center;
	justify-content: center;
}

@media only screen and (min-width: 768px) {
	#plan #plan-display {
		border: 4px solid var(--color-pastel);
		border-radius: 20px;
		padding: 1rem;
		margin: 1rem auto;
		width: 100%;
	}
}

/* --------- CONFIRM --------- */
#join.confirm {
	background-color: var(--color-black);
}

#join.confirm main {
	padding: 0;
}

#join.confirm .title {
	color: var(--color-white);
	margin: 1rem auto .5rem;
}

#join.confirm h1 {
	text-transform: uppercase;
	font-weight: 900;
	font-size: 1.5rem;
	line-height: 1;
	text-align: center;
	margin-bottom: .2rem;
}

#join.confirm h1 span {
	font-weight: 200;
	opacity: .6;
	border: none;
}

#join.confirm h3 {
	font-size: 1rem;
	font-weight: 900;
	text-align: center;
	margin-bottom: .2rem;
}

#join.confirm .card {
	border-radius: 15px;
}

#join.confirm .card .card-header {
	text-align: center;
	background-color: var(--color-white);
	border: none;
}

#join.confirm .card .card-header:first-of-type {
	border-radius: 15px;
}

#join.confirm .card .card-body {
	padding: 1rem 2rem;
	z-index: 1;
}

#join.confirm .card .card-body > span {
	display: flex;
	justify-content: space-between;
	align-items: center;
	border-bottom: 1px solid var(--color-light-blue);
	height: 26px;
	font-size: 14px;
}

#join.confirm .card .card-body > span:first-of-type {
	border-top: 1px solid var(--color-light-blue);
}

#join.confirm .card .card-body > span svg {
	width: 24px;
	height: 24px;
}
#join.confirm .card .card-body > span > span {
	line-height: 1;
	text-transform: uppercase;
	font-size: 14px;
}

#join.confirm .card.addons {
	z-index: 1;
}

#join.confirm .card.addons .card-body > span > span > span {
	font-size: .8rem;
	color: var(--color-blue);
}

#join.confirm .card.addons .card-body > span > span {
	text-transform: unset;
}

#join.confirm .card.promo {
	background: var(--color-white);
	border: none;
}

#join.confirm .card.promo .card-header {
	background-color: var(--color-pastel);
	color: var(--color-blue);
	text-transform: uppercase;
	padding: 0;
	font-weight: 900;
	display: flex;
	justify-content: center;
	align-items: center;
	letter-spacing: 1px;
	line-height: 1.2;
	padding: 5px 1rem;
}

#join.confirm .card.promo .card-header svg {
	width: 25px;
	height: 25px;
	fill: var(--color-blue);
}

#join.confirm .card.promo .card-body {
	display: flex;
	flex-flow: row;
	padding: 14px 20px;
}

#join.confirm .card.promo .card-body > span {
	display: flex;
	flex-flow: column;
	justify-content: center;
	color: var(--color-black);
	border: none;
	height: 50px;
	text-align: center;
}

#join.confirm .card.promo .card-body > span:nth-of-type(odd) {
	border-left: 1px solid var(--color-light-grey);
	border-right: 1px solid var(--color-light-grey);
}

#join.confirm .card.promo .card-body span button {
	border-radius: 30px;
	border: 1px solid var(--color-black);
	padding: 2px 10px;
	margin: 2px;
	transition: all, .2s;
	line-height: 1;
}

#join.confirm .card.promo .card-body span button:hover {
	background: var(--color-black);
	color: var(--color-white);
}

/* one column */
#join.confirm .card.promo .card-body.one-column > span {
	width: 100%;
}

/* two columns */
#join.confirm .card.promo .card-body.two-columns > span {
	width: calc(100% / 2);
}

#join.confirm .card.promo .card-body.two-columns > span:nth-of-type(even) {
	border-right: 1px solid var(--color-light-grey);
}

/* three columns */
#join.confirm .card.promo .card-body.three-columns > span {
	width: calc(100% / 3);
}

#join.confirm .card.promo .card-body > span > span {
	font-size: 12px;
	line-height: 1.2;
	letter-spacing: .5px;
	text-transform: unset;
}

#join.confirm .card.promo .card-body > span .price {
	font-weight: 900;
	font-size: 24px;
	display: flex;
}

#join.confirm .card.promo .card-body > span .price span {
	font-size: .8rem;
	margin-top: 2px;
}

#join.confirm .card.promo .card-body > span .promo {
	font-size: 1rem;
	font-weight: 900;
	text-transform: uppercase;
}

#join.confirm .nutri-info p {
	color: var(--color-light-grey);
	font-size: 14px;
	line-height: 1.2;
	letter-spacing: .2px;
}

/* --------- PLAN SUMMARY --------- */
#plan-summary {
	width: 100%;
	padding: 1rem;
	background: var(--color-pastel);
	text-align: center;
	margin-top: 2rem;
}

#plan-summary h3 {
	font-size: 1.8em;
	font-weight: 700;
}

#plan-summary h3 span {
	color: var(--color-blue);
}
#plan-summary .board {
	background: var(--color-black);
	font-size: .85rem;
	color: var(--color-pastel);
	border-radius: .7rem;
	overflow: hidden;
	margin-top: 1rem;
}

#plan-summary .board > div {
	display: flex;
	align-items: center;
	justify-content: center;
}
#plan-summary .board > div > div {
	padding: .5rem;
	width: calc(100% / 3);
	border-right: 1px solid var(--color-blue);
}

#plan-summary .board > div > div:last-of-type {
	border-right: none;
}

#plan-summary .board span {
	display: block;
	letter-spacing: .5px;
	line-height: 1.2;
	margin-bottom: .5rem;
}

#plan-summary .board .price {
	font-size: 2em;
	font-weight: 700;
	line-height: 1;
	margin: 0;
}

#plan-summary .board span:last-of-type {
	font-weight: 800;
	text-transform: uppercase;
	letter-spacing: 1px;
}
#plan-summary .promo {
	text-transform: uppercase;
	font-weight: 800;
	color: #fff;
	background: var(--color-blue);
	padding: .5rem 1rem;
	justify-content: center !important;
}

#plan-summary .promo span {
	margin: 0;
}

#plan-summary .note {
	font-size: .8rem;
	margin-top: .5rem;
	line-height: 1.3;
}

@media only screen and (min-width: 768px) {
	#plan-summary {
		position: fixed;
		width: 13rem;
		top: 50%;
		right: -13rem;
		border-radius: 1rem;
		transform: translateY(-50%);
		margin: 0;
		transition: right 300ms ease-in-out;
	}

	#plan-summary.show {
		right: 6rem;
	}

	#plan-summary .board > div {
		width: 100%;
		border: none;
		border-bottom: 1px solid var(--color-blue);
		flex-flow: column;
	}
	#plan-summary .board > div > div {
		width: 100%;
	}
}

/* --------- PAY --------- */
#join #pay .pack.card {
	border: none;
	margin-bottom: 1rem;
}

#join #pay .pack .card-body {
	border: 4px solid var(--color-pastel);
	border-radius: 20px;
	padding: 0;
}

#join #pay .pack .card-body > div:first-of-type {
	background-color: var(--color-pastel);
}

#join #pay .pack .card-body > div:last-of-type {
	padding: 1rem;
}

#join #pay .pack .card-body svg {
	fill: var(--color-blue);
	width: 80px;
	height: 80px;
}

#join #pay .alert {
	border-top: 4px solid var(--color-pastel);
	font-size: .8rem;
	padding: .5rem;
}

#join #pay .box {
	min-height: 14rem;
}

@media only screen and (min-width: 768px) {
	#join #pay .pack .card-body svg {
		width: 100px;
		height: 120px;
	}
}

/* --------- PERSONAL DATA --------- */
#join label {
	display: flex;
	align-items: center;
	justify-content: space-between;
	font-size: 1rem;
}

#join #personal-data label a {
	height: 30px;
}

#join #personal-data label button {
	fill: var(--color-light-blue);
	padding: 0;
	transition: all, .3s;
}

#join #personal-data label svg {
	width: 30px;
	height: 30px;
	fill: var(--color-light-blue);
	transition: all, .3s;
}

/* --------- MB REF --------- */
#join #mb-ref .card {
	border: 4px solid var(--color-white);
	border-radius: 20px;
	box-shadow: 0 0 10px 2px rgba(96, 125, 139, 0.3);
}

#join #mb-ref .card span {
	display: block;
}

#join #mb-ref .card span:first-of-type {
	margin-top: 0;
}

#join #mb-ref .card span:nth-of-type(odd) {
	margin-top: .5rem;
	color: var(--color-grey);
}

#join #mb-ref .card span:nth-of-type(even) {
	font-size: 1.5rem;
	font-weight: 700;
	color: var(--color-blue);
	letter-spacing: 2px;
	background-color: var(--color-pastel);
	padding: .5rem;
	text-align: center;
	margin-top: .5rem;
}

#join #mb-ref p {
	font-size: .8rem;
}

#join #mb-ref svg {
	fill: var(--color-grey);
	max-width: 100px;
	display: block;
	margin-bottom: 1rem;
}

/* --------- REDIRECT --------- */
#join #redirect {
	font-size: 1rem;
}

#join #redirect img {
	width: 60%;
}

@media only screen and (min-width: 768px) {
	#join #redirect {
		text-align: center;
	}
	#join #redirect img {
		width: 40%;
		margin: 0 auto;
	}
}

/* --------- LEGAL --------- */
#join #legal .card {
	border-radius: 20px;
	box-shadow: none;
	font-size: 1.6em;
}

#join #send-by-mail,
#join #send-by-mail.show {
	transition: all 300ms ease-out;
}

#join #legal label {
	display: block;
}

/* --------- SERVICES --------- */
#join #services p {
	line-height: 1;
	font-size: 1.4em;
}
#join #services p small {
	color: var(--color-blue);
}

#join #services .gallery {
	display: flex;
	justify-content: flex-start;
	flex-wrap: wrap;
}

#join #services .gallery > button {
	width: calc(96% / 2);
	border-radius: 10px;
	line-height: 1;
	color: var(--color-grey);
	padding: .5rem;
	display: flex;
	flex-flow: column;
	align-items: center;
	transition: all, .3s;
}

#join #services .gallery > button:hover {
	background: var(--color-pastel);
	transform: scale(1.1);
	box-shadow: 0 0 10px 2px rgba(96, 125, 139, 0.3);
}

#join #services .gallery > button svg {
	fill: var(--color-blue);
	width: 100px;
	height: 100px;
}

#join #services .gallery > button span {
	font-size: .7rem;
	line-height: 1.2;
	letter-spacing: 1px;
	color: var(--color-blue);
	text-transform: uppercase;
}

#join #services .partners .gallery > button svg {
	fill: var(--color-black);
}

#join .server-connect {
	border: 5px solid var(--color-pastel);
	border-radius: 20px;
	box-shadow: none;
}

#join .server-connect img {
	width: 50%;
	margin: 0 auto;
}

#join .server-connect svg {
	fill: var(--color-blue);
}

#join .server-connect.danger {
	border: 5px solid #ffebee;
}
#join .server-connect.danger svg {
	fill: #ef5350;
}

@media only screen and (min-width: 768px) {
	#join #services .gallery > button {
		width: calc(96% / 3);
	}

	#join .server-connect img {
		width: 30%;
	}
}

/* --------- PASSWORD RECOVER --------- */
#password-recover {
	padding: 1rem 0;
	display: flex;
	align-items: center;
	height: 100vh;
}

#password-recover .box {
	width: 90%;
	max-width: 800px;
	padding: 1rem;
	margin: auto;
	min-height: calc(100vh - 100px);
	display: flex;
	flex-flow: column;
	align-items: center;
	justify-content: center;
}

#password-recover .box .logo {
	margin: 1rem auto;
}

#password-recover form {
	min-height: unset;
	margin-top: 2rem;
}

@media only screen and (min-width: 768px) {
	#password-recover {
		padding: 0;
		height: calc(100vh - 160px);
		display: flex;
		align-items: center;
		justify-content: center;
	}

	#password-recover .box {
		padding: 2rem 12rem;
		min-height: calc(100vh - 240px);
	}
}

/* --------- PROMO REJOINER --------- */
#final-promo .card {
	position: relative;
	text-align: center;
	padding: 0;
	background: var(--color-pastel);
	/* background-image: linear-gradient(to left bottom, #222222, #1b1b1b, #151515, #0c0c0c, #000000); */
	box-shadow: 0px 30px 50px -25px rgba(0, 0, 0, 0.3);
}

#final-promo .card h2 {
	font-size: 3em;
}

#final-promo .card p {
	font-size: 1rem;
}

#final-promo .card .card-header {
	border: none;
	background: var(--color-pastel);
	padding-bottom: 0;
}

#final-promo .card .card-header p {
	width: 100%;
	max-width: 20rem;
	line-height: 1.3;
	margin: auto;
}

#final-promo .card .card-body {
	padding: 0;
}
#final-promo .card .slick {
	width: 100%;
	margin: auto;
}

#final-promo .card #drawer {
	position: absolute;
	width: 100%;
	height: 100%;
	top: 100%;
	left: 0;
	font-size: 1.6em;
	color: var(--color-black);
	background: var(--color-pastel);
	z-index: 1;
	display: grid;
	place-items: center;
	transition: top 200ms ease-in-out;
}
#final-promo .card #drawer.show {
	top: 0;
}

#final-promo .card #drawer > div {
	width: 80%;
	max-width: 22rem;
}
#final-promo .card #drawer > .btn-close {
	width: 1.5em;
	height: 1.5em;
	position: absolute;
	top: 1em;
	right: 1em;
}
#final-promo .card #drawer > .btn-close svg {
	width: 1.5em;
	height: 1.5em;
	fill: var(--color-blue);
	position: absolute;
	top: 0;
	left: 0;
}

#final-promo .card #send form {
	text-align: left;
}
#final-promo .card #send form svg,
#final-promo .card #message svg {
	fill: var(--color-blue);
	width: 6rem;
	height: 6rem;
	margin: auto;
}
#final-promo .card #send .custom-control-label {
	font-size: .7rem;
	line-height: 1.2;
}
#final-promo .promo-card {
	width: 90%;
	margin: 1rem 2rem;
	background: var(--color-white);
	border-radius: 2em;
	overflow: hidden;
	position: relative;
	box-shadow: 0 0 20px rgba(119, 115, 108, 0.2);
}

#final-promo .promo-card:focus {
	outline: 0;
}

#final-promo .promo-card_header {
	height: 10rem;
	padding: 1em;
	display: grid;
	place-items: center;
	background-image: radial-gradient(circle, #43a1ff, #3592f3, #2783e6, #1774d9, #0066cc);
	background-image: radial-gradient(circle, #f5bb56, #f3aa48, #f1993b, #ef8632, #ec732b);
}

#final-promo .promo-card_body {
	padding: 1em;
}
#final-promo .promo-card_footer {
	padding: 0 1em;
	display: flex;
	flex-flow: column;
	align-items: center;
	justify-content: center;
}

#final-promo .promo-card h3 {
	font-size: 2em;
	font-weight: 800;
	text-transform: uppercase;
}

#final-promo .promo-card h3,
#final-promo .promo-card p,
#final-promo .promo-card h2 {
	color: var(--color-black);
	line-height: 1;
}

#final-promo .promo-card input {
	text-align: center;
	font-size: 1.6rem;
	font-weight: 800;
	padding: .2em 1em;
	border-radius: .5em;
	border: 1px solid var(--color-blue);
	width: 90%;
	margin: .3em auto 0;
}

#final-promo .promo-card input:focus {
	background: var(--color-white);
	outline: 0;
}

#final-promo .promo-card.used::after {
	content: 'Usada';
	color: var(--color-pastel);
	font-size: 4em;
	font-weight: 800;
	background: rgba(0, 0, 0, 0.5);
	display: flex;
	align-items: flex-end;
	justify-content: center;
	padding: .75em;
	width: 100%;
	height: 100%;
	position: absolute;
	top: 0;
	left: 0;
	text-transform: uppercase;
	letter-spacing: 1px;
	text-shadow: 0 0 50px black;
}

#final-promo .promo-card.used .btn {
	opacity: 0;
}

#final-promo .promo-card.used h2,
#final-promo .promo-card.used h3,
#final-promo .promo-card.used p {
	opacity: .3;
}

#final-promo .promo-card.promo-card_footer button {
	visibility: hidden;
}

#final-promo .slick-dots {
	display: flex;
	align-items: center;
	justify-content: center;
	list-style: none;
	position: relative;
	top: -1rem;
	/* margin-bottom: 1rem; */
}

#final-promo .slick-dots li {
	padding: .3em;
}

#final-promo .slick-dots button {
	border: none;
	font-size: 1px;
	color: var(--color-blue);
	background: var(--color-blue);
	border-radius: 10em;
	width: 10em;
	height: 10em;
	opacity: .2;
}

#final-promo .slick-dots .slick-active button {
	opacity: 1;
}

.info-pop {
	width: 13rem;
	height: 3rem;
	position: absolute;
	left: 50%;
	bottom: -4rem;
	transform: translateX(-50%);
	color: var(--color-white);
	font-size: 1rem;
	display: flex;
	align-items: center;
	justify-content: center;
	background: var(--color-black);
	border-radius: .5em;
	z-index: 1;
	box-shadow: 0px 5px 10px rgba(0, 0, 0, 0.5);
	transition: bottom 300ms ease-in-out;
}

.info-pop svg {
	width: 3rem;
	height: 3rem;
	fill: #fff;
	margin-right: 1rem;
}
.info-pop.show {
	bottom: 2rem;
}
@media only screen and (min-width: 768px) {
	#final-promo .card {
		height: 460px;
	}
	#final-promo .card .slick {
		width: 20rem;
	}
}

/* --------- FOOTER --------- */
#join footer {
	text-align: center;
	font-size: .7rem;
	border-top: 1px solid var(--color-light-grey);
	color: var(--color-grey);
	background: var(--color-white);
	padding: .5rem 1rem;
	width: 100%;
	height: 50px;
	/* position: fixed; */
	/* bottom: 0; */
	/* left: 0; */
	z-index: 1;
}

#join footer a {
	color: var(--color-grey);
	text-decoration: underline;
}

#join footer.fixed {
	position: fixed;
	width: 100%;
	bottom: 0;
	left: 0;
}

/* --------- MODAL --------- */
.modal-open .modal {
	background: rgba(255, 255, 255, 0.9);
}

#join .modal.show .modal-dialog {
	max-width: 90%;
	margin: 1rem auto;
}

#join .modal-open:focus .modal {
	box-shadow: none !important;
}
#join .modal .modal-content {
	border-radius: 20px;
	border: none;
	font-size: 1.6em;
}

#join .modal .modal-header,
#join .modal .modal-footer {
	border: none;
	border-color: var(--color-pastel);
}

#join .modal .modal-header {
	padding: 0;
	background: var(--color-pastel);
	border-top-left-radius: 20px;
	border-top-right-radius: 20px;
}
s #join .modal .modal-header button,
#join .modal .modal-header .close {
	padding: 0;
	margin: 0 0 0 auto;
}

#join .modal .modal-header svg {
	width: 40px;
	height: 40px;
	fill: var(--color-light-blue);
	transition: all, .3s;
}

#join .modal .modal-header svg:hover {
	fill: var(--color-blue);
}

#join .modal .modal-footer {
	justify-content: center;
	padding-top: 0;
}

#join .modal .modal-body {
	padding: 0;
	text-align: center;
}

#join .modal .modal-body > div:first-of-type {
	background: var(--color-pastel);
	display: flex;
	justify-content: center;
	align-items: center;
}
#join .modal .modal-body > div:last-of-type {
	padding: 1rem;
}

#join .modal .modal-body > div:first-of-type span {
	display: flex;
	flex-flow: column;
	align-items: center;
}

#join .modal .modal-body h2 {
	margin: .5rem 0;
}

#join .modal .modal-body h3 {
	font-size: .8rem;
	color: var(--color-blue);
	text-transform: uppercase;
	letter-spacing: 2px;
	margin-bottom: 1rem;
}

#join .modal .modal-body a.btn {
	padding: .25rem 1rem;
}

#join .modal .modal-body svg {
	fill: var(--color-blue);
	display: block;
	height: 90px;
	width: 90px;
}

#join .modal .modal-body .card {
	border-radius: 20px;
	border: 4px solid var(--color-white);
	box-shadow: none;
	font-size: 1rem;
}

#join .modal .modal-body .card .card-body {
	padding: 1rem;
}

#join .modal .modal-body ul {
	display: flex;
	flex-wrap: wrap;
	list-style: none;
	margin-top: .5rem;
	justify-content: center;
}

#join .modal .modal-body ul li {
	border: 4px solid var(--color-pastel);
	border-radius: 10px;
	padding: 3px 10px;
	margin: 5px;
}

#join .modal .modal-body ul.list-group li {
	border: none;
}

#join .modal .modal-body .notas {
	font-size: .8rem;
	line-height: 1.2;
}

/* modal promo */
#join #m-promo .modal-header,
#join #m-promo .modal-content,
#join #m-promo .modal-body > div:first-of-type,
#join #m-promo .modal-body .card {
	background-color: var(--color-black);
}

#join #m-promo .modal-header svg {
	fill: var(--color-real-black);
	transition: all, .3s;
}

#join #m-promo .modal-header svg:hover {
	fill: var(--color-light-grey);
}

#join #m-promo .modal-body {
	padding: 1rem;
}

#join #m-promo .modal-body > div:last-of-type {
	padding: 0;
}

#join #m-promo .modal-body .card {
	border: none;
	margin-bottom: 1rem;
	padding: 0;
	background: var(--color-white);
	box-shadow: 0 0 10px 2px rgba(4, 4, 4, 0.5);
}

#join #m-promo .modal-body .card:last-of-type {
	margin-bottom: 0;
}

#join #m-promo .modal-body .card-header {
	background: var(--color-pastel);
	color: var(--color-light-grey);
	text-transform: uppercase;
	font-size: .8rem;
	letter-spacing: 1.5px;
	width: 100%;
	border: none;
	border-top-left-radius: 18px;
	border-top-right-radius: 18px;
	padding: 0 1rem;
	display: flex;
	justify-content: flex-end;
	align-items: center;
}

#join #m-promo .modal-body .card-header svg {
	width: 40px;
	height: 40px;
}

#join #m-promo .modal-body .promo-1 .card-header {
	color: #00bcd4;
}

#join #m-promo .modal-body .promo-2 .card-header {
	color: #ff5722;
}

#join #m-promo .modal-body .promo-1 .card-body svg,
#join #m-promo .modal-body .promo-2 .card-body svg {
	width: 120px;
	height: 120px;
}

#join #m-promo .modal-body .promo-1 .card-header svg,
#join #m-promo .modal-body .promo-1 .card-body svg {
	fill: #00bcd4;
}

#join #m-promo .modal-body .promo-2 .card-header svg,
#join #m-promo .modal-body .promo-2 .card-body svg {
	fill: #ff5722;
}

#join #m-promo .modal-body .card-body {
	padding: 1rem;
}

#join #m-promo .modal-body .card h2,
#join #m-promo .modal-body .card p {
	color: var(--color-grey);
	font-size: 1rem;
}

#join #m-promo .modal-body .card h2 {
	font-size: 1.2rem;
}

#join #m-promo .modal-body .card svg.inline-check {
	width: 30px;
	height: 30px;
	display: inline-block;
	transform: translateY(-2px);
}

#join #m-promo .modal-body .card button {
	width: 60%;
}

#join #m-promo .modal-body .card p.rules {
	font-size: .7rem;
}

@media only screen and (min-width: 768px) {
	#join .modal .modal-body svg {
		width: 150px;
		height: 150px;
	}

	#join .modal.show .modal-dialog {
		max-width: 600px;
	}

	#join #m-info-af img {
		width: 50%;
	}

	#join #m-promo .modal-body .card-body {
		margin: 0 auto;
		text-align: left;
	}

	#join #m-promo .modal-body .card h2 {
		font-size: 1.5rem;
	}
}

/* --------- CARD --------- */
.card {
	box-shadow: 0px 30px 20px -25px rgba(0, 0, 0, 0.2);
	border-radius: 20px;
	overflow: hidden;
	border: none;
	font-size: 1.4em;
}
.card form {
	min-height: unset;
}
.card-body.success {
	background: #d3f7e5;
}
.card-body.success::before {
	content: 'OK';
	width: 100%;
	height: 54%;
	display: block;
	position: absolute;
	top: 0;
	left: 0;
	display: flex;
	align-items: center;
	justify-content: center;
	font-size: 2em;
	color: green;
	background: #d3f7e5;
}
.card-body.success::after {
	content: '';
	width: 100%;
	height: 16%;
	display: block;
	position: absolute;
	bottom: 0;
	left: 0;
	display: flex;
	align-items: center;
	justify-content: center;
	font-size: 2em;
	background: #d3f7e5;
}
.card-body.error {
	background: #ffeae8;
}
.card-body.error::before {
	content: 'Oops!';
	width: 100%;
	height: 54%;
	display: block;
	position: absolute;
	top: 0;
	left: 0;
	display: flex;
	align-items: center;
	justify-content: center;
	font-size: 2em;
	color: red;
	background: #ffeae8;
}

.card-body.error::after {
	content: '';
	width: 100%;
	height: 16%;
	display: block;
	position: absolute;
	bottom: 0;
	left: 0;
	display: flex;
	align-items: center;
	justify-content: center;
	font-size: 2em;
	background: #ffeae8;
}

/* --------- QUERIES --------- */
@media only screen and (max-width: 600px) {
	.breadcrumbs__track--current:after {
		top: 44px;
	}
}
