@import url('https://fonts.googleapis.com/css2?family=DM+Sans:ital,opsz,wght@0,9..40,400;0,9..40,500;0,9..40,600;0,9..40,700;1,9..40,400&display=swap');

/* Bootstrap theme + UCP surfaces (readable hierarchy — not pure black stacks) */
:root,
[data-bs-theme="dark"] {
    --bs-primary: #48a9ff;
    --bs-primary-rgb: 72, 169, 255;
    --bs-body-font-family: 'DM Sans', system-ui, -apple-system, BlinkMacSystemFont, 'Segoe UI', Roboto, sans-serif;
    --bs-body-bg: #171f2c;
    --bs-body-color: #ebeef4;
    --bs-secondary-color: #94a8bc;
    --bs-border-color: #3f536c;
    --bs-secondary-bg: #1f2838;
    --bs-tertiary-bg: #253044;
    /* Legacy aliases (many PHP pages reference these — keep in sync with Bootstrap tokens) */
    --ucp-bg: var(--bs-body-bg);
    --ucp-bg-card: var(--bs-tertiary-bg);
    --ucp-bg-elevated: #2d3d55;
    --ucp-border: var(--bs-border-color);
    --ucp-text: var(--bs-body-color);
    --ucp-text-muted: var(--bs-secondary-color);
    --ucp-police: var(--bs-primary);
    --ucp-criminal: #ff7d8d;
    --ucp-accent: #ff6b81;
    --ucp-radius: 0.75rem;
    --ucp-radius-sm: 0.5rem;
    --ucp-shadow: 0 4px 28px rgba(0, 0, 0, 0.28);
    --ucp-shadow-soft: 0 1px 0 rgba(255, 255, 255, 0.06) inset;
    /* Sidebar — slightly quieter than main content */
    --ucp-sidebar-bg: #121822;
    --ucp-sidebar-chrome: rgba(0, 0, 0, 0.2);
    --ucp-sidebar-divider: rgba(100, 120, 150, 0.35);
    --ucp-sidebar-muted: #8ea0b8;
    --ucp-sidebar-fg-soft: #bcc9d9;
    --ucp-sidebar-radius: 0.5rem;
    --ucp-sidebar-item-h: 2.25rem;
}

body.ucp-app {
    font-family: var(--bs-body-font-family);
    letter-spacing: 0.01em;
}

/*
 * Bootstrap combines .offcanvas with .offcanvas-lg. The base .offcanvas rule keeps
 * visibility:hidden and translateX(-100%) at ALL widths, while .offcanvas-lg only
 * resets background at ≥lg — leaving the sidebar invisible on desktop. Override.
 */
@media (min-width: 992px) {
    .ucp-app-shell .ucp-sidebar-offcanvas.offcanvas {
        position: relative !important;
        top: auto !important;
        left: auto !important;
        right: auto !important;
        bottom: auto !important;
        transform: none !important;
        visibility: visible !important;
        pointer-events: auto !important;
        display: flex !important;
        flex-direction: column !important;
        flex-shrink: 0 !important;
        width: 272px !important;
        max-width: none !important;
        height: auto !important;
        min-height: 100vh !important;
        min-height: 100dvh !important;
        z-index: 8 !important;
        overflow: hidden;
        background-color: var(--ucp-sidebar-bg) !important;
        background-image: none !important;
        border-right: 1px solid var(--ucp-sidebar-divider) !important;
        box-shadow: 6px 0 28px rgba(0, 0, 0, 0.28) !important;
        transition: none !important;
    }
    .ucp-app-shell .ucp-sidebar-offcanvas.offcanvas.offcanvas-start {
        transform: none !important;
    }
    /* Bootstrap hides this at lg+; we need the brand row on desktop */
    .ucp-sidebar-offcanvas.offcanvas-lg .offcanvas-header.ucp-sidebar-brand {
        display: flex !important;
        flex-shrink: 0;
        align-items: center;
    }
    .ucp-sidebar-offcanvas.offcanvas-lg .offcanvas-body {
        flex: 1 1 auto !important;
        min-height: 0 !important;
        overflow-x: hidden !important;
        overflow-y: hidden !important;
        display: flex !important;
        flex-direction: column !important;
        padding-bottom: 0 !important;
        background: transparent !important;
    }
    .ucp-sidebar-offcanvas.offcanvas-lg .offcanvas-body > nav {
        flex: 1 1 auto !important;
        overflow-y: auto !important;
        overflow-x: hidden !important;
        scrollbar-width: thin;
    }
    /* Main column feels less flat */
    .ucp-app-column.ucp-app-column {
        background: radial-gradient(120% 70% at 100% 0%, rgba(var(--bs-primary-rgb), 0.07), transparent 55%), var(--bs-body-bg);
    }
}

@media (max-width: 991.98px) {
    .ucp-sidebar-offcanvas.offcanvas.show {
        box-shadow: 8px 0 40px rgba(0, 0, 0, 0.55);
    }
}

