feat(ui): Buttons im modernen Pill-Stil + Plus-Icon fixen
Großes Frontend-Update für alle Buttons. Der Stil orientiert sich an modernen App-Designs (Pill mit dezentem Schatten, sanft "abhebender" Hover-Effekt), die Farbe folgt der gewählten Primärfarbe des Users dynamisch via color-mix(). - .btn: fully rounded (border-radius: 999px), grösseres Padding, smooth Transitions für Schatten/Transform/Brightness - .btn-primary: Primärfarbe als Hintergrund + dezenter farbiger Schatten; Hover hebt um 1px, Schatten wird kräftiger, leichte Aufhellung - .btn-secondary: dezenter Border, auf Hover wird er primär-farben - .btn-ghost / .btn-danger entsprechend angepasst - .btn-fab (Sidebar "Erstellen"): jetzt in Primärfarbe statt grau, passt zum FAB unten rechts auf Mobile und zur Marken-Sprache - .icon-btn: kleines Scale-Down beim Drücken, Focus-Ring sichtbar für Tastatur-Nutzer - Form-Inputs: 8px Radius, sanfter Hover-Border, beim Focus jetzt Primärfarben-Ring (color-mix-Glow) Fix: kaputtes Plus-SVG am Kalender-Hinzufügen-Button — Vertikalbalken war zu lang (v12 statt v6), jetzt symmetrisch. Version v12 → v13.
This commit is contained in:
@@ -55,49 +55,129 @@ a { color: var(--primary); text-decoration: none; }
|
||||
.flex-col { display: flex; flex-direction: column; }
|
||||
.gap-8 { gap: 8px; }
|
||||
|
||||
/* ── Buttons ────────────────────────────────────────────── */
|
||||
/* ── Buttons ──────────────────────────────────────────────
|
||||
Modern pill style: fully rounded, subtle coloured shadow on the
|
||||
prominent variants, lift on hover, snap back on press. The
|
||||
primary-coloured glow follows --primary via color-mix(), so it adapts
|
||||
when the user changes the theme colour in settings. */
|
||||
.btn {
|
||||
display: inline-flex; align-items: center; gap: 6px;
|
||||
padding: 8px 16px; border-radius: 20px;
|
||||
font-weight: 500; transition: background var(--transition), color var(--transition);
|
||||
display: inline-flex; align-items: center; justify-content: center;
|
||||
gap: 8px;
|
||||
padding: 10px 22px;
|
||||
border-radius: 999px;
|
||||
font-weight: 500; font-size: 14px;
|
||||
letter-spacing: .1px;
|
||||
white-space: nowrap;
|
||||
user-select: none;
|
||||
-webkit-tap-highlight-color: transparent;
|
||||
transition:
|
||||
background var(--transition),
|
||||
color var(--transition),
|
||||
border-color var(--transition),
|
||||
box-shadow .18s ease,
|
||||
transform .12s ease,
|
||||
filter var(--transition);
|
||||
}
|
||||
.btn:active { transform: translateY(0) scale(.985); transition-duration: .05s; }
|
||||
.btn:focus-visible {
|
||||
outline: 2px solid var(--primary);
|
||||
outline-offset: 2px;
|
||||
}
|
||||
|
||||
.btn-primary {
|
||||
background: var(--primary);
|
||||
color: #fff;
|
||||
box-shadow: 0 2px 8px rgba(66,133,244,.28);
|
||||
box-shadow: 0 2px 8px color-mix(in srgb, var(--primary) 30%, transparent);
|
||||
}
|
||||
.btn-primary:hover { filter: brightness(1.12); }
|
||||
.btn-primary:hover {
|
||||
filter: brightness(1.08);
|
||||
transform: translateY(-1px);
|
||||
box-shadow: 0 6px 18px rgba(66,133,244,.42);
|
||||
box-shadow: 0 6px 18px color-mix(in srgb, var(--primary) 45%, transparent);
|
||||
}
|
||||
|
||||
.btn-secondary {
|
||||
background: var(--bg-surface);
|
||||
color: var(--text-1);
|
||||
border: 1px solid var(--border);
|
||||
}
|
||||
.btn-secondary:hover { background: var(--bg-hover); }
|
||||
.btn-ghost { color: var(--primary); }
|
||||
.btn-ghost:hover { background: var(--primary-dim); }
|
||||
.btn-danger { background: var(--accent); color: #fff; }
|
||||
.btn-danger:hover { filter: brightness(1.1); }
|
||||
.btn-full { width: 100%; justify-content: center; }
|
||||
.btn-secondary:hover {
|
||||
background: var(--bg-hover);
|
||||
border-color: var(--primary);
|
||||
transform: translateY(-1px);
|
||||
}
|
||||
|
||||
.btn-ghost {
|
||||
color: var(--primary);
|
||||
background: transparent;
|
||||
}
|
||||
.btn-ghost:hover {
|
||||
background: var(--primary-dim);
|
||||
transform: translateY(-1px);
|
||||
}
|
||||
|
||||
.btn-danger {
|
||||
background: var(--accent);
|
||||
color: #fff;
|
||||
box-shadow: 0 2px 8px rgba(234,67,53,.28);
|
||||
box-shadow: 0 2px 8px color-mix(in srgb, var(--accent) 30%, transparent);
|
||||
}
|
||||
.btn-danger:hover {
|
||||
filter: brightness(1.08);
|
||||
transform: translateY(-1px);
|
||||
box-shadow: 0 6px 18px rgba(234,67,53,.42);
|
||||
box-shadow: 0 6px 18px color-mix(in srgb, var(--accent) 45%, transparent);
|
||||
}
|
||||
|
||||
.btn-full { width: 100%; }
|
||||
|
||||
/* The big sidebar "Erstellen" button: same pill aesthetic, primary tinted,
|
||||
lives in the calm dark sidebar so the shadow is a touch stronger. */
|
||||
.btn-fab {
|
||||
display: flex; align-items: center; gap: 10px;
|
||||
padding: 12px 20px; border-radius: 24px;
|
||||
background: var(--bg-surface);
|
||||
color: var(--text-1);
|
||||
padding: 12px 22px;
|
||||
border-radius: 999px;
|
||||
background: var(--primary);
|
||||
color: #fff;
|
||||
font-weight: 600;
|
||||
box-shadow: var(--shadow);
|
||||
margin: 16px 12px 8px;
|
||||
transition: background var(--transition), box-shadow var(--transition);
|
||||
box-shadow: 0 4px 14px rgba(66,133,244,.32);
|
||||
box-shadow: 0 4px 14px color-mix(in srgb, var(--primary) 35%, transparent);
|
||||
transition:
|
||||
background var(--transition),
|
||||
box-shadow .18s ease,
|
||||
transform .12s ease,
|
||||
filter var(--transition);
|
||||
}
|
||||
.btn-fab:hover { background: var(--bg-hover); box-shadow: var(--shadow-lg); }
|
||||
.btn-fab:hover {
|
||||
filter: brightness(1.08);
|
||||
transform: translateY(-1px);
|
||||
box-shadow: 0 8px 22px rgba(66,133,244,.5);
|
||||
box-shadow: 0 8px 22px color-mix(in srgb, var(--primary) 50%, transparent);
|
||||
}
|
||||
.btn-fab:active { transform: translateY(0) scale(.985); }
|
||||
|
||||
/* Circular icon buttons (topbar nav, modal close, etc.) */
|
||||
.icon-btn {
|
||||
display: inline-flex; align-items: center; justify-content: center;
|
||||
width: 40px; height: 40px; border-radius: 50%;
|
||||
color: var(--text-2); transition: background var(--transition);
|
||||
width: 40px; height: 40px;
|
||||
border-radius: 50%;
|
||||
color: var(--text-2);
|
||||
flex-shrink: 0;
|
||||
-webkit-tap-highlight-color: transparent;
|
||||
transition:
|
||||
background var(--transition),
|
||||
color var(--transition),
|
||||
transform .1s ease;
|
||||
}
|
||||
.icon-btn svg { width: 20px; height: 20px; fill: currentColor; }
|
||||
.icon-btn:hover { background: var(--bg-hover); color: var(--text-1); }
|
||||
.icon-btn:active { transform: scale(.92); }
|
||||
.icon-btn:focus-visible {
|
||||
outline: 2px solid var(--primary);
|
||||
outline-offset: 2px;
|
||||
}
|
||||
|
||||
/* ── Auth Screens ───────────────────────────────────────── */
|
||||
.auth-screen {
|
||||
@@ -140,15 +220,22 @@ a { color: var(--primary); text-decoration: none; }
|
||||
.form-group input, .form-group select, .form-group textarea {
|
||||
background: var(--bg-app);
|
||||
border: 1px solid var(--border);
|
||||
border-radius: var(--radius-sm);
|
||||
padding: 10px 12px;
|
||||
border-radius: 8px;
|
||||
padding: 11px 14px;
|
||||
color: var(--text-1);
|
||||
outline: none;
|
||||
transition: border-color var(--transition);
|
||||
transition: border-color var(--transition), box-shadow var(--transition);
|
||||
width: 100%;
|
||||
}
|
||||
.form-group input:hover:not(:focus),
|
||||
.form-group select:hover:not(:focus),
|
||||
.form-group textarea:hover:not(:focus) {
|
||||
border-color: var(--text-3);
|
||||
}
|
||||
.form-group input:focus, .form-group select:focus, .form-group textarea:focus {
|
||||
border-color: var(--primary);
|
||||
box-shadow: 0 0 0 3px rgba(66,133,244,.18);
|
||||
box-shadow: 0 0 0 3px color-mix(in srgb, var(--primary) 18%, transparent);
|
||||
}
|
||||
.form-group textarea { resize: vertical; }
|
||||
|
||||
|
||||
Reference in New Issue
Block a user