/* ============================================================
   NH Software Studio UG (haftungsbeschränkt) – Website Styles
   No external assets. System fonts only. Cookie-free by default.
   Primary color: teal.
   ============================================================ */

:root{
  --bg: #050b0f;
  --bg2:#07131a;
  --surface: rgba(255,255,255,.06);
  --surface2: rgba(255,255,255,.09);
  --stroke: rgba(255,255,255,.12);
  --text: rgba(255,255,255,.92);
  --muted: rgba(255,255,255,.70);
  --faint: rgba(255,255,255,.55);

  --teal: #14b8a6;
  --teal2:#2dd4bf;
  --teal3:#5eead4;

  --warn:#fbbf24;
  --ok:#22c55e;

  --shadow: 0 22px 60px rgba(0,0,0,.45);
  --shadow-soft: 0 12px 30px rgba(0,0,0,.35);

  --radius: 18px;
  --radius-lg: 28px;

  --container: 1160px;

  --scroll: 0; /* set by JS for the progress bar */
  color-scheme: dark;
}

/* Basic reset */
*,
*::before,
*::after { box-sizing: border-box; }

html { scroll-behavior: smooth; }

body{
  margin:0;
  font-family: ui-sans-serif, system-ui, -apple-system, Segoe UI, Roboto, Helvetica, Arial, "Apple Color Emoji","Segoe UI Emoji";
  color: var(--text);
  background: radial-gradient(1200px 700px at 15% 10%, rgba(20,184,166,.18), transparent 60%),
              radial-gradient(900px 550px at 75% 0%, rgba(45,212,191,.12), transparent 58%),
              radial-gradient(900px 600px at 75% 70%, rgba(94,234,212,.10), transparent 60%),
              linear-gradient(180deg, var(--bg), var(--bg2));
  min-height:100vh;
  overflow-x:hidden;
}

/* Decorative grid */
body::before{
  content:"";
  position:fixed;
  inset:0;
  background:
    linear-gradient(to right, rgba(255,255,255,.06) 1px, transparent 1px),
    linear-gradient(to bottom, rgba(255,255,255,.06) 1px, transparent 1px);
  background-size: 64px 64px;
  mask-image: radial-gradient(1200px 800px at 55% 20%, rgba(0,0,0,.75), transparent 70%);
  opacity:.25;
  pointer-events:none;
  z-index:-2;
}

/* Subtle noise overlay */
body::after{
  content:"";
  position:fixed;
  inset:-20%;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='180' height='180'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='.8' numOctaves='3' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='180' height='180' filter='url(%23n)' opacity='.35'/%3E%3C/svg%3E");
  opacity:.08;
  pointer-events:none;
  z-index:-1;
  transform: translateZ(0);
}

/* Accessible skip link */
.skip-link{
  position:absolute;
  top:8px;
  left:8px;
  padding:10px 12px;
  border-radius: 10px;
  background: rgba(20,184,166,.18);
  border:1px solid rgba(94,234,212,.35);
  color: var(--text);
  text-decoration:none;
  transform: translateY(-140%);
  transition: transform .2s ease;
  z-index: 1000;
}
.skip-link:focus{ transform: translateY(0); outline:none; box-shadow: 0 0 0 4px rgba(20,184,166,.25); }

a{ color: inherit; text-decoration-thickness: .08em; text-underline-offset: .18em; }
a:hover{ color: rgba(94,234,212,.95); }

.container{
  width:min(var(--container), calc(100% - 40px));
  margin-inline:auto;
}

.section{
  padding: clamp(72px, 7vw, 110px) 0;
}

.kicker{
  display:inline-flex;
  align-items:center;
  gap:10px;
  font-size: 13px;
  letter-spacing:.16em;
  text-transform: uppercase;
  color: rgba(94,234,212,.9);
  opacity:.95;
}
.kicker::before{
  content:"";
  width: 36px;
  height: 1px;
  background: linear-gradient(90deg, rgba(94,234,212,.2), rgba(94,234,212,.9));
  border-radius: 2px;
}
h1, h2, h3{ margin: 0 0 12px 0; }
p{ margin: 0 0 16px 0; color: var(--muted); line-height:1.65; }

h1{
  font-size: clamp(34px, 5vw, 62px);
  line-height: 1.05;
  letter-spacing: -0.03em;
}
h2{
  font-size: clamp(26px, 3.2vw, 38px);
  letter-spacing: -0.02em;
  line-height:1.15;
}
h3{
  font-size: clamp(18px, 2.2vw, 22px);
  line-height:1.25;
}
.small{ font-size: 14px; color: var(--faint); }

