/* =====================================================================
   WOMBACH.CSS - Hauptstylesheet für wombach.de
   =====================================================================
   Zusammengeführt aus:
     - screen.css            (Basis-Layout, Typografie, Responsive)
     - cookie-banner.css     (Cookie-Banner v2.1)
     - container_justify.css (iframe-Container)
     - modern-zoom.css       (Bildzoom-Modal)
     - smooth_scrolling_Navigation.css (Navigation, Scroll, Seiten-Elemente)
     - global-optimized.css  (Dropdown-Fix)
	 - Trennstrich 			  Skript in kirche.html und folgende
							  und in Gottesdienste.html
   Erstellt: 20.04.2026
   ===================================================================== */
@charset "UTF-8";


/* =====================================================================
   1. BASIS-RESET & TYPOGRAFIE  (aus screen.css)
   ===================================================================== */

* {
    margin: 0;
    padding: 0;
}

html {
    font-size: 75%;
    scroll-behavior: smooth;
}

html>body {
    font-size: 12px;
}

body {
    background: #111111 url(https://wombach.de/images/site-bg-schwarz.jpg) repeat-x;
    text-align: center;
    font-family: Arial, Tahoma, Verdana, sans-serif;
    color: #000000;
}

a:link {
    color: #404040;
    text-decoration: none;
}

a:visited {
    color: #404040;
    text-decoration: none;
}

a:hover {
    text-decoration: underline;
}

a img {
    border: none;
}

a:focus {
    outline: none;
}

p {
    font: 1em/1.5em Arial, Tahoma, Verdana, sans-serif;
    margin-bottom: 1.5em;
}

h1 {
    font: 1.67em/0.9em Arial, Tahoma, Verdana, sans-serif;
    margin-top: 0.9em;
    margin-bottom: 0.9em;
}

h2 {
    font: 1.5em/1em Arial, Tahoma, Verdana, sans-serif;
    margin: 1.5em 0 1em 0;
    color: #193452;
}

h3 {
    font: 1em/1.3em Arial, Tahoma, Verdana, sans-serif;
    color: #193452;
    font-weight: bold;
    margin-bottom: -0.5em;
}

h4 {
    font: 1.17em/1.29em Arial, Tahoma, Verdana, sans-serif;
    margin-top: 1.29em;
    margin-bottom: 1.29em;
}

h5 {
    font: 3.0em/1em Arial, Tahoma, Verdana, sans-serif;
    margin: 1.0em 0 0em 2;
    color: #193452;
    padding-left: 40px;
}


/* =====================================================================
   2. LAYOUT  (aus screen.css)
   ===================================================================== */

#wrapper {
    background: #fff;
    text-align: left;
    width: 960px;
    margin: 0 auto;
}

#meta-information {
    clear: both;
    color: #fff;
    height: 160px;
}

/* Header-Bild (Jahreszeit austauschen):
   #060606 url(https://wombach.de/images/bg-header-wombach-fruehling-februar.jpg)   zeitiges Frühjahr
   #060606 url(https://wombach.de/images/bg-header-wombach-fruehling-4-1.jpg)       bevorzugt
   #060606 url(https://wombach.de/images/bg-header-wombach-fruehling-4.jpg)
   #060606 url(https://wombach.de/images/bg-header-wombach.jpg)                     Sommer
   #060606 url(https://wombach.de/images/bg-header-wombach-herbst2.jpg?v=1240)
   #060606 url(https://wombach.de/images/bg-header-wombach-winter2.jpg?v=1236)
*/
#meta-information h1 {
    background: #060606 url(https://wombach.de/images/bg-header-wombach-fruehling-4-1.jpg) no-repeat top left;
    font-size: 0;
    height: 150px;
}

#meta-information h1 a {
    display: block;
    height: 160px;
    width: 960px;
    border: none;
}

#meta-information h1 span {
    display: none;
}

