:root {
    --qui-color-primary: #0a6167;
    --qui-color-primary--light: rgba(201, 207, 195);
    --qui-body-color: #0a6167;
    --page-body-color: rgb(237, 230, 214); /*  inner page background color*/
    --qui-body-bgColor: #e1d3b4; /* body background color */

    --brand-color: var(--qui-color-primary);
    --brand-color-light: rgba(201, 207, 195);
    --brand-color-light-2: rgb(174, 190, 180);
    --brand-color-beige: rgb(48, 27, 15);

    --page-max-width: 1200px;
    --qui-footer-bg: transparent !important;

    --page-padding-inline: clamp(0rem, calc(4vw * 1.5 - 2rem), 3rem);
}

/***********/
/* General */
/***********/
body {
    font-weight: normal;
    background-color: var(--qui-body-bgColor) !important;
}

.slideout-panel.slideout-panel {
    --bgSize: 1400px 500px;

    background-color: var(--qui-body-bgColor) !important;

    background-image: url('/media/cache/77dsign/Assets/wischwasch_braun.png') !important;
    background-repeat: no-repeat !important;
    background-position: top center !important;
    background-size: var(--bgSize) !important;
}

@media screen and (min-width: 1400px) {
    .slideout-panel.slideout-panel {
        --bgSize: 100% calc(500px + 10vw);
    }
}

@media screen and (max-width: 767px) {
    .slideout-panel.slideout-panel {
        --bgSize: 1000px 300px;
    }
}

.body-container {
    max-width: var(--page-max-width);
    margin-inline: auto;
    background-color: var(--page-body-color);
    top: 0 !important;
}

.text-narrow {
    max-width: 700px;
    margin-inline: auto;
}

/********/
/* Logo */
/********/
.ks77d-sign-logoBig {
    margin-top: 8rem;
    margin-bottom: 2rem;
}

@media screen and (max-width: 1200px) {
    .ks77d-sign-logoBig {
        padding-inline: 1rem;
    }
}

@media screen and (max-width: 767px) {
    .ks77d-sign-logoBig {
        margin-top: 3rem;
        width: min(300px, 100%);
    }
}

@media screen and (max-width: 400px) {
    .ks77d-sign-logoBig {
        margin-top: 1rem;
    }
}

/*************/
/* Mega menu */
/*************/
.header-bar {
    background-color: var(--qui-color-primary) !important;
    max-width: 1200px;
    position: initial !important;
    margin-inline: auto;
}

.header-bar-inner {
    padding-inline: 0 !important;
}

.header-bar-inner-logo {
    display: none !important;
}

/* hide nav on start page */
.start-page .header-bar {
    display: none !important;
}

/********/
/* Page */
/********/
.page-header.page-header {
    background-color: var(--brand-color-light);
    padding: 3rem var(--page-padding-inline);
}

.tpl-presentation-row {
    padding: 3rem var(--page-padding-inline);
}

.page-header-text-title {
    text-transform: uppercase;
    color: var(--qui-color-primary);
    font-weight: normal;
    max-width: 100%;
    text-align: center;
    letter-spacing: 0.25em;
    font-size: var(--qui-display-4);
}

.main-content-wrapper {
    padding-inline: var(--page-padding-inline);
}

@media screen and (max-width: 767px) {
    .page-header.page-header {
        padding-bottom: 7rem;
    }
}

/**********/
/* Footer */
/**********/
/* Set footer image on body container */
.body-container {
    background-image: url('/media/cache/77dsign/Assets/wischwasch_petrol.png');
    background-size: 1300px auto;
    background-position: center calc(100% + 100px);
    background-repeat: no-repeat;
}

.page-footer.page-footer {
    font-size: 1rem;
    padding-inline: var(--page-padding-inline);
}

@media screen and (min-width: 768px) {
    .page-footer.page-footer {
        margin-top: 10rem;
    }
}

/* url list  */
.ks77d-sign-footer-right,
.ks77d-sign-footer-left {
    text-transform: uppercase;
}

:is(.ks77d-sign-footer-right, .ks77d-sign-footer-left) .quiqqer-urlList-entry {
    margin-bottom: 0;
}

.page-footer-container {
    padding-block: 3rem;
}

.page-footer a {
    color: #fff;
}

.page-footer a:hover {
    text-decoration: underline;
}

.page-footer-copyright {
    display: none;
}


@media screen and (min-width: 768px) {
    .ks77d-sign-footer-right .quiqqer-urlList-entry-link {
        text-align: right;
    }
}

/****************************/
/* Start page: welcome text */
/****************************/
.brick-container__ks77d-sign-halloText {
    background-color: var(--brand-color-light-2);
    color: #fff;
}

.ks77d-sign-halloText {
    padding-top: 3rem;
}

/******************/
/* Category boxes */
/******************/
.ks77d-sign-categories .quiqqer-boxContentAdvanced-entry {
    padding-inline: 1rem;
    position: relative;
    width: 250px;
    margin-inline: auto;
}

