/*
Theme Name: Sonnenschein Theme
Theme URI: https://christian-sonnenschein.de/
Author: Christian Sonnenschein Team
Author URI: https://christian-sonnenschein.de/
Description: Reduziertes WordPress Theme im Kevin-Design als Basis fuer Christian Sonnenschein.
Version: 1.0.0
Requires at least: 6.0
Tested up to: 6.6
Requires PHP: 7.4
Text Domain: sonnenschein-theme
*/

:root {
  --ss-header-height: 86px;
}

html {
  scroll-behavior: smooth;
  overflow-x: hidden;
}

body {
  margin: 0;
  font-family: var(--font-body), sans-serif;
  color: var(--color-text);
  background: #fff;
  overflow-x: hidden;
}

body.ss-menu-open,
body.menu-open {
  overflow: hidden;
}

.ss-main-content {
  padding-top: 0;
}

.ss-site-header {
  position: relative;
  z-index: 5000;
  background: rgba(20, 20, 20, 0.95);
  border-bottom: 1px solid rgba(255, 255, 255, 0.08);
  backdrop-filter: blur(8px);
}

.ss-header-inner {
  min-height: var(--ss-header-height);
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 20px;
  position: relative;
}

.ss-brand {
  display: inline-flex;
  align-items: center;
  line-height: 1;
  text-decoration: none;
  white-space: nowrap;
}

.ss-brand-logo {
  display: block;
  width: auto;
  height: clamp(26px, 3.2vw, 38px);
  max-width: min(46vw, 320px);
}

.main-menu {
  margin-left: auto;
}

.menu-root {
  list-style: none;
  display: flex;
  align-items: center;
  gap: clamp(16px, 2.2vw, 32px);
  margin: 0;
  padding: 0;
}

.menu-root li {
  display: flex;
  align-items: center;
}

.menu-root a,
.menu-root .root-link {
  font-family: var(--font-heading), sans-serif;
  text-decoration: none;
  font-size: var(--fs-small);
  text-transform: uppercase;
  letter-spacing: 1.2px;
  font-weight: 600;
  color: #f4f4f4;
  position: relative;
}

.menu-root a::after,
.menu-root .root-link::after {
  content: "";
  position: absolute;
  left: 0;
  bottom: -5px;
  width: 0;
  height: 1px;
  background: var(--color-primary);
  transition: width 0.3s ease;
}

.menu-root a:hover::after,
.menu-root .root-link:hover::after,
.menu-root .current-menu-item > a::after,
.menu-root .current-menu-parent > a::after,
.menu-root .current-menu-ancestor > a::after,
.menu-root .current_page_item > a::after,
.menu-root .current_page_parent > a::after,
.menu-root .current_page_ancestor > a::after,
.menu-root a[aria-current="page"]::after {
  width: 100%;
}

.mobile-menu {
  display: none;
  position: relative;
  margin-left: auto;
  z-index: 5300;
}

.menu-toggle {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 44px;
  height: 44px;
  border: 0;
  background: transparent;
  color: var(--color-primary);
  padding: 0;
  margin: 0;
  cursor: pointer;
}

.menu-toggle svg {
  width: 24px;
  height: 24px;
}

.menu-toggle .icon-close {
  display: none;
}

.mobile-menu.open .menu-toggle .icon-menu {
  display: none;
}

.mobile-menu.open .menu-toggle .icon-close {
  display: block;
}

.mobile-menu .menu-wrapper {
  position: fixed !important;
  top: var(--ss-header-height) !important;
  right: 0 !important;
  bottom: 0 !important;
  left: 0 !important;
  width: 100vw !important;
  height: calc(100dvh - var(--ss-header-height)) !important;
  min-height: calc(100dvh - var(--ss-header-height)) !important;
  max-height: calc(100dvh - var(--ss-header-height)) !important;
  padding: 0 !important;
  background: #141414 !important;
  backdrop-filter: none !important;
  box-sizing: border-box !important;
  overflow-x: hidden !important;
  overflow-y: hidden !important;
  z-index: 999999 !important;
  display: none !important;
  opacity: 0 !important;
  pointer-events: none !important;
}

