/* Card request show */
body.v3 .request-show-back-link {
    font-size: 0.78rem;
    padding: 6px 12px;
    display: inline-flex;
    align-items: center;
    gap: 6px;
    width: fit-content;
}

body.v3 .request-show-hero {
    position: relative;
    border-radius: 16px;
    border: 2px solid var(--border-strong);
    background:
        radial-gradient(
            120% 80% at 100% 0%,
            var(--accent-soft),
            transparent 55%
        ),
        var(--bg-2);
    overflow: hidden;
}
body.v3 .request-show-hero__grid {
    display: grid;
    grid-template-columns: 260px minmax(0, 1fr);
    gap: 32px;
    padding: 28px;
    align-items: start;
}
body.v3 .request-show-hero__artCol {
    min-width: 0;
}
body.v3 .request-show-hero__artWrap {
    position: relative;
    width: 240px;
    max-width: 100%;
    border-radius: 12px;
    box-shadow:
        0 18px 40px rgba(0, 0, 0, 0.45),
        0 0 0 1px var(--border-strong);
    overflow: hidden;
    background: var(--bg-3);
}
body.v3 .request-show-hero__img {
    display: block;
    width: 240px;
    height: 336px;
    max-width: 100%;
    object-fit: cover;
}
body.v3 .request-show-hero__img--placeholder {
    min-height: 200px;
    background: linear-gradient(145deg, var(--bg-4), var(--bg-3));
}
body.v3 .request-show-hero__shimmer {
    pointer-events: none;
    position: absolute;
    inset: 0;
    z-index: 1;
    background: linear-gradient(
        115deg,
        transparent 40%,
        rgba(255, 255, 255, 0.06) 48%,
        rgba(255, 255, 255, 0.12) 50%,
        rgba(255, 255, 255, 0.06) 52%,
        transparent 60%
    );
    animation: request-show-shimmer 4.5s ease-in-out infinite;
}
@keyframes request-show-shimmer {
    0%,
    100% {
        transform: translateX(-30%);
        opacity: 0.35;
    }
    50% {
        transform: translateX(30%);
        opacity: 0.85;
    }
}
body.v3 .request-show-hero__foilChip {
    position: absolute;
    right: 10px;
    bottom: 10px;
    z-index: 2;
    font-size: 10px;
    font-weight: 700;
    letter-spacing: 0.06em;
    text-transform: uppercase;
    padding: 5px 8px;
    border-radius: 999px;
    background: var(--warn-soft);
    color: var(--warn);
    border: 1px solid rgba(251, 191, 36, 0.35);
}
body.v3 .request-show-hero__oracle {
    margin-top: 12px;
    font-size: 11px;
    color: var(--fg-3);
}
body.v3 .request-show-hero__oracle code {
    font-size: 11px;
    color: var(--fg-2);
}
body.v3 .request-show-hero__main {
    min-width: 0;
}
body.v3 .request-show-hero__eyebrowRow {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    gap: 6px 8px;
    margin-bottom: 8px;
    color: var(--fg-3);
    font-size: 12px;
}
body.v3 .request-show-hero__meta {
    color: var(--fg-3);
}
body.v3 .request-show-hero__dot {
    color: var(--fg-4);
}
body.v3 .request-show-hero__title {
    margin: 0 0 8px;
    font-size: clamp(1.75rem, 2.2vw + 1rem, 2.75rem);
    font-weight: 800;
    letter-spacing: -0.02em;
    line-height: 1.1;
    color: var(--fg);
}
body.v3 .request-show-hero__subtitle {
    margin: 0 0 16px;
    font-size: 14px;
    color: var(--fg-2);
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    gap: 6px;
}
body.v3 .request-show-hero__badges {
    display: flex;
    flex-wrap: wrap;
    gap: 8px;
    margin-bottom: 20px;
}
body.v3 .request-show-hero__progressRow {
    display: flex;
    flex-wrap: wrap;
    align-items: flex-end;
    justify-content: space-between;
    gap: 16px 24px;
    margin-bottom: 20px;
}
body.v3 .request-show-hero__mega {
    flex: 1;
    min-width: 200px;
}
body.v3 .request-show-hero__megaLine {
    display: flex;
    flex-wrap: wrap;
    align-items: baseline;
    gap: 6px 10px;
    margin-bottom: 10px;
}
body.v3 .request-show-hero__megaRem {
    font-size: clamp(2rem, 3vw + 1rem, 3.25rem);
    font-weight: 800;
    line-height: 1;
    color: var(--accent);
}
body.v3 .request-show-hero__megaSuffix {
    font-size: 15px;
    font-weight: 600;
    color: var(--fg-2);
}
body.v3 .request-show-hero__bar {
    height: 10px;
    border-radius: 999px;
    background: var(--bg-4);
    overflow: hidden;
}
body.v3 .request-show-hero__barFill {
    display: block;
    height: 100%;
    border-radius: 999px;
    background: linear-gradient(90deg, var(--accent), var(--accent-2));
    box-shadow: 0 0 14px rgba(167, 139, 250, 0.45);
    transition: width 0.35s ease;
}
body.v3 .request-show-hero__ctaRow {
    display: flex;
    flex-wrap: wrap;
    gap: 10px;
    flex-shrink: 0;
}
body.v3 .request-show-statGrid {
    display: grid;
    grid-template-columns: repeat(5, minmax(0, 1fr));
    gap: 12px;
}
body.v3 .request-show-statTile {
    background: var(--bg-3);
    border: 1px solid var(--border);
    border-radius: 10px;
    padding: 12px 14px;
}
body.v3 .request-show-statTile__lbl {
    font-size: 10px;
    font-weight: 700;
    letter-spacing: 0.06em;
    text-transform: uppercase;
    color: var(--fg-4);
    margin-bottom: 6px;
}
body.v3 .request-show-statTile__val {
    font-size: 1.35rem;
    font-weight: 700;
    color: var(--fg);
}
body.v3 .request-show-statTile__val--success {
    color: var(--success);
}
body.v3 .request-show-statTile__val--accent {
    color: var(--accent);
}
body.v3 .request-show-main {
    display: grid;
    grid-template-columns: 1.6fr minmax(0, 1fr);
    gap: 16px;
    align-items: start;
}
body.v3 .request-show-main__primary {
    display: flex;
    flex-direction: column;
    gap: 16px;
    min-width: 0;
}
body.v3 .request-show-main__sidebar {
    display: flex;
    flex-direction: column;
    gap: 16px;
    min-width: 0;
}
body.v3 .request-show-split {
    display: grid;
    grid-template-columns: 1.6fr minmax(0, 1fr);
    gap: 16px;
    align-items: start;
}
body.v3 .request-show-linesHead {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 12px;
    padding: 14px 18px;
    border-bottom: 1px solid var(--border);
    background: var(--bg-3);
}
body.v3 .request-show-linesHead__title {
    margin: 0;
    font-size: 13px;
    font-weight: 700;
    letter-spacing: 0.04em;
    text-transform: uppercase;
    color: var(--fg-3);
}
body.v3 .request-show-split__wa {
    min-width: 0;
}

body.v3 .request-wa-panel {
    padding: 20px;
    border-radius: 12px;
    height: 100%;
    display: flex;
    flex-direction: column;
    gap: 14px;
}
body.v3 .request-wa-panel__head {
    display: flex;
    gap: 14px;
    align-items: flex-start;
}
body.v3 .request-wa-panel__pill {
    flex-shrink: 0;
    width: 44px;
    height: 44px;
    border-radius: 999px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    background: #25d366;
    color: #fff;
    box-shadow: 0 4px 14px rgba(37, 211, 102, 0.35);
}
body.v3 .request-wa-panel__title {
    margin: 0 0 4px;
    font-size: 15px;
    font-weight: 700;
    color: var(--fg);
}
body.v3 .request-wa-panel__lead {
    margin: 0;
    font-size: 12.5px;
    line-height: 1.45;
    color: var(--fg-3);
}
body.v3 .request-wa-panel__quote {
    margin: 0;
    padding: 12px 14px;
    border-left: 3px solid var(--border-strong);
    border-radius: 0 8px 8px 0;
    background: var(--bg-3);
    font-size: 13px;
    color: var(--fg-2);
    line-height: 1.45;
}
body.v3 .request-wa-panel__actions {
    margin-top: auto;
    display: flex;
    flex-direction: column;
    gap: 8px;
    align-items: stretch;
}
body.v3 .request-wa-panel__cta {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: 8px;
    padding: 10px 16px;
    border-radius: 10px;
    font-size: 13px;
    font-weight: 600;
    text-decoration: none;
    border: none;
    cursor: pointer;
    background: #25d366;
    color: #0a0a0a;
    transition:
        filter 0.12s,
        transform 0.12s;
}
body.v3 .request-wa-panel__cta:hover {
    filter: brightness(1.06);
    color: #0a0a0a;
    text-decoration: none;
}
body.v3 .request-wa-panel__cta--disabled {
    opacity: 0.45;
    cursor: not-allowed;
    filter: none;
}
body.v3 .request-wa-panel__hint {
    margin: 0;
    font-size: 11.5px;
    color: var(--fg-4);
    text-align: center;
}

body.v3 .request-show-forms {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 16px;
    align-items: stretch;
}
body.v3 .request-show-forms__cell {
    min-width: 0;
}
body.v3 .request-show-formSurface {
    padding: 18px 20px;
    height: 100%;
    container-type: inline-size;
    container-name: request-show-form;
}
body.v3 .request-show-formSurface__head {
    display: flex;
    align-items: center;
    gap: 8px;
    margin-bottom: 14px;
    color: var(--accent);
}
body.v3 .request-show-formSurface__title {
    margin: 0;
    font-size: 13px;
    font-weight: 700;
    color: var(--fg);
    letter-spacing: 0.02em;
}
body.v3 .request-show-formSurface__actions {
    margin-top: 14px;
    padding-top: 14px;
    border-top: 1px solid var(--border);
    display: flex;
    justify-content: flex-end;
}
body.v3 .request-show-danger {
    padding: 18px 20px;
    border-color: rgba(251, 113, 133, 0.35) !important;
}
body.v3 .request-show-danger__head {
    color: var(--danger);
}
body.v3 .request-show-danger__title {
    color: var(--danger);
}

body.v3 .request-show-audit {
    padding: 0;
    overflow: hidden;
}
body.v3 .request-show-audit__head {
    display: flex;
    align-items: center;
    gap: 8px;
    padding: 14px 18px;
    border-bottom: 1px solid var(--border);
    background: var(--bg-3);
}
body.v3 .request-show-audit__list {
    padding: 0;
}
body.v3 .request-show-audit__row {
    padding: 14px 18px;
    border-bottom: 1px solid var(--border);
}
body.v3 .request-show-audit__row:last-child {
    border-bottom: 0;
}
body.v3 .request-show-audit__time {
    font-size: 11px;
    color: var(--fg-3);
    display: block;
}
body.v3 .request-show-audit__action {
    margin-top: 4px;
    font-size: 13.5px;
    font-weight: 500;
    color: var(--fg-2);
}
body.v3 .request-show-audit__actor {
    color: var(--fg-4);
}
body.v3 .request-show-audit__ctx {
    margin: 10px 0 0;
    padding: 10px 12px;
    border-radius: 8px;
    font-size: 11px;
    background: var(--bg-3);
    color: var(--fg-2);
    overflow: auto;
}

body.v3 .audit-pre {
    font-size: 0.75rem;
    max-height: 10rem;
    overflow: auto;
    background: var(--bg-3);
    border: 1px solid var(--border);
    border-radius: 6px;
    color: var(--fg-3);
    padding: 8px 12px;
}

body.v3 .request-show-table__price-col {
    text-align: end;
    white-space: nowrap;
    min-width: 5.5rem;
}

body.v3 .request-show-table__priceHint {
    margin-top: 2px;
    font-size: 0.68rem;
}

body.v3 .request-list-ref-price-th,
body.v3 .request-list-ref-price-cell {
    min-width: 4.5rem;
}

body.v3 .request-show-lines-surface {
    padding: 0;
    overflow: hidden;
}

body.v3 .request-show-lines-viewport {
    overflow-x: auto;
    -webkit-overflow-scrolling: touch;
    min-width: 0;
}

@media (max-width: 991.98px) {
    body.v3 .request-show-hero__grid {
        grid-template-columns: 1fr;
        justify-items: center;
        text-align: center;
        gap: 24px;
    }
    body.v3 .request-show-hero__main {
        text-align: center;
        width: 100%;
    }
    body.v3 .request-show-hero__eyebrowRow,
    body.v3 .request-show-hero__subtitle,
    body.v3 .request-show-hero__badges {
        justify-content: center;
    }
    body.v3 .request-show-hero__progressRow {
        flex-direction: column;
        align-items: center;
    }
    body.v3 .request-show-hero__mega {
        width: 100%;
    }
    body.v3 .request-show-hero__ctaRow {
        justify-content: center;
    }
    body.v3 .request-show-statGrid {
        grid-template-columns: repeat(2, minmax(0, 1fr));
    }
    body.v3 .request-show-main,
    body.v3 .request-show-split {
        grid-template-columns: 1fr;
    }
    body.v3 .request-show-forms {
        grid-template-columns: 1fr;
    }
}
@media (max-width: 575.98px) {
    body.v3 .request-show-statGrid {
        grid-template-columns: 1fr;
    }
}

/* Customer show */
body.v3 .customer-show-hero {
    position: relative;
    overflow: hidden;
    border-radius: 16px;
    padding: 28px;
    border: 1px solid var(--border-2);
    background:
        linear-gradient(135deg, var(--accent-soft), transparent 60%),
        var(--bg-2);
}
body.v3 .customer-show-hero__grid {
    display: grid;
    grid-template-columns: auto 1fr auto;
    gap: 24px;
    align-items: center;
}
@media (max-width: 767.98px) {
    body.v3 .customer-show-hero__grid {
        grid-template-columns: 1fr;
        text-align: center;
    }
    body.v3 .customer-show-hero__actions {
        width: 100%;
        justify-content: center;
        flex-wrap: wrap;
    }
    body.v3 .customer-show-hero__avatar {
        margin: 0 auto;
    }
    body.v3 .customer-show-hero__meta {
        justify-content: center;
    }
}
body.v3 .customer-show-hero__avatar {
    width: 84px;
    height: 84px;
    border-radius: 18px;
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 1.875rem;
    font-weight: 800;
    color: var(--accent);
    background: var(--bg-3);
    border: 1px solid var(--border-2);
    flex-shrink: 0;
}
body.v3 .customer-show-hero__eyebrow {
    margin-bottom: 0;
}
body.v3 .customer-show-hero__title {
    margin: 8px 0 6px;
    font-size: clamp(1.75rem, 4vw, 2.5rem);
    font-weight: 700;
    letter-spacing: -0.025em;
    line-height: 1;
    color: var(--fg);
}
body.v3 .customer-show-hero__meta {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    gap: 10px 14px;
    font-size: 14px;
    color: var(--fg-2);
}
body.v3 .customer-show-hero__meta-item {
    display: inline-flex;
    align-items: center;
    gap: 6px;
}
body.v3 .customer-show-hero__actions {
    display: flex;
    flex-wrap: wrap;
    gap: 8px;
    align-items: center;
    justify-content: flex-end;
    flex-shrink: 0;
}
body.v3 .customer-show-kpi .kpi {
    min-width: 0;
}

body.v3 .customer-show-main {
    display: grid;
    /* Contact column ~15% narrower than previous 0.9fr (0.9 × 0.85 ≈ 0.765) */
    grid-template-columns: 0.765fr 1.6fr;
    gap: 16px;
    align-items: flex-start;
}
@media (max-width: 991.98px) {
    body.v3 .customer-show-main {
        grid-template-columns: 1fr;
    }
}
body.v3 .customer-show-main__requests {
    min-width: 0;
}

body.v3 .customer-show-contact {
    padding: var(--d-pad-card, 20px);
    align-self: flex-start;
}
body.v3 .customer-show-contact__head {
    display: flex;
    align-items: center;
    justify-content: space-between;
    margin-bottom: 16px;
}
body.v3 .customer-show-contact__title {
    margin: 0;
    font-size: 14px;
    font-weight: 700;
    color: var(--fg);
}
body.v3 .customer-show-contact__head-btn {
    padding: 3px 8px;
    font-size: 11px;
}
body.v3 .customer-show-contact__stack {
    display: flex;
    flex-direction: column;
    gap: 12px;
}
body.v3 .customer-show-contact-chip {
    display: flex;
    align-items: center;
    gap: 12px;
    padding: 10px 12px;
    background: var(--bg-3);
    border-radius: 8px;
    border: 1px solid var(--border);
}
body.v3 .customer-show-contact-chip__ic {
    color: var(--accent);
    flex-shrink: 0;
    display: inline-flex;
    align-items: center;
}
body.v3 .customer-show-contact-chip__body {
    flex: 1 1 0%;
    min-width: 0;
    width: 100%;
    display: flex;
    flex-direction: column;
    align-items: stretch;
}
body.v3 .customer-show-contact-chip__k {
    font-size: 10.5px;
    color: var(--fg-3);
    text-transform: uppercase;
    letter-spacing: 0.1em;
    font-weight: 700;
}
body.v3 .customer-show-contact-chip__v {
    font-size: 13px;
    font-weight: 500;
    color: var(--fg);
    display: block;
    width: 100%;
    min-width: 0;
    box-sizing: border-box;
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
    cursor: text;
}
body.v3 .customer-show-contact-chip__v .form-control,
body.v3 .customer-show-contact-chip__v textarea.form-control {
    width: 100%;
    max-width: none;
    min-width: 0;
    display: block;
    box-sizing: border-box;
}
body.v3 .customer-show-contact-notes {
    padding: 12px;
    background: var(--bg-3);
    border-radius: 8px;
    border: 1px solid var(--border);
    margin-top: 4px;
}
body.v3 .customer-show-contact-notes__body {
    font-size: 13px;
    color: var(--fg-2);
    font-style: italic;
    display: block;
    width: 100%;
    min-width: 0;
    box-sizing: border-box;
    white-space: pre-wrap;
    cursor: text;
}
body.v3 .customer-show-contact-notes__body .form-control,
body.v3 .customer-show-contact-notes__body textarea.form-control {
    width: 100%;
    max-width: none;
    min-width: 0;
    display: block;
    box-sizing: border-box;
}
body.v3 .customer-show-contact-actions {
    display: flex;
    gap: 8px;
    margin-top: 4px;
}
body.v3 .customer-show-contact-actions__wa {
    flex: 1;
    justify-content: center;
}
body.v3 .customer-show-contact-actions__mail {
    padding-inline: 12px;
}
body.v3 .customer-show-contact__hint {
    font-size: 12px;
    color: var(--fg-3);
    margin: 4px 0 0;
}
body.v3 .customer-show-contact-chip .invalid-feedback,
body.v3 .customer-show-contact-notes .invalid-feedback {
    display: block;
}

