html {
  font-size: 14px;
}

@media (min-width: 768px) {
  html {
    font-size: 16px;
  }
}

.btn:focus, .btn:active:focus, .btn-link.nav-link:focus, .form-control:focus, .form-check-input:focus {
  box-shadow: 0 0 0 0.1rem white, 0 0 0 0.25rem #258cfb;
}

html {
  position: relative;
  min-height: 100%;
}

body {
  margin-bottom: 60px;
}

.form-floating > .form-control-plaintext::placeholder, .form-floating > .form-control::placeholder {
  color: var(--bs-secondary-color);
  text-align: end;
}

.form-floating > .form-control-plaintext:focus::placeholder, .form-floating > .form-control:focus::placeholder {
  text-align: start;
}

.grayscale-debug {
    filter: grayscale(100%);
}

/* Default theme */
:root {
    --hero-bg: linear-gradient(135deg, #007cd4 0%, #003aa5 100%);
    --hero-fg: #ffffff;
    --hero-border: rgba(255, 255, 255, 0.18);
    --hero-overlay-from: rgba(255, 255, 255, 0.08);
    --hero-overlay-mid: rgba(255, 255, 255, 0.04);
    --hero-overlay-to: transparent;
    --hero-subtext: rgba(255, 255, 255, 0.75);
    --metric-bg: rgba(255, 255, 255, 0.12);
    --metric-border: rgba(255, 255, 255, 0.35);
    --metric-label: rgba(255, 255, 255, 0.70);
    --metric-value: #ffffff;
    --cta-fg: #ffffff;
    --cta-border: rgba(255, 255, 255, 0.55);
    --cta-bg-hover: rgba(255, 255, 255, 0.20);
    --cta-border-hover: #ffffff;
    /* base card */
    --card-bg: #ffffff;
    --card-fg: #212529;
    --card-border: rgba(0, 0, 0, 0.10);
    /* badges */
    --badge-primary-bg: #007CD4;
    --badge-secondary-bg: #D2D2D2;
    --badge-success-bg: #01924B;
    --badge-danger-bg: #CF202D;
    --badge-warning-bg: #F9A334;
    --badge-info-bg: #17C4FB;
    --badge-light-bg: #F8F9FA;
    --badge-dark-bg: #01001A;
    --badge-primary-color: #ffffff;
    --badge-secondary-color: #01001A;
    --badge-success-color: #ffffff;
    --badge-danger-color: #ffffff;
    --badge-warning-color: #01001A;
    --badge-info-color: #01001A;
    --badge-light-color: #01001A;
    --badge-dark-color: #ffffff;
    --badge-primary-border: #007CD4;
    --badge-secondary-border: #D2D2D2;
    --badge-success-border: #01924B;
    --badge-danger-border: #CF202D;
    --badge-warning-border: #F9A334;
    --badge-info-border: #17C4FB;
    --badge-light-border: #E2E6EA;
    --badge-dark-border: #01001A;
    --bg-primary: #007CD4;
    --bg-secondary: #D2D2D2;
    --bg-success: #01924B;
    --bg-danger: #CF202D;
    --bg-warning: #F9A334;
    --bg-info: #17C4FB;
    --bg-light: #F8F9FA;
    --bg-dark: #01001A;
}

/* Pension theme */
[data-theme="pension"] {
    --hero-bg: #01001A;
    --hero-fg: #ffffff;
    --hero-border: rgba(255, 255, 255, 0.12);
    --hero-overlay-from: rgba(0, 58, 165, 0.3);
    --hero-overlay-mid: rgba(0, 58, 165, 0.1);
    --hero-overlay-to: transparent;
    --hero-subtext: rgba(255, 255, 255, 0.7);
    --metric-bg: rgba(255, 255, 255, 0.08);
    --metric-border: rgba(0, 58, 165, 1);
    --metric-label: rgba(255, 255, 255, 0.55);
    --metric-value: #ffffff;
    --cta-fg: #ffffff;
    --cta-bg: rgba(0, 123, 255, 0.15);
    --cta-border: rgba(0, 58, 165, 1);
    --cta-bg-hover: rgba(0, 123, 255, 0.6);
    --cta-border-hover: #003AA5;
    /* base card in pension theme */
    --card-bg: #02031f;
    --card-fg: #ffffff;
    --card-border: rgba(255, 255, 255, 0.18);
    --badge-primary-bg: #003AA5;
    --badge-primary-color: #ffffff;
    --badge-primary-border: #003AA5;
    --badge-secondary-bg: #4B5A7D;
    --badge-secondary-color: #ffffff;
    --badge-secondary-border: #4B5A7D;
    --badge-info-bg: #007CD4;
    --badge-info-color: #ffffff;
    --badge-info-border: #007CD4;
    --bg-primary: #003AA5;
    --bg-secondary: #4B5A7D;
    --bg-info: #007CD4;
}

/* Health theme */
[data-theme="health"] {
    --hero-bg: #01001A;
    --hero-fg: #ffffff;
    --hero-border: rgba(255, 255, 255, 0.12);
    --hero-overlay-from: rgba(78, 43, 128, 0.30);
    --hero-overlay-mid: rgba(166, 69, 214, 0.10);
    --hero-overlay-to: transparent;
    --hero-subtext: rgba(255, 255, 255, 0.70);
    --metric-bg: rgba(255, 255, 255, 0.10);
    --metric-border: rgba(78, 43, 128, 1);
    --metric-label: rgba(255, 255, 255, 0.60);
    --metric-value: #ffffff;
    --cta-fg: #ffffff;
    --cta-bg: rgba(78, 43, 128, 0.25);
    --cta-border: rgba(78, 43, 128, 1);
    --cta-bg-hover: rgba(78, 43, 128, 0.60);
    --cta-border-hover: #4E2B80;
    /* base card in health theme */
    --card-bg: #140c24;
    --card-fg: #ffffff;
    --card-border: rgba(255, 255, 255, 0.18);
    --badge-primary-bg: #4E2B80;
    --badge-primary-color: #ffffff;
    --badge-primary-border: #4E2B80;
    --badge-secondary-bg: #A64D9D;
    --badge-secondary-color: #ffffff;
    --badge-secondary-border: #A64D9D;
    --badge-info-bg: #A64D9D;
    --badge-info-color: #ffffff;
    --badge-info-border: #A64D9D;
    --bg-primary: #4E2B80;
    --bg-secondary: #A64D9D;
    --bg-info: #A64D9D;
}

.bg-primary {
    background-color: var(--bg-primary) !important;
    color: #fff;
}

.bg-secondary {
    background-color: var(--bg-secondary) !important;
    color: #000;
}

.bg-success {
    background-color: var(--bg-success) !important;
    color: #fff;
}

.bg-danger {
    background-color: var(--bg-danger) !important;
    color: #fff;
}

.bg-warning {
    background-color: var(--bg-warning) !important;
    color: #000;
}

.bg-info {
    background-color: var(--bg-info) !important;
    color: #000;
}

.bg-light {
    background-color: var(--bg-light) !important;
    color: #000;
}

.bg-dark {
    background-color: var(--bg-dark) !important;
    color: #fff;
}

.card {
    width: auto;
    margin-bottom: 1.5rem;
    border-radius: 0.75rem;
    border: 1px solid var(--card-border);
    background-color: var(--card-bg);
    color: var(--card-fg);
    box-shadow: none;
}

    .card .card-header {
        display: flex;
        align-items: center;
        justify-content: space-between;
        gap: 0.75rem;
        border-bottom-color: transparent;
        background: transparent;
        font-weight: 500;
    }

        .card .card-header .card-header-left {
            display: flex;
            align-items: center;
            gap: 0.75rem;
        }

        .card .card-header .card-header-right {
            display: flex;
            align-items: center;
            gap: 0.75rem;
        }

    .card .card-body {
        padding: 1rem;
    }

/* ============================================
   HERO CARD BASE
   ============================================ */

    .card.card-hero {
        width: 100%;
        display: block;
        position: relative;
        overflow: hidden;
        border-radius: 1rem;
        border: 1px solid var(--hero-border);
        background: var(--hero-bg);
        color: var(--hero-fg);
        padding: 1.25rem;
    }

    /* Overlay gradient */
    .card.card-hero::before {
        content: "";
        position: absolute;
        inset: 0;
        background: linear-gradient( to bottom right, var(--hero-overlay-from), var(--hero-overlay-mid), var(--hero-overlay-to) );
        z-index: 0;
    }

    .card.card-hero > .card-header,
    .card.card-hero > .card-body {
        position: relative;
        z-index: 1;
    }

    /* ============================================
   HEADER
   ============================================ */

        .card.card-hero .card-header {
            color: var(--hero-fg);
        }

    /* ============================================
   BODY
   ============================================ */

    .card.card-hero .card-title {
        color: var(--hero-fg);
    }

        .card.card-hero .card-title .fs-6 {
            color: var(--hero-subtext);
        }

        .card.card-hero p.text-muted, small.text-muted {
            color: var(--hero-subtext) !important;
        }
        /* ============================================
   METRIC ROW / INNER CARDS
   ============================================ */

        .card.card-hero .metrics-row {
            display: grid;
            width: 100%;
            gap: 0.75rem; /* similar to Bootstrap gap-3 */
            grid-template-columns: repeat(3, minmax(0, 1fr)); /* up to 3 across on desktop */
        }

            /* If there is exactly 1 item in the last row (i.e. 4, 7, 10… total),
   make that last item span the full width */
            .card.card-hero .metrics-row > .inner-card:last-child:nth-child(3n + 1) {
                grid-column: 1 / -1;
            }

/* Optional: responsive stacking on small screens */
@media (max-width: 768px) {
    .card.card-hero .metrics-row {
        grid-template-columns: 1fr;
    }
}

/* Inner card styling */

.card.card-hero .inner-card {
    width: 100%;
    border-radius: 0.75rem;
    background: var(--metric-bg);
    border: 1px solid var(--metric-border);
    box-shadow: none;
}

    .card.card-hero .inner-card p.text-muted, small.text-muted {
        color: var(--metric-label) !important;
    }

    .card.card-hero .inner-card p.fw-bold {
        color: var(--metric-value);
    }

    /* ============================================
   CTA BUTTON
   ============================================ */

.card.card-hero .card-actions {
    margin-top: 0.75rem;
    display: grid;
    width: 100%;
}

    .card.card-hero .card-actions .btn-outline-primary {
        border-color: var(--cta-border);
        color: var(--cta-fg);
        background: var(--cta-bg);
    }

        .card.card-hero .card-actions .btn-outline-primary:hover {
            border-color: var(--cta-border-hover);
            background: var(--cta-bg-hover);
            color: var(--cta-fg);
        }

/* ============================================
   BADGE BASE
   ============================================ */

.badge {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    padding: 0.25rem 0.6rem;
    border-radius: 999px;
    font-size: 0.75rem;
    font-weight: 600;
    line-height: 1;
    border: 1px solid transparent;
    letter-spacing: 0.02em;
}

/* Solid badges */

.badge-primary {
    background-color: var(--badge-primary-bg);
    color: var(--badge-primary-color);
    border-color: var(--badge-primary-border);
}

.badge-secondary {
    background-color: var(--badge-secondary-bg);
    color: var(--badge-secondary-color);
    border-color: var(--badge-secondary-border);
}

.badge-success {
    background-color: var(--badge-success-bg);
    color: var(--badge-success-color);
    border-color: var(--badge-success-border);
}

.badge-danger {
    background-color: var(--badge-danger-bg);
    color: var(--badge-danger-color);
    border-color: var(--badge-danger-border);
}

.badge-warning {
    background-color: var(--badge-warning-bg);
    color: var(--badge-warning-color);
    border-color: var(--badge-warning-border);
}

.badge-info {
    background-color: var(--badge-info-bg);
    color: var(--badge-info-color);
    border-color: var(--badge-info-border);
}

.badge-light {
    background-color: var(--badge-light-bg);
    color: var(--badge-light-color);
    border-color: var(--badge-light-border);
}

.badge-dark {
    background-color: var(--badge-dark-bg);
    color: var(--badge-dark-color);
    border-color: var(--badge-dark-border);
}