/*

INVISIO -n
Envision, in this instance meaning the way we see the website in general.

*/

/* #region TEMPLATE */
/* #endregion */


/* #region NAVIGATION */

    .navbar {
        background-color: rgb(217, 218, 229, 0.6);
        backdrop-filter: blur(8px);
        box-shadow: var(--bsl);
        width: 100vw;
        padding: 0px 30px;
        position: fixed;
        z-index: 9999;
        top: 0px;
        left: 0px;
    }

    .gin--horizontal-toolbar .navbar {
        top: 113px;
    }

    .navbar-brand {
        padding: 0px;
    }

    .navbar-brand img {
        height: 0px;
        margin: 0px;
        padding: 5px 0px;
        transition: var(--trb);
    }

    .region-nav-main {
        display: flex;
        flex-flow: row wrap;
        align-items: center;
        justify-content: end;
    }

    .menu--main .navbar-nav .nav-link,
    .menu--main-navigation-other-pages .navbar-nav .nav-link {
        padding: 25px 20px;
        color: var(--cpr-100);
        transition: var(--trb);
    }

    .menu--main .navbar-nav .nav-link.is-active,
    .menu--main-navigation-other-pages .navbar-nav .nav-link.is-active {
        background-color: var(--cpr-130);
        color: var(--csw-100);
    }

    .path-frontpage .menu--main .navbar-nav .nav-link.is-active,
    .path-frontpage .menu--main-navigation-other-pages .navbar-nav .nav-link.is-active {
        background-color: transparent;
        color: var(--cpr-100);
    }

    .menu--main .navbar-nav .nav-link:is(:hover, :focus, :active),
    .menu--main .navbar-nav .nav-link.is-active:is(:hover, :focus, :active),
    .menu--main-navigation-other-pages .navbar-nav .nav-link:is(:hover, :focus, :active),
    .menu--main-navigation-other-pages .navbar-nav .nav-link.is-active:is(:hover, :focus, :active) {
        color: var(--csw-100);
        background-color: var(--cpr-100);
    }

    .menu--main .navbar-nav > li > .dropdown-menu {
        padding: 0px;
        border-radius: 0px 0px 15px 15px;
        overflow: hidden;
    }

    .dropdown-menu > li > a {
        padding: 15px;
        transition: var(--trb);
    }

    .dropdown-menu > li > a:is(:hover, :focus, :active),
    .dropdown-menu > li.active > a, .dropdown-menu > li.active > a:is(:hover, :focus, :active) {
        background-color: var(--ch1-100);
        color: var(--csw-100);
    }

    .menu--main .navbar-nav > .open > a,
    .menu--main .navbar-nav > .open > a:is(:hover, :focus, :active) {
        background-color: var(--ch1-100);
        color: var(--csw-100);
    }

    .logo-other {
        transition: var(--trb);
    }

/* #endregion */


/* #region MOBILE MENU */

    .mobile-menu-button {
        background: none;
        border: none;
        display: flex;
        align-items: center;
        justify-content: center;
        cursor: pointer;
        padding: 0;
    }
    
    .mobile-menu-icon {
        display: flex;
        flex-direction: column;
        width: 30px;
    }
    
    .mobile-menu-icon span {
        display: block;
        background: var(--cpr-100);
        border-radius: 10px;
        height: 3px;
        width: 30px;
        margin: 2px 0;
        transition: 0.4s cubic-bezier(0.68, -0.6, 0.32, 1.6);
    }
    
    .mobile-menu-icon span:nth-of-type(1) {
        width: 50%;
    }
    
    .mobile-menu-icon span:nth-of-type(2) {
        width: 100%;
    }
    
    .mobile-menu-icon span:nth-of-type(3) {
        width: 75%;
    }
    
    /* Animation when the button is active */
    .mobile-menu-button .active .mobile-menu-icon span:nth-of-type(1) {
        transform-origin: bottom;
        transform: rotateZ(45deg) translate(2px, -1px);
    }
    
    .mobile-menu-button .active .mobile-menu-icon span:nth-of-type(2) {
        transform-origin: top;
        transform: rotateZ(-45deg);
    }
    
    .mobile-menu-button .active .mobile-menu-icon span:nth-of-type(3) {
        transform-origin: bottom;
        width: 50%;
        transform: translate(13px, -3px) rotateZ(45deg);
    }

    .mobile-menu-button a {
        display: flex;
        flex-flow: row nowrap;
        align-items: center;
        justify-content: center;
        gap: 10px;
        padding: 25px 30px;
        text-decoration: none;
        color: var(--cpr-100);
        transition: var(--trb);
    }

    .mobile-menu-button a.active {
        background-color: var(--cpr-145);
        color: var(--csw-100);
    }

    .mobile-menu-button a.active .mobile-menu-icon span {
        background: var(--csw-100);
    }

    .mobile-menu-button a:is(:hover) {
        background-color: var(--cpr-100);
        color: var(--csw-100);
    }

    .mobile-menu-button a:is(:hover) span {
        background-color: var(--csw-100);
    }

    .mobile-menu-text {
        font-size: var(--dfs);
        transition: transform 0.3s ease;
    }
    
    .mobile-menu-text.fade-out {
        transition: transform 0.3s ease, opacity 0.3s ease;
    }
    
    a.active .mobile-menu-text {
        transform: scale(0.9);
    }
  
