@charset "UTF-8";

:root {
	--dark: #212529;
	--light-d10: #dae0e7;
	--light-d20: #bbc6d3;
	--primary-light: #cce4ff;
	--primary-light-l5: #e5f1ff;
	--primary-light-d10: #99c9ff;
	--primary-light-d30: #3393ff;
	--primary-light-d10-t50: #99c9ff80;
	--primary: #3f7bb5;
	--primary-l10: #6095c8;
	--primary-l20: #86aed5;
	--primary-l30: #acc7e2;
	--primary-d10: #326290;
	--primary-d10-t50: #32629080;
	--on-primary: #fff;
	--light-active: #e2e6ea;
	--blue-dark: #044891;
	--terracotta: #F05F40;
	--terracotta-l10: #f48871;
	--terracotta-l20: #f8b0a0;
	--eggplant: #36354b;
	--marked: #faedcf;
	--gold: #d0b981;
}

body, html {
	width: 100%;
	height: 100%;
}

body {
	font-family: 'Helvetica Neue', Arial, sans-serif;
	font-size: 115%;
}

hr {
	max-width: 50px;
	border-width: 3px;
	border-color: var(--terracotta);
}
hr.light {
	border-color: #fff;
}

hr.split {
	max-width: none;
	border-width: 3px;
	border-color: #dee2e6;
}

a {
	color: var(--primary);
	-webkit-transition: all 0.2s;
	-moz-transition: all 0.2s;
	transition: all 0.2s;
}
a:hover {
	color: #136ec5;
}

h1, h2, h3, h4, h5, h6 {
	font-family: 'Open Sans', 'Helvetica Neue', Arial, sans-serif;
	margin-bottom: 1rem;
}

figure.bordered {
	/* border: 2px solid #e1e1e1; */
	margin: 1rem auto;
	display: table;
	text-align: center;
	max-width: 100%;
}
figure.bordered > img {
	margin: 5px;
	max-width: 100%;
}
figure.bordered > figcaption {
	text-align: center;
	/* background: #e1e1e1; */
	padding: 2px 15px;
	}

.bg-primary {
	background-color: var(--terracotta) !important;
}

.bg-gold {
	background-color: var(--gold) !important;
}

.bg-light-20 {
	background-color: rgba(255, 255, 255, .2)!important;
}
.bg-light-50 {
	background-color: rgba(255, 255, 255, .5)!important;
}
.bg-light-80 {
	background-color: rgba(255, 255, 255, .8)!important;
}

.bg-dark {
	background-color: #212529 !important;
}

.bg-dark-20 {
	background-color: rgba(33, 37, 41, .2)!important;
}
.bg-dark-50 {
	background-color: rgba(33, 37, 41, .5)!important;
}

.text-black-30 {
	color: rgba(0, 0, 0, .3)!important;
}
.text-black-25 {
	color: rgba(0, 0, 0, .25)!important;
}

.text-blue {
	color: var(--blue) !important;
}
.text-blue-dark {
    color: var(--blue-dark) !important;
}
.text-purple {
	color: var(--purple) !important;
}
.text-light-d10 {
	color: var(--light-d10) !important;
}

.bg-eggplant {
	background-color: var(--eggplant) !important;
}
.bg-purple {
	background-color: var(--purple) !important;
}
.bg-blue {
	background-color: var(--blue) !important;
}
.bg-blue-30 {
	background-color: rgb(63, 123, 181, .3) !important;
}

.bg-marked {
	background-color: var(--marked) !important;
}

@media (min-width: 1720px) {
	.d-xxl-block {
		display: block!important;
	}
}

.text-faded {
	color: rgba(255, 255, 255, .7);
}

.top-offset {
	padding-top: 5rem;
}

.height-nofooter {
	min-height: 100vh;
}

section {
	padding: 5rem 0;
}

section#main {}

section#contact {
	padding: 0 0 2rem 0;
	color: var(--light-d10);
}

.section-heading {
	margin-top: 0;
}

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

img::selection, img::-moz-selection {
	color: #fff;
	background: transparent;
}

