/* ============================================
   MARK BEILHARZ — Portfolio Website
   style.css — Design System & Components
   ============================================ */

/* --- Local Fonts: Work Sans --- */
@font-face {
  font-family: 'Work Sans';
  font-style: normal;
  font-weight: 300;
  font-display: swap;
  src: url('Medien/fonts/WorkSans-Light.ttf') format('truetype');
}
@font-face {
  font-family: 'Work Sans';
  font-style: normal;
  font-weight: 400;
  font-display: swap;
  src: url('Medien/fonts/WorkSans-Regular.ttf') format('truetype');
}
@font-face {
  font-family: 'Work Sans';
  font-style: normal;
  font-weight: 500;
  font-display: swap;
  src: url('Medien/fonts/WorkSans-Medium.ttf') format('truetype');
}
@font-face {
  font-family: 'Work Sans';
  font-style: normal;
  font-weight: 600;
  font-display: swap;
  src: url('Medien/fonts/WorkSans-SemiBold.ttf') format('truetype');
}
@font-face {
  font-family: 'Work Sans';
  font-style: normal;
  font-weight: 700;
  font-display: swap;
  src: url('Medien/fonts/WorkSans-Bold.ttf') format('truetype');
}

/* --- Local Fonts: Material Symbols Outlined --- */
@font-face {
  font-family: 'Material Symbols Outlined';
  font-style: normal;
  font-weight: 300;
  font-display: swap;
  src: url('Medien/fonts/MaterialSymbolsOutlined.ttf') format('truetype');
}

:root {
  --color-background: #ffffff;
  --color-on-surface: #2d3432;
  --color-on-surface-variant: #5a605e;
  --color-surface-container-high: #e5e9e6;
  --color-primary: #5f5e5e;
  --color-inverse-surface: #0c0f0e;
  --color-inverse-on-surface: #9c9d9b;
  --color-neutral-400: #9ca3af;
  --color-neutral-800: #1f2937;

  --font-family: 'Work Sans', sans-serif;
  --font-weight-light: 300;
  --font-weight-regular: 400;
  --font-weight-medium: 500;
  --font-weight-semibold: 600;

  --space-1: 0.25rem; --space-2: 0.5rem; --space-3: 0.75rem;
  --space-4: 1rem; --space-6: 1.5rem; --space-8: 2rem;
  --space-10: 2.5rem; --space-12: 3rem; --space-16: 4rem;
  --space-20: 5rem; --space-24: 6rem;

  --transition-fast: 300ms ease;
  --transition-medium: 500ms ease;
  --transition-slow: 700ms ease;

  --z-base: 1; --z-content: 10; --z-nav: 50;
  --z-overlay: 100; --z-modal: 200; --z-lightbox: 300;
}

/* === Reset === */
*, *::before, *::after { margin: 0; padding: 0; box-sizing: border-box; }
html { height: 100%; scroll-behavior: smooth; }
body {
  font-family: var(--font-family);
  background: var(--color-background);
  color: var(--color-on-surface);
  height: 100%; width: 100%; overflow: hidden;
  overscroll-behavior-y: none;
  -webkit-font-smoothing: antialiased;
}
a { text-decoration: none; color: inherit; cursor: pointer; -webkit-tap-highlight-color: transparent; }
img, video { max-width: 100%; display: block; }
button { font-family: inherit; cursor: pointer; border: none; background: none; -webkit-tap-highlight-color: transparent; }
ul, ol { list-style: none; }

.visually-hidden {
  position: absolute; width: 1px; height: 1px; padding: 0; margin: -1px;
  overflow: hidden; clip: rect(0,0,0,0); white-space: nowrap; border: 0;
}
.material-symbols-outlined {
  font-variation-settings: 'FILL' 0, 'wght' 300, 'GRAD' 0, 'opsz' 24;
}

