/* =========================================================================
   Migat — Produkt-Website (statisch, mehrseitig, DE/EN)
   Helle, professionelle Tech-Palette (abgeleitet aus dem Migat-Foliendeck:
   Slate + Teal/Blau). Ein gemeinsames Stylesheet für alle Seiten.
   ========================================================================= */
:root{
  --bg:        #eef2f7;   /* kühles Hellgrau            */
  --surface:   #ffffff;   /* Karten/Flächen             */
  --surface-2: #f5f8fc;   /* zweite Fläche              */
  --ink:       #16202e;   /* Text (Slate)               */
  --muted:     #586675;   /* Sekundärtext               */
  --teal:      #12867d;   /* Primär-Akzent (Teal)       */
  --teal-deep: #0f6f68;
  --teal-soft: #e1f2f0;
  --blue:      #2f6fd0;   /* zweiter Akzent             */
  --band:      #1b2330;   /* dunkles Band (Hero/Footer) */
  --band-2:    #243044;
  --line:      #e2e8f0;
  --radius:    18px;
  --maxw:      1140px;
  --sans: -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, "Helvetica Neue", Arial, sans-serif;
  --mono: "SF Mono", ui-monospace, "Cascadia Code", "Roboto Mono", Menlo, Consolas, monospace;
  --shadow: 0 24px 60px -34px rgba(16,32,46,.45);
}
*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{margin:0; background:var(--bg); color:var(--ink); font-family:var(--sans);
  line-height:1.66; -webkit-font-smoothing:antialiased}
img,svg{max-width:100%; display:block}
a{color:inherit}
h1,h2,h3{line-height:1.18; letter-spacing:-.01em; margin:0 0 .4em}
h1{font-size:clamp(2rem,4.6vw,3.1rem); font-weight:800}
h2{font-size:clamp(1.5rem,3vw,2.15rem); font-weight:750}
h3{font-size:1.08rem; font-weight:700}
p{margin:.4em 0}
.wrap{max-width:var(--maxw); margin:0 auto; padding:0 24px}
.kicker{text-transform:uppercase; letter-spacing:.2em; font-size:.72rem; font-weight:800; color:var(--teal)}
.muted{color:var(--muted)}
.center{text-align:center}

/* ---- Buttons ---- */
.btn{display:inline-flex; align-items:center; gap:.5em; padding:13px 24px; border-radius:999px;
  background:linear-gradient(135deg,var(--teal),var(--blue)); color:#fff; text-decoration:none;
  font-weight:700; font-size:.96rem; border:0; cursor:pointer; transition:transform .15s ease, box-shadow .2s ease}
