﻿/* Admin login page â€” scoped to .admin-auth-login */

.admin-auth-login {
    --admin-login-accent: rgba(85, 110, 230, 0.35);
    --admin-login-accent-soft: rgba(85, 110, 230, 0.08);
    --admin-login-bg-line: rgba(85, 110, 230, 0.14);
    --admin-login-footer-space: 4.5rem;
    min-height: 100vh;
    min-height: 100dvh;
    display: flex;
    flex-direction: column;
}

/* Footer is outside this wrapper so it cannot steal flex space (was causing the huge white gap). */
.admin-auth-login .admin-login-page {
    position: relative;
    overflow: hidden;
    flex: 1 1 auto;
    min-height: 0;
    display: flex;
    flex-direction: column;
    padding-bottom: var(--admin-login-footer-space);
}

.admin-auth-login .admin-login-bg-vectors {
    position: absolute;
    inset: 0;
    z-index: 0;
    pointer-events: none;
    overflow: hidden;
}

.admin-auth-login .admin-login-bg-svg {
    position: absolute;
    inset: 0;
    width: 100%;
    height: 100%;
    display: block;
}

.admin-auth-login .admin-login-bg-curve {
    transform-origin: center;
    animation: admin-auth-login-bg-curve-shift 40s linear infinite;
}

@keyframes admin-auth-login-bg-curve-shift {
    0% {
        transform: translateX(0);
    }

    100% {
        transform: translateX(-8%);
    }
}

.admin-auth-login .admin-login-body {
    position: relative;
    z-index: 1;
    flex: 1 1 auto;
    min-height: 0;
    display: flex;
    flex-direction: column;
}

.admin-auth-login .admin-login-shell {
    flex: 1 1 auto;
    min-height: 0;
    display: flex;
    flex-wrap: nowrap;
    align-items: stretch;
}

.admin-auth-login .admin-login-shell>[class*="col-"] {
    display: flex;
    flex-direction: column;
    min-height: 0;
}

.admin-auth-login .admin-login-decorate {
    position: relative;
    overflow: hidden;
    background: linear-gradient(180deg,
            var(--admin-login-accent-soft) 0%,
            transparent 45%,
            transparent 55%,
            var(--admin-login-accent-soft) 100%);
}

.admin-auth-login .admin-login-decorate::before {
    content: "";
    position: absolute;
    inset: 0;
    z-index: 0;
    background-image:
        radial-gradient(circle at 50% 18%, var(--admin-login-accent) 0, transparent 42%),
        radial-gradient(circle at 30% 72%, var(--admin-login-accent) 0, transparent 38%),
        radial-gradient(circle at 78% 58%, var(--admin-login-accent) 0, transparent 36%);
    opacity: 0.45;
    pointer-events: none;
}

.admin-auth-login .admin-login-decorate-inner {
    position: relative;
    z-index: 2;
    height: 100%;
    min-height: 100%;
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    gap: 2.5rem;
    padding: 2rem 0;
}

.admin-auth-login .admin-login-side-rail {
    position: absolute;
    inset: 0;
    z-index: 1;
    display: flex;
    align-items: stretch;
    pointer-events: none;
    user-select: none;
}

.admin-auth-login .admin-login-side-rail--left {
    justify-content: flex-end;
    padding-right: clamp(0rem, 0.35vw, 0.8rem);
}

.admin-auth-login .admin-login-side-rail--right {
    justify-content: flex-start;
    padding-left: clamp(0rem, 0.35vw, 0.8rem);
}

.admin-auth-login .admin-login-side-rail-letters {
    display: flex;
    flex-direction: column;
    justify-content: space-between;
    align-items: center;
    height: 100%;
    box-sizing: border-box;
    padding: clamp(0.65rem, 5vh, 2.25rem) 0;
}

.admin-auth-login .admin-login-side-rail--right .admin-login-side-rail-letters {
    flex-direction: column-reverse;
}

.admin-auth-login .admin-login-side-rail-block {
    --admin-rail-i: 0;
    flex: 0 0 auto;
    display: flex;
    align-items: center;
    justify-content: center;
    min-width: clamp(1.2rem, 1.45vw, 1.6rem);
    min-height: clamp(1.2rem, 1.45vw, 1.6rem);
    padding: 0.08rem;
    border-radius: 0.3rem;
    border: 1px solid rgba(85, 110, 230, 0.32);
    background: rgba(85, 110, 230, 0.07);
    box-sizing: border-box;
    animation: admin-auth-login-rail-block-pulse 2.75s ease-in-out infinite;
    animation-delay: calc(var(--admin-rail-i) * 0.2s);
}

.admin-auth-login .admin-login-side-rail-letter {
    font-size: clamp(0.5rem, 0.75vw, 0.72rem);
    font-weight: 800;
    line-height: 1;
    letter-spacing: 0;
    color: rgba(85, 110, 230, 0.55);
}

@keyframes admin-auth-login-rail-block-pulse {

    0%,
    100% {
        border-color: rgba(85, 110, 230, 0.22);
        background: rgba(85, 110, 230, 0.05);
        box-shadow: 0 0 0 0 rgba(85, 110, 230, 0);
        transform: scale(1);
    }

    45% {
        border-color: rgba(99, 102, 241, 0.55);
        background: rgba(99, 102, 241, 0.12);
        box-shadow: 0 0 12px rgba(99, 102, 241, 0.22);
        transform: scale(1.04);
    }
}

.admin-auth-login .admin-login-ornament {
    width: 3px;
    height: 120px;
    border-radius: 999px;
    background: linear-gradient(180deg, transparent, var(--admin-login-accent), transparent);
    opacity: 0.85;
}

.admin-auth-login .admin-login-ornament--dot {
    width: 10px;
    height: 10px;
    border-radius: 50%;
    background: var(--admin-login-accent);
    box-shadow: 0 0 0 6px var(--admin-login-accent-soft);
}

.admin-auth-login .admin-login-main {
    min-height: 0;
    overflow: hidden;
    background: linear-gradient(135deg, rgba(255, 255, 255, 0.02) 0%, transparent 50%);
}

/* Override app.min.css .auth-full-page-content { min-height: 100vh } */
.admin-auth-login .auth-full-page-content {
    min-height: 0;
    overflow: hidden;
}

.admin-auth-login .admin-login-auth-stage {
    flex: 1 1 auto;
    min-height: 0;
    width: 100%;
    padding-top: 0.5rem;
    padding-bottom: 0.5rem;
}

.admin-auth-login .admin-login-center-stack {
    display: flex;
    flex-direction: column;
    align-items: center;
    width: 100%;
    max-width: 360px;
    margin-left: auto;
    margin-right: auto;
    transform: translateY(clamp(-1.5rem, -2.5vh, -0.35rem));
}

.admin-auth-login .admin-login-logo-above {
    flex-shrink: 0;
    margin-bottom: 0.85rem;
}

.admin-auth-login .admin-login-brand {
    display: inline-flex;
    flex-direction: column;
    align-items: center;
    gap: 0.35rem;
    text-decoration: none;
    line-height: 1.2;
}

.admin-auth-login .admin-login-brand-name {
    display: inline-flex;
    align-items: baseline;
    gap: 0;
    font-size: 1.65rem;
    font-weight: 700;
    letter-spacing: -0.01em;
    text-transform: none;
}

.admin-auth-login .admin-login-brand-accent {
    color: #0066ff;
    letter-spacing: 0.01em;
}

.admin-auth-login .admin-login-brand-rest {
    color: #1a2332;
    letter-spacing: -0.02em;
}

.admin-navbar-brand-link {
    display: flex;
    align-items: center;
    text-decoration: none !important;
}

.admin-navbar-brand {
    display: inline-flex;
    align-items: baseline;
    font-size: 1.35rem;
    font-weight: 700;
    letter-spacing: -0.02em;
    line-height: 1;
    white-space: nowrap;
}

.admin-navbar-brand--sm {
    font-size: 1.05rem;
}

.admin-navbar-brand-accent {
    color: #556ee6;
}

.admin-navbar-brand-rest {
    color: #495057;
}

body.admin-dashboard-dark .admin-navbar-brand-accent {
    color: #818cf8;
}

body.admin-dashboard-dark .admin-navbar-brand-rest {
    color: #f8fafc;
}

.admin-auth-login .admin-login-brand-tagline {
    display: inline-flex;
    align-items: center;
    gap: 0.65rem;
    font-size: 0.625rem;
    font-weight: 600;
    letter-spacing: 0.16em;
    text-transform: uppercase;
    color: #556ee6;
}

.admin-auth-login .admin-login-brand-tagline::before,
.admin-auth-login .admin-login-brand-tagline::after {
    content: "";
    width: 1.75rem;
    height: 1px;
    background: linear-gradient(90deg, transparent, rgba(85, 110, 230, 0.45));
}

.admin-auth-login .admin-login-brand-tagline::after {
    background: linear-gradient(90deg, rgba(85, 110, 230, 0.45), transparent);
}

.admin-auth-login .admin-login-eyebrow {
    font-size: 0.6875rem;
    font-weight: 600;
    letter-spacing: 0.14em;
    text-transform: uppercase;
    color: #556ee6;
}

.admin-auth-login .admin-login-footer {
    position: fixed;
    bottom: 0;
    left: 0;
    right: 0;
    z-index: 1030;
    width: 100%;
    border-top: 1px solid rgba(85, 110, 230, 0.28);
    background: linear-gradient(180deg, rgba(85, 110, 230, 0.22) 0%, rgba(45, 58, 120, 0.32) 100%);
    backdrop-filter: blur(12px);
    padding-top: 0.65rem;
    padding-bottom: max(0.65rem, env(safe-area-inset-bottom, 0px));
    color: rgba(255, 255, 255, 0.88);
}

.admin-auth-login .admin-login-footer a {
    color: rgba(255, 255, 255, 0.95);
    text-decoration: underline;
    text-underline-offset: 2px;
}

.admin-auth-login .admin-login-footer .text-muted {
    color: rgba(255, 255, 255, 0.78) !important;
}

.admin-auth-login .admin-login-card {
    position: relative;
    width: 100%;
    max-width: none;
    margin-left: 0;
    margin-right: 0;
    border-radius: 1rem;
    padding: 1.35rem 1.5rem 1.15rem;
    background: rgba(255, 255, 255, 0.94);
    border: 1px solid rgba(85, 110, 230, 0.16);
    overflow: hidden;
    box-shadow: 0 4px 22px rgba(85, 110, 230, 0.12);
    animation:
        admin-auth-login-card-in 0.65s cubic-bezier(0.22, 1, 0.36, 1) both,
        admin-auth-login-card-glow 5s ease-in-out infinite 0.7s;
}

.admin-auth-login .admin-login-card::before {
    content: "";
    position: absolute;
    top: 0;
    left: 0;
    right: 0;
    height: 3px;
    background: linear-gradient(90deg,
            rgba(85, 110, 230, 0.15),
            rgba(120, 165, 255, 0.95),
            rgba(72, 195, 210, 0.9),
            rgba(120, 165, 255, 0.95),
            rgba(85, 110, 230, 0.15));
    background-size: 200% 100%;
    animation: admin-auth-login-shine 3.5s linear infinite;
    pointer-events: none;
}

.admin-auth-login .admin-login-card-inner {
    position: relative;
    z-index: 1;
}

.admin-auth-login .admin-auth-dark-toggle-wrap {
    position: fixed;
    top: 1rem;
    right: 1rem;
    z-index: 1040;
}

.admin-auth-login #admin-auth-dark-toggle,
.admin-auth-login #admin-auth-dark-toggle.btn {
    width: 42px;
    height: 42px;
    padding: 0;
    border-radius: 50%;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    border: 0;
    background: transparent !important;
    color: #556ee6;
    box-shadow: none !important;
    transition: color 0.2s ease, transform 0.2s ease;
}

.admin-auth-login #admin-auth-dark-toggle:hover,
.admin-auth-login #admin-auth-dark-toggle:focus,
.admin-auth-login #admin-auth-dark-toggle:active,
.admin-auth-login #admin-auth-dark-toggle.btn:hover,
.admin-auth-login #admin-auth-dark-toggle.btn:focus,
.admin-auth-login #admin-auth-dark-toggle.btn:active {
    transform: translateY(-1px);
    background: transparent !important;
    box-shadow: none !important;
}

.admin-auth-login #admin-auth-dark-toggle .bx {
    font-size: 1.25rem;
    line-height: 1;
}

@keyframes admin-auth-login-card-in {
    from {
        opacity: 0;
        transform: translateY(14px) scale(0.98);
    }

    to {
        opacity: 1;
        transform: translateY(0) scale(1);
    }
}

