/* ═══════════════════════════════════════════════════════════
   danielnarum.de — Projekt-Hub
   Ein One-Pager mit 3 gekapselten Brand-Scopes:
   .s1  → bydaniwp.dev      (Webdesign · creme/Serif/Aurora)
   .s2  → ki-agenten-setup  (dark/Teal/Violet)
   .s3  → wemove.fun        (weiss-rot/Bold/Sport)
   ═══════════════════════════════════════════════════════════ */

@import url('https://fonts.googleapis.com/css2?family=Fraunces:ital,opsz,wght@0,9..144,300;0,9..144,400;0,9..144,500;0,9..144,600;1,9..144,300;1,9..144,400&family=Inter:wght@300;400;500;600;700;800&family=Oswald:wght@500;600;700&display=swap');

*, *::before, *::after { margin: 0; padding: 0; box-sizing: border-box; }

:root {
  --ink: #0e0e12;
  --bone: #fbf8f2;
  --font-serif: 'Fraunces', Georgia, serif;
  --font-sans: 'Inter', system-ui, -apple-system, sans-serif;
  --font-cond: 'Oswald', 'Inter', sans-serif;
  --max: 1180px;
  --ease: cubic-bezier(.22,1,.36,1);
}

html { scroll-behavior: smooth; font-size: 16px; -webkit-text-size-adjust: 100%; }
body {
  font-family: var(--font-sans);
  background: #0c0c10;
  color: var(--ink);
  line-height: 1.65;
  -webkit-font-smoothing: antialiased;
  overflow-x: hidden;
}
img { max-width: 100%; height: auto; display: block; }
ul { list-style: none; }
a { text-decoration: none; color: inherit; }
.wrap { max-width: var(--max); margin: 0 auto; padding: 0 24px; width: 100%; }
.sr-only { position:absolute;width:1px;height:1px;overflow:hidden;clip:rect(0,0,0,0); }

/* Reveal-on-scroll */
.reveal { opacity: 0; transform: translateY(28px); transition: opacity .8s var(--ease), transform .8s var(--ease); }
.reveal.in { opacity: 1; transform: none; }
@media (prefers-reduced-motion: reduce) {
  .reveal { opacity: 1 !important; transform: none !important; transition: none; }
  html { scroll-behavior: auto; }
}