.btn:hover{transform:translateY(-1px); box-shadow:0 12px 28px -12px rgba(47,111,208,.6)}
.btn.ghost{background:transparent; color:var(--teal-deep); border:1.5px solid #c7d3df}
.btn.ghost:hover{background:var(--surface); box-shadow:none}
.btn.light{background:#fff; color:var(--teal-deep)}
.btn.light:hover{background:#eef4f3}

/* ---- Header / Nav ---- */
header{position:sticky; top:0; z-index:20; background:rgba(238,242,247,.82);
  backdrop-filter:saturate(150%) blur(10px); border-bottom:1px solid var(--line)}
.bar{display:flex; align-items:center; justify-content:space-between; height:72px; gap:18px}
.brand{display:flex; align-items:center; gap:11px; text-decoration:none}
.brand .mark{width:30px; height:30px; flex:0 0 auto}
.brand .name{font-weight:800; font-size:1.35rem; letter-spacing:-.02em; color:var(--ink)}
.brand small{display:block; font-size:.58rem; letter-spacing:.18em; text-transform:uppercase; color:var(--muted); font-weight:700; margin-top:-2px}
nav.main{display:flex; align-items:center; gap:26px}
nav.main a{text-decoration:none; color:var(--ink); font-weight:600; font-size:.95rem; opacity:.82}
nav.main a:hover,nav.main a.active{opacity:1; color:var(--teal-deep)}
.head-right{display:flex; align-items:center; gap:14px}

.langmenu{position:relative}
.langmenu>summary{list-style:none; cursor:pointer; color:var(--muted); display:flex; align-items:center; gap:5px; padding:6px 8px; border-radius:9px; font-size:.82rem; font-weight:700}
.langmenu>summary::-webkit-details-marker{display:none}
.langmenu>summary:hover{color:var(--teal-deep); background:var(--surface)}
.langpop{position:absolute; right:0; top:130%; background:var(--surface); border:1px solid var(--line);
  border-radius:12px; box-shadow:var(--shadow); padding:6px; min-width:150px; display:flex; flex-direction:column; gap:2px; z-index:30}
.langpop a{padding:8px 12px; border-radius:8px; font-size:.88rem; text-decoration:none; color:var(--ink); font-weight:600}
.langpop a:hover{background:var(--teal-soft); color:var(--teal-deep)}
.langpop a.active{color:var(--teal-deep); font-weight:800}

.navtoggle{display:none; background:none; border:0; cursor:pointer; color:var(--ink); padding:6px}
@media(max-width:860px){
  nav.main{position:absolute; top:72px; left:0; right:0; flex-direction:column; gap:0;
    background:var(--surface); border-bottom:1px solid var(--line); padding:8px 0; display:none}
  nav.main.open{display:flex}
  nav.main a{width:100%; padding:13px 24px; opacity:1}
  .navtoggle{display:block}
}

/* ---- Hero ---- */
.hero{padding:76px 0 60px}
.hero-grid{display:grid; gap:48px; grid-template-columns:1.05fr .95fr; align-items:center}
.hero h1{margin:.18em 0 .3em}
.hero h1 em{font-style:normal; background:linear-gradient(120deg,var(--teal),var(--blue));
  -webkit-background-clip:text; background-clip:text; color:transparent}
.hero p.lead{font-size:1.12rem; color:var(--muted); max-width:540px; margin:0 0 28px}
.cta-row{display:flex; gap:13px; flex-wrap:wrap}
.trust{display:flex; gap:18px; flex-wrap:wrap; margin-top:26px; font-size:.82rem; color:var(--muted)}
.trust span{display:flex; align-items:center; gap:7px; font-weight:600}
.trust b{color:var(--teal-deep)}
@media(max-width:860px){ .hero-grid{grid-template-columns:1fr} .hero{padding:48px 0 36px} }

/* ---- Geräte-/App-Mock (CSS, ohne externe Bilder) ---- */
.mock{background:linear-gradient(160deg,var(--band),var(--band-2)); border-radius:24px; padding:26px;
  box-shadow:var(--shadow); color:#e9eef5}
.mock .screen{background:#0f1620; border:1px solid #2c3a4f; border-radius:14px; padding:20px}
.mock .row{display:flex; align-items:center; justify-content:space-between; gap:10px; padding:11px 0; border-bottom:1px solid #223047}
.mock .row:last-child{border-bottom:0}
.mock .dot{width:10px;height:10px;border-radius:50%;background:#3fd1a8;box-shadow:0 0 0 4px #3fd1a833}
.mock .t{font-weight:700;color:#fff}
.mock .s{color:#9fb0c6; font-size:.85rem}
.mock .big{font-size:1.7rem; font-weight:800; color:#fff; font-variant-numeric:tabular-nums}
.mock .pulsebtn{margin-top:14px; text-align:center; background:linear-gradient(135deg,#2bb39a,#2f6fd0);
  color:#fff; font-weight:800; padding:14px; border-radius:12px; letter-spacing:.02em}
.mock .cap{margin-top:12px; font-size:.74rem; color:#8aa0bb; text-align:center}

/* ---- Sections ---- */
section{padding:72px 0}
.section.alt{background:var(--surface-2); border-block:1px solid var(--line)}
.section-head{max-width:680px; margin:0 auto 44px}
.section-head.center{text-align:center}
.section-head p{color:var(--muted); margin:.3em 0 0}

/* ---- Zwei-Fragen / Split ---- */
.split{display:grid; gap:26px; grid-template-columns:1fr 1fr}
@media(max-width:760px){ .split{grid-template-columns:1fr} }

/* ---- Cards ---- */
.grid{display:grid; gap:22px; grid-template-columns:repeat(auto-fit,minmax(250px,1fr))}
.card{background:var(--surface); border:1px solid var(--line); border-radius:var(--radius); padding:28px 26px;
  transition:transform .18s ease, box-shadow .18s ease}
.card:hover{transform:translateY(-3px); box-shadow:var(--shadow)}
.card .ic{width:44px; height:44px; display:grid; place-items:center; border-radius:12px;
  background:var(--teal-soft); color:var(--teal-deep); font-size:1.4rem; margin-bottom:14px}
.card h3{color:var(--ink); margin:0 0 .35em}
.card p{color:var(--muted); margin:0; font-size:.97rem}

/* ---- Flow (Terminal-Ablauf) ---- */
.flow{display:flex; gap:14px; align-items:stretch; flex-wrap:wrap}
.flow .step{flex:1 1 200px; background:var(--surface); border:1px solid var(--line); border-radius:var(--radius); padding:22px}
.flow .step .n{width:30px;height:30px;border-radius:50%;background:linear-gradient(135deg,var(--teal),var(--blue));
  color:#fff;font-weight:800;display:grid;place-items:center;margin-bottom:12px}
.flow .step h3{margin:0 0 .3em}
.flow .step p{color:var(--muted); margin:0; font-size:.95rem}

/* ---- Liste mit Häkchen ---- */
.checks{list-style:none; padding:0; margin:.4em 0; display:grid; gap:12px}
.checks li{position:relative; padding-left:34px; color:var(--ink)}
.checks li::before{content:"✓"; position:absolute; left:0; top:0; width:22px; height:22px; border-radius:50%;
  background:var(--teal-soft); color:var(--teal-deep); font-weight:800; font-size:.8rem; display:grid; place-items:center}
.checks li b{font-weight:700}

/* ---- Badges/Pills ---- */
.pills{display:flex; flex-wrap:wrap; gap:8px; margin-top:8px}
.pill{display:inline-flex; align-items:center; gap:.4em; background:var(--surface); border:1px solid var(--line);
  border-radius:999px; padding:7px 14px; font-size:.85rem; font-weight:600; color:var(--ink)}
.pill .d{width:8px;height:8px;border-radius:50%;background:var(--teal)}

/* ---- Dunkles Band / Contact ---- */
.band{background:linear-gradient(160deg,var(--band),var(--band-2)); color:#eef3f9}
.band .kicker{color:#5fd0c6}
.band h2{color:#fff}
.band p{color:#bcc9da}
.contact-card{background:linear-gradient(160deg,var(--band),var(--band-2)); color:#fff; border-radius:26px;
  text-align:center; padding:60px 28px; box-shadow:var(--shadow)}
.contact-card h2{color:#fff}
.contact-card p{color:#bcc9da; max-width:560px; margin:.5em auto 24px}
.contact-card a.mail{color:#fff; font-weight:700; text-decoration:underline; text-underline-offset:4px; font-size:1.1rem}

/* ---- Footer ---- */
footer{background:var(--band); color:#aeb9c8; padding:46px 0 30px; margin-top:10px}
footer .cols{display:grid; gap:30px; grid-template-columns:1.4fr 1fr 1fr; align-items:start}
footer h4{color:#fff; font-size:.92rem; margin:0 0 .8em; letter-spacing:.02em}
footer a{color:#aeb9c8; text-decoration:none; display:block; padding:3px 0; font-size:.92rem}
footer a:hover{color:#fff}
footer .copy{border-top:1px solid #2c3a4f; margin-top:30px; padding-top:18px; font-size:.82rem; color:#8593a6;
  display:flex; justify-content:space-between; gap:14px; flex-wrap:wrap}
@media(max-width:760px){ footer .cols{grid-template-columns:1fr 1fr} }

/* ---- Legal-/Textseiten ---- */
.prose{max-width:780px; margin:0 auto}
.prose h2{margin-top:1.4em}
.prose p,.prose li{color:var(--muted)}
.note{background:var(--teal-soft); border-left:3px solid var(--teal); border-radius:10px; padding:14px 16px;
  color:var(--teal-deep); font-size:.92rem; margin:1em 0}

/* ---- Hilfsklassen ---- */
.lead-xl{font-size:1.18rem; color:var(--muted)}
.spacer{height:8px}
.eyebrow-row{display:flex; align-items:center; gap:12px; margin-bottom:10px}
