﻿@font-face { font-family: 'Graphik XXCond Web'; src: url('/css/GraphikXXCondWeb-Bold.woff2') format('woff2'), url('/css/GraphikXXCondWeb-Bold.woff') format('woff'); font-weight: bold; font-style: normal; font-display: swap; }

/*Reseteo la hoja de estilos*/
:root { --pix-color-primario: #546e7a; --pix-color-fondo-suave: #f7f7f7; --color-rojo-cre: #f5333f; --color-azul-cre: #091e3d; --color-gris-cre: #323232; --color-gris-claro-cre: #f2f2f2 }
* { box-sizing: border-box; font-family: 'Open Sans', sans-serif; }
html, body { margin: 0; padding: 0; background-color: var(--pix-color-fondo-suave); }

.pix-campo .pix-span-error, .pix-campo.pix-no-valido > label, .pix-campo.limite > label, #btnPolitica { color: var(--color-rojo-cre) }
.pix-campo.pix-no-valido:after { background-color: var(--color-rojo-cre) !important }
/*General*/
a { text-decoration: none; outline: none; }
img { max-height: 100%; max-width: 100%; }

figure.image img {  height: unset !important; aspect-ratio: auto !important; }

input:invalid { scroll-margin-top: 100px; /* deja 100px de margen al hacer scroll */ }

.div-snackbar > div { background-color: var(--color-azul-cre); color: #fff }

h2 { font-family: 'Graphik XXCond Web', sans-serif; color: var(--color-azul-cre); text-transform: uppercase; font-size: 52px; margin-top: 0; margin-bottom: 16px }
h3 { text-transform: uppercase; font-weight: 400 }

p { color: var(--color-gris-cre); margin-top: 0; margin-bottom: 24px }
.secInterior { padding-bottom: 48px; padding-top: 32px; min-height: calc(100vh - 128px) }
.secInterior h1 { margin-top: 0; font-size: 40px; font-weight: 300; margin-bottom:16px }
.botonera { text-align: center; padding-top: 32px }

.pix-campo.pix-foco:after { background-color: var(--color-azul-cre) }
.pix-campo > label { color: #727272 }
.pix-campo.pix-foco > label { color: var(--color-gris-cre) }
.pix-fila > div, .pix-fila-dec > div { font-size: 14px; color: var(--color-gris-cre) }

.pix-check > label input:checked ~ .pix-marcado { background-color: var(--color-azul-cre); border-color: var(--color-azul-cre) }

.btnPrimario { border: none; cursor: pointer; font-size: 18px; font-family: 'Montserrat', sans-serif; text-transform: uppercase; background-color: var(--color-rojo-cre); color: #fff; line-height: 60px; white-space: nowrap; display: inline-block; border-radius: 30px; font-weight: bold; padding: 0 32px; transition: background-color .1s; max-width: 100%; overflow: hidden; text-overflow: ellipsis; }
.btnPrimario:hover { background-color: var(--color-azul-cre); box-shadow: 0 0 10px rgba(0,0,0,.1) }
.btnSecundario { cursor: pointer; font-size: 18px; font-family: 'Montserrat', sans-serif; text-transform: uppercase; background-color: transparent; border: solid 2px #fff; color: #fff; line-height: 52px; white-space: nowrap; display: inline-block; border-radius: 28px; font-weight: bold; padding: 0 24px }
.btnSecundario:hover { background-color: var(--color-rojo-cre); border-color: var(--color-rojo-cre) }
::selection { background: var(--color-rojo-cre); color: #fff; text-shadow: none; }
::-moz-selection { background: var(--color-rojo-cre); color: #fff; text-shadow: none; }


/*Header (topbar)*/
header { display: table; width: 100%; table-layout: fixed; font-size: 0 }
header > div { display: table-cell }
header #divRellenoIzq { background-color: #fff; }
header #divRellenoDer { background-color: var(--color-rojo-cre); }
header #divColumnaHeader > div { display: table; width: 100%; }
header #divColumnaHeader > div > div { display: table-cell; vertical-align: top }
header #divColumnaHeader > div > div#celdaLogoCRE { background-color: #fff; width: 1% }
header #divColumnaHeader > div > div#celdaLogoCRE a { display: inline-block; padding: 16px 8px 16px 0; width: 130px }
header #divColumnaHeader > div > div#celdaLogoCRE img { height: 32px; aspect-ratio: 4/1 }
header #divColumnaHeader > div > div#celdaCongreso { width: 1%; background-color: var(--color-azul-cre); white-space: nowrap; padding-left: 64px; position: relative }
header #divColumnaHeader > div > div#celdaCongreso > h1 { font-family: 'Graphik XXCond Web', sans-serif; font-size: 22px; color: #fff; line-height: 64px; margin: 0 }
header #divColumnaHeader > div > div#celdaCongreso:before { content: ''; position: absolute; left: 0; top: 0; border-left: solid 64px #fff; border-bottom: solid 64px transparent; display: block }
header #divColumnaHeader > div > div#celdaMenu { background-color: var(--color-rojo-cre); position: relative; padding-left: 64px }
header #divColumnaHeader > div > div#celdaMenu:before { content: ''; position: absolute; left: 0; top: 0; border-left: solid 64px var(--color-azul-cre); border-bottom: solid 64px transparent; display: block }
header #divColumnaHeader > div > div#celdaMenu nav { display: none }



/*Hero*/
#secHero { background-color: var(--color-azul-cre); background-repeat: no-repeat; background-size: cover; background-position: center center; position: relative }
#secHero > div { padding-top: 80px; padding-bottom: 140px; }
#secHero #imgTuImpulso { width: 600px; margin-bottom: 40px }
#secHero p { width: 420px; color: #fff; z-index: 1; font-size: 16px; margin-bottom: 0; margin-top: 24px }

@media only screen and (min-width: 801px) {
    .pix-menu { display: inline-block; }
}

@media only screen and (max-width:768px) {
    /*Hero*/
    #secHero { background-image: url(/img/voluntaria-cruz-roja-ayudando-a-nina-con-tareas-escolares-v.webp); height: calc(100vh - 64px); background-position: center bottom }
    #secHero > div { padding-top: 40px; padding-bottom: 70px; }
    #secHero #imgTuImpulso { width: 100%; margin-bottom: 12px }
    #secHero p { width: 100%; margin-top: 12px; font-size: 15px }
    #secHero #tituloMv { color: #fff; font-size: 16px; text-transform: uppercase; font-family: 'Graphik XXCond Web',sans-serif; display: block; width: 100%; white-space: nowrap; text-overflow: ellipsis; overflow: hidden; margin-top: 0; margin-bottom: 12px; font-size: 26px; text-align: center }
}

@media only screen and (min-width: 1460px) {
    #secHero #imgTuImpulso { width: 680px }
    #secHero > div { padding-top: 170px; padding-bottom: 190px; }
}



/*Destacados (participa y premios)*/
#asdDestacados { pointer-events: none; transform: translateY(-120px) }
#asdDestacados a { pointer-events: all; transition: background-color .1s; border-radius: 2px; float: right; width: 280px; height: 280px; padding: 32px; display: block; clear: right; background: #fff; margin-bottom: 16px; transition: box-shadow .1s }
#asdDestacados a:last-child { margin-bottom: 0 }
#asdDestacados a:hover { box-shadow: 3px 5px 10px rgba(0,0,0,.1); }
#asdDestacados a > span.spanNum { color: var(--color-azul-cre); font-family: 'Montserrat', sans-serif; display: block; font-size: 32px; font-weight: bold }
#asdDestacados a > strong { color: var(--color-azul-cre); font-family: 'Montserrat', sans-serif; font-size: 36px; padding: 24px 0; display: block; color: var(--color-gris-cre) }
#asdDestacados a > span.spanTexto { color: var(--color-gris-cre); display: block; font-size: 24px; color: var(--color-gris-cre) }
#asdDestacados a#btnParticipa:not(:hover) { background-color: var(--color-rojo-cre) }
#asdDestacados a:hover { background-color: var(--color-azul-cre) }
#asdDestacados a:hover span.spanNum { color: var(--color-rojo-cre) }
#asdDestacados a#btnParticipa > strong, #asdDestacados a#btnParticipa > span.spanTexto, #asdDestacados a:hover > strong, #asdDestacados a:hover > span.spanTexto { color: #fff }

/*Contamos contigo*/
#secContamosContigo { padding-top: 120px; padding-bottom: 96px; background: linear-gradient(to right,#fff, var(--color-gris-claro-cre)) }

@media only screen and (max-width:768px) {
    #secContamosContigo { padding-bottom: 16px; }
}
/*Precongreso y congreso*/
#secPrecongreso { background: #fff }
#secPrecongreso .divImg { background-image: url(/img/voluntarias-cruz-roja-preparando-comida.webp) }
.divSeccionCuadros { display: flex; width: 100%; gap: 16px }
.divSeccionCuadros > div { flex: 1; border-radius: 2px }
.divSeccionCuadros > .divImg { background-size: cover; background-position: center center; }
.divSeccionCuadros > .divContenido { background-color: var(--color-gris-claro-cre); }
.divSeccionCuadros > .divContenido > div { padding: 64px }
#secCongreso { background: #fff; padding-top: 16px; padding-bottom: 120px }
#secCongreso .divImg { background-image: url(/img/voluntarias-cruz-roja-descansando.webp) }
#secCongreso .divSeccionCuadros { flex-direction: row-reverse; }

/*Programa*/
#secPrograma { background-color: var(--color-azul-cre); padding: 120px 0 }
#secPrograma h2 { text-align: center; color: #fff }
#secPrograma p { text-align: center; color: #fff }
#secPrograma #tblEventos { width: 100%; color: #fff }
#secPrograma #tblEventos tr { position: relative }
#secPrograma #tblEventos tr:after { content: ''; width: 70%; margin-left: -35%; position: absolute; border-bottom: solid 1px rgba(255,255,255,.25); display: block; left: 50%; bottom: 0 }
#secPrograma #tblEventos td { padding: 24px 8px; vertical-align: middle }
#secPrograma #tblEventos .numDia { font-size: 64px; font-weight: 600; display: block; font-family: Montserrat, sans-serif }
#secPrograma #tblEventos .mes { font-size: 24px; display: block; font-family: Montserrat, sans-serif; font-weight: 300 }
#secPrograma #tblEventos .anno { font-size: 24px; display: block; font-family: Montserrat, sans-serif; font-weight: 300 }
#secPrograma #tblEventos .btnDetalles, #secPrograma #tblEventos .spanHora { display: inline-block; padding: 4px 0; font-size: 15px; color: #fff; font-weight: 300 }
#secPrograma #tblEventos .btnDetalles .fa-solid, #secPrograma #tblEventos .spanHora .fa-solid { margin-right: 4px }
#secPrograma #tblEventos .btnDetalles { margin-right: 12px }
#secPrograma #tblEventos .btnDetalles:hover .fa-solid { color: var(--color-rojo-cre) }
#secPrograma #tblEventos strong { font-size: 24px; font-weight: normal; font-family: Montserrat, sans-serif; font-weight: 400; display: block; margin-bottom: 4px }

@media only screen and (max-width:768px) {
    /*Hero*/
    #secPrograma { padding: 48px 0 }
    #secPrograma #tblEventos td { vertical-align: top }
    #secPrograma #tblEventos td:nth-child(2), #tblEventos td:nth-child(4) { display: none }
    #secPrograma #tblEventos td:nth-child(1) { padding-left: 0; padding-right: 0 }
    #secPrograma #tblEventos td:nth-child(3) { padding-right: 0 }
    #secPrograma #tblEventos td:nth-child(3) .btnSecundario { margin-top: 8px; display: block; text-align: center }
    #secPrograma #tblEventos strong { font-size: 20px }
    #secPrograma #tblEventos .numDia { font-size: 50px }
}

/*Descubre Sevilla*/
#secDescubreSevilla > div { display: flex; width: 100% }
#secDescubreSevilla > div > div:first-child { background: var(--color-gris-claro-cre) }
#secDescubreSevilla > div > div { flex: 1; background: #fff }
#secDescubreSevilla iframe { width: 100%; height: 100%; border: 0 }
#secDescubreSevilla div#divDescubreSevilla { padding: 64px }
#secDescubreSevilla p { color: var(--color-gris-cre); line-height: 150%; font-size: 15px }

/*Mapa web y contacto*/
#secMapaWebContacto > div { display: flex; width: 100% }
#secMapaWebContacto > div > div { flex: 1 }
#secMapaWebContacto > div > div:first-child { direction: rtl }
#secMapaWebContacto > div > div:first-child > div { direction: ltr }
#secMapaWebContacto > div > div > div { padding: 64px }
#secMapaWebContacto div#divContacto { background-color: #fff }
#secMapaWebContacto #divMapaWeb > div > ol { list-style-type: none; padding: 0; margin: 0 }
#secMapaWebContacto #divMapaWeb > div > ol > li > a { color: var(--color-azul-cre); font-size: 14px; font-weight: 500; display: inline-block; margin-bottom: 6px }
#secMapaWebContacto #divMapaWeb > div > ol > li:not(:first-child) > a { margin-top: 8px }
#secMapaWebContacto #divMapaWeb > div > ol > li > ol { list-style-type: circle }
#secMapaWebContacto #divMapaWeb > div > ol > li > ol > li > a { color: var(--color-gris-cre); font-size: 13px; line-height: 14px; padding: 2px 0; display: inline-block }


#secMapaWebContacto #divBtnContacto { padding-top: 16px }

/*Footer*/
footer { background: linear-gradient(to right, #fff, var(--color-gris-claro-cre)); text-align: right }
footer > div { position: relative }
footer #btnLogoFooter { padding: 16px 16px 16px 0; background: #fff; display: inline-block; float: left; font-size: 0 }
footer #btnLogoFooter > img { height: 32px }
footer a:not(#btnLogoFooter) { line-height: 64px; padding: 0 8px; font-size: 14px; color: var(--color-gris-cre); display: inline-block }
footer a:not(#btnLogoFooter):hover { color: #000 }

@media only screen and (max-width:768px) {
    p { font-size: 15px }

    .btnPrimario { font-size: 16px; width: 100%; text-align: center; padding: 0 12px; line-height: 28px; padding-top: 16px; padding-bottom: 16px; white-space: wrap }


    #asdDestacados { pointer-events: none; transform: translateY(-48px); }
    #asdDestacados a { float: none; width: 100%; height: auto }

    #secContamosContigo { padding-top: 0; background: transparent }


    #secDescubreSevilla > div, #secMapaWebContacto > div { flex-direction: column; }
    #secDescubreSevilla iframe { height: 100vw }
    .divSeccionCuadros { flex-direction: column !important; padding: 16px 0 }

    .divSeccionCuadros > div { min-height: calc(100vw - 32px) }
    .divSeccionCuadros > .divContenido > div { padding: 20px }

    #secCongreso { padding-bottom: 0 }

    #secMapaWebContacto > div > div > div { padding: 16px }
    #secDescubreSevilla div#divDescubreSevilla { padding: 16px }

    footer { text-align: center; padding: 16px 0 }
    footer #btnLogoFooter { float: none }
    footer a:not(#btnLogoFooter) { display: block !important; float: none !important; text-align: center; line-height: 48px }
}

@media only screen and (min-width:769px) {

    .soloMv { display: none }
    #secHero { background-image: url(/img/voluntaria-cruz-roja-ayudando-a-nina-con-tareas-escolares.webp); }
    #secContamosContigo > div { padding-right: 320px }
}

@media only screen and (max-width: 1200px) {
    .divColumna { padding-left: 16px; padding-right: 16px }

    header #divRellenoIzq { width: 12px }
    header #divRellenoDer { width: 12px }

    /*Header - Navegación*/ header { position: relative; z-index: 100 }
    header #divColumnaHeader > div > div#celdaCongreso { display: none }
    header #divColumnaHeader > div > div#celdaLogoCRE { width: 99% }
    header #divColumnaHeader > div > div#celdaMenu:before { border-left-color: #fff }
    header .pix-menu { margin-right: -12px }
    .show-nav header #divColumnaHeader > div > div#celdaMenu nav { display: block; position: fixed; background-color: var(--color-rojo-cre); top: 64px; left: 0; width: 100%; font-size: 18px; z-index: 100; }
    header #divColumnaHeader > div > div#celdaMenu nav ul { list-style-type: none; margin: 0; padding: 0; white-space: nowrap }
    header #divColumnaHeader > div > div#celdaMenu nav ul > li:first-child { margin-top: 8px }
    header #divColumnaHeader > div > div#celdaMenu nav ul > li { display: block; }
    header #divColumnaHeader > div > div#celdaMenu nav ul > li > a { color: #fff; display: block; line-height: 32px; padding: 5px 12px; background-color: var(--color-rojo-cre) }
    header #divColumnaHeader > div > div#celdaMenu nav ul > li > a:hover { background-color: var(--color-azul-cre) }
    header #divColumnaHeader > div > div#celdaMenu nav ul > li > ol { list-style-type: none; text-align: left; padding: 0; margin: 0 }
    header #divColumnaHeader > div > div#celdaMenu nav ul > li > ol a { color: rgba(255,255,255,.8); padding: 10px 16px 10px 24px; font-size: 15px; display: block; white-space: normal }
    header #divColumnaHeader > div > div#celdaMenu nav ul > li > ol a:hover { color: #fff; background-color: var(--color-azul-cre) }
}


@media only screen and (min-width: 1201px) {
    .pix-menu { display: none }
    .divColumna { max-width: 1156px; width: 100%; margin: auto; padding-left: 0; padding-right: 0 }
    .divAjustarColumna { width: 540px; }
    div:first-child > .divAjustarColumna { padding-left: 0 !important }
    div:not(:first-child) > .divAjustarColumna { padding-right: 0 !important }


    header #divRellenoIzq { width: calc(50vw - 590px) }
    header #divRellenoDer { width: calc(50vw - 590px) }
    header #divColumnaHeader > div > div#celdaMenu nav { font-size: 0; color: #fff; text-align: right; display: block }
    header #divColumnaHeader > div > div#celdaMenu nav ul { list-style-type: none; margin: 0; padding: 0; white-space: nowrap }
    header #divColumnaHeader > div > div#celdaMenu nav ul > li { display: inline-block; vertical-align: top; position: relative }
    header #divColumnaHeader > div > div#celdaMenu nav ul > li > a { color: #fff; display: inline-block; line-height: 32px; padding: 16px 8px; font-size: 15px; }
    header #divColumnaHeader > div > div#celdaMenu nav ul > li:hover > a { background-color: var(--color-azul-cre) }
    header #divColumnaHeader > div > div#celdaMenu nav ul > li:first-child > a { margin-left: -8px }
    header #divColumnaHeader > div > div#celdaMenu nav ul > li:last-child > a { margin-right: -8px }
    header #divColumnaHeader > div > div#celdaMenu nav ul > li > ol { display: none; position: absolute; top: 64px; left: 0; z-index: 1; list-style-type: none; text-align: left; padding: 0; margin: 0 }
    header #divColumnaHeader > div > div#celdaMenu nav ul > li > ol a { color: rgba(255,255,255,.7); padding: 12px 16px; font-size: 14px; display: block; background: var(--color-azul-cre); }
    header #divColumnaHeader > div > div#celdaMenu nav ul > li > ol a:hover { color: #fff }
    header #divColumnaHeader > div > div#celdaMenu nav ul > li:hover > ol { display: block; box-shadow: 3px 5px 10px rgba(0,0,0,.15) }
    header #divColumnaHeader > div > div#celdaMenu nav ul > li > ol > li:last-child > a { border-bottom-left-radius: 2px; border-bottom-right-radius: 2px }
    header #divColumnaHeader > div > div#celdaMenu nav ul > li > ol.despliegueIzq { left: unset; right: 0 }
}

@media only screen and (min-width: 1460px) {
    .divColumna { max-width: 1280px; }
    .divAjustarColumna { width: 640px; }


    header #divRellenoIzq { width: calc(50vw - 640px) }
    header #divRellenoDer { width: calc(50vw - 640px) }
}