/* Desktop + mobile top bar */
.ucp-topbar {
    z-index: 1030;
    border-bottom: 1px solid var(--ucp-sidebar-divider);
    background: rgba(18, 24, 34, 0.92);
    backdrop-filter: blur(14px);
    -webkit-backdrop-filter: blur(14px);
}
.ucp-topbar-inner {
    display: flex;
    align-items: center;
    gap: 0.75rem;
    padding: 0.65rem 0.75rem;
    min-height: 3.25rem;
}
@media (min-width: 992px) {
    .ucp-topbar-inner {
        padding: 0.75rem 1rem;
        min-height: 3.5rem;
    }
}
.ucp-topbar-menu {
    color: var(--bs-body-color);
    padding: 0.35rem;
    border: 1px solid var(--ucp-border);
    border-radius: 0.5rem;
    line-height: 0;
}
.ucp-topbar-eyebrow {
    display: block;
    font-size: 0.625rem;
    font-weight: 700;
    letter-spacing: 0.12em;
    text-transform: uppercase;
    color: var(--ucp-sidebar-muted);
    line-height: 1.2;
}
.ucp-topbar-title {
    font-size: 1.125rem;
    font-weight: 800;
    letter-spacing: -0.02em;
    color: var(--bs-body-color);
    line-height: 1.2;
}
@media (min-width: 992px) {
    .ucp-topbar-title {
        font-size: 1.25rem;
    }
}
.ucp-topbar-badge {
    font-size: 0.625rem;
    font-weight: 800;
    letter-spacing: 0.08em;
    text-transform: uppercase;
    padding: 0.28rem 0.55rem;
    border-radius: 999px;
    color: rgba(var(--bs-primary-rgb), 0.95);
    background: rgba(var(--bs-primary-rgb), 0.12);
    border: 1px solid rgba(var(--bs-primary-rgb), 0.28);
}
.ucp-topbar-user {
    font-size: 0.8125rem;
    font-weight: 600;
    color: var(--ucp-sidebar-fg-soft);
    max-width: 10rem;
}
.ucp-topbar-icon-btn {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 2.25rem;
    height: 2.25rem;
    border-radius: 0.5rem;
    border: 1px solid rgba(255, 255, 255, 0.08);
    background: rgba(255, 255, 255, 0.04);
    color: var(--bs-body-color);
    text-decoration: none;
    transition: background 0.15s ease, border-color 0.15s ease;
}
.ucp-topbar-icon-btn:hover {
    background: rgba(var(--bs-primary-rgb), 0.12);
    border-color: rgba(var(--bs-primary-rgb), 0.35);
    color: var(--bs-body-color);
}

/* Pinned overview link */
.ucp-nav-overview {
    margin-bottom: 0.375rem;
    padding-bottom: 0.5rem;
    border-bottom: 1px solid rgba(255, 255, 255, 0.06);
}
.ucp-nav-overview .ucp-sidebar-nav-link {
    font-weight: 600;
    min-height: 2.5rem;
}

/* In-section group labels (staff sub-groups) */
.ucp-nav-divider {
    display: flex;
    align-items: center;
    gap: 0.5rem;
    margin: 0.5rem 0 0.25rem;
    padding: 0 0.25rem;
    font-size: 0.625rem;
    font-weight: 700;
    letter-spacing: 0.1em;
    text-transform: uppercase;
    color: var(--ucp-sidebar-muted);
}
.ucp-nav-divider::after {
    content: "";
    flex: 1;
    height: 1px;
    background: rgba(255, 255, 255, 0.06);
}
.ucp-nav-divider span {
    flex-shrink: 0;
}

/* Sidebar: brand + shell */
.ucp-sidebar-offcanvas {
    color: var(--bs-body-color);
}

.ucp-sidebar-brand {
    padding: 0.875rem 0.875rem !important;
    border-bottom: 1px solid var(--ucp-sidebar-divider);
    background: var(--ucp-sidebar-chrome);
}

.ucp-sidebar-brand-link {
    display: flex;
    align-items: center;
    gap: 0.75rem;
    min-width: 0;
    flex: 1;
    color: inherit;
    text-decoration: none;
}

.ucp-sidebar-brand-link:hover {
    color: inherit;
}

.ucp-sidebar-brand-logo {
    border-radius: 0.625rem;
    flex-shrink: 0;
    box-shadow: 0 0 0 1px rgba(255, 255, 255, 0.06);
}

.ucp-sidebar-brand-name {
    font-size: 1rem;
    font-weight: 700;
    letter-spacing: -0.02em;
}

.ucp-sidebar-eyebrow {
    margin-top: 0.0625rem;
    font-size: 0.625rem;
    font-weight: 600;
    letter-spacing: 0.1em;
    text-transform: uppercase;
    color: var(--ucp-sidebar-muted);
}

.ucp-sidebar-close {
    opacity: 0.85;
}

/* Nav list */
.ucp-sidebar-nav {
    scrollbar-width: thin;
    scrollbar-color: rgba(255, 255, 255, 0.12) transparent;
}

