@charset "UTF-8";
/*
Theme Name: OnePress
Theme URI: https://www.famethemes.com/themes/onepress/re
Author: FameThemes
Author URI: http://www.famethemes.com
Description: OnePress is an outstanding creative and flexible WordPress one page theme well suited for business website, portfolio, digital agency, product showcase, freelancers and everyone else who appreciate good design. The theme overall is an elegant and classic one, a fine example of Bootstrap 4 WordPress theme which compatibility with latest version of WooCommerce. (Live preview : https://demos.famethemes.com/onepress)
Version: 2.3.3
License: GNU General Public License v2 or later
License URI: http://www.gnu.org/licenses/gpl-2.0.html
Text Domain: onepress
Tested up to: 6.0.2
Requires PHP: 5.6
Tags: one-column, two-columns, left-sidebar, right-sidebar, custom-menu, featured-images, full-width-template, sticky-post, theme-options, threaded-comments, translation-ready, e-commerce, blog, portfolio

This theme, like WordPress, is licensed under the GPL.
Use it to make something cool, have fun, and share what you've learned with others.

OnePress is based on Underscores http://underscores.me/, (C) 2012-2015 Automattic, Inc.
Underscores is distributed under the terms of the GNU GPL v2 or later.

Normalizing styles have been helped along thanks to the fine work of
Nicolas Gallagher and Jonathan Neal http://necolas.github.com/normalize.css/
*/
/*--------------------------------------------------------------
>>> TABLE OF CONTENTS:
----------------------------------------------------------------
1.0  Reset
2.0  Document
3.0  Layout
4.0  Structure
5.0  Contents
6.0  Elements
7.0  Widgets
8.0  Sections
9.0  External Plugins

--------------------------------------------------------------*/
/*--------------------------------------------------------------
1.0 Reset
--------------------------------------------------------------*/
/* Reset already include in bootstrap */
/*--------------------------------------------------------------
2.0 Document Setup
--------------------------------------------------------------*/


/* @import url('https://fonts.googleapis.com/css2?family=Inter:ital,opsz,wght@0,14..32,100..900;1,14..32,100..900&family=Plus+Jakarta+Sans:ital,wght@0,200..800;1,200..800&display=swap'); */



html, body {
  height: 100%;
}

/*------------------------------
	2.1 Typography
------------------------------*/
html, body {
  margin: 0;
  padding: 0;
}

html {
  box-sizing: border-box;
  -webkit-tap-highlight-color: rgba(0, 0, 0, 0);
  font-size: 16px;
}
@media (max-width: 991px) {
  html {
    font-size: 15px;
  }
}
@media (max-width: 767px) {
  html {
    font-size: 14px;
  }
}

body {
  background: #1d2324 !important;
}

.site {
  background: #1d2324 !important;
  position: relative;
}

body, button, input, select, textarea {
  font-family: Georgia, "Times New Roman", serif;
  font-size: 14px;
  font-size: 0.875rem;
  font-optical-sizing: auto;
  line-height: 1.7;
  color: #777777;
}

pre,
code,
input,
textarea {
  font: inherit;
}

::-moz-selection {
  background: #000000;
  color: #FFFFFF;
}

::selection {
  background: #000000;
  color: #FFFFFF;
}

/*------------------------------
	2.2 Links
------------------------------*/
a {
  color: #03c4eb;
  text-decoration: none;
  outline: none;
}
a:hover {
  text-decoration: none;
  color: #777777;
  text-decoration: underline;
}
a:active, a:focus, a:hover {
  outline: none;
}

/*------------------------------
	2.3 Heading
------------------------------*/
h1,
h2,
h3,
h4,
h5,
h6 {
  clear: both;
  font-family: Georgia, "Times New Roman", serif;
  font-weight: 600;
  margin-bottom: 15px;
  margin-bottom: 15px;
  font-optical-sizing: auto;
  margin-bottom: 0.9375rem;
  margin-top: 0;
  color: #333333;
}
h1 a,
h2 a,
h3 a,
h4 a,
h5 a,
h6 a {
 /* color: #333333; */
  text-decoration: none;
}

h1 {
  line-height: 1.3;
  font-size: 33px;
  font-size: 2.0625rem;
}
@media (min-width: 768px) {
  h1 {
    font-size: 48px;
    font-size: 2.5rem;
  }
}
h1 span {
  font-weight: bold;
}

h2 {
  line-height: 1.2;
  font-size: 25px;
  font-size: 1.5625rem;
}
@media (min-width: 768px) {
  h2 {
    font-size: 32px;
    font-size: 2rem;
  }
}

h3 {
  font-size: 20px;
  font-size: 1.25rem;
  font-weight: 600;
}

h4 {
  font-size: 17px;
  font-size: 1.0625rem;
  margin-bottom: 12px;
}

h5 {
  text-transform: uppercase;
  font-size: 15px;
  font-size: 0.9375rem;
  font-weight: 700;
}

h6 {
  font-weight: 700;
  text-transform: uppercase;
  font-size: 12px;
  font-size: 0.75rem;
  letter-spacing: 1px;
}

/*------------------------------
	2.4 Base
------------------------------*/
ul, ol, dl, p, details, address, .vcard, figure, pre, fieldset, table, dt, dd, hr {
  margin-bottom: 15px;
  margin-bottom: 0.9375rem;
  margin-top: 0;
}

/*------------------------------
	2.4 Container
------------------------------*/

.container {
  width: 100%;
  padding-left: 24px;
  padding-right: 24px;
  margin-left: auto;
  margin-right: auto;
}

/* small */
@media (min-width: 576px) {
  .container {
    max-width: 540px;
  }
}

/* tablet */
@media (min-width: 768px) {
  .container {
    max-width: 720px;
  }
}

/* small desktop */
@media (min-width: 992px) {
  .container {
    max-width: 960px;
  }
}

/* desktop */
@media (min-width: 1200px) {
  .container {
    max-width: 1140px;
  }
}

/* ⭐ modern desktop */
@media (min-width: 1400px) {
  .container {
    max-width: 1320px;
  }
}

/*------------------------------
	2.5 Content
------------------------------*/
img {
  height: auto;
  max-width: 100%;
  vertical-align: middle;
}

b,
strong {
  font-weight: bold;
}

blockquote {
  clear: both;
  margin: 20px 0;
}
blockquote p {
  font-style: italic;
}
blockquote cite {
  font-style: normal;
  margin-bottom: 20px;
  font-size: 13px;
}

dfn,
cite,
em,
i {
  font-style: italic;
}

figure {
  margin: 0;
}

address {
  margin: 20px 0;
}

hr {
  border: 0;
  border-top: 1px solid #e9e9e9;
  height: 1px;
  margin-bottom: 20px;
}

tt,
kbd,
pre,
code,
samp,
var {
  font-family: Monaco, Consolas, "Andale Mono", "DejaVu Sans Mono", monospace;
  background-color: #e9e9e9;
  padding: 5px 7px;
  -webkit-border-radius: 2px;
  -moz-border-radius: 2px;
  border-radius: 2px;
}

pre {
  overflow: auto;
  white-space: pre-wrap;
  max-width: 100%;
  line-height: 1.7;
  margin: 20px 0;
  padding: 20px;
}

details summary {
  font-weight: bold;
  margin-bottom: 20px;
}
details :focus {
  outline: none;
}

abbr,
acronym,
dfn {
  cursor: help;
  font-size: 0.95em;
  text-transform: uppercase;
  border-bottom: 1px dotted #e9e9e9;
  letter-spacing: 1px;
}

mark {
  background-color: #fff9c0;
  text-decoration: none;
}

small {
  font-size: 82%;
}

big {
  font-size: 125%;
}

ul, ol {
  padding-left: 20px;
}

ul {
  list-style: disc;
}

ol {
  list-style: decimal;
}

ul li, ol li {
  margin: 8px 0;
}

dt {
  font-weight: bold;
}

dd {
  margin: 0 20px 20px;
}

/*------------------------------
	2.6 Table
------------------------------*/
table {
  width: 100%;
  margin-bottom: 20px;
  border: 1px solid #e9e9e9;
  border-collapse: collapse;
  border-spacing: 0;
}

table > thead > tr > th,
table > tbody > tr > th,
table > tfoot > tr > th,
table > thead > tr > td,
table > tbody > tr > td,
table > tfoot > tr > td {
  border: 1px solid #e9e9e9;
  line-height: 1.42857;
  padding: 5px;
  vertical-align: middle;
}

table > thead > tr > th, table > thead > tr > td {
  border-bottom-width: 2px;
}

table th {
  font-size: 14px;
  letter-spacing: 2px;
  text-transform: uppercase;
}

/*------------------------------
	2.7 Form
------------------------------*/
fieldset {
  padding: 20px;
  border: 1px solid #e9e9e9;
}

input[type=reset], input[type=submit], input[type=submit],
.pirate-forms-submit-button, .contact-form div.wpforms-container-full .wpforms-form .wpforms-submit {
  cursor: pointer;
  background: #03c4eb;
  border: none;
  display: inline-block;
  color: #FFFFFF;
  letter-spacing: 1px;
  text-transform: uppercase;
  line-height: 1;
  text-align: center;
  padding: 15px 23px 15px 23px;
  -webkit-border-radius: 2px;
  -moz-border-radius: 2px;
  border-radius: 2px;
  box-shadow: 0 -1px 0 0 rgba(0, 0, 0, 0.1) inset;
  margin: 3px 0;
  text-decoration: none;
  font-weight: 600;
  font-size: 13px;
}
input[type=reset]:hover, input[type=submit]:hover, input[type=submit]:hover,
.pirate-forms-submit-button:hover, .contact-form div.wpforms-container-full .wpforms-form .wpforms-submit:hover {
  opacity: 0.8;
  background: #03c4eb;
  border: none;
}

input[type=button]:hover, input[type=button]:focus, input[type=reset]:hover,
input[type=reset]:focus, input[type=submit]:hover, input[type=submit]:focus,
button:hover, button:focus {
  cursor: pointer;
}

textarea {
  resize: vertical;
}

select {
  max-width: 100%;
  overflow: auto;
  vertical-align: top;
  outline: none;
  border: 1px solid #e9e9e9;
  padding: 10px;
}

textarea:not(.editor-post-title__input),
input[type=date],
input[type=datetime],
input[type=datetime-local],
input[type=email],
input[type=month],
input[type=number],
input[type=password],
input[type=search],
input[type=tel],
input[type=text],
input[type=time],
input[type=url],
input[type=week] {
  padding: 10px;
  max-width: 100%;
  border: 0px;
  font-size: 15px;
  font-weight: normal;
  line-height: 22px;
  box-shadow: 0 1px 2px rgba(0, 0, 0, 0.12) inset;
  -moz-box-shadow: 0 1px 2px rgba(0, 0, 0, 0.12) inset;
  -webkit-box-shadow: 0 1px 2px rgba(0, 0, 0, 0.12) inset;
  -o-box-shadow: 0 1px 2px rgba(0, 0, 0, 0.12) inset;
  transition: all 0.2s linear;
  -moz-transition: all 0.2s linear;
  -webkit-transition: all 0.2s linear;
  -o-transition: all 0.2s linear;
  background-color: #f2f2f2;
  border-bottom: 1px solid #fff;
  box-sizing: border-box;
  color: #000000;
}
textarea:not(.editor-post-title__input):focus,
input[type=date]:focus,
input[type=datetime]:focus,
input[type=datetime-local]:focus,
input[type=email]:focus,
input[type=month]:focus,
input[type=number]:focus,
input[type=password]:focus,
input[type=search]:focus,
input[type=tel]:focus,
input[type=text]:focus,
input[type=time]:focus,
input[type=url]:focus,
input[type=week]:focus {
  box-shadow: 0 1px 2px rgba(0, 0, 0, 0.12) inset;
  -moz-box-shadow: 0 1px 2px rgba(0, 0, 0, 0.12) inset;
  -webkit-box-shadow: 0 1px 2px rgba(0, 0, 0, 0.12) inset;
  -o-box-shadow: 0 1px 2px rgba(0, 0, 0, 0.12) inset;
  transition: all 0.2s linear;
  -moz-transition: all 0.2s linear;
  -webkit-transition: all 0.2s linear;
  -o-transition: all 0.2s linear;
  border-color: #EBEBEB;
  border-bottom: 1px solid #fff !important;
  background: #e9e9e9;
}

button::-moz-focus-inner {
  border: 0;
  padding: 0;
}

input[type=radio], input[type=checkbox] {
  margin: 0 10px;
}

/*------------------------------
	2.8 Accessibility
------------------------------*/
/* Text meant only for screen readers */
.screen-reader-text {
  clip: rect(1px, 1px, 1px, 1px);
  position: absolute !important;
}

.screen-reader-text:hover,
.screen-reader-text:active,
.screen-reader-text:focus {
  background-color: #f8f9f9;
  -webkit-border-radius: 3px;
  -moz-border-radius: 3px;
  border-radius: 3px;
  clip: auto !important;
  color: #03c4eb;
  display: block;
  height: auto;
  left: 5px;
  line-height: normal;
  padding: 17px;
  text-decoration: none;
  top: 5px;
  width: auto;
  z-index: 100000;
  /* Above WP toolbar */
}

/*------------------------------
	2.8 Accessibility
------------------------------*/
/*------------------------------
	2.9 Alignments
------------------------------*/
.alignleft {
  display: inline;
  float: left;
  margin-right: 3.5em;
}

.alignright {
  display: inline;
  float: right;
  margin-left: 3.5em;
}

.aligncenter {
  clear: both;
  display: block;
  margin-left: auto;
  margin-right: auto;
}

/*------------------------------
	3.0 Clearings
------------------------------*/
.clear:before,
.clear:after,
.entry-content:before,
.entry-content:after,
.comment-content:before,
.comment-content:after,
.site-header:before,
.site-header:after,
.site-content:before,
.site-content:after,
.site-footer:before,
.site-footer:after {
  content: "";
  display: table;
  clear: both;
}

.clear:after,
.entry-content:after,
.comment-content:after,
.site-header:after,
.site-content:after,
.site-footer:after {
  clear: both;
}

/*------------------------------
	3.1 Infinite Scroll
------------------------------*/
/* Globally hidden elements when Infinite Scroll is supported and in use. */
.infinite-scroll .posts-navigation,
.infinite-scroll.neverending .site-footer {
  /* Theme Footer (when set to scrolling) */
  display: none;
}

/* When Infinite Scroll has reached its end we need to re-display elements that were hidden (via .neverending) before. */
.infinity-end.neverending .site-footer {
  display: block;
}

/*------------------------------
	3.1 Helper.
------------------------------*/
.hide {
  display: none;
}

.clearleft {
  clear: left;
}

.break, h1,
h2,
h3,
h4,
h5,
h6, p, ul, ol, dl, blockquote, pre {
  word-break: break-word;
  word-wrap: break-word;
}

body.mce-content-body {
  margin: 20px 40px;
  font-size: 13px;
}

/*--------------------------------------------------------------
3.0 Layout
--------------------------------------------------------------*/
#primary {
  padding-bottom: 40px;
  padding-top: 40px;
}

.template-fullwidth-stretched #primary,
.siteorigin-panels #primary {
  padding: 0;
}
.template-fullwidth-stretched .entry-content,
.siteorigin-panels .entry-content {
  margin-bottom: 0px;
}

#secondary {
  padding-bottom: 40px;
  padding-top: 0;
}
@media screen and (min-width: 940px) {
  #secondary {
    padding-top: 40px;
  }
}

.content-area {
  width: 100%;
  float: none;
}
@media screen and (min-width: 940px) {
  .content-area {
    float: left;
  }
}

.sidebar {
  width: 100%;
  float: none;
}
@media screen and (min-width: 940px) {
  .sidebar {
    width: 25.2252252252%;
    float: left;
  }
}

.left-sidebar .site-main {
  margin-left: auto;
}

.no-sidebar .content-area {
  width: 100%;
}

.single-post .no-sidebar .site-main,
.single-post .no-sidebar .entry-content > * {
  margin-left: auto;
  margin-right: auto;
}

@media screen and (min-width: 940px) {
  .left-sidebar .content-area {
    float: right;
    padding-left: 39px;
    border-left: 1px solid #e9e9e9;
    margin-right: 1px;
    width: 74.7747747748%;
  }

  .left-sidebar .sidebar {
    padding-right: 39px;
    border-right: 1px solid #e9e9e9;
    margin-right: -1px;
  }

  .right-sidebar .content-area {
    padding-right: 39px;
    border-right: 1px solid #e9e9e9;
    width: 74.7747747748%;
  }

  .right-sidebar .sidebar {
    padding-left: 39px;
    border-left: 1px solid #e9e9e9;
    margin-left: -1px;
  }
}
/**
Footer widgets
 */
.footer-widgets {
  background: #050505;
}
.footer-widgets.section-padding {
  padding: 70px 0px 35px;
  padding: 4.375rem 0rem 2.1875rem;
}
.footer-widgets table {
  border-collapse: collapse;
}
.footer-widgets table > thead > tr > th,
.footer-widgets table > thead > tr > td {
  border-width: 1px;
}
.footer-widgets table th,
.footer-widgets table td {
  border-color: rgba(233, 233, 233, 0.4);
}
.footer-widgets .widget-title {
  color: #ffffff;
}
.footer-widgets .widget-area .widget_categories li,
.footer-widgets .widget-area .widget_archive li,
.footer-widgets .widget-area .widget_meta li {
  width: 100% !important;
  float: none;
}
.footer-widgets .widget_recent_entries ul li,
.footer-widgets .widget_recent_comments ul li {
  border-bottom: 0px none;
  padding: 5px 0px;
  margin-bottom: 0px;
}
.footer-widgets .sidebar .widget {
  margin-bottom: 30px;
}

/*--------------------------------------------------------------
4.0 Structure
--------------------------------------------------------------*/
/* Header
------------------------------*/
.site-header {
  line-height: 25px;
  position: relative;
  width: 100%;
  background: #242d2e;;
  z-index: 1000;
  -webkit-transition: all 1s ease-out;
  /* Safari */
  transition: all 0.5s ease-out;
  box-shadow: 0 5px 10px 0 rgba(50, 50, 50, 0.06);
}
.site-header.header-fixed {
  top: 0px;
  left: 0px;
  position: fixed;
/* display:none !important; */
}
.site-header .custom-logo-transparent {
  display: none;
}

.followWrap {
  display: block;
}

.header-full-width .container {
  max-width: auto;
  width: auto;
}
@media screen and (min-width: 940px) {
  .header-full-width .container {
    padding-left: 30px;
    padding-right: 30px;
  }
}

.is-transparent .followWrap {
  z-index: 99;
  width: 100%;
  background: transparent;
  position: absolute;
  top: 0px;
  display: block;
}
.is-transparent .site-header {
  background: transparent;
  position: fixed;
  top: 0px;
}
.is-transparent .site-header.no-sticky {
  position: absolute;
  top: auto;
}
.is-transparent .site-header.no-scroll {
  box-shadow: none;
}
.is-transparent .site-header.no-scroll .has-t-logo .custom-logo-transparent {
  display: inline-block;
}
.is-transparent .site-header.no-scroll .has-t-logo .custom-logo {
  display: none;
}
.is-transparent .site-header.no-scroll #nav-toggle span {
  background-color: #ffffff;
}
.is-transparent .site-header.no-scroll #nav-toggle span::before, .is-transparent .site-header.no-scroll #nav-toggle span::after {
  background-color: #ffffff;
}
.is-transparent .site-header.no-scroll #nav-toggle.nav-is-visible span {
  background-color: transparent;
}
.is-transparent .site-header.header-fixed {
  background: #ffffff;
}
.is-transparent .site-header.header-fixed.no-scroll {
  background: transparent;
  box-shadow: none;
}

@media screen and (min-width: 1140px) {
  .is-transparent .no-scroll.site-header .onepress-menu > li > a {
    color: rgba(255, 255, 255, 0.9);
  }
}
.is-transparent .hero-slideshow-fullscreen .hero__content {
  padding-top: 50px;
  padding-top: 3.125rem;
}

.site-branding {
  float: left;
}

.site-branding .site-title,
.site-branding .site-text-logo {
  margin: 0px;
  line-height: 1;
  font-family: "Raleway", Helvetica, Arial, sans-serif;
  font-size: 23px;
  letter-spacing: 1px;
  text-transform: uppercase;
  color: #000000;
  display: initial;
  vertical-align: middle;
  font-weight: 600;
}
.site-branding .site-title:hover,
.site-branding .site-text-logo:hover {
  text-decoration: none;
}
.site-branding .site-title {
  display: inline-block;
}
.site-branding .site-image-logo {
  display: block;
}
.site-branding .site-logo-div {
  line-height: 75px;
}
.site-branding .no-logo-img.has-desc,
.site-branding .has-logo-img {
  line-height: 60px;
}
.site-branding .no-logo-img.has-desc .site-title,
.site-branding .has-logo-img .site-title {
  margin-top: -5px;
  position: relative;
}
.site-branding .no-logo-img.has-desc .site-description,
.site-branding .has-logo-img .site-description {
  font-size: 12px;
  line-height: 14px;
  margin-bottom: 0;
  position: relative;
  top: -15px;
  color: #000000;
}

.home.header-transparent .no-scroll .site-brand-inner,
.home.header-transparent .no-scroll .site-text-logo {
  color: #fff;
}

.header-social {
  margin-left: 0px;
  float: right;
}
@media screen and (min-width: 940px) {
  .header-social {
    margin-left: 10px;
  }
}
@media screen and (max-width: 576px) {
  .header-social {
    display: none;
  }
}
.header-social a {
  display: block;
  height: 100%;
  float: left;
  margin-left: 0px;
  margin-top: -2px;
  color: #03c4eb;
}
@media screen and (min-width: 940px) {
  .header-social a {
    margin-left: 3px;
  }
}
.header-social a:hover {
  color: #000000;
  transition: all 0.2s linear 0s;
}
.header-social .fa-stack-1x,
.header-social .fa-stack-2x {
  position: absolute;
  left: 0;
  width: 100%;
  text-align: center;
}
.header-social .fa-stack-1x {
  line-height: inherit;
}
.header-social .fa-stack-2x {
  font-size: 2em;
}
.header-social .fa-inverse {
  color: #ffffff;
}

.header-btn {
  float: right;
}

/* Site Navigation */
.onepress-menu,
.onepress-menu * {
  margin: 0;
  padding: 0;
  list-style: none;
}

.onepress-menu {
  float: right;
}
.onepress-menu ul {
  position: absolute;
  display: block;
  height: 1px;
  overflow: hidden;
  opacity: 0;
  z-index: -1;
  top: 100%;
  left: 0;
}
.onepress-menu ul.sub-ul-r {
  left: auto;
  right: 0px;
}
.onepress-menu ul ul {
  top: 0;
  left: 100%;
}
.onepress-menu li {
  position: relative;
}
.onepress-menu > li {
  float: left;
}
.onepress-menu li:hover > ul,
.onepress-menu li.sfHover > ul {
  display: block;
  height: initial;
  overflow: initial;
  opacity: 1;
  z-index: 99;
}
.onepress-menu a {
  display: block;
  position: relative;
}

.onepress-menu ul {
  min-width: 12em;
  width: fit-content;
  max-width: 100vw;
  border: 1px solid #e9e9e9;
  border-top: none;
}
.onepress-menu li {
  white-space: nowrap;
  *white-space: normal;
  -webkit-transition: background 0.2s;
  transition: background 0.2s;
}
.onepress-menu li:hover,
.onepress-menu li.sfHover {
  -webkit-transition: none;
  transition: none;
}
.onepress-menu a {
  color: #a4aeb0;;
  font-family: "Plus Jakarta Sans", Helvetica, Arial, sans-serif;

  font-size: 14px;
  font-weight: 600;
  text-transform: uppercase;
  text-decoration: none;
  zoom: 1;
  white-space: nowrap;
  letter-spacing: 1.4px;
  padding: 18px;
    transition: .25s ease;
	line-height: 55px;
}
.onepress-menu a:hover {
  color: #facd49;
}
.onepress-menu ul li {
  line-height: 26px;
  width: fit-content;
  min-width: 100%;
}
.onepress-menu ul li a {
  border-top: 1px solid #e9e9e9;
  padding: 8px 18px;
  color: #999999;
  font-size: 13px;
  text-transform: none;
  background: #ffffff;
  letter-spacing: 0;
}
.onepress-menu ul li a:hover {
  color: #03c4eb;
}
.onepress-menu li.onepress-current-item > a {
  color: #03c4eb;
}
.onepress-menu ul li.current-menu-item > a {
  color: #03c4eb;
}
.onepress-menu > li:last-child > a {
  padding-right: 0px;
}
.onepress-menu > li a.menu-actived {
  color: #03c4eb;
}
.onepress-menu .nav-toggle-subarrow {
  display: none;
}

#nav-toggle {
  display: none;
  margin-left: 15px;
}

@media screen and (max-width: 1140px) {
  .main-navigation {
    position: static;
  }

  .main-navigation .onepress-menu {
    width: 100% !important;
    display: block;
    height: 0px;
    overflow: hidden;
    background: #fff;
  }

  .onepress-menu.onepress-menu-mobile {
    position: absolute;
    top: 75px;
    right: 0;
    width: 100%;
    z-index: 800;
    overflow: auto !important;
    border-top: 1px solid #e9e9e9;
    border-bottom: 1px solid #e9e9e9;
  }
  .onepress-menu.onepress-menu-mobile .sub-menu {
    width: auto;
  }
  .onepress-menu.onepress-menu-mobile > li > a {
    padding: 12px 20px;
  }
  .onepress-menu.onepress-menu-mobile li:hover ul {
    display: none;
  }
  .onepress-menu.onepress-menu-mobile ul {
    box-shadow: none;
    padding-bottom: 0;
    border: none;
    position: relative;
  }
  .onepress-menu.onepress-menu-mobile ul li:last-child {
    border-bottom: none;
  }
  .onepress-menu.onepress-menu-mobile ul li a {
    padding: 12px 35px;
    border-top: none;
    white-space: pre-line;
  }
  .onepress-menu.onepress-menu-mobile ul li a:hover {
    background: transparent;
  }
  .onepress-menu.onepress-menu-mobile ul li li a {
    padding: 12px 70px;
    border-top: none;
  }
  .onepress-menu.onepress-menu-mobile ul li li li a {
    padding: 12px 105px;
  }
  .onepress-menu.onepress-menu-mobile ul ul {
    left: 0px;
  }
  .onepress-menu.onepress-menu-mobile li {
    line-height: 20px;
    background: #ffffff;
    border-top: 1px solid #e9e9e9;
    width: 100% !important;
  }
  .onepress-menu.onepress-menu-mobile > li:first-child {
    border-top: 0px none;
  }
  .onepress-menu.onepress-menu-mobile li.onepress-current-item > a {
    color: #03c4eb;
  }
  .onepress-menu.onepress-menu-mobile a {
    color: #777777;
  }
  .onepress-menu.onepress-menu-mobile a:hover {
    color: #000000;
  }
  .onepress-menu.onepress-menu-mobile .nav-toggle-subarrow {
    display: block;
    color: #999999;
    border-left: 1px solid #e9e9e9;
    font-weight: normal;
    position: absolute;
    top: 0;
    right: 0;
    cursor: pointer;
    text-align: center;
    padding: 11px 20px;
    z-index: 10;
    font-size: 22px;
  }
  .onepress-menu.onepress-menu-mobile .nav-toggle-dropdown > .nav-toggle-subarrow .fa-angle-down:before {
    content: "" !important;
  }
  .onepress-menu.onepress-menu-mobile .nav-toggle-dropdown > ul {
    left: 0px;
    display: block !important;
    height: initial;
    overflow: initial;
    opacity: 1;
    z-index: inherit;
  }

  #nav-toggle {
    display: block;
  }
}
#nav-toggle {
  float: right;
  position: relative;
  width: 35px;
  overflow: hidden;
  white-space: nowrap;
  color: transparent;
}
#nav-toggle span {
  position: absolute;
  top: 50%;
  right: 5px;
  margin-top: -2px;
  -webkit-transition: rotate 0.2s, translate 0.2s;
  -moz-transition: rotate 0.2s, translate 0.2s;
  transition: rotate 0.2s, translate 0.2s;
  display: inline-block;
  height: 3px;
  width: 24px;
  background: #000000;
}
#nav-toggle span:before {
  top: -8px;
}
#nav-toggle span:after {
  top: 8px;
}
#nav-toggle span:before, #nav-toggle span:after {
  position: absolute;
  display: inline-block;
  height: 3px;
  width: 24px;
  background: #000000;
  content: "";
  right: 0;
  -webkit-transform: translateZ(0);
  -moz-transform: translateZ(0);
  -ms-transform: translateZ(0);
  -o-transform: translateZ(0);
  transform: translateZ(0);
  -webkit-backface-visibility: hidden;
  backface-visibility: hidden;
  -webkit-transform-origin: 0% 50%;
  -moz-transform-origin: 0% 50%;
  -ms-transform-origin: 0% 50%;
  -o-transform-origin: 0% 50%;
  transform-origin: 0% 50%;
  -webkit-transition: -webkit-transform 0.2s;
  -moz-transition: -moz-transform 0.2s;
  transition: transform 0.2s;
}

