

[data-mod="alert"] {
	position: fixed;
	top: 0; left: 0;
	width: 100vw; height: 100vh;
	background-color: rgba(0,0,0,.4);
	z-index: 3000;
	display: none;
}


[data-mod="alert"] .box {
	background-color: rgba(0, 0, 0, 0.4);
	backdrop-filter: blur(10px);
	width: 340px; height: 250px;
	position: absolute;
	top: 50%; left: 50%;
	margin-top: -150px; margin-left: -170px;
	padding: 30px;
	border-radius: 10px;
	box-shadow: 1px 5px 30px 0px rgb(0 0 0 / 35%);
	-webkit-box-shadow: 1px 5px 30px 0px rgb(0 0 0 / 35%);
	-moz-box-shadow: 1px 5px 30px 0px rgba(0,0,0,.35);
}

[data-mod="alert"] .box .text {
	height: 125px;
}

[data-mod="alert"] .box .text .title {
	font-weight: 700; font-size: 20px; color: #e1e1e1;
}

[data-mod="alert"] .box .text .sep {
	width: 100%; height: 2px;
	background-color: #333;
	border-radius: 5px;
	margin: 5px 0;
	display: none;
}

[data-mod="alert"] .box .text .message {
	font-size: 15px; color: #e1e1e1;
}

[data-mod="alert"] .box .controls {
	height: 65px;
	overflow: hidden;
	text-align: right;
}







@media screen and (max-width: 710px) {



}




[data-mod="loading"] {
	width: 100vw; height: 100vh;
	z-index: 2000;
	background-color: rgba(0,0,0,.4);
	top: 0; right: 0; bottom: 0; left: 0;
	position: fixed;
	display: none;
	opacity: 0;
}

[data-mod="loading"] .graph {
	background-image: url(../images/system/loading.png);
	background-size: 52px;
	width: 60px;
	height: 60px;
	position: absolute;
	z-index: 2000;
	top: 50%;
	left: 50%;
	margin: -25px 0 0 -25px;
	border-radius: 50%;
	border: 6px solid #fbfbfb;
	animation: rotation 2s infinite linear;
}





@media screen and (max-width: 710px) {



}







/* ------------------------------ MARGIN BOTTOM ------------------------------ */

.one_mb5 { margin-bottom: 5px; }
.one_mb10 { margin-bottom: 10px; }
.one_mb15 { margin-bottom: 15px; }
.one_mb20 { margin-bottom: 20px; }
.one_mb25 { margin-bottom: 25px; }
.one_mb30 { margin-bottom: 30px; }
.one_mb35 { margin-bottom: 35px; }
.one_mb40 { margin-bottom: 40px; }
.one_mb45 { margin-bottom: 45px; }
.one_mb50 { margin-bottom: 50px; }
.one_mb55 { margin-bottom: 55px; }
.one_mb60 { margin-bottom: 60px; }

.one_pl20 { padding-left: 20px; }
.one_pl40 { padding-left: 40px; }





/* ------------------------------ BUTTONS ------------------------------ */

.one_btn1,
.one_btn2,
.one_btn3,
.one_btn4,
.one_btn5,
.one_btn6 {
	font-size: 15px; font-weight: 700; text-align: center; text-transform: uppercase;
	padding: 20px 40px;
	cursor: pointer;
	display: inline-block;
	border-radius: 10px;
	transition: all .15s linear;
	margin: 0 5px 0 0;
}