.gradient-text{
  background: linear-gradient(90deg, var(--teal3), var(--teal), rgba(255,255,255,.88));
  -webkit-background-clip:text;
  background-clip:text;
  color: transparent;
}

/* Scroll progress */
.scroll-progress{
  position: fixed;
  top:0; left:0;
  height: 2px;
  width: calc(var(--scroll) * 1%);
  background: linear-gradient(90deg, var(--teal2), rgba(255,255,255,.55));
  z-index: 999;
  box-shadow: 0 0 18px rgba(45,212,191,.25);
}

/* Header */
.site-header{
  position: sticky;
  top:0;
  z-index: 300;
  backdrop-filter: blur(12px);
  background: rgba(5,11,15,.55);
  border-bottom: 1px solid rgba(255,255,255,.08);
}
.header-inner{
  display:flex;
  align-items:center;
  justify-content: space-between;
  padding: 14px 0;
  gap: 14px;
}
.brand{
  display:flex;
  align-items:center;
  gap: 12px;
  text-decoration:none;
}
.logo{
  min-width: 38px; width: 38px;
  min-height: 38px; height: 38px;
  border-radius: 12px;
  background:
    radial-gradient(18px 18px at 30% 30%, rgba(94,234,212,.95), rgba(20,184,166,.55)),
    radial-gradient(26px 24px at 70% 70%, rgba(255,255,255,.22), transparent 65%),
    linear-gradient(180deg, rgba(255,255,255,.10), rgba(255,255,255,.04));
  border: 1px solid rgba(94,234,212,.35);
  box-shadow: 0 10px 25px rgba(0,0,0,.35);
  position: relative;
  overflow:hidden;
}
.logo::after{
  content:"";
  position:absolute;
  inset:-1px;
  background: radial-gradient(120px 120px at var(--x, 30%) var(--y, 30%), rgba(94,234,212,.35), transparent 55%);
  opacity:.75;
}
.brand-name{
  display:flex;
  flex-direction:column;
  line-height: 1.1;
}
.brand-name strong{ font-size: 15px; letter-spacing: -0.01em; }
.brand-name span{ font-size: 12px; color: var(--faint); }

.nav{
  display:flex;
  align-items:center;
  gap: 16px;
}
.nav a{
  color: rgba(255,255,255,.82);
  text-decoration:none;
  padding: 10px 10px;
  border-radius: 12px;
  transition: transform .18s ease, background .18s ease, color .18s ease;
}
.nav a:hover{
  background: rgba(255,255,255,.06);
  color: rgba(94,234,212,.95);
  transform: translateY(-1px);
}

.nav-cta{
  display:flex;
  gap: 10px;
  align-items:center;
}
.btn{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  gap: 10px;
  padding: 10px 14px;
  border-radius: 14px;
  border: 1px solid rgba(94,234,212,.25);
  background: rgba(20,184,166,.12);
  color: rgba(255,255,255,.92);
  text-decoration:none;
  transition: transform .18s ease, background .18s ease, border-color .18s ease;
  box-shadow: 0 14px 30px rgba(0,0,0,.25);
  font-weight: 600;
}
.btn:hover{
  transform: translateY(-1px);
  background: rgba(20,184,166,.18);
  border-color: rgba(94,234,212,.40);
}
.btn--primary{
  background: linear-gradient(180deg, rgba(45,212,191,.28), rgba(20,184,166,.16));
  border-color: rgba(94,234,212,.48);
}
.btn--ghost{
  background: rgba(255,255,255,.04);
  border-color: rgba(255,255,255,.14);
}
.btn svg{ width: 18px; height: 18px; opacity:.92; }

/* Mobile nav */
.nav-toggle{
  display:none;
  align-items:center;
  justify-content:center;
  width: 44px; height: 44px;
  border-radius: 14px;
  border: 1px solid rgba(255,255,255,.14);
  background: rgba(255,255,255,.04);
  color: var(--text);
}
.nav-toggle:focus{ outline:none; box-shadow: 0 0 0 4px rgba(20,184,166,.22); }

@media (max-width: 1114px){
  .nav{
    position: fixed;
    inset: 70px 20px auto 20px;
    background: rgba(7,19,26,.92);
    border: 1px solid rgba(255,255,255,.12);
    border-radius: 18px;
    padding: 14px;
    display:none;
    flex-direction: column;
    align-items: stretch;
    box-shadow: var(--shadow);
    backdrop-filter: blur(14px);
  }
  .nav.is-open{ display:flex; }
  .nav a{ padding: 12px 12px; }
  .nav-cta{ flex-direction: column; align-items: stretch; width: 100%; }
  .btn{ width: 100%; }
  .nav-toggle{ display:inline-flex; }
}

