/* ============================================================
   Brigitte Schwarz – Künstler-Portfolio
   Gestaltung: ruhiger digitaler Galerieraum.
   Aufbau: 1 Grundlagen · 2 Layout · 3 Kopf/Navigation · 4 Fuß
           5 Start · 6 Werk/Galerie · 7 Werk-Detail · 8 Textseiten
           9 Kontaktformular · 10 Lightbox · 11 Hilfsklassen
   ============================================================ */

/* --- 1 Grundlagen ----------------------------------------------------- */
:root {
  --farbe-hintergrund: #f6f3ee;
  --farbe-flaeche:      #fffdf9;
  --farbe-text:         #2b2b2b;
  --farbe-gedaempft:    #6f6a60;
  --farbe-akzent:       #a65a2e;
  --farbe-akzent-dunkel:#854425;
  --farbe-linie:        #e2dccf;

  --schrift-titel: Georgia, "Times New Roman", "Times", serif;
  --schrift-text:  system-ui, -apple-system, "Segoe UI", Roboto, "Helvetica Neue", Arial, sans-serif;

  --breite-inhalt: 70rem;
  --breite-text:   42rem;
  --abstand:       clamp(1rem, 2.2vw, 2rem);
  --abstand-gross: clamp(2.6rem, 6vw, 5.5rem);
  --raster-luecke: clamp(0.9rem, 2vw, 1.7rem);
  --radius:        2px;
  --uebergang:     180ms ease;
}

*, *::before, *::after { box-sizing: border-box; }

html { -webkit-text-size-adjust: 100%; scroll-behavior: smooth; }

body {
  margin: 0;
  background: var(--farbe-hintergrund);
  color: var(--farbe-text);
  font-family: var(--schrift-text);
  font-size: 1.0625rem;
  line-height: 1.7;
  -webkit-font-smoothing: antialiased;
  text-rendering: optimizeLegibility;
  display: flex;
  flex-direction: column;
  min-height: 100vh;
}

img { max-width: 100%; height: auto; display: block; }
/* <picture> aus eleventy-img erzeugt keine eigene Box – das <img> zählt direkt */
picture { display: contents; }

h1, h2, h3, h4 {
  font-family: var(--schrift-titel);
  font-weight: 400;
  line-height: 1.22;
  color: var(--farbe-text);
  margin: 0 0 0.6em;
}
h1 { font-size: clamp(1.9rem, 4.6vw, 3rem); letter-spacing: 0.005em; }
h2 { font-size: clamp(1.45rem, 3.2vw, 2.1rem); }
h3 { font-size: clamp(1.15rem, 2.2vw, 1.45rem); }

p { margin: 0 0 1.1em; }
p:last-child { margin-bottom: 0; }

a { color: var(--farbe-akzent); text-decoration-thickness: 1px; text-underline-offset: 2px; }
a:hover { color: var(--farbe-akzent-dunkel); }

:focus-visible {
  outline: 2px solid var(--farbe-akzent);
  outline-offset: 2px;
}

/* --- 2 Layout --------------------------------------------------------- */
.inhaltsbreite {
  width: 100%;
  max-width: var(--breite-inhalt);
  margin-inline: auto;
  padding-inline: var(--abstand);
}

.inhalt { flex: 1 0 auto; }

.abschnitt { padding-block: var(--abstand-gross); }
.abschnitt--schmal { padding-block: clamp(2rem, 4vw, 3.4rem); }

.textspalte { max-width: var(--breite-text); }

.seitenkopf {
  border-bottom: 1px solid var(--farbe-linie);
}
.seitenkopf__inhalt {
  padding-block: clamp(2rem, 5vw, 3.6rem);
}
.seitenkopf__augenmarke {
  font-family: var(--schrift-text);
  font-size: 0.8rem;
  letter-spacing: 0.16em;
  text-transform: uppercase;
  color: var(--farbe-akzent);
  margin: 0 0 0.7rem;
}
.seitenkopf p.einleitung {
  max-width: var(--breite-text);
  font-size: 1.15rem;
  color: var(--farbe-gedaempft);
  margin-top: 0.4rem;
}

