/* =========================================================
   SSV Aurach Mobile Optimierung v1.0.2
   Globale mobile Optimierung für ssvaurach.de
   ========================================================= */

:root {
    --ssv-mo-lila: #5b2c83;
    --ssv-mo-lila-2: #7a3db2;
    --ssv-mo-gold: #c9a227;
    --ssv-mo-ink: #211b2b;
    --ssv-mo-muted: #665f70;
    --ssv-mo-soft: #f7f2fb;
    --ssv-mo-line: rgba(91, 44, 131, .14);
    --ssv-mo-shadow: 0 16px 42px rgba(28, 20, 41, .12);
}

@media (max-width: 860px) {
    html {
        -webkit-text-size-adjust: 100%;
        scroll-behavior: smooth;
    }

    body {
        overflow-x: hidden !important;
        background: #fff !important;
    }

    body.ssv-mo-menu-open {
        overflow: hidden !important;
    }

    img, video, iframe {
        max-width: 100% !important;
        height: auto !important;
    }

    table {
        display: block;
        max-width: 100%;
        overflow-x: auto;
        -webkit-overflow-scrolling: touch;
    }

    /* Grundlayout */
    .site,
    .site-content,
    .content-area,
    .entry-content,
    .page-content,
    .container,
    .wrapper,
    .wrap,
    .main-container,
    .inner,
    .post,
    .page,
    main {
        max-width: 100% !important;
        box-sizing: border-box !important;
    }

    .site-content,
    .content-area,
    .entry-content,
    .page-content,
    main {
        padding-left: 12px !important;
        padding-right: 12px !important;
    }

    .entry-content > *:not(.alignfull):not(.ssv-vk-wrap),
    .page-content > *:not(.alignfull):not(.ssv-vk-wrap) {
        max-width: 100% !important;
    }

    /* Typografie */
    h1, .entry-title, .page-title {
        font-size: clamp(32px, 9vw, 46px) !important;
        line-height: .98 !important;
        letter-spacing: -.035em !important;
        margin-bottom: 16px !important;
    }

    h2 {
        font-size: clamp(28px, 7.6vw, 38px) !important;
        line-height: 1.02 !important;
        letter-spacing: -.03em !important;
    }

    h3 {
        font-size: clamp(22px, 6vw, 30px) !important;
        line-height: 1.08 !important;
    }

    p, li {
        font-size: 16px !important;
        line-height: 1.58 !important;
    }

    a, button, input, select, textarea {
        -webkit-tap-highlight-color: transparent;
    }



    /* v1.0.1: keinen zweiten Hamburger anzeigen – vorhandenen Theme-Button übernehmen */
    body.ssv-mo-menu-ready .toggleMenu:not(.ssv-mo-menu-toggle),
    body.ssv-mo-menu-ready .menu-toggle:not(.ssv-mo-menu-toggle),
    body.ssv-mo-menu-ready .mobile-menu-toggle:not(.ssv-mo-menu-toggle),
    body.ssv-mo-menu-ready .mobile-menu:not(.ssv-mo-menu-toggle),
    body.ssv-mo-menu-ready .hamburger:not(.ssv-mo-menu-toggle),
    body.ssv-mo-menu-ready .hamburger-menu:not(.ssv-mo-menu-toggle),
    body.ssv-mo-menu-ready .nav-toggle:not(.ssv-mo-menu-toggle),
    body.ssv-mo-menu-ready .navbar-toggle:not(.ssv-mo-menu-toggle),
    body.ssv-mo-menu-ready .menu-button:not(.ssv-mo-menu-toggle),
    body.ssv-mo-menu-ready .responsive-menu-toggle:not(.ssv-mo-menu-toggle),
    body.ssv-mo-menu-ready .sktmenu-toggle:not(.ssv-mo-menu-toggle),
    body.ssv-mo-menu-ready .meanmenu-reveal:not(.ssv-mo-menu-toggle),
    body.ssv-mo-menu-ready .slicknav_btn:not(.ssv-mo-menu-toggle) {
        display: none !important;
        visibility: hidden !important;
        pointer-events: none !important;
    }

    .ssv-mo-menu-toggle {
        text-decoration: none !important;
        line-height: 1 !important;
        appearance: none !important;
        -webkit-appearance: none !important;
    }

    /* Header / Logo */
    header,
    .site-header,
    #header,
    .header {
        position: relative !important;
        z-index: 9998 !important;
        box-sizing: border-box !important;
    }

    header img,
    .site-header img,
    #header img,
    .header img,
    .custom-logo {
        max-height: 72px !important;
        width: auto !important;
    }

    .ssv-mo-menu-toggle {
        position: fixed !important;
        top: max(12px, env(safe-area-inset-top)) !important;
        right: 12px !important;
        z-index: 100002 !important;
        display: inline-flex !important;
        align-items: center !important;
        justify-content: center !important;
        gap: 8px !important;
        min-height: 44px !important;
        padding: 11px 15px !important;
        border: 1px solid rgba(255,255,255,.25) !important;
        border-radius: 999px !important;
        background: linear-gradient(135deg, var(--ssv-mo-lila), var(--ssv-mo-lila-2)) !important;
        color: #fff !important;
        font-weight: 950 !important;
        font-size: 14px !important;
        box-shadow: 0 14px 32px rgba(91,44,131,.30) !important;
        cursor: pointer !important;
    }

    .ssv-mo-menu-toggle::before {
        content: "";
        width: 18px;
        height: 12px;
        display: inline-block;
        background:
            linear-gradient(#fff,#fff) 0 0/18px 2px no-repeat,
            linear-gradient(#fff,#fff) 0 5px/18px 2px no-repeat,
            linear-gradient(#fff,#fff) 0 10px/18px 2px no-repeat;
    }

    body.ssv-mo-menu-open .ssv-mo-menu-toggle::before {
        width: 16px;
        height: 16px;
        background:
            linear-gradient(#fff,#fff) center/18px 2px no-repeat;
        transform: rotate(45deg);
        box-shadow: 0 0 0 0 #fff;
    }

    body.ssv-mo-menu-open .ssv-mo-menu-toggle::after {
        content: "";
        position: absolute;
        width: 18px;
        height: 2px;
        background: #fff;
        transform: rotate(-45deg);
    }

    .ssv-mo-overlay {
        position: fixed;
        inset: 0;
        z-index: 100000;
        background: rgba(17, 12, 24, .58);
        backdrop-filter: blur(6px);
        opacity: 0;
        pointer-events: none;
        transition: opacity .2s ease;
    }

    body.ssv-mo-menu-open .ssv-mo-overlay {
        opacity: 1;
        pointer-events: auto;
    }

    /* Mobile Menü-Drawer */
    .ssv-mo-nav {
        position: fixed !important;
        top: 0 !important;
        right: 0 !important;
        bottom: 0 !important;
        left: auto !important;
        width: min(88vw, 390px) !important;
        max-width: 390px !important;
        height: 100dvh !important;
        z-index: 100001 !important;
        padding: calc(74px + env(safe-area-inset-top)) 16px 24px !important;
        box-sizing: border-box !important;
        background:
            radial-gradient(circle at 95% 0%, rgba(201,162,39,.18), transparent 28%),
            linear-gradient(180deg, #ffffff 0%, #fbf8fd 100%) !important;
        border-left: 1px solid rgba(91,44,131,.14) !important;
        box-shadow: -24px 0 70px rgba(0,0,0,.24) !important;
        overflow-y: auto !important;
        -webkit-overflow-scrolling: touch !important;
        transform: translateX(105%) !important;
        transition: transform .24s ease !important;
        display: block !important;
        visibility: visible !important;
    }

    body.ssv-mo-menu-open .ssv-mo-nav {
        transform: translateX(0) !important;
    }

    .ssv-mo-nav ul,
    .ssv-mo-nav .menu,
    .ssv-mo-nav .nav-menu {
        display: grid !important;
        grid-template-columns: 1fr !important;
        gap: 8px !important;
        list-style: none !important;
        margin: 0 !important;
        padding: 0 !important;
        width: 100% !important;
    }

    .ssv-mo-nav li {
        position: relative !important;
        margin: 0 !important;
        padding: 0 !important;
        width: 100% !important;
        list-style: none !important;
    }

    .ssv-mo-nav a {
        display: flex !important;
        align-items: center !important;
        min-height: 48px !important;
        padding: 12px 48px 12px 14px !important;
        border-radius: 15px !important;
        background: #fff !important;
        border: 1px solid rgba(91,44,131,.12) !important;
        color: var(--ssv-mo-ink) !important;
        text-decoration: none !important;
        font-weight: 900 !important;
        line-height: 1.25 !important;
        box-shadow: 0 6px 16px rgba(28,20,41,.045) !important;
    }

    .ssv-mo-nav a:hover,
    .ssv-mo-nav a:focus {
        background: var(--ssv-mo-soft) !important;
        color: var(--ssv-mo-lila) !important;
    }

    .ssv-mo-nav .sub-menu,
    .ssv-mo-nav .children {
        display: grid !important;
        gap: 7px !important;
        max-height: 0 !important;
        overflow: hidden !important;
        margin: 0 !important;
        padding: 0 0 0 12px !important;
        transition: max-height .24s ease, padding-top .24s ease !important;
    }

    .ssv-mo-nav li.ssv-mo-open > .sub-menu,
    .ssv-mo-nav li.ssv-mo-open > .children {
        max-height: 1200px !important;
        padding-top: 8px !important;
    }

    .ssv-mo-nav .sub-menu a,
    .ssv-mo-nav .children a {
        min-height: 42px !important;
        background: rgba(255,255,255,.72) !important;
        font-size: 14px !important;
        font-weight: 850 !important;
    }

    .ssv-mo-submenu-toggle {
        position: absolute !important;
        right: 7px !important;
        top: 6px !important;
        width: 38px !important;
        height: 38px !important;
        border: 0 !important;
        border-radius: 12px !important;
        background: rgba(91,44,131,.08) !important;
        color: var(--ssv-mo-lila) !important;
        font-size: 22px !important;
        font-weight: 800 !important;
        line-height: 1 !important;
        cursor: pointer !important;
        z-index: 2 !important;
    }

    .ssv-mo-open > .ssv-mo-submenu-toggle {
        background: var(--ssv-mo-lila) !important;
        color: #fff !important;
    }



    /* v1.0.2: Drawer-Kopf */
    .ssv-mo-nav-head {
        display: grid !important;
        gap: 2px !important;
        margin: 0 0 14px !important;
        padding: 0 4px 12px !important;
        border-bottom: 1px solid rgba(91,44,131,.12) !important;
    }

    .ssv-mo-nav-head strong {
        color: var(--ssv-mo-lila) !important;
        font-size: 22px !important;
        font-weight: 950 !important;
        line-height: 1 !important;
        letter-spacing: -.03em !important;
    }

    .ssv-mo-nav-head span {
        color: var(--ssv-mo-muted) !important;
        font-size: 13px !important;
        font-weight: 850 !important;
    }

    /* Startseiten-/Inhaltskarten */
    .wp-block-columns,
    .wp-block-group,
    .blocks-gallery-grid,
    .gallery,
    .services-wrap,
    .servicebox,
    .boxlayout,
    .features,
    .feature-box,
    .skt-builder-block,
    .homepage section,
    .home section {
        max-width: 100% !important;
        box-sizing: border-box !important;
    }

    .wp-block-columns,
    .blocks-gallery-grid,
    .gallery,
    .services-wrap,
    .features {
        display: grid !important;
        grid-template-columns: 1fr !important;
        gap: 16px !important;
    }

    .wp-block-column,
    .servicebox,
    .feature-box,
    article,
    .post,
    .card,
    .ssv-card,
    .ssv-ap-card,
    .ssv-ap-item,
    .ssv-post-card,
    .ssv-bfv-card {
        width: 100% !important;
        max-width: 100% !important;
        box-sizing: border-box !important;
    }

    .entry-content .wp-block-image,
    .entry-content figure,
    .entry-content .wp-block-column,
    .entry-content .servicebox,
    .entry-content .feature-box {
        margin-left: 0 !important;
        margin-right: 0 !important;
    }

    .entry-content .wp-block-column,
    .entry-content .servicebox,
    .entry-content .feature-box,
    .entry-content article,
    .ssv-mobile-cardify {
        border-radius: 22px !important;
    }

    .entry-content img {
        border-radius: 18px;
    }

    /* Buttons */
    .entry-content a.button,
    .entry-content .button,
    .entry-content button,
    .wp-block-button__link,
    input[type="submit"] {
        min-height: 44px !important;
        border-radius: 999px !important;
        padding: 12px 18px !important;
        font-weight: 900 !important;
        box-sizing: border-box !important;
    }

    .wp-block-button,
    .wp-block-button__link {
        width: 100% !important;
        text-align: center !important;
    }

    /* Vereinskalender / Pluginbereiche auf Mobile */
    .ssv-vk-wrap,
    .ssv-ap-wrap,
    .ssv-bfv-wrap,
    .ssv-posts-wrap,
    .ssv-meine-beitraege-wrap {
        width: 100% !important;
        max-width: 100% !important;
        margin-left: auto !important;
        margin-right: auto !important;
        padding-left: 0 !important;
        padding-right: 0 !important;
    }

    /* Footer: mobil kompakter */
    footer,
    .site-footer,
    #footer,
    .footer {
        margin-top: 28px !important;
        padding-left: 12px !important;
        padding-right: 12px !important;
        box-sizing: border-box !important;
    }

    footer .widget,
    .site-footer .widget,
    #footer .widget,
    .footer .widget,
    footer .footer-column,
    .site-footer .footer-column,
    footer [class*="footer"] {
        max-width: 100% !important;
        box-sizing: border-box !important;
    }

    .ssv-mo-footer-section {
        border: 1px solid rgba(91,44,131,.13) !important;
        border-radius: 18px !important;
        background: #fff !important;
        margin-bottom: 10px !important;
        overflow: hidden !important;
    }

    .ssv-mo-footer-toggle {
        width: 100% !important;
        border: 0 !important;
        background: #fff !important;
        color: var(--ssv-mo-ink) !important;
        text-align: left !important;
        padding: 14px 44px 14px 15px !important;
        font-weight: 950 !important;
        position: relative !important;
        cursor: pointer !important;
    }

    .ssv-mo-footer-toggle::after {
        content: "+";
        position: absolute;
        right: 16px;
        top: 50%;
        transform: translateY(-50%);
        color: var(--ssv-mo-lila);
        font-size: 22px;
    }

    .ssv-mo-footer-section.ssv-mo-open .ssv-mo-footer-toggle::after {
        content: "–";
    }

    .ssv-mo-footer-content {
        display: none !important;
        padding: 0 15px 15px !important;
    }

    .ssv-mo-footer-section.ssv-mo-open .ssv-mo-footer-content {
        display: block !important;
    }

    /* Cookie Banner mobil */
    .wpconsent-banner,
    .wpconsent-modal,
    .cky-consent-container,
    .cc-window,
    [class*="cookie"] [role="dialog"] {
        max-width: calc(100vw - 20px) !important;
        left: 10px !important;
        right: 10px !important;
        bottom: 10px !important;
        border-radius: 18px !important;
        box-sizing: border-box !important;
    }
}
