/*
Theme Name: Nachsuche Mitteldeutschland
Theme URI: https://elementor.com/hello-theme/?utm_source=wp-themes&utm_campaign=theme-uri&utm_medium=wp-dash
Template: hello-elementor
Author: Elementor Team
Author URI: https://elementor.com/?utm_source=wp-themes&utm_campaign=author-uri&utm_medium=wp-dash
Description: Hello Elementor is a lightweight and minimalist WordPress theme that was built specifically to work seamlessly with the Elementor site builder plugin. The theme is free, open-source, and designed for users who want a flexible, easy-to-use, and customizable website. The theme, which is optimized for performance, provides a solid foundation for users to build their own unique designs using the Elementor drag-and-drop site builder. Its simplicity and flexibility make it a great choice for both beginners and experienced Web Creators.
Tags: accessibility-ready,flexible-header,custom-colors,custom-menu,custom-logo,featured-images,rtl-language-support,threaded-comments,translation-ready
Version: 3.2.1.1734420240
Updated: 2025-04-09 12:54:00

*/
:root{
    --color-primary:                    #242419;
    --color-secondary:                  #929270;
    --color-accent-light:               #f9f9f9;
    --color-secondary-transp-80:       #929270DA;
    --color-secondary-transp-60:       #929270DD;

    --text-header-default:              #ffffff;
    --text-headline-color:              var(--e-global-color-primary);
    --text-footer-color:                #ffffff;
    --border-color-default:             #747452;
    --shadow-color-default:             #878484;
    
    --table-bg-default:                #989875;
    --table-bg-random-child:            #aaaa82;

    --button-default-background:        var(--color-secondary);
    --button-default-color:             var(--text-header-default);
    --button-hover-background:          var(--color-primary);
    --button-hover-color:               var(--background-header-dark);   
    
    
    --header-bg-color:                  var(--color-primary);
    
    --nav-link-color:                   #fff;
    --nav-link-hover-color:              var(--color-secondary);

    /* Container-Maximalbreite Ã¢â‚¬â€œ je Breakpoint in den Media Queries gesetzt */
    --container-max:                    none;
}

body{
    width:100%;     
    font-size:18px;
    color:var(--e-global-color-text);
    font-family: "Outfit", Sans-serif; 
    font-weight:400;
    letter-spacing: 1px;
    overflow: hidden;    
}
.wrapper{
    max-width:100%;
    margin:0 auto;
    padding:0;
    overflow-x: hidden;
    overflow-y:auto;
    height: 100vh;
}

header, footer{
    background-color: var(--header-bg-color);    
}

header.site-header{
    position: fixed;
    width: 100vw;
    z-index: 2500;
}

header a,
footer a, 
.site-header .site-navigation ul.menu li a{
    color:var(--nav-link-color);
}
 
header a:hover,
footer a:hover,
.site-header .site-navigation ul.menu li a:hover{
    color:var(--nav-link-hover-color);
}

main{
    min-height: calc(100vh - 250px);
    display: flex;
    flex-direction: column;
    justify-content: center; 
    margin-top: 120px; 
    
}
main, main p{
    font-family: "Roboto Flex", Sans-serif;
    font-size: 18px;
    font-weight:400;
}

.tips p{font-size:12px; line-height:1.0}

table, table th.gridjs-th, 
table .gridjs-tbody, 
table td.gridjs-td, 
.gridjs-container .gridjs-footer,
.gridjs-container input.gridjs-input {
    background-color: var(--color-secondary);
    color: var(--color-primary);
}
.gridjs-container td.gridjs-td, 
th.gridjs-th, .gridjs-container input.gridjs-input {
    border-color: var(--border-color-default) !important;
}


.page-content .um a.um-button, 
.page-content .um a.um-button.um-disabled:active, 
.page-content .um a.um-button.um-disabled:focus, 
.page-content .um a.um-button.um-disabled:hover, 
.page-content .um input[type="submit"].um-button, 
.page-content .um input[type="submit"].um-button:focus,
.gridjs-container th.gridjs-th-sort:focus, 
.gridjs-container th.gridjs-th-sort:hover,
.gridjs-container .gridjs-pagination .gridjs-pages button:disabled, 
.gridjs-container .gridjs-pagination .gridjs-pages button:hover:disabled, 
.gridjs-container .gridjs-pagination .gridjs-pages button[disabled],
.gridjs-container .gridjs-pagination .gridjs-pages button.gridjs-currentPage,
.gridjs-container .gridjs-pagination .gridjs-pages button
{
    background-color: var(--color-primary);
    color: var(--color-secondary);
}

.gridjs-container .gridjs-pagination .gridjs-pages button.gridjs-currentPage{
    color:var(--nav-link-color)
}

.gridjs-container .gridjs-pagination .gridjs-pages button:hover{
    background-color: var(--color-secondary);
}