label {
	margin-bottom: 7px;
	font-family: 'Open Sans', 'Helvetica Neue', Arial, sans-serif;
}

[data-toggle=buttons]>.btn>input[type=radio], [data-toggle=buttons]>.btn>input[type=checkbox] {
    display: none;
}

.radio, .checkbox {
    display: block;
    min-height: 20px;
    margin-top: 10px;
    margin-bottom: 10px;
    padding-left: 20px;
}

.radio input[type=radio], .radio-inline input[type=radio], .checkbox input[type=checkbox], .checkbox-inline input[type=checkbox] {
    margin-left: -20px;
}

.fixed-top {
	z-index: 99;
}

#mainNav .navbar-nav > li.nav-item > a.nav-link.active,
#mainNav .navbar-nav > li.nav-item > a.nav-link:focus.active {
	color: var(--terracotta) !important;
	background-color: transparent;
}

#mainNav .navbar-nav > li.nav-item > a.nav-link.active:hover,
#mainNav .navbar-nav > li.nav-item > a.nav-link:focus.active:hover {
	background-color: transparent;
}

#mainNav {
	border-color: transparent;
	background-color: #212529;
	box-shadow: 0 0 10px rgba(0,0,0,0.5);
	border-bottom: 1px solid rgba(33, 37, 41, 0.1);
	font-family: 'Open Sans', 'Helvetica Neue', Arial, sans-serif;
	-webkit-transition: all 0.2s;
	-moz-transition: all 0.2s;
	transition: all 0.2s;
}

#mainNav .navbar-brand {
	color: var(--terracotta);
	font-weight: 700;
	font-style: normal;
	font-family: 'Helvetica Neue', 'Merriweather', times;
}
#mainNav .navbar-brand:focus, #mainNav .navbar-brand:hover {
	color: var(--terracotta-l10);
}

#mainNav .navbar-brand-sab {
	color: var(--light-d10);
	transition: all 0.2s;
}
#mainNav .navbar-brand:focus .navbar-brand-sab, #mainNav .navbar-brand:hover .navbar-brand-sab {
	color: white;
}

#mainNav .navbar-nav > li.nav-item > a.nav-link {
	padding: 0.5rem 1rem;
}
#mainNav .navbar-nav > li.nav-item > a.nav-link,
#mainNav .navbar-nav > li.nav-item > a.nav-link:focus {
	color: rgba(255, 255, 255, 0.7);
	font-size: .9rem;
	font-weight: 700;
}
#mainNav .navbar-nav > li.nav-item > a.nav-link:hover,
#mainNav .navbar-nav > li.nav-item > a.nav-link:focus:hover {
	color: var(--terracotta);
}

#mainNav.navbar-shrink {}
#mainNav.navbar-shrink .navbar-brand {}
#mainNav.navbar-shrink .navbar-brand:focus, #mainNav.navbar-shrink .navbar-brand:hover {}
#mainNav.navbar-shrink .navbar-nav > li.nav-item > a.nav-link,
#mainNav.navbar-shrink .navbar-nav > li.nav-item > a.nav-link:focus {}
#mainNav.navbar-shrink .navbar-nav > li.nav-item > a.nav-link:hover,
#mainNav.navbar-shrink .navbar-nav > li.nav-item > a.nav-link:focus:hover {}

.navbar-nav .dropdown-menu {
    position: absolute;
}

header {
	padding-top: 90px;
	padding-bottom: calc(10rem - 120px);
	background-color: #322f41;
	background-image: url("../img/header3.jpg");
	background-position: center center;
	-webkit-background-size: cover;
	-moz-background-size: cover;
	background-size: cover;
}

header.masthead hr {
	margin-top: 20px;
	margin-bottom: 20px;
}

header.masthead h1 {
	font-size: 26pt;
	text-shadow: black 2px 2px 10px;
}

header.masthead p {
	font-weight: 300;
}

@media (min-width: 768px) {
	header.masthead p {
		font-size: 1.15rem;
	}
}

@media (min-width: 992px) {
	header.masthead {
		padding-top: 50px;
		padding-bottom: 0;
	}
	header.masthead h1 {
		font-size: 26pt;
	}
}

