/*
Theme Name: Arche Bestattungen
Theme URI: http://www.themesawesome.com
Author: Themes Awesome
Author URI: http://www.themesawesome.com
Text Domain: arche-bestattungen
Description: Arche Bestattungen custom wordpress theme
Tags: responsive-layout, custom-colors, custom-menu, featured-images, theme-options
Version: 1.0
License:      GNU General Public License V2
License URI:      license.txt
-----------------------------------------------------------------------------------
  1.  BASE
-----------------------------------------------------------------------------------*/


/*-----------------------------------------------------------------------------------*/
/*  1. BASE
/*-----------------------------------------------------------------------------------*/

:root {
    --green: #7DC99B;
    --dark-green: #034732;
    --white: #FAFAFA;
}

html {
    font-size: 62.5%;
    -webkit-font-smoothing: antialiased;
    height: 100%;
    overflow-x: hidden;
}

body {
    word-wrap: break-word;
    -ms-word-wrap: break-word;
    font-size: 15px;
    color: #333333;
    line-height: 22px;
    margin: 0;
    /* font-family: 'Lato'; */
}

img {
    max-width: 100%;
    height: auto;
    display: block;
}

/* remove list styles on ul, ol elements with a list role, which suggests default styling will be removed */
ul,
ol,
li {
    list-style: none;
    margin: 0;
    padding: 0;
}

h1,
h2,
h3,
h4,
h5,
h6 {
    font-family: IBM Plex Serif;
    margin-bottom: 20px;
    margin-top: 0;
    font-weight: 500;
}

a {
    cursor: pointer;
    outline: none;
    color: #333;
    text-decoration: none !important;
    -webkit-transition: all .2s ease-in-out;
    -o-transition: all .2s ease-in-out;
    transition: all .2s ease-in-out;
}

a:hover,
a:active,
a:focus {
    color: var(--dark-green);
    text-decoration: none;
    outline: none;
}

button:focus {
    outline: 0;
}

p {
    margin: 0 0 20px;
}

table {
    width: 100%;
    margin-bottom: 20px;
}

th,
td {
    padding: 8px;
    line-height: 20px;
    text-align: left;
    vertical-align: top;
    border: 1px solid #ddd;
    letter-spacing: 1px;
}

th {
    font-weight: bold;
    border-bottom: 2px solid;
    text-align: center;
}

*::-moz-selection {
    background: #000;
    color: #fff;
}

*::selection {
    background: #000;
    color: #fff;
}

button {
    background-image: none;
    background: transparent;
}

blockquote,
q {
    quotes: none;
}

blockquote:before,
blockquote:after,
q:before,
q:after {
    content: '';
    content: none;
}

blockquote {
    margin: 1.5em 0;
    padding: 0;
    border: none;
    display: inline-block;
    font: normal normal normal 14px/1 FontAwesome;
    font-size: inherit;
    text-rendering: auto;
    -webkit-font-smoothing: antialiased;
    -moz-osx-font-smoothing: grayscale;
}

blockquote:before {
    color: #999;
    content: "\f10d";
    font-size: 2em;
    margin-right: 0.4em;
}

blockquote p {
    font-size: 20px;
    line-height: 32px;
    display: inline;
}

.bypostauthor {
    background: #ffffff;
}

.bypostauthor>.comment .comment-author cite:after {
    content: "post author";
    font-size: 14px;
    margin-left: 6px;
    color: #e65454;
}

.aligncenter {
    display: block;
    margin-left: auto;
    margin-right: auto;
}

.alignright {
    float: right;
    margin-left: 10px;
}

.alignleft {
    float: left;
    margin-right: 10px;
}

img.aligncenter,
img.alignnone {
    margin-bottom: 12px;
    margin: 0 auto;
}

img.alignleft {
    margin: 12px 24px 12px 0;
    margin: 10px 20px 10px 0;
}

img.alignright {
    margin: 12px 0 12px 24px;
    margin: 10px 0 10px 20px;
}

pre {
    white-space: pre;
    word-wrap: normal;
    overflow-x: scroll;
    line-height: 1.3;
    margin: 1em 0;
}

figure,
select {
    max-width: 100%;
    height: auto;
}

.wp-caption .wp-caption-text,
.gallery-caption,
.entry-caption {
    font-style: italic;
    line-height: 2;
    color: #757575;
    font-size: 12px;
    text-align: left;
}

.sticky .post-title:before {
    content: "Featured Post";
    padding: 10px 20px;
    color: #ffffff;
    background-color: #1bc0ea;
    float: right;
    position: relative;
    top: 0;
    z-index: 10;
    right: 0px;
    font-size: 12px;
}

.screen-reader-text {
    clip: rect(1px, 1px, 1px, 1px);
    position: absolute !important;
    height: 1px;
    width: 1px;
    overflow: hidden;
}

