/****************************************************************************
* Change Styles here
****************************************************************************/
body .qr_wrapper, 
body .qr_overlay,
body .sp-dsgvo,
body .finish_wrapper {
    background-color: #141618;
    color: #fff;
}
body .button,
body .sp-dsgvo .sp-dsgvo-blocked-embedding-button-enable {
    background-color: #fff;
    color: #000;
    border-radius: 8px;
    border-color: #fff;
    border-width: 2px;
    font-size: 14px;
    font-weight: 600;
    text-transform: uppercase;
}
body .button.bordered {
    background-color: transparent;
    color: #fff;
    border-color: currentColor;
}

/****************************************************************************
 * Fonts
 ****************************************************************************/
@font-face {
    font-family: 'Inter';
    src: url('fonts/Inter-SemiBold.woff');
    src: local('Inter SemiBold'), local('Inter-SemiBold'),
        url('fonts/Inter-SemiBold.woff2') format('woff2');
    font-weight: 600;
    font-style: normal;
    font-display: swap;
}

@font-face {
    font-family: 'Inter';
    src: url('fonts/Inter-Light.woff');
    src: local('Inter Light'), local('Inter-Light'),
        url('fonts/Inter-Light.woff2') format('woff2');
    font-weight: 300;
    font-style: normal;
    font-display: swap;
}

/****************************************************************************
 * Wrapper
 ****************************************************************************/
html {line-height: 1.15;-webkit-text-size-adjust: 100%;}
body {
    font-family: 'Inter';
    font-weight: 300;
    font-style: normal;
    margin: 0;
}
a { color: inherit;}
p {line-height: 1.6;}

/****************************************************************************
 * Wrapper
 ****************************************************************************/
 .qr_wrapper {
    position: relative;
    width: 100svw;
    height: 100svh; 
    display: flex;
    flex-direction: column;
    flex-wrap: nowrap;
    justify-content: center;
    overflow: hidden;
}

/****************************************************************************
 * Logo && Buttons
 ****************************************************************************/
.button {
    outline: none;
    border: 2px solid currentColor;
    padding: 0.75rem 1.5rem;
}
.qr_logo {
    position: relative;
    width: 80%;
    max-width: 20rem;
    margin: 0 auto 1rem auto;
    height: 30%;
    max-height: 10rem;
}
.qr_logo.hidden {
    opacity: 0;
}
.qr_logo img {
    position: absolute;
    top: 0; left: 0; width: 100%; height: 100%;
    object-fit: contain;
    object-position: 50% 50%;
}
.qr_buttons {
    width: 80%;
    max-width: 20rem;
    margin: 0 auto;
}
.qr_buttons .button {
    margin: 0.5rem 0;
    display: block;
    width: 100%;
}

/****************************************************************************
 * Player
 ****************************************************************************/
#qr_vimeo_player {
    position: relative;
    left: 0; top: 0;
    width: 100svw;
    height: 100svh;
}
/*
#qr_vimeo_player iframe {
    position: absolute;
    top: 4rem; left: 0;
    width: 100%; height: calc(100% - 8rem);
    object-fit: contain;
}
*/

#qr_vimeo_player:after {
    content: none; color: #FFFFFF;
    position: absolute; z-index: 200;
    top: 50%; left: 50%; pointer-events: none;
    width: 3rem; height: 3rem;
    border: 0.25rem solid currentColor;
    border-bottom-color: transparent;
    border-radius: 50%;
    transform: translate(-50%,-50%);
}
@keyframes rotation {
    0% {transform: translate(-50%,-50%) rotate(0deg);}
    100% {transform: translate(-50%,-50%) rotate(360deg);}
} 
#qr_vimeo_player.loading:after {
    content: '';
    animation: rotation 1s linear infinite;
}

#qr_vimeo_player.pause:after {
    content: '';
    width: 5rem; height: 5rem;
    border-width: 0.1875rem;
    border-color: currentColor;
    background-image: url('data:image/svg+xml,<svg height="200" width="200" xmlns="http://www.w3.org/2000/svg"><polygon points="55,40 155,100 55,160" fill="%23FFFFFF" /></svg>');
    background-position: 50% 50%;
    background-size: 80% auto;
    background-repeat: no-repeat;
}

