
/* ==========================================
    OpenLayer
========================================== */

.ol-mouse-position {
    top: 8px;
    right: 8px;
    position: absolute
}

.ol-scale-line {
    background: #95b9e6;
    background: rgba(0,60,136,.3);
    border-radius: 4px;
    bottom: 8px;
    left: 8px;
    padding: 2px;
    position: absolute
}

.ol-scale-line-inner {
    border: 1px solid #eee;
    border-top: none;
    color: #eee;
    font-size: 10px;
    text-align: center;
    margin: 1px;
    padding: 0 2px
}

.ol-unsupported {
    display: none
}

.ol-viewport .ol-unselectable {
    -webkit-touch-callout: none;
    -webkit-user-select: none;
    -khtml-user-select: none;
    -moz-user-select: none;
    -ms-user-select: none;
    user-select: none;
    -webkit-tap-highlight-color: transparent
}

.ol-control {
    position: absolute;
    background-color: #eee;
    background-color: rgba(255,255,255,.4);
    border-radius: 4px;
    /* padding: 2px */
}

    .ol-control:hover {
        background-color: rgba(255,255,255,.6)
    }

.ol-zoom {
    top: .5em;
    right: .5em;
    left: auto;
}

.ol-rotate {
    top: .5em;
    right: .5em;
    transition: opacity .25s
}

.ol-zoom-extent {
    top: 4.643em;
    left: .5em
}

.ol-full-screen {
    left: auto;
    right: .5em;
    top: 4.5em
}

@media print {
    .ol-zoom {
        display: none
    }
    .ol-attribution li{
        font-size: 1.5em;
    }
}

.ol-control button {
    display: block;
    margin: 1px;
    padding: 0;
    color: #fff;
    font-size: 1.14em;
    font-weight: 700;
    text-decoration: none;
    text-align: center;
    height: 1.375em;
    width: 1.375em;
    line-height: .4em;
    background-color: #7b98bc;
    background-color: rgba(0,60,136,.5);
    border: none;
    border-radius: 2px
}

    .ol-control button::-moz-focus-inner {
        border: none;
        padding: 0
    }

.ol-zoom-extent button {
    line-height: 1.4em
}

.ol-compass {
    display: block;
    font-family: Arial;
    font-weight: 400;
    font-size: 1.2em
}

.ol-touch .ol-control button {
    font-size: 1.5em
}

.ol-touch .ol-zoom-extent {
    top: 5.5em
}

.ol-control button:focus, .ol-control button:hover {
    text-decoration: none;
    background-color: #4c6079;
    background-color: rgba(0,60,136,.7);
    outline-color:#333333;
    
}

.ol-zoom-extent button:after {
    content: "E"
}

.ol-zoom .ol-zoom-in {
    border-radius: 2px 2px 0 0
}

.ol-zoom .ol-zoom-out {
    border-radius: 0 0 2px 2px
}
/*
button.ol-full-screen-false:after {
    content: "\2194"
}

button.ol-full-screen-true:after {
    content: "\00d7"
}
*/
.ol-has-tooltip [role=tooltip] {
    position: absolute;
    clip: rect(1px 1px 1px 1px);
    clip: rect(1px,1px,1px,1px);
    padding: 0;
    border: 0;
    height: 1px;
    width: 1px;
    overflow: hidden;
    font-weight: 400;
    font-size: 14px;
    text-shadow: 0 0 2px #fff
}

.ol-has-tooltip:focus [role=tooltip], .ol-has-tooltip:hover [role=tooltip] {
    -moz-box-sizing: content-box;
    -webkit-box-sizing: content-box;
    box-sizing: content-box;
    clip: auto;
    padding: 0 .4em;
    font-size: .8em;
    height: 1.2em;
    width: auto;
    line-height: 1.2em;
    z-index: 1100;
    max-height: 100px;
    white-space: nowrap;
    display: inline-block;
    background: #FFF;
    background: rgba(255,255,255,.6);
    color: #000;
    border: 3px solid transparent;
    border-left-width: 0;
    border-radius: 0 4px 4px 0;
    bottom: .3em;
    left: 2.2em
}

.ol-touch .ol-has-tooltip:focus [role=tooltip], .ol-touch .ol-has-tooltip:hover [role=tooltip] {
    display: none
}

.ol-zoom .ol-has-tooltip:focus [role=tooltip], .ol-zoom .ol-has-tooltip:hover [role=tooltip] {
    top: 1.1em
}

.ol-attribution .ol-has-tooltip:focus [role=tooltip], .ol-attribution .ol-has-tooltip:hover [role=tooltip], .ol-full-screen .ol-has-tooltip:focus [role=tooltip], .ol-full-screen .ol-has-tooltip:hover [role=tooltip], .ol-rotate .ol-has-tooltip:focus [role=tooltip], .ol-rotate .ol-has-tooltip:hover [role=tooltip] {
    right: 2.2em;
    left: auto;
    border-radius: 4px 0 0 4px;
    border-left-width: 3px;
    border-right-width: 0
}

