
#map { width: 90%; height: 90vh; margin: 0 auto; }
.caption{ 
  width: 90%; margin: 0 auto;
  font: 14px/16px Arial, Helvetica, sans-serif; 
}

.info { 
  font-size: 20px 
  font-family: Arial, Helvetica, sans-serif; 
  background: rgba(255,255,255,0.8); 
  padding: 6px 8px; border-radius: 5px;
  box-shadow: 0 0 15px rgba(0,0,0,0.2);
} 

.nowrap { white-space:nowrap; }
h4 { text-align: left; }
.info h4  { font-size: 14px; margin: 2px 37px 5px 37px; color: #777; }
.legend   { font-size: 12px; text-align: left; line-height: 15px; color: #555; } 
.legend table { padding: 0px; border-spacing: 0px; }

.legend .cblock { padding 0px; margin: 0px;  width: 13px; opacity: 0.7; }
.legend .ltext  { padding: 0px 5px 0px 10px; }

h4.statewide {
  font-size: 13px;
  text-align: center;
  margin: 0px;
}

select.legend {
  font-weight: bold;
  margin: 0px 0px 4px 0px;
  width: 100%; 
  text-align-last: center; text-align: center;
  -webkit-align-self: center;
}

table.props { font-size: 12px; padding: 0px; border-spacing: 0px; }

table.props th, table.props td {
  text-align: left;
  padding: 1.5px 10px;
  font-size: 12px;
}

td.dval { width: 2.9em; }

table.planwide td {
  padding: 1.5px 9px;
} 

table.planwide {
  margin: 0px 0px 30px 0px;
}

table.planwide td.dval {
  width: 2em;
}

#map_sel_table h4 { 
  margin: 0;
}

table.props tr:nth-child(even) { background-color: rgba(230, 230, 230, 0.3); }

img.logo { float: left; width: 40px; margin: 2px 12px 2px 4px; }

form { white-space: nowrap; }

select {
  -webkit-appearance: none;
  -moz-appearance: none;
  appearance: none;
  padding: 3px 5px;
  border-radius: 1px;
  border: solid;
  border-width: 1px;
  border-color: black;
  background-color: rgba(240, 240, 240, 0.7);
  margin: 0px 7px 0px 0px;
}

#race_sel_span    { display: none; }
#year_sel_span    { display: none; }
#spatial_sel_span { display: none; }

#slidecontainer {
    width: 100%;
    font: 14px/16px Arial, Helvetica, sans-serif;
    padding: 6px 8px; border-radius: 5px;
    color: #777;
    font-weight:bold;
}

.slider {
    -webkit-appearance: none;
    width: 200px;
    height: 10px;
    background: #eee;
    outline: none;
    opacity: 1;
    -webkit-transition: .2s;
    transition: opacity .2s;
}

.slider:hover {
    opacity: 1;
}

.slider::-webkit-slider-thumb {
    -webkit-appearance: none;
    appearance: none;
    width: 10px;
    height: 20px;
    background: #777;
    cursor: pointer;
}

.slider::-moz-range-thumb {
    width: 10px;
    height: 20px;
    background: #777;
    cursor: pointer;
}

/* The container */
.input_container {
  display: block;
  position: relative;
  padding-left: 28px;
  margin: 2px 4px;
  cursor: pointer;
  -webkit-user-select: none;
  -moz-user-select: none;
  -ms-user-select: none;
  user-select: none;
}

table.planwide > label.input_container {
  width: 155px; 
  height: 17px;
}

/* Hide the browser's default checkbox */
.input_container input {
    position: absolute;
    opacity: 0;
}

/* Create a custom checkbox */
.checkmark {
    position: absolute;
    top: 0;
    left: 0;
    height: 18px;
    width: 18px;
    background-color: #EEE;
}

/* On mouse-over, add a grey background color */
.input_container:hover input ~ .checkmark {
    background-color: #CCC;
}

/* When the checkbox is checked, add a blue background */
.input_container input:checked ~ .checkmark {
    background-color: #AAA;
}

/* Create the checkmark/indicator (hidden when not checked) */
.checkmark:after {
    content: "";
    position: absolute;
    display: none;
}

