/* ==========================================================================
   MEX Marketing – Stylesheet
   Editorial Calm. Sehr nah am Persönlichkeitsprofil-Look.
   ========================================================================== */

/* ---------- 1) Tokens (in Divi 5 als Global Colors / Presets anlegen) ---- */
:root {
  /* Farben */
  --color-bg:        #F5F1EA;   /* Bone – Standard hell */
  --color-bg-soft:   #EFE9DE;   /* sehr dezente zweite Hellfläche */
  --color-bg-dark:   #1F1B17;   /* Aubergine-Anthrazit – dunkel */
  --color-ink:       #1C1A17;   /* Tinten-Schwarz, Text auf Hell */
  --color-cream:     #F2EAD8;   /* Text auf Dunkel */
  --color-gold:      #B68A4E;   /* Akzent */
  --color-gold-soft: #C9A574;
  --color-rust:      #B85C3A;   /* sparsamer Sekundär-Akzent */
  --color-line:      #C9C0B2;   /* Hairlines */
  --color-mute:      #6E665B;   /* Sekundär-Text */

  /* Schriften – mit kräftigen Fallbacks, falls Bunny Fonts blockiert wird */
  --font-display: "Cormorant Garamond", "Cormorant", "EB Garamond",
                  "Iowan Old Style", "Apple Garamond", "Hoefler Text",
                  "Times New Roman", Georgia, serif;
  --font-body:    "Inter", -apple-system, BlinkMacSystemFont, "Segoe UI Variable",
                  "Segoe UI", Roboto, "Helvetica Neue", Helvetica, Arial, sans-serif;

  /* Raster */
  --container:    1240px;
  --gutter:       clamp(20px, 4vw, 48px);
  --section-y:    clamp(72px, 11vw, 140px);

  /* Radius / Lines */
  --radius:       0px;        /* bewusst kantig, editorial */
  --hairline:     1px solid var(--color-line);
}

/* ---------- 2) Reset & Basis ---------------------------------------------- */
*, *::before, *::after { box-sizing: border-box; }
html { scroll-behavior: smooth; }
body {
  margin: 0;
  background: var(--color-bg);
  color: var(--color-ink);
  font-family: var(--font-body);
  font-size: 17px;
  line-height: 1.65;
  -webkit-font-smoothing: antialiased;
  text-rendering: optimizeLegibility;
}
img { max-width: 100%; height: auto; display: block; }
a   { color: inherit; text-decoration: none; }

/* ---------- 3) Typografie -------------------------------------------------- */
.h1, .h2, .h3 {
  font-family: var(--font-display);
  font-weight: 400;
  color: var(--color-ink);
  margin: 0 0 0.4em;
  letter-spacing: -0.005em;
}
.h1 {
  font-size: clamp(48px, 7.2vw, 96px);
  line-height: 1.02;
}
.h2 {
  font-size: clamp(34px, 4.4vw, 56px);
  line-height: 1.08;
}
.h3 {
  font-size: clamp(22px, 2.2vw, 28px);
  line-height: 1.2;
}
.italic { font-style: italic; }

.eyebrow {
  display: inline-block;
  font-family: var(--font-body);
  font-weight: 600;
  font-size: 12px;
  letter-spacing: 0.22em;
  text-transform: uppercase;
  color: var(--color-gold);
  margin-bottom: 18px;
}
.eyebrow.on-dark { color: var(--color-gold-soft); }

.lead {
  font-size: clamp(18px, 1.4vw, 21px);
  line-height: 1.6;
  color: var(--color-ink);
  max-width: 60ch;
}
.lead.on-dark { color: var(--color-cream); }

.small-meta {
  font-family: var(--font-body);
  font-size: 12px;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: var(--color-mute);
}

/* römische Ziffer als gestalterisches Element */
.roman {
  font-family: var(--font-display);
  font-style: italic;
  font-size: clamp(28px, 3vw, 40px);
  color: var(--color-gold);
  line-height: 1;
  margin-bottom: 18px;
  display: block;
}

/* ---------- 4) Layout-Helpers --------------------------------------------- */
.container {
  max-width: var(--container);
  margin: 0 auto;
  padding-inline: var(--gutter);
}
.section { padding-block: var(--section-y); }
.section.dark {
  background: var(--color-bg-dark);
  color: var(--color-cream);
}
.section.dark .h1,
.section.dark .h2,
.section.dark .h3 { color: var(--color-cream); }