.ucp-sidebar-nav::-webkit-scrollbar {
    width: 8px;
}

.ucp-sidebar-nav::-webkit-scrollbar-track {
    background: transparent;
}

.ucp-sidebar-nav::-webkit-scrollbar-thumb {
    background: rgba(255, 255, 255, 0.08);
    border-radius: 99px;
    border: 2px solid transparent;
    background-clip: padding-box;
}

.ucp-sidebar-nav::-webkit-scrollbar-thumb:hover {
    background: rgba(255, 255, 255, 0.14);
    border-radius: 99px;
    border: 2px solid transparent;
    background-clip: padding-box;
}

.ucp-sidebar-nav-inner {
    padding: 0.5rem 0.625rem 0.75rem;
    display: flex;
    flex-direction: column;
    gap: 0.125rem;
}

.ucp-sidebar-nav-inner > .ucp-nav-section:not(:first-child) {
    margin-top: 0.25rem;
    padding-top: 0.375rem;
    border-top: 1px solid rgba(255, 255, 255, 0.045);
}

/* Section headings */
.ucp-nav-section-toggle {
    width: 100%;
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 0.5rem;
    margin: 0;
    padding: 0.5625rem 0.4375rem;
    border: none;
    border-radius: var(--ucp-sidebar-radius);
    background: transparent;
    font: inherit;
    color: var(--ucp-sidebar-muted);
    font-size: 0.6875rem;
    font-weight: 700;
    letter-spacing: 0.08em;
    text-transform: uppercase;
    text-align: left;
    line-height: 1.2;
    transition: background-color 0.18s ease, color 0.18s ease;
}

@media (hover: hover) {
    .ucp-nav-section-toggle:hover {
        background: rgba(255, 255, 255, 0.045);
        color: var(--ucp-sidebar-fg-soft);
    }
}

.ucp-nav-section-toggle:focus-visible {
    outline: 2px solid rgba(var(--bs-primary-rgb), 0.45);
    outline-offset: 2px;
}

.ucp-nav-section-toggle:not(.collapsed) {
    color: var(--bs-body-color);
    background: rgba(255, 255, 255, 0.04);
}

.ucp-nav-section-heading {
    display: flex;
    align-items: center;
    gap: 0.5rem;
    min-width: 0;
}

.ucp-nav-section-accent {
    width: 3px;
    height: 0.875rem;
    border-radius: 99px;
    background: rgba(var(--bs-primary-rgb), 0.45);
    flex-shrink: 0;
    transition: height 0.18s ease, background 0.18s ease, opacity 0.18s ease;
    opacity: 0.55;
}

.ucp-nav-section-toggle:not(.collapsed) .ucp-nav-section-accent {
    height: 1rem;
    background: rgb(var(--bs-primary-rgb));
    opacity: 1;
}

.ucp-nav-section-title {
    display: block;
}

.ucp-nav-section-panel {
    margin-top: 0.125rem;
}

.ucp-nav-section-links {
    display: flex;
    flex-direction: column;
    gap: 0.125rem;
    padding: 0 0.25rem 0.5rem 1.5rem;
}

/* Row links */
.ucp-sidebar-nav-link {
    position: relative;
    display: flex;
    align-items: center;
    gap: 0.625rem;
    min-height: var(--ucp-sidebar-item-h);
    padding: 0.375rem 0.5rem 0.375rem 0.625rem;
    border-radius: calc(var(--ucp-sidebar-radius) - 0.0625rem);
    font-size: 0.8125rem;
    font-weight: 500;
    color: var(--ucp-sidebar-fg-soft);
    text-decoration: none;
    line-height: 1.25;
    transition: background-color 0.15s ease, color 0.15s ease;
}

.ucp-sidebar-nav-link .ucp-nav-ico {
    display: flex;
    align-items: center;
    justify-content: center;
    width: 1.25rem;
    flex-shrink: 0;
    color: inherit;
    opacity: 0.75;
}

@media (hover: hover) {
    .ucp-sidebar-nav-link:hover {
        background: rgba(255, 255, 255, 0.055);
        color: var(--bs-body-color);
    }

    .ucp-sidebar-nav-link:hover .ucp-nav-ico {
        opacity: 0.95;
    }
}

.ucp-sidebar-nav-link:focus-visible {
    outline: 2px solid rgba(var(--bs-primary-rgb), 0.45);
    outline-offset: 1px;
}

.ucp-sidebar-nav-link.active {
    color: var(--bs-body-color);
    background: rgba(var(--bs-primary-rgb), 0.11);
    font-weight: 600;
}

.ucp-sidebar-nav-link.active .ucp-nav-ico {
    opacity: 1;
}

.ucp-sidebar-nav-link.active::before {
    content: "";
    position: absolute;
    left: 5px;
    top: 50%;
    transform: translateY(-50%);
    width: 3px;
    height: 1rem;
    border-radius: 99px;
    background: rgb(var(--bs-primary-rgb));
    box-shadow: 0 0 12px rgba(var(--bs-primary-rgb), 0.35);
}

