/* ═══════════════════════════════════════════════════════════════════
   COLORA DESIGN · style.v5.css  ·  Premium-Veredelung
   Wird NACH style.v4.css geladen und hebt das bestehende Design auf
   Studio-Niveau. Farben bleiben unverändert (Marken-Verlauf + Dark Theme).
   Neu: Display-Serife "Fraunces" für Überschriften, feinere Typografie,
   ruhigere Abstände, atmosphärischer Hintergrund, edlere Komponenten.
   ═══════════════════════════════════════════════════════════════════ */

/* ── Display-Schrift (selbst gehostet, DSGVO-konform) ── */
@font-face{
  font-family:'Outfit';
  font-style:normal; font-weight:600;
  font-display:swap;
  src:url('fonts/outfit-600.woff2') format('woff2');
}
@font-face{
  font-family:'Outfit';
  font-style:normal; font-weight:700;
  font-display:swap;
  src:url('fonts/outfit-700.woff2') format('woff2');
}

:root{
  --font-head:'Outfit', 'Inter', system-ui, sans-serif;
  --shadow-soft: 0 18px 50px rgba(0,0,0,.45);
  --shadow-card: 0 1px 0 rgba(255,255,255,.04) inset, 0 14px 40px rgba(0,0,0,.35);
  --ease: cubic-bezier(.22,.61,.36,1);
}

/* ── Atmosphäre: ruhige Verlauf-Schleier + feine Körnung, hinter allem ── */
body::before{
  content:''; position:fixed; inset:0; z-index:-2; pointer-events:none;
  background:
    radial-gradient(70vw 70vw at var(--mx, 75%) var(--my, 12%), rgba(200,100,255,.17) 0%, rgba(200,100,255,.10) 30%, rgba(200,100,255,.03) 55%, transparent 76%),
    radial-gradient(74vw 74vw at 80% -8%, rgba(200,100,255,.24) 0%, rgba(200,100,255,.12) 38%, rgba(200,100,255,.035) 62%, transparent 82%),
    radial-gradient(66vw 66vw at 10% 6%, rgba(255,110,180,.19) 0%, rgba(255,110,180,.09) 40%, rgba(255,110,180,.03) 62%, transparent 78%),
    radial-gradient(84vw 64vw at 50% 118%, rgba(255,184,108,.15) 0%, rgba(255,184,108,.06) 45%, transparent 80%);
}
body::after{
  content:''; position:fixed; inset:0; z-index:-1; pointer-events:none; opacity:.035;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='180' height='180'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.95' numOctaves='2' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E");
}

/* ═══ TYPOGRAFIE ═══ */
.hero h1,
.section-title,
.about-text h3,
.cta-band h2{
  font-family:var(--font-head) !important;
  font-weight:700;
  letter-spacing:-.025em;
}

.hero h1{
  font-size:clamp(2.9rem, 6.2vw, 5.2rem);
  line-height:1.02;
  letter-spacing:-.025em;
}
.section-title{
  font-size:clamp(2.05rem, 4vw, 3.3rem);
  line-height:1.07;
}
.section-desc{
  font-size:clamp(1.02rem, 1.4vw, 1.18rem);
  line-height:1.7;
  color:var(--text-secondary);
}

/* Eyebrow / Section-Label edler: getrackte Versalien mit Verlaufs-Strich */
.section-label{
  display:inline-flex; align-items:center; gap:10px;
  font-family:var(--font-body);
  text-transform:uppercase; letter-spacing:.22em;
  font-size:.74rem; font-weight:600;
  color:var(--text-secondary);
}
.section-label::before{
  content:''; width:26px; height:2px; border-radius:2px;
  background:var(--accent-gradient);
}

/* ═══ BUTTONS ═══ */
/* Haupt-Button: dunkles Glas mit feinem Verlaufs-Rand (edel, ruhig).
   Beim Hover füllt sich der Verlauf sanft. */