.mobile-menu.open .menu-wrapper {
  display: block !important;
  opacity: 1 !important;
  pointer-events: auto !important;
}

.mobile-menu .menu-panel {
  box-sizing: border-box !important;
  position: relative !important;
  z-index: 2 !important;
  width: 100% !important;
  max-width: 100% !important;
  height: 100% !important;
  min-height: 100% !important;
  max-height: 100% !important;
  margin: 0 !important;
  overflow-y: auto !important;
}

.menu-wrapper {
  position: fixed;
  top: var(--ss-header-height);
  right: 0;
  bottom: 0;
  left: 0;
  padding: 0;
  background: #141414;
  backdrop-filter: none;
  opacity: 0;
  pointer-events: none;
  transition: opacity 0.24s ease;
  z-index: 5200;
  overflow-x: hidden;
  box-sizing: border-box;
}

.mobile-menu.open .menu-wrapper {
  opacity: 1;
  pointer-events: auto;
}

.menu-panel {
  box-sizing: border-box;
  width: 100%;
  max-width: 100%;
  height: 100%;
  max-height: 100%;
  margin: 0;
  background:
    radial-gradient(480px 260px at 100% 0%, rgba(208, 180, 111, 0.1) 0%, rgba(208, 180, 111, 0) 72%),
    linear-gradient(180deg, rgba(20, 20, 20, 0.98) 0%, rgba(12, 12, 12, 0.98) 100%);
  border: 0;
  border-radius: 0;
  box-shadow: none;
  padding: 24px 20px calc(28px + env(safe-area-inset-bottom));
  overflow-y: auto;
  transform: translateY(-10px);
  transition: transform 0.24s ease;
}

.mobile-menu.open .menu-panel {
  transform: translateY(0);
}

.mobile-link-list,
.mobile-link-list ul {
  list-style: none;
  margin: 0;
  padding: 0;
}

.mobile-link-list > li {
  border-bottom: 1px solid rgba(255, 255, 255, 0.2);
  margin-bottom: 10px;
}

.mobile-link-list > li > a {
  display: flex;
  align-items: center;
  width: 100%;
  padding: 1.02rem 2px;
  font-family: var(--font-heading), sans-serif;
  text-decoration: none;
  text-transform: uppercase;
  letter-spacing: 1.35px;
  font-size: clamp(1.02rem, 2.2vw, 1.1rem);
  font-weight: 700;
  color: rgba(255, 255, 255, 0.95);
  line-height: 1.35;
}

.mobile-link-list > li.current-menu-item > a,
.mobile-link-list > li.current-menu-parent > a,
.mobile-link-list > li.current-menu-ancestor > a,
.mobile-link-list > li.current_page_item > a,
.mobile-link-list > li.current_page_parent > a,
.mobile-link-list > li.current_page_ancestor > a,
.mobile-link-list > li > a[aria-current="page"] {
  color: var(--color-primary);
}

.mobile-link-list > li > a:hover,
.mobile-link-list .sub-menu a:hover {
  color: var(--color-primary);
}

.mobile-link-list .sub-menu {
  padding: 6px 0 14px;
}

.mobile-link-list .sub-menu li {
  border-bottom: 1px solid rgba(255, 255, 255, 0.16);
  margin-bottom: 6px;
}

.mobile-link-list .sub-menu a {
  display: flex;
  width: 100%;
  padding: 0.82rem 2px;
  text-decoration: none;
  color: var(--color-text-on-dark);
  font-family: var(--font-body), sans-serif;
  font-size: 0.98rem;
  font-weight: 500;
  line-height: 1.35;
}

.mobile-cta {
  width: auto !important;
  align-self: flex-start;
  margin-top: 16px !important;
  min-height: 0 !important;
  padding: 12px 28px !important;
  font-size: var(--fs-small) !important;
  letter-spacing: 0.3px !important;
  line-height: 1 !important;
}

