/* ===========================================================
   Gain and Retain GmbH – globale Styles
   =========================================================== */
@import url('https://fonts.googleapis.com/css2?family=Geist:wght@400;500;600;700&display=swap');

:root{
  --bg:#070a12;
  --bg2:#0a0f1a;
  --ink:#eef1f6;
  --muted:#8a93a6;
  --muted2:#6b7382;
  --blue:#3b82f6;
  --blue-bright:#5aa0ff;
  --line:rgba(255,255,255,.08);
  --card:rgba(255,255,255,.018);
  --card-line:rgba(120,150,210,.14);
  --serif:'Geist',system-ui,sans-serif;
  --sans:'Geist',system-ui,sans-serif;
}
*{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:smooth}
body{
  background:var(--bg);
  color:var(--ink);
  font-family:var(--sans);
  -webkit-font-smoothing:antialiased;
  line-height:1.6;
  overflow-x:hidden;
}
a{color:inherit}
.wrap{max-width:1080px;margin:0 auto;padding:0 32px}

.eyebrow{
  font-size:12px;letter-spacing:.28em;text-transform:uppercase;
  color:var(--blue);font-weight:600;text-align:center;margin-bottom:18px;
}
.section-title{
  font-family:var(--serif);font-weight:600;text-align:center;
  font-size:clamp(28px,3.4vw,40px);color:var(--ink);letter-spacing:-.01em;
}
.divider{height:1px;background:var(--line);width:100%}

/* ---------- HERO ---------- */
.hero{position:relative;overflow:hidden;border-bottom:1px solid var(--line)}
#constellation{position:absolute;inset:0;width:100%;height:100%;z-index:0}
.hero-inner{position:relative;z-index:2;padding:46px 0 96px}
.brand{display:flex;flex-direction:column;align-items:center;gap:14px;margin-bottom:90px}
.brand img{width:84px;height:auto;filter:drop-shadow(0 0 18px rgba(90,160,255,.12))}
.brand .name{
  font-family:var(--serif);font-size:20px;letter-spacing:.22em;
  text-transform:uppercase;color:#f3f5f9;font-weight:600;padding-left:.22em;text-decoration:none;
}
.hero-head{max-width:560px}
.hero-head h1{
  font-family:var(--serif);font-weight:600;
  font-size:clamp(40px,6vw,62px);line-height:1.06;letter-spacing:-.015em;
}
.hero-head p{margin-top:26px;max-width:380px;color:var(--muted);font-size:17px;line-height:1.65}

/* ---------- PROCESS ---------- */
.process{padding:72px 0 80px;border-bottom:1px solid var(--line)}
.process .section-title{margin-bottom:64px}
.steps{display:grid;grid-template-columns:repeat(4,1fr);gap:0 28px;position:relative}
.track{position:absolute;top:30px;left:11%;right:11%;height:1px;background:rgba(120,150,210,.30);z-index:0}
.step{text-align:center;position:relative;z-index:1}
.num{
  width:60px;height:60px;border-radius:50%;border:1px solid rgba(140,170,225,.55);
  display:flex;align-items:center;justify-content:center;margin:0 auto 30px;
  font-family:var(--serif);font-weight:500;font-size:20px;color:#dfe6f2;background:var(--bg);
}
.step .ic{height:48px;display:flex;align-items:center;justify-content:center;margin-bottom:22px}
.step .ic svg{stroke:var(--blue);width:42px;height:42px}
.step h3{font-family:var(--serif);font-weight:600;font-size:21px;letter-spacing:-.005em;margin-bottom:16px}
.step p{color:var(--muted);font-size:14.5px;line-height:1.6;max-width:210px;margin:0 auto}

/* ---------- OFFERINGS ---------- */
.offer{padding:74px 0 84px;border-bottom:1px solid var(--line)}
.offer .eyebrow{margin-bottom:50px}
.cards{display:grid;grid-template-columns:repeat(3,1fr);gap:22px}
.card{
  border:1px solid var(--card-line);background:var(--card);
  border-radius:14px;padding:38px 32px 42px;
  transition:border-color .25s,transform .25s,background .25s;
}
.card:hover{border-color:rgba(120,160,255,.4);transform:translateY(-3px);background:rgba(80,120,220,.05)}
.card .ic svg{stroke:var(--blue);width:34px;height:34px;margin-bottom:34px}
.card h3{font-family:var(--serif);font-weight:600;font-size:24px;letter-spacing:-.005em;margin-bottom:20px}
.card p{color:var(--muted);font-size:14.5px;line-height:1.65}

