
div.map { padding: 4px; border: 1px solid #eaeaea; color: #fff; line-height: 1; }
div.map * { margin: 0; padding: 0; }
div.map a { color: #fff; }
div.map a * { cursor: pointer; }
div.map .clip { position: relative; z-index: 1; overflow: hidden; width: 620px; height: 675px; background: #f7f9fa url("../images/map_background.png") repeat 0 0; }

div.map p.author { position: absolute; left: 5px; bottom: 5px; z-index: 2; color: #000; font-size: 11px; }
div.map p.author a { color: #000; }

div.map p.legend { position: absolute; left: 10px; top: 7px; z-index: 2; float: left; padding: 4px 0 0; background: #f7f9fa; color: #346590; font-size: 11px; text-transform: uppercase; white-space: nowrap; }
div.map p.legend span { float: left; padding: 0 15px 4px 41px; background: transparent url("../images/map_icon.png") no-repeat 5px 0; line-height: 17px; }
div.map p.legend span.free { background-image: url("../images/map_icon_free.png"); }

div.map ul { position: absolute; left: 0; top: 0; z-index: 1; list-style: none; width: 3800px; height: 1700px; background: transparent url("../images/map.png") no-repeat 0 0; }
div.map li { position: absolute; left: 0; top: 0; z-index: 1; float: left; width: 30px; height: 21px; margin: -20px 0 0 -20px; background: transparent url("../images/map_icon.png") no-repeat 0 0; cursor: pointer; white-space: nowrap; }
div.map li.free { background-image: url("../images/map_icon_free.png"); }

div.map li a { position: relative; top: 26px; visibility: hidden; float: left; padding: 0 1ex; background: #000; color: #fff; line-height: 1.5; font-size: 10px; text-transform: uppercase; text-decoration: none; }
div.map li.hover,
div.map li:hover { z-index: 2; }
div.map li.hover a,
div.map li:hover a { visibility: visible; }

div.map .nav { position: absolute; right: 6px; top: 6px; z-index: 3; overflow: hidden; width: 289px; padding: 0; background: transparent url("../images/map_navigation_background.png") repeat 0 0; }
div.map .nav p.map { position: relative; overflow: hidden; width: 265px; height: 121px; margin: 0 auto; margin: 12px 12px 0; background: transparent url("../images/map_small.png") no-repeat 0 0; }
div.map .nav p.map span.window { position: absolute; left: 0; top: 0; z-index: 2; float: left; border: 1px solid #eed456; background: transparent url("../images/map_navigation_window_background.png") repeat 0 0; }
div.map .nav p.map span.window a { float: left; width: 100%; height: 100%; }
div.map .nav p.map span.point { position: absolute; z-index: 1; float: left; width: 5px; height: 5px; margin: -2px 0 0 -2px; background: transparent url("../images/map_points.png") no-repeat 0 100%; }
div.map .nav p.map span.free { background-position: 0 0; }
div.map .nav p.toggle { text-align: center; }
div.map .nav p.toggle a { display: inline-block; padding: 0 3ex; background: #000; color: #fff; font-size: 11px; line-height: 20px; text-decoration: none; }
div.map .nav p.toggle a .off { display: none; }
div.map .nav p.toggle a.hide .off { display: inline; }
div.map .nav p.toggle a.hide .on { display: none; }
