/* =============================================================================
   powershelldba.de — user.css
   Korrekturen: Menü-Lesbarkeit + Header-Sprung
   Hochladen nach: /clickandbuilds/powershelldba/templates/shaper_helixultimate/css/user.css
   ============================================================================= */


/* -----------------------------------------------------------------------------
   FIX 0: Logo-Sichtbarkeit
   Das Logo ist dunkelgrau (#3d4450) auf weißem Hintergrund — auf dem
   Navy-Header (#0b1e3d) fast unsichtbar.
   CSS-Filter macht es weiß. Sobald eine weiße Logo-Variante verfügbar ist,
   diese als logo-sticky im Joomla-Backend hinterlegen und diesen Fix entfernen.
   ----------------------------------------------------------------------------- */

#sp-header .logo img,
#sp-header .logo a img {
    filter: brightness(0) invert(1);
}


/* -----------------------------------------------------------------------------
   FIX 1: Menü-Lesbarkeit
   Auf Blog-Artikelseiten und anderen Seiten mit transparentem/hellem Header
   wird der Header-Hintergrund explizit auf Navy gesetzt und die
   Menüschrift auf Weiß erzwungen — unabhängig vom Page-Builder-Override.
   ----------------------------------------------------------------------------- */

/* Hintergrundfarbe des Headers immer navy — kein Transparent */
#sp-header {
    background-color: #0b1e3d !important;
}

/* Hauptmenü-Links immer weiß */
#sp-menu .sp-megamenu-parent > li > a,
#sp-menu .sp-megamenu-parent > li > span {
    color: #ffffff !important;
}

/* Hover-Farbe: Cyan (passt zur default.css Akzentfarbe) */
#sp-menu .sp-megamenu-parent > li:hover > a,
#sp-menu .sp-megamenu-parent > li:hover > span,
#sp-menu .sp-megamenu-parent > li.active > a,
#sp-menu .sp-megamenu-parent > li.active > span {
    color: #5dade2 !important;
}

/* Dropdown-Menü: dunkler Hintergrund, helle Schrift */
#sp-menu .sp-megamenu-parent .sp-dropdown,
#sp-menu .sp-megamenu-parent .sp-dropdown-inner {
    background-color: #0b1e3d !important;
}

#sp-menu .sp-megamenu-parent .sp-dropdown li.sp-menu-item > a,
#sp-menu .sp-megamenu-parent .sp-dropdown li.sp-menu-item > span {
    color: #e0e0e0 !important;
}

#sp-menu .sp-megamenu-parent .sp-dropdown li.sp-menu-item > a:hover,
#sp-menu .sp-megamenu-parent .sp-dropdown li.sp-menu-item > span:hover {
    color: #5dade2 !important;
}

/* Sticky-Header: gleiche Farben beibehalten */
#sp-header.header-sticky {
    background-color: #0b1e3d !important;
}


/* -----------------------------------------------------------------------------
   FIX 2: Header-Sprung (Menü springt ~2 cm nach unten)
   Wenn der Header auf position:fixed wechselt (Klasse header-sticky),
   fehlt auf manchen Seiten der Ausgleich im Seiteninhalt.
   Wir setzen einen fixen padding-top auf den body-wrapper, der der
   Header-Höhe (60 px) entspricht — nur wenn der Header sticky ist.
   ----------------------------------------------------------------------------- */

/* Ausgleich für den fixierten Header — verhindert den Inhalts-Sprung */
body.has-sticky-header .body-wrapper,
body.header-sticky-active .body-wrapper {
    padding-top: 60px !important;
}

/* Fallback: direkt über die sticky-Klasse am Header steuern */
/* Wenn JS die Klasse an #sp-header setzt, bekommt der wrapper den Ausgleich */
#sp-header.header-sticky ~ .body-wrapper,
#sp-header.header-sticky + .body-wrapper {
    padding-top: 60px !important;
}

/* Sicherheitsnetz: body padding-top global wenn sticky aktiv */
body:has(#sp-header.header-sticky) .body-wrapper {
    padding-top: 60px;
}

/* Auf kleinen Bildschirmen ist der Header 50px hoch */
@media (max-width: 767px) {
    body:has(#sp-header.header-sticky) .body-wrapper {
        padding-top: 50px;
    }
}


/* =============================================================================
   psdb-base — Gemeinsames Design-System powershelldba.de
   Alle Artikel und Tool-Seiten verwenden diese Klassen.
   Kein eigener <style>-Block mehr in Joomla-Artikeln noetig.
   ============================================================================= */

:root {
  --psdb-bg:          #060f20;
  --psdb-bg-alt:      #0a1628;
  --psdb-bg-card:     rgba(10, 22, 40, 0.85);
  --psdb-border:      rgba(46, 134, 193, 0.25);
  --psdb-border-h:    rgba(93, 173, 226, 0.5);
  --psdb-accent:      #2e86c1;
  --psdb-accent2:     #5dade2;
  --psdb-green:       #1e8449;
  --psdb-green-light: #27ae60;
  --psdb-amber:       #d35400;
  --psdb-amber-light: #e67e22;
  --psdb-red:         #922b21;
  --psdb-text:        #e2e8f0;
  --psdb-muted:       #7f94ae;
  --psdb-code-bg:     #012456;
  --psdb-code-border: rgba(46, 134, 193, 0.4);
  --psdb-radius:      6px;
  --psdb-radius-lg:   10px;
  --psdb-shadow:      0 4px 24px rgba(0,0,0,0.5);
}

