/*
Theme Name:  Semtrix
Theme URI:   https://semtrix.de
Author:      Semtrix GmbH
Author URI:  https://semtrix.de
Description: Custom WordPress-Theme für semtrix.de — Search Experience Agentur. Figtree-Typografie, Ocean-Farbpalette, kein Page-Builder-Overhead.
Version:     1.0.0
Requires at least: 6.4
Tested up to: 6.7
Requires PHP: 8.1
License:     Proprietary
Text Domain: semtrix
*/

/* ═══════════════════════════════════════
   DESIGN TOKENS
═══════════════════════════════════════ */
:root {
  /* Colours */
  --color-black:  #111A1B;
  --color-dark:   #244348;
  --color-deep:   #385A61;
  --color-ocean:  #568287;
  --color-ice:    #CCD9DB;
  --color-bw:     #EEF2F3;
  --color-white:  #FFFFFF;
  --color-green:  #66B65C;
  --color-green-hover: #57A04D;

  /* Typography */
  --font-base:    'Figtree', system-ui, sans-serif;
  --text-xs:      11px;
  --text-sm:      13px;
  --text-base:    15px;
  --text-md:      16px;
  --text-lg:      18px;
  --text-xl:      22px;
  --text-2xl:     28px;
  --text-3xl:     36px;
  --text-4xl:     48px;
  --text-hero:    clamp(36px, 4.5vw, 56px);
  --text-h2:      clamp(28px, 3vw, 40px);

  /* Spacing */
  --sp-2:   8px;
  --sp-3:   12px;
  --sp-4:   16px;
  --sp-5:   24px;
  --sp-6:   32px;
  --sp-7:   48px;
  --sp-8:   64px;
  --sp-9:   96px;
  --sp-10:  128px;

  /* Layout */
  --max-w:  1160px;
  --gutter: 48px;

  /* Shadows */
  --shadow-sm: 0 2px 8px rgba(17,26,27,.05);
  --shadow-md: 0 8px 28px rgba(17,26,27,.09);
  --shadow-lg: 0 16px 48px rgba(17,26,27,.13);
}

/* ═══════════════════════════════════════
   RESET
═══════════════════════════════════════ */
*, *::before, *::after { margin: 0; padding: 0; box-sizing: border-box }
html { scroll-behavior: smooth }
body {
  font-family: var(--font-base);
  font-size: var(--text-base);
  line-height: 1.75;
  color: var(--color-black);
  background: var(--color-white);
  -webkit-font-smoothing: antialiased;
}
img, svg { display: block; max-width: 100% }
a { color: inherit; text-decoration: none }
ul { list-style: none }
button { font-family: inherit; cursor: pointer }

/* ═══════════════════════════════════════
   LAYOUT PRIMITIVES
═══════════════════════════════════════ */
.wrap {
  width: 100%;
  max-width: var(--max-w);
  margin-left: auto;
  margin-right: auto;
  padding-left: var(--gutter);
  padding-right: var(--gutter);
}
.section        { padding-top: var(--sp-10); padding-bottom: var(--sp-10) }
.section-md     { padding-top: var(--sp-9);  padding-bottom: var(--sp-9)  }
.section-sm     { padding-top: var(--sp-8);  padding-bottom: var(--sp-8)  }

/* ═══════════════════════════════════════
   TYPOGRAPHY
═══════════════════════════════════════ */
.eyebrow {
  display: block;
  font-size: var(--text-xs);
  font-weight: 700;
  letter-spacing: .12em;
  text-transform: uppercase;
  color: var(--color-ocean);
  margin-bottom: var(--sp-4);
}
h1, .h1 {
  font-size: var(--text-hero);
  font-weight: 800;
  line-height: 1.07;
  letter-spacing: -.025em;
  color: var(--color-black);
}
h2, .h2 {
  font-size: var(--text-h2);
  font-weight: 800;
  line-height: 1.1;
  letter-spacing: -.02em;
  color: var(--color-black);
}
h3, .h3 {
  font-size: var(--text-xl);
  font-weight: 700;
  line-height: 1.3;
  color: var(--color-black);
}
h4, .h4 {
  font-size: var(--text-md);
  font-weight: 700;
  color: var(--color-black);
}
.lead {
  font-size: var(--text-lg);
  font-weight: 400;
  line-height: 1.7;
  color: var(--color-ocean);
}
.body-text {
  font-size: var(--text-base);
  color: #4a5e62;
  line-height: 1.75;
}
.text-white   { color: var(--color-white) }
.text-ice     { color: var(--color-ice) }
.text-ocean   { color: var(--color-ocean) }
.text-dark    { color: var(--color-dark) }
.text-green   { color: var(--color-green) }