.mobile-cta:hover,
.mobile-cta:focus-visible {
  background: var(--color-primary-dark) !important;
  border-color: var(--color-primary-dark) !important;
  color: #fff !important;
}

.ss-header-cta {
  white-space: nowrap !important;
}

.ss-site-footer {
  padding: clamp(52px, 7vw, 82px) 0 20px;
  border-top: 1px solid rgba(255, 255, 255, 0.08);
}

.ss-footer-kc-grid {
  align-items: start !important;
  gap: clamp(20px, 4vw, 44px) !important;
  margin-bottom: clamp(22px, 3vw, 36px) !important;
}

.ss-footer-kc-grid p {
  color: var(--color-text-on-dark) !important;
}

.ss-footer-kc-grid .kc-line {
  margin: 20px 0 16px !important;
}

.ss-footer-kc-grid .kc-btn {
  margin-top: 12px !important;
}

.ss-footer-kc-list {
  list-style: none;
  margin: 0;
  padding: 0;
  display: flex;
  flex-direction: column;
  gap: 12px;
}

.ss-footer-kc-list li {
  display: flex;
  align-items: flex-start;
  gap: 10px;
}

.ss-footer-kc-icon {
  width: 18px;
  height: 18px;
  color: var(--color-primary);
  flex-shrink: 0;
  margin-top: 3px;
}

.ss-footer-kc-list a,
.ss-footer-kc-list span {
  color: #fff;
  text-decoration: none;
  font-size: var(--fs-body);
  line-height: 1.45;
}

.ss-footer-kc-list a:hover {
  color: var(--color-primary);
}

.ss-footer-links-main,
.ss-footer-legal {
  list-style: none;
  margin: 0;
  padding: 0;
  display: flex;
  flex-direction: column;
  gap: 10px;
}

.ss-footer-links-main a,
.ss-footer-legal a {
  color: #fff;
  text-decoration: none;
  font-size: var(--fs-body);
}

.ss-footer-links-main a:hover,
.ss-footer-legal a:hover {
  color: var(--color-primary);
}

.ss-footer-bottom {
  margin-top: clamp(28px, 4vw, 46px);
  padding-top: 16px;
  border-top: 1px solid rgba(255, 255, 255, 0.08);
  display: flex;
  justify-content: space-between;
  align-items: center;
  gap: 16px;
  flex-wrap: wrap;
}

.ss-footer-copy {
  font-size: var(--fs-small);
  color: var(--color-text-on-dark);
}

.ss-footer-legal {
  flex-direction: row;
  gap: 14px;
}

.sec-kc-hero {
  min-height: 0 !important;
  padding: clamp(44px, 5vw, 72px) 0 !important;
  display: block !important;
}

.sec-kc-hero .kc-container {
  min-height: 0 !important;
  display: block !important;
  width: 100% !important;
  padding-top: 0 !important;
  padding-bottom: 0 !important;
}

.sec-kc-hero .kc-grid-2 {
  width: 100% !important;
}

.sec-kc-hero .kc-hero-media img,
.sec-kc-intro .kc-intro-img,
.sec-kc-trust .kc-trust-img,
.sec-cs-about .kc-about-img {
  object-position: center top !important;
}

.sec-cs-home-hero .kc-hero-media img {
  aspect-ratio: 1 / 1 !important;
  object-fit: cover !important;
  object-position: center top !important;
}

.sec-cs-page-hero .kc-hero-media img {
  aspect-ratio: 1 / 1 !important;
  object-fit: cover !important;
  object-position: center top !important;
}

.sec-cs-about-intro .kc-intro-img {
  aspect-ratio: 1 / 1 !important;
  object-fit: cover !important;
  object-position: center top !important;
  width: 100% !important;
}

