@charset "UTF-8";
/* CSS Document */

/*------------------------------------*\
CONTENTS
\*------------------------------------*/
/*
RESET
REUSABLES
COLORS & TYPOGRAPHY
LAYOUT
HEADER
SITUATION
FIREDRILL
DEPENDS
FILTERS
SOLUTIONS
FOOTER
*/





/*------------------------------------*\
RESET
\*------------------------------------*/
html, body, 
div, span,
h1, h2, h3, h4, h5, p,
a, img,
ul, li,
button,
form, label, input, textarea {
  margin: 0;
  padding: 0;
  border: 0;
  outline: 0;
  font-size: 100%;
  font: inherit;
  vertical-align: baseline;
  font-weight: normal;

}

button, textarea, input[type=text]  {
	-webkit-appearance: none;
	border-radius: 0;
	background: none;
}

ul {
	list-style: none;
}

/* Scale images down in legacy IEs */
img { 
	-ms-interpolation-mode: bicubic;
}

/* When you tap an object, there won't be any unseemly highlighting */
* {
   -webkit-tap-highlight-color: rgba(0,0,0,0);
   -webkit-tap-highlight-color: transparent; /* For some Androids */
}





/*------------------------------------*\
REUSABLES
\*------------------------------------*/
.button-link {
}

/* Clear-fix recipe */
.cf:before,.cf:after {
    content: " ";
    display: table;
}

.cf:after {
    clear: both;
}

#solutions-container-col-a.hide, #solutions-container-col-b.hide {
	display: none;
}



/*------------------------------------*\
COLORS & TYPOGRAPHY
\*------------------------------------*/
body {
	font-family: "Source Sans Pro", sans-serif;
	font-weight: 300;
	font-size: 1em;
	line-height: 1em;
	color: #405467;
	text-rendering: optimizeLegibility;
	background-color: #405467;
}

@media (min-width: 50em) {
	body {
		font-size: 1.25em;
		line-height: 1.25em;
	}
}

a {
	color: #4eb4e4;
	text-decoration: none;
	cursor: pointer;
}

a:hover {
	color: #a0d8f6;
}

h1 {
	font-weight: 900;
	text-transform: uppercase;
}

h2 {
	font-size: 2em;
    line-height: 1em;
    font-weight: 600;
    margin-bottom: 0.5em;
}

h3 {
	font-weight: 400;
	font-size: 1.75em;
	line-height: 1.75em;
}

@media (min-width: 50em) {
	h3 {
		font-size: 2em;
		line-height: 2em;
	}
}

h4 {
	font-weight: 400;
	font-size: 1.5em;
	line-height: 1.5em;
}

h5 {
	font-size: 1.25em;
	line-height: 1.25em;
}

p, .homepage .solution-card-meta-subhead {
	font-family: 'Alegreya', serif;
	line-height: 1.25em;
}

@media (min-width: 50em) {
	p {
		line-height: 1.5em;
	}
}

.main-wrapper {
	background-color: #fff;
}

.homepage .main-wrapper {
	background: none;
}

.homepage .situation-container .situation-name {
	color: rgba(255, 255, 255, 0.9);
	font-weight: 600;
	font-size: 3em;
}

/*------------------------------------*\
LAYOUT
\*------------------------------------*/
.situation-container, .firedrill-container, .depends-container, .filters-content, .solutions-container, .ucg-solution, .footer-content {
	max-width: 60em;
	width: 94%;
	margin: 0 auto;
	padding: 1em 0;
}

.cta {
	text-align: center;
	color: #fff;
	padding: 0.5em 0;
}

.cta-headline {
	font-weight: 300;
	font-size: 1em;
	padding-bottom: 0.25em;
}

.cta-headline a {
	color: #fff;
	border-bottom: dotted 1px rgba(255,255,255,0.5);
	font-weight: 300;
}




