.elementor-bc-flex-widget .elementor-11127 .elementor-element.elementor-element-47e0fe9.elementor-column .elementor-widget-wrap{align-items:center;}.elementor-11127 .elementor-element.elementor-element-47e0fe9.elementor-column.elementor-element[data-element_type="column"] > .elementor-widget-wrap.elementor-element-populated{align-content:center;align-items:center;}.elementor-11127 .elementor-element.elementor-element-082eb33 .tec-events-elementor-event-widget__title{text-align:center;}.elementor-11127 .elementor-element.elementor-element-f8a8281 .tec-events-elementor-event-widget__datetime{color:#FFFFFF;}.elementor-11127 .elementor-element.elementor-element-f8a8281 .tec-events-elementor-event-widget__datetime-wrapper{justify-content:center;}.elementor-11127 .elementor-element.elementor-element-8d89fa6{width:var( --container-widget-width, 100% );max-width:100%;--container-widget-width:100%;--container-widget-flex-grow:0;}.elementor-widget-heading .elementor-heading-title{font-family:var( --e-global-typography-primary-font-family ), Sans-serif;font-weight:var( --e-global-typography-primary-font-weight );color:var( --e-global-color-primary );}.elementor-11127 .elementor-element.elementor-element-7b3d6b6{text-align:center;}.elementor-11127 .elementor-element.elementor-element-7b3d6b6 .elementor-heading-title{color:#FFFFFF;}.elementor-11127 .elementor-element.elementor-element-46596eb > .elementor-widget-container{padding:10px 10px 10px 10px;border-radius:40px 40px 40px 40px;}.elementor-11127 .elementor-element.elementor-element-46596eb{--alignment:center;--grid-side-margin:10px;--grid-column-gap:10px;--grid-row-gap:10px;--grid-bottom-margin:10px;}.elementor-widget-text-editor{font-family:var( --e-global-typography-text-font-family ), Sans-serif;font-weight:var( --e-global-typography-text-font-weight );color:var( --e-global-color-text );}.elementor-widget-text-editor.elementor-drop-cap-view-stacked .elementor-drop-cap{background-color:var( --e-global-color-primary );}.elementor-widget-text-editor.elementor-drop-cap-view-framed .elementor-drop-cap, .elementor-widget-text-editor.elementor-drop-cap-view-default .elementor-drop-cap{color:var( --e-global-color-primary );border-color:var( --e-global-color-primary );}.elementor-11127 .elementor-element.elementor-element-630cd5a .tec-events-elementor-event-widget__venue-name, .elementor-11127 .elementor-element.elementor-element-630cd5a .tec-events-elementor-event-widget__venue-name a{color:#FFFFFF;}.elementor-11127 .elementor-element.elementor-element-630cd5a .tec-events-elementor-event-widget__venue-name{text-align:left;}.elementor-11127 .elementor-element.elementor-element-630cd5a .tec-events-elementor-event-widget__venue-address-header{color:#FFFFFF;text-align:center;}.elementor-11127 .elementor-element.elementor-element-630cd5a .tec-events-elementor-event-widget__venue-address{color:#FFFFFF;}.elementor-11127 .elementor-element.elementor-element-630cd5a .tec-events-elementor-event-widget__venue-address-map-link .tribe-events-gmap{color:#FFFFFF;}.elementor-11127 .elementor-element.elementor-element-630cd5a .tec-events-elementor-event-widget__venue-phone-header{color:#FFFFFF;text-align:center;}.elementor-11127 .elementor-element.elementor-element-630cd5a .tec-events-elementor-event-widget__venue-website-header{color:#FFFFFF;text-align:center;}.elementor-11127 .elementor-element.elementor-element-630cd5a .tec-events-elementor-event-widget__venue-map{max-width:90%;width:90%;height:calc( 100% - var(--tec-spacer-2));}@media(max-width:1024px){ .elementor-11127 .elementor-element.elementor-element-46596eb{--grid-side-margin:10px;--grid-column-gap:10px;--grid-row-gap:10px;--grid-bottom-margin:10px;}.elementor-11127 .elementor-element.elementor-element-630cd5a .tec-events-elementor-event-widget__venue-map{max-width:100%;width:100%;}}@media(max-width:767px){ .elementor-11127 .elementor-element.elementor-element-46596eb{--grid-side-margin:10px;--grid-column-gap:10px;--grid-row-gap:10px;--grid-bottom-margin:10px;}.elementor-11127 .elementor-element.elementor-element-630cd5a .tec-events-elementor-event-widget__venue-map{max-width:100%;width:100%;}}/* Start custom CSS for column, class: .elementor-element-47e0fe9 */#tribe-events-pg-template {
    background-color: #212529;
    margin-top: 10px;
    margin-bottom: 10px;
}