.ucp-sidebar-nav-label {
    min-width: 0;
}

.ucp-nav-ico svg {
    display: block;
    width: 18px;
    height: 18px;
}

.ucp-nav-chevron {
    flex-shrink: 0;
    opacity: 0.45;
    transition: transform 0.22s ease, opacity 0.18s ease;
}

.ucp-nav-section-toggle:not(.collapsed) .ucp-nav-chevron {
    transform: rotate(180deg);
    opacity: 0.7;
}

/* Footer dock */
.ucp-sidebar-footer {
    flex-shrink: 0;
    margin-top: auto;
    padding: 0.75rem;
    display: flex;
    flex-direction: column;
    gap: 0.5rem;
    border-top: 1px solid var(--ucp-sidebar-divider);
    background: rgba(0, 0, 0, 0.32);
}

.ucp-sidebar-action {
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 0.5rem;
    min-height: 2.375rem;
    padding: 0 0.75rem;
    border-radius: var(--ucp-sidebar-radius);
    font-size: 0.8125rem;
    font-weight: 600;
    text-decoration: none;
    line-height: 1.2;
    border: 1px solid transparent;
    transition: background-color 0.15s ease, color 0.15s ease, border-color 0.15s ease, box-shadow 0.15s ease;
}

.ucp-sidebar-action .ucp-nav-ico svg {
    width: 16px;
    height: 16px;
}

.ucp-sidebar-action--ghost {
    color: var(--bs-body-color);
    background: rgba(255, 255, 255, 0.04);
    border-color: rgba(255, 255, 255, 0.08);
}

@media (hover: hover) {
    .ucp-sidebar-action--ghost:hover {
        background: rgba(255, 255, 255, 0.08);
        border-color: rgba(255, 255, 255, 0.12);
        color: var(--bs-body-color);
    }
}

.ucp-sidebar-action--danger {
    color: #ff7b72;
    background: rgba(248, 81, 73, 0.06);
    border-color: rgba(248, 81, 73, 0.28);
}

@media (hover: hover) {
    .ucp-sidebar-action--danger:hover {
        background: rgba(248, 81, 73, 0.12);
        border-color: rgba(248, 81, 73, 0.4);
        color: #ffa198;
    }
}

.ucp-sidebar-action:focus-visible {
    outline: 2px solid rgba(var(--bs-primary-rgb), 0.45);
    outline-offset: 2px;
}

.ucp-sidebar-user {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 0.5rem;
    padding: 0.5rem 0.625rem;
    border-radius: var(--ucp-sidebar-radius);
    background: rgba(255, 255, 255, 0.03);
    border: 1px solid rgba(255, 255, 255, 0.05);
}

.ucp-sidebar-user-name {
    font-size: 0.8125rem;
    font-weight: 600;
    color: var(--bs-body-color);
}

.ucp-sidebar-rank {
    font-size: 0.625rem;
    font-weight: 700;
    letter-spacing: 0.06em;
    text-transform: uppercase;
    padding: 0.2rem 0.45rem;
    border-radius: 0.35rem;
    color: rgba(var(--bs-primary-rgb), 0.95);
    background: rgba(var(--bs-primary-rgb), 0.1);
    border: 1px solid rgba(var(--bs-primary-rgb), 0.22);
    flex-shrink: 0;
}

/* Legacy overlay dialogs (not Bootstrap .modal — renamed to avoid clash) */
.ucp-dialog-modal {
    display: none;
    position: fixed;
    inset: 0;
    background: rgba(0, 0, 0, 0.88);
    z-index: 1055;
    align-items: center;
    justify-content: center;
    padding: max(20px, env(safe-area-inset-top)) max(20px, env(safe-area-inset-right)) max(20px, env(safe-area-inset-bottom)) max(20px, env(safe-area-inset-left));
}
.ucp-dialog-modal.ucp-dialog-modal--open,
.ucp-dialog-modal[style*="flex"],
.ucp-dialog-modal[style*="block"] {
    display: flex;
}
.ucp-dialog-modal .modal-content {
    background: var(--bs-dark);
    border-radius: 0.75rem;
    border: 1px solid var(--bs-border-color);
    box-shadow: 0 1rem 3rem rgba(0, 0, 0, 0.55);
    max-width: 440px;
    width: 100%;
    padding: 1.5rem;
}
.ucp-dialog-modal .modal-content h2 {
    color: var(--bs-primary);
    margin-bottom: 0.5rem;
    font-size: 1.15rem;
    font-weight: 700;
}
.ucp-dialog-modal .modal-content p {
    color: var(--bs-secondary-color);
    font-size: 0.875rem;
    margin-bottom: 1rem;
}
.ucp-dialog-modal .form-group {
    margin-bottom: 1rem;
}
.ucp-dialog-modal .form-group label {
    display: block;
    color: var(--bs-secondary-color);
    margin-bottom: 0.35rem;
    font-size: 0.8125rem;
    font-weight: 500;
}
.ucp-dialog-modal .form-group input {
    width: 100%;
    padding: 0.65rem 0.85rem;
    background: var(--bs-body-bg);
    border: 1px solid var(--bs-border-color);
    border-radius: 0.5rem;
    color: var(--bs-body-color);
    font-size: 1rem;
}
.ucp-dialog-modal .form-group input:focus {
    outline: none;
    border-color: var(--bs-primary);
    box-shadow: 0 0 0 0.2rem rgba(var(--bs-primary-rgb), 0.25);
}
.ucp-dialog-modal .modal-buttons {
    display: flex;
    gap: 0.5rem;
    justify-content: flex-end;
    margin-top: 1.25rem;
    flex-wrap: wrap;
}

