/* CSS Document */
:root {
/* ----------------------------------------------------------------------------------------------
	Variables
----------------------------------------------------------------------------------------------*/

	--working-borders: 0px solid rgba(255, 255, 255, 1.0); 
	
	--max-width: 1400px;
	--header-height-branded: 4.5rem;
}

html {
	box-sizing: border-box;
	scroll-behavior: smooth;
	-webkit-text-size-adjust: 100%;
}

*, *:before, *:after {
	box-sizing: inherit;
}

	
h2 {
	margin-top:0.25em;
	margin-bottom: 0;
	padding-bottom: 0;
}

h3 {
	margin-bottom: 0;
	padding-bottom: 0;
	margin-top: 1.75em;
	padding-top: 0;
}



p.indented {
	padding-left: 0;
}

p.subheading {
	margin-top: 0;
}


body {
	padding: 0;
	margin: 0;
}

img{
    vertical-align: middle;
    max-width: 100%;
    display: inline-block;
	border: var(--working-borders);
	border-color: var(--color-red);
}

.page {
    flex-direction: column;
    justify-content: center;
    align-items: center;
    /*display: flex;*/
    flex: 1;
	border: var(--working-borders);
	border-color: var(--color-blue);
	padding-top: 4em;
	min-height: 100vh;
}

.page.home {
	padding-top: 0em;
}

.header {
    z-index: 8888;
    position: fixed;
    top: 1.5em;
    top: 0;
    left: 0%;
    right: 0%;
	border: var(--working-borders);
	border-color: var(--color-lime);
	height: var(--header-height-branded);
	line-height: 1.2;
}

.header.show {	
	animation-name: showHeader;	
	animation-duration: 1s;
	animation-iteration-count:1;
	animation-fill-mode: forwards;
}

.header.hide {	
	animation-name: hideHeader;	
	animation-duration: 1s;
	animation-iteration-count:1;
	animation-fill-mode: forwards;
}

.link-button {
	display: inline-block;
	padding: 0.35em 2.0em;
	border-radius: 24px;
	margin-top: 0.6em;
	margin-bottom: 1.2em;
	transition: all 0.2s ease-in-out;
	min-width: 200px;
	cursor: pointer;
}

.cta-button {
	display: inline-block;
	padding: 0.45em 2.0em;
	border-radius: 24px;
	margin-top: 1.0em;
	margin-bottom: 1.5em;
	transition: all 0.2s ease-in-out;
	width: 300px;
	min-width: 200px;
	max-width: 100%;
	cursor: pointer;
}



@keyframes showHeader {
	from {  opacity: 1;	left: -1000px; } to { opacity: 1; top: 0px; }
}


@keyframes hideHeader {
	from { opacity: 1; left: 0px; } to { opacity: 1; top: -100px; }
}

@keyframes showHeader {
	from {  
		opacity: 0;	
		/*top: calc(var(--header-height) * -1); */
	} 
	to { 
		opacity: 1;
		/*top: 0px; */
	}
}

.header.hide {	
	animation-name: hideHeader;	
	animation-duration: 0.5s;
	animation-iteration-count:1;
	animation-fill-mode: forwards;
}

@keyframes hideHeader {
	from { 
		opacity: 1; 
		/*top: 0px; */
	} 
	to { 
		opacity: 0; 
		/*top: calc(var(--header-height) * -1);*/ 
	}
}
	
.header-bar {
    top: 0%;
    left: 0%;
    right: 0%;
	border: var(--working-borders);
	border-color: var(--color-lime);
}

.footer {
    z-index: 400;
    position: relative;
    bottom: 1.5em;
    left: 0%;
    right: 0%;
	border: var(--working-borders);
	border-color: var(--color-orange);
	padding: 0;
	padding-bottom: 3em;
	min-height: 10em;
	min-width: 100%;
	margin: auto;
	margin-top: 5em;
}

.footer-bar {
    z-index: 401;
    position: relative;
    top: 0%;
    left: 0%;
    right: 0%;
	border: var(--working-borders);
	border-color: var(--color-orange);
	margin: 0;
	min-height: 3em;
}