/* Hero */
.hero{
  position:relative;
  padding: clamp(60px, 6vw, 84px) 0 10px 0;
  overflow:hidden;
}
.hero-grid{
  display:grid;
  grid-template-columns: 1.2fr .8fr;
  gap: clamp(22px, 4vw, 44px);
  align-items:center;
}
@media (max-width: 980px){
  .hero-grid{ grid-template-columns: 1fr; }
}

.hero-card{
  border-radius: var(--radius-lg);
  border: 1px solid rgba(255,255,255,.12);
  background: linear-gradient(180deg, rgba(255,255,255,.06), rgba(255,255,255,.03));
  box-shadow: var(--shadow);
  padding: clamp(22px, 3vw, 34px);
  position:relative;
  overflow:hidden;
}
.hero-card::before{
  content:"";
  position:absolute;
  inset:-2px;
  background: radial-gradient(500px 240px at 20% 10%, rgba(94,234,212,.25), transparent 60%),
              radial-gradient(520px 320px at 85% 40%, rgba(20,184,166,.18), transparent 65%);
  opacity:.9;
  pointer-events:none;
}
.hero-card > *{ position:relative; }

.hero p.lead{
  font-size: clamp(16px, 2.1vw, 19px);
  color: rgba(255,255,255,.78);
  margin-top: 14px;
}

.hero-actions{
  display:flex;
  gap: 12px;
  flex-wrap:wrap;
  margin-top: 22px;
}

.hero-bullets{
  display:flex;
  flex-wrap:wrap;
  gap: 10px;
  margin-top: 18px;
}
.pill{
  display:inline-flex;
  align-items:center;
  gap:8px;
  padding: 8px 10px;
  border-radius: 999px;
  background: rgba(255,255,255,.05);
  border:1px solid rgba(255,255,255,.10);
  font-size: 13px;
  color: rgba(255,255,255,.80);
}
.pill .dot{
  width: 8px; height: 8px;
  border-radius:999px;
  background: var(--teal2);
  box-shadow: 0 0 0 4px rgba(45,212,191,.14);
}

.hero-aside{
  position:relative;
  min-height: 300px;
}
@media (max-width: 520px){
  .hero-aside{
    min-height: 510px;
  }
}
.hero-orb{
  position:absolute;
  inset:auto;
  width: min(520px, 90vw);
  height: min(520px, 90vw);
  border-radius: 999px;
  filter: blur(0px);
  opacity:.95;
  transform: translate3d(0,0,0);
  will-change: transform;
}
.hero-orb.orb1{
  right: -120px; top: -120px;
  background: radial-gradient(circle at 30% 30%, rgba(94,234,212,.85), rgba(20,184,166,.22) 60%, transparent 72%);
}
.hero-orb.orb2{
  left: -110px; bottom: -140px;
  background: radial-gradient(circle at 65% 30%, rgba(255,255,255,.16), rgba(45,212,191,.18) 45%, transparent 72%);
}
.hero-glass{
  position:absolute;
  border-radius: var(--radius-lg);
  border:1px solid rgba(255,255,255,.14);
  background: rgba(255,255,255,.05);
  backdrop-filter: blur(14px);
  box-shadow: var(--shadow-soft);
  padding: 20px;
  overflow:hidden;
}
.hero-glass::before{
  content:"";
  position:absolute;
  inset:-1px;
  background: radial-gradient(400px 280px at var(--mx, 40%) var(--my, 20%), rgba(94,234,212,.28), transparent 60%);
  opacity:.85;
  pointer-events:none;
}
.hero-glass > * { position:relative; }

.code-badge{
  display:inline-flex;
  align-items:center;
  gap:10px;
  padding: 10px 12px;
  border-radius: 14px;
  border:1px solid rgba(94,234,212,.22);
  background: rgba(20,184,166,.10);
  font-weight:700;
  letter-spacing: .01em;
}
.mini-grid{
  display:grid;
  grid-template-columns: repeat(2, minmax(0,1fr));
  gap: 12px;
  margin-top: 14px;
}
.mini-card{
  border-radius: 16px;
  border: 1px solid rgba(255,255,255,.12);
  background: rgba(255,255,255,.04);
  padding: 14px;
  transition: transform .18s ease, background .18s ease, border-color .18s ease;
}
.mini-card:hover{
  transform: translateY(-2px);
  background: rgba(255,255,255,.06);
  border-color: rgba(94,234,212,.26);
}
.mini-card strong{ display:block; font-size: 14px; }
.mini-card span{ display:block; font-size: 12px; color: var(--faint); margin-top: 6px; line-height: 1.45; }

