:root {
    --bg: #f5f7f8;
    --surface: #ffffff;
    --surface-soft: #eef3f1;
    --text: #172026;
    --muted: #60707a;
    --border: #dde5e3;
    --primary: #1f6f55;
    --primary-dark: #14523f;
    --accent: #76ae43;
    --shadow: 0 18px 50px rgba(20, 45, 38, .12);
    --radius: 22px;
    --shell: 1160px;
}

* {
    box-sizing: border-box;
}

html {
    scroll-behavior: smooth;
    scroll-padding-top: 96px;
}

body {
    margin: 0;
    background: var(--bg);
    color: var(--text);
    font-family: system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;
    line-height: 1.6;
}

a {
    color: var(--primary);
    text-decoration: none;
}

a:hover {
    color: var(--primary-dark);
    text-decoration: underline;
}

img {
    max-width: 100%;
    height: auto;
}

.shell {
    width: min(var(--shell), calc(100% - 32px));
    margin-inline: auto;
}

.skip-link {
    position: absolute;
    left: -999px;
    top: 12px;
    z-index: 1000;
    background: var(--primary);
    color: #fff;
    padding: 10px 14px;
    border-radius: 8px;
}

.skip-link:focus {
    left: 12px;
}

.site-header {
    position: sticky;
    top: 0;
    z-index: 100;
    background: rgba(255,255,255,.92);
    backdrop-filter: blur(18px);
    border-bottom: 1px solid var(--border);
}

.nav-shell {
    min-height: 78px;
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 24px;
}

.brand {
    display: inline-flex;
    align-items: center;
    gap: 12px;
    color: var(--text);
}

.brand:hover {
    text-decoration: none;
}

.brand-mark {
    width: 46px;
    height: 46px;
    border-radius: 14px;
    display: grid;
    place-items: center;
    color: #fff;
    font-weight: 800;
    background: linear-gradient(135deg, var(--primary), var(--accent));
    box-shadow: 0 10px 24px rgba(31, 111, 85, .25);
}

.brand small {
    display: block;
    color: var(--muted);
    font-size: .78rem;
    margin-top: -2px;
}

.main-nav {
    display: flex;
    align-items: center;
    gap: 6px;
}

.main-nav > a,
.nav-dropdown > a {
    display: inline-flex;
    align-items: center;
    padding: 10px 12px;
    border-radius: 999px;
    color: var(--text);
    font-weight: 600;
}

.main-nav a:hover,
.nav-dropdown:hover > a {
    background: var(--surface-soft);
    text-decoration: none;
}

.nav-dropdown {
    position: relative;
}

/* Hover-Brücke: verhindert, dass das Dropdown beim Weg vom Button
   zum Menü durch den kleinen Abstand sofort schließt. */
.nav-dropdown::after {
    content: "";
    position: absolute;
    left: 0;
    right: 0;
    top: 100%;
    height: 14px;
    display: none;
}

.nav-dropdown:hover::after,
.nav-dropdown:focus-within::after {
    display: block;
}

.dropdown-menu {
    position: absolute;
    right: 0;
    top: calc(100% + 12px);
    z-index: 1000;
    width: 290px;
    padding: 10px;
    border: 1px solid var(--border);
    border-radius: 18px;
    background: var(--surface);
    box-shadow: var(--shadow);
    display: none;
}

.dropdown-menu a {
    display: block;
    padding: 10px 12px;
    border-radius: 12px;
    color: var(--text);
}

.dropdown-menu a:hover {
    background: var(--surface-soft);
    text-decoration: none;
}

.nav-dropdown:hover .dropdown-menu,
.nav-dropdown:focus-within .dropdown-menu {
    display: block;
}

.nav-toggle,
.nav-button {
    display: none;
}

