:root {
    --wg-ink: #111318;
    --wg-muted: #677080;
    --wg-line: #dfe4ea;
    --wg-soft: #f6f8fb;
    --wg-surface: rgba(255, 255, 255, 0.92);
    --wg-gold: #c9a227;
    --wg-teal: #1b8a7d;
    --wg-focus: rgba(27, 138, 125, 0.22);
    --wg-shadow: 0 18px 60px rgba(17, 19, 24, 0.12);
    --wg-radius: 8px;
    --wg-font: "Noto Sans TC", "Segoe UI", sans-serif;
}

html {
    scroll-behavior: smooth;
    scrollbar-gutter: stable;
    width: 100%;
    max-width: 100%;
    overflow-x: clip;
}

body {
    background:
        radial-gradient(circle at 20% 10%, rgba(201, 162, 39, 0.12), transparent 28rem),
        linear-gradient(135deg, #fbfcfd 0%, #f4f7fa 45%, #eef3f1 100%);
    color: var(--wg-ink);
    font-family: var(--wg-font);
    text-rendering: optimizeLegibility;
    -webkit-font-smoothing: antialiased;
    width: 100%;
    max-width: 100%;
    overflow-x: clip;
}

body.modal-open {
    padding-right: 0 !important;
}

body > body {
    display: block;
    min-height: 100%;
    width: 100%;
    max-width: 100%;
    overflow-x: clip;
}

.page,
main,
article,
#main,
.wg-site-header,
.wg-site-header .container-fluid,
.wg-site-header .row,
.wg-site-header-inner {
    max-width: 100%;
}

.page,
main,
article,
#main,
.wg-site-header {
    overflow-x: clip;
}

.container,
.container-fluid {
    min-width: 0;
}

.table-responsive,
.bb-table,
.admin-content {
    overscroll-behavior-x: contain;
}

@supports not (overflow: clip) {
    html,
    body,
    body > body,
    .page,
    main,
    article,
    #main,
    .wg-site-header {
        overflow-x: hidden;
    }
}

a,
.btn,
.form-control,
.card,
.dropdown-menu,
.modal-content,
.bb-table,
.table {
    transition: background-color 160ms ease, border-color 160ms ease, box-shadow 160ms ease, color 160ms ease, transform 160ms ease;
}

a {
    color: var(--wg-teal);
}

a:hover,
a:focus {
    color: #12665d;
}

.btn {
    border-radius: var(--wg-radius);
    font-weight: 700;
    min-height: 44px;
}

.btn-primary,
.btn-warning,
.btn-dark {
    background: var(--wg-ink) !important;
    border-color: var(--wg-ink) !important;
    color: #fff !important;
}

.btn-primary:hover,
.btn-warning:hover,
.btn-dark:hover {
    background: #20242c !important;
    border-color: #20242c !important;
    box-shadow: 0 10px 24px rgba(17, 19, 24, 0.18);
    transform: translateY(-1px);
}

.btn-outline-secondary {
    border-color: var(--wg-line);
    color: var(--wg-ink);
}

.btn-outline-secondary:hover {
    background: #fff;
    border-color: var(--wg-teal);
    color: var(--wg-ink);
    box-shadow: 0 10px 24px rgba(27, 138, 125, 0.12);
}

.form-control,
.form-select,
input.form-control {
    background: #fff !important;
    border: 1px solid var(--wg-line) !important;
    border-radius: var(--wg-radius) !important;
    color: var(--wg-ink) !important;
    min-height: 46px;
}

.form-control:focus,
.form-select:focus,
input.form-control:focus {
    border-color: var(--wg-teal) !important;
    box-shadow: 0 0 0 4px var(--wg-focus) !important;
}

.card,
.modal-content,
.dropdown-menu {
    background: var(--wg-surface) !important;
    border: 1px solid rgba(223, 228, 234, 0.86) !important;
    border-radius: var(--wg-radius) !important;
    box-shadow: var(--wg-shadow) !important;
    backdrop-filter: blur(16px);
}

.table,
.bb-table {
    border-color: var(--wg-line);
}

.table thead th,
.bb-table thead th {
    background: var(--wg-soft);
    color: #3d4653;
    font-size: 0.84rem;
    letter-spacing: 0;
}

#components-reconnect-modal {
    border-radius: var(--wg-radius);
}