@media (max-width: 520px){
  .mini-grid{ grid-template-columns: 1fr; }
}

/* Sections */
.section-header{
  display:flex;
  align-items:flex-end;
  justify-content: space-between;
  gap: 18px;
  margin-bottom: 28px;
}
.section-header p{ max-width: 65ch; }
@media (max-width: 820px){
  .section-header{ flex-direction: column; align-items:flex-start; }
}

/* Cards */
.cards{
  display:grid;
  grid-template-columns: repeat(3, minmax(0,1fr));
  gap: 16px;
}
@media (max-width: 980px){
  .cards{ grid-template-columns: repeat(2, minmax(0,1fr)); }
}
@media (max-width: 620px){
  .cards{ grid-template-columns: 1fr; }
}

.card{
  position:relative;
  border-radius: var(--radius);
  border:1px solid rgba(255,255,255,.12);
  background: linear-gradient(180deg, rgba(255,255,255,.06), rgba(255,255,255,.03));
  padding: 18px 18px 16px;
  box-shadow: 0 16px 40px rgba(0,0,0,.34);
  overflow:hidden;
  transition: transform .22s ease, border-color .22s ease, background .22s ease;
  will-change: transform;
}
.card::before{
  content:"";
  position:absolute;
  inset:-1px;
  background: radial-gradient(420px 240px at var(--px, 30%) var(--py, 30%), rgba(94,234,212,.20), transparent 60%);
  opacity:.65;
  pointer-events:none;
}
.card > *{ position:relative; }
.card:hover{
  transform: translateY(-3px);
  border-color: rgba(94,234,212,.24);
  background: linear-gradient(180deg, rgba(255,255,255,.07), rgba(255,255,255,.03));
}
.card .icon{
  width: 40px; height: 40px;
  border-radius: 14px;
  display:grid;
  place-items:center;
  background: rgba(20,184,166,.12);
  border: 1px solid rgba(94,234,212,.22);
  margin-bottom: 14px;
}
.card .icon svg{ width: 20px; height: 20px; opacity:.95; }
.card ul{
  padding-left: 18px;
  margin: 12px 0 0 0;
  color: var(--muted);
  line-height:1.65;
}
.card li{ margin: 6px 0; }

/* Tech stack - details accordion */
.stack{
  display:grid;
  grid-template-columns: .9fr 1.1fr;
  gap: 18px;
}
@media (max-width: 980px){
  .stack{ grid-template-columns: 1fr; }
}
.stack-panel{
  border-radius: var(--radius);
  border:1px solid rgba(255,255,255,.12);
  background: rgba(255,255,255,.04);
  box-shadow: var(--shadow-soft);
  padding: 18px;
}
.stack-panel h3{ margin-bottom: 10px; }
.badges{
  display:flex;
  flex-wrap: wrap;
  gap: 10px;
}
.badge{
  padding: 8px 10px;
  border-radius: 999px;
  font-size: 13px;
  border: 1px solid rgba(255,255,255,.12);
  background: rgba(255,255,255,.04);
  color: rgba(255,255,255,.78);
}
.badge--teal{
  border-color: rgba(94,234,212,.28);
  background: rgba(20,184,166,.10);
}
details{
  border-radius: 16px;
  border: 1px solid rgba(255,255,255,.12);
  background: rgba(255,255,255,.03);
  padding: 12px 14px;
  margin-bottom: 12px;
}
details[open]{ background: rgba(255,255,255,.05); border-color: rgba(94,234,212,.22); }
summary{
  cursor:pointer;
  list-style:none;
  display:flex;
  align-items:center;
  justify-content: space-between;
  gap: 10px;
  font-weight: 700;
}
summary::-webkit-details-marker{ display:none; }
summary .chev{
  width: 18px; height: 18px;
  opacity:.8;
  transition: transform .22s ease;
}
details[open] summary .chev{ transform: rotate(180deg); }
details p{ margin: 12px 0 16px 0; }