.btn-primary{
  border-radius:100px !important;
  padding:16px 32px !important;
  font-weight:600 !important;
  letter-spacing:.01em;
  color:var(--text-primary) !important;
  border:2.5px solid transparent !important;
  background:
    linear-gradient(#15151a,#15151a) padding-box,
    linear-gradient(135deg,#c864ff 0%,#ff6eb4 50%,#ffb86c 100%) border-box !important;
  box-shadow:none !important;
  transition:transform .35s var(--ease), box-shadow .35s var(--ease), background .4s var(--ease), color .35s var(--ease);
}
.btn-primary:hover{
  transform:translateY(-3px);
  color:#fff !important;
  background:
    linear-gradient(135deg,#c864ff 0%,#ff6eb4 50%,#ffb86c 100%) padding-box,
    linear-gradient(135deg,#c864ff 0%,#ff6eb4 50%,#ffb86c 100%) border-box !important;
  box-shadow:0 10px 26px rgba(0,0,0,.40) !important;
}
/* Zweit-Button: Ghost – nur Text + Pfeil, kein Rahmen/Fläche.
   Klar untergeordnet zum Haupt-Button, beim Hover Markenfarbe + Pfeil wandert. */
.btn-secondary{
  background:none !important;
  border:none !important;
  border-radius:0 !important;
  box-shadow:none !important;
  color:var(--text-primary) !important;
  padding:16px 12px !important;
  display:inline-flex !important; align-items:center; gap:8px;
  transition:color .25s var(--ease), transform .25s var(--ease) !important;
}
.btn-secondary:hover{
  background:none !important;
  color:var(--accent) !important;
  transform:translateX(3px);
}

/* ═══ HERO ═══ */
.hero-badge{
  backdrop-filter:blur(12px);
  -webkit-backdrop-filter:blur(12px);
  border:1px solid var(--border-light);
  background:rgba(255,255,255,.04);
}
.hero-sub{
  font-size:clamp(1.05rem, 1.5vw, 1.25rem);
  line-height:1.7;
  color:var(--text-secondary);
  max-width:620px;
}

/* Kleine Feature-Chips ruhiger */
.service-feature{
  border:1px solid var(--border) !important;
  background:rgba(255,255,255,.03) !important;
  border-radius:100px !important;
  letter-spacing:.01em;
}
/* Hero-Vertrauens-Pillen ausblenden (Desktop + Mobil) – die Textzeile genügt */
.hero .service-feature{ display:none !important; }

/* ═══ KARTEN (Vorteile, Leistungen, Pakete, Bewertungen) ═══ */
.usp-card, .service-card, .package-card, .review-card, .portfolio-item{
  border-radius:var(--radius-lg) !important;
  transition:transform .4s var(--ease), border-color .4s var(--ease), box-shadow .4s var(--ease) !important;
}
.usp-card:hover, .service-card:hover, .review-card:hover{
  transform:translateY(-5px);
  border-color:var(--border-light) !important;
  box-shadow:var(--shadow-card);
}

/* Icon-Kacheln edler: Verlaufs-Rahmen statt nacktem Linien-Icon */
.usp-icon, .service-icon{
  display:inline-flex; align-items:center; justify-content:center;
  width:58px; height:58px; border-radius:16px;
  background:var(--accent-soft);
  border:1px solid rgba(200,100,255,.22);
  box-shadow:0 8px 24px rgba(200,100,255,.12);
}
.usp-icon svg, .service-icon svg{ width:26px; height:26px; }

/* ═══ PORTFOLIO (Startseite) – Symbol-Kacheln aufwerten ═══ */
#portfolio .portfolio-thumb svg{
  width:44px; height:44px;
  padding:16px; box-sizing:content-box;
  border-radius:18px;
  background:rgba(255,255,255,.04);
  border:1px solid var(--border-light);
}

/* ═══ ABSCHNITTS-RHYTHMUS etwas großzügiger ═══ */
.section-header{ margin-bottom:clamp(40px, 5vw, 64px); }

/* Trennlinien als zarter Verlauf statt harter Kante */
.section[style*="border-top"], .cta-band{ position:relative; }

/* Feinschliff: ausgewählter Text in Markenfarbe */
::selection{ background:rgba(200,100,255,.28); color:#fff; }

/* ═══ ZUGÄNGLICHKEIT & BEWEGUNG ═══ */
:focus-visible{ outline:2px solid var(--accent); outline-offset:3px; border-radius:6px; }
@media (prefers-reduced-motion: reduce){
  *,*::before,*::after{
    animation-duration:.01ms !important; animation-iteration-count:1 !important;
    transition-duration:.01ms !important; scroll-behavior:auto !important;
  }
}

/* ═══ HERO-ÜBERSCHRIFT: einheitliche Größe auf ALLEN Seiten ═══
   (kein JS-Shrinking mehr; eine Größe für alle, passt auch den längsten Titel) */
.hero h1{ font-size:clamp(2.05rem, 4vw, 3.3rem) !important; overflow-wrap:break-word; }

/* ═══════════════════════════════════════════════════════
   MOBILE-FEINSCHLIFF  (≤ 768px) – lesbar & bedienbar
   ═══════════════════════════════════════════════════════ */
@media (max-width:768px){
  /* Gut tappbare Navigation (≥ 48px Trefferfläche) */
  .nav-links a,
  .nav-dropdown-toggle,
  .nav-dropdown-menu a{
    min-height:48px; display:flex; align-items:center;
  }

  /* Ruhigerer Abschnitts-Rhythmus auf dem Handy */
  .section{ padding-top:clamp(54px,12vw,88px); padding-bottom:clamp(54px,12vw,88px); }
  .section-header{ margin-bottom:30px; }
  .hero-sub{ font-size:1.05rem; }

  /* Aktionsbuttons volle Breite, leicht zu treffen */
  .hero-buttons{ flex-direction:column; align-items:stretch; width:100%; gap:12px; }
  .hero-buttons .btn-primary,
  .hero-buttons .btn-secondary{ width:100%; justify-content:center; text-align:center; }

  /* Hero-Logo & Vertrauens-Chips bleiben sichtbar – wie im Original */
}

/* ═══ Sehr schmale Geräte (≤ 400px) ═══ */
@media (max-width:400px){
  .hero h1{ font-size:2.1rem; line-height:1.07; }
  .container{ padding-left:18px; padding-right:18px; }
}

/* ═══════════════════════════════════════════════════════
   MARKEN-VERLAUF EDLER EINSETZEN
   Statt den Text komplett mit Verlauf zu füllen (wirkt nach „KI"),
   wird die Schrift solide (hell) und der Verlauf erscheint nur als
   feiner Unterstrich-Akzent unter dem Schlüsselwort.
   ═══════════════════════════════════════════════════════ */
.gradient-text{
  -webkit-text-fill-color:var(--text-primary) !important;
  color:var(--text-primary) !important;
  text-decoration:none !important;
  padding-bottom:.06em;
  /* Verlaufs-Unterstrich als feiner Balken (höher angesetzt) */
  background-image:linear-gradient(135deg,#c864ff 0%,#ff6eb4 55%,#ffb86c 100%) !important;
  background-repeat:no-repeat !important;
  background-size:100% .07em !important;
  background-position:0 1.07em !important;
  -webkit-background-clip:border-box !important;
  background-clip:border-box !important;
  -webkit-box-decoration-break:clone;
  box-decoration-break:clone;
  /* Aussparung an den Unterlängen (g, j, p): die Hintergrundfarbe rund um die
     Glyphen "stanzt" Lücken in die Linie – so bleibt der Verlauf erhalten. */
  text-shadow:
    .04em 0 0 var(--bg-primary), -.04em 0 0 var(--bg-primary),
    .04em .02em 0 var(--bg-primary), -.04em .02em 0 var(--bg-primary),
    0 .02em 0 var(--bg-primary);
}

/* ═══ PREIS-TABS: gleicher edler Stil wie der Button ═══
   Aktiver Tab = leicht erhöhter dunkler Pill mit feinem Verlaufs-Rand,
   statt vollflächigem Verlauf. */
.pricing-tab.active{
  background:
    linear-gradient(var(--bg-card-hover),var(--bg-card-hover)) padding-box,
    linear-gradient(135deg,#c864ff 0%,#ff6eb4 50%,#ffb86c 100%) border-box !important;
  border:2px solid transparent !important;
  color:var(--text-primary) !important;
  box-shadow:none !important;
}
.pricing-tab{ transition:color .25s var(--ease), background .25s var(--ease); }

/* Desktop: alle drei Tabs gleich breit (gleichmäßiges Raster) */
@media (min-width:769px){
  .pricing-tabs{ display:grid !important; grid-auto-flow:column; grid-auto-columns:1fr; }
  .pricing-tab{ text-align:center; justify-content:center; }
}

/* Untere Tab-Leiste: gleicher Abstand zur Liste wie oben (nicht zu eng) */
#preise .pricing-tabs-bottom{ margin-top:48px; }

/* ═══ Block-Überschriften innerhalb eines Preis-Bereichs (Einzelpreise/Pakete/Abo) ═══ */
#preise .price-block-title{
  font-family:var(--font-display);
  font-size:1.2rem;
  font-weight:700;
  letter-spacing:-0.01em;
  color:var(--text-primary);
  margin:46px 0 20px;
  display:flex;
  align-items:center;
  gap:11px;
}
#preise .price-block-title::before{
  content:'';
  width:20px;
  height:3px;
  border-radius:3px;
  background:linear-gradient(135deg,#c864ff 0%,#ff6eb4 50%,#ffb86c 100%);
}
/* Erster Block direkt unter den Bereichs-Tabs: kein doppelter Abstand */
#preise .pricing-panel > .price-block-title:first-child{ margin-top:28px; }
/* Hinweis unter den Abo-Karten */
#preise .abo-note{ color:var(--text-muted); font-size:0.85rem; margin-top:20px; }

/* ═══ Boxen im Glas-Stil der Navileiste (Desktop + Mobil) ═══ */
@media (min-width:0px){
  #leistungen .service-card,
  #preise .package-card:not(.featured),
  #preise .flatrate-card,
  #preise .pricing-tabs,
  #preise .pricing-note,
  #bewertungen .review-card,
  #portfolio a.portfolio-item,
  #ueber .about-detail{
    background: rgba(22,22,26,0.55) !important;
    -webkit-backdrop-filter: blur(20px) saturate(160%);
    backdrop-filter: blur(20px) saturate(160%);
    border: 1px solid rgba(255,255,255,0.10) !important;
    box-shadow: 0 8px 32px rgba(0,0,0,0.30);
  }
  /* Hervorgehobenes Paket: Glas-Füllung + weiterhin Verlaufs-Rand */
  #preise .package-card.featured{
    background:
      linear-gradient(rgba(24,24,28,0.62),rgba(24,24,28,0.62)) padding-box,
      linear-gradient(135deg,#c864ff 0%,#ff6eb4 50%,#ffb86c 100%) border-box !important;
    -webkit-backdrop-filter: blur(20px) saturate(160%);
    backdrop-filter: blur(20px) saturate(160%);
  }
}

/* „Warum Colora Design?" – die Boxen auf dem Handy ebenfalls im Glas-Stil
   (auf dem Desktop bleibt es die ruhige Liste). */
@media (max-width:768px){
  #warum .usp-card{
    background: rgba(22,22,26,0.55) !important;
    -webkit-backdrop-filter: blur(20px) saturate(160%);
    backdrop-filter: blur(20px) saturate(160%);
    border: 1px solid rgba(255,255,255,0.10) !important;
    box-shadow: 0 8px 32px rgba(0,0,0,0.30);
  }
}

/* Kontaktformular: dunkler/grauer Hintergrund weg, Formular in Glasoptik (Desktop + Mobil) */
.contact-section{ background:transparent !important; border-top:none !important; }
.contact-form{
  background: rgba(22,22,26,0.55) !important;
  -webkit-backdrop-filter: blur(20px) saturate(160%);
  backdrop-filter: blur(20px) saturate(160%);
  border: 1px solid rgba(255,255,255,0.10) !important;
  box-shadow: 0 8px 32px rgba(0,0,0,0.30);
}

/* ═══ „Warum Colora Design?" – ruhige Editorial-Liste (ohne Ziffern) ═══ */
.usp-num{ display:none !important; }
/* Diese Zeilen sind NICHT klickbar – also keinerlei Hover-Effekt vortäuschen */
#warum .usp-card{ cursor:default; }
#warum .usp-card::before{ display:none !important; }
#warum .usp-card:hover{ background:transparent !important; transform:none !important; box-shadow:none !important; border-color:var(--border) !important; }
@media (min-width:769px){
  #warum .usp-grid{ display:flex; flex-direction:column; gap:0; max-width:940px; margin:0 auto; }
  #warum .usp-card{
    display:grid; grid-template-columns:58px 1fr; grid-template-rows:auto auto;
    column-gap:26px; row-gap:6px; align-items:center;
    background:transparent !important; border:none !important;
    border-top:1px solid var(--border) !important; border-radius:0 !important;
    padding:32px 6px !important;
  }
  #warum .usp-card:last-child{ border-bottom:1px solid var(--border) !important; }
  #warum .usp-card .usp-icon{ grid-column:1; grid-row:1 / span 2; align-self:center; }
  #warum .usp-card h3{ grid-column:2; grid-row:1; margin:0; }
  #warum .usp-card p{ grid-column:2; grid-row:2; margin:0; max-width:600px; }
}

/* ═══ Bewertungs-Karten: Name/Quelle unten bündig auf gleicher Höhe ═══ */
#bewertungen .reviews-grid{ align-items:stretch; }
#bewertungen .review-card{ display:flex; flex-direction:column; }
#bewertungen .review-card .review-author{ margin-top:auto; padding-top:18px; }

/* ═══ „Was ich für dich gestalte" – kompaktere Leistungs-Karten ═══ */
#leistungen a.service-card{ display:block; text-decoration:none; color:inherit; }
#leistungen .service-card{ padding:26px 24px !important; }
#leistungen .service-icon{ width:44px !important; height:44px !important; margin-bottom:16px; }
#leistungen .service-card h3{ font-size:1.1rem !important; margin-bottom:10px; }
#leistungen .service-card > p{ font-size:.9rem !important; margin-bottom:16px; text-align:justify; hyphens:auto; -webkit-hyphens:auto; }
#leistungen .service-feature{ font-size:.74rem !important; padding:5px 10px !important; }
@media (min-width:1000px){
  #leistungen .services-grid{ grid-template-columns:repeat(4,1fr) !important; gap:18px; }
}
@media (min-width:620px) and (max-width:999px){
  #leistungen .services-grid{ grid-template-columns:repeat(2,1fr) !important; }
}
/* Leistungs-Sektionen mit GENAU 3 Karten (Unterseiten) mittig zentrieren –
   statt linksbündig mit leerer Spalte rechts. Startseite (5) & App (4) bleiben 4-spaltig. */
@media (min-width:1000px){
  #leistungen .services-grid:has(> .service-card:nth-child(3):last-child){
    grid-template-columns:repeat(3, minmax(0, 340px)) !important;
    justify-content:center;
  }
}

/* ═══ Portfolio-Karten kompakt – im selben Stil wie die Leistungs-Karten ═══ */
@media (min-width:1000px){
  #portfolio .portfolio-grid{ grid-template-columns:repeat(4,1fr) !important; gap:18px; }
}
@media (min-width:620px) and (max-width:999px){
  #portfolio .portfolio-grid{ grid-template-columns:repeat(2,1fr) !important; }
}
#portfolio a.portfolio-item{ padding:26px 24px; display:flex; flex-direction:column; text-decoration:none; color:inherit; }
#portfolio .portfolio-info{ display:flex; flex-direction:column; flex:1; }
#portfolio .portfolio-view{
  margin-top:auto !important; padding-top:14px;
  display:inline-flex; align-items:center; gap:7px;
  font-size:.9rem; font-weight:600; letter-spacing:.01em;
  color:var(--text-secondary); transition:color .25s var(--ease), transform .25s var(--ease);
}
#portfolio .portfolio-item:hover .portfolio-view{ color:var(--accent); transform:translateX(4px); }
#portfolio .portfolio-thumb{
  aspect-ratio:auto !important; width:auto !important; min-height:0 !important;
  background:none !important; display:inline-flex !important; justify-content:flex-start !important;
  padding:0 !important; margin:0 0 16px 0 !important;
}
#portfolio .portfolio-thumb::after{ display:none !important; }
#portfolio .portfolio-thumb svg{ width:22px !important; height:22px !important; padding:13px !important; }
#portfolio .portfolio-info{ padding:0 !important; }
#portfolio .portfolio-info h4{ font-size:1.1rem !important; margin-bottom:8px; }
#portfolio .portfolio-info p{ font-size:.9rem !important; text-align:justify; hyphens:auto; -webkit-hyphens:auto; }