.sec-cs-solution-flow .kc-trust-img {
  aspect-ratio: 1 / 1 !important;
  object-fit: cover !important;
  object-position: center center !important;
}

.sec-cs-problem-icons .sec-cs-problem-note {
  display: flex;
  justify-content: center;
  margin: 22px auto 0;
}

.sec-cs-problem-icons .sec-cs-problem-note .sec-cs-problem-note-box {
  width: min(100%, 680px);
  display: flex;
  align-items: flex-start;
  gap: 14px;
  padding: clamp(16px, 2vw, 22px);
  text-align: left;
  border-radius: var(--radius-lg);
  border: 1px solid rgba(255, 255, 255, 0.14);
  background: rgba(255, 255, 255, 0.04);
}

.sec-cs-problem-icons .sec-cs-problem-note .kc-icon {
  margin: 0 !important;
  flex-shrink: 0;
  background: rgba(208, 180, 111, 0.14) !important;
  color: var(--color-primary) !important;
}

.sec-cs-problem-icons .sec-cs-problem-note .sec-cs-problem-note-content {
  flex: 1;
}

.sec-cs-problem-icons .sec-cs-problem-note .sec-cs-problem-note-title {
  margin: 2px 0 6px !important;
  font-family: var(--font-heading), sans-serif;
  font-size: var(--fs-small);
  font-weight: 700;
  letter-spacing: 0.7px;
  text-transform: uppercase;
}

.sec-cs-problem-icons .sec-cs-problem-note p {
  color: var(--color-text-on-dark) !important;
  margin-bottom: 7px !important;
}

.sec-cs-problem-icons .sec-cs-problem-note p:last-child {
  margin-bottom: 0 !important;
}

.sec-cs-risk-cta .kc-cta-card {
  background: var(--color-bg-dark) !important;
}

.sec-cs-risk-cta .kc-cta-btns {
  width: min(100%, 340px);
}

.sec-cs-risk-cta .kc-cta-btns .kc-btn {
  width: 100%;
}

.sec-cs-solution-flow .sec-cs-solution-note {
  margin-top: 16px !important;
}

.sec-cs-solution-flow .sec-cs-phase-grid {
  grid-template-columns: repeat(3, 1fr) !important;
  margin-top: clamp(26px, 3vw, 42px);
}

.sec-cs-solution-flow .sec-cs-phase-grid h4 {
  margin-bottom: 6px !important;
}

.sec-cs-solution-flow .sec-cs-phase-grid .kc-stats-small {
  font-size: var(--fs-small) !important;
}

.sec-cs-solution-flow .sec-cs-selection-hint {
  margin-top: clamp(20px, 3vw, 36px);
}

.sec-cs-solution-flow .sec-cs-selection-hint .kc-card {
  display: flex !important;
  gap: var(--sp-md) !important;
  align-items: flex-start !important;
  flex-wrap: wrap !important;
  background: rgba(255, 255, 255, 0.04) !important;
  border: 1px solid rgba(255, 255, 255, 0.12) !important;
  box-shadow: none !important;
}

.sec-cs-solution-flow .sec-cs-selection-hint .kc-icon {
  margin-bottom: 0 !important;
  background: rgba(208, 180, 111, 0.12) !important;
  color: var(--color-primary) !important;
}

.sec-cs-solution-flow .sec-cs-selection-hint .kc-card > div:last-child {
  flex: 1 !important;
  min-width: 220px !important;
}

.sec-cs-solution-flow .sec-cs-selection-hint h4 {
  margin-bottom: 8px !important;
}

.sec-cs-solution-flow .sec-cs-selection-hint p {
  color: var(--color-text-on-dark) !important;
  margin-bottom: 7px !important;
}

.sec-cs-solution-flow .sec-cs-selection-hint p:last-child {
  margin-bottom: 0 !important;
}

.sec-cs-invest-eco .kc-eco-head h2 {
  max-width: 760px !important;
  margin-left: auto !important;
  margin-right: auto !important;
}