/* ───────────────────────── Top Nav (glass, neutral) ───────────────────────── */
.topnav {
  position: fixed; inset: 0 0 auto 0; z-index: 100;
  display: flex; align-items: center; justify-content: space-between;
  padding: 14px clamp(20px,4vw,48px);
  background: rgba(12,12,16,.55);
  backdrop-filter: blur(14px) saturate(140%);
  -webkit-backdrop-filter: blur(14px) saturate(140%);
  border-bottom: 1px solid rgba(255,255,255,.08);
  transition: background .3s ease, padding .3s ease;
}
.topnav.scrolled { background: rgba(12,12,16,.82); padding: 10px clamp(20px,4vw,48px); }
.topnav__brand { font-family: var(--font-serif); font-weight: 500; font-size: 1.05rem; color: #fff; letter-spacing: -.01em; }
.topnav__brand span { color: #8a8a93; font-weight: 300; }
.topnav__links { display: flex; gap: 8px; align-items: center; }
.topnav__links a {
  font-size: .82rem; font-weight: 500; color: rgba(255,255,255,.74);
  padding: 7px 14px; border-radius: 999px; transition: color .25s ease, background .25s ease;
  white-space: nowrap;
}
.topnav__links a:hover { color: #fff; background: rgba(255,255,255,.08); }
.topnav__links .d1:hover { background: rgba(108,99,255,.22); }
.topnav__links .d2:hover { background: rgba(0,212,170,.18); }
.topnav__links .d3:hover { background: rgba(231,69,64,.22); }
@media (max-width: 720px) {
  .topnav__brand span { display: none; }
  .topnav__links a { padding: 6px 10px; font-size: .76rem; }
}

/* ═════════════════════════ INTRO (charcoal) ═════════════════════════ */
.intro {
  position: relative; min-height: 100svh; display: flex; align-items: center;
  background: radial-gradient(120% 80% at 50% -10%, #16161e 0%, #0c0c10 60%);
  color: #fff; overflow: hidden; padding: 120px 0 90px;
}
.intro__glow { position: absolute; inset: 0; pointer-events: none; z-index: 0; }
.intro__glow::before, .intro__glow::after, .intro__glow span {
  content: ''; position: absolute; border-radius: 50%; filter: blur(120px); opacity: .35;
}
.intro__glow::before { width: 520px; height: 520px; background: #6c63ff; top: -120px; left: -80px; }
.intro__glow::after  { width: 460px; height: 460px; background: #00d4aa; bottom: -140px; right: 8%; opacity:.28; }
.intro__glow span    { display:block; width: 380px; height: 380px; background: #e74540; bottom: -60px; left: 38%; opacity:.20; }
.intro .wrap { position: relative; z-index: 1; text-align: center; }
.intro__kicker {
  font-size: .74rem; font-weight: 600; text-transform: uppercase; letter-spacing: .28em;
  color: rgba(255,255,255,.55); margin-bottom: 26px;
}
.intro__avatar {
  width: 84px; height: 84px; border-radius: 50%; margin: 0 auto 24px;
  border: 2px solid rgba(255,255,255,.25); object-fit: cover;
  box-shadow: 0 12px 40px rgba(0,0,0,.45);
}
.intro h1 {
  font-family: var(--font-serif); font-weight: 400; letter-spacing: -.025em; line-height: .98;
  font-size: clamp(2.8rem, 8vw, 6rem); margin-bottom: 22px;
}
.intro h1 em { font-style: italic; font-weight: 300; }
.intro__sub {
  font-size: clamp(1.05rem,2.2vw,1.4rem); color: rgba(255,255,255,.72); font-weight: 300;
  max-width: 620px; margin: 0 auto 44px; line-height: 1.6;
}
.intro__sub b { color: #fff; font-weight: 500; }
.intro__nav { display: grid; grid-template-columns: repeat(3, minmax(0,1fr)); gap: 18px; max-width: 920px; margin: 0 auto; text-align: left; }
@media (max-width: 760px) { .intro__nav { grid-template-columns: 1fr; max-width: 420px; gap: 14px; } }
.pcard {
  position: relative; display: flex; flex-direction: column; align-items: flex-start;
  padding: 24px 22px 20px; border-radius: 18px;
  border: 1px solid rgba(255,255,255,.12); background: rgba(255,255,255,.045);
  color: #fff; overflow: hidden; isolation: isolate;
  transition: transform .45s var(--ease), border-color .35s ease, background .35s ease, box-shadow .35s ease;
}
.pcard::before {
  content: ""; position: absolute; inset: 0; z-index: -1; opacity: 0; transition: opacity .4s ease;
  background: radial-gradient(120% 90% at 0% 0%, var(--glow, rgba(255,255,255,.12)), transparent 60%);
}
.pcard:hover { transform: translateY(-5px); background: rgba(255,255,255,.07); box-shadow: 0 18px 44px rgba(0,0,0,.35); }
.pcard:hover::before { opacity: 1; }
.pcard__logo { display: flex; align-items: center; height: 40px; margin-bottom: 18px; }
.pcard__wordmark { height: 26px; width: auto; }
.pcard__wordmark.inv { filter: invert(1) brightness(1.7); }
.pcard__badge {
  display: flex; align-items: center; justify-content: center;
  width: 44px; height: 44px; border-radius: 12px; background: #fff;
  box-shadow: 0 4px 14px rgba(0,0,0,.25);
}
.pcard__badge img { width: 26px; height: 26px; object-fit: contain; }
.pcard__title { font-weight: 600; font-size: 1rem; letter-spacing: -.01em; margin-bottom: 6px; line-height: 1.25; }
.pcard__desc { font-size: .85rem; color: rgba(255,255,255,.6); font-weight: 300; line-height: 1.5; margin-bottom: 16px; }
.pcard__go { margin-top: auto; font-size: .82rem; font-weight: 500; color: rgba(255,255,255,.5); display: inline-flex; gap: 6px; transition: color .3s ease, gap .3s ease; }
.pcard:hover .pcard__go { gap: 10px; }
.pcard--1 { --glow: rgba(108,99,255,.22); } .pcard--1:hover { border-color: rgba(108,99,255,.55); } .pcard--1:hover .pcard__go { color: #a59dff; }
.pcard--2 { --glow: rgba(0,212,170,.20); } .pcard--2:hover { border-color: rgba(0,212,170,.5); } .pcard--2:hover .pcard__go { color: #4fe3c4; }
.pcard--3 { --glow: rgba(231,69,64,.22); } .pcard--3:hover { border-color: rgba(231,69,64,.55); } .pcard--3:hover .pcard__go { color: #f2756f; }
.intro__scroll { position: absolute; bottom: 26px; left: 50%; transform: translateX(-50%); z-index: 1; color: rgba(255,255,255,.4); animation: bob 2s infinite; }
@keyframes bob { 0%,100%{transform:translate(-50%,0)} 50%{transform:translate(-50%,8px)} }

/* shared section header */
.sec { position: relative; padding: clamp(80px,11vw,140px) 0; }
.sec__inner { display: grid; grid-template-columns: 1fr 1fr; gap: clamp(40px,6vw,80px); align-items: center; }
@media (max-width: 900px) { .sec__inner { grid-template-columns: 1fr; gap: 44px; } }
.sec__logo { height: 30px; width: auto; margin-bottom: 26px; }
.kicker {
  display: inline-flex; align-items: center; gap: 10px;
  font-size: .74rem; font-weight: 600; text-transform: uppercase; letter-spacing: .2em; margin-bottom: 18px;
}
.kicker::before { content: ''; width: 26px; height: 2px; }
.sec p.lead { font-size: 1.12rem; line-height: 1.7; margin-bottom: 28px; max-width: 540px; }
.flist { display: grid; gap: 12px; margin-bottom: 36px; max-width: 540px; }
.flist li { display: flex; align-items: flex-start; gap: 12px; font-size: .96rem; }
.flist .tick { flex-shrink: 0; margin-top: 2px; }
.ctarow { display: flex; flex-wrap: wrap; gap: 16px; align-items: center; }

/* ═════════════════════════ S1 — bydaniwp (creme/Serif/Aurora) ═════════════════════════ */
@property --rot { syntax: "<angle>"; inherits: false; initial-value: 0deg; }
@keyframes aurora-rot { to { --rot: 360deg; } }
.s1 {
  background: var(--bone); color: var(--ink);
  --a1: #6c63ff; --a2: #ff3da6; --a3: #22d3c5;
}
.s1 .kicker { color: var(--ink); }
.s1 .kicker::before { background: linear-gradient(90deg, var(--a1), var(--a2)); }
.s1 h2 {
  font-family: var(--font-serif); font-weight: 400; letter-spacing: -.025em; line-height: 1.0;
  font-size: clamp(2.2rem,4.4vw,3.6rem); margin-bottom: 22px;
}
.s1 h2 em { font-style: italic; }
.s1 .pill {
  display: inline-block; font-style: italic; padding: 0 .35em; border-radius: 999px;
  background: linear-gradient(135deg, rgba(108,99,255,.18), rgba(255,61,166,.18) 60%, rgba(34,211,197,.18));
  border: 1px solid rgba(14,14,18,.12);
}
.s1 .lead { color: var(--ink); opacity: .76; }
.s1 .flist .tick { color: var(--a1); }
.s1 .flist b { font-weight: 600; }
.btn-aurora {
  position: relative; isolation: isolate; display: inline-flex; align-items: center; gap: .6rem;
  padding: .95rem 1.6rem; border-radius: 999px; background: var(--bone); color: var(--ink);
  font-weight: 500; transition: transform .5s var(--ease);
}
.btn-aurora::before {
  content: ""; position: absolute; inset: 0; padding: 1.6px; border-radius: 999px;
  background: conic-gradient(from var(--rot,0deg), var(--a1), var(--a2), var(--a3), var(--a1));
  -webkit-mask: linear-gradient(#000 0 0) content-box, linear-gradient(#000 0 0);
          mask: linear-gradient(#000 0 0) content-box, linear-gradient(#000 0 0);
  -webkit-mask-composite: xor; mask-composite: exclude;
  animation: aurora-rot 7s linear infinite; z-index: -1;
}
.btn-aurora:hover { transform: translateY(-2px); }
.btn-ghost { display: inline-flex; align-items: center; gap: .5rem; font-weight: 500; padding: .95rem .25rem; position: relative; color: var(--ink); }
.btn-ghost::after { content:""; position:absolute; left:.25rem; right:.25rem; bottom:.5rem; height:1px; background: currentColor; opacity:.5; transform-origin:right; transition: transform .6s var(--ease); }
.btn-ghost:hover::after { transform-origin:left; transform: scaleX(1.04); }
/* S1 visual — review card */
.s1__visual {
  background: #fff; border: 1px solid rgba(14,14,18,.10); border-radius: 22px; padding: 30px;
  box-shadow: 0 30px 70px rgba(14,14,18,.08); position: relative;
}
.s1__visual::before {
  content:""; position:absolute; inset:-1px; border-radius:22px; z-index:-1; filter: blur(22px); opacity:.25;
  background: linear-gradient(135deg, var(--a1), var(--a2), var(--a3));
}
.s1__avatar { display:flex; align-items:center; gap:14px; margin-bottom:22px; }
.s1__avatar img { width:54px; height:54px; border-radius:50%; }
.s1__avatar .nm { font-family: var(--font-serif); font-size: 1.05rem; }
.s1__avatar .rl { font-size:.82rem; opacity:.6; }
.s1__quote { font-family: var(--font-serif); font-style: italic; font-size: 1.4rem; line-height: 1.4; letter-spacing:-.01em; margin-bottom: 22px; }
.s1__stars { display:flex; align-items:center; gap:8px; font-size:.9rem; }
.s1__stars .g { color:#fbbf24; letter-spacing:2px; }

/* ═════════════════════════ S2 — KI-Agenten (dark/Teal) ═════════════════════════ */
.s2 {
  position: relative; color: #f1f5f9;
  background: #07070d;
  --teal: #00d4aa; --violet: #8b5cf6;
}
.s2__bg { position:absolute; inset:0; z-index:0; background-size: cover; background-position: center; }
.s2__bg::after { content:""; position:absolute; inset:0; background: linear-gradient(115deg, rgba(7,7,13,.95) 30%, rgba(7,7,13,.72)); }
.s2 .wrap { position: relative; z-index: 1; }
.s2 .sec__logo { filter: invert(1) brightness(1.6); opacity:.92; }
.s2 .kicker { color: var(--teal); }
.s2 .kicker::before { background: var(--teal); }
.s2 h2 { font-weight: 800; letter-spacing:-.02em; line-height:1.08; font-size: clamp(2.2rem,4.6vw,3.6rem); margin-bottom: 20px; }
.s2 h2 .grad { background: linear-gradient(135deg, var(--teal), var(--violet)); -webkit-background-clip:text; background-clip:text; -webkit-text-fill-color:transparent; }
.s2 .lead { color: #94a3b8; }
.s2 .flist .tick { color: var(--teal); }
.s2 .pillset { display:flex; flex-wrap:wrap; gap:10px; margin-bottom:34px; }
.s2 .pillset span { font-size:.8rem; padding:7px 14px; border-radius:999px; background: rgba(255,255,255,.05); border:1px solid rgba(255,255,255,.1); color:#cbd5e1; }
.btn-teal {
  display:inline-flex; align-items:center; gap:10px; padding:.95rem 1.8rem; border-radius:999px; font-weight:700;
  background: linear-gradient(135deg, var(--teal), #0ea5e9); color:#04130f; transition: transform .35s var(--ease), box-shadow .35s ease;
}
.btn-teal:hover { transform: translateY(-2px); box-shadow: 0 14px 34px rgba(0,212,170,.35); }
.btn-outline-d { display:inline-flex; align-items:center; gap:10px; padding:.95rem 1.6rem; border-radius:999px; font-weight:600; color:#f1f5f9; border:1px solid rgba(255,255,255,.16); transition: border-color .3s, background .3s; }
.btn-outline-d:hover { border-color: var(--teal); background: rgba(255,255,255,.05); }
/* S2 visual — mock agent card */
.s2__card { background: rgba(255,255,255,.04); border:1px solid rgba(255,255,255,.1); border-radius:18px; padding:24px; box-shadow: 0 24px 70px rgba(0,0,0,.55); position:relative; }
.s2__card::before { content:""; position:absolute; inset:-1px; border-radius:18px; z-index:-1; filter:blur(20px); opacity:.18; background: linear-gradient(135deg, var(--teal), var(--violet)); }
.s2__crow { display:flex; align-items:center; justify-content:space-between; margin-bottom:18px; }
.s2__crow .h { font-weight:700; font-size:1.05rem; }
.s2__crow .b { font-size:.72rem; color:var(--teal); border:1px solid rgba(0,212,170,.4); padding:4px 10px; border-radius:999px; }
.s2__agent { display:flex; gap:14px; align-items:flex-start; padding:16px; border-radius:12px; background: rgba(0,212,170,.05); border:1px solid rgba(0,212,170,.2); }
.s2__agent .ic { width:40px; height:40px; border-radius:10px; flex-shrink:0; display:flex; align-items:center; justify-content:center; background: linear-gradient(135deg, var(--teal), var(--violet)); font-size:1.1rem; }
.s2__agent .nm { font-weight:600; font-size:.92rem; margin-bottom:2px; }
.s2__agent .ds { font-size:.78rem; color:#94a3b8; line-height:1.5; }
.s2__meta { display:flex; gap:18px; margin-top:16px; font-size:.72rem; color:#64748b; }
.s2__meta b { color:#cbd5e1; font-weight:600; }

/* ═════════════════════════ S3 — WEMOVE (Foto/Bold/Rot) ═════════════════════════ */
.s3 {
  position: relative; color: #fff; --red: #e74540;
  background: #111; overflow: hidden;
  min-height: 92svh; display: flex; align-items: center;
  padding: clamp(90px,12vw,150px) 0;
}
.s3__bg { position:absolute; inset:0; z-index:0; background-size: cover; background-position: center 22%; }
.s3__bg::after { content:""; position:absolute; inset:0; background: linear-gradient(90deg, rgba(10,10,12,.92) 0%, rgba(10,10,12,.7) 42%, rgba(10,10,12,.25) 100%); }
.s3 .wrap { position: relative; z-index: 1; }
.s3__inner { max-width: 680px; }
.s3__logo { height: 64px; width:auto; margin-bottom: 26px; }
.s3 .kicker { color: var(--red); letter-spacing:.24em; }
.s3 .kicker::before { background: var(--red); }
.s3 h2 {
  font-family: var(--font-cond); font-weight: 700; text-transform: uppercase;
  font-style: italic; letter-spacing: .01em; line-height: .96;
  font-size: clamp(2.6rem,6.4vw,5rem); margin-bottom: 20px;
}
.s3 h2 .r { color: var(--red); }
.s3 .lead { font-size: 1.18rem; color: rgba(255,255,255,.86); max-width: 540px; }
.s3__tags { display:flex; flex-wrap:wrap; gap: 10px 20px; margin-bottom: 36px; }
.s3__tags span { font-family: var(--font-cond); font-weight:600; text-transform:uppercase; letter-spacing:.06em; font-size:.92rem; color:#fff; }
.s3__tags span::before { content:"» "; color: var(--red); }
.btn-red {
  display:inline-flex; align-items:center; gap:10px; padding:1rem 2rem; border-radius:4px; font-weight:700;
  font-family: var(--font-cond); text-transform:uppercase; letter-spacing:.06em; font-size:1rem;
  background: var(--red); color:#fff; transition: transform .3s var(--ease), background .3s ease;
}
.btn-red:hover { transform: translateY(-2px); background:#d63a35; }
.btn-blk { display:inline-flex; align-items:center; gap:10px; padding:1rem 1.8rem; border-radius:4px; font-weight:700; font-family: var(--font-cond); text-transform:uppercase; letter-spacing:.06em; font-size:1rem; background: rgba(0,0,0,.55); color:#fff; border:1px solid rgba(255,255,255,.25); transition: border-color .3s, background .3s; }
.btn-blk:hover { background: rgba(0,0,0,.8); border-color:#fff; }

/* ═════════════════════════ FOOTER ═════════════════════════ */
.foot { background: #0c0c10; color: rgba(255,255,255,.7); padding: 60px 0 40px; }
.foot__grid { display:flex; flex-wrap:wrap; gap: 32px; justify-content: space-between; align-items: flex-start; }
.foot__brand { font-family: var(--font-serif); font-size: 1.4rem; color:#fff; margin-bottom: 10px; }
.foot__brand span { color:#8a8a93; font-weight:300; }
.foot p { font-size:.9rem; max-width: 360px; line-height:1.6; }
.foot a { color: rgba(255,255,255,.7); transition: color .2s ease; }
.foot a:hover { color:#fff; }
.foot__col h4 { font-size:.74rem; text-transform:uppercase; letter-spacing:.2em; color:#6c6c75; margin-bottom:14px; }
.foot__col a { display:block; font-size:.92rem; margin-bottom:8px; }
.foot__bar { margin-top: 44px; padding-top: 22px; border-top:1px solid rgba(255,255,255,.08); display:flex; flex-wrap:wrap; gap:12px; justify-content:space-between; font-size:.8rem; color:#6c6c75; }
.foot__bar a { color:#6c6c75; }

/* ═════════════════════════ LEGAL PAGES ═════════════════════════ */
.legal { background: var(--bone); color: var(--ink); min-height:100vh; padding: 120px 0 80px; }
.legal .wrap { max-width: 760px; }
.legal h1 { font-family: var(--font-serif); font-weight:400; font-size: clamp(2.2rem,5vw,3rem); letter-spacing:-.02em; margin-bottom: 10px; }
.legal h2 { font-family: var(--font-serif); font-weight:500; font-size:1.3rem; margin: 34px 0 10px; }
.legal p { margin-bottom: 14px; color: rgba(14,14,18,.8); }
.legal a { color:#6c63ff; text-decoration: underline; text-underline-offset:2px; }
.legal ul { list-style: none; margin: 0 0 14px; }
.legal li { position: relative; padding-left: 18px; margin-bottom: 6px; color: rgba(14,14,18,.8); }
.legal li::before { content:"–"; position:absolute; left:0; color:#6c63ff; }
.legal .box { background:#fff; border:1px solid rgba(14,14,18,.1); border-radius:12px; padding:16px; font-size:.92rem; }
.legal .eyebrow { font-size:.72rem; text-transform:uppercase; letter-spacing:.18em; color: rgba(14,14,18,.5); margin-bottom:6px; }
.legal__foot { margin-top: 48px; padding-top: 22px; border-top:1px solid rgba(14,14,18,.12); display:flex; justify-content:space-between; }
.legal__back { position: fixed; top: 18px; left: 18px; z-index: 10; display:inline-flex; align-items:center; gap:8px; padding:9px 16px; border-radius:999px; background: rgba(14,14,18,.85); color:#fff; font-size:.85rem; font-weight:500; backdrop-filter: blur(8px); }
