:root{
  --bg: #f5f7fb;
  --text: #0b2346;
  --line: rgba(11,35,70,.14);
  --primary: #176bff;
  --primary-2: #0f56d6;
  --btnText: #ffffff;
  --card: rgba(255,255,255,.78);
  --shadow: 0 20px 60px rgba(11,35,70,.12);
  --radius: 14px;
}

*{box-sizing:border-box}
html,body{height:100%}
body{
  margin:0;
  font-family: system-ui, -apple-system, Segoe UI, Roboto, Arial, sans-serif;
  color:var(--text);
  background:
  radial-gradient(1200px 600px at 70% 18%, rgba(23,107,255,.12), rgba(23,107,255,0) 60%),
  radial-gradient(900px 500px at 20% 30%, rgba(29,206,255,.10), rgba(29,206,255,0) 55%),
  linear-gradient(180deg, #ffffff 0%, var(--bg) 65%, #ffffff 100%);
}

a{color:inherit; text-decoration:none}

.container{max-width:1120px; margin:0 auto; padding:0 20px}

.skip-link{
  position:absolute; left:-9999px; top:10px;
  background:#fff; border:1px solid var(--line);
  padding:10px 12px; border-radius:10px; z-index:999;
}
.skip-link:focus{left:10px}

.site-header{
  position:sticky; top:0; z-index:50;
  backdrop-filter:saturate(180%) blur(10px);
  background:rgba(255,255,255,.75);
  border-bottom:1px solid var(--line);
}
.header-inner{display:flex; align-items:center; justify-content:space-between; gap:18px; padding:14px 0}

.brand{display:flex; align-items:center}
.brand-logo{height:44px; width:auto; display:block}

.nav{display:flex; align-items:center; gap:14px; position:relative}
.nav-menu{display:flex; align-items:center; gap:22px}

.nav-link{font-weight:500; color:rgba(11,35,70,.86)}
.nav-link:hover{color:var(--text)}

.nav-cta{
  display:inline-flex; align-items:center; justify-content:center;
  padding:10px 16px;
  border-radius:999px;
  background:linear-gradient(180deg, #0b2346, #071a35);
  color:#fff;
  font-weight:600;
  box-shadow: 0 10px 30px rgba(11,35,70,.18);
}
.nav-cta:hover{filter:brightness(1.05)}

.nav-toggle{
  display:none;
  border:1px solid var(--line);
  background:rgba(255,255,255,.9);
  border-radius:12px;
  padding:10px 10px;
}
.nav-toggle-lines{
  display:block; width:22px; height:2px; background:var(--text);
  position:relative;
}
.nav-toggle-lines::before,.nav-toggle-lines::after{
  content:""; position:absolute; left:0; width:22px; height:2px; background:var(--text);
}
.nav-toggle-lines::before{top:-7px}
.nav-toggle-lines::after{top:7px}
.sr-only{position:absolute; width:1px; height:1px; padding:0; margin:-1px; overflow:hidden; clip:rect(0,0,0,0); border:0}

.hero{padding:56px 0 10px}
.hero-grid{
  display:grid;
  grid-template-columns: minmax(0, 1.15fr) minmax(0, 0.85fr);
  gap:42px;
  align-items:center;
}

.hero-copy h1{
  margin:0 0 18px;
  font-size:44px;
  line-height:1.08;
  letter-spacing:-.6px;
}
.hero-lead{
  margin:0 0 22px;
  font-size:18px;
  line-height:1.6;
  color:rgba(11,35,70,.82);
}
.hero-actions{display:flex; gap:14px; flex-wrap:wrap; margin-bottom:22px}

.btn{
  display:inline-flex; align-items:center; justify-content:center;
  height:44px;
  padding:0 18px;
  border-radius:12px;
  font-weight:600;
  border:1px solid transparent;
}
.btn-primary{
  background:linear-gradient(180deg, var(--primary), var(--primary-2));
  color:var(--btnText);
  box-shadow: 0 14px 35px rgba(23,107,255,.22);
}
.btn-primary:hover{filter:brightness(1.03)}
.btn-secondary{
  background:rgba(255,255,255,.78);
  border-color:rgba(11,35,70,.18);
  color:rgba(11,35,70,.90);
}
.btn-secondary:hover{background:#fff}

.hero-foot{margin:0; color:rgba(11,35,70,.78); font-weight:500}

.hero-visual{position:relative}
.visual-card{
  border-radius:0;
  background:transparent;
  border:none;
  box-shadow:none;
  padding:0;
}
.hero-image{
  width:min(760px, 100%);
  height:520px;
  object-fit:contain;
  object-position: right center;
  border-radius:0;
  display:block;
}

.section{padding:56px 0}
.section.alt{
  background:linear-gradient(180deg, rgba(255,255,255,.0), rgba(23,107,255,.05) 40%, rgba(255,255,255,.0));
}
.section-head{margin-bottom:20px}
.section-head h2{margin:0 0 8px; font-size:28px; letter-spacing:-.3px}
.section-head p{margin:0; color:rgba(11,35,70,.75)}

.cards{display:grid; grid-template-columns:repeat(3, 1fr); gap:14px}
.card{
  padding:18px;
  border-radius: var(--radius);
  background: var(--card);
  border:none;
  box-shadow: 0 10px 30px rgba(11,35,70,.06);
}
.card h3{margin:0 0 8px}
.card p{margin:0; color:rgba(11,35,70,.75); line-height:1.55}

.two-col{display:grid; grid-template-columns:repeat(2, 1fr); gap:14px}
.panel{
  padding:18px;
  border-radius: var(--radius);
  border:none;
  background:rgba(255,255,255,.72);
}
.panel h3{margin:0 0 8px}
.panel p{margin:0; color:rgba(11,35,70,.75); line-height:1.55}

.form{
  border-radius: 18px;
  border:none;
  background:rgba(255,255,255,.72);
  padding:18px;
  box-shadow: 0 10px 30px rgba(11,35,70,.06);
}
.form-hint{margin:0 0 14px; color:rgba(11,35,70,.70)}
.form-grid{display:grid; grid-template-columns:repeat(2, 1fr); gap:12px}
.field{display:flex; flex-direction:column; gap:6px}
.field span{font-size:13px; font-weight:600; color:rgba(11,35,70,.84)}
.field input,.field textarea{
  width:min(760px, 100%);
  font: inherit;
  padding:12px 12px;
  border-radius:12px;
  border:1px solid rgba(11,35,70,.18);
  background:rgba(255,255,255,.88);
  outline:none;
}
.field input:focus,.field textarea:focus{border-color:rgba(23,107,255,.6); box-shadow:0 0 0 4px rgba(23,107,255,.12)}
.field-wide{grid-column:1/-1}

.form-actions{margin-top:12px; display:flex; align-items:center; gap:10px; flex-wrap:wrap}
.form-note{color:rgba(11,35,70,.65)}

.site-footer{padding:26px 0 34px; border-top:1px solid var(--line)}
.footer-inner{display:flex; align-items:center; justify-content:space-between; gap:12px}
.footer-left{color:rgba(11,35,70,.76)}
.footer-right{display:flex; gap:12px; align-items:center}
.footer-link{color:rgba(11,35,70,.76)}
.footer-link:hover{color:rgba(11,35,70,.94)}
.footer-sep{opacity:.5}

@media (max-width: 920px){
  .hero-copy h1{font-size:38px}
  .hero-grid{grid-template-columns:1fr; gap:22px}
  .hero-image{height:460px}
}

@media (max-width: 760px){
  .nav-toggle{display:inline-flex; align-items:center; justify-content:center}
  .nav-menu{
    position:absolute;
    right:0;
    top:54px;
    width:min(320px, calc(100vw - 40px));
    display:none;
    flex-direction:column;
    align-items:stretch;
    gap:10px;
    padding:12px;
    border-radius:16px;
    background:rgba(255,255,255,.92);
    border:1px solid rgba(11,35,70,.12);
    box-shadow: 0 20px 60px rgba(11,35,70,.18);
  }
  .nav-menu.is-open{display:flex}
  .nav-link{padding:10px 10px; border-radius:12px}
  .nav-link:hover{background:rgba(23,107,255,.07)}
  .nav-cta{justify-content:center}

  .cards{grid-template-columns:1fr}
  .two-col{grid-template-columns:1fr}
  .form-grid{grid-template-columns:1fr}
  .footer-inner{flex-direction:column; align-items:flex-start}
  .hero-copy h1{font-size:34px}
}

/* SPA-like single-page views */
.view[hidden]{display:none !important}

/* Legal pages (Impressum / Datenschutz) */
.legal-page{padding:34px 0 56px}
.legal-card{
  background:rgba(255,255,255,.78);
  border-radius:18px;
  box-shadow:0 10px 30px rgba(11,35,70,.06);
  padding:22px;
}
.legal-card h1{margin-top:0}
.legal-card h2{margin-top:22px}
.legal-meta{color:rgba(11,35,70,.70)}
.legal-back{margin:12px 0 0; display:inline-flex}

.legal-table{margin:12px 0 0; display:grid; gap:10px}
.legal-row{display:grid; grid-template-columns:220px 1fr; gap:12px}
.legal-k{font-weight:700; color:rgba(11,35,70,.85)}
.legal-v{color:rgba(11,35,70,.80)}

@media (max-width: 680px){
  .legal-row{grid-template-columns:1fr}
}

/* Leistungen (Services) — v2 (Feature Sections) */
.section-services{padding-top:52px}
.services-head p{max-width:75ch}

.services-stack{display:grid; gap:18px; margin-top:18px}

.service-feature{
  border-radius:22px;
  border:1px solid rgba(11,35,70,.10);
  background:
  radial-gradient(700px 320px at 80% 10%, rgba(23,107,255,.14), rgba(23,107,255,0) 60%),
  linear-gradient(180deg, rgba(255,255,255,.86), rgba(255,255,255,.66));
  box-shadow: 0 18px 60px rgba(11,35,70,.08);
  overflow:hidden;
}

.service-feature-grid{
  justify-items:stretch;
  display:grid;
  grid-template-columns: minmax(0, 1.15fr) minmax(0, 0.85fr);
  gap:18px;
  align-items:stretch;
}
.service-feature-grid.is-reversed{grid-template-columns: minmax(0, 0.85fr) minmax(0, 1.15fr)}
.service-feature-grid.is-reversed .service-feature-copy{order:2}
.service-feature-grid.is-reversed .service-feature-visual{
  min-width:0;order:1}

  .service-feature-copy{padding:22px}

  .service-eyebrow{
    margin:0 0 8px;
    display:inline-flex;
    gap:8px;
    align-items:center;
    font-weight:800;
    letter-spacing:.08em;
    text-transform:uppercase;
    font-size:12px;
    color:rgba(11,35,70,.72);
  }

  .service-feature h3{margin:0 0 10px; font-size:26px; letter-spacing:-.3px}
  .service-lead{margin:0 0 16px; color:rgba(11,35,70,.78); line-height:1.7; max-width:70ch}

  .service-benefits{
    display:grid;
    grid-template-columns:repeat(3, 1fr);
    gap:12px;
    margin:0;
  }

  .benefit{
    border-radius:16px;
    background:rgba(255,255,255,.72);
    border:1px solid rgba(11,35,70,.10);
    padding:14px;
  }
  .benefit h4{margin:0 0 6px; font-size:14px; letter-spacing:-.1px}
  .benefit p{margin:0; color:rgba(11,35,70,.72); line-height:1.55}

  .service-note{
    margin:0 0 14px;
    border-radius:16px;
    background:rgba(23,107,255,.08);
    border:1px solid rgba(23,107,255,.18);
    padding:12px 14px;
    color:rgba(11,35,70,.82);
    line-height:1.6;
  }

  .service-actions{margin-top:16px; display:flex; gap:12px; flex-wrap:wrap; align-items:center}

  .service-feature-visual{
    min-width:0;
    position:relative;
    display:flex;
    flex-direction:column;
    align-items:stretch;
    justify-content:flex-start;
    width:100%;
    padding:22px;
  }

  .service-illustration{
    width:100%;
    height:auto;
    aspect-ratio: 3 / 2;
    min-height:360px;
    object-fit:contain;
    border-radius:18px;
    border:1px solid rgba(11,35,70,.10);
    background:rgba(255,255,255,.55);
    display:block;

  }
  .services-next{
    margin-top:18px;
    border-radius:18px;
    border:1px solid rgba(11,35,70,.10);
    background:linear-gradient(180deg, rgba(23,107,255,.06), rgba(255,255,255,.65));
    padding:18px;
  }
  .services-next h3{margin:0 0 6px}
  .services-next p{margin:0; color:rgba(11,35,70,.75); max-width:none; line-height:1.65}

@media (max-width: 980px){
    .service-feature-grid,
    .service-feature-grid.is-reversed{grid-template-columns:1fr}
    .service-feature-grid.is-reversed .service-feature-copy,
    .service-feature-grid.is-reversed .service-feature-visual{
      min-width:0;order:unset}

      .service-feature-visual{
        min-width:0;padding:22px}
        .service-feature-visual.is-tight{padding:16px}
        .service-illustration{min-height:260px}
        .service-benefits{grid-template-columns:1fr}
      }

      .service-feature-visual .service-actions{
        margin-top: 14px;
        width: 100%;
        display: flex;
        justify-content: center;
        gap: 12px;
      }

@media (max-width: 520px){
        .service-feature-visual .service-actions{flex-wrap:wrap}
        .service-feature-visual .service-actions .btn{width:100%}
      }

/* Home: Services teaser */
      .home-services{padding-top:0px}
      .home-service-grid{display:grid; grid-template-columns:repeat(3, 1fr); gap:14px}
      .home-service-card{
        border-radius:18px;
        border:1px solid rgba(11,35,70,.10);
        background:rgba(255,255,255,.78);
        box-shadow: 0 10px 30px rgba(11,35,70,.06);
        overflow:hidden;
      }
      .home-service-media{
        padding:14px;
        background:
        radial-gradient(600px 260px at 70% 20%, rgba(23,107,255,.12), rgba(23,107,255,0) 60%),
        linear-gradient(180deg, rgba(255,255,255,.88), rgba(255,255,255,.68));
      }
      .home-service-media img{
        width:100%;
        height:220px;
        object-fit:contain;
        display:block;
      }
      .home-service-body{padding:14px 16px 16px}
      .home-service-body h3{margin:0 0 6px; font-size:18px}
      .home-service-body p{margin:0 0 10px; color:rgba(11,35,70,.74); line-height:1.6}
      .home-service-link{
        display:inline-flex;
        align-items:center;
        gap:8px;
        font-weight:700;
        color:rgba(11,35,70,.86);
      }
      .home-service-link:hover{color:rgba(11,35,70,.98)}
      .home-services-cta{margin-top:14px; display:flex; gap:12px; flex-wrap:wrap}

@media (max-width: 980px){
        .home-service-grid{grid-template-columns:1fr}
        .home-service-media img{height:240px}
      }

      .service-feature-visual .service-actions{align-self:stretch}

/* Ensure visual column uses full available width (independent of button width) */
      .service-feature-visual{
        min-width:0;box-sizing:border-box}
        .service-feature-visual > *{width:100%}

@media (min-width: 720px){
          .service-actions{flex-wrap:nowrap}
        }

        .service-actions .btn{white-space:nowrap}

/* About */
        .about-head p{max-width:75ch}
        .about-grid{display:grid; grid-template-columns: 1.1fr .9fr; gap:18px; align-items:start}
        .about-copy h3{margin:0 0 10px; font-size:22px}
        .about-copy p{margin:0 0 14px; color:rgba(11,35,70,.75); line-height:1.7}

        .about-points{display:grid; gap:12px}
        .about-point{
          border-radius:16px;
          background:rgba(255,255,255,.72);
          border:1px solid rgba(11,35,70,.10);
          padding:14px;
        }
        .about-point h4{margin:0 0 6px; font-size:14px}
        .about-point p{margin:0; color:rgba(11,35,70,.72); line-height:1.6}

        .about-cta{margin-top:14px; display:flex; gap:12px; align-items:center; flex-wrap:wrap}

        .about-visual{display:grid; gap:12px}
        .about-visual-card{
          border-radius:18px;
          border:1px solid rgba(11,35,70,.10);
          background:rgba(255,255,255,.78);
          box-shadow:0 10px 30px rgba(11,35,70,.06);
          overflow:hidden;
          padding:14px;
        }
        .about-visual-card img{
  width: 100%;
  height: 240px;
  object-fit: contain;
  object-position: center;
  display: block;
}

        .about-band{
          margin-top:18px;
          border-radius:18px;
          border:1px solid rgba(11,35,70,.10);
          background:linear-gradient(180deg, rgba(23,107,255,.06), rgba(255,255,255,.65));
          padding:18px;
        }
        .about-band h3{margin:0 0 10px}
        .about-values{display:grid; grid-template-columns:repeat(3,1fr); gap:12px}
        .about-value{
          border-radius:16px;
          background:rgba(255,255,255,.72);
          border:1px solid rgba(11,35,70,.10);
          padding:14px;
        }
        .about-value h4{margin:0 0 6px; font-size:14px}
        .about-value p{margin:0; color:rgba(11,35,70,.72); line-height:1.6}

@media (max-width: 980px){
          .about-grid{grid-template-columns:1fr}
          .about-visual-card img{height:240px}
          .about-values{grid-template-columns:1fr}
        }