body.v3 .customer-show-requests {
    padding: 0;
    overflow: visible;
}
body.v3 .customer-show-requests__toolbar {
    padding: 16px 20px;
    border-bottom: 1px solid var(--border);
    display: flex;
    align-items: center;
    gap: 10px;
    flex-wrap: wrap;
}
body.v3 .customer-show-requests__title {
    margin: 0;
    font-size: 14px;
    font-weight: 700;
    color: var(--fg);
}
body.v3 .customer-show-requests__table-wrap {
    width: 100%;
    min-width: 0;
    overflow-x: auto;
    overflow-y: visible;
    -webkit-overflow-scrolling: touch;
}
body.v3 .customer-show-requests__pager {
    padding: 12px 20px;
    border-top: 1px solid var(--border);
}
body.v3 .customer-show-requests-table {
    border: 0;
    border-radius: 0;
}
/* Customer detail request list: table only; colgroup + fixed layout align columns (scroll on viewport). */
body.v3 .customer-show-requests--compact .customer-show-requests-table.tbl {
    table-layout: fixed;
    width: 100%;
    min-width: 52rem;
    overflow: visible;
    border: 0;
    border-radius: 0;
}
body.v3 .customer-show-requests-table__col-card {
    width: 15.5rem;
}
body.v3 .customer-show-requests-table__col-date {
    width: 6.75rem;
}
body.v3 .customer-show-requests-table__col-icon {
    width: 3.5rem;
}
body.v3 .customer-show-requests-table__col-qty {
    width: 3.25rem;
}
body.v3 .customer-show-requests-table__col-actions {
    width: 10.75rem;
}
body.v3
    .customer-show-requests--compact
    .customer-show-requests-table__cell-card {
    overflow: hidden;
}
body.v3
    .customer-show-requests--compact
    .customer-show-requests-table__cell-card
    > .d-flex {
    min-width: 0;
}
body.v3
    .customer-show-requests--compact
    .customer-show-requests-table__cell-card
    .customer-show-requests-table__cardname {
    display: block;
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
    font-size: 0.8125rem;
    font-weight: 600;
    color: var(--fg);
    line-height: 1.25;
}
body.v3 .customer-show-requests-table tbody tr:last-child td {
    border-bottom: 0;
}
body.v3
    .customer-show-requests--compact
    .customer-show-requests-table.tbl
    thead
    th,
body.v3
    .customer-show-requests--compact
    .customer-show-requests-table.tbl
    tbody
    td {
    padding: 7px 10px;
    vertical-align: middle;
}
body.v3
    .customer-show-requests--compact
    .customer-show-requests-table.tbl
    thead
    th:nth-child(n + 3):nth-child(-n + 8),
body.v3
    .customer-show-requests--compact
    .customer-show-requests-table.tbl
    tbody
    td:nth-child(n + 3):nth-child(-n + 8) {
    padding-left: 5px;
    padding-right: 5px;
}
body.v3
    .customer-show-requests--compact
    .customer-show-requests-table.tbl
    thead
    th
    .th-label {
    font-size: 10px;
}
body.v3
    .customer-show-requests--compact
    .customer-show-requests-table.tbl
    thead
    th.customer-show-requests-table__th-icon
    .sort-link {
    justify-content: center;
    width: 100%;
}
body.v3
    .customer-show-requests--compact
    .customer-show-requests-table
    .card-thumb-zoom {
    --d-thumb: 36px;
    --d-thumb-h: 50px;
    --card-zoom-w: 13.5rem;
}
body.v3
    .customer-show-requests--compact
    .customer-show-requests-table__setcode {
    background: var(--bg-3);
    border: 1px solid var(--border);
    border-radius: 4px;
    padding: 0 5px;
    font-size: 0.62rem;
    color: var(--fg-3);
    font-weight: 600;
    letter-spacing: 0.04em;
}
body.v3
    .customer-show-requests--compact
    .customer-show-requests-table__cell-muted {
    font-size: 0.78rem;
    color: var(--fg-3);
}
body.v3
    .customer-show-requests--compact
    .customer-show-requests-table__cell-remaining {
    font-size: 0.8rem;
    font-weight: 700;
    color: var(--accent);
}
body.v3
    .customer-show-requests--compact
    .customer-show-requests-table__row--done {
    opacity: 0.72;
}
body.v3
    .customer-show-requests--compact
    .customer-show-requests-table__row--done
    .customer-show-requests-table__cell-remaining {
    color: var(--success);
}
body.v3
    .customer-show-requests--compact
    .customer-show-requests-table
    .app-request-lines {
    margin-top: 2px;
    gap: 2px;
}
body.v3
    .customer-show-requests--compact
    .customer-show-requests-table
    .app-request-spec {
    font-size: 0.62rem;
    padding: 1px 4px;
}
body.v3 .customer-show-requests--compact .customer-show-requests-table__stale {
    margin-left: 4px;
    background: rgba(251, 191, 36, 0.15);
    color: var(--warn);
    border-radius: 20px;
    padding: 1px 6px;
    font-size: 0.62rem;
    font-weight: 600;
}
body.v3
    .customer-show-requests--compact
    .customer-show-requests-table__actions {
    display: inline-grid;
    grid-template-columns: repeat(4, 2.5rem);
    justify-content: center;
    justify-items: center;
}
body.v3
    .customer-show-requests--compact
    .customer-show-requests-table__actions
    .btn-app-icon {
    width: 2.25rem;
    height: 2.25rem;
    flex-shrink: 0;
}

body.v3 .customer-show-gdpr {
    border-color: var(--warn);
    border-width: 1px;
}
body.v3 .customer-show-gdpr__head {
    display: flex;
    align-items: center;
    gap: 8px;
    padding: 12px 20px;
    border-bottom: 1px solid var(--border);
}
body.v3 .customer-show-gdpr__head-ic {
    color: var(--warn);
    display: inline-flex;
}
body.v3 .customer-show-gdpr__title {
    margin: 0;
    font-size: 14px;
    font-weight: 700;
    color: var(--warn);
}
body.v3 .customer-show-gdpr__body {
    padding: 20px;
}
body.v3 .customer-show-gdpr__lead {
    color: var(--fg-2);
    font-size: 13px;
    margin: 0 0 1rem;
}
body.v3 .customer-show-gdpr--spaced {
    margin-top: 1.5rem;
}
body.v3 .customer-show-gdpr__actions {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    gap: 8px;
}
body.v3 .customer-show-gdpr__export-btn {
    font-size: 0.875rem;
}
body.v3 .customer-show-gdpr__delete-form {
    display: inline;
}

/* Customer index — narrow viewport card */
body.v3 .customer-mobile-card {
    padding: 1rem;
}
body.v3 .customer-mobile-card__row {
    display: flex;
    flex-wrap: nowrap;
    align-items: flex-start;
    gap: 12px;
}
body.v3 .customer-mobile-card__main {
    min-width: 0;
    flex: 1;
}
body.v3 .customer-mobile-card__title {
    margin: 0 0 0.5rem;
    font-size: 1rem;
    font-weight: 600;
}
body.v3 .customer-mobile-card__link {
    color: var(--fg);
    text-decoration: none;
}
body.v3 .customer-mobile-card__fields {
    display: grid;
    grid-template-columns: 1fr 2fr;
    column-gap: 12px;
    row-gap: 4px;
    margin: 0;
    font-size: 0.875rem;
}
body.v3 .customer-mobile-card__label {
    margin: 0;
    font-weight: 400;
    color: var(--fg-3);
}
body.v3 .customer-mobile-card__value {
    margin: 0;
    color: var(--fg-2);
}
body.v3 .customer-mobile-card__value--break {
    word-break: break-word;
}
body.v3 .customer-mobile-card__actions {
    display: flex;
    flex-shrink: 0;
    gap: 4px;
}

/* Customer profile — compact mobile request row */
body.v3 .customer-request-mobile-compact {
    padding: 0.5rem;
}
body.v3 .customer-request-mobile-compact--done {
    opacity: 0.72;
}
body.v3 .customer-request-mobile-compact__row {
    display: flex;
    align-items: flex-start;
    gap: 8px;
}
body.v3 .customer-request-mobile-compact__thumb .card-thumb-zoom,
body.v3 .customer-request-mobile-compact__thumb .card-thumb--no-art {
    --d-thumb: 40px;
    --d-thumb-h: 56px;
}
body.v3 .customer-request-mobile-compact__content {
    min-width: 0;
    flex: 1;
}
body.v3 .customer-request-mobile-compact__head {
    display: flex;
    flex-wrap: nowrap;
    align-items: flex-start;
    gap: 8px;
    margin-bottom: 0.25rem;
}
body.v3 .customer-request-mobile-compact__title-wrap {
    min-width: 0;
    flex: 1;
}
body.v3 .customer-request-mobile-compact__title {
    margin: 0;
    word-break: break-word;
}
body.v3 .customer-request-mobile-compact__actions {
    flex-shrink: 0;
}
body.v3 .customer-request-mobile-compact__meta {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    gap: 8px;
    margin-bottom: 0.25rem;
    font-size: 0.875rem;
}
body.v3 .customer-request-mobile-compact__remaining {
    font-weight: 600;
}
body.v3 .customer-request-mobile-compact__badges {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    gap: 4px;
    margin-bottom: 0.5rem;
}
body.v3 .customer-request-mobile-compact__stats {
    display: flex;
    flex-wrap: wrap;
    gap: 8px;
    margin-bottom: 0.25rem;
    font-size: 0.875rem;
}
body.v3 .customer-request-mobile-compact__setcode {
    align-self: flex-start;
}
body.v3 .customer-request-mobile-compact__stale {
    border: 0;
}

/* Staff settings */
body.v3 .settings-section {
    display: flex;
    flex-direction: column;
    gap: 12px;
}
body.v3 .settings-page__head {
    margin-bottom: 1rem;
}
body.v3 .settings-page__title {
    display: flex;
    align-items: center;
    gap: 8px;
    flex-wrap: wrap;
}
body.v3 .settings-page__title-icon {
    color: var(--accent);
}
body.v3 .settings-page__actions {
    display: flex;
    justify-content: flex-end;
    margin-top: 12px;
}
body.v3 .settings-section-card__header {
    display: flex;
    flex-direction: column;
    align-items: flex-start;
    gap: 4px;
}
body.v3 .settings-section-card__help {
    margin: 0;
    font-size: 13px;
    color: var(--fg-2);
}
body.v3 .settings-section-card__toggle {
    margin-bottom: 1rem;
}
body.v3 .settings-section-card__block {
    margin-bottom: 1rem;
}
body.v3 .settings-section-card__block--tight {
    margin-top: 4px;
}
body.v3 .settings-section-card__note {
    margin: 8px 0 0;
}
body.v3 .settings-row {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 16px;
    padding: 14px 18px;
    background: var(--bg-3);
    border: 1px solid var(--border);
    border-radius: 10px;
}
body.v3 .settings-row__main {
    flex: 1;
    min-width: 0;
}
body.v3 .settings-row__label {
    display: block;
    margin: 0;
    color: var(--fg);
}
body.v3 .settings-row__field {
    flex-shrink: 0;
    min-width: 8rem;
}
body.v3 .settings-page .app-channel-subfields {
    transition: opacity 0.15s ease;
}
body.v3 .settings-page .settings-email-fields-row {
    display: grid;
    grid-template-columns: 1fr 1fr;
    column-gap: 20px;
    row-gap: 0;
    align-items: start;
    max-width: 50%;
    width: 100%;
}
body.v3 .settings-page .settings-email-fields-row__email,
body.v3 .settings-page .settings-email-fields-row__template {
    min-width: 0;
    display: flex;
    flex-direction: column;
}
body.v3 .settings-page .settings-email-fields-row__help {
    grid-column: 1 / -1;
    margin-top: 8px;
}
body.v3 .settings-page .settings-email-fields-row .invalid-feedback {
    margin-top: 4px;
}
@media (max-width: 767.98px) {
    body.v3 .settings-page .settings-email-fields-row {
        max-width: 100%;
        grid-template-columns: 1fr;
        row-gap: 12px;
    }
}
body.v3 .settings-page .settings-email-preview {
    position: relative;
    overflow: hidden;
    height: min(70vh, 520px);
    min-height: 320px;
    background: var(--bg-3);
    border: 1px solid var(--border);
    border-radius: 10px;
}
body.v3 .settings-page .settings-email-preview__iframe {
    height: 100%;
    min-height: 320px;
    position: relative;
    z-index: 0;
    background: var(--bg-2);
}
body.v3 .settings-page .settings-email-preview__loader {
    z-index: 1;
    background: color-mix(in srgb, var(--bg-2) 85%, transparent);
    backdrop-filter: blur(1px);
    position: absolute;
    inset: 0;
    display: flex;
    align-items: center;
    justify-content: center;
}
body.v3 .settings-page .settings-email-preview__loader-body {
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 8px;
    color: var(--fg-2);
}
body.v3 .settings-page .settings-email-preview__spinner {
    width: 24px;
    height: 24px;
    border-radius: 999px;
    border: 2px solid color-mix(in srgb, var(--accent) 24%, transparent);
    border-top-color: var(--accent);
    animation: spin 0.75s linear infinite;
}
body.v3 .settings-page .settings-email-preview__loader-copy {
    font-size: 12px;
}
body.v3 .settings-page .settings-email-preview__label {
    display: block;
    margin-bottom: 8px;
}
body.v3 .settings-page .settings-email-preview__iframe--full {
    width: 100%;
    border: 0;
}
body.v3 .settings-page .settings-logo-thumb {
    max-height: 44px;
    max-width: 200px;
    border: 1px solid var(--border);
    border-radius: 8px;
    padding: 6px 10px;
    background: var(--bg-3);
}
body.v3 .settings-page .settings-logo-row {
    display: flex;
    align-items: center;
    gap: 12px;
    margin-bottom: 8px;
}
body.v3 .settings-page .settings-logo-row__meta {
    display: flex;
    flex-direction: column;
    gap: 4px;
}
body.v3 .settings-page .settings-logo-row__label {
    font-size: 12px;
    color: var(--fg-3);
}
body.v3 .settings-page .settings-logo-row__remove {
    color: var(--danger);
}
body.v3 .settings-page .settings-field-wide {
    width: 100%;
    max-width: none;
    box-sizing: border-box;
}
body.v3 .settings-page .settings-field-wide textarea.form-control,
body.v3 .settings-page .settings-field-wide input.form-control {
    width: 100% !important;
    max-width: none !important;
    box-sizing: border-box;
}
body.v3 .settings-page .settings-field-wide textarea.form-control {
    min-height: 7.5rem;
    resize: vertical;
}
body.v3 .settings-gdpr__lead {
    margin-bottom: 12px;
}
body.v3 .settings-gdpr {
    margin-top: 1rem;
}
body.v3 .settings-gdpr__actions {
    display: flex;
    flex-wrap: wrap;
    gap: 8px;
    align-items: center;
}
body.v3 .settings-gdpr__form {
    display: inline-block;
}
body.v3 .settings-gdpr__button {
    font-size: 0.875rem;
}
body.v3 .settings-gdpr__note {
    margin: 8px 0 0;
    font-size: 12px;
    color: var(--fg-3);
}


body.v3 .report-cards-needed-col--kind {
    width: 7%;
}

body.v3 .report-cards-needed-col--card {
    width: 20%;
}

body.v3 .report-cards-needed-col--expansion {
    width: 23%;
}

body.v3 .report-cards-needed-col--scope,
body.v3 .report-cards-needed-col--remaining {
    width: 5%;
}

body.v3 .report-cards-needed-col--paid,
body.v3 .report-cards-needed-col--lang,
body.v3 .report-cards-needed-col--foil,
body.v3 .report-cards-needed-col--altered,
body.v3 .report-cards-needed-col--signed,
body.v3 .report-cards-needed-col--days {
    width: 4%;
}

body.v3 .report-cards-needed-col--condition,
body.v3 .report-cards-needed-col--requested-at {
    width: 8%;
}

body.v3 .report-cards-needed-col--price {
    width: 6%;
}

body.v3 .report-cards-needed-col-price,
body.v3 .report-cards-needed-th-price {
    text-align: end;
}

/* Cards-needed desktop table: fixed columns so group vs detail rows do not reflow */
body.v3 table.report-cards-needed-table.tbl {
    width: 100%;
    min-width: 1080px;
}
body.v3 .report-cards-needed-table .cards-needed-col-card {
    min-width: 0;
    overflow: hidden;
}
body.v3 .report-cards-needed-table tbody td:has(.card-thumb-zoom) {
    overflow: hidden;
}
/* Center cell text except card name, expansion, and set columns */
body.v3 .report-cards-needed-table thead th {
    text-align: center;
}
body.v3 .report-cards-needed-table thead th.cards-needed-th-card,
body.v3 .report-cards-needed-table thead th.cards-needed-th-expansion,
body.v3 .report-cards-needed-table thead th.cards-needed-th-set {
    text-align: left;
}
body.v3 .report-cards-needed-table tbody td {
    text-align: center;
}
body.v3 .report-cards-needed-table tbody td.cards-needed-col-card,
body.v3 .report-cards-needed-table tbody td.cards-needed-col-expansion,
body.v3 .report-cards-needed-table tbody td.cards-needed-col-set {
    text-align: left;
}
body.v3 .report-cards-needed-detail {
    opacity: 0;
    transition: opacity 0.24s ease;
}
body.v3 .report-cards-needed-detail.is-visible {
    opacity: 1;
}
body.v3 .report-cards-needed-group {
    cursor: pointer;
}
body.v3 .cards-needed-group-caret {
    transition: transform 0.28s cubic-bezier(0.22, 1, 0.36, 1);
    display: inline-block;
}
body.v3 .report-cards-needed-group.is-expanded .cards-needed-group-caret {
    transform: rotate(90deg);
}

