/* Inventissimo — Marken-Stylesheet (aus dem Entwurf inventissimo_vorschau.html, für Mehrseiten extrahiert).
   Design-System: Violett #5016C0 (Struktur), Dunkelviolett #2E0B72 (CTA/Footer), Orange #E87808 (eine
   Aktionsfarbe). Space Grotesk (Headlines) + Inter (Fließtext). Signatur: feine Evolutionslinie + oranger Punkt. */

/* Selbst gehostete Schriften (DSGVO — keine Google-Fonts-CDN, keine IP-Übertragung an Google).
   Variable woff2 aus /fonts. latin deckt Deutsch komplett ab (ä ö ü ß „ " – € in U+0000–00FF / U+2000–206F);
   latin-ext nur als Glyphen-Sicherheitsnetz. Lizenz beider Schriften: SIL OFL 1.1 — siehe /fonts/LICENSE.txt. */
@font-face{
  font-family:'Inter';
  font-style:normal;
  font-weight:100 900;
  font-display:swap;
  src:url('/fonts/inter-latin.woff2') format('woff2');
  unicode-range:U+0000-00FF,U+0131,U+0152-0153,U+02BB-02BC,U+02C6,U+02DA,U+02DC,U+0304,U+0308,U+0329,U+2000-206F,U+20AC,U+2122,U+2191,U+2193,U+2212,U+2215,U+FEFF,U+FFFD;
}
@font-face{
  font-family:'Inter';
  font-style:normal;
  font-weight:100 900;
  font-display:swap;
  src:url('/fonts/inter-latin-ext.woff2') format('woff2');
  unicode-range:U+0100-02BA,U+02BD-02C5,U+02C7-02CC,U+02CE-02D7,U+02DD-02FF,U+0304,U+0308,U+0329,U+1D00-1DBF,U+1E00-1E9F,U+1EF2-1EFF,U+2020,U+20A0-20AB,U+20AD-20C0,U+2113,U+2C60-2C7F,U+A720-A7FF;
}
@font-face{
  font-family:'Space Grotesk';
  font-style:normal;
  font-weight:300 700;
  font-display:swap;
  src:url('/fonts/space-grotesk-latin.woff2') format('woff2');
  unicode-range:U+0000-00FF,U+0131,U+0152-0153,U+02BB-02BC,U+02C6,U+02DA,U+02DC,U+0304,U+0308,U+0329,U+2000-206F,U+20AC,U+2122,U+2191,U+2193,U+2212,U+2215,U+FEFF,U+FFFD;
}
@font-face{
  font-family:'Space Grotesk';
  font-style:normal;
  font-weight:300 700;
  font-display:swap;
  src:url('/fonts/space-grotesk-latin-ext.woff2') format('woff2');
  unicode-range:U+0100-02BA,U+02BD-02C5,U+02C7-02CC,U+02CE-02D7,U+02DD-02FF,U+0304,U+0308,U+0329,U+1D00-1DBF,U+1E00-1E9F,U+1EF2-1EFF,U+2020,U+20A0-20AB,U+20AD-20C0,U+2113,U+2C60-2C7F,U+A720-A7FF;
}
:root{
  --violett:#5016C0;
  --dunkel:#2E0B72;
  --orange:#E87808;
  --orange-hell:#F6A23A;
  --orange-tief:#D86C00;
  --grund:#F4F1FB;
  --weiss:#FFFFFF;
  --ink:#1b1430;
  --muted:#5a5470;
  --line:#e4ddf5;
  --display:"Space Grotesk",system-ui,sans-serif;
  --body:"Inter",system-ui,-apple-system,sans-serif;
  --wrap:1080px;
}
*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{font-family:var(--body);color:var(--ink);background:var(--weiss);line-height:1.65;-webkit-font-smoothing:antialiased;font-size:17px}
h1,h2,h3{font-family:var(--display);line-height:1.12;letter-spacing:-0.02em;font-weight:700}
p{margin:0 0 1rem}
a{color:inherit}

