 :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;
 }

.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-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);
}

/* 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 */

 .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-tag {
   align-self: flex-start;
   padding: 6px 10px;
   border-radius: 999px;
   font-size: 0.72rem;
   text-transform: uppercase;
   letter-spacing: 0.15em;
   background: rgba(0, 0, 0, 0.9);
   border: 1px solid rgba(255, 255, 255, 0.26);
 }

 .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);
 }

 .social-card {
   padding: 20px 20px 18px;
   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);
 }

.contact-social-below {
   margin-top: 28px;
 }

/* 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-username {
   margin: 0 0 12px;
   font-size: 1.25rem;
   font-weight: 600;
   color: var(--color-text);
 }

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

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

.instagram-bio {
   margin: 0;
   font-size: 0.88rem;
   line-height: 1.45;
   color: var(--text-muted);
 }

.instagram-bio p {
   margin: 0 0 2px;
 }

.instagram-bio p:last-child {
   margin-bottom: 0;
 }

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

.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;
 }

 .social-list {
   list-style: none;
   padding: 0;
   margin: 12px 0 0;
   display: grid;
   gap: 10px;
   font-size: 0.9rem;
 }

 .social-link {
   display: flex;
   justify-content: space-between;
   align-items: center;
   padding: 8px 10px;
   border-radius: 999px;
   border: 1px solid transparent;
   transition:
     background-color var(--transition-fast),
     border-color var(--transition-fast),
     transform var(--transition-fast);
 }

 .social-link span:last-child {
   font-size: 0.78rem;
   color: var(--text-muted);
 }

 .social-link:hover {
   background-color: rgba(255, 255, 255, 0.03);
  border-color: rgba(192, 139, 90, 0.7);
   transform: translateY(-1px);
 }

 /* Social-Media-Section auf Startseite */

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

 .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; }
 .mt-14 { margin-top: 14px; }

 /* 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);
   }

   .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;
  }

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

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

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