div.tribe-events-notices {
    display: none;
}

div.tribe-events-schedule h2 {
    color: white !important;
}

.tribe-events-cost {
    color: white !important;
}

p.tribe-events-back a {
    color: white !important;
}

p.tribe-events-back a:hover {
    color: #7ad2c4 !important;
}

li.tribe-events-nav-previous a {
    color: white !important;
}

li.tribe-events-nav-previous a:hover {
    color: #e3771c !important;
}

li.tribe-events-nav-next a {
    color: white !important;
}

li.tribe-events-nav-next a:hover {
    color: #e3771c !important;
}

h2.tribe-events-single-section-title {
    color: white !important;
}

.tribe-events-meta-group-details{
    color: white;
}

.tribe-events-meta-group {
    color: white;
}

.tribe-event-date-start {
    color: white;
}

.tribe-events-cal-links {
    display: none;
}

img.attachment-full {
    display: none;
}/* End custom CSS */
/* Start custom CSS for html, class: .elementor-element-3978d30 *//* --- CONFIGURACIÓN AJUSTE EXACTO (SIN HOVER) --- */
.tm-exact-viewport {
    width: 100%;
    display: flex;
    justify-content: center;
    padding: 30px 20px;
    box-sizing: border-box;
    /* Cero interacción */
    pointer-events: none; 
}

.tm-exact-card {
    /* Clave: El contenedor se ajusta al contenido (inline-block) */
    display: inline-block; 
    position: relative;
    max-width: 900px;
    width: 100%;
    height: auto;
    
    /* BORDES REDONDEADOS: Clave para eliminar las puntas */
    border-radius: 40px; 
    overflow: hidden; /* Corta cualquier punta que sobresalga */
    
    /* Sombra técnica y violeta Trackmove FIJA */
    box-shadow: 0 15px 40px rgba(108, 52, 131, 0.3);
}

.tm-exact-background {
    position: absolute;
    inset: 0;
    /* Fondo negro mate muy suave para dar profundidad */
    background: #1c1c1e; 
    border-radius: 40px;
    z-index: 1; /* Detrás de la imagen */
}

.tm-exact-img {
    width: 100%;
    height: auto;
    /* Muestra la imagen COMPLETA, sin zoom */
    object-fit: contain; 
    
    /* BORDES REDONDEADOS EN LA IMAGEN (SIN PUNTAS) */
    border-radius: 40px; 
    
    /* Posicionamiento para que no se corte por el overflow */
    display: block; 
    position: relative;
    z-index: 2; /* Por encima del fondo */
    
    /* Sombra suave que integra la imagen */
    filter: drop-shadow(0 5px 15px rgba(0,0,0,0.4));
    
    /* Asegura que no se mueva nada */
    transition: none !important;
    transform: none !important;
}

/* RESPONSIVE MÓVIL */
@media (max-width: 850px) {
    .tm-exact-card, .tm-exact-background, .tm-exact-img {
        border-radius: 25px;
    }
}

@media (max-width: 480px) {
    .tm-exact-card, .tm-exact-background, .tm-exact-img {
        border-radius: 15px;
    }
}/* End custom CSS */
/* Start custom CSS for html, class: .elementor-element-08f9376 *//* --- ESTILOS DE TEXTO iPHONE --- */
.ios-text-container {
    max-width: 1100px;
    margin: 40px auto;
    padding: 0 20px;
    color: #ffffff;
    line-height: 1.6;
}

/* Título estilo "Ajustes" */
.ios-main-title {
    font-size: 32px;
    font-weight: 800;
    letter-spacing: -0.5px;
    margin-bottom: 10px;
    text-transform: none; /* iOS prefiere minúsculas con peso fuerte */
}

/* Párrafo descriptivo suave */
.ios-description {
    font-size: 17px;
    color: #a1a1a6; /* Gris típico de subtítulos iOS */
    margin-bottom: 40px;
    max-width: 800px;
}

/* Etiqueta de sección */
.ios-section-label {
    font-size: 13px;
    text-transform: uppercase;
    color: #8e8e93;
    letter-spacing: 0.5px;
    margin-left: 15px;
    margin-bottom: 8px;
    font-weight: 600;
}

/* Grupo de lista estilo iOS (Bordes redondeados y fondo oscuro) */
.ios-list-group {
    background: rgba(28, 28, 30, 0.7); /* Fondo de tarjetas iOS Dark */
    border-radius: 20px;
    overflow: hidden;
    backdrop-filter: blur(10px);
    -webkit-backdrop-filter: blur(10px);
    border: 1px solid rgba(255, 255, 255, 0.05);
}