.grid { display: grid; gap: var(--gutter); }
.grid-2 { grid-template-columns: repeat(2, 1fr); }
.grid-3 { grid-template-columns: repeat(3, 1fr); }
.grid-12 { grid-template-columns: repeat(12, 1fr); }

.hairline-top    { border-top:    var(--hairline); padding-top:    24px; }
.hairline-bottom { border-bottom: var(--hairline); padding-bottom: 24px; }

/* ---------- 5) Buttons ----------------------------------------------------- */
.btn {
  display: inline-flex;
  align-items: center;
  gap: 12px;
  padding: 14px 28px;
  font-family: var(--font-body);
  font-weight: 500;
  font-size: 14px;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  border: 1px solid var(--color-ink);
  color: var(--color-ink);
  background: transparent;
  cursor: pointer;
  transition: all .25s ease;
}
.btn:hover { background: var(--color-ink); color: var(--color-bg); }
.btn .arrow { transition: transform .25s ease; }
.btn:hover .arrow { transform: translateX(4px); }

.btn--gold {
  background: var(--color-gold);
  border-color: var(--color-gold);
  color: var(--color-bg-dark);
}
.btn--gold:hover { background: transparent; color: var(--color-gold); }

.btn--ghost-light {
  border-color: var(--color-cream);
  color: var(--color-cream);
}
.btn--ghost-light:hover { background: var(--color-cream); color: var(--color-bg-dark); }

.link-arrow {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  font-size: 14px;
  letter-spacing: 0.06em;
  text-transform: uppercase;
  border-bottom: 1px solid currentColor;
  padding-bottom: 4px;
  transition: gap .25s ease;
}
.link-arrow:hover { gap: 14px; }

/* ---------- 6) Header / Navigation ---------------------------------------- */
.site-header {
  position: sticky;
  top: 0;
  z-index: 100;
  background: rgba(245, 241, 234, 0.92);
  backdrop-filter: blur(10px);
  border-bottom: var(--hairline);
}
.nav {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding-block: 18px;
}
.nav__logo {
  font-family: var(--font-display);
  font-style: italic;
  font-size: 24px;
  color: var(--color-ink);
}
.nav__logo b { font-style: normal; font-weight: 500; letter-spacing: 0.04em; }
.nav__menu {
  display: flex;
  gap: 36px;
  list-style: none;
  padding: 0;
  margin: 0;
}
.nav__menu a {
  font-size: 13px;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  position: relative;
  padding-bottom: 4px;
}
.nav__menu a::after {
  content: "";
  position: absolute;
  left: 0; bottom: 0;
  width: 0;
  height: 1px;
  background: var(--color-gold);
  transition: width .3s ease;
}
.nav__menu a:hover::after,
.nav__menu a.is-active::after { width: 100%; }
.nav__cta {
  font-size: 13px;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  border: 1px solid var(--color-ink);
  padding: 10px 18px;
  transition: all .25s ease;
}
.nav__cta:hover { background: var(--color-ink); color: var(--color-bg); }
.nav__burger { display: none; }

/* ---------- 7) Hero -------------------------------------------------------- */
.hero {
  padding-block: clamp(60px, 9vw, 120px) var(--section-y);
}
.hero__grid {
  display: grid;
  grid-template-columns: 1.2fr 1fr;
  gap: clamp(40px, 6vw, 96px);
  align-items: center;
}
.hero__claim {
  font-family: var(--font-display);
  font-size: clamp(40px, 5.2vw, 72px);
  line-height: 1.08;
  letter-spacing: -0.01em;
  color: var(--color-ink);
  margin: 0 0 28px;
  max-width: 14ch;
}
.hero__claim em {
  font-style: italic;
}
/* Auf großen Schirmen das Verhältnis Text/Bild ausgewogener halten */
@media (min-width: 1100px) {
  .hero__grid { grid-template-columns: 1.35fr 1fr; }
}
.hero__sub {
  font-size: clamp(17px, 1.25vw, 19px);
  line-height: 1.65;
  max-width: 46ch;
  color: var(--color-ink);
  margin-bottom: 36px;
}
.hero__ctas { display: flex; flex-wrap: wrap; gap: 16px; }
.hero__image {
  position: relative;
  aspect-ratio: 4/5;
  overflow: hidden;
}
.hero__image img { width: 100%; height: 100%; object-fit: cover; }
.hero__image::after {
  content: "";
  position: absolute;
  inset: 0;
  border: 1px solid var(--color-line);
  pointer-events: none;
}

