/* ═══════════════════════════════════════════════════════════════
   MyWorkoutBuddy — Brand Tokens  (Vapor-first)
   Thin override layer on Bootswatch Vapor 5.3.3
   ═══════════════════════════════════════════════════════════════ */

:root {
    /* ── Bootstrap font override (Vapor defaults to Lato) ──────── */
    --bs-font-sans-serif:   'Inter', system-ui, -apple-system, 'Segoe UI', Roboto, sans-serif;
    --bs-body-font-family:  var(--bs-font-sans-serif);

    /* ── Bootstrap link color (drives <a> and .btn-link) ───────── */
    --bs-link-color:            #D4FF00;
    --bs-link-hover-color:      #B8E600;
    --bs-link-color-rgb:        212, 255, 0;

    /* ── Brand palette ─────────────────────────────────────────── */
    --brand-primary:        #7C3AED;
    --brand-primary-hover:  #6D28D9;
    --brand-primary-dark:   #5B21B6;
    --brand-accent:         #D4FF00;
    --brand-accent-hover:   #B8E600;
    --brand-accent-muted:   #C8F000;
    --brand-dark:           #170229;
    --brand-dark-soft:      #261e35;
    --brand-dark-surface:   #2e2540;

    /* ── Gradients ──────────────────────────────────────────────── */
    --gradient-nav:         linear-gradient(180deg, #261e35 0%, #170229 100%);
    --gradient-brand:       linear-gradient(135deg, #7C3AED 0%, #5B21B6 50%, #170229 100%);
    --gradient-accent:      linear-gradient(90deg, #7C3AED, #D4FF00);

    /* ── Surfaces (aligned to Vapor dark) ─────────────────────── */
    --surface-body:         #170229;
    --surface-card:         #261e35;
    --surface-card-hover:   #352c48;
    --surface-nav:          var(--brand-dark);
    --surface-top-bar:      #1f0a3d;
    --surface-input:        #261e35;
    --surface-border:       #495057;

    /* ── Text ──────────────────────────────────────────────────── */
    --text-primary:         #F0F0F5;
    --text-secondary:       #a9a9b8;
    --text-on-dark:         #FAFAFA;
    --text-on-dark-muted:   #A0A0B0;
    --text-on-primary:      #FFFFFF;
    --text-on-accent:       #0F0F0F;

    /* ── Semantic (Vapor-aligned) ─────────────────────────────── */
    --color-success:        #3cf281;
    --color-success-soft:   rgba(60, 242, 129, 0.15);
    --color-warning:        #ffc107;
    --color-warning-soft:   rgba(255, 193, 7, 0.15);
    --color-danger:         #e44c55;
    --color-danger-soft:    rgba(228, 76, 85, 0.15);
    --color-info:           #1ba2f6;
    --color-info-soft:      rgba(27, 162, 246, 0.15);

    /* ── Typography ────────────────────────────────────────────── */
    --font-family:          'Inter', system-ui, -apple-system, 'Segoe UI', Roboto, sans-serif;
    --font-size-xs:         0.75rem;
    --font-size-sm:         0.875rem;
    --font-size-base:       1rem;
    --font-size-lg:         1.125rem;
    --font-size-xl:         1.25rem;

    /* ── Spacing ───────────────────────────────────────────────── */
    --space-1:  0.25rem;
    --space-2:  0.5rem;
    --space-3:  0.75rem;
    --space-4:  1rem;
    --space-5:  1.25rem;
    --space-6:  1.5rem;
    --space-8:  2rem;

    /* ── Borders & Radius ──────────────────────────────────────── */
    --radius-sm:  0.375rem;
    --radius-md:  0.5rem;
    --radius-lg:  0.75rem;
    --radius-xl:  1rem;
    --radius-full: 9999px;

    /* ── Shadows ────────────────────────────────────────────────── */
    --shadow-sm:  0 1px 3px rgba(0, 0, 0, 0.3);
    --shadow-md:  0 4px 12px rgba(0, 0, 0, 0.4);
    --shadow-lg:  0 8px 24px rgba(0, 0, 0, 0.5);

    /* ── Transitions ───────────────────────────────────────────── */
    --transition-fast:  150ms ease;
    --transition-base:  250ms ease;
}


/* ═══════════════════════════════════════════════════════════════
   Global base — Inter font + brand link colors
   ═══════════════════════════════════════════════════════════════ */

html, body {
    font-family: var(--bs-font-sans-serif);
}

a {
    color: var(--brand-accent);
    transition: color var(--transition-fast);
}

a:hover {
    color: var(--brand-accent-hover);
}

h1:focus {
    outline: none;
}

.content {
    padding-top: 1.1rem;
}


/* ═══════════════════════════════════════════════════════════════
   Brand buttons — accent + primary purple override
   ═══════════════════════════════════════════════════════════════ */

.btn-primary {
    --bs-btn-bg: var(--brand-primary);
    --bs-btn-border-color: var(--brand-primary);
    --bs-btn-hover-bg: var(--brand-primary-hover);
    --bs-btn-hover-border-color: var(--brand-primary-dark);
    --bs-btn-active-bg: var(--brand-primary-dark);
    --bs-btn-active-border-color: var(--brand-primary-dark);
}

.btn-outline-primary {
    --bs-btn-color: var(--brand-primary);
    --bs-btn-border-color: var(--brand-primary);
    --bs-btn-hover-bg: var(--brand-primary);
    --bs-btn-hover-border-color: var(--brand-primary);
    --bs-btn-active-bg: var(--brand-primary-dark);
    --bs-btn-active-border-color: var(--brand-primary-dark);
}

.btn-accent {
    color: var(--text-on-accent);
    background-color: var(--brand-accent);
    border: none;
    font-weight: 600;
    transition: background-color var(--transition-fast), box-shadow var(--transition-fast);
}

.btn-accent:hover, .btn-accent:active {
    background-color: var(--brand-accent-hover);
    box-shadow: 0 0 0 3px rgba(212, 255, 0, 0.3);
}

.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 var(--brand-primary);
}


/* ═══════════════════════════════════════════════════════════════
   Cards — subtle border visibility on dark backgrounds
   ═══════════════════════════════════════════════════════════════ */

.card {
    --bs-card-border-color: rgba(108, 117, 125, 0.25);
}

.subscription-highlight {
    border-color: var(--brand-accent) !important;
    box-shadow: 0 0 20px 4px rgba(212, 255, 0, 0.18),
                0 0 6px 1px rgba(212, 255, 0, 0.25);
    background: linear-gradient(180deg, rgba(212, 255, 0, 0.05) 0%, transparent 40%);
}

.subscription-active {
    border-color: var(--color-success) !important;
    box-shadow: 0 0 12px 2px rgba(60, 242, 129, 0.15);
}

.bg-accent {
    background-color: var(--brand-accent) !important;
    color: var(--text-on-accent) !important;
}

.bg-accent-subtle {
    background: rgba(212, 255, 0, 0.12);
}


/* ═══════════════════════════════════════════════════════════════
   Progress bars — brand gradient
   ═══════════════════════════════════════════════════════════════ */

.progress-bar {
    background: var(--gradient-accent);
}


/* ═══════════════════════════════════════════════════════════════
   Badges — accent variant
   ═══════════════════════════════════════════════════════════════ */

.badge.bg-accent {
    background-color: var(--brand-accent) !important;
    color: var(--text-on-accent) !important;
    font-weight: 600;
}


/* ═══════════════════════════════════════════════════════════════
   Text accent — brand highlight for key figures / labels
   ═══════════════════════════════════════════════════════════════ */

.text-accent       { color: var(--brand-accent) !important; }
.text-accent-muted { color: var(--brand-accent-muted) !important; }


/* ═══════════════════════════════════════════════════════════════
   Day type indicators — rest vs workout color coding
   ═══════════════════════════════════════════════════════════════ */

.day-rest {
    background: rgba(108, 117, 125, 0.04) !important;
}

.day-workout {
    border-left: 3px solid var(--brand-accent) !important;
    background: rgba(212, 255, 0, 0.06) !important;
}

.day-today {
    border-color: var(--brand-accent) !important;
    box-shadow:
        0 0 6px 1px rgba(212, 255, 0, 0.5),
        0 0 14px 3px rgba(212, 255, 0, 0.25);
}

/* Mini-grid day cells (dashboard "this week") */
.day-cell-rest {
    background: rgba(108, 117, 125, 0.06);
}

.day-cell-workout {
    background: rgba(212, 255, 0, 0.06);
}

.day-cell-today {
    border-color: var(--brand-accent) !important;
    box-shadow:
        0 0 6px 1px rgba(212, 255, 0, 0.5),
        0 0 14px 3px rgba(212, 255, 0, 0.25);
}


/* ═══════════════════════════════════════════════════════════════
   Forms — rounded inputs (Vapor default 0.15 rem is too square)
   ═══════════════════════════════════════════════════════════════ */

.form-control,
.form-select {
    border-radius: var(--bs-border-radius-lg);
}

/* ── Blazor validation ─────────────────────────────────────── */

.valid.modified:not([type=checkbox]) {
    outline: 1px solid var(--color-success);
}

.invalid {
    outline: 1px solid var(--color-danger);
}

.validation-message {
    color: var(--color-danger);
}

.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;
}


/* ═══════════════════════════════════════════════════════════════
   Layout utilities — extracted from repeated inline styles
   ═══════════════════════════════════════════════════════════════ */

.progress-thin  { height: 6px; }
.progress-thinner { height: 4px; }

.status-icon {
    width: 2.5rem;
    height: 2.5rem;
}

.status-icon-lg {
    width: 3rem;
    height: 3rem;
}

.text-xxs  { font-size: 0.65rem; }
.text-xs   { font-size: 0.7rem; }
.text-hint { font-size: 0.75rem; }

.tracking-wide { letter-spacing: 0.04em; }

.btn-skip {
    text-decoration: none;
    font-size: 0.85rem;
}

.narrow-container { max-width: 500px; }

.cursor-pointer { cursor: pointer; }


/* ═══════════════════════════════════════════════════════════════
   Error boundaries
   ═══════════════════════════════════════════════════════════════ */

.blazor-error-boundary {
    background: url(data:image/svg+xml;base64,PHN2ZyB3aWR0aD0iNTYiIGhlaWdodD0iNDkiIHhtbG5zPSJodHRwOi8vd3d3LnczLm9yZy8yMDAwL3N2ZyIgeG1sbnM6eGxpbms9Imh0dHA6Ly93d3cudzMub3JnLzE5OTkveGxpbmsiIG92ZXJmbG93PSJoaWRkZW4iPjxkZWZzPjxjbGlwUGF0aCBpZD0iY2xpcDAiPjxyZWN0IHg9IjIzNSIgeT0iNTEiIHdpZHRoPSI1NiIgaGVpZ2h0PSI0OSIvPjwvY2xpcFBhdGg+PC9kZWZzPjxnIGNsaXAtcGF0aD0idXJsKCNjbGlwMCkiIHRyYW5zZm9ybT0idHJhbnNsYXRlKC0yMzUgLTUxKSI+PHBhdGggZD0iTTI2My41MDYgNTFDMjY0LjcxNyA1MSAyNjUuODEzIDUxLjQ4MzcgMjY2LjYwNiA1Mi4yNjU4TDI2Ny4wNTIgNTIuNzk4NyAyNjcuNTM5IDUzLjYyODMgMjkwLjE4NSA5Mi4xODMxIDI5MC41NDUgOTIuNzk1IDI5MC42NTYgOTIuOTk2QzI5MC44NzcgOTMuNTEzIDI5MSA5NC4wODE1IDI5MSA5NC42NzgyIDI5MSA5Ny4wNjUxIDI4OS4wMzggOTkgMjg2LjYxNyA5OUwyNDAuMzgzIDk5QzIzNy45NjMgOTkgMjM2IDk3LjA2NTEgMjM2IDk0LjY3ODIgMjM2IDk0LjM3OTkgMjM2LjAzMSA5NC4wODg2IDIzNi4wODkgOTMuODA3MkwyMzYuMzM4IDkzLjAxNjIgMjM2Ljg1OCA5Mi4xMzE0IDI1OS40NzMgNTMuNjI5NCAyNTkuOTYxIDUyLjc5ODUgMjYwLjQwNyA1Mi4yNjU4QzI2MS4yIDUxLjQ4MzcgMjYyLjI5NiA1MSAyNjMuNTA2IDUxWk0yNjMuNTg2IDY2LjAxODNDMjYwLjczNyA2Ni4wMTgzIDI1OS4zMTMgNjcuMTI0NSAyNTkuMzEzIDY5LjMzNyAyNTkuMzEzIDY5LjYxMDIgMjU5LjMzMiA2OS44NjA4IDI1OS4zNzEgNzAuMDg4N0wyNjEuNzk1IDg0LjAxNjEgMjY1LjM4IDg0LjAxNjEgMjY3LjgyMSA2OS43NDc1QzI2Ny44NiA2OS43MzA5IDI2Ny44NzkgNjkuNTg3NyAyNjcuODc5IDY5LjMxNzkgMjY3Ljg3OSA2Ny4xMTgyIDI2Ni40NDggNjYuMDE4MyAyNjMuNTg2IDY2LjAxODNaTTI2My41NzYgODYuMDU0N0MyNjEuMDQ5IDg2LjA1NDcgMjU5Ljc4NiA4Ny4zMDA1IDI1OS43ODYgODkuNzkyMSAyNTkuNzg2IDkyLjI4MzcgMjYxLjA0OSA5My41Mjk1IDI2My41NzYgOTMuNTI5NSAyNjYuMTE2IDkzLjUyOTUgMjY3LjM4NyA5Mi4yODM3IDI2Ny4zODcgODkuNzkyMSAyNjcuMzg3IDg3LjMwMDUgMjY2LjExNiA4Ni4wNTQ3IDI2My41NzYgODYuMDU0N1oiIGZpbGw9IiNGRkU1MDAiIGZpbGwtcnVsZT0iZXZlbm9kZCIvPjwvZz48L3N2Zz4=) no-repeat 1rem/1.8rem, var(--color-danger);
    padding: 1rem 1rem 1rem 3.7rem;
    color: white;
    border-radius: var(--radius-md);
}

    .blazor-error-boundary::after {
        content: "An error has occurred."
    }