.sec-cs-invest-eco .kc-card h4 {
  margin-bottom: 8px !important;
}

.sec-kc--dark.sec-cs-invest-eco .kc-eco-head h2,
.sec-kc--dark.sec-cs-invest-eco .kc-card h4,
.sec-kc--dark.sec-cs-invest-eco .kc-card p,
.sec-kc--dark.sec-cs-invest-eco .kc-eco-small {
  color: #fff !important;
}

.sec-cs-page-hero .sec-cs-about-mail {
  margin-top: 16px !important;
}

.sec-cs-page-hero .sec-cs-about-mail a {
  color: var(--color-primary) !important;
  text-decoration: none !important;
}

.sec-cs-page-hero .sec-cs-about-mail a:hover {
  color: var(--color-primary-light) !important;
}

.sec-cs-about-timeline > .kc-container > .kc-anim:first-child {
  text-align: center !important;
  max-width: 760px !important;
  margin: 0 auto clamp(16px, 2vw, 28px) !important;
}

.sec-cs-about-timeline .kc-timeline-entry p {
  color: var(--color-text-light) !important;
}

.sec-cs-about-bg .kc-card h4 {
  margin-bottom: 8px !important;
}

.sec-cs-about-bg .kc-icon {
  margin-bottom: 10px !important;
}

.sec-cs-about-bg .cs-about-lines p {
  color: var(--color-text-light) !important;
  margin-bottom: 7px !important;
  font-size: var(--fs-small) !important;
  line-height: 1.5 !important;
}

.sec-cs-about-bg .cs-about-lines p:last-child {
  margin-bottom: 0 !important;
}

.sec-cs-angebot-steps > .kc-container > .kc-anim:first-child {
  text-align: center !important;
  max-width: 760px !important;
  margin: 0 auto clamp(18px, 2.5vw, 34px) !important;
}

.sec-cs-angebot-steps > .kc-container > .kc-anim:first-child p {
  color: var(--color-text-on-dark) !important;
}

.cs-phase-list {
  display: flex !important;
  flex-direction: column !important;
  gap: 14px !important;
}

.cs-phase-block {
  display: grid !important;
  grid-template-columns: auto 1fr !important;
  gap: clamp(16px, 2vw, 24px) !important;
  align-items: start !important;
  padding: clamp(18px, 2.3vw, 28px) !important;
  border-radius: var(--radius-lg) !important;
  border: 1px solid rgba(255, 255, 255, 0.1) !important;
  background: rgba(255, 255, 255, 0.04) !important;
}

.cs-phase-block--hl {
  border-color: var(--color-primary) !important;
  background: rgba(208, 180, 111, 0.1) !important;
}

.cs-phase-num {
  font-family: var(--font-heading) !important;
  font-size: clamp(2.6rem, 6vw, 4.5rem) !important;
  line-height: 0.92 !important;
  font-weight: 800 !important;
  color: var(--color-primary) !important;
  min-width: clamp(72px, 8vw, 110px) !important;
}

.cs-phase-content h3 {
  margin-bottom: 6px !important;
  color: #fff !important;
}

.cs-phase-content > p {
  color: var(--color-text-on-dark) !important;
  margin-bottom: 10px !important;
}

.cs-phase-content .kc-checks {
  margin-bottom: 0 !important;
}

.cs-phase-content .kc-checks li {
  color: var(--color-text-on-dark) !important;
}

.sec-cs-selection-process > .kc-container > .kc-anim:first-child p {
  color: var(--color-text-light) !important;
}

.sec-cs-calendly > .kc-container > .kc-anim:first-child {
  text-align: center !important;
  max-width: 760px !important;
  margin: 0 auto clamp(16px, 2vw, 28px) !important;
}

.sec-cs-calendly .cs-calendly-card {
  padding: 0 !important;
  overflow: hidden !important;
}

.sec-cs-calendly .cs-calendly-iframe {
  width: 100%;
  min-height: 760px;
  border: 0;
  display: block;
  background: #fff;
}