/* ---------- 8) Logo-Wall --------------------------------------------------- */
.logos {
  padding-block: 56px;
  border-block: var(--hairline);
}
.logos__label {
  text-align: center;
  margin-bottom: 36px;
}
.logos__row {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  justify-content: space-between;
  gap: 24px;
}
.logos__row img {
  max-height: 44px;
  width: auto;
  filter: grayscale(1) brightness(.85) opacity(.65);
  transition: filter .35s ease;
}
.logos__row img:hover { filter: grayscale(0) brightness(1) opacity(1); }

/* ---------- 9) Trio --------------------------------------------------------- */
.trio {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: clamp(28px, 4vw, 56px);
  margin-top: 56px;
}
.trio__item {
  padding: 0;
  border-top: var(--hairline);
  padding-top: 28px;
}
.trio__item .h3 { margin-top: 0; }
.trio__item p { color: var(--color-mute); margin: 12px 0 0; }

/* ---------- 10) Projekte ---------------------------------------------------- */
.projects-intro {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: var(--gutter);
  align-items: end;
  margin-bottom: 64px;
}
.projects-intro p { max-width: 46ch; color: var(--color-mute); margin: 0; }

.projects {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: clamp(28px, 3.4vw, 48px);
}
.project {
  display: flex;
  flex-direction: column;
}
.project__media {
  aspect-ratio: 4/3;
  overflow: hidden;
  margin-bottom: 24px;
  background: var(--color-bg-soft);
}
.project__media img {
  width: 100%; height: 100%; object-fit: cover;
  transition: transform .6s ease;
}
.project:hover .project__media img { transform: scale(1.03); }
.project__title {
  font-family: var(--font-display);
  font-size: 28px;
  line-height: 1.15;
  margin: 0 0 12px;
}
.project__body { color: var(--color-mute); margin: 0 0 18px; }

/* ---------- 11) Über mich (Foto + Text) ------------------------------------ */
.about {
  display: grid;
  grid-template-columns: 1fr 1.2fr;
  gap: clamp(40px, 6vw, 96px);
  align-items: center;
}
.about__image { aspect-ratio: 4/5; overflow: hidden; }
.about__image img { width:100%; height:100%; object-fit: cover; }

/* ---------- 12) Stimmen / Quotes ------------------------------------------ */
.quotes {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: clamp(48px, 6vw, 80px) clamp(40px, 5vw, 80px);
}
.quote {
  position: relative;
  padding-left: 32px;
}
.quote::before {
  content: "„";
  position: absolute;
  left: -8px;
  top: -18px;
  font-family: var(--font-display);
  font-size: 96px;
  line-height: 1;
  color: var(--color-gold);
}
.quote__text {
  font-family: var(--font-display);
  font-style: italic;
  font-size: clamp(20px, 1.6vw, 26px);
  line-height: 1.4;
  margin: 0 0 20px;
}
.quote__who {
  font-size: 12px;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: var(--color-mute);
}
.quote__who b { color: var(--color-ink); font-weight: 600; }

/* ---------- 13) Dunkle CTA-Sektion ----------------------------------------- */
.cta-dark { text-align: center; }
.cta-dark .h2 {
  font-style: italic;
  max-width: 14ch;
  margin: 0 auto 24px;
}
.cta-dark p { max-width: 50ch; margin: 0 auto 40px; color: var(--color-cream); opacity: .85; }
.cta-dark__row {
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
  gap: 16px 28px;
  font-size: 14px;
  letter-spacing: 0.06em;
  margin-top: 24px;
  color: var(--color-cream);
}
.cta-dark__row a { border-bottom: 1px solid transparent; transition: border-color .25s; }
.cta-dark__row a:hover { border-color: var(--color-gold); }

/* ---------- 14) Footer ----------------------------------------------------- */
.site-footer {
  background: var(--color-bg);
  border-top: var(--hairline);
  padding-block: 64px 24px;
}
.footer-grid {
  display: grid;
  grid-template-columns: 1.4fr 1fr 1fr;
  gap: var(--gutter);
  margin-bottom: 48px;
}
.footer-grid h4 {
  font-family: var(--font-body);
  font-size: 12px;
  letter-spacing: 0.2em;
  text-transform: uppercase;
  color: var(--color-mute);
  margin: 0 0 18px;
  font-weight: 600;
}
.footer-grid ul { list-style: none; padding: 0; margin: 0; }
.footer-grid li { margin-bottom: 8px; }
.footer-grid a { transition: color .2s; }
.footer-grid a:hover { color: var(--color-gold); }
.footer-bottom {
  border-top: var(--hairline);
  padding-top: 24px;
  display: flex;
  flex-wrap: wrap;
  justify-content: space-between;
  gap: 16px;
  font-size: 12px;
  letter-spacing: 0.12em;
  color: var(--color-mute);
}

