/* ─────────────────────────────────────────────────────────────────────────
   uniworks — "Für Unternehmen" Übersicht (overview / hub page)
   Index-only sections. Loads AFTER branche.css and reuses its :root tokens
   (brand green #2ab54a, IBM Plex). No hardcoded hexes beyond white overlays.
   ───────────────────────────────────────────────────────────────────────── */

/* generic centered section heading */
.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:18px}
.eyebrow .ti{font-size:17px}
.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)}
@media(max-width:768px){.sec-head{margin-bottom:32px}.sec-head p{font-size:16px}}

/* ── HUB HERO: brand animation centered, copy + CTAs underneath ──
   Overrides branche.css's 2-column .bhero (index page only). */
.bhero-hub{display:block;text-align:center;padding-top:48px;padding-bottom:56px}
/* FLAG: #23a23e matches the LoadingAnimation video's edge green (not the
   canonical brand #2ab54a) so the container blends seamlessly with the clip. */
.bhero-hub .bhero-media{max-width:720px;margin:0 auto 40px;background:#23a23e;border-radius:var(--r20);overflow:hidden;line-height:0}
.bhero-hub .bhero-media video{width:100%;height:auto;object-fit:cover;display:block}
.bhero-hub .bhero-text{display:block;max-width:760px;margin:0 auto}
.bhero-hub h1{margin-bottom:20px}
.bhero-hub p{max-width:640px;margin:0 auto 32px}
.bhero-hub .bhero-btns{justify-content:center}
@media(max-width:900px){
  .bhero-hub{padding-top:28px;padding-bottom:40px}
  .bhero-hub .bhero-media{margin-bottom:28px}
}

/* ── LEISTUNGEN (what we take off your plate) ── */
.leist{padding:80px 0;background:var(--g)}
.leist .sec-head h2{color:#fff}
.leist .sec-head p{color:rgba(255,255,255,.9)}
.leist-grid{display:grid;grid-template-columns:repeat(5,1fr);gap:24px}
.leist-card{background:#fff;border:1px solid var(--border);border-radius:var(--r20);overflow:hidden;transition:transform var(--tr),box-shadow var(--tr)}
.leist-card:hover{transform:translateY(-4px);box-shadow:var(--shh)}
.leist-img{aspect-ratio:1/1;overflow:hidden;background:var(--gl)}
.leist-img img{width:100%;height:100%;object-fit:cover;display:block;transition:transform var(--tr)}
.leist-card:hover .leist-img img{transform:scale(1.05)}
.leist-body{padding:24px 24px 28px}
.leist-card h3{font-size:19px;font-weight:700;margin-bottom:10px}
.leist-card p{font-size:15px;line-height:1.55;color:var(--sec)}
@media(max-width:1024px){.leist-grid{grid-template-columns:repeat(2,1fr)}}
@media(max-width:768px){.leist{padding:56px 0}}
@media(max-width:480px){.leist-grid{grid-template-columns:repeat(2,1fr);gap:14px}}

/* ── CASE STUDIES ── */
.cases{padding:80px 0;background:var(--bg)}
.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;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)}
.case-stat{margin-top:auto;padding-top:16px;display:flex;align-items:baseline;gap:8px;flex-wrap:wrap}
.case-stat b{font-size:22px;font-weight:800;color:var(--g);letter-spacing:-.02em}
.case-stat span{font-size:13px;color:var(--sec)}
.case-more{margin-top:16px;align-self:flex-start;display:inline-flex;align-items:center;gap:6px;font-size:14px;font-weight:600;color:var(--g);background:#fff;border:1.5px solid var(--g);border-radius:var(--r8);padding:9px 16px;text-decoration:none;transition:all var(--tr)}
.case-more .ti{font-size:15px;transition:transform var(--tr)}
.case-more:hover{background:var(--gl);border-color:var(--gh);color:var(--gh)}
.case-more:hover .ti{transform:translate(2px,-2px)}
@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:repeat(2,1fr);gap:14px}.case-tag{display:none}.case-img{aspect-ratio:4/5}.case-body{padding:14px}}

