/*

csa-expert.ru

PAGE ELEMENTS - CSS
03/14/2026

*/


/* Element - Hero Section */

.sec--hero {
	background-color: #fff;
}
.cmp--hero-top-back {
	position: absolute;
	display: block;
	width: 100%;
	height: 100%;
	top: 0px;
	left: 0px;				
}
.cmp--hero-top-back > .bg {
	position: absolute;
	display: block;
	width: 100%;
	height: 100%;
	top: 0px;
	left: 0px;				
}
.cmp--hero-top-back > .bg > .item {
	position: absolute;
	display: block;
	width: 100%;
	height: 100%;
	top: 0px;
	left: 0px;
	background-image: url(/app/static/hp--hero-bgc.jpg);
	background-size: cover;
	background-position: center bottom;
	opacity: .15;
	mask-image: radial-gradient(#fff 50%, transparent 70%);				
}
.cmp--hero-top-back > .bg > .areas {}
.cmp--hero-top-back > .bg > .areas > .vign {
    position: absolute;
    bottom: 200px;
    left: 58%;
    width: 400px;
    height: 400px;
    background: #81b1ca;
    border-radius: 300px;
    filter: blur(100px);				
}
.cmp--hero-top-back > .bg > .portrait {
	position: absolute;
	display: block;
	width: 100%;
	height: 100%;
}
.cmp--hero-top-back > .bg > .portrait > .container {
    height: 100%;				
}
.cmp--hero-top-back > .bg > .portrait > .container > img {
	position: relative;
	display: block;
	height: calc(100% - 40px);
	margin: 0px;
	margin-left: auto;
	margin-top: 40px;
	padding: 0px;
	mask-image: linear-gradient(180deg, #fff 70%, transparent 98%);					
}

.cmp--hero-top {
	position: relative;
	display: block;
	height: 800px;				
}
.cmp--hero-top > .wrapper {
	position: absolute;
	display: block;
	width: 100%;
	height: 100%;
	top: 0px;
	left: 0px;
}
.cmp--hero-top > .wrapper > .bg {
    position: absolute;
    display: block;
    width: 100%;
    height: 100%;
    top: 0px;
    left: 0px;				
}
.cmp--hero-top > .wrapper > .bg > .portrait {
    height: calc(100% - 40px);
	position: relative;
	display: block;
	margin: 0px;
	margin-left: auto;
	margin-top: 40px;
	padding: 0px;
	mask-image: linear-gradient(180deg, #fff 70%, transparent 98%);				
}

.cmp--hero-top > .wrapper > .parts {
	position: relative;
	display: flex;
	flex-flow: row wrap;
	justify-content: space-between;
	height: 750px;
	width:100%;
}
.cmp--hero-top > .wrapper > .parts > .top {
	margin-top: 8%;
	flex: 0 0 100%;				
}
.cmp--hero-top > .wrapper > .parts > .top > .wrapper {
	position: relative;
	display: flex;
	flex-flow: row wrap;
}
.cmp--hero-top > .wrapper > .parts > .top > .wrapper > .l {
	flex: 0 0 70%;
}
.cmp--hero-top > .wrapper > .parts > .top > .wrapper > .r {
	flex: 0 0 30%;				
}			
.cmp--hero-top .hero-heading {
	width: 100%;
}
.cmp--hero-top .hero-subheading {
	padding: .5em 0em;
    border-radius: 6px;
    margin: .5em 0em 1em;
    font-size: 1.1em;
}
.cmp--hero-top .hero-heading > h1 > span {
	background: -webkit-linear-gradient(218deg, #5a0006, #ff0000);
	-webkit-background-clip: text;
	-webkit-text-fill-color: transparent;				
}
.cmp--hero-top .hero-heading > h1 {
	font-size: 42pt;
	line-height: 46pt;				
}

.cmp--hero-top > .wrapper > .parts > .bottom {
	flex: 0 0 100%;
}
.cmp--hero-top > .wrapper > .parts > .bottom > .wrapper {}
.cmp--hero-top .hero--howto {
	position: relative;
	display: flex;
	flex-flow: row wrap;
	width: 70%;
}
.cmp--hero-top .hero--howto > .item {
	flex: 0 0 calc(33.3333% - 8px);
}
.cmp--hero-top .hero--howto > .item:not(:first-child) {
	margin-left: 12px;
}
.cmp--hero-top .hero--howto > .item > .wrapper {
	position: relative;
	display: block;
	background: linear-gradient(45deg, #33547c, #1f2e46);
	padding: 40px 80px 40px 40px;
	color: #fff;
	border-radius: 8px;
}
.cmp--hero-top .hero--howto > .item > .wrapper > div {
	position: absolute;
	display: block;
	right: 20px;
	top: -35px;
	font-size: 80pt;
	font-weight: 600;
	background: -webkit-linear-gradient(218deg, #ffbae4, #ff0000);
	-webkit-background-clip: text;
	-webkit-text-fill-color: transparent;
}
.cmp--hero-top .hero--howto > .item > .wrapper > h3 {
	margin-top: 0px;
	font-weight: 300;
	font-size: 18pt;				
}
.cmp--hero-top .hero--howto > .item > .wrapper > p {
	margin: 0px;
    font-weight: 200;
    line-height: 17pt;
}
.cmp--hero-top .hero--features {
	position: relative;
	display: flex;
	flex-flow: row wrap;
	align-items: center;
	gap: 10px;
	margin-top: 20px;
	font-weight: 600;
	color: #fff;
	font-size: 10pt;
}			
.cmp--hero-top .hero--features > div {
	padding: 6px 20px;
	background: #fefff9;
	border-radius: 30px;
	color: #5a5a5a;
	border: 1px solid #dcdcdc;
}			
.cmp--hero-top .hero--cta {
    position: relative;
    display: flex;
    flex-flow: row wrap;
    align-items: center;
    margin-top: 1em
}
.cmp--hero-top .hero--cta > .button-wrapper {
	margin: 20px 0px 0px;
	flex: 0 0 100%;
}
.cmp--hero-top .hero--cta > .button-wrapper > a {
	width: 280px;
	border-radius: 6px;
}

@media only screen and (min-width: 320px) and (max-width: 360px) {
	.cmp--hero-top > .wrapper > .parts {

	}
}
@media only screen and (min-width: 320px) and (max-width: 460px) {
	.cmp--hero-top-back {
		height: 50%;
		overflow-x: hidden;
	}
	.cmp--hero-top-back > .bg {
		top: 70px;
		left: 0px;
	}
	.cmp--hero-top-back > .bg > .portrait > .container > img {
		height: 60%;
		margin-top: 246px;
		margin-right: auto;
	}
	.cmp--hero-top {
		height: unset;
	}
	.cmp--hero-top > .wrapper {
		height: auto;
		position: relative;
	}
	.cmp--hero-top > .wrapper > .bg {
		overflow: hidden;
	}
	.cmp--hero-top > .wrapper > .bg > .portrait {
		height: 60%;
	}
	.cmp--hero-top > .wrapper > .parts {
		flex-flow: row wrap;
		height: unset;
	}
	.cmp--hero-top > .wrapper > .parts > .top {
		margin-top: 80px;
		flex: 0 0 100%;
	}
	.cmp--hero-top > .wrapper > .parts > .top > .wrapper {}
	.cmp--hero-top > .wrapper > .parts > .top > .wrapper > .l {
		flex: 0 0 100%;
	}
	.cmp--hero-top .hero-heading > h1 {
		font-size: 24pt;
		line-height: 26pt;
		font-weight: 700;
	}
	.cmp--hero-top > .wrapper > .parts > .top > .wrapper > .r {
		flex: 0 0 100%;
	}
	.cmp--hero-top > .wrapper > .parts > .bottom {
		flex: 0 0 100%;
		margin-top: 350px;
	}

	.cmp--hero-top .hero--howto {
		width: 100%;
	}
	.cmp--hero-top .hero--howto > .item {
		flex: 0 0 100%;
	}
	.cmp--hero-top .hero--howto > .item:not(:first-child) {
		margin-left: 0px;
	}
}
@media only screen and (min-width: 421px) and (max-width: 560px) {}
@media only screen and (min-width: 561px) and (max-width: 959px) {}
@media only screen and (min-width: 960px) and (max-width: 1159px) {}
@media only screen and (min-width: 1160px) and (max-width: 1280px) {}
@media only screen and (min-width: 1281px) and (max-width: 1599px) {

	.cmp--hero-top .hero-heading > h1 {
		font-size: 38pt;
    	line-height: 40pt;	
	}
	.cmp--hero-top > .wrapper > .parts > .top {
		margin-top: 8%;
	}
	.cmp--hero-top > .wrapper > .parts > .top > .wrapper > .l {
    	flex: 0 0 65%;
	}
	.cmp--hero-top .hero--howto > .item > .wrapper {
		padding: 30px 60px 30px 30px;
	}
	.cmp--hero-top > .wrapper > .parts > .bottom {
		margin-top: 30px;
	}
	.cmp--hero-top .hero--howto > .item > .wrapper > div {
		top: -27px;
		right: 16px;
    	font-size: 60pt;
    	font-weight: 700;
	}

}
@media only screen and (min-width: 1600px) {}


/* Element - Breadcrumbs */

.cmp--breadcrumbs {}
.cmp--breadcrumbs > .wrapper {}
.cmp--breadcrumbs > .wrapper > ul {
	position: relative;
	display: flex;
	flex-flow: row wrap;
	align-items: center;
	font-size: 10pt;
}
.cmp--breadcrumbs > .wrapper > ul > li {}
.cmp--breadcrumbs > .wrapper > ul > li > a {
	user-select: none;
	color: var(--color--csa-red);
}
.cmp--breadcrumbs > .wrapper > ul > li > span {}

.cmp--breadcrumbs > .wrapper > ul > li:last-child > a {
	pointer-events: none;
	color: var(--color--text-main);
}
.cmp--breadcrumbs > .wrapper > ul > li.bca {
	position:relative;
	display: block;
	margin: 0px 10px;
}
.cmp--breadcrumbs > .wrapper > ul > li.bca > div {
	display: flex;
	flex-flow: row wrap;
	align-items: center;				
}
.cmp--breadcrumbs > .wrapper > ul > li.bca > div > span:first-child {
	position: relative;
	display: block;
	flex: 0 0 20px;
	width: 100%;
	height: 2px;
	background-color: #505050;
}
.cmp--breadcrumbs > .wrapper > ul > li.bca > div > span:last-child {
	position: relative;
	display: block;
	flex: 0 0 6px;
	height: 6px;
	transform: rotate(45deg);
	border-top: 2px solid #505050;
	border-right: 2px solid #505050;
	margin-left: -4px;
}

/* Element - Item Blocks */

/*.el--itemblocks {}
.el--itemblocks > .item {
	position: relative;
	display: block;
	border-left: 1px solid #c5c5c5;
	padding: 0em 1em;
}
.el--itemblocks > .item:before {
	content: '';
	position: absolute;
	display: block;
	width: 2px;
	height: 1.2em;
	background: red;
	left: 0px;	
}
.el--itemblocks > .item:not(:first-of-type) {
	margin-top: 1.8em;	
}
.el--itemblocks > .item .heading-wrapper.h3 {}
.el--itemblocks > .item .heading-wrapper.h3 > h3 {}
.el--itemblocks > .item .heading-wrapper.h3 > h3:before {}

.el--itemblock {}
.el--itemblock .object > .object-item {
	position: relative;
	display: block;
	border-left: 1px solid #c5c5c5;
	padding: 0em 1em;
}
.el--itemblock .object > .object-item:not(:first-of-type) {
	margin-top: 1.8em;	
}
.el--itemblock .object > .object-item:before {
	content: '';
	position: absolute;
	display: block;
	width: 2px;
	height: 1.2em;
	background: red;
	left: 0px;		
}*/



/* Element - Sequence */

.el--seq {}
.el--seq > .object {}
.el--seq > .object > .wrapper {
	background: transparent;
	border-radius: var(--border-radius-desktop);
}
.el--seq > .object > .wrapper > ul {}
.el--seq > .object > .wrapper > ul > li:not(:first-child) {
	margin-top: 0px;
}
.el--seq > .object > .wrapper > ul > li:not(:last-child):before { 
	content: '';
    display: block;
    position: absolute;
    width: 2px;
    height: 100%;
    background: #ccc;
    left: 29px;
}
.el--seq > .object > .wrapper > ul > li {
	position: relative;
	display: flex;
	flex-flow: row nowrap;
	align-items: start;
}
.el--seq > .object > .wrapper > ul > li {}
.el--seq > .object > .wrapper > ul > li > span {
	position: relative;
	display: block;
}
.el--seq > .object > .wrapper > ul > li > .c {
	margin-top: 16px;
	flex: 1 0 50px;
	margin-left: 21px;
}
.el--seq > .object > .wrapper > ul > li > .c > h4 {
	font-weight: 600;
	margin-bottom: 12px;
}
.el--seq > .object > .wrapper > ul > li:not(:last-child) > .c {
	padding-bottom: 30px;
}

.el--seq > .object > .wrapper > ul > li:not(:last-child) > .c {
	padding-bottom: 20px;
}
.el--seq.filled > .object > .wrapper > ul > li > .c {
	margin-top: 1px;
	margin-left: 38px;
}
.el--seq.filled > .object > .wrapper > ul > li > .c > p {
	margin: 0px;
}
.el--seq.filled > .object > .wrapper > ul > li:not(:last-child):before { 
	content: unset;
    display: none;
}
.el--seq.filled > .object > .wrapper > ul > li > span {
	position:relative;
	display: block;											
	flex: 0 0 24px;
	aspect-ratio: 1/1;
	background: #fff url(/app/static/check-bullet-filled.svg) center/cover no-repeat;
	margin-top: 2px;
	margin-left: 20px;
}
.el--seq.trans > .object > .wrapper > ul > li > span {
	position:relative;
	display: block;											
	flex: 0 0 60px;
	aspect-ratio: 1/1;
	background: var(--servicepage--color-obj-bg) url(/app/static/check-bullet.svg) center/cover no-repeat;
}

.el--seq.num > .object > .wrapper > ul > li > .c {
	margin-top: unset;
	margin-left: 36px;	
} 
.el--seq.num > .object > .wrapper > ul > li:not(:first-child) {
	margin-top: 15px;
}
.el--seq.num > .object > .wrapper > ul > li:not(:first-child) > .c{
	padding-top: 30px;
	border-top: 1px solid #ccc;
}
.el--seq.num > .object > .wrapper > ul > li:not(:first-child) > span {
	margin-top: 30px;
}
.el--seq.num > .object > .wrapper > ul > li:not(:last-child):before {
	content: unset;
	display: none;
}
.el--seq.num > .object > .wrapper > ul > li > span {
	display: flex;
    flex-flow: row wrap;
    align-items: center;
    justify-content: center;
    width: 30px;
    height: 30px;
    background: #ca0100;
    border-radius: 40px;
    color: #fff;
/*    margin-left: 18px;*/
}
.el--seq.num > .object > .wrapper > ul > li > span > span {
	font-size: 10pt;
	font-weight: 700;
	line-height: 12pt;											
}
.el--seq.num > .object > .wrapper > ul > li > .c {
}
.el--seq.num > .object > .wrapper > ul > li:not(:last-child) > .c {
	padding-bottom: 0px;
}
.el--seq.num > .object > .wrapper > ul > li > .c > div > p {
	margin: 20px 0px 0px;
}


@media only screen and (max-width: 519px) {
	.el--seq > .object > .wrapper > ul > li:not(:last-child):before {
		left: 16px;
	}
	.el--seq > .object > .wrapper > ul > li > .c > h4 {
		margin-top: -3px;
	}
	.el--seq.trans > .object > .wrapper > ul > li > span {
		flex: 0 0 34px;
	}
	.el--seq > .object > .wrapper > ul > li > .c {
		margin-top: 10px;
		margin-left: 10px;
	}
}
@media only screen and (min-width: 520px) and (max-width: 959px) {}
@media only screen and (min-width: 960px) and (max-width: 1279px) {}
@media only screen and (min-width: 1280px) and (max-width: 1599px) {}
@media only screen and (min-width: 1600px) {}


/* Element - General FAQ */

.el--generalfaq {}
.el--generalfaq > .object {}
.el--generalfaq > .object > .wrapper {
	background: transparent;
	border-radius: var(--border-radius-desktop);
}
.el--generalfaq ul {
	padding: 2em 0em 0em;
}
.el--generalfaq ul > li {
	width: 100%;
	margin-top: 0px!important;
}
.el--generalfaq ul > li:not(:first-child) {
	border-top: 1px solid #ccc;
}
.el--generalfaq ul > li > .q {
	position: relative;
    display: flex;
    align-items: center;
    padding: 16px 0px;
}
.el--generalfaq ul > li > .q > h4 {
	font-size: 14pt;
  	font-weight: 500;
  	flex: 1 0 80%;
}
.el--generalfaq ul > li > .q > h4 > span {
	display: block;
	max-width: 90%;
}
.el--generalfaq ul > li > .q > div {
	flex: 0 0 20px;
}
.el--generalfaq ul > li > .q > div > div {
	position:relative;
	display: block;
	width: 20px;
	height: 20px;
	border-radius: 24px;
	background-color: transparent;
	transition: .2s;
	transform: rotate(0deg);
}
.el--generalfaq ul > li > .q > div > div:before, .el--generalfaq  ul > li > .q > div > div:after {
	content: '';
	position: absolute;
	top: calc(50% - 1px);
	left: 10%;
	width:80%;
	height:2px;
	background-color: #000;	
}
.el--generalfaq ul > li > .q > div > div:after {
	transform: rotate(90deg);
}
.el--generalfaq ul > li > .a {
	overflow: hidden;
	max-height: 0px;
	transition: .4s;
	background-color: #fff;
	max-width: 100%;
	padding: 0px 40px;
	line-height:1.6em;
}
.el--generalfaq ul > li > .a > div {
}
.el--generalfaq ul > li > .a > div > p{}

.el--generalfaq ul > li.a > .q > div > div {
	transform: rotate(225deg);
}
.el--generalfaq ul > li.a > .a {
	max-height: 600px;
}


.el--generalfaq ul > li.open > .q > div > div {
	transform: rotate(225deg);
}
.el--generalfaq ul > li.open > .a {
	padding: 20px 40px;	
}




/* Element - Service Page Top Section */

.sec--pagetopper {
	overflow: hidden;
}
.sec--pagetopper.service {
	background: #00213d;
	color: #fff;
/*	color: var(--color--text-main);*/
}
.sec--pagetopper > .bg {
	position: absolute;
	display: block;
	width: 100%;
	height: 100%;
    left: 50%;
    top: 50%;
    filter: grayscale(100);
    opacity: .2;
    transform: translate(-50%, -50%);
}
.sec--pagetopper > .bg > img {
	width: 100%;
}

.sec--pagetopper .cmp--pagetopper {
	position: relative;
	display: flex;
	flex-flow: row wrap;
	padding: 100px 0px;
	align-items: center;
}
.sec--pagetopper .cmp--pagetopper > div > .wrapper{
	position: relative;
	display: block;
	max-width: 80%;		
}		
.sec--pagetopper .cmp--pagetopper > .pl > .wrapper {
	margin-left: 0px;
}
.sec--pagetopper .cmp--pagetopper > .pr > .wrapper {
	max-width: 90%;
	margin-right: 0px;
}

.sec--pagetopper .cmp--pagetopper .pageheading > .item--csa-graph-el {
	margin-bottom: 2em;
}
.sec--pagetopper .cmp--pagetopper .pageheading > h1 {
    margin: 0px;
    font-size: 2.5em;
    font-weight: 300;
    line-height: 1.2em;
}
.sec--pagetopper .cmp--pagetopper .pageheading > .subh {
	margin-top: 2em;
}
.sec--pagetopper .cmp--pagetopper .pageheading > .subh > p {}
.sec--pagetopper .cmp--pagetopper .pageheading > .subh > ul {}
.sec--pagetopper .cmp--pagetopper .pageheading > .subh > ul > li {}
.sec--pagetopper .cmp--pagetopper > div {
	flex: 0 0 50%;
}
.sec--pagetopper .cmp--pagetopper .pageheading > .wrapper-btn {
	margin-top: 2em;
	max-width: 50%;
}
.sec--pagetopper .cmp--pagetopper .pageheading > .wrapper-btn > a {

}



.sec--pagetopper .cmp--pagetopper .features {
	position: relative;
	display: flex;
	flex-flow: row wrap;
	width: 100%;
	gap: 6%;
	row-gap: 2em;
}	
.sec--pagetopper .cmp--pagetopper .features > li {
	flex: 1 0 40%;
}	
.sec--pagetopper .cmp--pagetopper .features > li > .wrapper {
	position: relative;
	display: block;
	padding: 1em 2em;
/*	border-left: 1px solid #c5c5c5;*/
	background: linear-gradient(45deg, #548097, #42586a, #344b5b, #42586a, #7b4a4b, #ae4c4c, #c23333);
    color: #fff;
    border-radius: 0px 6px;
	border-bottom: 1px solid #5a7b94;
	font-weight: 300;
}	
.sec--pagetopper .cmp--pagetopper .features > li > .wrapper:after {
	content: '';
	position: absolute;
	display: block;
	width: 2px;
	height: 20px;
	background: red;
	top: 0px;
	left: 0px;
}

.sec--pagetopper .cmp--pagetopper .example-btn {}
.sec--pagetopper .cmp--pagetopper .example-btn > a {
    height: max-content;
    position: relative;
    display: block;
    width: max-content;
    padding: .6em 1.5em;
    border: 1px solid var(--color--csa-red);
    background: #fff;
    margin: 2em 0px 0px 0px;
    color: var(--color--csa-red);
    transition: .2s;
    border-radius: 6px;
}
.sec--pagetopper .cmp--pagetopper .example-btn > a > div {
    position: relative;
    display: flex;
    flex-flow: row wrap;
}
.sec--pagetopper .cmp--pagetopper .example-btn > a > div > svg {
	flex: 0 0 30px;
	height: auto;
}
.sec--pagetopper .cmp--pagetopper .example-btn > a > div > p {
	flex: 1 0 20%;
	margin-left: 1em;
}
.sec--pagetopper .cmp--pagetopper .example-btn > a:hover {
	background: var(--color--csa-red);
	color: #fff;
}


@media only screen and (max-width: 519px) {
	.sec--pagetopper > .bg {
		overflow: hidden;
	}
	.sec--pagetopper > .bg > img {
        height: 100%;
        left: 50%;
        transform: translateX(-50%);
        display: block;
        width: auto;
	}	
	.sec--pagetopper .cmp--pagetopper > div {
		flex: 0 0 100%;
	}
	.sec--pagetopper .cmp--pagetopper > div > .wrapper {
		max-width: 100%;
	}
	.sec--pagetopper .cmp--pagetopper > .pr > .wrapper {
		max-width: 100%;
	}
	.sec--pagetopper .cmp--pagetopper .pageheading > h1 {
		font-size: 28pt;
    	line-height: 32pt;		
	}
	.sec--pagetopper .cmp--pagetopper .pageheading > .wrapper-btn {
		max-width: 100%;
	}
	.sec--pagetopper .cmp--pagetopper .pageheading > .wrapper-btn > a {
		border-radius: 4px;
	}
	.sec--pagetopper .cmp--pagetopper .features {
		row-gap: 1em;
	}
	.sec--pagetopper .cmp--pagetopper .features > li {
		flex: 0 0 100%;
	}
	.sec--pagetopper .cmp--pagetopper .features > li > .wrapper > p {
		margin: .5em 0pt;
	}
	.sec--pagetopper .cmp--pagetopper > .pr {
		margin-top: 2em;
	}
	.sec--pagetopper .cmp--pagetopper > .pr > .wrapper {}
	.sec--pagetopper .cmp--pagetopper .example-btn > a {
		margin: 2em auto;
	}
}


/* Element - CTA "Man", CTA "Onpage" */

.el--cta.man {}
.el--cta.man > a {
    position: relative;
    display: flex;
    flex-flow: row wrap;
    align-items: center;
    border-radius: 10px;
    margin: 12px 0px;
    padding: 36px 46px;
    text-decoration: none;
    background: linear-gradient(#323232, #161616) padding-box;
    border: 1px solid transparent;
    transition: all .4s;
}
.el--cta.man > a:hover {
	background: linear-gradient(#600000, #161616) padding-box;
}
.el--cta.man > a > div {
	position: relative;
	display: flex;
	flex: 0 0 33.3333%;
	flex-flow: row wrap;
	align-items: center;
}
.el--cta.man > a > img {
	position: absolute;
	display: block;									
	width: 275px;
    left: 50%;
    transform: translateX(-50%);
    bottom: 0px;
}
.el--cta.man .localtext {}
.el--cta.man .localtext > h3 {
	font-size: 2rem;
	line-height: 2rem;
	margin-top: 0rem;
	color: #fff;
	font-weight: 500;
}
.el--cta.man .localtext > p {
	font-size: 1.1rem;
	line-height: 1.7rem;
	margin: 1em 0em 0em;
	color: #fff;											
}
.el--cta.man .localtext > p > b {
	background-color: unset;
	padding: unset;
}
.el--cta.man .localbtn {}
.el--cta.man .localbtn:hover {}
.el--cta.man .localbtn:active {}

/* ---- */

.el--cta.onpage {}
.el--cta.onpage > .wrapper {
	padding: 4em;
	position: relative;
	display: flex;
	flex-flow: row wrap;
	align-items: top;
	background: #434343;
	color: #fff;	
	border-radius: 6px;
	overflow: hidden;
}
.el--cta.onpage > .wrapper > img {
	filter: grayscale(1);
    position: absolute;
    top: 0px;
    left: 0px;
    transform: translate(0%, -10%);
    z-index: 1;
    opacity: .2;
}
.el--cta.onpage > .wrapper > .pl {
	flex: 0 0 70%;
	z-index: 2;
    padding-right: 4em;
    display: flex;
    align-items: center;	
}
.el--cta.onpage > .wrapper > .pl > .heading {}
.el--cta.onpage > .wrapper > .pl > p {}
.el--cta.onpage > .wrapper > .pr {
	flex: 0 0 30%;
	z-index: 2;
}
.el--cta.onpage form > div {}
.el--cta.onpage form > div:not(:first-child) {
	margin-top: .8em;
}
.el--cta.onpage form > div > input {
	outline-color: var(--color--csa-red);
}
.el--cta.onpage form > div > label {
	font-size: 8pt;
}
.el--cta.onpage form > div > input:not([type="checkbox"]) {
	width: 100%;
	font-size: 12pt;
	padding: 1em;	
}
.el--cta.onpage form > div > input:not([type="checkbox"]):not(:first-child) {
	margin-top:.5em;
}
.el--cta.onpage form > div > input[type="checkbox"] {
	width: 18px;
	height: 18px;
}
.el--cta.onpage form > div > button {}

.el--cta.onpage form > .caption {
	display: flex;
	flex-flow: row wrap;
} 
.el--cta.onpage form > .caption > input {
	flex: 0 0 18px;
	margin: 0px;
}
.el--cta.onpage form > .caption > div {
	flex: 0 0 calc(100% - 18px - 1em);
	margin-left: 1em;
	font-size: .8em;
}
.el--cta.onpage form > .status-line {
	transition: .2s;
    margin: 0px;
    max-height: 0px;
    overflow: hidden;
    text-align: center;	
}
.el--cta.onpage form a {
	color: red;
}

@media only screen and (max-width: 519px) {
    
    .el--cta.man > a > div {
    	flex: 0 0 100%;
    }
    .el--cta.man > a > *:nth-child(3) {
    	height: 245px;
    }										    
    .el--cta.man > a > *:nth-child(4) {
    	margin-top: 40px;
    }

	.el--cta.onpage > .wrapper {
		padding: 2em;
	}
    .el--cta.onpage > .wrapper > .pl, .el--cta.onpage > .wrapper > .pr {
    	padding-right: 0px;
    	flex: 0 0 100%;
    }

}


/* Element - Why Us */

.el--whyus {
	margin-top: 0px;
}
.el--whyus > .wrapper {
	position: relative;
	display: flex;
	flex-flow: row wrap;
	overflow: hidden;
    border-radius: 6px;	
}
.el--whyus > .wrapper  > .item {
	flex: 0 0 25%;
	overflow: hidden;
}
.el--whyus > .wrapper  > .item:first-child {
	border-radius: var(--border-radius-desktop) 0px 0px var(--border-radius-desktop);
}
.el--whyus > .wrapper  > .item:last-child {
	border-radius: 0px var(--border-radius-desktop) var(--border-radius-desktop) 0px;
}
.el--whyus > .wrapper  > .item > .wrapper {
	position: relative;
	padding: 40px;
	background-color: #ececec;
	aspect-ratio: 1/1;
}
.el--whyus > .wrapper  > .item > .wrapper > .bg {
	position: absolute;
	width: 100%;
	height: 100%;
	top: 0px;
	left: 0px;
	overflow: hidden;
}
.el--whyus > .wrapper  > .item > .wrapper > .bg:before {
	content: '';
	position: absolute;
	bottom: 0px;
	left: 0px;
	width: 100%;
	height: 0%;
	transition: .5s;
	background: linear-gradient(0deg, #0000009e, transparent);
	z-index:1;
}

.el--whyus > .wrapper  > .item > .wrapper > .bg > img {
	position: absolute;
	display: block;
	width: 100%;
	height: 100%;
	top: 0px;
	left: 0px;
	filter: grayscale(1);
}
.el--whyus > .wrapper  > .item > .wrapper > .bg > .i {
	position: absolute;
	display: block;
	width: 100%;
	height: 100%;
	left: 0px;
	top: 0px;
	background-size: cover;
	background-repeat: no-repeat;
	transition: .5s;
}
.el--whyus > .wrapper  > .item > .wrapper > .bg > .d {
	position: absolute;
	display: block;
	width: 100%;
	height: 100%;
	left: 0px;
	top: 0px;
  	background-color: var(--color--dimmerbg-on);
  	transition: .5s;
}
.el--whyus > .wrapper  > .item > .wrapper > .bg > .r {
	position:absolute;
	display: block;
	top: 0px;
	right: 40px;
	transition: .2s;
	transition-delay: .1s;
}
.el--whyus > .wrapper  > .item > .wrapper > .bg > .r > div:nth-child(1) {
  position: relative;
  display: block;
  width: 30px;
  height: 0px;
  background: linear-gradient(0deg, gold, gold, gold, #b58900);
  transition: .5s;
}
.el--whyus > .wrapper  > .item > .wrapper > .bg > .r > div:nth-child(2) {
	position: relative;
	display: block;
	width: 20px;
	height: 40px;
	width: 0;
	height: 0;
	border-left: 15px solid gold;
	border-right: 15px solid gold;
	border-bottom: 0px solid transparent;
	transition: .5s;
	transition-delay: .2s;	
}
.el--whyus > .wrapper  > .item > .wrapper > .bg > .n {
	position: absolute;
	display: block;
	top: 0px;
	left: 35px;
	font-size: 140pt;
	color: rgb(255 255 255 / .15);
	font-weight: 700;
}

.el--whyus > .wrapper  > .item > .wrapper > .content {
	position: absolute;
	bottom: 40px;
	left: 40px;
	width: calc(100% - 80px);
	z-index: 2;
	border-left: 3px solid red;
	padding-left: 20px;
}
.el--whyus > .wrapper  > .item > .wrapper > .content * {
	color: #fff;
}
.el--whyus > .wrapper  > .item > .wrapper > .content > h3 {
	font-size: 20pt;
	font-weight: 300;
	line-height: 22pt;
	margin: 0px;
	padding: 0px;
}
.el--whyus > .wrapper  > .item > .wrapper > .content > p {
	margin: 24px 0px 0px 0px;
}

.cmp-whyus.small {}
.el--whyus.small > .wrapper > .item > .wrapper > .content > h3 {
	line-height: 1em;
}
.el--whyus.small > .wrapper > .item > .wrapper {
	padding: 2em;
}
.el--whyus.small > .wrapper > .item > .wrapper > .content {
	bottom: 2em;
    left: 2em;
    width: calc(100% - 4em);
}

@media (hover:hover) {

	.el--whyus > .wrapper  > .item > .wrapper > .bg > .n {
		font-size: 60pt;
		top: 20px;
		transition: .5s;
		line-height: 60pt;
	}
	.el--whyus > .wrapper  > .item:hover > .wrapper > .bg:before {
		height: 71%;
	}
	.el--whyus > .wrapper  > .item:hover > .wrapper > .bg > img {
		filter: grayscale(0);
	}
	.el--whyus > .wrapper  > .item:hover > .wrapper > .bg > .i {
		transform: scale(1.1);
	}
	.el--whyus > .wrapper  > .item:hover > .wrapper > .bg > .d {
		background-color: var(--color--dimmerbg-off); 
	}
	.el--whyus > .wrapper  > .item:hover > .wrapper > .bg > .r {
		top: -4px;
	}
	.el--whyus > .wrapper  > .item:hover > .wrapper > .bg > .r > div:nth-child(1) {
		height: 70px;
	}
	.el--whyus > .wrapper  > .item:hover > .wrapper > .bg > .r > div:nth-child(2) {
		border-bottom: 15px solid transparent;	
	}
	.el--whyus > .wrapper  > .item:hover > .wrapper > .bg > .n {
		font-size: 140pt;
		line-height: 140pt;
	}
	.el--whyus.small > .wrapper > .item:hover > .wrapper > .bg > .r > div:nth-child(1) {
        height: 40px;
    }
}	

@media only screen and (max-width: 519px) {
	.el--whyus > .wrapper  > .item {
		flex: 0 0 100%;
		overflow: hidden;
	}
	.el--whyus > .wrapper  > .item:first-child {
		border-radius: var(--border-radius-desktop) var(--border-radius-desktop) 0px 0px ;
	}
	.el--whyus > .wrapper  > .item:last-child {
		border-radius: 0px 0px var(--border-radius-desktop) var(--border-radius-desktop);
	}

	.el--whyus > .wrapper  > .item > .wrapper > .bg > .n {
		font-size: 60pt;
		top: 20px;
		transition: .5s;
		line-height: 60pt;
	}
	.el--whyus > .wrapper  > .item.active > .wrapper > .bg:before {
		height: 71%;
	}
	.el--whyus > .wrapper  > .item.active > .wrapper > .bg > img {
		filter: grayscale(0);
	}
	.el--whyus > .wrapper  > .item.active > .wrapper > .bg > .i {
		transform: scale(1.1);
	}
	.el--whyus > .wrapper  > .item.active > .wrapper > .bg > .d {
		background-color: var(--color--dimmerbg-off); 
	}
	.el--whyus > .wrapper  > .item.active > .wrapper > .bg > .r {
		top: -4px;
	}
	.el--whyus > .wrapper  > .item.active > .wrapper > .bg > .r > div:nth-child(1) {
		height: 70px;
	}
	.el--whyus > .wrapper  > .item.active > .wrapper > .bg > .r > div:nth-child(2) {
		border-bottom: 15px solid transparent;	
	}
	.el--whyus > .wrapper  > .item.active > .wrapper > .bg > .n {
		font-size: 140pt;
		line-height: 140pt;
	}	
}
@media only screen and (min-width: 520px) and (max-width: 959px) {}
@media only screen and (min-width: 960px) and (max-width: 1279px) {}
@media only screen and (min-width: 1280px) and (max-width: 1599px) {}
@media only screen and (min-width: 1600px) {}




/* Page Content */

.sec--pagecontent {}
.sec--pagecontent .pagecontent-wrapper {
	position: relative;
	display: block;
}
.sec--pagecontent .pagecontent-wrapper.has-sidepanel {
	position: relative;
	display: flex;
	flex-flow: row wrap;	
}
.sec--pagecontent .pagecontent-wrapper.has-sidepanel > div {
	position: relative;
	display: block;
}
.sec--pagecontent .pagecontent-wrapper.has-sidepanel > .pl {
	flex: 1 0 50%;
	min-width: 0;	
}
.sec--pagecontent .pagecontent-wrapper.has-sidepanel > .pr {
	flex: 0 0 320px;
	margin-left: 2%;
}

.sec--pagecontent .pagecontent-wrapper.has-sidepanel > .pr > .wrapper {
	position: sticky;
	height: 100%;
}
.sec--pagecontent .pagecontent-wrapper.has-sidepanel > .pl > .wrapper {
	position: relative;
	display: block;
	width: 100%;
}

.sec--pagecontent .heading-wrapper.h2 {
	max-width: 60%;
}
.sec--pagecontent .heading-wrapper.h2 > h2 {
	margin: 0px;
	font-size: 2.2em;
	font-weight: 300;
	line-height: 1.2em;
}
.sec--pagecontent .heading-wrapper.h2 > h2 > span.note {
	color: var(--csa--text-main);
    font-size: .6em;
    top: -8px;
    position: relative;
    margin-left: 2px;
}

.p-el > .object > .heading-wrapper.h2 {
	max-width: 70%;
}

@media only screen and (max-width: 409px) {
	.sec--pagecontent .heading-wrapper.h2 {
		max-width: 90%;
	}
	.sec--pagecontent .heading-wrapper.h2 > h2 {
		font-size: 1.8em;
		font-weight: 300;
		line-height: 1.2em;
	}
	.sec--pagecontent .pagecontent-wrapper.has-sidepanel > .pr {
		display: none;
	}
}
@media only screen and (min-width: 410px) and (max-width: 519px) {

	.sec--pagecontent .heading-wrapper.h2 {
		max-width: 90%;
	}
	.sec--pagecontent .heading-wrapper.h2 > h2 {
		font-size: 2em;
		font-weight: 300;
		line-height: 1.2em;
	}
	.sec--pagecontent .pagecontent-wrapper.has-sidepanel > .pr {
		display: none;
	}

}


/* Content elements */

.content-element {
	max-width: 100%;	
}
.content-element p {
	line-height: 1.5em;
}
.content-element p a {
	color: var(--color--csa-red);
	text-decoration: underline;
	transition: .2s;
}
.content-element p a:hover {
	opacity: .5;
}

.content-element .heading-wrapper.h2 {
	margin-bottom: 1em;
}
.content-element .heading-wrapper.h2 > .item--csa-graph-el {
	width: 24px;
	margin-bottom: 20px;
}

.content-element .object .heading-wrapper.lgrad.h3 {
	position: relative;
	width: auto;
}
.content-element .heading-wrapper.lgrad.h3 > h3 {
	font-size: 14pt;
    font-weight: 200;
    background: var(--color--csa-red);
    display: inline-block;
    position: relative;
    line-height: 28pt;
    color: #fff;
    padding-right: .5em;
    margin: 0px;
}
.content-element .object .heading-wrapper.lgrad.h3 > h3:before {
	content: '';
    position: absolute;
    display: block;
    height: 100%;
	width: 74px;
	background: linear-gradient(90deg, red, var(--color--csa-red));
	left: -74px;
	top: 0px;
}

.content-element .object {
    padding: 3em 4em;
    background-color: var(--servicepage--color-obj-bg);
    border-radius: 6px;		
}
.content-element .object.bg--lightred {
	background: #fcf0f0;
}
.content-element .object.green {
/*	background: #dff7e1;*/
}

.content-element .object > .item {}

.content-element picture, .content-element img {
	position: relative;
	display: block;
	width: 100%;
	margin: auto;
}

@media only screen and (max-width: 519px) {
	.content-element .heading-wrapper.h3 > h3 {
		font-size: 12pt;
	}
	.content-element .heading-wrapper.lgrad.h3 > h3 {
		line-height: 1em;
		padding: .5em;
	}

}


.el--hp-workwith, .el--hp-workwith * {
	color: #4e4e4e;
}
.el--hp-workwith > .wrapper {
	display: flex;
	flex-flow: row wrap;
}
.el--hp-workwith > .wrapper > .pl {
	flex: 0 0 25%;
}
.el--hp-workwith > .wrapper > .pl > .heading-wrapper { 
	width: 80%;
}
.el--hp-workwith > .wrapper > .pr {
	flex: 0 0 75%;
	display: flex;
	flex-flow: row wrap;
}
.el--hp-workwith > .wrapper > .pr > div {
	position: relative;
	flex: 0 0 25%;
	aspect-ratio: 1;
}
.el--hp-workwith > .wrapper > .pr > div > .wrapper {
	position: absolute;
    width: 100%;
    height: 100%;
    border-left: 1px solid #e3e3e3;
    overflow: hidden;
}
.el--hp-workwith > .wrapper > .pr > div > .wrapper > span {
	position: absolute;
	left: 20px;
	bottom: 0px;
	font-size: 14pt;
	font-weight: 400;
}
.el--hp-workwith > .wrapper > .pr > div > .wrapper > div {
	position: absolute;
	left: 20px;
	font-size: 10pt;
	width: calc(100% - 40px);
	line-height: 14pt;
}

.el--hp-workwith > .wrapper > .pr > div > .wrapper:after {
	content: '';
	position: absolute;
	top: 0px;
	left: 0px;
	width: 2px;
	height: 34px;
	display: block;
	transition: .2s;
	background-color: red;
}


@media only screen and (max-width: 520px) {

	.sec--hp-workwith {
		overflow: hidden;
	}
	.sec--hp-workwith > .bgl {
		display: none;
	}

	.sec--services {
		padding: 20px 0px;
	}


	.el--hp-workwith > .wrapper > .pl, .el--hp-workwith > .wrapper > .pr {
		flex: 0 0 100%;
	}
	.el--hp-workwith > .wrapper > .pr {
		margin-top: 40px;
	}
	.el--hp-workwith > .wrapper > .pr > div {
		flex: 0 0 100%;
		aspect-ratio: unset;
		height: max-content;
	}
	.el--hp-workwith > .wrapper > .pr > div:not(:first-child) {
		border-top: 1px solid #e3e3e3;
		padding-top: 40px;
		margin-top: 40px;
	}
	.el--hp-workwith > .wrapper > .pr > div > .wrapper {
		position: relative;
		display: flex;
		overflow: unset;
		border-left: 0px;
		flex-flow: row wrap;
	}
	.el--hp-workwith > .wrapper > .pr > div > .wrapper > span {
		position: relative;
		left: unset;
		font-size: 20pt;
		margin-left: 20px;
	}
	.el--hp-workwith > .wrapper > .pr > div > .wrapper > div {
        position: relative;
        left: unset;
        margin-top: 24px;
        font-size: 11pt;
        font-weight: 300;
        line-height: 18pt;
	}
	.el--hp-workwith > .wrapper > .pr > div > .wrapper:after {

	}

}


/* Homepage - Element + Section Reviews */
.sec--hp-reviews {
	padding: 100px 0px;
	background-color: #fff;
}
.sec--hp-reviews > .bg {
	position: absolute;
	display: block;
	width: 100%;
	height: 100%;
}
.sec--hp-reviews > .bg > .im {
    position: absolute;
    display: block;
    width: 100%;
    height: 100%;
    top: 0px;
    left: 0px;
    background-image: url(/app/static/hp--hero-bgc.jpg);
    background-size: cover;
    background-position: center bottom;
    opacity: .15;
    mask-image: radial-gradient(#fff 10%, transparent 70%);
}
.sec--hp-reviews > .bg > .ol {}
.el--sliderclisq {
	margin-top: 60px;
}
.el--sliderclisq .swiper {
  min-height: 460px;
}
.el--sliderclisq .swiper-slide {}
.el--sliderclisq .swiper-slide > .wrapper {
    padding: 24px 30px;
    border: 1px solid #e0e0e0;
    background-color: #fff;
    font-size: 12pt;
    font-weight: 300;
    line-height: 18pt;
    border-radius: 6px;
}
.el--sliderclisq .swiper-slide > .wrapper > .rt {
	padding: 20px 0px;
}
.el--sliderclisq .swiper-slide > .wrapper > .rt > svg {
	fill: #ddd;
	width: 40px;
	height: 40px;				
}			
.el--sliderclisq .swiper-slide > .wrapper > .rm {}
.el--sliderclisq .swiper-slide > .wrapper > .rm > p {}
.el--sliderclisq .swiper-slide > .wrapper > .rb {
	position: relative;
	display: flex;
	flex-flow: row wrap;
	align-items: center;
	padding-top: 20px;
	margin-top: 20px;
	border-top: 1px solid #e1e1e1;
	line-height: 14pt;
}
.el--sliderclisq .swiper-slide > .wrapper > .rb > .l {
	position: relative;
	flex: 0 0 40px;
	height: 40px;
	aspect-ratio: 1;
	overflow: hidden;
	border-radius: 50px;
	background-color: #eaeaea;
}
.el--sliderclisq .swiper-slide > .wrapper > .rb > .l > img {
	position: absolute;
	width: 100%;
	height: 100%;
}
.el--sliderclisq .swiper-slide > .wrapper > .rb > .r {
	flex: 0 0 calc(100% - 56px);
	margin-left: 16px;
}
.el--sliderclisq .swiper-slide > .wrapper > .rb > .r > p {
	margin: 0px;
}
.el--sliderclisq .swiper-slide > .wrapper > .rb > .r > p > b {}
.el--sliderclisq .swiper-slide > .wrapper > .rb > .r > p > span {
	position: relative;
	display: block;
	font-size: 10pt;
	margin-top: 2px;
	color: #aaa;
}


/* Content Element - Table */

.content-element .table-wrapper {
	position: relative;
	display: block;
	overflow: scroll;
}
.content-element table {
	width: 100%;
	border-collapse: collapse;
	border-spacing: 0;
	font-size: .9em;
}
.content-element table a {
	text-decoration: underline;
	transition: .2s;
	color: var(--color--text-main);
}
.content-element table a:hover {
	color: var(--color--csa-red);
}
.content-element table tr {}
.content-element table tr > th {
	background: #e0e0e0;
}
.content-element table tr > td {
	background-color:#fff;
}
.content-element table th, td {
	padding: 1em 1.2em;
	border: 1px solid #e3e3e3 !important;
}

.content-element table.table-prices tr > td:last-child, .content-block table.table-prices tr > th:last-child {
	width: 20%;
	text-align: center;
}

.content-element table.head-grey th {
	background: #e0e0e0;
}
.content-element table.head-red th {
	background: #b66767;
	color: #fff;
}
.content-element table.head-green th {
	background: #77a57b;
	color: #fff;
}

.content-element .note {
	margin: 2em 0em 0em;
	font-size: .75em;
}


@media only screen and (max-width: 519px) {
	
	.content-element .object {
		padding: 1em;
	}
	.content-element table {
		font-size: 10pt;
	}

}


.el--border-left {
	border-left: 6px solid #cdcdcd;
	padding: 2em 3em;
}
.el--border {
	border-radius: 6px;
	padding: 2em 3em;
}
.el--border.elb--red {
	border: 2px solid var(--color--csa-red);
}
.el--border.elb--red.elb--filled {
	background: #ffe2e2;
	border: 2px solid #ffc1c1;
}
.el--border.elb--grey {
	border: 2px solid #dcdcdc;
}
.el--border.elb--green {
	border: 2px solid #caf1ca;
}
.el--border.elb--green.elb--filled {
	background: #dcffdc;
}

@media only screen and (max-width: 519px) {
	.el--border {
		padding: 1.5em;
	}
	.el--border-left {
		border-left: 4px solid #cdcdcd;
		padding: 1.5em;
	}
}

/* Element - Lists */

ul.disc {
	list-style: disc;
	padding-left: 20px;	
}
ul.disc > li:not(:first-child) { margin-top: 1em; }

ul.text-strings { line-height: 1.2em; }
ul.text-strings > li:not(:first-child) { margin-top: .5em; }

.el--list-text { line-height: 1.4em; }
.el--list-text > li:not(:first-child) { margin-top: .5em; }

.el--list-textitem { line-height: 1.5em; }
.el--list-textitem > li:not(:first-child) { margin-top: 1.25em; }

.el--list-pagecontents {}
.el--list-pagecontents > li > span { margin-right: 10px; }
.el--list-pagecontents a {
	color: var(--color--csa-red);
	text-decoration: underline;
}

.el--list-h3-borders {}
.el--list-h3-borders h3 {
	color: var(--color--csa-red);
	margin: 0px;
}
.el--list-h3-borders > li {}
.el--list-h3-borders > li:first-child {
	margin-top: 1.5em;
}
.el--list-h3-borders > li:not(:first-child) {
	padding-top: 1.5em;
	margin-top: 1.5em;
	border-top: 1px solid #dbcfcf;
}

.el--list-questions {
	display: flex;
    flex-flow: row wrap;
    row-gap: .3em;
    gap: .3em;
    font-size: 11pt;
}
.el--list-questions > li {
    padding: .5em .75em;
    border: 1px solid #cccccc;
    border-radius: 200px;
    background: rgb(212 212 212 / 50%);
    color: var(--color--text-main);
    font-size:1.2em;
}

.el--list-su {}
.el--list-su > li {}
.el--list-su > li > strong {
	position: relative;
	text-decoration-line: underline;
	text-decoration-color: red;
	text-decoration-style: solid;
	text-decoration-thickness: 2px;
	text-underline-offset: 3px;
}
.el--list-su > li > ul {
	margin: 1em 0em;
    background: #f4f4f4;
    border-radius: 6px;
    padding: 2em 1em 2em 3em;
}
.el--list-su > li > ul > li {}

.el--list-short {
	line-height: 1em;
}
.el--list-short > li:not(:first-child) {
	margin-top: .7em!important;
}

@media only screen and (max-width: 519px) {
	.el--list-questions > li {
		font-size: 1em;
		padding: 1em 1.75em;
    	border: 1px solid #cccccc;
    	border-radius: 6px;
	}
}

/* Element - Stat Numbers */

.el--statnumbers {
	position: relative;
	display: flex;
	flex-flow: row wrap;
	gap: 1px;
	row-gap: 1px;
	overflow: hidden;
	border-radius: 6px;
	background-color: #ff5a59;
}
.el--statnumbers * {
	color: #fff;
}
.el--statnumbers > div {
	flex: 1 0 calc(25% - 3px);
	display: flex;
    align-items: center;
}
.el--statnumbers > div > .wrapper {
	background: linear-gradient(45deg, var(--color--csa-red), #9f1918);
	padding: 2em;
	height: stretch;
    width: 100%;
}
.el--statnumbers > div > .wrapper > .count {
	font-weight: 700;
	font-size: 3em;
}
.el--statnumbers > div > .wrapper > .comment {}

/* Element - Our Workflow */

.el--workflow {
	position: relative;
	display: flex;
	flex-flow: row wrap;
}
.el--workflow * {
	color: #fff;
}
.el--workflow > div:not(:first-child) {
	margin-left: 1px;
}
.el--workflow > div {
	flex: 1 0 calc(20% - 4px);
}
.el--workflow > div > .wrapper {
	background: linear-gradient(45deg, var(--color--csa-red), #9f1918);
	padding: 2em;
	width: 100%;
	position: relative;
	border-radius: 6px;
	display: flex;
	height: stretch;
	align-items: center;
}
.el--workflow > div > .wrapper > .count {
	position: absolute;
    top: -16px;
    right: .5em;
    font-weight: 700;
    font-size: 3em;
	background: -webkit-linear-gradient(224deg, #ffa4a4, #ffbfbf);
    -webkit-background-clip: text;
    -webkit-text-fill-color: transparent;	
}
.el--workflow > div > .wrapper > .comment {
	text-align: center;
}
.el--workflow > div:first-child > .wrapper {}
.el--workflow > div:last-child > .wrapper {}


@media only screen and (max-width: 519px) {
	.el--statnumbers > div {
		flex: 0 0 100%;
	}
	.el--workflow > div {
		flex: 0 0 100%;
	}
	.el--workflow > div:not(:first-child) {
		margin-left: 0px;
	}
	.el--workflow > div > .wrapper {
		padding: 2em 1em;
		display: flex;
		flex-flow: row wrap;
		align-items: center;
	}
	.el--workflow > div > .wrapper > .count {
		position: relative;
		font-size: 2em;
		top: 0px;
		left: .5em;
		flex: 0 0 2em;
	}
	.el--workflow > div > .wrapper > .comment {
		flex: 1 0 1em;
		text-align: left;
	}
}


.el--geo-bgmap {
	position: absolute;
    top: 0px;
    left: -360px;
    width: 1670px;
    height: 100%;
    aspect-ratio: 1;
    background-image: url(/app/static/map-russia.svg);
    background-size: cover;
    z-index: 0;
    opacity: 0.4;
}
.el--geo-list {
	position: relative;
	display: flex;
	flex-flow: row wrap;
	gap: 1em;
	row-gap: 1em;
	z-index: 1;
}
.el--geo-list > div {}
.el--geo-list > div > .wrapper {
	padding: 1em;
	background: var(--servicepage--color-obj-bg);
	border-radius: 6px;
	border: 1px solid #ebebeb;
}
.el--geo-list > div > .wrapper h3 {
	font-size: 11pt;
	color: var(--color--csa-red);
/*	text-decoration: underline;*/
	margin-top: 0em;
}
.el--geo-list > div > .wrapper h4 {
	font-size: 11pt;
}
.el--geo-list > div > .wrapper ul {
	font-size: 10pt;
	margin-top: .5em;
}
@media only screen and (max-width: 519px) {
	.el--geo-bgmap {
		display: none;
	}
	.el--geo-list {
		gap: 0em;
		row-gap: 1em;
	}
	.el--geo-list > div {
		flex: 0 0 calc(50% - .5em);
	}
	.el--geo-list > div:nth-child(2n + 2) {
		margin-left: 1em;
	}
	.el--geo-list > div > .wrapper h3 {
		font-size: 11pt!important;
	}
}

/* Element Documents */

.el--docblock {
	position: relative;
	display: flex;
	flex-flow: row wrap;
	row-gap: 1em;
}
.el--docblock > .el {
	width: 100%;
	user-select: none;
}
.el--docblock > .el > a {
	position: relative;
	display: block;
	width: 100%;
	height: 100%;
}
.el--docblock > .el > a > .wrapper {
	position: relative;
	display: flex;
	flex-flow: column wrap;
	width: 100%;
	height: 100%;
	background: #f4f4f4;
	padding: 2em;
	transition: .2s;
    overflow: hidden;
    border-radius: 6px;
}
.el--docblock > .el > a > .wrapper:before {
	content: '';
	position: absolute;
	display: block;
	background: url(/app/static/ico--document-pdf-dl.svg);
	background-size: cover;
	opacity: 1;
}
.el--docblock > .el > a > .wrapper > * {
	color: var(--color--text-main);
	transition: .2s;
}
.el--docblock > .el > a > .wrapper > h3 {
	margin: 0px;
	font-size: 1.2em;
	line-height: 1.2em;
	width: 80%;
}
.el--docblock > .el > a > .wrapper > div {
	width: 80%;
	font-size: .9em;
	margin-top: .3em;
}
.el--docblock > .el > a > .wrapper > span {
	position: relative;
	display: block;
	flex: 1 0 10%;
}
.el--docblock > .el > a > .wrapper > p {
    margin: 0px;
    margin-top: 0em;
    display: flex;
    align-items: end;
    padding: .1em 1em .2em;
    background: var(--color--text-main);
    color: #fff;
    width: max-content;
    border-radius: 30px;
    font-size: .9em;
}

.el--docblock > .el > a:hover > .wrapper {
	background: #cedeec;
}
.el--docblock > .el > a:hover > .wrapper > h3 {
	color: #1f4b72;
}
.el--docblock > .el > a:hover > .wrapper > p {
	background: var(--color--csa-red);
}


@media only screen and (min-width: 320px) and (max-width: 419px) {
	.el--docblock > .el {
		aspect-ratio: 1;
	}

}
@media only screen and (min-width: 420px) and (max-width: 759px) {
	.el--docblock > .el {
		aspect-ratio: 1.7;
	}
	.el--docblock > .el > a > .wrapper:before {
		right: 0px;
		top: -25px;
		width: 100px;
		height: 144px;
	}	

}
@media only screen and (min-width: 760px) and (max-width: 1279px) {
	.el--docblock > .el {
		flex: 0 0 calc(33.3333% - 1em);
		aspect-ratio: 2;
		margin-left: 1em;
	}
	.el--docblock > .el:nth-child(3n+3) {
		margin-left: 0px;
	}
}
@media only screen and (min-width: 1280px) and (min-width: 1439px) {
	.el--docblock > .el {
		flex: 0 0 calc(33.3333% - .6666em);
		aspect-ratio: 2;
	}
	.el--docblock > .el:nth-child(3n+1) {
		margin-left: 0px;
	}
}
@media only screen and (min-width: 1440px) {
	.el--docblock > .el {
		flex: 0 0 calc(33.3333% - .6666em);
		aspect-ratio: 1.8;
		margin-left: 1em;
	}
	.el--docblock > .el:nth-child(3n+1) {
		margin-left: 0px;
	}
	.el--docblock > .el > a > .wrapper:before {
		right: 0px;
		top: -25px;
		width: 100px;
		height: 144px;
	}								
}

