:root{
	--font-family: 'Roboto', sans-serif;
	--azul:#0056AC;
	--azul-dark:#003D7A;
	--azul-sat:#0065CB;
	--rojo:#bf0909;
	--black:#26292e;
	--white:#ffffff;
	--light:#ECF2F9;
	--gris:#969696;
	--gris-light:#f6f6f6;
	--border:#E6E6E6;
	--bs-success:#009D3F;
	--bs-success-rgb: 0,157,63;
}

body, table, td{
	font-family: var(--font-family);
	font-size: 18px;
	line-height: 1.45;
	color: var(--black);
	font-weight: 400;
}

a{
	color: var(--azul);
	text-decoration: underline;
}
a:hover{
	text-decoration: underline;
	color: var(--azul-sat);
}

small{ font-size: 85%; }

b, strong{ font-weight: 700;}

h1, .h1{ font-size: 52px; }
h2, .h2{ font-size: 42px; }
h3, .h3{ font-size: 32px; }
h4, .h4{ font-size: 26px; }
h5, .h5{ font-size: 22px; }
h6, .h6{ font-size: 20px; }

h1,h2,h3,h4,h5,h6{ margin-bottom: 1.65rem; line-height: 1.1;}

ul,ol{
	margin-bottom: 1.85rem;
}

ol:last-child,
ul:last-child,
p:last-child,
h1:last-child,
h2:last-child,
h3:last-child,
h4:last-child,
h5:last-child,
h6:last-child{
	margin-bottom: 0 !important;
}

p:first-child,
h1:first-child,
h2:first-child,
h3:first-child,
h4:first-child,
h5:first-child,
h6:first-child{
	margin-top: 0 !important;
}

p{
	margin-bottom: 1.5rem;
}

ul, ol{
	padding-left: 1em;
}
.tooltip{
	position: fixed;
}

/*------------------------------ Base -----------------------------*/

.py,.pt{ padding-top: 80px; }
.py,.pb{ padding-bottom: 80px; }
.my,.mt{ margin-top: 80px; }
.my,.mb{ margin-bottom: 80px; }

.text-azul{color: var(--azul) !important;}
.text-rojo{color: var(--rojo) !important;}
.text-black{color: var(--black) !important;}
.text-white{color: var(--white) !important;}
.text-gris{color: var(--gris) !important;}
.text-light{color: var(--light) !important;}
.text-gris-light{color: var(--gris-light) !important;}
.text-border{color: var(--border) !important;}

.bg-azul{background-color: var(--azul) !important;}
.bg-rojo{background-color: var(--rojo) !important;}
.bg-black{background-color: var(--black) !important;}
.bg-white{background-color: var(--white) !important;}
.bg-gris{background-color: var(--gris) !important;}
.bg-light{background-color: var(--light) !important;}
.bg-gris-light{background-color: var(--gris-light) !important;}
.bg-border{background-color: var(--border) !important;}

.bg-gradient{
	background: rgb(0,86,172) !important;
	background: -webkit-linear-gradient(top left, rgba(0,86,172,1) 0%, rgba(0,43,86,1) 100%) !important;
	background: -o-linear-gradient(top left, rgba(0,86,172,1) 0%, rgba(0,43,86,1) 100%) !important;
	background: linear-gradient(to bottom right, rgba(0,86,172,1) 0%, rgba(0,43,86,1) 100%) !important;
}

.font-light{font-weight: 300 !important;}
.font-regular{font-weight: 400 !important;}
.font-medium{font-weight: 500 !important;}
.font-bold{font-weight: 700 !important;}

/*------------------------------ Bootstrap -----------------------------*/

@media (min-width: 1500px) {
	.container-xxl, .container-xl, .container-lg, .container-md, .container-sm, .container {
		max-width: 1430px;
	}
}

.callout{
	background-color: var(--gris-light);
	padding: 32px;
	border-left: 3px solid;
	font-size: 0.9em;
}
.callout_title{
	margin-bottom: 1rem;
}
.callout_title svg{
	width: 1.4em;
}

