/* =========================================================
   PRINT
========================================================= */
@media print {
    .header,
    .footer,
    i {
        display: none !important;
    }
}

/* =========================================================
   THEME VARIABLES
========================================================= */
:root {
    --site-theme: #260751;
    --site-theme-light: color-mix(in srgb, var(--site-theme) 48%, white);
    --site-theme-soft: color-mix(in srgb, var(--site-theme) 38%, white);
    --site-theme-deep: color-mix(in srgb, var(--site-theme) 85%, black);
    --site-theme-gradient: linear-gradient(
        135deg,
        var(--site-theme),
        var(--site-theme-light)
    );
    --site-theme-gradient-rich: linear-gradient(
        135deg,
        var(--site-theme-deep) 0%,
        var(--site-theme) 42%,
        var(--site-theme-light) 100%
    );
    --site-theme-gradient-banner: linear-gradient(
        135deg,
        color-mix(in srgb, var(--site-theme) 72%, black) 0%,
        var(--site-theme) 38%,
        var(--site-theme-light) 72%,
        color-mix(in srgb, var(--site-theme-light) 65%, white) 100%
    );
    --bg-color: #121212;
    --text-main: #ffffff;
    --text-sec: #aaaaaa;
    --card-bg: #1e1e1e;
    --border-color: #2a2a2a;
    --link-accent: var(--site-theme-soft);
}

body.theme-light {
    --bg-color: #f8f9fa;
    --text-main: #111111;
    --text-sec: #3c3c3c;
    --card-bg: #ffffff;
    --border-color: #dee2e6;
    --link-accent: var(--site-theme);
}

/* =========================================================
   CLIENT PRIMARY ACTIONS (theme from site settings)
========================================================= */
#appBody .btn-primary,
#pwa-install-btn {
    background: var(--site-theme-gradient);
    border: none;
    color: #fff;
}

#appBody .btn-primary:hover,
#appBody .btn-primary:focus,
#appBody .btn-primary:active,
#pwa-install-btn:hover,
#pwa-install-btn:focus,
#pwa-install-btn:active {
    background: var(--site-theme-gradient);
    border: none;
    color: #fff;
    filter: brightness(1.06);
    opacity: 1;
}

.subscription-promo-icon {
    background: var(--site-theme-gradient);
    box-shadow: 0 10px 24px color-mix(in srgb, var(--site-theme) 35%, transparent);
}

/* =========================================================
   GLOBAL
========================================================= */
body {
    background-color: var(--bg-color);
    color: var(--text-main);
    transition: background-color 0.3s ease, color 0.3s ease;
}

a {
    color: inherit;
    text-decoration: none;
}

.text-muted {
    color: color-mix(in srgb, var(--text-main) 60%, transparent) !important;
}

/* =========================================================
   HEADER
========================================================= */
.header {
    background-color: var(--bg-color);
    border-bottom: 1px solid var(--border-color);
    z-index: 1050;
}

.header a,
.header .nav-link,
.header h5,
.header i {
    color: var(--text-main) !important;
}

.header .nav-link:hover,
.header .dropdown-item:hover {
    background-color: rgba(255, 255, 255, 0.08);
}

body.theme-light .header .nav-link:hover {
    background-color: rgba(0, 0, 0, 0.05);
}

.header .nav-link.aktif {
    border-bottom: 2px solid var(--text-main);
}

.header-nav-scroll {
    display: flex;
    align-items: stretch;
    max-width: 100%;
    min-width: 0;
    position: relative;
}

.header-nav-scroll__track {
    flex: 1 1 auto;
    min-width: 0;
    overflow-x: auto;
    overflow-y: hidden;
    scroll-behavior: smooth;
    -webkit-overflow-scrolling: touch;
    scrollbar-width: none;
}

.header-nav-scroll__track::-webkit-scrollbar {
    display: none;
}

.header-nav-scroll__list {
    display: flex;
    flex-wrap: nowrap;
    align-items: stretch;
    width: max-content;
    max-width: none;
}

.header-nav-scroll__list > li {
    flex-shrink: 0;
}

.header-nav-scroll .nav-item.dropdown > .dropdown-menu {
    z-index: 1060;
}

.header-nav-scroll .nav-item.dropdown > .dropdown-toggle::after {
    margin-left: 0.35em;
}

.header-nav-scroll__btn {
    display: none;
    flex: 0 0 auto;
    align-items: center;
    justify-content: center;
    width: 1.75rem;
    padding: 0;
    border: 0;
    background: color-mix(in srgb, var(--card-bg) 92%, transparent);
    color: var(--text-sec);
    cursor: pointer;
    z-index: 2;
    transition: color 0.15s ease, opacity 0.15s ease;
}

.header-nav-scroll.is-scrollable .header-nav-scroll__btn {
    display: inline-flex;
}

.header-nav-scroll__btn:hover:not(:disabled) {
    color: var(--primary);
}

.header-nav-scroll__btn:disabled {
    opacity: 0.3;
    cursor: default;
}

/* =========================================================
   DROPDOWN
========================================================= */
.custom-dropdown {
    max-height: 60vh;
    overflow-y: auto;
}

.dropdown-menu {
    background-color: var(--card-bg);
    border: 1px solid var(--border-color);
    box-shadow: 0 10px 30px rgba(0, 0, 0, 0.35);
}

.dropdown-header {
    color: var(--text-main);
    opacity: 0.65;
    font-size: 0.85rem;
}

.dropdown-divider {
    border-color: var(--border-color);
}

.dropdown-submenu {
    position: relative;
}

.dropdown-submenu > .dropdown-menu {
    top: 0;
    left: 100%;
}

/* =========================================================
   DROPDOWN THEME FIX
========================================================= */
.dropdown-menu {
    background-color: var(--card-bg);
    border-color: var(--border-color);
}

.dropdown-item {
    color: var(--text-main) !important;
}

.dropdown-item:hover,
.dropdown-item:focus {
    background-color: color-mix(in srgb, var(--text-main) 10%, transparent);
    color: var(--text-main) !important;
}

.dropdown-item i,
.dropdown-item svg {
    color: var(--text-main);
}

/* =========================================================
   FOOTER (MOBILE)
========================================================= */
.footer {
    background-color: var(--bg-color);
    border-top: 1px solid var(--border-color);
    padding-bottom: env(safe-area-inset-bottom);
    z-index: 1040;
}

.footer .nav-link {
    color: var(--text-main);
    opacity: 0.55;
    transition: opacity 0.2s ease;
}

.footer .nav-link svg {
    stroke: var(--text-main);
}

.footer .nav-link:hover {
    opacity: 0.85;
}

.footer .nav-link.aktif {
    opacity: 1;
    font-weight: 600;
}

.footer .nav-link.aktif::after {
    content: "";
    display: block;
    width: 18px;
    height: 2px;
    background-color: var(--text-main);
    margin: 3px auto 0;
    border-radius: 2px;
}

/* =========================================================
   RESPONSIVE TITLE
========================================================= */
.responsive-title {
    font-weight: bold;
    margin: 0;
    font-size: clamp(14px, 4vw, 22px);
}

/* =========================================================
   IMG GALLERY
========================================================= */
.img-gallery {
    width: 300px;
    padding: 10px;
    border-radius: 20px;
    background-color: var(--card-bg);
    transition: transform 0.3s ease, filter 0.3s ease;
}

.img-gallery:hover {
    transform: scale(1.08);
    filter: brightness(0.85);
}

@media (max-width: 768px) {
    .img-gallery {
        width: 140px;
    }
}

@media (max-width: 576px) {
    .img-gallery {
        width: 120px;
    }
}

/* =========================================================
   FRANCHISE CARD
========================================================= */
.franchise-card {
    background-color: var(--card-bg);
    color: var(--text-main);
    border-radius: 12px;
    padding: 10px 15px;
    font-size: 0.9rem;
    font-weight: 600;
    text-align: center;
    transition: all 0.25s ease;
}

.franchise-card:hover {
    transform: translateY(-6px);
    box-shadow: 0 6px 20px rgba(0, 0, 0, 0.35);
}

.franchise-card img {
    max-height: 90px;
    object-fit: contain;
}

/* =========================================================
   PAGINATION
========================================================= */
.pagination {
    --bs-pagination-bg: var(--card-bg);
    --bs-pagination-border-color: var(--border-color);
    --bs-pagination-color: var(--text-main);
    --bs-pagination-hover-bg: rgba(255, 255, 255, 0.08);
    --bs-pagination-active-bg: var(--text-main);
    --bs-pagination-active-color: var(--bg-color);
}

/* =========================================================
   SWIPER
========================================================= */
.swiper {
    width: 95%;
    padding-top: 20px;
    opacity: 0;
    transition: opacity 0.3s ease;
}

.swiper.swiper-initialized {
    opacity: 1;
}

.slide-image {
    overflow: hidden;
    border-radius: 8px;
    background-color: var(--card-bg);
}

.slide-image--landscape {
    aspect-ratio: 3 / 1;
}

.slide-image--16x9 {
    aspect-ratio: 16 / 9;
}

.slide-image--portrait {
    aspect-ratio: 2 / 3;
}

.slide-image img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    display: block;
}

.swiper-button-next,
.swiper-button-prev {
    top: 40% !important;
    color: var(--text-main) !important;
}

.swiper-button-next::after,
.swiper-button-prev::after {
    font-size: 28px;
}

/* =========================================================
   SECTION TITLE
========================================================= */
.section-title {
    display: flex;
    justify-content: center;
    align-items: center;
    position: relative;
    margin-bottom: 7px;
    padding: 0 15px;
}

.section-title .title {
    margin: 0;
}

.section-title a {
    position: absolute;
    right: 45px;
    font-size: 14px;
    opacity: 0.75;
    transition: opacity 0.2s;
}

.section-title a:hover {
    opacity: 1;
    text-decoration: underline;
}

@media (max-width: 576px) {
    .section-title {
        justify-content: flex-start;
    }

    .section-title a {
        right: 20px;
        font-size: 12px;
    }
}

/* =========================================================
   HISTORY & BOOKMARK (YouTube-style list)
========================================================= */

.saved-video-list {
    gap: 0.5rem;
}

.saved-video-item {
    --saved-video-thumb-width: 10.5rem;
    background-color: var(--card-bg) !important;
    color: var(--text-main) !important;
    border: 1px solid var(--border-color);
    border-radius: 0.5rem;
    padding: 0.75rem;
}

.saved-video-link {
    display: flex;
    align-items: flex-start;
    gap: 0.75rem;
    min-width: 0;
    color: var(--text-main) !important;
}

.saved-video-link:hover .saved-video-title {
    text-decoration: underline;
}

.saved-video-thumb {
    flex: 0 0 var(--saved-video-thumb-width);
    width: var(--saved-video-thumb-width);
    height: calc(var(--saved-video-thumb-width) * 9 / 16);
    border-radius: 0.5rem;
    overflow: hidden;
    background-color: #000;
}

.saved-video-thumb img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    display: block;
}

.saved-video-meta {
    display: flex;
    flex-direction: column;
    justify-content: center;
    gap: 0.2rem;
    min-width: 0;
    flex: 1;
    overflow: hidden;
}

.saved-video-title,
.saved-video-channel,
.saved-video-sub {
    min-width: 0;
    max-width: 100%;
    overflow: hidden;
    text-overflow: ellipsis;
}

.saved-video-title {
    font-weight: 600;
    font-size: 0.95rem;
    line-height: 1.35;
    display: -webkit-box;
    -webkit-box-orient: vertical;
    -webkit-line-clamp: 2;
    word-break: break-word;
}

.saved-video-channel,
.saved-video-sub {
    font-size: 0.8rem;
    line-height: 1.3;
    white-space: nowrap;
}

.saved-video-item .text-muted {
    color: color-mix(in srgb, var(--text-main) 60%, transparent) !important;
}

.saved-video-delete.btn-outline-danger {
    color: #ff6b6b;
    border-color: #ff6b6b;
}

.saved-video-delete.btn-outline-danger:hover {
    background-color: #ff6b6b;
    color: #fff;
}

#watchHistory li,
#bookmarkList li {
    color: var(--text-main);
}

@media (max-width: 575.98px) {
    .saved-video-item {
        --saved-video-thumb-width: 7.5rem;
    }

    .saved-video-title {
        font-size: 0.875rem;
    }

    .saved-video-channel,
    .saved-video-sub {
        font-size: 0.75rem;
    }
}

/* =========================================================
   SEARCH INPUT
========================================================= */
.client-search-input {
    border-radius: 10px;
    padding: 0.5rem 0.875rem 0.5rem 2.5rem;
    font-size: 0.9rem;
    line-height: 1.4;
}

.client-search-icon {
    position: absolute;
    top: 50%;
    left: 14px;
    transform: translateY(-50%);
    pointer-events: none;
    font-size: 14px;
    color: color-mix(in srgb, var(--text-main) 50%, transparent);
}

/* Header search — icon only, expands left beside menu (mobile) */
.header-search {
    position: relative;
    flex-shrink: 0;
}

.header-search-inner {
    display: flex;
    align-items: center;
    justify-content: flex-end;
    position: relative;
}

.header-search-field {
    position: absolute;
    right: calc(100% + 6px);
    top: 50%;
    transform: translateY(-50%);
    width: 0;
    min-width: 0;
    opacity: 0;
    overflow: hidden;
    pointer-events: none;
    transition: width 0.28s ease, opacity 0.2s ease;
}

.header-search.is-expanded .header-search-field {
    width: min(240px, calc(100vw - 148px));
    opacity: 1;
    pointer-events: auto;
}

.header-search-input {
    border-radius: 10px;
    height: 38px;
    padding: 0.375rem 0.75rem;
    font-size: 0.875rem;
    line-height: 1.4;
    width: 100%;
    min-width: 0;
}

.header-search-toggle {
    display: flex;
    align-items: center;
    justify-content: center;
    height: 38px;
    width: 38px;
    padding: 0;
    flex-shrink: 0;
    border-radius: 10px;
    border: 1px solid var(--border-color);
    background-color: var(--card-bg);
    color: var(--text-main) !important;
    transition: background-color 0.2s ease, border-color 0.2s ease;
}

.header-search-toggle:hover,
.header-search-toggle:focus {
    background-color: color-mix(in srgb, var(--text-main) 8%, var(--card-bg));
    border-color: color-mix(in srgb, var(--text-main) 35%, var(--border-color));
    color: var(--text-main) !important;
}

.header-search.is-expanded .header-search-toggle {
    border-color: color-mix(in srgb, var(--text-main) 35%, var(--border-color));
}

.input-group-text {
    background-color: var(--card-bg);
    border: 1px solid var(--border-color);
    color: var(--text-main);
}

.form-control {
    background-color: var(--card-bg);
    border: 1px solid var(--border-color);
    color: var(--text-main);
}

.form-control::placeholder {
    color: color-mix(in srgb, var(--text-main) 55%, transparent);
}

.form-control:focus {
    background-color: var(--card-bg);
    color: var(--text-main);
    border-color: var(--text-main);
    box-shadow: none;
}

/* Tight layout with left addon only; first input (admin search, etc.) keeps its left border */
.input-group > .input-group-text + .form-control,
.input-group > .input-group-text + textarea.form-control,
.input-group > .input-group-text + .form-select {
    border-left: 0;
}

.input-group-text {
    border-right: 0;
}

.btn-icon {
    background: transparent;
    border: none;
    color: var(--text-sec);
    padding: 6px;
    border-radius: 50%;
    transition: background-color 0.2s ease, color 0.2s ease;
    margin: 0;
    padding: 0;
}

.btn-icon i {
    color: var(--text-sec);
    font-size: 16px;
}

.btn-icon:hover {
    background-color: rgba(255, 255, 255, 0.12);
}

body.theme-light .btn-icon:hover {
    background-color: rgba(0, 0, 0, 0.08);
}

.table {
    --bs-table-bg: var(--card-bg);
    --bs-table-color: var(--text-main);
    --bs-table-border-color: var(--border-color);

    background-color: var(--card-bg);
    color: var(--text-main);
    font-size: 0.88rem;
}

.table thead th {
    background-color: color-mix(in srgb, var(--card-bg) 92%, #000);
    color: var(--text-main);
    border-bottom: 1px solid var(--border-color);
    font-size: 0.8rem;
    letter-spacing: 0.03em;
    text-transform: uppercase;
    white-space: nowrap;
}

.table th,
.table td {
    padding: 0.4rem 0.55rem;
    vertical-align: middle;
    border-color: var(--border-color);
}

.table tbody tr {
    background-color: var(--card-bg);
}

.table-hover tbody tr:hover {
    background-color: rgba(255, 255, 255, 0.06);
}

body.theme-light .table-hover tbody tr:hover {
    background-color: rgba(0, 0, 0, 0.04);
}

.table a {
    color: var(--text-main);
}

.table a:hover {
    text-decoration: underline;
}

.table i {
    color: var(--text-main);
    opacity: 0.85;
    font-size: 0.8rem;
}

.table td.text-muted,
.table .text-muted {
    font-size: 0.82rem;
    color: color-mix(in srgb, var(--text-main) 60%, transparent) !important;
    white-space: nowrap;
}

.table img {
    max-height: 65px;
    width: auto;
    background-color: var(--card-bg);
    border-radius: 6px;
}

/*
 * Images in modals whose markup still lives in <td>: only relax .table img constraints.
 * Do not use a global .modal .modal-body img.img-fluid { max-height: none } — img-fluid + col-12 would grow without bound.
 */
.table .modal img,
#adminAppBody .admin-table-bulk-scope .table .modal img {
    max-height: none !important;
    max-width: 100%;
    width: auto !important;
    height: auto;
    object-fit: contain;
}

