/* zeitWerk365 marketing — built on /colors_and_type.css and the ARNIO marketing-site kit */

* { box-sizing: border-box; }
html, body { margin: 0; padding: 0; }
body { background: #fff; color: var(--color-fg); font-family: var(--font-sans); -webkit-font-smoothing: antialiased; }

/* ---------- shared layout ---------- */
.zw-container { max-width: 1240px; margin: 0 auto; padding: 0 40px; }
.zw-eyebrow { font-size: 12px; font-weight: 600; letter-spacing: .08em; text-transform: uppercase; color: var(--arnio-gruenblau); margin-bottom: 14px; display: flex; align-items: center; gap: 10px; }
.zw-eyebrow::before { content: ""; display: inline-block; width: 24px; height: 1px; background: var(--arnio-gruenblau); }
.zw-section-head { margin-bottom: 56px; max-width: 880px; }
.zw-section-head h2 { font-family: "Flama"; font-weight: 400; text-transform: uppercase; font-size: 56px; letter-spacing: .015em; line-height: 1.05; margin: 0; color: var(--color-fg); }
.zw-section-head h2 em { font-style: italic; font-weight: 700; }
.zw-section-head p { margin: 24px 0 0; font-size: 17px; line-height: 1.5; color: var(--color-fg-muted); max-width: 640px; }
.zw-link { color: var(--arnio-gruenblau); font-weight: 600; text-decoration: none; font-size: 13px; letter-spacing: .04em; text-transform: uppercase; }
.zw-link:hover { color: var(--color-fg); }

/* ---------- buttons ---------- */
.zw-btn { font-family: "Flama"; font-weight: 600; font-size: 13px; letter-spacing: .04em; text-transform: uppercase; padding: 14px 24px; border-radius: 2px; border: 1px solid transparent; cursor: pointer; display: inline-flex; align-items: center; gap: 10px; text-decoration: none; transition: background var(--dur-1) var(--easing-standard), color var(--dur-1) var(--easing-standard), border-color var(--dur-1) var(--easing-standard); }
.zw-btn--primary { background: var(--arnio-gruenblau); color: #fff; }
.zw-btn--primary:hover { background: transparent; color: var(--arnio-stahlblau); border: 1px solid var(--arnio-stahlblau); }
.zw-btn--ghost { background: transparent; color: var(--color-fg); border-color: var(--color-fg); }
.zw-btn--ghost:hover { background: var(--color-fg); color: #fff; }
.zw-btn--accent { background: var(--arnio-gelbgruen); color: var(--arnio-stahlblau); }
.zw-btn--accent:hover { background: var(--arnio-stahlblau); color: var(--arnio-gelbgruen); }
.zw-btn--sm { padding: 9px 16px; font-size: 11px; }
.zw-btn--lg { padding: 18px 30px; font-size: 14px; }
.zw-btn--inverse { background: #fff; color: var(--arnio-stahlblau); }
.zw-btn--inverse:hover { background: var(--arnio-gelbgruen); color: var(--arnio-stahlblau); }
.zw-btn--inverse-ghost { background: transparent; color: #fff; border-color: rgba(255,255,255,.4); }
.zw-btn--inverse-ghost:hover { background: rgba(255,255,255,.08); border-color: #fff; }

/* ---------- nav ---------- */
.zw-nav { position: sticky; top: 0; z-index: 50; background: rgba(255,255,255,.92); backdrop-filter: blur(10px); border-bottom: 1px solid var(--color-border); }
.zw-nav__inner { display: flex; align-items: center; justify-content: space-between; padding: 18px 40px; max-width: 1240px; margin: 0 auto; gap: 32px; }
.zw-nav__brand { display: flex; align-items: center; gap: 14px; text-decoration: none; }
.zw-nav__brand img { height: 26px; display: block; }
.zw-nav__divider { width: 1px; height: 22px; background: var(--color-border-strong); }
.zw-nav__product { font-family: "Flama"; font-weight: 700; font-style: italic; font-size: 18px; color: var(--arnio-stahlblau); letter-spacing: -.005em; }
.zw-nav__product sup { font-style: normal; font-weight: 600; font-size: 12px; color: var(--arnio-gruenblau); margin-left: 1px; vertical-align: super; }
.zw-nav__list { list-style: none; margin: 0; padding: 0; display: flex; gap: 30px; }
.zw-nav__list a { font-size: 12px; font-weight: 600; letter-spacing: .06em; text-transform: uppercase; color: var(--color-fg); text-decoration: none; cursor: pointer; transition: color var(--dur-1); }
.zw-nav__list a.is-active, .zw-nav__list a:hover { color: var(--arnio-gruenblau); }
.zw-nav__cta { display: flex; align-items: center; gap: 12px; }
.zw-nav__cta .text-btn { font-size: 12px; font-weight: 600; letter-spacing: .06em; text-transform: uppercase; color: var(--color-fg); text-decoration: none; cursor: pointer; }
.zw-nav__cta .text-btn:hover { color: var(--arnio-gruenblau); }

/* ---------- hero ---------- */
.zw-hero { position: relative; padding: 70px 0 100px; overflow: hidden; }
.zw-hero__bg { position: absolute; inset: 0; background: linear-gradient(160deg, var(--arnio-himmelblau-2) 0%, #ffffff 55%); z-index: 0; }
.zw-hero__bg::after { content: ""; position: absolute; right: -120px; top: -120px; width: 540px; height: 540px; border-radius: 50%; background: radial-gradient(circle at 30% 30%, rgba(213,212,0,.18), transparent 65%); }
.zw-hero__inner { position: relative; z-index: 1; display: grid; grid-template-columns: 1fr 1fr; gap: 56px; align-items: center; }
.zw-hero__title { margin: 16px 0 24px; line-height: 1.0; }
.zw-hero__title .line { display: block; }
.line--flama { font-family: "Flama"; font-weight: 700; font-style: italic; text-transform: uppercase; font-size: 56px; letter-spacing: .005em; color: var(--color-fg); line-height: 1.05; }
.line--flood { font-family: "Flood"; font-weight: 400; text-transform: uppercase; font-size: 76px; line-height: 1.0; color: var(--arnio-stahlblau); margin-top: 4px; }
.line--flood-blue { color: var(--arnio-gruenblau); }
.zw-hero__lede { font-size: 18px; line-height: 1.5; font-weight: 500; color: var(--color-fg); max-width: 540px; margin: 0 0 32px; }
.zw-hero__ctas { display: flex; gap: 12px; flex-wrap: wrap; }
.zw-hero__trust { display: flex; gap: 28px; margin-top: 40px; padding-top: 28px; border-top: 1px dashed var(--color-border-strong); flex-wrap: wrap; }
.zw-hero__trust-item { display: flex; align-items: center; gap: 8px; font-size: 12px; font-weight: 600; letter-spacing: .04em; text-transform: uppercase; color: var(--color-fg-muted); }
.zw-hero__trust-item svg { width: 16px; height: 16px; color: var(--arnio-gruenblau); }

/* hero device mockup */
.zw-hero__device { position: relative; }
.zw-tablet { position: relative; aspect-ratio: 4/3; background: var(--arnio-stahlblau); border-radius: 22px; padding: 14px; box-shadow: 0 30px 60px -20px rgba(0,52,74,.35), 0 10px 20px -8px rgba(0,52,74,.18); transform: perspective(1400px) rotateY(-7deg) rotateX(3deg); transform-origin: center; }
.zw-tablet__camera { position: absolute; top: 7px; left: 50%; transform: translateX(-50%); width: 6px; height: 6px; border-radius: 50%; background: rgba(255,255,255,.18); }
.zw-tablet__screen { background: linear-gradient(180deg, #F4F8FA 0%, #ffffff 100%); border-radius: 8px; height: 100%; overflow: hidden; display: flex; flex-direction: column; }
.kiosk__top { display: flex; justify-content: space-between; align-items: center; padding: 14px 20px; border-bottom: 1px solid var(--color-border); }
.kiosk__brand { display: flex; align-items: center; gap: 8px; }
.kiosk__brand strong { font-family: "Flama"; font-weight: 700; font-style: italic; font-size: 14px; color: var(--arnio-stahlblau); }
.kiosk__brand sup { font-size: 9px; color: var(--arnio-gruenblau); font-weight: 600; }
.kiosk__time { font-family: "Flama"; font-weight: 600; font-size: 13px; color: var(--arnio-stahlblau); }
.kiosk__time .secs { color: var(--color-fg-muted); }
.kiosk__main { flex: 1; display: grid; grid-template-columns: 1fr 1.2fr; gap: 0; }
.kiosk__stamp { padding: 26px 22px; display: flex; flex-direction: column; justify-content: space-between; gap: 14px; border-right: 1px solid var(--color-border); background: linear-gradient(180deg, rgba(147,223,204,.18), transparent); }
.kiosk__rfid-circle { width: 110px; height: 110px; border-radius: 50%; border: 2px dashed var(--arnio-gruenblau); display: flex; align-items: center; justify-content: center; margin: 0 auto; position: relative; animation: zw-pulse 2.4s ease-in-out infinite; }
.kiosk__rfid-circle::before, .kiosk__rfid-circle::after { content: ""; position: absolute; inset: 0; border-radius: 50%; border: 1px solid var(--arnio-gruenblau); opacity: .4; animation: zw-pulse-ring 2.4s ease-out infinite; }
.kiosk__rfid-circle::after { animation-delay: 1.2s; }
.kiosk__rfid-circle svg { width: 42px; height: 42px; color: var(--arnio-gruenblau); }
@keyframes zw-pulse { 0%, 100% { transform: scale(1); } 50% { transform: scale(1.04); } }
@keyframes zw-pulse-ring { 0% { transform: scale(1); opacity: .4; } 100% { transform: scale(1.5); opacity: 0; } }
.kiosk__stamp-label { text-align: center; font-family: "Flama"; font-weight: 600; font-size: 13px; color: var(--arnio-stahlblau); letter-spacing: .04em; text-transform: uppercase; }
.kiosk__stamp-label small { display: block; font-weight: 400; font-size: 10px; color: var(--color-fg-muted); margin-top: 4px; letter-spacing: 0; text-transform: none; }
.kiosk__quick { display: flex; gap: 6px; justify-content: center; flex-wrap: wrap; padding-bottom: 2px; }
.kiosk__quick button { font-family: "Flama"; font-size: 9.5px; font-weight: 600; letter-spacing: .04em; text-transform: uppercase; padding: 6px 9px; border-radius: 9999px; border: 1px solid var(--color-border-strong); background: #fff; color: var(--arnio-stahlblau); cursor: pointer; }
.kiosk__quick button.is-active { background: var(--arnio-gruenblau); color: #fff; border-color: var(--arnio-gruenblau); }
.kiosk__present { padding: 18px 18px 14px; display: flex; flex-direction: column; gap: 8px; min-height: 0; }
.kiosk__present-head { display: flex; justify-content: space-between; align-items: baseline; }
.kiosk__present-head h5 { margin: 0; font-family: "Flama"; font-weight: 600; font-size: 11px; letter-spacing: .06em; text-transform: uppercase; color: var(--color-fg-muted); }
.kiosk__present-count { font-family: "Flama"; font-weight: 700; font-style: italic; font-size: 14px; color: var(--arnio-gruenblau); }
.kiosk__people { display: flex; flex-direction: column; gap: 5px; overflow: hidden; }
.kiosk__person { display: flex; align-items: center; gap: 8px; padding: 6px 8px; background: #fff; border: 1px solid var(--color-border); border-radius: 4px; font-family: "Flama"; font-size: 11px; }
.kiosk__person .avatar { width: 22px; height: 22px; border-radius: 50%; background: var(--arnio-gruenblau); color: #fff; font-size: 9px; font-weight: 700; display: flex; align-items: center; justify-content: center; flex-shrink: 0; }
.kiosk__person .name { flex: 1; color: var(--arnio-stahlblau); font-weight: 500; }
.kiosk__person .since { font-size: 9.5px; color: var(--color-fg-muted); font-variant-numeric: tabular-nums; }
.kiosk__person .dot { width: 6px; height: 6px; border-radius: 50%; background: var(--arnio-gelbgruen); flex-shrink: 0; box-shadow: 0 0 0 3px rgba(213,212,0,.18); }
.kiosk__person.is-out .dot { background: var(--color-border-strong); box-shadow: none; }
.kiosk__person.is-out .name { color: var(--color-fg-muted); }
.kiosk__present .seemore { font-size: 9.5px; color: var(--color-fg-muted); margin-top: auto; }

/* hero floating annotations around tablet */
.zw-hero__device-anno { position: absolute; font-family: "Flama"; font-size: 11px; font-weight: 600; letter-spacing: .04em; text-transform: uppercase; color: var(--arnio-stahlblau); display: flex; align-items: center; gap: 8px; }
.zw-hero__device-anno svg { width: 32px; height: 12px; }
.zw-hero__device-anno--tl { top: 8%; left: -18px; }
.zw-hero__device-anno--br { bottom: -2%; right: 0; flex-direction: row-reverse; }

/* ---------- problem ---------- */
.zw-problem { padding: 110px 0; background: #fff; border-bottom: 1px solid var(--color-border); }
.zw-problem__intro { display: grid; grid-template-columns: 1fr 1fr; gap: 60px; align-items: end; margin-bottom: 64px; }
.zw-problem__intro p { margin: 0; font-size: 17px; line-height: 1.55; color: var(--color-fg-muted); }
.zw-problem__intro p strong { color: var(--arnio-stahlblau); font-weight: 600; }
.zw-problem__grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 18px; }
.zw-problem__card { padding: 32px 28px; background: var(--color-bg-soft); border: 1px solid var(--color-border); border-radius: 4px; display: flex; flex-direction: column; gap: 14px; position: relative; }
.zw-problem__card .num { font-family: "Flood"; font-size: 56px; line-height: 1; color: var(--arnio-gruenblau); }
.zw-problem__card h4 { margin: 0; font-family: "Flama"; font-weight: 700; font-style: italic; text-transform: uppercase; font-size: 22px; letter-spacing: .005em; color: var(--arnio-stahlblau); }
.zw-problem__card p { margin: 0; font-size: 14px; line-height: 1.5; color: var(--color-fg-muted); }
.zw-problem__card .marks { display: flex; gap: 4px; margin-top: auto; padding-top: 12px; border-top: 1px dashed var(--color-border-strong); font-size: 11px; color: var(--color-fg-subtle); font-weight: 600; letter-spacing: .04em; text-transform: uppercase; }
.zw-problem__card .marks .x { color: #C04646; }

.zw-problem__verdict { margin-top: 64px; padding: 28px 32px; background: var(--arnio-stahlblau); color: #fff; border-radius: 4px; display: flex; align-items: center; gap: 24px; }
.zw-problem__verdict .badge { font-family: "Flama"; font-weight: 700; font-style: italic; font-size: 12px; letter-spacing: .04em; text-transform: uppercase; padding: 6px 12px; background: var(--arnio-gelbgruen); color: var(--arnio-stahlblau); border-radius: 9999px; flex-shrink: 0; }
.zw-problem__verdict p { margin: 0; font-size: 15px; line-height: 1.5; color: rgba(255,255,255,.85); }
.zw-problem__verdict p strong { color: #fff; font-weight: 600; }

/* ---------- promises ---------- */
.zw-promises { padding: 130px 0; background: #fff; }
.zw-promises__list { display: grid; grid-template-columns: repeat(3, 1fr); gap: 32px; position: relative; }
.zw-promise { padding: 36px 32px 36px; border: 1px solid var(--color-border); border-radius: 4px; display: flex; flex-direction: column; gap: 16px; background: #fff; position: relative; transition: border-color var(--dur-2) var(--easing-standard), transform var(--dur-2) var(--easing-standard); }
.zw-promise:hover { border-color: var(--arnio-gruenblau); transform: translateY(-2px); }
.zw-promise__loop { width: 64px; height: 64px; border-radius: 50%; display: flex; align-items: center; justify-content: center; font-family: "Flood"; font-size: 30px; }
.zw-promise:nth-child(1) .zw-promise__loop { background: var(--arnio-gruenblau); color: #fff; }
.zw-promise:nth-child(2) .zw-promise__loop { background: var(--arnio-gelbgruen); color: var(--arnio-stahlblau); }
.zw-promise:nth-child(3) .zw-promise__loop { background: var(--arnio-mint); color: var(--arnio-stahlblau); }
.zw-promise__eyebrow { font-size: 11px; font-weight: 600; letter-spacing: .08em; text-transform: uppercase; color: var(--color-fg-muted); }
.zw-promise h3 { margin: 0; font-family: "Flama"; font-weight: 700; font-style: italic; text-transform: uppercase; font-size: 28px; letter-spacing: .005em; line-height: 1.1; color: var(--arnio-stahlblau); }
.zw-promise p { margin: 0; font-size: 15px; line-height: 1.55; color: var(--color-fg-muted); }
.zw-promise__metric { margin-top: 8px; padding-top: 16px; border-top: 1px dashed var(--color-border-strong); display: flex; align-items: baseline; gap: 8px; }
.zw-promise__metric strong { font-family: "Flood"; font-size: 36px; color: var(--arnio-gruenblau); line-height: 1; }
.zw-promise__metric span { font-size: 12px; font-weight: 600; letter-spacing: .04em; text-transform: uppercase; color: var(--color-fg-muted); }

/* ---------- inverse plakativ ---------- */
.zw-plakativ { background: var(--arnio-stahlblau); color: #fff; padding: 130px 0; position: relative; overflow: hidden; }
.zw-plakativ::before { content: ""; position: absolute; right: -200px; top: -200px; width: 600px; height: 600px; border-radius: 50%; background: radial-gradient(circle, rgba(213,212,0,.10), transparent 60%); }
.zw-plakativ__inner { display: grid; grid-template-columns: 1fr auto; align-items: center; gap: 60px; position: relative; }
.zw-plakativ__h .line { display: block; }
.zw-plakativ .line--flama { color: #fff; font-size: 56px; }
.zw-plakativ .line--flood { color: var(--arnio-gelbgruen); font-size: 72px; line-height: 1.0; }
.zw-plakativ .line--flood.blue { color: var(--arnio-gruenblau); }
.zw-plakativ__loops { display: flex; align-items: center; gap: 18px; flex-direction: column; }
.zw-plakativ__loops-row { display: flex; align-items: center; gap: 14px; }
.loop { width: 130px; height: 130px; border-radius: 50%; display: flex; align-items: center; justify-content: center; flex-direction: column; font-family: "Flama"; font-weight: 700; font-style: italic; text-transform: uppercase; font-size: 13px; letter-spacing: .04em; text-align: center; padding: 12px; line-height: 1.1; }
.loop strong { font-family: "Flood"; font-size: 28px; font-style: normal; font-weight: 400; line-height: 1; margin-bottom: 4px; }
.loop--blue { background: var(--arnio-gruenblau); color: #fff; }
.loop--yellow { background: var(--arnio-gelbgruen); color: var(--arnio-stahlblau); }
.dash { font-family: "Flama"; color: rgba(255,255,255,.6); letter-spacing: -.05em; font-size: 18px; }

/* ---------- compliance ---------- */
.zw-compliance { padding: 130px 0; background: #F4F8FA; }
.zw-compliance__head { display: grid; grid-template-columns: 1fr 1fr; gap: 60px; align-items: end; margin-bottom: 64px; }
.zw-compliance__head .zw-section-head { margin-bottom: 0; }
.zw-compliance__head-meta { font-size: 13px; line-height: 1.55; color: var(--color-fg-muted); border-left: 1px dashed var(--color-border-strong); padding-left: 24px; }
.zw-compliance__head-meta strong { color: var(--arnio-stahlblau); font-weight: 600; }
.zw-compliance__grid { display: grid; grid-template-columns: repeat(2, 1fr); gap: 16px; }
.zw-paragraph { padding: 32px; background: #fff; border: 1px solid var(--color-border); border-radius: 4px; display: grid; grid-template-columns: auto 1fr; gap: 28px; align-items: start; transition: border-color var(--dur-2); }
.zw-paragraph:hover { border-color: var(--arnio-gruenblau); }
.zw-paragraph__sigil { font-family: "Flood"; font-size: 64px; line-height: 1; color: var(--arnio-gruenblau); border-right: 1px solid var(--color-border); padding-right: 28px; min-width: 100px; text-align: center; }
.zw-paragraph__sigil small { display: block; font-family: "Flama"; font-size: 11px; font-weight: 600; letter-spacing: .08em; text-transform: uppercase; color: var(--color-fg-muted); margin-top: 4px; }
.zw-paragraph__body h4 { margin: 0 0 8px; font-family: "Flama"; font-weight: 700; font-style: italic; text-transform: uppercase; font-size: 20px; letter-spacing: .005em; color: var(--arnio-stahlblau); }
.zw-paragraph__body p { margin: 0 0 12px; font-size: 14px; line-height: 1.55; color: var(--color-fg-muted); }
.zw-paragraph__rule { display: inline-flex; align-items: center; gap: 8px; font-family: "Flama"; font-size: 11px; font-weight: 600; letter-spacing: .04em; text-transform: uppercase; color: var(--arnio-gruenblau); background: var(--arnio-gruenblau-tint); padding: 4px 10px; border-radius: 9999px; }

/* ---------- product showcase / operative usps ---------- */
.zw-showcase { padding: 130px 0; background: #fff; }
.zw-showcase__row { display: grid; grid-template-columns: 1fr 1fr; gap: 60px; align-items: center; margin-bottom: 96px; }
.zw-showcase__row:last-child { margin-bottom: 0; }
.zw-showcase__row.is-reverse { grid-template-columns: 1fr 1fr; }
.zw-showcase__row.is-reverse .zw-showcase__copy { order: 2; }
.zw-showcase__copy h3 { margin: 0 0 18px; font-family: "Flama"; font-weight: 400; text-transform: uppercase; font-size: 40px; letter-spacing: .015em; line-height: 1.1; color: var(--arnio-stahlblau); }
.zw-showcase__copy h3 em { font-style: italic; font-weight: 700; color: var(--arnio-gruenblau); }
.zw-showcase__copy p { margin: 0 0 20px; font-size: 16px; line-height: 1.55; color: var(--color-fg-muted); max-width: 480px; }
.zw-showcase__list { list-style: none; margin: 24px 0 0; padding: 0; display: flex; flex-direction: column; gap: 14px; }
.zw-showcase__list li { display: grid; grid-template-columns: auto 1fr; gap: 14px; align-items: start; font-size: 14px; line-height: 1.5; color: var(--arnio-stahlblau); }
.zw-showcase__list li::before { content: "→"; font-family: "Flama"; font-weight: 700; color: var(--arnio-gruenblau); font-size: 16px; line-height: 1.4; }

/* mock screens for showcase */
.zw-mock { aspect-ratio: 4/3; background: var(--arnio-stahlblau); border-radius: 14px; padding: 10px; box-shadow: 0 25px 50px -20px rgba(0,52,74,.30); }
.zw-mock__inner { background: #fff; border-radius: 6px; height: 100%; overflow: hidden; display: flex; flex-direction: column; }
.zw-mock__chrome { display: flex; align-items: center; gap: 6px; padding: 8px 12px; background: var(--color-bg-soft); border-bottom: 1px solid var(--color-border); }
.zw-mock__chrome .dot { width: 9px; height: 9px; border-radius: 50%; background: var(--color-border-strong); }
.zw-mock__chrome .dot:nth-child(1) { background: #FF5F57; }
.zw-mock__chrome .dot:nth-child(2) { background: #FEBC2E; }
.zw-mock__chrome .dot:nth-child(3) { background: #28C840; }
.zw-mock__chrome .url { margin-left: 14px; flex: 1; padding: 4px 12px; background: #fff; border: 1px solid var(--color-border); border-radius: 4px; font-family: "Flama"; font-size: 11px; color: var(--color-fg-muted); }
.zw-mock__chrome .url strong { color: var(--arnio-stahlblau); font-weight: 600; }

.zw-mock__body { flex: 1; display: grid; grid-template-columns: 160px 1fr; min-height: 0; }
.zw-mock__sidebar { background: var(--arnio-stahlblau); color: #fff; padding: 14px 12px; display: flex; flex-direction: column; gap: 14px; }
.zw-mock__sidebar .brand { display: flex; align-items: center; gap: 8px; padding-bottom: 10px; border-bottom: 1px solid rgba(255,255,255,.12); }
.zw-mock__sidebar .brand strong { font-family: "Flama"; font-weight: 700; font-style: italic; font-size: 13px; }
.zw-mock__sidebar .brand sup { font-size: 8px; color: var(--arnio-gelbgruen); font-weight: 600; }
.zw-mock__sidebar nav { display: flex; flex-direction: column; gap: 2px; }
.zw-mock__sidebar nav a { font-family: "Flama"; font-size: 11px; padding: 7px 10px; border-radius: 3px; color: rgba(255,255,255,.7); display: flex; align-items: center; gap: 8px; cursor: default; }
.zw-mock__sidebar nav a.is-active { background: var(--arnio-gruenblau); color: #fff; }
.zw-mock__sidebar nav a svg { width: 12px; height: 12px; }
.zw-mock__sidebar .role { margin-top: auto; padding: 8px 10px; background: rgba(255,255,255,.06); border-radius: 3px; font-size: 9px; color: rgba(255,255,255,.7); display: flex; align-items: center; gap: 6px; letter-spacing: .04em; text-transform: uppercase; font-weight: 600; }

.zw-mock__main { padding: 16px 18px; display: flex; flex-direction: column; gap: 14px; min-height: 0; overflow: hidden; }
.zw-mock__main h6 { margin: 0; font-family: "Flama"; font-weight: 700; font-style: italic; font-size: 16px; color: var(--arnio-stahlblau); text-transform: uppercase; }
.zw-mock__main h6 + .sub { font-size: 10px; color: var(--color-fg-muted); margin-top: 0px; }

.zw-mock__kpis { display: grid; grid-template-columns: repeat(4, 1fr); gap: 8px; }
.zw-mock__kpi { padding: 8px 10px; background: var(--color-bg-soft); border-radius: 3px; }
.zw-mock__kpi .l { font-size: 8.5px; font-weight: 600; letter-spacing: .04em; text-transform: uppercase; color: var(--color-fg-muted); }
.zw-mock__kpi .v { font-family: "Flama"; font-weight: 700; font-style: italic; font-size: 17px; color: var(--arnio-stahlblau); margin-top: 2px; }
.zw-mock__kpi .v.alert { color: #C04646; }
.zw-mock__kpi .v.ok { color: #00875A; }

.zw-mock__chart { background: var(--color-bg-soft); border-radius: 4px; padding: 12px; display: flex; flex-direction: column; gap: 8px; flex: 1; min-height: 0; }
.zw-mock__chart-head { display: flex; justify-content: space-between; font-family: "Flama"; font-size: 10px; font-weight: 600; letter-spacing: .04em; text-transform: uppercase; color: var(--color-fg-muted); }
.zw-mock__chart-bars { display: flex; align-items: flex-end; gap: 5px; height: 100%; min-height: 0; }
.zw-mock__chart-bars .bar { flex: 1; background: var(--arnio-gruenblau); border-radius: 2px 2px 0 0; position: relative; }
.zw-mock__chart-bars .bar.over { background: var(--arnio-gelbgruen); }

/* employee selfservice mock */
.zw-mock--selfservice .zw-mock__main { padding: 0; }
.zw-mock__page-head { padding: 14px 18px 10px; border-bottom: 1px solid var(--color-border); display: flex; justify-content: space-between; align-items: center; }
.zw-mock__cards { padding: 14px 18px; display: grid; grid-template-columns: repeat(3, 1fr); gap: 10px; }
.zw-mock__balance { padding: 12px; border-radius: 4px; background: var(--color-bg-soft); border: 1px solid var(--color-border); }
.zw-mock__balance .l { font-size: 9px; font-weight: 600; letter-spacing: .04em; text-transform: uppercase; color: var(--color-fg-muted); }
.zw-mock__balance .v { font-family: "Flama"; font-weight: 700; font-style: italic; font-size: 22px; color: var(--arnio-stahlblau); margin-top: 4px; }
.zw-mock__balance .v.green { color: var(--arnio-gruenblau); }
.zw-mock__balance .sub { font-size: 9px; color: var(--color-fg-muted); margin-top: 2px; }
.zw-mock__rows { padding: 0 18px 14px; display: flex; flex-direction: column; gap: 4px; }
.zw-mock__row { display: grid; grid-template-columns: 60px 1fr 60px 70px 24px; gap: 10px; padding: 7px 10px; font-size: 10px; align-items: center; border-radius: 3px; }
.zw-mock__row.head { background: transparent; font-weight: 600; letter-spacing: .04em; text-transform: uppercase; color: var(--color-fg-muted); font-size: 8.5px; padding: 6px 10px; border-bottom: 1px dashed var(--color-border-strong); }
.zw-mock__row.alt { background: var(--color-bg-soft); }
.zw-mock__row .day { font-family: "Flama"; font-weight: 600; color: var(--arnio-stahlblau); }
.zw-mock__row .stat { font-size: 8.5px; font-weight: 600; letter-spacing: .04em; text-transform: uppercase; padding: 2px 6px; border-radius: 9999px; text-align: center; }
.zw-mock__row .stat.ok { background: var(--arnio-gruenblau-tint); color: var(--arnio-gruenblau); }
.zw-mock__row .stat.warn { background: rgba(192,70,70,.12); color: #C04646; }
.zw-mock__row .stat.note { background: rgba(213,212,0,.18); color: #6E6D00; }
.zw-mock__row .arrow { color: var(--color-fg-subtle); font-size: 12px; text-align: center; }

/* ---------- comparison table ---------- */
.zw-compare { padding: 130px 0; background: #fff; border-top: 1px solid var(--color-border); }
.zw-compare__intro { display: grid; grid-template-columns: 1fr 1fr; gap: 60px; align-items: end; margin-bottom: 56px; }
.zw-compare__intro .zw-section-head { margin-bottom: 0; }
.zw-compare__intro p { margin: 0; font-size: 16px; line-height: 1.55; color: var(--color-fg-muted); }
.zw-table { width: 100%; border-collapse: separate; border-spacing: 0; font-family: "Flama"; }
.zw-table thead th { padding: 18px 20px; text-align: left; font-size: 11px; font-weight: 600; letter-spacing: .06em; text-transform: uppercase; color: var(--color-fg-muted); border-bottom: 1px solid var(--color-border); }
.zw-table thead th.is-us { color: #fff; background: var(--arnio-stahlblau); border-radius: 4px 4px 0 0; position: relative; }
.zw-table thead th.is-us::after { content: ""; position: absolute; left: 20px; right: 20px; bottom: 8px; height: 2px; background: var(--arnio-gelbgruen); }
.zw-table thead th .label-product { font-family: "Flama"; font-weight: 700; font-style: italic; text-transform: none; font-size: 18px; letter-spacing: -.005em; color: #fff; display: block; margin-bottom: 4px; }
.zw-table thead th .label-product sup { color: var(--arnio-gelbgruen); font-size: 11px; }
.zw-table tbody td { padding: 16px 20px; font-size: 14px; line-height: 1.4; color: var(--arnio-stahlblau); border-bottom: 1px solid var(--color-border); vertical-align: middle; }
.zw-table tbody tr:hover { background: var(--color-bg-soft); }
.zw-table tbody td.is-us { background: rgba(0,145,183,.04); border-left: 1px solid var(--color-border); border-right: 1px solid var(--color-border); font-weight: 600; }
.zw-table tbody tr:last-child td.is-us { border-bottom: 1px solid var(--color-border); border-radius: 0 0 4px 4px; }
.zw-table .feat { font-weight: 500; color: var(--arnio-stahlblau); }
.zw-table .yes { color: var(--arnio-gruenblau); font-weight: 700; font-size: 16px; }
.zw-table .no { color: var(--color-fg-subtle); font-weight: 600; }
.zw-table .partial { color: #B5A700; font-weight: 600; }
.zw-table .cell { display: inline-flex; align-items: center; gap: 6px; }

/* ---------- target groups ---------- */
.zw-targets { padding: 130px 0; background: var(--arnio-gradient-himmel); position: relative; overflow: hidden; }
.zw-targets__inner { position: relative; }
.zw-targets__grid { display: grid; grid-template-columns: repeat(4, 1fr); gap: 18px; }
.zw-target { background: rgba(255,255,255,.85); backdrop-filter: blur(10px); border: 1px solid rgba(255,255,255,.6); border-radius: 4px; padding: 28px 24px; display: flex; flex-direction: column; gap: 14px; transition: transform var(--dur-2) var(--easing-standard), background var(--dur-2); }
.zw-target:hover { transform: translateY(-3px); background: #fff; }
.zw-target__icon { width: 40px; height: 40px; border-radius: 50%; background: var(--arnio-stahlblau); color: #fff; display: flex; align-items: center; justify-content: center; }
.zw-target__icon svg { width: 20px; height: 20px; }
.zw-target h4 { margin: 0; font-family: "Flama"; font-weight: 700; font-style: italic; text-transform: uppercase; font-size: 18px; letter-spacing: .005em; color: var(--arnio-stahlblau); }
.zw-target p { margin: 0; font-size: 13.5px; line-height: 1.5; color: var(--arnio-stahlblau-70); }
.zw-target .tag { display: inline-flex; align-items: center; gap: 6px; font-size: 10.5px; font-weight: 600; letter-spacing: .04em; text-transform: uppercase; color: var(--arnio-gruenblau); padding-top: 12px; border-top: 1px dashed rgba(0,52,74,.2); margin-top: auto; }

/* ---------- FAQ ---------- */
.zw-faq { padding: 130px 0; background: #fff; }
.zw-faq__layout { display: grid; grid-template-columns: 1fr 1.3fr; gap: 80px; align-items: start; }
.zw-faq__list { list-style: none; margin: 0; padding: 0; display: flex; flex-direction: column; gap: 12px; }
.zw-faq__row { border: 1px solid var(--color-border); border-radius: 4px; overflow: hidden; transition: border-color var(--dur-2); }
.zw-faq__row.is-open { border-color: var(--arnio-gruenblau); }
.zw-faq__q { width: 100%; display: flex; align-items: center; gap: 16px; padding: 18px 20px; background: #fff; border: 0; cursor: pointer; font-family: "Flama"; font-weight: 600; font-size: 16px; color: var(--color-fg); text-align: left; }
.zw-faq__q span:nth-child(2) { flex: 1; }
.zw-faq__chev { font-size: 22px; color: var(--arnio-gruenblau); width: 24px; text-align: center; }
.zw-faq__bubble { width: 36px; height: 36px; border-radius: 50%; display: inline-flex; align-items: center; justify-content: center; font-weight: 700; flex-shrink: 0; font-size: 16px; }
.zw-faq__bubble--q { background: var(--arnio-gruenblau); color: #fff; font-style: italic; }
.zw-faq__bubble--a { background: var(--arnio-gelbgruen); color: var(--arnio-stahlblau); }
.zw-faq__a { display: flex; gap: 16px; padding: 4px 20px 22px 20px; font-size: 14.5px; line-height: 1.55; color: var(--color-fg-muted); }
.zw-faq__a span:last-child { padding-top: 6px; }
.zw-faq__sidebar { padding: 32px; background: var(--color-bg-soft); border: 1px dashed var(--color-border-strong); border-radius: 4px; position: sticky; top: 100px; }
.zw-faq__sidebar h4 { margin: 0 0 12px; font-family: "Flama"; font-weight: 700; font-style: italic; text-transform: uppercase; font-size: 22px; letter-spacing: .005em; color: var(--arnio-stahlblau); }
.zw-faq__sidebar p { margin: 0 0 20px; font-size: 14px; line-height: 1.55; color: var(--color-fg-muted); }
.zw-faq__sidebar .person { display: flex; align-items: center; gap: 12px; margin: 16px 0 24px; padding: 16px 0; border-top: 1px dashed var(--color-border-strong); border-bottom: 1px dashed var(--color-border-strong); }
.zw-faq__sidebar .avatar { width: 48px; height: 48px; border-radius: 50%; background: var(--arnio-gruenblau); color: #fff; font-family: "Flama"; font-weight: 700; font-style: italic; font-size: 18px; display: flex; align-items: center; justify-content: center; }
.zw-faq__sidebar .person-name { font-family: "Flama"; font-weight: 600; font-size: 14px; color: var(--arnio-stahlblau); }
.zw-faq__sidebar .person-role { font-size: 12px; color: var(--color-fg-muted); margin-top: 2px; }

/* ---------- CTA ---------- */
.zw-cta { padding: 130px 0; background: var(--arnio-stahlblau); color: #fff; position: relative; overflow: hidden; }
.zw-cta::before { content: ""; position: absolute; left: -240px; top: 50%; transform: translateY(-50%); width: 480px; height: 480px; border-radius: 50%; background: radial-gradient(circle, rgba(97,184,212,.18), transparent 60%); }
.zw-cta::after { content: ""; position: absolute; right: -200px; top: 30%; width: 360px; height: 360px; border-radius: 50%; background: radial-gradient(circle, rgba(213,212,0,.10), transparent 60%); }
.zw-cta__inner { position: relative; display: grid; grid-template-columns: 1.2fr 1fr; gap: 60px; align-items: center; }
.zw-cta h2 { margin: 0; font-family: "Flama"; font-weight: 400; text-transform: uppercase; font-size: 56px; letter-spacing: .015em; line-height: 1.05; color: #fff; }
.zw-cta h2 em { font-style: italic; font-weight: 700; color: var(--arnio-gelbgruen); }
.zw-cta p { margin: 24px 0 32px; font-size: 17px; line-height: 1.55; color: rgba(255,255,255,.78); max-width: 540px; }
.zw-cta__ctas { display: flex; gap: 12px; flex-wrap: wrap; }

.zw-cta__card { background: #fff; color: var(--arnio-stahlblau); border-radius: 4px; padding: 32px; }
.zw-cta__card h4 { margin: 0 0 6px; font-family: "Flama"; font-weight: 700; font-style: italic; text-transform: uppercase; font-size: 20px; letter-spacing: .005em; }
.zw-cta__card .sub { font-size: 13px; color: var(--color-fg-muted); margin-bottom: 20px; }
.zw-cta__card form { display: flex; flex-direction: column; gap: 12px; }
.zw-cta__card label { display: flex; flex-direction: column; gap: 6px; font-size: 11px; font-weight: 600; letter-spacing: .04em; text-transform: uppercase; color: var(--color-fg-muted); }
.zw-cta__card input, .zw-cta__card select { font-family: "Flama"; font-size: 14px; padding: 12px 14px; border: 1px solid var(--color-border); border-radius: 2px; background: #fff; color: var(--arnio-stahlblau); transition: border-color var(--dur-1); }
.zw-cta__card input:focus, .zw-cta__card select:focus { outline: none; border-color: var(--arnio-gruenblau); box-shadow: var(--shadow-focus); }
.zw-cta__card .row { display: grid; grid-template-columns: 1fr 1fr; gap: 12px; }
.zw-cta__card button { margin-top: 6px; }
.zw-cta__card .legal { font-size: 11px; color: var(--color-fg-subtle); margin-top: 4px; line-height: 1.4; }

/* ---------- footer ---------- */
.zw-footer { background: var(--arnio-stahlblau); color: #fff; padding: 80px 0 0; border-top: 1px solid rgba(255,255,255,.08); }
.zw-footer__inner { display: grid; grid-template-columns: 1.2fr 2fr; gap: 64px; padding-bottom: 56px; }
.zw-footer__brand img { height: 56px; margin-bottom: 18px; }
.zw-footer__brand .product { font-family: "Flama"; font-weight: 700; font-style: italic; font-size: 22px; color: #fff; margin-bottom: 8px; }
.zw-footer__brand .product sup { font-size: 13px; color: var(--arnio-gelbgruen); font-weight: 600; }
.zw-footer__brand p { font-size: 13px; line-height: 1.55; color: rgba(255,255,255,.65); max-width: 360px; margin: 0; }
.zw-footer__cols { display: grid; grid-template-columns: repeat(4, 1fr); gap: 30px; }
.zw-footer__cols h6 { margin: 0 0 16px; font-size: 11px; letter-spacing: .08em; text-transform: uppercase; color: var(--arnio-gelbgruen); font-family: "Flama"; font-weight: 600; }
.zw-footer__cols ul { list-style: none; margin: 0; padding: 0; display: flex; flex-direction: column; gap: 10px; font-size: 13px; }
.zw-footer__cols a { color: rgba(255,255,255,.85); text-decoration: none; cursor: pointer; transition: color var(--dur-1); }
.zw-footer__cols a:hover { color: var(--arnio-gelbgruen); }
.zw-footer__legal { border-top: 1px solid rgba(255,255,255,.10); padding: 22px 40px; max-width: 1240px; margin: 0 auto; display: flex; justify-content: space-between; gap: 24px; font-size: 11px; color: rgba(255,255,255,.55); flex-wrap: wrap; }
.zw-footer__legal .badges { display: flex; gap: 18px; }
.zw-footer__legal .badges span { display: inline-flex; align-items: center; gap: 6px; }
.zw-footer__legal .badges .pill { width: 6px; height: 6px; border-radius: 50%; background: var(--arnio-gelbgruen); }