.screen-reader-text:focus {
    background-color: #f1f1f1;
    border-radius: 3px;
    box-shadow: 0 0 2px 2px rgba(0, 0, 0, 0.6);
    clip: auto !important;
    color: #21759b;
    display: block;
    font-size: 14px;
    font-weight: bold;
    height: auto;
    left: 5px;
    line-height: normal;
    padding: 15px 23px 14px;
    text-decoration: none;
    top: 5px;
    width: auto;
    z-index: 100000;
}


input {
    width: 100%;
    height: 50px;
    background-color: #f0f0f0;
    border: none;
    padding: 0 15px;
}

textarea {
    width: 100%;
    background-color: #f0f0f0;
    border: none;
    padding: 15px;
}

input[type="email"]:focus,
input[type="search"]:focus,
input[type="text"]:focus,
input[type="password"]:focus,
textarea:focus,
select:focus {
    outline: 0;
}

.clearfix:before,
.clearfix:after {
    content: "";
    display: table;
}

.clearfix:after {
    clear: both;
}

.clearfix {
    zoom: 1;
}

.container {
    max-width: 1820px;
    margin: 0 auto;
    padding: 0 50px;
}

/* Header */
.header {
    position: relative;
    padding-top: 47px;
	z-index: 100;
}
.header-inner {
    display: flex;
    align-items: center;
    justify-content: space-between;
    padding-right: 110px;
}
.header-logo > img {
    width: 103px;
    height: 100%;
    object-fit: scale-down;
}
.header-menu {
    flex: 1;
}
.navbar-nav {
    display: flex;
    flex-direction: row;
    align-items: center;
    justify-content: flex-end;
    gap: 48px;
}
.navbar-nav li a {
    font-family: Gantari;
    font-weight: 700;
    font-size: 24px;
    line-height: 1;
    color: var(--dark-green);
    background-color: transparent;
    border-radius: 50px;
    padding: 10px 20px;
}
.navbar-nav li a:hover {
    color: var(--white);
    background-color: var(--green);
}
.header__toggle {
    position: absolute;
    right: 23px;
    top: 23px;
    display: grid;
    gap: 7px;
    margin-left: auto;
    margin-bottom: 10px;
    z-index: 999;
}

.header__toggle:focus {
    outline: 0;
    box-shadow: none;
}

.header__toggle-line {
    background-color: var(--green);
    width: 31px;
    height: 6px;
    display: block;
    border-radius: 50px;
    transition: all 0.3s ease;
}

.header__toggle.open .header__toggle-line {
    background-color: var(--dark-green);
}

.header__toggle.open .header__toggle-line:nth-child(1) {
    transform: translateY(9px) rotate(45deg);
}

.header__toggle.open .header__toggle-line:nth-child(2) {
    opacity: 0;
}

.header__toggle.open .header__toggle-line:nth-child(3) {
    transform: translateY(-16px) rotate(-45deg);
}
/* end Header */

/* Footer */
/*@media (min-width: 2000px) {
    .footer-top-detail {
        left: 82%;
        transform: translateX(-82%);
        -webkit-transform: translateX(-82%);
        -moz-transform: translateX(-82%);
        -ms-transform: translateX(-82%);
        -o-transform: translateX(-82%);
    }
}*/

