
:root{
  --bg:#f5f5f7;
  --surface:#ffffff;
  --text:#1d1d1f;
  --muted:#6e6e73;
  --accent:#0071e3;
  --accent-hover:#0077ed;
  --max:1240px;
  --radius:28px;
  --radius-lg:44px;
  --shadow-soft:0 24px 70px rgba(0,0,0,.08);
  --shadow-card:0 12px 36px rgba(0,0,0,.06);
  --nav-h:72px;
}
*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{
  margin:0;
  font-family:"SF Pro Text","SF Pro Display",-apple-system,BlinkMacSystemFont,"Segoe UI","Helvetica Neue",Arial,sans-serif;
  background:
    radial-gradient(circle at top left, rgba(255,255,255,.75), transparent 28%),
    linear-gradient(180deg,#f7f7f9 0%,#f3f4f7 100%);
  color:var(--text);
  line-height:1.5;
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
}
img{display:block;max-width:100%}
a{text-decoration:none;color:inherit}
button,input,textarea{font:inherit}
.container{width:min(var(--max),calc(100% - 48px));margin:0 auto}
.site-header{position:sticky;top:0;z-index:100;background:rgba(245,245,247,.8);backdrop-filter:blur(22px);border-bottom:1px solid rgba(0,0,0,.05)}
.nav{min-height:var(--nav-h);display:flex;align-items:center;justify-content:space-between;gap:24px;padding:8px 0}
.brand{display:flex;align-items:center;gap:10px;font-size:.96rem;font-weight:600;letter-spacing:-.02em;white-space:nowrap}
.brand-mark{
  width:18px;
  height:18px;
  border-radius:4px;
  background-image:url("favicon.png");
  background-size:contain;
  background-position:center;
  background-repeat:no-repeat;
}
.nav-links{display:flex;align-items:center;gap:22px;flex-wrap:wrap;justify-content:flex-end;color:var(--muted);font-size:.92rem}
.nav-links a:hover,.nav-links a:focus-visible{color:var(--text)}
.nav-links a.active{color:var(--accent);font-weight:600}
.hero{padding:88px 0 58px;text-align:center}
.eyebrow{display:inline-block;margin-bottom:18px;color:var(--accent);font-weight:600;font-size:.98rem;letter-spacing:-.004em}
h1,h2,h3,p{margin:0}
h1{font-size:clamp(3.3rem,8vw,6.2rem);line-height:.95;letter-spacing:-.05em;max-width:11.2ch;margin:0 auto 20px;font-weight:700}
h2{font-size:clamp(2.3rem,5vw,4.2rem);line-height:.98;letter-spacing:-.045em;margin-bottom:16px;font-weight:700}
h3{font-size:1.34rem;line-height:1.15;letter-spacing:-.02em;font-weight:600}
.lead{max-width:860px;margin:0 auto;font-size:clamp(1.08rem,2vw,1.34rem);line-height:1.48;color:var(--muted);letter-spacing:-.006em}
.copy,.section-head p,.card p,.metric p,.caption,.contact-copy,.footer-copy,.body-copy,.faq-answer,.feature-list li,.spec-list li{
  font-size:clamp(1rem,1.8vw,1.08rem);color:var(--muted);line-height:1.58;letter-spacing:-.003em
}
.btn-row,.hero-actions{display:flex;justify-content:center;gap:14px;flex-wrap:wrap;margin-top:30px}
.btn{display:inline-flex;align-items:center;justify-content:center;padding:14px 22px;border-radius:999px;font-weight:600;font-size:1rem;border:0;cursor:pointer;transition:background .2s ease,transform .2s ease,box-shadow .2s ease}
.btn:hover,.btn:focus-visible{transform:translateY(-1px)}
.btn-primary{background:var(--accent);color:#fff;box-shadow:0 10px 24px rgba(0,113,227,.18)}
.btn-primary:hover,.btn-primary:focus-visible{background:var(--accent-hover)}
.btn-secondary{background:transparent;color:var(--accent)}
.link-arrow{color:var(--accent);font-weight:600;font-size:1rem}
.link-arrow:hover,.link-arrow:focus-visible{text-decoration:underline}
.section{padding:104px 0}
.section.compact{padding:76px 0}
.section-head{text-align:center;max-width:900px;margin:0 auto 58px}
.hero-frame,.hero-phone-strip,.showcase,.product-card,.card,.visual-card,.contact-card,.final-cta,.stat-band{
  background:rgba(255,255,255,.82);
  border:1px solid rgba(255,255,255,.55);
  box-shadow:0 24px 70px rgba(0,0,0,.08);
  backdrop-filter:blur(12px)
}
.card,.contact-card{padding:32px;border-radius:28px}
.card strong{display:block;font-size:1.16rem;line-height:1.2;letter-spacing:-.02em;margin-bottom:10px;font-weight:600;color:var(--text)}
.grid-2,.grid-3,.grid-4,.mosaic-2{display:grid;gap:28px}
.grid-2{grid-template-columns:repeat(2,minmax(0,1fr))}
.grid-3{grid-template-columns:repeat(3,minmax(0,1fr))}
.grid-4{grid-template-columns:repeat(4,minmax(0,1fr))}
.mosaic-2{grid-template-columns:1fr 1fr}
.hero-frame{overflow:hidden;margin-top:30px;border-radius:44px}
.hero-phone-strip{padding:24px;border-radius:34px}
.hero-phone-strip .grid-4{gap:18px}
.gallery-phone{padding:18px;background:linear-gradient(180deg,#fcfcfd 0%,#f2f4f7 100%);border-radius:26px;border:1px solid rgba(0,0,0,.04)}
.gallery-phone img,.visual-card img{border-radius:22px;box-shadow:0 10px 26px rgba(0,0,0,.08)}
.showcase{overflow:hidden;border-radius:44px}
.showcase-grid{display:grid;grid-template-columns:.98fr 1.02fr;align-items:stretch}
.showcase-image{background:linear-gradient(180deg,#ffffff 0%,#eef2f6 100%);padding:28px}
.showcase-image img{width:100%;height:100%;object-fit: contain;border-radius:28px}
.showcase-copy{padding:58px 54px;display:flex;flex-direction:column;justify-content:center;gap:26px}
.stack{display:grid;gap:18px}
.stack>div{padding-bottom:18px;border-bottom:1px solid rgba(0,0,0,.06)}
.stack>div:last-child{padding-bottom:0;border-bottom:0}
.visual-card{overflow:hidden;border-radius:28px}
.visual-card .copy-wrap{padding:24px 26px}
.visual-card .copy-wrap h3{margin-bottom:8px}
.image-fit{background:linear-gradient(180deg,#fff 0%,#f2f4f7 100%)}
.image-fit img{object-fit: contain;background:transparent}
.product-card{overflow:hidden;border-radius:44px}
.product-card .image{aspect-ratio:16/11;background:linear-gradient(180deg,#fff 0%,#f2f4f7 100%);padding:28px}
.product-card .image img{width:100%;height:100%;object-fit: contain}
.product-card .copy-wrap{padding:32px}
.tags{display:flex;flex-wrap:wrap;gap:10px;margin:18px 0 22px}
.tag{padding:8px 12px;border-radius:999px;background:#f0f2f5;color:#515154;font-size:.88rem;font-weight:500}
.feature-list,.spec-list{list-style:none;padding:0;margin:0;display:grid;gap:12px}
.feature-list li,.spec-list li{padding:14px 0;border-bottom:1px solid rgba(0,0,0,.06)}
.feature-list li:last-child,.spec-list li:last-child{border-bottom:0}
.contact-grid{display:grid;grid-template-columns:1fr 1fr;gap:28px}
.contact-list{display:grid;gap:16px;margin-top:22px}
.contact-list a,.contact-list div{display:block;padding:18px 20px;border-radius:20px;background:#fafafd;border:1px solid rgba(0,0,0,.05)}
.contact-label{display:block;color:var(--muted);font-size:.92rem;margin-bottom:4px}
.form{display:grid;gap:14px;margin-top:22px}
.field{display:grid;gap:8px}
.label{font-size:.92rem;font-weight:600;color:var(--muted)}
input,textarea{width:100%;border:1px solid rgba(0,0,0,.1);background:#fff;border-radius:18px;padding:15px 16px;color:var(--text);outline:none;transition:border-color .2s ease,box-shadow .2s ease}
textarea{min-height:140px;resize:vertical}
input:focus,textarea:focus{border-color:rgba(0,113,227,.4);box-shadow:0 0 0 4px rgba(0,113,227,.12)}
.final-cta{padding:46px;border-radius:36px;display:flex;align-items:center;justify-content:space-between;gap:28px}
.site-footer{padding:0 0 56px}
.footer-inner{padding-top:24px;display:flex;justify-content:space-between;gap:24px;align-items:center;color:var(--muted);font-size:.95rem;border-top:1px solid rgba(0,0,0,.06)}
.footer-links{display:flex;gap:18px;flex-wrap:wrap}
.footer-links a:hover,.footer-links a:focus-visible{color:var(--text)}
@media (max-width:1100px){
  .grid-4,.grid-3,.grid-2,.mosaic-2,.showcase-grid,.contact-grid,.final-cta,.footer-inner{grid-template-columns:1fr;flex-direction:column;align-items:flex-start}
  .showcase-copy,.contact-card,.final-cta{padding:30px}
}
@media (max-width:720px){
  .container{width:min(1240px,calc(100% - 24px))}
  .nav{min-height:auto;padding:14px 0;flex-direction:column;align-items:flex-start}
  .nav-links{gap:14px;justify-content:flex-start}
  .section{padding:82px 0}
  .section.compact{padding:66px 0}
  h1{max-width:none}
  .hero-frame,.showcase,.final-cta,.contact-card,.product-card{border-radius:24px}
  .card,.product-card .copy-wrap,.visual-card .copy-wrap,.contact-card{padding:24px}
  .hero-phone-strip{padding:18px}
}


.resource-row{
  display:flex;
  justify-content:center;
  gap:14px;
  flex-wrap:wrap;
  margin-top:22px;
}
.resource-pill{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  padding:12px 18px;
  border-radius:999px;
  background:#f0f2f5;
  color:#1d1d1f;
  font-weight:600;
  font-size:.96rem;
}
.resource-pill:hover,.resource-pill:focus-visible{
  background:#e8ebf0;
}
.footer-clean{
  display:grid;
  grid-template-columns:1.3fr .9fr .9fr;
  gap:28px;
  padding-top:28px;
  border-top:1px solid rgba(0,0,0,.06);
}
.footer-title{
  font-size:.95rem;
  font-weight:700;
  margin-bottom:12px;
  color:var(--text);
}
.footer-list{
  display:grid;
  gap:10px;
}
.footer-list a{
  color:var(--muted);
  font-size:.95rem;
}
.footer-list a:hover,.footer-list a:focus-visible{
  color:var(--text);
}
.footer-note{
  color:var(--muted);
  font-size:.95rem;
  line-height:1.6;
  max-width:48ch;
}
@media (max-width:1100px){
  .footer-clean{
    grid-template-columns:1fr;
  }
}


/* Bildzentrierung */
.hero-frame,
.product-card .image,
.showcase-image,
.gallery-phone,
.visual-card.image-fit,
.visual-card,
.image-fit {
  display: flex;
  align-items: center;
  justify-content: center;
}

.hero-frame img,
.product-card .image img,
.showcase-image img,
.gallery-phone img,
.visual-card img,
.image-fit img {
  object-position: center center;
  margin-left: auto;
  margin-right: auto;
}

.product-card .image,
.showcase-image,
.visual-card.image-fit,
.image-fit {
  overflow: hidden;
}

.product-card .image img,
.showcase-image img,
.visual-card.image-fit img,
.image-fit img {
  max-width: 100%;
  max-height: 100%;
}


.products-hero {
  padding-bottom: 32px;
}
.product-feature-list {
  list-style: none;
  padding: 0;
  margin: 18px 0 22px;
  display: grid;
  gap: 10px;
}
.product-feature-list li {
  color: var(--muted);
  font-size: 1rem;
  line-height: 1.5;
  padding-bottom: 10px;
  border-bottom: 1px solid rgba(0,0,0,.06);
}
.product-feature-list li:last-child {
  border-bottom: 0;
  padding-bottom: 0;
}
.product-intro-card {
  text-align: left;
}


/* Robuste Layout-Korrekturen */
.grid-2 > *,
.grid-3 > *,
.grid-4 > *,
.mosaic-2 > *,
.showcase-grid > *,
.contact-grid > * {
  min-width: 0;
}

.card,
.visual-card,
.product-card,
.contact-card,
.showcase-copy,
.showcase-image,
.copy-wrap {
  overflow-wrap: normal;
  word-break: normal;
}

h1,
h2,
h3,
.lead,
.copy,
.caption,
.body-copy,
.section-head p,
.stack p,
.stack strong,
.feature-list li,
.spec-list li {
  overflow-wrap: normal;
  word-break: normal;
  hyphens: auto;
}

.showcase-copy h2 {
  text-wrap: balance;
  max-width: 16ch;
}

.visual-card,
.visual-card.image-fit {
  display: flex !important;
  flex-direction: column !important;
  align-items: stretch !important;
  justify-content: flex-start !important;
}

.visual-card img,
.visual-card.image-fit img {
  width: 100% !important;
  height: auto !important;
  max-height: none !important;
  object-fit: contain !important;
  object-position: center center !important;
  margin: 0 auto !important;
  flex: 0 0 auto !important;
}

.visual-card .copy-wrap {
  width: 100% !important;
  flex: 0 0 auto !important;
}

.gallery-phone {
  display: flex;
  align-items: center;
  justify-content: center;
}

.gallery-phone img {
  width: 100%;
  height: auto;
  object-fit: contain;
}

.showcase-image {
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
}

.showcase-image img {
  width: 100% !important;
  height: auto !important;
  max-height: 760px !important;
  object-fit: contain !important;
  object-position: center center !important;
}

.product-card .image {
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
}

.product-card .image img {
  width: 100% !important;
  height: auto !important;
  object-fit: contain !important;
  object-position: center center !important;
}

.dynopull-device {
  width: 70% !important;
  height: auto !important;
}

.dynopull-index-device {
  width: 55% !important;
  height: auto !important;
}

.app-core-screen {
  width: 100% !important;
  height: 640px !important;
  object-fit: contain !important;
}

@media (max-width: 900px) {
  .app-core-screen {
    height: auto !important;
  }
}

.copy-wrap h3,
.visual-card .copy-wrap h3 {
  line-height: 1.2;
}

.copy-wrap .link-arrow {
  display: inline-block;
  margin-top: 12px;
}

.caption,
.copy,
.body-copy,
.feature-list li,
.spec-list li {
  max-width: 62ch;
}

.hero-phone-strip .grid-4 {
  align-items: start;
}

@media (max-width: 1100px) {
  .mosaic-2 {
    grid-template-columns: 1fr !important;
  }
}

.app-hero-actions {
  gap: 18px;
  margin-top: 38px;
}

.app-hero-phone-strip {
  margin-top: 52px;
}
