body {
    font-family: 'Montserrat', sans-serif;
}

.bgWhite {
    background-color: #fff;
}

.fontGP {
    font-family: 'Montserrat', sans-serif;
    font-weight: 900;
    font-size: xx-large;
}

.fontMenu {
    font-family: 'Montserrat', sans-serif;
    font-weight: 900;
    font-size: x-large;
    color: #fff;
}

.fontMenuOpen {
    font-family: 'Montserrat', sans-serif;
    font-weight: 900;
    font-size: x-large;
    color: #fff;
}

.fontMenuStatic {
    font-family: 'Montserrat', sans-serif;
    font-size: x-large;
    color: #fff;
}

.prfSubMenu {
    font-family: 'Montserrat', sans-serif;
    font-size: large;
    color: #3ca459;
}

.ligSubMenu {
    font-family: 'Montserrat', sans-serif;
    font-size: large;
    color: #ffb800;

}

.ligaNegrita {
    font-weight: 900 !important;
}

.ligaNegrita p {
    font-weight: 900 !important;
}

.namePart {
    font-weight: 900 !important;
}

.posPart {
    font-weight: 900 !important;
}

.tornSubMenu {
    font-family: 'Montserrat', sans-serif;
    font-size: large;
    color: #e44a3e;
}

.compSubMenu {
    font-family: 'Montserrat', sans-serif;
    font-size: large;
    color: #0089f0;
}

.logoImg {
    max-height: 35px;
}

.logoTxt {
    max-height: 24px;
}

.betaTxt {
    max-height: 22px;
    margin-left: 10px;
}

p {
    margin: 0px;
}

