/*
  ====================================================================
  HTMO Frontend CSS - Final Template
  ====================================================================

  Projekt:
  HTMO - Hinrichs Tobias Medien Online

  Zweck:
  Dieses Stylesheet steuert ausschließlich das öffentliche Frontend.

  Spätere ASP.NET-Übernahme:
  - Datei nach wwwroot/css/htmo-frontend.css kopieren
  - Layout nach Views/Shared/_Layout.cshtml übernehmen
  - Header/Footer optional als Partial Views auslagern

  Regeln:
  - Kein Bootstrap
  - Kein CDN
  - Keine Musik-Optik
  - Professioneller Unternehmenslook
  - Lesbarkeit vor Effekt
  - Animationen dezent halten
  - Mobile Darstellung beachten

  Inhaltsübersicht:
  1. Design Tokens
  2. Basis / Reset
  3. Header / Navigation
  4. Hero
  5. Sections / Cards
  6. Formulare
  7. Footer
  8. HTMO Company Anpassungen
  9. Typography Fix
  10. Responsive Regeln
  ====================================================================
*/

/*
  HTMO Frontend - Designer Edition
  ------------------------------------------------------------
  Ziel:
  - Weniger generisches Dashboard/Template
  - Mehr Markencharakter
  - Asymmetrie, Layer, Rasterlinien, Bewegung
  - Industrial / Editorial / Tech-Label Look
  - Trotzdem sauber nach ASP.NET/Razor übertragbar

  Animationen:
  - Header-Linie
  - Hero-Orbit
  - Floating Panels
  - Reveal Cards
  - Marquee-Band
*/

:root {
  /* Neutral, warm-grey dark base - no blue-black "cyberpunk" tint */
  --ink: #0c0c0d;
  --night: #131315;
  --night-2: #19191c;
  --panel: rgba(25, 25, 28, .74);
  --panel-solid: #1a1a1d;
  --line: rgba(255, 255, 255, .09);
  --line-strong: rgba(255, 255, 255, .15);
  --text: #f1f0ee;
  --muted: #a3a29d;
  --dim: #726f68;

  /* Single brand accent, taken from the HTMO logo blue. --acid keeps the
     variable name used across the stylesheet so components don't need
     renaming, but it now holds the calm brand blue instead of neon green. */
  --acid: #4f8fd1;
  --acid-strong: #6ba4dc;

  /* Kompatibilitäts-Alias für ältere Komponenten, die noch --accent
     referenzieren. Der Alias verhindert ungeklärte Custom-Properties
     und hält die Frontend-Farbe konsistent beim HTMO-Blau. */
  --accent: var(--acid);

  /* Sichere Standardwerte für serverseitig gerenderte Blockvariablen.
     Einzelne Blöcke können diese Werte per geprüfter Inline-Variable
     überschreiben, ohne dass die CSS-Datei ungeklärte Variablen meldet. */
  --htmo-spacer-height: 48px;
  --htmo-column-gap: clamp(18px, 3vw, 34px);
  --htmo-gallery-gap: 14px;

  --electric: #4f8fd1;
  --ember: #c98a4b;
  --violet: #c98a4b;
  --steel: #9a978f;

  --radius: 16px;
  --radius-sm: 10px;
  --radius-xl: 24px;

  --shadow: 0 20px 50px rgba(6, 8, 12, .38);
  --font: "Segoe UI Variable Text", "Segoe UI", -apple-system, BlinkMacSystemFont, system-ui, sans-serif;
}

* {
  box-sizing: border-box;
}

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

body {
  margin: 0;
  min-height: 100vh;
  color: var(--text);
  background: #0a0a0b;
  font-family: var(--font), system-ui, sans-serif;
  font-size: 16px;
  line-height: 1.55;
  overflow-x: hidden;
}

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

button,
input,
textarea,
select {
  font: inherit;
}

button {
  cursor: pointer;
}

h1,
h2,
h3,
p {
  margin-top: 0;
}

h1 {
  margin-bottom: 22px;
  max-width: 940px;
  font-size: clamp(48px, 8.6vw, 116px);
  line-height: .86;
  letter-spacing: -.085em;
}

h2 {
  margin-bottom: 14px;
  font-size: clamp(32px, 4.8vw, 62px);
  line-height: .92;
  letter-spacing: -.07em;
}

h3 {
  margin-bottom: 10px;
  font-size: 22px;
  letter-spacing: -.03em;
}

p {
  color: var(--muted);
}

::selection {
  color: #07101e;
  background: var(--acid);
}

.container {
  width: min(1220px, calc(100% - 38px));
  margin: 0 auto;
  position: relative;
  z-index: 1;
}

/* ============================================================
   Header
============================================================ */

.site-header {
  position: sticky;
  top: 0;
  z-index: 20;
  background: rgba(11, 11, 12, .66);
  border-bottom: 1px solid var(--line);
  backdrop-filter: blur(18px);
}

.header-inner {
  display: flex;
  align-items: center;
  justify-content: space-between;
  min-height: 82px;
  gap: 18px;
}

.brand {
  display: inline-flex;
  align-items: center;
  gap: 13px;
}

.brand-mark {
  position: relative;
  display: grid;
  place-items: center;
  width: 48px;
  height: 48px;
  color: #06101f;
  font-weight: 700;
  background: var(--acid);
  border-radius: var(--radius-sm);
  box-shadow: 0 0 0 1px rgba(255,255,255,.16) inset;
}

.brand strong,
.brand small {
  display: block;
}

.brand strong {
  letter-spacing: .14em;
}

.brand small {
  color: var(--muted);
  font-size: 12px;
}

.site-nav {
  display: flex;
  align-items: center;
  gap: 4px;
}

.site-nav a {
  position: relative;
  padding: 10px 12px;
  color: var(--muted);
  border-radius: 999px;
}

.site-nav a::before {
  content: "";
  position: absolute;
  left: 12px;
  right: 12px;
  bottom: 4px;
  height: 2px;
  background: var(--acid);
  transform: scaleX(0);
  transform-origin: left;
  transition: transform .22s ease;
}

.site-nav a:hover,
.site-nav a.active {
  color: var(--text);
}

.site-nav a:hover::before,
.site-nav a.active::before {
  transform: scaleX(1);
}

.site-nav .admin-link {
  margin-left: 10px;
  color: #07101e;
  background: var(--electric);
  box-shadow: 0 12px 30px rgba(79, 143, 209, .18);
}

.site-nav .admin-link::before {
  display: none;
}

.nav-toggle {
  display: none;
  width: 44px;
  height: 44px;
  color: var(--text);
  background: rgba(255,255,255,.05);
  border: 1px solid var(--line-strong);
  border-radius: 12px;
}

/* ============================================================
   Hero
============================================================ */

.hero {
  position: relative;
  padding: 112px 0 78px;
}

.hero-grid {
  display: grid;
  grid-template-columns: 1.08fr .92fr;
  align-items: center;
  gap: 54px;
}

.hero-copy {
  position: relative;
}

.hero-copy h1 strong {
  color: var(--acid);
  font-weight: inherit;
}

.hero-copy p {
  max-width: 700px;
  font-size: clamp(18px, 2vw, 23px);
}

.eyebrow {
  display: inline-flex;
  align-items: center;
  gap: 10px;
  margin-bottom: 18px;
  color: var(--acid);
  font-size: 12px;
  font-weight: 700;
  letter-spacing: .18em;
  text-transform: uppercase;
}

.eyebrow::before {
  content: "";
  width: 34px;
  height: 1px;
  background: currentColor;
}

.hero-actions {
  display: flex;
  flex-wrap: wrap;
  gap: 13px;
  margin-top: 30px;
}

.btn {
  position: relative;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-height: 50px;
  padding: 0 20px;
  overflow: hidden;
  color: var(--text);
  background: rgba(255,255,255,.055);
  border: 1px solid var(--line-strong);
  border-radius: 999px;
  transition: transform .18s ease, border-color .18s ease, background .18s ease;
}

.btn::after {
  content: "";
  position: absolute;
  inset: 0;
  background: linear-gradient(90deg, transparent, rgba(255,255,255,.16), transparent);
  transform: translateX(-120%);
  transition: transform .45s ease;
}

.btn:hover {
  transform: translateY(-2px);
  border-color: rgba(255,255,255,.32);
}

.btn:hover::after {
  transform: translateX(120%);
}

.btn.primary {
  color: #06101f;
  background: var(--acid);
  border-color: var(--acid);
  font-weight: 600;
}

.btn.ghost {
  background: transparent;
}

.hero-panel {
  position: relative;
  padding: 24px;
  background:
    linear-gradient(145deg, rgba(255,255,255,.06), rgba(255,255,255,.015)),
    rgba(25, 25, 28, .58);
  border: 1px solid var(--line-strong);
  border-radius: var(--radius-xl);
  box-shadow: var(--shadow);
  overflow: hidden;
}

.hero-panel::before {
  content: "";
  position: absolute;
  width: 340px;
  height: 340px;
  right: -140px;
  top: -110px;
  background: radial-gradient(circle, rgba(79,143,209,.16), transparent 62%);
  border-radius: 999px;
  pointer-events: none;
}

.signal-row {
  position: relative;
  z-index: 1;
  display: grid;
  grid-template-columns: 14px 1fr auto;
  align-items: center;
  gap: 12px;
  min-height: 54px;
  border-bottom: 1px solid var(--line);
}

.signal-row span {
  width: 8px;
  height: 8px;
  background: var(--acid);
  border-radius: 999px;
}

.signal-row em {
  color: var(--muted);
  font-style: normal;
}

.panel-terminal {
  position: relative;
  z-index: 1;
  display: grid;
  gap: 10px;
  padding: 18px;
  background: rgba(10, 10, 11, .5);
  border: 1px solid var(--line);
  border-radius: var(--radius-sm);
}

.panel-terminal p {
  margin: 0;
  color: var(--muted);
  font-size: 13px;
}

.panel-terminal p strong {
  color: var(--text);
}

/* ============================================================
   Designer Sections
============================================================ */

.section {
  padding: 82px 0;
}

.section-head {
  max-width: 780px;
  margin-bottom: 34px;
}

.feature-grid,
.project-grid,
.pricing-grid,
.blog-grid {
  display: grid;
  gap: 18px;
  grid-template-columns: repeat(3, minmax(0, 1fr));
}

.feature-card,
.project-card,
.price-card,
.blog-card,
.release-card,
.contact-form,
.contact-card,
.article-box {
  position: relative;
  overflow: hidden;
  background:
    linear-gradient(145deg, rgba(255,255,255,.075), rgba(255,255,255,.018)),
    var(--panel);
  border: 1px solid var(--line);
  border-radius: var(--radius);
  box-shadow: var(--shadow);
}

.feature-card,
.project-card,
.price-card,
.blog-card {
  padding: 26px;
  transition: transform .22s ease, border-color .22s ease, background .22s ease;
}

.feature-card:hover,
.project-card:hover,
.price-card:hover,
.blog-card:hover {
  transform: translateY(-4px);
  border-color: rgba(79,143,209,.34);
}

.feature-card::before,
.project-card::before,
.price-card::before,
.blog-card::before {
  content: "";
  position: absolute;
  inset: 0 0 auto;
  height: 2px;
  background: var(--acid);
  transform: scaleX(.16);
  transform-origin: left;
  transition: transform .25s ease;
}

.feature-card:hover::before,
.project-card:hover::before,
.price-card:hover::before,
.blog-card:hover::before {
  transform: scaleX(1);
}

.icon,
.badge {
  display: inline-flex;
  align-items: center;
  min-height: 30px;
  padding: 0 11px;
  margin-bottom: 16px;
  color: #06101f;
  background: var(--acid);
  border-radius: 999px;
  font-size: 12px;
  font-weight: 800;
}

.split-section {
  display: grid;
  grid-template-columns: .82fr 1.18fr;
  gap: 38px;
}

.news-list {
  display: grid;
  gap: 13px;
}

.news-row {
  position: relative;
  display: flex;
  justify-content: space-between;
  gap: 18px;
  padding: 20px;
  background: rgba(25, 25, 28, .72);
  border: 1px solid var(--line);
  border-radius: 18px;
  transition: transform .18s ease, border-color .18s ease;
}

.news-row:hover {
  transform: translateX(8px);
  border-color: rgba(79, 143, 209,.36);
}

.news-row-static,
.news-row[aria-disabled="true"] {
  cursor: default;
}

.news-row-static:hover,
.news-row[aria-disabled="true"]:hover {
  transform: none;
  border-color: var(--line);
}

.news-row span,
.blog-card span,
.project-card footer span {
  color: var(--muted);
}

.page-hero {
  position: relative;
  padding: 88px 0 44px;
  border-bottom: 1px solid var(--line);
}

.page-hero::after {
  content: "";
  position: absolute;
  right: 8vw;
  bottom: -60px;
  width: 220px;
  height: 220px;
  background: radial-gradient(circle, rgba(79,143,209,.14), transparent 65%);
  border-radius: 999px;
  pointer-events: none;
}

.page-hero p {
  max-width: 780px;
  font-size: 21px;
}

.release-grid {
  display: grid;
  gap: 22px;
}

.release-card {
  display: grid;
  grid-template-columns: 240px 1fr;
  gap: 26px;
  padding: 20px;
  align-items: center;
}

.release-card:nth-child(even) {
  margin-left: 70px;
}

.cover {
  min-height: 210px;
  border-radius: var(--radius);
  border: 1px solid var(--line-strong);
  box-shadow: inset 0 0 0 1px rgba(255,255,255,.08);
}

