/* =====================================================================
   Tech Artist — Portfolio
   Konzept: "Nächtliches Observatorium / Atelier"
   Tiefes Tinten-Schwarz · weiche Aurora (Türkis→Violett) · 1 Gold-Ember-Akzent
   Display: Fraunces (mystische Serife) · Body: Hanken Grotesk · Meta: JetBrains Mono
   ===================================================================== */

:root{
  /* Farbwelt */
  --void:    #07070c;
  --void-2:  #0a0a12;
  --ink:     #0e0e1b;
  --panel:   rgba(22,22,38,.45);
  --line:    rgba(180,190,255,.10);
  --line-2:  rgba(180,190,255,.18);

  --text:    #ece9f5;
  --mist:    #a9a7bd;
  --faint:   #6f6d84;

  /* Aurora / Akzente */
  --teal:    #6fe0c8;
  --cyan:    #7ec8ff;
  --violet:  #9a86ff;
  --ember:   #f0c486;   /* warmer Gegenpol, sparsam */

  --glow-teal:   rgba(111,224,200,.55);
  --glow-violet: rgba(154,134,255,.50);
  --glow-cyan:   rgba(126,200,255,.45);

  /* Typo */
  --display: 'Fraunces', Georgia, serif;
  --body:    'Hanken Grotesk', system-ui, sans-serif;
  --mono:    'JetBrains Mono', ui-monospace, monospace;

  /* Maße */
  --pad: clamp(1.25rem, 5vw, 6rem);
  --maxw: 1280px;
  --r: 18px;
  --ease: cubic-bezier(.22,.61,.36,1);
  --ease-out: cubic-bezier(.16,1,.3,1);
}

*,*::before,*::after{ box-sizing:border-box; margin:0; padding:0; }
html{ scroll-behavior:smooth; -webkit-text-size-adjust:100%; }
@media (prefers-reduced-motion: reduce){ html{ scroll-behavior:auto; } }

body{
  font-family:var(--body);
  background:var(--void);
  color:var(--text);
  line-height:1.6;
  overflow-x:hidden;
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
  cursor:none;
}
@media (hover:none){ body{ cursor:auto; } }

