:root {
    --djana-blue: #0d6efd;
    --djana-blue-dark: #0a58ca;
    --djana-page: #f5f8fc;
}

html,
body {
    min-height: 100%;
}

body {
    background: var(--djana-page);
    color: #1f2937;
    padding-top: 72px;
}

.page-shell {
    min-height: calc(100vh - 130px);
}

.navbar-brand {
    letter-spacing: 0;
}

.navbar.fixed-top {
    z-index: 1030;
}

.home-hero {
    min-height: calc(100vh - 180px);
}

.home-kicker {
    text-transform: uppercase;
}

.account-visual {
    background: #ffffff;
    border: 1px solid rgba(13, 110, 253, 0.12);
    border-radius: 8px;
    padding: 1.5rem;
}

.visual-topbar {
    border-bottom: 1px solid #e5e7eb;
    display: flex;
    gap: 0.5rem;
    margin: -0.25rem 0 1.5rem;
    padding-bottom: 1rem;
}

.visual-topbar span {
    background: #dbeafe;
    border-radius: 50%;
    display: block;
    height: 12px;
    width: 12px;
}

.visual-profile {
    align-items: center;
    display: flex;
    gap: 1rem;
    margin-bottom: 1.5rem;
}

.visual-avatar {
    align-items: center;
    background: var(--djana-blue);
    border-radius: 50%;
    color: #ffffff;
    display: flex;
    font-size: 2rem;
    font-weight: 700;
    height: 76px;
    justify-content: center;
    width: 76px;
}

.visual-line {
    background: #dbeafe;
    border-radius: 999px;
    height: 12px;
    margin: 0.5rem 0;
    width: 180px;
}

.visual-line-lg {
    background: #93c5fd;
    width: 240px;
}

.visual-grid {
    display: grid;
    gap: 1rem;
    grid-template-columns: repeat(2, minmax(0, 1fr));
}

.visual-tile,
.home-feature {
    background: #ffffff;
    border: 1px solid rgba(13, 110, 253, 0.12);
    border-radius: 8px;
    padding: 1.25rem;
}

.visual-tile strong,
.visual-tile span {
    display: block;
}

.visual-tile span {
    color: #6b7280;
    font-size: 0.95rem;
    margin-top: 0.25rem;
}

.home-band {
    background: #ffffff;
    border: 1px solid rgba(13, 110, 253, 0.12);
    border-radius: 8px;
    padding-left: 1.5rem;
    padding-right: 1.5rem;
}

.home-checks {
    display: grid;
    gap: 0.75rem;
    grid-template-columns: repeat(2, minmax(0, 1fr));
}

.home-checks div {
    background: #f5f8fc;
    border-left: 4px solid var(--djana-blue);
    border-radius: 8px;
    font-weight: 600;
    padding: 0.9rem 1rem;
}

.auth-card,
.card {
    border: 1px solid rgba(13, 110, 253, 0.12);
    border-radius: 8px;
}

.auth-kicker {
    color: var(--djana-blue);
    display: inline-block;
    font-size: 0.76rem;
    font-weight: 700;
    letter-spacing: 0;
    margin-bottom: 0.75rem;
    text-transform: uppercase;
}

.activation-email {
    background: #eff6ff;
    border: 1px solid #dbeafe;
    border-radius: 8px;
    color: #1d4ed8;
    display: inline-block;
    font-weight: 700;
    max-width: 100%;
    overflow-wrap: anywhere;
    padding: 0.75rem 1rem;
}

.form-control:focus {
    border-color: var(--djana-blue);
    box-shadow: 0 0 0 0.2rem rgba(13, 110, 253, 0.15);
}

.btn-primary {
    background: var(--djana-blue);
    border-color: var(--djana-blue);
}

.btn-primary:hover,
.btn-primary:focus {
    background: var(--djana-blue-dark);
    border-color: var(--djana-blue-dark);
}

.dashboard-header {
    border-color: rgba(13, 110, 253, 0.16) !important;
}

.profile-avatar {
    align-items: center;
    border-radius: 50%;
    display: flex;
    flex: 0 0 auto;
    height: 72px;
    justify-content: center;
    object-fit: cover;
    width: 72px;
}

.profile-avatar-lg {
    height: 112px;
    width: 112px;
}

.placeholder-avatar {
    background: #e7f0ff;
    color: var(--djana-blue);
    font-size: 1.75rem;
    font-weight: 700;
}

.profile-avatar-lg.placeholder-avatar {
    font-size: 2.5rem;
}

.info-list dt {
    color: #4b5563;
    font-weight: 600;
}

.info-list dd {
    overflow-wrap: anywhere;
}

@media (max-width: 575.98px) {
    body {
        padding-top: 64px;
    }

    .card-body {
        padding: 1.25rem !important;
    }

    .visual-grid,
    .home-checks {
        grid-template-columns: 1fr;
    }

    .visual-line,
    .visual-line-lg {
        max-width: 100%;
        width: 170px;
    }
}