/* Page content (works alongside Bootstrap utilities) */
.ucp-scroll {
    flex: 1 1 auto;
    overflow-x: hidden;
}

/* Bragcard / wide canvas previews — inner padding avoids border-radius clipping */
.ucp-bragcard-frame {
    border-radius: var(--ucp-radius-sm);
    border: 1px solid var(--ucp-border);
    background: #0c1018;
    padding: 10px;
    line-height: 0;
    max-width: 100%;
    box-sizing: border-box;
}

.ucp-bragcard-frame canvas {
    width: 100%;
    height: auto;
    display: block;
    border-radius: max(4px, calc(var(--ucp-radius-sm) - 6px));
}

.ucp-bragcard-kicker {
    display: block;
    font-size: 0.625rem;
    font-weight: 700;
    letter-spacing: 0.12em;
    color: var(--ucp-text-muted);
    margin-bottom: 0.25rem;
}

.ucp-site-footer {
    background: rgba(0, 0, 0, 0.2) !important;
    border-top-color: var(--ucp-border) !important;
    color: var(--ucp-text-muted) !important;
}

.ucp-main-content {
    outline: none;
}

.container {
    max-width: 1200px;
}

.ucp-page .page-header {
    margin-bottom: 1.5rem;
}
.ucp-page .page-title {
    font-size: clamp(1.35rem, 4vw, 1.75rem);
    font-weight: 800;
    color: var(--bs-body-color);
    margin: 0 0 0.35rem 0;
    letter-spacing: -0.02em;
}
.ucp-page .page-subtitle {
    color: var(--bs-secondary-color);
    font-size: 0.875rem;
    margin: 0;
    line-height: 1.55;
}
.ucp-page .ucp-card {
    background: var(--ucp-bg-card);
    border-radius: var(--ucp-radius);
    overflow: hidden;
    border: 1px solid var(--ucp-border);
    margin-bottom: 1rem;
    box-shadow: var(--ucp-shadow-soft), var(--ucp-shadow);
}
.ucp-page .card-header {
    padding: 0.875rem 1.1rem;
    background: linear-gradient(180deg, rgba(var(--bs-primary-rgb), 0.1) 0%, rgba(0, 0, 0, 0.08) 100%);
    border-bottom: 1px solid var(--ucp-border);
    display: flex;
    align-items: center;
    gap: 0.75rem;
}
.ucp-page .card-label {
    font-size: 0.95rem;
    font-weight: 700;
    margin: 0;
}
.ucp-page .card-body {
    padding: 1.1rem;
}
.ucp-page .stat-card {
    background: var(--ucp-bg-card);
    border: 1px solid var(--ucp-border);
    border-radius: var(--ucp-radius);
    padding: 1.1rem;
}
.ucp-page .stat-label {
    color: var(--bs-secondary-color);
    font-size: 0.65rem;
    text-transform: uppercase;
    letter-spacing: 0.08em;
    margin-bottom: 0.35rem;
}
.ucp-page .stat-value {
    color: var(--bs-primary);
    font-size: clamp(1.25rem, 4vw, 1.5rem);
    font-weight: 700;
    font-variant-numeric: tabular-nums;
}
.ucp-page .info-section h2,
.ucp-page .info-section h3 {
    color: var(--bs-primary);
    font-size: 0.95rem;
    font-weight: 700;
    margin: 0 0 0.75rem 0;
    padding-bottom: 0.5rem;
    border-bottom: 1px solid var(--bs-border-color);
}
.ucp-page .info-grid {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(min(100%, 200px), 1fr));
    gap: 0.75rem;
}
.ucp-page .info-label,
.ucp-page .info-item-label {
    color: var(--bs-secondary-color);
    font-size: 0.65rem;
    text-transform: uppercase;
    letter-spacing: 0.06em;
}
.ucp-page .info-value,
.ucp-page .info-item-value {
    color: var(--bs-body-color);
    font-size: 0.875rem;
    font-weight: 600;
    word-break: break-word;
}
.ucp-page .btn {
    min-height: 2.75rem;
}
.ucp-page table {
    display: block;
    width: 100%;
    overflow-x: auto;
    -webkit-overflow-scrolling: touch;
    border-collapse: collapse;
}
.ucp-page thead th {
    background: var(--bs-tertiary-bg);
    padding: 0.65rem 0.75rem;
    text-align: left;
    font-size: 0.65rem;
    font-weight: 700;
    color: var(--bs-primary);
    text-transform: uppercase;
    letter-spacing: 0.06em;
    border-bottom: 1px solid var(--bs-border-color);
    white-space: nowrap;
}
.ucp-page tbody td {
    padding: 0.75rem;
    border-bottom: 1px solid var(--bs-border-color);
    color: var(--bs-body-color);
    font-size: 0.875rem;
}
.ucp-page tbody tr:hover {
    background: rgba(var(--bs-primary-rgb), 0.06);
}
.ucp-page .verification-alert {
    background: rgba(229, 83, 103, 0.1);
    border: 1px solid rgba(229, 83, 103, 0.35);
    border-radius: 0.75rem;
    padding: 1rem 1.1rem;
    margin-bottom: 1.25rem;
    display: flex;
    align-items: flex-start;
    gap: 0.75rem;
}
.ucp-page .verification-alert-content h3 {
    color: var(--ucp-accent);
    margin-bottom: 0.25rem;
    font-size: 0.95rem;
}
.ucp-page .police-accent {
    color: var(--ucp-police);
}

