:root{
  --bg:#0f1020; --panel:#1a1b34; --panel2:#22244a; --txt:#eef0ff; --muted:#9aa0c7;
  --pink:#ff5e8a; --pink2:#ff8fb0; --violet:#7c5cff; --ok:#37d39b; --line:#2c2e57;
  --radius:16px; --shadow:0 10px 30px rgba(0,0,0,.35);
}
*{box-sizing:border-box} html,body{margin:0;height:100%}
body{font-family:'Segoe UI',system-ui,-apple-system,Roboto,Arial,sans-serif;
  background:radial-gradient(1200px 600px at 80% -10%,#2a1d4a,transparent),
             radial-gradient(900px 500px at -10% 110%,#3a1430,transparent),var(--bg);
  color:var(--txt)}
a{color:var(--pink2)}
.hidden{display:none!important}
button{font:inherit;cursor:pointer;border:0;border-radius:12px;padding:11px 16px;
  background:linear-gradient(135deg,var(--pink),var(--violet));color:#fff;font-weight:600;transition:.15s}
button:hover{filter:brightness(1.08)} button:active{transform:translateY(1px)}
button.ghost{background:var(--panel2);color:var(--txt)}
button.danger{background:#3a2230;color:#ff9fb6}
button.ok{background:linear-gradient(135deg,var(--ok),#1aa3ff)}
input,select,textarea{width:100%;background:var(--panel2);border:1px solid var(--line);
  color:var(--txt);border-radius:12px;padding:11px 12px;font:inherit;outline:none}
input:focus,select:focus,textarea:focus{border-color:var(--violet)}
label{display:block;font-size:13px;color:var(--muted);margin:0 0 5px}
textarea{min-height:90px;resize:vertical}
.field{margin-bottom:12px}
.row{display:flex;gap:12px;flex-wrap:wrap} .row>*{flex:1;min-width:120px}

/* top bar */
header{position:sticky;top:0;z-index:20;display:flex;align-items:center;gap:14px;
  padding:12px 20px;background:rgba(15,16,32,.82);backdrop-filter:blur(10px);border-bottom:1px solid var(--line)}
.brand{display:flex;align-items:center;gap:10px;white-space:nowrap}
.brand-logo{width:34px;height:34px;flex:none}
.brand-txt{font-weight:800;font-size:20px;background:linear-gradient(135deg,var(--pink2),var(--violet));
  -webkit-background-clip:text;background-clip:text;color:transparent}
.brand small{display:block;font-size:11px;color:var(--muted);font-weight:500;-webkit-text-fill-color:var(--muted)}
nav{display:flex;gap:6px;margin-left:auto;flex-wrap:wrap}
nav button{background:transparent;color:var(--muted);padding:8px 12px}
nav button.active{background:var(--panel2);color:var(--txt)}
.langsel{background:var(--panel2);color:var(--txt);border:1px solid var(--line);padding:8px;border-radius:10px;width:auto;min-width:120px}

main{max-width:1000px;margin:24px auto;padding:0 16px}
.card{background:var(--panel);border:1px solid var(--line);border-radius:var(--radius);
  padding:20px;box-shadow:var(--shadow);margin-bottom:18px}
h2{margin:.1em 0 .6em} h3{margin:.2em 0}
.muted{color:var(--muted)} .center{text-align:center}

/* auth */
.auth-wrap{max-width:420px;margin:6vh auto}
.hero{text-align:center;margin-bottom:18px}
.hero .big{font-size:30px;font-weight:800}
.tabs{display:flex;gap:8px;margin-bottom:14px}
.tabs button{flex:1;background:var(--panel2);color:var(--muted)}
.tabs button.active{background:linear-gradient(135deg,var(--pink),var(--violet));color:#fff}

/* grid of profiles */
.grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(210px,1fr));gap:16px}
.profile-card{background:var(--panel);border:1px solid var(--line);border-radius:var(--radius);
  overflow:hidden;display:flex;flex-direction:column;transition:.15s}
.profile-card:hover{transform:translateY(-3px);border-color:var(--violet)}
.avatar{height:180px;background:linear-gradient(135deg,#33264f,#22244a);display:flex;
  align-items:center;justify-content:center;font-size:54px;color:var(--muted)}
.avatar img{width:100%;height:100%;object-fit:cover}
.profile-card .body{padding:12px 14px;flex:1;display:flex;flex-direction:column;gap:6px}
.profile-card .name{font-weight:700;font-size:17px}
.chip{display:inline-block;background:var(--panel2);border:1px solid var(--line);
  border-radius:999px;padding:3px 10px;font-size:12px;color:var(--muted);margin:2px 3px 0 0}

.filters{display:grid;grid-template-columns:repeat(auto-fit,minmax(120px,1fr));gap:10px;align-items:end}

/* messages */
.msg-layout{display:grid;grid-template-columns:280px 1fr;gap:16px;min-height:60vh}
@media(max-width:720px){.msg-layout{grid-template-columns:1fr}}
.conv{padding:11px 13px;border-radius:12px;cursor:pointer;display:flex;gap:10px;align-items:center}
.conv:hover,.conv.active{background:var(--panel2)}
.conv .mini{width:40px;height:40px;border-radius:50%;background:var(--panel2);overflow:hidden;flex:none;
  display:flex;align-items:center;justify-content:center}
.conv .mini img{width:100%;height:100%;object-fit:cover}
.badge{background:var(--pink);color:#fff;border-radius:999px;font-size:11px;padding:1px 7px;margin-left:auto}
.chat{display:flex;flex-direction:column;height:62vh}
.chat-head{display:flex;gap:10px;align-items:center;padding-bottom:10px;border-bottom:1px solid var(--line);margin-bottom:10px}
.bubbles{flex:1;overflow-y:auto;display:flex;flex-direction:column;gap:8px;padding:4px}
.bubble{max-width:75%;padding:9px 13px;border-radius:14px;background:var(--panel2);line-height:1.35}
.bubble.me{align-self:flex-end;background:linear-gradient(135deg,var(--pink),var(--violet))}
.bubble small{display:block;font-size:10px;opacity:.6;margin-top:3px}
.composer{display:flex;gap:8px;margin-top:10px}
.composer input{flex:1}

.notice{background:var(--panel2);border:1px solid var(--line);border-radius:12px;padding:12px;color:var(--muted);font-size:14px}
.success{border-color:var(--ok);color:#bff4df}
.banner{padding:14px;border-radius:14px;background:linear-gradient(135deg,rgba(124,92,255,.25),rgba(255,94,138,.25));
  border:1px solid var(--violet);margin-bottom:14px}
.kv{display:flex;justify-content:space-between;padding:8px 0;border-bottom:1px solid var(--line)}
.kv:last-child{border:0}
.toast{position:fixed;bottom:20px;left:50%;transform:translateX(-50%);background:var(--ok);color:#04231a;
  padding:12px 20px;border-radius:12px;font-weight:600;box-shadow:var(--shadow);z-index:50}
.spinner{text-align:center;color:var(--muted);padding:40px}

/* Footer & Rechtstexte */
.site-footer{max-width:1000px;margin:30px auto 24px;padding:18px 16px 0;border-top:1px solid var(--line);
  display:flex;gap:18px;align-items:center;flex-wrap:wrap;color:var(--muted);font-size:13px}
.linklike{background:none;border:0;padding:0;color:var(--muted);font:inherit;cursor:pointer;text-decoration:none}
.linklike:hover{color:var(--pink2);filter:none}
.legal{line-height:1.6}
.legal h1{font-size:24px;margin:.2em 0 .6em}
.legal h2{font-size:18px;margin:1.1em 0 .4em;color:#cfd3f5}
.legal h3{font-size:15px;margin:.9em 0 .3em;color:#cfd3f5}
.legal p,.legal li{color:#d6d9f3}
.legal a{color:var(--pink2)}
.legal .ph{background:rgba(255,94,138,.14);border:1px dashed var(--pink);border-radius:6px;padding:0 5px}
.legal .note{background:var(--panel2);border:1px solid var(--line);border-radius:10px;padding:10px 12px;color:var(--muted);font-size:13px}

/* Sprachfunktionen */
.composer .mic{flex:none;font-size:18px;line-height:1;padding:0 12px}
.composer .mic.rec{background:linear-gradient(135deg,var(--pink),var(--violet));color:#fff}
.bubble{display:flex;align-items:center;gap:6px}
.bubble .btext{flex:1}
.bubble .say{flex:none;background:none;border:0;padding:0 2px;cursor:pointer;font-size:14px;opacity:.7;color:inherit;filter:none}
.bubble .say:hover{opacity:1}
.bubble small{flex:none}

/* Cookie-Hinweis */
.cookie-banner{position:fixed;left:0;right:0;bottom:0;z-index:60;display:flex;gap:14px;align-items:center;
  justify-content:center;flex-wrap:wrap;background:rgba(26,27,52,.98);border-top:1px solid var(--line);
  padding:12px 18px;color:var(--txt);font-size:14px;box-shadow:0 -6px 22px rgba(0,0,0,.35)}
.cookie-banner a{color:var(--pink2)}
.cookie-banner button{padding:9px 20px;flex:none}

/* Startseite / Landing */
.landing{max-width:980px;margin:24px auto;padding:0 16px}
.landing-top{display:grid;grid-template-columns:1.1fr .9fr;gap:26px;align-items:start}
@media(max-width:780px){.landing-top{grid-template-columns:1fr}}
.couple{border-radius:20px;overflow:hidden;box-shadow:var(--shadow);line-height:0}
.couple svg{width:100%;height:auto;display:block}
.landing-title{font-size:34px;margin:16px 0 2px;font-weight:800;
  background:linear-gradient(135deg,var(--pink2),var(--violet));-webkit-background-clip:text;background-clip:text;color:transparent}
.landing-tag{margin:0 0 12px;font-size:15px}
.landing-intro{color:#d6d9f3;line-height:1.6;margin:0}
.steps{margin-top:32px}
.steps-title{text-align:center;font-size:21px;margin:0 0 18px}
.steps-row{display:grid;grid-template-columns:repeat(3,1fr);gap:16px}
@media(max-width:780px){.steps-row{grid-template-columns:1fr}}
.step{background:var(--panel);border:1px solid var(--line);border-radius:16px;padding:18px;display:flex;gap:14px;align-items:flex-start}
.step-num{flex:none;width:38px;height:38px;border-radius:50%;display:flex;align-items:center;justify-content:center;
  font-weight:800;color:#fff;background:linear-gradient(135deg,var(--pink),var(--violet))}
.step b{font-size:15px}
.step p{margin:4px 0 0;font-size:14px;line-height:1.45}
.videos{margin-top:32px}
.videos-row{display:grid;grid-template-columns:repeat(2,1fr);gap:16px}
@media(max-width:780px){.videos-row{grid-template-columns:1fr}}
.vid{width:100%;aspect-ratio:16/9;background:#000;border:1px solid var(--line);border-radius:14px;box-shadow:var(--shadow)}
