/* SalBazaar Listings CSS
 * Product grid, listing detail, search
 */

/* Listing Grid */
.listing-grid {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(260px, 1fr));
    gap: var(--space-md);
}

/* Listing Card */
.listing-card {
    background-color: var(--bg-dark);
    border: var(--border);
    transition: border-color var(--transition-fast);
}

.listing-card:hover {
    border-color: var(--text-secondary);
}

.listing-card-link {
    display: block;
    color: inherit;
    text-decoration: none;
}

.listing-image {
    position: relative;
    aspect-ratio: 4/3;
    overflow: hidden;
    background-color: var(--bg-medium);
}

.listing-image img {
    width: 100%;
    height: 100%;
    object-fit: cover;
}

.listing-image-placeholder {
    display: flex;
    align-items: center;
    justify-content: center;
    width: 100%;
    height: 100%;
    color: var(--text-muted);
}

.listing-badges {
    position: absolute;
    top: var(--space-sm);
    left: var(--space-sm);
    display: flex;
    flex-direction: column;
    gap: var(--space-xs);
    z-index: 1;
}

.listing-badge {
    padding: var(--space-xs) var(--space-sm);
    font-size: var(--text-xs);
    font-weight: 500;
    background-color: var(--bg-dark);
    border: var(--border);
}

.listing-badge-digital {
    color: var(--info);
    border-color: var(--info);
}

.listing-badge-escrow {
    color: var(--success);
    border-color: var(--success);
}

.listing-badge-sold {
    color: var(--text-muted);
    border-color: var(--text-muted);
}

.listing-body {
    padding: var(--space-md);
}

.listing-title {
    font-size: var(--text-sm);
    font-weight: 500;
    margin-bottom: var(--space-xs);
    line-height: var(--leading-tight);
    display: -webkit-box;
    -webkit-line-clamp: 2;
    -webkit-box-orient: vertical;
    overflow: hidden;
}

.listing-seller {
    font-size: var(--text-xs);
    color: var(--text-secondary);
    margin-bottom: var(--space-sm);
}

.listing-footer {
    display: flex;
    align-items: center;
    justify-content: space-between;
}

.listing-price {
    font-size: var(--text-base);
    font-weight: 600;
    color: var(--accent);
}

.listing-stock {
    font-size: var(--text-xs);
    color: var(--text-muted);
}

.listing-shipping-tag {
    font-size: var(--text-xs);
    color: var(--text-muted);
}

.listing-local-pickup {
    color: var(--warning);
}

.listing-free-shipping {
    color: var(--success);
}

/* Listing Detail Page */
.listing-detail {
    display: grid;
    grid-template-columns: 1fr 380px;
    gap: var(--space-xl);
}

@media (max-width: 767px) {
    .listing-detail {
        grid-template-columns: 1fr;
    }
}

/* Image Gallery */
.listing-gallery {
    display: flex;
    flex-direction: column;
    gap: var(--space-md);
}

.gallery-main {
    aspect-ratio: 4/3;
    background-color: var(--bg-dark);
    border: var(--border);
    overflow: hidden;
}

.gallery-main img {
    width: 100%;
    height: 100%;
    object-fit: contain;
}

.gallery-thumbs {
    display: flex;
    gap: var(--space-sm);
    overflow-x: auto;
}

.gallery-thumb {
    flex-shrink: 0;
    width: 80px;
    height: 60px;
    background-color: var(--bg-dark);
    border: var(--border);
    cursor: pointer;
    overflow: hidden;
    opacity: 0.6;
    transition: opacity var(--transition-fast);
}

.gallery-thumb:hover,
.gallery-thumb.active {
    opacity: 1;
    border-color: var(--primary);
}

.gallery-thumb img {
    width: 100%;
    height: 100%;
    object-fit: cover;
}

/* Listing Info */
.listing-info {
    display: flex;
    flex-direction: column;
    gap: var(--space-md);
}

.listing-info-header {
    padding-bottom: var(--space-md);
    border-bottom: var(--border);
}

.listing-info-title {
    font-size: var(--text-xl);
    font-weight: 600;
    margin-bottom: var(--space-sm);
}

.listing-info-meta {
    display: flex;
    align-items: center;
    gap: var(--space-md);
    font-size: var(--text-sm);
    color: var(--text-secondary);
}

.listing-info-price {
    padding: var(--space-md);
    background-color: var(--bg-dark);
    border: var(--border);
}

.listing-info-price .price {
    font-size: var(--text-2xl);
    display: block;
    margin-bottom: var(--space-sm);
}

.listing-info-stock {
    font-size: var(--text-sm);
    color: var(--text-secondary);
}