/* nav */
.nav{position:sticky;top:0;z-index:20;background:rgba(255,255,255,.86);backdrop-filter:blur(10px);border-bottom:1px solid var(--line)}
.nav__in{max-width:var(--wrap);margin:0 auto;padding:.85rem 1.4rem;display:flex;align-items:center;justify-content:space-between;gap:1rem}
.brand{font-family:var(--display);font-weight:700;font-size:1.15rem;letter-spacing:-0.01em;color:var(--violett);text-decoration:none}
.brand span{color:var(--orange)}
.brand{display:inline-flex;align-items:center}
.brandlogo{height:34px;width:auto;display:block}
.inlinephoto{width:100%;height:280px;object-fit:cover;border-radius:14px;display:block;box-shadow:0 8px 24px rgba(46,11,114,.08)}
.navlinks{display:flex;gap:1.4rem;align-items:center;font-size:.92rem;font-weight:500}
.navlinks a{text-decoration:none;color:var(--muted)}
.navlinks a:hover{color:var(--violett)}
.soon{font-size:.6rem;text-transform:uppercase;letter-spacing:.1em;background:var(--grund);color:var(--violett);padding:.15rem .4rem;border-radius:99px;margin-left:.3rem;vertical-align:middle}
.navlinks .btn-mini{display:none}
.navtoggle{display:none;background:none;border:0;color:var(--violett);cursor:pointer;padding:.5rem;border-radius:8px;line-height:0}
.navsection{display:none}

/* layout */
.section{padding:5.5rem 1.4rem;scroll-margin-top:78px}
.in{max-width:var(--wrap);margin:0 auto}
.narrow{max-width:680px;margin:0 auto}
.tint{background:var(--grund)}
.eyebrow{font-family:var(--display);text-transform:uppercase;letter-spacing:.16em;font-size:.82rem;font-weight:600;color:var(--violett);margin-bottom:1.1rem;display:flex;align-items:center;gap:.6rem}
.eyebrow::before{content:"";width:26px;height:2px;background:var(--orange)}

/* evolution line motif */
.evoline{height:2px;background:linear-gradient(90deg,transparent,var(--line) 12%,var(--violett));position:relative;max-width:var(--wrap);margin:0 auto;opacity:.7}
.evoline::after{content:"";position:absolute;right:0;top:50%;width:10px;height:10px;border-radius:50%;background:var(--orange);transform:translateY(-50%);box-shadow:0 0 0 4px rgba(232,120,8,.18)}

/* hero */
.hero{padding-top:4.5rem;padding-bottom:4.5rem}
.hero__grid{display:grid;grid-template-columns:1.15fr .85fr;gap:3rem;align-items:center}
.hero h1{font-size:clamp(2rem,5vw,3.15rem);margin-bottom:1.4rem}
.hero .lead{font-size:1.12rem;color:var(--muted);max-width:34ch}
.proofquote{margin:1.8rem 0;padding:1rem 1.25rem;border-left:3px solid var(--orange);background:var(--grund);border-radius:0 10px 10px 0;font-size:1rem}
.proofquote b{color:var(--orange-tief);font-weight:700}

