/* ==================== DASHBOARD V5 - KOMPLETT ÜBERARBEITET ==================== */
/* Mobile First Design | Strukturiert | Optimiert | Ansprechend */

/* ==================== CSS VARIABLES ==================== */
/*
 * Import der globalen Variablen für Farben, Abstände und Typografie. Die
 * Dashboard-spezifischen Variablennamen werden auf die globalen Werte gemappt,
 * sodass das Dashboard einheitlich mit dem Rest der Anwendung wirkt.
 */
@import url('variables.css');

:root {
    /* Farben für Diagramme und Highlights: blau, grün, orange, violett
       werden explizit auf separate Variablen gemappt, um deutliche
       Unterscheidung zu gewährleisten. */
    --blue: var(--color-blue);
    --green: var(--color-primary);
    --orange: var(--color-accent);
    --purple: var(--color-purple);
    --red: var(--color-error);

    /* Helle Varianten (falls im Dashboard genutzt) */
    --blue-light: var(--color-blue-light);
    --green-light: var(--color-green-light);
    --orange-light: #FFF5D9; /* helle Variante der Akzentfarbe */
    --purple-light: var(--color-purple-light);

    /* Neutrale Graustufen: nutzen die globalen Border- und Textfarben als Basispunkte */
    --gray-50: var(--color-background);
    --gray-100: var(--color-background);
    --gray-200: var(--color-surface);
    --gray-300: var(--color-border);
    --gray-400: var(--color-border);
    --gray-500: var(--color-text-secondary);
    --gray-600: var(--color-text-secondary);
    --gray-700: var(--color-text-primary);
    --gray-800: var(--color-text-primary);
    --gray-900: var(--color-text-primary);

    /* Textfarben */
    --text-primary: var(--color-text-primary);
    --text-secondary: var(--color-text-secondary);
    --text-light: var(--color-text-secondary);

    /* Spacing - Alias auf globale Abstände */
    --space-xs: var(--spacing-xs);
    --space-sm: calc(var(--spacing-sm) * 0.75);
    --space-md: var(--spacing-sm);
    --space-lg: var(--spacing-md);
    --space-xl: var(--spacing-lg);
    --space-2xl: var(--spacing-xl);

    /* Border Radius - Alias */
    --radius-sm: var(--radius-sm);
    --radius-md: var(--radius-md);
    --radius-lg: var(--radius-lg);
    --radius-xl: var(--radius-lg);

    /* Schatten - verwenden globale Schattenvariablen */
    --shadow-sm: var(--shadow-sm);
    --shadow-md: var(--shadow-md);
    --shadow-lg: var(--shadow-lg);
    --shadow-xl: var(--shadow-lg);

    /* Transitionen basieren auf einer einheitlichen Dauer */
    --transition-fast: calc(var(--transition-duration) / 2);
    --transition-base: var(--transition-duration);
    --transition-slow: calc(var(--transition-duration) + 0.1s);
}

/* ==================== BASE STYLES ==================== */
* {
    margin: 0;
    padding: 0;
    box-sizing: border-box;
}

body {
    font-family: var(--font-family-base);
    color: var(--text-primary);
    background: var(--gray-100);
    line-height: 1.6;
    -webkit-font-smoothing: antialiased;
    -moz-osx-font-smoothing: grayscale;
}

/* ==================== CONTAINER ==================== */
.dashboard-container {
    width: 100%;
    max-width: 1400px;
    margin: 0 auto;
    padding: var(--space-md);
}

/* Benachrichtigungsleiste oben im Dashboard */
/* Wrapper: enthält alle Alerts, zeigt aber immer nur einen */
.notification-carousel {
    margin-top: calc(var(--space-md) * -3);
    margin-bottom: var(--space-lg);
}

.dashboard-notification {
    display: flex;
    align-items: center;
    gap: var(--space-md);
    background: var(--color-blue-light);
    color: var(--text-primary);
    border-radius: var(--radius-lg);
    padding: var(--space-md) var(--space-lg) var(--space-md) calc(var(--space-lg) + var(--space-xs));
    border: 1px solid rgba(74, 144, 226, 0.2);
    box-shadow: 0 2px 10px rgba(74, 144, 226, 0.1);
    position: relative;
    overflow: hidden;
}

/* Akzentstreifen links (absolut, kein Flex-Item) */
.dashboard-notification::after {
    content: '';
    position: absolute;
    left: 0;
    top: 0;
    bottom: 0;
    width: 4px;
    background: var(--color-blue);
    border-radius: var(--radius-lg) 0 0 var(--radius-lg);
}

/* Icon-Kreis (erstes Flex-Item via ::before) */
.dashboard-notification::before {
    content: 'i';
    flex-shrink: 0;
    width: 32px;
    height: 32px;
    background: var(--color-blue);
    color: var(--color-surface);
    border-radius: 50%;
    font-size: 0.85rem;
    font-weight: 700;
    font-style: italic;
    line-height: 32px;
    text-align: center;
}

/* Links in der Benachrichtigungsleiste hervorheben */
.dashboard-notification a {
    font-weight: 600;
    text-decoration: none;
    border-bottom: 1px solid transparent;
    transition: border-color var(--transition-base);
}

.dashboard-notification a:hover {
    border-bottom-color: var(--color-blue);
}

.notification-text {
    flex: 1;
    font-size: var(--font-size-sm);
    line-height: 1.5;
}

/* "2 von 3" Anzeige */
.notification-counter {
    flex-shrink: 0;
    font-size: var(--font-size-xs);
    color: var(--text-secondary);
    white-space: nowrap;
    background: rgba(0, 0, 0, 0.06);
    padding: 2px 8px;
    border-radius: 999px;
}

/* Spezielle Benachrichtigungsleiste für Monatsrückblicke */
.dashboard-notification.monthly-review {
    background: var(--purple-light);
    border-color: rgba(139, 92, 246, 0.2);
    box-shadow: 0 2px 10px rgba(139, 92, 246, 0.1);
}

.dashboard-notification.monthly-review::after {
    background: var(--color-purple);
}

.dashboard-notification.monthly-review::before {
    content: '★';
    background: var(--color-purple);
    font-style: normal;
    font-size: 0.8rem;
}

.dashboard-notification.monthly-review a {
    color: var(--color-purple);
}

.dashboard-notification.monthly-review a:hover {
    border-bottom-color: var(--color-purple);
}

.notification-close {
    flex-shrink: 0;
    background: none;
    border: none;
    width: 28px;
    height: 28px;
    border-radius: 50%;
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 1rem;
    line-height: 1;
    color: var(--text-secondary);
    cursor: pointer;
    transition: background var(--transition-base), color var(--transition-base);
}

.notification-close:hover {
    background: rgba(0, 0, 0, 0.08);
    color: var(--text-primary);
}

/* Desktop */
@media (min-width: 769px) {
    .dashboard-container {
        padding: var(--space-xl);
    }
}

/* ==================== HERO HEADER (UNTEREINANDER!) ==================== */
/* ==================== DASHBOARD HERO ==================== */

.dashboard-hero {
    margin-bottom: var(--space-xl);
    display: flex;
    flex-direction: column;
    gap: var(--space-lg);
}