/* --- 3 Kopf / Navigation --------------------------------------------- */
.kopf {
  background: var(--farbe-hintergrund);
  border-bottom: 1px solid var(--farbe-linie);
  position: sticky;
  top: 0;
  z-index: 50;
}
.kopf__zeile {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 1rem;
  min-height: 4.6rem;
  flex-wrap: wrap;
}
.kopf__marke {
  display: flex;
  flex-direction: column;
  text-decoration: none;
  color: var(--farbe-text);
  line-height: 1.15;
}
.kopf__name {
  font-family: var(--schrift-titel);
  font-size: 1.4rem;
  letter-spacing: 0.01em;
}
.kopf__rolle {
  font-size: 0.72rem;
  letter-spacing: 0.17em;
  text-transform: uppercase;
  color: var(--farbe-gedaempft);
  margin-top: 0.15rem;
}

.menue-knopf {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 2.9rem; height: 2.9rem;
  padding: 0;
  background: transparent;
  border: 1px solid var(--farbe-linie);
  border-radius: var(--radius);
  cursor: pointer;
}
.menue-knopf__strich,
.menue-knopf__strich::before,
.menue-knopf__strich::after {
  display: block;
  width: 1.2rem; height: 1.5px;
  background: var(--farbe-text);
  transition: transform var(--uebergang), opacity var(--uebergang);
}
.menue-knopf__strich { position: relative; }
.menue-knopf__strich::before,
.menue-knopf__strich::after { content: ""; position: absolute; left: 0; }
.menue-knopf__strich::before { top: -5px; }
.menue-knopf__strich::after  { top:  5px; }
.menue-knopf[aria-expanded="true"] .menue-knopf__strich { background: transparent; }
.menue-knopf[aria-expanded="true"] .menue-knopf__strich::before { transform: translateY(5px) rotate(45deg); }
.menue-knopf[aria-expanded="true"] .menue-knopf__strich::after  { transform: translateY(-5px) rotate(-45deg); }

.hauptnav__liste {
  list-style: none;
  margin: 0; padding: 0;
  display: flex;
  align-items: center;
  gap: clamp(1rem, 2.4vw, 2rem);
}
.hauptnav a {
  color: var(--farbe-text);
  text-decoration: none;
  font-size: 0.97rem;
  letter-spacing: 0.02em;
  padding-block: 0.35rem;
  border-bottom: 1.5px solid transparent;
}
.hauptnav a:hover { color: var(--farbe-akzent); }
.hauptnav a[aria-current="page"] {
  border-bottom-color: var(--farbe-akzent);
  color: var(--farbe-akzent);
}
.hauptnav__sprache a {
  font-size: 0.78rem;
  letter-spacing: 0.13em;
  text-transform: uppercase;
  color: var(--farbe-gedaempft);
  border: 1px solid var(--farbe-linie);
  border-radius: 999px;
  padding: 0.28rem 0.8rem;
}
.hauptnav__sprache a:hover {
  color: var(--farbe-akzent);
  border-color: var(--farbe-akzent);
}

/* Mobil: Navigation hinter dem Menü-Knopf */
@media (max-width: 47.99rem) {
  .hauptnav {
    flex-basis: 100%;
    display: none;
  }
  .hauptnav.ist-offen { display: block; }
  .hauptnav__liste {
    flex-direction: column;
    align-items: flex-start;
    gap: 0;
    padding-bottom: 0.8rem;
  }
  .hauptnav__liste > li { width: 100%; }
  .hauptnav a {
    display: block;
    padding: 0.7rem 0.1rem;
    border-bottom: 1px solid var(--farbe-linie);
  }
  .hauptnav a[aria-current="page"] { border-bottom-color: var(--farbe-akzent); }
  .hauptnav__sprache { margin-top: 0.7rem; }
  .hauptnav__sprache a { display: inline-block; border-bottom: 1px solid var(--farbe-linie); }
}
@media (min-width: 48rem) {
  .menue-knopf { display: none; }
  .hauptnav { display: block !important; }
}