.ucp-page.ucp-page-narrow {
    max-width: 960px;
    margin: 0 auto;
}
.ucp-page-header {
    margin: 0 0 0.5rem 0;
}
.ucp-page-title-main {
    margin: 0 0 0.5rem 0;
    font-size: 1.5rem;
    font-weight: 800;
    letter-spacing: -0.02em;
}
.ucp-page-lead {
    margin: 0 0 1.25rem 0;
    color: var(--bs-secondary-color);
    font-size: 0.875rem;
    line-height: 1.55;
}
.ucp-grid-stats {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(220px, 1fr));
    gap: 0.875rem;
    margin-bottom: 1.25rem;
}
.ucp-stat-tile {
    background: var(--ucp-bg-card);
    border: 1px solid var(--ucp-border);
    border-radius: var(--ucp-radius);
    padding: 1.1rem;
}
.ucp-stat-tile .ucp-stat-foot {
    margin-top: 0.5rem;
    font-size: 0.8125rem;
    color: var(--bs-secondary-color);
    line-height: 1.45;
}
.ucp-shortcut-card {
    background: var(--ucp-bg-card);
    border: 1px solid var(--ucp-border);
    border-radius: var(--ucp-radius);
    padding: 1rem 1.1rem;
}
.ucp-shortcut-card .ucp-eyebrow {
    font-size: 0.7rem;
    font-weight: 800;
    text-transform: uppercase;
    color: var(--bs-primary);
    margin-bottom: 0.75rem;
    letter-spacing: 0.06em;
}
.ucp-shortcut-row {
    display: flex;
    flex-wrap: wrap;
    gap: 0.5rem;
}
.ucp-muted {
    color: var(--bs-secondary-color);
}
.ucp-stat-tile .ucp-stat-tile-actions {
    margin-top: 0.75rem;
}
.ucp-stat-tile .stat-label {
    color: var(--bs-secondary-color);
    font-size: 0.65rem;
    text-transform: uppercase;
    letter-spacing: 0.08em;
    margin-bottom: 0.35rem;
    font-weight: 700;
}
.ucp-stat-tile .stat-value {
    color: var(--bs-primary);
    font-size: clamp(1.35rem, 4vw, 1.75rem);
    font-weight: 800;
    font-variant-numeric: tabular-nums;
}
.ucp-table-scroll {
    overflow-x: auto;
    -webkit-overflow-scrolling: touch;
}
.ucp-table-scroll table.ucp-table-native {
    display: table;
    width: 100%;
    border-collapse: collapse;
}
.ucp-table-scroll table.ucp-table-native th,
.ucp-table-scroll table.ucp-table-native td {
    padding: 0.75rem;
    border-bottom: 1px solid var(--bs-border-color);
    text-align: left;
    font-size: 0.875rem;
    color: var(--bs-body-color);
}
.ucp-table-scroll table.ucp-table-native th {
    font-size: 0.65rem;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: 0.06em;
    color: var(--bs-primary);
    white-space: nowrap;
}
.ucp-card-body-flush {
    padding: 0 !important;
}

