/* ==========================================================================
   Colors
   ========================================================================== */

#header {
	border-bottom: none;
}

::-moz-selection {
	color: #fff;
    background: #279878;
    text-shadow: none;
}

::selection {
	color: #fff;
    background: #279878;
    text-shadow: none;
}

a, a:link, a:visited, h1, h2, h5, h6 {
	color: #279878;
}

h3, h4 {
	color: #279878;
	margin-bottom: 0;
}

h2 {
	font-weight: 800;
	text-transform: uppercase;
	margin: 0 0 15px;
}

h2.subtitle {
	color: #279878;
	font-weight: 800;
	margin: 5px 0 10px;
	padding: 0;
	font-size: 34px;
	line-height: 38px;
	position: relative;
	text-align: center;
}

.title-block {
	display: inline-block;
	position: relative;
	width: 685px;
	max-width: 100%;
	text-align: left;
}

.title-block img {
	filter: drop-shadow(0px 0px 8px rgba(43,151,154,.5));
	float: left;
	width: 140px;
	height: 140px;
	margin: 0 15px 0 0;	
}

.logo {
	margin: 0 20px 0 0;
	display: inline;
	float: left;
}


/* Subtitle Gradient Overlay */

/*
h2.subtitle::after {
	width: 100%;
	height: 38px;
	background: linear-gradient(90deg, #279878 0%,#2C989E 100%);
	display: block;
	content:" ";
	position: absolute;
	top: 0;
	left: 0;
	background-blend-mode: screen !important;
	mix-blend-mode: screen !important;
}
*/


h2.subtitle.plain {
	color: #279878;
}

h2.subtitle.plain::after {
	width: 100%;
	height: 38px;
	background: none;
	display: block;
	content:" ";
	position: absolute;
	top: 0;
	left: 0;
}


h1 {
	font-size: 42px;
	line-height: 44px;
	color: #fff;
	font-weight: 900;
	margin: 5px 0 5px;
	padding: 0px 0 0;
	text-align: left;
	text-transform: uppercase;
}

a:hover {
	color: #000;
	text-decoration: underline;
	text-decoration-color:rgba(39, 152, 120, 0.5);
	text-decoration-thickness: 2px;
}

/*
.smaller {
	color: #859398;
}
*/


/* ==========================================================================
   Splash Section
   ========================================================================== */