/* ═══ „Über mich" – Detail-Boxen: Icon-Kacheln (wie die anderen) + Blocksatz ═══ */
.about-icon{
  width:46px; height:46px; border-radius:14px;
  background:var(--accent-soft); border:1px solid rgba(200,100,255,.22);
  display:inline-flex; align-items:center; justify-content:center;
  margin-bottom:16px; box-shadow:0 8px 24px rgba(200,100,255,.12);
}
.about-icon svg{ width:24px; height:24px; stroke:var(--accent); fill:none; stroke-width:1.8; stroke-linecap:round; stroke-linejoin:round; }
#ueber .about-detail p{ text-align:justify; hyphens:auto; -webkit-hyphens:auto; }
#ueber .about-text p{ text-align:justify; hyphens:auto; -webkit-hyphens:auto; }

/* ═══════════════════════════════════════════════════════
   PREISE & PAKETE – Premium-Politur
   ═══════════════════════════════════════════════════════ */
/* Einzelpreise-Tabelle: mehr Luft, klarer Zeilen-Hover, Preis kräftig */
#preise .price-table td{ padding:18px 26px !important; }
#preise .price-value{ font-size:1rem; }
/* Einzelpreise-Tabelle edler (Desktop): Zebra, feiner lila Hover, mehr Luft */
@media (min-width:769px){
  #preise .price-table td{ padding:20px 28px !important; }
  /* Alle Zeilen gleicher Hintergrund (kein Zebra) – nur dezenter Hover */
  #preise .price-table tbody tr td{ background:transparent !important; }
  #preise .price-table tbody tr:hover td{ background:rgba(200,100,255,.06) !important; }
}