/*------------------------------------*\
HEADER
\*------------------------------------*/
.header {
	background-color: #fafafa;
	font-size: 1.25em;
	box-shadow: 0 0 1px rgba(0, 0, 0, 0.15);
	color: #405467;
}

.header .header-content a {
	color: #405467;
}

.header-content {
	width: 94%;
	margin: 0 auto;
	padding: 1em 0;
	position: relative;
}

.header-headline {
	display: inline-block;
}

.header-logo-img {
	display: inline-block;
    width: 8%;
    position: relative;
    top: 0.25em;
    padding-right: 0.25em;
}

.header-logo-img img {
	max-width: 100%;
}

.header-list {
	display: inline-block;
	margin-left: 1.5em;
    margin-top: 0.25em;
}

@media (min-width: 40em) {
	.header-list {
		margin-top: 0;
		margin-left: -2.5em;
	}
}

.header-list-item {
	display: inline-block;
    font-size: 0.75em;
	position: relative;
}

.browse-menu-item {
	margin-right: 0.75em;
}
 
.browse-menu-item:after {
	font-family: "SSStandard";
	padding-left: 0.5em;
	font-size: 0.5em;
	content: "▾";
	-webkit-transition: all 0.5s ease-in-out;
  	transition: all 0.5s ease-in-out;
}

.browse-menu-item:hover:after {
	content: "▴";
}

.header-list-fly-out-menu {
	position: absolute;
    top: 1.5em;
    left: -0.75em;
    display: block;
	width: 150%;
    overflow: hidden;
    padding: 0.5em 0 0 0.75em;
    background-color: #fafafa;
	box-shadow: 0 2px 2px rgba(0, 0, 0, 0);
	-webkit-transition: all 0.5s ease-in-out;
  	transition: all 0.5s ease-in-out;
	max-height: 0;
}

.browse-menu-item:hover .header-list-fly-out-menu {
	max-height: 20em;
	box-shadow: 0 2px 2px rgba(0, 0, 0, 0.15);
	z-index: 100;
}

.header-search-trigger {
	display: inline-block;
	position: absolute;
    top: 0.7em;
    right: 0;
    /*
	border: solid 1px rgba(0, 0, 0, 0.1);
    border-radius: 50%;
	*/
    height: 2em;
    width: 2em;
    text-align: center;
	font-size: 1em;
}

.header-list-fly-out-menu-item {
	display: block;
	padding-bottom: 0.5em;
	font-size: 1em;
	font-weight: 300;
}

.header-list-fly-out-menu-item a {
	cursor: pointer;
}

.header-list-fly-out-menu-item:hover {

}

.header-list-fly-out-menu-item.dead {
		color: rgba(64, 84, 103, 0.6);
		cursor: auto;
}

.header-list-fly-out-menu-item.dead:hover {
		color: rgba(64, 84, 103, 0.6);
}

.header-list-fly-out-menu-item.dead {
	cursor:default;
}

.header-search-trigger-icon {
	position: relative;
	top: 0.625em;
	color: #405467;
	cursor: pointer;
}





/*------------------------------------*\
SITUATION
\*------------------------------------*/
.situation-container {
}


.situation-breadcrumb {
	font-size: 0.75em;
}

.situation-name {
	margin-top: 0.5em;
	margin-bottom: 0.75em;
}

.situation-description {
	font-size: 1.25em;
	margin-bottom: 1em;
}

.situation-comic-panel {
	display: inline-block;
}

@media (min-width: 35em) {
	.situation-comic-panel {
		width: 49%
	}
}

@media (min-width: 43.7em) {
	.situation-comic-panel {
		width: 32%
	}
}

.situation-comic-panel img {
	max-width: 100%;
}





/*------------------------------------*\
FIREDRILL
\*------------------------------------*/
.firedrill {
	background-color: #fafafa;
}

.firedrill-content {
}

.firedrill-list-item {
	margin-bottom: 1.25em;
}

.firedrill-headline {
	font-size: 1.75em;
	line-height: 1.25em;
	font-weight: 600;
	margin: 0.25em 0 0 0;
}