.sitemap {
    z-index: 999;
    position: relative;
	border: var(--working-borders);
	border-color: var(--color-cyan);
	margin: 1em;
	margin-bottom: 0;
	text-align: left;
}

.container {
    flex-direction: column;
    display: flex;
	flex: 1;
	max-width: var(--max-width);
	margin-left: auto;
    margin-right: auto;
	border: var(--working-borders);
	border-color: var(--color-yellow);
    justify-content: left;
	padding: 1.5em;
	padding: 2em;
	padding-top: 2.5em;
	
}

.container.wide {
	width: 96%;
	max-width: 100vw;
	background-color: #666666;
	border: var(--working-borders);
	border-color: var(--color-silver);
	border-radius: 1em;
	padding-left: 0.5em;
	padding-right: 0.5em;
	margin-left: 2em;
	margin-right: 2em;
	background-color: var(--color-highlight-25);
}

.content {
	width: 100%;
	margin-left: auto;
    margin-right: auto;
	border: var(--working-borders);
	border-color: var(--color-teal);
    justify-content: left;
	padding: 1.5em;
	
	
    grid-column-gap: 1em;
    grid-row-gap: 1em;
    grid-template-rows: auto;
    grid-template-columns:  1fr;
    grid-auto-columns: 1fr;
    display: grid;
	max-width: 1400px;
}

.content {
  display: grid;
  grid-template-columns: 100%;  /* first column 30%, second column 70% */
  margin-top: 2em;
}

.content.wide {
		max-width: 1400px;
	}

.content.even {
	
}

.content.odd {
	border: var(--working-borders);
	border-color: var(--color-silver);
	border-radius: 1em;
}

.content-left.text {
	padding-right: auto;
}

.content-right.text {
	padding-left: auto;
}

.content-center {
	margin-right: auto;
	margin-left: auto;
	text-align: center;
}

.content-numbered {
	margin-left: 2em;
}

.map {
	border: solid 1px var(--color-main-text-50);
	border-radius: 1em;
	overflow: hidden;
	min-height: 25em;
}

.content-heading {
	grid-area: 1 / 1 / 1 / 1;
	margin-bottom: 0;
}

.grid {
    grid-column-gap: 1em;
    grid-row-gap: 1em;
    grid-template-rows: auto;
    grid-template-columns: 1fr;
    grid-auto-columns: 1fr;
    display: grid;
	max-width: 1400px;
}

.grid-sitemap {
    grid-template-columns: 1fr 1fr;
    align-self: stretch;
	grid-area: 1 / 2 / 2 / 2;
}

.sitemap-image {
    grid-area: 1 / 1 / 2 / 3;
}

.sitemap-info {
	grid-area: 2 / 1 / 3 / 3;
}

.grid-sitemap-links {
	grid-area: 3 / 1 / 4 / 3;
}

.sitemap-links {
	grid-area: span 1 / span 1 / span 1 / span 1;
}

#animation_container {
	zoom: 0.15;
}

		
.insight-item {
	display: grid;
	grid-template-columns: 1fr;
	grid-template-areas:
		"image"
		"content";
	gap: 1em;
	margin-bottom: 3em;
	margin-top: 1em;
	align-items: start;
}

.insight-image {
	grid-area: image;
}

.insight-image img {
	display: block;
	max-width: 250px;
	height: auto;
	border-radius: 7px;	
	margin-right: 2em;
}

.insight-content {
	grid-area: content;
	margin-top: 1em;
}

.insight-content h3 {
	margin-top: 0;
	padding-top: 0;
	margin-bottom: 0.5em;
}

.insight-content p {
	margin-top: 0;
}
 
.step-marker {
  width: 44px;
  height: 100%;
  background: transparent;
  display: flex;
  flex-direction: column;
  align-items: center;
  float: left;
  margin-left: -3em;
  margin-right: 1em;
  padding-top: 0.8em;
}