/* ---------- 15) Page-Heading (Innen-Seiten) ------------------------------- */
.page-head {
  padding-block: clamp(80px, 12vw, 160px) clamp(40px, 6vw, 80px);
}
.page-head__claim {
  font-family: var(--font-display);
  font-size: clamp(44px, 6vw, 80px);
  line-height: 1.05;
  margin: 0 0 24px;
  max-width: 18ch;
}
.page-head__sub { max-width: 56ch; color: var(--color-mute); }

/* ---------- 16) Service-Stufen (Leistungen) ------------------------------- */
.tiers {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: clamp(24px, 3vw, 40px);
}
.tier {
  background: var(--color-bg-soft);
  padding: clamp(28px, 3vw, 40px);
  display: flex;
  flex-direction: column;
}
.tier__num {
  font-family: var(--font-display);
  font-style: italic;
  font-size: 36px;
  color: var(--color-gold);
  margin-bottom: 24px;
}
.tier h3 { margin: 0 0 16px; }
.tier p  { color: var(--color-mute); margin: 0 0 24px; }
.tier ul { padding-left: 18px; margin: 0 0 28px; color: var(--color-ink); }
.tier ul li { margin-bottom: 8px; }
.tier .link-arrow { margin-top: auto; }

/* ---------- 16b) Need-Cards (Schmerz-Block) -------------------------------- */
.needs {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: clamp(28px, 3vw, 48px);
  margin-top: 64px;
}
.need {
  position: relative;
  padding-top: 8px;
  border-top: 2px solid var(--color-gold);
}
.need__num {
  font-family: var(--font-display);
  font-style: italic;
  font-size: 28px;
  color: var(--color-gold);
  margin-bottom: 24px;
  display: block;
}
.need .small-meta { display: block; margin-bottom: 18px; }
.need h3 {
  font-family: var(--font-display);
  font-size: clamp(28px, 2.5vw, 36px);
  line-height: 1.15;
  margin: 0 0 14px;
}
.need__sub {
  font-style: italic;
  font-family: var(--font-display);
  font-size: 20px;
  color: var(--color-mute);
  margin: 0 0 20px;
}
.need__body { color: var(--color-mute); margin: 0 0 28px; }
.need__quote {
  border-left: 2px solid var(--color-gold);
  padding: 8px 0 8px 18px;
  font-family: var(--font-display);
  font-style: italic;
  font-size: 17px;
  line-height: 1.5;
  color: var(--color-ink);
}
.need__quote cite {
  display: block;
  margin-top: 8px;
  font-family: var(--font-body);
  font-style: normal;
  font-size: 12px;
  letter-spacing: 0.16em;
  text-transform: uppercase;
  color: var(--color-mute);
}

/* ---------- 16c) Answers (Mein Versprechen) -------------------------------- */
.answers {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: clamp(28px, 3vw, 48px);
  margin-top: 56px;
}
.answer { display: flex; flex-direction: column; }
.answer__label {
  font-family: var(--font-body);
  font-size: 12px;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: var(--color-gold);
  margin-bottom: 16px;
}
.answer h3 {
  font-family: var(--font-display);
  font-size: clamp(26px, 2.4vw, 34px);
  line-height: 1.15;
  margin: 0 0 16px;
}
.answer__body { color: var(--color-mute); margin: 0; }