.section.splash {
	background: #D3EADC;
	background: #279878;
	overflow: hidden;
	color: #fff;
	text-align: center;
	padding-top: 60px;
	background: linear-gradient(-45deg, #90CCA8 0%, #96CCCF 100%); padding-top: 0;
}

.section.splash .content {
	padding: 60px 15px 30px;
}

.section.splash h1 { 
	padding: 22px 0 0;
	font-size: 68px;
	clear: none;
	text-align: left;
	color: #279878;
}

.section.splash h2 { 
	text-align: left;
	font-size: 40px;
	line-height: 48px;
	margin: 0px 0 0px;
	font-weight: 300;
	color: #fff;
	text-transform: none;
}

.section.splash p {
	font-size: 18px;
	line-height: 26px;
	font-weight: 400;
}

.icon-soundsource {
	width: 100%;
	height: 200px;
	float: left;
	margin: 0 10px 0 0;
	background: url('../../global/images/icons/256/soundsource@2x.png') no-repeat bottom left;
	background-size: contain;
}

.icon-soundsource-small {
	width: 96px;
	height: 96px;
	float: left;
	margin: 0 10px 10px 0;
	background: url('../../global/images/icons/96/soundsource@2x.png') no-repeat center center;
	background-size: contain;
}

.title-soundsource {
	width: 250px;
	height: 44px;
	float: left;
	margin: 12px 10px 0 0;
	background: url('../images/soundsource-title@2x.png') no-repeat top left;
	background-size: contain;
}

.trademark {
	opacity: 0.75;
	right: 0px;
	top: 0;
	font-size: 30px;
	position: relative;
}


.section.splash .splash-hero .screenshot {
	background: url('../images/soundsource-splash.jpg') no-repeat center center;
	width: 100%;
	margin: 5px 0 30px;
	background-size: contain;
}

@media (-webkit-min-device-pixel-ratio: 1.25), (min-resolution: 120dpi){ 
    .section.splash .splash-hero .screenshot {
		background: url('../images/soundsource-splash@2x.jpg') no-repeat center center;
		background-size: contain;
	}
}

/*
Mobile Media Queries

@media all and (max-width: 769px) { 
	.section.splash .splash-hero .screenshot {
		height: 250px;
		margin: 0 0 10px;
	}
}
*/

video {
	width: 558px;
	max-width: 100%;
}

a.action-small, a.action-large {
	color: #fff;
}

.action-small.purchase, .action-large.purchase {
	background: url('../../global/images/siteimages/icon-basket.png') no-repeat 22px center, #279878;
	background-size: 24px 24px;
	font-weight: 600;
	color: #fff;
	position: relative;
}

.action-small .basket-handle-left, .action-large .basket-handle-left {
	position: absolute;
	display: inline-block;
	left: 28px;
	top: 12px;
	height: 10px;
	width: 2px;
	border-radius: 0px;
	background: #fff;
	
	-ms-transform: rotate(-20deg); /* IE 9 */
    -webkit-transform: rotate(-20deg); /* Chrome, Safari, Opera */
    transform: rotate(-20deg);
    
    -webkit-transition: all 300ms ease;
    -moz-transition: all 300ms ease;
    -o-transition: all 300ms ease;
    transition: all 300ms ease;
    
    transform-origin: bottom center;
}

.action-small .basket-handle-right, .action-large .basket-handle-right {
	position: absolute;
	display: inline-block;
	left: 38px;
	top: 12px;
	height: 10px;
	width: 2px;
	border-radius: 0px;
	background: #fff;
	
	-ms-transform: rotate(20deg); /* IE 9 */
    -webkit-transform: rotate(20deg); /* Chrome, Safari, Opera */
    transform: rotate(20deg);
    
    -webkit-transition: all 300ms ease;
    -moz-transition: all 300ms ease;
    -o-transition: all 300ms ease;
    transition: all 300ms ease;
    
    transform-origin: bottom center;
}

/* Rotate Left Handle on Hover */
.action-small:hover .basket-handle-left, .action-large:hover .basket-handle-left {	
	-ms-transform: rotate(20deg); /* IE 9 */
    -webkit-transform: rotate(20deg); /* Chrome, Safari, Opera */
    transform: rotate(20deg);
    
    -webkit-transition: all 300ms ease;
    -moz-transition: all 300ms ease;
    -o-transition: all 300ms ease;
    transition: all 300ms ease;
}

/* Rotate Left Handle on Hover */
.action-small:hover .basket-handle-right, .action-large:hover .basket-handle-right {
	-ms-transform: rotate(-20deg); /* IE 9 */
    -webkit-transform: rotate(-20deg); /* Chrome, Safari, Opera */
    transform: rotate(-20deg);
    
    -webkit-transition: all 300ms ease;
    -moz-transition: all 300ms ease;
    -o-transition: all 300ms ease;
    transition: all 300ms ease;	
}

	.action-small.purchase:hover, .action-large.purchase:hover {
		background: url('../../global/images/siteimages/icon-basket.png') no-repeat 22px center, #495b5b;
		background-size: 24px 24px;
		color: #fff;
	}

@media (-webkit-min-device-pixel-ratio: 1.25), (min-resolution: 120dpi){ 
    .action-small.purchase, .action-large.purchase {
		background: url('../../global/images/siteimages/icon-basket@2x.png') no-repeat 22px center, #279878;
		background-size: 24px 24px;
	}


	
	.action-small.purchase:hover, .action-large.purchase:hover {
		background: url('../../global/images/siteimages/icon-basket@2x.png') no-repeat 22px center, #113C3F;
		background-size: 24px 24px;
	}
}

/* Download Button */

.action-small.download, .action-large.download {
	background: url('../../global/images/siteimages/icon-download-small.png') no-repeat 20px 15px, url('../../global/images/siteimages/icon-download-small-stem.png') no-repeat 20px 15px, #279878;
	background-size: 16px 20px;
	color: #fff;
	padding-left: 25px;
	position: relative;
	font-weight: 600;
}

.action-small.download:hover, .action-large.download:hover {
	background: url('../../global/images/siteimages/icon-download-small.png') no-repeat 20px 20px, url('../../global/images/siteimages/icon-download-small-stem.png') no-repeat 20px 15px, #113C3F;
	background-size: 16px 20px;
	color: #fff;
	-webkit-transition: all 300ms ease;
    -moz-transition: all 300ms ease;
    -o-transition: all 300ms ease;
    transition: all 300ms ease;	
}

@media (-webkit-min-device-pixel-ratio: 1.25), (min-resolution: 120dpi){ 
	.action-small.download, .action-large.download {
		background: url('../../global/images/siteimages/icon-download-small@2x.png') no-repeat 20px 15px, url('../../global/images/siteimages/icon-download-small-stem@2x.png') no-repeat 20px 15px, #279878;
		background-size: 16px 20px;
	}
	
	.action-small.download:hover, .action-large.download:hover {
		background: url('../../global/images/siteimages/icon-download-small@2x.png') no-repeat 20px 20px, url('../../global/images/siteimages/icon-download-small-stem@2x.png') no-repeat 20px 15px, #113C3F;
		background-size: 16px 20px;
	}
}

/* ==========================================================================
   Tour Section
   ========================================================================== */

#tour-full {
	position: relative;
}

