/*	Less Framework 4
	http://lessframework.com
	by Joni Korpi
	License: http://opensource.org/licenses/mit-license.php	*/
/*	Resets
	------	*/
/* apply a natural box layout model to all elements */
/* from http://paulirish.com/2012/box-sizing-border-box-ftw/ */
* {
  -moz-box-sizing: border-box;
  -webkit-box-sizing: border-box;
  box-sizing: border-box;
}
/* maxvoltar.com/archive/-webkit-font-smoothing */
html {
  -webkit-font-smoothing: antialiased;
}
pre {
  padding: 15px;
  white-space: pre;
  /* CSS2 */

  white-space: pre-wrap;
  /* CSS 2.1 */

  white-space: pre-line;
  /* CSS 3 (and 2.1 as well, actually) */

  word-wrap: break-word;
  /* IE */

}
/* hand cursor on clickable input elements */
label,
input[type=button],
input[type=submit],
button {
  cursor: pointer;
}
html,
body,
div,
span,
object,
iframe,
h1,
h2,
h3,
h4,
h5,
h6,
p,
blockquote,
pre,
a,
abbr,
address,
cite,
code,
del,
dfn,
em,
img,
ins,
kbd,
q,
samp,
small,
strong,
sub,
sup,
var,
b,
i,
hr,
dl,
dt,
dd,
ol,
ul,
li,
fieldset,
form,
label,
legend,
table,
caption,
tbody,
tfoot,
thead,
tr,
th,
td,
article,
aside,
canvas,
details,
figure,
figcaption,
hgroup,
menu,
footer,
header,
nav,
section,
summary,
time,
mark,
audio,
video {
  margin: 0;
  padding: 0;
  border: 0;
}
article,
aside,
canvas,
figure,
figure img,
figcaption,
hgroup,
footer,
header,
nav,
section,
audio,
video {
  display: block;
}
a img {
  border: 0;
}
/*	Typography presets
	------------------	*/
.gigantic {
  font-size: 116px;
  line-height: 120px;
  letter-spacing: -2px;
}
.huge,
h1 {
  font-size: 68px;
  line-height: 72px;
  letter-spacing: -1px;
}
.large,
h2 {
  font-size: 44px;
  line-height: 48px;
}
.bigger,
h3 {
  font-size: 20px;
  line-height: 36px;
  font-weight: 800;
  margin-top: 3px;
  opacity: .8;
}
.big,
h4 {
  font-size: 24px;
  line-height: 30px;
}
body {
    background-color: black;
  font: 14px/20px 'Open Sans', sans-serif;
}
body.fullScreen {
    margin-top: 12px;
}

.small,
small {
  font-size: 13px;
  line-height: 18px;
}
body {
  color: white;
  background: url('img/sky.jpg');
  height: 1090px;
  margin-left: auto;
  margin-right: auto;
}
#wrapper {
  width: 960px;
}
text {
  font-size: 12px !important;
  font-weight: bold;
}

#title {
  font-size: 15px;
  margin-left: auto;
  margin-right: auto;
  padding: 18px;
  padding-top: 4px;
}
#title h1 {
  display: block;
  width: 160px;
  font-size: 32px !important;
  line-height: .5em;
  margin-top: 7px;
}
#title p {
  margin-bottom: 5px;
  font-weight: 600;
  line-height: 1.52em;
/*  opacity: .6; */
}
#title img {
  opacity: .7;
}

#title .dek {
  color: white;
  text-transform: uppercase;
  font-size: 11px;
  font-weight: 800;
}
#left_title {
  float: left;
  width: 160px;
  text-transform: uppercase;
  font-weight: 800;
  opacity: .35;
}
#left_title #giants {
  line-height: 1.1em;
}
#left_title #amper {
  font-size: 13px;
  line-height: 1.5em;
  text-transform: none;
  font-style: italic;
  padding-left: 3px;
}
#left_title #dwarves {
  font-size: 28px;
  font-weight: bold;
  font-style: italic;
  font-family: "gentium book basic";
  line-height: 1.2em;
}
a:link {
    color: white;
}
a:visited, a:hover {
    color: #CACACA;
}
#fullScreen {
 color: yellow;
 cursor: pointer;
 position: absolute;
 top: 0;
 right: 0;
 width: 48px;
 height: 48px;
 text-indent: -99999px;
 background:transparent url('img/full_screen_icon.png') no-repeat scroll center center;
 cursor: pointer;
}

