/* =============================================================
   Mimikama Education – Theme-CSS v1.0.0
   Frische Petrol-Palette (hell + dunkel), Poppins, Tabler Icons
   ============================================================= */

:root {
  --bg: #141C1C; --surface: #1C2828; --teal: #4FB3A8; --teal-soft: #1E3230;
  --coral: #F08A6E; --coral-soft: #2E2622; --amber: #F2B84B; --amber-soft: #2E2A20;
  --ink: #EAEFEE; --gray: #9AA8A6; --line: #2A3838;
  --hero-bg: #1C2828; --logo-bg: #fff; --logo-pad: 5px 8px;
}
[data-theme="dark"] {
  --bg: #141C1C; --surface: #1C2828; --teal: #4FB3A8; --teal-soft: #1E3230;
  --coral: #F08A6E; --coral-soft: #2E2622; --amber: #F2B84B; --amber-soft: #2E2A20;
  --ink: #EAEFEE; --gray: #9AA8A6; --line: #2A3838;
  --hero-bg: #1C2828; --logo-bg: #fff; --logo-pad: 5px 8px;
}

body { background: var(--bg); color: var(--ink); font-family: 'Poppins', sans-serif; line-height: 1.6; margin: 0; }
a { text-decoration: none; }
* { box-sizing: border-box; }

