svg:not(:root) { overflow: hidden; }

#geo {
  background: GhostWhite;
  border: 2px solid grey;
  width: 100%;
  height: 100%;
  box-sizing: border-box;
}

.overlay {
	position: absolute;
	top: 0px;
	left: 0px;
	width: 100%;
	height: 100%;
	fill: none;
	pointer-events: all;
	box-sizing: border-box;
}


#caption {
	border: 1px solid Gainsboro;
    box-shadow: 1px 2px 4px rgba(0, 0, 0, .5);
	background: white;
	position: absolute;
	bottom: 10px;
	right: 10px;
	width: 320px;
	//height: 520px;
	max-width: 40%;
	max-height: 90%;
    overflow: auto;
}

#caption_content {
	padding: 5px;
	position: relative;
	color: #808080;
	font-size: 12px;
	height: 100%;
	overflow: auto;
}

.captionRectItem {
	margin-bottom: -5px;
}

.captionTitle1 {
	font-size: 14px;
	font-weight: bold;
	text-decoration: underline;
	margin-bottom: 8px;
}

.captionTitle2 {
	font-size: 12px;
	font-weight: bold;
	text-decoration: underline;
	margin-bottom: 8px;
}

.captionSeparator {
	height: 12px;
}

.captionSupplementaryNote {
	font-size: 10px;
	font-style: italic;
	line-height: 0.9;
	margin-top: 12px;
	margin-left: 8px;
}

#canvas_footer {
	position: absolute;
	bottom: 5px;
}

#caption_copyright {
	margin-left: 8px;
	margin-right: 10px;
	font-size: 10px;
	color: #808080;
	float: left;
	white-space: nowrap;
}

#caption_copyright > a {
	color: #808080;
	position: relative;
	bottom: 1px;
}

#caption_copyright > a:visited {
	color: #808080;
}

#caption_copyright_data {
	margin-left: 8px;
	font-size: 10px;
	color: #808080;
	float: left;
	white-space: nowrap;
}

.tooltip {	
    position: absolute;			
	z-index: 1;
    text-align: center;			
    width: auto;		
	max-width: 250px;
    height: auto;					
    padding: 7px;				
    font: 12px sans-serif;		
    background: white;	
    border: 1px solid black;
    box-shadow: 3px 3px 3px #808080;
    pointer-events: none;			
}

.PAYS {
	fill: none;
    stroke: #cdcccc;
	stroke-linecap: round;
	stroke-dasharray: 2,2;
}

.PAYS_toponyme {
	text-anchor: middle;
	pointer-events: none;
	font-family: "Century Gothic", Arial;
	font-style: italic;
	fill: #a8a7a7;
}

.DEPT {
	fill: white;
    stroke: #cdcccc;
}

.DEPT_toponyme {
	text-anchor: middle;
	pointer-events: none;
	font-family: "Century Gothic", Arial;
	fill: #a8a7a7;
}
.CTT_toponyme {
	text-anchor: middle;
	pointer-events: none;
	font-family: "Century Gothic", Arial;
	fill: purple;    
    text-shadow:
		-1px -1px 0 white,
		1px -1px 0 white,
		-1px 1px 0 white,
		1px 1px 0 white;
}

.VILLE_toponyme {
	text-anchor: middle;
	pointer-events: none;
	font-family: "Century Gothic", Arial;
	fill: #a8a7a7;
    text-shadow:
		-1px -1px 0 white,
		1px -1px 0 white,
		-1px 1px 0 white,
		1px 1px 0 white;
}

#haut_rhin {
	fill: none;
    stroke: #33a9b1;
}

.EPCI {
	fill: #ffffff;
    stroke: #787878;
}

.EPCI_toponyme {
	text-anchor: middle;
	pointer-events: none;
	font-family: "Century Gothic", Arial;
	fill: black;
	font-weight: bold;
}

.COMMUNE {
	fill: #f6fbfe;
    stroke: #c7c6c6;
}

.CTT {
	fill: none;
    stroke: purple;
}

.prop_indicator {
	opacity: 0.8;
	stroke: white;
}

.hover_element {
  fill: #c9d7e8 !important;
}

.param0 {
	float: left;
	width: 200px;
}

.paramSelector0 {
	width: 190px;
	height: 25px;
	margin-bottom: 10px;
}


.paramTitle {
	color: #808080;
	font-size: 12px;
	margin-bottom: 2px;
}

.paramSep {
	border-right: 2px solid #808080;
	float: left;
	position: relative;
	top: 23px;
	height: 45px;
	margin-left: 6px;
	margin-right: 15px;
}

.param {
	float: left;
	width: 300px;
}

.paramSelector {
	width: 290px;
	height: 25px;
	margin-bottom: 10px;
}