/* V3Report — page hero + callout + filters */
body.v3 .report-v3-hero {
    position: relative;
    overflow: hidden;
    border-radius: 16px;
    border: 1px solid var(--accent-line);
    background:
        radial-gradient(circle at 0% 0%, var(--accent-soft), transparent 65%),
        var(--bg-2);
}
body.v3 .report-v3-hero__grid {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 28px 32px;
    padding: 28px 32px;
    align-items: center;
}
body.v3 .report-v3-hero__kpi {
    min-width: 0;
}
body.v3 .report-v3-hero__kpiLabel {
    margin: 0 0 10px;
    font-size: 11px;
    font-weight: 700;
    color: var(--accent);
    text-transform: uppercase;
    letter-spacing: 0.14em;
}
body.v3 .report-v3-hero__mega {
    margin: 0;
    font-size: clamp(3rem, 6vw + 2rem, 6.5rem);
    font-weight: 800;
    line-height: 0.95;
    letter-spacing: -0.04em;
    background: linear-gradient(135deg, var(--accent), var(--accent-2));
    -webkit-background-clip: text;
    background-clip: text;
    color: transparent;
    filter: drop-shadow(0 0 24px var(--accent-soft));
}
body.v3 .report-v3-hero__lead {
    margin: 14px 0 0;
    font-size: 14px;
    line-height: 1.5;
    color: var(--fg-2);
}
body.v3 .report-v3-hero__lead b {
    color: var(--fg);
    font-weight: 600;
}
body.v3 .report-v3-hero__hint {
    margin: 10px 0 0;
    font-size: 12px;
    color: var(--fg-4);
    line-height: 1.45;
}
body.v3 .report-v3-hero__buyLabel {
    margin-top: 14px;
    margin-bottom: 4px;
    font-size: 10px;
    font-weight: 700;
    letter-spacing: 0.06em;
    text-transform: uppercase;
    color: var(--fg-4);
}
body.v3 .report-v3-hero__buyValue {
    font-size: 1.25rem;
    font-weight: 700;
    color: var(--fg);
}
body.v3 .report-v3-hero__side {
    min-width: 0;
    display: flex;
    flex-direction: column;
    gap: 10px;
}
body.v3 .report-v3-hero__sideTitle {
    font-size: 10px;
    font-weight: 700;
    letter-spacing: 0.1em;
    text-transform: uppercase;
    color: var(--fg-4);
}
body.v3 .report-v3-hero__line {
    display: flex;
    align-items: center;
    gap: 12px;
    padding: 10px 12px;
    background: var(--bg-3);
    border-radius: 10px;
    border: 1px solid var(--border-2);
}
body.v3 .report-v3-hero__lineRank {
    font-size: 20px;
    font-weight: 800;
    color: var(--accent);
    width: 28px;
    text-align: center;
    flex-shrink: 0;
}
body.v3 .report-v3-hero__lineMain {
    flex: 1;
    min-width: 0;
}
body.v3 .report-v3-hero__lineName {
    font-size: 13px;
    font-weight: 600;
    color: var(--fg);
    overflow-wrap: anywhere;
}
body.v3 .report-v3-hero__lineQty {
    font-size: 20px;
    font-weight: 800;
    color: var(--accent);
    flex-shrink: 0;
}
body.v3 .report-v3-hero__empty {
    padding: 16px;
    text-align: center;
    font-size: 13px;
    color: var(--fg-3);
    border: 1px dashed var(--border);
    border-radius: 10px;
}
body.v3 .report-v3-callout {
    display: flex;
    gap: 14px;
    padding: 16px 18px;
    border-radius: 12px;
}
body.v3 .report-v3-callout__icon {
    flex-shrink: 0;
    color: var(--info);
    padding-top: 2px;
}
body.v3 .report-v3-callout__title {
    font-size: 13px;
    font-weight: 700;
    color: var(--fg);
    margin-bottom: 4px;
}
body.v3 .report-v3-callout__text {
    font-size: 12.5px;
    line-height: 1.5;
    color: var(--fg-2);
}
body.v3 .report-v3-mobile-sort__hint {
    color: var(--fg-3);
}
body.v3 .report-v3-section {
    margin-bottom: 1rem;
}
body.v3 .report-v3-actions {
    display: inline-flex;
    flex-wrap: wrap;
    gap: 8px;
}
body.v3 .report-v3-mobile-sort__bar {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    gap: 8px;
    margin-bottom: 12px;
}
body.v3 .report-v3-mobile-sort__actions {
    display: inline-flex;
    flex-wrap: wrap;
    gap: 8px;
}
body.v3 .report-v3-mobile-sort .btn-app-ghost.is-active {
    border-color: var(--accent-line);
    background: var(--accent-soft);
    color: var(--accent);
}
body.v3 .report-v3-empty-state {
    color: var(--fg-3);
}
body.v3 .report-v3-empty-state__text {
    font-size: 0.875rem;
    color: var(--fg-2);
    margin: 0;
}
body.v3 .report-v3-empty-card {
    padding: 1rem;
    text-align: center;
}
body.v3 .report-v3-filters-heading {
    display: flex;
    align-items: center;
    gap: 8px;
    font-size: 13px;
    font-weight: 700;
    color: var(--fg);
}
body.v3 .report-v3-filters-clear {
    display: inline-flex;
    align-items: center;
    gap: 5px;
    font-size: 12px;
    color: var(--fg-3);
    text-decoration: none;
    margin-left: auto;
}
body.v3 .report-v3-filters-clear:hover {
    color: var(--fg);
    text-decoration: none;
}
body.v3 .report-v3-mobile-line {
    background: var(--bg-2);
}
body.v3 .report-v3-mobile-line--alt {
    background: var(--bg-3) !important;
}
body.v3 .report-v3-mobile-card__body {
    padding: 1rem;
}
body.v3 .report-v3-mobile-card__head {
    display: flex;
    align-items: flex-start;
    gap: 12px;
}
body.v3 .report-v3-mobile-card__main {
    min-width: 0;
    flex: 1;
}
body.v3 .report-v3-mobile-card__title {
    margin: 0 0 8px;
    color: var(--fg);
    font-size: 1rem;
    font-weight: 700;
}
body.v3 .report-v3-mobile-card__meta {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    gap: 8px;
    color: var(--fg-2);
}
body.v3 .report-v3-mobile-card__meta-item {
    display: inline-flex;
    align-items: center;
    gap: 4px;
}
body.v3 .report-v3-mobile-card__toggle {
    flex-shrink: 0;
    padding-inline: 10px;
}
body.v3 .report-v3-mobile-card__panel {
    list-style: none;
    margin: 0;
    padding: 0;
    border-top: 1px solid var(--border);
}
body.v3 .report-v3-mobile-card__item {
    padding: 12px;
    border-top: 1px solid var(--border);
}
body.v3 .report-v3-mobile-card__item:first-child {
    border-top: 0;
}
body.v3 .report-v3-line-item {
    display: flex;
    flex-direction: column;
    gap: 10px;
}
body.v3 .report-v3-line-item__head {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    gap: 8px;
}
body.v3 .report-v3-line-item__kind {
    font-size: 0.68rem;
}
body.v3 .report-v3-line-item__detail {
    display: inline-flex;
    align-items: center;
    gap: 8px;
    color: var(--fg-2);
    min-width: 0;
}
body.v3 .report-v3-line-item__qty {
    margin-left: auto;
}
body.v3 .report-v3-line-item__meta {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    gap: 6px;
    font-size: 0.875rem;
}
body.v3 .report-v3-line-item__meta--muted {
    color: var(--fg-2);
}
body.v3 .report-v3-line-item__specs,
body.v3 .report-v3-line-item__footer {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    gap: 12px;
    font-size: 0.875rem;
}
body.v3 .report-v3-line-item__footer {
    color: var(--fg-2);
}
body.v3 .report-v3-line-item__label {
    color: var(--fg-3);
    margin-right: 4px;
}
body.v3 .report-v3-line-item__value {
    color: var(--fg-2);
}
body.v3 .report-v3-line-item__inline-icon {
    display: inline-flex;
    align-items: center;
    gap: 4px;
}
@media (max-width: 991.98px) {
    body.v3 .report-v3-hero__grid {
        grid-template-columns: 1fr;
    }
}

body.v3 .report-v3-group-row {
    background: var(--bg-3);
}
body.v3 .report-v3-group-row:hover {
    background: var(--bg-4);
}
body.v3 .report-v3-group-card {
    display: inline-flex;
    align-items: center;
    gap: 8px;
    min-width: 0;
}
body.v3 .report-v3-group-card__label {
    display: inline-flex;
    align-items: center;
    min-width: 0;
}
body.v3 .report-v3-group-card__name {
    overflow-wrap: anywhere;
}
body.v3 .report-v3-group-meta {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: 4px;
    width: 100%;
}
body.v3 .report-cards-needed-group__card-cell {
    font-weight: 600;
    color: var(--fg);
}
body.v3 .report-cards-needed-detail__card-cell {
    color: var(--fg-2);
}
body.v3 .report-cards-needed-detail__card-row {
    display: inline-flex;
    align-items: center;
    gap: 8px;
    flex-wrap: wrap;
    min-width: 0;
}
body.v3 .report-cards-needed-detail__card-link {
    display: inline-flex;
    align-items: center;
    gap: 4px;
}
body.v3 .report-cards-needed-cell-icon {
    display: inline-flex;
    justify-content: center;
    width: 100%;
}
body.v3 .report-cards-needed-cell-icon--success {
    color: var(--success);
}
body.v3 .report-cards-needed-cell-icon--muted {
    color: var(--fg-3);
}
body.v3 .report-cards-needed-expansion-hint {
    display: block;
    font-size: 0.875rem;
    color: var(--fg-3);
    margin-top: 4px;
}
body.v3 .report-cards-needed-sort-link--start {
    justify-content: flex-start;
    width: 100%;
}
body.v3 .report-cards-needed-sort-link--center {
    justify-content: center;
    width: 100%;
}
body.v3 .admin-catalog-cards-group__card-cell {
    font-weight: 600;
}
body.v3 .admin-catalog-cards-group__meta {
    display: inline-flex;
    align-items: center;
    gap: 4px;
}
body.v3 .admin-catalog-cards-sort-link {
    justify-content: center;
    width: 100%;
}
body.v3 .admin-catalog-card-mobile__refresh {
    margin-top: 12px;
}
body.v3 .admin-catalog-card-mobile__refresh-btn {
    width: 100%;
}
body.v3 .report-v3-thead-groups th {
    font-size: 10px;
    font-weight: 700;
    letter-spacing: 0.06em;
    text-transform: uppercase;
    color: var(--fg-3);
}

body.v3 .admin-catalog-cards-table th:nth-child(7),
body.v3 .admin-catalog-cards-table th:nth-child(8),
body.v3 .admin-catalog-cards-table td:nth-child(7),
body.v3 .admin-catalog-cards-table td:nth-child(8) {
    text-align: end;
}

body.v3 .admin-catalog-cards-col--kind {
    width: 6%;
}

body.v3 .admin-catalog-cards-col--card {
    width: 24%;
}

body.v3 .admin-catalog-cards-col--set {
    width: 18%;
}

body.v3 .admin-catalog-cards-col--collector {
    width: 8%;
}

body.v3 .admin-catalog-cards-col--lang {
    width: 6%;
}

body.v3 .admin-catalog-cards-col--price {
    width: 8%;
}

body.v3 .admin-catalog-cards-col--updated {
    width: 12%;
}

body.v3 .admin-catalog-cards-col--actions {
    width: 10%;
}

body.v3 .admin-catalog-cards-table .app-table-col--actions-sm {
    width: 8rem;
}

body.v3 .admin-catalog-card-printing-row__cell {
    position: relative;
    vertical-align: middle;
}

body.v3 .admin-catalog-card-refresh-btn {
    position: relative;
    display: inline-flex;
    max-width: 100%;
}

body.v3 .admin-catalog-card-refresh-btn.is-loading {
    pointer-events: none;
}

body.v3 .admin-catalog-card-refresh-btn__loading {
    position: absolute;
    inset: 0;
    z-index: 1;
    display: flex;
    align-items: center;
    justify-content: center;
    border-radius: 8px;
    background: color-mix(in srgb, var(--bg-2) 88%, transparent);
    backdrop-filter: blur(1px);
}

body.v3 .admin-catalog-card-refresh-btn__loading[hidden] {
    display: none;
}

body.v3 .admin-catalog-card-refresh-btn__spinner {
    width: 14px;
    height: 14px;
    border: 2px solid color-mix(in srgb, var(--fg-4) 35%, transparent);
    border-top-color: var(--accent);
    border-radius: 50%;
    animation: price-lookup-spin 0.75s linear infinite;
}

body.v3 .admin-catalog-card-mobile-line__body {
    position: relative;
}

body.v3 #admin-catalog-cards-list .app-cards-needed-mobile-card .app-action-form {
    display: flex;
    width: 100%;
}

body.v3 .admin-catalog-cards-group-row {
    cursor: pointer;
}

body.v3 .admin-dashboard-layout {
    display: grid;
    gap: var(--d-gap-stack);
}

body.v3 .admin-dashboard-layout__full {
    min-width: 0;
}

body.v3 .admin-dashboard-layout__columns {
    display: grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: var(--d-gap-stack);
}

body.v3 .admin-dashboard-layout__column,
body.v3 .admin-dashboard-layout__stack {
    display: flex;
    flex-direction: column;
    gap: var(--d-gap-stack);
    min-width: 0;
}

@media (max-width: 991.98px) {
    body.v3 .admin-dashboard-layout__columns {
        grid-template-columns: 1fr;
    }
}

/* Admin access request show */
body.v3 .admin-access-request-page__head {
    margin-bottom: 1rem;
}
body.v3 .admin-access-request-page__title {
    display: flex;
    align-items: center;
    gap: 8px;
}
body.v3 .admin-access-request-page__title-icon {
    color: var(--accent);
}
body.v3 .admin-access-request-page__grid {
    display: grid;
    grid-template-columns: minmax(0, 1.6fr) minmax(18rem, 1fr);
    gap: 12px;
}
@media (max-width: 991.98px) {
    body.v3 .admin-access-request-page__grid {
        grid-template-columns: 1fr;
    }
}
body.v3 .admin-access-request-page__card-head {
    display: flex;
    align-items: flex-start;
    justify-content: space-between;
    gap: 12px;
}
body.v3 .admin-access-request-page__identity-sub {
    margin: 4px 0 0;
    font-size: 12px;
    color: var(--fg-4);
}
body.v3 .admin-access-request-page__facts {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 12px 16px;
    margin: 0;
}
body.v3 .admin-access-request-page__fact {
    margin: 0;
    display: flex;
    flex-direction: column;
    gap: 4px;
}
body.v3 .admin-access-request-page__fact--full {
    grid-column: 1 / -1;
}
body.v3 .admin-access-request-page__fact dt {
    font-size: 11px;
    font-weight: 700;
    letter-spacing: 0.08em;
    text-transform: uppercase;
    color: var(--fg-4);
}
body.v3 .admin-access-request-page__fact dd {
    margin: 0;
    color: var(--fg-2);
}
body.v3 .admin-access-request-page__notes {
    padding: 10px 12px;
    border-radius: 10px;
    border: 1px solid var(--border);
    background: var(--bg-3);
    color: var(--fg-2);
}
body.v3 .admin-access-request-page__locked {
    display: flex;
    align-items: center;
    gap: 8px;
    padding: 12px 14px;
    border-radius: 10px;
    background: var(--bg-3);
    border: 1px solid var(--border);
    color: var(--fg-3);
}
body.v3 .admin-access-request-page__status-form {
    display: flex;
    flex-direction: column;
    gap: 12px;
}
body.v3 .admin-access-request-page__submit {
    align-self: flex-start;
}

/* Admin staff list */
body.v3 .admin-staff-list__narrow {
    display: grid;
    gap: 12px;
    margin-bottom: 1rem;
}
body.v3 .admin-staff-list__table-viewport {
    display: none;
}
body.v3 .admin-staff-list__table thead th,
body.v3 .admin-staff-list__table tbody td {
    text-align: center;
}
body.v3 .admin-staff-list__table thead th .sort-link {
    justify-content: center;
    width: 100%;
}
body.v3 .admin-staff-list__email {
    text-align: left;
}
body.v3 .admin-staff-list__metric {
    font-variant-numeric: tabular-nums;
}
@media (min-width: 992px) {
    body.v3 .admin-staff-list__narrow {
        display: none;
    }
    body.v3 .admin-staff-list__table-viewport {
        display: block;
    }
}

/* Admin access request list */
body.v3 .admin-access-request-list__narrow {
    display: grid;
    gap: 12px;
    margin-bottom: 1rem;
}
body.v3 .admin-access-request-list__table-viewport {
    display: none;
}
@media (min-width: 992px) {
    body.v3 .admin-access-request-list__narrow {
        display: none;
    }
    body.v3 .admin-access-request-list__table-viewport {
        display: block;
    }
}

/* GDPR data erasure list (staff) */
body.v3 .gdpr-data-erasure-list__narrow {
    display: grid;
    gap: 12px;
    margin-bottom: 1rem;
}
body.v3 .gdpr-data-erasure-list__table-viewport {
    display: none;
}
@media (min-width: 992px) {
    body.v3 .gdpr-data-erasure-list__narrow {
        display: none;
    }
    body.v3 .gdpr-data-erasure-list__table-viewport {
        display: block;
    }
}

