html {
    scrollbar-width: none; /* For Firefox */
    -ms-overflow-style: none; /* For Internet Explorer and Edge */
}

html::-webkit-scrollbar {
    width: 0px; /* For Chrome, Safari, and Opera */
}

/* Diseño móvil: 480 px e inferior. */
@media only screen and (max-width: 481px) {
/********************************* Header ********************************************/
#header_key {
	position:relative;
	box-sizing: border-box;
	width:100%;
	height:30px;
	z-index:9999;
}
#header_key .headerTabla {
	position:relative;
	margin-top:3px;
	width:100%;
	border-spacing: 0px;
	border-collapse: collapse;
}
#header_key .headerTabla .tdHeader1 {
	width:10%;
	text-align:left;
	vertical-align:middle;
	padding-left:5px;
}
#header_key .headerTabla .tdHeader2 {
	width:80%;
	text-align:center;
	vertical-align:middle;
}
#header_key .headerTabla .tdHeader3 {
	width:10%;
	text-align:right;
	vertical-align:middle;
	padding-right:5px;
}
#header_key .headerTabla .tdHeader4 {
	width:100%;
	text-align:right;
	vertical-align:middle;
	padding-right:5px;
}
#header_key .headerTabla .imgHeaderKey {
	position:relative;
	padding: 1px;
	width:20px;
	height:20px;
	-webkit-transition: all 0.5s;
  	-moz-transition: all 0.5s;
  	-ms-transition: all 0.5s;
  	-o-transition: all 0.5s;
  	transition: all 0.5s;
	cursor:pointer;
	outline: none;
}
#header_key .headerTabla .imgHeaderKey:hover {
	opacity:0.6;
}
#header_key .headerTabla .titKey {
	position:relative;
	display:inline-block;
	color: #333;
	font-size: 16px;
	font-family: 'Open Sans Condensed', sans-serif;
	text-align: center;
	font-weight:bold;
	text-transform:uppercase;
	letter-spacing:1px;
	line-height:15px;
}
#header_key .headerTabla .txtKey {
	position:relative;
	display:none;
	color: #333;
	font-size: 12px;
	font-family: 'Open Sans Condensed', sans-serif;
	text-align: right;
	font-weight:100;
	letter-spacing:0;
	line-height:15px;
}
#header_key .headerTabla .iconKey {
	position:relative;
	display:inline-block;
	text-align: right;
}
#header_key .headerTabla .txtHideKey {
	display:none;
}

/********************************* Subheader ********************************************/
#subheader_key {
	position:relative;
	box-sizing: border-box;
	width:100%;
	height:20px;
	background:#fcfcfc;
	z-index:9999;
}
#subheader_key .subheaderTabla {
	position:relative;
	margin-top:0;
	width:100%;
	border-spacing: 0px;
	border-collapse: collapse;
}
#subheader_key .subheaderTabla .tdSubheader1 {
	width:40%;
	text-align:center;
	vertical-align:middle;
	padding-left:20px;
}
#subheader_key .subheaderTabla .tdSubheader2 {
	width:20%;
	text-align:center;
	vertical-align:middle;
}
#subheader_key .subheaderTabla .tdSubheader3 {
	width:40%;
	text-align:center;
	vertical-align:middle;
	padding-right:20px;
}

/* Estado */
label.keyLabelEdo > input.keyCheckboxEdo{ /* HIDE RADIO */
	visibility: hidden; /* Makes input not-clickable */
	position: absolute; /* Remove input from document flow */
}
label.keyLabelEdo > input.keyCheckboxEdo + img.keyImgEdo{ /* IMAGE STYLES */
	width:22px;
	height:22px;
	cursor:pointer;
	border:1px solid #6b6b6b;
}
label.keyLabelEdo > input.keyCheckboxEdo:checked + img.keyImgEdo{ /* (RADIO CHECKED) IMAGE STYLES */
	background:#DB4755;
}

/* Taxa */
label.keyLabelTax > input.keyCheckboxTax{ /* HIDE RADIO */
	visibility: hidden; /* Makes input not-clickable */
	position: absolute; /* Remove input from document flow */
}
label.keyLabelTax > input.keyCheckboxTax + img.keyImgTax{ /* IMAGE STYLES */
	width:22px;
	height:22px;
	cursor:pointer;
	border:1px solid #6b6b6b;
}
label.keyLabelTax > input.keyCheckboxTax:checked + img.keyImgTax{ /* (RADIO CHECKED) IMAGE STYLES */
	background:#DB4755;
}

/* Vista */
label.keyLabelView > input.keyCheckboxView{ /* HIDE RADIO */
	visibility: hidden; /* Makes input not-clickable */
	position: absolute; /* Remove input from document flow */
}
label.keyLabelView > input.keyCheckboxView + img.keyImgView{ /* IMAGE STYLES */
	width:22px;
	height:22px;
	cursor:pointer;
	border:1px solid #6b6b6b;
}
label.keyLabelView > input.keyCheckboxView:checked + img.keyImgView{ /* (RADIO CHECKED) IMAGE STYLES */
	background:#DB4755;
}

