/*
Theme Name: ABMV World
Theme URI: https://www.duclair.org
Version: 1.0
Description: Custom theme for ABMV
Author: Filip Kábrt, DuCLAIR
Author URI: https://www.duclair.org
template: bb-theme
*/

/* FRAMEWORK */

body {
	background-image: url(http://abmv.cz.uvirt136.active24.cz/wp-content/uploads/2025/12/home.jpg);
	background-size: cover;
	background-repeat: repeat;
	background-attachment: fixed;
}

body.page-id-167 {
	background-image: url(http://abmv.cz.uvirt136.active24.cz/wp-content/uploads/2025/12/about.jpg);
}

body.page-id-390 {
	background-image: url(http://abmv.cz.uvirt136.active24.cz/wp-content/uploads/2025/12/services.jpg);
}

body.page-id-439 {
	background-image: url(http://abmv.cz.uvirt136.active24.cz/wp-content/uploads/2025/12/contact.jpg);
}

body.page-id-454 {
	background-image: url(http://abmv.cz.uvirt136.active24.cz/wp-content/uploads/2025/12/news.jpg);
}

p {
	font-size: 16px;
}

h2 a:hover, h1 a:hover {
	color: rgba(71,82,211,0.8);
}

h2 a {
	line-height: 1.1;
	transition: color .2s;
}

h2.novinka-title {
	line-height: 1.1;
}

#fl-main-content {
	padding-top: 120px;
}

@media (max-width: 768px) {
	#fl-main-content.fl-page-content {
		margin-left: 0px;
		margin-right: 0px;
	}
	h1.fl-module-heading, .single-projekt h1.fl-heading {
		margin-left: 20px !important;
		margin-right: 20px !important;
	}
	h2.fl-module-heading {
		line-height: 1.1;
	}
	footer .fl-rich-text p {
		text-align: center !important;
	}
	.hidemobile {
		display: none !important;
	}
}

@media (min-width: 769px) {
	.hidedesktop {
		display: none !important;
	}
}

/* HEADER NAVIGATION */

#menu-hlavni-menu.menu {
	width: 100%;
	display: flex;
	justify-content: space-between;
}

#menu-hlavni-menu.menu > li {
	width: 15%;
	padding: 0px 0px 7px 0px;
	border-bottom: 2px solid rgba(0,0,0,0.4);
}

#menu-prave-menu.menu > li {
	padding: 0px 0px 7px 0px;
}

#menu-hlavni-menu.menu > li a, #menu-prave-menu.menu > li a {
	padding: 0px;
	color: #626262;
	font-size: 18px;
	font-weight: 400;
	text-align: left;
}

.fl-node-1i5ksagcjb39 nav {
	text-align: right;
}

#menu-hlavni-menu.menu .sub-menu {
	padding: 5px 0px 5px 0px;
	background-color: rgba(255,255,255,0.9);
	margin-top: 2px;
}

#menu-hlavni-menu.menu .sub-menu li {
	padding: 8px 10px 6px 10px;
}

#menu-hlavni-menu.menu .sub-menu li:hover {
	background-color: rgba(71,82,211,0.8);
	border-bottom: none;
}

#menu-hlavni-menu.menu .sub-menu li a {
	font-weight: 300;
}

#menu-hlavni-menu.menu .sub-menu li:hover a {
	color: #fff;
	text-decoration: none;
}

#menu-hlavni-menu.menu > li.current-menu-item .sub-menu a {
	font-weight: 400;
}

#menu-hlavni-menu.menu li:hover {
	border-bottom: 2px solid rgba(0,0,0,0.7);
}

#menu-hlavni-menu.menu li:hover a, #menu-prave-menu.menu li:hover a {
	color: #000;
}

#menu-hlavni-menu.menu li.current-menu-item {
	border-bottom: 2px solid rgba(0,0,0,1);
}

#menu-hlavni-menu.menu li.current-menu-item .sub-menu li {
	border-bottom: none;
}

#menu-hlavni-menu.menu li.current-menu-item a {
	color: #000;
	font-weight: 700;
}

@media (max-width: 768px) {
	#menu-hlavni-menu.menu { 
		display: block;
	}
	#menu-hlavni-menu.menu li {
		width: 100%;
		margin: 0px 0px 10px 0px;
	}
	#menu-hlavni-menu.menu .sub-menu li {
		padding: 5px 0px 3px 0px;
	}
	.fl-module.fl-module-menu.menu.fl-menu-mobile-clone {
		background-color: rgba(255,255,255,0.7);
	}
	header.fl-builder-content .fl-menu-mobile-toggle {
		float: right !important;
	}
	#menu-prave-menu.menu > li {
		margin-top: -70px;
	}
}