.header-bg {
    background-image: linear-gradient(180deg, #eee, #fff 100px, #fff);
    background-repeat: no-repeat;
}

.container {
    max-width: 960px;
}

.pricing-header {
    max-width: 700px;
}

.bd-placeholder-img {
    font-size: 1.125rem;
    text-anchor: middle;
    -webkit-user-select: none;
    -moz-user-select: none;
    user-select: none;
}

@media (min-width: 768px) {
    .bd-placeholder-img-lg {
        font-size: 3.5rem;
    }
}

.drop-shadow {
    filter: drop-shadow(7px 7px 3px #666666);
    -webkit-filter: drop-shadow(7px 7px 3px #666666);
}

.square {
    width: 80%;
    /* background: linear-gradient(to bottom right, transparent calc(50% - 5px), black calc(50% - 5px), black 50%, transparent 50%), linear-gradient(to bottom left, transparent calc(50% - 5px), black calc(50% - 5px), black 50%, transparent 50%); */
}

.square:after {
    content: '';
    display: block;
    padding-bottom: 10%;
}

.squareBg {
    background-image: url('../images/cross.png');
    background-repeat: no-repeat;
    background-size: contain;
    background-position: center
}

.crossContent {
    position: absolute;
    width: 100%;
    height: 100%;
}

.imgCross {
    max-width: 30%;
    height: auto;
    cursor: pointer;
}

.bannerCross {
    height: 80px;
    color: #fff;
    font-size: 35px;
}

.ligaBg {
    background-color: #ffb800;
}
.soloBg {
    background-color: #3ca459;
}
.jamboreeBg {
    background-color: #080600 !important;
    color: white !important;
}

.ligaColor {
    color: #ffb800 !important;
}

.compBg {
    background-color: #0089f0;
}

.compColor {
    color: #0089f0 !important;
}

.compBorder {
    border-color: #0089f0 !important;
}

.tornBg {
    background-color: #ff473a;
}

.tornColor {
    color: #ff473a !important;
}

.perfBg {
    background-color: #00a650;
}

.perfColor {
    color: #00a650;
}

.selMenu {
    transform: skew(-30deg);
    position: relative;
    left: 20px;
    cursor: pointer;
}

.selMenuStatic {
    transform: skew(-30deg);
    position: relative;
    left: 20px;
}

.selMenu p {
    transform: skew(30deg);
}

.selMenuStatic p {
    transform: skew(30deg);
}

.objSkew {
    transform: skew(-28deg);
}

.objSkew p {
    transform: skew(28deg);
}

.objSkew img {
    transform: skew(28deg);
}

.objSkew span {
    transform: skew(28deg);
}

.objSkew button {
    transform: skew(28deg);
}

/* .inbox-badge {
    margin-left: -5px;
    margin-top: -5px;
} */

.listImg {
    margin-left: -3.5rem;
    margin-top: -1rem;
}

.selOption {
    cursor: pointer;
}

.margin-5 {
    margin-top: -4px;
    margin-bottom: -4px;
}

.input {
    width: 100%;
    padding: 10px;
    background: transparent;
    border: none;
    outline: none;
}

.line-box {
    position: relative;
    width: 100%;
    height: 2px;
    background: #BCBCBC;
}

.line {
    position: absolute;
    width: 0%;
    height: 2px;
    top: 0px;
    left: 50%;
    transform: translateX(-50%);
    background: #3ca459;
    transition: ease .6s;
}

.input:focus+.line-box .line {
    width: 100%;
}

#login-dp {
    min-width: 300px;
    padding: 14px 14px 0;
    overflow: hidden;
    background-color: rgba(255, 255, 255, .8);
}

.col-20 {
    width: 20%;
}

.text-justify {
    text-align: justify;
}

.maskGP {
    mask-image: url('../images/mascara_perfil.svg');
    mask-repeat: no-repeat;
    mask-size: 100%;
    mask-position: center;
    -webkit-mask-image: url('../images/mascara_perfil.svg');
    -webkit-mask-repeat: no-repeat;
    -webkit-mask-size: 100%;
    -webkit-mask-position: center;
    display: block;
    width: 100%;
    height: 120px;
}

.i_maskGP {
    position: relative;
    z-index: 100;
}

.accordion-button:focus {
    z-index: 3;
    border-color: #ff473a;
    outline: 0;
    box-shadow: 0 0 0 .25rem rgba(13, 110, 253, .25);
}

.accordion-button:not(.collapsed) {
    color: #ffffff;
    background-color: #ff473a;
    box-shadow: inset 0 -1px 0 rgba(0, 0, 0, .125);
}

.torBadge {
    margin-top: -6px;
    margin-left: -6px;
}

/* Fondo GEO */
.geoBg {
    background-color: #585eb1;
}


.leaflet-popup.popupLiga .leaflet-popup-content-wrapper {
    background-color: #ffb800;
    color: white;
    transform: skew(-20deg);
    border-radius: 12px;
    padding: 10px 14px;
    font-size: 14px;
    box-shadow: 0 0 12px rgba(0, 0, 0, 0.4);
    max-width: 240px;
    line-height: 1.5em;
}


.leaflet-popup.popupTorneo .leaflet-popup-content-wrapper {
    background-color: #ff473a;
    color: white;
    transform: skew(-20deg);
    border-radius: 12px;
    padding: 10px 14px;
    font-size: 14px;
    box-shadow: 0 0 12px rgba(0, 0, 0, 0.4);
    max-width: 240px;
    line-height: 1.5em;
}

.leaflet-popup.popupComp .leaflet-popup-content-wrapper {
    background-color: #0089f0;
    color: white;
    transform: skew(-20deg);
    border-radius: 12px;
    padding: 10px 14px;
    font-size: 14px;
    box-shadow: 0 0 12px rgba(0, 0, 0, 0.4);
    max-width: 240px;
    line-height: 1.5em;
}


.leaflet-popup.popupJam .leaflet-popup-content-wrapper {
    background-color: #000000;
    color: white;
    transform: skew(-20deg);
    border-radius: 12px;
    padding: 10px 14px;
    font-size: 14px;
    box-shadow: 0 0 12px rgba(0, 0, 0, 0.4);
    max-width: 240px;
    line-height: 1.5em;
}


/* Corregir la inclinación interna del texto */
.popupLiga .leaflet-popup-content,
.popupTorneo .leaflet-popup-content,
.popupComp .leaflet-popup-content {
    transform: skew(20deg);
    margin: 0;
    padding: 0 10px 0 30px;
}

/* Título del popup */
.popup-title {
    font-weight: 900 !important;
    font-family: 'Montserrat', sans-serif;
    font-size: 20px;
    color: white;
    margin-bottom: 4px;
    font-style: italic;
}

/* Texto debajo del título */
.popupGeoContent {
    font-family: 'Montserrat', sans-serif;
    font-size: 16px;
    display: block;
    margin-bottom: 5px;
    color: white;
    font-weight: bold;
    font-style: italic;
}

.popupLiga .popup-title a,
.popupTorneo .popup-title a,
.popupComp .popup-title a {
    color: inherit !important;
    text-decoration: none;
}

.popupLiga .popup-title a:hover,
.popupTorneo .popup-title a:hover,
.popupComp .popup-title a:hover {
    text-decoration: underline;
}

.leaflet-control-attribution .leaflet-attribution-flag {
    display: none !important;
}


/* EXPERIMENTAL */



/* inbox */


/* Tarjeta de notificación */
.notification-item {
    --border-color: #dee2e6;
    /* puedes sobreescribirla inline */
    background: #fff !important;
    border: 3px solid var(--border-color);
    border-radius: .75rem;
    padding: 20px;
    min-height: 120px;
    transition: transform .3s ease, box-shadow .3s ease, background-color .3s ease;
}

.notification-item:hover {
    transform: translateY(-4px);
    box-shadow: 0 12px 30px rgba(0, 0, 0, .1);
    background-color: #fff;
}

/* Columna de acciones (para poner spinners/restaurar botones desde JS) */
.notification-item .actions {
    display: flex;
    flex-direction: column;
    gap: .5rem;
}

/* Imagen/ilustración del tipo */
.notif-icon {
    width: 80px;
    height: 80px;
    object-fit: contain;
}

/* Título liga (hook para JS) */
.league-title {
    margin-bottom: .5rem;
}

/* Botones */
.accept-btn {
    background: #28a745;
    border: none;
    color: #fff;
    transition: transform .2s ease, filter .2s ease;
}

.accept-btn:hover {
    filter: brightness(.95);
    transform: translateY(-2px);
}

.reject-btn {
    border: 2px solid #dc3545;
    color: #dc3545;
    background: #fff;
    transition: transform .2s ease, background-color .2s ease, color .2s ease;
}

.reject-btn:hover {
    background: #dc3545;
    color: #fff;
    transform: translateY(-2px);
}

/* Estado vacío (una sola definición) */
.empty-state {
    padding: 60px 20px;
    background: #f8f9fa;
    border-radius: 15px;
    border: 2px dashed #dee2e6;
}

/* CAMPANA HEADER */
#inboxLink {
    line-height: 0;
    display: inline-block;
}

#lblCountInbox {
    transform: translate(-40%, -20%) !important;
}