@keyframes admin-auth-login-card-glow {

    0%,
    100% {
        box-shadow:
            0 4px 22px rgba(85, 110, 230, 0.12),
            0 0 0 0 rgba(85, 110, 230, 0);
    }

    50% {
        box-shadow:
            0 12px 38px rgba(85, 110, 230, 0.22),
            0 0 0 1px rgba(85, 110, 230, 0.1);
    }
}

@keyframes admin-auth-login-shine {
    0% {
        background-position: 0% 0;
    }

    100% {
        background-position: 200% 0;
    }
}

/* Dark mode â€” toggled via body.admin-dashboard-dark */
body.admin-dashboard-dark {
    --dash-bg: #0f172a;
    --dash-text: #e2e8f0;
    --dash-text-bright: #f8fafc;
    --dash-muted: #94a3b8;
    --dash-card-border: rgba(148, 163, 184, 0.18);
    --dash-input-border: rgba(148, 163, 184, 0.32);
    --dash-card-shadow: 0 10px 40px rgba(0, 0, 0, 0.35);
}

body.admin-dashboard-dark.auth-body-bg {
    background-color: var(--dash-bg) !important;
    color: var(--dash-text);
}

body.admin-dashboard-dark .admin-auth-login {
    background-color: var(--dash-bg);
    color: var(--dash-text);
    --admin-login-bg-line: rgba(129, 140, 248, 0.12);
}

body.admin-dashboard-dark .admin-auth-login #admin-auth-dark-toggle {
    background: transparent !important;
    border: 0 !important;
    color: var(--dash-text-bright) !important;
    box-shadow: none !important;
}

body.admin-dashboard-dark .admin-auth-login .admin-login-brand-accent {
    color: #818cf8;
}

body.admin-dashboard-dark .admin-auth-login .admin-login-brand-rest {
    color: var(--dash-text-bright);
}

body.admin-dashboard-dark .admin-auth-login .admin-login-brand-tagline {
    color: #a5b4fc;
}

body.admin-dashboard-dark .admin-auth-login .admin-login-brand-tagline::before,
body.admin-dashboard-dark .admin-auth-login .admin-login-brand-tagline::after {
    background: linear-gradient(90deg, transparent, rgba(129, 140, 248, 0.45));
}

body.admin-dashboard-dark .admin-auth-login .admin-login-brand-tagline::after {
    background: linear-gradient(90deg, rgba(129, 140, 248, 0.45), transparent);
}

body.admin-dashboard-dark .admin-auth-login .admin-login-page {
    background-color: transparent;
}

body.admin-dashboard-dark .admin-auth-login .admin-login-decorate {
    background: linear-gradient(180deg,
            rgba(99, 102, 241, 0.08) 0%,
            transparent 45%,
            transparent 55%,
            rgba(99, 102, 241, 0.06) 100%);
}

body.admin-dashboard-dark .admin-auth-login .admin-login-decorate::before {
    opacity: 0.35;
}

body.admin-dashboard-dark .admin-auth-login .admin-login-side-rail-block {
    border-color: rgba(99, 102, 241, 0.28);
    background: transparent;
    animation-name: admin-auth-login-rail-block-pulse-dark;
}

body.admin-dashboard-dark .admin-auth-login .admin-login-side-rail-letter {
    color: rgba(199, 210, 254, 0.55);
}

@keyframes admin-auth-login-rail-block-pulse-dark {

    0%,
    100% {
        border-color: rgba(99, 102, 241, 0.2);
        background: transparent;
        box-shadow: 0 0 0 0 rgba(99, 102, 241, 0);
        transform: scale(1);
    }

    45% {
        border-color: rgba(129, 140, 248, 0.5);
        background: transparent;
        box-shadow: 0 0 14px rgba(129, 140, 248, 0.28);
        transform: scale(1.04);
    }
}

body.admin-dashboard-dark .admin-auth-login .admin-login-main {
    background: transparent;
}

body.admin-dashboard-dark .admin-auth-login .admin-login-main>.text-center {
    color: var(--dash-muted);
}

body.admin-dashboard-dark .admin-auth-login .admin-login-main>.text-center a {
    color: #a5b4fc !important;
}

body.admin-dashboard-dark .admin-auth-login .admin-login-card {
    background: transparent;
    border-color: var(--dash-card-border);
    color: var(--dash-text);
    box-shadow: none;
}

body.admin-dashboard-dark .admin-auth-login .admin-login-card h4 {
    color: var(--dash-text-bright) !important;
}

body.admin-dashboard-dark .admin-auth-login .admin-login-card .text-muted {
    color: var(--dash-muted) !important;
}

body.admin-dashboard-dark .admin-auth-login .admin-login-card label,
body.admin-dashboard-dark .admin-auth-login .admin-login-card .form-check-label {
    color: var(--dash-muted) !important;
}

body.admin-dashboard-dark .admin-auth-login .admin-login-card input.form-control {
    background-color: transparent !important;
    border-color: var(--dash-input-border) !important;
    color: var(--dash-text) !important;
    color-scheme: dark;
}

body.admin-dashboard-dark .admin-auth-login .admin-login-card input.form-control:focus {
    border-color: #6366f1 !important;
    box-shadow: 0 0 0 0.12rem rgba(99, 102, 241, 0.22) !important;
}

body.admin-dashboard-dark .admin-auth-login .admin-login-card .btn-light {
    background-color: transparent !important;
    border-color: var(--dash-card-border) !important;
    color: var(--dash-text-bright) !important;
}

body.admin-dashboard-dark .admin-auth-login .admin-login-footer {
    background: transparent;
    border-top-color: var(--dash-card-border);
    color: var(--dash-muted);
}

body.admin-dashboard-dark .admin-auth-login .admin-login-footer a {
    color: #a5b4fc !important;
}

body.admin-dashboard-dark .admin-auth-login .admin-login-footer .text-muted {
    color: var(--dash-muted) !important;
}

body.admin-dashboard-dark .admin-auth-login .admin-login-eyebrow {
    color: #a5b4fc;
}

body.admin-dashboard-dark .admin-auth-login .admin-login-card .alert-danger {
    background-color: rgba(239, 68, 68, 0.12) !important;
    border-color: rgba(248, 113, 113, 0.35) !important;
    color: #fecaca !important;
}

body.admin-dashboard-dark .admin-auth-login .admin-login-card .alert-success {
    background-color: rgba(34, 197, 94, 0.12) !important;
    border-color: rgba(74, 222, 128, 0.35) !important;
    color: #bbf7d0 !important;
}

@media (prefers-reduced-motion: reduce) {

    .admin-auth-login .admin-login-card,
    .admin-auth-login .admin-login-card::before {
        animation: none;
    }

    .admin-auth-login .admin-login-card {
        opacity: 1;
        transform: none;
    }

    .admin-auth-login .admin-login-center-stack {
        transform: none;
    }

    .admin-auth-login .admin-login-side-rail-block {
        animation: none;
    }

    .admin-auth-login .admin-login-bg-curve {
        animation: none;
    }
}

/* Admin dashboard shell â€” dark mode via body.admin-dashboard-dark */
.admin-header-clock {
    margin-top: 3px;
    cursor: default;
    user-select: none;
}

.admin-header-clock small {
    color: #495057;
}

/* Admin dashboard header buttons â€” transparent backgrounds */
#page-topbar .header-item,
#page-topbar .btn.header-item,
#page-topbar #admin-dashboard-dark-toggle,
#page-topbar #vertical-menu-btn {
    background: transparent !important;
    border: 0 !important;
    box-shadow: none !important;
}

#page-topbar .header-item:hover,
#page-topbar .header-item:focus,
#page-topbar .header-item.show,
#page-topbar .btn.header-item:hover,
#page-topbar .btn.header-item:focus,
#page-topbar .btn.header-item:active,
#page-topbar .btn.header-item.active,
#page-topbar .dropdown .show.header-item,
#page-topbar #admin-dashboard-dark-toggle:hover,
#page-topbar #admin-dashboard-dark-toggle:focus,
#page-topbar #admin-dashboard-dark-toggle:active,
#page-topbar #vertical-menu-btn:hover,
#page-topbar #vertical-menu-btn:focus,
#page-topbar #vertical-menu-btn:active {
    background: transparent !important;
    box-shadow: none !important;
}

body.admin-dashboard-dark {
    background-color: var(--dash-bg);
    color: var(--dash-text);
}

/* Dashboard shell â€” transparent surfaces, body provides the dark base */
body.admin-dashboard-dark #layout-wrapper,
body.admin-dashboard-dark .main-content {
    background-color: transparent !important;
}

body.admin-dashboard-dark #page-topbar {
    background-color: transparent !important;
    border-bottom: 1px solid var(--dash-card-border);
    box-shadow: none !important;
}

body.admin-dashboard-dark[data-sidebar="dark"] .navbar-brand-box,
body.admin-dashboard-dark .navbar-brand-box {
    background: transparent !important;
    border-right: 1px solid var(--dash-card-border);
}

body.admin-dashboard-dark .navbar-header .header-item,
body.admin-dashboard-dark .navbar-header .header-item .bx,
body.admin-dashboard-dark .navbar-header .header-item .mdi {
    color: var(--dash-text-bright) !important;
}

body.admin-dashboard-dark .admin-header-clock small {
    color: var(--dash-muted) !important;
}

body.admin-dashboard-dark .navbar-brand-box .logo-dark {
    display: none !important;
}

body.admin-dashboard-dark .navbar-brand-box .logo-light {
    display: block !important;
}

body.admin-dashboard-dark[data-sidebar="dark"] .vertical-menu,
body.admin-dashboard-dark .vertical-menu {
    background: transparent !important;
    border-right: 1px solid var(--dash-card-border);
    box-shadow: none !important;
}

body.admin-dashboard-dark[data-sidebar="dark"] #sidebar-menu ul li a.active_menu,
body.admin-dashboard-dark #sidebar-menu ul li a.active_menu {
    background: transparent !important;
    color: #fff !important;
    border-left: 3px solid #6366f1;
}

body.admin-dashboard-dark #sidebar-menu ul li a {
    color: #cbd5e1 !important;
}

body.admin-dashboard-dark #sidebar-menu ul li a:hover,
body.admin-dashboard-dark #sidebar-menu ul li a:focus,
body.admin-dashboard-dark #sidebar-menu ul li .active_sub_menu {
    color: #fff !important;
}

body.admin-dashboard-dark #sidebar-menu ul li ul.sub-menu li a {
    color: #94a3b8 !important;
}

body.admin-dashboard-dark #sidebar-menu .menu-title {
    color: #64748b !important;
}

body.admin-dashboard-dark .page-content,
body.admin-dashboard-dark .footer {
    background-color: transparent !important;
    color: var(--dash-muted);
}

body.admin-dashboard-dark .page-title-box h4,
body.admin-dashboard-dark .card-title,
body.admin-dashboard-dark h4,
body.admin-dashboard-dark h5,
body.admin-dashboard-dark h6 {
    color: var(--dash-text-bright) !important;
}

body.admin-dashboard-dark .card,
body.admin-dashboard-dark .card-body,
body.admin-dashboard-dark .card-footer,
body.admin-dashboard-dark .mini-stats-wid {
    background-color: transparent !important;
    border-color: var(--dash-card-border) !important;
    box-shadow: none !important;
}

body.admin-dashboard-dark .text-muted,
body.admin-dashboard-dark .breadcrumb-item,
body.admin-dashboard-dark .breadcrumb-item.active,
body.admin-dashboard-dark .admin-dashboard-tips .text-muted {
    color: var(--dash-muted) !important;
}

body.admin-dashboard-dark .breadcrumb-item.active {
    color: var(--dash-text) !important;
}

body.admin-dashboard-dark .table,
body.admin-dashboard-dark .table thead,
body.admin-dashboard-dark .table tbody,
body.admin-dashboard-dark .table tfoot,
body.admin-dashboard-dark .table> :not(caption)>*>* {
    background-color: transparent !important;
    color: var(--dash-text);
    border-color: var(--dash-card-border) !important;
}

body.admin-dashboard-dark .table thead th {
    color: var(--dash-text-bright);
}

body.admin-dashboard-dark .form-control,
body.admin-dashboard-dark .form-select,
body.admin-dashboard-dark .sinput {
    background-color: transparent !important;
    border: 1px solid var(--dash-input-border) !important;
    color: var(--dash-text) !important;
    color-scheme: dark;
}