/* Begrüßungstext */
.hero-greeting {
    display: flex;
    flex-direction: column;
    gap: var(--space-xs);
}

.hero-title {
    font-size: 2.6rem;
    font-weight: 800;
    color: var(--color-text-primary);
    line-height: 1.1;
    letter-spacing: -0.02em;
}

.hero-name {
    display: block;
}

.hero-subtitle {
    font-size: 1rem;
    color: var(--color-text-secondary);
    font-style: italic;
    line-height: 1.5;
    margin-top: var(--space-xs);
}

@media (min-width: 600px) {
    .hero-title {
        font-size: 3.2rem;
    }
}

/* Featured Habit Card */
.hero-habit-card {
    display: block;
    background: var(--color-surface);
    border-radius: var(--radius-lg);
    padding: var(--space-lg);
    box-shadow: var(--shadow-sm);
    border: 1px solid var(--color-border);
    text-decoration: none;
    color: inherit;
    transition: box-shadow var(--transition-base), transform var(--transition-base);
    position: relative;
    overflow: hidden;
}

.hero-habit-card::before {
    content: '';
    position: absolute;
    top: 0; left: 0; right: 0;
    height: 3px;
    background: linear-gradient(90deg, var(--color-primary) 0%, var(--color-primary-dark) 100%);
}

.hero-habit-card:hover {
    box-shadow: var(--shadow-md);
    transform: translateY(-2px);
}

.hero-habit-top {
    display: flex;
    justify-content: space-between;
    align-items: center;
    margin-bottom: var(--space-sm);
}

.hero-habit-label {
    font-size: 0.7rem;
    font-weight: 700;
    letter-spacing: 0.08em;
    color: var(--color-primary);
    text-transform: uppercase;
}

.hero-habit-leaf {
    font-size: 1.5rem;
    opacity: 0.4;
}

.hero-habit-title {
    font-size: 1.2rem;
    font-weight: 700;
    color: var(--color-text-primary);
    line-height: 1.3;
    margin-bottom: var(--space-lg);
}

.hero-habit-bottom {
    display: flex;
    align-items: center;
    gap: var(--space-md);
}

.hero-progress-track {
    flex: 1;
    height: 6px;
    background: var(--color-border);
    border-radius: 6px;
    overflow: hidden;
}

.hero-progress-fill {
    height: 100%;
    background: var(--color-primary);
    border-radius: 6px;
    transition: width 0.6s ease;
    min-width: 4px;
}

.hero-progress-fill.is-done {
    background: linear-gradient(90deg, var(--color-primary) 0%, var(--color-primary-dark) 100%);
}

.hero-habit-meta {
    font-size: var(--font-size-sm);
    color: var(--color-text-secondary);
    font-weight: 600;
    white-space: nowrap;
}

/* Neue-Nutzer CTA-Buttons */
.hero-cta-row {
    display: flex;
    flex-direction: column;
    gap: var(--space-sm);
}

@media (min-width: 480px) {
    .hero-cta-row {
        flex-direction: row;
    }
}

.cta-btn {
    flex: 1;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: var(--space-xs);
    padding: var(--space-md) var(--space-lg);
    border-radius: var(--radius-lg);
    font-weight: 600;
    color: var(--color-surface);
    text-decoration: none;
    box-shadow: var(--shadow-sm);
    transition: transform var(--transition-base), box-shadow var(--transition-base);
}

.cta-btn:hover {
    transform: translateY(-2px);
    box-shadow: var(--shadow-md);
}

.cta-goal        { background: var(--color-primary); }
.cta-goal:hover  { background: var(--color-primary-dark); }
.cta-mood        { background: var(--color-blue); }
.cta-mood:hover  { background: var(--color-blue-dark); }
.cta-achievement       { background: var(--color-purple); }
.cta-achievement:hover { background: var(--color-purple-dark); }

/* ==================== HERO HABIT SLIDER ==================== */

.hero-habit-wrapper {
    display: flex;
    flex-direction: column;
    gap: var(--space-xs);
    /* Horizontalen Swipe abfangen, vertikales Scrollen erlauben */
    touch-action: pan-y;
}

.hero-slide-hidden {
    display: none !important;
}

/* Desktop: Pfeil-Navigation */
.hero-habit-nav-controls {
    display: none;
    align-items: center;
    justify-content: flex-end;
    gap: 6px;
    padding: 2px 4px;
}

@media (min-width: 768px) {
    .hero-habit-nav-controls {
        display: flex;
    }
}

.hero-nav-arrow {
    width: 28px;
    height: 28px;
    border-radius: 50%;
    border: 1px solid var(--color-border);
    background: var(--color-surface);
    color: var(--color-text-primary);
    font-size: 1rem;
    line-height: 1;
    cursor: pointer;
    display: flex;
    align-items: center;
    justify-content: center;
    padding: 0;
    transition: background var(--transition-base), border-color var(--transition-base), color var(--transition-base);
}

.hero-nav-arrow:hover:not(:disabled) {
    background: var(--color-primary-light);
    border-color: var(--color-primary);
    color: var(--color-primary-dark);
}

.hero-nav-arrow:disabled {
    opacity: 0.28;
    cursor: default;
}

.hero-nav-indicator {
    font-size: 0.72rem;
    color: var(--color-text-secondary);
    font-weight: 500;
    min-width: 36px;
    text-align: center;
}

/* Mobile: Dot-Indikatoren */
.hero-habit-dots {
    display: flex;
    justify-content: center;
    gap: 6px;
    padding: 4px 0;
}

@media (min-width: 768px) {
    .hero-habit-dots {
        display: none;
    }
}

.hero-dot {
    width: 6px;
    height: 6px;
    border-radius: 50%;
    background: var(--color-border);
    transition: background 0.2s;
}

.hero-dot.hero-dot-active {
    background: var(--color-primary);
    width: 18px;
    border-radius: 3px;
}

/* ==================== HERO HABIT SWITCH ==================== */

/* Hero-Karte als Block (nicht mehr als Link) */
.hero-habit-card {
    cursor: default;
}
.hero-habit-card:hover {
    transform: none;
    box-shadow: var(--shadow-sm);
}
.hero-habit-card.is-completed {
    opacity: 0.72;
}

.hero-habit-streak {
    font-size: 0.85rem;
    font-weight: 700;
    color: var(--color-text-secondary);
}

.hero-habit-bottom {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: var(--space-md);
}

.hero-habit-done {
    font-size: var(--font-size-sm);
    font-weight: 700;
    color: var(--color-primary);
}

.hero-habit-link {
    font-size: var(--font-size-sm);
    color: var(--color-text-secondary);
    text-decoration: none;
    white-space: nowrap;
}
.hero-habit-link:hover {
    color: var(--color-primary);
}