/* Ítem de la lista */
.ios-list-item {
    padding: 18px 20px;
    border-bottom: 1px solid rgba(255, 255, 255, 0.1);
    transition: background 0.3s ease;
}

.ios-list-item:last-child {
    border-bottom: none;
}

.ios-list-item:hover {
    background: rgba(255, 255, 255, 0.05);
}

.ios-item-content strong {
    color: #ffffff;
    font-weight: 700;
    display: block; /* Título de la modalidad en su propia línea */
    margin-bottom: 4px;
    font-size: 15px;
}

.ios-item-content span {
    color: #d1d1d6;
    font-size: 14px;
}

/* RESPONSIVE */
@media (max-width: 600px) {
    .ios-main-title { font-size: 24px; }
    .ios-description { font-size: 15px; }
    .ios-list-group { border-radius: 15px; }
}/* End custom CSS */
/* Start custom CSS for html, class: .elementor-element-afde3ac *//* --- ESTRUCTURA GRID --- */
.tm-subtle-grid {
    display: flex;
    flex-wrap: wrap; 
    gap: 20px;
    justify-content: center;
    width: 100%;
    max-width: 1100px;
    margin: 30px auto;
    padding: 0 15px;
    box-sizing: border-box;
    font-family: 'Montserrat', sans-serif;
}

.tm-subtle-box {
    flex: 1 1 calc(33.333% - 20px); 
    min-width: 280px; 
    max-width: 350px;
    position: relative;
}

.rt-logic { display: none; }

/* --- TARJETA --- */
.tm-subtle-card {
    display: block;
    background: #1c1c1e;
    border-radius: 30px;
    padding: 30px 15px;
    height: 100%;
    cursor: pointer;
    box-sizing: border-box;
    border: 1px solid rgba(255, 255, 255, 0.05);
    box-shadow: 0 15px 35px rgba(0, 0, 0, 0.3);
    transition: all 0.4s ease;
}

.tm-subtle-card:hover {
    background: #252529;
    box-shadow: 0 20px 45px rgba(108, 52, 131, 0.2);
}

.tm-card-content {
    display: flex;
    flex-direction: column;
    align-items: center;
    text-align: center;
    transition: transform 0.4s ease;
}

.tm-subtle-card:hover .tm-card-content {
    transform: translateY(-5px);
}

.tm-img-frame {
    width: 100%;
    height: 130px;
    display: flex;
    align-items: center;
    justify-content: center;
    margin-bottom: 20px;
}

.tm-img-frame img {
    max-width: 80%;
    max-height: 100%;
    object-fit: contain;
}

.tm-text-frame h3 {
    color: #ffffff !important;
    font-size: 1.2rem;
    font-weight: 800;
    margin: 0 0 5px;
}

.tm-text-frame p {
    color: #8e8e93;
    font-size: 0.85rem;
    margin: 0 0 20px;
}

/* BOTÓN DE LA TARJETA */
.tm-tag-btn {
    display: inline-block;
    padding: 10px 25px;
    background: #6c3483;
    color: #ffffff;
    border-radius: 12px;
    font-size: 0.8rem;
    font-weight: bold;
    letter-spacing: 1px;
}

/* --- MODAL --- */
.rt-modal {
    position: fixed;
    top: 0; left: 0;
    width: 100vw; height: 100vh;
    background: rgba(0, 0, 0, 0.9);
    backdrop-filter: blur(10px);
    -webkit-backdrop-filter: blur(10px);
    display: flex;
    align-items: center;
    justify-content: center;
    z-index: 9999;
    opacity: 0;
    pointer-events: none;
    transition: opacity 0.3s ease;
}

.rt-logic:checked ~ .rt-modal {
    opacity: 1;
    pointer-events: auto;
}

.rt-modal-overlay {
    position: absolute;
    width: 100%; height: 100%;
}

.rt-modal-content {
    position: relative;
    background: #1c1c1e;
    border-radius: 35px;
    padding: 40px;
    width: 90%;
    max-width: 450px;
    text-align: center;
    border: 1px solid rgba(255,255,255,0.1);
    box-shadow: 0 30px 60px rgba(0,0,0,0.5);
}

.rt-modal-close {
    position: absolute;
    top: 15px; right: 20px;
    color: #8e8e93;
    font-size: 28px;
    cursor: pointer;
}

.rt-modal-img {
    height: 100px;
    margin-bottom: 20px;
}