.step-number {
  font-size: 1.25rem;
  font-weight: 700;
  line-height: 1;
  color: #8a5cff;
  letter-spacing: 0.02em;
}

.step-line {
  width: 2px;
  height: 88px;
  margin-top: 18px;
  background: linear-gradient(
	to bottom,
	rgba(138, 92, 255, 1) 0%,
	rgba(138, 92, 255, 0.75) 55%,
	rgba(138, 92, 255, 0) 100%
  );
}	
	

.problem-hero {
	display: grid;
	grid-template-columns: 60% 40%;
	align-items: center;
	min-height: 200px;
	background-image: url(https://gregdscott.com/images/background.png);;
	background-repeat: no-repeat;
	background-position: right bottom;
	background-size: 75%;
	margin-top: 0;
	margin-bottom: 0;
	padding-top: 0;
	padding-bottom: 0;
	padding-left: 1em;
	padding-right: 1em;
	max-width: 1400px;
	margin: auto;
}


.problem-hero {
	display: block;
	min-height: auto;
	/*padding: 3rem 1.5rem;*/
	background-position: left bottom;
	background-size: 50%;
	background: none;
	width: 100%;
}

.problem-hero__photo {
	min-height: auto;
	align-self: end;
	margin-top: 2em;
	margin-left: 2em;
	margin-right: 1em;
	margin-bottom: 0;
	display: none;
}

.problem-hero__fade {
	height: 100%;
	background: var(--fade-from-white);
	display: flex;
	align-items: center;
	justify-content: center;
	padding-right: 30vw;
}

.problem-hero__questions {
	position: relative;
	padding-top: 2rem;
	padding-bottom: 3.5em;
	padding-left: 2em;
	padding-right: 1em;
	max-width: 800px;
	width: 100%;
	margin: auto;
	background: var(--fade-from-white);
}


.problem-hero__questions h1 {
	/*font-size: clamp(1.5rem, 3vw, 2.4rem);*/
	font-size: clamp(1.8rem, 8vw, 2.6rem);
	line-height: 1.2;
	font-weight: 700;
	max-width: 500px;
	margin: 0;
}

.problem-hero__questions h3 {
	margin-bottom: 0.3em;
}

.problem-hero__questions p {
	
	font-size: clamp(1.2rem, 1.2vw, 2rem);
	line-height: 1.2;
	font-weight: 700;
	margin: 0;
	max-width: 450px;
}

.solution-hero {
	display: block;
	align-items: center;
	min-height: 200px;
	margin: auto;
	margin-top: 0;
	margin-bottom: 0;
	padding-top: 1em;
	padding-bottom: 1em;
	padding-left: 0;
	padding-right: 0;
	align-items: center;
	max-width: 1400px;
}

.solution-hero__left {
	padding: 2em;
	padding-bottom: 0;
	border-right:dashed 0px var(--color-dark-text-100);
	border-bottom:dashed 0px var(--color-dark-text-100);
}

.solution-hero__left h1 {
	font-size: clamp(1.5rem, 3vw, 2.4rem);
	line-height: 1.2;
	font-weight: 700;
	margin: 0;
	color: var(--color-dark-text-100);
}

.solution-hero__left h3 {
	margin-bottom: 1.3em;
	color: var(--color-dark-text-100);
	font-size: 2em;
	margin-top: 0em;
}

.solution-hero__left p {
	color: var(--color-dark-text-100);
	line-height: 1.2;
	margin: 1em;
}

.solution-hero__right {
	align-self: start;
	color: var(--color-dark-text-100);
	margin: auto;
	margin-left: 0;
	margin-right: 0;
	margin-top: 0;
	margin-bottom: 0em;
	padding: 2em;
	padding-top:0;
}

.solution-hero__right h1 {
	font-size: clamp(1.5rem, 3vw, 2.4rem);
	line-height: 1.2;
	font-weight: 700;
	margin: 0;
	color: var(--color-dark-text-100);
}

.solution-hero__right p {
	color: var(--color-dark-text-100);
}

.solution-image {
	max-width: 3em;
	display: inline;
	margin-right: 1.5em;
	
}

.content.styled {
	
	background: linear-gradient(to right, rgba(256,256,256,0.5), rgba(256,256,256,0.5), rgba(256,256,256,0.8), rgba(256,256,256,1.0), rgba(256,256,256,1.0), rgba(256,256,256,1.0), rgba(256,256,256,1.0), rgba(256,256,256,1.0), rgba(256,256,256,1.0)), url("https://gregdscott.com/images/background.png");
	background-repeat: no-repeat;
	background-position: left bottom;
	border: solid 1px #5624da; 
	border-radius: 1em; 
	padding:1em;
	padding-top:2em;
	padding-bottom:2em;
}

.content-right.styled {
	padding-left: 2em;

}
	
.impact-section {
	display: block;
	width: 100%;
	
}

.impact-section img {
	height: 2em;
	display: inline-block;
	margin-right: 0.3em;

}

.impact-section p {
	font-size: 2em;
	margin: 0;
}

.impact-arrow {
	width: 100%;
	height: 2em;
  	transform: rotate(90deg);
}
	
.callouts {
	padding-left: 2em;
	padding-bottom: 2em;
}
	
.callout {
	display: block;
	max-width: 300px;
	padding: 1em;
	border-right: dashed 0px #999999;
	margin-bottom: 0;
}

.callout.end {
	border-right: dashed 0px #999999;
}

.callout img {
	height: 3em;
	float: left;
	margin-right: 1em;
}

.success-statement {
	margin-top: 1.5em;
	margin-bottom: 2em;
	max-width: 500px;
}

.success-statement p {
	margin-left: 2.8em;
}

.success-statement img {
	margin-right: 1em;
	height: 2em;
}


/*	Navigation - Used to create a responsive structure for to display links to pages and content
	 within the site */

.header-navigation {
	border: var(--working-borders);
	border-color: var(--color-magenta);	
	position: absolute;
	width: 100%;
	top: calc(( var(--header-height-branded) - ( 1rem + var(--header-footer-border) + var(--header-footer-border) )) / 2 );
	display: inline-block;
	z-index: 1000; 
	padding-right: 2.5rem;
	float-right;
	
}

.navigation-options {
	border: var(--working-borders);
	border-color: var(--color-cyan);	
	display: none;
	position: absolute;
	top: calc( ( var(--header-height-branded) / 2 ) + ( var(--header-footer-border) + var(--header-footer-border) ));
	padding-top: 0.8em;
	
	/*transform: translate(0, -);*/
}

.navigation-options.responsive {
	display: block;
	width: 100%;
	float: right;
}


.header-logo {
	border: var(--working-borders);
	border-color: var(--color-red);
	
	position: absolute;
	top: 52%;
	left: 0em;
	transform: translate(2em, -50%);
	z-index: 1500;
	height: 3.5em;
	height: auto;
}

.header-brand-link {
	position: absolute;
	z-index: 1;
}

.dropdown-content{
	
	position: absolute;
	
	min-width: 10rem;
	
	z-index: 1001;
	margin-top: 0rem;
	margin-left: -2rem;
	padding: 2rem;
	padding-top: 1rem;
	width:auto;

}

.dropdown-content.notext{
	margin-left: -9rem;
	margin-top: -1em;
}

.menu-option{
	border: var(--working-borders);
	border-color: var(---color-brown);
	float: right;
	display: inherit;

}



.menu-option.notext {
	display: block;
	top: 0;
	position: relative;
	left: 0;
	
	display: block;
	top: 5.3em;
	position: absolute;
	left: 6em;
}

.dropdown-option{
	border: var(--working-borders);
	border-color: var(---color-brown);
	display: block;

}

.icon{
	border: var(--working-borders);
	border-color: var(---color-brown);
	float: right;
	display: block;
	transform: translate(0, -0.75rem);

}

.navigation-options.responsive a.menu-option,
.navigation-options.responsive a.dropdown-option{
	display: block;
	width: 100%;
	float: left;
}

.navigation-options.responsive div.dropdown-content{
	position: relative;
	margin-left: 2rem;
	background: none;
}

.header-navigation icon{
	font-size: 2em;

}

.contactform {
	width: 85vw;
	height: 700px;
	border: var(--working-borders);
	border-color: var(--color-yellow);
	background: transparent; 
	overflow: hidden;
	margin-left: 0px
}


@media only screen and (max-width: 249.98px) {

}

@media only screen and (min-width: 250px) {

#animation_container {
	zoom: 0.19;
}

}