/* Tour Overlay default/invisible state */
.tour-overlay {
	position: absolute;
	top: 0;
	left: 0;
	opacity: 0;
	transform: translate(0,0) scale(1,1);
	pointer-events: none !important;
	
	-webkit-transition: all 200ms ease-in;
    -moz-transition: all 200ms ease-in;
    -o-transition: all 200ms ease-in;
    transition: all 200ms ease-in;
}

/* Make Tour Overlay Visible */
.tour-overlay.visible {
	opacity: 1;
	transform: translate(0,0) scale(1,1);
	
	-webkit-transition: all 200ms ease-out;
    -moz-transition: all 200ms ease-out;
    -o-transition: all 200ms ease-out;
    transition: all 200ms ease-out;
}

.tour-overlay .tour-description {
	position: absolute;
	background: #279878;
	background-image: linear-gradient(#219850, #2C989E);
	border-radius: 12px;
	width: 340px;
	padding: 5px 20px;
	bottom: 20px;
	left: 180px;
}

.tour-overlay .tour-description h4 {
	color: #fff;
}

.tour-overlay .tour-description p {
	color: #fff;
	font-size: 16px;
	line-height: 20px;
}


/* Hint Overlay */
.hint-overlay #hint-image {
	position: absolute;
	top: 0;
	left: 0;
	opacity: 1;
	transform: translate(0,0) scale(1,1);
	pointer-events: none !important;
	
	-webkit-transition: all 300ms ease;
    -moz-transition: all 300ms ease;
    -o-transition: all 300ms ease;
    transition: all 300ms ease;
    
    animation: hint 2s infinite;
}

@keyframes hint {
  0%   	{ opacity: 0.5; }
  50% 	{ opacity: 1; }
  100%   { opacity: 0.5; }
}

#tour-full:hover .hint-overlay {
	opacity: 0;
	
	-webkit-transition: all 300ms ease;
    -moz-transition: all 300ms ease;
    -o-transition: all 300ms ease;
    transition: all 300ms ease;
}


/* Hover Zones */
.activation-zone {
	background: transparent;
	position: absolute;
	opacity: 0;
	
/*
	background: pink;
	opacity: 0.25;
*/

}

#activation-apps {
	width: 200px;
	height: 140px;
	top: 190px;
	left: 0;
}

#activation-boost {
	width: 50px;
	height: 280px;
	top: 50px;
	left: 400px;
}

#activation-fx {
	width: 700px;
	height: 200px;
	top: 330px;
	left: 0px;
}

#activation-outputs {
	width: 250px;
	height: 280px;
	top: 50px;
	left: 450px;
}

#activation-system {
	width: 200px;
	height: 140px;
	top: 50px;
	left: 0;
}

#activation-toolbar {
	width: 700px;
	height: 50px;
	top: 0px;
	left: 0px;
}

#activation-volume {
	width: 200px;
	height: 280px;
	top: 50px;
	left: 200px;
}

#tap-message, #hover-message {
	padding: 10px 30px;
	border-radius: 30px;
	background: linear-gradient(-45deg, #279878 0%,#2C989E 100%);
	color: #fff;
	width: auto;
	display: inline-block;
	margin: 0 auto;
}

