/* NightVenture — Inventaire / Marchand UI commun
   Source canonique pour grille, toolbar, filtres, pagination, popups et actions partagées. */

/* Fenêtre / panneaux */
.nvi-window {
    display: flex;
    flex-direction: column;
    gap: 12px;
}

.nvi-panel,
.nvi-details {
    border: 1px solid rgba(255, 255, 255, 0.08);
    border-radius: 16px;
    background: rgba(0, 0, 0, 0.16);
    padding: 12px;
    box-shadow: 0 6px 18px rgba(0, 0, 0, 0.16);
}

.nvi-panel__title {
    display: flex;
    justify-content: space-between;
    align-items: center;
    margin-bottom: 10px;
    color: var(--text-muted, #c7bdad);
}

.nvi-layout {
    display: grid;
    gap: 12px;
    align-items: start;
}

.nvi-layout--inventory,
.nvi-layout--merchant {
    position: relative;
}

.nvi-layout--inventory {
    grid-template-columns: minmax(0, 1fr) minmax(280px, 340px);
}

.nvi-layout--inventory.nvimp-no-details,
.nvi-layout--merchant {
    grid-template-columns: minmax(0, 1fr) !important;
}

.nvi-layout--inventory .nvi-panel__title {
    display: none !important;
    margin: 0 !important;
}

/* Toolbar / header commun */
.nvi-toolbar,
.nvi-filter-toolbar {
    position: relative;
    padding: 12px;
    border: 1px solid rgba(255, 255, 255, 0.08);
    border-radius: 16px;
    background: radial-gradient(circle at top right, rgba(245, 211, 122, 0.055), transparent 42%), rgba(0, 0, 0, 0.18);
}

.nvi-filter-toolbar {
    display: flex !important;
    flex-direction: column !important;
    gap: 10px !important;
}

.nvi-filter-toolbar .nvi-toolbar__top,
.nvi-toolbar__top {
    display: grid !important;
    grid-template-columns: minmax(0, 1fr) auto !important;
    gap: 8px !important;
    align-items: start !important;
    margin-bottom: 0 !important;
}

.nvi-toolbar__title h2,
.nvi-filter-toolbar .nvi-toolbar__title h2,
.nvi-toolbar__top h2 {
    margin: 0 !important;
    font-size: 1.1rem !important;
    line-height: 1.08 !important;
}

.nvi-window .nvi-toolbar .nvi-toolbar__top p,
.nvi-toolbar__title p,
.nvi-toolbar__top p {
    margin: 0;
    color: var(--text-muted, #c7bdad);
    font-size: 0.86rem;
}

.nvi-toolbar--player-header .nvi-toolbar__title p,
.nvi-window .nvi-toolbar--player-header .nvi-toolbar__top p {
    display: none !important;
}

.nvi-toolbar__close {
    display: flex !important;
    justify-content: flex-end !important;
    align-items: flex-start !important;
}

.nvi-close-button,
.nvi-filter-reset {
    width: 32px !important;
    min-width: 32px !important;
    height: 32px !important;
    min-height: 32px !important;
    padding: 0 !important;
    border-radius: 999px !important;
    font-size: 1.08rem !important;
    font-weight: 900 !important;
    line-height: 1 !important;
    display: inline-flex !important;
    align-items: center !important;
    justify-content: center !important;
}

.nvi-filter-reset.is-hidden {
    display: none !important;
}

.nvi-filter-toolbar .nvi-toolbar__action-row {
    order: 2 !important;
    display: flex !important;
    align-items: center !important;
    justify-content: space-between !important;
    gap: 8px !important;
    width: 100% !important;
}

.nvi-filter-toolbar .nvi-toolbar__primary-actions,
.nvi-filter-toolbar .nvi-toolbar__filter-actions,
.nvi-toolbar__actions {
    display: flex !important;
    align-items: center !important;
    gap: 6px !important;
    min-width: 0 !important;
}

.nvi-filter-toolbar .nvi-toolbar__filter-actions {
    margin-left: auto !important;
}

.nvi-toolbar-action,
.nvi-filter-toggle,
.nvimp-toolbar-toggle {
    width: auto !important;
    min-width: auto !important;
    min-height: 32px !important;
    padding: 7px 12px !important;
    border-radius: 999px !important;
    font-size: 0.78rem !important;
    font-weight: 850 !important;
    line-height: 1.1 !important;
    opacity: 0.84 !important;
    background: rgba(0, 0, 0, 0.18);
    display: inline-flex !important;
    align-items: center !important;
    justify-content: center !important;
}

.nvi-toolbar-action:hover,
.nvi-filter-toggle:hover,
.nvimp-toolbar-toggle:hover {
    opacity: 1 !important;
}

.nvi-toolbar-action::before,
.nvi-toolbar-action::after,
.nvi-filter-toggle::before,
.nvi-filter-toggle::after,
.nvimp-toolbar-toggle::before,
.nvimp-toolbar-toggle::after {
    content: none !important;
    display: none !important;
}

.nvi-filter-toolbar.is-expanded .nvi-filter-toggle,
.nvi-filter-toolbar.is-expanded .nvimp-toolbar-toggle,
.nvi-filter-toggle.is-active,
.nvimp-toolbar-toggle.is-active {
    border-color: rgba(245, 211, 122, 0.72) !important;
    color: #f5d37a !important;
    box-shadow: 0 0 12px rgba(245, 211, 122, 0.18) !important;
    opacity: 1 !important;
}

/* Filtres / recherche / tri */
.nvi-filter-toolbar .nvi-toolbar__filters-panel,
.nvi-toolbar__filters-panel {
    order: 3 !important;
    width: 100% !important;
    box-sizing: border-box !important;
    margin: 0 !important;
    padding: 10px !important;
    border: 1px solid rgba(255, 255, 255, 0.08) !important;
    border-radius: 14px !important;
    background: rgba(0, 0, 0, 0.18) !important;
}

.nvi-toolbar__filters-panel:not(.is-open),
.nvimp-toolbar-compact:not(.is-expanded) .nvi-toolbar__search-row,
.nvimp-toolbar-compact:not(.is-expanded) .nvi-filters {
    display: none !important;
}

.nvi-toolbar__filters-panel.is-open {
    display: block !important;
}

.nvi-toolbar__filters-panel.is-open .nvi-toolbar__search-row,
.nvi-toolbar__search-row {
    display: grid !important;
    grid-template-columns: minmax(150px, 1fr) minmax(120px, 170px) 34px !important;
    gap: 8px !important;
    margin: 0 0 10px !important;
    align-items: center !important;
}

.nvi-toolbar__search-row input,
.nvi-toolbar__search-row select {
    width: 100%;
    min-height: 34px;
    box-sizing: border-box;
    border-radius: 999px;
    border: 1px solid rgba(255, 255, 255, 0.10);
    background: rgba(0, 0, 0, 0.24);
    color: var(--text, #f1eadf);
    padding: 7px 10px;
    outline: none;
}

.nvi-sort-direction {
    width: 34px !important;
    min-width: 34px !important;
    height: 34px !important;
    min-height: 34px !important;
    padding: 0 !important;
    border-radius: 999px !important;
    font-size: 1rem !important;
    font-weight: 900 !important;
    line-height: 1 !important;
    display: inline-flex !important;
    align-items: center !important;
    justify-content: center !important;
}

.nvi-filters,
.nvi-toolbar__filters-panel.is-open .nvi-filters {
    display: grid !important;
    grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
    gap: 6px !important;
    max-height: 31dvh !important;
    overflow: auto !important;
    padding-top: 0 !important;
}

.nvi-filter {
    width: 100% !important;
    min-height: 32px !important;
    padding: 6px 9px;
    border-radius: 999px;
    font-size: 0.78rem;
}

.nvi-filter[data-etat="actif"] {
    border-color: rgba(80, 220, 130, 0.38);
    color: #9dffb8;
    box-shadow: 0 0 10px rgba(80, 220, 130, 0.10);
}

.nvi-filter[data-etat="exclu"] {
    border-color: rgba(255, 100, 100, 0.34);
    color: #ffb4b4;
    opacity: 0.72;
}

/* Grilles */
.nvi-grid {
    display: grid;
    grid-template-columns: repeat(var(--nvi-columns), minmax(34px, 1fr));
    gap: 5px;
}

.nvi-layout--inventory .nvi-grid--inventory,
.nvi-layout--merchant .nvi-grid--merchant {
    grid-template-columns: repeat(5, minmax(0, 1fr)) !important;
    gap: 6px !important;
    touch-action: manipulation;
}

.nvi-slot {
    position: relative;
    aspect-ratio: 1 / 1;
    min-height: 58px !important;
    border: 1px solid rgba(255, 255, 255, 0.08);
    border-radius: 12px !important;
    background: rgba(0, 0, 0, 0.24);
    overflow: hidden;
    pointer-events: auto !important;
}

.nvi-slot--locked {
    border-color: rgba(245, 211, 122, 0.36);
}

.nvi-slot--filtered {
    opacity: 0.38;
}

.nvi-slot.nvimp-touch-target {
    border-color: rgba(245, 211, 122, 0.70) !important;
    box-shadow: 0 0 14px rgba(245, 211, 122, 0.16) !important;
}

.nvi-item {
    position: relative;
    width: 100%;
    height: 100%;
    padding: 0;
    border: none;
    border-radius: 11px !important;
    display: flex;
    align-items: center;
    justify-content: center;
    background: linear-gradient(180deg, rgba(255, 255, 255, 0.08), rgba(0, 0, 0, 0.20));
    color: var(--text, #f1eadf);
    cursor: pointer;
    overflow: hidden;
    touch-action: none;
    user-select: none;
    -webkit-user-select: none;
    -webkit-user-drag: none;
}

.nvi-item *,
.nvi-item img {
    pointer-events: none;
    -webkit-user-drag: none;
    user-drag: none;
}

.nvi-item--locked {
    filter: saturate(0.85);
}

.nvi-item.nvimp-moving {
    outline: 2px solid #f5d37a !important;
    outline-offset: -2px;
    filter: brightness(1.08);
    opacity: 0.34;
}

.nvi-item:focus,
.nvi-item:focus-visible,
.nvi-item:active,
.nvi-item.nvimp-item--popup-open,
.nvi-item.nvimp-item--popup-open:not(.nvimp-moving) {
    outline: 0 !important;
    outline-offset: 0 !important;
    box-shadow: none !important;
    transform: none !important;
    -webkit-tap-highlight-color: transparent !important;
}

.nvi-item.nvimp-item--popup-open::before,
.nvi-item.nvimp-item--popup-open::after {
    display: none !important;
    content: none !important;
}

.nvi-item__icon img {
    width: 86% !important;
    height: 86% !important;
    object-fit: contain;
    display: block;
}

.nvi-item__text-icon {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 100%;
    height: 100%;
    font-size: 0.72rem !important;
    font-weight: 800;
    letter-spacing: 0.02em;
    color: var(--gold, #f5d37a);
}

.nvi-item__favorite,
.nvi-item__lock,
.nvi-item__qty {
    position: absolute;
    z-index: 2;
    padding: 1px 3px !important;
    border-radius: 999px;
    background: rgba(0, 0, 0, 0.72);
    color: var(--gold, #f5d37a);
    font-size: 0.52rem !important;
    line-height: 1.2;
}

.nvi-item__favorite {
    left: 2px;
    top: 2px;
}

.nvi-item__lock {
    right: 2px;
    top: 2px;
}

.nvi-item__qty {
    right: 2px;
    bottom: 2px;
    color: #fff;
}

/* Pagination commune */
.nvi-pager,
.nvimp-pager,
.nvimp-popup-pager {
    display: flex !important;
    flex-wrap: wrap !important;
    gap: 6px !important;
    align-items: center !important;
    justify-content: center !important;
}

.nvi-pager,
.nvimp-pager {
    margin: 8px 0 10px !important;
}

.nvimp-popup-pager {
    margin-top: 10px;
    padding-top: 8px;
    border-top: 1px solid rgba(255, 255, 255, 0.10);
}

.nvimp-popup-pager__label {
    width: 100%;
    color: var(--text-muted, #c7bdad);
    font-size: 0.68rem;
    font-weight: 900;
    letter-spacing: 0.04em;
    text-align: center;
    text-transform: uppercase;
}

.nvi-page-btn,
.nvimp-page-btn {
    width: 36px !important;
    min-width: 36px !important;
    max-width: 36px !important;
    min-height: 30px !important;
    padding: 4px 0 !important;
    border-radius: 999px !important;
    font-size: 0.74rem !important;
    font-weight: 900 !important;
    line-height: 1 !important;
}

.nvi-page-btn.is-active,
.nvimp-page-btn.is-active {
    border-color: rgba(245, 211, 122, 0.65) !important;
    color: #f5d37a !important;
    box-shadow: 0 0 12px rgba(245, 211, 122, 0.18) !important;
}

/* Popups inventaire / commerce */
.nvi-details {
    position: sticky;
    top: 10px;
}

.nvi-details.nvimp-details-popup.nvipr-popup {
    position: fixed !important;
    left: max(10px, env(safe-area-inset-left)) !important;
    right: max(10px, env(safe-area-inset-right)) !important;
    top: calc(12px + env(safe-area-inset-top)) !important;
    bottom: auto !important;
    z-index: 1200 !important;
    width: auto !important;
    height: auto !important;
    max-height: none !important;
    overflow: visible !important;
    margin: 0 !important;
    padding: 12px !important;
    border-radius: 18px !important;
    background: rgba(12, 10, 9, 0.96) !important;
    border: 1px solid rgba(245, 211, 122, 0.16) !important;
    box-shadow: 0 18px 44px rgba(0, 0, 0, 0.58) !important;
    backdrop-filter: blur(5px) !important;
    -webkit-backdrop-filter: blur(5px) !important;
    opacity: 1 !important;
    pointer-events: auto !important;
}

.nvi-details.nvimp-details-popup.nvipr-popup .nvimp-popup-close {
    position: absolute !important;
    top: 8px !important;
    right: 8px !important;
    width: 28px !important;
    min-width: 28px !important;
    max-width: 28px !important;
    height: 28px !important;
    min-height: 28px !important;
    padding: 0 !important;
    border-radius: 8px !important;
    font-size: 1rem !important;
    font-weight: 900 !important;
    line-height: 1 !important;
    z-index: 3 !important;
}

.nvi-details__header,
.nvi-details.nvimp-details-popup.nvipr-popup .nvi-details__header {
    display: grid !important;
    grid-template-columns: 54px minmax(0, 1fr) !important;
    gap: 10px !important;
    align-items: center !important;
    min-height: 56px !important;
    margin: 0 36px 10px 0 !important;
    padding: 0 !important;
}

.nvi-details__icon,
.nvi-details.nvimp-details-popup.nvipr-popup .nvi-details__icon {
    width: 54px !important;
    height: 54px !important;
    border: 1px solid rgba(255, 255, 255, 0.10);
    border-radius: 13px !important;
    display: flex;
    align-items: center;
    justify-content: center;
    background: rgba(0, 0, 0, 0.22);
}

.nvi-details__icon img {
    width: 84%;
    height: 84%;
    object-fit: contain;
}

.nvi-details__header h3 {
    margin: 0 !important;
    font-size: 0.94rem !important;
    line-height: 1.1 !important;
    white-space: nowrap !important;
    overflow: hidden !important;
    text-overflow: ellipsis !important;
}

.nvi-details__header p {
    margin: 0 !important;
    color: #c7bdad !important;
    font-size: 0.72rem !important;
    font-weight: 850 !important;
    line-height: 1.18 !important;
}

.nvipr-meta-line {
    display: block !important;
}

.nvi-details__description {
    margin: 8px 0 10px !important;
    color: #d3cabd !important;
    font-size: 0.78rem !important;
    line-height: 1.34 !important;
}

.nvi-details__stats {
    display: block !important;
    margin: 8px 0 !important;
    padding: 8px 9px !important;
    border-radius: 12px !important;
    background: rgba(245, 211, 122, 0.08) !important;
    border: 1px solid rgba(245, 211, 122, 0.12) !important;
    color: #f5d37a !important;
    font-size: 0.78rem !important;
    font-weight: 850 !important;
    line-height: 1.32 !important;
}

.nvi-details__actions,
.nvi-delete-confirm {
    display: grid !important;
    grid-template-columns: 1fr !important;
    gap: 8px !important;
    margin: 8px 0 0 !important;
    padding: 0 !important;
    border: 0 !important;
}

.nvi-details__actions button:not(.nvipr-secondary-action) {
    width: 100% !important;
    min-height: 34px !important;
    padding: 7px 10px !important;
    border-radius: 11px !important;
    font-size: 0.76rem !important;
    font-weight: 900 !important;
}

.nvipr-secondary-row {
    display: grid !important;
    grid-template-columns: 1fr 1fr !important;
    gap: 8px !important;
    margin-top: 8px !important;
}

.nvipr-secondary-row button,
.nvipr-secondary-row .nvi-lock-toggle {
    width: 100% !important;
    min-height: 31px !important;
    padding: 6px 8px !important;
    border-radius: 10px !important;
    font-size: 0.72rem !important;
    font-weight: 850 !important;
    line-height: 1.05 !important;
    margin: 0 !important;
}

.nvi-lock-toggle {
    display: flex;
    gap: 6px;
    align-items: center;
    margin-top: 8px;
}

.nvi-lock-toggle__icon {
    display: none !important;
}

.nvi-danger {
    display: block !important;
    width: 100% !important;
    min-height: 32px !important;
    margin: 8px 0 0 !important;
    padding: 6px 10px !important;
    border-radius: 10px !important;
    border-color: rgba(255, 90, 90, 0.52) !important;
    background: rgba(145, 28, 28, 0.58) !important;
    color: #ffd6d6 !important;
    font-size: 0.74rem !important;
    font-weight: 900 !important;
}

.nvi-delete-confirm {
    grid-template-columns: 1fr 1fr !important;
}

.nvi-delete-confirm span {
    grid-column: 1 / -1 !important;
    font-size: 0.76rem !important;
    color: #ffd6d6 !important;
    text-align: center !important;
}

/* Drag / footer */
.nvimp-drag-ghost {
    position: fixed !important;
    left: 0 !important;
    top: 0 !important;
    z-index: 999999 !important;
    pointer-events: none !important;
    opacity: 0;
    border-radius: 12px !important;
    transform-origin: center center !important;
    will-change: transform !important;
    filter: none !important;
    box-shadow: none !important;
    background: rgba(28, 24, 20, 0.96) !important;
    border: 1px solid rgba(245, 211, 122, 0.45) !important;
    contain: layout style paint !important;
    display: flex !important;
    align-items: center !important;
    justify-content: center !important;
}

.nvimp-drag-ghost.is-visible {
    opacity: 0.98 !important;
}

.nvimp-drag-ghost * {
    pointer-events: none !important;
    transition: none !important;
    animation: none !important;
}

.nvimp-grid-footer {
    display: flex;
    justify-content: flex-start;
    align-items: center;
    margin-top: 8px;
    min-height: 24px;
}

.nvimp-gold {
    display: inline-flex;
    align-items: center;
    justify-content: flex-start;
    min-height: 24px;
    padding: 4px 10px;
    border: 1px solid rgba(245, 211, 122, 0.22);
    border-radius: 999px;
    background: rgba(0, 0, 0, 0.18);
    color: #f5d37a;
    font-size: 0.78rem;
    font-weight: 900;
    letter-spacing: 0.02em;
}

/* Touch / responsive */
.nvi-layout--inventory,
.nvi-layout--inventory *,
.nvi-details.nvipr-popup,
.nvi-details.nvipr-popup * {
    -webkit-tap-highlight-color: transparent !important;
    -webkit-touch-callout: none !important;
}

.nvi-layout--inventory .nvi-item,
.nvi-details.nvipr-popup button {
    outline: none !important;
    -webkit-tap-highlight-color: transparent !important;
    -webkit-touch-callout: none !important;
    touch-action: none !important;
    user-select: none !important;
    -webkit-user-select: none !important;
    caret-color: transparent !important;
}

@media (min-width: 720px) {
    .nvi-details.nvimp-details-popup.nvipr-popup {
        left: 50% !important;
        right: auto !important;
        width: min(430px, calc(100vw - 24px)) !important;
        transform: translateX(-50%) !important;
    }
}

@media (max-width: 900px) {
    .nvi-layout,
    .nvi-layout--inventory {
        grid-template-columns: 1fr !important;
    }

    .nvi-details {
        position: static;
    }

    .nvi-toolbar__filters-panel.is-open .nvi-toolbar__search-row {
        grid-template-columns: minmax(0, 1fr) 34px !important;
    }

    .nvi-toolbar__filters-panel.is-open .nvi-toolbar__search-row input {
        grid-column: 1 / -1 !important;
    }

    .nvi-toolbar__search-row select {
        min-width: 0 !important;
    }

    .nvi-toolbar-action,
    .nvi-filter-toggle,
    .nvimp-toolbar-toggle {
        padding-left: 10px !important;
        padding-right: 10px !important;
        font-size: 0.76rem !important;
    }
}

@media (max-width: 380px) {
    .nvi-slot {
        min-height: 52px !important;
    }

    .nvi-grid--inventory,
    .nvi-grid--merchant {
        gap: 5px !important;
    }

    .nvi-page-btn,
    .nvimp-page-btn {
        width: 32px !important;
        min-width: 32px !important;
        max-width: 32px !important;
        min-height: 28px !important;
        font-size: 0.68rem !important;
    }
}