/* ── BRANCHEN grid (links to subpages) ── */
.branchen{padding:80px 0;background:#fff}
.branchen-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:18px}
.branche-card{position:relative;aspect-ratio:1/1;border-radius:var(--r20);overflow:hidden;text-decoration:none;color:#fff;display:block;transition:transform var(--tr),box-shadow var(--tr)}
.branche-card:hover{transform:translateY(-4px);box-shadow:var(--shh)}
.branche-card-img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;transition:transform var(--tr)}
.branche-card:hover .branche-card-img{transform:scale(1.05)}
.branche-card-overlay{position:absolute;inset:0;background:linear-gradient(to top,rgba(0,0,0,.78) 0%,rgba(0,0,0,.42) 40%,rgba(0,0,0,.05) 75%)}
.branche-card-body{position:absolute;inset:0;z-index:1;display:flex;flex-direction:column;justify-content:flex-end;gap:8px;padding:24px}
.branche-card h3{font-size:19px;font-weight:700;color:#fff}
.branche-card p{font-size:13px;line-height:1.5;color:rgba(255,255,255,.88)}
.branche-more{display:inline-flex;align-items:center;gap:6px;font-size:14px;font-weight:600;color:#fff;margin-top:2px}
.branche-more .ti{transition:transform var(--tr)}
.branche-card:hover .branche-more .ti{transform:translateX(3px)}
@media(max-width:980px){.branchen-grid{grid-template-columns:repeat(2,1fr)}}
@media(max-width:768px){.branchen{padding:56px 0}}
@media(max-width:600px){.branche-card p,.branche-more{display:none}.branche-card-body{padding:16px 40px 16px 16px;justify-content:flex-end}.branche-card h3{font-size:16px}.branche-card::after{content:"\2192";position:absolute;right:14px;bottom:14px;z-index:2;width:28px;height:28px;display:flex;align-items:center;justify-content:center;border-radius:50%;background:rgba(255,255,255,.18);color:#fff;font-size:16px;font-weight:700}}
@media(max-width:420px){.branchen-grid{grid-template-columns:repeat(2,1fr);gap:12px}}

/* ── COVERAGE (deutschlandweit) ── */
.cover{padding:80px 0;background:var(--g);color:#fff;text-align:center}
.cover .eyebrow{background:rgba(255,255,255,.18);color:#fff}
.cover h2{color:#fff;font-size:clamp(26px,3.4vw,40px);font-weight:800;margin-bottom:16px}
.cover-lead{font-size:18px;line-height:1.6;color:rgba(255,255,255,.9);max-width:620px;margin:0 auto 28px}
.cover-stat{font-size:clamp(44px,7vw,72px);font-weight:800;letter-spacing:-.03em;line-height:1;margin-bottom:6px}
.cover-stat-lbl{font-size:15px;color:rgba(255,255,255,.82);margin-bottom:36px}
.cover-cities{display:flex;flex-wrap:wrap;align-items:center;justify-content:center;gap:10px;max-width:760px;margin:0 auto}
.cover-cities span{background:rgba(255,255,255,.14);border:1px solid rgba(255,255,255,.24);padding:8px 16px;border-radius:999px;font-size:14px;font-weight:500}
.cover-cities .city-extra{display:none}
.cover-cities.expanded .city-extra{display:inline-block}
.cities-toggle{display:inline-flex;align-items:center;justify-content:center;width:38px;height:38px;background:#fff;color:var(--g);border:none;border-radius:999px;cursor:pointer;transition:transform var(--tr),background var(--tr)}
.cities-toggle:hover{background:rgba(255,255,255,.85)}
.cities-toggle .ti{font-size:20px;transition:transform var(--tr)}
.cover-cities.expanded .cities-toggle .ti{transform:rotate(-90deg)}
@media(max-width:768px){.cover{padding:56px 0}.cover-lead{font-size:16px}}

/* ── PRESS (text wordmarks — see flag in HTML) ── */
.press{padding:60px 0;background:#fff;border-top:1px solid var(--border)}
.press h2{text-align:center;font-size:clamp(20px,2.4vw,26px);font-weight:700;margin-bottom:28px}
.press-row{display:flex;flex-wrap:wrap;align-items:center;justify-content:center;gap:18px 40px}
.press-row span{font-size:clamp(15px,1.6vw,19px);font-weight:700;color:var(--sec);letter-spacing:-.01em;opacity:.75}
@media(max-width:768px){.press{padding:44px 0}}

/* ── FAQ ── */
.faq{padding:80px 0;background:var(--bg)}
.faq-list{max-width:820px;margin:0 auto;display:flex;flex-direction:column;gap:12px}
.faq-item{background:#fff;border:1px solid var(--border);border-radius:var(--r12);overflow:hidden}
.faq-item summary{display:flex;align-items:center;justify-content:space-between;gap:16px;padding:20px 24px;font-size:16px;font-weight:600;color:var(--black);cursor:pointer;list-style:none}
.faq-item summary::-webkit-details-marker{display:none}
.faq-item summary .ti{font-size:22px;color:var(--g);transition:transform var(--tr);flex-shrink:0}
.faq-item[open] summary .ti{transform:rotate(45deg)}
.faq-item .faq-a{padding:0 24px 20px;font-size:15px;line-height:1.65;color:var(--body)}
@media(max-width:768px){.faq{padding:56px 0}.faq-item summary{padding:16px 18px;font-size:15px}.faq-item .faq-a{padding:0 18px 16px}}

/* ── CTA / CONTACT ── */
.cta{padding:80px 0;background:#fff}
.cta-card{background:var(--black);border-radius:var(--r20);padding:56px;text-align:center;color:#fff}
.cta-card h2{color:#fff;font-size:clamp(26px,3.4vw,40px);font-weight:800;margin-bottom:14px}
.cta-card p{font-size:17px;line-height:1.6;color:rgba(255,255,255,.8);max-width:540px;margin:0 auto 28px}
.cta-btns{display:flex;flex-wrap:wrap;gap:12px;justify-content:center}
.cta-card .btn-s{color:#fff;border-color:rgba(255,255,255,.4)}
.cta-card .btn-s:hover{background:rgba(255,255,255,.1)}
.cta-contact{margin-top:24px;font-size:14px;color:rgba(255,255,255,.72)}
.cta-contact a{color:#fff;text-decoration:underline}
@media(max-width:768px){.cta{padding:56px 0}.cta-card{padding:36px 24px}}

/* ── Contact (Sprechen Sie mit uns) ── */
.contact{padding:80px 0;background:#fff}
.contact-h{text-align:center;font-size:clamp(26px,3.4vw,40px);font-weight:800;color:var(--black);margin-bottom:48px;letter-spacing:-.02em}
.contact-card{display:grid;grid-template-columns:minmax(0,300px) 1fr;gap:48px;align-items:center;max-width:900px;margin:0 auto}
.contact-photo img{width:100%;aspect-ratio:3/4;object-fit:cover;object-position:center top;border-radius:var(--r20);display:block;box-shadow:var(--shh)}
.contact-info h3{font-size:clamp(22px,2.4vw,28px);font-weight:800;color:var(--black);letter-spacing:-.02em}
.contact-role{font-size:15px;font-weight:600;color:var(--sec);margin-top:4px}
.contact-info>p{font-size:16px;line-height:1.6;color:var(--body);margin-top:20px;max-width:460px}
.contact-btns{display:flex;flex-wrap:wrap;gap:12px;margin-top:28px}
.contact-pill{display:inline-flex;align-items:center;gap:8px;background:var(--g);color:#fff;font-size:15px;font-weight:600;padding:11px 20px;border-radius:999px;text-decoration:none;transition:background var(--tr)}
.contact-pill:hover{background:var(--gh)}
.contact-pill .ti{font-size:18px}
@media(max-width:768px){
  .contact{padding:56px 0}
  .contact-card{grid-template-columns:1fr;gap:24px;justify-items:center}
  .contact-h{margin-bottom:32px}
  .contact-photo{display:flex;justify-content:center;width:100%}
  .contact-photo img{max-width:220px}
  .contact-info{text-align:center}
  .contact-info>p{margin-left:auto;margin-right:auto}
  .contact-btns{justify-content:center}
}

/* ── Brand marquee (scrolling logo wall) ── */
.refs h2{padding:0 24px}
.refs-marquee{display:flex;flex-direction:column;gap:28px;margin-top:8px}
.refs-row{overflow:hidden;-webkit-mask-image:linear-gradient(to right,transparent,#000 8%,#000 92%,transparent);mask-image:linear-gradient(to right,transparent,#000 8%,#000 92%,transparent)}
.refs-track{display:flex;align-items:center;gap:64px;width:max-content;will-change:transform}
.refs-track img{height:46px;width:auto;object-fit:contain;filter:grayscale(1);opacity:.6;transition:filter var(--tr),opacity var(--tr)}
.refs-track img:hover{filter:grayscale(0);opacity:1}
.refs-marquee.refs-ready .refs-track-left{animation:refs-scroll-left 45s linear infinite}
.refs-marquee.refs-ready .refs-track-right{animation:refs-scroll-right 45s linear infinite}
/* before images load, hold the right row at its loop start so it doesn't jump */
.refs-track-right{transform:translateX(-50%)}
.refs-marquee.refs-ready .refs-track-right{transform:none}
.refs-marquee:hover .refs-track{animation-play-state:paused}
@keyframes refs-scroll-left{from{transform:translateX(0)}to{transform:translateX(-50%)}}
@keyframes refs-scroll-right{from{transform:translateX(-50%)}to{transform:translateX(0)}}
@media(prefers-reduced-motion:reduce){.refs-track{animation:none}}