.cover-a,
.cover-b,
.cover-c {
  background:
    radial-gradient(circle at 30% 25%, rgba(79,143,209,.28), transparent 45%),
    linear-gradient(135deg, #202024, #0a0a0b);
}

.text-link,
.project-card a,
.blog-card a,
.info-row a {
  color: var(--acid);
  font-weight: 700;
}

.project-card footer {
  display: flex;
  justify-content: space-between;
  gap: 16px;
  margin-top: 20px;
  padding-top: 16px;
  border-top: 1px solid var(--line);
}

.price-card strong {
  display: block;
  margin: 18px 0;
  color: var(--text);
  font-size: 34px;
  letter-spacing: -.05em;
}

.price-card.highlight {
  border-color: rgba(79, 143, 209,.38);
  transform: translateY(-12px);
}

.price-card ul {
  margin: 0;
  padding-left: 20px;
  color: var(--muted);
}

.blog-card span {
  display: block;
  margin-bottom: 12px;
  color: var(--acid);
  font-weight: 800;
}

.contact-grid {
  display: grid;
  grid-template-columns: 1.15fr .85fr;
  gap: 22px;
}

.contact-form,
.contact-card {
  padding: 28px;
}

label {
  display: block;
  margin-bottom: 17px;
}

label span {
  display: block;
  margin-bottom: 8px;
  color: var(--muted);
  font-size: 13px;
  font-weight: 600;
}

input,
textarea,
select {
  width: 100%;
  color: var(--text);
  background: rgba(10, 10, 11, .72);
  border: 1px solid var(--line-strong);
  border-radius: 14px;
  outline: none;
}

input,
select {
  min-height: 50px;
  padding: 0 14px;
}

textarea {
  resize: vertical;
  padding: 14px;
}

input:focus,
textarea:focus,
select:focus {
  border-color: rgba(79, 143, 209, .68);
  box-shadow: 0 0 0 4px rgba(79, 143, 209, .11);
}

.info-row {
  display: flex;
  justify-content: space-between;
  gap: 16px;
  padding: 15px 0;
  border-bottom: 1px solid var(--line);
}

.info-row span {
  color: var(--muted);
}

.article {
  max-width: 900px;
  padding-top: 86px;
  padding-bottom: 86px;
}

.article h1 {
  font-size: clamp(42px, 6.6vw, 78px);
}

.lead {
  color: #ccd8ef;
  font-size: 22px;
}

.article-box {
  margin-top: 30px;
  padding: 24px;
}

.site-footer {
  margin-top: 70px;
  padding: 46px 0;
  border-top: 1px solid var(--line);
  background: rgba(10, 10, 11, .78);
}

.footer-grid {
  display: grid;
  grid-template-columns: 1.4fr .6fr .6fr;
  gap: 32px;
}

.footer-grid a {
  display: block;
  margin: 8px 0;
  color: var(--muted);
}

.footer-grid a:hover {
  color: var(--text);
}

.footer-brand {
  margin-bottom: 14px;
}

/* ============================================================
   Responsive
============================================================ */

@media (prefers-reduced-motion: reduce) {
  *,
  *::before,
  *::after {
    animation: none !important;
    transition: none !important;
  }
}

@media (max-width: 980px) {
  h1 {
    letter-spacing: -.065em;
  }

  .nav-toggle {
    display: inline-grid;
    place-items: center;
  }

  .site-nav {
    position: fixed;
    left: 18px;
    right: 18px;
    top: 90px;
    display: none;
    flex-direction: column;
    align-items: stretch;
    padding: 14px;
    background: rgba(16, 16, 18, .98);
    border: 1px solid var(--line-strong);
    border-radius: 20px;
    box-shadow: var(--shadow);
  }

  body.nav-open .site-nav {
    display: flex;
  }

  .site-nav .admin-link {
    margin-left: 0;
  }

  .hero-grid,
  .split-section,
  .contact-grid,
  .footer-grid {
    grid-template-columns: 1fr;
  }

  .feature-grid,
  .project-grid,
  .pricing-grid,
  .blog-grid {
    grid-template-columns: 1fr;
  }

  .release-card,
  .release-card:nth-child(even) {
    grid-template-columns: 1fr;
    margin-left: 0;
  }

  .price-card.highlight {
    transform: none;
  }
}

@media (max-width: 560px) {
  .container {
    width: min(100% - 28px, 1220px);
  }

  .hero {
    padding-top: 62px;
  }

  .hero-actions,
  .news-row,
  .project-card footer,
  .info-row {
    flex-direction: column;
  }
}


/* ============================================================
   HTMO Company Anpassungen
   ------------------------------------------------------------
   Logo, Inhaberbild und Unternehmensauftritt.
============================================================ */

.logo-brand {
  min-width: 210px;
}

.logo-brand img {
  display: block;
  width: min(265px, 42vw);
  height: auto;
  object-fit: contain;
}

.footer-brand img {
  width: 235px;
}

.company-panel {
  display: flex;
  flex-direction: column;
  gap: 14px;
}

.founder-card {
  position: relative;
  z-index: 2;
  display: grid;
  grid-template-columns: 112px 1fr;
  align-items: center;
  gap: 16px;
  padding: 14px;
  margin-bottom: 8px;
  background: rgba(10, 10, 11, .54);
  border: 1px solid var(--line);
  border-radius: var(--radius);
}

.founder-card img {
  width: 112px;
  height: 112px;
  object-fit: cover;
  object-position: center top;
  border-radius: var(--radius-sm);
  border: 1px solid rgba(255,255,255,.18);
  filter: saturate(.96) contrast(1.03);
}

.founder-card span,
.founder-card small {
  display: block;
  color: var(--muted);
}

.founder-card strong {
  display: block;
  margin: 4px 0;
  font-size: 24px;
  letter-spacing: -.04em;
}

.about-grid {
  display: grid;
  grid-template-columns: .85fr 1.15fr;
  gap: 34px;
  align-items: center;
}

.about-portrait {
  position: relative;
  padding: 14px;
  background:
    linear-gradient(145deg, rgba(255,255,255,.075), rgba(255,255,255,.018)),
    var(--panel);
  border: 1px solid var(--line);
  border-radius: var(--radius-xl);
  box-shadow: var(--shadow);
}

.about-portrait::before {
  content: "";
  position: absolute;
  inset: -10px 14px 14px -10px;
  z-index: -1;
  border: 1px solid var(--line-strong);
  border-radius: inherit;
}

.about-portrait img {
  display: block;
  width: 100%;
  border-radius: var(--radius);
}

.info-panel {
  margin-top: 28px;
  padding: 18px;
  background: rgba(25, 25, 28, .72);
  border: 1px solid var(--line);
  border-radius: 22px;
}

.tech-list {
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
}

.tech-list span {
  display: inline-flex;
  align-items: center;
  min-height: 38px;
  padding: 0 14px;
  color: #06101f;
  background: var(--acid);
  border-radius: 999px;
  font-weight: 600;
}

.owner-contact img {
  display: block;
  width: 132px;
  height: 132px;
  object-fit: cover;
  object-position: center top;
  margin-bottom: 18px;
  border-radius: var(--radius);
  border: 1px solid rgba(255,255,255,.18);
}

@media (max-width: 980px) {
  .logo-brand {
    min-width: 0;
  }

  .logo-brand img {
    width: min(230px, 58vw);
  }

  .about-grid {
    grid-template-columns: 1fr;
  }

  .founder-card {
    grid-template-columns: 92px 1fr;
  }

  .founder-card img {
    width: 92px;
    height: 92px;
  }
}

@media (max-width: 560px) {
  .founder-card {
    grid-template-columns: 1fr;
  }

  .founder-card img {
    width: 120px;
    height: 120px;
  }
}


/* ============================================================
   HTMO Typography Fix
   ------------------------------------------------------------
   Die erste Designer-Version war bewusst kraftvoll, aber stellenweise
   zu massiv. Diese Korrektur macht die Überschriften ruhiger,
   lesbarer und professioneller.
============================================================ */

/* Globale Headlines weniger brutal */
h1 {
  max-width: 960px;
  font-size: clamp(42px, 6.6vw, 86px);
  line-height: .98;
  letter-spacing: -.058em;
}

h2 {
  font-size: clamp(28px, 4vw, 48px);
  line-height: 1.02;
  letter-spacing: -.048em;
}

h3 {
  line-height: 1.12;
  letter-spacing: -.025em;
}

/* Hero darf groß bleiben, aber nicht mehr erschlagen */
.hero-copy h1 {
  max-width: 780px;
  font-size: clamp(44px, 6.4vw, 82px);
  line-height: .98;
  letter-spacing: -.06em;
}

/* Unterseiten-Header kompakter */
.page-hero h1 {
  max-width: 820px;
  font-size: clamp(42px, 5.8vw, 74px);
  line-height: .98;
  letter-spacing: -.055em;
}

/* Artikel-Überschriften ebenfalls ruhiger */
.article h1 {
  font-size: clamp(38px, 5.2vw, 64px);
  line-height: 1;
}

/* Cards brauchen eigene Typografie, sonst werden sie zu laut */
.feature-card h3,
.project-card h2,
.price-card h2,
.blog-card h2,
.release-card h2 {
  max-width: 100%;
  font-size: clamp(25px, 2.4vw, 36px);
  line-height: 1.04;
  letter-spacing: -.045em;
  overflow-wrap: break-word;
  hyphens: auto;
}

/* Referenz-/Projektkarten: kein Abschneiden langer Wörter */
.project-card {
  min-width: 0;
}

.project-card h2 {
  font-size: clamp(28px, 2.8vw, 40px);
}

/* Hero-Text nicht zu breit und angenehmer lesbar */
.hero-copy p {
  max-width: 680px;
  font-size: clamp(18px, 1.6vw, 21px);
  line-height: 1.55;
}

/* Page-Hero Text ruhiger */
.page-hero p {
  max-width: 740px;
  font-size: clamp(18px, 1.7vw, 21px);
}

/* Etwas mehr Luft zwischen Header und Inhalt */
.page-hero {
  padding-top: 76px;
  padding-bottom: 52px;
}

/* Das große Hintergrund-HTMO bleibt Design-Element, aber dezenter */
.hero::before {
  opacity: .72;
  font-size: clamp(90px, 18vw, 260px);
}

/* Auf sehr großen Screens nicht endlos aufblasen */
@media (min-width: 1500px) {
  .hero-copy h1 {
    font-size: 82px;
  }

  .page-hero h1 {
    font-size: 74px;
  }
}

/* Mobile: deutlich entspannter */
@media (max-width: 680px) {
  h1,
  .hero-copy h1,
  .page-hero h1 {
    font-size: clamp(38px, 12vw, 56px);
    line-height: 1.02;
    letter-spacing: -.045em;
  }

  h2 {
    font-size: clamp(28px, 9vw, 40px);
  }

  .project-card h2,
  .price-card h2,
  .blog-card h2,
  .release-card h2 {
    font-size: clamp(26px, 8vw, 34px);
  }
}


/* Frontend Konto-Menü
   ------------------------------------------------------------
   Das Konto-Menü ist nur UI. Login, Backend und Profilseiten bleiben serverseitig geschützt.
*/
.frontend-account {
  display: flex;
  align-items: center;
  margin-left: 8px;
}

.account-login {
  display: inline-flex;
  align-items: center;
  min-height: 42px;
  padding: 0 14px;
  color: #07101e;
  background: var(--acid);
  border-radius: 999px;
  font-weight: 700;
}

.profile-menu {
  position: relative;
}

.profile-trigger {
  display: inline-flex;
  align-items: center;
  gap: 11px;
  min-height: 48px;
  padding: 5px 10px 5px 16px;
  color: var(--text);
  background: rgba(255,255,255,.055);
  border: 1px solid var(--line-strong);
  border-radius: 999px;
}

.profile-trigger:hover,
.profile-menu.open .profile-trigger {
  background: rgba(255,255,255,.085);
}

.profile-trigger-name {
  max-width: 160px;
  overflow: hidden;
  font-weight: 600;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.profile-caret {
  color: var(--muted);
}

.avatar {
  display: grid;
  place-items: center;
  overflow: hidden;
  color: #07101e;
  font-weight: 800;
  background: linear-gradient(135deg, var(--acid), var(--electric));
  border-radius: 999px;
}

.avatar.small {
  width: 34px;
  height: 34px;
  font-size: 13px;
}

.avatar.large {
  width: 58px;
  height: 58px;
  font-size: 20px;
}

.avatar img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}

.profile-dropdown {
  position: absolute;
  top: calc(100% + 12px);
  right: 0;
  z-index: 50;
  display: none;
  width: 320px;
  padding: 14px;
  background:
    linear-gradient(145deg, rgba(255,255,255,.07), rgba(255,255,255,.018)),
    #16161a;
  border: 1px solid var(--line-strong);
  border-radius: 20px;
  box-shadow: 0 28px 90px rgba(0,0,0,.5);
}

.profile-menu.open .profile-dropdown {
  display: block;
}

.profile-dropdown-head {
  display: flex;
  align-items: center;
  gap: 14px;
  padding: 8px 8px 12px;
}

.profile-dropdown-head strong,
.profile-dropdown-head span {
  display: block;
}

.profile-dropdown-head span {
  margin-top: 3px;
  color: var(--muted);
  font-size: 13px;
}

.profile-dropdown hr {
  border: 0;
  border-top: 1px solid var(--line);
  margin: 8px 0;
}

.profile-dropdown a,
.profile-dropdown form button {
  display: flex;
  align-items: center;
  width: 100%;
  min-height: 42px;
  padding: 0 10px;
  color: var(--muted);
  background: transparent;
  border: 0;
  border-radius: 12px;
  font-weight: 800;
  text-align: left;
}

.profile-dropdown a:hover,
.profile-dropdown form button:hover {
  color: var(--text);
  background: rgba(255,255,255,.055);
}

@media (max-width: 980px) {
  .frontend-account {
    order: 3;
  }

  .profile-trigger-name {
    display: none;
  }

  .profile-dropdown {
    right: -4px;
    width: min(320px, calc(100vw - 26px));
  }
}


/* Phase 3.01 - öffentlicher Kundenlogin */
.customer-login-link.active {
  border-color: rgba(79, 143, 209,.42);
  background: rgba(79, 143, 209,.13);
  color: var(--text);
}

.slim-hero {
  padding-block: clamp(70px, 9vw, 120px);
}

.feature-list {
  display: grid;
  gap: 10px;
  margin: 18px 0;
  padding: 0;
  list-style: none;
}

.feature-list li {
  padding: 12px 14px;
  border: 1px solid var(--border-soft);
  border-radius: 14px;
  background: rgba(255,255,255,.035);
}

.small-muted {
  margin-bottom: 0;
  color: var(--text-muted);
  font-size: 13px;
}


/* Phase 3.03 - Kundenportal Auth */
.customer-auth-card,
.portal-form-card {
  display: grid;
  gap: 14px;
}

.customer-auth-card label,
.portal-form-card label {
  display: grid;
  gap: 6px;
}

.customer-auth-card input,
.portal-form-card input {
  width: 100%;
  min-height: 44px;
  padding: 10px 12px;
  border: 1px solid var(--border);
  border-radius: 12px;
  color: var(--text);
  background: rgba(10, 10, 11,.65);
}

.portal-form-shell {
  max-width: 940px;
  margin: 0 auto;
}

.portal-form-head {
  margin-bottom: 22px;
}

.portal-form-card.panel {
  padding: 24px;
}

.validation-summary,
.validation-message {
  color: #ff8a8a;
  font-size: 13px;
}

.check-row {
  display: flex !important;
  grid-template-columns: none !important;
  align-items: center;
  gap: 10px;
}

.check-row input {
  width: 18px;
  min-height: 18px;
}


/* Phase 3.03.1 - Kundenportal Design-Verfeinerung
   ------------------------------------------------------------
   Die Auth-Seiten erhalten ein eigenständiges, wertigeres Layout,
   damit Registrierung und Login visuell mit dem restlichen HTMO-Design harmonieren.
*/
:root {
  --border: rgba(255, 255, 255, .14);
  --border-soft: rgba(255, 255, 255, .09);
  --text-muted: #a3a29d;
  --panel-card: linear-gradient(145deg, rgba(255,255,255,.06), rgba(255,255,255,.015));
}

.portal-page .container {
  width: min(1280px, calc(100% - 42px));
}

.portal-page .hero::before,
.portal-page.hero::before {
  opacity: .38;
}

.portal-page-title {
  margin-bottom: 20px;
  max-width: 12ch;
  font-size: clamp(56px, 6.4vw, 84px);
  line-height: .94;
  letter-spacing: -.065em;
}

.portal-lead {
  max-width: 720px;
  margin-bottom: 0;
  color: var(--muted);
  font-size: clamp(18px, 1.8vw, 22px);
  line-height: 1.6;
}

.portal-auth-grid,
.portal-auth-grid-register {
  display: grid;
  grid-template-columns: minmax(280px, .82fr) minmax(520px, 1.08fr);
  gap: 28px;
  align-items: start;
}

.portal-auth-grid-register {
  grid-template-columns: minmax(280px, .78fr) minmax(560px, 1.12fr);
}

.portal-auth-intro {
  display: grid;
  gap: 22px;
  padding-top: 18px;
}

.portal-info-stack {
  display: grid;
  gap: 18px;
}

.portal-card,
.hero-card {
  position: relative;
  overflow: hidden;
  min-width: 0;
  background: var(--panel-card), rgba(20, 20, 22, .86);
  border: 1px solid var(--line-strong);
  border-radius: 28px;
  box-shadow: 0 28px 80px rgba(0,0,0,.34);
  backdrop-filter: blur(12px);
}

.portal-card::before,
.hero-card::before {
  content: "";
  position: absolute;
  top: 18px;
  left: 24px;
  width: min(180px, calc(100% - 48px));
  height: 3px;
  border-radius: 999px;
  background: linear-gradient(90deg, var(--electric), rgba(127, 230, 228, .95), var(--acid));
  box-shadow: 0 0 18px rgba(79, 143, 209,.22);
}

.portal-card::after,
.hero-card::after {
  content: "";
  position: absolute;
  right: -70px;
  bottom: -70px;
  width: 220px;
  height: 220px;
  background: radial-gradient(circle, rgba(79, 143, 209,.08), transparent 62%);
  pointer-events: none;
}

.portal-info-card,
.hero-card,
.portal-status-card {
  padding: 28px;
}

.portal-info-card h2,
.portal-card-head h2 {
  margin-bottom: 12px;
  font-size: clamp(30px, 2.8vw, 40px);
  line-height: 1;
  letter-spacing: -.05em;
}

.portal-kicker {
  display: inline-flex;
  margin-bottom: 10px;
  color: var(--acid);
  font-size: 12px;
  font-weight: 700;
  letter-spacing: .16em;
  text-transform: uppercase;
}

.portal-chip {
  display: inline-flex;
  align-items: center;
  min-height: 38px;
  padding: 0 14px;
  color: var(--text);
  background: rgba(79, 143, 209,.16);
  border: 1px solid rgba(79, 143, 209,.22);
  border-radius: 999px;
  font-size: 13px;
  font-weight: 800;
}

.portal-note {
  margin-bottom: 18px;
  color: var(--muted);
}

.portal-feature-list {
  gap: 12px;
  margin: 6px 0 0;
}

.portal-feature-list li {
  position: relative;
  padding: 14px 16px 14px 18px;
  border: 1px solid var(--border-soft);
  border-radius: 16px;
  background: rgba(255,255,255,.032);
}

.portal-feature-list li::before {
  content: "";
  position: absolute;
  left: 0;
  top: 12px;
  bottom: 12px;
  width: 3px;
  border-radius: 999px;
  background: linear-gradient(180deg, var(--electric), var(--acid));
}

.portal-form-card,
.customer-auth-card {
  display: grid;
  gap: 22px;
  padding: 28px;
}

.portal-register-card {
  gap: 24px;
}

.portal-card-head {
  display: flex;
  align-items: start;
  justify-content: space-between;
  gap: 18px;
  padding-top: 6px;
}

.portal-card-head h2,
.portal-card-head .portal-status-title {
  margin-bottom: 15px;
}

.portal-form-section {
  display: grid;
  gap: 16px;
}

.portal-form-section + .portal-form-section {
  padding-top: 22px;
  border-top: 1px solid var(--line);
}

.portal-section-title {
  margin-bottom: 0;
  font-size: 18px;
  letter-spacing: -.03em;
}

.portal-form-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 18px 16px;
}

.portal-field,
.customer-auth-card label,
.portal-form-card label {
  display: grid;
  gap: 8px;
}

.portal-field-label {
  color: var(--text);
  font-size: 13px;
  font-weight: 800;
  letter-spacing: .02em;
}

.portal-form-card input,
.portal-form-card textarea,
.portal-form-card select,
.customer-auth-card input {
  width: 100%;
  min-height: 52px;
  padding: 0 16px;
  border: 1px solid var(--border);
  border-radius: 14px;
  color: var(--text);
  background: rgba(10, 10, 11,.88);
  box-shadow: inset 0 1px 0 rgba(255,255,255,.03);
  transition: border-color .18s ease, box-shadow .18s ease, background .18s ease;
}

.portal-form-card input:focus,
.portal-form-card textarea:focus,
.portal-form-card select:focus,
.customer-auth-card input:focus {
  outline: none;
  border-color: rgba(79, 143, 209,.45);
  box-shadow: 0 0 0 4px rgba(79, 143, 209,.12);
  background: rgba(11, 11, 12,.95);
}

.portal-form-card textarea {
  min-height: 160px;
  padding: 14px 16px;
  resize: vertical;
}

.field-span-2 {
  grid-column: 1 / -1;
}

.validation-summary {
  padding: 14px 16px;
  color: #ff9a9a;
  background: rgba(140, 24, 24, .18);
  border: 1px solid rgba(255, 138, 138, .18);
  border-radius: 14px;
  font-size: 14px;
}

.validation-summary:empty {
  display: none;
}

.validation-message {
  color: #ff9a9a;
  font-size: 13px;
}

.portal-consent,
.check-row {
  display: flex !important;
  align-items: flex-start;
  gap: 12px;
  padding: 14px 16px;
  background: rgba(255,255,255,.028);
  border: 1px solid var(--border-soft);
  border-radius: 16px;
}

.portal-consent input,
.check-row input {
  width: 18px !important;
  min-width: 18px;
  min-height: 18px !important;
  margin-top: 2px;
  accent-color: var(--acid);
}

.portal-consent-inline {
  padding: 12px 14px;
}

.portal-actions,
.form-actions {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 14px;
  padding-top: 6px;
  flex-wrap: wrap;
}

.portal-actions-end {
  justify-content: flex-end;
}

.portal-link-stack {
  display: grid;
  gap: 8px;
}

.small-muted {
  margin-bottom: 0;
  color: var(--text-muted);
  font-size: 13px;
}

.small-muted:hover {
  color: var(--text);
}

.portal-status-layout {
  display: flex;
  justify-content: center;
}

.portal-status-card {
  width: min(760px, 100%);
}

.portal-status-title {
  margin-bottom: 14px;
  max-width: 12ch;
  font-size: clamp(42px, 4.8vw, 62px);
  line-height: .96;
  letter-spacing: -.05em;
}

.portal-status-lead {
  max-width: 56ch;
}

.portal-dashboard-card .portal-feature-list {
  margin-top: 10px;
}

@media (max-width: 1120px) {
  .portal-auth-grid,
  .portal-auth-grid-register {
    grid-template-columns: 1fr;
  }

  .portal-auth-intro {
    padding-top: 0;
  }

  .portal-page-title {
    max-width: 100%;
  }
}

@media (max-width: 720px) {
  .portal-page .container {
    width: min(100%, calc(100% - 24px));
  }

  .portal-form-card,
  .customer-auth-card,
  .portal-info-card,
  .hero-card,
  .portal-status-card {
    padding: 22px;
  }

  .portal-form-grid {
    grid-template-columns: 1fr;
  }

  .field-span-2 {
    grid-column: auto;
  }

  .portal-card-head,
  .portal-actions,
  .form-actions {
    align-items: stretch;
    flex-direction: column;
  }

  .portal-card-head {
    gap: 12px;
  }

  .portal-chip,
  .portal-actions .btn,
  .form-actions .btn {
    width: 100%;
    justify-content: center;
  }

  .portal-actions-stack-mobile {
    align-items: stretch;
  }
}


/* Phase 3.04 - Kundenportal Dashboard/Profile */
.portal-dashboard-layout {
  display: grid;
  grid-template-columns: minmax(0, 1fr) 360px;
  gap: 24px;
  align-items: stretch;
}

.portal-dashboard-hero,
.portal-dashboard-side,
.portal-module-card,
.portal-notice {
  padding: 28px;
}

.portal-dashboard-cards {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 18px;
  margin-top: 24px;
}

.portal-module-card h2 {
  margin-bottom: 8px;
  color: var(--text);
  font-size: clamp(42px, 4vw, 58px);
  line-height: 1;
}

.portal-facts {
  display: grid;
  gap: 14px;
  margin: 0;
}

.portal-facts div {
  padding: 12px 0;
  border-bottom: 1px solid var(--line);
}

.portal-facts div:last-child {
  border-bottom: 0;
}

.portal-facts dt {
  color: var(--muted);
  font-size: 12px;
  font-weight: 800;
  letter-spacing: .08em;
  text-transform: uppercase;
}

.portal-facts dd {
  margin: 4px 0 0;
  color: var(--text);
  font-weight: 600;
  overflow-wrap: anywhere;
}

.portal-notice {
  margin-bottom: 18px;
  color: var(--acid);
  font-weight: 600;
}

.portal-notice.compact {
  margin-bottom: 0;
  padding: 14px 16px;
}

.portal-profile-card {
  width: min(860px, 100%);
}

@media (max-width: 1120px) {
  .portal-dashboard-layout {
    grid-template-columns: 1fr;
  }

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

@media (max-width: 720px) {
  .portal-dashboard-cards {
    grid-template-columns: 1fr;
  }
}


/* Phase 3.05 - Kundenprofilbild und Frontend-Kundenmenü */
.customer-profile-trigger {
  min-height: 48px;
  padding: 5px 11px 5px 7px;
}

.customer-profile-dropdown {
  width: 340px;
}

.customer-profile-dropdown form {
  margin: 0;
}

.portal-profile-image-panel {
  display: grid;
  grid-template-columns: 128px minmax(0, 1fr);
  gap: 24px;
  align-items: start;
  padding: 18px;
  border: 1px solid var(--border-soft);
  border-radius: 22px;
  background: rgba(255,255,255,.032);
}

.portal-profile-avatar {
  display: grid;
  place-items: center;
  width: 86px;
  height: 86px;
  overflow: hidden;
  color: #07101e;
  font-weight: 800;
  background: linear-gradient(135deg, var(--acid), var(--electric));
  border: 1px solid rgba(255,255,255,.20);
  border-radius: 999px;
  box-shadow: 0 18px 40px rgba(0,0,0,.28);
}

.portal-profile-avatar.large {
  width: 112px;
  height: 112px;
  font-size: 34px;
}

.portal-profile-avatar img,
.avatar img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}

.portal-profile-image-panel h2 {
  margin-bottom: 6px;
  font-size: clamp(26px, 2.4vw, 34px);
  line-height: 1;
}

.portal-dashboard-title-row {
  display: flex;
  align-items: center;
  gap: 20px;
}

.portal-dashboard-avatar {
  flex: 0 0 auto;
}

@media (max-width: 720px) {
  .portal-profile-image-panel {
    grid-template-columns: 1fr;
  }

  .portal-dashboard-title-row {
    align-items: flex-start;
    flex-direction: column;
  }

  .customer-profile-dropdown {
    right: 0;
    width: min(340px, calc(100vw - 24px));
  }
}


/* Phase 3.05.1 - Kundenprofil Design-Feinschliff */
.customer-profile-page {
  padding-top: 72px;
}

.portal-profile-shell {
  display: grid;
  gap: 26px;
  padding: 34px;
}

.portal-profile-hero {
  align-items: flex-start;
}

.customer-profile-title {
  max-width: 9ch;
  margin-bottom: 14px;
  font-size: clamp(52px, 6vw, 76px);
  line-height: .92;
  letter-spacing: -.06em;
}

.customer-profile-lead {
  max-width: 680px;
  margin-bottom: 0;
  font-size: 18px;
}

.customer-profile-head-meta {
  display: grid;
  justify-items: end;
  gap: 12px;
  padding-top: 6px;
}

.btn-sm {
  min-height: 42px;
  padding: 0 16px;
}

.customer-profile-layout {
  display: grid;
  grid-template-columns: minmax(280px, 340px) minmax(0, 1fr);
  gap: 22px;
  align-items: start;
}

.customer-profile-side,
.customer-profile-main {
  display: grid;
  gap: 18px;
}

.customer-profile-panel {
  position: relative;
  display: grid;
  gap: 18px;
  padding: 22px;
  background: rgba(255,255,255,.03);
  border: 1px solid var(--border-soft);
  border-radius: 22px;
}