/* Staff home dashboard */
body.v3 [data-dashboard-drag-handle] {
    cursor: grab;
}
body.v3.is-dragging-widget,
body.v3.is-dragging-widget * {
    cursor: grabbing !important;
}
body.v3 [data-dashboard-layout-target="column"] {
    min-height: 14rem;
    padding: 0.25rem;
    border-radius: 0.5rem;
}
body.v3 .dashboard-drop-target {
    outline: 2px dashed var(--accent-line);
    outline-offset: 4px;
    background: var(--accent-soft);
}
body.v3 .dashboard-sortable-ghost {
    opacity: 0.6;
}
body.v3 .dashboard-sortable-chosen {
    cursor: grabbing;
}
body.v3 .dashboard-sortable-drag {
    opacity: 0.9;
}
body.v3 .dashboard-home-actions {
    display: flex;
    gap: 8px;
    flex-shrink: 0;
}
body.v3 .dashboard-quick-fulfill-error {
    margin-bottom: 12px;
}
body.v3 .dashboard-home-urgent {
    padding: 0;
    overflow: hidden;
}
body.v3 .dashboard-home-urgent__head {
    padding: 18px 22px;
    border-bottom: 1px solid var(--border);
    display: flex;
    align-items: center;
    gap: 12px;
}
body.v3 .dashboard-home-urgent__icon {
    width: 32px;
    height: 32px;
    border-radius: 8px;
    background: var(--danger-soft);
    color: var(--danger);
    display: flex;
    align-items: center;
    justify-content: center;
    flex-shrink: 0;
}
body.v3 .dashboard-home-urgent__main {
    flex: 1;
    min-width: 0;
}
body.v3 .dashboard-home-open-btn {
    padding: 5px 10px;
    font-size: 12px;
    flex-shrink: 0;
}
body.v3 .dashboard-home-panel {
    padding: var(--d-pad-card);
}
body.v3 .dashboard-home-panel__head {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 16px;
    margin-bottom: 14px;
}
body.v3 .dashboard-home-panel__head--spacious {
    margin-bottom: 16px;
}
body.v3 .dashboard-home-section-title {
    margin: 0;
    font-size: 15px;
    font-weight: 700;
}
body.v3 .dashboard-home-trends__range {
    font-size: 0.8rem;
    color: var(--fg-3);
    margin-bottom: 8px;
}
body.v3 .dashboard-home-trends__chart {
    width: 100%;
    height: clamp(280px, 30vh, 420px);
}
body.v3 .dashboard-home-trends__chart-canvas {
    width: 100%;
    height: 100%;
}
body.v3 .dashboard-home-trends__legend {
    display: flex;
    gap: 14px;
    font-size: 11px;
    color: var(--fg-3);
    text-transform: uppercase;
    letter-spacing: 0.06em;
    font-weight: 600;
    flex-wrap: wrap;
    margin-top: 8px;
}
body.v3 .dashboard-home-stat-row {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 12px;
}
body.v3 .dashboard-home-stat-row__icon--accent {
    background: var(--accent-soft);
    color: var(--accent);
}
body.v3 .dashboard-home-stat-row__value {
    margin-top: 6px;
}
body.v3 .dashboard-home-list-row__main {
    min-width: 0;
    flex: 1 1 auto;
}
body.v3 .dashboard-home-list-row__title {
    font-weight: 500;
    font-size: 0.875rem;
    color: var(--fg);
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
}
body.v3 .dashboard-home-list-row__subtitle {
    font-size: 0.75rem;
    color: var(--fg-3);
    margin-top: 2px;
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
}
body.v3 .dashboard-home-list-row__meta {
    display: flex;
    align-items: center;
    gap: 8px;
    margin-top: 4px;
}
body.v3 .dashboard-home-list-row__meta-id {
    font-size: 0.72rem;
    color: var(--fg-3);
}
body.v3 .dashboard-home-list-row__aside {
    display: flex;
    flex-direction: column;
    align-items: flex-end;
    gap: 4px;
    flex-shrink: 0;
}
body.v3 .dashboard-home-list-row__date {
    font-size: 0.72rem;
    color: var(--fg-3);
    white-space: nowrap;
}
body.v3 .dashboard-home-urgent-item {
    display: flex;
    align-items: center;
    gap: 14px;
    padding: 14px 22px;
    border-bottom: 1px solid var(--border);
}
body.v3 .dashboard-home-urgent-item:last-child {
    border-bottom: none;
}
body.v3 .dashboard-home-urgent-item__main {
    flex: 1;
    min-width: 0;
}
body.v3 a.dashboard-home-urgent-item__main {
    color: inherit;
    text-decoration: none;
}
body.v3 a.dashboard-home-urgent-item__main:hover .dashboard-home-urgent-item__title {
    text-decoration: underline;
}
body.v3 .dashboard-home-urgent-item__title {
    font-weight: 600;
    font-size: 14px;
    margin-bottom: 3px;
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
}
body.v3 .dashboard-home-urgent-item__meta {
    font-size: 12px;
    color: var(--fg-3);
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
}
body.v3 .dashboard-home-urgent-item__form {
    flex-shrink: 0;
    margin: 0;
}
body.v3 .dashboard-home-urgent-item__action {
    flex-shrink: 0;
}
body.v3 .dashboard-home-trends__legend-item {
    display: inline-flex;
    align-items: center;
    gap: 6px;
}
body.v3 .dashboard-home-trends__legend-dot {
    width: 8px;
    height: 8px;
    border-radius: 2px;
    flex-shrink: 0;
}
body.v3 .dashboard-home-trends__legend-dot--accent {
    background: var(--accent);
    box-shadow: 0 0 6px var(--accent);
}
body.v3 .dashboard-home-trends__legend-dot--success {
    background: var(--success);
    box-shadow: 0 0 6px var(--success);
}
body.v3 .dashboard-home-trends__legend-dot--requests_fulfilled {
    background: rgb(255, 122, 69);
}
body.v3 .dashboard-home-trends__legend-dot--requests_created {
    background: rgb(96, 165, 250);
}
body.v3 .dashboard-home-trends__legend-dot--cards_fulfilled {
    background: rgb(45, 212, 191);
}
body.v3 .dashboard-home-trends__legend-dot--cards_requested {
    background: rgb(74, 222, 128);
}
body.v3 .dashboard-home-trends__legend-dot--copies_needed_backlog {
    background: rgb(148, 163, 184);
}
body.v3 .dashboard-analytics {
    margin-top: 16px;
}
body.v3 .dashboard-analytics__head {
    margin-bottom: 16px;
}
body.v3 .dashboard-analytics__period {
    display: flex;
    flex-direction: column;
    gap: 8px;
}
body.v3 .dashboard-analytics__title {
    margin: 0;
    font-size: 18px;
    font-weight: 700;
}
body.v3 .dashboard-analytics__body {
    display: flex;
    flex-direction: column;
    gap: 16px;
}
body.v3 .dashboard-analytics-charts {
    display: grid;
    grid-template-columns: minmax(0, 2fr) minmax(0, 1fr);
    gap: 16px;
    align-items: start;
}
body.v3 .dashboard-analytics-chart {
    padding: var(--d-pad-card);
    display: flex;
    flex-direction: column;
}
body.v3 .dashboard-analytics-chart__head {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 12px;
    margin-bottom: 12px;
}
body.v3 .dashboard-analytics-insights {
    display: grid;
    grid-template-columns: minmax(0, 1fr) minmax(0, 1fr);
    gap: 16px;
    align-items: start;
}
body.v3 .dashboard-analytics-urgent-panel {
    padding: var(--d-pad-card);
    align-self: start;
}
body.v3 .dashboard-analytics-urgent-panel #dashboard-home-urgent-list {
    margin-inline: calc(-1 * var(--d-pad-card));
}
body.v3 .dashboard-analytics-urgent-panel .dashboard-home-urgent-item {
    padding: 10px var(--d-pad-card);
    gap: 12px;
}
body.v3 .dashboard-analytics-table-panel,
body.v3 .dashboard-analytics-gallery-panel {
    padding: var(--d-pad-card);
}
body.v3 .dashboard-analytics-demand-table-wrap {
    overflow-x: auto;
}
body.v3 .dashboard-analytics-demand-table {
    width: 100%;
    border-collapse: collapse;
}
body.v3 .dashboard-analytics-demand-table th {
    font-size: 11px;
    text-transform: uppercase;
    letter-spacing: 0.08em;
    color: var(--fg-3);
    font-weight: 700;
    text-align: left;
    padding: 0 12px 10px 0;
    border-bottom: 1px solid var(--border);
}
body.v3 .dashboard-analytics-demand-table td {
    padding: 12px 12px 12px 0;
    border-bottom: 1px solid var(--border);
    vertical-align: middle;
}
body.v3 .dashboard-analytics-demand-table tbody tr:last-child td {
    border-bottom: none;
}
body.v3 .dashboard-analytics-demand-table__col-rank {
    width: 2.5rem;
}
body.v3 .dashboard-analytics-demand-table__col-qty {
    text-align: right;
    font-weight: 700;
    color: var(--accent);
    padding-right: 0;
}
body.v3 .dashboard-analytics-demand-table th.dashboard-analytics-demand-table__col-qty {
    text-align: right;
    padding-right: 0;
}
body.v3 .dashboard-analytics-demand-table__col-change {
    width: 5.5rem;
    text-align: right;
    padding-right: 0;
    white-space: nowrap;
}
body.v3 .dashboard-analytics-demand-table th.dashboard-analytics-demand-table__col-change {
    text-align: right;
    padding-right: 0;
}
body.v3 .dashboard-analytics-demand-table__change {
    font-size: 12px;
    font-weight: 700;
    font-variant-numeric: tabular-nums;
}
body.v3 .dashboard-analytics-demand-table__change--rise {
    color: var(--danger);
}
body.v3 .dashboard-analytics-demand-table__change--fall {
    color: var(--success);
}
body.v3 .dashboard-analytics-demand-table__change--neutral,
body.v3 .dashboard-analytics-demand-table__change--new {
    color: var(--fg-3);
    font-weight: 600;
}
body.v3 .dashboard-analytics-demand-table__set-code {
    font-weight: 700;
    margin-right: 8px;
}
body.v3 .dashboard-analytics-demand-table__set-name {
    color: var(--fg-3);
    font-size: 12px;
}
body.v3 .dashboard-analytics-demand-table__empty {
    text-align: center;
    padding: 28px 0;
    color: var(--fg-3);
    font-size: 13px;
}
body.v3 .dashboard-home-lookback {
    display: flex;
    flex-direction: column;
    align-items: flex-start;
    gap: 4px;
}
body.v3 .dashboard-home-lookback__field {
    display: flex;
    align-items: center;
    gap: 8px;
}
body.v3 .dashboard-home-lookback__range {
    margin: 0;
    font-size: 12px;
    color: var(--fg-3);
}
body.v3 .dashboard-home-lookback__label {
    font-size: 11px;
    color: var(--fg-3);
    text-transform: uppercase;
    letter-spacing: 0.06em;
    font-weight: 600;
    white-space: nowrap;
}
body.v3 .dashboard-home-lookback__select {
    min-width: 7.5rem;
}
body.v3 .dashboard-home-main {
    margin-top: 16px;
    align-items: stretch;
}
body.v3 .dashboard-home-main > .surface {
    min-height: 0;
}
body.v3 .dashboard-home-panel--trends {
    display: flex;
    flex-direction: column;
}
body.v3 .dashboard-home-panel--trends .dashboard-home-trends__chart {
    flex: 1;
    min-height: 0;
}
body.v3 .dashboard-home-trends__chart--compact {
    height: clamp(240px, 32vh, 380px);
}
body.v3 .dashboard-home-gallery-panel {
    margin-top: 16px;
}
body.v3 .dashboard-home-analytics-bar {
    width: 100%;
    height: clamp(200px, 22vh, 320px);
}
body.v3 .dashboard-home-analytics-bar__canvas {
    width: 100%;
    height: 100%;
}
/* Staff analytics dashboard: compact chart heights (override generic trend/bar rules above). */
body.v3 .dashboard-analytics-chart .dashboard-home-trends__chart,
body.v3 .dashboard-analytics-chart .dashboard-home-trends__chart--compact {
    flex: none;
    width: 100%;
    height: clamp(165px, 20vh, 255px);
    min-height: 0;
}
body.v3 .dashboard-analytics-chart .dashboard-home-analytics-bar {
    flex: none;
    height: clamp(165px, 20vh, 255px);
    min-height: 0;
}
body.v3 .dashboard-analytics-chart .dashboard-home-trends__legend {
    margin-top: 6px;
    gap: 10px;
    font-size: 10px;
}
body.v3 .dashboard-home-demand-list {
    list-style: none;
    margin: 0;
    padding: 0;
    display: flex;
    flex-direction: column;
    gap: 10px;
}
body.v3 .dashboard-home-demand-list__row {
    display: flex;
    align-items: center;
    gap: 10px;
}
body.v3 .dashboard-home-demand-list__rank {
    width: 1.5rem;
    font-size: 12px;
    font-weight: 700;
    color: var(--fg-3);
    flex-shrink: 0;
}
body.v3 .dashboard-home-demand-list__code {
    font-weight: 700;
    margin-right: 6px;
}
body.v3 .dashboard-home-demand-list__name {
    color: var(--fg-3);
    font-size: 12px;
}
body.v3 .dashboard-home-demand-list__qty {
    font-size: 12px;
    font-weight: 700;
    color: var(--accent);
    flex-shrink: 0;
}
body.v3 .dashboard-home-demand-list__empty {
    text-align: center;
    padding: 24px 0;
    color: var(--fg-3);
    font-size: 13px;
}
body.v3 .dashboard-home-gallery__meta {
    font-size: 11px;
    color: var(--fg-3);
    text-transform: uppercase;
    letter-spacing: 0.1em;
    font-weight: 600;
}
body.v3 .dashboard-most-requested__grid {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(100px, 1fr));
    gap: 14px;
}
body.v3 .dashboard-most-requested__strip {
    display: flex;
    gap: 14px;
    overflow-x: auto;
    padding-bottom: 6px;
    scroll-snap-type: x proximity;
    -webkit-overflow-scrolling: touch;
}
body.v3 .dashboard-most-requested__strip .dashboard-most-requested__cell {
    flex: 0 0 auto;
    width: 108px;
    scroll-snap-align: start;
}
body.v3 .dashboard-most-requested__cell {
    position: relative;
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 8px;
    padding: 12px;
    border-radius: 12px;
    background: var(--bg-3);
    border: 1px solid var(--border);
    transition: background 0.15s;
    text-decoration: none;
    color: inherit;
}
body.v3 a.dashboard-most-requested__cell:hover {
    background: var(--bg-4);
}
body.v3 .card-thumb-zoom .dashboard-most-requested__qty {
    padding: 3px 9px;
    background: var(--accent);
    color: var(--bg);
    border-radius: 999px;
    font-size: 11px;
    font-weight: 700;
    box-shadow: 0 0 12px var(--accent-soft);
    line-height: 1.4;
}
body.v3 .dashboard-most-requested__name {
    font-size: 11.5px;
    font-weight: 600;
    text-align: center;
    line-height: 1.2;
    color: var(--fg);
    word-break: break-word;
}
body.v3 .dashboard-most-requested__set {
    font-size: 10px;
    color: var(--fg-3);
    text-transform: uppercase;
    letter-spacing: 0.08em;
    font-weight: 700;
}
body.v3 .dashboard-most-requested__empty {
    text-align: center;
    padding: 32px 0;
    color: var(--fg-3);
}

body.v3 .dash-2col {
    display: grid;
    grid-template-columns: 1.1fr 1fr;
    gap: 16px;
}

@media (max-width: 991.98px) {
    body.v3 .dashboard-analytics-charts {
        grid-template-columns: 1fr;
    }
    body.v3 .dashboard-analytics-insights {
        grid-template-columns: 1fr;
    }
    body.v3 .dash-2col {
        grid-template-columns: 1fr;
    }
}

body.v3 .notification-inbox-sections {
    display: flex;
    flex-direction: column;
    gap: var(--d-gap-stack);
}

body.v3 .notification-inbox-columns {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: var(--d-gap-stack);
    align-items: start;
}

body.v3 .notification-inbox-columns--single {
    grid-template-columns: minmax(0, 1fr);
}

body.v3 .notification-inbox-columns__col {
    min-width: 0;
}

body.v3 .notification-inbox-columns .notification-inbox-section {
    min-width: 0;
}

body.v3 .notification-inbox-columns .app-card {
    height: 100%;
}

body.v3 .notification-inbox-section__title {
    margin-bottom: 0;
}

@media (max-width: 991.98px) {
    body.v3 .notification-inbox-columns {
        grid-template-columns: minmax(0, 1fr);
    }
}

body.v3 .app-import-decklist__fields {
    display: flex;
    flex-direction: column;
    gap: var(--d-gap-stack);
    margin-top: var(--d-gap-stack);
}

body.v3 .app-import-decklist__intro {
    display: flex;
    flex-direction: column;
    gap: 0.35rem;
}

body.v3 .app-import-decklist__title {
    display: inline-flex;
    align-items: center;
    gap: 0.5rem;
    font-weight: 600;
    font-size: 0.95rem;
}

body.v3 .app-import-decklist__hint {
    margin: 0;
    font-size: 0.85rem;
    color: var(--muted, var(--fg-3));
}

body.v3 .app-import-field .app-form-control--textarea,
body.v3 .app-import-field textarea.app-form-control {
    width: 100%;
    max-width: none;
    box-sizing: border-box;
    min-height: 12rem;
    font-family: ui-monospace, SFMono-Regular, Menlo, Monaco, Consolas, monospace;
    font-size: 0.82rem;
    line-height: 1.45;
}

body.v3 .app-import-field--textarea {
    width: 100%;
}

body.v3 .app-file-upload {
    display: flex;
    flex-direction: column;
    gap: 0.35rem;
}

body.v3 .app-form-control--file {
    padding: 0.55rem 0.75rem;
    background: var(--bg, var(--bg-2));
    border: 1px solid var(--border, var(--border-2));
    border-radius: var(--radius-sm, 8px);
    color: var(--fg, var(--fg-1));
    font-size: 0.88rem;
    width: 100%;
    max-width: 28rem;
}

body.v3 .app-form-control--file::file-selector-button {
    margin-right: 0.75rem;
    padding: 0.35rem 0.75rem;
    border: 1px solid var(--border-2);
    border-radius: var(--radius-sm, 6px);
    background: var(--bg-3);
    color: var(--fg-2);
    font-size: 0.8rem;
    font-weight: 600;
    cursor: pointer;
}

body.v3 .app-request-options__grid--import {
    grid-template-columns: minmax(0, 1fr) minmax(0, 1fr);
}

@media (max-width: 767.98px) {
    body.v3 .app-request-options__grid--import {
        grid-template-columns: minmax(0, 1fr);
    }
}

body.v3 .app-import-form__actions {
    display: flex;
    justify-content: flex-start;
}

body.v3 .app-import-contract {
    margin-bottom: 0;
    padding: 0.65rem 0.75rem;
    border: 1px solid var(--border);
    border-radius: var(--radius-md);
    background: var(--surface-elevated, var(--surface));
    font-size: 0.84rem;
    line-height: 1.35;
}

body.v3 .app-import-contract__title {
    font-weight: 600;
    font-size: 0.88rem;
    margin-bottom: 0.4rem;
}

body.v3 .app-import-contract__columns {
    display: flex;
    flex-direction: column;
    gap: 0.2rem;
    margin-bottom: 0.35rem;
}

body.v3 .app-import-contract__row {
    display: grid;
    grid-template-columns: 1.1rem minmax(0, 1fr);
    gap: 0.35rem 0.5rem;
    align-items: baseline;
}

body.v3 .app-import-contract__pos {
    font-size: 0.78rem;
    font-weight: 700;
    color: var(--text-muted);
    font-variant-numeric: tabular-nums;
}

body.v3 .app-import-contract__main {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    gap: 0.25rem 0.4rem;
    min-width: 0;
}

body.v3 .app-import-contract__name {
    font-weight: 600;
}

body.v3 .app-import-contract__tag {
    font-size: 0.72rem;
    font-weight: 600;
    color: var(--text-muted);
}

body.v3 .app-import-contract__tag--required {
    color: var(--accent);
}

body.v3 .app-import-contract__chips {
    display: inline-flex;
    flex-wrap: wrap;
    gap: 0.2rem;
    align-items: center;
}

body.v3 .app-import-contract__chip {
    font-family: ui-monospace, SFMono-Regular, Menlo, Monaco, Consolas, monospace;
    font-size: 10px;
    font-weight: 600;
    padding: 1px 6px;
    line-height: 1.35;
}

body.v3 .app-import-contract__note {
    font-size: 0.78rem;
    color: var(--text-muted);
}

body.v3 .app-import-contract__note::before {
    content: '·';
    margin-right: 0.35rem;
    opacity: 0.65;
}

body.v3 .app-import-contract__examples {
    margin-top: 0.15rem;
}

body.v3 .app-import-contract__examples-summary {
    font-size: 0.78rem;
    font-weight: 600;
    color: var(--text-muted);
    cursor: pointer;
    user-select: none;
}

body.v3 .app-import-contract__examples-summary:hover {
    color: var(--fg-2, var(--text));
}

body.v3 .app-import-contract__example {
    margin: 0.35rem 0 0;
    padding: 0.5rem 0.6rem;
    font-size: 0.78rem;
    border-radius: var(--radius-sm);
    background: var(--bg);
    border: 1px solid var(--border);
    overflow-x: auto;
}

body.v3 .app-import-row-list {
    list-style: none;
    margin: 0;
    padding: 0;
}

/* Decklist import preview */
body.v3 .import-preview-section {
    margin-bottom: 12px;
}

body.v3 .import-preview-card-list,
body.v3 .import-preview-row-list {
    list-style: none;
    margin: 0;
    padding: 0;
}

body.v3 .import-preview-card {
    display: grid;
    grid-template-columns: auto auto auto 1fr auto;
    grid-template-areas:
        'check num thumb main actions';
    align-items: start;
    gap: 0.75rem 0.85rem;
    padding: 0.85rem 1.25rem;
    border-bottom: 1px solid var(--border);
}

body.v3 .import-preview-card:not(:has(.import-preview-card__check)) {
    grid-template-columns: auto auto 1fr auto;
    grid-template-areas:
        'num thumb main actions';
}

body.v3 .import-preview-card:last-child {
    border-bottom: none;
}

body.v3 .import-preview-card--linked {
    cursor: pointer;
}

body.v3 .import-preview-card--linked:hover {
    background: var(--bg-3);
}

body.v3 .app-import-section--excluded .app-card-header {
    color: var(--fg-3);
}

body.v3 .import-preview-card--excluded {
    opacity: 0.82;
}

body.v3 .import-preview-card--excluded .import-preview-card__title {
    color: var(--fg-2);
}

body.v3 .import-preview-card__check {
    grid-area: check;
    display: flex;
    align-items: flex-start;
    padding-top: 0.35rem;
    cursor: pointer;
}

body.v3 .import-preview-card__num {
    grid-area: num;
    flex-shrink: 0;
    font-variant-numeric: tabular-nums;
    font-size: 0.78rem;
    color: var(--fg-3);
    min-width: 1.75rem;
    padding-top: 0.35rem;
}

body.v3 .import-preview-card__thumb {
    grid-area: thumb;
    flex-shrink: 0;
}

