:root{
    --bg0: #0b1220;
    --bg1: #0f1b33;
    --accent: #4f8cff;
    --accent2:#7c5cff;
    --color-primary: #1F2F4A;
}

/* Invena Header: Hemutis-Logo max. 50px Höhe */
.header-one .thumbnail a img.site-logo {
    max-height: 50px !important;
    width: auto !important;
    height: auto !important;
}

/* Sprachauswahl Select im Header */
.lang-select-wrapper { display: inline-flex; align-items: center; gap: 0.5rem; margin-right: 0.5rem; }
.lang-select-label {
    font-size: var(--font-size-b1, 16px);
    font-weight: 500;
    color: var(--color-primary, #1F2F4A);
    white-space: nowrap;
}
.lang-select {
    font-size: var(--font-size-b1, 16px);
    padding: 0.35rem 1.75rem 0.35rem 0.5rem;
    border: none !important;
    box-shadow: none !important;
    border-radius: 4px;
    background-color: transparent;
    color: var(--color-primary, #1F2F4A);
    cursor: pointer;
    min-height: 36px;
    appearance: none;
    -webkit-appearance: none;
    -moz-appearance: none;
    background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 12 12' fill='none'%3E%3Cpath stroke='%231F2F4A' stroke-width='1.5' stroke-linecap='round' d='M3 4.5l3 3 3-3'/%3E%3C/svg%3E");
    background-repeat: no-repeat;
    background-position: right 0.4rem center;
}
.lang-select:hover { opacity: 0.85; }
.lang-select:focus {
    outline: 2px solid var(--color-primary);
    outline-offset: 2px;
    border: none !important;
    box-shadow: none !important;
}
.lang-select::-ms-expand { display: none; }

/* Counter-Bereich (rts-counter-up-area) schmaler */
.rts-counter-up-area.rts-section-gap.counter-bg {
    height: auto;
    min-height: 0;
    padding: 2.5rem 0;
}
.rts-counter-up-area.counter-bg .single-counter {
    margin: 0.5rem 0;
}
.rts-counter-up-area.counter-bg .single-counter .icon {
    height: 56px;
    min-width: 56px;
}

/* Banner-Slider: blauer Schein (Primärfarbe) für bessere Lesbarkeit + Slide .three mit 03.webp */
.rts-banner-area-two {
    position: relative;
}
.rts-banner-area-two::before {
    content: '';
    position: absolute;
    inset: 0;
    /* Blau wie Logo/Contact-Button (#1F2F4A), halbtransparent für bessere Textlesbarkeit */
    background: rgba(31, 47, 74, 0.48);
    z-index: 0;
    pointer-events: none;
}
.rts-banner-area-two > .container,
.rts-banner-area-two > .shape-area-start {
    position: relative;
    z-index: 1;
}
.rts-banner-area-two.three {
    background-image: url('/invena/assets/images/banner/03.webp') !important;
}

/* Banner-Slider: Pfeile weiter nach unten, damit sie den Text nicht überlagern */
.mySwiper-banner-two .swiper-button-next,
.mySwiper-banner-two .swiper-button-prev {
    top: 60%;
    bottom: auto;
    transform: translateY(-50%);
}

body{
    background:#fff;
    /* Sticky Nav darf NICHT per padding-top "verschoben" werden.
       Wir nutzen scroll-padding-top am html für Anchors. */
}

/* =========================
   HEADER / HERO
   ========================= */
.site-header{
    position: relative;
    color:#fff;
    background:
        radial-gradient(1200px 600px at 20% 10%, rgba(79,140,255,.35), transparent 60%),
        radial-gradient(900px 500px at 90% 30%, rgba(124,92,255,.30), transparent 55%),
        linear-gradient(180deg, var(--bg0), var(--bg1));
}

.hero{
    position: relative;
    overflow: hidden;
}

.kicker{
    display:inline-flex;
    padding:.35rem .75rem;
    border-radius: 999px;
    background: rgba(255,255,255,.08);
    border: 1px solid rgba(255,255,255,.12);
    color: rgba(255,255,255,.9);
    letter-spacing: .02em;
    font-weight: 600;
}

.trust-pill{
    display:inline-flex;
    align-items:center;
    padding:.35rem .7rem;
    border-radius:999px;
    background: rgba(255,255,255,.08);
    border: 1px solid rgba(255,255,255,.12);
    color: rgba(255,255,255,.9);
    font-size:.9rem;
}

.btn-cta{
    border-radius: 999px;
    padding:.65rem 1.1rem;
    box-shadow: 0 12px 35px rgba(79,140,255,.20);
    white-space: nowrap;
}

/* =========================
   NAV / BRANDING
   ========================= */
.navbar{
    background: transparent;
}

/* Sticky Navbar */
.navbar-sticky{
    position: sticky;
    top: 0;
    z-index: 1030;
    backdrop-filter: blur(12px);
    -webkit-backdrop-filter: blur(12px);
    background: rgba(10, 15, 25, 0.40);
    border-bottom: 1px solid rgba(255,255,255,.06);
}

.navbar-sticky.is-scrolled{
    background: rgba(10, 15, 25, 0.92);
}

.navbar .nav-link{
    color: rgba(255,255,255,.78);
    font-weight: 500;
}

.navbar .nav-link:hover,
.navbar .nav-link:focus{
    color: rgba(255,255,255,.95);
}

.navbar .nav-link.active{
    color:#fff;
}

/* Logo + Brand */
.logo-wrap{
    width: 44px;
    height: 44px;
    border-radius: 50%;
    background: #ffffff;
    display: grid;
    place-items: center;
    box-shadow: 0 12px 30px rgba(0,0,0,.25);
    flex: 0 0 auto;
}

.brand-logo{
    width: 26px;
    height: 26px;
    display:block;
}

.brand-text{
    font-weight: 700;
    letter-spacing: .02em;
    color: #ffffff;
    font-size: 1.05rem;
    line-height: 1;
    white-space: nowrap;
}

@media (max-width: 420px){
    .logo-wrap{ width: 40px; height: 40px; }
    .brand-logo{ width: 24px; height: 24px; }
    .brand-text{ font-size: 1rem; }
}

/* Nav controls spacing */
.nav-controls{
    flex: 0 0 auto;
}

/* Language button */
.btn-lang{
    border-radius: 999px;
    padding: .45rem .75rem;
    min-width: 52px;
    justify-content: center;
    display: inline-flex;
    align-items: center;
    font-weight: 700;
    letter-spacing: .03em;
}

/* Login button */
.btn-login{
    border-radius: 999px;
    padding: .45rem .85rem;
    display: inline-flex;
    align-items: center;
    gap: .25rem;
    white-space: nowrap;
}

/* Anchor scroll offset for sticky nav + Smooth Scrolling für Anker-Links */
html{
    scroll-padding-top: 90px;
    scroll-behavior: smooth !important;
}

/* =========================
   HERO CARD
   ========================= */
.hero-card{
    border-radius: 18px;
    background: rgba(255,255,255,.06);
    border: 1px solid rgba(255,255,255,.12);
    padding: 16px;
    box-shadow: 0 30px 80px rgba(0,0,0,.35);
    backdrop-filter: blur(10px);
}

.hero-card-top{
    display:flex;
    align-items:center;
    gap:10px;
    margin-bottom: 14px;
}

.pulse{
    width:10px;height:10px;border-radius:50%;
    background:#2cff87;
    box-shadow: 0 0 0 0 rgba(44,255,135,.45);
    animation: pulse 1.6s infinite;
}

@keyframes pulse{
    0%{ box-shadow: 0 0 0 0 rgba(44,255,135,.45); }
    70%{ box-shadow: 0 0 0 14px rgba(44,255,135,0); }
    100%{ box-shadow: 0 0 0 0 rgba(44,255,135,0); }
}

.metric{
    padding: 12px;
    border-radius: 14px;
    background: rgba(255,255,255,.05);
    border: 1px solid rgba(255,255,255,.10);
    margin-bottom: 10px;
}

.hero-card-footer{
    padding-top: 6px;
}

.hero-wave{
    height: 48px;
    background: #fff;
    border-top-left-radius: 40px;
    border-top-right-radius: 40px;
    margin-top: 40px;
}

/* =========================
   SECTIONS / CONTENT
   ========================= */
/* Business Goal Bilder: gleiche Rundung wie CTA-Button */
.thumbnail-business-area-right-two .large-thumbnail img {
    border-radius: 25px;
}
.thumbnail-business-area-right-two .small-thumbnail img {
    border-radius: 25px;
    border: 10px solid var(--color-primary, #1F2F4A);
    box-sizing: border-box;
}

/* About- & Appointment-Bilder: gleicher Radius / Border */
.appoinment-thumbnail img {
    border-radius: 25px;
}
.left-thumbnail-about-area-two > img {
    border-radius: 25px;
}
.left-thumbnail-about-area-two + .about-image-caption {
    margin: 0.75rem auto 0;
    max-width: 490px;
    text-align: center;
    font-size: 16px;
    line-height: 1.5;
    color: var(--color-text-muted, #5a6b82);
}
.left-thumbnail-about-area-two .small-image img {
    border-radius: 25px;
    border: 10px solid var(--color-primary, #1F2F4A);
    box-sizing: border-box;
}

.section-pad{
    padding: 70px 0;
}

.section-alt{
    background: #f6f8fb;
}

.card-soft{
    border: 1px solid rgba(15,27,51,.10);
    border-radius: 18px;
    box-shadow: 0 18px 55px rgba(15,27,51,.08);
}

.card-soft .icon{
    width:44px;height:44px;border-radius:14px;
    display:grid;place-items:center;
    background: rgba(79,140,255,.12);
    color: #1d4ed8;
    font-size: 1.25rem;
}

.timeline{
    display:flex;
    flex-direction: column;
    gap: 12px;
}

.step{
    display:flex;
    gap: 14px;
    padding: 14px;
    border-radius: 18px;
    background: #fff;
    border: 1px solid rgba(15,27,51,.10);
    box-shadow: 0 18px 55px rgba(15,27,51,.06);
}

.step-num{
    width:34px;height:34px;border-radius:12px;
    display:grid;place-items:center;
    background: linear-gradient(135deg, var(--accent), var(--accent2));
    color:#fff;
    font-weight:700;
}

.case-card{
    display:flex;
    align-items:center;
    gap:12px;
    padding: 16px;
    border-radius: 18px;
    background:#fff;
    border: 1px solid rgba(15,27,51,.10);
    box-shadow: 0 18px 55px rgba(15,27,51,.06);
}

.case-card i{
    font-size: 1.35rem;
    color: #1d4ed8;
}

.contact-box{
    border-radius: 18px;
    padding: 16px;
    background: #fff;
    border: 1px solid rgba(15,27,51,.10);
    box-shadow: 0 18px 55px rgba(15,27,51,.06);
}

.site-footer{
    background: #fff;
    border-top: 1px solid rgba(15,27,51,.10);
}

/* =========================
   REVEAL ANIMATIONS
   ========================= */
.reveal{
    opacity: 0;
    transform: translateY(14px);
    transition: opacity .7s ease, transform .7s ease;
    will-change: opacity, transform;
}
.reveal.is-in{
    opacity: 1;
    transform: translateY(0);
}

/* =========================
   LOGIN BOTTOM SHEET
   ========================= */
.hs-sheet{
    position: fixed;
    inset: 0;
    z-index: 2000;
    display: none;
}
.hs-sheet.is-open{
    display: block;
}
.hs-backdrop{
    position: absolute;
    inset: 0;
    background: rgba(0,0,0,.55);
    backdrop-filter: blur(6px);
    -webkit-backdrop-filter: blur(6px);
}
.hs-panel{
    position: absolute;
    left: 0;
    right: 0;
    bottom: 0;
    margin: 0 auto;
    max-width: 720px;
    background: #fff;
    border-top-left-radius: 22px;
    border-top-right-radius: 22px;
    box-shadow: 0 -20px 60px rgba(0,0,0,.35);
    transform: translateY(20px);
    opacity: 0;
    transition: transform .2s ease, opacity .2s ease;
    overflow: hidden;
}
.hs-sheet.is-open .hs-panel{
    transform: translateY(0);
    opacity: 1;
}
.hs-header{
    display:flex;
    align-items:flex-start;
    justify-content: space-between;
    gap: 12px;
    padding: 18px 18px 10px 18px;
    border-bottom: 1px solid rgba(15,27,51,.08);
}
.hs-title{
    font-weight: 800;
    font-size: 1.15rem;
    line-height: 1.1;
    color: #0b1220;
}
.hs-subtitle{
    font-size: .95rem;
    color: rgba(15,27,51,.65);
    margin-top: 2px;
}
.hs-icon{
    width: 42px;
    height: 42px;
    border-radius: 14px;
    display: grid;
    place-items: center;
    background: rgba(79,140,255,.12);
    color: #1d4ed8;
    flex: 0 0 auto;
}
.hs-close{
    border: 0;
    background: transparent;
    width: 42px;
    height: 42px;
    border-radius: 14px;
    display: grid;
    place-items: center;
    color: rgba(15,27,51,.7);
}
.hs-close:hover{
    background: rgba(15,27,51,.06);
    color: rgba(15,27,51,.9);
}
.hs-close i{
    font-size: 1.25rem;
}
.hs-close-fallback{
    display: none;
    font-size: 1.6rem;
    line-height: 1;
}
html.fa-missing .hs-close i{ display:none; }
html.fa-missing .hs-close-fallback{ display:inline; }

.hs-body{
    padding: 16px 18px 18px 18px;
}

@media (max-width: 480px){
    .hs-panel{
        max-width: 100%;
        border-radius: 22px 22px 0 0;
    }
}
/* ===== Login Sheet ===== */
.login-sheet{
  position: fixed;
  inset: 0;
  z-index: 2000;
  display: none;
}

.login-sheet.is-open{
  display: block;
}

.login-sheet__backdrop{
  position: absolute;
  inset: 0;
  background: rgba(0,0,0,.45);
  backdrop-filter: blur(2px);
}

.login-sheet__panel{
  position: absolute;
  left: 50%;
  bottom: 18px;
  transform: translateX(-50%);
  width: min(520px, calc(100% - 24px));
  background: #fff;
  border-radius: 18px;
  box-shadow: 0 30px 80px rgba(0,0,0,.35);
  overflow: hidden;
}

.login-sheet__header{
  display:flex;
  align-items:center;
  justify-content: space-between;
  padding: 14px 14px;
  border-bottom: 1px solid rgba(15,27,51,.10);
}

.login-sheet__body{
  padding: 14px;
}

@media (min-width: 992px){
  .login-sheet__panel{
    bottom: auto;
    top: 50%;
    transform: translate(-50%, -50%);
    width: min(520px, calc(100% - 24px));
  }
}

body.login-sheet-open{
  overflow: hidden;
}

/* ===== Service Detail Bottom Sheet ===== */
.service-detail-sheet{
  position: fixed;
  inset: 0;
  z-index: 2001;
  display: none;
}
.service-detail-sheet.is-open{
  display: block;
}
.service-detail-sheet__backdrop{
  position: absolute;
  inset: 0;
  background: rgba(0,0,0,.5);
  backdrop-filter: blur(4px);
  -webkit-backdrop-filter: blur(4px);
}
.service-detail-sheet__panel{
  position: absolute;
  left: 0;
  right: 0;
  bottom: 0;
  max-height: 85vh;
  background: #fff;
  border-top-left-radius: 20px;
  border-top-right-radius: 20px;
  box-shadow: 0 -16px 48px rgba(0,0,0,.25);
  transform: translateY(100%);
  transition: transform .3s ease;
  overflow: hidden;
  display: flex;
  flex-direction: column;
}
.service-detail-sheet.is-open .service-detail-sheet__panel{
  transform: translateY(0);
}
.service-detail-sheet__header{
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
  padding: 18px 20px;
  border-bottom: 1px solid rgba(15,27,51,.08);
  flex-shrink: 0;
}
.service-detail-sheet__title{
  margin: 0;
  font-size: 1.75rem;
  font-weight: 700;
  color: #0b1220;
  line-height: 1.3;
}
.service-detail-sheet__close{
  border: 0;
  background: transparent;
  width: 40px;
  height: 40px;
  border-radius: 12px;
  display: grid;
  place-items: center;
  color: rgba(15,27,51,.7);
  cursor: pointer;
}
.service-detail-sheet__close:hover{
  background: rgba(15,27,51,.06);
  color: rgba(15,27,51,.9);
}
.service-detail-sheet__body{
  padding: 20px;
  overflow-y: auto;
  flex: 1;
}
.service-detail-sheet__text{
  margin: 0 0 20px;
  font-size: 1.35rem;
  line-height: 1.7;
  color: rgba(15,27,51,.85);
}
.service-detail-sheet__cta{
  display: inline-block;
}
body.service-detail-sheet-open{
  overflow: hidden;
}