.customer-profile-avatar-panel {
  justify-items: start;
}

.customer-profile-visual {
  width: 124px;
  height: 124px;
  font-size: 40px;
  box-shadow: 0 18px 50px rgba(0,0,0,.22);
}

.customer-profile-avatar-copy h2 {
  margin-bottom: 8px;
  font-size: clamp(28px, 2vw, 36px);
  line-height: .96;
  letter-spacing: -.05em;
}

.customer-profile-avatar-copy p,
.portal-section-head p {
  margin-bottom: 0;
}

.portal-file-field input[type="file"] {
  min-height: auto;
  padding: 14px;
  line-height: 1.35;
}

.portal-file-field input[type="file"]::file-selector-button {
  margin-right: 12px;
  padding: 10px 14px;
  color: var(--text);
  background: rgba(255,255,255,.06);
  border: 1px solid var(--border);
  border-radius: 12px;
  font-weight: 800;
  cursor: pointer;
}

.customer-profile-remove-box {
  margin-top: -4px;
}

.customer-profile-meta-panel h3 {
  margin-bottom: 0;
}

.customer-profile-meta-list {
  display: grid;
  gap: 14px;
}

.customer-profile-meta-list > div {
  display: grid;
  gap: 4px;
  padding: 14px 16px;
  background: rgba(10, 10, 11,.5);
  border: 1px solid var(--border-soft);
  border-radius: 16px;
}

.customer-profile-meta-label {
  color: var(--muted);
  font-size: 12px;
  font-weight: 800;
  letter-spacing: .08em;
  text-transform: uppercase;
}

.portal-section-head {
  display: grid;
  gap: 6px;
}

.portal-section-title-lg {
  margin-bottom: 0;
  font-size: clamp(28px, 2.2vw, 36px);
  line-height: 1;
  letter-spacing: -.05em;
}

.customer-profile-grid {
  gap: 20px 18px;
}

.customer-profile-actions {
  margin-top: 4px;
  padding-top: 14px;
  border-top: 1px solid var(--line);
}

@media (max-width: 980px) {
  .customer-profile-layout {
    grid-template-columns: 1fr;
  }

  .customer-profile-head-meta {
    justify-items: start;
  }
}

@media (max-width: 640px) {
  .portal-profile-shell {
    padding: 22px;
  }

  .customer-profile-title {
    font-size: clamp(42px, 12vw, 58px);
  }

  .customer-profile-panel {
    padding: 18px;
  }

  .customer-profile-visual {
    width: 104px;
    height: 104px;
    font-size: 34px;
  }
}


/* Phase 3.06 - Kundenportal Dokumente */
.portal-documents-shell {
  display: grid;
  gap: 26px;
  padding: 34px;
}

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

.portal-document-card {
  display: grid;
  gap: 14px;
  align-content: start;
  padding: 22px;
  background: rgba(255,255,255,.032);
  border: 1px solid var(--border-soft);
  border-radius: 22px;
}

.portal-document-card h2 {
  margin-bottom: 0;
  font-size: clamp(24px, 2.2vw, 32px);
  line-height: 1;
  letter-spacing: -.045em;
}

.portal-document-card p {
  margin-bottom: 0;
  overflow-wrap: anywhere;
}

.portal-document-category {
  display: inline-flex;
  width: fit-content;
  min-height: 30px;
  align-items: center;
  padding: 0 11px;
  color: #07101e;
  background: var(--acid);
  border-radius: 999px;
  font-size: 12px;
  font-weight: 700;
}

.portal-document-meta {
  display: flex;
  justify-content: space-between;
  gap: 12px;
  color: var(--muted);
  font-size: 13px;
}

.portal-module-card .btn {
  margin-top: 12px;
  width: fit-content;
}

@media (max-width: 980px) {
  .portal-document-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
}

@media (max-width: 640px) {
  .portal-documents-shell {
    padding: 22px;
  }

  .portal-document-grid {
    grid-template-columns: 1fr;
  }
}


/* Phase 3.06.6 - Kundenportal Dokumentenvorschau */
.portal-document-card-head {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
}

.portal-document-file-icon {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-width: 54px;
  height: 38px;
  padding: 0 10px;
  color: #07101e;
  background: linear-gradient(135deg, var(--electric), var(--acid));
  border-radius: 12px;
  font-size: 12px;
  font-weight: 800;
}

.portal-document-actions {
  display: flex;
  gap: 10px;
  flex-wrap: wrap;
}

.portal-document-actions .btn {
  flex: 1 1 auto;
  min-width: 120px;
}


/* Phase 3.07 - Kundenportal Tickets */
.ticket-thread {
  display: grid;
  gap: 14px;
}

.ticket-message {
  padding: 18px;
  background: rgba(255,255,255,.035);
  border: 1px solid var(--border-soft);
  border-radius: 18px;
}

.ticket-message header {
  display: flex;
  gap: 10px;
  flex-wrap: wrap;
  align-items: center;
  margin-bottom: 10px;
}

.ticket-message header span {
  color: var(--muted);
  font-size: 13px;
}

.ticket-reply-form {
  display: grid;
  gap: 14px;
}


/* Phase 3.07.3 - Ticket-Themen im Kundenportal */
.ticket-topic-grid {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 14px;
  margin: 20px 0 24px;
}

.ticket-topic-card {
  position: relative;
  display: grid;
  grid-template-columns: 58px 1fr;
  gap: 12px;
  align-items: center;
  padding: 16px;
  min-height: 88px;
  cursor: pointer;
  border: 1px solid var(--border-soft);
  border-radius: 18px;
  background: rgba(255,255,255,.035);
  box-shadow: inset 0 1px 0 rgba(255,255,255,.04);
  transition: transform .16s ease, border-color .16s ease, background .16s ease;
}

.ticket-topic-card:hover,
.ticket-topic-card:has(input:checked),
.ticket-topic-card.selected {
  transform: translateY(-1px);
  border-color: var(--acid);
  background: rgba(79, 143, 209,.08);
}

.ticket-topic-card input {
  position: absolute;
  opacity: 0;
  pointer-events: none;
}

.ticket-topic-icon {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  height: 52px;
  width: 52px;
  color: #07101e;
  background: linear-gradient(135deg, var(--electric), var(--acid));
  border-radius: 14px;
  font-size: 14px;
  font-weight: 800;
}

.ticket-topic-card strong,
.ticket-topic-card small {
  grid-column: 2;
}

.ticket-topic-card small {
  color: var(--muted);
}

@media (max-width: 960px) {
  .ticket-topic-grid {
    grid-template-columns: 1fr;
  }
}


/* Phase 3.07.5 - Supportportal Layout */
.support-ticket-page .container {
  max-width: 1320px;
}

.support-ticket-shell {
  display: grid;
  grid-template-columns: 250px minmax(0, 1fr);
  gap: 0;
  margin: 0 auto;
  border: 1px solid var(--border-soft);
  border-radius: 24px;
  overflow: hidden;
  background: linear-gradient(145deg, rgba(24, 24, 27,.96), rgba(19, 19, 21,.96));
  box-shadow: 0 28px 80px rgba(0,0,0,.36);
}

.support-ticket-tabs {
  display: grid;
  align-content: start;
  gap: 8px;
  padding: 28px 18px;
  background: rgba(10, 10, 11,.38);
  border-right: 1px solid var(--border-soft);
}

.support-ticket-tabs a {
  display: flex;
  align-items: center;
  min-height: 46px;
  padding: 0 16px;
  color: var(--muted);
  text-decoration: none;
  border: 1px solid transparent;
  border-radius: 14px;
  font-weight: 700;
}

.support-ticket-tabs a:hover,
.support-ticket-tabs a.active {
  color: var(--text);
  background: rgba(255,255,255,.055);
  border-color: rgba(79, 143, 209,.32);
}

.support-ticket-main {
  padding: 34px;
}

.support-ticket-head {
  display: flex;
  justify-content: space-between;
  gap: 22px;
  align-items: flex-start;
  margin-bottom: 26px;
}

.support-ticket-head h1 {
  margin: 0;
  color: var(--text);
  font-size: clamp(42px, 5vw, 72px);
  line-height: .9;
  letter-spacing: -.07em;
}

.support-ticket-head p {
  max-width: 740px;
  margin: 12px 0 0;
  color: var(--muted);
  font-size: 18px;
}

.support-topic-grid {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 14px;
  margin: 18px 0 24px;
}

.support-topic-card {
  position: relative;
  display: grid;
  grid-template-columns: 58px minmax(0, 1fr);
  gap: 14px;
  align-items: center;
  min-height: 108px;
  padding: 18px;
  cursor: pointer;
  border: 1px solid var(--border-soft);
  border-radius: 16px;
  background: rgba(255,255,255,.035);
  transition: transform .16s ease, border-color .16s ease, background .16s ease;
}

.support-topic-card:hover,
.support-topic-card:has(input:checked),
.support-topic-card.selected {
  transform: translateY(-1px);
  border-color: var(--acid);
  background: rgba(79, 143, 209,.08);
}

.support-topic-card input {
  position: absolute;
  opacity: 0;
  pointer-events: none;
}

.support-topic-icon {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 52px;
  height: 52px;
  color: #07101e;
  background: linear-gradient(135deg, var(--electric), var(--acid));
  border-radius: 14px;
  font-size: 13px;
  font-weight: 800;
}

.support-topic-text {
  display: grid;
  gap: 8px;
  min-width: 0;
}

.support-topic-text strong {
  color: var(--text);
  font-size: 16px;
  line-height: 1.15;
}

.support-topic-text small {
  color: var(--muted);
  font-size: 13px;
  line-height: 1.35;
}

.support-ticket-divider {
  height: 1px;
  margin: 28px 0;
  background: var(--border-soft);
}

.support-ticket-form {
  display: grid;
  gap: 22px;
}

.support-ticket-form textarea {
  min-height: 180px;
}

.support-ticket-actions {
  display: flex;
  justify-content: space-between;
  gap: 12px;
  margin-top: 26px;
}

.support-ticket-table-wrap {
  overflow-x: auto;
  border: 1px solid var(--border-soft);
  border-radius: 18px;
  background: rgba(255,255,255,.025);
}

.support-ticket-table {
  width: 100%;
  border-collapse: collapse;
}

.support-ticket-table th,
.support-ticket-table td {
  padding: 16px 18px;
  text-align: left;
  border-bottom: 1px solid var(--border-soft);
}

.support-ticket-table th {
  color: var(--muted);
  font-size: 12px;
  letter-spacing: .08em;
  text-transform: uppercase;
}

.support-ticket-table td {
  color: var(--text);
}

.support-ticket-table td span {
  display: block;
  margin-top: 4px;
  color: var(--muted);
}

.support-ticket-link {
  color: var(--acid);
  font-weight: 800;
  text-decoration: none;
}

.support-ticket-empty-row td {
  padding: 42px 18px;
  color: var(--muted);
  text-align: center;
}

@media (max-width: 1100px) {
  .support-ticket-shell {
    grid-template-columns: 1fr;
  }

  .support-ticket-tabs {
    grid-template-columns: repeat(3, minmax(0, 1fr));
    border-right: 0;
    border-bottom: 1px solid var(--border-soft);
  }

  .support-topic-grid {
    grid-template-columns: 1fr;
  }

  .support-ticket-main {
    padding: 24px;
  }
}


/* Phase 3.07.6 - Ticket-Themen Frontend ohne Beschreibung */
.support-topic-card {
  min-height: 78px;
}

.support-topic-text {
  align-content: center;
}

.support-topic-text strong {
  font-size: 17px;
}

.support-topic-text small {
  display: none;
}


/* Phase 3.07.9 - echte Ticket-Icons */
.support-topic-icon img {
  display: block;
  width: 32px;
  height: 32px;
  object-fit: contain;
}


/* Phase 3.07.12 - Ticket ungelesen / schließen */
.ticket-row-unread {
  background: rgba(79, 143, 209,.08);
}

.ticket-row-unread td:first-child {
  border-left: 3px solid var(--acid);
}

.ticket-new-badge {
  display: inline-flex;
  align-items: center;
  margin-left: 8px;
  padding: 3px 8px;
  border-radius: 999px;
  background: rgba(79, 143, 209,.18);
  color: var(--acid);
  font-size: 11px;
  font-style: normal;
  font-weight: 800;
  letter-spacing: .06em;
  text-transform: uppercase;
}

.ticket-detail-actions {
  display: flex;
  align-items: center;
  gap: 10px;
}


/* Phase 3.08.2 - Ticket Attachments */
.ticket-attachment-list {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  margin-top: 10px;
}

.ticket-attachment-link {
  display: inline-flex;
  align-items: center;
  min-height: 30px;
  padding: 0 10px;
  color: var(--text);
  background: rgba(79, 143, 209,.12);
  border: 1px solid rgba(79, 143, 209,.25);
  border-radius: 999px;
  font-size: 12px;
  font-weight: 600;
}


/* Phase 3.08.8 - Kundenportal Ticketdetail Titel */
.support-ticket-page .customer-ticket-detail-title {
  max-width: min(820px, 100%);
  margin: 10px 0 8px;
  color: var(--text);
  font-size: clamp(30px, 3.2vw, 46px);
  line-height: 1.05;
  letter-spacing: -.045em;
  overflow-wrap: anywhere;
}

.support-ticket-page .customer-ticket-detail-lead {
  max-width: 820px;
  margin-bottom: 0;
  color: var(--muted);
  font-size: 16px;
  line-height: 1.45;
}

.support-ticket-page .portal-card-head.portal-profile-hero {
  display: grid;
  grid-template-columns: minmax(0, 1fr) auto;
  align-items: start;
  gap: 20px;
  padding-top: 4px;
  margin-bottom: 8px;
}

.support-ticket-page .ticket-detail-actions {
  display: flex;
  flex-wrap: wrap;
  justify-content: flex-end;
  gap: 10px;
  min-width: fit-content;
}

@media (max-width: 860px) {
  .support-ticket-page .portal-card-head.portal-profile-hero {
    grid-template-columns: 1fr;
  }

  .support-ticket-page .ticket-detail-actions {
    justify-content: flex-start;
    min-width: 0;
  }

  .support-ticket-page .customer-ticket-detail-title {
    font-size: clamp(28px, 8vw, 38px);
  }
}


/* Phase 3.08.9 - Kundenportal Ticket Body Formatierung */
.ticket-message-body-text {
  margin: 0;
  color: var(--text);
  font-size: 16px;
  line-height: 1.7;
  overflow-wrap: anywhere;
}

.customer-ticket-quoted-mail {
  margin-top: 14px;
  padding-top: 12px;
  border-top: 1px dashed rgba(255,255,255,.12);
}

.customer-ticket-quoted-mail summary {
  display: inline-flex;
  align-items: center;
  min-height: 34px;
  padding: 0 12px;
  color: var(--muted);
  background: rgba(255,255,255,.045);
  border: 1px solid rgba(255,255,255,.10);
  border-radius: 999px;
  font-size: 12px;
  font-weight: 600;
  letter-spacing: .02em;
  cursor: pointer;
  transition: border-color .16s ease, color .16s ease, background .16s ease;
}

.customer-ticket-quoted-mail summary:hover,
.customer-ticket-quoted-mail[open] summary {
  color: var(--text);
  border-color: rgba(79, 143, 209,.28);
  background: rgba(79, 143, 209,.08);
}

.customer-ticket-quoted-mail-body {
  margin-top: 12px;
  padding: 14px 16px;
  color: var(--muted);
  background: rgba(9, 9, 10,.46);
  border: 1px solid rgba(255,255,255,.08);
  border-radius: 16px;
  font-size: 14px;
  line-height: 1.65;
  overflow-wrap: anywhere;
}


/* Phase 3.09.0 - Kundenportal Ticketverlauf Bubble UI */
.support-ticket-page .ticket-thread {
  position: relative;
  gap: 18px;
  margin-top: 22px;
  padding: 18px;
  background:
    linear-gradient(180deg, rgba(255,255,255,.026), rgba(255,255,255,.012)),
    rgba(10, 10, 11,.22);
  border: 1px solid rgba(255,255,255,.055);
  border-radius: 22px;
}

.support-ticket-page .customer-ticket-message {
  position: relative;
  width: fit-content;
  max-width: min(78%, 820px);
  padding: 18px 20px;
  border-radius: 22px;
  box-shadow: 0 18px 42px rgba(0,0,0,.18);
}

.support-ticket-page .customer-ticket-message header {
  margin-bottom: 12px;
}

.support-ticket-page .customer-ticket-message header strong {
  color: var(--text);
  font-size: 15px;
}

.support-ticket-page .customer-ticket-message header span {
  display: inline-flex;
  align-items: center;
  min-height: 24px;
  padding: 0 9px;
  color: var(--muted);
  background: rgba(255,255,255,.05);
  border: 1px solid rgba(255,255,255,.07);
  border-radius: 999px;
  font-size: 12px;
  font-weight: 800;
}

.support-ticket-page .customer-ticket-message.is-support {
  justify-self: start;
  border-color: rgba(79, 143, 209,.20);
  background:
    linear-gradient(145deg, rgba(79, 143, 209,.10), rgba(255,255,255,.025)),
    rgba(25, 25, 28,.72);
  border-top-left-radius: 8px;
}

.support-ticket-page .customer-ticket-message.is-customer {
  justify-self: end;
  border-color: rgba(79, 143, 209,.24);
  background:
    linear-gradient(145deg, rgba(79, 143, 209,.13), rgba(255,255,255,.025)),
    rgba(20, 20, 22,.78);
  border-top-right-radius: 8px;
}

.support-ticket-page .customer-ticket-message.is-system {
  justify-self: center;
  max-width: min(92%, 780px);
  background: rgba(255,255,255,.035);
  border-style: dashed;
}

.support-ticket-page .customer-ticket-message.is-customer header {
  justify-content: flex-end;
}

.support-ticket-page .customer-ticket-message.is-customer .ticket-message-body-text,
.support-ticket-page .customer-ticket-message.is-customer .ticket-attachment-list,
.support-ticket-page .customer-ticket-message.is-customer .customer-ticket-quoted-mail {
  text-align: left;
}

.support-ticket-page .customer-ticket-message.is-customer::after,
.support-ticket-page .customer-ticket-message.is-support::after {
  content: "";
  position: absolute;
  top: 15px;
  width: 10px;
  height: 18px;
  background: inherit;
  border: inherit;
  transform: rotate(45deg);
}

.support-ticket-page .customer-ticket-message.is-support::after {
  left: -5px;
  border-top: 0;
  border-right: 0;
}

.support-ticket-page .customer-ticket-message.is-customer::after {
  right: -5px;
  border-bottom: 0;
  border-left: 0;
}

.support-ticket-page .customer-ticket-message .ticket-message-body-text {
  color: #dce6f8;
}

.support-ticket-page .customer-ticket-message.is-customer .ticket-message-body-text {
  color: #eef7e9;
}

.support-ticket-page .customer-ticket-message .ticket-attachment-list {
  margin-top: 14px;
}

.support-ticket-page .customer-ticket-message .ticket-attachment-link {
  min-height: 34px;
  background: rgba(79, 143, 209,.14);
  border-color: rgba(79, 143, 209,.28);
}

.support-ticket-page .customer-ticket-message.is-customer .ticket-attachment-link {
  color: #eef7e9;
  background: rgba(79, 143, 209,.13);
  border-color: rgba(79, 143, 209,.28);
}

.support-ticket-page .ticket-reply-form {
  margin-top: 22px;
  padding: 20px;
  background: rgba(255,255,255,.028);
  border: 1px solid rgba(255,255,255,.075);
  border-radius: 22px;
}

.support-ticket-page .ticket-reply-form textarea {
  min-height: 150px;
}

@media (max-width: 900px) {
  .support-ticket-page .ticket-thread {
    padding: 12px;
  }

  .support-ticket-page .customer-ticket-message {
    max-width: 100%;
    width: 100%;
    justify-self: stretch;
  }

  .support-ticket-page .customer-ticket-message.is-customer,
  .support-ticket-page .customer-ticket-message.is-support {
    border-top-left-radius: 18px;
    border-top-right-radius: 18px;
  }

  .support-ticket-page .customer-ticket-message.is-customer::after,
  .support-ticket-page .customer-ticket-message.is-support::after {
    display: none;
  }

  .support-ticket-page .customer-ticket-message.is-customer header {
    justify-content: flex-start;
  }
}


/* Phase 3.10.8 - Support-Signatur im Kundenportal */
.ticket-message-signature {
  margin-top: 18px;
  padding-top: 14px;
  color: var(--muted);
  border-top: 1px solid var(--line);
  font-size: 14px;
}


/* Phase 3.10.11 - Support-Signatur Formatierung erhalten
   Die Signatur wird im Kundenportal als Text ausgegeben.
   `pre-wrap` erhält exakt die eingegebenen Zeilenumbrüche und Leerzeilen.
*/
.ticket-message-signature {
  white-space: pre-wrap !important;
  overflow-wrap: anywhere;
}

