/*+clearfix {*/
#banner:after {
  content: ".";
  display: block;
  height: 0;
  clear: both;
  visibility: hidden;
  font-size: 0;
}
#banner {
  display: block;
  *height: 1px;
}
/*+}*/
@font-face {
  font-family: 'MyriadPro';
  src: url('MyriadPro-Regular_1.otf') format('opentype');
  font-weight: normal;
  font-style: normal;
}
@font-face {
  font-family: 'MyriadPro';
  src: url('MyriadPro-Semibold_2.otf') format('opentype');
  font-weight: bold;
  font-style: normal;
}
@font-face {
  font-family: 'MyriadPro';
  src: url('MyriadPro-It_3.otf') format('opentype');
  font-weight: normal;
  font-style: italic;
}
:root {
  --rojo: #BD0926;
  --amarillo: #ffc500;
  --c1: #42210b;
  --c2: #254093;
  --c3: #efebe7;
  --c3_6p: #efebe799;
  --c4: #b73e18;
}
*, *:before, *:after {
  box-sizing: border-box;
}
body {
  background: #FFF;
  margin: 0 auto;
  font-family: MyriadPro, sans-serif;
  font-weight: 400;
  font-size: 100%;
  font-style: normal;
  /*overflow-x: hidden;*/
  height: 100%;
  min-height: 100vh;
  color:var(--c1);
  padding-bottom: 40px;
  border-bottom: 4px solid var(--c2);
}
button, input, optgroup, select, textarea {
  font-family: inherit;
  font-weight: 300;
}
figure {
  margin: 0px;
}
h1, h2, h3, h4, h5 {
  font-weight: inherit;
  color:var(--c1);
  margin: 0;
}
h1 {
  color:var(--c1);
  font-size: 1.875rem;
  font-weight: 300;
}
button {
  cursor: pointer;
}
button[type=submit]:disabled {
  cursor: default;
}
p {
  display: block;
  margin: 0 0 1rem 0;
  line-height: 1.3;
}
ul {
  list-style-type: none;
  padding: 0;
}
a {
  text-decoration: none;
  color: inherit;
}
#cargando {
  display: none;
  position: fixed;
  z-index: 1000000000;
  margin: 60px auto;
  width: 100%;
  text-align: center;
}
#cargando .pelota {
  border: 3px solid;
  border-color: var(--rojo) #FFF;
  background: rgba(255, 255, 255, 0.5);
  border-radius: 50%;
  box-shadow: 0 0 15px var(--rojo);
  width: 60px;
  height: 60px;
  margin: 0 auto;
  z-index: -1;
  animation: loop 2.5s infinite linear;
  background: rgba(188, 9, 38, 0.663);
}
#cargando p {
  position: relative;
  top: calc(-0.675rem + -30px);
  font-size: 0.675rem;
  font-weight: 400;
  color: #FFF;
}
@keyframes loop {
  from {
    transform: rotate(0deg);
  }
  to {
    transform: rotate(360deg);
  }
}
.botonera button, .btn {
  border: none;
  background-color: var(--rojo);
  color: #FFF;
  padding: 8px 20px;
  display: inline-block;
  cursor: pointer;
  line-height: 1rem;
  font-family: inherit;
  font-weight: 400;
}
.botonera button.BtnAtras, .btn.BtnAtras {
  background: #CCC;
  color: #000;
}
.msg {
  border-radius: 2px;
  border: 1px solid #12A112;
  padding: 5px 7px 5px 10px;
  text-transform: uppercase;
  color: #12A112;
  background-color: #E1FBDC;
  display: none;
  text-align: center !important;
  /*font: 300 14px / 1.3em 'Roboto', sans-serif;*/
  font-size: 0.8rem;
  margin-bottom: 10px;
}
.msg a {
  text-decoration: underline;
}
.msg.error {
  color: #C00;
  border-color: #C00;
  background-color: #FFCFCF;
}
.desactivado {
  opacity: 0.5;
  pointer-events: none;
}
.cont_max, main {
  position: relative;
  max-width: 1280px;
  margin: 0 auto;
  padding: 0 20px;
}
.mInicio {
  padding: 0;
}
.ilightbox {
  cursor: pointer;
}
.videoEmbed {
  position: relative;
  padding-bottom: 56.25%;
  /* 16:9 */
  padding-top: 25px;
  height: 0;
  overflow: hidden;
  max-width: 100%;
}
.videoEmbed iframe {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
}
.videoEmbed video {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
}
/*varios*/
.leermas {
  display: inline-block;
  font-size: 0.812rem;
  font-weight: 400;
  color: #F9660A;
  border: 1px solid #F9660A;
  padding: 6px 12px;
}
/*cabecera*/
.pHeader {
  text-align: left;
  padding: 20px 0;
}
.pHeader .minibanner {
  width: calc(100% + 40px);
  margin: 20px -20px 0;
  position: relative;
}
.pHeader .minibanner img {
  width: 100%;
  height: 75px;
  display: block;
  object-fit: cover;
}
.pHeader .minibanner:after {
  background: url(/imgs/logo_azul.png) 50% / auto 65px no-repeat;
  content: "";
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  bottom: 0;
  pointer-events: none;
}
/*pie*/
body > footer {
  color: #FFF;
  background-color:var(--c2);
  padding: 0 0 4px;
  text-align: center;
  font-size: 0.812rem;
  position: relative;
  margin-top: 40px;
}
/*Menú hamburguesa*/
#botonMenu {
  width: 25px;
  height: 20px;
  cursor: pointer;
  border:4px solid var(--c1);
  border-width: 4px 0;
  display: inline-block;
  /*float: right;*/
  margin-left: 0px;
  /*margin-top: 14px;*/
  /*clear: both;*/
}
#botonMenu::before {
  display: block;
  height: 4px;
  content: ' ';
  margin-top: 4px;
  background:var(--c1);
}
#menu {
  display: none;
  font-weight: 300;
  /*position: relative;*/
}
#menu .cerrar {
  position: absolute;
  right: 10px;
  font-size: 3.4rem;
  top: -6px;
  cursor: pointer;
}
body.ham {
  overflow-y: hidden;
}
#apagon {
  display: none;
}
.ham .apagon {
  opacity: 0.4;
  background: #000;
  display: block;
  position: fixed;
  width: 100vw;
  height: 100vh;
  top: 0;
  left: 0;
  z-index: 99998;
}
.ham #menu {
  position: fixed;
  display: block;
  top: 0;
  left: 0;
  bottom: 0;
  background: #212121;
  background:url(/imgs/logo_azul.png) 20px 10px / 150px auto no-repeat var(--c2);
  color: #FFF;
  z-index: 99999;
  padding: 5px 0 20px;
  box-shadow: 0 0 17px #444;
  width: 300px;
  overflow-y: scroll;
  animation: menuIn 0.6s;
}
.ham #cerrarMenu {
  display: block;
  position: absolute;
  right: 10px;
  top: 5px;
  font-size: 40px;
  cursor: pointer;
}
@keyframes menuIn {
  from {
    left: -300px;
  }
  to {
    left: 0;
  }
}
.ham #menu > ul {
  margin-top: 80px;
}
.ham #menu > ul ul {
  margin-top: 10px;
}
.ham #menu > ul ul li {
  padding: 0;
}
.ham #menu > ul ul li a {
  display: block;
  font-size: 1.1rem;
  padding: 15px 0 15px 20px;
}
.ham #menu > ul li a {
  display: block;
}
.ham #menu > ul li {
  padding: 20px;
  white-space: nowrap;
}
.ham #menu > ul > li {
  padding: 20px;
  font-weight: 300;
  border-bottom: 1px solid #FFF;
}
.ham #menu > ul > li:last-of-type {
  border-bottom: none;
}
#menu li {
  font-size: 1.2rem;
}
#menu #familias h2 {
  background: #F9660A;
  padding: 5px 15px 5px 5px;
  text-align: left;
  margin-top: 20px;
  font-size: 1rem;
}
#menu #familias img {
  margin-right: 10px;
  vertical-align: top;
}
#menu #familias li {
  padding: 10px;
  font-family: 'Roboto', sans-serif;
  font-size: 0.812rem;
}
body > header .info {
  display: none;
  text-align: right;
  font-family: 'Futured', sans-serif;
}
body > header .info .tel {
  font-size: 1.5rem;
  display: block;
  color: #F9660A;
}
body > header .info .mail {
  font-size: 0.7rem;
  display: block;
  text-transform: uppercase;
}
/*Banner home*/
.allinone_bannerRotator_texts {
  bottom: initial !important;
}
.allinone_bannerRotator {
  max-width: 100%;
}
/*[clearfix]*/
#banner {
  position: relative;
  z-index: 0;
  max-width: 1280px;
  margin: 0 auto 0;
  background: #FFF;
  cursor: pointer;
}
#banner .logo {
  position: absolute;
  top: 50%;
  left: 50%;
  width: 500px;
  max-width: 50%;
  z-index: 999;
  transform: translate(-50%, -50%);
}
#banner .banner {
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  line-height: 1.3;
}
#banner .banner h2 {
  color:var(--c2);
  background-color:var(--c3);
  font-size: 170%;
  font-weight: 400;
  text-transform: none;
  text-align: center;
  position: absolute;
  width: 100%;
  top: 0vw;
  bottom: 0;
}
/*Home*/
#mInicio {
  text-align: center;
}
#mInicio blockquote span {
  font-size: 2.4rem;
  line-height: 0;
}
#mInicio blockquote cite {
  display: block;
  text-align: right;
  font-size: 1rem;
  margin: 10px 0 0;
  font-weight: normal;
}
/*CRONOLOGIA*/
.mCronologia h1 {
  text-transform: uppercase;
}
.mCronologia dt span {
  display: inline-flex;
  border: 1px solid;
  justify-content: center;
  align-items: center;
  border-radius: 50%;
  width: 50px;
  height: 50px;
  margin-bottom: 10px;
}
.mCronologia dt.alargado span {
  border-radius: 10px;
  width: auto;
  height: auto;
  padding: 3px 20px 2px;
}
.mCronologia dd {
  margin-bottom: 30px;
}
.mCronologia dd p:last-of-type {
  margin-bottom: 0;
}
/*IMAGENES*/
.mImagenes {
  display: flex;
  flex-wrap: wrap;
  justify-content: space-between;
}
.mImagenes h1 {
  width: 100%;
  margin-bottom: 40px;
  text-transform: uppercase;
}
.mImagenes figure {
  margin-bottom: 40px;
  text-align: center;
  flex: 0 1 calc(50% - 5px);
}
.mImagenes figcaption {
  margin: 7px 10px 0;
}
.mImagenes img {
  max-width: 100%;
  display: block;
}
/*DECADAS*/
.mDecadas {
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
}
.mDecadas h1 {
  width: 100%;
  margin-bottom: 40px;
  text-transform: uppercase;
}
.mDecadas figure {
  margin-bottom: 40px;
  text-align: center;
}
.mDecadas figure div {
  position: relative;
  margin-bottom: 10px;
}
.mDecadas figure h2 {
  position: absolute;
  bottom: 20px;
  left: 0;
  right: 0;
  text-align: right;
  padding: 5px 10px 5px 0;
  font-size: 1rem;
  background: linear-gradient(90deg, transparent 0, #FFF 100%);
}
.mDecadas img {
  max-width: 100%;
  direction: ;
  display: block;
}
/*OLEOS*/
.mOleos {
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
}
.mOleos h1 {
  width: 100%;
  margin-bottom: 40px;
  text-transform: uppercase;
}
.mOleos figure {
  margin-bottom: 50px;
  text-align: center;
}
.mOleos figcaption {
  margin-top: 10px;
}
.mOleos figcaption div {
  color: #000;
  margin-top: 10px;
}
.mOleos img {
  max-width: 100%;
}
/*CRITICAS*/
.mCriticas h1 {
  margin-bottom: 20px;
}
.mCriticas .abc {
  text-align: center;
  margin: 40px 0;
}
.mCriticas .abc button {
  border: none;
  background:var(--c3);
  color:var(--c1);
  font-weight: bold;
  text-transform: uppercase;
  border-radius: 50%;
  width: 26px;
  height: 26px;
  display: flex;
  justify-content: center;
  align-items: center;
  display: inline-block;
  margin: 0 10px;
}
.mCriticas .inicial {
  column-count: 2;
  position: relative;
  background:var(--c3_6p);
  padding: 80px 20px 40px;
}
.mCriticas .inicial:not(:first-of-type) {
  display: none;
}
.mCriticas .inicial a {
  color:var(--c4);
  text-decoration: underline;
  display: block;
  margin: 0 10px 10px;
}
.mCriticas .inicial h2 {
  position: absolute;
  color: #000;
  text-transform: uppercase;
  font-weight: bold;
  top: 20px;
  font-size: 2rem;
}
/*CRITICA*/
.mCritica h1 small {
  display: block;
  font-size: 0.875rem;
  font-style: italic;
}
/*BLOQUE IMAGEN TXT*/
.bloque_imagen_txt {
  padding: 0 20px;
  margin: 40px 0;
}
.bloque_imagen_txt.noimgs .imagenes {
  display: none;
}
.bloque_imagen_txt figure {
  margin-bottom: 40px;
}
.bloque_imagen_txt img {
  max-width: 100%;
}
.bloque_imagen_txt figcaption {
  color:var(--c2);
}
.bloque_imagen_txt .contenido_html {
  text-align: left;
}
.bloque_imagen_txt .contenido_html h1 {
  text-transform: uppercase;
  margin-bottom: 20px;
}
.bloque_imagen_txt blockquote {
  background:var(--c3);
  color:var(--c2);
  padding: 30px;
  width: calc(100% + 40px);
  margin: 20px -20px 0;
  font-size: 1.3rem;
  font-weight: bold;
  line-height: 1.8;
}
/*info 4 columnas*/
.col4_info li {
  padding: 0;
  margin: 20px 0 10px;
  position: relative;
  display: inline-block;
  font-size: 0.875rem;
  width: 90%;
  max-width: 300px;
  vertical-align: top;
  box-sizing: border-box;
  text-align: center;
}
.col4_info li:last-of-type {
  margin-bottom: 20px;
}
@media screen and (min-width: 500px) {
  .col4_info li {
    padding: 0;
    margin: 20px 0 10px;
    position: relative;
    display: inline-block;
    font-size: 0.875rem;
    width: 40%;
    max-width: 300px;
    vertical-align: top;
    box-sizing: border-box;
    text-align: center;
  }
}
.col4_info li img {
  margin-bottom: 15px;
  display: block;
  margin: 0 auto;
}
.col4_info li p {
  margin: 10px 0 0;
  color: #333;
}
.col4_info li p small {
  display: block;
  color: #666;
}
/*info 3 columnas*/
.col3_info h2 {
  font-size: 1.875rem;
}
.col3_info li {
  margin: 20px 0;
  position: relative;
  color: #555;
  display: inline-block;
  font-size: 0.875rem;
  width: 90%;
}
.col3_info li img {
  max-width: 100%;
  height: auto;
}
/*contenido_html*/
.contenido_html {
  /*font-size: 0.9rem;*/
  line-height: 1.3;
}
.contenido_html p {
  /*margin: 0 0 20px;*/
  /*line-height: 1.5;*/
}
.contenido_html figure img {
  display: block;
}
.contenido_html figure p {
  margin: 0;
}
.contenido_html figure p:last-child {
  /*pie de foto*/
  font-size: 90%;
  margin-top: 5px;
}
.contenido_html strong {
  /*font-weight: 500;*/
}
.contenido_html img {
  max-width: 100%;
  height: auto !important;
}
.contenido_html ul {
  padding: 10px 40px;
  list-style-type: square;
  line-height: 2em;
}
.contenido_html .videoEmbed {
  position: relative;
  padding-bottom: 56.25%;
  /* 16:9 */
  padding-top: 25px;
  height: 0;
}
.contenido_html .videoEmbed iframe {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
}
.contenido_html table {
  border: none;
  border-collapse: collapse;
  text-align: initial;
  color: #222;
}
.contenido_html tr:nth-child(odd) {
  border-bottom: solid #9CC2E5 1px;
  background: #DEEAF6;
}
.contenido_html tr {
  border-bottom: solid #9CC2E5 1px;
  background: #FFF;
}
.contenido_html tr:first-of-type {
  font-size: 1rem;
  font-weight: 500;
  color: #FFF;
  background:var(--c2);
  border: 0;
}
.contenido_html td {
  border: none;
  padding: 6px 10px;
}
.contenido_html td p:last-of-type {
  margin: 0;
}
@media screen and (max-width: 500px) {
  .contenido_html td {
    display: block;
  }
  .contenido_html tr:first-of-type {
    display: flex;
    justify-content: space-around;
  }
  .contenido_html tr:first-of-type {
    display: flex;
    justify-content: space-around;
  }
  .contenido_html tr:first-of-type td {
    display: inline-block;
  }
}
.contenido_html a[href] {
  text-decoration: underline;
}
/*paginador*/
#paginador {
  font-weight: 400;
  font-size: 0.9rem;
}
#paginador .siguiente {
  float: right;
}
/*mapaweb*/
#mMapaWeb ul {
  list-style: square;
  padding: 10px 0px 0px 40px;
}
#mMapaWeb li {
  padding: 0 0 10px 0;
}
/*Contacto*/
#mContacto h1 {
  margin-bottom: 40px;
}
#mContacto input:not([type=checkbox]), #mContacto textarea {
  display: block;
  margin: 5px 0 20px;
  padding: 4px 5px 2px;
  width: 90%;
  font-size: 0.9rem;
}
#mContacto textarea {
  height: 8rem;
}
#mContacto .btn {
  margin: 20px 0;
}
#mContacto address {
  line-height: 1.5rem;
  font-style: normal;
}
#mContacto .msg {
  margin: 20px 0;
}
#mContacto iframe {
  width: 100%;
  max-width: 1180px;
  margin-bottom: 40px;
}
#mContacto ul {
  list-style-type: initial;
  padding-left: 20px;
  margin-bottom: 40px;
}
#mContacto li {
  margin-bottom: 20px;
}
#mContacto form {
  margin-bottom: 40px;
}
#mContacto a {
  text-decoration: underline;
}
#mContacto #detalle {
  /*bots*/
  display: none;
}
#mObras_museos .ver_obras {
  cursor: pointer;
  font-size: 80%;
  text-decoration: underline;
}
#mObras_museos table {
  border: none;
  border-collapse: collapse;
  text-align: initial;
  color: #222;
  width: 100%;
  max-width: 800px;
  margin: 30px auto;
}
#mObras_museos tr:nth-child(odd) {
  border-bottom: solid #9CC2E5 1px;
  background: #DEEAF6;
}
#mObras_museos tr {
  border-bottom: solid #9CC2E5 1px;
  background: #FFF;
}
#mObras_museos tr:first-of-type {
  font-size: 1rem;
  font-weight: 500;
  color: #FFF;
  background:var(--c2);
  border: 0;
}
#mObras_museos td {
  border: none;
  padding: 6px 10px;
}
/*Fundacion*/
#mFundacion h1 {
  margin-bottom: 40px;
}
#mFundacion .imagenes {
  display: flex;
  flex-wrap: wrap;
  margin-bottom: 40px;
  margin-right: -5px;
}
#mFundacion .imagenes img {
  width: 100%;
  display: block;
}
#mFundacion .imagenes a {
  flex: 0 calc(100% / 3 - 5px);
  margin: 0 5px 5px 0;
}
