/* Estilos mapa interactivo */

.map-popup {
    position: absolute;
    left: 50%;
    top: 470px;
    z-index: 99;
    width: 90%;
    padding: 45px 30px 30px 30px;
    background-color: #fff;
    transition: all 300ms ease-in;
    transform: translate(-50%, -50%);
    box-shadow: 0 0 24px rgba(0, 0, 0, 0.22);
    opacity: 0;
    visibility: hidden;
}

@media screen and (min-width: 768px) {
    .map-popup {
        width: 60%;
        padding: 30px 30px 30px 100px;
        top: 50%;
    }
}

.map-popup.item-01,
.map-popup.item-02,
.map-popup.item-03,
.map-popup.item-04 {
    background-image: url("../img/popup-quirofano-02.png");
    background-repeat: no-repeat;
    background-size: 60px;
    background-position: 20px 20px;
}

.map-popup.item-02 {
    background-image: url("../img/popup-quirofano-02.png");

}

.map-popup.item-02 {
    background-image: url("../img/popup-nuevos-materiales.png");
}

.map-popup.item-03 {
   background-image: url("../img/popup-quirofano-03.png");
}

.map-popup.item-04 {
     background-image: url("../img/popup-quirofano-01.png");
}

.map-popup>*:first-child {
    margin-top: 0;
}

.map-popup>*:last-child {
    margin-bottom: 0;
}

.map-popup.open {
    opacity: 1;
    visibility: visible;
}



@keyframes changesizeopacity {
    0% {
        @include transform-scale(1);
        opacity: .8;
        filter: alpha(opacity=80);
    }

    80% {
        @include transform-scale(1.5);
    }

    100% {
        opacity: 0;
        filter: alpha(opacity=0);
    }
}

.marker {
    position: absolute;
    z-index: 1;
    display: none;
    width: 85px;
    height: 85px;
    color: #fff;
    line-height: 36px;
    text-align: center;
    text-decoration: none;
    border-radius: 50%;
    background-color: transparent;
    background-repeat: no-repeat;
}

@keyframes changesizeopacity {
    0% {
        @include transform-scale(1);
        opacity: .8;
        filter: alpha(opacity=80);
    }
    50% {
        opacity: 0;
        filter: alpha(opacity=0);
        @include transform-scale(1.5);
    }

    100% {
        @include transform-scale(1);
        opacity: .8;
        filter: alpha(opacity=80);
    }
}

.marker::after {
    content: "";
    position: absolute;
    top: -8px;
    right: -7px;
    z-index: 0;
    width: 100px;
    height: 100px;
    border: 12px rgba(255, 255, 255, 0.8) solid;
    animation-duration: 2.5s;
    animation-name: changesizeopacity;
    animation-iteration-count: infinite;
    border-radius: 500px;
}

@media screen and (min-width: 768px) {
    .marker {
        display: inline-block;
    }
}

@media screen and (min-width: 768px) {
    .map-popup {
        width: 60%;
        padding: 30px 30px 30px 100px;
        top: 50%;
    }
}

.marker:hover {
    cursor: pointer;

}
.marker:hover:after {
    border: 0 rgba(255, 255, 255, 0.8) solid;
}

.marker1:hover,
.marker2:hover,
.marker3:hover,
.marker4:hover {
    /*border: 7px solid #175955;*/
    border: 7px solid #fff;
    margin-left: -7px;
    margin-top: -7px;
    height: 100px;
    width: 100px;
    animation: none;
    background-size: 90px;
    /*background-position: 0 -82px;*/
}