.firedrill-subhead {
	font-size: 1.5em;
    line-height: 1.25em;
	margin: 0 0 0.25em 0;
}

.firedrill-description {
	font-weight: 100;
	font-size: 1.25em;
	line-height: 1.25em;
	margin: 0 0 0.75em 0;
}

.firedrill a:after {
	font-family: "SSStandard";
	content:'➡';
	padding-left: 0.25em;
	position: relative;
	top: 0.175em;
}

.firedrill-list-item a {
	font-size: 1.25em;
	line-height: 1.25em;
}

.firedrill-list-item p {
	clear: both;
}

.firedrill p {
	font-style: italic;
}

.disclaimer-p {
	font-style:italic;
}



/*------------------------------------*\
DEPENDS
\*------------------------------------*/
.depends {
	
}

.depends-container {
	padding: 1em 0 1.5em 0;
}

.depends-headline {
	font-size: 1em;
}

.depends p {
	font-style:italic;
}





/*------------------------------------*\
FILTERS
\*------------------------------------*/
.filters {
	position: relative;
	top: 0;
	z-index: 1;
	padding-bottom: 0.75em;
	box-shadow: 0px 1px 2px rgba(0, 0, 0, 0.1);
}

.filters-content {
	padding-bottom: 0;
}

.filter-top-level {
	display: inline-block;
    width: 35%;
    margin-right: 4%;
}

.filter-label {
		width: 18%;
	}

.filter-label:after {
	content: " by:";
}

@media (min-width: 43.7em) {
	.filter-label {
	}
	
	.filter-top-level {
		width: 20%;
    	margin-right: 5%;
	}
	
	.filter-label:after {
		content: " Solutions by:";
	}
}

.filter-top-level:last-of-type {
	margin-right: 0;
}

.filter-trigger {
	display: inline-block;
	position: relative;
	cursor: pointer;
}

.filter-trigger:after {
	font-family: "SSStandard";
	padding-left: 0.5em;
	font-size: 0.5em;
	content: "▾";
	-webkit-transition: all 0.5s ease-in-out;
  	transition: all 0.5s ease-in-out;
}

.filter-trigger:hover:after {
	content: "▴";
}

.filter-group {
	position: absolute;
    top: 1.25em;
    left: -1.25em;
    display: block;
	width: auto;
    overflow: hidden;
    padding: 0 0.5em 0.25em 0.5em;
    background-color: #fafafa;
	box-shadow: 0 2px 2px rgba(0, 0, 0, 0);
	-webkit-transition: all 0.5s ease-in-out;
  	transition: all 0.5s ease-in-out;
	max-height: 0;
	background: #fafafa;
}

.filter-trigger:hover .filter-group {
	max-height: 20em;
	box-shadow: 0 2px 2px rgba(0, 0, 0, 0.15);
}

.filter-tag {
	display: block;
	width: auto;
	background: #fff;
	border: 1px solid rgba(0,0,0,0.04);
    box-shadow: 0 1px 4px rgba(0,0,0,0.03);
    border-radius: 3px;
	padding: 0.5em;
	margin: 0.5em;
	cursor: pointer;
	color: #4eb4e4;
}

.filter-tag:before {
	font-family: "SSStandard";
	padding-right: 0.5em;
	font-size: 0.5em;
	content: "✓";
	-webkit-transition: all 0.5s ease-in-out;
  	transition: all 0.5s ease-in-out;
}

.pressed {
	box-shadow: none;
	color: #ccc;
}

.pressed:before {
	font-size: 1em;
	content: "○";
	padding-right: 0.25em;
}





/*------------------------------------*\
SOLUTIONS
\*------------------------------------*/
.filters, .solutions {
	background-color: #fafafa;
}

.solution-col-header {
	font-size: 1.5em;
}

.solution-col-subhead {
	font-weight: 100;
    font-size: 0.9em;
    line-height: 1.25em;
    margin: 0.25em 0 0.5em 0;
}