.ks77d-sign-categories .quiqqer-boxContentAdvanced-entry-img {
    margin-bottom: 0 !important;
    transition: 0.2s ease;
}

.ks77d-sign-categories .quiqqer-boxContentAdvanced-entry:hover > a .quiqqer-boxContentAdvanced-entry-img {
    filter: brightness(1.3);
}

.ks77d-sign-categories .quiqqer-boxContentAdvanced-entry > header {
    position: absolute;
    left: calc(50% + 0.5em);
    top: calc(50% - 0.5em);
    transform: translate(-50%, -50%);
    padding: 0;
}

.ks77d-sign-categories .quiqqer-boxContentAdvanced-entry .quiqqer-boxContentAdvanced-entry-title {
    font-size: 1.125rem;
    font-weight: normal;
}

.ks77d-sign-categories .quiqqer-boxContentAdvanced-entry a {
    color: #fff;
}

/******************************/
/* Startpage: category boxes */
/******************************/
.ks77d-sign-categories .quiqqer-boxContentAdvanced-entry .quiqqer-boxContentAdvanced-entry-title {
    font-size: 1.25rem;
}

/******************/
/* Page portfolio */
/******************/
.ks77d-sign-page-portfolio {
    --qui-header-min-height: 350px !important;
}

.ks77d-sign-page-portfolio .page-header.page-header {
    padding: 3rem var(--page-padding-inline) 6rem;
}

/******************************/
/* Portfolio - category boxes */
/******************************/
.ks77d-sign-categories--portfolio {
    --top-spacing: 6rem;

    margin-top: -10rem;
}

.ks77d-sign-categories.ks77d-sign-categories--portfolio .quiqqer-boxContentAdvanced-entry {
    padding-inline: 4rem;
    width: 340px;
    border-radius: 14rem 14rem 0 0;
    padding-top: var(--top-spacing);
    background: var(--page-body-color);
}

.ks77d-sign-categories--portfolio .quiqqer-boxContentAdvanced-entry a {
    margin-top: -2rem;
    display: block;
}

.ks77d-sign-categories--portfolio .quiqqer-boxContentAdvanced-entry .quiqqer-boxContentAdvanced-entry-title > a {
    padding-top: var(--top-spacing);
}

.ks77d-sign-categories--portfolio .quiqqer-boxContentAdvanced-entry.hover-darker a {
    color: var(--brand-color-beige)
}

.ks77d-sign-categories--portfolio .quiqqer-boxContentAdvanced-entry.hover-darker:hover > a .quiqqer-boxContentAdvanced-entry-img {
    filter: brightness(0.9);
}

/*********************/
/* Portfolio gallery */
/*********************/
.quiqqer-gallery-grid-entry {
    background-color: transparent !important;
    padding: 0 !important;
    position: relative;
}

.quiqqer-gallery-grid-entry-image {
    height: auto !important;
}

.quiqqer-gallery-grid-entry-image img {
    display: block;
}

.quiqqer-gallery-grid-entry .quiqqer-gallery-grid-entry-text {
    position: absolute;
    inset: 0;
    display: grid;
    place-items: center;
    cursor: pointer;
    transition: 0.25s ease;
    opacity: 0;
    color: #fff;
    white-space: initial !important;
    padding-inline: 1rem;
    overflow: hidden;
}

.quiqqer-gallery-grid-entry .quiqqer-gallery-grid-entry-text:before,
.quiqqer-gallery-grid-entry .quiqqer-gallery-grid-entry-text:after {
    content: '';
    width: 3rem;
    height: 2px;
    background-color: rgba(255, 255, 255, 0);
    position: absolute;
    left: calc(50% - 1.5rem);
    transition: 0.35s ease;
}

.quiqqer-gallery-grid-entry .quiqqer-gallery-grid-entry-text:before {
    top: 1rem;
    transform: translateY(-1.5rem) scaleX(1.5);
}

.quiqqer-gallery-grid-entry .quiqqer-gallery-grid-entry-text:after {
    bottom: 1rem;
    transform: translateY(1.5rem) scaleX(1.5);
}

.quiqqer-gallery-grid-entry .quiqqer-gallery-grid-entry-text:is(:hover, :active) {
    background-color: rgba(0, 0, 0, 0.5);
    opacity: 1;
}

.quiqqer-gallery-grid-entry .quiqqer-gallery-grid-entry-text:is(:hover, :active):before,
.quiqqer-gallery-grid-entry .quiqqer-gallery-grid-entry-text:is(:hover, :active):after {
    background-color: rgba(255, 255, 255, 0.5);
    transform: translateY(0) scaleX(1);
}

.quiqqer-gallery-grid-entry .quiqqer-gallery-grid-entry-text > span {
    /*transform: translateY(5px);*/
    transform: scale(0.95);
    transition: 0.25s ease;
    transition-delay: 0.1s;
}


.quiqqer-gallery-grid-entry .quiqqer-gallery-grid-entry-text:is(:hover, :active) > span {
    /*transform: translateY(0);*/
    transform: scale(1);
}
