/*
Theme Name: Operskalski Neue Website Vorlage Blau V39
Theme URI: https://www.operskalski.de/
Author: OpenAI ChatGPT
Description: Operskalski Website mit professioneller Portfolio-Startseite mit sauberem Intro, klaren Leistungsbereichen, Landingpages, echten Bildern, Ansprechpartnern sowie Impressum und Datenschutz. Blaues Farbsystem.
Version: 39.0.0
Requires at least: 6.0
Tested up to: 6.6
Requires PHP: 7.4
Text Domain: operskalski-vorlage-blau
*/

:root {
  --ops-navy: #061d42;
  --ops-navy-2: #092a5b;
  --ops-blue: #0d5cab;
  --ops-blue-2: #0f74d8;
  --ops-blue-3: #eaf4ff;
  --ops-soft: #f5f9fe;
  --ops-soft-2: #edf5ff;
  --ops-line: #d9e6f4;
  --ops-text: #0b2345;
  --ops-muted: #5f7188;
  --ops-white: #ffffff;
  --ops-shadow: 0 20px 50px rgba(6, 29, 66, .12);
  --ops-shadow-soft: 0 10px 25px rgba(6, 29, 66, .08);
  --ops-radius: 18px;
}

* { box-sizing: border-box; }
html { scroll-behavior: smooth; }
body {
  margin: 0;
  font-family: Arial, Helvetica, sans-serif;
  color: var(--ops-text);
  background: var(--ops-white);
  line-height: 1.45;
}
a { color: inherit; }
img { max-width: 100%; height: auto; display: block; }
.ops-site { overflow-x: hidden; min-height: 100vh; }
.ops-container { width: min(1220px, calc(100% - 48px)); margin: 0 auto; }

.ops-header {
  position: sticky;
  top: 0;
  z-index: 50;
  background: rgba(255,255,255,.98);
  border-bottom: 1px solid var(--ops-line);
  backdrop-filter: blur(10px);
}
.ops-header__inner {
  min-height: 84px;
  display: grid;
  grid-template-columns: auto 1fr auto;
  align-items: center;
  gap: 26px;
}
.ops-brand { display: block; text-decoration: none; }
.ops-brand img { width: 255px; max-height: 68px; object-fit: contain; }
.ops-nav { display: flex; justify-content: center; align-items: center; gap: 24px; font-size: 13px; font-weight: 800; }
.ops-nav a { text-decoration: none; padding: 30px 0 26px; border-bottom: 3px solid transparent; color: var(--ops-navy); }
.ops-nav a:hover,
.ops-nav a.is-active { border-bottom-color: var(--ops-blue); color: var(--ops-blue); }
.ops-header__cta { display: flex; gap: 16px; align-items: center; }
.ops-phone { color: var(--ops-navy); text-decoration: none; font-weight: 900; white-space: nowrap; font-size: 18px; }
.ops-phone:before { content: "☎"; color: var(--ops-blue); margin-right: 9px; }
.ops-mobile-toggle { display: none; width: 48px; height: 48px; border: 1px solid var(--ops-line); border-radius: 12px; background: var(--ops-white); color: var(--ops-navy); font-size: 24px; }

.ops-button,
.ops-button:visited,
button.ops-button {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-height: 48px;
  padding: 13px 22px;
  border-radius: 10px;
  border: 0;
  background: linear-gradient(135deg, var(--ops-blue), var(--ops-navy-2));
  color: var(--ops-white);
  text-decoration: none;
  font-weight: 900;
  cursor: pointer;
  box-shadow: 0 14px 28px rgba(13, 92, 171, .22);
}
.ops-button:hover { transform: translateY(-1px); box-shadow: 0 18px 32px rgba(13, 92, 171, .28); }
.ops-button--outline,
.ops-button--outline:visited {
  background: var(--ops-white);
  color: var(--ops-blue);
  border: 2px solid var(--ops-blue);
  box-shadow: none;
}
.ops-actions { display: flex; gap: 14px; flex-wrap: wrap; margin-top: 28px; }
.ops-link-button { display: inline-flex; align-items: center; justify-content: center; min-height: 44px; padding: 11px 18px; background: var(--ops-blue); color: var(--ops-white); border-radius: 9px; text-decoration: none; font-weight: 900; margin-top: 12px; }
.ops-link-button:hover { background: var(--ops-navy); }