/* FAQ */
.faq-grid{
  display:grid;
  grid-template-columns: repeat(2, minmax(0,1fr));
  gap: 14px;
}
@media (max-width: 980px){
  .faq-grid{ grid-template-columns: 1fr; }
}
.faq-item{
  margin: 0;
  position: relative;
  overflow: hidden;
  transition: transform .22s ease, border-color .22s ease, background .22s ease;
  will-change: transform;
}
.faq-item::before{
  content: "";
  position:absolute;
  inset:-1px;
  background: radial-gradient(420px 240px at var(--px, 30%) var(--py, 30%), rgba(94,234,212,.18), transparent 60%);
  opacity:.55;
  pointer-events:none;
}
.faq-item > *{ position: relative; }
.faq-item:hover{
  transform: translateY(-2px);
  border-color: rgba(94,234,212,.24);
  background: rgba(255,255,255,.05);
}
.faq-item summary{ font-size: 15px; line-height: 1.35; }
.faq-item p,
.faq-item ul{ color: var(--muted); line-height: 1.65; }
.faq-item ul{ margin: 10px 0 0 0; padding-left: 18px; }

.faq-footer{
  margin-top: 18px;
  display:flex;
  flex-wrap: wrap;
  gap: 10px;
  align-items: center;
}
.faq-footer .notice{ margin-top: 0; flex: 1; min-width: 260px; }


/* Timeline */
.timeline{
  display:grid;
  grid-template-columns: repeat(4, minmax(0,1fr));
  gap: 14px;
  margin-top: 12px;
}
@media (max-width: 980px){ .timeline{ grid-template-columns: repeat(2, minmax(0,1fr)); } }
@media (max-width: 620px){ .timeline{ grid-template-columns: 1fr; } }
.step{
  border-radius: var(--radius);
  border:1px solid rgba(255,255,255,.12);
  background: rgba(255,255,255,.04);
  padding: 16px;
  position:relative;
  overflow:hidden;
}
.step::before{
  content:"";
  position:absolute;
  inset:-2px;
  background: radial-gradient(320px 200px at 20% 10%, rgba(94,234,212,.18), transparent 55%);
  opacity:.6;
  pointer-events:none;
}
.step > *{ position:relative; }
.step .num{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  width: 34px; height: 34px;
  border-radius: 14px;
  background: rgba(20,184,166,.14);
  border:1px solid rgba(94,234,212,.22);
  font-weight: 800;
  margin-bottom: 10px;
}

/* Portfolio */
.portfolio{
  display:grid;
  grid-template-columns: 1.2fr .8fr;
  gap: 16px;
  align-items: start;
}
@media (max-width: 980px){ .portfolio{ grid-template-columns: 1fr; } }
.project{
  border-radius: var(--radius);
  border:1px solid rgba(255,255,255,.12);
  background: rgba(255,255,255,.04);
  padding: 18px;
  box-shadow: var(--shadow-soft);
}
.project + .project{ margin-top: 14px; }
.project header{
  display:flex;
  align-items:flex-start;
  justify-content: space-between;
  gap: 12px;
}
.tag{
  font-size: 12px;
  padding: 6px 10px;
  border-radius: 999px;
  border:1px solid rgba(94,234,212,.24);
  background: rgba(20,184,166,.10);
  color: rgba(255,255,255,.82);
  white-space: nowrap;
}
.muted-box{
  border-radius: var(--radius);
  border:1px solid rgba(255,255,255,.12);
  background: rgba(255,255,255,.03);
  padding: 16px;
}
.quote{
  border-left: 2px solid rgba(94,234,212,.45);
  padding-left: 14px;
  margin: 14px 0;
}
.quote p{ margin: 0; color: rgba(255,255,255,.78); }
.quote .who{ margin-top: 10px; font-size: 13px; color: var(--faint); }

/* Contact */
.contact-grid{
  display:grid;
  grid-template-columns: 1.05fr .95fr;
  gap: 16px;
  align-items:start;
}
@media (max-width: 980px){ .contact-grid{ grid-template-columns: 1fr; } }

.contact-card{
  border-radius: var(--radius-lg);
  border:1px solid rgba(255,255,255,.12);
  background: linear-gradient(180deg, rgba(255,255,255,.06), rgba(255,255,255,.03));
  box-shadow: var(--shadow);
  padding: 20px;
  position:relative;
  overflow:hidden;
}
.contact-card::before{
  content:"";
  position:absolute;
  inset:-1px;
  background: radial-gradient(520px 280px at 10% 10%, rgba(94,234,212,.25), transparent 55%),
              radial-gradient(420px 260px at 85% 50%, rgba(20,184,166,.18), transparent 60%);
  opacity:.85;
  pointer-events:none;
}
.contact-card > *{ position:relative; }

