/*
Theme Name:     Kleo Child
Theme URI:
Description:    Child theme for Kleo
Author:         SeventhQueen
Author URI:     http://seventhqueen.com
Template:       kleo
Tags:  one-column, two-columns, right-sidebar, fluid-layout, custom-menu, featured-images, post-formats, sticky-post, translation-ready
License: GNU General Public License
License URI: license.txt
*/
/* ============================================================
   MCI Coaching — kleo-child Design-System
   Datei: wp-content/themes/kleo-child/assets/mci.css
   Single Source of Truth: CSS-Custom-Properties (Tokens).
   DSGVO: Fonts LOKAL gehostet, KEINE Google-CDN.
   Theme: KLEO 5.5 / PHP 8.3 — WPBakery-frei, Gutenberg-first.
   ============================================================ */

/* ---------- 1. Lokale Fonts (woff2 in kleo-child/fonts/) ---------- */
@font-face {
  font-family: "Inter";
  src: url("../fonts/Inter-roman-var.woff2") format("woff2-variations");
  font-weight: 100 900;
  font-style: normal;
  font-display: swap;
}
@font-face {
  font-family: "Fraunces";
  src: url("../fonts/Fraunces-roman-var.woff2") format("woff2-variations");
  font-weight: 300 900;
  font-style: normal;
  font-display: swap;
}

/* ---------- 2. Design-Tokens ---------- */
:root {
  /* Farben — Grün führt (UI), Navy trägt, Blau = Logo-Anker */
  --mci-gruen:        #1F7A4D;
  --mci-gruen-700:    #185F3C;
  --mci-gruen-soft:   #E7F1EC;
  --mci-navy:         #14385C;
  --mci-navy-800:     #0F2B47;
  --mci-logo-blau:    #0040A0;   /* nur Logo-Nähe / Tech-Grafik */
  --mci-bernstein:    #C8842A;
  --mci-bernstein-700:#A66A1E;

  --mci-ink:          #1C2733;   /* 14,8:1 auf Weiß */
  --mci-ink-muted:    #4A5A68;
  --mci-bg:           #FFFFFF;
  --mci-bg-soft:      #F4F7F5;
  --mci-line:         #E2E8E4;
  --mci-on-dark:      #FFFFFF;
  --mci-on-dark-mut:  #C7D4DE;

  /* Typografie */
  --mci-font-head: "Fraunces", "Source Serif 4", Georgia, serif;
  --mci-font-body: "Inter", system-ui, -apple-system, "Segoe UI", sans-serif;
  --mci-fs-base: 1.125rem;       /* 18px */
  --mci-lh-base: 1.65;
  --mci-measure: 68ch;

  /* Spacing — 8-Punkt-System */
  --sp-1: 4px;  --sp-2: 8px;  --sp-3: 12px; --sp-4: 16px;
  --sp-5: 24px; --sp-6: 32px; --sp-7: 48px; --sp-8: 64px;
  --sp-9: 80px; --sp-10: 96px; --sp-11: 128px;
  --mci-section-y: var(--sp-10);
  --mci-section-y-m: var(--sp-9-mobile, 56px);

  /* Form & Effekt */
  --mci-radius-btn: 10px;
  --mci-radius-card: 14px;
  --mci-shadow-card: 0 10px 30px rgba(20,56,92,.08);
  --mci-shadow-card-hover: 0 16px 40px rgba(20,56,92,.14);
  --mci-content-max: 1120px;
  --mci-focus: 0 0 0 3px var(--mci-bg), 0 0 0 6px var(--mci-gruen);
}

/* ---------- 3. Basis-Typografie ---------- */
body {
  font-family: var(--mci-font-body);
  font-size: var(--mci-fs-base);
  line-height: var(--mci-lh-base);
  color: var(--mci-ink);
  -webkit-font-smoothing: antialiased;
  text-rendering: optimizeLegibility;
}
h1, h2, h3, h4,
.mci-hero h1, .mci-cta-band h2 {
  font-family: var(--mci-font-head);
  color: var(--mci-navy);
  line-height: 1.12;
  letter-spacing: -0.01em;
  font-weight: 600;
}
h1 { font-size: clamp(2.2rem, 1.4rem + 3.2vw, 3.45rem); }
h2 { font-size: clamp(1.7rem, 1.2rem + 2vw, 2.45rem); }
h3 { font-size: clamp(1.3rem, 1.05rem + 1vw, 1.6rem); }
p  { max-width: var(--mci-measure); }
a  { color: var(--mci-gruen); text-decoration-thickness: 1px; text-underline-offset: 2px; }
a:hover { color: var(--mci-gruen-700); }

/* Sichtbarer Fokus überall (WCAG) */
a:focus-visible, button:focus-visible,
.mci-btn:focus-visible, input:focus-visible,
textarea:focus-visible, select:focus-visible {
  outline: none;
  box-shadow: var(--mci-focus);
  border-radius: 6px;
}

