/*
Theme Name: Handwaesche
Author: Daniel Nix
Version: 1.0.1
Description: Minimaltheme – Die Handwäsche (Schwarz/Rot)
Text Domain: handwaesche
*/

/* ================================
   1) Design Tokens / Vars
=================================== */
:root{
  /* Farben */
  --bg-900:#0a0a0a; --bg-800:#0e0e0e; --bg-700:#121212;
  --fg-100:#f3f4f6; --muted:#b7b7b7;
  --accent:#e11d2d; --accent-700:#b91c1c; --accent-300:#f87171;

  /* Layout */
  --max:1100px;
  --header-h: 88px;

  /* Eyebrow Defaults (Accent auf dunklem Hintergrund) */
  --eyebrow-bg: color-mix(in oklab, var(--accent) 16%, transparent);
  --eyebrow-fg: #ffffff;
  --eyebrow-brd: color-mix(in oklab, var(--accent) 40%, transparent);
}

/* ================================
   2) Base / Reset / Utilities
=================================== */
*{ box-sizing: border-box }
html{ scroll-behavior: smooth }
body{
  margin: 0;
  background: var(--bg-900);
  color: var(--fg-100);
  font-family: system-ui, Segoe UI, Roboto, Arial, sans-serif;
  line-height: 1.6;
}
a{ color: inherit; text-decoration: none }
.container{ max-width: var(--max); margin: 0 auto; padding: 0 20px }
.muted{ color: var(--muted) }
.sr-only{ position:absolute; width:1px; height:1px; padding:0; margin:-1px; overflow:hidden; clip:rect(0,0,0,0); white-space:nowrap; border:0; }

/* Buttons (generic) */
.btn{
  display:inline-block; padding:12px 18px; border-radius:999px;
  border:1px solid var(--accent); background:var(--accent); color:#111; font-weight:800;
}
.btn:hover{ background:var(--accent-700); border-color:var(--accent-700) }
.btn.outline{ background:transparent; color:var(--fg-100); border-color:rgba(255,255,255,.25) }
.btn.outline:hover{ border-color:var(--accent) }

/* ================================
   3) Header / Navigation
=================================== */
/* Header: Nav als Flex, Icons rechts daneben */
.site-nav{ display:flex; align-items:center; gap:14px; }

/* Social-Icon-Leiste im Header */
.header-social{
  display:flex; align-items:center; gap:12px;
  color: var(--fg-100); /* exakt wie Nav-Schrift */
}
.header-social .ic{
  width:24px; height:24px; line-height:0;
  display:inline-flex; align-items:center; justify-content:center;
  color: inherit; /* übernimmt Weiß von .header-social */
  opacity:1;      /* kein Grauschleier */
  transition: transform .2s ease;
}
.header-social .ic:hover{ transform: translateY(-1px); }

/* SVGs sauber skalieren */
.header-social svg, .header-social img{ width:100%; height:100%; display:block; }

/* SVG-Farben auf die Textfarbe zwingen */
.header-social svg [fill]:not([fill="none"]){ fill: currentColor !important; }
.header-social svg [stroke]:not([stroke="none"]){ stroke: currentColor !important; }

@media (max-width: 899px){
  .mobile-links .mobile-social-row .ic svg,
  .mobile-links .mobile-social-row .ic img{
    /* macht alles weiß – unabhängig von hartem Fill */
    filter: brightness(0) invert(1);
  }
}
@media (max-width: 899px){
  .mobile-links .mobile-social-row .ic{
    width:44px;  /* vorher 32px */
    height:44px; /* vorher 32px */
  }
}


/* Optional: Nur falls mal ein <img>-Fallback genutzt wird UND das Icon darin schwarz ist
   → dann wird es mit dem Filter weiß dargestellt. Sonst bitte entfernen. */
/* .header-social img{ filter: brightness(0) invert(1); } */