/* Kundenportal Zwei-Faktor-Authentifizierung
   ------------------------------------------------------------
   QR-Code-Setup und Login-Historie. CSS ist nur Darstellung; Kundenisolation,
   2FA-Prüfung und Lockout erfolgen serverseitig.
*/
.two-factor-setup-grid {
  display: grid;
  grid-template-columns: 220px minmax(0, 1fr);
  gap: 24px;
  align-items: center;
  margin: 20px 0;
}

.two-factor-qr-box {
  background: #fff;
  border-radius: 18px;
  padding: 14px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  max-width: 220px;
}

.two-factor-qr-box img {
  display: block;
  width: 190px;
  height: 190px;
}

.danger-zone-inline {
  margin-top: 18px;
}

@media (max-width: 780px) {
  .two-factor-setup-grid {
    grid-template-columns: 1fr;
  }
}


/* Phase 3.10.16 - Kundenportal Kontosicherheit UI Cleanup
   ------------------------------------------------------------
   Die Kontosicherheitsseite wird als funktionales Security-Center dargestellt.
   CSS bleibt reine Darstellung; 2FA, Login-Historie und Kundenisolation werden
   weiterhin ausschließlich serverseitig geprüft.
*/
.customer-security-page {
  padding: 54px 0 88px;
}

.customer-security-shell {
  display: grid;
  gap: 24px;
}

.customer-security-header {
  display: flex;
  align-items: flex-end;
  justify-content: space-between;
  gap: 24px;
  padding: 28px;
  background:
    linear-gradient(135deg, rgba(79, 143, 209,.12), rgba(79, 143, 209,.045)),
    rgba(11, 11, 12,.74);
  border: 1px solid var(--border-soft);
  border-radius: 28px;
  box-shadow: 0 22px 70px rgba(0,0,0,.30);
}

.customer-security-header-copy {
  max-width: 780px;
}

.customer-security-header h1 {
  max-width: none;
  margin-bottom: 12px;
  font-size: clamp(38px, 4.2vw, 64px);
  line-height: .96;
  letter-spacing: -.055em;
}

.customer-security-header p {
  max-width: 680px;
  margin-bottom: 0;
  color: var(--text-muted);
  font-size: 17px;
}

.customer-security-header-actions {
  flex: 0 0 auto;
}

.customer-security-alert {
  padding: 16px 18px;
  border: 1px solid var(--border-soft);
  border-radius: 18px;
  font-weight: 600;
}

.customer-security-alert.success {
  color: var(--acid);
  background: rgba(79, 143, 209,.08);
  border-color: rgba(79, 143, 209,.22);
}

.customer-security-grid {
  display: grid;
  grid-template-columns: minmax(0, 1.45fr) minmax(320px, .55fr);
  gap: 24px;
  align-items: start;
}

.customer-security-card {
  position: relative;
  overflow: hidden;
  padding: 26px;
  background:
    linear-gradient(145deg, rgba(255,255,255,.066), rgba(255,255,255,.018)),
    rgba(15, 15, 17,.80);
  border: 1px solid var(--border-soft);
  border-radius: 26px;
  box-shadow: 0 22px 70px rgba(0,0,0,.28);
}

.customer-security-card::before {
  content: "";
  position: absolute;
  inset: 0 0 auto;
  height: 2px;
  background: linear-gradient(90deg, rgba(79, 143, 209,.85), rgba(79, 143, 209,.65), transparent);
  opacity: .78;
}

.customer-security-card-head {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 18px;
  margin-bottom: 22px;
}

.customer-security-card-head.compact {
  margin-bottom: 16px;
}

.customer-security-card-head h2 {
  margin-bottom: 8px;
  font-size: clamp(26px, 2.2vw, 38px);
  line-height: 1;
  letter-spacing: -.05em;
}

.customer-security-card-head p {
  margin-bottom: 0;
  color: var(--text-muted);
}

.customer-security-label {
  display: inline-flex;
  margin-bottom: 8px;
  color: var(--acid);
  font-size: 12px;
  font-weight: 800;
  letter-spacing: .11em;
  text-transform: uppercase;
}

.customer-security-badge {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-height: 30px;
  padding: 0 12px;
  border: 1px solid rgba(255,255,255,.12);
  border-radius: 999px;
  color: var(--text);
  background: rgba(255,255,255,.06);
  font-size: 12px;
  font-weight: 800;
  white-space: nowrap;
}

.customer-security-badge.success {
  color: #06101f;
  background: var(--acid);
  border-color: var(--acid);
}

.customer-security-badge.warn {
  color: #171003;
  background: #ffd166;
  border-color: #ffd166;
}

.customer-security-badge.danger {
  color: #260707;
  background: #ff8a8a;
  border-color: #ff8a8a;
}

.customer-security-badge.neutral {
  color: var(--text);
  background: rgba(79, 143, 209,.14);
  border-color: rgba(79, 143, 209,.28);
}

.customer-security-setup {
  display: grid;
  grid-template-columns: 214px minmax(0, 1fr);
  gap: 24px;
  align-items: center;
  margin-bottom: 24px;
  padding: 18px;
  background: rgba(10, 10, 11,.38);
  border: 1px solid var(--border-soft);
  border-radius: 22px;
}

.customer-security-qr-frame {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 214px;
  height: 214px;
  padding: 13px;
  background: #fff;
  border-radius: 18px;
  box-shadow: 0 18px 46px rgba(0,0,0,.26);
}

.customer-security-qr-frame img {
  display: block;
  width: 188px;
  height: 188px;
}

.customer-security-setup-copy h3,
.customer-security-enabled-state h3 {
  margin-bottom: 8px;
  font-size: 22px;
  letter-spacing: -.035em;
}

.customer-security-setup-copy p,
.customer-security-enabled-state p {
  margin-bottom: 16px;
  color: var(--text-muted);
}

.customer-security-secret {
  display: grid;
  gap: 7px;
}

.customer-security-secret span {
  color: var(--dim);
  font-size: 12px;
  font-weight: 600;
  letter-spacing: .08em;
  text-transform: uppercase;
}

.customer-security-secret code {
  display: block;
  padding: 13px 14px;
  color: var(--text);
  background: rgba(0,0,0,.34);
  border: 1px solid var(--border-soft);
  border-radius: 14px;
  font-family: ui-monospace, SFMono-Regular, Menlo, Monaco, Consolas, "Liberation Mono", monospace;
  font-size: 13px;
  letter-spacing: .08em;
  overflow-wrap: anywhere;
}

.customer-security-form {
  display: grid;
  gap: 18px;
}

.customer-security-form-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 16px;
}

.customer-security-form label,
.customer-security-disable-form label {
  display: grid;
  gap: 8px;
}

.customer-security-form label > span:first-child,
.customer-security-disable-form label > span:first-child {
  color: var(--text);
  font-size: 13px;
  font-weight: 600;
}

.customer-security-form input,
.customer-security-disable-form input {
  width: 100%;
  min-height: 52px;
  padding: 0 16px;
  color: var(--text);
  background: rgba(10, 10, 11,.86);
  border: 1px solid var(--border);
  border-radius: 14px;
  box-shadow: inset 0 1px 0 rgba(255,255,255,.03);
}

.customer-security-form input:focus,
.customer-security-disable-form input:focus {
  outline: none;
  border-color: rgba(79, 143, 209,.48);
  box-shadow: 0 0 0 4px rgba(79, 143, 209,.12);
}

.customer-security-form-actions {
  display: flex;
  align-items: center;
  gap: 16px;
  padding-top: 2px;
}

.customer-security-form-actions p {
  max-width: 440px;
  margin-bottom: 0;
  color: var(--dim);
  font-size: 13px;
}

.customer-security-enabled-state {
  display: flex;
  gap: 16px;
  align-items: flex-start;
  margin-bottom: 22px;
  padding: 18px;
  background: rgba(79, 143, 209,.07);
  border: 1px solid rgba(79, 143, 209,.18);
  border-radius: 20px;
}

.customer-security-icon-lock {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  flex: 0 0 auto;
  width: 42px;
  height: 42px;
  color: #06101f;
  background: var(--acid);
  border-radius: 999px;
  font-weight: 800;
}

.customer-security-disable-form {
  max-width: 520px;
}

.btn.danger {
  color: #fff;
  background: rgba(255,87,87,.18);
  border-color: rgba(255,138,138,.38);
  font-weight: 600;
}

.customer-security-summary-text {
  margin-bottom: 18px;
  color: var(--text-muted);
}

.customer-security-facts {
  display: grid;
  gap: 12px;
  margin: 0 0 18px;
}

.customer-security-facts div {
  padding: 14px 15px;
  background: rgba(10, 10, 11,.44);
  border: 1px solid var(--border-soft);
  border-radius: 16px;
}

.customer-security-facts dt {
  color: var(--dim);
  font-size: 11px;
  font-weight: 700;
  letter-spacing: .08em;
  text-transform: uppercase;
}

.customer-security-facts dd {
  margin: 5px 0 0;
  color: var(--text);
  font-weight: 600;
  overflow-wrap: anywhere;
}

.customer-security-note-box {
  padding: 16px;
  background: rgba(79, 143, 209,.08);
  border: 1px solid rgba(79, 143, 209,.18);
  border-radius: 18px;
}

.customer-security-note-box strong {
  display: block;
  margin-bottom: 6px;
  color: var(--text);
}

.customer-security-note-box p {
  margin-bottom: 0;
  color: var(--text-muted);
  font-size: 14px;
}

.customer-security-history-card {
  padding-bottom: 18px;
}

.customer-security-table-wrap {
  overflow-x: auto;
  border: 1px solid var(--border-soft);
  border-radius: 18px;
  background: rgba(10, 10, 11,.32);
}

.customer-security-table {
  width: 100%;
  border-collapse: collapse;
  min-width: 920px;
}

.customer-security-table th,
.customer-security-table td {
  padding: 15px 16px;
  text-align: left;
  border-bottom: 1px solid var(--border-soft);
  vertical-align: top;
}

.customer-security-table th {
  color: var(--dim);
  background: rgba(255,255,255,.035);
  font-size: 11px;
  font-weight: 800;
  letter-spacing: .08em;
  text-transform: uppercase;
  white-space: nowrap;
}

.customer-security-table td {
  color: var(--text);
  font-size: 14px;
}

.customer-security-table tr:last-child td {
  border-bottom: 0;
}

.customer-security-table small {
  display: block;
  margin-top: 7px;
  color: var(--dim);
  font-size: 12px;
}

.customer-security-empty-row {
  color: var(--text-muted) !important;
}

@media (max-width: 1100px) {
  .customer-security-grid {
    grid-template-columns: 1fr;
  }

  .customer-security-summary-card {
    order: -1;
  }
}

@media (max-width: 780px) {
  .customer-security-page {
    padding: 34px 0 62px;
  }

  .customer-security-header,
  .customer-security-card-head,
  .customer-security-form-actions {
    align-items: stretch;
    flex-direction: column;
  }

  .customer-security-header,
  .customer-security-card {
    padding: 22px;
  }

  .customer-security-setup,
  .customer-security-form-grid {
    grid-template-columns: 1fr;
  }

  .customer-security-qr-frame {
    width: 100%;
    max-width: 214px;
  }

  .customer-security-form-actions .btn {
    width: 100%;
  }
}

@media (max-width: 640px) {
  .customer-security-header h1 {
    font-size: clamp(34px, 12vw, 48px);
  }

  .customer-security-table {
    min-width: 0;
  }

  .customer-security-table thead {
    display: none;
  }

  .customer-security-table,
  .customer-security-table tbody,
  .customer-security-table tr,
  .customer-security-table td {
    display: block;
    width: 100%;
  }

  .customer-security-table tr {
    padding: 12px 0;
    border-bottom: 1px solid var(--border-soft);
  }

  .customer-security-table tr:last-child {
    border-bottom: 0;
  }

  .customer-security-table td {
    display: grid;
    grid-template-columns: 120px minmax(0, 1fr);
    gap: 12px;
    padding: 8px 14px;
    border-bottom: 0;
  }

  .customer-security-table td::before {
    content: attr(data-label);
    color: var(--dim);
    font-size: 11px;
    font-weight: 800;
    letter-spacing: .07em;
    text-transform: uppercase;
  }

  .customer-security-empty-row {
    display: block !important;
  }

  .customer-security-empty-row::before {
    display: none;
  }
}


/* Phase 3.11.1 - Kunden-Ticket-Glocke und Antwortstatus
   ------------------------------------------------------------
   UI-Hinweis im Kundenbereich. Die echte Kundenisolation erfolgt serverseitig
   über /Kunden/Tickets/Benachrichtigungen und den Customer-SignalR-Hub.
*/
.frontend-account {
  gap: 10px;
}

.customer-ticket-notification-menu {
  position: relative;
}

.customer-ticket-notification-trigger {
  position: relative;
  display: inline-grid;
  place-items: center;
  width: 44px;
  height: 44px;
  color: var(--muted);
  background: rgba(255,255,255,.055);
  border: 1px solid var(--line-strong);
  border-radius: 999px;
  cursor: pointer;
  transition: background .16s ease, color .16s ease, border-color .16s ease, transform .16s ease;
}

.customer-ticket-notification-trigger:hover,
.customer-ticket-notification-menu.open .customer-ticket-notification-trigger,
.customer-ticket-notification-menu.has-unread .customer-ticket-notification-trigger {
  color: var(--text);
  background: rgba(79, 143, 209,.1);
  border-color: rgba(79, 143, 209,.38);
}

.customer-ticket-notification-menu.has-fresh-update .customer-ticket-notification-trigger {
  transform: translateY(-1px) scale(1.04);
}

.customer-ticket-notification-icon,
.customer-ticket-notification-icon svg {
  display: block;
  width: 19px;
  height: 19px;
}

.customer-ticket-notification-icon svg {
  fill: currentColor;
}

.customer-ticket-notification-count {
  position: absolute;
  top: -5px;
  right: -5px;
  min-width: 21px;
  height: 21px;
  padding: 0 6px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  color: #07101e;
  background: var(--acid);
  border: 2px solid #16161a;
  border-radius: 999px;
  font-size: 11px;
  font-weight: 800;
  line-height: 1;
}

.customer-ticket-notification-dropdown {
  position: absolute;
  top: calc(100% + 12px);
  right: 0;
  z-index: 55;
  display: none;
  width: min(380px, calc(100vw - 26px));
  padding: 14px;
  background:
    linear-gradient(145deg, rgba(255,255,255,.07), rgba(255,255,255,.018)),
    #16161a;
  border: 1px solid var(--line-strong);
  border-radius: 20px;
  box-shadow: 0 28px 90px rgba(0,0,0,.5);
}

.customer-ticket-notification-menu.open .customer-ticket-notification-dropdown {
  display: block;
}

.customer-ticket-notification-dropdown header {
  display: grid;
  gap: 4px;
  padding: 6px 6px 12px;
  border-bottom: 1px solid var(--line);
}

.customer-ticket-notification-dropdown header strong {
  color: var(--text);
  font-size: 15px;
}

.customer-ticket-notification-dropdown header span,
.customer-ticket-notification-empty {
  color: var(--muted);
  font-size: 13px;
}

.customer-ticket-notification-list {
  display: grid;
  gap: 8px;
  max-height: 330px;
  overflow: auto;
  padding: 10px 0;
}

.customer-ticket-notification-item {
  display: grid;
  gap: 4px;
  padding: 11px 12px;
  color: var(--muted);
  text-decoration: none;
  background: rgba(79, 143, 209,.055);
  border: 1px solid rgba(79, 143, 209,.16);
  border-radius: 14px;
}

.customer-ticket-notification-item:hover {
  color: var(--text);
  background: rgba(79, 143, 209,.095);
  border-color: rgba(79, 143, 209,.3);
}

.customer-ticket-notification-item strong {
  color: var(--text);
  font-size: 13px;
  line-height: 1.3;
}

.customer-ticket-notification-item span {
  color: var(--acid);
  font-size: 12px;
  font-weight: 700;
}

.customer-ticket-notification-item small {
  color: var(--muted);
  font-size: 12px;
}

.customer-ticket-notification-empty {
  padding: 18px 8px;
  text-align: center;
}

.customer-ticket-notification-all {
  display: flex;
  align-items: center;
  justify-content: center;
  min-height: 38px;
  color: #07101e;
  background: var(--acid);
  border-radius: 12px;
  font-size: 13px;
  font-weight: 800;
  text-decoration: none;
}

.ticket-row-has-answer {
  background: rgba(255,255,255,.018);
}

.ticket-answer-state,
.ticket-answer-meta {
  display: block;
}

.ticket-answer-state {
  color: var(--muted);
  font-size: 13px;
  font-weight: 700;
}

.ticket-answer-state.unread {
  color: var(--acid);
}

.ticket-answer-state.read {
  color: var(--text);
}

.ticket-answer-state.none {
  color: rgba(165,174,192,.68);
}

.ticket-answer-meta {
  margin-top: 4px;
  color: var(--muted);
  font-size: 12px;
}

@media (max-width: 980px) {
  .customer-ticket-notification-dropdown {
    right: -54px;
  }
}

@media (max-width: 720px) {
  .support-ticket-table th:nth-child(2),
  .support-ticket-table td:nth-child(2) {
    display: none;
  }

  .customer-ticket-notification-trigger {
    width: 40px;
    height: 40px;
  }
}



/*
  ====================================================================
  Phase 3.11.8 - Frontend Template Footer Rebuild
  ====================================================================

  Zweck:
  Diese Regeln ersetzen die früheren Footer-Fixes durch ein einziges
  stabiles Seitenmodell für das gesamte öffentliche Frontend.

  Aufbau:
  - body.site-shell bildet die echte Seitenschale.
  - Header, Main und Footer sind feste Layoutbereiche.
  - Der Main-Bereich trägt den bisherigen HTMO-Rasterhintergrund.
  - Der Footer ist ein eigener, deckender Abschlussbereich.

  Sicherheitsregel:
  Diese CSS-Regeln sind reine Darstellung. Sie ersetzen keine serverseitige
  Rechteprüfung, keine Kundenisolation und keine SignalR-Filterung.
  ====================================================================
*/

:root {
  --layout-container: 1220px;
  --layout-container-padding: 38px;
  --layout-header-height: 82px;
  --layout-section-y: clamp(64px, 7vw, 96px);
  --layout-section-y-compact: clamp(42px, 5vw, 72px);
  --layout-card-padding: clamp(22px, 2.6vw, 34px);
  --layout-card-gap: 22px;
  --layout-footer-padding-y: clamp(48px, 5vw, 72px);
}

html {
  min-height: 100%;
  background: #0a0a0b;
  scroll-behavior: smooth;
}

/* Echte Seitenschale:
   Bei kurzen Seiten nimmt der Main-Bereich den freien Platz ein.
   Der Footer bleibt dadurch mit seiner Unterkante am Viewport-Ende.
   Bei langen Seiten wächst der Main-Bereich normal mit dem Inhalt. */
body.site-shell {
  display: grid;
  grid-template-rows: auto minmax(0, 1fr) auto;
  min-height: 100vh;
  background: #0a0a0b;
}

@supports (min-height: 100svh) {
  body.site-shell {
    min-height: 100svh;
  }
}

@supports (min-height: 100dvh) {
  body.site-shell {
    min-height: 100dvh;
  }
}

.site-header,
.site-main,
.site-footer {
  min-width: 0;
}

.site-main,
.site-footer {
  position: relative;
  z-index: 1;
}

/* Header bleibt optisch wie bisher, sitzt aber sauber als erste Layout-Zeile. */
.site-header {
  grid-row: 1;
  min-height: var(--layout-header-height);
}

.header-inner {
  min-height: var(--layout-header-height);
}

/* Hauptbereich:
   Der bisherige HTMO-Hintergrund liegt bewusst nur im Main.
   Dadurch kann unterhalb des Footers kein Raster-/Gradienten-Leerraum mehr erscheinen. */