/********************************* Footer ********************************************/
#footer_key {
	clear: both;
	float: left;
	margin-left: 0;
	width: 100%;
	height: 15px;
	display: block;
	bottom: 0;
	background:#49a397;
	position:relative;
	padding:5px 0 5px 0;
	z-index:100;
	text-align: center;
}
#footer_key #txtTitulo {
	position:relative;
	margin-top:1px;
	color: #ffffff;
	font-size: 12px;
	font-family: 'Open Sans Condensed', sans-serif;
	font-weight:100;
	letter-spacing:2px;
	padding-right:6px;
}

/******************************* Claves taxonómicas **************************************/
#tableKey {
	position:relative;
	top: 72px;
	width:100%;
	border:none;
	border-spacing:0;
}
#tableKey .keyCols {
	position:relative;
	width:50%;
}
#tableKey .keyCols .divKey {
	position:relative;
	font-family: 'Open Sans Condensed', sans-serif;
	overflow-y:hidden;
	overflow-x:hidden;
	font-size:12px;
	padding:10px 0 0 10px;
}
#tableKey .keyCols .divKey .txtText {
	position:relative;
	display: inline-block;
	width:100%;
	font-family: 'Open Sans Condensed', sans-serif;
	font-size:16px;
	margin: -6px 0 0 20px;
	padding: 1px 0 1px 0;
	-webkit-transition: all 0.5s;
  	-moz-transition: all 0.5s;
  	-ms-transition: all 0.5s;
  	-o-transition: all 0.5s;
  	transition: all 0.5s;
	cursor:pointer;
}
#tableKey .keyCols .divKey .txtText:hover {
	text-decoration:underline;
	color:#DB4755;
	opacity:0.7;
}
#tableKey .keyCols .txtTit {
	position:relative;
	font-family: 'Open Sans Condensed', sans-serif;
	color:#fcfcfc;
	font-size:14px;
	font-weight:bold;
	text-transform:uppercase;
	letter-spacing:2px;
	width:100%;
	text-align:center;
	vertical-align:middle;
	background:#1d1d1d;
	padding:5px;
	margin-top:-2px;
}
#tableKey .keyCols .containerTotal {
	position:relative;
	background-color:#f1f1f1;
	box-sizing: border-box;
	width:100%;
	z-index:999;
}
#tableKey .keyCols .containerTotal .contentTotal {
	position:relative;
	display:inline-block;
	box-sizing: border-box;
	padding:1px;
	font-family: 'Open Sans Condensed', sans-serif;
	color:#1d1d1d;
	font-size:12px;
	font-weight:bold;
	letter-spacing:0;
	width:100%;
	text-align:center;
}
#tableKey .keyCols .containerTotal .contentTotal .opTotal {
	position:relative;
	display:inline-block;
	padding:0 1px 0 1px;
}

/******************************* Checkboxes **************************************/
.controlContent {
	position:relative;
}
.controlContent .textContent {
	position: relative;
	padding: 2px 0 2px 0;
}
.controlContent .textContent .txtTitOp {
	font-family: 'Open Sans Condensed', sans-serif;
	display: inline-block;
	position: relative;
	margin-bottom: 3px;
	padding-top: 0;
	cursor: pointer;
	font-size: 16px;
	font-weight: bold;
	letter-spacing: 1px;
}
.controlContent .textContent .txtImgOp {
	position: relative;
	display: inline-block;
	padding: 0 4px 0 0;
	margin-top: -4px;
	width: 15px;
	height: 15px;
	-webkit-transition: all 0.5s;
  	-moz-transition: all 0.5s;
  	-ms-transition: all 0.5s;
  	-o-transition: all 0.5s;
  	transition: all 0.5s;
  	cursor:pointer;
	outline: none;
}
.controlContent .textContent .txtImgOp:hover {
	opacity: 0.6;
}
.controlContent .marginLeftOn {
	padding-left: 10px;
}
.controlContent .marginLeftOff {
	padding-left: 0;
}
.controlContent .controlContain {
	position:relative;
}
.controlContainOp {
	position:relative;
	display: inline-block !important;
	width: 150px !important;
}
.controlContent .controlContain .control {
	font-family: 'Open Sans Condensed', sans-serif;
	display: block;
	position: relative;
	padding-left: 20px;
	margin-bottom: 3px;
	padding-top: 0;
	cursor: pointer;
	font-size: 16px;
}
.control input {
	position: absolute;
	z-index: -1;
	opacity: 0;
}
.control_indicator {
	position: absolute;
	top: 2px;
	left: 0;
	height: 15px;
	width: 15px;
	background: #e6e6e6;
	border: 0px solid #000000;
	border-radius: 0px;
}
.control:hover input ~ .control_indicator,
.control input:focus ~ .control_indicator {
	background: #cccccc;
}