@media (max-width: 899px){
  .mobile-links .mobile-social-row{
    display:flex; justify-content:center; align-items:center;
    gap:24px; margin: 8px 0 16px; list-style:none; padding:0;
    color: var(--fg-100);
  }
  .mobile-links .mobile-social-row .ic{
    width:32px; height:32px; display:inline-flex; align-items:center; justify-content:center;
    color: inherit; line-height:0; border-radius:8px; -webkit-tap-highlight-color: transparent;
    transition: transform .2s ease;
  }
  .mobile-links .mobile-social-row .ic:hover{ transform: translateY(-1px); }
  .mobile-links .mobile-social-row svg,
  .mobile-links .mobile-social-row img{ width:100%; height:100%; display:block; }
  .mobile-links .mobile-social-row svg [fill]:not([fill="none"]){ fill: currentColor !important; }
  .mobile-links .mobile-social-row svg [stroke]:not([stroke="none"]){ stroke: currentColor !important; }
  /* Optionaler Fallback, wenn du <img>-SVGs hast, die schwarz sind: */
  /* .mobile-links .mobile-social-row img{ filter: brightness(0) invert(1); } */
}



/* Mobile: Icons im Header ausblenden, im Overlay groß und mittig zeigen */
@media (max-width: 899px){
  .header-social{ display:none; }

  .mobile-social{
    display:flex; justify-content:center; gap:24px;
    margin: 18px 0 26px;
    color: var(--fg-100); /* auch mobil exakt weiß */
  }
  .mobile-social .ic{
    width:32px; height:32px;
    color: inherit;
    opacity:1;
    transition: transform .2s ease;
  }
  .mobile-social .ic:hover{ transform: translateY(-1px); }

  .mobile-social svg, .mobile-social img{ width:100%; height:100%; display:block; }
  .mobile-social svg [fill]:not([fill="none"]){ fill: currentColor !important; }
  .mobile-social svg [stroke]:not([stroke="none"]){ stroke: currentColor !important; }

  /* Optional Fallback wie oben */
  /* .mobile-social img{ filter: brightness(0) invert(1); } */
}
/* Macht schwarze Icons weiß – gilt für <svg> UND <img> */
.header-social .ic svg,
.header-social .ic img,
.mobile-social .ic svg,
.mobile-social .ic img{
  filter: brightness(0) invert(1);
}


.site-header{
  position: sticky; top: 0; z-index: 1200;
  background: linear-gradient(180deg, rgba(10,10,10,.95), rgba(10,10,10,.75) 60%, rgba(10,10,10,0));
  backdrop-filter: saturate(1.1) blur(6px);
  border-bottom: 1px solid rgba(225,29,45,.18);
}
.header-inner{
  display:flex; align-items:center; justify-content:space-between;
  min-height:72px; gap:12px; padding-block:6px;
}

/* Logo: maximal Fläche, aber kontrolliert */
.logo{ min-width:0; color:var(--fg-100); display:block; padding-block: 8px;  }
.logo:hover{ color:var(--accent) }
.logo svg, .logo img{ width:100%; height:auto; display:block; }
/* harte SVG-Farben überschreiben */
.logo svg *[fill="#000"], .logo svg *[fill="#000000"]{ fill: currentColor !important }

/* Desktop-Nav (ul/links) */
nav ul{ display:flex; gap:18px; list-style:none; margin:0; padding:0 }
nav a{ opacity:.9 }
nav a:hover{ opacity:1 }

/* --- Burger Button (Icon) --- */
.burger{
  position: relative;
  display: inline-flex;
  width: 40px; height: 40px;
  align-items: center; justify-content: center;
  background: transparent; border: 0; cursor: pointer; padding: 0;
  color: var(--fg-100);
  z-index: 1201; /* über Overlay, damit X immer klickbar */
}
/* Drei Linien – zentral übereinander */
.burger span{
  position:absolute; left:50%; top:50%;
  width:24px; height:2px; background: currentColor; border-radius:1px;
  transform-origin: 50% 50%;
  transition: transform .25s ease, opacity .2s ease;
}
.burger span:nth-child(1){ transform: translate(-50%, -8px); }
.burger span:nth-child(2){ transform: translate(-50%, -50%); }
.burger span:nth-child(3){ transform: translate(-50%,  6px); }
/* Offen -> X */
body.nav-open .burger span:nth-child(1){ transform: translate(-50%, -50%) rotate(45deg); }
body.nav-open .burger span:nth-child(2){ opacity: 0; transform: translate(-50%, -50%); }
body.nav-open .burger span:nth-child(3){ transform: translate(-50%, -50%) rotate(-45deg); }

