/* ─────────────────────────────────────────────────────────────────────────
   uniworks — Branchen-Subpages (Für Unternehmen)
   Shared design-system styles for pages/unternehmen/*.html
   Tokens mirror pages/index.html (canonical: brand green #2ab54a, IBM Plex).
   ───────────────────────────────────────────────────────────────────────── */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
:root{
  --g:#2ab54a;--gh:#21993d;--gd:#173404;--gl:#EBF9EE;--gm:#EAF3DE;
  --black:#111111;--body:#374151;--sec:#6B7280;--bg:#F5F5F5;
  --border:#E5E7EB;--white:#FFFFFF;
  --font:'IBM Plex Sans','Helvetica Neue',Arial,sans-serif;
  --mw:1280px;--r8:8px;--r12:12px;--r16:16px;--r20:20px;
  --sh:0 2px 8px rgba(0,0,0,.06);--shh:0 8px 24px rgba(0,0,0,.10);
  --tr:200ms ease-out;
}
html{scroll-behavior:smooth}
body{font-family:var(--font);color:var(--body);background:var(--white);-webkit-font-smoothing:antialiased;overflow-x:hidden}
h1,h2,h3,h4{color:var(--black);letter-spacing:-.02em;line-height:1.15}
a{color:inherit}
.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0}
.wrap{max-width:var(--mw);margin:0 auto;padding:0 40px}
@media(max-width:768px){.wrap{padding:0 24px}}