.site-main {
  grid-row: 2;
  min-height: 0;
  background:
    linear-gradient(rgba(255,255,255,.028) 1px, transparent 1px),
    linear-gradient(90deg, rgba(255,255,255,.026) 1px, transparent 1px),
    radial-gradient(circle at 15% 5%, rgba(79, 143, 209, .22), transparent 34rem),
    radial-gradient(circle at 90% 20%, rgba(79, 143, 209, .11), transparent 28rem),
    radial-gradient(circle at 70% 85%, rgba(201, 138, 75, .10), transparent 32rem),
    linear-gradient(180deg, #0b0e15, #07080c 68%);
  background-size: 38px 38px, 38px 38px, auto, auto, auto, auto;
}

/* Direkte Seitenbereiche dürfen keine alten Footer-Fixes erben.
   Abstand entsteht über Seiten-Padding, nicht über Footer-Verschiebung. */
.site-main > section:last-child,
.site-main > .container:last-child,
.site-main > .portal-page:last-child,
.site-main > .customer-profile-page:last-child,
.site-main > .customer-password-page:last-child,
.site-main > .customer-security-page:last-child,
.site-main > .support-ticket-page:last-child,
.site-main > .portal-status-page:last-child {
  margin-bottom: 0;
}

/* Öffentliche Standardsektionen behalten die vorhandene HTMO-Optik,
   bekommen aber einheitlichere vertikale Grundabstände. */
.section {
  padding-top: var(--layout-section-y);
  padding-bottom: var(--layout-section-y);
}

.hero {
  padding-top: clamp(86px, 8vw, 118px);
  padding-bottom: clamp(72px, 7vw, 96px);
}

.page-hero,
.slim-hero,
.portal-page,
.customer-profile-page,
.customer-password-page,
.customer-security-page,
.portal-status-page,
.support-ticket-page {
  padding-top: var(--layout-section-y-compact);
  padding-bottom: var(--layout-section-y-compact);
}

/* Kundenkonto-Seiten:
   Keine künstlichen Mindesthöhen mehr. Der globale Main-Bereich erledigt
   den Sticky-Footer. Die Seiten selbst bleiben nur für ihren Inhalt zuständig. */
.customer-profile-page,
.customer-password-page,
.customer-security-page {
  min-height: 0;
}

.container,
.portal-page .container,
.customer-security-shell {
  width: min(var(--layout-container), calc(100% - var(--layout-container-padding)));
  margin-inline: auto;
}

.logo-brand img {
  display: block;
  height: auto;
  max-height: 62px;
}

/* Einheitliche Kartenbasis für Frontend und Kundenportal.
   Die Farben und Radien bleiben im bestehenden HTMO-Stil. */
.feature-card,
.project-card,
.price-card,
.blog-card,
.release-card,
.contact-form,
.contact-card,
.portal-card,
.hero-card,
.portal-status-card,
.portal-dashboard-hero,
.portal-dashboard-side,
.portal-module-card,
.portal-documents-shell,
.customer-security-card,
.support-ticket-shell,
.portal-form-card,
.customer-auth-card,
.customer-profile-panel {
  border-radius: var(--radius);
}

.portal-card,
.hero-card,
.portal-status-card,
.portal-dashboard-hero,
.portal-dashboard-side,
.portal-module-card,
.portal-documents-shell,
.customer-security-card,
.portal-form-card,
.customer-auth-card,
.customer-profile-panel {
  padding: var(--layout-card-padding);
}

.feature-grid,
.project-grid,
.price-grid,
.blog-grid,
.portal-dashboard-cards,
.portal-document-grid,
.ticket-topic-grid,
.support-topic-grid,
.customer-security-grid,
.customer-profile-layout,
.portal-form-grid {
  gap: var(--layout-card-gap);
}

/* Formulare bleiben dunkel und technisch, aber mit konsistentem Radius. */
input,
textarea,
select {
  min-width: 0;
}

.portal-form-card input,
.portal-form-card textarea,
.portal-form-card select,
.customer-auth-card input,
.customer-security-form input,
.support-ticket-form textarea,
.ticket-reply-form textarea {
  border-radius: var(--radius-sm);
}

/* Footer:
   Der Footer ist der abschließende Block der Seite. Er ist deckend, besitzt
   keine automatische Verschiebung und keinen transparenten Rasterbereich.
   Seine Unterkante liegt bei kurzen Seiten direkt am Viewport-Ende, weil die
   Grid-Shell den freien Platz dem Main zuweist. */
.site-footer {
  grid-row: 3;
  margin: 0;
  padding: var(--layout-footer-padding-y) 0;
  background:
    radial-gradient(circle at 22% 0%, rgba(79, 143, 209, .08), transparent 28rem),
    linear-gradient(180deg, #0a0a0b 0%, #0a0a0b 100%);
  border-top: 1px solid rgba(255, 255, 255, .10);
  box-shadow: none;
}

.footer-grid,
.site-footer .footer-grid {
  display: grid;
  grid-template-columns: minmax(0, 1.35fr) minmax(170px, .55fr) minmax(170px, .55fr);
  gap: clamp(30px, 5vw, 76px);
  align-items: start;
  width: min(1120px, calc(100% - var(--layout-container-padding)));
  margin: 0 auto;
}

.site-footer p {
  max-width: 620px;
  margin: 0;
  color: var(--muted);
}

.site-footer h3 {
  margin-bottom: 12px;
  color: var(--text);
}

.site-footer a {
  display: block;
  margin: 8px 0;
  color: var(--muted);
}

.site-footer a:hover {
  color: var(--text);
}

.footer-brand {
  margin-bottom: 14px;
}

.footer-brand img {
  width: min(235px, 58vw);
}

/* Tastatur-Navigation: visuell erst bei Fokus sichtbar. */
.skip-link {
  position: fixed;
  left: 16px;
  top: 12px;
  z-index: 1000;
  padding: 10px 14px;
  color: #06101f;
  background: var(--acid);
  border-radius: 999px;
  font-weight: 700;
  transform: translateY(-160%);
  transition: transform .18s ease;
}

.skip-link:focus {
  transform: translateY(0);
}

@media (max-width: 980px) {
  :root {
    --layout-container-padding: 34px;
    --layout-header-height: 74px;
  }

  .footer-grid,
  .site-footer .footer-grid {
    grid-template-columns: 1fr 1fr;
  }

  .footer-grid > div:first-child,
  .site-footer .footer-grid > div:first-child {
    grid-column: 1 / -1;
  }
}

@media (max-width: 720px) {
  :root {
    --layout-container-padding: 28px;
    --layout-section-y: 48px;
    --layout-section-y-compact: 38px;
    --layout-footer-padding-y: 36px;
  }

  .footer-grid,
  .site-footer .footer-grid {
    grid-template-columns: 1fr;
    gap: 22px;
  }
}

/* Kundenportal: kompakte Statusmarken
   ------------------------------------------------------------
   Der Status wird serverseitig gesetzt;
   Farben sind ausschließlich visuelle Orientierung.
*/
.portal-ticket-state {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-height: 32px;
  padding: 0 12px;
  border-radius: 999px;
  font-size: 12px;
  font-weight: 700;
  white-space: nowrap;
}

.portal-ticket-state.is-neutral {
  color: var(--muted);
  background: rgba(255, 255, 255, .06);
  border: 1px solid var(--line);
}

.portal-ticket-state.is-open {
  color: #06101f;
  background: var(--acid);
}

.portal-ticket-state.is-waiting {
  color: #1b1205;
  background: rgba(245, 165, 36, .95);
}

.portal-ticket-state.is-closed {
  color: #eaffd5;
  background: rgba(47, 179, 68, .22);
  border: 1px solid rgba(47, 179, 68, .35);
}

.portal-ticket-state.is-overdue {
    border-color: rgba(248, 113, 113, .52);
    background: rgba(127, 29, 29, .28);
    color: #fecaca;
}

/* Phase 3.15.1 - Wartung und Fehlerseiten
   ------------------------------------------------------------
   Eigenständige öffentliche Systemseiten für Wartungsmodus, 404, 403 und 500.
   Sicherheit: CSS ist nur Darstellung. Wartungssperre und Staff-Bypass laufen
   serverseitig über FrontendMaintenanceModeMiddleware.
*/
.status-standalone {
  min-height: 100vh;
  background:
    radial-gradient(circle at 18% 10%, rgba(79, 143, 209, 0.17), transparent 32%),
    radial-gradient(circle at 78% 18%, rgba(79, 143, 209, 0.10), transparent 34%),
    linear-gradient(135deg, #0a0a0b 0%, #080d16 48%, #0b1019 100%);
}

.status-standalone::before {
  opacity: 0.42;
}

.status-page {
  min-height: 100vh;
  display: flex;
  align-items: center;
  padding: clamp(32px, 6vw, 86px) 0;
  position: relative;
  z-index: 1;
}

.status-page::before {
  content: "";
  position: fixed;
  inset: 0;
  pointer-events: none;
  background-image:
    linear-gradient(rgba(255,255,255,0.035) 1px, transparent 1px),
    linear-gradient(90deg, rgba(255,255,255,0.035) 1px, transparent 1px);
  background-size: 32px 32px;
  mask-image: linear-gradient(to bottom, rgba(0,0,0,0.95), transparent 88%);
}

.status-shell {
  width: min(1180px, calc(100% - 36px));
  display: grid;
  grid-template-columns: minmax(0, 1.08fr) minmax(320px, 0.62fr);
  gap: 24px;
  align-items: stretch;
}

.status-card,
.status-side-panel {
  border: 1px solid rgba(255, 255, 255, 0.12);
  background:
    linear-gradient(135deg, rgba(25, 25, 28, 0.92), rgba(14, 14, 15, 0.92)),
    rgba(25, 25, 28, 0.72);
  box-shadow: 0 30px 110px rgba(0, 0, 0, 0.46);
  backdrop-filter: blur(18px);
}

.status-card {
  border-radius: 34px;
  padding: clamp(26px, 4vw, 54px);
  position: relative;
  overflow: hidden;
}

.status-card::before {
  content: "";
  position: absolute;
  inset: 0 0 auto;
  height: 3px;
  background: linear-gradient(90deg, var(--electric), var(--acid));
}

.status-brand {
  display: inline-flex;
  align-items: center;
  gap: 10px;
  padding: 8px 12px;
  border: 1px solid rgba(255, 255, 255, 0.12);
  border-radius: 999px;
  background: rgba(10, 10, 11, 0.44);
  margin-bottom: clamp(26px, 5vw, 56px);
}

.status-brand img {
  width: 28px;
  height: auto;
}

.status-brand span {
  font-size: 0.78rem;
  font-weight: 700;
  letter-spacing: 0.08em;
}

.status-code {
  font-size: clamp(4.8rem, 14vw, 10.8rem);
  line-height: 0.84;
  font-weight: 800;
  letter-spacing: -0.08em;
  color: rgba(238, 243, 255, 0.92);
  text-shadow: 0 16px 70px rgba(79, 143, 209, 0.20);
  margin-bottom: 18px;
}

.status-card h1 {
  max-width: 820px;
  margin: 6px 0 16px;
  font-size: clamp(2.1rem, 4.7vw, 5.2rem);
  line-height: 0.96;
  letter-spacing: -0.055em;
}

.status-lead {
  max-width: 720px;
  color: rgba(238, 243, 255, 0.86);
  font-size: clamp(1.05rem, 1.8vw, 1.32rem);
  margin-bottom: 10px;
}

.status-detail {
  max-width: 760px;
  color: var(--muted);
}

.status-actions {
  display: flex;
  flex-wrap: wrap;
  gap: 12px;
  margin-top: clamp(24px, 4vw, 42px);
}

.status-side-panel {
  border-radius: 30px;
  padding: clamp(22px, 3vw, 34px);
  display: flex;
  flex-direction: column;
  justify-content: space-between;
  gap: 28px;
}

.status-side-panel h2 {
  margin: 8px 0 10px;
  font-size: clamp(1.45rem, 2.4vw, 2.3rem);
  letter-spacing: -0.04em;
}

.status-side-panel p {
  color: var(--muted);
}

.status-side-panel dl {
  margin: 0;
  display: grid;
  gap: 12px;
}

.status-side-panel dl div {
  padding: 14px 16px;
  border: 1px solid rgba(255, 255, 255, 0.10);
  border-radius: 18px;
  background: rgba(10, 10, 11, 0.44);
}

.status-side-panel dt {
  color: var(--dim);
  font-size: 0.76rem;
  text-transform: uppercase;
  letter-spacing: 0.08em;
}

.status-side-panel dd {
  margin: 4px 0 0;
  font-weight: 600;
  color: var(--text);
}

.maintenance-card::before {
  background: linear-gradient(90deg, var(--acid), var(--electric), var(--ember));
}

.maintenance-progress {
  width: min(480px, 100%);
  height: 10px;
  border-radius: 999px;
  overflow: hidden;
  border: 1px solid rgba(255, 255, 255, 0.12);
  background: rgba(10, 10, 11, 0.62);
  margin-top: 26px;
}

.maintenance-progress span {
  display: block;
  width: 42%;
  height: 100%;
  border-radius: inherit;
  background: linear-gradient(90deg, var(--electric), var(--acid));
  animation: htmo-maintenance-scan 2.8s ease-in-out infinite;
}

.maintenance-side-panel {
  border-color: rgba(79, 143, 209, 0.14);
  background:
    linear-gradient(135deg, rgba(79, 143, 209, 0.065), transparent 48%),
    rgba(25, 25, 28, 0.84);
}

@keyframes htmo-maintenance-scan {
  0% {
    transform: translateX(-110%);
  }
  55% {
    transform: translateX(78%);
  }
  100% {
    transform: translateX(230%);
  }
}

@media (max-width: 940px) {
  .status-shell {
    grid-template-columns: 1fr;
  }

  .status-side-panel {
    min-height: auto;
  }
}

@media (max-width: 620px) {
  .status-page {
    padding: 18px 0;
  }

  .status-shell {
    width: min(100% - 20px, 1180px);
  }

  .status-card,
  .status-side-panel {
    border-radius: 24px;
  }

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


/* Phase 3.15.2 - Dezente Wartungs- und Fehlerseiten
   ------------------------------------------------------------
   Reduziert die öffentlichen Systemseiten auf notwendige Informationen.
   Interne Zugriffsdetails werden nicht mehr angezeigt.
*/
.status-standalone-minimal .status-page {
  align-items: center;
  padding: clamp(28px, 5vw, 72px) 0;
}

.minimal-status-shell {
  width: min(760px, calc(100% - 36px));
  grid-template-columns: 1fr;
}

.minimal-status-card {
  border-radius: 28px;
  padding: clamp(28px, 5vw, 48px);
  max-width: 760px;
  margin: 0 auto;
  background:
    linear-gradient(135deg, rgba(25, 25, 28, 0.88), rgba(14, 14, 15, 0.92)),
    rgba(25, 25, 28, 0.74);
}

.minimal-status-card::before {
  height: 2px;
  opacity: 0.82;
}

.status-standalone-minimal .status-brand {
  margin-bottom: clamp(22px, 4vw, 38px);
}

.status-code-small {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-width: 58px;
  height: 36px;
  padding: 0 14px;
  margin-bottom: 22px;
  border-radius: 999px;
  border: 1px solid rgba(255, 255, 255, 0.12);
  background: rgba(10, 10, 11, 0.44);
  color: rgba(238, 243, 255, 0.78);
  font-size: 0.98rem;
  font-weight: 800;
  letter-spacing: 0.04em;
}

.minimal-status-card h1 {
  max-width: 660px;
  margin: 8px 0 14px;
  font-size: clamp(2rem, 5vw, 3.7rem);
  line-height: 1.02;
  letter-spacing: -0.048em;
  font-weight: 820;
}

.minimal-status-card .status-lead,
.maintenance-message {
  max-width: 640px;
  color: rgba(238, 243, 255, 0.86);
  font-size: clamp(1.02rem, 1.9vw, 1.24rem);
  line-height: 1.55;
  margin: 0;
}

.maintenance-message {
  padding: 18px 20px;
  margin-top: 18px;
  border-radius: 20px;
  border: 1px solid rgba(79, 143, 209, 0.13);
  background: rgba(79, 143, 209, 0.055);
}

.status-detail.minimal {
  max-width: 620px;
  margin-top: 14px;
  color: rgba(157, 169, 191, 0.92);
  font-size: 0.98rem;
}

.maintenance-progress.subtle {
  width: min(360px, 100%);
  height: 6px;
  margin-top: 24px;
  opacity: 0.74;
}

.maintenance-progress.subtle span {
  width: 34%;
  background: linear-gradient(90deg, rgba(79, 143, 209, 0.86), rgba(79, 143, 209, 0.88));
}

.status-standalone-minimal .status-actions {
  margin-top: clamp(22px, 4vw, 34px);
}

.status-standalone-minimal .btn.primary {
  box-shadow: none;
}

@media (max-width: 620px) {
  .minimal-status-shell {
    width: min(100% - 20px, 760px);
  }

  .minimal-status-card {
    border-radius: 22px;
  }

  .minimal-status-card h1 {
    font-size: clamp(1.85rem, 11vw, 3rem);
  }
}


/* Phase 3.16.0 - Öffentliche Content-Seiten
   ------------------------------------------------------------
   Darstellung veröffentlichter, serverseitig gerenderter Content-Seiten.
*/
.content-page-public {
  padding-bottom: clamp(32px, 6vw, 68px);
}

.content-public-shell {
  max-width: 980px;
}

.content-public-card {
  border: 1px solid var(--line);
  border-radius: 28px;
  background:
    linear-gradient(135deg, rgba(25, 25, 28, 0.74), rgba(11, 11, 12, 0.76)),
    rgba(25, 25, 28, 0.68);
  box-shadow: var(--shadow);
  padding: clamp(24px, 5vw, 54px);
}

.content-public-body {
  color: rgba(238, 243, 255, 0.9);
  font-size: clamp(1rem, 1.7vw, 1.12rem);
  line-height: 1.78;
}

.content-public-body p {
  margin: 0 0 1.25em;
}

.content-public-body p:last-child {
  margin-bottom: 0;
}

/* Phase 3.16.2 - Öffentliche News / Beiträge
   ------------------------------------------------------------
   Darstellung veröffentlichter ContentPosts. Die fachliche Freigabe erfolgt
   ausschließlich im NewsController über Status Published.
*/
.news-page-public {
  padding-bottom: clamp(32px, 6vw, 68px);
}

.news-public-shell {
  max-width: 1180px;
}

.news-public-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(280px, 1fr));
  gap: 20px;
}

.news-public-card {
  border: 1px solid var(--line);
  border-radius: 26px;
  background:
    linear-gradient(135deg, rgba(25, 25, 28, 0.74), rgba(11, 11, 12, 0.76)),
    rgba(25, 25, 28, 0.68);
  padding: clamp(22px, 3vw, 32px);
  box-shadow: 0 18px 60px rgba(0, 0, 0, 0.25);
  display: grid;
  gap: 14px;
  min-height: 100%;
}

.news-public-card.is-featured {
  border-color: rgba(79, 143, 209, 0.16);
  background:
    linear-gradient(135deg, rgba(79, 143, 209, 0.07), transparent 45%),
    rgba(25, 25, 28, 0.72);
}

.news-public-card-meta {
  display: flex;
  justify-content: space-between;
  gap: 12px;
  align-items: center;
}

.news-public-card time,
.news-public-date {
  color: var(--muted);
  font-size: 0.9rem;
}

.news-public-card h2 {
  margin: 0;
  font-size: clamp(1.4rem, 2.3vw, 2.15rem);
  line-height: 1.06;
  letter-spacing: -0.04em;
}

.news-public-card p {
  color: var(--muted);
  margin: 0;
}

.news-public-card .btn {
  justify-self: start;
  margin-top: 8px;
}

.news-back-row {
  margin-top: 24px;
}


/* Phase 3.16.3 - Frontend Content / News Polish
   ------------------------------------------------------------
   Ziel: Seiten und News sollen im Frontend hochwertiger, ruhiger und klarer
   lesbar wirken. Fokus auf editoriale Lesbarkeit, saubere Hierarchie und
   professionellen Gesamteindruck.
*/
.content-entry-hero {
  padding-top: clamp(78px, 9vw, 118px);
  padding-bottom: clamp(54px, 7vw, 90px);
}

.content-entry-hero-grid {
  display: grid;
  grid-template-columns: minmax(0, 1fr) minmax(260px, 320px);
  gap: 28px;
  align-items: end;
}

.content-entry-copy {
  max-width: 760px;
}

.content-entry-copy h1 {
  margin: 0;
  max-width: 820px;
  font-size: clamp(3.2rem, 7vw, 5.8rem);
  line-height: 0.94;
  letter-spacing: -0.065em;
}

.content-entry-lead {
  margin-top: 22px;
  max-width: 740px;
  color: rgba(238, 243, 255, 0.82);
  font-size: clamp(1.08rem, 1.8vw, 1.32rem);
  line-height: 1.65;
}

.content-entry-meta-card {
  padding: 24px;
  border: 1px solid rgba(255,255,255,.11);
  border-radius: 26px;
  background:
    linear-gradient(145deg, rgba(255,255,255,.07), rgba(255,255,255,.025)),
    rgba(25, 25, 28, .58);
  box-shadow: 0 20px 60px rgba(0, 0, 0, 0.25);
}

.content-entry-meta-list {
  display: grid;
  gap: 12px;
  margin: 8px 0 0;
}

.content-entry-meta-list div {
  padding: 12px 14px;
  border-radius: 16px;
  border: 1px solid rgba(255,255,255,.08);
  background: rgba(255,255,255,.03);
}

.content-entry-meta-list dt {
  margin: 0 0 4px;
  color: var(--text-muted);
  font-size: 12px;
  font-weight: 800;
  letter-spacing: .12em;
  text-transform: uppercase;
}

.content-entry-meta-list dd {
  margin: 0;
  color: rgba(238,243,255,.92);
  font-weight: 700;
  line-height: 1.5;
  overflow-wrap: anywhere;
}

.meta-inline-link {
  color: rgba(238,243,255,.92);
  text-decoration: none;
  border-bottom: 1px solid rgba(79, 143, 209,.35);
}

.meta-inline-link:hover {
  color: var(--acid);
  border-bottom-color: var(--acid);
}

.content-entry-section {
  padding-top: clamp(22px, 4vw, 34px);
}

.editorial-shell {
  max-width: 1120px;
}

.editorial-card {
  max-width: 900px;
  margin: 0 auto;
  border-radius: 30px;
  background:
    linear-gradient(135deg, rgba(22, 22, 25, 0.92), rgba(11, 11, 12, 0.92)),
    rgba(25, 25, 28, 0.72);
  border: 1px solid rgba(255,255,255,.11);
  box-shadow: 0 28px 84px rgba(0, 0, 0, 0.30);
  padding: clamp(28px, 4vw, 56px);
}

.editorial-body {
  max-width: 720px;
  margin: 0 auto;
  color: rgba(244,248,255,.92);
  font-size: clamp(1.04rem, 1.45vw, 1.16rem);
  line-height: 1.9;
}

.editorial-body p {
  margin: 0 0 1.45em;
}

.news-overview-shell {
  max-width: 980px;
}

/* News-Topkarte
   ------------------------------------------------------------
   Die Featured-Markierung ist als integrierter Kartenbereich gebaut.
   Es gibt bewusst keinen zweiten Container mit eigener Card-Optik in
   der großen News-Karte.
*/
.news-overview-copy h1 {
  margin: 0;
  font-size: clamp(3rem, 6vw, 5rem);
  line-height: 0.96;
  letter-spacing: -0.06em;
}

.news-overview-copy p {
  max-width: 760px;
  margin-top: 22px;
  color: rgba(238,243,255,.82);
  font-size: clamp(1.05rem, 1.7vw, 1.24rem);
  line-height: 1.65;
}

.news-overview-section {
  padding-top: clamp(10px, 2vw, 22px);
}

.news-featured-card {
  display: grid;
  grid-template-columns: minmax(0, 1fr);
  gap: clamp(24px, 4vw, 48px);
  align-items: center;
  margin-bottom: 24px;
  padding: clamp(26px, 4vw, 38px);
  border-radius: 30px;
  border: 1px solid rgba(79, 143, 209,.16);
  background:
    linear-gradient(135deg, rgba(79, 143, 209,.08), transparent 42%),
    linear-gradient(135deg, rgba(25, 25, 28, 0.88), rgba(11, 11, 12, 0.92));
  box-shadow: 0 24px 70px rgba(0, 0, 0, 0.28);
}

.news-featured-card.has-highlight {
  grid-template-columns: minmax(0, 1.28fr) minmax(260px, .72fr);
}

.news-featured-copy h2 {
  margin: 12px 0 12px;
  font-size: clamp(2.1rem, 3.6vw, 3.6rem);
  line-height: 0.98;
  letter-spacing: -0.05em;
}

.news-featured-copy p,
.news-featured-side p {
  color: rgba(238,243,255,.8);
  line-height: 1.7;
}

.news-featured-meta {
  display: flex;
  flex-wrap: wrap;
  gap: 10px 14px;
  align-items: center;
}

.news-featured-meta time {
  color: var(--text-muted);
  font-size: .95rem;
}

.news-featured-side {
  position: relative;
  display: grid;
  align-content: center;
  gap: 14px;
  min-height: 100%;
  padding: 6px 0 6px clamp(24px, 3vw, 34px);
}

.news-featured-side::before {
  content: "";
  position: absolute;
  left: 0;
  top: 4px;
  bottom: 4px;
  width: 1px;
  background: linear-gradient(
    to bottom,
    rgba(79, 143, 209, .72),
    rgba(79, 143, 209, .08)
  );
}

.refined-news-grid {
  grid-template-columns: repeat(auto-fit, minmax(280px, 1fr));
  gap: 22px;
}

.refined-news-card {
  gap: 12px;
  padding: 24px;
  border-radius: 24px;
  background:
    linear-gradient(135deg, rgba(22, 22, 25, 0.88), rgba(11, 11, 12, 0.92)),
    rgba(25, 25, 28, 0.72);
  border: 1px solid rgba(255,255,255,.09);
  box-shadow: 0 18px 56px rgba(0, 0, 0, 0.22);
}

.refined-news-card h2 {
  font-size: clamp(1.32rem, 2vw, 1.8rem);
  line-height: 1.12;
  letter-spacing: -0.04em;
}

.refined-news-card p {
  color: rgba(238,243,255,.76);
  line-height: 1.65;
}

.text-link {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  margin-top: 8px;
  color: var(--acid);
  font-weight: 800;
  letter-spacing: .02em;
  text-decoration: none;
}

.text-link::after {
  content: "→";
  transition: transform .18s ease;
}

.text-link:hover::after {
  transform: translateX(2px);
}

.refined-back-row {
  display: flex;
  justify-content: center;
  margin-top: 24px;
}

.empty-editorial-card {
  text-align: center;
}

@media (max-width: 980px) {
  .content-entry-hero-grid,
  .news-featured-card,
  .news-featured-card.has-highlight {
    grid-template-columns: 1fr;
  }

  .content-entry-meta-card,
  .news-featured-side {
    max-width: 620px;
  }

  .news-featured-side {
    padding: 22px 0 0;
  }

  .news-featured-side::before {
    left: 0;
    right: 0;
    top: 0;
    bottom: auto;
    width: auto;
    height: 1px;
    background: linear-gradient(
      to right,
      rgba(79, 143, 209, .72),
      rgba(79, 143, 209, .08)
    );
  }
}

@media (max-width: 640px) {
  .content-entry-copy h1,
  .news-overview-copy h1 {
    letter-spacing: -0.05em;
  }

  .editorial-card,
  .news-featured-card,
  .refined-news-card,
  .content-entry-meta-card {
    border-radius: 22px;
  }
}

.content-entry-copy > .eyebrow {
  margin-bottom: 20px;
}

.content-entry-meta-card > .eyebrow,
.news-featured-side > .eyebrow {
  margin-bottom: 16px;
}

.news-public-card-meta .eyebrow,
.news-featured-meta .eyebrow {
  margin-bottom: 0;
}


/* Phase 3.16.4 - Content Frame Layout nach 1320px-Skizze
   ------------------------------------------------------------
   Öffentliche Detailseiten bekommen einen klaren Contentrahmen:
   globaler Header -> 1320px Content-Area -> Footer.
   Die Skizzenfarben werden nicht übernommen; umgesetzt wird HTMO-Dark-Corporate.
*/
.content-frame-page {
  position: relative;
  padding: clamp(54px, 7vw, 96px) 0 clamp(76px, 8vw, 118px);
  min-height: clamp(620px, 78vh, 920px);
}

.content-frame-page::before {
  content: "";
  position: absolute;
  inset: 0;
  pointer-events: none;
  background:
    radial-gradient(circle at 18% 4%, rgba(79, 143, 209, 0.13), transparent 34%),
    radial-gradient(circle at 76% 16%, rgba(79, 143, 209, 0.08), transparent 30%),
    linear-gradient(180deg, rgba(255,255,255,0.015), transparent 32%);
}

.content-frame-shell {
  position: relative;
  width: min(1320px, calc(100% - 40px));
  max-width: 1320px;
}

.content-frame {
  position: relative;
  min-height: clamp(520px, 62vh, 760px);
  border: 1px solid rgba(255,255,255,.105);
  border-radius: 28px;
  background:
    linear-gradient(135deg, rgba(22, 22, 25, 0.88), rgba(11, 11, 12, 0.92)),
    rgba(25, 25, 28, 0.72);
  box-shadow: 0 32px 100px rgba(0, 0, 0, 0.34);
  padding: clamp(18px, 2.5vw, 30px);
  overflow: hidden;
}

.content-frame::before {
  content: "";
  position: absolute;
  inset: 0 0 auto 0;
  height: 2px;
  background: linear-gradient(90deg, var(--electric), var(--acid), var(--ember));
  opacity: .82;
}

.content-frame::after {
  content: "HTMO";
  position: absolute;
  right: -3vw;
  top: 12%;
  z-index: 0;
  color: transparent;
  -webkit-text-stroke: 1px rgba(255,255,255,.035);
  font-size: clamp(140px, 19vw, 280px);
  font-weight: 800;
  letter-spacing: -.08em;
  pointer-events: none;
}

.content-frame-header,
.content-frame-meta,
.content-frame-body {
  position: relative;
  z-index: 1;
}

.content-frame-header {
  max-width: 100%;
  padding: clamp(24px, 4vw, 48px);
  border: 1px solid rgba(255,255,255,.09);
  border-radius: 22px;
  background:
    linear-gradient(135deg, rgba(255,255,255,.045), rgba(255,255,255,.018)),
    rgba(10, 10, 11, 0.34);
}

.content-frame-header .eyebrow {
  margin-bottom: 18px;
}

.content-frame-header h1 {
  max-width: 980px;
  margin: 0;
  font-size: clamp(2.8rem, 6vw, 5.8rem);
  line-height: .96;
  letter-spacing: -.065em;
}

.content-frame-header p {
  max-width: 820px;
  margin: 22px 0 0;
  color: rgba(238,243,255,.8);
  font-size: clamp(1.04rem, 1.8vw, 1.26rem);
  line-height: 1.65;
}

.content-frame-meta {
  display: inline-flex;
  flex-wrap: wrap;
  gap: 8px;
  margin: 12px 0 clamp(74px, 12vw, 150px);
  padding: 8px;
  max-width: 100%;
  border: 1px solid rgba(255,255,255,.085);
  border-radius: 18px;
  background: rgba(10, 10, 11, 0.42);
}

.content-frame-meta span,
.content-frame-meta time,
.content-frame-meta a {
  display: inline-flex;
  align-items: center;
  min-height: 34px;
  padding: 0 12px;
  border-radius: 12px;
  background: rgba(255,255,255,.04);
  color: rgba(238,243,255,.74);
  font-size: .9rem;
  font-weight: 700;
  text-decoration: none;
}

.content-frame-meta a {
  color: var(--acid);
}

.content-frame-body {
  width: min(900px, 100%);
  margin: 0 auto;
  border: 1px solid rgba(255,255,255,.095);
  border-radius: 26px;
  background:
    linear-gradient(135deg, rgba(22, 22, 25, 0.90), rgba(11, 11, 12, 0.92)),
    rgba(25, 25, 28, 0.78);
  box-shadow: 0 24px 76px rgba(0, 0, 0, 0.25);
  padding: clamp(28px, 4vw, 54px);
}

.framed-editorial-body {
  max-width: 720px;
  margin: 0 auto;
  color: rgba(244,248,255,.9);
  font-size: clamp(1.04rem, 1.45vw, 1.16rem);
  line-height: 1.9;
}

.framed-editorial-body p {
  margin: 0 0 1.42em;
}

.framed-editorial-body p:last-child {
  margin-bottom: 0;
}

.news-frame-page .content-frame::before {
  background: linear-gradient(90deg, var(--acid), var(--electric), var(--ember));
}

@media (max-width: 760px) {
  .content-frame-page {
    padding-top: 28px;
  }

  .content-frame-shell {
    width: min(100% - 20px, 1320px);
  }

  .content-frame {
    border-radius: 22px;
    padding: 12px;
  }

  .content-frame-header {
    border-radius: 18px;
    padding: 22px;
  }

  .content-frame-header h1 {
    font-size: clamp(2.25rem, 12vw, 3.6rem);
    letter-spacing: -.055em;
  }

  .content-frame-meta {
    margin-bottom: 44px;
  }

  .content-frame-body {
    border-radius: 20px;
    padding: 24px;
  }
}


/* Phase 3.16.5 - Content Detail Frame Reduction
   ------------------------------------------------------------
   Reduziert das Detailseiten-Layout nach Praxistest:
   - weniger Abstand zum Header,
   - kleinere Titel,
   - weniger Padding,
   - Content ohne sichtbaren Innencontainer,
   - Content links/rechts am Titelbereich ausgerichtet.
*/
.content-frame-page {
  padding-top: clamp(24px, 3.2vw, 44px);
  padding-bottom: clamp(58px, 7vw, 92px);
  min-height: auto;
}

.content-frame-shell {
  width: min(1320px, calc(100% - 36px));
}

.content-frame {
  min-height: clamp(420px, 50vh, 640px);
  border-radius: 24px;
  padding: clamp(14px, 2vw, 24px);
}

.content-frame::after {
  top: 14%;
  right: -2vw;
  font-size: clamp(110px, 16vw, 230px);
  -webkit-text-stroke-color: rgba(255,255,255,.026);
}

.content-frame-header {
  padding: clamp(20px, 3vw, 34px);
  border-radius: 20px;
}

.content-frame-header .eyebrow {
  margin-bottom: 14px;
}

.content-frame-header h1 {
  max-width: 900px;
  font-size: clamp(2.25rem, 4.8vw, 4.25rem);
  line-height: 1.0;
  letter-spacing: -.055em;
}

.content-frame-header p {
  max-width: 760px;
  margin-top: 16px;
  font-size: clamp(1rem, 1.45vw, 1.15rem);
  line-height: 1.58;
}

.content-frame-meta {
  margin: 10px 0 clamp(34px, 6vw, 76px);
  padding: 6px;
  border-radius: 16px;
}

.content-frame-meta span,
.content-frame-meta time,
.content-frame-meta a {
  min-height: 30px;
  padding: 0 11px;
  font-size: .84rem;
}

.content-frame-body {
  width: 100%;
  max-width: none;
  margin: 0;
  border: 0;
  border-radius: 0;
  background: transparent;
  box-shadow: none;
  padding: clamp(20px, 3vw, 34px);
}

.framed-editorial-body {
  max-width: 820px;
  margin: 0;
  color: rgba(244,248,255,.88);
  font-size: clamp(1rem, 1.28vw, 1.09rem);
  line-height: 1.78;
}

.framed-editorial-body p {
  margin-bottom: 1.2em;
}

@media (max-width: 760px) {
  .content-frame-page {
    padding-top: 18px;
  }

  .content-frame-shell {
    width: min(100% - 18px, 1320px);
  }

  .content-frame {
    padding: 10px;
    border-radius: 20px;
  }

  .content-frame-header {
    padding: 18px;
    border-radius: 16px;
  }

  .content-frame-header h1 {
    font-size: clamp(2rem, 10vw, 3rem);
  }

  .content-frame-meta {
    margin-bottom: 28px;
  }

  .content-frame-body {
    padding: 18px;
  }
}

/* Phase 3.17.3 - Content Cover Media Output
   ------------------------------------------------------------
   Öffentliche Cover-Ausgabe für Seiten und Beiträge. Dateien werden weiterhin
   über den geschützten MediaController ausgeliefert.
*/
.content-frame-cover {
  position: relative;
  z-index: 1;
  margin: 0 0 clamp(28px, 5vw, 54px);
  overflow: hidden;
  border-radius: 24px;
  border: 1px solid rgba(255,255,255,.10);
  background: rgba(10, 10, 11, 0.38);
  box-shadow: 0 22px 70px rgba(0, 0, 0, 0.26);
}

.content-frame-cover img {
  display: block;
  width: 100%;
  max-height: clamp(260px, 42vw, 520px);
  object-fit: cover;
}

.news-featured-card.has-media {
  grid-template-columns: minmax(280px, .85fr) minmax(0, 1.15fr);
  align-items: stretch;
}

.news-featured-card.has-media.has-highlight {
  grid-template-columns: minmax(260px, .78fr) minmax(0, 1.05fr) minmax(220px, .58fr);
}

.news-featured-media,
.news-card-media {
  margin: 0;
  overflow: hidden;
  border-radius: 22px;
  border: 1px solid rgba(255,255,255,.10);
  background: rgba(10, 10, 11, 0.42);
}

.news-featured-media img,
.news-card-media img {
  display: block;
  width: 100%;
  height: 100%;
  object-fit: cover;
}

.news-featured-media img {
  min-height: 260px;
}

.news-card-media {
  height: 180px;
  margin-bottom: 6px;
}

@media (max-width: 1100px) {
  .news-featured-card.has-media,
  .news-featured-card.has-media.has-highlight {
    grid-template-columns: 1fr;
  }

  .news-featured-media img {
    min-height: 220px;
    max-height: 360px;
  }
}

@media (max-width: 760px) {
  .content-frame-cover {
    border-radius: 18px;
    margin-bottom: 26px;
  }

  .news-card-media {
    height: 160px;
  }
}


/* Phase 3.18.3 - Public Menu Subitems
   ------------------------------------------------------------
   Öffentliche Navigation mit Unterpunkten bis Ebene 3.
   Sicherheit: Ausgabe kommt aus ContentNavigationService; Zielcontroller bleiben maßgeblich.
*/
.site-nav {
  align-items: center;
}

.site-nav-item {
  position: relative;
  display: inline-flex;
  align-items: stretch;
}

.site-nav-item > a {
  display: inline-flex;
  align-items: center;
  gap: 7px;
}

.nav-caret {
  font-size: .72em;
  opacity: .7;
}

.site-subnav {
  position: absolute;
  top: calc(100% + 10px);
  left: 0;
  z-index: 80;
  min-width: 230px;
  padding: 8px;
  border: 1px solid rgba(255,255,255,.12);
  border-radius: 18px;
  background:
    linear-gradient(135deg, rgba(22, 22, 25, .96), rgba(11, 11, 12, .97)),
    rgba(11, 11, 12, .96);
  box-shadow: 0 24px 70px rgba(0,0,0,.34);
  opacity: 0;
  visibility: hidden;
  transform: translateY(6px);
  transition: opacity .16s ease, visibility .16s ease, transform .16s ease;
}

.site-nav-item:hover > .site-subnav,
.site-nav-item:focus-within > .site-subnav {
  opacity: 1;
  visibility: visible;
  transform: translateY(0);
}

.site-subnav .site-nav-item {
  display: flex;
  width: 100%;
}

.site-subnav .site-nav-item > a {
  width: 100%;
  justify-content: space-between;
  padding: 10px 12px;
  border-radius: 12px;
  white-space: nowrap;
}

.site-subnav .site-subnav {
  top: -8px;
  left: calc(100% + 8px);
}

.footer-nav-tree .site-nav-item {
  display: flex;
  flex-direction: column;
  align-items: flex-start;
}

.footer-nav-tree .site-nav-item > a {
  padding: 0;
}

.footer-nav-tree .site-subnav {
  position: static;
  display: grid;
  gap: 7px;
  min-width: 0;
  margin: 8px 0 0 14px;
  padding: 0;
  border: 0;
  border-radius: 0;
  background: transparent;
  box-shadow: none;
  opacity: 1;
  visibility: visible;
  transform: none;
}

.footer-nav-tree .nav-caret {
  display: none;
}

@media (max-width: 980px) {
  .site-nav-item,
  .site-nav-item > a {
    width: 100%;
  }

  .site-nav-item {
    display: flex;
    flex-direction: column;
  }

  .site-subnav,
  .site-subnav .site-subnav {
    position: static;
    display: grid;
    gap: 6px;
    min-width: 0;
    margin: 4px 0 6px 14px;
    padding: 0 0 0 10px;
    border: 0;
    border-left: 1px solid rgba(255,255,255,.12);
    border-radius: 0;
    background: transparent;
    box-shadow: none;
    opacity: 1;
    visibility: visible;
    transform: none;
  }

  .site-subnav .site-nav-item > a {
    padding: 9px 10px;
    white-space: normal;
  }
}


/* Phase 3.18.5 - Navigation ohne sichtbaren Pfeil
   ------------------------------------------------------------
   Untermenüs bleiben hover-/focusfähig, aber ohne sichtbares Caret am Hauptpunkt.
*/
.nav-caret {
  display: none !important;
}

/* Content Block Rendering
   ------------------------------------------------------------
   Öffentliche Darstellung für serverseitig gerenderte Editor-Blöcke.
   Sicherheit: Diese Klassen rendern nur bereinigtes ContentHtml; rohes HTML aus
   dem Editorformular wird nicht direkt ausgegeben.
*/
.content-block-notice {
  margin: 1.6rem 0;
  padding: 1rem 1.1rem;
  border: 1px solid rgba(79, 143, 209,.25);
  border-left-width: 4px;
  border-radius: 16px;
  background: rgba(79, 143, 209,.08);
}

.content-block-notice.notice-success {
  border-color: rgba(79, 143, 209,.32);
  background: rgba(79, 143, 209,.08);
}

.content-block-notice.notice-warning {
  border-color: rgba(255,187,68,.36);
  background: rgba(255,187,68,.08);
}

.content-block-notice.notice-danger {
  border-color: rgba(255,80,100,.38);
  background: rgba(255,80,100,.08);
}

/* Phase 3.22.5 - Frontend Content Flow Fix
   ------------------------------------------------------------
   Öffentliche Content-Detailseiten: Der eigentliche Inhalt rückt näher an
   die Meta-Leiste und nutzt die volle Breite des Content-Frames. Die große
   HTMO-Wasserzeichen-Schrift bleibt bewusst hinter dem Inhalt liegen.
   Sicherheit: Reines Layout. Keine Änderung an Rendering, Sanitizing oder
   serverseitiger Content-Prüfung.
*/
.content-frame-meta {
  margin-bottom: 8px;
}

.content-frame-body {
  padding-top: 8px;
}

.framed-editorial-body {
  width: 100%;
  max-width: none;
}

.framed-editorial-body :is(p, ul, ol, blockquote, h2, h3, h4, .content-block-notice) {
  max-width: none;
}

@media (max-width: 760px) {
  .content-frame-meta {
    margin-bottom: 8px;
  }

  .content-frame-body {
    padding-top: 8px;
  }
}

/* Phase 3.23.0 - Öffentliche Ausgabe erweiterter HTMO-Blöcke
   ------------------------------------------------------------
   Darstellung für serverseitig gerenderte Spalten-, Galerie-, Tabellen-,
   Code-, FAQ-, CTA-, Download-, Linkkarten- und Abstand-Blöcke.
   Sicherheit: Layout-only. HTML kommt weiterhin aus validiertem ContentJson.
*/
.content-block-columns {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: clamp(18px, 3vw, 34px);
  margin: 1.6rem 0;
}

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

.content-block-columns > div {
  padding: 1rem;
  border: 1px solid rgba(255,255,255,.08);
  border-radius: 18px;
  background: rgba(255,255,255,.025);
}

.content-block-gallery {
  margin: 1.8rem 0;
}

.content-block-gallery > div {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(180px, 1fr));
  gap: 14px;
}

.content-block-gallery figure {
  margin: 0;
  overflow: hidden;
  border-radius: 18px;
  background: rgba(255,255,255,.04);
}

.content-block-gallery img {
  width: 100%;
  height: 220px;
  object-fit: cover;
  display: block;
}

.content-block-gallery figcaption {
  margin-top: .8rem;
  color: rgba(210,224,255,.78);
  font-size: .94rem;
}

.content-block-table-wrap {
  width: 100%;
  margin: 1.7rem 0;
  overflow-x: auto;
}

.content-block-table {
  width: 100%;
  border-collapse: collapse;
  border: 1px solid rgba(255,255,255,.12);
  border-radius: 16px;
  overflow: hidden;
}

.content-block-table th,
.content-block-table td {
  padding: .82rem 1rem;
  border: 1px solid rgba(255,255,255,.1);
  text-align: left;
  vertical-align: top;
}

.content-block-table th {
  background: rgba(79, 143, 209,.1);
  color: #f5f8ff;
}

.content-block-code {
  margin: 1.7rem 0;
  padding: 1.1rem;
  overflow-x: auto;
  border: 1px solid rgba(79, 143, 209,.16);
  border-radius: 18px;
  background: rgba(8, 8, 9,.72);
  color: #d7e7ff;
  font-family: ui-monospace, SFMono-Regular, Menlo, Consolas, monospace;
  line-height: 1.55;
}

.content-block-faq {
  margin: 1.4rem 0;
  padding: 1rem 1.1rem;
  border: 1px solid rgba(255,255,255,.1);
  border-radius: 18px;
  background: rgba(255,255,255,.025);
}

.content-block-faq summary {
  cursor: pointer;
  font-weight: 700;
  color: #f5f8ff;
}

.content-block-faq div {
  margin-top: .9rem;
}

.content-block-cta {
  margin: 2rem 0;
  padding: clamp(1.2rem, 3vw, 2rem);
  border: 1px solid rgba(79, 143, 209,.24);
  border-radius: 24px;
  background: linear-gradient(135deg, rgba(79, 143, 209,.09), rgba(79, 143, 209,.06));
}

.content-block-cta h2 {
  margin-top: 0;
}

.content-block-download,
.content-block-embed {
  margin: 1.5rem 0;
}

.content-block-download a,
.content-block-embed a {
  display: grid;
  gap: .25rem;
  padding: 1rem 1.1rem;
  border: 1px solid rgba(255,255,255,.12);
  border-radius: 18px;
  background: rgba(255,255,255,.035);
  color: #f5f8ff;
  text-decoration: none;
}

.content-block-download span,
.content-block-embed span {
  color: rgba(210,224,255,.72);
  font-size: .92rem;
}

.content-block-spacer {
  height: var(--htmo-spacer-height, 48px);
}

.framed-editorial-body :is(.content-block-columns, .content-block-gallery, .content-block-table-wrap, .content-block-code, .content-block-faq, .content-block-cta, .content-block-download, .content-block-embed) {
  max-width: none;
}

@media (max-width: 760px) {
  .content-block-columns,
  .content-block-columns.columns-3 {
    grid-template-columns: 1fr;
  }

  .content-block-gallery img {
    height: 180px;
  }
}

/* Phase 3.23.2 - Unsichtbare Frontend-Spalten und globale Ausrichtung
   ------------------------------------------------------------
   Spalten sind Layout, kein sichtbarer Container. Die Ausgabe bleibt
   serverseitig generiert und enthält nur validierte Klassenwerte.
*/
.content-block.align-left { text-align: left; }
.content-block.align-right { text-align: right; }
.content-block.align-center { text-align: center; }
.content-block.align-middle {
  display: grid;
  align-items: center;
  justify-items: center;
  text-align: center;
}

.content-block-columns {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: clamp(18px, 3vw, 34px);
  margin: 1.4rem 0;
  padding: 0;
  border: 0;
  border-radius: 0;
  background: transparent;
}

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

.content-block-columns > .content-block-column {
  min-width: 0;
  padding: 0;
  border: 0;
  border-radius: 0;
  background: transparent;
}

.content-block-columns.valign-middle { align-items: center; }
.content-block-columns.valign-bottom { align-items: end; }

.content-block-columns .content-block:first-child { margin-top: 0; }
.content-block-columns .content-block:last-child { margin-bottom: 0; }

@media (max-width: 760px) {
  .content-block-columns,
  .content-block-columns.columns-3 {
    grid-template-columns: 1fr;
  }
}

/* Phase 3.23.3 - Frontend-Ausrichtung je Block
   ------------------------------------------------------------
   Zweck:
   - Jeder gerenderte Content-Block kann horizontale und vertikale Ausrichtung
     aus den validierten Blocksettings übernehmen.
   Sicherheit: Die Klassenwerte kommen nur aus der serverseitigen Allowlist des
   ContentRenderService; rohe CSS-/HTML-Werte werden nicht übernommen.
*/
.content-block.valign-top {
  align-items: start;
}

.content-block.valign-middle {
  display: grid;
  align-items: center;
}

.content-block.valign-bottom {
  display: grid;
  align-items: end;
}

/* Phase 3.23.5 - Saubere Bilddarstellung in Frontend-Spalten
   ------------------------------------------------------------
   Bilder aus dem HTMO Block Editor bleiben proportional, laufen nicht aus
   Spalten oder Content-Frames heraus und werden nicht durch sichtbare
   Container dekoriert. Layout-only: Medienzugriff und Sanitizing bleiben
   vollständig serverseitig geregelt.
*/
.content-block-image {
  width: 100%;
  max-width: 100%;
  margin: 1.35rem 0;
  padding: 0;
  border: 0;
  background: transparent;
  overflow: visible;
}

.content-block-image img {
  display: block;
  width: auto;
  max-width: 100%;
  height: auto;
  max-height: min(720px, 78vh);
  object-fit: contain;
}

.content-block-image figcaption {
  margin-top: .65rem;
  color: rgba(210, 224, 255, .72);
  font-size: .92rem;
  line-height: 1.45;
}

.content-block-image.align-left img,
.content-block.align-left .content-block-image img {
  margin-right: auto;
}

.content-block-image.align-center img,
.content-block.align-center .content-block-image img,
.content-block-image.align-middle img,
.content-block.align-middle .content-block-image img {
  margin-left: auto;
  margin-right: auto;
}

.content-block-image.align-right img,
.content-block.align-right .content-block-image img {
  margin-left: auto;
}

.content-block-image.align-wide {
  max-width: 100%;
}

.content-block-image.align-wide img {
  width: auto;
  max-width: 100%;
}

.content-block-columns .content-block-image {
  margin: 0;
}

.content-block-columns .content-block-image img {
  width: auto;
  max-width: 100%;
  max-height: min(560px, 68vh);
}

.content-block-columns.columns-3 .content-block-image img {
  max-height: min(460px, 62vh);
}

.content-block-columns .content-block.align-middle .content-block-image {
  min-height: 100%;
  display: flex;
  flex-direction: column;
  justify-content: center;
}

.content-block-columns .content-block.align-right .content-block-image {
  align-items: flex-end;
}

.content-block-columns .content-block.align-center .content-block-image,
.content-block-columns .content-block.align-middle .content-block-image {
  align-items: center;
}

@media (max-width: 760px) {
  .content-block-image img,
  .content-block-columns .content-block-image img,
  .content-block-columns.columns-3 .content-block-image img {
    max-height: none;
    width: auto;
    max-width: 100%;
  }
}

/* Phase 3.23.8 - Galerieausgabe ohne harte Bildbeschneidung
   ------------------------------------------------------------
   Galerieblöcke zeigen Bilder proportional und innerhalb des Contentrasters.
   Das HTML wird weiterhin serverseitig aus validiertem ContentJson erzeugt.
*/
.content-block-gallery {
  width: 100%;
  max-width: 100%;
  margin: 1.45rem 0;
}

.content-block-gallery > div {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(220px, 1fr));
  gap: clamp(12px, 1.8vw, 20px);
  align-items: start;
}

