/* Media queries */
/*
Less than:
'$screen-xs-up'		=> '575.98px',
'$screen-sm-up'		=> '767.98px',
'$screen-md-up'		=> '991.98px',
'$screen-lg-up'		=> '1199.98px', 
'$screen-xl-up'		=> '1359.98px', 
'$screen-xxl-up'	=> '1399.98px', 

More than:
'$screen-xs-down'	=> '576px',
'$screen-sm-down'	=> '768px',
'$screen-md-down'	=> '992px',
'$screen-lg-down'	=> '1200px',
'$screen-xl-down'	=> '1366px',
'$screen-xxl-down'	=> '1400px',

@media (max-width: $screen-size-up) {
	... less than ...
}
@media (min-width: $screen-size-down) {
	... more than ...
}
*/

/*fonts---------------------------------------------------------------*/
@font-face {
    font-family: 'Teva Sans';
    src: url('../fonts/TevaSans-Regular/TevaSans-Regular.eot');
    src: url('../fonts/TevaSans-Regular/TevaSans-Regular.eot?#iefix') format('embedded-opentype'),
        url('../fonts/TevaSans-Regular/TevaSans-Regular.woff2') format('woff2'),
        url('../fonts/TevaSans-Regular/TevaSans-Regular.woff') format('woff'),
        url('../fonts/TevaSans-Regular/TevaSans-Regular.ttf') format('truetype'),
        url('../fonts/TevaSans-Regular/TevaSans-Regular.svg#TevaSans-Regular') format('svg');
    font-weight: normal;
    font-style: normal;
    font-display: swap;
}

@font-face {
    font-family: 'Teva Sans bold';
    src: url('../fonts/TevaSans-Bold/TevaSans-Bold.eot');
    src: url('../fonts/TevaSans-Bold/TevaSans-Bold.eot?#iefix') format('embedded-opentype'),
        url('../fonts/TevaSans-Bold/TevaSans-Bold.woff2') format('woff2'),
        url('../fonts/TevaSans-Bold/TevaSans-Bold.woff') format('woff'),
        url('../fonts/TevaSans-Bold/TevaSans-Bold.ttf') format('truetype'),
        url('../fonts/TevaSans-Bold/TevaSans-Bold.svg#TevaSans-Bold') format('svg');
    font-weight: bold;
    font-style: normal;
    font-display: swap;
}

@font-face {
    font-family: 'Teva Sans light';
    src: url('../fonts/TevaSans-Light/TevaSans-Light.eot');
    src: url('../fonts/TevaSans-Light/TevaSans-Light.eot?#iefix') format('embedded-opentype'),
        url('../fonts/TevaSans-Light/TevaSans-Light.woff2') format('woff2'),
        url('../fonts/TevaSans-Light/TevaSans-Light.woff') format('woff'),
        url('../fonts/TevaSans-Light/TevaSans-Light.ttf') format('truetype'),
        url('../fonts/TevaSans-Light/TevaSans-Light.svg#TevaSans-Light') format('svg');
    font-weight: 300;
    font-style: normal;
    font-display: swap;
}

/*fonts/end---------------------------------------------------------------*/


/*Globales ---------------------------------------------------------------*/
:root {
    --main-gris: #acacac;    
    --main-azul: #0073b7;
    --main-gris2: #b1b1b1;
    --main-gris3: #ebebeb;
    --main-colorbanner: #f7f7f7;
    --card-image-h: 200px;
    --card-text-lines: 6;
    --main-azul-1: #022a3b;

    --main-textos-base: var(--main-azul);
    --main-textos-borde: var(--main-gris);
    --main-textos-gris: var(--main-gris3);
    --main-textos-enlaces:var(--main-azul);
    --main-textos-fuente: 'Teva Sans';
    --main-textos-fuente-bold: 'Teva Sans bold';
    --main-fuentes-size: 20px;
    

}

.fs-none {
    font-size: 0px !important;

}

.fs-0 {
    font-size: 3.5rem !important;
}

.fs-1 {
    font-size: 2.5rem !important;
}

.fs-2 {
    font-size: 2rem !important;
}

.fs-3 {
    font-size: 1.75rem !important;
}

.fs-4 {
    font-size: 1.5rem !important;
}

.fs-5 {
    font-size: 1.25rem !important;
}

.fs-6 {
    font-size: 1rem !important;
}

.fs-7 {
    font-size: 0.875rem !important;
}

.fs-8 {
    font-size: 0.8rem !important;
}

.fs-9 {
    font-size: 0.775rem !important;
}

.fs-10 {
    font-size: 0.7rem !important;
}

.font-teva-sans {
    font-family: 'Teva Sans';
}

.font-teva-bold {
    font-family: 'Teva Sans bold';
}

.font-teva-light {
    font-family: 'Teva Sans light';
}




a,
a:visited,
a:hover,
a:active {
    outline: none;
}

button,
button:visited,
button:hover,
button:active {
    outline: none;

}

.btn,
.btn:visited,
.btn:hover,
.btn:active,
.btn:focus-visible {

    box-shadow: none;

}

.is-opacity {
    transition: opacity ease 0.3s;
}

.is-opacity:hover {
    transition: opacity ease 0.3s;
    opacity: 0.5;
}

.is-scale {
    transition: transform ease 0.3s;
}

.is-scale:hover {

    transition: transform ease 0.3s;
    transform: scale(1.3);
}

.is-scale-sm {
    transition: transform ease 0.3s;
}

.is-scale-sm:hover {

    transition: transform ease 0.3s;
    transform: scale(1.1);
}

.is-scale-xs {
    transition: transform ease 0.3s;
}

.is-scale-xs:hover {

    transition: transform ease 0.3s;
    transform: scale(1.05);
}

.is-boton {

    font-family: 'Teva Sans';
    font-size: 20px;
    border-radius: 0px;
    background-color: var(--main-azul);
    color: white;
    padding: 0px 10px;
    margin: 50px 0px;
    border: none;
}



/*logos auspiciadores */
.main-logo-auspiciador a {

    display: inline-block;
    padding: 10px 20px;
}

.main-logo-auspiciador img {

    width: 100%;
    height: auto;
    max-width: 275px;
    max-height: 86px;
}


.is-main-textos {
	font-family: var(--main-textos-fuente);
	font-size: var(--main-fuentes-size);
	line-height: 28px;
	text-align: justify;
}
.is-main-textos > *:nth-last-child(1) {
	margin-bottom: 0px !important;
}
.is-main-textos p a:not(.is-popup),
.is-main-textos p a:not(.is-popup):visited,
.is-main-textos p a:not(.is-popup):hover,
.is-main-textos p a:not(.is-popup):active {
	background-color: var(--main-textos-enlaces);
	color: white;
	padding: 2px 5px;
	border-radius: 3px;
	display: inline-block;
	line-height: 20px;
}
.is-main-textos b,
.is-main-textos strong {
	font-family: var(--main-textos-fuente-bold);
	font-weight: normal;
	color: black;
}
.is-main-textos a b,
.is-main-textos a strong {
	color: white;
}
.is-main-textos p:nth-last-child(1) {
	margin-bottom: 0px;
}
.is-main-textos ul a,
.is-main-textos ul a:visited,
.is-main-textos ul a:hover,
.is-main-textos ul a:active,
.is-main-textos ol a,
.is-main-textos ol a:visited,
.is-main-textos ol a:hover,
.is-main-textos ol a:active {
	font-family: var(--main-textos-fuente);
	color: var(--main-textos-enlaces);
}
.is-main-textos ul {
	padding-left: 0px;
}
.is-main-textos ul li {
	list-style: none;
	padding-left: 17px;
	position: relative;
}
.is-main-textos ul li:before {
	content: '';
	width: 7px;
	height: 7px;
	vertical-align: middle;
	display: inline-block;
	background-color: var(--main-textos-base);
	position: absolute;
	top: 9px;
	left: 0;
}
.is-main-textos ul li > ul li:before {
	background-color: white;
	border: 1px solid var(--main-textos-borde);
}
.is-main-textos ol {
	padding-left: 0px;
	counter-reset: item;
}
.is-main-textos ol > li {
	list-style: none;
	padding-left: 33px;
	position: relative;
	counter-increment: li;
	margin-bottom: 5px;
}
.is-main-textos ol > li:nth-last-child(1) {
	margin-bottom: 0px;
}
.is-main-textos ol > li:before {
	content: counter(item); /* counters(item, ".") " " */
	counter-increment: item;
	vertical-align: middle;
	display: inline-block;
	background-color: var(--main-textos-base);
	position: absolute;
	top: 2px;
	margin-left: -33px;
	color: white;
	padding: 0px 5px;
	font-size: 12px;
	line-height: 20px;
	letter-spacing: -0.5px;
	min-width: 22px;
	text-align: center;
}
.is-main-textos ol > li > ol {
	margin-top: 5px;
}
.is-main-textos ol > li > ol > li:before {
	background-color: white;
	border: 1px solid var(--main-textos-borde);
	color: var(--main-textos-base);
}
.is-main-textos.text-center li,
.is-main-textos li[style*="text-align: center"] {
	display: inline;
}
.is-main-textos.text-center li:before,
.is-main-textos li[style*="text-align: center"]:before {
	top: 5px;
}
.is-main-textos.text-center li:after,
.is-main-textos li[style*="text-align: center"]:after {
     content: "\A";
     white-space: pre; 
}
.is-main-textos img {
	max-width: 100%;
    display: inline-block;
    height: auto !important;
}
.is-main-textos *:not(table).aligncenter {
    display: block;
    margin: 0px auto;
	text-align: center;
}
.is-main-textos .alignleft {
    float: left;
    margin-right: 1.5rem;
    margin-bottom: 1.5rem;
}
.is-main-textos .alignright {
    float: right;
    margin-left: 1.5rem;
    margin-bottom: 1.5rem;
}

@media (max-width: 575.98px) {	
	.is-main-textos .aligncenter,
	.is-main-textos .alignleft,
	.is-main-textos .alignright {
		width: 100%;
   		margin-right: 0px;
   		margin-left: 0px;
   		margin-bottom: 1.5rem;
	}
}
.is-main-textos h1:nth-child(1),
.is-main-textos h2:nth-child(1),
.is-main-textos h3:nth-child(1),
.is-main-textos h4:nth-child(1),
.is-main-textos h5:nth-child(1),
.is-main-textos h6:nth-child(1) {
	margin-top: 0px;
}
.is-main-textos h1,
.is-main-textos h2,
.is-main-textos h3,
.is-main-textos h4,
.is-main-textos h5,
.is-main-textos h6 {
	font-family: var(--main-textos-fuente-bold);
	font-weight: normal;
	color: var(--main-textos-base);
	margin-bottom: 0.5rem;
	/* h3 only */
	line-height: 33px;
	font-size: 24px;
}
.is-main-textos iframe {
	display: block;
	max-width: 100%;
	margin: 0 auto;
}
.is-main-textos table.aligncenter{
	margin: 0 auto;
   	margin-bottom: 1.5rem;
}
.is-main-textos table{
	border: none;
	margin-bottom: 20px;
}
.is-main-textos table tr:nth-child(1) th{
	border-top: 1px solid var(--main-textos-base);
}
.is-main-textos table tr:nth-child(1) td{
	border-top: 1px solid var(--main-textos-borde);
}
.is-main-textos table tr:nth-child(odd){
	background-color: var(--main-textos-gris);
}
.is-main-textos table tr th:nth-child(1){
	border-left: 1px solid var(--main-textos-base);
}
.is-main-textos table tr td:nth-child(1){
	border-left: 1px solid var(--main-textos-borde);
}
.is-main-textos table tr th{
	font-family: var(--main-textos-fuente-bold);
	font-weight: normal;
	background-color: var(--main-textos-base);
	color: white;
	text-transform: uppercase;
	padding: 8px 10px;
	font-size: 14px;
	line-height: 20px;
	border-right: 1px solid var(--main-textos-base);
	border-bottom: 1px solid var(--main-textos-base);
}
.is-main-textos table tr td{
	font-family: var(--main-textos-fuente);
	color: black;
	padding: 8px 10px;
	font-size: 15px;
	line-height: 19px;
	border-right: 1px solid var(--main-textos-borde);
	border-bottom: 1px solid var(--main-textos-borde);
}
/*Global/end-------------------------------------------------------------*/

/* header ---------------------------------------------------------------*/
header {  
    background-color: var(--main-colorbanner);
}

/* Header logos ---------------------------------------------------------------*/

header .main-barra-logos {
    background-color: #0b2438;
    padding-bottom: 5px;
}

header .main-barra-logos-inner {
    height: 85px;
    display: flex;
    align-items: center;
    border-bottom: 1px solid rgba(255, 255, 255, 0.25);
    filter: brightness(0) invert(1);
}

/* Para que la row ocupe todo el ancho dentro del inner */
header .main-barra-logos-inner .row {
    width: 100%;
}

/* Logo base */
header .main-barra-logos .is-logo {
    display: inline-flex;
    align-items: center;
    text-decoration: none;
}

/* Logo izquierdo */
header .main-barra-logos .is-logo-principal img {
    display: block;
    max-width: 95px;
    height: auto;
}

/* Contenedor de logos derechos */
header .main-barra-logos .is-logos-derecha {
    display: flex;
    align-items: center;
    gap: 25px;
}

/* Logos derechos */
header .main-barra-logos .is-logo-secundario img {
    display: block;
    max-height: 34px;
    width: auto;
}

/* Menú debajo */
header .main-menu {
    height: auto;
    background-color: #0073ba;
    color: white;
}


/* Menu ---------------------------------------------------------------*/

.main-menu {
    background-color: #0073ba;
}

.is-menu {
    display: flex;
    align-items: center;
    width: 100%;
    min-height: 48px;
    
}

/* Lista principal */
.is-menu-list {
    display: flex;
    align-items: center;
    flex: 1;
    list-style: none;
    padding: 0;
    margin: 0;
}

/* Item */
.is-menu-item {
    flex: 1;
    margin-right: 5px;
    transform: skewX(-12deg);
    background-color: #2ca6dc;
    overflow: hidden;
}