/* Show the checkmark when checked */
.input_container input:checked ~ .checkmark:after {
    display: block;
}

/* Style the checkmark/indicator */
.input_container .checkmark:after {
    left: 5px;
    top: 1px;
    width: 5px;
    height: 10px;
    border: solid white;
    border-width: 0 3px 3px 0;
    -webkit-transform: rotate(45deg);
    -ms-transform: rotate(45deg);
    transform: rotate(45deg);
}


/* Create a custom radio button */
.radiomark {
    position: absolute;
    top: 0;
    left: 0;
    height: 18px;
    width: 18px;
    background-color: #DDD;
    border-radius: 50%;
}

/* On mouse-over, add a grey background color */
.input_container:hover input ~ .radiomark {
    background-color: #CCC;
}

/* When the radio button is checked, add a blue background */
.input_container input:checked ~ .radiomark {
    background-color: #AAA;
}

/* Create the indicator (the dot/circle - hidden when not checked) */
.radiomark:after {
    left: 9px;
    top: 9px;
    width: 5px;
    content: "";
    display: none;
}

/* Show the indicator (dot/circle) when checked */
.input_container input:checked ~ .radiomark:after {
    display: block;
}

/* Style the indicator (dot/circle) */

.input_container .radiomark:after {
  width: 8px;
  height: 8px;
  border-radius: 50%;
  background: white;
  position: absolute;
  margin-left: auto;
  margin-right: auto;
  left: 1px;
  right: 1px;
  top: 5px;
}

#chart {
  height: 100;
  width: 250;
}

.xaxis { font: 14px Arial, Helvetica, sans-serif; }

#map_legend {
  text-align: center;
  font-style: normal;
  font-size: 11px;
  margin: 35px 0 0px 0;
}

#hover_instructions {
  font-style: normal;
  font-size: 11px;
}

#descr_instructions {
  width: 30%;
  float: right;
  padding-left: 5%;
  padding-bottom: 30px;
}

ol > li {
  margin-bottom: 5px;
}


div.intro_tour h3, div.intro_tour h2 {
  text-align: center;
  font-family: Arial, Helvetica, sans-serif;
  font-size: 15px;
  color: #777;
  font-weight: bold;
  margin: 0;
}

h2#welcome_header {
  margin-bottom: 10px;
}

div.intro_tour h2 {
  font-size: 20px;
}

.img_ctr {
  width: 100%;
  min-width: 300px;
  display: inline-block;
}

#intro_logo {
  width: 60px;
  display: block;
  margin: 10px auto;
}

.intro_tour {
  font-family: Arial, Helvetica, sans-serif;
  font-size: 14px;
  color: #555;
}

.intro_wide {
  display: inline-block;
  width: 350px;
}

.introjs-tooltip {
  max-width: 800px;
}


/*
.introjs-overlay {
  display: none;
}
*/

button {
  font-family: Arial, Helvetica, sans-serif;
  font-weight: bold;
  font-size: 12px;
  background-color: #EEE;
  color: #555;
	border: solid;
	border-width: 1px;
  padding: 5px 8px;
  text-align: center;
  text-decoration: none;
  display: inline-block;
  margin: 4px 2px;
  cursor: pointer;
}

.intro_high {
  border: 3px solid rgba(0,0,0,1);
  box-sizing: border-box;
  box-shadow: 7px 10px 10px rgba(0,0,0,.4);
}

.narr_high {
  display: none;
}

.narr_tour {
  font-family: Arial, Helvetica, sans-serif;
  font-size: 18px;
  color: #222;
  min-width: 400px;
  margin: 6px -3px 0 0;
}

div.narr_tour h3, div.narr_tour h2 {
  text-align: center;
  font-size: 22px;
  color: #777;
  font-weight: bold;
  margin: 8px;
}

div.narr_tour p {
  margin: 15px;
}

div.narr_tour .introjs-button {
  margin-top: 0px;
}


.img_narr_div {
  width: 100%;
  height: 170px;
  display: inline-block;
}

.img_narr {
  height: 90%;
  display: block;
  margin: 10px auto;
}


