/*
Theme Name:   Stephan Kälin v2
Theme URI:    https://stephan-kaelin.ch
Description:  Eigenständiges Theme – clean, modern, kein Framework.
Author:       Stephan Kälin
Version:      2.2.0
Text Domain:  sk2025v2
*/

/* ── Reset ─────────────────────────────────────────────────── */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0;}
html{-webkit-font-smoothing:antialiased;}
img{max-width:100%;height:auto;display:block;}

/* ── Defaults (überschrieben durch dynamisches CSS) ─────────── */
:root{
    --c-bg:#fff;--c-text:#1c1c1c;--c-muted:#888;
    --c-border:#ebebeb;--c-accent:#2e6fba;--c-accent-h:#1056a1;
    --f-body:'Montserrat',-apple-system,sans-serif;
    --fw-body:300;--max-w:860px;
}

/* ── Base ──────────────────────────────────────────────────── */
body{font-family:var(--f-body);font-weight:var(--fw-body);font-size:1rem;line-height:1.75;color:var(--c-text);background:var(--c-bg);}
a{color:var(--c-accent);text-decoration:none;transition:color .15s;}
a:hover{color:var(--c-accent-h);}
strong,b{font-weight:600;}
p{margin-bottom:1em;}
p:last-child{margin-bottom:0;}
.hdr-full p{margin-bottom:0;}
hr{border:none;border-top:1px solid var(--c-border);margin:2.5em 0;}

/* ── Layout ────────────────────────────────────────────────── */
#page{min-height:100vh;display:flex;flex-direction:column;}
.sk-container{max-width:var(--max-w);margin:0 auto;padding:0 2em;width:100%;}

/* ── Focus entfernen ──────────────────────────────────────── */
*:focus{outline:none;}

/* ── Header ────────────────────────────────────────────────── */
#masthead{
    background:rgba(255,255,255,.96);
    backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);
    border-bottom:1px solid var(--c-border);
    position:fixed;top:0;left:0;right:0;z-index:200;
}
#masthead .sk-container{
    display:flex;flex-direction:column;align-items:center;
    position:relative;
}
/* Mini-Header: volle Breite, kein max-width */
#masthead.header-mini .sk-container{
    max-width:none;padding:0;
}
#masthead-spacer{
    height:0;
}

/* Normaler Header */
.hdr-full{
    width:100%;display:flex;flex-direction:column;align-items:center;
    text-align:center;overflow:hidden;
}

#masthead.header-mini .hdr-full{display:none;}

/* Mini-Header */
.hdr-mini{
    width:100%;display:flex;align-items:center;gap:.75em;
    pointer-events:none;padding:0;
}
#masthead.header-mini .hdr-mini{
    opacity:1;pointer-events:auto;
}
.hdr-mini-divider{width:1px;height:1.6em;background:var(--c-border);flex-shrink:0;}
.hdr-mini-text{
    flex:1;display:flex;flex-direction:row;align-items:center;gap:.6em;min-width:0;
}
.hdr-mini-title{
    white-space:nowrap;overflow:hidden;text-overflow:ellipsis;
    font-weight:700;letter-spacing:.1em;text-transform:uppercase;color:var(--c-text);
    flex-shrink:0;
}
.hdr-mini-sub{
    white-space:nowrap;overflow:hidden;text-overflow:ellipsis;
    color:var(--c-muted);flex-shrink:1;min-width:0;
}
.hdr-mini-socials{display:flex;gap:.35em;align-items:center;flex-shrink:0;}
.hdr-mini-socials a{
    border-radius:50%;display:flex;align-items:center;justify-content:center;
    transition:background .2s,color .2s;text-decoration:none;flex-shrink:0;
}
.hdr-mini-socials svg{display:block;fill:currentColor;}

/* Hamburger */
.header-hamburger{width:100%;display:flex;justify-content:center;margin-bottom:.15em;}
#nav-toggle-v2,#nav-toggle-mini{
    background:none;border:none;cursor:pointer;padding:.3em;
    transition:color .2s;
    display:inline-flex;align-items:center;justify-content:center;
    line-height:1;flex-shrink:0;
}
#nav-toggle-v2 svg,#nav-toggle-mini svg{display:block;width:1.3em;height:1.3em;}