body.v3 .import-preview-card__main {
    grid-area: main;
    min-width: 0;
    display: flex;
    flex-direction: column;
    gap: 0.4rem;
}

body.v3 .import-preview-card__head {
    display: flex;
    align-items: flex-start;
    gap: 0.65rem;
}

body.v3 .import-preview-card__title {
    margin: 0;
    font-size: 0.92rem;
    font-weight: 600;
    line-height: 1.35;
    color: var(--fg);
    min-width: 0;
}

body.v3 .import-preview-card__qty {
    flex-shrink: 0;
    margin-left: auto;
}

body.v3 .import-preview-card__meta {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    gap: 0.45rem;
    font-size: 0.82rem;
    color: var(--fg-2);
}

body.v3 .import-preview-card__set-name {
    min-width: 0;
}

body.v3 .import-preview-card__collector {
    color: var(--fg-3);
    font-variant-numeric: tabular-nums;
}

body.v3 .import-preview-card__specs {
    display: flex;
    flex-wrap: wrap;
    gap: 0.35rem;
}

body.v3 .import-preview-card__spec {
    font-size: 0.68rem;
}

body.v3 .import-preview-card__source {
    margin-top: 0.15rem;
}

body.v3 .import-preview-card__source-summary {
    font-size: 0.75rem;
    color: var(--fg-3);
    cursor: pointer;
    user-select: none;
}

body.v3 .import-preview-card__source-summary:hover {
    color: var(--fg-2);
}

body.v3 .import-preview-card__raw {
    display: block;
    margin-top: 0.35rem;
    padding: 0.45rem 0.55rem;
    font-size: 0.75rem;
    color: var(--fg-2);
    word-break: break-word;
    border-radius: var(--radius-sm);
    background: var(--bg);
}

body.v3 .import-preview-card__actions {
    grid-area: actions;
    align-self: center;
}

body.v3 .import-preview-card__action-label {
    font-size: 0.78rem;
}

@media (max-width: 575.98px) {
    body.v3 .import-preview-card {
        display: flex;
        flex-wrap: wrap;
        align-items: flex-start;
    }

    body.v3 .import-preview-card__check,
    body.v3 .import-preview-card__num,
    body.v3 .import-preview-card__thumb {
        flex-shrink: 0;
    }

    body.v3 .import-preview-card__main {
        flex: 1 1 12rem;
        min-width: 0;
    }

    body.v3 .import-preview-card__actions {
        flex: 1 1 100%;
        margin-top: 0.25rem;
    }

    body.v3 .import-preview-card__actions .btn-app-ghost {
        width: 100%;
        justify-content: center;
    }
}

body.v3 .import-preview-row {
    display: grid;
    grid-template-columns: auto minmax(0, 1fr);
    gap: 0.85rem 1rem;
    align-items: start;
    padding: 1rem 1.25rem;
    border-bottom: 1px solid var(--border);
}

body.v3 .import-preview-row:last-child {
    border-bottom: none;
}

body.v3 .import-preview-row__num {
    flex-shrink: 0;
    font-variant-numeric: tabular-nums;
    font-size: 0.78rem;
    font-weight: 600;
    color: var(--fg-3);
    min-width: 1.75rem;
    padding-top: 0.55rem;
}

body.v3 .import-preview-row__panel {
    min-width: 0;
    padding: 0.85rem 1rem;
    border: 1px solid var(--border-2);
    border-radius: 10px;
    background: var(--bg-3);
}

body.v3 .import-preview-row--ambiguous .import-preview-row__panel {
    border-left: 3px solid var(--warn);
}

body.v3 .import-preview-row--unresolved .import-preview-row__panel {
    border-left: 3px solid var(--danger);
}

body.v3 .import-preview-row__head {
    display: flex;
    align-items: flex-start;
    gap: 0.65rem;
}

body.v3 .import-preview-row__title {
    margin: 0;
    flex: 1 1 auto;
    min-width: 0;
    font-size: 0.92rem;
    font-weight: 600;
    line-height: 1.35;
    color: var(--fg);
}

body.v3 .import-preview-row__qty {
    flex-shrink: 0;
    margin-left: auto;
}

body.v3 .import-preview-row__deck-hint {
    display: flex;
    align-items: center;
    gap: 0.4rem;
    margin: 0.45rem 0 0;
    font-size: 0.8rem;
    color: var(--fg-2);
}

body.v3 .import-preview-row__deck-hint span {
    min-width: 0;
}

body.v3 .import-preview-row__field {
    margin-top: 0.75rem;
    padding-top: 0.75rem;
    border-top: 1px solid var(--border);
}

body.v3 .import-preview-row__label {
    display: inline-flex;
    align-items: center;
    gap: 0.4rem;
    margin: 0 0 0.45rem;
    font-size: 0.68rem;
    font-weight: 700;
    letter-spacing: 0.08em;
    text-transform: uppercase;
    color: var(--fg-3);
}

body.v3 .import-preview-row__select {
    width: 100%;
    max-width: none;
}

body.v3 .import-preview-row--unresolved .import-preview-row__panel .import-preview-card__specs {
    margin-top: 0.45rem;
}

body.v3 .import-preview-row__reason {
    display: flex;
    align-items: flex-start;
    gap: 0.45rem;
    margin: 0.75rem 0 0;
    padding: 0.55rem 0.65rem;
    font-size: 0.82rem;
    line-height: 1.45;
    color: var(--danger);
    border-radius: var(--radius-sm);
    background: color-mix(in srgb, var(--danger) 10%, transparent);
}

body.v3 .import-preview-row__reason svg {
    flex-shrink: 0;
    margin-top: 0.12rem;
    opacity: 0.9;
}

body.v3 .import-preview-row__reason span {
    min-width: 0;
}

body.v3 .import-preview-row__source {
    margin-top: 0.55rem;
}

body.v3 .import-preview-row__source-summary {
    font-size: 0.75rem;
    color: var(--fg-3);
    cursor: pointer;
    user-select: none;
}

body.v3 .import-preview-row__source-summary:hover {
    color: var(--fg-2);
}

body.v3 .import-preview-row__raw {
    display: block;
    margin-top: 0.35rem;
    padding: 0.45rem 0.55rem;
    font-size: 0.75rem;
    color: var(--fg-2);
    word-break: break-word;
    border-radius: var(--radius-sm);
    background: var(--bg);
}

@media (max-width: 575.98px) {
    body.v3 .import-preview-row {
        grid-template-columns: 1fr;
        gap: 0.5rem;
    }

    body.v3 .import-preview-row__num {
        padding-top: 0;
    }
}

body.v3 .app-import-row {
    display: flex;
    gap: var(--d-gap-inline);
    padding: 0.75rem var(--d-gap-inline);
    border-bottom: 1px solid var(--border);
}

body.v3 .app-import-row:last-child {
    border-bottom: none;
}

body.v3 .app-import-row__num {
    flex-shrink: 0;
    font-variant-numeric: tabular-nums;
    color: var(--muted);
    min-width: 2rem;
}

body.v3 .app-import-row__body {
    flex: 1;
    min-width: 0;
    display: flex;
    flex-direction: column;
    gap: 0.35rem;
}

body.v3 .app-import-row__meta {
    color: var(--muted);
    font-size: 0.85rem;
}

body.v3 .app-import-row__raw {
    font-size: 0.78rem;
    color: var(--muted);
    word-break: break-word;
}

body.v3 .app-import-row--error .app-import-row__msg {
    color: var(--danger, #c0392b);
}

body.v3 .app-import-row__check {
    display: flex;
    align-items: flex-start;
    gap: 0.5rem;
    cursor: pointer;
}

body.v3 .app-import-preview-form__footer {
    display: flex;
    align-items: center;
    gap: var(--d-gap-inline);
    margin-top: var(--d-gap-stack);
}

body.v3 .app-import-section__actions {
    padding-top: 0;
    border-top: 1px solid var(--border);
}

body.v3 .app-import-section--choices .app-card-header {
    border-bottom-color: rgba(251, 191, 36, 0.22);
}

body.v3 .app-import-section--unresolved .app-card-header {
    border-bottom-color: color-mix(in srgb, var(--danger) 22%, var(--border));
}

body.v3 .app-import-section--errors .app-card-header {
    border-bottom-color: color-mix(in srgb, var(--danger) 22%, var(--border));
}

body.v3 .app-import-section__actions--choices {
    display: flex;
    flex-direction: column;
    align-items: stretch;
    gap: 0.75rem;
}

body.v3 .app-import-section__actions-lead {
    margin: 0;
    font-size: 0.8rem;
    color: var(--fg-2);
    line-height: 1.45;
}

body.v3 .app-import-section__apply-btn {
    align-self: flex-start;
}

@media (max-width: 575.98px) {
    body.v3 .app-import-section__apply-btn {
        width: 100%;
        justify-content: center;
    }
}

body.v3 .app-import-preview-kpi {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(9.5rem, 1fr));
    gap: 10px;
}

body.v3 .app-import-preview-kpi__cell {
    display: flex;
    flex-direction: column;
    gap: 8px;
    min-width: 0;
    padding: 14px 16px;
    border: 1px solid var(--border);
    border-radius: 12px;
    background: var(--bg-2);
    transition:
        border-color 0.15s ease,
        background 0.15s ease;
}

body.v3 .app-import-preview-kpi__cell.is-active {
    background: var(--bg-3);
}

body.v3 .app-import-preview-kpi__cell.is-zero {
    opacity: 0.78;
}

body.v3 .app-import-preview-kpi__cell.is-zero .app-import-preview-kpi__value {
    color: var(--fg-3);
}

body.v3 .app-import-preview-kpi__cell--accent.is-active {
    border-color: var(--accent-line);
}

body.v3 .app-import-preview-kpi__cell--accent.is-active .app-import-preview-kpi__value {
    color: var(--accent);
}

body.v3 .app-import-preview-kpi__cell--warn.is-active {
    border-color: rgba(251, 191, 36, 0.45);
}

body.v3 .app-import-preview-kpi__cell--warn.is-active .app-import-preview-kpi__value {
    color: var(--warn);
}

body.v3 .app-import-preview-kpi__cell--success.is-active {
    border-color: rgba(52, 211, 153, 0.35);
}

body.v3 .app-import-preview-kpi__cell--success.is-active .app-import-preview-kpi__value {
    color: var(--success);
}

body.v3 .app-import-preview-kpi__cell--danger.is-active {
    border-color: rgba(251, 113, 133, 0.35);
}

body.v3 .app-import-preview-kpi__cell--danger.is-active .app-import-preview-kpi__value {
    color: var(--danger);
}

body.v3 .app-import-preview-kpi__label {
    display: inline-flex;
    align-items: center;
    gap: 0.4rem;
    font-size: 0.65rem;
    font-weight: 700;
    letter-spacing: 0.08em;
    text-transform: uppercase;
    color: var(--fg-3);
    line-height: 1.2;
}

body.v3 .app-import-preview-kpi__label span {
    min-width: 0;
}

body.v3 .app-import-preview-kpi__value {
    font-size: 1.75rem;
    font-weight: 700;
    line-height: 1;
    letter-spacing: -0.02em;
    color: var(--fg);
}

body.v3 .app-import-terminal {
    border: 1px solid var(--border);
    border-radius: 14px;
    background: var(--bg-2);
    overflow: hidden;
}

body.v3 .app-import-terminal__header {
    display: flex;
    align-items: center;
    gap: 0.65rem;
    padding: 14px 20px;
    border-bottom: 1px solid var(--border);
    background: var(--bg-3);
}

body.v3 .app-import-terminal--success .app-import-terminal__header {
    border-bottom-color: rgba(52, 211, 153, 0.22);
}

body.v3 .app-import-terminal--warn .app-import-terminal__header {
    border-bottom-color: rgba(251, 191, 36, 0.22);
}

body.v3 .app-import-terminal--danger .app-import-terminal__header {
    border-bottom-color: rgba(251, 113, 133, 0.22);
}

body.v3 .app-import-terminal__header-icon {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    flex-shrink: 0;
}

body.v3 .app-import-terminal--success .app-import-terminal__header-icon {
    color: var(--success);
}

body.v3 .app-import-terminal--warn .app-import-terminal__header-icon {
    color: var(--warn);
}

body.v3 .app-import-terminal--danger .app-import-terminal__header-icon {
    color: var(--danger);
}

body.v3 .app-import-terminal__title {
    margin: 0;
    flex: 1 1 auto;
    min-width: 0;
    font-size: 14px;
    font-weight: 700;
    color: var(--fg);
}

body.v3 .app-import-terminal__panel {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 1.5rem;
    padding: 1.15rem 1.25rem 1.25rem;
    border-left: 3px solid var(--border-2);
}

body.v3 .app-import-terminal__content {
    flex: 1 1 auto;
    min-width: 0;
}

body.v3 .app-import-terminal--success .app-import-terminal__panel {
    border-left-color: var(--success);
    background:
        linear-gradient(135deg, rgba(52, 211, 153, 0.08), transparent 55%),
        var(--bg-2);
}

body.v3 .app-import-terminal--warn .app-import-terminal__panel {
    border-left-color: var(--warn);
    background:
        linear-gradient(135deg, rgba(251, 191, 36, 0.08), transparent 55%),
        var(--bg-2);
}

body.v3 .app-import-terminal--danger .app-import-terminal__panel {
    border-left-color: var(--danger);
    background:
        linear-gradient(135deg, rgba(251, 113, 133, 0.08), transparent 55%),
        var(--bg-2);
}

body.v3 .app-import-terminal__hero {
    display: flex;
    align-items: center;
    gap: 1rem;
    margin-bottom: 0.85rem;
}

body.v3 .app-import-terminal__hero-icon {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 3rem;
    height: 3rem;
    border-radius: 12px;
    flex-shrink: 0;
    border: 1px solid var(--border-2);
    background: var(--bg-3);
}

body.v3 .app-import-terminal--success .app-import-terminal__hero-icon {
    color: var(--success);
    border-color: rgba(52, 211, 153, 0.35);
    background: rgba(52, 211, 153, 0.1);
}

body.v3 .app-import-terminal--warn .app-import-terminal__hero-icon {
    color: var(--warn);
    border-color: rgba(251, 191, 36, 0.35);
    background: rgba(251, 191, 36, 0.1);
}

body.v3 .app-import-terminal--danger .app-import-terminal__hero-icon {
    color: var(--danger);
    border-color: rgba(251, 113, 133, 0.35);
    background: rgba(251, 113, 133, 0.1);
}

body.v3 .app-import-terminal__hero-value {
    font-size: 2rem;
    font-weight: 700;
    line-height: 1;
    letter-spacing: -0.02em;
    color: var(--fg);
}

body.v3 .app-import-terminal--success .app-import-terminal__hero-value {
    color: var(--success);
}

body.v3 .app-import-terminal--warn .app-import-terminal__hero-value {
    color: var(--warn);
}

body.v3 .app-import-terminal--danger .app-import-terminal__hero-value {
    color: var(--danger);
}

body.v3 .app-import-terminal__hero-label {
    margin-top: 0.35rem;
    font-size: 0.68rem;
    font-weight: 700;
    letter-spacing: 0.08em;
    text-transform: uppercase;
    color: var(--fg-3);
}

body.v3 .app-import-terminal__message {
    margin: 0;
    font-size: 0.88rem;
    line-height: 1.5;
    color: var(--fg-2);
}

body.v3 .app-import-terminal__stats {
    list-style: none;
    margin: 0.75rem 0 0;
    padding: 0;
    display: flex;
    flex-wrap: wrap;
    gap: 0.65rem;
}

body.v3 .app-import-terminal__stat {
    flex: 1 1 8rem;
    min-width: 0;
    padding: 0.65rem 0.85rem;
    border: 1px solid var(--border);
    border-radius: 8px;
    background: var(--bg-3);
    display: flex;
    flex-direction: column;
    gap: 0.25rem;
}

body.v3 .app-import-terminal__stat-value {
    font-size: 1.25rem;
    font-weight: 700;
    line-height: 1;
}

body.v3 .app-import-terminal__stat--success .app-import-terminal__stat-value {
    color: var(--success);
}

body.v3 .app-import-terminal__stat--warn .app-import-terminal__stat-value {
    color: var(--warn);
}

body.v3 .app-import-terminal__stat-label {
    font-size: 0.65rem;
    font-weight: 700;
    letter-spacing: 0.06em;
    text-transform: uppercase;
    color: var(--fg-3);
}

body.v3 .app-import-terminal__actions {
    display: flex;
    flex-shrink: 0;
    align-items: center;
    align-self: center;
}

body.v3 .app-import-terminal__cta {
    display: inline-flex;
    align-items: center;
    gap: 0.45rem;
    white-space: nowrap;
}

@media (max-width: 767.98px) {
    body.v3 .app-import-terminal__panel {
        flex-direction: column;
        align-items: stretch;
    }

    body.v3 .app-import-terminal__actions {
        align-self: stretch;
        justify-content: flex-start;
        padding-top: 0.25rem;
    }
}

@media (max-width: 575.98px) {
    body.v3 .app-import-terminal__cta {
        width: 100%;
        justify-content: center;
    }
}

body.v3 .app-import-progress__status {
    margin: 0 0 0.35rem;
    font-weight: 600;
}

body.v3 .app-import-progress__counts {
    margin: 0 0 0.75rem;
    color: var(--text-muted);
}

body.v3 .app-import-progress__bar {
    height: 0.45rem;
    border-radius: 999px;
    background: var(--surface-2);
    overflow: hidden;
}

body.v3 .app-import-progress__fill {
    display: block;
    height: 100%;
    background: var(--accent);
    transition: width 0.25s ease;
}

body.v3 .app-import-progress__bar.is-indeterminate {
    position: relative;
    overflow: hidden;
}

body.v3 .app-import-progress__bar.is-indeterminate .app-import-progress__fill {
    width: 35% !important;
    transition: none;
    animation: admin-scryfall-sync-indeterminate 1.4s ease-in-out infinite;
}

@keyframes admin-scryfall-sync-indeterminate {
    0% {
        transform: translateX(-100%);
    }
    100% {
        transform: translateX(400%);
    }
}

body.v3 .app-import-preview-form.is-busy {
    opacity: 0.85;
    pointer-events: none;
}

body.v3 .app-import-progress__summary {
    margin: 0.5rem 0 0;
    color: var(--text-muted);
    font-size: 0.92rem;
}

/* Quick new: request type choice */
body.v3 .app-request-type-choice {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 12px;
    margin: 0;
    padding: 0;
    border: 0;
}

body.v3 .app-request-type-choice__option {
    margin: 0;
    cursor: pointer;
}

body.v3 .app-request-type-choice__input {
    position: absolute;
    opacity: 0;
    pointer-events: none;
}

body.v3 .app-request-type-choice__card {
    display: flex;
    flex-direction: column;
    gap: 6px;
    min-height: 100%;
    padding: 14px 16px;
    border: 1px solid var(--border);
    border-radius: var(--radius-md, 10px);
    background: var(--bg-2);
    transition: border-color 0.15s ease, box-shadow 0.15s ease;
}

body.v3 .app-request-type-choice__input:focus-visible + .app-request-type-choice__card {
    outline: 2px solid var(--accent);
    outline-offset: 2px;
}

body.v3 .app-request-type-choice__input:checked + .app-request-type-choice__card {
    border-color: var(--accent);
    box-shadow: 0 0 0 1px var(--accent);
}