/* buttons */
.btn{display:inline-block;background:var(--orange);color:#fff;font-family:var(--display);font-weight:600;font-size:1rem;text-decoration:none;padding:.85rem 1.5rem;border-radius:10px;border:2px solid var(--orange);transition:transform .15s ease, box-shadow .15s ease, background .15s ease;box-shadow:0 6px 18px rgba(232,120,8,.28)}
.btn:hover{background:var(--orange-tief);border-color:var(--orange-tief);transform:translateY(-2px);box-shadow:0 10px 24px rgba(232,120,8,.34)}
.btn--ghost{background:transparent;color:var(--violett);border-color:var(--violett);box-shadow:none}
.btn--ghost:hover{background:var(--violett);color:#fff;transform:translateY(-2px)}
.btn--light{background:var(--orange);border-color:var(--orange)}

/* image placeholder — refined brand panel (steht bis echte Fotos da sind; dann <img> einsetzen) */
.ph{position:relative;overflow:hidden;border-radius:16px;min-height:340px;
  background:radial-gradient(130% 130% at 100% 0%,rgba(232,120,8,.12),transparent 55%),linear-gradient(135deg,var(--dunkel),var(--violett));
  display:flex;align-items:flex-end;padding:1.4rem}
.ph::before{content:"";position:absolute;left:-12%;right:-12%;top:52%;height:2px;background:linear-gradient(90deg,transparent,rgba(255,255,255,.42));transform:rotate(-7deg)}
.ph::after{content:"";position:absolute;right:16%;top:48%;width:12px;height:12px;border-radius:50%;background:var(--orange);box-shadow:0 0 0 6px rgba(232,120,8,.22)}
.ph .cap{position:relative;color:rgba(255,255,255,.8);font-family:var(--display);font-weight:600;font-size:.82rem;letter-spacing:.02em}
.ph--wide{min-height:240px}
/* real photos that replace .ph placeholders */
.photo{width:100%;height:340px;display:block;object-fit:cover;border-radius:16px}
.heroimg{object-position:center 35%;box-shadow:0 18px 40px rgba(46,11,114,.18)}
.aboutimg{object-position:center 62%}
.hero-img-mobile{display:none}

h2.big{font-size:clamp(1.6rem,3.8vw,2.3rem);margin-bottom:1.3rem}
.lede{font-size:1.12rem;color:var(--muted)}

/* generic list */
.checklist{list-style:none;margin:1.2rem 0}
.checklist li{position:relative;padding:.55rem 0 .55rem 2rem;border-bottom:1px solid var(--line)}
.checklist li::before{content:"";position:absolute;left:0;top:1.05rem;width:9px;height:9px;border-radius:2px;background:var(--orange);transform:rotate(45deg)}
.after{margin-top:1.4rem;font-family:var(--display);font-weight:600;color:var(--violett);font-size:1.15rem}

/* proof cards */
.proofgrid{display:grid;grid-template-columns:repeat(3,1fr);gap:1.2rem;margin:2.2rem 0}
.pcard{background:#fff;border:1px solid var(--line);border-top:4px solid var(--orange);border-radius:16px;padding:1.6rem 1.4rem;box-shadow:0 8px 24px rgba(46,11,114,.05)}
.pnum{font-family:var(--display);font-weight:700;color:var(--orange);font-size:3.1rem;line-height:1;letter-spacing:-0.03em}
.pcard p{margin:.6rem 0 0;font-size:.95rem;color:var(--muted)}
.pcard .ptitle{font-family:var(--display);font-weight:600;color:var(--ink);margin-top:.3rem}
.ministats{display:flex;gap:.4rem;flex-wrap:wrap;margin-top:.2rem}
.ministats span{font-family:var(--display);font-weight:700;color:var(--orange);font-size:1.35rem}
.ministats small{color:var(--muted);font-weight:500;font-family:var(--body);font-size:.72rem;display:block}

/* think section */
.pull{font-family:var(--display);font-weight:600;font-size:1.3rem;color:var(--violett);line-height:1.3;margin:1.6rem 0}
.inlinefig{margin:2rem 0}

/* two cards offer */
.two{display:grid;grid-template-columns:1fr 1fr;gap:1.4rem;margin-top:2rem}
.ocard{background:#fff;border:1px solid var(--line);border-top:4px solid var(--orange);border-radius:14px;padding:1.6rem}
.ocard h3{font-size:1.2rem;margin-bottom:.6rem;color:var(--violett)}
.ocard p{color:var(--muted);font-size:.97rem;margin:0}

/* quotes */
.qgrid{display:grid;grid-template-columns:repeat(3,1fr);gap:1.2rem;margin-top:2rem}
.q{background:#fff;border:1px solid var(--line);border-radius:14px;padding:1.5rem}
.q .mark{font-family:var(--display);font-size:2.4rem;color:var(--orange-hell);line-height:.6;height:.7em}
.q p{font-size:.98rem;margin:.4rem 0 1rem}
.q cite{font-style:normal;font-size:.82rem;color:var(--violett);font-weight:600;font-family:var(--display)}

/* about */
.about__grid{display:grid;grid-template-columns:.8fr 1.2fr;gap:2.5rem;align-items:center}

/* inventMAP teaser (Stufe 0 — nur Skelett) */
.lab-teaser{display:flex;align-items:center;gap:.7rem;flex-wrap:wrap}

/* CTA */
.cta{background:var(--dunkel);color:#efe9ff;text-align:center}
.cta h2{color:#fff;font-size:clamp(1.7rem,4vw,2.4rem);margin-bottom:1.2rem}
.cta p{color:#cdc1f0;max-width:52ch;margin:0 auto 1rem}
.ctabtns{display:flex;gap:.8rem;justify-content:center;flex-wrap:wrap;margin:1.8rem 0 1rem}
.contactline{font-size:.85rem;color:#a99fd0;margin-top:.5rem}
.contactline a{color:#cdb8ff;text-decoration:none}

/* footer */
.foot{background:#22085a;color:#9b8fc6;padding:2.4rem 1.4rem;font-size:.85rem}
.foot__in{max-width:var(--wrap);margin:0 auto;display:flex;justify-content:space-between;flex-wrap:wrap;gap:1rem;align-items:center}
.foot a{color:#cdb8ff;text-decoration:none;margin-left:1.1rem}
.foot .fbrand{font-family:var(--display);color:#fff;font-weight:700}
.foot .fbrand span{color:var(--orange)}

/* legal pages (Impressum / Datenschutz) */
.legal{max-width:760px;margin:0 auto}
.legal h1{font-size:clamp(1.8rem,4vw,2.4rem);margin-bottom:1.5rem}
.legal h2{font-size:1.2rem;color:var(--violett);margin:2rem 0 .6rem}
.legal address{font-style:normal;margin:0 0 .9rem}
.legal a{color:var(--violett);text-decoration:underline}
.todo{background:#fff7ec;border:1px solid #f3d9b0;color:#7a5b18;border-radius:8px;padding:.5rem .8rem;font-size:.85rem;margin:.5rem 0}
.backlink{display:inline-block;margin-top:2.4rem;font-family:var(--display);font-weight:600;color:var(--violett);text-decoration:none}

/* reveal */
.reveal{opacity:0;transform:translateY(18px);transition:opacity .6s ease, transform .6s ease}
.reveal.in{opacity:1;transform:none}

:focus-visible{outline:3px solid var(--orange);outline-offset:3px;border-radius:4px}

@media (max-width:860px){
  .section{padding:3.6rem 1.2rem}
  .hero__grid,.about__grid{grid-template-columns:1fr;gap:1.8rem}
  .proofgrid,.qgrid{grid-template-columns:1fr}
  .two{grid-template-columns:1fr}
  .navtoggle{display:inline-flex;align-items:center}
  .nav.open .navtoggle{background:var(--grund)}
  .navlinks{display:none;position:absolute;top:100%;left:0;right:0;flex-direction:column;align-items:stretch;gap:0;background:#fff;border-bottom:1px solid var(--line);box-shadow:0 10px 24px rgba(46,11,114,.10);padding:.2rem 0;max-height:80vh;overflow-y:auto;-webkit-overflow-scrolling:touch}
  .nav.open .navlinks{display:flex}
  .navlinks .navsection{display:block}
  .navlinks .hide-mobile{display:none}
  .navlinks a{padding:.85rem 1.4rem;font-size:1rem;border-top:1px solid var(--line)}
  .navlinks a:first-child{border-top:0}
  .navlinks .btn-mini{display:none}
  .ph{min-height:220px}
  .photo{height:260px}
  .hero__grid .heroimg{display:none}
  .hero-img-mobile{display:block;width:100%;height:auto;border-radius:16px;margin:.6rem 0 1.4rem;box-shadow:0 14px 30px rgba(46,11,114,.16)}
  .inlinephoto{height:200px}
  .about__grid .ph{order:-1}
}
@media (prefers-reduced-motion:reduce){
  .reveal{opacity:1;transform:none;transition:none}
  html{scroll-behavior:auto}
}