/* Wrapper */
.psdb {
  background: var(--psdb-bg);
  color: var(--psdb-text);
  font-family: 'Segoe UI', system-ui, -apple-system, sans-serif;
  font-size: 15px;
  line-height: 1.7;
}

/* ---- HERO ---- */
.psdb-hero {
  background: linear-gradient(150deg, #060f20 0%, #0b1e3d 60%, #0d2444 100%);
  border-bottom: 1px solid var(--psdb-border);
  padding: 3.5rem 2rem 3rem;
  position: relative;
  overflow: hidden;
}
.psdb-hero::before {
  content: '';
  position: absolute;
  inset: 0;
  background:
    radial-gradient(ellipse 60% 40% at 80% 50%, rgba(46,134,193,0.07) 0%, transparent 70%),
    radial-gradient(ellipse 30% 60% at 10% 80%, rgba(46,134,193,0.04) 0%, transparent 70%);
  pointer-events: none;
}
.psdb-hero-inner { max-width: 1100px; position: relative; }
.psdb-eyebrow {
  display: inline-flex; align-items: center; gap: .45rem;
  background: rgba(46,134,193,0.12);
  border: 1px solid rgba(46,134,193,0.3);
  border-radius: 20px;
  padding: .2rem .75rem;
  font-size: .72rem;
  font-weight: 600;
  letter-spacing: .08em;
  text-transform: uppercase;
  color: var(--psdb-accent2);
  margin-bottom: 1.1rem;
}
.psdb-eyebrow-dot {
  width: 6px; height: 6px;
  background: var(--psdb-accent2);
  border-radius: 50%;
  animation: psdb-pulse 2s ease-in-out infinite;
}
@keyframes psdb-pulse {
  0%,100% { opacity: 1; } 50% { opacity: .3; }
}
.psdb-hero h1 {
  font-size: clamp(1.7rem, 3vw, 2.4rem);
  font-weight: 700;
  color: #fff;
  line-height: 1.2;
  margin: 0 0 1rem;
  letter-spacing: -.02em;
}
.psdb-hero h1 em {
  font-style: normal;
  background: linear-gradient(90deg, var(--psdb-accent2), #85c1e9);
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
  background-clip: text;
}
.psdb-hero-desc {
  font-size: 1rem;
  color: var(--psdb-muted);
  max-width: 640px;
  margin: 0 0 1.6rem;
  line-height: 1.65;
}
.psdb-hero-badges {
  display: flex; flex-wrap: wrap; gap: .5rem; margin-bottom: 1.8rem;
}
.psdb-badge {
  background: rgba(255,255,255,0.05);
  border: 1px solid var(--psdb-border);
  border-radius: 4px;
  padding: .15rem .6rem;
  font-size: .72rem;
  font-family: 'Cascadia Code','Consolas','Courier New',monospace;
  color: var(--psdb-muted);
}
.psdb-badge strong { color: var(--psdb-accent2); }

/* ---- NAV ---- */
.psdb-nav {
  background: var(--psdb-bg-alt);
  border-bottom: 1px solid var(--psdb-border);
  padding: 0 2rem;
  display: flex;
  gap: 0;
  overflow-x: auto;
}
.psdb-nav a {
  display: inline-block;
  padding: .7rem 1.1rem;
  font-size: .8rem;
  font-weight: 600;
  letter-spacing: .04em;
  text-transform: uppercase;
  color: var(--psdb-muted);
  text-decoration: none;
  border-bottom: 2px solid transparent;
  white-space: nowrap;
  transition: color .2s, border-color .2s;
}
.psdb-nav a:hover {
  color: var(--psdb-accent2);
  border-bottom-color: var(--psdb-accent2);
}

/* ---- BODY / SECTIONS ---- */
.psdb-body {
  background: var(--psdb-bg);
  padding: 2.5rem 2rem;
  max-width: 1200px;
  margin: 0 auto;
}
.psdb-section { margin-bottom: 3rem; }
.psdb-section-title {
  font-size: .7rem;
  font-weight: 700;
  letter-spacing: .12em;
  text-transform: uppercase;
  color: var(--psdb-accent);
  margin: 0 0 1.2rem;
  display: flex;
  align-items: center;
  gap: .6rem;
}
.psdb-section-title::after {
  content: '';
  flex: 1;
  height: 1px;
  background: var(--psdb-border);
}

/* ---- CARDS GRID ---- */
.psdb-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(240px, 1fr));
  gap: 1rem;
}
.psdb-card {
  background: var(--psdb-bg-card);
  border: 1px solid var(--psdb-border);
  border-radius: var(--psdb-radius-lg);
  padding: 1.3rem 1.4rem;
  transition: border-color .2s, transform .2s, box-shadow .2s;
}
.psdb-card:hover {
  border-color: var(--psdb-border-h);
  transform: translateY(-2px);
  box-shadow: var(--psdb-shadow);
}
.psdb-card-icon {
  font-size: 1.5rem;
  margin-bottom: .7rem;
  display: block;
}
.psdb-card h3 {
  font-size: .9rem;
  font-weight: 700;
  color: #fff;
  margin: 0 0 .4rem;
}
.psdb-card p {
  font-size: .82rem;
  color: var(--psdb-muted);
  margin: 0;
  line-height: 1.55;
}

