/* --- GLOBAL --- */
:root {
    --neon-pink: #ff00ff;
    --neon-cyan: #00ffff;
    --neon-purple: #bc13fe;
    --neon-green: #39ff14;
    --glass-bg: rgba(16, 18, 27, 0.75); /* Etwas dunkler für Lesbarkeit */
    --glass-border: rgba(255, 255, 255, 0.15);
}

body {
    font-family: 'Chakra Petch', sans-serif;
    text-shadow: 0 0 2px rgba(0,0,0,0.8);
    background-attachment: fixed; /* Hintergrund fixieren */
}

/* --- SERVICE CARDS & WIDGET CARDS (Gemeinsame Basis) --- */
.service-card, .widget-card, .bookmark-card {
    background: var(--glass-bg) !important;
    backdrop-filter: blur(16px) saturate(140%);
    -webkit-backdrop-filter: blur(16px) saturate(140%);
    border: 1px solid var(--glass-border);
    border-radius: 12px;
    box-shadow: 0 4px 30px rgba(0, 0, 0, 0.6);
    transition: all 0.3s cubic-bezier(0.25, 0.8, 0.25, 1);
    overflow: hidden;
    position: relative;
}

/* Hover Effekt für ALLE Karten */
.service-card:hover, .widget-card:hover, .bookmark-card:hover {
    transform: translateY(-4px) scale(1.01);
    box-shadow: 
        0 0 20px rgba(0, 255, 255, 0.4),
        inset 0 0 20px rgba(0, 255, 255, 0.1);
    border-color: var(--neon-cyan);
    z-index: 10;
}

/* "Scanline" Effekt über ALLE Karten */
.service-card::after, .widget-card::after {
    content: "";
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    background: repeating-linear-gradient(
        0deg,
        transparent,
        transparent 2px,
        rgba(0, 0, 0, 0.3) 3px
    );
    pointer-events: none;
    opacity: 0.4;
    z-index: 2;
}

/* --- WIDGET SPECIFICS (Inhalte in den Widgets) --- */

/* Textfarben in Widgets anpassen */
.widget-card .text-neutral-400 { color: #aaa !important; } /* Label */
.widget-card .text-neutral-200 { color: #fff !important; text-shadow: 0 0 5px var(--neon-cyan); } /* Werte */

/* Graphen/Charts in Widgets (z.B. CPU History) */
.recharts-surface {
    filter: drop-shadow(0 0 2px var(--neon-purple));
    opacity: 0.9;
}

/* Progress Bars (z.B. Disk Usage) */
.progress-bar {
    background-color: rgba(255, 255, 255, 0.1) !important;
}
.progress-bar-fill {
    background: linear-gradient(90deg, var(--neon-purple), var(--neon-pink)) !important;
    box-shadow: 0 0 10px var(--neon-pink);
}

/* Status Indikatoren (Punkt grün/rot) */
.status-dot {
    box-shadow: 0 0 8px currentColor;
}
.status-dot.bg-green-500 { background-color: var(--neon-green) !important; color: var(--neon-green) !important; }
.status-dot.bg-red-500 { background-color: var(--neon-pink) !important; color: var(--neon-pink) !important; }

/* --- SERVICE ICONS & TEXT --- */
.service-name {
    color: #fff;
    text-transform: uppercase;
    letter-spacing: 1px;
    font-weight: 700;
    text-shadow: 0 0 8px var(--neon-purple);
}

.service-description {
    color: #ddd;
    font-size: 0.8em;
    font-style: italic;
    opacity: 0.8;
}

.service-icon img {
    filter: drop-shadow(0 0 5px var(--neon-pink));
    transition: transform 0.3s ease, filter 0.3s ease;
}

.service-card:hover .service-icon img {
    filter: drop-shadow(0 0 15px var(--neon-pink));
    transform: scale(1.1);
}

/* --- HEADERS --- */
h2, .group-title {
    color: var(--neon-cyan) !important;
    font-family: 'Chakra Petch', sans-serif;
    text-transform: uppercase;
    letter-spacing: 3px;
    text-shadow: 
        0 0 5px var(--neon-cyan),
        0 0 10px var(--neon-cyan),
        0 0 20px var(--neon-cyan);
    border-bottom: 2px solid var(--neon-pink);
    box-shadow: 0 10px 10px -10px var(--neon-pink);
    display: inline-block;
    padding: 5px 15px;
    margin-bottom: 20px;
    border-radius: 4px;
}

/* --- SEARCH BAR --- */
input[type="text"] {
    background: rgba(0, 0, 0, 0.8) !important;
    border: 1px solid var(--neon-purple) !important;
    color: var(--neon-cyan) !important;
    border-radius: 4px; /* Techy eckig */
    box-shadow: 0 0 15px rgba(188, 19, 254, 0.3);
    text-align: center;
    font-family: 'Chakra Petch', sans-serif;
    text-transform: uppercase;
    transition: all 0.2s ease;
}

input[type="text"]:focus {
    outline: none;
    box-shadow: 0 0 25px var(--neon-pink);
    border-color: var(--neon-pink) !important;
    background: rgba(0, 0, 0, 0.95) !important;
}


/* --- METHODE: INHALTS-BASIERTES STYLING --- */

/* 1. GREETING (Erkennbar an text-xl oder text-4xl) */
/* Wir suchen irgendein Element mit Klasse text-xl INNERHALB von widget-container */
.widget-container .text-xl, 
.widget-container .text-4xl {
    font-family: 'Chakra Petch', sans-serif !important;
    color: var(--neon-cyan) !important;
    text-shadow: 0 0 10px var(--neon-cyan), 0 0 20px var(--neon-purple) !important;
    font-weight: 800 !important;
    letter-spacing: 2px !important;
    text-transform: uppercase !important;
}

/* 2. DATUM (Erkennbar an text-md oder text-lg) */
.widget-container .text-md,
.widget-container .text-lg {
    font-family: 'Chakra Petch', sans-serif !important;
    color: #fff !important;
    text-shadow: 0 0 8px var(--neon-pink) !important;
    font-weight: 500 !important;
}

/* 3. WETTER (Erkennbar am Icon/SVG) */
/* Wir färben einfach ALLE SVGs in Widget-Containern grün */
/* (Service-Icons sind meist Bilder <img>, keine SVGs, daher sicher) */
.widget-container svg {
    color: var(--neon-green) !important;
    filter: drop-shadow(0 0 5px var(--neon-green)) !important;
}

.widget-container svg + span { /* Text direkt nach Icon (Temp) */
    color: var(--neon-green) !important;
    text-shadow: 0 0 5px var(--neon-green) !important;
}