/* Modal preview (category/franchise/era, etc.): center image & download actions */
#adminAppBody .modal .modal-body .card-body {
    text-align: center;
}

#adminAppBody .modal .modal-body .card-body > .img-fluid,
#adminAppBody .modal .modal-body .card-body > img.img-fluid,
#adminAppBody .modal .modal-body .card-body > img.img {
    display: block;
    margin-left: auto;
    margin-right: auto;
    max-width: min(100%, 280px) !important;
    max-height: min(55vh, 280px) !important;
    width: auto !important;
    height: auto !important;
    object-fit: contain;
}

#adminAppBody.theme-light .modal .modal-body .card-body .btn.btn-success,
#adminAppBody.theme-light .modal .modal-body .card-body a.btn.btn-success {
    color: #065f46 !important;
    background-color: #d1fae5 !important;
    border-color: #34d399 !important;
}

#adminAppBody.theme-light .modal .modal-body .card-body .btn.btn-success:hover,
#adminAppBody.theme-light
    .modal
    .modal-body
    .card-body
    a.btn.btn-success:hover {
    background-color: #a7f3d0 !important;
    color: #064e3b !important;
    border-color: #10b981 !important;
}

#adminAppBody:not(.theme-light) .modal .modal-body .card-body .btn.btn-success,
#adminAppBody:not(.theme-light)
    .modal
    .modal-body
    .card-body
    a.btn.btn-success {
    color: #ecfdf5 !important;
    background-color: #047857 !important;
    border-color: #10b981 !important;
}

#adminAppBody:not(.theme-light)
    .modal
    .modal-body
    .card-body
    .btn.btn-success:hover,
#adminAppBody:not(.theme-light)
    .modal
    .modal-body
    .card-body
    a.btn.btn-success:hover {
    background-color: #059669 !important;
    color: #fff !important;
}

/* Compact only on client area; admin uses normal btn-sm scale to match toolbar */
#appBody .table .btn-sm {
    padding: 0.2rem 0.45rem;
    font-size: 0.75rem;
    line-height: 1;
}

/* One scale for toolbar, row actions, and small controls in admin table cards */
#adminAppBody .admin-table-card .btn-sm {
    --bs-btn-padding-y: 0.25rem;
    --bs-btn-padding-x: 0.5rem;
    --bs-btn-font-size: 0.875rem;
    --bs-btn-line-height: 1.5;
}

#adminAppBody
    .admin-table-card
    .js-admin-bulk-toolbar
    .btn.btn-sm[data-bs-toggle="dropdown"] {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-width: 2.125rem;
}

.bookmark-btn {
    line-height: 1;
}

@media (max-width: 576px) {
    .table {
        font-size: 0.85rem;
    }

    .table img {
        max-height: 55px;
    }
}

.pagination {
    --bs-pagination-bg: var(--card-bg);
    --bs-pagination-border-color: var(--border-color);
    --bs-pagination-color: var(--text-main);

    --bs-pagination-hover-bg: rgba(255, 255, 255, 0.08);
    --bs-pagination-hover-color: var(--text-main);

    --bs-pagination-active-bg: var(--text-main);
    --bs-pagination-active-color: var(--bg-color);

    --bs-pagination-disabled-bg: var(--card-bg);
    --bs-pagination-disabled-color: color-mix(
        in srgb,
        var(--text-main) 40%,
        transparent
    );

    background-color: transparent;
}

.page-item .page-link {
    background-color: var(--card-bg);
    color: var(--text-main);
    border: 1px solid var(--border-color);
    margin: 0 2px;
    border-radius: 8px;
    transition: all 0.2s ease;
}

.page-item .page-link:hover {
    background-color: rgba(255, 255, 255, 0.08);
    color: var(--text-main);
}

body.theme-light .page-item .page-link:hover {
    background-color: rgba(0, 0, 0, 0.06);
}

.page-item.active .page-link {
    background-color: var(--text-main);
    color: var(--bg-color);
    border-color: var(--text-main);
    font-weight: 600;
}

.page-item.disabled .page-link {
    background-color: var(--card-bg);
    color: color-mix(in srgb, var(--text-main) 40%, transparent);
    border-color: var(--border-color);
    opacity: 0.6;
    pointer-events: none;
}

.page-link:focus {
    box-shadow: none;
}

/* =========================================================
   MODAL THEME (DARK / LIGHT)
========================================================= */
.modal-theme {
    background-color: var(--card-bg);
    color: var(--text-main);
    border: 1px solid var(--border-color);
}

.modal-theme .modal-header,
.modal-theme .modal-footer {
    border-color: var(--border-color);
}

.modal-theme .btn-close {
    filter: invert(1);
}

body.theme-light .modal-theme .btn-close {
    filter: invert(0);
}

.modal-theme textarea,
.modal-theme input {
    background-color: var(--bg-color);
    color: var(--text-main);
    border: 1px solid var(--border-color);
}

.modal-theme textarea::placeholder {
    color: color-mix(in srgb, var(--text-main) 50%, transparent);
}

.modal-theme {
    transition: background-color 0.3s ease, color 0.3s ease;
}

.server-btn,
.btn-outline-light {
    background-color: transparent;
    color: var(--text-main);
    border: 1px solid var(--border-color);
    transition: all 0.2s ease;
}

.server-btn:hover,
.btn-outline-light:hover {
    background-color: color-mix(in srgb, var(--text-main) 12%, transparent);
    color: var(--text-main);
}

.server-btn.active {
    background-color: var(--text-main);
    color: var(--bg-color);
    border-color: var(--text-main);
    font-weight: 600;
}

.server-btn:focus,
.btn-outline-light:focus {
    box-shadow: none;
}

body.theme-light .server-btn:hover,
body.theme-light .btn-outline-light:hover {
    background-color: rgba(0, 0, 0, 0.06);
}

@media (max-width: 768px) {
    .normal-text {
        font-size: 0.7rem !important;
        line-height: 1;
    }

    span.text-muted {
        font-size: 0.6rem !important;
    }
}

.franchise-img {
    width: 100%;
    height: 50px;
    object-fit: cover;
}

.episode-scroll {
    display: flex;
    gap: 10px;
    overflow-x: auto;
    padding: 10px 5px;
    scrollbar-width: none;
}

.episode-scroll::-webkit-scrollbar {
    display: none;
}

.episode-scroll.centered {
    justify-content: center;
}

.episode-btn {
    flex: 0 0 auto;
    width: 49px;
    height: 49px;
    background: var(--bg-color);
    border: 1px solid var(--border-color);
    border-radius: 8px;
    display: flex;
    align-items: center;
    justify-content: center;
    font-weight: 600;
    font-size: 0.9rem;
    color: var(--text-main);
    position: relative;
}

.episode-btn:hover {
    background: #cfcfcf;
}

.episode-btn.active {
    background: var(--site-theme);
    color: #fff;
}

a {
    text-decoration: none;
    color: inherit;
}

ul {
    list-style: none;
}

.app-header {
    position: fixed;
    top: 0;
    left: 0;
    right: 0;
    height: var(--header-height);
    background: var(--card-bg);
    display: flex;
    align-items: center;
    justify-content: space-between;
    padding: 0 16px;
    z-index: 1000;
    border-bottom: 1px solid var(--border-color);
}

.header-left {
    display: flex;
    align-items: center;
    gap: 15px;
}

.back-btn {
    font-size: 1.2rem;
}

.header-title {
    font-weight: 600;
    font-size: 1rem;
}

.header-right {
    display: flex;
    gap: 18px;
    color: var(--text-sec);
}

.header-right i {
    font-size: 1.1rem;
    cursor: pointer;
}

.video-container {
    width: 100%;
    background: #000;
    position: relative;
    padding-top: 56.25%;
}

.video-container iframe {
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    border: none;
}

.info-section {
    padding: 16px;
    background: var(--card-bg);
    margin-bottom: 8px;
}

.video-title {
    font-size: 1.1rem;
    font-weight: 600;
    line-height: 1.4;
    margin-bottom: 8px;
    display: -webkit-box;
    -webkit-line-clamp: 2;
    -webkit-box-orient: vertical;
    overflow: hidden;
}

.video-meta {
    font-size: 0.8rem;
    color: var(--text-sec);
    display: flex;
    align-items: center;
    justify-content: space-between;
    margin-bottom: 16px;
}

.meta-left span {
    margin-right: 8px;
}

.action-bar {
    display: flex;
    justify-content: space-between;
    align-items: center;
}

.action-item {
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 5px;
    color: var(--text-sec);
    font-size: 0.75rem;
    cursor: pointer;
}

.action-item i {
    font-size: 1.2rem;
    margin-bottom: 2px;
}

.action-item.active {
    color: var(--primary);
}

.channel-section {
    padding: 12px 16px;
    background: var(--card-bg);
    display: flex;
    align-items: center;
    justify-content: space-between;
    border-top: 1px solid var(--border-color);
    border-bottom: 1px solid var(--border-color);
    margin-bottom: 8px;
}

.channel-info {
    display: flex;
    align-items: center;
    gap: 10px;
    min-width: 0;
}

.channel-avatar {
    width: 50px;
    height: 50px;
    min-width: 50px;
    min-height: 50px;
    flex-shrink: 0;
    aspect-ratio: 1 / 1;
    background: #ddd;
    border-radius: 50%;
    overflow: hidden;
}

.channel-avatar img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    border-radius: 50%;
    display: block;
}

.channel-text {
    min-width: 0;
    flex: 1 1 auto;
}

.channel-title,
.channel-text h4 {
    font-size: 0.95rem;
    font-weight: 600;
    margin-bottom: 2px;
    line-height: 1.3;
    overflow: hidden;
    display: -webkit-box;
    -webkit-box-orient: vertical;
    -webkit-line-clamp: 2;
}

.channel-text span {
    font-size: 0.75rem;
    color: var(--text-sec);
}

.btn-subscribe {
    background: var(--primary);
    color: white;
    border: none;
    padding: 6px 16px;
    border-radius: 20px;
    font-size: 0.85rem;
    font-weight: 600;
}

.episodes-section {
    padding: 16px;
    background: var(--card-bg);
    margin-bottom: 8px;
}

.section-header {
    display: flex;
    justify-content: space-between;
    align-items: center;
    margin-bottom: 12px;
}

.section-title {
    font-size: 1rem;
    font-weight: 600;
}

.section-more {
    font-size: 0.85rem;
    color: var(--text-sec);
}

.comments-section {
    padding: 16px;
    background: var(--card-bg);
}

.comment-compose-form {
    margin-top: 1rem;
    padding-top: 0.75rem;
    border-top: 1px solid var(--border-color);
}

.comment-compose-row {
    display: flex;
    align-items: flex-start;
    gap: 0.5rem;
}

.comment-compose-input {
    flex: 1 1 auto;
    min-width: 0;
    resize: vertical;
    min-height: 2.5rem;
    max-height: 10rem;
}

.comment-reply-input,
.comment-edit-input {
    resize: vertical;
    min-height: 2.25rem;
    max-height: 10rem;
}

.comment-message {
    font-size: 0.9rem;
    white-space: pre-wrap;
    overflow-wrap: anywhere;
}

.comment-compose-submit {
    flex-shrink: 0;
    white-space: nowrap;
}

.user-mini-avatar {
    width: 30px;
    height: 30px;
    border-radius: 50%;
    background: #444;
}

.video-title-wrapper.expanded .truncate {
    display: none !important;
}

.video-title-wrapper.expanded .full,
.video-title-wrapper.expanded .category-desc {
    display: block !important;
}

.video-title-wrapper .accordion-toggle i {
    transition: transform 0.2s ease;
}

.video-title-wrapper.expanded .accordion-toggle i {
    transform: rotate(180deg);
}

.user-mini-avatar {
    width: 30px;
    height: 30px;
    border-radius: 50%;
    overflow: hidden;
    flex-shrink: 0;
}

.user-mini-avatar img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    border-radius: 50%;
}

.comment-author-link {
    color: var(--text-sec);
}

.comment-author-link:hover {
    color: var(--primary);
}

.comment-replies {
    margin-left: 38px;
    margin-top: 6px;
    padding-left: 12px;
    border-left: 2px solid var(--border-color);
}

.toggle-replies {
    display: block;
    margin-left: 38px;
    margin-top: 4px;
    margin-bottom: 2px;
    font-size: .7rem;
    text-align: left;
}

.comment-thread:last-child {
    margin-bottom: 0 !important;
}

.header-notifications {
    display: flex;
    align-items: center;
    position: relative;
}

.header-notifications-bell {
    touch-action: manipulation;
    -webkit-tap-highlight-color: transparent;
}

.header-right,
.header-notifications,
.header .container {
    overflow: visible;
}

.header-notifications .header-notifications-badge {
    position: absolute;
    top: 4px;
    right: 4px;
    width: 8px;
    height: 8px;
    border-radius: 50%;
    background: #dc3545;
    border: 2px solid var(--header-bg, var(--card-bg));
    z-index: 2;
    pointer-events: none;
}

.notifications-dropdown {
    width: min(18rem, calc(100vw - 1rem));
    max-width: calc(100vw - 1rem);
    margin-top: 0.35rem !important;
    background: var(--card-bg);
    color: var(--text-main);
    border-radius: 12px;
    overflow: hidden;
    z-index: 1060;
    box-sizing: border-box;
}

@media (max-width: 767.98px) {
    .header-notifications .notifications-dropdown.dropdown-menu.show {
        position: fixed !important;
        top: var(--notifications-dropdown-top, 4.5rem) !important;
        left: max(0.5rem, env(safe-area-inset-left, 0px)) !important;
        right: auto !important;
        bottom: auto !important;
        width: calc(100vw - 1rem - env(safe-area-inset-left, 0px) - env(safe-area-inset-right, 0px)) !important;
        max-width: calc(100vw - 1rem - env(safe-area-inset-left, 0px) - env(safe-area-inset-right, 0px)) !important;
        margin: 0 !important;
        transform: none !important;
    }
}

.notifications-dropdown__head {
    display: grid;
    grid-template-columns: minmax(0, 1fr) auto;
    align-items: center;
    column-gap: 1rem;
    border-color: var(--border-color) !important;
    background: var(--card-bg);
    min-width: 0;
    padding: 0.75rem 1.75rem 0.75rem 1.25rem;
}

.notifications-dropdown__title {
    min-width: 0;
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
}

.notifications-mark-all {
    font-size: 0.7rem;
    white-space: nowrap;
    padding: 0.35rem 0.65rem 0.35rem 0.5rem;
    margin: 0;
    justify-self: end;
}

.notifications-dropdown__head .notifications-mark-all.btn-link {
    margin-right: 0;
    margin-left: 0;
    --bs-btn-padding-x: 0.65rem;
    --bs-btn-padding-y: 0.35rem;
}

.notifications-dropdown__body {
    max-height: min(20rem, 55vh);
    overflow-x: hidden;
    overflow-y: auto;
    -webkit-overflow-scrolling: touch;
}

.notifications-item {
    background: transparent;
    border-color: var(--border-color) !important;
    min-width: 0;
}

.notifications-item__link {
    display: block;
    color: inherit;
    min-width: 0;
}

.notifications-item__top {
    display: flex;
    flex-direction: row;
    flex-wrap: nowrap;
    align-items: center;
    gap: 0.5rem;
    min-width: 0;
}

.notifications-item__avatar {
    display: inline-block;
    width: 28px;
    height: 28px;
    min-width: 28px;
    object-fit: cover;
    flex: 0 0 28px;
}

.notifications-item__meta {
    flex: 1 1 auto;
    min-width: 0;
    font-size: 0.75rem;
    font-weight: 600;
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
}

.notifications-item__name {
    font-weight: 600;
    color: inherit;
}

.notifications-item__action {
    font-weight: 400;
}

.notifications-item__time {
    flex: 0 0 auto;
    font-size: 0.65rem;
    font-weight: 400;
    white-space: nowrap;
}

.notifications-item__time::before {
    content: '·';
    margin-right: 0.35rem;
    opacity: 0.7;
}

.notifications-item__body {
    min-width: 0;
    padding-left: calc(28px + 0.5rem);
    margin-top: 0.25rem;
}

.notifications-item__video {
    font-size: 0.7rem;
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
}

.notifications-item__reply {
    display: -webkit-box;
    -webkit-box-orient: vertical;
    -webkit-line-clamp: 2;
    overflow: hidden;
    margin-top: 0.15rem;
    font-size: 0.75rem;
    line-height: 1.35;
    color: var(--text-sec);
    overflow-wrap: anywhere;
    word-break: break-word;
}

.notifications-item__link:hover .notifications-item__reply {
    color: var(--primary);
}

@media (max-width: 575.98px) {
    .notifications-dropdown__head {
        padding-left: 1rem !important;
        padding-right: 1.5rem !important;
        padding-inline-end: 1.5rem !important;
        column-gap: 0.75rem;
    }

    .notifications-mark-all {
        font-size: 0.65rem;
        padding-right: 0.5rem !important;
    }
}

.comment-item-menu .comment-menu-toggle {
    color: var(--text-sec);
    line-height: 1;
    min-width: 1.5rem;
}

.comment-item-menu .comment-menu-toggle:hover,
.comment-item-menu .comment-menu-toggle:focus {
    color: var(--primary);
}

.comment-edited-label {
    color: var(--text-sec);
    font-style: italic;
    opacity: 0.85;
}

.comment-edit-form,
.comment-reply-form {
    margin-top: 0.5rem;
}

.comment-compose-form .form-control,
.comment-edit-form .form-control,
.comment-reply-form .form-control {
    border-radius: 10px;
    font-size: 0.875rem;
}