.callout-danger{border-left-color: var(--bs-danger);}
.callout-danger .callout_title svg{fill: var(--bs-danger);}
.callout-warning{border-left-color: var(--bs-warning);}
.callout-warning .callout_title svg{fill: var(--bs-warning);}
.callout-success{border-left-color: var(--bs-success);}
.callout-success .callout_title svg{fill: var(--bs-success);}
.callout-azul{border-left-color: var(--azul);}
.callout-azul .callout_title svg{fill: var(--azul);}

.btn{
	display: -webkit-inline-box;
	display: -ms-inline-flexbox;
	display: inline-flex;
	-webkit-box-align: center;
	-ms-flex-align: center;
	align-items: center;
	-webkit-box-pack: center;
	-ms-flex-pack: center;
	-ms-flex-wrap: wrap;
	flex-wrap: wrap;
	justify-content: center;
	text-align: center;
	line-height: 1.1;
	color: var(--black);
	padding: 0 2rem;
	font-size: 0.9em;
	border-radius: 3px;
	transition: none;
	min-height: 50px;
	font-weight: 400;
	z-index: 1;
	gap: 0 0.5rem;
	text-decoration: none;
	border-width: 1px;
}

.btn svg{
	width: 1em;
}

.btn-lg, .btn-group-lg > .btn {
	padding: 0 2.5rem;
	font-size: 1em;
	border-radius: 3px;
	min-height: 60px;
	border-width: 2px;
}
.btn-sm, .btn-group-sm > .btn {
	padding: 0 1.5rem;
	font-size: 0.8em;
	border-radius: 3px;
	min-height: 40px;
	border-width: 1px;
}
.btn:hover{
	text-decoration: underline;
}
.btn:hover svg:not(:only-child):last-child{transform: translateX(6px);}

.btn-azul{ background-color: var(--azul); border-color: var(--azul); color: var(--white); }
.btn-azul:hover{ background-color: var(--azul-sat); border-color: var(--azul); color: var(--white); }

.btn-rojo{ background-color: var(--rojo); border-color: var(--rojo); color: var(--white); }
.btn-rojo:hover{ background-color: var(--rojo);	border-color: var(--rojo); color: var(--white); }

.btn-light{ background-color: var(--light); border-color: var(--light); color: var(--azul); }
.btn-light:hover{ background-color: var(--light); border-color: var(--azul); color: var(--azul); }

.btn-white{background-color: var(--white); border-color: var(--white); color: var(--azul);}
.btn-white:hover{background-color: var(--white); border-color: var(--azul); color: var(--azul);}

.btn-outline-white{ color: var(--white); background-color: transparent; border-color: var(--white);}
.btn-outline-white:hover{color: var(--azul); background-color: var(--white); border-color: var(--white);}

.btn-outline-light{ color: var(--azul); background-color: transparent; border-color: var(--border);}
.btn-outline-light:hover{color: var(--azul); background-color: transparent; border-color: var(--azul);}

.btn-outline-azul{ background-color: transparent; border-color: var(--azul); color: var(--azul); }
.btn-outline-azul:hover{ background-color: var(--azul); border-color: var(--azul); color: var(--white); }

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

.btn-link:focus,
.btn-link:hover{
	color: var(--azul);
}

.btn-check:focus+.btn, .btn:focus{
	background-color: var(--azul);
	color: var(--white);
	border-color: var(--azul-dark);
}

.btn:focus{
	box-shadow: none !important;
}

.label,
label{
	display: inline-block;
	font-size: 0.889em;
	font-weight: 500;
}

.form-select,
.form-control{
	border-radius: 3px;
	border-width: 2px;
	border-color: var(--border);
	padding-top: 0.69rem;
	padding-bottom: 0.69rem;
}
.form-select-sm,
.form-control-sm{
	padding-top: 0.5rem;
	padding-bottom: 0.5rem;
}
.form-select-sm{
	background-size: 22px auto !important;
	background-position: right 0.5rem center;
}
.form-select:focus,
.form-control:focus{
	border-color: var(--azul);
	color: var(--black);
	box-shadow: none;
}

