/* styles.css v4.4 (LIGHT) */
@import url('https://fonts.googleapis.com/css2?family=Inter:wght@300;400;500;600;700;800&family=DM+Sans:wght@300;400;500;600;700;800&display=swap');

:root{
  --bg:#f5f7fb;
  --text:#0e2a47; --muted:#5f6e85;
  --card:#ffffff; --border:#e3e8f4;
  --accent:#3b82f6; --accent-hover:#2563eb;
  --space-1:.25rem; --space-2:.5rem; --space-3:.75rem; --space-4:1rem; --space-5:1.25rem; --space-6:1.5rem; --space-8:2rem; --space-10:2.5rem; --space-12:3rem;
  --radius-sm:12px; --radius:16px; --radius-lg:24px; --radius-full:999px;
  --shadow-sm:0 2px 12px rgba(0,0,0,.04);
  --shadow-md:0 8px 30px rgba(0,0,0,.06);
  --shadow-lg:0 16px 48px rgba(0,0,0,.08);
  --container:1180px;
  --ease:cubic-bezier(.4,0,.2,1);
  --mx:50%; --my:50%; --ray-rot:0rad;
  color-scheme:light;
}

*{box-sizing:border-box;margin:0;padding:0}
html{height:100%;scroll-behavior:smooth}
body{
  min-height:100vh; background:var(--bg); color:var(--text);
  font-family:Inter,"DM Sans",system-ui,-apple-system,Segoe UI,Roboto,Helvetica,Arial,"Apple Color Emoji","Segoe UI Emoji";
  font-size:15px; line-height:1.6; -webkit-font-smoothing:antialiased; -moz-osx-font-smoothing:grayscale;
  position:relative; overflow-x:hidden;
}

/* Animated, subtle light background */
@keyframes bgShift {
  0%   { background-position: 0% 0%,  100% 50%, 20% 80%; }
  50%  { background-position: 100% 50%,  0% 30%, 80% 10%; }
  100% { background-position: 0% 0%,  100% 50%, 20% 80%; }
}
body::before{
  content:""; position:fixed; inset:0; z-index:0; pointer-events:none;
  background:
    radial-gradient(900px 900px at var(--mx) var(--my), rgba(117,157,230,.28), rgba(117,157,230,0) 58%),
    radial-gradient(680px 680px at 85% 22%, rgba(196,210,235,.33), rgba(196,210,235,0) 62%),
    radial-gradient(1000px 1000px at 10% 82%, rgba(210,224,248,.40), rgba(210,224,248,0) 68%);
  animation: bgShift 22s ease-in-out infinite alternate;
  background-repeat:no-repeat;
}

/* Waves near bottom (from v4.3) */
.wave{ position:fixed; left:0; z-index:0; pointer-events:none; width:200%; height:16em; bottom:160px; background:rgba(223,232,248,.72);
  border-radius:1000% 1000% 0 0; transform:translate3d(0,0,0); animation:wave 20s ease-in-out infinite; opacity:.75;}
.wave:nth-of-type(2){ bottom:120px; background:rgba(207,221,247,.7); animation-duration:30s; animation-direction:reverse; opacity:.72;}
.wave:nth-of-type(3){ bottom:80px; background:rgba(191,212,244,.68); animation-duration:38s; opacity:.68;}
@keyframes wave{ 0%{transform:translateX(0)} 50%{transform:translateX(-25%)} 100%{transform:translateX(0)} }

/* App frame */
.app-frame{background:var(--card);border:1px solid var(--border);border-radius:var(--radius-lg);box-shadow:var(--shadow-md);padding:clamp(28px,5.2vw,42px);margin:var(--space-8) auto;width:min(100% - 40px,var(--container));position:relative;z-index:1}
.container{width:min(100% - 40px,var(--container));margin-inline:auto;position:relative;z-index:1}

/* Type */
h1,h2,h3,h4,h5,h6{color:var(--text);font-weight:600;line-height:1.2;letter-spacing:-.02em}
h1{font-size:clamp(34px,5vw,52px);line-height:1.08;letter-spacing:-.03em;margin-bottom:var(--space-4)}
h2{font-size:clamp(22px,3.6vw,30px)} h3{font-size:clamp(17px,2.8vw,21px)}
p{margin-bottom:var(--space-4)}
a{color:var(--accent);text-decoration:none;transition:color .2s var(--ease)} a:hover,a:focus{color:var(--accent-hover);text-decoration:none}
.eyebrow{display:inline-flex;align-items:center;gap:8px;font-size:12px;font-weight:600;text-transform:uppercase;letter-spacing:.12em;color:var(--muted);margin-bottom:var(--space-3)}
.eyebrow::before{content:"";width:28px;height:1.5px;background:var(--border);display:inline-block}
.lead{font-size:clamp(16px,2vw,18px);color:var(--muted);max-width:60ch;margin:0 0 var(--space-5)}
.subtitle{color:var(--muted);margin:.25rem 0 .6rem}

