/*
Theme Name: Vatter Minimal
Theme URI: https://profi.vatter.de
Description: Minimales Performance-Theme für profi.vatter.de. Kein Elementor, kein Framework. Basiert auf SW Minimal (salewski.it).
Author: VATTER GmbH / yasmin
Version: 1.0.0
License: proprietary
Text Domain: vatter-minimal
*/

/* === CSS VARIABLES (aus Live-Elementor-Kit extrahiert) === */
:root{
    --vp-primary:#003781;       /* Vatter-Blau (Logo, Nav, Links) */
    --vp-primary-hover:#324A6D; /* dunkleres Blau (Hover/Active im Nav) */
    --vp-secondary:#7A7A7A;     /* Grau (Topbar + Footer-Row-1) */
    --vp-accent:#D7192F;        /* Rot (Body-Link-Hover, Kit-Accent) */
    --vp-text:#000000;
    --vp-bg:#FFFFFF;
    --vp-bg-sub:#F3F5F8;        /* Submenü-Hintergrund */
    --vp-bg-sub-hover:#F9FAFD;  /* Submenü-Hover */
    --vp-sep:#dddddd;           /* Trennstrich Topbar */
    --vp-font:'Open Sans Hebrew Condensed','Arial Narrow',Arial,sans-serif;
}

/* === RESET & BASE === */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%}
body{font-family:var(--vp-font);font-size:16px;line-height:1.6;color:var(--vp-text);background:var(--vp-bg);letter-spacing:1px}
img{max-width:100%;height:auto;display:block}
a{color:var(--vp-primary);text-decoration:none;transition:color .3s}
a:hover{color:var(--vp-accent)}
h1,h2,h3,h4,h5,h6{color:var(--vp-primary);font-weight:700;line-height:1.3}
p{margin-bottom:1em}
ul,ol{list-style:none}

