/*
Theme Name: Mosaico
Author: Mosaico
Description: A powerful Bootstrap 5 WordPress Starter Theme with WooCommerce Support. <a href="https://bootscore.me/category/documentation/" target="_blank">Documentation</a>. This theme gives you full control whatever you do and the full freedom to design whatever you want. It comes with a wide selection of category, page, post, author and archive templates as well as sidebar, header, footer and 404 widgets. There are no customizer settings in the backend. All settings can only be made by touching the code. Some CSS, HTML, PHP and JS Skills are required to customize it.
Version: 5.3.4
Requires at least: 5.0
Tested up to: 6.4.1
Requires PHP: 7.4
License: MIT License
License URI: https://github.com/bootscore/bootscore/blob/main/LICENSE
Text Domain: bootscore
Tags: featured-images, threaded-comments, translation-ready

Use this theme to make something cool, have fun, and share what you've learned with others.

Mosaico is based on Underscores https://underscores.me/, (C) 2012-2022 Automattic, Inc.
Underscores is distributed under the terms of the GNU GPL v2 or later.
*/

/* 
All style editing is done via scss/_bscore_custom.scss
*/


:root{
    --black: #000;
    --red: #d41f32;
    --gray: #d7d1e1;
    --gray2: #f3f3f5;
    --px18: 1.125rem;
    --px20: 1.25rem;
    --px22: 1.375rem;
    --px24: 1.5rem;
    --px26: 1.625rem;
    --px28: 1.75rem;
    --px30: 1.875rem;
    --px32: 2rem;
    --px34: 2.125rem;
    --px36: 2.25rem;
    --px38: 2.375rem;
    --px40: 2.5rem;
    --px45: 2.8125rem;
    --px50: 3.125rem;
}


@font-face {
    font-family: got;
    src: url(fonts/GOTHIC.TTF);
}

@font-face {
    font-family: bla;
    src: url(fonts/blair-itc-std.otf);
}


body{
    font-family: got, sans-serif;
    color: var(--black);
    font-size: var(--px18)
}


html, body {
    height: auto;
    margin: 0;
    padding: 0;
    overflow-x: hidden;
}

a:hover{
    color: var(--red)
}

.bb{
    border-bottom: 1px solid #000
}
.bt{
    border-top: 1px solid #000
}
.bl{
    border-left: 1px solid #000
}
.br{
    border-right: 1px solid #000
}

.bla{
    font-family: bla, sans-serif
}

.bg-black{
    background-color: var(--black)
}

.bg-gray{
    background-color: var(--gray)
}
.bg-red{
    background-color: var(--red)
}

.text-black{
    color: var(--black)!important
}

.text-red{
    color: var(--red)
}



a{
    text-decoration: none;
    color: var(--red)
}

.fs-12 {
    font-size: 12px;
}
.fs-14 {
    font-size: 14px;
}
.fs-16 {
    font-size: 16px;
}

/* Estilos base para las fuentes en 1920 en rem */
.fs-18 {
    font-size: var(--px18);
}
.fs-20 {
    font-size: var(--px20);
}
.fs-22 {
    font-size: var(--px22);
}
.fs-24 {
    font-size: var(--px24);
}
.fs-26 {
    font-size: var(--px26);
}
.fs-28 {
    font-size: var(--px28);
}
.fs-30 {
    font-size: var(--px30);
}
.fs-32 {
    font-size: var(--px32);
}
.fs-34 {
    font-size: var(--px34);
}
.fs-36 {
    font-size: var(--px36);
}
.fs-38 {
    font-size: var(--px38);
}
.fs-40 {
    font-size: var(--px40);
}
.fs-45 {
    font-size: var(--px45);
}
.fs-50 {
    font-size: var(--px50);
}

/* Media queries para diferentes tamaños de pantalla */

@media (max-width: 1440px) {
    :root {
        --px18: 0.85rem;
        --px20: 1rem;
        --px22: 1.1rem;
        --px24: 1.2rem;
        --px26: 1.3rem;
        --px28: 1.4rem;
        --px30: 1.5rem;
        --px32: 1.6rem;
        --px34: 1.7rem;
        --px36: 1.8rem;
        --px38: 1.9rem;
        --px40: 2rem;
        --px45: 2.1rem;
        --px50: 2.3rem;
    }
}