body.v3 .app-request-type-choice__icon {
    color: var(--accent);
}

body.v3 .app-request-type-choice__label {
    font-weight: 600;
    color: var(--text);
}

body.v3 .app-request-type-choice__help {
    font-size: 0.88rem;
    color: var(--text-muted);
    line-height: 1.4;
}

body.v3 .app-import-terminal__actions {
    display: flex;
    flex-wrap: wrap;
    gap: 10px;
    align-items: center;
}

@media (max-width: 640px) {
    body.v3 .app-request-type-choice {
        grid-template-columns: 1fr;
    }
}

body.v3 .admin-scryfall-sync-page__head {
    display: flex;
    align-items: flex-start;
    justify-content: space-between;
    gap: 16px;
    margin-bottom: 1rem;
}
body.v3 .admin-scryfall-sync-page__title {
    display: flex;
    align-items: center;
    gap: 8px;
}
body.v3 .admin-scryfall-sync-page__title-icon {
    color: var(--accent);
}
body.v3 .admin-scryfall-sync-page__queue-form {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    justify-content: flex-end;
    gap: 12px;
}
body.v3 .admin-scryfall-sync-page__force {
    margin: 0;
}
body.v3 .admin-scryfall-sync-page__empty {
    padding: 32px 16px;
}
body.v3 .admin-scryfall-sync-page__job {
    display: flex;
    flex-direction: column;
    gap: 14px;
}
body.v3 .admin-scryfall-sync-page__file-progress,
body.v3 .admin-scryfall-sync-page__import-progress {
    display: flex;
    flex-direction: column;
    gap: 8px;
}
body.v3 .admin-scryfall-sync-page__progress-head {
    display: flex;
    align-items: baseline;
    justify-content: space-between;
    gap: 12px;
}
body.v3 .admin-scryfall-sync-page__progress-label {
    font-size: 12px;
    font-weight: 700;
    letter-spacing: 0.06em;
    text-transform: uppercase;
    color: var(--fg-4);
}
body.v3 .admin-scryfall-sync-page__progress-status {
    margin: 0;
    font-weight: 600;
    color: var(--fg);
}
body.v3 .admin-scryfall-sync-page__progress-pct {
    font-size: 1.1rem;
    font-weight: 700;
    color: var(--accent);
}
body.v3 .admin-scryfall-sync-page__progress-summary {
    margin: 0;
    font-size: 13px;
    color: var(--fg-3);
}
body.v3 .admin-scryfall-sync-page__stats.request-show-statGrid {
    grid-template-columns: repeat(3, minmax(0, 1fr));
}
body.v3 .admin-scryfall-sync-page__stats .request-show-statTile__val {
    font-size: clamp(1rem, 3.5vw, 1.35rem);
    overflow-wrap: anywhere;
}
body.v3 .admin-scryfall-sync-page__error {
    margin: 0;
    font-size: 13px;
    line-height: 1.45;
}
body.v3 .admin-scryfall-sync-page__error-message {
    display: block;
    white-space: pre-wrap;
    overflow-wrap: anywhere;
}
body.v3 .admin-scryfall-sync-page__manifest-stats.request-show-statGrid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
}
body.v3 .admin-scryfall-sync-page__manifest-val {
    font-size: 0.92rem;
    font-weight: 600;
    overflow-wrap: anywhere;
}
body.v3 .admin-scryfall-sync-page__grid {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 12px;
}
body.v3 .admin-scryfall-sync-page__card-head {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 12px;
    flex-wrap: wrap;
}
@media (max-width: 1199.98px) {
    body.v3 .admin-scryfall-sync-page__grid {
        grid-template-columns: 1fr;
    }
}
@media (max-width: 991.98px) {
    body.v3 .admin-scryfall-sync-page__head {
        flex-direction: column;
    }
    body.v3 .admin-scryfall-sync-page__queue-form {
        width: 100%;
        justify-content: flex-start;
    }
}
@media (max-width: 640px) {
    body.v3 .admin-scryfall-sync-page__stats.request-show-statGrid,
    body.v3 .admin-scryfall-sync-page__manifest-stats.request-show-statGrid {
        grid-template-columns: 1fr;
    }
}

body.v3 .admin-scryfall-sync-page__history {
    margin-top: 12px;
}
body.v3 .admin-scryfall-sync-page__history-sub {
    margin: 4px 0 0;
    font-size: 13px;
    color: var(--fg-3);
}
body.v3 .admin-scryfall-sync-page__history-body {
    padding-top: 0;
}
body.v3 .admin-scryfall-sync-page__jobs-tbl .admin-scryfall-sync-page__jobs-notes {
    max-width: 18rem;
    overflow-wrap: anywhere;
}
body.v3 .admin-scryfall-sync-page__jobs-mobile-card .admin-scryfall-sync-page__jobs-notes {
    margin: 0;
    font-size: 12px;
    color: var(--fg-3);
    overflow-wrap: anywhere;
}

body.v3 .admin-catalog-image-cache-page__head {
    display: flex;
    align-items: flex-start;
    justify-content: space-between;
    gap: 16px;
}
body.v3 .admin-catalog-image-cache-page__title {
    display: flex;
    align-items: center;
    gap: 8px;
}
body.v3 .admin-catalog-image-cache-page__title-icon {
    color: var(--accent);
}
body.v3 .admin-catalog-image-cache-page__queue-form {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    gap: 10px;
}
body.v3 .admin-catalog-image-cache-page__force {
    margin: 0;
}
body.v3 .admin-catalog-image-cache-page__empty {
    padding: 32px 16px;
}
body.v3 .admin-catalog-image-cache-page__job {
    display: flex;
    flex-direction: column;
    gap: 14px;
}
body.v3 .admin-catalog-image-cache-page__cache-progress {
    display: flex;
    flex-direction: column;
    gap: 8px;
}
body.v3 .admin-catalog-image-cache-page__progress-head {
    display: flex;
    align-items: baseline;
    justify-content: space-between;
    gap: 8px;
}
body.v3 .admin-catalog-image-cache-page__progress-label {
    font-size: 12px;
    font-weight: 700;
    letter-spacing: 0.06em;
    text-transform: uppercase;
    color: var(--fg-3);
}
body.v3 .admin-catalog-image-cache-page__progress-status {
    margin: 0;
    font-weight: 600;
    color: var(--fg);
}
body.v3 .admin-catalog-image-cache-page__progress-pct {
    font-size: 1.1rem;
    font-weight: 700;
    color: var(--accent);
}
body.v3 .admin-catalog-image-cache-page__progress-summary {
    margin: 0;
    font-size: 13px;
    color: var(--fg-3);
}
body.v3 .admin-catalog-image-cache-page__stats.request-show-statGrid {
    grid-template-columns: repeat(4, minmax(0, 1fr));
}
body.v3 .admin-catalog-image-cache-page__stats .request-show-statTile__val {
    font-size: clamp(1rem, 3.5vw, 1.35rem);
    overflow-wrap: anywhere;
}
body.v3 .admin-catalog-image-cache-page__error {
    margin: 0;
    font-size: 13px;
    line-height: 1.45;
}
body.v3 .admin-catalog-image-cache-page__error-message {
    display: block;
    white-space: pre-wrap;
    overflow-wrap: anywhere;
}
body.v3 .admin-catalog-image-cache-page__summary-stats.request-show-statGrid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
}
body.v3 .admin-catalog-image-cache-page__summary-val {
    font-size: 0.92rem;
    font-weight: 600;
    overflow-wrap: anywhere;
}
body.v3 .admin-catalog-image-cache-page__grid {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 12px;
}
body.v3 .admin-catalog-image-cache-page__card-head {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 8px;
}
@media (max-width: 900px) {
    body.v3 .admin-catalog-image-cache-page__grid {
        grid-template-columns: 1fr;
    }
}
@media (max-width: 640px) {
    body.v3 .admin-catalog-image-cache-page__head {
        flex-direction: column;
    }
    body.v3 .admin-catalog-image-cache-page__queue-form {
        width: 100%;
        justify-content: flex-start;
    }
}
@media (max-width: 520px) {
    body.v3 .admin-catalog-image-cache-page__stats.request-show-statGrid,
    body.v3 .admin-catalog-image-cache-page__summary-stats.request-show-statGrid {
        grid-template-columns: 1fr;
    }
}
body.v3 .admin-catalog-image-cache-page__history {
    margin-top: 12px;
}
body.v3 .admin-catalog-image-cache-page__history-sub {
    margin: 4px 0 0;
    font-size: 13px;
    color: var(--fg-3);
}
body.v3 .admin-catalog-image-cache-page__history-body {
    padding-top: 0;
}
body.v3 .admin-catalog-image-cache-page__jobs-tbl .admin-catalog-image-cache-page__jobs-notes {
    max-width: 18rem;
    overflow-wrap: anywhere;
}
body.v3 .admin-catalog-image-cache-page__jobs-mobile-card .admin-catalog-image-cache-page__jobs-notes {
    margin: 0;
    font-size: 12px;
    color: var(--fg-3);
    overflow-wrap: anywhere;
}

/* Legal pages */
body.v3 .legal-page {
    max-width: 48rem;
    margin-inline: auto;
}
body.v3 .legal-page__title {
    margin: 0 0 1.5rem;
    font-size: var(--t-h2);
    font-weight: 700;
    color: var(--fg);
}
body.v3 .legal-page__section-title {
    margin: 1.5rem 0 0;
    font-size: var(--t-h3);
    font-weight: 600;
    color: var(--fg);
}
body.v3 .legal-page__text {
    color: var(--fg-2);
}
body.v3 .legal-page__text--last {
    margin-bottom: 0;
}
body.v3 .legal-page__footer {
    margin: 0;
}
body.v3 .legal-page__footer-link {
    color: var(--accent);
}
body.v3 .legal-data-deletion__form {
    margin-top: 1.5rem;
}
body.v3 .legal-data-deletion__alert-title {
    font-weight: 600;
}
body.v3 .legal-data-deletion__alert-body {
    font-size: 0.875rem;
}

/* Auth / login */
body.v3.login-page {
    background: var(--bg);
    color: var(--fg);
    min-height: 100vh;
    display: flex;
    flex-direction: column;
}
body.v3 .auth-main {
    flex: 1;
    display: flex;
    align-items: center;
    justify-content: center;
    padding: 40px 20px;
}
body.v3 .auth-card {
    width: 100%;
    max-width: 420px;
    background: var(--bg-2);
    border: 1px solid var(--border-2);
    border-radius: 16px;
    overflow: hidden;
}
body.v3 .app-auth-shell {
    width: 100%;
    max-width: 440px;
    margin: auto;
}
body.v3 .app-auth-error {
    display: flex;
    align-items: center;
    gap: 10px;
    margin-bottom: 1rem;
}
body.v3 .auth-card-head {
    padding: 20px 22px;
    border-bottom: 1px solid var(--border);
    background: var(--bg-3);
    display: flex;
    align-items: flex-start;
    gap: 14px;
}
body.v3 .auth-card-icon {
    width: 44px;
    height: 44px;
    border-radius: 10px;
    background: transparent;
    color: var(--accent);
    display: flex;
    align-items: center;
    justify-content: center;
    flex-shrink: 0;
}
body.v3 .auth-card-icon img {
    width: 44px;
    height: 44px;
    object-fit: contain;
}
body.v3 .auth-card-eyebrow {
    font-size: 10px;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: 0.08em;
    color: var(--fg-4);
    margin: 0 0 4px;
}
body.v3 .auth-card-title {
    font-size: 16px;
    font-weight: 700;
    color: var(--fg);
    margin: 0;
}
body.v3 .auth-card-body {
    padding: 22px;
}
body.v3 .app-auth-field {
    margin-bottom: 1rem;
}
body.v3 .app-auth-submit {
    width: 100%;
    justify-content: center;
}

@media (max-width: 991.98px) {
    body.v3.login-page .auth-main {
        padding-left: max(16px, env(safe-area-inset-left));
        padding-right: max(16px, env(safe-area-inset-right));
        padding-top: 24px;
        padding-bottom: 24px;
    }
}

/* Error pages */
body.v3.error-page .error-shell {
    width: 100%;
    max-width: 520px;
    margin: 0 auto;
}
body.v3.error-page .error-card {
    max-width: none;
    overflow: hidden;
}
body.v3.error-page .error-card-head {
    align-items: center;
}
body.v3.error-page .error-card-icon {
    width: 52px;
    height: 52px;
    border-radius: 14px;
    border: 1px solid var(--border-strong);
    background: var(--danger-soft);
}
body.v3.error-page .error-card-icon--warn {
    background: var(--warn-soft);
    color: var(--warn);
    border-color: rgba(251, 191, 36, 0.3);
}
body.v3.error-page .error-card-icon--info {
    background: var(--info-soft);
    color: var(--info);
    border-color: rgba(96, 165, 250, 0.3);
}
body.v3.error-page .error-card-icon--danger {
    background: var(--danger-soft);
    color: var(--danger);
    border-color: rgba(251, 113, 133, 0.3);
}
body.v3.error-page .error-card-body {
    display: flex;
    flex-direction: column;
    gap: 14px;
}
body.v3.error-page .error-status {
    margin: 0;
    font-size: 12px;
    font-weight: 700;
    letter-spacing: 0.18em;
    text-transform: uppercase;
    color: var(--accent);
}
body.v3.error-page .error-copy {
    margin: 0;
    color: var(--fg-2);
    font-size: 14px;
    line-height: 1.6;
}
body.v3.error-page .error-actions {
    display: flex;
    flex-wrap: wrap;
    gap: 10px;
    padding-top: 4px;
}

/* Landing + public marketing */
/* Scroll reveal (landing) */
.lp-reveal {
    opacity: 0;
    transform: translateY(22px);
    transition:
        opacity 0.65s cubic-bezier(0.16, 1, 0.3, 1),
        transform 0.65s cubic-bezier(0.16, 1, 0.3, 1);
}
.lp-reveal.is-visible {
    opacity: 1;
    transform: translateY(0);
}
.lp-reveal:nth-child(2) {
    transition-delay: 0.1s;
}
.lp-reveal:nth-child(3) {
    transition-delay: 0.2s;
}
.lp-reveal:nth-child(4) {
    transition-delay: 0.3s;
}
body.v3.landing-page #lp-platform {
    scroll-margin-top: 86px;
}
body.v3.landing-page #lp-platform.is-anchor-target::after {
    content: "";
    position: absolute;
    inset: 18px;
    border: 1px solid var(--accent-line);
    border-radius: 24px;
    pointer-events: none;
    animation: lp-platform-anchor-pulse 1.1s cubic-bezier(0.16, 1, 0.3, 1);
}
@keyframes lp-platform-anchor-pulse {
    0% {
        opacity: 0;
        transform: scale(0.985);
        box-shadow: 0 0 0 0 var(--accent-soft);
    }
    28% {
        opacity: 1;
    }
    100% {
        opacity: 0;
        transform: scale(1.01);
        box-shadow: 0 0 0 18px rgba(0, 0, 0, 0);
    }
}
@media (prefers-reduced-motion: reduce) {
    .lp-reveal {
        opacity: 1 !important;
        transform: none !important;
        transition: none !important;
    }

    body.v3.landing-page #lp-platform.is-anchor-target::after {
        animation: none;
        opacity: 0;
    }
}


/* Landing page + public nav shell */

body.v3.landing-page,
body.v3.access-request-page {
    background: var(--bg);
    min-height: 100vh;
    display: flex;
    flex-direction: column;
    position: relative;
    overflow-x: hidden;
}

body.v3 .landing-nav-root {
    position: relative;
    z-index: 1100;
    flex-shrink: 0;
}
body.v3 .landing-header {
    box-sizing: border-box;
    height: 76px;
    min-height: 76px;
    padding: 0 var(--d-brand-pad-x);
    display: flex;
    align-items: center;
    flex-wrap: nowrap;
    gap: 16px 24px;
    border-bottom: 1px solid var(--border);
    position: relative;
    z-index: 2;
    background: rgba(7, 7, 13, 0.8);
    backdrop-filter: blur(16px);
    -webkit-backdrop-filter: blur(16px);
}
body.v3 .landing-header .brand {
    padding: 0;
    border: 0;
    display: inline-flex;
    align-items: center;
    gap: 12px;
    flex-shrink: 0;
}
body.v3 .landing-header .landing-nav {
    flex: 1 1 auto;
    display: flex;
    align-items: center;
    flex-wrap: wrap;
    gap: clamp(12px, 2.2vw, 28px);
    min-width: 0;
    margin: 0;
    font-size: 13px;
    color: var(--fg-2);
    text-transform: uppercase;
    letter-spacing: 0.08em;
    font-weight: 600;
}
body.v3 .landing-header .landing-nav a {
    display: inline-flex;
    align-items: center;
    line-height: 1.2;
    padding: 6px 0;
    color: var(--fg-2);
    text-decoration: none;
    transition: color 0.12s;
}
body.v3 .landing-header .landing-nav a:hover {
    color: var(--fg);
}
body.v3 .landing-header .landing-nav a[aria-current="page"] {
    color: var(--fg);
    text-decoration: underline;
    text-underline-offset: 4px;
    text-decoration-color: var(--accent-line);
}
body.v3 .landing-header__actions {
    display: flex;
    align-items: center;
    gap: 10px;
    margin-left: auto;
    flex-shrink: 0;
    flex-wrap: wrap;
    justify-content: flex-end;
}
body.v3 .landing-header__desktop {
    display: flex;
    align-items: center;
    gap: 16px 24px;
    flex: 1 1 auto;
    min-width: 0;
}
body.v3 .landing-header__desktop .landing-nav {
    flex: 1 1 auto;
    justify-content: center;
}
body.v3 .landing-header__desktop .landing-header__actions {
    margin-left: auto;
}
body.v3 .landing-header__locale {
    display: inline-flex;
    align-items: center;
    gap: 4px;
}
body.v3 .landing-header__locale-pill {
    font-size: 11px;
    font-weight: 700;
    padding: 3px 8px;
    border-radius: 6px;
    text-decoration: none;
    transition:
        background 0.12s,
        color 0.12s;
    color: var(--fg-3);
}
body.v3 .landing-header__locale-pill:hover {
    color: var(--fg);
}
body.v3 .landing-header__locale-pill.is-active {
    background: var(--accent);
    color: var(--bg);
}
body.v3 .landing-header__menu-toggle {
    display: none;
    position: relative;
    z-index: 1102;
}

body.v3 .landing-nav-overlay {
    display: none;
    position: fixed;
    inset: 0;
    z-index: 1090;
    background: rgba(0, 0, 0, 0.55);
}
body.v3 .landing-nav-overlay.is-active {
    display: block;
}