/* ═══════════════════════════════════════
   BUTTONS
═══════════════════════════════════════ */
.btn {
  display: inline-block;
  font-family: var(--font-base);
  font-size: var(--text-sm);
  font-weight: 700;
  padding: 14px 32px;
  border: none;
  letter-spacing: .02em;
  transition: background .15s, color .15s, border-color .15s;
  white-space: nowrap;
  text-align: center;
}
.btn-primary  { background: var(--color-green); color: var(--color-white) }
.btn-primary:hover { background: var(--color-green-hover) }
.btn-white    { background: var(--color-white); color: var(--color-dark) }
.btn-white:hover { background: var(--color-bw) }
.btn-outline  {
  background: transparent; color: var(--color-dark);
  border: 1.5px solid var(--color-ice);
}
.btn-outline:hover { border-color: var(--color-ocean); background: var(--color-bw) }
.btn-ghost {
  background: transparent; border: none;
  color: var(--color-dark); font-weight: 600;
  text-decoration: underline; text-underline-offset: 4px;
  text-decoration-color: var(--color-ice);
  padding: 14px 0;
}
.btn-ghost:hover { text-decoration-color: var(--color-ocean) }
.btn-ghost-light { color: var(--color-ice); text-decoration-color: rgba(204,217,219,.35) }
.btn-ghost-light:hover { text-decoration-color: var(--color-ice) }

/* ═══════════════════════════════════════
   NAVIGATION
═══════════════════════════════════════ */
.site-header {
  position: sticky;
  top: 0;
  z-index: 200;
  transition: background .2s, border-color .2s;
}
.site-header .wrap {
  height: 72px;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: var(--sp-7);
}
.site-logo {
  font-size: 18px;
  font-weight: 800;
  letter-spacing: -.02em;
  flex-shrink: 0;
}
.site-logo .x { color: var(--color-green) }
.primary-nav { display: flex; align-items: center; gap: var(--sp-7) }
.primary-nav ul { display: flex; gap: var(--sp-6) }
.primary-nav a {
  font-size: var(--text-sm);
  font-weight: 600;
  letter-spacing: .01em;
  transition: color .12s;
}
.primary-nav a:hover { color: var(--color-green) }
.primary-nav a.current-menu-item { color: var(--color-green) }

/* Header Dark (default) */
.site-header--dark {
  background: var(--color-dark);
  border-bottom: 1px solid rgba(86,130,135,.2);
}
.site-header--dark .site-logo { color: var(--color-white) }
.site-header--dark .primary-nav a { color: var(--color-ice) }

/* Header Light */
.site-header--light {
  background: var(--color-white);
  border-bottom: 1px solid var(--color-ice);
}
.site-header--light .site-logo { color: var(--color-dark) }
.site-header--light .primary-nav a { color: var(--color-deep) }

/* Header Transparent (minimal F) */
.site-header--transparent {
  background: var(--color-white);
  border-bottom: 1px solid #e8ecec;
}
.site-header--transparent .site-logo { color: var(--color-black) }
.site-header--transparent .primary-nav a { color: var(--color-ocean) }
.site-header--transparent .btn-nav {
  background: transparent;
  border: 1.5px solid var(--color-ice);
  color: var(--color-dark);
}

/* Mobile hamburger */
.nav-toggle {
  display: none;
  flex-direction: column;
  gap: 5px;
  background: none;
  border: none;
  padding: 4px;
}
.nav-toggle span {
  display: block;
  width: 22px;
  height: 2px;
  background: currentColor;
  transition: transform .2s, opacity .2s;
}

/* ═══════════════════════════════════════
   HERO
═══════════════════════════════════════ */
/* Split Hero */
.hero-split .wrap {
  display: grid;
  grid-template-columns: 1fr 1fr;
  min-height: 600px;
  align-items: stretch;
}
.hero-copy {
  padding-top: var(--sp-10);
  padding-bottom: var(--sp-10);
  padding-right: var(--sp-9);
  display: flex;
  flex-direction: column;
  justify-content: center;
  gap: var(--sp-6);
}
.hero-ctas { display: flex; align-items: center; gap: var(--sp-5); flex-wrap: wrap }
.hero-visual {
  display: flex;
  flex-direction: column;
  justify-content: flex-end;
  gap: var(--sp-3);
  padding-top: var(--sp-8);
}
.hero-image {
  flex: 1;
  background: var(--color-deep);
  display: flex;
  align-items: center;
  justify-content: center;
  overflow: hidden;
}
.hero-image img { width: 100%; height: 100%; object-fit: cover }
.hero-stats { display: flex; gap: 2px }
.hero-stat {
  flex: 1;
  background: var(--color-black);
  padding: var(--sp-4) var(--sp-5);
  display: flex;
  flex-direction: column;
  gap: 4px;
}
.hero-stat__num {
  font-size: var(--text-xl);
  font-weight: 800;
  color: var(--color-white);
  line-height: 1;
}
.hero-stat__lbl {
  font-size: 10px;
  font-weight: 600;
  color: var(--color-ocean);
  letter-spacing: .03em;
}

/* Dark hero */
.hero--dark { background: var(--color-dark) }
.hero--dark .hero-copy h1 { color: var(--color-white) }
.hero--dark .hero-copy .lead { color: var(--color-ice) }
.hero--dark .hero-visual { background: var(--color-deep) }

