/* _content/ReadersClub.Blazor/Components/Layout/AdminLayout.razor.rz.scp.css */
#blazor-error-ui[b-d502gv0u5t] {
    color-scheme: light only;
    background: lightyellow;
    bottom: 0;
    box-shadow: 0 -1px 2px 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;
}

    #blazor-error-ui .dismiss[b-d502gv0u5t] {
        cursor: pointer;
        position: absolute;
        right: 0.75rem;
        top: 0.5rem;
    }
/* _content/ReadersClub.Blazor/Components/Layout/AuthLayout.razor.rz.scp.css */
html[b-hvqx5x0eed], body[b-hvqx5x0eed] {
    height: 100%;
    margin: 0;
    background: #ffffff;
}

/* Override the dot-grid body::before from app.css */
body[b-hvqx5x0eed]::before {
    display: none;
}

.auth-root[b-hvqx5x0eed] {
    display: flex;
    min-height: 100vh;
    width: 100%;
    background: #ffffff;
}

/* ── Two-column shell ── */

/* Left column */
[b-hvqx5x0eed] .auth-left {
    flex: 0 0 50%;
    width: 50%;
    background: #ffffff;
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    padding: 3rem 2.5rem;
    position: relative;
    overflow: hidden;
}

/* Logo */
[b-hvqx5x0eed] .auth-logo {
    margin-bottom: 2rem;
}

[b-hvqx5x0eed] .auth-logo .brand-logo-dots {
    gap: 0.45rem;
}

[b-hvqx5x0eed] .auth-logo .brand-logo-dot {
    width: 14px;
    height: 14px;
}

[b-hvqx5x0eed] .auth-logo .brand-logo-word {
    font-size: 2.75rem;
}

/* Illustration */
[b-hvqx5x0eed] .auth-ill {
    width: 100%;
    max-width: 340px;
    mix-blend-mode: multiply;
    margin-bottom: 2rem;
}

/* Tagline */
[b-hvqx5x0eed] .auth-tagline {
    font-family: var(--serif);
    font-style: italic;
    font-size: 1.5rem;
    font-weight: 400;
    color: var(--text);
    line-height: 1.4;
    margin-bottom: 0.6rem;
    text-align: center;
}

/* Sub-tagline */
[b-hvqx5x0eed] .auth-sub-tagline {
    font-size: 0.85rem;
    color: var(--text3);
    line-height: 1.6;
    text-align: center;
}

/* Right column */
[b-hvqx5x0eed] .auth-right {
    flex: 0 0 50%;
    width: 50%;
    background: #ffffff;
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    padding: 3rem 2.5rem;
    position: relative;
    overflow-y: auto;
}

/* ── Shared form styles ── */

[b-hvqx5x0eed] .auth-heading {
    font-family: var(--serif);
    font-size: 1.8rem;
    font-weight: 400;
    color: var(--text);
    margin-bottom: 0.3rem;
}

[b-hvqx5x0eed] .auth-sub {
    font-size: 0.85rem;
    color: var(--text3);
    margin-bottom: 2rem;
}
[b-hvqx5x0eed] .auth-sub a {
    color: var(--blue);
    text-decoration: none;
    font-weight: 500;
}
[b-hvqx5x0eed] .auth-sub a:hover { text-decoration: underline; }

[b-hvqx5x0eed] .auth-field { margin-bottom: 1rem; }
[b-hvqx5x0eed] .auth-field label {
    display: block;
    font-size: 0.78rem;
    font-weight: 500;
    color: var(--text2);
    margin-bottom: 0.4rem;
}

[b-hvqx5x0eed] .auth-input {
    width: 100%;
    font-family: var(--sans);
    font-size: 0.88rem;
    color: var(--text);
    background: var(--bg);
    border: 1px solid var(--border);
    border-radius: 4px;
    padding: 0.62rem 0.85rem;
    outline: none;
    transition: border-color 0.15s, box-shadow 0.15s;
}
[b-hvqx5x0eed] .auth-input:hover { border-color: var(--border2); }
[b-hvqx5x0eed] .auth-input:focus {
    border-color: var(--blue);
    box-shadow: 0 0 0 3px var(--blue-dim);
}
[b-hvqx5x0eed] .auth-input.invalid { border-color: var(--red); }
[b-hvqx5x0eed] .auth-input.invalid:focus { box-shadow: 0 0 0 3px rgba(220,38,38,0.1); }

/* password field with eye toggle */
[b-hvqx5x0eed] .pw-wrap { position: relative; }
[b-hvqx5x0eed] .pw-toggle {
    position: absolute; right: 0.75rem; top: 50%;
    transform: translateY(-50%);
    background: none; border: none; cursor: pointer;
    color: var(--text3); padding: 0;
    display: flex; align-items: center;
}
[b-hvqx5x0eed] .pw-toggle:hover { color: var(--text2); }

[b-hvqx5x0eed] .field-foot {
    display: flex;
    justify-content: flex-end;
    margin-top: 0.3rem;
}
[b-hvqx5x0eed] .forgot-link {
    font-size: 0.75rem;
    color: var(--blue);
    text-decoration: none;
    font-weight: 500;
}
[b-hvqx5x0eed] .forgot-link:hover { text-decoration: underline; }

/* two-column field grid for name fields */
[b-hvqx5x0eed] .field-row {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 0.75rem;
    margin-bottom: 1rem;
}

/* inline hints below fields */
[b-hvqx5x0eed] .field-hint { font-size: 0.72rem; color: var(--text3); margin-top: 0.3rem; }
[b-hvqx5x0eed] .field-hint.valid   { color: var(--green); }
[b-hvqx5x0eed] .field-hint.warn    { color: var(--amber); }
[b-hvqx5x0eed] .field-hint.invalid { color: var(--red); }

/* password strength bar */
[b-hvqx5x0eed] .strength-track {
    height: 3px;
    background: var(--border);
    border-radius: 2px;
    margin-top: 0.4rem;
    margin-bottom: 0.25rem;
}
[b-hvqx5x0eed] .strength-fill {
    height: 100%;
    border-radius: 2px;
    transition: width 0.3s, background 0.3s;
}
[b-hvqx5x0eed] .strength-text { font-size: 0.68rem; }

/* checkbox */
[b-hvqx5x0eed] .check-row { display: flex; align-items: flex-start; gap: 0.6rem; margin-top: 0.75rem; }
[b-hvqx5x0eed] .check-row input[type=checkbox] {
    width: 16px; height: 16px; min-width: 16px;
    margin-top: 2px; accent-color: var(--blue); cursor: pointer;
}
[b-hvqx5x0eed] .check-label { font-size: 0.78rem; color: var(--text2); cursor: pointer; }
[b-hvqx5x0eed] .check-label a { color: var(--blue); text-decoration: none; }
[b-hvqx5x0eed] .check-label a:hover { text-decoration: underline; }

/* submit button */
[b-hvqx5x0eed] .auth-submit {
    width: 100%;
    font-family: var(--sans);
    font-size: 0.85rem; font-weight: 500; letter-spacing: 0.03em;
    padding: 0.7rem 1.5rem; border-radius: 4px; cursor: pointer;
    background: var(--blue); color: white; border: 1px solid var(--blue);
    transition: background 0.15s; margin-top: 1.5rem;
}
[b-hvqx5x0eed] .auth-submit:hover { background: var(--blue-dk); }
[b-hvqx5x0eed] .auth-submit:disabled {
    background: var(--border2);
    border-color: var(--border2);
    cursor: not-allowed;
}

/* server error banner */
[b-hvqx5x0eed] .server-error {
    font-size: 0.82rem; color: var(--red);
    text-align: center; margin-top: 0.75rem;
    padding: 0.6rem 0.85rem;
    background: #fef2f2;
    border: 1px solid #fecaca;
    border-radius: 4px;
}

/* terms note below submit */
[b-hvqx5x0eed] .terms-note {
    font-size: 0.72rem; color: var(--text3);
    text-align: center; margin-top: 1rem; line-height: 1.5;
}

/* bottom switch link */
[b-hvqx5x0eed] .auth-alt {
    font-size: 0.82rem; color: var(--text2);
    text-align: center; margin-top: 1.75rem;
    padding-top: 1.5rem; border-top: 1px solid var(--border);
}
[b-hvqx5x0eed] .auth-alt a { color: var(--blue); font-weight: 500; text-decoration: none; }
[b-hvqx5x0eed] .auth-alt a:hover { text-decoration: underline; }
/* _content/ReadersClub.Blazor/Components/Layout/MainLayout.razor.rz.scp.css */
#blazor-error-ui[b-afjoknv95s] {
    color-scheme: light only;
    background: lightyellow;
    bottom: 0;
    box-shadow: 0 -1px 2px 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;
}

    #blazor-error-ui .dismiss[b-afjoknv95s] {
        cursor: pointer;
        position: absolute;
        right: 0.75rem;
        top: 0.5rem;
    }

/* ── NAV ── */
.rc-nav[b-afjoknv95s] {
    position: sticky;
    top: 0;
    z-index: 200;
    display: grid;
    grid-template-columns: 1fr auto 1fr;
    align-items: center;
    padding: 0 2.5rem;
    height: 58px;
    background: rgba(248, 250, 252, 0.97);
    backdrop-filter: blur(14px);
    -webkit-backdrop-filter: blur(14px);
    border-bottom: 1px solid var(--border);
}

.rc-nav-left[b-afjoknv95s] {
    display: flex;
    align-items: center;
    gap: 1rem;
    justify-content: flex-start;
}

.rc-nav-right[b-afjoknv95s] {
    display: flex;
    align-items: center;
    gap: 0.85rem;
    justify-content: flex-end;
}

.rc-body[b-afjoknv95s] {
    position: relative;
    z-index: 1;
    width: 100%;
    max-width: 1200px;
    margin: 0 auto;
}
/* _content/ReadersClub.Blazor/Components/Pages/Admin/AdminUpdateAuthors.razor.rz.scp.css */
.admin-update-authors-grid[b-gjhd00lmsp] {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(180px, 1fr));
    gap: 1rem;
}

.admin-update-authors-card[b-gjhd00lmsp] {
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 0.75rem;
    padding: 1rem;
    border: 1px solid rgba(0, 0, 0, 0.08);
    border-radius: 0.75rem;
    background: #fff;
    box-shadow: 0 0.25rem 0.75rem rgba(0, 0, 0, 0.04);
    cursor: pointer;
}

.admin-update-authors-checkbox[b-gjhd00lmsp] {
    align-self: flex-start;
}

.admin-update-authors-photo[b-gjhd00lmsp] {
    width: 100%;
    aspect-ratio: 1 / 1;
    object-fit: cover;
    border-radius: 0.75rem;
    background: #f1f3f5;
}

.admin-update-authors-photo-fallback[b-gjhd00lmsp] {
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 2rem;
    font-weight: 700;
    color: #495057;
}

.admin-update-authors-name[b-gjhd00lmsp] {
    width: 100%;
    text-align: center;
    font-weight: 600;
    color: #212529;
}

.admin-update-authors-updated-list[b-gjhd00lmsp] {
    padding-left: 1.25rem;
}

.admin-update-authors-status[b-gjhd00lmsp] {
    margin: 1.25rem 0 0;
    text-align: center;
    color: #6c757d;
}

.admin-update-authors-sentinel[b-gjhd00lmsp] {
    height: 1px;
}
/* _content/ReadersClub.Blazor/Components/Pages/Auth/Login.razor.rz.scp.css */
/* Page-scoped styles — shared layout lives in AuthLayout.razor.css */

@media (max-width: 768px) {
    .login-auth-left[b-onmblljvmc] {
        display: none;
    }

    .login-auth-right[b-onmblljvmc] {
        flex: 1 1 100%;
        width: 100%;
        padding: 2rem 1.25rem;
    }
}
/* _content/ReadersClub.Blazor/Components/Pages/Auth/Register.razor.rz.scp.css */
/* Page-scoped styles — shared layout lives in AuthLayout.razor.css */

@media (max-width: 768px) {
    .register-auth-left[b-lqpz5e43a4] {
        display: none;
    }

    .register-auth-right[b-lqpz5e43a4] {
        flex: 1 1 100%;
        width: 100%;
        padding: 2rem 1.25rem;
    }
}
/* _content/ReadersClub.Blazor/Components/Pages/AuthorDetail.razor.rz.scp.css */
/* More books by this author section */
.ad-more-section[b-bz6vjf6xt7] {
    margin-top: 2.5rem;
}

.ad-search-btn[b-bz6vjf6xt7] {
    display: inline-flex;
    align-items: center;
    gap: 0.4rem;
    font-family: var(--sans);
    font-size: 0.78rem;
    font-weight: 500;
    letter-spacing: 0.05em;
    text-transform: uppercase;
    padding: 0.45rem 1.1rem;
    background: var(--blue);
    color: white;
    border: none;
    border-radius: 3px;
    cursor: pointer;
    transition: background 0.15s;
    margin-bottom: 0.75rem;
}

.ad-search-btn:hover:not(:disabled)[b-bz6vjf6xt7] {
    background: var(--blue-dk);
}

.ad-search-btn:disabled[b-bz6vjf6xt7] {
    opacity: 0.6;
    cursor: default;
}

.ad-error[b-bz6vjf6xt7] {
    font-size: 0.85rem;
    color: var(--red);
    background: #fef2f2;
    border: 1px solid #fecaca;
    border-radius: 4px;
    padding: 0.75rem 1rem;
    margin-top: 0.5rem;
    margin-bottom: 0.75rem;
}

/* Cover grid */
.ad-cover-grid[b-bz6vjf6xt7] {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(130px, 1fr));
    gap: 1rem;
    margin-top: 0.5rem;
}

.ad-cover-card[b-bz6vjf6xt7] {
    background: var(--bg2);
    border: 1px solid var(--border);
    border-radius: 4px;
    overflow: hidden;
    cursor: pointer;
    padding: 0;
    text-align: left;
    transition: border-color 0.12s, background 0.12s;
}

.ad-cover-card:hover:not(:disabled):not(.ad-cover-card--importing)[b-bz6vjf6xt7] {
    border-color: var(--border2);
    background: var(--bg3);
}

.ad-cover-card--importing[b-bz6vjf6xt7] {
    opacity: 0.5;
    cursor: default;
}

.ad-cover-card:disabled[b-bz6vjf6xt7] {
    cursor: default;
}

.ad-cover-img[b-bz6vjf6xt7] {
    width: 100%;
    aspect-ratio: 2 / 3;
    object-fit: cover;
    display: block;
}

.ad-cover-placeholder[b-bz6vjf6xt7] {
    width: 100%;
    aspect-ratio: 2 / 3;
    background: linear-gradient(160deg, #1a1a2e, #2e2e4e);
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 2rem;
}

.ad-card-info[b-bz6vjf6xt7] {
    padding: 0.5rem 0.6rem;
    display: flex;
    flex-direction: column;
    gap: 0.1rem;
}

.ad-card-title[b-bz6vjf6xt7] {
    font-family: var(--serif);
    font-size: 0.82rem;
    font-weight: 400;
    color: var(--text);
    line-height: 1.3;
    display: -webkit-box;
    -webkit-line-clamp: 2;
    -webkit-box-orient: vertical;
    overflow: hidden;
}

.ad-card-year[b-bz6vjf6xt7] {
    font-size: 0.72rem;
    color: var(--text3);
}

.ad-add-label[b-bz6vjf6xt7] {
    font-size: 0.68rem;
    font-weight: 500;
    letter-spacing: 0.04em;
    text-transform: uppercase;
    color: var(--blue);
    margin-top: 0.2rem;
}

/* Import overlay */
.ad-import-overlay[b-bz6vjf6xt7] {
    position: fixed;
    inset: 0;
    background: rgba(31, 41, 55, 0.6);
    display: flex;
    align-items: center;
    justify-content: center;
    z-index: 20;
}

.ad-import-dialog[b-bz6vjf6xt7] {
    min-width: 260px;
    max-width: 420px;
    margin: 1rem;
    background: var(--bg2);
    border: 1px solid var(--border2);
    border-radius: 8px;
    box-shadow: 0 12px 30px rgba(0, 0, 0, 0.25);
    padding: 1.1rem 1.25rem;
    text-align: center;
}

.ad-import-spinner[b-bz6vjf6xt7] {
    width: 34px;
    height: 34px;
    margin: 0 auto 0.6rem;
    border-radius: 50%;
    border: 3px solid var(--border);
    border-top-color: var(--blue);
    animation: ad-spin-b-bz6vjf6xt7 0.8s linear infinite;
}

.ad-import-title[b-bz6vjf6xt7] {
    font-family: var(--sans);
    font-size: 0.92rem;
    font-weight: 600;
    color: var(--text);
}

.ad-import-text[b-bz6vjf6xt7] {
    font-size: 0.8rem;
    color: var(--text3);
    margin-top: 0.35rem;
}

@keyframes ad-spin-b-bz6vjf6xt7 {
    to {
        transform: rotate(360deg);
    }
}
/* _content/ReadersClub.Blazor/Components/Pages/Authors.razor.rz.scp.css */
.authors-grid[b-apbtptcx0z] {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(160px, 1fr));
    gap: 1rem;
}

.authors-card[b-apbtptcx0z] {
    display: flex;
    flex-direction: column;
    gap: 0.75rem;
    text-decoration: none;
    color: inherit;
}

.authors-photo-frame[b-apbtptcx0z] {
    width: 100%;
    aspect-ratio: 2 / 3;
    border-radius: 6px;
    background: var(--bg2);
    border: 1px solid var(--border);
    overflow: hidden;
}

.authors-photo[b-apbtptcx0z] {
    width: 100%;
    height: 100%;
    display: block;
    object-fit: cover;
}