#nav-toggle.nav-is-visible span {
  background: transparent;
}
#nav-toggle.nav-is-visible span:before {
  -webkit-transform: translateX(4px) translateY(-1px) rotate(45deg);
  -moz-transform: translateX(4px) translateY(-1px) rotate(45deg);
  -ms-transform: translateX(4px) translateY(-1px) rotate(45deg);
  -o-transform: translateX(4px) translateY(-1px) rotate(45deg);
  transform: translateX(4px) translateY(-1px) rotate(45deg);
}
#nav-toggle.nav-is-visible span:after {
  -webkit-transform: translateX(4px) translateY(0px) rotate(-45deg);
  -moz-transform: translateX(4px) translateY(0px) rotate(-45deg);
  -ms-transform: translateX(4px) translateY(0px) rotate(-45deg);
  -o-transform: translateX(4px) translateY(0px) rotate(-45deg);
  transform: translateX(4px) translateY(0px) rotate(-45deg);
}
#nav-toggle.nav-is-visible span:before, #nav-toggle.nav-is-visible span:after {
  background: #000000;
}

/* Content
------------------------------*/
.site-content {
  border-top: 1px solid #e9e9e9;
  margin-top: -1px;
}

.site-content.no-border {
  border-top: none;
}

.blog .site-content,
.tax-portfolio_cat .site-content,
.single-post .site-content,
.hiding-page-title .site-content {
  margin-top: 0;
}

.page-header {
  padding: 30px 0px;
  border-top: 1px solid #e9e9e9;
  background: #f8f9f9;
  border-bottom: 1px solid #e9e9e9;
  position: relative;
}
.page-header:before {
  position: absolute;
  top: 0px;
  bottom: 0;
  left: 0;
  width: 100%;
  display: block;
  content: " ";
}
.page-header .entry-title,
.page-header .page-title {
  margin-bottom: 0px;
  font-size: 24px;
  font-weight: 600;
  letter-spacing: 1px;
  text-transform: uppercase;
}
.page-header p {
  margin: 6px 0px 0px 0px;
}
.page-header.page--cover {
  position: relative;
  padding: 8% 0px;
  text-align: center;
  border-top: 0 none;
  border-bottom: 0 none;
  -webkit-background-size: cover;
  -moz-background-size: cover;
  -o-background-size: cover;
  background-size: cover;
  background-position: center center;
  background-repeat: no-repeat;
}
.page-header.page--cover:before {
  position: absolute;
  top: 0px;
  bottom: 0;
  left: 0;
  width: 100%;
  display: block;
  background: rgba(0, 0, 0, 0.3);
  content: " ";
}
.page-header.page--cover .entry-title {
  font-size: 2.5rem;
  font-weight: 800;
  color: #ffffff;
}
.page-header.page--cover .entry-tagline {
  color: #ffffff;
  font-style: italic;
  font-weight: 300;
}
@media screen and (min-width: 1140px) {
  .page-header.page--cover .entry-tagline {
    font-size: 20px;
  }
}
@media screen and (max-width: 940px) {
  .page-header.page--cover .entry-tagline {
    font-size: 18px;
  }
}
@media screen and (max-width: 720px) {
  .page-header.page--cover .entry-tagline {
    font-size: 16px;
  }
}
.page-header.page--cover.is-t-above .container {
  margin-top: 30px;
}

/* Footer
------------------------------*/
.site-footer {
  background: #111111;
  color: #bbbbbb;
  font-size: 14px;
}
.site-footer a {
  color: #03c4eb;
}
.site-footer .footer-connect {
  padding: 90px 0px;
  padding: 80px 0px;
  padding: 5rem 0rem;
  text-align: center;
}
@media (max-width: 767px) {
  .site-footer .footer-connect .footer-subscribe {
    margin-bottom: 40px;
  }
}
.site-footer .footer-connect .follow-heading {
  color: #ffffff;
  margin-bottom: 20px;
  letter-spacing: 0.8px;
}
.site-footer .footer-connect .subs_input {
  background-color: rgba(255, 255, 255, 0.145);
  color: #cccccc;
  border-bottom: none;
  box-shadow: none;
  padding: 12px 15px 12px;
  border-radius: 2px;
  width: 60%;
  font-size: 13px;
}
.site-footer .footer-connect .subs_input:focus {
  border: none;
}
@media screen and (max-width: 1140px) {
  .site-footer .footer-connect .subs_input {
    width: 100%;
    margin-bottom: 4px;
  }
}
@media screen and (max-width: 940px) {
  .site-footer .footer-connect .subs_input {
    width: 70%;
    margin-bottom: 4px;
  }
}
@media screen and (max-width: 720px) {
  .site-footer .footer-connect .subs_input {
    width: 100%;
    margin-bottom: 4px;
  }
}
.site-footer .footer-connect .subs-button {
  margin: 0px;
  position: relative;
  top: 0px;
  padding: 16px 23px 16px;
}
@media screen and (max-width: 1140px) {
  .site-footer .footer-connect .subs-button {
    width: 100%;
  }
}
@media screen and (max-width: 940px) {
  .site-footer .footer-connect .subs-button {
    width: 70%;
  }
}
@media screen and (max-width: 720px) {
  .site-footer .footer-connect .subs-button {
    width: 100%;
  }
}
.site-footer .footer-connect input[type=text]:focus {
  border: none !important;
}
.site-footer .footer-social {
  text-align: center;
}
.site-footer .footer-social a {
  font-size: 30px;
  margin: 0px 13px;
  color: #ffffff;
}
.site-footer .footer-social a:hover {
  color: #03c4eb;
}
.site-footer .site-info {
  position: relative;
  text-align: center;
  padding: 35px 0px;
  background: #222222;
  font-weight: 500;
  color: #bbbbbb;
}
.site-footer .site-info a {
  color: #dddddd;
}
.site-footer .site-info a:hover {
  text-decoration: underline;
}
.site-footer .site-info .container {
  position: initial;
}
.site-footer .btt a {
  border-radius: 0px 20px 0 0;
  color: #999999;
  background: #222222;
  display: block;
  font-size: 30px;
  height: 50px;
  line-height: 50px;
  margin: auto;
  position: absolute;
  right: 60px;
  top: -25px;
  transition: all 0.2s linear 0s;
  width: 50px;
  z-index: 99;
  -webkit-transform: rotate(-45deg);
  -moz-transform: rotate(-45deg);
  -ms-transform: rotate(-45deg);
  -o-transform: rotate(-45deg);
}
.site-footer .btt a:hover {
  color: #03c4eb;
}
.site-footer .btt a i {
  -webkit-transform: rotate(45deg);
  -moz-transform: rotate(45deg);
  -ms-transform: rotate(45deg);
  -o-transform: rotate(45deg);
  margin-left: 3px;
}
@media screen and (max-width: 940px) {
  .site-footer .btt a {
    right: 0;
    left: 0;
  }
}

/*--------------------------------------------------------------
5.0 Contents
--------------------------------------------------------------*/
/* Page: 404
------------------------------*/
.error-404 .search-form,
.error-404 .widget {
  margin-bottom: 40px;
}
.error-404 .widgettitle,
.error-404 .widget-title {
  font-size: 15px;
  text-transform: uppercase;
  letter-spacing: 2px;
  margin-bottom: 13px;
  font-weight: 700;
}
.error-404 ul {
  padding-left: 0px;
}
.error-404 ul li {
  list-style: none;
}

/* Page: Search
------------------------------*/
.search-results .hentry {
  border-bottom: 1px solid #e9e9e9;
  padding-bottom: 25px;
  margin-bottom: 25px;
}
.search-results .entry-summary p {
  margin-bottom: 0px;
}
.search-results .entry-header .entry-title {
  font-size: 22px;
  line-height: 1.5;
  font-weight: 500;
}
.search-results .entry-header .entry-title a:hover {
  text-decoration: none;
}

/* Entry Header
------------------------------*/
.entry-header .entry-title {
  font-weight: 500;
  text-transform: none;
  letter-spacing: -0.6px;
  font-family: "Open Sans", Helvetica, Arial, sans-serif;
  font-size: 25px;
  line-height: 1.3;
}
@media screen and (min-width: 940px) {
  .entry-header .entry-title {
    font-size: 32px;
    line-height: 1.5;
  }
}

.entry-thumbnail {
  margin-bottom: 30px;
}

.single .entry-header .entry-title {
  margin-bottom: 10px;
}

.highlight {
  color: #03c4eb;
}

/* Entry Content
------------------------------*/
.entry-content {
  margin-bottom: 30px;
}
.entry-content blockquote {
  padding: 30px;
  position: relative;
  background: #f8f9f9;
  border-left: 3px solid #03c4eb;
  font-style: italic;
}
.entry-content blockquote p {
  margin: 0px;
}

/* Entry Stuff
------------------------------*/
.entry-meta {
  margin-bottom: 30px;
  text-transform: uppercase;
  letter-spacing: 1.5px;
  font-size: 12px;
  font-weight: 600;
  padding-bottom: 30px;
  border-bottom: 1px solid #e9e9e9;
}

.entry-footer {
  margin-bottom: 30px;
  padding-top: 30px;
  border-top: 1px solid #e9e9e9;
}
.entry-footer .cat-links,
.entry-footer .tags-links {
  display: block;
  text-transform: uppercase;
  letter-spacing: 1.5px;
  font-size: 12px;
  font-weight: 600;
  margin-top: 5px;
}

.nav-links {
  padding: 30px 0px;
  border-left: none;
  border-right: none;
  margin-bottom: 50px;
  flex-basis: 100%;
  text-align: center;
}
.nav-links .nav-previous {
  float: left;
}
.nav-links .nav-next {
  float: right;
}
.nav-links a,
.nav-links .page-numbers {
  background: #cccccc;
  color: #FFFFFF;
  padding: 12px 20px;
  font-weight: 600;
  font-size: 12px;
  letter-spacing: 1px;
  text-transform: uppercase;
  border-radius: 2px;
}
@media screen and (max-width: 940px) {
  .nav-links a,
.nav-links .page-numbers {
    padding: 6px 10px;
  }
}
.nav-links a:hover, .nav-links a.current,
.nav-links .page-numbers:hover,
.nav-links .page-numbers.current {
  background: #03c4eb;
  text-decoration: none;
}

.bypostauthor {
  margin: 0;
}

/* Sticky Post
------------------------------*/
.sticky .entry-title {
  padding-left: 20px;
  position: relative;
}
.sticky .entry-title:after {
  content: "";
  display: inline-block;
  font-family: "FontAwesome";
  font-style: normal;
  font-weight: normal;
  width: 12px;
  height: 12px;
  position: absolute;
  left: 0px;
  top: 2px;
  font-size: 22px;
  color: #aaaaaa;
}

/* WordPress caption style
------------------------------*/
.wp-caption {
  max-width: 100%;
  font-style: italic;
  line-height: 1.35;
  margin-bottom: 15px;
  margin-top: 5px;
}
.wp-caption img[class*=wp-image-] {
  display: block;
  max-width: 100%;
}
.wp-caption .wp-caption-text {
  margin: 10px 0px;
}

.wp-caption-text,
.entry-thumbnail-caption,
.cycle-caption {
  font-style: italic;
  line-height: 1.35;
  font-size: 13px;
}

/* WordPress Gallery
------------------------------*/
.gallery {
  margin-bottom: 1.5em;
}

.gallery-item {
  display: inline-block;
  text-align: center;
  vertical-align: top;
  width: 100%;
}
.gallery-columns-2 .gallery-item {
  max-width: 50%;
}
.gallery-columns-3 .gallery-item {
  max-width: 33.33%;
}
.gallery-columns-4 .gallery-item {
  max-width: 25%;
}
.gallery-columns-5 .gallery-item {
  max-width: 20%;
}
.gallery-columns-6 .gallery-item {
  max-width: 16.66%;
}
.gallery-columns-7 .gallery-item {
  max-width: 14.28%;
}
.gallery-columns-8 .gallery-item {
  max-width: 12.5%;
}
.gallery-columns-9 .gallery-item {
  max-width: 11.11%;
}

.gallery-caption {
  display: block;
}

/* Comments
------------------------------*/
#comments {
  padding-top: 30px;
  border-top: 1px solid #e9e9e9;
}
#comments .comments-title {
  margin-bottom: 20px;
  font-size: 18px;
  line-height: 26px;
  letter-spacing: 1.5px;
  text-transform: uppercase;
}
#comments .comment-list {
  list-style: none;
  padding-left: 0px;
}
#comments .comment-list .pingback {
  border-bottom: 1px solid #e9e9e9;
  padding: 20px 0;
  margin: 0;
}
#comments .comment-list .pingback p {
  margin: 0px;
}
#comments .comment-list .pingback:last-child {
  margin-bottom: 40px;
}
#comments .comment-content.entry-content {
  margin-bottom: 0px;
}
#comments .comment {
  list-style: none;
  margin: 30px 0;
}
#comments .comment .avatar {
  width: 60px;
  float: left;
  -webkit-border-radius: 3px;
  -moz-border-radius: 3px;
  border-radius: 3px;
}
#comments .comment .comment-wrapper {
  margin-left: 90px;
  padding: 25px 30px 15px 30px;
  background: #f8f9f9;
  position: relative;
}
#comments .comment .comment-wrapper:before {
  border-color: rgba(0, 0, 0, 0) #f6f7f9 rgba(0, 0, 0, 0) rgba(0, 0, 0, 0);
  border-style: solid;
  border-width: 0 10px 10px 0;
  content: "";
  height: 0;
  left: -9px;
  position: absolute;
  top: 0;
  width: 0;
}
#comments .comment .comment-wrapper .comment-meta .comment-time,
#comments .comment .comment-wrapper .comment-meta .comment-reply-link,
#comments .comment .comment-wrapper .comment-meta .comment-edit-link {
  color: #aaaaaa;
  text-transform: uppercase;
  letter-spacing: 0.3px;
  font-size: 11px;
}
#comments .comment .comment-wrapper .comment-meta .comment-time:hover,
#comments .comment .comment-wrapper .comment-meta .comment-reply-link:hover,
#comments .comment .comment-wrapper .comment-meta .comment-edit-link:hover {
  color: #03c4eb;
}
#comments .comment .comment-wrapper .comment-meta .comment-time:after,
#comments .comment .comment-wrapper .comment-meta .comment-reply-link:after,
#comments .comment .comment-wrapper .comment-meta .comment-edit-link:after {
  content: "/";
  padding: 0px 5px;
}
#comments .comment .comment-wrapper .comment-meta a:last-child:after {
  content: "";
}
#comments .comment .comment-wrapper .comment-meta cite .fn {
  font-weight: bold;
  font-style: normal;
  margin-right: 5px;
  text-transform: uppercase;
  letter-spacing: 1.5px;
  font-size: 14px;
}
#comments .comment .comment-wrapper .comment-meta cite span {
  padding: 3px 10px;
  background: #e9e9e9;
  -webkit-border-radius: 4px;
  -moz-border-radius: 4px;
  border-radius: 4px;
  margin-right: 10px;
}
#comments .comment .comment-wrapper a {
  text-decoration: none;
}
#comments .comment .children {
  padding-left: 30px;
}
#comments .comment .children .children {
  padding-left: 30px;
}
#comments .comment .children .children .children {
  padding-left: 0px;
}
@media screen and (min-width: 940px) {
  #comments .comment .children {
    padding-left: 90px;
  }
  #comments .comment .children .children {
    padding-left: 90px;
  }
  #comments .comment .children .children .children {
    padding-left: 90px;
  }
}
#comments .form-allowed-tags {
  display: none;
}
#comments a {
  text-decoration: none;
}
#comments a:hover {
  text-decoration: underline;
}

.comment-respond textarea,
.comment-respond textarea {
  width: 100%;
}

/* Comment Form
------------------------------*/
#respond {
  padding-top: 20px;
}
#respond .comment-form label {
  display: block;
  margin-bottom: 4px;
}
#respond .form-allowed-tags {
  font-size: 12px;
}
#respond .form-allowed-tags code {
  background: none;
}
#respond .comment-reply-title {
  font-size: 18px;
  letter-spacing: 1.5px;
  margin-bottom: 20px;
  text-transform: uppercase;
}
#respond .comment-notes {
  display: none;
}
#respond label {
  font-size: 13px;
  text-transform: uppercase;
  letter-spacing: 1.5px;
}

.full-screen .comments-area {
  max-width: 1110px;
  margin: 0 auto;
}

/* woocommerce
------------------------------*/
.woocommerce div.product form.cart .variations td.label {
  color: #777;
}

/* . Gutenberg  Editor  - Block Editor */
.wp-block-gallery.is-layout-flex {
  display: flex;
  flex-wrap: wrap;
}

/*--------------------------------------------------------------
6.0 Elements
--------------------------------------------------------------*/
/* Button
------------------------------*/
.btn {
  text-transform: uppercase;
  -webkit-border-radius: 2px;
  -moz-border-radius: 2px;
  border-radius: 2px;
  box-shadow: 0 -1px 0 0 rgba(0, 0, 0, 0.1) inset;
  font-size: 13px;
  font-size: 0.8125rem;
  font-weight: 600;
}
.btn:active, .btn:focus {
  outline: none;
}
.btn.btn-secondary-outline {
  box-shadow: none;
  border-color: rgba(255, 255, 255, 0.9);
  color: rgba(255, 255, 255, 0.9);
}
.btn.btn-secondary-outline:hover {
  background: #FFF;
  color: #333;
}

.btn-lg {
  font-size: 17px;
  font-size: 1.0625rem;
}

.btn-theme-primary {
  background: #03c4eb;
  color: #FFFFFF;
}
.btn-theme-primary:hover {
  color: #FFFFFF;
}

.btn-theme-primary-outline {
  background-color: transparent;
  background-image: none;
  border-color: #03c4eb;
  color: #03c4eb;
}
.btn-theme-primary-outline:hover {
  color: #FFF;
  background-color: #03c4eb;
  border-color: #03c4eb;
}

/* Loading
------------------------------*/
.slider-spinner {
  width: 40px;
  height: 40px;
  position: relative;
  margin: 100px auto;
}

.double-bounce1, .double-bounce2 {
  width: 100%;
  height: 100%;
  border-radius: 50%;
  background-color: #fff;
  opacity: 0.6;
  position: absolute;
  top: 0;
  left: 0;
  -webkit-animation: sk-bounce 2s infinite ease-in-out;
  animation: sk-bounce 2s infinite ease-in-out;
}

.double-bounce2 {
  -webkit-animation-delay: -1s;
  animation-delay: -1s;
}

@-webkit-keyframes sk-bounce {
  0%, 100% {
    -webkit-transform: scale(0);
  }
  50% {
    -webkit-transform: scale(1);
  }
}
@keyframes sk-bounce {
  0%, 100% {
    transform: scale(0);
    -webkit-transform: scale(0);
  }
  50% {
    transform: scale(1);
    -webkit-transform: scale(1);
  }
}
/* WP 4.7 Shortcut */
section > .customize-partial-edit-shortcut {
  z-index: 95;
}
section > .customize-partial-edit-shortcut button {
  left: 30px;
}

/*--------------------------------------------------------------
7.0 Widgets
--------------------------------------------------------------*/
.sidebar .widget {
  margin-bottom: 40px;
}
.sidebar .widget .widget-title {
  font-size: 15px;
  text-transform: uppercase;
  letter-spacing: 2px;
  margin-bottom: 13px;
  font-weight: 700;
}
.sidebar .widget ul {
  list-style: none;
  padding: 0px;
}
.sidebar .widget ul:after {
  clear: both;
  content: ".";
  display: block;
  height: 0;
  visibility: hidden;
}
.sidebar .widget a {
  color: #777777;
  font-size: 14px;
}
.sidebar .widget a:hover {
  color: #03c4eb;
  text-decoration: underline;
}

/* Search
------------------------------*/
.search-form {
  display: flex;
  width: 100%;
  align-items: center;
}
.search-form .search-field {
  width: 100% !important;
  padding: 10px 15px;
  padding: 0.625rem 0.9375rem;
}
.search-form .search-submit {
  width: auto;
  margin: 0px 0 0 0.5em;
  height: 100%;
}
.search-form label {
  flex-grow: 2;
  margin: 0px;
}

/* Recent Comment
------------------------------*/
.widget_recent_comments ul {
  margin-top: 25px;
}
.widget_recent_comments ul li {
  margin-bottom: 20px;
  padding-bottom: 20px;
  border-bottom: 1px solid #e9e9e9;
}
.widget_recent_comments ul a {
  font-style: italic;
}
.widget_recent_comments .comment-author-link a {
  font-weight: bold;
  font-style: normal;
}

/* Recent Categories, Archive, Meta
------------------------------*/
.widget-area .widget_categories li, .widget-area .widget_archive li, .widget-area .widget_meta li {
  float: left;
  margin-bottom: 0;
  width: 50%;
}
@media screen and (min-width: 720px) {
  .widget-area .widget_categories li, .widget-area .widget_archive li, .widget-area .widget_meta li {
    width: 50%;
  }
}
@media screen and (min-width: 940px) {
  .widget-area .widget_categories li, .widget-area .widget_archive li, .widget-area .widget_meta li {
    width: 100%;
    float: none;
  }
}
@media screen and (min-width: 1140px) {
  .widget-area .widget_categories li, .widget-area .widget_archive li, .widget-area .widget_meta li {
    width: 50%;
    float: left;
  }
}

.widget_recent_entries ul li {
  margin: 0px;
  padding: 10px 0px 10px 0px;
  border-bottom: 1px solid #e9e9e9;
}

.sidebar .widget_calendar a {
  color: #03c4eb;
  text-decoration: underline;
}

/*--------------------------------------------------------------
8.0 Sections
--------------------------------------------------------------*/
/* Section Stuffs
------------------------------*/
.section-padding {
  padding: 70px 0px;
  padding: 4.375rem 0rem;
}

.section-padding-lg {
  padding: 90px 0px;
  padding: 5.625rem 0rem;
}

.section-padding-larger {
  padding: 140px 0px;
  padding: 8.75rem 0rem;
}

.section-meta {
  background-color: #f8f9f9;
}

.onepage-section {
  position: relative;
  overflow: hidden;
}
.onepage-section:before {
  position: absolute;
  top: 0px;
  left: 0px;
  right: 0px;
  bottom: 0px;
  display: block;
  content: " ";
  z-index: 1;
}
.onepage-section .container-fluid,
.onepage-section .container {
  position: relative;
  z-index: 5;
}

.section-inverse {
  background: #222222;
}
.section-inverse .section-title-area .section-title {
  color: rgba(255, 255, 255, 0.99);
}
.section-inverse .section-title-area .section-subtitle {
  color: rgba(255, 255, 255, 0.7);
}
.section-inverse .section-title-area .section-subtitle::after {
  background: rgba(255, 255, 255, 0.8);
}
.section-inverse .pricing-table .pricing__item ul p {
  color: #777777;
}

.section-inverse-extended {
  background: #333333;
}
.section-inverse-extended .section-title-area .section-title {
  color: rgba(255, 255, 255, 0.99);
}
.section-inverse-extended .section-title-area .section-subtitle {
  color: rgba(255, 255, 255, 0.7);
}
.section-inverse-extended .section-title-area .section-subtitle::after {
  background: rgba(255, 255, 255, 0.8);
}

.section-inverse {
  color: rgba(255, 255, 255, 0.5);
}
.section-inverse h1, .section-inverse h2, .section-inverse h3, .section-inverse h4, .section-inverse h5, .section-inverse h6 {
  color: rgba(255, 255, 255, 0.9);
}
.section-inverse p {
  color: rgba(255, 255, 255, 0.5);
}

.section-title-area {
  margin-bottom: 60px;
  text-align: center;
}
.section-title-area .section-title {
  font-size: 30px;
  letter-spacing: 2px;
  font-weight: 800;
  position: relative;
  margin-bottom: 0px;
  text-transform: uppercase;
}
@media screen and (min-width: 940px) {
  .section-title-area .section-title {
    font-size: 40px;
    letter-spacing: 3.5px;
  }
}
.section-title-area .section-subtitle {
  color: #aaaaaa;
  font-size: 12px;
  display: inline-block;
  position: relative;
  margin-bottom: 13px;
  margin-bottom: 0.8125rem;
  text-transform: uppercase;
  letter-spacing: 2px;
}
@media screen and (min-width: 940px) {
  .section-title-area .section-subtitle {
    font-size: 14px;
  }
}

.section-desc {
  font-size: 20px;
  font-size: 1.25rem;
  margin-top: 40px;
  margin-top: 2.5rem;
}

/* Section: Hero
------------------------------*/
.hero-slideshow-wrapper {
  width: 100%;
  position: relative;
  background-color: #222222;
  overflow: hidden;
  /* Loading icon */
}
.hero-slideshow-wrapper:after {
  position: absolute;
  top: 0px;
  left: 0px;
  width: 100%;
  height: 100%;
  background-color: rgba(0, 0, 0, 0.3);
  display: block;
  content: "";
}
.hero-slideshow-wrapper .hero__content .hero-large-text, .hero-slideshow-wrapper .hero__content .hero-small-text, .hero-slideshow-wrapper .hero__content .btn,
.hero-slideshow-wrapper .hero__content .hcl2-content {
  visibility: hidden;
  opacity: 0;
  -webkit-transform: translateY(100px);
  transform: translateY(100px);
  -webkit-transition: all 0.5s linear;
  transition: all 0.5s linear;
}
.hero-slideshow-wrapper .hero__content .hero-large-text {
  -webkit-transition-delay: 0.7s;
  /* Safari */
  transition-delay: 0.7s;
}
.hero-slideshow-wrapper .hero__content .hero-small-text {
  -webkit-transition-delay: 0.8s;
  /* Safari */
  transition-delay: 0.8s;
}
.hero-slideshow-wrapper .hero__content .btn {
  -webkit-transition-delay: 1s;
  /* Safari */
  transition-delay: 1s;
}
.hero-slideshow-wrapper .hero__content .hcl2-content {
  -webkit-transition-delay: 0.7s;
  /* Safari */
  transition-delay: 0.7s;
}
.hero-slideshow-wrapper.loaded .container .hero__content:hover .hero-large-text, .hero-slideshow-wrapper.loaded .container .hero__content:hover .hero-small-text, .hero-slideshow-wrapper.loaded .container .hero__content:hover .btn {
  -webkit-transition-duration: 0.3s;
  transition-duration: 0.3s;
}
.hero-slideshow-wrapper.loaded .container .hero__content:hover .hero-large-text {
  -webkit-transition-delay: 0s;
  /* Safari */
  transition-delay: 0s;
}
.hero-slideshow-wrapper.loaded .container .hero__content:hover .hero-small-text {
  -webkit-transition-delay: 0s;
  /* Safari */
  transition-delay: 0s;
}
.hero-slideshow-wrapper.loaded .container .hero__content:hover .btn {
  -webkit-transition-delay: 0s;
  /* Safari */
  transition-delay: 0s;
}
.hero-slideshow-wrapper.loaded .container .hero__content .hero-large-text,
.hero-slideshow-wrapper.loaded .container .hero__content .hero-small-text,
.hero-slideshow-wrapper.loaded .container .hero__content .btn, .hero-slideshow-wrapper.loaded .container .hero__content .hcl2-content {
  visibility: visible;
  opacity: 1;
  -webkit-transform: translateY(0);
  transform: translateY(0);
}
.hero-slideshow-wrapper .slider-spinner {
  position: absolute;
  top: 50%;
  left: 50%;
  z-index: 9999999;
  margin: 0px;
  -webkit-transform: translate(-50%, -50%);
  transform: translate(-50%, -50%);
}