.rt-modal-text h3 { color: #fff; margin-bottom: 10px; }
.rt-modal-text p { color: #8e8e93; font-size: 0.95rem; line-height: 1.5; }

/* BOTÓN DE SEGUIMIENTO DENTRO DEL MODAL */
.tm-live-btn {
    display: inline-block;
    margin-top: 25px;
    padding: 18px 35px;
    background: #6c3483;
    color: #ffffff;
    text-decoration: none;
    border-radius: 15px;
    font-weight: 800;
    font-size: 0.95rem;
    box-shadow: 0 10px 20px rgba(108, 52, 131, 0.3);
    transition: all 0.3s ease;
    width: 100%;
    box-sizing: border-box;
}

.tm-live-btn:hover {
    background: #8e44ad;
    transform: scale(1.02);
}

/* RESPONSIVE */
@media (max-width: 1024px) {
    .tm-subtle-box { flex: 1 1 calc(50% - 20px); }
}
@media (max-width: 680px) {
    .tm-subtle-box { flex: 1 1 100%; }
}/* End custom CSS */
/* Start custom CSS for html, class: .elementor-element-8d89fa6 *//* --- ESTILO iPHONE INTEGRADO --- */
.ios-full-card-viewport {
    width: 100%;
    display: flex;
    justify-content: center;
    padding: 0px 0;
}

.ios-combined-card {
    width: 95%;
    max-width: 1100px;
    background: rgba(28, 28, 30, 0.6);
    backdrop-filter: blur(25px) saturate(180%);
    -webkit-backdrop-filter: blur(25px) saturate(180%);
    border-radius: 40px;
    border: 1px solid rgba(255, 255, 255, 0.08);
    display: flex; /* Alineación horizontal */
    overflow: hidden;
    position: relative;
    box-shadow: 0 20px 50px rgba(0,0,0,0.4);
}

/* Lado de la Imagen */
.ios-card-visual {
    flex: 1;
    background: rgba(0,0,0,0.2);
    display: flex;
    align-items: center;
    justify-content: center;
    padding: 40px;
    position: relative;
}

.ios-integrated-tracker {
    width: 100%;
    max-width: 280px;
    height: auto;
    object-fit: contain;
    filter: drop-shadow(0 15px 30px rgba(0,0,0,0.6));
    z-index: 2;
}

.ios-visual-glow {
    position: absolute;
    width: 60%;
    height: 60%;
    background: radial-gradient(circle, rgba(108, 52, 131, 0.2) 0%, transparent 70%);
    z-index: 1;
}

/* Lado de los Textos */
.ios-card-info {
    flex: 1.2;
    padding: 50px;
    display: flex;
    flex-direction: column;
    justify-content: center;
}

.ios-tech-title {
    color: #ffffff;
    font-size: 13px;
    text-transform: uppercase;
    letter-spacing: 2px;
    margin-bottom: 25px;
    opacity: 0.6;
}

.ios-spec-item {
    margin-bottom: 20px;
    border-left: 2px solid rgba(108, 52, 131, 0.5);
    padding-left: 15px;
}

.ios-spec-item strong {
    display: block;
    color: #ffffff;
    font-size: 18px;
    margin-bottom: 5px;
}

.ios-spec-item p {
    color: #a1a1a6;
    font-size: 15px;
    margin: 0;
    line-height: 1.4;
}

@keyframes scan {
    0% { left: -100%; }
    30% { left: 100%; }
    100% { left: 100%; }
}

/* RESPONSIVE: De horizontal a vertical en móvil */
@media (max-width: 850px) {
    .ios-combined-card { flex-direction: column; }
    .ios-card-info { padding: 30px; }
    .ios-card-visual { padding: 30px; border-bottom: 1px solid rgba(255,255,255,0.1); }
    .ios-integrated-tracker { max-width: 180px; }
}/* End custom CSS */
/* Start custom CSS for text-editor, class: .elementor-element-b2c6409 */.boton-redondo-violeta {
    font-family: 'Montserrat', sans-serif !important; /* Tu fuente guardada */
    display: inline-block; /* No ocupa todo el ancho */
    padding: 14px 30px; /* Tamaño del botón */
    background: #6C3483; /* Violeta Oscuro Pro */
    color: #ffffff; /* Texto blanco */
    border-radius: 50px; /* Bordes totalmente redondos */
    text-decoration: none !important; /* Quitar subrayado */
    font-weight: 700; /* Negrita profesional */
    text-transform: uppercase; /* Mayúsculas */
    font-size: 14px;
    letter-spacing: 1px;
    border: none;
    transition: background 0.3s;
}/* End custom CSS */