/* ── BUTTONS ── */
.btn{display:inline-flex;align-items:center;justify-content:center;gap:8px;font-family:var(--font);font-size:16px;font-weight:600;border-radius:var(--r8);padding:14px 28px;border:none;cursor:pointer;text-decoration:none;transition:all var(--tr);white-space:nowrap}
.btn-p{background:var(--g);color:#fff}
.btn-p:hover{background:var(--gh);box-shadow:0 4px 16px rgba(42,181,74,.35);transform:translateY(-1px)}
.btn-p:active{transform:scale(.98)}
.btn-p:disabled{opacity:.6;cursor:not-allowed;transform:none;box-shadow:none}
.btn-s{background:transparent;color:var(--g);border:2px solid var(--g)}
.btn-s:hover{background:var(--gl);transform:translateY(-1px)}

/* ── NAV ── (matches landing) ── */
.nav{position:fixed;top:0;left:0;right:0;z-index:100;background:rgba(255,255,255,.96);backdrop-filter:blur(12px);border-bottom:1px solid transparent;transition:border-color var(--tr),box-shadow var(--tr)}
.nav.scrolled{border-color:var(--border);box-shadow:0 1px 20px rgba(0,0,0,.06)}
.nav-inner{max-width:var(--mw);margin:0 auto;padding:0 40px;height:72px;display:flex;align-items:center;gap:32px}
.nav-logo{display:flex;align-items:center;gap:10px;text-decoration:none;flex-shrink:0}
.nav-logo img{width:36px;height:36px;border-radius:8px}
.nav-logo-text{font-size:20px;font-weight:700;color:var(--black);letter-spacing:-.03em}.nav-logo-works{color:#197a30}
.nav-links{display:flex;align-items:center;gap:2px;flex:1;list-style:none}
.nav-links a{display:block;padding:8px 12px;font-size:15px;font-weight:500;color:var(--black);text-decoration:none;border-radius:var(--r8);transition:all var(--tr)}
.nav-links a:hover,.nav-links a.active{color:var(--g);background:var(--gl)}
.nav-ctas{display:flex;align-items:center;gap:8px;flex-shrink:0;margin-left:auto}
.nav-ctas .btn{font-size:14px;padding:10px 20px}
.nav-dd{position:relative}
.nav-dd-toggle .ti{font-size:16px;transition:transform var(--tr)}
.nav-dd.open .nav-dd-toggle .ti,.nav-dd:hover .nav-dd-toggle .ti,.nav-dd:focus-within .nav-dd-toggle .ti{transform:rotate(180deg)}
.nav-dd-menu{position:absolute;top:calc(100% + 10px);right:0;min-width:240px;background:#fff;border:1px solid var(--border);border-radius:var(--r12);box-shadow:var(--shh);padding:8px;opacity:0;visibility:hidden;transform:translateY(-8px);transition:opacity var(--tr),transform var(--tr),visibility var(--tr);z-index:101}
.nav-dd.open .nav-dd-menu,.nav-dd:hover .nav-dd-menu,.nav-dd:focus-within .nav-dd-menu{opacity:1;visibility:visible;transform:none}
.nav-dd-menu::before{content:"";position:absolute;top:-10px;left:0;right:0;height:10px}
.nav-dd-menu a{display:flex;align-items:center;gap:10px;padding:10px 12px;font-size:14px;font-weight:500;color:var(--black);text-decoration:none;border-radius:var(--r8);transition:all var(--tr)}
.nav-dd-menu a:hover,.nav-dd-menu a.active{background:var(--gl);color:var(--g)}
.nav-dd-menu a .ti{font-size:18px;color:var(--g);flex-shrink:0}
.nav-hbg{display:none;flex-direction:column;gap:5px;background:none;border:none;cursor:pointer;padding:4px;margin-left:auto}
.nav-hbg span{display:block;width:22px;height:2px;background:var(--black);border-radius:2px;transition:all var(--tr)}
.mob-overlay{display:none;position:fixed;top:72px;left:0;right:0;background:rgba(255,255,255,.92);backdrop-filter:blur(14px);-webkit-backdrop-filter:blur(14px);z-index:98;flex-direction:column;padding:6px 24px 16px;border-bottom:1px solid var(--border);box-shadow:0 16px 30px rgba(0,0,0,.10)}
.mob-overlay.open{display:flex}
.mob-overlay a{font-size:18px;font-weight:600;color:var(--black);text-decoration:none;padding:13px 0;border-bottom:1px solid var(--border)}
.mob-overlay a:hover{color:var(--g)}
.mob-dd summary{font-size:18px;font-weight:600;color:var(--black);padding:13px 0;cursor:pointer;list-style:none;display:flex;align-items:center;justify-content:space-between;border-bottom:1px solid var(--border)}
.mob-dd summary::-webkit-details-marker{display:none}
.mob-dd summary .ti{transition:transform var(--tr)}
.mob-dd[open] summary .ti{transform:rotate(180deg)}
.mob-dd-list{display:flex;flex-direction:column;padding:4px 0 10px}
.mob-dd-list a{font-size:16px;font-weight:500;padding:11px 0 11px 6px;border-bottom:none;display:flex;align-items:center;gap:12px}
.mob-dd-list a .ti{font-size:20px;color:var(--g)}
.mob-ctas{margin-top:18px;display:flex;flex-direction:column;gap:12px}
@media(max-width:900px){.nav-links,.nav-ctas{display:none}.nav-hbg{display:flex}.nav-inner{padding:0 24px;gap:16px}}

/* ── HERO ── */
.bhero-outer{padding-top:72px;background:#fff}
.bhero{max-width:var(--mw);margin:0 auto;padding:64px 40px 56px;display:grid;grid-template-columns:1.05fr .95fr;align-items:center;gap:56px}
.bhero-eyebrow{display:inline-flex;align-items:center;gap:8px;font-size:14px;font-weight:600;color:var(--g);background:var(--gl);padding:7px 14px;border-radius:999px;margin-bottom:20px}
.bhero-eyebrow .ti{font-size:17px}
.bhero h1{font-size:clamp(32px,4vw,50px);font-weight:800;line-height:1.08;letter-spacing:-.03em;margin-bottom:20px}
.bhero h1 em{color:var(--g);font-style:normal}
.bhero p{font-size:18px;line-height:1.6;color:var(--body);max-width:560px;margin-bottom:32px}
.bhero-btns{display:flex;flex-wrap:wrap;gap:12px}
.bhero-media{position:relative}
.bhero-media img,.bhero-media video{width:100%;height:520px;object-fit:cover;border-radius:var(--r20);box-shadow:0 24px 64px rgba(0,0,0,.16);display:block}
@media(max-width:900px){
  /* stack and reorder: eyebrow → headline → image → text → buttons */
  .bhero{display:flex;flex-direction:column;gap:0;padding:28px 24px 40px}
  .bhero-text{display:contents}
  .bhero-eyebrow{order:1;align-self:flex-start;margin-bottom:16px}
  .bhero h1{order:2;margin-bottom:20px}
  .bhero-media{order:3;margin-bottom:24px}
  .bhero-media img,.bhero-media video{height:240px}
  .bhero p{order:4;font-size:16px;margin-bottom:26px}
  .bhero-btns{order:5;justify-content:center;width:100%}
  /* "Lieber im Dialog ausfüllen" Button mittig auf Mobil */
  .anfrage-intro>p:last-child{text-align:center}
}

/* ── ROLES STRIP ── */
.roles{background:var(--gl);padding:32px 0}
.roles-inner{max-width:var(--mw);margin:0 auto;padding:0 40px;display:flex;align-items:flex-start;gap:18px}
.roles-inner .ti{font-size:28px;color:var(--g);flex-shrink:0;margin-top:2px}
.roles-inner p{font-size:17px;line-height:1.55;color:var(--gd);max-width:920px}
.roles-inner p strong{color:var(--black)}
@media(max-width:768px){.roles-inner{padding:0 24px}.roles-inner p{font-size:15px}}

/* ── STAGE BANNER (image + caption underneath) ── */
.stagefeat{background:#fff;padding:56px 0}
.stagefeat-img{width:100%;max-width:860px;height:auto;margin:0 auto;border-radius:var(--r20);box-shadow:var(--shh);display:block}
.stagefeat-text{max-width:680px;margin:26px auto 0;text-align:center;font-size:clamp(17px,1.8vw,20px);line-height:1.55;color:var(--gd)}
.stagefeat-text strong{color:var(--black)}
@media(max-width:768px){.stagefeat{padding:44px 0}.stagefeat-text{font-size:15px;margin-top:18px}}

/* ── REFERENCES ── */
.refs{background:#fff;padding:64px 0}
.refs h2{text-align:center;font-size:clamp(24px,3vw,34px);font-weight:700;margin-bottom:40px}
.refs-grid{display:grid;grid-template-columns:repeat(5,1fr);gap:28px;align-items:center;max-width:1040px;margin:0 auto}
.refs-grid img{width:100%;height:48px;object-fit:contain;filter:grayscale(1);opacity:.62;transition:filter var(--tr),opacity var(--tr)}
.refs-grid img:hover{filter:grayscale(0);opacity:1}
@media(max-width:768px){.refs{padding:44px 0}.refs-grid{grid-template-columns:repeat(3,1fr);gap:24px}.refs h2{margin-bottom:28px}}
/* 4-per-row variant (promotion) */
.refs-grid-4{grid-template-columns:repeat(4,1fr);max-width:860px}
@media(max-width:768px){.refs-grid-4{grid-template-columns:repeat(2,1fr)}}

/* ── EINSATZBEREICHE (role cards — same style as index.html cases) ── */
.sec-head{max-width:720px;margin:0 auto 48px;text-align:center}
.sec-head h2{font-size:clamp(26px,3.4vw,40px);font-weight:800;line-height:1.12;margin-bottom:16px}
.sec-head p{font-size:18px;line-height:1.6;color:var(--body)}
.cases{padding:80px 0;background:var(--g)}
.cases .sec-head h2{color:#fff}
.cases .sec-head p{color:rgba(255,255,255,.9)}
.cases-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px;max-width:var(--mw);margin:0 auto}
.case{background:#fff;border:1px solid var(--border);border-radius:var(--r16);overflow:hidden;display:flex;flex-direction:column;transition:transform var(--tr),box-shadow var(--tr)}
.case:hover{transform:translateY(-4px);box-shadow:var(--shh)}
.case-img{position:relative;aspect-ratio:16/10;overflow:hidden}
.case-img img{width:100%;height:100%;object-fit:cover;object-position:center 42%;transition:transform 400ms ease}
.case:hover .case-img img{transform:scale(1.05)}
.case-tag{position:absolute;top:14px;left:14px;background:rgba(255,255,255,.94);color:var(--g);font-size:12px;font-weight:700;padding:6px 12px;border-radius:999px;display:inline-flex;align-items:center;gap:6px}
.case-tag .ti{font-size:15px}
.case-body{padding:22px;display:flex;flex-direction:column;gap:8px;flex:1}
.case-body h3{font-size:18px;font-weight:700;line-height:1.25}
.case-body p{font-size:14px;line-height:1.55;color:var(--body)}
@media(max-width:1024px){.cases-grid{grid-template-columns:repeat(2,1fr)}}
@media(max-width:768px){.cases{padding:56px 0}}
@media(max-width:600px){.cases-grid{grid-template-columns:1fr}}
/* 4-up variant (catering Einsatzbereiche) */
.cases-grid-4{grid-template-columns:repeat(4,1fr)}
@media(max-width:1024px){.cases-grid-4{grid-template-columns:repeat(2,1fr)}}
@media(max-width:600px){.cases-grid-4{grid-template-columns:1fr}}
/* 2-up variant, centered (buero Einsatzbereiche) */
.cases-grid-2{grid-template-columns:repeat(2,1fr);max-width:820px}
@media(max-width:600px){.cases-grid-2{grid-template-columns:1fr}}

/* ── HYGIENE / GESUNDHEITSZEUGNIS feature ── */
.certfeat{background:#fff;padding:72px 0}
.certfeat-grid{display:grid;grid-template-columns:.8fr 1fr;gap:56px;align-items:center;max-width:1040px;margin:0 auto}
.certfeat-img{display:flex;justify-content:center}
.certfeat-img img{width:100%;max-width:360px;height:auto;border-radius:var(--r16);box-shadow:var(--shh)}
.certfeat-text h2{font-size:clamp(24px,3vw,34px);font-weight:700;margin-bottom:16px}
.certfeat-text p{font-size:16px;line-height:1.65;color:var(--body);max-width:520px;margin-bottom:20px}
.certfeat-points{list-style:none;display:flex;flex-direction:column;gap:12px}
.certfeat-points li{display:flex;align-items:flex-start;gap:10px;font-size:15px;color:var(--body)}
.certfeat-points .ti{color:var(--g);font-size:20px;flex-shrink:0;margin-top:1px}
@media(max-width:820px){.certfeat{padding:48px 0}.certfeat-grid{grid-template-columns:1fr;gap:32px}.certfeat-img{order:-1}.certfeat-img img{max-width:280px}}

/* ── KUNDENSTIMME (review) — text left, photo clean on the right ── */
.review{background:var(--bg);padding:72px 0}
.review h2{text-align:center;font-size:clamp(24px,3vw,34px);font-weight:700;margin-bottom:40px}
.review-card{border-radius:var(--r20);overflow:hidden;box-shadow:var(--shh);background:#fff;display:grid;grid-template-columns:1fr 1fr;min-height:380px}
.review-bg{order:2;width:100%;height:100%;object-fit:cover;object-position:center 38%}
.review-inner{order:1;padding:48px 52px;display:flex;flex-direction:column;justify-content:center}
.review-quote{font-size:clamp(19px,2vw,25px);line-height:1.42;font-weight:600;font-style:italic;color:var(--black);letter-spacing:-.01em;margin-bottom:22px}
.review-author{margin-bottom:26px}
.review-name{display:block;font-size:16px;font-weight:700;color:var(--black)}
.review-role{display:block;font-size:13.5px;font-weight:600;color:var(--g);margin-top:2px}
.review-press{font-size:15px;line-height:1.6;color:var(--body);margin-bottom:20px;max-width:440px}
.review-logos{display:flex;flex-wrap:wrap;align-items:flex-start;gap:18px 34px}
.review-logo{display:inline-flex;flex-direction:column;align-items:flex-start;gap:8px;text-decoration:none}
.review-logo img{height:30px;width:auto;max-width:170px;object-fit:contain;opacity:1;transition:opacity var(--tr)}
.review-logo:hover img{opacity:.85}
.review-logo-more{display:inline-flex;align-items:center;gap:5px;font-size:12.5px;font-weight:600;color:var(--g);background:#fff;border:1.5px solid var(--g);border-radius:var(--r8);padding:6px 12px;transition:all var(--tr)}
.review-logo:hover .review-logo-more{background:var(--gl);border-color:var(--gh);color:var(--gh)}
.review-logo-more .ti{font-size:14px;transition:transform var(--tr)}
.review-logo:hover .review-logo-more .ti{transform:translate(2px,-2px)}
@media(max-width:820px){
  .review{padding:48px 0}
  .review-card{grid-template-columns:1fr;min-height:0}
  .review-bg{order:1;width:100%;height:190px}
  .review-inner{order:2;max-width:none;padding:32px 24px}
}

/* ── VOICES (customer testimonial) ── */
.voices{background:var(--bg);padding:72px 0}
.voices h2{text-align:center;font-size:clamp(24px,3vw,34px);font-weight:700;margin-bottom:40px}
.voice-card{max-width:760px;margin:0 auto;background:var(--white);border:1px solid var(--border);border-radius:var(--r20);box-shadow:var(--sh);padding:44px 48px}
.voice-quote{font-size:clamp(19px,2.1vw,24px);font-style:italic;font-weight:600;line-height:1.4;color:var(--black);letter-spacing:-.01em}
.voice-head{display:flex;align-items:center;justify-content:space-between;gap:16px 24px;flex-wrap:wrap;margin-top:22px}
.voice-head .btn-s{padding:10px 20px;font-size:14px;flex-shrink:0}
.voice-author{margin-top:22px}
.voice-head .voice-author{margin-top:0}
.voice-author .name{font-weight:700;color:var(--black);font-size:16px}
.voice-author .role{font-size:14px;color:var(--sec);margin-top:2px}
.voice-press{margin-top:24px;padding-top:24px;border-top:1px solid var(--border);font-size:15px;color:var(--body);line-height:1.6}
.voice-foot{display:flex;align-items:center;justify-content:space-between;gap:24px;flex-wrap:wrap;margin-top:20px}
.voice-foot img{height:54px;width:auto;object-fit:contain}
@media(max-width:768px){.voices{padding:48px 0}.voices h2{margin-bottom:28px}.voice-card{padding:32px 24px}.voice-foot{gap:18px}}

/* ── ANFRAGE (custom request form) ── */
.anfrage{background:var(--bg);padding:72px 0}
.anfrage-grid{display:grid;grid-template-columns:1fr 1.1fr;gap:56px;align-items:start}
.anfrage-intro h2{font-size:clamp(26px,3vw,38px);font-weight:800;line-height:1.1;margin-bottom:18px}
.anfrage-intro p{font-size:17px;line-height:1.6;color:var(--body);max-width:440px;margin-bottom:28px}
.anfrage-points{list-style:none;display:flex;flex-direction:column;gap:14px}
.anfrage-points li{display:flex;align-items:flex-start;gap:12px;font-size:15px;color:var(--body)}
.anfrage-points li .ti{font-size:20px;color:var(--g);flex-shrink:0}

.form-card{background:#fff;border:1px solid var(--border);border-radius:var(--r20);box-shadow:var(--shh);padding:32px}
.form-grid{display:grid;grid-template-columns:1fr 1fr;gap:16px}
.field{display:flex;flex-direction:column;gap:6px}
.field.full{grid-column:1 / -1}
.field label{font-size:13px;font-weight:600;color:var(--black)}
.field label .req{color:var(--g)}
.field input,.field select,.field textarea{font-family:var(--font);font-size:15px;color:var(--black);background:#fff;border:1.5px solid var(--border);border-radius:var(--r8);padding:12px 14px;transition:border-color var(--tr),box-shadow var(--tr);width:100%}
.field input::placeholder,.field textarea::placeholder{color:#9CA3AF}
.field input:focus,.field select:focus,.field textarea:focus{outline:none;border-color:var(--g);box-shadow:0 0 0 3px var(--gl)}
.field textarea{resize:vertical;min-height:92px}
.field input[aria-invalid="true"],.field textarea[aria-invalid="true"]{border-color:#DC2626;box-shadow:0 0 0 3px #FEE2E2}
.field-error{font-size:12px;color:#DC2626;min-height:0;display:none}
.field-error.show{display:block}
.consent{display:flex;align-items:flex-start;gap:10px;grid-column:1 / -1;margin-top:4px}
.consent input{width:18px;height:18px;margin-top:2px;accent-color:var(--g);flex-shrink:0}
.consent label{font-size:13px;line-height:1.5;color:var(--sec);font-weight:400}
.consent a{color:var(--g);text-decoration:underline}
.form-card .btn-p{width:100%;margin-top:8px}
.form-note{font-size:12px;color:var(--sec);text-align:center;margin-top:12px}

/* form states */
.form-status{display:none;border-radius:var(--r8);padding:12px 14px;font-size:14px;margin-top:14px}
.form-status.show{display:block}
.form-status.err{background:#FEF2F2;color:#B91C1C;border:1px solid #FECACA}
.form-success{display:none;text-align:center;padding:24px 8px}
.form-success.show{display:block}
.form-success .ok{width:64px;height:64px;border-radius:999px;background:var(--gl);color:var(--g);display:inline-flex;align-items:center;justify-content:center;font-size:34px;margin-bottom:18px}
.form-success h3{font-size:22px;font-weight:700;margin-bottom:10px}
.form-success p{font-size:15px;color:var(--body);max-width:380px;margin:0 auto}
@media(max-width:900px){.anfrage-grid{grid-template-columns:1fr;gap:36px}}
@media(max-width:520px){.form-grid{grid-template-columns:1fr}.form-card{padding:24px}}

/* ── DEHOGA PARTNER ── */
.dpartner{background:var(--bg);padding:8px 0 72px}
.dpartner-card{background:#fff;border:1px solid var(--border);border-radius:var(--r20);box-shadow:var(--sh);padding:44px 52px;display:grid;grid-template-columns:1.35fr .65fr;gap:48px;align-items:center}
.dpartner-text h2{font-size:clamp(22px,2.4vw,28px);font-weight:700;margin-bottom:14px}
.dpartner-text p{font-size:15px;line-height:1.65;color:var(--body);max-width:520px}
.dpartner-logo{display:flex;justify-content:center}
.dpartner-logo img{width:100%;max-width:220px;height:auto;object-fit:contain}
@media(max-width:768px){.dpartner{padding:0 0 48px}.dpartner-card{grid-template-columns:1fr;gap:28px;padding:32px 24px}.dpartner-logo img{max-width:180px}}

/* ── PARTNER MARQUEE (mirrors pages/index.html) ── */
@keyframes scrollL{0%{transform:translateX(0)}100%{transform:translateX(-50%)}}
.partners{padding:72px 0;border-top:1px solid var(--border)}
.partners-lbl{text-align:center;font-size:12px;font-weight:600;letter-spacing:.1em;color:var(--sec);text-transform:uppercase;margin-bottom:40px}
.ptrs-track-wrap{position:relative;overflow:hidden}
.ptrs-track-wrap::before,.ptrs-track-wrap::after{content:'';position:absolute;top:0;bottom:0;width:80px;z-index:2;pointer-events:none}
.ptrs-track-wrap::before{left:0;background:linear-gradient(to right,#fff,transparent)}
.ptrs-track-wrap::after{right:0;background:linear-gradient(to left,#fff,transparent)}
.ptrs-track{display:flex;align-items:center;gap:56px;width:max-content;animation:scrollL 130s linear infinite;padding:8px 0}
.ptrs-track:hover{animation-play-state:paused}
.ptr-logo{height:36px;width:auto;opacity:.5;filter:grayscale(100%);transition:all var(--tr);object-fit:contain;flex-shrink:0}
.ptr-logo:hover{opacity:1;filter:grayscale(0%)}
@media(max-width:768px){.partners{padding:40px 0}.partners-lbl{margin-bottom:28px}}

/* ── FOOTER (mirrors pages/index.html) ── */
footer{background:#fff;color:var(--sec);padding:64px 0 32px;border-top:1px solid var(--border)}
.footer-grid{display:grid;grid-template-columns:2fr 1fr 1fr 1fr;gap:48px;padding-bottom:48px;border-bottom:1px solid var(--border)}
.footer-brand h3{color:var(--black);font-size:18px;font-weight:700;letter-spacing:-.02em;margin-bottom:12px}
.footer-brand p{font-size:14px;line-height:1.65;max-width:260px}
.footer-social{margin-top:20px;display:flex;gap:10px}
.foot-social-a{width:36px;height:36px;border-radius:8px;background:var(--bg);display:flex;align-items:center;justify-content:center;color:var(--sec);text-decoration:none;font-size:18px;transition:all var(--tr)}
.foot-social-a:hover{background:var(--g);color:#fff}
.footer-col h4{color:var(--black);font-size:12px;font-weight:600;text-transform:uppercase;letter-spacing:.08em;margin-bottom:16px}
.footer-col ul{list-style:none;display:flex;flex-direction:column;gap:10px}
.footer-col a{color:var(--sec);text-decoration:none;font-size:14px;transition:color var(--tr)}
.footer-col a:hover{color:var(--g)}
.footer-bottom{padding-top:24px;display:flex;align-items:center;justify-content:space-between;font-size:13px}
.footer-bottom a{color:var(--sec);text-decoration:none}
.footer-bottom a:hover{color:var(--black)}
.footer-bottom-links{display:flex;gap:20px}
@media(max-width:768px){.footer-grid{grid-template-columns:1fr 1fr;gap:32px}.footer-brand{grid-column:1/-1}.footer-bottom{flex-direction:column;gap:10px;text-align:center}}

/* ── Language switch ── */
.lang-switch{display:flex;align-items:center;gap:8px;font-size:14px;font-weight:600;margin:0 4px}
.lang-switch a{color:var(--sec);text-decoration:none;padding:4px 2px;transition:color var(--tr)}
.lang-switch a:hover{color:var(--g)}
.lang-switch a.active{color:var(--black)}
.lang-switch .sep{width:1px;height:16px;background:var(--border)}
.mob-overlay .lang-switch{padding:13px 0}
.mob-overlay .lang-switch a{font-size:16px;border-bottom:none;padding:4px 2px}

/* ── Nav text link (e.g. Über uns, grouped right with the CTAs) ── */
.nav-textlink{font-size:15px;font-weight:500;color:var(--black);text-decoration:none;padding:8px 12px;border-radius:var(--r8);transition:all var(--tr);white-space:nowrap}
.nav-textlink:hover{color:var(--g);background:var(--gl)}

/* ── Footer app download (store badges + rating) ── */
.footer-app{margin-top:22px}
.footer-app-row{display:flex;align-items:center;gap:10px;flex-wrap:wrap}
.footer-app-icon{width:46px;height:46px;border-radius:10px;flex-shrink:0}
.footer-app-badge{display:inline-flex;transition:transform var(--tr),opacity var(--tr)}
.footer-app-badge img{height:40px;width:auto;display:block}
.footer-app-badge:hover{transform:translateY(-1px);opacity:.85}
.footer-app-rating{display:flex;align-items:center;gap:8px;margin-top:13px;font-size:14px;color:var(--sec)}
.footer-app-rating strong{color:var(--black);font-weight:700;font-size:15px}
.footer-app-stars{color:var(--g);letter-spacing:1px}
