/* ==========================================================================
   THE INNER HOME ? Scoped CSS (aufgeräumt)
   Datei: innerhome.css

   Inhaltsübersicht:
   0) Lokale Fonts
   1) WordPress Theme Header + WP Titelblock ausblenden (Seiten)
   2) Shared Base: Variablen, Layout, Container, SR-only
   3) Shared Header / Navigation / Buttons (Desktop + Mobile)
   4) Shared Typo-Helfer
   5) Shared Footer (Custom) + Responsive
   6) #ih-home ? Sections / Layout / Cards / Responsive
   7) Seiten-spezifisch: Bilder + Maren-Prosa
   8) Legal-Seiten: Impressum (97) + Datenschutz (139) + Responsive
   9) Theme-Footer-Leiste (WP Site Footer) ausblenden
   10) Zusammenarbeit (page-id-146) ? Hero + Offers Feintuning
   11) Newsletter ? Seitenlayout + Diptychon
   12) Brevo (SIB) ? Styling im THE INNER HOME Look
   13) Newsletter ? Button-Regeln + Abmelden-Feinschliff
   ========================================================================== */


/* ========================================================================== 
   0) Lokale Fonts ? Google entfernt
   ========================================================================== */

/* Cormorant Garamond */
@font-face{
  font-family:"Cormorant Garamond";
  src:url("/wp-content/uploads/fonts/cormorant-garamond-v21-latin-regular.woff2") format("woff2");
  font-weight:400;
  font-style:normal;
  font-display:swap;
}
@font-face{
  font-family:"Cormorant Garamond";
  src:url("/wp-content/uploads/fonts/cormorant-garamond-v21-latin-500.woff2") format("woff2");
  font-weight:500;
  font-style:normal;
  font-display:swap;
}
@font-face{
  font-family:"Cormorant Garamond";
  src:url("/wp-content/uploads/fonts/cormorant-garamond-v21-latin-600.woff2") format("woff2");
  font-weight:600;
  font-style:normal;
  font-display:swap;
}

/* Lora */
@font-face{
  font-family:"Lora";
  src:url("/wp-content/uploads/fonts/lora-v37-latin-regular.woff2") format("woff2");
  font-weight:400;
  font-style:normal;
  font-display:swap;
}
@font-face{
  font-family:"Lora";
  src:url("/wp-content/uploads/fonts/lora-v37-latin-500.woff2") format("woff2");
  font-weight:500;
  font-style:normal;
  font-display:swap;
}
@font-face{
  font-family:"Lora";
  src:url("/wp-content/uploads/fonts/lora-v37-latin-600.woff2") format("woff2");
  font-weight:600;
  font-style:normal;
  font-display:swap;
}


/* ========================================================================== 
   1) WordPress Theme Header + WP Titelblock ausblenden
      (Seiten 7/64/97/139/146/204/206/208/223/226/290/292/294)
   ========================================================================== */

body.page-id-7   > .wp-site-blocks > header.wp-block-template-part,
body.page-id-64  > .wp-site-blocks > header.wp-block-template-part,
body.page-id-97  > .wp-site-blocks > header.wp-block-template-part,
body.page-id-139 > .wp-site-blocks > header.wp-block-template-part,
body.page-id-146 > .wp-site-blocks > header.wp-block-template-part,
body.page-id-204 > .wp-site-blocks > header.wp-block-template-part,
body.page-id-206 > .wp-site-blocks > header.wp-block-template-part,
body.page-id-208 > .wp-site-blocks > header.wp-block-template-part,
body.page-id-223 > .wp-site-blocks > header.wp-block-template-part,
body.page-id-226 > .wp-site-blocks > header.wp-block-template-part,
body.page-id-290 > .wp-site-blocks > header.wp-block-template-part,
body.page-id-292 > .wp-site-blocks > header.wp-block-template-part,
body.page-id-294 > .wp-site-blocks > header.wp-block-template-part,
body.page-id-419 > .wp-site-blocks > header.wp-block-template-part{
  display:none !important;
}

body.page-id-7   main#wp--skip-link--target > .wp-block-group.alignfull.has-tertiary-background-color,
body.page-id-64  main#wp--skip-link--target > .wp-block-group.alignfull.has-tertiary-background-color,
body.page-id-97  main#wp--skip-link--target > .wp-block-group.alignfull.has-tertiary-background-color,
body.page-id-139 main#wp--skip-link--target > .wp-block-group.alignfull.has-tertiary-background-color,
body.page-id-146 main#wp--skip-link--target > .wp-block-group.alignfull.has-tertiary-background-color,
body.page-id-204 main#wp--skip-link--target > .wp-block-group.alignfull.has-tertiary-background-color,
body.page-id-206 main#wp--skip-link--target > .wp-block-group.alignfull.has-tertiary-background-color,
body.page-id-208 main#wp--skip-link--target > .wp-block-group.alignfull.has-tertiary-background-color,
body.page-id-223 main#wp--skip-link--target > .wp-block-group.alignfull.has-tertiary-background-color,
body.page-id-226 main#wp--skip-link--target > .wp-block-group.alignfull.has-tertiary-background-color,
body.page-id-290 main#wp--skip-link--target > .wp-block-group.alignfull.has-tertiary-background-color,
body.page-id-292 main#wp--skip-link--target > .wp-block-group.alignfull.has-tertiary-background-color,
body.page-id-294 main#wp--skip-link--target > .wp-block-group.alignfull.has-tertiary-background-color,
body.page-id-419 main#wp--skip-link--target > .wp-block-group.alignfull.has-tertiary-background-color{
  display:none !important;
}

body.page-id-7   main#wp--skip-link--target,
body.page-id-64  main#wp--skip-link--target,
body.page-id-97  main#wp--skip-link--target,
body.page-id-139 main#wp--skip-link--target,
body.page-id-146 main#wp--skip-link--target,
body.page-id-204 main#wp--skip-link--target,
body.page-id-206 main#wp--skip-link--target,
body.page-id-208 main#wp--skip-link--target,
body.page-id-223 main#wp--skip-link--target,
body.page-id-226 main#wp--skip-link--target,
body.page-id-290 main#wp--skip-link--target,
body.page-id-292 main#wp--skip-link--target,
body.page-id-294 main#wp--skip-link--target,
body.page-id-419 main#wp--skip-link--target{
  margin-top:0 !important;
}

/* WP Theme Footer ausblenden (damit kein doppelter Footer erscheint) */
body.page-id-226 > .wp-site-blocks > footer.wp-block-template-part{
  display:none !important;
}


/* ========================================================================== 
   2) Shared Base für #ih-home und #ih-legal
   ========================================================================== */

:where(#ih-home, #ih-legal){
  --white:#FFFFFF;
  --rose:#EAD6D0;
  --beige:#EFE9E4;
  --espresso:#5A4A42;
  --espresso-80:rgba(90,74,66,.80);
  --espresso-60:rgba(90,74,66,.60);
  --line:rgba(90,74,66,.14);
  --shadow:0 18px 45px rgba(90,74,66,.12);

  --font-serif:"Cormorant Garamond", serif;
  --font-body:"Lora", serif;

  --radius-xl:28px;
  --radius-pill:999px;

  --container:1680px;

  color:var(--espresso);
  font-family:var(--font-body);

  width:100%;
  max-width:100%;
  margin-left:0;
  margin-right:0;
  overflow-x:clip;
}

:where(#ih-home, #ih-legal) *{
  box-sizing:border-box;
}

:where(#ih-home, #ih-legal) a{
  color:inherit;
}


html,
body{
  overflow-x:hidden;
  background:#EFE9E4;
}

body{
  margin:0;
}


/* Container */
:where(#ih-home, #ih-legal) .ih-container{
  width:100%;
  max-width:var(--container);
  margin-left:auto;
  margin-right:auto;
  padding-left:clamp(20px, 4vw, 64px);
  padding-right:clamp(20px, 4vw, 64px);
}

@media (min-width:1200px){
  :where(#ih-home, #ih-legal) .ih-container{
    padding-left:clamp(24px, 3vw, 40px);
    padding-right:clamp(24px, 3vw, 40px);
  }
}

/* SR only */
:where(#ih-home, #ih-legal) .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;
}


/* ========================================================================== 
   3) Shared Header / Nav / Buttons
   ========================================================================== */

:where(#ih-home, #ih-legal) header{
  position:sticky;
  top:0;
  z-index:9999;
  background:rgba(255,255,255,.85);
  backdrop-filter:saturate(1.2) blur(10px);
  border-bottom:1px solid var(--line);

  /* Luft nach oben, damit Hover-Lift nicht gekappt wird */
  padding-top:12px;

  /* Anti-Clipping */
  overflow:visible !important;
}

:where(#ih-home, #ih-legal) header *{
  overflow:visible !important;
}

:where(#ih-home, #ih-legal) nav.nav{
  display:flex;
  align-items:center;
  gap:clamp(12px, 1.6vw, 24px);
  padding:10px 0 12px;
  min-height:84px;
  flex-wrap:wrap;
  row-gap:14px;
}

:where(#ih-home, #ih-legal) .brand{
  padding:6px 0;
}

:where(#ih-home, #ih-legal) .nav-cta{
  align-items:center;
}

/* Desktop: Nav stabil in 3 Zonen (Logo | Links | CTA) */
@media (min-width:981px){
  :where(#ih-home, #ih-legal) nav.nav{
    display:grid;
    grid-template-columns:auto 1fr auto;
    align-items:center;
    column-gap:clamp(12px, 2.2vw, 32px);
    flex-wrap:unset;
    row-gap:0;
  }

  :where(#ih-home, #ih-legal) .brand{
    justify-self:start;
    margin-left:-15px;
  }

  :where(#ih-home, #ih-legal) .nav-cta{
    justify-self:end;
    margin-left:0;
  }

  :where(#ih-home, #ih-legal) .nav-links{
    grid-column:1 / -1;
    width:100%;
    justify-content:center;
  }
}

/* Brand */
:where(#ih-home, #ih-legal) .brand{
  display:flex;
  align-items:center;
  gap:12px;
  text-decoration:none;
}

:where(#ih-home, #ih-legal) .brand-mark{
  width:34px;
  height:34px;
  border-radius:50%;
  background:linear-gradient(135deg,var(--rose),var(--beige));
  border:1px solid rgba(90,74,66,.12);
  box-shadow:0 10px 20px rgba(90,74,66,.08);
  display:grid;
  place-items:center;
  font-family:var(--font-serif);
  font-weight:600;
  color:var(--espresso);
}

:where(#ih-home, #ih-legal) .brand-name{
  font-family:var(--font-serif);
  font-weight:600;
  letter-spacing:.04em;
  text-transform:uppercase;
  font-size:18px;
}