/* === Section Container === */
.section {
  position: absolute; top: 0; left: 0; width: 100%; height: 100%;
  overflow: hidden; opacity: 0; visibility: hidden;
  transition: opacity 0.6s ease, visibility 0.6s ease;
}
.section.active { opacity: 1; visibility: visible; z-index: var(--z-content); }
.section__inner {
  position: relative; width: 100%; height: 100%;
  display: flex; align-items: center; justify-content: center;
}

/* === Header === */
.site-header {
  position: fixed; top: 0; left: 0; width: 100%; z-index: var(--z-nav);
  display: flex; justify-content: space-between; align-items: center;
  padding: var(--space-6) var(--space-8);
  background: transparent; pointer-events: none;
}
.site-header__spacer { flex: 1; }
.site-header__title {
  flex: 1; text-align: center;
  font-size: 1.1rem; font-weight: var(--font-weight-medium);
  text-transform: uppercase; letter-spacing: 0.4em;
  color: var(--color-neutral-800);
  pointer-events: auto; cursor: pointer;
  transition: opacity var(--transition-medium);
}
.site-header__title:hover { opacity: 0.7; }
.site-header__actions { flex: 1; display: flex; justify-content: flex-end; pointer-events: auto; }

/* Back Button — fixed position so overlays don't shift it */
.btn-back {
  font-size: 0.65rem; font-weight: var(--font-weight-medium);
  text-transform: uppercase; letter-spacing: 0.35em;
  color: var(--color-on-surface);
  opacity: 0; visibility: hidden;
  transition: opacity var(--transition-fast), visibility var(--transition-fast);
  pointer-events: auto;
  padding: var(--space-2) var(--space-4);
  position: relative;
}
.btn-back::after {
  content: ''; position: absolute; bottom: 0; left: 50%;
  transform: translateX(-50%); width: 0; height: 1px;
  background: var(--color-on-surface);
  transition: width var(--transition-slow);
}
.btn-back:hover::after { width: 100%; }
.btn-back.visible { opacity: 1; visibility: visible; }

/* === Footer === */
.site-footer {
  position: fixed; bottom: 0; left: 0; width: 100%; z-index: var(--z-nav);
  display: flex; justify-content: flex-start; align-items: center;
  gap: var(--space-6); padding: var(--space-6) var(--space-8);
  background: transparent; pointer-events: none;
}
.site-footer__link {
  font-size: 0.6rem; font-weight: var(--font-weight-semibold);
  text-transform: uppercase; letter-spacing: 0.2em;
  color: var(--color-neutral-400);
  transition: color var(--transition-fast);
  pointer-events: auto; cursor: pointer;
}
.site-footer__link:hover { color: var(--color-on-surface); }