/* Light hero */
.hero--light { background: var(--color-white) }
.hero--light .wrap { border-bottom: 1px solid var(--color-ice) }
.hero--light .hero-visual {
  padding: var(--sp-8) 0 var(--sp-8) var(--sp-8);
  border-left: 1px solid var(--color-ice);
}
.hero--light .hero-image { background: var(--color-bw) }

/* Centred hero */
.hero--center {
  background: var(--color-white);
  padding-top: var(--sp-10);
  padding-bottom: var(--sp-9);
}
.hero--center .wrap {
  text-align: center;
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: var(--sp-6);
  grid-template-columns: unset;
  min-height: unset;
}
.hero--center .hero-ctas { justify-content: center }
.hero--center .lead { margin-left: auto; margin-right: auto; max-width: 520px }
.hero-logo-strip {
  width: 100%;
  padding-top: var(--sp-7);
  border-top: 1px solid var(--color-ice);
  display: flex;
  align-items: center;
  justify-content: center;
  gap: var(--sp-7);
  flex-wrap: wrap;
}
.hero-logo-strip__label {
  font-size: 10px;
  font-weight: 700;
  color: var(--color-ice);
  letter-spacing: .1em;
  text-transform: uppercase;
}
.hero-logo-strip img {
  height: 28px;
  width: auto;
  opacity: .5;
  filter: grayscale(1);
}

/* ═══════════════════════════════════════
   TRUST BAR
═══════════════════════════════════════ */
.trust-bar {
  background: var(--color-bw);
  border-bottom: 1px solid var(--color-ice);
}
.trust-bar .wrap { display: flex; align-items: stretch }
.trust-bar__item {
  flex: 1;
  padding: var(--sp-6) var(--sp-7);
  border-right: 1px solid var(--color-ice);
  display: flex;
  flex-direction: column;
  gap: 4px;
}
.trust-bar__item:last-child { border-right: none; flex: 1.5 }
.trust-bar__num {
  font-size: 32px;
  font-weight: 800;
  color: var(--color-dark);
  line-height: 1;
}
.trust-bar__lbl {
  font-size: 12px;
  font-weight: 600;
  color: var(--color-ocean);
}
.trust-bar__partners-label {
  font-size: 9px;
  font-weight: 700;
  color: var(--color-ocean);
  letter-spacing: .1em;
  text-transform: uppercase;
  margin-bottom: 8px;
  display: block;
}
.trust-bar__logos { display: flex; gap: 8px }
.trust-bar__logo {
  height: 22px;
  width: auto;
  opacity: .5;
  filter: grayscale(1);
}

/* ═══════════════════════════════════════
   CARDS
═══════════════════════════════════════ */
.cards-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 2px;
}
.cards-grid--4 { grid-template-columns: repeat(4, 1fr) }
.cards-grid--2 { grid-template-columns: repeat(2, 1fr) }

.card {
  padding: var(--sp-7) var(--sp-6);
  background: var(--color-bw);
  border-left: 4px solid var(--color-ocean);
  transition: box-shadow .2s;
}
.card:hover { box-shadow: var(--shadow-md) }
.card--dark  { background: var(--color-dark); border-left-color: var(--color-green) }
.card--white { background: var(--color-white); border-left: none; border-top: 3px solid var(--color-ice) }
.card--white:hover { border-top-color: var(--color-green); box-shadow: var(--shadow-sm) }
.card--numbered {
  background: var(--color-dark);
  border-left: none;
  display: flex;
  flex-direction: column;
  align-items: center;
  text-align: center;
  padding: var(--sp-7) var(--sp-6);
}
.card__eyebrow {
  font-size: 10px;
  font-weight: 700;
  color: var(--color-ocean);
  letter-spacing: .08em;
  text-transform: uppercase;
  margin-bottom: var(--sp-5);
}
.card__num {
  font-size: 40px;
  font-weight: 800;
  color: var(--color-white);
  line-height: 1;
  margin-bottom: var(--sp-5);
}
.card h3 { margin-bottom: var(--sp-3) }
.card .body-text { margin-bottom: var(--sp-5) }
.card__link {
  font-size: var(--text-sm);
  font-weight: 700;
  color: var(--color-green);
  display: inline-block;
  transition: text-decoration .12s;
}
.card__link:hover { text-decoration: underline }

/* Step cards */
.step-card {
  padding: var(--sp-7) var(--sp-5);
  background: var(--color-white);
  border-top: 4px solid var(--color-ice);
  transition: box-shadow .2s;
}
.step-card--active { border-top-color: var(--color-green) }
.step-card__num {
  font-size: 40px;
  font-weight: 800;
  color: var(--color-ice);
  line-height: 1;
  margin-bottom: var(--sp-5);
}
.step-card--active .step-card__num { color: var(--color-green) }

/* ═══════════════════════════════════════
   SECTION INTROS (eyebrow + h2 + lead side by side)
═══════════════════════════════════════ */
.section-intro {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: var(--sp-10);
  align-items: end;
  margin-bottom: var(--sp-8);
}
.section-intro--center { grid-template-columns: 1fr; text-align: center }
.section-intro--center .lead { margin-left: auto; margin-right: auto }
.section-intro--center .eyebrow { text-align: center }