@media only screen and (min-width:768px) {
    .map-item .marker {
        top: auto;
        left: auto;
        background-color: #fff;
        background-position: center center;
    }
    .map-item1 .marker {
        top: 330px;
        left: 90px;
        background-image: url("../img/icon-quirofano-02.png");
    }
    .map-item2 .marker {
        top: -126px;
        left: 317px;
        background-image: url("../img/icon-nuevos-materiales.png");
    }
    .map-item3 .marker {
        top: -35px;
        left: 530px;
        background-image: url("../img/icon-quirofano-03.png");
    }

    .map-item4 .marker {
        top: 420px;
        left: 600px;
        background-image: url("../img/icon-quirofano-01.png")
    }

    .map-popup {
        position: absolute;
        left: 79px;
        width: 620px;
        transform: translateY(-50%);
        top: 160px;
    }

    .map-popup.edge {
        left: auto;
        right: calc(100% + 24px);
    }
    .map-popup.edge:before {
        left: auto;
        right: -16px;
        border-width: 16px 0 16px 16px;
        border-color: transparent transparent transparent #fff;
    }
}

.map-item1 .marker:before {
    content: url("../img/map-selector-01.png");
    position: absolute;
    top: -48px;
    left: 40px;
}

.map-item4 .marker:before {
    content: url("../img/map-selector-01.png");
    position: absolute;
    top: -48px;
    left: 40px;
}

.map-item2 .marker:before {
    content: url("../img/map-selector-02.png");
    position: absolute;
    top: 85px;
    left: 40px;
}

.map-item3 .marker:before {
    content: url("../img/map-selector-02.png");
    position: absolute;
    top: 85px;
    left: 40px;
}

/* demo */

.container-map {
    background: url("../images/scene.jpg") no-repeat scroll center top transparent;
    color: #000000;
    height: 535px;
    margin: 20px auto;
    overflow: hidden;
    position: relative;
    width: 1030px;
}

.dialog {
    background-color: rgba(163, 154, 77, 0.9);
    color: #FFFFFF;
    display: none;
    height: 140px;
    left: 343px;
    line-height: 24px;
    padding: 100px 30px;
    position: absolute;
    text-align: center;
    top: 97px;
    width: 280px;
    z-index: 10;
    -moz-border-radius: 170px;
    -ms-border-radius: 170px;
    -o-border-radius: 170px;
    -webkit-border-radius: 170px;
    border-radius: 170px;
}

.dialog .close {
    background-color: #65683b;
    cursor: pointer;
    font-size: 22px;
    font-weight: bold;
    height: 36px;
    line-height: 36px;
    position: absolute;
    right: 10px;
    top: 60px;
    width: 36px;
    -moz-border-radius: 18px;
    -ms-border-radius: 18px;
    -o-border-radius: 18px;
    -webkit-border-radius: 18px;
    border-radius: 18px;
}

.labels p {
    display: none;
}

.labels a {
    background-color: rgba(203, 189, 58, 0.8);
    color: #FFFFFF;
    display: none;
    height: 50px;
    padding: 30px 0 0;
    position: absolute !important;
    text-align: center;
    text-decoration: none;
    width: 80px;
    -moz-border-radius: 40px;
    -ms-border-radius: 40px;
    -o-border-radius: 40px;
    -webkit-border-radius: 40px;
    border-radius: 40px;
}

.labels>a {
    background-color: rgba(203, 189, 58, 0.8);
    -moz-transition: .3s;
    -ms-transition: .3s;
    -o-transition: .3s;
    -webkit-transition: .3s;
    transition: .3s;
}

.labels a:hover {
    background-color: rgba(128, 128, 128, 0.8);
}

.labels a span {
    border-left: 10px solid transparent;
    border-right: 10px solid transparent;
    border-top: 15px solid rgba(203, 189, 58, 0.8);
    bottom: -14px;
    height: 0;
    left: 30px;
    position: absolute;
    width: 0;
    -moz-transition: .3s;
    -ms-transition: .3s;
    -o-transition: .3s;
    -webkit-transition: .3s;
    transition: .3s;
}

.labels a:hover span {
    border-top: 15px solid rgba(128, 128, 128, 0.8);
}

.close-icon {
    text-decoration: none!important;
    color: #323232;
    position: absolute;
    right: 30px;
    top: 20px;
}