.animation-disable .hero-slideshow-wrapper {
  /* Loading icon */
}
.animation-disable .hero-slideshow-wrapper .hero__content .hero-large-text, .animation-disable .hero-slideshow-wrapper .hero__content .hero-small-text, .animation-disable .hero-slideshow-wrapper .hero__content .btn, .animation-disable .hero-slideshow-wrapper .hero__content .hcl2-content {
  -webkit-transform: translateY(0px);
  transform: translateY(0px);
}
.animation-disable .hero-slideshow-wrapper .hero__content .hero-large-text {
  -webkit-transition-delay: 0s;
  /* Safari */
  transition-delay: 0s;
}
.animation-disable .hero-slideshow-wrapper .hero__content .hero-small-text {
  -webkit-transition-delay: 0s;
  /* Safari */
  transition-delay: 0s;
}
.animation-disable .hero-slideshow-wrapper .hero__content .btn {
  -webkit-transition-delay: 0s;
  /* Safari */
  transition-delay: 0s;
}
.animation-disable .hero-slideshow-wrapper .hero__content .hcl2-content {
  -webkit-transition-delay: 0s;
  /* Safari */
  transition-delay: 0s;
}
.animation-disable .hero-slideshow-wrapper.loaded .container .hero__content:hover .hero-large-text, .animation-disable .hero-slideshow-wrapper.loaded .container .hero__content:hover .hero-small-text, .animation-disable .hero-slideshow-wrapper.loaded .container .hero__content:hover .btn, .animation-disable .hero-slideshow-wrapper.loaded .container .hero__content:hover .hcl2-content {
  -webkit-transition-delay: 0s;
  /* Safari */
  transition-delay: 0s;
}
.animation-disable .hero-slideshow-wrapper.loaded .container .hero__content:hover .hero-large-text {
  -webkit-transition-delay: 0s;
  /* Safari */
  transition-delay: 0s;
}
.animation-disable .hero-slideshow-wrapper.loaded .container .hero__content:hover .hero-small-text {
  -webkit-transition-delay: 0s;
  /* Safari */
  transition-delay: 0s;
}
.animation-disable .hero-slideshow-wrapper.loaded .container .hero__content:hover .btn {
  -webkit-transition-delay: 0s;
  /* Safari */
  transition-delay: 0s;
}
.animation-disable .hero-slideshow-wrapper.loaded .container .hero__content:hover .hcl2-content {
  -webkit-transition-delay: 0s;
  /* Safari */
  transition-delay: 0s;
}
.animation-disable .hero-slideshow-wrapper .slider-spinner {
  position: absolute;
  top: 50%;
  left: 50%;
  z-index: 9999999;
  margin: 0px;
  -webkit-transform: translate(-50%, -50%);
  transform: translate(-50%, -50%);
}

.js-rotating {
  display: none;
}
.js-rotating.morphext {
  display: inline-block;
}

.is-customize-preview .slider-spinner {
  display: none !important;
}
.is-customize-preview .hero-slideshow-wrapper .hero__content .hero-large-text, .is-customize-preview .hero-slideshow-wrapper .hero__content .hero-small-text, .is-customize-preview .hero-slideshow-wrapper .hero__content .btn, .is-customize-preview .hero-slideshow-wrapper .hero__content .hcl2-content {
  visibility: visible;
  opacity: 1;
  -webkit-transform: translateY(0px);
  transform: translateY(0px);
  -webkit-transition: all 0s linear;
  transition: all 0s linear;
}
.is-customize-preview .hero-slideshow-wrapper .hero__content .hero-large-text {
  -webkit-transition-delay: 0s;
  /* Safari */
  transition-delay: 0s;
}
.is-customize-preview .hero-slideshow-wrapper .hero__content .hero-small-text {
  -webkit-transition-delay: 0s;
  /* Safari */
  transition-delay: 0s;
}
.is-customize-preview .hero-slideshow-wrapper .hero__content .btn {
  -webkit-transition-delay: 0s;
  /* Safari */
  transition-delay: 0s;
}
.is-customize-preview .hero-slideshow-wrapper .hero__content .hcl2-content {
  -webkit-transition-delay: 0s;
  /* Safari */
  transition-delay: 0s;
}
.is-customize-preview .hero-slideshow-wrapper.loaded .container .hero__content:hover .hero-large-text, .is-customize-preview .hero-slideshow-wrapper.loaded .container .hero__content:hover .hero-small-text, .is-customize-preview .hero-slideshow-wrapper.loaded .container .hero__content:hover .btn, .is-customize-preview .hero-slideshow-wrapper.loaded .container .hero__content:hover .hcl2-content {
  -webkit-transition-duration: 0s;
  transition-duration: 0s;
}
.is-customize-preview .hero-slideshow-wrapper.loaded .container .hero__content:hover .hero-large-text {
  -webkit-transition-delay: 0s;
  /* Safari */
  transition-delay: 0s;
}
.is-customize-preview .hero-slideshow-wrapper.loaded .container .hero__content:hover .hero-small-text {
  -webkit-transition-delay: 0s;
  /* Safari */
  transition-delay: 0s;
}
.is-customize-preview .hero-slideshow-wrapper.loaded .container .hero__content:hover .btn {
  -webkit-transition-delay: 0s;
  /* Safari */
  transition-delay: 0s;
}
.is-customize-preview .hero-slideshow-wrapper.loaded .container .hero__content:hover .hcl2-content {
  -webkit-transition-delay: 0s;
  /* Safari */
  transition-delay: 0s;
}
.is-customize-preview .hero-slideshow-wrapper.loaded .container .hero__content .hero-large-text,
.is-customize-preview .hero-slideshow-wrapper.loaded .container .hero__content .hero-small-text,
.is-customize-preview .hero-slideshow-wrapper.loaded .container .hero__content .btn,
.is-customize-preview .hero-slideshow-wrapper.loaded .container .hero__content .hcl2-content {
  visibility: visible;
  opacity: 1;
  -webkit-transform: translateY(0);
  transform: translateY(0);
}

.hero-slideshow-normal .container {
  padding: 10% 0px;
  position: relative;
  z-index: 80;
}

.hero-slideshow-fullscreen .container {
  z-index: 80;
  position: relative;
  top: 50%;
  transform: translateY(-50%);
}

.hero__content {
  color: #FFF;
  text-shadow: 0 2px 8px rgba(0, 0, 0, 0.15);
  font-size: 18px;
  font-size: 1.125rem;
  font-weight: 300;
}
.hero__content h1, .hero__content h2, .hero__content h3, .hero__content h4, .hero__content h5, .hero__content h6 {
  color: #FFF;
  letter-spacing: 2px;
  text-transform: uppercase;
}
.hero__content a.btn {
  margin: 10px 10px 20px 0px;
  margin: 0.625rem 0.625rem 1.25rem 0rem;
}
.hero__content p {
  margin-bottom: 20px;
  margin-bottom: 1.25rem;
}

/* Hero Content Style 2. */
.hero-content-style2 h1 {
  font-weight: 800;
  font-size: 50px;
  font-size: 3.125rem;
  letter-spacing: 3px;
}
.hero-content-style2 .hcl2-content {
  padding: 50px 0px;
  padding: 3.125rem 0rem;
}
.hero-content-style2 .hcl2-image {
  text-align: right;
}
@media (max-width: 1199px) {
  .hero-content-style2 .hcl2-content, .hero-content-style2 .hcl2-image {
    text-align: center;
  }
}

/* Hero Text Style1. */
.hero-content-style1 {
  text-align: center;
}
.hero-content-style1 h2 {
  color: #FFFFFF;
  font-size: 35px;
  letter-spacing: 2px;
  line-height: 1.3;
  text-shadow: 0 2px 8px rgba(0, 0, 0, 0.15);
  font-weight: 800;
  text-transform: uppercase;
}
@media screen and (min-width: 720px) {
  .hero-content-style1 h2 {
    font-size: 60px;
    letter-spacing: 3px;
  }
}
@media screen and (min-width: 940px) {
  .hero-content-style1 h2 {
    font-size: 75px;
    letter-spacing: 4px;
  }
}
.hero-content-style1 h2 strong {
  font-weight: 900;
}
.hero-content-style1 p {
  font-size: 14px;
  font-style: italic;
  letter-spacing: 0.4px;
  text-shadow: 0 2px 8px rgba(0, 0, 0, 0.15);
  color: #FFFFFF;
  text-align: center;
  font-weight: 100;
  margin-bottom: 30px;
  margin-bottom: 1.875rem;
}
@media screen and (min-width: 940px) {
  .hero-content-style1 p {
    font-size: 18px;
  }
}
@media screen and (min-width: 1140px) {
  .hero-content-style1 p {
    font-size: 22px;
  }
}
.hero-content-style1 p strong {
  letter-spacing: -0.6px;
}
@media (max-width: 767px) {
  .hero-content-style1 .btn {
    display: inline-block;
  }
}
.hero-content-style1 a:active, .hero-content-style1 a:focus, .hero-content-style1 .btn:active, .hero-content-style1 .btn:focus {
  outline: none;
}

#hero .btn {
  box-shadow: none;
}
#hero .btn-theme-primary:focus {
  color: #fff;
}

.h-on-top.is-transparent #hero .container .hero__content {
  margin-top: 75px;
}

/* Text Rotator */
.morphext > .animated {
  display: inline-block;
}

/* Section: Features
------------------------------*/
.icon-background-default {
  color: #03c4eb;
}

.feature-item {
  text-align: center;
}
.feature-item .feature-icon {
  color: #fff;
}
.feature-item .fa-5x {
  font-size: 4em;
}
.feature-item:hover .icon-background-default {
  color: #333333;
  -webkit-transition: all 0.5s ease-in-out;
  -moz-transition: all 0.5s ease-in-out;
  -o-transition: all 0.5s ease-in-out;
  transition: all 0.5s ease-in-out;
  transform: scale(1.1);
  -webkit-transform: scale(1.1);
  -moz-transform: scale(1.1);
  -ms-transform: scale(1.1);
  transform: scale(1.1);
}
@media screen and (min-width: 940px) {
  .feature-item.col-lg-3:nth-child(4n+1), .feature-item.col-lg-4:nth-child(3n+1), .feature-item.col-lg-6:nth-child(2n+1) {
    clear: left;
  }
}

.feature-media {
  text-align: center;
  margin-bottom: 20px;
}

/* Section: About Us
------------------------------*/
.section-about .about-image {
  text-align: center;
}
.section-about .about-image img {
  margin-bottom: 30px;
}
.section-about .section-title-area {
  margin-bottom: 30px;
}
.section-about .row > div {
  margin-top: 30px;
}

/* Section: Services
------------------------------*/
.section-services .service-item {
  background: #FFFFFF;
  padding: 30px;
  margin-bottom: 30px;
  position: relative;
  box-shadow: 0 1px 1px rgba(0, 0, 0, 0.08);
  -moz-box-shadow: 0 1px 1px rgba(0, 0, 0, 0.08);
  -webkit-box-shadow: 0 1px 1px rgba(0, 0, 0, 0.08);
  transition: all 100ms ease-out 0s;
}
@media screen and (max-width: 720px) {
  .section-services .service-item {
    padding: 20px;
  }
}
.section-services .service-item:after {
  content: "";
  display: table;
  clear: both;
  clear: both;
}
.section-services .service-item:hover {
  box-shadow: 0 6px 9px rgba(0, 0, 0, 0.09);
}
.section-services .service-item .service-image {
  float: left;
  margin-right: 30px;
}
.section-services .service-item .service-image img {
  max-width: 120px;
  height: auto;
}
.section-services .service-item .service-image i {
  color: #03c4eb;
}
@media screen and (max-width: 720px) {
  .section-services .service-item .service-image {
    float: none;
    margin-bottom: 30px;
    margin-top: 10px;
    margin-right: 0px;
    text-align: center;
  }
}
.section-services .service-item .service-thumbnail {
  margin-bottom: 25px;
  margin-bottom: 1.5625rem;
}
.section-services .service-item .service-content {
  overflow: hidden;
}
.section-services .service-item .service-content p {
  margin: 0px;
  font-size: 14px;
  color: #777777;
}
@media screen and (max-width: 720px) {
  .section-services .service-item .service-content {
    text-align: center;
    overflow: auto;
  }
}
.section-services .service-item .service-title {
  margin-bottom: 10px;
  margin-bottom: 0.625rem;
  color: #333333;
}
.section-services .service-item .service-link:before {
  width: 100%;
  height: 100%;
  display: block;
  position: absolute;
  top: 0px;
  left: 0px;
  content: "";
}

/* Section: Counter
------------------------------*/
.counter_item {
  text-align: center;
  margin-bottom: 35px;
  margin-bottom: 2.1875rem;
}
.counter_item .counter__number {
  font-size: 50px;
  font-size: 3.125rem;
  font-weight: 800;
  color: #03c4eb;
  line-height: 1;
  font-family: serif, sans-serif;
  text-transform: uppercase;
}
.counter_item .counter_title {
  font-size: 18px;
  font-size: 1.125rem;
}

/* Section: Parallax
------------------------------*/
#parallax-hero {
  position: relative;
  background: none;
  overflow: hidden;
}
#parallax-hero .hero-slideshow-wrapper {
  background: none;
}
#parallax-hero .hero-slideshow-wrapper::after {
  background: none;
}

.section-parallax, #parallax-hero {
  background: none;
  position: relative;
  overflow: hidden;
}
.section-parallax > section, .section-parallax .onepage-section, .section-parallax .section-inverse, #parallax-hero > section, #parallax-hero .onepage-section, #parallax-hero .section-inverse {
  background: none;
}
.section-parallax .parallax-bg, #parallax-hero .parallax-bg {
  position: absolute;
  top: 0px;
  left: 0px;
  width: 100%;
  height: auto;
  min-height: 100%;
  display: block;
  -webkit-background-size: 100% auto;
  -moz-background-size: 100% auto;
  background-size: 100% auto;
  background-repeat: no-repeat;
  background-attachment: scroll;
  background-position: 50% 50%;
}
.section-parallax .parallax-bg:before, #parallax-hero .parallax-bg:before {
  content: " ";
  position: absolute;
  top: 0px;
  left: 0px;
  right: 0px;
  bottom: 0px;
  background: rgba(0, 0, 0, 0.3);
  display: block;
  width: 100%;
  height: 100%;
  z-index: 2;
}
.section-parallax .parallax-bg img, #parallax-hero .parallax-bg img {
  position: absolute;
  left: 0;
  bottom: 0;
  min-width: 100%;
  min-height: 100%;
  width: auto;
  height: auto;
  max-width: 9999999px;
}
.section-parallax .parallax-bg.no-img, #parallax-hero .parallax-bg.no-img {
  height: 120%;
  -webkit-background-size: cover;
  -moz-background-size: cover;
  background-size: cover;
  background-repeat: no-repeat;
  background-attachment: scroll;
  background-attachment: scroll;
  background-position: 50% 0;
}

.parallax_bg_overlay {
  position: absolute;
  width: 100%;
  height: 100%;
  left: 0;
  top: 0;
  z-index: 5;
  opacity: 0.4;
}

.parallax-content {
  z-index: 10;
  position: relative;
  padding: 100px 0px;
  text-align: center;
}
.parallax-content h1, .parallax-content h2, .parallax-content h3, .parallax-content h4, .parallax-content h5, .parallax-content h6 {
  color: #FFFFFF;
  line-height: 1.5;
}
.parallax-content p, .parallax-content a {
  color: #FFFFFF;
}

/* Section: Team
------------------------------*/
.section-team .team-member {
  padding: 0px 0.5px;
  text-align: center;
}
.section-team .row {
  margin-left: -0.5px;
  margin-right: -0.5px;
}

.team-members.row {
  margin-left: 0px;
  margin-left: 0rem;
  margin-right: 0px;
  margin-right: 0rem;
}
@media screen and (min-width: 940px) {
  .team-members.row.team-layout-4 .team-member {
    width: 25%;
  }
  .team-members.row.team-layout-4 .team-member:nth-child(4n+1) {
    clear: left;
  }
  .team-members.row.team-layout-3 .team-member {
    width: 33.3333333333%;
  }
  .team-members.row.team-layout-3 .team-member:nth-child(3n+1) {
    clear: left;
  }
  .team-members.row.team-layout-2 .team-member {
    width: 50%;
  }
  .team-members.row.team-layout-2 .team-member:nth-child(2n+1) {
    clear: left;
  }
}
@media screen and (max-width: 940px) {
  .team-members.row .team-member {
    width: 50%;
  }
  .team-members.row .team-member:nth-child(2n+1) {
    clear: left;
  }
}
@media screen and (max-width: 720px) {
  .team-members.row .team-member {
    width: 50%;
  }
  .team-members.row .team-member:nth-child(2n+1) {
    clear: left;
  }
}
@media screen and (max-width: 576px) {
  .team-members.row .team-member {
    width: 100%;
  }
}

.team-member {
  margin-bottom: 20px;
  float: left;
}
.team-member .member-thumb {
  margin-bottom: 20px;
  position: relative;
  overflow: hidden;
}
.team-member .member-thumb:hover .member-profile {
  bottom: 8px;
  transition: all 0.1s linear;
}
.team-member .member-thumb:hover img {
  opacity: 0.7;
  transition: all 0.1s linear;
}
.team-member .member-thumb .member-profile {
  position: absolute;
  text-align: center;
  bottom: -35px;
  left: auto;
  right: auto;
  width: 100%;
}
.team-member .member-thumb .member-profile a {
  color: #000000;
}
.team-member .member-thumb .member-profile a .fa-inverse {
  color: #ffffff;
}
.team-member .member-thumb .member-profile a:hover {
  color: #03c4eb;
}
.team-member .member-info {
  margin-top: 0px;
  position: relative;
  z-index: 30;
  text-align: center;
}
.team-member .member-name {
  letter-spacing: 2px;
  margin-bottom: 15px;
  position: relative;
}
.team-member .member-name:after {
  content: "";
  display: block;
  position: absolute;
  left: 50%;
  margin-left: -15%;
  bottom: -11px;
  width: 30%;
  height: 1px;
  background: #cccccc;
}
.team-member .member-position {
  text-transform: uppercase;
  font-size: 10px;
  letter-spacing: 1.3px;
}

/* Section: News
------------------------------*/
.all-news {
  text-align: center;
  margin-top: 40px;
  display: block;
}

.section-news .list-article, .archive .list-article, .blog .list-article {
  border-top: 1px solid #e9e9e9;
  padding: 25px 0px;
}
.section-news .list-article:last-of-type, .archive .list-article:last-of-type, .blog .list-article:last-of-type {
  border-bottom: 1px solid #e9e9e9;
}
.section-news .list-article-thumb, .archive .list-article-thumb, .blog .list-article-thumb {
  float: left;
  margin-right: 30px;
}
.section-news .list-article-thumb a img:hover, .archive .list-article-thumb a img:hover, .blog .list-article-thumb a img:hover {
  opacity: 0.8;
}
@media screen and (max-width: 940px) {
  .section-news .list-article-thumb, .archive .list-article-thumb, .blog .list-article-thumb {
    display: none;
  }
}
@media screen and (max-width: 720px) {
  .section-news .list-article-thumb, .archive .list-article-thumb, .blog .list-article-thumb {
    width: 100%;
    float: none;
    margin-right: 0px;
    margin-bottom: 30px;
    display: block;
  }
  .section-news .list-article-thumb img, .archive .list-article-thumb img, .blog .list-article-thumb img {
    width: 100%;
  }
}
.section-news .list-article-content, .archive .list-article-content, .blog .list-article-content {
  float: none;
  overflow: hidden;
}
.section-news .list-article-meta, .archive .list-article-meta, .blog .list-article-meta {
  font-size: 11px;
  font-weight: bold;
  text-transform: uppercase;
  letter-spacing: 1.2px;
  margin-bottom: 10px;
}
.section-news .entry-title, .archive .entry-title, .blog .entry-title {
  font-size: 22px;
  line-height: 1.5;
}
.section-news .entry-title a:hover, .archive .entry-title a:hover, .blog .entry-title a:hover {
  text-decoration: none;
}
.section-news .entry-excerpt p, .archive .entry-excerpt p, .blog .entry-excerpt p {
  margin-bottom: 0px;
}

.archive .site-main .list-article:first-child,
.blog .site-main .list-article:first-of-type {
  border-top: none;
  padding-top: 0px;
}

.page-template-template-blog .section-news .list-article {
  padding: 30px 0px;
}
.page-template-template-blog .section-news .list-article:first-of-type {
  border-top: none;
  padding-top: 0px;
}
.page-template-template-blog .section-news .list-article:last-of-type {
  border-bottom: none;
}

.section-news.section-inverse .list-article {
  border-top: 1px solid rgba(255, 255, 255, 0.2);
}
.section-news.section-inverse .list-article:last-of-type {
  border-bottom: 1px solid rgba(255, 255, 255, 0.2);
}
.section-news.section-inverse h1 a, .section-news.section-inverse h2 a, .section-news.section-inverse h3 a, .section-news.section-inverse h4 a, .section-news.section-inverse h5 a {
  color: rgba(255, 255, 255, 0.8);
}
.section-news.section-inverse h1 a:hover, .section-news.section-inverse h2 a:hover, .section-news.section-inverse h3 a:hover, .section-news.section-inverse h4 a:hover, .section-news.section-inverse h5 a:hover {
  color: #FFF;
}

/* Section: Contact
------------------------------*/
.section-contact input, .section-contact textarea {
  width: 100%;
}
.section-contact .address-contact {
  margin-top: 5px;
  margin-bottom: 15px;
}
.section-contact .address-contact span {
  float: left;
  color: #aaaaaa;
}
.section-contact .address-contact .address-content {
  display: block;
  padding-left: 45px;
  font-style: italic;
  line-height: 2;
}
.section-contact .address-contact .fa-inverse {
  font-size: 12px;
}
.section-contact textarea {
  max-height: 190px;
}

.wpcf7-form {
  text-transform: uppercase;
  font-size: 11px;
  letter-spacing: 2px;
  font-weight: 600;
}
.wpcf7-form br {
  margin-bottom: 5px;
}
.wpcf7-form label {
  width: 100%;
}

div.wpcf7-validation-errors {
  margin: 20px 0px;
  padding: 15px;
}

div.wpcf7-response-output {
  margin: 20px 0px;
}

/* Section: Videolightbox
------------------------------*/
.section-videolightbox {
  text-align: center;
}
.section-videolightbox .videolightbox__icon {
  margin-bottom: 40px;
  margin-bottom: 2.5rem;
}
.section-videolightbox .videolightbox__heading {
  text-transform: uppercase;
  font-size: 38px;
  font-size: 2.375rem;
  letter-spacing: 0px;
  font-weight: 500;
}
.section-videolightbox .videolightbox__heading strong {
  font-weight: 800;
}
.section-videolightbox .video_icon {
  background: rgba(0, 0, 0, 0.2) none repeat scroll 0 0;
  border: 4px solid #fff;
  border-radius: 100px;
  height: 50px;
  line-height: 1;
  padding: 10px;
  width: 50px;
  display: inline-block;
}
.section-videolightbox .video_icon i {
  color: #fff;
  font-size: 20px;
  margin-left: 6px;
  margin-top: 1px;
  line-height: 1;
}
.section-videolightbox .video_icon:hover {
  background: #FFFFFF;
}
.section-videolightbox .video_icon:hover i {
  color: #000;
}

/* Section: Gallery
------------------------------*/
.gallery-grid .g-item {
  padding: 10px;
  float: left;
}

.all-gallery {
  text-align: center;
  margin-top: 40px;
  display: block;
}

.g-zoom-in .g-item {
  display: block;
  overflow: hidden;
}
.g-zoom-in .g-item .inner-content {
  display: block;
  width: 100%;
  height: 100%;
  overflow: hidden;
}
.g-zoom-in .g-item img {
  display: block;
  overflow: hidden;
  -webkit-transition: all 0.5s linear;
  transition: all 0.5s linear;
}
.g-zoom-in .g-item:hover img {
  -ms-transform: scale(1.5, 1.5);
  /* IE 9 */
  -webkit-transform: scale(1.5, 1.5);
  /* Safari */
  transform: scale(1.5, 1.5);
}

.g-layout-full-width.container {
  width: 100%;
  max-width: none;
  padding: 0px;
}

@media screen and (min-width: 720px) {
  .g-col-1 .g-item {
    width: 100%;
  }
  .g-col-1 .g-item:nth-child(1n+1) {
    clear: left;
  }

  .g-col-2 .g-item {
    width: 50%;
  }
  .g-col-2 .g-item:nth-child(2n+1) {
    clear: left;
  }

  .g-col-3 .g-item {
    width: 33.3333333333%;
  }
  .g-col-3 .g-item:nth-child(3n+1) {
    clear: left;
  }

  .g-col-4 .g-item {
    width: 25%;
  }
  .g-col-4 .g-item:nth-child(4n+1) {
    clear: left;
  }

  .g-col-5 .g-item {
    width: 20%;
  }
  .g-col-5 .g-item:nth-child(5n+1) {
    clear: left;
  }

  .g-col-6 .g-item {
    width: 16.6666666667%;
  }
  .g-col-6 .g-item:nth-child(6n+1) {
    clear: left;
  }
}
@media screen and (min-width: 576px) and (max-width: 720px) {
  .g-col-1 .g-item {
    width: 100%;
  }
  .g-col-1 .g-item:nth-child(1n+1) {
    clear: left;
  }

  .g-col-2 .g-item {
    width: 50%;
  }
  .g-col-2 .g-item:nth-child(2n+1) {
    clear: left;
  }

  .g-col-3 .g-item {
    width: 33.3333333333%;
  }
  .g-col-3 .g-item:nth-child(3n+1) {
    clear: left;
  }

  .g-col-4 .g-item {
    width: 25%;
  }
  .g-col-4 .g-item:nth-child(4n+1) {
    clear: left;
  }

  .g-col-5 .g-item {
    width: 20%;
  }
  .g-col-5 .g-item:nth-child(5n+1) {
    clear: left;
  }

  .g-col-6 .g-item {
    width: 16.6666666667%;
  }
  .g-col-6 .g-item:nth-child(6n+1) {
    clear: left;
  }
}
@media screen and (max-width: 576px) {
  .g-col-1 .g-item {
    width: 100%;
  }
  .g-col-1 .g-item:nth-child(1n+1) {
    clear: left;
  }

  .g-col-2 .g-item {
    width: 50%;
  }
  .g-col-2 .g-item:nth-child(2n+1) {
    clear: left;
  }

  .g-col-3 .g-item {
    width: 33.3333333333%;
  }
  .g-col-3 .g-item:nth-child(3n+1) {
    clear: left;
  }

  .g-col-4 .g-item {
    width: 25%;
  }
  .g-col-4 .g-item:nth-child(4n+1) {
    clear: left;
  }

  .g-col-5 .g-item {
    width: 20%;
  }
  .g-col-5 .g-item:nth-child(5n+1) {
    clear: left;
  }

  .g-col-6 .g-item {
    width: 16.6666666667%;
  }
  .g-col-6 .g-item:nth-child(6n+1) {
    clear: left;
  }
}
.gallery-justified {
  width: 100%;
  position: relative;
  overflow: hidden;
}
.gallery-justified img {
  max-width: none;
  position: absolute;
  top: 50%;
  left: 50%;
  margin: 0;
  padding: 0;
  border: none;
}

.gallery-justified > a,
.gallery-justified > div {
  position: absolute;
  display: inline-block;
  overflow: hidden;
  float: left;
}

.gallery-masonry {
  width: 100%;
  position: relative;
  display: block;
}
.gallery-masonry:after {
  clear: both;
}
.gallery-masonry .inner {
  display: block;
}

/*--------------------------------------------------------------
9.0 External Plugins
--------------------------------------------------------------*/
/* Magnific Popup CSS */
.mfp-bg {
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  z-index: 1042;
  overflow: hidden;
  position: fixed;
  background: #0b0b0b;
  opacity: 0.8;
  filter: alpha(opacity=80);
}

.mfp-wrap {
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  z-index: 1043;
  position: fixed;
  outline: none !important;
  -webkit-backface-visibility: hidden;
}

.mfp-container {
  text-align: center;
  position: absolute;
  width: 100%;
  height: 100%;
  left: 0;
  top: 0;
  padding: 0 8px;
  -webkit-box-sizing: border-box;
  -moz-box-sizing: border-box;
  box-sizing: border-box;
}

.mfp-container:before {
  content: "";
  display: inline-block;
  height: 100%;
  vertical-align: middle;
}

.mfp-align-top .mfp-container:before {
  display: none;
}

.mfp-content {
  position: relative;
  display: inline-block;
  vertical-align: middle;
  margin: 0 auto;
  text-align: left;
  z-index: 1045;
}

.mfp-inline-holder .mfp-content,
.mfp-ajax-holder .mfp-content {
  width: 100%;
  cursor: auto;
}

.mfp-ajax-cur {
  cursor: progress;
}

.mfp-zoom-out-cur, .mfp-zoom-out-cur .mfp-image-holder .mfp-close {
  cursor: -moz-zoom-out;
  cursor: -webkit-zoom-out;
  cursor: zoom-out;
}