.listing-info-stock.low {
    color: var(--warning);
}

.listing-info-stock.out {
    color: var(--danger);
}

/* Shipping Info */
.listing-shipping {
    padding: var(--space-xs) 0;
    font-size: var(--text-sm);
}

.shipping-cost {
    color: var(--text-secondary);
}

.shipping-free {
    color: var(--success);
}

.shipping-local {
    color: var(--warning);
}

/* Buy Section */
.listing-buy {
    padding: var(--space-md);
    background-color: var(--bg-dark);
    border: var(--border);
}

.quantity-select {
    display: flex;
    align-items: center;
    gap: var(--space-sm);
    margin-bottom: var(--space-md);
}

.quantity-select label {
    font-size: var(--text-sm);
    color: var(--text-secondary);
}

.quantity-input {
    display: flex;
    align-items: center;
    border: var(--border);
}

.quantity-btn {
    width: 36px;
    height: 36px;
    display: flex;
    align-items: center;
    justify-content: center;
    background-color: var(--bg-medium);
    border: none;
    color: var(--text-primary);
    cursor: pointer;
}

.quantity-btn:hover {
    background-color: var(--bg-light);
}

.quantity-input input {
    width: 60px;
    height: 36px;
    text-align: center;
    border: none;
    background-color: var(--bg-dark);
    font-size: var(--text-sm);
}

.listing-total {
    display: flex;
    justify-content: space-between;
    align-items: center;
    padding: var(--space-sm) 0;
    margin-bottom: var(--space-md);
    border-top: var(--border);
    border-bottom: var(--border);
}

.listing-total-label {
    font-size: var(--text-sm);
    color: var(--text-secondary);
}

.listing-total-value {
    font-size: var(--text-lg);
    font-weight: 600;
    color: var(--accent);
}

/* Seller Card */
.seller-card {
    padding: var(--space-md);
    background-color: var(--bg-dark);
    border: var(--border);
}

.seller-header {
    display: flex;
    align-items: center;
    gap: var(--space-md);
    margin-bottom: var(--space-md);
}

.seller-avatar {
    width: 48px;
    height: 48px;
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: var(--text-lg);
    font-weight: 600;
    color: var(--bg-darkest);
    background-color: var(--primary);
}

.seller-info {
    flex: 1;
}

.seller-name {
    font-weight: 600;
    margin-bottom: var(--space-xs);
}

.seller-name a {
    color: inherit;
}

.seller-stats {
    font-size: var(--text-xs);
    color: var(--text-secondary);
}

.seller-rating {
    display: flex;
    align-items: center;
    gap: var(--space-xs);
    color: var(--accent);
}

/* Description */
.listing-description {
    padding: var(--space-md);
    background-color: var(--bg-dark);
    border: var(--border);
}

.listing-description h4 {
    font-size: var(--text-sm);
    text-transform: uppercase;
    letter-spacing: 0.05em;
    color: var(--text-secondary);
    margin-bottom: var(--space-md);
}

.listing-description-content {
    font-size: var(--text-sm);
    line-height: var(--leading-relaxed);
    color: var(--text-primary);
    white-space: pre-wrap;
}

/* Search & Filters */
.search-bar {
    display: flex;
    gap: var(--space-sm);
    margin-bottom: var(--space-lg);
}

.search-input-wrapper {
    flex: 1;
    position: relative;
}

.search-input {
    width: 100%;
    padding-left: var(--space-xl);
}

.search-icon {
    position: absolute;
    left: var(--space-sm);
    top: 50%;
    transform: translateY(-50%);
    color: var(--text-muted);
    pointer-events: none;
}

.filters {
    display: flex;
    flex-wrap: wrap;
    gap: var(--space-sm);
    padding: var(--space-md);
    background-color: var(--bg-dark);
    border: var(--border);
    margin-bottom: var(--space-lg);
}

.filter-group {
    display: flex;
    align-items: center;
    gap: var(--space-sm);
}

.filter-label {
    font-size: var(--text-xs);
    color: var(--text-secondary);
    text-transform: uppercase;
    letter-spacing: 0.05em;
}

/* Categories - Flat list (legacy) */
.category-list {
    display: flex;
    flex-direction: column;
    gap: var(--space-xs);
}

.category-item {
    display: flex;
    align-items: center;
    justify-content: space-between;
    padding: var(--space-sm) var(--space-md);
    font-size: var(--text-sm);
    color: var(--text-secondary);
    border: var(--border);
    border-color: transparent;
    transition: all var(--transition-fast);
}

.category-item:hover {
    color: var(--text-primary);
    border-color: var(--border-color);
}