/* Nav Typo */
:where(#ih-home, #ih-legal) .nav,
:where(#ih-home, #ih-legal) .nav a{
  font-family:var(--font-serif);
  font-weight:500;
  line-height:1.2;
  letter-spacing:.02em;
}

/* Desktop Links */
:where(#ih-home, #ih-legal) .nav-links{
  order:3;
  width:100%;
  display:flex;
  justify-content:center;
  gap:clamp(12px, 1.6vw, 28px);
  flex-wrap:wrap;
  margin-top:4px;
  padding-top:10px;
  padding-bottom:10px;
  border-top:1px solid rgba(90,74,66,.08);
}

:where(#ih-home, #ih-legal) .nav-links a{
  display:inline-flex;
  align-items:center;
  white-space:nowrap;
  text-decoration:none;
  font-size:18px;
  letter-spacing:.03em;
  color:var(--espresso-80);
  padding:10px 8px;
  border-radius:12px;
  position:relative;
}

:where(#ih-home, #ih-legal) .nav-links a:hover{
  background:rgba(234,214,208,.35);
  color:var(--espresso);
}

:where(#ih-home, #ih-legal) .nav-links a.active{
  background: rgba(234,214,208,.45);
  color: var(--espresso);
}

/* Desktop CTA */
:where(#ih-home, #ih-legal) .nav-cta{
  order:2;
  margin-left:auto;
  flex:0 0 auto;
  display:flex;
  gap:10px;
  white-space:nowrap;
}

/* Buttons */
:where(#ih-home, #ih-legal) .btn{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  height:50px;
  padding:0 20px;
  border-radius:var(--radius-pill);
  font-size:15px;
  font-weight:600;
  text-decoration:none;
  cursor:pointer;
  border:1px solid transparent;
  transition:transform .12s ease, box-shadow .12s ease, background .12s ease;
  white-space:nowrap;
  overflow:visible;
}

:where(#ih-home, #ih-legal) .btn:active{
  transform:translateY(1px);
}

:where(#ih-home, #ih-legal) .btn-primary{
  background:var(--rose);
  color:var(--espresso);
  border-color:rgba(90,74,66,.10);
  box-shadow:0 14px 30px rgba(90,74,66,.12);
}

:where(#ih-home, #ih-legal) .btn-primary:hover{
  box-shadow:0 20px 42px rgba(90,74,66,.16);
  transform:translateY(-4px);
}

:where(#ih-home, #ih-legal) .btn-secondary{
  background:transparent;
  color:var(--espresso);
  border-color:rgba(90,74,66,.35);
}

:where(#ih-home, #ih-legal) .btn-secondary:hover{
  background:rgba(90,74,66,.06);
  transform:translateY(-4px);
}

:where(#ih-home, #ih-legal) .btn-espresso{
  background:var(--espresso);
  color:var(--white);
  border-color:rgba(90,74,66,.85);
}

:where(#ih-home, #ih-legal) .btn-espresso:hover{
  box-shadow:0 18px 40px rgba(90,74,66,.22);
  transform:translateY(-4px);
}

/* Mobile Hamburger */
:where(#ih-home, #ih-legal) .nav-toggle{
  display:none;
  width:46px;
  height:46px;
  border-radius:999px;
  border:1px solid rgba(90,74,66,.18);
  background:rgba(255,255,255,.75);
  backdrop-filter:blur(8px);
  align-items:center;
  justify-content:center;
  cursor:pointer;
  flex:0 0 auto;
  position:relative;
  z-index:10000;
}

:where(#ih-home, #ih-legal) .nav-toggle:active{
  transform:translateY(1px);
}

:where(#ih-home, #ih-legal) .nav-toggle-bars{
  width:18px;
  height:2px;
  background:rgba(90,74,66,.85);
  position:relative;
  display:block;
  border-radius:2px;
}

:where(#ih-home, #ih-legal) .nav-toggle-bars::before,
:where(#ih-home, #ih-legal) .nav-toggle-bars::after{
  content:"";
  position:absolute;
  left:0;
  width:18px;
  height:2px;
  background:rgba(90,74,66,.85);
  border-radius:2px;
}

:where(#ih-home, #ih-legal) .nav-toggle-bars::before{
  top:-6px;
}

:where(#ih-home, #ih-legal) .nav-toggle-bars::after{
  top: 6px;
}

/* Mobile Panel */
:where(#ih-home, #ih-legal) .nav-mobile{
  width:100%;
  margin-top:6px;
  padding:14px;
  border-radius:20px;
  border:1px solid rgba(90,74,66,.12);
  background:rgba(255,255,255,.92);
  box-shadow:0 18px 45px rgba(90,74,66,.12);
  backdrop-filter:blur(14px);
  opacity:0;
  transform:translateY(-10px) scale(.98);
  transition:opacity .28s ease, transform .28s ease;
  pointer-events:none;
}

:where(#ih-home, #ih-legal) [hidden]{
  display:none !important;
}

:where(#ih-home, #ih-legal) .nav-mobile:not([hidden]){
  opacity:1;
  transform:translateY(0) scale(1);
  pointer-events:auto;
}

:where(#ih-home, #ih-legal) .nav-mobile-links{
  display:flex;
  flex-direction:column;
  gap:8px;
  padding-bottom:12px;
  border-bottom:1px solid rgba(90,74,66,.10);
  margin-bottom:12px;
}

:where(#ih-home, #ih-legal) .nav-mobile-links a{
  text-decoration:none;
  color:var(--espresso-80);
  padding:10px 10px;
  border-radius:14px;
}

:where(#ih-home, #ih-legal) .nav-mobile-links a:hover{
  background:rgba(234,214,208,.35);
  color:var(--espresso);
}

:where(#ih-home, #ih-legal) .nav-mobile-cta{
  display:flex;
  gap:10px;
  flex-wrap:wrap;
}

/* ================================
   NAV LAYER FIX (Legal + Home)
   Dropdown muss über dem Content liegen
================================ */

/* Header als eigene Ebene ganz oben */
#ih-home header,
#ih-legal header{
  position: sticky;      /* darfst du auch auf 'relative' ändern, wenn du kein Sticky willst */
  top: 0;
  z-index: 99999;
  isolation: isolate;    /* WICHTIG: eigene Stacking-Context-Ebene */
  overflow: visible;
}

/* Sicherstellen, dass Nav/Container nichts abschneidet */
#ih-home .nav,
#ih-legal .nav,
#ih-home .ih-container,
#ih-legal .ih-container{
  overflow: visible;
}

/* Dropdown korrekt überlagern */
#ih-home .nav-dd,
#ih-legal .nav-dd{ position: relative; }

#ih-home .nav-dd-menu,
#ih-legal .nav-dd-menu{
  position: absolute;
  z-index: 999999;
  top: calc(100% + 10px);
  right: 0;
  left: auto;
}

/* Inhalt bewusst "unter" den Header legen (gegen z-index-Spielereien im Legal-Header) */
#ih-legal main{
  position: relative;
  z-index: 0;
}

/* Mobile: Dropdown im Panel nicht absolut positionieren */
@media (max-width: 980px){
  #ih-home .nav-dd--mobile .nav-dd-menu,
  #ih-legal .nav-dd--mobile .nav-dd-menu{
    position: static;
    top: auto;
    right: auto;
  }
}
#ih-home .nav-dd-trigger::after,
#ih-legal .nav-dd-trigger::after{
  content:"";
  display:inline-block;
  width:6px;
  height:6px;
  margin-left:8px;
  border-right:2px solid currentColor;
  border-bottom:2px solid currentColor;
  transform:rotate(45deg);
  opacity:.7;
}
/* ========================================================================== 
   4) Shared Typo-Helfer
   ========================================================================== */

:where(#ih-home, #ih-legal) .kicker{
  font-size:12px;
  letter-spacing:.18em;
  text-transform:uppercase;
  color:var(--espresso-60);
  margin:0 0 12px;
}

:where(#ih-home, #ih-legal) .muted{
  color:var(--espresso-60);
}

:where(#ih-home, #ih-legal) .lead{
  font-size:20px;
  line-height:1.7;
  color:var(--espresso-80);
}


/* ========================================================================== 
   5) Shared Footer – stabil (Social unter linker Linkspalte)
   ========================================================================== */

#ih-home footer,
#ih-legal footer{
  padding:24px 0;
  border-top:1px solid var(--line);
  background:rgba(239,233,228,.35);
}

#ih-home .footer-grid,
#ih-legal .footer-grid{
  display:grid;
  grid-template-columns:1.3fr 1fr;
  column-gap:48px;
  align-items:start;
}

/* Linke Brand-Spalte */
#ih-home .footer-brand p,
#ih-legal .footer-brand p{
  margin:0 0 14px;
  color:var(--espresso-80);
  font-size:18px;
  line-height:1.65;
}

#ih-home .footer-brand .kicker,
#ih-legal .footer-brand .kicker{
  margin:0 0 12px;
}

/* Rechter Bereich: zwei Linkspalten */
#ih-home .footer-nav,
#ih-legal .footer-nav{
  display:grid;
  grid-template-columns:auto auto;
  column-gap:32px;
  row-gap:8px;
  align-content:start;
}

#ih-home .footer-col,
#ih-legal .footer-col{
  display:flex;
  flex-direction:column;
  gap:6px;
}

#ih-home .footer-col a,
#ih-legal .footer-col a{
  display:inline-block;
  font-size:14px;
  line-height:1.55;
  color:var(--espresso-80);
  text-decoration:none;
  padding:2px 0;
}

#ih-home .footer-col a:hover,
#ih-legal .footer-col a:hover{
  text-decoration:underline;
}

/* Social */
#ih-home .footer-social,
#ih-legal .footer-social{
  display:flex;
  gap:12px;
  margin-top:8px;
  align-items:center;
}

#ih-home .footer-social a,
#ih-legal .footer-social a{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  width:32px;
  height:32px;
  border-radius:50%;
  background:rgba(90,74,66,.06);
  color:var(--espresso-80);
  transition:transform .18s ease, background .18s ease, color .18s ease;
}

#ih-home .footer-social a:hover,
#ih-legal .footer-social a:hover{
  background:rgba(234,214,208,.5);
  color:var(--espresso);
  transform:translateY(-2px);
}

/* Mobile Footer */
@media (max-width:700px){
  #ih-home .footer-grid,
  #ih-legal .footer-grid{
    grid-template-columns:1fr;
    row-gap:12px;
  }
  #ih-home .footer-nav,
  #ih-legal .footer-nav{
    grid-template-columns:1fr;
    row-gap:12px;
  }
}



/* ========================================================================== 
   6) #ih-home ? Sections / Layout (Startseite + Maren + Zusammenarbeit + Newsletter)
   ========================================================================== */

#ih-home section{
  padding:84px 0;
}

#ih-home .section-tight{
  padding:64px 0;
}

#ih-home h1,
#ih-home h2,
#ih-home h3{
  font-family:var(--font-serif);
  margin:0 0 14px;
}

#ih-home h1{
  font-size:56px;
  line-height:1.05;
  letter-spacing:-.01em;
}

#ih-home h2{
  font-size:40px;
  line-height:1.12;
}

#ih-home p{
  margin:0 0 14px;
  color:var(--espresso-80);
  font-size:18px;
  line-height:1.65;
}

#ih-home .divider{
  width:clamp(180px, 22vw, 420px);
  height:3px;
  background:rgba(234,214,208,.95);
  border-radius:999px;
  margin:30px auto 24px auto;
}

/* HERO */
#ih-home .hero{
  padding:84px 0 10px;
  background:
    radial-gradient(1200px 520px at 20% 0%, rgba(234,214,208,.55), transparent 55%),
    linear-gradient(90deg, rgba(239,233,228,.55), transparent 52%);
}

#ih-home .hero-grid{
  display:grid;
  grid-template-columns:1.05fr .95fr;
  gap:36px;
  align-items:center;
}

#ih-home .hero-card{
  padding:10px 0 0;
  min-width:0;
}

#ih-home .hero-cta{
  display:flex;
  gap:12px;
  flex-wrap:wrap;
  margin-top:22px;
  align-items:center;
}

#ih-home .hero-note{
  margin-top:18px;
  font-size:14px;
  color:var(--espresso-60);
}