.hero,
.page-hero {
    position: relative;
    overflow: hidden;
    padding: 96px 0 72px;
    background:
        radial-gradient(circle at 10% 10%, rgba(118,174,67,.18), transparent 30%),
        radial-gradient(circle at 90% 20%, rgba(31,111,85,.16), transparent 34%),
        linear-gradient(180deg, #fff, var(--bg));
}

.page-hero.compact {
    padding: 72px 0 44px;
}

.hero-grid {
    display: grid;
    grid-template-columns: 1.15fr .85fr;
    gap: 44px;
    align-items: center;
}

.eyebrow {
    margin: 0 0 12px;
    color: var(--primary);
    font-weight: 800;
    letter-spacing: .08em;
    text-transform: uppercase;
    font-size: .78rem;
}

h1,
h2,
h3 {
    line-height: 1.15;
    margin: 0 0 16px;
}

h1 {
    font-size: clamp(2.4rem, 5vw, 4.7rem);
    letter-spacing: -.05em;
}

h2 {
    font-size: clamp(1.7rem, 3vw, 2.6rem);
    letter-spacing: -.035em;
}

h3 {
    font-size: 1.25rem;
}

.lead {
    color: var(--muted);
    font-size: clamp(1.05rem, 1.8vw, 1.28rem);
    max-width: 760px;
}

.hero-actions,
.cookie-actions {
    display: flex;
    flex-wrap: wrap;
    gap: 12px;
    margin-top: 28px;
}

.btn {
    appearance: none;
    border: 0;
    cursor: pointer;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-height: 46px;
    padding: 12px 18px;
    border-radius: 999px;
    font-weight: 800;
    transition: transform .18s ease, box-shadow .18s ease, background .18s ease;
}

.btn:hover {
    transform: translateY(-1px);
    text-decoration: none;
}

.btn-primary {
    color: #fff;
    background: var(--primary);
    box-shadow: 0 12px 28px rgba(31, 111, 85, .25);
}

.btn-primary:hover {
    color: #fff;
    background: var(--primary-dark);
}

.btn-secondary {
    color: var(--text);
    background: var(--surface-soft);
}

.btn-light {
    color: var(--primary-dark);
    background: #fff;
}

.hero-card {
    background: rgba(255,255,255,.84);
    border: 1px solid var(--border);
    box-shadow: var(--shadow);
    border-radius: 32px;
    padding: 30px;
}

.hero-logo {
    display: block;
    max-width: 260px;
    margin: 0 auto 28px;
}

.mini-list {
    display: grid;
    gap: 10px;
}

.mini-list span,
.tag-list span {
    padding: 10px 12px;
    background: var(--surface-soft);
    border-radius: 999px;
    font-weight: 700;
}

.section {
    padding: 76px 0;
}

.section-muted {
    background: var(--surface-soft);
}

.section-heading {
    max-width: 760px;
    margin-bottom: 34px;
}

.section-heading p,
.text-block p,
.feature-card p,
.service-panel p {
    color: var(--muted);
}

.card-grid {
    display: grid;
    grid-template-columns: repeat(4, 1fr);
    gap: 18px;
}

.feature-card,
.contact-card,
.legal-card,
.service-panel {
    background: var(--surface);
    border: 1px solid var(--border);
    border-radius: var(--radius);
    box-shadow: 0 8px 28px rgba(20,45,38,.06);
}

.feature-card {
    padding: 24px;
}

.icon {
    width: 48px;
    height: 48px;
    border-radius: 16px;
    display: grid;
    place-items: center;
    margin-bottom: 18px;
    color: #fff;
    font-weight: 900;
    background: linear-gradient(135deg, var(--primary), var(--accent));
}

.split,
.contact-grid {
    display: grid;
    grid-template-columns: .8fr 1.2fr;
    gap: 42px;
    align-items: start;
}

.text-link {
    font-weight: 800;
}

.cta {
    padding: 76px 0;
}

.cta-box {
    background: linear-gradient(135deg, var(--primary-dark), var(--primary));
    color: #fff;
    border-radius: 34px;
    padding: clamp(28px, 5vw, 52px);
    display: flex;
    justify-content: space-between;
    align-items: center;
    gap: 28px;
    box-shadow: var(--shadow);
}

.cta-box .eyebrow,
.cta-box p {
    color: rgba(255,255,255,.82);
}

.service-layout {
    display: grid;
    grid-template-columns: 280px 1fr;
    gap: 28px;
    align-items: start;
}

.service-nav {
    position: sticky;
    top: 100px;
    display: grid;
    gap: 8px;
    background: var(--surface);
    border: 1px solid var(--border);
    border-radius: var(--radius);
    padding: 14px;
}

.service-nav a {
    padding: 10px 12px;
    border-radius: 12px;
    color: var(--text);
    font-weight: 700;
}

.service-nav a:hover {
    background: var(--surface-soft);
    text-decoration: none;
}

.service-content {
    display: grid;
    gap: 18px;
}

.service-panel {
    padding: clamp(24px, 4vw, 38px);
}

.check-list {
    list-style: none;
    padding: 0;
    margin: 20px 0 0;
    display: grid;
    gap: 10px;
}

.check-list li {
    position: relative;
    padding-left: 28px;
}

.check-list li::before {
    content: "✓";
    position: absolute;
    left: 0;
    top: 0;
    color: var(--primary);
    font-weight: 900;
}

.two-columns {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 24px;
}

.tag-list {
    display: flex;
    flex-wrap: wrap;
    gap: 10px;
    margin-top: 22px;
}

.contact-card {
    padding: clamp(24px, 4vw, 38px);
}

.contact-card.highlight {
    border-color: rgba(31,111,85,.35);
}

address {
    font-style: normal;
}

.contact-list {
    display: grid;
    gap: 18px;
    margin: 0;
}

.contact-list div {
    display: grid;
    grid-template-columns: 120px 1fr;
    gap: 12px;
}

.contact-list dt {
    color: var(--muted);
    font-weight: 800;
}

.contact-list dd {
    margin: 0;
    font-weight: 800;
}

.legal-section {
    padding-top: 34px;
}

.legal-card {
    padding: clamp(24px, 4vw, 42px);
    max-width: 920px;
}

.legal-card h1 {
    font-size: 2rem;
    letter-spacing: -.02em;
}

.legal-card h2,
.legal-card h3 {
    margin-top: 28px;
}

.legal-note {
    margin-top: 34px;
    padding: 16px;
    border-left: 4px solid var(--accent);
    background: var(--surface-soft);
    border-radius: 12px;
}

.cookie-consent {
    position: fixed;
    z-index: 200;
    left: 0;
    right: 0;
    bottom: 0;
    padding: 16px 0;
    background: rgba(255,255,255,.96);
    border-top: 1px solid var(--border);
    box-shadow: 0 -12px 30px rgba(20,45,38,.08);
}

.cookie-inner {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 22px;
}

.cookie-inner p {
    margin: 4px 0 0;
    color: var(--muted);
}

.site-footer {
    padding: 54px 0 28px;
    color: rgba(255,255,255,.82);
    background: #101a17;
}

.site-footer a {
    color: #fff;
    display: block;
}

.footer-grid {
    display: grid;
    grid-template-columns: 1.5fr 1fr 1fr;
    gap: 34px;
}

.footer-grid span {
    display: block;
    color: var(--accent);
    font-weight: 900;
    margin-bottom: 8px;
}

.footer-bottom {
    margin-top: 34px;
    padding-top: 20px;
    border-top: 1px solid rgba(255,255,255,.12);
    font-size: .9rem;
}

@media (max-width: 920px) {
    .nav-button {
        display: grid;
        gap: 5px;
        cursor: pointer;
    }

    .nav-button span {
        width: 28px;
        height: 3px;
        background: var(--text);
        border-radius: 99px;
    }

    .main-nav {
        position: absolute;
        left: 16px;
        right: 16px;
        top: 78px;
        display: none;
        flex-direction: column;
        align-items: stretch;
        background: var(--surface);
        border: 1px solid var(--border);
        border-radius: 22px;
        padding: 12px;
        box-shadow: var(--shadow);
    }

    .nav-toggle:checked ~ .main-nav {
        display: flex;
    }

    .nav-dropdown::after {
        display: none !important;
    }

    .dropdown-menu {
        position: static;
        display: block;
        width: auto;
        margin: 4px 0 0 14px;
        box-shadow: none;
        border-radius: 14px;
    }

    .hero-grid,
    .split,
    .contact-grid,
    .service-layout {
        grid-template-columns: 1fr;
    }

    .service-nav {
        position: static;
    }

    .card-grid {
        grid-template-columns: repeat(2, 1fr);
    }

    .cta-box,
    .cookie-inner {
        align-items: flex-start;
        flex-direction: column;
    }
}

@media (max-width: 640px) {
    .card-grid,
    .two-columns,
    .footer-grid {
        grid-template-columns: 1fr;
    }

    .contact-list div {
        grid-template-columns: 1fr;
        gap: 2px;
    }

    .hero,
    .page-hero {
        padding: 58px 0 42px;
    }

    .section,
    .cta {
        padding: 48px 0;
    }
}

/* Moderne Scroll-Effekte und Leistungsbereiche */
.js [data-reveal] {
    opacity: 0;
    transform: translateY(34px);
    transition:
        opacity .75s cubic-bezier(.2,.65,.2,1),
        transform .75s cubic-bezier(.2,.65,.2,1);
    transition-delay: var(--reveal-delay, 0ms);
    will-change: opacity, transform;
}

.js [data-reveal="left"] {
    transform: translateX(-42px);
}

.js [data-reveal="right"] {
    transform: translateX(42px);
}

.js [data-reveal].is-visible {
    opacity: 1;
    transform: translate(0, 0);
}

.service-hero {
    min-height: 620px;
    display: grid;
    align-items: center;
    color: #fff;
    background:
        linear-gradient(90deg, rgba(10, 26, 22, .9), rgba(10, 26, 22, .55)),
        radial-gradient(circle at 85% 18%, rgba(118,174,67,.35), transparent 28%),
        linear-gradient(135deg, #0f271f, #1f6f55);
}

.service-hero .eyebrow,
.service-hero .lead {
    color: rgba(255,255,255,.82);
}

.service-hero-grid {
    display: grid;
    grid-template-columns: minmax(0, 1.1fr) 360px;
    gap: 48px;
    align-items: center;
}

.hero-stat-card {
    min-height: 330px;
    padding: 34px;
    border: 1px solid rgba(255,255,255,.18);
    border-radius: 34px;
    background: rgba(255,255,255,.12);
    backdrop-filter: blur(14px);
    box-shadow: 0 30px 80px rgba(0,0,0,.22);
}

.stat-number {
    display: block;
    font-size: clamp(5rem, 12vw, 9rem);
    line-height: .85;
    font-weight: 900;
    letter-spacing: -.08em;
}

.stat-label {
    display: block;
    margin-top: 14px;
    color: #fff;
    font-size: 1.15rem;
    font-weight: 900;
}

.hero-stat-card p {
    margin-top: 16px;
    color: rgba(255,255,255,.78);
}

.service-overview {
    position: relative;
    overflow: hidden;
}

.service-overview::before {
    content: "";
    position: absolute;
    inset: auto -8% -28% auto;
    width: 440px;
    height: 440px;
    border-radius: 999px;
    background: rgba(31,111,85,.12);
    pointer-events: none;
}

.service-teaser-grid {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 18px;
}

.service-teaser {
    min-height: 150px;
    padding: 22px;
    display: flex;
    flex-direction: column;
    justify-content: space-between;
    color: var(--text);
    border: 1px solid var(--border);
    border-radius: 24px;
    background: #fff;
    box-shadow: 0 12px 32px rgba(20,45,38,.06);
    transition: transform .22s ease, box-shadow .22s ease, border-color .22s ease;
}

.service-teaser:hover {
    transform: translateY(-5px);
    border-color: rgba(31,111,85,.35);
    box-shadow: 0 22px 48px rgba(20,45,38,.12);
    text-decoration: none;
}

.service-teaser span {
    color: var(--primary);
    font-weight: 900;
}

.service-teaser strong {
    font-size: 1.12rem;
}

.service-stage-section {
    padding: 92px 0 20px;
    background: var(--bg);
}

.service-stage-layout {
    display: grid;
    grid-template-columns: 270px minmax(0, 1fr);
    gap: 34px;
    align-items: start;
}

.service-stage-nav {
    position: sticky;
    top: 102px;
    z-index: 3;
    display: grid;
    gap: 6px;
    padding: 16px;
    border: 1px solid var(--border);
    border-radius: 24px;
    background: rgba(255,255,255,.88);
    backdrop-filter: blur(16px);
    box-shadow: 0 16px 40px rgba(20,45,38,.08);
}

.service-stage-nav span {
    margin: 0 0 8px 10px;
    color: var(--muted);
    font-size: .78rem;
    font-weight: 900;
    letter-spacing: .08em;
    text-transform: uppercase;
}

.service-stage-nav a {
    padding: 10px 12px;
    border-radius: 14px;
    color: var(--text);
    font-weight: 800;
}

.service-stage-nav a:hover,
.service-stage-nav a.is-active {
    color: #fff;
    background: var(--primary);
    text-decoration: none;
}

.service-stage-list {
    display: grid;
    gap: clamp(48px, 8vw, 96px);
}

.service-stage {
    min-height: 560px;
    display: grid;
    grid-template-columns: minmax(0, .95fr) minmax(360px, .75fr);
    gap: 28px;
    align-items: center;
    scroll-margin-top: 110px;
}

.service-stage.is-reversed {
    grid-template-columns: minmax(360px, .75fr) minmax(0, .95fr);
}

.service-stage.is-reversed .service-stage-media {
    order: 2;
}

.service-stage.is-reversed .service-stage-card {
    order: 1;
}

.service-stage-media {
    min-height: 520px;
    border-radius: 34px;
    background-image:
        linear-gradient(135deg, rgba(13,35,29,.38), rgba(31,111,85,.12)),
        var(--service-bg),
        linear-gradient(135deg, #18352d, #76ae43);
    background-size: cover;
    background-position: center;
    box-shadow: 0 28px 72px rgba(20,45,38,.16);
    position: relative;
    overflow: hidden;
}

.service-stage-media::after {
    content: "";
    position: absolute;
    inset: 22px;
    border: 1px solid rgba(255,255,255,.34);
    border-radius: 24px;
}

.service-stage-card {
    margin-left: -72px;
    padding: clamp(26px, 4vw, 42px);
    border: 1px solid var(--border);
    border-radius: 30px;
    background: rgba(255,255,255,.94);
    backdrop-filter: blur(14px);
    box-shadow: 0 24px 70px rgba(20,45,38,.14);
}

.service-stage.is-reversed .service-stage-card {
    margin-left: 0;
    margin-right: -72px;
}

.service-stage-card p {
    color: var(--muted);
}

.service-stage-card h2 {
    max-width: 720px;
}

@media (prefers-reduced-motion: reduce) {
    html {
        scroll-behavior: auto;
    }

    .js [data-reveal] {
        opacity: 1;
        transform: none;
        transition: none;
    }
}

@media (max-width: 1020px) {
    .service-hero-grid,
    .service-stage-layout,
    .service-stage,
    .service-stage.is-reversed {
        grid-template-columns: 1fr;
    }

    .service-stage-nav {
        position: static;
    }

    .service-stage.is-reversed .service-stage-media,
    .service-stage.is-reversed .service-stage-card {
        order: initial;
    }

    .service-stage-card,
    .service-stage.is-reversed .service-stage-card {
        margin: -90px 18px 0;
        position: relative;
        z-index: 2;
    }
}

@media (max-width: 760px) {
    .service-teaser-grid {
        grid-template-columns: 1fr;
    }

    .service-hero {
        min-height: auto;
    }

    .hero-stat-card {
        min-height: auto;
    }

    .service-stage-section {
        padding-top: 54px;
    }

    .service-stage {
        min-height: auto;
    }

    .service-stage-media {
        min-height: 330px;
        border-radius: 26px;
    }

    .service-stage-card,
    .service-stage.is-reversed .service-stage-card {
        margin: -70px 10px 0;
    }
}

/* ------------------------------------------------------------
   Mobile-Korrekturen: kein Textüberlauf, scrollbares Menü,
   Logo-Grafik im IS-Icon
   ------------------------------------------------------------ */
html,
body {
    max-width: 100%;
    overflow-x: hidden;
}

body {
    -webkit-text-size-adjust: 100%;
}

main,
section,
article,
header,
footer,
.shell,
.hero-grid,
.service-hero-grid,
.service-stage-layout,
.service-stage,
.service-stage-card,
.legal-card,
.contact-card,
.feature-card {
    min-width: 0;
}

h1,
h2,
h3,
p,
li,
dd,
dt,
a,
strong,
span {
    overflow-wrap: anywhere;
    word-break: normal;
}

h1,
h2,
h3 {
    hyphens: auto;
}

.brand {
    min-width: 0;
    flex-shrink: 1;
}

.brand > span:last-child {
    min-width: 0;
}

.brand strong,
.brand small {
    max-width: 210px;
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
}

.brand-mark {
    position: relative;
    isolation: isolate;
    overflow: hidden;
    flex: 0 0 auto;
    background: linear-gradient(135deg, rgba(31,111,85,.92), rgba(118,174,67,.92));
}

.brand-mark::before {
    content: "";
    position: absolute;
    inset: -7px;
    z-index: -1;
    background-image:
        linear-gradient(135deg, rgba(31,111,85,.68), rgba(118,174,67,.58)),
        url('/images/insotec-symbol.png');
    background-size: cover, 165%;
    background-position: center, center;
    background-repeat: no-repeat;
    opacity: .8;
    filter: saturate(1.05) contrast(1.08);
}

.brand-mark::after {
    content: "";
    position: absolute;
    inset: 0;
    z-index: -1;
    background: rgba(31,111,85,.42);
}

@media (max-width: 920px) {
    .site-header {
        overflow: visible;
    }

    .nav-shell {
        min-height: 74px;
        gap: 10px;
    }

    .main-nav {
        top: 74px;
        max-height: calc(100dvh - 88px);
        overflow-y: auto;
        overscroll-behavior: contain;
        -webkit-overflow-scrolling: touch;
        padding-bottom: 18px;
    }

    .dropdown-menu {
        max-height: none;
        overflow: visible;
    }

    .main-nav > a,
    .nav-dropdown > a,
    .dropdown-menu a {
        min-height: 44px;
        align-items: center;
    }
}

@media (max-width: 640px) {
    .shell {
        width: min(var(--shell), calc(100% - 24px));
    }

    .brand-mark {
        width: 44px;
        height: 44px;
        border-radius: 13px;
        font-size: .82rem;
    }

    .brand {
        gap: 9px;
    }

    .brand strong {
        max-width: 170px;
        font-size: .94rem;
    }

    .brand small {
        max-width: 170px;
        font-size: .68rem;
    }

    .nav-button span {
        width: 26px;
    }

    h1 {
        font-size: clamp(2rem, 11vw, 2.65rem);
        letter-spacing: -.04em;
    }

    h2 {
        font-size: clamp(1.55rem, 8vw, 2.05rem);
        letter-spacing: -.03em;
    }

    .lead {
        font-size: 1.02rem;
    }

    .hero,
    .page-hero,
    .page-hero.compact {
        padding: 44px 0 34px;
    }

    .hero-card,
    .legal-card,
    .contact-card,
    .service-panel,
    .service-stage-card {
        border-radius: 22px;
    }

    .legal-card {
        padding: 22px 18px;
    }

    .legal-card h1 {
        font-size: clamp(1.65rem, 8vw, 2rem);
    }

    .legal-card h2,
    .legal-card h3 {
        font-size: clamp(1.35rem, 6vw, 1.75rem);
    }

    .service-stage-card,
    .service-stage.is-reversed .service-stage-card {
        margin: -56px 8px 0;
        padding: 22px 18px;
    }

    .service-stage-media {
        min-height: 260px;
        border-radius: 22px;
    }

    .service-stage-media::after {
        inset: 14px;
        border-radius: 18px;
    }

    .service-stage-nav {
        border-radius: 20px;
        padding: 12px;
    }
}

@media (max-width: 380px) {
    .shell {
        width: min(var(--shell), calc(100% - 18px));
    }

    .nav-shell {
        min-height: 70px;
    }

    .main-nav {
        left: 9px;
        right: 9px;
        top: 70px;
        max-height: calc(100dvh - 80px);
    }

    .brand-mark {
        width: 40px;
        height: 40px;
        border-radius: 12px;
    }

    .brand strong,
    .brand small {
        max-width: 145px;
    }

    .brand small {
        font-size: .64rem;
    }

    h1 {
        font-size: clamp(1.85rem, 10vw, 2.25rem);
    }
}


/* ------------------------------------------------------------
   Leistungsportfolio About-Seite mit Bildbereichen
   ------------------------------------------------------------ */
.portfolio-hero {
    background:
        linear-gradient(90deg, rgba(9, 25, 21, .88), rgba(9, 25, 21, .58)),
        var(--hero-bg),
        linear-gradient(135deg, #0f271f, #1f6f55);
    background-size: cover;
    background-position: center;
}

.portfolio-hero-image {
    position: relative;
    padding: 18px;
    border-radius: 34px;
    border: 1px solid rgba(255,255,255,.18);
    background: rgba(255,255,255,.12);
    box-shadow: 0 30px 80px rgba(0,0,0,.24);
    backdrop-filter: blur(14px);
}

.portfolio-hero-image img {
    display: block;
    width: 100%;
    border-radius: 24px;
    object-fit: cover;
}

.portfolio-kpi-grid {
    display: grid;
    grid-template-columns: repeat(4, 1fr);
    gap: 18px;
}

.portfolio-teaser-grid {
    grid-template-columns: repeat(4, 1fr);
}

.portfolio-stage-nav {
    max-height: calc(100dvh - 128px);
    overflow-y: auto;
    overscroll-behavior: contain;
    scrollbar-width: thin;
}

.portfolio-stage-list {
    gap: clamp(54px, 7vw, 92px);
}

.portfolio-stage {
    min-height: 640px;
}

.portfolio-stage-media {
    display: grid;
    place-items: center;
    padding: clamp(18px, 3vw, 30px);
    background-image:
        linear-gradient(135deg, rgba(13,35,29,.18), rgba(31,111,85,.08)),
        var(--service-bg),
        linear-gradient(135deg, #edf5f8, #dfeee8);
}

.portfolio-stage-media img {
    position: relative;
    z-index: 1;
    width: min(88%, 620px);
    max-height: 420px;
    object-fit: contain;
    border-radius: 22px;
    filter: drop-shadow(0 22px 34px rgba(12, 32, 27, .18));
}

.portfolio-stage-card h3 {
    margin-top: 26px;
    font-size: 1.08rem;
}

.lead-card {
    font-size: 1.06rem;
    font-weight: 650;
    color: #334149 !important;
}

.portfolio-list {
    grid-template-columns: 1fr;
}

.compact-tags span {
    font-size: .9rem;
    padding: 8px 10px;
}

@media (max-width: 1180px) {
    .portfolio-teaser-grid,
    .portfolio-kpi-grid {
        grid-template-columns: repeat(2, 1fr);
    }
}

@media (max-width: 1020px) {
    .portfolio-stage-nav {
        position: sticky;
        top: 86px;
        max-height: 46dvh;
    }

    .portfolio-stage {
        min-height: auto;
    }
}

@media (max-width: 760px) {
    .portfolio-teaser-grid,
    .portfolio-kpi-grid {
        grid-template-columns: 1fr;
    }

    .portfolio-stage-nav {
        position: static;
        max-height: 55dvh;
    }

    .portfolio-stage-media img {
        width: min(92%, 520px);
        max-height: 250px;
    }
}

@media (max-width: 640px) {
    .portfolio-hero-image {
        padding: 10px;
        border-radius: 24px;
    }

    .portfolio-hero-image img {
        border-radius: 18px;
    }

    .portfolio-stage-card h3 {
        font-size: 1rem;
    }
}

/* ------------------------------------------------------------
   Stärkere Scroll-Dynamik für die Leistungsseite
   Text kommt von unten, Bilder fliegen seitlich ein.
   ------------------------------------------------------------ */
.js [data-reveal] {
    opacity: 0;
    transform: translate3d(0, 92px, 0) scale(.985);
    transition:
        opacity .95s cubic-bezier(.16, 1, .3, 1),
        transform .95s cubic-bezier(.16, 1, .3, 1),
        filter .95s cubic-bezier(.16, 1, .3, 1);
    transition-delay: var(--reveal-delay, 0ms);
    will-change: opacity, transform;
}

.js [data-reveal="left"] {
    transform: translate3d(-150px, 0, 0) scale(.975);
}

.js [data-reveal="right"] {
    transform: translate3d(150px, 0, 0) scale(.975);
}

.js [data-reveal].is-visible {
    opacity: 1;
    transform: translate3d(0, 0, 0) scale(1);
}

/* Auf der About-/Leistungsseite sollen die Textkarten immer von unten kommen. */
.js .portfolio-stage-card[data-reveal],
.js .service-stage-card[data-reveal] {
    transform: translate3d(0, 120px, 0) scale(.985);
}

.js .portfolio-stage-card[data-reveal].is-visible,
.js .service-stage-card[data-reveal].is-visible {
    transform: translate3d(0, 0, 0) scale(1);
}

/* Das Bild im Medienbereich erhält zusätzlich einen kleinen Pop-in-Effekt. */
.js .portfolio-stage-media img,
.js .portfolio-hero-image img {
    opacity: 0;
    transform: translate3d(0, 24px, 0) scale(.94);
    transition:
        opacity .85s cubic-bezier(.16, 1, .3, 1),
        transform .85s cubic-bezier(.16, 1, .3, 1);
    transition-delay: calc(var(--reveal-delay, 0ms) + 260ms);
}

.js .portfolio-stage-media.is-visible img,
.js .portfolio-hero-image.is-visible img {
    opacity: 1;
    transform: translate3d(0, 0, 0) scale(1);
}

/* Inhalt in den Textkarten staffeln: Überschrift, Text und Listen erscheinen nacheinander. */
.js .portfolio-stage-card > *,
.js .service-stage-card > * {
    opacity: 0;
    transform: translate3d(0, 18px, 0);
    transition:
        opacity .62s cubic-bezier(.16, 1, .3, 1),
        transform .62s cubic-bezier(.16, 1, .3, 1);
}

.js .portfolio-stage-card.is-visible > *,
.js .service-stage-card.is-visible > * {
    opacity: 1;
    transform: translate3d(0, 0, 0);
}

.js .portfolio-stage-card.is-visible > :nth-child(1),
.js .service-stage-card.is-visible > :nth-child(1) { transition-delay: 220ms; }
.js .portfolio-stage-card.is-visible > :nth-child(2),
.js .service-stage-card.is-visible > :nth-child(2) { transition-delay: 290ms; }
.js .portfolio-stage-card.is-visible > :nth-child(3),
.js .service-stage-card.is-visible > :nth-child(3) { transition-delay: 360ms; }
.js .portfolio-stage-card.is-visible > :nth-child(4),
.js .service-stage-card.is-visible > :nth-child(4) { transition-delay: 430ms; }
.js .portfolio-stage-card.is-visible > :nth-child(n+5),
.js .service-stage-card.is-visible > :nth-child(n+5) { transition-delay: 500ms; }

/* Teaser und KPI-Karten wirken beim Scrollen lebendiger, ohne unruhig zu werden. */
.js .portfolio-kpi-grid [data-reveal],
.js .portfolio-teaser-grid [data-reveal] {
    transform: translate3d(0, 74px, 0) scale(.96);
}

.js .portfolio-kpi-grid [data-reveal].is-visible,
.js .portfolio-teaser-grid [data-reveal].is-visible {
    transform: translate3d(0, 0, 0) scale(1);
}

@media (max-width: 760px) {
    .js [data-reveal="left"],
    .js [data-reveal="right"] {
        transform: translate3d(0, 72px, 0) scale(.985);
    }

    .js [data-reveal="left"].is-visible,
    .js [data-reveal="right"].is-visible {
        transform: translate3d(0, 0, 0) scale(1);
    }

    .js .portfolio-stage-card[data-reveal],
    .js .service-stage-card[data-reveal] {
        transform: translate3d(0, 82px, 0) scale(.985);
    }
}

@media (prefers-reduced-motion: reduce) {
    .js [data-reveal],
    .js .portfolio-stage-media img,
    .js .portfolio-hero-image img,
    .js .portfolio-stage-card > *,
    .js .service-stage-card > * {
        opacity: 1 !important;
        transform: none !important;
        transition: none !important;
    }
}

/* ------------------------------------------------------------
   Korrektur 2026-06-21:
   modernes Leistungs-Dropdown, echte Sprungmarken, stärkere Flow-In-Effekte,
   kleineres IS-Hintergrundsymbol.
   ------------------------------------------------------------ */

.brand-mark {
    background: linear-gradient(135deg, rgba(31,111,85,.1), rgba(118,174,67,.10));
}

.brand-mark::before {
    inset: 0;
    background-image:
        linear-gradient(135deg, rgba(31,111,85,.52), rgba(118,174,67,.38)),
        url('/images/insotec-symbol-mark.png');
    background-size: cover, 72%;
    background-position: center, center;
    background-repeat: no-repeat;
    opacity: .94;
    filter: saturate(1.05) contrast(1.03);
}

.brand-mark::after {
    background: rgba(31,111,85,.10);
}

.dropdown-menu-services {
    width: min(520px, calc(100vw - 42px));
    max-height: min(72dvh, 620px);
    overflow-y: auto;
    overscroll-behavior: contain;
    padding: 16px;
    border-radius: 26px;
    background: rgba(255,255,255,.96);
    backdrop-filter: blur(18px);
    box-shadow: 0 28px 70px rgba(20,45,38,.16);
}

.dropdown-menu-title {
    margin: 2px 8px 12px;
    color: var(--muted);
    font-size: .76rem;
    font-weight: 900;
    letter-spacing: .1em;
    text-transform: uppercase;
}

.dropdown-menu-services a {
    display: grid;
    grid-template-columns: 36px minmax(0, 1fr);
    align-items: center;
    gap: 10px;
    min-height: 44px;
    padding: 10px 12px;
    border: 1px solid transparent;
    border-radius: 16px;
    color: var(--text);
    transition: background .18s ease, color .18s ease, border-color .18s ease, transform .18s ease;
}

.dropdown-menu-services a span {
    display: grid;
    place-items: center;
    width: 30px;
    height: 30px;
    border-radius: 10px;
    color: var(--primary-dark);
    background: var(--surface-soft);
    font-size: .72rem;
    font-weight: 900;
    overflow-wrap: normal;
}

.dropdown-menu-services a strong {
    font-weight: 850;
    overflow-wrap: anywhere;
}

.dropdown-menu-services a:hover,
.dropdown-menu-services a:focus-visible {
    color: #fff;
    background: linear-gradient(135deg, var(--primary), var(--primary-dark));
    border-color: rgba(255,255,255,.36);
    transform: translateX(4px);
    text-decoration: none;
}

.dropdown-menu-services a:hover span,
.dropdown-menu-services a:focus-visible span {
    color: var(--primary-dark);
    background: rgba(255,255,255,.9);
}

@media (min-width: 921px) {
    .dropdown-menu-services {
        display: grid;
        grid-template-columns: 1fr 1fr;
        gap: 6px;
    }

    .dropdown-menu-services .dropdown-menu-title {
        grid-column: 1 / -1;
    }
}

/* Deutlichere Flow-In-Animationen auf der Leistungsseite */
.js .portfolio-stage {
    overflow: clip;
}

.js .portfolio-stage-media[data-reveal],
.js .service-stage-media[data-reveal],
.js .portfolio-hero-image[data-reveal] {
    opacity: 0;
    filter: blur(4px);
    transform: translate3d(-220px, 0, 0) scale(.965) rotate(-1deg);
    transition:
        opacity 1.05s cubic-bezier(.16, 1, .3, 1),
        transform 1.05s cubic-bezier(.16, 1, .3, 1),
        filter 1.05s cubic-bezier(.16, 1, .3, 1);
    transition-delay: var(--reveal-delay, 0ms);
}

.js .portfolio-stage.is-reversed .portfolio-stage-media[data-reveal],
.js .service-stage.is-reversed .service-stage-media[data-reveal],
.js .portfolio-stage-media[data-reveal="right"],
.js .service-stage-media[data-reveal="right"],
.js .portfolio-hero-image[data-reveal="right"] {
    transform: translate3d(220px, 0, 0) scale(.965) rotate(1deg);
}

.js .portfolio-stage-card[data-reveal],
.js .service-stage-card[data-reveal] {
    opacity: 0;
    filter: blur(3px);
    transform: translate3d(0, 150px, 0) scale(.975);
    transition:
        opacity 1s cubic-bezier(.16, 1, .3, 1),
        transform 1s cubic-bezier(.16, 1, .3, 1),
        filter 1s cubic-bezier(.16, 1, .3, 1);
    transition-delay: var(--reveal-delay, 120ms);
}

.js .portfolio-stage-media.is-visible,
.js .service-stage-media.is-visible,
.js .portfolio-hero-image.is-visible,
.js .portfolio-stage-card.is-visible,
.js .service-stage-card.is-visible {
    opacity: 1;
    filter: blur(0);
    transform: translate3d(0, 0, 0) scale(1) rotate(0);
}

.js .portfolio-stage-media img,
.js .portfolio-hero-image img {
    opacity: 0;
    transform: translate3d(0, 34px, 0) scale(.90);
    transition:
        opacity .92s cubic-bezier(.16, 1, .3, 1),
        transform .92s cubic-bezier(.16, 1, .3, 1);
    transition-delay: calc(var(--reveal-delay, 0ms) + 320ms);
}

.js .portfolio-stage-media.is-visible img,
.js .portfolio-hero-image.is-visible img {
    opacity: 1;
    transform: translate3d(0, 0, 0) scale(1);
}

.js .portfolio-stage-card > *,
.js .service-stage-card > * {
    opacity: 0;
    transform: translate3d(0, 32px, 0);
    transition:
        opacity .7s cubic-bezier(.16, 1, .3, 1),
        transform .7s cubic-bezier(.16, 1, .3, 1);
}

.js .portfolio-stage-card.is-visible > *,
.js .service-stage-card.is-visible > * {
    opacity: 1;
    transform: translate3d(0, 0, 0);
}

.js .portfolio-stage-card.is-visible > :nth-child(1),
.js .service-stage-card.is-visible > :nth-child(1) { transition-delay: 260ms; }
.js .portfolio-stage-card.is-visible > :nth-child(2),
.js .service-stage-card.is-visible > :nth-child(2) { transition-delay: 360ms; }
.js .portfolio-stage-card.is-visible > :nth-child(3),
.js .service-stage-card.is-visible > :nth-child(3) { transition-delay: 460ms; }
.js .portfolio-stage-card.is-visible > :nth-child(4),
.js .service-stage-card.is-visible > :nth-child(4) { transition-delay: 560ms; }
.js .portfolio-stage-card.is-visible > :nth-child(n+5),
.js .service-stage-card.is-visible > :nth-child(n+5) { transition-delay: 660ms; }

@media (max-width: 920px) {
    .dropdown-menu-services {
        width: auto;
        max-height: none;
        padding: 10px;
        border-radius: 18px;
    }

    .dropdown-menu-services a {
        grid-template-columns: 32px minmax(0, 1fr);
    }

    .dropdown-menu-title {
        margin-top: 4px;
    }
}

@media (max-width: 760px) {
    .js .portfolio-stage-media[data-reveal],
    .js .service-stage-media[data-reveal],
    .js .portfolio-hero-image[data-reveal],
    .js .portfolio-stage.is-reversed .portfolio-stage-media[data-reveal],
    .js .service-stage.is-reversed .service-stage-media[data-reveal] {
        transform: translate3d(0, 86px, 0) scale(.975) rotate(0);
    }

    .js .portfolio-stage-card[data-reveal],
    .js .service-stage-card[data-reveal] {
        transform: translate3d(0, 96px, 0) scale(.98);
    }
}

/* ------------------------------------------------------------
   Fix 2026-06-21: Dropdown nur bei Hover/JS-Open anzeigen,
   Icon-Hintergrund etwas größer, Flow-In noch robuster.
   ------------------------------------------------------------ */

@media (min-width: 921px) {
    .nav-dropdown .dropdown-menu {
        display: block !important;
        opacity: 0;
        visibility: hidden;
        pointer-events: none;
        transform: translate3d(0, 12px, 0) scale(.985);
        transition:
            opacity .22s ease,
            visibility .22s ease,
            transform .22s ease;
    }

    .nav-dropdown:hover .dropdown-menu,
    .nav-dropdown.is-open .dropdown-menu {
        opacity: 1;
        visibility: visible;
        pointer-events: auto;
        transform: translate3d(0, 0, 0) scale(1);
    }

    /* Wichtig: Fokus allein darf das Menü nicht dauerhaft offen halten. */
    .nav-dropdown:focus-within:not(:hover):not(.is-open) .dropdown-menu {
        opacity: 0;
        visibility: hidden;
        pointer-events: none;
    }

    .nav-dropdown .dropdown-menu-services {
        display: grid !important;
        grid-template-columns: 1fr 1fr;
        gap: 6px;
    }
}

/* Das Symbol im IS-Button wieder sichtbarer/größer darstellen. */
.brand-mark::before {
    background-size: cover, 84% !important;
    opacity: .96;
}

.brand-mark::after {
    background: rgba(31,111,85,.10) !important;
}

/* Harte Absicherung: solange kein is-visible gesetzt ist, bleiben Elemente unsichtbar. */
html.js [data-reveal]:not(.is-visible) {
    opacity: 0 !important;
}

/* Deutlichere Bewegungen wie "Text flow in" und "Picture flow in". */
html.js .portfolio-stage-card[data-reveal]:not(.is-visible),
html.js .service-stage-card[data-reveal]:not(.is-visible),
html.js .section-heading[data-reveal]:not(.is-visible),
html.js .feature-card[data-reveal]:not(.is-visible),
html.js .service-teaser[data-reveal]:not(.is-visible),
html.js .cta-box[data-reveal]:not(.is-visible) {
    opacity: 0 !important;
    filter: blur(6px);
    transform: translate3d(0, 130px, 0) scale(.965);
}

html.js .portfolio-stage-media[data-reveal="left"]:not(.is-visible),
html.js .service-stage-media[data-reveal="left"]:not(.is-visible),
html.js .portfolio-stage-nav[data-reveal="left"]:not(.is-visible) {
    opacity: 0 !important;
    filter: blur(6px);
    transform: translate3d(-240px, 0, 0) scale(.955);
}

html.js .portfolio-stage-media[data-reveal="right"]:not(.is-visible),
html.js .service-stage-media[data-reveal="right"]:not(.is-visible),
html.js .portfolio-hero-image[data-reveal="right"]:not(.is-visible) {
    opacity: 0 !important;
    filter: blur(6px);
    transform: translate3d(240px, 0, 0) scale(.955);
}

html.js [data-reveal].is-visible {
    opacity: 1 !important;
    filter: blur(0);
    transform: translate3d(0, 0, 0) scale(1) rotate(0) !important;
}

html.js [data-reveal] {
    transition:
        opacity 1.05s cubic-bezier(.16, 1, .3, 1),
        transform 1.05s cubic-bezier(.16, 1, .3, 1),
        filter 1.05s cubic-bezier(.16, 1, .3, 1) !important;
    transition-delay: var(--reveal-delay, 0ms) !important;
}

@media (max-width: 920px) {
    html.js .portfolio-stage-media[data-reveal]:not(.is-visible),
    html.js .service-stage-media[data-reveal]:not(.is-visible),
    html.js .portfolio-hero-image[data-reveal]:not(.is-visible),
    html.js .portfolio-stage-card[data-reveal]:not(.is-visible),
    html.js .service-stage-card[data-reveal]:not(.is-visible) {
        transform: translate3d(0, 92px, 0) scale(.97) !important;
    }
}


/* ------------------------------------------------------------
   Fix: weiche Bild-Fade-ins und gestaffelte Text-/Listenpunkte.
   Der obere Text erscheint zuerst, danach Punkt für Punkt.
   ------------------------------------------------------------ */
html.js .portfolio-stage-media img,
html.js .service-stage-media img,
html.js .portfolio-hero-image img {
    opacity: 0 !important;
    transform: translate3d(0, 18px, 0) scale(.975) !important;
    filter: blur(5px) saturate(.96) !important;
    transition:
        opacity 1.85s cubic-bezier(.16, 1, .3, 1),
        transform 1.85s cubic-bezier(.16, 1, .3, 1),
        filter 1.85s cubic-bezier(.16, 1, .3, 1) !important;
    transition-delay: calc(var(--reveal-delay, 0ms) + 180ms) !important;
}

html.js .portfolio-stage-media.is-visible img,
html.js .service-stage-media.is-visible img,
html.js .portfolio-hero-image.is-visible img {
    opacity: 1 !important;
    transform: translate3d(0, 0, 0) scale(1) !important;
    filter: blur(0) saturate(1) !important;
}

/* Die Listencontainer selbst bleiben sichtbar; animiert werden die einzelnen Punkte. */
html.js .portfolio-stage-card ul,
html.js .service-stage-card ul,
html.js .portfolio-stage-card.is-visible ul,
html.js .service-stage-card.is-visible ul {
    opacity: 1 !important;
    transform: none !important;
    filter: none !important;
    transition: none !important;
}

html.js .portfolio-stage-card [data-stagger],
html.js .service-stage-card [data-stagger] {
    opacity: 0 !important;
    transform: translate3d(0, 30px, 0) !important;
    filter: blur(5px) !important;
    transition:
        opacity .9s cubic-bezier(.16, 1, .3, 1),
        transform .9s cubic-bezier(.16, 1, .3, 1),
        filter .9s cubic-bezier(.16, 1, .3, 1) !important;
    transition-delay: var(--stagger-delay, 260ms) !important;
}

html.js .portfolio-stage-card.is-visible [data-stagger],
html.js .service-stage-card.is-visible [data-stagger] {
    opacity: 1 !important;
    transform: translate3d(0, 0, 0) !important;
    filter: blur(0) !important;
}

html.js .portfolio-stage-card [data-stagger].eyebrow,
html.js .service-stage-card [data-stagger].eyebrow {
    transform: translate3d(0, 18px, 0) !important;
}

html.js .portfolio-stage-card.is-visible [data-stagger].eyebrow,
html.js .service-stage-card.is-visible [data-stagger].eyebrow {
    transform: translate3d(0, 0, 0) !important;
}

@media (prefers-reduced-motion: reduce) {
    html.js .portfolio-stage-media img,
    html.js .service-stage-media img,
    html.js .portfolio-hero-image img,
    html.js .portfolio-stage-card [data-stagger],
    html.js .service-stage-card [data-stagger] {
        opacity: 1 !important;
        transform: none !important;
        filter: none !important;
        transition: none !important;
    }
}


/* ------------------------------------------------------------
   FINAL FIX: Dropdown, Icon-Größe und echte gestaffelte Fade-Ins
   ------------------------------------------------------------ */

/* Dropdown: nicht mehr dauerhaft über focus-within geöffnet lassen. */
.nav-dropdown:not(:hover):not(.is-open) .dropdown-menu {
    display: none !important;
    opacity: 0 !important;
    visibility: hidden !important;
    pointer-events: none !important;
}

.nav-dropdown:hover .dropdown-menu,
.nav-dropdown.is-open .dropdown-menu {
    display: grid !important;
    opacity: 1 !important;
    visibility: visible !important;
    pointer-events: auto !important;
}

.dropdown-menu-services {
    width: min(520px, calc(100vw - 32px));
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 8px 12px;
    padding: 18px;
}

.dropdown-menu-title {
    grid-column: 1 / -1;
    margin: 0 0 8px;
    font-size: .76rem;
    letter-spacing: .14em;
    text-transform: uppercase;
    font-weight: 800;
    color: var(--muted);
}

.dropdown-menu-services a {
    display: grid;
    grid-template-columns: 32px minmax(0, 1fr);
    gap: 10px;
    align-items: center;
    min-height: 48px;
    padding: 9px 10px;
    border-radius: 14px;
}

.dropdown-menu-services a span {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 28px;
    height: 28px;
    border-radius: 10px;
    background: rgba(31,111,85,.10);
    color: var(--primary);
    font-size: .72rem;
    font-weight: 900;
}

.dropdown-menu-services a:hover,
.dropdown-menu-services a:focus-visible {
    background: rgba(31,111,85,.10);
}

/* Logo: Symbol im grünen IS-Button sichtbar, aber nicht übergroß. */
.brand-mark::before {
    background-size: cover, 88% !important;
    opacity: .92 !important;
}

/* Stage-Bilder: wirklich weich sichtbar werden. */
.js .portfolio-stage-media img,
.js .portfolio-hero-image img {
    opacity: 0 !important;
    transform: translate3d(0, 34px, 0) scale(.965) !important;
    filter: blur(10px) saturate(.95) contrast(.98);
    transition:
        opacity 1.65s cubic-bezier(.16, 1, .3, 1),
        transform 1.65s cubic-bezier(.16, 1, .3, 1),
        filter 1.65s cubic-bezier(.16, 1, .3, 1) !important;
    transition-delay: calc(var(--reveal-delay, 0ms) + 180ms) !important;
}

.js .portfolio-stage-media.is-visible img.is-img-ready,
.js .portfolio-hero-image.is-visible img.is-img-ready {
    opacity: 1 !important;
    transform: translate3d(0, 0, 0) scale(1) !important;
    filter: blur(0) saturate(1) contrast(1);
}

/* Textkarten: erst oberer Text, danach jeder Listenpunkt einzeln. */
.js .portfolio-stage-card [data-stagger],
.js .service-stage-card [data-stagger] {
    opacity: 0 !important;
    transform: translate3d(0, 22px, 0) !important;
    filter: blur(4px);
    transition:
        opacity .82s cubic-bezier(.16, 1, .3, 1),
        transform .82s cubic-bezier(.16, 1, .3, 1),
        filter .82s cubic-bezier(.16, 1, .3, 1) !important;
    transition-delay: var(--stagger-delay, 0ms) !important;
}

.js .portfolio-stage-card.is-visible [data-stagger],
.js .service-stage-card.is-visible [data-stagger] {
    opacity: 1 !important;
    transform: translate3d(0, 0, 0) !important;
    filter: blur(0);
}

/* Die Karte selbst darf einfliegen; die Kind-Elemente bleiben bis zur Staffelung unsichtbar. */
.js .portfolio-stage-card.is-visible > *,
.js .service-stage-card.is-visible > * {
    opacity: 1;
}

@media (max-width: 920px) {
    .nav-dropdown:hover .dropdown-menu,
    .nav-dropdown.is-open .dropdown-menu {
        display: block !important;
    }

    .dropdown-menu-services {
        width: auto;
        grid-template-columns: 1fr;
        padding: 10px;
    }
}


/* ------------------------------------------------------------
   User-Fix: langsames 3s Flow-In für Texte und Aufzählungen
   ------------------------------------------------------------ */
html.js .portfolio-stage-card,
html.js .service-stage-card {
    overflow: hidden;
}

/* Der komplette Textbereich darf nicht sofort sichtbar sein.
   Erst wenn die Karte sichtbar wird, laufen die Kinder gestaffelt ein. */
html.js .portfolio-stage-card [data-stagger],
html.js .service-stage-card [data-stagger] {
    opacity: 0 !important;
    transform: translate3d(0, var(--stagger-y, 70px), 0) !important;
    filter: blur(8px) !important;
    transition-property: opacity, transform, filter !important;
    transition-duration: var(--stagger-duration, 3000ms) !important;
    transition-timing-function: cubic-bezier(.16, 1, .3, 1) !important;
    transition-delay: var(--stagger-delay, 0ms) !important;
    will-change: opacity, transform, filter;
}

html.js .portfolio-stage-card.is-visible [data-stagger],
html.js .service-stage-card.is-visible [data-stagger] {
    opacity: 1 !important;
    transform: translate3d(0, 0, 0) !important;
    filter: blur(0) !important;
}

/* Listencontainer nicht als Ganzes animieren, sondern nur die einzelnen Punkte. */
html.js .portfolio-stage-card ul,
html.js .service-stage-card ul,
html.js .portfolio-stage-card.is-visible ul,
html.js .service-stage-card.is-visible ul {
    opacity: 1 !important;
    transform: none !important;
    filter: none !important;
    transition: none !important;
}

html.js .portfolio-stage-card li[data-stagger],
html.js .service-stage-card li[data-stagger] {
    display: grid;
    grid-template-columns: auto 1fr;
    align-items: start;
}

/* Überschriften dürfen etwas schneller sichtbar werden, der eigentliche Fließtext bleibt langsam. */
html.js .portfolio-stage-card [data-stagger-kind="text"].eyebrow,
html.js .service-stage-card [data-stagger-kind="text"].eyebrow,
html.js .portfolio-stage-card h2[data-stagger-kind="text"],
html.js .service-stage-card h2[data-stagger-kind="text"] {
    --stagger-duration: 2200ms;
}

/* Die Bildflächen bleiben weich, aber Text/Listen sind jetzt deutlich langsamer. */
html.js .portfolio-stage-media img,
html.js .service-stage-media img,
html.js .portfolio-hero-image img {
    transition-duration: 2600ms, 2600ms, 2600ms !important;
}

@media (prefers-reduced-motion: reduce) {
    html.js .portfolio-stage-card [data-stagger],
    html.js .service-stage-card [data-stagger] {
        opacity: 1 !important;
        transform: none !important;
        filter: none !important;
        transition: none !important;
    }
}

/* ============================================================
   HARD FIX 2026-06-21: echter Text-Flow-In pro Leistungsblock
   ------------------------------------------------------------
   Wichtig: Diese Regeln benutzen eigene Klassen (.flow-item / .flow-visible),
   damit alte [data-reveal]-Regeln die Animation nicht übersteuern.
   ============================================================ */
html.js .portfolio-stage-card .flow-item,
html.js .service-stage-card .flow-item {
    opacity: 0 !important;
    transform: translate3d(0, var(--flow-y, 78px), 0) !important;
    filter: blur(10px) !important;
    transition-property: opacity, transform, filter !important;
    transition-duration: var(--flow-duration, 3000ms) !important;
    transition-timing-function: cubic-bezier(.16, 1, .3, 1) !important;
    transition-delay: var(--flow-delay, 0ms) !important;
    will-change: opacity, transform, filter;
}

html.js .portfolio-stage-card.flow-visible .flow-item,
html.js .service-stage-card.flow-visible .flow-item {
    opacity: 1 !important;
    transform: translate3d(0, 0, 0) !important;
    filter: blur(0) !important;
}

/* Überschrift/Label etwas weniger weit, eigentlicher Fließtext deutlich von unten. */
html.js .portfolio-stage-card .flow-item.flow-title,
html.js .service-stage-card .flow-item.flow-title {
    --flow-y: 44px;
    --flow-duration: 2200ms;
}

html.js .portfolio-stage-card .flow-item.flow-body,
html.js .service-stage-card .flow-item.flow-body {
    --flow-y: 92px;
    --flow-duration: 3000ms;
}

html.js .portfolio-stage-card .flow-item.flow-list,
html.js .service-stage-card .flow-item.flow-list {
    --flow-y: 64px;
    --flow-duration: 3000ms;
}

/* Liste selbst bleibt als Container stabil, nur die einzelnen li fliegen ein. */
html.js .portfolio-stage-card ul,
html.js .service-stage-card ul {
    opacity: 1 !important;
    transform: none !important;
    filter: none !important;
    transition: none !important;
}

/* Bilder ebenfalls weich, aber unabhängig vom Text. */
html.js .portfolio-stage-media img,
html.js .service-stage-media img,
html.js .portfolio-hero-image img {
    opacity: 0 !important;
    transform: translate3d(0, 42px, 0) scale(.965) !important;
    filter: blur(12px) saturate(.96) !important;
    transition:
        opacity 2800ms cubic-bezier(.16, 1, .3, 1),
        transform 2800ms cubic-bezier(.16, 1, .3, 1),
        filter 2800ms cubic-bezier(.16, 1, .3, 1) !important;
}

html.js .portfolio-stage-media.is-visible img,
html.js .service-stage-media.is-visible img,
html.js .portfolio-hero-image.is-visible img,
html.js .portfolio-stage-media.flow-visible img,
html.js .service-stage-media.flow-visible img,
html.js .portfolio-hero-image.flow-visible img {
    opacity: 1 !important;
    transform: translate3d(0, 0, 0) scale(1) !important;
    filter: blur(0) saturate(1) !important;
}

@media (prefers-reduced-motion: reduce) {
    html.js .portfolio-stage-card .flow-item,
    html.js .service-stage-card .flow-item,
    html.js .portfolio-stage-media img,
    html.js .service-stage-media img,
    html.js .portfolio-hero-image img {
        opacity: 1 !important;
        transform: none !important;
        filter: none !important;
        transition: none !important;
    }
}

/* ------------------------------------------------------------
   Unser-Team-Seite
   ------------------------------------------------------------ */
.team-page-hero {
    position: relative;
    overflow: hidden;
    min-height: calc(100dvh - 92px);
    padding: clamp(72px, 9vw, 128px) 0 clamp(64px, 8vw, 110px);
    background:
        linear-gradient(90deg, rgba(245, 250, 252, .96) 0%, rgba(245, 250, 252, .90) 42%, rgba(245, 250, 252, .70) 100%),
        var(--team-bg),
        linear-gradient(135deg, #eef6f8, #dfeee8);
    background-size: cover;
    background-position: center;
}

.team-page-hero::before {
    content: "";
    position: absolute;
    inset: 0;
    pointer-events: none;
    background:
        radial-gradient(circle at 18% 22%, rgba(31,111,85,.16), transparent 30%),
        radial-gradient(circle at 82% 52%, rgba(118,174,67,.12), transparent 28%);
}

.team-hero-grid {
    position: relative;
    z-index: 1;
    display: grid;
    grid-template-columns: minmax(0, 1fr) minmax(320px, 560px);
    gap: clamp(32px, 6vw, 86px);
    align-items: center;
}

.team-hero-copy h1 {
    max-width: 760px;
    margin: 12px 0 22px;
    font-size: clamp(2.4rem, 6.4vw, 5.4rem);
    line-height: .98;
    letter-spacing: -.06em;
}

.team-hero-copy p {
    max-width: 760px;
    color: var(--muted);
    font-size: clamp(1.05rem, 1.5vw, 1.28rem);
    line-height: 1.8;
}

.team-hero-image {
    position: relative;
    padding: clamp(14px, 2vw, 24px);
    border-radius: 34px;
    background: rgba(255,255,255,.58);
    border: 1px solid rgba(31,111,85,.16);
    box-shadow: 0 34px 92px rgba(17, 37, 32, .16);
    backdrop-filter: blur(16px);
}

.team-hero-image::after {
    content: "";
    position: absolute;
    inset: 16px;
    border-radius: 24px;
    border: 1px solid rgba(255,255,255,.72);
    pointer-events: none;
}

.team-hero-image img {
    display: block;
    width: 100%;
    border-radius: 24px;
    object-fit: cover;
    box-shadow: 0 22px 54px rgba(18, 36, 30, .14);
}

.team-section {
    padding: clamp(64px, 8vw, 108px) 0;
    background: #f5f8f7;
}

.team-section-soft {
    background:
        linear-gradient(180deg, rgba(255,255,255,.82), rgba(240,247,245,.92)),
        url('/images/team/team-hintergrund.png');
    background-size: cover;
    background-position: center;
}

.team-intro-grid {
    display: grid;
    grid-template-columns: minmax(0, 1.05fr) minmax(280px, .95fr);
    gap: clamp(24px, 5vw, 64px);
    align-items: start;
}

.team-card,
.team-value-card,
.team-capability,
.team-cta-card {
    border: 1px solid rgba(31,111,85,.12);
    background: rgba(255,255,255,.82);
    box-shadow: 0 24px 70px rgba(18, 36, 30, .08);
    backdrop-filter: blur(14px);
}

.team-card {
    border-radius: 30px;
    padding: clamp(26px, 4vw, 50px);
}

.team-card h2,
.team-cta-card h2 {
    margin: 10px 0 18px;
    font-size: clamp(2rem, 4vw, 3.6rem);
    line-height: 1.02;
    letter-spacing: -.045em;
}

.team-card p,
.team-value-card p,
.team-capability p,
.team-cta-card p {
    color: var(--muted);
    line-height: 1.75;
}

.team-values {
    display: grid;
    gap: 18px;
}

.team-value-card {
    border-radius: 24px;
    padding: 24px;
}

.team-value-card strong {
    display: inline-grid;
    place-items: center;
    width: 42px;
    height: 42px;
    border-radius: 14px;
    background: rgba(31,111,85,.10);
    color: var(--green-dark);
    font-size: .86rem;
    margin-bottom: 16px;
}

.team-value-card h3,
.team-capability h3 {
    margin: 0 0 10px;
    font-size: 1.25rem;
}

.team-capability-grid {
    display: grid;
    grid-template-columns: repeat(4, minmax(0, 1fr));
    gap: 18px;
}

.team-capability {
    border-radius: 26px;
    padding: 26px;
}

.team-icon {
    display: inline-grid;
    place-items: center;
    width: 48px;
    height: 48px;
    border-radius: 16px;
    margin-bottom: 18px;
    color: #fff;
    background: linear-gradient(135deg, #1f6f55, #76ae43);
    font-weight: 800;
}

.team-cta {
    padding: clamp(64px, 8vw, 104px) 0;
    background: #f5f8f7;
}

.team-cta-card {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 28px;
    border-radius: 32px;
    padding: clamp(28px, 5vw, 56px);
}

.team-cta-card p {
    max-width: 760px;
}

/* Team-Seite nutzt dieselbe Flow-Logik: Text langsam von unten, Bild von rechts. */
html.js .team-hero-copy[data-reveal]:not(.is-visible),
html.js .team-card[data-reveal]:not(.is-visible),
html.js .team-values[data-reveal]:not(.is-visible),
html.js .team-capability[data-reveal]:not(.is-visible),
html.js .team-cta-card[data-reveal]:not(.is-visible) {
    opacity: 0 !important;
    transform: translate3d(0, 90px, 0) !important;
    filter: blur(10px) !important;
}

html.js .team-hero-image[data-reveal]:not(.is-visible) {
    opacity: 0 !important;
    transform: translate3d(150px, 0, 0) scale(.96) !important;
    filter: blur(10px) !important;
}

html.js .team-hero-copy[data-reveal],
html.js .team-card[data-reveal],
html.js .team-values[data-reveal],
html.js .team-capability[data-reveal],
html.js .team-cta-card[data-reveal],
html.js .team-hero-image[data-reveal] {
    transition-duration: 1600ms !important;
}

@media (max-width: 1020px) {
    .team-hero-grid,
    .team-intro-grid {
        grid-template-columns: 1fr;
    }

    .team-hero-image {
        max-width: 680px;
    }

    .team-capability-grid {
        grid-template-columns: repeat(2, minmax(0, 1fr));
    }
}

@media (max-width: 680px) {
    .team-page-hero {
        min-height: auto;
        padding-top: 48px;
    }

    .team-hero-image,
    .team-card,
    .team-cta-card {
        border-radius: 24px;
    }

    .team-capability-grid {
        grid-template-columns: 1fr;
    }

    .team-cta-card {
        align-items: flex-start;
        flex-direction: column;
    }

    html.js .team-hero-image[data-reveal]:not(.is-visible) {
        transform: translate3d(0, 70px, 0) scale(.97) !important;
    }
}

/* Schnellerer Flow-In: sichtbar, aber lesefreundlich */
html.js [data-reveal] {
    transition-duration: 620ms, 620ms, 620ms !important;
}

html.js .portfolio-stage-card[data-reveal],
html.js .service-stage-card[data-reveal],
html.js .team-card[data-reveal],
html.js .team-hero-copy[data-reveal] {
    transition-duration: 680ms, 680ms, 680ms !important;
}

html.js .portfolio-stage-card .flow-item,
html.js .service-stage-card .flow-item {
    --flow-duration: 720ms;
    --flow-y: 42px;
}

    html.js .portfolio-stage-card .flow-item.flow-title,
    html.js .service-stage-card .flow-item.flow-title {
        --flow-duration: 520ms;
        --flow-y: 26px;
    }

    html.js .portfolio-stage-card .flow-item.flow-body,
    html.js .service-stage-card .flow-item.flow-body {
        --flow-duration: 700ms;
        --flow-y: 46px;
    }

    html.js .portfolio-stage-card .flow-item.flow-list,
    html.js .service-stage-card .flow-item.flow-list {
        --flow-duration: 650ms;
        --flow-y: 34px;
    }

html.js .portfolio-stage-media img,
html.js .service-stage-media img,
html.js .portfolio-hero-image img {
    transition-duration: 850ms, 850ms, 850ms !important;
}


.back-to-top {
    position: fixed;
    right: 22px;
    bottom: 22px;
    z-index: 9999;
    width: 48px;
    height: 48px;
    display: grid;
    place-items: center;
    border-radius: 999px;
    background: var(--primary);
    color: #fff;
    font-size: 1.5rem;
    font-weight: 900;
    box-shadow: 0 14px 34px rgba(20,45,38,.22);
    text-decoration: none;
}

    .back-to-top:hover {
        color: #fff;
        background: var(--primary-dark);
        text-decoration: none;
        transform: translateY(-2px);
    }

@media (max-width: 760px) {
    .back-to-top {
        right: 14px;
        bottom: 14px;
        width: 44px;
        height: 44px;
        font-size: 1.3rem;
    }
}

@media (max-width: 920px) {
    .nav-dropdown:not(.is-open) .dropdown-menu {
        display: none !important;
    }

    .nav-dropdown.is-open .dropdown-menu {
        display: block !important;
        opacity: 1 !important;
        visibility: visible !important;
        pointer-events: auto !important;
    }
}