/* --- 4 Fuß ------------------------------------------------------------ */
.fuss {
  flex-shrink: 0;
  margin-top: var(--abstand-gross);
  border-top: 1px solid var(--farbe-linie);
  background: var(--farbe-hintergrund);
}
.fuss__zeile {
  display: flex;
  flex-wrap: wrap;
  justify-content: space-between;
  align-items: center;
  gap: 0.6rem 1.4rem;
  padding-block: 1.6rem;
  font-size: 0.88rem;
  color: var(--farbe-gedaempft);
}
.fuss__rechte { margin: 0; }
.fuss__links {
  list-style: none;
  display: flex;
  flex-wrap: wrap;
  gap: 0.4rem 1.4rem;
  margin: 0; padding: 0;
}
.fuss__links a { color: var(--farbe-gedaempft); text-decoration: none; }
.fuss__links a:hover { color: var(--farbe-akzent); }

/* --- 5 Start ---------------------------------------------------------- */
.held {
  display: grid;
  gap: clamp(1.6rem, 4vw, 3.4rem);
  align-items: center;
  padding-block: var(--abstand-gross);
}
.held__text { max-width: 34rem; }
.held__augenmarke {
  font-size: 0.8rem;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: var(--farbe-akzent);
  margin: 0 0 0.9rem;
}
.held h1 { margin-bottom: 0.5rem; }
.held__leitsatz {
  font-family: var(--schrift-titel);
  font-size: clamp(1.15rem, 2.4vw, 1.5rem);
  line-height: 1.5;
  color: var(--farbe-text);
}
.held__bild {
  background: var(--farbe-flaeche);
  border: 1px solid var(--farbe-linie);
  padding: clamp(0.6rem, 1.5vw, 1.1rem);
}
.held__bild img { width: 100%; }
@media (min-width: 48rem) {
  .held { grid-template-columns: 1.05fr 0.95fr; }
}