.ops-hero {
  position: relative;
  background: linear-gradient(90deg, #fff 0%, #fff 35%, #f2f7fc 100%);
  overflow: hidden;
}
.ops-hero__grid {
  min-height: 520px;
  display: grid;
  grid-template-columns: 45% 55%;
  align-items: stretch;
}
.ops-hero__copy { padding: 66px 24px 62px 0; display: flex; flex-direction: column; justify-content: center; position: relative; z-index: 2; }
.ops-kicker {
  display: inline-block;
  margin-bottom: 14px;
  color: var(--ops-blue);
  font-size: 13px;
  letter-spacing: .05em;
  text-transform: uppercase;
  font-weight: 900;
}
.ops-hero h1 {
  margin: 0;
  color: var(--ops-navy);
  font-size: clamp(42px, 4.9vw, 67px);
  line-height: .98;
  letter-spacing: -.05em;
}
.ops-hero__lead { margin: 12px 0 0; color: var(--ops-navy-2); font-size: clamp(28px, 3vw, 44px); line-height: 1.04; letter-spacing: -.035em; }
.ops-hero__text { max-width: 560px; margin: 22px 0 0; color: #344c68; font-size: 18px; line-height: 1.65; }
.ops-hero__ticks { display: flex; gap: 16px; flex-wrap: wrap; margin-top: 22px; }
.ops-hero__ticks span { color: var(--ops-navy); font-weight: 800; }
.ops-hero__ticks span:before { content: "✓"; color: var(--ops-blue); margin-right: 7px; font-weight: 900; }
.ops-hero__photo { min-height: 520px; position: relative; }
.ops-hero__photo img { width: calc(100% + 60px); height: 100%; object-fit: cover; object-position: center; }
.ops-hero__photo:before { content: ""; position: absolute; inset: 0 auto 0 0; width: 38%; z-index: 1; background: linear-gradient(90deg, rgba(255,255,255,.95), rgba(255,255,255,0)); }
.ops-hero--solar .ops-hero__photo img { object-position: center; }

.ops-trustbar { background: var(--ops-white); border-top: 1px solid var(--ops-line); border-bottom: 1px solid var(--ops-line); }
.ops-trustbar__inner { display: grid; grid-template-columns: repeat(4,1fr); gap: 0; min-height: 86px; align-items: center; }
.ops-trust-item { display: grid; grid-template-columns: 42px 1fr; gap: 16px; align-items: center; padding: 18px 24px; border-right: 1px solid var(--ops-line); }
.ops-trust-item:last-child { border-right: 0; }
.ops-icon { display: inline-flex; align-items: center; justify-content: center; width: 44px; height: 44px; border: 2px solid var(--ops-blue); color: var(--ops-blue); border-radius: 13px; font-size: 23px; line-height: 1; }
.ops-trust-item strong { display: block; color: var(--ops-navy); font-size: 16px; line-height: 1.15; }
.ops-trust-item span:not(.ops-icon) { color: var(--ops-muted); font-size: 13px; display: block; margin-top: 4px; }
.ops-trustbar--dark { border: 0; background: var(--ops-white); }
.ops-trustbar--dark .ops-trustbar__inner { background: var(--ops-navy); border-radius: 10px; box-shadow: var(--ops-shadow); transform: translateY(-26px); margin-bottom: -26px; color: var(--ops-white); }
.ops-trustbar--dark .ops-trust-item { border-color: rgba(255,255,255,.18); }
.ops-trustbar--dark .ops-icon { border-color: rgba(255,255,255,.75); color: var(--ops-white); }
.ops-trustbar--dark .ops-trust-item strong { color: var(--ops-white); }
.ops-trustbar--dark .ops-trust-item span:not(.ops-icon) { color: #d9e8fa; }

.ops-section { padding: 64px 0; }
.ops-section--soft { background: var(--ops-soft); }
.ops-section__head { margin-bottom: 26px; }
.ops-section__head h2,
.ops-section h2 { margin: 0 0 10px; color: var(--ops-navy); font-size: clamp(28px, 3vw, 42px); line-height: 1.08; letter-spacing: -.03em; }
.ops-section__head p { margin: 0; color: var(--ops-muted); font-size: 17px; }
.ops-center { text-align: center; }
.ops-grid-2 { display: grid; grid-template-columns: repeat(2,minmax(0,1fr)); gap: 28px; }

.ops-maincards { padding-top: 58px; }
.ops-feature-card { display: grid; grid-template-columns: 45% 55%; min-height: 265px; overflow: hidden; background: var(--ops-white); border: 1px solid var(--ops-line); border-radius: 16px; box-shadow: var(--ops-shadow-soft); }
.ops-feature-card img { width: 100%; height: 100%; object-fit: cover; object-position: center center; }
.ops-feature-card__copy { padding: 32px; display: flex; flex-direction: column; justify-content: center; }
.ops-feature-card h2 { font-size: 31px; margin-bottom: 10px; }
.ops-feature-card p { color: #425874; margin: 0 0 12px; font-size: 16px; }
.ops-list { list-style: none; padding: 0; margin: 0; }
.ops-list li { margin: 7px 0; color: var(--ops-navy); font-size: 14px; }
.ops-list li:before { content: "✓"; color: var(--ops-blue); font-weight: 900; margin-right: 8px; }

.ops-services { padding-top: 20px; }
.ops-service-row { display: grid; grid-template-columns: repeat(7,minmax(0,1fr)); gap: 14px; }
.ops-mini-card { display: block; background: var(--ops-white); border: 1px solid var(--ops-line); border-radius: 12px; overflow: hidden; box-shadow: var(--ops-shadow-soft); text-decoration: none; transition: .18s ease; }
.ops-mini-card:hover { transform: translateY(-3px); box-shadow: var(--ops-shadow); }
.ops-mini-card__top { min-height: 72px; display: grid; grid-template-columns: 34px 1fr; gap: 9px; align-items: center; padding: 13px 12px 9px; }
.ops-mini-card .ops-icon { width: 34px; height: 34px; border-radius: 9px; font-size: 18px; border-width: 1.7px; }
.ops-mini-card strong { display: block; color: var(--ops-navy); font-size: 13px; line-height: 1.15; overflow-wrap: anywhere; hyphens: auto; }
.ops-mini-card img { width: 100%; height: 124px; object-fit: cover; object-position: center center; border-top: 1px solid var(--ops-line); display: block; background: #eef4fb; }

.ops-why { align-items: center; }
.ops-proof-image-card { position: relative; overflow: hidden; min-height: 330px; border-radius: 18px; border: 1px solid var(--ops-line); box-shadow: var(--ops-shadow-soft); background: var(--ops-navy); }
.ops-proof-image-card img { position: absolute; inset: 0; width: 100%; height: 100%; object-fit: cover; object-position: center center; }
.ops-proof-image-card:after { content: ""; position: absolute; inset: 0; background: linear-gradient(180deg, rgba(6,29,66,0) 35%, rgba(6,29,66,.88) 100%); }
.ops-proof-badge { position: absolute; left: 24px; right: 24px; bottom: 24px; z-index: 2; display: grid; grid-template-columns: 56px 1fr; gap: 16px; align-items: center; padding: 18px; border-radius: 15px; background: rgba(255,255,255,.95); box-shadow: var(--ops-shadow-soft); }
.ops-proof-badge__icon { display: flex; align-items: center; justify-content: center; width: 56px; height: 56px; border-radius: 14px; background: var(--ops-blue-3); color: var(--ops-blue); font-size: 30px; font-weight: 900; }
.ops-proof-badge strong { display: block; color: var(--ops-navy); font-size: 19px; line-height: 1.15; }
.ops-proof-badge span { display: block; margin-top: 5px; color: var(--ops-muted); font-weight: 700; }
.ops-checkgrid { display: grid; grid-template-columns: repeat(2,minmax(0,1fr)); gap: 16px 24px; }
.ops-check { display: grid; grid-template-columns: 30px 1fr; gap: 12px; align-items: start; }
.ops-check:before { content: "✓"; width: 26px; height: 26px; border-radius: 50%; display: flex; align-items: center; justify-content: center; border: 2px solid var(--ops-blue); color: var(--ops-blue); font-weight: 900; }
.ops-check strong { display: block; color: var(--ops-navy); font-size: 16px; }
.ops-check span { color: var(--ops-muted); font-size: 14px; }


.ops-people { background: linear-gradient(180deg, #fff 0%, var(--ops-soft) 100%); }
.ops-people__head { display: flex; align-items: end; justify-content: space-between; gap: 24px; margin-bottom: 24px; }
.ops-people__head h2 { margin: 0; color: var(--ops-navy); font-size: clamp(28px, 3vw, 42px); line-height: 1.08; letter-spacing: -.03em; }
.ops-people__head p { margin: 0; max-width: 500px; color: var(--ops-muted); font-size: 16px; }
.ops-people__grid { display: grid; grid-template-columns: repeat(2,minmax(0,1fr)); gap: 24px; }
.ops-person-card { display: grid; grid-template-columns: 43% 57%; min-height: 300px; overflow: hidden; background: var(--ops-white); border: 1px solid var(--ops-line); border-radius: 18px; box-shadow: var(--ops-shadow-soft); }
.ops-person-card__image { position: relative; overflow: hidden; background: #eef4fb; }
.ops-person-card__image img { width: 100%; height: 100%; object-fit: cover; object-position: center center; }
.ops-person-card__copy { padding: 28px; display: flex; flex-direction: column; justify-content: center; }
.ops-person-card__copy span { color: var(--ops-blue); font-size: 13px; font-weight: 900; letter-spacing: .04em; text-transform: uppercase; }
.ops-person-card__copy h3 { margin: 8px 0 10px; color: var(--ops-navy); font-size: 28px; line-height: 1.05; }
.ops-person-card__copy p { margin: 0 0 18px; color: var(--ops-muted); font-size: 15px; }
.ops-person-card__links { display: flex; flex-wrap: wrap; gap: 10px; }
.ops-person-card__links a { display: inline-flex; align-items: center; min-height: 40px; padding: 9px 13px; border-radius: 9px; border: 1px solid var(--ops-line); text-decoration: none; color: var(--ops-blue); font-weight: 900; background: #fff; }
.ops-person-card__links a:hover { border-color: var(--ops-blue); background: var(--ops-blue-3); }

.ops-focus { display: grid; grid-template-columns: repeat(2,minmax(0,1fr)); gap: 24px; }
.ops-focus-card { position: relative; min-height: 230px; border-radius: 16px; overflow: hidden; color: var(--ops-white); box-shadow: var(--ops-shadow); background: var(--ops-navy); }
.ops-focus-card img { position: absolute; inset: 0; width: 100%; height: 100%; object-fit: cover; opacity: .62; }
.ops-focus-card div { position: relative; z-index: 2; padding: 30px; max-width: 470px; }
.ops-focus-card:after { content: ""; position: absolute; inset: 0; background: linear-gradient(90deg, rgba(6,29,66,.92), rgba(6,29,66,.35)); }
.ops-focus-card h3 { font-size: 31px; margin: 0 0 13px; }
.ops-focus-card ul { list-style: none; padding: 0; margin: 0 0 18px; }
.ops-focus-card li { margin: 8px 0; }
.ops-focus-card li:before { content: "✓"; margin-right: 8px; }
.ops-focus-card .ops-button { background: var(--ops-white); color: var(--ops-blue); box-shadow: none; }

.ops-logo-row { display: grid; grid-template-columns: repeat(6,1fr); gap: 14px; align-items: center; }
.ops-logo-row span { min-height: 76px; display: flex; align-items: center; justify-content: center; background: var(--ops-white); border: 1px solid var(--ops-line); border-radius: 12px; color: #6a7685; font-size: 18px; font-weight: 900; letter-spacing: .02em; text-transform: uppercase; filter: grayscale(1); }

.ops-process { display: grid; grid-template-columns: 1fr 1fr; gap: 34px; align-items: center; }
.ops-steps { display: grid; grid-template-columns: repeat(4,1fr); gap: 12px; margin-top: 24px; }
.ops-step { position: relative; padding: 22px 16px; background: var(--ops-white); border: 1px solid var(--ops-line); border-radius: 15px; box-shadow: var(--ops-shadow-soft); }
.ops-step b { display: flex; align-items: center; justify-content: center; width: 34px; height: 34px; border-radius: 50%; background: var(--ops-blue); color: var(--ops-white); margin-bottom: 12px; }
.ops-step strong { display: block; color: var(--ops-navy); }
.ops-step span { color: var(--ops-muted); font-size: 14px; display: block; margin-top: 6px; }

.ops-card-grid { display: grid; grid-template-columns: repeat(3,1fr); gap: 18px; }
.ops-card-grid article { background: var(--ops-white); border: 1px solid var(--ops-line); border-radius: 16px; padding: 26px; box-shadow: var(--ops-shadow-soft); }
.ops-card-grid h3 { margin: 0 0 10px; color: var(--ops-navy); font-size: 22px; }
.ops-card-grid p { margin: 0; color: var(--ops-muted); }

.ops-solar-targets { display: grid; grid-template-columns: repeat(4,1fr); gap: 20px; }
.ops-target { border: 1px solid var(--ops-line); border-radius: 16px; overflow: hidden; background: var(--ops-white); box-shadow: var(--ops-shadow-soft); text-align: center; }
.ops-target img { width: 100%; aspect-ratio: 1.5/1; object-fit: cover; }
.ops-target div { padding: 18px; }
.ops-target h3 { margin: 0 0 7px; color: var(--ops-navy); }
.ops-target p { margin: 0; color: var(--ops-muted); font-size: 14px; }

.ops-form-wrap { display: grid; grid-template-columns: .85fr 1.15fr; gap: 28px; align-items: start; }
.ops-form-card { background: var(--ops-white); border: 1px solid var(--ops-line); border-radius: 18px; box-shadow: var(--ops-shadow-soft); padding: 28px; }
.ops-form { display: grid; gap: 14px; }
.ops-form__row { display: grid; grid-template-columns: 1fr 1fr; gap: 14px; }
.ops-form label { color: var(--ops-navy); font-size: 13px; font-weight: 800; display: grid; gap: 7px; }
.ops-form input,
.ops-form select,
.ops-form textarea { width: 100%; border: 1px solid var(--ops-line); border-radius: 10px; min-height: 48px; padding: 12px 14px; font: inherit; color: var(--ops-text); background: #fff; }
.ops-form textarea { min-height: 118px; resize: vertical; }
.ops-form__check { grid-template-columns: 18px 1fr !important; align-items: start; font-weight: 600 !important; color: var(--ops-muted) !important; }
.ops-form__check input { min-height: auto; margin-top: 2px; }
.ops-notice { padding: 12px 14px; border-radius: 10px; font-weight: 800; }
.ops-notice--success { background: #eaf4ff; color: var(--ops-blue); }
.ops-notice--error { background: #fff1f1; color: #9b1c1c; }

.ops-cta-strip { margin-bottom: 34px; background: var(--ops-navy); color: var(--ops-white); border-radius: 15px; min-height: 96px; display: grid; grid-template-columns: 1.15fr .75fr .75fr; align-items: center; gap: 24px; padding: 24px 32px; box-shadow: var(--ops-shadow); }
.ops-cta-strip strong { display: block; font-size: 28px; line-height: 1.05; }
.ops-cta-strip span { color: #d5e6f8; }
.ops-cta-strip a:not(.ops-button) { color: var(--ops-white); font-size: 24px; font-weight: 900; text-decoration: none; }
.ops-cta-strip .ops-button { background: var(--ops-blue); }

.ops-footer { background: var(--ops-white); border-top: 1px solid var(--ops-line); padding: 0 0 0; }
.ops-footer__grid { display: grid; grid-template-columns: 1.25fr .95fr .95fr .95fr .85fr; gap: 30px; padding: 38px 0; }
.ops-footer img { width: 210px; margin-bottom: 14px; }
.ops-footer h3 { color: var(--ops-navy); margin: 0 0 13px; }
.ops-footer p,
.ops-footer a { color: #41546b; text-decoration: none; }
.ops-footer a:hover { color: var(--ops-blue); }
.ops-footer__bottom { background: var(--ops-navy); color: #d9e8f8; display: flex; align-items: center; justify-content: space-between; padding: 16px max(24px, calc((100vw - 1220px)/2)); font-size: 13px; }
.ops-footer__bottom a { color: #fff; }

.ops-mobile-bar { display: none; position: fixed; left: 0; right: 0; bottom: 0; z-index: 70; grid-template-columns: 1fr 1fr; }
.ops-mobile-bar a { display: flex; justify-content: center; align-items: center; min-height: 58px; background: var(--ops-navy); color: #fff; text-decoration: none; font-weight: 900; border-right: 1px solid rgba(255,255,255,.18); }
.ops-mobile-bar a:last-child { background: var(--ops-blue); }

@media (max-width: 1100px) {
  .ops-header__inner { grid-template-columns: auto auto; justify-content: space-between; }
  .ops-nav, .ops-header__cta .ops-button { display: none; }
  .ops-mobile-toggle { display: inline-flex; align-items: center; justify-content: center; }
  .ops-header__cta { gap: 10px; }
  .ops-phone { font-size: 0; width: 48px; height: 48px; border-radius: 12px; display: flex; align-items: center; justify-content: center; background: var(--ops-blue); color: #fff; }
  .ops-phone:before { margin: 0; color: #fff; font-size: 22px; }
}
@media (max-width: 920px) {
  .ops-container { width: min(100% - 28px, 720px); }
  .ops-hero__grid { grid-template-columns: 1fr; min-height: auto; }
  .ops-hero__copy { padding: 42px 0 28px; }
  .ops-hero__photo { min-height: 290px; margin: 0 -14px; }
  .ops-hero__photo img { width: 100%; }
  .ops-trustbar__inner { grid-template-columns: repeat(2,1fr); }
  .ops-trust-item { border-bottom: 1px solid var(--ops-line); }
  .ops-grid-2, .ops-focus, .ops-process, .ops-form-wrap { grid-template-columns: 1fr; }
  .ops-proof-image-card { min-height: 285px; }
  .ops-service-row { grid-template-columns: repeat(2,1fr); }
  .ops-feature-card { grid-template-columns: 1fr; }
  .ops-feature-card img { min-height: 220px; object-position: center center; }
  .ops-logo-row { grid-template-columns: repeat(2,1fr); }
  .ops-card-grid { grid-template-columns: 1fr; }
  .ops-solar-targets { grid-template-columns: repeat(2,1fr); }
  .ops-steps { grid-template-columns: 1fr 1fr; }
  .ops-cta-strip { grid-template-columns: 1fr; text-align: center; }
  .ops-footer__grid { grid-template-columns: 1fr 1fr; }
  .ops-footer__bottom { display: grid; gap: 8px; text-align: center; justify-content: center; padding-bottom: 74px; }
  .ops-mobile-bar { display: grid; }
}
@media (max-width: 560px) {
  .ops-brand img { width: 205px; }
  .ops-header__inner { min-height: 74px; }
  .ops-hero h1 { font-size: 38px; }
  .ops-hero__lead { font-size: 28px; }
  .ops-actions { display: grid; grid-template-columns: 1fr; }
  .ops-button { width: 100%; }
  .ops-trustbar__inner { grid-template-columns: 1fr; }
  .ops-trust-item { border-right: 0; }
  .ops-service-row { grid-template-columns: repeat(2, minmax(0,1fr)); gap: 10px; }
  .ops-mini-card__top { grid-template-columns: 1fr; text-align: center; justify-items: center; min-height: 92px; }
  .ops-checkgrid { grid-template-columns: 1fr; }
  .ops-proof-badge { left: 16px; right: 16px; bottom: 16px; grid-template-columns: 48px 1fr; padding: 14px; }
  .ops-proof-badge__icon { width: 48px; height: 48px; font-size: 24px; }
  .ops-solar-targets { grid-template-columns: 1fr; }
  .ops-form__row { grid-template-columns: 1fr; }
  .ops-footer__grid { grid-template-columns: 1fr; }
}


.ops-legal { background: linear-gradient(180deg, #ffffff 0%, var(--ops-soft) 100%); }
.ops-legal__wrap { max-width: 980px; margin: 0 auto; }
.ops-legal__intro { background: var(--ops-white); border: 1px solid var(--ops-line); border-radius: 18px; box-shadow: var(--ops-shadow-soft); padding: 34px; margin-bottom: 24px; }
.ops-legal h1 { margin: 0 0 14px; color: var(--ops-navy); font-size: clamp(36px,4vw,56px); line-height: 1.03; letter-spacing: -.04em; }
.ops-legal h2 { margin: 38px 0 12px; color: var(--ops-navy); font-size: 26px; letter-spacing: -.02em; }
.ops-legal h3 { margin: 22px 0 8px; color: var(--ops-navy); font-size: 20px; }
.ops-legal p, .ops-legal li { color: #344c68; font-size: 16px; line-height: 1.7; }
.ops-legal a { color: var(--ops-blue); font-weight: 800; }
.ops-legal__card { background: var(--ops-white); border: 1px solid var(--ops-line); border-radius: 16px; box-shadow: var(--ops-shadow-soft); padding: 28px; margin: 18px 0; }
.ops-legal__grid { display: grid; grid-template-columns: repeat(2,minmax(0,1fr)); gap: 18px; }
.ops-form__privacy { margin-top: -6px; color: var(--ops-muted); font-size: 12px; line-height: 1.55; }
.ops-form__privacy a { color: var(--ops-blue); font-weight: 900; }
@media (max-width: 760px) { .ops-legal__grid { grid-template-columns: 1fr; } .ops-legal__intro, .ops-legal__card { padding: 22px; } }


/* Startseiten-Animation: Logo einfliegen, Leistungsbereiche nacheinander einblenden */
@keyframes opsLogoFlyIn {
  0% { opacity: 0; transform: translateX(-34px) scale(.96); filter: blur(5px); }
  100% { opacity: 1; transform: translateX(0) scale(1); filter: blur(0); }
}
@keyframes opsFadeRise {
  0% { opacity: 0; transform: translateY(18px); }
  100% { opacity: 1; transform: translateY(0); }
}
body.ops-home-page .ops-brand img {
  opacity: 0;
  transform-origin: left center;
  animation: opsLogoFlyIn .78s cubic-bezier(.18,.84,.24,1) .05s forwards;
}
body.ops-home-page .ops-hero__copy,
body.ops-home-page .ops-hero__photo,
body.ops-home-page .ops-trust-item,
body.ops-home-page .ops-feature-card,
body.ops-home-page .ops-mini-card {
  opacity: 0;
  animation: opsFadeRise .62s ease forwards;
}
body.ops-home-page .ops-hero__copy { animation-delay: .28s; }
body.ops-home-page .ops-hero__photo { animation-delay: .40s; }
body.ops-home-page .ops-trust-item:nth-child(1) { animation-delay: .58s; }
body.ops-home-page .ops-trust-item:nth-child(2) { animation-delay: .68s; }
body.ops-home-page .ops-trust-item:nth-child(3) { animation-delay: .78s; }
body.ops-home-page .ops-trust-item:nth-child(4) { animation-delay: .88s; }
body.ops-home-page .ops-feature-card:nth-child(1) { animation-delay: 1.02s; }
body.ops-home-page .ops-feature-card:nth-child(2) { animation-delay: 1.14s; }
body.ops-home-page .ops-mini-card:nth-child(1) { animation-delay: 1.28s; }
body.ops-home-page .ops-mini-card:nth-child(2) { animation-delay: 1.38s; }
body.ops-home-page .ops-mini-card:nth-child(3) { animation-delay: 1.48s; }
body.ops-home-page .ops-mini-card:nth-child(4) { animation-delay: 1.58s; }
body.ops-home-page .ops-mini-card:nth-child(5) { animation-delay: 1.68s; }
body.ops-home-page .ops-mini-card:nth-child(6) { animation-delay: 1.78s; }
body.ops-home-page .ops-mini-card:nth-child(7) { animation-delay: 1.88s; }
@media (prefers-reduced-motion: reduce) {
  body.ops-home-page .ops-brand img,
  body.ops-home-page .ops-hero__copy,
  body.ops-home-page .ops-hero__photo,
  body.ops-home-page .ops-trust-item,
  body.ops-home-page .ops-feature-card,
  body.ops-home-page .ops-mini-card {
    opacity: 1;
    transform: none;
    filter: none;
    animation: none;
  }
}

/* V15: einheitliche Vorschaubilder in Weitere Leistungen */
.ops-mini-card { display: flex; flex-direction: column; }
.ops-mini-card__top { flex: 0 0 84px; }
.ops-mini-card img { flex: 0 0 124px; }
@media (max-width: 760px) { .ops-mini-card__top { flex-basis: 96px; } .ops-mini-card img { height: 118px; flex-basis: 118px; } }

/* V17: Prozesskern-inspirierte Startsequenz und echte Scroll-Reveals */
.ops-intro-splash {
  position: fixed;
  inset: 0;
  z-index: 9999;
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 28px;
  background:
    radial-gradient(circle at 50% 30%, rgba(255,255,255,.96), rgba(234,244,255,.94) 46%, rgba(6,29,66,.98) 100%),
    linear-gradient(135deg, #fff, var(--ops-blue-3));
  opacity: 1;
  visibility: visible;
  transition: opacity .55s ease, visibility 0s linear .55s;
}
.ops-intro-splash__card {
  width: min(840px, 100%);
  min-height: 300px;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  gap: 22px;
  text-align: center;
}
.ops-intro-splash__logo {
  width: min(420px, 86vw);
  max-height: 120px;
  object-fit: contain;
  opacity: 0;
  transform: translateX(-70px) scale(.94);
  filter: blur(8px);
  animation: opsIntroLogoFly .86s cubic-bezier(.16,.84,.22,1) .12s forwards;
}
.ops-intro-splash__line {
  color: var(--ops-navy);
  font-size: clamp(18px, 2vw, 24px);
  font-weight: 900;
  letter-spacing: -.02em;
  opacity: 0;
  transform: translateY(16px);
  animation: opsIntroFadeUp .5s ease .78s forwards;
}
.ops-intro-splash__services {
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
  gap: 10px;
}
.ops-intro-splash__services span {
  display: inline-flex;
  align-items: center;
  min-height: 40px;
  padding: 9px 15px;
  border: 1px solid rgba(13,92,171,.25);
  border-radius: 999px;
  background: rgba(255,255,255,.86);
  color: var(--ops-blue);
  font-weight: 900;
  box-shadow: 0 10px 25px rgba(6,29,66,.08);
  opacity: 0;
  transform: translateY(18px) scale(.98);
  animation: opsIntroChip .42s ease forwards;
}
.ops-intro-splash__services span:nth-child(1) { animation-delay: 1.08s; }
.ops-intro-splash__services span:nth-child(2) { animation-delay: 1.22s; }
.ops-intro-splash__services span:nth-child(3) { animation-delay: 1.36s; }
.ops-intro-splash__services span:nth-child(4) { animation-delay: 1.50s; }
.ops-intro-splash__services span:nth-child(5) { animation-delay: 1.64s; }
body.ops-intro-done .ops-intro-splash {
  opacity: 0;
  visibility: hidden;
  pointer-events: none;
}
@keyframes opsIntroLogoFly {
  0% { opacity: 0; transform: translateX(-70px) scale(.94); filter: blur(8px); }
  68% { opacity: 1; filter: blur(0); }
  100% { opacity: 1; transform: translateX(0) scale(1); filter: blur(0); }
}
@keyframes opsIntroFadeUp {
  100% { opacity: 1; transform: translateY(0); }
}
@keyframes opsIntroChip {
  100% { opacity: 1; transform: translateY(0) scale(1); }
}
.ops-coverage {
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
  margin-top: 22px;
}
.ops-coverage span {
  display: inline-flex;
  align-items: center;
  min-height: 34px;
  padding: 7px 12px;
  border-radius: 999px;
  background: rgba(234,244,255,.92);
  border: 1px solid rgba(13,92,171,.20);
  color: var(--ops-blue);
  font-size: 13px;
  font-weight: 900;
}
.ops-coverage span:before {
  content: "";
  width: 7px;
  height: 7px;
  border-radius: 50%;
  background: var(--ops-blue);
  margin-right: 8px;
}
/* JS-gesteuerte Reveals ersetzen die alte reine CSS-Animation und verhindern Cache-Probleme. */
html.ops-js body.ops-home-page .ops-brand img,
html.ops-js body.ops-home-page .ops-hero__copy,
html.ops-js body.ops-home-page .ops-hero__photo,
html.ops-js body.ops-home-page .ops-trust-item,
html.ops-js body.ops-home-page .ops-feature-card,
html.ops-js body.ops-home-page .ops-mini-card {
  animation: none;
  opacity: 1;
  transform: none;
  filter: none;
}
html.ops-js body.ops-home-page .ops-brand img {
  opacity: 0;
  transform-origin: left center;
}
html.ops-js body.ops-home-page.ops-intro-done .ops-brand img {
  animation: opsLogoFlyIn .58s cubic-bezier(.18,.84,.24,1) forwards;
}
html.ops-js body.ops-home-page .ops-reveal {
  opacity: 0 !important;
  transform: translateY(28px) !important;
  transition: opacity .62s ease var(--ops-reveal-delay, 0s), transform .62s ease var(--ops-reveal-delay, 0s);
  will-change: opacity, transform;
}
html.ops-js body.ops-home-page .ops-reveal.is-visible {
  opacity: 1 !important;
  transform: translateY(0) !important;
}
html.ops-js body.ops-home-page .ops-coverage span {
  opacity: 0;
  transform: translateY(10px);
  animation: opsCoverageIn .45s ease forwards;
}
html.ops-js body.ops-home-page .ops-coverage span:nth-child(1) { animation-delay: 2.90s; }
html.ops-js body.ops-home-page .ops-coverage span:nth-child(2) { animation-delay: 3.02s; }
html.ops-js body.ops-home-page .ops-coverage span:nth-child(3) { animation-delay: 3.14s; }
html.ops-js body.ops-home-page .ops-coverage span:nth-child(4) { animation-delay: 3.26s; }
html.ops-js body.ops-home-page .ops-coverage span:nth-child(5) { animation-delay: 3.38s; }
@keyframes opsCoverageIn { to { opacity: 1; transform: translateY(0); } }
@media (prefers-reduced-motion: reduce) {
  .ops-intro-splash { display: none; }
  html.ops-js body.ops-home-page .ops-brand img,
  html.ops-js body.ops-home-page .ops-reveal,
  html.ops-js body.ops-home-page .ops-coverage span {
    opacity: 1 !important;
    transform: none !important;
    animation: none !important;
    transition: none !important;
  }
}
@media (max-width: 760px) {
  .ops-intro-splash__card { min-height: 260px; gap: 18px; }
  .ops-intro-splash__services span { min-height: 36px; padding: 8px 12px; font-size: 13px; }
  .ops-coverage { gap: 8px; }
  .ops-coverage span { font-size: 12px; }
}

/* V18: Startseite als Portfolio-Intro statt einzelner Gebaeudereinigungs-Landingpage */
.ops-intro-splash--portfolio {
  overflow: hidden;
  background: var(--ops-navy);
  transition: opacity .70s ease, visibility 0s linear .70s;
}
.ops-intro-splash--portfolio:after {
  content: "";
  position: absolute;
  inset: 0;
  z-index: 1;
  background:
    radial-gradient(circle at 50% 42%, rgba(255,255,255,.24), rgba(6,29,66,.30) 38%, rgba(6,29,66,.92) 100%),
    linear-gradient(90deg, rgba(6,29,66,.90), rgba(13,92,171,.38), rgba(6,29,66,.90));
}
.ops-intro-bg {
  position: absolute;
  inset: 0;
  background-size: cover;
  background-position: center;
  opacity: 0;
  transform: scale(1.08);
  filter: saturate(1.04) contrast(1.02);
  animation: opsIntroBg 4.8s ease forwards;
}
.ops-intro-bg--cleaning { animation-delay: .10s; }
.ops-intro-bg--household { animation-delay: 1.00s; }
.ops-intro-bg--solar { animation-delay: 1.90s; }
.ops-intro-bg--glass { animation-delay: 2.80s; }
.ops-intro-bg--winter { animation-delay: 3.70s; }
.ops-intro-stage {
  position: relative;
  z-index: 2;
  width: min(980px, calc(100% - 36px));
  min-height: min(620px, 82vh);
}
.ops-intro-splash--portfolio .ops-intro-splash__logo {
  width: min(430px, 82vw);
  padding: 20px 26px;
  border-radius: 22px;
  background: rgba(255,255,255,.94);
  box-shadow: 0 35px 90px rgba(0,0,0,.28);
  animation: opsIntroLogoFly .95s cubic-bezier(.16,.84,.22,1) .16s forwards;
}
.ops-intro-splash--portfolio .ops-intro-splash__line {
  color: #fff;
  text-shadow: 0 6px 22px rgba(0,0,0,.35);
  animation-delay: .92s;
}
.ops-intro-word {
  position: absolute;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-height: 58px;
  padding: 13px 22px;
  border-radius: 999px;
  background: rgba(255,255,255,.92);
  color: var(--ops-navy);
  border: 1px solid rgba(255,255,255,.56);
  box-shadow: 0 24px 60px rgba(0,0,0,.23);
  font-weight: 950;
  font-size: clamp(17px, 2.2vw, 28px);
  letter-spacing: -.03em;
  opacity: 0;
}
.ops-intro-word:before {
  content: "";
  width: 11px;
  height: 11px;
  border-radius: 50%;
  background: var(--ops-blue);
  margin-right: 12px;
}
.ops-intro-word--left { left: 0; top: 52%; transform: translateX(-130px); animation: opsWordLeft .62s ease 1.35s forwards; }
.ops-intro-word--right { right: 0; top: 52%; transform: translateX(130px); animation: opsWordRight .62s ease 1.88s forwards; }
.ops-intro-word--top { left: 50%; top: 72px; transform: translate(-50%, -90px); animation: opsWordTop .62s ease 2.42s forwards; }
.ops-intro-word--bottom { left: 50%; bottom: 78px; transform: translate(-50%, 90px); animation: opsWordBottom .62s ease 2.96s forwards; }
.ops-intro-word--zoom { left: 50%; top: 70%; transform: translate(-50%, -50%) scale(.55); animation: opsWordZoom .68s ease 3.55s forwards; }
@keyframes opsIntroBg {
  0% { opacity: 0; transform: scale(1.08); }
  18% { opacity: .58; }
  52% { opacity: .52; }
  100% { opacity: 0; transform: scale(1.00); }
}
@keyframes opsWordLeft { to { opacity: 1; transform: translateX(0); } }
@keyframes opsWordRight { to { opacity: 1; transform: translateX(0); } }
@keyframes opsWordTop { to { opacity: 1; transform: translate(-50%, 0); } }
@keyframes opsWordBottom { to { opacity: 1; transform: translate(-50%, 0); } }
@keyframes opsWordZoom { to { opacity: 1; transform: translate(-50%, -50%) scale(1); } }

.ops-hero--portfolio { background: linear-gradient(120deg, #fff 0%, #f5f9fe 56%, #eaf4ff 100%); }
.ops-hero--portfolio .ops-hero__grid { grid-template-columns: 43% 57%; min-height: 560px; }
.ops-hero--portfolio .ops-hero__copy { padding-top: 76px; padding-bottom: 76px; }
.ops-hero--portfolio .ops-hero__text { max-width: 520px; }
.ops-hero-stack {
  min-height: 560px;
  display: block;
  padding: 44px 0 44px 36px;
}
.ops-hero-stack:before { display: none; }
.ops-stack-card {
  position: absolute;
  margin: 0;
  overflow: hidden;
  border-radius: 20px;
  background: #fff;
  border: 1px solid var(--ops-line);
  box-shadow: var(--ops-shadow);
}
.ops-stack-card img { width: 100%; height: 100%; object-fit: cover; }
.ops-stack-card figcaption {
  position: absolute;
  left: 18px;
  bottom: 18px;
  padding: 9px 13px;
  border-radius: 999px;
  background: rgba(255,255,255,.93);
  color: var(--ops-blue);
  font-weight: 950;
  box-shadow: 0 12px 28px rgba(6,29,66,.16);
}
.ops-stack-card--main { left: 36px; top: 44px; right: 0; bottom: 86px; }
.ops-stack-card--main img { object-position: center; }
.ops-stack-card--small { width: 265px; height: 160px; z-index: 2; }
.ops-stack-card--solar { left: 0; bottom: 40px; }
.ops-stack-card--winter { right: 28px; bottom: 14px; }

.ops-portfolio-overview { padding-top: 74px; }
.ops-portfolio-grid {
  display: grid;
  grid-template-columns: repeat(6, minmax(0, 1fr));
  gap: 18px;
}
.ops-portfolio-card {
  position: relative;
  min-height: 190px;
  overflow: hidden;
  display: flex;
  align-items: flex-end;
  padding: 20px;
  border-radius: 18px;
  text-decoration: none;
  color: #fff;
  background: var(--ops-navy);
  box-shadow: var(--ops-shadow-soft);
  border: 1px solid rgba(13,92,171,.16);
  isolation: isolate;
}
.ops-portfolio-card--large { grid-column: span 3; min-height: 275px; }
.ops-portfolio-card img {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  object-fit: cover;
  transition: transform .28s ease;
  z-index: -2;
}
.ops-portfolio-card:after {
  content: "";
  position: absolute;
  inset: 0;
  z-index: -1;
  background: linear-gradient(180deg, rgba(6,29,66,.08) 0%, rgba(6,29,66,.82) 100%);
}
.ops-portfolio-card:hover img { transform: scale(1.045); }
.ops-portfolio-card span {
  display: block;
  font-size: clamp(19px, 2vw, 28px);
  font-weight: 950;
  letter-spacing: -.03em;
  line-height: 1.02;
}
.ops-portfolio-card strong {
  display: block;
  margin-top: 8px;
  max-width: 450px;
  color: #dcecff;
  font-size: 15px;
}
.ops-home-shortcuts .ops-focus-card div p { margin: 0 0 18px; color: #dcecff; }

/* V18: alte Startseiten-Karten werden nicht mehr genutzt, Portfolio ist der Einstieg. */
.ops-home-page .ops-maincards,
.ops-home-page .ops-services { display: none; }

@media (max-width: 1020px) {
  .ops-hero--portfolio .ops-hero__grid { grid-template-columns: 1fr; min-height: auto; }
  .ops-hero-stack { min-height: 420px; padding: 22px 0 46px; }
  .ops-stack-card--main { left: 0; top: 22px; right: 0; bottom: 88px; }
  .ops-stack-card--small { width: 220px; height: 132px; }
  .ops-stack-card--solar { left: 22px; bottom: 26px; }
  .ops-stack-card--winter { right: 22px; bottom: 12px; }
  .ops-portfolio-grid { grid-template-columns: repeat(3, minmax(0, 1fr)); }
  .ops-portfolio-card--large { grid-column: span 3; }
}
@media (max-width: 760px) {
  .ops-intro-stage { min-height: 520px; }
  .ops-intro-word { min-height: 44px; padding: 10px 14px; font-size: 15px; }
  .ops-intro-word--left { left: 8px; top: 52%; }
  .ops-intro-word--right { right: 8px; top: 62%; }
  .ops-intro-word--top { top: 82px; }
  .ops-intro-word--bottom { bottom: 78px; }
  .ops-intro-word--zoom { top: 74%; }
  .ops-hero-stack { min-height: 350px; }
  .ops-stack-card--small { width: 46%; height: 118px; }
  .ops-portfolio-grid { grid-template-columns: 1fr; }
  .ops-portfolio-card,
  .ops-portfolio-card--large { grid-column: auto; min-height: 210px; }
}
@media (prefers-reduced-motion: reduce) {
  .ops-intro-bg,
  .ops-intro-word,
  .ops-stack-card,
  .ops-portfolio-card img { animation: none !important; transition: none !important; }
}

/* V33: separater Privat-Haushaltsbereich entfernt */
.ops-hero--household {
  background: linear-gradient(135deg, #f8fbff 0%, #ffffff 56%, #edf5ff 100%);
}
.ops-hero--compact { padding: 72px 0 58px; }
.ops-hero--services {
  background: radial-gradient(circle at 76% 28%, rgba(13,92,171,.13), transparent 34%), linear-gradient(135deg, #f7fbff 0%, #ffffff 58%, #edf5ff 100%);
}
.ops-household-split .ops-grid-2 { align-items: center; }
.ops-photo-frame--tall img { min-height: 520px; object-fit: cover; }
.ops-check-list { display: grid; gap: 13px; margin-top: 24px; }
.ops-check-list span {
  display: flex;
  align-items: center;
  gap: 12px;
  padding: 15px 16px;
  background: var(--ops-white);
  border: 1px solid var(--ops-line);
  border-radius: 14px;
  box-shadow: var(--ops-shadow-soft);
  color: var(--ops-navy);
  font-weight: 800;
}
.ops-check-list span:before {
  content: "✓";
  width: 28px;
  height: 28px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  flex: 0 0 auto;
  border-radius: 50%;
  background: var(--ops-blue-3);
  color: var(--ops-blue);
}
.ops-card-grid--blue article {
  background: linear-gradient(180deg, #ffffff, #f5f9ff);
  border-top: 4px solid var(--ops-blue);
}
.ops-focus--three { grid-template-columns: repeat(3, minmax(0, 1fr)); }
.ops-focus--three .ops-focus-card { min-height: 255px; }
.ops-services-mosaic {
  display: grid;
  grid-template-columns: 1.05fr .95fr;
  grid-template-rows: 170px 170px;
  gap: 14px;
}
.ops-services-mosaic img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  border-radius: 18px;
  box-shadow: var(--ops-shadow-soft);
  border: 1px solid rgba(255,255,255,.8);
}
.ops-services-mosaic img:first-child { grid-row: span 2; }
.ops-portfolio-overview--page { padding-top: 66px; }
.ops-portfolio-grid--services { grid-template-columns: repeat(3, minmax(0, 1fr)); }
.ops-portfolio-grid--services .ops-portfolio-card { min-height: 260px; }
.ops-service-strip { padding: 34px 0; }
.ops-service-strip__inner {
  display: flex;
  justify-content: space-between;
  align-items: center;
  gap: 22px;
  padding: 24px 28px;
  border-radius: 18px;
  background: var(--ops-white);
  border: 1px solid var(--ops-line);
  box-shadow: var(--ops-shadow-soft);
}
.ops-service-strip__inner strong { display: block; color: var(--ops-navy); font-size: 24px; margin-bottom: 4px; }
.ops-service-strip__inner span { color: var(--ops-muted); }

@media (max-width: 980px) {
  .ops-focus--three,
  .ops-portfolio-grid--services { grid-template-columns: 1fr; }
  .ops-services-mosaic { grid-template-rows: 150px 150px; }
  .ops-photo-frame--tall img { min-height: 360px; }
  .ops-service-strip__inner { flex-direction: column; align-items: flex-start; }
}
@media (max-width: 640px) {
  .ops-services-mosaic { grid-template-columns: 1fr; grid-template-rows: repeat(4, 150px); }
  .ops-services-mosaic img:first-child { grid-row: auto; }
}


/* V20: Prozesskern-naehere Intro-Sequenz ohne Ueberlagerung von Logo und Leistungsbegriffen */
.ops-intro-splash--portfolio {
  background: #061d42;
}
.ops-intro-splash--portfolio:after {
  background:
    radial-gradient(circle at 50% 32%, rgba(255,255,255,.18), rgba(6,29,66,.32) 34%, rgba(6,29,66,.94) 100%),
    linear-gradient(90deg, rgba(6,29,66,.95), rgba(13,92,171,.48), rgba(6,29,66,.94));
}
.ops-intro-stage {
  width: min(1120px, calc(100% - 36px));
  min-height: min(620px, 84vh);
  display: grid;
  grid-template-rows: 1fr auto 1fr;
  align-items: center;
  justify-items: center;
  gap: clamp(20px, 4vh, 38px);
}
.ops-intro-main {
  grid-row: 2;
  width: min(680px, 100%);
  display: grid;
  justify-items: center;
  gap: 18px;
  text-align: center;
  z-index: 3;
}
.ops-intro-splash--portfolio .ops-intro-splash__logo {
  width: min(460px, 80vw);
  max-height: 138px;
  padding: 22px 32px;
  border-radius: 24px;
  background: rgba(255,255,255,.96);
  box-shadow: 0 34px 90px rgba(0,0,0,.30);
  animation: opsIntroLogoFromTop .90s cubic-bezier(.16,.84,.22,1) .10s forwards;
}
.ops-intro-splash--portfolio .ops-intro-splash__line {
  margin: 0;
  color: #fff;
  font-size: clamp(22px, 3.2vw, 42px);
  font-weight: 950;
  letter-spacing: -.04em;
  line-height: 1.08;
  text-shadow: 0 8px 26px rgba(0,0,0,.36);
  animation-delay: .78s;
}
.ops-intro-modules {
  grid-row: 3;
  align-self: start;
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
  gap: 12px;
  width: min(1020px, 100%);
  z-index: 3;
}
.ops-intro-module {
  display: inline-flex;
  align-items: center;
  min-height: 48px;
  padding: 11px 18px;
  border-radius: 999px;
  background: rgba(255,255,255,.94);
  border: 1px solid rgba(255,255,255,.58);
  box-shadow: 0 18px 45px rgba(0,0,0,.22);
  color: var(--ops-navy);
  font-size: clamp(15px, 1.55vw, 20px);
  font-weight: 950;
  letter-spacing: -.02em;
  opacity: 0;
  transform: translateY(28px);
  filter: blur(5px);
  animation: opsIntroModuleUp .55s cubic-bezier(.18,.84,.24,1) forwards;
}
.ops-intro-module:before {
  content: "";
  width: 9px;
  height: 9px;
  border-radius: 50%;
  background: var(--ops-blue);
  margin-right: 10px;
  box-shadow: 0 0 0 5px rgba(13,92,171,.12);
}
.ops-intro-module:nth-child(1) { animation-delay: 1.22s; }
.ops-intro-module:nth-child(2) { animation-delay: 1.38s; }
.ops-intro-module:nth-child(3) { animation-delay: 1.54s; }
.ops-intro-module:nth-child(4) { animation-delay: 1.70s; }
.ops-intro-module:nth-child(5) { animation-delay: 1.86s; }
.ops-intro-module:nth-child(6) { animation-delay: 2.02s; }
.ops-intro-word { display: none !important; }
@keyframes opsIntroLogoFromTop {
  0% { opacity: 0; transform: translateY(-48px) scale(.96); filter: blur(7px); }
  70% { opacity: 1; filter: blur(0); }
  100% { opacity: 1; transform: translateY(0) scale(1); filter: blur(0); }
}
@keyframes opsIntroModuleUp {
  to { opacity: 1; transform: translateY(0); filter: blur(0); }
}
@media (max-width: 760px) {
  .ops-intro-stage {
    min-height: 540px;
    gap: 18px;
  }
  .ops-intro-main { gap: 14px; }
  .ops-intro-splash--portfolio .ops-intro-splash__logo {
    width: min(330px, 78vw);
    padding: 18px 22px;
    border-radius: 20px;
  }
  .ops-intro-splash--portfolio .ops-intro-splash__line {
    font-size: clamp(22px, 8vw, 34px);
  }
  .ops-intro-modules {
    gap: 8px;
    max-width: 360px;
  }
  .ops-intro-module {
    min-height: 38px;
    padding: 8px 12px;
    font-size: 13px;
  }
}
@media (prefers-reduced-motion: reduce) {
  .ops-intro-module,
  .ops-intro-splash--portfolio .ops-intro-splash__logo,
  .ops-intro-splash--portfolio .ops-intro-splash__line {
    opacity: 1 !important;
    transform: none !important;
    filter: none !important;
    animation: none !important;
  }
}


/* V21: Mobile Gesamtpruefung - Ansprechpartner, Navigation, Bilder und Formulare sauber stapeln */
.ops-person-card__links a { white-space: nowrap; }
.ops-person-card__image img { object-position: center center; }
.ops-person-card:first-child .ops-person-card__image img { object-position: 46% center; }
.ops-person-card:nth-child(2) .ops-person-card__image img { object-position: 52% center; }

@media (max-width: 1100px) {
  body.ops-nav-open { overflow: hidden; }
  body.ops-nav-open .ops-nav {
    display: grid;
    position: fixed;
    z-index: 90;
    left: 14px;
    right: 14px;
    top: 86px;
    gap: 0;
    padding: 12px;
    border: 1px solid var(--ops-line);
    border-radius: 18px;
    background: rgba(255,255,255,.98);
    box-shadow: var(--ops-shadow);
    backdrop-filter: blur(12px);
  }
  body.ops-nav-open .ops-nav a {
    display: block;
    padding: 15px 14px;
    border-bottom: 1px solid var(--ops-line);
    color: var(--ops-navy);
    font-size: 16px;
  }
  body.ops-nav-open .ops-nav a:last-child { border-bottom: 0; }
  body.ops-nav-open .ops-mobile-toggle { background: var(--ops-blue); color: #fff; border-color: var(--ops-blue); }
}

@media (max-width: 920px) {
  body { padding-bottom: 58px; }
  .ops-section { padding: 46px 0; }
  .ops-people__head { display: block; }
  .ops-people__head p { margin-top: 10px; max-width: none; }
  .ops-people__grid { grid-template-columns: 1fr; gap: 18px; }
  .ops-person-card {
    grid-template-columns: minmax(220px, 38%) 1fr;
    min-height: 260px;
  }
  .ops-person-card__copy { padding: 24px; }
  .ops-person-card__copy h3 { font-size: 26px; }
  .ops-person-card__image img { height: 100%; }
  .ops-feature-card,
  .ops-focus-card,
  .ops-portfolio-card,
  .ops-target,
  .ops-form-card,
  .ops-cta-strip,
  .ops-service-strip__inner { border-radius: 16px; }
  .ops-portfolio-card--large { min-height: 250px; }
  .ops-form-card { padding: 22px; }
}

@media (max-width: 700px) {
  .ops-container { width: min(100% - 24px, 620px); }
  .ops-header__inner { min-height: 72px; gap: 10px; }
  .ops-brand img { width: 188px; max-height: 58px; }
  body.ops-nav-open .ops-nav { top: 78px; }

  .ops-hero__copy { padding: 34px 0 24px; }
  .ops-hero h1 { font-size: clamp(34px, 10vw, 44px); letter-spacing: -.045em; }
  .ops-hero__lead { font-size: clamp(24px, 7vw, 31px); }
  .ops-hero__text { font-size: 16px; line-height: 1.55; }
  .ops-hero__photo { min-height: 260px; }
  .ops-hero-stack { min-height: 330px; }
  .ops-stack-card--small { height: 110px; }

  .ops-person-card {
    display: block;
    min-height: 0;
    border-radius: 18px;
  }
  .ops-person-card__image {
    height: auto;
    aspect-ratio: 16 / 10;
    border-bottom: 1px solid var(--ops-line);
  }
  .ops-person-card__image img {
    width: 100%;
    height: 100%;
    object-fit: cover;
  }
  .ops-person-card:first-child .ops-person-card__image img { object-position: 45% 42%; }
  .ops-person-card:nth-child(2) .ops-person-card__image img { object-position: 53% 38%; }
  .ops-person-card__copy {
    padding: 22px 20px 20px;
  }
  .ops-person-card__copy span { font-size: 12px; }
  .ops-person-card__copy h3 {
    font-size: 30px;
    line-height: 1.04;
  }
  .ops-person-card__copy p { font-size: 16px; }
  .ops-person-card__links {
    display: grid;
    grid-template-columns: 1fr;
    gap: 10px;
  }
  .ops-person-card__links a {
    width: 100%;
    justify-content: center;
    min-height: 48px;
  }

  .ops-mini-card__top { min-height: 86px; }
  .ops-mini-card strong { font-size: 12.5px; }
  .ops-mini-card img { height: 112px; flex-basis: 112px; }
  .ops-focus-card div { padding: 24px; }
  .ops-focus-card h3 { font-size: 27px; }
  .ops-trust-item { padding: 16px 14px; }
  .ops-logo-row span { min-height: 62px; font-size: 15px; }
}

@media (max-width: 420px) {
  .ops-brand img { width: 164px; }
  .ops-phone, .ops-mobile-toggle { width: 44px; height: 44px; }
  .ops-person-card__image { aspect-ratio: 4 / 3; }
  .ops-person-card__copy h3 { font-size: 27px; }
  .ops-service-row { grid-template-columns: 1fr; }
  .ops-mini-card { display: grid; grid-template-columns: 1fr 1.1fr; min-height: 138px; }
  .ops-mini-card__top { min-height: 0; align-content: center; border-right: 1px solid var(--ops-line); }
  .ops-mini-card img { height: 100%; min-height: 138px; border-top: 0; }
  .ops-portfolio-card, .ops-portfolio-card--large { min-height: 185px; }
  .ops-form-card { padding: 18px; }
}

/* V22: Hero-Bild Gebaeudereinigung kopfsicher und sauber */
body:not(.ops-home-page) .ops-hero__photo img { object-position: center center; }
@media (max-width: 720px) {
  .ops-hero__photo img { object-position: center top; }
}


/* V24: Intro-Worte frei um das Logo verteilt - ohne Rahmen, ohne Chip-Hintergrund */
.ops-intro-stage {
  position: relative;
  overflow: hidden;
  min-height: min(640px, 84vh);
}
.ops-intro-main {
  position: relative;
  z-index: 5;
}
.ops-intro-modules {
  position: absolute;
  inset: 0;
  display: block;
  width: 100%;
  max-width: none;
  pointer-events: none;
  z-index: 4;
}
.ops-intro-module {
  position: absolute;
  display: inline-block;
  min-height: 0;
  padding: 0;
  border: 0;
  border-radius: 0;
  background: transparent;
  box-shadow: none;
  color: rgba(255,255,255,.96);
  font-size: clamp(18px, 2.35vw, 34px);
  font-weight: 950;
  line-height: 1.02;
  letter-spacing: -.045em;
  white-space: nowrap;
  text-shadow: 0 8px 28px rgba(0,0,0,.52), 0 0 20px rgba(13,92,171,.35);
  opacity: 0;
  filter: blur(8px);
  animation: none;
}
.ops-intro-module:before { display: none; }
.ops-intro-module:nth-child(1) {
  left: 6%; top: 38%;
  transform: translateX(-130px) rotate(-2deg) scale(.95);
  animation: opsWordFloatLeft .74s cubic-bezier(.16,.84,.22,1) 1.08s forwards;
}
.ops-intro-module:nth-child(2) {
  right: 5%; top: 38%;
  transform: translateX(130px) rotate(2deg) scale(.95);
  animation: opsWordFloatRight .74s cubic-bezier(.16,.84,.22,1) 1.34s forwards;
}
.ops-intro-module:nth-child(3) {
  right: 12%; bottom: 18%;
  transform: translate(90px, 70px) rotate(-1.5deg) scale(.92);
  animation: opsWordFloatUpRight .76s cubic-bezier(.16,.84,.22,1) 1.60s forwards;
}
.ops-intro-module:nth-child(4) {
  left: 14%; bottom: 18%;
  transform: translate(-90px, 70px) rotate(2deg) scale(.92);
  animation: opsWordFloatUpLeft .76s cubic-bezier(.16,.84,.22,1) 1.86s forwards;
}
.ops-intro-module:nth-child(5) {
  left: 21%; top: 16%;
  transform: translateY(-90px) rotate(1.8deg) scale(.9);
  animation: opsWordFloatDown .72s cubic-bezier(.16,.84,.22,1) 2.12s forwards;
}
.ops-intro-module:nth-child(6) {
  right: 18%; top: 17%;
  transform: translateY(-90px) rotate(-1.5deg) scale(.9);
  animation: opsWordFloatDown .72s cubic-bezier(.16,.84,.22,1) 2.38s forwards;
}
@keyframes opsWordFloatLeft {
  to { opacity: 1; filter: blur(0); transform: translateX(0) rotate(-2deg) scale(1); }
}
@keyframes opsWordFloatRight {
  to { opacity: 1; filter: blur(0); transform: translateX(0) rotate(2deg) scale(1); }
}
@keyframes opsWordFloatUpRight {
  to { opacity: 1; filter: blur(0); transform: translate(0,0) rotate(-1.5deg) scale(1); }
}
@keyframes opsWordFloatUpLeft {
  to { opacity: 1; filter: blur(0); transform: translate(0,0) rotate(2deg) scale(1); }
}
@keyframes opsWordFloatDown {
  to { opacity: 1; filter: blur(0); transform: translateY(0) rotate(var(--ops-word-rot, 0deg)) scale(1); }
}
.ops-intro-module:nth-child(5) { --ops-word-rot: 1.8deg; }
.ops-intro-module:nth-child(6) { --ops-word-rot: -1.5deg; }

@media (max-width: 900px) {
  .ops-intro-stage { min-height: 590px; }
  .ops-intro-module { font-size: clamp(14px, 4.2vw, 22px); }
  .ops-intro-module:nth-child(1) { left: 6%; top: 31%; }
  .ops-intro-module:nth-child(2) { right: 6%; top: 31%; }
  .ops-intro-module:nth-child(3) { right: 6%; bottom: 24%; }
  .ops-intro-module:nth-child(4) { left: 8%; bottom: 24%; }
  .ops-intro-module:nth-child(5) { left: 8%; top: 17%; }
  .ops-intro-module:nth-child(6) { right: 8%; top: 17%; }
}
@media (max-width: 560px) {
  .ops-intro-stage { min-height: 560px; }
  .ops-intro-splash--portfolio .ops-intro-splash__line { font-size: clamp(20px, 7vw, 30px); }
  .ops-intro-module { font-size: 13px; letter-spacing: -.025em; text-shadow: 0 5px 16px rgba(0,0,0,.56); }
  .ops-intro-module:nth-child(1) { left: 8%; top: 25%; }
  .ops-intro-module:nth-child(2) { right: 7%; top: 25%; }
  .ops-intro-module:nth-child(3) { right: 7%; bottom: 20%; }
  .ops-intro-module:nth-child(4) { left: 9%; bottom: 20%; }
  .ops-intro-module:nth-child(5) { left: 13%; top: 14%; }
  .ops-intro-module:nth-child(6) { right: 11%; top: 14%; }
}
@media (prefers-reduced-motion: reduce) {
  .ops-intro-module { opacity: 1 !important; transform: none !important; filter: none !important; }
}

/* V24: Intro nur beim ersten direkten Startseitenaufruf je Browser-Tab anzeigen */
body.ops-intro-skipped .ops-intro-splash { display: none !important; }
body.ops-intro-skipped.ops-home-page { overflow: auto; }


/* V26: Intro-Worte frei verteilt, ohne Selbstueberdeckung und ohne Logo/Ueberschrift zu verdecken */
.ops-intro-stage {
  position: relative;
  overflow: hidden;
  min-height: min(680px, 86vh);
  width: min(1180px, calc(100% - 44px));
  display: grid;
  place-items: center;
  padding: clamp(28px, 5vh, 56px) 0;
}
.ops-intro-main {
  position: relative;
  z-index: 8;
  width: min(720px, 74vw);
  display: grid;
  justify-items: center;
  text-align: center;
  gap: 20px;
}
.ops-intro-modules {
  position: absolute !important;
  inset: 0;
  width: 100%;
  height: 100%;
  max-width: none;
  display: block !important;
  pointer-events: none;
  z-index: 6;
}
.ops-intro-module {
  position: absolute !important;
  display: block !important;
  padding: 0 !important;
  margin: 0 !important;
  min-height: 0 !important;
  border: 0 !important;
  border-radius: 0 !important;
  background: transparent !important;
  box-shadow: none !important;
  color: rgba(255,255,255,.96) !important;
  font-size: clamp(18px, 2.15vw, 34px) !important;
  font-weight: 950 !important;
  line-height: 1.02 !important;
  letter-spacing: -.045em !important;
  white-space: nowrap;
  text-shadow: 0 10px 32px rgba(0,0,0,.60), 0 0 22px rgba(13,92,171,.38);
  opacity: 0;
  filter: blur(9px);
  transform-origin: center;
}
.ops-intro-module:before { display: none !important; }
.ops-intro-module:nth-child(1) {
  left: clamp(24px, 6vw, 82px);
  top: clamp(56px, 15vh, 118px);
  transform: translate(-150px,-22px) rotate(-4deg) scale(.92);
  animation: opsV26WordOne .82s cubic-bezier(.16,.84,.22,1) 1.00s forwards;
}
.ops-intro-module:nth-child(2) {
  right: clamp(22px, 6vw, 82px);
  top: clamp(80px, 18vh, 142px);
  transform: translate(150px,-14px) rotate(3deg) scale(.92);
  animation: opsV26WordTwo .82s cubic-bezier(.16,.84,.22,1) 1.22s forwards;
}
.ops-intro-module:nth-child(3) {
  left: clamp(28px, 5vw, 78px);
  bottom: clamp(108px, 18vh, 152px);
  transform: translate(-135px,42px) rotate(2.5deg) scale(.92);
  animation: opsV26WordThree .82s cubic-bezier(.16,.84,.22,1) 1.44s forwards;
}
.ops-intro-module:nth-child(4) {
  right: clamp(34px, 8vw, 118px);
  bottom: clamp(126px, 20vh, 172px);
  transform: translate(120px,42px) rotate(-2.5deg) scale(.92);
  animation: opsV26WordFour .82s cubic-bezier(.16,.84,.22,1) 1.66s forwards;
}
.ops-intro-module:nth-child(5) {
  left: clamp(160px, 24vw, 308px);
  top: clamp(22px, 6vh, 54px);
  transform: translateY(-110px) rotate(2deg) scale(.90);
  animation: opsV26WordFive .78s cubic-bezier(.16,.84,.22,1) 1.88s forwards;
}
.ops-intro-module:nth-child(6) {
  right: clamp(150px, 22vw, 292px);
  bottom: clamp(38px, 7vh, 74px);
  transform: translateY(112px) rotate(-2deg) scale(.90);
  animation: opsV26WordSix .78s cubic-bezier(.16,.84,.22,1) 2.10s forwards;
}
@keyframes opsV26WordOne { to { opacity: 1; filter: blur(0); transform: translate(0,0) rotate(-4deg) scale(1); } }
@keyframes opsV26WordTwo { to { opacity: 1; filter: blur(0); transform: translate(0,0) rotate(3deg) scale(1); } }
@keyframes opsV26WordThree { to { opacity: 1; filter: blur(0); transform: translate(0,0) rotate(2.5deg) scale(1); } }
@keyframes opsV26WordFour { to { opacity: 1; filter: blur(0); transform: translate(0,0) rotate(-2.5deg) scale(1); } }
@keyframes opsV26WordFive { to { opacity: 1; filter: blur(0); transform: translateY(0) rotate(2deg) scale(1); } }
@keyframes opsV26WordSix { to { opacity: 1; filter: blur(0); transform: translateY(0) rotate(-2deg) scale(1); } }

@media (max-width: 1020px) {
  .ops-intro-stage { min-height: 640px; width: min(100% - 30px, 760px); }
  .ops-intro-main { width: min(640px, 76vw); }
  .ops-intro-module { font-size: clamp(15px, 3.2vw, 24px) !important; }
  .ops-intro-module:nth-child(1) { left: 20px; top: 88px; }
  .ops-intro-module:nth-child(2) { right: 20px; top: 126px; }
  .ops-intro-module:nth-child(3) { left: 22px; bottom: 138px; }
  .ops-intro-module:nth-child(4) { right: 24px; bottom: 160px; }
  .ops-intro-module:nth-child(5) { left: 18%; top: 34px; }
  .ops-intro-module:nth-child(6) { right: 17%; bottom: 54px; }
}
@media (max-width: 640px) {
  .ops-intro-stage { min-height: 610px; width: calc(100% - 20px); padding: 18px 0; }
  .ops-intro-main { width: min(330px, 78vw); gap: 12px; }
  .ops-intro-splash--portfolio .ops-intro-splash__logo { width: min(300px, 72vw); }
  .ops-intro-splash--portfolio .ops-intro-splash__line { font-size: clamp(20px, 7vw, 30px); }
  .ops-intro-module { font-size: clamp(13px, 4.1vw, 18px) !important; letter-spacing: -.035em !important; white-space: normal; max-width: 42vw; }
  .ops-intro-module:nth-child(1) { left: 5%; top: 70px; }
  .ops-intro-module:nth-child(2) { right: 5%; top: 108px; text-align: right; }
  .ops-intro-module:nth-child(3) { left: 5%; bottom: 132px; }
  .ops-intro-module:nth-child(4) { right: 7%; bottom: 158px; text-align: right; }
  .ops-intro-module:nth-child(5) { left: 12%; top: 24px; }
  .ops-intro-module:nth-child(6) { right: 10%; bottom: 52px; text-align: right; }
}
@media (max-width: 390px) {
  .ops-intro-module { font-size: 12.5px !important; max-width: 44vw; }
  .ops-intro-module:nth-child(1) { top: 76px; }
  .ops-intro-module:nth-child(2) { top: 122px; }
  .ops-intro-module:nth-child(3) { bottom: 138px; }
  .ops-intro-module:nth-child(4) { bottom: 174px; }
}
@media (prefers-reduced-motion: reduce) {
  .ops-intro-module { opacity: 1 !important; transform: none !important; filter: none !important; animation: none !important; }
}


/* V28: Intro-Worte kollisionsfrei um das Logo verteilt.
   Keine Chips, keine Rahmen, keine Ueberdeckung von Logo oder Hauptzeile. */
.ops-intro-stage {
  min-height: min(700px, 88vh) !important;
  width: min(1240px, calc(100% - 44px)) !important;
  padding: clamp(34px, 5vh, 62px) 0 !important;
  overflow: hidden !important;
}
.ops-intro-main {
  position: relative !important;
  z-index: 10 !important;
  width: min(660px, 70vw) !important;
  margin: 0 auto !important;
  display: grid !important;
  justify-items: center !important;
  gap: 22px !important;
  text-align: center !important;
}
.ops-intro-splash--portfolio .ops-intro-splash__logo {
  width: min(480px, 44vw) !important;
  max-width: 100% !important;
}
.ops-intro-splash--portfolio .ops-intro-splash__line {
  font-size: clamp(28px, 4vw, 52px) !important;
  max-width: 900px !important;
  white-space: nowrap !important;
}
.ops-intro-modules {
  position: absolute !important;
  inset: 0 !important;
  width: 100% !important;
  height: 100% !important;
  z-index: 7 !important;
  display: block !important;
  pointer-events: none !important;
}
.ops-intro-module {
  position: absolute !important;
  display: block !important;
  max-width: 360px !important;
  padding: 0 !important;
  border: 0 !important;
  border-radius: 0 !important;
  background: transparent !important;
  box-shadow: none !important;
  white-space: nowrap !important;
  color: rgba(255,255,255,.98) !important;
  font-size: clamp(18px, 2vw, 31px) !important;
  font-weight: 950 !important;
  line-height: 1.05 !important;
  letter-spacing: -.04em !important;
  text-shadow: 0 12px 34px rgba(0,0,0,.70), 0 0 20px rgba(13,92,171,.42) !important;
  opacity: 0;
  filter: blur(9px);
  transform-origin: center;
  animation-name: opsV28WordIn !important;
  animation-duration: .82s !important;
  animation-timing-function: cubic-bezier(.16,.84,.22,1) !important;
  animation-fill-mode: forwards !important;
}
.ops-intro-module:before { display: none !important; }
/* Perimeter-Positionen: ausreichend Abstand zur Mitte und untereinander */
.ops-intro-module:nth-child(1) {
  left: clamp(36px, 5.5vw, 84px) !important;
  top: clamp(72px, 14vh, 118px) !important;
  transform: translate(-160px,-28px) rotate(-2.2deg) scale(.94) !important;
  animation-delay: 1.00s !important;
}
.ops-intro-module:nth-child(2) {
  right: clamp(36px, 5.5vw, 84px) !important;
  top: clamp(98px, 18vh, 150px) !important;
  transform: translate(160px,-20px) rotate(2.0deg) scale(.94) !important;
  text-align: right !important;
  animation-delay: 1.22s !important;
}
.ops-intro-module:nth-child(3) {
  left: clamp(50px, 8vw, 140px) !important;
  bottom: clamp(126px, 20vh, 178px) !important;
  transform: translate(-150px,44px) rotate(1.9deg) scale(.94) !important;
  animation-delay: 1.44s !important;
}
.ops-intro-module:nth-child(4) {
  right: clamp(58px, 9vw, 150px) !important;
  bottom: clamp(146px, 22vh, 200px) !important;
  transform: translate(150px,46px) rotate(-1.9deg) scale(.94) !important;
  text-align: right !important;
  animation-delay: 1.66s !important;
}
.ops-intro-module:nth-child(5) {
  left: clamp(130px, 18vw, 270px) !important;
  top: clamp(24px, 5.5vh, 58px) !important;
  transform: translateY(-120px) rotate(1.5deg) scale(.92) !important;
  animation-delay: 1.88s !important;
}
.ops-intro-module:nth-child(6) {
  right: clamp(126px, 18vw, 270px) !important;
  bottom: clamp(42px, 7vh, 80px) !important;
  transform: translateY(120px) rotate(-1.5deg) scale(.92) !important;
  text-align: right !important;
  animation-delay: 2.10s !important;
}
@keyframes opsV28WordIn {
  to { opacity: 1; filter: blur(0); transform: translate(0,0) rotate(var(--ops-v27-rot, 0deg)) scale(1); }
}
.ops-intro-module:nth-child(1) { --ops-v27-rot: -2.2deg; }
.ops-intro-module:nth-child(2) { --ops-v27-rot: 2deg; }
.ops-intro-module:nth-child(3) { --ops-v27-rot: 1.9deg; }
.ops-intro-module:nth-child(4) { --ops-v27-rot: -1.9deg; }
.ops-intro-module:nth-child(5) { --ops-v27-rot: 1.5deg; }
.ops-intro-module:nth-child(6) { --ops-v27-rot: -1.5deg; }

@media (max-width: 1020px) {
  .ops-intro-stage { min-height: 660px !important; width: min(100% - 28px, 760px) !important; }
  .ops-intro-main { width: min(560px, 74vw) !important; }
  .ops-intro-splash--portfolio .ops-intro-splash__logo { width: min(400px, 62vw) !important; }
  .ops-intro-splash--portfolio .ops-intro-splash__line { font-size: clamp(24px, 5vw, 42px) !important; white-space: normal !important; }
  .ops-intro-module { font-size: clamp(16px, 3vw, 23px) !important; max-width: 300px !important; }
  .ops-intro-module:nth-child(1) { left: 24px !important; top: 92px !important; }
  .ops-intro-module:nth-child(2) { right: 24px !important; top: 122px !important; }
  .ops-intro-module:nth-child(3) { left: 28px !important; bottom: 150px !important; }
  .ops-intro-module:nth-child(4) { right: 32px !important; bottom: 178px !important; }
  .ops-intro-module:nth-child(5) { left: 20% !important; top: 38px !important; }
  .ops-intro-module:nth-child(6) { right: 20% !important; bottom: 58px !important; }
}
@media (max-width: 640px) {
  .ops-intro-stage { min-height: 640px !important; width: calc(100% - 18px) !important; padding: 20px 0 !important; }
  .ops-intro-main { width: min(328px, 76vw) !important; gap: 12px !important; }
  .ops-intro-splash--portfolio .ops-intro-splash__logo { width: min(290px, 70vw) !important; }
  .ops-intro-splash--portfolio .ops-intro-splash__line { font-size: clamp(20px, 6.4vw, 30px) !important; }
  .ops-intro-module { font-size: clamp(12.5px, 3.8vw, 17px) !important; letter-spacing: -.035em !important; max-width: 43vw !important; white-space: normal !important; }
  .ops-intro-module:nth-child(1) { left: 5% !important; top: 68px !important; }
  .ops-intro-module:nth-child(2) { right: 5% !important; top: 112px !important; }
  .ops-intro-module:nth-child(3) { left: 5% !important; bottom: 142px !important; }
  .ops-intro-module:nth-child(4) { right: 6% !important; bottom: 180px !important; }
  .ops-intro-module:nth-child(5) { left: 10% !important; top: 22px !important; }
  .ops-intro-module:nth-child(6) { right: 9% !important; bottom: 58px !important; }
}
@media (max-width: 390px) {
  .ops-intro-stage { min-height: 650px !important; }
  .ops-intro-module { font-size: 12px !important; max-width: 44vw !important; }
  .ops-intro-module:nth-child(1) { top: 82px !important; }
  .ops-intro-module:nth-child(2) { top: 126px !important; }
  .ops-intro-module:nth-child(3) { bottom: 150px !important; }
  .ops-intro-module:nth-child(4) { bottom: 190px !important; }
}
@media (prefers-reduced-motion: reduce) {
  .ops-intro-module { opacity: 1 !important; transform: none !important; filter: none !important; animation: none !important; }
}


/* V28: saubere Textformatierung in Bild-/Portfolio-Karten
   Ziel: keine abgeschnittenen Leistungsnamen, gleiche Lesbarkeit auf Desktop und Mobil. */
.ops-portfolio-grid {
  grid-template-columns: repeat(auto-fit, minmax(218px, 1fr)) !important;
  align-items: stretch;
}
.ops-portfolio-grid--services {
  grid-template-columns: repeat(auto-fit, minmax(232px, 1fr)) !important;
}
.ops-portfolio-card {
  min-height: 210px !important;
  padding: 0 !important;
  align-items: stretch !important;
  justify-content: flex-end !important;
  border-radius: 18px !important;
}
.ops-portfolio-card--large {
  grid-column: span 2 !important;
  min-height: 285px !important;
}
.ops-portfolio-card img {
  object-fit: cover !important;
  object-position: center center !important;
}
.ops-portfolio-card:after {
  background: linear-gradient(180deg, rgba(6,29,66,.06) 0%, rgba(6,29,66,.34) 45%, rgba(6,29,66,.92) 100%) !important;
}
.ops-portfolio-card span {
  position: absolute !important;
  left: 18px !important;
  right: 18px !important;
  bottom: 16px !important;
  z-index: 3 !important;
  display: block !important;
  max-width: calc(100% - 36px) !important;
  font-size: clamp(20px, 1.45vw, 25px) !important;
  line-height: 1.02 !important;
  letter-spacing: -.035em !important;
  white-space: normal !important;
  overflow-wrap: normal !important;
  word-break: normal !important;
  hyphens: none !important;
  color: #fff !important;
  text-shadow: 0 4px 14px rgba(0,0,0,.56) !important;
}
.ops-portfolio-card--large span {
  font-size: clamp(28px, 2.25vw, 38px) !important;
  bottom: 54px !important;
}
.ops-portfolio-card strong {
  position: absolute !important;
  left: 18px !important;
  right: 18px !important;
  bottom: 18px !important;
  z-index: 3 !important;
  margin: 0 !important;
  max-width: calc(100% - 36px) !important;
}
.ops-portfolio-card br { display: block; }
@media (min-width: 1180px) {
  .ops-portfolio-grid:not(.ops-portfolio-grid--services) {
    grid-template-columns: repeat(6, minmax(0, 1fr)) !important;
  }
  .ops-portfolio-grid:not(.ops-portfolio-grid--services) .ops-portfolio-card:not(.ops-portfolio-card--large) {
    min-height: 188px !important;
  }
  .ops-portfolio-grid:not(.ops-portfolio-grid--services) .ops-portfolio-card:not(.ops-portfolio-card--large) span {
    font-size: clamp(18px, 1.2vw, 23px) !important;
    left: 14px !important;
    right: 14px !important;
    bottom: 14px !important;
    max-width: calc(100% - 28px) !important;
  }
}
@media (max-width: 760px) {
  .ops-portfolio-grid,
  .ops-portfolio-grid--services {
    grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
    gap: 12px !important;
  }
  .ops-portfolio-card,
  .ops-portfolio-card--large {
    grid-column: auto !important;
    min-height: 178px !important;
  }
  .ops-portfolio-card span,
  .ops-portfolio-card--large span {
    font-size: clamp(17px, 5vw, 22px) !important;
    left: 14px !important;
    right: 14px !important;
    bottom: 14px !important;
    max-width: calc(100% - 28px) !important;
  }
  .ops-portfolio-card strong { display: none !important; }
}
@media (max-width: 430px) {
  .ops-portfolio-grid,
  .ops-portfolio-grid--services { grid-template-columns: 1fr !important; }
  .ops-portfolio-card,
  .ops-portfolio-card--large { min-height: 205px !important; }
}


/* V30: Intro neu geloest - keine freien Kollisionsworte mehr, nur ein kontrollierter Service-Ticker */
.ops-intro-splash--portfolio {
  background: #061d42;
}
.ops-intro-splash--portfolio:after {
  background:
    radial-gradient(circle at 50% 34%, rgba(255,255,255,.18), rgba(6,29,66,.30) 34%, rgba(6,29,66,.94) 100%),
    linear-gradient(90deg, rgba(6,29,66,.96), rgba(13,92,171,.48), rgba(6,29,66,.95));
}
.ops-intro-stage {
  width: min(1120px, calc(100% - 36px)) !important;
  min-height: min(620px, 84vh) !important;
  position: relative !important;
  overflow: hidden !important;
  display: grid !important;
  place-items: center !important;
  padding: clamp(28px, 5vh, 56px) 0 !important;
}
.ops-intro-main {
  position: relative !important;
  z-index: 7 !important;
  width: min(720px, 100%) !important;
  display: grid !important;
  justify-items: center !important;
  gap: clamp(14px, 2.6vh, 24px) !important;
  text-align: center !important;
}
.ops-intro-splash--portfolio .ops-intro-splash__logo {
  width: min(460px, 80vw) !important;
  max-height: 140px !important;
  padding: 22px 32px !important;
  border-radius: 24px !important;
  background: rgba(255,255,255,.96) !important;
  box-shadow: 0 34px 90px rgba(0,0,0,.30) !important;
  opacity: 0;
  transform: translateY(-34px) scale(.96);
  animation: opsV30LogoIn .90s cubic-bezier(.16,.84,.22,1) .12s forwards !important;
}
.ops-intro-splash--portfolio .ops-intro-splash__line {
  position: relative !important;
  z-index: 8 !important;
  margin: 0 !important;
  color: #fff !important;
  font-size: clamp(28px, 4vw, 54px) !important;
  font-weight: 950 !important;
  letter-spacing: -.045em !important;
  line-height: 1.06 !important;
  text-shadow: 0 8px 26px rgba(0,0,0,.36) !important;
  opacity: 0;
  transform: translateY(18px);
  animation: opsV30LineIn .72s ease .82s forwards !important;
}
.ops-intro-modules {
  position: relative !important;
  inset: auto !important;
  z-index: 8 !important;
  width: min(820px, 92vw) !important;
  height: clamp(54px, 8vh, 76px) !important;
  display: block !important;
  pointer-events: none !important;
  margin-top: 2px !important;
  overflow: visible !important;
}
.ops-intro-module,
.ops-intro-module:nth-child(n) {
  position: absolute !important;
  left: 50% !important;
  top: 50% !important;
  right: auto !important;
  bottom: auto !important;
  display: block !important;
  min-height: 0 !important;
  padding: 0 !important;
  border: 0 !important;
  border-radius: 0 !important;
  background: transparent !important;
  box-shadow: none !important;
  color: rgba(255,255,255,.98) !important;
  font-size: clamp(21px, 3vw, 38px) !important;
  font-weight: 950 !important;
  line-height: 1.05 !important;
  letter-spacing: -.045em !important;
  white-space: nowrap !important;
  text-align: center !important;
  text-shadow: 0 8px 28px rgba(0,0,0,.52), 0 0 22px rgba(13,92,171,.35) !important;
  opacity: 0;
  filter: blur(5px);
  transform: translate(-50%, calc(-50% + 28px)) scale(.94) !important;
  animation: opsV30ServiceTicker 5.25s cubic-bezier(.16,.84,.22,1) forwards !important;
}
.ops-intro-module:before { display: none !important; }
.ops-intro-module:nth-child(1) { animation-delay: 1.22s !important; }
.ops-intro-module:nth-child(2) { animation-delay: 1.80s !important; }
.ops-intro-module:nth-child(3) { animation-delay: 2.38s !important; }
.ops-intro-module:nth-child(4) { animation-delay: 2.96s !important; }
.ops-intro-module:nth-child(5) { animation-delay: 3.54s !important; }
.ops-intro-module:nth-child(6) { animation-delay: 4.12s !important; }
@keyframes opsV30LogoIn {
  0% { opacity: 0; transform: translateY(-34px) scale(.96); filter: blur(7px); }
  100% { opacity: 1; transform: translateY(0) scale(1); filter: blur(0); }
}
@keyframes opsV30LineIn {
  to { opacity: 1; transform: translateY(0); }
}
@keyframes opsV30ServiceTicker {
  0% { opacity: 0; filter: blur(6px); transform: translate(-50%, calc(-50% + 30px)) scale(.94); }
  7% { opacity: 1; filter: blur(0); transform: translate(-50%, -50%) scale(1); }
  16% { opacity: 1; filter: blur(0); transform: translate(-50%, -50%) scale(1); }
  24% { opacity: 0; filter: blur(5px); transform: translate(-50%, calc(-50% - 22px)) scale(.98); }
  100% { opacity: 0; filter: blur(5px); transform: translate(-50%, calc(-50% - 22px)) scale(.98); }
}
@media (max-width: 760px) {
  .ops-intro-stage { min-height: 540px !important; width: min(100%, calc(100% - 24px)) !important; }
  .ops-intro-splash--portfolio .ops-intro-splash__logo { width: min(330px, 80vw) !important; padding: 18px 22px !important; border-radius: 20px !important; }
  .ops-intro-splash--portfolio .ops-intro-splash__line { font-size: clamp(25px, 8vw, 38px) !important; }
  .ops-intro-modules { width: min(360px, 90vw) !important; height: 70px !important; }
  .ops-intro-module, .ops-intro-module:nth-child(n) { font-size: clamp(20px, 7.2vw, 30px) !important; white-space: normal !important; width: 100% !important; }
}
@media (prefers-reduced-motion: reduce) {
  .ops-intro-module, .ops-intro-splash--portfolio .ops-intro-splash__logo, .ops-intro-splash--portfolio .ops-intro-splash__line {
    animation: none !important; opacity: 1 !important; transform: translate(-50%, -50%) !important; filter: none !important;
  }
  .ops-intro-module:not(:first-child) { display: none !important; }
  .ops-intro-splash--portfolio .ops-intro-splash__logo,
  .ops-intro-splash--portfolio .ops-intro-splash__line { transform: none !important; }
}

/* V30: professionelle Bild-/Textkarten auf allen Portfolio- und Leistungsseiten.
   Ziel: keine ueberlappenden Texte, keine abgeschnittenen Titel, einheitliche Bildhoehen. */
.ops-portfolio-overview,
.ops-portfolio-overview--page {
  overflow: visible !important;
}
.ops-portfolio-grid,
.ops-portfolio-grid--services {
  display: grid !important;
  grid-template-columns: repeat(4, minmax(0, 1fr)) !important;
  gap: 22px !important;
  align-items: stretch !important;
}
.ops-portfolio-grid--services {
  grid-template-columns: repeat(3, minmax(0, 1fr)) !important;
}
.ops-portfolio-card,
.ops-portfolio-card--large {
  display: flex !important;
  flex-direction: column !important;
  justify-content: flex-start !important;
  align-items: stretch !important;
  grid-column: auto !important;
  min-height: 0 !important;
  height: auto !important;
  padding: 0 !important;
  overflow: hidden !important;
  border-radius: 18px !important;
  background: #fff !important;
  color: var(--ops-navy) !important;
  border: 1px solid var(--ops-line) !important;
  box-shadow: 0 18px 42px rgba(6, 29, 66, .10) !important;
  text-decoration: none !important;
}
.ops-portfolio-card--large {
  grid-column: span 2 !important;
}
.ops-portfolio-card:after,
.ops-portfolio-card:before {
  display: none !important;
}
.ops-portfolio-card img,
.ops-portfolio-card--large img {
  position: relative !important;
  inset: auto !important;
  z-index: auto !important;
  display: block !important;
  width: 100% !important;
  height: 185px !important;
  aspect-ratio: auto !important;
  object-fit: cover !important;
  object-position: center center !important;
  border: 0 !important;
  border-bottom: 1px solid var(--ops-line) !important;
  transform: none !important;
  transition: transform .22s ease, filter .22s ease !important;
}
.ops-portfolio-card--large img {
  height: 250px !important;
}
.ops-portfolio-card:hover img {
  transform: scale(1.025) !important;
  filter: saturate(1.03) contrast(1.02) !important;
}
.ops-portfolio-card span,
.ops-portfolio-card--large span {
  position: relative !important;
  left: auto !important;
  right: auto !important;
  top: auto !important;
  bottom: auto !important;
  z-index: auto !important;
  display: block !important;
  max-width: none !important;
  width: auto !important;
  margin: 0 !important;
  padding: 18px 18px 0 !important;
  color: var(--ops-navy) !important;
  text-shadow: none !important;
  font-size: clamp(21px, 1.35vw, 27px) !important;
  font-weight: 950 !important;
  letter-spacing: -.035em !important;
  line-height: 1.08 !important;
  white-space: normal !important;
  overflow: visible !important;
  overflow-wrap: normal !important;
  word-break: normal !important;
  hyphens: none !important;
}
.ops-portfolio-card--large span {
  font-size: clamp(30px, 2.25vw, 40px) !important;
  padding: 22px 22px 0 !important;
}
.ops-portfolio-card strong,
.ops-portfolio-card--large strong {
  position: relative !important;
  left: auto !important;
  right: auto !important;
  top: auto !important;
  bottom: auto !important;
  z-index: auto !important;
  display: block !important;
  max-width: none !important;
  width: auto !important;
  margin: 0 !important;
  padding: 8px 18px 22px !important;
  color: var(--ops-muted) !important;
  text-shadow: none !important;
  font-size: 15px !important;
  font-weight: 800 !important;
  line-height: 1.35 !important;
}
.ops-portfolio-card--large strong {
  padding: 9px 22px 24px !important;
  font-size: 16px !important;
}
.ops-portfolio-card br { display: none !important; }

/* Bildausrichtung je Karte: kopfsicher und ruhig */
.ops-portfolio-grid > .ops-portfolio-card:nth-child(1) img { object-position: 52% 33% !important; }
.ops-portfolio-grid > .ops-portfolio-card:nth-child(2) img { object-position: 54% 36% !important; }
.ops-portfolio-grid > .ops-portfolio-card:nth-child(3) img { object-position: center center !important; }
.ops-portfolio-grid > .ops-portfolio-card:nth-child(4) img { object-position: 55% 36% !important; }
.ops-portfolio-grid > .ops-portfolio-card:nth-child(5) img { object-position: 48% 52% !important; }
.ops-portfolio-grid > .ops-portfolio-card:nth-child(6) img { object-position: 50% 48% !important; }
.ops-portfolio-grid > .ops-portfolio-card:nth-child(7) img { object-position: 56% 45% !important; }
.ops-portfolio-grid > .ops-portfolio-card:nth-child(8) img { object-position: 46% 50% !important; }
.ops-portfolio-grid > .ops-portfolio-card:nth-child(9) img { object-position: 50% 38% !important; }

/* Zusatzkarten und Fokusbereiche: keine Texteinblendung abschneiden */
.ops-focus-card,
.ops-target,
.ops-solar-target {
  overflow: hidden;
}
.ops-focus-card h3,
.ops-target h3,
.ops-solar-target h3 {
  overflow-wrap: normal;
  word-break: normal;
  hyphens: none;
}
.ops-focus-card div {
  max-width: min(520px, calc(100% - 24px));
}

/* Leistungen-Mini-Karten: einheitlicher Zuschnitt und keine Textquetschung */
.ops-mini-card strong {
  overflow: visible !important;
  text-overflow: clip !important;
  white-space: normal !important;
  word-break: normal !important;
  hyphens: none !important;
}
.ops-mini-card img {
  object-position: center center !important;
}
.ops-service-row .ops-mini-card:nth-child(2) img { object-position: 55% 37% !important; }
.ops-service-row .ops-mini-card:nth-child(3) img { object-position: 48% 52% !important; }
.ops-service-row .ops-mini-card:nth-child(4) img { object-position: 50% 48% !important; }
.ops-service-row .ops-mini-card:nth-child(5) img { object-position: 56% 45% !important; }
.ops-service-row .ops-mini-card:nth-child(7) img { object-position: 50% 38% !important; }

@media (max-width: 1180px) {
  .ops-portfolio-grid,
  .ops-portfolio-grid--services {
    grid-template-columns: repeat(3, minmax(0, 1fr)) !important;
  }
  .ops-portfolio-card--large { grid-column: span 3 !important; }
  .ops-portfolio-card--large img { height: 285px !important; }
}
@media (max-width: 820px) {
  .ops-portfolio-grid,
  .ops-portfolio-grid--services {
    grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
    gap: 16px !important;
  }
  .ops-portfolio-card--large { grid-column: span 2 !important; }
  .ops-portfolio-card img { height: 170px !important; }
  .ops-portfolio-card--large img { height: 220px !important; }
  .ops-portfolio-card span { font-size: clamp(19px, 4.2vw, 25px) !important; padding: 16px 16px 0 !important; }
  .ops-portfolio-card strong { padding: 7px 16px 18px !important; }
}
@media (max-width: 520px) {
  .ops-portfolio-grid,
  .ops-portfolio-grid--services {
    grid-template-columns: 1fr !important;
  }
  .ops-portfolio-card--large { grid-column: auto !important; }
  .ops-portfolio-card img,
  .ops-portfolio-card--large img { height: 205px !important; }
  .ops-portfolio-card--large span { font-size: clamp(25px, 7vw, 32px) !important; }
}

/* V31: Professionelles Intro ohne ueberlappende Freitext-Worte */
body.ops-intro-active {
  overflow: hidden;
}
.ops-intro-splash {
  position: fixed;
  inset: 0;
  z-index: 2147483000;
  width: 100vw;
  height: 100vh;
  height: 100dvh;
  overflow: hidden;
  display: flex;
  align-items: center;
  justify-content: center;
  padding: clamp(18px, 3vw, 42px);
  background: #061d42;
  color: #fff;
  isolation: isolate;
}
.ops-intro-splash--portfolio {
  overflow: hidden;
  background:
    radial-gradient(circle at 50% 28%, rgba(55,142,224,.34), rgba(6,29,66,.82) 42%, rgba(6,29,66,.98) 100%),
    #061d42;
}
.ops-intro-splash--portfolio:after {
  content: "";
  position: absolute;
  inset: 0;
  z-index: 1;
  pointer-events: none;
  background:
    linear-gradient(90deg, rgba(6,29,66,.96), rgba(6,29,66,.68) 38%, rgba(6,29,66,.72) 63%, rgba(6,29,66,.98)),
    radial-gradient(circle at 50% 42%, rgba(255,255,255,.16), transparent 36%);
}
.ops-intro-bg {
  position: absolute;
  inset: -3%;
  z-index: 0;
  opacity: 0;
  background-size: cover;
  background-position: center;
  transform: scale(1.05);
  filter: saturate(.9) contrast(1.02);
  animation: opsIntroBgSequence 5.4s ease-in-out both;
}
.ops-intro-bg--cleaning { animation-delay: 0s; opacity: .44; }
.ops-intro-bg--household { animation-delay: 1.05s; }
.ops-intro-bg--solar { animation-delay: 2.10s; }
.ops-intro-bg--glass { animation-delay: 3.15s; }
.ops-intro-bg--winter { animation-delay: 4.20s; }
@keyframes opsIntroBgSequence {
  0%, 17% { opacity: .42; transform: scale(1.05); }
  24%, 100% { opacity: 0; transform: scale(1.09); }
}
.ops-intro-stage,
.ops-intro-splash__card.ops-intro-stage {
  position: relative;
  z-index: 3;
  width: min(980px, calc(100vw - 40px));
  min-height: auto;
  display: grid;
  grid-template-rows: auto auto auto;
  justify-items: center;
  align-items: center;
  gap: clamp(18px, 3vh, 28px);
  text-align: center;
  padding: 0;
  overflow: visible;
}
.ops-intro-main {
  width: min(760px, 100%);
  display: grid;
  justify-items: center;
  gap: clamp(14px, 2.4vh, 22px);
  text-align: center;
}
.ops-intro-splash--portfolio .ops-intro-splash__logo,
.ops-intro-splash__logo {
  width: min(430px, 78vw);
  max-height: 140px;
  object-fit: contain;
  padding: clamp(16px, 2.2vw, 24px) clamp(22px, 3vw, 36px);
  border-radius: clamp(20px, 2.5vw, 30px);
  background: rgba(255,255,255,.96);
  box-shadow: 0 34px 90px rgba(0,0,0,.34);
  opacity: 0;
  transform: translateY(-32px) scale(.97);
  filter: blur(7px);
  animation: opsIntroLogoClean .82s cubic-bezier(.16,.84,.22,1) .10s forwards;
}
.ops-intro-splash--portfolio .ops-intro-splash__line,
.ops-intro-splash__line {
  color: #fff;
  margin: 0;
  font-size: clamp(25px, 4.1vw, 58px);
  line-height: 1.02;
  font-weight: 950;
  letter-spacing: -.045em;
  text-shadow: 0 12px 28px rgba(0,0,0,.42);
  opacity: 0;
  transform: translateY(18px);
  animation: opsIntroTitleClean .55s ease .70s forwards;
}
.ops-intro-modules {
  position: relative;
  width: min(760px, calc(100vw - 48px));
  height: clamp(46px, 7vh, 66px);
  display: block;
  z-index: 4;
  margin: 0 auto;
  overflow: hidden;
}
.ops-intro-module,
.ops-intro-module:nth-child(n) {
  position: absolute;
  inset: 0;
  display: flex;
  align-items: center;
  justify-content: center;
  width: 100%;
  min-height: 0;
  padding: 0 14px;
  border: 0;
  border-radius: 0;
  background: transparent;
  box-shadow: none;
  color: #fff;
  font-size: clamp(20px, 3.2vw, 42px);
  line-height: 1.08;
  font-weight: 950;
  letter-spacing: -.035em;
  text-align: center;
  white-space: normal;
  opacity: 0;
  transform: translateY(18px) scale(.98);
  filter: blur(7px);
  text-shadow: 0 9px 28px rgba(0,0,0,.48);
  animation-name: opsIntroServiceOne;
  animation-duration: .88s;
  animation-timing-function: cubic-bezier(.16,.84,.22,1);
  animation-fill-mode: both;
}
.ops-intro-module:before { display: none !important; content: none !important; }
.ops-intro-module:nth-child(1) { animation-delay: 1.15s; }
.ops-intro-module:nth-child(2) { animation-delay: 1.78s; }
.ops-intro-module:nth-child(3) { animation-delay: 2.41s; }
.ops-intro-module:nth-child(4) { animation-delay: 3.04s; }
.ops-intro-module:nth-child(5) { animation-delay: 3.67s; }
.ops-intro-module:nth-child(6) { animation-delay: 4.30s; }
.ops-intro-module:after {
  content: "";
  position: absolute;
  left: 50%;
  bottom: -7px;
  width: min(220px, 42vw);
  height: 3px;
  border-radius: 999px;
  background: linear-gradient(90deg, transparent, rgba(255,255,255,.78), transparent);
  transform: translateX(-50%);
  opacity: .72;
}
.ops-intro-word { display: none !important; }
@keyframes opsIntroLogoClean {
  0% { opacity: 0; transform: translateY(-32px) scale(.97); filter: blur(7px); }
  70% { opacity: 1; filter: blur(0); }
  100% { opacity: 1; transform: translateY(0) scale(1); filter: blur(0); }
}
@keyframes opsIntroTitleClean {
  to { opacity: 1; transform: translateY(0); }
}
@keyframes opsIntroServiceOne {
  0% { opacity: 0; transform: translateY(20px) scale(.97); filter: blur(7px); }
  22% { opacity: 1; transform: translateY(0) scale(1); filter: blur(0); }
  72% { opacity: 1; transform: translateY(0) scale(1); filter: blur(0); }
  100% { opacity: 0; transform: translateY(-14px) scale(1.02); filter: blur(5px); }
}
body.ops-intro-done .ops-intro-splash {
  opacity: 0;
  visibility: hidden;
  pointer-events: none;
}
@media (max-width: 760px) {
  .ops-intro-splash { padding: 18px; }
  .ops-intro-stage,
  .ops-intro-splash__card.ops-intro-stage { width: calc(100vw - 28px); gap: 18px; }
  .ops-intro-splash--portfolio .ops-intro-splash__logo,
  .ops-intro-splash__logo { width: min(310px, 82vw); padding: 16px 22px; border-radius: 22px; }
  .ops-intro-splash--portfolio .ops-intro-splash__line,
  .ops-intro-splash__line { font-size: clamp(28px, 9vw, 42px); max-width: 10ch; }
  .ops-intro-modules { width: calc(100vw - 36px); height: 58px; }
  .ops-intro-module { font-size: clamp(20px, 7.4vw, 34px); padding: 0 8px; }
}
@media (max-width: 420px) {
  .ops-intro-splash--portfolio .ops-intro-splash__line,
  .ops-intro-splash__line { font-size: clamp(25px, 8.6vw, 34px); }
  .ops-intro-module { font-size: clamp(18px, 6.4vw, 27px); }
}
@media (prefers-reduced-motion: reduce) {
  .ops-intro-bg,
  .ops-intro-module,
  .ops-intro-splash__logo,
  .ops-intro-splash__line {
    animation: none !important;
    opacity: 1 !important;
    transform: none !important;
    filter: none !important;
  }
  .ops-intro-module:not(:first-child) { display: none; }
}


/* V32: Einheitliche Unterseiten-Layouts, stabile Karten, keine Text-/Bildueberlagerung */
body:not(.ops-home-page) .ops-hero {
  background: linear-gradient(120deg, #ffffff 0%, #f7fbff 56%, #eef6ff 100%) !important;
  padding: clamp(38px, 5vw, 72px) 0 clamp(34px, 4.2vw, 58px) !important;
  overflow: hidden !important;
}
body:not(.ops-home-page) .ops-hero__grid {
  display: grid !important;
  grid-template-columns: minmax(0, 1fr) minmax(420px, .92fr) !important;
  align-items: center !important;
  gap: clamp(34px, 4.5vw, 76px) !important;
  min-height: auto !important;
}
body:not(.ops-home-page) .ops-hero__copy {
  padding: 0 !important;
}
body:not(.ops-home-page) .ops-hero h1 {
  max-width: 720px !important;
  font-size: clamp(46px, 5.6vw, 82px) !important;
  line-height: .98 !important;
  letter-spacing: -.055em !important;
}
body:not(.ops-home-page) .ops-hero__text {
  max-width: 640px !important;
  font-size: clamp(17px, 1.35vw, 22px) !important;
  line-height: 1.65 !important;
}
body:not(.ops-home-page) .ops-hero__photo {
  min-height: 0 !important;
  height: auto !important;
  margin: 0 !important;
  border-radius: 28px !important;
  overflow: hidden !important;
  background: #eef5fc !important;
  border: 1px solid #cfe0f5 !important;
  box-shadow: 0 24px 70px rgba(6,29,66,.16) !important;
}
body:not(.ops-home-page) .ops-hero__photo:before {
  display: none !important;
}
body:not(.ops-home-page) .ops-hero__photo img {
  display: block !important;
  width: 100% !important;
  height: auto !important;
  aspect-ratio: 4 / 3 !important;
  object-fit: cover !important;
  object-position: center center !important;
}
body.page-template-default .ops-hero__photo img,
body:not(.ops-home-page) .ops-hero .ops-hero__photo img[alt*="Gebäudereinigung"] {
  object-position: center center !important;
}
body:not(.ops-home-page) .ops-trustbar--dark {
  margin-top: 0 !important;
  padding: 0 0 18px !important;
  background: #fff !important;
}
body:not(.ops-home-page) .ops-trustbar--dark .ops-trustbar__inner {
  transform: none !important;
  margin-top: 0 !important;
  margin-bottom: 0 !important;
  border-radius: 16px !important;
}

/* Karten: Text unter dem Bild, nie mehr im Bild abgeschnitten */
.ops-portfolio-grid,
.ops-portfolio-grid--services {
  display: grid !important;
  grid-template-columns: repeat(4, minmax(210px, 1fr)) !important;
  gap: 22px !important;
  align-items: stretch !important;
}
.ops-portfolio-card,
.ops-portfolio-card--large {
  grid-column: auto !important;
  min-height: 0 !important;
  display: flex !important;
  flex-direction: column !important;
  justify-content: flex-start !important;
  overflow: hidden !important;
  border-radius: 22px !important;
  background: #fff !important;
  color: var(--ops-navy) !important;
  border: 1px solid #cfe0f5 !important;
  box-shadow: 0 18px 42px rgba(6,29,66,.08) !important;
  text-decoration: none !important;
}
.ops-portfolio-card:before,
.ops-portfolio-card:after,
.ops-portfolio-card--large:before,
.ops-portfolio-card--large:after {
  display: none !important;
  content: none !important;
}
.ops-portfolio-card img,
.ops-portfolio-card--large img {
  position: static !important;
  inset: auto !important;
  display: block !important;
  width: 100% !important;
  height: 210px !important;
  aspect-ratio: auto !important;
  object-fit: cover !important;
  object-position: center center !important;
  transform: none !important;
  opacity: 1 !important;
  filter: none !important;
}
.ops-portfolio-card--large img { height: 240px !important; }
.ops-portfolio-card span,
.ops-portfolio-card--large span {
  position: static !important;
  display: block !important;
  width: auto !important;
  max-width: none !important;
  padding: 18px 20px 4px !important;
  margin: 0 !important;
  color: var(--ops-navy) !important;
  font-size: clamp(22px, 2vw, 30px) !important;
  line-height: 1.05 !important;
  letter-spacing: -.035em !important;
  font-weight: 950 !important;
  white-space: normal !important;
  overflow-wrap: anywhere !important;
  text-shadow: none !important;
}
.ops-portfolio-card--large span { font-size: clamp(28px, 3vw, 42px) !important; }
.ops-portfolio-card strong,
.ops-portfolio-card--large strong {
  position: static !important;
  display: block !important;
  padding: 6px 20px 20px !important;
  margin: 0 !important;
  color: var(--ops-muted) !important;
  font-size: 16px !important;
  line-height: 1.35 !important;
  text-shadow: none !important;
  white-space: normal !important;
  overflow-wrap: normal !important;
}
.ops-portfolio-card br { display: none !important; }
.ops-portfolio-card:hover img { transform: none !important; }
.ops-portfolio-grid > .ops-portfolio-card:nth-child(1) img,
.ops-portfolio-grid > .ops-portfolio-card:nth-child(2) img,
.ops-portfolio-grid > .ops-portfolio-card:nth-child(4) img,
.ops-portfolio-grid > .ops-portfolio-card:nth-child(5) img,
.ops-portfolio-grid > .ops-portfolio-card:nth-child(6) img,
.ops-portfolio-grid > .ops-portfolio-card:nth-child(7) img,
.ops-portfolio-grid > .ops-portfolio-card:nth-child(8) img,
.ops-portfolio-grid > .ops-portfolio-card:nth-child(9) img {
  object-position: center center !important;
}

@media (min-width: 1080px) {
  .ops-portfolio-overview:not(.ops-portfolio-overview--page) .ops-portfolio-card--large {
    grid-column: span 2 !important;
  }
}
@media (max-width: 1120px) {
  body:not(.ops-home-page) .ops-hero__grid {
    grid-template-columns: 1fr !important;
  }
  body:not(.ops-home-page) .ops-hero__photo img {
    aspect-ratio: 16 / 9 !important;
  }
  .ops-portfolio-grid,
  .ops-portfolio-grid--services {
    grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
  }
}
@media (max-width: 620px) {
  body:not(.ops-home-page) .ops-hero {
    padding: 32px 0 28px !important;
  }
  body:not(.ops-home-page) .ops-hero h1 {
    font-size: clamp(36px, 12vw, 48px) !important;
  }
  body:not(.ops-home-page) .ops-hero__photo img {
    aspect-ratio: 4 / 3 !important;
  }
  .ops-portfolio-grid,
  .ops-portfolio-grid--services {
    grid-template-columns: 1fr !important;
  }
  .ops-portfolio-card img,
  .ops-portfolio-card--large img {
    height: 210px !important;
  }
  .ops-portfolio-card span,
  .ops-portfolio-card--large span {
    font-size: 28px !important;
  }
}

/* V35 - Veröffentlichungs-Feinschliff: ruhiges Intro, einheitliche Karten, stabile Layouts */
html, body { overflow-x: hidden; }
body { background: #ffffff; }

/* Intro: kontrolliert, ohne kollidierende Freitexte */
.ops-intro-splash,
.ops-intro-splash--portfolio,
.ops-intro-splash--clean {
  position: fixed !important;
  inset: 0 !important;
  z-index: 99999 !important;
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
  width: 100vw !important;
  min-height: 100vh !important;
  min-height: 100svh !important;
  overflow: hidden !important;
  padding: 24px !important;
  background: #061d42 !important;
  color: #fff !important;
  transition: opacity .50s ease, visibility 0s linear .50s !important;
}
.ops-intro-splash__bg {
  position: absolute;
  inset: 0;
  background-position: center;
  background-size: cover;
  transform: scale(1.04);
  filter: saturate(.86) contrast(.95);
  opacity: .44;
}
.ops-intro-splash__overlay,
.ops-intro-splash--clean:after {
  content: "";
  position: absolute;
  inset: 0;
  background:
    radial-gradient(circle at 50% 36%, rgba(38, 101, 172, .32), rgba(6, 29, 66, .78) 42%, rgba(6, 29, 66, .96) 100%),
    linear-gradient(110deg, rgba(6,29,66,.96), rgba(13,92,171,.63), rgba(6,29,66,.97));
}
.ops-intro-splash__panel,
.ops-intro-stage {
  position: relative !important;
  z-index: 2 !important;
  width: min(860px, 92vw) !important;
  min-height: auto !important;
  display: grid !important;
  justify-items: center !important;
  align-items: center !important;
  gap: 22px !important;
  text-align: center !important;
  padding: 0 !important;
  overflow: visible !important;
}
.ops-intro-splash__logoWrap {
  width: min(520px, 82vw);
  min-height: 150px;
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 28px 48px;
  border-radius: 30px;
  background: rgba(255,255,255,.96);
  box-shadow: 0 26px 80px rgba(0,0,0,.28);
  border: 1px solid rgba(255,255,255,.86);
  animation: opsIntroPanelIn .70s cubic-bezier(.16,.84,.22,1) .05s both;
}
.ops-intro-splash__logo {
  display: block !important;
  width: min(390px, 68vw) !important;
  max-height: 100px !important;
  height: auto !important;
  object-fit: contain !important;
  opacity: 1 !important;
  transform: none !important;
  filter: none !important;
  animation: none !important;
}
.ops-intro-splash__line {
  margin: 0 !important;
  color: #fff !important;
  font-size: clamp(30px, 5.5vw, 60px) !important;
  line-height: 1.02 !important;
  font-weight: 950 !important;
  letter-spacing: -.05em !important;
  text-shadow: 0 14px 44px rgba(0,0,0,.36) !important;
  opacity: 0;
  transform: translateY(14px);
  animation: opsIntroLineIn .52s ease .55s both !important;
}
.ops-intro-splash__sequence {
  position: relative;
  width: min(620px, 90vw);
  height: 40px;
  overflow: hidden;
  opacity: 0;
  transform: translateY(10px);
  animation: opsIntroLineIn .40s ease .80s both;
}
.ops-intro-splash__sequence span {
  position: absolute;
  inset: 0;
  display: flex;
  align-items: center;
  justify-content: center;
  color: rgba(255,255,255,.96);
  font-size: clamp(18px, 2.6vw, 30px);
  font-weight: 850;
  letter-spacing: .01em;
  white-space: nowrap;
  opacity: 0;
  transform: translateY(15px);
  animation: opsIntroService 2.08s ease both;
}
.ops-intro-splash__sequence span:nth-child(1) { animation-delay: .90s; }
.ops-intro-splash__sequence span:nth-child(2) { animation-delay: 1.14s; }
.ops-intro-splash__sequence span:nth-child(3) { animation-delay: 1.38s; }
.ops-intro-splash__sequence span:nth-child(4) { animation-delay: 1.62s; }
.ops-intro-splash__sequence span:nth-child(5) { animation-delay: 1.86s; }
.ops-intro-modules,
.ops-intro-module,
.ops-intro-word,
.ops-intro-splash__services { display: none !important; }
body.ops-intro-done .ops-intro-splash { opacity: 0 !important; visibility: hidden !important; pointer-events: none !important; }
@keyframes opsIntroPanelIn { from { opacity: 0; transform: translateY(-20px) scale(.97); filter: blur(8px); } to { opacity: 1; transform: translateY(0) scale(1); filter: blur(0); } }
@keyframes opsIntroLineIn { to { opacity: 1; transform: translateY(0); } }
@keyframes opsIntroService { 0%, 100% { opacity: 0; transform: translateY(15px); } 14%, 46% { opacity: 1; transform: translateY(0); } }
@media (max-width: 680px) {
  .ops-intro-splash__logoWrap { min-height: 120px; padding: 20px 28px; border-radius: 22px; }
  .ops-intro-splash__line { font-size: clamp(28px, 9vw, 42px) !important; }
  .ops-intro-splash__sequence { height: 34px; }
  .ops-intro-splash__sequence span { font-size: 18px; white-space: normal; }
}
@media (prefers-reduced-motion: reduce) { .ops-intro-splash { display: none !important; } }

/* Stabile Header-/Menüführung */
.ops-header { position: sticky; top: 0; z-index: 1000; background: rgba(255,255,255,.96); backdrop-filter: blur(18px); border-bottom: 1px solid var(--ops-line); }
.ops-header__inner { min-height: 88px; display: flex; align-items: center; justify-content: space-between; gap: 22px; }
.ops-brand img { width: 190px; height: auto; display: block; }
.ops-nav { display: flex; align-items: center; gap: 22px; }
.ops-nav a { color: var(--ops-navy); font-weight: 850; text-decoration: none; padding: 32px 0 28px; border-bottom: 3px solid transparent; }
.ops-nav a.is-active, .ops-nav a:hover { color: var(--ops-blue); border-bottom-color: var(--ops-blue); }
.ops-header__cta { display: flex; align-items: center; gap: 14px; }
.ops-phone { display: inline-flex; align-items: center; gap: 8px; font-weight: 950; color: var(--ops-navy); text-decoration: none; white-space: nowrap; }
.ops-phone:before { content: "☎"; color: var(--ops-blue); }

/* Einheitliche Hero-Bereiche */
.ops-hero { background: linear-gradient(135deg,#fff 0%,#f7fbff 55%,#eaf4ff 100%); overflow: hidden; }
.ops-hero__grid { display: grid; grid-template-columns: minmax(0, 1fr) minmax(420px, .95fr); gap: 48px; align-items: center; min-height: 610px; }
.ops-hero__copy { padding: 76px 0; }
.ops-kicker { color: var(--ops-blue); font-size: 14px; line-height: 1.2; font-weight: 950; text-transform: uppercase; letter-spacing: .12em; }
.ops-hero h1 { margin: 18px 0 24px; font-size: clamp(44px, 6.2vw, 82px); line-height: .98; letter-spacing: -.06em; color: var(--ops-navy); }
.ops-hero__lead { margin: 0 0 12px; font-size: clamp(24px, 3.1vw, 38px); font-weight: 850; color: var(--ops-blue); }
.ops-hero__text { margin: 0 0 26px; max-width: 700px; color: #29415f; font-size: 21px; line-height: 1.65; }
.ops-hero__ticks { display: flex; flex-wrap: wrap; gap: 12px 24px; margin: 0 0 28px; }
.ops-hero__ticks span { display: inline-flex; align-items: center; color: var(--ops-navy); font-weight: 900; font-size: 18px; }
.ops-hero__ticks span:before { content: "✓"; margin-right: 8px; color: var(--ops-blue); }
.ops-hero__photo { min-height: 500px; border-radius: 24px; overflow: hidden; box-shadow: var(--ops-shadow); background: #dbeafe; }
.ops-hero__photo img { width: 100% !important; height: 100% !important; min-height: 500px; display: block; object-fit: cover; object-position: center center; transform: none !important; filter: none !important; }
.ops-hero__photo:before { display: none !important; }
.ops-hero--compact .ops-hero__grid { min-height: 500px; }
.ops-hero--services .ops-hero__grid { grid-template-columns: minmax(0, .95fr) minmax(420px, 1fr); }
.ops-hero--portfolio .ops-hero__grid { grid-template-columns: minmax(0, .9fr) minmax(420px, 1.1fr); min-height: 590px; }

/* Portfolio-/Bildkarten: Text nie mehr über Bild, keine Überlagerung */
.ops-portfolio-grid { display: grid; grid-template-columns: repeat(4, minmax(0, 1fr)); gap: 24px; align-items: stretch; }
.ops-portfolio-card, .ops-portfolio-card--large {
  position: relative !important;
  display: grid !important;
  grid-template-rows: 210px auto !important;
  min-height: 0 !important;
  overflow: hidden !important;
  border-radius: 18px !important;
  border: 1px solid rgba(13,92,171,.18) !important;
  background: #fff !important;
  color: var(--ops-navy) !important;
  box-shadow: 0 18px 46px rgba(6,29,66,.08) !important;
  text-decoration: none !important;
}
.ops-portfolio-card--large { grid-column: span 2 !important; }
.ops-portfolio-card:after { display: none !important; }
.ops-portfolio-card img {
  position: static !important;
  width: 100% !important;
  height: 210px !important;
  min-height: 0 !important;
  display: block !important;
  object-fit: cover !important;
  object-position: center center !important;
  opacity: 1 !important;
  filter: none !important;
  transform: none !important;
}
.ops-portfolio-card span {
  position: static !important;
  display: block !important;
  padding: 20px 22px 8px !important;
  color: var(--ops-navy) !important;
  font-size: clamp(22px, 2vw, 30px) !important;
  line-height: 1.05 !important;
  font-weight: 950 !important;
  letter-spacing: -.035em !important;
  text-shadow: none !important;
  white-space: normal !important;
  overflow-wrap: anywhere !important;
  word-break: normal !important;
}
.ops-portfolio-card strong {
  position: static !important;
  display: block !important;
  padding: 0 22px 22px !important;
  color: #47607d !important;
  font-size: 16px !important;
  line-height: 1.45 !important;
  font-weight: 750 !important;
  text-shadow: none !important;
}
.ops-portfolio-grid--services { grid-template-columns: repeat(3, minmax(0, 1fr)); }
.ops-portfolio-grid--services .ops-portfolio-card { grid-template-rows: 220px auto !important; }
.ops-portfolio-grid--services .ops-portfolio-card img { height: 220px !important; }

/* Startseiten-Karten und Bildstapel entschärfen */
.ops-stack-card { border-radius: 22px; overflow: hidden; box-shadow: var(--ops-shadow); background: #fff; }
.ops-stack-card img { width: 100%; height: 100%; object-fit: cover; display: block; }
.ops-stack-card figcaption { position: absolute; left: 18px; bottom: 18px; background: rgba(6,29,66,.88); color: #fff; border-radius: 999px; padding: 8px 14px; font-weight: 900; }
.ops-focus-card { display: grid; grid-template-columns: 42% 1fr; min-height: 280px; background: #fff; color: var(--ops-navy); border: 1px solid rgba(13,92,171,.16); border-radius: 20px; overflow: hidden; box-shadow: var(--ops-shadow-soft); }
.ops-focus-card:after { display: none !important; }
.ops-focus-card img { position: static !important; width: 100%; height: 100%; min-height: 280px; object-fit: cover; opacity: 1 !important; }
.ops-focus-card div { padding: 36px !important; max-width: none !important; color: var(--ops-navy); }
.ops-focus-card h3 { color: var(--ops-navy); }
.ops-focus-card p, .ops-focus-card li { color: #435a76; }
.ops-focus-card .ops-button { background: var(--ops-blue); color: #fff; }

/* CTA-Balken sauber, kein dunkler Buttontext auf blau */
.ops-cta-strip { grid-template-columns: 1fr auto !important; }
.ops-cta-strip a:not(.ops-button) { display: inline-flex; align-items: center; justify-content: center; min-height: 56px; padding: 0 22px; border-radius: 14px; border: 1px solid rgba(255,255,255,.32); background: rgba(255,255,255,.06); color: #fff !important; }

/* Formulare und Personen mobil/desktop ruhig */
.ops-person-card { display: grid; grid-template-columns: 42% 1fr; overflow: hidden; }
.ops-person-card__image img { width: 100%; height: 100%; object-fit: cover; display: block; }
.ops-person-card__links { display: flex; flex-wrap: wrap; gap: 12px; }
.ops-person-card__links a { text-decoration: none; }
.ops-form-card { max-width: 100%; }

/* Responsive Gesamtprüfung */
@media (max-width: 1100px) {
  .ops-nav { position: fixed; left: 18px; right: 18px; top: 88px; display: none; flex-direction: column; align-items: stretch; gap: 0; padding: 16px; border: 1px solid var(--ops-line); border-radius: 18px; background: #fff; box-shadow: var(--ops-shadow); }
  body.ops-nav-open .ops-nav { display: flex; }
  .ops-nav a { padding: 14px 16px; border-bottom: 0; border-radius: 12px; }
  .ops-nav a.is-active, .ops-nav a:hover { background: var(--ops-blue-3); border-bottom-color: transparent; }
  .ops-mobile-toggle { display: inline-flex; }
  .ops-header__inner { min-height: 78px; }
  .ops-brand img { width: 170px; }
}
@media (max-width: 980px) {
  .ops-container { width: min(100% - 28px, 760px); }
  .ops-hero__grid, .ops-hero--services .ops-hero__grid, .ops-hero--portfolio .ops-hero__grid { grid-template-columns: 1fr; gap: 24px; min-height: auto; }
  .ops-hero__copy { padding: 46px 0 12px; }
  .ops-hero h1 { font-size: clamp(42px, 9vw, 64px); }
  .ops-hero__photo, .ops-hero__photo img { min-height: 360px; }
  .ops-portfolio-grid, .ops-portfolio-grid--services { grid-template-columns: repeat(2, minmax(0, 1fr)); }
  .ops-portfolio-card--large { grid-column: span 2 !important; }
  .ops-focus-card, .ops-person-card { grid-template-columns: 1fr; }
  .ops-focus-card img, .ops-person-card__image img { height: auto; max-height: 420px; object-fit: cover; object-position: center top; }
}
@media (max-width: 640px) {
  .ops-brand img { width: 138px; }
  .ops-header__cta .ops-button { display: none; }
  .ops-phone { width: 46px; height: 46px; justify-content: center; border-radius: 12px; background: var(--ops-blue); color: #fff; font-size: 0; }
  .ops-phone:before { color: #fff; margin: 0; font-size: 21px; }
  .ops-hero__text { font-size: 18px; line-height: 1.55; }
  .ops-hero__ticks { display: grid; grid-template-columns: 1fr; gap: 10px; }
  .ops-actions { display: grid; grid-template-columns: 1fr; }
  .ops-button { width: 100%; }
  .ops-hero__photo, .ops-hero__photo img { min-height: 310px; }
  .ops-portfolio-grid, .ops-portfolio-grid--services { grid-template-columns: 1fr; }
  .ops-portfolio-card, .ops-portfolio-card--large { grid-column: auto !important; grid-template-rows: 190px auto !important; }
  .ops-portfolio-card img { height: 190px !important; }
  .ops-portfolio-card span { font-size: 24px !important; }
  .ops-trustbar__inner { grid-template-columns: 1fr; }
  .ops-form-wrap, .ops-process { grid-template-columns: 1fr; }
  .ops-footer__grid { grid-template-columns: 1fr; }
  .ops-footer__bottom { padding-bottom: 86px; }
}

/* V35 - Professionelle Intro-Sequenz: Text erscheint mittig und fliegt dann in feste Zielpositionen */
body.ops-intro-active { overflow: hidden !important; }
.ops-intro-splash,
.ops-intro-splash--clean,
.ops-intro-splash--portfolio {
  overflow: hidden !important;
  padding: 0 !important;
  background: #061d42 !important;
}
.ops-intro-splash__bg {
  opacity: .42 !important;
  transform: scale(1.03) !important;
  background-position: center center !important;
}
.ops-intro-splash__overlay,
.ops-intro-splash--clean:after {
  background:
    radial-gradient(circle at 50% 42%, rgba(48,119,193,.30), rgba(6,29,66,.62) 34%, rgba(6,29,66,.96) 100%),
    linear-gradient(110deg, rgba(6,29,66,.97), rgba(13,92,171,.50), rgba(6,29,66,.98)) !important;
}
.ops-intro-splash__panel,
.ops-intro-stage {
  position: relative !important;
  width: min(1180px, calc(100vw - 80px)) !important;
  height: min(720px, calc(100svh - 70px)) !important;
  min-height: 560px !important;
  display: block !important;
  overflow: visible !important;
  padding: 0 !important;
  text-align: center !important;
}
.ops-intro-splash__logoWrap {
  position: absolute !important;
  left: 50% !important;
  top: 32% !important;
  width: min(520px, 78vw) !important;
  min-height: 150px !important;
  padding: 26px 46px !important;
  transform: translate(-50%, -50%) !important;
  border-radius: 30px !important;
  background: rgba(255,255,255,.96) !important;
  box-shadow: 0 26px 80px rgba(0,0,0,.28) !important;
  animation: opsIntroPanelIn .75s cubic-bezier(.16,.84,.22,1) .08s both !important;
}
.ops-intro-splash__logo {
  width: min(390px, 68vw) !important;
  max-height: 100px !important;
  margin: 0 auto !important;
}
.ops-intro-splash__line {
  position: absolute !important;
  left: 50% !important;
  top: 54% !important;
  width: min(980px, 92vw) !important;
  transform: translate(-50%, -50%) !important;
  margin: 0 !important;
  font-size: clamp(32px, 4.6vw, 64px) !important;
  line-height: 1.02 !important;
  white-space: nowrap !important;
  opacity: 0 !important;
  animation: opsIntroCenterLine .60s ease .62s forwards !important;
}
.ops-intro-splash__sequence {
  position: absolute !important;
  inset: 0 !important;
  width: 100% !important;
  height: 100% !important;
  overflow: visible !important;
  opacity: 1 !important;
  transform: none !important;
  animation: none !important;
  pointer-events: none !important;
}
.ops-intro-splash__sequence span {
  position: absolute !important;
  left: 50% !important;
  top: 68% !important;
  right: auto !important;
  bottom: auto !important;
  width: auto !important;
  max-width: min(360px, 31vw) !important;
  min-height: 0 !important;
  padding: 0 !important;
  display: block !important;
  color: #fff !important;
  font-size: clamp(19px, 2.25vw, 34px) !important;
  line-height: 1.05 !important;
  font-weight: 950 !important;
  letter-spacing: -.035em !important;
  text-align: center !important;
  white-space: normal !important;
  text-shadow: 0 10px 30px rgba(0,0,0,.62) !important;
  opacity: 0 !important;
  transform: translate(-50%, -50%) scale(.97) !important;
  animation-name: opsIntroWordCenterToTarget !important;
  animation-duration: 1.28s !important;
  animation-timing-function: cubic-bezier(.17,.84,.22,1) !important;
  animation-fill-mode: forwards !important;
}
.ops-intro-splash__sequence span:nth-child(1) { --ops-target-x: 17%; --ops-target-y: 16%; animation-delay: 1.18s !important; }
.ops-intro-splash__sequence span:nth-child(2) { --ops-target-x: 50%; --ops-target-y: 13%; animation-delay: 2.08s !important; }
.ops-intro-splash__sequence span:nth-child(3) { --ops-target-x: 83%; --ops-target-y: 16%; animation-delay: 2.98s !important; }
.ops-intro-splash__sequence span:nth-child(4) { --ops-target-x: 25%; --ops-target-y: 86%; animation-delay: 3.88s !important; }
.ops-intro-splash__sequence span:nth-child(5) { --ops-target-x: 75%; --ops-target-y: 86%; animation-delay: 4.78s !important; }
@keyframes opsIntroCenterLine {
  from { opacity: 0; transform: translate(-50%, -42%); filter: blur(6px); }
  to { opacity: 1; transform: translate(-50%, -50%); filter: blur(0); }
}
@keyframes opsIntroWordCenterToTarget {
  0% { opacity: 0; left: 50%; top: 68%; transform: translate(-50%, -50%) scale(.96); filter: blur(8px); }
  18% { opacity: 1; left: 50%; top: 68%; transform: translate(-50%, -50%) scale(1); filter: blur(0); }
  44% { opacity: 1; left: 50%; top: 68%; transform: translate(-50%, -50%) scale(1); filter: blur(0); }
  100% { opacity: .96; left: var(--ops-target-x); top: var(--ops-target-y); transform: translate(-50%, -50%) scale(.92); filter: blur(0); }
}
@media (max-width: 900px) {
  .ops-intro-splash__panel,
  .ops-intro-stage {
    width: calc(100vw - 34px) !important;
    height: min(720px, calc(100svh - 42px)) !important;
    min-height: 560px !important;
  }
  .ops-intro-splash__logoWrap { top: 28% !important; min-height: 118px !important; padding: 20px 26px !important; }
  .ops-intro-splash__line { top: 48% !important; font-size: clamp(26px, 8vw, 42px) !important; white-space: normal !important; }
  .ops-intro-splash__sequence span {
    max-width: 42vw !important;
    font-size: clamp(15px, 4.2vw, 22px) !important;
  }
  .ops-intro-splash__sequence span:nth-child(1) { --ops-target-x: 24%; --ops-target-y: 12%; }
  .ops-intro-splash__sequence span:nth-child(2) { --ops-target-x: 76%; --ops-target-y: 12%; }
  .ops-intro-splash__sequence span:nth-child(3) { --ops-target-x: 50%; --ops-target-y: 63%; }
  .ops-intro-splash__sequence span:nth-child(4) { --ops-target-x: 25%; --ops-target-y: 86%; }
  .ops-intro-splash__sequence span:nth-child(5) { --ops-target-x: 75%; --ops-target-y: 86%; }
}
@media (max-width: 520px) {
  .ops-intro-splash__logoWrap { width: min(360px, 84vw) !important; min-height: 100px !important; border-radius: 22px !important; }
  .ops-intro-splash__logo { width: min(280px, 70vw) !important; }
  .ops-intro-splash__line { font-size: clamp(23px, 8.4vw, 34px) !important; top: 48% !important; }
  .ops-intro-splash__sequence span { max-width: 44vw !important; font-size: 14px !important; }
}

/* V36: Professionelles Intro mit dezent sichtbaren Arbeitsbildern im Hintergrund und sicherer Textsequenz */
.ops-site-intro {
  position: fixed !important;
  inset: 0 !important;
  z-index: 2147483000 !important;
  width: 100vw !important;
  height: 100vh !important;
  height: 100dvh !important;
  overflow: hidden !important;
  display: grid !important;
  place-items: center !important;
  background: #061d42 !important;
  color: #fff !important;
  padding: 0 !important;
  box-sizing: border-box !important;
  isolation: isolate !important;
}
.ops-site-intro__media,
.ops-site-intro__shade {
  position: absolute !important;
  inset: 0 !important;
  overflow: hidden !important;
}
.ops-site-intro__media {
  display: grid !important;
  grid-template-columns: repeat(4, 1fr) !important;
  gap: 0 !important;
  opacity: .58 !important;
  filter: saturate(.92) contrast(1.04) !important;
}
.ops-site-intro__tile {
  min-width: 0 !important;
  height: 100% !important;
  background-size: cover !important;
  background-position: center !important;
  opacity: .48 !important;
  transform: scale(1.06) !important;
  animation: opsIntroTileBreath 6.8s ease both !important;
}
.ops-site-intro__tile--cleaning { background-position: center top !important; animation-delay: .05s !important; }
.ops-site-intro__tile--solar { background-position: center center !important; animation-delay: .25s !important; }
.ops-site-intro__tile--glass { background-position: center center !important; animation-delay: .45s !important; }
.ops-site-intro__tile--winter { background-position: center center !important; animation-delay: .65s !important; }
.ops-site-intro__shade {
  z-index: 2 !important;
  background:
    radial-gradient(circle at 50% 42%, rgba(28,114,204,.30), rgba(6,29,66,.55) 36%, rgba(6,29,66,.97) 100%),
    linear-gradient(90deg, rgba(6,29,66,.95), rgba(8,43,91,.72) 38%, rgba(8,43,91,.72) 62%, rgba(6,29,66,.96)) !important;
  backdrop-filter: blur(1.5px) !important;
}
.ops-site-intro__content {
  position: relative !important;
  z-index: 4 !important;
  width: min(860px, calc(100vw - 40px)) !important;
  min-height: min(520px, calc(100dvh - 80px)) !important;
  display: grid !important;
  align-content: center !important;
  justify-items: center !important;
  gap: clamp(16px, 3vh, 26px) !important;
  text-align: center !important;
  padding: 0 10px !important;
}
.ops-site-intro__logo {
  width: min(440px, 78vw) !important;
  max-height: 138px !important;
  object-fit: contain !important;
  padding: clamp(16px, 2.8vw, 24px) clamp(24px, 4vw, 42px) !important;
  border-radius: clamp(18px, 3vw, 30px) !important;
  background: rgba(255,255,255,.96) !important;
  box-shadow: 0 34px 90px rgba(0,0,0,.35) !important;
  opacity: 0 !important;
  transform: translateY(-26px) scale(.97) !important;
  animation: opsIntroLogoV36 .85s cubic-bezier(.16,.84,.22,1) .10s forwards !important;
}
.ops-site-intro__claim {
  margin: 0 !important;
  max-width: 100% !important;
  color: #fff !important;
  font-size: clamp(27px, 4.2vw, 58px) !important;
  font-weight: 950 !important;
  line-height: 1.02 !important;
  letter-spacing: -.045em !important;
  text-shadow: 0 12px 30px rgba(0,0,0,.48) !important;
  opacity: 0 !important;
  transform: translateY(14px) !important;
  animation: opsIntroClaimV36 .72s ease .66s forwards !important;
}
.ops-site-intro__services {
  position: relative !important;
  width: min(760px, calc(100vw - 42px)) !important;
  height: clamp(42px, 8vh, 72px) !important;
  overflow: hidden !important;
  display: block !important;
  margin-top: 2px !important;
}
.ops-site-intro__services span {
  position: absolute !important;
  inset: 0 !important;
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
  width: 100% !important;
  color: #fff !important;
  font-size: clamp(21px, 3.1vw, 43px) !important;
  font-weight: 950 !important;
  line-height: 1.08 !important;
  letter-spacing: -.035em !important;
  white-space: normal !important;
  text-align: center !important;
  text-shadow: 0 14px 35px rgba(0,0,0,.62) !important;
  opacity: 0 !important;
  transform: translateY(28px) scale(.98) !important;
  filter: blur(7px) !important;
  animation: opsIntroServiceV36 1.12s cubic-bezier(.18,.84,.24,1) both !important;
}
.ops-site-intro__services span:nth-child(1) { animation-delay: 1.35s !important; }
.ops-site-intro__services span:nth-child(2) { animation-delay: 2.35s !important; }
.ops-site-intro__services span:nth-child(3) { animation-delay: 3.35s !important; }
.ops-site-intro__services span:nth-child(4) { animation-delay: 4.35s !important; }
.ops-site-intro__services span:nth-child(5) { animation-delay: 5.35s !important; }
body.ops-intro-active { overflow: hidden !important; }
body.ops-intro-done .ops-site-intro {
  opacity: 0 !important;
  visibility: hidden !important;
  pointer-events: none !important;
  transition: opacity .65s ease, visibility .65s ease !important;
}
@keyframes opsIntroTileBreath {
  0% { transform: scale(1.10); opacity: .38; }
  38% { opacity: .52; }
  100% { transform: scale(1.03); opacity: .42; }
}
@keyframes opsIntroLogoV36 {
  to { opacity: 1; transform: translateY(0) scale(1); filter: blur(0); }
}
@keyframes opsIntroClaimV36 {
  to { opacity: 1; transform: translateY(0); filter: blur(0); }
}
@keyframes opsIntroServiceV36 {
  0% { opacity: 0; transform: translateY(28px) scale(.98); filter: blur(7px); }
  18% { opacity: 1; transform: translateY(0) scale(1); filter: blur(0); }
  72% { opacity: 1; transform: translateY(0) scale(1); filter: blur(0); }
  100% { opacity: 0; transform: translateY(-24px) scale(.985); filter: blur(5px); }
}
@media (max-width: 760px) {
  .ops-site-intro__media { grid-template-columns: repeat(2, 1fr) !important; grid-template-rows: repeat(2, 1fr) !important; }
  .ops-site-intro__content { width: min(100vw - 28px, 620px) !important; min-height: min(520px, calc(100dvh - 44px)) !important; gap: 14px !important; }
  .ops-site-intro__logo { width: min(330px, 78vw) !important; max-height: 112px !important; padding: 16px 24px !important; }
  .ops-site-intro__claim { font-size: clamp(27px, 8.6vw, 41px) !important; max-width: 11ch !important; }
  .ops-site-intro__services { width: min(94vw, 520px) !important; height: 58px !important; }
  .ops-site-intro__services span { font-size: clamp(21px, 6.4vw, 31px) !important; }
}
@media (prefers-reduced-motion: reduce) {
  .ops-site-intro { display: none !important; }
}

/* V37: Splash-Intro entfernt. Professioneller Start direkt im Hero-Bereich. */
.ops-site-intro,
.ops-intro-splash,
.ops-intro-stage,
.ops-intro-bg,
.ops-intro-word,
.ops-intro-module {
  display: none !important;
}
body.ops-intro-active {
  overflow: auto !important;
}
body.ops-home-page {
  overflow-x: hidden !important;
}
.ops-hero--portfolio {
  position: relative;
  overflow: hidden;
  background:
    radial-gradient(circle at 78% 28%, rgba(13,92,171,.16), transparent 34%),
    linear-gradient(120deg, #ffffff 0%, #f6faff 52%, #eaf4ff 100%) !important;
}
.ops-hero--portfolio:before {
  content: "";
  position: absolute;
  inset: 0;
  background:
    linear-gradient(90deg, rgba(255,255,255,.94) 0%, rgba(255,255,255,.78) 44%, rgba(255,255,255,.35) 100%),
    url('assets/hero-cleaning.jpg') center / cover no-repeat;
  opacity: .14;
  z-index: 0;
  pointer-events: none;
}
.ops-hero--portfolio .ops-container {
  position: relative;
  z-index: 1;
}
.ops-hero-rotator {
  position: relative;
  width: min(620px, 100%);
  min-height: 56px;
  margin: 18px 0 0;
  overflow: hidden;
  border-left: 5px solid var(--ops-blue);
  padding-left: 18px;
}
.ops-hero-rotator span {
  position: absolute;
  inset: 0 auto auto 18px;
  display: block;
  max-width: calc(100% - 20px);
  color: var(--ops-blue);
  font-size: clamp(24px, 3.4vw, 42px);
  font-weight: 950;
  line-height: 1.12;
  letter-spacing: -.04em;
  opacity: 0;
  transform: translateY(22px);
  filter: blur(4px);
  animation: opsHeroServiceRotate 15s infinite;
}
.ops-hero-rotator span:nth-child(1) { animation-delay: 0s; }
.ops-hero-rotator span:nth-child(2) { animation-delay: 3s; }
.ops-hero-rotator span:nth-child(3) { animation-delay: 6s; }
.ops-hero-rotator span:nth-child(4) { animation-delay: 9s; }
.ops-hero-rotator span:nth-child(5) { animation-delay: 12s; }
@keyframes opsHeroServiceRotate {
  0% { opacity: 0; transform: translateY(22px); filter: blur(4px); }
  6% { opacity: 1; transform: translateY(0); filter: blur(0); }
  17% { opacity: 1; transform: translateY(0); filter: blur(0); }
  23% { opacity: 0; transform: translateY(-18px); filter: blur(3px); }
  100% { opacity: 0; transform: translateY(-18px); filter: blur(3px); }
}
.ops-stack-card {
  overflow: hidden;
  background: #fff;
}
.ops-stack-card img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}
.ops-stack-card figcaption {
  backdrop-filter: blur(8px);
}
@media (max-width: 780px) {
  .ops-hero-rotator {
    min-height: 50px;
    margin-top: 14px;
    padding-left: 14px;
  }
  .ops-hero-rotator span {
    left: 14px;
    font-size: clamp(22px, 7vw, 34px);
  }
}
@media (prefers-reduced-motion: reduce) {
  .ops-hero-rotator { min-height: auto; }
  .ops-hero-rotator span {
    position: static;
    display: none;
    opacity: 1;
    transform: none;
    filter: none;
    animation: none;
  }
  .ops-hero-rotator span:first-child { display: block; }
}


/* V38: Störende Floating-Servicekarten im Startseiten-Hero entfernt. */
.ops-hero-stack .ops-stack-card--solar,
.ops-hero-stack .ops-stack-card--winter { display: none !important; }
.ops-hero-stack { overflow: visible !important; }
.ops-hero-stack .ops-stack-card--main { position: relative !important; inset: auto !important; width: min(100%, 640px) !important; margin: 0 auto !important; transform: none !important; }
.ops-hero-stack .ops-stack-card--main img { width: 100% !important; height: auto !important; max-height: 560px; object-fit: contain !important; object-position: center center !important; }
@media (max-width: 900px) {
  .ops-hero-stack .ops-stack-card--main { width: 100% !important; }
  .ops-hero-stack .ops-stack-card--main img { max-height: 420px; }
}


/* =========================================================
   V39 - Professionelles Start-Intro, eigenstaendig und stabil
   ========================================================= */
body.ops-intro-v39-active {
  overflow: hidden !important;
}
.ops-splash-v39 {
  position: fixed;
  inset: 0;
  z-index: 999999;
  min-height: 100vh;
  min-height: 100dvh;
  width: 100%;
  overflow: hidden;
  background: #061d42;
  color: #fff;
  display: grid;
  place-items: center;
  opacity: 1;
  visibility: visible;
  transition: opacity .55s ease, visibility .55s ease;
}
.ops-splash-v39.is-hidden {
  opacity: 0;
  visibility: hidden;
  pointer-events: none;
}
.ops-splash-v39__bg,
.ops-splash-v39__overlay {
  position: absolute;
  inset: 0;
}
.ops-splash-v39__bg span {
  position: absolute;
  inset: -2%;
  background-position: center;
  background-size: cover;
  opacity: 0;
  transform: scale(1.04);
  animation: opsSplashBg39 6.2s linear infinite;
  filter: saturate(.95) contrast(1.04);
}
.ops-splash-v39__bg span:nth-child(1) { animation-delay: 0s; }
.ops-splash-v39__bg span:nth-child(2) { animation-delay: 1.55s; }
.ops-splash-v39__bg span:nth-child(3) { animation-delay: 3.1s; }
.ops-splash-v39__bg span:nth-child(4) { animation-delay: 4.65s; }
@keyframes opsSplashBg39 {
  0% { opacity: 0; transform: scale(1.05); }
  8% { opacity: .42; }
  28% { opacity: .42; }
  36% { opacity: 0; transform: scale(1.095); }
  100% { opacity: 0; transform: scale(1.095); }
}
.ops-splash-v39__overlay {
  background:
    radial-gradient(circle at 50% 42%, rgba(20, 115, 210, .22), transparent 38%),
    linear-gradient(90deg, rgba(3, 17, 42, .88), rgba(7, 38, 79, .74) 42%, rgba(3, 17, 42, .9)),
    rgba(6, 29, 66, .62);
  backdrop-filter: blur(1.5px);
}
.ops-splash-v39__content {
  position: relative;
  z-index: 2;
  width: min(860px, calc(100% - 40px));
  display: grid;
  justify-items: center;
  text-align: center;
  gap: clamp(16px, 2.6vh, 26px);
  padding: clamp(24px, 5vh, 46px) 0;
}
.ops-splash-v39__logo {
  width: min(470px, 78vw);
  border-radius: 26px;
  background: rgba(255,255,255,.96);
  box-shadow: 0 26px 70px rgba(0,0,0,.28);
  padding: clamp(18px, 3vw, 30px) clamp(24px, 5vw, 54px);
  transform: translateY(14px) scale(.96);
  opacity: 0;
  animation: opsSplashLogo39 .75s cubic-bezier(.22, 1, .36, 1) .08s forwards;
}
.ops-splash-v39__logo img {
  display: block;
  width: 100%;
  height: auto;
}
@keyframes opsSplashLogo39 {
  to { opacity: 1; transform: translateY(0) scale(1); }
}
.ops-splash-v39__headline {
  margin: 0;
  font-size: clamp(34px, 6vw, 72px);
  line-height: .98;
  letter-spacing: -.055em;
  font-weight: 900;
  text-shadow: 0 18px 45px rgba(0,0,0,.36);
  opacity: 0;
  transform: translateY(14px);
  animation: opsSplashTextIn39 .62s ease .52s forwards;
}
.ops-splash-v39__service {
  min-height: 56px;
  display: grid;
  place-items: center;
  padding: 0 12px;
  font-size: clamp(24px, 4vw, 42px);
  line-height: 1.05;
  font-weight: 900;
  letter-spacing: -.035em;
  color: #ffffff;
  text-shadow: 0 16px 34px rgba(0,0,0,.45);
  opacity: 0;
  transform: translateY(16px);
  transition: opacity .28s ease, transform .28s ease, filter .28s ease;
}
.ops-splash-v39__service.is-visible {
  opacity: 1;
  transform: translateY(0);
  filter: none;
}
.ops-splash-v39__service.is-switching {
  opacity: 0;
  transform: translateY(-12px);
  filter: blur(4px);
}
.ops-splash-v39__hint {
  margin: 0;
  max-width: 620px;
  font-size: clamp(15px, 1.6vw, 18px);
  line-height: 1.55;
  color: rgba(255,255,255,.82);
  opacity: 0;
  transform: translateY(10px);
  animation: opsSplashTextIn39 .55s ease .82s forwards;
}
@keyframes opsSplashTextIn39 {
  to { opacity: 1; transform: translateY(0); }
}
.ops-splash-v39__skip {
  position: absolute;
  right: max(18px, env(safe-area-inset-right));
  bottom: max(18px, env(safe-area-inset-bottom));
  z-index: 3;
  border: 1px solid rgba(255,255,255,.32);
  background: rgba(255,255,255,.12);
  color: #fff;
  font: inherit;
  font-weight: 800;
  border-radius: 999px;
  padding: 11px 18px;
  cursor: pointer;
  backdrop-filter: blur(8px);
}
.ops-splash-v39__skip:hover { background: rgba(255,255,255,.2); }
@media (max-width: 680px) {
  .ops-splash-v39__content { width: min(100% - 26px, 520px); gap: 16px; }
  .ops-splash-v39__logo { border-radius: 20px; }
  .ops-splash-v39__headline { font-size: clamp(32px, 11vw, 46px); }
  .ops-splash-v39__service { min-height: 46px; font-size: clamp(23px, 7vw, 34px); }
  .ops-splash-v39__hint { max-width: 340px; }
}
@media (prefers-reduced-motion: reduce) {
  .ops-splash-v39 { display: none !important; }
  body.ops-intro-v39-active { overflow: auto !important; }
}