.sec-cs-problem .kc-grid-2,
.sec-cs-mandat .kc-grid-2,
.sec-cs-about .kc-grid-2 {
  align-items: start !important;
}

.sec-cs-problem p,
.sec-cs-mandat p,
.sec-cs-invest p,
.sec-cs-about p {
  color: var(--color-text-light) !important;
}

.sec-cs-risk p,
.sec-cs-rahmen p {
  color: var(--color-text-on-dark) !important;
}

.sec-cs-problem .cs-problem-intro {
  font-size: clamp(1.06rem, 1.45vw, 1.18rem) !important;
  color: var(--color-text-heading) !important;
  margin-bottom: 14px !important;
}

.cs-list-clean {
  list-style: none !important;
  padding: 0 !important;
  margin: 0 0 16px !important;
}

.cs-list-clean li {
  position: relative;
  padding-left: 18px !important;
  margin-bottom: 7px !important;
}

.cs-list-clean li::before {
  content: "-";
  position: absolute;
  left: 0;
  top: 0;
  color: var(--color-primary-dark);
  font-weight: 700;
}

.sec-kc--dark .cs-list-clean li::before {
  color: var(--color-primary);
}

.sec-cs-risk {
  text-align: center;
}

.sec-cs-risk .cs-risk-copy {
  max-width: 760px;
  margin: 0 auto;
}

.sec-cs-risk h2 {
  margin-bottom: 14px !important;
}

.sec-cs-mandat .kc-mandat-card {
  border: 1px solid var(--color-border) !important;
  box-shadow: none !important;
}

.sec-cs-mandat .kc-mandat-card h3 {
  margin-bottom: 10px !important;
}

.sec-cs-mandat .kc-mandat-img {
  width: 100%;
  border-radius: var(--radius-lg);
  box-shadow: var(--shadow-md);
}

.sec-cs-ablauf .kc-process-head {
  text-align: center;
  max-width: 720px;
  margin: 0 auto clamp(18px, 2.3vw, 30px);
}

.sec-cs-ablauf .kc-card h3 {
  margin-bottom: 8px !important;
}

.sec-cs-ablauf .cs-ablauf-note {
  margin-top: 24px !important;
  text-align: center;
  color: var(--color-primary) !important;
  letter-spacing: 1px;
  text-transform: uppercase;
  font-size: var(--fs-small) !important;
}

.sec-cs-rahmen .kc-rahmen-box {
  text-align: center;
  max-width: 760px;
  margin: 0 auto;
  background: rgba(255, 255, 255, 0.04) !important;
  border: 1px solid rgba(255, 255, 255, 0.11) !important;
}

.sec-cs-invest .kc-invest-box {
  max-width: 820px;
  margin: 0 auto;
  border: 1px solid var(--color-border) !important;
  box-shadow: none !important;
}

.sec-cs-calendly .kc-container > .kc-anim:first-child {
  text-align: center;
}

.sec-cs-calendly .kc-container > .kc-anim:first-child .kc-line {
  margin-left: auto !important;
  margin-right: auto !important;
}

.sec-cs-about .kc-about-img {
  width: 100%;
  max-width: 420px;
  border-radius: var(--radius-lg);
  box-shadow: var(--shadow-md);
}

.sec-cs-form .kc-cta-card {
  align-items: start !important;
}

.ss-form-wrap {
  width: min(100%, 480px);
}

.ss-request-form {
  display: flex;
  flex-direction: column;
  gap: 10px;
}

.ss-request-form label {
  font-family: var(--font-heading), sans-serif;
  font-size: var(--fs-small);
  color: #f7f7f7;
  letter-spacing: 0.5px;
}

.ss-request-form input,
.ss-request-form textarea {
  width: 100%;
  border: 1px solid rgba(255, 255, 255, 0.22);
  background: rgba(255, 255, 255, 0.05);
  color: #fff;
  border-radius: 10px;
  padding: 12px 14px;
  font-family: var(--font-body), sans-serif;
  font-size: var(--fs-small);
}