/* Force layout / Chart styling */
/********************************/

#chart {
  position: relative;
  height: 900px;
  width: 100%;
  border-left: 1px solid black;
  border-right: 1px solid black;
}
#chart svg {
  position: relative; 
  top: -65px;
  margin-left: auto;
  margin-right: auto;
}


.hidden {
    display:none;
}

.paclink {
  stroke: yellow;
  opacity: 0.6;
  stroke-dasharray: 3, 5;
}

line {
  stroke: white;
  z-index: 0;
  stroke-dasharray: 3, 5;
  opacity: 0.4;
}
circle {
  cursor: pointer;
  z-index: 1000;
}
.center {
  display: block !important;
  font-size: 14px !important;
  font-weight: bold;
}
.clusterlabel {
  font-size: 18px !important;
  fill: white !important;
  text-transform: uppercase;
  font-weight: bold;
  text-shadow: rgba(0, 0, 0, 0.7) 0px 1px 0px;
}
.label {
  font-family: 'Open Sans', sans-serif;
}
.sizelabel, .showallmoneylabel {
  font-size: 14px !important;
}
/* Stepper window styling       */
/********************************/

.selected {
    background-color: #ffffff !important;
    background-image: -webkit-gradient(linear, left top, left bottom, from(rgb(255, 255, 255)), to(rgb(170, 170, 170))) !important;
    background-image: -webkit-linear-gradient(top, rgb(255, 255, 255), rgb(170, 170, 170)) !important;
    background-image: -moz-linear-gradient(top, rgb(255, 255, 255), rgb(170, 170, 170)) !important;
    background-image: -o-linear-gradient(top, rgb(255, 255, 255), rgb(170, 170, 170)) !important;
    background-image: -ms-linear-gradient(top, rgb(255, 255, 255), rgb(170, 170, 170)) !important;
    background-image: linear-gradient(top, rgb(255, 255, 255), rgb(170, 170, 170)) !important;
    filter: progid:DXImageTransform.Microsoft.gradient(GradientType=0,StartColorStr='#ffffff', EndColorStr='#aaaaaa') !important;
    
    text-shadow:rgba(255, 255, 255, 0.9) 0px 2px 1px; 
    
	color: black;
    border-width: 0px !important;
}

#steps {
    width: 472px;
    margin: 0px;
}
#stepper, #stepper-nav, #steps, #stepper-sub-nav {
  height: 225px;
  float: left;
  z-index: 400;
  position: relative;
}
#stepper-nav {
  margin-bottom: 4px;
  width: 150px;
}
#stepper-sub-nav {
/*    margin-top: -28px; */
}
#stepper #stepper-sub-nav li {
    font-size: 13px;
}