/* Paket-/Abo-Karten: Karte selbst nicht „klickbar" wirken lassen –
   die Aktion ist der CTA-Button. Kein Anheben, keine Hover-Linie. */
#preise .package-card, #preise .flatrate-card{ display:flex; flex-direction:column; }
#preise .package-card::before, #preise .flatrate-card::before{ display:none !important; }
#preise .package-card:hover, #preise .flatrate-card:hover{ transform:none !important; }
#preise .package-card:hover{ border-color:rgba(255,255,255,.10) !important; }
#preise .flatrate-card:hover{ border-color:rgba(255,255,255,.10) !important; }

/* Alle Preise einheitlich HELL (kein Verlaufs-Fill, kein Lila) */
#preise .package-price,
#preise .flatrate-price,
#preise .price-value{
  background:none !important;
  -webkit-text-fill-color:var(--text-primary) !important;
  color:var(--text-primary) !important;
}
#preise .flatrate-price span{
  -webkit-text-fill-color:var(--text-muted) !important;
  color:var(--text-muted) !important;
}
/* Pakete & Abo: einheitliche Schriftgrößen (Titel + Preis) */
#preise .package-card h3, #preise .flatrate-card h3{ font-size:1.3rem !important; }
#preise .package-price, #preise .flatrate-price{ font-size:2rem !important; }
#preise .package-features li, #preise .flatrate-card ul li{ font-size:.92rem !important; }

/* Hervorgehobenes Paket: feiner Verlaufs-Rand (wie Button/Tab) statt grellem Hervorheben */
#preise .package-card.featured{
  border:2px solid transparent !important;
  background:linear-gradient(#161618,#161618) padding-box,
             linear-gradient(135deg,#c864ff 0%,#ff6eb4 50%,#ffb86c 100%) border-box !important;
}
#preise .package-card.featured:hover{ border-color:transparent !important; }

/* CTA-Button in den Karten: kompakter, volle Breite, unten bündig ausgerichtet */
#preise .pkg-cta{ width:100%; margin-top:auto; padding:13px 22px !important; font-size:.95rem; }
#preise .package-features, #preise .flatrate-card ul{ margin-bottom:22px; }

/* Abo-Karten genau wie Pakete: Icon oben, gleiche Polsterung, Häkchen-Listen */
#preise .flatrate-card{ padding:40px 34px; }
#preise .flatrate-card ul{ list-style:none; padding:0; }
#preise .flatrate-card ul li{ padding:8px 0; font-size:.9rem; color:var(--text-secondary); display:flex; align-items:flex-start; gap:10px; text-align:left; }
#preise .flatrate-card ul li::before{ content:'✓'; color:var(--accent); font-weight:700; flex-shrink:0; }

/* ═══════════════════════════════════════════════════════
   KONTAKT – Kompakt-Modus für Paket-/Abo-Anfragen
   (gleiches Formular, Briefing-Felder ausgeblendet)
   ═══════════════════════════════════════════════════════ */
.compact-note{ display:none; }
#kontakt.selection .compact-note{
  display:flex; flex-wrap:wrap; align-items:center; gap:8px 14px;
  background:var(--accent-soft); border:1px solid rgba(200,100,255,.22);
  border-radius:var(--radius-md); padding:14px 18px; margin-bottom:24px;
  font-size:.95rem; color:var(--text-primary);
}
.compact-exit, .sel-clear{ background:none; border:none; color:var(--accent); cursor:pointer; font:inherit; padding:0; text-decoration:underline; }
#kontakt.compact .form-group:has([name="unternehmen"]),
#kontakt.compact .form-group:has([name="website"]),
#kontakt.compact .form-group:has([name="leistung"]),
#kontakt.compact .form-group:has([name="stil"]),
#kontakt.compact .form-group:has([name="farben"]),
#kontakt.compact .form-group:has([name="zielgruppe"]),
#kontakt.compact .form-group:has([name="budget"]),
#kontakt.compact .form-group:has([name="deadline"]),
#kontakt.compact .form-group:has([name="quelle"]),
#kontakt.compact .form-group:has([name="anmerkungen"]),
#kontakt.compact .form-group:has([name="datei"]){ display:none !important; }