/* ═══════════════════════════════════════
   SPLIT SECTIONS
═══════════════════════════════════════ */
.split-section { display: grid; grid-template-columns: 1fr 1fr }

.split-dark {
  background: var(--color-dark);
  padding: var(--sp-10) var(--sp-9) var(--sp-10) max(var(--gutter), calc(50vw - var(--max-w)/2 + var(--gutter)));
  display: flex;
  flex-direction: column;
  justify-content: center;
  gap: var(--sp-6);
}
.split-light {
  background: var(--color-bw);
  padding: var(--sp-10) max(var(--gutter), calc(50vw - var(--max-w)/2 + var(--gutter))) var(--sp-10) var(--sp-9);
  display: flex;
  flex-direction: column;
  justify-content: center;
}

.check-list { display: flex; flex-direction: column }
.check-item {
  display: flex;
  gap: var(--sp-4);
  align-items: flex-start;
  padding: var(--sp-5) 0;
  border-bottom: 1px solid var(--color-ice);
}
.check-item:last-child { border-bottom: none }
.check-item__box {
  width: 18px;
  height: 18px;
  background: var(--color-green);
  flex-shrink: 0;
  margin-top: 3px;
}
.check-item__label { font-size: 14px; font-weight: 700; color: var(--color-dark) }
.check-item__sub   { font-size: 12px; color: var(--color-ocean); margin-top: 2px }

/* ═══════════════════════════════════════
   KI / DARK SECTION
═══════════════════════════════════════ */
.section--black { background: var(--color-black) }
.section--dark  { background: var(--color-dark) }
.section--deep  { background: var(--color-deep) }
.section--bw    { background: var(--color-bw) }

.dark-card {
  background: var(--color-dark);
  padding: var(--sp-7) var(--sp-6);
  transition: box-shadow .2s;
}
.dark-card:hover { box-shadow: var(--shadow-md) }
.dark-card__icon {
  width: 40px;
  height: 40px;
  background: var(--color-deep);
  margin-bottom: var(--sp-5);
}
.dark-card h3 { color: var(--color-white); margin-bottom: var(--sp-3) }
.dark-card .body-text { color: var(--color-ocean) }

/* ═══════════════════════════════════════
   HIGHLIGHT / INFO BOXES
═══════════════════════════════════════ */
.highlight-box {
  background: var(--color-bw);
  border-left: 4px solid var(--color-green);
  padding: var(--sp-5) var(--sp-6);
}
.highlight-box p { font-size: 15px; font-weight: 600; color: var(--color-dark); line-height: 1.7 }

.info-box {
  background: var(--color-dark);
  padding: var(--sp-6);
}
.info-box h4 { color: var(--color-white); margin-bottom: var(--sp-3) }
.info-box p  { color: var(--color-ice); font-size: var(--text-sm); line-height: 1.65 }

/* ═══════════════════════════════════════
   LOGOS
═══════════════════════════════════════ */
.logo-section {
  border-top: 1px solid var(--color-ice);
  border-bottom: 1px solid var(--color-ice);
}
.logo-section .wrap {
  padding-top: var(--sp-8);
  padding-bottom: var(--sp-8);
}
.logo-row {
  display: flex;
  gap: var(--sp-7);
  align-items: center;
  justify-content: center;
  flex-wrap: wrap;
  margin-top: var(--sp-6);
}
.logo-row img {
  height: 32px;
  width: auto;
  opacity: .5;
  filter: grayscale(1);
  transition: opacity .2s;
}
.logo-row img:hover { opacity: .8 }

/* ═══════════════════════════════════════
   TESTIMONIAL
═══════════════════════════════════════ */
.testimonial-section {
  background: var(--color-deep);
  padding-top: var(--sp-10);
  padding-bottom: var(--sp-10);
  text-align: center;
}
.testimonial-section .wrap { max-width: 760px }
.testimonial__quote {
  font-size: clamp(20px, 2.2vw, 28px);
  font-weight: 800;
  color: var(--color-white);
  line-height: 1.35;
}
.testimonial__attr {
  font-size: var(--text-sm);
  font-weight: 600;
  color: var(--color-ocean);
  margin-top: var(--sp-5);
}

/* ═══════════════════════════════════════
   CTA BANNER
═══════════════════════════════════════ */
.cta-banner {
  background: var(--color-green);
}
.cta-banner .wrap {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: var(--sp-8);
  padding-top: var(--sp-9);
  padding-bottom: var(--sp-9);
}
.cta-banner h2 { color: var(--color-white); max-width: 520px }

.inline-cta {
  background: var(--color-dark);
  padding: var(--sp-6) var(--sp-7);
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: var(--sp-7);
}
.inline-cta p { font-size: 16px; font-weight: 700; color: var(--color-white); flex: 1; line-height: 1.5 }
.inline-cta p span { color: var(--color-green) }

