/* ================================================================================= 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; }