.content-block-gallery figure {
  display: flex;
  flex-direction: column;
  justify-content: center;
  min-width: 0;
  margin: 0;
  overflow: hidden;
  border: 0;
  border-radius: 0;
  background: transparent;
}

.content-block-gallery img {
  display: block;
  width: 100%;
  max-width: 100%;
  height: auto;
  max-height: min(520px, 64vh);
  object-fit: contain;
}

.content-block-columns .content-block-gallery {
  margin: 0;
}

.content-block-columns .content-block-gallery > div {
  grid-template-columns: repeat(auto-fit, minmax(150px, 1fr));
  gap: 12px;
}

.content-block-columns .content-block-gallery img {
  max-height: min(360px, 52vh);
}

@media (max-width: 760px) {
  .content-block-gallery > div,
  .content-block-columns .content-block-gallery > div {
    grid-template-columns: 1fr;
  }

  .content-block-gallery img,
  .content-block-columns .content-block-gallery img {
    max-height: none;
  }
}

/* Phase 3.24.0 - Öffentliche Ausgabe: Galerie- und Spaltenoptionen
   ------------------------------------------------------------
   Zweck:
   - Galerie-Optionen aus dem Editor werden serverseitig als geprüfte Klassen
     und CSS-Variablen ausgegeben.
   - Spalten bleiben unsichtbares Layout, können aber Breiten, Abstand und
     mobile Stapelung sauber steuern.
   Sicherheit: Die Werte stammen aus Allowlists bzw. numerisch begrenzten
   Pixelwerten im ContentRenderService. Keine freie CSS-Eingabe.
*/
.content-block-columns {
  gap: var(--htmo-column-gap, clamp(18px, 3vw, 34px));
}

