/*
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 margins via dynamic CSS (Absatz-Einstellungen im Customizer) */
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 ────────────────────────────────────────────────── */
body{overflow-x:hidden;}
#page{min-height:100vh;display:flex;flex-direction:column;overflow-x:hidden;}
.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;}

/* 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);}

/* Sprüche-Text im full/mini Header — Basis, Details aus dynamic CSS */
#hdr-quote-text,#hdr-mini-quote-text{
    line-height:1.4;
    font-family:var(--f-body);
    margin:0;
    /* Dynamische Verkleinerung: font-size wird via clamp() responsive */
}
#hdr-quote-container{
    max-width:100%;
    overflow:hidden;
}
#hdr-quote-text{
    white-space:nowrap;
    width:fit-content;   /* damit justify-content auf Container wirkt */
    max-width:100%;
    margin:0;
}

/* 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;top:0;left:0;right:0;bottom: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;
    overflow-y:auto;
    /* transform + transition kommen aus dynamic CSS */
}
#mobile-nav.is-open{transform:translate(0,0) !important;}
#mobile-nav.is-closing{
    pointer-events:none;
    /* transition kommt vom #mobile-nav selbst — kein !important hier */
}

/* X-Button: identisch zu nav-toggle-mini + position:fixed für korrekte Platzierung */
#mobile-nav-close{
    background:none;border:none;cursor:pointer;padding:.3em;
    transition:color .2s;
    display:inline-flex;align-items:center;justify-content:center;
    line-height:1;
    position:fixed;
}
#mobile-nav-close svg{display:block;}
#mobile-nav-close:hover{color:var(--c-text);}

/* ── Sprüche / Quotes ─────────────────────────────────────────────── */
#hdr-quote-container{
    display:none; /* wird via dynamic CSS aktiviert wenn Sprüche vorhanden */
    width:100%;
    min-height:1.4em;
    overflow:hidden;
}
#hdr-quote-text{
    margin:0;
    opacity:0;
    will-change:opacity,transform,filter;
}
/* Einblend-Animationen */
/* Reset: immer transition:none damit vorherige Transition abbricht */
#hdr-quote-text.q-reset{transition:none!important;opacity:0;}
#hdr-quote-text.q-in.q-fade     { transition:opacity var(--quote-dur-in) ease; opacity:1; }
#hdr-quote-text.q-out.q-fade    { transition:opacity var(--quote-dur-out) ease; opacity:0; }
#hdr-quote-text.q-in.q-slide-up  { transition:opacity var(--quote-dur-in) ease,transform var(--quote-dur-in) ease; opacity:1; transform:translateY(0); }
#hdr-quote-text.q-reset.q-slide-up{ opacity:0; transform:translateY(0.6em); transition:none; }
#hdr-quote-text.q-out.q-slide-up { transition:opacity var(--quote-dur-out) ease; opacity:0; }
#hdr-quote-text.q-in.q-slide-down { transition:opacity var(--quote-dur-in) ease,transform var(--quote-dur-in) ease; opacity:1; transform:translateY(0); }
#hdr-quote-text.q-reset.q-slide-down{ opacity:0; transform:translateY(-0.6em); transition:none; }
#hdr-quote-text.q-out.q-slide-down{ transition:opacity var(--quote-dur-out) ease; opacity:0; }
#hdr-quote-text.q-in.q-blur      { transition:opacity var(--quote-dur-in) ease,filter var(--quote-dur-in) ease; opacity:1; filter:blur(0); }
#hdr-quote-text.q-reset.q-blur   { opacity:0; filter:blur(8px); transition:none; }
#hdr-quote-text.q-out.q-blur     { transition:opacity var(--quote-dur-out) ease,filter var(--quote-dur-out) ease; opacity:0; filter:blur(8px); }
#hdr-quote-text.q-in.q-scale     { transition:opacity var(--quote-dur-in) ease,transform var(--quote-dur-in) ease; opacity:1; transform:scale(1); }
#hdr-quote-text.q-reset.q-scale  { opacity:0; transform:scale(0.92); transition:none; }
#hdr-quote-text.q-out.q-scale    { transition:opacity var(--quote-dur-out) ease; opacity:0; }
/* Responsive: kleiner auf Tablet, versteckt auf Mobile */
@media(max-width:600px){
    #hdr-quote-container{ display:none!important; }
}

/* 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) !important;}

/* 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;}

#primary .entry-header{padding-bottom:1em;}
/* .entry-title Styles via dynamic CSS (H1 Customizer-Einstellungen) */
.entry-title::after{
    content:'';display:block;width:2em;height:2px;
    background:var(--c-accent);margin-top:.5em;
}
.entry-content{font-weight:var(--fw-body);}
/* h1-h4 margins via dynamic CSS (Customizer) */
.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;
}
/* Fliesstext auf Inhaltsseiten: Blocksatz */
.entry-content p{text-align:justify!important;}

/* CF7 */
.wpcf7 label,
.wpcf7 .wpcf7-form-control-wrap,
.wpcf7 p{font-family:var(--f-body)!important;font-size:.9em;font-weight:400;color:var(--c-text);}
.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);}
/* Allgemeine Formular-Labels (auch ausserhalb CF7) */
label,legend,th,td{font-family:var(--f-body)!important;}

/* ── 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;}
    /* Content-Schrift auf Tablet etwas kleiner */
    .entry-content{font-size:.97em;}
}

/* ── RESPONSIVE MINI-HEADER ─────────────────────────────────────────
   Logik via JS (adaptive): prüft Overflow und blendet stufenweise aus
   1. Socials + letzter Divider
   2. font-size schrumpfen
   3. ≤560px: Subtitle + Divider weg, nur Hamburger + Titel
───────────────────────────────────────────────────────────────────── */

/* Grundregel: nie umbrechen */
.hdr-mini{ flex-wrap:nowrap; overflow:hidden; }

/* Hamburger: immer sichtbar */
.hdr-mini > #nav-toggle-mini{ flex-shrink:0; }

/* Text-Block */
.hdr-mini-text{ flex:1; min-width:0; overflow:hidden; }

/* Titel: nie abschneiden */
.hdr-mini-title{ flex-shrink:1; white-space:nowrap; overflow:visible; text-overflow:clip; }

/* Subtitle */
.hdr-mini-sub{ flex-shrink:1; min-width:0; white-space:nowrap; overflow:hidden; text-overflow:ellipsis; }

/* Socials + Divider */
.hdr-mini-socials{ flex-shrink:0; }
.hdr-mini-divider{ flex-shrink:0; }