/* =====================================================================
   swirt – Joomla 5 Template
   Design: "Leitstand" – Praxis-IT & Telematikinfrastruktur
   Akzent: swirt Signalrot #DC4554 | Self-hosted Fonts (DSGVO-konform)
   ===================================================================== */

/* ----------  Self-hosted Fonts (kein externer CDN-Call)  ---------- */
@font-face {
  font-family: 'Archivo Variable';
  src: url('../fonts/archivo-var.woff2') format('woff2-variations');
  font-weight: 100 900;
  font-display: swap;
  font-style: normal;
}
@font-face {
  font-family: 'IBM Plex Sans';
  src: url('../fonts/plexsans-400.woff2') format('woff2');
  font-weight: 400; font-display: swap; font-style: normal;
}
@font-face {
  font-family: 'IBM Plex Sans';
  src: url('../fonts/plexsans-600.woff2') format('woff2');
  font-weight: 600; font-display: swap; font-style: normal;
}
@font-face {
  font-family: 'IBM Plex Mono';
  src: url('../fonts/plexmono-400.woff2') format('woff2');
  font-weight: 400; font-display: swap; font-style: normal;
}
@font-face {
  font-family: 'IBM Plex Mono';
  src: url('../fonts/plexmono-500.woff2') format('woff2');
  font-weight: 500; font-display: swap; font-style: normal;
}

/* ----------  Design Tokens  ---------- */
:root {
  --signal:       #DC4554;   /* swirt Markenrot                */
  --signal-deep:  #B82F3E;   /* Hover/aktiv                    */
  --signal-soft:  #FCEEF0;   /* zarte rosa Fläche              */
  --ink:          #0E1B2A;   /* Text & dunkle Sektionen        */
  --ink-2:        #16293D;   /* Panel auf dunkel               */
  --ink-3:        #233a54;   /* Linie auf dunkel               */
  --paper:        #F6F8FB;   /* kühles Klinikweiß (Hintergrund)*/
  --white:        #FFFFFF;
  --slate:        #51637A;   /* Sekundärtext                   */
  --slate-2:      #7587A0;   /* gedämpft                       */
  --line:         #E2E8F1;   /* Hairline                       */
  --ok:           #1FB57A;   /* Status grün (Monitoring)       */

  --font-display: 'Archivo Variable', 'Archivo', system-ui, sans-serif;
  --font-body:    'IBM Plex Sans', system-ui, -apple-system, Segoe UI, Roboto, sans-serif;
  --font-mono:    'IBM Plex Mono', ui-monospace, SFMono-Regular, Menlo, monospace;

  --wrap: 1180px;
  --gap: clamp(1rem, 4vw, 2.25rem);
  --radius: 14px;
  --radius-sm: 9px;
  --shadow: 0 1px 2px rgba(14,27,42,.05), 0 12px 32px -12px rgba(14,27,42,.18);
  --shadow-lg: 0 30px 70px -30px rgba(14,27,42,.45);
}

/* ----------  Reset / Base  ---------- */
*, *::before, *::after { box-sizing: border-box; }
html { -webkit-text-size-adjust: 100%; scroll-behavior: smooth; }
body {
  margin: 0;
  font-family: var(--font-body);
  font-size: 1.0625rem;
  line-height: 1.65;
  color: var(--ink);
  background: var(--paper);
  -webkit-font-smoothing: antialiased;
  text-rendering: optimizeLegibility;
}
img { max-width: 100%; height: auto; display: block; }
a { color: var(--signal); text-decoration: none; }
a:hover { color: var(--signal-deep); }
:focus-visible { outline: 3px solid var(--signal); outline-offset: 2px; border-radius: 4px; }

h1, h2, h3, h4 {
  font-family: var(--font-display);
  font-weight: 700;
  line-height: 1.07;
  letter-spacing: -0.018em;
  color: var(--ink);
  margin: 0 0 .5em;
}
h1 { font-size: clamp(2.4rem, 6vw, 4.1rem); }
h2 { font-size: clamp(1.8rem, 4vw, 2.7rem); }
h3 { font-size: 1.3rem; letter-spacing: -0.01em; }
p  { margin: 0 0 1.1em; }

.wrap { width: min(var(--wrap), 100% - 2 * var(--gap)); margin-inline: auto; }

/* ----------  Eyebrow (Mono-Label, Monitoring-Sprache)  ---------- */
.eyebrow {
  font-family: var(--font-mono);
  font-size: .73rem;
  font-weight: 500;
  letter-spacing: .14em;
  text-transform: uppercase;
  color: var(--signal);
  display: inline-flex;
  align-items: center;
  gap: .55rem;
  margin-bottom: 1rem;
}
.eyebrow::before {
  content: "";
  width: 22px; height: 1px; background: var(--signal);
  display: inline-block;
}