/* Link */
.is-menu-link {
    position: relative;
    display: flex;
    align-items: center;
    justify-content: center;

    height: 38px;
    padding: 0 18px;

    font-family: 'Teva Sans bold';
    font-size: 14px;
    font-style: italic;
    color: #fff;
    text-decoration: none;

    background-color: #2ca6dc;
    transition: background-color 0.3s ease;
}

/* Corrige el texto para que no quede inclinado */
.is-menu-link span {
    display: inline-block;
    transform: skewX(12deg);
}

/* Triángulo pequeño inferior */
.is-menu-link::before {
    content: "";
    position: absolute;
    left: 10px;
    bottom: 4px;

    width: 0;
    height: 0;

    border-left: 4px solid transparent;
    border-right: 4px solid transparent;
    border-top: 5px solid #ffffff;
    opacity: 0.8;

    transform: skewX(12deg);
}

/* Hover / activo */
.is-menu-link:hover,
.is-menu-link.is-active {
    color: #fff;
    border-bottom: 4px solid #fff;
    padding-top: 4px;
}

.is-menu-link:hover::before,
.is-menu-link.is-active::before {
    display: none;
}

/* WhatsApp */
.is-menu-whatsapp {
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 8px;

    min-width: 170px;
    height: 48px;
    padding: 0 15px;

    font-family: 'Teva Sans bold';
    font-size: 9px;
    line-height: 1.1;
    color: #fff;
    text-decoration: none;
    text-transform: uppercase;  
}

.is-menu-whatsapp i {
    font-size: 24px;
    color: #fff;
}

.is-menu-whatsapp:hover {
    background-color: #0083c5;
    color: #fff;
}


@media (max-width: 991px) {
    .is-menu {
        overflow-x: auto;
    }

    .is-menu-list {
        min-width: 850px;
    }

    .is-menu-item {
        flex: initial;
        min-width: 120px;
    }

    .is-menu-whatsapp {
        min-width: 160px;
    }
}

@media (max-width: 576px) {
    .main-menu {
        border-top-width: 3px;
        border-bottom-width: 3px;
    }

    .is-menu-list {
        min-width: 760px;
    }

    .is-menu-link {
        height: 42px;
        font-size: 13px;
        padding: 0 14px;
    }

    .is-menu-whatsapp {
        height: 42px;
        font-size: 8px;
    }

    .is-menu-whatsapp i {
        font-size: 21px;
    }
}

@media (max-width: 991px) {
    .is-menu {
        overflow-x: auto;
    }

    .is-menu-list {
        min-width: 850px;
    }

    .is-menu-item {
        flex: initial;
        min-width: 120px;
    }

    .is-menu-whatsapp {
        min-width: 160px;
    }
}

@media (max-width: 576px) {
    .main-menu {
        border-top-width: 3px;
        border-bottom-width: 3px;
    }

    .is-menu-list {
        min-width: 760px;
    }

    .is-menu-link {
        height: 42px;
        font-size: 13px;
        padding: 0 14px;
    }

    .is-menu-whatsapp {
        height: 42px;
        font-size: 8px;
    }

    .is-menu-whatsapp i {
        font-size: 21px;
    }
}


/* header/end ---------------------------------------------------------------*/

/* Torneos ---------------------------------------------------------------*/
.main-torneos {
    background-color: #fff;
    border-bottom: 4px solid #d9d9d9;
}

/* Barra completa */
.is-torneos-bar {
    display: flex;
    align-items: center;
    width: 100%;
    min-height: 58px;
}

/* Título izquierdo */
.is-titulo-torneos-bar {
    flex: 0 0 auto;
    font-family: 'Teva Sans bold';
    font-size: 22px;
    line-height: 1;
    font-style: italic;
    color: #002b3f;
    white-space: nowrap;
    padding-right: 30px;
}

/* Línea inclinada/separador */
.is-separador-torneos {
    flex: 0 0 auto;
    width: 2px;
    height: 42px;
    background-color: #002b3f;
    transform: skewX(-14deg);
    margin-right: 35px;
}

/* Contenedor de cards */
.main-torneos .is-torneo,
.main-torneos .is-torneo-box {
    flex: 1;
    display: flex;
    align-items: center;
    gap: 45px;
    overflow-x: auto;
    flex-wrap: nowrap;
    position: relative;
}
.main-torneos .is-torneo-box::after {
    content: "";
    width: 80px;
    height: 100%;
    background: linear-gradient(90deg, rgba(255, 255, 255, 0) 0%, rgba(255, 255, 255, 1) 100%);
    position: absolute;
    right: 0;
    top: 0;
}

/* Ocultar scrollbar */
.is-scroll-hidden {
    -ms-overflow-style: none;
    scrollbar-width: none;
}

.is-scroll-hidden::-webkit-scrollbar {
    display: none;
}

/* Card torneo */
.is-card-torneo {
    flex: 0 0 auto;
    display: flex;
    align-items: center;
    min-width: 285px;
    color: #000;
    text-decoration: none;
    border: none;
    padding: 0;
    background-color: transparent;
}

/* Logo torneo */
.is-imagen-torneo {
    width: 42px;
    height: 42px;
    margin-right: 12px;
    flex-shrink: 0;
    background-color: transparent;

    display: flex;
    align-items: center;
    justify-content: center;
}

.is-imagen-torneo img {
    width: 100%;
    height: 100%;
    display: block;
    object-fit: contain;
}

/* Texto */
.is-texto-torneo {
    display: flex;
    flex-direction: column;
    min-width: 0;
}

.is-titulo-torneo {
    font-family: 'Teva Sans bold';
    font-size: 16px;
    line-height: 1.05;
    color: #000;
    margin-bottom: 3px;
    white-space: nowrap;
}

.is-fecha-torneo {
    font-family: 'Teva Sans';
    font-size: 12px;
    line-height: 1;
    color: #000;
    white-space: nowrap;
}

/* Flecha derecha */
.is-flecha-torneos {
    flex: 0 0 auto;
    display: flex;
    align-items: center;
    justify-content: center;

    width: 34px;
    height: 58px;
    margin-left: 18px;

    color: #2ca6dc;
    text-decoration: none;
    font-size: 18px;
}

.is-flecha-torneos:hover {
    color: #0073ba;
}

/* Responsive menú ---------------------------------------------------------------*/

@media (max-width: 991px) {

    .main-menu {
        background-color: #0073ba;
        padding: 30px 0 35px;
    }

    .is-menu {
        flex-direction: column;
        align-items: center;
        justify-content: center;
        min-height: auto;
        overflow: visible;
    }

    .is-menu-list {
        width: 100%;
        min-width: initial;
        display: flex;
        flex-wrap: wrap;
        justify-content: center;
        align-items: center;
        gap: 28px 12px;
        padding: 0 35px;
    }

    .is-menu-item {
        flex: 0 0 calc(25% - 12px);
        min-width: initial;
        margin-right: 0;
        transform: skewX(-12deg);
        background-color: #2ca6dc;
        overflow: visible;
    }

    .is-menu-link {
        height: 50px;
        padding: 0 7px;
        font-size: 17px;
        font-style: italic;
        border-bottom: none;
    }

    .is-menu-link span {
        transform: skewX(12deg);
    }

    .is-menu-link::before {
        left: 8px;
        bottom: 6px;
        border-left: 5px solid transparent;
        border-right: 5px solid transparent;
        border-top: 6px solid #fff;
    }

    .is-menu-link:hover,
    .is-menu-link.is-active {
        color: #fff;
        border-bottom: 4px solid #fff;
        padding-top: 4px;
    }

    .is-menu-whatsapp {
        margin-top: 35px;
        min-width: initial;
        height: auto;
        padding: 0;
        background-color: transparent;

        display: flex;
        align-items: center;
        justify-content: center;
        gap: 18px;

        font-size: 20px;
        line-height: 1.15;
        text-align: left;
    }

    .is-menu-whatsapp i {
        font-size: 54px;
    }

    .is-menu-whatsapp:hover {
        background-color: transparent;
        color: #fff;
    }
}

@media (max-width: 576px) {

    .main-menu {
        padding: 25px 0 30px;
    }

    .is-menu-list {
        padding: 0 25px;
        gap: 20px 12px;
    }

    .is-menu-item {
        flex: 0 0 calc(50% - 12px);
    }

    .is-menu-link {
        height: 52px;
        font-size: 20px;
        padding: 0 10px;
    }

    .is-menu-whatsapp {
        margin-top: 30px;
        font-size: 16px;
        gap: 14px;
    }

    .is-menu-whatsapp i {
        font-size: 44px;
    }
}
/* torneos/end ---------------------------------------------------------------*/
/* torneos destacados ---------------------------------------------------------------*/
/* Torneo destacado / ranking ---------------------------------------------------------------*/

.main-torneo-destacado {
    background-color: white;
}

.is-torneo-destacado-bar {
    display: flex;
    align-items: center;
    min-height: 60px;
    background-color: #fff;
    overflow: hidden;
}

/* Evento izquierdo */
.is-evento-destacado {
    flex: 0 0 370px;
    display: flex;
    align-items: center;
    padding: 5px 5px;
    color: #001c4f;
    text-decoration: none;
}

.is-evento-destacado:hover {
    color: #001c4f;
    text-decoration: none;
}

.is-logo-evento-destacado {
    width: 72px;
    height: 72px;
    margin-right: 22px;
    flex-shrink: 0;
}

.is-logo-evento-destacado img {
    width: 100%;
    height: 100%;
    display: block;
    object-fit: contain;
}

.is-info-evento-destacado {
    display: flex;
    flex-direction: column;
}

.is-titulo-evento-destacado {
    font-family: 'Teva Sans bold';
    font-size: 20px;
    line-height: 1.05;
    color: #001c4f;
}

.is-anio-evento-destacado {
    font-family: 'Teva Sans';
    font-size: 18px;
    line-height: 1;
    color: #001c4f;
    margin-top: 4px;
}

/* Separador */
.is-separador-evento-destacado {
    flex: 0 0 auto;
    width: 3px;
    height:42px;
    background-color: #00364d;
    transform: skewX(-12deg);
    margin-right: 35px;
}

/* Contenedor jugadores */
.is-jugadores-destacados-box,
.is-jugadores-destacados
 {
    flex: 1;
    display: flex;
    align-items: center;
    gap: 42px;
    overflow-x: auto;
    flex-wrap: nowrap;
    padding-right: 25px;
    position: relative;
}
.is-jugadores-destacados-box::after{
    content: "";
    width: 80px;
    height: 100%;
    background: linear-gradient(90deg, rgba(255, 255, 255, 0) 0%, rgba(255, 255, 255, 1) 100%);
    position: absolute;
    right: 0;
    top: 0;    
}

/* Card jugador */
.is-card-jugador-destacado {
    flex: 0 0 auto;
    display: flex;
    align-items: center;
    min-width: 100px;
    color: #000;
    text-decoration: none;
}

.is-card-jugador-destacado:hover {
    text-decoration: none;
}

.is-avatar-jugador-destacado {
    width: 68px;
    height: 68px;
    margin-right: 16px;
    flex-shrink: 0;
    border-radius: 50%;
    overflow: hidden;
    background-color: #d9d9d9;
}

.is-avatar-jugador-destacado img {
    width: 100%;
    height: 100%;
    display: block;
    object-fit: cover;
}

/* Texto jugador */
.is-info-jugador-destacado {
    display: flex;
    flex-direction: column;
    min-width: 0;
}

.is-nombre-jugador-destacado {
    font-family: 'Teva Sans bold';
    font-size: 22px;
    line-height: 1;
    color: #2ca6dc;
    white-space: nowrap;
}

.is-detalle-jugador-destacado {
    display: flex;
    align-items: baseline;
    gap: 8px;
    margin-top: 5px;
}

.is-score-jugador-destacado {
    font-family: 'Teva Sans';
    font-size: 26px;
    line-height: 1;
    color: #000;
}

.is-ronda-jugador-destacado {
    font-family: 'Teva Sans';
    font-size: 13px;
    line-height: 1;
    color: #000;
    white-space: nowrap;
}

/* Ocultar scrollbar */
.is-scroll-hidden {
    -ms-overflow-style: none;
    scrollbar-width: none;
}

.is-scroll-hidden::-webkit-scrollbar {
    display: none;
}

/* Responsive */
@media (max-width: 991px) {
    .is-torneo-destacado-bar {
        min-height: 100px;
    }

    .is-evento-destacado {
        flex: 0 0 320px;
        padding: 16px 25px;
    }

    .is-logo-evento-destacado {
        width: 60px;
        height: 60px;
        margin-right: 16px;
    }

    .is-titulo-evento-destacado {
        font-size: 18px;
    }

    .is-anio-evento-destacado {
        font-size: 15px;
    }

    .is-separador-evento-destacado {
        height: 65px;
        margin-right: 25px;
    }

    .is-jugadores-destacados {
        gap: 30px;
    }

    .is-card-jugador-destacado {
        min-width: 230px;
    }

    .is-avatar-jugador-destacado {
        width: 58px;
        height: 58px;
    }

    .is-nombre-jugador-destacado {
        font-size: 19px;
    }

    .is-score-jugador-destacado {
        font-size: 23px;
    }
}

@media (max-width: 576px) {
    .main-torneo-destacado {
        padding-top: 14px;
    }

    .is-torneo-destacado-bar {
        min-height: 90px;
    }

    .is-evento-destacado {
        flex: 0 0 270px;
        padding: 14px 18px;
    }

    .is-logo-evento-destacado {
        width: 52px;
        height: 52px;
        margin-right: 12px;
    }

    .is-titulo-evento-destacado {
        font-size: 15px;
    }

    .is-anio-evento-destacado {
        font-size: 13px;
    }

    .is-separador-evento-destacado {
        height: 56px;
        margin-right: 20px;
    }

    .is-card-jugador-destacado {
        min-width: 210px;
    }

    .is-avatar-jugador-destacado {
        width: 50px;
        height: 50px;
    }

    .is-nombre-jugador-destacado {
        font-size: 17px;
    }

    .is-score-jugador-destacado {
        font-size: 21px;
    }

    .is-ronda-jugador-destacado {
        font-size: 12px;
    }
}

