body{
    color:var(--dark) !important;
}

body #ul-global-nav {
    z-index: 999 !important;
}

/* Header */

#header {
    color:#000;
    background-color:#fff;
    position: relative;
    width:100%;
    left:0;
    top:0;
    z-index:300;
}

#header .ncontain {
    display: flex;
    gap: 1em;
    flex-wrap: wrap;
    align-items: center;
    position: relative;
}

#header .ncsearchform {
    max-width: 144px;
    font-size: var(--txt-small);
    margin-left: auto;
}

#header .header_nav {
    margin-left: 1.5rem;
}



.header_logo {
    display: flex;
    gap:5%;
    align-items: center;
    position: relative;
    z-index: 100;
}

.header_logotext {
    font-size: clamp(12px, 3.5vw, 22px);
    font-weight: 600;
    border-left:solid 1px #D3D3D3;
    display: flex;
    align-items: center;
    height: 35px;
    padding-left: 5%;
    font-family: var(--sans);
}

@media(max-width:1100px){
    .header_nav {
        display: none;
    }
    .header_mnav {
        display: flex;
        margin-left: auto;
    }
    #header {
        border-bottom: 1px solid #AAB4BC;
        box-shadow: 0px 2px 2px 0px #00000014;
    }

    #header .ncsearchform {
        visibility: hidden;
        position: absolute;
        opacity: 0;
        top: 0;
        left: 0;
        width: 100%;
        max-width: 100%;
        font-size: 1em;
        --border: solid 1px #fff;
        --focus-border: solid 1px #fff;
        --focus-dropshadow: none;
        transition:none;

        .ncsearchform_input {
            visibility: visible;
        }

        &.opened {
            visibility: visible;
            top: calc(100% + 1px);
            padding: 5px 1.5em;
            opacity: 1;
            background: #fff;
            margin-left: var(--gapn);
            width: calc(100vw + 3rem);
            box-shadow: 0 3px 3px rgba(0, 0, 0, 0.2);
            max-width: 100vw;
        }
    }
    #header .header_mnav .nc-search.opened:before {
        content:"\e903";
    } 
}

.ul-sticky {
    z-index: 198 !important;
}


/* Mpanel Button Icon */

.header_mnav {
    position: relative;
    right: -0.8em;
}

.mpanel_button .nc-close,
.mpanel_button.opened .nc-menu {
    display: none;
}

.mpanel_button.opened .nc-close {
    display: inline;
}

.mpanel_button,
#header .nc-search {
  width: 48px;
  height: 48px;
  display: flex;
  align-items: center;
  justify-content: center;
  cursor: pointer;
}

/* Mobile Panel */

.mpanel {
    width: 100%;
    padding: 124px 1em 1.5em 4.25em;
    background: #fff;
    z-index: 200;
    height: fit-content;
    bottom: 0;
    overflow-y: auto;
    color: #000;
    font-size: 1em;
    position: absolute;
    transform: translateY(-100%);
    top: 0;
    transition: all 0.3s ease-in-out;
    visibility: hidden;
    box-shadow: 0 0 0 #000;
}

body.admin-bar .mpanel {
    padding-top: calc(124px + 32px);
}

@media(max-width:782px){
    body.admin-bar .mpanel {
        padding-top: calc(124px + 46px);
    }
}

.mpanel_menu {
    list-style-type: none;
    padding-left: 0;
    margin: 0;
    font-weight: bold;

    a {
        display: block;
        padding-bottom: 1.5em;
    }
}

.mpanel_underlay {
    position: fixed;
    top: 0;
    bottom: 0;
    left: 0;
    right: 0;
    z-index: 199;
    /* background: #000; */
    opacity: 0;
    width:100%;
    height:100%;
    visibility: hidden;
    transition:0.5s;
}

/* When the label is clicked, it reveals the mobile panel */

    .mpanel_input:checked + .mpanel {
        transform: translateY(-1px);
        box-shadow: 3px 0 6px rgba(0, 0, 0, 0.3);
        visibility: visible;
    }

    .mpanel_input:checked + .mpanel + .mpanel_underlay {
        opacity: 0.5;
        visibility: visible;
    }