.one_btn1 { color: white; border: 2px solid #00aba5; background-color: #00aba5; }
.one_btn1:hover { color: white; border: 2px solid #1a1a1a; background-color: #1a1a1a; }

.one_btn2 { color: white; border: 2px solid white; background-color: transparent; }
.one_btn2:hover { color: #111; border: 2px solid white; background-color: white; }

.one_btn3 { color: white; border: 2px solid #f56a03; background-color: #f56a03; }
.one_btn3:hover { color: white; border: 2px solid #1a1a1a; background-color: #1a1a1a; }

.one_btn4 { color: white; border: 2px solid #e86a05; background-color: #e86a05; }
.one_btn4:hover { color: white; border: 2px solid black; background-color: black; }

.one_btn5 { color: white; border: 2px solid #f53729; background-color: #f53729; }
.one_btn5:hover { color: white; border: 2px solid black; background-color: black; }

.one_btn6 { color: white; border: 2px solid #ae1484; background-color: #ae1484; }
.one_btn6:hover { color: white; border: 2px solid black; background-color: black; }





/* TABLE / TABLE-CELL */

.one_tab {
	width: 100%; height: 100%;
	display: table;
}

.one_cel {
	width: 100%; height: 100%;
	display: table-cell;
	vertical-align: middle;
}





/* ------------------------------ SCROLLBARS ------------------------------ */

/* Works on Firefox */
* { scrollbar-width: thin; scrollbar-color: #cbcbcb transparent; }
/* Works on Chrome, Edge, and Safari */
*::-webkit-scrollbar { width: 8px; height: 4px; } /* width for vertical / height for horizontal */
*::-webkit-scrollbar-thumb { background-color: #7f7f7f; border: 3px solid transparent; } /* drag */
*::-webkit-scrollbar-track { background-color: #c3c3c3; } /* scroll */





/* ------------------------------ KEYFRAMES ------------------------------ */

@keyframes rotation {

	from { transform: rotate(0deg); }
	to { transform: rotate(359deg); }

}






:root {

	/* COLORS */
	--color-pink: #d53e5b;
	--color-blue: #0081b6;
	--color-green: #27a216;

	/* BACKGROUNDS */
	--background-app: url(../images/apps/background-desktop-b-004.jpg);

}

/* RESET */

* {
	margin: 0; padding: 0;
	border: none; outline: none;
	box-sizing: border-box;
	text-decoration: none;
	background-repeat: no-repeat;
	background-position: center;
	background-size: cover;
	font-family: 'Montserrat'; font-size: 16px;
	/* color: white; */
	list-style: none;
	word-break: break-word;
}

@media screen and (max-width: 800px) {

	* { font-size: 15px; line-height: 16px; }

}

html, body {
	background-color: #f9eae7;
	height: 100%;
	background-size: 750px;
	background-repeat: repeat;
}

/*
input, select, option, textarea {
	color: #111;
}
*/

p,
label { color: #333; }
a { color: #f56a04; }
a:hover { color: #333; }




@media screen and (max-width: 710px) {

	/* html, body { background-size: 500px; } */

}











[data-app="confirm"] {
	width: 100%; height: 100vh;
	overflow-y: auto;
	background-color: #e7ecf6;
	background-image: url(../images/apps/cordoba-background-apps-001.jpg);
}

@media screen and (max-width: 1200px) {

	

}



[data-app="confirm"] [data-confirm-status] {
	max-width: 300px;
	margin: 0 auto 30px auto;
	border-radius: 10px;
	padding: 10px;
	color: white; font-size: 15px;
	background-image: url(../images/apps/confirm/confirm-status-001.png);
	background-size: 58px 174px;
}

[data-app="confirm"] [data-confirm-status="pending"] {
	background-color: #e78806;
	background-position: 0 0;
}

[data-app="confirm"] [data-confirm-status="approved"] {
	background-color: #4175e9;
	background-position: 0 -56px;
}

[data-app="confirm"] [data-confirm-status="rejected"] {
	background-color: #df122f;
	background-position: 0 -115px;
}

[data-app="confirm"] [data-confirm-status] .status {
	text-transform: uppercase;
	color: white;
	font-weight: 700;
}















[data-app="login"] {
	width: 100vw; height: 100vh;
	overflow: hidden;
	position: relative;
	background-color: #a0ab9d;
	background-image: url(../images/apps/login/background-001.jpg);
}





/* LEFT */

[data-app="login"] .portrait {
	width: 100%;
	text-align: center;
	padding: 30px 0 30px 0;
}

[data-app="login"] .portrait img {
	width: 400px;
}

[data-app="login"] .portrait img.mobile {
	width: 90%; max-width: 300px;
	display: none;
}





/* RIGHT */

[data-app="login"] .content {
	width: 100%;
}





/* FORM */

[data-app="login"] .content #form {
	width: 70%; max-width: 400px;
	margin: 0 auto; padding: 50px;
	border-radius: 10px;
	text-align: center;
	transition: box-shadow 0.2s ease-out;
	-webkit-box-shadow: 0 30px 50px 0 rgb(0 0 0 / 15%);
    box-shadow: 0 30px 50px 0 rgb(0 0 0 / 15%);
    background-color: rgba(255, 255, 255, .1);
    backdrop-filter: blur(10px);
}

[data-app="login"] .content #form:hover {
	-webkit-box-shadow: 0 30px 50px 0 rgb(0 0 0 / 25%);
    box-shadow: 0 30px 50px 0 rgb(0 0 0 / 25%);
}






[data-app="login"] .content #form .field {
	width: 100%;
	margin: 0 0 15px 0;
}

[data-app="login"] .content #form .field label {
	color: #333;
	text-align: left;
}





/* SPONSORS */

[data-app="login"] .sponsors {

}

[data-app="login"] .sponsors img {
	width: 100%;
}





@media screen and (max-width: 1200px) {

	[data-app="login"] {
		overflow-y: auto;
		height: 100%;
	}

	[data-app="login"] .portrait img.desktop { display: none; }
	[data-app="login"] .portrait img.mobile { display: inline-block; }


	[data-app="login"] .portrait {
		padding: 25px 0 0 0;
	}

	[data-app="login"] .content {
		padding: 20px;
	}

	[data-app="login"] .content #form {
		width: 100%;
		padding: 40px;
	}

}















[data-app="register"] {
	width: 100%; height: 100vh;
	overflow-y: auto;
	background-color: #b3bab2;
	background-image: url(../images/apps/background-apps-001.jpg);
}

@media screen and (max-width: 1200px) {

	

}




















[data-app="reset"] {
	width: 100%; height: 100%;
	overflow-y: auto;
	background-image: url(../images/apps/background-008.jpg);
}

@media screen and (max-width: 1200px) {

	

}




















#portrait {
	width: 100%; height: 140px;
	background-image: url(../images/portrait-desktop-001.png);
	background-color: rgba(255, 255, 255, .1);
	margin: 0 0 30px 0;
}

@media screen and (max-width: 1000px) {

	#portrait {
		height: 150px;
		background-image: url(../images/portrait-mobile-001.png);
	}

}

@media screen and (max-width: 800px) {

	#portrait {
		margin: 0 0 20px 0;
	}

}




















#menu {
	width: 50px; height: 50px;
	top: 10px; right: 20px;
	/* background-color: rgba(0,0,0,.05); */
	border-radius: 5px;
	position: absolute;
	background-image: url(../images/mobile-menu.png);
	cursor: pointer;
	user-select: none;
	z-index: 1;
}

#menu:hover {
	background-color: rgba(0,0,0,.05);
}

@media screen and (max-width: 800px) {

	#menu { width: 40px; height: 40px; }

}


#nav {
	width: 250px;
	position: absolute;
	top: 70px;
	right: 20px;
	background-color: rgba(255, 255, 255, 0.2);
	backdrop-filter: blur(10px);
	border-radius: 10px;
	padding: 10px 0;
	text-align: right;
	box-shadow: 1px 5px 30px 0px rgb(0 0 0 / 25%);
	-webkit-box-shadow: 1px 5px 30px 0px rgb(0 0 0 / 25%);
	-moz-box-shadow: 1px 5px 30px 0px rgba(0,0,0,.25);
	user-select: none;
	z-index: 1;
}

#nav[data-display="show"] {
	display: block;
}

#nav[data-display="hide"] {
	display: none;
}

#nav li {
	user-select: none;
}