/* torneos destacados/end ---------------------------------------------------------------*/
/* Banner ---------------------------------------------------------------*/
.main-banner {
    position: relative;
    background-color: var(--main-colorbanner);
    display: flex;
    align-items: center;
    justify-content: center;
}
.main-banner-contenido{
    position: relative;
}
.main-banner .accesos-banner {
    background-color: rgb(10, 58, 104);
    padding: 0px 0px;
    height: 100%;
    width: 100%;
    position: absolute;
}
.main-banner .accesos-banner::after {
    content: "";
    position: absolute;
    left: 0;
    top: 0;
    width: 100%;
    height: 100%;
    background: linear-gradient(360deg, rgba(255, 255, 255, 1) 0%, rgba(10, 58, 104, 0) 53%);
}

.main-banner .accesos-banner img {
    width: 100%;
    height: 100%;
    display: block;
    object-fit: cover;
    position: absolute;
    opacity: 0.2; 
}

.main-banner .main-banner-texto {
    color: white;
    text-align: center;
    z-index: 1;
    justify-content: center;
}

.main-banner .main-banner-texto .is-titulo {
    font-family: 'Teva Sans bold';
    font-size: 40px;
    margin-bottom: 20px;
    padding-top: 75px;
}
.main-banner .main-banner-texto .is-detalle {
    font-family: 'Teva Sans';
    font-size: 35px;
    margin-bottom: 70px;
}




/*--------cards accesos-------*/
.main-accesos {
    row-gap: 20px;
    justify-content: center;
    align-items: center;
    margin-bottom: 40px;
}
.is-card-acceso {
    display: block;
    text-decoration: none;
    background-color: #fff;
    border-radius: 8px;
    overflow: hidden;
    color: rgb(255, 255, 255);
    transition: transform 0.3s ease, box-shadow 0.3s ease;
}

.is-card-acceso:hover {
    transform: translateY(-5px);
    box-shadow: 0 8px 18px rgba(0, 0, 0, 0.18);
}

.is-imagen-accesos {
    width: 100%;
    height: 230px;
    overflow: hidden;
}

.is-imagen-accesos img {
    width: 100%;
    height: 100%;
    display: block;
    object-fit: cover;
    background-color: blueviolet;
}

.is-titulo-accesos {
    font-family: 'Teva Sans bold';
    font-size: 18px;
    color: var(--main-azul);
    text-align: center;
    padding: 12px 10px;
    line-height: 1.1;
}

/*Clientes-----------------------------------*/
.is-titulo-clientes {
    font-family: 'Teva Sans bold';
    font-size: 40px;
    color: white;
    margin-bottom: 30px;
    text-shadow: 1px 1px 1px black;

}

.is-logos-clientes {
    flex-wrap: wrap;
    display: flex;
    justify-content: center;
    align-items: center;
    gap: 20px;
    margin-bottom: 50px;
}
.is-logos-clientes img {
    max-width: 150px;
    max-height: 60px;
    width: auto;
    height: auto;
}
/* Banner/end ---------------------------------------------------------------*/

/* OnlyGames ---------------------------------------------------------------*/

.main-onlygames {
    width: 100%;
    background-color: var(--main-azul-1);
}

/* Banner superior */
.onlygames-banner {
    position: relative;
    width: 100%;
    min-height: 190px;
    background-color: var(--main-azul-1);
    display: flex;
    align-items: center;    
    
}
.is-onlygames-banner{
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    opacity: 0.19;
    object-fit: cover;
    object-position: center;
}
/* Contenido dentro del banner */
.main-onlygames-contenido {
    position: relative;
}
    

/* Logo */
.is-logo-onlygames img {
    display: block;
    max-width: 460px;
    width: 100%;
    height: auto;    
}

/* Flecha */
.is-flecha-onlygames {
    font-family: 'Teva Sans bold';
    font-size: 56px;
    line-height: 1;
    color: #fff;
}

/* Botón */
.is-btn-onlygames .btn-primary {
    display: inline-flex;
    align-items: center;
    gap: 35px;
    font-family: 'Teva Sans bold';
    font-size: 30px;
    line-height: 1;
    color: #002b3f;
    background-color: #fff;
    border: none;
    border-radius: 12px;
    padding: 20px 30px;
    text-decoration: none;

    
}

.is-btn-onlygames .btn-primary span {
    font-size: 54px;
    line-height: 0.8;
    color: #0075b8;
}

/* Contenedor gris de cards */
.main-onlygames-cards-wrapper {
    background-color: #e5e5e5;
    padding: 30px 0 35px;
}

/* Cards */
.main-onlygames-cards {
    max-width: 1180px;
}

/* Card individual */
.is-card-onlygames {
    display: flex;
    align-items: center;

    width: 100%;
    min-height: 135px;
    margin-bottom: 12px;

    background-color: #0075b8;
    border-radius: 18px 0 0 18px;
    overflow: hidden;
}

/* Colores por card */
.is-card-onlygames:nth-of-type(1) {
    background-color: #0075b8;
}

.is-card-onlygames:nth-of-type(2) {
    background-color: #00577e;
}

.is-card-onlygames:nth-of-type(3) {
    background-color: #002b3f;
}

/* Número */
.is-numero-onlygames {
    width: 110px;
    min-width: 110px;

    text-align: center;
    font-family: 'Teva Sans bold';
    font-size: 70px;
    line-height: 1;
    color: #fff;
}

/* Línea vertical */
.is-separador-onlygames {
    width: 4px;
    height: 58px;
    background-color: #fff;
    border-radius: 10px;
    margin-right: 40px;
}

/* Texto */
.is-texto-onlygames {
    flex: 1;
    font-family: 'Teva Sans';
    font-size: 18px;
    line-height: 1.15;
    color: #fff;

    padding-right: 40px;
}

.is-texto-onlygames strong {
    font-family: 'Teva Sans bold';
}

/* Imagen */
.is-imagen-onlygames {
    position: relative;
    width: 300px;
    min-width: 300px;
    height: 135px;
}

.is-imagen-onlygames::before {
    content: "";
    position: absolute;
    left: -8px;
    top: 50%;
    transform: translateY(-50%);

    width: 16px;
    height: 16px;
    background-color: #fff;
    border-radius: 50%;

    z-index: 2;
}

.is-imagen-onlygames img {
    width: 100%;
    height: 100%;
    display: block;
    object-fit: cover;
}

/* Más información */
.is-mas-info-onlygames {
    text-align: center;
    margin-top: 20px;
}

.is-mas-info-onlygames a {
    display: inline-flex;
    align-items: center;
    gap: 15px;    
    font-family: 'Teva Sans bold';
    font-size: 18px;
    color: #0075b8;
    text-decoration: none;
}

.is-mas-info-onlygames span {
    width: 0;
    height: 0;
    
    border-left: 9px solid transparent;
    border-right: 9px solid transparent;
    border-top: 14px solid #0075b8;
}

@media (max-width: 991px) {
    .onlygames-banner {
        min-height: auto;
        padding: 35px 0;
    }

    .main-onlygames-contenido .row {
        gap: 25px;
        justify-content: center !important;
        text-align: center;
    }

    .is-logo-onlygames img {
        max-width: 360px;
    }

    .is-flecha-onlygames {
        font-size: 42px;
    }

    .is-btn-onlygames .btn-primary {
        font-size: 22px;
        padding: 16px 25px;
    }

    .is-btn-onlygames .btn-primary span {
        font-size: 42px;
    }
}

@media (max-width: 768px) {
    .main-onlygames-cards-wrapper {
        padding: 25px 0;
    }

    .is-card-onlygames {
        flex-direction: column;
        align-items: flex-start;
        border-radius: 18px;
    }

    .is-numero-onlygames {
        width: 100%;
        min-width: initial;
        text-align: left;
        padding: 20px 20px 0;
        font-size: 55px;
    }

    .is-separador-onlygames {
        display: none;
    }

    .is-texto-onlygames {
        padding: 10px 20px 20px;
        font-size: 16px;
    }

    .is-imagen-onlygames {
        width: 100%;
        min-width: initial;
        height: 180px;
    }

    .is-imagen-onlygames::before {
        display: none;
    }
}
/* OnlyGames/end -----------------------------------------------------------*/
/* Noticias ---------------------------------------------------------------*/

.main-noticias {
    width: 100%;
}

.page-noticias-cat {

    background-color: var(--main-gris3);
    padding: 25px 0px;


}


.page-noticias-cat .is-cat a,
.page-noticias-cat .is-cat a:visited,
.page-noticias-cat .is-cat a:hover,
.page-noticias-cat .is-cat a:active {
    text-decoration: none;
    text-transform: uppercase;
    color: black;
    font-family: 'Teva Sans bold';
    font-size: 22px;
    padding: 5px 15px;
    margin: 8px 0px;
    display: inline-block;
    border-right: 1px solid black;
}

.page-noticias-cat .is-cat a.active {

    color: var(--main-azul);

}

.page-noticias-cat .is-select .is-subtitulo {

    font-family: 'Teva Sans bold';
    color: var(--main-azul);

}

/* Noticia principal -----------------------------------------------------*/

/*page single noticias ------------------------------*/

.page-single-noticias .is-noticias-single-cards .card {
    border: none;
    padding: 0px 10px;



}

.page-single-noticias .is-noticias-single-cards .is-card img {
    width: 100%;
    height: auto;
    object-fit: cover;
    object-position: center center;
    border-radius: 0px;
}

.page-single-noticias .is-noticias-single-cards .is-card .card-body {
    padding: 10px 0px;


}

.page-single-noticias .is-noticias-single-cards .is-card .is-categoria {
    display: inline-flex;
    background-color: #0073b7;
    color: white;
    padding: 2px 20px;
}

.page-single-noticias .is-noticias-single-cards .is-card .card-title {

    font-family: 'teva sans bold';
    font-size: 20px;
}

.page-single-noticias .is-noticias-single-cards .is-card .card-subtitle {

    font-family: 'teva sans';
    font-size: 20px;
}

.page-single-noticias .is-noticias-single-cards .is-card .card-text {

    font-family: 'teva sans';
    font-size: 15px;


}

.page-single-noticias .is-noticias-single-cards .is-card .is-border-bottom {

    border-bottom: 2px solid var(--main-gris3);

}


.page-single-noticias .is-noticias-single-cards .is-card .card-footer {
    background-color: white;
    border: none;
    font-family: 'teva sans bold';
    font-size: 14px;
    padding: 10px 0px;

}



.page-single-noticias .is-mini-card .card {
    border: none;
    padding: 0px 5px;
}

.page-single-noticias .is-mini-card .card .card-img-top {

    width: 100%;
    height: auto;
    object-fit: cover;
    object-position: center center;
    border-radius: 0px;

}

.page-single-noticias .is-mini-card .card .card-title {

    font-family: 'teva sans bold';
    font-size: 15px;
}

.page-single-noticias .is-mini-card .card .btn {
    background-color: var(--main-gris3);
    color: black;
    font-size: 10px;
    font-family: 'teva sans';
    border: none;
    border-radius: 0px;
    padding: 5px 5px;
    margin-bottom: 5px;

}

.page-single-noticias .is-mini-card .is-border-bottom {

    padding-bottom: 5px;
    border-bottom: 2px solid var(--main-gris3);

}

/*page single noticias /end ------------------------------*/

.main-noticias-principal {
    position: relative;
    width: 100%;
    min-height: 550px;
    overflow: hidden;
}

.is-imagen-noticias-principal {
    position: absolute;
    inset: 0;
    width: 100%;
    height: 100%;
    object-fit: cover;
    object-position: center;
    z-index: 1;
}

.is-overlay-noticias-principal {
    position: absolute;
    inset: 0;
    background: linear-gradient(
        90deg,
        rgba(0, 0, 0, 0.75) 0%,
        rgba(0, 0, 0, 0.45) 35%,
        rgba(0, 0, 0, 0.05) 75%
    );
    z-index: 1;
}

.main-noticias-principal .container {
    position: relative;
    z-index: 3;
}

.is-contenido-noticias-principal {
    max-width: 470px;
}

.is-categoria-noticias {
    display: inline-block;
    font-family: 'Teva Sans bold';
    font-size: 20px;
    line-height: 1;
    color: #fff;
    background-color: #0073b8;
    padding: 8px 18px;
    margin-bottom: 5px;
}

.is-titulo-noticias {
    font-family: 'Teva Sans bold';
    font-size: 52px;
    line-height: 0.95;
    color: #fff;
    margin: 0;
    max-width: 450px;
}

.is-fecha-noticias {
    display: inline-block;
    font-family: 'Teva Sans';
    font-size: 12px;
    line-height: 1;
    color: #fff;
    background-color: rgba(0, 0, 0, 0.45);
    padding: 8px 10px;
    margin-top: 8px;
    text-transform: uppercase;
}

/* Noticias secundarias --------------------------------------------------*/

.main-noticias-secundarias {
    background-color: #0073b8;
    padding: 12px 0px 20px 0px;
    
}
.is-noticias-secundarias {
    margin-top: -60px;
    z-index: 1;
    position: relative;
}

.is-card-noticia-secundaria,
.is-card-video-noticia {
    display: block;
    height: 100%;
    color: #fff;
    text-decoration: none;
    overflow: hidden;
}

.is-card-noticia-secundaria:hover,
.is-card-video-noticia:hover {
    color: #fff;
    text-decoration: none;
}

.is-imagen-card-noticia {
    position: relative;
    width: 100%;
    height: 300px;
    overflow: hidden;
}

.is-imagen-card-noticia img,
.is-video-noticia img {
    width: 100%;
    height: 100%;
    display: block;
    object-fit: cover;
    border-radius: 10px;
}

/* Cuerpo cards */
.is-body-card-noticia {
    position: relative;
    background-color: #0073b8;
    padding: 0 8px 8px;
}

.is-categoria-card-noticia {
    display: inline-block;
    position: absolute;
    margin-top: -22px;
    z-index: 2;
    top: -100%;
    left: 0%;

    font-family: 'Teva Sans bold';
    font-size: 12px;
    color: #fff;
    background-color: #008bd2;
    padding: 5px 10px;
}