table .gridjs-tbody, table td.gridjs-td{
    background-color: var(--table-bg-default);
}

table tbody > tr:nth-child(2n+1) > td, table tbody > tr:nth-child(2n+1) > th {
    background-color: var(--table-bg-random-child);
}

input[Type="text"],
input[type="number"],
input[type="password"],
input[type="search"],
input[type="tel"], 
.page-content .select2-container .select2-choice, 
.page-content .select2-container-multi 
.page-content .select2-choices, 
.page-content .um .um-form input[type="number"], 
.page-content .um .um-form input[type="password"], 
.page-content .um .um-form input[type="search"], 
.page-content .um .um-form input[type="tel"], 
.page-content .um .um-form input[type="text"], 
.page-content .um .um-form textarea{
    background-color: var(--color-secondary);
    color:var(--color-primary);
    border-color:var(--border-color-default);
}

.page-content .um .um-field-label{
    color: var(--nav-link-color);
}

.page-content .um .um-button.um-alt, .page-content .um input[type="submit"].um-button.um-alt {
    background: var(--color-secondary);
    color:var(--color-primary)
}

.page-content .um a.um-button:hover, .page-content .um input[type=submit].um-button:hover {
    background-color: var(--color-secondary-transp-60);
    color:var(--color-primary)
}

a, .current_page_item a, .site-header .site-navigation ul.menu li.current_page_item a{
    color: var(--color-secondary);
}
#skip-link{font-size: 10px;color: var(--e-global-primary);}
#skip-link svg{width: 120px;font-weight:100;}

h1, .elementor-widget-heading h1.elementor-heading-title,
h2, .elementor-widget-heading h2.elementor-heading-title,
h3, .elementor-widget-heading h3.elementor-heading-title,
h4, .elementor-widget-heading h4.elementor-heading-title {
    font-family: 'outfit', Sans-serif;
    text-transform: uppercase;
}

h1, .elementor-widget-heading h1.elementor-heading-title{    
    font-weight:600;
    font-size:24px;
}
h2, .elementor-widget-heading h2.elementor-heading-title{
    font-weight: 600;
    font-size:22px;
}
h3, .elementor-widget-heading h3.elementor-heading-title{
    font-weight: 500;
    font-size:22px;
}
h4, .elementor-widget-heading h4.elementor-heading-title{
    font-weight: 500;
    font-size:22px;
}

h1, 
h2, 
h3, 
h4,
.elementor-widget-heading .elementor-heading-title{
    color: var(--text-headline-color) !important;
    margin-bottom: .25em;
}
.welcome-jumbo{text-align: center;}
.welcome-jumbo .elementor-widget-heading h1.elementor-heading-title{ font-size: 80px;line-height: 110px; font-weight: 900; letter-spacing: 10px; }
.site-footer-default{padding:1em 0;}
.elementor-widget-button .elementor-button{    
    padding: 1em 3em;
    background-color: var(--button-default-background);
}

.elementor-widget-button .elementor-button:hover{
    background-color: var(--button-hover-background);
}

.content-block-round, .elementor-widget-button .elementor-button{
    border-radius: .5em;
}

.footer-inner{
    margin: 0 auto;
    display: flex;
    flex-direction: row;
    justify-content: space-between;
    gap: .5em;
}

.footer-column{
    flex:1 0 0%;
}

/* Gemeinsame Container-Maximalbreite Ã¢â‚¬â€œ Wert je Breakpoint ÃƒÂ¼ber --container-max */
.page-header .entry-title,
.site-footer .footer-inner,
.site-footer:not(.dynamic-footer),
.site-header .header-inner,
.site-header:not(.dynamic-header),
body:not([class*="elementor-page-"]) .site-main,
.footer-inner{
    max-width: var(--container-max);
}

.footer-contact .row{
    display: flex;
    flex-direction: row;
    gap: .5em;
}

/* ===== BeitragsÃƒÂ¼bersicht ===== */
.beitragsuebersicht{
    justify-content: flex-start;
    padding: 2em 1em 3em;
}

.beitragsuebersicht .page-header{
    margin-bottom: 2em;
}

.beitragsuebersicht .page-header .entry-title{
    color: var(--text-header-default) !important;
    text-transform: uppercase;
    letter-spacing: 2px;
    margin-bottom: .3em;
}

.beitragsuebersicht__intro{
    color: #cfcec2;
    font-size: 1.05em;
    max-width: 65ch;
}

.beitragsuebersicht__intro p{
    margin: 0;
}

/* Desktop & Tablet: 2 Spalten */
.beitrag-grid{
    display: grid;
    grid-template-columns: repeat(2, 1fr);
    gap: 2em;
}

/* Karte: Bild links, Inhalt rechts (dunkel) */
.beitrag-card{
    display: flex;
    background: var(--color-secondary-transp-60);
    border: 1px solid var(--color-secondary-transp-80);
    border-radius: .6em;
    overflow: hidden;
    transition: box-shadow .2s ease, transform .2s ease, border-color .2s ease;
    padding: 1em;
}