.contact-actions{
  display:flex;
  flex-wrap:wrap;
  gap: 10px;
  margin-top: 16px;
}
.meta{
  margin-top: 14px;
  display:grid;
  gap: 10px;
}
.meta-item{
  display:flex;
  gap: 10px;
  align-items:flex-start;
  padding: 12px;
  border-radius: 16px;
  border:1px solid rgba(255,255,255,.12);
  background: rgba(255,255,255,.03);
}
.meta-item svg{ width: 18px; height: 18px; margin-top: 2px; opacity:.9; }
.meta-item span{ color: var(--muted); }
.meta-item a{ color: rgba(255,255,255,.85); }

.notice{
  margin-top: 14px;
  padding: 12px 14px;
  border-radius: 16px;
  border: 1px dashed rgba(255,255,255,.18);
  color: rgba(255,255,255,.70);
  background: rgba(255,255,255,.03);
}

/* Footer */
.footer{
  padding: 26px 0 40px;
  border-top: 1px solid rgba(255,255,255,.10);
  background: rgba(0,0,0,.10);
}
.footer-grid{
  display:flex;
  flex-wrap:wrap;
  gap: 12px 18px;
  align-items:center;
  justify-content: space-between;
}
.footer a{ color: rgba(255,255,255,.78); text-decoration:none; }
.footer a:hover{ color: rgba(94,234,212,.95); }
.footer small{ color: rgba(255,255,255,.55); }

/* Legal pages */
.legal{
  padding: 26px 0 90px;
}
.legal article{
  border-radius: var(--radius-lg);
  border: 1px solid rgba(255,255,255,.12);
  background: rgba(255,255,255,.04);
  box-shadow: var(--shadow-soft);
  padding: clamp(18px, 3vw, 28px);
}
.legal h1{ font-size: clamp(28px, 3.8vw, 44px); }
.legal h2{ margin-top: 26px; }
.legal ul{ color: var(--muted); line-height:1.65; }
.placeholder{
  display:inline-block;
  padding: 2px 8px;
  border-radius: 999px;
  border:1px solid rgba(251,191,36,.28);
  background: rgba(251,191,36,.08);
  color: rgba(251,191,36,.95);
  font-weight: 700;
  font-size: 12px;
  vertical-align: middle;
}

/* Reveal on scroll */
.reveal{
  opacity: 0;
  transform: translateY(14px);
  transition: opacity .65s ease, transform .65s ease;
}
.reveal.is-visible{
  opacity:1;
  transform: translateY(0);
}

/* Cursor glow */
.cursor-glow{
  position:fixed;
  inset:0;
  pointer-events:none;
  z-index: 50;
  background: radial-gradient(300px 260px at var(--cx, 50%) var(--cy, 30%), rgba(20,184,166,.16), transparent 65%);
  opacity:.85;
  transition: opacity .25s ease;
}
@media (prefers-reduced-motion: reduce){
  html{ scroll-behavior:auto; }
  .reveal{ opacity:1; transform:none; transition:none; }
  .cursor-glow{ display:none; }
  .hero-orb{ transition:none !important; }
}

/* ============================================================
   Emphasis: Gewissenhaftigkeit & Effizienz (Zusatz-Components)
   ============================================================ */

.hero-trust{
  display:grid;
  grid-template-columns: repeat(auto-fit, minmax(220px, 1fr));
  gap: 10px;
  margin-top: 18px;
}
.trust-item{
  border-radius: 16px;
  border: 1px solid rgba(255,255,255,.12);
  background: rgba(255,255,255,.03);
  padding: 12px;
}
.trust-item strong{
  display:block;
  font-size: 13px;
  letter-spacing: -0.01em;
}
.trust-item span{
  display:block;
  font-size: 12px;
  color: var(--faint);
  margin-top: 6px;
  line-height: 1.45;
}
@media (max-width: 620px){
  .hero-trust{ grid-template-columns: 1fr; }
}

.quality-grid{
  display:grid;
  grid-template-columns: repeat(2, minmax(0,1fr));
  gap: 16px;
}
@media (max-width: 980px){
  .quality-grid{ grid-template-columns: 1fr; }
}