#stepper-nav li {
  font-size: 14px;
  line-height: 1.2em;
  cursor: pointer;
  margin-bottom: 5px;
  margin-left: 4px;
  margin-right: 4px;
  padding: 5px 12px;
  border: 3px solid rgba(60,60,60,0.6); 
  border-radius: 6px;
  font-weight: bold;
  
  /*background-color: #000000;*/
  background-image: -webkit-gradient(linear, left top, left bottom, from(rgba(0, 0, 0, 0.89)), to(rgba(31, 31, 32, 0.66)));
  background-image: -webkit-linear-gradient(top, rgba(0, 0, 0, 0.89), rgba(31, 31, 32, 0.66));
  background-image: -moz-linear-gradient(top, rgba(0, 0, 0, 0.89), rgba(31, 31, 32, 0.66));
  background-image: -o-linear-gradient(top, rgba(0, 0, 0, 0.89), rgba(31, 31, 32, 0.66));
  background-image: -ms-linear-gradient(top, rgba(0, 0, 0, 0.89), rgba(31, 31, 32, 0.66));
  background-image: linear-gradient(top, rgba(0, 0, 0, 0.89), rgba(31, 31, 32, 0.66));
  filter: progid:DXImageTransform.Microsoft.gradient(GradientType=0,StartColorStr='#000000', EndColorStr='#1f1f20');
  
  -webkit-box-shadow:0 2px 0 2px rgba(0,0,0,0.8); /* Saf3.0+, Chrome */
     -moz-box-shadow:0 2px 0 2px rgba(0,0,0,0.8); /* FF3.5+ */
          box-shadow:0 2px 0 2px rgba(0,0,0,0.8); /* Opera 10.5, IE 9.0 */
      filter:progid:DXImageTransform.Microsoft.dropshadow(OffX=0, OffY=2px, Color='#fff'); /* IE6,IE7 */
  -ms-filter:"progid:DXImageTransform.Microsoft.dropshadow(OffX=0, OffY=2px, Color='#fff')"; /* IE8 */ 
  
  -webkit-transition:all .3s linear ;       
     -moz-transition:all .3s linear ;
       -o-transition:all .3s linear ;
          transition:all .3s linear ; 

}

#stepper-sub-nav li {
    
    font-size: 12px !important;
    line-height: 1.2em;
    cursor: pointer;
    margin-bottom: 5px;
    margin-left: 4px;
    margin-right: 4px;
    padding: 4px 10px;
    border: 2px solid rgba(60,60,60,0.5); 
    border-radius: 6px;
    font-weight: bold;
    
    /*background-color: #000000;*/
    background-image: -webkit-gradient(linear, left top, left bottom, from(rgba(0, 0, 0, 1.00)), to(rgba(14, 14, 14, 0.85)));
    background-image: -webkit-linear-gradient(top, rgba(0, 0, 0, 1.00), rgba(14, 14, 14, 0.85));
    background-image: -moz-linear-gradient(top, rgba(0, 0, 0, 1.00), rgba(14, 14, 14, 0.85));
    background-image: -o-linear-gradient(top, rgba(0, 0, 0, 1.00), rgba(14, 14, 14, 0.85));
    background-image: -ms-linear-gradient(top, rgba(0, 0, 0, 1.00), rgba(14, 14, 14, 0.85));
    background-image: linear-gradient(top, rgba(0, 0, 0, 1.00), rgba(14, 14, 14, 0.85));
    filter: progid:DXImageTransform.Microsoft.gradient(GradientType=0,StartColorStr='#000000', EndColorStr='#0e0e0e');
    
    -webkit-transition:all .12s linear ;       
       -moz-transition:all .12s linear ;
         -o-transition:all .12s linear ;
            transition:all .12s linear ;
}
#stepper-sub-nav li:hover {
    border: 2px solid rgba(60,60,60,0.2) !important; 
    opacity: 1;
    color: #C1C1C1;
}
#stepper-sub-nav #liberal-list li { 
    
}

#stepper li:hover {
    border: 3px solid rgba(60,60,60,0.9); 
}
.total-raised, #hide_labels-button:hover {
color: black ;
 width: 190px !important;
 font-size: 10px !important;
 line-height: 1.2em;
 cursor: pointer;
 margin-bottom: 5px;
 margin-left: 9px;
 margin-right: 4px;
 padding: 5px 7px !important;
 border: 2px solid rgba(60,60,60,0.5); 
 border-radius: 6px;    
 
 background-color: #e9b90f;
 background-image: -webkit-gradient(radial, 0% 100%,0,0% 100%,200, from(rgb(219, 129, 8)), to(rgb(233, 185, 15)));
 background-image: -webkit-radial-gradient(0% 100%, rgb(233, 185, 15), rgb(219, 129, 8));
 background-image: -moz-radial-gradient(0% 100%, rgb(233, 185, 15), rgb(219, 129, 8));
 background-image: -o-radial-gradient(0% 100%, rgb(233, 185, 15), rgb(219, 129, 8));
 background-image: -ms-radial-gradient(0% 100%, rgb(233, 185, 15), rgb(219, 129, 8));
 background-image: radial-gradient(0% 100%, rgb(233, 185, 15), rgb(219, 129, 8));

 -webkit-transition:all .4s linear ;       
    -moz-transition:all .4s linear ;
      -o-transition:all .4s linear ;
         transition:all .4s linear ; 
         
         opacity: 0.75;
}
.total-raised:hover, #hide_labels-button {
    background-color: #e9b90f;
    background-image: -webkit-gradient(radial, 100% 0%,0,100% 0%,200, from(rgb(219, 129, 8)), to(rgb(233, 185, 15)));
    background-image: -webkit-radial-gradient(100% 0%, rgb(233, 185, 15), rgb(219, 129, 8));
    background-image: -moz-radial-gradient(100% 0%, rgb(233, 185, 15), rgb(219, 129, 8));
    background-image: -o-radial-gradient(100% 0%, rgb(233, 185, 15), rgb(219, 129, 8));
    background-image: -ms-radial-gradient(100% 0%, rgb(233, 185, 15), rgb(219, 129, 8));
    background-image: radial-gradient(100% 0%, rgb(233, 185, 15), rgb(219, 129, 8));
    
    opacity: 1;
}

