html {
	background: #fff;
	min-height: 100vh;
	-webkit-font-smoothing: subpixel-antialiased;
}
body {
	color: #000;
	font-size: 16px;
	font-weight: 400;
	line-height: 1.3;
	margin: 0 auto;
	max-width: 2000px;
	overflow-x: hidden;
	padding: 0;
	word-wrap: break-word;
}
body.fixed {
	overflow: hidden;
}
.bodyWrapper {
	background: #fff;
	float: left;
	position: relative;
	width: 100%;
}
a {
	color: #000;
	position: relative;
	-webkit-transition: color 0.3s ease 0s;
	transition: color 0.3s ease 0s;
	text-decoration: none;
}
a:hover {
	color: #24108d;
}
h1,
h2,
h3,
h4,
h5,
h6 {
	color: #000;
	font-weight: 400;
	margin: 0;
	padding: 0;
}
h1 {
	font-size: 44px;
	font-weight: 500;
}
h2 {
	font-size: 42px;
}
h3 {
	font-size: 30px;
}
h4 {
	font-size: 18px;
}
h5 {
	font-size: 14px;
}
h6 {
	font-size: 12px;
}
ul {
	list-style: none;
	margin: 0;
	padding: 0;
}
p {
	margin: 15px 0;
}
.articleSections ul,
.ccAboutText ul {
	list-style: inside;
	margin: 15px 0;
}
iframe {
	max-width: 100%!important;
}
section img {
	display: block;
	height: auto;
	max-width: 100%;
}
#fancybox-overlay {
	z-index: 10002;
}
.ccPage {
	-webkit-box-sizing: border-box;
	-moz-box-sizing: border-box;
	box-sizing: border-box;
	display: table;
	table-layout: fixed;
	margin: 0 auto!important;
	padding: 0 50px;
	width: 100%;
}
.generalButton,
.formResponsive input[type="button"].generalButton,
.formResponsive button[type="button"].generalButton,
.formResponsive input[type="submit"].generalButton,
.formResponsive button[type="submit"].generalButton,
.formResponsive input[type="reset"].generalButton,
.formResponsive button[type="reset"].generalButton {
	-webkit-appearance: none;
	-webkit-align-items: center;
	align-items: center;
	background-color: #374c9f;
	background-image: none !important;
	border: none;
	border-radius: 0;
	-webkit-box-shadow: none;
	-moz-box-shadow: none;
	box-shadow: none;
	color: #fff;
	cursor: pointer;
	display: -webkit-flex;
	display: flex;
	float: left;
	font-size: 16px;
	font-weight: 900;
	min-height: 40px;
	-webkit-justify-content: center;
	justify-content: center;
	line-height: 1;
	min-width: 150px;
	outline: none !important;
	padding: 0 30px;
	position: relative;
	text-align: center;
	text-shadow: none;
	-webkit-transition: all 0.3s ease 0s;
	-moz-transition: all 0.3s ease 0s;
	transition: all 0.3s ease 0s;
}
.generalButton:hover,
.formResponsive input[type="button"].generalButton:hover,
.formResponsive button[type="button"].generalButton:hover,
.formResponsive input[type="submit"].generalButton:hover,
.formResponsive button[type="submit"].generalButton:hover,
.formResponsive input[type="reset"].generalButton:hover,
.formResponsive button[type="reset"].generalButton:hover {
	background-color: #24108d;
	color: #fff;
	text-shadow: none;
	-webkit-transition: all 0.3s ease 0s;
	-moz-transition: all 0.3s ease 0s;
	transition: all 0.3s ease 0s;
}
#ccTop1,
#ccTop2,
#ccTop3,
#ccTop4,
#ccTop5,
#ccTop6,
#ccTop7,
#ccTop8,
#ccTop9,
#ccTop10,
#ccBottom1,
#ccBottom2,
#ccBottom3,
#ccBottom4,
#ccBottom5,
#ccBottom6,
#ccBottom7,
#ccBottom8,
#ccBottom9,
#ccBottom10 {
	float: left;
	overflow: hidden;
	position: relative;
	width: 100%;
}
#ccContent,
#ccComponentWrap,
#ccSidebar,
#ccPageContent,
#ccContentWrap,
#ccMainBody,
#ccMainBodyTop,
#ccMainBodyBottom {
	-webkit-box-sizing: border-box;
	-moz-box-sizing: border-box;
	box-sizing: border-box;
	float: left;
	position: relative;
	width: 100%;
}
#ccHeader {
	-webkit-box-sizing: border-box;
	-moz-box-sizing: border-box;
	box-sizing: border-box;
	float: left;
	margin: 0;
	padding: 0;
	position: relative;
	-webkit-transition: all 0.3s ease 0.3s;
	-moz-transition: all 0.3s ease 0.3s;
	transition: all 0.3s ease 0.3s;
	width: 100%;
	z-index: 100;
}
#ccHeader .ccPage {
	max-width: 1980px;
}
#ccHeaderTop {
	float: left;
	padding: 8px 0;
	position: relative;
	-webkit-transition: all 0.3s ease 0s;
	-moz-transition: all 0.3s ease 0s;
	transition: all 0.3s ease 0s;
	width: 100%;
}
.ccHeaderTopInner {
	display: -webkit-flex;
	display: flex;
	-webkit-flex-wrap: wrap;
	flex-wrap: wrap;
	float: left;
	-webkit-justify-content: space-between;
	justify-content: space-between;
	position: relative;
	width: 100%;
}
.ccHeaderTopLeft {
	float: left;
	position: relative;
}
.ccHeaderTopRight {
	float: left;
	position: relative;
}
/* MODULE CC INTRO */
.ccIntro {
	-webkit-align-items: center;
	align-items: center;
	background-position: center center;
	background-repeat: no-repeat;
	background-size: cover;
	-webkit-box-sizing: border-box;
	-moz-box-sizing: border-box;
	box-sizing: border-box;
	display: -webkit-flex;
	display: flex;
	float: left;
	min-height: 100vh;
	padding: 100px 0;
	position: relative;
	width: 100%;
}
.ccIntroInner {
	float: left;
	position: relative;
	width: 100%;
}
.ccIntroLogoContainer {
	display: -webkit-flex;
	display: flex;
	float: left;
	-webkit-justify-content: center;
	justify-content: center;
	position: relative;
	width: 100%;
}
.ccIntroLogo {
	-webkit-animation: gradient 5s ease infinite;
	-moz-animation: gradient 5s ease infinite;
	animation: gradient 5s ease infinite;
	background: linear-gradient(-45deg, #374c9f, #374c9f, #374c9f, #374c9f, #ba231a, #ba231a, #bd33ab, #dd4631, #374c9f, #374c9f, #374c9f, #374c9f);
	background-size: 600% 400%;
	-webkit-mask-image: url('https://codica.gr/images/template/codica.svg');
	-o-mask-image: url('https://codica.gr/images/template/codica.svg');
	-moz-mask-image: url('https://codica.gr/images/template/codica.svg');
	mask-image: url('https://codica.gr/images/template/codica.svg');
	float: left;
	max-width: 700px;
	position: relative;
	width: 70vw;
}
.ccIntroTextContainer {
	display: -webkit-flex;
	display: flex;
	float: left;
	-webkit-justify-content: center;
	justify-content: center;
	margin: 50px 0 0;
	position: relative;
	text-align: center;
	width: 100%;
}
.ccIntroText {
	color: #fff;
	float: left;
	font-size: 24px;
	font-weight: 300;
	line-height: 1.3;
	max-width: 900px;
	position: relative;
	width: 100%;
}
.ccIntroText p {
	margin: 0 0 20px
}
@-webkit-keyframes gradient {
	0% {
		background-position: 100% 50%
	}
	100% {
		background-position: 0% 50%
	}
}
.ccIntroLogo svg {
	float: left;
	position: relative;
	visibility: hidden;
	width: 100%;
}
.ccIntroSloganContainer {
	display: -webkit-flex;
	display: flex;
	float: left;
	-webkit-justify-content: center;
	justify-content: center;
	margin: 10px 0 0;
	position: relative;
	width: 100%;
}
.ccIntroSlogan {
	color: #374c9f;
	float: left;
	font-size: 50px;
	font-weight: 400;
	line-height: 1;
	margin: 20px 0 0;
	max-width: 900px;
	position: relative;
	text-align: center;
	width: 100%;
}
.ccIntroGoToProjectsContainer {
	display: -webkit-flex;
	display: flex;
	float: left;
	-webkit-justify-content: center;
	justify-content: center;
	margin: 50px 0 -50px;
	position: relative;
	width: 100%;
}
.ccIntroGoToProjects {
	float: left;
	position: relative;
}
.ccIntroGoToProjects a {
	-webkit-animation: arrow 3s ease infinite;
	-moz-animation: arrow 3s ease infinite;
	animation: arrow 3s ease infinite;
	color: #fff;
	font-size: 40px;
	position: relative;
}
@-webkit-keyframes arrow {
	0% {
		top: 0
	}
	30% {
		top: 0;
	}
	40% {
		top: 20%;
	}
	45% {
		top: 0;
	}
	50% {
		top: 0;
	}
	60% {
		top: 20%;
	}
	65% {
		top: 0;
	}
	100% {
		top: 0;
	}
}
/* MODULE CC PROJECTS */
.ccProjects {
	float: left;
	position: relative;
	width: 100%;
}
.ccProjectsInner {
	-webkit-box-sizing: border-box;
	-moz-box-sizing: border-box;
	box-sizing: border-box;
	display: -webkit-flex;
	display: flex;
	-webkit-flex-wrap: wrap;
	flex-wrap: wrap;
	float: left;
	padding: 30px calc(15px + (30 - 15) * ((100vw - 320px) / (1300 - 320))) calc(30px + (50 - 30) * ((100vw - 320px) / (1300 - 320)));
	position: relative;
	width: 100%;
}
.ccProject {
	-webkit-box-sizing: border-box;
	-moz-box-sizing: border-box;
	box-sizing: border-box;
	float: left;
	padding: calc(20px + (30 - 20) * ((100vw - 320px) / (1300 - 320))) calc(0px + (10 - 0) * ((100vw - 320px) / (1300 - 320)));
	position: relative;
	width: 25%;
}
.ccProjectInner {
	float: left;
	position: relative;
	width: 100%;
}
.ccProjectImageContainer {
	float: left;
	position: relative;
	width: 100%;
}
.ccProjectImage {
	float: left;
	position: relative;
	width: 100%;
}
.ccProject .ccProjectInfoContainer {
	-webkit-box-sizing: border-box;
	-moz-box-sizing: border-box;
	box-sizing: border-box;
	float: left;
	padding: 20px 0 0;
	position: relative;
	width: 100%;
}
.ccProject .ccProjectInfoTitle {
	color: #374c9f;
	font-size: 26px;
	font-weight: 500;
	letter-spacing: 0.04em;
	line-height: 1.2;
	margin: 0 0 10px;
	position: relative;
	text-align: center;
	width: 100%;
}
.ccProject .ccProjectInfoTitle a {
	color: #374c9f;
}
.ccProject .ccProjectInfoTitle a:hover {
	color: #24108d;
}
.ccProject .ccProjectInfoText {
	float: left;
	font-size: 18px;
	font-weight: 300;
	line-height: 1.2;
	text-align: center;
	width: 100%;
}
/* MOD CONTACT CONTAINER */
#goToContact {
	bottom: 0;
	position: fixed;
	right: 60px;
}
.goToContactButton {
	-webkit-appearance: none !important;
	-webkit-align-items: center;
	align-items: center;
	background-color: #374c9f;
	border: none !important;
	color: #fff !important;
	display: -webkit-flex;
	display: flex;
	float: left;
	font-size: 14px;
	height: 40px;
	-webkit-justify-content: center;
	justify-content: center;
	letter-spacing: 1px;
	min-width: 40px;
	outline: none !important;
	padding: 0 20px;
	position: relative;
	-webkit-transition: all 0.3s ease 0s;
	-moz-transition: all 0.3s ease 0s;
	transition: all 0.3s ease 0s;
}
.goToContactButton:hover {
	background-color: #24108d;
}
.goToContactButton .label {
	margin-left: 10px;
}
.ccContactContainer {
	background-color: #e1e1e1;
	float: left;
	padding: 100px 0;
	position: relative;
	width: 100%;
}
.ccContactTitleContainer {
	float: left;
	position: relative;
	width: 100%;
}
.ccContactTitle {
	color: #374c9f;
	float: left;
	font-size: 30px;
	font-weight: 500;
	margin: 0 0 15px;
	position: relative;
	width: 100%;
}
.ccContactBodyContainer,
.ccContactBodyContainerInner,
.ccContactBody,
.ccContactTextContainer {
	float: left;
	overflow: hidden;
	position: relative;
	width: 100%;
}
.ccContactText {
	color: #000;
	float: left;
	font-size: 22px;
	font-weight: 300;
	line-height: 1.3;
	max-width: 960px;
	position: relative;
	width: 100%;
}
.ccContactText p {
	margin: 0;
}
.ccContactInfoContainer {
	display: -webkit-flex;
	display: flex;
	-webkit-flex-wrap: wrap;
	flex-wrap: wrap;
	float: left;
	margin: 50px 0 0 -30px;
	position: relative;
	width: calc(100% + 30px);
}
.ccContactInfoTitle {
	color: #374c9f;
	float: left;
	font-size: 25px;
	font-weight: 500;
	line-height: 1.3;
	margin: 0 0 10px;
	padding: 0 30px;
	position: relative;
	width: 100%;
}
.ccContactInfoItem {
	color: #000;
	float: left;
	font-size: 22px;
	font-weight: 300;
	line-height: 1.3;
	padding: 0 30px;
	position: relative;
}
.ccContactInfoItem::before {
	background-color: #374c9f;
	content: '';
	height: 20px;
	left: 0;
	position: absolute;
	top: 50%;
	-webkit-transform: translateY(-50%);
	-moz-transform: translateY(-50%);
	transform: translateY(-50%);
	width: 2px;
}
.ccContactAddress p {
	margin: 0;
}
/* RSFORM */
.ccFormContainer {
	background-color: #f1f1f1;
	float: left;
	padding: 100px 0 80px;
	position: relative;
	width: 100%;
}
.ccFormContainerInner {
	float: left;
	position: relative;
	width: 100%;
}
.ccFormContainer form {
	float: left;
	position: relative;
	width: 100%;
}
.ccContactForm {
	float: left;
	position: relative;
	width: 100%;
}
.generalFormFieldsContainer {
	display: -webkit-flex;
	display: flex;
	-webkit-flex-wrap: wrap;
	flex-wrap: wrap;
	float: left;
	margin-left: -10px;
	position: relative;
	width: calc(100% + 20px);
}
.generalFormField {
	-webkit-box-sizing: border-box;
	-moz-box-sizing: border-box;
	box-sizing: border-box;
	float: left;
	padding: 0 10px 20px;
	position: relative;
	width: 50%;
}
.generalFormField.fullWidth {
	width: 100%;
}
.generalFormLabel {
	float: left;
	font-size: 18px;
	font-weight: 300;
	margin: 0 0 5px;
	position: relative;
	width: 100%;
}
.generalFormBody {
	float: left;
	position: relative;
	width: 100%;
}
#userForm .generalForm textarea,
#userForm .generalForm input[type="text"],
#userForm .generalForm input[type="number"],
#userForm .generalForm input[type="email"],
#userForm .generalForm input[type="tel"],
#userForm .generalForm input[type="url"],
#userForm .generalForm input[type="password"] {
	-webkit-appearance: none !important;
	background-color: #fff;
	border: none;
	-webkit-border-radius: 0;
	-moz-border-radius: 0;
	border-radius: 0;
	-webkit-box-sizing: border-box;
	-moz-box-sizing: border-box;
	box-sizing: border-box;
	-webkit-box-shadow: none;
	-moz-box-shadow: none;
	box-shadow: none;
	color: #000;
	display: inline-block;
	font-size: 16px;
	height: auto;
	line-height: inherit;
	margin: 0;
	padding: 15px 20px;
	-webkit-transition: border linear 0.2s, box-shadow linear 0.2s;
	-moz-transition: border linear 0.2s, box-shadow linear 0.2s;
	transition: border linear 0.2s, box-shadow linear 0.2s;
	width: 100%;
}
#userForm .generalForm textarea {
	height: 150px;
	max-height: 250px;
	min-height: 150px;
	resize: vertical;
}
.generalFormField.rsform-block-required p {
	font-weight: 500;
	margin: 0;
}
.generalFormErrorContainer {
	float: left;
	position: relative;
	width: 100%;
}
.generalFormErrorContainer .formRed {
	color: #c80202;
	font-size: 16px;
	font-weight: 700;
	margin: 0 0 40px;
}
.generalFormButtonsContainer {
	float: left;
	position: relative;
	width: 100%;
}
.generalFormButtons {
	float: left;
	position: relative;
	width: 100%;
}
.generalFormButtonsContainer button[type="submit"].generalButton {
	font-weight: 700;
}
.generalFormValidation {
	float: left;
	position: relative;
	width: 100%;
}
.ccFormContainer form .generalFormValidation .formError {
	color: #c80202;
	font-size: 16px;
	font-weight: 500;
	margin: 0;
	padding: 3px 0 0;
}
/* FOOTER */
#ccFooter {
	float: left;
	position: relative;
	width: 100%;
}
.ccFooterContainer {
	background-color: #374c9f;
	float: left;
	padding: 20px 0;
	position: relative;
	width: 100%;
}
.ccFooter {
	-webkit-align-items: center;
	align-items: center;
	display: -webkit-flex;
	display: flex;
	float: left;
	-webkit-justify-content: space-between;
	justify-content: space-between;
	position: relative;
	width: 100%;
}
.ccFooterLogo {
	float: left;
	max-width: 100px;
	position: relative;
	width: 100%;
}
.ccFooterLogo path {
	fill: #fff
}
.ccFooterLogoCopyrights {
	color: #fff;
	float: left;
	font-size: 12px;
	margin: 4px 0 0;
	line-height: 1;
	position: relative;
}
/* Suffixes */
div.content {
	clear: both;
}
#fancybox-overlay {
	z-index: 10002;
}
/* GO TO TOP */
#goToTop {
	bottom: 0;
	position: fixed;
	right: 10px;
	-webkit-transition: opacity 0.5s ease 0s;
	-moz-transition: opacity 0.5s ease 0s;
	transition: opacity 0.5s ease 0s;
	visibility: hidden;
	z-index: 10000;
}
.goToTopButton {
	-webkit-appearance: none !important;
	-webkit-align-items: center;
	align-items: center;
	background-color: #374c9f;
	border: none !important;
	color: #fff !important;
	display: -webkit-flex;
	display: flex;
	float: left;
	font-size: 30px;
	font-family: 'ccFont';
	height: 40px;
	-webkit-justify-content: center;
	justify-content: center;
	outline: none !important;
	position: relative;
	-webkit-transition: all 0.3s ease 0s;
	-moz-transition: all 0.3s ease 0s;
	transition: all 0.3s ease 0s;
	width: 40px;
}
.goToTopButton:hover {
	background-color: #24108d;
}
/* MESSAGES */
#ccMessages {
	bottom: 0;
	left: 0;
	overflow: hidden;
	position: fixed;
	width: 100vw;
	z-index: 20000000;
}
#ccMessages #system-message-container {
	float: left;
	position: relative;
	width: 100%;
}
#ccMessages #system-message {
	margin: 0;
	position: relative;
}
#ccMessages #system-message dt {
	display: none;
}
#ccMessages #system-message .message {
	-webkit-box-sizing: border-box;
	-moz-box-sizing: border-box;
	box-sizing: border-box;
	background-color: #374c9f;
	color: #fff;
	font-size: 14px;
	font-weight: 400;
	letter-spacing: 1px;
	margin: 0;
	padding: 20px 15px;
	text-align: center;
	width: 100%;
}
#ccMessages #system-message .message * {
	font-size: 14px !important;
	font-weight: 400 !important;
	line-height: 1.2 !important;
}
#ccMessages #system-message .message p {
	margin: 0;
}
#ccMessages #system-message .message ul {
	list-style: none;
	padding: 0;
}
/* COOKIES LAW */
body .cpnb-m-cookies-floatButton {
	bottom: 10px;
	left: 10px;
}
body .cpnb-m-cookies-floatButton > div,
body .cpnb-m-cookies-floatButton img {
	float: left;
	position: relative;
}
@media (max-width: 1550px) {
	.ccProject {
		width: 33.33%;
	}
}
@media (max-width: 1300px) {
	.ccIntro {
		padding: calc(60px + (100 - 60) * ((100vw - 320px) / (1300 - 320))) 0;
	}
	.ccIntroSlogan {
		font-size: calc(23px + (50 - 23) * ((100vw - 320px) / (1300 - 320)));
		margin: calc(5px + (20 - 5) * ((100vw - 320px) / (1300 - 320)));;
	}
	.ccIntroText,
	.ccContactText,
	.ccContactInfoItem {
		font-size: calc(18px + (24 - 18) * ((100vw - 320px) / (1300 - 320)));
	}
	.ccIntroTextContainer {
		margin: calc(30px + (50 - 30) * ((100vw - 320px) / (1300 - 320))) 0 0;
	}
	.ccIntroGoToProjectsContainer {
		margin: calc(30px + (50 - 30) * ((100vw - 320px) / (1300 - 320))) 0 calc(-30px + (50 - 30) * ((100vw - 320px) / (1300 - 320)));
	}
}
@media (max-width: 1120px) {
	.ccProjectsInner {
		-webkit-justify-content: space-evenly;
		justify-content: space-evenly;
	}
	.ccProject {
		max-width: 500px;
		padding: calc(20px + (50 - 20) * ((100vw - 320px) / (1300 - 320))) calc(0px + (30 - 0) * ((100vw - 320px) / (1300 - 320)));
		width: 50%;
	}
}
@media (max-width: 980px) {
	.ccProject .ccProjectInfoTitle {
		font-size: 25px;
		font-weight: 700;
	}
}
@media (max-width: 800px) {
	.ccContactInfoContainer {
		-webkit-flex-direction: column;
		flex-direction: column;
	}
	.generalFormField {
		width: 100%;
	}
}
@media (max-width: 580px) {
	.ccPage {
		padding: 0 20px;
	}
	.ccIntroLogo {
		width: 80vw;
	}
	.ccProject {
		max-width: 340px;
		width: 100%;
	}
	.ccFooter {
		-webkit-flex-direction: column;
		flex-direction: column;
	}
	.ccFooterLogoCopyrights {
		margin: 15px 0 0;
	}
	/* Fix for tables */
	fieldset {
		box-sizing: border-box!important;
		max-width: 100%!important;
		width: 100%!important;
		overflow: hidden;
	}
	#ccMainBody table:before {
		content: "Scroll horizontally to view the whole table";
		height: 14px;
		width: 100%;
		display: block;
		font-size: 10px;
		margin-top: -30px;
		margin-bottom: 10px;
	}
	#ccMainBody table {
		width: 540px!important;
		display: block!important;
		padding: 30px 0 20px 0; /* padding for the scrollbars and the top message */
		overflow:scroll;
		-webkit-overflow-scrolling:touch;
	}
	#ccMainBody table tbody,
	#ccMainBody table thead,
	#ccMainBody table tfoot {
		width: 540px!important;
		display: table;
	}
}
@media (max-width: 480px) {
	#ccMainBody table {
		width: 420px!important;
	}
}
@media (max-width: 440px) {
	#ccMainBody table {
		width: 260px!important;
	}
}