/* #endregion */


/* #region SCROLLED STYLING */

    .scrolled .navbar-brand img {
        height: 75px;
    }

/* #endregion */


/* #region SIDR STYLING */

    #block-mmc {
        display: none;
    }

    body:before {
        content: "";
        display: block;
        width: 0vw;
        height: 100vh;
        background-color: var(--ctx-160);
        opacity: 0;
        z-index: 999;
        position: fixed;
        left: 0px;
        top: 0px;
        transition: 0.1s;
    }

    body.sidr-open:before {
        width: 100vw;
        opacity: 0.8;
    }

    .sidr-open .sidr {
        box-shadow: var(--cpr-015);
    }

    .navbar-toggle {
        display: none;
    }

    .sidr {
        position: fixed;
        top: 0px;
        height: 100vh;
        z-index: 999999;
        width: 400px;
        overflow-x: hidden;
        overflow-y: auto;
        background-color: var(--ctx-015);
    }

    .sidr.left {
        left: -400px;
        right: auto;
    }

    .sidr-class-field--label {
        display: none;
    }

    .sidr-class-bc_dark {
        background-color: var(--cpr-100);
        color: var(--csw-100);
        overflow: hidden;
        margin-bottom: 20px;
    }

    .sidr-class-mobile-logo {
        padding: 20px;
        display: flex;
        flex-flow: row wrap;
        align-items: center;
        justify-content: center;
    }

    .sidr-class-mobile-logo a {
        width: 70%;
    }

    .sidr-class-mobile-logo img {
        width: 50%;
    }

    .sidr-class-close {
        background-color: transparent;
        border: none;
        font-size: 0.7rem;
        color: var(--csw-100);
        padding: 20px;
        margin-left: 20px;
        border-left: 2px solid var(--csw-100);
        display: block;
    }

    #sidr-id-block-mainnavigation-menu,
    #sidr-id-block-mainnavigationotherpages-menu {
        display: none;
    }

    #sidr-id-block-mainnavigation,
    #sidr-id-block-mainnavigationotherpages {
        height: 81vh;
        overflow: scroll;
    }

    #sidr-id-block-mainnavigation,
    .path-frontpage #sidr-id-block-mainnavigationotherpages {
        display: none;
    }

    .path-frontpage #sidr-id-block-mainnavigation,
    #sidr-id-block-mainnavigationotherpages {
        display: block;
    }

    .sidr-class-navbar-nav {
        list-style-type: none;
        padding: 0px;
    }

    .sidr-class-nav-link {
        padding: 15px;
        color: var(--ctx-100);
        transition: var(--trb);
        display: inline-block;
        width: 100%;
        text-decoration: none;
    }

    .sidr-class-dropdown-menu {
        list-style-type: none;
        padding: 0px;
    }

    .sidr-class-dropdown-item {
        padding: 10px 10px 10px 40px;
        font-size: 0.9rem;
        color: var(--ctx-100);
        transition: var(--trb);
        display: inline-block;
        width: 100%;
        text-decoration: none;
    }

    .sidr-class-nav-link.sidr-class-is-active,
    .sidr-class-dropdown-item.sidr-class-is-active {
        background-color: var(--cpr-130);
        color: var(--csw-100);
    }

    .path-frontpage .sidr-class-nav-link.sidr-class-is-active {
        background-color: transparent;
        color: var(--ctx-100);
    }

    .sidr-class-nav-link:is(:hover, :focus, :active),
    .sidr-class-nav-link.sidr-class-is-active:is(:hover, :focus, :active),
    .sidr-class-dropdown-item:is(:hover, :focus, :active),
    .sidr-class-dropdown-item.sidr-class-is-active:is(:hover, :focus, :active) {
        background-color: var(--cpr-100);
        color: var(--csw-100);
    }

    .sidr-class-footer {
        position: fixed;
        bottom: 0px;
        background-color: var(--ctx-030);
        font-size: 0.7rem;
        text-align: center;
        padding: 20px;
        width: 400px;
    }
  
