/* ============================================================
   K-CNS · Das Systemhaus GmbH — Stylesheet
   Hell · freundlich · einladend · IT für die Medizin
   ============================================================ */

:root{
  /* Marke — exakt das Blau aus dem Logo (#0008E7) + abgeleitete Abstufungen */
  --blue:        #0008e7;
  --blue-600:    #0008e7;
  --blue-700:    #0006ad;
  --blue-500:    #3340ff;
  --blue-400:    #5e6bff;
  /* "Navy" = kräftiges Logo-Blau (kein fast-Schwarz mehr) */
  --navy:        #0008e7;
  --navy-deep:   #060a78;
  --blue-tint:   #eef2ff;
  --blue-tint-2: #f5f8ff;
  --blue-glow:   rgba(23,48,214,.16);

  /* Medical-Office Co-Brand */
  --mo-red:  #c8102e;
  --mo-ink:  #1f2a30;
  --mo-tint: #fdeef0;

  /* Neutralwerte */
  --ink:    #111726;
  --ink-2:  #2a3247;
  --muted:  #5d6782;
  --line:   #e6eaf3;
  --line-2: #eef1f8;
  --bg:     #ffffff;
  --bg-soft:#f5f8fd;
  --bg-soft-2:#eef3fb;

  --shadow-sm: 0 2px 8px rgba(16,28,70,.06);
  --shadow-md: 0 14px 40px -18px rgba(16,28,70,.22);
  --shadow-lg: 0 40px 80px -30px rgba(16,28,70,.30);
  --shadow-blue: 0 20px 45px -18px rgba(23,48,214,.45);

  --r-sm: 12px;
  --r:    18px;
  --r-lg: 26px;
  --r-xl: 34px;

  --maxw: 1280px;
  --pad: clamp(20px, 5vw, 64px);

  --ff-display: "Bricolage Grotesque", "Hanken Grotesk", system-ui, sans-serif;
  --ff-body:    "Hanken Grotesk", system-ui, -apple-system, sans-serif;
}

*,*::before,*::after{ box-sizing:border-box; margin:0; padding:0; }
html{ scroll-behavior:smooth; -webkit-text-size-adjust:100%; }
body{
  font-family:var(--ff-body);
  color:var(--ink);
  background:var(--bg);
  line-height:1.62;
  font-size:18px;
  font-weight:400;
  letter-spacing:.005em;
  overflow-x:hidden;
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
}
img{ max-width:100%; display:block; }
a{ color:inherit; text-decoration:none; }
ul{ list-style:none; }

h1,h2,h3,h4{
  font-family:var(--ff-display);
  font-weight:700;
  line-height:1.08;
  letter-spacing:-.02em;
  color:var(--ink);
  text-wrap:balance;
}

.wrap{ width:100%; max-width:var(--maxw); margin-inline:auto; padding-inline:var(--pad); }
.section{ padding-block:clamp(64px,9vw,124px); position:relative; }
.section--soft{ background:var(--bg-soft); }
.center{ text-align:center; }