.comment-form-actions {
    display: flex;
    flex-wrap: wrap;
    gap: 0.5rem;
    margin-top: 0.625rem;
    align-items: center;
}

.comment-btn-save {
    background: var(--primary);
    border: 1px solid var(--primary);
    color: #fff;
    padding: 0.35rem 1.125rem;
    border-radius: 999px;
    font-size: 0.8rem;
    font-weight: 600;
    line-height: 1.25;
    transition: filter 0.15s ease, transform 0.15s ease;
}

.comment-btn-save:hover,
.comment-btn-save:focus {
    filter: brightness(1.08);
    color: #fff;
    transform: translateY(-1px);
}

.comment-btn-save:active {
    transform: translateY(0);
}

.comment-btn-cancel {
    background: color-mix(in srgb, var(--card-bg) 88%, var(--text-main));
    border: 1px solid var(--border-color);
    color: var(--text-sec);
    padding: 0.35rem 1.125rem;
    border-radius: 999px;
    font-size: 0.8rem;
    font-weight: 500;
    line-height: 1.25;
    transition: border-color 0.15s ease, color 0.15s ease, background 0.15s ease;
}

.comment-btn-cancel:hover,
.comment-btn-cancel:focus {
    border-color: color-mix(in srgb, var(--text-sec) 55%, var(--border-color));
    color: var(--text-main);
    background: color-mix(in srgb, var(--card-bg) 75%, var(--text-main));
}

.view-all-comments {
    display: inline-block;
    font-size: 0.8rem;
    font-weight: 600;
    margin-top: 0.35rem;
    text-decoration: none;
}

.view-all-comments:hover {
    text-decoration: underline;
}

/* =========================================================
   CARD & MODAL
========================================================= */
.card,
.modal-content {
    background-color: var(--card-bg);
    color: var(--text-main);
    border: 1px solid var(--border-color);
}

/* Bootstrap utility overrides (follow theme-dark / theme-light) */
.text-body {
    color: var(--text-main) !important;
}

.text-body-secondary {
    color: var(--text-sec) !important;
}

.border {
    border-color: var(--border-color) !important;
}

.list-group {
    --bs-list-group-color: var(--text-main);
    --bs-list-group-bg: var(--card-bg);
    --bs-list-group-border-color: var(--border-color);
    --bs-list-group-action-color: var(--text-main);
    --bs-list-group-action-hover-color: var(--text-main);
    --bs-list-group-action-hover-bg: color-mix(
        in srgb,
        var(--text-main) 8%,
        var(--card-bg)
    );
    --bs-list-group-action-active-color: var(--text-main);
    --bs-list-group-action-active-bg: color-mix(
        in srgb,
        var(--text-main) 12%,
        var(--card-bg)
    );
    --bs-list-group-disabled-color: var(--text-sec);
    --bs-list-group-active-color: var(--text-main);
    --bs-list-group-active-bg: color-mix(
        in srgb,
        var(--text-main) 14%,
        var(--card-bg)
    );
    --bs-list-group-active-border-color: var(--border-color);
}

.list-group-item {
    color: var(--text-main);
    background-color: var(--card-bg);
    border-color: var(--border-color);
}

.list-group-item-action:hover,
.list-group-item-action:focus {
    color: var(--text-main);
    background-color: color-mix(in srgb, var(--text-main) 8%, var(--card-bg));
}

#main-content .list-group-item a:not(.btn) {
    color: var(--link-accent);
}

#main-content .list-group-item a:not(.btn):hover {
    color: color-mix(in srgb, var(--link-accent) 85%, var(--text-main));
}

/* Outline buttons on client content (membership, profile, etc.) */
#main-content .btn-outline-primary,
#main-content .btn-outline-secondary {
    color: var(--text-main);
    border-color: color-mix(in srgb, var(--text-main) 40%, var(--border-color));
    background-color: transparent;
}

#main-content .btn-outline-primary:hover,
#main-content .btn-outline-secondary:hover {
    color: var(--text-main);
    background-color: color-mix(in srgb, var(--text-main) 10%, transparent);
    border-color: color-mix(in srgb, var(--text-main) 55%, var(--border-color));
}

body.theme-light #main-content .btn-outline-primary,
body.theme-light #main-content .btn-outline-secondary {
    color: var(--text-main);
    border-color: color-mix(in srgb, var(--text-main) 35%, var(--border-color));
}

body.theme-light #main-content .btn-outline-primary:hover,
body.theme-light #main-content .btn-outline-secondary:hover {
    background-color: color-mix(in srgb, var(--text-main) 8%, transparent);
}

/* =========================================================
   MEMBERSHIP STATUS PILL (subscription / profile)
========================================================= */
.membership-pill {
    display: inline-flex;
    align-items: center;
    gap: 0.4rem;
    padding: 0.4rem 0.95rem;
    border-radius: 999px;
    font-size: 0.72rem;
    font-weight: 700;
    letter-spacing: 0.06em;
    line-height: 1.2;
    border: 1px solid transparent;
    vertical-align: middle;
    flex-shrink: 0;
    white-space: nowrap;
    max-width: 100%;
    transition: transform 0.2s ease, box-shadow 0.2s ease;
}

.membership-pill__icon {
    font-size: 0.68rem;
    opacity: 0.95;
    filter: drop-shadow(0 1px 1px rgba(0, 0, 0, 0.2));
}

.membership-pill__text {
    text-transform: uppercase;
}

.membership-pill--neutral {
    background: color-mix(in srgb, var(--text-main) 8%, var(--card-bg));
    color: var(--text-sec);
    border-color: var(--border-color);
    box-shadow: 0 1px 3px rgba(0, 0, 0, 0.12);
}

.membership-pill--neutral .membership-pill__text {
    text-transform: none;
    letter-spacing: 0.02em;
    font-weight: 600;
}

.membership-pill--active {
    color: #fff;
    background: var(--site-theme-gradient-rich);
    border-color: color-mix(in srgb, var(--site-theme-light) 55%, transparent);
    box-shadow: 0 2px 14px color-mix(in srgb, var(--site-theme) 45%, transparent),
        inset 0 1px 0 rgba(255, 255, 255, 0.22);
    text-shadow: 0 1px 2px rgba(0, 0, 0, 0.25);
}

.membership-pill--active .membership-pill__icon {
    color: #fde68a;
}

body.theme-light .membership-pill--active {
    box-shadow: 0 2px 12px color-mix(in srgb, var(--site-theme) 30%, transparent),
        inset 0 1px 0 rgba(255, 255, 255, 0.25);
}