/* ---------- Header ---------- */
.mke-header { background: var(--surface); position: sticky; top: 0; z-index: 100; box-shadow: 0 1px 0 var(--line); }
.mke-header-inner { width: 100%; margin: 0; padding: 1.3rem 60px; display: flex; justify-content: space-between; align-items: center; gap: 2rem; }
.mke-logo { display: flex; align-items: center; }
.mke-logo img { display: block; height: 64px; width: auto; }
.mke-logo .logo-dunkel { display: none; }
[data-theme="dark"] .mke-logo .logo-hell { display: none; }
[data-theme="dark"] .mke-logo .logo-dunkel { display: block; }
.mke-header nav, .mke-header .wp-block-navigation { margin-left: auto; }
.mke-header .wp-block-navigation { font-size: 0.9rem; font-weight: 500; }
.mke-header .wp-block-navigation a { color: #5f6b6a; }
.mke-header .wp-block-navigation a:hover { color: var(--teal); }
[data-theme="dark"] .mke-header .wp-block-navigation a { color: var(--gray); }
.mke-header .wp-block-navigation .mke-nav-cta a,
.mke-header a.nav-cta { background: var(--teal); color: #fff !important; padding: 0.55rem 1.3rem; border-radius: 30px; }
/* Navigation-Block: Overlay-/Burger-Farben */
.wp-block-navigation__responsive-container.is-menu-open { background: var(--surface) !important; }
.wp-block-navigation__responsive-container-open,
.wp-block-navigation__responsive-container-close { color: var(--ink) !important; }
#mke-theme-toggle { background: none; border: 1px solid var(--line); border-radius: 20px; width: 40px; height: 32px; cursor: pointer; color: var(--gray); font-size: 1rem; display: inline-flex; align-items: center; justify-content: center; }

.wp-block-navigation__submenu-container { background: var(--surface) !important; border: 1px solid var(--line) !important; border-radius: 12px !important; }
.wp-block-navigation__submenu-container a { color: #5f6b6a !important; }
.wp-block-navigation__submenu-container a:hover { color: var(--teal) !important; }

/* ---------- Startseiten-Hero (30/70) ---------- */
.hero { display: grid; grid-template-columns: 30fr 70fr; min-height: 520px; background: var(--hero-bg); }
.hero-text { display: flex; align-items: center; padding: 3rem 2.5rem; }
.eyebrow { display: inline-block; background: var(--coral-soft); color: var(--coral); font-size: 0.72rem; letter-spacing: 1.5px; text-transform: uppercase; font-weight: 600; padding: 6px 16px; border-radius: 20px; margin-bottom: 1.2rem; }
.hero h1 { color: var(--ink); font-size: 2.4rem; line-height: 1.1; font-weight: 700; letter-spacing: -1px; margin: 0 0 1.2rem; }
.hero h1 .hl { color: var(--teal); }
.hero p { color: var(--gray); font-size: 1.08rem; max-width: 38ch; margin-bottom: 2rem; }


  /* Hero-Slider */
  .hero-img { position: relative; overflow: hidden; }
  .hero-slide { position: absolute; inset: 0; background-size: cover; background-position: center; opacity: 0; transition: opacity 1.2s ease; }
  .hero-slide.active { opacity: 1; }
  .hero-dots { position: absolute; bottom: 16px; left: 50%; transform: translateX(-50%); display: flex; gap: 8px; z-index: 5; }
  .hero-dot { width: 9px; height: 9px; border-radius: 50%; background: rgba(255,255,255,0.55); border: none; cursor: pointer; padding: 0; transition: background 0.2s, transform 0.2s; }
  .hero-dot.active { background: #fff; transform: scale(1.25); }
  @media (prefers-reduced-motion: reduce) { .hero-slide { transition: none; } }
  .hero-slide.s1 { background-image: url('../images/slide1-dunkel.jpg'); }
  [data-theme="dark"] .hero-slide.s1 { background-image: url('../images/slide1-dunkel.jpg'); }
  .hero-slide.s2 { background-image: url('../images/slide2-dunkel.jpg'); }
  [data-theme="dark"] .hero-slide.s2 { background-image: url('../images/slide2-dunkel.jpg'); }
  .hero-slide.s3 { background-image: url('../images/slide3-dunkel.jpg'); }
  [data-theme="dark"] .hero-slide.s3 { background-image: url('../images/slide3-dunkel.jpg'); }
  .hero-slide.s4 { background-image: url('../images/slide4-dunkel.jpg'); }
  [data-theme="dark"] .hero-slide.s4 { background-image: url('../images/slide4-dunkel.jpg'); }
  .hero-slide.s5 { background-image: url('../images/slide5-dunkel.jpg'); }
  [data-theme="dark"] .hero-slide.s5 { background-image: url('../images/slide5-dunkel.jpg'); }

/* ---------- Unterseiten-Heros ---------- */
.page-hero { background: var(--teal-soft); padding: 3.5rem 24px 3rem; text-align: center; }
.page-hero .eyebrow, .profile-text .eyebrow { display: inline-block; background: var(--coral-soft); color: var(--coral); font-size: 0.72rem; letter-spacing: 1.5px; text-transform: uppercase; font-weight: 600; padding: 6px 16px; border-radius: 20px; margin-bottom: 1.2rem; }
.page-hero h1 { font-size: 2.4rem; font-weight: 700; color: var(--ink); letter-spacing: -1px; max-width: 22ch; margin: 0 auto 1rem; line-height: 1.12; }
.page-hero .subtitle { color: var(--teal); font-size: 1.15rem; font-weight: 600; margin: 0 auto; }

.profile-hero { background: var(--teal-soft); padding: 3.5rem 24px 3rem; }
.profile-inner { max-width: 1080px; margin: 0 auto; display: grid; grid-template-columns: 1.4fr 1fr; gap: 3rem; align-items: center; }
.profile-text h1 { font-size: 3rem; font-weight: 700; color: var(--ink); letter-spacing: -1.5px; line-height: 1.05; margin: 0 0 0.8rem; }
.profile-text .subtitle { color: var(--teal); font-size: 1.25rem; font-weight: 600; line-height: 1.4; margin-bottom: 1.6rem; max-width: 26ch; }
.profile-img { position: relative; justify-self: center; }
.profile-img::before { content: ""; position: absolute; inset: 18px -18px -18px 18px; background: var(--coral-soft); border-radius: 28px; z-index: 0; }
.profile-img img { position: relative; z-index: 1; display: block; width: 100%; max-width: 340px; border-radius: 24px; box-shadow: 0 18px 45px rgba(36,52,51,0.18); }

/* ---------- Bekannt-aus / Trust ---------- */
.trust { background: var(--bg); padding: 1.4rem 24px; }
.trust-inner { max-width: 1240px; margin: 0 auto; display: flex; gap: 1.8rem; flex-wrap: wrap; align-items: center; justify-content: center; }
.trust-label { font-size: 0.7rem; color: #AEB5B4; letter-spacing: 1.5px; font-weight: 600; }
.tv-row { display: flex; align-items: center; gap: 2rem; flex-wrap: wrap; justify-content: center; }
.tv-logo { height: 28px !important; width: auto !important; opacity: 0.5; transition: opacity 0.2s; }
.tv-logo:hover { opacity: 0.9; }
[data-theme="dark"] .tv-logo { opacity: 0.65; filter: invert(0.85); }

/* ---------- KI-Block (Startseite) ---------- */
.ki-section { padding: 3.5rem 24px 1rem; }
.ki { max-width: 1240px; margin: 0 auto; background: linear-gradient(125deg, #FF9D7E 0%, var(--coral) 100%); border-radius: 28px; padding: 3rem; display: flex; gap: 2.5rem; align-items: center; }
.ki-text { flex: 1; }
.ki-badge { display: inline-block; background: rgba(255,255,255,0.25); color: #fff; font-size: 0.72rem; letter-spacing: 1.5px; text-transform: uppercase; font-weight: 600; padding: 6px 16px; border-radius: 20px; margin-bottom: 1rem; }
.ki h2 { color: #fff; font-size: 1.9rem; font-weight: 700; letter-spacing: -0.5px; margin: 0 0 0.8rem; }
.ki p { color: rgba(255,255,255,0.92); font-size: 1.02rem; line-height: 1.6; margin-bottom: 1.4rem; }
.ki-icon-box { flex-shrink: 0; width: 130px; height: 130px; border-radius: 28px; background: rgba(255,255,255,0.18); display: flex; align-items: center; justify-content: center; font-size: 4rem; color: #fff; }

/* ---------- Karten-Raster (Startseite) ---------- */
.section-head { text-align: center; max-width: 720px; margin: 3.5rem auto 0; padding: 0 24px; }
.section-head h2 { font-size: 1.9rem; font-weight: 700; color: var(--ink); letter-spacing: -0.5px; margin: 0 0 0.4rem; }
.section-head p { color: var(--gray); margin: 0; }
.cards { max-width: 1240px; margin: 2rem auto 0; padding: 0 24px; display: grid; grid-template-columns: repeat(3, 1fr); gap: 1.2rem; }
.card { background: var(--surface); border: 1px solid var(--line); border-radius: 20px; padding: 1.8rem; transition: transform 0.15s, box-shadow 0.15s; }
.card:hover { transform: translateY(-3px); box-shadow: 0 12px 30px rgba(36,52,51,0.08); }
.card-icon { width: 48px; height: 48px; border-radius: 14px; display: inline-flex; align-items: center; justify-content: center; font-size: 1.4rem; margin-bottom: 1rem; }
.card-icon.teal { background: var(--teal-soft); color: var(--teal); }
.card-icon.coral { background: var(--coral-soft); color: var(--coral); }
.card-icon.amber { background: var(--amber-soft); color: #9A7222; }
[data-theme="dark"] .card-icon.amber { color: var(--amber); }
.card h3 { font-size: 1.1rem; font-weight: 600; color: var(--ink); margin: 0 0 0.5rem; }
.card p { font-size: 0.92rem; color: var(--gray); line-height: 1.6; margin: 0 0 0.8rem; }
.card-link { font-size: 0.88rem; color: var(--teal); font-weight: 600; }

/* ---------- Zahlen-Leiste ---------- */
.stats-section { padding: 3.5rem 24px 1rem; }
.stats { max-width: 1240px; margin: 0 auto; background: var(--teal-soft); border-radius: 24px; padding: 2.2rem 2rem; display: grid; grid-template-columns: repeat(4, 1fr); gap: 1rem; text-align: center; }
.stat-num { font-size: 1.9rem; font-weight: 700; color: var(--teal); letter-spacing: -1px; }
.stat-label { font-size: 0.88rem; color: var(--gray); }

/* ---------- Testimonials ---------- */
.testi-section { padding: 2rem 24px 1rem; }
.testi-grid { max-width: 1240px; margin: 0 auto; display: grid; grid-template-columns: 1fr 1fr; gap: 1.2rem; }
.testi { background: var(--surface); border: 1px solid var(--line); border-radius: 20px; padding: 1.8rem 2rem; display: flex; flex-direction: column; }
.testi-quote { font-size: 0.98rem; line-height: 1.7; color: var(--gray); margin-bottom: 1.3rem; flex: 1; }
[data-theme="dark"] .testi-quote { color: #b8c4c2; }
.testi-person { display: flex; align-items: center; gap: 0.9rem; }
.testi-avatar { flex-shrink: 0; width: 46px; height: 46px; border-radius: 50%; background: var(--teal-soft); color: var(--teal); font-weight: 700; font-size: 0.95rem; display: inline-flex; align-items: center; justify-content: center; }
img.testi-avatar { object-fit: cover; padding: 0; }
.testi-name { font-weight: 600; color: var(--ink); font-size: 0.95rem; line-height: 1.3; }
.testi-role { font-size: 0.84rem; color: var(--gray); line-height: 1.45; }
.testi-role a { color: var(--teal); font-weight: 500; }
.testi-role a:hover { text-decoration: underline; }

/* ---------- Lesetext ---------- */
.article { max-width: 720px; margin: 0 auto; padding: 3.5rem 24px 2rem; }
.article .lead { font-size: 1.3rem; line-height: 1.5; color: var(--ink); font-weight: 500; margin-bottom: 2rem; }
.article p { font-size: 1.05rem; line-height: 1.75; color: var(--gray); margin-bottom: 1.4rem; }
.article h2 { font-size: 1.6rem; font-weight: 700; color: var(--ink); letter-spacing: -0.5px; margin: 3rem 0 1.2rem; line-height: 1.2; scroll-margin-top: 110px; }
.article h3 { font-size: 1.15rem; font-weight: 600; color: var(--ink); margin: 1.8rem 0 0.7rem; }
.article .anchor { font-size: 1.4rem; font-weight: 700; color: var(--teal); letter-spacing: -0.5px; margin: 2rem 0 1.2rem; }
.article ul { margin: 0 0 1.4rem 1.4rem; padding: 0; }
.article li { font-size: 1.05rem; line-height: 1.7; color: var(--gray); margin-bottom: 0.35rem; }
.article a { color: var(--teal); }
[data-theme="dark"] .article p, [data-theme="dark"] .article li { color: #b8c4c2; }

.closing { background: var(--teal-soft); border-radius: 20px; padding: 2rem 2.2rem; margin: 2.5rem 0 1rem; }
.closing .closing-title { font-size: 1.3rem; font-weight: 700; color: var(--teal); margin-bottom: 1rem; }
.closing p { font-size: 1.1rem; font-weight: 500; color: var(--ink); margin-bottom: 0.8rem; line-height: 1.5; }
.closing p:last-child { margin-bottom: 0; }

/* ---------- Andre-Vorstellungskarte ---------- */
.andre-block { max-width: 960px; margin: 2rem auto; padding: 0 24px; }
.andre-card { background: var(--surface); border: 1px solid var(--line); border-radius: 24px; overflow: hidden; display: grid; grid-template-columns: 40% 60%; align-items: stretch; }
.andre-img { background-image: url('../images/andre-hell.jpg'); background-size: cover; background-position: center top; min-height: 380px; }
[data-theme="dark"] .andre-img { background-image: url('../images/andre-dunkel.jpg'); }
.andre-text { padding: 2.5rem; display: flex; flex-direction: column; justify-content: center; }
.andre-text .label { color: var(--coral); font-size: 0.72rem; letter-spacing: 1.5px; text-transform: uppercase; font-weight: 600; margin-bottom: 0.8rem; }
.andre-text h2 { font-size: 1.7rem; font-weight: 700; color: var(--ink); margin: 0 0 1rem; letter-spacing: -0.5px; }
.andre-text p { font-size: 1rem; line-height: 1.7; color: var(--gray); margin-bottom: 1rem; }
[data-theme="dark"] .andre-text p { color: #b8c4c2; }

/* ---------- Modul-Akkordeons ---------- */
.guide { max-width: 860px; margin: 0 auto; padding: 0 24px 0.5rem; }
.guide-box { background: var(--teal-soft); border-radius: 20px; padding: 1.6rem 1.8rem; }
.guide-box h3 { font-size: 1.05rem; font-weight: 700; color: var(--ink); margin: 0 0 0.8rem; }
.guide-box p { font-size: 0.95rem; line-height: 1.7; margin: 0 0 0.5rem; color: var(--gray); }
.guide-box p:last-child { margin-bottom: 0; }
[data-theme="dark"] .guide-box p { color: #b8c4c2; }
.guide-box a { color: var(--teal); font-weight: 600; white-space: nowrap; }
.guide-box a:hover { text-decoration: underline; }

.modules { max-width: 860px; margin: 0 auto; padding: 1rem 24px 2rem; display: flex; flex-direction: column; gap: 1rem; }
details.module { scroll-margin-top: 110px; background: var(--surface); border: 1px solid var(--line); border-radius: 18px; overflow: hidden; transition: border-color 0.15s; }
details.module[open] { border-color: var(--teal); }
details.module summary { list-style: none; cursor: pointer; display: flex; align-items: flex-start; gap: 1rem; padding: 1.3rem 1.6rem; }
details.module summary::-webkit-details-marker { display: none; }
.mod-icon { flex-shrink: 0; width: 44px; height: 44px; border-radius: 12px; background: var(--teal-soft); color: var(--teal); display: inline-flex; align-items: center; justify-content: center; font-size: 1.3rem; }
.mod-head { flex: 1; min-width: 0; }
.mod-title { font-size: 1.1rem; font-weight: 600; color: var(--ink); line-height: 1.3; }
.mod-sub { display: block; font-size: 0.92rem; color: var(--gray); margin-top: 0.2rem; line-height: 1.5; }
.mod-meta { display: flex; flex-wrap: wrap; gap: 0.5rem; margin-top: 0.7rem; }
.meta-pill { display: inline-flex; align-items: center; gap: 0.35rem; font-size: 0.76rem; font-weight: 600; padding: 4px 12px; border-radius: 20px; background: var(--teal-soft); color: var(--teal); }
.meta-pill.amber { background: var(--amber-soft); color: #9A7222; }
[data-theme="dark"] .meta-pill.amber { color: var(--amber); }
.meta-pill.coral { background: var(--coral-soft); color: var(--coral); }
.mod-chevron { margin-left: auto; color: var(--gray); transition: transform 0.25s; font-size: 1.2rem; margin-top: 0.3rem; }
details.module[open] .mod-chevron { transform: rotate(180deg); }
.mod-body { padding: 0.2rem 1.6rem 1.6rem; }
.mod-body p { font-size: 1rem; line-height: 1.7; color: var(--gray); margin-bottom: 1rem; }
[data-theme="dark"] .mod-body p { color: #b8c4c2; }
.mod-body strong { color: var(--ink); }
.mod-body ul { margin: 0 0 1.2rem 1.2rem; padding: 0; }
.mod-body li { font-size: 1rem; line-height: 1.7; color: var(--gray); margin-bottom: 0.3rem; }
[data-theme="dark"] .mod-body li { color: #b8c4c2; }
.mod-body h4 { font-size: 1.05rem; font-weight: 600; color: var(--ink); margin: 1.4rem 0 0.5rem; }
.dauer-pill { display: inline-flex; align-items: center; gap: 0.4rem; background: var(--amber-soft); color: #9A7222; font-size: 0.82rem; font-weight: 600; padding: 5px 14px; border-radius: 20px; margin-bottom: 1.2rem; }
[data-theme="dark"] .dauer-pill { color: var(--amber); }
.mod-cta { text-align: right; margin-top: 1.2rem; padding-top: 1.2rem; border-top: 1px solid var(--line); }

/* ---------- PROFESSIONAL-Säulen ---------- */
.pillars { max-width: 860px; margin: 0 auto; padding: 0.5rem 24px 1rem; display: flex; flex-direction: column; gap: 1.2rem; }
.pillar { background: var(--surface); border: 1px solid var(--line); border-radius: 20px; padding: 2rem 2.2rem; }
.pillar-head { display: flex; align-items: center; gap: 1rem; margin-bottom: 1rem; }
.pillar-num { flex-shrink: 0; width: 48px; height: 48px; border-radius: 14px; background: var(--teal); color: #fff; font-size: 1.3rem; font-weight: 700; display: inline-flex; align-items: center; justify-content: center; }
.pillar h3 { font-size: 1.3rem; font-weight: 700; color: var(--ink); line-height: 1.25; margin: 0; }
.pillar p { font-size: 1rem; line-height: 1.7; color: var(--gray); margin-bottom: 1rem; }
[data-theme="dark"] .pillar p { color: #b8c4c2; }
.pillar ul { margin: 0 0 0 1.3rem; padding: 0; }
.pillar li { font-size: 1rem; line-height: 1.7; color: var(--gray); margin-bottom: 0.5rem; }
[data-theme="dark"] .pillar li { color: #b8c4c2; }
.pillar strong { color: var(--ink); }

/* ---------- KI-Seite: Zielgruppen-Pills ---------- */
.aud-pill { display: inline-flex; align-items: center; gap: 0.4rem; font-size: 0.76rem; letter-spacing: 1.2px; text-transform: uppercase; font-weight: 600; padding: 5px 14px; border-radius: 20px; margin: 3rem 0 0.6rem; }
.aud-pill.teal { background: var(--teal-soft); color: var(--teal); }
.aud-pill.coral { background: var(--coral-soft); color: var(--coral); }
.aud-pill:first-child { margin-top: 0; }
.section-btn { margin: 0.4rem 0 1rem; }
.section-divider { border: none; border-top: 1px solid var(--line); margin: 3rem 0; }

/* ---------- Referenzen ---------- */
.collage { max-width: 720px; margin: 0 auto; padding: 0 24px; }
.collage-card { background: #fff; border: 1px solid var(--line); border-radius: 20px; padding: 1.5rem; text-align: center; }
.collage-card img { max-width: 100%; height: auto; display: block; margin: 0 auto; border-radius: 8px; }
.ref-list { display: flex; flex-direction: column; gap: 0.8rem; margin: 1.4rem 0 0.6rem; }
.ref-item { display: block; background: var(--surface); border: 1px solid var(--line); border-radius: 14px; padding: 1.1rem 1.4rem; transition: border-color 0.15s, transform 0.15s; }
.ref-item:hover { border-color: var(--teal); transform: translateY(-2px); }
.ref-source { font-size: 0.72rem; letter-spacing: 1.2px; text-transform: uppercase; font-weight: 600; color: var(--teal); margin-bottom: 0.25rem; display: flex; align-items: center; gap: 0.4rem; }
.ref-source .ti { font-size: 0.9rem; }
.ref-title { font-size: 0.98rem; font-weight: 500; color: var(--ink); line-height: 1.45; }
.more-link { display: inline-flex; align-items: center; gap: 0.5rem; color: var(--teal); font-weight: 600; font-size: 1.05rem; margin-top: 0.8rem; }
.more-link:hover { text-decoration: underline; }

/* ---------- Formular-Seite ---------- */
.form-wrap { max-width: 760px; margin: 0 auto; padding: 1rem 24px 2rem; }
.form-card { background: var(--surface); border: 1px solid var(--line); border-radius: 24px; padding: 2.5rem; }

/* ---------- Impressum / Datenschutz ---------- */
.imp-card { background: var(--surface); border: 1px solid var(--line); border-radius: 16px; padding: 1.4rem 1.6rem; margin-bottom: 1rem; }
.imp-card .imp-label { font-size: 0.72rem; letter-spacing: 1.2px; text-transform: uppercase; font-weight: 600; color: var(--teal); margin-bottom: 0.5rem; }
.imp-card p { margin-bottom: 0.3rem !important; font-size: 1rem !important; }
.imp-card a { color: var(--teal); font-weight: 500; }
.imp-card a:hover { text-decoration: underline; }
.toc-box { background: var(--teal-soft); border-radius: 20px; padding: 1.6rem 1.8rem; margin: 0 0 2.5rem; }
.toc-box h3 { font-size: 1rem; font-weight: 700; color: var(--ink); margin: 0 0 0.7rem; }
.toc-box ol { margin: 0 0 0 1.2rem; padding: 0; }
.toc-box li { font-size: 0.95rem; line-height: 1.8; }
.toc-box a { color: var(--teal); font-weight: 500; }
.toc-box a:hover { text-decoration: underline; }

/* ---------- CTA & Buttons ---------- */
.cta { text-align: center; padding: 2rem 24px 4rem; }
.cta h2 { font-size: 1.7rem; font-weight: 700; color: var(--ink); letter-spacing: -0.5px; margin: 0 0 0.5rem; }
.cta p { color: var(--gray); margin-bottom: 1.6rem; }
.btn { display: inline-block; background: var(--coral); color: #fff; padding: 0.95rem 2rem; border-radius: 30px; font-size: 0.95rem; font-weight: 600; transition: transform 0.15s, background 0.2s; }
.btn:hover { transform: translateY(-2px); background: #e07556; color: #fff; }
.btn.btn-white { background: #fff; color: var(--teal); }
.btn.btn-white:hover { background: #f4f4f4; color: var(--teal); }
.btn-teal { background: var(--teal); }

/* ---------- Footer ---------- */
.mke-footer { background: var(--surface); border-top: 1px solid var(--line); padding: 2.5rem 24px; text-align: center; }
.mke-footer .f-tags { color: var(--gray); font-size: 0.85rem; margin-bottom: 0.8rem; }
.mke-footer .f-project { color: var(--gray); font-size: 0.85rem; margin-bottom: 0.8rem; }
.mke-footer .f-project a, .mke-footer .f-copy a { color: var(--teal); font-weight: 500; }
.mke-footer .f-project a:hover, .mke-footer .f-copy a:hover, .mke-footer .f-links a:hover { text-decoration: underline; }
.mke-footer .f-copy { color: #AEB5B4; font-size: 0.78rem; }
.mke-footer .f-links { margin-top: 0.9rem; font-size: 0.85rem; display: flex; gap: 0.6rem; justify-content: center; align-items: center; }
.mke-footer .f-links a { color: var(--gray); }
.mke-footer .f-dot { color: var(--line); }


  /* Warum Mimikama – USP-Block */
  .usp-section { padding: 3.5rem 24px 1rem; }
  .usp-grid { max-width: 1240px; margin: 2rem auto 0; display: grid; grid-template-columns: repeat(3, 1fr); gap: 1.2rem; }
  .usp { background: var(--surface); border: 1px solid var(--line); border-radius: 20px; padding: 1.8rem; }
  .usp-icon { width: 48px; height: 48px; border-radius: 14px; background: var(--teal-soft); color: var(--teal); display: inline-flex; align-items: center; justify-content: center; font-size: 1.4rem; margin-bottom: 1rem; }
  .usp h3 { font-size: 1.08rem; font-weight: 600; color: var(--ink); margin: 0 0 0.5rem; }
  .usp p { font-size: 0.92rem; color: var(--gray); line-height: 1.65; margin: 0; }
  [data-theme="dark"] .usp p { color: #b8c4c2; }

/* ---------- Mobil ---------- */
@media (max-width: 900px) {
  .usp-grid { grid-template-columns: 1fr; }
  .mke-header-inner { padding: 1rem 24px; }
  .mke-logo img { height: 52px; }
  .hero { grid-template-columns: 1fr; }
  .hero-text { padding: 2.5rem; order: 2; }
  .hero-img { min-height: 320px; order: 1; }
  .page-hero h1 { font-size: 1.9rem; }
  .profile-inner { grid-template-columns: 1fr; gap: 2.2rem; text-align: center; }
  .profile-text h1 { font-size: 2.2rem; }
  .profile-text .subtitle { margin-left: auto; margin-right: auto; }
  .profile-img img { max-width: 280px; }
  .tv-logo { height: 22px !important; }
  .tv-row { gap: 1.2rem; }
  .ki { flex-direction: column; text-align: center; padding: 2.2rem 1.6rem; }
  .cards { grid-template-columns: 1fr; }
  .stats { grid-template-columns: repeat(2, 1fr); }
  .testi-grid { grid-template-columns: 1fr; }
  .andre-card { grid-template-columns: 1fr; }
  .andre-img { min-height: 300px; }
}

/* ---------- Contact Form 7 im Mimikama-Look ---------- */
.form-card .wpcf7 label { display: block; font-size: 0.9rem; font-weight: 600; color: var(--ink); margin-bottom: 0.3rem; }
.form-card .wpcf7 input[type="text"],
.form-card .wpcf7 input[type="email"],
.form-card .wpcf7 input[type="tel"],
.form-card .wpcf7 input[type="date"],
.form-card .wpcf7 select,
.form-card .wpcf7 textarea {
  width: 100%; padding: 0.75rem 1rem; margin-bottom: 1.1rem;
  border: 1px solid var(--line); border-radius: 12px;
  background: var(--bg); color: var(--ink);
  font-family: 'Poppins', sans-serif; font-size: 0.95rem;
}
.form-card .wpcf7 input:focus,
.form-card .wpcf7 select:focus,
.form-card .wpcf7 textarea:focus { outline: none; border-color: var(--teal); }
.form-card .wpcf7 input[type="submit"] {
  display: inline-block; background: var(--coral); color: #fff; border: none; cursor: pointer;
  padding: 0.95rem 2rem; border-radius: 30px; font-size: 0.95rem; font-weight: 600;
  font-family: 'Poppins', sans-serif; transition: transform 0.15s;
}
.form-card .wpcf7 input[type="submit"]:hover { transform: translateY(-2px); }
.form-card .wpcf7 .wpcf7-not-valid-tip { color: #C0392B; font-size: 0.82rem; margin-top: -0.8rem; margin-bottom: 1rem; display: block; }
.form-card .wpcf7 .wpcf7-response-output { border-radius: 12px; padding: 0.9rem 1.2rem; margin: 1rem 0 0; border: 1px solid var(--line); font-size: 0.92rem; }
.form-card .wpcf7 form.sent .wpcf7-response-output { border-color: var(--teal); background: var(--teal-soft); color: var(--ink); }
.form-card .wpcf7 form.invalid .wpcf7-response-output,
.form-card .wpcf7 form.failed .wpcf7-response-output { border-color: #C0392B; background: var(--coral-soft); color: var(--ink); }


/* ---------- Dark-only Härtung (greift auch im Editor-Canvas) ---------- */
.tv-logo { opacity: 0.65; filter: invert(0.85); }
.mke-logo .logo-hell { display: none; }
.mke-logo .logo-dunkel { display: block; }
.article p, .article li, .mod-body p, .mod-body li, .pillar p, .pillar li,
.testi-quote, .guide-box p, .andre-text p { color: #b8c4c2; }
.meta-pill.amber, .dauer-pill, .card-icon.amber { color: var(--amber); }