.control input:checked ~ .control_indicator {
	background: #49a397;
}
.control:hover input:not([disabled]):checked ~ .control_indicator,
.control input:checked:focus ~ .control_indicator {
	background: #0e6647d;
}
.control input:disabled ~ .control_indicator {
	background: #e6e6e6;
	opacity: 0.6;
	pointer-events: none;
}
.control_indicator:after {
	box-sizing: unset;
	content: '';
	position: absolute;
	display: none;
}
.control input:checked ~ .control_indicator:after {
	display: block;
}
.control-checkbox .control_indicator:after {
	left: 6px;
	top: 2px;
	width: 3px;
	height: 7px;
	border: solid #ffffff;
	border-width: 0 2px 2px 0;
	transform: rotate(45deg);
}
.control-checkbox input:disabled ~ .control_indicator:after {
	border-color: #7b7b7b;
}
.control-checkbox .control_indicator::before {
	content: '';
	display: block;
	position: absolute;
	left: 0;
	top: 0;
	width: 2.2rem;
	height: 2.2rem;
	margin-left: -0.349rem;
	margin-top: -0.404rem;
	background: #49a397;
	border-radius: 3rem;
	opacity: 0.3;
	z-index: 99999;
	transform: scale(0);
}
@keyframes s-ripple {
	0% {
		transform: scale(0);
	}
	20% {
		transform: scale(1);
	}
	100% {
		opacity: 0;
		transform: scale(1);
	}
}
@keyframes s-ripple-dup {
   0% {
	   transform: scale(0);
	}
   30% {
		transform: scale(1);
	}
	60% {
		transform: scale(1);
	}
	100% {
		opacity: 0;
		transform: scale(1);
	}
}
.control-checkbox input + .control_indicator::before {
	animation: s-ripple 250ms ease-out;
}
.control-checkbox input:checked + .control_indicator::before {
	animation-name: s-ripple-dup;
}

/******************************* Colores **************************************/
.color_edo {
	background-color:#CDF4E4;
}
.color_tax {
	background-color:#CEE2F2;
}

/******************************* Submenú **************************************/
#container .keySubmenu {
  position: absolute;
  display: none;
  box-sizing: border-box;
  top: 0;
  left: 0;
  min-width: 160px;
  width: auto;
  height: auto;
  background-color: #f1f1f1;
  padding: 6px 0 6px 0;
  z-index: 9999888;
}
#container .keySubmenu .keyOptions {
  position: relative;
  text-align: left;
  padding: 4px 4px 4px 8px;
  -webkit-transition: all 0.5s;
  -moz-transition: all 0.5s;
  -ms-transition: all 0.5s;
  -o-transition: all 0.5s;
  transition: all 0.5s;
  cursor: pointer;  
}
#container .keySubmenu .keyOptions:hover {
  background-color: #a9a9a9;
  opacity: 0.6;
}
#container .keySubmenu .keyOptions:hover > .keyTxt {
  font-weight: bold;
}
#container .keySubmenu .keyOptions .keyIcon {
  position: relative;
  display:inline-block;
  width:15px;
  height:15px;
  padding-left: 4px;
  margin-top:-2px;
  opacity:0.5;
}
.divKey .controlContent .keyIconShow {
  position: relative;
  display:inline-block;
  width:10px;
  height:10px;
  padding-left: 4px;
  margin-top:-2px;
  opacity:0.5;
}
#container .keySubmenu .keyOptions .keyTxt {
  position: relative;
  display:inline-block;
  font-family:'Open Sans Condensed', sans-serif;
  color:#434343;
  font-size: 12px;
  font-weight: 100;
  font-style: normal;
  padding-left: 2px;
  -webkit-transition: all 0.5s;
  -moz-transition: all 0.5s;
  -ms-transition: all 0.5s;
  -o-transition: all 0.5s;
  transition: all 0.5s;
}

/********************************* Descripciones ********************************************/
#modalDsc {
	position: relative;
	width:90%;
	height:auto;
	text-align:justify;
}
#modalDsc #contenedorDsc {
	position: relative;
	padding:8px;
}
#modalDsc #contenedorDsc .txtTitulo {
	font-size: 16px;
	font-family: 'Open Sans Condensed', sans-serif;
	font-weight:bold;
}
#modalDsc #contenedorDsc .txtTexto {
	font-size: 14px;
	font-family: 'Open Sans Condensed', sans-serif;
	font-weight:100;
}
}

/* Diseño tableta: de 481 px a 768 px. Hereda estilos de: Diseño móvil. */
@media only screen and (min-width: 481px) {
/********************************* Header ********************************************/
#header_key {
	position:relative;
	box-sizing: border-box;
	width:100%;
	height:40px;
	z-index:9999;
}
#header_key .headerTabla {
	position:relative;
	margin-top:6px;
	width:100%;
	border-spacing: 0px;
	border-collapse: collapse;
}
#header_key .headerTabla .tdHeader1 {
	width:10%;
	text-align:left;
	vertical-align:middle;
	padding-left:10px;
}
#header_key .headerTabla .tdHeader2 {
	width:80%;
	text-align:center;
	vertical-align:middle;
}
#header_key .headerTabla .tdHeader3 {
	width:10%;
	text-align:right;
	vertical-align:middle;
	padding-right:10px;
}
#header_key .headerTabla .tdHeader4 {
	width:100%;
	text-align:right;
	vertical-align:middle;
	padding-right:10px;
}
#header_key .headerTabla .imgHeaderKey {
	position:relative;
	padding: 1px;
	width:25px;
	height:25px;
	-webkit-transition: all 0.5s;
  	-moz-transition: all 0.5s;
  	-ms-transition: all 0.5s;
  	-o-transition: all 0.5s;
  	transition: all 0.5s;
	cursor:pointer;
	outline: none;
}
#header_key .headerTabla .imgHeaderKey:hover {
	opacity:0.6;
}
#header_key .headerTabla .titKey {
	position:relative;
	display:inline-block;
	color: #333;
	font-size: 20px;
	font-family: 'Open Sans Condensed', sans-serif;
	text-align: left;
	font-weight:bold;
	text-transform:uppercase;
	letter-spacing:1px;
	line-height:18px;
}
#header_key .headerTabla .txtKey {
	position:relative;
	display:none;
	color: #333;
	font-size: 13px;
	font-family: 'Open Sans Condensed', sans-serif;
	text-align: right;
	font-weight:100;
	letter-spacing:0;
	line-height:18px;
}
#header_key .headerTabla .iconKey {
	position:relative;
	display:inline-block;
	text-align: right;
}
#header_key .headerTabla .txtHideKey {
	display:none;
}