.is-descripcion-card-noticia {
    font-family: 'Teva Sans';
    font-size: 15px;
    line-height: 1.1;
    color: #fff;
    margin: 8px 0 0;
}

/* Separador vertical */
.is-separador-noticias-secundarias {
    width: 3px;
    height: 100%;
    min-height: 220px;
    background-color: #fff;
    opacity: 0.9;
}

/* Video --------------------------------------------------*/

.is-card-video-noticia {
    position: relative;
}

.is-video-noticia {
    border-radius: 8px 8px 8px 8px;
    border: 3px solid white;
    position: relative;
    width: 100%;
    height: 300px;
    overflow: hidden;
}

.is-play-video-noticia {
    position: absolute;
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%);

    width: 70px;
    height: 70px;
    border-radius: 50%;

    display: flex;
    align-items: center;
    justify-content: center;

    background-color: #00324a;
    color: #fff;
    font-size: 34px;
    line-height: 1;
    padding-left: 5px;
}
/*galerias ---------------------------------------------------------------------*/
/* Galería ---------------------------------------------------------------*/

.main-galeria-section {
    background-color: #e5e5e5;
    padding: 30px 0 35px;
}

.main-galeria {
    position: relative;
}

/* Header ---------------------------------------------------------------*/

.main-galeria-header {
    margin-bottom: 20px;
}

.is-titulo-galeria span {
    font-family: 'Teva Sans bold';
    font-size: 30px;
    line-height: 1;
    letter-spacing: 2px;
    color: #002b3f;
    text-transform: uppercase;
}

/* Filtros ---------------------------------------------------------------*/

.is-filtros-galeria {
    display: flex;
    align-items: center;
    justify-content: flex-end;
    gap: 35px;
}

.is-anios-galeria {
    display: flex;
    align-items: center;
    gap: 18px;
}

.is-anios-galeria a,
.is-anios-galeria span {
    font-family: 'Teva Sans bold';
    font-size: 16px;
    line-height: 1;
    color: #000;
    text-decoration: none;
}

.is-anios-galeria a:hover {
    color: #0073b8;
}

/* Buscador ---------------------------------------------------------------*/

.is-busqueda-galeria {
    display: flex;
    align-items: center;
    gap: 12px;
    margin: 0;
}

.is-busqueda-galeria label {
    font-family: 'Teva Sans';
    font-size: 16px;
    color: #000;
    margin: 0;
    white-space: nowrap;
}

.is-input-busqueda-galeria {
    display: flex;
    align-items: center;
    width: 195px;
    height: 38px;
    background-color: #fff;
    border-radius: 10px;
    overflow: hidden;
}

.is-input-busqueda-galeria button {
    width: 42px;
    height: 38px;
    border: none;
    background-color: transparent;
    color: #000;
    font-size: 18px;
    cursor: pointer;
}

.is-input-busqueda-galeria input {
    flex: 1;
    width: 100%;
    height: 38px;
    border: none;
    outline: none;
    padding: 0 10px 0 0;
    font-family: 'Teva Sans';
    font-size: 15px;
}

/* Slider base ---------------------------------------------------------------*/

.is-slider-galeria {
    width: 100%;
}

.multi-carousel-viewport {
    width: 100%;
    overflow: hidden;
}

.multi-carousel-inner {
    display: flex;
    transition: transform 0.4s ease;
}

.multi-carousel-item {
    padding: 0 8px;
}

/* Card galería ---------------------------------------------------------------*/

.is-card-galeria {
    display: block;
    color: #000;
    text-decoration: none;
}

.is-card-galeria:hover {
    color: #000;
    text-decoration: none;
}

.is-imagen-galeria {
    width: 100%;
    height: 200px;
    border-radius: 8px;
    overflow: hidden;
    background-color: #ccc;
}

.is-imagen-galeria img {
    width: 100%;
    height: 100%;
    display: block;
    object-fit: cover;
}

/* Texto card ---------------------------------------------------------------*/

.is-body-galeria {
    padding: 8px 4px 0;
}

.is-descripcion-galeria {
    font-family: 'Teva Sans';
    font-size: 10px;
    line-height: 1.15;
    color: #000;
    margin: 0 0 8px;
}

.is-fecha-galeria {
    font-family: 'Teva Sans bold';
    font-size: 10px;
    line-height: 1;
    color: #000;
    text-transform: uppercase;
}

/* Dots ---------------------------------------------------------------*/

.is-dots-galeria {
    display: flex;
    justify-content: center;
    align-items: center;
    gap: 12px;
    margin-top: 25px;
}

.is-dot-galeria {
    width: 8px;
    height: 8px;
    border: none;
    border-radius: 50%;
    background-color: #fff;
    opacity: 0.65;
    padding: 0;
    cursor: pointer;
}

.is-dot-galeria.is-active {
    opacity: 1;
}

/* Responsive ---------------------------------------------------------------*/

@media (max-width: 991px) {
    .is-filtros-galeria {
        justify-content: flex-start;
        flex-wrap: wrap;
        gap: 20px;
        margin-top: 15px;
    }

    .is-imagen-galeria {
        height: 180px;
    }
}

@media (max-width: 576px) {
    .main-galeria-section {
        padding: 25px 0 30px;
    }

    .is-titulo-galeria span {
        font-size: 26px;
    }

    .is-filtros-galeria {
        flex-direction: column;
        align-items: flex-start;
    }

    .is-busqueda-galeria {
        width: 100%;
        flex-direction: column;
        align-items: flex-start;
        gap: 8px;
    }

    .is-input-busqueda-galeria {
        width: 100%;
    }

    .is-imagen-galeria {
        height: 220px;
    }
}
/* Footer ---------------------------------------------------------------*/

.main-footer {
    background-color: #ffffff;
    padding: 70px 0 50px;
}

/* Logos superiores */
.main-footer-logos {
    margin-bottom: 30px;
}

.is-logo-footer {
    display: inline-block;
    text-decoration: none;
}

.is-logo-footer img {
    display: block;
    width: auto;
    max-width: 230px;
    max-height: 60px;
    margin: 0 auto;
}

/* Contenido */
.main-footer-content {
    align-items: flex-start;
}

.is-footer-box {
    text-align: left;
}

/* Títulos */
.is-titulo-footer {
    font-family: 'Teva Sans bold';
    font-size: 18px;
    line-height: 1.2;
    color: #002b3f;
    margin-bottom: 18px;
}

/* Textos */
.is-texto-footer {
    font-family: 'Teva Sans';
    font-size: 14px;
    line-height: 1.45;
    color: #686868;
    margin-bottom: 14px;
}

/* Listas */
.is-lista-footer {
    list-style: none;
    padding: 0;
    margin: 0;

    font-family: 'Teva Sans';
    font-size: 14px;
    line-height: 1.45;
    color: #686868;
}

.is-lista-footer li::before {
    content: "° ";
}

.is-lista-info-footer li::before {
    content: "";
}

/* Redes sociales */
.is-social-footer {
    display: flex;
    align-items: center;
    gap: 14px;
    margin-top: 12px;
}

.is-social-footer a {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    text-decoration: none;
}

.is-social-footer img {
    width: 30px;
    height: 30px;
    display: block;
    object-fit: contain;
    transition: transform 0.3s ease;
}

.is-social-footer a:hover img {
    transform: scale(1.1);
}

@media (max-width: 991px) {
    .main-footer {
        padding: 50px 0 40px;
    }

    .main-footer-logos {
        row-gap: 25px;
    }

    .main-footer-content {
        row-gap: 30px;
    }

    .is-footer-box {
        text-align: left;
    }
}

@media (max-width: 576px) {
    .main-footer {
        padding: 40px 0 35px;
    }

    .is-logo-footer img {
        max-width: 190px;
    }

    .is-titulo-footer {
        font-size: 17px;
        margin-bottom: 12px;
    }

    .is-texto-footer,
    .is-lista-footer {
        font-size: 13px;
    }
}

/* Nosotros ---------------------------------------------------------------*/

.page-nosotros {
    background-color: #e5e5e5;
}

/* Banner principal ------------------------------------------------------*/

.main-banner-nosotros {
    position: relative;
    width: 100%;
    min-height: 455px;
    display: flex;
    align-items: center;
    overflow: hidden;
    background-color: #002b3f;
}

.main-banner-nosotros .is-fondo-nosotros {
    position: absolute;
    inset: 0;
    width: 100%;
    height: 100%;
    object-fit: cover;
    object-position: center;
    z-index: 1;
}

.main-banner-nosotros .is-overlay-nosotros {
    position: absolute;
    inset: 0;
    background-color: rgba(0, 42, 60, 0.68);
    z-index: 2;
}

.main-banner-nosotros .container {
    z-index: 3;
}

.is-nosotros-logo {
    padding: 200px 0px 120px 0px;

}

.is-nosotros-logo img {
    width: 100%;
    max-width: 250px;
    height: auto;
}

.is-titulo-nosotros {
    font-family: 'Teva Sans bold';
    font-size: 38px;
    line-height: 1;
    color: #fff;
    text-transform: uppercase;
    letter-spacing: 4px;
    margin-bottom: 25px;
}

.is-texto-nosotros {
    max-width: 1080px;
    margin: 0 auto;
    font-family: 'Teva Sans';
    font-size: 20px;
    line-height: 1.35;
    color: #fff;
    text-align: left;
    padding-bottom: 30px;
}

/* nosotros Qué hacemos -----------------------------------------------------------*/

.main-content-nosotros {
    position: relative;
    padding: 45px 0 35px;
    background: linear-gradient(
        to bottom,
        #0073b8 0%,
        #0073b8 72%,
        #e5e5e5 72%,
        #e5e5e5 100%
    );    
}
.is-linea-sup {
    position: absolute;
    top: 0;
    left: 25%;
    width: 50%;    
    border-top: 2px solid white;
    
}

.is-titulo-que-hacemos {
    font-family: 'Teva Sans bold';
    font-size: 38px;
    line-height: 1;
    color: #fff;
    text-transform: uppercase;
    letter-spacing: 3px;
    margin-bottom: 22px;
}

.is-texto-que-hacemos {
    max-width: 1080px;
    margin: 0 auto;
    font-family: 'Teva Sans';
    font-size: 20px;
    line-height: 1.35;
    color: #fff;
    text-align: left;
}

/* NosotrosCards grandes ---------------------------------------------------------*/

.is-card-nosotros-big {
    margin-top: 35px;
    row-gap: 25px;
}

.is-card-nosotros {
    display: block;
    width: 100%;
    text-decoration: none;
    color: inherit;
    transition: transform 0.3s ease;
}

.is-card-nosotros:hover {
    transform: translateY(-4px);
    text-decoration: none;
}

.is-card-nosotros-grande {
    background-color: #fff;
    border-radius: 8px;
    overflow: hidden;
}

.is-card-nosotros-grande .is-imagen-card-nosotros {
    width: 100%;
    height: 220px;
    overflow: hidden;
}

.is-card-nosotros-grande .is-titulo-card-nosotros {
    min-height: 48px;
    padding: 8px 10px;
    background-color: #fff;
    font-family: 'Teva Sans bold';
    font-size: 15px;
    line-height: 1;
    color: #0073b8;
    text-align: center;
}

/* Nosotros Cards pequeñas --------------------------------------------------------*/

.is-card-nosotros-small {
    margin-top: 25px;
    row-gap: 25px;      

}

.is-card-nosotros-small .col-12 {
    max-width: 300px;
    padding: 0px 38px;

}


.is-card-nosotros-pequena {
    overflow: hidden;
    background-color: #00364d;
    border-radius: 0px 0px 8px 8px;
}

.is-card-nosotros-pequena .is-imagen-card-nosotros {
    width: 100%;
    height: 170px;
    overflow: hidden;
}

.is-card-nosotros-pequena .is-titulo-card-nosotros {
    min-height: 36px;
    padding: 6px 10px;
    background-color: #00364d;
    font-family: 'Teva Sans bold';
    font-size: 13px;
    line-height: 1;
    color: #fff;
    text-align: center;
}

.is-imagen-card-nosotros img {
    width: 100%;
    height: 100%;
    display: block;
    object-fit: cover;
}

/* Nosotros Clientes --------------------------------------------------------------*/

.main-content-nosotros-clientes {
    position: relative;
    height: 640px;
    display: flex;
    align-items: center;
    overflow: hidden;
    background-color: #00364d;
}

.banner-nosotros-clientes {
    position: absolute;
    inset: 0;
    width: 100%;
    height: 100%;
    object-fit: cover;
    object-position: center;
    z-index: 1;
}

.is-overlay-clientes {
    position: absolute;
    inset: 0;
    background-color: rgba(0, 61, 70, 0.55);
    z-index: 2;
}

.is-overlay-clientes::after {
    content: "";
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    background: linear-gradient(360deg, rgba(255, 255, 255, 1) 20%, rgba(242, 242, 242, 0) 85%);    
}

.main-content-nosotros-clientes .container {
    z-index: 3;
}

.is-titulo-nosotros-clientes {
    font-family: 'Teva Sans bold';
    font-size: 28px;
    line-height: 1;
    color: #fff;
    text-transform: uppercase;
    letter-spacing: 4px;
    margin-bottom: 40px;
    text-shadow: 1px 1px 1px rgba(0, 0, 0, 0.5);
}

.is-logo-nosotros-clientes {
    display: flex;
    align-items: center;
    justify-content: center;
    flex-wrap: wrap;
    gap: 35px 65px;
    max-width: 950px;
    margin: 0 auto;
}

.is-logo-nosotros-clientes img {
    display: block;
    max-width: 160px;
    max-height: 120px;
    width: auto;
    height: auto;
    object-fit: contain;    
}

/* Responsive Nosotros------------------------------------------------------------*/

@media (max-width: 991px) {
    .main-banner-nosotros {
        min-height: 420px;
        padding: 70px 0;
    }

    .main-content-nosotros {
        background: #0073b8;
        padding-bottom: 45px;
    }

    .is-card-nosotros-small {
        margin-top: 25px;
    }

    .is-card-nosotros-pequena {
        border-radius: 8px;
    }

    .is-logo-nosotros-clientes {
        gap: 30px 45px;
    }
}