#ih-home .hero-media{
  border-radius:var(--radius-xl);
  overflow:hidden;
  border:1px solid rgba(90,74,66,.12);
  box-shadow:var(--shadow);
  background:linear-gradient(135deg, rgba(234,214,208,.60), rgba(239,233,228,.75));
  min-height:440px;
  position:relative;
  min-width:0;
  align-self:center;
}

#ih-home .hero-media .img{
  position:absolute;
  inset:0;
  background-size: cover;
  background-position:center 15%;
  background-repeat:no-repeat;
}

#ih-home .hero-media .tag{
  position:absolute;
  left:50%;
  bottom:24px;
  transform:translateX(-50%);
  text-align:center;
  white-space:nowrap;
  max-width:calc(100% - 32px);
  overflow:hidden;
  text-overflow:ellipsis;
  padding:10px 18px;
  border-radius:999px;
  background:rgba(255,255,255,0.88);
  backdrop-filter:blur(8px);
}

/* PANELS / GRIDS / CARDS */
#ih-home .center-block{
  max-width:900px;
  margin:0 auto;
  text-align:center;
}

#ih-home .soft-panel{
  background:linear-gradient(180deg, rgba(243,231,226,.90), rgba(255,255,255,.92));
}

#ih-home .grid{
  display:grid;
  grid-template-columns:repeat(4, minmax(0, 1fr));
  gap:clamp(16px, 1.6vw, 26px);
  margin-top:28px;
  width:100%;
  max-width:100%;
}

#ih-home .grid-2{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:18px;
  margin-top:28px;
}

#ih-home .grid-3{
  display:grid;
  grid-template-columns:repeat(3,1fr);
  gap:18px;
  margin-top:18px;
}

#ih-home .card{
  background:var(--beige);
  border:1px solid rgba(90,74,66,.10);
  border-radius:24px;
  padding:26px 24px;
  box-shadow:0 16px 34px rgba(90,74,66,.10);
  min-height:220px;
  min-width:0;
  position:relative;
}

#ih-home .card.white{
  background:#fff;
  min-height:auto;
}

#ih-home .card .icon{
  width:44px;
  height:44px;
  border-radius:16px;
  background:rgba(255,255,255,.65);
  border:1px solid rgba(90,74,66,.10);
  display:grid;
  place-items:center;
  margin-bottom:14px;
  color:var(--espresso);
  font-family:var(--font-serif);
  font-weight:600;
}

#ih-home .card h3{
  font-size:26px;
  margin:0 0 8px;
  overflow-wrap:anywhere;
  hyphens:auto;
}

#ih-home .card p{
  font-size:16px;
  color:var(--espresso-80);
  margin:0;
}

#ih-home .price{
  margin-top:12px;
  font-weight:600;
  color:var(--espresso);
  font-size:16px;
}

#ih-home .mini{
  margin-top:10px;
  font-size:15px;
  color:var(--espresso-60);
  line-height:1.6;
}

/* Listen in Cards (Newsletter nutzt <ul>) */
#ih-home .card ul{
  margin:0;
  padding-left:1.2em;
}

#ih-home .card li{
  margin:0 0 8px;
  color:var(--espresso-80);
  line-height:1.6;
  font-size:16px;
}

#ih-home .card li:last-child{
  margin-bottom:0;
}

/* Angebote / ih-offers */
#ih-home .ih-offers .card{
  display:flex;
  flex-direction:column;
}

#ih-home .ih-offers .card h3{
  margin:0 0 18px;
}

#ih-home .ih-offers .card > p{
  margin:0 0 16px;
}

#ih-home .ih-offers .card .mini{
  margin:8px 0 0;
}

#ih-home .ih-offers .card .price{
  margin-top:auto;
  padding-top:28px;
  margin-bottom:14px;
  text-align:center;
  letter-spacing:.16em;
}

#ih-home .ih-offers .card .btn{
  align-self:center;
  margin-top:0;
}

/* About / Portrait */
#ih-home .about{
  background:rgba(234,214,208,.22);
}

#ih-home .about-grid{
  display:grid;
  grid-template-columns:1.1fr .9fr;
  gap:28px;
  align-items:center;
}

#ih-home .portrait{
  border-radius:var(--radius-xl);
  overflow:hidden;
  border:1px solid rgba(90,74,66,.12);
  box-shadow:var(--shadow);
  aspect-ratio:3 / 4;
  background-size:cover;
  background-position:center 15%;
}

/* Responsive (Home) */
@media (min-width:981px){
  #ih-home .nav-toggle{
    display:none !important;
  }
}

@media (max-width:980px){
  #ih-home h1{ font-size:46px; }

  #ih-home .hero-grid,
  #ih-home .about-grid{
    grid-template-columns:1fr;
  }

  #ih-home .hero-media{ min-height:360px; }
  #ih-home .grid{ grid-template-columns:repeat(2,1fr); }
  #ih-home .grid-3{ grid-template-columns:1fr; }
  #ih-home .grid-2{ grid-template-columns:1fr; }

  #ih-home header nav.nav > .nav-links{ display:none !important; }
  #ih-home header nav.nav > .nav-cta{ display:none !important; }
  #ih-home .nav-toggle{ display:inline-flex !important; }
}

@media (max-width:520px){
  #ih-home h1{ font-size:40px; }
  #ih-home section{ padding:68px 0; }
  #ih-home .grid{ grid-template-columns:1fr; }
  #ih-home .nav-mobile-cta .btn{ width:100% !important; }
  #ih-home .btn{ width:100%; }
}


/* ========================================================================== 
   7) Seiten-spezifisch: Bilder + Maren-Prosa
   ========================================================================== */

/* Startseite (page-id-7) ? Hero Bild rechts */
body.page-id-7 #ih-home .hero-media .img{
  background:
    radial-gradient(700px 420px at 70% 25%, rgba(255,255,255,.55), transparent 55%),
    linear-gradient(120deg, rgba(90,74,66,.10), transparent 45%),
    url("https://theinnerhome.de/wp-content/uploads/2026/02/Maren_portrait_optimized_1200x1600.jpg");
  background-size:cover;
  background-position:center 15%;
  background-repeat:no-repeat;
}

/* Startseite ? About Portrait */
body.page-id-7 #ih-home .portrait{
  background-image:url("https://theinnerhome.de/wp-content/uploads/2026/02/Maren_portrait2_optimized_1200x1600.jpg");
  background-size:cover;
  background-position:center 15%;
}

/* Maren (page-id-64) ? Portrait */
body.page-id-64 #ih-home .ih-about-portrait .img,
body.page-id-64 #ih-home .hero-media.ih-about-portrait .img{
  background:
    radial-gradient(700px 420px at 70% 25%, rgba(255,255,255,.55), transparent 55%),
    linear-gradient(120deg, rgba(90,74,66,.10), transparent 45%),
    url("https://theinnerhome.de/wp-content/uploads/2026/02/Maren_portrait2_optimized_1200x1600.jpg");
  background-size:cover;
  background-position:center 15%;
  background-repeat:no-repeat;
}

/* Maren ? Prosa */
body.page-id-64 #ih-home .ih-prose{
  max-width:860px;
  margin:0 auto;
}

body.page-id-64 #ih-home .ih-prose p{
  font-size:18px;
  line-height:1.75;
}

/* Kleines Layout-Feintuning */
.ih-about-page .soft-panel + section{
  margin-top:-30px;
}
/* ======================================================================
   Maren (page-id-64) ? "Wofür ich stehe" breitere Panels
   ====================================================================== */

@media (min-width:981px){
  body.page-id-64 #ih-home #values .grid.ih-about-values{
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: clamp(18px, 1.8vw, 28px);
  }
}

/* ========================================================================== 
   8) Legal-Seiten: Impressum (97) + Datenschutz (139)
   ========================================================================== */

body.page-id-97  #ih-legal .ih-narrow,
body.page-id-139 #ih-legal .ih-narrow{
  max-width:820px;
  margin:0 auto;
}

body.page-id-97  #ih-legal .ih-legal,
body.page-id-139 #ih-legal .ih-legal{
  padding:clamp(60px, 8vw, 110px) 0;
  background:
    radial-gradient(1200px 520px at 20% 0%, rgba(234,214,208,.35), transparent 55%),
    linear-gradient(90deg, rgba(239,233,228,.35), transparent 52%);
}

body.page-id-97  #ih-legal .ih-legal-header,
body.page-id-139 #ih-legal .ih-legal-header{
  text-align:left;
  background:transparent;
  padding:0;
  margin:0 0 18px;
  box-shadow:none;
  border:0;
}

body.page-id-97  #ih-legal .ih-legal-header h2,
body.page-id-139 #ih-legal .ih-legal-header h2{
  margin:0 0 14px;
  font-family:var(--font-serif);
  font-weight:500;
  font-size:56px;
  line-height:1.05;
  letter-spacing:-.01em;
  color:var(--espresso);
}

body.page-id-97  #ih-legal .ih-legal-header .divider,
body.page-id-139 #ih-legal .ih-legal-header .divider{
  width:clamp(180px, 22vw, 420px);
  height:3px;
  background:rgba(234,214,208,.95);
  border-radius:999px;
  margin:30px 0 24px 0;
}

body.page-id-97  #ih-legal .ih-legal-content,
body.page-id-139 #ih-legal .ih-legal-content{
  font-family:var(--font-body);
  color:var(--espresso-80);
  line-height:1.75;
  font-size:18px;
}

body.page-id-97  #ih-legal .ih-legal-content p,
body.page-id-139 #ih-legal .ih-legal-content p{
  margin:0 0 14px;
}

body.page-id-97  #ih-legal .ih-legal-note,
body.page-id-139 #ih-legal .ih-legal-note{
  margin-top:28px;
  font-size:15px;
  color:var(--espresso-60);
}

body.page-id-97  #ih-legal .ih-legal-content h3,
body.page-id-139 #ih-legal .ih-legal-content h3{
  font-family:var(--font-serif);
  font-weight:500;
  margin:26px 0 10px;
  font-size:22px;
  color:var(--espresso);
}

body.page-id-97  #ih-legal .ih-legal-content ul,
body.page-id-139 #ih-legal .ih-legal-content ul{
  margin:0 0 14px 18px;
  padding:0;
}

body.page-id-97  #ih-legal .ih-legal-content li,
body.page-id-139 #ih-legal .ih-legal-content li{
  margin:0 0 8px;
}

/* Legal Header subtil ?zurücknehmen? */
body.page-id-97  #ih-legal header,
body.page-id-139 #ih-legal header{
  background: rgba(255,255,255,.78);
  border-bottom-color: rgba(90,74,66,.10);
}

body.page-id-97  #ih-legal .brand-name,
body.page-id-139 #ih-legal .brand-name{
  opacity:.92;
}

body.page-id-97  #ih-legal .btn-primary,
body.page-id-139 #ih-legal .btn-primary{
  box-shadow: 0 10px 22px rgba(90,74,66,.10);
}

body.page-id-97  #ih-legal .btn-secondary,
body.page-id-139 #ih-legal .btn-secondary{
  border-color: rgba(90,74,66,.28);
}

body.page-id-97  #ih-legal .nav-mobile,
body.page-id-139 #ih-legal .nav-mobile{
  background: rgba(255,255,255,.90);
  box-shadow: 0 14px 34px rgba(90,74,66,.10);
}

/* Responsive (Legal) */
@media (max-width:980px){
  body.page-id-97  #ih-legal .ih-legal-header h2,
  body.page-id-139 #ih-legal .ih-legal-header h2{
    font-size:46px;
  }
}