/********************************* Subheader ********************************************/
#subheader_key {
	position:relative;
	box-sizing: border-box;
	width:100%;
	height:30px;
	background:#fcfcfc;
	z-index:9999;
}
#subheader_key .subheaderTabla {
	position:relative;
	margin-top:0;
	width:100%;
	border-spacing: 0px;
	border-collapse: collapse;
}
#subheader_key .subheaderTabla .tdSubheader1 {
	width:42%;
	text-align:center;
	vertical-align:middle;
	padding-left:20px;
}
#subheader_key .subheaderTabla .tdSubheader2 {
	width:14%;
	text-align:center;
	vertical-align:middle;
}
#subheader_key .subheaderTabla .tdSubheader3 {
	width:42%;
	text-align:center;
	vertical-align:middle;
	padding-right:20px;
}

/* Estado */
label.keyLabelEdo > input.keyCheckboxEdo{ /* HIDE RADIO */
	visibility: hidden; /* Makes input not-clickable */
	position: absolute; /* Remove input from document flow */
}
label.keyLabelEdo > input.keyCheckboxEdo + img.keyImgEdo{ /* IMAGE STYLES */
	width:25px;
	height:25px;
	cursor:pointer;
	border:1px solid #6b6b6b;
}
label.keyLabelEdo > input.keyCheckboxEdo:checked + img.keyImgEdo{ /* (RADIO CHECKED) IMAGE STYLES */
	background:#DB4755;
}

/* Taxa */
label.keyLabelTax > input.keyCheckboxTax{ /* HIDE RADIO */
	visibility: hidden; /* Makes input not-clickable */
	position: absolute; /* Remove input from document flow */
}
label.keyLabelTax > input.keyCheckboxTax + img.keyImgTax{ /* IMAGE STYLES */
	width:25px;
	height:25px;
	cursor:pointer;
	border:1px solid #6b6b6b;
}
label.keyLabelTax > input.keyCheckboxTax:checked + img.keyImgTax{ /* (RADIO CHECKED) IMAGE STYLES */
	background:#DB4755;
}

/* Vista */
label.keyLabelView > input.keyCheckboxView{ /* HIDE RADIO */
	visibility: hidden; /* Makes input not-clickable */
	position: absolute; /* Remove input from document flow */
}
label.keyLabelView > input.keyCheckboxView + img.keyImgView{ /* IMAGE STYLES */
	width:25px;
	height:25px;
	cursor:pointer;
	border:1px solid #6b6b6b;
}
label.keyLabelView > input.keyCheckboxView:checked + img.keyImgView{ /* (RADIO CHECKED) IMAGE STYLES */
	background:#DB4755;
}

/********************************* Footer ********************************************/
#footer_key {
	clear: both;
	float: left;
	margin-left: 0;
	width: 100%;
	height: 20px;
	display: block;
	bottom: 0;
	background:#49a397;
	position:relative;
	z-index:100;
	text-align: center;
}
#footer_key #txtTitulo {
	position:relative;
	margin-top:1px;
	color: #ffffff;
	font-size: 14px;
	font-family: 'Open Sans Condensed', sans-serif;
	font-weight:100;
	letter-spacing:3px;
	padding-right:8px;
}

/******************************* Claves taxonómicas **************************************/
#tableKey {
	position:relative;
	top: 76px;
	width:100%;
	border:none;
	border-spacing:0;
}
#tableKey .keyCols {
	position:relative;
	width:50%;
}
#tableKey .keyCols .divKey {
	position:relative;
	font-family: 'Open Sans Condensed', sans-serif;
	overflow-y:hidden;
	overflow-x:hidden;
	font-size:14px;
	padding:10px 0 0 10px;
}
#tableKey .keyCols .divKey .txtText {
	position:relative;
	display: inline-block;
	width:100%;
	font-family: 'Open Sans Condensed', sans-serif;
	font-size:18px;
	margin: -3px 0 0 25px;
	padding: 2px 0 2px 0;
	-webkit-transition: all 0.5s;
  	-moz-transition: all 0.5s;
  	-ms-transition: all 0.5s;
  	-o-transition: all 0.5s;
  	transition: all 0.5s;
	cursor:pointer;
}
#tableKey .keyCols .divKey .txtText:hover {
	text-decoration:underline;
	color:#DB4755;
	opacity:0.7;
}
#tableKey .keyCols .txtTit {
	position:relative;
	font-family: 'Open Sans Condensed', sans-serif;
	color:#fcfcfc;
	font-size:16px;
	font-weight:bold;
	text-transform:uppercase;
	letter-spacing:4px;
	width:100%;
	text-align:center;
	vertical-align:middle;
	background:#1d1d1d;
	padding:10px 5px 5px 5px;
	margin-top:-2px;
}
#tableKey .keyCols .containerTotal {
	position:relative;
	background-color:#f1f1f1;
	box-sizing: border-box;
	width:100%;
	z-index:999;
}
#tableKey .keyCols .containerTotal .contentTotal {
	position:relative;
	display:inline-block;
	box-sizing: border-box;
	padding:2px;
	font-family: 'Open Sans Condensed', sans-serif;
	color:#1d1d1d;
	font-size:14px;
	font-weight:bold;
	letter-spacing:0;
	width:100%;
	text-align:center;
}
#tableKey .keyCols .containerTotal .contentTotal .opTotal {
	position:relative;
	display:inline-block;
	padding:0 1px 0 1px;
}