@media (max-width: 576px) {
    .main-banner-nosotros {
        min-height: auto;
        padding: 55px 0;
    }

    .is-nosotros-logo img {
        max-width: 190px;
    }

    .is-titulo-nosotros,
    .is-titulo-que-hacemos,
    .is-titulo-nosotros-clientes {
        font-size: 23px;
        letter-spacing: 2px;
    }

    .is-texto-nosotros,
    .is-texto-que-hacemos {
        font-size: 13px;
        line-height: 1.4;
    }

    .is-card-nosotros-grande .is-imagen-card-nosotros {
        height: 180px;
    }

    .is-card-nosotros-pequena .is-imagen-card-nosotros {
        height: 160px;
    }

    .main-content-nosotros-clientes {
        min-height: auto;
        padding: 55px 0;
    }

    .is-logo-nosotros-clientes {
        gap: 25px;
    }

    .is-logo-nosotros-clientes img {
        max-width: 130px;
        max-height: 50px;
    }
}

/* Servicios page ---------------------------------------------------------------*/

.page-servicios {
    background-color: #e5e5e5;
}

/* Banner + servicios ----------------------------------------------------------*/

.main-servicios-page {
    position: relative;
    width: 100%;
    padding: 160px 0 45px;
    overflow: hidden;
    background-color: #002b3f;
}

.main-servicios-page .is-fondo-servicios {
    position: absolute;
    inset: 0;
    width: 100%;
    height: 100%;
    object-fit: cover;
    object-position: center;
    z-index: 1;
}

.main-servicios-page .is-overlay-servicios {
    position: absolute;
    inset: 0;
    background-color: rgba(0, 35, 50, 0.72);
    z-index: 2;
}

.main-servicios-page .container {
    z-index: 3;
}

.is-titulo-servicios {
    font-family: 'Teva Sans bold';
    font-size: 30px;
    line-height: 1;
    color: #fff;
    letter-spacing: 4px;
    text-transform: uppercase;
    margin-bottom: 100px;
}

/* Cards servicios -------------------------------------------------------------*/

.is-servicios-cards {
    row-gap: 34px;
}

.is-card-servicios {
    display: block;
    width: 100%;
    overflow: hidden;
    text-decoration: none;
    color: inherit;
    transition: transform 0.3s ease;
}

.is-card-servicios:hover {
    transform: translateY(-4px);
    text-decoration: none;
}

.is-imagen-card-servicios {
    width: 100%;
    height: 200px;
    overflow: hidden;
}

.is-imagen-card-servicios img {
    width: 100%;
    height: 100%;
    display: block;
    object-fit: cover;
}

/* Cards fila superior */
.is-card-servicios-up  .is-titulo-card-servicios{
    background-color: #fff;
    border-radius: 0px 0px 8px 8px;
}

.is-card-servicios-up .is-titulo-card-servicios {
    min-height: 42px;
    padding: 7px 10px;
    background-color: #fff;
    color: #0073b8;
}

/* Cards fila inferior */
.is-card-servicios-down .is-titulo-card-servicios{
    background-color: #0073b8;
    border-radius: 0px 0px 8px 8px;
}

.is-card-servicios-down .is-titulo-card-servicios {
    min-height: 50px;
    padding: 7px 10px;
    background-color: #0073b8;
    color: #fff;
}

.is-titulo-card-servicios {
    display: flex;
    align-items: center;
    justify-content: center;
    font-family: 'Teva Sans bold';
    font-size: 14px;
    line-height: 1;
    text-align: center;
}

.is-detalle-card-servicios {
    font-family: 'Teva Sans';
    font-size: 14px;
    line-height: 1.12;
    color: #fff;
    margin-top: 14px;
    max-width: 230px;
}

/* Experiencias ---------------------------------------------------------------*/

.main-experiencias-servicios {
    background-color: white;
    padding: 38px 0 45px;
}

.is-titulo-experiencias-servicios {
    font-family: 'Teva Sans bold';
    font-size: 30px;
    line-height: 1;
    letter-spacing: 3px;
    text-transform: uppercase;
    color: black;
    margin-bottom: 28px;
}

.is-experiencias-cards {
    row-gap: 25px;
}

.is-card-experiencia {
    display: block;
    background-color: #00364d;
    color: #fff;
    text-decoration: none;
    overflow: hidden;
    border-radius: 0px 0px 8px 8px;
}

.is-card-experiencia:hover {
    color: #fff;
    text-decoration: none;
}

.is-imagen-experiencia {
    width: 100%;
    height: 240px;
    overflow: hidden;
}

.is-imagen-experiencia img {
    width: 100%;
    height: 100%;
    display: block;
    object-fit: cover;
}

.is-body-experiencia {
    position: relative;
    padding: 12px 18px 22px;
    min-height: 60px;
}

.is-body-experiencia p {
    font-family: 'Teva Sans';
    font-size: 20px;
    line-height: 1.25;
    color: #fff;
    margin: 0;
    text-align: center;
}

.is-btn-experiencia {
    position: absolute;
    right: 14px;
    bottom: -1px;

    width: 32px;
    height: 18px;
    border-radius: 20px 20px 0 0;

    display: flex;
    align-items: center;
    justify-content: center;

    background-color: #009bd8;
    color: #fff;
    font-size: 14px;
}

/* Responsive ----------------------------------------------------------------*/

@media (max-width: 991px) {
    .main-servicios-page {
        padding: 55px 0 45px;
    }

    .is-titulo-servicios {
        margin-bottom: 35px;
    }

    .is-detalle-card-servicios {
        max-width: 100%;
    }

    .is-imagen-card-servicios {
        height: 165px;
    }

    .is-imagen-experiencia {
        height: 180px;
    }
}

@media (max-width: 576px) {
    .main-servicios-page {
        padding: 45px 0 40px;
    }

    .is-titulo-servicios,
    .is-titulo-experiencias-servicios {
        font-size: 24px;
        letter-spacing: 2px;
    }

    .is-imagen-card-servicios {
        height: 190px;
    }

    .is-detalle-card-servicios {
        font-size: 13px;
    }

    .is-imagen-experiencia {
        height: 200px;
    }
}

/* Campeonatos ---------------------------------------------------------------*/

.page-campeonatos {
    background-color: #e5e5e5;
}

/* Banner -------------------------------------------------------------------*/

.main-banner-campeonatos {
    position: relative;
    width: 100%;
    min-height: 260px;
    display: flex;
    align-items: center;
    overflow: hidden;
    background-color: #002b3f;
}

.main-banner-campeonatos .is-fondo-campeonatos {
    position: absolute;
    inset: 0;
    width: 100%;
    height: 100%;
    object-fit: cover;
    object-position: center;
    z-index: 1;
}

.main-banner-campeonatos .is-overlay-campeonatos {
    position: absolute;
    inset: 0;
    background-color: rgba(0, 45, 60, 0.68);
    z-index: 2;
}

.main-banner-campeonatos .container {
    z-index: 3;
}

.is-titulo-campeonatos {
    font-family: 'Teva Sans bold';
    font-size: 32px;
    line-height: 1;
    color: #fff;
    text-transform: uppercase;
    letter-spacing: 4px;
    margin-bottom: 45px;
}

.is-categorias-campeonatos {
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 18px;
}

.is-categorias-campeonatos a {
    font-family: 'Teva Sans bold';
    font-size: 16px;
    line-height: 1;
    color: #fff;
    text-transform: uppercase;
    text-decoration: none;
}

.is-categorias-campeonatos a:hover {
    color: #2ca6dc;
}

.is-categorias-campeonatos span {
    width: 2px;
    height: 24px;
    background-color: rgba(255, 255, 255, 0.75);
}

/* Listado ------------------------------------------------------------------*/

.main-card-campeonatos {
    background-color: #0073b8;
    padding: 35px 0 55px;
}

.main-campeonatos-header {
    margin-bottom: 28px;
}

.is-titulo-listado-campeonatos {
    font-family: 'Teva Sans bold';
    font-size: 24px;
    line-height: 1;
    color: #fff;
    margin: 0;
}

/* Buscador -----------------------------------------------------------------*/

.is-busqueda-campeonatos {
    display: flex;
    align-items: center;
    justify-content: flex-end;
    gap: 12px;
    margin: 0;
}

.is-busqueda-campeonatos label {
    font-family: 'Teva Sans';
    font-size: 12px;
    color: #fff;
    margin: 0;
    white-space: nowrap;
}

.is-input-busqueda-campeonatos {
    width: 180px;
    height: 28px;
    display: flex;
    align-items: center;
    background-color: #fff;
    border-radius: 6px;
    overflow: hidden;
}

.is-input-busqueda-campeonatos button {
    width: 34px;
    height: 28px;
    border: none;
    background-color: transparent;
    color: #000;
    font-size: 13px;
    cursor: pointer;
}

.is-input-busqueda-campeonatos input {
    flex: 1;
    width: 100%;
    height: 28px;
    border: none;
    outline: none;
    padding: 0 8px 0 0;
    font-family: 'Teva Sans';
    font-size: 13px;
}

/* Cards --------------------------------------------------------------------*/

.is-listado-campeonatos {
    row-gap: 34px;
}

.is-card-campeonatos {
    text-align: center;
}

.is-card-campeonatos-link {
    display: block;
    text-decoration: none;
    color: inherit;
}

.is-card-campeonatos-link:hover {
    text-decoration: none;
}

.is-imagen-card-campeonatos {
    position: relative;
    width: 100%;
    height: 150px;
    border-radius: 8px 8px 0 0;
    overflow: hidden;
    background-color: #ccc;
}

.is-imagen-card-campeonatos img {
    width: 100%;
    height: 100%;
    display: block;
    object-fit: cover;
}

/* Fecha sobre imagen */
.is-fecha-campeonatos {
    position: absolute;
    left: 50%;
    bottom: 0;
    transform: translateX(-50%);

    min-width: 150px;
    padding: 5px 10px;

    font-family: 'Teva Sans bold';
    font-size: 11px;
    line-height: 1;
    color: #fff;
    text-transform: uppercase;
    text-align: center;

    background-color: #0073b8;
}

/* Título card */
.is-titulo-card-campeonatos {
    min-height: 58px;
    padding: 10px 12px;

    display: flex;
    align-items: center;
    justify-content: center;

    font-family: 'Teva Sans bold';
    font-size: 15px;
    line-height: 1.15;
    color: #000;
    text-align: center;

    background-color: #e5e5e5;
    border-radius: 0 0 8px 8px;
}

/* Web del evento */
.is-web-evento-campeonatos {
    display: inline-block;
    margin-top: 18px;

    font-family: 'Teva Sans bold';
    font-size: 10px;
    line-height: 1;
    color: #fff;
    text-transform: uppercase;
    text-decoration: none;
}

.is-web-evento-campeonatos:hover {
    color: #002b3f;
    text-decoration: none;
}

/* Botón ver todos ----------------------------------------------------------*/

.btn-vermas-campeonatos {
    margin-top: 35px;
}

.btn-vermas-campeonatos .btn-primary {
    font-family: 'Teva Sans bold';
    font-size: 14px;
    line-height: 1;
    color: #fff;
    background-color: #002b3f;
    border: none;
    border-radius: 4px;
    padding: 9px 24px;
}

.btn-vermas-campeonatos .btn-primary:hover {
    background-color: #001c2a;
    color: #fff;
}

/* Responsive ---------------------------------------------------------------*/

@media (max-width: 991px) {
    .main-banner-campeonatos {
        min-height: 240px;
    }

    .is-titulo-campeonatos {
        font-size: 28px;
        margin-bottom: 35px;
    }

    .is-busqueda-campeonatos {
        justify-content: flex-start;
        margin-top: 18px;
    }

    .is-imagen-card-campeonatos {
        height: 180px;
    }
}

@media (max-width: 576px) {
    .main-banner-campeonatos {
        min-height: 220px;
    }

    .is-titulo-campeonatos {
        font-size: 24px;
        letter-spacing: 2px;
        margin-bottom: 30px;
    }

    .is-categorias-campeonatos {
        gap: 12px;
        flex-wrap: wrap;
    }

    .is-categorias-campeonatos a {
        font-size: 13px;
    }

    .is-categorias-campeonatos span {
        height: 18px;
    }

    .main-card-campeonatos {
        padding: 30px 0 45px;
    }

    .is-titulo-listado-campeonatos {
        font-size: 22px;
    }

    .is-busqueda-campeonatos {
        flex-direction: column;
        align-items: flex-start;
        gap: 8px;
    }

    .is-input-busqueda-campeonatos {
        width: 100%;
        height: 36px;
    }

    .is-input-busqueda-campeonatos button,
    .is-input-busqueda-campeonatos input {
        height: 36px;
    }

    .is-imagen-card-campeonatos {
        height: 210px;
    }
}


/* Noticias page ---------------------------------------------------------------*/

.page-noticias {
    background-color: #e5e5e5;
}

/* Banner --------------------------------------------------------------------*/

.main-banner-noticias {
    position: relative;
    width: 100%;
    height: 100%;
    min-height: 410px;
    display: flex;
    align-items: center;
    overflow: hidden;
    background-color: #002b3f;
}

.main-banner-noticias .is-fondo-noticias {
    position: absolute;
    inset: 0;
    width: 100%;
    height: 100%;
    object-fit: cover;
    object-position: center;
    z-index: 1;
}

.main-banner-noticias .is-overlay-noticias {
    position: absolute;
    inset: 0;
    background-color: rgba(0, 45, 60, 0.68);
    z-index: 2;
}

.main-banner-noticias .container {
    z-index: 3;
}

.is-titulo-noticias-page {
    font-family: 'Teva Sans bold';
    font-size: 28px;
    line-height: 1;
    color: #fff;
    text-transform: uppercase;
    letter-spacing: 4px;
    margin-bottom: 32px;
}

/* Filtros -------------------------------------------------------------------*/

.is-filtro-noticias {
    display: flex;
    align-items: center;
    justify-content: center;
    flex-wrap: wrap;
    gap: 20px 30px;
}