.nudge-icon {
    width: 45;
    /* ajusta a tu gusto */
    height: 45px;
    display: block;
    pointer-events: none;
    /* evita que el click lo capture la imagen en lugar del botón */
}

/* Base para el icono */
.nudge-icon-noti {
    width: 100px;
    height: 100px;
    background-color: #000;
    /* este se sobreescribe con cada tipo */

    /* usamos la silueta como máscara */
    -webkit-mask: url("../images/ring1.png") no-repeat center;
    -webkit-mask-size: contain;
    mask: url("../images/ring1.png") no-repeat center;
    mask-size: contain;
}

/* Ligas */
.nudge-lig {
    background-color: #ffb800;
    /* amarillo */
}

/* Competiciones */
.nudge-com {
    background-color: #0089f0;
    /* azul */
}

/* Torneos */
.nudge-tor {
    background-color: #ff473a;
    /* rojo */
}


/* perfil */


.perfilBg {
    background-color: #fc006d;
}





.perfilName {

    font-variation-settings: 'wght' 800, 'wdth' 100;
    font-size: 50px;
    font-style: italic;
}

/* EXPERIMENTAL */

/* ===== Perfil ===== */

/* Colores de cada barra */
.bar-liga {
    background: #ffb800;
    color: #ffb800;
}