/******************************* Checkboxes **************************************/
.controlContent {
	position:relative;
}
.controlContent .textContent {
	position: relative;
	padding: 4px 0 4px 0;
}
.controlContent .textContent .txtTitOp {
	font-family: 'Open Sans Condensed', sans-serif;
	display: inline-block;
	position: relative;
	margin-bottom: 3px;
	padding-top: 0;
	cursor: pointer;
	font-size: 18px;
	font-weight: bold;
	letter-spacing: 1px;
}
.controlContent .textContent .txtImgOp {
	position: relative;
	display: inline-block;
	padding: 0 5px 0 0;
	margin-top: -4px;
	width: 18px;
	height: 18px;
	-webkit-transition: all 0.5s;
  	-moz-transition: all 0.5s;
  	-ms-transition: all 0.5s;
  	-o-transition: all 0.5s;
  	transition: all 0.5s;
  	cursor:pointer;
	outline: none;
}
.controlContent .textContent .txtImgOp:hover {
	opacity: 0.6;
}
.controlContent .marginLeftOn {
	padding-left: 15px;
}
.controlContent .marginLeftOff {
	padding-left: 0;
}
.controlContent .controlContain {
	position:relative;
}
.controlContainOp {
	position:relative;
	display: inline-block !important;
	width: 150px !important;
}
.controlContent .controlContain .control {
	font-family: 'Open Sans Condensed', sans-serif;
	display: block;
	position: relative;
	padding-left: 30px;
	margin-bottom: 3px;
	padding-top: 0;
	cursor: pointer;
	font-size: 18px;
}
.control input {
	position: absolute;
	z-index: -1;
	opacity: 0;
}
.control_indicator {
	position: absolute;
	top: 2px;
	left: 0;
	height: 20px;
	width: 20px;
	background: #e6e6e6;
	border: 0px solid #000000;
	border-radius: 0px;
}
.control:hover input ~ .control_indicator,
.control input:focus ~ .control_indicator {
	background: #cccccc;
}

.control input:checked ~ .control_indicator {
	background: #49a397;
}
.control:hover input:not([disabled]):checked ~ .control_indicator,
.control input:checked:focus ~ .control_indicator {
	background: #0e6647d;
}
.control input:disabled ~ .control_indicator {
	background: #e6e6e6;
	opacity: 0.6;
	pointer-events: none;
}
.control_indicator:after {
	box-sizing: unset;
	content: '';
	position: absolute;
	display: none;
}
.control input:checked ~ .control_indicator:after {
	display: block;
}
.control-checkbox .control_indicator:after {
	left: 8px;
	top: 4px;
	width: 3px;
	height: 8px;
	border: solid #ffffff;
	border-width: 0 2px 2px 0;
	transform: rotate(45deg);
}
.control-checkbox input:disabled ~ .control_indicator:after {
	border-color: #7b7b7b;
}
.control-checkbox .control_indicator::before {
	content: '';
	display: block;
	position: absolute;
	left: 0;
	top: 0;
	width: 3.512rem;
	height: 3.512rem;
	margin-left: -0.805rem;
	margin-top: -0.805rem;
	background: #49a397;
	border-radius: 3rem;
	opacity: 0.3;
	z-index: 99999;
	transform: scale(0);
}
@keyframes s-ripple {
	0% {
		transform: scale(0);
	}
	20% {
		transform: scale(1);
	}
	100% {
		opacity: 0;
		transform: scale(1);
	}
}
@keyframes s-ripple-dup {
   0% {
	   transform: scale(0);
	}
   30% {
		transform: scale(1);
	}
	60% {
		transform: scale(1);
	}
	100% {
		opacity: 0;
		transform: scale(1);
	}
}
.control-checkbox input + .control_indicator::before {
	animation: s-ripple 250ms ease-out;
}
.control-checkbox input:checked + .control_indicator::before {
	animation-name: s-ripple-dup;
}

/******************************* Colores **************************************/
.color_edo {
	background-color:#CDF4E4;
}
.color_tax {
	background-color:#CEE2F2;
}