@media only screen and (min-width: 320px) {

#animation_container {
	zoom: 0.23;
}

}

}

@media only screen and (min-width: 360px) {

#animation_container {
	zoom: 0.26;
}

}

@media only screen and (min-width: 375px) {

#animation_container {
	zoom: 0.27;
}

}

@media only screen and (min-width: 385px) {

#animation_container {
	zoom: 0.28;
}

}

@media only screen and (min-width: 390px) {

#animation_container {
	zoom: 0.285;
}

}

@media only screen and (min-width: 414px) {

#animation_container {
	zoom: 0.305;
}

}

@media only screen and (min-width: 527px) {

#animation_container {
	zoom: 0.398;
}

.content-numbered {
	margin-left: 3em;
}

}

@media only screen and (min-width: 640px) {

.grid-sitemap-links {
	grid-area: 2 / 1 / 3 / 3;
}

.sitemap-image {
    grid-area: 1 / 1 / 2 / 2;
}

.sitemap-info {
	grid-area: 1 / 2 / 2 / 3;
}

#animation_container {
	zoom: 0.495;
}

}

@media only screen and (min-width: 768px)  {

.grid-sitemap {
    grid-template-columns: 1fr 1fr 1fr;
}

.sitemap-info {
	grid-area: 1 / 2/ 2 / 4;
}

.grid-sitemap-links {
	grid-area: 2 / 2 / 3 / 4;
}

.grid {
    grid-template-columns: 1fr 1fr;
}

#animation_container {
	zoom: 0.605;
}