@media (min-width: 1100px) {
	header.masthead {
		min-height: 100vh;
		padding-top: 90px;
		padding-bottom: 0;
	}
	header.masthead h1 {
		font-size: 26pt;
	}
}

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

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

@media (min-width: 992px) {
.container {
    width: 960px;
}
}

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

.service-box {
	max-width: 400px;
}

.portfolio-box {
	position: relative;
	display: block;
	max-width: 650px;
	margin: 0 auto;
}

.portfolio-box .portfolio-box-caption {
	position: absolute;
	bottom: 0;
	display: block;
	width: 100%;
	height: 100%;
	text-align: center;
	opacity: 0;
	color: #fff;
	background: rgba(240, 95, 64, 0.9);
	-webkit-transition: all 0.2s;
	-moz-transition: all 0.2s;
	transition: all 0.2s;
}

.portfolio-box .portfolio-box-caption .portfolio-box-caption-content {
	position: absolute;
	top: 50%;
	width: 100%;
	transform: translateY(-50%);
	text-align: center;
}

.portfolio-box .portfolio-box-caption .portfolio-box-caption-content .project-category,
.portfolio-box .portfolio-box-caption .portfolio-box-caption-content .project-name {
	padding: 0 15px;
	font-family: 'Open Sans', 'Helvetica Neue', Arial, sans-serif;
}

.portfolio-box .portfolio-box-caption .portfolio-box-caption-content .project-category {
	font-size: 14px;
	font-weight: 600;
	text-transform: uppercase;
}

.portfolio-box .portfolio-box-caption .portfolio-box-caption-content .project-name {
	font-size: 18px;
}

.portfolio-box:hover .portfolio-box-caption {
	opacity: 1;
}

.portfolio-box:focus {
	outline: none;
}

@media (min-width: 768px) {
  .portfolio-box .portfolio-box-caption .portfolio-box-caption-content .project-category {
    font-size: 16px;
  }
  .portfolio-box .portfolio-box-caption .portfolio-box-caption-content .project-name {
    font-size: 22px;
  }
}

.text-primary {
	color: var(--terracotta-l10) !important;
}
a.text-primary:focus, a.text-primary:hover {
    color: var(--terracotta)!important;
}

.border-primary {
	border-color: var(--terracotta-l10) !important;
}

.glow-primary {
	box-shadow: 0 0 0.35rem var(--terracotta);
}

header.masthead .news-preview a, .text-light-blue {
	color: #babad4 !important;	
}
header.masthead .news-preview p {
	font-size: 1rem;
}
a.text-light-blue:focus, a.text-light-blue:hover, .news-preview a:focus, .news-preview a:hover {
	color: #9696ad !important;
}

.text-shadow-sm {
	text-shadow: 1px 1px 1px rgba(0,0,0,.075)!important;
}

.menu-icon {
	float: left; 
	margin-right: 10px; 
	color: #f08140;
}

.btn {
	font-weight: 700;
	text-transform: uppercase;
	border: none;
	border-radius: 300px;
	font-family: 'Open Sans', 'Helvetica Neue', Arial, sans-serif;
	display: inline-block;
	text-align: center;
	white-space: nowrap;
	vertical-align: middle;
	-webkit-user-select: none;
	-moz-user-select: none;
	-ms-user-select: none;
	user-select: none;
	padding: .375rem .75rem;
	font-size: 1rem;
	line-height: 1.5;
	transition: color .15s ease-in-out,background-color .15s ease-in-out,border-color .15s ease-in-out,box-shadow .15s ease-in-out;
}

.btn-xl, .btn-lg {
	padding: 1rem 2rem;
}

.btn-m {
	padding: 0.5rem 1.5rem;
	border-radius: 5px;
}

.btn-sm {
	padding: 0.3rem 1.3rem;
	border-radius: 4px;
	text-transform: none;
}

.btn-xs {
	padding: 0.1rem 1rem;
	font-family: sans-serif;
	font-size: 11pt;
	font-weight: normal;
	border-radius: 3px;
	text-transform: none;
}

.btn-primary {
	background-color: var(--primary);
	border-color: var(--primary);
}