/* WP Header Image */

.wp-bannerimage {
    background-size: cover;
    background-repeat: no-repeat;
    background-position: center top;
    height: 200px;
}

/* Banner */

.banner {
    --padding: clamp(1.5rem, 5%, 3rem);
    min-height: 400px;
    background-color: var(--dark);
    position:relative;
    display:flex;
    align-items:center;

    .ncontain {
      position: relative;
    }
  }

  @keyframes fadeInAnimation {
    0% {
        opacity: 0;
    }
    100% {
        opacity: 1;
    }
  }

  .banner_img {
    background-repeat:no-repeat;
    background-size: cover;
    position:absolute;
    width:100%; height:100%;
    inset:0;
  }

  .banner_img, 
  .banner_textbox {
    animation: fadeInAnimation ease 1s;
    animation-iteration-count: 1;
    animation-delay: 0.5s;
    animation-fill-mode: backwards;
  }

  .banner_textbox {
    animation-delay: 0.75s;
  }

  .banner_textbox {
    
    max-width: 876px;
    padding: var(--padding);
    color: #fff;
    background-color: #585858E0;
    margin-block: var(--padding);

    h1 {
      text-wrap: balance;
    }
  }

  /* Single Banner */

  .banner-single {
    background-color: var(--gray);
    padding-block: var(--padding);
    border-top: solid 1px #CACDCE;

    .ncontain {
        display: grid;
        grid-template-columns: repeat(2, 1fr);
        gap: 0 clamp(1.5em, 10vmin, 3em);
    }

    @media(max-width:1000px){
        .ncontain {
            grid-template-columns:1fr;
        }
    }

    .banner_pretext {
        text-transform: uppercase;
        font-weight: bold;
        color:var(--red);
        margin-bottom: var(--gap);
    }

    .banner_img {
        position: static;
        aspect-ratio: 4 / 3;
        background-position: center;
        order:2;
    }

    .banner_textbox {
        padding: 0;
        margin-block: 0;
        max-width: none;
        display: flex;
        flex-direction: column;
        justify-content: center;
        background-color: transparent;
        color:var(--dark);
        order:1;
    }

  }

/* Share links */

.sharelinks {
    border-top: solid 1px #CACDCE;
    padding-top: 1em;
    font-size: var(--txt-medium);
    display: flex;
    align-items: center;
    gap: 0.25em;
    margin-inline: auto;
    margin-block: 3rem var(--gap);

    .sharelinks_anchor {
        color: var(--red);
        cursor: pointer;
        display: flex;
        align-items: center;
        justify-content: center;
        width: 40px;
        aspect-ratio: 1;
        transition:0.3s;

        &:hover {
            background-color: var(--red);
            color: #fff;
        }
    }

    .sharelinks_label {
        font-weight: bold;
        font-size: var(--txt-small);
    }
}

/* Hide pretext on area heading */

  .maintitle_pretext,
  .maintitle_colon {
    display: none;
  }

/* Mega Footer */

#footer {
    padding: 3rem 0;
    background-color: #494E50;
    color: #fff;
    font-size:1em;

    a {
        transition:0.3s;

        &:hover {
            color:#fff;
        }
    }
}

.footer_columns {
    display:grid;
    gap:var(--gap);
    grid-template-columns: repeat(4, 1fr);

    & > div {
        position: relative;
    }

    @media(max-width:773px){
        grid-template-columns: 1fr;

        & > div {
            text-align: center;
        }
    }


    .footer_select {
        position: relative;

        &:after {
            content: '\25BC';
            transform: scale(2, 1);
            position: absolute;
            right: 1.6em;
            font-size: 0.6em;
            z-index: 10;
            top: 1.6em;
        }
    }

    select {
        background: #000;
        color:#fff;
        max-width: 100%;
        width: 100%;
        border:none;
        border-radius: var(--border-radius);
        font-size: var(--txt-small);
        padding-inline: 1.25em;
    }

    ul {
        list-style-type: none;
        padding-left: 0;
        margin: 0;

        li {
            margin-bottom: var(--gap);
        }

        a {
            color: #eee;

            &:hover {
                text-decoration: underline;
                color: #fff;
            }
        }
    }
}