/* ═══════════════════════════════════════
   FORMS
═══════════════════════════════════════ */
.form-field { display: flex; flex-direction: column; gap: 6px }
.form-field label {
  font-size: 10px;
  font-weight: 700;
  color: var(--color-ocean);
  letter-spacing: .08em;
  text-transform: uppercase;
}
.form-field input,
.form-field select,
.form-field textarea {
  width: 100%;
  padding: 12px 16px;
  border: 1px solid var(--color-ice);
  border-bottom: 2px solid var(--color-ice);
  background: var(--color-bw);
  font-family: var(--font-base);
  font-size: 14px;
  color: var(--color-black);
  transition: border-color .15s, background .15s;
  border-radius: 0;
  appearance: none;
}
.form-field input:focus,
.form-field select:focus,
.form-field textarea:focus {
  outline: none;
  border-bottom-color: var(--color-green);
  background: var(--color-white);
}
.form-field textarea { resize: vertical; min-height: 100px }
.form-field .hint { font-size: 11px; color: var(--color-ocean) }
.form-row { display: grid; grid-template-columns: 1fr 1fr; gap: 16px }
.checkbox-row { display: flex; gap: 10px; align-items: flex-start }
.checkbox-row input[type="checkbox"] {
  width: 16px; height: 16px;
  margin-top: 2px; flex-shrink: 0;
  accent-color: var(--color-green);
}
.checkbox-row label {
  font-size: 12px; color: #678; line-height: 1.6;
  font-weight: 400; letter-spacing: 0; text-transform: none;
}

/* ═══════════════════════════════════════
   SIDEBAR
═══════════════════════════════════════ */
.content-sidebar-layout {
  display: grid;
  grid-template-columns: 1fr 360px;
  gap: 0;
  align-items: start;
}
.sidebar { background: var(--color-bw); border-left: 1px solid var(--color-ice) }
.sidebar-widget {
  padding: var(--sp-6) var(--sp-5);
  border-bottom: 1px solid var(--color-ice);
}
.sidebar-widget:last-child { border-bottom: none }
.sidebar-widget__title {
  font-size: 10px;
  font-weight: 700;
  color: var(--color-ocean);
  letter-spacing: .08em;
  text-transform: uppercase;
  margin-bottom: var(--sp-4);
}