.mfp-zoom {
  cursor: pointer;
  cursor: -webkit-zoom-in;
  cursor: -moz-zoom-in;
  cursor: zoom-in;
}

.mfp-auto-cursor .mfp-content {
  cursor: auto;
}

.mfp-close,
.mfp-arrow,
.mfp-preloader,
.mfp-counter {
  -webkit-user-select: none;
  -moz-user-select: none;
  user-select: none;
}

.mfp-loading.mfp-figure {
  display: none;
}

.mfp-hide {
  display: none !important;
}

.mfp-preloader {
  color: #CCC;
  position: absolute;
  top: 50%;
  width: auto;
  text-align: center;
  margin-top: -0.8em;
  left: 8px;
  right: 8px;
  z-index: 1044;
}
.mfp-preloader a {
  color: #CCC;
}
.mfp-preloader a:hover {
  color: #FFF;
}

.mfp-s-ready .mfp-preloader {
  display: none;
}

.mfp-s-error .mfp-content {
  display: none;
}

button.mfp-close, button.mfp-arrow {
  overflow: visible;
  cursor: pointer;
  background: transparent;
  border: 0;
  -webkit-appearance: none;
  display: block;
  outline: none;
  padding: 0;
  z-index: 1046;
  -webkit-box-shadow: none;
  box-shadow: none;
}
button::-moz-focus-inner {
  padding: 0;
  border: 0;
}

.mfp-close {
  width: 44px;
  height: 44px;
  line-height: 44px;
  position: absolute;
  right: 0;
  top: 0;
  text-decoration: none;
  text-align: center;
  opacity: 0.65;
  filter: alpha(opacity=65);
  padding: 0 0 18px 10px;
  color: #FFF;
  font-style: normal;
  font-size: 28px;
  font-family: Arial, Baskerville, monospace;
}
.mfp-close:hover, .mfp-close:focus {
  opacity: 1;
  filter: alpha(opacity=100);
}
.mfp-close:active {
  top: 1px;
}

.mfp-close-btn-in .mfp-close {
  color: #333;
}

.mfp-image-holder .mfp-close,
.mfp-iframe-holder .mfp-close {
  color: #FFF;
  right: -6px;
  text-align: right;
  padding-right: 6px;
  width: 100%;
}

.mfp-counter {
  position: absolute;
  top: 0;
  right: 0;
  color: #CCC;
  font-size: 12px;
  line-height: 18px;
  white-space: nowrap;
}

.mfp-arrow {
  position: absolute;
  opacity: 0.65;
  filter: alpha(opacity=65);
  margin: 0;
  top: 50%;
  margin-top: -55px;
  padding: 0;
  width: 90px;
  height: 110px;
  -webkit-tap-highlight-color: rgba(0, 0, 0, 0);
}
.mfp-arrow:active {
  margin-top: -54px;
}
.mfp-arrow:hover, .mfp-arrow:focus {
  opacity: 1;
  filter: alpha(opacity=100);
}
.mfp-arrow:before, .mfp-arrow:after,
.mfp-arrow .mfp-b,
.mfp-arrow .mfp-a {
  content: "";
  display: block;
  width: 0;
  height: 0;
  position: absolute;
  left: 0;
  top: 0;
  margin-top: 35px;
  margin-left: 35px;
  border: medium inset transparent;
}
.mfp-arrow:after,
.mfp-arrow .mfp-a {
  border-top-width: 13px;
  border-bottom-width: 13px;
  top: 8px;
}
.mfp-arrow:before,
.mfp-arrow .mfp-b {
  border-top-width: 21px;
  border-bottom-width: 21px;
  opacity: 0.7;
}

.mfp-arrow-left {
  left: 0;
}
.mfp-arrow-left:after,
.mfp-arrow-left .mfp-a {
  border-right: 17px solid #FFF;
  margin-left: 31px;
}
.mfp-arrow-left:before,
.mfp-arrow-left .mfp-b {
  margin-left: 25px;
  border-right: 27px solid #3F3F3F;
}

.mfp-arrow-right {
  right: 0;
}
.mfp-arrow-right:after,
.mfp-arrow-right .mfp-a {
  border-left: 17px solid #FFF;
  margin-left: 39px;
}
.mfp-arrow-right:before,
.mfp-arrow-right .mfp-b {
  border-left: 27px solid #3F3F3F;
}

.mfp-iframe-holder {
  padding-top: 40px;
  padding-bottom: 40px;
}
.mfp-iframe-holder .mfp-content {
  line-height: 0;
  width: 100%;
  max-width: 900px;
}
.mfp-iframe-holder .mfp-close {
  top: -40px;
}

.mfp-iframe-scaler {
  width: 100%;
  height: 0;
  overflow: hidden;
  padding-top: 56.25%;
}
.mfp-iframe-scaler iframe {
  position: absolute;
  display: block;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  box-shadow: 0 0 8px rgba(0, 0, 0, 0.6);
  background: #000;
}

/* Main image in popup */
img.mfp-img {
  width: auto;
  max-width: 100%;
  height: auto;
  display: block;
  line-height: 0;
  -webkit-box-sizing: border-box;
  -moz-box-sizing: border-box;
  box-sizing: border-box;
  padding: 40px 0 40px;
  margin: 0 auto;
}

/* The shadow behind the image */
.mfp-figure {
  line-height: 0;
}
.mfp-figure:after {
  content: "";
  position: absolute;
  left: 0;
  top: 40px;
  bottom: 40px;
  display: block;
  right: 0;
  width: auto;
  height: auto;
  z-index: -1;
  box-shadow: 0 0 8px rgba(0, 0, 0, 0.6);
  background: #444;
}
.mfp-figure small {
  color: #BDBDBD;
  display: block;
  font-size: 12px;
  line-height: 14px;
}
.mfp-figure figure {
  margin: 0;
}

.mfp-bottom-bar {
  margin-top: -36px;
  position: absolute;
  top: 100%;
  left: 0;
  width: 100%;
  cursor: auto;
}

.mfp-title {
  text-align: left;
  line-height: 18px;
  color: #F3F3F3;
  word-wrap: break-word;
  padding-right: 36px;
}

.mfp-image-holder .mfp-content {
  max-width: 100%;
}

.mfp-gallery .mfp-image-holder .mfp-figure {
  cursor: pointer;
}

@media screen and (max-width: 800px) and (orientation: landscape), screen and (max-height: 300px) {
  /**
   * Remove all paddings around the image on small screen
   */
  .mfp-img-mobile .mfp-image-holder {
    padding-left: 0;
    padding-right: 0;
  }
  .mfp-img-mobile img.mfp-img {
    padding: 0;
  }
  .mfp-img-mobile .mfp-figure:after {
    top: 0;
    bottom: 0;
  }
  .mfp-img-mobile .mfp-figure small {
    display: inline;
    margin-left: 5px;
  }
  .mfp-img-mobile .mfp-bottom-bar {
    background: rgba(0, 0, 0, 0.6);
    bottom: 0;
    margin: 0;
    top: auto;
    padding: 3px 5px;
    position: fixed;
    -webkit-box-sizing: border-box;
    -moz-box-sizing: border-box;
    box-sizing: border-box;
  }
  .mfp-img-mobile .mfp-bottom-bar:empty {
    padding: 0;
  }
  .mfp-img-mobile .mfp-counter {
    right: 5px;
    top: 3px;
  }
  .mfp-img-mobile .mfp-close {
    top: 0;
    right: 0;
    width: 35px;
    height: 35px;
    line-height: 35px;
    background: rgba(0, 0, 0, 0.6);
    position: fixed;
    text-align: center;
    padding: 0;
  }
}
@media all and (max-width: 900px) {
  .mfp-arrow {
    -webkit-transform: scale(0.75);
    transform: scale(0.75);
  }

  .mfp-arrow-left {
    -webkit-transform-origin: 0;
    transform-origin: 0;
  }

  .mfp-arrow-right {
    -webkit-transform-origin: 100%;
    transform-origin: 100%;
  }

  .mfp-container {
    padding-left: 6px;
    padding-right: 6px;
  }
}
.mfp-ie7 .mfp-img {
  padding: 0;
}
.mfp-ie7 .mfp-bottom-bar {
  width: 600px;
  left: 50%;
  margin-left: -300px;
  margin-top: 5px;
  padding-bottom: 5px;
}
.mfp-ie7 .mfp-container {
  padding: 0;
}
.mfp-ie7 .mfp-content {
  padding-top: 44px;
}
.mfp-ie7 .mfp-close {
  top: 0;
  right: 0;
  padding-top: 0;
}

/* WooCommerce support */
.woocommerce-result-count {
  font-style: italic;
}

.woocommerce .woocommerce-ordering, .woocommerce .woocommerce-result-count {
  margin-bottom: 1.5em;
}

.woocommerce-ordering select {
  padding: 7px;
  margin-top: -10px;
}

.woocommerce ul.products li.product h3 {
  font-size: 18px;
  font-size: 1.125rem;
  margin-bottom: 7px;
}

.woocommerce #respond input#submit, .woocommerce a.button, .woocommerce button.button, .woocommerce input.button, .woocommerce button.button.alt {
  background-color: #03c4eb;
  padding: 10px 20px;
  padding: 0.625rem 1.25rem;
  color: #FFF;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.5px;
  font-size: 13px;
  font-size: 0.8125rem;
  border-radius: 2px;
}
.woocommerce #respond input#submit:hover, .woocommerce a.button:hover, .woocommerce button.button:hover, .woocommerce input.button:hover, .woocommerce button.button.alt:hover {
  background: #222222;
  color: #FFF;
  -webkit-transition: all 0.2s ease-in-out;
  -moz-transition: all 0.2s ease-in-out;
  -o-transition: all 0.2s ease-in-out;
  transition: all 0.2s ease-in-out;
}

.woocommerce table.shop_table {
  border-collapse: collapse;
}

.woocommerce .quantity .qty {
  padding: 5px;
}

.woocommerce span.onsale {
  padding: inherit;
}

.related.products h2, #tab-description h2 {
  font-size: 17px;
  font-size: 1.0625rem;
  margin-bottom: 20px;
  text-transform: uppercase;
  letter-spacing: 1px;
}

.woocommerce nav.woocommerce-pagination ul li a, .woocommerce nav.woocommerce-pagination ul li span {
  padding: 9px 14px;
  font-weight: bold;
}

.woocommerce #customer_details .col-1, .woocommerce #customer_details .col-2, .woocommerce #customer_login .col-1, .woocommerce #customer_login .col-2,
.woocommerce .woocommerce-Addresses .col-1,
.woocommerce .woocommerce-Addresses .col-2,
.woocommerce .woocommerce-customer-details .col-1,
.woocommerce .woocommerce-customer-details .col-2 {
  max-width: 100%;
  padding-left: 0px;
  padding-right: 0px;
}
.woocommerce .woocommerce-additional-fields h3 {
  margin-top: 20px;
}
.woocommerce .cart_totals th {
  text-align: left;
}
.woocommerce .cart_totals h2 {
  font-size: 20px;
  font-size: 1.25rem;
}
.woocommerce .wc-proceed-to-checkout {
  text-align: center;
}
.woocommerce .woocommerce-order-details__title,
.woocommerce .woocommerce-customer-details h2 {
  font-size: 20px;
  font-size: 1.25rem;
}

.woocommerce ul.products li.product .price del {
  display: inline-block;
}

.woocommerce .cart-collaterals .cart_totals, .woocommerce-page .cart-collaterals .cart_totals {
  width: 100%;
  float: none;
}

#add_payment_method .wc-proceed-to-checkout a.checkout-button,
.woocommerce-cart .wc-proceed-to-checkout a.checkout-button,
.woocommerce-checkout .wc-proceed-to-checkout a.checkout-button {
  display: inline-block;
  margin: 0 auto;
}

.woocommerce #respond input#submit.alt,
.woocommerce a.button.alt,
.woocommerce button.button.alt,
.woocommerce input.button.alt {
  background-color: #03c4eb;
}
.woocommerce #respond input#submit.alt:hover,
.woocommerce a.button.alt:hover,
.woocommerce button.button.alt:hover,
.woocommerce input.button.alt:hover {
  background-color: #03c4eb;
  opacity: 0.8;
}

.woocommerce-MyAccount-navigation ul {
  margin: 0px;
  padding-left: 0px;
}
.woocommerce-MyAccount-navigation li {
  list-style: none;
}

/* Breadcrumbs
------------------------------*/
.breadcrumbs {
  font-size: 10px;
  padding: 15px 0px;
  border-bottom: 1px solid #e9e9e9;
  color: #858585;
}
@media screen and (min-width: 720px) {
  .breadcrumbs {
    font-size: 12px;
  }
}
.breadcrumbs i {
  margin: 0px 6px;
}
.breadcrumbs a {
  text-decoration: none;
  color: #777777;
  font-weight: 600;
}
.breadcrumbs a:hover {
  text-decoration: underline;
}
.breadcrumbs span {
  margin-right: 20px;
  position: relative;
}
@media screen and (min-width: 720px) {
  .breadcrumbs span {
    margin-right: 40px;
  }
}
.breadcrumbs span span {
  margin-right: 0;
}
.breadcrumbs a:before {
  border-bottom: 6px solid transparent;
  border-left: 6px solid rgba(0, 0, 0, 0.2);
  border-top: 6px solid transparent;
  content: "";
  display: inline-block;
  position: absolute;
  right: -11px;
  top: 2px;
}
@media screen and (min-width: 720px) {
  .breadcrumbs a:before {
    right: -23px;
    top: 3px;
  }
}
.breadcrumbs a:after {
  border-bottom: 5px solid transparent;
  border-left: 5px solid #ffffff;
  border-top: 5px solid transparent;
  content: "";
  display: inline-block;
  position: absolute;
  right: -10px;
  top: 3px;
}
@media screen and (min-width: 720px) {
  .breadcrumbs a:after {
    right: -22px;
    top: 4px;
  }
}

/* Coursel and slider */
/**
 * Owl Carousel v2.3.0
 * Copyright 2013-2017 David Deutsch
 * Licensed under  ()
 */
/*
 *  Owl Carousel - Core
 */
.owl-carousel {
  display: none;
  width: 100%;
  -webkit-tap-highlight-color: transparent;
  /* position relative and z-index fix webkit rendering fonts issue */
  position: relative;
  z-index: 1;
}

.owl-carousel .owl-stage {
  position: relative;
  -ms-touch-action: pan-Y;
  touch-action: manipulation;
  -moz-backface-visibility: hidden;
  /* fix firefox animation glitch */
}

.owl-carousel .owl-stage:after {
  content: ".";
  display: block;
  clear: both;
  visibility: hidden;
  line-height: 0;
  height: 0;
}

.owl-carousel .owl-stage-outer {
  position: relative;
  overflow: hidden;
  /* fix for flashing background */
  -webkit-transform: translate3d(0px, 0px, 0px);
}

.owl-carousel .owl-wrapper,
.owl-carousel .owl-item {
  -webkit-backface-visibility: hidden;
  -moz-backface-visibility: hidden;
  -ms-backface-visibility: hidden;
  -webkit-transform: translate3d(0, 0, 0);
  -moz-transform: translate3d(0, 0, 0);
  -ms-transform: translate3d(0, 0, 0);
}

.owl-carousel .owl-item {
  position: relative;
  min-height: 1px;
  float: left;
  -webkit-backface-visibility: hidden;
  -webkit-tap-highlight-color: transparent;
  -webkit-touch-callout: none;
}

.owl-carousel .owl-item img {
  display: block;
  width: 100%;
}

.owl-carousel .owl-nav.disabled,
.owl-carousel .owl-dots.disabled {
  display: none;
}

.owl-carousel .owl-nav .owl-prev,
.owl-carousel .owl-nav .owl-next,
.owl-carousel .owl-dot {
  cursor: pointer;
  cursor: hand;
  -webkit-user-select: none;
  -khtml-user-select: none;
  -moz-user-select: none;
  -ms-user-select: none;
  user-select: none;
}

.owl-carousel.owl-loaded {
  display: block;
}

.owl-carousel.owl-loading {
  opacity: 0;
  display: block;
}

.owl-carousel.owl-hidden {
  opacity: 0;
}

.owl-carousel.owl-refresh .owl-item {
  visibility: hidden;
}

.owl-carousel.owl-drag .owl-item {
  -ms-touch-action: none;
  touch-action: none;
  -webkit-user-select: none;
  -moz-user-select: none;
  -ms-user-select: none;
  user-select: none;
}

.owl-carousel.owl-grab {
  cursor: move;
  cursor: grab;
}

.owl-carousel.owl-rtl {
  direction: rtl;
}

.owl-carousel.owl-rtl .owl-item {
  float: right;
}

/* No Js */
.no-js .owl-carousel {
  display: block;
}

/*
 *  Owl Carousel - Animate Plugin
 */
.owl-carousel .animated {
  -webkit-animation-duration: 1000ms;
  animation-duration: 1000ms;
  -webkit-animation-fill-mode: both;
  animation-fill-mode: both;
}

.owl-carousel .owl-animated-in {
  z-index: 0;
}

.owl-carousel .owl-animated-out {
  z-index: 1;
}

.owl-carousel .fadeOut {
  -webkit-animation-name: fadeOut;
  animation-name: fadeOut;
}

@-webkit-keyframes fadeOut {
  0% {
    opacity: 1;
  }
  100% {
    opacity: 0;
  }
}
@keyframes fadeOut {
  0% {
    opacity: 1;
  }
  100% {
    opacity: 0;
  }
}
/*
 * 	Owl Carousel - Auto Height Plugin
 */
.owl-height {
  transition: height 500ms ease-in-out;
}

/*
 * 	Owl Carousel - Lazy Load Plugin
 */
.owl-carousel .owl-item .owl-lazy {
  opacity: 0;
  transition: opacity 400ms ease;
}

.owl-carousel .owl-item img.owl-lazy {
  -webkit-transform-style: preserve-3d;
  transform-style: preserve-3d;
}

/*
 * 	Owl Carousel - Video Plugin
 */
.owl-carousel .owl-video-wrapper {
  position: relative;
  height: 100%;
  background: #000;
}

.owl-carousel .owl-video-playing .owl-video-tn,
.owl-carousel .owl-video-playing .owl-video-play-icon {
  display: none;
}

.owl-carousel .owl-video-tn {
  opacity: 0;
  height: 100%;
  background-position: center center;
  background-repeat: no-repeat;
  background-size: contain;
  transition: opacity 400ms ease;
}

.owl-carousel .owl-video-frame {
  position: relative;
  z-index: 1;
  height: 100%;
  width: 100%;
}

/**
 * Owl Carousel v2.2.1
 * Copyright 2013-2017 David Deutsch
 * Licensed under  ()
 */
/*
 * 	Default theme - Owl Carousel CSS File
 */
.owl-theme {
  position: relative;
}
.owl-theme .owl-nav button {
  position: absolute;
  top: 50%;
  background-color: rgba(0, 0, 0, 0.45);
  border-radius: 2px;
  color: #999;
  cursor: pointer;
  display: block;
  font-size: 22px;
  margin-top: 0px;
  padding: 4px 10px 5px;
  transform: translateY(-50%);
  border: 0px none;
}
.owl-theme .owl-nav button:focus {
  box-shadow: none;
  outline: none;
}
.owl-theme .owl-nav:hover {
  background-color: rgba(0, 0, 0, 0.6);
  color: #fff;
}
.owl-theme .owl-nav .owl-prev {
  left: 15px;
}
.owl-theme .owl-nav .owl-prev .lg-icon::before {
  content: "";
}
.owl-theme .owl-nav .owl-next {
  right: 15px;
}
.owl-theme .owl-nav .owl-next .lg-icon::before {
  content: "";
}

.owl-theme .owl-nav {
  margin-top: 0px;
  text-align: center;
  -webkit-tap-highlight-color: transparent;
}

.gallery-carousel.owl-theme .owl-nav [class*=owl-] {
  color: #FFF;
  font-size: 14px;
  margin: 5px;
  padding: 4px 7px;
  display: inline-block;
  cursor: pointer;
  border-radius: 3px;
}

.owl-theme .owl-nav [class*=owl-]:hover {
  background: #869791;
  color: #FFF;
  text-decoration: none;
}

.owl-theme .owl-nav .disabled {
  opacity: 0.5;
  cursor: default;
}

.owl-theme .owl-nav.disabled + .owl-dots {
  margin-top: 10px;
}

.owl-theme .owl-dots {
  text-align: center;
  -webkit-tap-highlight-color: transparent;
}

.owl-theme .owl-dots .owl-dot {
  display: inline-block;
  zoom: 1;
  *display: inline;
  background: none !important;
  box-shadow: none !important;
  outline: none !important;
  border: 0px none;
  padding: 0px;
}

.owl-theme .owl-dots .owl-dot span {
  width: 10px;
  height: 10px;
  margin: 5px 7px;
  background: #D6D6D6;
  display: block;
  -webkit-backface-visibility: visible;
  transition: opacity 200ms ease;
  border-radius: 30px;
}

.owl-theme .owl-dots .owl-dot.active span, .owl-theme .owl-dots .owl-dot:hover span {
  background: #869791;
}

/* WP FORMS */
div.wpforms-container .wpforms-form .wpforms-field .wpforms-field-label, div.wpforms-container .wpforms-form .wpforms-field .wpforms-field-sublabel {
  text-transform: uppercase;
  font-size: 11px;
  letter-spacing: 2px;
  font-weight: 600;
}
div.wpforms-container .wpforms-form .wpforms-field-row.wpforms-field-medium {
  max-width: 100% !important;
}
div.wpforms-container .wpforms-form .wpforms-field input[type=date],
div.wpforms-container .wpforms-form .wpforms-field input[type=datetime],
div.wpforms-container .wpforms-form .wpforms-field input[type=datetime-local],
div.wpforms-container .wpforms-form .wpforms-field input[type=email],
div.wpforms-container .wpforms-form .wpforms-field input[type=month],
div.wpforms-container .wpforms-form .wpforms-field input[type=number],
div.wpforms-container .wpforms-form .wpforms-field input[type=password],
div.wpforms-container .wpforms-form .wpforms-field input[type=range],
div.wpforms-container .wpforms-form .wpforms-field input[type=search],
div.wpforms-container .wpforms-form .wpforms-field input[type=tel],
div.wpforms-container .wpforms-form .wpforms-field input[type=text],
div.wpforms-container .wpforms-form .wpforms-field input[type=time],
div.wpforms-container .wpforms-form .wpforms-field input[type=url],
div.wpforms-container .wpforms-form .wpforms-field input[type=week],
div.wpforms-container .wpforms-form .wpforms-field select,
div.wpforms-container .wpforms-form .wpforms-field textarea {
  padding: 10px;
  max-width: 100%;
  border: 0px;
  font-size: 15px;
  font-weight: normal;
  line-height: 22px;
  box-shadow: 0 1px 2px rgba(0, 0, 0, 0.12) inset;
  -moz-box-shadow: 0 1px 2px rgba(0, 0, 0, 0.12) inset;
  -webkit-box-shadow: 0 1px 2px rgba(0, 0, 0, 0.12) inset;
  -o-box-shadow: 0 1px 2px rgba(0, 0, 0, 0.12) inset;
  transition: all 0.2s linear;
  -moz-transition: all 0.2s linear;
  -webkit-transition: all 0.2s linear;
  -o-transition: all 0.2s linear;
  background-color: #f2f2f2;
  border-bottom: 1px solid #fff;
  box-sizing: border-box;
  color: #000000;
  border-bottom: 1px solid #fff;
}
div.wpforms-container .wpforms-form .wpforms-field input[type=date]:hover, div.wpforms-container .wpforms-form .wpforms-field input[type=date]:focus,
div.wpforms-container .wpforms-form .wpforms-field input[type=datetime]:hover,
div.wpforms-container .wpforms-form .wpforms-field input[type=datetime]:focus,
div.wpforms-container .wpforms-form .wpforms-field input[type=datetime-local]:hover,
div.wpforms-container .wpforms-form .wpforms-field input[type=datetime-local]:focus,
div.wpforms-container .wpforms-form .wpforms-field input[type=email]:hover,
div.wpforms-container .wpforms-form .wpforms-field input[type=email]:focus,
div.wpforms-container .wpforms-form .wpforms-field input[type=month]:hover,
div.wpforms-container .wpforms-form .wpforms-field input[type=month]:focus,
div.wpforms-container .wpforms-form .wpforms-field input[type=number]:hover,
div.wpforms-container .wpforms-form .wpforms-field input[type=number]:focus,
div.wpforms-container .wpforms-form .wpforms-field input[type=password]:hover,
div.wpforms-container .wpforms-form .wpforms-field input[type=password]:focus,
div.wpforms-container .wpforms-form .wpforms-field input[type=range]:hover,
div.wpforms-container .wpforms-form .wpforms-field input[type=range]:focus,
div.wpforms-container .wpforms-form .wpforms-field input[type=search]:hover,
div.wpforms-container .wpforms-form .wpforms-field input[type=search]:focus,
div.wpforms-container .wpforms-form .wpforms-field input[type=tel]:hover,
div.wpforms-container .wpforms-form .wpforms-field input[type=tel]:focus,
div.wpforms-container .wpforms-form .wpforms-field input[type=text]:hover,
div.wpforms-container .wpforms-form .wpforms-field input[type=text]:focus,
div.wpforms-container .wpforms-form .wpforms-field input[type=time]:hover,
div.wpforms-container .wpforms-form .wpforms-field input[type=time]:focus,
div.wpforms-container .wpforms-form .wpforms-field input[type=url]:hover,
div.wpforms-container .wpforms-form .wpforms-field input[type=url]:focus,
div.wpforms-container .wpforms-form .wpforms-field input[type=week]:hover,
div.wpforms-container .wpforms-form .wpforms-field input[type=week]:focus,
div.wpforms-container .wpforms-form .wpforms-field select:hover,
div.wpforms-container .wpforms-form .wpforms-field select:focus,
div.wpforms-container .wpforms-form .wpforms-field textarea:hover,
div.wpforms-container .wpforms-form .wpforms-field textarea:focus {
  border: none;
  box-shadow: 0 1px 2px rgba(0, 0, 0, 0.12) inset;
  -moz-box-shadow: 0 1px 2px rgba(0, 0, 0, 0.12) inset;
  -webkit-box-shadow: 0 1px 2px rgba(0, 0, 0, 0.12) inset;
  -o-box-shadow: 0 1px 2px rgba(0, 0, 0, 0.12) inset;
  transition: all 0.2s linear;
  -moz-transition: all 0.2s linear;
  -webkit-transition: all 0.2s linear;
  -o-transition: all 0.2s linear;
  border-color: #EBEBEB;
  border-bottom: 1px solid #fff !important;
  background: #e9e9e9;
}
div.wpforms-container .wpforms-form .wpforms-field textarea {
  min-height: 215px;
}
div.wpforms-container .wpforms-form button[type=submit] {
  width: 100%;
  text-align: center;
  display: block;
}

/* Pirate Forms */
.pirate_forms .pirate-forms-fields-container .form_field_wrap {
  width: 100%;
  max-width: 100%;
  padding: 0px;
}
.pirate_forms .pirate-forms-fields-container .form_field_wrap .form-control {
  border-radius: 0px;
}
.pirate_forms .pirate-forms-fields-container .form_field_wrap .pirate-forms-submit-button {
  display: block;
  width: 100%;
}
.pirate_forms .contact_message_wrap #pirate-forms-contact-message {
  border-radius: 0px;
  background-color: #f2f2f2;
  border: 0 none;
  min-height: 245px;
  max-height: 999px;
}

/**
* JQuery Bullly
* @see https://github.com/pixelgrade/rellax/blob/gh-pages/assets/css/bully.css
 */
[class*=c-bully],
[class*=c-bully]:before,
[class*=c-bully]:after {
  box-sizing: border-box;
}

.c-bully {
  position: fixed;
  top: 50%;
  right: 28px;
  font-size: 12px;
  transform: translate(0, -50%);
  z-index: 600;
  color: #333;
  text-transform: uppercase;
}
@media screen and (max-width: 940px) {
  .c-bully {
    right: 0px;
  }
}
.c-bully.c-bully--inversed {
  color: #fff;
}
@media screen and (max-width: 940px) {
  .c-bully.c-bully-hide-on-mobile {
    display: none;
  }
}

.onepress-menu-mobile-opening .c-bully {
  z-index: 10;
}

.c-bully__bullet {
  padding: 8px;
  opacity: 0;
  cursor: pointer;
  position: relative;
}
@media screen and (max-width: 940px) {
  .c-bully__bullet {
    padding: 8px 3px;
  }
}
.c-bully__bullet:hover .c-bully__title {
  opacity: 1;
  transform: scale(1);
}
.c-bully__title {
  position: absolute;
  right: 26px;
  top: 1px;
  left: auto;
  background: rgba(0, 0, 0, 0.7);
  padding: 1px 10px;
  border-radius: 2px;
  transition: all 0.2s ease-out;
  display: block;
  opacity: 0;
  white-space: nowrap;
  color: rgba(255, 255, 255, 0.8);
  transform: scale(0.6);
}