.ol-attribution {
    text-align: right;
    bottom: .5em;
    right: .5em;
    max-width: calc(100% - 1.3em);
    padding: 0;
}

    .ol-attribution ul {
        margin: 0;
        padding: 0 .5em;
        font-size: .5rem;
        line-height: 1.375em;
        color: #000;
        text-shadow: 0 0 2px #fff;
        /* max-width: calc(100% - 3.6em) */
    }

    .ol-attribution li {
        display: inline;
        list-style: none;
        line-height: inherit
    }

        .ol-attribution li:first-child {
            display: none;
        }

    .ol-attribution img {
        display: none;
        max-height: 2em
    }

    .ol-attribution button, .ol-attribution ul {
        display: inline-block
    }

    .ol-attribution.ol-collapsed ul, .ol-attribution:not(.ol-collapsed) button:hover [role=tooltip] {
        display: none
    }

    .ol-attribution.ol-logo-only ul {
        display: block
    }

    .ol-attribution:not(.ol-collapsed) {
        background: rgba(255,255,255,.5)
    }

    .ol-attribution.ol-uncollapsible {
        bottom: 0;
        right: 0;
        border-radius: 4px 0 0;
        height: 1.1em;
        line-height: 1em
    }

    .ol-attribution.ol-logo-only {
        background: 0 0;
        bottom: .4em;
        height: 1.1em;
        line-height: 1em
    }

    .ol-attribution.ol-uncollapsible img {
        margin-top: -.2em;
        max-height: 1.6em
    }

    .ol-attribution.ol-logo-only button, .ol-attribution.ol-uncollapsible button {
        display: none
    }

.ol-zoomslider {
    position: absolute;
    top: 4.5em;
    left: .5em;
    background: #eee;
    background: rgba(255,255,255,.4);
    border-radius: 4px;
    outline: 0;
    overflow: hidden;
    width: 1.5675em;
    height: 200px;
    padding: 3px;
    margin: 0
}

.ol-zoomslider-thumb {
    position: absolute;
    display: block;
    background: #7b98bc;
    background: rgba(0,60,136,.5);
    border-radius: 2px;
    outline: 0;
    overflow: hidden;
    cursor: pointer;
    font-size: 1.14em;
    height: 1em;
    width: 1.375em;
    margin: 3px;
    padding: 0
}

.ol-touch .ol-zoomslider {
    top: 5.5em;
    width: 2.052em
}

.ol-touch .ol-zoomslider-thumb {
    width: 1.8em
}

.ol-attribution, .ol-control button, .ol-has-tooltip [role=tooltip], .ol-scale-line-inner {
    font-family: 'Lucida Grande',Verdana,Geneva,Lucida,Arial,Helvetica,sans-serif
}

/*====================================================================================
    InfoWindow
====================================================================================*/
.ol-popup {
    position: absolute;
    left: 0;
    background-color: white;
    -webkit-filter: drop-shadow(0 1px 4px rgba(0,0,0,0.2));
    filter: drop-shadow(0 1px 4px rgba(0,0,0,0.2));
    padding: 10px;
    border-radius: 5px;
    border: 1px solid #cccccc;
    bottom: 26px;
    min-width: 100px;
    /* white-space: nowrap; */
    text-align:center;
    transform: translateX(-50%);
}

    .ol-popup:after, .ol-popup:before {
        content: " ";
        position: absolute;
        top: 100%;
        left: 50%;
        height: 0;
        width: 0;
        transform: translateX(-50%);
        border: solid transparent;
        pointer-events: none;
    }

    .ol-popup:after {
        border-top-color: white;
        border-width: 24px 10px 10px 10px;
    }

    .ol-popup:before {
        border-top-color: #cccccc;
        border-width: 26px 12px 12px 12px;
    }

.ol-popup-closer {
    text-decoration: none;
    position: absolute;
    top: 0px;
    right: 0px;
    padding: 0px 4px;
    margin: 2px;
    border-radius: 10px;

    outline-width: 0.25rem;
    outline-style: solid;
    outline-color: transparent;
    outline-offset: 5px;
    transition: outline-offset .2s linear;
}
.ol-popup-closer:hover {
    cursor: pointer;
    background: #7b98bc;
    color: #fff;
} 
.ol-popup-closer:after {
    content: "✖";
}

.ol-popup-closer:focus{
    outline-width: 0.25rem;
    outline-color: currentColor;
    outline-offset: -1px;
}


@media (min-width: 960px) {
    .ol-popup {
        transform: translateX(-20px);
    }
    .ol-popup:after, .ol-popup:before {
        left: 20px;
    }
}