#nav li a {
	user-select: none;
	display: block;
	height: 35px;
	line-height: 35px;
	margin: 0 0 1px 0; padding: 0 20px 0 0;
	cursor: pointer;
	border-right: 7px solid transparent;
	transition: background-color .25s ease-in-out;
}

#nav li a:hover {
	background-color: rgba(0,0,0,.05);
	/* border-right: 7px solid rgba(0,0,0,.1); */
}

#nav li a.active {
	border-right: 7px solid #f56a04;
}

#nav .nav-sep {
	border-bottom: 2px solid #e3e3e3;
	padding: 10px 0 0 0;
	margin: 0 0 10px 0;
}

@media screen and (max-width: 800px) {

	#nav { top: 60px; }

}
















[data-sector] {
	margin: 0 auto;
}

[data-sector="intro"] {
	max-width: 800px;
	padding: 0 10px 40px 10px;
}

[data-sector="steps"] {
	max-width: 800px;
	padding: 0 0 75px 0;
}

[data-sector="select"] {
	padding: 40px 10% 100px 10%;
	/* background-color: rgba(0, 0, 0, .05); */
}

@media screen and (max-width: 1500px) {

	[data-sector="select"] { padding: 10px 2% 40px 2%; }

}

[data-sector="type"] {
	/* background-color: rgba(0, 0, 0, .05); */
	padding: 0 10px 40px 10px;
}

[data-sector="bottom"] {
	max-width: 800px;
	padding: 0 0 80px 0;
}










.one_air_form {
	max-width: 800px;
	margin: 0px auto;
	border: 20px solid transparent;
	border-radius: 5px;
}








