/* ============================================================
   THEME 05 — MINIMAL / MODERN
   ------------------------------------------------------------
   Sehr reduziert. Haarlinien, winzige Versal-Labels mit weitem
   Laufweitenabstand, viel Luft, ein einziger warmer Holzton als
   Akzent. Bewegung kaum sichtbar — aber spürbar präzise.
   ============================================================ */

body[data-theme="minimal"] {
  /* --- Tokens --- */
  --c-bg:         #fbfaf7;
  --c-surface:    #efede7;
  --c-ink:        #1b1a17;
  --c-ink-soft:   #8d8a82;
  --c-accent:     #9c6b40;
  --c-accent-ink: #fbfaf7;
  --c-line:       #e3e1da;

  --font-display: "Instrument Sans", sans-serif;
  --font-body:    "Instrument Sans", sans-serif;

  --radius-img:   0;
  --btn-radius:   0;
  --container:    1280px;
  --ease:         cubic-bezier(.3, .9, .3, 1);
  --dur:          .9s;

  font-size: 16px;
  letter-spacing: .005em;
}
body[data-theme="minimal"] h1,
body[data-theme="minimal"] h2,
body[data-theme="minimal"] h3 { font-weight: 500; letter-spacing: -.02em; }
body[data-theme="minimal"] h2 em { font-style: normal; color: var(--c-accent); }

/* Reveals: kaum sichtbar, nur ein Hauch */
body[data-theme="minimal"] [data-reveal] { transform: translateY(12px); }
body[data-theme="minimal"] [data-reveal].is-revealed { transform: none; }

/* wiederkehrendes Mikro-Label-Muster */
body[data-theme="minimal"] .section-head__label,
body[data-theme="minimal"] .contact__detail-label,
body[data-theme="minimal"] .hero__kicker {
  font-size: .64rem; text-transform: uppercase; letter-spacing: .3em;
  color: var(--c-ink-soft);
}

/* ---------- Header ---------- */
body[data-theme="minimal"] .site-header {
  background: color-mix(in srgb, var(--c-bg) 90%, transparent);
  backdrop-filter: blur(6px);
  border-bottom: 1px solid transparent;
  transition: border-color .4s ease;
}
body[data-theme="minimal"] .site-header.is-scrolled { border-bottom-color: var(--c-line); }
body[data-theme="minimal"] .brand__name { font-weight: 600; font-size: 1rem; }
body[data-theme="minimal"] .brand__mark { width: 24px; height: 24px; }
body[data-theme="minimal"] .main-nav__link {
  font-size: .8rem; color: var(--c-ink-soft);
  transition: color .3s ease;
}
body[data-theme="minimal"] .main-nav__link:hover { color: var(--c-ink); }
body[data-theme="minimal"] .theme-btn:not([aria-pressed="true"]):hover { background: var(--c-surface); }

/* ---------- Hero: stille Asymmetrie ---------- */
body[data-theme="minimal"] .hero {
  grid-template-columns: minmax(0, 1.1fr) minmax(0, .9fr);
  column-gap: clamp(2rem, 6vw, 7rem);
  align-items: end;
  padding-bottom: clamp(3rem, 8vh, 6rem);
}
body[data-theme="minimal"] .hero__kicker { margin-bottom: clamp(2.5rem, 8vh, 5rem); }
body[data-theme="minimal"] .hero__title {
  font-size: clamp(2.6rem, 5.5vw, 4.8rem);
  font-weight: 500; line-height: 1.06;
}
body[data-theme="minimal"] .hero__line { display: inline; }
body[data-theme="minimal"] .hero__word { margin-right: .18em; }
body[data-theme="minimal"] .hero__word--accent { color: var(--c-accent); }
body[data-theme="minimal"] .hero__claim {
  margin-top: 2rem;
  max-width: 40ch; font-size: .98rem; line-height: 1.75;
  color: var(--c-ink-soft);
}
body[data-theme="minimal"] .hero__actions { margin-top: 2.4rem; gap: 1.8rem; }
body[data-theme="minimal"] .hero__media {
  aspect-ratio: 4 / 5;
  max-width: 460px; justify-self: end; width: 100%;
}
body[data-theme="minimal"] .hero__media img {
  transition: opacity .4s ease;
}
body[data-theme="minimal"] .hero__media:hover img { opacity: .92; }
body[data-theme="minimal"] .hero__media-caption {
  margin-top: .8em;
  display: flex; justify-content: space-between;
  font-size: .68rem; letter-spacing: .08em;
}
body[data-theme="minimal"] .hero__media-caption::after { content: "01 / 09"; color: var(--c-ink-soft); }
body[data-theme="minimal"] .hero__deco {
  position: absolute; left: clamp(1.25rem, 5vw, 4rem); right: clamp(1.25rem, 5vw, 4rem);
  bottom: 0; height: 1px; background: var(--c-line);
}
body[data-theme="minimal"] .hero__scroll-hint { right: clamp(1.25rem, 5vw, 4rem); letter-spacing: .3em; }