/* #endregion */


/* #region HEADER */

    #block-header h2 {
        display: none;
    }

    .head-size {
        position: relative;
        display: flex;
        flex-flow: row nowrap;
        align-items: center;
        justify-content: center;
        box-shadow: var(--bsl);
        margin-top: -75px;
        overflow: hidden;
    }

    .head-bg {
        position: absolute;
        width: 100%;
        z-index: 1;
    }

    .hb-image img {
        width: 100%;
        object-position: center;
        object-fit: cover;
        background-position: center;
        background-size: cover;
        position: absolute;
        top: 0;
        left: 0;
        transform: translateY(0);
        transition: transform 0.1s ease-out;
    }

    .hb-image.hh_100 img {
        height: 100vh;
    }

    .hb-image.hh_085 img {
        height: 85vh;
    }

    .hb-image.hh_065 img {
        height: 65vh;
    }

    .hb-image.hh_045 img {
        height: 45vh;
    }

    .hb-image.hh_030 img {
        height: 30vh;
    }

    .hcnt {
        position: relative;
        z-index: 2;
        max-width: 80%;
        text-align: center;
    }

    .hcnt svg {
        height: 250px;
        transition: var(--trb);
    }

    .hcnt div {
        margin: 40px 0px 0px 0px;
        color: var(--csw-100);
        font-size: 3rem;
        font-weight: 900;
        transition: var(--trb);
    }

    .hcnt h2, .hcnt h3, .hcnt h4, .hcnt h5 {
        margin: 0px 0px 15px 0px;
    }

    .head-title {
        font-size: 5rem;
        color: var(--cpr-100);
        font-weight: 900;
        margin-bottom: 10px;
        margin-top: -30px;
    }

    .head-cnt {
        font-size: 1.3rem;
        font-weight: 500;
    }

/* #endregion */


/* #region PARAGRAPH / LEGAL BLOCK */

    .paragraph--type--t-lb .flex {
        display: flex;
        flex-flow: row wrap;
        align-items: start;
        justify-content: start;
        gap: 30px;
    }

    .paragraph--type--t-lb .flex .left {
        width: 23%;
    }

    .paragraph--type--t-lb .flex .right {
        width: 73%;
    }

    .field--name-field-st {
        font-size: 2rem;
        font-weight: 900;
        line-height: 1.1;
    }

    .field--name-field-tldr {
        font-size: 0.8rem;
        color: var(--ctx-060);
        margin-top: 10px;
        text-align: justify;
    }

    .field--name-field-tldr .field__label {
        color: var(--ctx-100);
    }

/* #endregion */