/* ----------  Buttons  ---------- */
.btn {
  --bg: var(--signal); --fg: #fff;
  display: inline-flex; align-items: center; gap: .55rem;
  font-family: var(--font-body); font-weight: 600; font-size: .98rem;
  padding: .85rem 1.5rem; border-radius: 999px;
  background: var(--bg); color: var(--fg);
  border: 1px solid transparent; cursor: pointer;
  transition: transform .18s ease, box-shadow .18s ease, background .18s ease;
  box-shadow: 0 8px 20px -10px rgba(220,69,84,.7);
}
.btn:hover { background: var(--signal-deep); color: #fff; transform: translateY(-2px); box-shadow: 0 14px 28px -12px rgba(220,69,84,.8); }
.btn--ghost {
  --bg: transparent; --fg: var(--ink);
  border-color: var(--line); box-shadow: none;
}
.btn--ghost:hover { background: var(--white); color: var(--ink); border-color: var(--ink); transform: translateY(-2px); }
.btn--on-dark { --bg: #fff; --fg: var(--ink); box-shadow: none; }
.btn--on-dark:hover { background: var(--paper); color: var(--ink); }
.btn--ghost-dark { --bg: transparent; --fg:#fff; border-color: var(--ink-3); box-shadow:none;}
.btn--ghost-dark:hover { background: var(--ink-2); color:#fff; border-color: var(--slate-2);}
.btn .arr { transition: transform .18s ease; }
.btn:hover .arr { transform: translateX(3px); }

/* =====================================================================
   TOPBAR – Status-Leiste (Signature: liest sich wie ein Monitoring-NOC)
   ===================================================================== */
.topbar {
  background: var(--ink);
  color: #cdd7e4;
  font-family: var(--font-mono);
  font-size: .76rem;
  letter-spacing: .02em;
}
.topbar .wrap {
  display: flex; align-items: center; gap: 1.4rem;
  min-height: 38px; flex-wrap: wrap;
}
.topbar__status { display: inline-flex; align-items: center; gap: .5rem; color: #e7edf4; }
.dot { width: 8px; height: 8px; border-radius: 50%; background: var(--ok); display: inline-block; position: relative; }
.dot::after {
  content:""; position:absolute; inset:-4px; border-radius:50%;
  border: 1px solid var(--ok); opacity:.6;
  animation: pulse 2.4s ease-out infinite;
}
@keyframes pulse { 0%{transform:scale(.6);opacity:.7} 100%{transform:scale(1.9);opacity:0} }
.topbar__sep { color: var(--ink-3); }
.topbar__spacer { margin-left: auto; }
.topbar a { color: #cdd7e4; }
.topbar a:hover { color: #fff; }
.topbar__meta { display: inline-flex; gap: 1.4rem; }
@media (max-width: 760px){
  .topbar__meta { display:none; }
  .topbar__spacer { margin-left:auto; }
}

/* =====================================================================
   HEADER / NAV
   ===================================================================== */
.site-header {
  position: sticky; top: 0; z-index: 50;
  background: rgba(246,248,251,.82);
  backdrop-filter: saturate(140%) blur(12px);
  border-bottom: 1px solid var(--line);
}
.site-header .wrap { display: flex; align-items: center; gap: 1.5rem; min-height: 74px; }
.brand { display: inline-flex; align-items: center; gap: .7rem; flex-shrink: 0; }
.brand img { height: 30px; width: auto; }
.brand__type {
  font-family: var(--font-display); font-weight: 700; font-size: 1.45rem;
  letter-spacing: -.03em; color: var(--ink);
}
.brand__type b { color: var(--signal); font-weight: 700; }

.nav { margin-left: auto; }
.nav ul { list-style: none; display: flex; gap: .35rem; margin: 0; padding: 0; }
.nav a {
  display: block; padding: .55rem .85rem; border-radius: 8px;
  font-weight: 600; font-size: .96rem; color: var(--ink);
}
.nav a:hover { background: var(--white); color: var(--signal); }
.nav .active > a, .nav .current > a { color: var(--signal); }
.header-cta { flex-shrink: 0; }

.nav-toggle {
  display: none; margin-left: auto; background: var(--ink); color:#fff;
  border:0; border-radius: 8px; width: 44px; height: 40px; cursor: pointer;
}
.nav-toggle span, .nav-toggle span::before, .nav-toggle span::after {
  content:""; display:block; width:18px; height:2px; background:#fff; margin:0 auto; position:relative;
}
.nav-toggle span::before { position:absolute; top:-6px; }
.nav-toggle span::after  { position:absolute; top:6px; }

@media (max-width: 900px) {
  .header-cta { display: none; }
  .nav-toggle { display: inline-block; }
  .nav {
    position: absolute; top: 100%; left: 0; right: 0;
    background: var(--white); border-bottom: 1px solid var(--line);
    margin: 0; padding: .5rem var(--gap) 1rem;
    display: none; box-shadow: var(--shadow);
  }
  .nav.open { display: block; }
  .nav ul { flex-direction: column; gap: 0; }
  .nav a { padding: .8rem .4rem; border-bottom: 1px solid var(--line); border-radius: 0; }
}

/* =====================================================================
   HERO
   ===================================================================== */
.hero { padding: clamp(2.5rem, 7vw, 5.5rem) 0 clamp(2.5rem, 6vw, 4.5rem); position: relative; overflow: hidden; }
.hero::before {
  content:""; position:absolute; top:-30%; right:-12%;
  width: 620px; height: 620px; border-radius:50%;
  background: radial-gradient(circle at 30% 30%, rgba(220,69,84,.10), transparent 62%);
  pointer-events:none;
}
.hero .wrap { display: grid; grid-template-columns: 1.05fr .95fr; gap: clamp(2rem,5vw,4rem); align-items: center; }
.hero__title { margin-bottom: 1rem; }
.hero__title .accent { color: var(--signal); }
.hero__lead { font-size: 1.18rem; color: var(--slate); max-width: 34ch; margin-bottom: 1.8rem; }
.hero__cta { display: flex; gap: .8rem; flex-wrap: wrap; }
.hero__note { margin-top: 1.5rem; font-family: var(--font-mono); font-size: .78rem; color: var(--slate-2); letter-spacing:.02em; }

/* ----------  Leitstand-Panel (Signature)  ---------- */
.leitstand {
  background: var(--ink);
  border-radius: var(--radius);
  box-shadow: var(--shadow-lg);
  color: #dbe4ef;
  overflow: hidden;
  border: 1px solid var(--ink-3);
}
.leitstand__bar {
  display: flex; align-items: center; gap: .5rem;
  padding: .7rem 1rem; border-bottom: 1px solid var(--ink-3);
  font-family: var(--font-mono); font-size: .72rem; letter-spacing: .08em; color: #9fb0c6;
  text-transform: uppercase;
}
.leitstand__bar .led { width:9px;height:9px;border-radius:50%; }
.led--r{background:#ff5f57} .led--y{background:#febc2e} .led--g{background:#28c840}
.leitstand__title { margin-left: auto; }
.leitstand__rows { padding: .4rem 0; }
.lrow {
  display: flex; align-items: center; gap: 1rem;
  padding: .72rem 1.15rem; font-family: var(--font-mono); font-size: .86rem;
  border-bottom: 1px dashed rgba(255,255,255,.06);
}
.lrow:last-child { border-bottom: 0; }
.lrow__k { color: #9fb0c6; }
.lrow__v { margin-left: auto; color: #fff; font-weight: 500; display:inline-flex; align-items:center; gap:.5rem; }
.lrow__v .dot { box-shadow: 0 0 0 3px rgba(31,181,122,.18); }
.lrow__v.warn { color: #febc2e; }
.lrow__v .ok { color: var(--ok); }

/* =====================================================================
   TRUST STRIP (Kennzahlen)
   ===================================================================== */
.trust { border-top: 1px solid var(--line); border-bottom: 1px solid var(--line); background: var(--white); }
.trust .wrap { display: grid; grid-template-columns: repeat(4, 1fr); }
.stat { padding: 1.6rem 1rem; text-align: center; border-left: 1px solid var(--line); }
.stat:first-child { border-left: 0; }
.stat__n { font-family: var(--font-display); font-weight: 700; font-size: 2rem; color: var(--ink); letter-spacing: -.02em; }
.stat__n b { color: var(--signal); }
.stat__l { font-family: var(--font-mono); font-size: .72rem; letter-spacing: .08em; text-transform: uppercase; color: var(--slate); }
@media (max-width: 720px){ .trust .wrap { grid-template-columns: repeat(2,1fr); } .stat:nth-child(odd){border-left:0;} .stat:nth-child(n+3){border-top:1px solid var(--line);} }

/* =====================================================================
   SECTIONS
   ===================================================================== */
.section { padding: clamp(3rem, 8vw, 6rem) 0; }
.section--tint { background: var(--signal-soft); }
.section__head { max-width: 620px; margin-bottom: 2.6rem; }
.section__head p { color: var(--slate); font-size: 1.1rem; margin-bottom: 0; }

/* ----------  Leistungs-Karten  ---------- */
.cards { display: grid; grid-template-columns: repeat(3, 1fr); gap: 1.2rem; }
@media (max-width: 900px){ .cards { grid-template-columns: repeat(2,1fr);} }
@media (max-width: 620px){ .cards { grid-template-columns: 1fr;} }
.card {
  background: var(--white); border: 1px solid var(--line); border-radius: var(--radius);
  padding: 1.6rem 1.5rem; transition: transform .2s ease, box-shadow .2s ease, border-color .2s ease;
  position: relative;
}
.card:hover { transform: translateY(-4px); box-shadow: var(--shadow); border-color: #cdd7e6; }
.card__ico {
  width: 46px; height: 46px; border-radius: 11px; display: grid; place-items: center;
  background: var(--signal-soft); color: var(--signal); margin-bottom: 1.1rem;
}
.card__ico svg { width: 24px; height: 24px; }
.card h3 { margin-bottom: .45rem; }
.card p { color: var(--slate); font-size: .98rem; margin-bottom: 0; }
.card__tag {
  position:absolute; top:1.5rem; right:1.5rem;
  font-family: var(--font-mono); font-size:.66rem; letter-spacing:.06em;
  color: var(--slate-2); text-transform: uppercase;
}

/* =====================================================================
   TI-SEKTION (dunkel) – swirt Spezialgebiet
   ===================================================================== */
.ti { background: var(--ink); color: #cdd7e4; position: relative; overflow:hidden; }
.ti::before{
  content:""; position:absolute; inset:0;
  background-image: radial-gradient(rgba(255,255,255,.04) 1px, transparent 1px);
  background-size: 26px 26px; opacity:.5; pointer-events:none;
}
.ti .wrap { position: relative; display: grid; grid-template-columns: 1fr 1fr; gap: clamp(2rem,5vw,4rem); align-items: center; }
.ti h2 { color: #fff; }
.ti .eyebrow { color: #ff8a96; }
.ti .eyebrow::before { background:#ff8a96; }
.ti p { color: #aab9cc; }
.ti__list { list-style: none; margin: 1.5rem 0 2rem; padding: 0; display: grid; gap: .8rem; }
.ti__list li { display: flex; gap: .75rem; align-items: flex-start; color:#d7e0ec; }
.ti__list svg { flex-shrink:0; width: 22px; height: 22px; color: var(--signal); margin-top:2px; }
.ti-card {
  background: linear-gradient(160deg, var(--ink-2), #0c1828);
  border: 1px solid var(--ink-3); border-radius: var(--radius); padding: 1.6rem;
  font-family: var(--font-mono); box-shadow: var(--shadow-lg);
}
.ti-card__h { font-size:.72rem; letter-spacing:.1em; text-transform:uppercase; color:#8fa1b8; margin-bottom:1rem; display:flex; align-items:center; gap:.5rem;}
.ti-bar { margin: .7rem 0 1.1rem; }
.ti-bar__t { display:flex; justify-content:space-between; font-size:.8rem; color:#c4d0de; margin-bottom:.35rem; }
.ti-bar__track { height: 7px; border-radius: 99px; background: var(--ink-3); overflow:hidden; }
.ti-bar__fill { height:100%; border-radius:99px; background: linear-gradient(90deg, var(--ok), #57d39e); }
.ti-bar__fill.warn { background: linear-gradient(90deg,#febc2e,#ffd479); }

/* =====================================================================
   ABLAUF – echte Sequenz, daher nummeriert
   ===================================================================== */
.steps { display: grid; grid-template-columns: repeat(4,1fr); gap: 1.2rem; counter-reset: step; }
@media (max-width:900px){ .steps{ grid-template-columns:repeat(2,1fr);} }
@media (max-width:540px){ .steps{ grid-template-columns:1fr;} }
.step { position: relative; padding-top: 2.4rem; }
.step__n {
  font-family: var(--font-mono); font-size: .78rem; color: var(--signal); font-weight:500;
  letter-spacing:.1em; position:absolute; top:0; left:0;
}
.step::before {
  content:""; position:absolute; top: .4rem; left: 2.6rem; right: -.6rem; height:1px;
  background: repeating-linear-gradient(90deg, var(--line) 0 6px, transparent 6px 12px);
}
.step:last-child::before { display:none; }
.step h3 { font-size: 1.12rem; margin-bottom: .35rem; }
.step p { color: var(--slate); font-size: .95rem; margin-bottom:0; }

/* =====================================================================
   WISSEN / KB-Teaser
   ===================================================================== */
.kb { display:grid; grid-template-columns: 1.1fr .9fr; gap: clamp(2rem,5vw,3.5rem); align-items:center; }
.kb-panel {
  background: var(--white); border:1px solid var(--line); border-radius: var(--radius);
  padding: .4rem; box-shadow: var(--shadow);
}
.kb-item { display:flex; align-items:center; gap:.9rem; padding:.95rem 1.1rem; border-bottom:1px solid var(--line); font-size:.96rem; }
.kb-item:last-child{ border-bottom:0; }
.kb-item__tag { font-family:var(--font-mono); font-size:.66rem; letter-spacing:.05em; text-transform:uppercase; color:var(--signal); background:var(--signal-soft); padding:.2rem .5rem; border-radius:5px; flex-shrink:0;}
.kb-item__arr { margin-left:auto; color:var(--slate-2); }
@media (max-width:780px){ .kb{ grid-template-columns:1fr;} }

/* =====================================================================
   CTA-Sektion
   ===================================================================== */
.cta-band {
  background: linear-gradient(135deg, var(--signal), #c5394a);
  border-radius: var(--radius); padding: clamp(2.2rem,5vw,3.5rem); color:#fff;
  display:flex; align-items:center; justify-content:space-between; gap:2rem; flex-wrap:wrap;
  box-shadow: 0 30px 60px -25px rgba(220,69,84,.6);
}
.cta-band h2 { color:#fff; margin-bottom:.3rem; }
.cta-band p { color: rgba(255,255,255,.9); margin-bottom:0; }

/* =====================================================================
   FOOTER
   ===================================================================== */
.site-footer { background: var(--ink); color:#9fb0c6; padding: 3.5rem 0 2rem; font-size:.95rem; }
.site-footer .wrap { display:grid; grid-template-columns: 1.4fr 1fr 1fr 1fr; gap: 2rem; }
.site-footer h4 { color:#fff; font-family:var(--font-mono); font-size:.74rem; letter-spacing:.1em; text-transform:uppercase; margin-bottom:1rem; }
.site-footer a { color:#9fb0c6; }
.site-footer a:hover { color:#fff; }
.site-footer ul { list-style:none; margin:0; padding:0; display:grid; gap:.55rem; }
.foot-brand__type { font-family:var(--font-display); font-weight:700; font-size:1.4rem; color:#fff; letter-spacing:-.03em; }
.foot-brand__type b { color: var(--signal); }
.foot-brand p { max-width: 34ch; color:#8295ac; margin-top:.6rem; }
.foot-status { font-family:var(--font-mono); font-size:.78rem; color:#8295ac; display:inline-flex; align-items:center; gap:.5rem; margin-top:1rem;}
.foot-bottom {
  border-top:1px solid var(--ink-3); margin-top:2.5rem; padding-top:1.4rem;
  display:flex; justify-content:space-between; gap:1rem; flex-wrap:wrap;
  font-family:var(--font-mono); font-size:.76rem; color:#7587a0;
}
@media (max-width:780px){ .site-footer .wrap{ grid-template-columns:1fr 1fr;} }
@media (max-width:480px){ .site-footer .wrap{ grid-template-columns:1fr;} }

/* =====================================================================
   JOOMLA INHALT – Artikel / Komponente / Module (innere Seiten)
   ===================================================================== */
.page-main { padding: clamp(2rem,5vw,3.5rem) 0 4rem; }
.page-main .wrap { display: grid; grid-template-columns: minmax(0,1fr); gap: 2.5rem; }
.page-main.has-sidebar .wrap { grid-template-columns: minmax(0,1fr) 320px; }
@media (max-width: 880px){ .page-main.has-sidebar .wrap { grid-template-columns: 1fr; } }

.com-content, .item-page, .blog, main article { background: transparent; }
.page-main h1 { margin-bottom: 1rem; }
.page-main a { color: var(--signal); text-decoration: underline; text-underline-offset: 3px; }
.page-main img { border-radius: var(--radius-sm); }
.page-main table { width:auto; max-width:100%; border-collapse: collapse; margin: 1rem 0; font-size:.96rem; }
.page-main table.table th, .page-main table.table td { padding:.7rem .9rem; border:1px solid var(--line); text-align:left; }
.page-main table.table th { background: var(--signal-soft); font-family: var(--font-mono); font-size:.8rem; letter-spacing:.04em; text-transform:uppercase; color: var(--ink); }
.page-main blockquote {
  margin: 1.5rem 0; padding: 1rem 1.4rem; border-left: 3px solid var(--signal);
  background: var(--white); border-radius: 0 var(--radius-sm) var(--radius-sm) 0; color: var(--slate);
}
.page-main pre, .page-main code { font-family: var(--font-mono); }
.page-main pre { background: var(--ink); color:#dbe4ef; padding:1.1rem 1.3rem; border-radius: var(--radius-sm); overflow:auto; font-size:.88rem; }
.page-main :not(pre) > code { background: var(--signal-soft); color: var(--signal-deep); padding:.12em .4em; border-radius:5px; font-size:.9em; }

.page-heading, .page-title { font-family: var(--font-display); }
.breadcrumb { font-family: var(--font-mono); font-size:.76rem; color: var(--slate); list-style:none; display:flex; gap:.5rem; padding:0; margin:0 0 1.4rem; flex-wrap:wrap; }
.breadcrumb a { color: var(--slate); }
.breadcrumb .divider { color: var(--slate-2); }

/* Sidebar-Module */
.sidebar .moduletable, aside .moduletable { background: var(--white); border:1px solid var(--line); border-radius: var(--radius); padding:1.3rem 1.4rem; margin-bottom:1.2rem; }
.moduletable > h3, .sidebar h3.moduletitle { font-size: .82rem; font-family: var(--font-mono); letter-spacing:.08em; text-transform:uppercase; color: var(--signal); margin-bottom:.9rem; }

/* Joomla Standardklassen abdecken */
.btn-primary, button.btn { background: var(--signal); }
.alert { border-radius: var(--radius-sm); padding: 1rem 1.2rem; border:1px solid var(--line); background: var(--white); }
.alert-success { border-color:#bfe8d5; background:#eafaf2; color:#14794f; }
.alert-danger  { border-color:#f3c2c8; background: var(--signal-soft); color: var(--signal-deep); }
.pagination { list-style:none; display:flex; gap:.35rem; padding:0; flex-wrap:wrap; }
.pagination a, .pagination span { display:block; padding:.4rem .7rem; border:1px solid var(--line); border-radius:8px; font-size:.9rem; background:#fff; }
.pagination .active span { background: var(--signal); color:#fff; border-color: var(--signal); }

/* Offline / Error helpers */
.center-narrow { min-height: 70vh; display:grid; place-items:center; text-align:center; padding: 2rem; }
.center-narrow .box { max-width: 520px; }

/* Skip link */
.skip-link { position:absolute; left:-999px; top:0; background: var(--ink); color:#fff; padding:.6rem 1rem; border-radius:0 0 8px 0; z-index:100; }
.skip-link:focus { left:0; color:#fff; }

/* ----------  Reveal-Animation (dezent, respektiert Prefers-Reduced-Motion)  ---------- */
.reveal { opacity: 0; transform: translateY(14px); transition: opacity .6s ease, transform .6s ease; }
.reveal.in { opacity: 1; transform: none; }

@media (prefers-reduced-motion: reduce) {
  * { animation: none !important; scroll-behavior: auto !important; }
  .reveal { opacity: 1; transform: none; transition: none; }
  .dot::after { display:none; }
}

/* =====================================================================
   v1.1 – Re-Skin der bestehenden swirt-Struktur
   ===================================================================== */

/* ----------  Brand + Tagline  ---------- */
.brand { gap: .85rem; }
.brand__tag {
  font-family: var(--font-mono); font-size: .7rem; letter-spacing: .02em;
  color: var(--slate); border-left: 1px solid var(--line); padding-left: .85rem;
  max-width: 17ch; line-height: 1.25;
}
@media (max-width: 1040px){ .brand__tag { display:none; } }

/* ----------  Dropdown-Navigation (mod_menu mit Untermenüs)  ---------- */
.nav ul ul {
  position: absolute; top: calc(100% + 8px); left: 0; min-width: 240px;
  background: var(--white); border: 1px solid var(--line); border-radius: var(--radius-sm);
  box-shadow: var(--shadow); padding: .4rem; display: none; flex-direction: column; z-index: 60;
}
.nav > ul > li, .nav-fallback > li { position: relative; }
.nav li.parent > a, .nav li.item-with-children > a { display: inline-flex; align-items: center; gap: .35rem; }
.nav li.parent > a::after, .nav li.item-with-children > a::after {
  content: ""; width: 6px; height: 6px; border-right: 2px solid currentColor; border-bottom: 2px solid currentColor;
  transform: rotate(45deg) translateY(-2px); opacity: .6;
}
.nav > ul > li:hover > ul,
.nav > ul > li:focus-within > ul,
.nav-fallback > li:hover > ul,
.nav-fallback > li:focus-within > ul { display: flex; }
.nav ul ul a { padding: .6rem .8rem; border-radius: 7px; font-weight: 500; white-space: nowrap; }
.nav ul ul a:hover { background: var(--signal-soft); color: var(--signal); }

@media (max-width: 900px){
  .nav ul ul {
    position: static; display: flex; box-shadow: none; border: 0; border-radius: 0;
    padding: 0 0 .4rem 1rem; min-width: 0; background: transparent;
  }
  .nav li.parent > a::after, .nav li.item-with-children > a::after { display: none; }
  .nav ul ul a { border-bottom: 1px solid var(--line); }
}

/* ----------  Hero: Leistungsbereiche-Panel  ---------- */
.pillars { padding: .5rem; display: grid; gap: .4rem; }
.pillar {
  display: flex; align-items: center; gap: .9rem; padding: .85rem .95rem;
  border-radius: var(--radius-sm); color: #dbe4ef; transition: background .18s ease;
}
.pillar:hover { background: var(--ink-2); color: #fff; }
.pillar__ico {
  width: 40px; height: 40px; flex-shrink: 0; border-radius: 10px; display: grid; place-items: center;
  background: rgba(220,69,84,.14); color: #ff8a96;
}
.pillar__ico svg { width: 22px; height: 22px; }
.pillar__t { display: flex; flex-direction: column; line-height: 1.3; }
.pillar__t b { font-family: var(--font-body); font-weight: 600; font-size: .98rem; color: #fff; }
.pillar__t span { font-family: var(--font-mono); font-size: .72rem; color: #9fb0c6; }
.pillar__arr { margin-left: auto; color: var(--slate-2); transition: transform .18s ease; }
.pillar:hover .pillar__arr { transform: translateX(3px); color: #ff8a96; }

/* ----------  Slider-Zone  ---------- */
.slider-zone { padding: 0 0 1.5rem; }
.slider-zone img { border-radius: var(--radius); width: 100%; }

/* ----------  Home: Beitrags-Feed  ---------- */
.home-main { padding: clamp(2.5rem, 6vw, 4.5rem) 0; }
.home-main .section__head { margin-bottom: 2rem; }

/* Joomla Featured/Blog -> Karten-Optik */
.content-area .items-leading,
.content-area .items-row,
.content-area .blog-items,
.content-area .com-content-category-blog__items {
  display: grid; gap: 1.4rem; margin: 0 0 1.4rem; padding: 0; list-style: none;
}
.content-area .items-row,
.content-area .com-content-category-blog__items { grid-template-columns: repeat(auto-fill, minmax(320px, 1fr)); }

.content-area .item,
.content-area .blog-item,
.content-area [class*="item-"] > .item {
  background: var(--white); border: 1px solid var(--line); border-radius: var(--radius);
  padding: 1.6rem 1.7rem; box-shadow: var(--shadow); margin: 0;
  transition: transform .2s ease, box-shadow .2s ease, border-color .2s ease;
}
.content-area .item:hover { transform: translateY(-3px); border-color: #cdd7e6; }
.content-area .item > *:last-child { margin-bottom: 0; }
.content-area .item h1, .content-area .item h2, .content-area .item h3 { font-size: 1.4rem; margin-bottom: .6rem; }
.content-area .item h2 a, .content-area .item h3 a { color: var(--ink); text-decoration: none; }
.content-area .item h2 a:hover, .content-area .item h3 a:hover { color: var(--signal); }
.content-area .item-image img, .content-area .item img.float-start,
.content-area .item figure img { border-radius: var(--radius-sm); margin-bottom: 1rem; }
.content-area .article-info, .content-area .createdby, .content-area .published {
  font-family: var(--font-mono); font-size: .73rem; letter-spacing: .03em; color: var(--slate-2);
  text-transform: uppercase; margin-bottom: .8rem;
}
.content-area .readmore { margin-top: 1rem; }
.content-area .readmore a, .content-area a.btn-readmore {
  display: inline-flex; align-items: center; gap: .4rem; font-weight: 600; font-size: .92rem;
  color: var(--signal); text-decoration: none;
}
.content-area .readmore a::after { content: "→"; transition: transform .18s ease; }
.content-area .readmore a:hover::after { transform: translateX(3px); }
/* Layout-Tabellen in bestehenden Beiträgen nicht zerstören */
.content-area table { border: 0; }
.content-area table td, .content-area table th { border: 0; background: transparent; padding: .35rem .5rem; }

/* ----------  Partner-Logos  ---------- */
.partners { background: var(--white); border-top: 1px solid var(--line); border-bottom: 1px solid var(--line); padding: 2.2rem 0; }
.partners .wrap { display: flex; align-items: center; gap: 2rem; flex-wrap: wrap; }
.partners__label { font-family: var(--font-mono); font-size: .72rem; letter-spacing: .12em; text-transform: uppercase; color: var(--slate-2); flex-shrink: 0; }
.partners__logos { display: flex; align-items: center; gap: 2.2rem; flex-wrap: wrap; flex: 1; }
.partners__logos img {
  max-height: 38px; width: auto; filter: grayscale(1); opacity: .65;
  transition: filter .2s ease, opacity .2s ease;
}
.partners__logos img:hover { filter: grayscale(0); opacity: 1; }
.partners__logos a { display: inline-flex; }

/* ----------  Footer-Module  ---------- */
.foot-modules { border-top: 1px solid var(--ink-3); margin-top: 1.5rem; padding-top: 1.5rem; }
.foot-modules a { color: #9fb0c6; }
.foot-modules a:hover { color: #fff; }
.foot-bottom a { color: #7587a0; }
.foot-bottom a:hover { color: #fff; }

/* =====================================================================
   swirt – Navigations-Fix für Joomla mod_menu (Dropdowns)
   Ans ENDE von /templates/swirt/css/template.css anhängen, dann Strg+F5.
   Behebt: Untermenü klappt beim Rübergehen sofort wieder zu (Hover-Gap).
   ===================================================================== */

/* Oberste Ebene horizontal */
.nav > ul,
.nav .mod-menu {
  list-style: none; display: flex; flex-wrap: wrap; align-items: center;
  gap: .2rem; margin: 0; padding: 0;
}
.nav > ul > li,
.nav .mod-menu > li { position: relative; }

.nav .mod-menu a,
.nav > ul a,
.nav .mod-menu > li > span {
  display: block; padding: .55rem .85rem; border-radius: 8px;
  font-weight: 600; font-size: .96rem; color: var(--ink);
  text-decoration: none; white-space: nowrap;
}
.nav a:hover { background: #fff; color: var(--signal); }
.nav .current > a, .nav .active > a { color: var(--signal); }

/* Pfeil bei Einträgen mit Untermenü */
.nav li.parent > a { display: inline-flex; align-items: center; gap: .4rem; }
.nav li.parent > a::after {
  content: ""; width: 6px; height: 6px;
  border-right: 2px solid currentColor; border-bottom: 2px solid currentColor;
  transform: rotate(45deg) translateY(-1px); opacity: .55;
}

/* Untermenü-Panel – BÜNDIG an top:100% (kein Spalt mehr) */
.nav .mod-menu__sub,
.nav > ul ul,
.nav .mod-menu ul {
  position: absolute; top: 100%; left: 0; min-width: 252px;
  margin: 0; padding: .4rem; list-style: none;
  background: #fff; border: 1px solid var(--line); border-radius: 11px;
  box-shadow: var(--shadow); display: none; z-index: 200;
}

/* Unsichtbare Hover-Brücke direkt unter dem Hauptpunkt */
.nav > ul > li.parent::after,
.nav .mod-menu > li.parent::after {
  content: ""; position: absolute; left: 0; right: 0; top: 100%; height: 12px;
}

/* Anzeigen, solange Haupt-LI gehovert/fokussiert ist */
.nav > ul > li:hover > ul,
.nav > ul > li:focus-within > ul,
.nav .mod-menu > li:hover > .mod-menu__sub,
.nav .mod-menu > li:hover > ul,
.nav .mod-menu > li:focus-within > .mod-menu__sub,
.nav .mod-menu > li:focus-within > ul { display: block; }

.nav ul ul a { font-weight: 500; }
.nav ul ul a:hover { background: var(--signal-soft); color: var(--signal); }

/* Mobil: aufgeklappt & eingerückt statt Dropdown */
@media (max-width: 900px) {
  .nav > ul, .nav .mod-menu { flex-direction: column; align-items: stretch; }
  .nav .mod-menu__sub,
  .nav > ul ul,
  .nav .mod-menu ul {
    position: static; display: block; box-shadow: none; border: 0;
    border-radius: 0; padding: 0 0 .4rem 1rem; min-width: 0;
  }
  .nav li.parent > a::after { display: none; }
  .nav a { border-bottom: 1px solid var(--line); border-radius: 0; }
}

/* =====================================================================
   Joomla Screenreader-Utility (versteckt z. B. "More about: ..." im Menü)
   ===================================================================== */
.visually-hidden,
.sr-only,
.visually-hidden-focusable:not(:focus):not(:focus-within) {
  position: absolute !important;
  width: 1px; height: 1px;
  padding: 0; margin: -1px;
  overflow: hidden; clip: rect(0, 0, 0, 0);
  white-space: nowrap; border: 0;
}