@media(max-width:773px){
    .wwwulcom-footer-logo {
        margin-inline: auto;
    }
}

#ul-global-footer .wwwulcom-wrapper {
    margin-inline: auto !important;
    max-width: calc(1440px + 6rem) !important;
    padding-inline: var(--gap) !important;
}


/* Remove Theme Translation Notice */

.wpml-ls-statics-post_translations.wpml-ls,
.wpml-ls-statics-footer,
.otgs-development-site-front-end {
    display: none;
}

img[width="1"] {
    position: absolute;
    left:0;
    top:0;
}


/* Seminar Footer on Archive Page */

.seminarfooter {
    padding-block: clamp(3rem, 5vmin, 6rem);
    background: var(--gray);
    width: 100% !important;
    max-width: 100% !important;

    .ncontain {
        display: flex;
        gap: 1.5rem clamp(1.5rem, 5vmin, 3rem);
        align-items: center;

        & > * {
            width:50%;
        }
    }

    .seminarfooter_image {
        align-self: center;
        display: block;
        aspect-ratio: 4/2.5;
        object-fit: cover;
        max-width: 664px;
    }

    .seminarfooter_content {

        & > :last-child {
            margin-bottom: 0;
        }
    }

    @media(max-width:840px){
        .ncontain {
            flex-direction: column;
            
            & > * {
                max-width: 500px;
                width: 100%;
            }
        }
    }
}

/* Featured Footer Content for Featured Archive page */

.featuredfooter {
    padding-block: clamp(3rem, 5vmin, 6rem);
    background: var(--gray);
    width: 100% !important;
    max-width: 100% !important;

    .featuredfooter_heading {
        margin-bottom: 1em;
    }
    
    .ncontain {
        display: flex;
        gap: clamp(var(--gap), 5vmin, 3rem);

        & > div {
            width: 100%;
            max-width: 500px;
            flex-grow: 1;
            margin-inline: auto;
        }
        & > div :first-child {
            margin-bottom: 0.5rem;
        }
    }

    @media(max-width:900px){
        .featuredfooter_heading {
            margin-inline: auto;
            max-width:500px;
        }
        .ncontain {
            flex-direction: column;
        }
    }

}

/* Audio / Video Player */

.mejs-container {
    max-width: 100% !important;
}

.ncontent_main > .mejs-container,
.wp-video {
    max-width: var(--width-standard) !important;
    width: var(--width-limit) !important;
    margin-bottom: var(--gap);
}


/* Yoast breadcrumbs */

.yoast-breadcrumbs {
    font-size: var(--txt-small);
    padding-block: 0.7em;
    margin-bottom: clamp(var(--gap), 6vmin, 3rem);
    white-space: nowrap;
    text-overflow: ellipsis;
    overflow: hidden;
    background: var(--gray);
    border-block: solid 1px #CACDCE;

    .ncontain > span {
        display: flex;
        gap: 1em;
        align-items: center;
    }

    .ncicon {
        font-size: 9px;
    }

    .breadcrumb_last {
        white-space: nowrap;
        text-overflow: ellipsis;
        overflow: hidden;
    }
}

.yoast-breadcrumbs a {
    color: var(--red);
    font-weight: inherit;

    &:hover {
        text-decoration: underline;
    }
}

/*
.yoast-breadcrumbs .breadcrumb_last { 
    position: absolute;
    width: 1px;
    height: 1px;
    padding: 0;
    margin: -1px;
    border: 0;
    clip: rect(0 0 0 0);
    overflow: hidden;
}
*/


/* Main Body Content Layout */

body:is(.blog, .archive, .search) .ncontent_main > * {
    max-width: var(--width-wide);
}

body:not(.page-template-blank) .ncontent {
    margin-block: clamp(2rem, 6vmin, 3rem) 0;
}

.ncontent_main > * {
    width: var(--width-limit);
    max-width:var(--width-standard);
    margin-inline:auto;
}

.ncontent_main > .alignwide {
    max-width:var(--width-wide);
}

.ncontent_main > .alignmax {
    max-width: var(--width-max);
}