/* ---------- Buttons: Textlinks mit Linie ---------- */
body[data-theme="minimal"] .btn {
  padding: 0 0 .5em;
  font-size: .8rem; letter-spacing: .06em;
  border-bottom: 1px solid var(--c-ink);
  border-radius: 0;
}
body[data-theme="minimal"] .btn--primary { color: var(--c-ink); position: relative; }
body[data-theme="minimal"] .btn--primary::after {
  content: ""; position: absolute; left: 0; bottom: -1px;
  width: 100%; height: 1px; background: var(--c-accent);
  transform: scaleX(0); transform-origin: right;
  transition: transform .45s var(--ease);
}
body[data-theme="minimal"] .btn--primary:hover { color: var(--c-accent); }
body[data-theme="minimal"] .btn--primary:hover::after { transform: scaleX(1); transform-origin: left; }
body[data-theme="minimal"] .btn--ghost {
  border-bottom-color: var(--c-line); color: var(--c-ink-soft);
}
body[data-theme="minimal"] .btn--ghost:hover { color: var(--c-ink); border-bottom-color: var(--c-ink); }

/* ---------- Sektionsköpfe: Label links, Titel rechts ---------- */
body[data-theme="minimal"] .section { padding-block: clamp(5rem, 11vw, 10rem); }
body[data-theme="minimal"] .section-head {
  display: grid;
  grid-template-columns: minmax(140px, 1fr) 3fr;
  gap: 1.5rem;
  border-top: 1px solid var(--c-line);
  padding-top: 1.6rem;
}
body[data-theme="minimal"] .section-head__index {
  font-size: .64rem; color: var(--c-ink-soft); letter-spacing: .1em;
  grid-column: 1; grid-row: 1;
}
body[data-theme="minimal"] .section-head__index::after { content: " —"; }
body[data-theme="minimal"] .section-head__label { grid-column: 1; grid-row: 2; }
body[data-theme="minimal"] .section-head__title {
  grid-column: 2; grid-row: 1 / 3;
  font-size: clamp(1.9rem, 3.6vw, 3.1rem);
}
body[data-theme="minimal"] .section-head__desc {
  grid-column: 2; font-size: .92rem; margin-top: .5em;
}

/* ---------- Leistungen: Indexzeilen ---------- */
body[data-theme="minimal"] .services__grid {
  display: grid;
  margin-left: calc(25% + 1.5rem);  /* fluchtet mit dem Sektions-Titel */
}
body[data-theme="minimal"] .service-card {
  display: grid;
  grid-template-columns: auto 1fr 1.3fr auto;
  gap: clamp(1rem, 3vw, 2.5rem);
  align-items: baseline;
  padding: 1.6rem 0;
  border-bottom: 1px solid var(--c-line);
  transition: padding-left .4s var(--ease);
}
body[data-theme="minimal"] .service-card:first-child { border-top: 1px solid var(--c-line); }
body[data-theme="minimal"] .service-card:hover { padding-left: .8rem; }
body[data-theme="minimal"] .service-card__icon { display: none; }
body[data-theme="minimal"] .service-card__index {
  font-size: .68rem; color: var(--c-ink-soft); font-variant-numeric: tabular-nums;
}
body[data-theme="minimal"] .service-card__title { font-size: 1.15rem; font-weight: 500; }
body[data-theme="minimal"] .service-card__text {
  font-size: .85rem; color: var(--c-ink-soft); margin: 0;
}
body[data-theme="minimal"] .service-card__link {
  font-size: .75rem; color: var(--c-ink-soft);
  display: inline-flex; gap: .4em;
  transition: color .3s ease;
}
body[data-theme="minimal"] .service-card__link .arrow {
  display: inline-block;
  transition: transform .35s var(--ease);
}
body[data-theme="minimal"] .service-card:hover .service-card__link { color: var(--c-accent); }
body[data-theme="minimal"] .service-card:hover .arrow { transform: translateX(4px); }

/* ---------- Projekte: ruhige Zweier-Reihe ---------- */
body[data-theme="minimal"] .projects__grid {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: clamp(3.5rem, 7vw, 6rem) clamp(2rem, 5vw, 4.5rem);
}
body[data-theme="minimal"] .project:nth-child(even) { margin-top: clamp(2.5rem, 6vw, 5rem); }
body[data-theme="minimal"] .project__media { aspect-ratio: 5 / 6; }
body[data-theme="minimal"] .project__media img {
  transition: transform 1.2s var(--ease), opacity .4s ease;
}
body[data-theme="minimal"] .project:hover .project__media img {
  transform: scale(1.02); opacity: .94;
}
body[data-theme="minimal"] .project__meta {
  margin-top: 1rem;
  grid-template-columns: 1fr auto;
  row-gap: .2em;
}
body[data-theme="minimal"] .project__title { font-size: .95rem; font-weight: 500; }
body[data-theme="minimal"] .project__cat { font-size: .74rem; }
body[data-theme="minimal"] .project__year {
  grid-column: 2; grid-row: 1;
  font-size: .74rem; font-variant-numeric: tabular-nums;
}

