feat: Demo-Logbuch und Onboarding-Tour bei Registrierung

Neue Nutzer erhalten automatisch ein Demo-Logbuch mit drei Ostsee-Reisetagen
und eine interaktive App-Tour; die Tour kann in den Einstellungen erneut gestartet werden.

Co-authored-by: Cursor <cursoragent@cursor.com>
This commit is contained in:
2026-05-29 17:59:02 +02:00
parent 646d316a36
commit 0da855381d
20 changed files with 5549 additions and 23 deletions
+130
View File
@@ -2548,4 +2548,134 @@ html.theme-cupertino .events-scroll-container {
text-decoration: underline;
}
.demo-badge {
display: inline-flex;
align-items: center;
padding: 2px 8px;
border-radius: 999px;
font-size: 11px;
font-weight: 600;
letter-spacing: 0.02em;
text-transform: uppercase;
color: #fbbf24;
background: rgba(251, 191, 36, 0.12);
border: 1px solid rgba(251, 191, 36, 0.25);
}
.app-tour-root {
position: fixed;
inset: 0;
z-index: 10000;
pointer-events: none;
}
.app-tour-backdrop {
position: absolute;
inset: 0;
background: rgba(2, 6, 23, 0.72);
pointer-events: auto;
}
.app-tour-spotlight {
position: fixed;
border-radius: 12px;
box-shadow: 0 0 0 9999px rgba(2, 6, 23, 0.72);
border: 2px solid rgba(56, 189, 248, 0.85);
pointer-events: none;
z-index: 10001;
}
.app-tour-tooltip {
position: fixed;
z-index: 10002;
width: min(420px, calc(100vw - 32px));
padding: 20px 20px 16px;
border-radius: 16px;
background: rgba(15, 23, 42, 0.96);
border: 1px solid rgba(148, 163, 184, 0.25);
box-shadow: 0 20px 50px rgba(0, 0, 0, 0.45);
pointer-events: auto;
}
.app-tour-tooltip.centered {
top: 50%;
left: 50%;
transform: translate(-50%, -50%);
}
.app-tour-close {
position: absolute;
top: 12px;
right: 12px;
display: inline-flex;
align-items: center;
justify-content: center;
width: 32px;
height: 32px;
border: none;
border-radius: 8px;
background: transparent;
color: #94a3b8;
cursor: pointer;
}
.app-tour-close:hover {
background: rgba(148, 163, 184, 0.12);
color: #e2e8f0;
}
.app-tour-progress {
margin: 0 0 8px;
font-size: 12px;
color: #64748b;
text-transform: uppercase;
letter-spacing: 0.04em;
}
.app-tour-title {
margin: 0 0 8px;
font-size: 20px;
color: #f8fafc;
}
.app-tour-body {
margin: 0 0 16px;
font-size: 14px;
line-height: 1.55;
color: #cbd5e1;
}
.app-tour-actions {
display: flex;
align-items: center;
justify-content: space-between;
gap: 12px;
}
.app-tour-link {
border: none;
background: transparent;
color: #94a3b8;
font-size: 13px;
cursor: pointer;
padding: 0;
}
.app-tour-link:hover {
color: #e2e8f0;
}
.app-tour-nav {
display: flex;
gap: 8px;
margin-left: auto;
}
.app-tour-nav-btn {
width: auto;
padding: 8px 14px;
display: inline-flex;
align-items: center;
gap: 6px;
}