.ncontent_main > .alignfull {
    max-width:100%;
    width:100%;
}

/* Link colors */

.ncontent_main p a:not([class]),
.ncontent_main li a:not([class]) {
    text-decoration:none;
    transition:0.3s;
    position:relative;
    color: var(--red);
    border-bottom: solid 1px;
}

.ncontent_main p a:not([class]):hover,
.ncontent_main li a:not([class]):hover { 
    text-decoration:none; 
    color: #000;
}

/*
.ncontent_main p a:not([class]),
.ncontent_main li a:not([class]) { 
    text-decoration:none; 
    transition:0.3s; 
    position:relative; 
    font-weight: 500;
}

.ncontent_main p a:not([class]):after,
.ncontent_main li a:not([class]):after { 
    content:''; 
    height:1px; 
    background: currentColor; 
    width:100%;
    transition:0.5s; 
    display:block; 
    position:absolute;
    bottom:0;
    left:0;
}

.ncontent_main p a:not([class]):hover:after,
.ncontent_main li a:not([class]):hover:after { 
    width:0;
}

.ncontent_main p a:not([class]):hover,
.ncontent_main li a:not([class]):hover {
    color:currentColor
}
*/

/* Misc Needed to pass test */

.sticky,
.gallery-caption,
.bypostauthor{
    cursor:inherit;
 }

.featuredimage  {
    margin-bottom:1.5em;
}


.ncurrentpage{
    text-align: right;
}

/* Card Listings */

.lcard_box {
    display:grid;
    gap: clamp(1.5rem, 5vmin, 3rem);
    grid-template-columns: repeat(4, 1fr);
    margin-bottom: 1.5rem;

    @media(max-width:1260px){
        grid-template-columns: repeat(2, 1fr);
    }
    @media(max-width:800px){
        grid-template-columns: 1fr;
    }
}

.lcard.events .lcard_text {
    position: relative;
  }
  
  .lcard_event {
    display: block;
    position: absolute;
    bottom: 100%;
    width: 100px;
    z-index: 20;
    background: #fff;
    border-radius: 8px 8px 0 0;
    padding: 0.75em 0;
    text-align: center;
    border: solid 1px #ccc;
    border-bottom: 0;
  }
  
  .lcard_eventday {
    font-size: 22px;
    font-weight: bold;
    color: var(--red);
    text-transform: uppercase;
    line-height: 1;
    display: block;
  }
  
  .lcard_eventdate {
    font-size: 11px;
    font-weight: bold;
    white-space: nowrap;
    display: block;
    margin-top: 0.3em;
  }
  
  .lcard_eventtype {
    color: var(--red);
    text-transform: uppercase;
    font-size: 11px;
    font-weight: bold;
    display: block;
    margin-bottom: 1em;
  }