/* Staff operations hub */
.ucp-page.ucp-page-staff-hub {
    max-width: 1120px;
    margin: 0 auto;
}
.ucp-staff-hub-eyebrow {
    margin: 0 0 0.5rem 0;
    font-size: 0.7rem;
    font-weight: 800;
    letter-spacing: 0.12em;
    text-transform: uppercase;
    color: var(--bs-primary);
}
.ucp-staff-hub-metrics {
    margin-bottom: 1.5rem;
}
.ucp-stat-tile-accent {
    border-color: rgba(var(--bs-primary-rgb), 0.35);
    background: linear-gradient(145deg, rgba(var(--bs-primary-rgb), 0.12) 0%, var(--bs-tertiary-bg) 100%);
}
.ucp-staff-hub-deck {
    display: grid;
    grid-template-columns: 1fr;
    gap: 1rem;
}
@media (min-width: 992px) {
    .ucp-staff-hub-deck {
        grid-template-columns: repeat(3, 1fr);
    }
}
.ucp-hub-card {
    background: var(--ucp-bg-card);
    border: 1px solid var(--ucp-border);
    border-radius: var(--ucp-radius);
    padding: 1.25rem 1.1rem;
    display: flex;
    flex-direction: column;
    gap: 0.5rem;
    min-height: 100%;
    transition: border-color 0.2s ease, box-shadow 0.2s ease;
}
@media (hover: hover) {
    .ucp-hub-card:hover {
        border-color: rgba(var(--bs-primary-rgb), 0.35);
        box-shadow: 0 0.5rem 2rem rgba(0, 0, 0, 0.25);
    }
}
.ucp-hub-card-title {
    margin: 0;
    font-size: 1.05rem;
    font-weight: 800;
    letter-spacing: -0.02em;
}
.ucp-hub-card-desc {
    margin: 0 0 0.35rem 0;
    font-size: 0.8125rem;
    color: var(--bs-secondary-color);
    line-height: 1.5;
}
.ucp-hub-card-links {
    list-style: none;
    margin: 0;
    padding: 0;
    display: flex;
    flex-direction: column;
}
.ucp-hub-card-links li {
    display: flex;
    flex-wrap: wrap;
    align-items: baseline;
    gap: 0.5rem 0.75rem;
    padding: 0.75rem 0;
    border-bottom: 1px solid var(--bs-border-color);
}
.ucp-hub-card-links li:last-child {
    border-bottom: none;
    padding-bottom: 0;
}
.ucp-hub-card-links a {
    font-weight: 700;
    font-size: 0.875rem;
    color: var(--bs-primary);
    text-decoration: none;
}
.ucp-hub-card-links a:hover {
    text-decoration: underline;
}
.ucp-hub-hint {
    font-size: 0.75rem;
    font-weight: 500;
    color: var(--bs-secondary-color);
}
.ucp-hub-card-empty {
    margin: 0.75rem 0 0;
    font-size: 0.8125rem;
    color: var(--bs-secondary-color);
    line-height: 1.5;
    padding: 0.75rem 0.875rem;
    border-radius: 0.5rem;
    background: rgba(0, 0, 0, 0.2);
    border: 1px dashed var(--bs-border-color);
}

/* Breadcrumbs — readable on dark shell */
.ucp-breadcrumb-nav {
    max-width: 100%;
}
.ucp-breadcrumb-bar {
    --bs-breadcrumb-divider: quote('›');
    --bs-breadcrumb-item-padding-x: 0.4rem;
    --bs-breadcrumb-divider-color: var(--bs-secondary-color);
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    gap: 0;
    row-gap: 0.35rem;
    padding: 0.5rem 0.75rem;
    border-radius: var(--ucp-radius);
    border: 1px solid var(--ucp-border);
    background: rgba(0, 0, 0, 0.18);
    box-shadow: var(--ucp-shadow-soft);
    font-size: 0.8125rem;
}
.ucp-breadcrumb-bar .breadcrumb-item + .breadcrumb-item::before {
    opacity: 0.85;
}
.ucp-breadcrumb-link {
    color: var(--bs-primary);
    text-decoration: none;
    font-weight: 600;
}
.ucp-breadcrumb-link:hover {
    text-decoration: underline;
}
.ucp-breadcrumb-bar .breadcrumb-item.active .ucp-breadcrumb-text {
    color: var(--bs-body-color);
    font-weight: 700;
}
.ucp-breadcrumb-bar .ucp-breadcrumb-text {
    color: var(--bs-secondary-color);
    font-weight: 600;
}

/* Horizontal “jump to” row on discover-related pages */
.ucp-explore-strip {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    gap: 0.375rem 0.875rem;
    padding: 0.65rem 0.875rem;
    margin-top: 0.65rem;
    border-radius: var(--ucp-radius);
    border: 1px solid var(--ucp-border);
    background: linear-gradient(180deg, rgba(var(--bs-primary-rgb), 0.06) 0%, rgba(0, 0, 0, 0.16) 100%);
}
.ucp-explore-strip__label {
    font-size: 0.65rem;
    font-weight: 800;
    letter-spacing: 0.14em;
    text-transform: uppercase;
    color: var(--bs-secondary-color);
    flex-shrink: 0;
}
.ucp-explore-strip__links {
    display: flex;
    flex-wrap: wrap;
    gap: 0.35rem;
    align-items: center;
    min-width: 0;
}
.ucp-explore-strip__pill {
    display: inline-flex;
    align-items: center;
    padding: 0.32rem 0.7rem;
    border-radius: 999px;
    font-size: 0.8125rem;
    font-weight: 600;
    border: 1px solid rgba(var(--bs-primary-rgb), 0.28);
    background: rgba(0, 0, 0, 0.2);
    color: var(--bs-body-color);
    text-decoration: none;
    transition:
        border-color 0.15s ease,
        background 0.15s ease,
        color 0.15s ease;
}
.ucp-explore-strip__pill:hover {
    border-color: rgba(var(--bs-primary-rgb), 0.55);
    background: rgba(var(--bs-primary-rgb), 0.1);
    color: var(--bs-body-color);
}
.ucp-explore-strip__pill--active {
    border-color: rgba(var(--bs-primary-rgb), 0.5);
    background: rgba(var(--bs-primary-rgb), 0.22);
    color: #fff;
    cursor: default;
}