#qr_vimeo_player.iphone_start:not(.loading):after {
    content: 'Start';
    width: 8rem; height: 4rem; font-size: 1.375rem;
    line-height: 4rem; text-align: center;
    font-weight: 700; text-transform: uppercase;
    border-color: #FFFFFF;
    border-radius: 0.375rem;
    background: transparent;
}

/****************************************************************************
 * Videos
 ****************************************************************************/
#qr_vimeo_player .player_videos {
    position: absolute; top: 50%;  left: 50%;
    width: 100svh; height: 100svh;
    transform: translate(-50%,-50%);
}
#qr_vimeo_player .player_item {
    position: absolute;
    top: 0; left: 0; width: 100%; height: 100%;
}
#qr_vimeo_player .player_item.active {
    display: block;
}
#qr_vimeo_player .player_item iframe {
    position: absolute;
    top: 0; left: 0; width: 100%; height: 100%;
}

/****************************************************************************
 * Player Topbar
 ****************************************************************************/
#qr_vimeo_player .qr_topbar {
    position: absolute;
    top: 0; height: 4rem;
    width: 100%; left: 0;
}
#qr_vimeo_player .qr_topbar > * {
    position: relative; z-index: 20;
    display: inline-block; cursor: pointer;
    width: 4rem; height: 4rem;
}
#qr_vimeo_player .qr_topbar > .qr_topbar_logo {
    width: calc(100% - 4rem);
    cursor: auto;
}
#qr_vimeo_player .qr_topbar > .qr_topbar_logo img {
    position: absolute;
    top: 1rem; left: 1rem; width: calc(100% - 2rem);
    height: calc(100% - 2rem);
    object-fit: contain;
    object-position: 0 50%;
}
/*
#qr_vimeo_player .qr_topbar > *::after {
    content: ''; pointer-events: none;
    position: absolute; top: 0.25rem; left: 0.125rem;
    right: 0.125rem; bottom: 0.25rem;
    background-color: rgba(255,255,255,0.2);
}
*/
#qr_vimeo_player .qr_topbar > span svg {
    width: 1.5rem; height: 1.5rem;
    position: absolute; pointer-events: none;
    top: 50%; left: 50%;
    transform: translate(-50%,-50%);
}
#qr_vimeo_player .qr_topbar > span svg path {
    fill: currentColor;
}

/****************************************************************************
 * Start Stop
 ****************************************************************************/
#qr_vimeo_player .start_stop {
    position: absolute;
    top: 4rem; left: 0; bottom: 4rem; right: 0;
    height: auto; height: auto; z-index: 100;
    opacity: 0;
}

/****************************************************************************
 * Controls
 ****************************************************************************/
#qr_vimeo_player .conrols {
    position: absolute;
    top: 50%; height: 4rem;
    width: 100%; z-index: 300;
    pointer-events: none;
    transform: translate(0,-50%);
    display: flex; flex-direction: row;
    flex-wrap: nowrap;
    justify-content: space-between;
}
#qr_vimeo_player .conrols > span {
    position: relative; z-index: 20;
    display: inline-block; cursor: pointer;
    height: 4rem; flex: 0 0 4rem; width: 4rem;
    pointer-events: all;
    
}
/*
#qr_vimeo_player .conrols > span::after {
    content: ''; pointer-events: none;
    position: absolute; top: 0.25rem; left: 0.125rem;
    right: 0.125rem; bottom: 0.25rem;
    background-color: rgba(255,255,255,0.2);
}
*/
#qr_vimeo_player .conrols > span svg {
    width: 1.5rem; height: 1.5rem;
    position: absolute; pointer-events: none;
    top: 50%; left: 50%;
    transform: translate(-50%,-50%);
}
#qr_vimeo_player .conrols > span svg path {
    fill: currentColor;
}

#qr_vimeo_player .conrols .conrol_volume.hidden {
    display: none;
}

#qr_vimeo_player.player_muted .conrols .conrol_volume:after {
    content: ''; position: absolute;
    top: 50%; left: 50%; width: 1.5rem; height: 0.125rem;
    transform: translate(-50%,-50%) rotate(-45deg);
    background-color: currentColor;
}



/****************************************************************************
 * Controls Bottom
 ****************************************************************************/