.solution-card {
	background: none;
	border: 1px solid rgba(0,0,0,0);
    border-radius: 3px;
	-webkit-transition: height 0.5s ease-in-out;
  	transition: height 0.5s ease-in-out;
	height: 300px;
	overflow: hidden;
	position: relative;
	display: none;
}

.large-corporation,  .small-business,  .startup,  .agency,  .freelance, .no-budget, .low-budget, .med-budget, .high-budget {
	background: #fff;
	border: 1px solid rgba(0,0,0,0.04);
	box-shadow: 0 1px 4px rgba(0,0,0,0.03);
	margin-bottom: 1em;
	display: block;
	
}

.solution-card-content {
	padding: 1em 1em 3em 1em;
}

.homepage .solution-card-content {
	padding: 1em 1em 2em 1em;
}

@media (min-width: 43.7em) {
	.solutions-container {
		display: flex;
    	justify-content: space-between;
	}
	
	.solutions-container-col-a, .solutions-container-col-b {
		display: inline-block;
		vertical-align: top;
		width: 50%;
	}
	
	.solutions-container-col-a {
		margin-right: 0.5em;
	}
	
	.solutions-container-col-b {
		margin-left: 0.5em;
	}
}

/*
.solutions-container.homepage {
	display: block;
}

.homepage .solutions-container-col-a, .solutions-container-col-b {
	display: block;
	width: 100%;
}
*/

.homepage .solution-card {
	height: auto;
	color: #405467;
}

.solution-image {
	max-width: 100%;
}

.solution-card-meta {
	margin: 0.5em 0 0.75em 0;
}

.solution-card-meta li {
	display: block;
	font-size: 0.75em;
	line-height: 1.75em;
	font-weight: 100;
}

.solution-card-timeline {
	font-size: 0.9em;
	font-weight: 300;
}

.solution-card-rate {
	display: none !important;
}

.solution-card-budget {
}

.solution-card-contexts {
}

.solution-card .summary {
	margin: 0.5em 0 1em 0;
}

.solution-list {
	margin: 1em;
}

.solution-list-item {
	margin-bottom: 1.25em;
	line-height: 1.25em;
}

.solution-list-qoute {
	display: block;
	margin-bottom: 0.5em;
	position: relative;
	line-height: 1.45em;
}

.solution-list-qoute:before {
	content: "“";
	position: absolute;
	left:  -0.45em;
	color: rgba(0, 0, 0, 0.3);
}

.solution-list-qoute:after {
	content: "”";
	color: rgba(0, 0, 0, 0.3);
}

.solution-list-attribution {
	display: block;
	text-align: right;
	font-size: 0.9em;
	font-style:italic;
	font-family: 'Alegreya', serif;	
}

.solution-list-attribution:before {
	content: "– ";
}

.solution-sources-list-item {
	margin-bottom: 0.25em;
	font-size: 0.9em;
}

.solution-card-resources {
	margin-bottom: 1em;
}

.homepage .solution-card-resources {
	margin-bottom: 0;
}

.solution-card-success-rate {
	display: inline-block;
	padding: 0 0.25em 0.5em 0;
}

.solution-card-hide {
	max-height: 0;
	box-shadow: none;
	border: 1px solid rgba(0,0,0,0);
	background: rgba(0,0,0,0);
	margin-bottom: 0;
}

.solution-card-reply {
	display: none;
}

.solution-card-reply-container-trigger {
	cursor: pointer;
	color: #4eb4e4;
    display: inline-block;
}

.solution-card-reply-content {
	position: relative;
	max-height: 0px;
	overflow: hidden;
	-webkit-transition: height 0.5s ease-in-out;
  	transition: height 0.5s ease-in-out;
}

.solution-card-reply-form {
	padding: 0.5em 0;
}

.show-reply {
	max-height: 20em;
}

.solution-card-reply-container-close {
	position: absolute;
	top: 0.1em;
	right: 0;
	cursor: pointer;
}