.ss-request-form input::placeholder,
.ss-request-form textarea::placeholder {
  color: rgba(255, 255, 255, 0.7);
}

.ss-request-form textarea {
  min-height: 120px;
  resize: vertical;
}

.ss-request-form .ss-form-note {
  color: rgba(255, 255, 255, 0.72);
  font-size: var(--fs-small) !important;
  margin-top: 2px !important;
}

.ss-form-feedback {
  border-radius: 10px;
  padding: 10px 14px;
  font-size: var(--fs-small) !important;
  margin-bottom: 8px !important;
}

.ss-form-feedback--success {
  background: rgba(91, 181, 126, 0.2);
  border: 1px solid rgba(91, 181, 126, 0.45);
  color: #d7ffe4 !important;
}

.ss-form-feedback--error {
  background: rgba(193, 92, 92, 0.2);
  border: 1px solid rgba(193, 92, 92, 0.5);
  color: #ffdede !important;
}

.ss-page-wrap {
  max-width: 900px;
  margin: 0 auto;
}

.ss-page-wrap h1 {
  margin-bottom: 10px !important;
}

.ss-page-wrap p {
  color: var(--color-text-light) !important;
}

.kc-anim,
.kc-anim.is-visible {
  opacity: 1 !important;
  transform: none !important;
  transition: none !important;
}

.sec-cs-legal-hero,
.sec-cs-legal-hero .kc-container {
  min-height: 0 !important;
}

.sec-cs-legal-hero .kc-container {
  padding-top: calc(var(--ss-header-height) + 30px) !important;
  padding-bottom: clamp(24px, 5vw, 56px) !important;
}

.sec-cs-legal-hero a,
.sec-cs-legal-hero a:visited,
.sec-cs-legal-hero a:hover,
.sec-cs-legal-hero a:active {
  color: var(--color-text-on-dark) !important;
  text-decoration: underline;
  text-underline-offset: 2px;
  text-decoration-thickness: 1px;
}

.ss-impressum-content,
.ss-legal-content {
  max-width: 980px;
}

.ss-impressum-content p,
.ss-legal-content p,
.ss-impressum-content li,
.ss-legal-content li {
  line-height: 1.7 !important;
}

.ss-impressum-content h2,
.ss-impressum-content h3,
.ss-impressum-content h4 {
  margin-top: 1.55em !important;
  margin-bottom: 0.65em !important;
}

.ss-impressum-content h2:first-child,
.ss-impressum-content h3:first-child,
.ss-impressum-content h4:first-child {
  margin-top: 0 !important;
}

.ss-impressum-content p {
  margin-bottom: 1rem !important;
}

.ss-impressum-content a,
.ss-legal-content a {
  color: var(--color-text-light) !important;
  text-decoration: underline;
  text-underline-offset: 2px;
  text-decoration-thickness: 1px;
}

.ss-impressum-content a:hover,
.ss-legal-content a:hover {
  color: var(--color-text-light) !important;
  opacity: 0.92;
}

.ss-legal-content h2,
.ss-legal-content h3,
.ss-legal-content h4 {
  margin-top: 1.35em !important;
  margin-bottom: 0.5em !important;
}

.ss-legal-content h2:first-child {
  margin-top: 0 !important;
}

.ss-legal-content ul {
  margin: 0 0 14px 1.2rem !important;
  padding: 0 !important;
}

.ss-legal-content li {
  color: var(--color-text-light) !important;
  margin-bottom: 8px !important;
}

.ss-legal-content .ss-legal-caps {
  text-transform: uppercase;
  letter-spacing: 0.2px;
}

.ss-hidden-field {
  display: none;
}