.wg-page-enter {
    animation: wgFadeLift 420ms ease both;
}

@keyframes wgFadeLift {
    from {
        opacity: 0;
        transform: translateY(12px);
    }
    to {
        opacity: 1;
        transform: translateY(0);
    }
}

@media (prefers-reduced-motion: reduce) {
    html {
        scroll-behavior: auto;
    }

    *,
    *::before,
    *::after {
        animation-duration: 1ms !important;
        transition-duration: 1ms !important;
    }
}

.wg-site-header {
    min-height: 4rem;
}

.wg-site-header .container-fluid,
.wg-site-header .row {
    width: 100%;
}

.wg-site-header-inner {
    gap: clamp(0.5rem, 2vw, 1.5rem);
    min-width: 0;
    width: 100%;
}

.wg-site-logo {
    align-items: center;
    display: inline-flex;
    flex: 0 0 auto;
    min-height: 44px;
}

.wg-site-logo img {
    display: block;
    margin-left: 0 !important;
    max-height: clamp(3.25rem, 7vw, 5.625rem);
    max-width: min(44vw, 13rem);
    object-fit: contain;
}

.wg-mobile-menu-toggle {
    align-items: center !important;
    display: inline-flex !important;
    flex: 0 0 44px;
    justify-content: center !important;
    min-height: 44px !important;
    min-width: 44px !important;
    padding: 0 !important;
}

.wg-desktop-nav-list {
    min-width: 0;
    text-align: end;
}

.wg-desktop-nav-list ul {
    align-items: center;
    display: flex;
    flex-wrap: wrap;
    gap: clamp(0.25rem, 1.2vw, 1rem);
    justify-content: flex-end;
    margin: 0;
    padding: 0;
}

.wg-desktop-nav-list li {
    align-items: center;
    display: inline-flex;
    min-height: 44px;
}

.wg-desktop-nav-list a {
    align-items: center;
    display: inline-flex;
    min-height: 44px;
    white-space: nowrap;
}

.wg-desktop-login {
    min-width: 0;
}

@media (max-width: 767.98px) {
    .wg-site-header {
        min-height: 3.75rem;
    }

    .wg-site-header-inner {
        width: 100%;
    }
}

#login.login-shell {
    min-height: 100svh;
    padding: 7rem 1rem 2rem;
    background:
        linear-gradient(115deg, rgba(17, 19, 24, 0.82), rgba(17, 19, 24, 0.35)),
        url("/main/assets/img/hero-carousel/1.jpg") center / cover no-repeat,
        #111318;
}

#login .login-panel {
    display: grid;
    grid-template-columns: minmax(0, 1fr) minmax(340px, 430px);
    gap: clamp(1.5rem, 4vw, 4.5rem);
    align-items: center;
    width: min(1120px, 100%);
    margin: 0 auto;
}

#login .login-story {
    color: #fff;
    max-width: 620px;
}

#login .login-kicker,
#login .login-card-header span {
    display: inline-block;
    color: #f4c942;
    font-size: 0.78rem;
    font-weight: 800;
    letter-spacing: 0.08em;
    text-transform: uppercase;
}

#login .login-story h1 {
    margin: 1rem 0;
    color: #fff;
    font-size: clamp(2.35rem, 6vw, 5rem);
    font-weight: 900;
    line-height: 1.02;
}

#login .login-story p {
    max-width: 32rem;
    color: rgba(255, 255, 255, 0.78);
    font-size: 1.04rem;
    line-height: 1.8;
}

#login .login-proof {
    display: flex;
    flex-wrap: wrap;
    gap: 0.75rem;
    margin-top: 2rem;
}

#login .login-proof span {
    border: 1px solid rgba(255, 255, 255, 0.26);
    border-radius: 999px;
    color: rgba(255, 255, 255, 0.86);
    padding: 0.55rem 0.85rem;
}