.solution-card-reply-form-element {
	display: block;
	margin: 1em 0;
}

.solution-card-reply-label {
	display: block;
	margin-bottom: 0.5em;
}

.solution-card-reply-textarea, .solution-card-reply-email {
	border: 1px solid rgba(0,0,0,0.04);
    border-radius: 3px;
	display: block;
	padding: 0.5em;
	margin: 0.5em 0;
	width: 90%;
}

.solution-card-reply-email {
}

.solution-card-reply-submit {
	display: inline-block;
	border: 1px solid rgba(0,0,0,0.04);
    box-shadow: 0 1px 4px rgba(0,0,0,0.03);
    border-radius: 3px;
	padding: 0.5em;
	cursor: pointer;
	color: #4eb4e4;
	margin-top: 0.5em;
}

.ucg-solution p, .ucg-solution span {
	font-size: 1.5em;
	margin-bottom: 1em;
}

.ucg-solution .solution-card-reply-submit {
	background: #fff;
}

.solution-card-reply-radio {
	margin: 0 2.25em 0 0.1em
	
}

.solution-card-expander {
	position: absolute;
	left: 0;
	bottom: 0;
	background: -moz-linear-gradient(rgba(255,255,255,0) 0%, rgba(255,255,255,1) 75%, rgba(255,255,255,1) 100%);
	background: -webkit-linear-gradient(rgba(255,255,255,0) 0%, rgba(255,255,255,1) 75%, rgba(255,255,255,1) 100%);
	background: -webkit-gradient(linear, 0 0, 0 100%, from(rgba(255,255,255,0)), color-stop(0.75, rgba(255,255,255,1)), to(rgba(255,255,255,1)));
	background: -o-linear-gradient(rgba(255,255,255,0) 0%, rgba(255,255,255,1) 75%, rgba(255,255,255,1) 100%);
	background: linear-gradient(rgba(255,255,255,0) 0%, rgba(255,255,255,1) 75%, rgba(255,255,255,1) 100%); /* FF3.6-15 */ /* Chrome10-25,Safari5.1-6 */ /* W3C, IE10+, FF16+, Chrome26+, Opera12+, Safari7+ */
	filter: progid:DXImageTransform.Microsoft.gradient( startColorstr='#00ffffff', endColorstr='#ffffff',GradientType=0 ); /* IE6-9 */
	width: 100%;
	padding: 0.5em 0;
	text-align: center;
}

.solution-card-expander-btn {
	display: inline-block;
	background: #fff;
	border: 1px solid rgba(64, 84, 103, 0.25);
	box-shadow: 0 1px 9px rgba(64, 84, 103, 0.25);
	border-radius: 3px;
	padding: 0.5em 1em;
	margin: 0 0.25em 0.25em 0.25em;
	cursor: pointer;
	color: #4eb4e4;
	-webkit-transition: all 0.3s ease-in-out;
	transition: all 0.3s ease-in-out;
}

.solution-card-expander-btn:hover {
	box-shadow: 0 1px 12px rgba(64, 84, 103, 0.5);
}

.solution-card-expander-btn:before {
	content: "Expand";
}

.open .solution-card-expander-btn:before {
	content: "Collapse";
}


span.ss-dollarsign:before {
	position: relative;
    top: 0.25em;
    color: rgba(0, 0, 0, 0.25);
    padding-right: 0.15em;
}





/*------------------------------------*\
FOOTER
\*------------------------------------*/
.footer {
	padding: 1em 0;
	color: rgba(255, 255, 255, 0.8);
}

.footer-about, .footer-contact {
	margin-bottom: 1em;
}

.footer p {
	font-size: 0.9em;
	margin-bottom: 1.25em;
}

.footer h5 {
	margin-bottom: 0.25em;
}

@media (min-width: 50em) {
	.footer-about, .footer-contact {
		display: inline-block;
		width: 45%;
		vertical-align: top;
	}
	
}
.footer-contact {
		margin-left: 2em;
}