/* Toggle-Switch in der Hero-Karte */
.hero-switch {
    display: inline-flex;
    align-items: center;
    gap: var(--space-xs);
    cursor: pointer;
    user-select: none;
}
.hero-switch input[type="checkbox"] {
    position: absolute;
    opacity: 0;
    width: 0; height: 0;
}
.hero-switch-track {
    display: inline-block;
    width: 40px;
    height: 22px;
    background: var(--color-border);
    border-radius: 11px;
    position: relative;
    transition: background 0.25s;
    flex-shrink: 0;
}
.hero-switch-track::after {
    content: '';
    position: absolute;
    width: 16px; height: 16px;
    background: #fff;
    border-radius: 50%;
    top: 3px; left: 3px;
    transition: transform 0.25s;
    box-shadow: 0 1px 3px rgba(0,0,0,.2);
}
.hero-switch input:checked ~ .hero-switch-track {
    background: var(--color-primary);
}
.hero-switch input:checked ~ .hero-switch-track::after {
    transform: translateX(18px);
}
.hero-switch input:disabled ~ .hero-switch-track {
    opacity: 0.5;
}
.hero-switch-label {
    font-size: var(--font-size-sm);
    font-weight: 600;
    color: var(--color-text-secondary);
}

/* ==================== AUFGABEN-KARTEN IM CAROUSEL ==================== */

.dashboard-notification.task-card {
    display: flex;
    align-items: center;
    gap: var(--space-sm);
    padding: var(--space-md) var(--space-lg);
    flex-wrap: nowrap;
    /* Blaues Basis-Styling überschreiben */
    background: var(--color-surface);
    border-color: var(--color-border);
    box-shadow: var(--shadow-sm);
}
.dashboard-notification.task-card::before,
.dashboard-notification.task-card::after {
    display: none;
}

.task-card-body {
    display: flex;
    align-items: center;
    gap: var(--space-sm);
    flex: 1;
    min-width: 0;
}

.task-card-icon {
    width: 32px;
    height: 32px;
    border-radius: 8px;
    background: var(--color-background);
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 1rem;
    flex-shrink: 0;
}

.task-card-mood .task-card-icon {
    background: var(--color-blue-light);
}

.task-card-info {
    display: flex;
    flex-direction: column;
    gap: 1px;
    min-width: 0;
}

.task-card-type {
    font-size: 0.65rem;
    font-weight: 700;
    letter-spacing: 0.07em;
    text-transform: uppercase;
    color: var(--color-text-secondary);
    line-height: 1;
}

.task-card-title {
    font-size: 0.875rem;
    font-weight: 600;
    color: var(--color-text-primary);
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
}

/* Switch in der Aufgabenkarte */
.task-switch {
    display: inline-flex;
    align-items: center;
    gap: 6px;
    cursor: pointer;
    user-select: none;
    flex-shrink: 0;
}
.task-switch input[type="checkbox"] {
    position: absolute;
    opacity: 0;
    width: 0; height: 0;
}
.task-switch-track {
    display: inline-block;
    width: 36px;
    height: 20px;
    background: var(--color-border);
    border-radius: 10px;
    position: relative;
    transition: background 0.25s;
}
.task-switch-track::after {
    content: '';
    position: absolute;
    width: 14px; height: 14px;
    background: #fff;
    border-radius: 50%;
    top: 3px; left: 3px;
    transition: transform 0.25s;
    box-shadow: 0 1px 3px rgba(0,0,0,.2);
}
.task-switch input:checked ~ .task-switch-track {
    background: var(--color-primary);
}
.task-switch input:checked ~ .task-switch-track::after {
    transform: translateX(16px);
}
.task-switch input:disabled ~ .task-switch-track {
    opacity: 0.5;
}
.task-switch-label {
    font-size: 0.75rem;
    font-weight: 600;
    color: var(--color-text-secondary);
}

/* Mood-Check Button in Aufgabenkarte */
.task-action-btn {
    display: inline-flex;
    align-items: center;
    padding: 6px 12px;
    background: var(--color-blue);
    color: #fff;
    border-radius: var(--radius-md);
    font-size: 0.78rem;
    font-weight: 600;
    text-decoration: none;
    white-space: nowrap;
    flex-shrink: 0;
    transition: background var(--transition-base);
}
.task-action-btn:hover {
    background: var(--color-blue-dark);
    color: #fff;
}

/* ==================== HERO DESKTOP LAYOUT ==================== */
@media (min-width: 768px) {
    .dashboard-hero {
        display: grid;
        grid-template-columns: 1fr 360px;
        gap: var(--space-xl);
        align-items: center;
    }

    .hero-greeting {
        align-self: center;
    }

    .hero-title {
        font-size: 3.8rem;
    }

    .hero-cta-row {
        grid-column: 1 / -1;
    }
}

@media (min-width: 1024px) {
    .hero-title {
        font-size: 4.4rem;
    }

    .dashboard-hero {
        grid-template-columns: 1fr 400px;
        gap: calc(var(--space-xl) * 1.5);
    }
}

/* ==================== STATS SECTION ==================== */
/*
 * Stats‑Abschnitt
 *
 * Dieser Abschnitt wurde neu gestaltet, um eine kompaktere und modernere
 * Darstellung zu erreichen. Die Karten sind zentriert ausgerichtet und
 * zeigen die wichtigsten Kennzahlen auf einen Blick. Der Zeitraum
 * Umschalter ist als einfacher Button‑Switcher umgesetzt.
 */
.stats-section {
    margin-bottom: var(--space-2xl);
}

/* Header im Stats‑Bereich */
.stats-section-header,
.stats-section-header.alt {
    display: flex;
    flex-direction: column;
    gap: var(--space-sm);
    margin-bottom: var(--space-md);
    align-items: flex-start;
}

.stats-section-header h2,
.stats-section-header.alt h2 {
    font-size: 1.5rem;
    font-weight: 700;
    color: var(--color-text-primary);
    margin: 0;
}

@media (min-width: 768px) {
    .stats-section-header,
    .stats-section-header.alt {
        flex-direction: row;
        align-items: center;
        justify-content: space-between;
    }
    .stats-section-header h2,
    .stats-section-header.alt h2 {
        font-size: 1.75rem;
    }
}

/* Period Umschalter */
.period-toggle-right,
.period-toggle-alt {
    display: flex;
    align-items: center;
    gap: var(--space-xs);
    flex-wrap: wrap;
}
.period-toggle-right .period-toggle-btn,
.period-toggle-alt .period-btn {
    background: var(--gray-100);
    border: none;
    border-radius: var(--radius-md);
    padding: var(--space-xs) var(--space-sm);
    color: var(--color-text-secondary);
    font-size: 0.875rem;
    cursor: pointer;
    transition: background var(--transition-duration);
}
.period-toggle-right .period-toggle-btn:hover,
.period-toggle-alt .period-btn:hover {
    background: var(--color-surface);
    color: var(--color-text-primary);
}
.period-toggle-right .period-toggle-btn.active,
.period-toggle-alt .period-btn.active {
    background: var(--color-blue);
    color: #fff;
    font-weight: 600;
}
.period-toggle-right .period-label,
.period-toggle-alt .period-label {
    margin-left: var(--space-sm);
    font-size: 0.875rem;
    color: var(--color-text-secondary);
    font-weight: 500;
}

/* Stats Grid */
.stats-grid {
    display: grid;
    grid-template-columns: 1fr;
    gap: var(--space-md);
}
@media (min-width: 500px) {
    .stats-grid {
        grid-template-columns: repeat(2, 1fr);
    }
}
@media (min-width: 900px) {
    .stats-grid {
        grid-template-columns: repeat(4, 1fr);
    }
}