@media (max-width:520px){
  body.page-id-97  #ih-legal .ih-legal-header h2,
  body.page-id-139 #ih-legal .ih-legal-header h2{
    font-size:40px;
  }
}

@media (min-width:981px){
  body.page-id-97  #ih-legal .nav-toggle,
  body.page-id-139 #ih-legal .nav-toggle{
    display:none !important;
  }
}

@media (max-width:980px){
  body.page-id-97  #ih-legal header nav.nav > .nav-links,
  body.page-id-97  #ih-legal header nav.nav > .nav-cta,
  body.page-id-139 #ih-legal header nav.nav > .nav-links,
  body.page-id-139 #ih-legal header nav.nav > .nav-cta{
    display:none !important;
  }

  body.page-id-97  #ih-legal .nav-toggle,
  body.page-id-139 #ih-legal .nav-toggle{
    display:inline-flex !important;
  }
}

@media (max-width:520px){
  body.page-id-97  #ih-legal .nav-mobile-cta .btn,
  body.page-id-139 #ih-legal .nav-mobile-cta .btn{
    width:100% !important;
  }

  body.page-id-97  #ih-legal .btn,
  body.page-id-139 #ih-legal .btn{
    width:100%;
  }
}


/* ========================================================================== 
   9) Theme-Footer-Leiste (Site Footer) ausblenden
   ========================================================================== */

.wp-site-blocks > footer.wp-block-template-part{
  display:none !important;
}



/* ========================================================================== 
   10) Zusammenarbeit (page-id-146) ? Hero Feintuning + Offers
   ========================================================================== */

@media (min-width:981px){
  body.page-id-146 #ih-home .hero-grid{
    grid-template-columns:4fr 6fr;
    gap:16px;
    align-items:start;
  }

  body.page-id-146 #ih-home .hero-title{
    position:relative;
    z-index:3;
    margin:0 0 12px;
    width:calc(100% + 120px);
    pointer-events:none;
    text-shadow:0 2px 8px rgba(255,255,255,.45);
  }
}

body.page-id-146 #ih-home .hero-media{
  min-height:520px;
}

body.page-id-146 #ih-home .hero-media .img{
  position:absolute;
  inset:0;
  display:block;
  background-image: var(--hero-img);
  background-size:112%;
  background-repeat:no-repeat;
  background-position:58% center;
}

body.page-id-146 #ih-home .hero-media::after{
  content:"";
  position:absolute;
  inset:0;
  background: linear-gradient(120deg, rgba(90,74,66,.10), transparent 55%);
  pointer-events:none;
}

/* Kleine Zeile unter h3 (z.B. "7 Tage ? täglich") */
body.page-id-146 #ih-home .ih-offers .mini.muted{
  margin-top:-6px;
  margin-bottom:14px;
  font-size:13.5px;
  letter-spacing:.08em;
  text-transform:uppercase;
  color:var(--espresso-60);
}
/* ==========================================================
   WEGE ? Textbalance: letzter Contentblock atmet überall gleich
   ========================================================== */

/* letzte Mini-Absätze vor Preis/CTA etwas enger */
body.page-id-146 #ih-home #wege .ih-offers .card p.mini{
  margin-bottom:12px;
}

/* der letzte Textabsatz soll nicht ?kleben? */
body.page-id-146 #ih-home #wege .ih-offers .card p.price{
  margin-top:18px;
}

/* ==========================================================
   WEGE ? Klarheit: Mini/Muted sauber differenzieren
   (1. Zeile unter h3 = ?Label-Stil?, weitere muted-Minis = normaler Fließtext)
   ========================================================== */

/* ERSETZT diesen Block komplett:
   body.page-id-146 #ih-home #wege #klarheit .mini.muted { ... }
   body.page-id-146 #ih-home #wege #klarheit .mini:last-of-type { ... }
*/

/* 1) Die erste mini.muted direkt unter h3 soll wie in allen anderen Karten aussehen */
body.page-id-146 #ih-home #wege #klarheit > p.mini.muted:first-of-type{
  margin-top:-6px;
  margin-bottom:14px;
  font-size:13.5px;
  letter-spacing:.08em;
  text-transform:uppercase;
  color:var(--espresso-60);
  line-height:1.3;
}


/* ==========================================================
   WEGE ("Deine Wege") ? 4 Karten: Desktop immer 2×2
   Breakpoint passt zu eurer globalen Regel:
   max-width:980px => 1 Spalte, ab 981px => 2 Spalten
   ========================================================== */
@media (min-width:981px){
  body.page-id-146 #ih-home .grid-2.ih-offers{
    grid-template-columns:repeat(2, minmax(0, 1fr));
    gap:14px;
    align-items:stretch;
  }

  /* Alte Sonderrollen (3. Karte mittig / Klarheit auf eigene Zeile) neutralisieren */
  body.page-id-146 #ih-home .grid-2.ih-offers > .card{
    grid-column:auto;
    width:auto;
    max-width:none;
    margin:0;
    justify-self:stretch;
  }

 
}

/* Newsletter-Karten: Preis + Button kompakter */
body.page-id-146 #ih-home #newsletter-7tage .price,
body.page-id-146 #ih-home #newsletter-monatlich .price{
  padding-top:20px;
}

/* Offers: Rhythmus + saubere Typo-Abstände */
body.page-id-146 #ih-home .ih-offers .card h3{
  margin:0 0 12px;
}

body.page-id-146 #ih-home .ih-offers .card > p{
  margin:0 0 14px;
}

body.page-id-146 #ih-home .ih-offers .card > p:last-of-type{
  margin-bottom:0;
}

/* ==========================================
   PRICE + BUTTON Abstände (alle Karten)
   ========================================== */

body.page-id-146 #ih-home #wege .ih-offers .card .price{
  margin:22px 0 0;   /* oben enger */
  padding:0;
}

body.page-id-146 #ih-home #wege .ih-offers .card .price + .btn{
  margin-top:18px;   /* mehr Luft zum Button */
}

/* ==========================================
   PRICE ? Editorial Upgrade
   ========================================== */

body.page-id-146 #ih-home #wege .ih-offers .card .price{
  margin:22px 0 0;
  padding:0;

  font-size:14px;              /* etwas kleiner */
  letter-spacing:.12em;        /* ruhiger */
  text-transform:uppercase;    /* konsistent */
  font-weight:500;

  color:var(--espresso-70);    /* minimal softer */
}
#programm-12-wochen .price{
  font-size:15px;
}

/* ==========================================================
   WEGE ? Visuelle Führung (Einstieg ? Vertiefung)
   ========================================================== */
body.page-id-146 #ih-home #wege{
  position:relative;
  overflow:hidden;
}

/* ganz subtile Bühnenbeleuchtung: oben neutral, unten minimal wärmer */
body.page-id-146 #ih-home #wege::before{
  content:"";
  position:absolute;
  inset:0;
  pointer-events:none;
  background:
    radial-gradient(900px 420px at 50% 18%, rgba(255,255,255,.75), transparent 60%),
    radial-gradient(900px 520px at 50% 88%, rgba(234,214,208,.22), transparent 62%);
}

/* Grid als Layer über dem Background */
body.page-id-146 #ih-home #wege .ih-container{
  position:relative;
  z-index:1;
}

/* ?Achse? zwischen den Reihen (nur Desktop) */
@media (min-width:981px){
  body.page-id-146 #ih-home #wege .grid-2.ih-offers{
    position:relative;
    padding-top:6px;
  }

  body.page-id-146 #ih-home #wege .grid-2.ih-offers::after{
    content:"";
    position:absolute;
    left:50%;
    top:50%;
transform:translate(-50%, -50%);
margin-top: var(--wege-cross-shift); /* ? neu */
    width:2px;
    height:52px;
    border-radius:999px;
    background:linear-gradient(to bottom, transparent, rgba(90,74,66,.10), transparent);
    opacity:.55;
    pointer-events:none;
  }

  body.page-id-146 #ih-home #wege .grid-2.ih-offers::before{
    content:"";
    position:absolute;
    left:50%;
    top:50%;
    transform:translate(-50%, -50%);
margin-top: var(--wege-cross-shift); /* ? neu */
    width:9px;
    height:9px;
    background:rgba(255,255,255,.92);
    border:1px solid rgba(90,74,66,.16);
    box-shadow:0 10px 22px rgba(90,74,66,.08);
    opacity:.9;
    pointer-events:none;
  }
}

/* ==========================================================
   WEGE ? Labels als ?Tabs?
   ========================================================== */
body.page-id-146 #ih-home .ih-offers .card{
  position:relative;
  overflow:visible;
}

/* Label wie ein kleiner ?Tab? über der Karte */
body.page-id-146 #ih-home .ih-offers .card[data-tier]::before{
  content:attr(data-tier);
  position:absolute;
  top:-10px;
  right:10px;
  padding:7px 12px;
  border-radius:999px;
  font-family:var(--font-serif);
  font-weight:600;
  font-size:11px;
  letter-spacing:.10em;
  text-transform:uppercase;
  color:rgba(90,74,66,.72);
  background:rgba(255,255,255,.92);
  border:1px solid rgba(90,74,66,.14);
  box-shadow:0 10px 24px rgba(90,74,66,.10);
  backdrop-filter: blur(8px);
  z-index:3;
}

/* Überschrift minimal entspannen (kein ?Gestaucht?-Gefühl) */
body.page-id-146 #ih-home .ih-offers .card h3{
  padding-right:8px; /* kleines Safety-Polster */
  line-height:1.12;
  letter-spacing:-0.01em;
}

/* Mobile Feinschliff */
@media (max-width:520px){
  body.page-id-146 #ih-home .ih-offers .card h3{
    padding-right:0;
  }

  body.page-id-146 #ih-home .ih-offers .card[data-tier]::before{
    top:14px;
    right:14px;
    font-size:10.5px;
    padding:6px 9px;
  }
}

/* ==========================================================
   WEGE ? Tiefen-Hierarchie (statisch) + minimaler Hover-Shift
   ========================================================== */

/* Grund-Transition (ohne Lift) */
body.page-id-146 #ih-home #wege .ih-offers .card{
  transition: box-shadow .16s ease, border-color .16s ease;
}

/* Reihen-Gewichtung (Desktop) */
@media (min-width:981px){
  /* obere Reihe = leichter */
  body.page-id-146 #ih-home #wege .ih-offers .card:nth-child(-n+2){
    box-shadow: 0 10px 24px rgba(90,74,66,.06);
  }

  /* untere Reihe = stabiler */
  body.page-id-146 #ih-home #wege .ih-offers .card:nth-child(n+3){
    box-shadow: 0 16px 36px rgba(90,74,66,.10);
  }
}

/* ==========================================================
   WEGE ? Hover-Shift abgestuft
   (jetzt: Richtung Ziel stärker)
   ========================================================== */
@media (hover:hover) and (pointer:fine){

  /* oben links ? leicht */
  body.page-id-146 #ih-home #wege .ih-offers .card:nth-child(1):hover{
    box-shadow: 0 22px 50px rgba(90,74,66,.11);
    border-color: rgba(90,74,66,.15);
  }

  /* oben rechts */
  body.page-id-146 #ih-home #wege .ih-offers .card:nth-child(2):hover{
    box-shadow: 0 24px 54px rgba(90,74,66,.12);
    border-color: rgba(90,74,66,.16);
  }

  /* unten links */
  body.page-id-146 #ih-home #wege .ih-offers .card:nth-child(3):hover{
    box-shadow: 0 26px 58px rgba(90,74,66,.13);
    border-color: rgba(90,74,66,.17);
  }

  /* unten rechts = Zielpunkt */
  body.page-id-146 #ih-home #wege .ih-offers .card:nth-child(4):hover{
    box-shadow: 0 30px 68px rgba(90,74,66,.16);
    border-color: rgba(90,74,66,.20);
  }
}