/* ---------- CTA ---------- */
.cta{padding:78px 0;border-bottom:1px solid var(--line)}
.cta-inner{display:flex;align-items:center;justify-content:space-between;gap:40px;flex-wrap:wrap}
.cta h2{font-family:var(--serif);font-weight:600;font-size:clamp(28px,3.6vw,40px);line-height:1.18;letter-spacing:-.01em;max-width:480px}
.talk{display:flex;align-items:center;gap:20px;text-decoration:none}
.talk .li{
  width:52px;height:52px;border-radius:11px;background:var(--blue);
  display:flex;align-items:center;justify-content:center;flex-shrink:0;transition:transform .2s;
}
.talk:hover .li{transform:scale(1.06)}
.talk .li svg{width:30px;height:30px;fill:#fff}
.talk .label{display:flex;align-items:center;gap:14px;font-family:var(--serif);font-weight:600;font-size:26px;letter-spacing:-.01em;color:#dfe6f2}
.talk .label svg{width:22px;height:22px;stroke:#dfe6f2;transition:transform .2s}
.talk:hover .label svg{transform:translate(3px,-3px)}

/* ---------- FOOTER ---------- */
footer{padding:30px 0 34px}
.foot{display:flex;align-items:center;justify-content:space-between;gap:18px;flex-wrap:wrap}
.foot .legal{color:var(--muted2);font-size:12.5px;display:flex;flex-wrap:wrap;gap:10px;align-items:center}
.foot .legal .sep{opacity:.4}
.foot .links{display:flex;gap:18px;font-size:13px}
.foot .links a{color:var(--muted);text-decoration:none}
.foot .links a:hover{color:var(--ink)}

/* ---------- LEGAL PAGES ---------- */
.legal-header{border-bottom:1px solid var(--line)}
.legal-header .wrap{display:flex;align-items:center;justify-content:space-between;padding-top:24px;padding-bottom:24px}
.legal-header .logo-row{display:flex;align-items:center;gap:14px;text-decoration:none}
.legal-header .logo-row img{width:42px;height:auto}
.legal-header .logo-row .name{font-family:var(--serif);font-size:14px;font-weight:600;letter-spacing:.20em;text-transform:uppercase;color:#f3f5f9;padding-left:.20em}
.legal-header .back{font-size:13px;color:var(--muted);text-decoration:none}
.legal-header .back:hover{color:var(--ink)}

.legal-main{padding:64px 0 90px}
.legal-main .wrap{max-width:780px}
.legal-main h1{font-family:var(--serif);font-weight:600;font-size:clamp(34px,5vw,48px);letter-spacing:-.015em;margin-bottom:14px}
.legal-main .lead{color:var(--muted);font-size:16px;margin-bottom:48px}
.legal-main h2{
  font-family:var(--serif);font-weight:600;font-size:21px;color:var(--ink);letter-spacing:-.005em;
  margin:42px 0 14px;padding-top:8px;
}
.legal-main h3{font-size:15px;font-weight:600;color:var(--ink);margin:26px 0 8px;letter-spacing:.01em}
.legal-main p{color:#c3c9d6;font-size:15px;line-height:1.75;margin-bottom:14px}
.legal-main ul{color:#c3c9d6;font-size:15px;line-height:1.75;margin:0 0 14px 22px}
.legal-main li{margin-bottom:6px}
.legal-main a.inline{color:var(--blue-bright);text-decoration:none;border-bottom:1px solid rgba(90,160,255,.35)}
.legal-main a.inline:hover{border-bottom-color:var(--blue-bright)}
.legal-main .block{
  border:1px solid var(--card-line);background:var(--card);
  border-radius:12px;padding:24px 26px;margin:18px 0;
}
.legal-main .block p{margin-bottom:4px;color:var(--ink)}
.note{
  border-left:2px solid var(--blue);background:rgba(80,120,220,.05);
  padding:14px 18px;border-radius:0 8px 8px 0;margin:28px 0;
  font-size:13.5px;color:var(--muted);line-height:1.7;
}
.note strong{color:#c9d2e2;font-weight:600}
.updated{margin-top:46px;color:var(--muted2);font-size:13px}

/* ---------- RESPONSIVE ---------- */
@media(max-width:880px){
  .steps{grid-template-columns:repeat(2,1fr);gap:48px 28px}
  .track{display:none}
  .cards{grid-template-columns:1fr}
  .hero-head p{max-width:100%}
}
@media(max-width:560px){
  .wrap{padding:0 22px}
  .steps{grid-template-columns:1fr}
  .cta-inner{flex-direction:column;align-items:flex-start}
  .brand{margin-bottom:56px}
  .legal-header .logo-row .name{display:none}
}