/* Einzelne Stat‑Karte */
.stat-item {
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    background: var(--color-surface);
    border-radius: var(--radius-lg);
    box-shadow: var(--shadow-md);
    padding: var(--space-lg);
    text-decoration: none;
    color: var(--color-text-primary);
    transition: transform var(--transition-duration), box-shadow var(--transition-duration);
    position: relative;
    overflow: hidden;
}

.stat-item::before {
    content: '';
    position: absolute;
    top: 0;
    left: 0;
    right: 0;
    height: 4px;
    background: currentColor;
}

.stat-item:hover {
    transform: translateY(-4px);
    box-shadow: var(--shadow-lg);
}

/* Farbliche Zuordnung */
.stat-blue { color: var(--color-blue); }
.stat-green { color: var(--color-primary); }
.stat-purple { color: var(--color-purple); }
.stat-orange { color: var(--color-accent); }

/* Inhalt der Stat-Karte */
.stat-icon {
    font-size: 2rem;
    margin-bottom: var(--space-xs);
    line-height: 1;
}

.stat-number {
    font-size: 2rem;
    font-weight: 700;
    margin-bottom: var(--space-xs);
}

.stat-label {
    font-size: 1rem;
    font-weight: 600;
    margin-bottom: var(--space-xs);
}

.stat-sub {
    font-size: 0.75rem;
    color: var(--color-text-secondary);
    margin-bottom: var(--space-xs);
}

.stat-extra {
    font-size: 0.75rem;
    color: var(--color-text-secondary);
    font-weight: 500;
}

/* Period Toggle */
.period-toggle-right {
    display: flex;
    flex-direction: column;
    gap: var(--space-sm);
}

.toggle-hint {
    font-size: 0.875rem;
    color: var(--text-light);
    font-weight: 500;
    display: none;
}

@media (min-width: 600px) {
    .toggle-hint {
        display: inline;
    }
}

.period-toggle-wrapper {
    display: flex;
    gap: var(--space-xs);
    background: var(--gray-100);
    padding: 4px;
    border-radius: var(--radius-md);
}

.period-toggle-btn {
    flex: 1;
    padding: var(--space-sm) var(--space-md);
    border: none;
    background: transparent;
    color: var(--text-secondary);
    font-size: 0.9rem;
    font-weight: 600;
    border-radius: var(--radius-sm);
    cursor: pointer;
    transition: all var(--transition-base);
    white-space: nowrap;
}

.period-toggle-btn:hover {
    background: var(--color-surface);
    color: var(--text-primary);
}

.period-toggle-btn.active {
    background: var(--color-blue);
    color: var(--color-surface);
    box-shadow: var(--shadow-sm);
}

/* Desktop: Toggle horizontal */
@media (min-width: 769px) {
    .period-toggle-right {
        flex-direction: row;
        align-items: center;
        gap: var(--space-md);
    }
    
    .period-toggle-wrapper {
        width: auto;
    }
    
    .period-toggle-btn {
        flex: 0 0 auto;
        padding: var(--space-sm) var(--space-lg);
    }
}

/* ==================== STATS CARDS (KOMPAKTER!) ==================== */
.stats-cards-grid {
    display: grid;
    grid-template-columns: repeat(2, 1fr);
    gap: var(--space-sm);
}

@media (min-width: 600px) {
    .stats-cards-grid {
        gap: var(--space-md);
    }
}

@media (min-width: 1024px) {
    .stats-cards-grid {
        grid-template-columns: repeat(4, 1fr);
        gap: var(--space-lg);
    }
    .stat-card-order1 { order: 1; }
    .stat-card-order2 { order: 2; }
    .stat-card-order3 { order: 3; }
    .stat-card-order4 { order: 4; }
}

/* Stat Card */
/* Neue Gestaltung der Statistikkarten.
 * Die Karten sind jetzt zentriert ausgerichtet, zeigen große Icons und Zahlen und
 * verzichten auf separate Card‑Header/Footer. Statt eines dicken Rahmens
 * gibt es oben einen farbigen Streifen (via ::before). Die Inhalte sind
 * vertikal gegliedert. */
.stat-card-v2 {
    background: var(--color-surface);
    border-radius: var(--radius-lg);
    box-shadow: var(--shadow-md);
    padding: var(--space-md);
    overflow: hidden;
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    text-decoration: none;
    position: relative;
    border: none;
    transition: transform var(--transition-duration), box-shadow var(--transition-duration);
}

@media (min-width: 600px) {
    .stat-card-v2 {
        padding: var(--space-lg);
    }
}

/* Farbstreifen oben bleibt erhalten via ::before */
.stat-card-v2::before {
    content: '';
    position: absolute;
    top: 0;
    left: 0;
    right: 0;
    height: 4px;
    background: currentColor;
}

.stat-card-v2:hover {
    transform: translateY(-4px);
    box-shadow: var(--shadow-lg);
}

/* Zentrierter Inhalt */
.stat-card-inner {
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    gap: var(--space-xs);
}

.stat-card-header {
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    gap: var(--space-xs);
    margin-bottom: 0;
}

.stat-icon-large {
    font-size: 2rem;
    line-height: 1;
}

.stat-category {
    font-size: 0.875rem;
    font-weight: 600;
    color: var(--color-text-primary);
}

.stat-card-body {
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    gap: var(--space-xs);
}

.stat-main-number {
    font-size: 2rem;
    font-weight: 700;
    color: var(--color-text-primary);
}

.stat-description {
    font-size: 0.75rem;
    color: var(--color-text-secondary);
    font-weight: 500;
}

/* Aufteilung für Ziele: wir stellen beide Werte untereinander dar */
.stat-split-view {
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    gap: var(--space-xs);
}
.stat-split-item {
    display: flex;
    flex-direction: column;
    align-items: center;
}
.stat-split-number {
    font-size: 1.5rem;
    font-weight: 700;
    color: var(--color-text-primary);
}
.stat-split-label {
    font-size: 0.75rem;
    color: var(--color-text-secondary);
    font-weight: 500;
}
.stat-split-divider {
    display: none;
}
.stat-card-footer {
    margin-top: var(--space-sm);
}

.stat-card-v2::before {
    content: '';
    position: absolute;
    top: 0;
    left: 0;
    right: 0;
    height: 4px;
    background: currentColor;
}

.stat-card-v2:hover {
    transform: translateY(-4px);
    box-shadow: var(--shadow-lg);
}

.stat-card-blue { color: var(--blue); }
.stat-card-green { color: var(--green); }
.stat-card-orange { color: var(--orange); }
.stat-card-purple { color: var(--purple); }

.stat-card-inner {
    /* kompaktere Innenabstände für kleinere Karten */
    padding: var(--space-md);
}

/* Desktop: Mehr Padding */
@media (min-width: 1024px) {
    .stat-card-inner {
        padding: var(--space-lg);
    }
}

/* Stat Header */
.stat-card-header {
    display: flex;
    align-items: center;
    gap: var(--space-md);
    margin-bottom: var(--space-md);
}