#tap-message {
	display: none;
}

/* Disable tour for devices without hover */

@media (hover: none) {
	#hover-message {
		display: none;
	}
	
	#tap-message {
		display: block;
	}
}



/* ==========================================================================
   Secondary Features Section
   ========================================================================== */

.section.features-secondary {
	background: #fff;
	overflow: hidden;
	text-align: left;
}

.column.feature {
	background: url('../images/soundsource-feature-star.svg') no-repeat 15px 0px;
	background-size: 25px 25px;
}

.new-badge{
	border-radius: 6px;
	color: #fff;
	background: #279878;
	padding: 3px 3px;
	margin: 0 5px 0 0;
	font-size: 10px;
	line-height: 13px;
	display: inline-block;
	text-align: center;
	float: left;
	font-weight: 600;
}

.new {
	color: #37bfe7;
}

.column .feature-description {
	padding-left: 40px;
}

.column.new {
	color: #000;
	padding: 0 0 0 55px;
}

.column.new:before {
	content: 'New';
	float: left;
}

.feature-icon-container {
	text-align: center;
	margin: 30px 0 5px;
}

.feature-large h3 {
	margin: 20px 0 10px;
	font-size: 30px;
	line-height: 34px;
}

.section.features-secondary p {
	margin-bottom: 45px;
}

/* ==========================================================================
   Use Cases Section
   ========================================================================== */

.section.use-cases {
		background: #D3EADC;
		text-align: left;
	}

/* ==========================================================================
   Actions Section
   ========================================================================== */
   
   .section.actions {
		background: #D3EADC;
		background: linear-gradient(-45deg, #D2EADC 0%,#D5EAEB 100%);
		text-align: left;
	}
	
	.section.highlight {
		background: #E4F2EE;
	}
	
	.section.actions .icon-container {
		float: left;
		margin: 0 0 20px 0;
	}
	
	.section.actions .icon-container img {
		width: 64px;
		height: 64px;
		max-width: 100%;
		float: left;
		margin-right: 15px;
	}
	
	.section.actions h2 {
		position: relative;
		font-size: 32px;
		line-height: 36px;
		font-weight: 800;
		margin: 15px 0 15px;
	}
	
	.release-notes img {
		-webkit-transition: all 300ms ease;
		-moz-transition: all 300ms ease;
		-o-transition: all 300ms ease;
		transition: all 300ms ease;
	}
	
	.release-notes:hover img {
		filter: brightness(0.1);
		-webkit-transition: all 100ms ease;
		-moz-transition: all 100ms ease;
		-o-transition: all 100ms ease;
		transition: all 100ms ease;
	}
	
	/* Dual Index */
	
	.dual .details-columns { 
		grid-template-columns: 1fr 2fr;
	}
	
	.dual table {
		margin: 0 auto;
	}
	
	.dual table tr, .dual table td  {
		font-size: 14px;
		line-height: 20px;
		padding: 0 3px;
		margin: 0;
		text-align: right;
	}
	
	@media (max-width: 1000px) {
			.dual .actions-icon {
				  display: block;
			}
	}
	  
	  @media (max-width: 880px) {
			.dual table tr, .dual table td  {
				font-size: 12px;
				line-height: 16px;
			}
			
			.dual .details-column strong {
				font-size: 12px;
				line-height: 16px;
			}
			
			.dual table tr td {
				padding-bottom: 2px;
				margin-bottom: 2px;
			}
			
			.dual table {
				margin-bottom: 15px;
			}
		}
	  
		  @media (max-width: 780px) {
			.dual .actions-icon {
				display: none;
			}
			
			.dual .details-columns { 
				grid-template-columns: 1fr;
			}
			
			.dual table tr td {
				padding-bottom: 2px;
				margin-bottom: 2px;
			}
		}
		
	@media (max-width: 300px) {
		.dual table tr, .dual table td  {
			font-size: 11px;
			line-height: 12px;
		}
		
		.dual .details-column strong {
			font-size: 11px;
			line-height: 12px;
		}
	}
	
/* ==========================================================================
   Accolades Section
   ========================================================================== */
   
   .section.accolades {
		background: #279878;
		color: #fff;
	}
	
	.section.accolades h2 {
		color: #fff;
	}
	
	.section.accolades a {
		color: #fff;
	}
	
	.quotes-container {
		height: 300px;
	}
	
/* ==========================================================================
   Buy Page
   ========================================================================== */

#title h1 {
	color: #333;
	margin-bottom: 0;
	padding-top: 0;
	margin-top: 0;
	font-weight: 700;
}