/* #region CONTENT */

    .heading {
        text-align: center;
        display: flex;
        flex-flow: column;
        align-items: center;
        justify-content: center;
    }

    .heading .sml {
        font-size: 1.5rem;
        font-weight: 400;
        text-align: center;
        line-height: 1;
        color: var(--cpr-100);
    }

    .heading .lrg {
        font-family: 'Baskervville', serif;
        font-size: 4rem;
        font-weight: 700;
        text-align: center;
        line-height: 1;
        color: var(--cpr-100);
    }

    .heading .line {
        width: 100px;
        height: 5px;
        background-color: var(--cpr-100);
        margin: 10px 0px 30px 0px;
    }

    .view-services .view-content {
        margin-top: 60px;
        display: flex;
        flex-flow: row wrap;
        align-items: start;
        justify-content: center;
        gap: 30px;
    }

    .view-services .views-row {
        width: 30%;
    }

    .view-services .serv-wrap {
        background-color: var(--csw-100);
        box-shadow: var(--bsl);
        border-radius: 30px;
        padding: 30px;
        display: flex;
        flex-flow: column;
        align-items: center;
        justify-content: space-between;
    }

    .sw-sum {
        text-align: center;
        min-height: 130px;
        margin-bottom: 25px;
    }

    .sw-tit {
        height: 80px;
        font-size: 2rem;
        font-family: 'Baskervville', serif;
        font-weight: 700;
        color: var(--cpr-100);
        margin: 25px 0px;
        line-height: 1.2;
        text-align: center;
    }

    .sw-lnk {
        width: 100%;
        text-align: center;
    }

    .sw-lnk a {
        display: inline-block;
        background-color: var(--cpr-100);
        color: var(--csw-100);
        width: 100%;
        padding: 15px;
        border-radius: 15px;
    }

    .cnt-wrap {
        background-color: var(--cpr-015);
        padding: 30px;
        border-radius: 30px;
        display: flex;
        flex-flow: column;
        gap: 25px;
        line-height: 1.2;
    }

    .cnt-wrap .cw-itm.nolink,
    .cnt-wrap .cw-itm a {
        background-color: var(--csw-100);
        padding: 25px;
        border-radius: 15px;
        display: flex;
        flex-flow: row nowrap;
        align-items: center;
        justify-content: start;
        gap: 25px;
        color: var(--ctx-100);
        text-decoration: none;
    }

    .cw-itm .cwi-icn {
        width: 60px;
    }

    .cw-itm .cwit-head {
        font-size: 1.5rem;
        font-weight: 900;
    }

    .cnt-map {
        border-radius: 30px;
        overflow: hidden;
    }

/* #endregion */


/* #region SERVICES */

    .hcnt div.ban-icon {
        display: inline-block;
        width: 100px;
        margin: 60px 0px 25px 0px;
    }

    .hcnt div.ban-icon svg {
        width: 100px;
        height: auto;
    }

    .hcnt div.white-heading {
        margin: 0px;
    }

    .white-heading .sml {
        font-size: 1.5rem;
        font-weight: 400;
        text-align: center;
        line-height: 1;
        color: var(--csw-100);
        margin: 0px;
    }

    .white-heading .lrg {
        font-family: 'Baskervville', serif;
        font-size: 4rem;
        font-weight: 700;
        text-align: center;
        line-height: 1;
        color: var(--csw-100);
        margin: 0px;
        transition: var(--trb);
    }

    .white-heading .line {
        display: inline-block;
        width: 100px;
        height: 5px;
        background-color: var(--csw-100);
        margin: 10px 0px 0px 0px;
    }

    main .node--type-service {
        width: 80%;
        margin: 60px auto;
    }

    .serv-head {
        background-color: var(--cpr-015);
        padding: 25px;
        border-radius: 30px;
        display: none;
        flex-flow: row nowrap;
        align-items: center;
        justify-content: start;
        gap: 30px;
        margin-bottom: 40px;
    }

    .modal-body .serv-head {
        display: flex;
    }

    .field--name-field-svg-icon {
        width: 100px;
    }

    .field--name-field-sh {
        font-size: 1.5rem;
        font-weight: 400;
        line-height: 1;
        color: var(--cpr-100);
        margin: 0px;
    }

    .field--name-field-mh {
        font-family: 'Baskervville', serif;
        font-size: 3rem;
        font-weight: 700;
        line-height: 1;
        color: var(--cpr-100);
        margin: 0px;
    }

    .sh-line {
        display: inline-block;
        width: 100px;
        height: 5px;
        background-color: var(--cpr-100);
        margin: 10px 0px 0px 0px;
    }

/* #endregion */


