 :root {
  --bg-gradient: radial-gradient(circle at 0% 0%, #3b3228 0, transparent 46%),
                  radial-gradient(circle at 100% 0%, #4a3b2e 0, transparent 46%),
                  radial-gradient(circle at 0% 100%, #2c2620 0, transparent 46%),
                  radial-gradient(circle at 100% 100%, #4b3a2b 0, transparent 46%),
                  linear-gradient(135deg, #090806 0%, #090806 40%, #15100c 100%);
   --color-bg: #050608;
   --color-surface: rgba(255, 255, 255, 0.04);
   --color-surface-strong: rgba(255, 255, 255, 0.07);
   --color-border: rgba(255, 255, 255, 0.16);
   --color-border-soft: rgba(255, 255, 255, 0.09);
   --color-highlight: rgba(255, 255, 255, 0.45);
   --shadow-soft: 0 18px 45px rgba(0, 0, 0, 0.65);
   --shadow-soft-sm: 0 10px 26px rgba(0, 0, 0, 0.5);
   --radius-pill: 999px;
   --radius-lg: 28px;
   --radius-md: 18px;
   --radius-sm: 12px;
   --blur-strong: 22px;
   --blur-medium: 16px;
  --accent-primary: #f1e0c7; /* Creme */
  --accent-primary-soft: rgba(241, 224, 199, 0.25);
  --accent-secondary: #c08b5a; /* Warmes Braun */
   --text-main: #f7f7f8;
   --text-muted: #b4b7c3;
   --text-soft: #8f93a2;
   --focus-ring: 0 0 0 2px rgba(242, 194, 123, 0.35);
   --transition-fast: 180ms ease-out;
   --transition-med: 220ms ease;
   --max-width: 1120px;
 }

 /* Global Reset & Base */

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

 html {
   scroll-behavior: smooth;
   background-color: var(--color-bg);
 }

 body {
   margin: 0;
   min-height: 100vh;
   min-height: 100dvh;
   font-family: system-ui, -apple-system, BlinkMacSystemFont, "SF Pro Text",
     "Segoe UI", sans-serif;
   color: var(--text-main);
   background-color: var(--color-bg);
   background-image: var(--bg-gradient);
   background-attachment: fixed;
 }

 body::before {
   content: "";
   position: fixed;
   inset: 0;
   pointer-events: none;
   background:
    radial-gradient(circle at 20% 30%, rgba(241, 224, 199, 0.33), transparent 55%),
    radial-gradient(circle at 80% 70%, rgba(192, 139, 90, 0.28), transparent 55%);
   mix-blend-mode: screen;
   opacity: 0.3;
   z-index: -1;
 }

 img {
   max-width: 100%;
   display: block;
 }

 a {
   color: inherit;
   text-decoration: none;
 }

 a:focus-visible,
 button:focus-visible {
   outline: none;
   box-shadow: var(--focus-ring);
   border-radius: 999px;
 }

 /* Layout */

 .page {
   min-height: 100vh;
   display: flex;
   flex-direction: column;
 }

 .page-main {
   flex: 1;
   padding: 104px 16px 64px; /* Platz für Floating-Header */
 }

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

 /* Floating Glass Header */

 .header-shell {
  position: fixed;
  top: 18px;
  left: 0;
  right: 0;
  z-index: 40;
  display: flex;
  justify-content: center;
  padding: 0 16px;
 }

.header-glass {
  position: relative;
  display: flex;
  align-items: center;
  gap: 24px;
  padding: 4px 18px;
  max-width: var(--max-width);
  width: 100%;
  background: linear-gradient(
      135deg,
      rgba(255, 255, 255, 0.08),
      rgba(255, 255, 255, 0.02)
    );
  background-clip: padding-box;
  border-radius: var(--radius-pill);
  border: 1px solid var(--color-border);
  border-bottom-color: rgba(0, 0, 0, 0.7);
  box-shadow: var(--shadow-soft);
  backdrop-filter: blur(var(--blur-strong));
  -webkit-backdrop-filter: blur(var(--blur-strong));
  isolation: isolate;
  overflow: hidden; /* Shine-Effekt strikt innerhalb des Headers */
}

 /* Glass Shine Animation */

 .header-glass::before {
   content: "";
   position: absolute;
  inset: 0;
   border-radius: inherit;
  background: linear-gradient(
    120deg,
    transparent 0%,
    rgba(241, 224, 199, 0.35) 20%,
    rgba(255, 255, 255, 0.5) 35%,
    rgba(241, 224, 199, 0.35) 50%,
    transparent 70%
  );
  opacity: 0;
  transform: translateX(-25%);
   pointer-events: none;
   mix-blend-mode: screen;
   animation: headerShine 7s linear infinite;
 }

 @keyframes headerShine {
   0% {
     opacity: 0;
     transform: translateX(-45%);
   }
   25% {
     opacity: 0.7;
   }
   45% {
     opacity: 0;
     transform: translateX(45%);
   }
   100% {
     opacity: 0;
     transform: translateX(45%);
   }
 }

/* Nav & zentriertes Logo */

 .nav {
  flex: 1;
  display: flex;
  justify-content: center;
 }

 .nav-list {
   display: flex;
   align-items: center;
  gap: 32px;
   padding: 0;
   margin: 0;
   list-style: none;
   font-size: 14px;
 }

.nav-logo-wrap {
  padding: 0;
  display: flex;
  align-items: center;
  justify-content: center;
  border-radius: 0;
  background: none;
  box-shadow: none;
}

.nav-logo {
  height: 52px;
  max-width: 220px;
  display: block;
  object-fit: contain;
}

 .nav-link {
   position: relative;
  padding: 6px 12px;
   border-radius: 999px;
  color: var(--text-muted);
   font-weight: 500;
   letter-spacing: 0.06em;
   text-transform: uppercase;
  font-size: 0.9rem;
   transition:
    color var(--transition-fast),
    transform var(--transition-fast),
    text-shadow var(--transition-fast);
 }

 .nav-link::after {
   content: "";
   position: absolute;
   inset: 0;
   border-radius: inherit;
  border: none;
  box-shadow: none;
 }

 .nav-link:hover {
  color: var(--text-main);
   transform: translateY(-1px);
  text-shadow:
    0 0 8px rgba(241, 224, 199, 0.8),
    0 0 18px rgba(192, 139, 90, 0.75);
 }

 .nav-link:hover::after {
  box-shadow: none;
 }

 .nav-link[aria-current="page"] {
  color: var(--text-main);
  text-shadow:
    0 0 10px rgba(241, 224, 199, 0.9),
    0 0 22px rgba(192, 139, 90, 0.85);
 }

 .nav-link[aria-current="page"]::after {
   border-color: rgba(242, 194, 123, 0.9);
 }

/* Theme Toggle (Dark / Light) */

.theme-toggle {
  position: relative;
  display: inline-flex;
  align-items: center;
  cursor: pointer;
}

.theme-toggle input {
  position: absolute;
  opacity: 0;
  pointer-events: none;
}

.theme-toggle-track {
  position: relative;
  width: 44px;
  height: 20px;
  border-radius: 999px;
  padding: 1px;
  background: radial-gradient(circle at 20% 20%, rgba(0, 0, 0, 0.8), transparent 70%);
  border: 1px solid rgba(255, 255, 255, 0.16);
  box-shadow:
    inset 0 0 0 1px rgba(0, 0, 0, 0.8),
    0 6px 14px rgba(0, 0, 0, 0.7);
  display: flex;
  align-items: center;
}

.theme-toggle-thumb {
  width: 16px;
  height: 16px;
  border-radius: 999px;
  background: radial-gradient(circle at 30% 25%, #f7f7f8, #b9becb);
  box-shadow:
    0 0 0 1px rgba(0, 0, 0, 0.7),
    0 3px 8px rgba(0, 0, 0, 0.9);
  transform: translateX(0);
  transition: transform var(--transition-fast), background-color var(--transition-fast),
    box-shadow var(--transition-fast);
}

/* Light Mode via :has */

body:has(#theme-toggle:checked) {
  --bg-gradient: radial-gradient(circle at 0% 0%, #f7f7fb 0, transparent 45%),
                  radial-gradient(circle at 100% 0%, #ffe7c3 0, transparent 45%),
                  radial-gradient(circle at 0% 100%, #d0e3ff 0, transparent 45%),
                  radial-gradient(circle at 100% 100%, #ffd8df 0, transparent 45%),
                  linear-gradient(135deg, #f3f4f7 0%, #f5f6fa 40%, #e9edf7 100%);
  --color-bg: #f5f5f7;
  --text-main: #14151a;
  --text-muted: #5d6270;
  --text-soft: #808593;
  --color-border: rgba(0, 0, 0, 0.13);
  --color-border-soft: rgba(0, 0, 0, 0.08);
  --shadow-soft: 0 18px 45px rgba(15, 17, 32, 0.25);
  --shadow-soft-sm: 0 10px 26px rgba(15, 17, 32, 0.18);
}

body:has(#theme-toggle:checked) .header-glass {
  background: linear-gradient(
      135deg,
      rgba(255, 255, 255, 0.9),
      rgba(255, 255, 255, 0.7)
    );
}

body:has(#theme-toggle:checked) .theme-toggle-track {
  background: linear-gradient(135deg, #f2c27b, #ff7a90);
}

body:has(#theme-toggle:checked) .theme-toggle-thumb {
  transform: translateX(20px);
  background: radial-gradient(circle at 30% 25%, #10121b, #222532);
  box-shadow:
    0 0 0 1px rgba(0, 0, 0, 0.8),
    0 3px 10px rgba(0, 0, 0, 0.85);
}

 /* Hero Section */

 .hero {
   margin-top: 32px;
 }

.hero-grid {
  display: grid;
  grid-template-columns: minmax(0, 3fr) minmax(0, 2.5fr);
  gap: 32px;
  align-items: center;
}

 .hero-kicker {
   font-size: 12px;
   letter-spacing: 0.24em;
   text-transform: uppercase;
   color: var(--accent-primary);
   margin-bottom: 12px;
 }

 .hero-title {
   font-size: clamp(2.4rem, 3vw, 3.1rem);
   line-height: 1.05;
   margin: 0 0 16px;
 }

 .hero-title span {
   background: linear-gradient(135deg, #ffffff, #f2c27b);
   -webkit-background-clip: text;
   color: transparent;
 }

 .hero-subtitle {
   margin: 0 0 24px;
   max-width: 34rem;
   color: var(--text-soft);
   font-size: 0.98rem;
   white-space: pre-line;
 }

.hero-content {
  max-width: 40rem;
}

 .hero-meta {
   display: flex;
   gap: 24px;
   font-size: 0.86rem;
   color: var(--text-muted);
   margin-bottom: 20px;
 }

 .hero-meta strong {
   color: var(--text-main);
 }

 .hero-actions {
   display: flex;
   flex-wrap: wrap;
   gap: 12px;
   margin-bottom: 32px;
 }

 .btn {
   display: inline-flex;
   align-items: center;
   justify-content: center;
   gap: 8px;
   padding: 14px 28px;
   border-radius: 999px;
   border: 1px solid transparent;
   background: transparent;
   color: var(--text-main);
   font-size: 0.95rem;
   font-weight: 500;
   letter-spacing: 0.04em;
   text-transform: uppercase;
   cursor: pointer;
   transition:
     background-color var(--transition-med),
     transform var(--transition-fast),
     box-shadow var(--transition-med),
     border-color var(--transition-med);
 }

 .btn-primary {
  background: radial-gradient(circle at 0 0, rgba(255, 255, 255, 0.4), transparent 70%),
              linear-gradient(135deg, #f1e0c7, #c08b5a);
   color: #120c07;
   box-shadow: 0 12px 28px rgba(0, 0, 0, 0.75);
 }

 .btn-primary:hover {
   transform: translateY(-1px);
   box-shadow: 0 18px 40px rgba(0, 0, 0, 0.85);
 }

 .btn-block {
   width: 100%;
   justify-content: center;
 }

 .btn-secondary {
   border-color: var(--color-border-soft);
   background-color: rgba(10, 11, 16, 0.8);
   box-shadow: var(--shadow-soft-sm);
 }

 .btn-secondary:hover {
   background-color: rgba(19, 21, 29, 0.9);
   border-color: rgba(242, 194, 123, 0.7);
   transform: translateY(-1px);
 }

 .btn-ghost {
   padding-inline: 14px;
   border-color: transparent;
   background: transparent;
   color: var(--text-muted);
 }

 .btn-ghost:hover {
   color: var(--text-main);
   background-color: rgba(255, 255, 255, 0.04);
 }

 .hero-badges {
   display: flex;
   flex-wrap: wrap;
   gap: 8px;
   font-size: 0.7rem;
   color: var(--text-soft);
   margin-bottom: 20px;
 }

 .hero-badge {
   padding: 5px 10px;
   border-radius: 999px;
   background-color: rgba(8, 10, 14, 0.95);
   border: 1px solid rgba(255, 255, 255, 0.08);
   backdrop-filter: blur(var(--blur-medium));
   -webkit-backdrop-filter: blur(var(--blur-medium));
 }

 /* Hero Visual */

 .hero-visual {
   position: relative;
 }

.hero-card {
  position: relative;
  padding: 10px;
  border-radius: var(--radius-lg);
  background: transparent;
  border: 1px solid rgba(255, 255, 255, 0.18);
  box-shadow: var(--shadow-soft);
  backdrop-filter: blur(20px);
  -webkit-backdrop-filter: blur(20px);
  overflow: hidden;
}

.hero-card-inner {
  position: relative;
  border-radius: calc(var(--radius-lg) - 4px);
  overflow: hidden;
}

.hero-card-media {
  position: relative;
  height: 100%;
  min-height: 300px;
  overflow: hidden;
}

.hero-video {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  object-fit: cover;
}

.hero-video-1 {
  opacity: 1;
  z-index: 1;
}

.hero-video-2 {
  opacity: 0;
  z-index: 2;
  animation: heroVideoFade 8s infinite;
}

@keyframes heroVideoFade {
  0%, 45% {
    opacity: 0;
  }
  50%, 95% {
    opacity: 1;
  }
  100% {
    opacity: 0;
  }
}


 /* Section Generic */

 .section {
   margin-top: 64px;
 }

 .section-heading {
   display: flex;
   justify-content: space-between;
   align-items: baseline;
   gap: 12px;
   margin-bottom: 24px;
 }

.section-heading--packages {
  margin-top: 48px;
}

 .section-title {
   font-size: 1.2rem;
   letter-spacing: 0.18em;
   text-transform: uppercase;
   color: var(--text-muted);
 }

.section-subtitle {
  font-size: 0.95rem;
  color: var(--text-soft);
}

/* Partner-Logos (Marquee unter Highlights) */
.partners-section {
  margin-top: 56px;
}

.partners-heading {
  margin-bottom: 24px;
  text-align: center;
}

.partners-heading > div {
  margin-inline: auto;
  max-width: 42rem;
}

.partners-heading .section-subtitle {
  margin-top: 10px;
  margin-inline: auto;
  max-width: 40rem;
}

.partners-marquee {
  position: relative;
  display: flex;
  flex-direction: column;
  align-items: center;
  width: 100%;
  overflow: hidden;
  padding-block: 16px;
  mask-image: linear-gradient(
    90deg,
    transparent,
    #000 5%,
    #000 95%,
    transparent
  );
  -webkit-mask-image: linear-gradient(
    90deg,
    transparent,
    #000 5%,
    #000 95%,
    transparent
  );
}

#partners-marquee-host {
  width: 100%;
  max-width: var(--max-width);
  margin-inline: auto;
  display: flex;
  justify-content: center;
  overflow: hidden;
}

.partners-marquee__track {
  display: flex;
  width: max-content;
  margin-inline: auto;
  animation: partners-marquee-scroll 45s linear infinite;
}

.partners-marquee:hover .partners-marquee__track {
  animation-play-state: paused;
}

@keyframes partners-marquee-scroll {
  0% {
    transform: translateX(0);
  }
  100% {
    transform: translateX(-50%);
  }
}

.partners-marquee__group {
  display: flex;
  flex-shrink: 0;
  align-items: center;
  justify-content: center;
  gap: clamp(40px, 7vw, 88px);
  padding-inline: clamp(24px, 4vw, 48px);
}

.partners-marquee__item {
  flex: 0 0 auto;
  display: flex;
  align-items: center;
  justify-content: center;
  height: 88px;
  max-width: 280px;
  opacity: 0.88;
  transition: opacity var(--transition-fast);
}

.partners-marquee__item:hover {
  opacity: 1;
}

.partners-marquee__item a {
  display: flex;
  align-items: center;
  justify-content: center;
  max-width: 100%;
}

.partners-marquee__item img {
  max-height: 88px;
  max-width: 280px;
  width: auto;
  height: auto;
  object-fit: contain;
  filter: grayscale(0.12) brightness(1.06);
}

@media (prefers-reduced-motion: reduce) {
  #partners-marquee-host {
    justify-content: center;
  }

  .partners-marquee__track {
    animation: none;
    flex-wrap: wrap;
    justify-content: center;
    width: 100%;
    max-width: 100%;
    row-gap: 28px;
  }

  .partners-marquee__group {
    flex-wrap: wrap;
    justify-content: center;
    width: 100%;
    max-width: 56rem;
  }

  .partners-marquee__group:last-child {
    display: none;
  }

  .partners-marquee:hover .partners-marquee__track {
    animation-play-state: running;
  }

  #artworks-marquee-host {
    justify-content: center;
  }

  .artworks-marquee__track {
    animation: none;
    flex-wrap: wrap;
    justify-content: center;
    width: 100%;
    max-width: 100%;
    row-gap: 20px;
  }

  .artworks-marquee__group {
    flex-wrap: wrap;
    justify-content: center;
    width: 100%;
    max-width: 56rem;
  }

  .artworks-marquee__group:last-child {
    display: none;
  }

  .artworks-marquee:hover .artworks-marquee__track {
    animation-play-state: running;
  }
}

/* Highlights Controls - Tabs und Subtitle vertikal zentriert */
.highlights-controls {
  display: flex;
  justify-content: space-between;
  align-items: center;
  gap: 24px;
  margin-bottom: 24px;
}

.highlights-controls .section-subtitle {
  margin: 0;
  text-align: right;
}

/* Portfolio Tabs (visuelles Filter-Feeling) */

.tabs {
  position: relative;
  display: inline-flex;
  padding: 4px;
  border-radius: var(--radius-pill);
  background: rgba(0, 0, 0, 0.76);
  border: 1px solid rgba(255, 255, 255, 0.12);
  box-shadow: var(--shadow-soft-sm);
  overflow: hidden;
}

.tab-input {
  position: absolute;
  opacity: 0;
  pointer-events: none;
}

.tab {
  position: relative;
  z-index: 1;
  flex: 1 1 0;
  min-width: 0;
  padding: 7px 14px;
  border-radius: 999px;
  border: none;
  background: transparent;
  color: var(--text-muted);
  font-size: 0.8rem;
  text-transform: uppercase;
  letter-spacing: 0.12em;
  cursor: pointer;
  display: flex;
  align-items: center;
  justify-content: center;
  transition:
    color var(--transition-fast),
    transform var(--transition-fast);
}

.tab::after {
  content: "";
  position: absolute;
  inset: 0;
  border-radius: inherit;
  border: 1px solid transparent;
  transition:
    border-color var(--transition-fast),
    box-shadow var(--transition-fast);
}

.tab:hover {
  color: var(--text-main);
  transform: translateY(-1px);
}

/* Sliding Highlight-Pill (nur transform = flüssig, kein backdrop-filter) */

.tabs::before {
  content: "";
  position: absolute;
  top: 4px;
  bottom: 4px;
  left: 4px;
  width: calc((100% - 8px) / 3);
  border-radius: 999px;
  background: linear-gradient(135deg, #f1e0c7, #c08b5a);
  box-shadow: 0 12px 30px rgba(0, 0, 0, 0.9);
  transition: transform 0.25s cubic-bezier(0.4, 0, 0.2, 1);
  transform: translateZ(0);
  z-index: 0;
}

/* Aktiver Tab über :has() – Highlights & Portfolio */

.tabs:has(#filter-all:checked) .tab--all,
.tabs:has(#filter-photo:checked) .tab--photo,
.tabs:has(#filter-video:checked) .tab--video,
.tabs:has(#portfolio-filter-all:checked) .tab--p-all,
.tabs:has(#portfolio-filter-photo:checked) .tab--p-photo,
.tabs:has(#portfolio-filter-video:checked) .tab--p-video,
.tabs:has(#packages-filter-start:checked) .tab--pkg-start,
.tabs:has(#packages-filter-praesenz:checked) .tab--pkg-praesenz,
.tabs:has(#packages-filter-website:checked) .tab--pkg-website {
  color: var(--color-bg);
}

.tabs:has(#filter-all:checked)::before,
.tabs:has(#portfolio-filter-all:checked)::before,
.tabs:has(#packages-filter-start:checked)::before {
  transform: translateX(0%);
}

.tabs:has(#filter-photo:checked)::before,
.tabs:has(#portfolio-filter-photo:checked)::before,
.tabs:has(#packages-filter-praesenz:checked)::before {
  transform: translateX(100%);
}

.tabs:has(#filter-video:checked)::before,
.tabs:has(#portfolio-filter-video:checked)::before,
.tabs:has(#packages-filter-website:checked)::before {
  transform: translateX(200%);
}

/* CSS-Filter-Logik – Pakete (Startseite) */

.packages-grid .package-card {
  display: none;
}

.packages-controls:has(#packages-filter-start:checked) + .packages-grid .package-card--start,
.packages-controls:has(#packages-filter-start:checked) + .packages-grid .package-card--start-addons {
  display: flex;
}

.packages-controls:has(#packages-filter-praesenz:checked) + .packages-grid .package-card--praesenz,
.packages-controls:has(#packages-filter-praesenz:checked) + .packages-grid .package-card--praesenz-addons {
  display: flex;
}

.packages-controls:has(#packages-filter-website:checked) + .packages-grid .package-card--website,
.packages-controls:has(#packages-filter-website:checked) + .packages-grid .package-card--website-addons {
  display: flex;
}

.packages-controls {
  display: flex;
  justify-content: space-between;
  align-items: center;
  gap: 24px;
  margin-bottom: 24px;
}

.packages-controls .section-subtitle {
  margin: 0;
  text-align: right;
}

/* CSS-Filter-Logik – Startseite (Highlights) */

.highlights-controls ~ .grid .card {
  display: block;
}

/* Im "Alle" Tab nur die ersten 3 Cards zeigen */
.highlights-controls:has(#filter-all:checked) ~ .grid .card:nth-child(n+4) {
  display: none;
}

.highlights-controls:has(#filter-photo:checked) ~ .grid .card--video {
  display: none;
}

.highlights-controls:has(#filter-video:checked) ~ .grid .card--photo {
  display: none;
}

/* Spezielles Layout für Hochkant-Videos in Highlights */

#highlights .card-media {
  height: 260px;
}

#highlights .card--video::before,
#highlights .card--video .card-media::after {
  display: none;
}

/* CSS-Filter-Logik – Portfolio-Seite (Filter + Grid im gleichen Container) */

.container:has(#portfolio-filter-all:checked) .grid .card {
  display: block;
}

.container:has(#portfolio-filter-photo:checked) .grid .card--video {
  display: none;
}

.container:has(#portfolio-filter-video:checked) .grid .card--photo {
  display: none;
}

.portfolio-grid__status {
  grid-column: 1 / -1;
  margin: 0;
  padding: 2rem 1rem;
  text-align: center;
  font-size: 0.95rem;
  line-height: 1.5;
  color: var(--text-muted, rgba(255, 255, 255, 0.55));
}

.portfolio-grid__status--error {
  color: rgba(230, 160, 140, 0.95);
}

.portfolio-grid--loading .portfolio-grid__status {
  min-height: 8rem;
  display: flex;
  align-items: center;
  justify-content: center;
}

/* Portfolio: Zeilen nicht strecken — Foto-Karte bleibt so hoch wie Inhalt (kein Leerraum unter 4:3) */
#portfolio-grid {
  align-items: start;
}

/* Portfolio: Fotos 4:3 (ueberschreibt globale .card-media-Hoehe 190px) */
#portfolio-grid .card--photo .card-media {
  height: auto;
  aspect-ratio: 4 / 3;
  width: 100%;
}

/* Portfolio: Reels 9:16, volle Kartenbreite */
#portfolio-grid .card--video .card-media {
  aspect-ratio: 9 / 16;
  width: 100%;
  height: auto;
}

#portfolio-grid .card--video .card-media img,
#portfolio-grid .card--video .card-media video {
  transform: scale(1.02);
  transition: transform 260ms ease-out;
}

#portfolio-grid .card--video:hover .card-media img,
#portfolio-grid .card--video:hover .card-media video {
  transform: scale(1.07);
}

/* Portfolio: klickbare Reel-Karte (ohne Play-Overlay) */
#portfolio-grid a.card.card--reel-link {
  display: block;
  text-decoration: none;
  color: inherit;
  outline: none;
}

#portfolio-grid a.card.card--reel-link:focus-visible {
  box-shadow: var(--focus-ring);
  border-color: rgba(242, 194, 123, 0.55);
}

#portfolio-grid .card--video .play-icon {
  display: none;
}

 /* Portfolio Grid */

 .grid {
   display: grid;
   grid-template-columns: repeat(3, minmax(0, 1fr));
   gap: 20px;
 }

 .card {
   position: relative;
   border-radius: var(--radius-md);
   overflow: hidden;
   background: rgba(9, 11, 18, 0.96);
   border: 1px solid rgba(255, 255, 255, 0.08);
   box-shadow: var(--shadow-soft-sm);
   backdrop-filter: blur(var(--blur-medium));
   -webkit-backdrop-filter: blur(var(--blur-medium));
   transition:
     transform var(--transition-med),
     box-shadow var(--transition-med),
     border-color var(--transition-med),
     background-color var(--transition-med);
 }

 .card:hover {
   transform: translateY(-4px);
   box-shadow: 0 24px 55px rgba(0, 0, 0, 0.9);
  border-color: rgba(192, 139, 90, 0.9);
   background-color: rgba(14, 18, 26, 0.98);
 }

 .card-media {
   position: relative;
  height: 190px;
   background-color: #151821;
   overflow: hidden;
 }

 .card-media img {
   width: 100%;
   height: 100%;
   object-fit: cover;
   transform: scale(1.02);
   transition: transform 260ms ease-out;
 }

 .card:hover .card-media img {
   transform: scale(1.07);
 }

 .card-badge {
   position: absolute;
   top: 12px;
   left: 12px;
   padding: 4px 9px;
   border-radius: 999px;
   font-size: 0.7rem;
   text-transform: uppercase;
   letter-spacing: 0.16em;
   background-color: rgba(0, 0, 0, 0.8);
   border: 1px solid rgba(255, 255, 255, 0.3);
 }

 .card-body {
  padding: 12px 16px 14px;
 }

 .card-title {
  margin: 0 0 6px;
   font-size: 0.98rem;
 }

/* Zentrierte Titel & Tags speziell für Reel-Highlights */

#highlights .card--video .card-body,
#highlights .card--photo .card-body {
  text-align: center;
}

 .card-meta {
   margin: 0;
   font-size: 0.8rem;
   color: var(--text-soft);
 }

.card-tags {
  margin: 4px auto 0;
  display: flex;
  justify-content: center;
  flex-wrap: wrap;
  gap: 6px;
  font-size: 0.65rem;
  color: var(--text-soft);
}

.card-tag {
  padding: 2px 6px;
  border-radius: 999px;
  background-color: rgba(0, 0, 0, 0.9);
  border: 1px solid rgba(255, 255, 255, 0.18);
}

 /* Video Card Play Icon */

 .card--video .card-media::after {
   content: "";
   position: absolute;
   inset: 0;
  background: radial-gradient(circle at 50% 50%, rgba(0, 0, 0, 0.32), transparent 60%);
   opacity: 1;
   transition: opacity var(--transition-med);
 }

 .card--video::before {
   content: "";
   position: absolute;
   inset: 14px;
   border-radius: inherit;
   border: 1px dashed rgba(255, 255, 255, 0.14);
   pointer-events: none;
   opacity: 0.3;
 }

 .card--video .play-icon {
   position: absolute;
   top: 50%;
   left: 50%;
   width: 54px;
   height: 54px;
   border-radius: 999px;
   border: 1px solid rgba(255, 255, 255, 0.6);
   background: radial-gradient(circle at 30% 20%, rgba(255, 255, 255, 0.35), transparent 60%),
               rgba(0, 0, 0, 0.86);
   transform: translate(-50%, -50%);
   box-shadow:
     0 10px 24px rgba(0, 0, 0, 0.9),
     0 0 0 1px rgba(0, 0, 0, 0.9);
 }

 .card--video .play-icon::before {
   content: "";
   position: absolute;
   left: 52%;
   top: 50%;
   transform: translate(-50%, -50%);
   width: 0;
   height: 0;
   border-left: 13px solid #f7f7f8;
   border-top: 9px solid transparent;
   border-bottom: 9px solid transparent;
 }

 .card--video:hover .card-media::after {
   opacity: 0.7;
 }

 /* Kontakt / Kontaktkarte */

 .contact-grid {
   display: grid;
   grid-template-columns: 1fr 1fr;
   gap: 28px;
   align-items: stretch;
 }

.contact-grid > * {
   min-width: 0;
 }

.contact-card.contact-card--form {
   display: flex;
   flex-direction: column;
 }

.contact-card.contact-card--form .contact-form {
   flex: 1;
   min-height: 0;
   display: flex;
   flex-direction: column;
   gap: 14px;
 }

.contact-card.contact-card--form .contact-form-row {
   display: grid;
   grid-template-columns: 1fr 1fr;
   gap: 12px;
 }

.contact-card.contact-card--form .contact-form-field {
   display: flex;
   flex-direction: column;
   gap: 6px;
   min-width: 0;
 }

.contact-card.contact-card--form .contact-form-field label {
   font-size: 0.78rem;
   text-transform: uppercase;
   letter-spacing: 0.12em;
   color: var(--text-muted);
 }

.contact-card.contact-card--form .contact-form-field input,
.contact-card.contact-card--form .contact-form-field textarea {
   width: 100%;
   min-width: 0;
   padding: 10px 14px;
   border-radius: var(--radius-sm);
   border: 1px solid rgba(255, 255, 255, 0.16);
   background: rgba(5, 7, 12, 0.7);
   color: var(--text-main);
   font: inherit;
   font-size: 0.9rem;
   outline: none;
   transition: border-color var(--transition-fast), box-shadow var(--transition-fast);
 }

.contact-card.contact-card--form .contact-form-field input::placeholder,
.contact-card.contact-card--form .contact-form-field textarea::placeholder {
   color: var(--text-soft);
   opacity: 0.9;
 }

.contact-card.contact-card--form .contact-form-field input:focus,
.contact-card.contact-card--form .contact-form-field textarea:focus {
   border-color: rgba(192, 139, 90, 0.7);
   box-shadow: 0 0 0 2px rgba(192, 139, 90, 0.2);
 }

.contact-card.contact-card--form .contact-form-field textarea {
   border-radius: var(--radius-md);
   min-height: 100px;
   resize: vertical;
 }

.contact-card.contact-card--form .contact-form-actions {
   margin-top: 6px;
 }

.contact-card.contact-card--form .contact-form-actions .btn-primary {
   width: 100%;
   padding: 12px 24px;
 }

.contact-card.contact-card--form .contact-form-hint {
   margin: 0;
   font-size: 0.78rem;
   color: var(--text-soft);
 }

.form-message {
   padding: 12px 14px;
   border-radius: var(--radius-sm);
   font-size: 0.88rem;
 }

.form-message--success {
   background: rgba(80, 140, 90, 0.15);
   border: 1px solid rgba(80, 140, 90, 0.4);
 }

.form-message--error {
   background: rgba(180, 80, 80, 0.12);
   border: 1px solid rgba(180, 80, 80, 0.4);
 }

.form-message--error a {
   color: var(--accent-primary);
   text-decoration: underline;
 }

.contact-card.contact-card--form {
   border-color: rgba(192, 139, 90, 0.25);
   box-shadow: var(--shadow-soft), 0 0 0 1px rgba(241, 224, 199, 0.06);
 }

 .contact-card {
   position: relative;
   padding: 24px 24px 22px;
   border-radius: var(--radius-lg);
   background: linear-gradient(
       135deg,
       rgba(255, 255, 255, 0.09),
       rgba(1, 3, 7, 0.98)
     );
   border: 1px solid rgba(255, 255, 255, 0.18);
   box-shadow: var(--shadow-soft);
   backdrop-filter: blur(20px);
   -webkit-backdrop-filter: blur(20px);
 }

 .contact-card-header {
   display: flex;
   justify-content: space-between;
   gap: 16px;
   margin-bottom: 16px;
 }

 .contact-title {
   margin: 0 0 4px;
   font-size: 1.1rem;
 }

 .contact-subtitle {
   margin: 0;
   font-size: 0.9rem;
   color: var(--text-soft);
 }

 .contact-details {
   display: grid;
   grid-template-columns: minmax(0, 1.4fr) minmax(0, 1.2fr);
   gap: 18px;
   font-size: 0.9rem;
 }

.contact-card > .contact-details {
   grid-template-columns: 1fr;
 }

 .contact-list {
   list-style: none;
   padding: 0;
   margin: 0;
 }

 .contact-list li + li {
   margin-top: 10px;
 }

 .contact-label {
   font-size: 0.78rem;
   text-transform: uppercase;
   letter-spacing: 0.16em;
   color: var(--text-muted);
 }

 .contact-value {
   font-size: 0.92rem;
 }

 .contact-note {
   margin-top: 18px;
   font-size: 0.84rem;
   color: var(--text-soft);
 }

.contact-grid--inquiry {
   grid-template-columns: minmax(0, 1fr);
   max-width: 52rem;
   margin-inline: auto;
}

/* Kontaktformular links, Instagram + WhatsApp rechts übereinander, gleiche Höhe */
.contact-layout {
   display: grid;
   grid-template-columns: minmax(0, 1.22fr) minmax(260px, 0.78fr);
   gap: 28px;
   align-items: stretch;
}

.contact-layout > * {
   min-width: 0;
}

.contact-layout .contact-grid--inquiry {
   max-width: none;
   margin-inline: 0;
}

.contact-layout .instagram-cards {
   margin-top: 0;
   display: flex;
   flex-direction: column;
   gap: 28px;
   min-width: 0;
   height: 100%;
}

.contact-layout .instagram-profile-card,
.contact-layout .whatsapp-card {
   flex: 1 1 0;
   min-height: 0;
}

.contact-layout .instagram-profile-card {
   min-height: 0;
}

.contact-layout .instagram-profile-header {
   flex: 1 1 auto;
   min-height: 0;
}

.contact-layout .instagram-profile-info {
   min-height: 0;
}

.contact-layout .whatsapp-card .btn-primary {
   width: 100%;
   justify-content: center;
}

.contact-card--inquiry {
   padding: 28px 28px 26px;
   border-color: rgba(192, 139, 90, 0.22);
   box-shadow: var(--shadow-soft), 0 0 0 1px rgba(241, 224, 199, 0.06);
}

.contact-highlight-grid {
   display: grid;
   grid-template-columns: repeat(2, minmax(0, 1fr));
   gap: 12px;
   margin-bottom: 20px;
}

.contact-highlight-cell {
   padding: 14px 16px;
   border-radius: var(--radius-md);
   border: 1px solid rgba(255, 255, 255, 0.14);
   background: rgba(5, 8, 14, 0.78);
}

.contact-highlight-label {
   font-size: 0.72rem;
   text-transform: uppercase;
   letter-spacing: 0.14em;
   color: var(--text-muted);
   margin-bottom: 8px;
}

.contact-highlight-value {
   font-size: 0.95rem;
   font-weight: 600;
   color: var(--text-main);
   line-height: 1.45;
}

.contact-highlight-value a {
   color: inherit;
   text-decoration: none;
}

.contact-highlight-value a:hover {
   color: var(--accent-secondary);
}

.contact-inquiry-form {
   display: flex;
   flex-direction: column;
   gap: 16px;
}

.contact-inquiry-row {
   display: grid;
   grid-template-columns: repeat(2, minmax(0, 1fr));
   gap: 12px;
}

.contact-inquiry-field {
   display: flex;
   flex-direction: column;
   gap: 0;
   min-width: 0;
}

.contact-inquiry-field--full {
   width: 100%;
}

.contact-inquiry-sr {
   position: absolute;
   width: 1px;
   height: 1px;
   padding: 0;
   margin: -1px;
   overflow: hidden;
   clip: rect(0, 0, 0, 0);
   white-space: nowrap;
   border: 0;
}

.contact-inquiry-field input,
.contact-inquiry-field textarea {
   width: 100%;
   min-width: 0;
   padding: 12px 14px;
   border-radius: var(--radius-sm);
   border: 1px solid rgba(255, 255, 255, 0.16);
   background: rgba(5, 7, 12, 0.85);
   color: var(--text-main);
   font: inherit;
   font-size: 0.92rem;
   outline: none;
   transition: border-color var(--transition-fast), box-shadow var(--transition-fast);
}

.contact-inquiry-field textarea {
   border-radius: var(--radius-md);
   min-height: 120px;
   resize: vertical;
}

.contact-inquiry-field input::placeholder,
.contact-inquiry-field textarea::placeholder {
   color: var(--text-soft);
   opacity: 0.9;
}

.contact-inquiry-field input:focus,
.contact-inquiry-field textarea:focus {
   border-color: rgba(192, 139, 90, 0.75);
   box-shadow: 0 0 0 2px rgba(192, 139, 90, 0.2);
}

.contact-pill-group {
   display: flex;
   flex-wrap: wrap;
   gap: 10px;
}

.contact-pill {
   position: relative;
   cursor: pointer;
   margin: 0;
}

.contact-pill input {
   position: absolute;
   opacity: 0;
   width: 1px;
   height: 1px;
   margin: 0;
}

.contact-pill__text {
   display: inline-block;
   padding: 9px 16px;
   border-radius: 999px;
   font-size: 0.82rem;
   font-weight: 500;
   border: 1px solid rgba(255, 255, 255, 0.18);
   background: rgba(8, 10, 16, 0.9);
   color: var(--text-main);
   transition:
     background-color var(--transition-fast),
     border-color var(--transition-fast),
     color var(--transition-fast);
}

.contact-pill:hover .contact-pill__text {
   border-color: rgba(192, 139, 90, 0.45);
}

.contact-pill input:focus-visible + .contact-pill__text {
   outline: 2px solid rgba(192, 139, 90, 0.65);
   outline-offset: 2px;
}

.contact-pill input:checked + .contact-pill__text {
   border-color: rgba(192, 139, 90, 0.9);
   background: rgba(192, 139, 90, 0.14);
   color: #f5ebe0;
}

.contact-inquiry-actions {
   margin-top: 4px;
   display: flex;
   flex-direction: column;
   gap: 10px;
}

.contact-inquiry-actions .btn-primary {
   box-shadow: 0 10px 32px rgba(0, 0, 0, 0.55), 0 0 36px rgba(192, 139, 90, 0.07);
}

/* Instagram + WhatsApp: 2 gleich große Cards */
.instagram-cards {
   margin-top: 28px;
   display: grid;
   grid-template-columns: 1fr 1fr;
   gap: 28px;
   align-items: stretch;
 }

.instagram-profile-card,
.whatsapp-card {
   padding: 24px 24px 22px;
   border-radius: var(--radius-lg);
   background: rgba(8, 10, 14, 0.95);
   border: 1px solid rgba(255, 255, 255, 0.12);
   box-shadow: var(--shadow-soft-sm);
 }

.instagram-profile-card {
   display: flex;
   flex-direction: column;
   align-items: flex-start;
   gap: 20px;
 }

.instagram-title {
   margin: 0;
   font-size: 1.1rem;
   font-weight: 600;
 }

.instagram-profile-header {
   display: flex;
   align-items: flex-start;
   gap: 24px;
   width: 100%;
   min-width: 0;
 }

.instagram-profile-link {
   display: block;
   line-height: 0;
   width: 110px;
   height: 110px;
   border-radius: 50%;
   overflow: hidden;
   flex-shrink: 0;
   border: 2px solid rgba(255, 255, 255, 0.12);
 }

.instagram-logo {
   width: 100%;
   height: 100%;
   object-fit: cover;
   object-position: center;
   display: block;
   transform: scale(1.25);
 }

.instagram-profile-info {
   flex: 1;
   min-width: 0;
 }

.instagram-display-name {
   margin: 0 0 4px;
   font-size: 1.15rem;
   font-weight: 600;
   color: var(--color-text);
}

.instagram-username {
   margin: 0 0 12px;
   font-size: 1.25rem;
   font-weight: 600;
   color: var(--color-text);
}

.instagram-username--secondary {
   font-size: 0.92rem;
   font-weight: 500;
   color: var(--text-muted);
}

.instagram-stats {
   display: flex;
   gap: 20px;
   margin: 0;
   font-size: 0.9rem;
   color: var(--text-muted);
 }

.instagram-stats strong {
   font-weight: 600;
   color: var(--color-text);
   margin-right: 4px;
 }

/* Volle Breite + Flex: Button zuverlässig horizontal zentrieren */
.instagram-profile-actions {
   display: flex;
   justify-content: center;
   width: 100%;
   margin-top: auto;
   flex-shrink: 0;
   padding-top: 4px;
 }

.instagram-profile-card .instagram-profile-actions .btn-primary {
   margin-top: 0;
 }

.whatsapp-card {
   display: flex;
   flex-direction: column;
   align-items: flex-start;
   gap: 20px;
 }

.whatsapp-title {
   margin: 0;
   font-size: 1.1rem;
   font-weight: 600;
 }

.whatsapp-text {
   margin: 0;
   font-size: 0.95rem;
   line-height: 1.5;
   color: var(--text-muted);
 }

.whatsapp-number {
   margin: 0;
   font-size: 1rem;
 }

.whatsapp-number a {
   color: var(--color-text);
   text-decoration: none;
   font-weight: 600;
 }

.whatsapp-number a:hover {
   color: var(--color-accent);
 }

.whatsapp-card .btn-primary {
   margin-top: auto;
 }

.btn-sm {
   padding: 8px 14px;
   font-size: 0.8rem;
 }

 .packages-grid {
   margin-top: 40px;
   display: grid;
   grid-template-columns: repeat(2, minmax(0, 1fr));
   gap: 24px;
 }

/* Artworks: endloser Marquee nach links, quadratische Kacheln (1:1) */
.section--artworks .artworks-marquee {
  position: relative;
  margin-top: 28px;
  display: flex;
  flex-direction: column;
  align-items: center;
  width: 100%;
  overflow: hidden;
  padding-block: 12px;
  mask-image: linear-gradient(
    90deg,
    transparent,
    #000 5%,
    #000 95%,
    transparent
  );
  -webkit-mask-image: linear-gradient(
    90deg,
    transparent,
    #000 5%,
    #000 95%,
    transparent
  );
}

#artworks-marquee-host {
  width: 100%;
  max-width: var(--max-width);
  margin-inline: auto;
  display: flex;
  justify-content: center;
  overflow: hidden;
}

.artworks-marquee__track {
  display: flex;
  width: max-content;
  margin-inline: auto;
  animation: artworks-marquee-scroll 45s linear infinite;
}

.artworks-marquee:hover .artworks-marquee__track {
  animation-play-state: paused;
}

@keyframes artworks-marquee-scroll {
  0% {
    transform: translateX(0);
  }
  100% {
    transform: translateX(-50%);
  }
}

.artworks-marquee__group {
  display: flex;
  flex-shrink: 0;
  align-items: center;
  justify-content: center;
  gap: clamp(20px, 5vw, 40px);
  padding-inline: clamp(16px, 3vw, 36px);
}

.artworks-marquee__item {
  flex: 0 0 auto;
  width: clamp(140px, 22vw, 220px);
}

.artworks-marquee__item .artworks-cell {
  position: relative;
  margin: 0;
  border-radius: var(--radius-lg);
  overflow: hidden;
  background: rgba(5, 7, 12, 0.98);
  border: 1px solid rgba(255, 255, 255, 0.12);
  box-shadow: var(--shadow-soft-sm);
  aspect-ratio: 1 / 1;
  width: 100%;
}

.artworks-cell__link {
  display: block;
  width: 100%;
  height: 100%;
  line-height: 0;
}

.artworks-cell__link:focus-visible {
  outline: 2px solid var(--color-accent);
  outline-offset: 3px;
}

.artworks-marquee__item .artworks-cell img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
}

 .package-card {
   padding: 18px 18px 16px;
   border-radius: var(--radius-lg);
   background: rgba(5, 7, 12, 0.98);
   border: 1px solid rgba(255, 255, 255, 0.12);
   box-shadow: var(--shadow-soft-sm);
   display: flex;
   flex-direction: column;
   justify-content: space-between;
   gap: 16px;
   font-size: 0.9rem;
 }

 .package-content {
   display: flex;
   flex-direction: column;
   gap: 12px;
 }

 .package-list {
   margin: 0;
   padding-left: 20px;
   list-style: disc;
   display: flex;
   flex-direction: column;
   gap: 8px;
 }

 .package-list li {
   font-size: 0.88rem;
   line-height: 1.5;
   color: var(--text-muted);
 }

 .package-sublist {
   margin-top: 4px;
   margin-left: 16px;
   padding-left: 0;
   list-style: disc;
   display: flex;
   flex-direction: column;
   gap: 4px;
 }

 .package-sublist li {
   font-size: 0.88rem;
   line-height: 1.5;
   color: var(--text-muted);
 }

 .package-addons {
   margin-top: 16px;
   padding-top: 16px;
   border-top: 1px solid rgba(255, 255, 255, 0.08);
 }

 .package-addons strong {
   display: block;
   margin-bottom: 8px;
   color: var(--text-main);
 }

 .social-hero {
   margin-top: 40px;
   padding: 18px 18px 16px;
   border-radius: var(--radius-lg);
   background: rgba(5, 7, 12, 0.98);
   border: 1px solid rgba(255, 255, 255, 0.12);
   box-shadow: var(--shadow-soft-sm);
   display: flex;
   flex-wrap: wrap;
   justify-content: space-between;
   gap: 16px;
   font-size: 0.9rem;
 }

 /* Footer */

 .footer {
  padding: 28px 16px 32px;
  font-size: 0.8rem;
  color: var(--text-soft);
}

.footer-shell {
  max-width: var(--max-width);
  margin: 0 auto;
  display: flex;
  justify-content: center;
}

.footer-glass {
  margin-top: 0;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  padding: 12px 32px 18px;
 }

.footer-copy {
  font-size: 1rem;
  color: var(--text-soft);
  font-weight: 500;
}

.footer-glass .nav-link {
  font-size: 0.9rem;
}

 /* Utilities */

 .badge-soft {
   padding: 4px 9px;
   border-radius: 999px;
   font-size: 0.74rem;
   background-color: rgba(0, 0, 0, 0.85);
   border: 1px solid rgba(255, 255, 255, 0.16);
 }

 .text-soft {
   color: var(--text-soft);
 }

 .mt-20 { margin-top: 20px; }
 .mt-32 { margin-top: 32px; }

 /* Video-Füllung ohne Inline-Styles */
 .hero-card-media video,
 .card-media video {
   width: 100%;
   height: 100%;
   object-fit: cover;
 }

 /* Responsive */

 @media (max-width: 960px) {
   .hero-grid {
     grid-template-columns: minmax(0, 1.2fr);
   }

   .hero-visual {
     order: -1;
   }

   .header-glass {
     gap: 12px;
     padding-inline: 12px;
   }

   .contact-grid {
     grid-template-columns: minmax(0, 1fr);
   }

   .contact-layout {
     grid-template-columns: minmax(0, 1fr);
   }

   .contact-layout .instagram-profile-card,
   .contact-layout .whatsapp-card {
     flex: none;
   }

   .grid {
     grid-template-columns: repeat(2, minmax(0, 1fr));
   }
 }

 @media (max-width: 720px) {
   .page-main {
     padding-top: 96px;
   }

   .header-shell {
     top: 12px;
   }

   .header-glass {
     padding-inline: 10px;
   }

   .nav-list {
     gap: 6px;
   }

   .nav-link {
     padding-inline: 10px;
     font-size: 10px;
   }

   .hero-meta {
     flex-direction: column;
     gap: 6px;
   }

   .hero-grid {
     gap: 24px;
   }

  .grid {
    grid-template-columns: minmax(0, 1fr);
  }

  .highlights-controls {
    flex-direction: column;
    align-items: flex-start;
    gap: 16px;
  }

  .highlights-controls .section-subtitle {
    text-align: left;
  }

  .contact-details {
    grid-template-columns: minmax(0, 1fr);
  }

  .contact-card--form .contact-form-row {
    grid-template-columns: 1fr;
  }

  .contact-highlight-grid {
    grid-template-columns: minmax(0, 1fr);
  }

  .contact-inquiry-row {
    grid-template-columns: minmax(0, 1fr);
  }

  .instagram-cards {
    grid-template-columns: 1fr;
  }

   .packages-grid {
     grid-template-columns: minmax(0, 1fr);
   }

  /* Paket-Tabs (Switch): volle Breite, untereinander mit Untertitel */
  .packages-controls {
    flex-direction: column;
    align-items: stretch;
    gap: 14px;
  }

  .packages-controls .section-subtitle {
    text-align: left;
    max-width: none;
    order: 2;
  }

  .packages-controls .tabs--packages {
    width: 100%;
    max-width: 100%;
    box-sizing: border-box;
    align-self: stretch;
  }

  .packages-controls .tabs--packages .tab {
    padding: 10px 8px;
    font-size: 0.72rem;
    letter-spacing: 0.07em;
    min-height: 44px;
  }

  .section--artworks .artworks-marquee {
    margin-top: 20px;
    padding-block: 10px;
  }

  .artworks-marquee__item {
    width: clamp(120px, 70vw, 200px);
  }

  /* Footer mobil: nur Impressum, Instagram, WhatsApp (kein ©, kein Datenschutz) */
  .footer-copy {
    display: none;
  }

  .footer-nav__item--datenschutz {
    display: none;
  }

  /* Footer: kompakt, Links umbrechen, taugliche Klickflächen */
  .footer {
    padding: 20px 12px max(28px, env(safe-area-inset-bottom, 0px));
  }

  .footer-glass {
    width: 100%;
    max-width: 100%;
    padding: 14px 14px 16px;
    gap: 12px;
    box-sizing: border-box;
  }

  .footer-copy {
    font-size: 0.88rem;
    text-align: center;
    width: 100%;
    margin: 0;
    line-height: 1.35;
  }

  .footer-glass nav {
    width: 100%;
  }

  .footer-glass .nav-list {
    justify-content: center;
    flex-wrap: wrap;
    gap: 8px 10px;
    row-gap: 6px;
    width: 100%;
  }

  .footer-glass .nav-link {
    padding: 10px 12px;
    font-size: 0.68rem;
    letter-spacing: 0.08em;
    min-height: 40px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
  }

   .social-hero {
     flex-direction: column;
   }
 }

@media (max-width: 400px) {
  .packages-controls .tabs--packages .tab {
    font-size: 0.65rem;
    padding-inline: 6px;
    letter-spacing: 0.05em;
  }

  .footer-glass .nav-link {
    font-size: 0.62rem;
    padding-inline: 10px;
  }
}