.is-filtro-noticias a {
    font-family: 'Teva Sans bold';
    font-size: 24px;
    line-height: 1;
    color: #fff;
    text-transform: uppercase;
    text-decoration: none;
    letter-spacing: 1px;
}

.is-filtro-noticias a:hover {
    color: #2ca6dc;
}



/* Listado noticias ----------------------------------------------------------*/

.main-listado-noticias {
    background-color: #e5e5e5;
    padding: 25px 0 35px;
}

/* Buscador -----------------------------------------------------------------*/

.is-busqueda-noticias,
.is-busqueda-videos {
    display: flex;
    align-items: center;
    justify-content: flex-end;
    gap: 12px;
    margin: 0 0 25px;
}

.is-busqueda-noticias label,
.is-busqueda-videos label {
    font-family: 'Teva Sans';
    font-size: 12px;
    color: #000;
    margin: 0;
    white-space: nowrap;
}

.is-input-busqueda-noticias,
.is-input-busqueda-videos {
    width: 180px;
    height: 28px;
    display: flex;
    align-items: center;
    background-color: #fff;
    border-radius: 6px;
    overflow: hidden;
}

.is-input-busqueda-noticias button,
.is-input-busqueda-videos button {
    width: 34px;
    height: 28px;
    border: none;
    background-color: transparent;
    color: #000;
    font-size: 13px;
    cursor: pointer;
}

.is-input-busqueda-noticias input,
.is-input-busqueda-videos input {
    flex: 1;
    width: 100%;
    height: 28px;
    border: none;
    outline: none;
    padding: 0 8px 0 0;
    font-family: 'Teva Sans';
    font-size: 13px;
}

/* Cards noticias ------------------------------------------------------------*/

.noticias-cards {
    row-gap: 28px;
}

.card-noticia {
    display: block;
    color: #000;
    text-decoration: none;
}

.card-noticia:hover {
    color: #000;
    text-decoration: none;
}

.imagen-card-noticia {
    width: 100%;
    height: 410px;
    overflow: hidden;
    border-radius: 8px 8px;
    background-color: #ccc;
}

.imagen-card-noticia img {
    width: 100%;
    height: 100%;
    display: block;
    object-fit: cover;
}

.body-card-noticia {
    position: relative;
    padding: 0 6px 10px;
}

.categoria-card-noticia {
    display: inline-block;
    position: absolute;
    margin-top: -80px;
    z-index: 2;
    padding: 10px 18px;
    left: 0px;

    font-family: 'Teva Sans bold';
    font-size: 20px;
    line-height: 1;
    color: #fff;

    background-color: #0073b8;
}

.descripcion-card-noticia {
    font-family: 'Teva Sans';
    font-size: 15px;
    line-height: 1.2;
    color: #000;
    margin: 8px 0 0;
}

/* Paginador ----------------------------------------------------------------*/

.paginador-noticias {
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 20px;
    margin-top: 28px;
}

.is-paginador-link,
.is-paginador-arrow {
    font-family: 'Teva Sans bold';
    font-size: 25px;
    line-height: 1;
    color: #000;
    text-decoration: none;
}

.is-paginador-link.is-active,
.is-paginador-link:hover,
.is-paginador-arrow:hover {
    color: #0073b8;
}

/* Videos -------------------------------------------------------------------*/

.main-videos-noticias {
    background-color: #002b3f;
    padding: 35px 0 45px;
}

.main-videos-noticias-header {
    margin-bottom: 20px;
}

.is-titulo-videos-noticias {
    font-family: 'Teva Sans bold';
    font-size: 26px;
    line-height: 1;
    color: #fff;
    letter-spacing: 3px;
    text-transform: uppercase;
    margin: 0 0 25px;
}

.main-videos-noticias .is-busqueda-videos {
    margin-bottom: 25px;
}

.main-videos-noticias .is-busqueda-videos label {
    color: #fff;
}

.is-noticias-videos {
    row-gap: 28px;
}

.is-card-video-noticia-page {
    display: block;
    color: #fff;
    text-decoration: none;
}

.is-card-video-noticia-page:hover {
    color: #fff;
    text-decoration: none;
}

.is-imagen-card-video {
    position: relative;
    width: 100%;
    height: 240px;
    overflow: hidden;
    border-radius: 8px 8px;
    background-color: #ccc;
}

.is-imagen-card-video img {
    width: 100%;
    height: 100%;
    display: block;
    object-fit: cover;
}

.is-play-card-video {
    position: absolute;
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%);

    width: 58px;
    height: 58px;
    border-radius: 50%;

    display: flex;
    align-items: center;
    justify-content: center;

    background-color: #00364d;
    color: #fff;
    font-size: 22px;
    padding-left: 4px;
}

.is-body-card-video {
    position: relative;
    padding: 0 6px 10px;
}

.is-categoria-card-video {
    display: inline-block;
    position: absolute;
    margin-top: -50px;
    left: 0px;
    z-index: 2;
    padding: 5px 12px;

    font-family: 'Teva Sans bold';
    font-size: 11px;
    line-height: 1;
    color: #fff;

    background-color: #0073b8;
}

.is-descripcion-card-video {
    font-family: 'Teva Sans';
    font-size: 11px;
    line-height: 1.2;
    color: #fff;
    margin: 8px 0 0;
}

/* Responsive ---------------------------------------------------------------*/

@media (max-width: 991px) {
    .main-banner-noticias {
        min-height: 240px;
        padding: 50px 0;
    }

    .is-filtro-noticias {
        gap: 12px;
    }

    .is-busqueda-noticias,
    .is-busqueda-videos {
        justify-content: flex-start;
        margin-top: 15px;
    }

    .imagen-card-noticia,
    .is-imagen-card-video {
        height: 180px;
    }

    .is-titulo-videos-noticias {
        text-align: center;
    }
}

@media (max-width: 576px) {
    .is-titulo-noticias-page {
        font-size: 24px;
        letter-spacing: 2px;
    }

    .is-filtro-noticias a {
        font-size: 11px;
    }

    .is-filtro-noticias span {
        display: none;
    }

    .is-busqueda-noticias,
    .is-busqueda-videos {
        flex-direction: column;
        align-items: flex-start;
        gap: 8px;
    }

    .is-input-busqueda-noticias,
    .is-input-busqueda-videos {
        width: 100%;
        height: 36px;
    }

    .is-input-busqueda-noticias button,
    .is-input-busqueda-noticias input,
    .is-input-busqueda-videos button,
    .is-input-busqueda-videos input {
        height: 36px;
    }

    .imagen-card-noticia,
    .is-imagen-card-video {
        height: 210px;
    }

    .paginador-noticias {
        gap: 14px;
    }
}

/* Galería page ---------------------------------------------------------------*/

.page-galeria {
    background-color: #e5e5e5;
}

/* Banner --------------------------------------------------------------------*/

.main-banner-galeria {
    position: relative;
    width: 100%;
    min-height: 260px;
    display: flex;
    align-items: center;
    overflow: hidden;
    background-color: #002b3f;
}

.main-banner-galeria .is-fondo-galeria {
    position: absolute;
    inset: 0;
    width: 100%;
    height: 100%;
    object-fit: cover;
    object-position: center;
    z-index: 1;
}

.main-banner-galeria .is-overlay-galeria {
    position: absolute;
    inset: 0;
    background-color: rgba(0, 45, 60, 0.68);
    z-index: 2;
}

.main-banner-galeria .container {
    z-index: 3;
}

.is-titulo-galeria-page {
    font-family: 'Teva Sans bold';
    font-size: 28px;
    line-height: 1;
    color: #fff;
    text-transform: uppercase;
    letter-spacing: 4px;
    margin-bottom: 32px;
}

/* Tabs ----------------------------------------------------------------------*/

.main-tabs-galeria {
    background-color: #fff;
}

.is-tabs-galeria {
    display: flex;
    align-items: center;
}

.is-tab-galeria {
    display: inline-flex;
    align-items: center;
    padding: 16px 38px;
    font-family: 'Teva Sans bold';
    font-size: 18px;
    line-height: 1;
    color: #686868;
    text-decoration: none;
    text-transform: uppercase;
    letter-spacing: 2px;
    border-bottom: 3px solid transparent;
    transition: color 0.2s ease, border-color 0.2s ease;
}

.is-tab-galeria:hover {
    color: #0073b8;
    text-decoration: none;
}

.is-tab-galeria.is-active {
    color: var(--main-azul);
    border-bottom-color: var(--main-azul);
}

/* Filtros categoría ---------------------------------------------------------*/

.is-filtros-cat-galeria {
    display: flex;
    align-items: center;
    flex-wrap: wrap;
    gap: 8px 14px;
    padding: 18px 0 0;
}

.is-filtros-cat-galeria a {
    font-family: 'Teva Sans bold';
    font-size: 15px;
    line-height: 1;
    text-decoration: none;
    text-transform: uppercase;
    padding: 5px 14px;
    border-radius: 4px;
    transition: background-color 0.2s ease, color 0.2s ease;
}

.main-fotos-galeria .is-filtros-cat-galeria a {
    color: #000;
}

.main-fotos-galeria .is-filtros-cat-galeria a:hover {
    background-color: #0073b8;
    color: #fff;
}

.main-fotos-galeria .is-filtros-cat-galeria a.is-active {
    background-color: var(--main-azul);
    color: #fff;
}

.main-videos-galeria .is-filtros-cat-galeria a {
    color: rgba(255, 255, 255, 0.75);
}

.main-videos-galeria .is-filtros-cat-galeria a:hover {
    background-color: var(--main-azul);
    color: #fff;
}

.main-videos-galeria .is-filtros-cat-galeria a.is-active {
    background-color: #fff;
    color: #002b3f;
}

/* Sección fotos -------------------------------------------------------------*/

.main-fotos-galeria {
    background-color: #e5e5e5;
    padding: 30px 0 45px;
}

.main-fotos-galeria .is-titulo-seccion-galeria {
    font-family: 'Teva Sans bold';
    font-size: 24px;
    line-height: 1;
    color: #002b3f;
    letter-spacing: 3px;
    text-transform: uppercase;
    margin: 0;
}

/* Cards fotos ---------------------------------------------------------------*/

.fotos-galeria-cards {
    row-gap: 28px;
    margin-top: 22px;
}

.is-card-album-galeria {
    display: block;
    color: #000;
    text-decoration: none;
    transition: transform 0.3s ease;
}

.is-card-album-galeria:hover {
    color: #000;
    text-decoration: none;
    transform: translateY(-4px);
}

.is-imagen-album-galeria {
    width: 100%;
    height: 220px;
    border-radius: 8px 8px 0 0;
    overflow: hidden;
    background-color: #ccc;
}

.is-imagen-album-galeria img {
    width: 100%;
    height: 100%;
    display: block;
    object-fit: cover;
    transition: transform 0.35s ease;
}

.is-card-album-galeria:hover .is-imagen-album-galeria img {
    transform: scale(1.04);
}

.is-body-album-galeria {
    padding: 8px 10px 10px;
    background-color: #fff;
    border-radius: 0 0 8px 8px;
    min-height: 60px;
}

.is-titulo-album-galeria {
    font-family: 'Teva Sans bold';
    font-size: 14px;
    line-height: 1.2;
    color: #002b3f;
    margin-bottom: 4px;
    display: -webkit-box;
    -webkit-line-clamp: 2;
    line-clamp: 2;
    -webkit-box-orient: vertical;
    overflow: hidden;
}

.is-meta-album-galeria {
    display: flex;
    align-items: center;
    justify-content: space-between;
    margin-top: 4px;
}

.is-fecha-album-galeria {
    font-family: 'Teva Sans';
    font-size: 11px;
    color: #686868;
}

.is-total-album-galeria {
    font-family: 'Teva Sans';
    font-size: 11px;
    color: #0073b8;
}

/* Sección videos ------------------------------------------------------------*/

.main-videos-galeria {
    background-color: #002b3f;
    padding: 30px 0 45px;
}

.main-videos-galeria .is-titulo-seccion-galeria {
    font-family: 'Teva Sans bold';
    font-size: 24px;
    line-height: 1;
    color: #fff;
    letter-spacing: 3px;
    text-transform: uppercase;
    margin: 0;
}

.videos-galeria-cards {
    row-gap: 28px;
    margin-top: 22px;
}

/* Paginador galería ---------------------------------------------------------*/

.paginador-galeria {
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 20px;
    margin-top: 30px;
}

.main-fotos-galeria .paginador-galeria .is-paginador-link,
.main-fotos-galeria .paginador-galeria .is-paginador-arrow {
    color: #000;
}

.main-fotos-galeria .paginador-galeria .is-paginador-link.is-active,
.main-fotos-galeria .paginador-galeria .is-paginador-link:hover,
.main-fotos-galeria .paginador-galeria .is-paginador-arrow:hover {
    color: #0073b8;
}

.main-videos-galeria .paginador-galeria .is-paginador-link,
.main-videos-galeria .paginador-galeria .is-paginador-arrow {
    color: #fff;
}

.main-videos-galeria .paginador-galeria .is-paginador-link.is-active,
.main-videos-galeria .paginador-galeria .is-paginador-link:hover,
.main-videos-galeria .paginador-galeria .is-paginador-arrow:hover {
    color: #2ca6dc;
}

/* Responsive ---------------------------------------------------------------*/

@media (max-width: 991px) {
    .main-banner-galeria {
        min-height: 240px;
        padding: 50px 0;
    }

    .is-tab-galeria {
        padding: 14px 26px;
        font-size: 16px;
    }

    .is-imagen-album-galeria {
        height: 195px;
    }
}

@media (max-width: 576px) {
    .is-titulo-galeria-page {
        font-size: 24px;
        letter-spacing: 2px;
    }

    .is-tabs-galeria {
        justify-content: center;
    }

    .is-tab-galeria {
        padding: 12px 22px;
        font-size: 15px;
        letter-spacing: 1px;
    }

    .is-filtros-cat-galeria a {
        font-size: 13px;
        padding: 5px 10px;
    }

    .is-imagen-album-galeria {
        height: 205px;
    }

    .main-fotos-galeria,
    .main-videos-galeria {
        padding: 25px 0 35px;
    }
}