.membership-pill--lifetime {
    color: #0c0a09;
    background: linear-gradient(135deg, #fcd34d 0%, #f59e0b 45%, #d97706 100%);
    border-color: color-mix(in srgb, #fef3c7 65%, #b45309);
    box-shadow: 0 2px 14px rgba(217, 119, 6, 0.4),
        inset 0 1px 0 rgba(255, 255, 255, 0.35);
    text-shadow: 0 1px 1px rgba(255, 255, 255, 0.35);
}

.membership-pill--lifetime .membership-pill__icon {
    color: #422006;
}

body.theme-light .membership-pill--lifetime {
    color: #422006;
    box-shadow: 0 2px 12px rgba(217, 119, 6, 0.28);
}

.membership-pill--expiring {
    color: #1c1917;
    background: linear-gradient(135deg, #facc15 0%, #f59e0b 55%, #ea580c 100%);
    border-color: color-mix(in srgb, #fef3c7 70%, #d97706);
    box-shadow: 0 2px 12px rgba(245, 158, 11, 0.35);
}

.membership-pill--expiring .membership-pill__icon {
    color: #422006;
}

.membership-pill--expired {
    color: #fecaca;
    background: linear-gradient(
        135deg,
        color-mix(in srgb, #ef4444 35%, var(--card-bg)) 0%,
        #7f1d1d 180%
    );
    border-color: rgba(239, 68, 68, 0.45);
    box-shadow: 0 2px 10px rgba(127, 29, 29, 0.35);
}

.membership-pill--expired .membership-pill__icon {
    color: #fca5a5;
}

body.theme-light .membership-pill--expired {
    color: #7f1d1d;
    background: linear-gradient(135deg, #fee2e2 0%, #fecaca 100%);
    border-color: #f87171;
    box-shadow: 0 2px 8px rgba(185, 28, 28, 0.15);
}

body.theme-light .membership-pill--expired .membership-pill__icon {
    color: #b91c1c;
}

/* =========================================================
   PROFILE PAGE
========================================================= */
.profile-page {
    max-width: 920px;
    margin-left: auto;
    margin-right: auto;
}

.profile-page-header {
    margin-bottom: 1.75rem;
}

.profile-page-header__title {
    font-size: clamp(1.35rem, 4vw, 1.75rem);
    font-weight: 800;
    letter-spacing: -0.02em;
    color: var(--text-main);
    margin-bottom: 0.35rem;
}

.profile-page-header__lead {
    color: var(--text-sec);
    font-size: 0.95rem;
    max-width: 42rem;
    margin-bottom: 0;
}

.profile-page-header__links {
    margin-top: 1rem;
    display: flex;
    flex-wrap: wrap;
    gap: 0.5rem;
}

.profile-page-header__links a {
    display: inline-flex;
    align-items: center;
    gap: 0.4rem;
    padding: 0.35rem 0.75rem;
    border-radius: 999px;
    font-size: 0.8rem;
    font-weight: 600;
    background: color-mix(in srgb, var(--text-main) 8%, var(--card-bg));
    border: 1px solid var(--border-color);
    color: var(--text-main);
    transition: background 0.2s ease, border-color 0.2s ease;
}

.profile-page-header__links a:hover {
    background: color-mix(in srgb, var(--text-main) 14%, var(--card-bg));
    border-color: color-mix(
        in srgb,
        var(--link-accent) 45%,
        var(--border-color)
    );
    color: var(--text-main);
}

.profile-card-main {
    border-radius: 16px;
    overflow: hidden;
    border: 1px solid var(--border-color) !important;
    box-shadow: 0 8px 32px rgba(0, 0, 0, 0.18);
}

body.theme-light .profile-card-main {
    box-shadow: 0 8px 28px rgba(0, 0, 0, 0.08);
}

.profile-section {
    padding-bottom: 1.5rem;
    margin-bottom: 1.5rem;
    border-bottom: 1px solid var(--border-color);
}

.profile-section:last-of-type {
    border-bottom: none;
    margin-bottom: 0;
    padding-bottom: 0;
}

.profile-section__head {
    display: flex;
    align-items: center;
    gap: 0.6rem;
    margin-bottom: 1.15rem;
}

.profile-section__icon {
    width: 2.25rem;
    height: 2.25rem;
    border-radius: 10px;
    display: flex;
    align-items: center;
    justify-content: center;
    background: linear-gradient(
        135deg,
        color-mix(in srgb, var(--link-accent) 35%, var(--card-bg)),
        var(--card-bg)
    );
    border: 1px solid var(--border-color);
    color: var(--link-accent);
    font-size: 0.95rem;
}

.profile-section__title {
    font-size: 0.95rem;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: 0.06em;
    color: var(--text-sec);
    margin: 0;
}

.profile-photo-wrap {
    display: flex;
    flex-direction: column;
    gap: 1.25rem;
}

@media (min-width: 576px) {
    .profile-photo-wrap {
        flex-direction: row;
        align-items: center;
    }
}

.profile-photo-wrap__avatar {
    position: relative;
    flex-shrink: 0;
}

.profile-photo-wrap__avatar img {
    width: 112px;
    height: 112px;
    border-radius: 50%;
    object-fit: cover;
    border: 3px solid var(--border-color);
    box-shadow: 0 6px 20px rgba(0, 0, 0, 0.2);
}

.profile-photo-wrap__upload {
    flex: 1;
    min-width: 0;
    padding: 1rem 1.15rem;
    border-radius: 12px;
    border: 1px dashed
        color-mix(in srgb, var(--text-main) 22%, var(--border-color));
    background: color-mix(in srgb, var(--text-main) 4%, var(--card-bg));
}

.profile-actions-bar {
    display: flex;
    flex-wrap: wrap;
    justify-content: space-between;
    align-items: center;
    gap: 1rem;
    margin-top: 1.5rem;
    padding-top: 1.25rem;
    border-top: 1px solid var(--border-color);
}

.profile-actions-bar .btn-primary {
    border-radius: 10px;
    font-weight: 600;
    padding: 0.5rem 1.35rem;
    box-shadow: 0 4px 14px color-mix(in srgb, var(--site-theme) 30%, transparent);
}

body.theme-light .profile-actions-bar .btn-primary {
    box-shadow: 0 4px 12px color-mix(in srgb, var(--site-theme) 20%, transparent);
}

.profile-actions-bar .btn-danger {
    border-radius: 10px;
    font-weight: 600;
}

.profile-membership-card {
    border-radius: 16px;
    border: 1px solid var(--border-color) !important;
    overflow: hidden;
    position: relative;
    box-shadow: 0 8px 28px rgba(0, 0, 0, 0.15);
}

.profile-membership-card::before {
    content: "";
    position: absolute;
    left: 0;
    right: 0;
    top: 0;
    height: 4px;
    background: linear-gradient(
        90deg,
        var(--site-theme),
        var(--site-theme-light),
        var(--site-theme-soft)
    );
}

body.theme-light .profile-membership-card {
    box-shadow: 0 8px 24px rgba(0, 0, 0, 0.07);
}

.profile-membership-card .card-body {
    padding-top: 1.35rem;
}

/* =========================================================
   PUBLIC USER PROFILE PAGE
========================================================= */
.user-profile-page {
    max-width: 920px;
    margin-left: auto;
    margin-right: auto;
}

.user-profile-card {
    border-radius: 20px;
    border: 1px solid var(--border-color);
    background: var(--card-bg);
    box-shadow: 0 10px 36px rgba(0, 0, 0, 0.2);
    overflow: visible;
}

body.theme-light .user-profile-card {
    box-shadow: 0 10px 32px rgba(0, 0, 0, 0.08);
}

.user-profile-banner {
    position: relative;
    height: 140px;
    background: var(--site-theme-gradient-banner);
    overflow: hidden;
    border-radius: 20px 20px 0 0;
}

body.theme-light .user-profile-banner {
    background: var(--site-theme-gradient);
}

.user-profile-banner__glow {
    position: absolute;
    inset: 0;
    background: radial-gradient(
            circle at 18% 120%,
            rgba(255, 255, 255, 0.22),
            transparent 42%
        ),
        radial-gradient(
            circle at 88% -20%,
            rgba(253, 230, 138, 0.28),
            transparent 38%
        );
    pointer-events: none;
}

.user-profile-body {
    padding: 0 1.35rem 1.5rem;
    margin-top: -64px;
    position: relative;
}

.user-profile-avatar-wrap {
    position: relative;
    width: 128px;
    height: 128px;
}

.user-profile-avatar {
    width: 128px;
    height: 128px;
    border-radius: 50%;
    object-fit: cover;
    border: 4px solid var(--card-bg);
    box-shadow: 0 8px 24px rgba(0, 0, 0, 0.28);
    display: block;
}

.user-profile-avatar-wrap--member .user-profile-avatar {
    border-color: var(--card-bg);
    box-shadow:
        0 0 0 3px var(--site-theme-light),
        0 8px 24px color-mix(in srgb, var(--site-theme) 28%, transparent);
}

.user-profile-avatar-wrap--lifetime .user-profile-avatar {
    border-color: var(--card-bg);
    box-shadow:
        0 0 0 3px #fbbf24,
        0 0 0 6px #d97706,
        0 8px 24px rgba(217, 119, 6, 0.32);
}

.user-profile-avatar__badge {
    position: absolute;
    right: 4px;
    bottom: 4px;
    width: 2rem;
    height: 2rem;
    border-radius: 50%;
    display: flex;
    align-items: center;
    justify-content: center;
    background: var(--site-theme-gradient);
    color: #fde68a;
    border: 2px solid var(--card-bg);
    font-size: 0.72rem;
    box-shadow: 0 2px 8px color-mix(in srgb, var(--site-theme) 45%, transparent);
}

.user-profile-avatar__badge--lifetime {
    background: linear-gradient(135deg, #fde68a, #f59e0b, #d97706);
    color: #422006;
    font-size: 0.8rem;
    box-shadow: 0 2px 10px rgba(217, 119, 6, 0.5);
}

.user-profile-name {
    font-size: clamp(1.35rem, 4vw, 1.75rem);
    font-weight: 800;
    letter-spacing: -0.02em;
    color: var(--text-main);
    margin-bottom: 0.2rem;
}

.user-profile-handle {
    color: var(--text-sec);
    font-size: 0.95rem;
    margin-bottom: 0.75rem;
}

.user-profile-about {
    color: var(--text-main);
    font-size: 0.95rem;
    line-height: 1.55;
    white-space: pre-wrap;
}

.user-profile-meta {
    display: flex;
    flex-direction: column;
    align-items: flex-start;
    gap: 0.35rem;
}

.user-profile-meta__primary {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    gap: 0.5rem;
    width: 100%;
}

@media (min-width: 768px) {
    .user-profile-info {
        overflow: visible;
    }
}

.user-profile-meta-chip {
    display: inline-flex;
    align-items: center;
    gap: 0.3rem;
    padding: 0;
    border-radius: 0;
    font-size: 0.62rem;
    font-weight: 500;
    letter-spacing: 0.01em;
    border: none;
    background: transparent;
    color: color-mix(in srgb, var(--text-main) 50%, transparent);
}

.user-profile-meta-chip i {
    font-size: 0.58rem;
    opacity: 0.75;
}

.user-profile-meta-chip--joined {
    text-transform: none;
}

.user-profile-stats {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 0.85rem;
    margin-top: 1.35rem;
    padding-top: 1.25rem;
    border-top: 1px solid var(--border-color);
}

.user-profile-stat {
    display: flex;
    flex-direction: column;
    align-items: center;
    text-align: center;
    padding: 0.85rem 0.75rem;
    border-radius: 14px;
    background: color-mix(in srgb, var(--text-main) 5%, var(--card-bg));
    border: 1px solid var(--border-color);
    transition: border-color 0.2s ease, transform 0.2s ease;
}

.user-profile-stat:hover {
    border-color: color-mix(
        in srgb,
        var(--link-accent) 45%,
        var(--border-color)
    );
    transform: translateY(-2px);
}

.user-profile-stat__icon {
    width: 2.25rem;
    height: 2.25rem;
    border-radius: 10px;
    display: flex;
    align-items: center;
    justify-content: center;
    background: linear-gradient(
        135deg,
        color-mix(in srgb, var(--link-accent) 35%, var(--card-bg)),
        var(--card-bg)
    );
    color: var(--link-accent);
    font-size: 0.9rem;
    margin-bottom: 0.5rem;
}

.user-profile-stat__value {
    font-size: 1.35rem;
    font-weight: 800;
    color: var(--text-main);
    line-height: 1.1;
}

.user-profile-stat__label {
    font-size: 0.72rem;
    font-weight: 700;
    letter-spacing: 0.06em;
    text-transform: uppercase;
    color: var(--text-sec);
    margin-top: 0.2rem;
}

.user-profile-section-head {
    display: flex;
    align-items: flex-start;
    gap: 0.75rem;
    margin-bottom: 1rem;
}

.user-profile-section-head__icon {
    width: 2.5rem;
    height: 2.5rem;
    border-radius: 12px;
    display: flex;
    align-items: center;
    justify-content: center;
    background: linear-gradient(
        135deg,
        color-mix(in srgb, var(--link-accent) 35%, var(--card-bg)),
        var(--card-bg)
    );
    border: 1px solid var(--border-color);
    color: var(--link-accent);
    flex-shrink: 0;
}

.user-profile-section-head__title {
    font-size: 1rem;
    font-weight: 800;
    letter-spacing: 0.02em;
    color: var(--text-main);
    margin-bottom: 0.15rem;
}

.user-profile-section-head__lead {
    font-size: 0.85rem;
    color: var(--text-sec);
}

.user-profile-empty {
    text-align: center;
    padding: 2.5rem 1.25rem;
    border-radius: 16px;
    border: 1px dashed
        color-mix(in srgb, var(--text-main) 22%, var(--border-color));
    background: color-mix(in srgb, var(--text-main) 4%, var(--card-bg));
}

.user-profile-empty__icon {
    display: inline-flex;
    width: 3rem;
    height: 3rem;
    align-items: center;
    justify-content: center;
    border-radius: 50%;
    background: color-mix(in srgb, var(--text-main) 8%, var(--card-bg));
    color: var(--text-sec);
    font-size: 1.35rem;
    margin-bottom: 0.75rem;
}

.user-profile-empty__text {
    color: var(--text-sec);
    font-size: 0.95rem;
}

.user-profile-comment-list {
    list-style: none;
    margin: 0;
    padding: 0;
    border-radius: 16px;
    overflow: hidden;
    border: 1px solid var(--border-color);
    box-shadow: 0 6px 24px rgba(0, 0, 0, 0.12);
}

body.theme-light .user-profile-comment-list {
    box-shadow: 0 6px 20px rgba(0, 0, 0, 0.06);
}

.user-profile-comment-item {
    padding: 1rem 1.15rem;
    background: var(--card-bg);
    border-bottom: 1px solid var(--border-color);
    transition: background 0.2s ease;
}

.user-profile-comment-item:last-child {
    border-bottom: none;
}

.user-profile-comment-item:hover {
    background: color-mix(in srgb, var(--text-main) 4%, var(--card-bg));
}

.user-profile-comment-item__title {
    font-weight: 700;
    color: var(--text-main);
    transition: color 0.2s ease;
}

.user-profile-comment-item__title:hover {
    color: var(--link-accent);
}

.user-profile-comment-item__series {
    display: inline-block;
    margin-top: 0.25rem;
    font-size: 0.72rem;
    font-weight: 700;
    letter-spacing: 0.05em;
    text-transform: uppercase;
    color: var(--text-sec);
    padding: 0.15rem 0.5rem;
    border-radius: 999px;
    background: color-mix(in srgb, var(--text-main) 8%, var(--card-bg));
    border: 1px solid var(--border-color);
}

.user-profile-comment-item__message {
    font-size: 0.9rem;
    color: var(--text-sec);
    line-height: 1.5;
}

.user-profile-comment-item__time {
    font-size: 0.78rem;
    color: var(--text-sec);
    white-space: nowrap;
}

.profile-membership-card__title {
    display: flex;
    align-items: center;
    gap: 0.5rem;
    font-size: 0.95rem;
    font-weight: 800;
    letter-spacing: 0.04em;
    text-transform: uppercase;
    color: var(--text-main);
    margin-bottom: 1rem;
}

.profile-membership-card__title i {
    color: #fde68a;
    filter: drop-shadow(0 1px 2px rgba(0, 0, 0, 0.25));
}

.profile-membership-card .btn {
    border-radius: 10px;
    font-weight: 600;
    margin-top: 0.25rem;
}

.provider-section-title {
    display: flex;
    align-items: center;
    gap: 0.5rem;
    font-size: 0.95rem;
    font-weight: 800;
    letter-spacing: 0.04em;
    text-transform: uppercase;
    color: var(--text-sec);
    margin-bottom: 1.15rem;
    margin-top: 0.25rem;
}

.provider-tile {
    border-radius: 14px;
    border: 1px solid var(--border-color);
    background: var(--card-bg);
    height: 100%;
    transition: border-color 0.2s ease, box-shadow 0.2s ease;
}

.provider-tile:hover {
    border-color: color-mix(
        in srgb,
        var(--link-accent) 35%,
        var(--border-color)
    );
    box-shadow: 0 6px 20px rgba(0, 0, 0, 0.12);
}

.provider-tile .card-body {
    padding: 1rem 1.15rem;
}

.provider-tile--profile .card-body {
    padding: 0.75rem 0.9rem;
}

.provider-tile__label {
    font-size: 0.9rem;
    line-height: 1.25;
}

.provider-tile__icon-wrap {
    width: 48px;
    height: 48px;
    border-radius: 12px;
    display: flex;
    align-items: center;
    justify-content: center;
    background: color-mix(in srgb, var(--text-main) 8%, var(--card-bg));
    border: 1px solid var(--border-color);
    flex-shrink: 0;
}

.provider-tile__icon-wrap i {
    font-size: 1.35rem;
}

.provider-tile__status {
    display: inline-flex;
    align-items: center;
    gap: 0.3rem;
    margin-top: 0.25rem;
    font-size: 0.72rem;
    font-weight: 700;
    letter-spacing: 0.04em;
    text-transform: uppercase;
    padding: 0.2rem 0.55rem;
    border-radius: 999px;
}

.provider-tile__status--on {
    background: color-mix(in srgb, #22c55e 22%, var(--card-bg));
    color: #86efac;
    border: 1px solid rgba(34, 197, 94, 0.35);
}

body.theme-light .provider-tile__status--on {
    color: #166534;
    background: #dcfce7;
    border-color: #86efac;
}

.provider-tile__status--off {
    background: color-mix(in srgb, var(--text-main) 10%, var(--card-bg));
    color: var(--text-sec);
    border: 1px solid var(--border-color);
}

.provider-tile .btn {
    border-radius: 10px;
    font-weight: 600;
}

body.theme-dark .provider-tile__icon-wrap .fa-github {
    color: #c9d1d9 !important;
}

/* Admin: Google Drive file list (provider show page) */
#adminAppBody .provider-drive-file-item {
    transition: background 0.2s ease;
}

@media (max-width: 767.98px) {
    #adminAppBody .provider-drive-toolbar-actions > .btn,
    #adminAppBody .provider-drive-toolbar-actions > a.btn,
    #adminAppBody .provider-drive-toolbar-actions > form {
        width: 100%;
    }

    #adminAppBody .provider-drive-toolbar-actions form.d-flex {
        flex-direction: column;
        align-items: stretch;
    }

    #adminAppBody .provider-drive-toolbar-actions form .btn,
    #adminAppBody .provider-drive-toolbar-actions form label.btn {
        width: 100%;
        justify-content: center;
    }

    #adminAppBody .provider-drive-file-actions {
        width: 100%;
        justify-content: flex-end;
        border-top: 1px solid var(--border-color);
        margin-top: 0.5rem;
        padding-top: 0.75rem;
    }
}

/* =========================================================
   MOBILE — profile, public user, subscription, providers
========================================================= */
@media (max-width: 767.98px) {
    .profile-page-header__lead {
        font-size: 0.9rem;
    }

    .profile-page-header__links {
        flex-direction: column;
        align-items: stretch;
    }

    .profile-page-header__links a {
        justify-content: center;
        width: 100%;
        text-align: center;
    }

    .profile-card-main .card-body.p-4,
    .profile-card-main .card-body.p-md-5 {
        padding-left: 1rem !important;
        padding-right: 1rem !important;
        padding-top: 1.15rem !important;
        padding-bottom: 1.15rem !important;
    }

    .profile-section__title {
        font-size: 0.8rem;
        letter-spacing: 0.04em;
    }

    .profile-section__icon {
        width: 2rem;
        height: 2rem;
        font-size: 0.85rem;
    }

    .profile-photo-wrap__avatar img {
        width: 96px;
        height: 96px;
    }

    .profile-photo-wrap__upload {
        padding: 0.85rem 1rem;
    }

    .profile-actions-bar {
        flex-direction: column-reverse;
        align-items: stretch !important;
        gap: 0.75rem;
    }

    .profile-actions-bar .btn,
    .profile-actions-bar form .btn {
        width: 100%;
        justify-content: center;
    }

    .membership-pill {
        font-size: 0.65rem;
        padding: 0.32rem 0.75rem;
        letter-spacing: 0.04em;
    }

    .profile-membership-card .btn {
        width: 100%;
    }

    .client-user-hero {
        text-align: center;
    }

    .client-user-hero .client-user-hero__meta {
        align-items: center !important;
        text-align: center;
        width: 100%;
    }

    .client-user-hero .client-user-hero__stats {
        justify-content: center;
    }

    .user-profile-body {
        padding-left: 1rem;
        padding-right: 1rem;
    }

    .user-profile-identity {
        text-align: center;
    }

    .user-profile-info {
        align-items: center !important;
        text-align: center;
        width: 100%;
    }

    .user-profile-meta {
        flex-direction: column;
        align-items: center;
        gap: 0.15rem;
    }

    .user-profile-meta__primary {
        justify-content: center;
    }

    .user-profile-stats {
        grid-template-columns: 1fr 1fr;
    }

    .client-comment-row {
        flex-direction: column !important;
        align-items: stretch !important;
    }

    .client-comment-row__side {
        flex-direction: row !important;
        align-items: center !important;
        justify-content: space-between !important;
        width: 100% !important;
        margin-top: 0.65rem;
    }

    .client-comment-row__side form .btn {
        white-space: nowrap;
    }

    .subscription-page__head {
        flex-direction: column !important;
        align-items: stretch !important;
    }

    .subscription-page__head .btn {
        width: 100%;
    }

    .subscription-page__lead {
        font-size: 0.875rem;
        line-height: 1.45;
    }

    .provider-tile .card-body {
        flex-direction: row !important;
        align-items: center !important;
        padding: 0.55rem 0.65rem;
        gap: 0.5rem;
    }

    .provider-tile__icon-wrap {
        width: 34px;
        height: 34px;
        border-radius: 8px;
    }

    .provider-tile__icon-wrap i {
        font-size: 0.95rem;
    }

    .provider-tile__label {
        font-size: 0.82rem;
    }

    .provider-tile__status {
        font-size: 0.62rem;
        padding: 0.12rem 0.4rem;
        margin-top: 0.15rem;
    }

    .provider-tile__action {
        width: auto;
    }

    .provider-tile .card-body .btn,
    .provider-tile .card-body a.btn {
        width: auto;
        font-size: 0.72rem;
        padding: 0.22rem 0.55rem;
        white-space: nowrap;
    }

    .input-group .btn {
        min-width: 2.75rem;
        flex-shrink: 0;
    }
}

@media (max-width: 575.98px) {
    .profile-page-header__title {
        font-size: 1.35rem;
        line-height: 1.25;
    }

    .client-user-hero__avatar {
        margin-left: auto;
        margin-right: auto;
    }

    .user-profile-avatar-wrap {
        margin-left: auto;
        margin-right: auto;
    }

    .user-profile-banner {
        height: 110px;
    }

    .user-profile-body {
        margin-top: -56px;
    }

    .user-profile-avatar,
    .user-profile-avatar-wrap {
        width: 108px;
        height: 108px;
    }
}

/* =========================================================
   SWEETALERT THEME SUPPORT
========================================================= */

.swal2-popup {
    background: var(--card-bg) !important;
    color: var(--text-main) !important;
    border: 1px solid var(--border-color);
    border-radius: 12px;
}

.swal2-title {
    color: var(--text-main) !important;
}

.swal2-html-container {
    color: var(--text-sec) !important;
}

.swal2-confirm {
    background-color: transparent !important;
    color: var(--text-main) !important;
    border: 1px solid var(--border-color) !important;
    padding: 8px 16px;
    border-radius: 8px;
}

.swal2-confirm:hover {
    background-color: rgba(255, 255, 255, 0.08) !important;
}

body.theme-light .swal2-confirm:hover {
    background-color: rgba(0, 0, 0, 0.06) !important;
}

.swal2-icon.swal2-success {
    border-color: #22c55e !important;
    color: #22c55e !important;
}

.swal2-icon.swal2-error {
    border-color: #ef4444 !important;
    color: #ef4444 !important;
}

.swal2-icon.swal2-warning {
    border-color: #facc15 !important;
    color: #facc15 !important;
}

/* =========================================================
   ADMIN PANEL (AdminLTE + theme-dark / theme-light)
   Same theme keys as client: body.theme-dark | body.theme-light
========================================================= */

#adminAppBody {
    background-color: var(--bg-color);
    color: var(--text-main);

    /* Bootstrap 5 dropdowns (bulk actions, etc.) — follow theme */
    --bs-dropdown-bg: var(--card-bg);
    --bs-dropdown-color: var(--text-main);
    --bs-dropdown-border-color: var(--border-color);
    --bs-dropdown-box-shadow: 0 0.5rem 1.25rem
        color-mix(in srgb, #000 45%, transparent);
    --bs-dropdown-link-color: var(--text-main);
    --bs-dropdown-link-hover-color: var(--text-main);
    --bs-dropdown-link-hover-bg: color-mix(
        in srgb,
        var(--text-main) 12%,
        transparent
    );
    --bs-dropdown-link-active-color: var(--text-main);
    --bs-dropdown-link-active-bg: color-mix(
        in srgb,
        var(--text-main) 20%,
        transparent
    );
    --bs-dropdown-link-disabled-color: color-mix(
        in srgb,
        var(--text-main) 45%,
        transparent
    );
    --bs-dropdown-header-color: var(--text-sec);
    --bs-dropdown-divider-bg: var(--border-color);
}

#adminAppBody.theme-light {
    --bs-dropdown-box-shadow: 0 0.5rem 1rem rgba(0, 0, 0, 0.12);
    --bs-dropdown-link-hover-bg: rgba(0, 0, 0, 0.06);
    --bs-dropdown-link-active-bg: rgba(0, 0, 0, 0.09);
}

/* Ensure menu & items follow theme even when CDN CSS order differs */
#adminAppBody .dropdown-menu {
    background-color: var(--bs-dropdown-bg) !important;
    color: var(--bs-dropdown-color) !important;
    border-color: var(--bs-dropdown-border-color) !important;
}

#adminAppBody .dropdown-item {
    color: var(--bs-dropdown-link-color) !important;
}

#adminAppBody .dropdown-item:hover,
#adminAppBody .dropdown-item:focus {
    color: var(--bs-dropdown-link-hover-color) !important;
    background-color: var(--bs-dropdown-link-hover-bg) !important;
}

#adminAppBody .dropdown-item.active,
#adminAppBody .dropdown-item:active {
    color: var(--bs-dropdown-link-active-color) !important;
    background-color: var(--bs-dropdown-link-active-bg) !important;
}

#adminAppBody .dropdown-header {
    color: var(--bs-dropdown-header-color) !important;
}

#adminAppBody .dropdown-divider {
    border-top-color: var(--bs-dropdown-divider-bg) !important;
    opacity: 1;
}

#adminAppBody .dropdown-item.text-danger {
    color: #f87171 !important;
}

#adminAppBody.theme-light .dropdown-item.text-danger {
    color: #dc2626 !important;
}

#adminAppBody .dropdown-item.text-danger:hover,
#adminAppBody .dropdown-item.text-danger:focus {
    color: #fff !important;
    background-color: rgba(220, 38, 38, 0.85) !important;
}

#adminAppBody.theme-light .dropdown-item.text-danger:hover,
#adminAppBody.theme-light .dropdown-item.text-danger:focus {
    color: #fff !important;
    background-color: #dc2626 !important;
}