.quality-card{
  padding: 20px;
}
.quality-head{
  display:flex;
  gap: 12px;
  align-items:flex-start;
  margin-bottom: 10px;
}
.quality-icon{
  width: 44px;
  height: 44px;
  border-radius: 16px;
  display:grid;
  place-items:center;
  background: rgba(20,184,166,.12);
  border: 1px solid rgba(94,234,212,.22);
  flex: 0 0 auto;
}
.quality-icon svg{ width: 22px; height: 22px; opacity:.95; }
.quality-head h3{ margin-bottom: 6px; }
.quality-head p{ margin: 0; }

.checklist{
  list-style:none;
  padding:0;
  margin: 14px 0 0 0;
  display:grid;
  gap: 10px;
}
.checklist li{
  position:relative;
  padding-left: 30px;
  color: var(--muted);
  line-height: 1.55;
}
.checklist li strong{
  color: rgba(255,255,255,.86);
  font-weight: 800;
}
.checklist li::before{
  content:"✓";
  position:absolute;
  left:0;
  top: 2px;
  width: 18px;
  height: 18px;
  border-radius: 6px;
  display:grid;
  place-items:center;
  background: rgba(20,184,166,.12);
  border: 1px solid rgba(94,234,212,.24);
  color: rgba(94,234,212,.95);
  box-shadow: 0 0 0 4px rgba(20,184,166,.08);
  font-size: 12px;
  font-weight: 900;
}

/* ============================================================
   Product-first Components (Produkte)
   ============================================================ */

.products-grid{
  display:grid;
  grid-template-columns: 1.15fr .85fr;
  gap: 16px;
  align-items:start;
}
@media (max-width: 980px){
  .products-grid{ grid-template-columns: 1fr; }
}

.product-cards{
  display:grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 16px;
}
@media (max-width: 820px){
  .product-cards{ grid-template-columns: 1fr; }
}

.product-card{
  padding: 20px;
}

.product-head{
  display:flex;
  align-items:flex-start;
  justify-content: space-between;
  gap: 12px;
  margin-bottom: 8px;
}
.product-head p{ margin: 0; }

.status{
  font-size: 12px;
  padding: 6px 10px;
  border-radius: 999px;
  border: 1px solid rgba(255,255,255,.14);
  background: rgba(255,255,255,.04);
  color: rgba(255,255,255,.80);
  white-space: nowrap;
  box-shadow: 0 12px 26px rgba(0,0,0,.26);
}
.status--teal{
  border-color: rgba(94,234,212,.30);
  background: rgba(20,184,166,.10);
}


/* ============================================================
   Fristly featured product (Produkte)
   ============================================================ */

.product-card--featured{
  grid-column: 1 / -1;
  padding: 26px;
}

.product-brand{
  display:flex;
  align-items:center;
  gap: 12px;
}

.app-mark{
  min-width: 46px; width: 46px;
  min-height: 46px; height: 46px;
  border-radius: 16px;
  display:grid;
  place-items:center;
  font-weight: 900;
  letter-spacing:-0.02em;
  color: rgba(255,255,255,.92);
  background-image: url('assets/fristly_icon.png');
  background-size: cover;       
  background-repeat: no-repeat;
  background-position: center;
  border: 1px solid rgba(94,234,212,.35);
  box-shadow: 0 16px 40px rgba(0,0,0,.35);
}

.status-stack{
  display:flex;
  gap: 10px;
  flex-wrap: wrap;
  justify-content:flex-end;
}

.product-split{
  display:grid;
  grid-template-columns: 1.1fr .9fr;
  gap: 18px;
  align-items: center;
  margin-top: 12px;
}
@media (max-width: 980px){
  .product-split{ grid-template-columns: 1fr; }
  .status-stack{ justify-content:flex-start; }
}

.feature-grid{
  display:grid;
  grid-template-columns: repeat(2, minmax(0,1fr));
  gap: 12px;
  margin-top: 14px;
}
@media (max-width: 720px){
  .feature-grid{ grid-template-columns: 1fr; }
}

.feature{
  border-radius: 16px;
  border: 1px solid rgba(255,255,255,.12);
  background: rgba(255,255,255,.04);
  padding: 12px 12px;
}
.feature strong{
  display:block;
  color: rgba(255,255,255,.88);
  margin-bottom: 4px;
}
.feature span{
  display:block;
  font-size: 14px;
  color: var(--muted);
  line-height:1.55;
}

.badge--pro{
  border-color: rgba(251,191,36,.30);
  background: rgba(251,191,36,.10);
}

.product-cta{
  display:flex;
  flex-wrap: wrap;
  gap: 10px;
  margin-top: 14px;
}