/*
@media (max-width: 1199px) {
    :root {
        --px18: 0.75rem;
        --px20: 0.9rem;
        --px22: 1rem;
        --px24: 1.1rem;
        --px26: 1.2rem;
        --px28: 1.3rem;
        --px30: 1.4rem;
        --px32: 1.5rem;
        --px34: 1.6rem;
        --px36: 1.7rem;
        --px38: 1.8rem;
        --px40: 1.9rem;
        --px45: 2rem;
        --px50: 2.1rem;
    }
}


@media (max-width: 991px) {
    :root {
        --px18: 0.65rem;
        --px20: 0.8rem;
        --px22: 0.9rem;
        --px24: 1rem;
        --px26: 1.1rem;
        --px28: 1.2rem;
        --px30: 1.3rem;
        --px32: 1.4rem;
        --px34: 1.5rem;
        --px36: 1.6rem;
        --px38: 1.7rem;
        --px40: 1.8rem;
        --px45: 1.9rem;
        --px50: 2rem;
    }
}
*/
.line1{
    line-height: 1
}
.line2{
    line-height: 1.2
}
.line3{
    line-height: 1.3
}
.line4{
    line-height: 1.4
}
.line5{
    line-height: 1.5
}


.bold{
    font-weight: 700
}

h6, .h6, h5, .h5, h4, .h4, h3, .h3, h2, .h2, h1, .h1{
    font-family: bla, sans-serif;
    text-transform: uppercase
}



.full-img{
    height: 100%;
}

.full-img img{
    height: 100%!important;
    width: 100%;
    object-fit: cover
}


.navbar-expand-lg .offcanvas .offcanvas-body{
    flex-wrap: wrap;
    flex-direction: column;
}

.cont-top{
    order: -1;
    display: flex;
    align-items: center;
    gap: 5px
}

.sep{
    height: 25px;
    width: 1px;
    background-color: #000
}

.wp-block-social-links{
    margin-bottom: 0
}

#bootscore-navbar{
    --bs-navbar-nav-link-padding-x: 1rem
}

#bootscore-navbar li a{
    color: var(--black);
    font-family: bla, sans-serif;
    text-transform: uppercase;
    line-height: 1;
    transition: all .15s linear;
}

li.current-menu-parent a,
li.current-menu-item a,
#footer-menu li a:hover,
#bootscore-navbar li a:hover{
    color: var(--red)!important
}


.to-fixed #bootscore-navbar li a{
    font-size: 0.9rem
}

#footer-menu{
    justify-content: end
}

#footer-menu li a{
    color: var(--black);
    font-size: 14px
}

ul#bootscore-navbar li.current_page_item a{
    color: var(--red)
}

.title{
    font-size: var(--px18);
    font-family: bla, sans-serif;
    text-transform: uppercase
}

#content{
    margin-top: 134px;
    transition: all .15s linear
}

.custom-logo-link img{
    width: 300px;
    transition: all .15s linear;
}

.to-fixed .custom-logo-link img{
    width: 200px
} 

.bg-footer{
    background-color: #231f20;
    color: #fff
}

.cont-list-footer{
    padding-bottom: 1.5rem;
    border-bottom: 1px solid #fff;
    display: table;
    margin: auto
}

.list-footer{
    display: flex;
    justify-content: center;
    row-gap: 8px
}

.list-footer li{
    padding-left: var(--bs-nav-link-padding-x);
    padding-right: var(--bs-nav-link-padding-x);
    border-left: 1px solid #fff;
    border-right: 1px solid #fff;
    margin-left: -1px;
    line-height: 1
}

.list-footer li:first-child{
    border-left: 0;
    padding-left: 0;
}
.list-footer li:last-child{
    border-right: 0;
    padding-right: 0
}

.cont-play p{
    margin-bottom: 0
}

.cont-play .btn{
    border: 0;
    padding: 0;
    font-family: bla,sans-serif;
    line-height: 1
}

.cont-play .btn:hover{
    background-color: transparent;
    color: rgba(255,255,255,.8)
}

.cont-play{
    position: absolute!important;
    bottom: 1.5rem;
    right: 4rem;
    color: #fff;
    font-family: bla,sans-serif;
    font-size: 22px;
    align-items: center
}

.mejs-overlay-button {
    background: url(img/mejs-controls.svg) no-repeat;
    background-position: 0 -39px;
    height: 80px;
    width: 80px;
}


.carousel-indicators {
    right: 1rem;
    bottom: 1rem;
    left: auto;
    justify-content: end;
    margin-right: 0;
    margin-bottom: 1rem;
    margin-left: 0;
    flex-direction: column;
}

