:root {
    --goalaura-purple: #6B46C1;
    --goalaura-purple-light: #8B5CF6;
    --goalaura-purple-dark: #553C9A;
    --goalaura-gradient-start: #3B2667;
    --goalaura-gradient-end: #7C3AED;
}

body {
    min-height: 100vh;
}

.bg-goalaura {
    background: linear-gradient(135deg, var(--goalaura-gradient-start) 0%, var(--goalaura-purple) 50%, var(--goalaura-gradient-end) 100%) !important;
}

.text-goalaura {
    color: var(--goalaura-purple) !important;
}

.btn-primary {
    background: linear-gradient(135deg, var(--goalaura-purple) 0%, var(--goalaura-purple-light) 100%);
    border-color: var(--goalaura-purple);
}

.btn-primary:hover {
    background: linear-gradient(135deg, var(--goalaura-purple-dark) 0%, var(--goalaura-purple) 100%);
    border-color: var(--goalaura-purple-dark);
}

.landing-hero {
    background: linear-gradient(135deg, var(--goalaura-gradient-start) 0%, var(--goalaura-purple) 50%, var(--goalaura-gradient-end) 100%);
    min-height: 400px;
    border-radius: 0 0 50px 50px;
    margin: -1rem -1rem 2rem -1rem;
    padding: 3rem 1rem !important;
}

.card {
    box-shadow: 0 0.125rem 0.25rem rgba(0, 0, 0, 0.075);
}

[data-bs-theme="dark"] .card {
    background-color: #212529;
    border-color: #495057;
}

[data-bs-theme="dark"] .bg-goalaura {
    background: linear-gradient(135deg, #2D1B4E 0%, #553C9A 50%, #6B46C1 100%) !important;
}

.progress {
    height: 20px;
}

.badge {
    font-weight: 500;
}

.list-group-item {
    border-left: none;
    border-right: none;
}

.list-group-item:first-child {
    border-top: none;
}

.list-group-item:last-child {
    border-bottom: none;
}

.nav-link {
    cursor: pointer;
}

.modal-backdrop.show {
    opacity: 0.5;
}

.navbar-brand img {
    border-radius: 4px;
}

[data-bs-theme="dark"] footer {
    background: linear-gradient(135deg, #2D1B4E 0%, #553C9A 50%, #6B46C1 100%) !important;
}

[data-bs-theme="dark"] footer p,
[data-bs-theme="dark"] footer a {
    color: rgba(255, 255, 255, 0.9) !important;
}

[data-bs-theme="dark"] footer a:hover {
    color: rgba(255, 255, 255, 1) !important;
    text-decoration: underline;
}