.fl-theme-builder-header-shrink {
	background-color: #fff;
}

/* TITLES */

.title0 {
	background-color: rgba(95,95,95,0.8);
	padding: 2px 20px 2px 33px;
}

.title1 {
	background-color: rgba(161,161,161,0.8);
	padding: 37px 20px 5px 33px;
}

.title2 {
	background-color: rgba(229,229,229,0.8);
	padding: 37px 20px 5px 33px;
}

@media (max-width: 768px) {
	h1.fl-module-heading {
		font-size: 52px !important;
	}
	.title0 {
		padding-left: 0px;
		padding-right: 0px;
	}
	.title1 {
		padding-left: 20px;
	}
	.title2 {
		padding-left: 20px;
	}
}

/* SECTIONS */

.sec {
	background-color: rgba(255,255,255,0.8);
	padding: 20px 20px 45px 33px;
}

.sec ul {
	list-style-type: square;
}

.sec ul li::marker {
	color: #a7a7a7;
}

.fl-rich-text ul {
	padding-left: 18px;
}

@media (max-width: 768px) {
	.sec {
		padding-left: 20px;
	}
}

/* ABOUT BLOCKS */

.about-block {
	background-color: rgba(255,255,255,0.8);
	padding: 10% 10% 10% 10%;
	position: relative;
	font-size: 18px;
	color: #000;
	min-height: 711px;
}

.about-block.contact-block {
	padding: 10% 10% 22% 10%;
	min-height: 100px;
}

@media (min-width: 768px) {
	.about-block.contact-block {
		min-height: 780px;
	}
}

.about-block.contact-block img {
	mix-blend-mode: multiply;
}

.about-desc {
	background-color: rgba(69,69,69,0.8);
	padding: 7% 7% 7% 7%;
	position: relative;
	font-size: 18px;
	color: #fff;
}

.about-desc h2 {
	color: #fff;
	font-weight: 200;
}

.about-block .about-letter {
	font-size: 300px;
	color: rgba(112,112,112,1);
	font-weight: 300;
	margin-top: -80px;
}

.about-block .about-title {
	font-size: 100px;
	line-height: 80px;
	color: rgba(217,217,217,1);
	margin-top: -50px;
	margin-bottom: 40px;
	font-weight: 200;
}

.about-block .about-text.grey {
	color: #626262;
}

.about-block .about-pic {
	margin-bottom: 20px;
}

.about-dark {
	background-color: rgba(29,29,29,0.8);
	color: #fff;
	font-size: 18px;
	padding: 70px 40px 70px 40px;
}

.about-cross {
	position: absolute;
	background-color: transparent;
	display: none;
}

.about-cross .cross-h, .about-cross .cross-v {
	background-color: rgba(0,0,0,0.6);
}

.about-desc .about-cross .cross-h, .about-desc .about-cross .cross-v {
	background-color: rgba(255,255,255,0.6);
}

.cross-ul, .cross-ll {
	left: 5%;
}

.about-desc .cross-ul, .about-desc .cross-ll {
	left: 3%;
}

.cross-ur, .cross-lr {
	right: 5%;
}

.about-desc .cross-ur, .about-desc .cross-lr {
	right: 3%;
}

.cross-ul, .cross-ur {
	top: 5%;
}

.cross-ll, .cross-lr {
	bottom: 5%;
}

.cross-h {
	width: 40px;
	height: 1px;
	margin-top: 20px;
}

.cross-v {
	height: 40px;
	width: 1px;
	margin-left: 20px;
	margin-top: -20px;
}

@media (max-width: 768px) {
	.about-block, .about-desc {
		padding-left: 20px;
		padding-right: 20px;
	}
	.about-block.contact-block {
		padding-left: 20px;
		padding-right: 20px;
	}
}

/* TEAM BLOCKS */

.bio .fl-post-image {
	width: 200px;
	height: 200px;
	margin-right: 35px;
	float: left;
}

.bio .fl-post-text {
	background-color: rgba(69,69,69,0.8);
	padding: 15px 20px 15px 20px;
	height: 200px;
}

.bio .fl-post-text h2 {
	color: #fff;
	text-transform: uppercase;
	font-size: 18px;
}

.bio .fl-post-text p {
	color: #fff;
	font-size: 18px;
}

.bio-s .fl-post-image {
	margin: 0px 35px 35px 0px;
}

.bio-s .fl-post-columns-post {
	position: relative;
}

.bio-s .fl-post-grid-post {
	border: none;
}

