/**************************************************************
   FACTLens — Konsistenz-Styles (ergänzend/ersetzend)
   **************************************************************/

/* 1) Grundfarben / Spacing (bereits vorhanden – nur Ergänzungen) */
:root{
  --white:#FFFFFF;
  --sage:#7FA08C;
  --mango:#FFA726;
  --moss:#2A3329;
  --deep-moss:#1A2A21;
  --black:#000000;

  --container:980px;
  --radius:12px;
  --pad:24px;

  --border:#e7e9e7;
  --muted:#5a5f5b;
  --bg-soft:#fcfdfb;
  --nav-h: 70px;          /* fixed nav height desktop */
  --anchor-gap: 12px;     /* visual breathing space */
}

/* 2) Baselines (vereinheitlicht) */
*{box-sizing:border-box}
html{scroll-behavior:smooth}
html,body{margin:0;padding:0;background:var(--white);color:var(--deep-moss)}
body{font-family:system-ui,-apple-system,Segoe UI,Roboto,"Helvetica Neue",Arial,"Noto Sans";line-height:1.6;padding-top:70px}
h1,h2,h3{font-weight:800;line-height:1.2;margin:0 0 .5em;color:var(--moss)}
h1{font-size:clamp(2rem,4vw,3rem)}
h2{font-size:clamp(1.35rem,2.4vw,1.9rem)}
p,li{font-size:1.03rem;color:var(--deep-moss)}
a{color:var(--deep-moss);text-decoration:none}
a:hover{color:var(--mango)}
.container{max-width:var(--container);margin:0 auto;padding-inline:var(--pad)}
.muted{opacity:.9;color:var(--muted)}
.tag{display:inline-block;font-size:.82rem;padding:.25rem .6rem;border:1px solid var(--border);border-radius:999px;background:#fafaf9}
.divider{height:1px;background:var(--border);margin:32px auto;width:100%}
.hero{padding-top:48px;padding-bottom:8px}
.headline .accent{color:var(--sage)}
.accent-dark{color:var(--moss)}
.logo{max-width:225px;height:auto;margin-bottom:20px;display:block}

/* 3) Navigation (wie bisher, kleine Verfeinerungen) */
nav{position:fixed;top:0;left:0;right:0;background:rgba(255,255,255,.97);backdrop-filter:blur(10px);border-bottom:1px solid var(--border);z-index:1000}
nav .container{display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:16px;padding:12px 24px}
nav .nav-logo{max-width:120px;height:auto}
nav ul{list-style:none;margin:0;padding:0;display:flex;flex-wrap:wrap;gap:20px;align-items:center;justify-content:flex-end;flex-grow:1}
nav ul li a{font-size:.95rem;font-weight:600;transition:color .2s}
nav ul li a:hover{color:var(--mango)}
nav ul li a.active{color:var(--mango);text-decoration:underline}
@media (max-width:900px){nav ul{justify-content:center;margin-top:8px}nav .nav-logo{margin:0 auto}}
@media (max-width:759px){nav ul{gap:16px;font-size:.85rem}body{padding-top:60px}}

/* 4) Mood Images – EINHEITLICH (bitte alte Duplikate entfernen) */
.mood-img{
  width:100%;
  display:block;
  aspect-ratio:30/7;        /* ~1200×280 */
  object-fit:cover;
  object-position:center;
  border-radius:var(--radius);
  margin:24px 0;
  background:linear-gradient(135deg,#7FA08C22 0%,#FFA72622 100%);
  border:2px dashed var(--border);
  color:#9ca39d;font-size:.9rem;font-weight:600;
  display:flex;align-items:center;justify-content:center;
}
.mood-img-hero{aspect-ratio:16/5;margin:32px 0}
.mood-img-small{aspect-ratio:29/10}

/* 5) Cards – links, ruhig, konsistent */
.card{
  border:1px solid var(--border);
  border-radius:var(--radius);
  background:var(--bg-soft);
  padding:18px;
  text-align:left;      /* erzwingt linke Ausrichtung */
}
.list{padding-left:1.25rem}
.list li{margin:.35rem 0}

/* 6) CTAs – linksbündig, klare Kontraste */
.cta{
  display:inline-block;
  margin-top:10px;
  padding:.75rem 1rem;
  border-radius:10px;
  background:var(--sage);
  color:var(--white);
  font-weight:700;
  border:0;
  transition:all .2s ease-in-out;
}
.cta:hover{background:var(--mango);color:var(--moss)}           /* lesbar auf Orange */
.cta:focus{outline:2px solid var(--mango);outline-offset:2px}

.cta-secondary{
  background:#f7f7f7;
  color:var(--moss);
  border:1px solid var(--border);
}
.cta-secondary:hover{background:var(--mango);color:var(--white)}

/* 7) Formulare – ruhig, unaufgeregt */
input[type="text"],input[type="email"],textarea,select{
  width:100%;
  padding:.6rem .7rem;
  border:1px solid #ccc;
  border-radius:8px;
  font:inherit;
  color:var(--deep-moss);
  background:#fff;
}
input:focus,textarea:focus,select:focus{
  outline:2px solid #ffd59a;         /* softer Mango-Fokus */
  border-color:#e6b16e;
}

/* 8) Footer – neu, 4 Spalten */
footer.site-footer{
  border-top:1px solid var(--border);
  margin-top:48px;              /* Abstand zum Content */
  padding:64px 24px 24px;       /* mehr Luft nach oben */
  background:#f8f9f8;           /* leichte Abhebung */
  color:var(--muted);
  font-size:.95rem;
}
.footer-grid{
  display:grid;gap:20px;
  grid-template-columns:1.3fr 1fr 1fr 1fr;
}
.footer-col h4{
  margin:.2rem 0 .6rem;
  font-size:1rem;
  color:var(--moss);
}
.footer-meta{font-weight:800;letter-spacing:.2px;color:var(--moss);margin-top:6px}
.footer-bottom{margin-top:16px;font-size:.9rem;opacity:.9}
.footer-logo{max-width:150px;height:auto;margin-bottom:8px}
.footer-links{list-style:none;margin:0;padding:0}
.footer-links li{margin:.25rem 0}
.footer-links a{color:var(--deep-moss)}
.footer-links a:hover{color:var(--mango)}

@media (max-width:900px){
  .footer-grid{grid-template-columns:1fr 1fr}
}
@media (max-width:560px){
  .footer-grid{grid-template-columns:1fr}
}

/* =========================================================
   Footer: 5-Spalten-Layout (linke Spalte doppelt breit)
   ========================================================= */
.footer-grid-5{
  display:grid;
  gap:20px;
  grid-template-columns: repeat(5, 1fr); /* 5 gleich breite Spalten */
}
/* Linke Spalte soll zwei Spalten belegen */
.footer-col-wide{
  grid-column: span 2;
}

/* Responsiv: ab 900px zwei Spalten, die breite Spalte über volle Breite */
@media (max-width: 900px){
  .footer-grid-5{
    grid-template-columns: repeat(2, 1fr);
  }
  .footer-col-wide{
    grid-column: 1 / -1; /* volle Breite */
  }
}

/* Auf sehr kleinen Screens eine Spalte */
@media (max-width: 560px){
  .footer-grid-5{
    grid-template-columns: 1fr;
  }
  .footer-col-wide{
    grid-column: 1 / -1;
  }
}

/* =========================================================
   Layout: Grid-Fix für Kontaktbereich (3 Spalten)
   ========================================================= */
   .grid {
    display: grid;
    gap: 24px;
  }
  
  /* Drei Spalten ab mittlerer Breite */
  @media (min-width: 900px) {
    .grid-3 {
      grid-template-columns: repeat(3, 1fr);
    }
  }
  
  /* Zwei Spalten auf Tablets */
  @media (min-width: 600px) and (max-width: 899px) {
    .grid-3 {
      grid-template-columns: repeat(2, 1fr);
    }
  }
  
  /* Eine Spalte auf Smartphones */
  @media (max-width: 599px) {
    .grid-3 {
      grid-template-columns: 1fr;
    }
  }

  .grid{ display:grid; gap:24px; }

@media (min-width:760px){
  .grid-2{ grid-template-columns: 1fr 1fr; }
}

/* =========================================================
   Generic two-column utility (page-agnostic)
   ========================================================= */
   .two-col{ display:grid; gap:24px; }
   @media (min-width:760px){
     .two-col{ grid-template-columns:1fr 1fr; align-items:start; }
     .two-col > h2{ grid-column:1 / -1; margin-bottom:12px; }
     /* default order: 2nd child left, 3rd child right (since 1st is H2) */
     .two-col > :nth-child(2){ grid-column:1; align-self:start; }
     .two-col > :nth-child(3){ grid-column:2; align-self:start; }
     /* swap order when .reverse is present */
     .two-col.reverse > :nth-child(2){ grid-column:2; }
     .two-col.reverse > :nth-child(3){ grid-column:1; }
     /* align images with text top */
     .two-col .mood-img{ margin-top:0; align-self:start; }
     /* tighten first paragraph under H2 */
     .two-col > div > p:first-child{ margin-top:0; }
   }

   /* Header-CTA in der Navi */
.nav-cta{
  display:inline-block;
  padding:.55rem .9rem;
  border-radius:999px;
  background:var(--sage);
  color:var(--white);
  font-weight:800;
  letter-spacing:.2px;
  border:1px solid transparent;
}
.nav-cta:hover{ background:var(--mango); color:var(--moss); }
.nav-cta.active{
  background:var(--mango);
  color:var(--moss);
}

/* Kleine optische Trennung rechts, wenn du später doch ein Kontakt-Icon ergänzen willst */
nav ul { gap: 22px; }

/* =========================================================
   Navigation: Dropdown for "Jetzt Mitmachen"
   ========================================================= */

/* Parent container */
nav ul li.nav-dropdown { position: relative; }

/* Caret indicator on the main CTA */
nav ul li.nav-dropdown > a.nav-cta::after{
  content: "";
  display:inline-block;
  width:6px; height:6px;
  border-right:2px solid var(--white);
  border-bottom:2px solid var(--white);
  transform: rotate(45deg);
  margin-left:8px;
}
nav ul li.nav-dropdown > a.nav-cta:hover::after{
  border-color: var(--moss);
}

/* Dropdown panel */
.dropdown-menu{
  display:none;
  position:absolute;
  top: 100%;
  margin-top: 0;
  right:0;
  min-width: 260px;
  background:#fff;
  border:1px solid var(--border);
  border-radius:10px;
  box-shadow: 0 10px 24px rgba(0,0,0,.08);
  padding:8px;
  z-index: 1200; /* above sticky nav */
}
/* Hover bridge to avoid gap between trigger and dropdown */
nav ul li.nav-dropdown::after{
  content: "";
  position: absolute;
  left: 0; right: 0;
  top: 100%;
  height: 14px;
  pointer-events: auto;
}
.dropdown-menu li{ list-style:none; }
.dropdown-menu a{
  display:block;
  padding:.55rem .7rem;
  border-radius:8px;
  color: var(--deep-moss);
  font-weight:600;
}
.dropdown-menu a:hover{
  background:#f7f7f7;
  color: var(--moss);
}

/* Show on hover/focus for mouse + keyboard */
nav ul li.nav-dropdown:hover > .dropdown-menu,
nav ul li.nav-dropdown:focus-within > .dropdown-menu{ display:block; }

/* Touch-friendly: on small screens render as inline menu without absolute positioning */
@media (max-width: 900px){
  nav ul li.nav-dropdown{ width:100%; }
  nav ul li.nav-dropdown > a.nav-cta{ width:100%; text-align:center; }
  .dropdown-menu{
    position: static;
    box-shadow: none;
    border: 0;
    padding: 6px 0 0;
    margin-top: 4px;
  }
  .dropdown-menu a{ padding:.5rem .75rem; }
}

/* =========================================================
   Anchor offset for fixed navigation (global)
   ========================================================= */
:where(section, header, .container, .two-col, .grid)[id]{
  scroll-margin-top: calc(var(--nav-h) + var(--anchor-gap));
}
:where(h2, h3)[id]{
  scroll-margin-top: calc(var(--nav-h) + var(--anchor-gap));
}
@media (max-width: 759px){
  :root{ --nav-h: 60px; }
}

.calendly-inline-widget {
  border: 1px solid var(--border);
  border-radius: var(--radius);
  background: var(--bg-soft);
  margin-top: 24px;
}

/* Utility: prevent line breaks for specific phrases (e.g., "Kommunikation & Support") */
.nowrap{
  white-space: nowrap;
  word-break: keep-all;
  display: inline-block; /* stabilizes in grid/link contexts */
}

/* Footer links: keep chosen labels on one line when .nowrap is applied */
.footer-links a.nowrap{
  white-space: nowrap;
  word-break: keep-all;
  hyphens: manual;
}

.footer-grid-5 {
  grid-template-columns: repeat(5, minmax(170px, 1fr));
}
@media (max-width: 900px){
  .footer-grid-5 { grid-template-columns: repeat(2, minmax(200px,1fr)); }
}