.footer-top-wrap {
    position: relative;
}
.footer-top {
    height: 620px;
    background-repeat: no-repeat;
    background-size: cover;
    background-position: 50% 21%;
    mask-image: url("data:image/svg+xml,%3Csvg width='1787' height='627' viewBox='0 0 1787 627' fill='none' xmlns='http://www.w3.org/2000/svg'%3E%3Cmask id='mask0_281_20' style='mask-type:luminance' maskUnits='userSpaceOnUse' x='0' y='0' width='1787' height='627'%3E%3Cpath d='M833.008 626.797H25.2094C11.3386 626.797 0 615.458 0 601.587V25.1717C0 11.3386 11.3386 0 25.2094 0H786.331H833.008H1770.29C1779.33 0 1786.7 7.37008 1786.7 16.4031V391.975C1786.7 401.008 1779.33 408.378 1770.29 408.378H893.291H883.011C869.367 408.378 858.217 419.528 858.217 433.172V445.984V601.587C858.217 615.458 846.879 626.797 833.008 626.797Z' fill='white'/%3E%3C/mask%3E%3Cg mask='url(%23mask0_281_20)'%3E%3Cmask id='mask1_281_20' style='mask-type:luminance' maskUnits='userSpaceOnUse' x='0' y='0' width='1787' height='627'%3E%3Cpath d='M833.008 626.797H25.2094C11.3386 626.797 0 615.458 0 601.587V25.1717C0 11.3386 11.3386 0 25.2094 0H786.331H833.008H1770.29C1779.33 0 1786.7 7.37008 1786.7 16.4031V391.975C1786.7 401.008 1779.33 408.378 1770.29 408.378H893.291H883.011C869.367 408.378 858.217 419.528 858.217 433.172V445.984V601.587C858.217 615.458 846.879 626.797 833.008 626.797Z' fill='white'/%3E%3C/mask%3E%3Cg mask='url(%23mask1_281_20)'%3E%3Crect x='-32.8819' y='-86.8916' width='1870.45' height='735.912' fill='%23D5D5D5'/%3E%3C/g%3E%3C/g%3E%3C/svg%3E%0A");
    mask-size: 100%;
    mask-repeat: no-repeat;
    mask-position: center;
    z-index: 1;
}
.footer-top-detail {
    position: absolute;
    width: 100%;
    left: 0;
    bottom: 54px;
    z-index: 2;
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    /* transform: translateX(-84%);
    -webkit-transform: translateX(-84%);
    -moz-transform: translateX(-84%);
    -ms-transform: translateX(-84%);
    -o-transform: translateX(-84%); */
}
.footer-top-detail h3,
.footer-top-detail a {
    grid-column-start: 2;
}
.footer-top-detail h3 {
    font-family: IBM Plex Serif;
    font-weight: 500;
    font-size: 48px;
    line-height: 1.3;
    color: var(--dark-green);
    margin-bottom: 30px;
}
.footer-top-detail a {
    display: inline-block;
    width: max-content;
    padding: 10px 20px;
    font-family: Gantari;
    font-weight: 700;
    font-size: 24px;
    line-height: 1;
    background-color: var(--green);
    color: var(--white);
    border-radius: 30px;
}
.footer-top-detail a:hover {
    color: var(--dark-green);
}
.footer-bottom {
    background-color: var(--green);
    padding-top: 82px;
    padding-bottom: 111px;
    margin-top: 56px;
}
.footer-bottom-title {
    font-family: IBM Plex Serif;
    font-weight: 500;
    font-size: 32px;
    line-height: 1.5;
    color: var(--dark-green);
    margin-top: 0;
    margin-bottom: 35px;
}
.footer-bottom-title:hover {
    color: var(--white);
}
.footer-bottom-title a {
    color: inherit;
    text-decoration: none;
}
.footer-widget-wrap {
    display: grid;
    grid-template-columns: repeat(5, minmax(0, 1fr));
    gap: 66px;
    align-items: center;
    background-color: var(--white);
    border-radius: 20px;
    padding: 18px 68px 30px;
}
.footer-widget-item p {
    font-family: Gantari;
    font-weight: 600;
    font-size: 20px;
    line-height: 1;
    color: var(--dark-green);
    margin-bottom: 15px;
}
.footer-widget-item p.city {
    display: none;
    font-weight: 700;
}
.footer-widget-item p.footer-text1 {
    font-weight: 700;
}
.footer-widget-item a {
    display: flex;
    align-items: center;
    gap: 13px;
    font-family: Gantari;
    font-weight: 500;
    font-size: 20px;
    line-height: 1;
    color: var(--dark-green);
}
.footer-menu-wrap {
    margin-top: 32px;
}
.footer-menu {
    display: flex;
    align-items: center;
    justify-content: flex-end;
    gap: 13px;
}
.footer-menu li a {
    font-family: IBM Plex Serif;
    font-weight: 500;
    font-size: 24px;
    line-height: 2;
    color: var(--dark-green);
}
.footer-menu li a:hover {
    color: var(--white);
}
.footer-widget-wrap {
    padding: 20px 42px 37px;
}
.footer-menu-wrap {
    margin-top: 28px;
}
.footer-menu-wrap.has-slogan {
    display: flex;
    align-items: center;
    justify-content: space-between;
}
.footer-slogan-wrap > p {
    font-family: IBM Plex Serif;
    font-weight: 500;
    font-size: 24px;
    line-height: 2;
    color: #034732;
    margin: 0;
}
.ab-footer-fixed {
    position: fixed;
    top: 62%;
    right: 0;
    width: 247px;
    padding: 34px 43px;
    border-radius: 100px;
    background-color: var(--green);
    transform: translateX(135px);
    -webkit-transform: translateX(135px);
    -moz-transform: translateX(135px);
    -ms-transform: translateX(135px);
    -o-transform: translateX(135px);
    transition: all 0.3s ease;
    z-index: 999;
}
.ab-footer-fixed:hover {
    transform: translateX(110px);
    -webkit-transform: translateX(110px);
    -moz-transform: translateX(110px);
    -ms-transform: translateX(110px);
    -o-transform: translateX(110px);
}
/* end Footer */