.bio-s h2.fl-post-title {
	position: absolute;
	bottom: 0px;
	left: 0px;
	height: 35px;
	width: 100%;
	color: #fff;
	text-transform: uppercase;
	background-color: #404040;
	font-size: 18px;
	z-index: 80;
	padding: 5px 0px 5px 12px;
	display: block;
}

.bio-s .fl-position {
	position: absolute;
	right: 0px;
	top: 0px;
	height: 100%;
	color: #fff;
	text-transform: lowercase;
	font-size: 18px;
	background-color: #ddd;
	z-index: 70;
	display: block;
	color: #404040;
	writing-mode: sideways-lr;
	padding: 0px 7px 47px 3px;
}

.bio-s .fl-post-grid .fl-post-column {
	display: none;
}

.bio-s .fl-post-grid .fl-post-column:nth-of-type(1) {
	display: block;
}

.bio-s .fl-post-grid .fl-post-column:nth-of-type(2) {
	display: block;
}

.bio-s .fl-post-grid .fl-post-column:nth-of-type(3) {
	display: block;
}

.bio-s .fl-post-grid .fl-post-column:nth-of-type(4) {
	display: block;
	position: relative;
	cursor: pointer;
}

.bio-s .fl-post-grid .fl-post-column:nth-of-type(4):before {
	display: block;
	position: absolute;
	left: 10px;
	top: 3px;
	width: calc(100% - 20px);
	height: calc(100% - 20px);
	box-sizing: border-box;
	content: 'zobrazit celý tým';
	background-color: #959595;
	background-color: transparent;
	z-index: 120;
	border: 1px solid #fff;
	text-align: center;
	vertical-align: center;
	padding-top: 35%;
	font-size: 32px;
	color: #fff;
	font-size: 200;
}

.bio-s .fl-post-grid .fl-post-column.hide-clicker:before {
	display: none;
}

.bio-s .fl-post-grid .fl-post-column:nth-of-type(4) .fl-post-grid-post {
	visibility: hidden;
}

body .bio-s .fl-post-grid .fl-post-column.hide-clicker .fl-post-grid-post {
	visibility: visible;
}

.bio-s .fl-post-grid .fl-post-column.hide-clicker {
	cursor: default;
}

.bio-c .fl-post-grid-post {
	display: flex;
	align-items: center;
	justify-content: center;
}

.client img {
  filter: grayscale(100%);
  transition: filter 0.4s ease;
  will-change: filter;
}

img:hover {
  filter: grayscale(0%);
}

/* PROJECT DETAIL */

.project-desc {
	font-size: 18px;
}

.project-table {
	font-size: 18px;
}

.project-table th {
	padding-right: 10px;
}

.project-gallery figure figcaption, .project-grid-title {
	position: absolute;
	bottom: 0;
	width: 100%;
	font-size: 18px;
	text-transform: uppercase;
	font-weight: 400;
	text-align: left;
	background-color: rgba(95,95,95,0.6);
	color: #fff;
	padding-left: 15px;
}

@media (min-width: 769px) {
	.project-grid-item.size2 .project-grid-title, .project-grid-item.size4 .project-grid-title {
		width: 515px;
	}
	.project-grid-item.size1 .project-grid-title {
		width: 250px;
	}
}

.project-gallery figure figcaption {
	display: none;
}

/* PROJECT GRID */

.projects-grid {
    position: relative;
}

.project-grid-item {
    position: absolute;
    width: 250px;
	height: 250px;
	margin: 0px 15px 15px 0px;
    box-sizing: border-box;
	background-color: rgba(255,255,255,0.2);
	overflow: hidden;
}

.project-grid-item.size2 {
	width: 515px;
}

.project-grid-item.size4 {
	width: 515px;
	height: 515px;
}

.project-grid-item a {
	text-decoration: none;
	position: absolute;
	width: 100%;
	height: 100%;
}

.project-grid-item a img {
	max-height: 100%;
}

.project-grid-title {
	padding-top: 4px;
}

.project-grid-item:hover .project-grid-title {
	background-color: rgba(95,95,238,0.6);
}

.project-grid-thumb {
	height: 100%;
}

.projects-filter {
    margin-bottom: 20px;
	display: flex;
	justify-content: space-between;
}

.projects-filter-btn {
    margin: 0 0.25rem 0.25rem 0;
    cursor: pointer;
	color: #000;
	font-size: 18px;
	text-transform: lowercase;
}

.projects-filter-btn:hover {
	text-decoration: none;
	color: #000;
	border-bottom: 2px solid #929292;
}

.projects-filter-btn.is-active {
    font-weight: bold;
	color: #626262;
	border-bottom: 2px solid #626262;
}

