/* _content/SportCompiler.Web/Components/Layout/MainLayout.razor.rz.scp.css */
/* ============================================================================
   MainLayout Scoped Styles — Black Dashboard Inspired
   ============================================================================ */

.page[b-p9wtx2hegu] {
    position: relative;
    display: flex;
    flex-direction: column;
    min-height: 100vh;
}

main[b-p9wtx2hegu] {
    flex: 1;
    display: flex;
    flex-direction: column;
}

.sidebar[b-p9wtx2hegu] {
    background: linear-gradient(180deg, #1d1d2b 0%, #15152a 100%);
    z-index: 10;
}

.top-row[b-p9wtx2hegu] {
    background-color: var(--navbar-bg);
    border-bottom: 1px solid var(--toprow-border);
    justify-content: flex-end;
    height: 3.5rem;
    display: flex;
    align-items: center;
    z-index: 5;
    backdrop-filter: blur(10px);
    transition: background-color 0.3s ease, border-color 0.3s ease;
}

/* Theme toggle button */
.theme-toggle-btn[b-p9wtx2hegu] {
    display: inline-flex;
    align-items: center;
    gap: 0.4rem;
    padding: 0.3rem 0.75rem;
    font-size: 0.8rem;
    border-radius: 50rem;
    transition: all 0.25s ease;
}

.theme-icon[b-p9wtx2hegu] {
    font-size: 1rem;
    line-height: 1;
}

.theme-label[b-p9wtx2hegu] {
    font-size: 0.78rem;
    font-weight: 500;
}

/* User info area */
.user-info[b-p9wtx2hegu] {
    display: flex;
    align-items: center;
    gap: 0.5rem;
}

.user-avatar[b-p9wtx2hegu] {
    width: 2rem;
    height: 2rem;
    border-radius: 50%;
    background: linear-gradient(135deg, var(--accent) 0%, var(--accent-hover) 100%);
    color: #ffffff;
    font-size: 0.7rem;
    font-weight: 600;
    display: flex;
    align-items: center;
    justify-content: center;
    letter-spacing: 0.02em;
    text-transform: uppercase;
}

.user-name[b-p9wtx2hegu] {
    font-size: 0.82rem;
    font-weight: 500;
    color: var(--text-primary);
}

/* Responsive */
@media (max-width: 640.98px) {
    .top-row[b-p9wtx2hegu] {
        justify-content: space-between;
    }

    .user-name[b-p9wtx2hegu] {
        display: none;
    }

    .theme-label[b-p9wtx2hegu] {
        display: none;
    }
}

@media (min-width: 641px) {
    .page[b-p9wtx2hegu] {
        flex-direction: row;
    }

    .sidebar[b-p9wtx2hegu] {
        width: 260px;
        height: 100vh;
        position: sticky;
        top: 0;
        flex-shrink: 0;
    }

    .top-row[b-p9wtx2hegu] {
        position: sticky;
        top: 0;
        z-index: 5;
    }

    .top-row[b-p9wtx2hegu], article[b-p9wtx2hegu] {
        padding-left: 2rem !important;
        padding-right: 1.5rem !important;
    }
}

#blazor-error-ui[b-p9wtx2hegu] {
    color-scheme: light only;
    background: var(--bg-card);
    bottom: 0;
    box-shadow: 0 -2px 20px rgba(0, 0, 0, 0.2);
    box-sizing: border-box;
    display: none;
    left: 0;
    padding: 0.6rem 1.25rem 0.7rem 1.25rem;
    position: fixed;
    width: 100%;
    z-index: 1000;
    border-top: 3px solid var(--danger);
}

    #blazor-error-ui .dismiss[b-p9wtx2hegu] {
        cursor: pointer;
        position: absolute;
        right: 0.75rem;
        top: 0.5rem;
    }
/* _content/SportCompiler.Web/Components/Layout/NavMenu.razor.rz.scp.css */
/* ============================================================================
   NavMenu Scoped Styles — Black Dashboard Inspired
   ============================================================================ */

/* ---------- Brand / Logo ---------- */
.sidebar-brand[b-4nq8shdnpq] {
    padding: 1.5rem 1.5rem 1.25rem;
    border-bottom: 1px solid rgba(255, 255, 255, 0.08);
}

.sidebar-brand a[b-4nq8shdnpq] {
    display: flex;
    align-items: center;
    gap: 0.75rem;
    text-decoration: none;
    color: #ffffff;
}

.sidebar-brand a:hover[b-4nq8shdnpq] {
    text-decoration: none;
    color: #ffffff;
}