.lcard {
    --card-padding: 0;
    --card-margin-bottom:3em;
    --card-bg-color: #fff;
    --card-bg-color-hover: #fff;
    --card-flex-direction: column;
    --card-border: none;
    --card-border-hover: none;
    --card-bshadow: none;
    --border-radius: 5px;
    --pretext-color:currentColor;
    --image-width: 30%;
    --image-height: 50%;
    --text-padding: 1.5em;
    --text-size: 1em;
    --text-color: #000;
    --text-color-hover: #000;
    --trans-speed: 0.3s;
    }
    
    .lcard { 
      width:100%; 
      max-width:100%; 
      position:relative; 
     }
    
    .lcard_link {
    text-decoration:none;
    color:inherit;
    display:block;
    }
    
    .lcard_container {
    display:flex;
    position:relative;
    background:var(--card-bg-color);
    padding:var(--card-padding);
    flex-direction:var(--card-flex-direction);
    border:var(--card-border);
    box-shadow:var(--card-bshadow);
    transition:var(--trans-speed);
    border-radius: var(--border-radius);
    overflow: hidden;
    }
    
    .lcard:hover .lcard_container {
    background:var(--card-bg-color-hover);
    border:var(--card-border-hover);
    }
    
    .lcard_image {
    flex-basis:var(--image-width);
    min-width:var(--image-width);
    overflow:hidden;
    background-color: #eee;
    }
    
    .lcard_imgcon {
      padding-top:var(--image-height);
      width:100%;
      height:var(--image-height);
      min-height:100%;
      display:block;
      position:relative;
    }
    
    .lcard_img {
      position:absolute;
      object-fit:cover;
      top:0; left:0;
      display:block;
      width:100%;
      height:100%;
      transform:scale(1);
      transition:var(--trans-speed);
    }
    
    .lcard:hover .lcard_img {
      transform:scale(1.2);
    }
    
    .lcard_text {
    display:flex;
    flex-grow:1;
    flex-direction:column;
    justify-content:center;
    font-size:var(--text-size);
    color:var(--text-color);
    padding:var(--text-padding);
    transition:var(--trans-speed);
    min-width: 0; /* This is needed if you use truncated content within a flexbox */
    }
    
    .lcard:hover .lcard_text {
    color:var(--text-color-hover);
    }

    /* Customized for all listings except news */

    .lcard {
        --border-radius: 0;
        --card-border: solid 1px #ccc;
        --card-border-hover: solid 1px #000;
        --text-padding: 1.5rem;
        max-width: 500px;
        margin-inline: auto;
        }
        
        .lcard_text {
        min-height: 210px;
        }
        
        .lcard_desc {
        flex-grow: 1;
        }
        
        .lcard_rmore {
        display:none;
        }
        
        .lcard_title {
        font-size: var(--txt-medium);
        font-weight: 600;
        margin-bottom: 1em;
        display: -webkit-box;
        -webkit-line-clamp: 3;
        -webkit-box-orient: vertical;
        overflow: hidden;
        }
        
        .lcard_desc {
        font-size: var(--txt-small);
        }
        
        .featured_button {
        text-align: center;
        padding-top:3em;
        }
        
        @media(max-width:800px){
            .lcard_text {
                min-height: 0;
            }
        }
        
        .lcard_date,
        .lcard_readmore {
            display:none;
        }

  /* News Listings (ONLY) */

  body.post-type-archive-news,
  body.post-type-archive-events {

    .lcard {
    --border-radius: 0;
    --card-border: solid 1px #ccc;
    --card-border-hover: solid 1px #000;
    --text-padding: 1.5rem;
    max-width: 500px;
    margin-inline: auto;
    }
    
    .lcard_date {
    order: -1;
    display: flex;
    justify-content: space-between;
    font-size: var(--txt-xsmall);
    margin-bottom:1em;
    text-transform: uppercase;
    color: #666
    }

    .lcard_desc {
        display: none;
    }
    
    .lcard_date:before {
    content: 'News Story';
    font-weight: bold;
    color: var(--red);
    }
    
    .lcard_text {
    min-height: 210px;
    justify-content: start;
    }
    
    .lcard_desc {
    flex-grow: 1;
    }
    
    .lcard_rmore {
    display:none;
    }
    
    .lcard_title {
    font-size: var(--txt-medium);
    font-weight: 400;
    margin-bottom: 1em;
    display: -webkit-box;
    -webkit-line-clamp: 4;
    -webkit-box-orient: vertical;
    overflow: hidden;
    }
    
    .featured_button {
    text-align: center;
    padding-top:3em;
    }
    
    @media(max-width:800px){
    .lcard_text {
    min-height: 0;
    }
    }

}

html[lang="de-DE"] {
    .lcard_date:before {
        content: 'Geschichte';
    }
}

.lcard_box-upcoming .lcard_date {
    display: none !important;
}

.lcard_box-archives {

    .lcard_event {
        bottom: calc(100% + -41px);
        width: auto;
        background: transparent;
        padding: 0;
        border: none;
        color: #999;
        right: var(--gap);
        text-transform: uppercase;
    }

    .lcard_eventday,
    .lcard_date {
        display: none !important;
    }
}
  
  
/* Single Event Banner */