@media (max-width: 768px) {
	.project-grid-item {
		position: relative;
	}
	.projects-filter {
		display: none;
	}
	.project-grid-item, .project-grid-item.size2, .project-grid-item.size4 {
		width: 100%;
		margin-bottom: 15px;
	}
}

/* SERVICES LIST */

.service-block {
	background-color: rgba(95,95,95,0.6);
	color: #fff;
	height: 165px;
	padding: 50px 5px 5px 35px;
	font-size: 44px;
	line-height: 47px;
	font-weight: 100;
	display: block;
	width: 100%;
	text-transform: lowercase;
	position: relative;
	margin: 15px 0px;
	transition: background-color 200ms linear;
}

@media (max-width: 768px) {
	.service-block {
		height: 95px;
		font-size: 28px;
		line-height: 31px;
	}
}

@media (min-width: 1026px) {
	.service-block {
		display: inline-block;
		margin: 0.8%;
	}
	.service-block.odd.first, .service-block.even.second {
		width: 37%;
	}
	.service-block.even.first, .service-block.odd.second {
		width: 57%;
	}
}

.service-block span {
	display: block;
	position: absolute;
	bottom: 6px;
	left: 30px;
	width: 70%;
}

.service-block i {
	display: none;
}

.service-block:hover {
	background-color: rgba(77,84,158,0.6);
	color: #fff;
	text-decoration: none;
}

.service-arrow-anchor .fl-row-content {
	position: relative;
}

.service-arrow {
	position: absolute;
	left: -90px;
	top: 191px;
	transition: color .2s;
}

.service-arrow a i:before {
	transition: color .2s;
}

.service-arrow a:hover i:before {
	color: rgba(71,82,211,0.8) !important;
}

@media (max-width: 768px) {
	.service-arrow {
		display: none;
	}
}

/* NEWS LIST */

.novinky-list { 
	display: flex; 
	flex-direction: column; 
	gap: 24px; 
}

.novinka-row { 
	width: 100%; 
}

.novinka-inner {
	display: flex;
	gap: 12px;
	align-items: stretch;
}

.novinka-media img { 
	display: block; 
	max-width: 240px; 
	height: auto; 
	border-radius: 0px; 
}
		
.novinka-content { 
	flex: 1; 
	padding: 10px 20px;
	background-color: #fff;
}

.novinka-title { 
	margin: 0 0 8px; 
}

.novinka-desc p { 
	margin: 0; 
}

.novinka-row.img-right .novinka-inner { 
	flex-direction: row-reverse; 
}

@media (max-width: 700px) {
	.novinka-inner, .novinka-row.img-right .novinka-inner { 
		flex-direction: column; 
	}
	.novinka-media img { 
		max-width: 100%; 
	}
}

/* HOME PAGE */

#home-claim p {
	font-size: 24px;
}

#home-claim p a {
	color: #757575;
	text-decoration: underline;
}

#home-menu ul {
	width: 100%;
}

#home-menu li {
	margin: 15px 1px 15px 0px;
	width: 18%;
}

#home-menu li:first-of-type {
	display: none;
}

#home-menu li a {
	background-color: rgba(95,95,95,0.6);
	color: #fff;
	height: 100px;
	padding: 50px 5px 5px 20px;
	font-size: 32px;
	line-height: 37px;
	font-weight: 100;
	display: block;
	width: 100%;
	position: relative;
	margin: 15px 2px;
	transition: background-color 200ms linear;
}

#home-menu .sub-menu {
	display: none;
}

@media (min-width: 1026px) {
	#home-menu li a {
		display: inline-block;
		margin: 0.8%;
		width: 100%;
	}
}

#home-menu li a:hover {
	background-color: rgba(77,84,158,0.6);
	color: #fff;
	text-decoration: none;
}


/* ANIMATION ENGINE */

#animated-words-container {
    position: relative;
	margin: 0px 10vw 0px 10vw;
    width: 80vw;
    height: 50vmin;
    overflow: hidden;
}

.animated-word {
    white-space: nowrap;
    will-change: transform, opacity;
	opacity: 0;
}

@media (max-width: 580px) {
	#animated-words-container {
		margin: 0px 0px 0px 0px;
		width: 100%;
		height: 50vmin;
	}
	/*.animated-word.anim-class-letter {
		margin-top: 15vh;
		margin-left: -8vw;
	}*/
}

/* PARALLAX SCROLLING */

.fl-theme-builder-singular-sluzba .fl-photo-img {
    /*transition: transform 0.1s linear;*/
    will-change: transform;
}