ul {
  list-style-image : none;
  list-style-type : none;
  padding: 10px;
}
#allgroups-list, #conservative-list, #liberal-list {	
/*	padding-top: 40px; */
	width: 140px;
}
.next {
  cursor: pointer;
  font-size: 11px;
  padding: 3px 7px;
  border: 1px solid #444;
}

li {
  cursor: pointer;
  line-height: 14px;
}

.byline {
  color: white;
  opacity: .8;
  font-weight: 600;
  float: left;
  width: 318px;
  padding-top: 25px;
}

#show_labels-button {
   padding: 8px; 
   font-weight: normal; 
   font-size: 11px; 
   cursor: pointer; 
   display: inline; 
}
#hide_labels-button {
    padding: 8px; 
    font-weight: normal; 
    font-size: 11px; 
    cursor: pointer; 
    display: inline;  
}
/* Tooltip styling       */
/********************************/
#information {
	font-size: 11px;
	width: 180px;
    top: 300px;
	padding: 16px;
	position: absolute;
	background-color: rgba(23, 23, 23, 0.93);
	border-radius: 8px;
    z-index: 500; 
}

#donor_section {
    width: 140px;
    line-height: 1.3em;
}

#donor_section h5 {
  font-weight: bold;
  font-size: 10px;
}

#donors {

  font-size: 10px;
  line-height: 1.5em;
  width: 140px;
  margin-left: 10px;

}
.pacname {
    opacity: 1!important;
    font-size: 15px;
    line-height: 1.1em;
}

.linked-to {
    line-height: 1px;
}
#container {
    /*padding: 0px 10px; */
    z-index: 400;
    width: 960px;
    margin: auto;
    height: 80px;
}

#info {
    width: 150px;
    float: left;
    margin-right: 8px;
    padding-bottom: 10px;
}
.pactype, .pacspent {
    opacity: 0.6;
}
.pacname {
    font-size: 1.4em;
    font-style: normal;
    font-weight: 800;
}
.pacblurb {
    margin-top: 6px;
    margin-bottom: 6px;
    padding-top: 6px;
    padding-bottom: 10px;
    border-top: 1px    dotted rgba(255,255,255,0.3);
    border-bottom: 1px dotted rgba(255,255,255,0.3);
    font-style: italic;
    font: 12px 'Open Sans', sans-serif;
    font-weight: 600;
    line-height: 1.2em;
}
#information #info .pacreceipts {
    line-height: 13px;
}

#information #info .infobox_receipts {
    font-weight: bold;
    font-size: 15px;
}

.dark-money-footer {
    position: relative;	
	top: 20px;
    float: left;	
}

#debug {
    border: 1px solid red;
    width: 60px;
    height: 100px;
    position: fixed;
    bottom: 0px;
}

#poor_firefox {
    background-color: orange;
    color: black;
    text-align: center;
    color: white;
    font-weight: bold;
}
#bigwrapper {
    position:absolute;
    height: 1070px;
    overflow-y: hidden;
    width: 100%;
}