/* ═══════════════════════════════════════════════════════
   MOBILE-NACHBESSERUNGEN
   ═══════════════════════════════════════════════════════ */
@media (max-width:768px){
  /* Großes Hero-Logo auf dem Handy (nochmal 10 % kleiner: 180 → 162 px) */
  .hero .hero-logo{ display:block !important; width:162px !important; height:162px !important; margin:0 auto 22px !important; }

  /* Hero: Headline & Texte linksbündig (Block bleibt im zentrierten Layout), Logo bleibt mittig */
  .hero-content{ align-items:flex-start !important; text-align:left !important; }
  .hero-badge{ align-self:center; }
  .hero h1{ text-align:left !important; }
  .hero-sub{ text-align:justify !important; margin-left:0 !important; hyphens:auto; -webkit-hyphens:auto; }

  /* „Alle Texte wenn möglich Blocksatz" – Fließtexte auf dem Handy */
  .section-desc, .review-text, .intro-text p, .package-desc{
    text-align:justify; hyphens:auto; -webkit-hyphens:auto;
  }

  /* Navi-Symbol oben links erst einblenden, wenn das große Logo weggescrollt ist */
  .nav-logo-mark{ opacity:0; transform:scale(.6); transition:opacity .35s ease, transform .35s ease; }
  body.show-nav-mark .nav-logo-mark{ opacity:1; transform:scale(1); }
  /* Solange das Symbol versteckt ist, rückt der Schriftzug nach links – aber nur so weit,
     dass er auf Höhe des Seiteninhalts sitzt (nicht ganz an den Rand). */
  .nav-logo-text{ transform:translateX(-53px); transition:transform .35s ease; }
  body.show-nav-mark .nav-logo-text{ transform:translateX(0); }

  /* Kein weißer Strich an der Navi beim Scrollen */
  .nav{ border-bottom:none !important; }
  .nav.scrolled{ border-bottom:none !important; background:#0a0a0a !important; }

  /* „Warum Colora Design?" – Boxen kompakter & einspaltig, wie die Leistungs-Boxen */
  #warum .usp-grid{ grid-template-columns:1fr !important; gap:16px; }
  #warum .usp-card{ padding:24px 22px !important; }
  #warum .usp-icon{ width:44px !important; height:44px !important; margin-bottom:14px !important; }
  #warum .usp-card h3{ font-size:1.08rem !important; margin-bottom:8px; }
  #warum .usp-card p{ font-size:.9rem !important; }

  /* Einzelpreise-Tabelle mobil: 2/3 Text links, 1/3 Preis rechts – in einer Zeile,
     mit etwas Luft zum Rand. */
  #preise .price-table thead{ display:none; }
  #preise .price-table,
  #preise .price-table tbody{ display:block; width:auto; }
  #preise .price-table tr{
    display:flex;
    align-items:baseline;
    gap:14px;
    padding:14px 8px;
    border-bottom:1px solid var(--border);
  }
  #preise .price-table tr:hover td{ background:transparent !important; }
  #preise .price-table td{
    display:block;
    padding:0 !important; border:none !important;
    hyphens:manual !important; -webkit-hyphens:manual !important;
    word-break:normal !important; overflow-wrap:normal !important; white-space:normal !important;
  }
  /* Zwei Drittel für den Text */
  #preise .price-table td:first-child{ flex:0 0 66%; max-width:66%; }
  /* Letztes Drittel für den Preis, rechtsbündig */
  #preise .price-table td.price-value{
    flex:1 1 auto; text-align:right; white-space:nowrap !important; margin-top:0 !important;
  }
}

/* ═══ „Alles aus einer Hand" – Glas-Karten wie bei Leistungen/Preisen ═══ */
#kombination a.service-card{ display:block; text-decoration:none; color:inherit; }
#kombination .service-card{
  padding:26px 24px !important;
  background: rgba(22,22,26,0.55) !important;
  -webkit-backdrop-filter: blur(20px) saturate(160%);
  backdrop-filter: blur(20px) saturate(160%);
  border: 1px solid rgba(255,255,255,0.10) !important;
  box-shadow: 0 8px 32px rgba(0,0,0,0.30);
}
#kombination .service-icon{ width:44px !important; height:44px !important; margin-bottom:16px; }
#kombination .service-card h3{ font-size:1.1rem !important; margin-bottom:10px; }
#kombination .service-card > p{ font-size:.9rem !important; margin-bottom:16px; text-align:justify; hyphens:auto; -webkit-hyphens:auto; }
#kombination .service-feature{ font-size:.74rem !important; padding:5px 10px !important; }
@media (min-width:620px){
  #kombination .services-grid{ grid-template-columns:repeat(3,1fr) !important; gap:18px; }
}
#kombination .service-card:hover{ border-color:rgba(255,255,255,0.18) !important; transform:translateY(-4px); }

/* ═══ Formularfelder im dunklen Glasdesign (wie die Navi-Pille) ═══ */
.contact-form .form-input,
.contact-form .form-select,
.contact-form .form-textarea,
.contact-form .date-overlay{
  background-color:rgba(20,20,24,0.5) !important;
  -webkit-backdrop-filter:blur(16px) saturate(170%);
  backdrop-filter:blur(16px) saturate(170%);
  border:1px solid rgba(255,255,255,0.12) !important;
  box-shadow:0 1px 0 rgba(255,255,255,0.04) inset, 0 6px 18px rgba(0,0,0,0.18);
}
.contact-form .form-input:focus,
.contact-form .form-select:focus,
.contact-form .form-textarea:focus,
.contact-form .date-wrapper:focus-within .date-overlay{
  border-color:rgba(200,100,255,0.55) !important;
  box-shadow:0 0 0 3px rgba(200,100,255,0.18) !important;
  background-color:rgba(28,26,34,0.62) !important;
}
.contact-form .form-input::placeholder,
.contact-form .form-textarea::placeholder{ color:rgba(245,245,247,0.42); }