#title h2 {
	font-size: 22px;
	font-weight: 300;
	color: #279878;
	text-transform: none;
}

#title h2 img {
	margin-bottom: 4px;
}

a.storeButton, a.storeButton:link, a.storeButton:visited {
	color: #fff;
	background: #279878;
}

a.storeButton:hover {
	color: #fff;
	background: #223940;
}

.notice {
	color: #279878;
}

.notice strong {
	font-weight: 500;
}

a.cart-header-link {
	color: #279878;
	
	-webkit-transition: all 300ms ease;
	-moz-transition: all 300ms ease;
	-o-transition: all 300ms ease;
	transition: all 300ms ease;
}

a.cart-header-link:hover {
	color: #000;
	
	-webkit-transition: all 300ms ease;
	-moz-transition: all 300ms ease;
	-o-transition: all 300ms ease;
	transition: all 300ms ease;
}

.cart-header-link img {
	-webkit-transition: all 300ms ease;
	-moz-transition: all 300ms ease;
	-o-transition: all 300ms ease;
	transition: all 300ms ease;
}

.cart-header-link:hover img {
	-webkit-filter: brightness(0.1);
	filter: brightness(0.1);
	
	-webkit-transition: all 300ms ease;
	-moz-transition: all 300ms ease;
	-o-transition: all 300ms ease;
	transition: all 300ms ease;
}

