/*
Theme Name: Seelenkraft Kompass Plus
Theme URI: https://seelenkraft.vorlagenwerk.com/
Author: ChatGPT für Stev
Description: Professionelles WordPress-Design für Depression verstehen, Selbstwert stärken, Selbstfürsorge und Android-App. Entwickelt als seriöse Informations- und Begleitseite mit klaren Krisenhinweisen und Plugin-Unterstützung.
Version: 3.1.0
Requires at least: 6.0
Requires PHP: 7.4
License: GPLv2 or later
License URI: https://www.gnu.org/licenses/gpl-2.0.html
Text Domain: seelenkraft-kompass-plus
Tags: accessibility-ready, custom-logo, custom-menu, featured-images, one-column, wide-blocks, blog
*/

:root {
  --sk-bg: #f7f2ea;
  --sk-bg-soft: #fffaf2;
  --sk-surface: rgba(255, 252, 246, .94);
  --sk-surface-strong: #fffdf8;
  --sk-text: #20312c;
  --sk-muted: #61706a;
  --sk-green: #315f4b;
  --sk-green-dark: #1f3e33;
  --sk-green-soft: #dcebe2;
  --sk-gold: #d1a55c;
  --sk-gold-soft: #f5e7c9;
  --sk-rose: #f2dfd7;
  --sk-danger: #8f2f2f;
  --sk-border: rgba(49, 95, 75, .16);
  --sk-shadow: 0 28px 80px rgba(38, 54, 48, .12);
  --sk-shadow-small: 0 14px 35px rgba(38, 54, 48, .10);
  --sk-radius-xl: 34px;
  --sk-radius-lg: 24px;
  --sk-radius-md: 16px;
  --sk-max: 1180px;
  --sk-font: Inter, ui-sans-serif, system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;
  --sk-serif: Georgia, "Times New Roman", serif;
}
* { box-sizing: border-box; }
html { scroll-behavior: smooth; }
body {
  margin: 0;
  color: var(--sk-text);
  background:
    radial-gradient(circle at 10% 6%, rgba(209,165,92,.17), transparent 32%),
    radial-gradient(circle at 92% 10%, rgba(49,95,75,.14), transparent 30%),
    linear-gradient(180deg, var(--sk-bg) 0%, #fbf7ef 55%, #f2ece3 100%);
  font-family: var(--sk-font);
  line-height: 1.7;
  -webkit-font-smoothing: antialiased;
}
a { color: var(--sk-green); text-decoration-thickness: .08em; text-underline-offset: .18em; }
a:hover { color: var(--sk-green-dark); }
img { max-width: 100%; height: auto; }
.container { width: min(calc(100% - 40px), var(--sk-max)); margin: 0 auto; }
.container.narrow { width: min(calc(100% - 40px), 880px); }
.skip-link { position:absolute; top:-100px; left:16px; background:var(--sk-green-dark); color:#fff; padding:10px 16px; border-radius:999px; z-index:999; }
.skip-link:focus { top:16px; }
.site-header { position: sticky; top: 0; z-index: 90; background: rgba(247,242,234,.90); backdrop-filter: blur(18px); border-bottom: 1px solid var(--sk-border); }
.header-inner { width:min(calc(100% - 32px), 1240px); margin:0 auto; min-height:86px; display:flex; align-items:center; justify-content:space-between; gap:18px; }
.brand { display:inline-flex; align-items:center; gap:12px; min-width:235px; color:var(--sk-text); text-decoration:none; }
.brand-mark { width:50px; height:50px; display:grid; place-items:center; border-radius:17px; background:var(--sk-green-soft); color:var(--sk-green); box-shadow:inset 0 0 0 1px rgba(49,95,75,.12); }
.brand-mark svg { width:32px; height:32px; }
.custom-logo { width:46px; height:46px; object-fit:contain; border-radius:12px; }
.brand-title { display:block; font-weight:900; font-size:1.06rem; letter-spacing:-.02em; }
.brand-subtitle { display:block; color:var(--sk-muted); font-size:.78rem; line-height:1.35; max-width:230px; }
.main-navigation { flex:1; display:flex; align-items:center; justify-content:center; }
.primary-menu { list-style:none; display:flex; align-items:center; justify-content:center; gap:4px; padding:0; margin:0; }
.primary-menu li { position:relative; }
.primary-menu a { display:inline-flex; align-items:center; gap:6px; padding:10px 12px; border-radius:999px; color:var(--sk-text); font-weight:750; font-size:.9rem; text-decoration:none; }
.primary-menu a:hover, .primary-menu .current-menu-item > a, .primary-menu .current-menu-ancestor > a, .primary-menu .menu-item-has-children:focus-within > a { background:rgba(49,95,75,.10); color:var(--sk-green-dark); }
.primary-menu .menu-item-has-children > a::after { content:"⌄"; font-size:.82em; line-height:1; transform:translateY(-1px); }
.primary-menu .sub-menu { position:absolute; top:calc(100% + 12px); right:0; z-index:110; min-width:270px; list-style:none; padding:10px; margin:0; border:1px solid var(--sk-border); border-radius:22px; background:rgba(255,253,248,.98); box-shadow:var(--sk-shadow-small); opacity:0; visibility:hidden; transform:translateY(8px); pointer-events:none; transition:opacity .18s ease, transform .18s ease, visibility .18s ease; }
.primary-menu .menu-item-has-children:hover > .sub-menu, .primary-menu .menu-item-has-children:focus-within > .sub-menu { opacity:1; visibility:visible; transform:translateY(0); pointer-events:auto; }
.primary-menu .sub-menu::before { content:""; position:absolute; top:-12px; left:0; right:0; height:12px; }
.primary-menu .sub-menu a { display:flex; width:100%; justify-content:flex-start; border-radius:14px; padding:11px 12px; font-size:.92rem; white-space:nowrap; }
.primary-menu .sub-menu a:hover, .primary-menu .sub-menu .current-menu-item > a { background:var(--sk-green-soft); }
.menu-toggle { display:none; border:1px solid var(--sk-border); border-radius:999px; background:var(--sk-surface-strong); color:var(--sk-text); padding:10px 14px; font-weight:850; }
.header-cta { display:inline-flex; align-items:center; justify-content:center; padding:12px 16px; border-radius:999px; background:var(--sk-green); color:#fff; text-decoration:none; font-weight:900; box-shadow:var(--sk-shadow-small); white-space:nowrap; }
.header-cta:hover { background:var(--sk-green-dark); color:#fff; }
.hero, .subpage-hero { position:relative; overflow:hidden; padding:92px 0 60px; }
.hero::before, .subpage-hero::before { content:""; position:absolute; width:420px; height:420px; right:3%; top:20px; border-radius:999px; background:radial-gradient(circle, rgba(49,95,75,.13), transparent 68%); pointer-events:none; }
.hero-grid, .subpage-hero-grid { display:grid; grid-template-columns:1.1fr .9fr; align-items:center; gap:48px; }
.eyebrow { display:inline-flex; align-items:center; gap:9px; color:var(--sk-green); font-weight:950; text-transform:uppercase; letter-spacing:.11em; font-size:.75rem; }
.eyebrow::before { content:""; width:28px; height:1px; display:inline-block; background:var(--sk-gold); }
.hero h1, .subpage-hero h1 { margin:14px 0 18px; color:var(--sk-green-dark); font-size:clamp(2.45rem, 5.2vw, 5.35rem); line-height:.96; letter-spacing:-.065em; }
.subpage-hero h1 { font-size:clamp(2.25rem, 4.5vw, 4.5rem); }
.lead { font-size:clamp(1.08rem, 1.45vw, 1.3rem); color:#42524d; margin:0 0 26px; max-width:780px; }
.hero-actions { display:flex; flex-wrap:wrap; gap:12px; margin-top:24px; }
.button, .wp-element-button { display:inline-flex; align-items:center; justify-content:center; min-height:48px; padding:13px 20px; border-radius:999px; border:1px solid transparent; text-decoration:none; font-weight:900; transition:transform .18s ease, background .18s ease, box-shadow .18s ease; }
.button:hover, .wp-element-button:hover { transform:translateY(-1px); }
.button-primary { background:var(--sk-green); color:#fff; box-shadow:var(--sk-shadow-small); }
.button-primary:hover { background:var(--sk-green-dark); color:#fff; }
.button-secondary { background:rgba(255,255,255,.58); border-color:var(--sk-border); color:var(--sk-green-dark); }
.button-secondary:hover { background:#fff; color:var(--sk-green-dark); }
.hero-panel, .anchor-card, .subpage-panel { background:linear-gradient(145deg, rgba(255,253,248,.97), rgba(245,231,201,.72)); border:1px solid var(--sk-border); border-radius:var(--sk-radius-xl); box-shadow:var(--sk-shadow); }
.hero-panel { padding:18px; transform:rotate(1.15deg); }
.anchor-card { padding:clamp(26px, 4vw, 44px); transform:rotate(-1.15deg); }
.anchor-card h2, .subpage-panel h2 { font-family:var(--sk-serif); font-size:clamp(1.65rem, 3vw, 2.45rem); line-height:1.12; margin:12px 0; color:var(--sk-green-dark); }
.subpage-panel { padding:clamp(24px, 4vw, 38px); }
.crisis-strip { background:var(--sk-green-dark); color:#fff; }
.crisis-inner { display:flex; align-items:center; justify-content:space-between; gap:16px; padding:14px 0; font-size:.96rem; }
.crisis-strip a { color:#fff; font-weight:900; }
.crisis-link { background:rgba(255,255,255,.13); border-radius:999px; padding:8px 12px; text-decoration:none; white-space:nowrap; }
.section { padding:86px 0; }
.section-tight { padding:58px 0; }
.section-heading { max-width:790px; margin-bottom:34px; }
.section-heading h2, .entry-content h2 { margin:12px 0 14px; color:var(--sk-green-dark); font-size:clamp(1.9rem, 3.6vw, 3.55rem); line-height:1.04; letter-spacing:-.05em; }
.section-heading p, .intro-text, .entry-content p { color:#4c5b56; }
.card-grid { display:grid; gap:22px; }
.card-grid.three { grid-template-columns:repeat(3, minmax(0, 1fr)); }
.card-grid.two { grid-template-columns:repeat(2, minmax(0, 1fr)); }
.info-card, .entry-card, .detail-card, .source-note, .sk-card, .wp-block-group.is-style-sk-card { background:var(--sk-surface); border:1px solid var(--sk-border); border-radius:var(--sk-radius-lg); padding:clamp(22px, 3vw, 32px); box-shadow:var(--sk-shadow-small); }
.info-card h2, .info-card h3, .detail-card h2, .sk-card h2, .sk-card h3 { color:var(--sk-green-dark); margin:14px 0 10px; line-height:1.18; letter-spacing:-.025em; }
.info-card p, .detail-card p, .sk-card p { color:#50615b; margin:0 0 18px; }
.info-card a { font-weight:900; text-decoration:none; }
.number { display:inline-flex; align-items:center; justify-content:center; width:42px; height:42px; border-radius:14px; background:var(--sk-green-soft); color:var(--sk-green); font-weight:950; }
.check-list { list-style:none; padding:0; margin:18px 0 0; display:grid; gap:10px; }
.check-list li { position:relative; padding-left:30px; color:#41504b; }
.check-list li::before { content:""; position:absolute; left:0; top:.55em; width:14px; height:14px; border-radius:50%; background:var(--sk-green-soft); box-shadow:inset 0 0 0 4px var(--sk-green); }
.compass { background:linear-gradient(135deg, rgba(49,95,75,.96), rgba(31,62,51,.97)); color:#fff; }
.compass .eyebrow, .compass h2, .compass p { color:#fff; }
.compass-grid { display:grid; grid-template-columns:.92fr 1.08fr; gap:32px; align-items:center; }
.compass-panel { padding:clamp(28px, 4vw, 46px); border:1px solid rgba(255,255,255,.18); border-radius:var(--sk-radius-xl); background:rgba(255,255,255,.08); }
.compass-panel h2 { font-size:clamp(2rem, 3.4vw, 3.65rem); line-height:1.02; margin:14px 0; letter-spacing:-.05em; }
.scale { display:grid; grid-template-columns:repeat(5, 1fr); gap:8px; margin-top:22px; }
.scale span { display:grid; place-items:center; min-height:52px; border-radius:16px; background:rgba(255,255,255,.13); color:#fff; font-weight:950; }
.micro-tools { display:grid; gap:16px; }
.micro-tool { display:flex; gap:18px; align-items:flex-start; padding:22px; border-radius:22px; background:rgba(255,255,255,.12); border:1px solid rgba(255,255,255,.16); }
.micro-tool svg { width:34px; height:34px; color:var(--sk-gold-soft); flex:0 0 auto; }
.micro-tool h3 { color:#fff; margin:0 0 4px; }
.micro-tool p { color:rgba(255,255,255,.82); margin:0; }
.app-section { background:linear-gradient(180deg, rgba(255,250,242,.92), rgba(245,231,201,.45)); }
.app-grid { display:grid; grid-template-columns:1fr .72fr; gap:36px; align-items:center; }
.app-panel { background:var(--sk-surface-strong); border:1px solid var(--sk-border); border-radius:var(--sk-radius-xl); padding:clamp(28px,5vw,52px); box-shadow:var(--sk-shadow); }
.app-header { display:flex; align-items:center; gap:18px; margin-bottom:20px; }
.app-icon { width:76px; height:76px; border-radius:24px; box-shadow:var(--sk-shadow-small); }
.app-header h2 { margin:4px 0 0; color:var(--sk-green-dark); font-size:clamp(1.9rem,3.8vw,3.35rem); letter-spacing:-.055em; line-height:1; }
.feature-list { list-style:none; display:grid; grid-template-columns:repeat(2,minmax(0,1fr)); gap:10px; padding:0; margin:24px 0; }
.feature-list li { padding:12px 14px; border-radius:16px; background:var(--sk-green-soft); color:var(--sk-green-dark); font-weight:800; }
.download-meta { color:var(--sk-muted); font-size:.94rem; margin-top:18px; }
.app-phone { width:min(100%,340px); margin:0 auto; padding:18px; border-radius:42px; background:#203b31; box-shadow:0 28px 80px rgba(34,63,52,.28); border:1px solid rgba(255,255,255,.15); }
.phone-bar { display:flex; justify-content:center; padding:4px 0 14px; }
.phone-notch { width:88px; height:8px; border-radius:999px; background:rgba(255,255,255,.2); }
.phone-screen { background:linear-gradient(180deg,#f8f2e7,#e6eee8); border-radius:30px; padding:24px; min-height:520px; }
.phone-pill { display:inline-flex; padding:7px 12px; border-radius:999px; background:#fff; color:var(--sk-green); font-weight:950; font-size:.8rem; }
.phone-screen h3 { font-size:1.48rem; line-height:1.15; color:var(--sk-green-dark); margin:18px 0; }
.phone-card { display:grid; gap:2px; padding:15px; border-radius:18px; background:rgba(255,255,255,.84); margin-top:12px; box-shadow:0 8px 24px rgba(49,95,75,.08); }
.phone-card small { color:var(--sk-muted); }
.content-area { padding:76px 0; }
.entry-title { color:var(--sk-green-dark); font-size:clamp(2rem,4vw,3.8rem); line-height:1.05; letter-spacing:-.045em; margin:0 0 20px; }
.entry-content { font-size:1.05rem; }
.entry-content h3 { color:var(--sk-green-dark); font-size:1.45rem; line-height:1.2; margin-top:32px; }
.entry-content ul, .entry-content ol { color:#45564f; }
.entry-content .wp-block-group, .entry-content .sk-card { margin:22px 0; }
.entry-content blockquote { margin:28px 0; border-left:4px solid var(--sk-gold); background:rgba(255,253,248,.75); padding:22px 26px; border-radius:0 18px 18px 0; color:#43524d; }
.sitemap-grid { display:grid; grid-template-columns:repeat(3, minmax(0, 1fr)); gap:16px; }
.sitemap-grid a { display:block; padding:16px; border:1px solid var(--sk-border); border-radius:18px; background:rgba(255,255,255,.58); text-decoration:none; font-weight:850; }
.contact-cta { display:flex; align-items:center; justify-content:space-between; gap:28px; padding:clamp(28px,5vw,52px); border-radius:var(--sk-radius-xl); background:var(--sk-green-dark); color:#fff; box-shadow:var(--sk-shadow); }
.contact-cta h2 { color:#fff; font-size:clamp(1.9rem,3.4vw,3.3rem); line-height:1.02; letter-spacing:-.05em; margin:10px 0 12px; }
.contact-cta p { color:rgba(255,255,255,.78); max-width:690px; }
.contact-cta .eyebrow { color:#fff; }
.contact-cta .button-primary { background:#fff; color:var(--sk-green-dark); }
.site-footer { background:#172d25; color:rgba(255,255,255,.78); padding:58px 0 28px; }
.site-footer .brand { color:#fff; }
.site-footer .brand-mark { background:rgba(255,255,255,.12); color:#fff; }
.site-footer .brand-subtitle, .footer-note { color:rgba(255,255,255,.68); }
.footer-grid { display:grid; grid-template-columns:1.25fr .8fr .9fr .9fr; gap:34px; align-items:start; }
.footer-title { color:#fff; font-size:1rem; margin:0 0 14px; }
.footer-menu { list-style:none; padding:0; margin:0; display:grid; gap:10px; }
.footer-menu a { color:rgba(255,255,255,.82); text-decoration:none; font-weight:750; }
.footer-menu a:hover { color:#fff; }
.footer-button { margin-top:10px; color:#fff; border-color:rgba(255,255,255,.18); }
.footer-bottom { display:flex; justify-content:space-between; gap:18px; border-top:1px solid rgba(255,255,255,.1); margin-top:38px; padding-top:22px; font-size:.92rem; color:rgba(255,255,255,.58); }
@media (prefers-reduced-motion: no-preference) {
  .info-card, .detail-card { transition:opacity .55s ease, transform .55s ease; }
  .reveal-card { opacity:0; transform:translateY(18px); }
  .reveal-card.is-visible { opacity:1; transform:translateY(0); }
}
@media (max-width:1120px) {
  .header-cta { display:none; }
  .primary-menu a { font-size:.86rem; padding:9px 9px; }
}
@media (max-width:960px) {
  .header-inner { min-height:74px; }
  .menu-toggle { display:inline-flex; }
  .main-navigation { position:absolute; top:74px; left:0; right:0; background:rgba(247,242,234,.98); border-bottom:1px solid var(--sk-border); padding:14px 20px; display:none; }
  .main-navigation.is-open { display:block; }
  .primary-menu { flex-direction:column; align-items:stretch; }
  .primary-menu a { justify-content:center; padding:12px; }
  .primary-menu .menu-item-has-children > a::after { margin-left:3px; }
  .primary-menu .sub-menu { position:static; min-width:0; width:100%; margin:6px 0 4px; padding:8px; border-radius:18px; opacity:1; visibility:visible; transform:none; pointer-events:auto; background:rgba(255,255,255,.58); box-shadow:none; }
  .primary-menu .sub-menu::before { display:none; }
  .primary-menu .sub-menu a { justify-content:center; white-space:normal; font-size:.9rem; }
  .hero, .subpage-hero { padding:64px 0 42px; }
  .hero-grid, .subpage-hero-grid, .compass-grid, .app-grid { grid-template-columns:1fr; }
  .card-grid.three, .card-grid.two, .sitemap-grid, .footer-grid { grid-template-columns:1fr; }
  .contact-cta, .crisis-inner, .footer-bottom { flex-direction:column; align-items:flex-start; }
  .app-phone { width:min(100%, 320px); }
}
@media (max-width:620px) {
  .container { width:min(calc(100% - 28px), var(--sk-max)); }
  .brand-subtitle { display:none; }
  .brand { min-width:0; }
  .feature-list { grid-template-columns:1fr; }
  .hero h1, .subpage-hero h1 { letter-spacing:-.05em; }
  .footer-bottom { font-size:.86rem; }
}
