/* ==========================================================================
   KYC tab — visual identity aligned with the Wallets tab.
   Globally loaded via app.js so .bg-gradient-primary is always available.
   ========================================================================== */

/* Shared gradient for tab section headers (used by KYC, Wallets, etc.) */
.bg-gradient-primary {
    background: linear-gradient(135deg, #667eea 0%, #764ba2 100%);
}

/* Row hover/expand styling — shared by every expandable list row across the
   customer detail tabs (Wallets, KYC documents, IBANs, …). Single source of
   truth so visual feedback stays consistent. */
.kyc-row,
.iban-row { transition: all .2s ease; }

.kyc-row:hover,
.iban-row:hover {
    background-color: #f8f9fa !important;
    transform: scale(1.005);
    box-shadow: 0 2px 12px rgba(0, 0, 0, .08);
}

.kyc-row[aria-expanded="true"] {
    background-color: #f0f4ff !important;
    border-left: 4px solid #667eea;
}

/* IBAN cards carry their aria-expanded on the inner header (role="button");
   the :has() selector lifts the open state up to the card so we can apply
   the same accent. */
.iban-row:has(.iban-row-header[aria-expanded="true"]) {
    background-color: #f0f4ff !important;
    border-left: 4px solid #667eea;
}

.icon-badge { transition: all .2s ease; }
.kyc-row:hover .icon-badge,
.iban-row:hover .avatar-title { transform: scale(1.05); }

/* ==========================================================================
   Document detail frame (loaded inside the expanded row).
   iOS-flavoured layout: rounded surfaces, grouped key-value lists.
   ========================================================================== */

.kyc-doc {
    --kyc-radius:    14px;
    --kyc-radius-sm: 10px;
    --kyc-surface:   #fff;
    --kyc-surface-2: #f9f9fb;
    --kyc-separator: rgba(60, 60, 67, .12);
    --kyc-text:      #1d1d1f;
    --kyc-text-2:    rgba(60, 60, 67, .6);
    --kyc-text-3:    rgba(60, 60, 67, .3);
    --kyc-shadow-sm: 0 1px 2px rgba(0, 0, 0, .04);
    --kyc-easing:    cubic-bezier(.32, .72, 0, 1);

    display: grid;
    grid-template-columns: 1fr;
    gap: 1rem;
    color: var(--kyc-text);
    font-family: -apple-system, BlinkMacSystemFont, "SF Pro Text", "Inter", "Segoe UI", Roboto, system-ui, sans-serif;
}

[data-bs-theme="dark"] .kyc-doc {
    --kyc-surface:   #1c1c1e;
    --kyc-surface-2: #2c2c2e;
    --kyc-separator: rgba(84, 84, 88, .65);
    --kyc-text:      #f5f5f7;
    --kyc-text-2:    rgba(235, 235, 245, .6);
    --kyc-text-3:    rgba(235, 235, 245, .3);
    --kyc-shadow-sm: 0 1px 2px rgba(0, 0, 0, .35);
}

@media (min-width: 1200px) {
    .kyc-doc { grid-template-columns: minmax(0, 2fr) minmax(280px, 1fr); }
}

.kyc-doc__media {
    background: var(--kyc-surface);
    border-radius: var(--kyc-radius);
    padding: .75rem;
    box-shadow: var(--kyc-shadow-sm);
}

.kyc-doc__image,
.kyc-doc__video {
    display: block;
    width: 100%;
    height: auto;
    max-height: 70vh;
    object-fit: contain;
    border-radius: var(--kyc-radius-sm);
    background: #000;
}

.kyc-doc__image { cursor: zoom-in; transition: opacity .15s var(--kyc-easing); }
.kyc-doc__image:hover { opacity: .92; }

.kyc-doc__caption {
    margin-top: .625rem;
    padding: 0 .25rem;
    font-size: .8125rem;
    color: var(--kyc-text-2);
    display: flex;
    align-items: center;
    gap: .5rem;
}

.kyc-doc__no-preview {
    text-align: center;
    padding: 3rem 1rem;
}

.kyc-doc__no-preview-icon {
    font-size: 3rem;
    color: var(--kyc-text-3);
    margin-bottom: 1rem;
    display: block;
}

/* Sidebar (grouped inset list, iOS-style) */
.kyc-aside { display: flex; flex-direction: column; gap: 1rem; }

.kyc-card {
    background: var(--kyc-surface);
    border-radius: var(--kyc-radius);
    overflow: hidden;
    box-shadow: var(--kyc-shadow-sm);
}

.kyc-card__title {
    font-size: .75rem;
    font-weight: 600;
    text-transform: uppercase;
    letter-spacing: .04em;
    color: var(--kyc-text-2);
    padding: .75rem 1rem .25rem;
    margin: 0;
}

.kyc-kv {
    margin: 0;
    padding: 0;
    display: grid;
    grid-template-columns: minmax(7rem, auto) 1fr;
    gap: 0;
}

.kyc-kv__key,
.kyc-kv__val {
    padding: .625rem 1rem;
    border-top: 1px solid var(--kyc-separator);
    font-size: .9375rem;
    margin: 0;
}

.kyc-kv__key:nth-of-type(1),
.kyc-kv__val:nth-of-type(1) { border-top: 0; }

.kyc-kv__key { color: var(--kyc-text-2); font-weight: 500; }
.kyc-kv__val { color: var(--kyc-text); word-break: break-word; }

.kyc-kv__val code {
    font-size: .8125rem;
    background: var(--kyc-surface-2);
    padding: 1px 6px;
    border-radius: 6px;
}

.kyc-btn {
    display: inline-flex;
    align-items: center;
    gap: .5rem;
    padding: .5rem 1rem;
    border-radius: 999px;
    font-size: .9375rem;
    font-weight: 600;
    background: #667eea;
    color: #fff;
    text-decoration: none;
    border: 0;
    cursor: pointer;
    transition: opacity .15s var(--kyc-easing), transform .1s var(--kyc-easing);
}

.kyc-btn:hover  { opacity: .9; color: #fff; }
.kyc-btn:active { transform: scale(.98); }

/* ==========================================================================
   Lightbox — fullscreen image preview with frosted backdrop.
   ========================================================================== */

.kyc-lightbox {
    position: fixed;
    inset: 0;
    z-index: 1080;
    display: flex;
    align-items: center;
    justify-content: center;
    padding: 2rem;
    background: rgba(0, 0, 0, .75);
    backdrop-filter: blur(20px);
    -webkit-backdrop-filter: blur(20px);
    opacity: 0;
    pointer-events: none;
    transition: opacity .25s cubic-bezier(.32, .72, 0, 1);
}

.kyc-lightbox--open {
    opacity: 1;
    pointer-events: auto;
}

.kyc-lightbox__media {
    max-width: 100%;
    max-height: 100%;
    border-radius: 14px;
    box-shadow: 0 30px 60px rgba(0, 0, 0, .5);
    transform: scale(.96);
    transition: transform .3s cubic-bezier(.32, .72, 0, 1);
}

.kyc-lightbox--open .kyc-lightbox__media { transform: scale(1); }

.kyc-lightbox__close {
    position: absolute;
    top: 1.25rem;
    right: 1.25rem;
    width: 2.5rem;
    height: 2.5rem;
    border-radius: 50%;
    border: 0;
    background: rgba(255, 255, 255, .15);
    color: #fff;
    font-size: 1.25rem;
    cursor: pointer;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    backdrop-filter: blur(20px);
    -webkit-backdrop-filter: blur(20px);
    transition: background .15s cubic-bezier(.32, .72, 0, 1);
}

.kyc-lightbox__close:hover { background: rgba(255, 255, 255, .25); }

@media (prefers-reduced-motion: reduce) {
    .kyc-row,
    .kyc-doc *,
    .kyc-lightbox * {
        animation-duration: .01ms !important;
        transition-duration: .01ms !important;
    }
}