/* Sichtbarkeitslogik: Desktop vs. Mobil */
.menu{ display: block; }
@media (max-width: 899px){
  .site-header .container{ padding-inline: 12px } /* etwas schmaler mobil */
  .header-inner{
    display:grid; grid-template-columns: 1fr auto; align-items:center; gap:8px;
    min-height: unset; padding-block: 10px; /* Logo darf Höhe bestimmen */
  }
  .menu{ display: none !important; }
  .burger{ display: inline-flex !important; }
}
@media (min-width: 900px){
  .menu{ display: block !important; }
  .burger{ display: none !important; }
}

/* ================================
   4) Mobile Panel (Overlay)
=================================== */
.mobile-panel{
  position: fixed;
  inset: 0;
  display: grid;           /* Basis: Grid – wir zentrieren später im Container */
  align-items: start;
  background: rgba(10,10,10,.45);
  backdrop-filter: blur(8px);
  opacity: 0;
  pointer-events: none;
  transition: opacity .25s ease;
  z-index: 1100;           /* unter Header/Burger, über Inhalt */
}
body.nav-open .mobile-panel{ opacity:1; pointer-events:auto; }
body.nav-open{ overflow:hidden; }  /* Scroll-Lock */

/* Links-Liste (shared) */
.mobile-links{
  list-style:none;
  margin:0;
  padding:0;
  display:grid;
  gap:18px;
}
.mobile-links a{ font-size:22px; opacity:.95 }

/* 4.1 Mobile: Navigation mittig im sichtbaren Bereich unterhalb des Headers */
@media (max-width: 899px){
  .mobile-panel .container{
    /* sichtbarer Bereich abzüglich Header */
    margin-top: var(--header-h);
    min-height: calc(100svh - var(--header-h));
    display: grid;
    place-content: center;       /* vertikal + horizontal zentrieren */
    padding-inline: 20px;
  }
  .mobile-links{
    text-align: center;
    gap: clamp(14px, 4vh, 28px);
  }
}

/* ================================
   5) Hero (Beispiel)
=================================== */
section.hero .eyebrow.eyebrow--accent-strong{ color: var(--eyebrow-fg); }
.hero{
  padding:80px 0 60px;
  position: relative;
  overflow: hidden;
  background: none !important; /* WICHTIG: sonst liegt der Background über dem Video */
}
.hero .container{ position:relative; z-index:2; } /* Text oben */
.hero-grid{ display:grid; grid-template-columns:1.1fr .9fr; gap:28px; align-items:center }
@media (max-width:900px){ .hero-grid{ grid-template-columns:1fr } }
.eyebrow{
  display:inline-block;
  padding:6px 10px 5px;
  border-radius:10px;           /* dezent rund; für „Pill“ siehe Modifier */
  background:var(--eyebrow-bg);
  color:var(--eyebrow-fg);
  border:1px solid var(--eyebrow-brd);
  text-transform:uppercase;
  letter-spacing:.18em;
  font-size:.78rem;
  line-height:1;
  backdrop-filter: saturate(1.1);
}

.eyebrow--accent-strong{
  /* #e11d2d mit höherer Deckkraft */
  --eyebrow-bg: rgba(225, 29, 45, .75);
  --eyebrow-fg: #fff;                  /* dunkler Text auf kräftigem Rot */
  --eyebrow-brd: rgba(225, 29, 45, .9);
}