.brand-icon[b-4nq8shdnpq] {
    width: 2.25rem;
    height: 2.25rem;
    border-radius: 0.5rem;
    background: linear-gradient(135deg, #1d8cf8 0%, #1773d0 100%);
    color: #ffffff;
    font-size: 1.1rem;
    font-weight: 700;
    display: flex;
    align-items: center;
    justify-content: center;
    letter-spacing: -0.02em;
    box-shadow: 0 4px 10px rgba(29, 140, 248, 0.3);
    flex-shrink: 0;
}

.brand-text[b-4nq8shdnpq] {
    font-size: 1rem;
    font-weight: 600;
    letter-spacing: 0.02em;
    text-transform: uppercase;
    white-space: nowrap;
}

/* ---------- Mobile Toggle ---------- */
.navbar-toggler[b-4nq8shdnpq] {
    appearance: none;
    cursor: pointer;
    width: 3.5rem;
    height: 2.5rem;
    color: white;
    position: absolute;
    top: 0.75rem;
    right: 1rem;
    border: 1px solid rgba(255, 255, 255, 0.12);
    border-radius: 0.4285rem;
    background: url("data:image/svg+xml,%3csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 30 30'%3e%3cpath stroke='rgba%28255, 255, 255, 0.6%29' stroke-linecap='round' stroke-miterlimit='10' stroke-width='2' d='M4 7h22M4 15h22M4 23h22'/%3e%3c/svg%3e") no-repeat center/1.75rem rgba(255, 255, 255, 0.05);
    transition: all 0.25s ease;
}

.navbar-toggler:hover[b-4nq8shdnpq] {
    border-color: rgba(255, 255, 255, 0.25);
    background-color: rgba(255, 255, 255, 0.1);
}

.navbar-toggler:checked[b-4nq8shdnpq] {
    background-color: rgba(255, 255, 255, 0.15);
}

/* ---------- Section Labels ---------- */
.nav-section-label[b-4nq8shdnpq] {
    font-size: 0.68rem;
    font-weight: 600;
    text-transform: uppercase;
    letter-spacing: 0.1em;
    color: rgba(255, 255, 255, 0.3);
    padding: 1rem 1.5rem 0.4rem;
    margin-top: 0.25rem;
}

/* ---------- Nav Items ---------- */
.nav-item[b-4nq8shdnpq] {
    padding: 0;
}

    .nav-item:first-of-type[b-4nq8shdnpq] {
        padding-top: 0.75rem;
    }

    .nav-item[b-4nq8shdnpq]  .nav-link {
        color: rgba(255, 255, 255, 0.6);
        background: none;
        border: none;
        border-radius: 0.4285rem;
        display: flex;
        align-items: center;
        gap: 0.85rem;
        padding: 0.65rem 1.5rem;
        margin: 0.1rem 0.75rem;
        font-size: 0.82rem;
        font-weight: 400;
        text-transform: uppercase;
        letter-spacing: 0.02em;
        transition: all 0.25s ease;
        text-decoration: none;
        position: relative;
        width: calc(100% - 1.5rem);
    }

.nav-item[b-4nq8shdnpq]  .nav-link:hover {
    color: #ffffff;
    background-color: rgba(255, 255, 255, 0.08);
}

.nav-item[b-4nq8shdnpq]  a.active {
    color: #ffffff;
    background-color: rgba(29, 140, 248, 0.15);
}

.nav-item[b-4nq8shdnpq]  a.active::before {
    content: '';
    position: absolute;
    left: -0.75rem;
    top: 50%;
    transform: translateY(-50%);
    width: 3px;
    height: 55%;
    background: linear-gradient(180deg, #1d8cf8 0%, #1773d0 100%);
    border-radius: 0 3px 3px 0;
}

/* ---------- Nav Icon ---------- */
.nav-icon[b-4nq8shdnpq] {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 1.25rem;
    height: 1.25rem;
    flex-shrink: 0;
    opacity: 0.7;
    transition: opacity 0.2s ease;
}

.nav-item[b-4nq8shdnpq]  a.active .nav-icon,
.nav-item[b-4nq8shdnpq]  .nav-link:hover .nav-icon {
    opacity: 1;
}

/* ---------- Nav Scrollable ---------- */
.nav-scrollable[b-4nq8shdnpq] {
    display: none;
    padding-top: 0.5rem;
}

.navbar-toggler:checked ~ .nav-scrollable[b-4nq8shdnpq] {
    display: block;
}

@media (min-width: 641px) {
    .navbar-toggler[b-4nq8shdnpq] {
        display: none;
    }

    .nav-scrollable[b-4nq8shdnpq] {
        display: block;
        height: calc(100vh - 4.5rem);
        overflow-y: auto;
    }
}
/* _content/SportCompiler.Web/Components/Pages/Coach/ProgramBuilder.razor.rz.scp.css */
.calendar-grid[b-2tt6r2agae] {
    border-radius: 15px;
    overflow: hidden;
    border: 1px solid rgba(255, 255, 255, 0.1);
}

.calendar-header[b-2tt6r2agae] {
    display: grid;
    grid-template-columns: repeat(7, 1fr);
    text-align: center;
    font-weight: 600;
    font-size: 0.75rem;
    text-transform: uppercase;
    letter-spacing: 0.06em;
    color: rgba(255, 255, 255, 0.5);
}

.calendar-header > div[b-2tt6r2agae] {
    padding: 0.75rem;
    background: rgba(255, 255, 255, 0.03);
    border-bottom: 1px solid rgba(255, 255, 255, 0.1);
}

.calendar-week[b-2tt6r2agae] {
    display: grid;
    grid-template-columns: repeat(7, 1fr);
}

.calendar-day[b-2tt6r2agae] {
    background: rgba(255, 255, 255, 0.02);
    min-height: 130px;
    padding: 0.5rem;
    cursor: pointer;
    transition: background-color 0.15s ease;
    position: relative;
    border-right: 1px solid rgba(255, 255, 255, 0.05);
    border-bottom: 1px solid rgba(255, 255, 255, 0.05);
}

.calendar-day:last-child[b-2tt6r2agae] {
    border-right: none;
}

.calendar-day:hover[b-2tt6r2agae] {
    background-color: rgba(255, 255, 255, 0.05);
}

.calendar-day.has-sessions[b-2tt6r2agae] {
    border-left: 3px solid #1d8cf8;
}

.calendar-day.is-today[b-2tt6r2agae] {
    background-color: rgba(29, 140, 248, 0.06);
}

.day-header[b-2tt6r2agae] {
    display: flex;
    align-items: baseline;
    gap: 0.25rem;
    margin-bottom: 0.35rem;
}

.day-number[b-2tt6r2agae] {
    font-weight: 600;
    font-size: 0.95rem;
    color: rgba(255, 255, 255, 0.85);
}

.day-month[b-2tt6r2agae] {
    font-size: 0.65rem;
    color: rgba(255, 255, 255, 0.4);
    text-transform: uppercase;
}

.session-chip[b-2tt6r2agae] {
    background: rgba(29, 140, 248, 0.12);
    color: #1d8cf8;
    border-radius: 6px;
    padding: 0.25rem 0.5rem;
    font-size: 0.75rem;
    font-weight: 500;
    margin-bottom: 0.25rem;
    cursor: pointer;
    transition: background-color 0.15s ease;
    display: flex;
    justify-content: space-between;
    align-items: center;
}

.session-chip:hover[b-2tt6r2agae],
.session-chip.active[b-2tt6r2agae] {
    background: rgba(29, 140, 248, 0.25);
}

.exercise-count[b-2tt6r2agae] {
    font-size: 0.6rem;
    opacity: 0.7;
    margin-left: 0.25rem;
}

.add-session-btn[b-2tt6r2agae] {
    position: absolute;
    bottom: 0.25rem;
    right: 0.25rem;
    width: 1.5rem;
    height: 1.5rem;
    border-radius: 50%;
    border: 1px dashed rgba(255, 255, 255, 0.2);
    background: transparent;
    color: rgba(255, 255, 255, 0.4);
    font-size: 0.9rem;
    cursor: pointer;
    display: flex;
    align-items: center;
    justify-content: center;
    opacity: 0;
    transition: opacity 0.15s ease;
    line-height: 1;
}

.calendar-day:hover .add-session-btn[b-2tt6r2agae] {
    opacity: 1;
}

.add-session-btn:hover[b-2tt6r2agae] {
    border-color: #1d8cf8;
    color: #1d8cf8;
}

/* Exercise card within session editor */
.exercise-card[b-2tt6r2agae] {
    border: 1px solid rgba(255, 255, 255, 0.1);
    border-radius: 10px;
    padding: 0.75rem;
    background: rgba(255, 255, 255, 0.02);
}

.exercise-header[b-2tt6r2agae] {
    display: flex;
    align-items: center;
    margin-bottom: 0.5rem;
}

/* Sets table */
.sets-table[b-2tt6r2agae] {
    width: 100%;
    font-size: 0.8rem;
    margin-top: 0.5rem;
}

.sets-table th[b-2tt6r2agae] {
    font-size: 0.65rem;
    text-transform: uppercase;
    letter-spacing: 0.04em;
    color: rgba(255, 255, 255, 0.5);
    font-weight: 600;
    padding: 0.3rem 0.25rem;
    border-bottom: 1px solid rgba(255, 255, 255, 0.1);
}

.sets-table td[b-2tt6r2agae] {
    padding: 0.2rem 0.25rem;
    vertical-align: middle;
}

[b-2tt6r2agae] .sets-table input.form-control-sm {
    padding: 0.2rem 0.4rem;
    font-size: 0.8rem;
    height: auto;
}
/* _content/SportCompiler.Web/Components/Pages/Practitioner/WorkoutLog.razor.rz.scp.css */
.calendar-grid[b-n2v8kop6j0] {
    border-radius: 15px;
    overflow: hidden;
    border: 1px solid rgba(255, 255, 255, 0.1);
}

.calendar-header[b-n2v8kop6j0] {
    display: grid;
    grid-template-columns: repeat(7, 1fr);
    text-align: center;
    font-weight: 600;
    font-size: 0.75rem;
    text-transform: uppercase;
    letter-spacing: 0.06em;
    color: rgba(255, 255, 255, 0.5);
}

.calendar-header > div[b-n2v8kop6j0] {
    padding: 0.75rem;
    background: rgba(255, 255, 255, 0.03);
    border-bottom: 1px solid rgba(255, 255, 255, 0.1);
}

.calendar-week[b-n2v8kop6j0] {
    display: grid;
    grid-template-columns: repeat(7, 1fr);
}

.calendar-day[b-n2v8kop6j0] {
    background: rgba(255, 255, 255, 0.02);
    min-height: 130px;
    padding: 0.5rem;
    cursor: pointer;
    transition: background-color 0.15s ease;
    position: relative;
    border-right: 1px solid rgba(255, 255, 255, 0.05);
    border-bottom: 1px solid rgba(255, 255, 255, 0.05);
}

.calendar-day:last-child[b-n2v8kop6j0] {
    border-right: none;
}

.calendar-day:hover[b-n2v8kop6j0] {
    background-color: rgba(255, 255, 255, 0.05);
}

.calendar-day.has-sessions[b-n2v8kop6j0] {
    border-left: 3px solid #1d8cf8;
}

.calendar-day.is-today[b-n2v8kop6j0] {
    background-color: rgba(29, 140, 248, 0.06);
}

.day-header[b-n2v8kop6j0] {
    display: flex;
    align-items: baseline;
    gap: 0.25rem;
    margin-bottom: 0.35rem;
}

.day-number[b-n2v8kop6j0] {
    font-weight: 600;
    font-size: 0.95rem;
    color: rgba(255, 255, 255, 0.85);
}

.day-month[b-n2v8kop6j0] {
    font-size: 0.65rem;
    color: rgba(255, 255, 255, 0.4);
    text-transform: uppercase;
}

/* Add workout button on calendar day header */
.add-workout-btn[b-n2v8kop6j0] {
    margin-left: auto;
    background: none;
    border: 1px solid rgba(255, 255, 255, 0.15);
    color: rgba(255, 255, 255, 0.4);
    border-radius: 4px;
    width: 18px;
    height: 18px;
    font-size: 0.75rem;
    line-height: 1;
    cursor: pointer;
    display: flex;
    align-items: center;
    justify-content: center;
    padding: 0;
    transition: all 0.15s ease;
    opacity: 0;
}

.calendar-day:hover .add-workout-btn[b-n2v8kop6j0] {
    opacity: 1;
}

.add-workout-btn:hover[b-n2v8kop6j0] {
    background: rgba(157, 78, 221, 0.2);
    border-color: #9d4edd;
    color: #9d4edd;
}

/* Session chips - blue for pending, green for logged */
.session-chip[b-n2v8kop6j0] {
    background: rgba(29, 140, 248, 0.12);
    color: #1d8cf8;
    border-radius: 6px;
    padding: 0.25rem 0.5rem;
    font-size: 0.75rem;
    font-weight: 500;
    margin-bottom: 0.25rem;
    cursor: pointer;
    transition: background-color 0.15s ease;
    display: flex;
    justify-content: space-between;
    align-items: center;
}

.session-chip:hover[b-n2v8kop6j0],
.session-chip.active[b-n2v8kop6j0] {
    background: rgba(29, 140, 248, 0.25);
}

.session-chip.logged[b-n2v8kop6j0] {
    background: rgba(0, 191, 154, 0.12);
    color: #00bf9a;
}

.session-chip.logged:hover[b-n2v8kop6j0],
.session-chip.logged.active[b-n2v8kop6j0] {
    background: rgba(0, 191, 154, 0.25);
}

/* Ad-hoc session chip - purple */
.session-chip.ad-hoc[b-n2v8kop6j0] {
    background: rgba(157, 78, 221, 0.12);
    color: #9d4edd;
}

.session-chip.ad-hoc:hover[b-n2v8kop6j0],
.session-chip.ad-hoc.active[b-n2v8kop6j0] {
    background: rgba(157, 78, 221, 0.25);
}

.chip-actions[b-n2v8kop6j0] {
    display: flex;
    align-items: center;
    gap: 0.25rem;
}

.log-badge[b-n2v8kop6j0] {
    font-size: 0.7rem;
    font-weight: 700;
}

.exercise-count[b-n2v8kop6j0] {
    font-size: 0.6rem;
    opacity: 0.7;
    margin-left: 0.25rem;
}

/* Reschedule button on session chips */
.reschedule-btn[b-n2v8kop6j0] {
    background: none;
    border: none;
    color: inherit;
    opacity: 0;
    cursor: pointer;
    padding: 0.1rem;
    border-radius: 3px;
    display: flex;
    align-items: center;
    transition: opacity 0.15s ease;
}

.session-chip:hover .reschedule-btn[b-n2v8kop6j0] {
    opacity: 0.6;
}

.reschedule-btn:hover[b-n2v8kop6j0] {
    opacity: 1 !important;
    background: rgba(255, 255, 255, 0.1);
}

/* Reschedule card */
.reschedule-card[b-n2v8kop6j0] {
    border-color: rgba(29, 140, 248, 0.3);
    background: rgba(29, 140, 248, 0.03);
}

/* Ad-hoc editor accent */
.ad-hoc-editor[b-n2v8kop6j0] {
    border-color: rgba(157, 78, 221, 0.3);
}

.text-ad-hoc[b-n2v8kop6j0] {
    color: #9d4edd;
}

/* Exercise card within session editor */
.exercise-card[b-n2v8kop6j0] {
    border: 1px solid rgba(255, 255, 255, 0.1);
    border-radius: 10px;
    padding: 0.75rem;
    background: rgba(255, 255, 255, 0.02);
}

.exercise-header[b-n2v8kop6j0] {
    display: flex;
    align-items: center;
    margin-bottom: 0.5rem;
}

/* Sets table with Rx / Actual columns */
.sets-table[b-n2v8kop6j0] {
    width: 100%;
    font-size: 0.8rem;
    margin-top: 0.5rem;
}

.sets-table th[b-n2v8kop6j0] {
    font-size: 0.65rem;
    text-transform: uppercase;
    letter-spacing: 0.04em;
    color: rgba(255, 255, 255, 0.5);
    font-weight: 600;
    padding: 0.3rem 0.25rem;
    border-bottom: 1px solid rgba(255, 255, 255, 0.1);
}

.sets-table td[b-n2v8kop6j0] {
    padding: 0.2rem 0.25rem;
    vertical-align: middle;
}

/* Rx column header */
.rx-header[b-n2v8kop6j0] {
    color: rgba(255, 255, 255, 0.35) !important;
    font-size: 0.6rem !important;
    text-align: center;
}

/* Actual column header */
.actual-header[b-n2v8kop6j0] {
    color: #00bf9a !important;
    font-size: 0.6rem !important;
    text-align: center;
}

/* Rx value cell - muted */
.rx-cell[b-n2v8kop6j0] {
    text-align: center;
    min-width: 35px;
}

.rx-value[b-n2v8kop6j0] {
    color: rgba(255, 255, 255, 0.35);
    font-size: 0.75rem;
    font-style: italic;
}

/* Actual value cell - highlighted */
.actual-cell[b-n2v8kop6j0] {
    min-width: 50px;
}

[b-n2v8kop6j0] .actual-input {
    padding: 0.2rem 0.4rem;
    font-size: 0.8rem;
    height: auto;
    border-color: rgba(0, 191, 154, 0.3) !important;
    background: rgba(0, 191, 154, 0.03) !important;
}

[b-n2v8kop6j0] .actual-input:focus {
    border-color: #00bf9a !important;
    box-shadow: 0 0 0 0.15rem rgba(0, 191, 154, 0.2) !important;
}

[b-n2v8kop6j0] .sets-table input.form-control-sm {
    padding: 0.2rem 0.4rem;
    font-size: 0.8rem;
    height: auto;
}