.register_points {
	margin: 0 0 3px 0;
	padding: 15px 40px;
	background-color: rgba(0, 0, 0, .05);
	border-radius: 5px;
	transition: background-color 0.25s ease-in-out;
	position: relative;
	min-height: 60px;
}

.register_points .dot {
	position: absolute;
	top: 12px;
	left: -17px;
	font-size: 20px;
	font-weight: 700;
	color: #f6f3ea;
	width: 35px;
	height: 35px;
	line-height: 35px;
	background-color: #be135c;
	border-radius: 50px;
	text-align: center;
}

.register_points:hover {
	background-color: rgba(0, 0, 0, .125);
}

@media screen and (max-width: 900px) {

	.register_points .dot { left: 12px; width: 30px; height: 30px; line-height: 30px; }
	.register_points { padding: 15px 40px 15px 55px; text-align: left; }

}















/* ------------------------------ WIDE APP ------------------------------ */

.wide_app {
	margin: 0 auto;
}

.wide_app.full   { max-width: 100%;   }
.wide_app.extra  { max-width: 1620px; }
.wide_app.big    { max-width: 1100px; }
.wide_app.medium { max-width: 920px;  }
.wide_app.normal { max-width: 820px;  }
.wide_app.small  { max-width: 620px;  }





/* ------------------------------ FLOW APP ------------------------------ */

.one_flow_app {
	/* padding: 30px 0 100px 0; */
	width: 100%; height: 100%;
	overflow-y: auto;
	position: relative;
}

@media screen and (max-width: 1000px) {

	/* .one_flow_app { padding: 5px 0 100px 0; } */

}





/* ------------------------------ ONE BOX ------------------------------ */

.one_air {
	border: 10px solid transparent;
}
/*

.one_box {
	border-radius: 10px;
	background-color: white;
	overflow: hidden;
	border: 1px solid rgba(0,0,0,.075);
	transition: box-shadow 0.2s ease-out;
	position: relative;
	padding: 55px;
}
.one_box_b {
	overflow: hidden;
	position: relative;
	padding: 35px;
}
.one_box_c {
	overflow: hidden;
	position: relative;
	padding: 35px;
	background-color: rgba(0,0,0,.05);
}

*/

@media screen and (min-width: 900px) {

	/*

	.one_box:hover {
		-webkit-box-shadow: 0 3px 5px 0 rgba(0,0,0,.1);
		box-shadow: 0 3px 5px 0 rgba(0,0,0,.1);
	}

	*/

}

@media screen and (max-width: 600px) {

	/*

	.one_box {
		padding: 30px;
	}
	.one_box_b {
		padding: 10px;
	}
	.one_box_c {
		padding: 10px;
	}

	*/

	.one_air {
		/* border: 5px solid transparent; */
	}

}

.one_box_left { float: right; width: 75%; padding: 0 0 50px 0; }
.one_box_right { float: left; width: 25%; padding: 0 50px 0 0; }

@media screen and (max-width: 1000px) {

	.one_box_left { float: none; width: 100%; padding: 0 0 50px 0; }
	.one_box_right { float: none; display: none; }

}





/* ------------------------------ H ------------------------------ */

h1, 
h1 a, 
h2, 
h2 a, 
h3, 
h3 a {
	font-weight: 400;
	transition: color .15s linear;
	color: #ec6608;
}

h1, h1 a { font-size: 30px; line-height: 30px; }
h2, h2 a { font-size: 25px; line-height: 25px; }
h3, h3 a { font-size: 18px; line-height: 18px; }