/* Guest pages (login, verify) */
.ucp-guest-shell {
    background: radial-gradient(120% 80% at 50% 0%, rgba(var(--bs-primary-rgb), 0.08), transparent 50%), var(--bs-body-bg);
}
.ucp-guest-page {
    display: flex;
    align-items: center;
    justify-content: center;
    min-height: 100vh;
    min-height: 100dvh;
    padding: max(1.25rem, env(safe-area-inset-top)) max(1rem, env(safe-area-inset-right)) max(1.25rem, env(safe-area-inset-bottom)) max(1rem, env(safe-area-inset-left));
}
.ucp-guest-card {
    width: 100%;
    max-width: 440px;
    padding: clamp(2rem, 6vw, 3rem) clamp(1.5rem, 5vw, 2.5rem);
    border-radius: var(--ucp-radius);
    text-align: center;
    background: rgba(23, 31, 44, 0.94);
    border: 1px solid rgba(255, 255, 255, 0.08);
    box-shadow: var(--ucp-shadow), 0 0 0 1px rgba(var(--bs-primary-rgb), 0.08);
    backdrop-filter: blur(16px);
    -webkit-backdrop-filter: blur(16px);
}
.ucp-guest-logo {
    width: min(168px, 42vw);
    height: auto;
    margin: 0 auto 1rem;
    display: block;
    border-radius: 0.75rem;
    filter: drop-shadow(0 8px 24px rgba(var(--bs-primary-rgb), 0.2));
}
.ucp-guest-title {
    margin: 0 0 0.35rem;
    font-size: clamp(1.5rem, 4vw, 1.85rem);
    font-weight: 800;
    letter-spacing: -0.03em;
}
.ucp-guest-subtitle {
    margin: 0 0 2rem;
    font-size: 0.6875rem;
    font-weight: 700;
    letter-spacing: 0.14em;
    text-transform: uppercase;
    color: var(--ucp-text-muted);
}
.ucp-guest-btn {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: 0.5rem;
    width: 100%;
    max-width: 20rem;
    min-height: 3rem;
    padding: 0 1.5rem;
    border: none;
    border-radius: 0.625rem;
    font-size: 1rem;
    font-weight: 700;
    font-family: inherit;
    color: #fff;
    text-decoration: none;
    background: var(--bs-primary);
    box-shadow: 0 4px 20px rgba(var(--bs-primary-rgb), 0.35);
    transition: background 0.2s ease, transform 0.15s ease;
}
.ucp-guest-btn:hover {
    background: #5aadff;
    color: #fff;
    transform: translateY(-1px);
}
.ucp-guest-alert {
    margin-top: 1.25rem;
    padding: 0.875rem 1rem;
    border-radius: 0.625rem;
    font-size: 0.875rem;
    font-weight: 600;
    line-height: 1.45;
    color: #ff8a94;
    background: rgba(232, 72, 85, 0.1);
    border: 1px solid rgba(232, 72, 85, 0.3);
}
.ucp-verify-wrap {
    max-width: 36rem;
    margin: 0 auto;
    padding: 1.75rem 1.125rem 3rem;
}
.ucp-verify-card {
    background: var(--ucp-bg-card);
    border: 1px solid var(--ucp-border);
    border-radius: var(--ucp-radius);
    padding: 1.125rem 1.125rem 1rem;
    margin-bottom: 0.875rem;
    box-shadow: var(--ucp-shadow-soft);
}
.ucp-verify-card h2 {
    font-size: 1rem;
    font-weight: 700;
    color: var(--bs-primary);
    margin-bottom: 0.625rem;
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 0.625rem;
    flex-wrap: wrap;
}
.ucp-verify-status {
    font-size: 0.75rem;
    font-weight: 600;
    padding: 0.25rem 0.625rem;
    border-radius: 999px;
    border: 1px solid var(--ucp-border);
    color: var(--ucp-text-muted);
}
.ucp-verify-status.ok {
    border-color: rgba(72, 199, 116, 0.45);
    color: #7dffb1;
}
.ucp-verify-wrap h1 {
    font-size: 1.35rem;
    font-weight: 800;
    letter-spacing: -0.02em;
    margin-bottom: 0.5rem;
}
.ucp-verify-wrap > .mb-4 > p {
    color: var(--ucp-text-muted);
    font-size: 0.875rem;
    line-height: 1.55;
    margin: 0;
}