/* === TOPBAR (grau, oberhalb des Headers, nicht-sticky) === */
.vp-topbar{background:var(--vp-secondary);color:#fff}
.vp-topbar-inner{max-width:1600px;margin:0 auto;padding:0 40px;display:flex;justify-content:flex-end;align-items:center}
.vp-topbar-list{display:flex;align-items:center;gap:0;font-size:15px;font-weight:500;letter-spacing:6px;line-height:50px}
.vp-topbar-list li{display:flex;align-items:center;padding:0 18px;position:relative}
.vp-topbar-list li + li::before{content:"";position:absolute;left:0;top:50%;transform:translateY(-50%);height:40%;border-left:1px solid var(--vp-sep)}
.vp-topbar-list a{color:#fff;display:flex;align-items:center;gap:8px;transition:color .3s}
.vp-topbar-list a:hover{color:var(--vp-accent)}
.vp-topbar-list svg{width:16px;height:16px;fill:#fff;transition:fill .3s}
.vp-topbar-list a:hover svg{fill:var(--vp-accent)}
@media(max-width:767px){.vp-topbar{display:none}}

/* === HEADER (weiß, sticky) === */
.vp-header{position:sticky;top:0;z-index:95;background:#fff;border-bottom:1px solid #eee;transition:box-shadow .3s}
.vp-header.vp-scrolled{box-shadow:0 2px 14px rgba(0,55,129,.08)}
.vp-header-inner{max-width:1600px;margin:0 auto;padding:12px 40px;display:flex;align-items:center;gap:20px;min-height:100px}
.vp-logo{flex:0 0 auto}
.vp-logo img{height:clamp(32px,4.5vw,72px);width:auto;display:block;transition:height .2s}
.vp-nav-wrap{flex:1;display:flex;justify-content:flex-end;align-items:center}

/* Desktop-Navigation */
.vp-nav{display:flex;align-items:center;gap:20px}
.vp-nav-item{position:relative}
.vp-nav-item>a{display:inline-block;padding:14px 8px;font-family:var(--vp-font);font-size:16px;font-weight:500;letter-spacing:6px;color:var(--vp-primary);position:relative;transition:color .3s}
.vp-nav-item>a::after{content:"";position:absolute;left:50%;bottom:4px;width:0;height:2px;background:var(--vp-accent);transition:width .3s,left .3s}
.vp-nav-item>a:hover,.vp-nav-item>a.vp-active{color:var(--vp-accent)}
.vp-nav-item>a:hover::after,.vp-nav-item>a.vp-active::after{width:calc(100% - 16px);left:8px}

/* Dropdown */
.vp-nav-sub{display:none;position:absolute;top:100%;left:-10px;min-width:240px;background:var(--vp-bg-sub);box-shadow:0 8px 24px rgba(0,0,0,.08);padding:8px 0;z-index:10}
.vp-nav-item:hover .vp-nav-sub,.vp-nav-item:focus-within .vp-nav-sub{display:block}
.vp-nav-sub a{display:block;padding:12px 20px;font-size:16px;font-weight:500;letter-spacing:6px;color:var(--vp-primary);transition:background .2s,color .2s}
.vp-nav-sub a:hover{background:var(--vp-bg-sub-hover);color:var(--vp-accent)}

/* Burger */
.vp-burger{display:none;background:none;border:none;cursor:pointer;padding:8px;color:var(--vp-primary)}
.vp-burger svg{width:28px;height:28px;fill:var(--vp-primary)}

/* Mobile-Navigation */
.vp-mobile-nav{display:none;position:absolute;top:100%;left:0;right:0;background:#fff;border-top:2px solid var(--vp-primary);box-shadow:0 8px 24px rgba(0,0,0,.12);max-height:calc(100vh - 100px);overflow-y:auto;z-index:99}
.vp-mobile-nav.vp-open{display:block}
.vp-mobile-nav a{display:block;padding:14px 24px;font-size:16px;font-weight:500;letter-spacing:6px;color:var(--vp-primary);border-bottom:1px solid #eee;transition:background .2s,color .2s}
.vp-mobile-nav a:hover{background:var(--vp-bg-sub-hover);color:var(--vp-accent)}
.vp-mobile-nav .vp-sub-indent{padding-left:48px;font-size:14px;color:var(--vp-primary);opacity:.75}

@media(max-width:1024px){
    .vp-header-inner{min-height:85px;padding:0 5%}
    .vp-nav{display:none}
    .vp-burger{display:block}
}
@media(max-width:767px){
    .vp-header-inner{min-height:65px}
}

/* Admin-Bar-Fix */
.admin-bar .vp-header{top:32px}
@media(max-width:782px){.admin-bar .vp-header{top:46px}}

/* === MAIN CONTENT === */
.vp-main{min-height:60vh}
.vp-main>*{overflow-x:visible!important}

/* === FOOTER ZEILE 1 (grau) === */
footer[role="contentinfo"]::before{content:"";display:block;height:10px;background:#fff}
.vp-footer-top{background:var(--vp-secondary);padding:28px 16px 14px}
.vp-footer-top-inner{max-width:1600px;margin:0 auto;display:flex;flex-direction:column;align-items:center;gap:8px}
.vp-footer-menu{display:flex;gap:24px;list-style:none;flex-wrap:wrap;justify-content:center}
.vp-footer-menu a{color:#fff;font-family:var(--vp-font);font-size:16px;font-weight:700;letter-spacing:6px;line-height:50px;transition:color .3s}
.vp-footer-menu a:hover{color:var(--vp-accent)}
.vp-footer-address{color:rgba(255,255,255,.85);font-family:var(--vp-font);font-size:14px;font-weight:200;letter-spacing:5px;line-height:40px;text-align:center}

/* === FOOTER ZEILE 2 (weiß) === */
.vp-footer-bottom{background:#fff;min-height:60px;display:flex;align-items:center;justify-content:flex-end;padding:0 40px}
.vp-footer-copy a{color:#999;font-family:var(--vp-font);font-size:14px;font-weight:200;letter-spacing:5px;line-height:50px;padding-left:10px;transition:color .3s}
.vp-footer-copy a:hover{color:var(--vp-accent)}

@media(max-width:767px){
    .vp-footer-top{padding:25px 0 10px}
    .vp-footer-address{font-size:14px;line-height:35px;letter-spacing:3px;padding:0 20px}
    .vp-footer-bottom{justify-content:center;padding:0 20px}
    .vp-footer-copy a{font-size:14px;line-height:35px;letter-spacing:3px}
}

/* === Legal Pages === */
.vp-legal-content{max-width:800px;margin:0 auto;padding:60px 24px 80px;line-height:1.8;color:var(--vp-text);font-size:15px}
.vp-legal-content h1{font-size:28px;font-weight:700;color:var(--vp-primary);margin-bottom:32px;padding-bottom:16px;border-bottom:2px solid var(--vp-primary)}
.vp-legal-content h2{font-size:20px;font-weight:600;color:var(--vp-primary);margin:32px 0 12px}
.vp-legal-content h3{font-size:17px;font-weight:600;color:var(--vp-text);margin:24px 0 8px}
.vp-legal-content p{margin-bottom:12px}
.vp-legal-content ul,.vp-legal-content ol{margin:12px 0 12px 24px;list-style:disc}
.vp-legal-content li{margin-bottom:6px}
.vp-legal-content a{color:var(--vp-primary);text-decoration:underline}

/* === Button Hover-Fix: rote Buttons dürfen bei Hover NICHT roten Text bekommen === */
.btn-primary,
.form-submit,
.map-info__btn,
.kk-card,
a.btn-primary:hover,
a.btn-primary:focus,
a.form-submit:hover,
a.form-submit:focus,
a.map-info__btn:hover,
a.map-info__btn:focus { color: #FFFFFF; }

a.btn-primary:hover,
.btn-primary:hover,
button.form-submit:hover,
a.map-info__btn:hover {
    background: #003781;
    color: #FFFFFF;
    transform: translateY(-2px);
    box-shadow: 0 0 0 1px #FFFFFF;
}