/* ═══════════════════════════════════════
   TEAM CARDS
═══════════════════════════════════════ */
.team-card {
  background: var(--color-white);
  border: 1px solid var(--color-ice);
  overflow: hidden;
  transition: box-shadow .2s;
}
.team-card:hover { box-shadow: var(--shadow-md) }
.team-card__photo {
  width: 100%;
  aspect-ratio: 3/4;
  object-fit: cover;
  background: var(--color-deep);
}
.team-card__body { padding: var(--sp-5) var(--sp-5) var(--sp-6) }
.team-card__name { font-size: 16px; font-weight: 700; color: var(--color-black) }
.team-card__role { font-size: 13px; font-weight: 600; color: var(--color-ocean); margin-top: 2px }
.team-card__spec { font-size: 12px; color: #789; margin-top: 6px; line-height: 1.5 }

/* ═══════════════════════════════════════
   BADGES & CHIPS
═══════════════════════════════════════ */
.badge {
  display: inline-block;
  font-size: 9px;
  font-weight: 700;
  letter-spacing: .08em;
  text-transform: uppercase;
  padding: 4px 10px;
  border-radius: 0;
}
.badge--ocean { background: var(--color-bw); color: var(--color-ocean); border: 1px solid var(--color-ice) }
.badge--dark  { background: var(--color-dark); color: var(--color-white) }
.badge--green { background: var(--color-green); color: var(--color-white) }

.chip {
  display: inline-block;
  font-family: var(--font-base);
  font-size: 12px;
  font-weight: 700;
  padding: 8px 16px;
  border: 2px solid transparent;
  background: var(--color-bw);
  color: var(--color-ocean);
  transition: all .12s;
  cursor: pointer;
}
.chip--active { background: var(--color-dark); color: var(--color-white); border-color: var(--color-dark) }
.chip:hover   { border-color: var(--color-ocean) }

/* ═══════════════════════════════════════
   FOOTER
═══════════════════════════════════════ */
.site-footer { background: var(--color-black) }
.site-footer .wrap {
  display: grid;
  grid-template-columns: 2fr 1fr 1fr 1fr;
  gap: var(--sp-9);
  padding-top: var(--sp-9);
  padding-bottom: var(--sp-8);
}
.footer-brand__logo {
  font-size: 17px;
  font-weight: 800;
  color: var(--color-white);
}
.footer-brand__logo .x { color: var(--color-green) }
.footer-brand__desc {
  font-size: 13px;
  color: var(--color-ocean);
  line-height: 1.7;
  margin-top: var(--sp-4);
}
.footer-col h4 {
  font-size: 9px;
  font-weight: 700;
  color: var(--color-ocean);
  letter-spacing: .12em;
  text-transform: uppercase;
  margin-bottom: var(--sp-5);
}
.footer-col ul { display: flex; flex-direction: column; gap: var(--sp-3) }
.footer-col ul a { font-size: 13px; color: var(--color-ice); transition: color .12s }
.footer-col ul a:hover { color: var(--color-white) }
.footer-bottom {
  background: var(--color-black);
  border-top: 1px solid var(--color-dark);
}
.footer-bottom .wrap {
  display: flex;
  justify-content: space-between;
  align-items: center;
  padding-top: var(--sp-5);
  padding-bottom: var(--sp-5);
  grid-template-columns: unset;
  gap: 0;
}
.footer-bottom p { font-size: 11px; color: var(--color-ocean) }

/* ═══════════════════════════════════════
   UTILITIES
═══════════════════════════════════════ */
.bg-white  { background: var(--color-white) }
.bg-bw     { background: var(--color-bw) }
.bg-dark   { background: var(--color-dark) }
.bg-black  { background: var(--color-black) }
.bg-deep   { background: var(--color-deep) }
.bg-green  { background: var(--color-green) }
.mt-auto   { margin-top: auto }
.gap-2     { gap: 2px }
.sr-only   { position: absolute; width: 1px; height: 1px; padding: 0; margin: -1px; overflow: hidden; clip: rect(0,0,0,0); white-space: nowrap; border: 0 }

/* ═══════════════════════════════════════
   RESPONSIVE
═══════════════════════════════════════ */
@media (max-width: 1024px) {
  :root { --gutter: 32px }
  .hero-split .wrap { grid-template-columns: 1fr }
  .hero--dark .hero-visual { display: none }
  .section-intro { grid-template-columns: 1fr; gap: var(--sp-6) }
  .cards-grid--4 { grid-template-columns: repeat(2,1fr) }
  .content-sidebar-layout { grid-template-columns: 1fr }
  .sidebar { border-left: none; border-top: 1px solid var(--color-ice) }
}

@media (max-width: 768px) {
  :root {
    --gutter: 20px;
    --sp-9:  64px;
    --sp-10: 80px;
  }
  .site-header .wrap { height: 60px }
  .primary-nav ul { display: none }
  .nav-toggle { display: flex }
  .primary-nav.is-open ul {
    display: flex;
    flex-direction: column;
    position: fixed;
    inset: 60px 0 0;
    background: var(--color-dark);
    padding: var(--sp-7) var(--sp-6);
    gap: 0;
    z-index: 100;
  }
  .primary-nav.is-open ul a {
    color: var(--color-white);
    font-size: 18px;
    padding: var(--sp-5) 0;
    border-bottom: 1px solid rgba(86,130,135,.2);
    display: block;
  }
  .cards-grid { grid-template-columns: 1fr }
  .cards-grid--2 { grid-template-columns: 1fr }
  .split-section { grid-template-columns: 1fr }
  .split-dark, .split-light { padding: var(--sp-8) var(--gutter) }
  .trust-bar .wrap { flex-wrap: wrap }
  .trust-bar__item { flex: 1 1 50%; border-right: none; border-bottom: 1px solid var(--color-ice) }
  .trust-bar__item:nth-child(odd) { border-right: 1px solid var(--color-ice) }
  .cta-banner .wrap { flex-direction: column; align-items: flex-start }
  .cta-banner .btn { width: 100%; text-align: center }
  .site-footer .wrap { grid-template-columns: 1fr 1fr; gap: var(--sp-7) }
  .footer-bottom .wrap { flex-direction: column; gap: var(--sp-2); text-align: center }
  .steps-row { grid-template-columns: 1fr }
  .form-row { grid-template-columns: 1fr }
  .hero--center h1 { font-size: 32px }
}

/* ═══════════════════════════════════════
   BREADCRUMB
═══════════════════════════════════════ */
.breadcrumb-nav {
  background: var(--color-bw);
  border-bottom: 1px solid var(--color-ice);
}
.breadcrumb-nav .wrap {
  padding-top: 12px;
  padding-bottom: 12px;
  font-size: 12px;
  font-weight: 600;
  color: var(--color-ocean);
}
.breadcrumb-nav a { color: var(--color-ocean) }
.breadcrumb-nav a:hover { color: var(--color-dark) }
.breadcrumb-nav span[aria-current] { color: var(--color-dark) }

/* ═══════════════════════════════════════
   LP HERO
═══════════════════════════════════════ */
.lp-hero { background: var(--color-dark) }
.lp-hero__inner {
  display: grid;
  grid-template-columns: 1fr 400px;
  gap: var(--sp-10);
  align-items: start;
  padding-top: var(--sp-9);
  padding-bottom: var(--sp-9);
}
.lp-hero__copy {
  display: flex;
  flex-direction: column;
  gap: var(--sp-6);
}
.lp-hero__copy h1 { color: var(--color-white) }
.lp-form-box {
  background: var(--color-white);
  padding: var(--sp-6);
  display: flex;
  flex-direction: column;
  gap: var(--sp-5);
}
.lp-form-box h3 { font-size: 18px; font-weight: 800; color: var(--color-black) }

/* ═══════════════════════════════════════
   HERO META (Pillar Page)
═══════════════════════════════════════ */
.pillar-hero { background: var(--color-dark) }
.pillar-hero__inner {
  display: grid;
  grid-template-columns: 1fr 360px;
  gap: var(--sp-9);
  padding-top: var(--sp-8);
  padding-bottom: var(--sp-8);
  align-items: start;
}
.pillar-hero__copy {
  display: flex;
  flex-direction: column;
  gap: var(--sp-5);
}
.hero-meta {
  display: flex;
  gap: var(--sp-6);
  flex-wrap: wrap;
  margin-top: var(--sp-2);
}
.hero-meta span {
  font-size: 12px;
  font-weight: 600;
  color: var(--color-ocean);
  display: flex;
  align-items: center;
  gap: 6px;
}

/* ═══════════════════════════════════════
   TOC BOX
═══════════════════════════════════════ */
.toc-box {
  background: var(--color-black);
  padding: var(--sp-6);
  position: sticky;
  top: calc(72px + 40px + var(--sp-5));
}
.toc-box__title {
  font-size: 10px;
  font-weight: 700;
  color: var(--color-ocean);
  letter-spacing: .08em;
  text-transform: uppercase;
  margin-bottom: var(--sp-4);
}
.toc-list { list-style: none; display: flex; flex-direction: column }
.toc-list li a {
  font-size: 13px;
  font-weight: 600;
  color: var(--color-ice);
  text-decoration: none;
  display: block;
  padding: var(--sp-3) 0;
  border-bottom: 1px solid var(--color-dark);
  line-height: 1.4;
  transition: color .12s;
}
.toc-list li a:hover { color: var(--color-green) }
.toc-list li a.is-active { color: var(--color-green) }
.toc-list li a span {
  font-size: 10px;
  color: var(--color-ocean);
  margin-right: 8px;
  font-weight: 700;
}
.toc-list li.toc--h3 a { padding-left: var(--sp-5); font-weight: 400 }

/* ═══════════════════════════════════════
   PILLAR CONTENT
═══════════════════════════════════════ */
.pillar-main {
  background: var(--color-white);
  border-right: 1px solid var(--color-ice);
}
.pillar-section {
  padding: var(--sp-8) var(--sp-9);
  border-bottom: 1px solid var(--color-ice);
}
.pillar-section:last-child { border-bottom: none }
.pillar-section h2 {
  margin-bottom: var(--sp-5);
  scroll-margin-top: calc(72px + 56px);
}
.pillar-section h3 {
  margin-top: var(--sp-7);
  margin-bottom: var(--sp-3);
  scroll-margin-top: calc(72px + 56px);
}
.pillar-body {
  font-size: var(--text-base);
  color: var(--color-black);
  line-height: 1.8;
}
.pillar-body p { margin-bottom: var(--sp-4) }
.pillar-body ul, .pillar-body ol { padding-left: var(--sp-6); margin-bottom: var(--sp-4) }
.pillar-body li { margin-bottom: var(--sp-2) }

/* Feature list */
.feature-list {
  list-style: none;
  display: flex;
  flex-direction: column;
  gap: var(--sp-3);
}
.feature-list--2col {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: var(--sp-3) var(--sp-7);
}
.feature-list li {
  display: flex;
  gap: var(--sp-3);
  align-items: flex-start;
  font-size: var(--text-base);
  color: var(--color-black);
}
.feature-dot {
  width: 18px;
  height: 18px;
  background: var(--color-green);
  flex-shrink: 0;
  margin-top: 3px;
}

/* Table */
.pillar-table-wrap { overflow-x: auto; margin: var(--sp-6) 0 }
.pillar-table {
  width: 100%;
  border-collapse: collapse;
  font-size: 14px;
}
.pillar-table th {
  background: var(--color-dark);
  color: var(--color-white);
  padding: 14px 18px;
  text-align: left;
  font-weight: 700;
  font-size: 13px;
  letter-spacing: .03em;
}
.pillar-table td {
  padding: 13px 18px;
  border-bottom: 1px solid var(--color-ice);
  color: var(--color-black);
  line-height: 1.5;
}
.pillar-table tr:nth-child(even) td { background: var(--color-bw) }

/* Process steps */
.pillar-steps { display: flex; flex-direction: column; gap: 0; margin: var(--sp-5) 0 }
.pillar-step {
  display: flex;
  gap: var(--sp-5);
  position: relative;
  padding-bottom: var(--sp-7);
}
.pillar-step::after {
  content: '';
  position: absolute;
  left: 19px;
  top: 40px;
  bottom: 0;
  width: 2px;
  background: var(--color-ice);
}
.pillar-step:last-child { padding-bottom: 0 }
.pillar-step:last-child::after { display: none }
.pillar-step__num {
  width: 40px;
  height: 40px;
  background: var(--color-dark);
  color: var(--color-white);
  font-size: 16px;
  font-weight: 800;
  display: flex;
  align-items: center;
  justify-content: center;
  flex-shrink: 0;
  z-index: 1;
  position: relative;
}
.pillar-step__body { padding-top: 8px }
.pillar-step__body h4 { font-size: 15px; font-weight: 700; color: var(--color-black); margin-bottom: var(--sp-2) }
.pillar-step__body ul { padding-left: var(--sp-5); margin-top: var(--sp-3); font-size: 14px; color: #567; line-height: 1.8 }

/* ═══════════════════════════════════════
   TABS (Leistungen + Leitfaden)
═══════════════════════════════════════ */
.leistungen-tabs {
  display: flex;
  border-bottom: 2px solid var(--color-ice);
  overflow-x: auto;
}
.leistungen-tab {
  font-family: var(--font-base);
  font-size: 14px;
  font-weight: 700;
  padding: var(--sp-4) var(--sp-6);
  border: none;
  background: transparent;
  color: var(--color-ocean);
  cursor: pointer;
  border-bottom: 3px solid transparent;
  margin-bottom: -2px;
  white-space: nowrap;
  transition: color .12s, border-color .12s;
}
.leistungen-tab--active { color: var(--color-dark); border-bottom-color: var(--color-green) }
.leistungen-tab:hover   { color: var(--color-dark) }

.leistungen-tab-layout {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 0;
}
.leistungen-tab-left  { padding: var(--sp-8) var(--sp-9) var(--sp-8) 0; background: var(--color-bw) }
.leistungen-tab-right { padding: var(--sp-8) 0 var(--sp-8) var(--sp-7) }
.leistungen-tab-left h3 { margin-bottom: var(--sp-5) }

/* Deliverable */
.deliverable {
  display: flex;
  gap: var(--sp-5);
  align-items: flex-start;
  padding: var(--sp-5) 0;
  border-bottom: 1px solid var(--color-ice);
}
.deliverable:last-child { border: none }
.deliverable__num {
  font-size: 28px;
  font-weight: 800;
  color: var(--color-ice);
  line-height: 1;
  flex-shrink: 0;
  width: 36px;
}
.deliverable h4 { font-size: 15px; margin-bottom: var(--sp-2) }

/* ═══════════════════════════════════════
   FAQ
═══════════════════════════════════════ */
.faq-list { display: flex; flex-direction: column }
.faq-item { border-top: 1px solid var(--color-ice) }
.faq-item:last-child { border-bottom: 1px solid var(--color-ice) }
.faq-question {
  width: 100%;
  display: flex;
  justify-content: space-between;
  align-items: center;
  gap: var(--sp-5);
  padding: var(--sp-5) 0;
  background: none;
  border: none;
  font-family: var(--font-base);
  font-size: 15px;
  font-weight: 700;
  color: var(--color-black);
  cursor: pointer;
  text-align: left;
}
.faq-icon {
  width: 20px;
  height: 20px;
  position: relative;
  flex-shrink: 0;
}
.faq-icon::before,
.faq-icon::after {
  content: '';
  position: absolute;
  background: var(--color-ocean);
  transition: transform .2s;
}
.faq-icon::before { width: 14px; height: 2px; top: 9px; left: 3px }
.faq-icon::after  { width: 2px; height: 14px; top: 3px; left: 9px }
.faq-question[aria-expanded="true"] .faq-icon::after { transform: rotate(90deg) }
.faq-answer {
  padding: 0 0 var(--sp-5) 0;
  max-width: 680px;
}
.faq-answer p { font-size: 14px; color: #456; line-height: 1.75 }
.faq-answer[hidden] { display: none }

/* ═══════════════════════════════════════
   TIMELINE
═══════════════════════════════════════ */
.timeline {
  position: relative;
  padding-left: var(--sp-8);
  margin-top: var(--sp-7);
}
.timeline::before {
  content: '';
  position: absolute;
  left: 0;
  top: 0;
  bottom: 0;
  width: 2px;
  background: var(--color-ice);
}
.timeline__item {
  position: relative;
  padding-bottom: var(--sp-8);
}
.timeline__item:last-child { padding-bottom: 0 }
.timeline__dot {
  position: absolute;
  left: calc(-1 * var(--sp-8) - 5px);
  top: 5px;
  width: 12px;
  height: 12px;
  border-radius: 50%;
  background: var(--color-ocean);
  border: 2px solid var(--color-white);
  z-index: 1;
}
.timeline__year {
  font-size: 11px;
  font-weight: 700;
  color: var(--color-ocean);
  letter-spacing: .08em;
  text-transform: uppercase;
  margin-bottom: var(--sp-2);
}
.timeline__title {
  font-size: 17px;
  font-weight: 700;
  color: var(--color-black);
  margin-bottom: var(--sp-2);
}

/* ═══════════════════════════════════════
   ADDITIONAL RESPONSIVE
═══════════════════════════════════════ */
@media (max-width: 1024px) {
  .lp-hero__inner     { grid-template-columns: 1fr }
  .pillar-hero__inner { grid-template-columns: 1fr }
  .toc-box            { display: none }
  .leistungen-tab-layout { grid-template-columns: 1fr }
  .leistungen-tab-left { padding: var(--sp-6) var(--sp-5) }
  .leistungen-tab-right { padding: var(--sp-6) var(--sp-5) }
}

@media (max-width: 768px) {
  .pillar-section { padding: var(--sp-7) var(--sp-5) }
  .feature-list--2col { grid-template-columns: 1fr }
  .timeline { padding-left: var(--sp-6) }
}