/* ---------- Werkstatt ---------- */
body[data-theme="minimal"] .about__layout {
  display: grid;
  grid-template-columns: minmax(140px, 1fr) 1.6fr 1.4fr;
  gap: clamp(2rem, 5vw, 5rem);
  align-items: start;
}
body[data-theme="minimal"] .about__media {
  grid-column: 3;
  display: grid; gap: 1.2rem;
}
body[data-theme="minimal"] .about__body { grid-column: 2; grid-row: 1; }
body[data-theme="minimal"] .about__fig--1 { aspect-ratio: 4 / 5; }
body[data-theme="minimal"] .about__fig--2 { aspect-ratio: 1; width: 62%; }
body[data-theme="minimal"] .about__lead {
  font-size: clamp(1.25rem, 2vw, 1.6rem);
  font-weight: 500; line-height: 1.45; letter-spacing: -.01em;
  margin-bottom: 1.2em;
}
body[data-theme="minimal"] .about__body > p:not(.about__lead) {
  font-size: .92rem; color: var(--c-ink-soft);
}
body[data-theme="minimal"] .about__quote {
  margin: 2rem 0; padding-left: 1.4rem;
  border-left: 1px solid var(--c-accent);
}
body[data-theme="minimal"] .about__quote p { font-size: 1.05rem; margin-bottom: .4em; }
body[data-theme="minimal"] .about__stats {
  grid-template-columns: repeat(2, auto);
  justify-content: start; gap: 1.6rem 3rem;
  margin-top: 2.4rem; padding-top: 1.6rem;
  border-top: 1px solid var(--c-line);
}
body[data-theme="minimal"] .stat__value { font-size: 1.8rem; font-weight: 500; }
body[data-theme="minimal"] .stat__label { font-size: .72rem; }

/* ---------- Kontakt ---------- */
body[data-theme="minimal"] .contact { border-top: 1px solid var(--c-line); }
body[data-theme="minimal"] .contact__layout {
  display: grid;
  grid-template-columns: minmax(140px, 1fr) 3fr;
  gap: 1.5rem;
}
body[data-theme="minimal"] .section-head--contact {
  border-top: 0; padding-top: 0; margin: 0;
  display: block; grid-column: 1;
}
body[data-theme="minimal"] .contact__title {
  grid-column: 2;
  font-size: clamp(2.2rem, 4.5vw, 3.8rem);
  max-width: 18ch;
}
body[data-theme="minimal"] .contact__title em { font-style: normal; color: var(--c-accent); }
body[data-theme="minimal"] .contact__desc {
  grid-column: 2;
  margin-top: 1.4em; max-width: 46ch;
  font-size: .95rem; color: var(--c-ink-soft);
}
body[data-theme="minimal"] .contact__actions { grid-column: 2; margin-top: 2rem; gap: 2rem; }
body[data-theme="minimal"] .contact__details {
  grid-column: 2;
  margin-top: 3.5rem;
  grid-template-columns: repeat(4, auto);
  justify-content: start; gap: 2.5rem;
  font-size: .85rem;
}

/* ---------- Footer ---------- */
body[data-theme="minimal"] .site-footer { border-top: 1px solid var(--c-line); }
body[data-theme="minimal"] .footer__nav a,
body[data-theme="minimal"] .footer__legal a {
  font-size: .78rem; color: var(--c-ink-soft);
  transition: color .3s ease;
}
body[data-theme="minimal"] .footer__nav a:hover,
body[data-theme="minimal"] .footer__legal a:hover { color: var(--c-ink); }

/* ---------- Responsive ---------- */
@media (max-width: 1000px) {
  body[data-theme="minimal"] .about__layout { grid-template-columns: 1fr 1fr; }
  body[data-theme="minimal"] .about__body { grid-column: 1; }
  body[data-theme="minimal"] .about__media { grid-column: 2; }
  body[data-theme="minimal"] .services__grid { margin-left: 0; }
  body[data-theme="minimal"] .service-card { grid-template-columns: auto 1fr auto; }
  body[data-theme="minimal"] .service-card__text { grid-column: 1 / -1; grid-row: 2; }
}
@media (max-width: 900px) {
  body[data-theme="minimal"] .hero { grid-template-columns: 1fr; align-items: start; }
  body[data-theme="minimal"] .hero__media { justify-self: start; margin-top: 3rem; }
  body[data-theme="minimal"] .section-head,
  body[data-theme="minimal"] .contact__layout { grid-template-columns: 1fr; }
  body[data-theme="minimal"] .section-head__title,
  body[data-theme="minimal"] .section-head__desc,
  body[data-theme="minimal"] .contact__title,
  body[data-theme="minimal"] .contact__desc,
  body[data-theme="minimal"] .contact__actions,
  body[data-theme="minimal"] .contact__details { grid-column: 1; }
  body[data-theme="minimal"] .about__layout { grid-template-columns: 1fr; }
  body[data-theme="minimal"] .about__media { grid-column: 1; max-width: 480px; }
}
@media (max-width: 700px) {
  body[data-theme="minimal"] .projects__grid { grid-template-columns: 1fr; }
  body[data-theme="minimal"] .project:nth-child(even) { margin-top: 0; }
  body[data-theme="minimal"] .contact__details { grid-template-columns: repeat(2, 1fr); }
}