/* Titel — Grösse/Gewicht/etc. kommt aus dynamic CSS */
.site-title{line-height:1.2;margin:0;text-align:center;}
.site-title a{color:var(--c-text);transition:color .15s;}
.site-title a:hover{color:var(--c-accent);}

/* Untertitel-Zeilen — Basisstil, Details aus dynamic CSS */
.hdr-sub1,.hdr-sub2,.hdr-sub3{line-height:1.4;font-family:var(--f-body);margin:0;text-align:center;}

/* Social */
.header-socials{display:flex;gap:.5em;justify-content:center;}
.header-socials a{
    width:2em;height:2em;border-radius:50%;outline:none;
    background:var(--c-muted);color:#fff;border:1px solid var(--c-muted);
    display:flex;align-items:center;justify-content:center;
    transition:background .2s,border-color .2s,color .2s;
    text-decoration:none;flex-shrink:0;
}
.header-socials svg{display:block;fill:currentColor;width:.9em;height:.9em;}

/* ── Mobile Menu ───────────────────────────────────────────── */
#mobile-nav-overlay{
    display:none;position:fixed;inset:0;
    background:rgba(0,0,0,.3);z-index:240;
}
#mobile-nav-overlay.is-open{display:block;}

#mobile-nav{
    position:fixed;inset:0;background:#fff;z-index:250;
    transform:translateX(-100%);
    transition:transform .35s cubic-bezier(.4,0,.2,1);
    overflow-y:auto;
}
#mobile-nav.is-open{transform:translateX(0);}

/* X-Button zentriert oben */
#mobile-nav-close{
    display:flex;align-items:center;justify-content:center;width:100%;
    background:none;border:none;border-bottom:1px solid var(--c-border);
    cursor:pointer;color:var(--c-muted);
    font-size:1em;line-height:1;
    min-height:2.8em;
    text-align:center;
    transition:color .2s;
}
#mobile-nav-close:hover{color:var(--c-text);}

/* Nav-Liste — KEINE Trennstriche */
#mobile-nav ul{list-style:none;padding:0;margin:0;}
#mobile-nav ul li{margin:0;}

/* Links: als Block, Inhalt zentriert via flex */
#mobile-nav a{
    display:flex;align-items:center;justify-content:center;
    text-align:center;
    transition:color .15s;
    width:100%;
}
#mobile-nav a:hover,
#mobile-nav li.current-menu-item > a,
#mobile-nav li.current_page_item > a{color:var(--c-accent);}

/* Text-Span: inline, kein eigenes Sizing */
#mobile-nav .nav-label-wrap{display:inline;}

/* Pfeil direkt nach Text, kleiner und gedämpft */
#mobile-nav .sub-toggle{
    display:inline-flex;align-items:center;justify-content:center;
    background:none;border:none;cursor:pointer;
    color:var(--c-muted);padding:0 0 0 .35em;
    flex-shrink:0;
    transition:transform .25s,color .15s;
    line-height:1;
}
#mobile-nav .sub-toggle.open{
    transform:rotate(180deg);color:var(--c-accent);
}

/* Sub-menus: keine Einrückung, alles zentriert */
#mobile-nav .sub-menu,#mobile-nav .children{
    list-style:none;padding:0;margin:0;
    max-height:0;overflow:hidden;
    transition:max-height .35s cubic-bezier(0,1,.5,1);
}
#mobile-nav .sub-menu.open,#mobile-nav .children.open{
    max-height:600px;
    transition:max-height .4s cubic-bezier(.4,0,.2,1);
}

/* ── Content ───────────────────────────────────────────────── */
#primary{flex:1;padding:3em 0 5em;}

.entry-header{margin-bottom:2em;padding-bottom:1em;border-bottom:1px solid var(--c-border);}
.entry-title{
    font-size:1.3em;font-weight:600;
    letter-spacing:.1em;text-transform:uppercase;line-height:1.3;
}
.entry-title::after{
    content:'';display:block;width:2em;height:2px;
    background:var(--c-accent);margin-top:.5em;
}
.entry-content{font-weight:var(--fw-body);line-height:1.75;font-size:.97em;}
.entry-content h1{margin:1.5em 0 .5em;}
.entry-content h2{margin:2.5em 0 .7em;}
.entry-content h3{margin:1.8em 0 .4em;}
.entry-content h4{margin:1.4em 0 .3em;}
.entry-content ul{list-style:none;padding-left:0;}
.entry-content ul li{padding-left:1.2em;position:relative;margin-bottom:.4em;}
.entry-content ul li::before{content:'–';position:absolute;left:0;color:var(--c-muted);}
.entry-content blockquote{
    border-left:3px solid var(--c-accent);padding:.8em 1.2em;
    margin:1.5em 0;color:var(--c-muted);font-style:italic;
}

