/**
 * XaniaCode Compliance Suite - Premium Client Portal UI
 */
.bcs-portal {
    --bcs-font: inherit;
    --bcs-accent: #2563eb;
    --bcs-accent-2: #7c3aed;
    --bcs-on-accent: #ffffff;
    --bcs-on-accent-muted: rgba(255,255,255,.86);
    --bcs-on-accent-soft: rgba(255,255,255,.16);
    --bcs-on-accent-border: rgba(255,255,255,.24);
    --bcs-bg: transparent;
    --bcs-surface: color-mix(in srgb, Canvas 94%, transparent);
    --bcs-surface-2: color-mix(in srgb, Canvas 88%, CanvasText 4%);
    --bcs-text: CanvasText;
    --bcs-muted: color-mix(in srgb, CanvasText 62%, transparent);
    --bcs-border: color-mix(in srgb, CanvasText 12%, transparent);
    --bcs-border-strong: color-mix(in srgb, CanvasText 18%, transparent);
    --bcs-success: #10b981;
    --bcs-danger: #ef4444;
    --bcs-warning: #f59e0b;
    --bcs-radius: 20px;
    --bcs-radius-sm: 13px;
    --bcs-shadow: 0 20px 50px rgba(15, 23, 42, .10);
    --bcs-shadow-sm: 0 10px 26px rgba(15, 23, 42, .07);
    max-width: var(--bcs-max-width, 1180px);
    margin: 26px auto;
    font-family: var(--bcs-font);
    color: var(--bcs-text);
}
.bcs-portal *, .bcs-portal *::before, .bcs-portal *::after { box-sizing: border-box; }
.bcs-portal a { color: var(--bcs-accent); }
.bcs-portal a:hover { color: color-mix(in srgb, var(--bcs-accent) 80%, #000); }
.bcs-portal strong { font-weight: 650; }

.bcs-portal.bcs-theme-light {
    --bcs-surface: #ffffff;
    --bcs-surface-2: #f8fafc;
    --bcs-text: #111827;
    --bcs-muted: #64748b;
    --bcs-border: #e2e8f0;
    --bcs-border-strong: #cbd5e1;
}
.bcs-portal.bcs-theme-dark {
    --bcs-surface: #111827;
    --bcs-surface-2: #172033;
    --bcs-text: #f8fafc;
    --bcs-muted: #a7b0c0;
    --bcs-border: rgba(148, 163, 184, .24);
    --bcs-border-strong: rgba(148, 163, 184, .38);
    --bcs-shadow: 0 20px 54px rgba(0,0,0,.35);
    --bcs-shadow-sm: 0 10px 30px rgba(0,0,0,.22);
}
@media (prefers-color-scheme: dark) {
    .bcs-portal.bcs-theme-auto {
        --bcs-surface: #111827;
        --bcs-surface-2: #172033;
        --bcs-text: #f8fafc;
        --bcs-muted: #a7b0c0;
        --bcs-border: rgba(148, 163, 184, .24);
        --bcs-border-strong: rgba(148, 163, 184, .38);
        --bcs-shadow: 0 20px 54px rgba(0,0,0,.35);
        --bcs-shadow-sm: 0 10px 30px rgba(0,0,0,.22);
    }
}

.bcs-portal-shell {
    border: 1px solid var(--bcs-border);
    border-radius: calc(var(--bcs-radius) + 8px);
    padding: 22px;
    background:
        radial-gradient(circle at top left, color-mix(in srgb, var(--bcs-accent) 15%, transparent), transparent 34%),
        radial-gradient(circle at top right, color-mix(in srgb, var(--bcs-accent-2) 12%, transparent), transparent 30%),
        var(--bcs-bg);
}

.bcs-hero {
    position: relative;
    overflow: hidden;
    display: grid;
    grid-template-columns: 1fr auto;
    gap: 22px;
    align-items: center;
    min-height: 176px;
    color: #fff;
    background: var(--bcs-accent);
    background: linear-gradient(135deg, var(--bcs-accent) 0%, var(--bcs-accent-2) 100%);
    box-shadow: 0 20px 52px color-mix(in srgb, var(--bcs-accent) 24%, transparent);
}
.bcs-hero::after {
    content: "";
    position: absolute;
    right: -90px;
    top: -120px;
    width: 320px;
    height: 320px;
    border-radius: 999px;
    background: rgba(255,255,255,.16);
}
.bcs-hero h2 { color: #fff !important; margin-bottom: 8px !important; }
.bcs-hero p { color: rgba(255,255,255,.84) !important; margin: 0; }
.bcs-hero-badge {
    position: relative;
    z-index: 1;
    display: inline-flex;
    gap: 8px;
    align-items: center;
    justify-content: center;
    padding: 10px 14px;
    border-radius: 999px;
    background: rgba(255,255,255,.16);
    border: 1px solid rgba(255,255,255,.24);
    color: #fff;
    font-weight: 650;
    white-space: nowrap;
}

.bcs-grid { display: grid; grid-template-columns: minmax(0, 1.15fr) minmax(320px, .85fr); gap: 20px; }
.bcs-card {
    background: var(--bcs-surface);
    border: 1px solid var(--bcs-border);
    border-radius: var(--bcs-radius);
    padding: 24px;
    margin: 20px 0;
    box-shadow: var(--bcs-shadow-sm);
    backdrop-filter: blur(10px);
}
.bcs-card h2, .bcs-card h3 { margin: 0 0 16px; color: var(--bcs-text); font-weight: 650; letter-spacing: -.018em; }

/* Hero card override: this rule intentionally comes after .bcs-card so the hero card
   cannot inherit a white/surface background from the generic card styling. */
.bcs-portal .bcs-card.bcs-hero {
    color: var(--bcs-on-accent) !important;
    background: var(--bcs-accent) !important;
    background-image: linear-gradient(135deg, var(--bcs-accent) 0%, var(--bcs-accent-2) 100%) !important;
    border-color: color-mix(in srgb, var(--bcs-accent) 35%, var(--bcs-border)) !important;
}
.bcs-portal .bcs-card.bcs-hero h2 {
    color: var(--bcs-on-accent) !important;
}
.bcs-portal .bcs-card.bcs-hero p {
    color: var(--bcs-on-accent-muted) !important;
}
.bcs-portal .bcs-card.bcs-hero .bcs-hero-badge {
    color: var(--bcs-on-accent) !important;
    background: var(--bcs-on-accent-soft) !important;
    border-color: var(--bcs-on-accent-border) !important;
}

.bcs-card p { color: var(--bcs-muted); line-height: 1.65; }
.bcs-card-header { display: flex; align-items: center; justify-content: space-between; gap: 12px; margin-bottom: 14px; }
.bcs-card-icon {
    width: 42px;
    height: 42px;
    border-radius: 14px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    background: color-mix(in srgb, var(--bcs-accent) 12%, var(--bcs-surface));
    color: var(--bcs-accent);
    font-weight: 650;
}

.bcs-portal label { display: block; font-weight: 600; color: var(--bcs-text); margin: 14px 0; }
.bcs-portal input:not([type="file"]), .bcs-portal select, .bcs-portal textarea {
    width: 100%;
    border: 1px solid var(--bcs-border-strong);
    border-radius: var(--bcs-radius-sm);
    background: var(--bcs-surface);
    color: var(--bcs-text);
    padding: 12px 14px;
    min-height: 46px;
    margin-top: 8px;
    transition: border-color .18s ease, box-shadow .18s ease;
}
.bcs-portal input[type="file"] {
    width: 100%;
    border: 1px dashed var(--bcs-border-strong);
    border-radius: var(--bcs-radius-sm);
    background: var(--bcs-surface-2);
    color: var(--bcs-muted);
    padding: 14px;
    margin-top: 8px;
}
.bcs-portal textarea { min-height: 110px; line-height: 1.5; }
.bcs-portal input:focus, .bcs-portal select:focus, .bcs-portal textarea:focus {
    outline: none;
    border-color: var(--bcs-accent);
    box-shadow: 0 0 0 4px color-mix(in srgb, var(--bcs-accent) 16%, transparent);
}
.bcs-portal button, .bcs-button, .bcs-portal a.bcs-button {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: 8px;
    border: 0;
    border-radius: 999px;
    padding: 12px 18px;
    min-height: 44px;
    background: linear-gradient(135deg, var(--bcs-accent), var(--bcs-accent-2));
    color: #fff !important;
    text-decoration: none !important;
    font-weight: 650;
    cursor: pointer;
    box-shadow: 0 12px 28px color-mix(in srgb, var(--bcs-accent) 24%, transparent);
    transition: transform .18s ease, box-shadow .18s ease;
}
.bcs-portal button:hover, .bcs-button:hover { transform: translateY(-1px); box-shadow: 0 16px 34px color-mix(in srgb, var(--bcs-accent) 30%, transparent); }

.bcs-table-wrap { width: 100%; overflow-x: auto; border: 1px solid var(--bcs-border); border-radius: var(--bcs-radius); }
.bcs-table { width: 100%; border-collapse: separate; border-spacing: 0; background: var(--bcs-surface); }
.bcs-table th, .bcs-table td { padding: 14px; border-bottom: 1px solid var(--bcs-border); text-align: left; vertical-align: middle; color: var(--bcs-text); }
.bcs-table th { background: var(--bcs-surface-2); color: var(--bcs-muted); font-size: 12px; text-transform: uppercase; letter-spacing: .055em; font-weight: 650; }
.bcs-table tr:last-child td { border-bottom: 0; }
.bcs-table tr:hover td { background: color-mix(in srgb, var(--bcs-accent) 6%, transparent); }
.bcs-empty {
    border: 1px dashed var(--bcs-border-strong);
    border-radius: var(--bcs-radius);
    background: var(--bcs-surface-2);
    padding: 24px;
    color: var(--bcs-muted);
    text-align: center;
}
.bcs-alert { padding: 14px 16px; border-radius: var(--bcs-radius-sm); margin: 14px 0; border: 1px solid var(--bcs-border); font-weight: 600; }
.bcs-autodismiss { position: relative; overflow: hidden; transition: opacity .35s ease, transform .35s ease, margin .35s ease, padding .35s ease; }
.bcs-autodismiss::after { content: ""; position: absolute; left: 0; bottom: 0; height: 3px; width: 100%; background: currentColor; opacity: .24; transform-origin: left center; animation: bcsNoticeTimer 5s linear forwards; }
.bcs-alert-out { opacity: 0; transform: translateY(-6px); pointer-events: none; margin-top: 0; margin-bottom: 0; padding-top: 0; padding-bottom: 0; border-width: 0; }
@keyframes bcsNoticeTimer { from { transform: scaleX(1); } to { transform: scaleX(0); } }
.bcs-success { background: color-mix(in srgb, var(--bcs-success) 12%, var(--bcs-surface)); color: #047857; border-color: color-mix(in srgb, var(--bcs-success) 32%, var(--bcs-border)); }
.bcs-error { background: color-mix(in srgb, var(--bcs-danger) 10%, var(--bcs-surface)); color: #b91c1c; border-color: color-mix(in srgb, var(--bcs-danger) 30%, var(--bcs-border)); }
.bcs-login-required { max-width: 680px; }
.bcs-login-required form { background: var(--bcs-surface); border: 1px solid var(--bcs-border); border-radius: var(--bcs-radius); padding: 22px; box-shadow: var(--bcs-shadow-sm); }

@media (max-width: 920px) {
    .bcs-grid, .bcs-hero { grid-template-columns: 1fr; }
    .bcs-hero-badge { justify-self: flex-start; }
}
@media (max-width: 680px) {
    .bcs-portal { margin: 18px auto; }
    .bcs-portal-shell { padding: 12px; border-radius: 20px; }
    .bcs-card { padding: 18px; border-radius: 17px; }
    .bcs-table th, .bcs-table td { padding: 12px; }
}

/* Compliance profile tiles */
.bcs-profile-grid {
    display: grid;
    grid-template-columns: repeat(4, minmax(0, 1fr));
    gap: 14px;
    margin: 18px 0 2px;
}
.bcs-profile-tile {
    background: var(--bcs-surface);
    border: 1px solid var(--bcs-border);
    border-radius: var(--bcs-radius-sm);
    padding: 16px;
    box-shadow: var(--bcs-shadow-sm);
}
.bcs-profile-tile span {
    display: block;
    color: var(--bcs-muted);
    font-size: 12px;
    text-transform: uppercase;
    letter-spacing: .055em;
    margin-bottom: 6px;
}
.bcs-profile-tile strong {
    display: block;
    color: var(--bcs-text);
    font-size: 14px;
    line-height: 1.35;
    font-weight: 600;
}
@media (max-width: 920px) {
    .bcs-profile-grid { grid-template-columns: repeat(2, minmax(0, 1fr)); }
}
@media (max-width: 560px) {
    .bcs-profile-grid { grid-template-columns: 1fr; }
}


/* Client portal 2FA gate */
.bcs-2fa-required { max-width: 760px; }
.bcs-2fa-card {
    text-align: center;
    background: var(--bcs-surface);
}
.bcs-2fa-icon {
    width: 62px;
    height: 62px;
    margin: 0 auto 16px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    border-radius: 22px;
    background: var(--bcs-accent);
    color: #fff;
    box-shadow: 0 18px 36px color-mix(in srgb, var(--bcs-accent) 28%, transparent);
    font-size: 26px;
}
.bcs-2fa-setup {
    text-align: left;
    margin: 20px auto;
    padding: 18px;
    border: 1px solid var(--bcs-border);
    border-radius: var(--bcs-radius);
    background: color-mix(in srgb, var(--bcs-accent) 7%, var(--bcs-surface));
}
.bcs-2fa-setup strong { color: var(--bcs-text); font-weight: 650; }
.bcs-secret-key {
    margin: 12px 0;
    padding: 14px 16px;
    border-radius: var(--bcs-radius-sm);
    border: 1px dashed color-mix(in srgb, var(--bcs-accent) 40%, var(--bcs-border));
    background: var(--bcs-surface);
    color: var(--bcs-text);
    font-family: ui-monospace, SFMono-Regular, Menlo, Monaco, Consolas, "Liberation Mono", monospace;
    font-size: 18px;
    line-height: 1.55;
    letter-spacing: .12em;
    word-break: break-word;
    user-select: all;
}
.bcs-muted-note { color: var(--bcs-muted) !important; font-size: 13px; }
.bcs-2fa-setup details {
    margin-top: 12px;
    color: var(--bcs-muted);
}
.bcs-2fa-setup code {
    display: block;
    overflow-wrap: anywhere;
    margin-top: 8px;
    padding: 12px;
    border-radius: var(--bcs-radius-sm);
    background: var(--bcs-surface-2);
    color: var(--bcs-text);
}
.bcs-2fa-form {
    max-width: 360px;
    margin: 18px auto 0;
    text-align: left;
}
.bcs-code-input {
    text-align: center;
    font-size: 22px;
    letter-spacing: .24em;
    font-variant-numeric: tabular-nums;
}
.bcs-2fa-form button { width: 100%; }

.bcs-2fa-setup-link { margin-top: 4px; }

.bcs-2fa-qr-wrap {
    margin: 16px 0 14px;
    padding: 16px;
    border-radius: var(--bcs-radius);
    border: 1px solid color-mix(in srgb, var(--bcs-accent) 24%, var(--bcs-border));
    background: var(--bcs-surface);
    display: flex;
    align-items: center;
    justify-content: center;
}
.bcs-2fa-qr {
    width: min(100%, 240px);
    min-height: 240px;
    display: flex;
    align-items: center;
    justify-content: center;
    padding: 10px;
    border-radius: calc(var(--bcs-radius-sm) + 2px);
    background: #fff;
    box-shadow: inset 0 0 0 1px rgba(15,23,42,.06);
}
.bcs-2fa-qr svg {
    width: 100%;
    height: auto;
}