/* ---------- Eyebrow / Section heads ---------- */
.eyebrow{
  display:inline-flex; align-items:center; gap:10px;
  font-size:.94rem; font-weight:700; letter-spacing:.13em; text-transform:uppercase;
  color:var(--blue-700);
  background:var(--blue-tint);
  padding:11px 22px; border-radius:100px;
  border:1px solid #dde3ff;
}
/* Punkt vor dem Text entfernt (Kundenwunsch) */
/* Einheitlicher Abstand zwischen Label-Pill und Überschrift überall */
.eyebrow + h1, .eyebrow + h2, .eyebrow + .mo-logo{ margin-top:30px; }
.eyebrow--light{ color:#eaf0ff; background:rgba(255,255,255,.16); border-color:rgba(255,255,255,.32); }
.eyebrow--mo{ color:var(--mo-red); background:var(--mo-tint); border-color:#f6d2d8; }

.sec-head{ max-width:760px; }
.sec-head.center{ margin-inline:auto; }
.sec-head.wide{ max-width:1000px; }
.sec-title{
  /* Einheitliche Größe für ALLE Abschnitts-Überschriften — so groß wie möglich,
     dass auch die längste einzeilige noch auf eine Zeile passt (gemessen: max ~3,1rem) */
  font-size:clamp(2rem,4.5vw,3rem);
  line-height:1.26; /* mehr Abstand zw. umbrechenden Zeilen (sonst klebt die Highlight-Box) */
  margin:0 0 16px;
}
.sec-sub{ color:var(--ink-2); font-size:1.16rem; max-width:64ch; }

/* Farbig hinterlegte Schlüsselwörter in Überschriften ("mehr Farbe & Kontrast") */
.mark{
  background:linear-gradient(120deg,var(--blue),var(--blue-500));
  color:#fff; padding:.04em .34em; border-radius:.28em;
  -webkit-box-decoration-break:clone; box-decoration-break:clone;
}
.mark--red{ background:linear-gradient(120deg,var(--mo-red),#e23b54); }
.nowrap{ white-space:nowrap; }
/* "oneline" behält nur das Nicht-Umbrechen ab Desktop; Größe = wie alle anderen Überschriften */
@media(min-width:1180px){
  .sec-head.wide{ max-width:none; }
  .sec-title.oneline{ white-space:nowrap; }
}
.sec-head.center .sec-sub{ margin-inline:auto; }

/* ---------- Buttons ---------- */
.btn{
  display:inline-flex; align-items:center; justify-content:center; gap:10px;
  font-family:var(--ff-body); font-weight:700; font-size:1.08rem;
  padding:16px 32px; border-radius:100px; cursor:pointer;
  border:1px solid transparent; transition:.25s cubic-bezier(.2,.7,.3,1);
  white-space:nowrap;
}
.btn svg{ width:20px; height:20px; }
.btn-primary{
  background:var(--blue); color:#fff;
  box-shadow:var(--shadow-blue);
}
.btn-primary:hover{ background:var(--blue-700); transform:translateY(-2px); box-shadow:0 26px 50px -18px rgba(23,48,214,.6); }
.btn-ghost{
  background:#fff; color:var(--ink); border-color:var(--line);
  box-shadow:var(--shadow-sm);
}
.btn-ghost:hover{ border-color:var(--blue); color:var(--blue-700); transform:translateY(-2px); }
.btn-light{ background:#fff; color:var(--blue-700); }
.btn-light:hover{ transform:translateY(-2px); box-shadow:var(--shadow-md); }
.btn-outline-light{ background:rgba(255,255,255,.06); color:#fff; border-color:rgba(255,255,255,.35); }
.btn-outline-light:hover{ background:rgba(255,255,255,.14); transform:translateY(-2px); }
.btn-mo{ background:var(--mo-red); color:#fff; box-shadow:0 18px 40px -16px rgba(200,16,46,.6); }
.btn-mo:hover{ background:#a50c25; transform:translateY(-2px); }
/* "MEDICAL OFFICE entdecken": weißer Hintergrund, rote, fette Schrift (Kundenwunsch) */
.btn-mo-light{ background:#fff; color:var(--mo-red); font-weight:800; border-color:#f3c9d0; box-shadow:var(--shadow-sm); }
.btn-mo-light:hover{ background:var(--mo-tint); color:#a50c25; transform:translateY(-2px); box-shadow:var(--shadow-md); }
.btn-lg{ padding:19px 40px; font-size:1.18rem; }

/* ---------- Top utility bar ---------- */
.topbar{
  background:linear-gradient(90deg,var(--blue-700),var(--blue) 55%,var(--blue-500));
  color:#eaefff;
  font-size:.9rem; font-weight:600;
}
.topbar .wrap{ display:flex; align-items:center; justify-content:space-between; gap:16px; padding-block:9px; }
.topbar a{ color:#e7ecff; transition:.2s; }
.topbar a:hover{ color:#fff; }
.topbar .tb-left{ display:flex; gap:22px; align-items:center; flex-wrap:wrap; }
.topbar .tb-item{ display:inline-flex; align-items:center; gap:7px; }
.topbar .tb-item svg{ width:14px; height:14px; opacity:.8; }
.topbar .tb-right{ display:flex; gap:18px; }
@media(max-width:760px){ .topbar .tb-right{ display:none; } .topbar .tb-left{ gap:16px; font-size:.8rem; } }

/* ---------- Header / Nav ---------- */
.nav{
  position:sticky; top:0; z-index:50;
  background:rgba(255,255,255,.82);
  backdrop-filter:saturate(180%) blur(16px);
  -webkit-backdrop-filter:saturate(180%) blur(16px);
  border-bottom:1px solid transparent;
  transition:border-color .3s, box-shadow .3s;
}
.nav.scrolled{ border-bottom-color:var(--line); box-shadow:0 6px 24px -16px rgba(16,28,70,.3); }
.nav .wrap{ display:flex; align-items:center; justify-content:space-between; height:104px; gap:20px; }
.brand{ display:flex; align-items:center; gap:14px; }
.brand img{ height:80px; width:auto; border-radius:14px; box-shadow:var(--shadow-sm); }
/* b-txt: „Das Systemhaus" ist der optische Anker und sitzt auf der Mittellinie
   (= auf einer Linie mit den Menüpunkten); die Tagline hängt absolut darunter. */
.brand .b-txt{ position:relative; line-height:1.05; white-space:nowrap; }
.brand .b-name{ display:block; font-family:var(--ff-display); font-weight:700; font-size:1.4rem; letter-spacing:-.01em; color:var(--ink); }
.brand .b-tag{ position:absolute; top:calc(100% + 2px); left:0; font-size:.74rem; color:var(--muted); font-weight:600; letter-spacing:.07em; text-transform:uppercase; }
@media(max-width:600px){
  .brand{ gap:11px; }
  .brand img{ height:60px; }
  .brand .b-name{ font-size:1.18rem; }
  .brand .b-tag{ font-size:.62rem; letter-spacing:.05em; }
  .nav-cta .btn-primary{ display:none; }
}
@media(max-width:360px){ .brand .b-tag{ display:none; } .brand img{ height:54px; } }

.nav-links{ display:flex; align-items:center; gap:2px; }
.nav-links a{
  font-size:.99rem; font-weight:600; color:var(--ink-2);
  padding:10px 12px; border-radius:10px; transition:.2s; white-space:nowrap;
}
.nav-links a:hover{ color:var(--blue-700); background:var(--blue-tint); }
.nav-links a[aria-current="page"]{ color:var(--blue-700); background:var(--blue-tint); }
.nav-cta{ display:flex; align-items:center; gap:9px; }
.nav-cta .btn{ padding:12px 19px; font-size:.98rem; }
/* "Anrufen" im Desktop-Header ausgeblendet (Nummer steht in der Topbar + im Info-Panel) */
.nav-cta .btn-ghost{ display:none; }

/* Info-Button in der Menüleiste: reiner Icon-Button (nur "i"), gleiche Höhe wie die anderen Buttons */
.info-btn{
  display:inline-flex; align-items:center; justify-content:center;
  width:52px; height:52px; padding:0; border-radius:50%; cursor:pointer;
  background:var(--blue-tint); color:var(--blue);
  border:1px solid #dde3ff; transition:.2s;
}
.info-btn svg{ width:28px; height:28px; }
.info-btn:hover{ background:var(--blue); color:#fff; border-color:var(--blue); transform:translateY(-1px); box-shadow:var(--shadow-blue); }
.info-btn[aria-expanded="true"]{ background:var(--blue); color:#fff; border-color:var(--blue); }
@media(max-width:1240px){ .nav-cta .info-wrap{ display:none; } }

.burger{ display:none; flex-direction:column; gap:5px; background:none; border:0; cursor:pointer; padding:8px; }
.burger span{ width:26px; height:2.5px; background:var(--ink); border-radius:3px; transition:.3s; }
.burger.open span:nth-child(1){ transform:translateY(7.5px) rotate(45deg); }
.burger.open span:nth-child(2){ opacity:0; }
.burger.open span:nth-child(3){ transform:translateY(-7.5px) rotate(-45deg); }

@media(max-width:1240px){
  .nav-links, .nav-cta .btn-ghost{ display:none; }
  .burger{ display:flex; }
  /* "Beratung anfragen" nach rechts an den Burger heranrücken (nicht mittig schweben) */
  .nav-cta{ margin-left:auto; }
}

/* Mobile drawer */
.drawer{
  position:fixed; inset:0 0 0 auto; width:min(86vw,360px);
  background:#fff; z-index:60; transform:translateX(100%);
  transition:transform .35s cubic-bezier(.2,.7,.3,1);
  padding:28px 26px; display:flex; flex-direction:column; gap:6px;
  box-shadow:var(--shadow-lg); overflow-y:auto;
}
.drawer.open{ transform:translateX(0); }
.drawer a{ font-size:1.1rem; font-weight:600; padding:13px 8px; border-bottom:1px solid var(--line-2); }
.drawer .btn{ margin-top:18px; }
.drawer-head{ display:flex; justify-content:space-between; align-items:center; margin-bottom:14px; }
.drawer-close{ background:none; border:0; font-size:2rem; line-height:1; cursor:pointer; color:var(--muted); }
.overlay{ position:fixed; inset:0; background:rgba(8,14,40,.45); z-index:55; opacity:0; visibility:hidden; transition:.3s; }
.overlay.open{ opacity:1; visibility:visible; }

/* ============================================================
   HERO
   ============================================================ */
/* Helles Hero: weißer Hintergrund, Text links, Foto rechts (Kundenwunsch) */
.hero{
  position:relative; overflow:hidden; color:var(--ink);
  background:
    radial-gradient(1100px 520px at 88% -8%, var(--blue-tint), transparent 60%),
    linear-gradient(180deg,#ffffff 0%,#f4f7ff 100%);
  padding-top:clamp(40px,5vw,76px); padding-bottom:clamp(56px,7vw,104px);
}
.hero .wrap{ position:relative; z-index:2; }
.hero-grid{ display:grid; grid-template-columns:1.04fr .96fr; gap:clamp(34px,5vw,68px); align-items:stretch; }
@media(max-width:960px){
  /* Mobile-Reihenfolge: Eyebrow → Überschrift → Bild → Text → Buttons → Chips */
  .hero-grid{ display:flex; flex-direction:column; align-items:stretch; gap:20px; }
  .hero-copy, .hero-media{ display:contents; }
  .hero-copy .eyebrow{ order:1; align-self:flex-start; }
  .hero-copy h1{ order:2; margin:0; max-width:none; } /* volle Breite statt schmaler Spalte */
  .hero-media > img{ order:3; margin:0; }
  .hero-copy .lead{ order:4; margin:0; }
  .hero-copy .hero-cta{ order:5; margin:0; }
  .hero-media .hero-chips{ order:6; }
}
.hero-copy{ max-width:620px; align-self:center; }

.hero h1{
  font-size:clamp(2.6rem,5.4vw,4.2rem); color:var(--ink);
  letter-spacing:-.025em; margin-bottom:22px; max-width:16ch;
}
.hero h1 .accent{ color:var(--blue); }
.hero h1 .hl{
  white-space:nowrap; color:#fff;
  background:linear-gradient(120deg,var(--blue),var(--blue-500));
  padding:.02em .26em; border-radius:.26em;
}
.hero p.lead{ font-size:1.24rem; color:var(--ink-2); max-width:56ch; margin-bottom:32px; }
.hero-cta{ display:flex; gap:14px; flex-wrap:wrap; margin-bottom:30px; }
/* Hero-CTAs nebeneinander: gleich breit; passen beide nicht in eine Zeile, stapeln sie sauber
   (min-width:max-content verhindert Schrumpfen unter die Textbreite → kein Überlauf) */
.hero .hero-cta .btn{ padding:15px 18px; font-size:1rem; flex:1 1 0; min-width:max-content; }
/* MEDICAL-OFFICE-Sektion: Buttons ebenso nebeneinander (wie Deckblatt) */
.mo .hero-cta .btn{ padding:16px 22px; font-size:1.04rem; flex:1 1 0; min-width:max-content; }

/* Hero-Bildseite: Bild füllt die volle Höhe der linken Textspalte */
.hero-media{ position:relative; min-height:100%; }
.hero-media > img{
  width:100%; height:100%; min-height:440px; object-fit:cover;
  border-radius:var(--r-xl); box-shadow:var(--shadow-lg); border:1px solid var(--line);
}
/* 3 Chips schweben einzeln an den Rändern des Bildes (ragen leicht heraus) + sanfte Schwebe-Animation */
.hero-media .hero-chips{
  position:absolute; inset:0; z-index:4; margin:0; display:block; pointer-events:none;
}
.hero-media .hero-chips .chip{
  position:absolute; pointer-events:auto;
  background:rgba(255,255,255,.95); border-color:rgba(255,255,255,.8);
  box-shadow:var(--shadow-lg); backdrop-filter:saturate(160%) blur(8px);
  -webkit-backdrop-filter:saturate(160%) blur(8px);
  animation:chip-float 5s ease-in-out infinite;
}
.hero-media .hero-chips .chip:nth-child(1){ top:44%; left:-26px;  animation-delay:.9s; }
.hero-media .hero-chips .chip:nth-child(2){ top:9%;  right:-26px; animation-delay:0s; }
.hero-media .hero-chips .chip:nth-child(3){ bottom:11%; right:-16px; animation-delay:1.8s; }
@keyframes chip-float{ 0%,100%{ transform:translateY(0); } 50%{ transform:translateY(-11px); } }

@media(max-width:960px){
  .hero-media > img{ height:auto; aspect-ratio:16/10; min-height:0; }
  /* Mobil: Chips unter dem Bild als umbrechende Reihe */
  .hero-media .hero-chips{ position:static; inset:auto; display:flex; flex-wrap:wrap; gap:10px; margin:0; pointer-events:auto; }
  .hero-media .hero-chips .chip{ position:static; animation:none; box-shadow:var(--shadow-sm); backdrop-filter:none; -webkit-backdrop-filter:none; }
}
@media(prefers-reduced-motion:reduce){ .hero-media .hero-chips .chip{ animation:none; } }
.hero-chips{ display:flex; gap:10px; flex-wrap:wrap; }
.chip{
  display:inline-flex; align-items:center; gap:9px;
  background:#fff; border:1px solid var(--line); border-radius:100px;
  padding:11px 20px; font-size:.92rem; font-weight:600; color:var(--ink-2);
  box-shadow:var(--shadow-sm); line-height:1;
}
.chip svg{ width:16px; height:16px; color:var(--blue); }

/* Hero visual */
.hero-visual{ position:relative; }
.hero-card{
  position:relative; background:#fff; border:1px solid var(--line);
  border-radius:var(--r-lg); box-shadow:var(--shadow-lg); overflow:hidden;
}
.hero-card .hc-bar{ display:flex; align-items:center; gap:7px; padding:13px 18px; border-bottom:1px solid var(--line-2); background:var(--bg-soft); }
.hero-card .hc-bar i{ width:11px; height:11px; border-radius:50%; background:#d4dae8; display:block; }
.hero-card .hc-bar i:nth-child(1){ background:#ff6058; }
.hero-card .hc-bar i:nth-child(2){ background:#ffbd2e; }
.hero-card .hc-bar i:nth-child(3){ background:#28c840; }
.hero-card .hc-bar span{ margin-left:10px; font-size:.82rem; color:var(--muted); font-weight:600; }
.hero-card img{ width:100%; height:auto; }

.float-card{
  position:absolute; background:#fff; border:1px solid var(--line);
  border-radius:16px; box-shadow:var(--shadow-md); padding:14px 17px;
  display:flex; align-items:center; gap:12px; z-index:3;
}
.float-card .fc-ic{
  width:42px; height:42px; border-radius:12px; flex:none;
  display:grid; place-items:center; color:#fff;
}
.float-card .fc-t{ font-family:var(--ff-display); font-weight:700; font-size:1.05rem; line-height:1; }
.float-card .fc-s{ font-size:.78rem; color:var(--muted); }
.float-card.fc-1{ top:-26px; left:-26px; background:#fff; animation:floaty 5.5s ease-in-out infinite; }
.float-card.fc-1 .fc-ic{ background:linear-gradient(135deg,#0008e7,#3340ff); }
.float-card.fc-2{ bottom:-24px; right:-20px; animation:floaty 6.5s ease-in-out infinite .8s; }
.float-card.fc-2 .fc-ic{ background:linear-gradient(135deg,#19a36a,#22c281); }
@keyframes floaty{ 0%,100%{ transform:translateY(0); } 50%{ transform:translateY(-12px); } }
@media(max-width:560px){ .float-card{ display:none; } }

/* ---------- Counter band ---------- */
.stats{ display:grid; grid-template-columns:repeat(3,1fr); gap:clamp(20px,4vw,48px); }
@media(max-width:680px){ .stats{ gap:10px; } }
.stat{ text-align:center; padding:14px; }
.stat .num{ font-family:var(--ff-display); font-weight:700; font-size:clamp(2.6rem,6vw,3.6rem); color:var(--blue); line-height:1; letter-spacing:-.03em; }
.stat .lbl{ margin-top:10px; color:var(--muted); font-weight:600; font-size:1rem; }

/* ============================================================
   MEDICAL OFFICE Showcase
   ============================================================ */
.mo{ background:linear-gradient(180deg,#fff, #fafbff 60%, #fff); position:relative; overflow:hidden; }
.mo-hero{ display:grid; grid-template-columns:1fr 1fr; gap:clamp(34px,5vw,64px); align-items:center; }
@media(max-width:940px){ .mo-hero{ grid-template-columns:1fr; } .mo-hero .mo-visual{ order:2; } }
.mo-logo{ height:54px; width:auto; margin-bottom:22px; }
.mo h2{ font-size:clamp(1.9rem,3.8vw,3rem); }
.mo .mo-claim{ color:var(--mo-red); font-weight:700; }
.mo-visual{ position:relative; }
.mo-visual img{ width:100%; border-radius:var(--r-lg); box-shadow:var(--shadow-lg); border:1px solid var(--line); background:#fff; }
/* Freigestellte Illustration: ohne Karte/Rahmen/Schatten, damit die Köpfe frei herausragen */
.mo-visual img.mo-illu{ background:transparent; border:0; box-shadow:none; border-radius:0; }
.mo-badge{
  position:absolute; top:-18px; right:-14px; background:#fff; border:1px solid #f0d9b3;
  border-radius:16px; padding:10px 14px; box-shadow:var(--shadow-md); z-index:4;
  display:flex; align-items:center; gap:10px;
}
.mo-badge img{ height:46px; width:auto; box-shadow:none; border:0; border-radius:0; }
@media(max-width:560px){ .mo-badge{ position:static; margin-bottom:16px; display:inline-flex; } }

.mo-modules{ display:grid; grid-template-columns:repeat(4,1fr); gap:14px; margin-top:40px; }
@media(max-width:820px){ .mo-modules{ grid-template-columns:repeat(2,1fr); } }
.mo-mod{
  background:#fff; border:1px solid var(--line); border-radius:var(--r);
  padding:20px 16px; text-align:center; transition:.25s; box-shadow:var(--shadow-sm);
  min-width:0;
}
.mo-mod:hover{ transform:translateY(-5px); box-shadow:var(--shadow-md); border-color:#f3c9d0; }
.mo-mod img{ width:66px; height:66px; margin:0 auto 12px; transition:transform .45s cubic-bezier(.2,.7,.3,1); }
.mo-mod:hover img{ transform:scale(1.18); }
.mo-mod .mm-t{ font-family:var(--ff-display); font-weight:700; font-size:.98rem; overflow-wrap:break-word; hyphens:auto; }
.mo-mod .mm-s{ font-size:.82rem; color:var(--muted); margin-top:3px; overflow-wrap:break-word; hyphens:auto; }

/* ============================================================
   Cards grid (Leistungen)
   ============================================================ */
.cards{ display:grid; grid-template-columns:repeat(3,1fr); gap:22px; margin-top:52px; }
@media(max-width:900px){ .cards{ grid-template-columns:repeat(2,1fr); } }
@media(max-width:600px){ .cards{ grid-template-columns:1fr; } }
.card{
  background:#fff; border:1px solid var(--line); border-radius:var(--r-lg);
  padding:0; transition:.28s cubic-bezier(.2,.7,.3,1); position:relative; overflow:hidden;
  box-shadow:var(--shadow-sm); display:flex; flex-direction:column;
}
.card:hover{ transform:translateY(-7px); box-shadow:var(--shadow-md); border-color:#d4ddff; }
/* Bild-/Motivfläche oben (Platzhalter; 1:1 durch echtes Foto ersetzbar) */
.card-media{
  position:relative; height:172px; overflow:hidden; display:grid; place-items:center;
  background:linear-gradient(135deg,var(--c1,#0008e7),var(--c2,#3340ff));
}
.card-media img{ position:absolute; inset:0; width:100%; height:100%; object-fit:cover; transition:transform .6s cubic-bezier(.2,.7,.3,1); }
.card-media::after{
  content:""; position:absolute; inset:0;
  background:radial-gradient(120px 120px at 78% 22%, rgba(255,255,255,.28), transparent 70%),
             repeating-linear-gradient(135deg, rgba(255,255,255,.06) 0 12px, transparent 12px 24px);
}
.card-media .card-ic{
  position:relative; z-index:2; width:74px; height:74px; border-radius:18px; display:grid; place-items:center;
  background:rgba(255,255,255,.16); color:#fff; backdrop-filter:blur(2px);
  transition:transform .6s cubic-bezier(.2,.7,.3,1);
}
.card-media .card-ic svg{ width:38px; height:38px; }
.card:hover .card-media .card-ic{ transform:scale(1.12); }
.card:hover .card-media img{ transform:scale(1.08); }
/* Karte mit echtem Foto: Icon + Diagonalmuster weg, dezenter Scrim */
.card-media:has(img) .card-ic{ display:none; }
.card-media:has(img)::after{ background:linear-gradient(180deg, rgba(8,14,70,.04), rgba(8,14,70,.16)); }
/* Foto konnte nicht geladen werden → zurück zum sauberen Icon-Fallback (kein roher Alt-Text) */
.card-media.media-broken img{ display:none; }
.card-media.media-broken .card-ic{ display:grid; }
.card-media.media-broken::after{
  background:radial-gradient(120px 120px at 78% 22%, rgba(255,255,255,.28), transparent 70%),
             repeating-linear-gradient(135deg, rgba(255,255,255,.06) 0 12px, transparent 12px 24px);
}
.card-body{ padding:26px 28px 30px; display:flex; flex-direction:column; flex:1; }
.card h3{ font-size:1.36rem; margin-bottom:9px; }
.card p{ color:var(--muted); font-size:1.04rem; }
.card-list{ margin-top:16px; display:flex; flex-direction:column; gap:8px; }
.card-list li{ display:flex; gap:9px; align-items:flex-start; font-size:1rem; color:var(--ink-2); }
.card-list svg{ width:18px; height:18px; min-width:18px; color:var(--blue); flex:none; margin-top:4px; }

/* Solutions (4) — Bild-Motiv oben + Nummer (Kundenwunsch: "da müssen Bilder rein") */
.sol-grid{ display:grid; grid-template-columns:repeat(2,1fr); gap:24px; margin-top:52px; }
@media(max-width:760px){ .sol-grid{ grid-template-columns:1fr; } }
.sol{
  background:#fff; border:1px solid var(--line); border-radius:var(--r-lg); overflow:hidden;
  box-shadow:var(--shadow-sm); transition:.28s; display:flex; flex-direction:column;
}
.sol:hover{ transform:translateY(-6px); box-shadow:var(--shadow-md); }
.sol-media{
  position:relative; height:190px; overflow:hidden; display:grid; place-items:center;
  background:linear-gradient(135deg,var(--c1,#0008e7),var(--c2,#3340ff));
}
.sol-media img{ position:absolute; inset:0; width:100%; height:100%; object-fit:cover; transition:transform .6s cubic-bezier(.2,.7,.3,1); }
.sol-media::after{
  content:""; position:absolute; inset:0;
  background:radial-gradient(160px 140px at 80% 18%, rgba(255,255,255,.26), transparent 70%);
}
.sol:hover .sol-media img{ transform:scale(1.08); }
.sol-ic{ position:relative; z-index:2; width:64px; height:64px; color:#fff; transition:transform .6s cubic-bezier(.2,.7,.3,1); }
.sol:hover .sol-ic{ transform:scale(1.12); }
/* Lösungs-Karte mit Foto: Icon weg (Nummer bleibt), dezenter Scrim für Lesbarkeit */
.sol-media:has(img) .sol-ic{ display:none; }
.sol-media:has(img)::after{ background:linear-gradient(180deg, rgba(8,14,70,.06) 35%, rgba(8,14,70,.34)); }
/* Foto konnte nicht geladen werden → Icon-Fallback wieder zeigen */
.sol-media.media-broken img{ display:none; }
.sol-media.media-broken .sol-ic{ display:block; }
.sol-num{
  position:absolute; top:16px; left:18px; z-index:2;
  font-family:var(--ff-display); font-weight:700; font-size:1.05rem;
  width:44px; height:44px; border-radius:12px; display:grid; place-items:center;
  background:rgba(255,255,255,.18); color:#fff; border:1px solid rgba(255,255,255,.35);
}
.sol-body{ padding:26px 28px 30px; }
.sol h3{ font-size:1.34rem; margin-bottom:8px; }
.sol p{ color:var(--muted); font-size:1.03rem; }

/* ============================================================
   Ablauf / Steps
   ============================================================ */
.steps{ display:grid; grid-template-columns:repeat(4,1fr); gap:20px; margin-top:54px; counter-reset:step; }
@media(max-width:900px){ .steps{ grid-template-columns:repeat(2,1fr); } }
@media(max-width:560px){
  .steps{ grid-template-columns:1fr; gap:26px; }
  /* Schritt als kompakte Zeile: gefüllter Nummern-Kreis links, Text rechts */
  .step{ display:grid; grid-template-columns:auto 1fr; column-gap:16px; padding-top:0; align-items:start; }
  .step .step-n{ grid-row:1 / span 2; margin-bottom:0; background:var(--blue); color:#fff; }
  .step h3{ margin:0 0 5px; }
  .step p{ margin:0; }
}
.step{ position:relative; padding-top:14px; }
.step .step-n{
  font-family:var(--ff-display); font-weight:700; font-size:1.05rem;
  width:46px; height:46px; border-radius:50%; display:grid; place-items:center;
  background:#fff; border:2px solid var(--blue); color:var(--blue); margin-bottom:18px; position:relative; z-index:2;
}
.step h3{ font-size:1.18rem; margin-bottom:8px; }
.step p{ color:var(--muted); font-size:.95rem; }

/* ============================================================
   Why / USP feature band (dark)
   ============================================================ */
.feature{ background:linear-gradient(135deg,var(--blue) 0%,var(--blue-500) 60%,var(--blue-400) 100%); color:#eef1ff; position:relative; overflow:hidden; }
.feature::before{
  content:""; position:absolute; width:600px; height:600px; border-radius:50%;
  background:radial-gradient(circle,rgba(255,255,255,.22),transparent 70%); top:-200px; right:-150px; filter:blur(40px);
}
.feature .wrap{ position:relative; z-index:2; }
.feature .sec-title{ color:#fff; }
.feature .sec-sub{ color:#e6ebff; }
.feat-grid{ display:grid; grid-template-columns:repeat(2,1fr); gap:18px; margin-top:48px; }
@media(max-width:760px){ .feat-grid{ grid-template-columns:1fr; } }
.feat{
  display:grid; grid-template-columns:auto 1fr; gap:18px; align-items:start;
  background:rgba(255,255,255,.12); border:1px solid rgba(255,255,255,.22);
  border-radius:var(--r); padding:28px 26px; transition:.25s;
}
.feat:hover{ background:rgba(255,255,255,.18); transform:translateY(-4px); }
.feat-ic{ width:54px; height:54px; border-radius:14px; display:grid; place-items:center; background:#fff; color:var(--blue); flex:none; }
.feat-ic svg{ width:27px; height:27px; }
.feat h3{ color:#fff; font-size:1.26rem; margin-bottom:7px; }
.feat p{ color:#eaeefc; font-size:1.02rem; }

/* ============================================================
   FAQ
   ============================================================ */
.faq-wrap{ max-width:820px; margin:52px auto 0; display:flex; flex-direction:column; gap:14px; }
.faq{ background:#fff; border:1px solid var(--line); border-radius:var(--r); overflow:hidden; transition:.25s; }
.faq[open]{ box-shadow:var(--shadow-md); border-color:#d4ddff; }
.faq summary{
  list-style:none; cursor:pointer; padding:22px 26px;
  display:flex; align-items:center; justify-content:space-between; gap:16px;
  font-family:var(--ff-display); font-weight:600; font-size:1.1rem; color:var(--ink);
}
.faq summary::-webkit-details-marker{ display:none; }
.faq summary .q-ic{ flex:none; width:30px; height:30px; border-radius:50%; background:var(--blue-tint); color:var(--blue); display:grid; place-items:center; transition:.3s; }
.faq[open] summary .q-ic{ background:var(--blue); color:#fff; transform:rotate(45deg); }
.faq .faq-a{ padding:0 26px 24px; color:var(--muted); }

/* ============================================================
   Partner strip (dezent)
   ============================================================ */
.partners{ padding-block:clamp(44px,6vw,72px); }
.partners .p-title{ text-align:center; font-size:.84rem; font-weight:700; letter-spacing:.16em; text-transform:uppercase; color:var(--muted); margin-bottom:30px; }
.partner-track{ display:flex; flex-wrap:wrap; justify-content:center; align-items:center; gap:clamp(26px,6vw,64px); }
.partner-track img{
  height:58px; width:auto; opacity:.55; filter:grayscale(1);
  transition:.3s;
}
.partner-track img.mo{ height:72px; }
.partner-track img:hover{ opacity:1; filter:grayscale(0); }
.partner-track img[aria-hidden="true"]{ display:none; } /* Desktop: keine Duplikate */

/* Mobil: durchlaufender Endlos-Loop (rechts → links, nahtlos) */
@media(max-width:560px){
  .partner-marquee{ overflow:hidden; }
  .partner-track{ flex-wrap:nowrap; justify-content:flex-start; width:max-content; gap:0; animation:partner-scroll 24s linear infinite; }
  .partner-track img{ height:44px; margin-right:46px; flex:none; opacity:.6; }
  .partner-track img.mo{ height:54px; }
  .partner-track img[aria-hidden="true"]{ display:block; }
}
@keyframes partner-scroll{ from{ transform:translateX(0); } to{ transform:translateX(-50%); } }
@media(prefers-reduced-motion:reduce) and (max-width:560px){
  .partner-track{ animation:none; flex-wrap:wrap; justify-content:center; width:auto; gap:24px; }
  .partner-track img[aria-hidden="true"]{ display:none; }
}

/* ============================================================
   Kontakt
   ============================================================ */
.contact-grid{ display:grid; grid-template-columns:1fr 1fr; gap:clamp(30px,4vw,56px); margin-top:48px; align-items:start; }
@media(max-width:880px){ .contact-grid{ grid-template-columns:1fr; } }
.contact-info{ display:flex; flex-direction:column; gap:18px; }
.ci-item{ display:flex; gap:16px; align-items:flex-start; background:#fff; border:1px solid var(--line); border-radius:var(--r); padding:20px 22px; box-shadow:var(--shadow-sm); }
.ci-item .ci-ic{ width:48px; height:48px; border-radius:13px; background:var(--blue-tint); color:var(--blue); display:grid; place-items:center; flex:none; }
.ci-item .ci-ic svg{ width:23px; height:23px; }
.ci-item .ci-t{ font-family:var(--ff-display); font-weight:700; font-size:.82rem; letter-spacing:.08em; text-transform:uppercase; color:var(--muted); margin-bottom:3px; }
.ci-item .ci-v{ font-size:1.12rem; font-weight:600; color:var(--ink); }
.ci-item .ci-v a:hover{ color:var(--blue); }
.ci-item .ci-s{ font-size:.9rem; color:var(--muted); }

.map-card{ margin-top:6px; border-radius:var(--r); overflow:hidden; border:1px solid var(--line); box-shadow:var(--shadow-sm); position:relative; z-index:0; isolation:isolate; }
.map-card img{ width:100%; height:auto; display:block; }
.map-card iframe{ width:100%; height:300px; border:0; display:block; }
.map-card #map{ width:100%; height:320px; }
.map-card .leaflet-container{ font-family:var(--ff-body); }
.map-link{ display:inline-flex; align-items:center; gap:8px; margin-top:14px; font-weight:600; color:var(--blue-700); font-size:.95rem; }
.map-link svg{ width:18px; height:18px; }
.map-link:hover{ color:var(--blue); }

.form-card{ background:#fff; border:1px solid var(--line); border-radius:var(--r-lg); padding:clamp(26px,4vw,40px); box-shadow:var(--shadow-md); }
.form-card h3{ font-size:1.5rem; margin-bottom:6px; }
.form-card p.fsub{ color:var(--muted); margin-bottom:24px; }
.field{ margin-bottom:18px; }
.field label{ display:block; font-weight:600; font-size:.92rem; margin-bottom:7px; color:var(--ink-2); }
.field input,.field textarea,.field select{
  width:100%; font-family:var(--ff-body); font-size:1rem; color:var(--ink);
  padding:13px 16px; border:1px solid var(--line); border-radius:var(--r-sm); background:var(--bg-soft); transition:.2s;
}
.field input:focus,.field textarea:focus,.field select:focus{ outline:none; border-color:var(--blue); background:#fff; box-shadow:0 0 0 4px var(--blue-glow); }
.field textarea{ resize:vertical; min-height:120px; }
.field-row{ display:grid; grid-template-columns:1fr 1fr; gap:16px; }
@media(max-width:540px){ .field-row{ grid-template-columns:1fr; } }
.consent{ display:flex; gap:11px; align-items:flex-start; font-size:.88rem; color:var(--muted); margin-bottom:22px; }
.consent input{ width:18px; height:18px; margin-top:3px; flex:none; accent-color:var(--blue); }
.form-card .btn{ width:100%; }
.form-msg{ padding:13px 16px; border-radius:var(--r-sm); font-size:.95rem; font-weight:600; margin-bottom:18px; }
.form-msg.ok{ background:#e6f7ee; color:#0f7a43; border:1px solid #b7e7cd; }
.form-msg.err{ background:var(--mo-tint); color:#a50c25; border:1px solid #f3c9d0; }

/* ============================================================
   Footer
   ============================================================ */
.footer{ background:var(--navy-deep); color:#aeb9e8; padding-block:clamp(56px,7vw,80px) 0; }
.footer-grid{ display:grid; grid-template-columns:1.4fr 1fr 1fr 1.2fr; gap:40px; }
@media(max-width:880px){ .footer-grid{ grid-template-columns:1fr 1fr; gap:34px; } }
@media(max-width:520px){ .footer-grid{ grid-template-columns:1fr; } }
.footer .f-brand{ display:flex; align-items:center; gap:14px; margin-bottom:20px; }
.footer .f-brand img{ height:88px; border-radius:14px; }
.footer .f-brand .b-txt{ display:flex; flex-direction:column; line-height:1.08; }
.footer .f-brand .b-name{ font-family:var(--ff-display); font-weight:700; font-size:1.5rem; color:#fff; }
.footer .f-brand .b-tag{ font-size:.78rem; color:#8b97cf; font-weight:600; letter-spacing:.08em; text-transform:uppercase; margin-top:2px; }
.footer p{ font-size:.94rem; line-height:1.7; }
.footer h4{ color:#fff; font-size:.82rem; letter-spacing:.1em; text-transform:uppercase; margin-bottom:18px; font-family:var(--ff-body); font-weight:700; }
.footer ul li{ margin-bottom:11px; }
.footer ul a{ font-size:.95rem; transition:.2s; }
.footer ul a:hover{ color:#fff; padding-left:4px; }
.footer .f-contact li{ display:flex; gap:10px; align-items:flex-start; }
.footer .f-contact svg{ width:17px; height:17px; margin-top:3px; color:#5e6fb0; flex:none; }
.footer-bottom{ margin-top:54px; border-top:1px solid rgba(255,255,255,.1); padding-block:24px; display:flex; justify-content:space-between; gap:14px; flex-wrap:wrap; font-size:.86rem; }
.footer-bottom a:hover{ color:#fff; }

/* ============================================================
   Reveal on scroll
   ============================================================ */
.reveal{ opacity:0; transform:translateY(26px); transition:opacity .7s cubic-bezier(.2,.7,.3,1), transform .7s cubic-bezier(.2,.7,.3,1); }
.reveal.in{ opacity:1; transform:none; }

/* Angesprungener Abschnitt (#anchor) immer sofort sichtbar — sonst bleibt
   per Button erreichter Inhalt durch die Einblend-Animation unsichtbar */
:target .reveal, :target.reveal{ opacity:1 !important; transform:none !important; }
/* Abstand, damit die fixierte Navi die Abschnitts-Überschrift nicht verdeckt */
[id]{ scroll-margin-top:96px; }
.reveal.d1{ transition-delay:.08s; } .reveal.d2{ transition-delay:.16s; }
.reveal.d3{ transition-delay:.24s; } .reveal.d4{ transition-delay:.32s; }
@media(prefers-reduced-motion:reduce){
  .reveal{ opacity:1; transform:none; transition:none; }
  .float-card{ animation:none; }
  html{ scroll-behavior:auto; }
}

/* ============================================================
   Page hero (subpages)
   ============================================================ */
.page-hero{ background:linear-gradient(135deg,var(--blue) 0%,var(--blue-500) 60%,var(--blue-400) 100%); color:#fff; position:relative; overflow:hidden; padding-block:clamp(64px,9vw,120px); }
.page-hero::before{ content:""; position:absolute; width:600px; height:600px; border-radius:50%; background:radial-gradient(circle,rgba(255,255,255,.22),transparent 70%); top:-220px; right:-120px; filter:blur(50px); }
.page-hero .wrap{ position:relative; z-index:2; }
.mo-hero-badge{ background:#fff; border-radius:var(--r-xl); padding:clamp(36px,4vw,56px); box-shadow:var(--shadow-lg); display:grid; place-items:center; }
.mo-hero-badge img{ width:100%; max-width:430px; }
.page-hero h1{ color:#fff; font-size:clamp(2.3rem,4.8vw,3.6rem); margin:30px 0 16px; max-width:24ch; }
.page-hero p{ color:#eaeefc; font-size:1.22rem; max-width:60ch; }
.breadcrumb{ font-size:.9rem; color:#9fb0e8; margin-bottom:8px; }
.breadcrumb a:hover{ color:#fff; }

/* Prose blocks for legal pages */
.prose{ max-width:none; }
.prose h2{ font-size:1.5rem; margin:36px 0 14px; }
.prose h3{ font-size:1.15rem; margin:26px 0 10px; }
.prose p,.prose li{ color:var(--ink-2); margin-bottom:12px; }
.prose ul{ list-style:disc; padding-left:22px; margin-bottom:14px; }
.prose a{ color:var(--blue-700); text-decoration:underline; }
.placeholder-note{ color:var(--mo-red); font-weight:600; font-size:.95rem; margin:0 0 24px; }

/* ============================================================
   Mobile-Feinschliff — gilt NUR für kleine Screens, Desktop unverändert
   ============================================================ */
@media(max-width:560px){
  /* CTAs kleiner & nebeneinander (nicht vollbreit gestapelt) */
  .hero-cta{ flex-direction:row; flex-wrap:wrap; gap:10px; }
  .hero-cta .btn{ width:auto; padding:12px 18px; font-size:.9rem; }
  /* Etwas kompaktere Abschnittsabstände auf dem Handy */
  .section{ padding-block:clamp(48px,11vw,72px); }
  /* Section-Überschrift eine Spur kleiner für saubere Umbrüche */
  .sec-title{ font-size:clamp(1.7rem,7vw,2.1rem); }
  .hero h1{ font-size:clamp(2.3rem,10.5vw,3.1rem); }
  /* 3 Kennzahlen in einer Reihe — Zahl & Label dafür kompakter */
  .stat{ padding:4px 2px; }
  .stat .num{ font-size:clamp(1.35rem,6.4vw,2rem); letter-spacing:-.02em; }
  .stat .lbl{ font-size:.72rem; margin-top:6px; line-height:1.3; }
  /* Hero-Chips auf kleinen Screens: weiterhin Pillen, nur etwas kompakter (Text nicht am Rand) */
  .hero .chip{ padding:10px 16px; font-size:.86rem; gap:7px; }
  .hero .chip svg{ width:15px; height:15px; }
  /* Zentrierte Abschnitts-Köpfe auf dem Handy linksbündig (wie der Hero) */
  .sec-head.center{ text-align:left; margin-inline:0; }
  .sec-head.center .sec-sub{ margin-inline:0; }
}

/* ============================================================
   Maus-Over-Zoom auf Infografiken/Bildern (Kundenwunsch)
   Wrapper .zoom kapselt das Bild, beim Hover wird es sanft vergrößert.
   ============================================================ */
.zoom{ overflow:hidden; border-radius:var(--r-lg); position:relative; }
.zoom > img{ display:block; width:100%; transition:transform .6s cubic-bezier(.2,.7,.3,1); }
.zoom:hover > img{ transform:scale(1.09); }
/* Dezenter Lupen-Hinweis oben rechts */
.zoom::after{
  content:""; position:absolute; top:14px; right:14px; width:38px; height:38px; border-radius:50%;
  background:rgba(255,255,255,.9) url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='20' height='20' viewBox='0 0 24 24' fill='none' stroke='%230008e7' stroke-width='2.2' stroke-linecap='round'%3E%3Ccircle cx='11' cy='11' r='7'/%3E%3Cpath d='M21 21l-4.3-4.3M11 8v6M8 11h6'/%3E%3C/svg%3E") center / 20px no-repeat;
  box-shadow:var(--shadow-sm); opacity:0; transform:scale(.8); transition:.3s; pointer-events:none; z-index:3;
}
.zoom:hover::after{ opacity:1; transform:scale(1); }
/* mo-visual als Zoom-Container: Bild bekommt eigenen Rahmen, Wrapper klippt */
.mo-visual.zoom > img{ border-radius:var(--r-lg); }
@media(prefers-reduced-motion:reduce){ .zoom:hover > img{ transform:none; } }

/* ============================================================
   Info-Panel — klappt wie ein Mega-Menü unter dem i-Button auf
   ============================================================ */
.info-wrap{ position:relative; }
.info-panel{
  position:absolute; top:calc(100% + 14px); right:0;
  width:min(400px,86vw);
  background:#fff; border:1px solid var(--line); border-radius:var(--r-lg);
  box-shadow:var(--shadow-lg); padding:24px 26px; z-index:70;
  opacity:0; visibility:hidden; transform:translateY(-10px) scale(.98);
  transform-origin:top right; transition:.22s cubic-bezier(.2,.7,.3,1);
}
.info-wrap.open .info-panel{ opacity:1; visibility:visible; transform:none; }
/* kleiner Pfeil nach oben (Mega-Menü-Optik) */
.info-panel::before{
  content:""; position:absolute; top:-7px; right:18px; width:14px; height:14px;
  background:#fff; border-left:1px solid var(--line); border-top:1px solid var(--line);
  transform:rotate(45deg);
}
.info-panel .eyebrow{ margin-bottom:14px; }
.info-panel h3{ font-size:1.3rem; margin-bottom:8px; }
.info-panel > p{ color:var(--ink-2); font-size:1rem; line-height:1.5; margin-bottom:18px; }
.info-list{ display:flex; flex-direction:column; gap:14px; margin-bottom:0; }
.info-list li{ display:flex; gap:13px; align-items:center; }
.info-list li > span:last-child{ display:flex; flex-direction:column; gap:3px; min-width:0; }
.info-list .il-ic{ width:42px; height:42px; border-radius:11px; background:var(--blue-tint); color:var(--blue); display:grid; place-items:center; flex:none; }
.info-list .il-ic svg{ width:20px; height:20px; }
.info-list .il-t{ display:block; font-size:.76rem; text-transform:uppercase; letter-spacing:.08em; color:var(--muted); font-weight:700; line-height:1; }
.info-list .il-v{ display:block; font-size:1.02rem; font-weight:600; color:var(--ink); line-height:1.25; }
.info-panel .info-actions{ display:flex; gap:10px; flex-wrap:wrap; }
.info-panel .info-actions .btn{ flex:1; min-width:130px; padding:12px 16px; font-size:.98rem; }

/* Info-Eintrag im mobilen Drawer */
.drawer .drawer-info{ display:flex; align-items:center; gap:10px; }
.drawer .drawer-info svg{ width:20px; height:20px; color:var(--blue); }

/* ============ NEWS ============ */
.news-grid{ display:grid; grid-template-columns:repeat(3,1fr); gap:28px; }
@media(max-width:900px){ .news-grid{ grid-template-columns:repeat(2,1fr); } }
@media(max-width:620px){ .news-grid{ grid-template-columns:1fr; } }
.news-card{
  display:flex; flex-direction:column; background:#fff; border:1px solid var(--line);
  border-radius:20px; padding:30px 28px; box-shadow:var(--shadow-sm);
  transition:transform .25s ease, box-shadow .25s ease;
}
.news-card:hover{ transform:translateY(-5px); box-shadow:var(--shadow-md); }
.news-meta{ display:flex; align-items:center; gap:12px; margin-bottom:16px; }
.news-cat{
  font-size:.72rem; font-weight:700; letter-spacing:.08em; text-transform:uppercase;
  color:var(--blue-700); background:var(--blue-tint); padding:6px 12px; border-radius:999px;
}
.news-date{ font-size:.86rem; color:var(--muted); font-weight:600; }
.news-card h3{ font-family:var(--ff-display); font-size:1.35rem; line-height:1.25; margin:0 0 12px; color:var(--ink); }
.news-card p{ font-size:1rem; line-height:1.7; color:var(--muted); margin:0 0 20px; }
.news-card .news-more{ margin-top:auto; font-weight:700; color:var(--blue-700); display:inline-flex; align-items:center; gap:7px; }
.news-card .news-more svg{ width:18px; height:18px; transition:transform .25s ease; }
.news-card:hover .news-more svg{ transform:translateX(4px); }
.news-empty{ margin-top:46px; padding:30px 28px; border:1px dashed var(--line); border-radius:18px; background:var(--blue-tint); color:var(--ink); font-size:1.02rem; line-height:1.7; }

/* ============ COOKIE-BANNER ============ */
.cookie-banner{
  position:fixed; left:50%; bottom:22px; z-index:200;
  width:min(960px, calc(100% - 32px)); transform:translate(-50%, 140%);
  background:#fff; border:1px solid var(--line); border-radius:18px;
  box-shadow:0 18px 50px rgba(10,20,80,.22); opacity:0; transition:transform .4s cubic-bezier(.2,.7,.3,1), opacity .4s ease;
}
.cookie-banner.show{ transform:translate(-50%, 0); opacity:1; }
.cookie-inner{ display:flex; align-items:center; gap:26px; padding:20px 26px; }
.cookie-text strong{ display:block; font-family:var(--ff-display); font-size:1.08rem; color:var(--ink); margin-bottom:4px; }
.cookie-text p{ margin:0; font-size:.95rem; line-height:1.6; color:var(--muted); }
.cookie-text a{ color:var(--blue-700); font-weight:600; text-decoration:underline; }
.cookie-actions{ display:flex; gap:10px; flex:none; }
.cookie-actions .btn{ padding:12px 20px; font-size:.96rem; white-space:nowrap; }
.cookie-actions .cookie-min{ border:1.5px solid var(--line); }
@media(max-width:720px){
  .cookie-banner{ bottom:12px; width:calc(100% - 20px); }
  .cookie-inner{ flex-direction:column; align-items:stretch; gap:16px; padding:20px; }
  .cookie-actions{ flex-direction:row; }
  .cookie-actions .btn{ flex:1; }
}