/* Outline secondary (bulk dropdown, search/filter toolbar, etc.) — use --bs-btn-* so AdminLTE does not force white */
#adminAppBody .btn-outline-secondary {
    --bs-btn-color: var(--text-main);
    --bs-btn-border-color: var(--border-color);
    --bs-btn-bg: transparent;
    --bs-btn-hover-color: var(--text-main);
    --bs-btn-hover-bg: color-mix(
        in srgb,
        var(--card-bg) 70%,
        var(--text-main) 30%
    );
    --bs-btn-hover-border-color: var(--border-color);
    --bs-btn-active-color: var(--text-main);
    --bs-btn-active-bg: color-mix(
        in srgb,
        var(--card-bg) 62%,
        var(--text-main) 38%
    );
    --bs-btn-active-border-color: var(--border-color);
    --bs-btn-disabled-color: color-mix(
        in srgb,
        var(--text-main) 45%,
        transparent
    );
    --bs-btn-disabled-bg: transparent;
    --bs-btn-disabled-border-color: var(--border-color);

    color: var(--text-main) !important;
    border-color: var(--border-color) !important;
    background-color: transparent !important;
}

#adminAppBody .btn-outline-secondary:hover,
#adminAppBody .btn-outline-secondary:focus {
    color: var(--text-main) !important;
    background-color: color-mix(
        in srgb,
        var(--card-bg) 70%,
        var(--text-main) 30%
    ) !important;
    border-color: var(--border-color) !important;
}

#adminAppBody.theme-light .btn-outline-secondary {
    --bs-btn-hover-bg: #e9ecef;
    --bs-btn-active-bg: #dee2e6;
}

#adminAppBody.theme-light .btn-outline-secondary:hover,
#adminAppBody.theme-light .btn-outline-secondary:focus {
    background-color: #e9ecef !important;
    color: #212529 !important;
    border-color: var(--border-color) !important;
}

/* Select2 (admin filters) — dropdown is often appended to body */
#adminAppBody .select2-container--bootstrap-5 .select2-selection {
    background-color: var(--card-bg) !important;
    border-color: var(--border-color) !important;
    color: var(--text-main) !important;
}

#adminAppBody .select2-container--bootstrap-5 .select2-selection__rendered {
    color: var(--text-main) !important;
}

#adminAppBody .select2-container--bootstrap-5 .select2-selection__placeholder {
    color: var(--text-sec) !important;
}

#adminAppBody .select2-container--bootstrap-5 .select2-dropdown {
    background-color: var(--card-bg) !important;
    border-color: var(--border-color) !important;
}

#adminAppBody .select2-container--bootstrap-5 .select2-results__option {
    color: var(--text-main) !important;
    background-color: var(--card-bg) !important;
}

#adminAppBody
    .select2-container--bootstrap-5
    .select2-results__option--highlighted {
    background-color: var(--bs-dropdown-link-hover-bg) !important;
    color: var(--text-main) !important;
}

#adminAppBody
    .select2-container--bootstrap-5
    .select2-results__option--selected {
    background-color: color-mix(
        in srgb,
        var(--link-accent) 28%,
        var(--card-bg)
    ) !important;
    color: var(--text-main) !important;
}

#adminAppBody
    .select2-container--bootstrap-5
    .select2-search--dropdown
    .select2-search__field {
    background-color: var(--card-bg) !important;
    border-color: var(--border-color) !important;
    color: var(--text-main) !important;
}

#adminAppBody
    .select2-container--bootstrap-5
    .select2-selection--single
    .select2-selection__arrow
    b {
    border-color: var(--text-main) transparent transparent transparent !important;
}

#adminAppBody .wrapper {
    background-color: var(--bg-color);
}

#adminAppBody .content-wrapper {
    background-color: var(--bg-color) !important;
}

#adminAppBody .content-header h1 {
    color: var(--text-main) !important;
}

/* Admin breadcrumb — divider & links readable in dark/light (including Google Drive trail) */
#adminAppBody .breadcrumb {
    --bs-breadcrumb-divider-color: color-mix(
        in srgb,
        var(--text-sec) 65%,
        var(--border-color)
    );
    background-color: transparent;
}

#adminAppBody .breadcrumb-item.active {
    color: var(--text-main) !important;
}

#adminAppBody nav.provider-drive-breadcrumb .breadcrumb-item.active {
    color: var(--text-sec) !important;
}

#adminAppBody.theme-light .breadcrumb-item a {
    color: var(--link-accent) !important;
}

#adminAppBody.theme-light .breadcrumb-item a:hover,
#adminAppBody.theme-light .breadcrumb-item a:focus {
    color: #4c1d95 !important;
    text-decoration: underline;
}

#adminAppBody:not(.theme-light) .breadcrumb-item a {
    color: var(--link-accent) !important;
}

#adminAppBody:not(.theme-light) .breadcrumb-item a:hover,
#adminAppBody:not(.theme-light) .breadcrumb-item a:focus {
    color: #e9d5ff !important;
    text-decoration: underline;
}

/* Google Drive — folder breadcrumb slightly elevated in dark mode */
#adminAppBody:not(.theme-light) nav.provider-drive-breadcrumb .breadcrumb {
    padding: 0.4rem 0.75rem;
    border-radius: 0.375rem;
    border: 1px solid var(--border-color);
    background-color: color-mix(
        in srgb,
        var(--card-bg) 88%,
        var(--text-main) 12%
    );
}

#adminAppBody.theme-light nav.provider-drive-breadcrumb .breadcrumb {
    padding: 0.4rem 0.75rem;
    border-radius: 0.375rem;
    border: 1px solid
        color-mix(in srgb, var(--border-color) 85%, var(--text-main) 15%);
    background-color: color-mix(in srgb, #ffffff 92%, var(--text-main) 8%);
}

/* Drive toolbar: Clone = admin primary (not default bright BS blue outside table cards) */
#adminAppBody.theme-light .provider-drive-toolbar-actions .btn.btn-primary {
    color: #1e3a8a !important;
    background-color: #dbeafe !important;
    border-color: #3b82f6 !important;
}

#adminAppBody.theme-light
    .provider-drive-toolbar-actions
    .btn.btn-primary:hover,
#adminAppBody.theme-light
    .provider-drive-toolbar-actions
    .btn.btn-primary:focus {
    background-color: #bfdbfe !important;
    color: #1e3a8a !important;
    border-color: #2563eb !important;
}

#adminAppBody:not(.theme-light)
    .provider-drive-toolbar-actions
    .btn.btn-primary {
    color: #eff6ff !important;
    background-color: #1e40af !important;
    border-color: #3b82f6 !important;
}

#adminAppBody:not(.theme-light)
    .provider-drive-toolbar-actions
    .btn.btn-primary:hover,
#adminAppBody:not(.theme-light)
    .provider-drive-toolbar-actions
    .btn.btn-primary:focus {
    background-color: #2563eb !important;
    color: #fff !important;
    border-color: #60a5fa !important;
}

/* Drive toolbar: Export — same success palette as Excel in admin-table-actions */
#adminAppBody.theme-light .provider-drive-toolbar-actions .btn.btn-success,
#adminAppBody.theme-light .provider-drive-toolbar-actions a.btn.btn-success {
    color: #065f46 !important;
    background-color: #d1fae5 !important;
    border-color: #34d399 !important;
}

#adminAppBody.theme-light
    .provider-drive-toolbar-actions
    .btn.btn-success:hover,
#adminAppBody.theme-light
    .provider-drive-toolbar-actions
    .btn.btn-success:focus,
#adminAppBody.theme-light
    .provider-drive-toolbar-actions
    a.btn.btn-success:hover,
#adminAppBody.theme-light
    .provider-drive-toolbar-actions
    a.btn.btn-success:focus {
    background-color: #a7f3d0 !important;
    color: #064e3b !important;
    border-color: #10b981 !important;
}

#adminAppBody:not(.theme-light)
    .provider-drive-toolbar-actions
    .btn.btn-success,
#adminAppBody:not(.theme-light)
    .provider-drive-toolbar-actions
    a.btn.btn-success,
#adminAppBody:not(.theme-light)
    .provider-drive-toolbar-actions
    .btn.btn-success.text-white,
#adminAppBody:not(.theme-light)
    .provider-drive-toolbar-actions
    a.btn.btn-success.text-white {
    color: #ecfdf5 !important;
    background-color: #047857 !important;
    border-color: #10b981 !important;
}

#adminAppBody:not(.theme-light)
    .provider-drive-toolbar-actions
    .btn.btn-success:hover,
#adminAppBody:not(.theme-light)
    .provider-drive-toolbar-actions
    .btn.btn-success:focus,
#adminAppBody:not(.theme-light)
    .provider-drive-toolbar-actions
    a.btn.btn-success:hover,
#adminAppBody:not(.theme-light)
    .provider-drive-toolbar-actions
    a.btn.btn-success:focus {
    background-color: #059669 !important;
    color: #fff !important;
    border-color: #34d399 !important;
}

#adminAppBody .content .card,
#adminAppBody .card-outline {
    background-color: var(--card-bg) !important;
    color: var(--text-main);
    border-color: var(--border-color) !important;
}

/* card-outline primary (DB export, etc.) — soft accent, not harsh AdminLTE blue */
#adminAppBody .card.card-outline.card-primary {
    border-top: 3px solid
        color-mix(in srgb, var(--link-accent) 45%, var(--border-color)) !important;
}

#adminAppBody .card-header {
    background-color: color-mix(
        in srgb,
        var(--card-bg) 92%,
        var(--text-main) 8%
    ) !important;
    color: var(--text-main) !important;
    border-bottom-color: var(--border-color) !important;
}

#adminAppBody .table {
    color: var(--text-main);
    --bs-table-bg: transparent;
}

#adminAppBody .table-bordered {
    border-color: var(--border-color) !important;
}

#adminAppBody .table-bordered th,
#adminAppBody .table-bordered td {
    border-color: var(--border-color) !important;
}

#adminAppBody .table-striped > tbody > tr:nth-of-type(odd) > * {
    --bs-table-accent-bg: color-mix(
        in srgb,
        var(--card-bg) 85%,
        var(--text-main) 15%
    );
    color: var(--text-main);
}

#adminAppBody .table-secondary {
    --bs-table-bg: color-mix(in srgb, var(--card-bg) 75%, var(--text-main) 25%);
    color: var(--text-main);
}

#adminAppBody .form-control,
#adminAppBody .form-select {
    background-color: var(--card-bg);
    color: var(--text-main);
    border-color: var(--border-color);
}

#adminAppBody .form-control:focus,
#adminAppBody .form-select:focus {
    background-color: var(--card-bg);
    color: var(--text-main);
    border-color: var(--link-accent);
    box-shadow: 0 0 0 0.2rem
        color-mix(in srgb, var(--link-accent) 25%, transparent);
}

#adminAppBody .input-group-text {
    background-color: color-mix(
        in srgb,
        var(--card-bg) 90%,
        var(--text-main) 10%
    );
    color: var(--text-main);
    border-color: var(--border-color);
}

#adminAppBody .modal-content {
    background-color: var(--card-bg);
    color: var(--text-main);
    border: 1px solid var(--border-color);
}

#adminAppBody .modal-header,
#adminAppBody .modal-footer {
    border-color: var(--border-color) !important;
}

/* Modal header: × button (.close legacy AdminLTE/BS4) — contrast in dark mode */
#adminAppBody .modal .modal-header .close {
    background: transparent;
    border: 0;
    font-size: 1.35rem;
    font-weight: 300;
    line-height: 1;
    padding: 0.25rem 0.5rem;
    margin: 0;
}

#adminAppBody.theme-light .modal .modal-header .close {
    color: #4b5563 !important;
    opacity: 1;
    text-shadow: none;
}

#adminAppBody.theme-light .modal .modal-header .close:hover,
#adminAppBody.theme-light .modal .modal-header .close:focus {
    color: #111827 !important;
}

#adminAppBody:not(.theme-light) .modal .modal-header .close {
    color: #e5e7eb !important;
    opacity: 0.92;
    text-shadow: none;
}

#adminAppBody:not(.theme-light) .modal .modal-header .close:hover,
#adminAppBody:not(.theme-light) .modal .modal-header .close:focus {
    color: #ffffff !important;
    opacity: 1;
}

/* btn-close (BS5) in modal — match dark card background */
#adminAppBody:not(.theme-light) .modal .btn-close {
    filter: invert(1) brightness(1.1);
    opacity: 0.9;
}

#adminAppBody:not(.theme-light) .modal .btn-close:hover,
#adminAppBody:not(.theme-light) .modal .btn-close:focus {
    opacity: 1;
    filter: invert(1) brightness(1.25);
}

#adminAppBody.theme-light .modal .btn-close {
    filter: none;
    opacity: 0.72;
}

#adminAppBody.theme-light .modal .btn-close:hover,
#adminAppBody.theme-light .modal .btn-close:focus {
    opacity: 1;
}

/* Modal footer: Close/Cancel, Save, Import (success), delete — match admin theme */
#adminAppBody.theme-light .modal-footer .btn.btn-secondary {
    color: #374151 !important;
    background-color: #f3f4f6 !important;
    border-color: #9ca3af !important;
}

#adminAppBody.theme-light .modal-footer .btn.btn-secondary:hover {
    background-color: #e5e7eb !important;
    color: #111827 !important;
    border-color: #6b7280 !important;
}

#adminAppBody.theme-light .modal-footer .btn.btn-primary {
    color: #1e3a8a !important;
    background-color: #dbeafe !important;
    border-color: #3b82f6 !important;
}

#adminAppBody.theme-light .modal-footer .btn.btn-primary:hover {
    background-color: #bfdbfe !important;
    color: #1e3a8a !important;
    border-color: #2563eb !important;
}

#adminAppBody.theme-light .modal-footer .btn.btn-success,
#adminAppBody.theme-light .modal-footer a.btn.btn-success {
    color: #065f46 !important;
    background-color: #d1fae5 !important;
    border-color: #34d399 !important;
}

#adminAppBody.theme-light .modal-footer .btn.btn-success:hover,
#adminAppBody.theme-light .modal-footer a.btn.btn-success:hover {
    background-color: #a7f3d0 !important;
    color: #064e3b !important;
    border-color: #10b981 !important;
}

#adminAppBody.theme-light .modal-footer .btn.btn-danger {
    color: #991b1b !important;
    background-color: #fef2f2 !important;
    border-color: #ef4444 !important;
}

#adminAppBody.theme-light .modal-footer .btn.btn-danger:hover {
    background-color: #fee2e2 !important;
    color: #7f1d1d !important;
    border-color: #dc2626 !important;
}

#adminAppBody:not(.theme-light) .modal-footer .btn.btn-secondary {
    color: #f9fafb !important;
    background-color: #4b5563 !important;
    border-color: #6b7280 !important;
}

#adminAppBody:not(.theme-light) .modal-footer .btn.btn-secondary:hover {
    background-color: #6b7280 !important;
    color: #fff !important;
}

#adminAppBody:not(.theme-light) .modal-footer .btn.btn-primary {
    color: #eff6ff !important;
    background-color: #1e40af !important;
    border-color: #3b82f6 !important;
}

#adminAppBody:not(.theme-light) .modal-footer .btn.btn-primary:hover {
    background-color: #2563eb !important;
    color: #fff !important;
}

#adminAppBody:not(.theme-light) .modal-footer .btn.btn-success,
#adminAppBody:not(.theme-light) .modal-footer a.btn.btn-success {
    color: #ecfdf5 !important;
    background-color: #047857 !important;
    border-color: #10b981 !important;
}

#adminAppBody:not(.theme-light) .modal-footer .btn.btn-success:hover,
#adminAppBody:not(.theme-light) .modal-footer a.btn.btn-success:hover {
    background-color: #059669 !important;
    color: #fff !important;
}

#adminAppBody:not(.theme-light) .modal-footer .btn.btn-danger {
    color: #fef2f2 !important;
    background-color: #991b1b !important;
    border-color: #ef4444 !important;
}

#adminAppBody:not(.theme-light) .modal-footer .btn.btn-danger:hover {
    background-color: #b91c1c !important;
    color: #fff !important;
}

/* File input: filename text + “Choose file” button follow theme */
#adminAppBody .form-control[type="file"] {
    color: var(--text-main);
}

#adminAppBody .form-control[type="file"]::file-selector-button,
#adminAppBody .form-control[type="file"]::-webkit-file-upload-button {
    font: inherit;
    font-weight: 600;
    font-size: 0.8125rem;
    line-height: 1.4;
    cursor: pointer;
    margin-right: 0.75rem;
    padding: 0.4rem 0.75rem;
    border-radius: 0.35rem;
    border: 1px solid var(--border-color);
    transition: background-color 0.15s ease, color 0.15s ease,
        border-color 0.15s ease;
}

#adminAppBody.theme-light .form-control[type="file"]::file-selector-button,
#adminAppBody.theme-light
    .form-control[type="file"]::-webkit-file-upload-button {
    background-color: #e5e7eb;
    color: #1f2937;
    border-color: #9ca3af;
}

#adminAppBody.theme-light
    .form-control[type="file"]:hover::file-selector-button,
#adminAppBody.theme-light
    .form-control[type="file"]:hover::-webkit-file-upload-button {
    background-color: #d1d5db;
    color: #111827;
    border-color: #6b7280;
}

#adminAppBody:not(.theme-light)
    .form-control[type="file"]::file-selector-button,
#adminAppBody:not(.theme-light)
    .form-control[type="file"]::-webkit-file-upload-button {
    background-color: #374151;
    color: #f9fafb;
    border-color: #6b7280;
}

#adminAppBody:not(.theme-light)
    .form-control[type="file"]:hover::file-selector-button,
#adminAppBody:not(.theme-light)
    .form-control[type="file"]:hover::-webkit-file-upload-button {
    background-color: #4b5563;
    color: #fff;
    border-color: #9ca3af;
}