/* ---------- 4. Layout / Sektions-Rhythmus ---------- */
.mci-section { padding-block: var(--mci-section-y); }
.mci-section--soft { background: var(--mci-bg-soft); }
.mci-section--navy { background: var(--mci-navy); color: var(--mci-on-dark); }
.mci-section--navy h2,
.mci-section--navy h3 { color: var(--mci-on-dark); }
.mci-wrap { max-width: var(--mci-content-max); margin-inline: auto; padding-inline: var(--sp-5); }

@media (max-width: 781px) {
  .mci-section { padding-block: var(--mci-section-y-m); }
}

/* ---------- 5. Buttons ---------- */
.mci-btn,
.wp-block-button__link {
  display: inline-flex; align-items: center; gap: var(--sp-2);
  font-family: var(--mci-font-body); font-weight: 600; font-size: 1rem;
  padding: 14px 28px; border-radius: var(--mci-radius-btn);
  text-decoration: none; line-height: 1; cursor: pointer;
  transition: transform .15s ease, background-color .15s ease, box-shadow .15s ease;
  border: 2px solid transparent;
}
/* Primär — Grün */
.mci-btn--primary,
.wp-block-button:not(.is-style-outline) .wp-block-button__link {
  background: var(--mci-gruen); color: #fff;
}
.mci-btn--primary:hover,
.wp-block-button:not(.is-style-outline) .wp-block-button__link:hover {
  background: var(--mci-gruen-700); color:#fff; transform: translateY(-2px);
}
/* Sekundär — Navy */
.mci-btn--secondary { background: var(--mci-navy); color:#fff; }
.mci-btn--secondary:hover { background: var(--mci-navy-800); transform: translateY(-2px); }
/* Geist — transparent + Border (auf dunkel oder hell) */
.mci-btn--ghost,
.wp-block-button.is-style-outline .wp-block-button__link {
  background: transparent; color: var(--mci-gruen); border-color: var(--mci-gruen);
}
.mci-section--navy .mci-btn--ghost { color:#fff; border-color: rgba(255,255,255,.6); }
.mci-btn--ghost:hover { background: var(--mci-gruen-soft); }
/* CTA im Hauptmenü */
.mci-menu-cta > a {
  background: var(--mci-gruen) !important; color:#fff !important;
  padding: 10px 20px !important; border-radius: var(--mci-radius-btn) !important;
  font-weight: 600;
}
.mci-menu-cta > a:hover { background: var(--mci-gruen-700) !important; }

/* ---------- 6. Hero ---------- */
.mci-hero {
  position: relative;
  background: linear-gradient(135deg, var(--mci-navy) 0%, var(--mci-navy-800) 40%, var(--mci-gruen-700) 100%);
  color: var(--mci-on-dark);
  padding-block: clamp(72px, 8vw, 132px);
}
.mci-hero h1 { color:#fff; max-width: 18ch; }
.mci-hero .mci-sub {
  font-size: clamp(1.05rem, .95rem + .6vw, 1.3rem);
  color: var(--mci-on-dark-mut); max-width: 56ch; margin-top: var(--sp-4);
}
.mci-hero .mci-cta-row { display:flex; flex-wrap:wrap; gap: var(--sp-4); margin-top: var(--sp-6); }

/* ---------- 7. Trust-Bar ---------- */
.mci-trust-bar {
  display:flex; flex-wrap:wrap; gap: var(--sp-3) var(--sp-6);
  align-items:center; justify-content:center;
  padding-block: var(--sp-5);
}
.mci-trust-bar .mci-badge {
  display:inline-flex; align-items:center; gap: var(--sp-2);
  font-size:.95rem; font-weight:600; color: var(--mci-navy);
  background: var(--mci-gruen-soft); border:1px solid var(--mci-line);
  padding: 8px 14px; border-radius: 999px;
}
.mci-section--navy .mci-trust-bar .mci-badge {
  background: rgba(255,255,255,.08); color:#fff; border-color: rgba(255,255,255,.18);
}

/* ---------- 8. Feature-/Säulen-Grid + Cards ---------- */
.mci-feature-grid {
  display:grid; gap: var(--sp-5);
  grid-template-columns: repeat(auto-fit, minmax(280px, 1fr));
  margin-top: var(--sp-6);
}
.mci-card {
  background: var(--mci-bg); border:1px solid var(--mci-line);
  border-radius: var(--mci-radius-card); padding: var(--sp-6);
  box-shadow: var(--mci-shadow-card);
  transition: transform .18s ease, box-shadow .18s ease;
}
.mci-card:hover { transform: translateY(-4px); box-shadow: var(--mci-shadow-card-hover); }
.mci-card h3 { margin: 0 0 var(--sp-2); }
.mci-card .mci-card-icon {
  width:48px; height:48px; border-radius:12px; display:grid; place-items:center;
  background: var(--mci-gruen-soft); color: var(--mci-gruen); margin-bottom: var(--sp-3);
  font-size:1.4rem;
}
.mci-card p { color: var(--mci-ink-muted); }
.mci-card .mci-card-link { font-weight:600; }

/* ---------- 9. CTA-Band ---------- */
.mci-cta-band {
  background: var(--mci-gruen); color:#fff; text-align:center;
  padding-block: var(--sp-9); border-radius: 0;
}
.mci-cta-band h2 { color:#fff; max-width: 24ch; margin-inline:auto; }
.mci-cta-band p  { color: rgba(255,255,255,.9); margin: var(--sp-3) auto var(--sp-6); }
.mci-cta-band .mci-btn--ghost { color:#fff; border-color:#fff; }
.mci-cta-band .mci-btn--ghost:hover { background: rgba(255,255,255,.12); }
.mci-cta-band .mci-btn--secondary { background: var(--mci-bernstein); }
.mci-cta-band .mci-btn--secondary:hover { background: var(--mci-bernstein-700); }

/* ---------- 10. Zitat / Leitbild (statt Fake-Testimonial) ---------- */
.mci-quote {
  border-left: 4px solid var(--mci-gruen);
  padding: var(--sp-4) var(--sp-6);
  font-family: var(--mci-font-head);
  font-size: clamp(1.2rem, 1.05rem + .8vw, 1.6rem);
  color: var(--mci-navy); line-height: 1.4; max-width: 42ch;
}
.mci-quote cite { display:block; margin-top: var(--sp-3); font-family: var(--mci-font-body);
  font-size: .95rem; font-style: normal; color: var(--mci-ink-muted); }

/* ---------- 11. FAQ (nativer Details-Block) ---------- */
.mci-faq .wp-block-details,
.mci-faq details {
  border:1px solid var(--mci-line); border-radius: 12px;
  padding: var(--sp-4) var(--sp-5); margin-bottom: var(--sp-3); background: var(--mci-bg);
}
.mci-faq summary { font-weight:600; color: var(--mci-navy); cursor:pointer; }
.mci-faq details[open] { background: var(--mci-bg-soft); }

/* ---------- 12. Header (transparent → sticky solid) ---------- */
/* KLEO setzt sticky-Klassen; hier nur Branding-Feinschliff */
.mci-header-solid, .sticky-header.is-stuck, #header.small {
  background: var(--mci-bg) !important;
  box-shadow: 0 2px 16px rgba(20,56,92,.08);
}

/* ---------- 13. Footer (Navy, 4 Spalten) ---------- */
#footer, .mci-footer {
  background: var(--mci-navy) !important; color: var(--mci-on-dark-mut);
}
#footer a, .mci-footer a { color:#fff; }
#footer a:hover, .mci-footer a:hover { color: var(--mci-gruen-soft); }
.mci-footer h4 { color:#fff; font-family: var(--mci-font-body); font-size:1rem;
  text-transform:uppercase; letter-spacing:.04em; }

/* ---------- 14. FluentForms-Wrapper ---------- */
.mci-form .ff-el-input--content input,
.mci-form .ff-el-input--content textarea,
.mci-form .ff-el-input--content select {
  border:1px solid var(--mci-line); border-radius:10px; padding:12px 14px;
  font-family: var(--mci-font-body); font-size:1rem; width:100%;
}
.mci-form .ff-el-input--content input:focus,
.mci-form .ff-el-input--content textarea:focus { box-shadow: var(--mci-focus); border-color: var(--mci-gruen); }
.mci-form .ff-btn-submit { background: var(--mci-gruen); border-radius: var(--mci-radius-btn);
  padding:14px 28px; font-weight:600; border:none; }
.mci-form .ff-btn-submit:hover { background: var(--mci-gruen-700); }

/* ---------- 15. Utilities ---------- */
.mci-lead { font-size: clamp(1.1rem,1rem+.5vw,1.35rem); color: var(--mci-ink-muted); max-width:56ch; }
.mci-eyebrow { text-transform:uppercase; letter-spacing:.08em; font-size:.8rem; font-weight:700;
  color: var(--mci-gruen); margin-bottom: var(--sp-2); }
.mci-section--navy .mci-eyebrow { color: var(--mci-gruen-soft); }

/* ---------- 16. Reduced Motion ---------- */
@media (prefers-reduced-motion: reduce) {
  *, .mci-card, .mci-btn, .wp-block-button__link { transition: none !important; }
  .mci-card:hover, .mci-btn:hover { transform: none; }
}

/* ---- Full-Bleed + Homepage-Layout (MCI) ---- */
html,body{overflow-x:hidden;}
.mci-fullbleed{width:100vw;margin-left:calc(50% - 50vw);margin-right:calc(50% - 50vw);}
.mci-hero,.mci-cta-band,.mci-section--navy,.mci-section--soft{width:100vw;margin-left:calc(50% - 50vw);margin-right:calc(50% - 50vw);}
.home #sidebar,.home .sidebar,.home aside.sidebar{display:none!important;}
.mci-hero ul,.mci-section--navy ul{list-style:none;padding-left:0;}
.mci-section--navy li{padding:6px 0;border-bottom:1px solid rgba(255,255,255,.12);}

/* ---- Header-Logo (MCI) ---- */
#logo_img{max-height:50px;width:auto;}
.navbar-resize.small #logo_img{max-height:40px;}
strong.logo a{display:inline-flex;align-items:center;}