#login .login-card {
    background: rgba(255, 255, 255, 0.95);
    border: 1px solid rgba(255, 255, 255, 0.72);
    border-radius: 8px;
    box-shadow: 0 24px 70px rgba(0, 0, 0, 0.28);
    padding: clamp(1.25rem, 3vw, 2.25rem);
    backdrop-filter: blur(18px);
}

#login .login-card-header {
    margin-bottom: 1.5rem;
}

#login .login-card-header h2 {
    margin: 0.2rem 0 0;
    color: #111318;
    font-size: 1.8rem;
    font-weight: 900;
}

#login .login-submit {
    margin-top: 0.25rem;
}

#login .login-divider {
    display: flex;
    align-items: center;
    gap: 0.9rem;
    color: #7b8492;
    font-size: 0.78rem;
    font-weight: 800;
    letter-spacing: 0.08em;
}

#login .login-divider::before,
#login .login-divider::after {
    content: "";
    height: 1px;
    flex: 1;
    background: #dfe4ea;
}

#login .google-login-button {
    background: #fff !important;
    border-color: #dfe4ea !important;
    color: #1f2328 !important;
    gap: 0.75rem;
    text-decoration: none;
}

#login .google-login-button img {
    width: 22px;
    height: 22px;
}

@media (max-width: 860px) {
    #login.login-shell {
        padding-top: 5.75rem;
    }

    #login .login-panel {
        grid-template-columns: 1fr;
    }

    #login .login-story h1 {
        font-size: clamp(2.1rem, 12vw, 3.2rem);
    }
}

.wallet-price-list {
    display: flex;
    flex-direction: column;
    gap: 8px;
}

.wallet-price-row {
    min-height: 38px;
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 12px;
    padding: 0 12px;
    border: 1px solid var(--wg-line);
    border-radius: 8px;
    background: rgba(255, 255, 255, 0.72);
}

.wallet-price-row span {
    color: var(--wg-muted);
    font-weight: 700;
}

.wallet-price-row strong {
    color: var(--wg-ink);
    font-weight: 900;
}

@media (max-width: 520px) {
    #login.login-shell {
        padding-inline: 0.75rem;
    }

    #login .login-card {
        padding: 1.1rem;
    }
}

/* Admin dashboard shell */
:root {
    --admin-bg: #f5f7fa;
    --admin-sidebar-bg: #ffffff;
    --admin-border: #e1e7ef;
    --admin-text-main: #111827;
    --admin-text-muted: #64748b;
    --admin-accent: #111318;
    --admin-accent-hover: #2a2f39;
    --admin-surface: #ffffff;
}

.admin-dashboard-container {
    position: fixed;
    inset: 0;
    z-index: 50;
    display: grid;
    grid-template-columns: 260px minmax(0, 1fr);
    width: 100vw;
    height: 100svh;
    overflow: hidden;
    background: var(--admin-bg);
    color: var(--admin-text-main);
    font-family: var(--wg-font);
}

.admin-sidebar {
    min-width: 0;
    background: var(--admin-sidebar-bg);
    border-right: 1px solid var(--admin-border);
    display: flex;
    flex-direction: column;
    overflow: hidden;
}

.sidebar-brand {
    min-height: 72px;
    display: flex;
    align-items: center;
    padding: 0 22px;
    border-bottom: 1px solid var(--admin-border);
}

.sidebar-brand .brand-logo {
    display: block;
    width: 190px;
    max-width: 100%;
    height: auto;
    filter: invert(1);
}

.sidebar-nav {
    flex: 1;
    overflow-y: auto;
    padding: 18px 12px;
}

.sidebar-nav .nav-list {
    list-style: none;
    padding: 0;
    margin: 0;
    display: flex;
    flex-direction: column;
    gap: 4px;
}

.sidebar-nav .nav-link {
    min-height: 42px;
    display: flex;
    align-items: center;
    gap: 10px;
    padding: 0 12px;
    color: var(--admin-text-muted);
    border-radius: 8px;
    font-size: 14px;
    font-weight: 800;
    letter-spacing: 0;
    text-decoration: none;
    white-space: nowrap;
}