body.admin-dashboard-dark .form-control:focus,
body.admin-dashboard-dark .form-select:focus,
body.admin-dashboard-dark .sinput:focus {
    background-color: transparent !important;
    border-color: #818cf8 !important;
    box-shadow: 0 0 0 0.15rem rgba(99, 102, 241, 0.28) !important;
    color: var(--dash-text-bright) !important;
}

body.admin-dashboard-dark .form-control::placeholder {
    color: var(--dash-muted) !important;
}

body.admin-dashboard-dark input[type="file"].form-control,
body.admin-dashboard-dark input[type="file"] {
    background-color: transparent !important;
    color: var(--dash-text) !important;
    color-scheme: dark;
}

body.admin-dashboard-dark input[type="file"]::file-selector-button {
    background-color: transparent !important;
    border: 1px solid var(--dash-input-border) !important;
    color: var(--dash-text-bright) !important;
    border-radius: 4px;
    padding: 0.35rem 0.75rem;
    margin-right: 0.75rem;
    cursor: pointer;
    transition: border-color 0.2s ease, color 0.2s ease;
}

body.admin-dashboard-dark input[type="file"]::file-selector-button:hover {
    border-color: #6366f1 !important;
    color: var(--dash-text-bright) !important;
}

body.admin-dashboard-dark input[type="file"]::-webkit-file-upload-button {
    background-color: transparent !important;
    border: 1px solid var(--dash-input-border) !important;
    color: var(--dash-text-bright) !important;
    border-radius: 4px;
    padding: 0.35rem 0.75rem;
    margin-right: 0.75rem;
    cursor: pointer;
}

body.admin-dashboard-dark textarea.form-control {
    background-color: transparent !important;
    color: var(--dash-text) !important;
}

/* Native select â€” dark dropdown list + readable options */
body.admin-dashboard-dark select,
body.admin-dashboard-dark select.form-control,
body.admin-dashboard-dark select.form-select,
body.admin-dashboard-dark select.sinput {
    background-color: transparent !important;
    color: var(--dash-text-bright) !important;
    color-scheme: dark;
    accent-color: #6366f1;
}

body.admin-dashboard-dark select:focus,
body.admin-dashboard-dark select.form-control:focus,
body.admin-dashboard-dark select.form-select:focus,
body.admin-dashboard-dark select.sinput:focus {
    color: var(--dash-text-bright) !important;
}

body.admin-dashboard-dark select option,
body.admin-dashboard-dark select optgroup {
    background-color: #1e293b !important;
    color: #e2e8f0 !important;
}

body.admin-dashboard-dark select option:checked,
body.admin-dashboard-dark select option:hover,
body.admin-dashboard-dark select option:focus,
body.admin-dashboard-dark select option:active {
    background-color: #334155 !important;
    color: #f8fafc !important;
}

body.admin-dashboard-dark .modal-content,
body.admin-dashboard-dark .modal-body {
    color-scheme: dark;
}

body.admin-dashboard-dark .modal-content {
    background-color: rgba(30, 41, 59, 0.98) !important;
    border-color: var(--dash-card-border) !important;
    color: var(--dash-text);
    box-shadow: var(--dash-card-shadow) !important;
}

body.admin-dashboard-dark .modal-header,
body.admin-dashboard-dark .modal-body,
body.admin-dashboard-dark .modal-footer {
    background-color: transparent !important;
    border-color: var(--dash-card-border) !important;
    color: var(--dash-text);
}

body.admin-dashboard-dark .modal-header .btn-close {
    filter: invert(1) grayscale(100%) brightness(200%);
}

body.admin-dashboard-dark .dropdown-menu {
    background-color: transparent !important;
    border-color: var(--dash-card-border);
    backdrop-filter: blur(8px);
}

body.admin-dashboard-dark .dropdown-item,
body.admin-dashboard-dark .dropdown-item-text {
    color: var(--dash-text);
}

body.admin-dashboard-dark .dropdown-item:hover,
body.admin-dashboard-dark .dropdown-item:focus {
    background-color: transparent !important;
    color: var(--dash-text-bright);
}

body.admin-dashboard-dark .dropdown-divider {
    border-color: var(--dash-card-border);
}

body.admin-dashboard-dark .pagination .page-link {
    background-color: transparent !important;
    border-color: var(--dash-card-border) !important;
    color: var(--dash-text) !important;
}

body.admin-dashboard-dark .pagination .page-item.active .page-link {
    background-color: transparent !important;
    border-color: #6366f1 !important;
    color: var(--dash-text-bright) !important;
}

body.admin-dashboard-dark .pagination .page-item.disabled .page-link {
    background-color: transparent !important;
    color: var(--dash-muted) !important;
}

body.admin-dashboard-dark .btn-secondary,
body.admin-dashboard-dark .action-btn.btn-secondary {
    background-color: transparent !important;
    border-color: var(--dash-card-border) !important;
    color: var(--dash-text-bright) !important;
}

body.admin-dashboard-dark .btn-secondary:hover,
body.admin-dashboard-dark .action-btn.btn-secondary:hover {
    background-color: transparent !important;
    border-color: #6366f1 !important;
    color: var(--dash-text-bright) !important;
}

body.admin-dashboard-dark .nav_item_active,
body.admin-dashboard-dark .mm-active>a {
    background: transparent !important;
}

body.admin-dashboard-dark .badge.bg-soft {
    background-color: transparent !important;
    border: 1px solid var(--dash-card-border);
}

body.admin-dashboard-dark .navbar-header .dropdown .show.header-item,
body.admin-dashboard-dark .header-profile-user {
    background-color: transparent !important;
}

body.admin-dashboard-dark label,
body.admin-dashboard-dark .col-form-label {
    color: var(--dash-muted) !important;
}

body.admin-dashboard-dark .pre_style_modal {
    background-color: transparent !important;
    border-color: var(--dash-card-border) !important;
    color: var(--dash-text);
}

/* Video management page */
.admin-video-management-page .badge {
    font-size: 10px;
    font-weight: 500;
    width: fit-content;
    padding: 3px 8px;
}

.admin-video-management-page div.disabled {
    opacity: 0.9 !important;
    cursor: not-allowed !important;
    pointer-events: none !important;
}


/* Modal loading overlay */
.admin-video-management-page .modal-content {
    position: relative !important;
    overflow: hidden;
}

.admin-video-management-page .modal-content>.admin-modal-loading {
    position: absolute !important;
    top: 0 !important;
    right: 0 !important;
    bottom: 0 !important;
    left: 0 !important;
    z-index: 1056 !important;
    width: 100% !important;
    height: 100% !important;
    margin: 0 !important;
    align-items: center !important;
    justify-content: center !important;
    background: rgba(15, 23, 42, 0.55) !important;
    border-radius: inherit;
}

.admin-video-management-page .modal-content>.admin-modal-loading.flex,
.admin-video-management-page .modal-content>.admin-modal-loading[wire\:loading] {
    display: flex !important;
}

/* Table loading overlay */
.admin-video-management-page .admin-table-body {
    position: relative;
    width: 100%;
}

.admin-video-management-page .admin-table-loading {
    position: absolute;
    inset: 0;
    z-index: 5;
    display: none;
    align-items: center;
    justify-content: center;
    background: rgba(255, 255, 255, 0.72);
    border-radius: 0.375rem;
    pointer-events: none;
}

.admin-video-management-page .admin-table-loading.flex,
.admin-video-management-page .admin-table-loading[wire\:loading] {
    display: flex !important;
}

.admin-video-management-page .admin-table-loading-spinner {
    width: 1.75rem;
    height: 1.75rem;
    border-width: 0.15em;
}

.admin-video-management-page .admin-add-video-btn.action-btn {
    width: auto;
    min-width: auto;
    height: 30px;
    padding: 0 0.65rem;
    display: inline-flex;
    align-items: center;
    gap: 0.25rem;
}

.admin-video-management-page .admin-add-video-btn-icon {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 14px;
    flex-shrink: 0;
}

.admin-video-management-page .admin-add-video-btn-text {
    font-size: 12px;
    line-height: 1;
    white-space: nowrap;
}

.admin-video-form-footer {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 0.75rem;
    padding: 0.85rem 1.25rem !important;
    border-top: 1px solid rgba(0, 0, 0, 0.06);
}

.admin-video-form-footer .admin-video-form-footer-save {
    margin-left: auto;
}

/* Video add/edit form modal */
.admin-video-form-modal {
    --admin-scroll-track: transparent;
    --admin-scroll-thumb: rgba(148, 163, 184, 0.22);
    --admin-scroll-thumb-hover: rgba(148, 163, 184, 0.36);
}

.admin-video-form-dialog {
    max-width: 540px;
    width: calc(100% - 1.5rem);
}

.admin-video-form-modal .modal-content {
    border: 0;
    border-radius: 0.85rem;
    overflow: hidden;
    box-shadow: 0 18px 48px rgba(15, 23, 42, 0.18);
}

.admin-video-form-modal-header {
    display: flex;
    align-items: flex-start;
    justify-content: space-between;
    gap: 0.75rem;
    padding: 1rem 1.25rem 0.85rem !important;
    border-bottom: 1px solid rgba(0, 0, 0, 0.06);
}

.admin-video-form-modal-header-main {
    display: flex;
    align-items: flex-start;
    gap: 0.85rem;
    min-width: 0;
}