/******************************* Submenú **************************************/
#container .keySubmenu {
  position: absolute;
  display: none;
  box-sizing: border-box;
  top: 0;
  left: 0;
  min-width: 220px;
  width: auto;
  height: auto;
  background-color: #f1f1f1;
  padding: 10px 0 10px 0;
  z-index: 9999888;
}
#container .keySubmenu .keyOptions {
  position: relative;
  text-align: left;
  padding: 8px 8px 8px 12px;
  -webkit-transition: all 0.5s;
  -moz-transition: all 0.5s;
  -ms-transition: all 0.5s;
  -o-transition: all 0.5s;
  transition: all 0.5s;
  cursor: pointer;  
}
#container .keySubmenu .keyOptions:hover {
  background-color: #a9a9a9;
  opacity: 0.6;
}
#container .keySubmenu .keyOptions:hover > .keyTxt {
  font-weight: bold;
}
#container .keySubmenu .keyOptions .keyIcon {
  position: relative;
  display:inline-block;
  width:18px;
  height:18px;
  padding-left: 8px;
  margin-top:-4px;
  opacity:0.5;
}
.divKey .controlContent .keyIconShow {
  position: relative;
  display:inline-block;
  width:12px;
  height:12px;
  padding-left: 8px;
  margin-top:-4px;
  opacity:0.5;
}
#container .keySubmenu .keyOptions .keyTxt {
  position: relative;
  display:inline-block;
  font-family:'Open Sans Condensed', sans-serif;
  color:#434343;
  font-size: 14px;
  font-weight: 100;
  font-style: normal;
  padding-left: 4px;
  -webkit-transition: all 0.5s;
  -moz-transition: all 0.5s;
  -ms-transition: all 0.5s;
  -o-transition: all 0.5s;
  transition: all 0.5s;
}

/********************************* Descripciones ********************************************/
#modalDsc {
	position: relative;
	width:420px;
	height:auto;
	text-align:justify;
}
#modalDsc #contenedorDsc {
	position: relative;
	padding:14px;
}
#modalDsc #contenedorDsc .txtTitulo {
	font-size: 18px;
	font-family: 'Open Sans Condensed', sans-serif;
	font-weight:bold;
}
#modalDsc #contenedorDsc .txtTexto {
	font-size: 16px;
	font-family: 'Open Sans Condensed', sans-serif;
	font-weight:100;
}
}

/* Diseño escritorio: de 769 px hasta un máximo de 1232 px.  Hereda estilos de: Diseño móvil y Diseño tableta. */
@media only screen and (min-width: 769px) {
/********************************* Header ********************************************/
#header_key {
	position:relative;
	box-sizing: border-box;
	width:100%;
	height:50px;
	z-index:9999;
}
#header_key .headerTabla {
	position:relative;
	margin-top:6px;
	width:100%;
	border-spacing: 0px;
	border-collapse: collapse;
}
#header_key .headerTabla .tdHeader1 {
	width:5%;
	text-align:left;
	vertical-align:middle;
	padding-left:20px;
}
#header_key .headerTabla .tdHeader2 {
	width:25%;
	text-align:left;
	vertical-align:middle;
}
#header_key .headerTabla .tdHeader3 {
	width:70%;
	text-align:right;
	vertical-align:middle;
	padding-right:20px;
}
#header_key .headerTabla .tdHeader4 {
	width:100%;
	text-align:right;
	vertical-align:middle;
	padding-right:20px;
}
#header_key .headerTabla .imgHeaderKey {
	position:relative;
	padding: 1px;
	width:35px;
	height:35px;
	-webkit-transition: all 0.5s;
  	-moz-transition: all 0.5s;
  	-ms-transition: all 0.5s;
  	-o-transition: all 0.5s;
  	transition: all 0.5s;
	cursor:pointer;
	outline: none;
}
#header_key .headerTabla .imgHeaderKey:hover {
	opacity:0.6;
}
#header_key .headerTabla .titKey {
	position:relative;
	display:inline-block;
	color: #333;
	font-size: 24px;
	font-family: 'Open Sans Condensed', sans-serif;
	text-align: left;
	font-weight:bold;
	text-transform:uppercase;
	letter-spacing:2px;
	line-height:18px;
}
#header_key .headerTabla .txtKey {
	position:relative;
	display:inline-block;
	color: #333;
	font-size: 15px;
	font-family: 'Open Sans Condensed', sans-serif;
	text-align: right;
	font-weight:100;
	letter-spacing:0;
	line-height:16px;
}
#header_key .headerTabla .iconKey {
	display:none;
}
#header_key .headerTabla .txtHideKey {
	display:inline-block;
}

/********************************* Subheader ********************************************/
#subheader_key {
	position:relative;
	box-sizing: border-box;
	width:100%;
	height:35px;
	background:#fcfcfc;
	z-index:9999;
}
#subheader_key .subheaderTabla {
	position:relative;
	margin-top:1px;
	width:100%;
	border-spacing: 0px;
	border-collapse: collapse;
}
#subheader_key .subheaderTabla .tdSubheader1 {
	width:45%;
	text-align:center;
	vertical-align:middle;
	padding-left:20px;
}
#subheader_key .subheaderTabla .tdSubheader2 {
	width:10%;
	text-align:center;
	vertical-align:middle;
}
#subheader_key .subheaderTabla .tdSubheader3 {
	width:45%;
	text-align:center;
	vertical-align:middle;
	padding-right:20px;
}

/* Estado */
label.keyLabelEdo > input.keyCheckboxEdo{ /* HIDE RADIO */
	visibility: hidden; /* Makes input not-clickable */
	position: absolute; /* Remove input from document flow */
}
label.keyLabelEdo > input.keyCheckboxEdo + img.keyImgEdo{ /* IMAGE STYLES */
	width:30px;
	height:30px;
	cursor:pointer;
	border:1px solid #6b6b6b;
}
label.keyLabelEdo > input.keyCheckboxEdo:checked + img.keyImgEdo{ /* (RADIO CHECKED) IMAGE STYLES */
	background:#DB4755;
}