#adminAppBody .form-control-sm[type="file"]::file-selector-button,
#adminAppBody .form-control-sm[type="file"]::-webkit-file-upload-button {
    font-size: 0.78rem;
    padding: 0.3rem 0.55rem;
    margin-right: 0.5rem;
}

/* Image preview in create/edit modal + default.png (small, consistent with 96px thumbnail) */
#adminAppBody .modal .admin-modal-media-preview {
    max-width: 96px !important;
    max-height: 96px !important;
    width: auto !important;
    height: auto !important;
    object-fit: contain;
    display: block;
    margin-left: auto;
    margin-right: auto;
}

#adminAppBody .modal .admin-modal-current-thumb img {
    display: block;
}

#adminAppBody .btn-close {
    filter: invert(1);
}

#adminAppBody.theme-light .btn-close {
    filter: none;
}

#adminAppBody .main-footer {
    background-color: var(--card-bg) !important;
    border-top: 1px solid var(--border-color) !important;
    color: var(--text-sec) !important;
}

#adminAppBody .main-footer a {
    color: var(--link-accent) !important;
}

/* Top navbar */
#adminAppBody .admin-top-navbar {
    background-color: var(--card-bg) !important;
    border-bottom: 1px solid var(--border-color) !important;
}

#adminAppBody .admin-top-navbar .navbar-nav .nav-link {
    color: var(--text-main) !important;
}

#adminAppBody .admin-top-navbar .navbar-nav .nav-link:hover {
    background-color: color-mix(in srgb, var(--text-main) 8%, transparent);
}

#adminAppBody.theme-light .admin-top-navbar .navbar-nav .nav-link:hover {
    background-color: rgba(0, 0, 0, 0.05);
}

#adminAppBody .admin-navbar-user-name {
    color: var(--text-main) !important;
}

#adminAppBody .admin-theme-toggle {
    color: var(--text-main) !important;
    text-decoration: none !important;
}

#adminAppBody .admin-theme-toggle:hover {
    color: var(--link-accent) !important;
}

/* Sidebar — dark: neutral charcoal (no blue); light: soft gray */
#adminAppBody:not(.theme-light) .main-sidebar {
    background-color: #141414 !important;
    border-right: 1px solid var(--border-color);
}

#adminAppBody.theme-light .main-sidebar {
    background-color: #f1f3f5 !important;
    border-right: 1px solid var(--border-color);
}

#adminAppBody .main-sidebar .brand-link {
    border-bottom: 1px solid var(--border-color) !important;
}

#adminAppBody.theme-light .main-sidebar .brand-link {
    border-bottom: 1px solid var(--border-color) !important;
}

#adminAppBody:not(.theme-light) .main-sidebar .brand-text,
#adminAppBody:not(.theme-light) .main-sidebar .nav-header,
#adminAppBody:not(.theme-light) .main-sidebar .nav-link {
    color: rgba(255, 255, 255, 0.88) !important;
}

#adminAppBody.theme-light .main-sidebar .brand-text,
#adminAppBody.theme-light .main-sidebar .nav-header,
#adminAppBody.theme-light .main-sidebar .nav-link {
    color: #212529 !important;
}

#adminAppBody .main-sidebar .nav-icon {
    color: inherit !important;
}

#adminAppBody:not(.theme-light) .main-sidebar .nav-link:hover {
    background-color: rgba(255, 255, 255, 0.06) !important;
}

#adminAppBody.theme-light .main-sidebar .nav-link:hover {
    background-color: rgba(0, 0, 0, 0.05) !important;
}

/* Custom active class (blade) — neutral highlight, not primary blue */
#adminAppBody:not(.theme-light) .main-sidebar .nav-link.aktif {
    background-color: rgba(255, 255, 255, 0.1) !important;
    color: #fff !important;
    box-shadow: inset 3px 0 0 rgba(255, 255, 255, 0.35);
}

#adminAppBody.theme-light .main-sidebar .nav-link.aktif {
    background-color: rgba(0, 0, 0, 0.07) !important;
    color: #111 !important;
    box-shadow: inset 3px 0 0 rgba(0, 0, 0, 0.35);
}

#adminAppBody:not(.theme-light) .main-sidebar .nav-treeview {
    background-color: rgba(0, 0, 0, 0.22) !important;
}

#adminAppBody.theme-light .main-sidebar .nav-treeview {
    background-color: rgba(0, 0, 0, 0.03) !important;
}

#adminAppBody:not(.theme-light) .main-sidebar .nav-treeview .nav-link {
    color: rgba(255, 255, 255, 0.82) !important;
}

#adminAppBody.theme-light .main-sidebar .nav-treeview .nav-link {
    color: #343a40 !important;
}

#adminAppBody:not(.theme-light) .main-sidebar .nav-treeview .nav-link.aktif {
    background-color: rgba(255, 255, 255, 0.08) !important;
    box-shadow: inset 3px 0 0 rgba(255, 255, 255, 0.3);
}

#adminAppBody.theme-light .main-sidebar .nav-treeview .nav-link.aktif {
    background-color: rgba(0, 0, 0, 0.06) !important;
    box-shadow: inset 3px 0 0 rgba(0, 0, 0, 0.25);
}

/* AdminLTE: remove default blue on .nav-link.active / menu-open */
#adminAppBody:not(.theme-light)
    .main-sidebar
    .nav-sidebar
    .nav-item
    > .nav-link.active,
#adminAppBody:not(.theme-light) .main-sidebar .nav-sidebar .nav-link.active {
    background-color: transparent !important;
    color: rgba(255, 255, 255, 0.88) !important;
}

#adminAppBody:not(.theme-light)
    .main-sidebar
    .nav-sidebar
    .menu-open
    > .nav-link,
#adminAppBody:not(.theme-light)
    .main-sidebar
    .nav-sidebar
    .menu-is-opening
    > .nav-link {
    background-color: rgba(255, 255, 255, 0.06) !important;
    color: rgba(255, 255, 255, 0.92) !important;
}

/* Admin CRUD tables (components/table-layout — .admin-table-bulk-scope) */
#adminAppBody .admin-table-bulk-scope .table code {
    color: var(--link-accent);
    background-color: color-mix(
        in srgb,
        var(--card-bg) 75%,
        var(--text-main) 25%
    );
    padding: 0.15em 0.45em;
    border-radius: 0.25rem;
    font-size: 0.9em;
    border: 1px solid var(--border-color);
}

#adminAppBody .admin-table-bulk-scope .table a:not(.btn):not(.page-link) {
    color: var(--link-accent);
}

#adminAppBody .admin-table-bulk-scope .badge,
#adminAppBody .content .list-group .badge {
    border: 1px solid color-mix(in srgb, var(--border-color) 70%, transparent);
    font-weight: 600;
}

/* Bootstrap / AdminLTE badges in admin tables & lists — soft (light) & readable (dark) */
#adminAppBody.theme-light .admin-table-bulk-scope .badge.bg-primary,
#adminAppBody.theme-light .content .list-group .badge.bg-primary,
#adminAppBody.theme-light .admin-table-bulk-scope .badge.badge-primary,
#adminAppBody.theme-light .content .list-group .badge.badge-primary {
    background-color: #dbeafe !important;
    color: #1e40af !important;
    border-color: color-mix(in srgb, #3b82f6 35%, transparent) !important;
}

#adminAppBody.theme-light .admin-table-bulk-scope .badge.bg-secondary,
#adminAppBody.theme-light .content .list-group .badge.bg-secondary,
#adminAppBody.theme-light .admin-table-bulk-scope .badge.badge-secondary,
#adminAppBody.theme-light .content .list-group .badge.badge-secondary {
    background-color: #f3f4f6 !important;
    color: #4b5563 !important;
    border-color: color-mix(in srgb, #9ca3af 45%, transparent) !important;
}

#adminAppBody.theme-light .admin-table-bulk-scope .badge.bg-success,
#adminAppBody.theme-light .content .list-group .badge.bg-success,
#adminAppBody.theme-light .admin-table-bulk-scope .badge.badge-success,
#adminAppBody.theme-light .content .list-group .badge.badge-success {
    background-color: #d1fae5 !important;
    color: #065f46 !important;
    border-color: color-mix(in srgb, #34d399 40%, transparent) !important;
}

#adminAppBody.theme-light .admin-table-bulk-scope .badge.bg-danger,
#adminAppBody.theme-light .content .list-group .badge.bg-danger,
#adminAppBody.theme-light .admin-table-bulk-scope .badge.badge-danger,
#adminAppBody.theme-light .content .list-group .badge.badge-danger {
    background-color: #fee2e2 !important;
    color: #991b1b !important;
    border-color: color-mix(in srgb, #f87171 40%, transparent) !important;
}

#adminAppBody.theme-light .admin-table-bulk-scope .badge.bg-warning,
#adminAppBody.theme-light .content .list-group .badge.bg-warning,
#adminAppBody.theme-light .admin-table-bulk-scope .badge.badge-warning,
#adminAppBody.theme-light .content .list-group .badge.badge-warning {
    background-color: #fef3c7 !important;
    color: #92400e !important;
    border-color: color-mix(in srgb, #fbbf24 45%, transparent) !important;
}

#adminAppBody.theme-light .admin-table-bulk-scope .badge.bg-info,
#adminAppBody.theme-light .content .list-group .badge.bg-info,
#adminAppBody.theme-light .admin-table-bulk-scope .badge.badge-info,
#adminAppBody.theme-light .content .list-group .badge.badge-info {
    background-color: #cffafe !important;
    color: #155e75 !important;
    border-color: color-mix(in srgb, #22d3ee 40%, transparent) !important;
}

#adminAppBody.theme-light .admin-table-bulk-scope .badge.bg-dark,
#adminAppBody.theme-light .content .list-group .badge.bg-dark,
#adminAppBody.theme-light .admin-table-bulk-scope .badge.badge-dark,
#adminAppBody.theme-light .content .list-group .badge.badge-dark {
    background-color: #374151 !important;
    color: #f9fafb !important;
    border-color: #4b5563 !important;
}

#adminAppBody.theme-light .admin-table-bulk-scope .badge.bg-warning.text-dark,
#adminAppBody.theme-light .content .list-group .badge.bg-warning.text-dark {
    color: #78350f !important;
}

#adminAppBody:not(.theme-light) .admin-table-bulk-scope .badge.bg-primary,
#adminAppBody:not(.theme-light) .content .list-group .badge.bg-primary,
#adminAppBody:not(.theme-light) .admin-table-bulk-scope .badge.badge-primary,
#adminAppBody:not(.theme-light) .content .list-group .badge.badge-primary {
    background-color: #1e3a8a !important;
    color: #dbeafe !important;
    border-color: #3b82f6 !important;
}

#adminAppBody:not(.theme-light) .admin-table-bulk-scope .badge.bg-secondary,
#adminAppBody:not(.theme-light) .content .list-group .badge.bg-secondary,
#adminAppBody:not(.theme-light) .admin-table-bulk-scope .badge.badge-secondary,
#adminAppBody:not(.theme-light) .content .list-group .badge.badge-secondary {
    background-color: #4b5563 !important;
    color: #f3f4f6 !important;
    border-color: #6b7280 !important;
}

#adminAppBody:not(.theme-light) .admin-table-bulk-scope .badge.bg-success,
#adminAppBody:not(.theme-light) .content .list-group .badge.bg-success,
#adminAppBody:not(.theme-light) .admin-table-bulk-scope .badge.badge-success,
#adminAppBody:not(.theme-light) .content .list-group .badge.badge-success {
    background-color: #047857 !important;
    color: #ecfdf5 !important;
    border-color: #10b981 !important;
}

#adminAppBody:not(.theme-light) .admin-table-bulk-scope .badge.bg-danger,
#adminAppBody:not(.theme-light) .content .list-group .badge.bg-danger,
#adminAppBody:not(.theme-light) .admin-table-bulk-scope .badge.badge-danger,
#adminAppBody:not(.theme-light) .content .list-group .badge.badge-danger {
    background-color: #991b1b !important;
    color: #fef2f2 !important;
    border-color: #ef4444 !important;
}

/* Warning badge/chip — same palette as .alert.alert-warning above table (video / video-report) */
#adminAppBody:not(.theme-light) .admin-table-bulk-scope .badge.bg-warning,
#adminAppBody:not(.theme-light) .content .list-group .badge.bg-warning,
#adminAppBody:not(.theme-light) .admin-table-bulk-scope .badge.badge-warning,
#adminAppBody:not(.theme-light) .content .list-group .badge.badge-warning {
    background-color: color-mix(
        in srgb,
        #78350f 30%,
        var(--card-bg)
    ) !important;
    color: #fde68a !important;
    border-color: color-mix(
        in srgb,
        #ca8a04 50%,
        var(--border-color)
    ) !important;
}

#adminAppBody:not(.theme-light)
    .admin-table-bulk-scope
    .badge.bg-warning.text-dark,
#adminAppBody:not(.theme-light)
    .content
    .list-group
    .badge.bg-warning.text-dark {
    color: #fef3c7 !important;
}

#adminAppBody:not(.theme-light)
    .admin-table-bulk-scope
    a.badge.bg-warning:hover,
#adminAppBody:not(.theme-light)
    .admin-table-bulk-scope
    a.badge.bg-warning:focus {
    background-color: color-mix(
        in srgb,
        #78350f 42%,
        var(--card-bg)
    ) !important;
    color: #fffbeb !important;
    border-color: color-mix(
        in srgb,
        #ca8a04 58%,
        var(--border-color)
    ) !important;
}

#adminAppBody:not(.theme-light) .admin-table-bulk-scope .badge.bg-info,
#adminAppBody:not(.theme-light) .content .list-group .badge.bg-info,
#adminAppBody:not(.theme-light) .admin-table-bulk-scope .badge.badge-info,
#adminAppBody:not(.theme-light) .content .list-group .badge.badge-info {
    background-color: #0e7490 !important;
    color: #ecfeff !important;
    border-color: #06b6d4 !important;
}

#adminAppBody:not(.theme-light) .admin-table-bulk-scope .badge.bg-dark,
#adminAppBody:not(.theme-light) .content .list-group .badge.bg-dark,
#adminAppBody:not(.theme-light) .admin-table-bulk-scope .badge.badge-dark,
#adminAppBody:not(.theme-light) .content .list-group .badge.badge-dark {
    background-color: #e5e7eb !important;
    color: #111827 !important;
    border-color: #d1d5db !important;
}

/* Total videos without links / Total problematic — alert above table */
#adminAppBody.theme-light .admin-table-bulk-scope .alert.alert-warning {
    color: #78350f !important;
    background-color: #fef3c7 !important;
    border-color: color-mix(
        in srgb,
        #f59e0b 42%,
        var(--border-color)
    ) !important;
}

#adminAppBody.theme-light .admin-table-bulk-scope .alert.alert-warning strong {
    color: #92400e !important;
}

#adminAppBody:not(.theme-light) .admin-table-bulk-scope .alert.alert-warning {
    color: #fde68a !important;
    background-color: color-mix(
        in srgb,
        #78350f 30%,
        var(--card-bg)
    ) !important;
    border-color: color-mix(
        in srgb,
        #ca8a04 50%,
        var(--border-color)
    ) !important;
}

#adminAppBody:not(.theme-light)
    .admin-table-bulk-scope
    .alert.alert-warning
    strong {
    color: #fef3c7 !important;
}

#adminAppBody .admin-table-bulk-scope .table-responsive.shadow-sm {
    box-shadow: 0 0.125rem 0.35rem color-mix(in srgb, #000 50%, transparent) !important;
}

#adminAppBody.theme-light .admin-table-bulk-scope .table-responsive.shadow-sm {
    box-shadow: 0 0.125rem 0.25rem rgba(0, 0, 0, 0.075) !important;
}

/* Align Bootstrap table striping with theme background */
#adminAppBody:not(.theme-light)
    .admin-table-bulk-scope
    .table-striped
    > tbody
    > tr:nth-of-type(odd)
    > * {
    --bs-table-accent-bg: color-mix(
        in srgb,
        var(--card-bg) 90%,
        var(--text-main) 10%
    );
    color: var(--text-main);
}

#adminAppBody:not(.theme-light)
    .admin-table-bulk-scope
    .table-striped
    > tbody
    > tr:nth-of-type(even)
    > * {
    --bs-table-accent-bg: transparent;
    color: var(--text-main);
}

#adminAppBody .admin-table-bulk-scope .table tbody tr:hover > td,
#adminAppBody .admin-table-bulk-scope .table tbody tr:hover > th {
    background-color: color-mix(
        in srgb,
        var(--card-bg) 78%,
        var(--text-main) 22%
    ) !important;
}

#adminAppBody.theme-light
    .admin-table-bulk-scope
    .table-striped
    > tbody
    > tr:nth-of-type(odd)
    > * {
    --bs-table-accent-bg: transparent;
    background-color: #ffffff !important;
    color: var(--text-main);
}

#adminAppBody.theme-light
    .admin-table-bulk-scope
    .table-striped
    > tbody
    > tr:nth-of-type(even)
    > * {
    --bs-table-accent-bg: #f3f4f6;
    background-color: #f3f4f6 !important;
    color: var(--text-main);
}

/*
 * Bulk (ellipsis) button: AdminLTE + Bootstrap --bs-btn-* often force a light background.
 * Use theme variables + !important so it stays consistent in dark/light.
 */