.navigation-options{
	display: block;
	position: relative;		
	top: calc( ( var(--header-height-branded) / 2 ) - ( 3rem + var(--header-footer-border) + var(--header-footer-border) ));
	display: flex;
	flex-direction: row;
	float: right;

}

.dropdown-content{
		
	box-shadow: 0px 8px 16px 0px rgba(0,0,0,0.2);
	margin-top: calc( ( var(--header-height-branded) / 2 ) + ( var(--header-footer-border) + var(--header-footer-border) ));
	background-color:  var(--branded-background-color);

}

.dropdown-content{
		
	box-shadow: 0px 8px 16px 0px rgba(0,0,0,0.2);
	margin-top: calc( ( var(--header-height-unbranded) / 2 ) + ( var(--header-footer-border) + var(--header-footer-border) ));
	background-color:  var(--color-dark-highlight);
	border: 1px solid  var(--color-light-100);
}

.navigation-options.minimalist{
	top: calc( ( var(--header-height-branded) / 2 ) - ( 2.75rem + var(--header-footer-border) + var(--header-footer-border) ));

}

.navigation-options.responsive{
	display: none;

}

.menu-option {
	display: inline-block;
}

.dropdown-content.notext{
	margin-left: -9rem;
	margin-top: 3em;
}


.menu-option.notext {
	display: block;
	top: auto;
	position: relative;
	left: auto;
}


.icon{
	display: none;
}

.insight-item {
    grid-template-columns: 250px 1fr;
    column-gap: 2.5em;
	grid-template-areas: "image content";
}

.success-statement {
	margin-top: 1.5em;
	margin-bottom: 2em;
	max-width: 500px;
}

.success-statement p {
	margin-left: 2.8em;
}

.success-statement img {
	margin-right: 1em;
	height: 2em;
}