.c-bully__bullet:after {
  content: "";
  display: block;
  width: 12px;
  height: 12px;
  border: 2px solid currentColor;
  border-radius: 50%;
  will-change: transform;
}
@media screen and (max-width: 940px) {
  .c-bully__bullet:after {
    width: 9px;
    height: 9px;
  }
}

.c-bully__bullet--active {
  position: absolute;
  top: 0;
  left: 0;
  transition: top 0.2s ease-out;
}

.c-bully__bullet--active:before {
  content: "";
  width: 12px;
  height: 12px;
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
  font-size: 14px;
  background: currentColor;
  border-radius: 50%;
}
@media screen and (max-width: 940px) {
  .c-bully__bullet--active:before {
    width: 9px;
    height: 9px;
  }
}

.c-bully__bullet--active:after {
  border-color: transparent;
}

.c-bully__bullet--pop {
  animation: bully-pop 0.6s cubic-bezier(0.485, 1.63, 0.43, 2) forwards, fade-in 0.2s 0.2s ease-out forwards;
}

.c-bully__bullet--squash {
  opacity: 1;
  animation: bully-squash 0.2s ease-out forwards;
}

@keyframes fade-in {
  0% {
    opacity: 0;
  }
  100% {
    opacity: 1;
  }
}
@keyframes bully-pop {
  50% {
    transform: scale(0.7);
  }
  100% {
    transform: scale(1);
  }
}
@keyframes bully-squash {
  50% {
    transform: scale(0.6, 1.8);
  }
  100% {
    transform: scale(1);
  }
}
.single-post .content-inner {
  margin-left: auto;
  margin-right: auto;
}

.entry-content > * {
  margin-left: auto;
  margin-right: auto;
  max-width: 100%;
}

.no-sidebar .entry-content > .alignwide {
  max-width: 100vw;
  max-width: calc(var(--vw, 1vw) * 100);
  width: 1110px;
  transform: translateX(-50%);
  left: 50%;
  position: relative;
}
.no-sidebar .entry-content > .alignfull {
  margin: 1.5em 0;
  max-width: 100vw;
  max-width: calc(var(--vw, 1vw) * 100);
  width: 100vw;
  /* Use vh as a fallback for browsers that do not support Custom Properties */
  width: calc(var(--vw, 1vw) * 100);
  transform: translateX(-50%);
  left: 50%;
  position: relative;
}

.single-post .right-sidebar .content-inner {
  margin-left: 0px;
}

.single-post .left-sidebar .content-inner {
  margin-right: 0px;
}

.entry-content ul,
.entry-content ol {
  margin: 1.5em auto;
  list-style-position: outside;
}

.wp-block-video video {
  max-width: 100%;
}

.wp-block-embed.is-type-video .wp-block-embed__wrapper {
  width: 100%;
  position: relative;
  padding: 0 0 0 0;
  height: auto;
  display: block;
}
.wp-block-embed.is-type-video .wp-block-embed__wrapper::before {
  padding-top: 56.25%;
  content: "";
  display: block;
}
.wp-block-embed.is-type-video .wp-block-embed__wrapper > iframe, .wp-block-embed.is-type-video .wp-block-embed__wrapper > object {
  position: absolute;
  width: 100%;
  height: 100%;
  top: 0;
  left: 0;
  bottom: 0;
  right: 0;
}

.wp-block-image img {
  display: block;
}

.wp-block-image.alignleft,
.wp-block-image.alignright {
  width: 100%;
}

.wp-block-image.alignfull img {
  width: 100vw;
  width: calc(var(--vw, 1vw) * 100);
}

.wp-block-gallery:not(.components-placeholder) {
  margin: 1.5em auto;
}

.wp-block-cover-text p {
  padding: 1.5em 14px;
}

ul.wp-block-latest-posts.alignwide,
ul.wp-block-latest-posts.alignfull,
ul.wp-block-latest-posts.is-grid.alignwide,
ul.wp-block-latest-posts.is-grid.alignwide {
  padding: 0 14px;
}

.wp-block-table {
  display: block;
  overflow-x: auto;
}

.wp-block-table table {
  border-collapse: collapse;
  width: 100%;
}

.wp-block-table td,
.wp-block-table th {
  padding: 0.5em;
}

.entry-content li {
  margin-left: 0em;
  margin-bottom: 6px;
}

.entry-content ul ul,
.entry-content ol ol,
.entry-content ul ol,
.entry-content ol ul {
  margin: 0 auto;
}

.entry-content ul ul li,
.entry-content ol ol li,
.entry-content ul ol li,
.entry-content ol ul li {
  margin-left: 0;
}

.wp-block-quote {
  border-left-width: 4px;
  border-left-color: currentColor;
}
.wp-block-quote.is-style-large {
  padding: 0px;
}
.wp-block-quote.is-style-large cite {
  font-size: 13px;
}
.wp-block-quote > * {
  margin-left: 16px;
  margin-right: 16px;
}
.wp-block-quote cite {
  font-style: normal;
  margin-top: 1em;
  margin-left: 0px;
  position: relative;
  font-size: 13px;
  display: block;
  margin-bottom: 0px;
}

.wp-block-pullquote {
  border-bottom: 4px solid currentColor;
  border-top: 4px solid currentColor;
  margin-top: 1.5em;
  margin-bottom: 1.5em;
  padding: 3em 0;
  text-align: center;
}
.wp-block-pullquote.is-style-solid-color {
  border-bottom: 0 none;
  border-top: 0 none;
}
.wp-block-pullquote > p:first-child {
  margin-top: 0;
}
.wp-block-pullquote cite {
  font-size: 13px;
  font-style: normal;
  text-transform: uppercase;
}
.wp-block-pullquote blockquote {
  border-left: 0px;
  background: none;
}

.wp-block-separator {
  margin: 3em auto;
  border: none;
  border-bottom: 2px solid currentColor;
}
.wp-block-separator:not(.is-style-wide) {
  max-width: 100px;
}
.wp-block-separator.is-style-dots {
  border-bottom: none !important;
  text-align: center;
}
.wp-block-separator.is-style-dots::before {
  padding-left: 0px;
  font-size: 30px;
}

@media screen and (min-width: 768px) {
  .wp-block-cover-text p {
    padding: 1.5em 0;
  }

  .entry-content > * {
    padding-left: 0px;
    padding-right: 0px;
  }
}
/*--------------------------------------------------------------
  # Block Color Palette Colors
  --------------------------------------------------------------*/
.has-strong-blue-color {
  color: #0073aa;
}

.has-strong-blue-background-color {
  background-color: #0073aa;
}

.has-lighter-blue-color {
  color: #229fd8;
}

.has-lighter-blue-background-color {
  background-color: #229fd8;
}

.has-very-light-gray-color {
  color: #eee;
}

.has-very-light-gray-background-color {
  background-color: #eee;
}

.has-very-dark-gray-color {
  color: #444;
}

.has-very-dark-gray-background-color {
  background-color: #444;
}

.carousel, .carousel-inner, .carousel-item {
    position: relative;
}

#mainCarousel .container-slide-nav {
    position: absolute;
    bottom: 100px;
    left: 50%;
    -webkit-transform: translate(-50%, 0);
    transform: translate(-50%, 0);
    z-index: 9;
}

.carousel-inner {
    width: 100%;
    overflow: hidden;
}

#mainCarousel {
background: #242d2e; 

}

#mainCarousel .carousel-item:first-child {
    background-image: url(https://www.marlowe.cz/wp-content/uploads/2023/02/hp4.png);
}

@media only screen and (max-width: 576px) {
#mainCarousel .carousel-item:first-child {
    background-image: url(https://www.marlowe.cz/wp-content/uploads/2025/04/hp-1-mobile.jpg);
}
	}


#mainCarousel .carousel-item:nth-child(2) {
    background-image: url(https://www.marlowe.cz/wp-content/uploads/2023/02/hp1.png);
}

@media only screen and (max-width: 576px) {
#mainCarousel .carousel-item:nth-child(2) {
	    background-image: url(https://www.marlowe.cz/wp-content/uploads/2025/04/hp-2-mobile.jpg);
	}
}


#mainCarousel .carousel-item {
    height: 100vh;
    background-size: cover;
    background-position: center;
}

#mainCarousel .carousel-item .slide-title h1 {
    font-size: 100px;
    line-height: 1;
    color: #fff;
    font-weight: 700;
}

#mainCarousel .carousel-item .slide-title h1 small {
    font-size: 18px;
    line-height: 6;
    color: #a4aeb0;
    font-weight: 400;
    text-transform: uppercase;
    letter-spacing: 9px;
}

#mainCarousel .carousel-indicators li, #mainCarousel .carousel-indicators li.active, #mainCarousel .carousel-item .slide-title, #mainCarousel .sr-only {
    font-family: Oswald, sans-serif;
}

#mainCarousel .slider-social .social {
    position: relative;
    bottom: 100px;
}

#mainCarousel .slider-social {
    position: absolute;
    left: 4.5rem;
    top: 0;
    height: 100%;
}

#mainCarousel .carousel-indicators li {
    font-size: 13.7px;
    line-height: 2.14;
    color: #a4aeb0;
    font-weight: 700;
    letter-spacing: 2.7px;
    text-indent: inherit;
    height: auto;
    width: auto;
    background: 0 0;
    margin: 0 0 -7px;
    transition: .25s ease;
    cursor: pointer;
	min-width: 60px;
}

#mainCarousel .carousel-indicators {
    -webkit-box-align: end;
    -ms-flex-align: end;
    align-items: flex-end;
    -webkit-box-pack: start;
    -ms-flex-pack: start;
    justify-content: flex-start;
    margin: 0 0 0 135px;
    bottom: 0;
}

#mainCarousel .slider-social .social-title {
    font-size: 14px;
    line-height: 1;
    font-weight: 700;
    text-transform: uppercase;
    color: #a4aeb0;
    -webkit-transform: rotate(-90deg);
    transform: rotate(-90deg);
    -webkit-transform-origin: left top 0;
    transform-origin: left top 0;
    letter-spacing: 5px;
    position: relative;
    bottom: 330px;
}

#mainCarousel .slider-social .social-title {
    font-size: 14px;
    line-height: 1;
    font-weight: 700;
    text-transform: uppercase;
    color: #a4aeb0;
    -webkit-transform: rotate(-90deg);
    transform: rotate(-90deg);
    -webkit-transform-origin: left top 0;
    transform-origin: left top 0;
    letter-spacing: 5px;
    position: relative;
    bottom: 330px;
}

#mainCarousel .slider-social .social-title:before {
    display: block;
    content: '';
    width: 120px;
    height: 1px;
    background: rgba(100, 112, 114, .3);
    position: absolute;
    left: -180px;
    top: 7px;
}

.h-100 {
    height: 100% !important;
}

ul.social {
    list-style: none;
    padding: 0;
    margin: 0 auto;
    width: 100%;
}

#mainCarousel .slider-social .social li {
    padding: 0;
}

ul.social li {
    display: inline-block;
    list-style: none;
}

ul.social li a {
    font-size: 24px;
    color: #647072;
    line-height: 1.5;
    transition: .25s ease;
}

#mainCarousel .slide-navigation {
    margin-left: 25%;
}

#mainCarousel .slide-navigation {
    margin-left: 25%;
}

#mainCarousel .carousel-control-prev {
    border-right: 1px solid #a4aeb0;
}

#mainCarousel .carousel-control-next, #mainCarousel .carousel-control-prev {
    opacity: 1;
    position: relative;
    top: 5px;
    display: inline-block;
    width: auto;
    line-height: 1;
    z-index: 15;
}
.carousel-control-prev {
    left: 0;
}

#mainCarousel .carousel-indicators:before {
    content: '';
    display: block;
    position: absolute;
    height: 1px;
    width: 70px;
    background-color: #647072;
    bottom: 10px;
    left: -120px;
}

#mainCarousel .sr-only {
    position: static;
    -webkit-clip-path: inset(0);
    clip-path: inset(0);
    font-size: 14px;
    line-height: 1;
    color: #a4aeb0;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: 1.7px;
    height: inherit;
    width: auto;
    clip: auto;
    padding: 0 30px;
}

#mainCarousel .carousel-indicators li.active {
    font-size: 30px;
    line-height: .97;
    color: #facd49;
    font-weight: 700;
    letter-spacing: 2.3px;
    margin-bottom: 0;
}


/* Testimonial */

#quoteCarousel .testimonial-item .item-author .author-name {
    font-size: 22px;
    line-height: 1.36;
    color: #facd49;
    font-weight: 400;
    font-family: Roboto, sans-serif;
}

/* Portfolio */

#filters li {
    float: left;
}

#filters li span.active {
    color: #facd49;
}

#filters li span {
    display: block;
    font-size: 14px;
    font-family: Roboto, sans-serif;
    font-weight: 500;
    padding: 0;
    text-decoration: none;
    color: #fff;
    text-transform: uppercase;
    cursor: pointer;
}


#portfoliolist {
    width: 100%;
}

#portfoliolist .portfolio.w2 {
    width: 50%;
}





/* Create three equal columns that floats next to each other */
.column {
  float: left;
  width: 33.33%;
  display: none; /* Hide columns by default */
	padding: 35px;
}

/* Clear floats after rows */
.row:after {
  content: "";
  display: table;
  clear: both;
}

/* Content */
.content {
 /* background-color: #242d2e; */
  padding: 10px;
}

/* The "show" class is added to the filtered elements */
.show {
  display: block;
}

/* Style the buttons */
.btn {
  border: none;
  outline: none;
  padding: 12px 16px;
  background-color: white;
  cursor: pointer;
}

/* Add a grey background color on mouse-over */
.btn:hover {
  background-color: #ddd;
}

/* Add a dark background color to the active button */
.btn.active {
  background-color: #666;
   color: white;
}

.benefit .media .media-number {
    font-size: 93px;
    line-height: 1;
    color: rgba(100, 112, 114, .3);
    font-weight: 700;
    font-family: Oswald, sans-serif;
    position: relative;
    left: -24px;
}


.site-branding .box {
	/*  width: 250px;
	height: 250px; */
	 position: relative;
	 display: flex;
	 justify-content: center;
	 flex-direction: column;
	padding: 20px 0px 20px 0px;
}
 .site-branding .box .title {
	 width: 100%;
	 position: relative;
	 display: flex;
	 align-items: center;
	 height: auto;
}
 .site-branding .box .title .block {
	 width: 0%;
	 height: inherit;
	 background: #ffb510;
	 position: absolute;
	 animation: mainBlock 2s cubic-bezier(0.74, 0.06, 0.4, 0.92) forwards;
	 display: flex;
}
 .site-branding .box .title h1 {
	 font-family: 'Oswald', sans-serif;
	 color: #fff;
	 font-size: 36px;
	 -webkit-animation: mainFadeIn 2s forwards;
	 -o-animation: mainFadeIn 2s forwards;
	 animation: mainFadeIn 2s forwards;
	 animation-delay: 1.6s;
	 opacity: 0;
	 display: flex;
	 align-items: baseline;
	 position: relative;
	 text-transform: uppercase;
	 margin-bottom: 15px;
	  letter-spacing: 3px;
	 font-weight:normal;
}
 .site-branding .box .title h1 span {
	 width: 0px;
	 height: 0px;
	 -webkit-border-radius: 50%;
	 -moz-border-radius: 50%;
	 border-radius: 50%;
	 background: #ffb510;
	 -webkit-animation: load 0.6s cubic-bezier(0.74, 0.06, 0.4, 0.92) forwards;
	 animation: popIn 0.8s cubic-bezier(0.74, 0.06, 0.4, 0.92) forwards;
	 animation-delay: 2s;
	 margin-left: 5px;
	 margin-top: -10px;
	 position: absolute;
	 bottom: 13px;
	 right: -12px;
}
 .site-branding .box .role {
	 width: 100%;
	 position: relative;
	 display: flex;
	 align-items: center;
	 height: 30px;
	 margin-top: -10px;
}
 .site-branding .box .role .block {
	 width: 0%;
	 height: inherit;
	 background: #facd49;
	 position: absolute;
	 animation: secBlock 2s cubic-bezier(0.74, 0.06, 0.4, 0.92) forwards;
	 animation-delay: 2s;
	 display: flex;
}
 .site-branding .box .role p {
	 animation: secFadeIn 2s forwards;
	 animation-delay: 3.2s;
	 opacity: 0;
	 font-weight: 400;
	 font-family: 'Oswald', sans-serif;
	 
	  color: #facd49;
	 font-size: 15px;
	 text-transform: uppercase;
	 letter-spacing: 5px;
}
 @keyframes mainBlock {
	 0% {
		 width: 0%;
		 left: 0;
	}
	 50% {
		 width: 100%;
		 left: 0;
	}
	 100% {
		 width: 0;
		 left: 100%;
	}
}
 @keyframes secBlock {
	 0% {
		 width: 0%;
		 left: 0;
	}
	 50% {
		 width: 100%;
		 left: 0;
	}
	 100% {
		 width: 0;
		 left: 100%;
	}
}
 @keyframes mainFadeIn {
	 0% {
		 opacity: 0;
	}
	 100% {
		 opacity: 1;
	}
}
 @keyframes popIn {
	 0% {
		 width: 0px;
		 height: 0px;
		 background: #e9d856;
		 border: 0px solid #ddd;
		 opacity: 0;
	}
	 50% {
		 width: 10px;
		 height: 10px;
		 background: #e9d856;
		 opacity: 1;
		 bottom: 45px;
	}
	 65% {
		 width: 7px;
		 height: 7px;
		 bottom: 0px;
		 width: 15px;
	}
	 80% {
		 width: 10px;
		 height: 10px;
		 bottom: 20px;
	}
	 100% {
		 width: 7px;
		 height: 7px;
		 background: #e9d856;
		 border: 0px solid #222;
		 bottom: 13px;
	}
}
 @keyframes secFadeIn {
	 0% {
		 opacity: 0;
	}
	 100% {
		 opacity: 0.5;
	}
}


#mainCarousel .carousel-control-next-icon, #mainCarousel .carousel-control-prev-icon {
    background: 0 0;
    display: none;
}


.carousel-indicators li::before {
    top: -10px;
}
.carousel-indicators li::after, .carousel-indicators li::before {
    left: 0;
    display: inline-block;
    height: 10px;
    position: absolute;
    content: "";
    width: 100%;
}

@media only screen and (max-width: 767px) {
    #mainCarousel .container-slide-nav {
        top: 60%;
        bottom: auto;
    }
	
	    #mainCarousel .carousel-item .slide-title h1 {
        font-size: 40px;
        margin-bottom: 20px;
    }
	
	    #mainCarousel .carousel-item .slide-title p {
        font-size: 12px;
        line-height: 1.4;
    }
	
	    #mainCarousel .slider-social {
        left: 1em;
    }
}

header {
    position: absolute;
    width: 100%;
    top: 0;
    left: 0;
    z-index: 999;
}

.navbar.fixed-top {
    transition: .5s ease;
}
header .navbar {
    padding: 2.5rem 3rem;
}
.fixed-top {
    top: 0;
}
.fixed-bottom, .fixed-top {
    position: fixed;
    z-index: 1030;
    right: 0;
    left: 0;
}

@media only screen and (min-width: 992px) {
    .navbar-expand-lg {
        -ms-flex-flow: row nowrap;
        flex-flow: row nowrap;
        -ms-flex-pack: start;
        justify-content: flex-start;
    }
}

header .navbar-brand {
    position: relative;
    top: -10px;
}

@media only screen and (min-width: 1200px) {
    .ml-xl-3, .mx-xl-3 {
        margin-left: 1rem !important;
    }
}
@media only screen and (min-width: 768px) {
    .mr-md-auto, .mx-md-auto {
        margin-right: auto !important;
    }
}
.navbar-brand {
    display: inline-block;
    padding-top: .3125rem;
    padding-bottom: .3125rem;
    margin-right: 1rem;
    font-size: 1.25rem;
    line-height: inherit;
}


header #navbar .main-menu {
    position: relative;
    top: 18px;
    max-width: 680px;
    width: 100%;
    margin-left: 35px;
}

@media only screen and (min-width: 992px) {
    .navbar-expand-lg .navbar-nav {
        -ms-flex-direction: row;
        flex-direction: row;
    }
}
@media only screen and (min-width: 768px) {
    .justify-content-md-around {
        -ms-flex-pack: distribute !important;
        justify-content: space-around !important;
    }
}
@media only screen and (min-width: 768px) {
    .flex-md-nowrap {
        -ms-flex-wrap: nowrap !important;
        flex-wrap: nowrap !important;
    }
}
@media (min-width: 768px) {
    .d-md-flex {
        display: -ms-flexbox !important;
        display: flex !important
;
    }
}
.navbar-nav {
    display: flex
;
    -ms-flex-direction: column;
    flex-direction: column;
    padding-left: 0;
    margin-bottom: 0;
}
.card, .navbar-nav {
    display: -ms-flexbox;
}
.dropdown-menu, .nav, .navbar-nav {
    list-style: none;
}

.dropdown-menu, .nav, .navbar-nav {
    list-style: none;
}

header .navbar .navbar-nav > li a.nav-link {
    font-size: 14px;
    line-height: 1;
    color: #a4aeb0;
    font-weight: 500;
    letter-spacing: 1.4px;
    text-transform: uppercase;
    padding: 0 0 38px;
    transition: .25s ease;
}

header .navbar .navbar-nav > li a.nav-link.active, header .navbar .navbar-nav > li a.nav-link:hover {
    color: #facd49;
}

header #navbar .main-menu {
    position: relative;
    top: 18px;
    max-width: 680px;
    width: 100%;
    margin-left: 35px;
}

@media only screen and (min-width: 992px) {
    .navbar-expand-lg .navbar-nav {
        -ms-flex-direction: row;
        flex-direction: row;
    }
}
@media only screen and (min-width: 768px) {
    .justify-content-md-around {
        -ms-flex-pack: distribute !important;
        justify-content: space-around !important;
    }
}
@media only screen and (min-width: 768px) {
    .flex-md-nowrap {
        -ms-flex-wrap: nowrap !important;
        flex-wrap: nowrap !important;
    }
}
@media only screen and (min-width: 768px) {
    .d-md-flex {
        display: -ms-flexbox !important;
        display: flex !important
;
    }
}
.navbar-nav {
    display: flex
;
    -ms-flex-direction: column;
    flex-direction: column;
    padding-left: 0;
    margin-bottom: 0;
}
.card, .navbar-nav {
    display: -ms-flexbox;
}
.dropdown-menu, .nav, .navbar-nav {
    list-style: none;
}

@media only screen and (min-width: 992px) {
    .navbar-expand-lg .navbar-collapse {
        display: -ms-flexbox !important;
        display: flex !important
;
        -ms-flex-preferred-size: auto;
        flex-basis: auto;
    }
}

@media only screen and (min-width: 992px) {
    .navbar-expand-lg .navbar-collapse {
        display: -ms-flexbox !important;
        display: flex !important
;
        -ms-flex-preferred-size: auto;
        flex-basis: auto;
    }
}

@media only screen and (min-width: 992px) {
    .ml-lg-3, .mx-lg-3 {
        margin-left: 1rem !important;
    }
}
@media only screen and (min-width: 992px) {
    .mr-lg-3, .mx-lg-3 {
        margin-right: 1rem !important;
    }
}
.navbar-collapse {
    -ms-flex-preferred-size: 100%;
    flex-basis: 100%;
    -ms-flex-positive: 1;
    flex-grow: 1;
    -ms-flex-align: center;
    align-items: center;
}

section#benefit, section#references, section#contactUs {
background: #242d2e;
	}

.content h4 {
    color: #fff !important;
	padding-top: 2rem;
	text-align: center;
}

h5.mt-0 {
color: #fff;	
}

.masked-text {
    font-size: 3rem;
    font-weight: bold;
    color: transparent;
    background-image: url('https://images.unsplash.com/photo-1732535725600-f805d8b33c9c?q=80&w=1470&auto=format&fit=crop&ixlib=rb-4.0.3&ixid=M3wxMjA3fDB8MHxwaG90by1wYWdlfHx8fGVufDB8fHx8fA%3D%3D'); 
    background-size: 200%; /* Enlarged for smooth animation */
    background-position: 0 50%;
    background-clip: text;
    -webkit-background-clip: text;
    -webkit-text-fill-color: transparent;
    animation: animate-background 5s infinite alternate linear;
}

@keyframes animate-background {
    0% {
        background-position: 0 50%;
    }
    100% {
        background-position: 100% 50%;
    }
}

.navbar.fixed-top.fixed-theme {
    background-color: #242d2e;
    border-color: #080808;
    box-shadow: 0 0 5px rgba(0, 0, 0, .8);
}

@media (min-width: 992px) {
    .navbar-expand-lg .navbar-toggler {
        display: none;
    }
}

   .portfolio-item { margin-bottom: 30px; }
        .portfolio-item img { width: 100%; height: auto; }
        .filter-button-group { margin-bottom: 30px; }
        .filter-button-group .btn { margin: 5px; }

@media (max-width: 991px) {
    header .navbar {
       background-color: #242d2e !important;
        padding: .5rem 1rem;
    }
}

/* Přizpůsobení modálu na 95% viewportu a centrování */
        .modal-dialog {
            max-width: 95vw;
            margin: 2.5vh auto;
        }
        .modal-content {
            height: 95vh;
        }
        .modal-body {
            overflow-y: auto; /* Vertikální posuv pro velké obrázky */
            max-height: 80vh; /* Omezení výšky pro scroll */
            padding: 1rem;
            display: flex;
            flex-direction: column;
            align-items: center;
            justify-content: center;
        }
        .modal-body img {
            max-width: 100%;
            max-height: 60vh; /* Omezení výšky obrázku pro místo na text */
            object-fit: contain;
            margin-bottom: 1rem;
        }
        .modal-description {
            text-align: center;
            max-width: 80%;
            font-size: 1.1rem;
            color: #666;
        }
        /* 3D Flip Card efekt */
        .card-container {
            perspective: 1000px;
            height: 450px;
            margin-bottom: 1rem;
			padding: 14px;
        }
        .card {
            position: relative;
            width: 100%;
            height: 100%;
            transition: transform 0.6s;
            transform-style: preserve-3d;
            cursor: pointer;
        }
        .card:hover {
            transform: rotateY(180deg);
        }
        .card-front, .card-back {
            position: absolute;
            width: 100%;
            height: 100%;
            backface-visibility: hidden;
            border-radius: 8px;
            overflow: hidden;
        }
        .card-front {
            background: #242d2e;
            box-shadow: 0 4px 8px rgba(0,0,0,0.1);
        }
        .card-front img {
          /*  width: 100%;
            height: 100%; */
            object-fit: cover;
            transition: filter 0.3s ease;
            loading: lazy; /* Lazy load pro obrázky v gridu */
        }
        .card-container:hover .card-front img {
            filter: brightness(1.1);
        }
        .card-back {
            background: transparent;
            transform: rotateY(180deg);
            box-shadow: 0 4px 8px rgba(0,0,0,0.2);
            border-radius: 8px;
            position: relative;
        }
        .card-back .back-img {
            position: absolute;
            top: 0;
            left: 0;
            width: 100%;
            height: 100%;
            object-fit: cover;
            z-index: 1;
        }
        .card-back .gradient-overlay {
            position: absolute;
            top: 0;
            left: 0;
            width: 100%;
            height: 100%;
            background: linear-gradient(135deg, rgba(36, 45, 46, 0.8) 0%, rgba(0, 0, 0, 0.8) 100%);
            z-index: 2;
        }
        .card-back .back-text {
            position: relative;
            z-index: 3;
            color: white;
            font-size: 1.2rem;
            text-align: center;
            padding: 1rem;
            margin: 0;
            display: flex;
            align-items: center;
            justify-content: center;
            height: 100%;
        }

.card {
/* background: #242d2e; */
}

h2.nadpis {
font-size: 63px;
    line-height: 1;
    color: rgba(255, 255, 255, .3);
    font-weight: 700;
    font-family: Oswald, sans-serif;
	text-transform: uppercase;
}

input.form-control {
    padding: 1.25rem;
}

textarea#message {
    height: 100%;
    min-height: 10rem;
}

.btn-xl {
    padding: 1.25rem 2.5rem;
    font-size: 1.125rem;
    font-weight: 700;
	text-transform: uppercase;
}

@media (max-width: 991px) {
	.flex-column {
flex-direction: row !important;
		}
}