/* CF7 */
.wpcf7 input[type=text],.wpcf7 input[type=email],.wpcf7 input[type=tel],.wpcf7 select,.wpcf7 textarea{
    width:100%;background:#fafafa;border:1px solid var(--c-border);
    border-radius:4px;padding:.65em .9em;
    font-family:var(--f-body);font-size:.93em;font-weight:300;color:var(--c-text);
    transition:border-color .15s;outline:none;-webkit-appearance:none;
}
.wpcf7 input:focus,.wpcf7 textarea:focus{
    border-color:var(--c-accent);background:#fff;
    box-shadow:0 0 0 3px rgba(46,111,186,.08);
}
.wpcf7 textarea{min-height:120px;resize:vertical;}
.wpcf7 input[type=submit]{
    background:var(--c-accent);color:#fff;border:none;border-radius:4px;
    padding:.7em 2.4em;font-family:var(--f-body);
    font-size:.82em;font-weight:600;letter-spacing:.1em;text-transform:uppercase;
    cursor:pointer;transition:background .2s;
}
.wpcf7 input[type=submit]:hover{background:var(--c-accent-h);}

/* ── Footer ────────────────────────────────────────────────── */
#colophon{
    background:#f9f9f9;border-top:1px solid var(--c-border);
    padding:1.5em 0;text-align:center;
    font-size:.78em;color:var(--c-muted);
}
#colophon a{color:var(--c-muted);}
#colophon a:hover{color:var(--c-accent);}


/* ── Scroll-to-top ─────────────────────────────────────────── */
#scroll-top{
    position:fixed;bottom:1.5em;right:1.5em;z-index:190;
    width:2.5em;height:2.5em;border-radius:50%;
    background:#fff;color:var(--c-muted);border:1px solid var(--c-border);
    cursor:pointer;
    display:flex;align-items:center;justify-content:center;
    opacity:0;pointer-events:none;
    transform:translateY(.5em);
    transition:opacity .25s,transform .25s,background .2s,color .2s,border-color .2s;
}
#scroll-top.visible{opacity:1;pointer-events:auto;transform:translateY(0);}
#scroll-top:hover{background:var(--c-accent);color:#fff;border-color:var(--c-accent);}
#scroll-top svg{width:1em;height:1em;display:block;}
/* ── Responsive ────────────────────────────────────────────── */
@media(max-width:860px){
    #primary{padding:2em 0 4em;}
    .sk-container{padding:0 1.2em;}
}
@media(max-width:480px){
    #masthead{padding:1em 0;}
}

/* Mini-Header Overflow wird per JS gesteuert */

/* Collapsed header: kein Wrap, JS entscheidet was wegfällt */
.hdr-mini-socials{flex-shrink:0;}
.hdr-mini-text{flex:1;min-width:0;}
.hdr-mini-title{flex-shrink:0;}
.hdr-mini-sub{flex-shrink:1;min-width:0;}

/* Mini-Header: Socials weg wenn zu schmal */
@media(max-width:620px){
    #masthead.header-mini .hdr-mini-socials,
    #masthead.header-mini .hdr-mini > .hdr-mini-divider:last-of-type{
        display:none !important;
    }
}
/* Mini-Header: Text auch weg wenn sehr schmal */
@media(max-width:360px){
    #masthead.header-mini .hdr-mini-text,
    #masthead.header-mini .hdr-mini-divider{
        display:none !important;
    }
    #masthead.header-mini .hdr-mini{
        justify-content:center !important;
        padding:0 !important;
    }
}
/* Normaler Header: Socials weg nur auf sehr kleinen Screens */
@media(max-width:360px){
    .hdr-full .header-socials{display:none !important;}
}