.admin-video-form-modal-icon {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 42px;
    height: 42px;
    flex-shrink: 0;
    font-size: 22px;
    color: #fff;
    background: linear-gradient(135deg, #34c38f, #2ea872);
    border-radius: 0.65rem;
    box-shadow: 0 4px 14px rgba(52, 195, 143, 0.28);
}

.admin-video-form-modal--edit .admin-video-form-modal-icon {
    background: linear-gradient(135deg, #556ee6, #4f63d9);
    box-shadow: 0 4px 14px rgba(85, 110, 230, 0.28);
}

.admin-video-form-modal-subtitle {
    margin-top: 0.15rem;
    font-size: 12px;
    line-height: 1.45;
    color: #6c757d;
}

.admin-video-form-modal-body {
    max-height: calc(100vh - 220px);
    overflow-y: auto;
    padding: 1rem 1.25rem 1.15rem !important;
    scrollbar-width: thin;
    scrollbar-color: var(--admin-scroll-thumb) var(--admin-scroll-track);
}

.admin-video-form-modal-body::-webkit-scrollbar {
    width: 4px;
}

.admin-video-form-modal-body::-webkit-scrollbar-track {
    background: transparent;
}

.admin-video-form-modal-body::-webkit-scrollbar-thumb {
    background: var(--admin-scroll-thumb);
    border-radius: 999px;
}

.admin-video-form-modal-body::-webkit-scrollbar-thumb:hover {
    background: var(--admin-scroll-thumb-hover);
}

.admin-video-form-section {
    margin-bottom: 1rem;
}

.admin-video-form-section--group {
    padding: 0.85rem;
    border-radius: 0.65rem;
    background: rgba(85, 110, 230, 0.04);
    border: 1px solid rgba(85, 110, 230, 0.08);
}

.admin-video-form-section-head {
    display: flex;
    align-items: baseline;
    justify-content: space-between;
    gap: 0.75rem;
    margin-bottom: 0.75rem;
}

.admin-video-form-section-title {
    font-size: 11px;
    font-weight: 700;
    letter-spacing: 0.05em;
    text-transform: uppercase;
    color: #556ee6;
}

.admin-video-form-section-desc {
    font-size: 11px;
    color: #94a3b8;
}

.admin-video-form-field {
    margin-bottom: 0.75rem;
}

.admin-video-form-label {
    display: block;
    margin-bottom: 0.35rem;
    font-size: 11px;
    font-weight: 600;
    letter-spacing: 0.03em;
    text-transform: uppercase;
    color: #64748b;
}

.admin-video-form-input,
.admin-video-form-modal .form-control.admin-video-form-input {
    border: 1px solid rgba(15, 23, 42, 0.08);
    background: rgba(255, 255, 255, 0.92);
    padding: 0.5rem 0.65rem;
    font-size: 13px;
    line-height: 1.45;
    color: #334155;
    border-radius: 0.45rem;
    box-shadow: none;
    transition: border-color 0.15s ease, background 0.15s ease, box-shadow 0.15s ease;
}

.admin-video-form-modal select.admin-video-form-input {
    cursor: pointer;
    padding-right: 1.75rem;
}

.admin-video-form-input:focus,
.admin-video-form-modal .form-control.admin-video-form-input:focus {
    border-color: rgba(85, 110, 230, 0.35);
    background: #fff;
    box-shadow: 0 0 0 0.15rem rgba(85, 110, 230, 0.1);
    outline: 0;
}

.admin-video-form-textarea {
    min-height: 88px;
    max-height: 140px;
    resize: none;
    overflow-y: auto;
    scrollbar-width: thin;
    scrollbar-color: var(--admin-scroll-thumb) var(--admin-scroll-track);
}

.admin-video-form-textarea::-webkit-scrollbar {
    width: 4px;
}

.admin-video-form-textarea::-webkit-scrollbar-track {
    background: transparent;
}

.admin-video-form-textarea::-webkit-scrollbar-thumb {
    background: var(--admin-scroll-thumb);
    border-radius: 999px;
}

.admin-video-form-textarea::-webkit-scrollbar-thumb:hover {
    background: var(--admin-scroll-thumb-hover);
}

.admin-video-form-hint {
    display: flex;
    align-items: flex-start;
    gap: 0.35rem;
    margin-top: 0.45rem;
    font-size: 11px;
    line-height: 1.45;
    color: #94a3b8;
}

.admin-video-form-hint i {
    font-size: 13px;
    line-height: 1.2;
    margin-top: 0.05rem;
}

.admin-video-form-hint code {
    padding: 0.05rem 0.3rem;
    font-size: 10px;
    border-radius: 0.25rem;
    background: rgba(15, 23, 42, 0.05);
}

.admin-video-form-error {
    margin: 0.35rem 0 0;
    font-size: 11px;
    color: #dc3545;
}

.admin-video-form-current-file {
    display: flex;
    align-items: center;
    gap: 0.65rem;
    margin-bottom: 0.65rem;
    padding: 0.55rem 0.65rem;
    border-radius: 0.45rem;
    background: rgba(52, 195, 143, 0.08);
    border: 1px solid rgba(52, 195, 143, 0.16);
}

.admin-video-form-current-file i {
    font-size: 22px;
    color: #34c38f;
}

.admin-video-form-current-file-label {
    display: block;
    font-size: 10px;
    font-weight: 600;
    letter-spacing: 0.04em;
    text-transform: uppercase;
    color: #64748b;
}

.admin-video-form-current-file-link {
    font-size: 12px;
    font-weight: 500;
    color: #556ee6;
    text-decoration: none;
}

.admin-video-form-current-file-link:hover {
    color: #4f63d9;
    text-decoration: underline;
}

.admin-video-form-file {
    position: relative;
    display: flex;
    align-items: center;
    gap: 0.75rem;
    margin-bottom: 0.45rem;
    padding: 0.85rem 0.95rem;
    border-radius: 0.55rem;
    border: 1px dashed rgba(85, 110, 230, 0.28);
    background: rgba(255, 255, 255, 0.72);
    cursor: pointer;
    transition: border-color 0.15s ease, background 0.15s ease, box-shadow 0.15s ease;
}

.admin-video-form-file:hover {
    border-color: rgba(85, 110, 230, 0.45);
    background: rgba(85, 110, 230, 0.04);
    box-shadow: 0 0 0 0.12rem rgba(85, 110, 230, 0.06);
}

.admin-video-form-file-icon {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 38px;
    height: 38px;
    flex-shrink: 0;
    border-radius: 0.45rem;
    background: rgba(85, 110, 230, 0.1);
    color: #556ee6;
    font-size: 20px;
}

.admin-video-form-file-copy {
    display: flex;
    flex-direction: column;
    gap: 0.1rem;
    min-width: 0;
    flex: 1;
}

.admin-video-form-file-copy strong {
    font-size: 13px;
    font-weight: 600;
    color: #334155;
}

.admin-video-form-file-copy small {
    font-size: 11px;
    color: #94a3b8;
}

.admin-video-form-file-action {
    flex-shrink: 0;
    padding: 0.3rem 0.65rem;
    font-size: 11px;
    font-weight: 600;
    color: #556ee6;
    background: rgba(85, 110, 230, 0.1);
    border-radius: 0.35rem;
}

.admin-video-form-file-input {
    position: absolute;
    inset: 0;
    opacity: 0;
    cursor: pointer;
}

.admin-video-form-modal .admin-video-form-footer .admin-video-form-footer-save .spinner-border-xs {
    color: inherit;
}

.admin-video-form-modal .btn-close:disabled {
    opacity: 0.35;
    pointer-events: none;
}

.admin-video-management-page .admin-modal-action-btn.action-btn,
.modal .admin-modal-action-btn.action-btn {
    width: auto;
    min-width: 88px;
    height: 30px;
    padding: 0 0.75rem;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: 0.25rem;
    font-size: 12px;
    line-height: 1;
}

.admin-video-management-page .admin-youtube-details-refresh.action-btn {
    min-width: 30px;
    padding: 0;
}

/* Shared modal open/close animation */
.admin-video-management-page .modal.fade.show,
.admin-video-management-page .modal.fade.admin-modal-closing {
    display: flex !important;
    align-items: center;
    justify-content: center;
    padding: 1rem;
}

.admin-video-management-page .modal.fade .modal-dialog {
    margin-left: auto;
    margin-right: auto;
    transform: none !important;
    transition: none !important;
}

@media (max-width: 767px) {

    .admin-video-management-page .modal.fade.show,
    .admin-video-management-page .modal.fade.admin-modal-closing {
        padding: 0.5rem;
    }
}

/* Play video modal */
.admin-play-video-modal {
    --admin-scroll-track: transparent;
    --admin-scroll-thumb: rgba(148, 163, 184, 0.22);
    --admin-scroll-thumb-hover: rgba(148, 163, 184, 0.36);
}

.admin-play-video-modal .modal-body {
    overflow: visible;
}

.admin-play-video-layout {
    display: flex;
    align-items: stretch;
    gap: 0.75rem;
    min-width: 0;
    max-height: min(480px, calc(100vh - 10rem));
}

.admin-play-video-media {
    flex: 0 0 38%;
    min-width: 0;
    align-self: stretch;
    display: flex;
    flex-direction: column;
    background: #000;
    border-radius: 0.5rem;
    overflow: hidden;
}

.admin-play-video-player {
    display: block;
    flex: 1 1 auto;
    width: 100%;
    height: 100%;
    min-height: 100%;
    background: #000;
    object-fit: contain;
}

.admin-play-video-details {
    flex: 1;
    min-width: 0;
    min-height: 0;
    display: flex;
    flex-direction: column;
    gap: 0.55rem;
    padding: 0.75rem 0.85rem;
    border-radius: 0.65rem;
    background: linear-gradient(145deg, rgba(85, 110, 230, 0.05), rgba(0, 0, 0, 0.02));
    overflow: hidden;
}

.admin-play-video-details-head {
    display: flex;
    align-items: center;
    gap: 0.4rem;
    padding-bottom: 0.45rem;
    border-bottom: 1px solid rgba(0, 0, 0, 0.06);
    font-size: 12px;
    font-weight: 500;
    color: #495057;
}

.admin-play-video-details-head i {
    font-size: 15px;
    color: #556ee6;
}

.admin-play-video-meta-list {
    display: flex;
    flex-direction: column;
    gap: 0.3rem;
    margin: 0;
}

.admin-play-video-meta-row {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 0.65rem;
    padding: 0.38rem 0.5rem;
    border-radius: 0.4rem;
    background: rgba(255, 255, 255, 0.45);
}

.admin-play-video-meta-row dt {
    margin: 0;
    font-size: 10px;
    font-weight: 500;
    letter-spacing: 0.03em;
    text-transform: uppercase;
    color: #6c757d;
    flex-shrink: 0;
}

.admin-play-video-meta-row dd {
    margin: 0;
    font-size: 11.5px;
    font-weight: 400;
    color: #343a40;
    text-align: right;
    min-width: 0;
}

.admin-play-video-file-value {
    display: inline-flex;
    align-items: center;
    justify-content: flex-end;
    gap: 0.35rem;
    max-width: 100%;
}

.admin-play-video-file-name {
    min-width: 0;
}

.admin-play-video-download {
    display: inline-flex;
    align-items: center;
    flex-shrink: 0;
    color: #6c757d;
    font-size: 14px;
    line-height: 1;
    text-decoration: none;
    opacity: 0.8;
    transition: opacity 0.15s ease, color 0.15s ease;
}

.admin-play-video-download:hover {
    color: #495057;
    opacity: 1;
}

.admin-play-video-badge {
    display: inline-flex;
    align-items: center;
    padding: 0.12rem 0.45rem;
    font-size: 10px;
    font-weight: 500;
    line-height: 1.2;
    border-radius: 999px;
    white-space: nowrap;
}

.admin-play-video-badge.is-success {
    color: #198754;
    background: rgba(25, 135, 84, 0.12);
}

.admin-play-video-badge.is-info {
    color: #0d6efd;
    background: rgba(13, 110, 253, 0.12);
}

.admin-play-video-badge.is-danger {
    color: #dc3545;
    background: rgba(220, 53, 69, 0.12);
}

.admin-play-video-badge.is-muted {
    color: #6c757d;
    background: rgba(0, 0, 0, 0.06);
}

.admin-play-video-section {
    padding-top: 0.15rem;
}

.admin-play-video-section-desc {
    flex: 1 1 auto;
    min-height: 0;
    display: flex;
    flex-direction: column;
}

.admin-play-video-section-label {
    display: block;
    margin-bottom: 0.3rem;
    font-size: 10px;
    font-weight: 500;
    letter-spacing: 0.04em;
    text-transform: uppercase;
    color: #6c757d;
}

.admin-play-video-section-text {
    font-size: 11.5px;
    font-weight: 400;
    line-height: 1.45;
    color: #343a40;
}

.admin-play-video-tags {
    display: flex;
    flex-wrap: wrap;
    gap: 0.3rem;
}

.admin-play-video-tag {
    display: inline-flex;
    align-items: center;
    padding: 0.15rem 0.45rem;
    font-size: 10px;
    font-weight: 400;
    line-height: 1.2;
    color: #556ee6;
    background: rgba(85, 110, 230, 0.1);
    border-radius: 999px;
}

.admin-play-video-desc-box {
    flex: 1 1 auto;
    min-height: 4.5rem;
    padding: 0.5rem 0.55rem;
    font-size: 11.5px;
    font-weight: 400;
    line-height: 1.45;
    color: #495057;
    white-space: pre-wrap;
    word-break: break-word;
    border-radius: 0.45rem;
    background: rgba(255, 255, 255, 0.5);
    overflow-y: auto;
    scrollbar-width: thin;
    scrollbar-color: var(--admin-scroll-thumb) var(--admin-scroll-track);
}

.admin-play-video-desc-box::-webkit-scrollbar {
    width: 2px;
}

.admin-play-video-desc-box::-webkit-scrollbar-track {
    background: transparent;
}

.admin-play-video-desc-box::-webkit-scrollbar-thumb {
    background: var(--admin-scroll-thumb);
    border-radius: 999px;
}

.admin-play-video-desc-box::-webkit-scrollbar-thumb:hover {
    background: var(--admin-scroll-thumb-hover);
}

.admin-play-video-clamp-2 {
    display: -webkit-box;
    -webkit-line-clamp: 2;
    -webkit-box-orient: vertical;
    overflow: hidden;
}

body.admin-dashboard-dark .admin-play-video-modal {
    --admin-scroll-thumb: rgba(148, 163, 184, 0.14);
    --admin-scroll-thumb-hover: rgba(148, 163, 184, 0.24);
}

body.admin-dashboard-dark .admin-play-video-details {
    background: linear-gradient(145deg, rgba(99, 102, 241, 0.08), rgba(255, 255, 255, 0.02));
}

body.admin-dashboard-dark .admin-play-video-details-head {
    color: var(--dash-text);
    border-bottom-color: rgba(255, 255, 255, 0.06);
}

body.admin-dashboard-dark .admin-play-video-details-head i {
    color: #818cf8;
}

body.admin-dashboard-dark .admin-play-video-meta-row {
    background: rgba(255, 255, 255, 0.04);
}

body.admin-dashboard-dark .admin-play-video-meta-row dt,
body.admin-dashboard-dark .admin-play-video-section-label {
    color: var(--dash-muted);
}

body.admin-dashboard-dark .admin-play-video-meta-row dd,
body.admin-dashboard-dark .admin-play-video-section-text {
    color: var(--dash-text);
}

body.admin-dashboard-dark .admin-play-video-download {
    color: var(--dash-muted);
}

body.admin-dashboard-dark .admin-play-video-download:hover {
    color: var(--dash-text);
}

body.admin-dashboard-dark .admin-play-video-desc-box {
    color: var(--dash-text);
    background: rgba(255, 255, 255, 0.04);
}

body.admin-dashboard-dark .admin-play-video-tag {
    color: #a5b4fc;
    background: rgba(99, 102, 241, 0.14);
}

body.admin-dashboard-dark .admin-play-video-badge.is-success {
    color: #86efac;
    background: rgba(74, 222, 128, 0.12);
}

body.admin-dashboard-dark .admin-play-video-badge.is-info {
    color: #93c5fd;
    background: rgba(59, 130, 246, 0.12);
}

body.admin-dashboard-dark .admin-play-video-badge.is-danger {
    color: #f87171;
    background: rgba(248, 113, 113, 0.12);
}

body.admin-dashboard-dark .admin-play-video-badge.is-muted {
    color: var(--dash-muted);
    background: rgba(255, 255, 255, 0.06);
}

@media (max-width: 575px) {
    .admin-play-video-layout {
        flex-direction: column;
    }

    .admin-play-video-media {
        flex: none;
        width: 100%;
        min-height: 220px;
    }

    .admin-play-video-player {
        min-height: 220px;
    }
}

body.admin-dashboard-dark .admin-video-management-page .modal-content>.admin-modal-loading {
    background: rgba(15, 23, 42, 0.78) !important;
}

body.admin-dashboard-dark .admin-video-management-page .admin-table-loading {
    background: rgba(15, 23, 42, 0.72);
}

body.admin-dashboard-dark .admin-video-form-modal .modal-content {
    box-shadow: 0 18px 48px rgba(0, 0, 0, 0.45);
}

body.admin-dashboard-dark .admin-video-form-modal-header,
body.admin-dashboard-dark .admin-video-form-footer {
    border-color: var(--dash-card-border) !important;
}

body.admin-dashboard-dark .admin-video-form-modal-subtitle,
body.admin-dashboard-dark .admin-video-form-section-desc,
body.admin-dashboard-dark .admin-video-form-hint,
body.admin-dashboard-dark .admin-video-form-file-copy small {
    color: var(--dash-muted);
}

body.admin-dashboard-dark .admin-video-form-label,
body.admin-dashboard-dark .admin-video-form-current-file-label {
    color: #94a3b8;
}

body.admin-dashboard-dark .admin-video-form-section--group {
    background: rgba(99, 102, 241, 0.06);
    border-color: rgba(129, 140, 248, 0.12);
}

body.admin-dashboard-dark .admin-video-form-section-title {
    color: #818cf8;
}

body.admin-dashboard-dark .admin-video-form-input,
body.admin-dashboard-dark .admin-video-form-modal .form-control.admin-video-form-input {
    color: var(--dash-text);
    background: rgba(255, 255, 255, 0.05);
    border-color: rgba(255, 255, 255, 0.08);
}

body.admin-dashboard-dark .admin-video-form-input:focus,
body.admin-dashboard-dark .admin-video-form-modal .form-control.admin-video-form-input:focus {
    background: rgba(255, 255, 255, 0.07);
    border-color: rgba(129, 140, 248, 0.32);
    box-shadow: 0 0 0 0.12rem rgba(99, 102, 241, 0.08);
}

body.admin-dashboard-dark .admin-video-form-hint code {
    background: rgba(255, 255, 255, 0.06);
    color: #cbd5e1;
}

body.admin-dashboard-dark .admin-video-form-current-file {
    background: rgba(52, 195, 143, 0.1);
    border-color: rgba(52, 195, 143, 0.18);
}

body.admin-dashboard-dark .admin-video-form-current-file-link {
    color: #818cf8;
}

body.admin-dashboard-dark .admin-video-form-file {
    background: rgba(255, 255, 255, 0.03);
    border-color: rgba(129, 140, 248, 0.22);
}

body.admin-dashboard-dark .admin-video-form-file:hover {
    background: rgba(99, 102, 241, 0.08);
    border-color: rgba(129, 140, 248, 0.35);
}

body.admin-dashboard-dark .admin-video-form-file-copy strong {
    color: var(--dash-text);
}

body.admin-dashboard-dark .admin-video-form-file-icon,
body.admin-dashboard-dark .admin-video-form-file-action {
    background: rgba(99, 102, 241, 0.14);
    color: #a5b4fc;
}

body.admin-dashboard-dark .admin-video-form-modal {
    --admin-scroll-thumb: rgba(148, 163, 184, 0.14);
    --admin-scroll-thumb-hover: rgba(148, 163, 184, 0.24);
}

.admin-modal-loading-spinner {
    width: 1.25rem;
    height: 1.25rem;
    border-width: 0.15em;
    color: #fff;
}

/* YouTube details modal */
.admin-yt-details-link {
    font-size: 12px;
    text-decoration: none;
    color: #34c38f !important;
}

.admin-yt-details-link .mdi-youtube {
    color: #34c38f;
}

.admin-yt-details-link:hover {
    text-decoration: underline;
    color: #2ca579 !important;
}

.admin-yt-details-link:hover .mdi-youtube {
    color: #2ca579;
}

.admin-yt-status-cell {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: 0.35rem;
    flex-wrap: wrap;
}

.admin-yt-details-link-text {
    margin-left: 0.15rem;
}

.admin-yt-view-link {
    color: #34c38f;
}

.admin-yt-view-link:hover {
    color: #2ca579;
}

.admin-youtube-details-modal {
    --admin-scroll-track: transparent;
    --admin-scroll-thumb: rgba(148, 163, 184, 0.22);
    --admin-scroll-thumb-hover: rgba(148, 163, 184, 0.36);
}

.admin-youtube-details-modal .admin-youtube-details-dialog {
    width: 100%;
    max-width: 860px;
    height: auto;
    min-height: 0;
    max-height: calc(100vh - 2rem);
    display: flex;
    align-items: center;
}

.admin-youtube-details-modal .modal-content {
    display: flex;
    flex-direction: column;
    width: 100%;
    height: 55vh;
    min-height: 440px;
    max-height: calc(100vh - 2rem);
    overflow: hidden;
    border-radius: 0.75rem;
    border: 1px solid rgba(0, 0, 0, 0.06);
    box-shadow: 0 18px 48px rgba(15, 23, 42, 0.18);
}

.admin-youtube-details-modal .admin-youtube-details-body {
    flex: 1 1 auto;
    min-height: 0;
    display: flex;
    flex-direction: column;
    overflow: hidden;
}

.admin-youtube-details-header {
    border-bottom: 1px solid rgba(0, 0, 0, 0.06);
}

.admin-youtube-details-header-icon {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 2rem;
    height: 2rem;
    border-radius: 0.5rem;
    background: rgba(255, 0, 0, 0.1);
    color: #ff0000;
    flex-shrink: 0;
}

.admin-youtube-details-header-icon i {
    font-size: 18px;
}

.admin-youtube-details-channel-label {
    font-size: 11px;
    color: #6c757d;
    margin-top: 0.1rem;
}

.admin-youtube-details-refresh {
    padding: 0.2rem 0.45rem;
}

.admin-youtube-details-loading {
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 0.55rem;
    flex: 1 1 auto;
    min-height: 220px;
    font-size: 13px;
    color: #6c757d;
}

.admin-youtube-details-alert {
    font-size: 13px;
}

.admin-youtube-details-mode-label {
    display: block;
    font-size: 10px;
    font-weight: 500;
    color: #556ee6;
    letter-spacing: 0.03em;
    text-transform: uppercase;
}

.admin-youtube-details-layout {
    display: flex;
    align-items: stretch;
    gap: 0;
    min-width: 0;
    flex: 1 1 auto;
    min-height: 0;
    height: 100%;
}

.admin-youtube-details-media {
    flex: 0 0 300px;
    width: 300px;
    max-width: 300px;
    min-width: 0;
    min-height: 0;
    display: flex;
    flex-direction: column;
    background: #0a0a0a;
    border-right: 1px solid rgba(255, 255, 255, 0.06);
}

.admin-youtube-details-player-wrap {
    flex: 1 1 auto;
    min-height: 0;
    display: flex;
    align-items: center;
    justify-content: center;
    background: #000;
}

.admin-youtube-details-player {
    width: 100%;
    height: 100%;
    border: 0;
    display: block;
    background: #000;
}

.admin-youtube-details-player-placeholder {
    flex: 1 1 auto;
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    gap: 0.5rem;
    color: #adb5bd;
    font-size: 12px;
    background: #111;
}

.admin-youtube-details-player-placeholder i {
    font-size: 2rem;
    color: #ff0000;
    opacity: 0.7;
}

.admin-youtube-details-panel {
    flex: 1;
    min-width: 0;
    min-height: 0;
    display: flex;
    flex-direction: column;
    background: linear-gradient(180deg, rgba(255, 0, 0, 0.03), rgba(0, 0, 0, 0.01));
    overflow: hidden;
}

.admin-youtube-details-head {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 0.65rem;
    flex-shrink: 0;
    padding: 0.65rem 0.85rem;
    border-bottom: 1px solid rgba(0, 0, 0, 0.06);
    font-size: 12px;
    font-weight: 500;
    color: #495057;
}

.admin-youtube-details-head-main {
    display: inline-flex;
    align-items: center;
    gap: 0.4rem;
    min-width: 0;
}

.admin-youtube-details-head i {
    font-size: 15px;
    color: #ff0000;
}

.admin-youtube-details-fetched {
    font-size: 10px;
    font-weight: 400;
    color: #6c757d;
    white-space: nowrap;
}

.admin-youtube-details-panel-body {
    flex: 1 1 auto;
    min-height: 0;
    padding: 0.75rem 0.85rem;
    overflow-y: auto;
    scrollbar-width: thin;
    scrollbar-color: var(--admin-scroll-thumb) var(--admin-scroll-track);
}

.admin-youtube-details-stats-bar {
    display: grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: 0.3rem;
    flex-shrink: 0;
    padding: 0.45rem 0.5rem;
    border-top: 1px solid rgba(255, 255, 255, 0.08);
    background: rgba(255, 255, 255, 0.04);
}

.admin-youtube-details-media .admin-youtube-details-stat-pill {
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    gap: 0.08rem;
    padding: 0.32rem 0.28rem;
    border-radius: 0.4rem;
    background: rgba(255, 255, 255, 0.08);
    text-align: center;
    min-width: 0;
}

.admin-youtube-details-media .admin-youtube-details-stat-pill span {
    display: block;
    font-size: 8px;
    font-weight: 500;
    letter-spacing: 0.03em;
    text-transform: uppercase;
    color: rgba(255, 255, 255, 0.52);
    line-height: 1.15;
}

.admin-youtube-details-media .admin-youtube-details-stat-pill strong {
    display: block;
    margin-top: 0;
    font-size: 11px;
    font-weight: 600;
    color: #f1f3f5;
    line-height: 1.15;
}

.admin-youtube-details-media .admin-youtube-details-open-link {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: 0.25rem;
    grid-column: 1 / -1;
    padding: 0.35rem 0.45rem;
    border-radius: 0.4rem;
    font-size: 10px;
    font-weight: 500;
    color: #fca5a5;
    background: rgba(248, 113, 113, 0.12);
    text-decoration: none;
    transition: background 0.15s ease, color 0.15s ease;
}

.admin-youtube-details-media .admin-youtube-details-open-link i {
    font-size: 12px;
    line-height: 1;
}

.admin-youtube-details-media .admin-youtube-details-open-link:hover {
    color: #fecaca;
    background: rgba(248, 113, 113, 0.2);
}

.admin-youtube-details-panel-body::-webkit-scrollbar,
.admin-youtube-details-edit-textarea::-webkit-scrollbar {
    width: 2px;
}

.admin-youtube-details-panel-body::-webkit-scrollbar-track,
.admin-youtube-details-edit-textarea::-webkit-scrollbar-track {
    background: transparent;
}

.admin-youtube-details-panel-body::-webkit-scrollbar-thumb,
.admin-youtube-details-edit-textarea::-webkit-scrollbar-thumb {
    background: var(--admin-scroll-thumb);
    border-radius: 999px;
}

.admin-youtube-details-panel-body::-webkit-scrollbar-thumb:hover,
.admin-youtube-details-edit-textarea::-webkit-scrollbar-thumb:hover {
    background: var(--admin-scroll-thumb-hover);
}

.admin-youtube-details-meta-grid {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 0.35rem;
    margin-bottom: 0.65rem;
    flex-shrink: 0;
}

.admin-youtube-details-meta-card {
    display: flex;
    flex-direction: column;
    gap: 0.15rem;
    min-width: 0;
    padding: 0.45rem 0.55rem;
    border-radius: 0.45rem;
    background: rgba(255, 255, 255, 0.45);
}

.admin-youtube-details-meta-label {
    font-size: 9px;
    font-weight: 500;
    letter-spacing: 0.04em;
    text-transform: uppercase;
    color: #6c757d;
}

.admin-youtube-details-meta-value {
    font-size: 11.5px;
    font-weight: 500;
    line-height: 1.35;
    color: #343a40;
}

.admin-youtube-details-badge {
    display: inline-flex;
    align-items: center;
    padding: 0.12rem 0.45rem;
    font-size: 10px;
    font-weight: 500;
    line-height: 1.2;
    border-radius: 999px;
    white-space: nowrap;
}

.admin-youtube-details-badge.is-info {
    color: #0d6efd;
    background: rgba(13, 110, 253, 0.12);
}

.admin-youtube-details-section {
    padding-top: 0.5rem;
}

.admin-youtube-details-section-label {
    display: block;
    margin-bottom: 0.3rem;
    font-size: 10px;
    font-weight: 500;
    letter-spacing: 0.04em;
    text-transform: uppercase;
    color: #6c757d;
}

.admin-youtube-details-section-text {
    font-size: 11.5px;
    font-weight: 400;
    line-height: 1.45;
    color: #343a40;
}

.admin-youtube-details-tags {
    display: flex;
    flex-wrap: wrap;
    gap: 0.3rem;
}

.admin-youtube-details-tag {
    display: inline-flex;
    align-items: center;
    padding: 0.15rem 0.45rem;
    font-size: 10px;
    font-weight: 400;
    line-height: 1.2;
    color: #dc3545;
    background: rgba(220, 53, 69, 0.1);
    border-radius: 999px;
}

.admin-youtube-details-desc-text {
    padding: 0.55rem 0.6rem;
    font-size: 11.5px;
    font-weight: 400;
    line-height: 1.55;
    color: #495057;
    white-space: pre-wrap;
    word-break: break-word;
    border-radius: 0.45rem;
    background: rgba(255, 255, 255, 0.45);
}

.admin-youtube-details-readonly-grid {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 0.35rem;
}

.admin-youtube-details-readonly-item {
    display: flex;
    flex-direction: column;
    gap: 0.12rem;
    min-width: 0;
    padding: 0.4rem 0.5rem;
    border-radius: 0.4rem;
    background: rgba(255, 255, 255, 0.35);
}

.admin-youtube-details-readonly-item span {
    font-size: 9px;
    font-weight: 500;
    letter-spacing: 0.04em;
    text-transform: uppercase;
    color: #6c757d;
}

.admin-youtube-details-readonly-item strong {
    font-size: 11px;
    font-weight: 500;
    color: #343a40;
}

.admin-youtube-details-field-label {
    display: block;
    margin-bottom: 0.35rem;
    font-size: 10px;
    font-weight: 600;
    letter-spacing: 0.04em;
    text-transform: uppercase;
    color: #6c757d;
}

.admin-youtube-details-field-hint {
    font-weight: 400;
    text-transform: none;
    letter-spacing: 0;
    color: #adb5bd;
}

.admin-youtube-details-control {
    padding: 0.55rem 0.65rem;
    border-radius: 2px;
    background: rgba(255, 255, 255, 0.42);
    border: 1px solid rgba(0, 0, 0, 0.03);
}

.admin-youtube-details-edit-form .admin-youtube-details-input,
.admin-youtube-details-edit-form .form-control.admin-youtube-details-input {
    border: 1px solid rgba(0, 0, 0, 0.035);
    background: rgba(255, 255, 255, 0.72);
    padding: 0.45rem 0.55rem;
    font-size: 12px;
    font-weight: 400;
    line-height: 1.4;
    color: #343a40;
    border-radius: 0.3rem;
    box-shadow: none;
    transition: border-color 0.15s ease, background 0.15s ease, box-shadow 0.15s ease;
}

.admin-youtube-details-edit-form select.admin-youtube-details-input {
    cursor: pointer;
    padding-right: 1.75rem;
}

.admin-youtube-details-edit-form .admin-youtube-details-input:focus,
.admin-youtube-details-edit-form .form-control.admin-youtube-details-input:focus {
    border-color: rgba(85, 110, 230, 0.28);
    background: #fff;
    box-shadow: 0 0 0 0.12rem rgba(85, 110, 230, 0.08);
    outline: 0;
}

.admin-youtube-details-edit-textarea {
    min-height: 100px;
    resize: vertical;
}

.admin-youtube-details-footer {
    display: flex;
    align-items: center;
    border-top: 1px solid rgba(0, 0, 0, 0.06);
    gap: 0.5rem;
}

.admin-youtube-details-footer-view {
    justify-content: flex-end;
}

.admin-youtube-details-footer-edit {
    justify-content: space-between;
}

.admin-youtube-details-footer-edit .admin-modal-action-btn {
    min-width: 88px;
    padding: 0.35rem 0.85rem;
    font-size: 12px;
    font-weight: 500;
    border-radius: 0.45rem;
}

.admin-youtube-details-btn-spinner {
    width: 0.85rem;
    height: 0.85rem;
    border-width: 0.12em;
    vertical-align: -0.1em;
}

body.admin-dashboard-dark .admin-youtube-details-modal {
    --admin-scroll-thumb: rgba(148, 163, 184, 0.14);
    --admin-scroll-thumb-hover: rgba(148, 163, 184, 0.24);
}

body.admin-dashboard-dark .admin-youtube-details-loading {
    color: var(--dash-muted);
}

body.admin-dashboard-dark .admin-youtube-details-mode-label {
    color: #818cf8;
}

body.admin-dashboard-dark .admin-youtube-details-header {
    border-bottom-color: rgba(255, 255, 255, 0.06);
}

body.admin-dashboard-dark .admin-youtube-details-header-icon {
    background: rgba(255, 0, 0, 0.14);
}

body.admin-dashboard-dark .admin-youtube-details-channel-label {
    color: var(--dash-muted);
}

body.admin-dashboard-dark .admin-youtube-details-modal .modal-content {
    border-color: rgba(255, 255, 255, 0.06);
    box-shadow: 0 18px 48px rgba(0, 0, 0, 0.35);
}

body.admin-dashboard-dark .admin-youtube-details-panel {
    background: linear-gradient(145deg, rgba(255, 0, 0, 0.08), rgba(255, 255, 255, 0.02));
}

body.admin-dashboard-dark .admin-youtube-details-head {
    color: var(--dash-text);
    border-bottom-color: rgba(255, 255, 255, 0.06);
}

body.admin-dashboard-dark .admin-youtube-details-fetched,
body.admin-dashboard-dark .admin-youtube-details-meta-label,
body.admin-dashboard-dark .admin-youtube-details-section-label,
body.admin-dashboard-dark .admin-youtube-details-field-label,
body.admin-dashboard-dark .admin-youtube-details-readonly-item span,
body.admin-dashboard-dark .admin-youtube-details-stat-pill span {
    color: var(--dash-muted);
}

body.admin-dashboard-dark .admin-youtube-details-stats-bar {
    border-top-color: rgba(255, 255, 255, 0.08);
    background: rgba(0, 0, 0, 0.25);
}

body.admin-dashboard-dark .admin-youtube-details-media .admin-youtube-details-stat-pill {
    background: rgba(255, 255, 255, 0.06);
}

body.admin-dashboard-dark .admin-youtube-details-meta-card,
body.admin-dashboard-dark .admin-youtube-details-readonly-item {
    background: rgba(255, 255, 255, 0.04);
}

body.admin-dashboard-dark .admin-youtube-details-control {
    background: rgba(255, 255, 255, 0.03);
    border-color: rgba(255, 255, 255, 0.04);
}

body.admin-dashboard-dark .admin-youtube-details-edit-form .admin-youtube-details-input,
body.admin-dashboard-dark .admin-youtube-details-edit-form .form-control.admin-youtube-details-input {
    color: var(--dash-text);
    background: rgba(255, 255, 255, 0.05);
    border-color: rgba(255, 255, 255, 0.08);
}

body.admin-dashboard-dark .admin-youtube-details-edit-form .admin-youtube-details-input:focus,
body.admin-dashboard-dark .admin-youtube-details-edit-form .form-control.admin-youtube-details-input:focus {
    background: rgba(255, 255, 255, 0.07);
    border-color: rgba(129, 140, 248, 0.32);
    box-shadow: 0 0 0 0.12rem rgba(99, 102, 241, 0.08);
}

body.admin-dashboard-dark .admin-youtube-details-field-hint {
    color: var(--dash-muted);
}

body.admin-dashboard-dark .admin-youtube-details-meta-value,
body.admin-dashboard-dark .admin-youtube-details-section-text,
body.admin-dashboard-dark .admin-youtube-details-desc-text,
body.admin-dashboard-dark .admin-youtube-details-readonly-item strong,
body.admin-dashboard-dark .admin-youtube-details-stat-pill strong {
    color: var(--dash-text-bright);
}

body.admin-dashboard-dark .admin-youtube-details-desc-text {
    background: rgba(255, 255, 255, 0.04);
}

body.admin-dashboard-dark .admin-youtube-details-open-link {
    color: #fca5a5;
    background: rgba(248, 113, 113, 0.12);
}

body.admin-dashboard-dark .admin-youtube-details-open-link:hover {
    color: #fecaca;
    background: rgba(248, 113, 113, 0.18);
}

body.admin-dashboard-dark .admin-youtube-details-tag {
    color: #fca5a5;
    background: rgba(248, 113, 113, 0.14);
}

body.admin-dashboard-dark .admin-youtube-details-footer {
    border-top-color: rgba(255, 255, 255, 0.06);
}

@media (max-width: 767px) {
    .admin-youtube-details-modal .modal-content {
        height: 85vh;
        max-height: calc(100vh - 1rem);
        min-height: 480px;
    }

    .admin-youtube-details-layout {
        flex-direction: column;
    }

    .admin-youtube-details-media {
        flex: 0 0 auto;
        width: 100%;
        max-width: none;
        border-right: 0;
        border-bottom: 1px solid rgba(255, 255, 255, 0.06);
    }

    .admin-youtube-details-player-wrap {
        max-height: 42vh;
    }

    .admin-youtube-details-media .admin-youtube-details-stats-bar {
        grid-template-columns: repeat(3, minmax(0, 1fr));
    }

    .admin-youtube-details-media .admin-youtube-details-open-link {
        grid-column: 1 / -1;
    }

    .admin-youtube-details-meta-grid,
    .admin-youtube-details-readonly-grid {
        grid-template-columns: 1fr;
    }
}

/* Social media upload modal */
.admin-social-upload-modal {
    position: relative;
    overflow: hidden;
    --admin-scroll-track: transparent;
    --admin-scroll-thumb: rgba(148, 163, 184, 0.22);
    --admin-scroll-thumb-hover: rgba(148, 163, 184, 0.36);
}

.admin-social-upload-modal .admin-social-modal-body,
.admin-social-upload-modal textarea.form-control {
    scrollbar-width: thin;
    scrollbar-color: var(--admin-scroll-thumb) var(--admin-scroll-track);
}

.admin-social-upload-modal .admin-social-modal-body::-webkit-scrollbar,
.admin-social-upload-modal textarea.form-control::-webkit-scrollbar {
    width: 2px;
    height: 2px;
}

.admin-social-upload-modal .admin-social-modal-body::-webkit-scrollbar-track,
.admin-social-upload-modal textarea.form-control::-webkit-scrollbar-track {
    background: transparent;
}

.admin-social-upload-modal .admin-social-modal-body::-webkit-scrollbar-thumb,
.admin-social-upload-modal textarea.form-control::-webkit-scrollbar-thumb {
    background: var(--admin-scroll-thumb);
    border-radius: 999px;
}

.admin-social-upload-modal .admin-social-modal-body::-webkit-scrollbar-thumb:hover,
.admin-social-upload-modal textarea.form-control::-webkit-scrollbar-thumb:hover {
    background: var(--admin-scroll-thumb-hover);
}

.admin-social-modal-header {
    display: flex;
    align-items: flex-start;
    justify-content: space-between;
    gap: 1rem;
    padding: 1.1rem 1.25rem 1rem;
    border-bottom: 1px solid rgba(0, 0, 0, 0.08);
}

.admin-social-modal-header-main {
    display: flex;
    align-items: flex-start;
    gap: 0.85rem;
    min-width: 0;
}

.admin-social-modal-icon {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 42px;
    height: 42px;
    flex-shrink: 0;
    font-size: 22px;
    color: #fff;
    background: linear-gradient(135deg, #ff0000, #cc0000);
    border-radius: 0.65rem;
    box-shadow: 0 4px 14px rgba(255, 0, 0, 0.25);
}

.admin-social-modal-subtitle {
    font-size: 13px;
    font-weight: 500;
    color: #495057;
    line-height: 1.4;
}

.admin-social-code {
    display: inline-block;
    margin-right: 0.35rem;
    padding: 0.1rem 0.4rem;
    font-size: 11px;
    font-weight: 700;
    color: #556ee6;
    background: rgba(85, 110, 230, 0.1);
    border-radius: 0.25rem;
}

.admin-social-modal-file {
    margin-top: 0.2rem;
    font-size: 11px;
    color: #6c757d;
}

.admin-social-modal-body {
    max-height: calc(100vh - 220px);
    overflow-y: auto;
    padding: 1rem 1.25rem 1.25rem;
}

.admin-social-modal-footer {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 1rem;
    padding: 0.85rem 1.25rem;
    border-top: 1px solid rgba(0, 0, 0, 0.08);
}

.admin-social-footer-actions {
    display: flex;
    align-items: center;
    gap: 0.75rem;
}

.admin-yt-footer-status {
    display: inline-flex;
    align-items: center;
    gap: 0.35rem;
    font-size: 12px;
    font-weight: 600;
}

.admin-yt-footer-status--success {
    color: #198754;
}

.admin-yt-footer-status--danger {
    color: #dc3545;
}

.admin-social-tabs-minimal {
    display: flex;
    flex-wrap: wrap;
    gap: 0.5rem;
    padding: 0.65rem;
    margin-bottom: 1rem;
    background: rgba(0, 0, 0, 0.03);
    border: none;
    border-radius: 0.65rem;
}

.admin-social-tab-min {
    display: inline-flex;
    align-items: center;
    gap: 0.4rem;
    padding: 0.45rem 0.85rem;
    font-size: 13px;
    font-weight: 500;
    color: #6c757d;
    background: transparent;
    border: 1px solid transparent;
    border-radius: 0.45rem;
    transition: color 0.15s ease, border-color 0.15s ease, background 0.15s ease, box-shadow 0.15s ease;
}

.admin-social-tab-min i {
    font-size: 16px;
    line-height: 1;
}

.admin-social-tab-min:hover:not(:disabled) {
    color: #495057;
    background: rgba(255, 255, 255, 0.6);
}

.admin-social-tab-min.is-active {
    color: #556ee6;
    border-color: rgba(85, 110, 230, 0.2);
    background: #fff;
    box-shadow: 0 1px 4px rgba(0, 0, 0, 0.06);
}

.admin-social-tab-min.is-disabled,
.admin-social-tab-min:disabled {
    opacity: 0.45;
    cursor: not-allowed;
}

.admin-social-tab-soon {
    font-size: 9px;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: 0.05em;
    padding: 0.12rem 0.4rem;
    border-radius: 999px;
    background: rgba(0, 0, 0, 0.06);
    color: #6c757d;
}

.admin-social-tab-min--youtube.is-active {
    color: #dc3545;
    border-color: rgba(220, 53, 69, 0.22);
    background: rgba(220, 53, 69, 0.06);
    box-shadow: 0 1px 4px rgba(220, 53, 69, 0.12);
}

.admin-social-upload-modal .modal-footer .admin-modal-action-btn {
    min-width: 130px;
}

/* YouTube upload form */
.admin-yt-form {
    display: flex;
    flex-direction: column;
    gap: 1rem;
}

.admin-yt-panel {
    border: none;
    border-radius: 0.75rem;
    background: rgba(255, 255, 255, 0.18);
    overflow: hidden;
}

.admin-yt-panel-head {
    display: flex;
    align-items: flex-start;
    gap: 0.75rem;
    padding: 0.9rem 1rem 0.5rem;
    border-bottom: none;
    background: transparent;
}

.admin-yt-panel-icon {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 36px;
    height: 36px;
    flex-shrink: 0;
    font-size: 17px;
    border-radius: 0.5rem;
}

.admin-yt-panel-icon--content {
    color: #556ee6;
    background: rgba(85, 110, 230, 0.12);
}

.admin-yt-panel-icon--settings {
    color: #dc3545;
    background: rgba(220, 53, 69, 0.1);
}

.admin-yt-panel-title {
    margin: 0 0 0.15rem;
    font-size: 14px;
    font-weight: 700;
    color: #343a40;
}

.admin-yt-panel-desc {
    margin: 0;
    font-size: 12px;
    color: #6c757d;
    line-height: 1.4;
}

.admin-yt-panel-body {
    padding: 1rem;
}

.admin-yt-stack {
    display: flex;
    flex-direction: column;
    gap: 1rem;
}

.admin-yt-control {
    padding: 0.85rem;
    border: none;
    border-radius: 0.55rem;
    background: rgba(255, 255, 255, 0.22);
}

.admin-yt-control--switch {
    display: flex;
    flex-direction: column;
    justify-content: space-between;
}

.admin-yt-control-head {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 0.5rem;
    margin-bottom: 0.5rem;
}

.admin-yt-label {
    display: block;
    margin-bottom: 0.45rem;
    font-size: 13px;
    font-weight: 600;
    color: #343a40;
}

.admin-yt-control-head .admin-yt-label {
    margin-bottom: 0;
}

.admin-yt-hint {
    margin-top: 0.45rem;
    margin-bottom: 0;
    font-size: 11px;
    color: #6c757d;
    line-height: 1.45;
}

.admin-yt-pill {
    display: inline-flex;
    align-items: center;
    padding: 0.12rem 0.5rem;
    font-size: 10px;
    font-weight: 700;
    color: #6c757d;
    background: rgba(0, 0, 0, 0.05);
    border-radius: 999px;
}

.admin-yt-pill.is-danger {
    color: #dc3545;
    background: rgba(220, 53, 69, 0.1);
}

.admin-yt-switch-row {
    display: flex;
    align-items: center;
    min-height: 38px;
    margin-top: auto;
}

.admin-yt-switch-row .form-check {
    display: flex;
    align-items: center;
    gap: 0.55rem;
    margin: 0;
    padding: 0;
}

.admin-yt-switch-row .form-check-input {
    width: 2.1em;
    height: 1.1em;
    margin: 0;
}

.admin-yt-switch-row .form-check-label {
    font-size: 13px;
    font-weight: 500;
    color: #495057;
}

.admin-yt-check .form-check-label {
    font-size: 13px;
    font-weight: 500;
}

/* YouTube sidebar */
.admin-yt-sidebar {
    display: flex;
    flex-direction: column;
    gap: 0.85rem;
    height: 100%;
}

.admin-yt-sidebar-card {
    padding: 0.9rem;
    border: none;
    border-radius: 0.75rem;
    background: rgba(255, 255, 255, 0.18);
}

.admin-yt-sidebar-preview {
    position: relative;
    aspect-ratio: 16 / 9;
    border-radius: 0.65rem;
    overflow: hidden;
    background: #000;
    border: none;
    box-shadow: 0 4px 16px rgba(0, 0, 0, 0.12);
}

.admin-yt-sidebar-preview video {
    width: 100%;
    height: 100%;
    object-fit: cover;
}

.admin-yt-sidebar-preview-label {
    position: absolute;
    left: 0.5rem;
    bottom: 0.5rem;
    display: inline-flex;
    align-items: center;
    gap: 0.25rem;
    padding: 0.2rem 0.55rem;
    font-size: 11px;
    font-weight: 600;
    color: #fff;
    background: rgba(0, 0, 0, 0.7);
    border-radius: 999px;
    backdrop-filter: blur(4px);
}

.admin-yt-channel-panel {
    position: relative;
    overflow: hidden;
}

.admin-yt-channel-panel::before {
    content: "";
    position: absolute;
    top: 0;
    left: 0;
    right: 0;
    height: 2px;
    background: linear-gradient(90deg, #ff0000, #ff4444 55%, #cc0000);
    opacity: 0.9;
}

.admin-yt-channel-panel.is-connected::before {
    background: linear-gradient(90deg, #198754, #20c997);
}

.admin-yt-channel-head {
    width: 100%;
    margin-bottom: 0.75rem;
}

.admin-yt-channel-head i {
    color: #dc3545;
}

.admin-yt-channel-panel.is-connected .admin-yt-channel-head i {
    color: #198754;
}

.admin-yt-channel-live {
    display: inline-flex;
    align-items: center;
    gap: 0.3rem;
    margin-left: auto;
    font-size: 10px;
    font-weight: 700;
    letter-spacing: 0.04em;
    text-transform: uppercase;
    color: #198754;
}

.admin-yt-channel-live-dot {
    width: 6px;
    height: 6px;
    border-radius: 50%;
    background: #20c997;
    box-shadow: 0 0 0 0 rgba(32, 201, 151, 0.45);
    animation: admin-yt-live-pulse 2s ease-out infinite;
}

@keyframes admin-yt-live-pulse {
    0% {
        box-shadow: 0 0 0 0 rgba(32, 201, 151, 0.45);
    }

    70% {
        box-shadow: 0 0 0 6px rgba(32, 201, 151, 0);
    }

    100% {
        box-shadow: 0 0 0 0 rgba(32, 201, 151, 0);
    }
}

.admin-yt-channel-body {
    padding: 0.85rem;
    border-radius: 0.6rem;
    background: rgba(0, 0, 0, 0.03);
}

.admin-yt-channel-panel.is-disconnected .admin-yt-channel-body {
    background: linear-gradient(145deg, rgba(220, 53, 69, 0.05), rgba(0, 0, 0, 0.02));
}

.admin-yt-channel-panel.is-connected .admin-yt-channel-body {
    background: linear-gradient(145deg, rgba(25, 135, 84, 0.08), rgba(0, 0, 0, 0.02));
}

.admin-yt-channel-top {
    display: flex;
    align-items: center;
    gap: 0.75rem;
}

.admin-yt-channel-icon {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 44px;
    height: 44px;
    flex-shrink: 0;
    font-size: 22px;
    color: #fff;
    background: linear-gradient(135deg, #ff0000, #cc0000);
    border-radius: 0.65rem;
    box-shadow: 0 4px 12px rgba(255, 0, 0, 0.22);
}

.admin-yt-channel-name {
    font-size: 14px;
    font-weight: 700;
    line-height: 1.35;
    color: #343a40;
}

.admin-yt-channel-sub {
    margin-top: 0.15rem;
    font-size: 11px;
    color: #6c757d;
    line-height: 1.4;
}

.admin-yt-channel-actions {
    display: flex;
    flex-direction: column;
    gap: 0.55rem;
    margin-top: 0.85rem;
    padding-top: 0.75rem;
    border-top: 1px solid rgba(0, 0, 0, 0.06);
}

.admin-yt-channel-badge {
    display: inline-flex;
    align-items: center;
    align-self: flex-start;
    gap: 0.3rem;
    padding: 0.22rem 0.55rem;
    font-size: 10px;
    font-weight: 700;
    letter-spacing: 0.02em;
    border: none;
    border-radius: 999px;
}

.admin-yt-channel-badge--connected {
    color: #0f5132;
    background: rgba(25, 135, 84, 0.14);
}

.admin-yt-channel-badge--pending {
    color: #6c757d;
    background: rgba(0, 0, 0, 0.06);
}

.admin-yt-channel-avatar {
    width: 44px;
    height: 44px;
    flex-shrink: 0;
    border-radius: 50%;
    object-fit: cover;
    border: 2px solid rgba(25, 135, 84, 0.45);
    box-shadow: 0 0 0 3px rgba(25, 135, 84, 0.12);
}

.admin-yt-channel-btn {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: 0.4rem;
    width: 100%;
    padding: 0.48rem 0.75rem;
    font-size: 12px;
    font-weight: 600;
    line-height: 1.2;
    border: none;
    border-radius: 0.45rem;
    transition: background 0.15s ease, color 0.15s ease, transform 0.15s ease;
}

.admin-yt-channel-btn--connect {
    color: #fff;
    background: linear-gradient(135deg, #ff0000, #cc0000);
    box-shadow: 0 3px 10px rgba(255, 0, 0, 0.2);
}

.admin-yt-channel-btn--connect:hover:not(:disabled) {
    color: #fff;
    background: linear-gradient(135deg, #e60000, #b30000);
    transform: translateY(-1px);
}

.admin-yt-channel-btn--connect:disabled {
    opacity: 0.45;
    cursor: not-allowed;
    box-shadow: none;
}

.admin-yt-channel-btn--disconnect {
    color: #6c757d;
    background: rgba(0, 0, 0, 0.05);
}

.admin-yt-channel-btn--disconnect:hover:not(:disabled) {
    color: #dc3545;
    background: rgba(220, 53, 69, 0.1);
}

.admin-yt-channel-setup-hint {
    font-size: 11px;
    color: #6c757d;
    line-height: 1.45;
}

.admin-yt-sidebar-head {
    display: flex;
    align-items: center;
    gap: 0.45rem;
    margin-bottom: 0.65rem;
    font-size: 13px;
    font-weight: 700;
    color: #343a40;
}

.admin-yt-sidebar-head i {
    font-size: 16px;
    color: #6c757d;
}

.admin-yt-meta-grid {
    display: flex;
    flex-direction: column;
    gap: 0.35rem;
    margin: 0;
}

.admin-yt-meta-row {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 0.75rem;
    padding: 0.45rem 0.55rem;
    border-radius: 0.4rem;
    background: rgba(0, 0, 0, 0.03);
}

.admin-yt-meta-row dt {
    margin: 0;
    font-size: 11px;
    font-weight: 600;
    color: #6c757d;
    text-transform: uppercase;
    letter-spacing: 0.03em;
}

.admin-yt-meta-row dd {
    margin: 0;
    font-size: 12px;
    font-weight: 600;
    color: #343a40;
    text-align: right;
    min-width: 0;
}

.admin-yt-check-grid {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 0.45rem;
}

.admin-yt-check-item {
    display: flex;
    align-items: center;
    gap: 0.35rem;
    padding: 0.45rem 0.5rem;
    font-size: 11px;
    font-weight: 500;
    color: #6c757d;
    background: rgba(0, 0, 0, 0.03);
    border: none;
    border-radius: 0.4rem;
}

.admin-yt-check-item.is-done {
    color: #198754;
    background: rgba(25, 135, 84, 0.08);
}

.admin-yt-check-item i {
    font-size: 15px;
}

.admin-yt-status-banner {
    display: flex;
    align-items: center;
    gap: 0.4rem;
    margin-top: 0.65rem;
    padding: 0.55rem 0.65rem;
    font-size: 12px;
    font-weight: 600;
    border-radius: 0.45rem;
}

.admin-yt-status-banner--success {
    color: #198754;
    background: rgba(25, 135, 84, 0.1);
}

.admin-yt-status-banner--ready {
    color: #0d6efd;
    background: rgba(13, 110, 253, 0.1);
}

.admin-yt-status-banner--info {
    color: #6c757d;
    background: rgba(0, 0, 0, 0.04);
}

.admin-yt-url-box {
    display: flex;
    gap: 0.35rem;
}

.admin-yt-url-box .form-control {
    min-width: 0;
}

.admin-yt-url-box .btn {
    flex-shrink: 0;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    padding-inline: 0.75rem;
}

/* Dark mode — social upload modal */
body.admin-dashboard-dark .admin-social-modal-header,
body.admin-dashboard-dark .admin-social-modal-footer {
    border-color: var(--dash-card-border);
}

body.admin-dashboard-dark .admin-social-modal-subtitle {
    color: var(--dash-text);
}

body.admin-dashboard-dark .admin-social-modal-file,
body.admin-dashboard-dark .admin-social-code {
    color: var(--dash-muted);
}

body.admin-dashboard-dark .admin-social-code {
    color: #a5b4fc;
    background: rgba(99, 102, 241, 0.15);
}

body.admin-dashboard-dark .admin-social-tabs-minimal {
    background: rgba(255, 255, 255, 0.03);
}

body.admin-dashboard-dark .admin-social-tab-min {
    color: var(--dash-muted);
}

body.admin-dashboard-dark .admin-social-tab-min:hover:not(:disabled) {
    color: var(--dash-text);
    background: rgba(255, 255, 255, 0.04);
}

body.admin-dashboard-dark .admin-social-tab-min.is-active {
    color: #a5b4fc;
    background: rgba(99, 102, 241, 0.1);
    border-color: rgba(99, 102, 241, 0.25);
    box-shadow: none;
}

body.admin-dashboard-dark .admin-social-tab-min--youtube.is-active {
    color: #f87171;
    background: rgba(248, 113, 113, 0.1);
    border-color: rgba(248, 113, 113, 0.25);
}

body.admin-dashboard-dark .admin-social-tab-soon {
    background: rgba(255, 255, 255, 0.06);
    color: var(--dash-muted);
}

body.admin-dashboard-dark .admin-yt-panel,
body.admin-dashboard-dark .admin-yt-sidebar-card {
    background: rgba(255, 255, 255, 0.02);
}

body.admin-dashboard-dark .admin-yt-panel-head {
    background: transparent;
}

body.admin-dashboard-dark .admin-yt-panel-title,
body.admin-dashboard-dark .admin-yt-label,
body.admin-dashboard-dark .admin-yt-sidebar-head,
body.admin-dashboard-dark .admin-yt-meta-row dd {
    color: var(--dash-text-bright);
}

body.admin-dashboard-dark .admin-yt-panel-desc,
body.admin-dashboard-dark .admin-yt-hint,
body.admin-dashboard-dark .admin-yt-meta-row dt,
body.admin-dashboard-dark .admin-yt-pill {
    color: var(--dash-muted);
}

body.admin-dashboard-dark .admin-yt-control {
    background: rgba(255, 255, 255, 0.02);
}

body.admin-dashboard-dark .admin-yt-panel-icon--content {
    color: #a5b4fc;
    background: rgba(99, 102, 241, 0.15);
}

body.admin-dashboard-dark .admin-yt-panel-icon--settings {
    color: #f87171;
    background: rgba(248, 113, 113, 0.12);
}

body.admin-dashboard-dark .admin-yt-meta-row,
body.admin-dashboard-dark .admin-yt-check-item {
    background: rgba(255, 255, 255, 0.03);
}

body.admin-dashboard-dark .admin-yt-check-item.is-done {
    color: #86efac;
    background: rgba(74, 222, 128, 0.08);
}

body.admin-dashboard-dark .admin-yt-channel-name {
    color: var(--dash-text-bright);
}

body.admin-dashboard-dark .admin-yt-channel-sub,
body.admin-dashboard-dark .admin-yt-channel-setup-hint {
    color: var(--dash-muted);
}

body.admin-dashboard-dark .admin-yt-channel-body {
    background: rgba(255, 255, 255, 0.03);
}

body.admin-dashboard-dark .admin-yt-channel-panel.is-disconnected .admin-yt-channel-body {
    background: linear-gradient(145deg, rgba(248, 113, 113, 0.08), rgba(255, 255, 255, 0.02));
}

body.admin-dashboard-dark .admin-yt-channel-panel.is-connected .admin-yt-channel-body {
    background: linear-gradient(145deg, rgba(74, 222, 128, 0.1), rgba(255, 255, 255, 0.02));
}

body.admin-dashboard-dark .admin-yt-channel-actions {
    border-top-color: rgba(255, 255, 255, 0.06);
}

body.admin-dashboard-dark .admin-yt-channel-live {
    color: #86efac;
}

body.admin-dashboard-dark .admin-yt-channel-live-dot {
    background: #4ade80;
}

body.admin-dashboard-dark .admin-yt-channel-head i {
    color: #f87171;
}

body.admin-dashboard-dark .admin-yt-channel-panel.is-connected .admin-yt-channel-head i {
    color: #86efac;
}

body.admin-dashboard-dark .admin-yt-channel-badge--connected {
    color: #86efac;
    background: rgba(74, 222, 128, 0.14);
}

body.admin-dashboard-dark .admin-yt-channel-badge--pending {
    color: var(--dash-muted);
    background: rgba(255, 255, 255, 0.06);
}

body.admin-dashboard-dark .admin-yt-channel-avatar {
    border-color: rgba(74, 222, 128, 0.45);
    box-shadow: 0 0 0 3px rgba(74, 222, 128, 0.12);
}

body.admin-dashboard-dark .admin-yt-channel-btn--disconnect {
    color: var(--dash-muted);
    background: rgba(255, 255, 255, 0.05);
}

body.admin-dashboard-dark .admin-yt-channel-btn--disconnect:hover:not(:disabled) {
    color: #f87171;
    background: rgba(248, 113, 113, 0.12);
}

body.admin-dashboard-dark .admin-social-upload-modal {
    --admin-scroll-thumb: rgba(148, 163, 184, 0.14);
    --admin-scroll-thumb-hover: rgba(148, 163, 184, 0.24);
}

body.admin-dashboard-dark .admin-yt-switch-row .form-check-label {
    color: var(--dash-text);
}

body.admin-dashboard-dark .admin-yt-status-banner--success {
    color: #86efac;
    background: rgba(74, 222, 128, 0.1);
}

body.admin-dashboard-dark .admin-yt-status-banner--ready {
    color: #93c5fd;
    background: rgba(59, 130, 246, 0.12);
}

body.admin-dashboard-dark .admin-yt-footer-status--success {
    color: #86efac;
}

body.admin-dashboard-dark .admin-yt-footer-status--danger {
    color: #f87171;
}

body.admin-dashboard-dark .action-btn.btn-success {
    background-color: transparent !important;
    border-color: #34c38f !important;
    color: #34c38f !important;
}

body.admin-dashboard-dark .action-btn.btn-success:hover {
    border-color: #4fd1a5 !important;
    color: #4fd1a5 !important;
}

body.admin-dashboard-dark .action-btn.btn-primary {
    background-color: transparent !important;
    border-color: #556ee6 !important;
    color: #818cf8 !important;
}

body.admin-dashboard-dark .action-btn.btn-primary:hover {
    border-color: #818cf8 !important;
    color: #a5b4fc !important;
}

body.admin-dashboard-dark .action-btn.btn-danger {
    background-color: transparent !important;
    border-color: #f87171 !important;
    color: #f87171 !important;
}

body.admin-dashboard-dark .action-btn.btn-danger:hover {
    border-color: #fca5a5 !important;
    color: #fca5a5 !important;
}

body.admin-dashboard-dark .admin-yt-details-link {
    color: #34c38f !important;
}

body.admin-dashboard-dark .admin-yt-details-link .mdi-youtube {
    color: #34c38f;
}

body.admin-dashboard-dark .admin-yt-details-link:hover {
    color: #4fd1a5 !important;
}

body.admin-dashboard-dark .admin-yt-details-link:hover .mdi-youtube {
    color: #4fd1a5;
}

body.admin-dashboard-dark .admin-yt-view-link {
    color: #34c38f;
}

body.admin-dashboard-dark .admin-yt-view-link:hover {
    color: #4fd1a5;
}

/* Admin form inputs — soft borders */
#layout-wrapper .form-control,
#layout-wrapper .form-select,
#layout-wrapper .sinput,
.modal .form-control,
.modal .form-select,
.modal .sinput {
    border: 1px solid rgba(73, 80, 87, 0.28) !important;
}

body.admin-dashboard-dark #layout-wrapper .form-control,
body.admin-dashboard-dark #layout-wrapper .form-select,
body.admin-dashboard-dark #layout-wrapper .sinput,
body.admin-dashboard-dark .modal .form-control,
body.admin-dashboard-dark .modal .form-select,
body.admin-dashboard-dark .modal .sinput {
    border: 1px solid var(--dash-input-border) !important;
}

#layout-wrapper .form-control:focus,
#layout-wrapper .form-select:focus,
#layout-wrapper .sinput:focus,
.modal .form-control:focus,
.modal .form-select:focus,
.modal .sinput:focus {
    border-color: #556ee6 !important;
    box-shadow: 0 0 0 0.12rem rgba(85, 110, 230, 0.15) !important;
}

body.admin-dashboard-dark #layout-wrapper .form-control:focus,
body.admin-dashboard-dark #layout-wrapper .form-select:focus,
body.admin-dashboard-dark #layout-wrapper .sinput:focus,
body.admin-dashboard-dark .modal .form-control:focus,
body.admin-dashboard-dark .modal .form-select:focus,
body.admin-dashboard-dark .modal .sinput:focus {
    border-color: #818cf8 !important;
    box-shadow: 0 0 0 0.15rem rgba(99, 102, 241, 0.28) !important;
}

#layout-wrapper .form-control:disabled,
#layout-wrapper .form-select:disabled,
.modal .form-control:disabled,
.modal .form-select:disabled,
body.admin-dashboard-dark #layout-wrapper .form-control:disabled,
body.admin-dashboard-dark .modal .form-control:disabled {
    opacity: 0.75;
}

body.admin-dashboard-dark #layout-wrapper .form-control:disabled,
body.admin-dashboard-dark .modal .form-control:disabled {
    border-color: rgba(148, 163, 184, 0.22) !important;
}