.sidebar-nav .nav-link:hover,
.sidebar-nav .nav-link:focus {
    background: #eef3f7;
    color: var(--admin-text-main);
    text-decoration: none;
}

.sidebar-nav .nav-link.active {
    background: var(--admin-accent);
    color: #ffffff;
}

.sidebar-nav .nav-icon {
    width: 18px;
    text-align: center;
    flex: 0 0 18px;
}

.sidebar-footer {
    min-height: 74px;
    padding: 14px 16px;
    border-top: 1px solid var(--admin-border);
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 12px;
}

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

.user-profile .avatar {
    width: 36px;
    height: 36px;
    border-radius: 50%;
    background: #eef3f7;
    border: 1px solid var(--admin-border);
    display: flex;
    align-items: center;
    justify-content: center;
    color: var(--admin-text-muted);
    flex: 0 0 36px;
}

.user-profile .user-info {
    min-width: 0;
    display: flex;
    flex-direction: column;
}

.user-profile .user-name {
    max-width: 150px;
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
    color: var(--admin-text-main);
    font-size: 13px;
    font-weight: 900;
}

.user-profile .user-role {
    color: var(--admin-text-muted);
    font-size: 12px;
    font-weight: 700;
}

.logout-btn {
    width: 36px;
    height: 36px;
    border-radius: 8px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    color: var(--admin-text-muted);
    text-decoration: none;
}

.logout-btn:hover {
    background: #fee2e2;
    color: #b91c1c;
    text-decoration: none;
}

.admin-main {
    min-width: 0;
    display: flex;
    flex-direction: column;
    overflow: hidden;
}

.admin-header {
    min-height: 72px;
    padding: 0 28px;
    display: flex;
    align-items: center;
    justify-content: space-between;
    background: var(--admin-surface);
    border-bottom: 1px solid var(--admin-border);
}

.admin-header .header-title h2 {
    margin: 0;
    color: var(--admin-text-main);
    font-size: 20px;
    font-weight: 900;
    letter-spacing: 0;
}

.admin-content {
    flex: 1;
    min-height: 0;
    overflow: auto;
    padding: 28px;
}

.admin-page-container {
    width: min(1200px, 100%);
    margin: 0 auto;
    display: flex;
    flex-direction: column;
    gap: 20px;
}

.admin-card {
    background: var(--admin-surface) !important;
    border: 1px solid var(--admin-border) !important;
    border-radius: 8px !important;
    box-shadow: 0 14px 42px rgba(15, 23, 42, 0.08) !important;
    overflow: hidden;
}

.admin-card-header {
    padding: 16px 20px;
    border-bottom: 1px solid var(--admin-border);
    background: #fbfcfe;
}

.admin-card-header h3 {
    margin: 0;
    color: var(--admin-text-main);
    font-size: 18px;
    font-weight: 900;
    letter-spacing: 0;
}

.admin-card-body {
    padding: 20px;
}

.admin-card-body.p-0 {
    padding: 0 !important;
}

.admin-content .table {
    width: 100%;
    margin-bottom: 0;
    color: var(--admin-text-main);
}

.admin-content .table thead th {
    background: #f8fafc !important;
    color: var(--admin-text-muted) !important;
    border-bottom: 1px solid var(--admin-border) !important;
    font-size: 12px;
    font-weight: 900;
    letter-spacing: 0;
    white-space: nowrap;
}

.admin-content .table tbody td {
    color: var(--admin-text-main);
    border-bottom: 1px solid var(--admin-border) !important;
    vertical-align: middle;
}

.admin-error-card {
    background: #fff7ed;
    border: 1px solid #fed7aa;
    border-radius: 8px;
    color: #9a3412;
    padding: 20px;
}

.admin-error-card .btn-retry {
    margin-top: 12px;
    min-height: 40px;
    border: 0;
    border-radius: 8px;
    background: #111318;
    color: #ffffff;
    padding: 0 14px;
}