@media (max-width: 1024px) {
  .ss-site-header .kc-container {
    width: 100% !important;
    max-width: 100% !important;
    padding-left: 14px !important;
    padding-right: 14px !important;
    box-sizing: border-box !important;
  }

  .ss-header-inner {
    display: flex;
    align-items: center;
    gap: 10px;
  }

  .ss-brand {
    flex: 1 1 auto;
    min-width: 0;
    max-width: calc(100% - 56px);
  }

  .main-menu {
    display: none;
  }

  .mobile-menu {
    display: flex;
    align-items: center;
    flex: 0 0 auto;
  }

  .menu-toggle {
    display: inline-flex;
    align-items: center;
    justify-content: center;
  }

  .ss-header-cta {
    display: none !important;
  }

  .sec-cs-solution-flow .sec-cs-phase-grid {
    grid-template-columns: repeat(2, 1fr) !important;
  }

  .sec-kc-hero .kc-container {
    padding-bottom: 28px !important;
  }

  .ss-footer-kc-grid {
    grid-template-columns: 1fr 1fr !important;
  }
}

@media (max-width: 767px) {
  :root {
    --ss-header-height: 66px;
  }

  .sec-kc-hero .kc-container {
    padding-top: 0 !important;
  }

  .ss-site-header .kc-container {
    width: 100% !important;
    padding-left: 12px !important;
    padding-right: 12px !important;
    box-sizing: border-box !important;
  }

  .ss-header-inner {
    min-height: var(--ss-header-height);
  }

  .ss-brand {
    min-width: 0;
    max-width: calc(100% - 46px);
  }

  .ss-brand-logo {
    height: clamp(22px, 7vw, 27px);
    max-width: 100%;
  }

  .menu-wrapper {
    padding: 0;
  }

  .menu-panel {
    width: 100%;
    max-width: 100%;
    height: 100%;
    max-height: 100%;
    padding: 20px 16px calc(24px + env(safe-area-inset-bottom));
    border-radius: 0;
  }

  .mobile-link-list > li > a {
    padding: 1rem 2px;
    letter-spacing: 1.1px;
    font-size: 1rem;
  }

  .mobile-link-list .sub-menu a {
    padding: 0.78rem 2px;
    font-size: 0.95rem;
  }

  .mobile-cta {
    margin-top: 14px !important;
    padding: 12px 24px !important;
    min-height: 0 !important;
    font-size: var(--fs-small) !important;
  }

  .sec-cs-solution-flow .sec-cs-phase-grid {
    grid-template-columns: 1fr !important;
  }

  .home .sec-kc-intro .kc-grid-2 > .kc-anim:first-child {
    order: 2;
  }

  .home .sec-kc-intro .kc-grid-2 > .kc-anim:last-child {
    order: 1;
  }

  .sec-cs-about-intro .kc-grid-2 > .kc-anim:first-child {
    order: 2;
  }

  .sec-cs-about-intro .kc-grid-2 > .kc-anim:last-child {
    order: 1;
  }

  .sec-kc-hero .kc-hero-media img,
  .sec-kc-intro .kc-intro-img,
  .sec-kc-trust .kc-trust-img,
  .sec-cs-about .kc-about-img {
    aspect-ratio: 4 / 3 !important;
    width: 100% !important;
    max-height: 420px !important;
    object-fit: cover !important;
    object-position: center top !important;
  }

  .sec-cs-problem-icons .sec-cs-problem-note .sec-cs-problem-note-box {
    flex-direction: column;
    gap: 12px;
  }

  .cs-phase-block {
    grid-template-columns: 1fr !important;
  }

  .cs-phase-num {
    min-width: 0 !important;
  }

  .ss-footer-kc-grid {
    grid-template-columns: 1fr !important;
    gap: 40px !important;
  }

  .ss-footer-kc-list a,
  .ss-footer-kc-list span,
  .ss-footer-links-main a,
  .ss-footer-legal a {
    font-size: var(--fs-body);
  }

  .ss-footer-bottom {
    flex-direction: column;
    align-items: flex-start;
  }

  .sec-cs-calendly .cs-calendly-iframe {
    min-height: 680px;
  }
}

