/*!
 * Theme Name: Demo BFI Design
 * Author: Lukas Hofer
 */

:root {
    --white: #ffffff;
    --black: #000000;
    --grey-light: #eee;
    --grey-medium: #aaa;
    --grey-dark: #555;

    --text: #000;
    --text-light: #eee;

    --primary: #023770;
    --secondary: #c61832;

    --navigation-width: 350px;
    --navigation-background: rgba(2, 55, 112, 0.8);
    --navigation-backdrop: rgba(0, 0, 0, 0.5);

    --header-padding: 30px;
    --header-bottom: 100px;
    --logo-width: 190px;
}

/* Startseiten-Header höher machen -neu */
body.home {
    --header-bottom: 100px;
}

*,
*::before,
*::after {
    box-sizing: inherit;
}

html {
    box-sizing: border-box;
}

/*-----------------------------------
 *---------- Typographie -----------*
 *----------------------------------*/
body,
button,
input,
select,
optgroup,
textarea {
    color: var(--text);
    font-size: 1rem;
    line-height: 1.5;
    font-family: "Roboto", sans-serif;
}

h1, h2, h3,
h4, h5, h6 {
    font-family: "Asap", sans-serif;
}


/*-----------------------------------
 *------------ Layout --------------*
 *----------------------------------*/

html, body {
    margin: 0;
    padding: 0;
    height: 100vh;
}

#page {
    display: flex;
    flex-flow: column nowrap;
    min-height: calc(100vh - var(--wp-admin--admin-bar--height));
}

#content {
    flex: 1;
    z-index: 1;
}

.site-header {
    /*background: var(--secondary); deaktiviert egen gradient*/
    position: relative;
    z-index: 2;
}

.site-branding {
    display: flex;
    align-items: center;
    justify-content: center;

    position: absolute;
    left: 50%;
    transform: translateX(-50%);
    top: var(--header-padding);
}

.custom-logo {
    max-width: var(--logo-width);
    height: auto;
}

.search-toggle {
    position: absolute;
    top: var(--header-padding);
    right: 95px;
    width: 38px;
    height: 35px;
    padding-top: 6px;
    cursor: pointer;
}

.search-toggle svg {
    width: 100%;
    height: 100%;
    fill: var(--white);
}

.menu-toggle {
    position: absolute;
    top: var(--header-padding);
    /* left: var(--header-padding); V1: links gleich wie oben */
    /* left: 30px; V2: links fixer abstand */
    /* right: var(--header-padding); V3: rechts gleich wie oben */
    right: 30px; /* V4: rechts fixer abstand */

    cursor: pointer;
    display: inline-block;
}

.menu-toggle div {
    width: 35px;
    height: 5px;
    background: var(--white);
    margin: 6px 0;
}

body.nav-open .menu-toggle div:nth-child(1) {
    transform: translateY(11px) rotate(-45deg);
}

body.nav-open .menu-toggle div:nth-child(2) {
    opacity: 0;
}

body.nav-open .menu-toggle div:nth-child(3) {
    transform: translateY(-11px) rotate(45deg);
}

.header-media {
    width: 100%;
    height: calc(100vh - var(--wp-admin--admin-bar--height) - var(--header-bottom));
}

.header-media-image {
    width: 100%;
    height: 100%;
}

.header-media-image img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    mask-image: linear-gradient(to bottom, rgba(0,0,0,1) 75%, rgba(0,0,0,0));
}

.header-media-content h1 {
    margin: 0;
    color: var(--white);
    font-size: 6rem;
}

/* V1: Überschrift links unten
.header-media-content {
    position: absolute;
    left: var(--header-padding);
    bottom: var(--header-padding);
}
*/

/* V2: Überschrift rechts unten mit mehr Abstand
.header-media-content {
    position: absolute;
    right: calc(4 * var(--header-padding));
    bottom: calc(4 * var(--header-padding));
}
*/

/* V3: Überschrift zentriert */
.header-media-content {
    position: absolute;
    left: 50%;
    top: 50%;
    transform: translate(-50%, -50%);
    text-align: center;
    width: 100%;
}

.site-footer {
    background: var(--secondary);
    color: var(--text-light);
    padding-top: 30px;
}

.site-footer-columns {
    display: flex;
    justify-content: space-around;
}

.site-footer-navigation ul {
    display: flex;
    flex-flow: row rap;
    justify-content: center;
    list-style-type: none;
}

.site-footer-navigation a {
    padding: 0 10px;
    color: var(--white);
}