/* === Hero Section === */
.hero { position: relative; background: #fff; }
.hero__content {
  position: relative; z-index: var(--z-base);
  width: 100%; height: 100%;
  display: flex; flex-direction: row; align-items: center;
}

/* Image left — 4:5 portrait format */
.hero__image-area {
  flex: 0 0 50%; height: 100%;
  display: flex; align-items: center; justify-content: center;
  padding: var(--space-16);
}
/* Hero image is styled via .hero__image-wrapper + .hero__image-area .hero__image below */

/* Nav right — slightly toward center */
.hero__nav-area {
  flex: 0 0 50%;
  display: flex; align-items: center; justify-content: center;
  padding-right: 8%;
}

/* === Nav Menu (shared style) === */
.nav-menu {
  display: flex; flex-direction: column; align-items: center;
  gap: var(--space-8);
}
.nav-link { position: relative; overflow: hidden; display: block; }
.nav-link__text {
  display: block; font-size: 0.75rem; font-weight: var(--font-weight-medium);
  text-transform: uppercase; letter-spacing: 0.6em;
  color: var(--color-on-surface);
  transition: opacity var(--transition-fast);
}
.nav-link:hover .nav-link__text { opacity: 0.7; }
.nav-link__underline {
  position: absolute; bottom: 0; left: 50%; transform: translateX(-50%);
  width: 0; height: 1px; background: var(--color-on-surface);
  transition: width var(--transition-slow);
}
.nav-link:hover .nav-link__underline { width: 100%; }

/* === Portfolio Section — centered text links === */
.portfolio__content {
  display: flex; align-items: center; justify-content: center;
  width: 100%; height: 100%;
}
.portfolio__nav {
  display: flex; flex-direction: column; align-items: center;
  gap: var(--space-8);
}
.portfolio__link { position: relative; overflow: hidden; display: block; }
.portfolio__link-text {
  display: block; font-size: 0.75rem; font-weight: var(--font-weight-medium);
  text-transform: uppercase; letter-spacing: 0.6em;
  color: var(--color-on-surface);
  transition: opacity var(--transition-fast);
}
.portfolio__link:hover .portfolio__link-text { opacity: 0.7; }
.portfolio__link-underline {
  position: absolute; bottom: 0; left: 50%; transform: translateX(-50%);
  width: 0; height: 1px; background: var(--color-on-surface);
  transition: width var(--transition-slow);
}
.portfolio__link:hover .portfolio__link-underline { width: 100%; }

/* === Gallery (Foto) === */
.gallery__items { position: absolute; top: 0; left: 0; width: 100%; height: 100%; }
.gallery-item {
  position: absolute; cursor: pointer; overflow: hidden;
  transition: transform var(--transition-fast), box-shadow var(--transition-fast);
  -webkit-tap-highlight-color: transparent;
}
.gallery-item:hover { transform: scale(1.04); box-shadow: 0 4px 20px rgba(0,0,0,0.12); }
.gallery-item__image { width: 100%; height: 100%; object-fit: cover; }

/* === Lightbox === */
.lightbox {
  position: fixed; inset: 0; z-index: var(--z-lightbox);
  background: rgba(0,0,0,0.85);
  display: flex; align-items: center; justify-content: center;
  opacity: 0; visibility: hidden;
  transition: opacity var(--transition-fast), visibility var(--transition-fast);
  cursor: pointer;
}
.lightbox.active { opacity: 1; visibility: visible; }
.lightbox__image { max-width: 90vw; max-height: 90vh; object-fit: contain; border-radius: 2px; }
.lightbox__close {
  position: fixed; top: var(--space-6); left: var(--space-8);
  color: #fff; font-size: 0.65rem; font-weight: var(--font-weight-medium);
  text-transform: uppercase; letter-spacing: 0.35em;
  cursor: pointer; opacity: 0.7; transition: opacity var(--transition-fast); z-index: 1;
}
.lightbox__close:hover { opacity: 1; }

/* === Video Section === */
.video__items { position: absolute; top: 0; left: 0; width: 100%; height: 100%; }
.video-item { position: absolute; transition: transform var(--transition-fast); }
.video-item:hover { transform: scale(1.02); }
.video-item__link { display: block; width: 100%; text-decoration: none; color: inherit; }
.video-item__thumb-wrapper { position: relative; width: 100%; overflow: hidden; background: #000; }
.video-item__thumbnail {
  width: 100%; height: 100%; object-fit: cover; display: block;
  transition: opacity var(--transition-fast);
}
.video-item__link:hover .video-item__thumbnail { opacity: 0.8; }
.video-item__play-btn {
  position: absolute; top: 50%; left: 50%; transform: translate(-50%,-50%);
  width: 48px; height: 48px;
  border: 1.5px solid rgba(255,255,255,0.9); border-radius: 50%;
  display: flex; align-items: center; justify-content: center;
  color: rgba(255,255,255,0.9);
  transition: all var(--transition-fast);
  backdrop-filter: blur(2px); background: rgba(0,0,0,0.15);
}
.video-item__play-btn svg { width: 18px; height: 18px; margin-left: 2px; }
.video-item__link:hover .video-item__play-btn {
  border-color: #fff; color: #fff; background: rgba(0,0,0,0.3);
  transform: translate(-50%,-50%) scale(1.08);
}
.video-item__label {
  margin-top: var(--space-2); font-size: 0.6rem; font-weight: var(--font-weight-medium);
  letter-spacing: 0.3em; color: var(--color-on-surface-variant);
  text-align: center; text-transform: none;
}

/* === Audio Section === */
.audio__items { position: absolute; top: 0; left: 0; width: 100%; height: 100%; }
.audio-item {
  position: absolute; display: flex; flex-direction: column;
  align-items: center; gap: var(--space-3);
}
.audio-item__icon {
  width: 40px; height: 40px; border-radius: 50%;
  background: var(--color-surface-container-high);
  display: flex; align-items: center; justify-content: center;
  color: var(--color-on-surface-variant); font-size: 1rem;
  margin-bottom: var(--space-1);
}
.audio-item__label {
  font-size: 0.55rem; font-weight: var(--font-weight-medium);
  text-transform: uppercase; letter-spacing: 0.3em;
  color: var(--color-on-surface-variant); margin-bottom: var(--space-1);
}
.audio-item audio { width: 320px; height: 36px; }

/* === About Choice (Schwerpunkte / Lebenslauf) === */
.about-choice__content {
  display: flex; align-items: center; justify-content: center;
  width: 100%; height: 100%;
}
.about-choice__nav {
  display: flex; flex-direction: column; align-items: center;
  gap: var(--space-8);
}
.about-choice__link { position: relative; overflow: hidden; display: block; }
.about-choice__link-text {
  display: block; font-size: 0.75rem; font-weight: var(--font-weight-medium);
  text-transform: uppercase; letter-spacing: 0.6em;
  color: var(--color-on-surface);
  transition: opacity var(--transition-fast);
}
.about-choice__link:hover .about-choice__link-text { opacity: 0.7; }
.about-choice__link-underline {
  position: absolute; bottom: 0; left: 50%; transform: translateX(-50%);
  width: 0; height: 1px; background: var(--color-on-surface);
  transition: width var(--transition-slow);
}
.about-choice__link:hover .about-choice__link-underline { width: 100%; }

/* === Schwerpunkte === */
.schwerpunkt__items { position: absolute; top: 0; left: 0; width: 100%; height: 100%; }
.schwerpunkt-item {
  position: absolute; display: flex; flex-direction: column;
  align-items: center; gap: var(--space-1);
  cursor: pointer; transition: transform var(--transition-fast), opacity var(--transition-fast);
}
.schwerpunkt-item:hover { transform: scale(1.06); }
.schwerpunkt-item__text {
  font-size: 0.8rem; font-weight: var(--font-weight-semibold);
  text-transform: uppercase; letter-spacing: 0.5em;
  color: var(--color-on-surface);
  transition: opacity var(--transition-fast);
}
.schwerpunkt-item:hover .schwerpunkt-item__text { opacity: 0.7; }
.schwerpunkt-item__sub {
  font-size: 0.55rem; font-weight: var(--font-weight-regular);
  letter-spacing: 0.2em; color: var(--color-on-surface-variant);
  text-align: center; max-width: 220px;
  opacity: 0; transition: opacity var(--transition-fast);
}
.schwerpunkt-item:hover .schwerpunkt-item__sub { opacity: 1; }

/* === Lebenslauf — text items like Schwerpunkte === */
.lebenslauf__items { position: absolute; top: 0; left: 0; width: 100%; height: 100%; }
.lebenslauf-item {
  position: absolute; display: flex; flex-direction: column;
  align-items: center; gap: var(--space-1);
  cursor: pointer; transition: transform var(--transition-fast), opacity var(--transition-fast);
}
.lebenslauf-item:hover { transform: scale(1.06); }
.lebenslauf-item__text {
  font-size: 0.7rem; font-weight: var(--font-weight-semibold);
  text-transform: uppercase; letter-spacing: 0.4em;
  color: var(--color-on-surface);
  transition: opacity var(--transition-fast);
  white-space: nowrap;
}
.lebenslauf-item:hover .lebenslauf-item__text { opacity: 0.7; }
.lebenslauf-item__sub {
  font-size: 0.5rem; font-weight: var(--font-weight-regular);
  letter-spacing: 0.2em; color: var(--color-on-surface-variant);
  text-align: center;
  opacity: 0; transition: opacity var(--transition-fast);
}
.lebenslauf-item:hover .lebenslauf-item__sub { opacity: 1; }

/* === Info Overlay === */
.info-overlay {
  position: fixed; inset: 0; z-index: var(--z-lightbox);
  background: rgba(255,255,255,0.95);
  display: flex; align-items: center; justify-content: center;
  opacity: 0; visibility: hidden;
  transition: opacity var(--transition-fast), visibility var(--transition-fast);
  padding: var(--space-8);
}
.info-overlay.active { opacity: 1; visibility: visible; }
.info-overlay__content { max-width: 520px; text-align: center; }
.info-overlay__title {
  font-size: 0.8rem; font-weight: var(--font-weight-semibold);
  text-transform: uppercase; letter-spacing: 0.4em;
  color: var(--color-on-surface); margin-bottom: var(--space-6);
}
.info-overlay__text {
  font-size: 0.85rem; font-weight: var(--font-weight-regular);
  line-height: 1.8; color: var(--color-on-surface-variant);
}
.info-overlay__close {
  position: fixed; top: var(--space-6); left: var(--space-8);
  font-size: 0.65rem; font-weight: var(--font-weight-medium);
  text-transform: uppercase; letter-spacing: 0.35em;
  color: var(--color-on-surface); cursor: pointer;
  opacity: 0.6; transition: opacity var(--transition-fast);
}
.info-overlay__close:hover { opacity: 1; }

/* === Contact — centered === */
.contact__content {
  position: relative; width: 100%; height: 100%;
  display: flex; align-items: center; justify-content: center;
}
.contact__info {
  display: flex; flex-direction: column; align-items: center;
  gap: var(--space-6);
}
.contact__link { position: relative; overflow: hidden; display: block; }
.contact__link-text {
  display: block; font-size: 0.7rem; font-weight: var(--font-weight-medium);
  text-transform: uppercase; letter-spacing: 0.5em;
  color: var(--color-on-surface);
  transition: opacity var(--transition-fast);
}
.contact__link:hover .contact__link-text { opacity: 0.7; }
.contact__link-underline {
  position: absolute; bottom: 0; left: 50%; transform: translateX(-50%);
  width: 0; height: 1px; background: var(--color-on-surface);
  transition: width var(--transition-slow);
}
.contact__link:hover .contact__link-underline { width: 100%; }

/* === Legal Overlay === */
.legal-overlay {
  position: fixed; inset: 0; z-index: var(--z-lightbox);
  background: rgba(255,255,255,0.97);
  display: flex; align-items: flex-start; justify-content: center;
  opacity: 0; visibility: hidden;
  transition: opacity var(--transition-fast), visibility var(--transition-fast);
  padding: var(--space-16) var(--space-8); overflow-y: auto;
}
.legal-overlay.active { opacity: 1; visibility: visible; }
.legal-overlay__content { max-width: 600px; width: 100%; }
.legal-overlay__title {
  font-size: 0.9rem; font-weight: var(--font-weight-semibold);
  text-transform: uppercase; letter-spacing: 0.4em;
  color: var(--color-on-surface); margin-bottom: var(--space-8);
}
.legal-overlay__text {
  font-size: 0.8rem; font-weight: var(--font-weight-regular);
  line-height: 1.9; color: var(--color-on-surface-variant);
}
.legal-overlay__text h3 {
  font-size: 0.75rem; font-weight: var(--font-weight-semibold);
  text-transform: uppercase; letter-spacing: 0.2em;
  margin-top: var(--space-6); margin-bottom: var(--space-3);
  color: var(--color-on-surface);
}
.legal-overlay__text p { margin-bottom: var(--space-4); }
.legal-overlay__close {
  position: fixed; top: var(--space-6); left: var(--space-8);
  font-size: 0.65rem; font-weight: var(--font-weight-medium);
  text-transform: uppercase; letter-spacing: 0.35em;
  color: var(--color-on-surface); cursor: pointer;
  opacity: 0.6; transition: opacity var(--transition-fast); z-index: 1;
}
.legal-overlay__close:hover { opacity: 1; }

/* === Cookie Banner === */
.cookie-banner {
  position: fixed; bottom: var(--space-8); left: 50%;
  transform: translateX(-50%); z-index: var(--z-modal);
  background: var(--color-inverse-surface); color: var(--color-inverse-on-surface);
  padding: var(--space-4) var(--space-8);
  display: flex; align-items: center; gap: var(--space-6);
  font-size: 0.65rem; font-weight: var(--font-weight-regular);
  letter-spacing: 0.1em; max-width: 560px; width: calc(100% - 2rem);
  opacity: 0; visibility: hidden;
  transition: opacity var(--transition-fast), visibility var(--transition-fast);
}
.cookie-banner.active { opacity: 1; visibility: visible; }
.cookie-banner__text { flex: 1; line-height: 1.6; }
.cookie-banner__text a { text-decoration: underline; opacity: 0.8; }
.cookie-banner__btn {
  font-size: 0.6rem; font-weight: var(--font-weight-semibold);
  text-transform: uppercase; letter-spacing: 0.2em;
  color: var(--color-background); background: var(--color-primary);
  padding: var(--space-2) var(--space-4);
  transition: background var(--transition-fast);
  white-space: nowrap; border: none; cursor: pointer;
}
.cookie-banner__btn:hover { background: var(--color-on-surface); }

/* ============================================
   Responsive
   ============================================ */
@media (max-width: 1024px) {
  .site-header { padding: var(--space-4) var(--space-6); }
  .site-header__title { font-size: 0.9rem; letter-spacing: 0.3em; }
  .site-footer { padding: var(--space-4) var(--space-6); }
  .nav-menu { gap: var(--space-6); }
  .nav-link__text { font-size: 0.7rem; }
  .audio-item audio { width: 260px; }
  .hero__image-area { padding: var(--space-10); }
  .hero__image { height: 62%; }
  .hero__nav-area { padding-right: 5%; }
}

@media (max-width: 640px) {
  .site-header { padding: var(--space-3) var(--space-4); }
  .site-header__title { font-size: 0.75rem; letter-spacing: 0.25em; }
  .btn-back { font-size: 0.55rem; }
  .site-footer { padding: var(--space-3) var(--space-4); gap: var(--space-4); }
  .site-footer__link { font-size: 0.5rem; }
  .nav-menu { gap: var(--space-4); }
  .nav-link__text { font-size: 0.6rem; letter-spacing: 0.4em; }
  .contact__link-text { font-size: 0.6rem; letter-spacing: 0.35em; }
  .audio-item audio { width: 220px; }
  .cookie-banner {
    flex-direction: column; text-align: center;
    gap: var(--space-3); padding: var(--space-3) var(--space-4);
  }

  /* Hero mobile: image = full background */
  .hero__content { flex-direction: column; position: relative; }
  .hero__image-area {
    position: absolute; top: 0; left: 0;
    width: 100%; height: 100%;
    padding: 0; z-index: 0; flex: none;
  }
  .hero__image {
    width: 100%; height: 100%;
    aspect-ratio: auto; max-width: 100%;
    object-fit: cover; opacity: 0.12; box-shadow: none;
  }
  .hero__nav-area {
    position: relative; z-index: 1; flex: none;
    width: 100%; height: 100%;
    display: flex; align-items: center; justify-content: center;
    padding-right: 0;
  }

  .schwerpunkt-item__text { font-size: 0.65rem; letter-spacing: 0.35em; }
  .schwerpunkt-item__sub { font-size: 0.45rem; max-width: 160px; }
  .lebenslauf-item__text { font-size: 0.55rem; letter-spacing: 0.3em; }
  .lebenslauf-item__sub { font-size: 0.4rem; }

  .video-item__play-btn { width: 36px; height: 36px; }
  .video-item__play-btn svg { width: 14px; height: 14px; }

  .portfolio__link-text { font-size: 0.6rem; letter-spacing: 0.4em; }
  .about-choice__link-text { font-size: 0.6rem; letter-spacing: 0.4em; }
}

/* === Hero Image Wrapper + Copyright === */
.hero__image-wrapper {
  position: relative;
  height: 70%;
  aspect-ratio: 4 / 5;
  max-width: 90%;
}
.hero__image-area .hero__image {
  width: 100%;
  height: 100%;
  object-fit: cover;
  box-shadow: 0 2px 12px rgba(0,0,0,0.08);
  opacity: 0;
  transition: opacity 150ms ease;
}
.hero__image-area .hero__image.loaded {
  opacity: 1;
}
.hero__copyright {
  position: absolute;
  bottom: 8px;
  left: 8px;
  font-size: 0.5rem;
  font-weight: var(--font-weight-regular);
  color: rgba(255,255,255,0.75);
  letter-spacing: 0.05em;
  text-shadow: 0 1px 3px rgba(0,0,0,0.5);
  pointer-events: none;
  z-index: 2;
}
@media (max-width: 640px) {
  .hero__image-wrapper {
    width: 100%;
    height: 100%;
    max-width: 100%;
    aspect-ratio: auto;
  }
  .hero__copyright {
    bottom: 8px;
    right: 8px;
    left: auto;
    font-size: 0.45rem;
    color: rgba(45,52,50,0.5);
    text-shadow: none;
  }
  .legal-overlay__close, .info-overlay__close {
    top: 0;
    left: 0;
    width: 100%;
    padding-top: var(--space-6);
    padding-bottom: var(--space-4);
    padding-left: var(--space-8);
    background: rgba(255,255,255,0.98);
    box-sizing: border-box;
    border-bottom: 1px solid rgba(0,0,0,0.05);
  }
  .legal-overlay__content, .info-overlay__content {
    margin-top: var(--space-12);
  }
  .hero__image-area .hero__image.loaded {
    opacity: 0.12;
  }
}



.gallery-item__copyright {
  position: absolute;
  bottom: 4px;
  left: 6px;
  font-size: 0.45rem;
  font-weight: var(--font-weight-regular);
  color: rgba(255,255,255,0.7);
  letter-spacing: 0.05em;
  text-shadow: 0 1px 2px rgba(0,0,0,0.5);
  pointer-events: none;
  z-index: 2;
}

/* === Focus Styles for Accessibility === */
a:focus-visible,
button:focus-visible,
[tabindex]:focus-visible {
  outline: 2px solid var(--color-primary);
  outline-offset: 3px;
}
.nav-link:focus-visible .nav-link__underline,
.portfolio__link:focus-visible .portfolio__link-underline,
.about-choice__link:focus-visible .about-choice__link-underline,
.contact__link:focus-visible .contact__link-underline {
  width: 100%;
}
.lebenslauf-item:focus-visible,
.schwerpunkt-item:focus-visible {
  outline: 2px solid var(--color-primary);
  outline-offset: 3px;
}
.gallery-item:focus-visible {
  outline: 2px solid var(--color-primary);
  outline-offset: 2px;
}