.store-block-big {
	background: #D3EADC;
	background: linear-gradient(-45deg, #D2EADC 0%,#D5EAEB 100%);
}

.store-box:has(h4:target), .store-box:target {
	box-shadow: 0 0 20px 5px #279878;
}

 /* ==========================================================================
   What's New Page
   ========================================================================== */

.section.whatsnew, .section.accolades {
	background: #279878;
	background: linear-gradient(-45deg, #279878 0%,#2C989E 100%);
	background: #279878;
}

.section.whatsnew p {
	color: #fff;
	font-weight: 300;
	font-size: 20px;
	line-height: 27px;
	margin-top: 30px;
	text-align: left;
}

.section.splash .main-page-link {
	background-color: #279878;
	color: #fff;
	position: absolute;
	top: 0;
	right: 0px;
	border-bottom-left-radius: 12px;
	border-bottom-right-radius: 12px;
	padding: 6px 15px 6px;
	margin: 0 0 0;
	font-weight: 400;
	text-align: center;
	width: 450px;
	font-size: 16px !important;
	line-height: 20px;
}

.section.splash .main-page-link:hover {
	background-color: #113C3F;
	color: #fff;
}

.section.ss5whatsnew .main-page-link {
	background-color: rgba(0,0,0,0.2);
	color: #fff;
	position: absolute;
	top: 0;
	right: 0px;
	border-bottom-left-radius: 12px;
	border-bottom-right-radius: 12px;
	padding: 6px 15px 6px;
	margin: 0 0 0;
	font-weight: 400;
	font-size: 18px;
	width: 420px;
	text-align: center;
}

.section.ss5whatsnew .main-page-link:hover {
	background-color: rgba(0,0,0,0.4);
	color: #fff;
}

.section.ss5whatsnew .action-small.purchase, .section.ss5whatsnew .action-small.download {
	background-color: rgba(0,0,0,0.2);
}

.section.ss5whatsnew .action-small.purchase:hover, .section.ss5whatsnew .action-small.download:hover {
	background-color: rgba(0,0,0,0.4);
}


.section.whatsnew .action-small.purchase, .section.whatsnew .action-small.download {
	background-color: #279878;
}

.section.whatsnew .action-small.purchase:hover, .section.whatsnew .action-small.download:hover {
	background-color: #2B979A;
}

.whatsnew-hero {
	width: 435px;
	margin: 0 auto 15px;
	border-radius: 10px;
	box-shadow: 0 0 1px 1px #C3E1D8;
}

.note {
	background: #E4F2EE;
	background: linear-gradient(-45deg, #D2EADC 0%,#D5EAEB 100%);
	padding: 10px 15px 5px;
}

.section.ss5whatsnew h1.whatsnew-title {
	color: #fff;
	position: relative;
	font-size: 48px;
	line-height: 48px;
	font-weight: 900;
	margin: 0px 0 0px;
	padding: 0;
	text-transform: uppercase;	
	text-align: center;
}

.section.ss5whatsnew p {
	font-size: 18px;
	line-height: 26px;
	text-align: left;
}

 /* ==========================================================================
   Mobile Styles
   ========================================================================== */
	
@media all and (max-width: 931px) {
	.section.splash {
		text-align: center;
	}
	
	.section.splash h1 {
		font-size: 36px !important;
		line-height: 40px !important;
		padding: 0 !important;
		margin: 10px 0 0 !important;
	}
	
	.title-block {
		text-align: center;
	}
	
	.title-block img {
		float: none;
		text-align: center;
		margin: 0 auto;
		display: inline;
		width: 160px;
		height: 160px;
	}
	
	.logo {
		margin: 0 auto 0;
		display: block;
		float: none;
	}
	
	.trademark {
		opacity: 0.75;
		float: none;
		right: 0px;
		top: 2px;
		font-size: 20px;
	}
	
	#lightbox {
		display: none !important;
	}
	
	h1, h2, .section.splash h2, .section.whatsnew h1 {
		text-align: center !important;
	}
	
	.section.splash h2 {
		font-size: 26px !important;
		line-height: 30px !important;
	}
	
	.section.splash .content {
		padding-top: 30px;
	}
	
	.feature-large h3 {
		text-align: center;
		margin: 0;
		font-size: 24px;
	}
	
	.feature-large .content, .feature-large p {
		margin: 0;
	}
	
	.section.splash .main-page-link {
		width: auto;
		right: 15px;
	}
	
	.feature-icon-container {
		margin: 0 0 5px;
	}
	
	.section.actions .icon-container {
		float: none;
		display: block;
		margin: 0 0 20px 0;
		text-align: center;
	}
	
	.section.actions .icon-container img {
		display: none;
	}
	
	.section.actions h2 {
		margin-top: 15px;
		line-height: 40px;
		font-size: 36px;
	}
	
	.tour-description {
		padding: 15px 0 0;
	}
	
	.section.whatsnew h1.whatsnew-title {
		font-size: 34px;
		line-height: 38px;
	}
	
	h2.subtitle {
		font-size: 33px !important;
		line-height: 36px !important;
		margin-bottom: 20px;
	}
	
	#hover-message, #tap-message {
		display: none;
	}
}

@media all and (max-width: 400px) { 
	
	h1 {
		font-size: 34px;
		line-height: 40px;
		margin: 5px 0 5px;
		padding: 0px 0 0;
		text-align: center;
	}
	
	.section.splash h2 {

		font-size: 25px;
		line-height: 28px;
		text-align: center;
	}
	
	.section.whatsnew h1 {
		font-size: 28px;
	}

}

@media all and (max-width: 350px) { 
	
	.section.actions h2 {

		line-height: 38px;
		font-size: 34px;

	}
	
	.section.ss5whatsnew .whatsnew-title {
		font-size: 32px !important;
		line-height: 32px !important;
	}
	
	.section.ss5whatsnew .main-page-link {
		display: none;
	}
}

@media all and (max-width: 800px) { 
	.columns.three {
		grid-template-columns: 1fr 1fr !important;
	}
}

@media all and (max-width: 450px) { 
	.columns.three {
		grid-template-columns: 1fr !important;
	}
}

/* ==========================================================================
   Dark Mode Styles
   ========================================================================== */
@media (prefers-color-scheme: dark) {
	a, a:link, a:visited, h1, h2, h5, h6 {
		color: #40bd9a;
	}
	
	h3, h4, .section.splash h1 {
		color: #40bd9a;
	}
	
	h2.subtitle {
		color: #40bd9a;
	}
	
	.features-primary h2 {
		color: #279878;
	}
	
	.dark-modal .section.splash,
	.dark-modal .section.actions {
		background: rgba(76, 150, 122, 0.2);
	}
	
	.dark-modal .section.features-secondary {
		background: none;
	}
	
	.dark-modal .store-block-big {
		background: rgba(76, 150, 122, 0.2);
	}
}