#smoothmenu1 {
    float: left;
    clear: both;
    width: 890px;
    height: 32px;
    background: #767676 url(https://wombach.de/images/bg-navi1.jpg) bottom left repeat-x;
    font: 1em/1.5em Arial, Tahoma, Verdana, sans-serif;
    text-shadow: #666 2px 2px 4px;
}

#contentgutter {
    width: 910px;
    float: left;
    border: 25px solid #FFF;
    background: #767676 url(https://wombach.de/images/bg-gutter.gif) repeat-y;
}

#contentgutter p {
    text-align: justify;
}

#contentgutter ul {
    font: 1em/1.5em Arial, Tahoma, Verdana, sans-serif;
    margin: 1.5em 20px;
}

#contentgutter li {
    list-style-type: square;
}

.hauptinhalt {
    float: left;
    width: 652px;
    min-height: 710px;
    padding-bottom: 50px;
    background: url(https://wombach.de/images/bg-col1.gif) no-repeat bottom left;
}

.hauptinhalt2 {
    float: left;
    width: 652px;
    min-height: 850px;
    padding-bottom: 50px;
    background: url(https://wombach.de/images/bg-col1.gif) no-repeat bottom left;
}

.hauptinhaltblock {
    float: left;
    width: 652px;
    padding-bottom: 25px;
}

/* Notizen-Container (Jahreszeit-Bild austauschen):
   url(https://wombach.de/images/dorfbrunnen5.jpg)             Sommer
   url(../images/brunnen-herbst_236x236.jpg?v=1241)
   url(https://wombach.de/images/brunnen-winter-muetze_236x236-2.jpg?v=1235)
   url(https://wombach.de/images/brunnen-fasching_236x236-2.jpg)
   url(https://wombach.de/images/brunnen-ostern_236x236.jpg)
*/
.notizen {
    float: right;
    width: 236px;
    height: auto;
    padding-top: 230px;
    margin: 0 0 25px 0;
    background: url(https://wombach.de/images/dorfbrunnen5.jpg) no-repeat top center;
    overflow: visible;
}

.notizenblock {
    float: right;
    width: 95%;
    max-width: 236px;
    height: auto;
    min-height: 250px;
    padding-top: 220px;
    margin: 0 auto 5px auto;
    overflow: visible;
}

.notizenblock:last-child {
    margin-bottom: 0;
}

.notizen,
.notizenblock {
    overflow: visible !important;
    -webkit-overflow-scrolling: auto !important;
}

/* Container 4 (Jahreszeit-Bild austauschen):
   url(https://wombach.de/images/dorfplatz-sommer.jpg?v=2)
   url(https://wombach.de/images/dorfplatz-herbst.jpg?v=4)
   url(https://wombach.de/images/dorfplatz-winter.jpg)
   url(https://wombach.de/images/start-fruehling-2-250x250.jpg?v=1234)
   url(https://wombach.de/images/fasching-start.jpg?v=1235)
   url(https://wombach.de/images/start-kirb.jpg)
   url(https://wombach.de/images/start-weihnachtsmarkt.jpg)
*/
.container4 {
    width: 300px;
    height: 300px;
    float: left top;
    padding-top: 0px;
    background: url(https://wombach.de/images/start-fruehling-2-250x250.jpg?v=1234) no-repeat top center;
}

#footer {
    clear: both;
    margin: 0 25px;
    padding-top: 20px;
}

p {
    font: 1em/1.5em Arial, Tahoma, Verdana, sans-serif;
    margin-top: 1.5em;
    margin-bottom: 1.5em;
    clear: both;
}

h1, .hauptinhalt h2, .hauptinhalt h3, .hauptinhalt h4, .hauptinhalt ul, .hauptinhalt p,
.notizen h2, .notizen h3, .notizen ul, .notizen p,
.hauptinhaltblock h2, .hauptinhaltblock h3, .hauptinhaltblock h4, .hauptinhaltblock ul, .hauptinhaltblock p,
.notizenblock h2, .notizenblock h3, .notizenblock h4, .notizenblock ul, .notizenblock p,
#contentgutter h2 {
    padding: 0 20px;
}

.notizen h2 {
    font: 1em/1.5em Arial, Tahoma, Verdana, sans-serif;
    margin-bottom: 1.5em;
    color: #193452;
    font-weight: bold;
}

.notizen h3 {
    font: 1em/1.5em Arial, Tahoma, Verdana, sans-serif;
    margin-bottom: 1.5em;
    color: #193452;
    font-weight: normal;
}

.bild {
    float: left;
    padding: 5px;
    border: 1px solid #eee;
    margin: 0 18px 18px 0;
}

.elastisches-bild {
    float: left;
    padding: 0.42em;
    border: 0.083em solid #eee;
    margin: 0 1.5em 1.5em 0;
    width: 25em;
    height: 16.7em;
}

#map {
    width: 610px;
    height: 350px;
    margin: 20px;
}

#footer p {
    padding: 0 20px;
    margin: 0;
}

