:root{
  --obsidian:#0b0b0f;
  --graphit:#151622;
  --violett:#7a3cff;
  --tiefviolett:#2c1a41;
  --rauchgrau:#9aa0a6;
  --text:#e6e6ef;
  --blur: 10px;
  --glass: rgba(21,22,34,0.65);
  --ring: 0 0 0 1px rgba(122,60,255,0.18) inset;
  --shadow: 0 10px 30px rgba(0,0,0,0.45);
  --glow: 0 0 18px rgba(122,60,255,0.35);
}
*{box-sizing:border-box}
html,body{height:100%}
body{
  margin:0; color:var(--text);
  background: radial-gradient(1200px 800px at 20% -10%, #111 0%, var(--obsidian) 45%), var(--obsidian);
  font-family: Inter, system-ui, -apple-system, Segoe UI, Roboto, "Helvetica Neue", Arial, "Noto Sans", "Apple Color Emoji","Segoe UI Emoji", "Segoe UI Symbol", sans-serif;
  -webkit-font-smoothing:antialiased; text-rendering:optimizeLegibility;
}

/* Serif for logo/headline */
.logo__title{
  font-family: "Merriweather", Georgia, "Times New Roman", serif;
  letter-spacing:.02em; font-weight:700; font-size:1.05rem; line-height:1;
}

/* NAV */
.nav{
  position:sticky; top:0; z-index:1000;
  backdrop-filter:saturate(120%) blur(var(--blur));
  background: linear-gradient(to bottom, rgba(11,11,15,0.95), rgba(11,11,15,0.55));
  box-shadow: var(--ring), var(--shadow);
}
.nav__inner{
  max-width:1200px; margin:0 auto;
  display:flex; align-items:center; justify-content:flex-start; /* Logo links, Rest nach rechts */
  padding:.8rem 1rem;
}
.nav__logo{display:flex; align-items:center; gap:.6rem; color:var(--text); text-decoration:none}
.nav__logo:hover .logo__title{ text-shadow: var(--glow) }

.nav__toggle{
  display:inline-flex; flex-direction:column; gap:5px;
  width:42px; height:36px; align-items:center; justify-content:center;
  background:transparent; border:1px solid rgba(255,255,255,.08); border-radius:10px; cursor:pointer;
  box-shadow:var(--ring);
}
.nav__toggle:focus-visible{ outline:2px solid var(--violett); outline-offset:2px }
.nav__toggle-bar{ width:20px; height:2px; background:#eae8ff; border-radius:2px }

.nav__menu{
  position:fixed; inset:0 0 0 auto; width:78%;
  max-width:340px; background:linear-gradient(180deg, #0e0e14 0%, #141421 100%);
  transform:translateX(100%); transition:transform .35s ease; padding:5.5rem 1.25rem 2rem;
  display:flex; flex-direction:column; gap:1.2rem; box-shadow:-8px 0 30px rgba(0,0,0,.55);
}
.nav__menu[aria-hidden="true"]{ pointer-events:none }
.nav__menu.open{ transform:translateX(0%) }

.nav__menu ul{ list-style:none; margin:0; padding:0; display:flex; flex-direction:column; gap:.2rem }
.nav__link{
  display:inline-flex; align-items:center; gap:.6rem;
  padding:.8rem 1rem; border-radius:12px; text-decoration:none; color:var(--text);
  background:rgba(255,255,255,0.02); border:1px solid rgba(255,255,255,0.06);
  box-shadow:var(--ring);
  transition:background .2s ease, transform .2s ease, text-shadow .2s ease;
}
.nav__link:hover{ background:rgba(122,60,255,0.07); text-shadow: var(--glow) }
.nav__link.is-active{
  border-color:rgba(122,60,255,.55);
  box-shadow:0 0 0 1px rgba(122,60,255,.55) inset, var(--glow);
}

/* Desktop */
@media (min-width: 980px){
  .nav__toggle{ display:none }
  .nav__menu{
    position:static; width:auto; max-width:none; padding:0; background:transparent; transform:none; box-shadow:none;

    /* Menü-Links rechtsbündig */
    display:flex; align-items:center; gap:.8rem;
    margin-left:auto;
  }
  .nav__menu ul{ flex-direction:row; gap:.35rem }
  .nav__link{
    background:transparent; border:1px solid transparent; border-radius:10px;
    padding:.6rem .9rem; position:relative;
  }
  .nav__link::after{
    content:""; position:absolute; left:.9rem; right:.9rem; bottom:.35rem;
    height:2px; background:linear-gradient(90deg, transparent, var(--violett), transparent);
    transform:scaleX(0); transform-origin: center; transition:transform .25s ease;
    box-shadow: var(--glow);
  }
  .nav__link:hover::after{ transform:scaleX(1) }
  .nav__link.is-active::after{ transform:scaleX(1) }
}

/* HERO */
.hero{
  min-height:60vh; display:grid; place-items:center; text-align:center; padding:6rem 1rem 4rem;
  background:
    radial-gradient(800px 400px at 70% 0%, rgba(122,60,255,0.10), transparent 70%),
    radial-gradient(600px 300px at 20% 20%, rgba(122,60,255,0.07), transparent 60%);
}
.hero__title{
  font-family: "Merriweather", Georgia, serif;
  font-size: clamp(2rem, 4vw + 1rem, 4rem);
  margin:0 0 .5rem; letter-spacing:.04em;
}
.hero__subtitle{ color: var(--rauchgrau); margin:0 auto; max-width:680px }

/* Layout helpers */
.container{ max-width:1200px; margin:0 auto; padding:2rem 1rem }
.card{
  background:rgba(255,255,255,.02); border:1px solid rgba(255,255,255,.06);
  border-radius:16px; padding:1rem 1.25rem; box-shadow:var(--ring);
}

/* Footer */
footer{
  border-top:1px solid rgba(255,255,255,.08);
  background:linear-gradient(180deg, rgba(11,11,15,.8), rgba(11,11,15,.95));
  padding:2rem 1rem; margin-top:4rem;
}
footer .footer__links{ display:flex; gap:1rem; flex-wrap:wrap; align-items:center }
footer a{ color:var(--rauchgrau); text-decoration:none }
footer a:hover{ color:var(--text); text-shadow: var(--glow) }

@media (prefers-reduced-motion: reduce){
  .nav__menu, .nav__link, .nav__link::after { transition:none !important }
  .nav__menu{ transform:none !important }
}

/* --- NAV FIX: sicherstellen, dass Links klickbar sind --- */
.nav__menu,
.nav__menu a,
.nav__logo,
.nav__toggle { pointer-events: auto; }

header.nav::before,
header.nav::after,
.hero::before,
.hero::after { pointer-events: none; /* Deko blockiert keine Klicks */ }

/* --- NAV SEARCH (nur Grund-Wrapper; Detail-Styles sind in search.css) --- */
.nav__search{
  display:flex;
  align-items:center;
  gap:.5rem;
  position:relative;
}

/* ========= MOBILE / TABLET ANPASSUNGEN ========= */
@media (max-width: 979px){
  /* Safe-area oben (Notch) berücksichtigen */
  .nav__inner{
    padding: calc(.8rem + env(safe-area-inset-top, 0px)) 1rem .8rem;
  }

  /* Offcanvas-Menü bleibt wie definiert; Liste vertikal */
  .nav__menu ul{ flex-direction:column; gap:.2rem }

  /* 🔎 Lupe immer sichtbar rechts oben in der Leiste */
  .nav__search-toggle{
    position:absolute;           /* Klasse kommt aus search.css, hier nur Positionierung */
    right: 1rem;
    top: calc(.8rem + env(safe-area-inset-top, 0px));
    z-index: 1100;
  }

  /* Verhindert Überdeckung der Lupe durch das Offcanvas */
  .nav__menu{ z-index: 1001; }
}

/* Extrem kleine Phones: etwas Luft zu den Rändern */
@media (max-width: 480px){
  .nav__inner{ padding-right: max(1rem, env(safe-area-inset-right, 0px)); }
}
/* === Buttons ========================================================== */
.btn{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  gap:.5rem;
  padding:.6em 1.2em;
  border-radius:10px;
  font-weight:600;
  text-decoration:none;
  line-height:1;
  border:1px solid transparent;
  cursor:pointer;
  transition:transform .15s ease, background .2s ease, color .2s ease, border-color .2s ease, box-shadow .2s ease;
  box-shadow: var(--ring);
  color: var(--text);
  background: rgba(255,255,255,0.04);
}

.btn:hover{ transform: translateY(-1px); }
.btn:active{ transform: translateY(0); }
.btn:focus-visible{
  outline:2px solid var(--violett);
  outline-offset:2px;
  box-shadow: var(--glow);
}

/* Primär (Violett) – für Login */
.btn--primary{
  background: var(--violett);
  color:#fff;
  border-color: rgba(122,60,255,0.55);
}
.btn--primary:hover{
  background: #5f2fbd; /* dunkleres Violett */
}
.btn--primary:active{
  background: #4f289c;
}

/* Ghost / Umriss (Violett) – für Registrieren */
.btn--ghost{
  background: transparent;
  color: var(--violett);
  border-color: var(--violett);
}
.btn--ghost:hover{
  background: rgba(122,60,255,0.10);
  box-shadow: var(--glow);
}

/* Größen & Helfer */
.btn--sm{ padding:.45em .9em; border-radius:8px; font-weight:600; }
.btn--lg{ padding:.75em 1.4em; font-size:1.05rem; }
.btn + .btn{ margin-left:.6rem; }        /* Abstand zwischen Buttons */
.btn--full{ width:100%; }                /* volle Breite auf Wunsch */

/* Optional: Buttons in Cards mittig */
.card .btn{ box-shadow: var(--ring); }


/* Mail-Links & Links in Cards in Violett */
.card a,
a.link-mail{
  color: var(--violett);
  text-decoration: none;
  font-weight: 600;
}
.card a:hover,
a.link-mail:hover{
  text-shadow: var(--glow);
}