.form-select{
	background-image: url("data:image/svg+xml;utf8,%3csvg xmlns='http://www.w3.org/2000/svg' fill='%230056AC' viewBox='0 0 16 16'%3e%3cpath fill-rule='evenodd' d='M16 8A8 8 0 1 1 0 8a8 8 0 0 1 16 0zM8.5 4.5a.5.5 0 0 0-1 0v5.793L5.354 8.146a.5.5 0 1 0-.708.708l3 3a.5.5 0 0 0 .708 0l3-3a.5.5 0 0 0-.708-.708L8.5 10.293V4.5z'/%3e%3c/svg%3e");
	background-size: 24px auto;
}
.form-check-input{
	border-width: 2px;
	border-radius: 4px;
	width: 1.111em;
	height: 1.111em;
	margin-top: 0.15em;
	border-color: var(--gris);
}
.form-check-input:hover{
	border-color: var(--black);
}
.form-check-input:checked{
	background-color: var(--azul);
	border-color: var(--azul);
}
.input_tag{
	position: relative;
}
.input_tag input{
	position: absolute;
	opacity: 0;
	width: 1px;
	height: 1px;
}
.input_tag label{
	display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
	align-items: center;
	justify-content: center;
	padding: 0.5rem 0.6rem;
	min-height: 48px;
	border: 2px solid var(--border);
	border-radius: 3px;
	font-size: 1em;
	cursor: pointer;
	font-weight: 400;
}

.input_tag label:hover{
	border-color: var(--azul);
}
.input_tag input:checked ~ label{
	border-color: var(--azul);
	background-color: var(--azul);
	color: var(--white);
}

.input_upload{
	position: relative;
	cursor: pointer;
}
.input_upload input{
	position: absolute;
    z-index: 0;
    width: 0%;
    height: 0%;
    margin: 0;
    overflow: hidden;
    opacity: 0;
    cursor: pointer;
    left: 0;
    top: 0;
}
.input_upload label{
	font-size: 1em;
	cursor: pointer;
	border: 2px solid var(--border);
	border-radius: 10px;
}
.input_upload .input_upload_btn{
	display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
	align-items: center;
	justify-content: center;
	width: 54px;
	height: 54px;
	border: 0 none;
	background-color: transparent;
	color: var(--gris);
}

.input_upload label:hover .input_upload_btn{
	background-color: transparent;
	color: var(--azul);
}
.input_upload label:hover{
	background-color: var(--light);
	border-color: var(--azul);
	color: var(--azul);
}
.input_upload label.uploaded .input_upload_label .file_del,
.input_upload label.uploaded .input_upload_label .status_1{
	display: block;
	visibility: visible;
}
.input_upload label.uploaded .input_upload_label > p{
	display: none;
}

.input_upload .input_upload_label{
	flex: 1 0 1%;
	line-height: 1.1;
}
.input_upload .input_upload_label p{
	margin-bottom: 0;
}

.input_upload .input_upload_label .status_1{
	font-size: 0.9em;
	color: var(--bs-success);
	display: none;
	visibility: hidden;
}
.input_upload .input_upload_label .file_del{
	position: absolute;
	right: 12px;
	top: 50%;
	transform: translateY(-50%);
	display: none;
	visibility: hidden;
	border: 1px solid var(--border);
	background-color: var(--white);
	color: var(--gris);
}

.files_upload .file_item{
	padding: 0.375rem 0.5rem 0.375rem 1rem;
	border: 2px solid var(--border);
	border-radius: 4px;
	align-items: center;
}
.files_upload .file_item:not(:last-child){
	margin-bottom: 10px;
}
.files_upload .file_item .file_name{
	flex: 1 0 1%;
	font-size: 0.9em;
}