body.v3 .landing-nav-panel {
    position: fixed;
    top: 0;
    right: 0;
    z-index: 1100;
    width: min(320px, 92vw);
    height: 100%;
    max-height: 100dvh;
    display: flex;
    flex-direction: column;
    gap: 20px;
    padding: 16px 18px 24px;
    background: var(--bg-sidebar);
    border-left: 1px solid var(--border);
    box-shadow: -12px 0 40px rgba(0, 0, 0, 0.45);
    overflow-y: auto;
    transform: translateX(100%);
    transition: transform 0.2s ease;
    visibility: hidden;
}
body.v3 .landing-nav-panel.is-open {
    transform: translateX(0);
    visibility: visible;
}
body.v3 .landing-nav-panel__head {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 12px;
    padding-bottom: 12px;
    border-bottom: 1px solid var(--border);
}
body.v3 .landing-nav-panel__title {
    font-size: 13px;
    font-weight: 700;
    letter-spacing: 0.06em;
    text-transform: uppercase;
    color: var(--fg-2);
}
body.v3 .landing-nav-panel__section .landing-nav {
    flex-direction: column;
    align-items: stretch;
    gap: 4px;
    flex-wrap: nowrap;
}
body.v3 .landing-nav-panel__section .landing-nav a {
    padding: 12px 14px;
    border-radius: 8px;
    text-transform: none;
    letter-spacing: 0;
    font-size: 14px;
    font-weight: 600;
}
body.v3 .landing-nav-panel__section .landing-nav a:hover,
body.v3 .landing-nav-panel__section .landing-nav a[aria-current="page"] {
    background: var(--bg-3);
    text-decoration: none;
}
body.v3 .landing-nav-panel__actions {
    margin-left: 0;
    margin-top: auto;
    flex-direction: column;
    align-items: stretch;
    gap: 10px;
}
body.v3 .landing-nav-panel__actions .btn {
    justify-content: center;
    width: 100%;
}
body.v3 .landing-nav-panel__actions .landing-header__locale {
    justify-content: center;
    padding-bottom: 4px;
}

body.v3.landing-nav-open .landing-header {
    z-index: 1101;
}

@media (max-width: 991.98px) {
    body.v3 .landing-header {
        flex-wrap: nowrap;
        height: auto;
        min-height: 64px;
        padding: 12px var(--d-brand-pad-x);
        gap: 12px;
    }
    body.v3 .landing-header .brand-text {
        overflow: hidden;
        text-overflow: ellipsis;
        white-space: nowrap;
        max-width: min(42vw, 12rem);
    }
    body.v3 .landing-header__desktop {
        display: none;
    }
    body.v3 .landing-header__menu-toggle {
        display: inline-flex;
        margin-left: auto;
        flex-shrink: 0;
    }
    body.v3.access-request-page .arq-section,
    body.v3.landing-page .lp-hero {
        padding-left: max(16px, env(safe-area-inset-left));
        padding-right: max(16px, env(safe-area-inset-right));
    }
}


/* Site footer (shell + public) */

body.v3 .site-footer {
    flex-shrink: 0;
    border-top: 1px solid var(--border);
    background: var(--bg-sidebar);
    color: var(--fg-3);
    padding: clamp(18px, 3vw, 24px) clamp(20px, 4vw, 40px) 20px;
}
body.v3 .site-footer__inner {
    max-width: 1440px;
    margin: 0 auto;
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    justify-content: space-between;
    gap: 16px 24px;
}
body.v3 .site-footer__start {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    gap: 12px 20px;
    min-width: 0;
}
body.v3 .site-footer__brand {
    display: inline-flex;
    align-items: center;
    gap: 8px;
    text-decoration: none;
    color: var(--fg-2);
    font-weight: 700;
    font-size: 13px;
    letter-spacing: 0.05em;
    text-transform: uppercase;
    transition: color 0.12s;
}
body.v3 .site-footer__brand:hover,
body.v3 .site-footer__brand:focus-visible {
    color: var(--fg);
}
body.v3 .site-footer__logo {
    width: 22px;
    height: 22px;
    opacity: 0.85;
    object-fit: contain;
}
body.v3 .site-footer__copyright {
    font-size: 12px;
    color: var(--fg-3);
    line-height: 1.45;
}
body.v3 .site-footer__nav {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    gap: 8px clamp(16px, 2.5vw, 24px);
}
body.v3 .site-footer__link {
    font-size: 12px;
    font-weight: 600;
    letter-spacing: 0.06em;
    text-transform: uppercase;
    color: var(--fg-3);
    text-decoration: none;
    transition: color 0.12s;
    background: none;
    border: 0;
    padding: 0;
    cursor: pointer;
    font-family: inherit;
}
body.v3 .site-footer__link:hover,
body.v3 .site-footer__link:focus-visible {
    color: var(--fg);
}
body.v3 .site-footer__disclaimer {
    max-width: 1440px;
    margin: 14px auto 0;
    padding-top: 14px;
    border-top: 1px solid var(--border);
    font-size: 10.5px;
    line-height: 1.55;
    color: var(--fg-4);
}

body.v3 .landing-hero {
    padding: 70px 40px 60px;
    max-width: 1280px;
    margin: 0 auto;
    width: 100%;
    display: grid;
    grid-template-columns: 1.1fr 1fr;
    gap: 60px;
    align-items: center;
    position: relative;
    z-index: 1;
}
body.v3 .landing-badge {
    display: inline-flex;
    align-items: center;
    gap: 6px;
    padding: 6px 12px;
    border-radius: 999px;
    background: var(--accent-soft);
    color: var(--accent);
    font-size: 11px;
    font-weight: 700;
    letter-spacing: 0.14em;
    text-transform: uppercase;
    border: 1px solid var(--accent-line);
    box-shadow: var(--accent-glow);
    margin-bottom: 28px;
}
body.v3 .landing-title {
    font-size: clamp(3rem, 6vw, 5rem);
    line-height: 1.1;
    letter-spacing: -0.04em;
    font-weight: 800;
    margin: 0;
    overflow: visible;
}
body.v3 .landing-title .holo-text {
    background: var(--holo);
    background-clip: text;
    -webkit-background-clip: text;
    -webkit-text-fill-color: transparent;
    background-size: 200% 200%;
}
body.v3 .landing-subtitle {
    font-size: 18px;
    line-height: 1.5;
    color: var(--fg-2);
    margin: 32px 0 36px;
    max-width: 520px;
}
body.v3 .landing-stats {
    display: flex;
    gap: 28px;
    font-size: 12px;
    color: var(--fg-3);
    text-transform: uppercase;
    letter-spacing: 0.08em;
    font-weight: 700;
}
body.v3 .landing-stats .stat-num {
    font-size: 28px;
    color: var(--accent);
    font-weight: 800;
    display: block;
    letter-spacing: -0.02em;
    text-transform: none;
    font-variant-numeric: tabular-nums;
}

body.v3 .landing-card-fan {
    position: relative;
    height: 480px;
    display: flex;
    align-items: center;
    justify-content: center;
}
body.v3 .landing-card-fan .fan-card {
    position: absolute;
    border-radius: 12px;
    overflow: hidden;
    box-shadow:
        0 30px 60px rgba(0, 0, 0, 0.5),
        0 0 0 1px var(--border-2);
    transition: all 0.3s ease;
}
body.v3 .landing-floating-badge {
    position: absolute;
    bottom: 40px;
    right: -10px;
    padding: 10px 14px;
    background: var(--bg-2);
    border: 1px solid var(--accent-line);
    border-radius: 12px;
    font-size: 12px;
    font-weight: 600;
    color: var(--fg);
    box-shadow: 0 8px 24px rgba(0, 0, 0, 0.5);
}

body.v3 .landing-features {
    padding: 80px 40px;
    background: var(--bg-2);
    border-top: 1px solid var(--border);
    position: relative;
    z-index: 2;
}
body.v3 .landing-features-inner {
    max-width: 1280px;
    margin: 0 auto;
}
body.v3 .landing-features-grid {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 16px;
}
@media (max-width: 767.98px) {
    body.v3 .landing-features-grid {
        grid-template-columns: 1fr;
    }
}
@media (min-width: 768px) and (max-width: 991.98px) {
    body.v3 .landing-features-grid {
        grid-template-columns: repeat(2, 1fr);
    }
}
body.v3 .landing-feature-card {
    padding: 28px;
    position: relative;
    overflow: hidden;
    background: var(--bg-3);
    border: 1px solid var(--border);
    border-radius: 14px;
    transition:
        border-color 0.25s,
        box-shadow 0.25s;
}
body.v3 .landing-feature-card:hover {
    border-color: var(--accent-line);
    box-shadow: 0 0 0 1px var(--accent-soft);
}

/* Ambient orbs */
body.v3 .lp-orb {
    position: absolute;
    border-radius: 50%;
    filter: blur(90px);
    pointer-events: none;
    user-select: none;
}

/* ---- Landing (V3Landing-aligned, public route) ---- */
body.v3.landing-page .lp-ambient,
body.v3.access-request-page .lp-ambient {
    position: absolute;
    inset: 0;
    overflow: hidden;
    pointer-events: none;
    z-index: 0;
}
body.v3.landing-page .lp-ambient__blob,
body.v3.access-request-page .lp-ambient__blob {
    position: absolute;
    border-radius: 50%;
    pointer-events: none;
}
body.v3.landing-page .lp-ambient__blob--a,
body.v3.access-request-page .lp-ambient__blob--a {
    top: -200px;
    left: 20%;
    width: 600px;
    height: 600px;
    background: radial-gradient(circle, var(--accent-soft), transparent 60%);
}
body.v3.landing-page .lp-ambient__blob--b,
body.v3.access-request-page .lp-ambient__blob--b {
    top: 100px;
    right: -200px;
    width: 500px;
    height: 500px;
    background: radial-gradient(
        circle,
        rgba(124, 106, 247, 0.1),
        transparent 60%
    );
}

body.v3.landing-page #main-content,
body.v3.access-request-page #main-content {
    position: relative;
    z-index: 1;
}


/* Access request (public) */

body.v3.access-request-page .arq-section {
    flex: 1;
    width: 100%;
    padding: clamp(40px, 8vh, 64px) clamp(20px, 4vw, 40px)
        clamp(48px, 10vh, 80px);
}
body.v3.access-request-page .arq-section__inner {
    max-width: 640px;
    margin: 0 auto;
}
body.v3.access-request-page .arq-pill {
    display: inline-flex;
    align-items: center;
    gap: 6px;
    padding: 6px 12px;
    border-radius: 999px;
    margin-bottom: 20px;
    background: var(--accent-soft);
    color: var(--accent);
    font-size: 11px;
    font-weight: 700;
    letter-spacing: 0.14em;
    text-transform: uppercase;
    border: 1px solid var(--accent-line);
    box-shadow: var(--accent-glow);
}
body.v3.access-request-page .arq-title {
    font-size: clamp(2rem, 5vw, 2.75rem);
    line-height: 1.08;
    letter-spacing: -0.03em;
    font-weight: 800;
    margin: 0 0 16px;
    color: var(--fg);
}
body.v3.access-request-page .arq-lead {
    font-size: 16px;
    line-height: 1.55;
    color: var(--fg-2);
    margin: 0 0 28px;
    max-width: 52ch;
}
body.v3.access-request-page .arq-card {
    background: var(--bg-2);
    border: 1px solid var(--border-2);
    border-radius: 16px;
    overflow: hidden;
}
body.v3.access-request-page .arq-card__body {
    padding: clamp(20px, 4vw, 28px);
}
body.v3.access-request-page .arq-form-grid {
    display: grid;
    grid-template-columns: 1fr;
    gap: 16px;
    width: 100%;
}
body.v3.access-request-page .arq-form-grid__full {
    grid-column: 1 / -1;
}
@media (min-width: 768px) {
    body.v3.access-request-page .arq-form-grid {
        grid-template-columns: 1fr 1fr;
        column-gap: 16px;
        row-gap: 16px;
    }
}
body.v3.access-request-page .arq-form-field {
    min-width: 0;
    width: 100%;
}
body.v3.access-request-page .arq-form-field .mb-3 {
    margin-bottom: 0;
}
body.v3.access-request-page .arq-form-field .app-form-row {
    width: 100%;
}
body.v3.access-request-page .arq-form-field .form-control,
body.v3.access-request-page .arq-form-field .app-form-control,
body.v3.access-request-page .arq-form-field textarea.form-control,
body.v3.access-request-page .arq-form-field textarea.app-form-control {
    display: block;
    width: 100%;
    max-width: 100%;
    box-sizing: border-box;
}
body.v3.access-request-page .arq-form-feedback {
    color: var(--danger);
    font-size: 12px;
    margin-top: 4px;
}
body.v3.access-request-page .arq-form-feedback[hidden] {
    display: none;
}
body.v3.access-request-page .arq-actions {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    gap: 10px;
    margin-top: 8px;
}
body.v3.access-request-page .arq-actions .btn.primary {
    display: inline-flex;
    align-items: center;
    gap: 8px;
    padding: 12px 20px;
    font-size: 14px;
    font-weight: 600;
    border-radius: 8px;
    border: 0;
    cursor: pointer;
    text-decoration: none;
}
body.v3.access-request-page .arq-actions .btn.ghost {
    padding: 12px 18px;
    font-size: 14px;
    text-decoration: none;
}

body.v3.landing-page .lp-hero {
    padding: clamp(56px, 10vh, 70px) clamp(24px, 4vw, 40px)
        clamp(48px, 8vh, 60px);
    max-width: 1280px;
    margin: 0 auto;
}
body.v3.landing-page .lp-hero__inner {
    display: grid;
    grid-template-columns: 1fr;
    gap: clamp(32px, 5vw, 60px);
    align-items: center;
}
@media (min-width: 992px) {
    body.v3.landing-page .lp-hero__inner {
        grid-template-columns: 1.1fr 1fr;
    }
}
body.v3.landing-page .lp-hero__pill {
    display: inline-flex;
    align-items: center;
    gap: 6px;
    padding: 6px 12px;
    border-radius: 999px;
    margin-bottom: 28px;
    background: var(--accent-soft);
    color: var(--accent);
    font-size: 11px;
    font-weight: 700;
    letter-spacing: 0.14em;
    text-transform: uppercase;
    border: 1px solid var(--accent-line);
    box-shadow: var(--accent-glow);
}
body.v3.landing-page .lp-hero__title {
    font-size: clamp(2.5rem, 8vw, 5rem);
    line-height: 1.1;
    letter-spacing: -0.04em;
    font-weight: 800;
    margin: 0;
    color: var(--fg);
    overflow: visible;
}
body.v3.landing-page .lp-hero__title-line,
body.v3.landing-page .lp-hero__title-holo {
    display: block;
    overflow: visible;
    padding-bottom: 0.08em;
}
body.v3.landing-page .lp-hero__title-holo {
    background: var(--holo);
    background-size: 200% 200%;
    -webkit-background-clip: text;
    background-clip: text;
    -webkit-text-fill-color: transparent;
    -webkit-box-decoration-break: clone;
    box-decoration-break: clone;
}
body.v3.landing-page .lp-hero__lead {
    font-size: 18px;
    line-height: 1.5;
    color: var(--fg-2);
    margin: 32px 0 36px;
    max-width: 520px;
}
body.v3.landing-page .lp-hero__actions {
    display: flex;
    flex-wrap: wrap;
    gap: 12px;
    margin-bottom: 56px;
}
body.v3.landing-page .lp-hero__btn-primary {
    padding: 14px 24px;
    font-size: 14px;
    display: inline-flex;
    align-items: center;
    gap: 8px;
    border-radius: 8px;
    text-decoration: none;
}
body.v3.landing-page .lp-hero__btn-ghost {
    padding: 14px 24px;
    font-size: 14px;
    border-radius: 8px;
    text-decoration: none;
}
body.v3.landing-page .lp-hero__stats {
    display: flex;
    flex-wrap: wrap;
    gap: 28px;
    font-size: 12px;
    color: var(--fg-3);
    text-transform: uppercase;
    letter-spacing: 0.08em;
    font-weight: 700;
}
body.v3.landing-page .lp-hero__stat-value {
    font-size: 28px;
    color: var(--accent);
    font-weight: 800;
    display: block;
    letter-spacing: -0.02em;
    text-transform: none;
    font-variant-numeric: tabular-nums;
}
body.v3.landing-page .lp-hero__stat-label {
    margin-top: 4px;
    display: block;
}

body.v3.landing-page .lp-hero__visual--desktop {
    display: none;
}
@media (min-width: 992px) {
    body.v3.landing-page .lp-hero__visual--desktop {
        display: block;
    }
}

body.v3.landing-page .lp-fan {
    position: relative;
    height: 480px;
    display: flex;
    align-items: center;
    justify-content: center;
}
body.v3.landing-page .lp-fan__card {
    position: absolute;
    width: 220px;
    height: 308px;
    border-radius: 12px;
    overflow: hidden;
    box-shadow:
        0 30px 60px rgba(0, 0, 0, 0.5),
        0 0 0 1px var(--border-2);
    transition:
        transform 0.3s ease,
        box-shadow 0.3s ease;
}
body.v3.landing-page .lp-fan__card--0 {
    transform: translateX(-40px) rotate(-12deg);
    z-index: 0;
}
body.v3.landing-page .lp-fan__card--1 {
    transform: translateX(0) rotate(0deg);
    z-index: 1;
}
body.v3.landing-page .lp-fan__card--2 {
    transform: translateX(40px) rotate(12deg);
    z-index: 0;
}
body.v3.landing-page .lp-fan__img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    object-position: center top;
    display: block;
    image-rendering: -webkit-optimize-contrast;
}
body.v3.landing-page .lp-fan__shine {
    position: absolute;
    inset: 0;
    background: linear-gradient(
        135deg,
        transparent 30%,
        rgba(255, 255, 255, 0.1) 50%,
        transparent 70%
    );
    pointer-events: none;
    z-index: 1;
}
body.v3.landing-page .lp-fan__badge {
    position: absolute;
    bottom: 40px;
    right: -10px;
    padding: 10px 14px;
    background: var(--bg-2);
    border: 1px solid var(--accent-line);
    border-radius: 12px;
    font-size: 12px;
    font-weight: 600;
    color: var(--fg);
    box-shadow: 0 8px 24px rgba(0, 0, 0, 0.5);
    display: flex;
    align-items: center;
    gap: 8px;
    z-index: 2;
}
body.v3.landing-page .lp-fan__badge-dot {
    width: 8px;
    height: 8px;
    border-radius: 50%;
    background: var(--success);
    box-shadow: 0 0 8px var(--success);
    flex-shrink: 0;
}
body.v3.landing-page .lp-fan__badge-title {
    font-size: 12px;
    font-weight: 600;
    color: var(--fg);
}
body.v3.landing-page .lp-fan__badge-sub {
    font-size: 10.5px;
    color: var(--fg-3);
    text-transform: uppercase;
    letter-spacing: 0.1em;
    margin-top: 2px;
}