#adminAppBody
    .admin-table-bulk-scope
    .js-admin-bulk-toolbar
    .btn.btn-outline-secondary[data-bs-toggle="dropdown"] {
    --bs-btn-color: var(--text-main);
    --bs-btn-border-color: var(--border-color);
    --bs-btn-bg: var(--card-bg);
    --bs-btn-hover-color: var(--text-main);
    --bs-btn-hover-bg: color-mix(
        in srgb,
        var(--card-bg) 72%,
        var(--text-main) 28%
    );
    --bs-btn-hover-border-color: var(--border-color);
    --bs-btn-active-color: var(--text-main);
    --bs-btn-active-bg: color-mix(
        in srgb,
        var(--card-bg) 62%,
        var(--text-main) 38%
    );
    --bs-btn-active-border-color: var(--border-color);
    --bs-btn-disabled-color: color-mix(
        in srgb,
        var(--text-main) 45%,
        transparent
    );
    --bs-btn-disabled-bg: var(--card-bg);
    --bs-btn-disabled-border-color: var(--border-color);

    background-color: var(--card-bg) !important;
    color: var(--text-main) !important;
    border-color: var(--border-color) !important;
}

#adminAppBody.theme-light
    .admin-table-bulk-scope
    .js-admin-bulk-toolbar
    .btn.btn-outline-secondary[data-bs-toggle="dropdown"] {
    --bs-btn-hover-bg: #e9ecef;
    --bs-btn-active-bg: #dee2e6;
}

#adminAppBody
    .admin-table-bulk-scope
    .js-admin-bulk-toolbar
    .btn.btn-outline-secondary[data-bs-toggle="dropdown"]:hover,
#adminAppBody
    .admin-table-bulk-scope
    .js-admin-bulk-toolbar
    .btn.btn-outline-secondary[data-bs-toggle="dropdown"]:focus,
#adminAppBody
    .admin-table-bulk-scope
    .js-admin-bulk-toolbar
    .show
    > .btn.btn-outline-secondary[data-bs-toggle="dropdown"] {
    background-color: var(--bs-btn-hover-bg) !important;
    color: var(--text-main) !important;
    border-color: var(--border-color) !important;
}

#adminAppBody
    .admin-table-bulk-scope
    .js-admin-bulk-toolbar
    .btn.btn-outline-secondary[data-bs-toggle="dropdown"]:active,
#adminAppBody
    .admin-table-bulk-scope
    .js-admin-bulk-toolbar
    .btn.btn-outline-secondary[data-bs-toggle="dropdown"].active {
    background-color: var(--bs-btn-active-bg) !important;
    color: var(--text-main) !important;
    border-color: var(--border-color) !important;
}

#adminAppBody
    .admin-table-bulk-scope
    .js-admin-bulk-toolbar
    .btn.btn-outline-secondary[data-bs-toggle="dropdown"]:focus-visible {
    box-shadow: 0 0 0 0.2rem
        color-mix(in srgb, var(--link-accent) 40%, transparent) !important;
}

/* Row selection checkbox (header + body) */
#adminAppBody .admin-table-bulk-scope .form-check-input {
    background-color: var(--card-bg) !important;
    border-color: var(--border-color) !important;
}

#adminAppBody .admin-table-bulk-scope .form-check-input:checked {
    background-color: var(--link-accent) !important;
    border-color: var(--link-accent) !important;
}

#adminAppBody .admin-table-bulk-scope .form-check-input:focus {
    border-color: var(--link-accent);
    box-shadow: 0 0 0 0.2rem
        color-mix(in srgb, var(--link-accent) 35%, transparent);
}

/* Modals (create/edit role permissions, user roles, etc.): checkboxes & native selects */
#adminAppBody .modal .form-check-input {
    --bs-form-check-bg: var(--card-bg);
    background-color: var(--card-bg) !important;
    border-color: var(--border-color) !important;
}

#adminAppBody .modal .form-check-input:checked {
    --bs-form-check-bg: var(--link-accent);
    background-color: var(--link-accent) !important;
    border-color: var(--link-accent) !important;
}

#adminAppBody .modal .form-check-input:focus {
    border-color: var(--link-accent);
    box-shadow: 0 0 0 0.2rem
        color-mix(in srgb, var(--link-accent) 35%, transparent);
}

#adminAppBody .modal .form-check-input[type="checkbox"]:indeterminate {
    background-color: color-mix(
        in srgb,
        var(--link-accent) 55%,
        var(--card-bg)
    ) !important;
    border-color: var(--link-accent) !important;
}

#adminAppBody .modal .form-select {
    background-color: var(--card-bg) !important;
    color: var(--text-main) !important;
    border-color: var(--border-color) !important;
}

#adminAppBody .modal .form-select:focus {
    background-color: var(--card-bg) !important;
    color: var(--text-main) !important;
    border-color: var(--link-accent) !important;
    box-shadow: 0 0 0 0.2rem
        color-mix(in srgb, var(--link-accent) 25%, transparent);
}

#adminAppBody .modal .form-select option {
    background-color: var(--card-bg);
    color: var(--text-main);
}

/* User create/edit: role multi-select as wrapped chips inside modal */
#adminAppBody .admin-user-roles-multiselect {
    border-color: var(--border-color) !important;
    background-color: color-mix(
        in srgb,
        var(--card-bg) 94%,
        var(--text-main) 6%
    );
    overflow: hidden;
}

#adminAppBody .admin-user-roles-multiselect.is-invalid {
    border-color: #dc3545 !important;
}

#adminAppBody .admin-user-roles-multiselect__scroll {
    max-height: 12rem;
    overflow-y: auto;
    padding: 0.6rem;
    display: flex;
    flex-wrap: wrap;
    gap: 0.5rem;
    align-content: flex-start;
}

#adminAppBody .admin-user-roles-multiselect__item {
    display: inline-flex;
    align-items: center;
    gap: 0.55rem;
    padding: 0.45rem 0.75rem;
    margin: 0;
    border: 1px solid var(--border-color);
    border-radius: 0.5rem;
    background-color: var(--card-bg);
    cursor: pointer;
    flex-shrink: 0;
    max-width: 100%;
    box-sizing: border-box;
    transition: background-color 0.15s ease, border-color 0.15s ease;
}

#adminAppBody .admin-user-roles-multiselect__item:hover {
    border-color: color-mix(
        in srgb,
        var(--link-accent) 42%,
        var(--border-color)
    );
}

#adminAppBody
    .admin-user-roles-multiselect__item:has(.form-check-input:checked) {
    border-color: color-mix(
        in srgb,
        var(--link-accent) 55%,
        var(--border-color)
    );
    background-color: color-mix(
        in srgb,
        var(--link-accent) 16%,
        var(--card-bg)
    );
}

#adminAppBody.theme-light
    .admin-user-roles-multiselect__item:has(.form-check-input:checked) {
    background-color: color-mix(in srgb, var(--link-accent) 10%, #ffffff);
}

#adminAppBody .admin-user-roles-multiselect__item .form-check-input {
    position: static !important;
    float: none !important;
    margin: 0 !important;
    flex: 0 0 1.05rem;
    width: 1.05rem !important;
    height: 1.05rem !important;
    min-width: 1.05rem !important;
    cursor: pointer;
    transform: none !important;
    align-self: center;
}

#adminAppBody .admin-user-roles-multiselect__text {
    flex-shrink: 0;
    font-weight: 600;
    font-size: 0.875rem;
    color: var(--text-main);
    user-select: none;
    line-height: 1.25;
    white-space: nowrap;
}

/* Status toggle — track & knob follow theme (not harsh Bootstrap red/green) */
#adminAppBody .toggle-switch {
    position: relative;
    display: inline-block;
    width: 46px;
    height: 24px;
    vertical-align: middle;
}

#adminAppBody .toggle-switch input {
    position: absolute;
    opacity: 0;
    width: 46px;
    height: 24px;
    margin: 0;
    cursor: pointer;
    z-index: 2;
}

#adminAppBody .toggle-switch .toggle-slider {
    position: absolute;
    cursor: pointer;
    top: 0;
    left: 0;
    right: 0;
    bottom: 0;
    border-radius: 24px;
    transition: background-color 0.25s ease, box-shadow 0.2s ease;
    z-index: 1;
}

#adminAppBody .toggle-switch .toggle-slider::before {
    content: "";
    position: absolute;
    height: 18px;
    width: 18px;
    left: 3px;
    bottom: 3px;
    border-radius: 50%;
    transition: transform 0.25s ease, background-color 0.25s ease;
}

#adminAppBody.theme-light .toggle-switch .toggle-slider {
    background-color: #d1d5db;
    box-shadow: inset 0 1px 2px rgba(0, 0, 0, 0.06);
}

#adminAppBody.theme-light .toggle-switch .toggle-slider::before {
    background-color: #ffffff;
    box-shadow: 0 1px 2px rgba(0, 0, 0, 0.12);
}

#adminAppBody.theme-light .toggle-switch input:checked + .toggle-slider {
    background-color: #10b981;
    box-shadow: inset 0 1px 2px rgba(0, 0, 0, 0.08);
}

#adminAppBody.theme-light
    .toggle-switch
    input:checked
    + .toggle-slider::before {
    transform: translateX(22px);
}

#adminAppBody:not(.theme-light) .toggle-switch .toggle-slider {
    background-color: #4b5563;
    box-shadow: inset 0 1px 3px rgba(0, 0, 0, 0.35);
}

#adminAppBody:not(.theme-light) .toggle-switch .toggle-slider::before {
    background-color: #f3f4f6;
    box-shadow: 0 1px 2px rgba(0, 0, 0, 0.25);
}

#adminAppBody:not(.theme-light) .toggle-switch input:checked + .toggle-slider {
    background-color: #059669;
}

#adminAppBody:not(.theme-light)
    .toggle-switch
    input:checked
    + .toggle-slider::before {
    transform: translateX(22px);
    background-color: #ecfdf5;
}

#adminAppBody .toggle-switch input:focus-visible + .toggle-slider {
    box-shadow: inset 0 1px 2px rgba(0, 0, 0, 0.08),
        0 0 0 0.2rem color-mix(in srgb, var(--link-accent) 45%, transparent);
}

#adminAppBody:not(.theme-light)
    .toggle-switch
    input:focus-visible
    + .toggle-slider {
    box-shadow: inset 0 1px 3px rgba(0, 0, 0, 0.35),
        0 0 0 0.2rem color-mix(in srgb, var(--link-accent) 45%, transparent);
}

#adminAppBody .content .list-group-item {
    transition: background-color 0.2s ease;
}

#adminAppBody.theme-light .content .list-group-item:hover {
    background-color: color-mix(
        in srgb,
        var(--card-bg) 92%,
        var(--text-main) 8%
    );
}

#adminAppBody:not(.theme-light) .content .list-group-item:hover {
    background-color: color-mix(
        in srgb,
        var(--card-bg) 82%,
        var(--text-main) 18%
    );
}

/* =========================================================
   Role / permission matrix badges (light = soft; dark = readable)
========================================================= */

#adminAppBody .admin-perm-badge {
    font-size: 0.7rem;
    font-weight: 600;
    letter-spacing: 0.02em;
    border: 1px solid transparent;
    vertical-align: middle;
}

/* Dark theme: enough contrast, not “neon” */
#adminAppBody:not(.theme-light) .admin-perm-badge--view,
#adminAppBody:not(.theme-light) .admin-perm-badge--default {
    background-color: #4b5563 !important;
    color: #f9fafb !important;
    border-color: #6b7280 !important;
}

#adminAppBody:not(.theme-light) .admin-perm-badge--create {
    background-color: #1e40af !important;
    color: #eff6ff !important;
    border-color: #3b82f6 !important;
}

#adminAppBody:not(.theme-light) .admin-perm-badge--edit {
    background-color: #b45309 !important;
    color: #fffbeb !important;
    border-color: #f59e0b !important;
}

#adminAppBody:not(.theme-light) .admin-perm-badge--delete {
    background-color: #991b1b !important;
    color: #fef2f2 !important;
    border-color: #ef4444 !important;
}

#adminAppBody:not(.theme-light) .admin-perm-badge--restore {
    background-color: #475569 !important;
    color: #f1f5f9 !important;
    border-color: #64748b !important;
}

#adminAppBody:not(.theme-light) .admin-perm-badge--import {
    background-color: #0e7490 !important;
    color: #ecfeff !important;
    border-color: #06b6d4 !important;
}

#adminAppBody:not(.theme-light) .admin-perm-badge--export {
    background-color: #047857 !important;
    color: #ecfdf5 !important;
    border-color: #10b981 !important;
}

/* Light theme: pastel background + dark text (readable) */
#adminAppBody.theme-light .admin-perm-badge--view,
#adminAppBody.theme-light .admin-perm-badge--default {
    background-color: #e9ecef !important;
    color: #343a40 !important;
    border-color: #ced4da !important;
}

#adminAppBody.theme-light .admin-perm-badge--create {
    background-color: #dbeafe !important;
    color: #1e3a8a !important;
    border-color: #93c5fd !important;
}

#adminAppBody.theme-light .admin-perm-badge--edit {
    background-color: #fef3c7 !important;
    color: #92400e !important;
    border-color: #fcd34d !important;
}

#adminAppBody.theme-light .admin-perm-badge--delete {
    background-color: #fee2e2 !important;
    color: #991b1b !important;
    border-color: #fca5a5 !important;
}

#adminAppBody.theme-light .admin-perm-badge--restore {
    background-color: #e2e8f0 !important;
    color: #475569 !important;
    border-color: #cbd5e1 !important;
}

#adminAppBody.theme-light .admin-perm-badge--import {
    background-color: #cffafe !important;
    color: #155e75 !important;
    border-color: #67e8f9 !important;
}

#adminAppBody.theme-light .admin-perm-badge--export {
    background-color: #d1fae5 !important;
    color: #065f46 !important;
    border-color: #6ee7b7 !important;
}

/*
 * Admin action buttons (Add, Edit, Delete, Restore, Delete all, …) on table cards:
 * .admin-table-card covers toolbar + table body; not modal body (except round media-delete buttons).
 * Light = soft background + dark text; dark = calm contrast.
 */
#adminAppBody.theme-light
    .admin-table-card
    .btn.btn-sm.btn-primary[data-bs-toggle="modal"] {
    color: #1e3a8a !important;
    background-color: #dbeafe !important;
    border-color: #3b82f6 !important;
}

#adminAppBody.theme-light
    .admin-table-card
    .btn.btn-sm.btn-primary[data-bs-toggle="modal"]:hover {
    background-color: #bfdbfe !important;
    color: #1e3a8a !important;
    border-color: #2563eb !important;
}

#adminAppBody.theme-light
    .admin-table-card
    .btn.btn-sm.btn-warning[data-bs-toggle="modal"] {
    color: #92400e !important;
    background-color: #fffbeb !important;
    border-color: #f59e0b !important;
}

#adminAppBody.theme-light
    .admin-table-card
    .btn.btn-sm.btn-warning[data-bs-toggle="modal"]:hover {
    background-color: #fef3c7 !important;
    color: #78350f !important;
    border-color: #d97706 !important;
}

#adminAppBody.theme-light
    .admin-table-card
    .btn.btn-sm.btn-danger[data-bs-toggle="modal"] {
    color: #991b1b !important;
    background-color: #fef2f2 !important;
    border-color: #ef4444 !important;
}

#adminAppBody.theme-light
    .admin-table-card
    .btn.btn-sm.btn-danger[data-bs-toggle="modal"]:hover {
    background-color: #fee2e2 !important;
    color: #7f1d1d !important;
    border-color: #dc2626 !important;
}

#adminAppBody.theme-light
    .admin-table-card
    .btn.btn-sm.btn-info[data-bs-toggle="modal"] {
    color: #155e75 !important;
    background-color: #cffafe !important;
    border-color: #22d3ee !important;
}

#adminAppBody.theme-light
    .admin-table-card
    .btn.btn-sm.btn-info[data-bs-toggle="modal"]:hover {
    background-color: #a5f3fc !important;
    color: #164e63 !important;
    border-color: #06b6d4 !important;
}

#adminAppBody.theme-light
    .admin-table-card
    .btn.btn-sm.btn-secondary[data-bs-toggle="modal"] {
    color: #374151 !important;
    background-color: #f3f4f6 !important;
    border-color: #9ca3af !important;
}

#adminAppBody.theme-light
    .admin-table-card
    .btn.btn-sm.btn-secondary[data-bs-toggle="modal"]:hover {
    background-color: #e5e7eb !important;
    color: #1f2937 !important;
}

/* Round image-delete buttons inside modal forms (era/franchise/category/video) */
#adminAppBody.theme-light
    .admin-table-card
    .modal
    .btn.btn-sm.btn-danger.rounded-circle {
    color: #991b1b !important;
    background-color: #fef2f2 !important;
    border-color: #ef4444 !important;
}

#adminAppBody.theme-light
    .admin-table-card
    .modal
    .btn.btn-sm.btn-danger.rounded-circle:hover {
    background-color: #fee2e2 !important;
    color: #7f1d1d !important;
}

/* Dark theme */
#adminAppBody:not(.theme-light)
    .admin-table-card
    .btn.btn-sm.btn-primary[data-bs-toggle="modal"] {
    color: #eff6ff !important;
    background-color: #1e40af !important;
    border-color: #3b82f6 !important;
}

#adminAppBody:not(.theme-light)
    .admin-table-card
    .btn.btn-sm.btn-primary[data-bs-toggle="modal"]:hover {
    background-color: #2563eb !important;
    color: #fff !important;
}

#adminAppBody:not(.theme-light)
    .admin-table-card
    .btn.btn-sm.btn-warning[data-bs-toggle="modal"] {
    color: #fffbeb !important;
    background-color: #92400e !important;
    border-color: #b45309 !important;
}