.btn-primary:hover, .btn-primary:focus, .btn-primary:active {
	color: #fff;
	background-color: #136ec5 !important;
}

.btn-primary:active, .btn-primary:focus {
	box-shadow: 0 0 0 0.2rem rgba(63, 123, 181, 0.5)!important;
}

.btn-blue {
	background-color: #50a7d6;
	border-color: #50a7d6;
	color: #fff !important;
}

.btn-blue:hover, .btn-blue:focus, .btn-blue:active {
	color: #fff;
	background-color: #2c89bc !important;
}

.page-link {
    color: #6c757d;
	padding: 0.4rem 0.75rem;
}
.page-link:hover {
    color: var(--primary-light-d30);
}
.page-item.active .page-link {
    background-color: var(--primary-light-l5);
	border-color: var(--primary-l10);
	color: black;
}
.page-link:focus {
    box-shadow: none;
}

.breadcrumb {
	background: none;
	margin: 0;
	padding: 0;
}
.breadcrumb-item::before {
    display: inline-block;
    padding-right: .5rem;
    color: #6c757d;
	font-weight: bold;
    content: "/";
}

.form-group.required .control-label:after { 
   content:"*";
   color:gray;
}

.bs-callout {
	margin: 20px 0; 
	padding: 20px; 
	border-left: 3px solid #cacaca;
	background-color: #f9f9f9;
}
.bs-callout > p:last-child {
	margin-bottom: 0;
}
.bs-callout-info {
	border-left: 3px solid #5bc0de; 
	background-color: #f4f8fa;
}

.colorBox {
	float: left; 
	width: 12px; 
	height: 12px; 
	margin: 5px 5px 0 0;
}

.hidden {
	display: none;
}

.cursor-pointer{
	cursor: pointer;
}

.btn-group-label {
	display: block;
	float: left;
	font-size: 1rem;
	padding: 6px 12px;
}

.video-preview {
	display: flex;
    position: absolute;
    width: 100%;
    height: 100%;
    align-items: center;
    justify-content: center;
	background-color: rgba(80, 167, 214, 0);
	color: rgb(240, 129, 64, 0.8);
	transition: background-color ease-in-out 0.5s, color ease-in-out 0.5s;
}
.video-preview:hover {
	background-color: rgba(80, 167, 214, .5);
	color: rgb(255, 255, 255, 0.8);
}

.news-preview>p {
	margin-bottom: auto;
}

/* --- Bootstrap update --- */

.card-text {
	font-family: 'Open Sans', 'Helvetica Neue', Arial, sans-serif;
	font-weight: 400;
}

.card-title {
	font-weight: 600;
}

.card {
	border-radius: 0.5rem;
}

.card-hor-bg {
	background-size: cover;
    border-bottom-left-radius: 0.5rem;
    border-top-left-radius: 0.5rem;
}

.invalid-feedback {
	background-color: #c3372c;
    color: #eee;
    padding: 2px 10px;
    margin: 0 5px;
	border-bottom-right-radius: 10px;
	border-bottom-left-radius: 10px;
	width: calc(100% - 10px);
}

.table-ui {
	font-family: 'Open Sans', 'Helvetica Neue', Arial, sans-serif;
	font-size: .9rem;
	line-height: 1;
	background-color: white;
}

.table-ui td, .table-ui th {
    padding: .5rem;
}

.col-resizable {
	position: relative;
}
.col-resizer {
	width: 7px; 
	height: 100%; 
	top: 0px;
	right: 0px;
	position: absolute;
	cursor: col-resize;
}

/* -------- Modal --------- */

.modal-mask {
	position: fixed;
	z-index: 100;
	top: 0;
	left: 0;
	width: 100%;
	height: 100%;
	background-color: rgba(0, 0, 0, .5);
	display: table;
	transition: opacity .3s ease;
}

.modal-wrapper {
	display: table-cell;
	vertical-align: middle;
}

.modal-container {
	width: 350px;
	margin: 0px auto;
	/*padding: 10px 15px;
	background-color: #fff;
	border-radius: 2px;*/
	box-shadow: 0 2px 8px rgba(0, 0, 0, .33);
	transition: all .3s ease;
	font-family: Helvetica, Arial, sans-serif;
	border-width: 3px;
}