/* ==========================================================
   PREMIUM-HERVORHEBUNG / ZIELPUNKT ? 12 Wochen Programm
   (neu: subtil vorne statt zurückgesetzt)
   ========================================================== */

body.page-id-146 #ih-home #programm-12-wochen{
  background:
    linear-gradient(
      180deg,
      rgba(234,214,208,.22),
      rgba(255,255,255,1) 45%
    );
  border:1px solid rgba(90,74,66,.24);
  box-shadow: 0 26px 66px rgba(90,74,66,.15);
}

body.page-id-146 #ih-home #programm-12-wochen::after{
  content:"";
  position:absolute;
  inset:0;
  border-radius:inherit;
  pointer-events:none;
  box-shadow: inset 0 0 0 1px rgba(255,255,255,.55);
  opacity:.85;
}

/* ========================================================================== 
   11) NEWSLETTER ? Seiten (Brief page-id-208, Momente page-id-223, Abmelden/Bestätigt)
      Scope: #ih-home.ih-nl-page + data-page
   ========================================================================== */

/* Grundlayout Newsletter-Hero (kompakter & editorial) */
#ih-home.ih-nl-page .hero.hero-compact{
  padding-top: clamp(28px, 4vw, 48px);
  padding-bottom: clamp(28px, 4vw, 54px);
}

#ih-home.ih-nl-page .hero-title{
  font-family: var(--font-serif);
  font-weight: 600;
  letter-spacing: .02em;
  font-size: clamp(34px, 4.2vw, 54px);
  line-height: 1.05;
  margin: 0 0 10px;
}

/* Divider: eher editorial */
#ih-home.ih-nl-page .divider{
  margin:14px 0 18px;
}

/* Hero Card als echte Card */
#ih-home.ih-nl-page .hero-card{
  background: rgba(255,255,255,.72);
  border: 1px solid var(--line);
  box-shadow: var(--shadow);
  border-radius: var(--radius-xl);
  padding: clamp(18px, 2.5vw, 28px);
}

/* Obere weiße Karte bündig (kein "Doppelversatz") */
#ih-home.ih-nl-page .hero-card{
  padding-top:0;
}

#ih-home.ih-nl-page .card.white{
  margin-top:0 !important;
}

/* Desktop: Bild oben zentriert + Inhalt darunter */
@media (min-width:981px){
  #ih-home.ih-nl-page .hero .ih-container.ih-narrow{
    display:block !important;
    width:100% !important;
    max-width:1280px !important;
  }

  #ih-home.ih-nl-page .hero-card{
    max-width:980px;
    margin-left:auto;
    margin-right:auto;
  }

  #ih-home.ih-nl-page .divider{
    margin:14px auto 18px !important;
  }
}

#ih-home .step-status{
  margin:0;
  font-size:15px;
  letter-spacing:.04em;
}

#ih-home .step-divider{
  width:120px;
  height:2px;
  background:rgba(234,214,208,.85);
  border-radius:999px;
  margin:12px 0 18px 0;
}

/* Newsletter-Diptychon (ein Bild ? zwei Darstellungen) */
#ih-home.ih-nl-page .nl-image{
  width: min(540px, 100%);
  aspect-ratio: 3 / 4;
  margin: 1.25rem auto;
  border-radius: 28px;
  box-shadow: var(--shadow);
  background-image: url("https://theinnerhome.de/wp-content/uploads/2026/02/diptychon.png");
  background-size: 200% 100%;
  background-repeat: no-repeat;
  background-position: left center;
  position: relative;
  overflow: hidden;
  transform: none;
  transition: transform .25s ease, box-shadow .25s ease, filter .25s ease;
}

/* Welche Hälfte sichtbar ist */
#ih-home.ih-nl-page[data-page="brief-fuer-dich"] .nl-image{
  background-position:left center;
}
#ih-home.ih-nl-page[data-page="momente-fuer-dich"] .nl-image{
  background-position:right center;
}

/* Falz: sichtbar, aber weich */
#ih-home.ih-nl-page .nl-image::before{
  content:"";
  position:absolute;
  inset:0;
  border-radius:inherit;
  pointer-events:none;
  opacity:.75;
  background: linear-gradient(
    to right,
    transparent 0%,
    transparent 74%,
    rgba(0,0,0,.18) 78%,
    rgba(255,255,255,.14) 82%,
    transparent 88%,
    transparent 100%
  );
}

/* Falz spiegeln für Momente (innen links) */
#ih-home.ih-nl-page[data-page="momente-fuer-dich"] .nl-image::before{
  background: linear-gradient(
    to right,
    transparent 0%,
    transparent 12%,
    rgba(255,255,255,.14) 18%,
    rgba(0,0,0,.18) 22%,
    transparent 28%,
    transparent 100%
  );
}

/* Warmes Licht + Vignette */
#ih-home.ih-nl-page .nl-image::after{
  content:"";
  position:absolute;
  inset:0;
  border-radius:inherit;
  pointer-events:none;
  opacity:.55;
  background:
    linear-gradient(to bottom, rgba(90,74,66,.03), rgba(90,74,66,.07)),
    radial-gradient(120% 120% at 50% 40%, transparent 58%, rgba(0,0,0,.10) 100%);
}

/* Hover nur auf Desktop mit Maus */
@media (hover:hover) and (pointer:fine){
  #ih-home.ih-nl-page .nl-image:hover{
    transform: translateY(-2px);
    box-shadow: 0 22px 58px rgba(90,74,66,.16);
    filter: saturate(1.01) contrast(1.01);
  }
}


/* ========================================================================== 
   12) BREVO (SIB) ? Styling im THE INNER HOME Look
      Scope: nur Newsletter-Seiten (#ih-home.ih-nl-page)
   ========================================================================== */

/* Box um das Formular */
#ih-home.ih-nl-page .nl-signup{
  background: rgba(239,233,228,.65);
  border: 1px solid var(--line);
  border-radius: var(--radius-xl);
  padding: clamp(14px, 2vw, 18px);
}

/* Brevo Grundfläche neutralisieren */
#ih-home.ih-nl-page .nl-signup .sib-form{
  background: transparent !important;
  text-align: left !important;
}

/* Container-Karte (weiße Box) */
#ih-home.ih-nl-page .nl-signup #sib-container{
  background: rgba(255,255,255,.92) !important;
  border: 1px solid rgba(90,74,66,.14) !important;
  border-radius: 18px !important;
  box-shadow: 0 16px 34px rgba(90,74,66,.10) !important;
  max-width: 100% !important;
  padding: 18px !important;
  font-family: var(--font-body) !important;
  color: var(--espresso) !important;
}

/* Brevo-Headline/Intro im Formular ausblenden (robust, ohne first-child) */
#ih-home.ih-nl-page .nl-signup .sib-form-block[style*="font-size:34px"]{
  display:none !important;
}
#ih-home.ih-nl-page .nl-signup .sib-text-form-block{
  display:none !important;
}

/* Kleines Hygiene: Brevo P-Defaults */
#ih-home.ih-nl-page .nl-signup .sib-form-block p{
  margin:0;
}

/* Eingabefeld */
#ih-home.ih-nl-page .nl-signup input.input{
  width: 100% !important;
  height: 46px !important;
  padding: 0 14px !important;
  border-radius: 14px !important;
  border: 1px solid rgba(90,74,66,.22) !important;
  background: rgba(255,255,255,.95) !important;
  color: var(--espresso) !important;
  font-family: var(--font-body) !important;
  font-size: 16px !important;
  outline: none !important;
  box-shadow: none !important;
}

#ih-home.ih-nl-page .nl-signup input.input:focus{
  border-color: rgba(90,74,66,.45) !important;
  box-shadow: 0 0 0 4px rgba(234,214,208,.55) !important;
}

/* Hinweistext unter dem Feld */
#ih-home.ih-nl-page .nl-signup .entry__specification{
  font-family: var(--font-body) !important;
  color: var(--espresso-60) !important;
  font-size: 13px !important;
  line-height: 1.5 !important;
}

/* Fehlermeldung */
#ih-home.ih-nl-page .nl-signup .entry__error--primary{
  margin-top: 10px;
  font-size: 14px;
  color: #661d1d;
}

/* Honeypot verstecken */
#ih-home.ih-nl-page .nl-signup .input--hidden{
  display:none !important;
}

/* Feedback Panels */
#ih-home.ih-nl-page .nl-signup .sib-form-message-panel{
  border-radius: 14px !important;
  border-width: 1px !important;
  max-width: 100% !important;
  font-family: var(--font-body) !important;
}

/* Loader-Icon im Button */
#ih-home.ih-nl-page .nl-signup .sib-hide-loader-icon{
  margin-right: 10px !important;
}

/* Button Block zentrieren + Hover-Lift Luft */
#ih-home.ih-nl-page .nl-signup .sib-form-block[style*="text-align"]{
  text-align: center !important;
  margin-top: 8px !important;
}

#kontakt-formulare{
  scroll-margin-top: 120px;
}
/* ========================================================================== 
   13) Newsletter ? Buttons + Abmelden-Feinschliff
   ========================================================================== */

/* Newsletter Buttons ? wie Brief/Momente (rose pill)
   Gilt für: brief-fuer-dich, momente-fuer-dich, newsletter-abmelden */
#ih-home.ih-nl-page[data-page="brief-fuer-dich"] .nl-signup button.sib-form-block__button,
#ih-home.ih-nl-page[data-page="momente-fuer-dich"] .nl-signup button.sib-form-block__button,
#ih-home.ih-nl-page[data-page="newsletter-abmelden"] .nl-signup button.sib-form-block__button,
#ih-home.ih-nl-page[data-page="newsletter-abmelden"] .nl-signup input[type="submit"],
#ih-home.ih-nl-page[data-page="newsletter-abmelden"] .nl-signup button{
  display:inline-flex !important;
  align-items:center !important;
  justify-content:center !important;
  height:46px !important;
  padding:0 18px !important;
  border-radius:var(--radius-pill) !important;
  background:var(--rose) !important;
  color:var(--espresso) !important;
  border:1px solid rgba(90,74,66,.25) !important;
  font-family:var(--font-serif) !important;
  font-weight:600 !important;
  letter-spacing:.02em !important;
  cursor:pointer !important;
  transition:transform .12s ease, box-shadow .12s ease, filter .12s ease !important;
  box-shadow:0 14px 30px rgba(90,74,66,.10) !important;
  text-transform:none !important;
}

@media (hover:hover) and (pointer:fine){
  #ih-home.ih-nl-page[data-page="brief-fuer-dich"] .nl-signup button.sib-form-block__button:hover,
  #ih-home.ih-nl-page[data-page="momente-fuer-dich"] .nl-signup button.sib-form-block__button:hover,
  #ih-home.ih-nl-page[data-page="newsletter-abmelden"] .nl-signup button.sib-form-block__button:hover,
  #ih-home.ih-nl-page[data-page="newsletter-abmelden"] .nl-signup input[type="submit"]:hover,
  #ih-home.ih-nl-page[data-page="newsletter-abmelden"] .nl-signup button:hover{
    transform:translateY(-2px) !important;
    box-shadow:0 18px 40px rgba(90,74,66,.18) !important;
    filter:saturate(1.01) contrast(1.01) !important;
    background:#e2c8c1 !important;
  }
}