/*
 * Die Icons der Statistikkarten wurden verkleinert, um die Karten
 * insgesamt kompakter wirken zu lassen. Dadurch bleibt auf kleineren
 * Bildschirmen mehr Platz für Inhalte und die Karten wirken ruhiger.
 */
.stat-icon-large {
    font-size: 2.25rem;
    line-height: 1;
    filter: drop-shadow(0 2px 4px rgba(0,0,0,0.1));
}

.stat-category {
    font-size: 0.85rem;
    font-weight: 700;
    color: var(--text-primary);
    text-transform: uppercase;
    letter-spacing: 0.5px;
}

/* Desktop: Größere Icons */
@media (min-width: 1024px) {
    .stat-icon-large {
        font-size: 3rem;
    }
    
    .stat-category {
        font-size: 0.95rem;
    }
}

/* Stat Body */
.stat-card-body {
    margin-bottom: 0;
    /* Einheitliche Zentrierung der Werte und Beschriftungen in allen
       Statistikkarten. Dies verhindert linkslastige Ausrichtung auf
       kleineren Bildschirmen und sorgt für ein harmonisches Layout. */
    text-align: center;
    display: flex;
    flex-direction: column;
    align-items: center;
}

/*
 * Die Hauptzahlen der Statistikkarten wurden weiter reduziert, um den
 * Karten ein dezenteres Erscheinungsbild zu geben. Dadurch sehen die
 * Statistiken auch nebeneinander auf dem Desktop weniger dominant aus.
 */
.stat-main-number {
    font-size: 1.5rem;
    font-weight: 800;
    line-height: 1;
    color: var(--text-primary);
    margin-bottom: var(--space-xs);
}

@media (min-width: 600px) {
    .stat-main-number {
        font-size: 1.8rem;
    }
}

.stat-description {
    font-size: 0.875rem;
    color: var(--text-secondary);
    font-weight: 500;
}

/* Desktop: Größere Zahlen */
@media (min-width: 1024px) {
    .stat-main-number {
        font-size: 2.2rem;
    }
    
    .stat-description {
        font-size: 0.9rem;
    }
}

/* Split View (Ziele) */
.stat-split-view {
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: var(--space-sm);
    padding: var(--space-sm) 0;
}

.stat-split-item {
    text-align: center;
    /* Im vertikalen Layout nicht strecken */
    flex: none;
    width: 100%;
}

.stat-split-number {
    font-size: 2rem;
    font-weight: 800;
    color: var(--text-primary);
    line-height: 1;
    margin-bottom: var(--space-xs);
}

.stat-split-number.stat-success {
    color: var(--green);
}

.stat-split-label {
    font-size: 0.75rem;
    color: var(--text-secondary);
    font-weight: 600;
}

.stat-split-divider {
    /* Im vertikalen Layout keine Trennlinie anzeigen */
    display: none;
    width: 2px;
    height: 40px;
    background: var(--gray-300);
    flex-shrink: 0;
}

/* Desktop: Größere Split */
@media (min-width: 1024px) {
    .stat-split-number {
        font-size: 2.5rem;
    }
    
    .stat-split-label {
        font-size: 0.85rem;
    }
    
    .stat-split-divider {
        height: 50px;
    }
}

/* Stat Footer (Fire Badge) */
.stat-card-footer {
    padding-top: var(--space-md);
    margin-top: var(--space-md);
    border-top: 2px solid var(--gray-200);
}

