192 lines
4.8 KiB
CSS
192 lines
4.8 KiB
CSS
/* =================================================================================
|
|
GLOBALE STYLING-GRUNDLAGE (THEME & UTILITIES)
|
|
================================================================================== */
|
|
/* @import url("https://fonts.googleapis.com/css2?family=Roboto:wght@300;400;500;700;900&display=swap"); */
|
|
|
|
/* =================================================================================
|
|
* 1. CSS-VARIABLEN (DESIGN TOKENS)
|
|
* Dies ist die einzige Quelle der Wahrheit für Ihr Design.
|
|
* ================================================================================= */
|
|
:root {
|
|
/* Farbpalette */
|
|
--color-primary-gradient: linear-gradient(135deg, #3498db, #2980b9);
|
|
--color-primary: #3498db;
|
|
--color-primary-dark: #2980b9;
|
|
--color-danger: #e74c3c;
|
|
--color-success: #27ae60;
|
|
--color-warning: #f39c12;
|
|
|
|
/* Neutrale Farben (Light Mode) */
|
|
--color-text: #2c3e50;
|
|
--color-text-light: #7f8c8d;
|
|
--color-body-bg: rgb(243, 243, 243);
|
|
--color-body-bg-lighter: #ffffff;
|
|
--color-body-bg-active: rgb(238, 238, 240);
|
|
--color-body-bg-hover: #f2f3f5;
|
|
--color-surface: #ffffff;
|
|
--color-border: #e0e6ed;
|
|
|
|
/* Typografie */
|
|
--font-family-base: "Roboto", -apple-system, BlinkMacSystemFont, "Segoe UI",
|
|
sans-serif;
|
|
--font-size-base: 16px;
|
|
--line-height-base: 1.6;
|
|
|
|
/* Abstände, Kanten & Schatten */
|
|
--border-radius-sm: 4px;
|
|
--border-radius-md: 8px;
|
|
--box-shadow-sm: 0 2px 4px rgba(0, 0, 0, 0.05);
|
|
--box-shadow-md: 0 10px 15px -3px rgba(0, 0, 0, 0.1),
|
|
0 4px 6px -2px rgba(0, 0, 0, 0.05);
|
|
--transition-speed: 0.3s cubic-bezier(0.4, 0, 0.2, 1);
|
|
}
|
|
|
|
body.dark-theme {
|
|
/* Textfarben werden heller */
|
|
--color-text: #ecf0f1;
|
|
--color-text-light: #95a5a6;
|
|
|
|
/*
|
|
* Die Hierarchie der Hintergrundfarben wird umgekehrt:
|
|
* Was im Light Mode hell war, ist jetzt dunkel.
|
|
* Was leicht abgedunkelt war (hover, active), wird jetzt leicht aufgehellt.
|
|
*/
|
|
|
|
/* Der Hintergrund für den Body (am dunkelsten) */
|
|
--color-body-bg: #1a202c;
|
|
|
|
/* Der Hintergrund für Elemente, die darauf liegen (etwas heller) */
|
|
--color-surface: #2d3748;
|
|
|
|
/* NEU: Die "hellste" Hintergrundfarbe aus dem Light Mode wird zur dunkelsten */
|
|
--color-body-bg-lighter: #131720; /* Ein sehr dunkler Ton für besondere Fälle */
|
|
|
|
/* Die Hover-Farbe ist jetzt heller als der Standard-Hintergrund */
|
|
--color-body-bg-hover: #374151; /* ÜBERARBEITET für besseren Kontrast */
|
|
|
|
/* NEU: Die "active"-Farbe ist noch einen Schritt heller als die Hover-Farbe */
|
|
--color-body-bg-active: #4a5568;
|
|
|
|
/* Die Rahmenfarbe ist heller als die Oberfläche, um sichtbar zu sein */
|
|
--color-border: #4a5568;
|
|
}
|
|
|
|
/* =================================================================================
|
|
* 2. GLOBALER RESET UND BASIS-STILE
|
|
* ================================================================================= */
|
|
*,
|
|
*::before,
|
|
*::after {
|
|
box-sizing: border-box;
|
|
margin: 0;
|
|
padding: 0;
|
|
}
|
|
|
|
body {
|
|
font-family: var(--font-family-base);
|
|
font-size: var(--font-size-base);
|
|
line-height: var(--line-height-base);
|
|
color: var(--color-text);
|
|
background-color: var(--color-body-bg);
|
|
transition: background-color var(--transition-speed),
|
|
color var(--transition-speed);
|
|
}
|
|
|
|
body.no-scroll {
|
|
overflow: hidden;
|
|
}
|
|
|
|
/* -- Textausrichtung -- */
|
|
.text-right {
|
|
text-align: right !important;
|
|
}
|
|
.text-left {
|
|
text-align: left !important;
|
|
}
|
|
.text-center {
|
|
text-align: center !important;
|
|
}
|
|
|
|
.grid {
|
|
display: grid;
|
|
grid-template-columns: repeat(4, 1fr);
|
|
gap: 1.5rem;
|
|
}
|
|
|
|
main {
|
|
display: flex;
|
|
flex-direction: column;
|
|
/* padding: 1rem; */
|
|
gap: 1rem;
|
|
}
|
|
|
|
.grid-col-span-1 {
|
|
grid-column: span 1;
|
|
}
|
|
|
|
.grid-col-span-2 {
|
|
grid-column: span 2;
|
|
}
|
|
|
|
.grid-col-span-3 {
|
|
grid-column: span 3;
|
|
}
|
|
|
|
.grid-col-span-4 {
|
|
grid-column: span 4;
|
|
}
|
|
|
|
[data-tooltip] {
|
|
position: relative;
|
|
}
|
|
[data-tooltip]::after {
|
|
content: attr(data-tooltip);
|
|
position: absolute;
|
|
bottom: 100%;
|
|
left: 50%;
|
|
transform: translateX(-50%) translateY(-8px);
|
|
background-color: #2c3e50;
|
|
color: #fff;
|
|
padding: 0.25rem 0.75rem;
|
|
border-radius: var(--border-radius-sm);
|
|
font-size: 0.85rem;
|
|
font-weight: 500;
|
|
white-space: nowrap;
|
|
opacity: 0;
|
|
visibility: hidden;
|
|
pointer-events: none;
|
|
transition: opacity 0.2s ease-out, transform 0.2s ease-out;
|
|
}
|
|
[data-tooltip]:hover::after {
|
|
opacity: 1;
|
|
visibility: visible;
|
|
transform: translateX(-50%) translateY(-12px);
|
|
}
|
|
|
|
@media (max-width: 1200px) {
|
|
.grid {
|
|
grid-template-columns: repeat(2, 1fr);
|
|
}
|
|
}
|
|
@media (max-width: 768px) {
|
|
.grid {
|
|
grid-template-columns: 1fr;
|
|
}
|
|
}
|
|
|
|
/* ========================================================================================== */
|
|
/* ========================================================================================== */
|
|
|
|
.button-group {
|
|
display: flex;
|
|
align-items: center;
|
|
flex-wrap: wrap;
|
|
gap: 0.75rem;
|
|
}
|
|
|
|
.chip-set {
|
|
display: flex;
|
|
flex-wrap: wrap;
|
|
gap: 0.5rem;
|
|
}
|