.carousel-indicators [data-bs-target]{
    width: 14px;
    height: 14px;
    border-radius: 14px;
    border: 0;
    background-color: #fff;
    margin-top: 10px;
    opacity: 1
}

.carousel-indicators .active{
    background-color: var(--red)
}


.caption-banner{
    position: absolute!important;
    bottom: 20%;
    width: 100%;
    padding: 0 1.5rem;
    left: 50%;
    transform: translateX(-50%);
}

.cont-trailer >div:last-child{
    margin-bottom: 1rem!important;
}

.btn{
    --bs-btn-padding-x: 0.75rem;
    --bs-btn-padding-y: 0.375rem;
    --bs-btn-font-family: bla,sans-serif;
    --bs-btn-border-radius: 0;

}
.btn-shadow{
    box-shadow: 2px 2px 4px 0px rgba(0,0,0,.4);
    border: 0;
    color: #555
}

.cont-title > *{
    display: table;
    padding-right: 3rem;
    background-color: #fff
}

.cont-title{
    position: relative
}

.cont-title.left > *{
    padding-right: 0;
    padding-left: 3rem;
    margin-left: auto
}


.cont-title:after{
    position: absolute;
    content: "";
    width: 100%;
    height: 1px;
    top: 50%;
    left: 0;
    z-index: -1;
    background-color: #000
}

.img-box{
    padding-bottom: 1.5rem;
}

.img-box:after{
    position: absolute;
    content: "";
    width: 100%;
    height: calc(100% - 1.5rem);
    bottom: 0;
    background-color: var(--gray);
    left: 1.5rem;
    z-index: -1
}

.img-box-left:after{
    left: -1.5rem
}

.line100{
    line-height: 2
}




input[type=checkbox], input[type=radio] {
    position: relative;
    border: 2px solid #000;
    border-radius: 2px;
    background: none;
    cursor: pointer;
    line-height: 0;
    margin: 0 .6em 0 0;
    outline: 0;
    padding: 0 !important;
    vertical-align: text-top;
    height: 20px;
    width: 20px;
    -webkit-appearance: none;
    opacity: .5;
    border-radius: 10px
}

input[type=radio]{
    border-radius: 0;
    border: 1px solid #000;
    height: 16px;
    width: 16px;
}

input[type=checkbox]:hover, input[type=radio] {
    opacity: 1;
}

input[type=checkbox]:checked, input[type=radio]:checked {
    background-color: #fff;
    opacity: 1;
}


input[type=checkbox]:checked:before, input[type=radio]:checked:before {
    content: '';
}

input[type=checkbox]:before, input[type=radio]:before  {
    position: absolute;
    right: 50%;
    top: 50%;
    width: 5px;
    height: 10px;
    border: solid #000;
    border-width: 0 2px 2px 0;
    margin: -1px -1px 0 -1px;
    transform: rotate(45deg) translate(-50%, -50%);
    z-index: 2;
}

.text-privacy{
    font-size: 11px
}


input::placeholder,
textarea::placeholder{
    font-family: bla, sans-serif;
    color: var(--black);
    font-weight: 400;
    font-size: 1rem
}

textarea, input:not([type="file"], [type="image" ], [type="submit"], [type="checkbox"], [type="radio"]) {
    border: 0;
    border-bottom: 1px solid var(--black);
    width: 100%;
    background-color: transparent;
}

textarea{
    height: 140px;
    padding: 10px;
    border: 1px solid var(--black);
}

.form-item p{
    display: flex;
    align-items: end
}

.form-item p > span:first-child{
    width: 100px;
    line-height: 1
}

.wpcf7-submit{
    border: 1px solid var(--gold2);
    background-color: var(--gold2);
    color: var(--black);
    position: relative;
    padding: 5px 4rem;
    max-width: 100%;
    min-width: auto;
}

.wpcf7-submit:hover{
    background-color: var(--black);
    color: #fff
}

.wpcf7-form p > label{
    display: block
}

.wpcf7-form-control-wrap{
    flex: 1
}

.wpcf7-list-item-label{
    font-size: 13px
}

.wpcf7-list-item{
    margin-left: 0
}

.box-contacto{
    padding-bottom: 1.5rem
}

.cont-btn p,
.row-contact p{
    margin-bottom: 0;
    position: relative;
    text-align: right
}

