/* =========================================================================
   Novemcore · Kontakt (/de/kontakt · /en/contact)
   Simple, personal contact page — hero + personal card · reassurance.
   No form. No routing grid. One clear contact.
   ========================================================================= */
@import url("colors_and_type.css");

*, *::before, *::after { box-sizing: border-box; }
html { scroll-behavior: smooth; scroll-padding-top: 96px; }
html, body { margin: 0; padding: 0; background: var(--nc-paper); color: var(--nc-ink); font-family: var(--font-body); }
body { min-height: 100vh; overflow-x: hidden; }
img { max-width: 100%; }
a { color: inherit; }
button { font-family: inherit; cursor: pointer; }
ul, ol { margin: 0; padding: 0; list-style: none; }

.wrap { max-width: var(--container); margin: 0 auto; padding: 0 28px; width: 100%; }

/* =========================================================================
   Buttons
   ========================================================================= */
.btn {
  font-family: var(--font-body); font-weight: 500; font-size: 15px;
  border-radius: 10px; padding: 12px 20px; border: 0;
  display: inline-flex; align-items: center; gap: 9px; line-height: 1;
  text-decoration: none; white-space: nowrap;
  transition: transform 120ms var(--ease-standard),
              background 160ms var(--ease-standard),
              box-shadow 160ms var(--ease-standard),
              filter 160ms var(--ease-standard);
}
.btn:active { transform: translateY(1px); }
.btn--secondary {
  background: transparent; color: var(--nc-ink);
  border: 1px solid var(--border-strong); padding: 11px 19px;
}
.btn--secondary:hover { background: rgba(11,15,23,0.06); }
.btn--pulse {
  color: #FFFFFF; background: var(--pulse-cta-gradient); font-weight: 600;
  padding: 12px 22px;
  box-shadow: inset 0 1px 0 rgba(255,245,234,0.45),
              0 0 0 1px rgba(255,235,210,0.18),
              0 12px 32px -10px rgba(184,87,48,0.55);
}
.btn--pulse:hover { filter: brightness(1.05); }
.btn .btn__ic { display: inline-flex; }
.btn .btn__ic svg { width: 17px; height: 17px; }
:focus-visible { outline: 2px solid var(--nc-cobalt); outline-offset: 2px; border-radius: 4px; }

/* =========================================================================
   Section scaffolding
   ========================================================================= */
.block { padding: 88px 0; }
.block--offwhite { background: var(--nc-offwhite); }

.eyebrow {
  font-family: var(--font-mono); font-size: 12px;
  letter-spacing: 0.12em; text-transform: uppercase; color: var(--fg-3);
}
.eyebrow--accent {
  position: relative; padding-left: 24px; color: var(--nc-teal);
}
.eyebrow--accent::before {
  content: ""; position: absolute; left: 0; top: 50%;
  width: 16px; height: 1px; background: currentColor;
}

.sec-head__title {
  font-family: var(--font-display); font-weight: 500;
  font-size: clamp(26px, 2.8vw, 36px); line-height: 1.1;
  letter-spacing: -0.002em; margin: 0 0 18px; color: var(--nc-ink);
  text-wrap: balance;
}
.sec-head__body {
  font-size: 17px; line-height: 1.66; color: var(--fg-2);
  max-width: 64ch; margin: 0; text-wrap: pretty;
}

/* =========================================================================
   1 · HERO  (copy left · card right)
   ========================================================================= */
.hero {
  display: grid;
  grid-template-columns: minmax(0, 1.05fr) minmax(0, 0.95fr);
  gap: 64px; align-items: center;
  padding-top: 80px; padding-bottom: 88px;
}

.hero__h1 {
  font-family: var(--font-display); font-weight: 500;
  font-size: clamp(34px, 3.8vw, 52px); line-height: 1.07;
  letter-spacing: -0.003em; margin: 20px 0 22px; color: var(--nc-ink);
  max-width: 15ch; text-wrap: balance;
}
.hero__sub {
  font-size: 17.5px; line-height: 1.66; color: var(--fg-2);
  max-width: 56ch; margin-bottom: 34px; text-wrap: pretty;
}
.hero__ctas { display: flex; gap: 14px; flex-wrap: wrap; align-items: center; }

/* =========================================================================
   Personal contact card
   ========================================================================= */
.pcard {
  background: #FFFFFF;
  border: 1px solid var(--border-1);
  border-radius: var(--r-md);
  padding: 24px;
  box-shadow: 0 1px 0 rgba(11,15,23,0.03), 0 16px 44px -24px rgba(11,15,23,0.16);
}

.pcard__label {
  display: inline-block;
  font: 500 10px var(--font-mono); letter-spacing: 0.14em;
  text-transform: uppercase; color: var(--fg-3); margin-bottom: 18px;
}

.pcard__person { display: flex; align-items: center; gap: 20px; }

