/* public map */

#publicWebcam .map-wrapper {
    position: relative;
}
#publicWebcam {
    padding: 0;
}

#publicWebcam .map {
    width: 100%;
    height: 735px;
    display: block;
    background-color: #333;
    position: relative;
    text-align: center;
}

#publicWebcam .map-wrapper .map-btn {
    text-transform: uppercase;
    color: #fff;
    background-color: #4a4d4c;
    display: inline-block;
    font-weight: bold;
    font-size: 13px;
    padding: 11px 23px 21px 18px;
    top: 50px;
    position: absolute;
    z-index: 2000;
}

#publicWebcam .map-wrapper .map-btn:hover {
    background-color: #656766;
}

.smallWebcam > img {
    max-width: 100px !important;
}

#publicWebcam .map .pinWebcam {
    position: absolute;
    left: -42px;
    bottom: 0;
}

#publicWebcam .map .pinWebcam .wrapperWebcam {
    padding: 3px;
    border-radius: 3px;
    background-color: #fff;
    box-shadow: 0 0 5px 1px rgba(34,35,35,0.97);
    position: relative;
    z-index: 2;
}

#publicWebcam .map .pinWebcam img {
    display: block;
    border-radius: 3px;
}

#publicWebcam .map .pinWebcam .wrapperWebcam:after {
    top: 100%;
    left: 50%;
    border: solid transparent;
    content: " ";
    height: 0;
    width: 0;
    position: absolute;
    pointer-events: none;
    border-color: rgba(255, 255, 255, 0);
    border-top-color: #ffffff;
    border-width: 5px;
    margin-left: -5px;
}

#publicWebcam .map .pinWebcam .large {
    display: none;
}
#publicWebcam .map .pinWebcam.active .smallWebcam {
    display: none;
}
#publicWebcam .map .pinWebcam.active .large {
    display: block;
}

#publicWebcam .map .pinWebcam.active {
    width: 300px;
    padding: 4px;
    left: -154px;
}

#publicWebcam .map .pinWebcam.active {
    width: 300px;
    padding: 4px;
}

#publicWebcam .map .pinWebcam.active .image {
    width: 100%;
    height: 194px;
    display: block;
    border-bottom-width: 4px;
    border-bottom-style: solid;
    position: relative;
}

#publicWebcam .map .pinWebcam.active .image img {
    border-radius: 3px 3px 0 0;
    width: 100%;
}

#publicWebcam .map .pinWebcam.active .image a.arrow {
    position: absolute;
    top: 90px;
    z-index: 200;
    background-color: rgba(255,255,255,0.8);
    display: block;
    width: 32px;
    height: 27px;
}

#publicWebcam .map .pinWebcam.active .image a.arrow:hover {
    background-color: rgba(255,255,255,1.0);
}


#publicWebcam .map .pinWebcam.active .text {
    padding: 20px 12px;
    text-align: left;
}

#publicWebcam .map .pinWebcam.active .text p {
    font-size: 13px;
    line-height: 18px;
    margin: 0;
}

#publicWebcam .map .pinWebcam.active .text p.artist {
    text-transform: uppercase;
    margin: 0;
}

#publicWebcam .map .pinWebcam.active .text p.artist em {
    text-transform: none;
}

#publicWebcam .map .pinWebcam.active .text p.title {
    margin: 10px 0 5px;
}

#publicWebcam .map .pinWebcam.active .text p.description {
    max-height: 120px;
    padding-bottom: 10px;
    overflow-y: scroll;
    padding-right: 15px;
}
#publicWebcam .map .pinWebcam.active .text p.description::-webkit-scrollbar {
    -webkit-appearance: none;
}
#publicWebcam .map .pinWebcam.active .text p.description::-webkit-scrollbar:vertical {
    width: 11px;
}
#publicWebcam .map .pinWebcam.active .text p.description::-webkit-scrollbar:horizontal {
    height: 11px;
}
#publicWebcam .map .pinWebcam.active .text p.description::-webkit-scrollbar-thumb {
    border-radius: 8px;
    border: 2px solid white; /* should match background, can't be transparent */
    background-color: rgba(0, 0, 0, .5);
}
#publicWebcam .map .pinWebcam.active .text p.description::-webkit-scrollbar-track {
    background-color: #fff;
    border-radius: 8px;
}