/* Abmelden-Button soll sich vom Card-Hintergrund abheben */
#ih-home.ih-nl-page a.btn.btn-secondary[href*="newsletter-abmelden"]{
  background:#fff !important;
  border-color:rgba(90,74,66,.28) !important;
  color:var(--espresso) !important;
  box-shadow:0 10px 22px rgba(90,74,66,.08);
}

@media (hover:hover) and (pointer:fine){
  #ih-home.ih-nl-page a.btn.btn-secondary[href*="newsletter-abmelden"]:hover{
    background:rgba(234,214,208,.45) !important;
    border-color:rgba(90,74,66,.22) !important;
    transform:translateY(-2px);
    box-shadow:0 16px 34px rgba(90,74,66,.12);
  }
}

/* Newsletter Abmelden ? Platzhalter-Formular (nl-row) */
#ih-home.ih-nl-page[data-page="newsletter-abmelden"] .nl-row{
  display:flex;
  flex-direction:column;
  gap:14px; /* Abstand Input -> Button */
}

/* Brevo-Abmeldeformular: Abstand zwischen Feld und Button */
#ih-home.ih-nl-page[data-page="newsletter-abmelden"] .nl-signup .sib-form .sib-form-block{
  margin-bottom:14px !important;
}

#ih-home.ih-nl-page[data-page="newsletter-abmelden"] .nl-signup .sib-form .sib-form-block:last-of-type{
  margin-bottom:0 !important;
}

/* Newsletter-Abmeldung bestätigt ? weiße Secondary Buttons (scoped) */
#ih-home.ih-nl-page[data-page="newsletter-abmeldung-bestaetigt"] .btn-secondary{
  background:#ffffff;
  color:var(--espresso);
  border:1px solid #d8cfc6;
}

#ih-home.ih-nl-page[data-page="newsletter-abmeldung-bestaetigt"] .btn-secondary:hover{
  background:#f7f4f1;
  color:var(--espresso);
  border-color:#cfc4ba;
}

/* === Consent Hinweis ? Inner Home Style === */
.ih-consent-hint{
  position:fixed;
  inset:0;
  background:rgba(90,74,66,.18);
  display:none;
  align-items:center;
  justify-content:center;
  z-index:999999;
  opacity:0;
  pointer-events:none;
  transition:opacity .25s ease;
}

.ih-consent-hint.show{
  opacity:1;
  pointer-events:auto;
  display:flex;
}

.ih-consent-card{
  max-width:420px;
  width:calc(100% - 32px);
  background:#EFE9E4;
  border-radius:18px;
  box-shadow:0 18px 45px rgba(90,74,66,.15);
  padding:24px;
  font-family:"Lora", serif;
  color:#5A4A42;
}

.ih-consent-card p{
  margin:0 0 10px 0;
  line-height:1.5;
}

.ih-consent-card .small{
  font-size:14px;
  opacity:.85;
}

.ih-consent-card button{
  margin-top:10px;
  width:100%;
  border:none;
  border-radius:999px;
  padding:.65rem 1rem;
  background:#5A4A42;
  color:#fff;
  font-weight:600;
  cursor:pointer;
}

/* ==========================================================================
   13a) Footer-Fallbacks / Newsletter-Abmelden
   ========================================================================== */

/* Fallback: Dein Custom-Footer auf Seite 226, auch wenn er aus #ih-home rausfällt */
body.page-id-226 footer .footer-grid{
  display:grid;
  grid-template-columns: 1fr 1fr;
  gap: 24px;
}

body.page-id-226 footer .footer-nav{
  display:grid;
  grid-template-columns: 1fr 1fr;
  gap: 24px;
}

@media (max-width: 900px){
  body.page-id-226 footer .footer-grid,
  body.page-id-226 footer .footer-nav{
    grid-template-columns: 1fr;
  }
}

/* ==========================================================================
   PATCH: Newsletter-Abmelden ? WP Footer zuverlässig ausblenden
   (Theme kann je nach Template andere Footer-Strukturen nutzen)
   ========================================================================== */

body.page-id-226 .wp-site-blocks > footer,
body.page-id-226 .wp-site-blocks footer.wp-block-template-part,
body.page-id-226 footer.wp-block-template-part,
body.page-id-226 footer.wp-site-footer,
body.page-id-226 .wp-site-blocks footer.wp-block-group{
  display:none !important;
}

/* =====================================================================
   BREVO: Success/Error Panels standardmäßig verstecken
   (werden von Brevo bei Bedarf wieder eingeblendet)
   ===================================================================== */

#ih-home.ih-nl-page .nl-signup #error-message,
#ih-home.ih-nl-page .nl-signup #success-message{
  display:none;
  margin:0 0 14px;
}

/* Wenn Brevo inline display:block setzt, soll das sichtbar sein */
#ih-home.ih-nl-page .nl-signup #error-message[style*="display: block"],
#ih-home.ih-nl-page .nl-signup #success-message[style*="display: block"]{
  display:block;
}

/* Optional: die riesigen Icons innerhalb der Panels etwas zähmen */
#ih-home.ih-nl-page .nl-signup .sib-form-message-panel__text svg{
  width:22px;
  height:22px;
}
/* ==========================================================================
   KONTAKT (page-id-360) ? CSS-Ergänzung für innerhome.css
   ========================================================================== */

/* 1) WP Header + WP Titelblock auch auf Kontakt ausblenden */
body.page-id-360 > .wp-site-blocks > header.wp-block-template-part,
body.page-id-360 main#wp--skip-link--target > .wp-block-group.alignfull.has-tertiary-background-color{
  display:none !important;
}
body.page-id-360 main#wp--skip-link--target{ margin-top:0 !important; }

/* WP Theme Footer-Leiste auf Kontakt ausblenden (falls Template sie trotzdem rendert) */
body.page-id-360 .wp-site-blocks > footer.wp-block-template-part{
  display:none !important;
}

/* 2) Kontakt Layout */
/* 2) Kontakt Layout ? Formulare untereinander */
#ih-home.ih-contact-page .ih-contact-grid{
  display:grid;
  grid-template-columns: 1fr;   /* vorher: 1fr 1fr */
  gap: 26px;                   /* etwas mehr Luft */
  align-items:start;
}

/* Karten für Formulare */
#ih-home.ih-contact-page .ih-form-card{
  background: rgba(255,255,255,.78);
  border: 1px solid var(--line);
  box-shadow: var(--shadow);
  border-radius: var(--radius-xl);
  padding: clamp(18px, 2.5vw, 28px);
}

#ih-home.ih-contact-page .ih-form-title{
  font-family: var(--font-serif);
  font-weight: 600;
  font-size: 28px;
  line-height: 1.15;
  margin: 0 0 12px;
}

#ih-home.ih-contact-page .ih-form{
  margin-top:14px;
}

#ih-home.ih-contact-page .ih-row{
  display:flex;
  flex-direction:column;
  gap:8px;
  margin-bottom:12px;
}

#ih-home.ih-contact-page .ih-label{
  font-family: var(--font-serif);
  font-weight: 500;
  letter-spacing: .02em;
  color: var(--espresso);
  font-size: 15px;
}

#ih-home.ih-contact-page .ih-input,
#ih-home.ih-contact-page .ih-textarea{
  width:100%;
  border-radius: 14px;
  border: 1px solid rgba(90,74,66,.22);
  background: rgba(255,255,255,.95);
  color: var(--espresso);
  font-family: var(--font-body);
  font-size: 16px;
  padding: 12px 14px;
  outline: none;
  box-shadow: none;
}

#ih-home.ih-contact-page .ih-input:focus,
#ih-home.ih-contact-page .ih-textarea:focus{
  border-color: rgba(90,74,66,.45);
  box-shadow: 0 0 0 4px rgba(234,214,208,.55);
}

#ih-home.ih-contact-page .ih-textarea{
  resize: vertical;
  min-height: 130px;
}

/* Checkbox */
#ih-home.ih-contact-page .ih-check{
  margin-top:6px;
}
#ih-home.ih-contact-page .ih-checkbox{
  display:flex;
  gap:10px;
  align-items:flex-start;
  font-size: 14px;
  line-height: 1.5;
  color: var(--espresso-80);
}
#ih-home.ih-contact-page .ih-checkbox input{
  margin-top:3px;
}

/* Actions */
#ih-home.ih-contact-page .ih-actions{
  display:flex;
  gap:10px;
  flex-wrap:wrap;
  margin-top:12px;
}
#ih-home.ih-contact-page .ih-privacy{
  margin: 10px 0 0;
}

/* Statusbox */
#ih-home.ih-contact-page .ih-form-status{
  border-radius: 16px;
  padding: 12px 14px;
  border: 1px solid rgba(90,74,66,.14);
  background: rgba(239,233,228,.55);
  color: var(--espresso);
  margin: 0 0 16px;
}
#ih-home.ih-contact-page .ih-form-status.ok{
  background: rgba(231,250,240,.75);
  border-color: rgba(19,206,102,.35);
}
#ih-home.ih-contact-page .ih-form-status.bad{
  background: rgba(255,237,237,.75);
  border-color: rgba(255,73,73,.35);
}

/* Honeypot verstecken */
#ih-home.ih-contact-page .ih-hp{
  position:absolute;
  left:-9999px;
  width:1px;
  height:1px;
  overflow:hidden;
}

/* Responsive */
@media (max-width:980px){
  #ih-home.ih-contact-page .ih-contact-grid{
    grid-template-columns: 1fr;
  }
}
@media (max-width:520px){
  #ih-home.ih-contact-page .ih-actions .btn{
    width:100%;
  }
}
/* ==========================================================================
   KLARHEITSGESPRÄCH ? Seite (bitte Page-ID eintragen, sobald vorhanden)
   Beispiel: body.page-id-XXX
   ========================================================================== */

/* 1) WP Theme Header + Titelblock ausblenden (wie eure anderen Custom-Seiten) */
body.page-id-365 > .wp-site-blocks > header.wp-block-template-part,
body.page-id-365 main#wp--skip-link--target > .wp-block-group.alignfull.has-tertiary-background-color{
  display:none !important;
}
body.page-id-365 main#wp--skip-link--target{ margin-top:0 !important; }

/* 2) WP Theme Footer-Leiste ausblenden (doppelter Footer verhindern) */
body.page-id-365 .wp-site-blocks > footer.wp-block-template-part{
  display:none !important;
}

/* 3) Offer-spezifische Feinschliffe */
#ih-home.ih-offer-page .ih-offer-meta{
  display:flex;
  flex-wrap:wrap;
  gap:10px;
  margin-top:14px;
}

#ih-home.ih-offer-page .ih-offer-pill{
  display:inline-flex;
  gap:8px;
  align-items:center;
  padding:8px 12px;
  border-radius:999px;
  border:1px solid rgba(90,74,66,.14);
  background:rgba(239,233,228,.40);
  color:var(--espresso-80);
  font-size:14px;
  line-height:1.2;
}

#ih-home.ih-offer-page .ih-steps .card .icon{
  width:44px;
  height:44px;
  border-radius:16px;
  background:rgba(234,214,208,.35);
  border:1px solid rgba(90,74,66,.10);
}

#ih-home.ih-offer-page .ih-cal-card{
  overflow:hidden;
}