/* Portrait slot — swap <image-slot> for <img> in production */
.pcard__photo {
  flex: 0 0 auto; width: 120px; height: 148px;
  border-radius: var(--r-sm); overflow: hidden;
  border: 1px solid var(--border-1);
  background: var(--nc-sand);
}
.pcard__photo img { width: 100%; height: 100%; object-fit: cover; display: block; }

.pcard__who { min-width: 0; }
.pcard__name {
  font-family: var(--font-display); font-weight: 500;
  font-size: 21px; line-height: 1.1; color: var(--nc-ink); margin-bottom: 6px;
}
.pcard__role { font-size: 14px; line-height: 1.5; color: var(--fg-2); }

/* Contact rows */
.pcard__rows {
  display: flex; flex-direction: column; gap: 4px;
  margin-top: 20px; padding-top: 18px; border-top: 1px solid var(--border-1);
}
.crow {
  display: flex; align-items: center; gap: 14px;
  padding: 10px 10px; margin: 0 -4px; border-radius: var(--r-sm);
  border: 1px solid transparent; text-decoration: none;
  transition: border-color 160ms var(--ease-standard),
              background 160ms var(--ease-standard);
}
.crow:hover {
  border-color: var(--border-strong);
  background: var(--nc-offwhite);
}
.crow:hover .crow__ic {
  color: var(--pulse-copper);
  border-color: rgba(217,119,87,0.34);
  background: rgba(217,119,87,0.08);
}
.crow__ic {
  flex: 0 0 auto; width: 36px; height: 36px; border-radius: var(--r-sm);
  display: flex; align-items: center; justify-content: center;
  color: var(--nc-cobalt);
  background: rgba(30,58,138,0.07);
  border: 1px solid rgba(30,58,138,0.13);
  transition: color 160ms var(--ease-standard),
              border-color 160ms var(--ease-standard),
              background 160ms var(--ease-standard);
}
.crow__ic svg { width: 18px; height: 18px; }
.crow__body { display: flex; flex-direction: column; gap: 2px; min-width: 0; }
.crow__lbl {
  font: 500 10px var(--font-mono); letter-spacing: 0.12em;
  text-transform: uppercase; color: var(--fg-3);
}
.crow__val {
  font: 500 14.5px var(--font-body); color: var(--nc-ink);
  line-height: 1.35; overflow: hidden; text-overflow: ellipsis; white-space: nowrap;
}

/* =========================================================================
   2 · UNVERBINDLICH ANSPRECHEN
   ========================================================================= */
.ansprechen__head { max-width: 660px; margin-bottom: 40px; }

.steps { display: flex; gap: 0; }
.step {
  flex: 1; display: flex; align-items: flex-start; gap: 14px;
  padding: 20px 20px 20px 0;
}
.step + .step {
  border-left: 1px solid var(--border-1);
  padding-left: 24px;
}
.step__num {
  flex: 0 0 auto; width: 28px; height: 28px; border-radius: 999px;
  display: flex; align-items: center; justify-content: center;
  font: 600 12px var(--font-mono); color: var(--pulse-copper);
  background: rgba(217,119,87,0.10);
  border: 1px solid rgba(217,119,87,0.24);
}
.step__txt {
  font-size: 15px; line-height: 1.5; color: var(--nc-ink);
  padding-top: 3px;
}

/* =========================================================================
   Motion / reveal
   ========================================================================= */
.has-js .reveal {
  opacity: 0; transform: translateY(14px);
  transition: opacity var(--dur-slow) var(--ease-emphasized),
              transform var(--dur-slow) var(--ease-emphasized);
}
.has-js .reveal.is-in { opacity: 1; transform: none; }
.has-js .pcard.reveal { transition-delay: 120ms; }

@media (prefers-reduced-motion: reduce) {
  html { scroll-behavior: auto; }
  .has-js .reveal,
  .has-js .pcard.reveal { opacity: 1; transform: none; transition: none; }
}

/* =========================================================================
   Responsive
   ========================================================================= */
@media (max-width: 980px) {
  .hero {
    grid-template-columns: 1fr; gap: 44px;
    padding-top: 60px; padding-bottom: 68px;
  }
  .hero__copy { max-width: 600px; }
  .pcard { max-width: 520px; }
  .block { padding: 72px 0; }
  .step + .step { border-left: 0; padding-left: 0; }
  .steps { flex-direction: column; gap: 4px; }
}

@media (max-width: 680px) {
  .wrap { padding: 0 20px; }
  .block { padding: 56px 0; }
  .hero__ctas { gap: 12px; }
  .hero__ctas .btn { flex: 1 1 auto; justify-content: center; }
  .pcard { max-width: none; padding: 20px; }
  .pcard__person { align-items: flex-start; }
  .pcard__photo { width: 88px; height: 108px; }
  .step { padding: 12px 0; }
}