.content-block-columns.columns-layout-33-66 {
  grid-template-columns: minmax(0, .5fr) minmax(0, 1fr);
}

.content-block-columns.columns-layout-66-33 {
  grid-template-columns: minmax(0, 1fr) minmax(0, .5fr);
}

.content-block-columns.columns-layout-25-50-25 {
  grid-template-columns: minmax(0, .5fr) minmax(0, 1fr) minmax(0, .5fr);
}

.content-block-gallery > div {
  gap: var(--htmo-gallery-gap, 14px);
}

.content-block-gallery.gallery-columns-2 > div {
  grid-template-columns: repeat(2, minmax(0, 1fr));
}

.content-block-gallery.gallery-columns-3 > div {
  grid-template-columns: repeat(3, minmax(0, 1fr));
}

.content-block-gallery.gallery-columns-4 > div {
  grid-template-columns: repeat(4, minmax(0, 1fr));
}

.content-block-gallery.gallery-aspect-original img {
  height: auto;
  max-height: min(720px, 78vh);
  object-fit: contain;
}

.content-block-gallery.gallery-aspect-square img {
  aspect-ratio: 1 / 1;
  height: auto;
  object-fit: cover;
}

.content-block-gallery.gallery-aspect-16x9 img {
  aspect-ratio: 16 / 9;
  height: auto;
  object-fit: cover;
}

.content-block-gallery.gallery-aspect-4x3 img {
  aspect-ratio: 4 / 3;
  height: auto;
  object-fit: cover;
}

.content-block-gallery.gallery-click-lightbox figure a,
.content-block-image-link {
  display: block;
  color: inherit;
  text-decoration: none;
}

.framed-editorial-body .content-block a {
  color: #cfe8ff;
  text-underline-offset: .18em;
}