.bar-comp {
    background: #0089f0;
    color: #0089f0;
}

.bar-torn {
    background: #ff473a;
    color: #ff473a;
}

.bar-jam {
    background: #000000;
    color: #000000;
}

.bar-perf {
    background: #ff7e00;
    color: #ff7e00;
}

/* Fila rectangular por defecto (sin skew) */
.barRow {
    display: flex;
    align-items: center;
    padding: .75rem 1rem;
    font-weight: 900;
    border-radius: 10px;
    box-shadow: 0 2px 6px rgba(0, 0, 0, .06);
    transform: none;
    transition: transform .18s ease, box-shadow .18s ease;
    cursor: pointer;
    margin-bottom: .6rem;
}

.barRow:hover {
    box-shadow: 0 6px 14px rgba(0, 0, 0, .12);
}

.barRow.disabled {
    cursor: default;
}

.barLabel {
    flex: 1;
    padding-right: 16px;
    font-family: 'Montserrat', sans-serif;
    font-weight: 900;
    font-size: x-large;
    color: #fff;
}

.barValue {
    margin-left: auto;
    padding-left: 16px;
    font-family: 'Montserrat', sans-serif;
    font-weight: 900;
    font-size: x-large;
    color: #fff;
}

/* Efecto inclinación solo al hacer click */
.barRow.skewed {
    transform: skewX(-20deg) translateX(14px);
    box-shadow: 0 10px 24px rgba(0, 0, 0, .16);
}

.barRow.skewed .barLabel,
.barRow.skewed .barValue {
    transform: skewX(20deg);
}

/* Panel que se inserta debajo de la barra */
.stat-details-panel {
    margin-left: 0.25rem;
}


/* Tarjeta detalle bajo cada barra */
.statCard {
    border: 3px solid transparent;
    /* el color lo fijamos inline desde JS */
    border-radius: 12px;
    background: #fff;
    overflow: hidden;
    font-weight: 800 !important;
}


/* evita que se vea nada por fuera */
.listImg img {
    max-height: 80px;
    object-fit: contain;
}

/* Evita que el logo del sitio “asome” si no hay imagen */
.stat-details-panel .listImg {
    margin-left: -3.5rem;
    margin-top: -1rem;
}





/* Header avatar */


/* Avatar en header */
.avatarHeader {
    width: 50px;
    height: 50px;
    border-radius: 50%;
    object-fit: cover;
    display: block;
    box-shadow: 0 0 0 2px #fff;
}

/* Ajustes mínimos de la flecha */
.caret-toggle::after {
    vertical-align: middle;
}



/* Botón contenedor circular */
.friend-chip {
    width: 40px;
    height: 40px;
    padding: 0;
    /* sin padding para que la imagen ocupe todo */
    border: 0;
    background: transparent;
    /* o #fff si quieres fondo blanco */
    border-radius: 50%;
    display: inline-flex;
    align-items: center;
    justify-content: center;

    /* SOLUCIÓN al “descolgado” */
    vertical-align: middle;
    /* alinea con botones de al lado */
    line-height: 0;
    /* quita espacio extra del inline */

    margin-left: .5rem;
    /* separación del botón anterior (opcional) */
    cursor: pointer;
}

/* La imagen entra entera en el círculo */
.friend-chip__img {
    width: 100%;
    height: 100%;
    object-fit: contain;
    /* se ve completa */
    display: block;
}

/* Hover sutil (opcional) */
.friend-chip:hover .friend-chip__img {
    transform: scale(1.04);
    transition: transform .12s ease;
}