.stat-badge-fire {
    display: inline-flex;
    align-items: center;
    gap: var(--space-sm);
    padding: var(--space-sm) var(--space-md);
    background: linear-gradient(135deg, #FF5722 0%, #F4511E 100%);
    border-radius: var(--radius-md);
    box-shadow: 0 2px 8px rgba(255, 87, 34, 0.3);
}

.stat-badge-fire .badge-icon {
    font-size: 1.25rem;
}

.stat-badge-fire .badge-text {
    color: var(--color-surface);
    font-weight: 600;
    font-size: 0.875rem;
}

/* ==================== QUICK ACTIONS (ABSTÄNDE GEFIXT!) ==================== */
.quick-actions-section {
    margin-bottom: var(--space-xl);
}

.quick-actions-section h2 {
    font-size: 1.5rem;
    font-weight: 700;
    color: var(--text-primary);
    margin-bottom: var(--space-lg);
}

@media (min-width: 769px) {
    .quick-actions-section h2 {
        font-size: 1.75rem;
    }
}

.quick-actions-grid {
    display: grid;
    grid-template-columns: 1fr;
    gap: var(--space-md);
}

/* Tablet: 2 Spalten */
@media (min-width: 600px) {
    .quick-actions-grid {
        grid-template-columns: repeat(2, 1fr);
    }
}

/* Desktop: 4 Spalten mit KORREKTEN Abständen */
@media (min-width: 1024px) {
    .quick-actions-grid {
        grid-template-columns: repeat(4, 1fr);
        gap: var(--space-lg);
    }
}

/* Action Card */
.action-card {
    display: flex;
    /* Durchgehende horizontale Anordnung, damit die Pfeile rechts stehen */
    flex-direction: row;
    align-items: center;
    text-align: left;
    padding: var(--space-lg);
    background: var(--color-surface);
    border-radius: var(--radius-lg);
    text-decoration: none;
    box-shadow: var(--shadow-md);
    transition: all var(--transition-base);
    border: 2px solid transparent;
    gap: var(--space-md);
}

.action-card:hover {
    transform: translateY(-4px);
    box-shadow: var(--shadow-lg);
    border-color: currentColor;
}

.action-card.action-blue {
    color: var(--blue);
    background: linear-gradient(135deg, #ffffff 0%, var(--blue-light) 100%);
}

.action-card.action-green {
    color: var(--green);
    background: linear-gradient(135deg, #ffffff 0%, var(--green-light) 100%);
}

.action-card.action-orange {
    color: var(--orange);
    background: linear-gradient(135deg, #ffffff 0%, var(--orange-light) 100%);
}

.action-card.action-purple {
    color: var(--purple);
    background: linear-gradient(135deg, #ffffff 0%, var(--purple-light) 100%);
}

.action-icon {
    font-size: 3rem;
    line-height: 1;
}

.action-text h3 {
    font-size: 1rem;
    font-weight: 700;
    color: var(--text-primary);
    margin-bottom: var(--space-xs);
}

.action-text p {
    font-size: 0.85rem;
    color: var(--text-secondary);
}

.action-arrow {
    font-size: 1.5rem;
    color: currentColor;
    opacity: 0.3;
    transition: all var(--transition-base);
    margin-left: auto;
    align-self: center;
}

.action-card:hover .action-arrow {
    opacity: 1;
    /* Pfeil gleitet sanft nach rechts beim Hover */
    transform: translateX(4px);
}

/* Desktop: Horizontal Layout */
@media (min-width: 1024px) {
    .action-card {
        flex-direction: row;
        text-align: left;
        padding: var(--space-xl);
    }
    
    .action-text {
        flex: 1;
    }
    
    /* In größeren Breakpoints ist keine abweichende Anordnung mehr nötig,
       da die horizontale Ausrichtung bereits definiert ist */
}

/* ==================== PAGE HEADER WITH ACTION BUTTON ==================== */
.page-header {
    display: flex;
    flex-direction: column;
    gap: var(--space-md);
    margin-bottom: var(--space-xl);
    background: var(--color-surface);
    padding: var(--space-lg);
    border-radius: var(--radius-lg);
    box-shadow: var(--shadow-md);
}

.page-header-content h1 {
    font-size: 1.75rem;
    font-weight: 700;
    color: var(--text-primary);
    margin-bottom: var(--space-xs);
}

.page-header-content p {
    font-size: 0.95rem;
    color: var(--text-secondary);
}

.page-header-actions {
    display: flex;
    flex-wrap: wrap;
    gap: var(--space-sm);
}

/* Desktop: Nebeneinander */
@media (min-width: 769px) {
    .page-header {
        flex-direction: row;
        justify-content: space-between;
        align-items: center;
        padding: var(--space-xl);
    }
    
    .page-header-content h1 {
        font-size: 2rem;
    }
    
    .page-header-actions {
        flex-shrink: 0;
    }
}

/* ==================== BUTTONS ==================== */
.btn {
    display: inline-flex;
    align-items: center;
    gap: var(--space-sm);
    padding: var(--space-sm) var(--space-lg);
    border-radius: var(--radius-md);
    text-decoration: none;
    font-weight: 600;
    font-size: 0.95rem;
    transition: all var(--transition-base);
    border: 2px solid transparent;
    cursor: pointer;
    white-space: nowrap;
}

.btn-primary {
    background: var(--color-blue);
    color: var(--color-surface);
    box-shadow: var(--shadow-sm);
}

.btn-primary:hover {
    background: var(--color-blue-dark);
    transform: translateY(-2px);
    box-shadow: var(--shadow-md);
}

.btn-secondary {
    background: var(--color-surface);
    color: var(--text-primary);
    border-color: var(--color-border);
}

.btn-secondary:hover {
    border-color: var(--color-border);
    background: var(--color-background);
}

.btn-success {
    background: var(--color-primary);
    color: var(--color-surface);
    box-shadow: var(--shadow-sm);
}

.btn-success:hover {
    background: var(--color-primary-dark);
    transform: translateY(-2px);
}

.btn-icon {
    font-size: 1.25rem;
}

/* Desktop: Größere Buttons */
@media (min-width: 769px) {
    .btn {
        padding: var(--space-md) var(--space-xl);
        font-size: 1rem;
    }
}

/* ==================== HABITS SECTION ==================== */
.habits-section {
    background: var(--color-surface);
    padding: var(--space-lg);
    border-radius: var(--radius-lg);
    box-shadow: var(--shadow-md);
    margin-bottom: var(--space-xl);
}

@media (min-width: 769px) {
    .habits-section {
        padding: var(--space-xl);
    }
}

.section-header {
    display: flex;
    justify-content: space-between;
    align-items: center;
    margin-bottom: var(--space-lg);
    padding-bottom: var(--space-md);
    border-bottom: 2px solid var(--gray-200);
    flex-wrap: wrap;
    gap: var(--space-sm);
}

.section-header h2 {
    font-size: 1.25rem;
    font-weight: 700;
    color: var(--text-primary);
}

@media (min-width: 769px) {
    .section-header h2 {
        font-size: 1.5rem;
    }
}

.link-primary {
    color: var(--color-blue);
    text-decoration: none;
    font-weight: 600;
    font-size: 0.9rem;
    transition: all var(--transition-base);
}

.link-primary:hover {
    color: var(--color-blue-dark);
}

/* Habits Grid */
.habits-grid {
    display: grid;
    grid-template-columns: 1fr;
    gap: var(--space-md);
}

@media (min-width: 600px) {
    .habits-grid {
        grid-template-columns: repeat(2, 1fr);
    }
}

@media (min-width: 1024px) {
    .habits-grid {
        grid-template-columns: repeat(3, 1fr);
    }
}

.habit-card {
    display: flex;
    align-items: center;
    gap: var(--space-md);
    padding: var(--space-md);
    background: var(--gray-50);
    border-radius: var(--radius-md);
    border: 2px solid var(--gray-200);
    transition: all var(--transition-base);
}

.habit-card:hover {
    border-color: var(--green);
    background: white;
    transform: translateY(-2px);
}

.habit-card.completed {
    background: var(--green-light);
    border-color: var(--green);
}

.habit-icon {
    width: 50px;
    height: 50px;
    border-radius: 50%;
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 1.75rem;
    color: white;
    flex-shrink: 0;
    box-shadow: var(--shadow-sm);
}

.habit-info {
    flex: 1;
    min-width: 0;
}

.habit-info h4 {
    font-size: 0.95rem;
    font-weight: 700;
    color: var(--text-primary);
    margin-bottom: var(--space-xs);
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
}

.habit-streak {
    font-size: 0.85rem;
    color: var(--red);
    font-weight: 600;
}

.habit-btn {
    width: 50px;
    height: 28px;
    background: var(--gray-300);
    border: none;
    border-radius: 28px;
    position: relative;
    cursor: pointer;
    transition: all var(--transition-base);
    flex-shrink: 0;
}

.habit-btn:hover:not(:disabled) {
    background: var(--green);
}

.habit-btn:disabled {
    background: var(--green);
    cursor: default;
}

.habit-btn-circle {
    position: absolute;
    width: 24px;
    height: 24px;
    background: white;
    border-radius: 50%;
    top: 2px;
    left: 2px;
    transition: all var(--transition-base);
    box-shadow: 0 2px 4px rgba(0,0,0,0.2);
}

.habit-btn:disabled .habit-btn-circle {
    left: 24px;
}

/* ==================== CONTENT GRID ==================== */
.content-grid {
    display: grid;
    grid-template-columns: 1fr;
    gap: var(--space-xl);
}

/* Wenn nur eine content-col vorhanden ist (z. B. nachdem die
   Erfolgssektion in einen Slider ausgelagert wurde), soll die
   Spalte beide Gitterspalten einnehmen, um leeren Raum zu vermeiden. */
.content-grid > .content-col:only-child {
    grid-column: span 2;
}

/* ==================== ACHIEVEMENTS SLIDER ==================== */
/*
 * Der Erfolge-Slider präsentiert die persönlichen Erfolge als
 * horizontale Slideshow. Nutzer können durch Wischen oder mit den
 * Navigationspfeilen zwischen den Karten wechseln. Jede Karte
 * enthält ein Bild (falls vorhanden) und den Titel des Erfolgs.
 */
/* ==================== SUCCESS MOMENTS SLIDER ==================== */

.sm-section {
    margin-bottom: var(--space-xl);
}

.sm-header {
    display: flex;
    justify-content: space-between;
    align-items: center;
    margin-bottom: var(--space-lg);
    gap: var(--space-sm);
}

.sm-header h2 {
    font-size: 1.6rem;
    font-weight: 800;
    color: var(--color-text-primary);
    letter-spacing: -0.01em;
}

.sm-header-actions {
    display: flex;
    align-items: center;
    gap: 12px;
}

.sm-add-btn {
    width: 32px;
    height: 32px;
    border-radius: 50%;
    background: var(--color-primary);
    color: #fff;
    font-size: 1.25rem;
    font-weight: 700;
    display: flex;
    align-items: center;
    justify-content: center;
    text-decoration: none;
    line-height: 1;
    transition: background 0.15s, transform 0.15s;
}

.sm-add-btn:hover {
    background: var(--color-primary-dark);
    transform: scale(1.08);
}

.sm-view-all {
    font-size: var(--font-size-sm);
    font-weight: 600;
    color: var(--color-accent-text);
    text-decoration: none;
}

.sm-view-all:hover {
    text-decoration: underline;
}

/* Track */
.sm-track {
    display: grid;
    grid-auto-flow: column;
    grid-auto-columns: 76%;
    gap: 16px;
    overflow-x: auto;
    scroll-snap-type: x mandatory;
    -webkit-overflow-scrolling: touch;
    padding-bottom: 8px;
}

.sm-track::-webkit-scrollbar { display: none; }

/* Card */
.sm-card {
    scroll-snap-align: start;
    background: var(--color-surface);
    border-radius: 18px;
    box-shadow: var(--shadow-md);
    overflow: hidden;
    text-decoration: none;
    color: var(--color-text-primary);
    display: flex;
    flex-direction: column;
    transition: transform 0.18s, box-shadow 0.18s;
}

.sm-card:hover {
    transform: translateY(-3px);
    box-shadow: var(--shadow-lg);
}

/* Image area */
.sm-card-image {
    position: relative;
    aspect-ratio: 3 / 4;
    overflow: hidden;
    background: var(--color-background);
}

.sm-img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    display: block;
    transition: transform 0.3s ease;
}

.sm-card:hover .sm-img {
    transform: scale(1.04);
}

.sm-img-placeholder {
    width: 100%;
    height: 100%;
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 3rem;
    background: linear-gradient(135deg, #f5f0e8, #ede8df);
}

/* Category badge overlay */
.sm-badge {
    position: absolute;
    top: 12px;
    left: 12px;
    background: rgba(255, 255, 255, 0.92);
    backdrop-filter: blur(4px);
    color: var(--color-text-primary);
    font-size: 0.65rem;
    font-weight: 800;
    letter-spacing: 0.08em;
    text-transform: uppercase;
    padding: 4px 10px;
    border-radius: 6px;
}

/* Card body */
.sm-card-body {
    padding: 14px 16px 16px;
}

.sm-card-title {
    font-size: 1.05rem;
    font-weight: 800;
    color: var(--color-text-primary);
    margin: 0 0 6px;
    line-height: 1.3;
}

.sm-card-desc {
    font-size: 0.875rem;
    font-style: italic;
    color: var(--color-text-secondary);
    margin: 0;
    line-height: 1.5;
}

/* Empty */
.sm-empty {
    text-align: center;
    padding: var(--space-xl) var(--space-md);
    color: var(--color-text-secondary);
}

.sm-empty-icon {
    display: block;
    font-size: 2.5rem;
    opacity: 0.4;
    margin-bottom: 8px;
}

.sm-empty p {
    margin-bottom: 16px;
    font-size: var(--font-size-sm);
}

/* Responsive */
@media (min-width: 500px) {
    .sm-track { grid-auto-columns: 56%; }
}

@media (min-width: 768px) {
    .sm-track { grid-auto-columns: 38%; }
}

@media (min-width: 1024px) {
    .sm-track { grid-auto-columns: 28%; }
}


@media (min-width: 1024px) {
    .content-grid {
        grid-template-columns: repeat(2, 1fr);
    }
}

.content-section {
    background: var(--color-surface);
    padding: var(--space-lg);
    border-radius: var(--radius-lg);
    box-shadow: var(--shadow-md);
}

@media (min-width: 769px) {
    .content-section {
        padding: var(--space-xl);
    }
}

/* ==================== LIST ITEMS ==================== */
.list-items {
    display: flex;
    flex-direction: column;
    gap: var(--space-sm);
}

.list-item {
    display: flex;
    align-items: center;
    gap: var(--space-md);
    padding: var(--space-md);
    background: var(--gray-50);
    border-radius: var(--radius-md);
    text-decoration: none;
    transition: all var(--transition-base);
    border: 2px solid transparent;
}

.list-item:hover {
    background: white;
    border-color: var(--blue);
    transform: translateX(4px);
}

.list-icon {
    font-size: 2rem;
    flex-shrink: 0;
}

.list-content {
    flex: 1;
    min-width: 0;
}

.list-title {
    font-weight: 700;
    color: var(--text-primary);
    font-size: 0.95rem;
    margin-bottom: var(--space-xs);
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
}

.list-meta {
    font-size: 0.85rem;
    color: var(--text-secondary);
}

.list-arrow {
    font-size: 1.5rem;
    color: var(--blue);
    opacity: 0.3;
    transition: all var(--transition-base);
    flex-shrink: 0;
}

.list-item:hover .list-arrow {
    opacity: 1;
    transform: translateX(4px);
}

/* ==================== GOALS ==================== */
/* ==================== DASHBOARD GOALS (dg-*) ==================== */

.dg-section {
    margin-top: var(--space-xl);
    margin-bottom: var(--space-xl);
}

.dg-track {
    display: grid;
    grid-auto-flow: column;
    grid-auto-columns: 76%;
    gap: 16px;
    overflow-x: auto;
    scroll-snap-type: x mandatory;
    -webkit-overflow-scrolling: touch;
    padding-bottom: 8px;
}

.dg-track::-webkit-scrollbar { display: none; }

.dg-card {
    scroll-snap-align: start;
    background: var(--color-surface);
    border-radius: 18px;
    box-shadow: var(--shadow-md);
    overflow: hidden;
    text-decoration: none;
    color: var(--color-text-primary);
    display: flex;
    flex-direction: column;
    transition: transform 0.18s, box-shadow 0.18s;
}

.dg-card:hover {
    transform: translateY(-3px);
    box-shadow: var(--shadow-lg);
}

.dg-card-image {
    position: relative;
    aspect-ratio: 3 / 4;
    overflow: hidden;
    background: var(--color-background);
}

.dg-img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    display: block;
    transition: transform 0.3s ease;
}

.dg-card:hover .dg-img {
    transform: scale(1.04);
}

.dg-img-placeholder {
    width: 100%;
    height: 100%;
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 3rem;
    background: linear-gradient(135deg, #fef9ec, #fde8b0);
}

.dg-badge-active    { background: rgba(255,255,255,0.92); color: var(--color-success); }
.dg-badge-completed { background: rgba(255,255,255,0.92); color: var(--color-primary-dark); }
.dg-badge-paused    { background: rgba(255,255,255,0.92); color: var(--color-text-secondary); }

.dg-card-body {
    padding: 14px 16px 16px;
    display: flex;
    flex-direction: column;
    flex: 1;
}

.dg-card-title {
    font-size: 1rem;
    font-weight: 800;
    color: var(--color-text-primary);
    margin: 0 0 10px;
    line-height: 1.3;
}

.dg-progress-row {
    display: flex;
    align-items: center;
    gap: 8px;
    margin-bottom: 8px;
}

.dg-progress-track {
    flex: 1;
    height: 6px;
    background: var(--color-border);
    border-radius: 6px;
    overflow: hidden;
}

.dg-progress-fill {
    height: 100%;
    background: linear-gradient(90deg, var(--color-accent), #E65100);
    border-radius: 6px;
    transition: width 0.4s ease;
    min-width: 4px;
}

.dg-progress-pct {
    font-size: 0.75rem;
    font-weight: 700;
    color: var(--color-accent-text);
    white-space: nowrap;
    min-width: 32px;
    text-align: right;
}

.dg-date {
    font-size: 0.72rem;
    color: var(--color-text-secondary);
    margin-top: auto;
}

@media (min-width: 500px) {
    .dg-track { grid-auto-columns: 56%; }
}

@media (min-width: 768px) {
    .dg-track { grid-auto-columns: 38%; }
}

@media (min-width: 1024px) {
    .dg-track { grid-auto-columns: 28%; }
}

/* Keep progress-bar for any remaining legacy usage */
.progress-bar {
    height: 100%;
    background: linear-gradient(90deg, var(--orange) 0%, #F57C00 100%);
    transition: width var(--transition-slow);
}

.progress-label {
    font-size: 0.85rem;
    font-weight: 700;
    color: var(--orange);
}

.goal-footer {
    display: flex;
    justify-content: space-between;
    align-items: center;
    padding-top: var(--space-md);
    border-top: 2px solid var(--gray-200);
    gap: var(--space-sm);
}

.goal-date {
    font-size: 0.85rem;
    color: var(--text-secondary);
    font-weight: 600;
}

.goal-link {
    color: var(--blue);
    text-decoration: none;
    font-weight: 700;
    font-size: 0.85rem;
}

/* ==================== ACHIEVEMENTS GRID ==================== */
.achievements-grid {
    display: grid;
    grid-template-columns: repeat(2, 1fr);
    gap: var(--space-md);
}

@media (min-width: 600px) {
    .achievements-grid {
        grid-template-columns: repeat(3, 1fr);
    }
}

@media (min-width: 1024px) {
    .achievements-grid {
        grid-template-columns: repeat(2, 1fr);
    }
}

@media (min-width: 1200px) {
    .achievements-grid {
        grid-template-columns: repeat(3, 1fr);
    }
}

.achievement-item {
    position: relative;
    display: block;
    text-decoration: none;
    border-radius: var(--radius-lg);
    overflow: hidden;
    box-shadow: var(--shadow-md);
    transition: all var(--transition-base);
    aspect-ratio: 1;
}

.achievement-item:hover {
    transform: translateY(-4px);
    box-shadow: var(--shadow-lg);
}

.achievement-image {
    width: 100%;
    height: 100%;
    background-size: cover;
    background-position: center;
    transition: transform var(--transition-slow);
}

.achievement-item:hover .achievement-image {
    transform: scale(1.05);
}

.achievement-placeholder {
    background: linear-gradient(135deg, var(--color-purple) 0%, var(--color-purple-dark) 100%);
    display: flex;
    align-items: center;
    justify-content: center;
}

.achievement-emoji {
    font-size: 4rem;
}

.achievement-overlay {
    position: absolute;
    bottom: 0;
    left: 0;
    right: 0;
    padding: var(--space-md);
    background: linear-gradient(to top, rgba(0,0,0,0.8) 0%, transparent 100%);
    opacity: 0;
    transition: opacity var(--transition-base);
}

.achievement-item:hover .achievement-overlay {
    opacity: 1;
}

.achievement-overlay h4 {
    color: var(--color-surface);
    font-size: 0.9rem;
    font-weight: 700;
    margin-bottom: var(--space-xs);
}

.achievement-overlay p {
    color: rgba(255, 255, 255, 0.9);
    font-size: 0.8rem;
}

/* ==================== EMPTY STATE ==================== */
.empty-state {
    text-align: center;
    padding: var(--space-2xl) var(--space-lg);
}

.empty-icon {
    font-size: 4rem;
    margin-bottom: var(--space-lg);
    opacity: 0.5;
}

.empty-state p {
    color: var(--text-secondary);
    font-size: 1rem;
    margin-bottom: var(--space-lg);
}

/* ==================== UTILITIES ==================== */
.text-center {
    text-align: center;
}

.mb-lg {
    margin-bottom: var(--space-lg);
}

.mb-xl {
    margin-bottom: var(--space-xl);
}

/* ==================== HABIT SUCCESS MODAL (aus dashboard.php) ==================== */

.section-header-right {
    display: flex;
    align-items: center;
    gap: var(--space-lg);
    flex-wrap: wrap;
}

.habit-progress-text {
    font-size: var(--font-size-sm);
    color: var(--text-secondary);
    font-weight: 600;
}

/* Lade-Animation für Habit-Toggle-Button */
.habit-btn-circle.loading {
    animation: spin 1s linear infinite;
}

/* Habit-Success-Modal: Zentral ausgerichtetes Bestätigungs-Popup */
#habit-success-modal.modal {
    position: fixed;
    top: 0;
    left: 0;
    right: 0;
    bottom: 0;
    background: rgba(0, 0, 0, 0.5);
    display: flex;
    align-items: center;
    justify-content: center;
    z-index: 1000;
    padding: var(--space-md);
}

#habit-success-modal .modal-content {
    background: var(--color-surface);
    padding: var(--space-xl);
    border-radius: var(--radius-lg);
    max-width: 500px;
    width: 100%;
    text-align: center;
    box-shadow: var(--shadow-lg);
    animation: modalSlideIn 0.3s ease-out;
}

#habit-success-modal .modal-icon {
    font-size: 4rem;
    margin-bottom: var(--space-md);
    line-height: 1;
}

#habit-success-modal .modal-content h2 {
    font-size: var(--font-size-xl);
    color: var(--text-primary);
    margin-bottom: var(--space-md);
}

/* Streak-Badge im Habit-Erfolgs-Modal */
#habit-success-modal .habit-streak {
    display: inline-flex;
    align-items: center;
    gap: var(--space-sm);
    padding: var(--space-sm) var(--space-lg);
    background: linear-gradient(135deg, var(--color-streak) 0%, var(--color-streak-dark) 100%);
    color: var(--color-surface);
    border-radius: var(--radius-lg);
    font-size: var(--font-size-lg);
    font-weight: 700;
    margin-bottom: var(--space-lg);
    box-shadow: 0 4px 12px rgba(255, 87, 34, 0.3);
}

@media (max-width: 768px) {
    .section-header-right {
        width: 100%;
        justify-content: space-between;
    }

    #habit-success-modal .modal-content {
        padding: var(--space-lg);
    }

    #habit-success-modal .modal-icon {
        font-size: 3rem;
    }
}

/* ==================== PRINT STYLES ==================== */
@media print {
    .dashboard-container {
        max-width: 100%;
        padding: 0;
    }
    
    .stat-card-v2,
    .action-card,
    .content-section {
        box-shadow: none;
        border: 1px solid var(--gray-300);
    }
    
    .period-toggle-wrapper,
    .btn,
    .habit-btn {
        display: none;
    }
}