body.v3.landing-page .lp-platform {
    padding: 80px clamp(24px, 4vw, 40px);
    background: var(--bg-2);
    border-top: 1px solid var(--border);
    position: relative;
    z-index: 2;
}
body.v3.landing-page .lp-platform__inner {
    max-width: 1280px;
    margin: 0 auto;
}
body.v3.landing-page .lp-platform__head {
    margin-bottom: 48px;
}
body.v3.landing-page .lp-platform__title {
    font-size: clamp(2rem, 4vw, 3rem);
    font-weight: 800;
    letter-spacing: -0.025em;
    margin: 8px 0 0;
    max-width: 980px;
    line-height: 1.05;
    color: var(--fg);
}
@media (min-width: 900px) {
    body.v3.landing-page .lp-platform__title {
        white-space: nowrap;
    }
}
body.v3.landing-page .lp-platform__title-accent {
    color: var(--accent);
}
body.v3.landing-page .lp-platform__lead {
    max-width: 620px;
    margin: 18px 0 0;
    color: var(--fg-2);
    font-size: 16px;
    line-height: 1.55;
}
body.v3.landing-page .lp-platform-walkthrough {
    display: grid;
    gap: 28px;
}
body.v3.landing-page .lp-platform-step {
    display: grid;
    gap: 22px;
    align-items: center;
    padding: clamp(18px, 3vw, 28px);
    position: relative;
    overflow: hidden;
    background:
        radial-gradient(circle at 85% 15%, var(--accent-soft), transparent 34%),
        var(--bg);
    border: 1px solid var(--border-2);
    border-radius: 22px;
    box-shadow: 0 24px 80px rgba(0, 0, 0, 0.28);
}
body.v3.landing-page .lp-platform-step__copy {
    position: relative;
    z-index: 1;
}
body.v3.landing-page .lp-platform-step__meta {
    display: inline-flex;
    align-items: center;
    gap: 10px;
    margin-bottom: 16px;
}
body.v3.landing-page .lp-platform-step__num {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 34px;
    height: 34px;
    border-radius: 999px;
    background: var(--accent-soft);
    border: 1px solid var(--accent-line);
    color: var(--accent);
    font-size: 12px;
    font-weight: 800;
    letter-spacing: 0.04em;
}
body.v3.landing-page .lp-platform-step__kicker {
    color: var(--fg-3);
    font-size: 11px;
    font-weight: 800;
    letter-spacing: 0.14em;
    text-transform: uppercase;
}
body.v3.landing-page .lp-platform-step__title {
    max-width: 480px;
    margin: 0 0 12px;
    color: var(--fg);
    font-size: clamp(1.45rem, 3vw, 2.35rem);
    font-weight: 800;
    letter-spacing: -0.03em;
    line-height: 1.06;
}
body.v3.landing-page .lp-platform-step__body {
    max-width: 520px;
    margin: 0;
    color: var(--fg-2);
    font-size: 15px;
    line-height: 1.6;
}
body.v3.landing-page .lp-platform-shot {
    position: relative;
    z-index: 1;
    margin: 0;
    overflow: hidden;
    border: 1px solid var(--border-2);
    border-radius: 16px;
    background:
        linear-gradient(180deg, rgba(255, 255, 255, 0.05), transparent 18%),
        var(--bg-2);
    box-shadow:
        0 18px 50px rgba(0, 0, 0, 0.35),
        0 0 0 1px rgba(255, 255, 255, 0.02);
}
body.v3.landing-page .lp-platform-shot__chrome {
    display: flex;
    align-items: center;
    gap: 6px;
    height: 34px;
    padding: 0 14px;
    border-bottom: 1px solid var(--border);
    background: rgba(255, 255, 255, 0.025);
}
body.v3.landing-page .lp-platform-shot__chrome span {
    width: 8px;
    height: 8px;
    border-radius: 999px;
    background: var(--border-2);
}
body.v3.landing-page .lp-platform-shot__chrome span:first-child {
    background: var(--accent);
}
body.v3.landing-page .lp-platform-shot picture {
    display: block;
}
body.v3.landing-page .lp-platform-shot__img {
    display: block;
    width: 100%;
    aspect-ratio: 16 / 10;
    height: auto;
    object-fit: cover;
    object-position: center top;
}
@media (min-width: 900px) {
    body.v3.landing-page .lp-platform-step {
        grid-template-columns: minmax(260px, 0.82fr) minmax(0, 1.18fr);
        gap: clamp(28px, 4vw, 52px);
    }

    body.v3.landing-page .lp-platform-step:nth-child(even) {
        grid-template-columns: minmax(0, 1.18fr) minmax(260px, 0.82fr);
    }

    body.v3.landing-page .lp-platform-step:nth-child(even) .lp-platform-step__copy {
        grid-column: 2;
    }

    body.v3.landing-page .lp-platform-step:nth-child(even) .lp-platform-shot {
        grid-column: 1;
        grid-row: 1;
    }
}
@media (max-width: 575.98px) {
    body.v3.landing-page .lp-platform {
        padding-top: 64px;
        padding-bottom: 64px;
    }

    body.v3.landing-page .lp-platform__head {
        margin-bottom: 32px;
    }

    body.v3.landing-page .lp-platform-step {
        border-radius: 18px;
    }

    body.v3.landing-page .lp-platform-shot__img {
        aspect-ratio: 9 / 16;
    }
}

@media (prefers-reduced-motion: reduce) {
    body.v3.landing-page .lp-fan__card {
        transition: none;
    }
}


/* Card request list chrome */
/* ===== Quick-filter pills (V3 requests list) ===== */
body.v3 .filter-pills {
    display: flex;
    flex-wrap: wrap;
    gap: 6px;
    align-items: center;
    margin-bottom: 16px;
}
body.v3 .filter-pills-label {
    font-size: 11px;
    font-weight: 700;
    color: var(--fg-3);
    text-transform: uppercase;
    letter-spacing: 0.1em;
    margin-right: 4px;
    flex-shrink: 0;
}
body.v3 .filter-pill {
    display: inline-flex;
    align-items: center;
    gap: 4px;
    padding: 5px 12px;
    font-size: 12px;
    font-weight: 600;
    border-radius: 8px;
    border: 1px solid var(--border-2);
    background: transparent;
    color: var(--fg-2);
    text-decoration: none;
    cursor: pointer;
    transition:
        background 0.12s,
        color 0.12s,
        border-color 0.12s;
    white-space: nowrap;
}
body.v3 .filter-pill:hover {
    background: var(--bg-3);
    color: var(--fg);
    border-color: var(--border-strong);
}
body.v3 .filter-pill.active {
    background: var(--accent-soft);
    color: var(--accent);
    border-color: var(--accent-line);
}
body.v3 .filter-pills-search {
    display: flex;
    align-items: center;
    gap: 8px;
    background: var(--bg-input);
    border: 1px solid var(--border-2);
    border-radius: 8px;
    padding: 0 12px;
}
body.v3 .filter-pills-search input {
    background: transparent;
    border: 0;
    padding: 8px 0;
    font-size: 13px;
    color: var(--fg);
    outline: none;
    flex: 1 1 auto;
    width: 100%;
    min-width: 0;
}
/* Compact search in horizontal pill bars (not adv/report filter panels). */
body.v3 .filter-pills > .filter-pills__end > .filter-pills-search:not(.report-filter-search),
body.v3 .filter-pills__search-form > .filter-pills-search {
    flex: 0 1 220px;
    width: 220px;
    max-width: 100%;
}
body.v3 .filter-pills-search input::placeholder {
    color: var(--fg-4);
}
body.v3 .filter-pills-search:focus-within {
    border-color: var(--accent);
    box-shadow: 0 0 0 3px var(--accent-soft);
}
body.v3 .filter-pills-adv-btn.active {
    background: var(--accent-soft);
    color: var(--accent);
    border-color: var(--accent-line);
}
body.v3 .filter-pills__end {
    margin-left: auto;
    display: flex;
    gap: 8px;
    align-items: center;
    flex-shrink: 0;
}
body.v3 .filter-pills__search-form {
    display: flex;
    align-items: center;
    min-width: 0;
}
@media (max-width: 991.98px) {
    body.v3 .filter-pills {
        gap: 4px;
    }
    body.v3 .filter-pills > .filter-pills__end > .filter-pills-search:not(.report-filter-search),
    body.v3 .filter-pills__search-form > .filter-pills-search {
        flex: 1 1 auto;
        width: 100%;
    }
    body.v3 .filter-pills-label {
        display: none;
    }
    body.v3 .filter-pills__end {
        margin-left: 0;
        flex-basis: 100%;
        width: 100%;
        margin-top: 6px;
        padding-top: 8px;
        border-top: 1px solid var(--border);
    }
    body.v3 .filter-pills__search-form {
        flex: 1;
        min-width: 0;
    }
    body.v3 .filter-pills__end .filter-pills-search {
        flex: 1;
        min-width: 0;
    }
    body.v3 .filter-pills__end .filter-pills-search input {
        width: 100%;
        min-width: 0;
    }
}

/* Card request list */
body.v3 .app-request-mobile-card {
    border-radius: 14px;
}
body.v3 .app-request-mobile-card--done {
    opacity: 0.88;
    border-color: rgba(74, 222, 128, 0.28);
}
body.v3 .app-request-mobile-card__layout {
    display: flex;
    align-items: flex-start;
    gap: 12px;
}
body.v3 .app-request-mobile-card__body {
    min-width: 0;
    flex: 1 1 auto;
}
body.v3 .app-request-mobile-card__head {
    display: flex;
    flex-wrap: nowrap;
    align-items: flex-start;
    gap: 8px;
    margin-bottom: 8px;
}
body.v3 .app-request-mobile-card__head-main {
    min-width: 0;
    flex: 1 1 auto;
}
body.v3 .app-request-mobile-card__head-actions {
    flex-shrink: 0;
}
body.v3 .app-request-mobile-card__title {
    margin: 0;
    color: var(--fg);
    font-size: 1rem;
    font-weight: 600;
    line-height: 1.25;
    word-break: break-word;
    overflow-wrap: anywhere;
}
body.v3 .app-request-mobile-card__customer {
    font-size: 12px;
    margin-bottom: 8px;
    color: var(--fg-3);
}
body.v3 .app-request-mobile-card__customer-link {
    margin-left: 4px;
    font-weight: 600;
    color: var(--fg);
    text-decoration: none;
}
body.v3 .app-request-mobile-card__customer-link:hover {
    text-decoration: underline;
}
body.v3 .app-request-mobile-card__meta {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    gap: 8px;
    margin-bottom: 8px;
    font-size: 12px;
    color: var(--fg-3);
}
body.v3 .app-request-mobile-card__meta-remaining {
    font-weight: 600;
    color: var(--accent);
}
body.v3 .app-request-mobile-card__meta-remaining--fulfilled {
    color: var(--success);
}
body.v3 .app-request-mobile-card__badges {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    gap: 8px;
    margin-bottom: 12px;
}
body.v3 .app-request-mobile-card__stats {
    display: flex;
    flex-wrap: wrap;
    gap: 12px;
    margin-bottom: 8px;
    font-size: 12px;
    color: var(--fg-3);
}
body.v3 .app-request-mobile-card__stats .badge {
    align-self: flex-start;
}
body.v3 .app-request-table-card__layout {
    display: flex;
    align-items: flex-start;
    gap: 8px;
}
body.v3 .app-request-table-card__main {
    min-width: 0;
    flex: 1 1 auto;
}
body.v3 .app-request-table-card__name-row {
    display: flex;
    align-items: center;
    flex-wrap: wrap;
    gap: 4px;
    margin-bottom: 2px;
}
body.v3 .app-request-table-card__name {
    font-weight: 600;
    font-size: 0.875rem;
    color: var(--text-primary);
}
body.v3 .app-request-table-card__set-chip {
    background: var(--bg-elevated);
    border: 1px solid var(--border);
    border-radius: 4px;
    padding: 1px 6px;
    font-size: 0.68rem;
    color: var(--text-muted);
    font-weight: 600;
    letter-spacing: 0.04em;
}
body.v3.picklist-mode-active {
    background: #04040a;
}

body.v3.picklist-mode-active .shell-content {
    margin-left: 0 !important;
    padding: 0 !important;
    width: 100% !important;
    max-width: 100% !important;
}

body.v3.picklist-mode-active .content {
    padding: 0;
    gap: 0;
}

body.v3 .picklist-mutation-error {
    margin-bottom: 12px;
}

body.v3 .picklist-mutation-error[hidden] {
    display: none !important;
}

body.v3 .picklist-container {
    width: 100%;
    max-width: 640px;
    margin: 0 auto;
    padding: 12px;
    display: flex;
    flex-direction: column;
    gap: 12px;
    min-height: 100vh;
    box-sizing: border-box;
}

@media (min-width: 480px) {
    body.v3 .picklist-container {
        padding: 16px;
        gap: 16px;
    }
}

body.v3 .picklist-header {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 10px;
    padding-bottom: 10px;
    border-bottom: 1px solid var(--border-2);
}

body.v3 .picklist-header__exit {
    flex-shrink: 0;
    min-height: 44px;
    padding-inline: 10px;
    white-space: nowrap;
}

body.v3 .picklist-header__counter {
    font-size: 0.8rem;
    color: var(--fg-2);
    text-align: right;
    min-width: 0;
}

body.v3 .picklist-header__counter strong {
    color: var(--accent);
}

@media (max-width: 380px) {
    body.v3 .picklist-header__exit-label {
        display: none;
    }

    body.v3 .picklist-header__counter {
        font-size: 0.75rem;
    }
}

body.v3 .picklist-search-container {
    position: sticky;
    top: 0;
    z-index: 100;
    background: #04040a;
    padding: 8px 0;
}

body.v3 .picklist-search-field {
    position: relative;
    display: flex;
    align-items: center;
}

body.v3 .picklist-search-icon {
    position: absolute;
    left: 14px;
    color: var(--fg-3);
    display: flex;
    align-items: center;
    pointer-events: none;
}

body.v3 .picklist-search-input {
    width: 100%;
    padding: 14px 14px 14px 40px;
    font-size: 1rem;
    border-radius: 12px;
    background: var(--bg-input);
    border: 1px solid var(--border-strong);
    color: var(--fg);
    transition: border-color 0.2s, box-shadow 0.2s;
}

body.v3 .picklist-search-input:focus {
    border-color: var(--accent);
    box-shadow: 0 0 0 3px var(--accent-soft);
    outline: none;
}

body.v3 .picklist-items-list {
    display: flex;
    flex-direction: column;
    gap: 14px;
}

body.v3 .picklist-row {
    border-radius: 14px;
    border: 1px solid var(--border-2);
    padding: 10px;
    transition: transform 0.2s, border-color 0.2s, opacity 0.3s ease-out;
}

@media (min-width: 480px) {
    body.v3 .picklist-row {
        padding: 14px;
        border-radius: 16px;
    }
}

body.v3 .picklist-row:hover {
    border-color: var(--border-strong);
}

body.v3 .picklist-row--fulfilled {
    opacity: 0.4;
    transform: scale(0.98);
}

/* Mobile-first: thumb left, content right (same on all breakpoints) */
body.v3 .picklist-row__main {
    display: flex;
    align-items: flex-start;
    gap: 10px;
}

body.v3 .picklist-row__art-col {
    flex-shrink: 0;
}

body.v3 .picklist-row__art-col .card-thumb-zoom,
body.v3 .picklist-row__art-col .card-thumb--no-art {
    --d-thumb: 46px;
    --d-thumb-h: 64px;
}

@media (min-width: 480px) {
    body.v3 .picklist-row__art-col .card-thumb-zoom,
    body.v3 .picklist-row__art-col .card-thumb--no-art {
        --d-thumb: 56px;
        --d-thumb-h: 78px;
    }
}

body.v3 .picklist-row__body {
    flex: 1;
    min-width: 0;
    display: flex;
    flex-direction: column;
    gap: 6px;
}

body.v3 .picklist-row__header {
    display: flex;
    align-items: flex-start;
    gap: 8px;
}

body.v3 .picklist-row__header > div:first-child {
    min-width: 0;
    flex: 1;
}

body.v3 .picklist-row__priority {
    flex-shrink: 0;
    line-height: 1;
}

body.v3 .picklist-row__title {
    margin: 0 0 2px;
    font-size: 0.95rem;
    font-weight: 700;
    color: var(--fg);
    line-height: 1.25;
    overflow: hidden;
    display: -webkit-box;
    -webkit-box-orient: vertical;
    -webkit-line-clamp: 2;
}

@media (min-width: 480px) {
    body.v3 .picklist-row__title {
        font-size: 1.05rem;
    }
}

body.v3 .picklist-row__subtitle {
    display: flex;
    align-items: center;
    gap: 5px;
    min-width: 0;
    font-size: 0.72rem;
    color: var(--fg-3);
}

body.v3 .picklist-row__set-badge {
    flex-shrink: 0;
    font-size: 0.62rem;
    font-weight: 700;
}

body.v3 .picklist-row__set-name {
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
    min-width: 0;
}

@media (max-width: 400px) {
    body.v3 .picklist-row__set-name {
        display: none;
    }
}

body.v3 .picklist-row__meta {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    gap: 4px 6px;
    font-size: 0.78rem;
    color: var(--fg-2);
    line-height: 1.3;
}

body.v3 .picklist-row__customer-name {
    font-weight: 600;
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
    max-width: 100%;
}

body.v3 .picklist-row__meta-sep {
    color: var(--fg-3);
    flex-shrink: 0;
}

body.v3 .picklist-row__qty-summary {
    flex-shrink: 0;
    white-space: nowrap;
}

body.v3 .picklist-row__lines {
    display: flex;
    flex-direction: column;
    gap: 6px;
    margin-top: 2px;
}

body.v3 .picklist-line {
    display: grid;
    grid-template-columns: minmax(0, 1fr) auto;
    align-items: center;
    gap: 8px;
    padding: 6px 8px;
    background: var(--bg-3);
    border-radius: 10px;
    border: 1px solid var(--border);
}

body.v3 .picklist-line__specs {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    gap: 4px;
    min-width: 0;
}

body.v3 .picklist-line__specs .badge {
    font-size: 0.62rem;
    padding: 2px 5px;
    line-height: 1.3;
    white-space: nowrap;
}

body.v3 .picklist-line__qty-badge {
    font-size: 0.68rem;
    font-weight: 800;
    background: var(--bg-4);
    color: var(--accent-2);
}

body.v3 .picklist-line__cond-badge {
    flex-shrink: 0;
    width: fit-content;
    max-width: none;
}

body.v3 .picklist-line__actions {
    flex-shrink: 0;
}

body.v3 .picklist-line__actions form {
    display: flex;
}

body.v3 .picklist-row__actions-footer {
    display: flex;
    gap: 8px;
    margin-top: 4px;
}

body.v3 .picklist-row__actions-footer-forms {
    flex: 2;
    min-width: 0;
}

body.v3 .picklist-row__actions-footer-forms form {
    display: flex;
}

body.v3 .picklist-row__actions-footer-forms .btn-picklist-action {
    width: 100%;
}

/* Mega actions styling */
body.v3 .btn-picklist-action {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: 5px;
    padding: 10px 12px;
    font-size: 0.8rem;
    font-weight: 600;
    border-radius: 10px;
    border: none;
    cursor: pointer;
    transition: background-color 0.15s, border-color 0.15s, transform 0.1s;
    min-height: 44px;
    min-width: 44px;
    box-sizing: border-box;
}

@media (max-width: 400px) {
    body.v3 .picklist-line .btn-picklist-action--success {
        padding-inline: 10px;
    }

    body.v3 .picklist-line .btn-picklist-action--success .btn-picklist-action__label {
        display: none;
    }
}

body.v3 .btn-picklist-action:active {
    transform: scale(0.98);
}

body.v3 .btn-picklist-action--success {
    background: var(--success-soft);
    color: var(--success);
    border: 1px solid rgba(74, 222, 128, 0.3);
}

body.v3 .btn-picklist-action--success:hover {
    background: rgba(74, 222, 128, 0.2);
    border-color: var(--success);
}

body.v3 .btn-picklist-action--success-all {
    background: var(--success);
    color: #05050a;
    flex: 2;
    font-weight: 700;
}

body.v3 .btn-picklist-action--success-all:hover {
    filter: brightness(1.08);
}

body.v3 .btn-picklist-action--detail {
    background: var(--bg-4);
    color: var(--fg-2);
    border: 1px solid var(--border-strong);
    flex: 1;
}

body.v3 .btn-picklist-action--detail:hover {
    background: var(--bg-3);
    color: var(--fg);
}