#publicWebcam .map .pinWebcam.active a.close {
    position: absolute;
    top: -13px;
    right: -13px;
    width: 26px;
    height: 26px;
    display: block;
    z-index: 999;
    text-indent: -9999px;
}

#publicWebcam .map-nav {
    width: 100%;
    display: block;
    position: relative;
}

#publicWebcam .map-nav .title {
    background-color: #282828;
    text-align: center;
    text-transform: uppercase;
    color: #b0b0b0;
    font-size: 13px;
    padding: 14px 0;

}

#publicWebcam .map-nav ul {
    list-style: none;
    padding: 0;
    margin: 0;
}

#publicWebcam .map-nav li {
    float: left;
    display: block;
    width: 33.3%;
    text-align: center;
    margin: 0;
}

#publicWebcam .map-nav li a {
    text-transform: uppercase;
    padding: 23px 0;
    display: block;
    font-weight: bold;
}

/* blobs */

#publicWebcam .map .pinWebcam span {
    border-radius: 50%;
    height: 7px;
    width: 14px;
    position: absolute;
    bottom: -9px;
    left: 35px;
}

#publicWebcam .map .pinWebcam.active span {
    left: 147px;
    bottom: -5px;
}


/* colours */

/* purple - william street */

#publicWebcam .map .pinWebcam.william span {
    background-color: #943d9c;
}

#publicWebcam .map .pinWebcam.active.william .image {
    border-color: #943d9c;
}

#publicWebcam .map .pinWebcam.active.william .text a {
    color: #943d9c;
}

#publicWebcam .map-nav li a.william {
    background-color: #d1d1d1;
    color: #707070;
}

#publicWebcam .map-nav li a.william:hover {
    background-color: #e2e2e2;
}

#publicWebcam .map-nav li a.william.active {
    background: #943d9c url(../../images/public-active-arrow.png) center top no-repeat;
    color: #fff;
}

#publicWebcam .map .pinWebcam.active.william a.close {
    background-position: -384px -320px;
}

/* public - green */

#publicWebcam .map .pinWebcam.publicWebcam span {
    background-color: #55a696;
}

#publicWebcam .map .pinWebcam.active.publicWebcam .image {
    border-color: #55a696;
}

#publicWebcam .map .pinWebcam.active.publicWebcam .text a {
    color: #55a696;
}

#publicWebcam .map-nav li a.publicWebcam {
    background-color: #d1d1d1;
    color: #707070;
}

#publicWebcam .map-nav li a.publicWebcam:hover {
    background-color: #e2e2e2;
}

#publicWebcam .map-nav li a.publicWebcam.active {
    background: #55a696 url(../../images/public-active-arrow.png) center top no-repeat;
    color: #fff;
}

#publicWebcam .map .pinWebcam.active.publicWebcam a.close {
    background-position: -320px -320px;
}

/* local - grey */

#publicWebcam .map .pinWebcam.local span {
    background-color: #6bc5e6;
}

#publicWebcam .map .pinWebcam.active.local .image {
    border-color: #6bc5e6;
}

#publicWebcam .map .pinWebcam.active.local .text a {
    color: #6bc5e6;
}

#publicWebcam .map-nav li a.local {
    background-color: #d1d1d1;
    color: #707070;
}

#publicWebcam .map-nav li a.local:hover {
    background-color: #e2e2e2;
}

#publicWebcam .map-nav li a.local.active {
    background: #6bc5e6 url(../../images/public-active-arrow.png) center top no-repeat;
    color: #fff;
}

#publicWebcam .map .pinWebcam.active.local a.close {
    background-position: -256px -320px;
}