/* #region WEBFORM */

    .webform-flex--container > .form-item {
        position: relative;
    }

    .webform-element--title-inline > label,
    .form-type-tel > label {
        position: absolute;
        padding: 20px 15px;
        font-weight: 700;
    }

    .form-control {
        display: block;
        width: 100%;
        padding: 20px 25px 20px 160px;
        font-size: 1rem;
        font-weight: 400;
        line-height: 1.5;
        color: var(--ctx-100);
        appearance: none;
        background-color: var(--csw-100);
        background-clip: padding-box;
        border: none;
        border-radius: 30px;
        box-shadow: var(--bsl);
        transition: border-color 0.15s ease-in-out, box-shadow 0.15s ease-in-out;
    }

    .webform-type-checkboxes {
        display: flex;
        flex-flow: row nowrap;
        align-items: center;
        justify-content: start;
        gap: 15px;
    }

    .webform-type-checkboxes > legend {
        width: 20%;
    }

    .webform-type-checkboxes > .fieldset-wrapper {
        width: 80%;
    }

    .webform-flexbox {
        gap: 50px;
    }

    .webform-options-display-buttons label.webform-options-display-buttons-label {
        display: table-cell;
        height: 100%;
        padding: 10px;
        text-align: center;
        vertical-align: middle;
        color: var(--ctx-100);
        border: none;
        border-radius: 30px;
        background-color: var(--csw-100);
        box-shadow: var(--bsl);
        transition: var(--trb);
        cursor: pointer;
    }

    .webform-options-display-buttons input:checked + label.webform-options-display-buttons-label {
        color: var(--csw-100);
        border: none;
        background-color: var(--cpr-100);
    }

    .webform-options-display-buttons label.webform-options-display-buttons-label:is(:hover, :focus, :active) {
        color: var(--csw-100);
        border: none;
        background-color: var(--cpr-030);
    }

    .webform-actions {
        text-align: center;
    }

    .btn-primary {
        background-color: var(--cpr-075);
        padding: 15px 25px;
        border-radius: 30px;
        border: none;
    }

    .btn-primary:is(:hover, :focus, :active) {
        background-color: var(--cpr-100);
    }

    .captcha__element {
        text-align: center;
    }

    .container-inline .webform-flex--container > .form-item > input:not([type="checkbox"]), .container-inline .webform-flex--container > .form-item > select, .webform-flex--container > .form-item.webform-element--title-inline > input:not([type="checkbox"]), .webform-flex--container > .form-item.webform-element--title-inline > select {
        width: 100%;
    }

/* #endregion */


/* #region FOOTER */

    footer {
        margin: 0px;
        padding: 0px;
        font-size: 0.8rem;
    }

    footer p {
        margin: 0px;
    }

    footer .tcl-wrap .content {
        align-items: center;
    }

    .foot-std {
        padding: 15px 30px;
    }

    .foot-std .fs-wrap {
        display: flex;
        flex-flow: row wrap;
        align-items: center;
        justify-content: space-between;
        gap: 25px;
    }

    .footer-logo {
        text-align: left;
    }

    .footer-logo svg {
        width: 250px !important;
        width: auto;
    }

    .path-frontpage #block-footer,
    #block-footerotherpage {
        display: block;
    }

    #block-footer,
    .path-frontpage #block-footerotherpage {
        display: none;
    }

    #block-footer .navbar-nav,
    #block-footerotherpage .navbar-nav {
        display: flex;
        flex-flow: column;
        align-items: end;
        justify-content: end;
        column-gap: 30px;
    }

    #block-footer .navbar-nav li,
    #block-footerotherpage .navbar-nav li {
        width: 40%;
        border-bottom: 2px solid var(--csw-100);
        transition: var(--trb);
    }

    #block-footer .navbar-nav li:is(:hover, :focus, :active),
    #block-footerotherpage .navbar-nav li:is(:hover, :focus, :active) {
        border-bottom: 2px solid var(--cpr-045);
    }

    #block-footer .navbar-nav li a:is(:hover, :focus, :active),
    #block-footerotherpage .navbar-nav li a:is(:hover, :focus, :active) {
        color: var(--cpr-045);
    }

/* #endregion */