/*#qr_vimeo_player .conrols_bottom {
    position: absolute;
    bottom: 0; height: 4rem;
    width: 100%; z-index: 300;
    pointer-events: none;
    display: flex; flex-direction: row;
    flex-wrap: nowrap;
}
*/
#qr_vimeo_player .conrols_bottom {
    position: absolute;
    top: 4rem; height: 8rem;
    width: 4rem; z-index: 300;
    pointer-events: none;
    display: flex; flex-direction: row;
    flex-wrap: wrap;
}
#qr_vimeo_player .conrols_bottom > span {
    position: relative; z-index: 20;
    display: inline-block; cursor: pointer;
    height: 4rem; flex: 0 0 4rem; width: 4rem;
    pointer-events: all;
    
}
#qr_vimeo_player .conrols_bottom > span svg {
    width: 1.5rem; height: 1.5rem;
    position: absolute; pointer-events: none;
    top: 50%; left: 50%;
    transform: translate(-50%,-50%);
}
#qr_vimeo_player .conrols_bottom > span svg path {
    fill: currentColor;
}
#qr_vimeo_player .conrols_bottom .conrol_bottom_volume {
    display: none;
}
#qr_vimeo_player .conrols_bottom .conrol_bottom_volume.visible {
    display: block;
}
#qr_vimeo_player.player_muted .conrols_bottom .conrol_bottom_volume:after {
    content: ''; position: absolute;
    top: 50%; left: 50%; width: 1.5rem; height: 0.125rem;
    transform: translate(-50%,-50%) rotate(-45deg);
    background-color: currentColor;
}

/****************************************************************************
 * Finish Wrapper
 ****************************************************************************/
.finish_wrapper {
    position: absolute; z-index: 200;
    top: 0; left: 0; width: 100svw; height: 100svh;
    background-color: #FFFFFF;
    display: flex;
    flex-direction: row;
    flex-wrap: nowrap;
    align-items: center;
    justify-content: center;
}
.finish_wrapper .finish_wrapper_inner {
    flex: 0 0 70%; overflow: auto;
    box-sizing: border-box;
    max-height: 100%;
    max-width: 25rem;
}
.finish_wrapper .finish_wrapper_inner .button {
    display: block;
    width: 100%;
    margin: 0.5rem 0;
    box-sizing: border-box;
    text-align: center;
}

/****************************************************************************
 * Overlay Toggle
 ****************************************************************************/
.qr_overlay_toggle {
    position: absolute;
    bottom: 1rem;
    left: 0; right: 0;
    text-align: center;
    font-size: 0.75rem;
    font-weight: 600;
}
/****************************************************************************
 * Overlay
 ****************************************************************************/
.qr_overlay {
    box-sizing: border-box;
    position: fixed;
    top: 0; left: 0;
    width: 100svw; height: 100svh;
    display: flex;
    flex-direction: row;
    flex-wrap: nowrap;
    align-items: center;
    justify-content: center;
    padding: 2rem;
}
.qr_overlay.hidden {
    display: none;
}

.qr_overlay .qr_overlay_inner {
    flex: 0 0 100%; overflow: auto;
    box-sizing: border-box;
    max-height: 100%;
    max-width: 25rem;
}
.qr_overlay .close {
    position: absolute; top: 1rem; right: 1rem;
    width: 2rem; height: 2rem; cursor: pointer;
}
.qr_overlay .close svg {
    position: absolute;
    top: 50%; left: 50%;
    width: 1.5rem; height: 1.5rem;
    transform: translate(-50%,-50%);
}
.qr_overlay .close svg path{
    fill: currentColor;
}



/****************************************************************************
 * Legalweb
 ****************************************************************************/
.sp-dsgvo {
    position: absolute;
    top: 0; left: 0;
    height: 100svh; width: 100svw;
    display: flex;
    flex-direction: row;
    flex-wrap: nowrap;
    align-items: center;
    justify-content: center;
    background-color: #FFFFFF;
}
.sp-dsgvo:empty {
    background: transparent !important;
    pointer-events: none;
}
.sp-dsgvo .sp-dsgvo-blocked-embedding-placeholder {
    background: transparent;
    flex: 0 0 100%;
    padding: 2rem;
    box-sizing: border-box;
    max-width: 25rem;
}

body .sp-dsgvo-blocked-embedding-placeholder, 
body a.sp-dsgvo-blocked-embedding-button-enable {
    font-family: 'Inter';
    font-weight: 300;
    line-height: 1.4;
}
body .sp-dsgvo-blocked-embedding-placeholder-header {
    margin-bottom: 1rem;
}