.bfi-social-links {
    display: flex;
    justify-content: center;
    gap: 20px;
    padding: 20px;
}

.bfi-social-links a {
    display: inline-block;
    width: 40px;
    height: 40px;
}

.bfi-social-links svg {
    width: 100%;
    height: 100%;
}


/*-----------------------------------
 *---------- Navigation ------------*
 *----------------------------------*/

.site-navigation ul {
    list-style-type: none;
    font-size: 1.4rem;
    line-height: 2;
    font-weight: bold;
}

.menu-close {
    display: flex;
    justify-content: flex-end;
}

.menu-close-button {
    color: var(--white);
    font-size: 2rem;
    cursor: pointer;
    user-select: none;
    padding: 0 15px;

    transition: 0.2s ease-out;
}

.menu-close-button:hover {
    color: var(--grey-medium);
}

/* Für Trenner aktivieren: */
.site-navigation ul.menu > li {
    border-bottom: 1px dashed rgba(255, 255, 255, 0.7);
}

.site-navigation ul a,
.site-navigation ul a:visited {
    display: block;
    color: var(--white);
    text-decoration: none;
    padding: 16px 0;

    transition: 0.2s ease-out;
}

.site-navigation ul a:hover {
    padding-left: 30px;
}

.backdrop,
.search-backdrop {
    position: fixed;
    top: 0;
    bottom: 0;
    left: 0;
    right: 0;
}

.backdrop {
    background: var(--navigation-backdrop);
    backdrop-filter: blur(5px);

    transition: 0.5s;
}

.search-backdrop {
    background: var(--navigation-backdrop);
    backdrop-filter: blur(5px);

    transition: 0.5s;
}

/*...*/

.search-close {
    position: absolute;
    top: var(--header-padding);
    right: var(--header-padding);
    line-height: 1;
    font-size: 45px;
    color: var(--white);
    cursor: pointer;
    padding-left: 14px;
    padding-right: 15px;
    border-radius: 25%;
}

/*...*/

.search-backdrop form {
    position: absolute;
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%);

    display: flex;
    flex-flow: column;
    align-items: center;
}

.search-backdrop label {
    display: none;
}

.search-backdrop .search-input {
    padding: 1rem 2rem;
    font-size: 1.5rem;
    min-width: 50vw;
    border-radius: 2rem;
    border-bottom: none;
}

.search-backdrop .search-submit {
    padding: 0.5rem 3rem;
    border-bottom-left-radius: 2rem;
    border-bottom-right-radius: 2rem;
    border-top: none;
    background-color: antiquewhite;
}

.menu-container {
    position: fixed;
    top: 0;
    left: 0;
    bottom: 0;

    overflow-y: auto;

    margin: 0;
    margin-top: var(--wp-admin--admin-bar--height);
    padding: 16px 35px;
    width: var(--navigation-width);
    max-width: 100vw;

    background: var(--navigation-background);
    backdrop-filter: blur(15px);

    transform: translateX(calc(100vw - 100%));
    visibility: visible;
    transition: 0.5s;
}

body:not(.nav-open) .menu-container {
    transform: translateX(calc(100vw + 1%));
    visibility: hidden;
}

body:not(.nav-open) .backdrop,
body:not(.search-open) .search-backdrop {
    display: none;
}


/*----------------------------
 *--------- Content ---------*
 *---------------------------*/

#content {
    padding: 20px;
}

@media screen and (min-width: 678px) {
    .search-backdrop .search-submit {
        padding: 0.5rem 6rem;
    }
}

@media screen and (min-width: 1048px) {
    .search-backdrop .search-submit {
        padding: 0.5rem 10rem;
    }
}

.post-header h1 {
    margin-top: 0;
    font-size: 2.5rem;
}

/*----------------------
 -------Diverses-------- neu
 ----------------------*/

.top-button {
    position: fixed;
    right: var(--header-padding);
    bottom: var(--header-padding);
  /*background: rgb(121, 109, 109);*/
    background: var(--navigation-backdrop);
    border-radius: 50%;

    width: 50px;
    height: 50px;
    padding: 10px;

    cursor: pointer;
    opacity: 0;
    visibility: hidden;
    transition: 0.2s ease-out;
  /*transform: scaleY(2);*/
}

body.top-btn-visible .top-button {
    opacity: 1;
    visibility: visible;
  /*transform: scaleY(2);*/
}

.top-button svg {
    width: 100%;
    height: 100%;
    fill: var(--white);
}
