/* required styles */
.leaflet-map-pane,.leaflet-tile,.leaflet-marker-icon,.leaflet-marker-shadow,.leaflet-tile-pane,.leaflet-tile-container,.leaflet-overlay-pane,.leaflet-shadow-pane,.leaflet-marker-pane,.leaflet-popup-pane,.leaflet-overlay-pane svg,.leaflet-zoom-box,.leaflet-image-layer,.leaflet-layer{position:absolute; left:0; top:0}
.leaflet-container{overflow:hidden; -ms-touch-action:none}
.leaflet-tile,.leaflet-marker-icon,.leaflet-marker-shadow{
-webkit-user-select:none;
   -moz-user-select:none;
        user-select:none;
-webkit-user-drag:none}
.leaflet-marker-icon,.leaflet-marker-shadow{display:block}
/* map is broken in FF if you have max-width:100% on tiles */
.leaflet-container img{max-width:none !important}
/* stupid Android 2 doesn't understand "max-width:none" properly */
.leaflet-container img.leaflet-image-layer{max-width:15000px !important}
.leaflet-tile{filter:inherit; visibility:hidden}
.leaflet-tile-loaded{visibility:inherit}
.leaflet-zoom-box{width:0; height:0}
/* workaround for https://bugzilla.mozilla.org/show_bug.cgi?id=888319 */
.leaflet-overlay-pane svg{-moz-user-select:none}
.leaflet-tile-pane{z-index:2}
.leaflet-objects-pane{z-index:3}
.leaflet-overlay-pane{z-index:4}
.leaflet-shadow-pane{z-index:5}
.leaflet-marker-pane{z-index:6}
.leaflet-popup-pane{z-index:7}
.leaflet-vml-shape{width:1px; height:1px}
.lvml{behavior:url(#default#VML); display:inline-block; position:absolute}
/* control positioning */
.leaflet-control{position:relative; z-index:7; pointer-events:auto}
.leaflet-top,.leaflet-bottom{position:absolute; z-index:1000; pointer-events:none}
.leaflet-top{top:0}
.leaflet-right{right:0}
.leaflet-bottom{bottom:0}
.leaflet-left{left:0}
.leaflet-control{float:left; clear:both}
.leaflet-right .leaflet-control{float:right}
.leaflet-top .leaflet-control{margin-top:10px}
.leaflet-bottom .leaflet-control{margin-bottom:10px}
.leaflet-left .leaflet-control{margin-left:10px}
.leaflet-right .leaflet-control{margin-right:10px}
/* zoom and fade animations */
.leaflet-fade-anim .leaflet-tile,.leaflet-fade-anim .leaflet-popup{opacity:0;
-webkit-transition:opacity 0.2s linear;
   -moz-transition:opacity 0.2s linear;
     -o-transition:opacity 0.2s linear;
        transition:opacity 0.2s linear;
}
.leaflet-fade-anim .leaflet-tile-loaded,.leaflet-fade-anim .leaflet-map-pane .leaflet-popup{opacity:1}
.leaflet-zoom-anim .leaflet-zoom-animated{
-webkit-transition:-webkit-transform 0.25s cubic-bezier(0,0,0.25,1);
   -moz-transition:   -moz-transform 0.25s cubic-bezier(0,0,0.25,1);
     -o-transition:     -o-transform 0.25s cubic-bezier(0,0,0.25,1);
        transition:        transform 0.25s cubic-bezier(0,0,0.25,1);
}
.leaflet-zoom-anim .leaflet-tile,.leaflet-pan-anim .leaflet-tile,.leaflet-touching .leaflet-zoom-animated{
-webkit-transition:none;
   -moz-transition:none;
     -o-transition:none;
        transition:none;
}
.leaflet-zoom-anim .leaflet-zoom-hide{visibility:hidden}
/* cursors */
.leaflet-clickable{cursor:pointer}
.leaflet-container{cursor:-webkit-grab; cursor:   -moz-grab}
.leaflet-popup-pane,.leaflet-control{cursor:auto}
.leaflet-dragging .leaflet-container,.leaflet-dragging .leaflet-clickable{
cursor:move;
cursor:-webkit-grabbing;
cursor:   -moz-grabbing;
}
/* visual tweaks */
.leaflet-container{background:#ddd;
outline:0;
}
.leaflet-container a{
color:#0078A8;
}
.leaflet-container a.leaflet-active{
outline:2px solid orange;
}
.leaflet-zoom-box{
border:2px dotted #38f;
background:rgba(255,255,255,0.5);
}


/* general typography */
.leaflet-container{
font:12px/1.5 "Helvetica Neue", Arial, Helvetica, sans-serif;
}


/* general toolbar styles */

.leaflet-bar{
box-shadow:0 1px 5px rgba(0,0,0,0.65);
border-radius:4px;
}
.leaflet-bar a,
.leaflet-bar a:hover{
background-color:#fff;
border-bottom:1px solid #ccc;
width:26px;
height:26px;
line-height:26px;
display:block;
text-align:center;
text-decoration:none;
color:black;
}
.leaflet-bar a,
.leaflet-control-layers-toggle{
background-position:50% 50%;
background-repeat:no-repeat;
display:block;
}
.leaflet-bar a:hover{
background-color:#f4f4f4;
}
.leaflet-bar a:first-child{
border-top-left-radius:4px;
border-top-right-radius:4px;
}
.leaflet-bar a:last-child{
border-bottom-left-radius:4px;
border-bottom-right-radius:4px;
border-bottom:none;
}
.leaflet-bar a.leaflet-disabled{
cursor:default;
background-color:#f4f4f4;
color:#bbb;
}

.leaflet-touch .leaflet-bar a{
width:30px;
height:30px;
line-height:30px;
}


/* zoom control */

.leaflet-control-zoom-in,
.leaflet-control-zoom-out{
font:bold 18px 'Lucida Console', Monaco, monospace;
text-indent:1px;
}
.leaflet-control-zoom-out{
font-size:20px;
}

.leaflet-touch .leaflet-control-zoom-in{
font-size:22px;
}
.leaflet-touch .leaflet-control-zoom-out{
font-size:24px;
}


/* layers control */

.leaflet-control-layers{
box-shadow:0 1px 5px rgba(0,0,0,0.4);
background:#fff;
border-radius:5px;
}
.leaflet-control-layers-toggle{
background-image:url(images/layers.png);
width:36px;
height:36px;
}
.leaflet-retina .leaflet-control-layers-toggle{
background-image:url(images/layers-2x.png);
background-size:26px 26px;
}
.leaflet-touch .leaflet-control-layers-toggle{
width:44px;
height:44px;
}
.leaflet-control-layers .leaflet-control-layers-list,
.leaflet-control-layers-expanded .leaflet-control-layers-toggle{
display:none;
}
.leaflet-control-layers-expanded .leaflet-control-layers-list{
display:block;
position:relative;
}
.leaflet-control-layers-expanded{
padding:6px 10px 6px 6px;
color:#333;
background:#fff;
}
.leaflet-control-layers-selector{
margin-top:2px;
position:relative;
top:1px;
}
.leaflet-control-layers label{
display:block;
}
.leaflet-control-layers-separator{
height:0;
border-top:1px solid #ddd;
margin:5px -10px 5px -6px;
}


/* attribution and scale controls */

.leaflet-container .leaflet-control-attribution{
background:#fff;
background:rgba(255, 255, 255, 0.7);
margin:0;
}
.leaflet-control-attribution,
.leaflet-control-scale-line{
padding:0 5px;
color:#333;
}
.leaflet-control-attribution a{
text-decoration:none;
}
.leaflet-control-attribution a:hover{
text-decoration:underline;
}
.leaflet-container .leaflet-control-attribution,
.leaflet-container .leaflet-control-scale{
font-size:11px;
}
.leaflet-left .leaflet-control-scale{
margin-left:5px;
}
.leaflet-bottom .leaflet-control-scale{
margin-bottom:5px;
}
.leaflet-control-scale-line{
border:2px solid #777;
border-top:none;
line-height:1.1;
padding:2px 5px 1px;
font-size:11px;
white-space:nowrap;
overflow:hidden;
-moz-box-sizing:content-box;
     box-sizing:content-box;

background:#fff;
background:rgba(255, 255, 255, 0.5);
}
.leaflet-control-scale-line:not(:first-child){
border-top:2px solid #777;
border-bottom:none;
margin-top:-2px;
}
.leaflet-control-scale-line:not(:first-child):not(:last-child){
border-bottom:2px solid #777;
}

.leaflet-touch .leaflet-control-attribution,
.leaflet-touch .leaflet-control-layers,
.leaflet-touch .leaflet-bar{
box-shadow:none;
}
.leaflet-touch .leaflet-control-layers,
.leaflet-touch .leaflet-bar{
border:2px solid rgba(0,0,0,0.2);
background-clip:padding-box;
}


/* popup */

.leaflet-popup{
position:absolute;
text-align:center;
}
.leaflet-popup-content-wrapper{
padding:1px;
text-align:left;
border-radius:12px;
}
.leaflet-popup-content{
margin:13px 19px;
line-height:1.4;
}
.leaflet-popup-content p{
margin:18px 0;
}
.leaflet-popup-tip-container{
margin:0 auto;
width:40px;
height:20px;
position:relative;
overflow:hidden;
}
.leaflet-popup-tip{
width:17px;
height:17px;
padding:1px;

margin:-10px auto 0;

-webkit-transform:rotate(45deg);
   -moz-transform:rotate(45deg);
    -ms-transform:rotate(45deg);
     -o-transform:rotate(45deg);
        transform:rotate(45deg);
}
.leaflet-popup-content-wrapper,
.leaflet-popup-tip{
background:white;

box-shadow:0 3px 14px rgba(0,0,0,0.4);
}
.leaflet-container a.leaflet-popup-close-button{
position:absolute;
top:0;
right:0;
padding:4px 4px 0 0;
text-align:center;
width:18px;
height:14px;
font:16px/14px Tahoma, Verdana, sans-serif;
color:#c3c3c3;
text-decoration:none;
font-weight:bold;
background:transparent;
}
.leaflet-container a.leaflet-popup-close-button:hover{
color:#999;
}
.leaflet-popup-scrolled{
overflow:auto;
border-bottom:1px solid #ddd;
border-top:1px solid #ddd;
}

.leaflet-oldie .leaflet-popup-content-wrapper{
zoom:1;
}
.leaflet-oldie .leaflet-popup-tip{
width:24px;
margin:0 auto;

-ms-filter:"progid:DXImageTransform.Microsoft.Matrix(M11=0.70710678, M12=0.70710678, M21=-0.70710678, M22=0.70710678)";
filter:progid:DXImageTransform.Microsoft.Matrix(M11=0.70710678, M12=0.70710678, M21=-0.70710678, M22=0.70710678);
}
.leaflet-oldie .leaflet-popup-tip-container{
margin-top:-1px;
}

.leaflet-oldie .leaflet-control-zoom,
.leaflet-oldie .leaflet-control-layers,
.leaflet-oldie .leaflet-popup-content-wrapper,
.leaflet-oldie .leaflet-popup-tip{
border:1px solid #999;
}


/* div icon */

.leaflet-div-icon{
background:#fff;
border:1px solid #666;
}