img{ max-width:100%; display:block; }
a{ color:inherit; text-decoration:none; }
em{ font-style:italic; }
::selection{ background:var(--glow-violet); color:#fff; }

/* ---------- Atmosphäre ---------- */
.atmosphere{ position:fixed; inset:0; z-index:0; pointer-events:none; overflow:hidden; }
#starfield{ position:absolute; inset:0; width:100%; height:100%; opacity:.9; }

.aurora{
  position:absolute; border-radius:50%;
  filter:blur(80px); opacity:.55; mix-blend-mode:screen;
  will-change:transform;
}
.aurora--1{ width:60vw; height:60vw; left:-12vw; top:-14vw;
  background:radial-gradient(circle at 50% 50%, var(--glow-teal), transparent 62%);
  animation:drift1 26s var(--ease) infinite alternate; }
.aurora--2{ width:55vw; height:55vw; right:-14vw; top:8vh;
  background:radial-gradient(circle at 50% 50%, var(--glow-violet), transparent 60%);
  animation:drift2 32s var(--ease) infinite alternate; }
.aurora--3{ width:48vw; height:48vw; left:30vw; bottom:-18vw;
  background:radial-gradient(circle at 50% 50%, var(--glow-cyan), transparent 64%);
  animation:drift3 38s var(--ease) infinite alternate; }
@keyframes drift1{ to{ transform:translate3d(8vw,6vh,0) scale(1.15); } }
@keyframes drift2{ to{ transform:translate3d(-7vw,10vh,0) scale(1.2); } }
@keyframes drift3{ to{ transform:translate3d(5vw,-8vh,0) scale(1.1); } }

.grain{
  position:absolute; inset:-50%; opacity:.045; mix-blend-mode:overlay;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='160' height='160'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='.85' numOctaves='2' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E");
  animation:grain 7s steps(6) infinite;
}
@keyframes grain{
  0%{transform:translate(0,0)} 20%{transform:translate(-4%,3%)}
  40%{transform:translate(3%,-4%)} 60%{transform:translate(-3%,2%)}
  80%{transform:translate(4%,-2%)} 100%{transform:translate(0,0)}
}
.vignette{ position:absolute; inset:0;
  background:radial-gradient(120% 100% at 50% 0%, transparent 55%, rgba(0,0,0,.55) 100%); }

/* ---------- Custom Cursor ---------- */
.cursor{ position:fixed; left:0; top:0; z-index:9999; pointer-events:none;
  mix-blend-mode:screen; will-change:transform; }
.cursor__dot{ position:absolute; width:6px; height:6px; border-radius:50%;
  background:var(--teal); transform:translate(-50%,-50%);
  box-shadow:0 0 12px var(--glow-teal); }
.cursor__ring{ position:absolute; width:34px; height:34px; border-radius:50%;
  border:1px solid var(--line-2); transform:translate(-50%,-50%);
  transition:width .3s var(--ease-out), height .3s var(--ease-out), border-color .3s, background .3s; }
.cursor.is-hover .cursor__ring{ width:58px; height:58px; border-color:var(--glow-teal);
  background:radial-gradient(circle, rgba(111,224,200,.10), transparent 70%); }
.cursor.is-down .cursor__ring{ width:26px; height:26px; }
@media (hover:none){ .cursor{ display:none; } }

/* ---------- Ladevorhang ---------- */
.curtain{ position:fixed; inset:0; z-index:9000; background:var(--void);
  display:grid; place-content:center; gap:24px; transition:opacity .8s var(--ease), visibility .8s; }
.curtain.is-done{ opacity:0; visibility:hidden; }
.curtain__mark{ font-family:var(--display); font-size:clamp(3rem,9vw,6rem);
  font-weight:500; letter-spacing:.04em; text-align:center;
  background:linear-gradient(120deg,var(--teal),var(--violet) 60%,var(--ember));
  -webkit-background-clip:text; background-clip:text; color:transparent;
  animation:breathe 2.4s var(--ease) infinite; }
@keyframes breathe{ 50%{ opacity:.55; transform:scale(.97); } }
.curtain__bar{ width:min(46vw,220px); height:2px; background:var(--line);
  border-radius:2px; overflow:hidden; margin-inline:auto; }
.curtain__bar i{ display:block; height:100%; width:40%;
  background:linear-gradient(90deg,transparent,var(--teal),transparent);
  animation:load 1.1s var(--ease) infinite; }
@keyframes load{ from{ transform:translateX(-120%);} to{ transform:translateX(360%);} }

/* ---------- Sigil (Platzhalter bis Codex-Emblem) ---------- */
.sigil{ position:relative; width:30px; height:30px; flex:0 0 auto;
  border-radius:50%; display:inline-block;
  background:
    radial-gradient(circle at 50% 50%, var(--teal) 0 2px, transparent 3px),
    conic-gradient(from 0deg, var(--teal), var(--violet), var(--cyan), var(--teal));
  -webkit-mask:radial-gradient(circle at 50% 50%, transparent 4px, #000 5px 11px, transparent 12px,
              #000 12px 13.5px, transparent 14.5px);
          mask:radial-gradient(circle at 50% 50%, transparent 4px, #000 5px 11px, transparent 12px,
              #000 12px 13.5px, transparent 14.5px);
  animation:spin 14s linear infinite;
  box-shadow:0 0 16px rgba(111,224,200,.25);
}
@keyframes spin{ to{ transform:rotate(360deg); } }
/* Wenn Codex ein Emblem liefert: .sigil mit Bild übersteuern */
.sigil[data-img]{ background:none; -webkit-mask:none; mask:none; animation:spin 24s linear infinite; }

/* ---------- Layout-Helfer ---------- */
section{ position:relative; z-index:1; }
.eyebrow{ font-family:var(--mono); font-size:.74rem; letter-spacing:.22em;
  text-transform:uppercase; color:var(--mist); display:inline-flex; align-items:center; gap:.7em; }
.eyebrow__pulse{ width:7px; height:7px; border-radius:50%; background:var(--teal);
  box-shadow:0 0 0 0 var(--glow-teal); animation:pulse 2.4s var(--ease) infinite; }
@keyframes pulse{ 0%{box-shadow:0 0 0 0 var(--glow-teal);} 70%{box-shadow:0 0 0 9px transparent;} }
.hl{ color:var(--text); background:linear-gradient(120deg,var(--glow-teal),var(--glow-violet));
  -webkit-background-clip:text; background-clip:text; -webkit-text-fill-color:transparent;
  font-weight:600; }

.section-head{ max-width:var(--maxw); }
.section-head__kicker{ font-family:var(--mono); font-size:.78rem; letter-spacing:.2em;
  text-transform:uppercase; color:var(--mist); display:flex; align-items:center; gap:.8em; margin-bottom:1.1rem; }
.section-head__kicker span{ color:var(--teal); }
.section-head__title{ font-family:var(--display); font-weight:400;
  font-size:clamp(2rem,5.2vw,3.6rem); line-height:1.06; letter-spacing:-.01em; }
.section-head__title em{ color:var(--violet); }

/* ---------- Navigation ---------- */
.nav{ position:fixed; top:0; left:0; right:0; z-index:100;
  display:flex; align-items:center; justify-content:space-between;
  padding:1.1rem var(--pad);
  transition:background .4s var(--ease), backdrop-filter .4s, padding .4s var(--ease), border-color .4s;
  border-bottom:1px solid transparent; }
.nav.is-stuck{ background:rgba(7,7,12,.6); backdrop-filter:blur(14px) saturate(140%);
  border-bottom-color:var(--line); padding-block:.7rem; }
.nav__brand{ display:inline-flex; align-items:center; gap:.6rem;
  font-family:var(--display); font-size:1.18rem; font-weight:500; letter-spacing:.01em; }
.nav__links{ display:flex; align-items:center; gap:clamp(1rem,2.4vw,2.2rem);
  font-size:.92rem; color:var(--mist); }
.nav__links a{ position:relative; transition:color .3s; }
.nav__links a:not(.nav__cta)::after{ content:""; position:absolute; left:0; bottom:-4px;
  width:100%; height:1px; background:var(--teal); transform:scaleX(0); transform-origin:right;
  transition:transform .4s var(--ease-out); }
.nav__links a:hover{ color:var(--text); }
.nav__links a:not(.nav__cta):hover::after{ transform:scaleX(1); transform-origin:left; }
.nav__cta{ padding:.5rem 1.1rem; border:1px solid var(--line-2); border-radius:100px;
  color:var(--text); transition:background .35s,border-color .35s,box-shadow .35s; }
.nav__cta:hover{ background:rgba(111,224,200,.08); border-color:var(--glow-teal);
  box-shadow:0 0 24px rgba(111,224,200,.18); }
@media (max-width:620px){ .nav__links a:not(.nav__cta){ display:none; } }

/* ---------- HERO ---------- */
.hero{ min-height:100svh; display:flex; flex-direction:column; justify-content:center;
  padding:8rem var(--pad) 4rem; max-width:var(--maxw); margin-inline:auto; }
.hero__nebula{ position:absolute; inset:0; z-index:0; pointer-events:none;
  background:url("../assets/img/hero-nebula.png") center/cover no-repeat;
  opacity:.5; mix-blend-mode:screen;
  -webkit-mask:radial-gradient(120% 90% at 70% 60%, #000, transparent 78%);
          mask:radial-gradient(120% 90% at 70% 60%, #000, transparent 78%);
  animation:nebulaFloat 30s var(--ease) infinite alternate; }
@keyframes nebulaFloat{ from{ transform:scale(1.02) translate(0,0); } to{ transform:scale(1.1) translate(-2%,1%); } }
.hero__inner{ position:relative; z-index:2; width:100%; max-width:min(100%,720px); }

/* Hero-Blickfang rechts: Observatoriums-Siegel + Halo + Umlaufbahnen */
.hero__visual{ position:absolute; z-index:1; pointer-events:none;
  right:clamp(-4rem,1vw,2rem); top:50%; translate:0 -50%;
  width:clamp(320px,42vw,600px); aspect-ratio:1; }
.hero__halo{ position:absolute; inset:10%; border-radius:50%;
  background:radial-gradient(circle at 50% 45%, var(--glow-violet), transparent 62%),
             radial-gradient(circle at 60% 65%, var(--glow-teal), transparent 60%);
  filter:blur(46px); opacity:.65; animation:breathe 7s var(--ease) infinite; }
.hero__seal{ position:absolute; inset:0;
  background:url("../assets/img/sigil.png") center/contain no-repeat;
  filter:saturate(1.25) drop-shadow(0 0 26px rgba(126,200,255,.28));
  opacity:.92; animation:spin 80s linear infinite; }
.hero__orbit{ position:absolute; border-radius:50%; border:1px solid var(--line-2); }
.hero__orbit--a{ inset:4%;  animation:spin 26s linear infinite; }
.hero__orbit--b{ inset:20%; border-style:dashed; border-color:var(--line);
  animation:spin 18s linear infinite reverse; }
.hero__orbit i{ position:absolute; top:-4px; left:50%; translate:-50% 0;
  width:9px; height:9px; border-radius:50%; background:var(--teal);
  box-shadow:0 0 16px var(--glow-teal); }
.hero__orbit--b i{ background:var(--ember); box-shadow:0 0 14px rgba(240,196,134,.6); width:7px; height:7px; }
@media (max-width:900px){
  .hero__inner{ max-width:100%; }
  .hero__visual{ right:50%; translate:50% -50%; top:42%;
    width:min(120vw,640px); opacity:.28; }
  .hero__orbit i{ opacity:.6; }
}
.hero .eyebrow{ margin-bottom:1.8rem; }

.hero__title{ font-family:var(--display); font-weight:400;
  font-size:clamp(2.7rem,10vw,7.4rem); line-height:.98; letter-spacing:-.02em; }
.hero__title .line{ display:block; overflow:hidden; }
.hero__title .word{ display:inline-block; transform:translateY(110%);
  will-change:transform; }
.hero__title .word--accent{ position:relative; }
.hero__title .word--accent em{
  background:linear-gradient(110deg,var(--teal),var(--cyan) 38%,var(--violet) 78%,var(--ember));
  -webkit-background-clip:text; background-clip:text; -webkit-text-fill-color:transparent;
  padding-right:.08em; }

.hero__meta{ margin-top:clamp(1.8rem,4vw,3rem); display:flex; flex-direction:column;
  gap:1.8rem; align-items:flex-start; max-width:56ch; }
.hero__lede{ font-size:clamp(1.02rem,1.7vw,1.28rem); color:var(--mist); }
.hero__lede .hl{ font-weight:600; }

.btn{ display:inline-flex; align-items:center; gap:.7em; font-family:var(--body);
  font-weight:600; font-size:1rem; padding:.95rem 1.6rem; border-radius:100px;
  border:1px solid transparent; transition:transform .35s var(--ease-out), box-shadow .35s, background .35s; }
.btn svg{ transition:transform .35s var(--ease-out); }
.btn--primary{ color:#06120f;
  background:linear-gradient(120deg,var(--teal),var(--cyan));
  box-shadow:0 0 0 1px rgba(111,224,200,.4), 0 18px 50px -18px rgba(111,224,200,.6); }
.btn--primary:hover{ box-shadow:0 0 0 1px rgba(111,224,200,.6), 0 22px 60px -16px rgba(126,200,255,.7); }
.btn--primary:hover svg{ transform:translateX(4px); }

.scrollcue{ position:absolute; left:var(--pad); bottom:2rem; background:none; border:0;
  color:var(--faint); font-family:var(--mono); font-size:.7rem; letter-spacing:.2em;
  text-transform:uppercase; display:flex; align-items:center; gap:.8rem; cursor:none; }
.scrollcue__line{ width:1px; height:48px; background:linear-gradient(var(--teal),transparent);
  position:relative; overflow:hidden; }
.scrollcue__line::after{ content:""; position:absolute; top:0; left:0; width:100%; height:40%;
  background:var(--teal); animation:cue 1.8s var(--ease) infinite; }
@keyframes cue{ to{ transform:translateY(260%);} }

/* ---------- Marquee ---------- */
.marquee-wrap{ border-block:1px solid var(--line); padding-block:1.5rem;
  background:linear-gradient(var(--void-2),var(--void)); overflow:hidden; }
.marquee{ display:flex; gap:0; width:max-content; }
.marquee__row{ display:flex; align-items:center; gap:2.6rem; list-style:none; padding-right:2.6rem;
  font-family:var(--display); font-size:clamp(1.3rem,2.6vw,2.1rem); color:var(--mist);
  white-space:nowrap; animation:scrollx 32s linear infinite; }
.marquee__row .dot{ color:var(--teal); font-size:.7em; }
.marquee:hover .marquee__row{ animation-play-state:paused; }
@keyframes scrollx{ to{ transform:translateX(-100%);} }

/* ---------- WORKS ---------- */
.works{ padding:clamp(5rem,12vw,9rem) var(--pad); max-width:var(--maxw); margin-inline:auto; }
.section-head{ margin-bottom:clamp(2.5rem,6vw,4.5rem); }
.works__list{ display:flex; flex-direction:column; gap:clamp(2.5rem,6vw,5rem); }

.work{ display:grid; grid-template-columns:1.05fr .95fr; gap:clamp(1.5rem,4vw,3.5rem);
  align-items:center; }
.work:nth-child(even){ grid-template-columns:.95fr 1.05fr; }
.work:nth-child(even) .work__art{ order:-1; }
@media (max-width:820px){ .work,.work:nth-child(even){ grid-template-columns:1fr; }
  .work:nth-child(even) .work__art{ order:0; } }

.work__art{ position:relative; aspect-ratio:4/3; border-radius:var(--r); overflow:hidden;
  border:1px solid var(--line); transform:translateZ(0);
  box-shadow:0 30px 80px -40px rgba(0,0,0,.9); }
.work__art::after{ content:""; position:absolute; inset:0;
  background:linear-gradient(180deg,transparent 40%,rgba(7,7,12,.5)); }
.work__img{ position:absolute; inset:0; width:100%; height:100%; object-fit:cover;
  transition:transform .9s var(--ease-out); will-change:transform; }
.work:hover .work__img{ transform:scale(1.06); }
/* Aurora-Platzhalter, falls Bild fehlt */
.work__art[data-tint]{ background:#0c0c18; }
.work__art[data-tint] .work__ph{ position:absolute; inset:0; opacity:.95; }
.work__art[data-tint="teal"]   .work__ph{ background:radial-gradient(80% 90% at 25% 20%, var(--glow-teal),transparent 60%),radial-gradient(70% 80% at 85% 90%, var(--glow-cyan),transparent 60%),#0a121a; }
.work__art[data-tint="ember"]  .work__ph{ background:radial-gradient(80% 90% at 20% 25%, rgba(240,196,134,.5),transparent 60%),radial-gradient(70% 80% at 90% 85%, var(--glow-violet),transparent 60%),#16100c; }
.work__art[data-tint="violet"] .work__ph{ background:radial-gradient(80% 90% at 30% 20%, var(--glow-violet),transparent 60%),radial-gradient(70% 80% at 85% 90%, var(--glow-teal),transparent 60%),#0f0c1a; }
.work__art[data-tint="cyan"]   .work__ph{ background:radial-gradient(80% 90% at 25% 25%, var(--glow-cyan),transparent 60%),radial-gradient(70% 80% at 88% 88%, var(--glow-violet),transparent 60%),#0a1018; }
.work__idx{ position:absolute; top:1rem; left:1.1rem; z-index:2; font-family:var(--mono);
  font-size:.8rem; letter-spacing:.2em; color:var(--text); opacity:.85;
  padding:.3rem .6rem; border:1px solid var(--line-2); border-radius:100px;
  background:rgba(7,7,12,.4); backdrop-filter:blur(6px); }

.work__title{ font-family:var(--display); font-weight:400; font-size:clamp(1.9rem,4vw,3rem);
  line-height:1.04; letter-spacing:-.01em; margin-bottom:.5rem; }
.work__kind{ font-family:var(--mono); font-size:.78rem; letter-spacing:.16em; text-transform:uppercase;
  color:var(--teal); display:inline-flex; gap:.8em; align-items:center; margin-bottom:1.1rem; }
.work__kind .sep{ color:var(--faint); }
.work__blurb{ color:var(--mist); font-size:1.02rem; max-width:46ch; margin-bottom:1.4rem; }
.work__stack{ display:flex; flex-wrap:wrap; gap:.5rem; list-style:none; margin-bottom:1.3rem; }
.work__stack li{ font-family:var(--mono); font-size:.74rem; color:var(--mist);
  padding:.32rem .7rem; border:1px solid var(--line); border-radius:8px; background:var(--panel); }
.work__link{ display:inline-flex; align-items:center; gap:.5em; font-weight:600; color:var(--text);
  border-bottom:1px solid var(--line-2); padding-bottom:3px; transition:gap .3s,border-color .3s,color .3s; }
.work__link:hover{ gap:.9em; color:var(--teal); border-color:var(--teal); }
.work__link.is-soon{ color:var(--faint); border-color:transparent; pointer-events:none; }

/* ---------- CRAFT ---------- */
.craft{ padding:clamp(5rem,12vw,9rem) var(--pad); max-width:var(--maxw); margin-inline:auto; }
.craft__lede{ color:var(--mist); font-size:1.1rem; max-width:46ch; margin-top:1.4rem; }
.craft__grid{ display:grid; grid-template-columns:minmax(0,.85fr) minmax(0,1.15fr);
  gap:clamp(2rem,5vw,4rem); align-items:start; }
@media (max-width:880px){ .craft__grid{ grid-template-columns:1fr; } }
.craft__cards{ list-style:none; display:grid; grid-template-columns:1fr 1fr; gap:1px;
  background:var(--line); border:1px solid var(--line); border-radius:var(--r); overflow:hidden; }
@media (max-width:520px){ .craft__cards{ grid-template-columns:1fr; } }
.craft__card{ background:var(--ink); padding:1.8rem 1.6rem; position:relative;
  transition:background .4s; overflow:hidden; }
.craft__card::before{ content:""; position:absolute; inset:0;
  background:radial-gradient(120% 120% at 0% 0%, rgba(111,224,200,.10), transparent 45%);
  opacity:0; transition:opacity .5s; }
.craft__card:hover{ background:#11111f; }
.craft__card:hover::before{ opacity:1; }
.craft__ico{ width:38px; height:38px; color:var(--teal); margin-bottom:1.1rem; }
.craft__card h3{ font-family:var(--display); font-weight:500; font-size:1.25rem; margin-bottom:.4rem; }
.craft__card p{ color:var(--mist); font-size:.95rem; }

/* ---------- ABOUT ---------- */
.about{ padding:clamp(5rem,12vw,9rem) var(--pad); }
.about__inner{ max-width:1000px; margin-inline:auto; text-align:center; }
.about__quote{ margin:1.8rem 0 3rem; }
.about__quote p{ font-family:var(--display); font-weight:400;
  font-size:clamp(1.6rem,4.4vw,3rem); line-height:1.2; letter-spacing:-.01em; }
.about__quote em{ color:var(--violet); }
.about__quote .word{ display:inline-block; }
.about__stats{ display:grid; grid-template-columns:repeat(4,1fr); gap:1.5rem; margin-top:2rem; }
@media (max-width:780px){ .about__stats{ grid-template-columns:1fr 1fr; gap:2rem; } }
.stat{ text-align:center; }
.stat__n{ font-family:var(--display); font-size:clamp(2.2rem,5vw,3.4rem); font-weight:400;
  background:linear-gradient(120deg,var(--teal),var(--violet));
  -webkit-background-clip:text; background-clip:text; -webkit-text-fill-color:transparent; line-height:1; }
.stat__l{ color:var(--mist); font-size:.86rem; margin-top:.6rem; max-width:22ch; margin-inline:auto; }

/* ---------- CONTACT ---------- */
.contact{ padding:clamp(6rem,14vw,11rem) var(--pad); text-align:center; overflow:hidden; }
.contact__seal{ position:absolute; left:50%; top:48%; translate:-50% -50%;
  width:min(86vw,720px); aspect-ratio:1; pointer-events:none; z-index:0;
  background:url("../assets/img/sigil.png") center/contain no-repeat;
  opacity:.16; mix-blend-mode:screen; filter:saturate(1.2);
  animation:spin 90s linear infinite; }
.contact__inner{ position:relative; z-index:1; max-width:900px; margin-inline:auto; }
.contact__title{ font-family:var(--display); font-weight:400; line-height:1.05;
  font-size:clamp(2.4rem,8vw,5.5rem); letter-spacing:-.02em; margin:1.2rem 0 2.4rem; }
.contact__title em{ background:linear-gradient(110deg,var(--teal),var(--cyan) 45%,var(--violet) 80%,var(--ember));
  -webkit-background-clip:text; background-clip:text; -webkit-text-fill-color:transparent; }
.contact__mail{ display:inline-block; font-family:var(--mono); font-size:clamp(1rem,2.6vw,1.5rem);
  color:var(--text); padding:.6em 0; border-bottom:1px solid var(--line-2);
  transition:color .35s,border-color .35s,letter-spacing .35s; }
.contact__mail:hover{ color:var(--teal); border-color:var(--teal); letter-spacing:.02em; }
.contact__socials{ list-style:none; display:flex; gap:1.4rem; justify-content:center;
  margin-top:2.4rem; flex-wrap:wrap; }
.contact__socials a{ font-family:var(--mono); font-size:.82rem; letter-spacing:.1em;
  text-transform:uppercase; color:var(--mist); padding:.5rem .9rem; border:1px solid var(--line);
  border-radius:100px; transition:color .3s,border-color .3s,background .3s; }
.contact__socials a:hover{ color:var(--text); border-color:var(--glow-teal); background:rgba(111,224,200,.07); }

/* ---------- Footer ---------- */
.foot{ position:relative; z-index:1; border-top:1px solid var(--line);
  padding:2.5rem var(--pad); display:flex; align-items:center; justify-content:space-between;
  gap:1.2rem; flex-wrap:wrap; color:var(--faint); font-size:.86rem; }
.foot__sigil{ width:24px; height:24px; }
.foot p{ flex:1; min-width:200px; }
.foot__top{ color:var(--mist); transition:color .3s; }
.foot__top:hover{ color:var(--teal); }

/* ---------- Reveal (JS-gesteuert, mit Fallback) ---------- */
[data-rise]{ opacity:0; transform:translateY(28px); }
.is-ready [data-rise]{ transition:opacity .9s var(--ease-out), transform .9s var(--ease-out); }
[data-rise].in{ opacity:1; transform:none; }
[data-lines] .word{ display:inline-block; }

/* Kein JS / reduced motion: alles sichtbar */
.no-js [data-rise], .no-js .hero__title .word{ opacity:1 !important; transform:none !important; }
@media (prefers-reduced-motion: reduce){
  .aurora,.grain,.marquee__row,.curtain__mark,.scrollcue__line::after,.eyebrow__pulse,.sigil{ animation:none !important; }
  [data-rise]{ opacity:1 !important; transform:none !important; }
  .hero__title .word{ transform:none !important; }
  body{ cursor:auto; } .cursor{ display:none; }
}