@media (max-width: 760px) {
  .content-block-columns.mobile-stack,
  .content-block-columns.mobile-stack.columns-3,
  .content-block-columns.mobile-stack.columns-layout-33-66,
  .content-block-columns.mobile-stack.columns-layout-66-33,
  .content-block-columns.mobile-stack.columns-layout-25-50-25 {
    grid-template-columns: 1fr;
  }

  .content-block-gallery.gallery-columns-3 > div,
  .content-block-gallery.gallery-columns-4 > div {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
}

@media (max-width: 520px) {
  .content-block-gallery.gallery-columns-2 > div,
  .content-block-gallery.gallery-columns-3 > div,
  .content-block-gallery.gallery-columns-4 > div {
    grid-template-columns: 1fr;
  }
}

@media (max-width: 760px) {
  .content-block-columns.no-mobile-stack.columns-2,
  .content-block-columns.no-mobile-stack:not(.columns-3) {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  .content-block-columns.no-mobile-stack.columns-3 {
    grid-template-columns: repeat(3, minmax(0, 1fr));
  }

  .content-block-columns.no-mobile-stack.columns-layout-33-66 {
    grid-template-columns: minmax(0, .5fr) minmax(0, 1fr);
  }

  .content-block-columns.no-mobile-stack.columns-layout-66-33 {
    grid-template-columns: minmax(0, 1fr) minmax(0, .5fr);
  }

  .content-block-columns.no-mobile-stack.columns-layout-25-50-25 {
    grid-template-columns: minmax(0, .5fr) minmax(0, 1fr) minmax(0, .5fr);
  }
}

/* Phase 3.24.1 - Sichere Button-Darstellung für Button- und CTA-Blöcke
   ------------------------------------------------------------
   Zweck:
   - Button-Blöcke werden im Frontend als echte Call-to-Action-Buttons dargestellt.
   - Optionale Farben kommen nur über serverseitig geprüfte Hex-Werte als CSS-Variablen.
*/
.content-block-button-wrap {
  margin: 1.35rem 0;
}

.content-block-button {
  --htmo-button-bg: #4f8fd1;
  --htmo-button-text: #06100c;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-height: 44px;
  padding: .72rem 1.35rem;
  border: 1px solid rgba(79, 143, 209,.45);
  border-radius: 999px;
  background: var(--htmo-button-bg);
  color: var(--htmo-button-text);
  font-weight: 800;
  line-height: 1.1;
  text-decoration: none;
  box-shadow: 0 14px 32px rgba(0,0,0,.22);
  transition: transform .16s ease, filter .16s ease, box-shadow .16s ease;
}

.content-block-button:hover,
.content-block-button:focus-visible {
  color: var(--htmo-button-text);
  filter: brightness(1.05);
  text-decoration: none;
  transform: translateY(-1px);
  box-shadow: 0 18px 42px rgba(0,0,0,.28);
}

.content-block-cta .content-block-button {
  margin-top: .35rem;
}

/* Phase 3.24.2 - Button-Designsystem im Frontend
   ------------------------------------------------------------
   Zweck:
   - Button- und CTA-Blöcke verwenden seriöse HTMO-Systemfarben.
   - Eigene Farben kommen nur über serverseitig geprüfte CSS-Variablen.
   - Stilvarianten, Breite und Ecken werden über erlaubte Klassen abgebildet.
*/
.content-block-button {
  --htmo-button-system-bg: #2f8cff;
  --htmo-button-system-text: #f8fbff;
  --htmo-button-bg: var(--htmo-button-system-bg);
  --htmo-button-text: var(--htmo-button-system-text);
  min-height: 46px;
  padding: .78rem 1.45rem;
  border: 1px solid rgba(91, 171, 255, .52);
  border-radius: 999px;
  background: var(--htmo-button-bg);
  color: var(--htmo-button-text);
  box-shadow: 0 14px 34px rgba(0,0,0,.24);
}

.content-block-button:hover,
.content-block-button:focus-visible {
  color: var(--htmo-button-text);
  filter: brightness(1.08);
}

.content-block-button.button-style-secondary {
  --htmo-button-bg: #17253a;
  --htmo-button-text: #e8f2ff;
  background: var(--htmo-button-bg);
  color: var(--htmo-button-text);
  border-color: rgba(118, 169, 255, .34);
}

.content-block-button.button-style-outline {
  --htmo-button-bg: #2f8cff;
  --htmo-button-text: #8fc4ff;
  background: transparent;
  color: var(--htmo-button-text);
  border-color: var(--htmo-button-bg);
  box-shadow: none;
}

.content-block-button.button-style-outline:hover,
.content-block-button.button-style-outline:focus-visible {
  background: color-mix(in srgb, var(--htmo-button-bg) 14%, transparent);
  color: var(--htmo-button-text);
}

.content-block-button.button-style-ghost {
  --htmo-button-bg: #dcecff;
  --htmo-button-text: #dcecff;
  background: rgba(143, 196, 255, .08);
  color: var(--htmo-button-text);
  border-color: transparent;
  box-shadow: none;
}

.content-block-button.button-style-ghost:hover,
.content-block-button.button-style-ghost:focus-visible {
  background: rgba(143, 196, 255, .14);
  color: var(--htmo-button-text);
}

.content-block-button.button-width-full {
  display: flex;
  width: 100%;
}

.content-block-button.button-radius-rounded {
  border-radius: 18px;
}

.content-block-button.button-radius-soft {
  border-radius: 10px;
}

.content-block-button.button-radius-square {
  border-radius: 4px;
}

/* Setup / Erstinstallation
   ------------------------------------------------------------
   Minimaler Installationsmodus für leere Datenbanken.
   Sicherheit: Styling ist nur Oberfläche; Setup-Sperre und Secret-Schutz erfolgen serverseitig.
*/
.setup-shell {
  min-height: 100vh;
  background:
    radial-gradient(circle at top left, rgba(34, 111, 209, 0.18), transparent 34rem),
    linear-gradient(135deg, #05080d 0%, #101722 55%, #06090e 100%);
}

.setup-main {
  width: min(1120px, calc(100% - 32px));
  margin: 0 auto;
  padding: 56px 0;
}

.setup-card {
  border: 1px solid rgba(148, 163, 184, 0.22);
  border-radius: 28px;
  background: rgba(10, 15, 23, 0.92);
  box-shadow: 0 28px 90px rgba(0, 0, 0, 0.42);
  overflow: hidden;
}

.setup-header {
  display: flex;
  gap: 22px;
  align-items: center;
  padding: 32px;
  border-bottom: 1px solid rgba(148, 163, 184, 0.16);
  background: linear-gradient(135deg, rgba(37, 99, 235, 0.18), rgba(15, 23, 42, 0.2));
}

.setup-header img {
  width: 72px;
  height: auto;
  flex: 0 0 auto;
}

.setup-header h1 {
  margin: 0 0 10px;
  font-size: clamp(2rem, 4vw, 3.2rem);
}

.setup-header p:last-child {
  margin: 0;
  color: var(--muted, #aab6c7);
  max-width: 760px;
}

.setup-form,
.setup-completed .setup-actions,
.setup-result-box {
  padding: 0 32px;
}

.setup-section {
  padding: 32px 0;
  border-bottom: 1px solid rgba(148, 163, 184, 0.14);
}

.setup-section-head {
  display: flex;
  gap: 16px;
  align-items: flex-start;
  margin-bottom: 24px;
}

.setup-section-head > span {
  display: grid;
  place-items: center;
  width: 38px;
  height: 38px;
  border-radius: 999px;
  background: rgba(37, 99, 235, 0.22);
  color: #dbeafe;
  font-weight: 800;
}

.setup-section-head h2 {
  margin: 0 0 6px;
  font-size: 1.35rem;
}

.setup-section-head p {
  margin: 0;
  color: var(--muted, #aab6c7);
}

.form-grid.two {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 18px;
}

.field {
  display: grid;
  gap: 7px;
}

.field > span:first-child,
.check-row span {
  color: #e5edf7;
  font-weight: 700;
}

.field input {
  width: 100%;
  border: 1px solid rgba(148, 163, 184, 0.28);
  border-radius: 14px;
  background: rgba(2, 6, 12, 0.7);
  color: #f8fafc;
  padding: 13px 14px;
  outline: none;
}

.field input:focus {
  border-color: rgba(59, 130, 246, 0.72);
  box-shadow: 0 0 0 3px rgba(59, 130, 246, 0.18);
}

.field small {
  color: var(--muted, #aab6c7);
}

.field [data-valmsg-for],
.validation-summary,
.validation-summary-errors,
.field .field-validation-error {
  color: #fecaca;
}

.validation-summary ul {
  margin: 0 0 20px;
  padding-left: 20px;
}

.check-row {
  display: inline-flex;
  align-items: center;
  gap: 10px;
  margin-bottom: 18px;
}

.check-row input {
  width: 18px;
  height: 18px;
  accent-color: #2563eb;
}

.setup-flags {
  display: flex;
  flex-wrap: wrap;
  gap: 18px 28px;
  margin-top: 18px;
}

.setup-actions {
  display: flex;
  justify-content: space-between;
  align-items: center;
  gap: 20px;
  padding: 28px 32px 32px;
}

.setup-actions p {
  margin: 0;
  color: var(--muted, #aab6c7);
}

.setup-result-box {
  margin: 32px;
  padding: 22px;
  border: 1px solid rgba(59, 130, 246, 0.26);
  border-radius: 18px;
  background: rgba(37, 99, 235, 0.12);
}

.setup-result-box p {
  margin: 0 0 8px;
}

.setup-result-box p:last-child {
  margin-bottom: 0;
}

@media (max-width: 760px) {
  .setup-main {
    width: min(100% - 20px, 1120px);
    padding: 20px 0;
  }

  .setup-header,
  .setup-actions {
    flex-direction: column;
    align-items: flex-start;
  }

  .form-grid.two {
    grid-template-columns: 1fr;
  }
}


/* ============================================================
   Legal pages
============================================================ */
.legal-hero .lead {
  max-width: 760px;
}

.legal-quicklinks {
  display: flex;
  flex-wrap: wrap;
  gap: 12px;
  margin-top: 26px;
}

.legal-overview-grid {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 18px;
  margin-top: 34px;
  margin-bottom: 80px;
}

.legal-overview-card {
  display: block;
  padding: 26px;
  color: inherit;
  transition: transform .22s ease, border-color .22s ease, background .22s ease;
}

.legal-overview-card:hover {
  transform: translateY(-4px);
  border-color: rgba(79, 143, 209, .45);
}

.legal-document {
  max-width: 980px;
}

.legal-document h2 {
  margin-top: 38px;
  padding-top: 28px;
  border-top: 1px solid var(--line);
  font-size: clamp(28px, 3vw, 42px);
  line-height: 1.05;
}

.legal-document h2:first-child,
.legal-card h2 {
  margin-top: 0;
  padding-top: 0;
  border-top: 0;
}

.legal-document h3 {
  margin-top: 28px;
  color: var(--text);
  font-size: clamp(21px, 2vw, 28px);
}

.legal-document p,
.legal-document li,
.legal-document dd {
  color: var(--muted);
}

.legal-document a {
  color: #ccd8ef;
  text-decoration: underline;
  text-decoration-thickness: 1px;
  text-underline-offset: 3px;
}

.legal-card {
  padding: clamp(22px, 3vw, 34px);
}

.legal-card + .legal-card {
  margin-top: 18px;
}

.legal-card address {
  color: var(--muted);
  font-style: normal;
}

.legal-card address strong {
  color: var(--text);
}

.legal-contact-list {
  display: grid;
  gap: 14px;
  margin: 0;
}

.legal-contact-list div {
  display: grid;
  grid-template-columns: 160px minmax(0, 1fr);
  gap: 16px;
  padding-bottom: 14px;
  border-bottom: 1px solid var(--line);
}

.legal-contact-list div:last-child {
  padding-bottom: 0;
  border-bottom: 0;
}

.legal-contact-list dt {
  color: var(--dim);
  font-weight: 700;
}

.legal-contact-list dd {
  margin: 0;
}

.legal-longform {
  padding-top: 20px;
}

.legal-longform > p,
.legal-longform > ul {
  margin-bottom: 18px;
}

.legal-clause strong {
  color: var(--text);
}

.legal-list {
  margin: 0 0 22px;
  padding-left: 22px;
}

@media (max-width: 860px) {
  .legal-overview-grid {
    grid-template-columns: 1fr;
  }

  .legal-contact-list div {
    grid-template-columns: 1fr;
    gap: 4px;
  }
}

/* Phase 1.0.8 - Kontaktformular aktiv
   ------------------------------------------------------------
   Pflicht-Einwilligungen, reCAPTCHA und Statusmeldungen für öffentliche Kontaktanfragen.
*/
.contact-form-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 16px;
}

.contact-form small,
.contact-consent-box small {
  display: block;
  min-height: 18px;
  margin-top: 6px;
  color: #ffb8bb;
  font-size: 12px;
}

.form-status {
  margin-bottom: 16px;
  padding: 14px 16px;
  border-radius: 16px;
  border: 1px solid var(--line-strong);
  background: rgba(255,255,255,.045);
}

.form-status ul {
  margin: 0;
  padding-left: 18px;
}

.form-status.success {
  color: #bdf4c8;
  border-color: rgba(47, 179, 68, .34);
  background: rgba(47, 179, 68, .12);
}

.form-status.danger {
  color: #ffb8bb;
  border-color: rgba(229, 72, 77, .34);
  background: rgba(229, 72, 77, .12);
}

.validation-summary-valid {
  display: none;
}

.contact-consent-box {
  display: grid;
  gap: 10px;
  margin: 20px 0;
  padding: 16px;
  border: 1px solid var(--line);
  border-radius: 18px;
  background: rgba(10, 10, 11, .42);
}

.checkbox-line {
  display: grid;
  grid-template-columns: 22px minmax(0, 1fr);
  gap: 10px;
  align-items: start;
  margin: 0;
}

.checkbox-line input {
  width: auto;
  min-height: auto;
  margin-top: 4px;
}

.checkbox-line span {
  margin: 0;
  color: var(--muted);
  font-size: 13px;
  line-height: 1.5;
}

.checkbox-line a {
  color: var(--acid);
  font-weight: 800;
}

.captcha-box {
  margin: 18px 0;
  min-height: 78px;
}

.form-hint {
  margin: 14px 0 18px;
  color: var(--muted);
  font-size: 13px;
}

@media (max-width: 720px) {
  .contact-form-grid {
    grid-template-columns: 1fr;
  }
}


/* Phase 1.0.14 - deaktiviertes Kundenportal
   ------------------------------------------------------------
   Kompakte, öffentliche Sperrseite für den deaktivierten Kundenbereich.
   Der serverseitige Zugriffsschutz bleibt im Controller; CSS ist nur Darstellung.
*/
.portal-disabled-page {
  padding: clamp(64px, 8vw, 112px) 0;
}

.portal-disabled-container {
  display: grid;
  justify-items: start;
}

.portal-disabled-card {
  width: min(760px, 100%);
  padding: clamp(28px, 4vw, 46px);
  background:
    radial-gradient(circle at 18% 0%, rgba(79, 143, 209, .18), transparent 26rem),
    linear-gradient(145deg, rgba(255,255,255,.07), rgba(255,255,255,.018));
  border: 1px solid var(--line-strong);
  border-radius: 30px;
  box-shadow: 0 28px 90px rgba(0,0,0,.36);
}

.portal-disabled-card h1 {
  max-width: 13ch;
  margin: 12px 0 16px;
  font-size: clamp(42px, 6vw, 76px);
  line-height: .95;
  letter-spacing: -.065em;
}

.portal-disabled-card p {
  max-width: 650px;
  color: var(--muted);
  font-size: clamp(16px, 1.4vw, 19px);
  line-height: 1.65;
}

.portal-disabled-actions {
  display: flex;
  flex-wrap: wrap;
  gap: 14px;
  margin-top: 26px;
}

@media (max-width: 720px) {
  .portal-disabled-page {
    padding: 42px 0 54px;
  }

  .portal-disabled-card h1 {
    max-width: 100%;
    font-size: clamp(38px, 11vw, 54px);
  }
}

/* Phase 1.0.19 - Dezenter Cookie-Consent-Banner
   ------------------------------------------------------------
   Kompakte Consent-Card unten rechts. Der Banner blockiert die Seite
   nicht mehr vollflächig, bleibt aber als Dialog bedienbar.
*/
.cookie-consent-shell[hidden] {
  display: none !important;
}

.cookie-consent-shell {
  position: fixed;
  right: clamp(12px, 2vw, 22px);
  bottom: clamp(12px, 2vw, 22px);
  z-index: 120;
  width: min(430px, calc(100vw - 24px));
  max-height: calc(100vh - 24px);
  pointer-events: none;
}

.cookie-consent-backdrop {
  display: none;
}

.cookie-consent-panel {
  position: relative;
  width: 100%;
  max-height: calc(100vh - 24px);
  overflow: auto;
  padding: clamp(16px, 2vw, 20px);
  border: 1px solid rgba(255, 255, 255, .13);
  border-radius: 22px;
  background:
    radial-gradient(circle at 100% 0%, rgba(79, 143, 209, .18), transparent 15rem),
    linear-gradient(145deg, rgba(22, 22, 25, .97), rgba(10, 10, 12, .97));
  box-shadow: 0 18px 60px rgba(0, 0, 0, .45);
  backdrop-filter: blur(18px);
  transform: translate(14px, 14px) scale(.98);
  opacity: 0;
  transition: opacity .18s ease, transform .18s ease;
  pointer-events: auto;
}

.cookie-consent-shell.is-visible .cookie-consent-panel {
  opacity: 1;
  transform: translate(0, 0) scale(1);
}

.cookie-consent-head .eyebrow {
  font-size: 11px;
  letter-spacing: .18em;
}

.cookie-consent-head h2 {
  margin: 6px 0 8px;
  font-size: clamp(22px, 3vw, 28px);
  line-height: 1.05;
  letter-spacing: -.04em;
}

.cookie-consent-head p,
.cookie-consent-note {
  color: var(--muted);
}

.cookie-consent-head p {
  margin: 0;
  font-size: 14px;
  line-height: 1.45;
}

.cookie-consent-categories {
  display: grid;
  gap: 8px;
  margin: 14px 0;
}

.cookie-consent-category {
  display: grid;
  grid-template-columns: 22px minmax(0, 1fr);
  gap: 10px;
  align-items: start;
  padding: 10px 11px;
  border: 1px solid var(--line);
  border-radius: 15px;
  background: rgba(255, 255, 255, .032);
}

.cookie-consent-category input {
  width: 17px;
  height: 17px;
  margin-top: 3px;
  accent-color: var(--acid);
}

.cookie-consent-category strong {
  display: block;
  color: var(--text);
  font-size: 13px;
}

.cookie-consent-category small {
  display: block;
  margin-top: 3px;
  color: var(--muted);
  font-size: 12px;
  line-height: 1.35;
}

.cookie-consent-category.is-required {
  border-color: rgba(79, 143, 209, .24);
  background: rgba(79, 143, 209, .07);
}

.cookie-consent-actions {
  display: grid;
  grid-template-columns: 1fr;
  gap: 8px;
  align-items: stretch;
}

.cookie-consent-actions .btn {
  width: 100%;
  justify-content: center;
  min-height: 42px;
  padding: 10px 14px;
}

.cookie-consent-actions .btn.ghost {
  background: rgba(255, 255, 255, .035);
}

.cookie-consent-note {
  margin: 12px 0 0;
  font-size: 12px;
  line-height: 1.45;
}

.cookie-consent-note a,
.footer-cookie-settings {
  color: var(--acid);
  font-weight: 800;
}

.footer-cookie-settings {
  display: block;
  width: fit-content;
  margin: 10px 0 0;
  padding: 0;
  border: 0;
  background: transparent;
  text-align: left;
}

.footer-cookie-settings:hover,
.footer-cookie-settings:focus-visible {
  color: var(--acid-strong);
}

body.cookie-consent-open {
  overflow: auto;
}

@media (min-width: 520px) {
  .cookie-consent-actions {
    grid-template-columns: 1fr 1fr;
  }

  .cookie-consent-actions .btn.primary {
    grid-column: 1 / -1;
  }
}

@media (max-width: 520px) {
  .cookie-consent-shell {
    right: 10px;
    bottom: 10px;
    width: calc(100vw - 20px);
    max-height: calc(100vh - 20px);
  }

  .cookie-consent-panel {
    max-height: calc(100vh - 20px);
    border-radius: 20px;
  }
}


/* Version 1.0.22 - HTMO-Editor: Blocksatz und Bild-Textfluss
   ------------------------------------------------------------
   Zweck:
   - Absatz-, Hinweis-, Zitat- und Textblöcke können als Blocksatz ausgegeben werden.
   - Bildblöcke mit Ausrichtung links/rechts fließen wie klassische Editorial-Bilder
     in den folgenden Text hinein.
   Sicherheit: Nur serverseitig normalisierte Klassenwerte und numerische Breitenvariablen
   werden verwendet; keine freien CSS-Werte aus dem Editor.
*/
.content-block.align-justify {
  text-align: justify;
  text-justify: inter-word;
  hyphens: auto;
}

.content-block.align-justify :is(p, blockquote, .content-block-notice, li) {
  text-align: justify;
  text-justify: inter-word;
  hyphens: auto;
}

.content-block.content-block-image-wrap {
  width: 100%;
  max-width: 100%;
}

.content-block.content-block-image-wrap > .content-block-image {
  margin: 0;
}

.content-block.content-block-image-wrap.image-flow-left,
.content-block.content-block-image-wrap.image-flow-right {
  width: min(var(--htmo-image-flow-width, 380px), 46%);
  max-width: 46%;
  margin-top: .35rem;
  margin-bottom: 1rem;
  position: relative;
  z-index: 1;
}

.content-block.content-block-image-wrap.image-flow-left {
  float: left;
  margin-right: clamp(1rem, 2.8vw, 1.85rem);
}

.content-block.content-block-image-wrap.image-flow-right {
  float: right;
  margin-left: clamp(1rem, 2.8vw, 1.85rem);
}

.content-block.content-block-image-wrap.image-flow-left .content-block-image img,
.content-block.content-block-image-wrap.image-flow-right .content-block-image img {
  width: 100%;
  max-width: 100%;
}

.content-block.content-block-image-wrap.image-flow-center,
.content-block.content-block-image-wrap.image-flow-middle,
.content-block.content-block-image-wrap.image-flow-wide {
  clear: both;
}

.framed-editorial-body::after {
  content: "";
  display: block;
  clear: both;
}

.content-block-columns .content-block.content-block-image-wrap {
  float: none;
  width: 100%;
  max-width: 100%;
  margin-left: 0;
  margin-right: 0;
  clear: none;
}

@media (max-width: 760px) {
  .content-block.content-block-image-wrap.image-flow-left,
  .content-block.content-block-image-wrap.image-flow-right {
    float: none;
    width: 100%;
    max-width: 100%;
    margin-left: 0;
    margin-right: 0;
  }
}

/* Phase 1.0.23 - Content preview banner
   Zweck: Admin-Vorschauen sollen als Vorschau erkennbar sein, ohne das öffentliche
   Seitendesign zu beschädigen. */
.content-preview-banner {
  width: min(1320px, calc(100% - 40px));
  margin: 22px auto 0;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 14px;
  padding: 12px 16px;
  border: 1px solid rgba(91, 155, 255, .35);
  border-radius: 18px;
  background: rgba(91, 155, 255, .10);
  color: rgba(235, 244, 255, .92);
  box-shadow: 0 18px 48px rgba(0, 0, 0, .24);
}

.content-preview-banner strong {
  color: #fff;
}

.content-preview-banner span {
  color: rgba(210, 224, 244, .78);
}

.content-preview-banner a {
  color: #fff;
  text-decoration: none;
  font-weight: 800;
  border-bottom: 1px solid rgba(255,255,255,.35);
}

@media (max-width: 720px) {
  .content-preview-banner {
    width: calc(100% - 24px);
    align-items: flex-start;
    flex-direction: column;
  }
}


/* ============================================================
   Security confirmation page
   Öffentliche Bestätigungsseite für Login-Warnmails.
============================================================ */

.security-confirmation-page {
  position: relative;
  min-height: clamp(560px, 70vh, 760px);
  padding: clamp(48px, 7vw, 96px) 0;
  overflow: hidden;
  border-bottom: 1px solid var(--line);
}

.security-confirmation-page::before {
  content: "";
  position: absolute;
  inset: 0;
  background:
    radial-gradient(circle at 18% 20%, rgba(79, 143, 209, .20), transparent 34%),
    radial-gradient(circle at 80% 76%, rgba(201, 138, 75, .10), transparent 30%);
  pointer-events: none;
}

.security-confirmation-page::after {
  content: "";
  position: absolute;
  inset: 0;
  background-image:
    linear-gradient(rgba(255,255,255,.035) 1px, transparent 1px),
    linear-gradient(90deg, rgba(255,255,255,.035) 1px, transparent 1px);
  background-size: 48px 48px;
  mask-image: linear-gradient(180deg, rgba(0,0,0,.88), rgba(0,0,0,.18));
  pointer-events: none;
}

.security-confirmation-shell {
  display: grid;
  place-items: center;
}

.security-confirmation-card {
  position: relative;
  width: min(860px, 100%);
  padding: clamp(26px, 5vw, 56px);
  overflow: hidden;
  background: linear-gradient(135deg, rgba(25, 25, 28, .92), rgba(13, 13, 15, .88));
  border: 1px solid rgba(255,255,255,.13);
  border-radius: 30px;
  box-shadow: 0 30px 90px rgba(0,0,0,.46);
}

.security-confirmation-card::before {
  content: "";
  position: absolute;
  inset: 0 0 auto;
  height: 3px;
  background: linear-gradient(90deg, var(--acid), rgba(255,255,255,.14), transparent);
}

.security-confirmation-page.is-invalid .security-confirmation-card::before {
  background: linear-gradient(90deg, #ff7676, rgba(255,255,255,.14), transparent);
}

.security-confirmation-glow {
  position: absolute;
  right: -90px;
  top: -110px;
  width: 320px;
  height: 320px;
  background: radial-gradient(circle, rgba(79,143,209,.22), transparent 66%);
  border-radius: 999px;
  pointer-events: none;
}

.security-confirmation-page.is-invalid .security-confirmation-glow {
  background: radial-gradient(circle, rgba(255,118,118,.16), transparent 66%);
}

.security-confirmation-header {
  position: relative;
  z-index: 1;
}

.security-confirmation-topline {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: 10px;
  margin-bottom: 22px;
}

.security-confirmation-badge,
.security-confirmation-state {
  display: inline-flex;
  align-items: center;
  min-height: 32px;
  padding: 0 12px;
  color: #06101f;
  background: var(--acid);
  border-radius: 999px;
  font-size: 12px;
  font-weight: 800;
}

.security-confirmation-state {
  color: var(--text);
  background: rgba(255,255,255,.075);
  border: 1px solid var(--line);
}

.security-confirmation-page.is-invalid .security-confirmation-badge {
  color: #fff;
  background: rgba(255, 96, 96, .9);
}

.security-confirmation-icon {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 72px;
  height: 72px;
  margin-bottom: 20px;
  color: #06101f;
  background: linear-gradient(135deg, var(--acid), var(--acid-strong));
  border-radius: 24px;
  font-size: 40px;
  font-weight: 900;
  line-height: 1;
  box-shadow: 0 18px 50px rgba(79,143,209,.25);
}

.security-confirmation-page.is-invalid .security-confirmation-icon {
  color: #fff;
  background: linear-gradient(135deg, #ff6464, #c74343);
  box-shadow: 0 18px 50px rgba(255,96,96,.20);
}

.security-confirmation-eyebrow {
  margin: 0 0 8px;
  color: var(--acid-strong);
  font-size: 12px;
  font-weight: 800;
  letter-spacing: .14em;
  text-transform: uppercase;
}

.security-confirmation-card h1 {
  max-width: 720px;
  margin-bottom: 14px;
  font-size: clamp(46px, 8vw, 84px);
  line-height: .95;
}

.security-confirmation-lead {
  max-width: 760px;
  margin: 0;
  color: #c7c4bd;
  font-size: clamp(17px, 2vw, 20px);
}

.security-confirmation-facts {
  position: relative;
  z-index: 1;
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 14px;
  margin: clamp(24px, 4vw, 34px) 0 0;
}

.security-confirmation-facts div {
  padding: 18px 20px;
  background: rgba(10,10,12,.56);
  border: 1px solid rgba(255,255,255,.10);
  border-radius: 20px;
}

.security-confirmation-facts dt {
  color: var(--dim);
  font-size: 11px;
  font-weight: 800;
  letter-spacing: .10em;
  text-transform: uppercase;
}

.security-confirmation-facts dd {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: 8px;
  margin: 7px 0 0;
  color: var(--text);
  font-size: 18px;
  font-weight: 800;
  overflow-wrap: anywhere;
}

.security-confirmation-facts dd span {
  display: inline-flex;
  min-height: 24px;
  align-items: center;
  padding: 0 8px;
  color: var(--muted);
  background: rgba(255,255,255,.06);
  border: 1px solid var(--line);
  border-radius: 999px;
  font-size: 11px;
  font-weight: 800;
  letter-spacing: .08em;
}

.security-confirmation-note {
  position: relative;
  z-index: 1;
  margin-top: 18px;
  padding: 18px 20px;
  border-radius: 20px;
}

.security-confirmation-note.notice {
  background: rgba(79,143,209,.09);
  border: 1px solid rgba(79,143,209,.22);
}

.security-confirmation-note.warning {
  background: rgba(255,118,118,.10);
  border: 1px solid rgba(255,118,118,.25);
}

.security-confirmation-note strong {
  display: block;
  margin-bottom: 5px;
  color: var(--text);
}

.security-confirmation-note p {
  margin: 0;
  color: var(--muted);
}

.security-confirmation-actions {
  position: relative;
  z-index: 1;
  display: flex;
  flex-wrap: wrap;
  gap: 12px;
  margin-top: 26px;
}

@media (max-width: 720px) {
  .security-confirmation-card {
    border-radius: 24px;
  }

  .security-confirmation-facts {
    grid-template-columns: 1fr;
  }

  .security-confirmation-card h1 {
    font-size: clamp(42px, 14vw, 64px);
  }

  .security-confirmation-actions .btn {
    width: 100%;
  }
}