.problem-hero {
	display: grid;
	grid-template-columns: 60% 40%;
	align-items: center;
	min-height: 200px;
	background-image: url(https://gregdscott.com/images/background.png);
	background-repeat: no-repeat;
	background-position: right bottom;
	background-size: 75%;
	margin-top: 0;
	margin-bottom: 0;
	padding-top: 0;
	padding-bottom: 0;
	padding-left: 0;
	padding-right: 0;
	max-width: 1400px;
	margin: auto;
}


.problem-hero__photo {
	display: inline-flex;
}

.problem-hero__questions {
	padding-top: 2rem;
	padding-bottom: 4rem;
	padding-left: 3em;
	padding-right: 0;
	width: 100%;
}

.problem-hero__questions h1 {
	font-size: clamp(1.8rem, 8vw, 2.6rem);
}

.problem-hero__questions p {
}

.problem-hero__fade {
	height: 100%;
	background: rgba(256,256,256,0.0);
	display: flex;
	align-items: center;
	justify-content: center;
	padding-right: 0;
}

.solution-hero__right {
	margin: auto;
	align-self: center;
}
.content-right.styled {
	padding-left: 0;

}
	
.impact-section {
	display: inline-block;
	width: 100px;
	align-self: center;
	
}

.impact-section img {
	height: 5em;
	display: block;
	margin-right: 0;

}

.impact-section p {
	font-size: 1em;

}

.impact-arrow {
	width: 20px;
	height: 1em;
  	transform: rotate(0deg);
}


			
}

@media only screen and (min-width: 1024px) {

.grid-sitemap {
    grid-template-columns: 1fr 1fr 1fr 1fr;
}

.sitemap-info {
	grid-area: 2 / 1 / 3 / 3;
}

.grid-sitemap-links {
	grid-area: 2 / 3 / 3 / 5;
}

.content {
  grid-template-columns: 25% 75%; 
}

.content-left {
	grid-area: 2 / 1 / 2 / 1;
}

.content-right {
	grid-area: 2 / 2 / 2 / 2;
}

.content-left.text {
	padding-right: 2.0em;
}

.content-right.text {
	padding-left: 2.0em;
}

#animation_container {
	zoom: 0.39;
}

.container.wide {
	padding-left: 2em;
	padding-right: 2em;
}

.contactform {
	margin-left: -50px
}

.header-logo {
	left: 3em;
}

.header-navigation {
	padding-right: 5rem;
}

.container {
	padding-left: 5em;
	padding-right: 4em;
}

.problem-hero__questions {
	padding-top: 3rem;
	padding-bottom: 4rem;
	padding-left: 4em;
	padding-right: 0;
}

.problem-hero__photo {
	margin-top: 3em;
	margin-left: 4em;
	margin-right: 4em;
}
	
.solution-hero {
	display: grid;
	grid-template-columns: 30% 70%;
	padding-left: 0;
	padding-right: 0;
}


.solution-hero__left {
	align-self: end;
	color: var(--color-dark-text-100);
	margin: auto;
	margin-right: 0;
	width: 100%;
	padding-bottom: 2em;
	border-right:dashed 1px var(--color-dark-text-100);
	border-bottom:dashed 0px var(--color-dark-text-100);
}

.solution-hero__right {
	margin-top: 2em;
}
.solution-hero__left h3 {
	font-size: 1.3em;
	margin-bottom: 0.3em;

.content-numbered {
	margin-left: 3em;
}


}

@media only screen and (min-width: 1366px) {

.grid {
    grid-template-columns: 1fr 1fr 1fr 1fr;
}

#animation_container {
	zoom: 0.57;
}
	
.solution-hero {
	display: grid;
	grid-template-columns: 36% 64%;
	padding-left: 0;
	padding-right: 0;
}
	
.callout {
	border-right: dashed 1px #999999;
	display: inline-block;
}

}

@media only screen and (min-width: 1440px) {

}

@media only screen and (min-width: 1680px) {

}

@media only screen and (min-width: 1920px) {

}

@media only screen and (min-width: 2560px)  {

}