#footer a:link { color: #666; text-decoration: none; }
#footer a:visited { color: #666; text-decoration: none; }
#footer a:hover { text-decoration: underline; }


/* =====================================================================
   3. VEREINE GRID  (aus screen.css)
   ===================================================================== */

.vw-grid {
    width: 100%;
    max-width: 660px;
    margin: 0 auto;
    font-family: Arial, Tahoma, Verdana, sans-serif;
    font-size: 12px;
    color: #000000;
}

.vw-row {
    display: flex;
    align-items: center;
    justify-content: space-around;
    padding: 10px 0;
}

.vw-item {
    display: flex;
    flex-direction: column;
    align-items: center;
    text-align: center;
    flex: 0 0 auto;
    width: 110px;
    gap: 4px;
    text-decoration: none;
    color: #000000;
}

.vw-item img {
    max-width: 90px;
    max-height: 90px;
    object-fit: contain;
}

.vw-item span {
    font-size: 11px;
    line-height: 1.3;
}

.vw-pair {
    display: flex;
    flex-direction: row;
    align-items: flex-end;
    gap: 20px;
}

.vw-center-row {
    display: flex;
    align-items: center;
    justify-content: space-between;
    padding: 10px 0;
}

.vw-center-col {
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 10px;
    padding-left: 15px;
}

.vw-center-col-right {
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 10px;
    align-self: flex-start;
    margin-top: 30px;
}

.vw-qr {
    font-size: 10px;
    line-height: 1.3;
    text-align: center;
    color: #666666;
}


/* =====================================================================
   4. NAVIGATION (ddsmoothmenu CSS-only Dropdown)
      (aus smooth_scrolling_Navigation.css + global-optimized.css)
   ===================================================================== */

.ddsmoothmenu ul li {
    position: relative;
}

.ddsmoothmenu ul li ul {
    position: absolute !important;
    display: none !important;
    left: 0;
    top: 100%;
    background-color: #f9f9f9;
    min-width: 160px;
    box-shadow: 0 8px 16px 0 rgba(0,0,0,0.2);
    z-index: 1000;
    border-radius: 4px;
    visibility: visible !important;
}

.ddsmoothmenu ul li:hover > ul {
    display: block !important;
}

.ddsmoothmenu ul li ul li {
    display: block !important;
    width: 100%;
    float: none !important;
    background-color: #ffffff !important;
}

.ddsmoothmenu ul li ul li a {
    color: #333333 !important;
    padding: 4px 12px !important;
    min-height: 26px !important;
    font-weight: normal !important;
    line-height: 1.2 !important;
    text-decoration: none;
    display: block;
    font-size: 13px;
    border-bottom: 1px solid #eee;
    background-color: #ffffff !important;
}

.ddsmoothmenu ul li ul li a:hover {
    background-color: #f1f1f1 !important;
}

.ddsmoothmenu ul li ul li:last-child a {
    border-bottom: none;
}


/* =====================================================================
   5. SEITEN-ELEMENTE  (aus smooth_scrolling_Navigation.css)
   ===================================================================== */

.page-title {
    font-size: 24px;
    margin-top: 10px;
}

.page-subtitle {
    font-size: 18px;
    margin-top: 0;
}