/* Top nav */
.top-nav{position:sticky;top:0;z-index:100;backdrop-filter:saturate(180%) blur(12px);-webkit-backdrop-filter:saturate(180%) blur(12px);background:rgba(244,247,251,.85);border-bottom:1px solid var(--border);box-shadow:var(--shadow-sm)}
.top-nav-content{max-width:var(--container);margin:0 auto;padding:0 var(--space-6);display:flex;align-items:center;justify-content:space-between;height:64px}
.brand{display:inline-flex;align-items:center;gap:.6rem;color:var(--text)}
.brand .logo{width:26px;height:26px;object-fit:contain;display:inline-block;margin-right:.45rem}
.brand strong{font-size:21px}
.nav-toggle{display:none;border:1px solid var(--border);background:var(--card);border-radius:10px;padding:10px 12px;color:var(--text);position:relative}
.nav-toggle .bar{display:block;width:22px;height:2px;background:var(--text);margin:4px 0;transition:transform .25s var(--ease),opacity .25s var(--ease)}
.nav-open .nav-toggle .bar:nth-child(1){transform:translateY(6px) rotate(45deg)}.nav-open .nav-toggle .bar:nth-child(2){opacity:0}.nav-open .nav-toggle .bar:nth-child(3){transform:translateY(-6px) rotate(-45deg)}
.site-nav{display:block}
.top-nav-links{display:flex;gap:var(--space-6);align-items:center;list-style:none;margin:0;padding:0}
.top-nav-links a{color:var(--text);font-weight:600;font-size:14px;letter-spacing:.01em;padding:10px 12px;border-radius:10px;transition:color .2s var(--ease),background .2s var(--ease)}
.top-nav-links a:hover{background:#006699;color:#fff}
.nav-cta,.nav-cta:link,.nav-cta:visited{color:#fff !important}
.nav-cta{display:inline-flex;align-items:center;gap:.5rem;padding:.55rem .9rem;border-radius:999px;font-weight:700;font-size:14px;background:#243b6b;border:1px solid #243b6b;box-shadow:var(--shadow-sm);text-decoration:none;transition:transform .2s var(--ease),box-shadow .2s var(--ease),background .2s var(--ease),color .2s var(--ease),border-color .2s var(--ease)}
.nav-cta:hover{transform:translateY(-1px);box-shadow:var(--shadow-md);background:#006699;color:#fff !important;border-color:#006699;text-decoration:none}

/* Sections */
.section{padding:36px 0}
.hero{padding:clamp(26px,5.2vw,52px) 0}
.hero-grid{display:grid;grid-template-columns:1.2fr 1fr;gap:clamp(20px,3.6vw,40px);align-items:center}
.hero-media{background:linear-gradient(180deg,#ffffff,#eef4ff);border:1px solid var(--border);border-radius:22px;box-shadow:var(--shadow-md);aspect-ratio:4/3;overflow:hidden;position:relative}
.hero-media::after{content:"Minimal Mockup2";position:absolute;inset:auto 12px 12px auto;font-size:12px;color:var(--muted);background:rgba(255,255,255,.7);padding:6px 10px;border-radius:999px;border:1px solid var(--border)}

/* Grids */
.grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:clamp(14px,2.4vw,24px)}
.grid-2{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:clamp(14px,2.4vw,24px)}

/* Counters */
#zahlen.section{padding-top:18px}
.stats{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:clamp(14px,2.4vw,24px);margin:12px 0 6px}
.stat-card{background:#eef3ff;border:1px solid #d7e3ff;border-radius:18px;padding:18px;box-shadow:var(--shadow-sm);text-align:center;transition:transform .22s var(--ease),box-shadow .22s var(--ease),border-color .22s var(--ease)}
.stat-card:hover{transform:translateY(-2px);box-shadow:var(--shadow-md);border-color:var(--accent)}
.stat-value{font-size:clamp(26px,4.2vw,38px);font-weight:800;letter-spacing:-.02em;line-height:1.05}
.stat-label{margin-top:6px;color:var(--muted);font-weight:600;letter-spacing:.02em}

/* Dark promo box */
.dark-promo{
  background:#243b6b; color:#e6edf5;
  border:1px solid #1e305a; border-radius:18px;
  box-shadow:0 10px 30px rgba(36,59,107,.22);
  padding:18px 20px; margin: 4px 0 22px;
}
.dark-promo a{ color:#b9d3ff; font-weight:700 }
.dark-promo a:hover{ color:#fff }
.dark-promo .line{ display:block; margin-bottom:8px }
.dark-promo .pill-row{ display:grid; grid-template-columns:repeat(3,minmax(0,1fr)); gap:10px }
.dark-promo .pill{ display:flex; align-items:center; justify-content:center; gap:6px; padding:8px 10px; border-radius:999px; background:#1c2e59; border:1px solid #27447f; font-size:13px; color:#e6edf5 }

/* Folder Tabs */
.tabs{background:var(--card);border:1px solid var(--border);border-radius:18px;box-shadow:var(--shadow-sm)}
.tablist{display:flex;gap:10px;padding:10px;border-bottom:1px solid var(--border);flex-wrap:wrap}
.tab{position:relative;appearance:none;background:#f6f9ff;border:1px solid var(--border);border-bottom:none;border-radius:10px 10px 0 0;padding:.6rem .9rem;font-weight:800;cursor:pointer;box-shadow:0 2px 0 rgba(0,0,0,0.02)}
.tab::after{content:"";position:absolute;right:12px;top:-8px;width:10px;height:18px;border-radius:2px;background:#ffcc66;box-shadow:0 1px 0 rgba(0,0,0,.05)}
.tab[aria-selected="true"]{background:#fff;border-color:var(--accent);color:#0e2a47;z-index:2}
.tabpanel{display:none;padding:16px;background:#fff;border-top:1px solid var(--accent);border-radius:0 0 18px 18px}
.tabpanel.active{display:block}
.tab-flex{display:grid;grid-template-columns:1fr 1fr;gap:20px;align-items:flex-start}
.tab-graphic{width:100%;aspect-ratio:4/3;object-fit:cover;border:1px solid var(--border);border-radius:14px;background:#eef4ff}

/* Cards */
.card{background:var(--card);border:1px solid var(--border);border-radius:var(--radius);padding:var(--space-6);box-shadow:var(--shadow-sm);transition:transform .22s var(--ease),box-shadow .22s var(--ease),border-color .22s var(--ease)}
.card:hover{transform:translateY(-2px);box-shadow:var(--shadow-md);border-color:var(--accent)}
.feature-img{width:100%;aspect-ratio:4/3;object-fit:cover;display:block;border:1px solid var(--border);border-radius:16px;background:#eef4ff;margin-bottom:12px}

/* CTA band */
.band{
  margin: var(--space-8) 0; padding: clamp(16px, 3.4vw, 26px);
  background: var(--card); border:1px solid var(--border); border-radius: calc(var(--radius) + 8px);
  display:flex; align-items:center; justify-content:space-between; gap: 12px; flex-wrap:wrap; box-shadow: var(--shadow-sm);
}
.band strong{ font-size: clamp(18px, 2vw, 22px); }
.band .cta-row{ display:flex; gap:10px; flex-wrap:wrap }

/* Contact form */
.form-card{--fld-bg:#f8fbff}
.form-card h3{margin-bottom:8px}
.form-grid{display:grid;grid-template-columns:1fr 1fr;gap:12px}
.form-item{display:flex;flex-direction:column;gap:6px}
label{font-size:14px;font-weight:600;color:var(--text)}
.input, textarea, select, input[type="text"],input[type="email"],input[type="number"]{
  width:100%; padding:12px 14px; font-size:15px; color:var(--text);
  background:var(--card); border:2px solid var(--border); border-radius:12px; transition:border-color .2s var(--ease), box-shadow .2s var(--ease), background .2s var(--ease);
}
input[type="text"]:focus,input[type="email"]:focus,input[type="number"]:focus,textarea:focus,select:focus{
  outline:none; border-color:var(--accent); box-shadow:0 0 0 3px rgba(59,130,246,.12); background:#fff;
}
textarea{min-height:120px; resize:vertical}
.form-grid .span-2{grid-column:1 / -1}
.form-actions{display:flex;justify-content:flex-end;margin-top:6px}
.help{font-size:12px;color:var(--muted)}

/* Buttons */
.btn,.cta{display:inline-flex;align-items:center;justify-content:center;gap:var(--space-2);padding:14px 24px;font-size:15px;font-weight:600;border:none;border-radius:var(--radius-full);cursor:pointer;min-height:44px;position:relative;overflow:hidden;transition:transform .2s var(--ease),box-shadow .2s var(--ease),background .2s var(--ease),color .2s var(--ease)}
.btn::before,.cta::before{content:"";position:absolute;inset:0;left:-100%;background:linear-gradient(90deg,transparent,rgba(255,255,255,.3),transparent);transition:left .5s var(--ease)}
.btn:hover::before,.cta:hover::before{left:100%}
.btn-primary,.cta{background:var(--accent);color:#fff;box-shadow:var(--shadow-sm)}
.btn-primary:hover,.cta:hover{background:var(--accent-hover);color:#fff;transform:translateY(-1px);box-shadow:var(--shadow-md)}
.btn-secondary,.cta.secondary{background:#eaf2ff;color:var(--text);border:1px solid var(--border);box-shadow:none}
.btn-secondary:hover,.cta.secondary:hover{background:#f3f7ff;border-color:var(--accent);color:var(--text)}

/* Reveal */
.reveal{opacity:0;transform:translateY(14px);transition:opacity .9s var(--ease),transform .9s var(--ease)}
.reveal.show{opacity:1;transform:none}
[data-stagger] .reveal-child{opacity:0;transform:translateY(14px)}
[data-stagger].show .reveal-child{animation:revealIn .85s var(--ease) forwards}
[data-stagger].show .reveal-child:nth-child(2){animation-delay:.08s}
[data-stagger].show .reveal-child:nth-child(3){animation-delay:.16s}
[data-stagger].show .reveal-child:nth-child(4){animation-delay:.24s}
@keyframes revealIn{to{opacity:1;transform:none}}

/* Footer */
footer{margin-top:32px;border-top:1px solid rgba(255,255,255,.06);padding:20px 0;color:#e6edf5;background:#0f1a2c;box-shadow:0 -18px 40px rgba(0,0,0,.18);position:relative;z-index:2}
.footer-grid{display:grid;grid-template-columns:2fr 1fr 1fr 1fr;gap:14px}
.footer-grid a{color:#cfe0ff}
.footer-grid a:hover{color:#fff}
.footer-grid .socials{display:flex;gap:8px;margin-top:6px}
.footer-grid .socials .social{display:inline-flex;align-items:center;justify-content:center;width:28px;height:28px;border-radius:999px;border:1px solid rgba(255,255,255,.18);background:transparent;color:#e6edf5;font-size:13px}
.footer-grid .socials .social:hover{border-color:#fff;color:#fff}
.footer-address{font-size:13px; line-height:1.6; color:#cbd5e1; margin-top:6px}
.legal-row{display:flex;gap:.5rem;align-items:center;justify-content:center;padding:10px 0;color:#cbd5e1;font-size:12px;border-top:1px dashed rgba(255,255,255,.15);margin-top:8px}

/* Responsive */
@media (max-width:960px){
  .top-nav-content{flex-direction:column;height:auto;padding:var(--space-4) var(--space-6);gap:var(--space-4)}
  .nav-toggle{display:inline-block}
  .site-nav{display:none;width:100%}
  .site-nav.open{display:block}
  .top-nav-links{flex-direction:column;align-items:stretch;gap:.45rem}
  .top-nav-links>li{width:100%}
  .top-nav-links a{display:block;width:100%;padding:.8rem 1rem;border-radius:12px}
  .hero-grid{grid-template-columns:1fr}
  .footer-grid{grid-template-columns:1fr 1fr}
  .grid,.grid-3{grid-template-columns:1fr}
  .tab-flex{grid-template-columns:1fr}
  .form-grid{grid-template-columns:1fr}
  /* counters stacked */
  .stats{grid-template-columns:1fr}
  /* CTA band buttons stacked & centered */
  .band .cta-row{flex-direction:column; align-items:center; width:100%}
}
@media (max-width:640px){
  .container{width:min(100% - 32px,var(--container))}
  .card{padding:var(--space-5)}
  .footer-grid{grid-template-columns:1fr}
  .dark-promo .pill-row{grid-template-columns:1fr}
}

	/* Make the image fill the rounded mockup area */
.hero-media::after { content: none; }           /* hide "Minimal Mockup" label */
.hero-media { overflow: hidden; }               /* keep rounded clip */

.hero-media-img{
  width: 100%;
  height: 100%;
  object-fit: cover;                            /* fills without distortion */
  display: block;
}