p.headline {
color: #fff;
font-family: Oswald, sans-serif;
font-weight: 700;
}


.timeline-section {
  position: relative;
}

/* samotná osa */
.timeline-item {
  position: relative;
  display: flex;
  align-items: flex-start;
  padding-left: 80px;
  margin-bottom: 50px;
}

/* vertikální čára */
.timeline-item::before {
  content: "";
  position: absolute;
  left: 28px;
  top: 0;
  bottom: -50px;
  width: 2px;
  background: #d1c8bd;
}

.timeline-item:last-child::before {
  display: none;
}

/* kolečko s číslem */
.timeline-number {
  position: absolute;
  left: 0;
  width: 56px;
  height: 56px;
  background: #d1c8bd;
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
  font-weight: 600;
  font-size: 18px;
  z-index: 2;
}

/* vodorovná čára */
.timeline-content {
  position: relative;
  padding-left: 30px;
}

.timeline-content::before {
  content: "";
  position: absolute;
  left: 0;
  top: 16px;
  width: 30px;
  height: 2px;
  background: #d1c8bd;
}

.timeline-content h5 {
  margin-bottom: 0.3rem;
}

/* mobilní verze */
@media (max-width: 576px) {
  .timeline-item {
    padding-left: 70px;
  }

  .timeline-content::before {
    width: 20px;
  }
}



/* ===== Reveal zhora dolů ===== */
.reveal-item {
  opacity: 0;
  transform: translateY(-16px);
  transition: opacity 700ms ease, transform 700ms ease;
  will-change: opacity, transform;
}

/* “dotahování” vertikální čáry u každé položky */
.reveal-item::before {
  transform: scaleY(0);
  transform-origin: top center;
  transition: transform 900ms ease 120ms;
}

/* “kreslení” vodorovné čáry k textu */
.reveal-item .timeline-content::before {
  transform: scaleX(0);
  transform-origin: left center;
  transition: transform 700ms ease 260ms;
}

/* jemný pop kolečka */
.reveal-item .timeline-number {
  transform: scale(0.85);
  transition: transform 650ms cubic-bezier(.2,.9,.2,1) 180ms;
}

/* aktivace */
.reveal-item.is-visible {
  opacity: 1;
  transform: translateY(0);
}

.reveal-item.is-visible::before {
  transform: scaleY(1);
}

.reveal-item.is-visible .timeline-content::before {
  transform: scaleX(1);
}

.reveal-item.is-visible .timeline-number {
  transform: scale(1);
}

/* stagger (postupně bod po bodu) */
.reveal-item:nth-child(1) { transition-delay: 0ms; }
.reveal-item:nth-child(2) { transition-delay: 90ms; }
.reveal-item:nth-child(3) { transition-delay: 180ms; }
.reveal-item:nth-child(4) { transition-delay: 270ms; }
.reveal-item:nth-child(5) { transition-delay: 360ms; }
.reveal-item:nth-child(6) { transition-delay: 450ms; }

/* reduced motion */
@media (prefers-reduced-motion: reduce) {
  .reveal-item,
  .reveal-item::before,
  .reveal-item .timeline-content::before,
  .reveal-item .timeline-number {
    transition: none !important;
    transform: none !important;
    opacity: 1 !important;
  }
}


/* =====================================================
   HERO BACKGROUND CAROUSEL
===================================================== */

.hero-bg-carousel{
  position: relative;
  overflow: hidden;
  min-height: clamp(720px, 110vh, 1360px);
}

/* slides */
.hero-slides{
  position: relative;
  width: 100%;
  height: 100%;
  min-height: inherit;
}

.hero-slide{
  position: absolute;
  inset: 0;
  background-size: cover;
  background-position: center;
  opacity: 0;
  transform: scale(1.02);
  transition: opacity 900ms ease, transform 1400ms ease;
  display: flex;
}

.hero-slide.is-active{
  opacity: 1;
  transform: scale(1);
  z-index: 2;
}

/* overlay */
.hero-overlay{
  position: absolute;
  inset: 0;
  background: rgba(0,0,0,.22);
  z-index: 1;
}

/* container */
.hero-container{
  position: relative;
  z-index: 2;
  width: 100%;
  height: 100%;
  display: flex;
  padding: clamp(16px,4vw,56px);
  box-sizing: border-box;
}

/* =====================================================
   TEXT AREA
===================================================== */

.hero-left{
  width: 50%;
  display: flex;
  align-items: center;
}

/* text card */
.hero-text{
  max-width: 760px;
  padding: clamp(18px,2.4vw,34px);
/*  background: rgba(255,255,255,.82); */
  border-radius: 14px;
  backdrop-filter: blur(7px);
  box-sizing: border-box;
}

/* subtitle */
.hero-subtitle{
  font-weight: 600;
  opacity: .85;
  margin-bottom: .6rem;
  font-size: 1rem;
}

/* title */
.hero-title{
  margin: 0 0 .8rem 0;
  line-height: 1.1;
  font-weight: 700;
  font-size: clamp(1.8rem,2.8vw,3rem);
}



/* perex */
.hero-perex{
  margin: 0;
  line-height: 1.55;
  font-size: 1.05rem;
  opacity: .95;
}

/* =====================================================
   ✅ DESKTOP POSITION OVERRIDE
===================================================== */

@media (min-width: 993px){

  .hero-left{
    align-items: flex-start;

    /* výška textu cca horní třetina */
    padding-top: clamp(140px, 18vh, 260px);

    /* posun doprava */
    padding-left: clamp(120px, 10vw, 220px);
  }

  /* větší subtitle */
  .hero-subtitle{
    font-size: clamp(1.6rem, 2vw, 2.4rem);
  }

  /* výrazně větší headline */
  .hero-title{
    font-size: clamp(4rem, 6vw, 7rem);
    line-height: 1.02;
  }

  /* lehce větší perex aby držel proporce */
  .hero-perex{
    font-size: 1.15rem;
  }
}

/* =====================================================
   NAVIGATION
===================================================== */

.hero-nav{
  position: absolute;
  top: 50%;
  transform: translateY(-50%);
  z-index: 5;
  width: 44px;
  height: 44px;
  border: none;
  border-radius: 999px;
  background: rgba(255,255,255,.75);
  cursor: pointer;
  display: grid;
  place-items: center;
  font-size: 28px;
}

.hero-prev{ left:14px; }
.hero-next{ right:14px; }

/* dots */
.hero-dots{
  position:absolute;
  left:50%;
  bottom:14px;
  transform:translateX(-50%);
  z-index:6;
  display:flex;
  gap:10px;
}

.hero-dot{
  width:10px;
  height:10px;
  border-radius:99px;
  border:none;
  background:rgba(255,255,255,.55);
  cursor:pointer;
}

.hero-dot.is-active{
  background:rgba(255,255,255,.95);
}

/* =====================================================
   MOBILE
===================================================== */

@media (max-width: 992px){

  .hero-left{
    width:100%;
    align-items:center;
    padding:0;
  }

  .hero-text{
    max-width:100%;
  }

  .hero-nav{
    display:none;
  }
}

.hero-text{
  box-shadow: 0 30px 80px rgba(0,0,0,.18);
}

/* reduced motion */
@media (prefers-reduced-motion: reduce){
  .hero-slide{
    transition:none !important;
    transform:none !important;
  }
}



.icon-bubble{
  width: 44px;
  height: 44px;
  border-radius: 999px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  background: rgba(13,110,253,.10); /* bootstrap primary, jemně */
  color: #0d6efd;
  flex: 0 0 auto;
}

.benefit-card{
  transition: transform .25s ease, box-shadow .25s ease, border-color .25s ease;
}

.benefit-card:hover{
  transform: translateY(-5px);
  box-shadow: 0 14px 34px rgba(0,0,0,.10);
  border-color: rgba(13,110,253,.25) !important;
}

  /* ===== TIMELINE layout ===== */
  .timeline-item{
    position: relative;
    display: flex;
    align-items: flex-start;
    padding-left: 80px;
    margin-bottom: 50px;
  }
  .timeline-item::before{
    content:"";
    position:absolute;
    left:28px;
    top:0;
    bottom:-50px;
    width:2px;
    background: #394446;
    display:block;
    will-change: transform;
  }
  .timeline-item:last-child::before{ display:none; }

  .timeline-number{
	 color: #f4f6f7;
    position:absolute;
    left:0;
    width:56px;
    height:56px;
    background: #394446;
    border-radius:50%;
    display:flex;
    align-items:center;
    justify-content:center;
    font-weight:600;
    font-size:18px;
    z-index:2;
  }
  .timeline-content{
    position:relative;
    padding-left:30px;
  }
  .timeline-content::before{
    content:"";
    position:absolute;
    left:0;
    top:16px;
    width:30px;
    height:2px;
    background: #394446;;
  }
  @media (max-width: 576px){
    .timeline-item{ padding-left:70px; }
    .timeline-content::before{ width:20px; }
  }

  /* ===== Timeline reveal (namespaced) ===== */
  .tl-reveal{
    opacity: 0;
    transform: translateY(-16px);
    transition: opacity 700ms ease, transform 700ms ease;
    will-change: opacity, transform;
  }
  .tl-reveal::before{
    transform: scaleY(0);
    transform-origin: top center;
    transition: transform 900ms ease 120ms;
  }
  .tl-reveal .timeline-content::before{
    transform: scaleX(0);
    transform-origin: left center;
    transition: transform 700ms ease 260ms;
  }
  .tl-reveal .timeline-number{
    transform: scale(0.85);
    transition: transform 650ms cubic-bezier(.2,.9,.2,1) 180ms;
  }
  .tl-reveal.is-visible{
    opacity: 1;
    transform: translateY(0);
  }
  .tl-reveal.is-visible::before{ transform: scaleY(1); }
  .tl-reveal.is-visible .timeline-content::before{ transform: scaleX(1); }
  .tl-reveal.is-visible .timeline-number{ transform: scale(1); }

  /* ===== SERVICES layout ===== */
  .wd-services{ padding: clamp(36px, 5vw, 72px) 0; }
  .wd-container{ width: min(1100px, calc(100% - 32px)); margin: 0 auto; }
  .wd-head{ margin-bottom: clamp(18px, 3vw, 28px); }
  .wd-h2{ margin: 0 0 10px 0; font-size: clamp(1.6rem, 3.2vw, 2.4rem); line-height: 1.15; }
  .wd-lead{ margin: 0; max-width: 70ch; opacity: .85; line-height: 1.6; font-size: 1.05rem; }

  .wd-grid{
    display: grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: clamp(14px, 2.2vw, 22px);
  }
  .wd-card{
    position: relative;
    padding: clamp(16px, 2.2vw, 22px);
    border-radius: 16px;
    background: rgba(0,0,0,.035);
    border: 1px solid rgba(0,0,0,.08);
    overflow: hidden;
  }
  .wd-card::after{
    content:"";
    position:absolute;
    inset:-2px;
    background: radial-gradient(600px 140px at 15% 0%, rgba(0,0,0,.06), transparent 60%);
    pointer-events:none;
    opacity:.9;
  }
  .wd-title{
    margin: 0 0 10px 0;
    font-size: 1.15rem;
    line-height: 1.25;
    position: relative;
    display: inline-block;
    padding-bottom: 10px;
  }
  .wd-title::after{
    content:"";
    position:absolute;
    left:0;
    bottom:0;
    height:2px;
    width:100%;
    transform: scaleX(0);
    transform-origin: left center;
    transition: transform 700ms ease 220ms;
    background: currentColor;
    opacity: .35;
  }
  .wd-text{ margin:0; line-height: 1.65; opacity: .9; }

  @media (max-width: 992px){ .wd-grid{ grid-template-columns: repeat(2, minmax(0, 1fr)); } }
  @media (max-width: 576px){ .wd-grid{ grid-template-columns: 1fr; } }

  /* ===== Services reveal (namespaced) ===== */
  .wd-reveal{
    opacity: 0;
    transform: translateY(16px);
    filter: blur(3px);
    transition: opacity 700ms ease, transform 700ms ease, filter 700ms ease;
    will-change: opacity, transform, filter;
  }
  .wd-reveal.is-visible{
    opacity: 1;
    transform: translateY(0);
    filter: blur(0);
  }
  .wd-reveal.is-visible .wd-title::after{
    transform: scaleX(1);
  }

  /* stagger jen pro karty (ať header nelítá se zpožděním) */
  .wd-grid .wd-reveal:nth-child(1){ transition-delay: 0ms; }
  .wd-grid .wd-reveal:nth-child(2){ transition-delay: 80ms; }
  .wd-grid .wd-reveal:nth-child(3){ transition-delay: 160ms; }
  .wd-grid .wd-reveal:nth-child(4){ transition-delay: 240ms; }
  .wd-grid .wd-reveal:nth-child(5){ transition-delay: 320ms; }
  .wd-grid .wd-reveal:nth-child(6){ transition-delay: 400ms; }

  @media (prefers-reduced-motion: reduce){
    .tl-reveal, .wd-reveal{
      transition: none !important;
      opacity: 1 !important;
      transform: none !important;
      filter: none !important;
    }
    .tl-reveal::before, .tl-reveal .timeline-content::before{
      transition: none !important;
      transform: none !important;
    }
    .wd-title::after{
      transition: none !important;
      transform: scaleX(1) !important;
    }
  }



  /* Section */
  .refs-section{
    background: #fff;
  }
  .refs-title{ letter-spacing: .5px; }
  .refs-subtitle{ opacity: .75; }

  /* Card */
  .ref-card{
    display:block;
    position:relative;
    border-radius: 18px;
    overflow:hidden;
    text-decoration:none;
    transform: translateY(0);
    transition: transform .35s ease, box-shadow .35s ease, filter .35s ease;
    will-change: transform;
  }

  /* Nice “depth” */
  .ref-card{
    box-shadow: 0 10px 28px rgba(0,0,0,.10);
    background: #111;
  }
  .ref-card:hover{
    transform: translateY(-6px);
    box-shadow: 0 16px 42px rgba(0,0,0,.16);
  }

  /* Media */
  .ref-media{
    position:relative;
  /*  aspect-ratio: 4/3; /* keeps equal tiles */
    overflow:hidden;
  }
  .ref-media img{
    width:100%;
    height:100%;
    object-fit: cover;
    display:block;
    transform: scale(1.02);
    transition: transform .6s ease, filter .6s ease;
    filter: saturate(1.02) contrast(1.02);
  }
  .ref-card:hover .ref-media img{
    transform: scale(1.10);
    filter: saturate(1.08) contrast(1.06);
  }

  /* Subtle shine sweep */
  .ref-media::after{
    content:"";
    position:absolute;
    inset:-40% -60%;
    background: linear-gradient(115deg, transparent 30%, rgba(255,255,255,.18) 45%, transparent 60%);
    transform: translateX(-35%) rotate(8deg);
    transition: transform .8s ease;
    pointer-events:none;
  }
  .ref-card:hover .ref-media::after{
    transform: translateX(35%) rotate(8deg);
  }

  /* Overlay */
  .ref-overlay{
    position:absolute;
    inset:0;
    display:flex;
    flex-direction:column;
    justify-content:flex-end;
    gap:10px;
    padding:16px 16px 14px;
    background: linear-gradient(180deg, rgba(0,0,0,0) 30%, rgba(0,0,0,.78) 100%);
    transition: opacity .35s ease;
  }

  .ref-meta{
    transform: translateY(10px);
    opacity: .0;
    transition: transform .45s ease, opacity .45s ease;
  }
  .ref-card:hover .ref-meta{
    transform: translateY(0);
    opacity: 1;
  }

  .ref-name{
    color:#fff;
    font-weight: 700;
    letter-spacing:.2px;
    font-size: 1.05rem;
    line-height: 1.2;
  }
  .ref-url{
    color: rgba(255,255,255,.78);
    font-size: .92rem;
  }

  .ref-cta{
    align-self:flex-start;
    color:#fff;
    font-weight:600;
    font-size:.92rem;
    padding:8px 12px;
    border-radius:999px;
    background: rgba(255,255,255,.12);
    backdrop-filter: blur(6px);
    transform: translateY(10px);
    opacity: 0;
    transition: transform .45s ease .05s, opacity .45s ease .05s, background .35s ease;
  }
  .ref-card:hover .ref-cta{
    transform: translateY(0);
    opacity: 1;
  }
  .ref-card:hover .ref-cta{
    background: rgba(255,255,255,.18);
  }

  /* Reveal on scroll */
  .js-reveal{
    opacity: 0;
    transform: translateY(18px);
    filter: blur(6px);
  }
  .js-reveal.is-visible{
    opacity: 1;
    transform: translateY(0);
    filter: blur(0);
    transition:
      opacity .7s ease,
      transform .7s ease,
      filter .7s ease;
    transition-delay: calc(var(--stagger, 1) * 70ms);
  }

  /* Motion safety */
  @media (prefers-reduced-motion: reduce){
    .ref-card, .ref-media img, .ref-media::after, .ref-meta, .ref-cta, .js-reveal, .js-reveal.is-visible{
      transition: none !important;
      animation: none !important;
    }
    .js-reveal{ opacity:1; transform:none; filter:none; }
  }


/* ===== ICON BENEFITS ===== */
.wd-icons{ padding: clamp(18px, 4vw, 46px) 0 clamp(36px, 5vw, 72px); }
.wd-icons-head{ margin-bottom: clamp(14px, 2.5vw, 22px); }

.wd-icons-grid{
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: clamp(12px, 2vw, 18px);
}

.wd-icon-card{
  display: flex;
  gap: 14px;
  align-items: flex-start;
  padding: 16px 16px;
  border-radius: 16px;
  background: rgba(0,0,0,.02);
  border: 1px solid rgba(0,0,0,.08);
  position: relative;
  overflow: hidden;
}

/* jemná dekor “linka” */
.wd-icon-card::after{
  content:"";
  position:absolute;
  left: 16px;
  right: 16px;
  bottom: 12px;
  height: 2px;
  opacity: .18;
  background: currentColor;
  transform: scaleX(0);
  transform-origin: left center;
  transition: transform 700ms ease 230ms;
}

.wd-icon-card.wd-reveal.is-visible::after{
  transform: scaleX(1);
}

/* ikonka v “pilulce” */
.wd-ic{
  width: 44px;
  height: 44px;
  border-radius: 14px;
  display: grid;
  place-items: center;
  background: rgba(0,0,0,.06);
  flex: 0 0 auto;
}

.wd-ic svg{
  width: 22px;
  height: 22px;
  display: block;
}

.wd-icon-title{
  margin: 0 0 6px 0;
  font-size: 1.05rem;
  line-height: 1.25;
}

.wd-icon-desc{
  margin: 0;
  line-height: 1.55;
  opacity: .88;
}

/* responzivita */
@media (max-width: 992px){
  .wd-icons-grid{ grid-template-columns: repeat(2, minmax(0, 1fr)); }
}
@media (max-width: 576px){
  .wd-icons-grid{ grid-template-columns: 1fr; }
}


/* ===== ICON BENEFITS ===== */
.wd-icons{ padding: clamp(18px, 4vw, 46px) 0 clamp(36px, 5vw, 72px); }
.wd-icons-head{ margin-bottom: clamp(14px, 2.5vw, 22px); }

.wd-icons-grid{
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: clamp(12px, 2vw, 18px);
}

.wd-icon-card{
  display: flex;
  gap: 14px;
  align-items: flex-start;
  padding: 16px 16px;
  border-radius: 16px;
  background: rgba(0,0,0,.02);
  border: 1px solid rgba(0,0,0,.08);
  position: relative;
  overflow: hidden;
}

/* jemná dekor “linka” */
.wd-icon-card::after{
  content:"";
  position:absolute;
  left: 16px;
  right: 16px;
  bottom: 12px;
  height: 2px;
  opacity: .18;
  background: currentColor;
  transform: scaleX(0);
  transform-origin: left center;
  transition: transform 700ms ease 230ms;
}

.wd-icon-card.wd-reveal.is-visible::after{
  transform: scaleX(1);
}

/* ikonka v “pilulce” */
.wd-ic{
  width: 44px;
  height: 44px;
  border-radius: 14px;
  display: grid;
  place-items: center;
  background: rgba(0,0,0,.06);
  flex: 0 0 auto;
}

.wd-ic svg{
  width: 22px;
  height: 22px;
  display: block;
}

.wd-icon-title{
  margin: 0 0 6px 0;
  font-size: 1.05rem;
  line-height: 1.25;
}

.wd-icon-desc{
  margin: 0;
  line-height: 1.55;
  opacity: .88;
}

/* responzivita */
@media (max-width: 992px){
  .wd-icons-grid{ grid-template-columns: repeat(2, minmax(0, 1fr)); }
}
@media (max-width: 576px){
  .wd-icons-grid{ grid-template-columns: 1fr; }
}


/* ===== CONTACT FORM ===== */
.wd-contact{
  padding: clamp(36px, 5vw, 72px) 0;
}

.wd-contact-head{
  margin-bottom: clamp(14px, 2.5vw, 22px);
}

.wd-contact-card{
  border-radius: 18px;
  border: 1px solid rgba(0,0,0,.10);
  background: rgba(0,0,0,.02);
  padding: clamp(16px, 3vw, 28px);
  position: relative;
  overflow: hidden;
}

/* jemný “shine” */
.wd-contact-card::before{
  content:"";
  position:absolute;
  inset:-2px;
  background: radial-gradient(700px 180px at 18% 0%, rgba(0,0,0,.06), transparent 60%);
  pointer-events:none;
  opacity:.9;
}

.wd-form{ position: relative; z-index: 1; }

.wd-form-grid{
  display: grid;
  grid-template-columns: repeat(2, minmax(0,1fr));
  gap: 14px;
}

.wd-field{ display: flex; flex-direction: column; gap: 7px; }
.wd-field-full{ grid-column: 1 / -1; }

.wd-label{
  font-weight: 600;
  font-size: .95rem;
  opacity: .88;
}

.wd-input{
  width: 100%;
  box-sizing: border-box;
  padding: 12px 12px;
  border-radius: 12px;
  border: 1px solid rgba(0,0,0,.14);
  background: rgba(255,255,255,.86);
  outline: none;
  transition: transform 180ms ease, box-shadow 220ms ease, border-color 220ms ease;
}

.wd-textarea{
  resize: vertical;
  min-height: 140px;
}

/* focus “micro interaction” */
.wd-input:focus{
  border-color: rgba(0,0,0,.35);
  box-shadow: 0 10px 26px rgba(0,0,0,.10);
  transform: translateY(-1px);
}

/* footer */
.wd-form-footer{
  margin-top: 14px;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 14px;
  flex-wrap: wrap;
}

.wd-privacy{
  font-size: .92rem;
  opacity: .75;
  max-width: 70ch;
}

.wd-btn{
  border: 1px solid rgba(0,0,0,.18);
  background: rgba(0,0,0,.92);
  color: #fff;
  padding: 12px 16px;
  border-radius: 999px;
  cursor: pointer;
  display: inline-flex;
  align-items: center;
  gap: 10px;
  transition: transform 160ms ease, opacity 200ms ease;
  user-select: none;
}

.wd-btn:hover{ transform: translateY(-1px); opacity: .95; }
.wd-btn:active{ transform: translateY(0px); opacity: .92; }

.wd-btn-arrow{
  display: inline-block;
  transform: translateX(0);
  transition: transform 180ms ease;
}

.wd-btn:hover .wd-btn-arrow{
  transform: translateX(4px);
}

/* responzivita */
@media (max-width: 768px){
  .wd-form-grid{ grid-template-columns: 1fr; }
}

:root{
  --c-dark:#1d2324;
  --c-text:#5f6b6d;
  --c-muted:#8a9597;
  --c-primary:#0d6efd;
}

body{
  color: var(--c-text);
  font-size: 18px;
  line-height: 1.65;
  -webkit-font-smoothing: antialiased;
  text-rendering: optimizeLegibility;
}

h1,h2,h3{
  /* color: var(--c-dark); */
  letter-spacing: -0.02em;
}

.hero-title, h1{
  font-size: clamp(2.2rem, 4vw, 3.4rem);
  line-height: 1.08;
  font-weight: 700;
}

h2{
  font-size: clamp(1.6rem, 2.4vw, 2.2rem);
  line-height: 1.18;
  font-weight: 700;
}

h3{
  font-size: 1.125rem;
  line-height: 1.25;
  font-weight: 700;
}

.lead{
  font-size: 1.15rem;
  line-height: 1.55;
  color: #4b5658;
  max-width: 56ch;
}

p{ max-width: 70ch; }

.text-narrow{ max-width: 56ch; }
.text-normal{ max-width: 70ch; }

a{
  color: var(--c-primary);
  text-decoration: none;
}
a:hover{
  color:#0b5ed7;
  text-decoration: underline;
  text-underline-offset: 3px;
}

.section{ padding: 100px 0; }
.section-sm{ padding: 70px 0; }
.section-lg{ padding: 130px 0; }

.section-dark{
  background: var(--c-dark);
  color: #d1d5d6;
}
.section-dark h1,
.section-dark h2,
.section-dark h3{ color:#fff; }
.section-dark .lead{ color:#d1d5d6; }

.btn-primary,
.btn-outline-secondary{
  border-radius: 14px;
  padding: .85rem 1.15rem;
  font-weight: 600;
}

/* Zruší jakékoli rotace/transformace na hoveru jen v sekci #pro-koho */
#pro-koho .card,
#pro-koho .card:hover,
#pro-koho .card * ,
#pro-koho .card:hover * {
  transform: none !important;
  animation: none !important;
}

#pro-koho .card {
  transition: transform .25s ease, box-shadow .25s ease;
}

#pro-koho .card:hover {
  transform: translateY(-4px) !important;
  box-shadow: 0 14px 34px rgba(0,0,0,.10);
}

.bg-white {
	background: #fff;
}

.bg-light {
	background: #f4f6f7;
}

.section {
  padding: 100px 0;
}

@media (max-width: 768px) {
  .section {
    padding: 60px 0;
  }
}


.pricing-card {
  transition: all .3s ease;
}

.pricing-card:hover {
  transform: translateY(-6px);
  box-shadow: 0 18px 40px rgba(0,0,0,.12);
}

.pricing-card.featured {
  border: 2px solid #c6a46a;
}

.price {
  font-size: 1.6rem;
  color: #1d2324;
}


/* =====================================================
   TYPO SYSTEM (luxusní / studio look)
===================================================== */

:root{
  /* fonty */
  --ff-body: Georgia, "Times New Roman", serif;
  --ff-head: Georgia, "Times New Roman", serif;

  /* váhy */
  --fw-regular: 400;
  --fw-medium: 500;
  --fw-semibold: 600;
  --fw-bold: 700;
  --fw-extrabold: 800;

  /* line-height (víc „vzduchu“, luxusnější rytmus) */
  --lh-tight: 1.02;
  --lh-snug: 1.15;
  --lh-normal: 1.60;
  --lh-relaxed: 1.75;

  /* škála font-size (větší kontrast = premium) */
  --fs-900: clamp(3.8rem, 6.0vw, 7.5rem); /* HERO H1 dominantní */
  --fs-800: clamp(2.8rem, 4.0vw, 4.8rem); /* H1 */
  --fs-700: clamp(2.2rem, 3.0vw, 3.2rem); /* H2 */
  --fs-600: clamp(1.6rem, 2.0vw, 2.1rem); /* H3 */
  --fs-500: clamp(1.18rem, 1.25vw, 1.40rem); /* lead / perex */
  --fs-400: 1.05rem;                      /* body */
  --fs-300: 0.92rem;                      /* small */
  --fs-200: 0.84rem;                      /* micro */

  /* letter-spacing */
  --ls-tight: -0.03em; /* dražší dojem pro headlines */
  --ls-normal: 0;
}

/* globální základ */
html{ font-size: 16px; }

body{
  font-family: var(--ff-body);
  font-weight: var(--fw-regular);
  font-size: var(--fs-400);
  line-height: var(--lh-relaxed);
  letter-spacing: -0.01em; /* jemně premium */
  text-rendering: optimizeLegibility;
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
}

/* nadpisy globálně */
h1,h2,h3,h4,h5,h6{
  font-family: var(--ff-head);
  letter-spacing: var(--ls-tight);
  line-height: var(--lh-snug);
  margin: 0 0 .55em 0;
}

h1{ font-size: var(--fs-800); font-weight: var(--fw-bold); letter-spacing: -0.035em; }
h2{ font-size: var(--fs-700); font-weight: var(--fw-bold); letter-spacing: -0.03em; }
h3{ font-size: var(--fs-600); font-weight: var(--fw-bold);      letter-spacing: -0.02em; }
h4{ font-size: 1.25rem;      font-weight: var(--fw-bold);       letter-spacing: -0.01em; }