/* ---------- 16d) Paths (Zwei Wege) ----------------------------------------- */
.paths {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: clamp(28px, 3vw, 48px);
  margin-top: 56px;
}
.path {
  background: var(--color-bg-soft);
  padding: clamp(32px, 3vw, 48px);
  display: flex;
  flex-direction: column;
}
.path__num {
  font-family: var(--font-display);
  font-style: italic;
  font-size: 40px;
  color: var(--color-gold);
  margin-bottom: 16px;
}
.path__label {
  font-size: 12px;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: var(--color-mute);
  margin-bottom: 12px;
}
.path h3 {
  font-family: var(--font-display);
  font-size: clamp(28px, 2.6vw, 38px);
  line-height: 1.1;
  margin: 0 0 12px;
}
.path__quote {
  font-family: var(--font-display);
  font-style: italic;
  font-size: 18px;
  color: var(--color-mute);
  margin: 0 0 20px;
}
.path__body { margin: 0 0 24px; color: var(--color-ink); }
.path__list {
  list-style: none;
  padding: 0;
  margin: 0 0 32px;
  border-top: var(--hairline);
}
.path__list li {
  border-bottom: var(--hairline);
  padding: 12px 0 12px 24px;
  position: relative;
  color: var(--color-mute);
}
.path__list li::before {
  content: "—";
  position: absolute;
  left: 0;
  color: var(--color-gold);
}
.path .link-arrow { margin-top: auto; }

/* ---------- 16e) Toolbox (Werkzeugkasten) ---------------------------------- */
.toolbox {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: clamp(20px, 2.5vw, 32px);
  margin-top: 56px;
}
.tool {
  display: flex;
  flex-direction: column;
  padding: clamp(24px, 2.5vw, 32px);
  border: 1px solid var(--color-line);
  background: var(--color-bg);
}
.tool__num {
  font-family: var(--font-display);
  font-style: italic;
  font-size: 24px;
  color: var(--color-gold);
  margin-bottom: 18px;
}
.tool h4 {
  font-family: var(--font-display);
  font-size: 24px;
  line-height: 1.15;
  margin: 0 0 12px;
  font-weight: 400;
}
.tool__body { color: var(--color-mute); margin: 0 0 18px; font-size: 15px; }
.tool__tags {
  font-size: 11px;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: var(--color-gold);
  margin-bottom: 16px;
}
.tool .link-arrow {
  margin-top: auto;
  font-size: 12px;
}

/* ---------- 16f) Fit-Check (Selbst-Check) ---------------------------------- */
.fit {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: clamp(40px, 5vw, 80px);
}
.fit__list {
  list-style: none;
  padding: 0;
  margin: 0;
}
.fit__list li {
  padding: 18px 0 18px 36px;
  border-bottom: var(--hairline);
  position: relative;
  font-size: 17px;
  line-height: 1.5;
}
.fit__list li::before {
  content: "✓";
  position: absolute;
  left: 0;
  top: 18px;
  font-family: var(--font-display);
  font-size: 22px;
  color: var(--color-gold);
}
.fit__close {
  margin-top: 32px;
  font-style: italic;
  font-family: var(--font-display);
  font-size: 22px;
  color: var(--color-ink);
  line-height: 1.5;
}

/* ---------- 17) Kontakt-Block --------------------------------------------- */
.contact-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: var(--gutter);
  align-items: start;
}
.contact-card {
  border-top: var(--hairline);
  padding-top: 28px;
  margin-bottom: 28px;
}
.contact-card h3 { margin: 0 0 8px; font-family: var(--font-display); font-size: 24px; }
.contact-card a, .contact-card p { color: var(--color-ink); margin: 0; }

/* ---------- 18) Responsive -------------------------------------------------- */
@media (max-width: 1100px) {
  .toolbox { grid-template-columns: repeat(2, 1fr); }
}
@media (max-width: 960px) {
  .hero__grid,
  .about,
  .contact-grid,
  .projects-intro,
  .fit { grid-template-columns: 1fr; }
  .trio, .projects, .quotes, .tiers,
  .needs, .answers, .paths, .toolbox { grid-template-columns: 1fr; gap: 32px; }
  .footer-grid { grid-template-columns: 1fr 1fr; }
  .nav__menu { display: none; }
  .nav__burger {
    display: inline-flex;
    background: transparent;
    border: 1px solid var(--color-ink);
    padding: 10px 14px;
    font-size: 12px;
    letter-spacing: 0.18em;
    text-transform: uppercase;
  }
}
@media (max-width: 540px) {
  .footer-grid { grid-template-columns: 1fr; }
  .logos__row img { max-height: 32px; }
}

/* ---------- 19) Sanfter Fade-In beim Scrollen ----------------------------- */
[data-reveal] {
  opacity: 0;
  transform: translateY(16px);
  transition: opacity .8s ease, transform .8s ease;
}
[data-reveal].is-visible {
  opacity: 1;
  transform: none;
}