.store-cta{
  display:flex;
  flex-wrap: wrap;
  gap: 10px;
  justify-content: center;
  margin-top: 10px;
}

.store-badge{
  display:inline-flex;
  align-items:center;
  gap: 10px;
  padding: 10px 12px;
  border-radius: 16px;
  border: 1px solid rgba(255,255,255,.14);
  background: rgba(255,255,255,.04);
  color: rgba(255,255,255,.92);
  text-decoration:none;
  transition: transform .18s ease, background .18s ease, border-color .18s ease;
  box-shadow: 0 14px 30px rgba(0,0,0,.22);
  min-width: 135px;
}

.store-badge:hover{
  transform: translateY(-1px);
  background: rgba(255,255,255,.07);
  border-color: rgba(94,234,212,.32);
}

.store-badge svg{ width: 18px; height: 18px; opacity:.92; flex: 0 0 auto; }

.store-text{
  display:flex;
  flex-direction:column;
  line-height:1.1;
}

.store-title{
  font-weight: 800;
  letter-spacing: .2px;
}

.store-sub{
  font-size: 12px;
  color: var(--muted);
  margin-top: 3px;
  font-weight: 600;
}

.store-note{
  margin-top: 8px;
  color: rgba(255,255,255,.56);
}

@media (max-width: 520px){
  .store-badge{ width: 100%; min-width: 0; justify-content:flex-start; }
}

/* Phone mock (rein dekorativ) */
.phone-mock{
  display:grid;
  place-items:center;
}
.phone{
  width: min(320px, 100%);
  aspect-ratio: 10 / 19;
  border-radius: 36px;
  background: linear-gradient(180deg, rgba(255,255,255,.08), rgba(255,255,255,.03));
  border: 1px solid rgba(94,234,212,.22);
  box-shadow: 0 22px 60px rgba(0,0,0,.45);
  position: relative;
  overflow: hidden;
}
.phone::before{
  content:"";
  position:absolute;
  inset:-20%;
  background:
    radial-gradient(240px 240px at 25% 18%, rgba(94,234,212,.22), transparent 60%),
    radial-gradient(220px 220px at 75% 80%, rgba(20,184,166,.18), transparent 55%);
  opacity:.9;
}
.phone-top{
  position:absolute;
  top:0; left:0; right:0;
  height: 44px;
  display:flex;
  justify-content:center;
  align-items:flex-end;
  padding-bottom: 10px;
  z-index:1;
}
.notch{
  width: 118px;
  height: 24px;
  border-radius: 0 0 18px 18px;
  background: rgba(0,0,0,.35);
  border: 1px solid rgba(255,255,255,.10);
  box-shadow: 0 10px 30px rgba(0,0,0,.35);
}
.phone-screen{
  position:absolute;
  inset: 44px 14px 14px;
  border-radius: 26px;
  background: rgba(0,0,0,.28);
  border: 1px solid rgba(255,255,255,.10);
  padding: 14px;
  display:flex;
  flex-direction:column;
  gap: 10px;
  z-index:1;
}
.phone-title{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap: 10px;
  color: rgba(255,255,255,.92);
}
.phone-pill{
  font-size: 12px;
  padding: 6px 10px;
  border-radius: 999px;
  border: 1px solid rgba(94,234,212,.26);
  background: rgba(20,184,166,.10);
  color: rgba(94,234,212,.95);
  white-space: nowrap;
}
.phone-card{
  border-radius: 18px;
  border: 1px solid rgba(255,255,255,.10);
  background: rgba(255,255,255,.06);
  padding: 10px 10px;
  display:flex;
  flex-direction:column;
  gap: 6px;
}
.phone-card--soft{
  background: rgba(255,255,255,.05);
}
.phone-row{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap: 10px;
}
.phone-row strong{
  font-size: 13px;
  color: rgba(255,255,255,.88);
}
.phone-tag{
  font-size: 11px;
  padding: 4px 8px;
  border-radius: 999px;
  border: 1px solid rgba(94,234,212,.22);
  background: rgba(20,184,166,.10);
  color: rgba(255,255,255,.82);
  white-space: nowrap;
}
.phone-tag--warn{
  border-color: rgba(251,191,36,.30);
  background: rgba(251,191,36,.10);
}
.phone-main{
  font-weight: 800;
  letter-spacing:-0.01em;
  color: rgba(255,255,255,.92);
}
.phone-meta{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap: 10px;
  font-size: 12px;
  color: rgba(255,255,255,.72);
}