#adminAppBody:not(.theme-light)
    .admin-table-card
    .btn.btn-sm.btn-warning[data-bs-toggle="modal"]:hover {
    background-color: #b45309 !important;
    color: #fff !important;
}

#adminAppBody:not(.theme-light)
    .admin-table-card
    .btn.btn-sm.btn-danger[data-bs-toggle="modal"] {
    color: #fef2f2 !important;
    background-color: #991b1b !important;
    border-color: #b91c1c !important;
}

#adminAppBody:not(.theme-light)
    .admin-table-card
    .btn.btn-sm.btn-danger[data-bs-toggle="modal"]:hover {
    background-color: #b91c1c !important;
}

#adminAppBody:not(.theme-light)
    .admin-table-card
    .btn.btn-sm.btn-info[data-bs-toggle="modal"] {
    color: #ecfeff !important;
    background-color: #0e7490 !important;
    border-color: #06b6d4 !important;
}

#adminAppBody:not(.theme-light)
    .admin-table-card
    .btn.btn-sm.btn-info[data-bs-toggle="modal"]:hover {
    background-color: #0891b2 !important;
    color: #fff !important;
}

#adminAppBody:not(.theme-light)
    .admin-table-card
    .btn.btn-sm.btn-secondary[data-bs-toggle="modal"] {
    color: #f9fafb !important;
    background-color: #4b5563 !important;
    border-color: #6b7280 !important;
}

#adminAppBody:not(.theme-light)
    .admin-table-card
    .btn.btn-sm.btn-secondary[data-bs-toggle="modal"]:hover {
    background-color: #6b7280 !important;
    color: #fff !important;
}

#adminAppBody:not(.theme-light)
    .admin-table-card
    .modal
    .btn.btn-sm.btn-danger.rounded-circle {
    color: #fef2f2 !important;
    background-color: #991b1b !important;
    border-color: #b91c1c !important;
}

/*
 * Admin toolbar (Upload / Excel / PDF): no data-bs-toggle — needs its own rules.
 * Override Bootstrap .text-white with color !important.
 */
#adminAppBody .admin-table-card .admin-table-actions .btn.btn-sm,
#adminAppBody .admin-table-card .admin-table-actions a.btn.btn-sm {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: 0.35rem;
    min-height: calc(1.5em + 0.5rem + 2px);
    text-decoration: none;
    white-space: nowrap;
}

#adminAppBody.theme-light
    .admin-table-card
    .admin-table-actions
    .btn.btn-sm.btn-info[data-bs-toggle="modal"] {
    color: #155e75 !important;
    background-color: #cffafe !important;
    border-color: #22d3ee !important;
}

#adminAppBody.theme-light
    .admin-table-card
    .admin-table-actions
    .btn.btn-sm.btn-info[data-bs-toggle="modal"]:hover {
    background-color: #a5f3fc !important;
    color: #164e63 !important;
    border-color: #06b6d4 !important;
}

#adminAppBody.theme-light
    .admin-table-card
    .admin-table-actions
    .btn.btn-sm.btn-success,
#adminAppBody.theme-light
    .admin-table-card
    .admin-table-actions
    a.btn.btn-sm.btn-success,
#adminAppBody.theme-light
    .admin-table-card
    .admin-table-actions
    .btn.btn-sm.btn-success.text-white,
#adminAppBody.theme-light
    .admin-table-card
    .admin-table-actions
    a.btn.btn-sm.btn-success.text-white {
    color: #065f46 !important;
    background-color: #d1fae5 !important;
    border-color: #34d399 !important;
}

#adminAppBody.theme-light
    .admin-table-card
    .admin-table-actions
    .btn.btn-sm.btn-success:hover,
#adminAppBody.theme-light
    .admin-table-card
    .admin-table-actions
    a.btn.btn-sm.btn-success:hover,
#adminAppBody.theme-light
    .admin-table-card
    .admin-table-actions
    .btn.btn-sm.btn-success.text-white:hover,
#adminAppBody.theme-light
    .admin-table-card
    .admin-table-actions
    a.btn.btn-sm.btn-success.text-white:hover {
    background-color: #a7f3d0 !important;
    color: #064e3b !important;
    border-color: #10b981 !important;
}

#adminAppBody.theme-light
    .admin-table-card
    .admin-table-actions
    .btn.btn-sm.btn-secondary,
#adminAppBody.theme-light
    .admin-table-card
    .admin-table-actions
    a.btn.btn-sm.btn-secondary,
#adminAppBody.theme-light
    .admin-table-card
    .admin-table-actions
    .btn.btn-sm.btn-secondary.text-white,
#adminAppBody.theme-light
    .admin-table-card
    .admin-table-actions
    a.btn.btn-sm.btn-secondary.text-white {
    color: #374151 !important;
    background-color: #f3f4f6 !important;
    border-color: #9ca3af !important;
}

#adminAppBody.theme-light
    .admin-table-card
    .admin-table-actions
    .btn.btn-sm.btn-secondary:hover,
#adminAppBody.theme-light
    .admin-table-card
    .admin-table-actions
    a.btn.btn-sm.btn-secondary:hover,
#adminAppBody.theme-light
    .admin-table-card
    .admin-table-actions
    .btn.btn-sm.btn-secondary.text-white:hover,
#adminAppBody.theme-light
    .admin-table-card
    .admin-table-actions
    a.btn.btn-sm.btn-secondary.text-white:hover {
    background-color: #e5e7eb !important;
    color: #1f2937 !important;
    border-color: #6b7280 !important;
}

#adminAppBody:not(.theme-light)
    .admin-table-card
    .admin-table-actions
    .btn.btn-sm.btn-success,
#adminAppBody:not(.theme-light)
    .admin-table-card
    .admin-table-actions
    a.btn.btn-sm.btn-success,
#adminAppBody:not(.theme-light)
    .admin-table-card
    .admin-table-actions
    .btn.btn-sm.btn-success.text-white,
#adminAppBody:not(.theme-light)
    .admin-table-card
    .admin-table-actions
    a.btn.btn-sm.btn-success.text-white {
    color: #ecfdf5 !important;
    background-color: #047857 !important;
    border-color: #10b981 !important;
}

#adminAppBody:not(.theme-light)
    .admin-table-card
    .admin-table-actions
    .btn.btn-sm.btn-success:hover,
#adminAppBody:not(.theme-light)
    .admin-table-card
    .admin-table-actions
    a.btn.btn-sm.btn-success:hover {
    background-color: #059669 !important;
    color: #fff !important;
}

#adminAppBody:not(.theme-light)
    .admin-table-card
    .admin-table-actions
    .btn.btn-sm.btn-secondary,
#adminAppBody:not(.theme-light)
    .admin-table-card
    .admin-table-actions
    a.btn.btn-sm.btn-secondary,
#adminAppBody:not(.theme-light)
    .admin-table-card
    .admin-table-actions
    .btn.btn-sm.btn-secondary.text-white,
#adminAppBody:not(.theme-light)
    .admin-table-card
    .admin-table-actions
    a.btn.btn-sm.btn-secondary.text-white {
    color: #f9fafb !important;
    background-color: #4b5563 !important;
    border-color: #6b7280 !important;
}

#adminAppBody:not(.theme-light)
    .admin-table-card
    .admin-table-actions
    .btn.btn-sm.btn-secondary:hover,
#adminAppBody:not(.theme-light)
    .admin-table-card
    .admin-table-actions
    a.btn.btn-sm.btn-secondary:hover {
    background-color: #6b7280 !important;
    color: #fff !important;
}

#adminAppBody:not(.theme-light)
    .admin-table-card
    .admin-table-actions
    .btn.btn-sm.btn-info[data-bs-toggle="modal"] {
    color: #ecfeff !important;
    background-color: #0e7490 !important;
    border-color: #06b6d4 !important;
}

#adminAppBody:not(.theme-light)
    .admin-table-card
    .admin-table-actions
    .btn.btn-sm.btn-info[data-bs-toggle="modal"]:hover {
    background-color: #0891b2 !important;
    color: #fff !important;
}

/* Pages without x-admin-table: actions in list rows (e.g. Provider Google Drive) */
#adminAppBody.theme-light .content .list-group-item .btn.btn-sm.btn-primary,
#adminAppBody.theme-light .content .list-group-item a.btn.btn-sm.btn-primary {
    color: #1e3a8a !important;
    background-color: #dbeafe !important;
    border-color: #3b82f6 !important;
}

#adminAppBody.theme-light
    .content
    .list-group-item
    .btn.btn-sm.btn-primary:hover,
#adminAppBody.theme-light
    .content
    .list-group-item
    a.btn.btn-sm.btn-primary:hover {
    background-color: #bfdbfe !important;
    color: #1e3a8a !important;
}

#adminAppBody.theme-light .content .list-group-item .btn.btn-sm.btn-danger,
#adminAppBody.theme-light .content .list-group-item a.btn.btn-sm.btn-danger {
    color: #991b1b !important;
    background-color: #fef2f2 !important;
    border-color: #ef4444 !important;
}

#adminAppBody.theme-light
    .content
    .list-group-item
    .btn.btn-sm.btn-danger:hover,
#adminAppBody.theme-light
    .content
    .list-group-item
    a.btn.btn-sm.btn-danger:hover {
    background-color: #fee2e2 !important;
    color: #7f1d1d !important;
}

#adminAppBody:not(.theme-light)
    .content
    .list-group-item
    .btn.btn-sm.btn-primary,
#adminAppBody:not(.theme-light)
    .content
    .list-group-item
    a.btn.btn-sm.btn-primary {
    color: #eff6ff !important;
    background-color: #1e40af !important;
    border-color: #3b82f6 !important;
}

#adminAppBody:not(.theme-light)
    .content
    .list-group-item
    .btn.btn-sm.btn-danger,
#adminAppBody:not(.theme-light)
    .content
    .list-group-item
    a.btn.btn-sm.btn-danger {
    color: #fef2f2 !important;
    background-color: #991b1b !important;
    border-color: #b91c1c !important;
}

/* Green CTA in content area (e.g. Add account) — softer in light mode */
#adminAppBody.theme-light .content .container .btn.btn-success {
    color: #065f46 !important;
    background-color: #d1fae5 !important;
    border-color: #34d399 !important;
}

#adminAppBody.theme-light .content .container .btn.btn-success:hover {
    background-color: #a7f3d0 !important;
    color: #064e3b !important;
}

/* =========================================================
   Admin pages without x-admin-table (DB export, etc.): badges & buttons in .card
========================================================= */

#adminAppBody
    .content
    .container-fluid
    .card:not(.admin-table-card)
    .table
    .badge {
    border: 1px solid color-mix(in srgb, var(--border-color) 70%, transparent);
    font-weight: 600;
}

#adminAppBody.theme-light
    .content
    .container-fluid
    .card:not(.admin-table-card)
    .table
    .badge.bg-secondary {
    background-color: #f3f4f6 !important;
    color: #4b5563 !important;
    border-color: color-mix(in srgb, #9ca3af 45%, transparent) !important;
}

#adminAppBody:not(.theme-light)
    .content
    .container-fluid
    .card:not(.admin-table-card)
    .table
    .badge.bg-secondary {
    background-color: #4b5563 !important;
    color: #f3f4f6 !important;
    border-color: #6b7280 !important;
}

#adminAppBody.theme-light
    .content
    .container-fluid
    .card:not(.admin-table-card)
    .table
    .btn.btn-sm.btn-success,
#adminAppBody.theme-light
    .content
    .container-fluid
    .card:not(.admin-table-card)
    .table
    a.btn.btn-sm.btn-success {
    color: #065f46 !important;
    background-color: #d1fae5 !important;
    border-color: #34d399 !important;
}

#adminAppBody.theme-light
    .content
    .container-fluid
    .card:not(.admin-table-card)
    .table
    .btn.btn-sm.btn-success:hover,
#adminAppBody.theme-light
    .content
    .container-fluid
    .card:not(.admin-table-card)
    .table
    a.btn.btn-sm.btn-success:hover {
    background-color: #a7f3d0 !important;
    color: #064e3b !important;
    border-color: #10b981 !important;
}

#adminAppBody:not(.theme-light)
    .content
    .container-fluid
    .card:not(.admin-table-card)
    .table
    .btn.btn-sm.btn-success,
#adminAppBody:not(.theme-light)
    .content
    .container-fluid
    .card:not(.admin-table-card)
    .table
    a.btn.btn-sm.btn-success {
    color: #ecfdf5 !important;
    background-color: #047857 !important;
    border-color: #10b981 !important;
}

#adminAppBody:not(.theme-light)
    .content
    .container-fluid
    .card:not(.admin-table-card)
    .table
    .btn.btn-sm.btn-success:hover,
#adminAppBody:not(.theme-light)
    .content
    .container-fluid
    .card:not(.admin-table-card)
    .table
    a.btn.btn-sm.btn-success:hover {
    background-color: #059669 !important;
    color: #fff !important;
}

#adminAppBody.theme-light
    .content
    .container-fluid
    .card:not(.admin-table-card)
    .table
    thead
    th {
    background-color: #f8fafc !important;
    color: var(--text-main) !important;
    border-color: var(--border-color) !important;
}

#adminAppBody.theme-light
    .content
    .container-fluid
    .card:not(.admin-table-card)
    .table-striped
    > tbody
    > tr:nth-of-type(odd)
    > * {
    --bs-table-accent-bg: transparent;
    background-color: #ffffff !important;
}

#adminAppBody.theme-light
    .content
    .container-fluid
    .card:not(.admin-table-card)
    .table-striped
    > tbody
    > tr:nth-of-type(even)
    > * {
    --bs-table-accent-bg: #f3f4f6;
    background-color: #f3f4f6 !important;
}

#adminAppBody:not(.theme-light)
    .content
    .container-fluid
    .card:not(.admin-table-card)
    .table
    thead
    th {
    background-color: color-mix(
        in srgb,
        var(--card-bg) 88%,
        var(--text-main) 12%
    ) !important;
}

/* Primary btn-sm on table cards (not only modals) — e.g. “Use this gateway” */
#adminAppBody.theme-light .admin-table-card .btn.btn-sm.btn-primary {
    color: #1e3a8a !important;
    background-color: #dbeafe !important;
    border-color: #3b82f6 !important;
}

#adminAppBody.theme-light .admin-table-card .btn.btn-sm.btn-primary:hover {
    background-color: #bfdbfe !important;
    color: #1e3a8a !important;
    border-color: #2563eb !important;
}

#adminAppBody:not(.theme-light) .admin-table-card .btn.btn-sm.btn-primary {
    color: #eff6ff !important;
    background-color: #1e40af !important;
    border-color: #3b82f6 !important;
}

#adminAppBody:not(.theme-light)
    .admin-table-card
    .btn.btn-sm.btn-primary:hover {
    background-color: #2563eb !important;
    color: #fff !important;
}

/* =========================================================
   Dashboard AdminLTE .small-box — neutral / soft, not harsh default blue/green
========================================================= */

#adminAppBody .small-box {
    border-radius: 0.85rem;
    overflow: hidden;
    box-shadow: 0 6px 18px color-mix(in srgb, #000 14%, transparent);
    border: 1px solid var(--border-color);
}

#adminAppBody.theme-light .small-box.bg-primary {
    background: linear-gradient(145deg, #eff6ff 0%, #dbeafe 100%) !important;
    color: #1e3a8a !important;
}

#adminAppBody.theme-light .small-box.bg-primary .inner h3,
#adminAppBody.theme-light .small-box.bg-primary .inner p {
    color: #1e3a8a !important;
}

#adminAppBody.theme-light .small-box.bg-primary .small-box-footer {
    background: color-mix(in srgb, #3b82f6 14%, #ffffff) !important;
    color: #1e40af !important;
}

#adminAppBody.theme-light .small-box.bg-success {
    background: linear-gradient(145deg, #ecfdf5 0%, #d1fae5 100%) !important;
    color: #065f46 !important;
}

#adminAppBody.theme-light .small-box.bg-success .inner h3,
#adminAppBody.theme-light .small-box.bg-success .inner p {
    color: #065f46 !important;
}

#adminAppBody.theme-light .small-box.bg-success .small-box-footer {
    background: color-mix(in srgb, #10b981 14%, #ffffff) !important;
    color: #047857 !important;
}

#adminAppBody:not(.theme-light) .small-box.bg-primary {
    background: linear-gradient(145deg, #1e3a8a 0%, #172554 100%) !important;
    color: #e0e7ff !important;
}

#adminAppBody:not(.theme-light) .small-box.bg-primary .inner h3,
#adminAppBody:not(.theme-light) .small-box.bg-primary .inner p {
    color: #eef2ff !important;
}

#adminAppBody:not(.theme-light) .small-box.bg-primary .small-box-footer {
    background: rgba(0, 0, 0, 0.22) !important;
    color: #c7d2fe !important;
}

#adminAppBody:not(.theme-light) .small-box.bg-success {
    background: linear-gradient(145deg, #065f46 0%, #064e3b 100%) !important;
    color: #ecfdf5 !important;
}

#adminAppBody:not(.theme-light) .small-box.bg-success .inner h3,
#adminAppBody:not(.theme-light) .small-box.bg-success .inner p {
    color: #ecfdf5 !important;
}

#adminAppBody:not(.theme-light) .small-box.bg-success .small-box-footer {
    background: rgba(0, 0, 0, 0.22) !important;
    color: #a7f3d0 !important;
}

#adminAppBody .small-box .small-box-footer {
    border-top: 1px solid
        color-mix(in srgb, var(--border-color) 80%, transparent);
}

#adminAppBody .small-box .small-box-footer:hover {
    text-decoration: none;
    filter: brightness(1.05);
}