.authors-photo-fallback[b-apbtptcx0z] {
    display: flex;
    align-items: center;
    justify-content: center;
    font-family: var(--sans);
    font-size: 1.1rem;
    font-weight: 600;
    color: #dbe3ff;
    background: linear-gradient(160deg, #1a1a2e, #2e2e4e);
}

.authors-name[b-apbtptcx0z] {
    font-family: var(--sans);
    font-size: 0.92rem;
    font-weight: 500;
    color: var(--text);
    line-height: 1.35;
}

.authors-card:hover .authors-name[b-apbtptcx0z] {
    color: var(--blue);
}

.bk-pagination[b-apbtptcx0z] {
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 0.25rem;
    margin-top: 1.5rem;
    flex-wrap: wrap;
}

.bk-page-btn[b-apbtptcx0z] {
    font-family: var(--sans);
    font-size: 0.78rem;
    font-weight: 500;
    padding: 0.38rem 0.75rem;
    border: 1px solid var(--border);
    border-radius: 3px;
    background: var(--bg2);
    color: var(--text2);
    cursor: pointer;
    transition: all 0.12s;
    min-width: 36px;
    text-align: center;
}

.bk-page-btn:hover:not(:disabled):not(.bk-page-active)[b-apbtptcx0z] {
    background: var(--bg3);
    border-color: var(--border2);
}

.bk-page-btn.bk-page-active[b-apbtptcx0z] {
    background: var(--blue);
    color: white;
    border-color: var(--blue);
}

.bk-page-btn:disabled[b-apbtptcx0z],
.bk-page-btn[aria-disabled="true"][b-apbtptcx0z] {
    color: var(--text3);
    cursor: default;
}

.bk-page-btn.bk-ellipsis[b-apbtptcx0z] {
    cursor: default;
    border-color: transparent;
    background: transparent;
    color: var(--text3);
}
/* _content/ReadersClub.Blazor/Components/Pages/Blog.razor.rz.scp.css */
.blog-hub[b-vdc24grctv] {
    max-width: 1180px;
}

.blog-card[b-vdc24grctv] {
    transition: transform 0.15s ease, box-shadow 0.15s ease;
}

.blog-card:hover[b-vdc24grctv] {
    transform: translateY(-2px);
    box-shadow: 0 0.75rem 1.5rem rgba(21, 35, 56, 0.12) !important;
}

.blog-card img[b-vdc24grctv] {
    object-fit: cover;
    aspect-ratio: 16 / 9;
}
/* _content/ReadersClub.Blazor/Components/Pages/BlogArticle.razor.rz.scp.css */
.blog-article[b-86lnwc56na] {
    max-width: 960px;
}

.blog-article-hero[b-86lnwc56na] {
    width: 100%;
    object-fit: cover;
    aspect-ratio: 16 / 9;
}

.blog-article-body[b-86lnwc56na] {
    font-size: 1.05rem;
    line-height: 1.75;
}

.blog-article-body :deep(h2)[b-86lnwc56na] {
    margin-top: 2rem;
    margin-bottom: 0.75rem;
    font-size: 1.4rem;
}

.blog-article-body :deep(h3)[b-86lnwc56na] {
    margin-top: 1.5rem;
    margin-bottom: 0.75rem;
    font-size: 1.2rem;
}
/* _content/ReadersClub.Blazor/Components/Pages/BookDetail.razor.rz.scp.css */
.bd-page-shell[b-ivznlhd9i5] {
    --bd-cover-width: 240px;
    --bd-cover-height: 348px;
    --bd-hero-gap: 2rem;
}

.bd-hero[b-ivznlhd9i5] {
    display: grid;
    grid-template-columns: var(--bd-cover-width) 1fr;
    gap: var(--bd-hero-gap);
    align-items: start;
    margin-bottom: 2rem;
}

.bd-cover-col[b-ivznlhd9i5] {
    display: flex;
    flex-direction: column;
    gap: 0.6rem;
}

.bd-cover[b-ivznlhd9i5] {
    width: var(--bd-cover-width);
    height: var(--bd-cover-height);
    object-fit: cover;
    border-radius: 6px;
    display: block;
    box-shadow: 3px 6px 20px rgba(0,0,0,0.22), inset -3px 0 6px rgba(0,0,0,0.1);
}

.bd-cover-ph[b-ivznlhd9i5] {
    width: var(--bd-cover-width);
    height: var(--bd-cover-height);
    border-radius: 6px;
    background: linear-gradient(160deg, #1a1a2e, #2e2e4e);
    box-shadow: 3px 6px 20px rgba(0,0,0,0.22);
}

.bd-affiliate-links[b-ivznlhd9i5] {
    display: flex;
    flex-direction: column;
    gap: 0.4rem;
}

.bd-affiliate-btn[b-ivznlhd9i5] {
    display: flex;
    align-items: center;
    justify-content: center;
    width: var(--bd-cover-width);
    padding: 0.42rem 0;
    font-size: 0.72rem;
    font-weight: 500;
    border-radius: 6px;
    text-decoration: none;
    text-align: center;
    border: 1px solid var(--border2);
    color: var(--text2);
    background: transparent;
    transition: all 0.12s;
}

.bd-affiliate-btn:hover[b-ivznlhd9i5] {
    border-color: var(--blue);
    color: var(--blue);
    background: var(--blue-dim);
}

.bd-main-col[b-ivznlhd9i5] {
    min-width: 0;
}

.bd-title[b-ivznlhd9i5] {
    font-family: var(--serif);
    font-size: clamp(2rem, 4vw, 2.75rem);
    line-height: 1.1;
    margin: 0 0 0.75rem;
    color: var(--text);
}

.bd-authors[b-ivznlhd9i5] {
    margin: 0 0 0.85rem;
    font-size: 1rem;
    color: var(--text2);
}

.bd-author-link[b-ivznlhd9i5] {
    color: var(--blue);
    text-decoration: none;
}

.bd-author-link:hover[b-ivznlhd9i5] {
    text-decoration: underline;
}

.bd-genres[b-ivznlhd9i5] {
    display: flex;
    flex-wrap: wrap;
    gap: 0.45rem;
    margin-bottom: 1rem;
}

.bd-genre-tag[b-ivznlhd9i5] {
    display: inline-flex;
    align-items: center;
    padding: 0.25rem 0.6rem;
    border-radius: 999px;
    background: var(--bg3);
    border: 1px solid var(--border);
    color: var(--text2);
    font-size: 0.8rem;
}

.bd-genre-link[b-ivznlhd9i5] {
    text-decoration: none;
}

.bd-genre-link:hover[b-ivznlhd9i5] {
    color: var(--blue);
    border-color: #bfdbfe;
    background: var(--blue-dim);
}

.bd-rating-row[b-ivznlhd9i5] {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    gap: 0.5rem;
    margin-bottom: 1.25rem;
}

.bd-stars[b-ivznlhd9i5] {
    display: inline-flex;
    gap: 0.12rem;
}

.bd-star-on[b-ivznlhd9i5] {
    color: var(--amber);
    font-size: 1rem;
}

.bd-star-off[b-ivznlhd9i5] {
    color: var(--border2);
    font-size: 1rem;
}

.bd-rating-text[b-ivznlhd9i5],
.bd-meta-text[b-ivznlhd9i5],
.bd-meta-link[b-ivznlhd9i5] {
    font-size: 0.9rem;
    color: var(--text3);
}

.bd-meta-link[b-ivznlhd9i5] {
    text-decoration: none;
}

.bd-meta-link:hover[b-ivznlhd9i5] {
    color: var(--blue);
    text-decoration: underline;
}

.bd-description[b-ivznlhd9i5] {
    margin-bottom: 1.25rem;
}

.bd-publisher-description[b-ivznlhd9i5] {
    border: 1px solid var(--border);
    border-left: 4px solid var(--border2);
    border-radius: 6px;
    padding: 0.9rem 1rem;
    background: var(--bg3);
}

.bd-publisher-description summary[b-ivznlhd9i5] {
    cursor: pointer;
    font-weight: 600;
    color: var(--text2);
    margin-bottom: 0.6rem;
}

.bd-section-heading[b-ivznlhd9i5] {
    font-family: var(--serif);
    font-size: 1.15rem;
    margin: 0 0 0.4rem;
    color: var(--text);
}

.bd-description p[b-ivznlhd9i5] {
    margin: 0;
    color: var(--text);
    line-height: 1.7;
}

.bd-description-attribution[b-ivznlhd9i5] {
    margin-top: 0.75rem !important;
    font-size: 0.8rem;
    color: var(--text3) !important;
}

.bd-empty-state[b-ivznlhd9i5] {
    border: 1px dashed var(--border2);
    border-radius: 8px;
    padding: 1rem;
    background: var(--bg3);
}

.bd-metadata-list[b-ivznlhd9i5] {
    display: grid;
    grid-template-columns: max-content 1fr;
    column-gap: 0.75rem;
    row-gap: 0.35rem;
    margin: 0;
}

.bd-metadata-list dt[b-ivznlhd9i5] {
    color: var(--text3);
    font-size: 0.85rem;
}

.bd-metadata-list dd[b-ivznlhd9i5] {
    margin: 0;
    color: var(--text);
    font-size: 0.92rem;
}

.bd-main-column-section[b-ivznlhd9i5] {
    margin-left: calc(var(--bd-cover-width) + var(--bd-hero-gap));
}

.bd-reviews-divider[b-ivznlhd9i5] {
    margin: 0 0 1.25rem;
    border: 0;
    border-top: 1px solid var(--border);
    opacity: 1;
}

.bd-reviews-cols[b-ivznlhd9i5] {
    display: grid;
    grid-template-columns: var(--bd-cover-width) 1fr;
    gap: var(--bd-hero-gap);
    align-items: start;
}

.bd-reviews-cols--no-sidebar[b-ivznlhd9i5] {
    grid-template-columns: 1fr;
}

.bd-reviews-main[b-ivznlhd9i5] {
    min-width: 0;
}

.bd-similar-books-section[b-ivznlhd9i5] {
    margin-left: 0;
}

.bd-controls[b-ivznlhd9i5] {
    display: flex;
    flex-direction: column;
    gap: 0.9rem;
}

.bd-reading-list[b-ivznlhd9i5] {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    gap: 0.6rem;
}

.bd-reading-list-label[b-ivznlhd9i5] {
    color: var(--text3);
    font-size: 0.9rem;
}

.bd-reading-select[b-ivznlhd9i5] {
    width: auto;
}

.bd-action-row[b-ivznlhd9i5] {
    display: flex;
    flex-wrap: wrap;
    gap: 0.6rem;
    align-items: center;
}

/* Genre section */
.bd-genre-section[b-ivznlhd9i5] {
    border-top: 1px solid var(--border);
    padding-top: 1.25rem;
}

.bd-genre-heading[b-ivznlhd9i5] {
    font-family: var(--serif);
    font-size: 1.05rem;
    font-weight: 500;
    color: var(--text);
    margin: 0;
}

/* Horizontal scrollable row of book cards */
.bd-genre-row[b-ivznlhd9i5] {
    display: flex;
    gap: 0.75rem;
    overflow-x: auto;
    padding-bottom: 0.5rem;
    scrollbar-width: thin;
    scrollbar-color: var(--border) transparent;
}

.bd-genre-row[b-ivznlhd9i5]::-webkit-scrollbar {
    height: 4px;
}

.bd-genre-row[b-ivznlhd9i5]::-webkit-scrollbar-track {
    background: transparent;
}

.bd-genre-row[b-ivznlhd9i5]::-webkit-scrollbar-thumb {
    background: var(--border);
    border-radius: 2px;
}

/* Expanded multi-line grid after "Load more" */
.bd-genre-row--expanded[b-ivznlhd9i5] {
    flex-wrap: wrap;
    overflow-x: visible;
}

/* Individual book card */
.bd-genre-card[b-ivznlhd9i5] {
    flex: 0 0 auto;
    width: 110px;
    display: flex;
    flex-direction: column;
    align-items: flex-start;
    gap: 0.4rem;
    cursor: pointer;
    background: var(--bg2);
    border: 1px solid var(--border);
    border-radius: 4px;
    padding: 0.5rem;
    text-align: left;
    transition: background 0.12s, border-color 0.12s;
    color: inherit;
}

.bd-genre-card:hover:not(:disabled)[b-ivznlhd9i5] {
    background: var(--bg3);
    border-color: var(--border2);
}

.bd-genre-card:disabled[b-ivznlhd9i5] {
    opacity: 0.7;
    cursor: default;
}

.bd-genre-card-cover[b-ivznlhd9i5] {
    width: 100%;
    height: 120px;
    object-fit: cover;
    border-radius: 2px;
    box-shadow: 1px 2px 6px rgba(0, 0, 0, 0.15);
}

.bd-genre-card-placeholder[b-ivznlhd9i5] {
    width: 100%;
    height: 120px;
    background: linear-gradient(160deg, #1a1a2e, #2e2e4e);
    border-radius: 2px;
    box-shadow: 1px 2px 6px rgba(0, 0, 0, 0.15);
}

.bd-genre-card-info[b-ivznlhd9i5] {
    display: flex;
    flex-direction: column;
    gap: 0.15rem;
    min-width: 0;
    width: 100%;
}

.bd-genre-card-title[b-ivznlhd9i5] {
    font-size: 0.75rem;
    font-weight: 500;
    color: var(--text);
    line-height: 1.3;
    display: -webkit-box;
    -webkit-line-clamp: 2;
    -webkit-box-orient: vertical;
    overflow: hidden;
}

.bd-genre-card:hover:not(:disabled) .bd-genre-card-title[b-ivznlhd9i5] {
    color: var(--blue);
}

.bd-genre-card-author[b-ivznlhd9i5] {
    font-size: 0.67rem;
    color: var(--text3);
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
}

.bd-genre-card-external[b-ivznlhd9i5] {
    font-size: 0.6rem;
    font-weight: 500;
    letter-spacing: 0.04em;
    text-transform: uppercase;
    color: var(--blue);
    background: rgba(59, 130, 246, 0.08);
    border: 1px solid rgba(59, 130, 246, 0.2);
    padding: 0.1rem 0.3rem;
    border-radius: 2px;
    align-self: flex-start;
}

@media (max-width: 700px) {
    .bd-hero[b-ivznlhd9i5] {
        grid-template-columns: 1fr;
    }

    .bd-main-column-section[b-ivznlhd9i5] {
        margin-left: 0;
    }

    .bd-reviews-cols[b-ivznlhd9i5] {
        grid-template-columns: 1fr;
    }

    .bd-cover[b-ivznlhd9i5],
    .bd-cover-ph[b-ivznlhd9i5],
    .bd-affiliate-btn[b-ivznlhd9i5] {
        width: min(var(--bd-cover-width), 100%);
    }
}

/* Rating breakdown sidebar */
.bdr-rating-sidebar[b-ivznlhd9i5] {
    position: sticky;
    top: 1rem;
}

.bdr-rating-summary[b-ivznlhd9i5] {
    margin-bottom: 1rem;
}

.bdr-rating-overall[b-ivznlhd9i5] {
    display: flex;
    align-items: center;
    gap: 0.3rem;
    margin-bottom: 0.2rem;
}

.bdr-rs-star-on[b-ivznlhd9i5] {
    color: var(--amber);
    font-size: 1.1rem;
}

.bdr-rs-star-off[b-ivznlhd9i5] {
    color: var(--border2);
    font-size: 1.1rem;
}

.bdr-rating-value[b-ivznlhd9i5] {
    font-size: 0.9rem;
    font-weight: 600;
    color: var(--text);
    margin-left: 0.25rem;
}

.bdr-rating-global[b-ivznlhd9i5] {
    font-size: 0.78rem;
    color: var(--text3);
}

.bdr-rating-bars[b-ivznlhd9i5] {
    display: flex;
    flex-direction: column;
    gap: 0.35rem;
}

.bdr-rating-bar-row[b-ivznlhd9i5] {
    display: grid;
    grid-template-columns: 3.5rem 1fr 2.2rem;
    align-items: center;
    gap: 0.5rem;
}

.bdr-bar-label[b-ivznlhd9i5] {
    font-size: 0.78rem;
    color: var(--blue);
    text-align: right;
    white-space: nowrap;
}

.bdr-bar-track[b-ivznlhd9i5] {
    height: 8px;
    background: var(--bg3);
    border: 1px solid var(--border);
    border-radius: 4px;
    overflow: hidden;
}

.bdr-bar-fill[b-ivznlhd9i5] {
    height: 100%;
    background: var(--amber);
    border-radius: 4px;
    transition: width 0.3s ease;
}

.bdr-bar-pct[b-ivznlhd9i5] {
    font-size: 0.78rem;
    color: var(--blue);
    text-align: right;
}

/* Redesigned flat review list */
.bdr-rv-list[b-ivznlhd9i5] {
    display: flex;
    flex-direction: column;
}

.bdr-rv-card[b-ivznlhd9i5] {
    padding: 1.25rem 0;
    border-bottom: 1px solid var(--border);
}

.bdr-rv-card:last-child[b-ivznlhd9i5] {
    border-bottom: none;
}

/* Reviewer header row */
.bdr-rv-header[b-ivznlhd9i5] {
    display: flex;
    align-items: flex-start;
    justify-content: space-between;
    margin-bottom: 0.75rem;
    gap: 0.5rem;
}

.bdr-rv-author-row[b-ivznlhd9i5] {
    display: flex;
    align-items: center;
    gap: 0.65rem;
}

.bdr-rv-avatar[b-ivznlhd9i5] {
    width: 38px;
    height: 38px;
    min-width: 38px;
    border-radius: 50%;
    object-fit: cover;
    display: block;
    box-shadow: 0 0 0 1.5px white, 0 0 0 2.5px var(--border);
}

.bdr-rv-avatar-fallback[b-ivznlhd9i5] {
    width: 38px;
    height: 38px;
    min-width: 38px;
    border-radius: 50%;
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 0.68rem;
    font-weight: 600;
    box-shadow: 0 0 0 1.5px white, 0 0 0 2.5px var(--border);
}

.bdr-rv-avatar-fallback.green[b-ivznlhd9i5] {
    background: linear-gradient(135deg, #c8e6c9, #a5d6a7);
    color: #2e7d32;
}

.bdr-rv-avatar-fallback.blue[b-ivznlhd9i5] {
    background: linear-gradient(135deg, #bfdbfe, #93c5fd);
    color: #1d4ed8;
}

.bdr-rv-avatar-fallback.amber[b-ivznlhd9i5] {
    background: linear-gradient(135deg, #fde68a, #fcd34d);
    color: #92400e;
}

.bdr-rv-author-info[b-ivznlhd9i5] {
    min-width: 0;
}

.bdr-rv-author-name[b-ivznlhd9i5] {
    font-size: 0.85rem;
    font-weight: 500;
    color: var(--text);
    text-decoration: none;
    display: block;
    line-height: 1.2;
}

.bdr-rv-author-name:hover[b-ivznlhd9i5] {
    color: var(--blue);
}

.bdr-rv-author-deleted[b-ivznlhd9i5] {
    font-style: italic;
    color: var(--text3);
    font-weight: 400;
}

.bdr-rv-avatar-deleted[b-ivznlhd9i5] {
    background: linear-gradient(135deg, #e5e7eb, #d1d5db);
    color: #9ca3af;
}

.bdr-rv-date[b-ivznlhd9i5] {
    font-size: 0.7rem;
    color: var(--text3);
    flex-shrink: 0;
    padding-top: 1px;
}

/* Stars */
.bdr-rv-stars[b-ivznlhd9i5] {
    display: flex;
    align-items: center;
    gap: 0.2rem;
    margin-bottom: 0.5rem;
}

.bdr-star-on[b-ivznlhd9i5] {
    color: var(--amber);
    font-size: 0.75rem;
}

.bdr-star-off[b-ivznlhd9i5] {
    color: var(--border2);
    font-size: 0.75rem;
}

.bdr-rv-rating[b-ivznlhd9i5] {
    font-size: 0.7rem;
    color: var(--text3);
    margin-left: 0.2rem;
}

/* Body */
.bdr-rv-body[b-ivznlhd9i5] {
    font-size: 1rem;
    font-family: var(--sans);
    color: var(--text);
    line-height: 1.6;
}

.bdr-rv-body.clamped[b-ivznlhd9i5] {
    display: -webkit-box;
    -webkit-line-clamp: 3;
    -webkit-box-orient: vertical;
    overflow: hidden;
}

.bdr-rv-body-link[b-ivznlhd9i5] {
    text-decoration: none;
    color: inherit;
}

.bdr-rv-see-more[b-ivznlhd9i5] {
    font-size: 0.75rem;
    color: var(--blue);
    font-weight: 500;
    display: inline-flex;
    align-items: center;
    gap: 0.25rem;
    margin-top: 0.4rem;
    cursor: pointer;
    background: none;
    border: none;
    padding: 0;
    font-family: var(--sans);
    text-decoration: none;
}

.bdr-rv-see-more:hover[b-ivznlhd9i5] {
    text-decoration: underline;
}

/* Reactions */
.bdr-rv-reactions[b-ivznlhd9i5] {
    display: flex;
    align-items: center;
    gap: 0.3rem;
    margin-top: 0.75rem;
}

.bdr-rv-reaction[b-ivznlhd9i5] {
    display: inline-flex;
    align-items: center;
    gap: 0.35rem;
    font-family: var(--sans);
    font-size: 0.72rem;
    font-weight: 500;
    color: var(--text3);
    background: transparent;
    border: 1px solid var(--border);
    border-radius: 4px;
    padding: 0.28rem 0.65rem;
    cursor: pointer;
    transition: all 0.12s;
}

.bdr-rv-reaction:hover:not(:disabled)[b-ivznlhd9i5] {
    border-color: var(--border2);
    color: var(--text2);
    background: var(--bg3);
}

.bdr-rv-reaction.active[b-ivznlhd9i5] {
    background: var(--blue-dim);
    border-color: #bfdbfe;
    color: var(--blue);
}

.bdr-rv-reaction.active svg[b-ivznlhd9i5] {
    stroke: var(--blue);
}

.bdr-rv-reaction:disabled[b-ivznlhd9i5] {
    opacity: 0.6;
    cursor: default;
}

/* Comments */
.bdr-rv-comments[b-ivznlhd9i5] {
    margin-top: 0.75rem;
}

.bdr-rv-comments-label[b-ivznlhd9i5] {
    font-size: 0.65rem;
    font-weight: 500;
    letter-spacing: 0.07em;
    text-transform: uppercase;
    color: var(--text3);
    margin-bottom: 0.6rem;
}

.bdr-rv-comment[b-ivznlhd9i5] {
    display: flex;
    gap: 0.55rem;
    margin-bottom: 0.6rem;
}

.bdr-rv-comment:last-child[b-ivznlhd9i5] {
    margin-bottom: 0;
}

.bdr-rv-comment-avatar[b-ivznlhd9i5] {
    width: 24px;
    height: 24px;
    min-width: 24px;
    border-radius: 50%;
    object-fit: cover;
    display: block;
    box-shadow: 0 0 0 1px white, 0 0 0 1.5px var(--border);
}

.bdr-rv-comment-avatar-fb[b-ivznlhd9i5] {
    width: 24px;
    height: 24px;
    min-width: 24px;
    border-radius: 50%;
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 0.55rem;
    font-weight: 600;
    box-shadow: 0 0 0 1px white, 0 0 0 1.5px var(--border);
}

.bdr-rv-comment-avatar-fb.green[b-ivznlhd9i5] {
    background: linear-gradient(135deg, #c8e6c9, #a5d6a7);
    color: #2e7d32;
}

.bdr-rv-comment-avatar-fb.blue[b-ivznlhd9i5] {
    background: linear-gradient(135deg, #bfdbfe, #93c5fd);
    color: #1d4ed8;
}

.bdr-rv-comment-avatar-fb.amber[b-ivznlhd9i5] {
    background: linear-gradient(135deg, #fde68a, #fcd34d);
    color: #92400e;
}

.bdr-rv-comment-body[b-ivznlhd9i5] {
    flex: 1;
    min-width: 0;
}

.bdr-rv-comment-header[b-ivznlhd9i5] {
    display: flex;
    align-items: baseline;
    gap: 0.4rem;
    margin-bottom: 0.1rem;
}

.bdr-rv-comment-author[b-ivznlhd9i5] {
    font-size: 0.75rem;
    font-weight: 500;
    color: var(--text);
    text-decoration: none;
}

.bdr-rv-comment-author:hover[b-ivznlhd9i5] {
    color: var(--blue);
}

.bdr-rv-comment-date[b-ivznlhd9i5] {
    font-size: 0.65rem;
    color: var(--text3);
}

.bdr-rv-comment-text[b-ivznlhd9i5] {
    font-size: 0.78rem;
    color: var(--text2);
    line-height: 1.55;
}

.bdr-rv-comment-reactions[b-ivznlhd9i5] {
    margin-top: 0.35rem;
}

.bdr-rv-comment-compose[b-ivznlhd9i5] {
    margin-top: 0.65rem;
}

.bdr-rv-comment-input[b-ivznlhd9i5] {
    width: 100%;
    border: 1px solid var(--border);
    border-radius: 6px;
    padding: 0.45rem 0.55rem;
    font-size: 0.8rem;
    font-family: var(--sans);
    color: var(--text);
    background: var(--bg2);
}

.bdr-rv-comment-input:focus[b-ivznlhd9i5] {
    outline: none;
    border-color: #93c5fd;
    box-shadow: 0 0 0 2px rgba(59, 130, 246, 0.18);
}

.bdr-rv-comment-submit[b-ivznlhd9i5] {
    margin-top: 0.4rem;
    border: 1px solid #bfdbfe;
    background: var(--blue-dim);
    color: var(--blue);
    border-radius: 4px;
    font-size: 0.72rem;
    font-weight: 500;
    padding: 0.25rem 0.55rem;
}

.bdr-rv-comment-submit:disabled[b-ivznlhd9i5] {
    opacity: 0.6;
}

.bdr-rv-comment-error[b-ivznlhd9i5] {
    color: #b91c1c;
    font-size: 0.72rem;
    margin-top: 0.35rem;
}

.bdr-rv-comment-signin[b-ivznlhd9i5] {
    margin: 0;
    font-size: 0.75rem;
}

.bdr-rv-no-comments[b-ivznlhd9i5] {
    font-size: 0.75rem;
    color: var(--text3);
    font-style: italic;
}
/* _content/ReadersClub.Blazor/Components/Pages/BookList.razor.rz.scp.css */
.bk-add-btn[b-kdbgip01ra] {
    display: inline-flex;
    align-items: center;
    gap: 0.4rem;
    font-family: var(--sans);
    font-size: 0.78rem;
    font-weight: 500;
    letter-spacing: 0.05em;
    text-transform: uppercase;
    padding: 0.45rem 1.1rem;
    background: var(--blue);
    color: white;
    border: none;
    border-radius: 3px;
    text-decoration: none;
    cursor: pointer;
    transition: background 0.15s;
    white-space: nowrap;
}

.bk-add-btn:hover[b-kdbgip01ra] {
    background: var(--blue-dk);
    color: white;
}

/* Filter bar */
.bk-filter-bar[b-kdbgip01ra] {
    display: flex;
    align-items: center;
    gap: 0.75rem;
    background: var(--bg2);
    border: 1px solid var(--border);
    border-radius: 4px;
    padding: 0.75rem 1rem;
    margin-bottom: 0.85rem;
    flex-wrap: wrap;
}

.bk-search-wrap[b-kdbgip01ra] {
    display: flex;
    align-items: center;
    gap: 0.5rem;
    flex: 1;
    min-width: 160px;
    position: relative;
    background: var(--bg3);
    border: 1px solid var(--border);
    border-radius: 3px;
    padding: 0.42rem 0.75rem;
}

.bk-search-input[b-kdbgip01ra] {
    border: none;
    background: transparent;
    font-family: var(--sans);
    font-size: 0.85rem;
    color: var(--text);
    outline: none;
    width: 100%;
}

.bk-search-input[b-kdbgip01ra]::placeholder {
    color: var(--text3);
}

.bk-suggestions[b-kdbgip01ra] {
    position: absolute;
    top: calc(100% + 0.35rem);
    left: 0;
    right: 0;
    z-index: 10;
    background: var(--bg2);
    border: 1px solid var(--border);
    border-radius: 4px;
    box-shadow: 0 8px 20px rgba(0, 0, 0, 0.2);
    max-height: 280px;
    overflow-y: auto;
}

.bk-suggestion-item[b-kdbgip01ra] {
    width: 100%;
    text-align: left;
    display: flex;
    flex-direction: column;
    gap: 0.15rem;
    padding: 0.55rem 0.7rem;
    border: none;
    border-bottom: 1px solid var(--border);
    background: transparent;
    color: var(--text);
    cursor: pointer;
}

.bk-suggestion-item:last-child[b-kdbgip01ra] {
    border-bottom: none;
}

.bk-suggestion-item:hover[b-kdbgip01ra] {
    background: var(--bg3);
}

.bk-suggestion-title[b-kdbgip01ra] {
    font-size: 0.82rem;
    font-weight: 500;
}

.bk-suggestion-authors[b-kdbgip01ra] {
    font-size: 0.72rem;
    color: var(--text3);
}

.bk-suggestion-state[b-kdbgip01ra] {
    font-size: 0.78rem;
    color: var(--text3);
    padding: 0.65rem 0.75rem;
}

.bk-filter-divider[b-kdbgip01ra] {
    width: 1px;
    height: 24px;
    background: var(--border);
    flex-shrink: 0;
}

.bk-genre-select[b-kdbgip01ra] {
    font-family: var(--sans);
    font-size: 0.82rem;
    color: var(--text2);
    background: var(--bg3);
    border: 1px solid var(--border);
    border-radius: 3px;
    padding: 0.42rem 2rem 0.42rem 0.75rem;
    outline: none;
    cursor: pointer;
    appearance: none;
    background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 12 12'%3E%3Cpath d='M2 4l4 4 4-4' stroke='%239ca3af' stroke-width='1.5' fill='none' stroke-linecap='round'/%3E%3C/svg%3E");
    background-repeat: no-repeat;
    background-position: right 0.6rem center;
    min-width: 130px;
}

.bk-genre-select:focus[b-kdbgip01ra] {
    border-color: var(--border2);
}

.bk-search-btn[b-kdbgip01ra] {
    font-family: var(--sans);
    font-size: 0.78rem;
    font-weight: 500;
    letter-spacing: 0.04em;
    text-transform: uppercase;
    padding: 0.42rem 1.1rem;
    background: var(--blue);
    color: white;
    border: none;
    border-radius: 3px;
    cursor: pointer;
    transition: background 0.15s;
    white-space: nowrap;
}

.bk-search-btn:hover[b-kdbgip01ra] {
    background: var(--blue-dk);
}

.bk-search-btn:disabled[b-kdbgip01ra] {
    opacity: 0.6;
    cursor: default;
}

.bk-clear-btn[b-kdbgip01ra] {
    font-family: var(--sans);
    font-size: 0.78rem;
    font-weight: 500;
    padding: 0.42rem 0.9rem;
    background: transparent;
    border: 1px solid var(--border2);
    color: var(--text2);
    border-radius: 3px;
    cursor: pointer;
    transition: all 0.12s;
    white-space: nowrap;
}

.bk-clear-btn:hover[b-kdbgip01ra] {
    border-color: var(--text3);
    color: var(--text);
}

.bk-clear-btn:disabled[b-kdbgip01ra] {
    opacity: 0.6;
    cursor: default;
}

/* Active filter label */
.bk-filter-label[b-kdbgip01ra] {
    display: flex;
    align-items: center;
    gap: 0.35rem;
    font-size: 0.78rem;
    color: var(--text3);
    margin-bottom: 1rem;
}

.bk-filter-label strong[b-kdbgip01ra] {
    color: var(--text2);
    font-weight: 500;
}

.bk-filter-clear-x[b-kdbgip01ra] {
    background: none;
    border: none;
    cursor: pointer;
    color: var(--text3);
    font-size: 0.75rem;
    padding: 0;
    line-height: 1;
}

.bk-filter-clear-x:hover[b-kdbgip01ra] {
    color: var(--red);
}

/* Result count */
.bk-result-meta[b-kdbgip01ra] {
    font-size: 0.78rem;
    color: var(--text3);
    margin-bottom: 0.85rem;
}

.bk-result-meta strong[b-kdbgip01ra] {
    color: var(--text2);
    font-weight: 500;
}

/* States */
.bk-state[b-kdbgip01ra] {
    font-size: 0.85rem;
    color: var(--text3);
    font-style: italic;
    padding: 2rem 0;
}

.bk-error[b-kdbgip01ra] {
    font-size: 0.85rem;
    color: var(--red);
    background: #fef2f2;
    border: 1px solid #fecaca;
    border-radius: 4px;
    padding: 0.75rem 1rem;
    margin-bottom: 1rem;
}

/* Book list */
.bk-list[b-kdbgip01ra] {
    display: flex;
    flex-direction: column;
}

.bk-row[b-kdbgip01ra] {
    display: flex;
    align-items: center;
    gap: 1rem;
    padding: 0.9rem 1.1rem;
    background: var(--bg2);
    border: 1px solid var(--border);
    border-bottom: none;
    text-decoration: none;
    transition: background 0.12s, border-color 0.12s;
    cursor: pointer;
    width: 100%;
    text-align: left;
}

.bk-row:first-child[b-kdbgip01ra] {
    border-radius: 6px 6px 0 0;
}

.bk-row:last-child[b-kdbgip01ra] {
    border-bottom: 1px solid var(--border);
    border-radius: 0 0 6px 6px;
}

.bk-row:only-child[b-kdbgip01ra] {
    border-radius: 6px;
    border-bottom: 1px solid var(--border);
}

.bk-row:hover[b-kdbgip01ra] {
    background: var(--bg3);
}

.bk-row:disabled[b-kdbgip01ra] {
    opacity: 0.8;
    cursor: default;
}

/* Cover */
.bk-cover[b-kdbgip01ra] {
    width: 44px;
    min-width: 44px;
    height: 60px;
    border-radius: 2px;
    object-fit: cover;
    box-shadow: 1px 2px 6px rgba(0, 0, 0, 0.15);
    flex-shrink: 0;
}

.bk-cover-placeholder[b-kdbgip01ra] {
    width: 44px;
    min-width: 44px;
    height: 60px;
    border-radius: 2px;
    flex-shrink: 0;
    background: linear-gradient(160deg, #1a1a2e, #2e2e4e);
    display: flex;
    align-items: center;
    justify-content: center;
    box-shadow: 1px 2px 6px rgba(0, 0, 0, 0.15);
}

/* Book info */
.bk-info[b-kdbgip01ra] {
    flex: 1;
    min-width: 0;
}

.bk-book-title[b-kdbgip01ra] {
    font-family: var(--serif);
    font-size: 0.95rem;
    font-weight: 400;
    color: var(--text);
    line-height: 1.3;
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
    display: block;
}

.bk-row:hover .bk-book-title[b-kdbgip01ra] {
    color: var(--blue);
}

.bk-book-authors[b-kdbgip01ra] {
    font-size: 0.78rem;
    color: var(--text3);
    margin-top: 0.05rem;
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
}

.bk-book-year[b-kdbgip01ra] {
    color: var(--text3);
}

.bk-book-meta[b-kdbgip01ra] {
    display: flex;
    align-items: center;
    gap: 0.5rem;
    margin-top: 0.3rem;
    flex-wrap: wrap;
}

.bk-star-filled[b-kdbgip01ra] {
    color: var(--amber);
    font-size: 0.72rem;
}

.bk-star-empty[b-kdbgip01ra] {
    color: var(--border2);
    font-size: 0.72rem;
}

.bk-rating[b-kdbgip01ra] {
    font-size: 0.72rem;
    color: var(--text3);
}

.bk-genre-tag[b-kdbgip01ra] {
    font-size: 0.6rem;
    font-weight: 500;
    letter-spacing: 0.05em;
    text-transform: uppercase;
    background: var(--bg3);
    color: var(--text3);
    border: 1px solid var(--border);
    padding: 0.1rem 0.4rem;
    border-radius: 2px;
}

/* Pagination */
.bk-pagination[b-kdbgip01ra] {
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 0.25rem;
    margin-top: 1.5rem;
    flex-wrap: wrap;
}

.bk-page-btn[b-kdbgip01ra] {
    font-family: var(--sans);
    font-size: 0.78rem;
    font-weight: 500;
    padding: 0.38rem 0.75rem;
    border: 1px solid var(--border);
    border-radius: 3px;
    background: var(--bg2);
    color: var(--text2);
    cursor: pointer;
    transition: all 0.12s;
    min-width: 36px;
    text-align: center;
}

.bk-page-btn:hover:not(:disabled):not(.bk-page-active)[b-kdbgip01ra] {
    background: var(--bg3);
    border-color: var(--border2);
}

.bk-page-btn.bk-page-active[b-kdbgip01ra] {
    background: var(--blue);
    color: white;
    border-color: var(--blue);
}

.bk-page-btn:disabled[b-kdbgip01ra] {
    color: var(--text3);
    cursor: default;
}

.bk-page-btn.bk-ellipsis[b-kdbgip01ra] {
    cursor: default;
    border-color: transparent;
    background: transparent;
    color: var(--text3);
}

.bk-showing-count[b-kdbgip01ra] {
    text-align: center;
    font-size: 0.75rem;
    color: var(--text3);
    margin-top: 0.75rem;
}

.bk-import-overlay[b-kdbgip01ra] {
    position: fixed;
    inset: 0;
    background: rgba(31, 41, 55, 0.6);
    display: flex;
    align-items: center;
    justify-content: center;
    z-index: 20;
}

.bk-import-dialog[b-kdbgip01ra] {
    min-width: 260px;
    max-width: 420px;
    margin: 1rem;
    background: var(--bg2);
    border: 1px solid var(--border2);
    border-radius: 8px;
    box-shadow: 0 12px 30px rgba(0, 0, 0, 0.25);
    padding: 1.1rem 1.25rem;
    text-align: center;
}

.bk-import-spinner[b-kdbgip01ra] {
    width: 34px;
    height: 34px;
    margin: 0 auto 0.6rem;
    border-radius: 50%;
    border: 3px solid var(--border);
    border-top-color: var(--blue);
    animation: bk-spin-b-kdbgip01ra 0.8s linear infinite;
}

.bk-import-title[b-kdbgip01ra] {
    font-family: var(--sans);
    font-size: 0.92rem;
    font-weight: 600;
    color: var(--text);
}

.bk-import-text[b-kdbgip01ra] {
    font-size: 0.8rem;
    color: var(--text3);
    margin-top: 0.35rem;
}

@keyframes bk-spin-b-kdbgip01ra {
    to {
        transform: rotate(360deg);
    }
}

@media (max-width: 700px) {
    .rc-page-shell[b-kdbgip01ra] {
        padding: 1.5rem 1rem 3rem;
    }

    .bk-filter-bar[b-kdbgip01ra] {
        flex-wrap: wrap;
    }

    .bk-filter-divider[b-kdbgip01ra] {
        display: none;
    }

    .bk-genre-select[b-kdbgip01ra] {
        min-width: 100%;
    }
}
/* _content/ReadersClub.Blazor/Components/Pages/Books.razor.rz.scp.css */
/* ── Browse trigger ── */
.rc-browse-btn[b-nstesivbkb] {
    display: inline-flex;
    align-items: center;
    gap: 0.35rem;
    font-family: var(--sans);
    font-size: 0.82rem;
    font-weight: 500;
    color: var(--text2);
    padding: 0.4rem 0.75rem;
    border-radius: 4px;
    background: transparent;
    border: none;
    cursor: pointer;
    transition: background 0.12s, color 0.12s;
    white-space: nowrap;
}

.rc-browse-btn:hover[b-nstesivbkb],
.rc-browse-btn--open[b-nstesivbkb] {
    background: var(--bg3);
    color: var(--blue);
}

.rc-chevron[b-nstesivbkb] {
    transition: transform 0.2s ease;
}

.rc-chevron--up[b-nstesivbkb] {
    transform: rotate(180deg);
}

/* ── Browse dropdown ── */
.rc-browse-dropdown[b-nstesivbkb] {
    position: absolute;
    top: calc(100% + 8px);
    left: 0;
    min-width: 230px;
    background: var(--bg2);
    border: 1px solid var(--border);
    border-radius: 6px;
    box-shadow: 0 8px 32px rgba(0, 0, 0, 0.1), 0 2px 8px rgba(0, 0, 0, 0.06);
    z-index: 200;
    padding: 0.25rem 0;
}

.rc-dropdown-label[b-nstesivbkb] {
    font-size: 0.62rem;
    font-weight: 500;
    letter-spacing: 0.09em;
    text-transform: uppercase;
    color: var(--text3);
    padding: 0.6rem 1rem 0.25rem;
}

.rc-dropdown-row[b-nstesivbkb] {
    display: flex;
    align-items: center;
    justify-content: space-between;
    width: 100%;
    padding: 0.6rem 1rem;
    font-family: var(--sans);
    font-size: 0.85rem;
    color: var(--text2);
    background: transparent;
    border: none;
    cursor: pointer;
    text-align: left;
    transition: background 0.1s, color 0.1s;
}

.rc-dropdown-row:hover[b-nstesivbkb] {
    background: var(--bg3);
    color: var(--text);
}

.rc-dropdown-row--genres[b-nstesivbkb] {
    position: relative;
}

.rc-dropdown-row--genres:hover[b-nstesivbkb] {
    background: var(--blue-dim);
    color: var(--blue);
}

.rc-dropdown-divider[b-nstesivbkb] {
    height: 1px;
    background: var(--border);
    margin: 0.25rem 0;
}

/* ── Genres flyout ── */
.rc-genres-flyout[b-nstesivbkb] {
    position: absolute;
    top: -6px;
    left: calc(100% + 6px);
    width: 520px;
    background: var(--bg2);
    border: 1px solid var(--border);
    border-radius: 6px;
    box-shadow: 0 8px 32px rgba(0, 0, 0, 0.1), 0 2px 8px rgba(0, 0, 0, 0.06);
    padding: 0.75rem 0.75rem 0.5rem;
    z-index: 210;
}

.rc-flyout-header[b-nstesivbkb] {
    border-bottom: 1px solid var(--border);
    padding-bottom: 0.55rem;
    margin-bottom: 0.4rem;
}

.rc-flyout-all[b-nstesivbkb] {
    font-size: 0.68rem;
    font-weight: 500;
    letter-spacing: 0.1em;
    text-transform: uppercase;
    color: var(--blue);
    cursor: pointer;
}

.rc-flyout-all:hover[b-nstesivbkb] {
    text-decoration: underline;
}

.rc-genre-grid[b-nstesivbkb] {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
}

.rc-genre-flyout-row[b-nstesivbkb] {
    display: flex;
    align-items: center;
    justify-content: space-between;
    padding: 0.38rem 0.6rem;
    font-size: 0.83rem;
    color: var(--text2);
    border-radius: 3px;
    cursor: pointer;
    transition: background 0.1s, color 0.1s;
}

.rc-genre-flyout-row:hover[b-nstesivbkb] {
    background: var(--blue-dim);
    color: var(--blue);
}

.rc-genre-count[b-nstesivbkb] {
    font-size: 0.67rem;
    color: var(--text3);
}

/* ── Search bar ── */
.rc-search-shell[b-nstesivbkb] {
    position: relative;
    flex: 1;
    max-width: 560px;
}

.rc-search-bar[b-nstesivbkb] {
    display: flex;
    align-items: center;
    gap: 0.5rem;
    width: 100%;
    background: var(--bg3);
    border: 1px solid var(--border);
    border-radius: 4px;
    padding: 0.3rem 0.75rem;
    transition: border-color 0.15s;
}

.rc-search-bar:focus-within[b-nstesivbkb] {
    border-color: var(--border2);
}

.rc-search-input[b-nstesivbkb] {
    flex: 1;
    border: none;
    background: transparent;
    font-family: var(--sans);
    font-size: 0.82rem;
    color: var(--text);
    outline: none;
    min-width: 0;
}

.rc-search-input[b-nstesivbkb]::placeholder {
    color: var(--text3);
}

.rc-search-clear[b-nstesivbkb] {
    background: none;
    border: none;
    cursor: pointer;
    color: var(--text3);
    font-size: 0.75rem;
    padding: 0;
    line-height: 1;
    flex-shrink: 0;
}

.rc-search-clear:hover[b-nstesivbkb] {
    color: var(--text2);
}

.rc-search-submit[b-nstesivbkb] {
    border: 1px solid var(--border);
    background: var(--bg2);
    color: var(--text2);
    border-radius: 4px;
    padding: 0.2rem 0.7rem;
    font-size: 0.75rem;
    font-family: var(--sans);
    cursor: pointer;
    flex-shrink: 0;
}

.rc-search-submit:hover:not(:disabled)[b-nstesivbkb] {
    border-color: var(--border2);
    color: var(--text);
}

.rc-search-submit:disabled[b-nstesivbkb] {
    opacity: 0.55;
    cursor: not-allowed;
}

.rc-search-suggestions[b-nstesivbkb] {
    position: absolute;
    top: calc(100% + 4px);
    left: 0;
    right: 0;
    background: var(--bg2);
    border: 1px solid var(--border);
    border-radius: 6px;
    box-shadow: 0 8px 24px rgba(0, 0, 0, 0.09);
    z-index: 220;
    padding: 0.35rem 0;
}

.rc-search-suggestion-loading[b-nstesivbkb] {
    padding: 0.5rem 0.85rem;
    font-size: 0.78rem;
    color: var(--text3);
}

.rc-search-suggestion-section[b-nstesivbkb] {
    font-size: 0.64rem;
    font-weight: 500;
    letter-spacing: 0.08em;
    text-transform: uppercase;
    color: var(--text3);
    padding: 0.45rem 0.85rem 0.25rem;
}

.rc-search-suggestion-item[b-nstesivbkb] {
    width: 100%;
    background: transparent;
    border: none;
    text-align: left;
    padding: 0.5rem 0.85rem;
    font-size: 0.82rem;
    color: var(--text2);
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 0.5rem;
    cursor: pointer;
}

.rc-search-suggestion-item:hover[b-nstesivbkb] {
    background: var(--blue-dim);
    color: var(--blue);
}

.rc-search-suggestion-tag[b-nstesivbkb] {
    font-size: 0.62rem;
    color: var(--text3);
}

/* ── Search loading bar ── */
.rc-search-loading-bar[b-nstesivbkb] {
    position: absolute;
    bottom: 0;
    left: 0;
    height: 2px;
    background: var(--blue);
    animation: rc-search-progress-b-nstesivbkb 600ms ease-in-out infinite;
}

@keyframes rc-search-progress-b-nstesivbkb {
    0%   { width: 0; }
    50%  { width: 60%; }
    100% { width: 0; }
}

/* ── Breadcrumb bar ── */
.rc-breadcrumb[b-nstesivbkb] {
    display: flex;
    align-items: center;
    gap: 0.4rem;
    padding: 0.6rem 0;
    background: var(--bg2);
    border-bottom: 1px solid var(--border);
    font-size: 0.8rem;
}

.rc-breadcrumb-link[b-nstesivbkb] {
    color: var(--blue);
    cursor: pointer;
    text-decoration: none;
}

.rc-breadcrumb-link:hover[b-nstesivbkb] {
    text-decoration: underline;
}

.rc-breadcrumb-sep[b-nstesivbkb] {
    color: var(--text3);
}

.rc-breadcrumb-current[b-nstesivbkb] {
    color: var(--text2);
}

.rc-breadcrumb-clear[b-nstesivbkb] {
    margin-left: auto;
    background: transparent;
    border: 1px solid var(--border);
    border-radius: 3px;
    font-size: 0.72rem;
    color: var(--text3);
    padding: 0.15rem 0.5rem;
    cursor: pointer;
    font-family: var(--sans);
    transition: border-color 0.12s, color 0.12s;
}

.rc-breadcrumb-clear:hover[b-nstesivbkb] {
    border-color: var(--border2);
    color: var(--text2);
}

/* ── Main content area ── */
.rc-content[b-nstesivbkb] {
    padding: 1.75rem 0 3rem;
}

/* ── Grid header ── */
.rc-grid-header[b-nstesivbkb] {
    display: flex;
    align-items: center;
    justify-content: space-between;
    margin-bottom: 1.5rem;
    padding-bottom: 1rem;
    border-bottom: 1px solid var(--border);
}

.rc-grid-header-left[b-nstesivbkb] {
    display: flex;
    align-items: center;
    gap: 0.6rem;
    flex-wrap: wrap;
}

.rc-grid-title[b-nstesivbkb] {
    font-family: var(--serif);
    font-size: 1.5rem;
    color: var(--text);
    margin: 0;
}

.rc-grid-subtitle[b-nstesivbkb] {
    font-family: var(--serif);
    font-size: 1rem;
    font-style: italic;
    color: var(--blue);
}

/* ── Sort control ── */
.rc-sort-btn[b-nstesivbkb] {
    display: inline-flex;
    align-items: center;
    font-family: var(--sans);
    font-size: 0.75rem;
    color: var(--text2);
    padding: 0.3rem 0.7rem;
    border: 1px solid var(--border);
    border-radius: 3px;
    background: var(--bg2);
    cursor: pointer;
    white-space: nowrap;
    transition: border-color 0.12s, color 0.12s;
}

.rc-sort-btn:hover[b-nstesivbkb] {
    border-color: var(--border2);
    color: var(--text);
}

.rc-sort-dropdown[b-nstesivbkb] {
    position: absolute;
    top: calc(100% + 4px);
    right: 0;
    min-width: 190px;
    background: var(--bg2);
    border: 1px solid var(--border);
    border-radius: 5px;
    box-shadow: 0 6px 20px rgba(0, 0, 0, 0.1), 0 2px 6px rgba(0, 0, 0, 0.06);
    z-index: 200;
    padding: 0.25rem 0;
}

.rc-sort-option[b-nstesivbkb] {
    display: block;
    width: 100%;
    padding: 0.55rem 1rem;
    font-family: var(--sans);
    font-size: 0.83rem;
    color: var(--text2);
    background: transparent;
    border: none;
    text-align: left;
    cursor: pointer;
    transition: background 0.1s, color 0.1s;
}

.rc-sort-option:hover[b-nstesivbkb] {
    background: var(--bg3);
    color: var(--text);
}

.rc-sort-option--active[b-nstesivbkb] {
    color: var(--blue);
    font-weight: 500;
}



/* ── Filter pill ── */
.rc-filter-pill[b-nstesivbkb] {
    display: inline-flex;
    align-items: center;
    gap: 0.3rem;
    background: var(--blue-dim);
    color: var(--blue);
    border: 1px solid rgba(29, 111, 212, 0.25);
    border-radius: 20px;
    padding: 0.2rem 0.35rem 0.2rem 0.75rem;
    font-size: 0.78rem;
}

.rc-filter-pill-remove[b-nstesivbkb] {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 16px;
    height: 16px;
    border-radius: 50%;
    border: none;
    background: rgba(29, 111, 212, 0.15);
    color: var(--blue);
    font-size: 0.6rem;
    cursor: pointer;
    padding: 0;
    line-height: 1;
}

.rc-filter-pill-remove:hover[b-nstesivbkb] {
    background: rgba(29, 111, 212, 0.3);
}

/* ── Book grid ── */
.rc-book-grid[b-nstesivbkb] {
    display: grid;
    grid-template-columns: repeat(4, minmax(0, 1fr));
    gap: 1.5rem 1.25rem;
}

@media (max-width: 1200px) {
    .rc-book-grid[b-nstesivbkb] {
        grid-template-columns: repeat(3, minmax(0, 1fr));
    }
}

@media (max-width: 992px) {
    .rc-book-grid[b-nstesivbkb] {
        grid-template-columns: repeat(2, minmax(0, 1fr));
    }
}

@media (max-width: 768px) {
    .rc-book-grid[b-nstesivbkb] {
        grid-template-columns: 1fr;
    }
}

@media (max-width: 480px) {
    .rc-book-grid[b-nstesivbkb] {
        grid-template-columns: 1fr;
    }
}

/* ── Pagination ── */
.bk-pagination[b-nstesivbkb] {
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 0.25rem;
    margin-top: 1.5rem;
    flex-wrap: wrap;
}

.bk-page-btn[b-nstesivbkb] {
    font-family: var(--sans);
    font-size: 0.78rem;
    font-weight: 500;
    padding: 0.38rem 0.75rem;
    border: 1px solid var(--border);
    border-radius: 3px;
    background: var(--bg2);
    color: var(--text2);
    cursor: pointer;
    transition: all 0.12s;
    min-width: 36px;
    text-align: center;
}

.bk-page-btn:hover:not(:disabled):not(.bk-page-active)[b-nstesivbkb] {
    background: var(--bg3);
    border-color: var(--border2);
}

.bk-page-btn.bk-page-active[b-nstesivbkb] {
    background: var(--blue);
    color: white;
    border-color: var(--blue);
}

.bk-page-btn:disabled[b-nstesivbkb],
.bk-page-btn[aria-disabled="true"][b-nstesivbkb] {
    color: var(--text3);
    cursor: default;
}

.bk-page-btn.bk-ellipsis[b-nstesivbkb] {
    cursor: default;
    border-color: transparent;
    background: transparent;
    color: var(--text3);
}

/* ── Book card ── */
.rc-book-card[b-nstesivbkb] {
    cursor: pointer;
}

.rc-book-cover[b-nstesivbkb] {
    aspect-ratio: 2 / 3;
    border-radius: 2px;
    position: relative;
    overflow: hidden;
    margin-bottom: 0.65rem;
    box-shadow: 3px 4px 12px rgba(0, 0, 0, 0.18), inset -3px 0 5px rgba(0, 0, 0, 0.12);
    transition: transform 0.2s ease, box-shadow 0.2s ease;
}

.rc-book-cover:hover[b-nstesivbkb] {
    transform: translateY(-3px);
    box-shadow: 0 14px 32px rgba(0, 0, 0, 0.18), 3px 0 0 rgba(29, 111, 212, 0.35);
}

.rc-book-cover-img[b-nstesivbkb] {
    width: 100%;
    height: 100%;
    object-fit: cover;
    display: block;
}

.rc-book-spine[b-nstesivbkb] {
    position: absolute;
    left: 0;
    top: 0;
    bottom: 0;
    width: 7px;
    background: rgba(0, 0, 0, 0.2);
}

.rc-book-cover-text[b-nstesivbkb] {
    position: absolute;
    bottom: 0;
    left: 7px;
    right: 0;
    padding: 0.85rem;
    background: linear-gradient(to top, rgba(0,0,0,0.6) 0%, transparent 100%);
}

.rc-book-cover-title[b-nstesivbkb] {
    font-family: var(--serif);
    font-size: 0.78rem;
    color: #fff;
    text-shadow: 0 1px 4px rgba(0, 0, 0, 0.55);
    line-height: 1.3;
    margin-bottom: 0.15rem;
    overflow: hidden;
    display: -webkit-box;
    -webkit-line-clamp: 3;
    -webkit-box-orient: vertical;
}

.rc-book-cover-author[b-nstesivbkb] {
    font-size: 0.65rem;
    color: rgba(255, 255, 255, 0.8);
    text-shadow: 0 1px 4px rgba(0, 0, 0, 0.55);
}

.rc-book-meta-title[b-nstesivbkb] {
    font-size: 0.83rem;
    font-weight: 500;
    color: var(--text);
    line-height: 1.3;
    margin-bottom: 0.15rem;
    overflow: hidden;
    display: -webkit-box;
    -webkit-line-clamp: 2;
    -webkit-box-orient: vertical;
}

.rc-book-meta-author[b-nstesivbkb] {
    font-size: 0.73rem;
    color: var(--text3);
    margin-bottom: 0.2rem;
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
}

.rc-book-stars[b-nstesivbkb] {
    color: var(--amber);
    font-size: 0.68rem;
    letter-spacing: 0.05em;
}

.rc-book-genre-tag[b-nstesivbkb] {
    display: inline-block;
    font-size: 0.6rem;
    font-weight: 500;
    text-transform: uppercase;
    background: var(--bg3);
    color: var(--text3);
    border: 1px solid var(--border);
    padding: 0.12rem 0.45rem;
    border-radius: 2px;
    margin-top: 0.3rem;
}

/* ── Infinite scroll sentinel and loading indicator ── */
.rc-scroll-sentinel[b-nstesivbkb] {
    height: 1px;
    margin-top: 0.75rem;
}

.rc-scroll-loading[b-nstesivbkb] {
    text-align: center;
    color: var(--text3);
    font-size: 0.85rem;
    padding: 0.75rem 0;
    margin: 0;
}

/* ── Genres page grid ── */
.rc-genres-grid[b-nstesivbkb] {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(200px, 1fr));
    gap: 0.75rem;
}

.rc-genre-card[b-nstesivbkb] {
    background: var(--bg2);
    border: 1px solid var(--border);
    border-radius: 4px;
    padding: 0.9rem 1.1rem;
    display: flex;
    align-items: center;
    justify-content: space-between;
    cursor: pointer;
    transition: border-color 0.15s, background 0.15s;
}

.rc-genre-card:hover[b-nstesivbkb] {
    border-color: var(--blue);
    background: var(--blue-dim);
}

.rc-genre-card-name[b-nstesivbkb] {
    font-size: 0.88rem;
    font-weight: 500;
    color: var(--text);
}

.rc-genre-card-count[b-nstesivbkb] {
    font-size: 0.78rem;
    color: var(--text3);
}

/* ── Search results ── */
.rc-search-section-label[b-nstesivbkb] {
    font-size: 0.65rem;
    font-weight: 500;
    letter-spacing: 0.1em;
    text-transform: uppercase;
    color: var(--text3);
    border-bottom: 1px solid var(--border);
    padding-bottom: 0.5rem;
    margin-bottom: 0.85rem;
}

.rc-author-results[b-nstesivbkb] {
    display: flex;
    flex-wrap: wrap;
    gap: 0.75rem;
    margin-bottom: 0.5rem;
}

.rc-author-card[b-nstesivbkb] {
    display: flex;
    align-items: center;
    gap: 0.75rem;
    background: var(--bg2);
    border: 1px solid var(--border);
    border-radius: 4px;
    padding: 0.85rem 1rem;
    width: 220px;
    text-decoration: none;
    transition: border-color 0.15s, background 0.15s;
    cursor: pointer;
}

.rc-author-card:hover[b-nstesivbkb] {
    border-color: var(--blue);
    background: var(--blue-dim);
}

.rc-author-avatar[b-nstesivbkb] {
    width: 40px;
    height: 40px;
    border-radius: 50%;
    background: var(--bg3);
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 0.85rem;
    font-weight: 500;
    color: var(--text2);
    flex-shrink: 0;
}

.rc-author-name[b-nstesivbkb] {
    font-size: 0.88rem;
    font-weight: 500;
    color: var(--text);
}

.rc-author-count[b-nstesivbkb] {
    font-size: 0.75rem;
    color: var(--text3);
}

.rc-view-all-link[b-nstesivbkb] {
    color: var(--blue);
    font-size: 0.82rem;
    text-decoration: none;
}

.rc-view-all-link:hover[b-nstesivbkb] {
    text-decoration: underline;
}

.rc-genre-intro[b-nstesivbkb] {
    margin-bottom: 1.25rem;
}

.rc-genre-intro p[b-nstesivbkb] {
    margin: 0 0 0.85rem 0;
    color: var(--text2);
    font-size: 0.92rem;
    line-height: 1.55;
}

.rc-genre-filter-row[b-nstesivbkb] {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    gap: 0.45rem;
}

.rc-genre-filter-link[b-nstesivbkb] {
    border: 1px solid var(--border);
    border-radius: 999px;
    padding: 0.2rem 0.65rem;
    color: var(--text2);
    font-size: 0.72rem;
    text-decoration: none;
}

.rc-genre-filter-link.active[b-nstesivbkb],
.rc-genre-filter-link:hover[b-nstesivbkb] {
    border-color: var(--blue);
    color: var(--blue);
    background: var(--blue-dim);
}

.rc-genre-nav[b-nstesivbkb] {
    display: grid;
    gap: 0.75rem;
    margin-bottom: 1.1rem;
}

.rc-genre-sections[b-nstesivbkb] {
    display: grid;
    gap: 1rem;
    margin-bottom: 1.25rem;
}

.rc-genre-panel[b-nstesivbkb] {
    border: 1px solid var(--border);
    border-radius: 6px;
    padding: 0.9rem;
    background: var(--bg2);
}

.rc-genre-panel h2[b-nstesivbkb] {
    margin: 0 0 0.65rem 0;
    font-size: 1rem;
    font-family: var(--serif);
    color: var(--text);
}

.rc-genre-reading-list[b-nstesivbkb] {
    margin-bottom: 0.85rem;
}

.rc-genre-reading-list ul[b-nstesivbkb] {
    margin: 0.35rem 0 0 0;
    padding-left: 1rem;
}

.rc-genre-reading-list li[b-nstesivbkb] {
    margin-bottom: 0.2rem;
}

.rc-empty-muted[b-nstesivbkb] {
    color: var(--text3);
    font-size: 0.85rem;
    margin: 0.5rem 0;
}

/* ── Full empty state ── */
.rc-empty-state[b-nstesivbkb] {
    text-align: center;
    padding: 3rem 1rem;
}

.rc-empty-heading[b-nstesivbkb] {
    font-family: var(--serif);
    font-size: 1.25rem;
    color: var(--text);
    margin-bottom: 0.5rem;
}

.rc-empty-sub[b-nstesivbkb] {
    font-size: 0.85rem;
    color: var(--text2);
}
/* _content/ReadersClub.Blazor/Components/Pages/Feed.razor.rz.scp.css */
/* Page wrapper */
.feed-page-wrap[b-pw2t10fip9] {
    width: 100%;
    max-width: 1100px;
    min-width: 0;
    margin: 0 auto;
    padding: 2rem 2.5rem 4rem;
    display: grid;
    grid-template-columns: 1fr 300px;
    gap: 2rem;
    align-items: start;
}

/* Feed column */
.feed-col[b-pw2t10fip9] { min-width: 0; }

.feed-header[b-pw2t10fip9] {
    display: block;
    margin-bottom: 1.5rem;
}

.composer-bar[b-pw2t10fip9] {
    display: flex;
    align-items: center;
    gap: 0.9rem;
    padding: 1rem 1.1rem;
    background: var(--bg2);
    border: 1px solid var(--border);
    border-radius: 8px;
}

.composer-avatar[b-pw2t10fip9] {
    width: 42px;
    height: 42px;
    border-radius: 50%;
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 0.82rem;
    font-weight: 600;
    flex-shrink: 0;
    object-fit: cover;
    overflow: hidden;
}

.composer-trigger[b-pw2t10fip9] {
    flex: 1;
    min-width: 0;
    border: none;
    border-radius: 999px;
    background: var(--bg);
    color: var(--text2);
    font-size: 1rem;
    padding: 0.95rem 1.35rem;
    text-align: left;
    cursor: pointer;
}

.composer-trigger:focus[b-pw2t10fip9] {
    outline: 2px solid var(--blue);
    outline-offset: 2px;
}

/* Review card */
.review-card[b-pw2t10fip9] {
    width: 100%;
    max-width: 100%;
    background: var(--bg2);
    border: 1px solid var(--border);
    border-radius: 6px;
    margin-bottom: 1.25rem;
    overflow: hidden;
    transition: border-color 0.15s;
}

.review-card:hover[b-pw2t10fip9] { border-color: var(--border2); }

/* Reviewer row (top of card) */
.reviewer-row[b-pw2t10fip9] {
    display: flex;
    align-items: center;
    gap: 0.75rem;
    padding: 0.9rem 1.25rem 0;
}

.reviewer-avatar[b-pw2t10fip9] {
    width: 34px;
    height: 34px;
    border-radius: 50%;
    flex-shrink: 0;
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 0.7rem;
    font-weight: 500;
    object-fit: cover;
    overflow: hidden;
}

.reviewer-name[b-pw2t10fip9] {
    font-size: 0.85rem;
    font-weight: 500;
    color: var(--blue);
    text-decoration: none;
}
.reviewer-name:hover[b-pw2t10fip9] { text-decoration: underline; }

.reviewer-info[b-pw2t10fip9] {
    flex: 1;
    min-width: 0;
}

.reviewer-meta[b-pw2t10fip9] {
    font-size: 0.72rem;
    color: var(--text3);
    overflow-wrap: anywhere;
    word-break: break-word;
}
.reviewer-time[b-pw2t10fip9]  { margin-left: auto; font-size: 0.72rem; color: var(--text3); white-space: nowrap; }

/* Card body */
.card-body[b-pw2t10fip9] {
    display: flex;
    gap: 1.1rem;
    padding: 0.85rem 1.25rem 1rem;
}

/* Book cover thumbnail */
.book-cover[b-pw2t10fip9] {
    width: 76px;
    min-width: 76px;
    height: 108px;
    border-radius: 2px;
    flex-shrink: 0;
    box-shadow: 2px 3px 10px rgba(0,0,0,0.18), inset -2px 0 4px rgba(0,0,0,0.12);
    position: relative;
    overflow: hidden;
    display: flex;
    flex-direction: column;
    justify-content: flex-end;
    padding: 0.4rem;
    transition: transform 0.18s, box-shadow 0.18s;
    text-decoration: none;
}

.book-cover--photo[b-pw2t10fip9] {
    padding: 0;
}

.book-cover-image[b-pw2t10fip9] {
    width: 100%;
    height: 100%;
    object-fit: cover;
    display: block;
    border-radius: 2px;
}

.book-cover:hover[b-pw2t10fip9] {
    transform: translateY(-2px);
    box-shadow: 0 8px 18px rgba(0,0,0,0.22), 2px 0 0 rgba(29,112,212,0.3);
}

.book-cover-spine[b-pw2t10fip9] {
    position: absolute;
    left: 0; top: 0; bottom: 0;
    width: 5px;
    background: rgba(0,0,0,0.2);
}

.book-cover-title[b-pw2t10fip9] {
    font-family: var(--serif);
    font-size: 0.52rem;
    font-weight: 600;
    color: rgba(255,255,255,0.95);
    line-height: 1.2;
    text-shadow: 0 1px 3px rgba(0,0,0,0.5);
    position: relative;
    z-index: 1;
}

/* Review text area */
.review-content[b-pw2t10fip9] {
    flex: 1;
    min-width: 0;
    max-width: 100%;
}

.book-title[b-pw2t10fip9] {
    font-family: var(--serif);
    font-size: 1rem;
    font-weight: 400;
    color: var(--text);
    text-decoration: none;
    line-height: 1.3;
    display: block;
    margin-bottom: 0.1rem;
    overflow-wrap: anywhere;
    word-break: break-word;
}
.book-title:hover[b-pw2t10fip9] { color: var(--blue); }

.book-author[b-pw2t10fip9] {
    font-size: 0.75rem;
    color: var(--text3);
    margin-bottom: 0.35rem;
    overflow-wrap: anywhere;
    word-break: break-word;
}

.stars-row[b-pw2t10fip9] { display: flex; align-items: center; gap: 0.5rem; margin-bottom: 0.5rem; }
.stars[b-pw2t10fip9]      { color: var(--amber); font-size: 0.75rem; letter-spacing: 0.04em; }

.spoiler-badge[b-pw2t10fip9] {
    font-size: 0.58rem;
    font-weight: 500;
    letter-spacing: 0.04em;
    text-transform: uppercase;
    background: #fef9c3;
    color: #854d0e;
    border: 1px solid #fde68a;
    padding: 0.1rem 0.4rem;
    border-radius: 2px;
}

.review-text[b-pw2t10fip9] {
    font-size: 0.85rem;
    color: var(--text2);
    line-height: 1.7;
    white-space: pre-line;
    overflow-wrap: anywhere;
    word-break: break-word;
}

.review-text.clamped[b-pw2t10fip9] {
    display: -webkit-box;
    -webkit-line-clamp: 4;
    -webkit-box-orient: vertical;
    overflow: hidden;
}

.read-more[b-pw2t10fip9] {
    font-size: 0.78rem;
    font-weight: 500;
    color: var(--blue);
    text-decoration: none;
    margin-top: 0.3rem;
    display: inline-block;
    background: none;
    border: 0;
    padding: 0;
    font-family: var(--sans);
    cursor: pointer;
}
.read-more:hover[b-pw2t10fip9] { text-decoration: underline; }

/* Card footer */
.card-footer[b-pw2t10fip9] {
    display: flex;
    align-items: center;
    gap: 1rem;
    padding: 0.7rem 1.25rem;
    border-top: 1px solid var(--border);
    background: var(--bg);
}

.card-action[b-pw2t10fip9] {
    display: flex;
    align-items: center;
    gap: 0.35rem;
    font-size: 0.75rem;
    color: var(--text3);
    cursor: pointer;
    background: none;
    border: none;
    padding: 0;
    font-family: var(--sans);
    transition: color 0.12s;
    text-decoration: none;
}
.card-action:hover[b-pw2t10fip9] { color: var(--blue); }
.card-action.liked[b-pw2t10fip9] { color: var(--blue); }
.card-action.reposted[b-pw2t10fip9] { color: var(--blue); }
.card-action:disabled[b-pw2t10fip9] {
    cursor: default;
    opacity: 0.65;
}

.genre-tag[b-pw2t10fip9] {
    font-size: 0.6rem;
    font-weight: 500;
    letter-spacing: 0.05em;
    text-transform: uppercase;
    background: var(--bg3);
    color: var(--text3);
    border: 1px solid var(--border);
    padding: 0.12rem 0.45rem;
    border-radius: 2px;
    margin-left: auto;
}

/* ── Inline feed comments ── */
.fc-comments[b-pw2t10fip9] {
    border-top: 1px solid var(--border);
    background: var(--bg);
}

.fc-loading[b-pw2t10fip9] {
    padding: 0.75rem 1rem;
    font-size: 0.78rem;
    color: var(--text3);
    font-style: italic;
}

.fc-comment-list[b-pw2t10fip9] {
    padding: 0.5rem 1rem 0;
}

.fc-comment[b-pw2t10fip9] {
    display: flex;
    gap: 0.6rem;
    padding: 0.5rem 0;
    border-bottom: 1px solid var(--border);
}

.fc-comment:last-child[b-pw2t10fip9] {
    border-bottom: none;
}

.fc-comment-avatar-fb[b-pw2t10fip9] {
    width: 28px;
    height: 28px;
    min-width: 28px;
    border-radius: 50%;
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 0.6rem;
    font-weight: 600;
    flex-shrink: 0;
    margin-top: 1px;
}

.fc-comment-body[b-pw2t10fip9] {
    flex: 1;
    min-width: 0;
}

.fc-comment-meta[b-pw2t10fip9] {
    display: flex;
    align-items: baseline;
    gap: 0.4rem;
    margin-bottom: 0.15rem;
}

.fc-comment-author[b-pw2t10fip9] {
    font-size: 0.78rem;
    font-weight: 500;
    color: var(--text);
    text-decoration: none;
}

.fc-comment-author:hover[b-pw2t10fip9] {
    color: var(--blue);
}

.fc-comment-date[b-pw2t10fip9] {
    font-size: 0.62rem;
    color: var(--text3);
}

.fc-comment-text[b-pw2t10fip9] {
    font-size: 0.78rem;
    color: var(--text2);
    line-height: 1.55;
}

.fc-comment-like[b-pw2t10fip9] {
    font-size: 0.65rem;
    color: var(--text3);
    background: none;
    border: none;
    cursor: pointer;
    font-family: var(--sans);
    margin-top: 0.25rem;
    display: inline-flex;
    align-items: center;
    gap: 0.2rem;
    padding: 0;
    transition: color 0.12s;
}

.fc-comment-like:hover[b-pw2t10fip9] {
    color: var(--red);
}

/* Input row */
.fc-input-row[b-pw2t10fip9] {
    display: flex;
    align-items: center;
    gap: 0.6rem;
    padding: 0.6rem 1rem 0.7rem;
}

.fc-input-avatar[b-pw2t10fip9] {
    width: 28px;
    height: 28px;
    min-width: 28px;
    border-radius: 50%;
    object-fit: cover;
    flex-shrink: 0;
}

.fc-input-avatar-fb[b-pw2t10fip9] {
    width: 28px;
    height: 28px;
    min-width: 28px;
    border-radius: 50%;
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 0.6rem;
    font-weight: 600;
    flex-shrink: 0;
}

.fc-input-wrap[b-pw2t10fip9] {
    display: flex;
    align-items: center;
    flex: 1;
    background: var(--bg2);
    border: 1px solid var(--border);
    border-radius: 20px;
    padding: 0.3rem 0.6rem 0.3rem 0.85rem;
    transition: border-color 0.15s;
}

.fc-input-wrap:focus-within[b-pw2t10fip9] {
    border-color: var(--blue);
}

.fc-input[b-pw2t10fip9] {
    flex: 1;
    border: none;
    background: transparent;
    font-family: var(--sans);
    font-size: 0.78rem;
    color: var(--text);
    outline: none;
    min-width: 0;
}

.fc-input[b-pw2t10fip9]::placeholder {
    color: var(--text3);
}

.fc-send[b-pw2t10fip9] {
    background: none;
    border: none;
    cursor: pointer;
    color: var(--text3);
    padding: 0 0.2rem;
    display: flex;
    align-items: center;
    transition: color 0.12s;
}

.fc-send:hover:not(:disabled)[b-pw2t10fip9] {
    color: var(--blue);
}

.fc-send:disabled[b-pw2t10fip9] {
    opacity: 0.4;
    cursor: default;
}

/* Active state on comment button */
.card-action.active[b-pw2t10fip9] {
    color: var(--blue);
}

/* Infinite scroll sentinel */
.feed-sentinel[b-pw2t10fip9] {
    height: 1px;
    margin-top: 0.75rem;
}

/* Loading indicator shown while fetching the next page */
.feed-loading-indicator[b-pw2t10fip9] {
    text-align: center;
    color: var(--text3);
    font-size: 0.85rem;
    padding: 0.75rem 0;
    margin: 0;
}

/* Sidebar */
.sidebar-col[b-pw2t10fip9] {
    position: sticky;
    top: 78px;
    display: flex;
    flex-direction: column;
    gap: 1.25rem;
}

.widget[b-pw2t10fip9] {
    background: var(--bg2);
    border: 1px solid var(--border);
    border-radius: 6px;
    overflow: hidden;
}

.widget-hdr[b-pw2t10fip9] {
    padding: 0.8rem 1.1rem 0.7rem;
    border-bottom: 1px solid var(--border);
    font-size: 0.65rem;
    font-weight: 500;
    letter-spacing: 0.1em;
    text-transform: uppercase;
    color: var(--text3);
    margin: 0;
}

.widget-body[b-pw2t10fip9] { padding: 0.9rem 1.1rem; }

.widget-footer[b-pw2t10fip9] {
    padding: 0.6rem 1.1rem;
    border-top: 1px solid var(--border);
    background: var(--bg);
}

/* Sidebar suggestion items */
.sug-item[b-pw2t10fip9] {
    display: flex;
    align-items: center;
    gap: 0.7rem;
    padding: 0.5rem 0;
    border-bottom: 1px solid var(--border);
}
.sug-item:last-child[b-pw2t10fip9] { border-bottom: none; padding-bottom: 0; }
.sug-item:first-child[b-pw2t10fip9] { padding-top: 0; }

.sug-av[b-pw2t10fip9] {
    width: 34px;
    height: 34px;
    min-width: 34px;
    border-radius: 50%;
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 0.7rem;
    font-weight: 500;
    object-fit: cover;
    overflow: hidden;
}

.sug-avatar-img[b-pw2t10fip9] {
    display: block;
}

.sug-name[b-pw2t10fip9] {
    font-size: 0.82rem;
    font-weight: 500;
    color: var(--text);
    text-decoration: none;
}
.sug-name:hover[b-pw2t10fip9] { color: var(--blue); }

.sug-sub[b-pw2t10fip9] { font-size: 0.7rem; color: var(--text3); white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }

.sug-follow-btn[b-pw2t10fip9] {
    font-size: 0.68rem;
    font-weight: 500;
    padding: 0.22rem 0.65rem;
    border: 1px solid var(--border2);
    border-radius: 3px;
    background: transparent;
    color: var(--text2);
    cursor: pointer;
    white-space: nowrap;
    transition: all 0.12s;
}
.sug-follow-btn:hover[b-pw2t10fip9] { border-color: var(--blue); color: var(--blue); background: var(--blue-dim); }
.sug-follow-btn.followed[b-pw2t10fip9] { background: var(--blue-dim); border-color: var(--blue); color: var(--blue); }

/* Trending items */
.trend-item[b-pw2t10fip9] {
    display: flex;
    align-items: center;
    gap: 0.7rem;
    padding: 0.5rem 0;
    border-bottom: 1px solid var(--border);
    cursor: pointer;
    text-decoration: none;
}
.trend-item:last-child[b-pw2t10fip9] { border-bottom: none; padding-bottom: 0; }
.trend-item:first-child[b-pw2t10fip9] { padding-top: 0; }
.trend-item:hover .trend-title[b-pw2t10fip9] { color: var(--blue); }

.trend-cover[b-pw2t10fip9] {
    width: 30px;
    min-width: 30px;
    aspect-ratio: 2 / 3;
    border-radius: 2px;
    box-shadow: 1px 2px 5px rgba(0,0,0,0.15);
    display: block;
    object-fit: cover;
}

.trend-title[b-pw2t10fip9] {
    font-size: 0.8rem;
    font-weight: 500;
    color: var(--text);
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
    transition: color 0.12s;
}

.trend-author[b-pw2t10fip9] { font-size: 0.7rem; color: var(--text3); }
.trend-ct[b-pw2t10fip9]     { font-size: 0.68rem; color: var(--text3); white-space: nowrap; }

/* See more link */
.see-more-link[b-pw2t10fip9] {
    font-size: 0.72rem;
    font-weight: 500;
    color: var(--blue);
    text-decoration: none;
    display: flex;
    align-items: center;
    gap: 0.3rem;
}
.see-more-link:hover[b-pw2t10fip9] { text-decoration: underline; }
.see-more-link svg[b-pw2t10fip9] { transition: transform 0.15s; }
.see-more-link:hover svg[b-pw2t10fip9] { transform: translateX(2px); }

/* Empty feed state */
.feed-empty[b-pw2t10fip9] {
    text-align: center;
    padding: 4rem 2rem;
    background: var(--bg2);
    border: 1px solid var(--border);
    border-radius: 6px;
}
.feed-empty-title[b-pw2t10fip9] {
    font-family: var(--serif);
    font-size: 1.2rem;
    color: var(--text);
    margin: 0 0 0.5rem;
}
.feed-empty-sub[b-pw2t10fip9] {
    font-size: 0.85rem;
    color: var(--text3);
    margin-bottom: 1.5rem;
    line-height: 1.6;
}
.feed-empty-cta[b-pw2t10fip9] {
    display: inline-flex;
    align-items: center;
    font-size: 0.78rem;
    font-weight: 500;
    letter-spacing: 0.05em;
    text-transform: uppercase;
    padding: 0.55rem 1.25rem;
    background: var(--blue);
    color: white;
    border-radius: 3px;
    text-decoration: none;
    transition: background 0.15s;
}
.feed-empty-cta:hover[b-pw2t10fip9] { background: var(--blue-dk); }

.composer-modal-backdrop[b-pw2t10fip9] {
    background: rgba(0,0,0,.45);
}

.composer-modal-dialog[b-pw2t10fip9] {
    max-width: 760px;
}

.composer-modal-content[b-pw2t10fip9] {
    border-radius: 10px;
}

/* Responsive */
@media (max-width: 900px) {
    .feed-page-wrap[b-pw2t10fip9] {
        grid-template-columns: 1fr;
        padding: 1.5rem 1rem 3rem;
    }

    .sidebar-col[b-pw2t10fip9] {
        position: static;
    }

    .composer-bar[b-pw2t10fip9] {
        gap: 0.75rem;
        padding: 0.85rem;
    }

    .composer-trigger[b-pw2t10fip9] {
        font-size: 0.92rem;
        padding: 0.85rem 1rem;
    }
}

@media (max-width: 640px) {
    .feed-page-wrap[b-pw2t10fip9] {
        padding-left: 0.75rem;
        padding-right: 0.75rem;
    }

    .reviewer-row[b-pw2t10fip9] {
        display: grid;
        grid-template-columns: auto minmax(0, 1fr);
        grid-template-areas:
            "avatar info"
            "avatar time";
        column-gap: 0.75rem;
        row-gap: 0.25rem;
        padding: 0.8rem 0.9rem 0;
        align-items: start;
    }

    .reviewer-avatar[b-pw2t10fip9] {
        grid-area: avatar;
    }

    .reviewer-info[b-pw2t10fip9] {
        grid-area: info;
    }

    .reviewer-time[b-pw2t10fip9] {
        grid-area: time;
        margin-left: 0;
        white-space: normal;
        text-align: left;
        justify-self: start;
    }

    .card-body[b-pw2t10fip9] {
        display: grid;
        grid-template-columns: 58px minmax(0, 1fr);
        align-items: start;
        padding: 0.75rem 0.9rem 0.9rem;
        gap: 0.75rem;
    }

    .book-cover[b-pw2t10fip9] {
        width: 58px;
        min-width: 58px;
        height: 84px;
    }

    .stars-row[b-pw2t10fip9] {
        flex-wrap: wrap;
    }

    .card-footer[b-pw2t10fip9] {
        padding: 0.6rem 0.9rem;
        gap: 0.75rem;
        flex-wrap: wrap;
    }

    .genre-tag[b-pw2t10fip9] {
        margin-left: 0;
    }
}

@media (max-width: 480px) {
    .feed-page-wrap[b-pw2t10fip9] {
        padding-left: 0.5rem;
        padding-right: 0.5rem;
    }

    .composer-bar[b-pw2t10fip9] {
        gap: 0.65rem;
        padding: 0.75rem;
    }

    .composer-trigger[b-pw2t10fip9] {
        font-size: 0.9rem;
        padding: 0.8rem 0.95rem;
    }

    .reviewer-row[b-pw2t10fip9] {
        padding: 0.75rem 0.75rem 0;
    }

    .card-body[b-pw2t10fip9] {
        grid-template-columns: 48px minmax(0, 1fr);
        padding: 0.7rem 0.75rem 0.85rem;
        gap: 0.65rem;
    }

    .book-cover[b-pw2t10fip9] {
        width: 48px;
        min-width: 48px;
        height: 72px;
    }

    .book-title[b-pw2t10fip9] {
        font-size: 0.92rem;
    }

    .book-author[b-pw2t10fip9] {
        font-size: 0.72rem;
        margin-bottom: 0.3rem;
    }

    .review-text[b-pw2t10fip9] {
        font-size: 0.8rem;
        line-height: 1.6;
    }

    .read-more[b-pw2t10fip9],
    .card-action[b-pw2t10fip9] {
        font-size: 0.72rem;
    }

    .card-footer[b-pw2t10fip9] {
        padding: 0.55rem 0.75rem;
        gap: 0.5rem 0.75rem;
    }

    .genre-tag[b-pw2t10fip9] {
        flex-basis: 100%;
        width: fit-content;
    }
}
/* _content/ReadersClub.Blazor/Components/Pages/Home.razor.rz.scp.css */
/* ── Landing page (Home.razor) ── */

/* Hero */
.lp-hero[b-15pkwteaqr] {
    padding: 5rem 3rem 4rem;
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 4rem;
    align-items: center;
    max-width: 1100px;
    margin: 0 auto;
}

.lp-hero-eyebrow[b-15pkwteaqr] {
    font-size: 0.65rem;
    font-weight: 500;
    letter-spacing: 0.12em;
    text-transform: uppercase;
    color: var(--blue);
    margin-bottom: 0.75rem;
}

.lp-hero-h1[b-15pkwteaqr] {
    font-family: var(--serif);
    font-size: 3rem;
    font-weight: 400;
    color: var(--text);
    line-height: 1.15;
    letter-spacing: -0.02em;
    margin-bottom: 1.25rem;
}

.lp-hero-h1 em[b-15pkwteaqr] {
    font-style: italic;
    color: var(--blue);
}

.lp-hero-sub[b-15pkwteaqr] {
    font-size: 0.95rem;
    color: var(--text2);
    line-height: 1.75;
    margin-bottom: 2rem;
    max-width: 420px;
}

.lp-hero-btns[b-15pkwteaqr] {
    display: flex;
    align-items: center;
    gap: 0.75rem;
    margin-bottom: 2.5rem;
}

.lp-btn-primary[b-15pkwteaqr] {
    font-size: 0.8rem;
    font-weight: 500;
    letter-spacing: 0.04em;
    padding: 0.6rem 1.5rem;
    background: var(--text);
    color: #fff;
    border: none;
    border-radius: 4px;
    cursor: pointer;
    font-family: var(--sans);
    text-decoration: none;
}

.lp-btn-primary:hover[b-15pkwteaqr] {
    opacity: 0.9;
    color: #fff;
}

.lp-btn-secondary[b-15pkwteaqr] {
    font-size: 0.8rem;
    font-weight: 500;
    padding: 0.6rem 1.25rem;
    background: transparent;
    color: var(--text2);
    border: 0.5px solid var(--border);
    border-radius: 4px;
    cursor: pointer;
    font-family: var(--sans);
    text-decoration: none;
}

.lp-btn-secondary:hover[b-15pkwteaqr] {
    border-color: var(--border2);
    color: var(--text);
}

/* Book stack */
.lp-book-stack[b-15pkwteaqr] {
    position: relative;
    height: 340px;
}

.lp-book-card[b-15pkwteaqr] {
    position: absolute;
    display: block;
    background: var(--bg2);
    border: 0.5px solid var(--border);
    border-radius: 8px;
    overflow: hidden;
    width: 160px;
    height: 220px;
    text-decoration: none;
    color: inherit;
}

.lp-book-card:hover[b-15pkwteaqr] {
    color: inherit;
}

.lp-bc1[b-15pkwteaqr] {
    top: 60px;
    left: 30px;
    transform: rotate(-4deg);
}

.lp-bc2[b-15pkwteaqr] {
    top: 40px;
    left: 130px;
    transform: rotate(1deg);
}

.lp-bc3[b-15pkwteaqr] {
    top: 80px;
    left: 230px;
    transform: rotate(3deg);
}

.lp-book-cover-placeholder[b-15pkwteaqr] {
    width: 100%;
    height: 160px;
    background: linear-gradient(160deg, #1a3a5c, #0d2137);
    display: block;
}

.lp-book-cover-img[b-15pkwteaqr] {
    width: 100%;
    height: 160px;
    object-fit: cover;
    display: block;
}

.lp-book-meta[b-15pkwteaqr] {
    padding: 0.5rem 0.6rem;
}

.lp-book-title-sm[b-15pkwteaqr] {
    font-family: var(--serif);
    font-size: 0.72rem;
    color: var(--text);
    line-height: 1.3;
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
}

.lp-book-author-sm[b-15pkwteaqr] {
    font-size: 0.62rem;
    color: var(--text3);
    margin-top: 0.1rem;
}

.lp-book-stars-sm[b-15pkwteaqr] {
    font-size: 0.6rem;
    color: var(--blue);
    margin-top: 0.15rem;
}

/* Divider */
.lp-divider[b-15pkwteaqr] {
    border: none;
    border-top: 0.5px solid var(--border);
    margin: 0 3rem;
}

/* Section */
.lp-section[b-15pkwteaqr] {
    padding: 3.5rem 3rem;
    max-width: 1100px;
    margin: 0 auto;
}

.lp-section-label[b-15pkwteaqr] {
    font-size: 0.65rem;
    font-weight: 500;
    letter-spacing: 0.12em;
    text-transform: uppercase;
    color: var(--blue);
    margin-bottom: 0.5rem;
}

.lp-section-title[b-15pkwteaqr] {
    font-family: var(--serif);
    font-size: 1.8rem;
    font-weight: 400;
    color: var(--text);
    margin: 0 0 0.5rem;
}

.lp-section-sub[b-15pkwteaqr] {
    font-size: 0.85rem;
    color: var(--text2);
    line-height: 1.7;
    max-width: 480px;
    margin-bottom: 2rem;
}

/* Feature cards */
.lp-features[b-15pkwteaqr] {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 1rem;
    margin-bottom: 3rem;
}

.lp-feat-card[b-15pkwteaqr] {
    background: var(--bg2);
    border: 0.5px solid var(--border);
    border-radius: 10px;
    padding: 1.25rem;
}

.lp-feat-icon[b-15pkwteaqr] {
    width: 36px;
    height: 36px;
    border-radius: 8px;
    background: var(--blue-dim);
    display: flex;
    align-items: center;
    justify-content: center;
    margin-bottom: 0.85rem;
}

.lp-feat-title[b-15pkwteaqr] {
    font-family: var(--serif);
    font-size: 1rem;
    font-weight: 400;
    color: var(--text);
    margin: 0 0 0.35rem;
}

.lp-feat-body[b-15pkwteaqr] {
    font-size: 0.78rem;
    color: var(--text2);
    line-height: 1.65;
}

/* Reviews */
.lp-reviews-row[b-15pkwteaqr] {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 1rem;
}

.lp-rv[b-15pkwteaqr] {
    background: var(--bg2);
    border: 0.5px solid var(--border);
    border-radius: 10px;
    padding: 1rem;
}

.lp-rv-link[b-15pkwteaqr] {
    display: block;
    color: inherit;
    text-decoration: none;
}

.lp-rv-top[b-15pkwteaqr] {
    display: flex;
    align-items: center;
    gap: 0.6rem;
    margin-bottom: 0.65rem;
}

.lp-rv-avatar[b-15pkwteaqr] {
    width: 32px;
    height: 32px;
    min-width: 32px;
    border-radius: 50%;
    object-fit: cover;
    box-shadow: 0 0 0 1.5px #fff, 0 0 0 2.5px #dde3ea;
}

.lp-rv-avatar-fb[b-15pkwteaqr] {
    width: 32px;
    height: 32px;
    min-width: 32px;
    border-radius: 50%;
    background: linear-gradient(135deg, #bfdbfe, #93c5fd);
    color: #1e40af;
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 0.65rem;
    font-weight: 600;
    box-shadow: 0 0 0 1.5px #fff, 0 0 0 2.5px #dde3ea;
}

.lp-rv-name[b-15pkwteaqr] {
    font-size: 0.78rem;
    font-weight: 500;
    color: var(--text);
}

.lp-rv-date[b-15pkwteaqr] {
    font-size: 0.65rem;
    color: var(--text3);
}

.lp-rv-book[b-15pkwteaqr] {
    display: flex;
    gap: 0.5rem;
    margin-bottom: 0.55rem;
    padding: 0.5rem;
    background: var(--bg);
    border-radius: 4px;
}

.lp-rv-book-cover-placeholder[b-15pkwteaqr] {
    width: 28px;
    height: 38px;
    border-radius: 2px;
    flex-shrink: 0;
    background: linear-gradient(160deg, #1a3a5c, #0d2137);
}

.lp-rv-book-cover[b-15pkwteaqr] {
    width: 28px;
    height: 38px;
    object-fit: cover;
    border-radius: 2px;
    flex-shrink: 0;
}

.lp-rv-book-title[b-15pkwteaqr] {
    font-family: var(--serif);
    font-size: 0.72rem;
    color: var(--text);
    line-height: 1.3;
}

.lp-rv-book-author[b-15pkwteaqr] {
    font-size: 0.62rem;
    color: var(--text3);
}

.lp-rv-stars[b-15pkwteaqr] {
    font-size: 0.7rem;
    color: var(--blue);
    margin-bottom: 0.4rem;
}

.lp-rv-body[b-15pkwteaqr] {
    font-size: 0.78rem;
    color: var(--text2);
    line-height: 1.65;
    display: -webkit-box;
    -webkit-line-clamp: 3;
    -webkit-box-orient: vertical;
    overflow: hidden;
}

.lp-rv-thumbs[b-15pkwteaqr] {
    display: flex;
    align-items: center;
    gap: 0.25rem;
    margin-bottom: 0.6rem;
}

.lp-rv-thumb[b-15pkwteaqr] {
    width: 24px;
    height: 34px;
    object-fit: cover;
    border-radius: 2px;
    border: 0.5px solid var(--border);
    flex-shrink: 0;
}

/* Footer */
.lp-footer[b-15pkwteaqr] {
    background: #111827;
    padding: 2.5rem 3rem;
    margin-top: 3rem;
}

.lp-footer-inner[b-15pkwteaqr] {
    max-width: 1100px;
    margin: 0 auto;
    display: flex;
    align-items: center;
    justify-content: space-between;
}

.lp-footer .brand-logo-word[b-15pkwteaqr] {
    color: #fff;
}

.lp-footer-copy[b-15pkwteaqr] {
    font-size: 0.7rem;
    color: #6b7280;
}

.lp-footer-links[b-15pkwteaqr] {
    display: flex;
    gap: 1.5rem;
}

.lp-footer-link[b-15pkwteaqr] {
    font-size: 0.7rem;
    color: #9ca3af;
    text-decoration: none;
}

.lp-footer-link:hover[b-15pkwteaqr] {
    color: #ffffff;
}

/* Responsive */
@media (max-width: 768px) {
    .lp-hero[b-15pkwteaqr] {
        grid-template-columns: 1fr;
        padding: 3rem 1.5rem 2rem;
        gap: 2rem;
    }

    .lp-hero-h1[b-15pkwteaqr] {
        font-size: 2rem;
    }

    .lp-book-stack[b-15pkwteaqr] {
        height: 260px;
    }

    .lp-features[b-15pkwteaqr] {
        grid-template-columns: 1fr;
    }

    .lp-reviews-row[b-15pkwteaqr] {
        grid-template-columns: 1fr;
    }

    .lp-divider[b-15pkwteaqr] {
        margin: 0 1.5rem;
    }

    .lp-section[b-15pkwteaqr] {
        padding: 2.5rem 1.5rem;
    }

    .lp-footer[b-15pkwteaqr] {
        padding: 2rem 1.5rem;
    }

    .lp-footer-inner[b-15pkwteaqr] {
        flex-direction: column;
        gap: 1rem;
        text-align: center;
    }
}
/* _content/ReadersClub.Blazor/Components/Pages/Me/EditProfile.razor.rz.scp.css */
/* ── Page shell ── */
.ep-page[b-38ppoeewv3] {
    display: flex;
    min-height: calc(100vh - 58px);
    background: var(--bg);
}

.ep-state[b-38ppoeewv3] {
    padding: 2rem;
    color: var(--text2);
    text-align: center;
}

.ep-state-error[b-38ppoeewv3] { color: var(--red); }

/* ── Left column: live preview ── */
.ep-preview[b-38ppoeewv3] {
    width: 300px;
    min-width: 300px;
    position: sticky;
    top: 58px;
    height: calc(100vh - 58px);
    overflow-y: auto;
    background: var(--bg2);
    border-right: 1px solid var(--border);
    padding: 2rem 1.75rem 3rem;
    flex-shrink: 0;
}

.ep-preview-label[b-38ppoeewv3] {
    font-size: 0.62rem;
    font-weight: 500;
    letter-spacing: 0.1em;
    text-transform: uppercase;
    color: var(--text3);
    margin-bottom: 1.25rem;
}

/* Preview avatar */
.ep-preview-avatar-wrap[b-38ppoeewv3] {
    display: flex;
    justify-content: center;
    margin-bottom: 0.75rem;
}

.ep-preview-avatar[b-38ppoeewv3] {
    width: 96px;
    height: 96px;
    border-radius: 50%;
    box-shadow: 0 0 0 3px white, 0 0 0 4px var(--border2);
    display: grid;
    place-items: center;
}

.ep-preview-avatar-img[b-38ppoeewv3] {
    object-fit: cover;
}

.ep-preview-avatar-fallback[b-38ppoeewv3] {
    background: linear-gradient(135deg, #1d6fd4, #0d4a9e);
    color: #fff;
    font-size: 1.75rem;
    font-family: var(--serif);
}

.ep-preview-name[b-38ppoeewv3] {
    font-size: 1.2rem;
    font-family: var(--serif);
    text-align: center;
    color: var(--text);
    margin-bottom: 0.2rem;
}

.ep-preview-username[b-38ppoeewv3] {
    font-size: 0.75rem;
    color: var(--text3);
    text-align: center;
    margin-bottom: 0.75rem;
}

.ep-preview-bio[b-38ppoeewv3] {
    font-size: 0.8rem;
    line-height: 1.6;
    color: var(--text2);
    margin-bottom: 1.25rem;
}

.ep-preview-bio-empty[b-38ppoeewv3] {
    color: var(--text3);
    font-style: italic;
}

.ep-preview-section-label[b-38ppoeewv3] {
    font-size: 0.62rem;
    font-weight: 500;
    letter-spacing: 0.1em;
    text-transform: uppercase;
    color: var(--text3);
    margin-bottom: 0.5rem;
}

.ep-preview-genres[b-38ppoeewv3] {
    display: flex;
    flex-wrap: wrap;
    gap: 0.35rem;
    margin-bottom: 1rem;
}

.ep-preview-since[b-38ppoeewv3] {
    font-size: 0.72rem;
    color: var(--text3);
    margin-top: 0.75rem;
}

/* ── Right column: form ── */
.ep-form-col[b-38ppoeewv3] {
    flex: 1;
    min-width: 0;
    padding: 1.75rem 2rem 3rem;
    max-width: 800px;
}

/* Breadcrumb */
.ep-breadcrumb[b-38ppoeewv3] {
    display: flex;
    align-items: center;
    gap: 0.4rem;
    font-size: 0.78rem;
    color: var(--text3);
    margin-bottom: 1rem;
}

.ep-breadcrumb-link[b-38ppoeewv3] {
    color: var(--blue);
    text-decoration: none;
}

.ep-breadcrumb-link:hover[b-38ppoeewv3] { text-decoration: underline; }

.ep-breadcrumb-sep[b-38ppoeewv3] { color: var(--text3); }
.ep-breadcrumb-current[b-38ppoeewv3] { color: var(--text2); }

/* Page title */
.ep-title[b-38ppoeewv3] {
    font-family: var(--serif);
    font-size: 1.6rem;
    color: var(--text);
    margin: 0 0 0.25rem;
}

.ep-subtitle[b-38ppoeewv3] {
    font-size: 0.83rem;
    color: var(--text3);
    margin: 0 0 1.25rem;
}

/* Error banner */
.ep-error-banner[b-38ppoeewv3] {
    background: #fef2f2;
    border: 1px solid #fecaca;
    border-radius: 4px;
    color: var(--red);
    font-size: 0.83rem;
    padding: 0.6rem 1rem;
    margin-bottom: 1rem;
}

/* ── Cards ── */
.ep-card[b-38ppoeewv3] {
    background: var(--bg2);
    border: 1px solid var(--border);
    border-radius: 4px;
    margin-bottom: 1.25rem;
    overflow: hidden;
}

.ep-card-header[b-38ppoeewv3] {
    padding: 1rem 1.25rem 0.75rem;
    border-bottom: 1px solid var(--border);
    display: flex;
    align-items: center;
    justify-content: space-between;
}

.ep-card-title[b-38ppoeewv3] {
    font-size: 0.82rem;
    font-weight: 500;
    color: var(--text);
}

.ep-card-hint[b-38ppoeewv3] {
    font-size: 0.75rem;
    color: var(--text3);
}

.ep-card-body[b-38ppoeewv3] {
    padding: 1.25rem;
}

/* ── Profile photo section ── */
.ep-photo-row[b-38ppoeewv3] {
    display: flex;
    align-items: center;
    gap: 1.25rem;
}

.ep-photo-avatar[b-38ppoeewv3] {
    width: 80px;
    height: 80px;
    border-radius: 50%;
    box-shadow: 0 0 0 3px white, 0 0 0 4px var(--border2);
    flex-shrink: 0;
    display: grid;
    place-items: center;
}

.ep-photo-avatar-img[b-38ppoeewv3] { object-fit: cover; }

.ep-photo-avatar-fallback[b-38ppoeewv3] {
    background: linear-gradient(135deg, #1d6fd4, #0d4a9e);
    color: #fff;
    font-size: 1.2rem;
    font-family: var(--serif);
}

.ep-photo-actions[b-38ppoeewv3] {
    display: flex;
    flex-direction: column;
    gap: 0.5rem;
    align-items: flex-start;
}

.ep-upload-btn[b-38ppoeewv3] {
    font-size: 0.75rem;
    font-weight: 500;
    text-transform: uppercase;
    letter-spacing: 0.04em;
    padding: 0.48rem 1.1rem;
    border: 1px solid var(--border2);
    border-radius: 3px;
    background: transparent;
    color: var(--text2);
    cursor: pointer;
    display: inline-block;
}

.ep-upload-btn:hover[b-38ppoeewv3] {
    border-color: var(--blue);
    color: var(--blue);
    background: var(--blue-dim);
}

.ep-upload-btn-disabled[b-38ppoeewv3] {
    opacity: 0.6;
    cursor: not-allowed;
    pointer-events: none;
}

.ep-remove-photo-btn[b-38ppoeewv3] {
    font-size: 0.75rem;
    background: none;
    border: none;
    color: var(--red);
    cursor: pointer;
    padding: 0;
}

.ep-remove-photo-btn:hover[b-38ppoeewv3] { text-decoration: underline; }

.ep-photo-hint[b-38ppoeewv3] {
    font-size: 0.72rem;
    color: var(--text3);
}

/* ── Form fields ── */
.ep-field-grid[b-38ppoeewv3] {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 1rem;
    margin-bottom: 1rem;
}

.ep-field[b-38ppoeewv3] { display: flex; flex-direction: column; gap: 0.3rem; }
.ep-field-fullwidth[b-38ppoeewv3] { margin-top: 0.75rem; }

.ep-label[b-38ppoeewv3] {
    font-size: 0.78rem;
    font-weight: 500;
    color: var(--text2);
    display: flex;
    align-items: center;
    gap: 0.35rem;
}

.ep-readonly-badge[b-38ppoeewv3] {
    font-size: 0.65rem;
    font-weight: 500;
    letter-spacing: 0.05em;
    text-transform: uppercase;
    color: var(--text3);
    background: var(--bg3);
    border: 1px solid var(--border);
    border-radius: 2px;
    padding: 0.1rem 0.4rem;
}

.ep-optional-badge[b-38ppoeewv3] {
    font-size: 0.65rem;
    font-weight: 400;
    color: var(--text3);
    text-transform: lowercase;
    letter-spacing: 0;
}

.ep-input[b-38ppoeewv3] {
    width: 100%;
    font-size: 0.83rem;
    padding: 0.45rem 0.65rem;
    border: 1px solid var(--border);
    border-radius: 3px;
    background: var(--bg2);
    color: var(--text);
    outline: none;
    box-sizing: border-box;
}

.ep-input:focus[b-38ppoeewv3] { border-color: var(--blue); }

.ep-input-ro[b-38ppoeewv3] {
    background: var(--bg3);
    color: var(--text3);
    border-color: var(--border);
    cursor: not-allowed;
}

.ep-input-ro:focus[b-38ppoeewv3] { border-color: var(--border); }
.ep-input-invalid[b-38ppoeewv3] { border-color: var(--red); }

.ep-input-prefix-wrap[b-38ppoeewv3] {
    display: flex;
    align-items: stretch;
    border: 1px solid var(--border);
    border-radius: 3px;
    overflow: hidden;
}

.ep-input-readonly .ep-input-prefix-wrap[b-38ppoeewv3] {
    border-color: var(--border);
    background: var(--bg3);
}

.ep-input-prefix[b-38ppoeewv3] {
    padding: 0.45rem 0.55rem;
    background: var(--bg3);
    color: var(--text3);
    font-size: 0.83rem;
    border-right: 1px solid var(--border);
    display: flex;
    align-items: center;
}

.ep-input-inner-prefix[b-38ppoeewv3] {
    border: none;
    border-radius: 0;
    flex: 1;
}

.ep-input-inner-prefix:focus[b-38ppoeewv3] { border-color: transparent; box-shadow: none; }

.ep-textarea[b-38ppoeewv3] {
    width: 100%;
    font-size: 0.83rem;
    padding: 0.45rem 0.65rem;
    border: 1px solid var(--border);
    border-radius: 3px;
    background: var(--bg2);
    color: var(--text);
    outline: none;
    resize: vertical;
    min-height: 90px;
    font-family: inherit;
    box-sizing: border-box;
}

.ep-textarea:focus[b-38ppoeewv3] { border-color: var(--blue); }

.ep-field-footer[b-38ppoeewv3] {
    display: flex;
    justify-content: space-between;
    align-items: center;
    gap: 0.5rem;
    margin-top: 0.2rem;
}

.ep-field-hint[b-38ppoeewv3] { font-size: 0.72rem; color: var(--text3); }
.ep-field-error[b-38ppoeewv3] { font-size: 0.75rem; color: var(--red); margin-top: 0.2rem; }

.ep-char-counter[b-38ppoeewv3] { font-size: 0.72rem; color: var(--text3); flex-shrink: 0; }
.ep-counter-amber[b-38ppoeewv3] { color: var(--amber); }
.ep-counter-red[b-38ppoeewv3] { color: var(--red); }

/* ── Password section ── */
.ep-toggle-pwd-btn[b-38ppoeewv3] {
    font-size: 0.78rem;
    font-weight: 500;
    color: var(--blue);
    background: none;
    border: none;
    cursor: pointer;
    padding: 0;
}

.ep-toggle-pwd-btn:hover[b-38ppoeewv3] { text-decoration: underline; }

.ep-pwd-placeholder[b-38ppoeewv3] {
    font-size: 0.83rem;
    color: var(--text3);
    font-style: italic;
}

/* ── Genre picker ── */
.ep-genres-hint[b-38ppoeewv3] {
    font-size: 0.72rem;
    color: var(--text3);
    margin-bottom: 0.6rem;
}

.ep-genres-grid[b-38ppoeewv3] {
    display: flex;
    flex-wrap: wrap;
    gap: 0.45rem;
}

.ep-genre-pill[b-38ppoeewv3] {
    font-size: 0.78rem;
    padding: 0.3rem 0.75rem;
    border-radius: 999px;
    border: 1px solid;
    cursor: pointer;
    font-family: inherit;
    transition: border-color 0.15s, color 0.15s, background 0.15s;
}

.ep-genre-pill-unselected[b-38ppoeewv3] {
    background: var(--bg3);
    border-color: var(--border);
    color: var(--text2);
}

.ep-genre-pill-unselected:hover[b-38ppoeewv3] {
    border-color: var(--border2);
    color: var(--text);
}

.ep-genre-pill-selected[b-38ppoeewv3] {
    background: var(--blue-dim);
    border-color: var(--blue);
    color: var(--blue);
}

/* ── Danger zone ── */
.ep-danger-card[b-38ppoeewv3] {
    border: 1px solid #fecaca;
    border-radius: 4px;
    margin-bottom: 1.25rem;
    overflow: hidden;
}

.ep-danger-title[b-38ppoeewv3] {
    display: flex;
    align-items: center;
    gap: 0.45rem;
    font-size: 0.82rem;
    font-weight: 500;
    color: var(--red);
}

.ep-danger-body[b-38ppoeewv3] {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 1rem;
}

.ep-danger-desc[b-38ppoeewv3] {
    font-size: 0.82rem;
    color: var(--text2);
    margin: 0;
    flex: 1;
}

.ep-delete-btn[b-38ppoeewv3] {
    border: 1px solid #fecaca;
    background: transparent;
    color: var(--red);
    border-radius: 3px;
    padding: 0.45rem 1.1rem;
    font-size: 0.78rem;
    cursor: pointer;
    white-space: nowrap;
    flex-shrink: 0;
}

.ep-delete-btn:hover[b-38ppoeewv3] {
    background: #fef2f2;
    border-color: var(--red);
}

/* ── Delete confirmation modal ── */
.ep-modal-backdrop[b-38ppoeewv3] {
    position: fixed;
    inset: 0;
    background: rgba(0, 0, 0, 0.45);
    display: flex;
    align-items: center;
    justify-content: center;
    z-index: 1000;
}

.ep-modal[b-38ppoeewv3] {
    background: var(--bg2);
    border: 1px solid var(--border);
    border-radius: 6px;
    padding: 2rem;
    max-width: 440px;
    width: calc(100% - 2rem);
    box-shadow: 0 8px 32px rgba(0, 0, 0, 0.2);
}

.ep-modal-title[b-38ppoeewv3] {
    font-family: var(--serif);
    font-size: 1.2rem;
    font-weight: 400;
    color: var(--text);
    margin: 0 0 0.75rem;
}

.ep-modal-body[b-38ppoeewv3] {
    font-size: 0.85rem;
    line-height: 1.65;
    color: var(--text2);
    margin: 0 0 1.25rem;
}

.ep-modal-error[b-38ppoeewv3] {
    font-size: 0.8rem;
    color: var(--red, #dc2626);
    background: #fef2f2;
    border: 1px solid #fecaca;
    border-radius: 4px;
    padding: 0.5rem 0.75rem;
    margin-bottom: 1rem;
}

.ep-modal-actions[b-38ppoeewv3] {
    display: flex;
    gap: 0.65rem;
    justify-content: flex-end;
}

.ep-modal-btn[b-38ppoeewv3] {
    font-size: 0.78rem;
    font-weight: 500;
    padding: 0.45rem 1rem;
    border-radius: 3px;
    cursor: pointer;
    border: 1px solid transparent;
}

.ep-modal-btn:disabled[b-38ppoeewv3] {
    opacity: 0.6;
    cursor: not-allowed;
}

.ep-modal-btn-cancel[b-38ppoeewv3] {
    border-color: var(--border2);
    color: var(--text2);
    background: transparent;
}

.ep-modal-btn-cancel:hover:not(:disabled)[b-38ppoeewv3] {
    border-color: var(--blue);
    color: var(--blue);
}

.ep-modal-btn-delete[b-38ppoeewv3] {
    border-color: var(--red, #dc2626);
    background: var(--red, #dc2626);
    color: #fff;
}

.ep-modal-btn-delete:hover:not(:disabled)[b-38ppoeewv3] {
    background: #b91c1c;
    border-color: #b91c1c;
}

/* ── Footer ── */
.ep-footer[b-38ppoeewv3] {
    display: flex;
    align-items: center;
    justify-content: space-between;
    padding: 1.25rem 0 0;
    border-top: 1px solid var(--border);
    margin-top: 0.5rem;
}

.ep-footer-left[b-38ppoeewv3] { flex: 1; }

.ep-last-saved[b-38ppoeewv3] {
    font-size: 0.78rem;
    color: var(--text3);
}

.ep-footer-actions[b-38ppoeewv3] {
    display: flex;
    gap: 0.65rem;
    align-items: center;
}

.ep-btn[b-38ppoeewv3] {
    font-size: 0.78rem;
    font-weight: 500;
    padding: 0.52rem 1.25rem;
    border-radius: 3px;
    cursor: pointer;
    text-decoration: none;
    display: inline-block;
    text-align: center;
    font-family: inherit;
}

.ep-btn-cancel[b-38ppoeewv3] {
    border: 1px solid var(--border2);
    background: transparent;
    color: var(--text2);
}

.ep-btn-cancel:hover[b-38ppoeewv3] {
    border-color: var(--blue);
    color: var(--blue);
    background: var(--blue-dim);
}

.ep-btn-save[b-38ppoeewv3] {
    background: var(--blue);
    color: white;
    border: 1px solid var(--blue);
    padding: 0.52rem 1.5rem;
}

.ep-btn-save:hover:not(:disabled)[b-38ppoeewv3] { background: var(--blue-dk); }

.ep-btn-save:disabled[b-38ppoeewv3] {
    background: var(--border2);
    border-color: var(--border2);
    cursor: not-allowed;
    color: var(--text3);
}

/* ── Toast ── */
.ep-toast[b-38ppoeewv3] {
    position: fixed;
    bottom: 2rem;
    right: 2rem;
    z-index: 500;
    background: var(--text);
    color: white;
    font-size: 0.82rem;
    font-weight: 500;
    padding: 0.75rem 1.25rem;
    border-radius: 4px;
    box-shadow: 0 4px 16px rgba(0,0,0,0.2);
    display: flex;
    align-items: center;
    gap: 0.55rem;
    opacity: 0;
    transform: translateY(12px);
    transition: opacity 0.25s ease, transform 0.25s ease;
    pointer-events: none;
}

.ep-toast-visible[b-38ppoeewv3] {
    opacity: 1;
    transform: translateY(0);
}

.ep-toast-icon[b-38ppoeewv3] { color: #4ade80; }

/* ── Responsive ── */
@media (max-width: 900px) {
    .ep-page[b-38ppoeewv3] { display: block; }
    .ep-preview[b-38ppoeewv3] { position: static; width: auto; height: auto; min-width: unset; }
    .ep-form-col[b-38ppoeewv3] { padding: 1.25rem 1rem 2rem; }
    .ep-field-grid[b-38ppoeewv3] { grid-template-columns: 1fr; }
    .ep-danger-body[b-38ppoeewv3] { flex-direction: column; align-items: flex-start; }
}
/* _content/ReadersClub.Blazor/Components/Pages/Me/ReadingListPage.razor.rz.scp.css */
.rl-page[b-8psmwk7lbd] {
    position: relative;
    z-index: 1;
    max-width: 900px;
    margin: 0 auto;
    padding: 2rem 2.5rem 4rem;
}

/* Header */
.rl-header[b-8psmwk7lbd] {
    display: flex;
    align-items: baseline;
    justify-content: space-between;
    margin-bottom: 1.75rem;
}

.rl-title[b-8psmwk7lbd] {
    font-family: var(--serif);
    font-size: 1.75rem;
    font-weight: 400;
    color: var(--text);
    margin: 0;
}

.rl-browse-link[b-8psmwk7lbd] {
    font-size: 0.78rem;
    font-weight: 500;
    letter-spacing: 0.05em;
    text-transform: uppercase;
    color: var(--blue);
    text-decoration: none;
}

.rl-browse-link:hover[b-8psmwk7lbd] {
    text-decoration: underline;
}

/* Tabs */
.rl-tabs[b-8psmwk7lbd] {
    display: flex;
    border-bottom: 1px solid var(--border);
    margin-bottom: 1.5rem;
}

.rl-tab[b-8psmwk7lbd] {
    font-family: var(--sans);
    font-size: 0.78rem;
    font-weight: 500;
    letter-spacing: 0.04em;
    text-transform: uppercase;
    padding: 0.7rem 1.1rem;
    cursor: pointer;
    color: var(--text3);
    border: none;
    border-bottom: 2px solid transparent;
    margin-bottom: -1px;
    background: none;
    transition: color 0.15s;
    white-space: nowrap;
}

.rl-tab:hover[b-8psmwk7lbd] {
    color: var(--text2);
}

.rl-tab.active[b-8psmwk7lbd] {
    color: var(--blue);
    border-bottom-color: var(--blue);
}

/* States */
.rl-state[b-8psmwk7lbd] {
    font-size: 0.85rem;
    color: var(--text3);
    font-style: italic;
    padding: 2rem 0;
}

.rl-error[b-8psmwk7lbd] {
    font-size: 0.85rem;
    color: var(--red);
    background: #fef2f2;
    border: 1px solid #fecaca;
    border-radius: 4px;
    padding: 0.75rem 1rem;
    margin-bottom: 1rem;
}

.rl-inline-error[b-8psmwk7lbd] {
    font-size: 0.75rem;
    color: var(--red);
    padding: 0.3rem 1.1rem 0.5rem 52px;
    background: var(--bg2);
    border: 1px solid var(--border);
    border-top: none;
    margin-top: -1px;
}

/* Empty state */
.rl-empty[b-8psmwk7lbd] {
    text-align: center;
    padding: 3rem 1rem;
    background: var(--bg2);
    border: 1px solid var(--border);
    border-radius: 6px;
}

.rl-empty-title[b-8psmwk7lbd] {
    font-family: var(--serif);
    font-size: 1.1rem;
    color: var(--text);
    margin: 0 0 0.4rem;
}

.rl-empty-sub[b-8psmwk7lbd] {
    font-size: 0.85rem;
    color: var(--text3);
    margin-bottom: 1.25rem;
}

.rl-empty-cta[b-8psmwk7lbd] {
    display: inline-flex;
    align-items: center;
    font-size: 0.78rem;
    font-weight: 500;
    letter-spacing: 0.05em;
    text-transform: uppercase;
    padding: 0.45rem 1.1rem;
    background: var(--blue);
    color: white;
    border-radius: 3px;
    text-decoration: none;
    transition: background 0.15s;
}

.rl-empty-cta:hover[b-8psmwk7lbd] {
    background: var(--blue-dk);
}

/* Book list */
.rl-list[b-8psmwk7lbd] {
    display: flex;
    flex-direction: column;
}

.rl-row[b-8psmwk7lbd] {
    display: flex;
    align-items: center;
    gap: 1rem;
    padding: 0.85rem 1.1rem;
    background: var(--bg2);
    border: 1px solid var(--border);
    border-bottom: none;
    transition: background 0.12s;
}

.rl-row:first-child[b-8psmwk7lbd] {
    border-radius: 6px 6px 0 0;
}

.rl-row:last-child[b-8psmwk7lbd] {
    border-bottom: 1px solid var(--border);
    border-radius: 0 0 6px 6px;
}

.rl-row:only-child[b-8psmwk7lbd] {
    border-radius: 6px;
    border-bottom: 1px solid var(--border);
}

.rl-row:hover[b-8psmwk7lbd] {
    background: var(--bg3);
}

/* Cover */
.rl-cover[b-8psmwk7lbd] {
    width: 40px;
    min-width: 40px;
    height: 56px;
    border-radius: 2px;
    object-fit: cover;
    box-shadow: 1px 2px 6px rgba(0, 0, 0, 0.15);
    flex-shrink: 0;
    display: block;
}

.rl-cover-placeholder[b-8psmwk7lbd] {
    width: 40px;
    min-width: 40px;
    height: 56px;
    border-radius: 2px;
    flex-shrink: 0;
    background: linear-gradient(160deg, #1a1a2e, #2e2e4e);
    display: flex;
    align-items: center;
    justify-content: center;
    box-shadow: 1px 2px 6px rgba(0, 0, 0, 0.12);
}

/* Book info */
.rl-info[b-8psmwk7lbd] {
    flex: 1;
    min-width: 0;
}

.rl-book-title[b-8psmwk7lbd] {
    font-family: var(--serif);
    font-size: 0.95rem;
    font-weight: 400;
    color: var(--text);
    text-decoration: none;
    line-height: 1.3;
    display: block;
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
}

.rl-book-title:hover[b-8psmwk7lbd] {
    color: var(--blue);
}

.rl-author[b-8psmwk7lbd] {
    font-size: 0.75rem;
    color: var(--text3);
    margin-top: 0.05rem;
}

.rl-date[b-8psmwk7lbd] {
    font-size: 0.68rem;
    color: var(--text3);
    margin-top: 0.2rem;
}

/* Controls */
.rl-controls[b-8psmwk7lbd] {
    display: flex;
    align-items: center;
    gap: 0.5rem;
    flex-shrink: 0;
}

.rl-status-select[b-8psmwk7lbd] {
    font-family: var(--sans);
    font-size: 0.75rem;
    color: var(--text2);
    background: var(--bg3);
    border: 1px solid var(--border);
    border-radius: 3px;
    padding: 0.3rem 1.8rem 0.3rem 0.6rem;
    outline: none;
    cursor: pointer;
    appearance: none;
    background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='11' height='11' viewBox='0 0 12 12'%3E%3Cpath d='M2 4l4 4 4-4' stroke='%239ca3af' stroke-width='1.5' fill='none' stroke-linecap='round'/%3E%3C/svg%3E");
    background-repeat: no-repeat;
    background-position: right 0.45rem center;
    transition: border-color 0.12s;
    white-space: nowrap;
}

.rl-status-select:focus[b-8psmwk7lbd] {
    border-color: var(--border2);
}

.rl-status-select.reading[b-8psmwk7lbd] {
    border-color: #bfdbfe;
    background-color: #eff6ff;
    color: var(--blue);
}

.rl-status-select.finished[b-8psmwk7lbd] {
    border-color: #bbf7d0;
    background-color: #f0fdf4;
    color: var(--green);
}

.rl-remove-btn[b-8psmwk7lbd] {
    font-family: var(--sans);
    font-size: 0.72rem;
    font-weight: 500;
    padding: 0.28rem 0.65rem;
    border: 1px solid #fecaca;
    border-radius: 3px;
    background: transparent;
    color: var(--red);
    cursor: pointer;
    transition: all 0.12s;
    white-space: nowrap;
}

.rl-remove-btn:hover[b-8psmwk7lbd] {
    background: #fef2f2;
    border-color: var(--red);
}

.rl-remove-btn:disabled[b-8psmwk7lbd] {
    opacity: 0.6;
    cursor: default;
}

/* Pagination */
.rl-pagination[b-8psmwk7lbd] {
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 0.25rem;
    margin-top: 1.5rem;
    flex-wrap: wrap;
}

.rl-page-btn[b-8psmwk7lbd] {
    font-family: var(--sans);
    font-size: 0.78rem;
    font-weight: 500;
    padding: 0.38rem 0.75rem;
    border: 1px solid var(--border);
    border-radius: 3px;
    background: var(--bg2);
    color: var(--text2);
    cursor: pointer;
    transition: all 0.12s;
    min-width: 36px;
    text-align: center;
}

.rl-page-btn:hover:not(:disabled):not(.active)[b-8psmwk7lbd] {
    background: var(--bg3);
    border-color: var(--border2);
}

.rl-page-btn.active[b-8psmwk7lbd] {
    background: var(--blue);
    color: white;
    border-color: var(--blue);
}

.rl-page-btn:disabled[b-8psmwk7lbd] {
    color: var(--text3);
    cursor: default;
}

.rl-page-btn.ellipsis[b-8psmwk7lbd] {
    cursor: default;
    border-color: transparent;
    background: transparent;
    color: var(--text3);
}

/* Share section */
.rl-share[b-8psmwk7lbd] {
    margin-top: 2rem;
    background: var(--bg2);
    border: 1px solid var(--border);
    border-radius: 6px;
    overflow: hidden;
}

.rl-share-header[b-8psmwk7lbd] {
    display: flex;
    align-items: center;
    gap: 0.5rem;
    padding: 0.8rem 1.1rem 0.7rem;
    border-bottom: 1px solid var(--border);
}

.rl-share-label[b-8psmwk7lbd] {
    font-size: 0.65rem;
    font-weight: 500;
    letter-spacing: 0.1em;
    text-transform: uppercase;
    color: var(--text3);
}

.rl-share-body[b-8psmwk7lbd] {
    padding: 1rem 1.1rem;
}

.rl-share-sub[b-8psmwk7lbd] {
    font-size: 0.78rem;
    color: var(--text3);
    margin-bottom: 0.75rem;
}

.rl-share-row[b-8psmwk7lbd] {
    display: flex;
    align-items: center;
    gap: 0.5rem;
    margin-bottom: 0.75rem;
}

.rl-share-input[b-8psmwk7lbd] {
    flex: 1;
    font-family: var(--sans);
    font-size: 0.8rem;
    color: var(--text2);
    background: var(--bg3);
    border: 1px solid var(--border);
    border-radius: 3px;
    padding: 0.38rem 0.75rem;
    outline: none;
    min-width: 0;
}

.rl-copy-btn[b-8psmwk7lbd] {
    font-family: var(--sans);
    font-size: 0.75rem;
    font-weight: 500;
    padding: 0.38rem 0.85rem;
    background: var(--blue);
    color: white;
    border: none;
    border-radius: 3px;
    cursor: pointer;
    white-space: nowrap;
    transition: background 0.12s;
}

.rl-copy-btn:hover[b-8psmwk7lbd] {
    background: var(--blue-dk);
}

.rl-copy-btn.copied[b-8psmwk7lbd] {
    background: var(--green);
}

.rl-regen-btn[b-8psmwk7lbd] {
    font-family: var(--sans);
    font-size: 0.72rem;
    font-weight: 500;
    padding: 0.28rem 0.75rem;
    background: transparent;
    border: 1px solid var(--border2);
    color: var(--text2);
    border-radius: 3px;
    cursor: pointer;
    transition: all 0.12s;
}

.rl-regen-btn:hover[b-8psmwk7lbd] {
    border-color: var(--amber);
    color: var(--amber);
}

/* Modals */
.rl-modal-overlay[b-8psmwk7lbd] {
    position: fixed;
    inset: 0;
    z-index: 500;
    background: rgba(0, 0, 0, 0.35);
    backdrop-filter: blur(2px);
    display: flex;
    align-items: center;
    justify-content: center;
    padding: 1rem;
}

.rl-modal[b-8psmwk7lbd] {
    background: var(--bg2);
    border: 1px solid var(--border);
    border-radius: 8px;
    width: 100%;
    max-width: 400px;
    box-shadow: 0 20px 60px rgba(0, 0, 0, 0.15);
}

.rl-modal-header[b-8psmwk7lbd] {
    padding: 1rem 1.25rem 0.85rem;
    border-bottom: 1px solid var(--border);
    display: flex;
    align-items: center;
    justify-content: space-between;
}

.rl-modal-title[b-8psmwk7lbd] {
    font-family: var(--serif);
    font-size: 1.05rem;
    font-weight: 400;
    color: var(--text);
}

.rl-modal-close[b-8psmwk7lbd] {
    background: none;
    border: none;
    cursor: pointer;
    color: var(--text3);
    font-size: 1rem;
    padding: 0.1rem;
    line-height: 1;
}

.rl-modal-close:hover[b-8psmwk7lbd] {
    color: var(--text);
}

.rl-modal-body[b-8psmwk7lbd] {
    padding: 1rem 1.25rem;
    font-size: 0.85rem;
    color: var(--text2);
    line-height: 1.6;
}

.rl-modal-body strong[b-8psmwk7lbd] {
    color: var(--text);
    font-weight: 500;
}

.rl-modal-error[b-8psmwk7lbd] {
    margin-top: 0.75rem;
    font-size: 0.82rem;
    color: var(--red);
    background: #fef2f2;
    border: 1px solid #fecaca;
    border-radius: 4px;
    padding: 0.5rem 0.75rem;
}

.rl-modal-footer[b-8psmwk7lbd] {
    padding: 0.85rem 1.25rem;
    border-top: 1px solid var(--border);
    display: flex;
    justify-content: flex-end;
    gap: 0.5rem;
}

.rl-modal-cancel[b-8psmwk7lbd] {
    font-family: var(--sans);
    font-size: 0.78rem;
    font-weight: 500;
    padding: 0.4rem 1rem;
    border: 1px solid var(--border2);
    border-radius: 3px;
    background: transparent;
    color: var(--text2);
    cursor: pointer;
}

.rl-modal-cancel:hover[b-8psmwk7lbd] {
    border-color: var(--text3);
    color: var(--text);
}

.rl-modal-danger[b-8psmwk7lbd] {
    font-family: var(--sans);
    font-size: 0.78rem;
    font-weight: 500;
    padding: 0.4rem 1rem;
    border: none;
    border-radius: 3px;
    background: var(--red);
    color: white;
    cursor: pointer;
}

.rl-modal-danger:hover[b-8psmwk7lbd] {
    background: #b91c1c;
}

.rl-modal-danger:disabled[b-8psmwk7lbd] {
    opacity: 0.6;
    cursor: default;
}

.rl-modal-warning[b-8psmwk7lbd] {
    font-family: var(--sans);
    font-size: 0.78rem;
    font-weight: 500;
    padding: 0.4rem 1rem;
    border: none;
    border-radius: 3px;
    background: var(--amber);
    color: white;
    cursor: pointer;
}

.rl-modal-warning:hover[b-8psmwk7lbd] {
    background: #b45309;
}

.rl-modal-warning:disabled[b-8psmwk7lbd] {
    opacity: 0.6;
    cursor: default;
}

@media (max-width: 700px) {
    .rl-page[b-8psmwk7lbd] {
        padding: 1.5rem 1rem 3rem;
    }

    .rl-controls[b-8psmwk7lbd] {
        flex-direction: column;
        align-items: flex-end;
        gap: 0.35rem;
    }

    .rl-row[b-8psmwk7lbd] {
        flex-wrap: wrap;
    }
}
/* _content/ReadersClub.Blazor/Components/Pages/MyProfile.razor.rz.scp.css */
.mp-page[b-c9ient6z9u] {
    display: flex;
    min-height: calc(100vh - 58px);
    background: var(--bg);
    max-width: 1100px;
    margin: 0 auto;
}

.mp-sidebar[b-c9ient6z9u] {
    width: 280px;
    flex-shrink: 0;
    align-self: flex-start;
    position: sticky;
    top: 58px;
    background: var(--bg2);
    border-right: 1px solid var(--border);
    padding: 1.25rem 1rem;
}

.mp-main[b-c9ient6z9u] { flex: 1; min-width: 0; }
.mp-content[b-c9ient6z9u] { padding: 1.75rem 2rem 3rem; }

.mp-tabs[b-c9ient6z9u] {
    position: sticky;
    top: 58px;
    display: flex;
    border-bottom: 1px solid var(--border);
    background: var(--bg2);
    padding: 0 2rem;
    z-index: 3;
}

.mp-tab[b-c9ient6z9u] {
    border: 0;
    border-bottom: 2px solid transparent;
    background: transparent;
    color: var(--text3);
    font-size: .78rem;
    font-weight: 500;
    letter-spacing: .05em;
    text-transform: uppercase;
    padding: .85rem 1rem;
    margin-bottom: -1px;
}

.mp-tab:hover[b-c9ient6z9u] { color: var(--text2); }
.mp-tab.active[b-c9ient6z9u] { color: var(--blue); border-bottom-color: var(--blue); }

.mp-section[b-c9ient6z9u] { padding-bottom: 1.5rem; margin-bottom: 1.5rem; border-bottom: 1px solid var(--border); }
.mp-section-last[b-c9ient6z9u] { margin-bottom: 0; border-bottom: 0; padding-bottom: 0; }

.mp-avatar-section[b-c9ient6z9u] { text-align: center; }
.mp-avatar-wrap[b-c9ient6z9u] { position: relative; width: 96px; margin: 0 auto .75rem; }
.mp-avatar[b-c9ient6z9u] {
    width: 96px; aspect-ratio: 1; border-radius: 50%; object-fit: cover;
    box-shadow: 0 0 0 3px #fff, 0 0 0 4px var(--border2);
}
.mp-avatar-fallback[b-c9ient6z9u] {
    display: grid; place-items: center;
    background: linear-gradient(135deg, #1d6fd4, #0d4a9e);
    color: #fff; font-size: 1.75rem; font-family: var(--serif);
}
.mp-avatar-edit[b-c9ient6z9u] {
    position: absolute; right: 2px; bottom: 2px; width: 26px; height: 26px; border-radius: 50%;
    border: 1px solid var(--border2); display: grid; place-items: center; text-decoration: none; color: var(--text2); background: var(--bg2);
}
.mp-avatar-edit:hover[b-c9ient6z9u] { border-color: var(--blue); color: var(--blue); }

.mp-name[b-c9ient6z9u] { font-size: 1.2rem; font-family: var(--serif); margin: 0; }
.mp-meta[b-c9ient6z9u] { font-size: .75rem; color: var(--text3); margin-top: .25rem; }
.mp-bio[b-c9ient6z9u] { font-size: .8rem; line-height: 1.6; color: var(--text2); margin: 0; }

.mp-stats[b-c9ient6z9u] { display: grid; grid-template-columns: repeat(3, 1fr); gap: .35rem; }
.mp-stat[b-c9ient6z9u] { border: 0; background: transparent; padding: .4rem; text-align: center; }
.mp-stat:hover[b-c9ient6z9u] { background: var(--bg3); border-radius: 4px; }
.mp-stat-value[b-c9ient6z9u] { display: block; font-size: 1.2rem; font-family: var(--serif); font-weight: 600; color: var(--text); }
.mp-stat-label[b-c9ient6z9u] { display: block; text-transform: uppercase; letter-spacing: .07em; font-size: .62rem; color: var(--text3); }

.mp-actions[b-c9ient6z9u] { display: grid; gap: .5rem; }
.mp-btn[b-c9ient6z9u] {
    display: block; width: 100%; text-align: center; text-decoration: none;
    font-size: .75rem; font-weight: 500; letter-spacing: .04em; text-transform: uppercase;
    padding: .5rem 1rem; border-radius: 3px;
}
.mp-btn-primary[b-c9ient6z9u] { border: 1px solid var(--blue); background: var(--blue); color: #fff; }
.mp-btn-primary:hover[b-c9ient6z9u] { background: var(--blue-dk); color: #fff; }
.mp-btn-outline[b-c9ient6z9u] { border: 1px solid var(--border2); color: var(--text2); background: transparent; }
.mp-btn-outline:hover[b-c9ient6z9u] { border-color: var(--blue); color: var(--blue); background: var(--blue-dim); }

.mp-subtitle[b-c9ient6z9u] { font-size: .62rem; text-transform: uppercase; letter-spacing: .1em; color: var(--text3); font-weight: 500; margin-bottom: .75rem; }
.mp-muted[b-c9ient6z9u] { color: var(--text3); font-size: .73rem; }
.mp-italic[b-c9ient6z9u] { font-style: italic; }
.mp-genre-list[b-c9ient6z9u] { display: flex; flex-wrap: wrap; gap: .55rem; }
.mp-genre-pill[b-c9ient6z9u] {
    display: inline-flex;
    align-items: center;
    border-radius: 999px;
    border: 1px solid var(--blue);
    color: var(--blue);
    background: var(--bg2);
    padding: .35rem .8rem;
    font-size: .78rem;
    line-height: 1.2;
}

.mp-compact-list[b-c9ient6z9u] { display: grid; gap: .55rem; }
.mp-compact-item[b-c9ient6z9u] { display: grid; grid-template-columns: 30px 1fr; gap: .55rem; text-decoration: none; }
.mp-compact-cover[b-c9ient6z9u] { width: 30px; aspect-ratio: 2/3; border-radius: 2px; object-fit: cover; }
.mp-compact-title[b-c9ient6z9u] { font-size: .78rem; color: var(--text); font-weight: 500; line-height: 1.2; }
.mp-compact-sub[b-c9ient6z9u] { font-size: .66rem; color: var(--text3); }
.mp-cover-ph[b-c9ient6z9u] { background: linear-gradient(145deg, #194f98, #0f2f5f); }

.mp-share-card[b-c9ient6z9u] { background: var(--bg3); border: 1px solid var(--border); border-radius: 4px; padding: .85rem; }
.mp-share-title[b-c9ient6z9u] { font-size: .8rem; font-weight: 500; color: var(--text); }
.mp-share-sub[b-c9ient6z9u] { font-size: .73rem; color: var(--text3); margin-bottom: .65rem; }
.mp-share-row[b-c9ient6z9u] { display: flex; gap: .45rem; }
.mp-share-url[b-c9ient6z9u] { flex: 1; font-size: .69rem; font-family: monospace; background: var(--bg2); border: 1px solid var(--border); border-radius: 14px; padding: .22rem .55rem; overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }
.mp-copy-btn[b-c9ient6z9u] { border: 1px solid var(--border2); border-radius: 3px; background: var(--bg2); color: var(--text2); padding: .2rem .55rem; font-size: .7rem; }

.mp-recs-summary-line[b-c9ient6z9u] { display: flex; justify-content: space-between; font-size: .75rem; color: var(--text2); margin-bottom: .25rem; }
.mp-opened[b-c9ient6z9u] { color: var(--green); }
.mp-view-all[b-c9ient6z9u] { font-size: .75rem; color: var(--blue); text-decoration: none; }

.mp-review-row[b-c9ient6z9u] { display: flex; gap: 1rem; padding: 1.25rem 0; border-bottom: 1px solid var(--border); }
.mp-review-cover[b-c9ient6z9u] { width: 44px; aspect-ratio: 2/3; border-radius: 2px; object-fit: cover; box-shadow: 2px 3px 8px rgba(0,0,0,.18); }
.mp-review-main[b-c9ient6z9u] { flex: 1; min-width: 0; }
.mp-review-top[b-c9ient6z9u] { display: flex; justify-content: space-between; gap: 1rem; }
.mp-review-book[b-c9ient6z9u] { font-size: .9rem; color: var(--text); font-weight: 500; }
.mp-review-author[b-c9ient6z9u] { font-size: .75rem; color: var(--text3); }
.mp-review-edit[b-c9ient6z9u] { font-size: .68rem; border: 1px solid var(--border); border-radius: 3px; padding: .2rem .6rem; color: var(--text3); text-decoration: none; align-self: start; }
.mp-review-meta[b-c9ient6z9u] { display: flex; gap: .55rem; color: var(--text3); font-size: .72rem; margin-top: .45rem; align-items: center; }
.mp-stars[b-c9ient6z9u] { color: var(--amber); }
.mp-spoiler-pill[b-c9ient6z9u] { font-size: .58rem; padding: .1rem .4rem; border-radius: 2px; background: #fef9c3; color: #854d0e; border: 1px solid #fde68a; }
.mp-review-body[b-c9ient6z9u] { font-size: .82rem; line-height: 1.65; color: var(--text2); margin-top: .45rem; }
.mp-review-actions[b-c9ient6z9u] { display: flex; gap: 1rem; margin-top: .55rem; font-size: .72rem; }
.mp-review-actions a[b-c9ient6z9u] { color: var(--text3); text-decoration: none; }
.mp-review-actions a:hover[b-c9ient6z9u] { color: var(--blue); }

/* ── Reading list tab ── */
.mp-rl-group[b-c9ient6z9u] { margin-bottom: 2rem; }

.mp-rl-group-header[b-c9ient6z9u] {
    display: flex;
    align-items: center;
    justify-content: space-between;
    margin-bottom: 0.85rem;
    padding-bottom: 0.6rem;
    border-bottom: 1px solid var(--border);
}

.mp-rl-group-label[b-c9ient6z9u] {
    font-size: 0.65rem;
    font-weight: 500;
    letter-spacing: 0.1em;
    text-transform: uppercase;
    color: var(--text3);
}

.mp-rl-group-count[b-c9ient6z9u] {
    font-size: 0.72rem;
    color: var(--text3);
}

.mp-rl-list[b-c9ient6z9u] { display: flex; flex-direction: column; }

.mp-rl-empty[b-c9ient6z9u] {
    font-size: 0.8rem;
    color: var(--text3);
    font-style: italic;
    padding: 0.5rem 0;
}

.mp-rl-row[b-c9ient6z9u] {
    display: flex;
    align-items: center;
    gap: 0.85rem;
    padding: 0.6rem 0;
    border-bottom: 1px solid var(--border);
    text-decoration: none;
    transition: background 0.1s;
}
.mp-rl-row:last-child[b-c9ient6z9u] { border-bottom: none; }
.mp-rl-row:hover .mp-rl-title[b-c9ient6z9u] { color: var(--blue); }

.mp-rl-cover[b-c9ient6z9u] {
    width: 36px;
    min-width: 36px;
    height: 50px;
    border-radius: 2px;
    object-fit: cover;
    box-shadow: 1px 2px 5px rgba(0,0,0,0.15);
    flex-shrink: 0;
    display: block;
}

.mp-rl-cover-ph[b-c9ient6z9u] {
    width: 36px;
    min-width: 36px;
    height: 50px;
    border-radius: 2px;
    flex-shrink: 0;
    background: linear-gradient(160deg, #1a1a2e, #2e2e4e);
    display: flex;
    align-items: center;
    justify-content: center;
}

.mp-rl-info[b-c9ient6z9u] { flex: 1; min-width: 0; }

.mp-rl-title[b-c9ient6z9u] {
    font-family: var(--serif);
    font-size: 0.88rem;
    font-weight: 400;
    color: var(--text);
    line-height: 1.3;
    display: block;
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
    transition: color 0.12s;
}

.mp-rl-author[b-c9ient6z9u] {
    font-size: 0.72rem;
    color: var(--text3);
    margin-top: 0.05rem;
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
}

/* Status badge — reuses existing GetStatusClass values */
.mp-rl-badge[b-c9ient6z9u] {
    flex-shrink: 0;
    font-size: 0.58rem;
    font-weight: 500;
    letter-spacing: 0.04em;
    text-transform: uppercase;
    padding: 0.12rem 0.45rem;
    border-radius: 2px;
}

/* Keep these class names — produced by existing GetStatusClass() */
.mp-status-reading[b-c9ient6z9u]  { background: var(--blue-dim); color: var(--blue);   border: 1px solid #bfdbfe; }
.mp-status-finished[b-c9ient6z9u] { background: #f0fdf4;          color: var(--green);  border: 1px solid #bbf7d0; }
.mp-status-want[b-c9ient6z9u]     { background: var(--bg3);        color: var(--text3);  border: 1px solid var(--border); }

.mp-table[b-c9ient6z9u] { width: 100%; border-collapse: collapse; }
.mp-table th[b-c9ient6z9u] { font-size: .62rem; text-transform: uppercase; letter-spacing: .08em; color: var(--text3); font-weight: 500; border-bottom: 1px solid var(--border); text-align: left; padding: 0 0 .65rem; }
.mp-table td[b-c9ient6z9u] { padding: .85rem 0; border-bottom: 1px solid var(--border); font-size: .83rem; vertical-align: middle; }
.mp-recipient-member[b-c9ient6z9u] { color: var(--blue); text-decoration: none; font-weight: 500; font-size: .83rem; }
.mp-recipient-member:hover[b-c9ient6z9u] { text-decoration: underline; }
.mp-recipient-email[b-c9ient6z9u] { color: var(--text2); font-size: .82rem; }
.mp-chip[b-c9ient6z9u] { font-size: .72rem; border: 1px solid var(--border); border-radius: 999px; padding: .12rem .5rem; color: var(--text3); background: var(--bg3); }
.mp-chip-opened[b-c9ient6z9u] { background: #f0fdf4; color: var(--green); border-color: #bbf7d0; }
.mp-chip-revoked[b-c9ient6z9u] { background: #fef2f2; color: var(--red); border-color: #fecaca; }
.mp-revoke[b-c9ient6z9u] { border: 1px solid var(--border2); background: transparent; color: var(--text2); border-radius: 3px; padding: .18rem .45rem; font-size: .7rem; }

.mp-member-grid[b-c9ient6z9u] { display: grid; grid-template-columns: repeat(auto-fill, minmax(220px, 1fr)); gap: .75rem; }
.mp-member-card[b-c9ient6z9u] { display: flex; gap: .75rem; align-items: center; background: var(--bg2); border: 1px solid var(--border); border-radius: 4px; padding: .9rem 1rem; cursor: pointer; }
.mp-member-card:hover[b-c9ient6z9u] { border-color: var(--blue); background: var(--blue-dim); }
.mp-member-avatar[b-c9ient6z9u] { width: 38px; aspect-ratio: 1; border-radius: 50%; display: grid; place-items: center; background: linear-gradient(145deg, #183f78, #0f2b56); color: #fff; font-size: .75rem; font-weight: 600; }
.mp-member-meta[b-c9ient6z9u] { min-width: 0; flex: 1; }
.mp-member-name[b-c9ient6z9u] { font-size: .85rem; font-weight: 500; color: var(--text); line-height: 1.2; }
.mp-member-sub[b-c9ient6z9u] { font-size: .72rem; color: var(--text3); }
.mp-follow-btn[b-c9ient6z9u] { font-size: .68rem; font-weight: 500; padding: .25rem .7rem; border: 1px solid var(--border2); border-radius: 3px; background: transparent; color: var(--text2); }
.mp-follow-btn:hover[b-c9ient6z9u] { border-color: var(--blue); color: var(--blue); }
.mp-following[b-c9ient6z9u] { border-color: var(--blue); color: var(--blue); background: var(--blue-dim); }

.mp-load-more[b-c9ient6z9u] { margin-top: 1rem; border: 1px solid var(--border2); background: var(--bg2); color: var(--text2); border-radius: 4px; padding: .35rem .8rem; }
.mp-empty[b-c9ient6z9u] { text-align: center; padding: 2rem 1rem; }
.mp-empty-title[b-c9ient6z9u] { font-family: var(--serif); font-size: 1.1rem; margin-bottom: .4rem; color: var(--text); }
.mp-empty-sub[b-c9ient6z9u] { font-size: .85rem; color: var(--text2); }
.mp-empty-btn[b-c9ient6z9u] { max-width: 230px; margin: 1rem auto 0; }
.mp-empty-link[b-c9ient6z9u] { color: var(--blue); text-decoration: none; display: inline-block; margin-top: .7rem; }

.mp-state[b-c9ient6z9u] { padding: 2rem; color: var(--text2); text-align: center; }
.mp-state-error[b-c9ient6z9u] { color: var(--red); }

/* ── FOLLOWING / FOLLOWERS GRID ── */
.member-grid[b-c9ient6z9u] {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 0.75rem;
}

.member-card[b-c9ient6z9u] {
    background: var(--bg2);
    border: 1px solid var(--border);
    border-radius: 12px;
    padding: 0.9rem 1rem;
    display: flex;
    gap: 0.75rem;
    align-items: center;
    cursor: pointer;
    transition: border-color 0.12s, background 0.12s;
    text-decoration: none;
}

.member-card:hover[b-c9ient6z9u] {
    border-color: var(--blue);
    background: var(--blue-dim);
}

.member-avatar[b-c9ient6z9u] {
    width: 42px;
    height: 42px;
    min-width: 42px;
    border-radius: 50%;
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 0.72rem;
    font-weight: 500;
    flex-shrink: 0;
    object-fit: cover;
}

.member-info[b-c9ient6z9u] {
    flex: 1;
    min-width: 0;
}

.member-name[b-c9ient6z9u] {
    font-size: 0.85rem;
    font-weight: 500;
    color: var(--text);
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
}

.member-sub[b-c9ient6z9u] {
    font-size: 0.72rem;
    color: var(--text3);
    margin-top: 0.05rem;
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
}

.member-follow-btn[b-c9ient6z9u] {
    font-size: 0.68rem;
    font-weight: 500;
    padding: 0.25rem 0.7rem;
    border: 1px solid var(--border2);
    border-radius: 3px;
    background: transparent;
    color: var(--text2);
    cursor: pointer;
    white-space: nowrap;
    transition: all 0.12s;
    flex-shrink: 0;
}

.member-follow-btn:hover[b-c9ient6z9u] {
    border-color: var(--blue);
    color: var(--blue);
}

.member-follow-btn.following[b-c9ient6z9u] {
    background: var(--blue-dim);
    border-color: var(--blue);
    color: var(--blue);
}

.member-follow-btn.unfollow:hover[b-c9ient6z9u] {
    border-color: var(--red);
    color: var(--red);
}

/* ── Delete account danger zone ── */
.mp-danger-section[b-c9ient6z9u] {
    border-color: var(--red, #dc2626);
    border-bottom: 0;
    padding-bottom: 0;
    margin-bottom: 0;
}

.mp-btn-danger[b-c9ient6z9u] {
    border: 1px solid var(--red, #dc2626);
    color: var(--red, #dc2626);
    background: transparent;
    cursor: pointer;
}

.mp-btn-danger:hover[b-c9ient6z9u] {
    background: #fef2f2;
    border-color: #b91c1c;
    color: #b91c1c;
}

/* ── Confirmation modal ── */
.mp-modal-backdrop[b-c9ient6z9u] {
    position: fixed;
    inset: 0;
    background: rgba(0, 0, 0, 0.45);
    display: flex;
    align-items: center;
    justify-content: center;
    z-index: 1000;
}

.mp-modal[b-c9ient6z9u] {
    background: var(--bg2);
    border: 1px solid var(--border);
    border-radius: 6px;
    padding: 2rem;
    max-width: 440px;
    width: calc(100% - 2rem);
    box-shadow: 0 8px 32px rgba(0, 0, 0, 0.2);
}

.mp-modal-title[b-c9ient6z9u] {
    font-family: var(--serif);
    font-size: 1.2rem;
    font-weight: 400;
    color: var(--text);
    margin: 0 0 0.75rem;
}

.mp-modal-body[b-c9ient6z9u] {
    font-size: 0.85rem;
    line-height: 1.65;
    color: var(--text2);
    margin: 0 0 1.25rem;
}

.mp-modal-error[b-c9ient6z9u] {
    font-size: 0.8rem;
    color: var(--red, #dc2626);
    background: #fef2f2;
    border: 1px solid #fecaca;
    border-radius: 4px;
    padding: 0.5rem 0.75rem;
    margin-bottom: 1rem;
}

.mp-modal-actions[b-c9ient6z9u] {
    display: flex;
    gap: 0.65rem;
    justify-content: flex-end;
}

.mp-modal-btn[b-c9ient6z9u] {
    font-size: 0.78rem;
    font-weight: 500;
    padding: 0.45rem 1rem;
    border-radius: 3px;
    cursor: pointer;
    border: 1px solid transparent;
}

.mp-modal-btn:disabled[b-c9ient6z9u] {
    opacity: 0.6;
    cursor: not-allowed;
}

.mp-modal-btn-cancel[b-c9ient6z9u] {
    border-color: var(--border2);
    color: var(--text2);
    background: transparent;
}

.mp-modal-btn-cancel:hover:not(:disabled)[b-c9ient6z9u] {
    border-color: var(--blue);
    color: var(--blue);
}

.mp-modal-btn-delete[b-c9ient6z9u] {
    border-color: var(--red, #dc2626);
    background: var(--red, #dc2626);
    color: #fff;
}

.mp-modal-btn-delete:hover:not(:disabled)[b-c9ient6z9u] {
    background: #b91c1c;
    border-color: #b91c1c;
}

@media (max-width: 768px) {
    .mp-page[b-c9ient6z9u] { display: block; }
    .mp-sidebar[b-c9ient6z9u] { position: static; width: auto; }
    .mp-tabs[b-c9ient6z9u] { top: 0; }
}

@media (max-width: 640px) {
    .member-grid[b-c9ient6z9u] { grid-template-columns: 1fr; }
}
/* _content/ReadersClub.Blazor/Components/Pages/Notifications.razor.rz.scp.css */
.notif-list[b-xcso2bz9lq] {
    display: flex;
    flex-direction: column;
    gap: 0.5rem;
}

.notif-item[b-xcso2bz9lq] {
    display: flex;
    justify-content: space-between;
    align-items: flex-start;
    padding: 0.75rem 1rem;
    border-radius: 0.5rem;
    background: var(--bs-body-bg, #fff);
    transition: background 0.15s;
}

.notif-item:hover[b-xcso2bz9lq] {
    background: var(--bs-tertiary-bg, #f8f9fa);
}

.notif-item--unread[b-xcso2bz9lq] {
    font-weight: 600;
    background: color-mix(in srgb, #1d6fd4 6%, var(--bs-body-bg, #fff));
}

.notif-item--unread:hover[b-xcso2bz9lq] {
    background: color-mix(in srgb, #1d6fd4 10%, var(--bs-body-bg, #fff));
}

.notif-avatar[b-xcso2bz9lq] {
    width: 40px;
    height: 40px;
    min-width: 40px;
    border-radius: 50%;
    overflow: hidden;
}

.notif-avatar-img[b-xcso2bz9lq] {
    width: 100%;
    height: 100%;
    object-fit: cover;
}

.notif-avatar-fallback[b-xcso2bz9lq] {
    width: 100%;
    height: 100%;
    display: flex;
    align-items: center;
    justify-content: center;
    background: linear-gradient(135deg, #1d6fd4, #0d4a9e);
    color: white;
    font-size: 0.75rem;
    font-weight: 600;
    border-radius: 50%;
    user-select: none;
}

.notif-unread-dot[b-xcso2bz9lq] {
    width: 10px;
    height: 10px;
    min-width: 10px;
    border-radius: 50%;
    background-color: #1d6fd4;
    flex-shrink: 0;
}

.notif-follow-btn[b-xcso2bz9lq] {
    display: inline-block;
    padding: 0.25rem 0.75rem;
    font-size: 0.8rem;
    font-weight: 600;
    border-radius: 1rem;
    border: 1.5px solid #1d6fd4;
    background: #1d6fd4;
    color: #fff;
    cursor: pointer;
    transition: background 0.15s, color 0.15s;
}

.notif-follow-btn:hover[b-xcso2bz9lq] {
    background: #1558ab;
    border-color: #1558ab;
}

.notif-follow-btn--following[b-xcso2bz9lq] {
    background: transparent;
    color: #1d6fd4;
}

.notif-follow-btn--following:hover[b-xcso2bz9lq] {
    background: #fee2e2;
    border-color: #dc2626;
    color: #dc2626;
}

.notif-book-cover[b-xcso2bz9lq] {
    width: 44px;
    height: 60px;
    min-width: 44px;
    border-radius: 3px;
    overflow: hidden;
    margin-top: 2px;
}

.notif-book-cover-img[b-xcso2bz9lq] {
    width: 100%;
    height: 100%;
    object-fit: cover;
}
/* _content/ReadersClub.Blazor/Components/Pages/PublicProfile.razor.rz.scp.css */
.pp-page[b-w5lwrzadzy] {
    position: relative;
    z-index: 1;
    max-width: 900px;
    margin: 0 auto;
    padding: 2rem 2.5rem 4rem;
}

/* States */
.pp-state[b-w5lwrzadzy] {
    font-size: 0.85rem;
    color: var(--text3);
    font-style: italic;
    padding: 2rem 0;
    text-align: center;
}
.pp-error[b-w5lwrzadzy] {
    font-size: 0.85rem;
    color: var(--red);
    background: #fef2f2;
    border: 1px solid #fecaca;
    border-radius: 4px;
    padding: 0.75rem 1rem;
}

/* Profile header card */
.pp-header[b-w5lwrzadzy] {
    display: flex;
    align-items: flex-start;
    gap: 1.25rem;
    padding: 1.5rem;
    background: var(--bg2);
    border: 1px solid var(--border);
    border-radius: 6px;
    margin-bottom: 1.75rem;
}

/* Avatar */
.pp-avatar[b-w5lwrzadzy] {
    width: 72px;
    height: 72px;
    min-width: 72px;
    border-radius: 50%;
    object-fit: cover;
    box-shadow: 0 0 0 3px white, 0 0 0 4px var(--border2);
    flex-shrink: 0;
}
.pp-avatar-fallback[b-w5lwrzadzy] {
    display: flex;
    align-items: center;
    justify-content: center;
    background: linear-gradient(135deg, #1d6fd4, #0d4a9e);
    font-family: var(--serif);
    font-size: 1.5rem;
    color: white;
    font-weight: 600;
}

/* Profile info */
.pp-info[b-w5lwrzadzy] { flex: 1; min-width: 0; }

.pp-name[b-w5lwrzadzy] {
    font-family: var(--serif);
    font-size: 1.4rem;
    font-weight: 400;
    color: var(--text);
    margin: 0 0 0.1rem;
}

.pp-username[b-w5lwrzadzy] { font-size: 0.78rem; color: var(--text3); margin-bottom: 0.4rem; }

.pp-bio[b-w5lwrzadzy] {
    font-size: 0.83rem;
    color: var(--text2);
    line-height: 1.6;
    margin-bottom: 0.65rem;
}

.pp-favorite-genres[b-w5lwrzadzy] {
    display: flex;
    flex-wrap: wrap;
    gap: 0.45rem;
    margin: 0 0 0.8rem;
}

.pp-favorite-genre-pill[b-w5lwrzadzy] {
    font-size: 0.68rem;
    font-weight: 600;
    letter-spacing: 0.04em;
    text-transform: uppercase;
    color: var(--blue);
    background: #eff6ff;
    border: 1px solid #bfdbfe;
    border-radius: 999px;
    padding: 0.2rem 0.55rem;
}

.pp-stats[b-w5lwrzadzy] { display: flex; gap: 1.5rem; }
.pp-stat[b-w5lwrzadzy] {
    font-size: 0.75rem;
    color: var(--text3);
    text-decoration: none;
}
.pp-stat strong[b-w5lwrzadzy] {
    font-size: 0.88rem;
    font-weight: 500;
    color: var(--text);
    margin-right: 0.2rem;
}
.pp-stat:hover[b-w5lwrzadzy] { color: var(--blue); }

/* Follow button */
.pp-actions[b-w5lwrzadzy] { flex-shrink: 0; margin-left: auto; }

.pp-follow-btn[b-w5lwrzadzy] {
    font-family: var(--sans);
    font-size: 0.78rem;
    font-weight: 500;
    padding: 0.42rem 1.1rem;
    border-radius: 3px;
    cursor: pointer;
    transition: all 0.12s;
    white-space: nowrap;
}
.pp-follow-btn-primary[b-w5lwrzadzy] {
    background: var(--blue);
    color: white;
    border: none;
}
.pp-follow-btn-primary:hover[b-w5lwrzadzy] { background: var(--blue-dk); }
.pp-follow-btn-outline[b-w5lwrzadzy] {
    background: transparent;
    color: var(--text2);
    border: 1px solid var(--border2);
}
.pp-follow-btn-outline:hover[b-w5lwrzadzy] { border-color: var(--text3); color: var(--text); }
.pp-follow-btn:disabled[b-w5lwrzadzy] { opacity: 0.6; cursor: default; }

/* Tabs */
.pp-tabs[b-w5lwrzadzy] {
    display: flex;
    border-bottom: 1px solid var(--border);
    margin-bottom: 1.5rem;
}
.pp-tab[b-w5lwrzadzy] {
    font-family: var(--sans);
    font-size: 0.78rem;
    font-weight: 500;
    letter-spacing: 0.04em;
    text-transform: uppercase;
    padding: 0.7rem 1.1rem;
    cursor: pointer;
    color: var(--text3);
    border: none;
    border-bottom: 2px solid transparent;
    margin-bottom: -1px;
    background: none;
    transition: color 0.15s;
}
.pp-tab.active[b-w5lwrzadzy] { color: var(--blue); border-bottom-color: var(--blue); }

/* Review list */
.pp-review-list[b-w5lwrzadzy] { display: flex; flex-direction: column; gap: 0.75rem; }

.pp-review-card[b-w5lwrzadzy] {
    background: var(--bg2);
    border: 1px solid var(--border);
    border-radius: 10px;
    overflow: hidden;
    transition: border-color 0.12s, box-shadow 0.12s;
}
.pp-review-card:hover[b-w5lwrzadzy] {
    border-color: var(--border2);
    box-shadow: 0 2px 12px rgba(0,0,0,0.06);
}

/* Card header */
.pp-card-header[b-w5lwrzadzy] {
    display: flex;
    align-items: center;
    gap: 0.75rem;
    padding: 0.9rem 1.1rem 0.7rem;
}
.pp-card-avatar[b-w5lwrzadzy] {
    width: 34px;
    height: 34px;
    min-width: 34px;
    border-radius: 50%;
    background: linear-gradient(135deg, #c8e6c9, #a5d6a7);
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 0.72rem;
    font-weight: 600;
    color: #2e7d32;
    flex-shrink: 0;
}
.pp-card-header-info[b-w5lwrzadzy] { flex: 1; min-width: 0; }
.pp-card-name[b-w5lwrzadzy] {
    font-size: 0.85rem;
    font-weight: 500;
    color: var(--blue);
    text-decoration: none;
    display: block;
    line-height: 1.2;
}
.pp-card-name:hover[b-w5lwrzadzy] { text-decoration: underline; }
.pp-card-sub[b-w5lwrzadzy] { font-size: 0.72rem; color: var(--text3); }
.pp-card-time[b-w5lwrzadzy] { font-size: 0.72rem; color: var(--text3); flex-shrink: 0; margin-left: auto; }

/* Card body */
.pp-card-body[b-w5lwrzadzy] {
    display: flex;
    gap: 1rem;
    align-items: flex-start;
    padding: 0 1.1rem 1rem;
}

/* Cover */
.pp-cover-link[b-w5lwrzadzy] { flex-shrink: 0; display: block; }
.pp-cover[b-w5lwrzadzy] {
    width: 76px;
    min-width: 76px;
    height: 108px;
    border-radius: 4px;
    object-fit: cover;
    box-shadow: 2px 3px 10px rgba(0,0,0,0.18), inset -2px 0 4px rgba(0,0,0,0.1);
    display: block;
}
.pp-cover-ph[b-w5lwrzadzy] {
    width: 76px;
    min-width: 76px;
    height: 108px;
    border-radius: 4px;
    background: linear-gradient(160deg, #1a1a2e, #2e2e4e);
    display: flex;
    align-items: center;
    justify-content: center;
    box-shadow: 2px 3px 10px rgba(0,0,0,0.18);
}

/* Content */
.pp-review-content[b-w5lwrzadzy] { flex: 1; min-width: 0; }
.pp-book-title[b-w5lwrzadzy] {
    font-family: var(--serif);
    font-size: 1rem;
    font-weight: 400;
    color: var(--text);
    text-decoration: none;
    line-height: 1.3;
    display: block;
    margin-bottom: 0.1rem;
}
.pp-book-title:hover[b-w5lwrzadzy] { color: var(--blue); }
.pp-book-author[b-w5lwrzadzy] { font-size: 0.75rem; color: var(--text3); margin-bottom: 0.45rem; }
.pp-stars-row[b-w5lwrzadzy] { display: flex; align-items: center; gap: 0.2rem; margin-bottom: 0.45rem; }
.pp-star-on[b-w5lwrzadzy]  { color: var(--amber); font-size: 0.8rem; }
.pp-star-off[b-w5lwrzadzy] { color: var(--border2); font-size: 0.8rem; }
.pp-excerpt[b-w5lwrzadzy] {
    font-size: 0.83rem;
    color: var(--text2);
    line-height: 1.6;
    margin-bottom: 0.6rem;
}
.pp-read-link[b-w5lwrzadzy] {
    font-size: 0.78rem;
    color: var(--blue);
    text-decoration: none;
    font-weight: 500;
}
.pp-read-link:hover[b-w5lwrzadzy] { text-decoration: underline; }

/* Spoiler badge */
.pp-spoiler[b-w5lwrzadzy] {
    display: inline-block;
    font-size: 0.58rem;
    font-weight: 600;
    letter-spacing: 0.04em;
    text-transform: uppercase;
    background: #fef9c3;
    color: #854d0e;
    border: 1px solid #fde68a;
    padding: 0.08rem 0.35rem;
    border-radius: 2px;
    margin-left: 0.35rem;
}

/* Action bar */
.pp-actions-bar[b-w5lwrzadzy] {
    display: flex;
    align-items: center;
    border-top: 1px solid var(--border);
    padding: 0.45rem 1.1rem;
}
.pp-actions-left[b-w5lwrzadzy] { display: flex; align-items: center; gap: 0.1rem; flex: 1; }
.pp-action[b-w5lwrzadzy] {
    display: flex;
    align-items: center;
    gap: 0.3rem;
    font-size: 0.75rem;
    color: var(--text3);
    background: none;
    border: none;
    cursor: pointer;
    padding: 0.3rem 0.6rem;
    border-radius: 4px;
    font-family: var(--sans);
    text-decoration: none;
    transition: background 0.12s, color 0.12s;
}
.pp-action:hover[b-w5lwrzadzy] { background: var(--bg3); color: var(--text2); }
.pp-action.liked[b-w5lwrzadzy] { color: var(--red); }
.pp-action.liked svg[b-w5lwrzadzy] { fill: currentColor; }
.pp-genre-tag[b-w5lwrzadzy] {
    font-size: 0.6rem;
    font-weight: 500;
    letter-spacing: 0.05em;
    text-transform: uppercase;
    background: var(--bg3);
    color: var(--text3);
    border: 1px solid var(--border);
    padding: 0.18rem 0.55rem;
    border-radius: 3px;
    white-space: nowrap;
    flex-shrink: 0;
    text-decoration: none;
}

.pp-genre-tag:hover[b-w5lwrzadzy] {
    color: var(--blue);
    border-color: #bfdbfe;
    background: #eff6ff;
}

.pp-book-grid[b-w5lwrzadzy] {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(170px, 1fr));
    gap: 1rem;
}

.pp-book-grid-reading[b-w5lwrzadzy] {
    margin-top: 0.8rem;
}

.pp-book-card[b-w5lwrzadzy] {
    display: flex;
    flex-direction: column;
    gap: 0.75rem;
    text-decoration: none;
    color: inherit;
    background: var(--bg2);
    border: 1px solid var(--border);
    border-radius: 10px;
    padding: 0.95rem;
    transition: border-color 0.12s, box-shadow 0.12s, transform 0.12s;
}

.pp-book-card:hover[b-w5lwrzadzy] {
    border-color: var(--border2);
    box-shadow: 0 2px 12px rgba(0,0,0,0.06);
    transform: translateY(-1px);
}

.pp-book-card-cover[b-w5lwrzadzy] {
    width: 100%;
    aspect-ratio: 0.72;
    object-fit: cover;
    border-radius: 6px;
    box-shadow: 2px 3px 10px rgba(0,0,0,0.18), inset -2px 0 4px rgba(0,0,0,0.1);
}

.pp-book-card-meta[b-w5lwrzadzy] {
    min-width: 0;
}

.pp-book-card-title[b-w5lwrzadzy] {
    font-family: var(--serif);
    font-size: 0.95rem;
    color: var(--text);
    line-height: 1.35;
}

.pp-book-card-author[b-w5lwrzadzy] {
    font-size: 0.76rem;
    color: var(--text3);
    margin-top: 0.2rem;
    line-height: 1.45;
}

.pp-reading-status[b-w5lwrzadzy] {
    display: inline-flex;
    margin-top: 0.55rem;
    font-size: 0.66rem;
    font-weight: 600;
    letter-spacing: 0.04em;
    text-transform: uppercase;
    color: var(--text3);
    background: var(--bg3);
    border: 1px solid var(--border);
    border-radius: 999px;
    padding: 0.18rem 0.5rem;
}

.pp-reading-group + .pp-reading-group[b-w5lwrzadzy] {
    margin-top: 1.6rem;
}

.pp-reading-group-header[b-w5lwrzadzy] {
    display: flex;
    justify-content: space-between;
    align-items: center;
    gap: 1rem;
    padding-bottom: 0.55rem;
    border-bottom: 1px solid var(--border);
}

.pp-reading-group-title[b-w5lwrzadzy] {
    margin: 0;
    font-size: 1rem;
    font-family: var(--serif);
    font-weight: 400;
    color: var(--text);
}

.pp-reading-group-count[b-w5lwrzadzy] {
    font-size: 0.72rem;
    color: var(--text3);
}

.pp-reading-group-empty[b-w5lwrzadzy] {
    margin: 0.9rem 0 0;
    font-size: 0.8rem;
    color: var(--text3);
    font-style: italic;
}

@media (max-width: 700px) {
    .pp-page[b-w5lwrzadzy]   { padding: 1.5rem 1rem 3rem; }
    .pp-header[b-w5lwrzadzy] { flex-wrap: wrap; }
    .pp-actions[b-w5lwrzadzy] { margin-left: 0; width: 100%; }
    .pp-reading-group-header[b-w5lwrzadzy] { align-items: flex-start; flex-direction: column; gap: 0.35rem; }
}
/* _content/ReadersClub.Blazor/Components/Pages/QuoteDetail.razor.rz.scp.css */
.qtd-page-shell[b-m58ge5kavz] {
    max-width: 640px;
    margin: 0 auto;
    display: grid;
    gap: 1.4rem;
}

.qtd-state[b-m58ge5kavz] {
    color: var(--text3);
    font-size: 0.9rem;
}

.qtd-error[b-m58ge5kavz] {
    color: #b91c1c;
    background: #fef2f2;
    border: 1px solid #fecaca;
    border-radius: 6px;
    padding: 0.75rem 0.9rem;
    font-size: 0.85rem;
}

.qtd-quote-box[b-m58ge5kavz] {
    position: relative;
    border: 1px solid var(--border);
    border-radius: 10px;
    background: var(--bg2);
    overflow: hidden;
}

.qtd-mark[b-m58ge5kavz] {
    position: absolute;
    top: 0.55rem;
    left: 0.85rem;
    font-family: var(--serif);
    font-size: 3.4rem;
    line-height: 1;
    color: #9eb4d4;
    pointer-events: none;
}

.qtd-body[b-m58ge5kavz] {
    margin: 0;
    padding: 2.1rem 1.05rem 1rem;
    font-family: var(--serif);
    font-style: italic;
    font-size: 20px;
    line-height: 1.55;
    color: var(--text);
    white-space: pre-wrap;
}

.qtd-meta[b-m58ge5kavz] {
    display: flex;
    align-items: center;
    gap: 0.7rem;
    padding: 0 1.05rem 1rem;
}

.qtd-author-photo[b-m58ge5kavz] {
    width: 34px;
    height: 34px;
    border-radius: 50%;
    object-fit: cover;
    border: 1px solid var(--border);
    background: var(--bg3);
    flex-shrink: 0;
}

.qtd-author-photo--fallback[b-m58ge5kavz] {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    font-size: 0.72rem;
    font-weight: 600;
    color: var(--text2);
}

.qtd-meta-text[b-m58ge5kavz] {
    display: grid;
    gap: 0.1rem;
}

.qtd-author-link[b-m58ge5kavz] {
    color: var(--text2);
    font-size: 0.86rem;
    text-decoration: none;
}

.qtd-author-link:hover[b-m58ge5kavz] {
    text-decoration: underline;
}

.qtd-book-link[b-m58ge5kavz] {
    color: var(--blue);
    font-size: 0.78rem;
    text-decoration: none;
}

.qtd-book-link:hover[b-m58ge5kavz] {
    text-decoration: underline;
}

.qtd-actions[b-m58ge5kavz] {
    display: flex;
    align-items: center;
    gap: 0.38rem;
    padding: 0.62rem 0.85rem;
    border-top: 1px solid var(--border);
    background: var(--blue-dim);
    flex-wrap: wrap;
}

.qtd-action[b-m58ge5kavz] {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: 0.34rem;
    border: 1px solid var(--border);
    background: var(--bg2);
    color: var(--text2);
    border-radius: 5px;
    padding: 0.35rem 0.62rem;
    font-size: 0.8rem;
    font-family: var(--sans);
    cursor: pointer;
}

.qtd-action:disabled[b-m58ge5kavz] {
    opacity: 0.7;
    cursor: default;
}

.qtd-action.is-active[b-m58ge5kavz],
.qtd-action--like.is-active[b-m58ge5kavz] {
    color: var(--blue);
    border-color: #bfdbfe;
    background: #eff6ff;
}

.qtd-action--like.is-active[b-m58ge5kavz] {
    color: #dc2626;
    border-color: #fecaca;
    background: #fef2f2;
}

.qtd-action--share[b-m58ge5kavz] {
    min-width: 36px;
    padding: 0.35rem 0.45rem;
}

.qtd-share-toast[b-m58ge5kavz] {
    margin: 0.4rem 0.85rem 0.7rem;
    color: #15803d;
    font-size: 0.8rem;
    font-family: var(--sans);
}

.qtd-author-section[b-m58ge5kavz] {
    display: grid;
    gap: 0.45rem;
}

.qtd-author-portrait[b-m58ge5kavz] {
    width: 80px;
    height: 80px;
    border-radius: 50%;
    object-fit: cover;
    object-position: top;
    border: 1px solid var(--border);
    background: var(--bg3);
}

.qtd-author-portrait--fallback[b-m58ge5kavz] {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    font-family: var(--sans);
    font-weight: 600;
    font-size: 1rem;
    color: var(--text2);
}

.qtd-author-title[b-m58ge5kavz] {
    margin: 0;
    font-size: 18px;
    line-height: 1.25;
    font-weight: 500;
    color: var(--text);
}

.qtd-author-subline[b-m58ge5kavz] {
    margin: 0;
    color: var(--text3);
    font-size: 0.82rem;
}

.qtd-author-bio[b-m58ge5kavz] {
    margin: 0;
    color: var(--text2);
    font-size: 0.9rem;
    line-height: 1.55;
}

.qtd-author-page-link[b-m58ge5kavz] {
    color: var(--blue);
    text-decoration: none;
    font-size: 0.86rem;
    width: fit-content;
}

.qtd-author-page-link:hover[b-m58ge5kavz] {
    text-decoration: underline;
}

.qtd-books-section[b-m58ge5kavz] {
    display: grid;
    gap: 0.6rem;
}

.qtd-books-label[b-m58ge5kavz] {
    margin: 0;
    font-family: var(--sans);
    font-size: 11px;
    text-transform: uppercase;
    letter-spacing: 0.06em;
    color: var(--text3);
}

.qtd-books-empty[b-m58ge5kavz] {
    margin: 0;
    color: var(--text3);
    font-size: 0.82rem;
}

.qtd-books-row[b-m58ge5kavz] {
    display: flex;
    gap: 0.8rem;
    overflow-x: auto;
    padding-bottom: 0.2rem;
}

.qtd-book-card[b-m58ge5kavz] {
    min-width: 100px;
    max-width: 100px;
    display: grid;
    gap: 0.25rem;
    text-decoration: none;
}

.qtd-book-cover[b-m58ge5kavz] {
    width: 100px;
    height: 140px;
    border-radius: 6px;
    object-fit: cover;
    border: 1px solid var(--border);
    background: var(--bg3);
}

.qtd-book-cover--fallback[b-m58ge5kavz] {
    position: relative;
    border: 1px solid rgba(255, 255, 255, 0.12);
    padding: 0.5rem 0.45rem;
    color: #f9fafb;
    overflow: hidden;
}

.qtd-book-cover-spine[b-m58ge5kavz] {
    position: absolute;
    left: 0;
    top: 0;
    bottom: 0;
    width: 7px;
    background: rgba(255, 255, 255, 0.09);
}

.qtd-book-cover-title[b-m58ge5kavz] {
    font-family: var(--serif);
    font-size: 0.71rem;
    line-height: 1.2;
    padding-left: 0.28rem;
    word-break: break-word;
}

.qtd-book-title[b-m58ge5kavz] {
    color: var(--text2);
    font-family: var(--sans);
    font-size: 12px;
    font-weight: 500;
    line-height: 1.25;
    display: -webkit-box;
    -webkit-line-clamp: 2;
    line-clamp: 2;
    -webkit-box-orient: vertical;
    overflow: hidden;
}

.qtd-book-year[b-m58ge5kavz] {
    color: var(--text3);
    font-family: var(--sans);
    font-size: 11px;
}
/* _content/ReadersClub.Blazor/Components/Pages/Quotes.razor.rz.scp.css */
.qt-header[b-081i0x9skx] {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 1rem;
    margin-bottom: 1.25rem;
}

.qt-title[b-081i0x9skx] {
    margin: 0;
    font-family: var(--serif);
    font-size: 1.7rem;
    color: var(--text);
}

.qt-filters[b-081i0x9skx] {
    display: flex;
    align-items: center;
    gap: 0.6rem;
    flex-wrap: wrap;
}

.qt-search[b-081i0x9skx],
.qt-author-filter[b-081i0x9skx] {
    border: 1px solid var(--border);
    background: var(--bg2);
    color: var(--text2);
    border-radius: 4px;
    padding: 0.42rem 0.65rem;
    font-size: 0.85rem;
    font-family: var(--sans);
}

.qt-search[b-081i0x9skx] {
    min-width: 260px;
}

.qt-grid[b-081i0x9skx] {
    display: grid;
    gap: 1rem;
}

.qt-card[b-081i0x9skx] {
    border: 1px solid var(--border);
    border-radius: 8px;
    background: var(--bg2);
    overflow: hidden;
}

.qt-card--active[b-081i0x9skx] {
    border: 2px solid var(--blue);
}

.qt-body[b-081i0x9skx] {
    width: 100%;
    text-align: left;
    border: none;
    background: transparent;
    cursor: pointer;
    padding: 1rem 1rem 0.85rem;
}

.qt-text[b-081i0x9skx] {
    margin: 0 0 0.9rem;
    font-family: var(--serif);
    font-size: 1.12rem;
    line-height: 1.6;
    font-style: italic;
    color: var(--text);
}

.qt-meta[b-081i0x9skx] {
    display: flex;
    align-items: center;
    gap: 0.65rem;
}

.qt-author-photo[b-081i0x9skx] {
    width: 32px;
    height: 32px;
    border-radius: 50%;
    object-fit: cover;
    border: 1px solid var(--border);
    background: var(--bg3);
    flex-shrink: 0;
}

.qt-author-photo--fallback[b-081i0x9skx] {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    font-size: 0.72rem;
    font-weight: 600;
    color: var(--text2);
}

.qt-author-name[b-081i0x9skx] {
    font-size: 0.84rem;
    color: var(--text2);
}

.qt-book-link[b-081i0x9skx] {
    font-size: 0.77rem;
    color: var(--blue);
    text-decoration: none;
}

.qt-book-link:hover[b-081i0x9skx] {
    text-decoration: underline;
}

.qt-actions[b-081i0x9skx] {
    display: flex;
    align-items: center;
    gap: 0.3rem;
    padding: 0.55rem 0.8rem;
    border-top: 1px solid var(--border);
    background: var(--blue-dim);
    flex-wrap: wrap;
}

.qt-action[b-081i0x9skx] {
    display: inline-flex;
    align-items: center;
    gap: 0.3rem;
    border: 1px solid var(--border);
    background: var(--bg2);
    color: var(--text2);
    border-radius: 4px;
    padding: 0.28rem 0.55rem;
    font-size: 0.76rem;
    font-family: var(--sans);
    cursor: pointer;
}

.qt-action:disabled[b-081i0x9skx] {
    opacity: 0.7;
    cursor: default;
}

.qt-action--like.is-active[b-081i0x9skx] {
    color: #dc2626;
    border-color: #fecaca;
    background: #fef2f2;
}

.qt-action--share[b-081i0x9skx] {
    min-width: 34px;
    justify-content: center;
    padding: 0.28rem 0.42rem;
}

.qt-share-toast[b-081i0x9skx] {
    margin: 0.45rem 0.8rem 0.7rem;
    color: #15803d;
    font-size: 0.78rem;
    font-family: var(--sans);
}

.qt-state[b-081i0x9skx] {
    color: var(--text3);
    font-size: 0.9rem;
}

.qt-error[b-081i0x9skx] {
    color: #b91c1c;
    background: #fef2f2;
    border: 1px solid #fecaca;
    border-radius: 6px;
    padding: 0.7rem 0.85rem;
    font-size: 0.85rem;
}

.bk-pagination[b-081i0x9skx] {
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 0.25rem;
    margin-top: 1.5rem;
    flex-wrap: wrap;
}

.bk-page-btn[b-081i0x9skx] {
    font-family: var(--sans);
    font-size: 0.78rem;
    font-weight: 500;
    padding: 0.38rem 0.75rem;
    border: 1px solid var(--border);
    border-radius: 3px;
    background: var(--bg2);
    color: var(--text2);
    cursor: pointer;
    min-width: 36px;
    text-align: center;
}

.bk-page-btn.bk-page-active[b-081i0x9skx] {
    background: var(--blue);
    color: white;
    border-color: var(--blue);
}

.bk-page-btn[aria-disabled="true"][b-081i0x9skx] {
    color: var(--text3);
    cursor: default;
}

.bk-page-btn.bk-ellipsis[b-081i0x9skx] {
    cursor: default;
    border-color: transparent;
    background: transparent;
    color: var(--text3);
}

@media (max-width: 768px) {
    .qt-header[b-081i0x9skx] {
        flex-direction: column;
        align-items: stretch;
    }

    .qt-search[b-081i0x9skx] {
        min-width: 100%;
    }
}
/* _content/ReadersClub.Blazor/Components/Pages/Reviews.razor.rz.scp.css */
.rv-new-btn[b-yym5fk9r8g] {
    display: inline-flex;
    align-items: center;
    gap: 0.4rem;
    font-family: var(--sans);
    font-size: 0.78rem;
    font-weight: 500;
    letter-spacing: 0.05em;
    text-transform: uppercase;
    padding: 0.45rem 1.1rem;
    background: var(--blue);
    color: white;
    border: none;
    border-radius: 3px;
    text-decoration: none;
    cursor: pointer;
    transition: background 0.15s;
    white-space: nowrap;
}
.rv-new-btn:hover[b-yym5fk9r8g] { background: var(--blue-dk); color: white; }

/* States */
.rv-meta[b-yym5fk9r8g] {
    font-size: 0.78rem;
    color: var(--text3);
    margin-bottom: 0.85rem;
}
.rv-meta strong[b-yym5fk9r8g] { color: var(--text2); font-weight: 500; }

.rv-state[b-yym5fk9r8g] {
    font-size: 0.85rem;
    color: var(--text3);
    font-style: italic;
    padding: 2rem 0;
}
.rv-error[b-yym5fk9r8g] {
    font-size: 0.85rem;
    color: var(--red);
    background: #fef2f2;
    border: 1px solid #fecaca;
    border-radius: 4px;
    padding: 0.75rem 1rem;
    margin-bottom: 1rem;
}

/* Review list */
.rv-list[b-yym5fk9r8g] { display: flex; flex-direction: column; }

.rv-card[b-yym5fk9r8g] {
    border-bottom: 1px solid var(--border);
    padding: 1.1rem 0;
    transition: background 0.12s;
}
.rv-card:first-child[b-yym5fk9r8g] { padding-top: 0; }
.rv-card:last-child[b-yym5fk9r8g] { border-bottom: none; }

.rv-card-inner[b-yym5fk9r8g] {
    display: flex;
    align-items: flex-start;
    gap: 1rem;
}

.rv-body[b-yym5fk9r8g] { flex: 1; min-width: 0; }

/* Author row with avatar */
.rv-author-row[b-yym5fk9r8g] {
    display: flex;
    align-items: center;
    gap: 0.5rem;
    margin-bottom: 0.4rem;
}

.rv-avatar-img[b-yym5fk9r8g] {
    width: 28px;
    height: 28px;
    border-radius: 50%;
    object-fit: cover;
    flex-shrink: 0;
}

.rv-avatar-initials[b-yym5fk9r8g] {
    width: 28px;
    height: 28px;
    border-radius: 50%;
    background: var(--blue-dim);
    color: var(--blue);
    font-size: 0.65rem;
    font-weight: 600;
    display: flex;
    align-items: center;
    justify-content: center;
    flex-shrink: 0;
    border: 1px solid var(--border);
}

.rv-author-name[b-yym5fk9r8g] {
    font-size: 0.8rem;
    color: var(--text2);
}

/* Title row */
.rv-title-row[b-yym5fk9r8g] {
    display: flex;
    align-items: flex-start;
    gap: 0.6rem;
    flex-wrap: wrap;
    margin-bottom: 0.25rem;
}

.rv-review-title[b-yym5fk9r8g] {
    font-family: var(--serif);
    font-size: 1rem;
    font-weight: 500;
    color: var(--text);
    text-decoration: none;
    line-height: 1.3;
}
.rv-review-title:hover[b-yym5fk9r8g] { text-decoration: underline; }

.rv-spoiler[b-yym5fk9r8g] {
    font-size: 0.58rem;
    font-weight: 500;
    letter-spacing: 0.04em;
    text-transform: uppercase;
    background: #fef9c3;
    color: #854d0e;
    border: 1px solid #fde68a;
    padding: 0.1rem 0.4rem;
    border-radius: 2px;
    white-space: nowrap;
    align-self: center;
}

/* Stars */
.rv-stars-row[b-yym5fk9r8g] {
    display: flex;
    align-items: center;
    gap: 0.3rem;
    margin-bottom: 0.4rem;
}
.rv-star-on[b-yym5fk9r8g]  { color: var(--amber); font-size: 0.78rem; }
.rv-star-off[b-yym5fk9r8g] { color: var(--border2); font-size: 0.78rem; }
.rv-rating-text[b-yym5fk9r8g] { font-size: 0.72rem; color: var(--text3); margin-left: 0.15rem; }

/* Book + author */
.rv-book-line[b-yym5fk9r8g] {
    font-size: 0.78rem;
    color: var(--text3);
    margin-bottom: 0.5rem;
}
.rv-book-link[b-yym5fk9r8g] {
    color: var(--blue);
    text-decoration: none;
    font-weight: 500;
}
.rv-book-link:hover[b-yym5fk9r8g] { text-decoration: underline; }
.rv-author-link[b-yym5fk9r8g] {
    color: var(--text2);
    text-decoration: none;
}
.rv-author-link:hover[b-yym5fk9r8g] { color: var(--blue); text-decoration: underline; }

/* Excerpt */
.rv-excerpt[b-yym5fk9r8g] {
    font-size: 0.83rem;
    color: var(--text2);
    line-height: 1.65;
    margin-bottom: 0.5rem;
    display: -webkit-box;
    -webkit-line-clamp: 3;
    -webkit-box-orient: vertical;
    overflow: hidden;
}

/* Footer */
.rv-footer[b-yym5fk9r8g] {
    display: flex;
    align-items: center;
    gap: 0.4rem;
    flex-wrap: wrap;
}
.rv-date[b-yym5fk9r8g]    { font-size: 0.72rem; color: var(--text3); }
.rv-updated[b-yym5fk9r8g] { font-size: 0.72rem; color: var(--text3); font-style: italic; }

/* Edit / Delete actions */
.rv-actions[b-yym5fk9r8g] {
    display: flex;
    align-items: center;
    gap: 0.5rem;
    flex-shrink: 0;
}

.rv-btn[b-yym5fk9r8g] {
    font-family: var(--sans);
    font-size: 0.72rem;
    font-weight: 500;
    padding: 0.22rem 0.7rem;
    border-radius: 3px;
    cursor: pointer;
    transition: all 0.12s;
    white-space: nowrap;
    text-decoration: none;
    display: inline-flex;
    align-items: center;
    background: transparent;
}
.rv-btn-edit[b-yym5fk9r8g] {
    border: 1px solid var(--border2);
    color: var(--text2);
}
.rv-btn-edit:hover[b-yym5fk9r8g] {
    border-color: var(--blue);
    color: var(--blue);
    background: var(--blue-dim);
}
.rv-btn-delete[b-yym5fk9r8g] {
    border: 1px solid #fecaca;
    color: var(--red);
}
.rv-btn-delete:hover[b-yym5fk9r8g] {
    background: #fef2f2;
    border-color: var(--red);
}
.rv-btn-delete:disabled[b-yym5fk9r8g] { opacity: 0.6; cursor: default; }

/* Pagination */
.rv-pagination[b-yym5fk9r8g] {
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 0.25rem;
    margin-top: 1.5rem;
    flex-wrap: wrap;
}

.rv-page-btn[b-yym5fk9r8g] {
    font-family: var(--sans);
    font-size: 0.78rem;
    font-weight: 500;
    padding: 0.38rem 0.75rem;
    border: 1px solid var(--border);
    border-radius: 3px;
    background: var(--bg2);
    color: var(--text2);
    cursor: pointer;
    transition: all 0.12s;
    min-width: 36px;
    text-align: center;
}
.rv-page-btn:hover:not(:disabled):not(.rv-page-active)[b-yym5fk9r8g] {
    background: var(--bg3);
    border-color: var(--border2);
}
.rv-page-btn.rv-page-active[b-yym5fk9r8g] {
    background: var(--blue);
    color: white;
    border-color: var(--blue);
}
.rv-page-btn:disabled[b-yym5fk9r8g] { color: var(--text3); cursor: default; }
.rv-page-btn.rv-ellipsis[b-yym5fk9r8g] {
    cursor: default;
    border-color: transparent;
    background: transparent;
    color: var(--text3);
}

.rv-showing[b-yym5fk9r8g] {
    text-align: center;
    font-size: 0.75rem;
    color: var(--text3);
    margin-top: 0.75rem;
}

/* Delete modal */
.rv-modal-overlay[b-yym5fk9r8g] {
    position: fixed;
    inset: 0;
    z-index: 500;
    background: rgba(0,0,0,0.35);
    backdrop-filter: blur(2px);
    display: flex;
    align-items: center;
    justify-content: center;
    padding: 1rem;
}

.rv-modal[b-yym5fk9r8g] {
    background: var(--bg2);
    border: 1px solid var(--border);
    border-radius: 8px;
    width: 100%;
    max-width: 420px;
    box-shadow: 0 20px 60px rgba(0,0,0,0.15);
}

.rv-modal-header[b-yym5fk9r8g] {
    padding: 1.1rem 1.25rem 0.9rem;
    border-bottom: 1px solid var(--border);
    display: flex;
    align-items: center;
    justify-content: space-between;
}

.rv-modal-title[b-yym5fk9r8g] {
    font-family: var(--serif);
    font-size: 1.05rem;
    font-weight: 400;
    color: var(--text);
    margin: 0;
}

.rv-modal-close[b-yym5fk9r8g] {
    background: none;
    border: none;
    cursor: pointer;
    color: var(--text3);
    font-size: 1rem;
    padding: 0.2rem;
    line-height: 1;
}
.rv-modal-close:hover[b-yym5fk9r8g] { color: var(--text); }

.rv-modal-body[b-yym5fk9r8g] {
    padding: 1.1rem 1.25rem;
    font-size: 0.85rem;
    color: var(--text2);
    line-height: 1.6;
}
.rv-modal-body strong[b-yym5fk9r8g] { color: var(--text); font-weight: 500; }

.rv-modal-error[b-yym5fk9r8g] {
    margin-top: 0.75rem;
    font-size: 0.82rem;
    color: var(--red);
    background: #fef2f2;
    border: 1px solid #fecaca;
    border-radius: 4px;
    padding: 0.5rem 0.75rem;
}

.rv-modal-footer[b-yym5fk9r8g] {
    padding: 0.9rem 1.25rem;
    border-top: 1px solid var(--border);
    display: flex;
    justify-content: flex-end;
    gap: 0.5rem;
}

.rv-modal-cancel[b-yym5fk9r8g] {
    font-family: var(--sans);
    font-size: 0.78rem;
    font-weight: 500;
    padding: 0.42rem 1rem;
    border: 1px solid var(--border2);
    border-radius: 3px;
    background: transparent;
    color: var(--text2);
    cursor: pointer;
    transition: all 0.12s;
}
.rv-modal-cancel:hover[b-yym5fk9r8g] { border-color: var(--text3); color: var(--text); }

.rv-modal-delete[b-yym5fk9r8g] {
    font-family: var(--sans);
    font-size: 0.78rem;
    font-weight: 500;
    padding: 0.42rem 1rem;
    border: none;
    border-radius: 3px;
    background: var(--red);
    color: white;
    cursor: pointer;
    transition: background 0.12s;
}
.rv-modal-delete:hover[b-yym5fk9r8g] { background: #b91c1c; }
.rv-modal-delete:disabled[b-yym5fk9r8g] { opacity: 0.6; cursor: default; }

@media (max-width: 700px) {
    .rc-page-shell[b-yym5fk9r8g] { padding: 1.5rem 1rem 3rem; }
    .rv-card-inner[b-yym5fk9r8g] { flex-direction: column; gap: 0.75rem; }
    .rv-actions[b-yym5fk9r8g] { flex-direction: row; }
}
/* _content/ReadersClub.Blazor/Components/Pages/UserSearch.razor.rz.scp.css */
.page-sub[b-r12l6inqm1] {
    margin-top: 0.25rem;
}

/* Filter bar */
.filter-bar[b-r12l6inqm1] {
    display: flex;
    gap: 0.75rem;
    align-items: center;
    margin-bottom: 1.75rem;
    background: var(--bg2);
    border: 1px solid var(--border);
    border-radius: 4px;
    padding: 0.75rem 1rem;
}

.search-wrap[b-r12l6inqm1] {
    display: flex;
    align-items: center;
    gap: 0.5rem;
    flex: 1;
    background: var(--bg3);
    border: 1px solid var(--border);
    border-radius: 3px;
    padding: 0.42rem 0.75rem;
}

.search-wrap input[b-r12l6inqm1] {
    border: none;
    background: transparent;
    font-family: var(--sans);
    font-size: 0.85rem;
    color: var(--text);
    outline: none;
    width: 100%;
}

.search-wrap input[b-r12l6inqm1]::placeholder {
    color: var(--text3);
}

.filter-divider[b-r12l6inqm1] {
    width: 1px;
    height: 24px;
    background: var(--border);
    flex-shrink: 0;
}

.filter-pill[b-r12l6inqm1] {
    font-size: 0.75rem;
    font-weight: 500;
    padding: 0.32rem 0.85rem;
    border: 1px solid var(--border);
    border-radius: 20px;
    background: transparent;
    color: var(--text2);
    cursor: pointer;
    transition: all 0.12s;
    white-space: nowrap;
    font-family: var(--sans);
}

.filter-pill:hover[b-r12l6inqm1] {
    border-color: var(--border2);
    color: var(--text);
}

.filter-pill.active[b-r12l6inqm1] {
    background: var(--blue-dim);
    border-color: var(--blue);
    color: var(--blue);
}

/* Tab row */
.tab-row[b-r12l6inqm1] {
    display: flex;
    border-bottom: 1px solid var(--border);
    margin-bottom: 1.75rem;
}

.tab[b-r12l6inqm1] {
    font-size: 0.78rem;
    font-weight: 500;
    letter-spacing: 0.04em;
    text-transform: uppercase;
    padding: 0.7rem 1.1rem;
    cursor: pointer;
    color: var(--text3);
    border: none;
    border-bottom: 2px solid transparent;
    margin-bottom: -1px;
    background: none;
    font-family: var(--sans);
    transition: color 0.15s;
}

.tab:hover[b-r12l6inqm1] {
    color: var(--text2);
}

.tab.active[b-r12l6inqm1] {
    color: var(--blue);
    border-bottom-color: var(--blue);
}

/* Member grid */
.member-grid[b-r12l6inqm1] {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(260px, 1fr));
    gap: 1rem;
}

.member-card[b-r12l6inqm1] {
    background: var(--bg2);
    border: 1px solid var(--border);
    border-radius: 6px;
    padding: 1.1rem 1.1rem 0.9rem;
    display: flex;
    flex-direction: column;
    transition: border-color 0.15s;
}

.member-card:hover[b-r12l6inqm1] {
    border-color: var(--border2);
}

.mc-top[b-r12l6inqm1] {
    display: flex;
    align-items: flex-start;
    gap: 0.75rem;
    margin-bottom: 0.75rem;
}

.mc-avatar[b-r12l6inqm1] {
    width: 44px;
    height: 44px;
    min-width: 44px;
    border-radius: 50%;
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 0.82rem;
    font-weight: 500;
    font-family: var(--sans);
    object-fit: cover;
}

.mc-info[b-r12l6inqm1] {
    flex: 1;
    min-width: 0;
}

.mc-name[b-r12l6inqm1] {
    font-size: 0.9rem;
    font-weight: 500;
    color: var(--text);
    line-height: 1.3;
    text-decoration: none;
    display: block;
}

.mc-name:hover[b-r12l6inqm1] {
    color: var(--blue);
}

.mc-username[b-r12l6inqm1] {
    font-size: 0.72rem;
    color: var(--text3);
}

.mc-bio[b-r12l6inqm1] {
    font-size: 0.78rem;
    color: var(--text2);
    line-height: 1.55;
    display: -webkit-box;
    -webkit-line-clamp: 2;
    -webkit-box-orient: vertical;
    overflow: hidden;
    margin-bottom: 0.75rem;
    min-height: 2.4em;
}

.mc-stats[b-r12l6inqm1] {
    display: flex;
    gap: 1.25rem;
    margin-bottom: 0.85rem;
    min-height: 2rem;
}

.mc-stat[b-r12l6inqm1] {
    font-size: 0.72rem;
    color: var(--text3);
}

.mc-stat strong[b-r12l6inqm1] {
    font-size: 0.82rem;
    font-weight: 500;
    color: var(--text);
    display: block;
    line-height: 1.2;
}

.mc-genres[b-r12l6inqm1] {
    display: flex;
    flex-wrap: wrap;
    gap: 0.3rem;
    margin-bottom: 0.85rem;
    min-height: 1.4rem;
}

.mc-genre[b-r12l6inqm1] {
    font-size: 0.62rem;
    font-weight: 500;
    letter-spacing: 0.04em;
    text-transform: uppercase;
    background: var(--bg3);
    color: var(--text3);
    border: 1px solid var(--border);
    padding: 0.1rem 0.4rem;
    border-radius: 2px;
}

.mc-footer[b-r12l6inqm1] {
    display: flex;
    justify-content: flex-end;
    margin-top: auto;
}

.mc-follow-btn[b-r12l6inqm1] {
    font-size: 0.72rem;
    font-weight: 500;
    padding: 0.28rem 0.85rem;
    border: 1px solid var(--border2);
    border-radius: 3px;
    background: transparent;
    color: var(--text2);
    cursor: pointer;
    transition: all 0.12s;
    font-family: var(--sans);
}

.mc-follow-btn:hover[b-r12l6inqm1] {
    border-color: var(--blue);
    color: var(--blue);
    background: var(--blue-dim);
}

.mc-follow-btn.following[b-r12l6inqm1] {
    background: var(--blue-dim);
    border-color: var(--blue);
    color: var(--blue);
}

/* Loading / empty states */
.rs-state[b-r12l6inqm1] {
    text-align: center;
    padding: 3rem 1rem;
    color: var(--text3);
    font-size: 0.85rem;
    font-style: italic;
}

.rs-load-more-wrap[b-r12l6inqm1] {
    display: flex;
    justify-content: center;
    margin-top: 1.5rem;
}

.rs-load-more[b-r12l6inqm1] {
    font-size: 0.78rem;
    font-weight: 500;
    padding: 0.6rem 1.2rem;
    border: 1px solid var(--blue);
    border-radius: 999px;
    background: var(--blue-dim);
    color: var(--blue);
    cursor: pointer;
    transition: all 0.12s;
    font-family: var(--sans);
}

.rs-load-more:hover:not(:disabled)[b-r12l6inqm1] {
    background: var(--blue);
    color: white;
}

.rs-load-more:disabled[b-r12l6inqm1] {
    opacity: 0.7;
    cursor: default;
}

@media (max-width: 700px) {
    .rc-page-shell[b-r12l6inqm1] {
        padding: 1.5rem 1rem 3rem;
    }

    .member-grid[b-r12l6inqm1] {
        grid-template-columns: 1fr;
    }

    .filter-bar[b-r12l6inqm1] {
        flex-wrap: wrap;
    }
}
/* _content/ReadersClub.Blazor/Components/Shared/BrandLogo.razor.rz.scp.css */
.brand-logo[b-wjfyi3rxm6] {
    display: inline-flex;
    align-items: center;
    gap: 8px;
    text-decoration: none;
}

.brand-logo-dots[b-wjfyi3rxm6] {
    display: inline-flex;
    gap: 5px;
    align-items: center;
}

.brand-logo-dot[b-wjfyi3rxm6] {
    width: 10px;
    height: 10px;
    border-radius: 50%;
    background: var(--blue);
}

.brand-logo-word[b-wjfyi3rxm6] {
    font-family: var(--serif);
    font-size: 1.35rem;
    font-style: italic;
    color: var(--text);
    letter-spacing: -0.01em;
}
/* _content/ReadersClub.Blazor/Components/Shared/NotificationBell.razor.rz.scp.css */
.nb-avatar[b-onmg55r3t5] {
    width: 32px;
    height: 32px;
    min-width: 32px;
    border-radius: 50%;
    overflow: hidden;
}

.nb-avatar-img[b-onmg55r3t5] {
    width: 100%;
    height: 100%;
    object-fit: cover;
}

.nb-avatar-fallback[b-onmg55r3t5] {
    width: 100%;
    height: 100%;
    display: flex;
    align-items: center;
    justify-content: center;
    background: linear-gradient(135deg, #1d6fd4, #0d4a9e);
    color: white;
    font-size: 0.65rem;
    font-weight: 600;
    border-radius: 50%;
    user-select: none;
}

.nb-unread-dot[b-onmg55r3t5] {
    width: 8px;
    height: 8px;
    min-width: 8px;
    border-radius: 50%;
    background-color: #1d6fd4;
}

.nb-follow-btn[b-onmg55r3t5] {
    display: inline-block;
    padding: 0.25rem 0.75rem;
    font-size: 0.8rem;
    font-weight: 600;
    line-height: 1.2;
    border-radius: 999px;
    border: 1px solid #1d6fd4;
    background: #1d6fd4;
    color: #fff;
}

.nb-follow-btn--following[b-onmg55r3t5] {
    background: #eef4ff;
    color: #1d6fd4;
}
/* _content/ReadersClub.Blazor/Components/Shared/ReactionBar.razor.rz.scp.css */
.reaction-bar[b-rug4hh1mdl] {
    display: flex;
    align-items: center;
    gap: 0.3rem;
    flex-wrap: wrap;
}

.reaction-chip[b-rug4hh1mdl] {
    display: inline-flex;
    align-items: center;
    gap: 0.35rem;
    padding: 0.28rem 0.65rem;
    border: 1px solid var(--border);
    border-radius: 4px;
    background: transparent;
    color: var(--text3);
    font-family: var(--sans);
    font-size: 0.72rem;
    font-weight: 500;
    line-height: 1;
    cursor: pointer;
    transition: all 0.12s;
}

.reaction-chip:not(:disabled):hover[b-rug4hh1mdl] {
    background: var(--bg3);
    border-color: var(--border2);
    color: var(--text2);
}

.reaction-chip:disabled[b-rug4hh1mdl] {
    opacity: 0.6;
    cursor: default;
}

.reaction-chip.selected[b-rug4hh1mdl] {
    background: var(--blue-dim);
    border-color: #bfdbfe;
    color: var(--blue);
}

.reaction-chip__icon[b-rug4hh1mdl] {
    display: inline-flex;
    align-items: center;
}

.reaction-chip__icon :deep(svg)[b-rug4hh1mdl] {
    stroke: currentColor;
}

.reaction-chip__count[b-rug4hh1mdl] {
    color: inherit;
}

.reaction-bar__hint[b-rug4hh1mdl],
.reaction-bar__error[b-rug4hh1mdl] {
    font-size: 0.85rem;
}