/* Taxa */
label.keyLabelTax > input.keyCheckboxTax{ /* HIDE RADIO */
	visibility: hidden; /* Makes input not-clickable */
	position: absolute; /* Remove input from document flow */
}
label.keyLabelTax > input.keyCheckboxTax + img.keyImgTax{ /* IMAGE STYLES */
	width:30px;
	height:30px;
	cursor:pointer;
	border:1px solid #6b6b6b;
}
label.keyLabelTax > input.keyCheckboxTax:checked + img.keyImgTax{ /* (RADIO CHECKED) IMAGE STYLES */
	background:#DB4755;
}

/* Vista */
label.keyLabelView > input.keyCheckboxView{ /* HIDE RADIO */
	visibility: hidden; /* Makes input not-clickable */
	position: absolute; /* Remove input from document flow */
}
label.keyLabelView > input.keyCheckboxView + img.keyImgView{ /* IMAGE STYLES */
	width:30px;
	height:30px;
	cursor:pointer;
	border:1px solid #6b6b6b;
}
label.keyLabelView > input.keyCheckboxView:checked + img.keyImgView{ /* (RADIO CHECKED) IMAGE STYLES */
	background:#DB4755;
}


/********************************* Footer ********************************************/
#footer_key {
	clear: both;
	float: left;
	margin-left: 0;
	width: 100%;
	height: 25px;
	display: block;
	bottom: 0;
	background:#49a397;
	position:relative;
	z-index:100;
	text-align: center;
}
#footer_key #txtTitulo {
	position:relative;
	margin-top:4px;
	color: #ffffff;
	font-size: 16px;
	font-family: 'Open Sans Condensed', sans-serif;
	font-weight:100;
	letter-spacing:4px;
	padding-right:10px;
}

/******************************* Claves taxonómicas **************************************/
#tableKey {
	position:relative;
	top: 70px;
	width:100%;
	border:none;
	border-spacing:0;
}
#tableKey .keyCols {
	position:relative;
	width:50%;
}
#tableKey .keyCols .divKey {
	position:relative;
	font-family: 'Open Sans Condensed', sans-serif;
	overflow-y:hidden;
	overflow-x:hidden;
	font-size:16px;
	padding:10px 0 0 10px;
}
#tableKey .keyCols .divKey .txtText {
	position:relative;
	display: inline-block;
	width:100%;
	font-family: 'Open Sans Condensed', sans-serif;
	font-size:20px;
	margin: -4px 0 0 30px;
	padding: 2px 0 2px 0;
	-webkit-transition: all 0.5s;
  	-moz-transition: all 0.5s;
  	-ms-transition: all 0.5s;
  	-o-transition: all 0.5s;
  	transition: all 0.5s;
	cursor:pointer;
}
#tableKey .keyCols .divKey .txtText:hover {
	text-decoration:underline;
	color:#DB4755;
	opacity:0.7;
}
#tableKey .keyCols .txtTit {
	position:relative;
	font-family: 'Open Sans Condensed', sans-serif;
	color:#fcfcfc;
	font-size:18px;
	font-weight:bold;
	text-transform:uppercase;
	letter-spacing:5px;
	width:100%;
	text-align:center;
	vertical-align:middle;
	background:#1d1d1d;
	padding:8px;
	margin-top:-2px;
}
#tableKey .keyCols .containerTotal {
	position:relative;
	background-color:#f1f1f1;
	box-sizing: border-box;
	width:100%;
	z-index:999;
}
#tableKey .keyCols .containerTotal .contentTotal {
	position:relative;
	display:inline-block;
	box-sizing: border-box;
	padding:4px;
	font-family: 'Open Sans Condensed', sans-serif;
	color:#1d1d1d;
	font-size:16px;
	font-weight:bold;
	letter-spacing:0;
	width:100%;
	text-align:center;
}
#tableKey .keyCols .containerTotal .contentTotal .opTotal {
	position:relative;
	display:inline-block;
	padding:0 1px 0 1px;
}

/******************************* Checkboxes **************************************/
.controlContent {
	position:relative;
}
.controlContent .textContent {
	position: relative;
	padding: 5px 0 5px 0;
}
.controlContent .textContent .txtTitOp {
	font-family: 'Open Sans Condensed', sans-serif;
	display: inline-block;
	position: relative;
	margin-bottom: 3px;
	padding-top: 0;
	cursor: pointer;
	font-size: 20px;
	font-weight: bold;
	letter-spacing: 2px;
}
.controlContent .textContent .txtImgOp {
	position: relative;
	display: inline-block;
	padding: 0 5px 0 0;
	margin-top: -5px;
	width: 20px;
	height: 20px;
	-webkit-transition: all 0.5s;
  	-moz-transition: all 0.5s;
  	-ms-transition: all 0.5s;
  	-o-transition: all 0.5s;
  	transition: all 0.5s;
  	cursor:pointer;
	outline: none;
}
.controlContent .textContent .txtImgOp:hover {
	opacity: 0.6;
}
.controlContent .marginLeftOn {
	padding-left: 20px;
}
.controlContent .marginLeftOff {
	padding-left: 0;
}
.controlContent .controlContain {
	position:relative;
}
.controlContainOp {
	position:relative;
	display: inline-block !important;
	width: 150px !important;
}
.controlContent .controlContain .control {
	font-family: 'Open Sans Condensed', sans-serif;
	display: block;
	position: relative;
	padding-left: 30px;
	margin-bottom: 3px;
	padding-top: 0;
	cursor: pointer;
	font-size: 20px;
}
.control input {
	position: absolute;
	z-index: -1;
	opacity: 0;
}
.control_indicator {
	position: absolute;
	top: 2px;
	left: 0;
	height: 20px;
	width: 20px;
	background: #e6e6e6;
	border: 0px solid #000000;
	border-radius: 0px;
}
.control:hover input ~ .control_indicator,
.control input:focus ~ .control_indicator {
	background: #cccccc;
}