#ih-home.ih-offer-page .ih-calendly-wrap{
  border-radius:18px;
  border:1px solid rgba(90,74,66,.12);
  overflow:hidden;
  background:#fff;
}

#ih-home.ih-offer-page .ih-legal-block h3{
  font-family:var(--font-serif);
  font-weight:600;
  margin:22px 0 10px;
  font-size:22px;
  color:var(--espresso);
}

#ih-home.ih-offer-page .ih-legal-block p{
  margin:0 0 14px;
}

/* FAQ Grid auf Mobile einspaltig */
@media (max-width:980px){
  #ih-home.ih-offer-page .ih-faq{ grid-template-columns:1fr !important; }
}

/* ==========================================================================
   Accordion (Zahlungsdetails) ? ohne JS
   ========================================================================== */

#ih-home.ih-offer-page .ih-accordion{
  border:1px solid rgba(90,74,66,.14);
  border-radius:18px;
  background:rgba(255,255,255,.82);
  box-shadow:0 12px 28px rgba(90,74,66,.08);
  padding:0;
  margin-top:14px;
  overflow:hidden;
}

#ih-home.ih-offer-page .ih-accordion > summary{
  list-style:none;
  cursor:pointer;
  padding:14px 16px;
  font-family:var(--font-serif);
  font-weight:600;
  letter-spacing:.02em;
  color:var(--espresso);
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:12px;
  user-select:none;
}

#ih-home.ih-offer-page .ih-accordion > summary::-webkit-details-marker{
  display:none;
}

#ih-home.ih-offer-page .ih-accordion > summary::after{
  content:"";
  font-size:18px;
  opacity:.8;
  transform:translateY(-1px);
  transition:transform .18s ease;
}

#ih-home.ih-offer-page .ih-accordion[open] > summary{
  border-bottom:1px solid rgba(90,74,66,.12);
  background:rgba(239,233,228,.35);
}

#ih-home.ih-offer-page .ih-accordion[open] > summary::after{
  transform:rotate(180deg);
}

#ih-home.ih-offer-page .ih-accordion-body{
  padding:14px 16px 16px;
}

/* Zahlungs-Karten innen */
#ih-home.ih-offer-page .ih-pay-grid{
  display:grid;
  grid-template-columns: 1fr 1fr;
  gap:12px;
  margin-top:10px;
}

#ih-home.ih-offer-page .ih-pay-card{
  border:1px solid rgba(90,74,66,.12);
  border-radius:16px;
  background:rgba(239,233,228,.28);
  padding:14px 14px;
}

@media (max-width:700px){
  #ih-home.ih-offer-page .ih-pay-grid{
    grid-template-columns:1fr;
  }
}
/* ======================================================================
   Klarheitsgespräch ? Hero Bild (scoped)
   Voraussetzung: #ih-home[data-page="klarheitsgespraech"]
   ====================================================================== */

#ih-home[data-page="klarheitsgespraech"] .ih-hero-media{
  margin: 26px auto 22px;
  max-width: 900px;                 /* passt zu euren Kartenbreiten */
  border-radius: 22px;
  overflow: hidden;
  background: rgba(255,255,255,.55);
  box-shadow:
    0 14px 40px rgba(28, 18, 14, .10),
    0  2px  8px rgba(28, 18, 14, .06);
}

#ih-home[data-page="klarheitsgespraech"] .ih-hero-media img{
  display: block;
  width: 100%;
  height: auto;
}

/* Optional: wenn du eine gleichmäßige Bildhöhe willst (wie ein Hero-Crop) */
@media (min-width: 900px){
  #ih-home[data-page="klarheitsgespraech"] .ih-hero-media img{
    height: 520px;                  /* ggf. anpassen */
    object-fit: cover;
    object-position: center;
  }
}
/* ==============================
   NAV Dropdown: Zusammenarbeit
============================== */

.nav-dd{ position:relative; display:inline-block; }

.nav-dd-trigger{
  display:inline-flex;
  align-items:center;
  gap:10px;
}

.nav-dd-trigger::after{
  content:"?";
  font-size:12px;
  line-height:1;
  opacity:.75;
}

.nav-dd-menu{
  position:absolute;
  right:0;
  top:calc(100% + 10px);
  min-width:260px;
  background:#fff;
  border:1px solid rgba(90,74,66,.18);
  border-radius:16px;
  box-shadow:0 18px 40px rgba(0,0,0,.10);
  padding:10px;
  display:none;
  z-index:9999;
}

.nav-dd[data-open="true"] .nav-dd-menu{ display:block; }

.nav-dd-menu a{
  display:block;
  padding:10px 12px;
  border-radius:12px;
  text-decoration:none;
  color:inherit;
}

.nav-dd-menu a:hover{
  background:rgba(90,74,66,.06);
}

.nav-dd-sep{
  height:1px;
  margin:8px 6px;
  background:rgba(90,74,66,.16);
}

/* Mobile: Menü im Panel als Accordion */
.nav-dd--mobile{ width:100%; }
.nav-dd--mobile .nav-dd-menu{
  position:static;
  min-width:0;
  margin-top:10px;
  box-shadow:none;
  border-radius:14px;
}
.nav-dd--mobile .nav-dd-trigger{ width:100%; justify-content:center; }
.nav-dd-trigger{
  font-weight: inherit;
}

/* 12 Wochen ? Hero Bild wie Klarheitsgespräch */
#ih-home[data-page="12wochen"] .ih-hero-media{
  margin: 26px auto 22px;
  max-width: 900px;
  border-radius: 22px;
  overflow: hidden;
  background: rgba(255,255,255,.55);
  box-shadow:
    0 14px 40px rgba(28, 18, 14, .10),
    0  2px  8px rgba(28, 18, 14, .06);
}

#ih-home[data-page="12wochen"] .ih-hero-media img{
  display:block;
  width:100%;
  height:auto;
}

/* gleicher Desktop-Crop wie Klarheitsgespräch */
@media (min-width:900px){
  #ih-home[data-page="12wochen"] .ih-hero-media img{
    height:520px;
    object-fit:cover;
    object-position:center;
  }
}
/* ==========================================
   12 WOCHEN ? PHASEN KARTEN
========================================== */

.ih-steps-phases{
  margin-top:28px;
  gap:22px;
}

/* Karte vorbereiten */
.ih-phase-card{
  position:relative;
  padding-top:36px;
}

/* Badge links oben */
.ih-phase-badge{
  position:absolute;
  top:-14px;
  left:22px;

  background:#fafafa;
  color:#6A5446;

  font-family:"Cormorant Garamond", serif;
  font-size:15px;
  letter-spacing:.12em;

  padding:6px 14px;
  border-radius:999px;

  border:1px solid rgba(0,0,0,0.05);

  box-shadow:0 6px 14px rgba(0,0,0,0.05);
}

/* Überschrift minimal Abstand */
.ih-phase-card h3{
  margin-top:4px;
}
/* ==========================================================================
   12 WOCHEN ? ANMELDUNG FORMULAR (wie Kontakt-Formulare, aber für Offer-Seite)
   Scope: #ih-home.ih-offer-page (damit es nicht global alles überschreibt)
   ========================================================================== */

#ih-home.ih-offer-page #anmeldung .ih-form-card{
  background: rgba(255,255,255,78);
  border: 1px solid var(--line);
  box-shadow: var(--shadow);
  border-radius: var(--radius-xl);
  padding: clamp(18px, 2.5vw, 28px);
}

#ih-home.ih-offer-page #anmeldung .ih-form-title{
  font-family: var(--font-serif);
  font-weight: 600;
  font-size: 28px;
  line-height: 1.15;
  margin: 0 0 12px;
}

#ih-home.ih-offer-page #anmeldung .ih-form{
  margin-top: 14px;
}

#ih-home.ih-offer-page #anmeldung .ih-row{
  display: flex;
  flex-direction: column;
  gap: 8px;
  margin-bottom: 12px;
}

#ih-home.ih-offer-page #anmeldung .ih-label{
  font-family: var(--font-serif);
  font-weight: 500;
  letter-spacing: .02em;
  color: var(--espresso);
  font-size: 15px;
}

/* Inputs + Select + Textarea */
#ih-home.ih-offer-page #anmeldung .ih-input,
#ih-home.ih-offer-page #anmeldung select.ih-input,
#ih-home.ih-offer-page #anmeldung .ih-textarea{
  width: 100%;
  border-radius: 14px;
  border: 1px solid rgba(90,74,66,22);
  background: rgba(255,255,255,95);
  color: var(--espresso);
  font-family: var(--font-body);
  font-size: 16px;
  padding: 12px 14px;
  outline: none;
  box-shadow: none;
}

#ih-home.ih-offer-page #anmeldung .ih-input:focus,
#ih-home.ih-offer-page #anmeldung .ih-textarea:focus{
  border-color: rgba(90,74,66,45);
  box-shadow: 0 0 0 4px rgba(234,214,208,55);
}

#ih-home.ih-offer-page #anmeldung .ih-textarea{
  resize: vertical;
  min-height: 130px;
}

/* Checkbox */
#ih-home.ih-offer-page #anmeldung .ih-check{
  margin-top: 6px;
}

#ih-home.ih-offer-page #anmeldung .ih-checkbox{
  display: flex;
  gap: 10px;
  align-items: flex-start;
  font-size: 14px;
  line-height: 1.5;
  color: var(--espresso-80);
}

#ih-home.ih-offer-page #anmeldung .ih-checkbox input{
  margin-top: 3px;
}

/* Actions */
#ih-home.ih-offer-page #anmeldung .ih-actions{
  display: flex;
  gap: 10px;
  flex-wrap: wrap;
  margin-top: 12px;
}

#ih-home.ih-offer-page #anmeldung .ih-privacy{
  margin: 10px 0 0;
}

/* Honeypot verstecken */
#ih-home.ih-offer-page #anmeldung .ih-hp{
  position: absolute;
  left: -9999px;
  width: 1px;
  height: 1px;
  overflow: hidden;
}

/* Mobile: Buttons im Formular untereinander */
@media (max-width:520px){
  #ih-home.ih-offer-page #anmeldung .ih-actions .btn{
    width: 100%;
  }
}
html,
body{
  overflow-x:hidden;
}

body{
  margin:0;
}
/* ==========================================================================
   14) Mobile Feinschliff ? Rand, Hero, Header
   ========================================================================== */

@media (max-width:520px){

  /* Seite optisch breiter, weniger weiße Seitenränder */
  :where(#ih-home, #ih-legal) .ih-container{
    padding-left:12px;
    padding-right:12px;
  }

  /* Hero oben etwas kompakter */
  #ih-home .hero{
    padding-top:28px;
    padding-bottom:8px;
  }

  /* Hero-Inhalt luftiger, aber enger am Rand */
  #ih-home .hero-card{
    padding-top:0;
  }

  /* Überschrift auf Mobile etwas harmonischer */
  #ih-home h1{
    font-size:34px;
    line-height:1.08;
    letter-spacing:-0.01em;
  }

  /* Divider etwas kürzer, damit er besser wirkt */
  #ih-home .divider{
    width:140px;
    margin:22px auto 20px;
  }

  /* Hero-Bild breiter und etwas niedriger für Mobile */
  #ih-home .hero-media{
    min-height:250px;
    border-radius:20px;
    margin-left:-2px;
    margin-right:-2px;
  }

  #ih-home .hero-media .img{
    background-position:center center;
    background-size:cover;
  }

  /* Header kompakter */
  #ih-home header,
  #ih-legal header{
    padding-top:10px;
    padding-bottom:10px;
  }

  /* Navigation enger setzen */
  #ih-home .nav,
  #ih-legal .nav{
    min-height:auto;
  }

  /* Branding etwas kleiner */
  #ih-home .brand-name,
  #ih-legal .brand-name{
    font-size:clamp(22px, 6vw, 30px);
    letter-spacing:.08em;
  }

  /* Logo und Burger etwas kompakter */
  #ih-home .brand-mark,
  #ih-legal .brand-mark{
    width:44px;
    height:44px;
  }

  #ih-home .nav-toggle,
  #ih-legal .nav-toggle{
    width:44px;
    height:44px;
    min-width:44px;
    min-height:44px;
  }
}

