/* ============================================================
   Mahlich — Karriere
   Stil wie EDV-Sachverstand / Umweltschutz: dunkler Glow-Hero,
   Chrome-Schrift, helle Sektionen, aufklappbare Stellenkarten.
   Baut auf mahlich2.css + pages.css
   ============================================================ */

/* helle, eisblaue Grundstimmung (wie Leistungen / EDV) */
body {
  --bg: oklch(0.965 0.012 252);
  --surface: oklch(0.995 0.004 252);
  --surface-2: oklch(0.935 0.018 252);
  --line: oklch(0.89 0.018 252);
  --line-soft: oklch(0.92 0.015 252);
  background: var(--bg);
  color: var(--ink);
}

/* ============================================================
   HERO — dunkel, Glow, Chrome
   ============================================================ */
.kr-hero {
  position: relative; isolation: isolate; overflow: hidden; color: #fff;
  min-height: 100svh; display: flex; flex-direction: column;
  background:
    radial-gradient(120% 80% at 50% -10%, var(--hero-1), transparent 60%),
    linear-gradient(180deg, var(--hero-2) 0%, var(--hero-3) 100%);
}
.kr-hero::before {
  content: ""; position: absolute; inset: 0; z-index: -1; opacity: 0.4; pointer-events: none;
  background-image: radial-gradient(rgba(255,255,255,0.06) 1px, transparent 1px);
  background-size: 30px 30px;
  -webkit-mask-image: radial-gradient(110% 70% at 50% 0%, #000 30%, transparent 75%);
  mask-image: radial-gradient(110% 70% at 50% 0%, #000 30%, transparent 75%);
}
.kr-hero .bloom {
  position: absolute; z-index: -1; left: 50%; top: clamp(40px, 11vh, 130px);
  width: min(760px, 92vw); height: 340px; transform: translateX(-50%);
  background:
    radial-gradient(ellipse 34% 44% at 50% 46%, rgba(var(--glow), 1) 0%, rgba(var(--glow), 0.5) 24%, rgba(var(--glow), 0.16) 46%, transparent 66%);
  filter: blur(26px); opacity: 0.9; pointer-events: none;
  will-change: transform;
}
.kr-hero .bloom-2 {
  position: absolute; z-index: -1; right: -10%; top: -6%; width: 540px; height: 540px;
  background: radial-gradient(circle at 50% 50%, rgba(var(--glow-2), 0.42), transparent 62%);
  filter: blur(54px); pointer-events: none;
}

.kr-hero-content {
  margin: auto; text-align: center; max-width: 980px;
  padding-inline: var(--pad); position: relative; z-index: 2;
}
.kr-hero-content .eyebrow { color: rgba(255,255,255,0.66); justify-content: center; }
.kr-hero-content .eyebrow::before {
  content: ""; width: 8px; height: 8px; border-radius: 50%;
  background: oklch(0.78 0.18 150); box-shadow: 0 0 12px rgba(60,210,130,0.8);
  animation: krPulse 2.4s var(--ease) infinite;
}
@keyframes krPulse { 0%,100% { opacity: 1; } 50% { opacity: 0.55; } }
.kr-hero-content h1 {
  font-size: clamp(2.6rem, 6.6vw, 5.4rem); font-weight: 600;
  letter-spacing: -0.035em; margin-top: 20px; line-height: 1.0;
}
.kr-hero-content .sub {
  font-size: clamp(1.02rem, 1.7vw, 1.26rem); color: rgba(255,255,255,0.76);
  margin: 26px auto 0; max-width: 58ch; line-height: 1.65;
}
.kr-hero-actions { display: flex; flex-wrap: wrap; gap: 14px; justify-content: center; margin-top: 36px; }

.kr-hint {
  position: absolute; left: 50%; bottom: clamp(20px, 4vh, 42px); transform: translateX(-50%); z-index: 2;
  font-family: var(--font-mono); font-size: 0.7rem; letter-spacing: 0.2em; text-transform: uppercase;
  color: rgba(255,255,255,0.66); padding-bottom: 9px; white-space: nowrap;
  border-bottom: 1px solid rgba(255,255,255,0.38); animation: krHint 2.6s var(--ease) infinite;
}
@keyframes krHint { 0%,100% { opacity: 0.7; } 50% { opacity: 1; } }

@media (prefers-reduced-motion: no-preference) {
  .kr-hero-content .eyebrow, .kr-hero-content h1, .kr-hero-content .sub, .kr-hero-actions {
    animation-name: krRise; animation-duration: 0.9s; animation-timing-function: var(--ease); animation-fill-mode: backwards;
  }
  .kr-hero-content .eyebrow { animation-delay: 0.05s; }
  .kr-hero-content h1 { animation-delay: 0.14s; }
  .kr-hero-content .sub { animation-delay: 0.26s; }
  .kr-hero-actions { animation-delay: 0.38s; }
  @keyframes krRise { from { opacity: 0; transform: translateY(22px); } to { opacity: 1; transform: none; } }
  .kr-hint { animation: krRise 0.9s var(--ease) 0.56s backwards, krHint 2.6s var(--ease) 1.5s infinite; }
}
@media (prefers-reduced-motion: reduce) {
  .kr-hero-content .eyebrow::before { animation: none; }
  .kr-hint { animation: none; }
}

/* Top-Navigation im Hero */
.kr-hero .page-nav { position: relative; z-index: 3; }

/* ============================================================
   WEN WIR SUCHEN — Split Foto + Ticks
   ============================================================ */
.team-inner { display: grid; grid-template-columns: 0.95fr 1.05fr; gap: clamp(32px, 5vw, 72px); align-items: center; }
@media (max-width: 880px) { .team-inner { grid-template-columns: 1fr; } }

.team-photo { position: relative; }
.team-photo .ph-wrap {
  border-radius: var(--radius); overflow: hidden;
  box-shadow: 0 44px 90px -44px rgba(2,2,60,0.45);
}
.team-photo .ph {
  width: 100%; aspect-ratio: 4 / 3.4; object-fit: cover; display: block;
  transition: transform 0.8s var(--ease);
}
.team-photo:hover .ph { transform: scale(1.045); }
.team-badge {
  position: absolute; left: -14px; bottom: -14px; z-index: 2;
  display: flex; align-items: center; gap: 12px;
  padding: 12px 18px 12px 14px; border-radius: var(--r-pill);
  background: linear-gradient(180deg, color-mix(in oklab, var(--accent) 96%, #000), color-mix(in oklab, var(--accent) 72%, #000));
  color: #fff; box-shadow: 0 22px 44px -20px rgba(2,10,50,0.6);
}
.team-badge .pb-ic { width: 34px; height: 34px; flex: none; border-radius: 50%; display: grid; place-items: center; background: rgba(255,255,255,0.18); }
.team-badge .pb-ic svg { width: 18px; height: 18px; }
.team-badge b { font-size: 0.92rem; font-weight: 700; line-height: 1.1; }
.team-badge small { display: block; font-family: var(--font-mono); font-size: 0.66rem; letter-spacing: 0.06em; color: rgba(255,255,255,0.8); margin-top: 2px; }
.team-badge { transition: transform 0.4s var(--ease); }
.team-photo:hover .team-badge { transform: translateY(-4px) rotate(-1.5deg); }

.team-body .eyebrow { color: var(--accent); }
.team-body h2 { font-size: clamp(1.8rem, 3.4vw, 2.7rem); margin-top: 14px; letter-spacing: -0.03em; }
.team-body .lead { color: var(--ink-soft); font-size: 1.06rem; line-height: 1.7; margin-top: 16px; }

.team-ticks { display: grid; gap: 4px; margin-top: 26px; }
.team-ticks li { display: grid; grid-template-columns: auto 1fr; gap: 14px; align-items: start; padding: 14px 0; border-top: 1px solid var(--line); }
.team-ticks li:last-child { border-bottom: 1px solid var(--line); }
.team-ticks .tick {
  width: 26px; height: 26px; flex: none; border-radius: 50%; margin-top: 1px; display: grid; place-items: center;
  background: color-mix(in oklab, var(--accent) 14%, transparent); color: var(--accent);
}
.team-ticks .tick svg { width: 13px; height: 13px; }
.team-ticks b { font-weight: 700; font-size: 1.02rem; }
.team-ticks span.tx { display: block; color: var(--ink-soft); font-size: 0.93rem; margin-top: 3px; line-height: 1.6; }
.team-ticks li { transition: background 0.25s; }
.team-ticks li:hover .tick { transform: scale(1.12); }
.team-ticks .tick { transition: transform 0.3s var(--ease); }

/* Ticks gleiten nacheinander herein */
@media (prefers-reduced-motion: no-preference) {
  .team-ticks li { opacity: 0; transform: translateX(-16px); transition: opacity .55s ease, transform .7s var(--ease); }
  .team-ticks.in li { opacity: 1; transform: none; }
  .team-ticks.in li:nth-child(2) { transition-delay: .12s; }
  .team-ticks.in li:nth-child(3) { transition-delay: .24s; }
  .team-ticks.in li:nth-child(4) { transition-delay: .36s; }
}

/* ============================================================
   WERTE — dunkles Panel
   ============================================================ */
.values-box {
  position: relative; isolation: isolate; overflow: hidden;
  border-radius: calc(var(--radius) * 1.3); color: #fff; text-align: center;
  padding: clamp(44px, 6vw, 76px) clamp(24px, 5vw, 72px);
  background:
    radial-gradient(120% 130% at 50% -25%, var(--hero-1), transparent 58%),
    linear-gradient(165deg, var(--hero-2), var(--hero-3));
}
.values-box::before {
  content: ""; position: absolute; inset: 0; z-index: -1; opacity: 0.35; pointer-events: none;
  background-image: radial-gradient(rgba(255,255,255,0.07) 1px, transparent 1px);
  background-size: 28px 28px;
  -webkit-mask-image: radial-gradient(100% 80% at 50% 0%, #000 25%, transparent 78%);
  mask-image: radial-gradient(100% 80% at 50% 0%, #000 25%, transparent 78%);
}
.values-box .bloom {
  position: absolute; z-index: -1; left: 50%; top: -34%; width: 72%; height: 340px; transform: translateX(-50%);
  background: radial-gradient(ellipse at center, rgba(var(--glow), 0.8), transparent 64%);
  filter: blur(46px);
}
.values-box .eyebrow { color: rgba(255,255,255,0.62); justify-content: center; }
.values-box h2 { font-size: clamp(1.5rem, 2.8vw, 2.3rem); margin-top: 16px; letter-spacing: -0.03em; }

.values-grid {
  display: grid; grid-template-columns: repeat(4, 1fr); gap: 14px;
  margin-top: clamp(28px, 3.4vw, 44px); text-align: left;
}
@media (max-width: 900px) { .values-grid { grid-template-columns: repeat(2, 1fr); } }
@media (max-width: 520px) { .values-grid { grid-template-columns: 1fr; } }
.value {
  padding: 20px 22px; border-radius: var(--radius-sm);
  background: linear-gradient(180deg, rgba(255,255,255,0.12), rgba(255,255,255,0.05));
  border: 1px solid rgba(255,255,255,0.2);
  -webkit-backdrop-filter: blur(10px); backdrop-filter: blur(10px);
  box-shadow: inset 0 1px 0 rgba(255,255,255,0.3);
  transition: transform .35s var(--ease), background .3s, border-color .3s;
}
.value:hover {
  transform: translateY(-5px);
  background: linear-gradient(180deg, rgba(255,255,255,0.18), rgba(255,255,255,0.08));
  border-color: rgba(255,255,255,0.34);
}

/* Werte-Karten treten nacheinander auf */
@media (prefers-reduced-motion: no-preference) {
  .values-grid .value { opacity: 0; transform: translateY(20px); transition: opacity .55s ease, transform .7s var(--ease), background .3s, border-color .3s; }
  .values-box.in .value { opacity: 1; transform: none; }
  .values-box.in .value:nth-child(2) { transition-delay: .1s; }
  .values-box.in .value:nth-child(3) { transition-delay: .2s; }
  .values-box.in .value:nth-child(4) { transition-delay: .3s; }
  .values-box.in .value:hover { transform: translateY(-5px); }
  .values-close { opacity: 0; transition: opacity .7s ease .55s; }
  .values-box.in .values-close { opacity: 1; }
}
.value .vn { font-family: var(--font-mono); font-size: 0.68rem; letter-spacing: 0.16em; color: rgba(255,255,255,0.55); }
.value h3 { font-size: 1.05rem; margin-top: 10px; line-height: 1.3; }
.value p { font-size: 0.88rem; color: rgba(255,255,255,0.7); margin-top: 7px; line-height: 1.55; }

.values-close {
  margin-top: clamp(26px, 3vw, 36px);
  font-family: var(--font-display); font-weight: 600; letter-spacing: -0.02em;
  font-size: clamp(1.05rem, 1.8vw, 1.35rem); color: rgba(255,255,255,0.92);
}
.values-close::before { content: "„"; color: oklch(0.78 0.1 250); }
.values-close::after { content: "“"; color: oklch(0.78 0.1 250); }

/* ============================================================
   OFFENE STELLEN — aufklappbare Karten
   ============================================================ */
.jobs { display: grid; gap: 18px; max-width: 860px; margin: 0 auto; }
.job-card {
  background: var(--surface); border: 1px solid var(--line); border-radius: var(--radius);
  padding: clamp(24px, 3vw, 34px) clamp(24px, 3.4vw, 38px);
  transition: transform .3s var(--ease), box-shadow .3s var(--ease), border-color .3s var(--ease);
  scroll-margin-top: 96px;
}
.job-card:hover { transform: translateY(-3px); box-shadow: 0 26px 50px -32px rgba(2,2,60,0.3); border-color: var(--line-soft); }

.jc-tags { display: flex; flex-wrap: wrap; gap: 8px; }
.jc-tags span {
  font-family: var(--font-mono); font-size: 0.66rem; letter-spacing: 0.1em; text-transform: uppercase;
  color: var(--accent); padding: 5px 12px; border-radius: var(--r-pill);
  background: color-mix(in oklab, var(--accent) 9%, transparent);
  border: 1px solid color-mix(in oklab, var(--accent) 22%, var(--line));
}
.job-card h3 { font-size: clamp(1.25rem, 2vw, 1.55rem); letter-spacing: -0.02em; margin-top: 16px; }
.jc-meta { font-family: var(--font-mono); font-size: 0.74rem; letter-spacing: 0.08em; text-transform: uppercase; color: var(--ink-soft); margin-top: 8px; }
.jc-text { color: var(--ink-soft); font-size: 1rem; line-height: 1.7; margin-top: 14px; }

.jc-detail { display: grid; grid-template-rows: 0fr; transition: grid-template-rows .5s var(--ease); }
.jc-detail > div { overflow: hidden; }
.job-card.open .jc-detail { grid-template-rows: 1fr; }
.jc-detail-inner { padding-top: 18px; }
.jc-detail-inner p { color: var(--ink-soft); font-size: 0.97rem; line-height: 1.7; }
.jc-detail-inner p + p { margin-top: 10px; }
.jc-detail-inner ul { display: grid; gap: 9px; margin-top: 14px; }
.jc-detail-inner li { display: grid; grid-template-columns: auto 1fr; gap: 11px; align-items: start; font-size: 0.95rem; color: var(--ink-soft); line-height: 1.6; }
.jc-detail-inner .tick {
  width: 21px; height: 21px; flex: none; border-radius: 50%; margin-top: 2px; display: grid; place-items: center;
  background: color-mix(in oklab, var(--accent) 13%, transparent); color: var(--accent);
}
.jc-detail-inner .tick svg { width: 11px; height: 11px; }
.jc-detail-inner b { color: var(--ink); }

.jc-actions { display: flex; flex-wrap: wrap; align-items: center; gap: 12px 18px; margin-top: 20px; }
.jc-more {
  display: inline-flex; align-items: center; gap: 7px; cursor: pointer;
  font: inherit; font-size: 0.92rem; font-weight: 600; color: var(--accent);
  background: none; border: 0; padding: 10px 4px;
}
.jc-more .chev { display: inline-block; transition: transform .35s var(--ease); }
.job-card.open .jc-more .chev { transform: rotate(180deg); }
.jc-actions .btn { margin-left: auto; }
@media (max-width: 560px) {
  .jc-actions .btn { margin-left: 0; width: 100%; justify-content: center; }
}

/* Reveal-Stagger für Stellenkarten */
@media (prefers-reduced-motion: no-preference) {
  .jobs .job-card { opacity: 0; transform: translateY(24px); transition: opacity .6s ease, transform .8s var(--ease), box-shadow .3s var(--ease), border-color .3s var(--ease); }
  .jobs .job-card.in { opacity: 1; transform: none; }
  .jobs .job-card:nth-child(2).in { transition-delay: .12s; }
}

/* Feature-Stagger (Was wir bieten) */
@media (prefers-reduced-motion: no-preference) {
  .feature-list .feature { opacity: 0; transform: translateY(24px); transition: opacity .6s ease, transform .8s var(--ease), box-shadow .3s var(--ease); }
  .feature-list.in .feature { opacity: 1; transform: none; }
  .feature-list.in .feature:nth-child(2) { transition-delay: .1s; }
  .feature-list.in .feature:nth-child(3) { transition-delay: .2s; }
  .feature-list.in .feature:nth-child(4) { transition-delay: .3s; }
}

/* Feature-Icons reagieren auf Hover */
.feature .ic { transition: transform .35s var(--ease); }
.feature:hover .ic { transform: scale(1.1) rotate(-5deg); }

/* Stellen-Tags heben sich beim Karten-Hover */
.jc-tags span { transition: transform .3s var(--ease), background .25s; }
.job-card:hover .jc-tags span { background: color-mix(in oklab, var(--accent) 14%, transparent); }
.job-card:hover .jc-tags span:nth-child(1) { transform: translateY(-2px); }
.job-card:hover .jc-tags span:nth-child(2) { transform: translateY(-2px); transition-delay: .05s; }
.job-card:hover .jc-tags span:nth-child(3) { transform: translateY(-2px); transition-delay: .1s; }