.control input:checked ~ .control_indicator {
	background: #49a397;
}
.control:hover input:not([disabled]):checked ~ .control_indicator,
.control input:checked:focus ~ .control_indicator {
	background: #0e6647d;
}
.control input:disabled ~ .control_indicator {
	background: #e6e6e6;
	opacity: 0.6;
	pointer-events: none;
}
.control_indicator:after {
	box-sizing: unset;
	content: '';
	position: absolute;
	display: none;
}
.control input:checked ~ .control_indicator:after {
	display: block;
}
.control-checkbox .control_indicator:after {
	left: 8px;
	top: 4px;
	width: 3px;
	height: 8px;
	border: solid #ffffff;
	border-width: 0 2px 2px 0;
	transform: rotate(45deg);
}
.control-checkbox input:disabled ~ .control_indicator:after {
	border-color: #7b7b7b;
}
.control-checkbox .control_indicator::before {
	content: '';
	display: block;
	position: absolute;
	left: 0;
	top: 0;
	width: 3.512rem;
	height: 3.512rem;
	margin-left: -0.805rem;
	margin-top: -0.805rem;
	background: #49a397;
	border-radius: 3rem;
	opacity: 0.3;
	z-index: 99999;
	transform: scale(0);
}
@keyframes s-ripple {
	0% {
		transform: scale(0);
	}
	20% {
		transform: scale(1);
	}
	100% {
		opacity: 0;
		transform: scale(1);
	}
}
@keyframes s-ripple-dup {
   0% {
	   transform: scale(0);
	}
   30% {
		transform: scale(1);
	}
	60% {
		transform: scale(1);
	}
	100% {
		opacity: 0;
		transform: scale(1);
	}
}
.control-checkbox input + .control_indicator::before {
	animation: s-ripple 250ms ease-out;
}
.control-checkbox input:checked + .control_indicator::before {
	animation-name: s-ripple-dup;
}

/******************************* Colores **************************************/
.color_edo {
	background-color:#CDF4E4;
}
.color_tax {
	background-color:#CEE2F2;
}

/******************************* Submenu **************************************/
#container .keySubmenu {
  position: absolute;
  display: none;
  box-sizing: border-box;
  top: 0;
  left: 0;
  min-width: 250px;
  width: auto;
  height: auto;
  background-color: #f1f1f1;
  padding: 15px 0 15px 0;
  z-index: 9999888;
}
#container .keySubmenu .keyOptions {
  position: relative;
  text-align: left;
  padding: 10px 10px 10px 15px;
  -webkit-transition: all 0.5s;
  -moz-transition: all 0.5s;
  -ms-transition: all 0.5s;
  -o-transition: all 0.5s;
  transition: all 0.5s;
  cursor: pointer;  
}
#container .keySubmenu .keyOptions:hover {
  background-color: #a9a9a9;
  opacity: 0.6;
}
#container .keySubmenu .keyOptions:hover > .keyTxt {
  font-weight: bold;
}
#container .keySubmenu .keyOptions .keyIcon {
  position: relative;
  display:inline-block;
  width:20px;
  height:20px;
  padding-left: 10px;
  margin-top:-5px;
  opacity:0.5;
}
.divKey .controlContent .keyIconShow {
  position: relative;
  display:inline-block;
  width:15px;
  height:15px;
  padding-left: 10px;
  margin-top:-5px;
  opacity:0.5;
}
#container .keySubmenu .keyOptions .keyTxt {
  position: relative;
  display:inline-block;
  font-family:'Open Sans Condensed', sans-serif;
  color:#434343;
  font-size: 16px;
  font-weight: 100;
  font-style: normal;
  padding-left: 5px;
  -webkit-transition: all 0.5s;
  -moz-transition: all 0.5s;
  -ms-transition: all 0.5s;
  -o-transition: all 0.5s;
  transition: all 0.5s;
}

/********************************* Descripciones ********************************************/
#modalDsc {
	position: relative;
	width:720px;
	height:auto;
	text-align:justify;
}
#modalDsc #contenedorDsc {
	position: relative;
	padding:20px;
}
#modalDsc #contenedorDsc .txtTitulo {
	font-size: 20px;
	font-family: 'Open Sans Condensed', sans-serif;
	font-weight:bold;
}
#modalDsc #contenedorDsc .txtTexto {
	font-size: 18px;
	font-family: 'Open Sans Condensed', sans-serif;
	font-weight:100;
}
}