h1:hover, 
h1 a:hover, 
h2:hover, 
h2 a:hover, 
h3:hover, 
h3 a:hover { color: #1a1a1a; }

@media screen and (max-width: 800px) {

	h1, h1 a { font-size: 25px; line-height: 25px; }
	h2, h2 a { font-size: 22px; line-height: 22px; }
	h3, h3 a { font-size: 18px; line-height: 18px; }

}





/* APP HEADERS */

[data-app] header {
	margin: 0 0 25px 0;
}

[data-app] header h1, 
[data-app] header p {
	margin: 0 0 10px 0;
}





/* ------------------------------ FIELDS ------------------------------ */

.sep {
	border-bottom: 2px dotted #e3e3e3;
	padding: 0 0 0 0;
	margin: 0 0 30px 0;
}

.fields {
	overflow: hidden;
}

.fields .pack {
	overflow: hidden;
	width: 100%;
	/* border: 1px solid #d4d4d4; */
	/* border-radius: 5px; */
	margin: 0 0 20px 0;
	/* padding: 20px; */
}

.fields .pack h3 {
	font-size: 16px; font-weight: 700; color: #333;
	margin: 0 0 15px 0;
}

.fields .field {
	border-radius: 10px;
	margin: 0 10px 15px 0;
	float: left;
}

.fields .field.w100 { width: 100%; }
.fields .field.w48 { width: 48%; }
.fields .field.w30 { width: 30%; }
.fields .field.w20 { width: 20%; }

@media screen and (max-width: 900px) {

	.fields .field.w100 { width: 100%; }
	.fields .field.w48  { width: 100%; }
	.fields .field.w30  { width: 100%; }
	.fields .field.w20  { width: 100%; }

}

.fields .field label {
	font-size: 15px;
	margin: 0 0 5px 0;
	display: block;
	color: black;
}

.fields .field label span {
	color: #ec6608;
}

.fields .field .text {

}

.fields .field .select {

}

.fields .field .text input,
.fields .field .select select {
	width: 100%; height: 40px; line-height: 40px;
	padding: 0 10px;
	border-radius: 5px;
	font-weight: 700;
	background-color: rgba(0,0,0,.1);
	border: 2px solid transparent;
	color: #333;
	transition: border .25s ease-in-out;
}

.fields .field .text input:focus,
.fields .field .select select:focus {
	border: 2px solid black;
}

.fields .field .text input.error,
.fields .field .select select.error {
	border: 2px solid #d53e5b;
	color: #d53e5b;
}

.fields .field .textarea {

}

.fields .field .textarea textarea {
	width: 100%; max-width: 100%; height: 150px; line-height: 20px;
	padding: 15px 10px;
	border-radius: 5px;
	font-weight: 700;
	background-color: transparent;
	border: 2px solid #e3e3e3;
	color: black;
}

.fields .field .textarea textarea:focus {
	border: 2px solid black;
}

.fields .radio {
	overflow: hidden;
	width: 100%;
	border: 2px solid rgba(0,0,0,.1);
	border-radius: 5px;
	margin: 0 0 20px 0;
	padding: 20px;
}

.fields .radio h3 {
	font-size: 16px; font-weight: 700; color: #333;
	margin: 0 0 15px 0;
}

.fields .radio [data-radio] {
	position: relative;
	cursor: pointer;
	margin: 0; padding: 10px 5px 10px 45px;
	border-radius: 5px;
}

.fields .radio [data-radio]:hover {
	background-color: rgba(0,0,0,.05);
}

.fields .radio [data-radio] p {
	border: 3px solid black;
	width: 20px; height: 20px;
	border-radius: 50%;
	position: absolute;
	top: 10px; left: 15px;
}

.fields .radio [data-radio] p.active {
	border: 3px solid black;
	background-color: black;
}

.fields .radio [data-radio] .text {

}




.fields .check {
	overflow: hidden;
	width: 100%;
	border: 2px solid rgba(0,0,0,.1);
	border-radius: 5px;
	margin: 0 0 20px 0;
	padding: 20px;
}

.fields .check h3 {
	font-size: 16px; font-weight: 700; color: #333;
	margin: 0 0 15px 0;
}

.fields .check [data-check] {
	position: relative;
	cursor: pointer;
	margin: 0; padding: 10px 5px 10px 45px;
	border-radius: 5px;
}

.fields .check [data-check]:hover {
	background-color: rgba(0,0,0,.05);
}

.fields .check [data-check] p {
	border: 3px solid black;
	width: 20px; height: 20px;
	border-radius: 5px;
	position: absolute;
	top: 10px; left: 15px;
}

.fields .check [data-check] p.active {
	border: 3px solid black;
	background-color: black;
	background-image: url(../images/system/checkbox-icon.png);
	background-size: 20px 20px;
}

.fields .check [data-check] .text {

}





/* ------------------------------ CONTROLS ------------------------------ */

.controls {

}

.controls [data-control="loading"] {
	display: none;
}





/* ------------------------------ VISIBILITY ------------------------------ */

[data-visible="hide"] { display: none; }
[data-visible="show"] { display: block; }







/* TITLES */

.app_title {
	margin: 0 0 18px 0;
}

.app_title .title {
	font-size: 25px;
	font-weight: 700;
	line-height: 30px;
	text-decoration: none;
	color: #be135c;
	text-transform: uppercase;
}

.app_title .subtitle {
	color: #333;
}

@media screen and (max-width: 800px) {

	.app_title .title { font-size: 22px; line-height: 22px; }

}