.beitrag-card:hover{
    box-shadow: 0 .6em 1.6em rgba(0, 0, 0, .4);
    transform: translateY(-3px);
    border-color: rgba(255, 255, 255, .22);
}

.beitrag-card__thumb{
    flex: 0 0 42%;
    display: block;
    overflow: hidden;
    background: rgba(0, 0, 0, .25);
    border-radius: .5em;
}

.beitrag-card__thumb img{
    width: 100%;
    height: 100%;
    object-fit: cover;
    display: block;
}

.beitrag-card__body{
    flex: 1 1 auto;
    display: flex;
    flex-direction: column;
    gap: .6em;
    padding: 0 1.4em;
}

h2.beitrag-card__title{
    margin: 0;
    font-size: 1.35em;
    line-height: 1.25;
}

.beitrag-card__title-link{
    color: #ffffff;
    text-decoration: none;
}

.beitrag-card__title-link:hover{
    color: var(--color-secondary);
}

.beitrag-card__excerpt{
    flex: 1 1 auto;
    color: var(--button-default-color);
    font-size: .92em;
    line-height: 1.5;
}

.beitrag-card__excerpt p{
    margin: 0;
}

.beitrag-card__more{
    align-self: flex-start;
    margin-top: .2em;
    color: #c4c4a4;
    font-weight: 600;
    letter-spacing: .5px;
    text-decoration: none;
    background-color: var(--color-primary);
    padding: .25em 1em;
    border-radius: .25em;
}

.beitrag-card__more:hover{
    color: #ffffff;
    background-color: var(--color-secondary);
}

/* Paginierung */
.beitrag-pagination{
    margin-top: 2.5em;
}

.beitrag-pagination__list{
    display: flex;
    flex-wrap: wrap;
    justify-content: center;
    gap: .5em;
    list-style: none;
    margin: 0;
    padding: 0;
}

.beitrag-pagination__item .page-numbers{
    display: inline-block;
    padding: .5em .9em;
    border: 1px solid rgba(255, 255, 255, .2);
    border-radius: .35em;
    text-decoration: none;
    color: #dedede;
    line-height: 1;
}

.beitrag-pagination__item .page-numbers.current,
.beitrag-pagination__item .page-numbers:hover{
    background: var(--color-secondary);
    color: var(--color-primary);
    border-color: var(--color-secondary);
}

.beitrag-empty{
    text-align: center;
    padding: 2em 0;
    color: #cfcec2;
}

@media (max-width: 576px) {
    :root{ --container-max: 500px; }

    /* Handy: Karte gestapelt (Bild oben) */
    .beitrag-grid{
        gap: 1.5em;
    }
    .beitrag-card{
        flex-direction: column;
    }
    .beitrag-card__thumb{
        flex: 0 0 auto;
        width: 100%;
        aspect-ratio: 16 / 9;
    }
    
    .footer-inner{flex-direction: column;}
    #menu-footermenue{
        flex-direction:column;
        width:100%;
    }

    #menu-footermenue a{
        width:100%;
        text-align:center;
        margin-bottom:.25em;
        border:solid 1px var(--border-color-default);
        border-radius:.25em;
        background-color:var(--color-secondary);
    }

    #menu-footermenue a:hover{
        background-color:var(--color-primary);
    }
}

@media (max-width: 768px) {
    :root{ --container-max: 600px; }
    .welcome-jumbo .elementor-widget-heading h1.elementor-heading-title{font-size: 2.7em;}
}

@media (max-width: 992px) {
    :root{ --container-max: 900px; }

    /* Tablet: 1 Spalte, Karte bleibt horizontal */
    .beitrag-grid{
        grid-template-columns: 1fr;
    }

    h1, .elementor-widget-heading h1.elementor-heading-title,
    h2, .elementor-widget-heading h2.elementor-heading-title,
    h3, .elementor-widget-heading h3.elementor-heading-title,
    h4, .elementor-widget-heading h4.elementor-heading-title{font-size:22px;}
    main, main p{font-size:14px;}    
}

@media (max-width: 1024px){
    .site-header .header-inner,
    .footer-inner{
        padding-left:1em;
        padding-right: 1em;
    }

    .footer-column{flex: 1 0 48%;}
    .footer-inner{flex-wrap:wrap; justify-content:center;}
    .footer-column .site-navigation{
        justify-content:center;
    }
}

@media (min-width: 1024px){
    footer{
        position: fixed;
        bottom:0;
        z-index:500;
        width:100vw;
        height: 150px;
    }
    
    main#content{
        margin-bottom: 90px;
    }
}

@media (min-width: 1200px) {
    :root{ --container-max: 1140px; }
    footer{
        height:80px
    }  
    
}