.box-contacto:after{
    position: absolute;
    content: "";
    width: 100%;
    height: calc(100% + 1.5rem);
    left: -1.5rem;
    top: -1.5rem;
    background-color: var(--gray);
    z-index: -1
}

.row-contact > div{
    position: relative
}

.wpcf7-not-valid-tip{
    font-size: 14px
}

.wpcf7-spinner{
    position: absolute;
    right: 1rem;
    top: 50%;
    transform: translateY(-50%);
    margin: 0
}

.cont-img-contact{
    height: 100%;
    border-right: 1px solid #000
}

.cont-img-contact:after,
.cont-img-contact:before{
    position: absolute;
    content: "";
    width: 7rem;
    height: 60%;
    left: -8.5rem;
    top: 50%;
    transform: translateY(-50%);
    background-color: #e1c97d;
}


.cont-img-contact:before{
    width: 3.5rem;
    height: 35%;
    background-color: var(--gold2);
    left: -11.5rem
}

.img-contact{
    padding-left: 2rem;
    padding-top: 2rem;
    padding-bottom: 2rem;
}

.img-contact:after{
    position: absolute;
    content: "";
    width: calc(100% - 2rem);
    height: 100%;
    top: 0;
    left: 0;
    background-color: var(--gold2);
    z-index: -1
}


.cont-contact{
    padding: 3rem 2rem;
    background-color: #fcfaf4;
    height: 100%
}


.img1, .img2{
    width: calc(100% - 6rem);
    height: calc(100% - 3.5rem);
    margin-left: auto;
    margin-bottom: 0
}

.img2{
    position: absolute!important;
    left: 0;
    bottom: 0;
    z-index: -1
}

.img2 img, .img1 img{
    width: 100%;
    height: 100%!important;
    object-fit: cover;
}

#nav-main{
    border-bottom: 1px solid #000
}



.box-action{
    display: flex;
    align-items: end;
    position: absolute;
    right: 0;
    height: 100%;
    width: auto;
    background-color: rgba(0,0,0,.5);
    top: 0;
    transition: all .15s linear;
}

.box-action i{
    font-size: 50px;
    color: #fff
}

.box-action button{
    border: 0;
    padding: 1rem;
    background-color: transparent
}

.box-description{
    position: absolute;
    display: flex;
    flex-direction: column;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    background-color: #000;
    color: #fff;
    transition: all .15s linear;
    transform: translateY(100%);
    padding: 1.5rem;
    z-index: 1001
}

.box-description button{
    border: 0;
    padding: 0;
    background-color: transparent;
    width: 35px;
    height: 35px;
}



.box-description button svg{
    width: 24px;
    height: 24px;
    transform: rotate(45deg)
}


.box-description a{
    height: 100%;
    display: flex;
    flex-direction: column;
    flex: 1;
    justify-content: space-between;
    color: #fff;
    font-size: 20px;
}

.box-content.active .box-description{
    transform: none;
}

.box-content.active .box-action{
    opacity: 0;
}


.owl-box-action{
    position: relative;
    z-index: 1001
}


.box-action-button{
   color: var(--black);
   font-family: bla, sans-serif;
   font-size: 13px;
   line-height: 1
}


#carouselExampleIndicators {
    padding-left: 30px;
    padding-right: 30px;
}

.carousel-control-prev, .carousel-control-next{
    width: auto;
    opacity: 1
}

.carousel-control-prev-icon, .carousel-control-next-icon {
    width: 2.5rem;
    height: 2.5rem;
}

.carousel-control-prev{
    left: -10px;
}

.carousel-control-next{
    right: -10px
}

.carousel-control-prev-icon {
  background-image: url("data:image/svg+xml,%3csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 16 16' fill='%23000'%3e%3cpath d='M11.354 1.646a.5.5 0 0 1 0 .708L5.707 8l5.647 5.646a.5.5 0 0 1-.708.708l-6-6a.5.5 0 0 1 0-.708l6-6a.5.5 0 0 1 .708 0z'/%3e%3c/svg%3e");
}

.carousel-control-next-icon {
  background-image: url("data:image/svg+xml,%3csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 16 16' fill='%23000'%3e%3cpath d='M4.646 1.646a.5.5 0 0 1 .708 0l6 6a.5.5 0 0 1 0 .708l-6 6a.5.5 0 0 1-.708-.708L10.293 8 4.646 2.354a.5.5 0 0 1 0-.708z'/%3e%3c/svg%3e");
}