@media (max-width: 860px) {
    .admin-dashboard-container {
        grid-template-columns: 72px minmax(0, 1fr);
    }

    .sidebar-brand {
        padding: 0 10px;
        justify-content: center;
    }

    .sidebar-brand .brand-logo {
        width: 42px;
        height: 42px;
        object-fit: cover;
        object-position: left center;
    }

    .sidebar-nav .nav-link span,
    .user-profile .user-info {
        display: none;
    }

    .sidebar-nav .nav-link {
        justify-content: center;
        padding: 0;
    }

    .sidebar-nav .nav-icon {
        margin: 0;
    }

    .sidebar-footer {
        padding: 12px;
        flex-direction: column;
    }

    .admin-header,
    .admin-content {
        padding-inline: 16px;
    }
}

.kyc-review-workbench {
    display: flex;
    flex-direction: column;
    gap: 16px;
    width: min(1240px, 100%);
    margin: 0 auto;
    color: var(--admin-text-main, #111827);
}

.kyc-review-header,
.kyc-review-card-header,
.kyc-review-stage-head,
.kyc-review-actions {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 12px;
    min-width: 0;
}

.kyc-review-header h2,
.kyc-review-card h3,
.kyc-review-stage h4 {
    margin: 0;
    letter-spacing: 0;
}

.kyc-review-header p,
.kyc-review-stage p {
    margin: 4px 0 0;
    color: var(--admin-text-muted, #64748b);
}

.kyc-review-search {
    display: grid;
    grid-template-columns: minmax(220px, 360px) auto;
    gap: 8px;
}

.kyc-review-stats {
    display: grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: 12px;
}

.kyc-review-stats > div,
.kyc-review-card,
.kyc-review-queue,
.kyc-review-empty {
    background: var(--admin-surface, #ffffff);
    border: 1px solid var(--admin-border, #e5e7eb);
    border-radius: 8px;
}

.kyc-review-stats > div {
    padding: 14px 16px;
}

.kyc-review-stats strong {
    display: block;
    font-size: 24px;
}

.kyc-review-stats span,
.kyc-review-summary-grid span,
.kyc-review-evidence span,
.kyc-review-field span {
    color: var(--admin-text-muted, #64748b);
    font-size: 13px;
}

.kyc-review-grid {
    display: grid;
    grid-template-columns: minmax(260px, 340px) minmax(0, 1fr);
    gap: 16px;
    align-items: start;
    min-width: 0;
}

.kyc-review-queue {
    display: flex;
    flex-direction: column;
    overflow: hidden;
}

.kyc-review-queue-header {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 12px;
    padding: 14px 16px;
    border-bottom: 1px solid var(--admin-border, #e5e7eb);
}

.kyc-review-queue-header div {
    display: grid;
    gap: 2px;
}

.kyc-review-queue-header span,
.kyc-review-queue-meta,
.kyc-review-queue-footer {
    color: var(--admin-text-muted, #64748b);
    font-size: 12px;
}

.kyc-review-queue-item {
    display: grid;
    gap: 4px;
    width: 100%;
    padding: 14px 16px;
    text-align: left;
    background: transparent;
    border: 0;
    border-bottom: 1px solid var(--admin-border, #e5e7eb);
    color: inherit;
}

.kyc-review-queue-item:disabled {
    cursor: wait;
    opacity: 0.72;
}

.kyc-review-queue-item:hover,
.kyc-review-queue-item.is-selected {
    background: rgba(15, 23, 42, 0.05);
}

.kyc-review-queue-name {
    font-weight: 700;
}

.kyc-review-queue-name,
.kyc-review-queue-meta,
.kyc-review-queue-footer span,
.kyc-review-summary-grid strong,
.kyc-review-final-grid strong {
    min-width: 0;
    overflow-wrap: anywhere;
}

.kyc-review-queue-footer {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 8px;
    min-width: 0;
}

.kyc-review-detail,
.kyc-review-stage-list {
    display: grid;
    gap: 16px;
    min-width: 0;
}

.kyc-review-card {
    padding: 16px;
    min-width: 0;
    overflow-x: auto;
}

.kyc-review-summary-grid,
.kyc-review-evidence-grid,
.kyc-review-final-grid {
    display: grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: 12px;
    margin-top: 16px;
}

.kyc-review-summary-grid > div,
.kyc-review-final-grid > div {
    display: grid;
    gap: 4px;
    padding: 12px;
    border: 1px solid var(--admin-border, #e5e7eb);
    border-radius: 8px;
}

.kyc-review-stage {
    padding: 14px;
    border: 1px solid var(--admin-border, #e5e7eb);
    border-radius: 8px;
}

.kyc-review-evidence {
    display: grid;
    gap: 8px;
    min-width: 0;
}

.kyc-review-evidence > div:not(.kyc-review-missing) {
    min-height: 180px;
    display: grid;
    place-items: center;
    overflow: hidden;
    border: 1px dashed var(--admin-border, #e5e7eb);
    border-radius: 8px;
    background: #f8fafc;
}

.kyc-review-evidence img {
    max-width: 100%;
    max-height: 220px;
    object-fit: contain;
}

.kyc-review-missing,
.kyc-review-empty {
    padding: 20px;
    color: var(--admin-text-muted, #64748b);
}

.kyc-review-status {
    display: inline-flex;
    align-items: center;
    width: fit-content;
    padding: 4px 8px;
    border-radius: 999px;
    background: #f1f5f9;
    color: #334155;
    font-size: 12px;
    font-weight: 700;
}

.kyc-review-status.is-approved,
.kyc-review-final-grid .is-approved {
    background: #ecfdf5;
    color: #047857;
}

.kyc-review-status.is-rejected,
.kyc-review-final-grid .is-rejected {
    background: #fef2f2;
    color: #b91c1c;
}

.kyc-review-status.is-pending,
.kyc-review-final-grid .is-pending {
    background: #fffbeb;
    color: #92400e;
}

.kyc-review-field {
    display: grid;
    gap: 6px;
    margin-top: 12px;
}

.kyc-review-field small {
    color: #b45309;
    font-size: 12px;
}

.kyc-review-actions {
    justify-content: flex-end;
    margin-top: 12px;
}

.kyc-review-reason {
    margin-top: 12px;
    padding: 10px 12px;
    border-radius: 8px;
    background: #fef2f2;
    color: #991b1b;
}

.kyc-review-log-list {
    display: grid;
    gap: 12px;
}

.kyc-review-log-item {
    display: grid;
    gap: 6px;
    padding: 12px;
    border: 1px solid var(--admin-border, #e5e7eb);
    border-radius: 8px;
    background: #ffffff;
}

.kyc-review-log-item div {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 12px;
}

.kyc-review-log-item span,
.kyc-review-log-item time,
.kyc-review-log-item p {
    color: var(--admin-text-muted, #64748b);
    font-size: 13px;
}

.kyc-review-log-item p {
    margin: 0;
}

@media (max-width: 992px) {
    .kyc-review-header,
    .kyc-review-card-header,
    .kyc-review-stage-head {
        align-items: flex-start;
        flex-direction: column;
    }

    .kyc-review-search,
    .kyc-review-grid,
    .kyc-review-stats,
    .kyc-review-summary-grid,
    .kyc-review-evidence-grid,
    .kyc-review-final-grid {
        grid-template-columns: 1fr;
    }

    .kyc-review-actions {
        align-items: stretch;
        flex-direction: column;
    }

    .kyc-review-actions .btn {
        width: 100%;
    }
}

.kyc-flow-shell {
    width: min(1120px, calc(100% - 32px));
    margin: 0 auto;
    padding: 48px 0 72px;
    color: #111827;
}

.kyc-flow-hero {
    display: grid;
    grid-template-columns: minmax(0, 1fr) minmax(280px, 420px);
    gap: 24px;
    align-items: stretch;
    margin-bottom: 24px;
}

.kyc-flow-kicker,
.kyc-flow-status-kicker {
    display: inline-flex;
    margin-bottom: 8px;
    color: #6b5cff;
    font-size: 12px;
    font-weight: 800;
    letter-spacing: 0.08em;
    text-transform: uppercase;
}

.kyc-flow-hero h1,
.kyc-flow-status h2 {
    margin: 0;
    letter-spacing: 0;
}

.kyc-flow-hero h1 {
    max-width: 720px;
    font-size: clamp(32px, 5vw, 56px);
    line-height: 1.05;
}

.kyc-flow-hero p,
.kyc-flow-status p,
.kyc-flow-loading span,
.kyc-flow-step span {
    color: #64748b;
}

.kyc-flow-hero p {
    max-width: 680px;
    margin: 16px 0 0;
    font-size: 16px;
}

.kyc-flow-status,
.kyc-flow-content,
.kyc-flow-loading {
    border: 1px solid #e5e7eb;
    border-radius: 8px;
    background: #ffffff;
}

.kyc-flow-status {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 16px;
    padding: 20px;
}

.kyc-flow-status p {
    margin: 8px 0 0;
}

.kyc-flow-status.is-approved {
    border-color: #bbf7d0;
    background: #f0fdf4;
}

.kyc-flow-status.is-rejected {
    border-color: #fecaca;
    background: #fef2f2;
}

.kyc-flow-status.is-pending {
    border-color: #fde68a;
    background: #fffbeb;
}

.kyc-flow-progress {
    display: grid;
    grid-template-columns: repeat(5, minmax(0, 1fr));
    gap: 10px;
    margin-bottom: 16px;
}

.kyc-flow-step {
    display: flex;
    gap: 10px;
    min-width: 0;
    padding: 12px;
    border: 1px solid #e5e7eb;
    border-radius: 8px;
    background: #ffffff;
}

.kyc-flow-step-number {
    display: inline-grid;
    place-items: center;
    flex: 0 0 28px;
    width: 28px;
    height: 28px;
    border-radius: 999px;
    background: #f1f5f9;
    color: #334155;
    font-weight: 800;
}

.kyc-flow-step strong,
.kyc-flow-step span {
    display: block;
}

.kyc-flow-step strong {
    font-size: 14px;
}

.kyc-flow-step span {
    font-size: 12px;
}

.kyc-flow-step.is-current {
    border-color: #6b5cff;
}

.kyc-flow-step.is-current .kyc-flow-step-number {
    background: #6b5cff;
    color: #ffffff;
}

.kyc-flow-step.is-done .kyc-flow-step-number {
    background: #dcfce7;
    color: #166534;
}

.kyc-flow-content {
    padding: 24px;
    overflow: hidden;
}

.kyc-flow-content .row {
    margin-inline: 0;
}

.kyc-flow-loading {
    display: grid;
    place-items: center;
    gap: 12px;
    min-height: 280px;
    padding: 24px;
}

@media (max-width: 992px) {
    .kyc-flow-hero,
    .kyc-flow-progress {
        grid-template-columns: 1fr;
    }

    .kyc-flow-status {
        align-items: flex-start;
        flex-direction: column;
    }

    .kyc-flow-content {
        padding: 16px;
    }
}

.admin-dashboard-container a:focus-visible,
.admin-dashboard-container button:focus-visible,
.admin-dashboard-container input:focus-visible,
.admin-dashboard-container textarea:focus-visible,
.kyc-flow-shell a:focus-visible,
.kyc-flow-shell button:focus-visible,
.kyc-flow-shell input:focus-visible,
.kyc-flow-shell textarea:focus-visible {
    outline: 3px solid #facc15;
    outline-offset: 2px;
}

.kyc-review-empty[aria-live="polite"]::before,
.kyc-flow-loading::before {
    content: "";
    width: 24px;
    height: 24px;
    border: 3px solid #d1d5db;
    border-top-color: #111318;
    border-radius: 50%;
    animation: wg-spin 0.8s linear infinite;
}

@keyframes wg-spin {
    to {
        transform: rotate(360deg);
    }
}