/* Galería page/end ----------------------------------------------------------*/

/*
 * style-theme.css
 * Estilos propios del tema onlygolf_2026.
 * Este archivo se compila junto con style-base.css y style-bootstrap.css
 * en assets/css/style.css mediante el sistema de build WebsiteBase.
 * Para reconstruir: añadir ?rebuild=onlygolf2020 a cualquier URL del sitio.
 */

/* =====================================================================
   Single Fotos (álbum de fotografías)
   ===================================================================== */

.single-fotos {
    background-color: #e5e5e5;
}

/* Banner ----------------------------------------------------------------*/

.main-banner-fotos {
    position: relative;
    width: 100%;
    min-height: 320px;
    display: flex;
    align-items: flex-end;
    overflow: hidden;
    background-color: #002b3f;
}

.main-banner-fotos .is-fondo-album {
    position: absolute;
    inset: 0;
    width: 100%;
    height: 100%;
    object-fit: cover;
    object-position: center;
    z-index: 1;
}

.main-banner-fotos .is-overlay-album {
    position: absolute;
    inset: 0;
    background: linear-gradient(0deg, rgba(0, 0, 0, 0.78) 0%, rgba(0, 0, 0, 0.12) 65%);
    z-index: 2;
}

.main-banner-fotos .container {
    z-index: 3;
    padding-bottom: 32px;
}

.is-categoria-album {
    display: inline-block;
    font-family: 'Teva Sans bold';
    font-size: 13px;
    line-height: 1;
    color: #fff;
    background-color: #0073b8;
    padding: 5px 12px;
    margin-bottom: 10px;
}

.is-titulo-album {
    font-family: 'Teva Sans bold';
    font-size: 34px;
    line-height: 1;
    color: #fff;
    text-transform: uppercase;
    letter-spacing: 2px;
    margin: 0 0 8px;
}

.is-autor-album {
    font-family: 'Teva Sans';
    font-size: 14px;
    color: rgba(255, 255, 255, 0.78);
    margin: 0;
}

/* Contenido fotos -------------------------------------------------------*/

.main-contenido-fotos {
    background-color: #e5e5e5;
    padding: 28px 0 45px;
}

.is-nav-fotos {
    display: flex;
    align-items: center;
    justify-content: space-between;
    flex-wrap: wrap;
    gap: 10px 18px;
    margin-bottom: 22px;
}

.is-volver-galeria {
    display: inline-flex;
    align-items: center;
    gap: 8px;
    font-family: 'Teva Sans bold';
    font-size: 14px;
    color: #002b3f;
    text-decoration: none;
    text-transform: uppercase;
    letter-spacing: 1px;
    transition: color 0.2s ease;
}

.is-volver-galeria:hover {
    color: #0073b8;
    text-decoration: none;
}

.is-contador-fotos {
    font-family: 'Teva Sans';
    font-size: 13px;
    color: #686868;
}

/* Grid de imágenes -------------------------------------------------------*/

.fotos-album-grid {
    row-gap: 12px;
}

.is-item-album {
    display: block;
    overflow: hidden;
    border-radius: 6px;
    background-color: #ccc;
    cursor: pointer;
}

.is-item-album img {
    width: 100%;
    height: 200px;
    display: block;
    object-fit: cover;
    transition: transform 0.32s ease;
}

.is-item-album:hover img {
    transform: scale(1.05);
}

/* Paginador fotos --------------------------------------------------------*/

.paginador-fotos {
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 18px;
    margin-top: 28px;
}

/* =====================================================================
   Lightbox (galería de fotos)
   ===================================================================== */

#og-lightbox {
    position: fixed;
    inset: 0;
    z-index: 9000;
    background-color: rgba(0, 0, 0, 0.93);
    display: flex;
    align-items: center;
    justify-content: center;
    opacity: 0;
    visibility: hidden;
    transition: opacity 0.22s ease, visibility 0.22s ease;
}

#og-lightbox.is-open {
    opacity: 1;
    visibility: visible;
}

.og-lb-contenedor {
    position: relative;
    max-width: 90vw;
    max-height: 88vh;
    display: flex;
    align-items: center;
    justify-content: center;
}

.og-lb-img {
    display: block;
    max-width: 90vw;
    max-height: 88vh;
    object-fit: contain;
    border-radius: 4px;
    user-select: none;
}

.og-lb-close {
    position: fixed;
    top: 16px;
    right: 20px;
    width: 42px;
    height: 42px;
    background: none;
    border: none;
    color: #fff;
    font-size: 32px;
    line-height: 1;
    cursor: pointer;
    opacity: 0.75;
    transition: opacity 0.2s;
    padding: 0;
    z-index: 1;
}

.og-lb-close:hover {
    opacity: 1;
}

.og-lb-prev,
.og-lb-next {
    position: fixed;
    top: 50%;
    transform: translateY(-50%);
    width: 46px;
    height: 46px;
    background: rgba(255, 255, 255, 0.1);
    border: none;
    border-radius: 50%;
    color: #fff;
    font-size: 20px;
    cursor: pointer;
    z-index: 1;
    display: flex;
    align-items: center;
    justify-content: center;
    transition: background 0.2s;
}

.og-lb-prev { left: 14px; }
.og-lb-next { right: 14px; }

.og-lb-prev:hover,
.og-lb-next:hover {
    background: rgba(255, 255, 255, 0.26);
}

.og-lb-contador {
    position: fixed;
    bottom: 16px;
    left: 50%;
    transform: translateX(-50%);
    font-family: 'Teva Sans';
    font-size: 13px;
    color: rgba(255, 255, 255, 0.65);
    white-space: nowrap;
}

/* =====================================================================
   Single Videos
   ===================================================================== */

.single-videos {
    background-color: #e5e5e5;
}

/* Header ----------------------------------------------------------------*/

.main-header-video {
    position: relative;
    width: 100%;
    min-height: 300px;
    display: flex;
    align-items: flex-end;
    overflow: hidden;
    background-color: #001c2a;
}

.main-header-video .is-fondo-video {
    position: absolute;
    inset: 0;
    width: 100%;
    height: 100%;
    object-fit: cover;
    object-position: center;
    z-index: 1;
    opacity: 0.38;
}

.main-header-video .is-overlay-video {
    position: absolute;
    inset: 0;
    background: linear-gradient(0deg, rgba(0, 20, 35, 0.92) 0%, rgba(0, 20, 35, 0.18) 72%);
    z-index: 2;
}

.main-header-video .container {
    z-index: 3;
    padding-bottom: 28px;
}

.is-titulo-video {
    font-family: 'Teva Sans bold';
    font-size: 30px;
    line-height: 1.05;
    color: #fff;
    text-transform: uppercase;
    letter-spacing: 2px;
    margin: 0;
    max-width: 820px;
}

/* Contenido video -------------------------------------------------------*/

.main-contenido-video {
    background-color: #001c2a;
    padding: 28px 0 45px;
}

.is-nav-video {
    display: flex;
    align-items: center;
    justify-content: space-between;
    flex-wrap: wrap;
    gap: 10px;
    margin-bottom: 22px;
}

.is-volver-galeria-video {
    display: inline-flex;
    align-items: center;
    gap: 8px;
    font-family: 'Teva Sans bold';
    font-size: 14px;
    color: rgba(255, 255, 255, 0.7);
    text-decoration: none;
    text-transform: uppercase;
    letter-spacing: 1px;
    transition: color 0.2s ease;
}

.is-volver-galeria-video:hover {
    color: #2ca6dc;
    text-decoration: none;
}

.is-fecha-video {
    font-family: 'Teva Sans';
    font-size: 13px;
    color: rgba(255, 255, 255, 0.55);
}

/* Player embed ----------------------------------------------------------*/

.is-player-wrapper {
    border-radius: 8px;
    overflow: hidden;
    background-color: #000;
}

.is-player-video {
    position: relative;
    width: 100%;
    padding-bottom: 56.25%;
    height: 0;
    overflow: hidden;
}

.is-player-video iframe {
    position: absolute;
    inset: 0;
    width: 100%;
    height: 100%;
    border: none;
}

/* Reel / vertical */
.is-player-vertical {
    max-width: 420px;
    margin: 0 auto;
}

.is-player-vertical .is-player-video {
    padding-bottom: 177.78%;
}

/* Instagram embed */
.is-player-ig {
    display: flex;
    justify-content: center;
    padding: 12px 0;
}

/* Relacionados ----------------------------------------------------------*/

.main-relacionados-video {
    background-color: #e5e5e5;
    padding: 35px 0 45px;
}

.is-titulo-relacionados {
    font-family: 'Teva Sans bold';
    font-size: 22px;
    line-height: 1;
    color: #002b3f;
    letter-spacing: 3px;
    text-transform: uppercase;
    margin-bottom: 22px;
}

.relacionados-video-cards {
    row-gap: 25px;
}

/* =====================================================================
   Responsive
   ===================================================================== */

@media (max-width: 991px) {
    .main-banner-fotos {
        min-height: 280px;
    }

    .is-titulo-album {
        font-size: 26px;
    }

    .main-header-video {
        min-height: 250px;
    }

    .is-titulo-video {
        font-size: 24px;
    }
}

@media (max-width: 576px) {
    .main-banner-fotos {
        min-height: 220px;
        padding-top: 35px;
    }

    .is-titulo-album {
        font-size: 20px;
        letter-spacing: 1px;
    }

    .main-header-video {
        min-height: 200px;
    }

    .is-titulo-video {
        font-size: 18px;
        letter-spacing: 1px;
    }

    .is-item-album img {
        height: 185px;
    }

    .main-contenido-video {
        padding: 22px 0 32px;
    }

    .main-relacionados-video {
        padding: 25px 0 35px;
    }

    .og-lb-prev { left: 6px; }
    .og-lb-next { right: 6px; }
}
/* =====================================================================
   Single Post (artículo de noticia — single-post.php)
   ===================================================================== */

.is-articulo-noticia {
    background-color: #fff;
    padding: 0px 32px 24px;
}

/* Categoría badge */
.is-articulo-noticia .is-categoria {
    display: inline-block;
    background-color: var(--main-azul);
    color: #fff;
    font-family: 'Teva Sans bold';
    font-size: 16px;
    letter-spacing: 1px;
    text-transform: uppercase;
    padding: 4px 14px;
    margin-bottom: 14px;
}

/* Título */
.is-titulo-noticia-single {
    font-family: 'Teva Sans bold';
    font-size: 28px;
    line-height: 1.1;
    color: #002b3f;
    text-transform: uppercase;
    letter-spacing: 1px;
    margin: 0 0 14px;
}

/* Subtítulo / extracto */
.is-subtitulo-noticia-single {
    font-family: 'Teva Sans';
    font-size: 17px;
    line-height: 1.55;
    color: #686868;
    margin: 0 0 22px;
    border-left: 3px solid var(--main-azul);
    padding-left: 14px;
}

/* Figura / imagen destacada */
.is-figura-noticia-single {
    margin: 0 0 28px;
}

.is-imagen-noticia-single {
    width: 100%;
    height: auto;
    display: block;
    object-fit: cover;
}

/* Crédito foto */
.is-credito-foto {
    font-family: 'Teva Sans';
    font-size: 12px;
    color: #999;
    text-align: right;
    padding: 5px 0 0;
    margin: 0;
}

/* Contenido wysiwyg */
.is-contenido-noticia-single {
    font-family: 'Teva Sans';
    font-size: 15px;
    line-height: 1.75;
    color: #333;
    padding-bottom: 24px;
    border-bottom: 2px solid var(--main-gris3);
}

/* Pie del artículo */
.is-pie-noticia-single {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    gap: 6px 20px;
    padding: 14px 0;
    border-bottom: 1px solid var(--main-gris3);
    margin-bottom: 16px;
}

.is-fecha-noticia-single {
    font-family: 'Teva Sans';
    font-size: 13px;
    color: #555;
    margin-right: auto;
}

.is-credito-noticia-footer {
    font-family: 'Teva Sans';
    font-size: 12px;
    color: #999;
}

/* Tags */
.is-tags-noticia {
    display: flex;
    flex-wrap: wrap;
    gap: 6px;
    width: 100%;
    padding-top: 4px;
}

.is-tag-noticia {
    display: inline-block;
    background-color: var(--main-gris3);
    color: #333;
    font-family: 'Teva Sans';
    font-size: 11px;
    padding: 3px 10px;
    text-decoration: none;
    border: 1px solid #ddd;
    transition: background-color 0.2s, color 0.2s;
}

.is-tag-noticia:hover {
    background-color: var(--main-azul);
    color: #fff;
    border-color: var(--main-azul);
    text-decoration: none;
}

/* Link externo */
.is-link-externo-noticia {
    padding: 18px 0 8px;
}

.is-boton-link-externo {
    display: inline-flex;
    align-items: center;
    gap: 8px;
    background-color: var(--main-azul);
    color: #fff;
    font-family: 'Teva Sans bold';
    font-size: 14px;
    letter-spacing: 1px;
    text-transform: uppercase;
    text-decoration: none;
    padding: 11px 22px;
    transition: background-color 0.2s ease;
}

.is-boton-link-externo:hover {
    background-color: var(--main-azul-1);
    color: #fff;
    text-decoration: none;
}

/* Responsive single post */
@media (max-width: 767px) {
    .is-articulo-noticia {
        padding: 20px 16px 18px;
    }

    .is-titulo-noticia-single {
        font-size: 22px;
    }

    .is-subtitulo-noticia-single {
        font-size: 15px;
    }
}

/* =====================================================================
   Sidebar "Más noticias" (sidebar-post.php)
   ===================================================================== */

.sidebar-noticias-panel {
    background-color: #fff;
    padding: 18px 16px 12px;
    margin-bottom: 20px;
}

.sidebar-noticias-titulo {
    font-family: 'Teva Sans bold';
    font-size: 13px;
    letter-spacing: 2px;
    text-transform: uppercase;
    color: #fff;
    background-color: var(--main-azul);
    padding: 9px 16px;
    margin: -18px -16px 16px;
}