.event_details {
    position: relative;
    color: #fff;
    background: var(--dark);
    padding: 0.7em 1em;
    display: inline-block;
    width: fit-content;
    text-transform: uppercase;
    font-size: var(--txt-small);
    letter-spacing: 1px;
    
    .lcard_event,
    .lcard_event *,
    .lcard_eventtype {
        all:revert;
    }

    .lcard_eventday:after {
        content:', ';
    }

    .lcard_event:before {
        content:'Starts:';
        font-weight:bold
    }

    .lcard_eventtype {
        display:none;
    }
}


  /* Site Pagination */
  
  .pagination {
    --pgbgcolor:var(--gray);
    --pgtextcolor:#222;
  
    --pgbgcolor-hover:var(--red);
    --pgtextcolor-hover:#fff;
  
    --pgbgcolor-current:#222;
    --pgtextcolor-current:#fff;
  
    --pgradius:0;
    --pgbordercolor:#eee;
  }
  
  .pagination {
    position: relative;
    display: flex;
    justify-content: flex-end;
    margin-block:3rem;
  }
  
  .pagination .page-numbers {
    padding: 0.5em;
    border-radius: var(--pgradius);
    text-align: center;
    background-color: var(--pgbgcolor);
    margin: 0.25em;
    font-weight: bold;
    width: 3em;
    border:solid 1px var(--pgbordercolor);
    transition: .3s;
  }
  
  .pagination .page-numbers:first-child {
    margin-left: 0;
  }
  
  .pagination .page-numbers:last-child {
    margin-right: 0;
  }
  
  .pagination .page-numbers.dots {
    cursor: default;
  }
  
  .pagination .page-numbers:hover:not(.dots):not(.current) {
    background-color: var(--pgbgcolor-hover);
    color: var(--pgtextcolor-hover);
    border:solid 1px var(--pgbgcolor-hover);
  }
  
  .pagination a.page-numbers {
    color: var(--pgtextcolor);
  }
  
  .pagination_prev:before {
    content: '\2190';
  }
  
  .pagination_next:before {
    content: '\2192';
  }
  
  .pagination .page-numbers.current {
    background-color: var(--pgbgcolor-current);
    color: var(--pgtextcolor-current);
    border:solid 1px var(--pgbgcolor-current);
    cursor: default;
  }

/* Login */

#login-holder {
    position: absolute;
    right: 0;
    max-width: calc(100% - 0.2rem);
    width: 900px;
    top: 100%;
    font-size: var(--txt-small);
    background: #fff;
    box-shadow: 0 3px 6px rgba(0,0,0,0.3);
    padding: 2em;
    border:solid 1px #ccc;
    transition: 0.5s;
    opacity: 0;
    visibility: hidden;
    transform: scale(1, 0);
    transform-origin: top center;

    &.open {
        opacity: 1;
        visibility: visible;
        transform: scale(1, 1);
    }

    .language-selector, 
    .btn-login {
        display: none;
    }

    .row.align-items-start {
        display: flex;
        gap:clamp(2em,5vw,9em);
        position: relative;
    }

    .login-modal-close {
        position: absolute;
        right:0;
        top:0;
        z-index: 10;
        cursor: pointer;
        font-size:0.7em;
        font-weight: bold;
        color:var(--red);
        display: flex;
        align-items: center;
        background: none;
        border:none;

        span + .fa:after {
            content:'\e903';
            font-family: 'ncicons';
            font-style: normal;

            display: inline-block;
            margin-left: 0.25em;
        }
    }

    .field.submit-field {
        margin-block: 1em;
    }

    .login-title, .join h3 {
        font-size: var(--txt-medium);
    }

    .join {

        .btn { 
            background-color: #000;
        }
        
        .btn:hover { 
            background-color: var(--red);
        }
    }

    .col-md-4 {
        flex-basis: 35%;
        margin-top: 3.5em;
    }

    .col-md-8 {
        flex-basis: 65%;

        a {
            text-decoration: none;
            color: var(--red);
            
            &:hover {
                color:var(--link-color);
                text-decoration: underline;
            }
        }

    }

    @media(max-width:547px){
        .row.align-items-start {
            flex-direction: column;
        }
        .row.align-items-start > div {
            flex-basis: auto;
        }
    }

    input {
        font-size: var(--txt-small);
    }

    input:not([type='submit']) {
        width: 100%;
    }

    .validation-error {
        font-size: 0.7em;
        margin-bottom: 1em;
    }
}