/* Außenfläche nicht weiß wirken lassen */
html,
body{
  background:#EFE9E4;
}
@media (max-width: 980px){
  :where(#ih-home, #ih-legal) nav.nav{
    display:flex;
    flex-wrap:nowrap;
    align-items:center;
    justify-content:space-between;
    gap:12px;
    min-height:auto;
  }

  :where(#ih-home, #ih-legal) .brand{
    flex:1 1 auto;
    min-width:0;
  }

  :where(#ih-home, #ih-legal) .nav-toggle{
    flex:0 0 auto;
    margin-left:auto;
  }
}
@media (max-width: 520px){
  :where(#ih-home, #ih-legal) .brand-name{
    font-size:16px;
    letter-spacing:.03em;
  }

  :where(#ih-home, #ih-legal) .brand{
    gap:10px;
  }
}
/* ================================
   MOBILE – Container enger
================================ */

@media (max-width: 600px){

  :where(#ih-home, #ih-legal) .ih-container{
    padding-left:8px;
    padding-right:8px;
  }

}
@media (max-width: 520px){

  /* Allgemeiner Seitenrhythmus etwas kompakter */
  #ih-home section{
    padding:56px 0;
  }

  /* Karten innen enger */
  #ih-home .card{
    padding:20px 18px;
    border-radius:20px;
  }

  /* Hero-/Content-Karten auf Newsletter- und Angebotsseiten */
  #ih-home .hero-card,
  #ih-home.ih-nl-page .hero-card,
  #ih-home.ih-offer-page #anmeldung .ih-form-card,
  #ih-home.ih-contact-page .ih-form-card{
    padding:16px 14px;
    border-radius:20px;
  }

  /* Formularfelder etwas kompakter */
  #ih-home.ih-offer-page #anmeldung .ih-input,
  #ih-home.ih-offer-page #anmeldung select.ih-input,
  #ih-home.ih-offer-page #anmeldung .ih-textarea,
  #ih-home.ih-contact-page .ih-input,
  #ih-home.ih-contact-page .ih-textarea{
    padding:11px 12px;
    font-size:16px;
    border-radius:12px;
  }

  /* Große Überschriften zähmen */
  #ih-home h1{
    font-size:34px;
    line-height:1.08;
  }

  #ih-home h2,
  #ih-home .hero-title,
  #ih-home.ih-nl-page .hero-title{
    font-size:28px;
    line-height:1.12;
  }

  #ih-home .card h3,
  #ih-home.ih-offer-page .ih-form-title,
  #ih-home.ih-contact-page .ih-form-title{
    font-size:22px;
    line-height:1.15;
    margin-bottom:10px;
  }

  /* Fließtext leicht kleiner für mehr Ruhe */
  #ih-home p,
  #ih-home .card p,
  #ih-home .mini,
  #ih-home .card li{
    font-size:17px;
    line-height:1.55;
  }

  /* Buttons auf Mobile harmonischer */
  #ih-home .btn{
    min-height:52px;
    padding:14px 18px;
    font-size:16px;
  }

  /* Newsletter-/Brevo-Formular innen nicht zu schmal wirken lassen */
  #ih-home.ih-nl-page .nl-signup{
    padding-left:0;
    padding-right:0;
  }
}

/* =================================
   Mobile Menü – sauber auf bestehender nav-mobile Basis
================================= */

@media (max-width:980px){

  #ih-home nav.nav{
    position:relative;
    display:flex;
    align-items:center;
    justify-content:space-between;
    flex-wrap:nowrap;
    gap:12px;
  }

  #ih-home .brand{
    flex:1 1 auto;
    min-width:0;
  }

  #ih-home .nav-toggle{
    width:48px;
    height:48px;
    min-width:48px;
    min-height:48px;
    margin-left:auto;
    display:inline-flex !important;
    align-items:center;
    justify-content:center;
    position:relative;
    z-index:10003;
  }

  /* Mobile Panel: vorhandene nav-mobile Regeln nutzen, nur Positionierung ändern */
  #ih-home #ih-mobile-nav.nav-mobile{
    position:absolute;
    top:calc(100% + 14px);
    left:50%;
    right:auto;
    width:min(420px, calc(100vw - 32px));
    max-width:calc(100vw - 32px);
    margin-top:0;
    transform:translateX(-50%) translateY(-10px) scale(.98);
    z-index:10002;
  }

  /* Sichtbarer Zustand basiert weiter auf hidden/not([hidden]) */
  #ih-home #ih-mobile-nav.nav-mobile:not([hidden]){
    opacity:1;
    visibility:visible;
    pointer-events:auto;
    transform:translateX(-50%) translateY(0) scale(1);
  }

  /* Versteckter Zustand */
  #ih-home #ih-mobile-nav.nav-mobile[hidden]{
    display:none !important;
  }

  /* Hamburger ? X */
  #ih-home .nav-toggle-bars{
    width:22px;
    height:2px;
    background:rgba(90,74,66,.85);
    position:relative;
    display:block;
    border-radius:999px;
    transition:
      background .22s ease,
      transform .22s ease;
  }

  #ih-home .nav-toggle-bars::before,
  #ih-home .nav-toggle-bars::after{
    content:"";
    position:absolute;
    left:0;
    width:22px;
    height:2px;
    background:rgba(90,74,66,.85);
    border-radius:999px;
    transition:
      transform .22s ease,
      top .22s ease,
      opacity .18s ease;
  }

  #ih-home .nav-toggle-bars::before{
    top:-7px;
  }

  #ih-home .nav-toggle-bars::after{
    top:7px;
  }

  #ih-home .nav-toggle[aria-expanded="true"] .nav-toggle-bars{
    background:transparent;
  }

  #ih-home .nav-toggle[aria-expanded="true"] .nav-toggle-bars::before{
    top:0;
    transform:rotate(45deg);
  }

  #ih-home .nav-toggle[aria-expanded="true"] .nav-toggle-bars::after{
    top:0;
    transform:rotate(-45deg);
  }
}

/* Overlay */
body.ih-menu-open::before{
  content:"";
  position:fixed;
  inset:0;
  background:rgba(90,74,66,.18);
  backdrop-filter:blur(3px);
  -webkit-backdrop-filter:blur(3px);
  z-index:10000;
}

body.ih-menu-open{
  overflow:hidden;
}

/* Header und Menü über dem Overlay */
#ih-home header{
  position:sticky;
  z-index:10001;
}

@media (max-width:980px){
  #ih-home #ih-mobile-nav.nav-mobile{
    z-index:10002;
  }

  #ih-home .nav-toggle{
    z-index:10003;
  }
}
/* ==========================================================
   PAGE FIXES – Angebotsseiten
   Klarheitsgespräch (365) + 12 Wochen Programm (419)
   ========================================================== */

body.page-id-365 #ih-home .hero-card,
body.page-id-419 #ih-home .hero-card{
  width:100%;
  max-width:100%;
  padding-left:0;
  padding-right:0;
}

body.page-id-365 #ih-home .ih-offer-hero,
body.page-id-419 #ih-home .ih-offer-hero{
  width:100%;
  max-width:100%;
}

/* Mobile Sicherheit – verhindert schmalere Karten */
@media (max-width:520px){

  body.page-id-365 #ih-home .hero-card,
  body.page-id-419 #ih-home .hero-card{
    padding-left:0 !important;
    padding-right:0 !important;
  }

}
/* ==========================================================================
   MAREN / ÜBER MICH – TESTIMONIALS
   ========================================================================== */

.ih-about-testimonials {
  padding-top: clamp(28px, 4vw, 52px);
  padding-bottom: clamp(40px, 5vw, 72px);
}

.ih-about-testimonials .kicker {
  margin-bottom: 10px;
}

.ih-about-testimonials h2 {
  margin-bottom: 14px;
}

.ih-about-testimonials .lead {
  max-width: 720px;
  margin-bottom: clamp(28px, 4vw, 40px);
}

.ih-testimonial-list {
  display: grid;
  gap: 24px;
  margin-top: 40;
max-width: 720px;
  margin: 0 auto;
}

.ih-testimonial-card {
  position: relative;
  background: linear-gradient(180deg, rgba(255, 250, 247, 0.88) 0%, rgba(250, 240, 234, 0.78) 100%);
  border: 1px solid rgba(90, 70, 60, 0.12);
  border-radius: 24px;
  padding: clamp(24px, 3.2vw, 34px);
  box-shadow: 0 10px 30px rgba(60, 40, 30, 0.08);
  backdrop-filter: blur(3px);
  -webkit-backdrop-filter: blur(3px);
}

.ih-testimonial-card::before {
  content: "“";
  position: absolute;
  top: 12px;
  left: 18px;
  font-family: "Cormorant Garamond", serif;
  font-size: 5rem;
  line-height: 1;
  color: rgba(123, 92, 74, 0.14);
  pointer-events: none;
}

.ih-testimonial-head {
  position: relative;
  z-index: 1;
  margin-bottom: 14px;
}

.ih-testimonial-head h3 {
  margin: 0;
  font-family: "Cormorant Garamond", serif;
   font-size: clamp(1.7rem, 2.5vw, 2.1rem);
  line-height: 1.1;
  color: var(--ih-espresso, #5c4438);
  letter-spacing: 0.01em;
}

.ih-testimonial-card blockquote {
  position: relative;
  z-index: 1;
  margin: 0;
  padding: 0;
  border: 0;
}

.ih-testimonial-card blockquote p {
  margin: 0 0 1em;
  color: var(--ih-text, #4f4038);
  font-size: 1rem;
  line-height: 1.8;
}

.ih-testimonial-card blockquote p:last-child {
  margin-bottom: 0;
}

/* Feiner Trenner zwischen den Karten – optional über Luft statt Linie */
.ih-testimonial-card + .ih-testimonial-card {
  margin-top: 0;
}

/* Mobile Feinschliff */
@media (max-width: 767px) {
  .ih-about-testimonials {
    padding-top: 24px;
    padding-bottom: 40px;
  }

  .ih-testimonial-list {
    gap: 18px;
  }

  .ih-testimonial-card {
    border-radius: 20px;
    padding: 22px 18px 20px;
  }

  .ih-testimonial-card::before {
    top: 10px;
    left: 14px;
    font-size: 3.3rem;
  }

  .ih-testimonial-head {
    margin-bottom: 10px;
  }

  .ih-testimonial-head h3 {
    font-size: 1.45rem;
  }

  .ih-testimonial-card blockquote p {
    font-size: 0.98rem;
    line-height: 1.75;
  }
}
.ih-testimonial-card {
  transition: transform 0.35s ease, box-shadow 0.35s ease;
}

.ih-testimonial-card:hover {
  transform: translateY(-4px);
  box-shadow: 0 18px 45px rgba(60,40,30,0.12);
}