/* Dropdown: lila Pfeil + dunkle, lesbare Optionsliste passend zum Design */
.contact-form .form-select{
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='8'%3E%3Cpath d='M1 1l5 5 5-5' stroke='%23c864ff' stroke-width='1.7' fill='none'/%3E%3C/svg%3E") !important;
  background-repeat:no-repeat !important;
  background-position:right 16px center !important;
}
.contact-form .form-select option{ background:#14141a; color:#f5f5f7; }
.contact-form .form-select option:checked{ background:#2a1830; color:#fff; }

/* Datei-Feld: flexible Höhe + Button vertikal zentriert (statt fester 48px,
   wodurch der Button mit dem Inline-Padding aus dem Feld ragte). */
.contact-form input[type="file"].form-input{
  height:auto !important;
  min-height:48px;
  display:flex; align-items:center;
  padding:8px 12px !important;
}

/* Datei-Auswahl-Button im selben dunklen Glas-Stil */
.contact-form input[type="file"].form-input::-webkit-file-upload-button,
.contact-form input[type="file"].form-input::file-selector-button{
  background:rgba(255,255,255,0.06);
  color:var(--text-secondary);
  border:1px solid rgba(255,255,255,0.14);
  border-radius:8px;
  padding:7px 14px;
  margin-right:12px;
  cursor:pointer;
  font-family:var(--font-body);
  transition:border-color .2s, background .2s;
}
.contact-form input[type="file"].form-input::-webkit-file-upload-button:hover,
.contact-form input[type="file"].form-input::file-selector-button:hover{
  border-color:rgba(200,100,255,0.5);
  background:rgba(200,100,255,0.12);
}

/* ═══ Formular-Abschnittsüberschriften ("Kontaktdaten" / "Zur Anfrage") ═══ */
.form-section-head{
  grid-column:1 / -1;
  margin:24px 0 14px;
  font-size:0.78rem; font-weight:700; letter-spacing:1.2px; text-transform:uppercase;
  color:var(--accent);
  display:flex; align-items:center; gap:12px;
}
.form-section-head::after{
  content:''; flex:1; height:1px;
  background:linear-gradient(to right, rgba(200,100,255,0.4), rgba(255,255,255,0.05));
}
.form-section-head:first-child{ margin-top:0; }

/* ═══ Custom-Dropdown (glasiges Aufklappmenü statt nativem <select>) ═══ */
.cd{ position:relative; }
/* Natives Select bleibt als Wertträger, ist aber unsichtbar hinter dem Trigger. */
.cd select.form-select{
  position:absolute; inset:0; width:100%; height:100%;
  margin:0; opacity:0; pointer-events:none;
}
.cd-trigger{
  width:100%; height:48px;
  display:flex; align-items:center; justify-content:space-between; gap:10px;
  padding:0 16px 0 18px; text-align:left;
  background-color:rgba(20,20,24,0.5);
  -webkit-backdrop-filter:blur(16px) saturate(170%);
  backdrop-filter:blur(16px) saturate(170%);
  border:1px solid rgba(255,255,255,0.12);
  border-radius:var(--radius-md);
  color:var(--text-primary); font-family:var(--font-body); font-size:0.92rem;
  cursor:pointer;
  box-shadow:0 1px 0 rgba(255,255,255,0.04) inset, 0 6px 18px rgba(0,0,0,0.18);
  transition:border-color .2s, box-shadow .2s, background .2s;
}
.cd-value{ overflow:hidden; text-overflow:ellipsis; white-space:nowrap; }
.cd-placeholder .cd-value{ color:rgba(245,245,247,0.5); }
.cd-trigger::after{
  content:''; width:12px; height:8px; flex-shrink:0;
  background:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='8'%3E%3Cpath d='M1 1l5 5 5-5' stroke='%23c864ff' stroke-width='1.7' fill='none'/%3E%3C/svg%3E") no-repeat center;
  background-size:contain;
  transition:transform .25s ease;
}
.cd.open .cd-trigger::after{ transform:rotate(180deg); }
.cd.open .cd-trigger,
.cd-trigger:focus-visible{
  border-color:rgba(200,100,255,0.55);
  box-shadow:0 0 0 3px rgba(200,100,255,0.18);
  outline:none;
}
.cd-panel{
  position:absolute; top:calc(100% + 8px); left:0; right:0; z-index:60;
  background:rgba(18,18,22,0.85);
  -webkit-backdrop-filter:blur(24px) saturate(180%);
  backdrop-filter:blur(24px) saturate(180%);
  border:1px solid rgba(255,255,255,0.12);
  border-radius:14px;
  box-shadow:0 16px 44px rgba(0,0,0,0.5);
  padding:6px; max-height:260px; overflow-y:auto;
  overscroll-behavior:contain;
  opacity:0; transform:translateY(-6px) scale(0.985); transform-origin:top center;
  pointer-events:none;
  transition:opacity .18s ease, transform .18s ease;
}
.cd.open .cd-panel{ opacity:1; transform:none; pointer-events:auto; }
.cd-option{
  display:flex; align-items:center; justify-content:space-between; gap:10px;
  padding:10px 14px; border-radius:9px; cursor:pointer;
  font-size:0.9rem; color:var(--text-secondary);
  transition:background .15s, color .15s;
}
/* Gruppen-Überschrift im Dropdown (Grafikdesign / Webdesign / Apps & Programme)
   – deutlich abgehoben: farbiges Band + Akzent-Balken + helle, fette Schrift */
.cd-group-label{
  display:flex;
  align-items:center;
  gap:9px;
  margin:10px 0 6px;
  padding:9px 13px;
  font-size:0.76rem;
  font-weight:800;
  letter-spacing:0.1em;
  text-transform:uppercase;
  color:#fff;
  background:rgba(200,100,255,0.18);
  border-left:3px solid #c864ff;
  border-radius:0 8px 8px 0;
  pointer-events:none;
}
.cd-group-label:first-child{ margin-top:2px; }
.cd-group-label + .cd-option{ margin-top:3px; }
.cd-option:hover,
.cd-option.active{ background:rgba(200,100,255,0.14); color:#fff; }
.cd-option.selected{ color:#fff; }
.cd-option.selected::after{ content:'✓'; color:var(--accent); font-size:0.85rem; }
.cd-panel::-webkit-scrollbar{ width:8px; }
.cd-panel::-webkit-scrollbar-thumb{ background:rgba(255,255,255,0.16); border-radius:8px; }
.cd-panel::-webkit-scrollbar-track{ background:transparent; }

/* ═══ Custom-Kalender (glasiges Datums-Popup statt nativem Picker) ═══ */
.cal{
  position:absolute; top:calc(100% + 8px); left:0; right:0; z-index:60;
  background:rgba(18,18,22,0.9);
  -webkit-backdrop-filter:blur(24px) saturate(180%);
  backdrop-filter:blur(24px) saturate(180%);
  border:1px solid rgba(255,255,255,0.12);
  border-radius:16px;
  box-shadow:0 16px 44px rgba(0,0,0,0.5);
  padding:14px;
  opacity:0; transform:translateY(-6px) scale(0.985); transform-origin:top center;
  pointer-events:none;
  transition:opacity .18s ease, transform .18s ease;
}
.date-wrapper.cal-open .cal{ opacity:1; transform:none; pointer-events:auto; }
.cal-head{ display:flex; align-items:center; justify-content:space-between; margin-bottom:10px; }
.cal-title{ font-weight:700; color:#f5f5f7; font-size:0.95rem; }
.cal-nav{
  width:32px; height:32px; flex-shrink:0;
  display:flex; align-items:center; justify-content:center;
  border-radius:8px; background:rgba(255,255,255,0.06);
  border:1px solid rgba(255,255,255,0.12); color:var(--text-secondary);
  cursor:pointer; font-size:1.15rem; line-height:1;
  transition:border-color .2s, background .2s, color .2s;
}
.cal-nav:hover:not(:disabled){ border-color:rgba(200,100,255,0.5); background:rgba(200,100,255,0.14); color:#fff; }
.cal-nav:disabled{ opacity:0.3; cursor:default; }
.cal-wd{ display:grid; grid-template-columns:repeat(7,1fr); gap:2px; margin-bottom:4px; }
.cal-wd span{ text-align:center; font-size:0.72rem; color:var(--text-muted); padding:4px 0; }
.cal-grid{ display:grid; grid-template-columns:repeat(7,1fr); gap:2px; }
.cal-day{
  aspect-ratio:1; min-height:34px;
  border:none; background:transparent; color:var(--text-secondary);
  border-radius:9px; cursor:pointer; font-size:0.85rem;
  transition:background .15s, color .15s, box-shadow .15s;
}
.cal-day:hover:not(:disabled){ background:rgba(200,100,255,0.16); color:#fff; }
.cal-day.today{ box-shadow:inset 0 0 0 1px rgba(200,100,255,0.55); color:#fff; }
.cal-day.sel{ background:var(--accent); color:#fff; }
.cal-day.past{ opacity:0.25; cursor:default; }

/* ═══ Custom-Farbwähler (Glas-Palette mit Mehrfachauswahl + HEX-Eingabe) ═══ */
.cp{ position:relative; }
.cp-trigger{
  width:100%; min-height:48px;
  display:flex; align-items:center; justify-content:space-between; gap:10px;
  padding:0 16px 0 18px; text-align:left;
  background-color:rgba(20,20,24,0.5);
  -webkit-backdrop-filter:blur(16px) saturate(170%);
  backdrop-filter:blur(16px) saturate(170%);
  border:1px solid rgba(255,255,255,0.12);
  border-radius:var(--radius-md);
  color:var(--text-primary); font-family:var(--font-body); font-size:0.92rem;
  cursor:pointer;
  box-shadow:0 1px 0 rgba(255,255,255,0.04) inset, 0 6px 18px rgba(0,0,0,0.18);
  transition:border-color .2s, box-shadow .2s, background .2s;
}
.cp-trigger::after{
  content:''; width:12px; height:8px; flex-shrink:0;
  background:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='8'%3E%3Cpath d='M1 1l5 5 5-5' stroke='%23c864ff' stroke-width='1.7' fill='none'/%3E%3C/svg%3E") no-repeat center;
  background-size:contain; transition:transform .25s ease;
}
.cp.open .cp-trigger::after{ transform:rotate(180deg); }
.cp.open .cp-trigger, .cp-trigger:focus-visible{
  border-color:rgba(200,100,255,0.55); box-shadow:0 0 0 3px rgba(200,100,255,0.18); outline:none;
}
.cp-trigger-val{ display:flex; align-items:center; gap:6px; flex-wrap:wrap; }
.cp-empty .cp-trigger-val{ color:rgba(245,245,247,0.5); }
.cp-dot{ width:16px; height:16px; border-radius:50%; box-shadow:inset 0 0 0 1px rgba(255,255,255,0.25); }
.cp-count{ font-size:0.82rem; color:var(--text-secondary); margin-left:4px; }

/* Umschalter Wunschfarben / Zu vermeiden */
.cp-modes{
  display:flex; gap:6px; margin-bottom:12px; padding:4px;
  background:rgba(255,255,255,0.05); border:1px solid rgba(255,255,255,0.1); border-radius:10px;
}
.cp-mode{
  flex:1; padding:8px 6px; border:none; background:transparent; color:var(--text-secondary);
  border-radius:7px; cursor:pointer; font-size:0.82rem; font-family:var(--font-body);
  transition:background .15s, color .15s;
}
.cp-mode.active{ background:rgba(200,100,255,0.22); color:#fff; }
.cp-avoid .cp-mode.active{ background:rgba(255,90,90,0.24); }
/* Im "vermeiden"-Modus alles rot statt lila markieren */
.cp-avoid .cp-chip{ border-color:rgba(255,90,90,0.45); }
.cp-avoid .cp-swatch.on{ box-shadow:0 0 0 2px rgba(18,18,22,0.9), 0 0 0 4px #ff5a5a; }

/* Mobil: weniger Spalten -> größere, besser tippbare Farbfelder */
@media (max-width:768px){
  .cp-palette{ grid-template-columns:repeat(8,1fr) !important; gap:8px !important; }
}

.cp-panel{
  position:absolute; top:calc(100% + 8px); left:0; right:0; z-index:60;
  background:rgba(18,18,22,0.9);
  -webkit-backdrop-filter:blur(24px) saturate(180%);
  backdrop-filter:blur(24px) saturate(180%);
  border:1px solid rgba(255,255,255,0.12); border-radius:16px;
  box-shadow:0 16px 44px rgba(0,0,0,0.5); padding:14px;
  opacity:0; transform:translateY(-6px) scale(0.985); transform-origin:top center;
  pointer-events:none; transition:opacity .18s ease, transform .18s ease;
}
.cp.open .cp-panel{ opacity:1; transform:none; pointer-events:auto; }

.cp-chips{ display:flex; flex-wrap:wrap; gap:6px; margin-bottom:12px; }
.cp-chip{
  display:inline-flex; align-items:center; gap:6px;
  padding:4px 6px 4px 6px; border-radius:999px;
  background:rgba(255,255,255,0.06); border:1px solid rgba(255,255,255,0.12);
  font-size:0.78rem; color:var(--text-secondary);
}
.cp-chip-sw{ width:14px; height:14px; border-radius:50%; box-shadow:inset 0 0 0 1px rgba(255,255,255,0.3); }
.cp-chip-x{ border:none; background:none; color:var(--text-muted); cursor:pointer; font-size:1rem; line-height:1; padding:0 2px; }
.cp-chip-x:hover{ color:#fff; }

.cp-palette{ display:grid; grid-template-columns:repeat(10,1fr); gap:6px; }
.cp-swatch{
  aspect-ratio:1; border:1px solid rgba(255,255,255,0.14); border-radius:7px;
  cursor:pointer; padding:0; transition:transform .12s ease, box-shadow .12s ease;
}
.cp-swatch:hover{ transform:scale(1.12); }
.cp-swatch.on{ box-shadow:0 0 0 2px rgba(18,18,22,0.9), 0 0 0 4px var(--accent); }

.cp-custom{ margin-top:14px; padding-top:12px; border-top:1px solid rgba(255,255,255,0.1); }
.cp-custom-label{ font-size:0.8rem; color:var(--text-secondary); margin-bottom:8px; }
.cp-custom-row{ display:flex; align-items:center; gap:8px; margin-top:10px; }
.cp-sv{
  position:relative; width:100%; height:120px; margin-bottom:10px;
  border-radius:10px; border:1px solid rgba(255,255,255,0.12);
  cursor:crosshair; touch-action:none;
}
.cp-sv-handle{
  position:absolute; width:14px; height:14px; border-radius:50%;
  border:2px solid #fff; box-shadow:0 0 0 1px rgba(0,0,0,0.45);
  transform:translate(-50%,-50%); pointer-events:none;
}
.cp-hue{
  position:relative; width:100%; height:14px; margin-bottom:4px;
  border-radius:8px; border:1px solid rgba(255,255,255,0.12);
  cursor:pointer; touch-action:none;
  background:linear-gradient(to right,#ff0000,#ffff00,#00ff00,#00ffff,#0000ff,#ff00ff,#ff0000);
}
.cp-hue-handle{
  position:absolute; top:50%; width:16px; height:16px; border-radius:50%;
  background:#fff; border:2px solid #fff; box-shadow:0 0 0 1px rgba(0,0,0,0.45);
  transform:translate(-50%,-50%); pointer-events:none;
}
.cp-preview{
  width:38px; height:38px; flex-shrink:0; border-radius:8px;
  border:1px solid rgba(255,255,255,0.2);
}
.cp-hex{
  flex:1; min-width:0; height:38px; padding:0 12px;
  background-color:rgba(20,20,24,0.5); border:1px solid rgba(255,255,255,0.12);
  border-radius:8px; color:var(--text-primary); font-family:var(--font-body); font-size:0.88rem; outline:none;
}
.cp-hex:focus{ border-color:rgba(200,100,255,0.55); box-shadow:0 0 0 3px rgba(200,100,255,0.18); }
.cp-add{
  flex-shrink:0; height:38px; padding:0 14px;
  background:rgba(200,100,255,0.16); border:1px solid rgba(200,100,255,0.4);
  border-radius:8px; color:#fff; cursor:pointer; font-family:var(--font-body); font-size:0.85rem;
  transition:background .2s, border-color .2s;
}
.cp-add:hover{ background:rgba(200,100,255,0.28); border-color:rgba(200,100,255,0.6); }

/* ═══════════════════════════════════════════════════════
   PORTFOLIO-GALERIE: Vorlage → Ergebnis (zusammengehöriges Paar)
   ═══════════════════════════════════════════════════════ */
/* Karten im Glasdesign (wie Navileiste / "im Aufbau"-Box) */
.arbeit-card{
  background: rgba(22,22,26,0.55) !important;
  -webkit-backdrop-filter: blur(20px) saturate(160%);
  backdrop-filter: blur(20px) saturate(160%);
  border: 1px solid rgba(255,255,255,0.10) !important;
  box-shadow: 0 8px 32px rgba(0,0,0,0.30);
}
.arbeit-pair .arbeit-pair-row{
  display:flex; align-items:center; gap:14px; padding:22px;
}
.arbeit-pair .arbeit-pair-item{ flex:1 1 0; min-width:0; }
.arbeit-pair .arbeit-pair-label{
  display:block; text-align:center; margin-bottom:10px;
  font-size:.74rem; font-weight:700; letter-spacing:.07em; text-transform:uppercase;
  color:var(--text-muted);
}
.arbeit-pair .arbeit-pair-arrow{
  flex:0 0 auto; margin-top:18px; color:#c864ff; font-size:1.7rem; line-height:1;
}
.arbeit-pair .arbeit-thumb{ aspect-ratio:1/1; padding:16px; border-radius:12px; }

/* Ganze Karte anklickbar + Lupe-+-Hinweis unten rechts */
.arbeit-klickbar{ cursor:zoom-in; }
.arbeit-card .arbeit-pair-row,
.arbeit-card > .arbeit-thumb{ position:relative; }
.arbeit-zoom{
  position:absolute; right:12px; bottom:12px; z-index:3;
  width:32px; height:32px; border-radius:50%;
  display:flex; align-items:center; justify-content:center;
  background:rgba(20,20,24,0.6); border:1px solid rgba(255,255,255,0.22);
  -webkit-backdrop-filter:blur(8px); backdrop-filter:blur(8px);
  color:#fff; pointer-events:none;
  box-shadow:0 4px 14px rgba(0,0,0,0.35);
  transition:background .2s ease, border-color .2s ease, transform .2s ease;
}
.arbeit-zoom svg{ width:17px; height:17px; fill:none; stroke:currentColor; stroke-width:2; stroke-linecap:round; stroke-linejoin:round; }
.arbeit-klickbar:hover .arbeit-zoom{ background:rgba(200,100,255,0.65); border-color:rgba(200,100,255,0.8); transform:scale(1.06); }

/* Desktop: Paar-Karte breiter (über 2 Spalten), damit die Bilder größer wirken */
@media (min-width:769px){
  .arbeiten-grid .arbeit-pair{ grid-column: span 2; }
  .arbeit-pair .arbeit-pair-row{ gap:22px; padding:28px; }
}

/* Lightbox als Vorher/Nachher-Paar – beide Bilder auf gleicher Höhe, ohne Pfeil */
.lightbox-panel.is-pair{ max-width:min(96vw,1300px); }
.lightbox-pair{ display:flex; align-items:flex-start; justify-content:center; gap:24px; width:100%; }
/* Zwei gleich breite Spalten -> Bilder sprengen die Box nie, egal wie groß der Bildschirm. */
.lightbox-pair .lbp-col{ flex:1 1 0; min-width:0; display:flex; flex-direction:column; align-items:center; }
.lightbox-pair .lbp-label{
  display:block; margin-bottom:10px;
  font-size:.82rem; font-weight:700; letter-spacing:.06em; text-transform:uppercase; color:#666;
}
/* Feste, gleiche Höhe für Vorlage und Ergebnis; Breite = Spaltenbreite (max. halbe Box). */
.lightbox-pair img{ width:100%; height:min(58vh, 30vw, 420px); object-fit:contain; display:block; }

@media (max-width:600px){
  .lightbox-pair{ flex-direction:column; align-items:center; gap:16px; }
  .lightbox-pair .lbp-col{ width:100%; }
  .lightbox-pair img{ width:100%; height:auto; max-height:38vh; }
}