small, .text-small{
  font-size: var(--fs-300);
  letter-spacing: 0;
}

/* “lead/perex” třída */
.lead, .text-lead{
  font-size: var(--fs-500);
  line-height: var(--lh-relaxed);
  letter-spacing: -0.005em;
  max-width: 62ch; /* luxusní čitelnost */
}


/* =====================================================
   HERO typography mapping (luxus)
===================================================== */

.hero-subtitle{
  font-family: var(--ff-body);
  font-weight: var(--fw-medium);
  font-size: 1.65rem;
  letter-spacing: 0.1em;     /* elegantní label */
  text-transform: uppercase;
  opacity: .75;
  margin-bottom: .55rem;
}

.hero-title{
  font-family: var(--ff-head);
  font-weight: var(--fw-bold);
  font-size: var(--fs-800);
  line-height: var(--lh-tight);
  letter-spacing: -0.035em;  /* extra premium */
  margin-bottom: .7rem;
}

.hero-perex{
  font-family: var(--ff-body);
  font-weight: var(--fw-regular);
  font-size: var(--fs-500);
  line-height: var(--lh-relaxed);
  letter-spacing: -0.005em;
  max-width: 48ch;           /* premium: kratší řádek */
}

.hero-text{ box-shadow: 0 30px 80px rgba(0,0,0,.18); }


/* HEADINGS */
.bg-white h1,
.bg-white h2,
.bg-white h3,
.bg-light h1,
.bg-light h2,
.bg-light h3 {
  color: #1d2324 !important;
}

/* TEXT */
.bg-white p,
.bg-light p {
  color: #5f6b6d !important;
}

/* LEAD */
.bg-white .lead,
.bg-light .lead {
  color: #4b5658 !important;
}

/* LINKS */
.bg-white a,
.bg-light a {
  color:  #af8c51 !important;
}

.bg-white a:hover,
.bg-light a:hover {
  color: #c6a46a !important;
}


.bg-dark {
  background-color: #1d2324 !important;
  color: #c7cdcf !important;
}

/* NADPISY */
.bg-dark h1,
.bg-dark h2,
.bg-dark h3,
.bg-dark h4 {
  color: #ffffff !important;
}

/* PEREX */
.bg-dark .lead {
  color: #d1d5d6 !important;
}

/* TEXT */
.bg-dark p,
.bg-dark li {
  color: #c7cdcf !important;
}

/* MUTED TEXT */
.bg-dark .text-muted {
  color: #9aa3a5 !important !important;
}

/* ODKAZY */
.bg-dark a {
  color: #c6a46a !important;
}

.bg-dark a:hover {
  color: #af8c51 !important;
}

.btn-outline-primary {
  border: 2px solid #0d6efd;
  color: #0d6efd;
  font-weight: 600;
  padding: 0.85rem 1.4rem;
  border-radius: 14px;
  transition: all .25s ease;
}

.btn-outline-primary:hover {
  background-color: #0d6efd;
  color: #ffffff;
  transform: translateY(-2px);
}

.bg-dark .btn-primary {
  background-color: #0d6efd;
  border-color: #0d6efd;
}

.bg-dark .btn-outline-primary {
  border-color: #ffffff;
  color: #ffffff;
}

.bg-dark .btn-outline-primary:hover {
  background-color: #ffffff;
  color: #1d2324;
}

.cta-note {
  font-size: 0.9rem;
  color: #8a9597;
}

.bg-dark .cta-note {
  color: #aab2b4;
}

.btn {
  letter-spacing: .2px;
}

.btn:focus,
.btn:active {
  box-shadow: none !important;
}

.hero-buttons .btn {
  transition: all 0.25s ease;
  border-radius: 12px; /* lehce modernější look */
  padding: 0.9rem 1.8rem;
}

/* jemný pohyb nahoru */
.hero-buttons .btn:hover {
  transform: translateY(-3px);
}

/* primární tlačítko - decentní stín */
.btn-hero-primary:hover {
  box-shadow: 0 12px 30px rgba(0, 0, 0, 0.15);
}

/* outline tlačítko - lehčí stín */
.btn-hero-outline:hover {
  box-shadow: 0 8px 20px rgba(0, 0, 0, 0.08);
}

.btn-hero-primary {
  position: relative;
  overflow: hidden;
}

.btn-hero-primary::after {
  content: "";
  position: absolute;
  top: 0;
  left: -100%;
  width: 120%;
  height: 100%;
  background: linear-gradient(
    120deg,
    transparent 0%,
    rgba(255,255,255,0.25) 50%,
    transparent 100%
  );
  transition: all 0.6s ease;
}

.btn-hero-primary:hover::after {
  left: 100%;
}

.hero-buttons .btn {
  transition: all 0.25s ease;
  border-radius: 14px;
  padding: 0.95rem 2rem;
  font-weight: 500;
  letter-spacing: 0.2px;
}

.btn-hero-primary {
  background: linear-gradient(135deg, #1f3c88 0%, #2952cc 100%);
  border: none;
  box-shadow: 0 6px 18px rgba(31, 60, 136, 0.18);
}

.btn-hero-primary:hover {
  transform: translateY(-3px);
  box-shadow: 0 14px 35px rgba(31, 60, 136, 0.28);
}

.btn-hero-outline {
  background-color: #ffffff;
  border: 2px solid #e3e7ef;
  color: #2c2c2c;
}

.btn-hero-outline:hover {
  background-color: #f4f6f7;
  border-color: #d6dbe6;
  transform: translateY(-3px);
  box-shadow: 0 10px 25px rgba(0, 0, 0, 0.06);
}

.btn-hero-primary {
  position: relative;
  overflow: hidden;
}

.btn-hero-primary::after {
  content: "";
  position: absolute;
  top: 0;
  left: -120%;
  width: 120%;
  height: 100%;
  background: linear-gradient(
    120deg,
    transparent 0%,
    rgba(255,255,255,0.18) 50%,
    transparent 100%
  );
  transition: all 0.7s ease;
}

.btn-hero-primary:hover::after {
  left: 120%;
}

.hamburger-btn{
  width: 44px; height: 44px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  border: 0;
  background: transparent;
  padding: 0;
}
.hamburger-btn span{
  display: block;
  width: 22px;
  height: 2px;
  margin: 3px 0;
  background: currentColor;
}

html {
  scroll-behavior: smooth;
}

.navbar-toggler-icon {
  width: 4.5em;
  height: 4.5em;
color: #fff;
}



.offcanvas {
  max-width: 100%;
  width: 100%;
}


@media (max-width: 991.98px){
  .offcanvas.mobile-full{
    width: 100vw;
    max-width: 100vw;
  }
  .offcanvas.mobile-full .offcanvas-body{
    display:flex;
    align-items:center;
    justify-content:center;
  }
  .offcanvas.mobile-full .mobile-menu{
    width:100%;
    display:flex;
    flex-direction:column;
    gap:14px;
    padding: 8px 8px;
  }
  .offcanvas.mobile-full .mobile-link{
    display:block;
    font-size: 1.35rem;
    line-height: 1.2;
    text-decoration: none;
    padding: 14px 12px;
    border-radius: 12px;
  }
  .offcanvas.mobile-full .mobile-link:hover{
    background: rgba(0,0,0,.06);
  }
}

.hamburger-btn{
  width:44px;height:44px;
  border:0;background:transparent;padding:0;
  display:inline-flex;flex-direction:column;
  justify-content:center;gap:6px;
}
.hamburger-btn span{
  width:24px;height:2px;
  background: currentColor;
  display:block;
  transition: transform .2s ease, opacity .2s ease;
}
.hamburger-btn.is-open span:nth-child(1){ transform: translateY(8px) rotate(45deg); }
.hamburger-btn.is-open span:nth-child(2){ opacity:0; }
.hamburger-btn.is-open span:nth-child(3){ transform: translateY(-8px) rotate(-45deg); }


.hamburger-btn{
  width:44px !important;
  height:44px !important;
  border:0 !important;
  background:transparent !important;
  padding:0 !important;

  display:flex !important;
  flex-direction:column !important;
  align-items:none !important;
  justify-content:left !important;
  gap:6px !important;

  position:relative !important;
  z-index:9999 !important;

  opacity:1 !important;
  visibility:visible !important;
}

.hamburger-btn span{
  width:26px !important;
  height:3px !important;
  background-color:#fff !important; /* změň na #fff na tmavém pozadí */
  display:block !important;

  opacity:1 !important;
  visibility:visible !important;
}

@media (min-width: 992px){
  .mobile-menu{
    display:flex;
    flex-direction:column;
    gap:12px;
  }
}

div#mainMenu {
background: #242d2e;
}
div#mainMenu a {
color: #d1d5d6;
font-size: 1.4rem;
}
.btn-close {
    --bs-btn-close-color: #fff;
}

/* Základ */
#mainMenu .mobile-link{
  position: relative;
  display: inline-flex;          /* ať underline sedí na text */
  align-items: center;
  gap: .4rem;
  padding: .25rem 0;
  color: #d1d5d6;
  font-size: 1.4rem;

  text-decoration: none;
  transition: color .18s ease, transform .18s ease, opacity .18s ease;
  will-change: transform;
}

/* Jemná linka pod textem (reveal zleva) */
#mainMenu .mobile-link::after{
  content: "";
  position: absolute;
  left: 0;
  bottom: -6px;
  height: 1px;
  width: 100%;
  background: currentColor;
  opacity: .55;

  transform: scaleX(.08);
  transform-origin: left center;
  transition: transform .22s ease, opacity .22s ease;
}

/* Hover / focus (i pro klávesnici) */
#mainMenu .mobile-link:hover,
#mainMenu .mobile-link:focus-visible{
  color: #ffffff;
  transform: translateX(3px);
}

#mainMenu .mobile-link:hover::after,
#mainMenu .mobile-link:focus-visible::after{
  transform: scaleX(1);
  opacity: .75;
}

/* “Premium” detail: jemný glow jen na hover */
#mainMenu .mobile-link:hover{
  text-shadow: 0 0 18px rgba(255,255,255,.12);
}

/* Kliknutí (active) – mikropohyb */
#mainMenu .mobile-link:active{
  transform: translateX(2px) scale(.99);
}

/* Respektuje uživatele, co nechtějí animace */
@media (prefers-reduced-motion: reduce){
  #mainMenu .mobile-link,
  #mainMenu .mobile-link::after{
    transition: none;
  }
}


#mainMenu .mobile-link{
  opacity:0;
  transform:translateY(6px);
  animation: menuReveal .35s ease forwards;
}

#mainMenu .mobile-link:nth-child(1){ animation-delay:.05s }
#mainMenu .mobile-link:nth-child(2){ animation-delay:.09s }
#mainMenu .mobile-link:nth-child(3){ animation-delay:.13s }
#mainMenu .mobile-link:nth-child(4){ animation-delay:.17s }

@keyframes menuReveal{
  to{
    opacity:1;
    transform:translateY(0);
  }
}

.offcanvas{
  backdrop-filter: blur(6px);
}

.mobile-link{
  padding:10px 6px;
}

.menu-chevron{
  display:inline-flex;
  align-items:center;
  gap:10px;
  background:none;
  border:0;
  cursor:pointer;
  font-weight:600;
  font-size: 1.4em;
  letter-spacing:.12em;
  text-transform:uppercase;
color: rgba(255,255,255,.9);
padding-left: 2em;
}
.menu-chevron .chev{
  width:10px;height:10px;
  border-right:2px solid rgba(255,255,255,.9);
  border-bottom:2px solid rgba(255,255,255,.9);
  transform:rotate(-45deg);
  transition:transform .25s ease;
  opacity:.8;
}
.menu-chevron:hover .chev{ transform:rotate(135deg); }

.fa-solid, .fa-brands, .fas, .far, .fab {
  /* color:#394446 !important; */
  transition:color .25s ease;
}

.fa-solid:hover, .fa-brands:hover, .fas:hover, .far:hover, .fab:hover {
  color:#1d2324 !important;
}

@media (min-width: 993px){
	div.ref-div {
	padding: 20px 40px;
	}
	
}


.hero-float{
  animation: heroFloatSoft 7s ease-in-out infinite;
  will-change: transform;
}

@keyframes heroFloatSoft{
  0%{
    transform: translate3d(0, 0, 0);
  }
  25%{
    transform: translate3d(0, -6px, 0);
  }
  50%{
    transform: translate3d(0, -10px, 0);
  }
  75%{
    transform: translate3d(0, -4px, 0);
  }
  100%{
    transform: translate3d(0, 0, 0);
  }
}

@media (max-width: 767.98px){
  .hero-float{
    animation: none;
  }
}

:root{
  --case-bg: #f6f8f8;
  --case-card: rgba(255,255,255,0.82);
  --case-border: rgba(29,35,36,0.08);
  --case-heading: #1d2324;
  --case-text: #5f6b6d;
  --case-muted: #7a8789;
  --case-accent: #1d2324;
  --case-radius-xl: 28px;
  --case-radius-lg: 22px;
  --case-radius-md: 16px;
  --case-shadow-soft: 0 18px 60px rgba(18, 28, 29, 0.08);
  --case-shadow-premium: 0 24px 80px rgba(18, 28, 29, 0.14);
}