.category-item.active {
    color: var(--primary);
    border-color: var(--primary);
}

.category-count {
    font-size: var(--text-xs);
    color: var(--text-muted);
}

/* Categories - Grid layout (nested) */
.category-grid {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(250px, 1fr));
    gap: var(--space-lg);
}

.category-section {
    background-color: var(--bg-dark);
    border: var(--border);
    padding: var(--space-md);
}

.category-section-title {
    font-size: var(--text-base);
    font-weight: 600;
    margin-bottom: var(--space-sm);
    padding-bottom: var(--space-sm);
    border-bottom: var(--border);
    display: flex;
    justify-content: space-between;
    align-items: center;
}

.category-section-title a {
    color: var(--text-primary);
    text-decoration: none;
}

.category-section-title a:hover {
    color: var(--primary);
}

.category-children {
    list-style: none;
    padding: 0;
    margin: 0;
}

.category-children li {
    display: flex;
    justify-content: space-between;
    padding: var(--space-xs) 0;
}

.category-children a {
    color: var(--text-secondary);
    text-decoration: none;
    font-size: var(--text-sm);
}

.category-children a:hover {
    color: var(--primary);
}

/* Create/Edit Listing Form */
.listing-form {
    max-width: 720px;
}

.image-upload {
    border: var(--border);
    border-style: dashed;
    padding: var(--space-xl);
    text-align: center;
    cursor: pointer;
    transition: border-color var(--transition-fast);
}

.image-upload:hover,
.image-upload.dragover {
    border-color: var(--primary);
    background-color: var(--bg-medium);
}

.image-upload-icon {
    width: 48px;
    height: 48px;
    margin: 0 auto var(--space-md);
    color: var(--text-muted);
}

.image-upload-text {
    font-size: var(--text-sm);
    color: var(--text-secondary);
}

.image-preview-grid {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(120px, 1fr));
    gap: var(--space-md);
    margin-top: var(--space-md);
}

.image-preview {
    position: relative;
    aspect-ratio: 1;
    background-color: var(--bg-medium);
    border: var(--border);
}

.image-preview img {
    width: 100%;
    height: 100%;
    object-fit: cover;
}

.image-preview-remove {
    position: absolute;
    top: var(--space-xs);
    right: var(--space-xs);
    width: 24px;
    height: 24px;
    display: flex;
    align-items: center;
    justify-content: center;
    background-color: var(--danger);
    color: white;
    border: none;
    cursor: pointer;
    font-size: var(--text-lg);
    z-index: 2;
}

.image-preview-featured {
    position: absolute;
    bottom: var(--space-xs);
    left: var(--space-xs);
    width: 28px;
    height: 28px;
    display: flex;
    align-items: center;
    justify-content: center;
    background-color: rgba(0, 0, 0, 0.6);
    color: var(--text-muted);
    border: none;
    border-radius: 4px;
    padding: 0;
    cursor: pointer;
    font-size: var(--text-base);
    z-index: 2;
    transition: color 0.15s, background-color 0.15s;
}

.image-preview-featured:hover {
    color: var(--warning);
}

.image-preview.is-featured {
    border: 2px solid var(--primary);
}

.image-preview.is-featured .image-preview-featured {
    color: var(--warning);
    background-color: rgba(0, 0, 0, 0.7);
}

/* Location Filters */
.location-filters {
    margin-top: calc(-1 * var(--space-lg) + var(--space-xs));
    border-top: none;
}

/* Distance Unit Toggle */
.distance-unit-toggle {
    display: flex;
    border: var(--border);
    overflow: hidden;
}

.distance-unit-toggle .unit-option {
    display: flex;
    align-items: center;
    cursor: pointer;
}

.distance-unit-toggle .unit-option input {
    position: absolute;
    opacity: 0;
    pointer-events: none;
}

.distance-unit-toggle .unit-option span {
    display: block;
    padding: var(--space-sm) var(--space-md);
    font-size: var(--text-sm);
    color: var(--text-secondary);
    background-color: var(--bg-medium);
    border-left: var(--border);
    transition: all var(--transition-fast);
}

.distance-unit-toggle .unit-option:first-child span {
    border-left: none;
}

.distance-unit-toggle .unit-option input:checked + span {
    color: var(--text-primary);
    background-color: var(--primary);
}

.listing-distance {
    font-size: var(--text-xs);
    color: var(--text-muted);
    margin-top: var(--space-xs);
}

.listing-location {
    font-size: var(--text-xs);
    color: var(--text-muted);
}