@media (min-width: 540px) {
	.modal-container {
		width: 400px;
	}
}

@media (min-width: 768px) {
	.modal-container {
		width: 600px;
	}
}

@media (min-width: 992px) {
	.modal-wide {
		width: 800px;
	}
}

.modal-header {
	padding: 1rem 1.8rem;
}

.modal-header h3 {
	margin: 0;
	white-space: nowrap;
	overflow: hidden;
	text-overflow: ellipsis;
}

.modal-header .close {
	margin-top: -13.5px;
}

.modal-body {
	/*margin: 10px 0;*/
	max-height: calc(100vh - 200px);
	overflow-y: auto;
}

.modal-footer {
	background: 10px 0;
}

.modal-default-button {
	float: right;
}

.vacation-btn {
	padding: .25rem .5rem;
	margin: 0;
	border-radius: 0;
	position: absolute; 
	right: -12px; 
	top: 0px;
	cursor:default;
}
.vacation-btn .info {
    overflow: hidden;
	display: none;
}
.vacation-btn:hover .info {
	display: inline;
}

/*
 * The following styles are auto-applied to elements with
 * transition="modal" when their visibility is toggled
 * by Vue.js.
 *
 * You can easily play with the modal transition by editing
 * these styles.
 */

.modal-enter {
	opacity: 0;
}

.modal-leave-active {
	opacity: 0;
}

.modal-enter .modal-container,
.modal-leave-active .modal-container {
	-webkit-transform: scale(1.1);
	transform: scale(1.1);
}

[v-cloak] { 
	display: none; 
}

/* Fade animation */

.fade-enter-active, .fade-leave-active {
  transition: opacity .5s;
}
.fade-enter, .fade-leave-to /* .fade-leave-active до версии 2.1.8 */ {
  opacity: 0;
}

/* Slide-fade animation */

.slide-fade-enter-active {
  transition: all .3s ease;
}
.slide-fade-leave-active {
  transition: all .8s cubic-bezier(1.0, 0.5, 0.8, 1.0);
}
.slide-fade-enter, .slide-fade-leave-to
/* .slide-fade-leave-active до версии 2.1.8 */ {
  transform: translateX(10px);
  opacity: 0;
}

/* List animation */

.list {
  transition: all 1s; display: inline-block;
}
/*.list-enter-active, .list-leave-active {
  transition: all .5s;
}*/
.list-enter, .list-leave-to /* .list-leave-active до версии 2.1.8 */ {
  opacity: 0;
  transform: translateY(30px);
}
.list-move {
  transition: transform 1s;
}
.list-leave-active {
  position: absolute;
}

/* dropdown menu animation */

@media (min-width: 992px) {
  .animate {
    animation-duration: 0.3s;
    -webkit-animation-duration: 0.3s;
    animation-fill-mode: both;
    -webkit-animation-fill-mode: both;
  }
}

@keyframes slideIn {
  0% {
    transform: translateY(1rem);
    opacity: 0;
  }
  100% {
    transform:translateY(0rem);
    opacity: 1;
  }
  0% {
    transform: translateY(1rem);
    opacity: 0;
  }
}

@-webkit-keyframes slideIn {
  0% {
    -webkit-transform: transform;
    -webkit-opacity: 0;
  }
  100% {
    -webkit-transform: translateY(0);
    -webkit-opacity: 1;
  }
  0% {
    -webkit-transform: translateY(1rem);
    -webkit-opacity: 0;
  }
}

.slideIn {
  -webkit-animation-name: slideIn;
  animation-name: slideIn;
}

.filter .card {
	border-radius: 0;
	background-color: rgba(0,0,0,.03);
}
.filter .card-header {
    padding: .5rem 0.7rem;
    margin-bottom: 0;
    border-radius: 0;
}
.filter .card-body {
    padding: .3rem;
}
.filter .form-group {
	margin: 5px 0 5px 0;
}

.sticky {
	position: fixed;
	top: 0;
	width: 100%
}