.owl-carousel .owl-nav .owl-next, .owl-carousel .owl-nav .owl-prev {
    position: absolute;
    bottom: 4rem;
    left: -2.25rem;
    width: 25px
}

.owl-carousel .owl-nav .owl-next{
    left: auto;
    right: -2.25rem;
    transform: rotate(180deg)
}

.owl-nav  svg{
    width: 100%;
    height: auto
}

.owl-next.disabled,
.owl-prev.disabled{
    opacity: .5
}

.owl-center .owl-stage{
    display: flex;
    justify-content: center;
    align-items: center;
}

.owl-center img{
    max-height: 50px;
    width: auto!important;
    margin: auto
}

.box-content .box-img img{
    aspect-ratio: 210/300;
    object-fit: cover;
    object-position: top;
    height: 100%;
    width: 100%;
    border: 1px solid #000
}

.owl-box-action .btn, .btn-shadow {
    border: 0;
    box-shadow: 1px 2px 4px 0px rgba(0,0,0,.3);
}


.idioma{
    font-size: 12px;
    line-height: 1
}

.idioma a{
    margin-left: 5px
}

.entry-footer{
    margin-top: 1rem;
    text-align: center;
    padding-bottom: 3rem
}

.bliss_loadmore{
    position: relative;
    background-color: transparent!important;
    font-family: bla,sans-serif;
    color: var(--black)!important;
    font-weight: 400;
    font-size: 14px;
    height: auto;
    line-height: 1.4;
    width: 100px;
    padding: 0
}

.bliss_loadmore:hover{
    opacity: .82
}


.bliss_loadmore:after{
 content: "";
  position: absolute;
  top: 100%; /* Ajusta según el tamaño del triángulo */
  left: 0;
  width: 0;
  height: 0;
  border-left: 50px solid transparent;
  border-right: 50px solid transparent;
  border-top: 45px solid #222; /* Cambia el color según tus necesidades */
}

.top-button{
    background-color: var(--red);
    border-color: var(--red);
}


.left-logo{
    position: absolute;
    top: 0;
    left: 0;
    transform: translateX(-100%);
    
}

.left-logo img{
    width: 300px;
    background-color: #000
}

.films .left-logo{
    top: 1.5rem
}

.left-logo.to-top {
    position: relative;
    transform: none;
    /* display: table; */
    margin-bottom: 1rem;
    width: 200px;
}

.films .left-logo.to-top{
    top: 0
}


#carouselExampleIndicators .carousel-item img{
    width: 100%;
    height: 100%;
    object-fit: contain
}

#carouselExampleIndicators .carousel-item{
    background-color: #000
}


.carousel-home .areoi-strip figure img{
    max-height: calc(100vh - 135px)
}


.admin-bar .carousel-home .areoi-strip figure img{
    max-height: calc(100vh - 135px - 32px)
}




@media (min-width: 1400px){
    .container-xxl, .container-xl, .container-lg, .container-md, .container-sm, .container {
        max-width: 1390px;
    }
}

@media (max-width: 991px){
    #footer-menu{
        --bs-nav-link-padding-y: 0.25rem;
        justify-content: center
    }
    
    .header-actions .btn{
    font-size: 24px;
    line-height: 1;
    font-family: got, sans-serif;

    }
    
    .offcanvas-header{
        background-color: var(--red);
        color: #fff;
    }
    
    .offcanvas-header .btn-close{
        filter: invert(1);
        opacity: 1
    }
    
    .offcanvas-body{
        display: flex
    }
    
    .cont-top{
        order: 6;
        margin-top: auto;
        justify-content: center;
        align-items: center
    }
        .row-lg > div{
        flex: 0 0 auto;
        width: 100%;
    }
    
        .order-lg{
        order: -1
    }
    
}
@media (max-width: 767px){
    .row-md > div{
        flex: 0 0 auto;
        width: 100%;
    }
    .order-md{
        order: -1
    }
    .img-footer img{
        width: 250px
    }
    
    .carousel-home .areoi-strip{
        height: calc(100vh - 135px);
        min-height: 450px
    }
}

@media (max-width:575px ){
    .box-action-button{
        font-size: 12px
    }
    
    .box-description button{
        width: 25px;
        height: 25px
    }
    
    .box-description{
        padding: 0.75rem
    }
}

@media (max-width: 411px){
    .custom-logo-link img{
        width: 250px
    }
}

@media (max-width: 1199px) and (min-width: 992px){
    .list-footer{
        font-size: 0.8rem
    }
}