.case-study-hero{
  background:
    radial-gradient(circle at top left, rgba(255,255,255,0.95), rgba(255,255,255,0) 40%),
    linear-gradient(180deg, #f8fafa 0%, #f3f6f6 100%);
}

.case-study-content{
  background: var(--case-bg);
}

.py-lg-6{
  padding-top: 5rem;
  padding-bottom: 5rem;
}

.case-study-eyebrow{
  display:inline-flex;
  align-items:center;
  gap:.5rem;
  font-size:.82rem;
  letter-spacing:.16em;
  text-transform:uppercase;
  color: var(--case-muted);
  font-weight:600;
}

.case-study-title{
  font-size: clamp(2.2rem, 5vw, 4.4rem);
  line-height: 1.02;
  font-weight: 800;
  color: var(--case-heading);
  letter-spacing: -0.03em;
  margin:0;
}

.case-study-lead{
  font-size: 1.08rem;
  line-height: 1.8;
  color: var(--case-text);
  max-width: 60ch;
}

.case-study-tags{
  display:flex;
  flex-wrap:wrap;
  gap:.75rem;
}

.case-tag{
  display:inline-flex;
  align-items:center;
  min-height:42px;
  padding:.6rem .95rem;
  border-radius:999px;
  border:1px solid var(--case-border);
  background: rgba(255,255,255,.78);
  color: var(--case-heading);
  font-size:.92rem;
  font-weight:600;
}

.btn-case-primary,
.btn-case-secondary{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  min-height:54px;
  padding:0 1.35rem;
  border-radius:999px;
  text-decoration:none;
  font-weight:700;
  transition: all .28s ease;
}

.btn-case-primary{
  background: var(--case-accent);
  color:#fff;
  border:1px solid var(--case-accent);
}

.btn-case-primary:hover{
  transform: translateY(-2px);
  color:#fff;
  box-shadow: 0 14px 30px rgba(29,35,36,.18);
}

.btn-case-secondary{
  background: rgba(255,255,255,.8);
  color: var(--case-heading);
  border:1px solid var(--case-border);
}

.btn-case-secondary:hover{
  transform: translateY(-2px);
  color: var(--case-heading);
  background:#fff;
}

.case-browser-frame{
  background: rgba(255,255,255,.85);
  border: 1px solid rgba(255,255,255,.9);
  border-radius: 26px;
  overflow: hidden;
  backdrop-filter: blur(10px);
}

.case-browser-top{
  display:flex;
  align-items:center;
  gap:8px;
  padding:14px 18px;
  border-bottom:1px solid rgba(29,35,36,0.06);
  background: rgba(248,250,250,.9);
}

.case-browser-top span{
  width:10px;
  height:10px;
  border-radius:50%;
  background:#d8dede;
  display:block;
}

.case-browser-body img{
  display:block;
  width:100%;
  height:auto;
}

.case-card{
  background: var(--case-card);
  border:1px solid var(--case-border);
  border-radius: var(--case-radius-xl);
  padding: 2rem;
  backdrop-filter: blur(10px);
}

.case-section-title,
.case-sidebar-title{
  color: var(--case-heading);
  font-weight: 800;
  letter-spacing: -0.02em;
  line-height:1.1;
}

.case-section-title{
  font-size: clamp(1.5rem, 2vw, 2rem);
}

.case-sidebar-title{
  font-size: 1.2rem;
}

.case-card p{
  color: var(--case-text);
  line-height: 1.85;
  margin-bottom: 1rem;
}

.case-info-box{
  height:100%;
  padding:1.2rem 1.2rem 1.1rem;
  border-radius: 18px;
  background: rgba(255,255,255,.7);
  border:1px solid rgba(29,35,36,.06);
}

.case-info-box h3{
  font-size:1rem;
  font-weight:700;
  color: var(--case-heading);
  margin-bottom:.5rem;
}

.case-info-box p{
  margin:0;
  font-size:.98rem;
}

.case-gallery-note{
  color: var(--case-muted);
  font-size:.95rem;
}

.case-gallery-grid{
  display:grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 1rem;
}

.case-gallery-item{
  display:block;
  position:relative;
  border-radius: 18px;
  overflow:hidden;
  background:#fff;
  border:1px solid rgba(29,35,36,.06);
  box-shadow: 0 10px 30px rgba(18,28,29,.06);
  transition: transform .35s ease, box-shadow .35s ease;
}

.case-gallery-item:hover{
  transform: translateY(-4px);
  box-shadow: 0 18px 36px rgba(18,28,29,.12);
}

.case-gallery-item img{
  width:100%;
  height:100%;
  display:block;
/*  aspect-ratio: 16 / 11; */
  object-fit: cover;
}

.case-sidebar{
  top: 110px;
}

.case-meta-item{
  padding:.85rem 0;
  border-bottom:1px solid rgba(29,35,36,.08);
}

.case-meta-item:last-child{
  border-bottom:0;
}

.case-meta-label{
  display:block;
  font-size:.82rem;
  text-transform:uppercase;
  letter-spacing:.08em;
  color: var(--case-muted);
  margin-bottom:.28rem;
  font-weight:700;
}

.case-meta-value{
  display:block;
  color: var(--case-heading);
  font-weight:600;
  line-height:1.6;
}

.case-bullets{
  margin:0;
  padding-left:1.1rem;
  color: var(--case-text);
}

.case-bullets li{
  margin-bottom:.8rem;
  line-height:1.7;
}

.shadow-soft{
  box-shadow: var(--case-shadow-soft);
}

.shadow-premium{
  box-shadow: var(--case-shadow-premium);
}

@media (max-width: 991.98px){
  .case-card{
    padding: 1.4rem;
    border-radius: 22px;
  }

  .case-gallery-grid{
    grid-template-columns: 1fr;
  }

  .case-study-lead{
    max-width: 100%;
  }
}


.case-gallery-grid{
  display:grid;
  grid-template-columns:repeat(2, 1fr);
  gap:1rem;
}

.case-gallery-item{
  position:relative;
  display:block;
  overflow:hidden;
  border-radius:20px;
  background:#fff;
  border:1px solid rgba(29,35,36,.08);
  box-shadow:0 10px 30px rgba(18,28,29,.07);
  transform:translateY(0);
  transition:
    transform .45s ease,
    box-shadow .45s ease,
    border-color .45s ease;
  isolation:isolate;
}

.case-gallery-item img{
  display:block;
  width:100%;
  height:100%;
  /* aspect-ratio:16 / 11; */
  object-fit:cover;
  transform:scale(1);
  transition:transform .7s ease;
}

.case-gallery-overlay{
  position:absolute;
  inset:0;
  display:flex;
  align-items:flex-end;
  justify-content:flex-end;
  padding:1rem;
  background:
    linear-gradient(to top, rgba(18,28,29,.28), rgba(18,28,29,0) 45%);
  opacity:0;
  transition:opacity .35s ease;
  z-index:2;
}

.case-gallery-zoom{
  width:46px;
  height:46px;
  border-radius:50%;
  display:inline-flex;
  align-items:center;
  justify-content:center;
  background:rgba(255,255,255,.92);
  color:#1d2324;
  box-shadow:0 10px 24px rgba(18,28,29,.16);
  transform:translateY(8px) scale(.94);
  transition:transform .35s ease;
  font-size:1rem;
}

.case-gallery-item::after{
  content:"";
  position:absolute;
  inset:0;
  border-radius:inherit;
  pointer-events:none;
  box-shadow:inset 0 0 0 1px rgba(255,255,255,.35);
  opacity:.7;
  z-index:1;
}

.case-gallery-item:hover{
  transform:translateY(-6px);
  box-shadow:0 20px 42px rgba(18,28,29,.14);
  border-color:rgba(29,35,36,.12);
}

.case-gallery-item:hover img{
  transform:scale(1.045);
}

.case-gallery-item:hover .case-gallery-overlay{
  opacity:1;
}

.case-gallery-item:hover .case-gallery-zoom{
  transform:translateY(0) scale(1);
}

@media (max-width: 991.98px){
  .case-gallery-grid{
    grid-template-columns:1fr;
  }
}


.js-reveal{
  opacity:0;
  transform:translateY(26px);
  transition:
    opacity .8s ease,
    transform .8s ease;
  transition-delay:var(--reveal-delay, 0s);
  will-change:opacity, transform;
}

.js-reveal.is-visible{
  opacity:1;
  transform:translateY(0);
}

@media (prefers-reduced-motion: reduce){
  .js-reveal{
    opacity:1 !important;
    transform:none !important;
    transition:none !important;
  }

  .case-gallery-item,
  .case-gallery-item img,
  .case-gallery-overlay,
  .case-gallery-zoom,
  .case-lightbox,
  .case-lightbox-inner{
    transition:none !important;
  }
}


.case-lightbox{
  position:fixed;
  inset:0;
  display:flex;
  align-items:center;
  justify-content:center;
  padding:2rem;
  background:rgba(10,14,15,.82);
  backdrop-filter:blur(8px);
  opacity:0;
  visibility:hidden;
  pointer-events:none;
  transition:
    opacity .28s ease,
    visibility .28s ease;
  z-index:9999;
}

.case-lightbox.is-open{
  opacity:1;
  visibility:visible;
  pointer-events:auto;
}

.case-lightbox-inner{
  max-width:min(1200px, 92vw);
  max-height:86vh;
  transform:translateY(10px) scale(.985);
  transition:transform .3s ease;
}

.case-lightbox.is-open .case-lightbox-inner{
  transform:translateY(0) scale(1);
}

.case-lightbox-image{
  display:block;
  max-width:100%;
  max-height:86vh;
  width:auto;
  height:auto;
  border-radius:20px;
  box-shadow:0 24px 60px rgba(0,0,0,.35);
  background:#fff;
}

.case-lightbox-close,
.case-lightbox-nav{
  position:absolute;
  border:0;
  background:rgba(255,255,255,.1);
  color:#fff;
  display:inline-flex;
  align-items:center;
  justify-content:center;
  cursor:pointer;
  backdrop-filter:blur(10px);
  transition:
    background .25s ease,
    transform .25s ease;
}

.case-lightbox-close:hover,
.case-lightbox-nav:hover{
  background:rgba(255,255,255,.18);
  transform:translateY(-1px);
}

.case-lightbox-close{
  top:24px;
  right:24px;
  width:52px;
  height:52px;
  border-radius:50%;
  font-size:1.25rem;
}

.case-lightbox-nav{
  top:50%;
  transform:translateY(-50%);
  width:56px;
  height:56px;
  border-radius:50%;
  font-size:1.1rem;
}

.case-lightbox-prev{
  left:24px;
}

.case-lightbox-next{
  right:24px;
}

.case-lightbox-prev:hover,
.case-lightbox-next:hover{
  transform:translateY(-50%) scale(1.03);
}

body.case-lightbox-open{
  overflow:hidden;
}

@media (max-width: 767.98px){
  .case-lightbox{
    padding:1rem;
  }

  .case-lightbox-nav{
    width:46px;
    height:46px;
  }

  .case-lightbox-prev{
    left:10px;
  }

  .case-lightbox-next{
    right:10px;
  }

  .case-lightbox-close{
    top:12px;
    right:12px;
    width:46px;
    height:46px;
  }
}


#mainMenu{
  background:
    radial-gradient(circle at 20% 20%, rgba(255,255,255,0.03), transparent 40%),
    linear-gradient(180deg,#0f1a1d,#1a2a2e) !important;
}


.mobile-link{
  font-size:1.6rem !important;
  letter-spacing:.02em !important;
  padding:14px 0 !important;
}

.mobile-link:nth-child(1){transition-delay:.05s;}
.mobile-link:nth-child(2){transition-delay:.1s;}
.mobile-link:nth-child(3){transition-delay:.15s;}
.mobile-link:nth-child(4){transition-delay:.2s;}


.btn-close{
  filter:invert(1) !important;
  opacity:.8 !important;
}

.mobile-link.active{
  color:#fff !important;
  font-weight:600 !important;
}

.menu-brand{
  margin-bottom:32px;
}

.menu-logo{
  font-size:1.2rem;
  font-weight:600;
  color:#fff;
}

.menu-tagline{
  font-size:.8rem;
  color:#94a3b8;
}

.hero-kicker{
  display:flex;
  align-items:center;
  gap:14px;
  margin-bottom:18px;
  font-size:.72rem;
  font-weight:500;
  letter-spacing:.22em;
  text-transform:uppercase;
  color:rgba(255,255,255,.62);
}

.hero-kicker span{
  display:block;
  width:42px;
  height:1px;
  background:rgba(255,255,255,.28);
}

.hero-signature{
  display:inline-block;
  padding-top:18px;
  border-top:1px solid rgba(255,255,255,.16);
}

.hero-signature-brand{
  font-size:1rem;
  font-weight:600;
  letter-spacing:.01em;
  color:#fff;
}

.hero-signature-sub{
  margin-top:4px;
  font-size:.72rem;
  letter-spacing:.22em;
  text-transform:uppercase;
  color:rgba(255,255,255,.58);
}

.menu-sticky-wrap{
  position: sticky;
  top: 0;
  z-index: 1030;
  padding-top: 12px;
  padding-bottom: 12px;
  background: linear-gradient(to bottom, rgba(0,0,0,.18), rgba(0,0,0,0));
}


/* floating menu trigger */

.menu-floating-trigger{
  position: fixed;
  top: 18px;
  right: 18px;
  z-index: 1035;
}


/* menu button */

.menu-chevron{
  display: inline-flex;
  align-items: center;
  gap: .65rem;

  padding: .8rem 1rem;

  border: 0;
  border-radius: 999px;

  background: rgba(20,20,20,.82);
  color: #fff;

  font-size: .95rem;
  font-weight: 500;

  cursor: pointer;

  backdrop-filter: blur(8px);
  -webkit-backdrop-filter: blur(8px);

  box-shadow: 0 10px 30px rgba(0,0,0,.18);

  transition: all .25s ease;
}


/* hover efekt */

.menu-chevron:hover{
  transform: translateY(-2px);
  box-shadow: 0 14px 36px rgba(0,0,0,.25);
}


/* chevron šipka */

.menu-chevron .chev{
  width: 8px;
  height: 8px;

  border-right: 2px solid #fff;
  border-bottom: 2px solid #fff;

  transform: rotate(45deg);
  margin-top: -2px;
}


/* aby offcanvas byl nad buttonem */

.offcanvas{
  z-index: 1045;
}


/* mobil drobné odsazení */

@media (max-width: 768px){

  .menu-floating-trigger{
    top: 14px;
    right: 14px;
  }

}


.btn-hero-primary{
  background: linear-gradient(135deg,#2a46c7,#3f6df6);
  border:none;
  box-shadow:0 10px 28px rgba(63,109,246,.35);
	transition:all .25s ease;
}

btn-hero-primary:hover{
  transform:translateY(-2px);
  box-shadow:0 12px 30px rgba(63,109,246,.45);
}


.bg-dark {
  background-color: #1d2324 !important;
  color: #c7cdcf !important;
}

/* Sekce */
.contact-section {
  position: relative;
  overflow: hidden;
}

.contact-eyebrow {
  display: inline-block;
  font-size: 0.82rem;
  font-weight: 700;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: #8fa3ad;
}

.contact-title {
  color: #fff;
  font-weight: 700;
  line-height: 1.15;
}

.contact-lead {
  color: #aeb8bb;
  font-size: 1.05rem;
  max-width: 760px;
  margin: 0 auto;
}

/* Karty */
.contact-card {
  background: linear-gradient(180deg, rgba(255,255,255,0.04) 0%, rgba(255,255,255,0.025) 100%);
  border: 1px solid rgba(255,255,255,0.08);
  border-radius: 1.25rem;
  padding: 2rem;
  box-shadow:
    0 18px 45px rgba(0,0,0,0.22),
    inset 0 1px 0 rgba(255,255,255,0.03);
  backdrop-filter: blur(6px);
}

.contact-card-title {
  color: #fff;
  font-size: 1.35rem;
  font-weight: 700;
}

.contact-card-text {
  color: #aeb8bb;
  line-height: 1.7;
}

/* Kontaktní info */
.contact-info-list {
  display: flex;
  flex-direction: column;
  gap: 0.9rem;
}

.contact-info-item {
  display: flex;
  align-items: center;
  gap: 1rem;
  padding: 1rem 1.1rem;
  border-radius: 1rem;
  text-decoration: none;
  color: #e8ecee;
  background: rgba(255,255,255,0.03);
  border: 1px solid rgba(255,255,255,0.06);
  transition: transform 0.22s ease, border-color 0.22s ease, background 0.22s ease;
}

.contact-info-item:hover {
  transform: translateY(-2px);
  color: #fff;
  background: rgba(255,255,255,0.05);
  border-color: rgba(255,255,255,0.14);
}

.contact-info-item small {
  color: #93a3aa;
  margin-bottom: 0.15rem;
  font-size: 0.78rem;
  letter-spacing: 0.04em;
  text-transform: uppercase;
}

.contact-info-icon {
  width: 46px;
  height: 46px;
  flex: 0 0 46px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  border-radius: 50%;
  background: linear-gradient(135deg, rgba(41,82,204,0.28) 0%, rgba(31,60,136,0.4) 100%);
  background: #c6a46a;
  color: #fff;
  font-size: 1rem;
  box-shadow: 0 8px 20px rgba(0,0,0,0.18);
}

.contact-note {
  color: #94a4aa;
  font-size: 0.96rem;
  line-height: 1.7;
  border-top: 1px solid rgba(255,255,255,0.08);
  padding-top: 1rem;
}

/* Formulář */
.contact-section .form-label {
  color: #eef2f3;
  font-weight: 600;
  margin-bottom: 0.5rem;
}

.contact-section .form-control {
  background-color: rgba(255,255,255,0.045);
  border: 1px solid rgba(255,255,255,0.1);
  color: #fff;
  border-radius: 0.9rem;
  padding: 0.9rem 1rem;
  min-height: 54px;
  box-shadow: none;
  transition: border-color 0.2s ease, box-shadow 0.2s ease, background-color 0.2s ease;
}

.contact-section textarea.form-control {
  min-height: 170px;
  resize: vertical;
}

.contact-section .form-control::placeholder {
  color: #7f8c91;
}

.contact-section .form-control:focus {
  background-color: rgba(255,255,255,0.06);
  border-color: rgba(91,126,219,0.8);
  color: #fff;
  box-shadow: 0 0 0 0.22rem rgba(41, 82, 204, 0.18);
}

/* Bootstrap validace na tmavém pozadí */
.contact-section .form-control.is-invalid,
.contact-section .was-validated .form-control:invalid {
  border-color: #dc3545;
  background-image: none;
}

.contact-section .form-control.is-valid,
.contact-section .was-validated .form-control:valid {
  border-color: #198754;
  background-image: none;
}

.contact-section .invalid-feedback {
  color: #ff9ca6;
  font-size: 0.92rem;
}

.form-required-note {
  color: #96a4a9;
  font-size: 0.92rem;
}

/* Button */
.btn-contact {
  background: linear-gradient(135deg, #1f3c88 0%, #2952cc 100%);
  color: #fff;
  border: none;
  border-radius: 999px;
  padding: 0.9rem 1.5rem;
  font-weight: 600;
  letter-spacing: 0.01em;
  box-shadow: 0 10px 28px rgba(31, 60, 136, 0.28);
  transition: transform 0.2s ease, box-shadow 0.2s ease, opacity 0.2s ease;
}

.btn-contact:hover,
.btn-contact:focus {
  color: #fff;
  transform: translateY(-1px);
  box-shadow: 0 14px 30px rgba(31, 60, 136, 0.34);
}

.btn-contact:active {
  transform: translateY(0);
}

/* Responsive */
@media (max-width: 767.98px) {
  .contact-card {
    padding: 1.4rem;
    border-radius: 1rem;
  }

  .contact-title {
    font-size: 1.9rem;
  }
}


/* =====================================================
   UNIFIED REVEAL SYSTEM
===================================================== */

.js-reveal,
.tl-reveal {
  opacity: 0;
  transform: translate3d(0, 22px, 0);
  transition:
    opacity 720ms cubic-bezier(.22,.61,.36,1),
    transform 720ms cubic-bezier(.22,.61,.36,1);
  transition-delay: calc(var(--stagger, 0) * 90ms);
  will-change: opacity, transform;
}

.js-reveal.is-visible,
.tl-reveal.is-visible {
  opacity: 1;
  transform: translate3d(0, 0, 0);
}

.js-reveal.reveal-soft {
  transform: translate3d(0, 14px, 0);
  transition-duration: 620ms;
}

.tl-reveal::before {
  transform: scaleY(0);
  transform-origin: top center;
  transition: transform 900ms ease 140ms;
}

.tl-reveal .timeline-content::before {
  transform: scaleX(0);
  transform-origin: left center;
  transition: transform 700ms ease 260ms;
}

.tl-reveal .timeline-number {
  transform: scale(0.88);
  transition: transform 650ms cubic-bezier(.2,.9,.2,1) 180ms;
}

.tl-reveal.is-visible::before {
  transform: scaleY(1);
}

.tl-reveal.is-visible .timeline-content::before {
  transform: scaleX(1);
}

.tl-reveal.is-visible .timeline-number {
  transform: scale(1);
}

.no-js .js-reveal,
.no-js .tl-reveal {
  opacity: 1;
  transform: none;
}

@media (prefers-reduced-motion: reduce) {
  .js-reveal,
  .tl-reveal,
  .tl-reveal::before,
  .tl-reveal .timeline-content::before,
  .tl-reveal .timeline-number {
    opacity: 1 !important;
    transform: none !important;
    transition: none !important;
  }
}


/* =====================================================
   UNIFIED CARD HOVER SYSTEM
   - Pro koho jsou moje weby
   - Co umím vytvořit
   - Proč si vybrat mě
===================================================== */

:root{
  --card-hover-lift: translate3d(0, -8px, 0);
  --card-hover-shadow: 0 18px 42px rgba(17, 24, 39, 0.10);
  --card-base-shadow: 0 8px 24px rgba(17, 24, 39, 0.06);
  --card-hover-border: rgba(31, 60, 136, 0.14);
  --card-transition:
    transform 320ms cubic-bezier(.22,.61,.36,1),
    box-shadow 320ms cubic-bezier(.22,.61,.36,1),
    border-color 320ms cubic-bezier(.22,.61,.36,1),
    background-color 320ms ease;
}

/* společný základ */
.card-hover,
.service-card,
.benefit-card {
  transition: var(--card-transition);
  box-shadow: var(--card-base-shadow);
  backface-visibility: hidden;
  transform: translate3d(0, 0, 0);
  border-color: rgba(17, 24, 39, 0.06);
}

/* hover / focus */
.card-hover:hover,
.card-hover:focus-within,
.service-card:hover,
.service-card:focus-within,
.benefit-card:hover,
.benefit-card:focus-within {
  transform: var(--card-hover-lift);
  box-shadow: var(--card-hover-shadow);
  border-color: var(--card-hover-border);
}

/* jemné zvýraznění vnitřních ikon */
.card-hover .rounded-circle,
.service-card i,
.benefit-card .icon-bubble {
  transition:
    transform 320ms cubic-bezier(.22,.61,.36,1),
    color 320ms ease,
    background-color 320ms ease,
    box-shadow 320ms ease;
}

.card-hover:hover .rounded-circle,
.card-hover:focus-within .rounded-circle {
  transform: translate3d(0, -2px, 0) scale(1.03);
  box-shadow: 0 10px 22px rgba(31, 60, 136, 0.10);
}

.service-card:hover i,
.service-card:focus-within i {
  transform: translate3d(0, -2px, 0) scale(1.04);
}

.benefit-card:hover .icon-bubble,
.benefit-card:focus-within .icon-bubble {
  transform: translate3d(0, -2px, 0) scale(1.04);
}

/* jemné zvýraznění pozadí u benefit cards */
.benefit-card:hover,
.benefit-card:focus-within {
  background: linear-gradient(180deg, #ffffff 0%, #fbfcff 100%);
}

/* jemné zvýraznění service cards */
.service-card:hover,
.service-card:focus-within {
  background: linear-gradient(180deg, #ffffff 0%, #fcfdff 100%);
}

/* pro touch zařízení / reduced motion */
@media (hover: none) and (pointer: coarse) {
  .card-hover:hover,
  .card-hover:focus-within,
  .service-card:hover,
  .service-card:focus-within,
  .benefit-card:hover,
  .benefit-card:focus-within {
    transform: none;
    box-shadow: var(--card-base-shadow);
  }

  .card-hover:hover .rounded-circle,
  .service-card:hover i,
  .benefit-card:hover .icon-bubble {
    transform: none;
    box-shadow: none;
  }
}

@media (prefers-reduced-motion: reduce) {
  .card-hover,
  .service-card,
  .benefit-card,
  .card-hover .rounded-circle,
  .service-card i,
  .benefit-card .icon-bubble {
    transition: none !important;
    transform: none !important;
  }
}


/* =====================================================
   UNIFIED BUTTON SYSTEM
===================================================== */

:root{
  --brand-primary: #1f3c88;
  --brand-primary-2: #2952cc;
  --brand-dark: #1d2324;
  --brand-light: #f4f6f7;
  --brand-text-soft: #c7cdcf;
  --jdx-gold: #c6a46a;
  --jdx-gold-dark: #af8c51;

  --btn-radius: 14px;
  --btn-pad-y: 0.95rem;
  --btn-pad-x: 1.35rem;
  --btn-shadow: 0 8px 22px rgba(31, 60, 136, 0.16);
  --btn-shadow-hover: 0 14px 28px rgba(31, 60, 136, 0.22);
  --btn-transition:
    transform 260ms cubic-bezier(.22,.61,.36,1),
    box-shadow 260ms cubic-bezier(.22,.61,.36,1),
    background-color 260ms ease,
    border-color 260ms ease,
    color 260ms ease;
}

/* společný základ */
.btn-hero-primary,
.btn-hero-outline,
.btn-price-primary,
.btn-price-outline,
.btn-contact {
  border-radius: var(--btn-radius);
  padding: var(--btn-pad-y) var(--btn-pad-x);
  font-weight: 600;
  letter-spacing: 0.01em;
  transition: var(--btn-transition);
  transform: translate3d(0, 0, 0);
}

/* primary */
.btn-hero-primary,
.btn-price-primary,
.btn-contact {
  background: linear-gradient(135deg, var(--jdx-gold) 0%, var(--jdx-gold-dark) 100%);
  border: 1px solid transparent;
  color: #fff;
  box-shadow: var(--btn-shadow);
}

.btn-hero-primary:hover,
.btn-hero-primary:focus,
.btn-price-primary:hover,
.btn-price-primary:focus,
.btn-contact:hover,
.btn-contact:focus {
  background: linear-gradient(135deg, var(--jdx-gold-dark) 0%, var(--jdx-gold) 100%);
  color: #fff;
  transform: translate3d(0, -2px, 0);
  box-shadow: var(--btn-shadow-hover);
}

/* outline on dark / hero */
.btn-hero-outline {
  background: rgba(255,255,255,0.06);
  border: 1px solid rgba(255,255,255,0.26);
  color: #f8f9fa;
  backdrop-filter: blur(6px);
}

.btn-hero-outline:hover,
.btn-hero-outline:focus {
  background: rgba(255,255,255,0.12);
  border-color: rgba(255,255,255,0.44);
  color: #fff;
  transform: translate3d(0, -2px, 0);
  box-shadow: 0 12px 26px rgba(0,0,0,0.16);
}

/* outline on light */
.btn-price-outline {
  background: #fff;
  border: 1px solid rgba(31, 60, 136, 0.22);
  color: var(--brand-primary);
}

.btn-price-outline:hover,
.btn-price-outline:focus {
  background: #f8faff;
  border-color: rgba(31, 60, 136, 0.38);
  color: var(--brand-primary);
  transform: translate3d(0, -2px, 0);
  box-shadow: 0 12px 24px rgba(31, 60, 136, 0.12);
}

/* focus accessibility */
.btn-hero-primary:focus-visible,
.btn-hero-outline:focus-visible,
.btn-price-primary:focus-visible,
.btn-price-outline:focus-visible,
.btn-contact:focus-visible {
  outline: none;
  box-shadow:
    0 0 0 0.22rem rgba(41, 82, 204, 0.20),
    0 12px 24px rgba(31, 60, 136, 0.16);
}

@media (prefers-reduced-motion: reduce) {
  .btn-hero-primary,
  .btn-hero-outline,
  .btn-price-primary,
  .btn-price-outline,
  .btn-contact {
    transition: none !important;
    transform: none !important;
  }
}


/* =====================================================
   HERO SUBTITLE — NOIR TYPEWRITER
===================================================== */

.noir-subtitle{
  display: inline-flex;
  flex-wrap: wrap;
  align-items: center;
  gap: .35rem;
  font-size: clamp(1rem, 1.2vw, 1.2rem);
  line-height: 1.4;
  letter-spacing: .08em;
  text-transform: uppercase;
  color: rgba(255,255,255,.88);
  opacity: 0;
  transform: translateY(10px);
  filter: blur(2px);
  text-shadow:
    0 1px 0 rgba(255,255,255,.03),
    0 2px 12px rgba(0,0,0,.30),
    0 0 18px rgba(0,0,0,.12);
  will-change: opacity, transform, filter;
}

.noir-subtitle .subtitle-static{
  white-space: nowrap;
}

.noir-subtitle .subtitle-dynamic-wrap{
  display: inline-flex;
  align-items: center;
  white-space: nowrap;
  min-width: 12ch; /* můžeš upravit podle nejdelší varianty */
}

.noir-subtitle .subtitle-dynamic{
  display: inline-block;
  min-height: 1em;
}

.noir-subtitle .subtitle-cursor{
  display: inline-block;
  width: 1px;
  height: 1.05em;
  margin-left: .14rem;
  background: currentColor;
  opacity: 0;
  box-shadow: 0 0 8px rgba(255,255,255,.22);
}

.noir-subtitle.is-animating{
  animation: noirSubtitleReveal 1.1s ease-out forwards;
}

.noir-subtitle.is-typing .subtitle-cursor,
.noir-subtitle.is-done .subtitle-cursor{
  animation: noirCursorBlink .95s steps(1, end) infinite;
}

.noir-subtitle.is-done .subtitle-cursor{
  animation-iteration-count: 4;
}

@keyframes noirSubtitleReveal{
  0%{
    opacity: 0;
    transform: translateY(10px);
    filter: blur(2px);
  }
  60%{
    opacity: .82;
    transform: translateY(0);
    filter: blur(.5px);
  }
  100%{
    opacity: 1;
    transform: translateY(0);
    filter: blur(0);
  }
}

@keyframes noirCursorBlink{
  0%, 49%{ opacity: 1; }
  50%, 100%{ opacity: 0; }
}

@media (prefers-reduced-motion: reduce){
  .noir-subtitle{
    opacity: 1;
    transform: none;
    filter: none;
    animation: none !important;
  }

  .noir-subtitle .subtitle-cursor{
    display: none;
    animation: none !important;
  }
}

.hero-title{
  background: linear-gradient(
    180deg,
    #ffffff 0%,
    #f1f1f1 100%
  );
  -webkit-background-clip:text;
  -webkit-text-fill-color:transparent;
}

a.btn-price-primary,  a.btn-price-primary:hover, a.btn-hero-primary, a.btn-hero-primary:hover {
color: #fff !important;
}


.form-success-message {
  display: flex;
  align-items: flex-start;
  gap: 1rem;
  margin-bottom: 1.5rem;
  padding: 1rem 1.1rem;
  border-radius: 1rem;
  background: rgba(25, 135, 84, 0.12);
  border: 1px solid rgba(25, 135, 84, 0.35);
  color: #dff5e8;
  animation: successFadeUp 0.45s ease;
}

.form-success-icon {
  width: 42px;
  height: 42px;
  flex: 0 0 42px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  border-radius: 50%;
  background: rgba(25, 135, 84, 0.18);
  color: #7ee2a8;
  font-size: 1rem;
}

.form-success-text {
  color: #b9dcca;
  margin-top: 0.2rem;
  line-height: 1.55;
}

@keyframes successFadeUp {
  from {
    opacity: 0;
    transform: translateY(10px);
  }
  to {
    opacity: 1;
    transform: translateY(0);
  }
}
.hero-bg-carousel{
  position: relative;
  overflow: hidden;
}

.hero-slide{
  position: absolute;
  inset: 0;
  opacity: 0;
  visibility: hidden;
  transition: opacity .55s ease, visibility .55s ease;
  background-size: cover;
  background-position: center;
  --hero-accent: rgba(41,82,204,.16);
}

.hero-slide.is-active{
  opacity: 1;
  visibility: visible;
  z-index: 2;
}

.hero-overlay{
  position: absolute;
  inset: 0;
 /* background:
    linear-gradient(90deg, rgba(11,16,20,.82) 0%, rgba(11,16,20,.68) 38%, rgba(11,16,20,.42) 100%),
    radial-gradient(circle at 85% 20%, var(--hero-accent), transparent 32%); */
  z-index: 1;
}

.hero-container,
.hero-left,
.hero-text{
  position: relative;
  z-index: 3;
}

/* jemný světelný akcent */
.hero-bg-carousel::after{
  content: "";
  position: absolute;
  right: -70px;
  top: 70px;
  width: 180px;
  height: 180px;
  border-radius: 50%;
  background: radial-gradient(circle, rgba(56,102,255,.16) 0%, rgba(56,102,255,0) 70%);
  filter: blur(10px);
  pointer-events: none;
  z-index: 1;
}

/* MOBILE UI - nově už není absolutně dole */
.hero-mobile-ui{
  display: none;
  margin-top: 28px;
}

.hero-mobile-counter{
  display: inline-flex;
  align-items: center;
  gap: 8px;
  padding: 8px 12px;
  margin-bottom: 10px;
  border: 1px solid rgba(255,255,255,.12);
  border-radius: 10px;
  background: rgba(255,255,255,.05);
  backdrop-filter: blur(6px);
  -webkit-backdrop-filter: blur(6px);
  color: #eef1f2;
  font-weight: 600;
  letter-spacing: .08em;
  font-size: .75rem;
}

.hero-separator{
  opacity: .55;
}

.hero-mobile-progress{
  width: 100%;
  height: 3px;
  border-radius: 999px;
  background: rgba(255,255,255,.12);
  overflow: hidden;
}

.hero-mobile-progress-bar{
  display: block;
  height: 100%;
  width: 50%;
  border-radius: 999px;
  background: linear-gradient(90deg, #8fb0ff 0%, #2952cc 100%);
  transition: width .35s ease, transform .35s ease;
}

/* text */
.hero-title{
  line-height: .96;
}

.hero-perex{
  max-width: 34rem;
}

/* dots */
.hero-dots{
  position: absolute;
  left: 50%;
  transform: translateX(-50%);
  bottom: 28px;
  z-index: 6;
  display: flex;
  gap: 10px;
}

.hero-dot{
  width: 10px;
  height: 10px;
  border: 0;
  border-radius: 50%;
  background: rgba(255,255,255,.28);
  transition: transform .25s ease, background .25s ease, box-shadow .25s ease;
}

.hero-dot.is-active{
  background: #fff;
  transform: scale(1.15);
  box-shadow: 0 0 0 6px rgba(255,255,255,.08);
}

/* šipky desktop */
.hero-nav{
  position: absolute;
  top: 50%;
  transform: translateY(-50%);
  z-index: 6;
  width: 52px;
  height: 52px;
  border-radius: 50%;
  border: 1px solid rgba(255,255,255,.14);
  background: rgba(255,255,255,.08);
  color: #fff;
  font-size: 2rem;
  line-height: 1;
  display: flex;
  align-items: center;
  justify-content: center;
  backdrop-filter: blur(8px);
  -webkit-backdrop-filter: blur(8px);
}

.hero-prev{ left: 22px; }
.hero-next{ right: 22px; }

.hero-nav:hover{
  background: rgba(255,255,255,.14);
}

/* MOBILE */
@media (max-width: 991.98px){
  .hero-bg-carousel{
    min-height: 100svh;
  }

  .hero-slide{
    background-position: 62% center;
  }

  .hero-container{
    min-height: 100svh;
    display: flex;
    align-items: flex-start;
    padding-top: 110px;
    padding-bottom: 88px;
  }

  .hero-left{
    width: 100%;
  }

  .hero-text{
    max-width: 100%;
    padding-right: 4px;
  }

  .hero-kicker{
    font-size: .78rem;
    letter-spacing: .14em;
  }

  .hero-title{
    font-size: clamp(2.5rem, 9vw, 4rem);
    margin-bottom: 18px;
  }

  .hero-perex{
    font-size: 1.06rem;
    line-height: 1.72;
    color: rgba(255,255,255,.84);
  }

  .hero-buttons{
    flex-direction: column;
    align-items: stretch;
  }

  .hero-buttons .btn{
    width: 100%;
    min-height: 60px;
    border-radius: 16px;
    font-weight: 700;
    font-size: 1.05rem;
  }

  .hero-mobile-ui{
    display: block;
  }

  .hero-nav{
    display: none;
  }
}

/* MENŠÍ MOBILY */
@media (max-width: 575.98px){
  .hero-container{
    padding-top: 96px;
    padding-bottom: 82px;
  }

  .hero-subtitle{
    margin-bottom: 12px;
  }

  .hero-kicker{
    margin-bottom: 18px;
  }

  .hero-title{
    font-size: clamp(2.25rem, 11vw, 3.5rem);
  }

  .hero-perex{
    font-size: 1.02rem;
    line-height: 1.68;
  }

  .hero-mobile-ui{
    margin-top: 24px;
  }

  .hero-dots{
    bottom: 22px;
  }
}

.hero-bg-carousel{
  touch-action: pan-y;
}


/* subtle moving light */

.hero-bg-carousel::before{
  content:"";
  position:absolute;
  inset:-20%;
  z-index:2;
  pointer-events:none;

  background:
    linear-gradient(
      120deg,
      rgba(255,255,255,0) 40%,
      rgba(255,255,255,0.05) 50%,
      rgba(255,255,255,0) 60%
    );

  transform:translateX(-40%);
  animation:heroLightMove 14s linear infinite;
}

@keyframes heroLightMove{
  from{
    transform:translateX(-40%);
  }
  to{
    transform:translateX(40%);
  }
}

.hero-slide{
  transition:
    opacity .55s ease,
    visibility .55s ease,
    transform .9s ease;
}

.hero-slide.is-active{
  transform:scale(1.02);
}

.hero-scroll-hint{
  margin-top:28px;
  font-size:1.4rem;
  color:rgba(255,255,255,.45);
  text-align:center;
  animation:heroScrollHint 1.8s ease-in-out infinite;
}

.hero-scroll-hint i{
  display:inline-block;
}

@keyframes heroScrollHint{

  0%{
    transform:translateY(0);
    opacity:.5;
  }

  50%{
    transform:translateY(8px);
    opacity:.9;
  }

  100%{
    transform:translateY(0);
    opacity:.5;
  }

}

@media (min-width:992px){

.hero-scroll-hint{
display:none;
}

}



.hero-accent{

  background: linear-gradient(
    90deg,
    #ffffff 0%,
    #d9dde2 45%,
    #b8c0c7 100%
  );

  -webkit-background-clip:text;
  -webkit-text-fill-color:transparent;
  background-clip:text;
  color:transparent;

}




.hero-accent{
text-shadow:
0 0 12px rgba(90,130,255,.25);
}

.hero-title{
font-weight:700;
letter-spacing:-0.02em;
}

h1.hidden {
display: none !important;
}


.case-more-projects {
  border-top: 1px solid rgba(29, 35, 36, 0.06);
}

.case-more-projects-lead {
  color: #5f6b6d;
  max-width: 760px;
}

.case-ref-card {
  position: relative;
  display: flex;
  flex-direction: column;
  gap: 14px;
  height: 100%;
  padding: 24px 22px;
  border-radius: 20px;
  background: #fff;
  border: 1px solid rgba(29, 35, 36, 0.08);
  box-shadow: 0 10px 30px rgba(17, 24, 39, 0.05);
  text-decoration: none;
  transition: transform .28s ease, box-shadow .28s ease, border-color .28s ease;
  overflow: hidden;
}

.case-ref-card::before {
  content: "";
  position: absolute;
  inset: 0 auto 0 0;
  width: 4px;
  background: linear-gradient(180deg, #2952cc 0%, #6f8cff 100%);
  opacity: .95;
}

.case-ref-card:hover {
  transform: translateY(-6px);
  box-shadow: 0 18px 40px rgba(17, 24, 39, 0.10);
  border-color: rgba(41, 82, 204, 0.18);
  text-decoration: none;
}

.case-ref-card-top {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
}

.case-ref-index {
  font-size: .82rem;
  font-weight: 700;
  letter-spacing: .08em;
  text-transform: uppercase;
  color: #8a9597;
}

.case-ref-icon {
  width: 38px;
  height: 38px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  border-radius: 999px;
  background: #f4f6f7;
  color: #1d2324;
  transition: transform .28s ease, background .28s ease, color .28s ease;
}

.case-ref-card:hover .case-ref-icon {
  transform: translate(2px, -2px);
  background: #2952cc;
  color: #fff;
}

.case-ref-title {
  margin: 0;
  font-size: 1.1rem;
  line-height: 1.35;
  color: #1d2324;
}

.case-ref-text {
  margin: 0;
  color: #5f6b6d;
  line-height: 1.65;
  font-size: .96rem;
}

.case-ref-link {
  margin-top: auto;
  font-weight: 600;
  color: #2952cc;
  font-size: .95rem;
}

@media (max-width: 767.98px) {
  .case-ref-card {
    padding: 20px 18px;
    border-radius: 18px;
  }
}

p.section-lead {
  max-width: 820px;
  margin: 0 auto 2.5rem;
  text-align: center;
  font-size: 1.14rem;
  line-height: 1.8;
  color: #5f6b6d;
	}


.hero-scroll-contact {
  display: flex;
  flex-direction: column;
  align-items: center;
  margin-top: 26px;
  gap: 10px;
}

.hero-contact-inline {
  display: flex;
  align-items: center;
  gap: 14px;
  font-size: 0.92rem;
  line-height: 1.4;
  opacity: 0.78;
  transition: opacity .25s ease;
}

.hero-contact-inline:hover {
  opacity: 1;
}

.hero-contact-link {
  color: #c7cdcf;
  text-decoration: none;
  display: inline-flex;
  align-items: center;
  gap: 7px;
  transition: color .25s ease, transform .25s ease, opacity .25s ease;
}

.hero-contact-link:hover {
  color: #ffffff;
  transform: translateY(-1px);
  text-decoration: none;
}

.hero-contact-link i {
  font-size: 0.86rem;
  opacity: 0.85;
}

.hero-contact-sep {
  opacity: 0.38;
}

@media (max-width: 767.98px) {
  .hero-scroll-contact {
    margin-top: 22px;
    gap: 8px;
  }

  .hero-contact-inline {
    flex-direction: column;
    gap: 6px;
    font-size: 0.86rem;
  }

  .hero-contact-sep {
    display: none;
  }
}

a.contact-info-item:hover {
text-decoration: none;
}

.contact-info-item .contact-info-icon i {
  color: inherit !important;
  opacity: 1 !important;
}

.about-section {
  padding: 80px 0;
}

.about-card {
  padding: 30px;
  border-radius: 14px;
  background: #f8f9fb;
  transition: all 0.3s ease;
  text-align: left;
}

.about-card h3 {
  font-size: 1.1rem;
  margin-bottom: 10px;
}

.about-card p {
  font-size: 0.95rem;
  color: #6c757d;
}

.about-card:hover {
  transform: translateY(-6px);
  box-shadow: 0 12px 30px rgba(0,0,0,0.06);
}

.about-text {
  font-size: 1rem;
  color: #555;
}

.hero-title-carousel {
  font-size: var(--fs-800);
   line-height: 1.3;
	font-weight: 700;
    letter-spacing: -0.02em;
  background: linear-gradient(
    135deg,
    #e2c48a 0%,
    #c6a46a 40%,
    #af8c51 100%
  );
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
	 padding-bottom: 0.1em;
 margin-bottom:.10em
}

div.badge.bg-primary {
background-color: #c6a46a !important;
}