.h1{ font-size: clamp(28px, 6.2vw, 56px); line-height:1.05; margin:.2em 0 .4em; font-weight:900; letter-spacing:.04em }
.lead{ color:#dfe5e2; font-size: clamp(16px, 2.1vw, 19px) }
.panel{
  border:1px solid rgba(225,29,45,.18);
  border-radius:16px; padding:18px;
  background: linear-gradient(180deg, rgba(255,255,255,.02), rgba(255,255,255,0));
}
/* Video-Layer belegt die komplette Hero-Sektion */
.hero-media{
  position: absolute;
  inset: 0;               /* füllt die Sektion vom oberen bis unteren Rand */
  z-index: 0;            /* liegt hinter dem Content */
  overflow: hidden;
}
.hero-video{
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  object-fit: cover;      /* bedeckt den gesamten Bereich */
  display: block !important;
}

/* Overlay für Lesbarkeit (über dem Video, unter dem Text) */
.hero::after{
  content:"";
  position:absolute; inset:0;       /* fix: war 'relative' */
  z-index:1; pointer-events:none;
  background:
    radial-gradient(1200px 600px at 80% -10%, rgba(225,29,45,.20), transparent 60%),
    radial-gradient(800px 400px at -10% 10%, rgba(185,28,28,.18), transparent 60%),
    linear-gradient(180deg, rgba(0,0,0,.35), rgba(0,0,0,.55));
}


/* Gerätelogik: Desktop zeigt Landscape, Mobile zeigt Portrait */
.hero-video--portrait{ display: none; }
@media (max-aspect-ratio: 1/1){
  .hero-video--landscape{ display: none; }
  .hero-video--portrait{ display: block; }
}

/* Barrierefreiheit / Fallback: reduziere Bewegung → Poster/Bild */
@media (prefers-reduced-motion: reduce){
  .hero-media{ display: none; }
  .hero{
    background: url('/wp-content/uploads/handwaesche-hero/hero-desktop.jpg') center/cover no-repeat;
  }
}
/* DEV: Video immer zeigen – auch bei Reduce Motion */
body.force-video .hero-media{ display:block !important; }
body.force-video .hero{ background:none !important; }



/* ================================
   6) Footer
=================================== */
.site-footer{
  padding:30px 0; color:var(--muted);
  border-top:1px solid rgba(225,29,45,.18);
}
.foot-nav{ display:flex; gap:16px; flex-wrap:wrap }

/* Footer: Powered-by / Partner */
.site-footer .footer-meta{
  display:flex; align-items:center; gap:10px;
  margin-top:12px; flex-wrap:wrap;
}
.site-footer .powered-by{
  font-size:14px; letter-spacing:.02em;
  color: var(--muted);
}

.site-footer .logo-vockrodt{
  display:inline-flex; align-items:center; line-height:0;
  width:160px; /* ggf. 140–200px anpassen */
  color: var(--muted);           /* steuert die SVG-Farbe (currentColor) */
  opacity:.95; transition:opacity .2s ease, color .2s ease;
}
.site-footer .logo-vockrodt:hover{
  color: var(--fg-100); opacity:1;
}
.site-footer .logo-vockrodt svg{
  width:100%; height:auto; display:block;
}

/* Falls das SVG harte Schwarztöne setzt, überschreibe sie: */
.site-footer .logo-vockrodt svg *[fill="#000"],
.site-footer .logo-vockrodt svg *[fill="#000000"]{
  fill: currentColor !important;
}


/* ================================
   7) Floating WhatsApp Button
=================================== */
.btn-whatsapp-fixed{
  position: fixed;
  right: clamp(12px, 1.5vw, 20px);
  bottom: calc(env(safe-area-inset-bottom, 0px) + 18px);
  z-index: 60;
  width: 56px; height: 56px; border-radius: 999px;
  background: #25D366; color: #fff;
  display: inline-flex; align-items: center; justify-content: center;
  border: 0; box-shadow: 0 10px 28px rgba(37,211,102,.35);
  transition: transform .2s ease, box-shadow .2s ease;
}
.btn-whatsapp-fixed:hover{ transform: translateY(-1px); box-shadow: 0 14px 36px rgba(37,211,102,.45) }
.btn-whatsapp-fixed:active{ transform: translateY(0) }
.btn-whatsapp-fixed svg{ width:28px; height:28px; fill: currentColor; display:block }
/* ================================
   7) Impressum
=================================== */

.impressum-content { max-width: var(--max); margin: 0 auto; padding: 40px 20px; }
.impressum-content h1 { color: var(--fg-100); }
.impressum-content p  { color: var(--muted); line-height: 1.7; }