.knopf {
  display: inline-block;
  font-family: var(--schrift-text);
  font-size: 0.95rem;
  letter-spacing: 0.03em;
  color: #fff;
  background: var(--farbe-akzent);
  border: 1px solid var(--farbe-akzent);
  border-radius: var(--radius);
  padding: 0.7rem 1.5rem;
  text-decoration: none;
  cursor: pointer;
  transition: background var(--uebergang);
}
.knopf:hover { background: var(--farbe-akzent-dunkel); color: #fff; }
.knopf--linie {
  color: var(--farbe-akzent);
  background: transparent;
}
.knopf--linie:hover { background: var(--farbe-akzent); color: #fff; }

.wegweiser {
  display: grid;
  gap: var(--raster-luecke);
  grid-template-columns: 1fr;
  margin-top: 0.5rem;
}
@media (min-width: 38rem) {
  .wegweiser { grid-template-columns: repeat(3, 1fr); }
}
.wegweiser__feld {
  display: block;
  background: var(--farbe-flaeche);
  border: 1px solid var(--farbe-linie);
  padding: 1.4rem 1.4rem 1.5rem;
  text-decoration: none;
  color: var(--farbe-text);
  transition: border-color var(--uebergang), transform var(--uebergang);
}
.wegweiser__feld:hover {
  border-color: var(--farbe-akzent);
  transform: translateY(-2px);
}
.wegweiser__feld h3 { margin: 0 0 0.3rem; }
.wegweiser__feld p { margin: 0; color: var(--farbe-gedaempft); font-size: 0.95rem; }
.wegweiser__pfeil { color: var(--farbe-akzent); }

/* --- 6 Werk / Galerie ------------------------------------------------- */
.gruppenliste {
  display: grid;
  gap: var(--abstand);
  grid-template-columns: 1fr;
}
@media (min-width: 44rem) {
  .gruppenliste { grid-template-columns: repeat(2, 1fr); }
}
.gruppenkarte {
  display: flex;
  flex-direction: column;
  background: var(--farbe-flaeche);
  border: 1px solid var(--farbe-linie);
  text-decoration: none;
  color: var(--farbe-text);
  transition: border-color var(--uebergang), transform var(--uebergang);
}
.gruppenkarte:hover { border-color: var(--farbe-akzent); transform: translateY(-2px); }
.gruppenkarte__bild {
  aspect-ratio: 3 / 2;
  overflow: hidden;
  background: var(--farbe-hintergrund);
}
.gruppenkarte__bild img { width: 100%; height: 100%; object-fit: cover; }
.gruppenkarte__text { padding: 1.2rem 1.3rem 1.4rem; }
.gruppenkarte__text h2 { margin: 0 0 0.25rem; font-size: 1.4rem; }
.gruppenkarte__meta { color: var(--farbe-gedaempft); font-size: 0.9rem; margin: 0; }

.werk-galerie {
  display: grid;
  gap: var(--raster-luecke);
  grid-template-columns: repeat(2, 1fr);
}
@media (min-width: 38rem) { .werk-galerie { grid-template-columns: repeat(3, 1fr); } }
@media (min-width: 60rem) { .werk-galerie { grid-template-columns: repeat(4, 1fr); } }

.werk-kachel {
  display: flex;
  flex-direction: column;
  text-decoration: none;
  color: var(--farbe-text);
}
.werk-kachel__rahmen {
  display: flex;
  align-items: center;
  justify-content: center;
  aspect-ratio: 4 / 5;
  background: var(--farbe-flaeche);
  border: 1px solid var(--farbe-linie);
  padding: 0.6rem;
  overflow: hidden;
  transition: border-color var(--uebergang);
}
.werk-kachel__rahmen img,
.werk-kachel__rahmen picture {
  width: 100%; height: 100%;
}
.werk-kachel__rahmen img { object-fit: contain; }
.werk-kachel:hover .werk-kachel__rahmen { border-color: var(--farbe-akzent); }
.werk-kachel__titel {
  font-family: var(--schrift-titel);
  font-size: 0.98rem;
  margin-top: 0.55rem;
  line-height: 1.35;
}
.werk-kachel:hover .werk-kachel__titel { color: var(--farbe-akzent); }

/* --- 7 Werk-Detail ---------------------------------------------------- */
.werk-detail {
  display: grid;
  gap: clamp(1.4rem, 4vw, 3rem);
}
@media (min-width: 50rem) {
  .werk-detail { grid-template-columns: minmax(0, 1.4fr) minmax(0, 1fr); align-items: start; }
}
.werk-detail__bild {
  display: block;
  background: var(--farbe-flaeche);
  border: 1px solid var(--farbe-linie);
  padding: clamp(0.7rem, 1.6vw, 1.3rem);
  cursor: zoom-in;
}
.werk-detail__bild img { width: 100%; }
.werk-detail__angaben { padding-top: 0.4rem; }
.werk-detail__angaben h1 { margin-bottom: 0.7rem; }
.werk-detail__daten {
  margin: 0 0 1.6rem;
  border-top: 1px solid var(--farbe-linie);
}
.werk-detail__daten div {
  display: flex;
  gap: 1rem;
  padding: 0.6rem 0;
  border-bottom: 1px solid var(--farbe-linie);
  font-size: 0.96rem;
}
.werk-detail__daten dt {
  flex: 0 0 7.5rem;
  color: var(--farbe-gedaempft);
  letter-spacing: 0.04em;
}
.werk-detail__daten dd { margin: 0; }
.werk-detail__hinweis { font-size: 0.92rem; color: var(--farbe-gedaempft); }

.werk-blaettern {
  display: flex;
  flex-wrap: wrap;
  justify-content: space-between;
  gap: 0.8rem;
  margin-top: var(--abstand-gross);
  padding-top: 1.3rem;
  border-top: 1px solid var(--farbe-linie);
}
.werk-blaettern a {
  text-decoration: none;
  color: var(--farbe-text);
  font-size: 0.93rem;
  max-width: 45%;
}
.werk-blaettern a:hover { color: var(--farbe-akzent); }
.werk-blaettern__klein {
  display: block;
  font-size: 0.74rem;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color: var(--farbe-gedaempft);
  margin-bottom: 0.15rem;
}
.werk-blaettern__weiter { text-align: right; margin-left: auto; }

/* --- 8 Textseiten (Vita, Ausstellungen, Recht) ----------------------- */
.fliesstext > * + * { margin-top: 1.1em; }
.fliesstext h2 { margin-top: 2rem; }
.fliesstext h3 { margin-top: 1.6rem; }
.fliesstext ul { padding-left: 1.2rem; }
.fliesstext li { margin-bottom: 0.35rem; }

.vita {
  display: grid;
  gap: clamp(1.6rem, 4vw, 3rem);
}
@media (min-width: 50rem) {
  .vita { grid-template-columns: 16rem minmax(0, 1fr); align-items: start; }
}
.vita__portrait {
  background: var(--farbe-flaeche);
  border: 1px solid var(--farbe-linie);
  padding: 0.7rem;
}
.vita__portrait-platzhalter {
  aspect-ratio: 3 / 4;
  display: flex;
  align-items: center;
  justify-content: center;
  text-align: center;
  padding: 1rem;
  background: var(--farbe-hintergrund);
  color: var(--farbe-gedaempft);
  font-size: 0.85rem;
}
.vita__bildtext { font-size: 0.8rem; color: var(--farbe-gedaempft); margin-top: 0.5rem; }

.zapchen-feld {
  margin-top: 2rem;
  background: var(--farbe-flaeche);
  border: 1px solid var(--farbe-linie);
  border-left: 3px solid var(--farbe-akzent);
  padding: 1.3rem 1.5rem;
}
.zapchen-feld h3 { margin-top: 0; }
.zapchen-feld p:last-child { margin-bottom: 0; }

.zeitleiste { list-style: none; margin: 0; padding: 0; }
.zeitleiste > li {
  display: flex;
  gap: 1.2rem;
  padding: 0.9rem 0;
  border-bottom: 1px solid var(--farbe-linie);
}
.zeitleiste > li:first-child { border-top: 1px solid var(--farbe-linie); }
.zeitleiste__jahr {
  flex: 0 0 4.5rem;
  font-family: var(--schrift-titel);
  color: var(--farbe-akzent);
}
.zeitleiste__inhalt { margin: 0; }

.presse-artikel {
  background: var(--farbe-flaeche);
  border: 1px solid var(--farbe-linie);
  padding: clamp(1.3rem, 3vw, 2.4rem);
  margin-top: 1.6rem;
}
.presse-artikel__quelle {
  font-size: 0.82rem;
  letter-spacing: 0.04em;
  color: var(--farbe-gedaempft);
  text-transform: uppercase;
  margin-bottom: 0.4rem;
}
.presse-artikel h3 { margin-top: 0.2rem; }
.presse-artikel__unterzeile { font-style: italic; color: var(--farbe-gedaempft); }

.platzhalter-notiz {
  background: #fbf3e8;
  border: 1px dashed var(--farbe-akzent);
  color: var(--farbe-akzent-dunkel);
  font-size: 0.86rem;
  padding: 0.7rem 1rem;
  margin-bottom: 1.4rem;
  border-radius: var(--radius);
}

/* --- 9 Kontaktformular ----------------------------------------------- */
.kontakt-raster {
  display: grid;
  gap: clamp(1.6rem, 4vw, 3rem);
}
@media (min-width: 50rem) {
  .kontakt-raster { grid-template-columns: minmax(0, 1.3fr) minmax(0, 1fr); }
}
.formular { margin: 0; }
.feld { margin-bottom: 1.1rem; }
.feld label {
  display: block;
  font-size: 0.9rem;
  letter-spacing: 0.03em;
  margin-bottom: 0.35rem;
}
.feld .pflicht { color: var(--farbe-akzent); }
.feld input,
.feld textarea {
  width: 100%;
  font-family: var(--schrift-text);
  font-size: 1rem;
  color: var(--farbe-text);
  background: var(--farbe-flaeche);
  border: 1px solid var(--farbe-linie);
  border-radius: var(--radius);
  padding: 0.65rem 0.8rem;
}
.feld input:focus,
.feld textarea:focus { border-color: var(--farbe-akzent); outline: none; }
.feld textarea { min-height: 9rem; resize: vertical; }
.feld--zustimmung {
  display: flex;
  gap: 0.6rem;
  align-items: flex-start;
  font-size: 0.9rem;
}
.feld--zustimmung input { width: auto; margin-top: 0.25rem; }
.feld--falle {
  position: absolute;
  left: -9999px;
  width: 1px; height: 1px;
  overflow: hidden;
}
.kontakt-angaben {
  background: var(--farbe-flaeche);
  border: 1px solid var(--farbe-linie);
  padding: 1.4rem 1.5rem;
}
.kontakt-angaben h2 { margin-top: 0; font-size: 1.25rem; }
.kontakt-angaben dl { margin: 0; }
.kontakt-angaben dt {
  font-size: 0.78rem;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  color: var(--farbe-gedaempft);
  margin-top: 0.9rem;
}
.kontakt-angaben dd { margin: 0.1rem 0 0; }

.meldung {
  text-align: center;
  max-width: 34rem;
  margin-inline: auto;
  padding-block: var(--abstand-gross);
}
.meldung__zeichen {
  font-family: var(--schrift-titel);
  font-size: 3rem;
  color: var(--farbe-akzent);
  line-height: 1;
}

/* --- 10 Lightbox ------------------------------------------------------ */
.lightbox {
  position: fixed;
  inset: 0;
  z-index: 100;
  display: none;
  background: rgba(28, 25, 21, 0.93);
  padding: clamp(0.8rem, 3vw, 2.4rem);
}
.lightbox.ist-offen {
  display: flex;
  flex-direction: column;
}
.lightbox__buehne {
  flex: 1;
  display: flex;
  align-items: center;
  justify-content: center;
  min-height: 0;
}
.lightbox__bild {
  max-width: 100%;
  max-height: 100%;
  width: auto; height: auto;
  object-fit: contain;
  box-shadow: 0 10px 40px rgba(0,0,0,0.5);
}
.lightbox__leiste {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 1rem;
  color: #f1ece3;
  padding-top: 0.9rem;
}
.lightbox__bildtext { font-size: 0.92rem; }
.lightbox__bildtext strong { font-family: var(--schrift-titel); font-weight: 400; }
.lightbox__bildtext span { color: #b9b1a4; }
.lightbox__zaehler { font-size: 0.82rem; color: #b9b1a4; white-space: nowrap; }
.lightbox__knopf {
  background: transparent;
  border: 1px solid rgba(255,255,255,0.35);
  color: #f1ece3;
  width: 2.8rem; height: 2.8rem;
  font-size: 1.3rem;
  line-height: 1;
  border-radius: 999px;
  cursor: pointer;
  display: inline-flex;
  align-items: center;
  justify-content: center;
}
.lightbox__knopf:hover { border-color: #fff; background: rgba(255,255,255,0.12); }
.lightbox__schliessen { position: absolute; top: clamp(0.8rem,3vw,2.4rem); right: clamp(0.8rem,3vw,2.4rem); }
.lightbox__navi {
  position: absolute;
  top: 50%;
  transform: translateY(-50%);
}
.lightbox__navi--vor  { left:  clamp(0.5rem, 2vw, 1.6rem); }
.lightbox__navi--zur  { right: clamp(0.5rem, 2vw, 1.6rem); }
body.lightbox-offen { overflow: hidden; }

/* --- 11 Hilfsklassen -------------------------------------------------- */
.visuell-versteckt {
  position: absolute !important;
  width: 1px; height: 1px;
  margin: -1px; padding: 0; border: 0;
  overflow: hidden;
  clip: rect(0 0 0 0);
  clip-path: inset(50%);
  white-space: nowrap;
}
.sprung-link {
  position: absolute;
  left: 0.5rem; top: -3rem;
  background: var(--farbe-akzent);
  color: #fff;
  padding: 0.5rem 1rem;
  border-radius: var(--radius);
  z-index: 200;
  transition: top var(--uebergang);
}
.sprung-link:focus { top: 0.5rem; color: #fff; }

.zentriert { text-align: center; }
.aktionszeile { margin-top: 1.6rem; display: flex; flex-wrap: wrap; gap: 0.8rem; }

@media (prefers-reduced-motion: reduce) {
  * { transition: none !important; scroll-behavior: auto !important; }
}