.back-link {
    display: inline-block;
    margin: 20px 0;
}

.image-credit {
    margin: 20px;
}

.top-link {
    padding: 20px;
}

.copyright-notice,
.gallery-instructions {
    font-size: 10px;
    color: #808080;
    background-color: #f5f5f5;
    margin: 0 30px 0 30px;
    padding: 8px;
    border-radius: 4px;
    text-align: justify;
    line-height: 1.4;
    word-spacing: 0.1em;
}

.gallery-instructions {
    margin-top: 10px;
    margin-bottom: 20px;
}


/* =====================================================================
   6. BILDZOOM MODAL  (aus modern-zoom.css)
   ===================================================================== */

.zoomable {
    cursor: zoom-in;
    transition: all 0.3s cubic-bezier(0.4, 0, 0.2, 1);
    border-radius: 4px;
    box-shadow: 0 2px 8px rgba(0, 0, 0, 0.1);
}

.zoomable:hover {
    transform: scale(1.02) translateZ(0);
    box-shadow: 0 8px 25px rgba(0, 0, 0, 0.15);
    filter: brightness(1.05);
}

.zoomable:active {
    transform: scale(0.98);
    transition: transform 0.1s ease;
}

.zoom-modal {
    display: none;
    position: fixed;
    z-index: 9999;
    left: 0;
    top: 0;
    width: 100%;
    height: 100%;
    background-color: rgba(0, 0, 0, 0.9);
    backdrop-filter: blur(5px);
    cursor: zoom-out;
    opacity: 0;
    transition: opacity 0.3s ease;
}

.zoom-modal.active {
    display: flex;
    justify-content: center;
    align-items: center;
    opacity: 1;
    animation: modalFadeIn 0.3s ease-out;
}

.zoom-modal img {
    max-width: 90%;
    max-height: 90%;
    object-fit: contain;
    border-radius: 8px;
    box-shadow: 0 20px 60px rgba(0, 0, 0, 0.5);
    animation: imageZoomIn 0.4s cubic-bezier(0.25, 0.46, 0.45, 0.94);
    user-select: none;
    -webkit-user-select: none;
    pointer-events: none;
}

.close-btn {
    position: absolute;
    top: 20px;
    right: 30px;
    color: white;
    font-size: 40px;
    font-weight: bold;
    cursor: pointer;
    z-index: 10001;
    text-shadow: 2px 2px 4px rgba(0, 0, 0, 0.7);
    transition: all 0.2s ease;
    user-select: none;
    line-height: 1;
    padding: 5px;
    border-radius: 50%;
    width: 50px;
    height: 50px;
    display: flex;
    align-items: center;
    justify-content: center;
}

.close-btn:hover {
    background-color: rgba(255, 255, 255, 0.1);
    transform: scale(1.1);
    color: #ff6b6b;
}

.close-btn:active {
    transform: scale(0.9);
}

.zoom-info {
    position: absolute;
    bottom: 20px;
    left: 50%;
    transform: translateX(-50%);
    color: rgba(255, 255, 255, 0.7);
    font-size: 14px;
    text-shadow: 1px 1px 2px rgba(0, 0, 0, 0.7);
    pointer-events: none;
    opacity: 0;
    animation: infoFadeIn 0.5s ease 1s forwards;
}

@keyframes modalFadeIn {
    from { opacity: 0; backdrop-filter: blur(0px); }
    to   { opacity: 1; backdrop-filter: blur(5px); }
}

@keyframes imageZoomIn {
    from { opacity: 0; transform: scale(0.7) rotate(5deg); }
    to   { opacity: 1; transform: scale(1) rotate(0deg); }
}

@keyframes infoFadeIn {
    from { opacity: 0; transform: translateX(-50%) translateY(10px); }
    to   { opacity: 1; transform: translateX(-50%) translateY(0); }
}