.file_del{
	display: inline-block;
	width: 32px;
	height: 32px;
	border: 0 none;
	background-color: var(--light);
	color: var(--gris);
	border-radius: 50%;
	padding: 0;
}
.files_upload .file_item:hover .file_del:not(:hover){
	color: var(--black);
}
.file_del:hover{
	color: var(--white);
	background-color: var(--azul);
}

.form-floating>.rounded-pill ~ label{
	padding-left: 1rem;
}
.form-floating>.form-control.rounded-pill{
	padding-left: 1rem;
}
.form-floating>label{
	font-size: 1em;
	line-height: 1.5;
}

/*------------------------------ Datepicker -----------------------------*/

.datepicker-picker{
	width: 100%;
	border:1px solid var(--border);
}
.datepicker-view .days,
.datepicker-grid{
	width: 100%;
}

.datepicker-header{
	padding: 12px;
	border-bottom: 1px solid var(--light);
}

.datepicker-controls .view-switch{
	border: 0 none;
	background-color: transparent;
	padding: 0;
	font-weight: 500;
}

.datepicker-controls .next-btn, .datepicker-controls .prev-btn{
	display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
	align-items: center;
	justify-content: center;
	border-radius: 50%;
	border: 0 none;
	background-color: var(--light);
	width: 32px;
	height: 32px;
	color: var(--azul);
}
.datepicker-controls .next-btn:hover, .datepicker-controls .prev-btn:hover{
	background-color: var(--azul);
	color: var(--white);
}
.datepicker-controls .next-btn:focus, .datepicker-controls .prev-btn:focus{
	outline: 3px solid #ffbf47 !important;
    outline-offset: 0 !important;
}
.datepicker-view .dow{
	font-size: 1em;
}
.datepicker-view .days-of-week{
	padding-top: 0.5rem;
	padding-bottom: 0.5rem;
}

.datepicker-cell{
	height: 3rem;
	line-height: 3rem;
}
.datepicker-cell:not(.disabled):hover{
	background-color: var(--light);
}
.datepicker-cell.selected, .datepicker-cell.selected:hover{
	background-color: var(--azul);
}

.datepicker-view .days{
	padding-top: 1rem;
	padding-bottom: 1rem;
}

/*------------------------------ Responsive -----------------------------*/

@media only screen and (max-width: 1499px){
	.py,.pt{ padding-top: 70px; }
	.py,.pb{ padding-bottom: 70px; }
	.my,.mt{ margin-top: 70px; }
	.my,.mb{ margin-bottom: 70px; }
}
@media only screen and (max-width: 1399px){
	.py,.pt{ padding-top: 60px; }
	.py,.pb{ padding-bottom: 60px; }
	.my,.mt{ margin-top: 60px; }
	.my,.mb{ margin-bottom: 60px; }
}

@media only screen and (max-width: 1199px){
	.py,.pt{ padding-top: 80px; }
	.py,.pb{ padding-bottom: 80px; }
	.my,.mt{ margin-top: 80px; }
	.my,.mb{ margin-bottom: 80px; }	
}

@media only screen and (max-width: 991px){
	.py,.pt{ padding-top: 70px; }
	.py,.pb{ padding-bottom: 70px; }
	.my,.mt{ margin-top: 70px; }
	.my,.mb{ margin-bottom: 70px; }
}

@media only screen and (max-width: 767px){	
	.py,.pt{ padding-top: 60px; }
	.py,.pb{ padding-bottom: 60px; }
	.my,.mt{ margin-top: 60px; }
	.my,.mb{ margin-bottom: 60px; }
	small, .small{
		font-size: 100%;
	}
}

@media only screen and (max-width: 575px){
	.py,.pt{ padding-top: 48px; }
	.py,.pb{ padding-bottom: 48px; }
	.my,.mt{ margin-top: 48px; }
	.my,.mb{ margin-bottom: 48px; }
}