.sidebar-noticia-destacada {
    padding-bottom: 14px;
    border-bottom: 2px solid var(--main-gris3);
    margin-bottom: 14px;
}

.sidebar-noticia-img-link {
    display: block;
    overflow: hidden;
    margin-bottom: 10px;
}

.sidebar-noticia-img {
    width: 100%;
    height: 170px;
    object-fit: cover;
    display: block;
    transition: transform 0.3s ease;
}

.sidebar-noticia-img-link:hover .sidebar-noticia-img {
    transform: scale(1.04);
    opacity: 1;
}

.sidebar-noticia-titulo-dest {
    font-family: 'Teva Sans bold';
    font-size: 14px;
    line-height: 1.4;
    margin: 0 0 8px;
}

.sidebar-noticia-titulo-dest a {
    color: #002b3f;
    text-decoration: none;
}

.sidebar-noticia-titulo-dest a:hover {
    color: var(--main-azul);
    text-decoration: none;
}

.sidebar-leer-mas {
    display: inline-block;
    background-color: var(--main-azul);
    color: #fff;
    font-family: 'Teva Sans bold';
    font-size: 11px;
    letter-spacing: 1px;
    text-transform: uppercase;
    text-decoration: none;
    padding: 5px 14px;
    transition: background-color 0.2s ease;
}

.sidebar-leer-mas:hover {
    background-color: var(--main-azul-1);
    color: #fff;
    text-decoration: none;
}

.sidebar-noticias-lista {
    list-style: none;
    padding: 0;
    margin: 0;
}

.sidebar-noticias-lista li {
    border-bottom: 1px solid var(--main-gris3);
    padding: 9px 0;
}

.sidebar-noticias-lista li:last-child {
    border-bottom: none;
}

.sidebar-noticias-lista li a {
    font-family: 'Teva Sans bold';
    font-size: 13px;
    color: #333;
    border-left: 3px solid var(--main-azul);
    padding-left: 14px;
    text-decoration: none;
    line-height: 1.4;
    display: block;
    transition: color 0.2s;
}

.sidebar-noticias-lista li a:hover {
    color: var(--main-azul);
    text-decoration: none;
}

/* =====================================================================
   Auspiciadores (sidebar-auspiciadores.php)
   ===================================================================== */

.auspiciador-separador {
    width: 60px;
    height: 1px;
    background-color: var(--main-gris3);
    margin: 4px auto;
}
/* =====================================================================
   OnlyGames — botón video demo y modal
   ===================================================================== */

/* Botón "Ver demo en video" */
.is-mas-info-video {
    text-align: center;
    margin-top: 12px;
}

.is-btn-video-onlygames {
    display: inline-flex;
    align-items: center;
    gap: 10px;
    background: none;
    border: 2px solid #0075b8;
    color: #0075b8;
    font-family: 'Teva Sans bold';
    font-size: 16px;
    line-height: 1;
    padding: 10px 22px;
    cursor: pointer;
    text-decoration: none;
    transition: background-color 0.2s ease, color 0.2s ease;
}

.is-btn-video-onlygames:hover {
    background-color: #0075b8;
    color: #fff;
}

.is-btn-video-onlygames .fa-circle-play {
    font-size: 20px;
}

/* Modal overlay */
.og-video-modal {
    position: fixed;
    inset: 0;
    z-index: 9999;
    background-color: rgba(0, 0, 0, 0.88);
    display: flex;
    align-items: center;
    justify-content: center;
    padding: 20px;
    opacity: 0;
    visibility: hidden;
    transition: opacity 0.22s ease, visibility 0.22s ease;
}

.og-video-modal.is-open {
    opacity: 1;
    visibility: visible;
}

/* Contenedor interno */
.og-video-modal-inner {
    position: relative;
    width: 100%;
    max-width: 900px;
}

/* Botón cerrar */
.og-video-modal-close {
    position: absolute;
    top: -40px;
    right: 0;
    width: 36px;
    height: 36px;
    background: none;
    border: none;
    color: #fff;
    font-size: 32px;
    line-height: 1;
    cursor: pointer;
    opacity: 0.75;
    padding: 0;
    transition: opacity 0.2s;
}

.og-video-modal-close:hover {
    opacity: 1;
}

/* Player 16:9 */
.og-video-modal-player {
    position: relative;
    width: 100%;
    padding-bottom: 56.25%;
    background-color: #000;
    border-radius: 4px;
    overflow: hidden;
}

.og-video-modal-player iframe {
    position: absolute;
    inset: 0;
    width: 100%;
    height: 100%;
    border: none;
}

@media (max-width: 576px) {
    .og-video-modal-close {
        top: -34px;
        font-size: 28px;
    }
}
/* =====================================================================
   Campeonatos — rediseño cards tipo poster
    ===================================================================== */

/* Grid */
.is-listado-campeonatos {
    row-gap: 24px;
}

/* Card poster -------------------------------------------------------- */
.is-card-campeonatos {
    position: relative;
    height: 400px;
    border-radius: 12px;
    overflow: hidden;
    background-color: #001c2a;
    display: flex;
    flex-direction: column;
    justify-content: space-between;
    text-align: left;
    box-shadow: 0 4px 18px rgba(0, 0, 0, 0.22);
    transition: box-shadow 0.25s ease, transform 0.25s ease;
}

.is-card-campeonatos:hover {
    box-shadow: 0 10px 32px rgba(0, 0, 0, 0.36);
    transform: translateY(-4px);
}

/* Imagen de fondo */
.is-card-campeonatos-bg {
    position: absolute;
    inset: 0;
    width: 100%;
    height: 100%;
    object-fit: cover;
    object-position: center;
    z-index: 1;
}

/* Overlay degradado oscuro desde abajo */
.is-card-campeonatos-overlay {
    position: absolute;
    inset: 0;
    background: linear-gradient(
        0deg,
        rgba(0, 20, 35, 0.96) 0%,
        rgba(0, 20, 35, 0.55) 45%,
        rgba(0, 20, 35, 0.10) 100%
    );
    z-index: 2;
}

/* Header: logo (izq) + año (der) ------------------------------------ */
.is-card-campeonatos-header {
    position: relative;
    z-index: 3;
    display: flex;
    align-items: flex-start;
    justify-content: space-between;
    padding: 14px 14px 0;
    gap: 8px;
}

.is-card-campeonatos-logo {
    background-color: rgba(255, 255, 255, 0.88);
    border-radius: 6px;
    padding: 5px 8px;
    display: flex;
    align-items: center;
    justify-content: center;
    max-width: 88px;
}

.is-card-campeonatos-logo img {
    display: block;
    max-width: 72px;
    max-height: 56px;
    width: auto;
    height: auto;
    object-fit: contain;
}

.is-card-campeonatos-anio {
    font-family: 'Teva Sans bold';
    font-size: 26px;
    line-height: 1;
    color: rgba(255, 255, 255, 0.9);
    letter-spacing: 1px;
    white-space: nowrap;
    text-shadow: 1px 1px 6px black;
}

/* Body: título + servicios + botón — anclado al 50% de la card */
.is-card-campeonatos-body {
    position: absolute;
    left: 0;
    right: 0;
    top: 50%;
    bottom: 0;
    z-index: 3;
    display: flex;
    flex-direction: column;
    justify-content: flex-start;
    padding: 0 16px 16px 16px;
}

.is-card-campeonatos-titulo {
    font-family: 'Teva Sans bold';
    font-size: 17px;
    line-height: 1.2;
    color: #fff;
    text-transform: uppercase;
    letter-spacing: 1px;
    margin: 0 0 10px;
}

/* Lista vertical de servicios en cards campeonatos */
.is-card-campeonatos-servicios-lista {
    list-style: disc;
    padding-left: 18px;
    margin: 0 0 10px 0;
    flex-shrink: 0;
}

.is-card-campeonatos-servicios-lista li {
    color: #fff;
    font-size: 12px;
    font-weight: 600;
    letter-spacing: 0.05em;
    text-transform: uppercase;
    line-height: 1.8;
}

/* Botón Web del evento */
.is-web-evento-campeonatos {
    display: block;
    width: 100%;
    text-align: center;
    font-family: 'Teva Sans bold';
    font-size: 12px;
    line-height: 1;
    color: #002b3f;
    background-color: #fff;
    text-transform: uppercase;
    letter-spacing: 1px;
    text-decoration: none;
    padding: 10px 14px;
    border-radius: 24px;
    margin-top: auto;
    transition: background-color 0.2s ease, color 0.2s ease;
}

.is-web-evento-campeonatos:hover {
    background-color: var(--main-azul);
    color: #fff;
    text-decoration: none;
}

/* Ocultar clases antiguas que ya no se usan en el nuevo diseño */
.is-card-campeonatos-link,
.is-imagen-card-campeonatos,
.is-fecha-campeonatos,
.is-titulo-card-campeonatos {
    display: none;
}

/* Responsive -------------------------------------------------------- */
@media (max-width: 991px) {
    .is-card-campeonatos {
        height: 370px;
    }
}

@media (max-width: 575px) {
    .is-card-campeonatos {
        height: 340px;
    }

    .is-card-campeonatos-anio {
        font-size: 22px;       
    }

    .is-card-campeonatos-titulo {
        font-size: 15px;
    }
}
/* =====================================================================
   Servicio Detalle (/servicios/{slug}/)
   ===================================================================== */

/* Banner ------------------------------------------------------------- */
.main-banner-servicio-detalle {
    position: relative;
    width: 100%;
    min-height: 380px;
    display: flex;
    align-items: flex-end;
    overflow: hidden;
    background-color: var(--main-azul-1);
}

.main-banner-servicio-detalle .is-fondo-servicio-detalle {
    position: absolute;
    inset: 0;
    width: 100%;
    height: 100%;
    object-fit: cover;
    z-index: 1;
}

.main-banner-servicio-detalle .is-overlay-servicio-detalle {
    position: absolute;
    inset: 0;
    background: linear-gradient(0deg, rgba(0, 0, 0, 0.84) 0%, rgba(0, 0, 0, 0.2) 70%);
    z-index: 2;
}

.main-banner-servicio-detalle .container {
    z-index: 3;
    padding-bottom: 44px;
}

.is-back-servicios {
    display: inline-flex;
    align-items: center;
    gap: 8px;
    color: rgba(255, 255, 255, 0.7);
    font-family: 'Teva Sans';
    font-size: 12px;
    text-decoration: none;
    text-transform: uppercase;
    letter-spacing: 1.5px;
    margin-bottom: 16px;
    transition: color 0.2s;
}

.is-back-servicios:hover {
    color: #fff;
    text-decoration: none;
}

.is-titulo-servicio-detalle {
    font-family: 'Teva Sans bold';
    font-size: 42px;
    color: #fff;
    text-transform: uppercase;
    letter-spacing: 2px;
    margin: 0;
    line-height: 1.1;
}

/* Descripción -------------------------------------------------------- */
.main-cuerpo-servicio-detalle {
    background-color: #fff;
    padding: 52px 0;
}

/*.is-descripcion-servicio-detalle {
    font-family: 'Teva Sans';
    font-size: 17px;
    line-height: 1.8;
    color: #333;
    margin: 0;
}*/

/* Campeonatos relacionados ------------------------------------------- */
.main-campeonatos-servicio-detalle {
    background-color: var(--main-gris3);
    padding: 52px 0 64px;
}

.is-titulo-campeonatos-relacionados {
    font-family: 'Teva Sans bold';
    font-size: 24px;
    color: var(--main-azul-1);
    text-transform: uppercase;
    letter-spacing: 1px;
    margin: 0;
}

.is-no-campeonatos-msg {
    font-family: 'Teva Sans';
    font-size: 15px;
    color: #888;
    margin: 0;
}

/* Responsive --------------------------------------------------------- */
@media (max-width: 768px) {
    .main-banner-servicio-detalle {
        min-height: 300px;
    }

    .is-titulo-servicio-detalle {
        font-size: 30px;
    }
}

@media (max-width: 575px) {
    .is-titulo-servicio-detalle {
        font-size: 24px;
        letter-spacing: 1px;
    }

    .main-cuerpo-servicio-detalle,
    .main-campeonatos-servicio-detalle {
        padding: 36px 0 44px;
    }
}

/* ==========================================================================
   Menú hamburguesa móvil
   ========================================================================== */

.is-menu-hamburger {
    display: none;
    flex-direction: column;
    justify-content: space-between;
    width: 32px;
    height: 22px;
    background: none;
    border: none;
    cursor: pointer;
    padding: 0;
    z-index: 1001;
    margin: 12px;
}

.is-hamburger-bar {
    display: block;
    width: 100%;
    height: 2px;
    background: #fff;
    border-radius: 2px;
    transition: transform 0.3s ease, opacity 0.3s ease;
}

/* Animación X al abrir */
.is-menu-hamburger.is-active .is-hamburger-bar:nth-child(1) {
    transform: translateY(10px) rotate(45deg);
}
.is-menu-hamburger.is-active .is-hamburger-bar:nth-child(2) {
    opacity: 0;
    transform: scaleX(0);
}
.is-menu-hamburger.is-active .is-hamburger-bar:nth-child(3) {
    transform: translateY(-10px) rotate(-45deg);
}

@media (max-width: 991px) {

    /* Mostrar hamburguesa */
    .is-menu-hamburger {
        display: flex;
    }

    /* Barra compacta cuando el nav está cerrado */
    .main-menu {
        padding: 0;
        position: relative;
    }

    .main-menu .container {
        display: flex;
        align-items: center;
        justify-content: flex-end;
        padding-top: 8px;
        padding-bottom: 8px;
    }

    /* Nav oculto por defecto — dropdown absoluto con estilos del grid original */
    #is-menu-nav {
        display: none;
        position: absolute;
        top: 100%;
        left: 0;
        right: 0;
        z-index: 1000;
        background-color: #0073ba;
        padding: 10px 0 15px;
        
    }

    #is-menu-nav.is-open {
        display: block;
    }
}

@media (min-width: 992px) {
    #is-menu-nav {
        display: flex !important;
    }
    .is-menu-hamburger {
        display: none !important;
    }
}