/* ---- TABLE ---- */
.psdb-table-wrap { overflow-x: auto; }
.psdb-table {
  width: 100%;
  border-collapse: collapse;
  font-size: .83rem;
}
.psdb-table th {
  background: rgba(46,134,193,0.1);
  color: var(--psdb-accent2);
  font-weight: 700;
  letter-spacing: .04em;
  text-transform: uppercase;
  font-size: .72rem;
  padding: .65rem 1rem;
  text-align: left;
  border-bottom: 1px solid var(--psdb-border);
}
.psdb-table td {
  padding: .6rem 1rem;
  border-bottom: 1px solid rgba(255,255,255,0.04);
  color: var(--psdb-text);
  vertical-align: top;
}
.psdb-table tr:last-child td { border-bottom: none; }
.psdb-table tr:hover td { background: rgba(255,255,255,0.02); }
.psdb-ok   { color: var(--psdb-green-light); font-weight: 600; }
.psdb-warn { color: var(--psdb-amber-light); font-weight: 600; }

/* ---- CODE ---- */
.psdb-code-wrap {
  position: relative;
  margin: 1rem 0;
}
.psdb-code-label {
  display: inline-block;
  background: rgba(46,134,193,0.15);
  border: 1px solid var(--psdb-border);
  border-bottom: none;
  border-radius: var(--psdb-radius) var(--psdb-radius) 0 0;
  padding: .2rem .75rem;
  font-size: .68rem;
  font-weight: 700;
  letter-spacing: .06em;
  text-transform: uppercase;
  color: var(--psdb-muted);
}
.psdb-code {
  background: var(--psdb-code-bg);
  border: 1px solid var(--psdb-code-border);
  border-radius: 0 var(--psdb-radius) var(--psdb-radius) var(--psdb-radius);
  padding: 1.1rem 1.3rem;
  font-family: 'Cascadia Code','Consolas','Courier New',monospace;
  font-size: .82rem;
  line-height: 1.65;
  overflow-x: auto;
  color: #cce5ff;
  margin: 0;
}
.psdb-code .k  { color: #569cd6; }   /* keyword */
.psdb-code .s  { color: #ce9178; }   /* string */
.psdb-code .p  { color: #9cdcfe; }   /* parameter */
.psdb-code .c  { color: #6a9955; }   /* comment */
.psdb-code .n  { color: #4ec9b0; }   /* type/noun */
.psdb-code .v  { color: #dcdcaa; }   /* variable/function */
.psdb-code .num { color: #b5cea8; }  /* number */

/* ---- STEPS ---- */
.psdb-steps { display: flex; flex-direction: column; gap: .8rem; }
.psdb-step {
  display: grid;
  grid-template-columns: 2.2rem 1fr;
  gap: .9rem;
  align-items: start;
}
.psdb-step-num {
  width: 2rem; height: 2rem;
  background: rgba(46,134,193,0.12);
  border: 1px solid var(--psdb-border);
  border-radius: 50%;
  display: flex; align-items: center; justify-content: center;
  font-size: .75rem;
  font-weight: 700;
  color: var(--psdb-accent2);
  flex-shrink: 0;
}
.psdb-step-body h4 {
  font-size: .88rem;
  font-weight: 700;
  color: #fff;
  margin: .1rem 0 .25rem;
}
.psdb-step-body p {
  font-size: .82rem;
  color: var(--psdb-muted);
  margin: 0;
}

/* ---- ALERTS ---- */
.psdb-alert {
  border-radius: var(--psdb-radius);
  padding: .9rem 1.2rem;
  font-size: .84rem;
  line-height: 1.55;
  margin: 1rem 0;
  border-left: 3px solid;
}
.psdb-alert-info {
  background: rgba(46,134,193,0.08);
  border-color: var(--psdb-accent);
  color: #a9cce3;
}
.psdb-alert-ok {
  background: rgba(39,174,96,0.08);
  border-color: var(--psdb-green-light);
  color: #a9dfbf;
}
.psdb-alert-warn {
  background: rgba(230,126,34,0.08);
  border-color: var(--psdb-amber-light);
  color: #f0b27a;
}
.psdb-alert strong { color: #fff; }

/* ---- BUTTON ---- */
.psdb-btn {
  display: inline-flex;
  align-items: center;
  gap: .5rem;
  background: linear-gradient(135deg, var(--psdb-accent), #1a6fa3);
  color: #fff;
  border: none;
  border-radius: var(--psdb-radius);
  padding: .65rem 1.4rem;
  font-size: .85rem;
  font-weight: 700;
  letter-spacing: .02em;
  cursor: pointer;
  text-decoration: none;
  transition: opacity .2s, transform .15s, box-shadow .2s;
  box-shadow: 0 2px 12px rgba(46,134,193,0.3);
}
.psdb-btn:hover {
  opacity: .9;
  transform: translateY(-1px);
  box-shadow: 0 4px 20px rgba(46,134,193,0.45);
}
.psdb-btn-ghost {
  background: transparent;
  border: 1px solid var(--psdb-border);
  color: var(--psdb-muted);
  box-shadow: none;
}
.psdb-btn-ghost:hover {
  border-color: var(--psdb-border-h);
  color: var(--psdb-text);
  opacity: 1;
}
.psdb-btn-row { display: flex; flex-wrap: wrap; gap: .75rem; margin-top: 1.2rem; }

/* ---- CTA FOOTER ---- */
.psdb-cta {
  background: linear-gradient(135deg, #0b1e3d 0%, #0d2444 100%);
  border: 1px solid var(--psdb-border);
  border-radius: var(--psdb-radius-lg);
  padding: 2.2rem 2rem;
  text-align: center;
  margin-top: 3rem;
}
.psdb-cta h2 {
  font-size: 1.3rem;
  font-weight: 700;
  color: #fff;
  margin: 0 0 .5rem;
}
.psdb-cta p {
  font-size: .88rem;
  color: var(--psdb-muted);
  margin: 0 0 1.4rem;
}

/* ---- RESPONSIVE ---- */
@media (max-width: 640px) {
  .psdb-hero { padding: 2.2rem 1.2rem 2rem; }
  .psdb-body { padding: 1.8rem 1.2rem; }
  .psdb-nav  { padding: 0 .8rem; }
  .psdb-grid { grid-template-columns: 1fr; }
}


/* =============================================================================
   psdb-art — Artikel / Tutorial Layout (Typ B)
   Fuer Blog-Artikel, SQL_Kurs, Technisch, News
   ============================================================================= */

.psdb-art {
  background: var(--psdb-bg, #060f20);
  color: var(--psdb-text, #e2e8f0);
  font-family: 'Segoe UI', system-ui, -apple-system, sans-serif;
  font-size: 15px;
  line-height: 1.75;
}

/* ---- ARTIKEL-HEADER ---- */
.psdb-art-header {
  background: linear-gradient(160deg, #060f20 0%, #0b1e3d 100%);
  border-bottom: 1px solid rgba(46,134,193,0.2);
  padding: 2.2rem 2rem 2rem;
}
.psdb-art-meta {
  display: flex;
  align-items: center;
  gap: .6rem;
  margin-bottom: .9rem;
  flex-wrap: wrap;
}
.psdb-art-cat {
  font-size: .68rem;
  font-weight: 700;
  letter-spacing: .1em;
  text-transform: uppercase;
  color: #5dade2;
  background: rgba(46,134,193,0.1);
  border: 1px solid rgba(46,134,193,0.25);
  border-radius: 4px;
  padding: .15rem .55rem;
}
.psdb-art-date {
  font-size: .75rem;
  color: #7f94ae;
}
.psdb-art-sep { color: rgba(255,255,255,0.15); }

.psdb-art-header h1 {
  font-size: clamp(1.35rem, 2.5vw, 1.9rem);
  font-weight: 700;
  color: #fff;
  line-height: 1.25;
  letter-spacing: -.02em;
  margin: 0 0 .75rem;
  max-width: 1000px;
}
.psdb-art-lead {
  font-size: .95rem;
  color: #94a8c0;
  max-width: 780px;
  line-height: 1.6;
  margin: 0;
}

/* ---- TOC (optional) ---- */
.psdb-art-toc {
  background: rgba(10,22,40,0.7);
  border: 1px solid rgba(46,134,193,0.2);
  border-left: 3px solid #2e86c1;
  border-radius: 0 6px 6px 0;
  padding: 1rem 1.4rem;
  margin: 1.5rem 0 2rem;
  display: inline-block;
  min-width: 260px;
  max-width: 420px;
}
.psdb-art-toc-title {
  font-size: .7rem;
  font-weight: 700;
  letter-spacing: .1em;
  text-transform: uppercase;
  color: #5dade2;
  margin-bottom: .6rem;
}
.psdb-art-toc ol {
  margin: 0;
  padding-left: 1.2rem;
}
.psdb-art-toc li {
  font-size: .82rem;
  color: #94a8c0;
  margin-bottom: .2rem;
  line-height: 1.5;
}
.psdb-art-toc a {
  color: #94a8c0;
  text-decoration: none;
}
.psdb-art-toc a:hover { color: #5dade2; }

/* ---- CONTENT ---- */
.psdb-art-body {
  max-width: 1100px;
  margin: 0 auto;
  padding: 2.2rem 2rem 3rem;
}

/* Typografie */
.psdb-art-body h2 {
  font-size: 1.25rem;
  font-weight: 700;
  color: #fff;
  margin: 2.2rem 0 .8rem;
  padding-bottom: .4rem;
  border-bottom: 1px solid rgba(46,134,193,0.2);
  letter-spacing: -.01em;
}
.psdb-art-body h3 {
  font-size: 1.05rem;
  font-weight: 700;
  color: #c8dae8;
  margin: 1.8rem 0 .6rem;
}
.psdb-art-body h4 {
  font-size: .9rem;
  font-weight: 700;
  color: #94a8c0;
  text-transform: uppercase;
  letter-spacing: .06em;
  margin: 1.4rem 0 .5rem;
}
.psdb-art-body p {
  margin: 0 0 1rem;
  color: #d4dfe8;
}
.psdb-art-body a {
  color: #5dade2;
  text-decoration: none;
  border-bottom: 1px solid rgba(93,173,226,0.3);
  transition: border-color .2s;
}
.psdb-art-body a:hover {
  border-bottom-color: #5dade2;
}
.psdb-art-body ul,
.psdb-art-body ol {
  margin: 0 0 1rem 1.4rem;
  color: #d4dfe8;
}
.psdb-art-body li { margin-bottom: .3rem; line-height: 1.65; }
.psdb-art-body strong { color: #fff; font-weight: 700; }
.psdb-art-body em { color: #a9cce3; font-style: italic; }

/* Inline Code */
.psdb-art-body code {
  background: rgba(1,36,86,0.7);
  border: 1px solid rgba(46,134,193,0.25);
  border-radius: 3px;
  padding: .1rem .38rem;
  font-family: 'Cascadia Code','Consolas','Courier New',monospace;
  font-size: .82em;
  color: #9cdcfe;
}

/* Code-Block */
.psdb-art-body .psdb-code-wrap {
  margin: 1.2rem 0;
}
.psdb-art-body .psdb-code-label {
  display: inline-block;
  background: rgba(46,134,193,0.12);
  border: 1px solid rgba(46,134,193,0.25);
  border-bottom: none;
  border-radius: 6px 6px 0 0;
  padding: .18rem .7rem;
  font-size: .67rem;
  font-weight: 700;
  letter-spacing: .06em;
  text-transform: uppercase;
  color: #7f94ae;
}
.psdb-art-body pre.psdb-code {
  background: #012456;
  border: 1px solid rgba(46,134,193,0.35);
  border-radius: 0 6px 6px 6px;
  padding: 1.1rem 1.3rem;
  font-family: 'Cascadia Code','Consolas','Courier New',monospace;
  font-size: .82rem;
  line-height: 1.7;
  overflow-x: auto;
  color: #cce5ff;
  margin: 0;
}
/* Syntax-Farben */
.psdb-art-body pre.psdb-code .k   { color: #569cd6; }  /* keyword */
.psdb-art-body pre.psdb-code .s   { color: #ce9178; }  /* string */
.psdb-art-body pre.psdb-code .p   { color: #9cdcfe; }  /* parameter */
.psdb-art-body pre.psdb-code .c   { color: #6a9955; }  /* comment */
.psdb-art-body pre.psdb-code .n   { color: #4ec9b0; }  /* type */
.psdb-art-body pre.psdb-code .v   { color: #dcdcaa; }  /* function */
.psdb-art-body pre.psdb-code .num { color: #b5cea8; }  /* number */

/* Tabelle */
.psdb-art-body .psdb-table-wrap { overflow-x: auto; margin: 1.2rem 0; }
.psdb-art-body table.psdb-table {
  width: 100%;
  border-collapse: collapse;
  font-size: .83rem;
}
.psdb-art-body table.psdb-table th {
  background: rgba(46,134,193,0.1);
  color: #5dade2;
  font-weight: 700;
  letter-spacing: .04em;
  text-transform: uppercase;
  font-size: .72rem;
  padding: .6rem .9rem;
  text-align: left;
  border-bottom: 1px solid rgba(46,134,193,0.25);
}
.psdb-art-body table.psdb-table td {
  padding: .55rem .9rem;
  border-bottom: 1px solid rgba(255,255,255,0.04);
  vertical-align: top;
  color: #d4dfe8;
}
.psdb-art-body table.psdb-table tr:last-child td { border-bottom: none; }
.psdb-art-body table.psdb-table tr:hover td { background: rgba(255,255,255,0.02); }

/* Alert-Boxen */
.psdb-art-body .psdb-alert {
  border-radius: 6px;
  padding: .85rem 1.2rem;
  font-size: .84rem;
  line-height: 1.55;
  margin: 1.1rem 0;
  border-left: 3px solid;
}
.psdb-art-body .psdb-alert-info {
  background: rgba(46,134,193,0.08);
  border-color: #2e86c1;
  color: #a9cce3;
}
.psdb-art-body .psdb-alert-ok {
  background: rgba(39,174,96,0.08);
  border-color: #27ae60;
  color: #a9dfbf;
}
.psdb-art-body .psdb-alert-warn {
  background: rgba(230,126,34,0.08);
  border-color: #e67e22;
  color: #f0b27a;
}
.psdb-art-body .psdb-alert strong { color: #fff; }

/* Trennlinie */
.psdb-art-body hr {
  border: none;
  border-top: 1px solid rgba(46,134,193,0.15);
  margin: 2rem 0;
}

/* ---- ARTIKEL-FOOTER ---- */
.psdb-art-footer {
  max-width: 800px;
  margin: 0 auto;
  padding: 0 2rem 2.5rem;
  display: flex;
  flex-wrap: wrap;
  gap: .5rem;
  align-items: center;
  justify-content: space-between;
  border-top: 1px solid rgba(46,134,193,0.15);
  padding-top: 1.5rem;
}
.psdb-art-tags { display: flex; gap: .4rem; flex-wrap: wrap; }
.psdb-art-tag {
  background: rgba(46,134,193,0.08);
  border: 1px solid rgba(46,134,193,0.2);
  border-radius: 4px;
  padding: .15rem .55rem;
  font-size: .72rem;
  color: #7f94ae;
  text-decoration: none;
}
.psdb-art-tag:hover { border-color: rgba(93,173,226,0.45); color: #5dade2; }
.psdb-art-back {
  font-size: .8rem;
  color: #7f94ae;
  text-decoration: none;
  display: flex;
  align-items: center;
  gap: .3rem;
}
.psdb-art-back:hover { color: #5dade2; }

/* Responsive */
@media (max-width: 640px) {
  .psdb-art-header { padding: 1.6rem 1.2rem 1.4rem; }
  .psdb-art-body   { padding: 1.6rem 1.2rem 2rem; }
  .psdb-art-footer { padding: 1.2rem 1.2rem 2rem; }
  .psdb-art-toc    { max-width: 100%; }
}


/* =============================================================================
   KATEGORIE-LISTEN-ANSICHT (category-list / com-content-category)
   Dark-Theme für die Tabellen-Listenansicht der Kategorien
   ============================================================================= */

/* Seiten-Hintergrund */
.com-content-category,
.content-category {
  background: #060f20;
  color: #e2e8f0;
}

/* Filter-Leiste */
.com-content-category .com-content__filter {
  background: #0b1e3d;
  border-radius: 8px;
  padding: .5rem;
  gap: .5rem;
}
.com-content-category .com-content__filter input[type="text"] {
  background: #060f20;
  border: 1px solid #1a3a5c;
  color: #e2e8f0;
  border-radius: 6px;
  padding: .4rem .8rem;
}
.com-content-category .com-content__filter input[type="text"]::placeholder {
  color: #4a6580;
}
.com-content-category .com-content__filter .btn-primary {
  background: #2e86c1;
  border-color: #2e86c1;
  color: #fff;
}
.com-content-category .com-content__filter .btn-secondary {
  background: #0f2744;
  border-color: #1a3a5c;
  color: #94a8c0;
}

/* Anzeige-Auswahl (30 ▾) */
.com-content-category .form-select {
  background-color: #0b1e3d;
  border-color: #1a3a5c;
  color: #e2e8f0;
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='16' height='16' viewBox='0 0 16 16'%3E%3Cpath fill='%235dade2' d='M7.247 11.14L2.451 5.658C1.885 5.013 2.345 4 3.204 4h9.592a1 1 0 0 1 .753 1.659l-4.796 5.48a1 1 0 0 1-1.506 0z'/%3E%3C/svg%3E");
}

/* Tabelle */
.com-content-category .category.table {
  background: transparent;
  border-color: #1a3a5c;
  margin-top: 1rem;
}

/* Tabellen-Header */
.com-content-category .category.table thead th {
  background: #0b1e3d;
  color: #5dade2;
  border-color: #1a3a5c;
  font-weight: 600;
  letter-spacing: .04em;
  text-transform: uppercase;
  font-size: .78rem;
  padding: .75rem 1rem;
}
.com-content-category .category.table thead th a {
  color: #5dade2 !important;
  text-decoration: none;
}
.com-content-category .category.table thead th a:hover {
  color: #aed6f1 !important;
}

/* Tabellen-Zeilen: abwechselnd dunkel */
.com-content-category .category.table tbody tr {
  background: #060f20;
  border-color: #1a3a5c;
  transition: background .15s;
}
.com-content-category .category.table tbody tr:nth-child(even) {
  background: #0a1a30;
}
.com-content-category .category.table tbody tr:hover {
  background: #0f2744;
}

/* Tabellen-Zellen (th + td) */
.com-content-category .category.table tbody td,
.com-content-category .category.table tbody th {
  border-color: #1a3a5c;
  color: #c8d8e8;
  padding: .6rem 1rem;
  vertical-align: middle;
  font-weight: normal;
}

/* Artikel-Titel-Links (th.list-title und td) */
.com-content-category .category.table tbody th a,
.com-content-category .category.table tbody td a,
.content-category table tbody th a,
.content-category table tbody td a {
  color: #ffffff !important;
  text-decoration: underline dotted rgba(93,173,226,.6) !important;
  text-underline-offset: 3px;
  font-weight: 500;
}
.com-content-category .category.table tbody th a:hover,
.com-content-category .category.table tbody td a:hover,
.content-category table tbody th a:hover,
.content-category table tbody td a:hover {
  color: #5dade2 !important;
  text-decoration: underline !important;
}

/* Zugriffs-Zähler Badges */
.com-content-category .category.table tbody td:last-child {
  text-align: center;
}
.com-content-category .badge,
.com-content-category .category.table .hits {
  background: #1a3a5c !important;
  color: #5dade2 !important;
  border-radius: 12px;
  padding: .2rem .6rem;
  font-size: .8rem;
  font-weight: 600;
}

/* Pagination */
.com-content-category .pagination {
  justify-content: center;
  margin-top: 1.5rem;
}
.com-content-category .page-link {
  background: #0b1e3d;
  border-color: #1a3a5c;
  color: #5dade2;
}
.com-content-category .page-link:hover {
  background: #2e86c1;
  color: #fff;
  border-color: #2e86c1;
}
.com-content-category .page-item.active .page-link {
  background: #2e86c1;
  border-color: #2e86c1;
  color: #fff;
}
.com-content-category .page-item.disabled .page-link {
  background: #060f20;
  border-color: #1a3a5c;
  color: #3a5570;
}

/* =============================================================================
   VORHER / WEITER ARTIKEL-NAVIGATION
   Joomla rendert .pager-newer / .pager-older als Bootstrap-Pagination
   ============================================================================= */

.pager {
  display: flex;
  justify-content: space-between;
  align-items: center;
  margin: 2.5rem 0 1rem;
  padding: 1rem 0;
  border-top: 1px solid #1a3a5c;
}
.pager .previous a,
.pager .next a,
.pager-newer a,
.pager-older a {
  display: inline-flex;
  align-items: center;
  gap: .5rem;
  background: #0b1e3d;
  border: 1px solid #1a3a5c;
  color: #5dade2 !important;
  padding: .55rem 1.1rem;
  border-radius: 7px;
  font-size: .9rem;
  font-weight: 600;
  text-decoration: none !important;
  transition: background .2s, border-color .2s;
}
.pager .previous a:hover,
.pager .next a:hover,
.pager-newer a:hover,
.pager-older a:hover {
  background: #2e86c1;
  border-color: #2e86c1;
  color: #fff !important;
}
/* Pfeil-Icons via CSS */
.pager .previous a::before { content: '←  '; }
.pager .next a::after      { content: '  →'; }

/* ── psdb eigene Artikel-Navigation (helix-article-default.php) ── */
.psdb-article-nav {
   display: none !important;
  justify-content: space-between;
  align-items: stretch;
  gap: 1rem;
  margin: 2.5rem 0 1rem;
  padding-top: 1.5rem;
  border-top: 1px solid #1a3a5c;
}
.psdb-nav-btn {
  display: flex;
  flex-direction: column;
  gap: .25rem;
  background: #0b1e3d;
  border: 1px solid #1a3a5c;
  border-radius: 8px;
  padding: .85rem 1.2rem;
  text-decoration: none !important;
  color: #e2e8f0 !important;
  max-width: 45%;
  transition: background .2s, border-color .2s;
}
.psdb-nav-btn:hover {
  background: #0f2744;
  border-color: #2e86c1;
  color: #fff !important;
}
.psdb-nav-next { align-items: flex-end; text-align: right; margin-left: auto; }
.psdb-nav-prev { align-items: flex-start; text-align: left; }
.psdb-nav-arrow {
  font-size: 1.2rem;
  color: #5dade2;
  line-height: 1;
}
.psdb-nav-label {
  font-size: .7rem;
  font-weight: 700;
  letter-spacing: .1em;
  text-transform: uppercase;
  color: #5dade2;
}
.psdb-nav-title {
  font-size: .88rem;
  font-weight: 500;
  color: #e2e8f0;
  line-height: 1.35;
}
@media (max-width: 600px) {
  .psdb-article-nav { flex-direction: column; }
  .psdb-nav-btn     { max-width: 100%; }
  .psdb-nav-next    { align-items: flex-start; text-align: left; }
}

/* =============================================================================
   BLOG-LISTEN-ANSICHT (com-content-category-blog)
   Zeigt pro Artikel nur den psdb-art-header als Vorschau-Karte.
   Body wird ausgeblendet — "Weiterlesen" führt zum vollen Artikel.
   ============================================================================= */

/* Seiten-Hintergrund auch in der Listen-Ansicht dunkel */
.com-content-category-blog,
.com-content-category-blog .blog-items {
  background: #060f20;
}

/* Jeder Artikel-Eintrag als abgesetzte Karte */
.com-content-category-blog .blog-item {
  background: #0b1e3d;
  border: 1px solid #1a3a5c;
  border-radius: 10px;
  margin-bottom: 1.5rem;
  overflow: hidden;
  transition: border-color .2s, box-shadow .2s;
}
.com-content-category-blog .blog-item:hover {
  border-color: #2e86c1;
  box-shadow: 0 4px 24px rgba(46,134,193,.18);
}

/* psdb-art im Listen-Kontext: kein Abstand, kein Shadow (Karte übernimmt) */
.com-content-category-blog .article-introtext .psdb-art {
  background: transparent;
  box-shadow: none;
  border-radius: 0;
  margin: 0;
}

/* Header dunkler Gradient-Streifen */
.com-content-category-blog .article-introtext .psdb-art-header {
  background: linear-gradient(135deg, #0b1e3d 0%, #0f2744 100%);
  border-bottom: none;
  padding: 1.4rem 1.6rem 1.2rem;
}

/* Body komplett ausblenden — nur Teaserzeile sichtbar */
.com-content-category-blog .article-introtext .psdb-art-body {
  display: none;
}

/* Artikel-Titel in der Liste etwas kleiner */
.com-content-category-blog .article-introtext .psdb-art-header h1 {
  font-size: 1.25rem;
  margin-bottom: 0;
  color: #e2e8f0;
}

/* Kategorie-Pill */
.com-content-category-blog .article-introtext .psdb-art-cat {
  font-size: .72rem;
  padding: .25rem .7rem;
  margin-bottom: .6rem;
}

/* "Weiterlesen"-Link als Button */
.com-content-category-blog .article-more-link {
  padding: .75rem 1.6rem 1rem;
  background: #0b1e3d;
}
.com-content-category-blog .article-more-link a {
  display: inline-block;
  background: #2e86c1;
  color: #fff !important;
  padding: .4rem 1.1rem;
  border-radius: 6px;
  font-size: .85rem;
  font-weight: 600;
  text-decoration: none !important;
  transition: background .2s;
}
.com-content-category-blog .article-more-link a:hover {
  background: #1a6a9f;
}

/* Seiten-Pagination */
.com-content-category-blog .pagination {
  margin-top: 1.5rem;
  justify-content: center;
}
.com-content-category-blog .page-link {
  background: #0b1e3d;
  border-color: #1a3a5c;
  color: #5dade2;
}
.com-content-category-blog .page-link:hover {
  background: #2e86c1;
  color: #fff;
}
.com-content-category-blog .page-item.active .page-link {
  background: #2e86c1;
  border-color: #2e86c1;
  color: #fff;
}

/* =========================================================================
   WEBSITE-FIXES: Kontrast + Überschriften - 2026-05-31
   ========================================================================= */

/* ========== FIX 1: KONTRAST ========== */
/* Helle Text auf hellem Hintergrund (z.B. /ueber/background) */

/* Kritisch: Spans mit inline-style background (#eef2f5) müssen dunklen Text haben */
span[style*="background: #eef2f5"],
span[style*="background:#eef2f5"] {
  color: #1a202c !important; /* Dunkeltext für helle Backgrounds */
}

/* Allgemein: Alle Spans mit hellen Hintergründen */
span[style*="background: #fff"],
span[style*="background: white"],
span[style*="background-color: #fff"],
span[style*="background-color: white"],
span[style*="background: #f"] {
  color: #1a202c !important;
}

.entry-content p,
.article-content p,
.timeline p,
.about-intro p,
article p {
  color: #2d3748 !important; /* Dunkelgrau statt Hellgrau */
}

/* Explizit für die /ueber/background Seite */
.itemid-103 p,
[data-article-id="background"] p {
  color: #1a202c !important; /* Noch dunkler für besseren Kontrast */
}

/* Allgemein: Wenn Hintergrund hell (#fff oder white), Text dunkel */
[style*="background: #fff"],
[style*="background: white"],
[style*="background-color: #fff"],
[style*="background-color: white"] {
  color: #1a202c !important;
}

/* Ensure strong text auf hellem Hintergrund ist auch lesbar */
.entry-content strong,
.article-content strong,
article strong {
  color: #1a202c;
}

/* ========== FIX 2: ÜBERSCHRIFTEN ========== */
/* SQL-Blog: Nummerte Überschriften auf 1 Zeile halten (z.B. "02 Sicherheitsarchitektur") */

/* Kritisch: .feat-header Container muss Numero + Title horizontal halten */
.feat-header {
  display: flex;
  flex-direction: row;               /* Horizontal layout */
  width: 100%;
  gap: 1rem;
  align-items: flex-start;
}

/* Nummer darf nicht brechen */
.feat-num {
  flex-shrink: 0;                    /* Nicht schrumpfen */
  white-space: nowrap;
  min-width: fit-content;
}

/* Title-Wrapper darf sich ausdehnen, aber Title bleibt auf 1 Zeile */
.feat-title-wrap {
  flex: 1;
  min-width: 0;                      /* Erlaubt overflow ellipsis */
}

.feat-area,
.feat-title-wrap h2 {
  white-space: nowrap;               /* Keine Umbrüche */
  overflow: hidden;
  text-overflow: ellipsis;           /* Falls zu lang: ... zeigen */
}

/* Allgemeine Überschriften */
h2, h3, h4,
.article-title,
.post-title,
.section-heading,
.numbered-title {
  white-space: nowrap;               /* Keine Umbrüche */
  overflow: hidden;                  /* Overflow verstecken statt umbrechen */
  text-overflow: ellipsis;           /* Falls zu lang: ... zeigen */
  max-width: 100%;
}

/* Speziell für nummerte Überschriften (01, 02, etc.) */
.numbered-heading,
.section-number {
  display: inline;                   /* Inline damit Nummer + Text zusammen */
  margin-right: 0.5rem;
}

/* Für Mobile: Responsive anpassen */
@media (max-width: 767px) {
  .feat-header {
    flex-direction: column;           /* Auf Mobile: übereinander */
  }

  h2, h3 {
    white-space: normal;             /* Normale Umbrüche auf Mobile */
  }
}