.zoomable:focus  { outline: 3px solid #007cba; outline-offset: 2px; }
.close-btn:focus { outline: 3px solid white; outline-offset: 2px; }


/* =====================================================================
   7. COOKIE BANNER  (aus cookie-banner.css v2.1)
   ===================================================================== */

.cookie-banner {
    position: fixed;
    bottom: -100%;
    left: 0;
    right: 0;
    margin-left: auto;
    margin-right: auto;
    background: linear-gradient(135deg, #1e3c72 0%, #2a5298 100%);
    color: white;
    padding: 20px;
    box-shadow: 0 -4px 20px rgba(0,0,0,0.3);
    z-index: 999999;
    transition: bottom 0.5s ease-in-out;
    border-top: 3px solid #4a90e2;
    max-width: 965px;
    width: calc(100% - 40px);
    box-sizing: border-box;
    -webkit-transform: translateZ(0);
    transform: translateZ(0);
    -webkit-backface-visibility: hidden;
    backface-visibility: hidden;
}

.cookie-banner.show {
    bottom: 0;
}

@supports (padding-bottom: env(safe-area-inset-bottom)) {
    .cookie-banner.show {
        bottom: env(safe-area-inset-bottom);
        padding-bottom: calc(20px + env(safe-area-inset-bottom));
    }
}

.cookie-content {
    max-width: 965px;
    margin: 0 auto;
    display: flex;
    justify-content: space-between;
    align-items: center;
    gap: 20px;
    -webkit-box-pack: justify;
    -webkit-justify-content: space-between;
    -webkit-box-align: center;
    -webkit-align-items: center;
}

.cookie-text {
    flex: 1;
    -webkit-flex: 1;
    line-height: 1.6;
    font-size: 14px;
}

.cookie-text strong {
    font-size: 16px;
    display: block;
    margin-bottom: 5px;
}

.privacy-link {
    color: #ffd700;
    text-decoration: underline;
    font-weight: bold;
}

.privacy-link:hover { color: #fff; }

.cookie-buttons {
    display: flex;
    display: -webkit-flex;
    gap: 10px;
    flex-shrink: 0;
    -webkit-flex-shrink: 0;
}

@supports not (gap: 10px) {
    .cookie-buttons > * { margin-left: 5px; margin-right: 5px; }
    .cookie-buttons > *:first-child { margin-left: 0; }
    .cookie-buttons > *:last-child  { margin-right: 0; }
}

.cookie-btn {
    padding: 12px 24px;
    border: none;
    border-radius: 6px;
    cursor: pointer;
    font-size: 14px;
    font-weight: 600;
    transition: all 0.3s ease;
    white-space: nowrap;
    -webkit-tap-highlight-color: transparent;
    touch-action: manipulation;
}

.cookie-btn.accept  { background: #28a745; color: white; }
.cookie-btn.accept:hover  { background: #218838; transform: translateY(-2px); box-shadow: 0 4px 12px rgba(40,167,69,0.4); }
.cookie-btn.decline { background: #dc3545; color: white; }
.cookie-btn.decline:hover { background: #c82333; transform: translateY(-2px); box-shadow: 0 4px 12px rgba(220,53,69,0.4); }
.cookie-btn.settings { background: rgba(255,255,255,0.2); color: white; border: 2px solid white; }
.cookie-btn.settings:hover { background: white; color: #1e3c72; transform: translateY(-2px); }

.cookie-modal {
    display: none;
    position: fixed;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    background: rgba(0,0,0,0.7);
    z-index: 1000000;
    backdrop-filter: blur(5px);
    -webkit-backdrop-filter: blur(5px);
    -webkit-transform: translateZ(0);
    transform: translateZ(0);
}

.cookie-modal.show {
    display: flex;
    display: -webkit-flex;
    align-items: center;
    -webkit-align-items: center;
    justify-content: center;
    -webkit-justify-content: center;
    animation: fadeIn 0.3s ease;
}

.cookie-modal-content {
    background: white;
    border-radius: 12px;
    max-width: 600px;
    width: 90%;
    max-height: 90vh;
    overflow-y: auto;
    -webkit-overflow-scrolling: touch;
    box-shadow: 0 10px 40px rgba(0,0,0,0.3);
    animation: slideUp 0.3s ease;
}

.cookie-modal-header {
    display: flex;
    display: -webkit-flex;
    justify-content: space-between;
    align-items: center;
    padding: 20px 25px;
    border-bottom: 2px solid #e9ecef;
    background: linear-gradient(135deg, #1e3c72 0%, #2a5298 100%);
    color: white;
    border-radius: 12px 12px 0 0;
}

.cookie-modal-header h2 { margin: 0; font-size: 22px; }

.cookie-modal-close {
    background: none;
    border: none;
    font-size: 32px;
    color: white;
    cursor: pointer;
    line-height: 1;
    padding: 0;
    width: 44px;
    height: 44px;
    display: flex;
    align-items: center;
    justify-content: center;
    border-radius: 50%;
    transition: all 0.3s ease;
    -webkit-tap-highlight-color: transparent;
}

.cookie-modal-close:hover { background: rgba(255,255,255,0.2); transform: rotate(90deg); }

.cookie-modal-body { padding: 25px; }

.cookie-option {
    margin-bottom: 20px;
    padding: 15px;
    border: 2px solid #e9ecef;
    border-radius: 8px;
    transition: all 0.3s ease;
}

.cookie-option:hover { border-color: #4a90e2; box-shadow: 0 2px 8px rgba(74,144,226,0.1); }

.cookie-option-header {
    display: flex;
    align-items: center;
    gap: 15px;
    margin-bottom: 10px;
}

.cookie-option-title {
    flex: 1;
    display: flex;
    align-items: center;
    gap: 10px;
}

.cookie-option-title strong { color: #1e3c72; }

.cookie-badge {
    background: #28a745;
    color: white;
    padding: 3px 10px;
    border-radius: 12px;
    font-size: 11px;
    font-weight: bold;
    text-transform: uppercase;
}

.cookie-description { color: #6c757d; font-size: 13px; margin: 0; line-height: 1.5; }

.cookie-switch {
    position: relative;
    display: inline-block;
    width: 50px;
    height: 26px;
    flex-shrink: 0;
}

.cookie-switch input { opacity: 0; width: 0; height: 0; }

.cookie-slider {
    position: absolute;
    cursor: pointer;
    top: 0; left: 0; right: 0; bottom: 0;
    background-color: #ccc;
    transition: 0.4s;
    border-radius: 26px;
}

.cookie-slider:before {
    position: absolute;
    content: "";
    height: 20px;
    width: 20px;
    left: 3px;
    bottom: 3px;
    background-color: white;
    transition: 0.4s;
    border-radius: 50%;
}

.cookie-switch input:checked + .cookie-slider { background-color: #28a745; }
.cookie-switch input:checked + .cookie-slider:before { transform: translateX(24px); }
.cookie-switch input:disabled + .cookie-slider { background-color: #6c757d; cursor: not-allowed; }

.cookie-modal-footer {
    padding: 20px 25px;
    border-top: 2px solid #e9ecef;
    display: flex;
    gap: 10px;
    justify-content: flex-end;
    background: #f8f9fa;
    border-radius: 0 0 12px 12px;
}

@keyframes fadeIn {
    from { opacity: 0; }
    to   { opacity: 1; }
}

@keyframes slideUp {
    from { transform: translateY(50px); opacity: 0; }
    to   { transform: translateY(0);    opacity: 1; }
}


/* =====================================================================
   8. IFRAME-CONTAINER  (aus container_justify.css)
   ===================================================================== */

.iframe-container {
    width: 100%;
    background: #FFFFFF;
}

.container1 { width: 100%; height: 200px; margin-bottom: 0; }
.container1 iframe { width: 100%; height: 100%; border: none; background: #FFFFFF; display: block; }

.container2 { width: 100%; height: 225px; margin-bottom: 0; }
.container2 iframe { width: 100%; height: 100%; border: none; background: #FFFFFF; display: block; }

.container3 { width: 100%; height: 225px; margin-bottom: 0; }
.container3 iframe { width: 100%; height: 100%; border: none; background: #FFFFFF; display: block; }


/* =====================================================================
   9. RESPONSIVE DESIGN  (aus screen.css)
   ===================================================================== */

/* Tablet (iPad, bis 980px) */
@media (max-width: 980px) {
    #wrapper { width: 100%; max-width: 960px; }
    #smoothmenu1 { width: 100%; box-sizing: border-box; }
    #contentgutter { width: calc(100% - 50px); box-sizing: border-box; }
    .hauptinhalt, .hauptinhalt2, .hauptinhaltblock { width: calc(100% - 256px); }
    .notizen { width: 220px; }
    #meta-information h1 { width: 100%; background-size: cover; }
    #meta-information h1 a { width: 100%; }
}

/* Navigation kompakt, 2 Zeilen (bis 768px) */
@media (max-width: 768px) {
    #smoothmenu1 { height: auto; width: 100%; padding: 2px 0 6px 0; }
    #smoothmenu1 ul { display: flex; flex-wrap: wrap; padding: 0; margin: 0; }
    #smoothmenu1 ul li { float: none; display: inline-block; }
    #smoothmenu1 ul li a { font-size: 11px; padding: 6px 7px 7px 7px; display: inline-block; line-height: 1.5; }
    #smoothmenu1 ul li ul { position: absolute !important; font-size: 11px; min-width: 130px; }

    /* Dropdown kompakter */
    .ddsmoothmenu ul li ul li a {
        padding: 3px 10px !important;
        min-height: 26px !important;
        font-size: 12px !important;
    }

    /* Container iframe-Höhen */
    .container1 { height: auto; min-height: 200px; }
    .container2, .container3 { height: auto; min-height: 225px; }

    /* Cookie Banner */
    .cookie-banner { width: calc(100% - 20px); padding: 15px; }
    .cookie-content { flex-direction: column; -webkit-flex-direction: column; text-align: center; }
    .cookie-buttons { width: 100%; flex-direction: column; -webkit-flex-direction: column; }
    .cookie-btn { width: 100%; padding: 14px 24px; min-height: 44px; }
    .cookie-modal-content { width: 95%; margin: 10px; }
    .cookie-modal-footer { flex-direction: column; -webkit-flex-direction: column; }
    .cookie-modal-footer .cookie-btn { width: 100%; }

    /* Zoom */
    .zoomable:hover { transform: none; box-shadow: 0 2px 8px rgba(0,0,0,0.1); filter: none; }
    .zoom-modal img { max-width: 98%; max-height: 80%; border-radius: 4px; }
    .close-btn { top: 10px; right: 15px; font-size: 30px; width: 40px; height: 40px; }
    .zoom-info span { display: none; }
    .zoom-info::after { content: "Tippen zum Schließen"; }

    /* copyright/gallery hints */
    .copyright-notice, .gallery-instructions { margin: 0 15px; font-size: 9px; }
}

/* Smartphone (bis 600px) */
@media (max-width: 600px) {
    #wrapper { width: 100%; }
    #smoothmenu1 { width: 100%; height: auto; }
    #contentgutter { width: calc(100% - 10px); border-width: 5px; float: none; }
    .hauptinhalt, .hauptinhalt2, .hauptinhaltblock { float: none; width: 100%; min-height: auto; }
    .notizen { float: none; width: 100%; max-width: 100%; padding-top: 10px; background-image: none; margin: 0; }
    table { width: 100% !important; }
    #meta-information { height: 80px; }
    #meta-information h1 { height: 80px !important; background-size: cover !important; width: 100%; }
    #meta-information h1 a { width: 100%; height: 80px; }
    #map { width: 100%; margin: 10px 0; }

    /* Vereine-Grid */
    .vw-row { flex-wrap: wrap; gap: 12px; justify-content: center; }
    .vw-center-row { flex-direction: row; align-items: center; justify-content: space-between; gap: 4px; padding: 6px 2px; }
    .vw-center-col { padding-left: 0; max-width: 90px; flex-shrink: 1; gap: 6px; }
    .vw-center-col img { max-width: 80px; height: auto; }
    .container4 { width: 120px !important; height: 120px !important; float: none !important; flex-shrink: 0; background-size: contain; background-repeat: no-repeat; background-position: center; }
    .vw-center-col-right { max-width: 85px; flex-shrink: 1; align-self: flex-start; margin-top: 0; }
    .vw-center-col-right .vw-item { width: 80px; }
    .vw-center-col-right img { max-width: 55px; height: auto; }
    .vw-item { width: 80px; }
    .vw-item img { max-width: 70px; max-height: 70px; }
    .vw-qr { font-size: 9px; }
}

/* Smartphone (bis 480px) */
@media (max-width: 480px) {
    .cookie-banner { width: calc(100% - 10px); padding: 12px; left: 5px; right: 5px; margin: 0; }
    .cookie-text { font-size: 13px; }
    .cookie-text strong { font-size: 14px; }
    .cookie-btn { padding: 12px 16px; font-size: 14px; min-height: 48px; }
    .cookie-modal-header h2 { font-size: 18px; }
    .cookie-option { padding: 12px; }
    .cookie-option-header { flex-wrap: wrap; -webkit-flex-wrap: wrap; }
    .zoom-modal img { max-width: 100%; max-height: 75%; border-radius: 0; }
    .close-btn { top: 5px; right: 10px; font-size: 25px; width: 35px; height: 35px; }
}

/* Landscape Mobile */
@media (max-width: 768px) and (orientation: landscape) {
    .cookie-banner { padding: 10px 15px; }
    .cookie-content { flex-direction: row; -webkit-flex-direction: row; text-align: left; }
    .cookie-buttons { flex-direction: row; -webkit-flex-direction: row; width: auto; }
    .cookie-btn { width: auto; padding: 10px 16px; }
    .zoom-modal img { max-height: 85%; }
    .zoom-info { bottom: 10px; font-size: 12px; }
}

/* Hochformat, kleines Display */
@media (orientation: portrait) and (max-height: 800px) {
    .zoom-modal img { max-height: 70%; }
}

/* Tablet Zoom */
@media (max-width: 1024px) {
    .zoom-modal img { max-width: 95%; max-height: 85%; }
    .close-btn { top: 15px; right: 20px; font-size: 35px; width: 45px; height: 45px; }
    .zoom-info { bottom: 15px; font-size: 13px; }
}


/* =====================================================================
   10. BARRIEREFREIHEIT & SONDERMODI
   ===================================================================== */

@media (prefers-reduced-motion: reduce) {
    .zoomable, .zoom-modal, .zoom-modal img, .close-btn {
        transition: none;
        animation: none;
    }
    .zoom-modal.active { animation: none; }
    .cookie-banner, .cookie-btn, .cookie-modal, .cookie-modal-content,
    .cookie-slider, .cookie-slider:before {
        transition: none !important;
        animation: none !important;
    }
}

@media (prefers-contrast: high) {
    .zoom-modal { background-color: black; }
    .close-btn { background-color: white; color: black; border: 2px solid black; }
    .cookie-banner { border: 3px solid white; }
    .cookie-btn { border: 2px solid currentColor; }
}

@media (prefers-color-scheme: dark) {
    .zoomable { box-shadow: 0 2px 8px rgba(255,255,255,0.1); }
    .zoomable:hover { box-shadow: 0 8px 25px rgba(255,255,255,0.15); }
}

@media print {
    .zoom-modal { display: none !important; }
    .zoomable { cursor: default; }
    .zoomable:hover { transform: none; box-shadow: none; filter: none; }
}

/* Trennstrich in kirche.html bis kirche8.html */
.tag {
      margin-bottom: 18px;
	  margin-right: 0px;
    }
    .tag-header {
      font-weight: bold;
      font-size: 14px;
      border-bottom: 1px solid #aaa;
      padding-bottom: 3px;
      margin-bottom: 6px;
	  margin-left: 40px;
	  margin-right: 40px;
    }
	
/* ENDE wombach.css */