/* Postal Code Validation Feedback */
.postal-validation {
    font-size: var(--text-xs);
    margin-top: var(--space-xs);
    min-height: 1.2em;
}

.postal-validation.checking {
    color: var(--text-muted);
}

.postal-validation.valid {
    color: var(--success);
}

.postal-validation.invalid {
    color: var(--warning);
}

/* Mobile: Stack location filters vertically */
@media (max-width: 640px) {
    .location-filters .filter-group {
        flex-direction: column;
        align-items: stretch;
        width: 100%;
    }

    .location-filters .filter-group .filter-label {
        margin-bottom: var(--space-xs);
    }

    .location-filters .filter-group select,
    .location-filters .filter-group input {
        width: 100% !important;
    }

    .location-filters .distance-unit-toggle {
        justify-content: center;
        margin-top: var(--space-xs);
    }
}

/* Escrow Option Styles */
.escrow-option,
.upgrade-option {
    background-color: var(--bg-medium);
    padding: var(--space-md);
    border: var(--border);
    margin-top: var(--space-md);
}

.escrow-option .form-check-label,
.upgrade-option .form-check-label {
    display: flex;
    align-items: center;
    gap: var(--space-sm);
    flex-wrap: wrap;
}

.escrow-fee-note {
    font-size: var(--text-xs);
    color: var(--text-muted);
    font-weight: normal;
}

.escrow-option .form-help,
.upgrade-option .form-help {
    margin-top: var(--space-sm);
    margin-bottom: 0;
    font-size: var(--text-sm);
    color: var(--text-secondary);
    line-height: var(--leading-relaxed);
}

.escrow-verification-warning {
    margin-top: var(--space-sm);
    margin-bottom: 0;
    padding: var(--space-sm) var(--space-md);
    font-size: var(--text-sm);
    background-color: rgba(255, 152, 0, 0.1);
    border-left: 3px solid #ff9800;
    color: var(--text-secondary);
}

.escrow-verification-warning strong {
    color: #ff9800;
}

.escrow-verification-warning a {
    color: var(--primary);
}

/* Escrow Badge on Listing Cards and Detail */
.digital-badge {
    display: inline-flex;
    align-items: center;
    padding: var(--space-xs) var(--space-sm);
    background-color: rgba(var(--info-rgb), 0.15);
    color: var(--info);
    font-size: var(--text-xs);
    font-weight: 500;
    border-radius: var(--radius-sm);
}

.escrow-badge {
    display: inline-flex;
    align-items: center;
    gap: var(--space-xs);
    padding: var(--space-xs) var(--space-sm);
    background-color: rgba(var(--success-rgb), 0.15);
    color: var(--success);
    font-size: var(--text-xs);
    font-weight: 500;
    border-radius: var(--radius-sm);
}

.upgraded-badge {
    display: inline-flex;
    align-items: center;
    padding: var(--space-xs) var(--space-sm);
    background-color: rgba(245, 158, 11, 0.15);
    color: var(--accent);
    font-size: var(--text-xs);
    font-weight: 500;
    border-radius: var(--radius-sm);
}

.listing-video {
    position: relative;
    width: 100%;
    padding-bottom: 56.25%;
    margin-top: var(--space-md);
    background: var(--bg-secondary);
    border-radius: var(--radius);
    overflow: hidden;
}

.listing-video iframe {
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
}

.digital-notice {
    display: flex;
    align-items: center;
    gap: var(--space-sm);
    padding: var(--space-sm);
    margin-bottom: var(--space-sm);
    background-color: rgba(var(--info-rgb), 0.1);
    border: 1px solid rgba(var(--info-rgb), 0.25);
    border-radius: var(--radius);
    font-size: var(--text-sm);
    color: var(--text-secondary);
}
.digital-notice .digital-icon {
    flex-shrink: 0;
}

.escrow-notice {
    display: flex;
    align-items: center;
    gap: var(--space-sm);
    padding: var(--space-sm);
    margin-bottom: var(--space-sm);
    background-color: rgba(var(--success-rgb), 0.1);
    border: 1px solid rgba(var(--success-rgb), 0.25);
    border-radius: var(--radius);
    font-size: var(--text-sm);
    color: var(--text-secondary);
}
.escrow-notice .escrow-icon {
    flex-shrink: 0;
}
.escrow-notice a {
    color: var(--success);
    text-decoration: underline;
}

.direct-badge {
    display: inline-flex;
    align-items: center;
    gap: var(--space-xs);
    padding: var(--space-xs) var(--space-sm);
    background-color: var(--bg-medium);
    color: var(--text-secondary);
    font-size: var(--text-xs);
    font-weight: 500;
    border-radius: var(--radius-sm);
}
