﻿/**
 * KASUWA CLASSIFIEDS - Main Stylesheet
 * Modern, responsive design for classified ads platform
 * 
 * @package Kasuwa
 * @version 1.0.0
 */

/* ============================================================================
   CSS VARIABLES (Design Tokens)
   ============================================================================ */
:root {
    /* Colors */
    --color-primary: #2563eb;
    --color-primary-dark: #1d4ed8;
    --color-secondary: #10b981;
    --color-accent: #f59e0b;
    --color-danger: #ef4444;
    --color-success: #22c55e;
    --color-warning: #f59e0b;

    /* Neutrals */
    --color-white: #ffffff;
    --color-gray-50: #f9fafb;
    --color-gray-100: #f3f4f6;
    --color-gray-200: #e5e7eb;
    --color-gray-300: #d1d5db;
    --color-gray-500: #6b7280;
    --color-gray-700: #374151;
    --color-gray-900: #111827;

    /* Typography */
    --font-family: 'Inter', -apple-system, BlinkMacSystemFont, 'Segoe UI', Roboto, sans-serif;
    --font-size-xs: 0.75rem;
    --font-size-sm: 0.875rem;
    --font-size-base: 1rem;
    --font-size-lg: 1.125rem;
    --font-size-xl: 1.25rem;
    --font-size-2xl: 1.5rem;
    --font-size-3xl: 1.875rem;
    --font-size-4xl: 2.25rem;

    /* Spacing */
    --spacing-xs: 0.25rem;
    --spacing-sm: 0.5rem;
    --spacing-md: 1rem;
    --spacing-lg: 1.5rem;
    --spacing-xl: 2rem;
    --spacing-2xl: 3rem;

    /* Borders */
    --border-radius-sm: 0.25rem;
    --border-radius: 0.5rem;
    --border-radius-lg: 0.75rem;
    --border-radius-full: 9999px;

    /* Shadows */
    --shadow-sm: 0 1px 2px rgba(0, 0, 0, 0.05);
    --shadow: 0 1px 3px rgba(0, 0, 0, 0.1), 0 1px 2px rgba(0, 0, 0, 0.06);
    --shadow-md: 0 4px 6px rgba(0, 0, 0, 0.1);
    --shadow-lg: 0 10px 15px rgba(0, 0, 0, 0.1);

    /* Container */
    --container-max: 1200px;
}

/* ============================================================================
   RESET & BASE
   ============================================================================ */
*,
*::before,
*::after {
    box-sizing: border-box;
}

html {
    font-size: 16px;
    scroll-behavior: smooth;
}

body {
    margin: 0;
    font-family: var(--font-family);
    font-size: var(--font-size-base);
    line-height: 1.6;
    color: var(--color-gray-900);
    background-color: var(--color-gray-50);
    min-height: 100vh;
    display: flex;
    flex-direction: column;
}

/* ============================================================================
   Post Ad Page
   ============================================================================ */
.post-ad-page {
    padding: 20px 0;
    background: #f3f5f7;
}

.post-ad-page .container {
    max-width: 820px;
}

.post-ad-card {
    background: #ffffff;
    border-radius: 12px;
    box-shadow: var(--shadow-lg);
    overflow: hidden;
}

.post-ad-progress {
    display: flex;
    justify-content: space-between;
    position: relative;
    padding: 16px 30px;
    background: #f8fafc;
    border-bottom: 1px solid var(--color-gray-200);
}

.post-ad-progress::after {
    content: '';
    position: absolute;
    top: 36px;
    left: 36px;
    right: 36px;
    height: 3px;
    background: var(--color-gray-200);
    z-index: 0;
}

.post-ad-progress .progress-line {
    position: absolute;
    top: 36px;
    left: 36px;
    height: 3px;
    width: 0%;
    background: var(--color-success);
    z-index: 0;
    transition: width 0.3s ease;
}

.progress-step {
    position: relative;
    z-index: 1;
    text-align: center;
}

.progress-dot {
    width: 32px;
    height: 32px;
    border-radius: 999px;
    background: var(--color-gray-200);
    color: #64748b;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    font-weight: 700;
    border: 2px solid #fff;
    margin-bottom: 6px;
    transition: all 0.2s ease;
}

.progress-label {
    font-size: 12px;
    font-weight: 600;
    color: #94a3b8;
}

.progress-step.active .progress-dot,
.progress-step.completed .progress-dot {
    background: var(--color-success);
    color: #fff;
    box-shadow: 0 0 0 4px rgba(34, 197, 94, 0.15);
}

.progress-step.active .progress-label {
    color: var(--color-success);
}

.post-ad-body {
    padding: 24px 30px;
}

.post-step {
    display: none;
}

.post-step.active {
    display: block;
    animation: fadeIn 0.2s ease-in;
}

@keyframes fadeIn {
    from {
        opacity: 0;
        transform: translateY(6px);
    }

    to {
        opacity: 1;
        transform: translateY(0);
    }
}

.post-ad-page h2 {
    margin: 0 0 16px;
    font-size: 20px;
}

.form-grid.two-col {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 16px;
}

.post-ad-page .form-group {
    margin-bottom: 14px;
}

.post-ad-page label {
    display: block;
    font-size: 13px;
    font-weight: 600;
    color: #334155;
    margin-bottom: 8px;
}

.label-note {
    font-weight: 400;
    color: #94a3b8;
    font-size: 12px;
    margin-left: 6px;
}

.post-ad-page input[type="text"],
.post-ad-page input[type="number"],
.post-ad-page input[type="url"],
.post-ad-page select,
.post-ad-page textarea {
    width: 100%;
    padding: 12px 14px;
    border-radius: 8px;
    border: 1px solid var(--color-gray-200);
    font-size: 14px;
}

.post-ad-page input:focus,
.post-ad-page select:focus,
.post-ad-page textarea:focus {
    outline: none;
    border-color: var(--color-success);
    box-shadow: 0 0 0 3px rgba(34, 197, 94, 0.12);
}

.category-selects {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(180px, 1fr));
    gap: 12px;
}

.field-hint {
    font-size: 12px;
    color: #94a3b8;
    margin-top: 6px;
}

.toggle-grid {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(180px, 1fr));
    gap: 10px;
    margin-top: 6px;
}

.toggle-item {
    display: inline-flex;
    align-items: center;
    gap: 8px;
    padding: 10px 12px;
    border: 1px solid var(--color-gray-200);
    border-radius: 10px;
    background: #fff;
    font-size: 13px;
    color: #374151;
}

.field-hint.error {
    color: var(--color-danger);
}

.price-row {
    display: flex;
    gap: 10px;
    align-items: center;
    flex-wrap: nowrap;
}

.price-input {
    position: relative;
    flex: 1.6;
    min-width: 220px;
}

.currency-symbol {
    position: absolute;
    left: 12px;
    top: 50%;
    transform: translateY(-50%);
    color: #94a3b8;
    font-weight: 600;
}

.price-input input {
    padding-left: 32px;
}

.price-unit-badge {
    display: inline-flex;
    align-items: center;
    padding: 2px 8px;
    border-radius: 999px;
    background: #eafaf0;
    color: #16a34a;
    font-size: 11px;
    font-weight: 600;
    margin-left: 6px;
}

.price-unit-badge:empty {
    display: none;
}

.price-negotiable {
    font-size: 11px;
    color: #64748b;
    margin-left: 6px;
    font-weight: 600;
}

.price-unit-select.hidden {
    display: none;
}

.checkbox-inline {
    display: inline-flex;
    align-items: center;
    gap: 8px;
    font-size: 13px;
    color: #475569;
    white-space: nowrap;
}

.checkbox-inline input {
    width: 16px;
    height: 16px;
    accent-color: var(--color-success);
}

.upload-area {
    border: 2px dashed #cbd5f5;
    border-radius: 10px;
    padding: 22px;
    text-align: center;
    background: #f8fafc;
    cursor: pointer;
    transition: all 0.2s ease;
}

.upload-area:hover {
    border-color: var(--color-success);
    background: #f0fdf4;
}

.upload-icon {
    font-size: 30px;
    color: #94a3b8;
    margin-bottom: 8px;
}

.upload-text {
    font-size: 14px;
    font-weight: 600;
    color: #475569;
}

.upload-sub {
    font-size: 12px;
    color: #94a3b8;
    margin-top: 4px;
}

.image-preview-grid {
    margin-top: 14px;
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(90px, 1fr));
    gap: 10px;
}

.preview-item {
    position: relative;
    width: 100%;
    padding-top: 100%;
    border-radius: 10px;
    overflow: hidden;
    border: 1px solid var(--color-gray-200);
    background: #f8fafc;
}

.preview-item img {
    position: absolute;
    inset: 0;
    width: 100%;
    height: 100%;
    object-fit: cover;
}

.preview-item.dragging {
    opacity: 0.6;
}

.remove-img {
    position: absolute;
    top: 6px;
    right: 6px;
    width: 22px;
    height: 22px;
    border: none;
    border-radius: 999px;
    background: rgba(15, 23, 42, 0.7);
    color: #fff;
    cursor: pointer;
}

.upload-debug {
    margin-top: 12px;
    background: #0f172a;
    color: #e2e8f0;
    font-size: 12px;
    padding: 10px;
    border-radius: 8px;
    max-height: 220px;
    overflow: auto;
    display: none;
}

.upload-debug pre {
    margin: 0 0 8px;
    white-space: pre-wrap;
    word-break: break-word;
}

.catalog-section,
.attributes-section {
    margin-bottom: 22px;
}

.section-title {
    font-weight: 700;
    font-size: 14px;
    color: #1e293b;
    margin-bottom: 12px;
}

.attr-grid {
    background: #f8fafc;
    border: 1px solid var(--color-gray-200);
    padding: 16px;
    border-radius: 10px;
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 14px;
}

.seller-info-box {
    background: #fff7ed;
    border: 1px solid #fed7aa;
    padding: 16px;
    border-radius: 10px;
}

.seller-info-title {
    font-weight: 700;
    color: #c2410c;
    margin-bottom: 12px;
    display: flex;
    align-items: center;
    gap: 8px;
}

.locked-field {
    background: #f1f5f9;
    color: #64748b;
}

.input-icon-wrapper {
    position: relative;
}

.lock-icon {
    position: absolute;
    right: 12px;
    top: 50%;
    transform: translateY(-50%);
    color: #94a3b8;
}

.post-ad-footer {
    padding: 16px 30px;
    background: #fff;
    border-top: 1px solid var(--color-gray-200);
    display: flex;
    justify-content: space-between;
    gap: 12px;
}

.post-ad-page .btn.btn-primary {
    background: var(--color-accent);
    border-color: var(--color-accent);
    color: #fff;
}

.post-ad-page .btn.btn-primary:hover {
    background: #f97316;
    border-color: #f97316;
}

.post-ad-page .invalid {
    border-color: var(--color-danger);
}

@media (max-width: 900px) {

    .post-ad-body,
    .post-ad-footer,
    .post-ad-progress {
        padding: 20px;
    }

    .attr-grid {
        grid-template-columns: 1fr;
    }
}

@media (max-width: 640px) {
    .form-grid.two-col {
        grid-template-columns: 1fr;
    }

    .post-ad-progress::after,
    .post-ad-progress .progress-line {
        left: 24px;
        right: 24px;
    }

    .price-row {
        flex-wrap: wrap;
    }
}

a {
    color: var(--color-primary);
    text-decoration: none;
}

a:hover {
    text-decoration: underline;
}

img {
    max-width: 100%;
    height: auto;
}

h1,
h2,
h3,
h4,
h5,
h6 {
    margin-top: 0;
    line-height: 1.3;
}

/* ============================================================================
   LAYOUT
   ============================================================================ */
.container {
    width: 100%;
    max-width: var(--container-max);
    margin: 0 auto;
    padding: 0 var(--spacing-md);
}

.main-content {
    flex: 1;
    min-height: 0;
}

/* ============================================================================
   HEADER
   ============================================================================ */
.site-header {
    background: var(--color-white);
    box-shadow: var(--shadow);
    position: sticky;
    top: 0;
    z-index: 100;
}

.header-inner {
    display: flex;
    align-items: center;
    justify-content: space-between;
    padding: var(--spacing-md) 0;
    gap: var(--spacing-md);
}

.logo {
    font-size: var(--font-size-2xl);
    font-weight: 700;
    color: var(--color-primary);
}

.logo:hover {
    text-decoration: none;
}

.header-search {
    flex: 1;
    max-width: 500px;
    display: flex;
    gap: var(--spacing-sm);
}

.search-input {
    flex: 1;
    padding: var(--spacing-sm) var(--spacing-md);
    border: 1px solid var(--color-gray-200);
    border-radius: var(--border-radius);
    font-size: var(--font-size-base);
}

.search-btn {
    padding: var(--spacing-sm) var(--spacing-lg);
    background: var(--color-primary);
    color: var(--color-white);
    border: none;
    border-radius: var(--border-radius);
    cursor: pointer;
}

.header-nav {
    display: flex;
    align-items: center;
    gap: var(--spacing-md);
}

.nav-link {
    color: var(--color-gray-700);
    font-weight: 500;
}

.nav-link:hover {
    color: var(--color-primary);
    text-decoration: none;
}

.mobile-menu-toggle {
    display: none;
}

/* ============================================================================
   BUTTONS
   ============================================================================ */
.btn {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    padding: var(--spacing-sm) var(--spacing-lg);
    font-size: var(--font-size-base);
    font-weight: 500;
    border-radius: var(--border-radius);
    cursor: pointer;
    border: none;
    transition: all 0.2s;
    text-decoration: none;
}

.btn-primary {
    background: #3db83a;
    color: var(--color-white);
}

.btn-primary:hover {
    background: var(--color-primary-dark);
    text-decoration: none;
}

.btn-outline {
    background: transparent;
    border: 2px solid var(--color-primary);
    color: var(--color-primary);
}

.btn-outline:hover {
    background: var(--color-primary);
    color: white;
    text-decoration: none;
}

.btn-lg {
    padding: var(--spacing-md) var(--spacing-xl);
    font-size: var(--font-size-lg);
}

.btn-link {
    background: none;
    border: none;
    color: var(--color-primary);
    cursor: pointer;
}

/* ============================================================================
   HERO SECTION
   ============================================================================ */




/* ============================================================================
   CATEGORIES SECTION
   ============================================================================ */
.categories-section {
    padding: var(--spacing-2xl) 0;
}

.categories-section h2 {
    text-align: center;
    margin-bottom: var(--spacing-xl);
}

.category-grid {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(150px, 1fr));
    gap: var(--spacing-md);
}

.category-card {
    display: flex;
    flex-direction: column;
    align-items: center;
    padding: var(--spacing-lg);
    background: var(--color-white);
    border-radius: var(--border-radius-lg);
    box-shadow: var(--shadow);
    transition: transform 0.2s, box-shadow 0.2s;
    text-decoration: none;
    color: var(--color-gray-700);
}

.category-card:hover {
    transform: translateY(-4px);
    box-shadow: var(--shadow-lg);
    text-decoration: none;
}

.category-icon {
    font-size: 2.5rem;
    margin-bottom: var(--spacing-sm);
}

/* ============================================================================
   LISTINGS
   ============================================================================ */
.listings-grid {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(250px, 1fr));
    gap: var(--spacing-lg);
}

.related-listings.is-list {
    grid-template-columns: 1fr;
}

.related-listings.is-list .listing-card {
    display: flex;
    flex-direction: row;
    align-items: stretch;
}

.related-listings.is-list .listing-media {
    width: 220px;
    height: 160px;
    flex-shrink: 0;
}

.related-listings.is-list .listing-media img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    display: block;
}

.related-listings.is-list .listing-placeholder {
    height: 100%;
    display: flex;
    align-items: center;
    justify-content: center;
}

.related-listings.is-list .card-content {
    flex: 1;
    display: flex;
    flex-direction: column;
}

@media (max-width: 768px) {
    .related-listings.is-list .listing-card {
        flex-direction: column;
    }

    .related-listings.is-list .listing-media {
        width: 100%;
        height: 180px;
    }
}

.related-scope-pill,
.scope-pill {
    display: none !important;
}

/* ============================================================================
   Error Pages
   ============================================================================ */
.error-page-shell {
    background: radial-gradient(circle at top, rgba(34, 197, 94, 0.08), transparent 50%),
        radial-gradient(circle at 20% 20%, rgba(37, 99, 235, 0.08), transparent 45%);
    padding: 40px 0 70px;
}

.error-page-container {
    max-width: var(--container-max);
}

.error-hero {
    display: grid;
    grid-template-columns: minmax(0, 1fr) 280px;
    gap: 32px;
    align-items: center;
    background: #ffffff;
    border-radius: 20px;
    padding: 32px;
    box-shadow: 0 20px 50px rgba(15, 23, 42, 0.08);
}

.error-code {
    font-size: 64px;
    font-weight: 800;
    color: #0f172a;
    line-height: 1;
    margin-bottom: 12px;
}

.error-copy h1 {
    margin: 0 0 12px;
    font-size: 28px;
    color: #0f172a;
}

.error-message {
    margin: 0 0 20px;
    color: #475569;
    font-size: 15px;
}

.error-actions {
    display: flex;
    flex-wrap: wrap;
    gap: 10px;
}

.error-art {
    position: relative;
    min-height: 220px;
    border-radius: 18px;
    background: linear-gradient(135deg, #e0f2fe, #f8fafc);
    display: flex;
    align-items: center;
    justify-content: center;
    overflow: hidden;
}

.error-art-orb {
    width: 160px;
    height: 160px;
    border-radius: 50%;
    background: radial-gradient(circle at 30% 30%, #22c55e, #0ea5e9);
    opacity: 0.15;
}

.error-art-ring {
    position: absolute;
    width: 220px;
    height: 220px;
    border-radius: 50%;
    border: 2px dashed rgba(15, 23, 42, 0.15);
}

.error-art-chip {
    position: absolute;
    width: 90px;
    height: 90px;
    border-radius: 20px;
    background: #ffffff;
    display: flex;
    align-items: center;
    justify-content: center;
    box-shadow: 0 18px 30px rgba(15, 23, 42, 0.12);
    color: #0f172a;
    font-size: 26px;
}

.error-section {
    margin-top: 28px;
    background: #ffffff;
    border-radius: 18px;
    padding: 22px;
    box-shadow: 0 12px 28px rgba(15, 23, 42, 0.06);
}

.error-section-title {
    font-weight: 700;
    color: #0f172a;
    margin-bottom: 16px;
    font-size: 16px;
}

.error-actions-grid {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(220px, 1fr));
    gap: 12px;
}

.error-action-card {
    display: flex;
    gap: 12px;
    align-items: flex-start;
    padding: 14px;
    border-radius: 14px;
    border: 1px solid #e2e8f0;
    background: #f8fafc;
    color: inherit;
    text-decoration: none;
    transition: transform 0.2s ease, box-shadow 0.2s ease;
}

.error-action-card:hover {
    transform: translateY(-2px);
    box-shadow: 0 12px 20px rgba(15, 23, 42, 0.08);
}

.error-action-icon {
    width: 40px;
    height: 40px;
    border-radius: 12px;
    background: rgba(34, 197, 94, 0.15);
    color: #15803d;
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 18px;
    flex-shrink: 0;
}

.error-action-title {
    font-weight: 700;
    color: #0f172a;
    margin-bottom: 4px;
}

.error-action-desc {
    font-size: 13px;
    color: #64748b;
}

.error-search-chips {
    display: flex;
    flex-wrap: wrap;
    gap: 10px;
}

.error-search-chips .search-chip {
    padding: 8px 14px;
    border-radius: 999px;
    background: #f1f5f9;
    color: #0f172a;
    text-decoration: none;
    font-size: 13px;
    border: 1px solid #e2e8f0;
}

.error-search-chips .search-chip:hover {
    border-color: #22c55e;
    color: #166534;
}

.error-listings-grid {
    margin-top: 6px;
}

@media (max-width: 900px) {
    .error-hero {
        grid-template-columns: 1fr;
    }

    .error-art {
        min-height: 160px;
    }
}

.listing-card {
    background: var(--color-white);
    border-radius: var(--border-radius-lg);
    overflow: hidden;
    box-shadow: var(--shadow);
    transition: transform 0.2s;
}

.listing-card:hover {
    transform: translateY(-4px);
}

.listing-image {
    height: 180px;
    background: var(--color-gray-200);
}


/* ============================================================================
   MOBILE OPTIMIZATIONS (Custom)
   ============================================================================ */
@media (max-width: 600px) {

    /* --- Local Buzz Section (Mobile) --- */
    .home-wireframe .local-buzz-section {
        gap: 15px;
    }

    .home-wireframe .panel {
        padding: 15px;
        border-radius: 8px;
    }

    .home-wireframe .panel h3 {
        font-size: 16px;
        margin-bottom: 12px;
    }

    /* Sleek horizontal scrolling for tags */
    .home-wireframe .hot-tags {
        flex-wrap: nowrap;
        overflow-x: auto;
        padding-bottom: 8px;
        -webkit-overflow-scrolling: touch;
        scrollbar-width: none;
        /* Firefox */
        gap: 8px;
    }

    .home-wireframe .hot-tags::-webkit-scrollbar {
        display: none;
        /* Chrome/Safari */
    }

    .home-wireframe .hot-tag {
        flex-shrink: 0;
        padding: 6px 12px;
        font-size: 12px;
        white-space: nowrap;
    }


    /* Compact Local Posts */
    .home-wireframe .happening-header {
        margin-bottom: 15px;
    }

    .home-wireframe .local-posts {
        display: flex;
        flex-direction: column;
        gap: 12px;
    }

    .home-wireframe .local-post {
        display: flex;
        gap: 12px;
        padding: 12px;
        margin-bottom: 0;
        border-bottom: none;
        background: #fff;
        border-radius: 10px;
        box-shadow: 0 1px 3px rgba(0, 0, 0, 0.05);
        /* Card look to reduce "scattered" feel */
        align-items: flex-start;
    }

    .home-wireframe .post-thumb {
        width: 70px;
        height: 70px;
        border-radius: 8px;
        flex-shrink: 0;
        /* Prevent shrinking */
        background-color: #f1f5f9;
    }

    .home-wireframe .post-thumb img {
        width: 100%;
        height: 100%;
        object-fit: cover;
        border-radius: 8px;
    }

    .home-wireframe .post-content {
        flex: 1;
        min-width: 0;
        /* Essential for text truncation in flex children */
        display: flex;
        flex-direction: column;
        justify-content: space-between;
    }

    .home-wireframe .post-title {
        font-size: 13.5px;
        line-height: 1.4;
        margin-bottom: 6px;
        font-weight: 600;
        display: -webkit-box;
        -webkit-line-clamp: 2;
        line-clamp: 2;
        -webkit-box-orient: vertical;
        overflow: hidden;
    }

    .home-wireframe .post-meta {
        font-size: 10.5px;
        margin-bottom: 4px;
        display: flex;
        align-items: center;
        flex-wrap: wrap;
        gap: 6px;
    }

    .home-wireframe .post-footer {
        font-size: 11px;
        margin-top: auto;
    }

    .home-wireframe .post-actions span {
        margin-right: 12px;
        background: #f8fafc;
        padding: 2px 6px;
        border-radius: 4px;
    }

    /* Hide view details link on mobile to reduce clutter, title click is enough */
    .home-wireframe .view-details {
        display: none;
    }

    /* --- Top Sellers Grid (Compact & Sleek) --- */
    .home-wireframe .top-sellers-grid {
        grid-template-columns: repeat(2, 1fr) !important;
        gap: 10px;
    }

    .home-wireframe .top-seller-card {
        min-height: auto;
        border-radius: 10px;
        box-shadow: 0 2px 8px rgba(0, 0, 0, 0.05);
    }

    .home-wireframe .top-seller-thumb {
        height: 70px;
    }

    .home-wireframe .top-seller-logo {
        width: 32px;
        height: 32px;
        border-radius: 8px;
        left: 8px;
        bottom: -12px;
        font-size: 0.75rem;
        border-width: 1.5px;
        z-index: 2;
    }

    .home-wireframe .top-seller-rating {
        font-size: 9px;
        padding: 2px 6px;
        top: 6px;
        right: 6px;
        font-weight: 700;
    }

    .home-wireframe .top-seller-body {
        padding: 20px 10px 10px 10px;
        /* Top padding clears the logo overlap */
        display: flex;
        flex-direction: column;
        justify-content: center;
    }

    .home-wireframe .top-seller-name {
        font-size: 12px;
        margin-bottom: 2px;
    }

    .home-wireframe .top-seller-meta {
        font-size: 10px;
        opacity: 0.8;
    }

    .home-wireframe .top-seller-stats {
        margin-top: 6px;
        gap: 4px;
    }

    .home-wireframe .top-seller-stats .rating-stars {
        display: none;
        /* Hide stars on mobile to save space, rely on top-right badge */
    }

    .home-wireframe .top-seller-stats .response-pill {
        font-size: 9px;
        padding: 2px 5px;
        background: #f3f4f6;
    }
}

.listing-info h3 {
    margin: 0 0 var(--spacing-sm);
    font-size: var(--font-size-lg);
}

.listing-info .price {
    color: var(--color-secondary);
    font-weight: 700;
    font-size: var(--font-size-xl);
}

/* ============================================================================
   FEATURED & CTA SECTIONS
   ============================================================================ */
.featured-section {
    padding: var(--spacing-2xl) 0;
    background: var(--color-white);
}

/* ============================================================================
   PROMOTIONS BADGES
   ============================================================================ */
.promo-badges {
    display: flex;
    flex-wrap: wrap;
    gap: 6px;
}

.promo-badges.promo-overlay {
    position: absolute;
    top: 8px;
    left: 8px;
    z-index: 3;
}

.promo-badge {
    display: inline-flex;
    align-items: center;
    gap: 4px;
    padding: 2px 8px;
    border-radius: 999px;
    font-size: 11px;
    font-weight: 600;
    background: #e2e8f0;
    color: #1e293b;
    text-transform: uppercase;
    letter-spacing: 0.02em;
}

.promo-badge.promo-elite {
    background: #111827;
    color: #f8fafc;
}

.promo-badge.promo-top {
    background: #7c3aed;
    color: #fff;
}

.promo-badge.promo-premium {
    background: #0ea5e9;
    color: #fff;
}

.promo-badge.promo-inspected {
    background: #16a34a;
    color: #fff;
}

.promo-badge.promo-urgent {
    background: #ef4444;
    color: #fff;
}

.promo-badge.promo-colored {
    background: #f59e0b;
    color: #fff;
}

.promo-badge.promo-featured {
    background: #f59e0b;
    color: #fff;
}

.promo-badge.promo-refreshed {
    background: #0f766e;
    color: #fff;
}

.promo-colored {
    border: 2px solid var(--promo-color, #f59e0b);
    box-shadow: 0 6px 16px rgba(0, 0, 0, 0.12);
}

.section-subtitle {
    color: var(--color-gray-500);
    margin-bottom: var(--spacing-xl);
}

.section-footer {
    text-align: center;
    margin-top: var(--spacing-xl);
}

.cta-section {
    padding: var(--spacing-2xl) 0;
    text-align: center;
    background: var(--color-gray-100);
}

/* ============================================================================
   FORMS
   ============================================================================ */
.form-group {
    margin-bottom: var(--spacing-md);
}

.form-group label {
    display: block;
    margin-bottom: var(--spacing-xs);
    font-weight: 500;
}

.form-control {
    width: 100%;
    padding: var(--spacing-sm) var(--spacing-md);
    border: 1px solid var(--color-gray-300);
    border-radius: var(--border-radius);
    font-size: var(--font-size-base);
}

.form-control:focus {
    outline: none;
    border-color: var(--color-primary);
    box-shadow: 0 0 0 3px rgba(37, 99, 235, 0.1);
}

/* ============================================================================
   ALERTS
   ============================================================================ */
.alert {
    padding: var(--spacing-md);
    border-radius: var(--border-radius);
    margin-bottom: var(--spacing-md);
}

.alert-success {
    background: #dcfce7;
    color: #166534;
    border: 1px solid #86efac;
}

.alert-error {
    background: #fee2e2;
    color: #991b1b;
    border: 1px solid #fca5a5;
}

.alert-warning {
    background: #fef3c7;
    color: #92400e;
    border: 1px solid #fcd34d;
}

/* ============================================================================
   LOCATION NOTICE PILL
   ============================================================================ */
.location-notice {
    display: inline-flex;
    align-items: center;
    gap: 10px;
    padding: 10px 14px;
    border-radius: 10px;
    background: #eef6ff;
    color: #1e3a8a;
    font-size: 12px;
    font-weight: 600;
    margin: 0 0 16px;
    border: 1px solid #c7ddff;
}

.location-notice .notice-dot {
    width: 8px;
    height: 8px;
    border-radius: 50%;
    background: #2563eb;
}

.location-notice.warn {
    background: #fff7ed;
    color: #9a3412;
    border-color: #fed7aa;
}

.location-notice.warn .notice-dot {
    background: #f97316;
}

/* ============================================================================
   LOCATION DEFAULT PROMPT
   ============================================================================ */
.location-switch-banner {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 16px;
    padding: 12px 16px;
    border-radius: 12px;
    background: #fff7ed;
    color: #9a3412;
    border: 1px solid #fed7aa;
    margin: 0 0 16px;
    font-size: 14px;
    font-weight: 600;
}

.location-switch-banner .banner-actions {
    display: flex;
    gap: 8px;
}

.location-switch-banner .btn-keep,
.location-switch-banner .btn-switch {
    border: none;
    border-radius: 999px;
    padding: 6px 12px;
    font-size: 12px;
    font-weight: 700;
    cursor: pointer;
}

.location-switch-banner .btn-keep {
    background: #fff;
    color: #9a3412;
    border: 1px solid #fbd3b1;
}

.location-switch-banner .btn-switch {
    background: #f97316;
    color: #fff;
}

@media (max-width: 768px) {
    .location-switch-banner {
        flex-direction: column;
        align-items: flex-start;
    }

    .location-switch-banner .banner-actions {
        width: 100%;
    }

    .location-switch-banner .btn-keep,
    .location-switch-banner .btn-switch {
        flex: 1;
        text-align: center;
    }
}

/* ============================================================================
   SEARCH TYPEAHEAD
   ============================================================================ */
.search-typeahead-wrap {
    position: relative;
}

.search-typeahead {
    position: absolute;
    top: calc(100% + 10px);
    left: 0;
    right: 0;
    background: #ffffff;
    border: 1px solid #eef0f3;
    border-radius: 16px;
    box-shadow: 0 18px 36px rgba(15, 23, 42, 0.18);
    max-height: 70vh;
    overflow-y: auto;
    display: none;
    z-index: 2000;
    padding: 6px 4px 10px;
    text-align: left;
}

.search-typeahead.open {
    display: block;
}

.search-typeahead-empty {
    padding: 12px 16px;
    font-size: 13px;
    color: #6b7280;
}

.st-section {
    padding: 6px 0;
    border-top: 1px solid #f0f2f5;
}

.st-section:first-child {
    border-top: none;
}

.st-title {
    padding: 6px 16px;
    font-size: 11px;
    font-weight: 700;
    letter-spacing: 0.08em;
    text-transform: uppercase;
    color: #6b7280;
}

.st-item {
    display: flex;
    align-items: center;
    justify-content: flex-start;
    padding: 12px 18px;
    cursor: pointer;
    gap: 12px;
    border-radius: 12px;
    margin: 2px 10px;
}

.st-item:hover {
    background: #f1f5f9;
}

.st-listing {
    display: flex;
    align-items: center;
    gap: 18px;
    padding: 14px 16px;
    border: 1px solid #e7edf5;
    border-radius: 20px;
    margin: 10px 14px;
    box-shadow: 0 10px 18px rgba(15, 23, 42, 0.06);
    cursor: pointer;
    background: #fff;
    transition: transform 0.12s ease, box-shadow 0.12s ease;
}

.st-listing:hover {
    transform: translateY(-1px);
    box-shadow: 0 14px 24px rgba(15, 23, 42, 0.12);
}

.st-listing:last-child {
    border-bottom: 1px solid #e9eef5;
}

.st-listing-thumb {
    width: 64px;
    height: 64px;
    border-radius: 16px;
    overflow: hidden;
    background: #f1f5f9;
    display: flex;
    align-items: center;
    justify-content: center;
    flex-shrink: 0;
}

.st-listing-thumb.st-thumb-fallback {
    font-weight: 700;
    color: #94a3b8;
    font-size: 18px;
    background: #f1f5f9;
}

.st-listing-thumb img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    display: block;
}

.st-listing-body {
    display: flex;
    flex-direction: column;
    gap: 4px;
    flex: 1;
    min-width: 0;
    text-align: left;
    align-items: flex-start;
}

.st-listing-title {
    font-size: 16px;
    font-weight: 700;
    color: #1f2937;
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
}

.st-listing-meta {
    font-size: 13px;
    color: #6b7280;
}

.st-listing-meta .category {
    color: #3db83a;
    font-weight: 600;
}

.st-listing-location {
    display: inline-flex;
    align-items: center;
    gap: 6px;
    color: #6b7280;
    font-size: 12px;
}

.st-listing-location i {
    color: #3db83a;
}

.st-listing-price {
    font-weight: 800;
    color: #16a34a;
    font-size: 16px;
    margin-left: auto;
    white-space: nowrap;
}

.st-label {
    font-size: 14px;
    font-weight: 600;
    color: #111827;
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
}

.st-meta {
    font-size: 12px;
    color: #6b7280;
    white-space: nowrap;
}

.st-thumb {
    width: 36px;
    height: 36px;
    border-radius: 10px;
    background: #f3f4f6;
    display: flex;
    align-items: center;
    justify-content: center;
    overflow: hidden;
    flex: 0 0 36px;
    font-size: 13px;
    font-weight: 700;
    color: #6b7280;
}

.st-thumb img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    display: block;
}

.st-body {
    display: flex;
    flex-direction: column;
    gap: 2px;
    min-width: 0;
}

@media (max-width: 600px) {
    .search-typeahead {
        border-radius: 14px;
    }

    .st-listing {
        flex-wrap: wrap;
    }

    .st-listing-price {
        margin-left: 0;
        width: 100%;
        text-align: right;
    }
}

/* ============================================================================
   ERROR PAGES
   ============================================================================ */
.error-page {
    text-align: center;
    padding: var(--spacing-2xl) 0;
}

.error-page h1 {
    font-size: 6rem;
    color: var(--color-gray-300);
    margin: 0;
}

.error-page h2 {
    font-size: var(--font-size-2xl);
    margin-bottom: var(--spacing-md);
}

/* ============================================================================
   FOOTER
   ============================================================================ */
.site-footer {
    background: var(--color-gray-900);
    color: var(--color-gray-300);
    padding: var(--spacing-2xl) 0 var(--spacing-md);
}

.footer-grid {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(200px, 1fr));
    gap: var(--spacing-xl);
    margin-bottom: var(--spacing-xl);
}

.footer-section h4 {
    color: var(--color-white);
    margin-bottom: var(--spacing-md);
}

.footer-section ul {
    list-style: none;
    padding: 0;
    margin: 0;
}

.footer-section li {
    margin-bottom: var(--spacing-sm);
}

.footer-section a {
    color: var(--color-gray-400);
}

.footer-section a:hover {
    color: var(--color-white);
}

.footer-bottom {
    text-align: center;
    padding-top: var(--spacing-lg);
    border-top: 1px solid var(--color-gray-700);
}

@media (max-width: 768px) {
    .site-footer .footer-grid {
        grid-template-columns: repeat(3, minmax(0, 1fr));
        gap: 12px;
    }

    .site-footer .footer-col-categories,
    .site-footer .footer-col-why {
        display: none;
    }

    .site-footer .footer-col h3 {
        font-size: 13px;
    }

    .site-footer .footer-col p,
    .site-footer .footer-col li {
        font-size: 11px;
    }
}

/* ============================================================================
   PAGE CONTENT
   ============================================================================ */
.page-content {
    padding: var(--spacing-2xl) 0;
}

.page-content h1 {
    margin-bottom: var(--spacing-lg);
}

/* ============================================================================
   RESPONSIVE
   ============================================================================ */
@media (max-width: 768px) {
    .header-search {
        display: none;
    }

    .header-nav {
        display: none;
    }

    .mobile-menu-toggle {
        display: block;
    }

    .hero h1 {
        font-size: var(--font-size-2xl);
    }

    .hero p {
        font-size: var(--font-size-base);
    }

    .hero-search {
        flex-direction: column;
    }

    .hero-category-select {
        display: none;
    }
}

/* ============================================================================
   Jiji-Style Header/Footer + Home Wireframe
   ============================================================================ */
:root {
    --primary-green: #3db83a;
    --secondary-green: #2a9d28;
    --accent-orange: #ff8c00;
    --dark-navy: #0b1120;
    --bg-gray: #f2f4f5;
    --text-dark: #292929;
    --text-gray: #949494;
    --white: #ffffff;
    --shadow: 0 2px 4px rgba(0, 0, 0, 0.1);
    --sidebar-width: 280px;
}

body {
    background-color: var(--bg-gray);
    color: var(--text-dark);
    font-family: 'Segoe UI', Roboto, Helvetica, Arial, sans-serif;
    padding-bottom: 0;
}

.site-header {
    background-color: var(--primary-green);
    color: var(--white);
    padding: 10px 0;
    position: sticky;
    top: 0;
    z-index: 1000;
    box-shadow: 0 2px 5px rgba(0, 0, 0, 0.1);
}

.site-header .container,
.site-footer .container,
.home-wireframe .container {
    max-width: 1200px;
    padding-left: 15px;
    padding-right: 15px;
}

.site-header *,
.site-footer *,
.home-wireframe * {
    box-sizing: border-box;
    margin: 0;
    padding: 0;
    font-family: 'Segoe UI', Roboto, Helvetica, Arial, sans-serif;
}

.site-header a,
.site-footer a,
.home-wireframe a {
    color: inherit;
    text-decoration: none;
}

.home-wireframe ul {
    list-style: none;
    margin: 0;
    padding: 0;
}

.home-wireframe img {
    display: block;
}

.home-wireframe h1,
.home-wireframe h2,
.home-wireframe h3,
.home-wireframe h4,
.home-wireframe h5,
.home-wireframe h6,
.home-wireframe p {
    margin: 0;
}

.site-header .header-flex {
    display: flex;
    justify-content: flex-start;
    align-items: center;
}

.site-header .logo {
    font-size: 28px;
    font-weight: 800;
    letter-spacing: -1px;
}

.site-header .logo-img {
    height: 34px;
    width: auto;
    display: block;
}

.site-header a {
    text-decoration: none;
    color: inherit;
}

.site-header .header-actions {
    display: flex;
    align-items: center;
    gap: 10px;
    margin-left: auto;
}

.site-header .header-icon {
    display: flex;
    flex-direction: column;
    align-items: center;
    font-size: 12px;
    cursor: pointer;
    position: relative;
}

.site-header .header-icon i {
    font-size: 18px;
    margin-bottom: 4px;
}

.site-header .header-emoji {
    font-size: 18px;
    margin-bottom: 4px;
    line-height: 1;
}

.site-header .header-icon .badge {
    background: red;
    border-radius: 50%;
    padding: 2px 5px;
    font-size: 10px;
    position: absolute;
    margin-left: 15px;
    margin-top: -5px;
    top: 4px;
    right: -6px;
}

.site-header .btn-sell {
    background: linear-gradient(135deg, #28a745 0%, #f68b1e 100%);
    color: white;
    padding: 12px 34px;
    border-radius: 4px;
    font-weight: 700;
    text-transform: uppercase;
    font-size: 14px;
    box-shadow: 0 2px 5px rgba(0, 0, 0, 0.2);
    transition: transform 0.2s;
}

.site-header .btn-sell:hover {
    transform: translateY(-2px);
}

.site-header .language-switcher {
    position: relative;
}

.site-header .language-chip {
    display: inline-flex;
    align-items: center;
    gap: 6px;
    background: rgba(255, 255, 255, 0.12);
    color: #fff;
    border: 1px solid rgba(255, 255, 255, 0.15);
    border-radius: 999px;
    padding: 6px 10px;
    cursor: pointer;
    font-size: 12px;
    font-weight: 600;
}

.site-header .language-chip i {
    font-size: 12px;
}

.site-header .language-panel {
    position: absolute;
    top: calc(100% + 8px);
    right: 0;
    min-width: 220px;
    background: #fff;
    border-radius: 12px;
    box-shadow: 0 12px 24px rgba(0, 0, 0, 0.12);
    padding: 10px;
    display: none;
    z-index: 50;
}

.site-header .language-panel.open {
    display: block;
}

.site-header .language-panel .dropdown-item {
    width: 100%;
    text-align: left;
    border: none;
    background: transparent;
    padding: 8px 10px;
    border-radius: 8px;
    font-size: 13px;
    cursor: pointer;
}

.site-header .language-panel .dropdown-item.active,
.site-header .language-panel .dropdown-item:hover {
    background: #f1f5f9;
}

/* --- HOME WIREFRAME --- */
.home-wireframe .hero {
    background-color: var(--primary-green);
    padding: 30px 0 60px 0;
    text-align: center;
    color: white;
    border-bottom-left-radius: 24px;
    border-bottom-right-radius: 24px;
}

.home-wireframe .hero h2 {
    margin-bottom: 20px;
    font-weight: 500;
}

.home-wireframe .hero-subtitle {
    margin: -8px 0 18px;
    font-size: 14px;
    opacity: 0.9;
}

.home-wireframe .hero-cta-btn {
    background: #ffffff;
    color: var(--primary-green);
    border: none;
    font-weight: 700;
}

.home-wireframe .search-bar-wrapper {
    background: white;
    max-width: 900px;
    margin: 0 auto;
    border-radius: 18px;
    padding: 10px;
    display: flex;
    gap: 12px;
    box-shadow: 0 18px 40px rgba(15, 23, 42, 0.18);
    border: none;
    position: relative;
}

.home-wireframe .search-input-group {
    display: flex;
    align-items: center;
    background: #fff;
    border-radius: 14px;
    padding: 2px 12px;
    border: 1px solid #e5e7eb;
    min-height: 52px;
}

.home-wireframe .search-input-group.location-box {
    flex: 0 0 28%;
}

.home-wireframe .search-input-group.keyword-box {
    flex: 1;
}

.home-wireframe .search-input-group i {
    color: #94a3b8;
    margin-right: 8px;
    font-size: 15px;
}

.home-wireframe .search-input-group select,
.home-wireframe .search-input-group input {
    border: none;
    background: transparent;
    padding: 10px 6px;
    width: 100%;
    outline: none;
    font-size: 15px;
}

.home-wireframe .search-input-group .location-trigger {
    border: none;
    background: transparent;
    padding: 8px 6px;
    width: 100%;
    text-align: left;
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 8px;
    font-size: 15px;
    color: #111827;
    cursor: pointer;
}

.home-wireframe .search-input-group .location-trigger .location-chip-text {
    display: inline-block;
    max-width: 100%;
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
}

.home-wireframe .search-input-group .location-trigger i {
    margin-right: 0;
    font-size: 12px;
    color: #94a3b8;
}

.home-wireframe .search-divider {
    width: 1px;
    background: #e2e8f0;
    height: 30px;
    align-self: center;
}

.home-wireframe .btn-search {
    background-color: var(--primary-green);
    color: white;
    border: none;
    padding: 12px 30px;
    border-radius: 14px;
    font-weight: 600;
    cursor: pointer;
    font-size: 15px;
    box-shadow: 0 10px 18px rgba(16, 185, 129, 0.25);
}

.home-wireframe .search-input-group.keyword-box .search-typeahead {
    left: 0;
    right: 0;
    top: calc(100% + 10px);
}

/* --- MOBILE CATEGORY GRID --- */
.home-wireframe .mobile-categories {
    display: none;
    padding: 15px;
    background: white;
    margin-bottom: 10px;
}

.home-wireframe .mobile-cat-grid {
    display: grid;
    grid-template-columns: repeat(4, 1fr);
    gap: 15px 10px;
    text-align: center;
}

.home-wireframe .m-cat-item {
    display: flex;
    flex-direction: column;
    align-items: center;
    cursor: pointer;
}

.home-wireframe .m-cat-icon {
    width: 60px;
    height: 60px;
    background: #f0f6fa;
    border-radius: 18px;
    display: flex;
    align-items: center;
    justify-content: center;
    margin-bottom: 8px;
    overflow: hidden;
}

.home-wireframe .m-cat-icon img {
    width: 65px;
    height: 65px;
    object-fit: contain;
}

.home-wireframe .m-cat-item span {
    font-size: 11px;
    color: #333;
    line-height: 1.2;
    font-weight: 500;
}

/* --- MAIN LAYOUT --- */
.home-wireframe .main-wrapper {
    display: flex;
    gap: 20px;
    margin-top: 12px;
    position: relative;
    z-index: 10;
}

/* --- SIDEBAR --- */
.home-wireframe .sidebar {
    width: var(--sidebar-width);
    background: white;
    border-radius: 18px;
    box-shadow: 0 18px 36px rgba(15, 23, 42, 0.08);
    border: 1px solid #eef2f6;
    flex-shrink: 0;
    height: fit-content;
    padding: 6px 6px;
    z-index: 200;
    position: sticky;
    top: 86px;
    align-self: flex-start;
}

.home-wireframe .sidebar-scroll-shell {
    position: relative;
}

.home-wireframe .sidebar-scroll-list {
    list-style: none;
    margin: 0;
    padding: 0;
    max-height: calc(100vh - 190px);
    overflow-y: auto;
    overflow-x: visible;
    overscroll-behavior: contain;
    scrollbar-width: none;
}

.home-wireframe .sidebar-scroll-list::-webkit-scrollbar {
    width: 0;
    height: 0;
}

.home-wireframe .js-home-sidebar::before,
.home-wireframe .js-home-sidebar::after {
    content: "";
    position: absolute;
    left: 6px;
    right: 6px;
    height: 26px;
    pointer-events: none;
    opacity: 0;
    transition: opacity 0.2s ease;
    z-index: 205;
}

.home-wireframe .js-home-sidebar::before {
    top: 6px;
    background: linear-gradient(to bottom, rgba(255, 255, 255, 0.96), rgba(255, 255, 255, 0));
}

.home-wireframe .js-home-sidebar::after {
    bottom: 6px;
    background: linear-gradient(to top, rgba(255, 255, 255, 0.96), rgba(255, 255, 255, 0));
}

.home-wireframe .js-home-sidebar.is-scrollable::before,
.home-wireframe .js-home-sidebar.is-scrollable::after {
    opacity: 1;
}

.home-wireframe .sidebar-scroll-btn {
    position: absolute;
    left: 50%;
    transform: translateX(-50%);
    width: 30px;
    height: 30px;
    border: none;
    border-radius: 999px;
    background: rgba(255, 255, 255, 0.96);
    color: #5b6b80;
    box-shadow: 0 8px 16px rgba(15, 23, 42, 0.18);
    cursor: pointer;
    z-index: 210;
    opacity: 0;
    pointer-events: none;
    transition: opacity 0.2s ease, transform 0.2s ease;
}

.home-wireframe .sidebar-scroll-btn:hover {
    transform: translateX(-50%) scale(1.06);
}

.home-wireframe .sidebar-scroll-btn.is-visible {
    opacity: 1;
    pointer-events: auto;
}

.home-wireframe .sidebar-scroll-btn--top {
    top: 10px;
}

.home-wireframe .sidebar-scroll-btn--bottom {
    bottom: 10px;
}

@media (max-height: 860px) {
    .home-wireframe .sidebar-scroll-list {
        max-height: calc(100vh - 140px);
    }
}

.home-wireframe .sidebar-item {
    padding: 12px 16px;
    cursor: pointer;
    display: flex;
    align-items: center;
    gap: 14px;
    position: relative;
    font-size: 15px;
    color: #1f2937;
    transition: background 0.15s ease;
    border-bottom: 1px solid #edf2f7;
}

.home-wireframe .sidebar-item:last-child {
    border-bottom: none;
}

.home-wireframe .sidebar-item:hover {
    background-color: #f8fafc;
}

.home-wireframe .sidebar-cat-img {
    width: 46px;
    height: 46px;
    object-fit: contain;

    border-radius: 12px;
    background: #f3f6fb;
    box-sizing: border-box;
    box-shadow: inset 0 0 0 1px #e5e9f2;
}

.home-wireframe .sidebar-text {
    flex: 1;
    font-weight: 600;
}

.home-wireframe .sidebar-count {
    font-size: 12px;
    color: #94a3b8;
    display: block;
    margin-top: 2px;
    font-weight: 500;
}

.home-wireframe .sidebar-arrow {
    color: #cbd5e1;
    font-size: 14px;
}

.home-wireframe .sidebar-item:hover .pullout-menu {
    display: block;
}

.home-wireframe .pullout-menu {
    display: none;
    position: absolute;
    left: 100%;
    top: -5px;
    width: 300px;
    background: white;
    box-shadow: 0 18px 36px rgba(15, 23, 42, 0.12);
    min-height: calc(100% + 10px);
    z-index: 300;
    padding: 10px 0;
    border-top-right-radius: 16px;
    border-bottom-right-radius: 16px;
    border: 1px solid #eef2f6;
}

.home-wireframe .pullout-menu.is-fixed-flyout {
    position: fixed;
    left: 0;
    top: 0;
    min-height: 0;
    max-height: calc(100vh - 16px);
    overflow-y: auto;
    border-radius: 16px;
    z-index: 1200;
}

.home-wireframe .sub-cat-item {
    display: flex;
    align-items: center;
    padding: 12px 16px;
    gap: 12px;
    border-bottom: 1px solid #f1f5f9;
}

.home-wireframe .sub-cat-item:hover {
    background-color: #f9f9f9;
}

.home-wireframe .sub-cat-thumb {
    width: 40px;
    height: 40px;
    background: #f3f6fb;
    border-radius: 10px;
    object-fit: cover;
}

.home-wireframe .sub-cat-info h4 {
    font-size: 14px;
    font-weight: 500;
    color: #333;
    margin-bottom: 2px;
}

.home-wireframe .sub-cat-info span {
    font-size: 11px;
    color: #888;
}

.home-wireframe .content-area {
    flex: 1;
}

/* --- INFO BOXES --- */
.home-wireframe .info-boxes {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 15px;
    margin-bottom: 25px;
}

.home-wireframe .info-card {
    border-radius: 6px;
    padding: 15px 12px;
    text-align: left;
    box-shadow: 0 2px 4px rgba(0, 0, 0, 0.05);
    border: 1px solid transparent;
    transition: 0.3s;
    position: relative;
    height: 100px;
    display: flex;
    flex-direction: column;
    justify-content: flex-end;
    cursor: pointer;
    overflow: hidden;
}

.home-wireframe .info-card-icon {
    position: absolute;
    top: 10px;
    left: 50%;
    transform: translateX(-50%);
    width: 50px;
    height: 50px;
    object-fit: contain;
}

.home-wireframe .info-card h3 {
    font-size: 15px;
    font-weight: 700;
    margin: 0;
    color: #222;
    z-index: 1;
    text-align: center;
}

.home-wireframe .info-card.job {
    background-color: #e6f6e8;
    border-color: #a5d6a7;
}

.home-wireframe .info-card.sell {
    background-color: #e6f6e8;
    border-color: #a5d6a7;
}

.home-wireframe .info-card.buy {
    background-color: #ede7f6;
    border-color: #d1c4e9;
}

/* --- ADS GRID --- */
.home-wireframe .section-header {
    display: flex;
    justify-content: space-between;
    align-items: center;
    margin-bottom: 15px;
    margin-top: 15px;
}

.home-wireframe .section-title {
    font-size: 20px;
    font-weight: 600;
    color: #333;
}

.home-wireframe .section-subtitle {
    font-size: 14px;
    color: #777;
    font-weight: 400;
    margin-left: 10px;
}

.home-wireframe .ads-grid {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(200px, 1fr));
    gap: 15px;
    margin-bottom: 30px;
}

.home-wireframe .ad-card {
    background: white;
    border-radius: 4px;
    overflow: hidden;
    box-shadow: var(--shadow);
    transition: box-shadow 0.2s;
    position: relative;
    display: flex;
    flex-direction: column;
}

.home-wireframe .ad-card:hover {
    box-shadow: 0 5px 15px rgba(0, 0, 0, 0.2);
}

.home-wireframe .ad-img-container {
    height: 180px;
    background-color: #e0e0e0;
    position: relative;
    display: flex;
    align-items: center;
    justify-content: center;
    color: #999;
    font-weight: 600;
}

.home-wireframe .ad-img-container img {
    width: 100%;
    height: 100%;
    object-fit: cover;
}

.home-wireframe .ad-content {
    padding: 15px;
    flex-grow: 1;
    display: flex;
    flex-direction: column;
    justify-content: space-between;
}

.home-wireframe .ad-title {
    font-size: 15px;
    font-weight: 500;
    margin-bottom: 10px;
    color: var(--text-dark);
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
}

.home-wireframe .ad-price {
    color: var(--primary-green);
    font-weight: 800;
    font-size: 18px;
    margin-bottom: 10px;
}

.home-wireframe .ad-meta-container {
    display: flex;
    justify-content: space-between;
    align-items: center;
}

.home-wireframe .ad-location {
    font-size: 12px;
    color: #999;
    display: flex;
    align-items: center;
}

.home-wireframe .ad-location i {
    margin-right: 5px;
}

.home-wireframe .badge-container {
    position: absolute;
    bottom: 6px;
    left: 6px;
    display: flex;
    gap: 4px;
    flex-wrap: wrap;
    z-index: 10;
    max-width: 95%;
}

.home-wireframe .ad-badge {
    font-size: 9px;
    padding: 2px 6px;
    border-radius: 3px;
    color: white;
    font-weight: 700;
    text-transform: uppercase;
    display: inline-flex;
    align-items: center;
    box-shadow: 0 1px 3px rgba(0, 0, 0, 0.3);
    line-height: 1.2;
}

.home-wireframe .ad-badge i {
    margin-right: 3px;
    font-size: 8px;
}

.home-wireframe .badge-top {
    background: #00bcd4;
}

.home-wireframe .badge-premium {
    background: linear-gradient(45deg, #ffd700, #ffaa00);
    color: #333;
    text-shadow: none;
    top: -140px;
    position: absolute;
}

.home-wireframe .badge-verified {
    background: #4caf50;
}

.home-wireframe .badge-new {
    background: #ff5722;
}

.home-wireframe .badge-trusted {
    background: #9c27b0;
}

.home-wireframe .attr-tag {
    font-size: 10px;
    color: #555;
    background: #f0f2f5;
    padding: 3px 6px;
    border-radius: 4px;
    font-weight: 600;
    white-space: nowrap;
}

/* --- LOCAL BUZZ --- */
.home-wireframe .local-buzz-section {
    display: grid;
    gap: 24px;
}

.home-wireframe .panel {
    background: white;
    border-radius: 4px;
    box-shadow: var(--shadow);
    padding: 20px;
    margin-bottom: 25px;
}

.home-wireframe .panel h3 {
    font-size: 18px;
    font-weight: 600;
    color: #333;
    margin-bottom: 15px;
}

.home-wireframe .hot-tags {
    display: flex;
    flex-wrap: wrap;
    gap: 10px;
}

.home-wireframe .hot-tag {
    display: inline-block;
    background: #f5f5f5;
    padding: 8px 15px;
    border-radius: 20px;
    font-size: 13px;
    color: #555;
    border: 1px solid #eee;
}

.home-wireframe .hot-tag span {
    color: var(--accent-orange);
    font-weight: 600;
    margin-right: 5px;
}

.home-wireframe .happening-header {
    display: flex;
    justify-content: space-between;
    align-items: center;
    margin-bottom: 20px;
    gap: 10px;
    flex-wrap: wrap;
}

.home-wireframe .btn-post-update {
    background: #eee;
    color: #555;
    padding: 8px 15px;
    border-radius: 4px;
    font-size: 12px;
    font-weight: 600;
    cursor: pointer;
}

.home-wireframe .local-post {
    display: flex;
    gap: 15px;
    border-bottom: 1px solid #eee;
    padding-bottom: 15px;
    margin-bottom: 15px;
}

.home-wireframe .post-thumb {
    width: 80px;
    height: 80px;
    background: #ddd;
    border-radius: 4px;
    flex-shrink: 0;
}

.home-wireframe .post-content {
    flex: 1;
}

.home-wireframe .post-meta {
    font-size: 11px;
    color: #999;
    margin-bottom: 5px;
}

.home-wireframe .post-tag {
    font-weight: 700;
    margin-right: 5px;
}

.home-wireframe .tag-event {
    color: #9c27b0;
}

.home-wireframe .tag-deal {
    color: #00bcd4;
}

.home-wireframe .tag-news {
    color: #ff5722;
}

.home-wireframe .post-title {
    font-size: 14px;
    font-weight: 600;
    color: #333;
    margin-bottom: 8px;
    line-height: 1.4;
}

.home-wireframe .post-footer {
    display: flex;
    justify-content: space-between;
    align-items: center;
    font-size: 12px;
    color: #999;
}

.home-wireframe .post-actions i {
    margin-right: 5px;
}

.home-wireframe .post-actions span {
    margin-right: 15px;
}

.home-wireframe .view-details {
    color: var(--primary-green);
}

.home-wireframe .see-all-buzz {
    display: block;
    text-align: center;
    color: var(--primary-green);
    font-size: 14px;
    font-weight: 600;
    padding-top: 10px;
}

/* Events */
.home-wireframe .events-grid {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(200px, 1fr));
    gap: 15px;
}

.home-wireframe .event-card-horiz {
    background: #fff;
    border-radius: 4px;
    overflow: hidden;
    box-shadow: var(--shadow);
}

.home-wireframe .event-img-con {
    height: 120px;
    background: #ddd;
    position: relative;
}

.home-wireframe .event-img-con img {
    width: 100%;
    height: 100%;
    object-fit: cover;
}

.home-wireframe .soon-badge {
    position: absolute;
    bottom: 10px;
    right: 10px;
    background: #333;
    color: white;
    padding: 2px 8px;
    border-radius: 10px;
    font-size: 10px;
}

.home-wireframe .event-details-horiz {
    padding: 12px;
}

.home-wireframe .event-date-tag {
    font-size: 11px;
    color: var(--primary-green);
    font-weight: 700;
    margin-bottom: 5px;
    display: block;
}

.home-wireframe .event-title-horiz {
    font-size: 14px;
    font-weight: 600;
    color: #333;
    margin-bottom: 5px;
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
}

.home-wireframe .event-price {
    font-size: 12px;
    color: #777;
}

/* Top sellers (home) */
.home-wireframe .top-sellers-grid {
    display: grid;
    grid-template-columns: repeat(var(--seller-cols, 4), minmax(0, 1fr));
    gap: 14px;
}

.home-wireframe .top-seller-card {
    background: #fff;
    border-radius: 6px;
    overflow: hidden;
    box-shadow: var(--shadow);
    text-decoration: none;
    color: inherit;
    display: flex;
    flex-direction: column;
    min-height: 170px;
    min-width: 0;
}

.home-wireframe .top-seller-thumb {
    position: relative;
    height: 90px;
    background: #e2e8f0;
    background-size: cover;
    background-position: center;
}

.home-wireframe .top-seller-logo {
    position: absolute;
    left: 10px;
    bottom: -16px;
    width: 40px;
    height: 40px;
    border-radius: 10px;
    background: #0f172a;
    color: #fff;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    font-weight: 700;
    font-size: 0.85rem;
    border: 2px solid #fff;
    overflow: hidden;
}

.home-wireframe .top-seller-logo img {
    width: 100%;
    height: 100%;
    object-fit: cover;
}

.home-wireframe .top-seller-rating {
    position: absolute;
    top: 8px;
    right: 8px;
    background: rgba(15, 23, 42, 0.85);
    color: #fff;
    font-size: 11px;
    padding: 3px 8px;
    border-radius: 999px;
    font-weight: 600;
}

.home-wireframe .top-seller-body {
    padding: 26px 12px 12px;
    flex: 1;
}

.home-wireframe .top-seller-name {
    font-size: 13px;
    font-weight: 600;
    color: #111;
    margin-bottom: 4px;
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
}

.home-wireframe .top-seller-meta {
    font-size: 11px;
    color: #777;
}

.home-wireframe .top-seller-stats {
    margin-top: 8px;
    display: flex;
    align-items: center;
    gap: 6px;
    flex-wrap: wrap;
    font-size: 11px;
    color: #777;
}

.home-wireframe .top-seller-stats .rating-stars i {
    color: #f59e0b;
    font-size: 11px;
}

.home-wireframe .top-seller-stats .response-pill {
    background: #f1f5f9;
    color: #0f172a;
    padding: 2px 6px;
    border-radius: 999px;
    font-size: 10px;
    font-weight: 600;
}

@media (max-width: 992px) {
    .home-wireframe .top-sellers-grid {
        grid-template-columns: repeat(2, minmax(0, 1fr));
    }
}

@media (max-width: 600px) {
    .home-wireframe .top-sellers-grid {
        grid-template-columns: repeat(2, minmax(0, 1fr));
    }
}

/* --- FOOTER --- */
.site-footer {
    background-color: var(--dark-navy);
    color: #a0a6b5;
    padding: 60px 0 20px 0;
    margin-top: 60px;
    font-size: 14px;
}

.site-footer .footer-grid {
    display: grid;
    grid-template-columns: 1.5fr 1fr 1fr 1.5fr 1fr;
    gap: 30px;
    border-bottom: 1px solid #1f2633;
    padding-bottom: 40px;
    margin-bottom: 20px;
}

.site-footer .footer-col h3 {
    color: white;
    margin: 0 0 20px;
    font-size: 16px;
}

.site-footer .footer-col p {
    line-height: 1.6;
    margin: 0 0 15px;
}

.site-footer .footer-col ul {
    list-style: none;
    padding: 0;
    margin: 0;
}

.site-footer .footer-col ul li {
    margin-bottom: 12px;
}

.site-footer .footer-col ul li a:hover {
    color: white;
}

.site-footer .social-icons a {
    display: inline-block;
    width: 40px;
    height: 40px;
    background: #1f2633;
    color: white;
    text-align: center;
    line-height: 32px;
    border-radius: 4px;
    margin-right: 5px;
}

.site-footer .btn-download {
    background: #1f2633;
    color: #777;
    padding: 10px;
    border-radius: 6px;
    text-align: center;
    display: block;
    margin-top: 10px;
    font-weight: 700;
}

.site-footer .footer-bottom {
    display: flex;
    justify-content: space-between;
    font-size: 12px;
}

.site-footer a {
    text-decoration: none;
    color: inherit;
}

.site-footer .footer-language {
    margin-top: 16px;
}

.site-footer .footer-language h4 {
    color: white;
    font-size: 14px;
    margin: 12px 0 8px;
}

.site-footer .language-switcher {
    position: relative;
    display: inline-flex;
}

.site-footer .language-chip {
    display: inline-flex;
    align-items: center;
    gap: 6px;
    background: #1f2633;
    color: #fff;
    border: 1px solid #2b3444;
    border-radius: 999px;
    padding: 6px 12px;
    cursor: pointer;
    font-size: 12px;
    font-weight: 600;
}

.site-footer .language-panel {
    position: absolute;
    bottom: calc(100% + 8px);
    right: 0;
    min-width: 200px;
    background: #fff;
    color: #111;
    border-radius: 12px;
    box-shadow: 0 12px 24px rgba(0, 0, 0, 0.15);
    padding: 10px;
    display: none;
    z-index: 50;
}

.site-footer .language-panel.open {
    display: block;
}

.site-footer .language-panel .dropdown-item {
    width: 100%;
    text-align: left;
    border: none;
    background: transparent;
    padding: 8px 10px;
    border-radius: 8px;
    font-size: 13px;
    cursor: pointer;
}

.site-footer .language-panel .dropdown-item.active,
.site-footer .language-panel .dropdown-item:hover {
    background: #f1f5f9;
}

/* --- MOBILE NAV --- */
.mobile-nav,
.home-wireframe .mobile-nav {
    display: none;
    position: fixed;
    bottom: 0;
    left: 0;
    width: 100%;
    background: white;
    box-shadow: 0 -2px 10px rgba(0, 0, 0, 0.1);
    z-index: 1000;
    justify-content: space-around;
    padding: 10px 0;
    border-top: 1px solid #eee;
}

.mobile-nav .nav-item,
.home-wireframe .nav-item {
    display: flex;
    flex-direction: column;
    align-items: center;
    color: #777;
    font-size: 10px;
}

.mobile-nav .nav-item i,
.home-wireframe .nav-item i {
    font-size: 20px;
    margin-bottom: 4px;
}

.mobile-nav .nav-item.active,
.home-wireframe .nav-item.active {
    color: var(--primary-green);
}

.mobile-nav .nav-item-sell,
.home-wireframe .nav-item-sell {
    transform: translateY(-25px);
    background: var(--accent-orange);
    color: white;
    width: 55px;
    height: 55px;
    border-radius: 50%;
    display: flex;
    align-items: center;
    justify-content: center;
    box-shadow: 0 4px 10px rgba(255, 140, 0, 0.4);
    border: 4px solid white;
}

.mobile-nav .nav-item-sell i,
.home-wireframe .nav-item-sell i {
    margin: 0;
    font-size: 24px;
}

.mobile-nav .nav-item-sell span,
.home-wireframe .nav-item-sell span {
    display: none;
}

/* --- SUB-CATEGORY SLIDE-IN VIEW --- */
.sub-cat-view {
    display: none;
}

.sub-search-input {
    display: none;
}

.home-wireframe .sub-cat-view {
    position: fixed;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    background: white;
    z-index: 3000;
    transform: translateX(100%);
    transition: transform 0.3s ease-in-out;
    display: flex;
    flex-direction: column;
}

.home-wireframe .sub-cat-view.active {
    transform: translateX(0);
}

.home-wireframe .sub-cat-header {
    background: var(--primary-green);
    padding: 15px;
    display: flex;
    align-items: center;
    gap: 15px;
    color: white;
    flex-shrink: 0;
}

.home-wireframe .back-btn {
    font-size: 20px;
    cursor: pointer;
}

.home-wireframe .sub-search-input {
    flex: 1;
    background: white;
    border-radius: 4px;
    padding: 10px 12px;
    display: flex;
    align-items: center;
}

.home-wireframe .sub-search-input input {
    width: 100%;
    border: none;
    outline: none;
    font-size: 16px;
    background: transparent;
}

.home-wireframe .sub-cat-list-container {
    flex: 1;
    overflow-y: auto;
    -webkit-overflow-scrolling: touch;
    background: #fff;
}

.home-wireframe .sub-cat-list {
    list-style: none;
    padding: 0;
    margin: 0;
}

.home-wireframe .sub-list-item {
    display: flex;
    align-items: center;
    gap: 15px;
    padding: 15px;
    border-bottom: 1px solid #f0f0f0;
    cursor: pointer;
}

.home-wireframe .sub-list-item:hover {
    background: #f9f9f9;
}

.home-wireframe .sub-list-img-con {
    width: 50px;
    height: 50px;
    background: #f0f6fa;
    border-radius: 12px;
    display: flex;
    align-items: center;
    justify-content: center;
    overflow: hidden;
    flex-shrink: 0;
}

.home-wireframe .sub-list-img-con img {
    width: 35px;
    height: 35px;
    object-fit: contain;
}

.home-wireframe .sub-list-text h4 {
    font-size: 16px;
    font-weight: 500;
    color: var(--text-dark);
    margin-bottom: 4px;
}

.home-wireframe .sub-list-text span {
    font-size: 13px;
    color: var(--text-gray);
}

@media (max-width: 900px) {
    .home-wireframe .hero {
        padding: 20px 0;
    }

    .site-header .header-actions .btn-sell,
    .site-header .header-actions .header-icon {
        display: none;
    }

    .home-wireframe .sidebar {
        display: none;
    }

    .home-wireframe .search-input-group.location-box,
    .home-wireframe .search-input-group.keyword-box {
        flex: auto;
        width: 100%;
        margin-bottom: 10px;
    }

    .home-wireframe .info-boxes {
        grid-template-columns: repeat(3, 1fr) !important;
        gap: 8px;
    }

    .home-wireframe .info-card {
        height: 85px;
        padding: 10px 5px;
    }

    .home-wireframe .info-card h3 {
        font-size: 11px;
    }

    .home-wireframe .info-card-icon {
        width: 40px;
        height: 40px;
        top: 5px;
    }

    .home-wireframe .ads-grid {
        grid-template-columns: 1fr 1fr;
    }

    .home-wireframe .events-grid {
        grid-template-columns: 1fr 1fr;
    }

    .home-wireframe .mobile-categories {
        display: block;
    }

    .home-wireframe .main-wrapper {
        display: block;
        margin-top: 0;
    }

    .site-footer .footer-grid {
        grid-template-columns: repeat(3, minmax(0, 1fr)) !important;
        text-align: left;
        gap: 12px;
    }

    .site-footer .footer-col-categories,
    .site-footer .footer-col-why {
        display: none !important;
    }

    .site-footer .footer-col h3 {
        font-size: 13px;
        margin-bottom: 12px;
    }

    .site-footer .footer-col p,
    .site-footer .footer-col li {
        font-size: 11px !important;
    }

    .site-footer .btn-download {
        padding: 1px;
    }

    .footer-language {
        display: none;
    }

    .mobile-nav,
    .home-wireframe .mobile-nav {
        display: flex;
    }

    .home-wireframe .search-bar-wrapper {
        flex-direction: column;
        border-radius: 16px;
        padding: 12px;
    }

    .home-wireframe .search-divider {
        display: none;
    }

    .home-wireframe .btn-search {
        width: 100%;
    }

    .home-wireframe .local-post {
        flex-direction: column;
    }

    .home-wireframe .post-thumb {
        width: 100%;
        height: 150px;
    }

    .home-wireframe .happening-header {
        align-items: flex-start;
    }

    .home-wireframe .btn-post-update {
        padding: 6px 12px;
        font-size: 11px;
    }

    .home-wireframe .top-seller-card {
        min-height: 150px;
    }

    .home-wireframe .top-seller-thumb {
        height: 72px;
    }

    .home-wireframe .top-seller-logo {
        width: 34px;
        height: 34px;
        border-radius: 8px;
        bottom: -12px;
        font-size: 0.7rem;
    }

    .home-wireframe .top-seller-body {
        padding: 22px 10px 10px;
    }

    .home-wireframe .top-seller-stats {
        gap: 4px;
    }

    .home-wireframe .top-seller-stats .response-pill {
        font-size: 9px;
    }
}

/* --- ACCOUNT-STYLE HEADER DROPDOWNS + LOCATION CHIP --- */
.site-header .header-flex {
    gap: 16px;
    flex-wrap: nowrap;
}

.site-header .header-location {
    display: flex;
    align-items: center;
}

.site-header .location-chip {
    display: inline-flex;
    align-items: center;
    gap: 8px;
    border: 1px solid rgba(255, 255, 255, 0.35);
    background: rgba(255, 255, 255, 0.12);
    color: #fff;
    padding: 6px 12px;
    border-radius: 999px;
    cursor: pointer;
    font-size: 13px;
    font-weight: 600;
}

.site-header .location-chip i {
    font-size: 12px;
}

.site-header .location-chip .location-chip-text {
    max-width: 120px;
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
}

.site-header .header-searchbar {
    flex: 1;
    max-width: 480px;
    display: flex;
    align-items: center;
    gap: 8px;
    background: #fff;
    border-radius: 8px;
    padding: 4px 6px;
    box-shadow: 0 6px 12px rgba(0, 0, 0, 0.12);
}

.site-header .header-search-input {
    flex: 1;
    display: flex;
    align-items: center;
    gap: 8px;
    padding: 4px 6px;
    position: relative;
}

.site-header .header-search-input i {
    color: #94a3b8;
    font-size: 14px;
}

.site-header .header-search-input input {
    border: none;
    outline: none;
    background: transparent;
    width: 100%;
    font-size: 14px;
    color: #111;
}

.site-header .header-search-btn {
    background: var(--primary-green);
    color: #fff;
    border: none;
    padding: 6px 12px;
    border-radius: 6px;
    font-weight: 600;
    font-size: 13px;
    cursor: pointer;
}

.site-header .header-searchbar--guest {
    max-width: 640px;
    padding: 6px 10px;
    box-shadow: 0 4px 12px rgba(0, 0, 0, 0.18);
}

.site-header .header-searchbar--guest .header-search-input {
    flex-direction: row-reverse;
}

.site-header .header-searchbar--guest .header-search-input i {
    margin-left: 10px;
    margin-right: 0;
}

.site-header .header-searchbar--guest .header-search-input input {
    font-size: 16px;
    color: #2f2f2f;
}

.site-header .header-auth-link {
    color: #fff;
    font-weight: 600;
    font-size: 15px;
}

.site-header .header-auth-sep {
    color: rgba(255, 255, 255, 0.75);
    font-weight: 600;
}

.site-header .profile-chip {
    display: flex;
    align-items: center;
    gap: 10px;
    background: transparent;
    border: none;
    padding: 4px 0;
    border-radius: 0;
    color: #fff;
    cursor: pointer;
}

.site-header .profile-chip .avatar {
    width: 32px;
    height: 32px;
    border-radius: 50%;
    background: #fff;
    color: var(--primary-green);
    display: flex;
    align-items: center;
    justify-content: center;
    font-weight: 700;
    font-size: 12px;
}

.site-header .profile-chip .avatar.avatar-photo {
    background: transparent;
    overflow: hidden;
}

.site-header .profile-chip .avatar.avatar-photo img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    display: block;
    border-radius: 50%;
}

.site-header .profile-chip .profile-text {
    display: flex;
    flex-direction: column;
    line-height: 1.1;
    font-size: 11px;
}

.site-header .profile-chip .profile-text strong {
    font-size: 12px;
}

.site-header .dropdown-panel:not(.new-profile-panel) {
    position: absolute;
    top: calc(100% + 12px);
    right: 0;
    background: #ffffff;
    color: #0f172a;
    min-width: 248px;
    max-width: 288px;
    padding: 10px;
    border: 1px solid #e2e8f0;
    border-radius: 12px;
    box-shadow: 0 12px 26px rgba(15, 23, 42, 0.16);
    display: none;
    z-index: 2000;
}

.site-header .dropdown-panel.open:not(.new-profile-panel) {
    display: block;
}

.site-header .profile-panel:not(.new-profile-panel) {
    display: grid;
    gap: 2px;
}

.site-header .profile-panel .dropdown-head {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 8px;
    margin-bottom: 4px;
    padding: 2px 8px 6px;
    border-bottom: 1px solid #f1f5f9;
}

.site-header .profile-panel .dropdown-head .title {
    font-size: 12px;
    font-weight: 700;
    color: #0f172a;
    text-decoration: none;
}

.site-header .profile-panel .dropdown-head .action {
    font-size: 11px;
    color: #64748b;
    font-weight: 600;
}

.site-header .profile-panel-head {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 8px;
    padding: 2px 4px 6px;
}

.site-header .profile-panel-user {
    display: flex;
    align-items: center;
    gap: 10px;
}

.site-header .profile-panel-user-icon {
    width: 28px;
    height: 28px;
    border-radius: 999px;
    display: flex;
    align-items: center;
    justify-content: center;
    background: #eff6ff;
    color: #1d4ed8;
    flex: 0 0 auto;
}

.site-header .profile-panel-user-meta {
    display: grid;
    gap: 2px;
}

.site-header .profile-panel-user-meta strong {
    font-size: 12px;
    line-height: 1.1;
    color: #0f172a;
}

.site-header .profile-panel-user-meta span {
    font-size: 10px;
    color: #64748b;
}

.site-header .panel-dashboard-link {
    display: inline-flex;
    width: fit-content;
    align-items: center;
    padding: 4px 8px;
    border-radius: 999px;
    background: #eef2ff;
    color: #334155;
    font-size: 10px;
    font-weight: 700;
    text-decoration: none;
}

.site-header .panel-dashboard-link:hover {
    background: #e2e8f0;
}

.site-header .profile-panel-section {
    display: grid;
    gap: 2px;
    border-top: none;
    padding-top: 0;
}

.site-header .profile-panel-section+.profile-panel-section {
    border-top: 1px solid #f1f5f9;
    padding-top: 6px;
    margin-top: 2px;
}

.site-header .profile-panel-section-title {
    font-size: 10px;
    font-weight: 700;
    letter-spacing: 0.03em;
    text-transform: uppercase;
    color: #94a3b8;
    padding: 0 8px 1px;
}

.site-header .profile-panel .profile-link {
    display: flex;
    align-items: center;
    gap: 10px;
    padding: 7px 8px;
    border-radius: 8px;
    color: #0f172a;
    font-size: 13px;
    text-decoration: none;
}

.site-header .profile-panel .profile-link i {
    width: 14px;
    text-align: center;
    color: #64748b;
}

.site-header .profile-panel .profile-link:hover {
    background: #f1f5f9;
    color: #0f172a;
}

.site-header .profile-panel .profile-link:hover i {
    color: #334155;
}

.site-header .profile-panel .profile-link.danger {
    color: #b91c1c;
}

.site-header .profile-panel .profile-link.danger i {
    color: #b91c1c;
}

.site-header .profile-panel .profile-link.danger:hover {
    background: #fee2e2;
    color: #991b1b;
}

.site-header .mobile-menu-btn {
    display: none;
    color: #fff;
    font-size: 20px;
    align-items: center;
    justify-content: center;
}

.mobile-actions-panel {
    display: none;
    background: linear-gradient(180deg, #f8fafc 0%, #ffffff 100%);
    color: #111;
    padding: 18px 16px 20px;
    border-bottom: 1px solid #e2e8f0;
    box-shadow: 0 14px 24px rgba(15, 23, 42, 0.08);
    border-bottom-left-radius: 16px;
    border-bottom-right-radius: 16px;
}

.mobile-actions-panel.open {
    display: block;
}

.mobile-panel-group+.mobile-panel-group {
    margin-top: 16px;
}

.mobile-panel-title {
    font-size: 12px;
    font-weight: 700;
    letter-spacing: 0.5px;
    text-transform: uppercase;
    color: #64748b;
    margin-bottom: 8px;
}

.mobile-panel-links {
    display: grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    column-gap: 12px;
    row-gap: 8px;
}

.mobile-panel-actions {
    display: flex;
    flex-wrap: wrap;
    gap: 8px;
}

.mobile-lang-btn {
    border: 1px solid #e2e8f0;
    background: #f8fafc;
    color: #111;
    padding: 6px 10px;
    border-radius: 999px;
    font-size: 12px;
}

.mobile-lang-btn.active {
    background: #e2e8f0;
    font-weight: 700;
}

.mobile-location-btn {
    border: none;
    width: 100%;
}

.mobile-panel-link {
    display: flex;
    align-items: center;
    justify-content: flex-start;
    gap: 6px;
    padding: 2px 0 2px 12px;
    background: transparent;
    border: none;
    border-radius: 0;
    color: #0f172a;
    font-weight: 600;
    font-size: 12px;
    text-decoration: none;
    position: relative;
    text-align: left;
    flex-wrap: nowrap;
    cursor: pointer;
}

.mobile-panel-link::before {
    content: "|";
    position: absolute;
    left: 0;
    color: #cbd5e1;
}

.mobile-panel-link:nth-child(3n+1)::before {
    content: "";
}

.mobile-panel-link i {
    display: none;
}

.mobile-panel-link span {
    line-height: 1;
    white-space: nowrap;
}

.mobile-badge {
    position: static;
    margin-left: 4px;
    background: #ef4444;
    color: #fff;
    border-radius: 999px;
    font-size: 10px;
    padding: 1px 5px;
    line-height: 1;
}

.mobile-panel-link i {
    font-size: 14px;
    color: #16a34a;
}

.mobile-panel-link span {
    line-height: 1;
}

.mobile-badge {
    position: absolute;
    top: 6px;
    right: 8px;
    background: #ef4444;
    color: #fff;
    border-radius: 999px;
    font-size: 10px;
    padding: 2px 5px;
    line-height: 1;
}

@media (max-width: 900px) {
    .site-header .header-searchbar {
        display: none;
    }

    .site-header .header-actions .profile-chip,
    .site-header .header-actions .header-icon,
    .site-header .header-actions .header-auth-link,
    .site-header .header-actions .header-auth-sep,
    .site-header .location-chip {
        display: none;
    }

    .site-header .header-actions .btn-sell {
        display: inline-flex;
    }

    .site-header .mobile-menu-btn {
        display: inline-flex;
    }

    .site-header .btn-sell {
        background: linear-gradient(135deg, #28a745 0%, #f68b1e 100%);
        border-radius: 999px;
        padding: 10px 22px;
        font-size: 13px;
        letter-spacing: 0.06em;
        box-shadow: 0 6px 14px rgba(16, 185, 129, 0.25);
    }
}

/* --- Footer alignment overrides to match wireframe --- */
.site-footer .footer-bottom {
    border-top: none;
    padding-top: 0;
    text-align: left;
}

/* ================= AD DETAILS PAGE (Jiji-style) ================= */
.ad-details-page {
    --jiji-green: #3db83a;
    --jiji-green-dark: #2e8b2c;
    --jiji-bg: #eff2f3;
    --text-dark: #3a3a3a;
    --text-muted: #888;
    --accent-orange: #ff9e42;
    background-color: var(--jiji-bg);
    font-family: "Segoe UI", Roboto, Helvetica, Arial, sans-serif;
    color: var(--text-dark);
    padding-bottom: 70px;
}

.ad-details-page a {
    text-decoration: none;
    color: inherit;
}

.ad-details-page .container {
    width: 100%;
    max-width: 1200px;
    margin: 0 auto;
    padding: 0 16px;
}

.ad-details-page .row {
    display: flex;
    flex-wrap: wrap;
    margin: 0 -10px;
}

.ad-details-page .col-lg-8,
.ad-details-page .col-lg-4 {
    width: 100%;
    padding: 0 10px;
}

@media (min-width: 992px) {
    .ad-details-page .col-lg-8 {
        width: 66.6667%;
    }

    .ad-details-page .col-lg-4 {
        width: 33.3333%;
    }
}

.ad-details-page .d-flex {
    display: flex;
}

.ad-details-page .align-items-center {
    align-items: center;
}

.ad-details-page .align-items-start {
    align-items: flex-start;
}

.ad-details-page .justify-content-between {
    justify-content: space-between;
}

.ad-details-page .gap-2 {
    gap: 8px;
}

.ad-details-page .ms-auto {
    margin-left: auto;
}

.ad-details-page .mt-2 {
    margin-top: 8px;
}

.ad-details-page .mt-3 {
    margin-top: 16px;
}

.ad-details-page .mb-2 {
    margin-bottom: 8px;
}

.ad-details-page .mb-3 {
    margin-bottom: 12px;
}

.ad-details-page .pb-5 {
    padding-bottom: 32px;
}

.ad-details-page .py-2 {
    padding-top: 8px;
    padding-bottom: 8px;
}

.ad-details-page .p-2 {
    padding: 8px;
}

.ad-details-page .small {
    font-size: 12px;
}

.ad-details-page .fw-bold {
    font-weight: 700;
}

.ad-details-page .text-muted {
    color: #888;
}

.ad-details-page .text-success {
    color: #3db83a;
}

.ad-details-page .opacity-25 {
    opacity: 0.25;
}

.ad-details-page .breadcrumb {
    display: flex;
    flex-wrap: wrap;
    list-style: none;
    padding: 0;
    margin: 0;
    font-size: 13px;
    color: #888;
}

.ad-details-page .breadcrumb-item+.breadcrumb-item:before {
    content: "/";
    margin: 0 6px;
    color: #bbb;
}

.ad-details-page .breadcrumb-item {
    max-width: 100%;
    word-break: break-word;
}

.ad-details-page .breadcrumb-item a {
    color: inherit;
    white-space: normal;
}

.ad-details-page .breadcrumb-item.active {
    color: #999;
    white-space: normal;
}

.ad-details-page .btn {
    border: 1px solid transparent;
    background: #ffffff;
    cursor: pointer;
    font-family: inherit;
}

.ad-details-page .btn-sm {
    padding: 6px;
    font-size: 12px;
}

.ad-details-page .btn-light {
    background: #f8f9fa;
}

.ad-details-page .rounded-circle {
    border-radius: 999px;
}

.ad-details-page .shadow-sm {
    box-shadow: 0 1px 3px rgba(0, 0, 0, 0.15);
}

.ad-details-page .border-0 {
    border: 0;
}

.ad-details-page .btn-outline-danger {
    color: #dc3545;
    border: 1px solid #dc3545;
}

.ad-details-page .btn-outline-success {
    color: #2e8b2c;
    border: 1px solid #2e8b2c;
    background: transparent;
}

.ad-details-page .w-100 {
    width: 100%;
}

.ad-details-page .flex-grow-1 {
    flex: 1;
}

.ad-details-page .ps-1 {
    padding-left: 4px;
}

.ad-details-page .details-card {
    background: white;
    border-radius: 4px;
    padding: 20px;
    margin-bottom: 15px;
    box-shadow: 0 1px 2px rgba(0, 0, 0, 0.05);
}

.ad-details-page .ad-gallery-main {
    height: 400px;
    background-color: #e0e0e0;
    border-radius: 4px;
    display: flex;
    align-items: center;
    justify-content: center;
    color: #aaa;
    position: relative;
    overflow: hidden;
}

.ad-details-page .ad-gallery-main .badge-container {
    position: absolute;
    left: 8px;
    bottom: 8px;
    display: flex;
    gap: 6px;
    flex-wrap: wrap;
    max-width: calc(100% - 16px);
    z-index: 6;
    pointer-events: none;
}

.ad-details-page .ad-gallery-main .ad-badge {
    font-size: 10px;
    padding: 3px 7px;
    border-radius: 4px;
    color: #fff;
    font-weight: 700;
    text-transform: uppercase;
    display: inline-flex;
    align-items: center;
    gap: 4px;
    box-shadow: 0 2px 8px rgba(0, 0, 0, 0.25);
    line-height: 1.2;
    pointer-events: auto;
}

.ad-details-page .ad-gallery-main .ad-badge i {
    font-size: 10px;
}

.ad-details-page .ad-gallery-main .ad-badge.badge-top {
    background: #00bcd4;
}

.ad-details-page .ad-gallery-main .ad-badge.badge-premium {
    background: linear-gradient(45deg, #ffd700, #ffaa00);
    color: #1f2937;
}

.ad-details-page .ad-gallery-main .ad-badge.badge-elite {
    background: #7c3aed;
}

.ad-details-page .ad-gallery-main .ad-badge.badge-urgent {
    background: #ef4444;
}

.ad-details-page .ad-gallery-main .ad-badge.badge-inspected {
    background: #22c55e;
}

.ad-details-page .ad-gallery-main .ad-badge.badge-colored {
    background: #ec4899;
}

.ad-details-page .ad-gallery-main .ad-badge.badge-featured {
    background: #3b82f6;
}

.ad-details-page .ad-gallery-main .ad-badge.badge-escrow {
    background: #16a34a;
}

.ad-details-page .ad-gallery-main .ad-badge.badge-condition {
    background: #334155;
}

.ad-details-page .ad-gallery-main .ad-badge.badge-negotiable {
    background: #f97316;
}

.ad-details-page .ad-gallery-main .ad-badge.badge-warning {
    background: #f59e0b;
    color: #1f2937;
}

.ad-details-page .ad-main-image {
    width: 100%;
    height: 100%;
    object-fit: cover;
}

.ad-details-page .gallery-badge-count {
    position: absolute;
    top: 12px;
    right: 12px;
    background: rgba(0, 0, 0, 0.6);
    color: white;
    padding: 5px 10px;
    border-radius: 4px;
    font-size: 12px;
}

.ad-details-page .ad-gallery-thumbs {
    display: flex;
    gap: 10px;
    margin-top: 10px;
    overflow-x: auto;
}

.ad-details-page .thumb-item {
    width: 80px;
    height: 60px;
    background-color: #ddd;
    border-radius: 4px;
    flex-shrink: 0;
    cursor: pointer;
    border: 2px solid transparent;
    background-size: cover;
    background-position: center;
}

.ad-details-page .thumb-item.active {
    border-color: var(--jiji-green);
}

.ad-details-page .ad-title-h1 {
    font-weight: 700;
    font-size: 24px;
    margin-bottom: 10px;
    line-height: 1.3;
}

.ad-details-page .ad-meta-row {
    font-size: 13px;
    color: #999;
    margin-bottom: 20px;
    display: flex;
    gap: 20px;
    border-bottom: 1px solid #eee;
    padding-bottom: 15px;
    flex-wrap: wrap;
}

.ad-details-page .ad-meta-badges {
    display: flex;
    flex-wrap: wrap;
    gap: 8px;
    margin: -4px 0 18px;
}

.ad-details-page .ad-meta-badge {
    display: inline-flex;
    align-items: center;
    gap: 6px;
    padding: 6px 12px;
    border-radius: 999px;
    font-size: 11px;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: 0.4px;
    background: #f1f5f9;
    color: #0f172a;
    border: 1px solid rgba(15, 23, 42, 0.08);
    box-shadow: 0 2px 6px rgba(15, 23, 42, 0.12);
    position: relative;
}

.ad-details-page .ad-meta-badge[data-tooltip]::after {
    content: attr(data-tooltip);
    position: absolute;
    bottom: 120%;
    left: 0;
    padding: 8px 10px;
    border-radius: 8px;
    background: #0f172a;
    color: #f8fafc;
    font-size: 11px;
    opacity: 0;
    pointer-events: none;
    transform: translateY(4px);
    transition: opacity 0.2s ease, transform 0.2s ease;
    white-space: nowrap;
}

.ad-details-page .ad-meta-badge[data-tooltip]:hover::after {
    opacity: 1;
    transform: translateY(0);
}

.ad-details-page .badge-premium {
    background: #f4c542;
    color: #1f2937;
}

.ad-details-page .badge-elite {
    background: #ede9fe;
    color: #6d28d9;
}

.ad-details-page .badge-top {
    background: #dbeafe;
    color: #1d4ed8;
}

.ad-details-page .badge-urgent {
    background: #fee2e2;
    color: #b91c1c;
}

.ad-details-page .badge-inspected {
    background: #dcfce7;
    color: #15803d;
}

.ad-details-page .badge-colored {
    background: #fce7f3;
    color: #be185d;
}

.ad-details-page .badge-featured {
    background: #e0f2fe;
    color: #0369a1;
}

.ad-details-page .badge-escrow {
    background: #ecfdf3;
    color: #15803d;
}

.ad-details-page .badge-condition {
    background: #f1f5f9;
    color: #334155;
}

.ad-details-page .badge-negotiable {
    background: #fff7ed;
    color: #c2410c;
}

.ad-details-page .badge-new {
    background: #ff6a3d;
    color: #ffffff;
}

.ad-details-page .ad-meta-row {
    display: flex;
    flex-wrap: nowrap;
    gap: 14px;
    font-size: 13px;
    color: #666;
    margin-bottom: 16px;
    overflow-x: auto;
    -webkit-overflow-scrolling: touch;
    scrollbar-width: none;
}

.ad-details-page .ad-meta-row::-webkit-scrollbar {
    display: none;
}

.ad-details-page .ad-meta-row span {
    display: inline-flex;
    align-items: center;
    gap: 5px;
    white-space: nowrap;
    flex-shrink: 0;
}

.ad-details-page .ad-meta-row span i {
    font-size: 13px;
    color: #999;
}

.ad-details-page .attribute-grid {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 15px;
    margin-bottom: 25px;
}

@media (min-width: 768px) {
    .ad-details-page .attribute-grid {
        grid-template-columns: 1fr 1fr 1fr;
    }
}

.ad-details-page .attr-box {
    font-size: 14px;
}

.ad-details-page .attr-label {
    color: #888;
    display: block;
    font-size: 12px;
    margin-bottom: 2px;
}

.ad-details-page .attr-value {
    font-weight: 500;
    color: var(--text-dark);
}

.ad-details-page .description-text {
    font-size: 15px;
    line-height: 1.6;
    color: #444;
    white-space: pre-line;
}

.ad-details-page .listing-video-embed {
    margin-top: 16px;
    border-radius: 14px;
    overflow: hidden;
    box-shadow: 0 12px 30px rgba(0, 0, 0, 0.08);
    background: #0f172a;
}

.ad-details-page .listing-video-embed iframe {
    display: block;
    width: 100%;
    border: 0;
}

.ad-details-page .sticky-sidebar {
    position: sticky;
    top: 80px;
}

.ad-details-page .price-card-box {
    text-align: left;
    padding: 22px 18px;
}

.ad-details-page .main-price {
    color: var(--jiji-green);
    font-weight: 800;
    font-size: 28px;
    margin-bottom: 5px;
}

.ad-details-page .price-block {
    text-align: center;
    padding: 12px 10px;
    border-radius: 14px;
    background: linear-gradient(180deg, #ffffff 0%, #f8fafc 100%);
    box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.7);
    margin-bottom: 10px;
}

.ad-details-page .price-note {
    font-size: 12px;
    font-weight: 600;
    color: #94a3b8;
    margin-bottom: 8px;
}

.ad-details-page .seller-profile-mini {
    display: flex;
    align-items: flex-start;
    gap: 12px;
    text-align: left;
    margin-top: 12px;
    padding-top: 12px;
    border-top: 1px solid #eef2f7;
}

.ad-details-page .seller-avatar-mini {
    width: 64px;
    height: 64px;
    border-radius: 50%;
    background: #f0f0f0;
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 30px;
    color: #ccc;
    border: 2px solid white;
    box-shadow: 0 2px 5px rgba(0, 0, 0, 0.1);
    overflow: hidden;
    position: relative;
}

.ad-details-page .seller-avatar-image {
    width: 100%;
    height: 100%;
    object-fit: cover;
    border-radius: 50%;
}

.ad-details-page .seller-name-link {
    font-weight: 700;
    font-size: 16px;
    margin-bottom: 2px;
    display: block;
}

.ad-details-page .seller-info-mini {
    flex: 1;
    display: flex;
    flex-direction: column;
    align-items: flex-start;
}

.ad-details-page .seller-verified-badge {
    font-size: 11px;
    background: #e6f7ec;
    color: var(--jiji-green);
    padding: 2px 8px;
    border-radius: 10px;
    font-weight: 600;
}

.ad-details-page .seller-badge-row {
    display: flex;
    flex-wrap: wrap;
    gap: 6px;
    justify-content: flex-start;
    margin-top: 4px;
}

.ad-details-page .seller-badge {
    display: inline-flex;
    align-items: center;
    gap: 2px;
    font-size: 9px;
    font-weight: 700;
    padding: 2px 5px;
    border-radius: 999px;
    background: #f1f5f9;
    color: #0f172a;
    position: relative;
}

.ad-details-page .seller-badge.verified {
    background: #e6f7ec;
    color: #15803d;
}

.ad-details-page .seller-badge.phone {
    background: #dbeafe;
    color: #1d4ed8;
}

.ad-details-page .seller-badge.trust {
    background: #ede9fe;
    color: #6d28d9;
}

.ad-details-page .seller-badge.elite {
    background: #fef3c7;
    color: #b45309;
}

.ad-details-page .seller-badge.new {
    background: #ffedd5;
    color: #c2410c;
}

.ad-details-page .seller-badge.meta {
    background: #f1f5f9;
    color: #475569;
}

.ad-details-page .seller-response {
    line-height: 1.5;
    font-size: 12px;
}

.ad-details-page .action-buttons {
    display: flex;
    flex-direction: column;
    gap: 10px;
    margin-top: 12px;
    width: 100%;
}

.ad-details-page .btn-action-lg {
    padding: 12px;
    font-weight: 700;
    border-radius: 6px;
    width: 100%;
    border: none;
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 10px;
    font-size: 15px;
    box-shadow: 0 4px 6px rgba(0, 0, 0, 0.1);
    transition: transform 0.1s;
}

.ad-details-page .btn-action-lg:active {
    transform: scale(0.98);
}

.ad-details-page .btn-show-contact {
    background-color: var(--jiji-green);
    color: white;
}

.ad-details-page .btn-show-contact:hover {
    background-color: var(--jiji-green-dark);
    color: white;
}

.ad-details-page .btn-start-chat {
    background-color: white;
    border: 2px solid var(--jiji-green);
    color: var(--jiji-green);
    box-shadow: none;
}

.ad-details-page .btn-start-chat:hover {
    background-color: #f0f9f2;
}

.ad-details-page .btn-make-offer {
    background: linear-gradient(135deg, rgba(34, 197, 94, 0.12), rgba(34, 197, 94, 0.03));
    border: 2px solid rgba(34, 197, 94, 0.45);
    color: #15803d;
    box-shadow: 0 8px 18px rgba(34, 197, 94, 0.2);
}

.ad-details-page .btn-make-offer:hover {
    background: linear-gradient(135deg, rgba(34, 197, 94, 0.2), rgba(34, 197, 94, 0.06));
}

.ad-details-page .btn-make-offer-inline {
    margin: 0 auto 8px;
    width: 100%;
    border-radius: 10px;
    padding: 10px 12px;
}

.ad-details-page .btn-escrow-safe {
    background: #f9f5ff;
    border: 2px solid #a78bfa;
    color: #6d28d9;
    box-shadow: none;
}

.ad-details-page .btn-escrow-safe:hover {
    background: #ede9fe;
}

.ad-details-page .safety-tips-box {
    background-color: #fff;
    border: 1px solid #e0e0e0;
    border-radius: 4px;
    padding: 15px;
    font-size: 13px;
}

.ad-details-page .escrow-seal {
    margin-top: 12px;
    display: flex;
    gap: 12px;
    align-items: center;
    background: rgba(236, 253, 243, 0.7);
    border: 1px solid rgba(16, 185, 129, 0.25);
    padding: 10px 12px;
    border-radius: 16px;
    backdrop-filter: blur(8px);
    box-shadow: 0 8px 24px rgba(16, 185, 129, 0.12);
}

.ad-details-page .escrow-seal-icon {
    width: 36px;
    height: 36px;
    border-radius: 12px;
    background: rgba(22, 163, 74, 0.85);
    color: #ffffff;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    font-size: 18px;
    box-shadow: inset 0 0 12px rgba(255, 255, 255, 0.35);
}

.ad-details-page .escrow-seal-text strong {
    display: block;
    font-size: 13px;
    color: #0f172a;
}

.ad-details-page .escrow-seal-text span {
    font-size: 12px;
    color: #475569;
}

.ad-details-page .escrow-guide-card {
    margin-top: 12px;
    border-radius: 14px;
    border: 1px solid rgba(99, 102, 241, 0.2);
    background: linear-gradient(145deg, #f8faff, #f1f5ff);
    padding: 12px 14px;
}

.ad-details-page .escrow-guide-card h5 {
    margin: 0 0 8px;
    font-size: 13px;
    font-weight: 700;
    color: #1e293b;
    display: inline-flex;
    align-items: center;
    gap: 8px;
}

.ad-details-page .escrow-guide-steps {
    margin: 0;
    padding-left: 18px;
    display: grid;
    gap: 6px;
    font-size: 12px;
    color: #334155;
}

.ad-details-page .escrow-guide-note {
    margin: 8px 0 0;
    font-size: 11px;
    color: #475569;
    font-weight: 600;
}

.ad-details-page .online-indicator {
    position: absolute;
    bottom: 4px;
    right: 2px;
    width: 12px;
    height: 12px;
    border-radius: 50%;
    border: 2px solid #ffffff;
    box-shadow: 0 0 0 3px rgba(148, 163, 184, 0.2);
}

.ad-details-page .online-indicator.online {
    background: #22c55e;
    box-shadow: 0 0 0 3px rgba(34, 197, 94, 0.15);
}

.ad-details-page .online-indicator.offline {
    background: #94a3b8;
}

.ad-details-page [data-tooltip]::after {
    content: attr(data-tooltip);
    position: absolute;
    bottom: 120%;
    left: 0;
    padding: 6px 10px;
    border-radius: 10px;
    background: #0f172a;
    color: #f8fafc;
    font-size: 11px;
    opacity: 0;
    pointer-events: none;
    transform: translateY(4px);
    transition: opacity 0.2s ease, transform 0.2s ease;
    white-space: nowrap;
    z-index: 5;
}

.ad-details-page [data-tooltip]:hover::after,
.ad-details-page [data-tooltip]:focus::after {
    opacity: 1;
    transform: translateY(0);
}

.ad-details-page .safety-tips-box li {
    margin-bottom: 8px;
    color: #666;
}

.ad-details-page .mobile-bottom-actions {
    position: fixed;
    bottom: 0;
    left: 0;
    width: 100%;
    background: white;
    padding: 10px 15px;
    box-shadow: 0 -2px 10px rgba(0, 0, 0, 0.1);
    display: flex;
    gap: 10px;
    z-index: 9999;
}

@media (max-width: 768px) {
    .ad-details-page .sidebar-wrapper {
        display: none;
    }

    .ad-details-page .mobile-price-header {
        display: block;
    }

    .ad-details-page .price-card-box .price-block .main-price,
    .ad-details-page .price-card-box .price-block .price-note {
        display: none;
    }

    .ad-details-page .price-card-box .price-block {
        padding-top: 0;
    }
}

@media (min-width: 769px) {
    .ad-details-page .mobile-bottom-actions {
        display: none;
    }

    .ad-details-page .mobile-price-header {
        display: none;
    }
}

.offer-modal-overlay {
    position: fixed;
    inset: 0;
    background: radial-gradient(circle at top, rgba(15, 23, 42, 0.6), rgba(15, 23, 42, 0.75));
    display: none;
    align-items: flex-end;
    justify-content: center;
    z-index: 10000;
    backdrop-filter: blur(6px);
    padding: 12px;
    padding-top: max(12px, env(safe-area-inset-top));
    padding-right: max(12px, env(safe-area-inset-right));
    padding-bottom: max(12px, env(safe-area-inset-bottom));
    padding-left: max(12px, env(safe-area-inset-left));
    overflow-y: auto;
    overscroll-behavior: contain;
    -webkit-overflow-scrolling: touch;
}

.offer-modal-overlay.show {
    display: flex;
}

body.offer-modal-open {
    overflow: hidden;
}

.offer-modal {
    width: 100%;
    max-width: 520px;
    background: #ffffff;
    border-radius: 18px;
    box-shadow: 0 -30px 60px rgba(15, 23, 42, 0.35);
    padding: 22px 24px 24px;
    border: 1px solid rgba(226, 232, 240, 0.7);
    position: relative;
    overflow: hidden;
    display: flex;
    flex-direction: column;
    box-sizing: border-box;
    max-height: calc(100vh - 24px);
    max-height: calc(100dvh - 24px);
}

@media (min-width: 768px) {
    .offer-modal {
        border-radius: 16px;
        margin: 0;
        max-height: min(92dvh, 780px);
    }

    .offer-modal-overlay {
        align-items: center;
    }
}

.offer-modal-header {
    display: flex;
    align-items: center;
    justify-content: space-between;
    margin-bottom: 12px;
}

.offer-modal-header h3 {
    margin: 0;
    font-size: 19px;
    font-weight: 800;
    color: #0f172a;
}

.offer-modal-close {
    width: 32px;
    height: 32px;
    border-radius: 50%;
    border: none;
    background: #e2e8f0;
    font-size: 20px;
    cursor: pointer;
    color: #0f172a;
}

.offer-modal-body {
    display: grid;
    gap: 14px;
    flex: 1 1 auto;
    min-height: 0;
    overflow-y: auto;
    padding-right: 2px;
}

.offer-error {
    display: none;
    padding: 10px 12px;
    border-radius: 12px;
    background: #fee2e2;
    color: #991b1b;
    font-size: 13px;
    font-weight: 600;
}

.offer-error.show {
    display: block;
}

.offer-form-group label {
    display: block;
    font-size: 12px;
    font-weight: 700;
    color: #334155;
    letter-spacing: 0.02em;
    margin-bottom: 6px;
}

.offer-form-group input,
.offer-form-group textarea,
.offer-form-group select {
    width: 100%;
    border: 1px solid #e2e8f0;
    border-radius: 14px;
    padding: 13px 14px;
    font-size: 15px;
    outline: none;
    background: #f8fafc;
    transition: border-color 0.2s ease, box-shadow 0.2s ease, background 0.2s ease;
}

.offer-form-group textarea {
    resize: vertical;
}

.offer-form-group input:focus,
.offer-form-group textarea:focus,
.offer-form-group select:focus {
    border-color: #22c55e;
    box-shadow: 0 0 0 3px rgba(34, 197, 94, 0.15);
    background: #ffffff;
}

.offer-escrow-row {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 12px;
    padding: 12px 14px;
    border-radius: 14px;
    background: linear-gradient(120deg, rgba(99, 102, 241, 0.1), rgba(34, 197, 94, 0.08));
    border: 1px solid rgba(34, 197, 94, 0.25);
}

.offer-escrow-label {
    display: flex;
    align-items: center;
    gap: 8px;
    font-weight: 600;
    font-size: 13px;
    color: #0f172a;
}

.offer-escrow-icon {
    width: 28px;
    height: 28px;
    border-radius: 10px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    background: rgba(34, 197, 94, 0.15);
    color: #15803d;
    font-size: 14px;
}

.offer-escrow-label input[type="checkbox"] {
    width: 18px;
    height: 18px;
    accent-color: #22c55e;
}

.offer-escrow-guide {
    margin-top: -2px;
    border-radius: 12px;
    border: 1px solid #dbeafe;
    background: #eff6ff;
    padding: 10px 12px;
    color: #1e3a8a;
    font-size: 12px;
}

.offer-escrow-guide strong {
    display: block;
    font-size: 12px;
    margin-bottom: 4px;
}

.offer-escrow-guide p {
    margin: 0 0 6px;
}

.offer-escrow-guide ul {
    margin: 0;
    padding-left: 16px;
    display: grid;
    gap: 4px;
}

.offer-hint {
    margin-top: 6px;
    font-size: 12px;
    color: #64748b;
}

.offer-hint.is-success {
    color: #166534;
}

.offer-hint.is-error {
    color: #dc2626;
}

.offer-escrow-agreements {
    margin-top: 10px;
    border-radius: 12px;
    border: 1px solid #bbf7d0;
    background: #f0fdf4;
    padding: 12px;
    display: grid;
    gap: 8px;
}

.offer-escrow-agreements strong {
    font-size: 13px;
    color: #14532d;
}

.offer-escrow-check {
    display: flex;
    align-items: flex-start;
    gap: 8px;
    font-size: 13px;
    color: #14532d;
}

.offer-escrow-check input {
    width: 16px;
    height: 16px;
    margin-top: 2px;
    accent-color: #16a34a;
}

.offer-escrow-terms-note {
    margin: 0;
    font-size: 12px;
    color: #166534;
}

.offer-escrow-terms {
    padding-top: 4px;
    border-top: 1px dashed #86efac;
}

.offer-tooltip {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 22px;
    height: 22px;
    border-radius: 50%;
    background: #0f172a;
    color: #f8fafc;
    font-size: 12px;
    position: relative;
}

.offer-tooltip::after {
    content: attr(data-tooltip);
    position: absolute;
    right: 0;
    bottom: 28px;
    min-width: 200px;
    max-width: 240px;
    background: #0f172a;
    color: #f8fafc;
    padding: 10px 12px;
    border-radius: 10px;
    font-size: 12px;
    line-height: 1.4;
    opacity: 0;
    pointer-events: none;
    transform: translateY(4px);
    transition: opacity 0.2s ease, transform 0.2s ease;
}

.offer-tooltip:hover::after,
.offer-tooltip:focus::after {
    opacity: 1;
    transform: translateY(0);
}

.offer-tooltip.is-open::after {
    opacity: 1;
    transform: translateY(0);
}

.offer-total-note {
    font-size: 13px;
    color: #475569;
    font-weight: 600;
}

.offer-modal-footer {
    margin-top: 16px;
    flex: 0 0 auto;
}

.offer-submit-btn {
    width: 100%;
    border: none;
    border-radius: 14px;
    padding: 13px;
    background: linear-gradient(135deg, #22c55e, #16a34a);
    color: #ffffff;
    font-weight: 700;
    font-size: 15px;
    cursor: pointer;
    box-shadow: 0 14px 24px rgba(34, 197, 94, 0.25);
}

.offer-submit-btn:disabled {
    opacity: 0.6;
    cursor: not-allowed;
}

/* Quick chat inline (listing page sidebar) */
.quick-chat-inline {
    margin-top: 16px;
    border-radius: 16px;
    background: #ffffff;
    border: 1px solid #e2e8f0;
    padding: 16px;
    display: none;
    box-shadow: 0 16px 30px rgba(15, 23, 42, 0.08);
}

.quick-chat-inline.is-open {
    display: block;
}

.quick-chat-header {
    display: flex;
    align-items: center;
    justify-content: space-between;
    margin-bottom: 12px;
}

.quick-chat-header h4 {
    margin: 0;
    font-size: 16px;
    font-weight: 700;
    color: #0f172a;
}

.quick-chat-close {
    width: 28px;
    height: 28px;
    border-radius: 50%;
    border: none;
    background: #e2e8f0;
    font-size: 18px;
    cursor: pointer;
}

.quick-chat-templates {
    display: flex;
    gap: 10px;
    overflow-x: auto;
    padding-bottom: 6px;
    margin-bottom: 14px;
}

.quick-chat-templates::-webkit-scrollbar {
    height: 6px;
}

.quick-chat-templates::-webkit-scrollbar-thumb {
    background: #cbd5f5;
    border-radius: 999px;
}

.quick-chat-chip {
    border: 1px solid #22c55e;
    color: #15803d;
    background: #ffffff;
    border-radius: 999px;
    padding: 8px 14px;
    font-size: 13px;
    font-weight: 600;
    white-space: nowrap;
    cursor: pointer;
}

.quick-chat-chip-offer {
    border-color: #16a34a;
    background: rgba(34, 197, 94, 0.12);
}

.quick-chat-chip.active,
.quick-chat-chip:hover {
    background: #ecfdf3;
}

.quick-chat-input {
    width: 100%;
    min-height: 90px;
    border: 1px solid #e2e8f0;
    border-radius: 14px;
    padding: 12px 14px;
    font-size: 15px;
    outline: none;
    resize: vertical;
    background: #f8fafc;
    margin-bottom: 12px;
}

.quick-chat-status {
    display: flex;
    align-items: center;
    flex-wrap: wrap;
    gap: 8px;
    font-size: 12px;
    color: #64748b;
    margin-bottom: 10px;
}

.quick-chat-status .quick-chat-success {
    display: inline-flex;
    align-items: center;
    gap: 6px;
    padding: 6px 10px;
    border-radius: 999px;
    background: #f1f5f9;
    color: #0f172a;
    font-weight: 600;
}

.quick-chat-status .quick-chat-error {
    display: inline-flex;
    align-items: center;
    gap: 6px;
    padding: 6px 10px;
    border-radius: 999px;
    background: #fee2e2;
    color: #b91c1c;
    font-weight: 600;
}

.quick-chat-status a {
    display: inline-flex;
    align-items: center;
    gap: 6px;
    padding: 6px 10px;
    border-radius: 999px;
    background: #ecfdf3;
    color: #16a34a;
    font-weight: 700;
    text-decoration: none;
}

.quick-chat-submit {
    width: 100%;
    border: none;
    border-radius: 14px;
    padding: 12px;
    background: #f6c18b;
    color: #ffffff;
    font-weight: 700;
    font-size: 15px;
    cursor: pointer;
}

/* ================= SELLER PROFILE ================= */
.seller-page {
    --jiji-green: var(--primary-green);
    background: #eff2f3;
    padding-bottom: 30px;
}

.seller-page .seller-breadcrumb {
    display: flex;
    flex-wrap: wrap;
    list-style: none;
    padding: 0;
    margin: 0;
    font-size: 13px;
    color: #888;
}

.seller-page .breadcrumb-item+.breadcrumb-item:before {
    content: "/";
    margin: 0 6px;
    color: #bbb;
}

.seller-hero-card {
    background: #ffffff;
    border-radius: 8px;
    padding: 24px;
    margin-bottom: 20px;
    box-shadow: 0 1px 3px rgba(0, 0, 0, 0.06);
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    gap: 20px;
}

.seller-avatar {
    width: 96px;
    height: 96px;
    border-radius: 50%;
    background: #f0f0f0;
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 36px;
    color: #c2c2c2;
    overflow: hidden;
    border: 3px solid #fff;
    box-shadow: 0 2px 6px rgba(0, 0, 0, 0.12);
    position: relative;
}

.seller-avatar img {
    width: 100%;
    height: 100%;
    object-fit: cover;
}

.seller-info {
    flex: 1;
    min-width: 240px;
}

.seller-name-row {
    display: flex;
    align-items: center;
    flex-wrap: wrap;
    gap: 10px;
}

.seller-name {
    font-weight: 800;
    font-size: 24px;
    margin: 0;
    color: #2d2d2d;
}

.seller-badge {
    display: inline-flex;
    align-items: center;
    gap: 6px;
    background: #e6f7ec;
    color: #2e8b2c;
    font-size: 12px;
    font-weight: 700;
    padding: 4px 10px;
    border-radius: 999px;
}

.seller-badge.trust {
    background: #eff6ff;
    color: #1d4ed8;
}

.seller-page .online-indicator {
    position: absolute;
    bottom: 6px;
    right: 6px;
    width: 14px;
    height: 14px;
    border-radius: 50%;
    border: 2px solid #ffffff;
    box-shadow: 0 0 0 4px rgba(148, 163, 184, 0.2);
}

.seller-page .online-indicator.online {
    background: #22c55e;
    box-shadow: 0 0 0 4px rgba(34, 197, 94, 0.15);
}

.seller-page .online-indicator.offline {
    background: #94a3b8;
}

.seller-page [data-tooltip]::after {
    content: attr(data-tooltip);
    position: absolute;
    bottom: 120%;
    left: 0;
    padding: 6px 10px;
    border-radius: 10px;
    background: #0f172a;
    color: #f8fafc;
    font-size: 11px;
    opacity: 0;
    pointer-events: none;
    transform: translateY(4px);
    transition: opacity 0.2s ease, transform 0.2s ease;
    white-space: nowrap;
    z-index: 5;
}

.seller-page [data-tooltip]:hover::after,
.seller-page [data-tooltip]:focus::after {
    opacity: 1;
    transform: translateY(0);
}

.seller-meta {
    color: #888;
    font-size: 13px;
    margin-top: 8px;
    display: flex;
    gap: 14px;
    flex-wrap: wrap;
}

.seller-meta i {
    margin-right: 6px;
    color: #a0a0a0;
}

.seller-rating {
    margin-top: 10px;
    display: flex;
    align-items: center;
    gap: 8px;
}

.seller-stars {
    color: #f4b400;
    font-size: 13px;
}

.seller-actions {
    display: flex;
    flex-direction: column;
    gap: 10px;
    min-width: 200px;
}

.seller-actions .btn-action {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: 8px;
    padding: 12px 18px;
    border-radius: 8px;
    font-weight: 700;
    border: none;
    cursor: pointer;
    text-decoration: none;
}

.seller-actions .btn-show-contact {
    background: var(--jiji-green);
    color: #ffffff;
    box-shadow: 0 4px 10px rgba(61, 184, 58, 0.25);
}

.seller-actions .btn-start-chat {
    background: #ffffff;
    color: var(--jiji-green);
    border: 2px solid var(--jiji-green);
}

.seller-layout {
    display: grid;
    gap: 20px;
    grid-template-columns: 1fr;
}

@media (min-width: 992px) {
    .seller-layout {
        grid-template-columns: 280px 1fr;
    }
}

.seller-sidebar-card {
    background: #ffffff;
    border-radius: 6px;
    padding: 16px;
    margin-bottom: 12px;
    box-shadow: 0 1px 2px rgba(0, 0, 0, 0.05);
}

.seller-sidebar-card .filter-title {
    font-weight: 700;
    font-size: 14px;
    margin-bottom: 12px;
    color: #2d2d2d;
}

.seller-filter-group {
    display: flex;
    flex-direction: column;
}

.seller-category-item {
    display: flex;
    justify-content: space-between;
    padding: 8px 0;
    color: #2d2d2d;
    font-size: 14px;
    border-bottom: 1px solid #f0f0f0;
    text-decoration: none;
}

.seller-category-item span {
    color: #b0b0b0;
    font-size: 12px;
}

.seller-category-item.filter-link-active {
    font-weight: 700;
    color: var(--jiji-green);
    position: relative;
    padding-left: 14px;
}

.seller-category-item.filter-link-active::before {
    content: '';
    position: absolute;
    left: 0;
    top: 50%;
    transform: translateY(-50%);
    width: 6px;
    height: 6px;
    background: var(--jiji-green);
    border-radius: 50%;
}

.seller-sidebar-card.safety-card ul {
    list-style: none;
    padding-left: 0;
    margin: 0;
    font-size: 12px;
    color: #777;
}

.seller-sidebar-card.safety-card li {
    margin-bottom: 8px;
}

.seller-sidebar-card.safety-card a {
    color: var(--jiji-green);
    font-weight: 700;
    text-decoration: none;
}

.seller-report {
    margin-top: 10px;
}

.seller-report .btn-outline-danger {
    width: 100%;
    padding: 10px 12px;
    border-radius: 6px;
    border: 1px solid #f5c2c7;
    background: #fff;
    color: #b42318;
    font-weight: 600;
    cursor: pointer;
}

.seller-main .seller-listing-header {
    display: flex;
    align-items: center;
    justify-content: space-between;
    margin-bottom: 16px;
}

.seller-main .seller-listing-header h5 {
    margin: 0;
    font-weight: 700;
}

.seller-sort button {
    border: 1px solid #e2e8f0;
    background: #ffffff;
    border-radius: 8px;
    padding: 8px 12px;
    font-size: 12px;
    cursor: pointer;
}

.seller-listing-grid {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(200px, 1fr));
    gap: 16px;
}

.seller-listing-card {
    background: #ffffff;
    border-radius: 8px;
    overflow: hidden;
    text-decoration: none;
    color: inherit;
    box-shadow: 0 1px 2px rgba(0, 0, 0, 0.05);
    transition: transform 0.2s ease, box-shadow 0.2s ease;
}

.seller-listing-card:hover {
    transform: translateY(-3px);
    box-shadow: 0 10px 20px rgba(0, 0, 0, 0.1);
}

.seller-listing-img {
    height: 160px;
    background: #e5e7eb;
    display: flex;
    align-items: center;
    justify-content: center;
    color: #9ca3af;
    position: relative;
}

.seller-listing-img img {
    width: 100%;
    height: 100%;
    object-fit: cover;
}

.seller-listing-content {
    padding: 14px;
}

.seller-listing-content .ad-title {
    font-size: 14px;
    margin-bottom: 6px;
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
    color: #2d2d2d;
    font-weight: 600;
}

.seller-listing-content .ad-price {
    color: var(--jiji-green);
    font-weight: 800;
    font-size: 15px;
    margin-bottom: 4px;
}

.seller-listing-content .ad-meta {
    font-size: 12px;
    color: #888;
}

.seller-empty {
    background: #ffffff;
    border-radius: 10px;
    padding: 30px;
    text-align: center;
    color: #94a3b8;
}

.seller-empty i {
    font-size: 28px;
    margin-bottom: 10px;
}

.seller-pagination {
    margin-top: 24px;
    display: flex;
    justify-content: center;
    gap: 8px;
    flex-wrap: wrap;
}

.seller-pagination .page-btn {
    border: 1px solid #e2e8f0;
    background: #ffffff;
    padding: 8px 12px;
    border-radius: 8px;
    font-size: 12px;
    cursor: pointer;
}

.seller-pagination .page-btn.active {
    background: var(--jiji-green);
    color: #ffffff;
    border-color: var(--jiji-green);
}

.mobile-actions-panel.open {
    display: block;
}

.mobile-panel-group+.mobile-panel-group {
    margin-top: 16px;
}

.mobile-panel-title {
    font-size: 12px;
    font-weight: 700;
    letter-spacing: 0.5px;
    text-transform: uppercase;
    color: #64748b;
    margin-bottom: 8px;
}

.mobile-panel-actions {
    display: flex;
    flex-wrap: wrap;
    gap: 8px;
}

.mobile-lang-btn {
    border: 1px solid #e2e8f0;
    background: #f8fafc;
    color: #111;
    padding: 6px 10px;
    border-radius: 999px;
    font-size: 12px;
}

.mobile-lang-btn.active {
    background: #e2e8f0;
    font-weight: 700;
}

.mobile-location-btn {
    display: inline-flex;
    align-items: center;
    gap: 8px;
    border: 1px solid #e2e8f0;
    background: #f8fafc;
    padding: 8px 12px;
    border-radius: 999px;
}

.mobile-panel-link {
    display: inline-flex;
    margin-right: 12px;
    color: #2563eb;
    font-weight: 600;
}

@media (max-width: 900px) {
    .site-header .header-searchbar {
        display: none;
    }

    .site-header .header-actions .profile-chip,
    .site-header .header-actions .header-icon,
    .site-header .header-actions .header-auth-link,
    .site-header .header-actions .header-auth-sep,
    .site-header .location-chip {
        display: none;
    }

    .site-header .header-actions .btn-sell {
        display: inline-flex;
    }

    .site-header .mobile-menu-btn {
        display: inline-flex;
    }

    .site-header .btn-sell {
        background: linear-gradient(135deg, #28a745 0%, #f68b1e 100%);
        border-radius: 999px;
        padding: 8px 16px;
        font-size: 12px;
        letter-spacing: 0.06em;
        box-shadow: 0 6px 14px rgba(16, 185, 129, 0.25);
    }
}

/* --- Footer alignment overrides to match wireframe --- */
.site-footer .footer-bottom {
    border-top: none;
    padding-top: 0;
    text-align: left;
}

/* ============================================================================
   SEARCH PAGE WIREFRAME
   ============================================================================ */
.search-page {
    padding-bottom: 40px;
}

.search-page .search-crumbs {
    font-size: 13px;
    color: #888;
}

.search-page .search-topbar {
    display: flex;
    flex-direction: column;
    gap: 10px;
    margin-bottom: 18px;
}

.search-page .search-form-inline {
    display: flex;
    gap: 8px;
    max-width: 620px;
}

.search-page .search-input-field {
    flex: 1;
    padding: 10px 14px;
    border: 1px solid #d7dde3;
    border-radius: 6px;
    font-size: 14px;
    background: #fff;
}

.search-page .search-submit-btn {
    border: none;
    padding: 10px 18px;
    border-radius: 6px;
    background: var(--primary-green);
    color: #fff;
    font-weight: 700;
    cursor: pointer;
}

.search-page .search-correction {
    font-size: 13px;
    color: #6b7280;
}

.search-page .active-filters {
    display: flex;
}

.search-page .active-filters {
    display: flex;
    flex-wrap: wrap;
    gap: 8px;
    align-items: center;
    margin-bottom: 16px;
    padding: 12px;
    background: #f1f5f9;
    border-radius: 10px;
}

.search-page .active-filters .label {
    font-weight: 600;
    color: #475569;
    font-size: 13px;
}

.search-page .filter-pill {
    display: inline-flex;
    align-items: center;
    padding: 4px 10px;
    background: var(--primary-green);
    color: #fff;
    border-radius: 999px;
    font-size: 12px;
    text-decoration: none;
}

.results-notice-pill {
    grid-column: 1 / -1;
    display: flex;
    align-items: center;
    gap: 10px;
    padding: 10px 14px;
    margin: 2px 0 6px;
    background: #f8fafc;
    border: 1px dashed #dbe3ea;
    border-radius: 999px;
    color: #475569;
    font-size: 13px;
}

.results-notice-pill .notice-dot {
    width: 8px;
    height: 8px;
    border-radius: 999px;
    background: #22c55e;
    box-shadow: 0 0 0 3px rgba(34, 197, 94, 0.15);
    flex: 0 0 8px;
}

.results-notice-pill .notice-text {
    flex: 1;
}

.nearby-city-header {
    grid-column: 1 / -1;
    display: flex;
    align-items: center;
    gap: 10px;
    padding: 10px 14px;
    margin: 6px 0 8px;
    background: linear-gradient(90deg, #ffedd5, #fff4e6);
    border: 1px solid #fdba74;
    border-radius: 14px;
    color: #c2410c;
    box-shadow: 0 8px 16px rgba(234, 88, 12, 0.18);
}

.nearby-city-icon {
    width: 28px;
    height: 28px;
    border-radius: 50%;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    background: #fdba74;
    color: #9a3412;
    font-size: 13px;
    flex: 0 0 28px;
}

.nearby-city-text {
    display: flex;
    flex-direction: column;
    gap: 2px;
}

.nearby-city-title {
    font-weight: 800;
    font-size: 14px;
    color: #9a3412;
}

.nearby-city-sub {
    font-size: 12px;
    color: #c2410c;
}

.search-page .clear-all {
    color: #ef4444;
    font-size: 12px;
    font-weight: 600;
    margin-left: 8px;
}

.search-page .search-sidebar {
    position: sticky;
    top: 90px;
    height: fit-content;
}

.search-page .sidebar-card {
    background: #fff;
    border-radius: 6px;
    padding: 14px;
    margin-bottom: 12px;
    box-shadow: 0 1px 2px rgba(0, 0, 0, 0.05);
}

.search-page .filter-title {
    font-weight: 700;
    font-size: 13px;
    margin-bottom: 10px;
    display: flex;
    justify-content: space-between;
    align-items: center;
}

.search-page .filter-hint {
    font-size: 11px;
    font-weight: 600;
    color: #059669;
}

.search-page .category-item {
    display: flex;
    justify-content: space-between;
    align-items: center;
    padding: 6px 0;
    color: #374151;
    text-decoration: none;
    font-size: 13px;
    border-bottom: 1px solid #f0f0f0;
}

.search-page .category-item.active {
    font-weight: 700;
    color: var(--primary-green);
}

.search-page .category-item:last-child {
    border-bottom: none;
}

.search-page .category-count {
    color: #9ca3af;
    font-size: 11px;
}

.search-page .category-more {
    background: #f3f4f6;
    border: none;
    border-radius: 6px;
    padding: 6px 10px;
    font-size: 12px;
    font-weight: 600;
    margin-top: 8px;
    cursor: pointer;
}

.search-page .category-other-list {
    display: none;
    margin-top: 10px;
}

.search-page .category-other-list.open {
    display: block;
}

@media (min-width: 992px) {
    .search-page .category-other-list.open {
        display: block;
    }
}

.search-page .scrollable-filter {
    max-height: 200px;
    overflow-y: auto;
}

.search-page .filter-checkbox-label {
    font-size: 13px;
    display: block;
    margin-bottom: 6px;
    cursor: pointer;
}

.search-page .attribute-block {
    margin-bottom: 12px;
}

.search-page .attribute-title {
    font-size: 12px;
    font-weight: 600;
    margin-bottom: 6px;
    color: #374151;
}

.search-page .page-title {
    font-weight: 800;
    font-size: 22px;
    margin: 8px 0 18px;
    color: #1f2937;
}

.search-page .price-grid {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(140px, 1fr));
    gap: 10px;
    margin-bottom: 20px;
}

.search-page .price-block-btn {
  
    cursor: pointer;
}

.search-page .brand-scroller {
    display: flex;
    gap: 16px;
    overflow-x: auto;
    padding-bottom: 8px;
    margin-bottom: 18px;
}

.search-page .brand-item {
    display: flex;
    flex-direction: column;
    align-items: center;
    min-width: 70px;
    cursor: pointer;
}

.search-page .brand-logo-circle {
    width: 52px;
    height: 52px;
    background: #fff;
    border-radius: 50%;
    display: flex;
    align-items: center;
    justify-content: center;
    margin-bottom: 6px;
    box-shadow: 0 1px 3px rgba(0, 0, 0, 0.1);
    font-weight: 700;
    color: #6b7280;
}

.search-page .brand-logo-circle img {
    width: 70%;
    height: 70%;
    object-fit: contain;
}

.search-page .brand-name {
    font-size: 11px;
    color: #4b5563;
    text-align: center;
}

.search-page .results-toolbar {
    display: flex;
    justify-content: space-between;
    align-items: center;
    margin-bottom: 12px;
    gap: 10px;
    flex-wrap: wrap;
}

.search-page .results-toolbar-left {
    display: flex;
    align-items: center;
    gap: 10px;
}

.search-page .results-toolbar-notices {
    flex: 1;
    display: flex;
    justify-content: center;
}

.search-page .toolbar-notice {
    display: inline-flex;
    align-items: center;
    gap: 8px;
    background: #f4f7fb;
    border: 1px solid #e2e8f0;
    color: #475569;
    padding: 6px 10px;
    border-radius: 999px;
    font-size: 12px;
    box-shadow: 0 1px 2px rgba(0, 0, 0, 0.05);
}

.search-page .toolbar-notice.info {
    background: #f0f7ff;
    border-color: #dbeafe;
    color: #1d4ed8;
}

.search-page .toolbar-notice .notice-icon {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 18px;
    height: 18px;
    border-radius: 50%;
    background: #e2e8f0;
    color: #475569;
    font-size: 10px;
}

.search-page .toolbar-notice.info .notice-icon {
    background: #dbeafe;
    color: #2563eb;
}

.search-page .toolbar-notice .notice-text {
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
    max-width: 520px;
}

.search-page .toolbar-notice .notice-close {
    border: none;
    background: transparent;
    color: #94a3b8;
    font-size: 16px;
    line-height: 1;
    cursor: pointer;
    padding: 0 2px;
}

.search-page .toolbar-notice .notice-close:hover {
    color: #64748b;
}

.search-page .filter-toggle {
    border: none;
    background: #fff;
    border-radius: 8px;
    padding: 8px 10px;
    box-shadow: 0 1px 2px rgba(0, 0, 0, 0.08);
}

.search-page .view-toggle {
    display: flex;
    gap: 6px;
}

.search-page .view-btn {
    border: none;
    background: #f3f4f6;
    border-radius: 8px;
    padding: 8px 10px;
    color: #6b7280;
    cursor: pointer;
}

.search-page .view-btn.is-active {
    background: #e6f6e8;
    color: #1f7a36;
}

.search-page .results-toolbar-right {
    display: flex;
    align-items: center;
    gap: 12px;
    flex-wrap: wrap;
}

.search-page .save-search-btn.is-saved {
    background: #dcfce7;
    border-color: #86efac;
    color: #166534;
}

.search-page .save-search-btn {
    display: inline-flex;
    align-items: center;
    gap: 8px;
    padding: 10px 16px;
    border-radius: 999px;
    border: 1px solid #16a34a;
    background: #16a34a;
    color: #fff;
    font-weight: 600;
    font-size: 13px;
    box-shadow: 0 10px 22px rgba(22, 163, 74, 0.2);
    transition: transform 0.2s ease, box-shadow 0.2s ease, background 0.2s ease;
}

.search-page .save-search-btn:hover {
    transform: translateY(-1px);
    box-shadow: 0 14px 26px rgba(22, 163, 74, 0.3);
    background: #15803d;
    border-color: #15803d;
}

.search-page .save-search-btn i {
    font-size: 13px;
}

.search-page .save-search-btn.is-saved {
    background: #dcfce7;
    border-color: #86efac;
    color: #166534;
    box-shadow: none;
}

.search-page .filter-apply-btn {
    width: 100%;
}

@media (max-width: 991px) {
    .search-page .filter-apply-btn {
        display: block;
    }
}


.search-page .sort-dropdown {
    position: relative;
}

.search-page .sort-trigger {
    border: none;
    background: #fff;
    border-radius: 8px;
    padding: 8px 12px;
    font-size: 13px;
    font-weight: 600;
    color: #374151;
    display: inline-flex;
    gap: 6px;
    align-items: center;
    box-shadow: 0 1px 2px rgba(0, 0, 0, 0.08);
    cursor: pointer;
}

.search-page .sort-menu {
    position: absolute;
    top: calc(100% + 6px);
    right: 0;
    background: #fff;
    border-radius: 10px;
    box-shadow: 0 10px 20px rgba(0, 0, 0, 0.12);
    padding: 6px;
    display: none;
    z-index: 10;
    min-width: 160px;
}

.search-page .sort-menu.open {
    display: block;
}

.search-page .sort-option {
    width: 100%;
    text-align: left;
    border: none;
    background: transparent;
    padding: 8px 10px;
    border-radius: 8px;
    font-size: 13px;
    cursor: pointer;
}

.search-page .sort-option:hover {
    background: #f3f4f6;
}

.search-page .results-grid {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(220px, 1fr));
    gap: 16px;
}

.search-page .results-grid.is-list {
    grid-template-columns: 1fr;
}

.search-page .listing-card {
    background: #fff;
    border-radius: 8px;
    overflow: hidden;
    box-shadow: 0 1px 2px rgba(0, 0, 0, 0.06);
    display: flex;
    flex-direction: column;
}

.search-page.search-compact .results-grid {
    grid-template-columns: repeat(auto-fill, minmax(200px, 1fr));
    gap: 12px;
}

.search-page.search-compact .listing-card {
    border-radius: 10px;
}

.search-page.search-compact .listing-media {
    height: 150px;
}

.search-page.search-compact .listing-content {
    padding: 10px 12px;
}

.search-page.search-compact .listing-title {
    font-size: 14px;
    line-height: 1.3;
}

.search-page.search-compact .listing-price {
    font-size: 14px;
}

.search-page.search-compact .listing-meta {
    font-size: 12px;
}

.search-page .results-grid.is-list .listing-card {
    flex-direction: row;
    align-items: stretch;
}

.search-page .listing-media {
    position: relative;
    display: block;
    height: 180px;
    background: #eef2f7;
    color: #94a3b8;
}

.search-page .results-grid.is-list .listing-media {
    width: 220px;
    height: auto;
}

/* List view redesign to match reference layout */
.search-page .results-grid.is-list .listing-card {
    border: 1px solid #e2e8f0;
    border-radius: 12px;
    background: #fff;
    box-shadow: 0 1px 2px rgba(15, 23, 42, 0.06);
    overflow: hidden;
    min-height: 220px;
}

.search-page .results-grid.is-list .listing-card:hover {
    border-color: #16a34a;
}

.search-page .results-grid.is-list .listing-media {
    width: 38%;
    min-width: 320px;
    height: 200px;
    align-self: stretch;
}

.search-page .results-grid.is-list .listing-content {
    flex: 1;
    display: flex;
    flex-direction: column;
    gap: 10px;
    padding: 18px 20px;
}

.search-page .results-grid.is-list .listing-header {
    display: flex;
    align-items: flex-start;
    justify-content: space-between;
    gap: 16px;
}

.search-page .results-grid.is-list .listing-title {
    font-size: 20px;
    font-weight: 700;
    color: #111827;
    line-height: 1.25;
    margin: 0;
}

.search-page .results-grid.is-list .listing-price {
    font-size: 20px;
    font-weight: 800;
    color: #16a34a;
    white-space: nowrap;
}

.search-page .results-grid.is-list .listing-desc {
    font-size: 14px;
    color: #6b7280;
    line-height: 1.45;
    display: block;
}

.search-page .results-grid.is-list .listing-attrs {
    display: flex;
    flex-wrap: wrap;
    gap: 8px;
}

.search-page .results-grid.is-list .listing-attrs .attr-chip {
    display: inline-flex;
    align-items: center;
    padding: 6px 12px;
    border-radius: 8px;
    background: #f1f5f9;
    color: #1f2937;
    font-size: 13px;
    font-weight: 600;
}

.search-page .results-grid.is-list .listing-meta {
    display: flex;
    align-items: center;
    gap: 12px;
    font-size: 13px;
    color: #64748b;
}

.search-page .results-grid.is-list .listing-meta i {
    color: #94a3b8;
}

.search-page .results-grid.is-list .listing-condition {
    display: inline-flex;
    align-items: center;
    padding: 4px 10px;
    border-radius: 999px;
    background: #ecfeff;
    color: #0369a1;
    font-size: 12px;
    font-weight: 700;
}

.search-page .results-grid.is-list .listing-footer {
    display: none;
}

.search-page .results-grid.is-list .listing-badges {
    top: 12px;
    left: 12px;
    right: auto;
    flex-direction: column;
    gap: 6px;
}

.search-page .results-grid.is-list .listing-badge {
    background: rgba(255, 255, 255, 0.9);
    border: 1px solid #e5e7eb;
    color: #111827;
    border-radius: 999px;
    padding: 4px 10px;
    font-size: 11px;
}

@media (max-width: 900px) {
    .search-page .results-grid.is-list .listing-media {
        width: 44%;
        min-width: 240px;
        height: 190px;
    }
}

@media (max-width: 640px) {
    .search-page .results-grid.is-list .listing-card {
        flex-direction: column;
    }

    .search-page .results-grid.is-list .listing-media {
        width: 100%;
        min-width: 0;
        height: 200px;
    }

    .search-page .results-grid.is-list .listing-content {
        padding: 14px 16px;
    }

    .search-page .results-grid.is-list .listing-title {
        font-size: 18px;
    }

    .search-page .results-grid.is-list .listing-price {
        font-size: 18px;
    }
}

.search-page .listing-media img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    display: block;
}

.search-page .listing-placeholder {
    display: flex;
    align-items: center;
    justify-content: center;
    height: 100%;
    font-size: 32px;
    color: #cbd5f5;
}

.search-page .listing-badges {
    position: absolute;
    top: 10px;
    left: 10px;
    display: flex;
    flex-direction: column;
    gap: 6px;
    z-index: 2;
}

.search-page .listing-badge {
    display: inline-flex;
    align-items: center;
    gap: 6px;
    font-size: 11px;
    font-weight: 700;
    padding: 4px 8px;
    border-radius: 6px;
    background: #eef2f7;
    color: #374151;
}

.search-page .listing-desc {
    display: none;
}

.search-page .listing-attrs {
    display: flex;
    flex-wrap: wrap;
    gap: 6px;
}

.search-page .listing-attrs .attr-chip {
    display: inline-flex;
    align-items: center;
}

.search-page .badge-verified {
    background: #e6f7ec;
    color: #15803d;
    border: 1px solid #86efac;
}

.search-page .badge-promo {
    background: #fff4e6;
    color: #c2410c;
    border: 1px solid #fed7aa;
}

.search-page .badge-reputation {
    background: #eef2ff;
    color: #4338ca;
    border: 1px solid #c7d2fe;
}

.search-page .card-content {
    padding: 12px;
    display: flex;
    flex-direction: column;
    gap: 4px;
}

.search-page .ad-title {
    font-size: 14px;
    font-weight: 600;
    margin: 0;
}

.search-page .ad-title a {
    color: #1f2937;
    text-decoration: none;
}

.search-page .ad-price {
    color: var(--primary-green);
    font-weight: 800;
    font-size: 16px;
}

.search-page .ad-meta {
    font-size: 12px;
    color: #6b7280;
}

.search-page .ad-location {
    display: flex;
    justify-content: space-between;
    font-size: 12px;
    color: #9ca3af;
}

.search-page .ad-meta-stack {
    display: flex;
    flex-direction: column;
    gap: 2px;
    margin-top: 4px;
}

.search-page .ad-meta-row {
    display: flex;
    align-items: center;
    gap: 6px;
    font-size: 12px;
    color: #6b7280;
    line-height: 1.25;
    flex-wrap: wrap;
}

.search-page .ad-meta-row i {
    font-size: 11px;
    color: #94a3b8;
}

.search-page .ad-meta-text {
    display: inline-flex;
    align-items: center;
    gap: 6px;
}

.search-page .ad-meta-chip {
    display: inline-flex;
    align-items: center;
    gap: 4px;
    padding: 2px 3px;
    border-radius: 999px;
    font-size: 11px;
    font-weight: 600;
    color: #1e293b;
    background: #f1f5f9;
    border: 1px solid #e2e8f0;
}

.search-page .pagination {
    display: flex;
    justify-content: center;
    gap: 6px;
    margin-top: 20px;
}

.search-page .page-link {
    padding: 6px 12px;
    background: #fff;
    border-radius: 6px;
    color: #475569;
    text-decoration: none;
}

.search-page .page-link.active {
    background: var(--primary-green);
    color: #fff;
}

.search-page .no-results {
    text-align: center;
    padding: 40px 20px;
    background: #fff;
    border-radius: 8px;
}

.search-page .is-loading {
    opacity: 0.6;
    pointer-events: none;
}

.filter-backdrop {
    position: fixed;
    inset: 0;
    background: rgba(0, 0, 0, 0.35);
    opacity: 0;
    visibility: hidden;
    transition: all 0.2s;
    z-index: 900;
}

body.filters-open .filter-backdrop {
    opacity: 1;
    visibility: visible;
}

@media (max-width: 991px) {
    .search-page .search-sidebar {
        position: fixed;
        top: 0;
        left: 0;
        width: 86%;
        max-width: 320px;
        height: 100%;
        overflow-y: auto;
        transform: translateX(-100%);
        transition: transform 0.25s ease;
        z-index: 950;
        padding: 20px 16px;
        background: #f8fafc;
    }

    body.filters-open .search-page .search-sidebar {
        transform: translateX(0);
    }

    .search-page .results-toolbar {
        flex-direction: column;
        align-items: flex-start;
    }

    .search-page .results-grid.is-list .listing-media {
        width: 140px;
    }
}

.search-page .results-grid.is-list .card-content {
    flex: 1;
}

.search-page .results-grid.is-list .listing-card {
    align-items: stretch;
}

.search-page .results-grid.is-list .listing-media {
    flex-shrink: 0;
}

.search-page .results-grid.is-list .listing-media {
    width: 220px;
    height: 160px;
    flex-shrink: 0;
}

/* Search page utility helpers (Bootstrap-lite, scoped) */
.search-page .d-flex {
    display: flex;
}

.search-page .flex-wrap {
    flex-wrap: wrap;
}

.search-page .gap-2 {
    gap: 8px;
}

.search-page .gap-3 {
    gap: 12px;
}

.search-page .mb-2 {
    margin-bottom: 8px;
}

.search-page .mb-3 {
    margin-bottom: 12px;
}

.search-page .mt-2 {
    margin-top: 8px;
}

.search-page .mt-3 {
    margin-top: 12px;
}

.search-page .pb-5 {
    padding-bottom: 3rem;
}

.search-page .text-success {
    color: var(--primary-green);
}

.search-page .text-muted {
    color: #6b7280;
}

.search-page .fw-bold {
    font-weight: 700;
}

.search-page .form-select {
    width: 100%;
    padding: 8px 10px;
    border: 1px solid #d1d5db;
    border-radius: 6px;
    background: #fff;
    font-size: 13px;
}

.search-page .form-select-sm {
    padding: 6px 8px;
    font-size: 12px;
}

.search-page .form-control-sm {
    padding: 6px 8px;
    font-size: 12px;
    border-radius: 6px;
}

/* Search layout fallback (Bootstrap-like grid) */
.search-page .row {
    display: flex;
    align-items: flex-start;
    gap: 24px;
    flex-wrap: nowrap;
}

.search-page .col-lg-3 {
    flex: 0 0 280px;
    max-width: 280px;
}

.search-page .col-lg-9 {
    flex: 1;
    min-width: 0;
}

@media (max-width: 991px) {
    .search-page .row {
        flex-direction: column;
        gap: 16px;
    }

    .search-page .col-lg-3,
    .search-page .col-lg-9 {
        max-width: 100%;
        width: 100%;
    }
}

/* Search wireframe polish (match docs/search.html) */
.search-page {
    background: #eff2f3;
    color: #3a3a3a;
}

.search-page .search-breadcrumb {
    margin-bottom: 8px;
}

.search-page .search-breadcrumb {
    margin: 6px 0 14px;
}

.search-page .search-crumbs {
    font-size: 13px;
    color: #8b8b8b;
    display: flex;
    flex-wrap: wrap;
    gap: 6px;
    align-items: center;
}

.search-page .search-crumbs .breadcrumb-item {
    display: flex;
    align-items: center;
    gap: 6px;
}

.search-page .search-crumbs .breadcrumb-item+.breadcrumb-item:before {
    content: "/";
    color: #bdbdbd;
}

.search-page .search-crumbs a {
    color: #6b7280;
    text-decoration: none;
}

.search-page .search-crumbs a:hover {
    color: #3a3a3a;
}

.search-page .search-crumbs .active {
    color: #5f5f5f;
    font-weight: 600;
}

.search-page .search-topbar {
    margin-bottom: 10px;
}

.search-page .active-filters {
    margin-bottom: 10px;
}

.search-page .results-summary {
    margin-top: 0;
}

.search-page .search-form-inline {
    background: #fff;
    border-radius: 16px;
    box-shadow: 0 10px 30px rgba(15, 23, 42, 0.08);
    overflow: visible;
    position: relative;
    border: 1px solid #e5e7eb;
    display: flex;
    align-items: center;
    padding: 6px 8px;
    flex-wrap: wrap;
}

.search-page .search-input-field {
    border: none;
    padding: 12px 14px;
    font-size: 18px;
    flex: 1 1 auto;
    background: transparent;
    order: 2;
    min-width: 240px;
}

.search-page .search-input-field::placeholder {
    color: #9aa0a6;
}

.search-page .search-submit-btn {
    background: #f1f5f9;
    border: none;
    color: #334155;
    width: 44px;
    height: 44px;
    border-radius: 12px;
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 16px;
    cursor: pointer;
    transition: all 0.2s;
    order: 3;
}

.search-page .search-submit-btn:hover {
    background: #e2e8f0;
    color: #0f172a;
}

.search-page .search-detected-pills {
    display: none;
    flex-wrap: wrap;
    gap: 8px;
    padding: 6px 8px;
    width: 100%;
    order: 1;
}

.search-page .search-detected-pills.is-visible {
    display: flex;
}

.search-page .search-pill {
    display: inline-flex;
    align-items: center;
    gap: 6px;
    background: #eef2ff;
    color: #4338ca;
    border-radius: 999px;
    padding: 4px 10px;
    font-size: 12px;
    font-weight: 600;
}

.search-page .search-pill.brand {
    background: #ecfdf3;
    color: #047857;
}

.search-page .search-pill .pill-icon {
    font-size: 12px;
}

.search-page .search-pill .pill-tag {
    background: rgba(15, 23, 42, 0.12);
    color: #1f2937;
    border-radius: 999px;
    padding: 1px 6px;
    font-size: 9px;
    font-weight: 700;
    letter-spacing: 0.3px;
    text-transform: uppercase;
}

.search-page .search-pill .pill-remove {
    color: inherit;
    text-decoration: none;
    font-weight: 700;
    line-height: 1;
    margin-left: 2px;
}

.search-page .search-pill .pill-remove {
    border: none;
    background: transparent;
    color: inherit;
    font-size: 14px;
    line-height: 1;
    cursor: pointer;
    padding: 0 2px;
    opacity: 0.7;
}

.search-page .search-pill .pill-remove:hover {
    opacity: 1;
}

.search-page .sidebar-card {
    border-radius: 4px;
    padding: 15px;
    margin-bottom: 10px;
}

.search-page .filter-title {
    font-size: 14px;
    margin-bottom: 10px;
}

.search-page .category-item {
    font-size: 14px;
    color: #3a3a3a;
}

.search-page .category-count {
    color: #bbb;
    font-size: 12px;
}

.search-page .filter-checkbox-label {
    font-size: 14px;
    margin-bottom: 8px;
}

.search-page .range-inputs input {
    text-align: center;
    font-size: 13px;
}

.search-page .page-title {
    font-size: 24px;
    margin-bottom: 20px;
    color: #2b2b2b;
}

.search-page .price-grid {
    grid-template-columns: repeat(4, minmax(0, 1fr));
    gap: 15px;
    margin-bottom: 30px;
}

.search-page .price-block-btn {
    background: #ecf0f1;
    color: #4a4a4a;
    font-weight: 600;
    font-size: 12px !important;
    padding: 15px 5px;
    border-radius: 6px;
}

.search-page .brand-scroller {
    justify-content: space-between;
    margin-bottom: 30px;
}

.search-page .brand-logo-circle {
    width: 50px;
    height: 50px;
}

.search-page .brand-logo-circle i {
    font-size: 24px;
    color: #555;
}

.search-page .brand-name {
    font-size: 12px;
    color: #555;
}

.search-page .listing-card {
    border-radius: 6px;
    transition: transform 0.2s, box-shadow 0.2s;
}

.search-page .listing-card:hover {
    transform: translateY(-3px);
    box-shadow: 0 10px 20px rgba(0, 0, 0, 0.1);
}

.search-page .listing-media {
    height: 180px;
    background: #e0e0e0;
}

.search-page .listing-badges {
    top: 10px;
    right: 10px;
    left: auto;
}

.search-page .badge-verified {
    background: rgba(230, 247, 236, 0.9);
    color: #2e8b2c;
    border: 1px solid #3db83a;
    border-radius: 4px;
}

.search-page .ad-title {
    font-size: 16px;
    margin-bottom: 5px;
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
    color: #2d2d2d;
}

.search-page .ad-price {
    font-size: 18px;
}

.search-page .ad-meta {
    font-size: 12px;
    color: #888;
    margin-bottom: 15px;
}

.search-page .ad-location {
    font-size: 12px;
    color: #999;
}

.search-page .results-grid.is-list .listing-media {
    width: 200px;
    height: 160px;
}

.search-page .results-grid.is-list .card-content {
    padding: 16px;
}

@media (min-width: 992px) {
    .search-page .results-grid {
        grid-template-columns: repeat(3, minmax(0, 1fr));
    }
}

@media (min-width: 1200px) {
    .search-page .results-grid {
        grid-template-columns: repeat(4, minmax(0, 1fr));
    }
}

@media (max-width: 991px) {
    .search-page .price-grid {
        grid-template-columns: repeat(2, minmax(0, 1fr));
    }
}

@media (max-width: 640px) {
    .search-page .results-grid {
        grid-template-columns: repeat(2, minmax(0, 1fr));
    }

    .search-page .page-title {
        font-size: 18px;
        margin-bottom: 12px;
    }

    .search-page .search-crumbs {
        font-size: 12px;
        gap: 4px;
    }

    .search-page .results-toolbar {
        gap: 8px;
        overflow: visible;
    }

    .search-page .results-toolbar-left,
    .search-page .results-toolbar-right {
        width: 100%;
        justify-content: flex-start;
        flex-wrap: wrap;
    }

    .search-page .results-toolbar-left {
        justify-content: space-between;
        padding-right: 6px;
    }

    .search-page .view-toggle {
        gap: 4px;
        overflow: visible;
        margin-left: auto;
    }

    .search-page .view-btn {
        padding: 6px 8px;
        font-size: 11px;
        border-radius: 6px;
    }

    .search-page .view-btn.is-active {
        box-shadow: 0 0 0 1px #b7e6c0 inset;
    }

    .search-page .sort-trigger {
        padding: 6px 8px;
        font-size: 11px;
        border-radius: 6px;
    }

    .search-page .toolbar-notice {
        font-size: 11px;
        padding: 6px 8px;
    }

    .search-page .card-content {
        padding: 10px;
    }

    .search-page .listing-media {
        height: 150px;
    }

    .search-page .ad-title {
        font-size: 13px;
    }

    .search-page .ad-price {
        font-size: 15px;
    }

    .search-page .ad-meta {
        font-size: 11px;
        margin-bottom: 6px;
    }

    .search-page .ad-location {
        font-size: 11px;
    }
}

/* Search listing card match (results.png) */
.search-page .listing-card {
    border-radius: 6px;
    box-shadow: 0 1px 2px rgba(0, 0, 0, 0.06);
    border: none;
}

.search-page .img-wrapper {
    position: relative;
    display: flex;
    align-items: center;
    justify-content: center;
    height: 170px;
    background: #dedede;
    color: #9a9a9a;
}

.search-page .listing-placeholder i {
    font-size: 40px;
    color: #9a9a9a;
}

.search-page .card-content {
    padding: 14px 14px 12px;
}

.search-page .ad-title {
    font-size: 14px;
    font-weight: 700;
    color: #2d2d2d;
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
}

.search-page .ad-price {
    font-size: 18px;
    font-weight: 800;
    color: #3db83a;
    margin-bottom: 4px;
}

.search-page .ad-meta {
    font-size: 12px;
    color: #888;
    margin-bottom: 10px;
}

.search-page .ad-location {
    font-size: 12px;
    color: #999;
    display: flex;
    justify-content: space-between;
}

.search-page .listing-badges {
    top: 10px;
    right: 10px;
    left: auto;
}

.search-page .listing-badge {
    border-radius: 4px;
    font-size: 11px;
}

.search-page .results-grid.is-list .listing-card {
    flex-direction: row;
}

.search-page .results-grid.is-list .listing-media {
    width: 240px;
    height: 180px;
}

.search-page .results-grid.is-list .card-content {
    flex: 1;
    display: flex;
    flex-direction: column;
    justify-content: flex-start;
    padding: 14px;
    gap: 6px;
}

.search-page .results-grid.is-list .card-content {
    display: grid;
    grid-template-columns: 1fr auto;
    grid-template-areas:
        "title price"
        "desc desc"
        "tags tags"
        "meta meta";
    align-items: start;
    gap: 8px 16px;
}

.search-page .results-grid.is-list .ad-title {
    grid-area: title;
    font-size: 20px;
    font-weight: 700;
    color: #111827;
}

.search-page .results-grid.is-list .ad-price {
    grid-area: price;
    font-size: 20px;
    font-weight: 800;
    color: #16a34a;
    justify-self: end;
    white-space: nowrap;
}

.search-page .results-grid.is-list .ad-desc {
    grid-area: desc;
    display: block;
    font-size: 14px;
    color: #6b7280;
    line-height: 1.45;
}

.search-page .results-grid.is-list .ad-attrs {
    grid-area: tags;
    display: flex;
    flex-wrap: wrap;
    gap: 8px;
}

.search-page .results-grid.is-list .ad-attrs .attr-chip {
    display: inline-flex;
    align-items: center;
    padding: 6px 12px;
    border-radius: 8px;
    background: #f1f5f9;
    color: #1f2937;
    font-size: 13px;
    font-weight: 600;
}

.search-page .results-grid.is-list .ad-meta-stack {
    grid-area: meta;
    margin-top: 4px;
}

.search-page .results-grid.is-list .listing-content {
    flex: 1;
    display: flex;
    flex-direction: column;
    gap: 6px;
    padding: 14px;
}

.search-page .results-grid.is-list .ad-meta-stack {
    margin-top: 4px;
}

.search-page .results-grid.is-list .ad-meta-row {
    font-size: 12px;
    color: #6b7280;
}

@media (max-width: 640px) {
    .search-page .results-grid.is-list .listing-card {
        flex-direction: column;
    }

    .search-page .results-grid.is-list .listing-media {
        width: 100%;
        height: 180px;
    }
}

.search-page .results-grid.is-list .ad-title {
    font-size: 16px;
}

.search-page .results-grid.is-list .ad-meta {
    margin-bottom: 8px;
}

.search-page .results-grid.is-list .ad-location {
    margin-top: auto;
}

.search-page .results-summary {
    background: #fff;
    border-radius: 6px;
    padding: 10px 12px;
    margin-bottom: 14px;
    font-size: 13px;
    color: #6b7280;
    box-shadow: 0 1px 2px rgba(0, 0, 0, 0.05);
}

.search-page .results-summary .summary-label {
    font-weight: 700;
    color: #374151;
    margin-right: 6px;
}

.search-page .ad-desc,
.search-page .ad-attrs {
    display: none;
}

.search-page .ad-attrs {
    font-size: 12px;
    color: #6b7280;
    margin-bottom: 6px;
}

.search-page .ad-desc {
    font-size: 12px;
    color: #6b7280;
    line-height: 1.4;
    margin-bottom: 8px;
}

.search-page .results-grid.is-list .ad-desc,
.search-page .results-grid.is-list .ad-attrs {
    display: block;
}

/* Search listing badges: single-row compact chips */
.search-page .listing-badges {
    top: 8px;
    right: 8px;
    left: auto;
    display: flex;
    flex-direction: row;
    flex-wrap: nowrap;
    gap: 4px;
    max-width: calc(100% - 16px);
}

.search-page .listing-badge {
    padding: 2px 6px;
    font-size: 10px;
    border-radius: 4px;
    gap: 4px;
    white-space: nowrap;
}

.search-page .listing-badge i {
    font-size: 10px;
}

.listing-badge.badge-warning,
.ad-badge.badge-warning,
.promo-badge.promo-warning {
    background: #fef3c7;
    color: #92400e;
}

/* List view redesign overrides (keep last to win cascade) */
.search-page .results-grid.is-list .listing-card {
    border: 1px solid #e2e8f0;
    border-radius: 12px;
    background: #fff;
    box-shadow: 0 1px 2px rgba(15, 23, 42, 0.06);
    overflow: hidden;
    min-height: 220px;
    flex-direction: row;
    align-items: stretch;
}

.search-page .results-grid.is-list .listing-card:hover {
    border-color: #16a34a;
}

.search-page .results-grid.is-list .listing-media {
    width: 38%;
    min-width: 320px;
    height: 100%;
    align-self: stretch;
}

.search-page .results-grid.is-list .listing-content {
    flex: 1;
    display: flex;
    flex-direction: column;
    gap: 10px;
    padding: 18px 20px;
}

.search-page .results-grid.is-list .listing-header {
    display: flex;
    align-items: flex-start;
    justify-content: space-between;
    gap: 16px;
}

.search-page .results-grid.is-list .listing-title {
    font-size: 20px;
    font-weight: 700;
    color: #111827;
    line-height: 1.25;
    margin: 0;
}

.search-page .results-grid.is-list .listing-price {
    font-size: 20px;
    font-weight: 800;
    color: #16a34a;
    white-space: nowrap;
}

.search-page .results-grid.is-list .listing-desc {
    display: block;
    font-size: 14px;
    color: #6b7280;
    line-height: 1.45;
}

.search-page .results-grid.is-list .listing-attrs {
    display: flex;
    flex-wrap: wrap;
    gap: 8px;
}

.search-page .results-grid.is-list .listing-attrs .attr-chip {
    display: inline-flex;
    align-items: center;
    padding: 6px 12px;
    border-radius: 8px;
    background: #f1f5f9;
    color: #1f2937;
    font-size: 13px;
    font-weight: 600;
}

.search-page .results-grid.is-list .listing-meta {
    display: flex;
    align-items: center;
    gap: 12px;
    font-size: 13px;
    color: #64748b;
}

.search-page .results-grid.is-list .listing-meta i {
    color: #94a3b8;
}

.search-page .results-grid.is-list .listing-condition {
    display: inline-flex;
    align-items: center;
    padding: 4px 10px;
    border-radius: 999px;
    background: #ecfeff;
    color: #0369a1;
    font-size: 12px;
    font-weight: 700;
}

.search-page .results-grid.is-list .listing-footer {
    display: none;
}

.search-page .results-grid.is-list .listing-badges {
    top: 12px;
    left: 12px;
    right: auto;
    flex-direction: column;
    gap: 6px;
}

.search-page .results-grid.is-list .listing-badge {
    background: rgba(255, 255, 255, 0.9);
    border: 1px solid #e5e7eb;
    color: #111827;
    border-radius: 999px;
    padding: 4px 10px;
    font-size: 11px;
}

.search-page .results-grid.is-list .card-content {
    display: grid;
    grid-template-columns: 1fr auto;
    grid-template-areas:
        "title price"
        "desc desc"
        "tags tags"
        "meta meta";
    align-items: start;
    gap: 8px 16px;
    padding: 18px 20px;
}

.search-page .results-grid.is-list .ad-title {
    grid-area: title;
    font-size: 20px;
    font-weight: 700;
    color: #111827;
}

.search-page .results-grid.is-list .ad-price {
    grid-area: price;
    font-size: 20px;
    font-weight: 800;
    color: #16a34a;
    justify-self: end;
    white-space: nowrap;
}

.search-page .results-grid.is-list .ad-desc {
    grid-area: desc;
    display: block;
    font-size: 14px;
    color: #6b7280;
    line-height: 1.45;
}

.search-page .results-grid.is-list .ad-attrs {
    grid-area: tags;
    display: flex;
    flex-wrap: wrap;
    gap: 8px;
}

.search-page .results-grid.is-list .ad-attrs .attr-chip {
    display: inline-flex;
    align-items: center;
    padding: 6px 12px;
    border-radius: 8px;
    background: #f1f5f9;
    color: #1f2937;
    font-size: 13px;
    font-weight: 600;
}

.search-page .results-grid.is-list .ad-meta-stack {
    grid-area: meta;
    margin-top: 4px;
}

@media (max-width: 900px) {
    .search-page .results-grid.is-list .listing-media {
        width: 44%;
        min-width: 240px;
    }
}

@media (max-width: 640px) {
    .search-page .results-grid.is-list .listing-card {
        flex-direction: column;
    }

    .search-page .results-grid.is-list .listing-media {
        width: 100%;
        min-width: 0;
        height: 200px;
    }

    .search-page .results-grid.is-list .listing-content,
    .search-page .results-grid.is-list .card-content {
        padding: 14px 16px;
    }

    .search-page .results-grid.is-list .listing-title,
    .search-page .results-grid.is-list .ad-title {
        font-size: 18px;
    }

    .search-page .results-grid.is-list .listing-price,
    .search-page .results-grid.is-list .ad-price {
        font-size: 18px;
    }
}

.ad-meta-badge.badge-warning {
    background: #fff7ed;
    color: #9a3412;
}

.seller-warning-tag {
    position: absolute;
    left: 8px;
    top: 8px;
    display: inline-flex;
    align-items: center;
    gap: 6px;
    background: #fef3c7;
    color: #92400e;
    padding: 4px 8px;
    border-radius: 999px;
    font-size: 11px;
    font-weight: 600;
}

.listing-warning-banner {
    margin-top: 10px;
    display: flex;
    align-items: center;
    gap: 8px;
    padding: 8px 12px;
    background: #fff7ed;
    border: 1px solid #fdba74;
    color: #9a3412;
    border-radius: 8px;
    font-size: 13px;
    font-weight: 600;
}

.listing-escrow-reco {
    margin-top: 8px;
    display: flex;
    align-items: center;
    gap: 8px;
    padding: 8px 12px;
    background: #ecfdf3;
    border: 1px solid #86efac;
    color: #15803d;
    border-radius: 8px;
    font-size: 13px;
    font-weight: 600;
}

/* Auth pages (login/register/forgot) */
.auth-page {
    --auth-green: #3db83a;
    --auth-green-hover: #2e962b;
    --auth-orange: #ff8c00;
    --auth-bg: #f2f4f5;
    --auth-text: #292929;
    --auth-muted: #7d8597;
    --auth-border: #e0e4e8;
    --auth-shadow: 0 12px 40px rgba(0, 0, 0, 0.12);
    background-color: var(--auth-bg);
    color: var(--auth-text);
    min-height: 100vh;
    display: flex;
    flex-direction: column;
    font-family: 'Segoe UI', Roboto, Helvetica, Arial, sans-serif;
}

.auth-page *,
.auth-page *::before,
.auth-page *::after {
    box-sizing: border-box;
}

.auth-page a {
    text-decoration: none;
    color: inherit;
    transition: 0.2s;
}

.auth-page .auth-topbar {
    background: rgba(255, 255, 255, 0.95);
    padding: 14px 0;
    box-shadow: 0 6px 20px rgba(15, 23, 42, 0.06);
    position: sticky;
    top: 0;
    z-index: 50;
    backdrop-filter: blur(6px);
}

.auth-page .auth-topbar::after {
    content: '';
    display: block;
    height: 3px;
    background: linear-gradient(90deg, var(--auth-green), #7ddf6f, #ffc266);
    margin-top: 12px;
}

.auth-page .auth-topbar-center .header-con {
    justify-content: center;
}

.auth-page .header-con {
    max-width: 1200px;
    margin: 0 auto;
    padding: 0 20px;
    display: flex;
    justify-content: space-between;
    align-items: center;
}

.auth-page .logo {
    font-size: 24px;
    font-weight: 800;
    color: var(--auth-green);
    letter-spacing: -1px;
}

.auth-page .login-link,
.auth-page .register-link {
    font-size: 14px;
    color: var(--auth-text);
    font-weight: 500;
}

.auth-page .login-link span,
.auth-page .register-link span {
    color: var(--auth-green);
    font-weight: 700;
}

.auth-page .auth-wrapper {
    flex: 1;
    display: flex;
    align-items: center;
    justify-content: center;
    padding: 40px 20px;
}

.auth-page .auth-card {
    background: #fff;
    width: 100%;
    border-radius: 12px;
    box-shadow: var(--auth-shadow);
    overflow: hidden;
}

.auth-page .signup-card {
    max-width: 650px;
}

.auth-page .login-card {
    max-width: 900px;
    min-height: 600px;
    display: flex;
}

.auth-page .forgot-card {
    max-width: 400px;
    padding: 40px 30px;
    text-align: center;
}

.auth-page .forgot-card .form-group {
    text-align: left;
}

.auth-page .fancy-banner {
    height: 240px;
    background-image: url('https://images.unsplash.com/photo-1543639837-773a469614db?q=80&w=2000&auto=format&fit=crop');
    background-size: cover;
    background-position: center;
    position: relative;
    display: flex;
    flex-direction: column;
    justify-content: flex-end;
    padding: 25px 40px;
    color: #fff;
}

.auth-page .banner-overlay {
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    background: linear-gradient(to top, rgba(11, 20, 15, 0.95), rgba(61, 184, 58, 0.3));
    z-index: 1;
}

.auth-page .banner-content {
    position: relative;
    z-index: 2;
}

.auth-page .banner-title {
    font-size: 28px;
    font-weight: 800;
    margin-bottom: 5px;
    line-height: 1.2;
    text-shadow: 0 2px 4px rgba(0, 0, 0, 0.5);
}

.auth-page .banner-subtitle {
    font-size: 15px;
    opacity: 0.95;
    margin-bottom: 20px;
    font-weight: 500;
}

.auth-page .banner-features-grid {
    display: grid;
    grid-template-columns: auto auto;
    gap: 10px;
    max-width: 100%;
}

.auth-page .b-feat {
    font-size: 12px;
    background: rgba(255, 255, 255, 0.15);
    backdrop-filter: blur(5px);
    padding: 6px 12px;
    border-radius: 6px;
    display: inline-flex;
    align-items: center;
    gap: 8px;
    border: 1px solid rgba(255, 255, 255, 0.2);
    font-weight: 600;
    width: fit-content;
}

.auth-page .b-feat i {
    color: #4ade80;
    font-size: 14px;
}

.auth-page .card-body {
    padding: 30px 40px 40px;
}

.auth-page .form-grid {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 20px;
}

.auth-page .form-group {
    margin-bottom: 5px;
    position: relative;
}

.auth-page .form-group.full-width {
    grid-column: span 2;
}

.auth-page .form-group-spaced {
    margin-top: 15px;
    margin-bottom: 15px;
}

.auth-page label {
    display: block;
    font-size: 13px;
    font-weight: 600;
    color: #444;
    margin-bottom: 8px;
}

.auth-page input[type="text"],
.auth-page input[type="email"],
.auth-page input[type="password"],
.auth-page input[type="tel"],
.auth-page select {
    width: 100%;
    padding: 12px 15px;
    border: 1px solid var(--auth-border);
    border-radius: 12px;
    font-size: 15px;
    color: var(--auth-text);
    outline: none;
    transition: all 0.2s;
    background: #f9fbfc;
}

.auth-page input:focus,
.auth-page select:focus {
    border-color: var(--auth-green);
    background: #fff;
    box-shadow: 0 0 0 3px rgba(61, 184, 58, 0.1);
}

.auth-page .field-note {
    font-weight: 400;
    font-size: 11px;
    color: var(--auth-orange);
}

.auth-page .phone-wrapper {
    display: flex;
    border: 2px solid #d1d9e0;
    border-radius: 12px;
    overflow: hidden;
    background: #fff;
    transition: 0.2s;
    height: 56px;
    align-items: center;
}

.auth-page .phone-wrapper:focus-within {
    border-color: var(--auth-green);
    box-shadow: 0 4px 12px rgba(61, 184, 58, 0.15);
}

.auth-page .phone-prefix {
    background: #f1f4f6;
    padding: 0 20px;
    display: flex;
    align-items: center;
    font-weight: 700;
    color: #333;
    font-size: 16px;
    border-right: 1px solid #d1d9e0;
    height: 100%;
    white-space: nowrap;
}

.auth-page .phone-prefix img {
    width: 24px;
    margin-right: 8px;
}

.auth-page .phone-input {
    border: none !important;
    box-shadow: none !important;
    background: transparent !important;
    padding-left: 20px;
    font-size: 18px !important;
    font-weight: 500;
    height: 100%;
}

.auth-page .account-type-grid {
    display: grid;
    grid-template-columns: 1fr 1fr 1fr;
    gap: 10px;
}

.auth-page .type-option {
    position: relative;
}

.auth-page .type-option input {
    position: absolute;
    opacity: 0;
    cursor: pointer;
}

.auth-page .type-card {
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    padding: 12px;
    border: 1px solid var(--auth-border);
    border-radius: 12px;
    cursor: pointer;
    transition: 0.2s;
    background: #f9fbfc;
    height: 100%;
}

.auth-page .type-card i {
    font-size: 18px;
    margin-bottom: 5px;
    color: #aaa;
    transition: 0.2s;
}

.auth-page .type-card span {
    font-size: 13px;
    font-weight: 600;
    color: #555;
}

.auth-page .type-option input:checked+.type-card {
    border-color: var(--auth-green);
    background: #ebf9eb;
}

.auth-page .type-option input:checked+.type-card i,
.auth-page .type-option input:checked+.type-card span {
    color: var(--auth-green);
}

.auth-page .type-card-disabled {
    grid-column: span 3;
    cursor: default;
    opacity: 0.7;
}

.auth-page .password-container {
    position: relative;
}

.auth-page .toggle-pass {
    position: absolute;
    right: 15px;
    top: 50%;
    transform: translateY(-50%);
    color: #999;
    cursor: pointer;
    font-size: 14px;
    background: none;
    border: none;
}

.auth-page .password-strength {
    height: 4px;
    width: 100%;
    background: #eee;
    margin-top: 8px;
    border-radius: 2px;
    overflow: hidden;
    display: flex;
}

.auth-page .strength-bar {
    height: 100%;
    width: 0%;
    transition: 0.3s;
}

.auth-page .strength-text {
    font-size: 11px;
    margin-top: 4px;
    color: #888;
    text-align: right;
    display: block;
    min-height: 15px;
}

.auth-page .terms-box {
    display: flex;
    align-items: flex-start;
    gap: 10px;
    margin-top: 10px;
    margin-bottom: 25px;
}

.auth-page .terms-box input {
    margin-top: 3px;
    accent-color: var(--auth-green);
    width: 16px;
    height: 16px;
}

.auth-page .terms-box span {
    font-size: 13px;
    color: #666;
    line-height: 1.4;
}

.auth-page .terms-box a {
    color: var(--auth-green);
    font-weight: 600;
    text-decoration: underline;
}

.auth-page .btn-submit {
    width: 100%;
    padding: 16px;
    background-color: var(--auth-green);
    color: #fff;
    border: none;
    border-radius: 12px;
    font-size: 16px;
    font-weight: 700;
    cursor: pointer;
    transition: 0.2s;
    box-shadow: 0 4px 15px rgba(61, 184, 58, 0.4);
    letter-spacing: 0.5px;
}

.auth-page .btn-submit:hover {
    background-color: var(--auth-green-hover);
    transform: translateY(-1px);
}

.auth-page .divider {
    display: flex;
    align-items: center;
    text-align: center;
    margin: 30px 0 20px;
    color: #aaa;
    font-size: 13px;
}

.auth-page .divider::before,
.auth-page .divider::after {
    content: '';
    flex: 1;
    border-bottom: 1px solid #eee;
}

.auth-page .divider::before {
    margin-right: 15px;
}

.auth-page .divider::after {
    margin-left: 15px;
}

.auth-page .social-container {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 15px;
}

.auth-page .social-btn {
    display: flex;
    align-items: center;
    justify-content: center;
    padding: 12px;
    border-radius: 12px;
    font-size: 14px;
    font-weight: 600;
    cursor: pointer;
    transition: 0.2s;
    text-decoration: none;
}

.auth-page .btn-google {
    background: #fff;
    border: 1px solid #ddd;
    color: #444;
}

.auth-page .btn-google img {
    width: 18px;
    margin-right: 10px;
}

.auth-page .btn-facebook {
    background: #1877f2;
    border: 1px solid #1877f2;
    color: #fff;
}

.auth-page .btn-facebook i {
    margin-right: 10px;
    font-size: 16px;
}

.auth-page .login-page .social-container {
    display: flex;
    flex-direction: column;
    gap: 12px;
}

.auth-page .auth-footnote {
    text-align: center;
    font-size: 12px;
    color: #999;
    padding: 20px;
}

.auth-page .auth-form-side {
    flex: 1;
    padding: 50px 40px;
    display: flex;
    flex-direction: column;
    justify-content: center;
}

.auth-page .auth-header {
    margin-bottom: 30px;
}

.auth-page .auth-header h2 {
    font-size: 28px;
    font-weight: 700;
    margin-bottom: 8px;
    color: #1a1a1a;
}

.auth-page .auth-header p {
    color: var(--auth-muted);
    font-size: 15px;
}

.auth-page .auth-splash-side {
    flex: 1;
    background-image: url('https://images.unsplash.com/photo-1531123414780-f74242c2b052?q=80&w=1000&auto=format&fit=crop');
    background-size: cover;
    background-position: center;
    position: relative;
    display: flex;
    flex-direction: column;
    justify-content: flex-end;
    padding: 40px;
    color: #fff;
}

.auth-page .splash-overlay {
    position: absolute;
    top: 0;
    left: 0;
    right: 0;
    bottom: 0;
    background: linear-gradient(to bottom, rgba(61, 184, 58, 0.1), rgba(0, 0, 0, 0.8));
    z-index: 1;
}

.auth-page .splash-content {
    position: relative;
    z-index: 2;
}

.auth-page .splash-quote {
    font-size: 24px;
    font-weight: 700;
    line-height: 1.3;
    margin-bottom: 15px;
    text-shadow: 0 2px 4px rgba(0, 0, 0, 0.3);
}

.auth-page .splash-features {
    display: flex;
    flex-direction: column;
    gap: 10px;
    margin-bottom: 30px;
}

.auth-page .feature-item {
    display: flex;
    align-items: center;
    font-size: 14px;
    font-weight: 500;
    opacity: 0.9;
}

.auth-page .feature-item i {
    color: var(--auth-green);
    background: #fff;
    width: 24px;
    height: 24px;
    border-radius: 50%;
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 12px;
    margin-right: 10px;
}

.auth-page .carousel-dots {
    display: flex;
    gap: 8px;
}

.auth-page .dot {
    width: 8px;
    height: 8px;
    background: rgba(255, 255, 255, 0.4);
    border-radius: 50%;
}

.auth-page .dot.active {
    background: var(--auth-green);
    width: 24px;
    border-radius: 4px;
}

.auth-page .form-actions {
    display: flex;
    justify-content: space-between;
    align-items: center;
    margin-bottom: 25px;
    font-size: 13px;
}

.auth-page .remember-me {
    display: flex;
    align-items: center;
    gap: 8px;
    color: #666;
    cursor: pointer;
}

.auth-page .remember-me input {
    accent-color: var(--auth-green);
    width: 16px;
    height: 16px;
}

.auth-page .forgot-pass {
    color: var(--auth-orange);
    font-weight: 600;
}

.auth-page .forgot-pass:hover {
    text-decoration: underline;
}

.auth-page .icon-circle {
    width: 70px;
    height: 70px;
    background: #e8f5e9;
    color: var(--auth-green);
    border-radius: 50%;
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 28px;
    margin: 0 auto 20px;
}

.auth-page .forgot-card h2 {
    font-size: 22px;
    font-weight: 700;
    margin-bottom: 10px;
}

.auth-page .forgot-card p {
    color: var(--auth-muted);
    font-size: 14px;
    margin-bottom: 30px;
    line-height: 1.5;
}

.auth-page .back-link {
    display: block;
    margin-top: 25px;
    color: var(--auth-muted);
    font-size: 14px;
    font-weight: 500;
}

.auth-page .back-link i {
    margin-right: 5px;
    font-size: 12px;
}

.auth-page .back-link:hover {
    color: var(--auth-green);
}

.auth-page .auth-alert {
    padding: 12px 14px;
    border-radius: 10px;
    margin-bottom: 16px;
    font-size: 13px;
}

.auth-page .auth-alert-error {
    background: #fee2e2;
    color: #991b1b;
    border: 1px solid #fecaca;
}

.auth-page .auth-alert-success {
    background: #dcfce7;
    color: #166534;
    border: 1px solid #bbf7d0;
}

.auth-page .auth-alert-warn {
    background: #fffbeb;
    color: #92400e;
    border: 1px solid #fde68a;
}

.auth-page .auth-alert-info {
    background: #e0f2fe;
    color: #1e3a8a;
    border: 1px solid #bae6fd;
}

@media (max-width: 900px) {
    .auth-page .auth-splash-side {
        display: none;
    }

    .auth-page .login-card {
        max-width: 500px;
        min-height: auto;
    }

    .auth-page .auth-form-side {
        padding: 30px 25px;
    }
}

@media (max-width: 768px) {
    .auth-page .signup-card {
        max-width: 100%;
        border-radius: 0;
        box-shadow: none;
    }

    .auth-page .card-body {
        padding: 25px 20px;
    }

    .auth-page .fancy-banner {
        padding: 20px;
        border-radius: 0;
        height: auto;
        min-height: 200px;
    }

    .auth-page .banner-features-grid {
        grid-template-columns: 1fr 1fr;
    }

    .auth-page .form-grid {
        grid-template-columns: 1fr;
        gap: 15px;
    }

    .auth-page .form-group.full-width {
        grid-column: span 1;
    }

    .auth-page .account-type-grid {
        grid-template-columns: 1fr;
    }

    .auth-page .type-card {
        flex-direction: row;
        padding: 15px;
        justify-content: flex-start;
        gap: 15px;
    }

    .auth-page .type-card i {
        margin-bottom: 0;
    }

    .auth-page .social-container {
        grid-template-columns: 1fr;
    }
}

@media (max-width: 500px) {
    .auth-page .login-card {
        box-shadow: none;
        background: transparent;
    }

    .auth-page .auth-form-side {
        padding: 10px 0;
    }

    .auth-page .auth-topbar {
        display: none;
    }

    .auth-page {
        background: #fff;
        padding: 2px;
    }
}

.price-row select {
    min-width: 140px;
    flex: 0 0 140px;
}

.price-row .price-unit-select {
    flex: 0 0 120px;
    min-width: 120px;
}

/* Post Ad price controls (formatted amount + clearer spacing) */
.post-ad-page .price-row {
    align-items: center;
    flex-wrap: wrap;
    gap: 8px;
}

.post-ad-page .price-input {
    flex: 1 1 250px;
    min-width: 0;
    position: relative;
}

.post-ad-page .price-input .currency-symbol {
    position: absolute;
    left: 8px;
    top: 50%;
    transform: translateY(-50%);
    min-width: 50px;
    height: 32px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    padding: 0 8px;
    border-radius: 8px;
    border: 1px solid #dbe2ea;
    background: #f5f7fa;
    color: #4b5563;
    font-weight: 700;
    font-size: 12px;
    line-height: 1;
}

.post-ad-page .price-input #price-display {
    padding-left: 68px;
    font-weight: 700;
    font-variant-numeric: tabular-nums;
    letter-spacing: 0.01em;
}

.post-ad-page .price-row>select {
    flex: 0 0 128px;
    min-width: 108px;
}

.post-ad-page .price-row .checkbox-inline {
    margin-left: auto;
}

@media (max-width: 640px) {
    .post-ad-page .price-row>select {
        flex: 1 1 calc(50% - 4px);
        min-width: 0;
    }

    .post-ad-page .price-row .checkbox-inline {
        margin-left: 0;
        width: 100%;
    }
}

/* ============================================================================
   MODERATION FEEDBACK
   ============================================================================ */
.moderation-feedback-box {
    background-color: #fff;
    border-radius: 12px;
    box-shadow: 0 4px 6px -1px rgba(0, 0, 0, 0.1), 0 2px 4px -1px rgba(0, 0, 0, 0.06);
    overflow: hidden;
    margin: 2rem 0;
    border: 1px solid #e5e7eb;
    border-left: 5px solid #f59e0b;
}

.moderation-header {
    background-color: #fffbeb;
    padding: 1rem 1.5rem;
    border-bottom: 1px solid #fef3c7;
    display: flex;
    justify-content: space-between;
    align-items: center;
}

.moderation-title {
    display: flex;
    align-items: center;
    gap: 0.75rem;
}

.moderation-title h5 {
    margin: 0;
    color: #92400e;
    font-weight: 700;
    font-size: 1.1rem;
}

.moderation-icon {
    color: #f59e0b;
    font-size: 1.5rem;
}

.moderation-body {
    padding: 1.5rem;
}

.moderation-note {
    background-color: #fff7ed;
    border: 1px solid #ffedd5;
    border-radius: 8px;
    padding: 1rem;
    color: #9a3412;
    margin-bottom: 1.5rem;
    line-height: 1.6;
}

.moderation-checklist h6 {
    font-weight: 700;
    color: #374151;
    margin-bottom: 0.75rem;
    display: flex;
    align-items: center;
    gap: 0.5rem;
}

.moderation-list-item {
    display: flex;
    align-items: center;
    gap: 0.75rem;
    padding: 0.75rem 1rem;
    background-color: #f9fafb;
    border: 1px solid #e5e7eb;
    border-radius: 6px;
    margin-bottom: 0.5rem;
    color: #4b5563;
}

.moderation-list-item i {
    color: #ef4444;
}

.moderation-deadline {
    display: inline-flex;
    align-items: center;
    gap: 0.5rem;
    background-color: #fef2f2;
    color: #b91c1c;
    padding: 0.5rem 1rem;
    border-radius: 9999px;
    font-size: 0.875rem;
    font-weight: 600;
}

.moderation-footer {
    display: flex;
    justify-content: flex-end;
    padding-top: 1.5rem;
    border-top: 1px solid #f3f4f6;
    margin-top: 1rem;
}

.btn-edit-fix {
    background-color: #f59e0b;
    color: #fff;
    font-weight: 600;
    padding: 0.75rem 1.5rem;
    border-radius: 8px;
    display: inline-flex;
    align-items: center;
    gap: 0.5rem;
    box-shadow: 0 4px 6px rgba(245, 158, 11, 0.2);
    transition: all 0.2s;
}

.btn-edit-fix:hover {
    background-color: #d97706;
    text-decoration: none;
    transform: translateY(-1px);
    box-shadow: 0 6px 8px rgba(245, 158, 11, 0.3);
}

.btn-sidebar-edit {
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 0.5rem;
    background: #ffffff;
    border: 1px solid #e2e8f0;
    color: #1e293b;
    font-weight: 600;
    padding: 12px;
    border-radius: 8px;
    transition: all 0.2s;
    box-shadow: 0 1px 2px rgba(0, 0, 0, 0.05);
}

.btn-sidebar-edit:hover {
    background: #f8fafc;
    border-color: #cbd5e1;
    color: #0f172a;
    text-decoration: none;
}

/* ============================================================================
   SEARCH LIST VIEW REDESIGN (Jiji Style - Final Robust)
   ============================================================================ */
.results-grid.is-list {
    display: flex !important;
    flex-direction: column !important;
    gap: 16px !important;
}

.results-grid.is-list .listing-card {
    display: flex !important;
    flex-direction: row !important;
    /* Force side-by-side */
    height: auto !important;
    min-height: 200px !important;
    /* Robust height */
    align-items: stretch !important;
    border: 1px solid #e2e8f0;
    border-radius: 6px;
    background: #fff;
    transition: all 0.2s ease;
    padding: 0 !important;
    overflow: hidden;
    /* Ensure image doesn't overflow corners */
}

.results-grid.is-list .listing-card:hover {
    box-shadow: 0 4px 15px rgba(0, 0, 0, 0.08);
    border-color: #16a34a;
}

/* Image/Media Container - Left Side */
.results-grid.is-list .listing-media {
    display: block !important;
    width: 260px !important;
    /* Fixed standard width */
    min-width: 260px !important;
    height: auto !important;
    min-height: 100% !important;
    /* Fill vertical space */
    flex-shrink: 0 !important;
    position: relative !important;
    border-right: 1px solid #f1f5f9;
    background: #f8fafc;
    margin: 0 !important;
}

/* The Image Itself */
.results-grid.is-list .listing-media img {
    position: absolute !important;
    top: 0;
    left: 0;
    width: 100% !important;
    height: 100% !important;
    object-fit: cover !important;
    z-index: 10;
    display: block !important;
    border-radius: 0 !important;
    /* remove defaults */
}

/* Content Container - Right Side */
.results-grid.is-list .listing-content {
    flex: 1 !important;
    display: flex !important;
    flex-direction: column !important;
    justify-content: space-between;
    /* Space out elements */
    padding: 16px 20px !important;
    gap: 8px;
    min-width: 0;
    /* Fix flex text overflow */
}

/* Header: Title & Price */
.results-grid.is-list .listing-header {
    display: flex;
    justify-content: space-between;
    align-items: flex-start;
    margin-bottom: 4px;
    gap: 16px;
}

.results-grid.is-list .listing-title {
    font-size: 18px !important;
    /* Jiji Standard */
    font-weight: 600 !important;
    color: #111827;
    margin: 0 !important;
    line-height: 1.35;
    display: -webkit-box;
    -webkit-line-clamp: 2;
    -webkit-box-orient: vertical;
    overflow: hidden;
}

.results-grid.is-list .listing-price {
    flex-shrink: 0;
    text-align: right;
    display: flex;
    flex-direction: column;
    align-items: flex-end;
}

.results-grid.is-list .price-value {
    color: #16a34a !important;
    /* Jiji Green */
    font-weight: 800 !important;
    font-size: 20px !important;
    white-space: nowrap;
}

/* Elements */
.results-grid.is-list .listing-desc {
    font-size: 14px;
    color: #64748b;
    margin-bottom: 8px;
    display: -webkit-box;
    -webkit-line-clamp: 2;
    -webkit-box-orient: vertical;
    overflow: hidden;
    line-height: 1.5;
}

.results-grid.is-list .listing-attrs {
    display: flex;
    flex-wrap: wrap;
    gap: 8px;
    margin-top: 4px;
}

.results-grid.is-list .attr-chip {
    background: #f1f5f9;
    color: #334155;
    font-size: 12px;
    padding: 4px 10px;
    border-radius: 4px;
    font-weight: 500;
}

.results-grid.is-list .listing-meta {
    display: flex;
    justify-content: space-between;
    align-items: center;
    margin-top: auto;
    /* Push to bottom */
    padding-top: 12px;
    border-top: 1px solid #f1f5f9;
    color: #94a3b8;
    font-size: 13px;
}

.results-grid.is-list .listing-location i {
    color: #16a34a;
    /* Jiji green icon */
    margin-right: 4px;
}

/* Badges */
.results-grid.is-list .listing-badges {
    top: 10px;
    left: 10px;
    flex-direction: column;
    align-items: flex-start;
    gap: 4px;
}

/* Mobile Optimization (Compact Jiji Style) */
@media (max-width: 768px) {
    .results-grid.is-list .listing-card {
        min-height: 120px !important;
        height: auto !important;
    }

    .results-grid.is-list .listing-media {
        width: 140px !important;
        min-width: 140px !important;
        height: auto !important;
        /* Let it fill parent height */
    }

    .results-grid.is-list .listing-content {
        padding: 12px !important;
        gap: 4px;
    }

    .results-grid.is-list .listing-title {
        font-size: 15px !important;
        line-height: 1.3;
    }

    .results-grid.is-list .price-value {
        font-size: 16px !important;
    }

    .results-grid.is-list .listing-desc {
        display: none !important;
        /* Max compactness */
    }

    .results-grid.is-list .listing-meta {
        margin-top: 8px;
        padding-top: 8px;
        font-size: 11px;
    }

    .results-grid.is-list .attr-chip {
        padding: 2px 6px;
        font-size: 10px;
    }
}

/* Search list view final override (match listviewside.png) */
.search-page .results-grid.is-list {
    display: flex;
    flex-direction: column;
    gap: 16px;
}

.search-page .results-grid.is-list .listing-card {
    display: flex;
    flex-direction: row;
    align-items: stretch;
    border: 2px solid #22c55e;
    border-radius: 12px;
    background: #fff;
    box-shadow: 0 2px 6px rgba(15, 23, 42, 0.06);
    overflow: hidden;
    min-height: 220px;
}

.search-page .results-grid.is-list .listing-card:hover {
    border-color: #16a34a;
}

.search-page .results-grid.is-list .listing-media,
.search-page .results-grid.is-list .img-wrapper {
    width: 38%;
    min-width: 320px;
    height: 200px !important;
    min-height: 200px;
    align-self: stretch;
    overflow: hidden;
    position: relative;
    border-right: 1px solid #e5e7eb;
    background: #f8fafc;
}

.search-page .results-grid.is-list .listing-media img {
    position: static !important;
    width: 100%;
    height: 100%;
    object-fit: cover;
    display: block;
}

.search-page .results-grid.is-list .listing-content {
    flex: 1;
    padding: 18px 20px;
    display: flex;
    flex-direction: column;
    gap: 10px;
}

.search-page .results-grid.is-list .listing-header {
    display: flex;
    justify-content: space-between;
    align-items: flex-start;
    gap: 16px;
}

.search-page .results-grid.is-list .listing-title {
    font-size: 20px;
    font-weight: 700;
    color: #111827;
    line-height: 1.25;
}

.search-page .results-grid.is-list .listing-price {
    font-size: 20px;
    font-weight: 800;
    color: #16a34a;
    white-space: nowrap;
}

.search-page .results-grid.is-list .listing-desc {
    display: block !important;
    font-size: 14px;
    color: #6b7280;
    line-height: 1.45;
}

.search-page .results-grid.is-list .listing-attrs {
    display: flex;
    flex-wrap: wrap;
    gap: 8px;
}

.search-page .results-grid.is-list .listing-attrs .attr-chip {
    display: inline-flex;
    align-items: center;
    padding: 6px 12px;
    border-radius: 8px;
    background: #f1f5f9;
    color: #1f2937;
    font-size: 13px;
    font-weight: 600;
}

.search-page .results-grid.is-list .listing-meta {
    display: flex;
    align-items: center;
    gap: 12px;
    font-size: 13px;
    color: #64748b;
}

.search-page .results-grid.is-list .listing-location i {
    color: #16a34a;
    margin-right: 6px;
}

.search-page .results-grid.is-list .listing-badges {
    position: absolute;
    top: 10px;
    left: 10px;
    display: flex;
    flex-direction: column;
    gap: 6px;
    z-index: 2;
}

.search-page .results-grid.is-list .listing-condition {
    display: inline-flex;
    align-items: center;
    padding: 4px 10px;
    border-radius: 999px;
    background: #e2f1ff;
    color: #1e40af;
    font-size: 12px;
    font-weight: 700;
}

@media (max-width: 900px) {

    .search-page .results-grid.is-list .listing-media,
    .search-page .results-grid.is-list .img-wrapper {
        width: 44%;
        min-width: 240px;
        height: 180px !important;
    }
}

@media (max-width: 640px) {
    .search-page .results-grid.is-list .listing-card {
        flex-direction: column;
    }

    .search-page .results-grid.is-list .listing-media,
    .search-page .results-grid.is-list .img-wrapper {
        width: 100%;
        min-width: 0;
        height: 200px !important;
    }

    .search-page .results-grid.is-list .listing-content {
        padding: 14px 16px;
    }

    .search-page .results-grid.is-list .listing-title,
    .search-page .results-grid.is-list .listing-price {
        font-size: 18px;
    }
}

/* ============================================================================
   Default Theme: Mobile Category + Search Drawer + Dashboard Hero Refresh
============================================================================ */

/* Home category subview: always keep close controls visible on mobile */
.home-wireframe .sub-cat-view {
    position: fixed;
    inset: 0;
    background: #fff;
    z-index: 5100;
    display: flex;
    flex-direction: column;
    transform: translateX(100%);
    visibility: hidden;
    pointer-events: none;
    transition: transform 0.28s ease, visibility 0.28s ease;
}

.home-wireframe .sub-cat-view.active {
    transform: translateX(0);
    visibility: visible;
    pointer-events: auto;
}

.home-wireframe .sub-cat-header {
    background: var(--primary-green);
    padding: 12px 14px;
    display: flex;
    align-items: center;
    gap: 10px;
    color: #fff;
    position: sticky;
    top: 0;
    z-index: 2;
}

.home-wireframe .sub-cat-header .back-btn {
    border: none;
    background: transparent;
    color: #fff;
    display: inline-flex;
    align-items: center;
    gap: 6px;
    font-size: 16px;
    font-weight: 700;
    cursor: pointer;
    padding: 4px 2px;
}

.home-wireframe .sub-cat-header .back-btn span {
    font-size: 14px;
}

.home-wireframe .sub-cat-header .sub-close-btn {
    border: none;
    background: rgba(255, 255, 255, 0.18);
    color: #fff;
    width: 34px;
    height: 34px;
    border-radius: 10px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    cursor: pointer;
    flex-shrink: 0;
}

.home-wireframe .sub-search-input {
    flex: 1;
    background: #fff;
    border-radius: 8px;
    padding: 10px 12px;
    display: flex;
    align-items: center;
    min-width: 0;
}

.home-wireframe .sub-search-input input {
    width: 100%;
    border: none;
    outline: none;
    font-size: 16px;
    background: transparent;
}

body.sub-cat-open {
    overflow: hidden;
}

body.sub-cat-open .site-header,
body.sub-cat-open .mobile-nav {
    visibility: hidden;
}

/* Search filter drawer: explicit close button for mobile */
.search-page .mobile-filter-head {
    display: none;
}

@media (max-width: 991px) {
    .search-page .mobile-filter-head {
        display: flex;
        align-items: center;
        justify-content: space-between;
        gap: 10px;
        position: sticky;
        top: 0;
        z-index: 3;
        padding: 10px 0 12px;
        background: #f8fafc;
        border-bottom: 1px solid #e2e8f0;
        margin-bottom: 12px;
    }

    .search-page .mobile-filter-title {
        font-size: 16px;
        font-weight: 800;
        color: #0f172a;
    }

    .search-page .mobile-filter-close {
        border: none;
        background: #e2e8f0;
        color: #0f172a;
        width: 34px;
        height: 34px;
        border-radius: 10px;
        display: inline-flex;
        align-items: center;
        justify-content: center;
        cursor: pointer;
    }
}

/* Dashboard refresh (default theme) */
.account-page .account-dashboard {
    display: flex;
    flex-direction: column;
    gap: 20px;
    padding: 8px 0 24px;
}

.account-page .account-dashboard .dash-hero {
    background: linear-gradient(135deg, #ffffff 0%, #ecfdf3 100%);
    border: 1px solid #dbe8df;
    border-radius: 22px;
    padding: 22px;
    display: grid;
    grid-template-columns: 1.2fr 0.8fr;
    gap: 20px;
}

.account-page .account-dashboard .dash-pill {
    display: inline-flex;
    align-items: center;
    gap: 6px;
    padding: 6px 12px;
    border-radius: 999px;
    background: rgba(61, 184, 58, 0.14);
    color: #166534;
    font-size: 11px;
    font-weight: 700;
    letter-spacing: 0.08em;
    text-transform: uppercase;
}

.account-page .account-dashboard .dash-hero-copy h2 {
    margin: 10px 0 6px;
    font-size: 20px;
    font-weight: 800;
    color: #0f172a;
}

.account-page .account-dashboard .dash-hero-copy p {
    margin: 0 0 16px;
    font-size: 14px;
    color: #475569;
}

.account-page .account-dashboard .dash-hero-actions {
    display: flex;
    flex-wrap: wrap;
    gap: 10px;
}

.account-page .account-dashboard .dash-hero-actions .btn {
    border-radius: 999px;
    padding: 10px 10px;
    font-weight: 700;
    font-size: 12px;
}

.account-page .account-dashboard .dash-hero-actions .btn-outline {
    border: 1px solid #9ca3af;
    color: #334155;
    background: #fff;
}

.account-page .account-dashboard .dash-hero-chips {
    margin-top: 14px;
    display: flex;
    flex-wrap: wrap;
    gap: 8px;
}

.account-page .account-dashboard .dash-chip {
    display: inline-flex;
    align-items: center;
    gap: 6px;
    padding: 6px 10px;
    border-radius: 999px;
    background: #fff;
    border: 1px solid #dbe4ee;
    font-size: 11px;
    font-weight: 700;
    color: #334155;
}

.account-page .account-dashboard .dash-chip strong {
    color: #166534;
}

.account-page .account-dashboard .dash-chip.is-good {
    background: rgba(34, 197, 94, 0.14);
    color: #166534;
    border-color: rgba(34, 197, 94, 0.35);
}

.account-page .account-dashboard .dash-chip.is-bad {
    background: rgba(239, 68, 68, 0.12);
    color: #991b1b;
    border-color: rgba(239, 68, 68, 0.3);
}

.account-page .account-dashboard .dash-hero-cards {
    display: grid;
    gap: 12px;
}

.account-page .account-dashboard .hero-card {
    background: #fff;
    border: 1px solid #dbe4ee;
    border-radius: 16px;
    padding: 14px 16px;
    box-shadow: 0 8px 18px rgba(15, 23, 42, 0.06);
}

.account-page .account-dashboard .hero-card-label {
    font-size: 12px;
    color: #64748b;
    font-weight: 600;
}

.account-page .account-dashboard .hero-card-value {
    margin-top: 6px;
    font-size: 24px;
    font-weight: 800;
    color: #0f172a;
}

.account-page .account-dashboard .hero-card-meta {
    margin-top: 4px;
    font-size: 12px;
    color: #64748b;
}

.account-page .account-dashboard .hero-card-link {
    display: inline-flex;
    align-items: center;
    margin-top: 8px;
    font-size: 12px;
    font-weight: 700;
    color: #16a34a;
    text-decoration: none;
}

.account-page .account-dashboard .hero-card-link:hover {
    text-decoration: underline;
    color: #15803d;
}

.account-page .account-dashboard .dash-stats {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 16px;
}

.account-page .account-dashboard .stat-card {
    background: #fff;
    border: 1px solid #dbe4ee;
    border-radius: 16px;
    padding: 16px;
    display: flex;
    flex-direction: column;
    gap: 10px;
    box-shadow: 0 8px 18px rgba(15, 23, 42, 0.05);
}

.account-page .account-dashboard .stat-head {
    display: flex;
    align-items: center;
    gap: 10px;
}

.account-page .account-dashboard .stat-icon {
    width: 40px;
    height: 40px;
    border-radius: 12px;
    display: grid;
    place-items: center;
    background: rgba(61, 184, 58, 0.14);
    color: #166534;
}

.account-page .account-dashboard .stat-label {
    font-size: 13px;
    font-weight: 700;
    color: #1e293b;
}

.account-page .account-dashboard .stat-meta {
    font-size: 12px;
    color: #64748b;
}

.account-page .account-dashboard .stat-value {
    font-size: 24px;
    font-weight: 800;
    color: #0f172a;
}

.account-page .account-dashboard .score-display {
    padding: 14px;
    display: grid;
    place-items: center;
    gap: 12px;
}

.account-page .account-dashboard .score-circle {
    width: 132px;
    height: 132px;
    border-radius: 50%;
    display: grid;
    place-items: center;
}

.account-page .account-dashboard .score-inner {
    width: 98px;
    height: 98px;
    border-radius: 50%;
    background: #fff;
    display: grid;
    place-items: center;
    text-align: center;
}

.account-page .account-dashboard .score-number {
    font-size: 30px;
    font-weight: 800;
    color: #0f172a;
    line-height: 1;
}

.account-page .account-dashboard .score-label {
    font-size: 11px;
    font-weight: 700;
    color: #64748b;
    text-transform: uppercase;
    letter-spacing: 0.08em;
}

.account-page .account-dashboard .tier-badge-centered {
    display: inline-flex;
    align-items: center;
    gap: 6px;
    font-size: 12px;
    font-weight: 700;
}

.account-page .account-dashboard .stat-micro-grid {
    display: grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: 8px;
}

.account-page .account-dashboard .micro-col,
.account-page .account-dashboard .stat-micro-box {
    border: 1px solid #dbe4ee;
    border-radius: 12px;
    background: #f8fafc;
    padding: 8px 10px;
}

.account-page .account-dashboard .micro-label,
.account-page .account-dashboard .stat-micro-box .label {
    font-size: 11px;
    color: #64748b;
    font-weight: 700;
    margin-bottom: 4px;
}

.account-page .account-dashboard .micro-status,
.account-page .account-dashboard .stat-micro-box .value {
    font-size: 12px;
    font-weight: 700;
    color: #334155;
}

.account-page .account-dashboard .micro-status.success {
    color: #15803d;
}

.account-page .account-dashboard .micro-status.muted {
    color: #64748b;
}

.account-page .account-dashboard .stat-actions {
    display: flex;
    flex-wrap: wrap;
    gap: 8px;
    margin-top: 8px;
}

.account-page .account-dashboard .dash-link-chip {
    display: inline-flex;
    align-items: center;
    gap: 6px;
    border-radius: 999px;
    padding: 7px 12px;
    font-size: 12px;
    font-weight: 700;
    background: #16a34a;
    color: #fff;
    border: 1px solid #16a34a;
}

.account-page .account-dashboard .dash-link-chip.outline {
    background: #fff;
    color: #166534;
    border-color: #86efac;
}

.account-page .account-dashboard .dash-grid,
.account-page .account-dashboard .dash-bottom {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 16px;
}

.account-page .account-dashboard .dash-panel {
    background: #fff;
    border: 1px solid #dbe4ee;
    border-radius: 16px;
    padding: 16px;
    display: flex;
    flex-direction: column;
    gap: 12px;
    box-shadow: 0 8px 18px rgba(15, 23, 42, 0.05);
}

.account-page .account-dashboard .dash-panel-head {
    display: flex;
    align-items: flex-start;
    justify-content: space-between;
    gap: 10px;
}

.account-page .account-dashboard .dash-panel-title {
    font-size: 16px;
    font-weight: 800;
    color: #0f172a;
}

.account-page .account-dashboard .dash-panel-sub {
    font-size: 12px;
    color: #64748b;
}

.account-page .account-dashboard .dash-panel-badge,
.account-page .account-dashboard .dash-panel-pill {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    border-radius: 999px;
    padding: 4px 10px;
    font-size: 12px;
    font-weight: 700;
}

.account-page .account-dashboard .dash-panel-badge {
    background: #16a34a;
    color: #fff;
}

.account-page .account-dashboard .dash-panel-pill {
    background: #e8f5e9;
    color: #166534;
    border: 1px solid #bbf7d0;
}

.account-page .account-dashboard .dash-panel-attention {
    border-color: #fde68a;
    box-shadow: 0 12px 20px rgba(217, 119, 6, 0.12);
}

.account-page .account-dashboard .dash-panel-head-attention {
    position: relative;
}

.account-page .account-dashboard .dash-panel-focus {
    display: inline-flex;
    margin-left: 8px;
    padding: 2px 8px;
    border-radius: 999px;
    background: #f59e0b;
    color: #fff;
    font-size: 10px;
    font-weight: 800;
    text-transform: uppercase;
    letter-spacing: 0.06em;
    animation: dashPulse 1.8s ease-in-out infinite;
}

@keyframes dashPulse {
    0% {
        box-shadow: 0 0 0 0 rgba(245, 158, 11, 0.35);
    }

    70% {
        box-shadow: 0 0 0 8px rgba(245, 158, 11, 0);
    }

    100% {
        box-shadow: 0 0 0 0 rgba(245, 158, 11, 0);
    }
}

.account-page .account-dashboard .dash-actions {
    display: flex;
    flex-direction: column;
    gap: 10px;
}

.account-page .account-dashboard .dash-action {
    display: flex;
    align-items: center;
    gap: 12px;
    border: 1px solid #e2e8f0;
    border-radius: 12px;
    padding: 11px 12px;
    background: #f8fafc;
}

.account-page .account-dashboard .dash-action.is-urgent {
    background: #fff7ed;
    border-color: #fdba74;
}

.account-page .account-dashboard .dash-action-icon {
    width: 36px;
    height: 36px;
    border-radius: 10px;
    display: grid;
    place-items: center;
    background: #dcfce7;
    color: #166534;
    flex-shrink: 0;
}

.account-page .account-dashboard .dash-action-icon.is-warm {
    background: #ffedd5;
    color: #9a3412;
}

.account-page .account-dashboard .dash-action-body {
    flex: 1;
    min-width: 0;
}

.account-page .account-dashboard .dash-action-title {
    font-size: 14px;
    font-weight: 700;
    color: #0f172a;
}

.account-page .account-dashboard .dash-action-meta {
    font-size: 12px;
    color: #64748b;
}

.account-page .account-dashboard .dash-action-arrow {
    color: #94a3b8;
    font-size: 12px;
}

.account-page .account-dashboard .dash-empty {
    border: 1px dashed #86efac;
    border-radius: 12px;
    background: #f0fdf4;
    padding: 12px;
    display: flex;
    align-items: center;
    gap: 10px;
}

.account-page .account-dashboard .dash-empty-icon {
    width: 36px;
    height: 36px;
    border-radius: 999px;
    display: grid;
    place-items: center;
    background: #bbf7d0;
    color: #166534;
}

.account-page .account-dashboard .dash-empty-title {
    font-size: 13px;
    font-weight: 800;
    color: #166534;
}

.account-page .account-dashboard .dash-empty-meta {
    font-size: 12px;
    color: #166534;
}

.account-page .account-dashboard .dash-panel-foot {
    border-top: 1px solid #e2e8f0;
    padding-top: 10px;
}

.account-page .account-dashboard .dash-link {
    font-size: 13px;
    font-weight: 700;
    color: #166534;
}

.account-page .account-dashboard .dash-quick-grid {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 10px;
}

.account-page .account-dashboard .dash-quick-card {
    display: flex;
    align-items: center;
    gap: 10px;
    border: 1px solid #dbe4ee;
    border-radius: 12px;
    padding: 12px;
    background: #f8fafc;
}

.account-page .account-dashboard .dash-quick-card.is-primary {
    background: #16a34a;
    border-color: #16a34a;
    color: #fff;
}

.account-page .account-dashboard .dash-quick-icon {
    width: 34px;
    height: 34px;
    border-radius: 10px;
    display: grid;
    place-items: center;
    background: #dcfce7;
    color: #166534;
    flex-shrink: 0;
}

.account-page .account-dashboard .dash-quick-card.is-primary .dash-quick-icon {
    background: rgba(255, 255, 255, 0.18);
    color: #fff;
}

.account-page .account-dashboard .dash-quick-title {
    font-size: 13px;
    font-weight: 800;
}

.account-page .account-dashboard .dash-quick-meta {
    font-size: 11px;
    color: #64748b;
}

.account-page .account-dashboard .dash-quick-card.is-primary .dash-quick-meta {
    color: rgba(255, 255, 255, 0.8);
}

.account-page .account-dashboard .dash-mini-card {
    border: 1px dashed #cbd5e1;
    border-radius: 12px;
    background: #f8fafc;
    padding: 12px;
}

.account-page .account-dashboard .dash-mini-label {
    font-size: 12px;
    color: #64748b;
    font-weight: 700;
}

.account-page .account-dashboard .dash-mini-value {
    margin-top: 4px;
    font-size: 24px;
    font-weight: 800;
    color: #0f172a;
}

.account-page .account-dashboard .dash-listings,
.account-page .account-dashboard .dash-message-list {
    display: flex;
    flex-direction: column;
    gap: 10px;
}

.account-page .account-dashboard .dash-listing-item,
.account-page .account-dashboard .dash-message {
    display: flex;
    align-items: center;
    gap: 10px;
    border: 1px solid #e2e8f0;
    border-radius: 12px;
    padding: 10px 12px;
    background: #fff;
}

.account-page .account-dashboard .dash-listing-info,
.account-page .account-dashboard .dash-message>div {
    flex: 1;
    min-width: 0;
}

.account-page .account-dashboard .dash-listing-title,
.account-page .account-dashboard .dash-message-name {
    font-size: 13px;
    font-weight: 700;
    color: #0f172a;
}

.account-page .account-dashboard .dash-listing-meta,
.account-page .account-dashboard .dash-message-text {
    font-size: 12px;
    color: #64748b;
}

.account-page .account-dashboard .dash-listing-actions {
    display: inline-flex;
    gap: 8px;
}

.account-page .account-dashboard .dash-avatar {
    width: 36px;
    height: 36px;
    border-radius: 999px;
    display: grid;
    place-items: center;
    background: #e2e8f0;
    color: #334155;
    font-size: 12px;
    font-weight: 800;
    flex-shrink: 0;
}

.account-page .account-dashboard .dash-message-arrow {
    color: #94a3b8;
    font-size: 12px;
}

@media (max-width: 1080px) {
    .account-page .account-dashboard .dash-hero {
        grid-template-columns: 1fr;
    }

    .account-page .account-dashboard .dash-stats {
        grid-template-columns: 1fr;
    }
}

@media (max-width: 900px) {

    .account-page .account-dashboard .dash-grid,
    .account-page .account-dashboard .dash-bottom {
        grid-template-columns: 1fr;
    }

    .account-page .account-dashboard .dash-quick-grid {
        grid-template-columns: 1fr;
    }
}

/* Listing cards: compact single-line titles on home and search */
.home-wireframe .listing-card .listing-title,
.search-page .listing-card .listing-title,
.search-page .results-grid .listing-title,
.listing-grid .listing-card .listing-title {
    display: block;
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
    line-height: 1.2;
    font-size: 14px;
}

.search-page .results-grid.is-list .listing-title {
    font-size: 16px !important;
}

@media (max-width: 768px) {

    .home-wireframe .listing-card .listing-title,
    .search-page .listing-card .listing-title,
    .search-page .results-grid .listing-title,
    .listing-grid .listing-card .listing-title {
        font-size: 13px;
    }
}

/* Mobile card polish (340px - 580px): keep all card data visible, tighter spacing */
@media (min-width: 340px) and (max-width: 580px) {
    .home-wireframe .ads-grid {
        grid-template-columns: repeat(2, minmax(0, 1fr));
        gap: 10px;
    }

    .home-wireframe .ad-card {
        border-radius: 12px;
        border: 1px solid #e2e8f0;
        box-shadow: 0 6px 14px rgba(15, 23, 42, 0.08);
    }

    .home-wireframe .ad-img-container {
        height: 118px;
    }

    .home-wireframe .badge-container {
        left: 5px;
        right: 5px;
        bottom: 5px;
        gap: 3px;
        max-width: calc(100% - 10px);
    }

    .home-wireframe .ad-badge {
        font-size: 8px;
        padding: 2px 5px;
        border-radius: 999px;
        line-height: 1.15;
    }

    .home-wireframe .ad-badge i {
        font-size: 7px;
        margin-right: 2px;
    }

    .home-wireframe .badge-premium {
        position: static;
        top: auto;
    }

    .home-wireframe .ad-content {
        padding: 8px 9px 9px;
        gap: 5px;
    }

    .home-wireframe .ad-title {
        font-size: 12px;
        line-height: 1.28;
        margin-bottom: 0;
        white-space: normal;
        display: -webkit-box;
        -webkit-line-clamp: 2;
        -webkit-box-orient: vertical;
        line-clamp: 2;
        overflow: hidden;
        min-height: 31px;
    }

    .home-wireframe .ad-price {
        font-size: 13px;
        line-height: 1.2;
        margin-bottom: 0;
    }

    .home-wireframe .ad-meta-container {
        gap: 4px;
        align-items: center;
    }

    .home-wireframe .ad-location {
        font-size: 10px;
        line-height: 1.25;
        min-width: 0;
        white-space: nowrap;
        overflow: hidden;
        text-overflow: ellipsis;
    }

    .home-wireframe .attr-tag {
        font-size: 9px;
        padding: 2px 6px;
        border-radius: 999px;
    }

    .search-page .results-grid:not(.is-list) {
        grid-template-columns: repeat(2, minmax(0, 1fr));
        gap: 10px;
    }

    .search-page .results-grid:not(.is-list) .listing-card {
        border-radius: 12px;
        border: 1px solid #e2e8f0;
        box-shadow: 0 6px 14px rgba(15, 23, 42, 0.07);
    }

    .search-page .results-grid:not(.is-list) .listing-media,
    .search-page .results-grid:not(.is-list) .img-wrapper {
        height: 122px;
    }

    .search-page .results-grid:not(.is-list) .listing-badges {
        top: 6px;
        left: 6px;
        right: auto;
        gap: 4px;
        max-width: calc(100% - 12px);
    }

    .search-page .results-grid:not(.is-list) .listing-badge {
        font-size: 9px;
        padding: 2px 5px;
        border-radius: 999px;
        gap: 3px;
    }

    .search-page .results-grid:not(.is-list) .listing-badge i {
        font-size: 8px;
    }

    .search-page .results-grid:not(.is-list) .listing-content,
    .search-page .results-grid:not(.is-list) .card-content {
        padding: 8px;
        gap: 5px;
    }

    .search-page .results-grid:not(.is-list) .listing-header {
        gap: 6px;
    }

    .search-page .results-grid:not(.is-list) .listing-title,
    .search-page .results-grid:not(.is-list) .ad-title {
        font-size: 12px;
        line-height: 1.25;
        margin: 0;
        white-space: normal;
        display: -webkit-box;
        -webkit-line-clamp: 2;
        -webkit-box-orient: vertical;
        line-clamp: 2;
        overflow: hidden;
        min-height: 30px;
    }

    .search-page .results-grid:not(.is-list) .listing-price,
    .search-page .results-grid:not(.is-list) .ad-price,
    .search-page .results-grid:not(.is-list) .price-value {
        font-size: 13px;
        line-height: 1.2;
        font-weight: 800;
    }

    .search-page .results-grid:not(.is-list) .price-unit-badge,
    .search-page .results-grid:not(.is-list) .price-negotiable {
        font-size: 9px;
        padding: 2px 5px;
    }

    .search-page .results-grid:not(.is-list) .listing-desc,
    .search-page .results-grid:not(.is-list) .ad-desc {
        display: block;
        font-size: 10px;
        line-height: 1.35;
        max-height: 2.7em;
        overflow: hidden;
        margin: 0;
    }

    .search-page .results-grid:not(.is-list) .listing-attrs,
    .search-page .results-grid:not(.is-list) .ad-attrs {
        display: flex;
        flex-wrap: wrap;
        gap: 4px;
    }

    .search-page .results-grid:not(.is-list) .listing-attrs .attr-chip,
    .search-page .results-grid:not(.is-list) .ad-attrs .attr-chip,
    .search-page .results-grid:not(.is-list) .ad-meta-chip {
        font-size: 9px;
        padding: 2px 6px;
        border-radius: 999px;
    }

    .search-page .results-grid:not(.is-list) .listing-meta,
    .search-page .results-grid:not(.is-list) .ad-meta,
    .search-page .results-grid:not(.is-list) .ad-meta-row,
    .search-page .results-grid:not(.is-list) .ad-location,
    .search-page .results-grid:not(.is-list) .listing-location,
    .search-page .results-grid:not(.is-list) .listing-condition {
        font-size: 10px;
        line-height: 1.25;
        gap: 4px;
    }

    .related-listings:not(.is-list) {
        grid-template-columns: repeat(2, minmax(0, 1fr));
        gap: 10px;
    }

    .related-listings:not(.is-list) .listing-card {
        border-radius: 12px;
        border: 1px solid #e2e8f0;
        box-shadow: 0 6px 14px rgba(15, 23, 42, 0.07);
    }

    .related-listings:not(.is-list) .listing-media,
    .related-listings:not(.is-list) .img-wrapper {
        height: 122px;
    }

    .related-listings:not(.is-list) .card-content {
        padding: 8px;
        gap: 5px;
    }

    .related-listings:not(.is-list) .ad-title {
        font-size: 12px;
        line-height: 1.25;
        margin: 0;
        white-space: normal;
        display: -webkit-box;
        -webkit-line-clamp: 2;
        -webkit-box-orient: vertical;
        line-clamp: 2;
        overflow: hidden;
        min-height: 30px;
    }

    .related-listings:not(.is-list) .ad-price {
        font-size: 13px;
        line-height: 1.2;
    }

    .related-listings:not(.is-list) .ad-meta,
    .related-listings:not(.is-list) .ad-location {
        font-size: 10px;
        line-height: 1.25;
    }
}

/* Warning badge icon pin (all card views) */
.listing-media .warning-icon-badge-js,
.ad-img-container .warning-icon-badge-js {
    position: absolute !important;
    right: 8px;
    bottom: 26px;
    width: 28px;
    height: 28px;
    border-radius: 999px;
    display: inline-flex !important;
    align-items: center;
    justify-content: center;
    background: #fef3c7;
    color: #92400e;
    border: 1px solid rgba(146, 64, 14, 0.35);
    box-shadow: 0 6px 14px rgba(15, 23, 42, 0.18);
    z-index: 4;
    font-size: 0;
    line-height: 1;
    padding: 0;
    cursor: help;
}

.listing-media .warning-icon-badge-js i,
.ad-img-container .warning-icon-badge-js i {
    font-size: 12px !important;
    margin: 0 !important;
    line-height: 1;
}

@media (min-width: 340px) and (max-width: 580px) {
    .home-wireframe .ad-img-container .badge-container {
        position: absolute;
        inset: 0;
        max-width: none;
        pointer-events: none;
    }

    .home-wireframe .ad-img-container .badge-container .ad-badge {
        position: absolute;
        pointer-events: auto;
    }

    .home-wireframe .ad-img-container .ad-badge.badge-top {
        top: 6px;
        left: 6px;
    }

    .home-wireframe .ad-img-container .ad-badge.badge-premium {
        top: 6px;
        left: 8px;
    }

    .home-wireframe .ad-img-container .ad-badge.badge-new,
    .home-wireframe .ad-img-container .ad-badge.badge-urgent {
        top: 6px;
        left: 80px;
    }

    .home-wireframe .ad-img-container .ad-badge.badge-verified {
        bottom: 6px;
        left: 6px;
    }

    .home-wireframe .ad-img-container .ad-badge.badge-elite {
        bottom: 6px;
        left: 74px;
    }

    .home-wireframe .ad-img-container .ad-badge.badge-trusted {
        bottom: 6px;
        left: 136px;
    }

    .search-page .results-grid:not(.is-list) .listing-badges {
        position: absolute;
        inset: 0;
        display: block;
        pointer-events: none;
        max-width: none;
    }

    .search-page .results-grid:not(.is-list) .listing-badge {
        position: absolute;
        pointer-events: auto;
    }

    .search-page .results-grid:not(.is-list) .listing-badge.badge-promo,
    .search-page .results-grid:not(.is-list) .listing-badge.badge-top {
        top: 6px;
        left: 6px;
    }

    .search-page .results-grid:not(.is-list) .listing-badge.badge-premium {
        top: 6px;
        left: 58px;
    }

    .search-page .results-grid:not(.is-list) .listing-badge.badge-urgent,
    .search-page .results-grid:not(.is-list) .listing-badge.badge-new {
        top: 6px;
        left: 124px;
    }

    .search-page .results-grid:not(.is-list) .listing-badge.badge-verified {
        bottom: 6px;
        left: 6px;
    }

    .search-page .results-grid:not(.is-list) .listing-badge.badge-reputation,
    .search-page .results-grid:not(.is-list) .listing-badge.badge-elite {
        bottom: 6px;
        left: 74px;
    }

    .search-page .results-grid:not(.is-list) .listing-content,
    .search-page .results-grid:not(.is-list) .card-content {
        display: flex;
        flex-direction: column;
    }

    .search-page .results-grid:not(.is-list) .listing-meta {
        margin-top: auto;
        display: flex;
        flex-direction: column;
        align-items: flex-start;
        gap: 2px;
    }

    .search-page .results-grid:not(.is-list) .ad-meta-stack {
        order: 3;
        margin-top: auto;
    }

    .search-page .results-grid:not(.is-list) .ad-attrs {
        order: 2;
    }

    .search-page .results-grid:not(.is-list) .ad-meta-row {
        font-size: 10px;
        line-height: 1.25;
    }

    .search-page .results-grid:not(.is-list) .listing-desc,
    .search-page .results-grid:not(.is-list) .ad-desc {
        display: none !important;
    }

    .search-page .results-grid:not(.is-list) .listing-attrs,
    .search-page .results-grid:not(.is-list) .ad-attrs {
        display: flex !important;
    }

    .search-page .results-grid:not(.is-list) .listing-attrs .attr-chip:nth-child(n+3),
    .search-page .results-grid:not(.is-list) .ad-attrs .attr-chip:nth-child(n+3) {
        display: none;
    }

    .search-page .results-grid.is-list .listing-header {
        display: flex;
        flex-direction: column;
        align-items: flex-start;
        gap: 4px;
    }

    .search-page .results-grid.is-list .listing-title,
    .search-page .results-grid.is-list .ad-title {
        font-size: 14px !important;
        line-height: 1.28 !important;
    }

    .search-page .results-grid.is-list .listing-price,
    .search-page .results-grid.is-list .ad-price,
    .search-page .results-grid.is-list .price-value {
        font-size: 14px !important;
        line-height: 1.2 !important;
        white-space: normal !important;
    }

    .search-page .results-grid.is-list .ad-price {
        justify-self: start !important;
        text-align: left !important;
    }

    .search-page .results-grid.is-list .card-content {
        grid-template-columns: 1fr !important;
        grid-template-areas:
            "title"
            "price"
            "desc"
            "tags"
            "meta";
        gap: 6px !important;
    }
}

/* Default theme mobile hardening for ad details and search grid cards */
@media (max-width: 768px) {
    .ad-details-page .details-card {
        padding: 16px;
        border-radius: 12px;
    }

    .ad-details-page .ad-title-h1 {
        font-size: clamp(1.1rem, 5vw, 1.45rem);
        line-height: 1.3;
        margin-bottom: 8px;
        word-break: break-word;
    }

    .ad-details-page .mobile-price-header .main-price,
    .ad-details-page .price-card-box .main-price {
        font-size: clamp(1.10rem, 4vw, 1.4rem);
        line-height: 1.15;
        word-break: break-word;
    }

    .ad-details-page .ad-meta-row {
        display: flex;
        align-items: center;
        gap: 8px;
        flex-wrap: nowrap;
        overflow-x: auto;
        -webkit-overflow-scrolling: touch;
        scrollbar-width: none;
        font-size: 12px;
        color: #64748b;
        padding: 8px 0;
        padding-bottom: 12px;
        margin-bottom: 14px;
    }

    .ad-details-page .ad-meta-row::-webkit-scrollbar {
        display: none;
    }

    .ad-details-page .ad-meta-row>span {
        display: inline-flex;
        align-items: center;
        gap: 4px;
        white-space: nowrap;
        flex-shrink: 0;
    }

    .ad-details-page .ad-meta-row>span i {
        font-size: 11px;
        color: #94a3b8;
    }

    .ad-details-page .ad-meta-row>span:not(:last-child)::after {
        content: "•";
        margin-left: 8px;
        color: #cbd5e1;
        font-weight: bold;
    }

    .ad-details-page .attribute-grid {
        grid-template-columns: 1fr 1fr;
        gap: 10px;
        margin-bottom: 18px;
    }

    .ad-details-page .attr-box {
        padding: 10px 12px;
        border: 1px solid #e5e7eb;
        border-radius: 10px;
        background: #fff;

    }

    .ad-details-page .description-text {
        font-size: 14px;
        line-height: 1.6;
        word-break: break-word;
    }

    .ad-details-page .ad-gallery-main .badge-container.ad-image-badges {
        left: 6px;
        right: 6px;
        bottom: 6px;
        max-width: calc(100% - 12px);
        gap: 5px;
        display: none;
    }

    .ad-details-page .ad-gallery-main .ad-image-badges .ad-badge {
        font-size: 10px;
        padding: 3px 6px;
        border-radius: 999px;
        max-width: 100%;
        white-space: nowrap;
        overflow: hidden;
        text-overflow: ellipsis;
    }

    .ad-details-page .ad-gallery-main {
        height: 300px;
    }
}

@media (max-width: 576px) {
    .ad-details-page .container {
        padding-left: 10px;
        padding-right: 10px;
    }

    .ad-details-page .ad-gallery-main {
        height: 240px;
    }

    .ad-details-page .ad-title-h1 {
        font-size: 1.15rem;
    }

    .ad-details-page .ad-meta-row span {
        font-size: 12px;
    }
}

/* Super small screens (280-500px): Compact seller profile layout */
@media (max-width: 500px) {
    .ad-details-page .seller-profile-mini {
        display: flex;
        gap: 12px;
        padding: 16px;
        background: #f8fafc;
        border-radius: 12px;
        margin-top: 16px;
    }

    .ad-details-page .attr-box {
        font-size: 12.4px;
    }

    .ad-details-page .seller-avatar-mini {
        position: relative;
        flex-shrink: 0;
    }

    .ad-details-page .seller-avatar-mini .seller-avatar-image,
    .ad-details-page .seller-avatar-mini i.fa-user {
        width: 56px;
        height: 56px;
        border-radius: 50%;
        object-fit: cover;
        border: 3px solid #fff;
        box-shadow: 0 2px 8px rgba(0, 0, 0, 0.08);
    }

    .ad-details-page .seller-avatar-mini i.fa-user {
        display: flex;
        align-items: center;
        justify-content: center;
        background: linear-gradient(135deg, #e0f2fe 0%, #dbeafe 100%);
        color: #0369a1;
        font-size: 24px;
    }

    .ad-details-page .seller-avatar-mini .online-indicator {
        position: absolute;
        bottom: 2px;
        right: 2px;
        width: 14px;
        height: 14px;
        border-radius: 50%;
        border: 2px solid #fff;
        box-shadow: 0 1px 3px rgba(0, 0, 0, 0.15);
    }

    .ad-details-page .seller-avatar-mini .online-indicator.online {
        background: #10b981;
    }

    .ad-details-page .seller-avatar-mini .online-indicator.offline {
        background: #94a3b8;
    }

    .ad-details-page .seller-info-mini {
        flex: 1;
        min-width: 0;
    }

    .ad-details-page .seller-name-link {
        display: block;
        font-size: 15px;
        font-weight: 700;
        color: #0f172a;
        text-decoration: none;
        margin-bottom: 6px;
        line-height: 1.3;
    }

    .ad-details-page .seller-name-link:hover {
        color: #0369a1;
    }

    .ad-details-page .seller-badge-row {
        display: flex;
        flex-wrap: wrap;
        gap: 6px;
        margin-bottom: 8px;
    }

    .ad-details-page .seller-badge-row .seller-badge {
        display: inline-flex;
        align-items: center;
        gap: 4px;
        padding: 3px 8px;
        border-radius: 6px;
        font-size: 10px;
        font-weight: 600;
        white-space: nowrap;
        line-height: 1.2;
    }

    .ad-details-page .seller-badge-row .seller-badge i {
        font-size: 9px;
    }

    .ad-details-page .seller-badge-row .seller-badge.verified {
        background: #dcfce7;
        color: #15803d;
    }

    .ad-details-page .seller-badge-row .seller-badge.phone {
        background: #dbeafe;
        color: #1e40af;
    }

    .ad-details-page .seller-badge-row .seller-badge.elite {
        background: linear-gradient(135deg, #fef3c7 0%, #fde68a 100%);
        color: #92400e;
    }

    .ad-details-page .seller-badge-row .seller-badge.trust {
        background: #e0e7ff;
        color: #4338ca;
    }

    .ad-details-page .seller-badge-row .seller-badge.new {
        background: #fce7f3;
        color: #9f1239;
    }

    .ad-details-page .seller-badge-row .seller-badge.meta {
        background: #f1f5f9;
        color: #475569;
    }

    .ad-details-page .seller-rating.mb-2 {
        display: flex !important;
        align-items: center !important;
        gap: 8px !important;
        margin-bottom: 12px !important;
        color: #fbbf24 !important;
        margin-left: -70px;
    }

    .ad-details-page .seller-rating.mb-2 i.fas.fa-star,
    .ad-details-page .seller-rating.mb-2 i.fas.fa-star-half-alt {
        font-size: 16px !important;
        color: #fbbf24 !important;
    }

    .ad-details-page .seller-rating.mb-2 i.far.fa-star {
        font-size: 16px !important;
        color: #e2e8f0 !important;
    }

    .ad-details-page .seller-rating.mb-2 a {
        font-size: 12px !important;
        margin-left: 4px !important;
        font-weight: 600 !important;
        color: #22c55e !important;
        text-decoration: none !important;
    }

    .ad-details-page .seller-rating.mb-2 a:hover {
        text-decoration: underline !important;
        margin-left: -80px;
    }

    .ad-details-page .seller-response,
    .ad-details-page .small.text-muted.mt-2.seller-response {
        display: grid !important;
        grid-template-columns: auto 1fr !important;
        gap: 6px 8px !important;
        font-size: 12px !important;
        line-height: 1.5 !important;
        color: #94a3b8 !important;
        margin-top: 12px !important;
        align-items: center !important;
        margin-left: -80px;
    }

    .ad-details-page .seller-response i,
    .ad-details-page .small.text-muted.mt-2.seller-response i {
        font-size: 12px !important;
        color: #94a3b8 !important;
        width: 14px !important;
        text-align: center !important;
    }

    .ad-details-page .seller-response br,
    .ad-details-page .small.text-muted.mt-2.seller-response br {
        display: none !important;
    }
}

@media (max-width: 640px) {
    .search-page .results-grid:not(.is-list) {
        grid-template-columns: repeat(auto-fit, minmax(220px, 1fr)) !important;
        gap: 14px !important;
    }

    .search-page .results-grid:not(.is-list) .listing-card {
        min-width: 0;
        border-radius: 14px;
    }

    .search-page .results-grid:not(.is-list) .listing-media,
    .search-page .results-grid:not(.is-list) .img-wrapper {
        height: 165px !important;
    }

    .search-page .results-grid:not(.is-list) .listing-content,
    .search-page .results-grid:not(.is-list) .card-content {
        padding: 12px !important;
        gap: 8px !important;
    }

    .search-page .results-grid:not(.is-list) .listing-title,
    .search-page .results-grid:not(.is-list) .ad-title {
        font-size: 14px !important;
        line-height: 1.3 !important;
        min-height: 0;
        font-weight: 500;
    }

    .search-page .results-grid:not(.is-list) .listing-price,
    .search-page .results-grid:not(.is-list) .ad-price,
    .search-page .results-grid:not(.is-list) .price-value {
        font-size: 14px !important;
        line-height: 1.2 !important;
    }

    .search-page .results-grid:not(.is-list) .listing-desc,
    .search-page .results-grid:not(.is-list) .ad-desc {
        display: block !important;
        font-size: 10px;
        line-height: 1.4;
        max-height: 3.2em;
    }

    .search-page .results-grid:not(.is-list) .ad-meta-row,
    .search-page .results-grid:not(.is-list) .listing-meta {
        font-size: 10px !important;
        line-height: 1.4;
        gap: 6px;
        flex-wrap: wrap;
    }

    .search-page .results-grid:not(.is-list) .ad-meta-chip,
    .search-page .results-grid:not(.is-list) .listing-attrs .attr-chip,
    .search-page .results-grid:not(.is-list) .ad-attrs .attr-chip {
        font-size: 11px;
        padding: 3px 8px;
    }

    .search-page .results-grid:not(.is-list) .listing-badges {
        max-width: calc(100% - 14px);
    }

    .search-page .results-grid:not(.is-list) .listing-badge {
        font-size: 10px;
        padding: 3px 7px;
    }
}

@media (max-width: 420px) {
    .search-page .results-grid:not(.is-list) {
        grid-template-columns: 1fr !important;
    }
}

/* Search grid mobile override: force 2-up cards and hide descriptions on grid view */
@media (min-width: 340px) and (max-width: 700px) {
    .search-page .results-grid:not(.is-list) {
        grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
    }

    .search-page .results-grid:not(.is-list) .listing-desc,
    .search-page .results-grid:not(.is-list) .ad-desc {
        display: none !important;
    }
}

/* Search page mobile: make wrapper full-width so cards can expand */
@media (max-width: 700px) {
    .search-page>.container.pb-5 {
        width: 100% !important;
        max-width: 100% !important;
        margin: 0 !important;
        padding: 0 !important;
    }
}

/* Search grid compact pass (mobile 340-700): tighter cards, clean footer row */
@media (min-width: 340px) and (max-width: 700px) {
    .search-page .results-grid:not(.is-list) {
        gap: 4px !important;

        padding: 2px 4px;
    }

    .search-page .results-grid:not(.is-list) .listing-card {
        border-radius: 10px !important;
        overflow: hidden;
        min-width: 0;
    }

    .search-page .results-grid:not(.is-list) .listing-media,
    .search-page .results-grid:not(.is-list) .img-wrapper {
        height: 108px !important;
    }

    .search-page .results-grid:not(.is-list) .listing-content,
    .search-page .results-grid:not(.is-list) .card-content {
        display: flex !important;
        flex-direction: column !important;
        min-height: 0;
        padding: 8px 8px 7px !important;
        gap: 4px !important;
    }

    .search-page .results-grid:not(.is-list) .listing-header {
        display: flex;
        flex-direction: column;
        align-items: flex-start;
        gap: 3px;
        min-width: 0;
    }

    .search-page .results-grid:not(.is-list) .listing-title,
    .search-page .results-grid:not(.is-list) .ad-title,
    .search-page .results-grid:not(.is-list) .ad-title a {
        display: -webkit-box !important;
        -webkit-box-orient: vertical;
        -webkit-line-clamp: 2;
        line-clamp: 2;
        overflow: hidden !important;
        text-overflow: ellipsis;
        white-space: normal !important;
        font-size: 12.5px !important;
        line-height: 1.25 !important;
        min-height: 2.5em;
        margin: 0 !important;
    }

    .search-page .results-grid:not(.is-list) .listing-price,
    .search-page .results-grid:not(.is-list) .ad-price {
        display: block !important;
        width: 100%;
        margin: 0 !important;
        white-space: nowrap;
        overflow: hidden;
        text-overflow: ellipsis;
        font-size: 13px !important;
        line-height: 1.2 !important;
    }

    .search-page .results-grid:not(.is-list) .price-value {
        display: inline-block;
        max-width: 100%;
        white-space: nowrap;
        overflow: hidden;
        text-overflow: ellipsis;
        font-size: 13px !important;
        line-height: 1.2 !important;
    }

    .search-page .results-grid:not(.is-list) .price-unit-badge,
    .search-page .results-grid:not(.is-list) .price-negotiable {
        font-size: 8.5px !important;
        padding: 2px 4px !important;
        margin-left: 4px;
    }

    .search-page .results-grid:not(.is-list) .listing-desc,
    .search-page .results-grid:not(.is-list) .ad-desc {
        display: none !important;
    }

    .search-page .results-grid:not(.is-list) .listing-attrs,
    .search-page .results-grid:not(.is-list) .ad-attrs {
        display: flex !important;
        flex-wrap: wrap !important;
        gap: 4px !important;
    }

    .search-page .results-grid:not(.is-list) .listing-attrs .attr-chip,
    .search-page .results-grid:not(.is-list) .ad-attrs .attr-chip {
        font-size: 9px !important;
        line-height: 1.1 !important;
        padding: 2px 6px !important;
        border-radius: 999px !important;
    }

    .search-page .results-grid:not(.is-list) .listing-attrs .attr-chip:nth-child(n+3),
    .search-page .results-grid:not(.is-list) .ad-attrs .attr-chip:nth-child(n+3) {
        display: none !important;
    }

    .search-page .results-grid:not(.is-list) .listing-meta {
        margin-top: auto !important;
        display: flex !important;
        flex-direction: row !important;
        align-items: center !important;
        justify-content: space-between !important;
        flex-wrap: nowrap !important;
        gap: 6px !important;
        min-width: 0;
    }

    .search-page .results-grid:not(.is-list) .listing-location {
        display: inline-flex !important;
        align-items: center;
        gap: 4px;
        min-width: 0;
        white-space: nowrap;
        overflow: hidden;
        text-overflow: ellipsis;
        font-size: 10px !important;
        line-height: 1.2 !important;
    }

    .search-page .results-grid:not(.is-list) .listing-condition {
        margin-left: auto;
        flex: 0 0 auto;
        white-space: nowrap;
        font-size: 10px !important;
        line-height: 1.1 !important;
        padding: 3px 8px !important;
    }

    .search-page .results-grid:not(.is-list) .ad-meta-stack {
        margin-top: auto !important;
        order: 10;
        display: block !important;
    }

    .search-page .results-grid:not(.is-list) .ad-meta-stack .ad-meta-row:first-child:not(:last-child) {
        display: none !important;
    }

    .search-page .results-grid:not(.is-list) .ad-meta-row {
        display: flex !important;
        align-items: center !important;
        gap: 8px !important;
        min-width: 0;
        width: 100%;
        flex-wrap: nowrap !important;
        margin: 0 !important;
    }

    .search-page .results-grid:not(.is-list) .ad-meta-row i {
        font-size: 10px !important;
        line-height: 1 !important;
    }

    .search-page .results-grid:not(.is-list) .ad-meta-text {
        display: none !important;
    }

    .search-page .results-grid:not(.is-list) .ad-meta-row i.fa-map-marker-alt+.ad-meta-text {
        display: inline !important;
        min-width: 0;
        overflow: hidden;
        text-overflow: ellipsis;
        white-space: nowrap;
        font-size: 10px !important;
        line-height: 1.2 !important;
        color: #64748b;
        flex: 1 1 auto;
        padding-right: 8px;
    }

    .search-page .results-grid:not(.is-list) .ad-meta-chip {
        margin-left: auto !important;
        flex: 0 0 auto;
        max-width: 58%;
        white-space: nowrap;
        overflow: hidden;
        text-overflow: ellipsis;
        font-size: 9.5px !important;
        line-height: 1.1 !important;
        padding: 3px 7px !important;
    }

    .search-page .results-grid:not(.is-list) .listing-badges {
        top: 5px !important;
        left: 5px !important;
        gap: 3px !important;
        max-width: calc(100% - 10px);
    }

    .search-page .results-grid:not(.is-list) .listing-badge {
        font-size: 8px !important;
        line-height: 1.1 !important;
        padding: 2px 4px !important;
        border-radius: 999px !important;
        gap: 2px !important;
    }

    .search-page .results-grid:not(.is-list) .listing-badge i {
        font-size: 7px !important;
    }
}

/* Search grid card metadata/attributes consistency (desktop + mobile) */
.search-page .results-grid:not(.is-list) .ad-meta-stack .ad-meta-row:first-child:not(:last-child) {
    display: none;
}

.search-page .results-grid:not(.is-list) .listing-attrs,
.search-page .results-grid:not(.is-list) .ad-attrs {
    display: flex;
    flex-wrap: wrap;
    gap: 6px;
}

.search-page .results-grid:not(.is-list) .listing-attrs .attr-chip:nth-child(n+3),
.search-page .results-grid:not(.is-list) .ad-attrs .attr-chip:nth-child(n+3) {
    display: none;
}

.search-page .results-grid:not(.is-list) .ad-meta-row {
    display: flex;
    align-items: center;
    gap: 10px;
    width: 100%;
    min-width: 0;
    flex-wrap: nowrap;
}

.search-page .results-grid:not(.is-list) .ad-meta-row .ad-meta-text {
    display: none;
}

.search-page .results-grid:not(.is-list) .ad-meta-row i.fa-map-marker-alt+.ad-meta-text {
    display: inline-block;
    flex: 1 1 auto;
    min-width: 0;
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
}

.search-page .results-grid:not(.is-list) .ad-meta-chip {
    margin-left: auto;
    flex: 0 0 auto;
}

/* Final search polish: mobile filter modal + metadata ordering/spacing */
@media (max-width: 991px) {
    body.filters-open {
        overflow: hidden;
    }

    .filter-backdrop {
        z-index: 5000 !important;
    }

    .search-page .search-sidebar {
        position: fixed !important;
        top: 50% !important;
        left: 50% !important;
        width: min(94vw, 420px) !important;
        max-width: 94vw !important;
        height: auto !important;
        max-height: calc(100vh - 20px) !important;
        padding: 0 !important;
        background: #f8fafc !important;
        border: 1px solid #e2e8f0;
        border-radius: 14px;
        box-shadow: 0 22px 48px rgba(15, 23, 42, 0.26);
        overflow: hidden !important;
        transform: translate(-50%, calc(-50% + 24px)) scale(0.98) !important;
        opacity: 0;
        visibility: hidden;
        transition: transform 0.22s ease, opacity 0.22s ease, visibility 0.22s ease;
        z-index: 5100;
    }

    body.filters-open .search-page .search-sidebar {
        transform: translate(-50%, -50%) scale(1) !important;
        opacity: 1;
        visibility: visible;
    }

    .search-page .search-sidebar #filter-form {
        max-height: calc(100vh - 20px);
        overflow-y: auto;
        -webkit-overflow-scrolling: touch;
        padding: 12px 12px 14px;
    }

    .search-page .mobile-filter-head {
        position: sticky;
        top: 0;
        z-index: 5;
        margin: -12px -12px 12px;
        padding: 12px;
        background: #f8fafc;
        border-bottom: 1px solid #e2e8f0;
    }

    .search-page .mobile-filter-close {
        width: 36px;
        height: 36px;
        border-radius: 11px;
    }
}

.search-page .results-grid:not(.is-list) .listing-content,
.search-page .results-grid:not(.is-list) .card-content {
    display: flex;
    flex-direction: column;
}

.search-page .results-grid:not(.is-list) .listing-attrs,
.search-page .results-grid:not(.is-list) .ad-attrs {
    order: 2;
}

.search-page .results-grid:not(.is-list) .listing-meta,
.search-page .results-grid:not(.is-list) .ad-meta-stack {
    order: 3;
}

.search-page .results-grid:not(.is-list) .ad-meta-stack .ad-meta-row:first-child:not(:last-child) {
    display: none;
}

.search-page .results-grid:not(.is-list) .ad-meta-row {
    display: flex;
    align-items: center;
    gap: 10px;
    width: 100%;
    min-width: 0;
    flex-wrap: nowrap;
}

.search-page .results-grid:not(.is-list) .ad-meta-row .ad-meta-text {
    display: none;
}

.search-page .results-grid:not(.is-list) .ad-meta-row i.fa-map-marker-alt+.ad-meta-text {
    display: inline-block;
    flex: 1 1 auto;
    min-width: 0;
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
}

.search-page .results-grid:not(.is-list) .ad-meta-chip {
    margin-left: auto;
    flex: 0 0 auto;
    max-width: 46%;
}

/* Search attribute chips: bold label, normal value */
.search-page .results-grid .listing-attrs .attr-chip,
.search-page .results-grid .ad-attrs .attr-chip {
    display: inline-flex;
    align-items: center;
    gap: 3px;
    font-weight: 400;
}

.search-page .results-grid .listing-attrs .attr-chip .attr-label,
.search-page .results-grid .ad-attrs .attr-chip .attr-label {
    font-weight: 700;
}

.search-page .results-grid .listing-attrs .attr-chip .attr-value,
.search-page .results-grid .ad-attrs .attr-chip .attr-value {
    font-weight: 400;
}

/* Search toolbar mobile stack: left row above right row */
@media (min-width: 340px) and (max-width: 700px) {
    .search-page .results-toolbar {
        display: flex !important;
        flex-direction: column !important;
        align-items: stretch !important;
        flex-wrap: nowrap !important;
        gap: 6px !important;
        overflow: visible !important;
        white-space: normal !important;
    }

    .search-page .results-toolbar-left,
    .search-page .results-toolbar-right {
        display: flex !important;
        align-items: center !important;
        width: 100% !important;
        justify-content: flex-start !important;
        gap: 6px !important;
        flex: 0 0 auto !important;
        padding-right: 0 !important;
        overflow: visible !important;
    }

    .search-page .results-toolbar-left {
        order: 1;
        flex-wrap: nowrap !important;
    }

    .search-page .results-toolbar-right {
        order: 2;
        flex-wrap: wrap !important;
        position: relative;
        z-index: 3;
    }

    .search-page .results-toolbar-notices {
        order: 3;
        width: 100% !important;
        justify-content: flex-start !important;
        overflow: hidden;
    }

    .search-page .toolbar-notice {
        max-width: 100%;
        font-size: 10px !important;
        padding: 4px 7px !important;
        gap: 6px;
    }

    .search-page .filter-toggle,
    .search-page .view-btn,
    .search-page .sort-trigger {
        padding: 5px 7px !important;
        font-size: 10px !important;
        line-height: 1.15;
        border-radius: 6px;
        flex: 0 0 auto;
    }

    .search-page .save-search-btn {
        padding: 5px 7px !important;
        font-size: 10px !important;
        line-height: 1.15;
        white-space: nowrap;
        flex: 0 0 auto;
    }

    .search-page .sort-dropdown,
    .search-page .view-toggle {
        flex: 0 0 auto;
    }

    .search-page .sort-dropdown {
        position: relative;
        z-index: 4;
    }

    .search-page .sort-menu {
        z-index: 30;
        right: auto;
        left: 0;
        min-width: 170px;
    }

    .search-page .results-grid .price-negotiable {
        display: inline-block !important;
        max-width: min(32vw, 88px);
        overflow: hidden;
        text-overflow: ellipsis;
        white-space: nowrap;
        vertical-align: middle;
    }
}

/* Search brand scroller controls and responsive sizing */
.search-page .brand-strip {
    display: flex;
    align-items: center;
    gap: 10px;
    margin-bottom: 18px;
}

.search-page .brand-scroller {
    flex: 1 1 auto;
    display: flex;
    align-items: flex-start;
    gap: 14px;
    overflow-x: auto;
    overflow-y: hidden;
    scroll-behavior: smooth;
    justify-content: flex-start !important;
    scrollbar-width: none;
    -ms-overflow-style: none;
}

.search-page .brand-scroller::-webkit-scrollbar {
    display: none;
}

.search-page .brand-scroll-btn {
    width: 34px;
    height: 34px;
    border: 1px solid #dbe4ee;
    border-radius: 999px;
    background: #fff;
    color: #334155;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    cursor: pointer;
    flex: 0 0 auto;
    box-shadow: 0 1px 3px rgba(15, 23, 42, 0.12);
}

.search-page .brand-scroll-btn:disabled {
    opacity: 0.35;
    cursor: default;
}

@media (max-width: 700px) {
    .search-page .brand-logo-circle {
        width: 60px !important;
        height: 60px !important;
    }

    .search-page .brand-item {
        min-width: 78px;
    }

    .search-page .brand-scroll-btn {
        display: none !important;
    }
}

@media (min-width: 701px) {
    .search-page .brand-logo-circle {
        width: 80px !important;
        height: 80px !important;
        margin-bottom: 8px;
    }

    .search-page .brand-item {
        min-width: 92px;
    }

    .search-page .brand-scroll-btn {
        display: inline-flex;
    }
}

/* Search list view mobile polish: keep all data visible and compact */
@media (max-width: 700px) {

    .search-page .results-grid.is-list .listing-title,
    .search-page .results-grid.is-list .ad-title {
        font-size: 15px !important;
        line-height: 1.3 !important;
    }

    .search-page .results-grid.is-list .listing-price,
    .search-page .results-grid.is-list .ad-price,
    .search-page .results-grid.is-list .price-value {
        font-size: 16px !important;
        line-height: 1.2 !important;
    }

    .search-page .results-grid.is-list .listing-desc,
    .search-page .results-grid.is-list .ad-desc {
        display: block !important;
        font-size: 12px !important;
        line-height: 1.4 !important;
    }

    .search-page .results-grid.is-list .listing-attrs,
    .search-page .results-grid.is-list .ad-attrs {
        display: flex !important;
        flex-wrap: wrap;
        gap: 6px !important;
    }

    .search-page .results-grid.is-list .listing-attrs .attr-chip,
    .search-page .results-grid.is-list .ad-attrs .attr-chip {
        font-size: 12px !important;
        line-height: 1.25 !important;
        padding: 3px 8px !important;
    }
}

/* Ultra-small list view fix (<340): title first, price below, no clipping */
@media (max-width: 340px) {
    .search-page .results-grid.is-list .listing-header {
        display: flex !important;
        flex-direction: column !important;
        align-items: flex-start !important;
        gap: 4px !important;
    }

    .search-page .results-grid.is-list .card-content {
        grid-template-columns: 1fr !important;
        grid-template-areas:
            "title"
            "price"
            "desc"
            "tags"
            "meta";
        gap: 6px !important;
    }

    .search-page .results-grid.is-list .listing-title,
    .search-page .results-grid.is-list .ad-title {
        white-space: normal !important;
        display: -webkit-box !important;
        -webkit-box-orient: vertical;
        -webkit-line-clamp: 2;
        line-clamp: 2;
        overflow: hidden !important;
        max-width: 100%;
    }

    .search-page .results-grid.is-list .listing-price,
    .search-page .results-grid.is-list .ad-price {
        justify-self: start !important;
        text-align: left !important;
        white-space: normal !important;
    }

    .search-page .results-grid.is-list .listing-content,
    .search-page .results-grid.is-list .card-content {
        padding: 12px !important;
        gap: 6px !important;
    }
}

/* Final tiny-screen fixes: keep grid 2-up and toolbar-left compact */
@media (max-width: 339px) {
    .search-page .results-grid:not(.is-list) {
        grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
        gap: 4px !important;
        padding: 2px;
    }

    .search-page .results-grid:not(.is-list) .listing-content,
    .search-page .results-grid:not(.is-list) .card-content {
        padding: 6px !important;
        gap: 3px !important;
    }

    .search-page .results-grid:not(.is-list) .listing-media,
    .search-page .results-grid:not(.is-list) .img-wrapper {
        height: 96px !important;
    }
}

@media (max-width: 700px) {
    .search-page .results-toolbar-left {
        gap: 4px !important;
        align-items: center !important;
    }

    .search-page .results-toolbar-left .view-toggle {
        gap: 3px !important;
        margin-left: 0 !important;
    }

    .search-page .results-toolbar-left .filter-toggle,
    .search-page .results-toolbar-left .view-btn {
        padding: 4px 6px !important;
        font-size: 9.5px !important;
        line-height: 1.1 !important;
        border-radius: 6px !important;
    }
}

/* Final grid/tiny-screen polish */
@media (max-width: 700px) {
    .search-page .results-grid:not(.is-list) .listing-badges {
        top: 4px !important;
        left: 4px !important;
        gap: 2px !important;
        max-width: calc(100% - 8px) !important;
    }

    .search-page .results-grid:not(.is-list) .listing-badge {
        font-size: 7px !important;
        line-height: 1.05 !important;
        padding: 2px 4px !important;
        border-radius: 999px !important;
        gap: 2px !important;
    }

    .search-page .results-grid:not(.is-list) .listing-badge i {
        font-size: 6px !important;
    }

    .search-page .results-grid:not(.is-list) .ad-desc {
        display: none !important;
    }

    .search-page .results-grid:not(.is-list) .ad-meta-chip {
        display: inline-block !important;
        max-width: 44% !important;
        overflow: hidden !important;
        text-overflow: ellipsis !important;
        white-space: nowrap !important;
    }
}

@media (max-width: 339px) {
    .search-page .results-toolbar-right {
        display: flex !important;
        flex-wrap: nowrap !important;
        width: 100% !important;
        gap: 4px !important;
        overflow-x: auto !important;
        overflow-y: hidden !important;
        white-space: nowrap !important;
        padding-bottom: 2px;
    }

    .search-page .results-toolbar-right .sort-dropdown,
    .search-page .results-toolbar-right .save-search-btn {
        flex: 0 0 auto !important;
    }
}

/* Final toolbar-right compact sizing (<=700) */
@media (max-width: 700px) {
    .search-page .results-toolbar-right {
        gap: 4px !important;
    }

    .search-page .results-toolbar-right .save-search-btn,
    .search-page .results-toolbar-right .save-search-btn.btn,
    .search-page .results-toolbar-right .save-search-btn.btn.btn-outline {
        padding: 3px 6px !important;
        min-height: 24px !important;
        height: 24px !important;
        border-radius: 7px !important;
        gap: 4px !important;
        font-size: 9px !important;
        line-height: 1.05 !important;
        box-shadow: none !important;
        white-space: nowrap !important;
    }

    .search-page .results-toolbar-right .save-search-btn i {
        font-size: 9px !important;
        margin: 0 !important;
    }

    .search-page .results-toolbar-right .sort-trigger {
        padding: 3px 6px !important;
        min-height: 24px !important;
        height: 24px !important;
        border-radius: 7px !important;
        font-size: 9px !important;
        line-height: 1.05 !important;
        gap: 4px !important;
        box-shadow: none !important;
    }

    .search-page .results-toolbar-right .sort-trigger i {
        font-size: 8px !important;
    }

    .search-page .results-toolbar-right .sort-dropdown {
        flex: 0 0 auto !important;
    }
}

@media (max-width: 339px) {

    .search-page .results-toolbar-right .save-search-btn,
    .search-page .results-toolbar-right .save-search-btn.btn,
    .search-page .results-toolbar-right .save-search-btn.btn.btn-outline,
    .search-page .results-toolbar-right .sort-trigger {
        padding: 2px 5px !important;
        min-height: 22px !important;
        height: 22px !important;
        font-size: 8.5px !important;
        border-radius: 6px !important;
    }
}

/* Final UX alignment fixes */
@media (max-width: 700px) {

    .search-page .results-toolbar-right .save-search-btn,
    .search-page .results-toolbar-right .save-search-btn.btn,
    .search-page .results-toolbar-right .save-search-btn.btn.btn-outline,
    .search-page .results-toolbar-right .sort-trigger {
        padding: 2px 5px !important;
        min-height: 22px !important;
        height: 22px !important;
        font-size: 11.4px !important;
        line-height: 1 !important;
        border-radius: 6px !important;
        gap: 3px !important;
        box-shadow: none !important;
    }

    .search-page .results-toolbar-right .save-search-btn i,
    .search-page .results-toolbar-right .sort-trigger i {
        font-size: 8px !important;
    }

    .search-page .results-grid:not(.is-list) .listing-badge {
        font-size: 9.3px !important;
    }

    .search-page .results-grid:not(.is-list) .listing-badge i {
        font-size: 8.2px !important;
    }
}

@media (max-width: 339px) {
    .search-page .search-form-inline {
        flex-wrap: nowrap !important;
        align-items: center !important;
        gap: 4px !important;
        padding: 4px 6px !important;
    }

    .search-page .search-input-field {
        min-width: 0 !important;
        width: 100% !important;
        flex: 1 1 auto !important;
        font-size: 14px !important;
        padding: 8px 10px !important;
    }

    .search-page .search-submit-btn {
        order: 3 !important;
        flex: 0 0 auto !important;
        width: 32px !important;
        height: 32px !important;
        min-width: 32px !important;
        border-radius: 8px !important;
        padding: 0 !important;
    }

    .search-page .search-detected-pills,
    .search-page .search-detected-pills.is-visible {
        display: none !important;
    }
}

.search-page .results-grid:not(.is-list) .listing-content,
.search-page .results-grid:not(.is-list) .card-content {
    justify-content: flex-start !important;
}

.search-page .results-grid:not(.is-list) .listing-meta,
.search-page .results-grid:not(.is-list) .ad-meta-stack {
    margin-top: 2px !important;
}

.search-page .results-grid:not(.is-list) .ad-meta-stack {
    order: 3 !important;
}

.search-page .results-grid:not(.is-list) .ad-meta-row {
    margin: 0 !important;
    align-items: center !important;
}

/* Final grid meta alignment (desktop + mobile) */
.search-page .results-grid:not(.is-list) .listing-content,
.search-page .results-grid:not(.is-list) .card-content {
    display: flex !important;
    flex-direction: column !important;
    justify-content: flex-start !important;
    gap: 4px !important;
}

.search-page .results-grid:not(.is-list) .listing-attrs,
.search-page .results-grid:not(.is-list) .ad-attrs {
    display: flex !important;
    flex-wrap: nowrap !important;
    align-items: center !important;
    gap: 4px !important;
    min-height: 24px !important;
    max-height: 24px !important;
    overflow: hidden !important;
}

.search-page .results-grid:not(.is-list) .listing-attrs .attr-chip,
.search-page .results-grid:not(.is-list) .ad-attrs .attr-chip {
    max-width: calc(50% - 2px) !important;
    overflow: hidden !important;
    text-overflow: ellipsis !important;
    white-space: nowrap !important;
}

.search-page .results-grid:not(.is-list) .listing-meta,
.search-page .results-grid:not(.is-list) .ad-meta-stack {
    margin-top: 4px !important;
}

.search-page .results-grid:not(.is-list) .ad-meta-stack .ad-meta-row {
    min-height: 20px;
    margin: 0 !important;
}

@media (max-width: 339px) {
    .search-page .search-topbar {
        width: 100%;
    }

    .search-page .search-form-inline {
        width: 100% !important;
        max-width: none !important;
    }
}

/* Small-screen attrs: allow second chip to wrap under first */
@media (max-width: 700px) {

    .search-page .results-grid:not(.is-list) .listing-attrs,
    .search-page .results-grid:not(.is-list) .ad-attrs {
        flex-wrap: wrap !important;
        align-items: flex-start !important;
        min-height: 0 !important;
        max-height: none !important;
    }

    .search-page .results-grid:not(.is-list) .listing-attrs .attr-chip,
    .search-page .results-grid:not(.is-list) .ad-attrs .attr-chip {
        max-width: 100% !important;
    }
}

/* Hard order guard: attrs must render before meta stack in grid cards */
.search-page .results-grid:not(.is-list) .ad-attrs {
    order: 2 !important;
}

.search-page .results-grid:not(.is-list) .ad-meta-stack {
    order: 3 !important;
}

/* Footer baseline alignment in grid cards */
.search-page .results-grid:not(.is-list) .listing-card {
    display: flex !important;
    flex-direction: column !important;
    height: 100% !important;
}

.search-page .results-grid:not(.is-list) .listing-media,
.search-page .results-grid:not(.is-list) .img-wrapper {
    flex: 0 0 auto;
}

.search-page .results-grid:not(.is-list) .listing-content,
.search-page .results-grid:not(.is-list) .card-content {
    flex: 1 1 auto !important;
    min-height: 0;
    display: flex !important;
    flex-direction: column !important;
}

.search-page .results-grid:not(.is-list) .listing-meta,
.search-page .results-grid:not(.is-list) .ad-meta-stack {
    margin-top: auto !important;
}

/* Home page mobile expansion/polish (default theme) */
@media (max-width: 900px) {
    .home-wireframe {
        overflow-x: hidden;
    }

    .home-wireframe .container {
        max-width: 100% !important;
        padding-left: 8px !important;
        padding-right: 8px !important;
    }

    .home-wireframe .mobile-categories {
        padding: 8px 0 !important;
        margin-bottom: 8px !important;
    }

    .home-wireframe .main-wrapper {
        margin-top: 0 !important;
        overflow-x: hidden;
    }

    .home-wireframe .content-area {
        width: 100%;
        max-width: 100%;
        padding-left: 2px;
        padding-right: 2px;
        min-width: 0;
    }

    .home-wireframe .content-area>* {
        min-width: 0;
    }

    .home-wireframe .section-header {
        gap: 8px;
        flex-wrap: wrap;
        margin-bottom: 10px;
    }

    .home-wireframe .ads-grid {
        width: 100%;
        grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
        gap: 8px !important;
        padding: 0 2px !important;
        margin: 0 0 16px !important;
        box-sizing: border-box;
    }

    .home-wireframe .ad-card {
        border-radius: 10px;
        border: 1px solid #e2e8f0;
        box-shadow: 0 4px 10px rgba(15, 23, 42, 0.08);
    }

    .home-wireframe .ad-content {
        padding: 8px !important;
        gap: 4px;
    }

    .home-wireframe .ad-title {
        font-size: 12px !important;
        line-height: 1.25 !important;


    }

    .home-wireframe .ad-price {
        font-size: 13px !important;
        line-height: 1.2 !important;
    }

    .home-wireframe .ad-location,
    .home-wireframe .attr-tag {
        font-size: 9px !important;
        line-height: 1.2 !important;
    }
}

@media (max-width: 420px) {
    .home-wireframe .container {
        padding-left: 6px !important;
        padding-right: 6px !important;
    }

    .home-wireframe .content-area {
        padding-left: 1px;
        padding-right: 1px;
    }

    .home-wireframe .ads-grid {
        gap: 7px !important;
        padding: 0 1px !important;
    }
}

/* Auth Actions Row (Forgot Pass / Resend) */
.auth-actions-row {
    display: flex;
    gap: 15px;
    align-items: center;
    margin-top: 10px;
    font-size: 13px;
}

.auth-actions-row a {
    color: var(--auth-muted);
    font-weight: 600;
    transition: color 0.2s;
}

.auth-actions-row a:hover {
    color: var(--auth-green);
    text-decoration: underline;
}

/* Mobile Auth Optimizations */
@media (max-width: 640px) {
    .auth-actions-row {
        width: 100%;
        justify-content: space-between;
        margin-top: 15px;
        gap: 10px;
    }

    .auth-actions-row a {
        font-size: 13px;
    }

    .auth-page .auth-wrapper {
        padding: 0 !important;
        align-items: flex-start !important;
        /* align-items: flex-start helps on small screens to avoid vertical centering issues if keyboard opens */
    }

    .auth-page .auth-card {
        border-radius: 16px !important;
        box-shadow: 0 4px 12px rgba(0, 0, 0, 0.08) !important;
    }

    .auth-page .login-card {
        flex-direction: column !important;
        min-height: auto !important;
    }

    .auth-page .auth-splash-side {
        display: none !important;
        /* Hide splash side on mobile to save space */
    }

    .auth-page .card-body {
        padding: 24px 20px !important;
    }

    .auth-page .auth-form-side {
        padding: 24px 20px !important;
    }

    .auth-page .auth-header h2 {
        font-size: 22px !important;
        margin-bottom: 6px !important;
    }

    .auth-page .auth-header p {
        font-size: 14px !important;
    }

    .auth-page .auth-topbar {
        padding: 10px 0 !important;
        margin-bottom: 0 !important;
    }

    .auth-page .auth-topbar .register-link,
    .auth-page .auth-topbar .login-link {
        display: none !important;
        /* Hide header links on mobile, use the new inline ones */
    }

    .auth-page .logo {
        font-size: 20px !important;
    }

    /* Tweak interactions for touch */
    .auth-page input[type="text"],
    .auth-page input[type="email"],
    .auth-page input[type="password"],
    .auth-page input[type="tel"],
    .auth-page select {
        padding: 14px 16px !important;
        /* Larger touch targets */
        font-size: 16px !important;
        /* Prevent zoom on iOS */
    }

    .auth-page .btn-submit {
        padding: 14px !important;
        font-size: 16px !important;
    }

    .auth-page .form-group {
        margin-bottom: 12px !important;
    }
}

/* Auth Switch Link Style */
.mobile-auth-switch {
    text-align: center;
    margin-top: 24px;
    padding-top: 20px;
    border-top: 1px solid var(--auth-border);
    font-size: 14px;
    color: var(--auth-text);
}

.mobile-auth-switch a {
    color: var(--auth-green);
    font-weight: 700;
}

.mobile-auth-switch a:hover {
    text-decoration: underline;
}

/* ============================================================================
   WHATSAPP FLOAT BUTTON
   ============================================================================ */
.whatsapp-float {
    position: fixed;
    bottom: 30px;
    right: 30px;
    background-color: #25d366;
    color: #fff;
    width: 60px;
    height: 60px;
    border-radius: 50%;
    text-align: center;
    font-size: 30px;
    box-shadow: 2px 2px 3px #999;
    z-index: 9999;
    display: flex;
    align-items: center;
    justify-content: center;
    text-decoration: none;
    transition: all 0.3s ease;
}

.whatsapp-float:hover {
    background-color: #128c7e;
    color: #fff;
    transform: scale(1.1);
    text-decoration: none;
}

.whatsapp-float i {
    margin-top: 2px;
}

@keyframes whatsapp-pulse {
    0% {
        box-shadow: 0 0 0 0 rgba(37, 211, 102, 0.7);
    }

    70% {
        box-shadow: 0 0 0 15px rgba(37, 211, 102, 0);
    }

    100% {
        box-shadow: 0 0 0 0 rgba(37, 211, 102, 0);
    }
}

.whatsapp-float {
    animation: whatsapp-pulse 2s infinite;
}

@media (max-width: 768px) {
    .whatsapp-float {
        width: 50px;
        height: 50px;
        font-size: 24px;
        bottom: 20px;
        right: 20px;
    }
}

body.has-mobile-bottom-nav .whatsapp-float {
    bottom: 80px;
}

/* ============================================================================
   COLLAPSIBLE SELLER INFO BOX
   ============================================================================ */
.seller-info-box .seller-info-title {
    cursor: pointer;
    display: flex;
    align-items: center;
    justify-content: space-between;
    user-select: none;
}

.seller-info-box .seller-info-title::after {
    content: '\f078';
    font-family: 'Font Awesome 5 Free';
    font-weight: 900;
    font-size: 12px;
    color: #999;
    transition: transform 0.25s ease;
}

.seller-info-box.is-collapsed .seller-info-title::after {
    transform: rotate(-90deg);
}

.seller-info-box .seller-info-body {
    transition: max-height 0.3s ease, opacity 0.25s ease;
    max-height: 600px;
    opacity: 1;
    overflow: hidden;
}

.seller-info-box.is-collapsed .seller-info-body {
    max-height: 0;
    opacity: 0;
    overflow: hidden;
}

/* ============================================================================
   POST PAGE MOBILE OPTIMIZATION
   ============================================================================ */

/* Attributes grid – always 2 per line */
.attr-grid {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 10px;
}

@media (max-width: 740px) {

    /* Category selects side-by-side */
    .category-selects {
        grid-template-columns: 1fr 1fr;
        gap: 8px;
    }

    /* State / City always side-by-side */
    .form-grid.two-col {
        grid-template-columns: 1fr 1fr;
        gap: 8px;
    }

    /* Delivery & Escrow toggles – all in one row */
    .toggle-grid {
        grid-template-columns: repeat(3, 1fr);
        gap: 6px;
    }

    .toggle-item {
        padding: 8px 6px;
        font-size: 11px;
        gap: 5px;
        justify-content: center;
    }

    .toggle-item input[type="checkbox"] {
        width: 14px;
        height: 14px;
    }
}

@media (max-width: 400px) {
    .category-selects {
        gap: 6px;
    }

    .category-selects select {
        font-size: 13px;
        padding: 8px 6px;
    }

    .form-grid.two-col {
        gap: 6px;
    }

    .toggle-item {
        padding: 6px 4px;
        font-size: 10px;
        gap: 4px;
        border-radius: 8px;
    }

    .attr-grid {
        gap: 6px;
    }

    .account-page .account-dashboard .dash-chip {
        font-size: 10px;
        padding: 3px 3px;
        border-radius: 1px;
    }
}

/* ============================================================================
   MOBILE FOOTER NAV
   ============================================================================ */
.mobile-nav {
    display: none;
    position: fixed;
    bottom: 0;
    left: 0;
    width: 100%;
    background: #fff;
    box-shadow: 0 -2px 10px rgba(0, 0, 0, 0.08);
    z-index: 1000;
    justify-content: space-around;
    align-items: flex-end;
    padding: 8px 0 6px;
    border-top: 1px solid #eee;
}

.mobile-nav .nav-item {
    display: flex;
    flex-direction: column;
    align-items: center;
    color: #888;
    font-size: 10px;
    text-decoration: none;
    position: relative;
    gap: 2px;
    padding: 0 8px;
}

.mobile-nav .nav-item i {
    font-size: 20px;
    line-height: 1;
}

.mobile-nav .nav-item span {
    line-height: 1;
}

.mobile-nav .nav-item.active {
    color: #2f6b4f;
}

.mobile-nav .nav-item.active::after {
    content: '';
    position: absolute;
    bottom: -6px;
    left: 50%;
    transform: translateX(-50%);
    width: 20px;
    height: 3px;
    border-radius: 2px;
    background: #2f6b4f;
}

/* Elevated Sell button */
.mobile-nav .nav-item-sell {
    display: flex;
    flex-direction: column;
    align-items: center;
    text-decoration: none;
    position: relative;
    margin-top: -28px;
}

.mobile-nav .nav-item-sell i {
    width: 48px;
    height: 48px;
    border-radius: 50%;
    background: #2f6b4f;
    color: #fff;
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 22px;
    box-shadow: 0 4px 12px rgba(47, 107, 79, 0.35);
    border: 3px solid #fff;
    margin: 0;
}

.mobile-nav .nav-item-sell span {
    color: #2f6b4f;
    font-size: 10px;
    font-weight: 600;
    margin-top: 2px;
}

/* Notification badges */
.mobile-badge {
    position: absolute;
    top: -4px;
    right: -2px;
    background: #ef4444;
    color: #fff;
    border-radius: 999px;
    font-size: 9px;
    font-weight: 700;
    padding: 2px 5px;
    line-height: 1;
    min-width: 16px;
    text-align: center;
}

@media (max-width: 900px) {
    .mobile-nav {
        display: flex;
    }

    /* Add bottom padding to body so content doesn't hide behind nav */
    body {
        padding-bottom: 0px;
    }

    .site-footer {
        margin-bottom: 60px;
    }
}

/* ============================================================================
   MOBILE SLIDE-OUT MENU (DRAWER)
   ============================================================================ */
body.no-scroll {
    overflow: hidden;
}

.menu-backdrop {
    display: none;
    position: fixed;
    inset: 0;
    background: rgba(0, 0, 0, 0.45);
    z-index: 10000;
}

.menu-backdrop.show {
    display: block;
}

.mobile-menu {
    position: fixed;
    top: 0;
    left: 0;
    width: 85%;
    max-width: 340px;
    height: 100%;
    background: #fff;
    z-index: 10001;
    transform: translateX(-100%);
    transition: transform 0.28s cubic-bezier(.4, 0, .2, 1);
    display: flex;
    flex-direction: column;
    overflow: hidden;
    box-shadow: 4px 0 20px rgba(0, 0, 0, 0.1);
}

.mobile-menu.open {
    transform: translateX(0);
}

.mobile-menu-header {
    display: flex;
    align-items: center;
    justify-content: space-between;
    padding: 14px 16px;
    background: #0f2940;
    color: #fff;
}

.mobile-menu-header .brand {
    display: flex;
    align-items: center;
    gap: 10px;
    font-weight: 700;
    font-size: 16px;
}

.mobile-menu-header .brand-badge {
    width: 30px;
    height: 30px;
    border-radius: 8px;
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 14px;
    font-weight: 800;
    background: rgba(255, 255, 255, 0.2);
    color: #fff;
}

.mobile-menu-close {
    background: none;
    border: 0;
    color: #fff;
    font-size: 20px;
    cursor: pointer;
    padding: 4px;
}

.mobile-menu .mobile-search {
    display: flex;
    align-items: center;
    gap: 8px;
    margin: 12px 16px;
    padding: 8px 12px;
    border: 1px solid #e5e7eb;
    border-radius: 8px;
    background: #f8fafc;
}

.mobile-menu .mobile-search i {
    color: #94a3b8;
    font-size: 14px;
}

.mobile-menu .mobile-search input {
    flex: 1;
    border: 0;
    background: transparent;
    font-size: 14px;
    outline: none;
    color: #0f2940;
}

.mobile-menu .mobile-search button {
    background: none;
    border: 0;
    color: #0f2940;
    font-size: 14px;
    cursor: pointer;
    padding: 2px;
}

.mobile-panel-body {
    flex: 1;
    overflow-y: auto;
    padding: 0 0 20px 0;
}

.mobile-panel-body>ul {
    list-style: none;
    margin: 0;
    padding: 0;
}

.mobile-panel-body>ul>li {
    border-bottom: 1px solid #f1f5f9;
}

.mobile-panel-body>ul>li>a {
    display: flex;
    align-items: center;
    gap: 12px;
    padding: 12px 16px;
    color: #0f2940;
    text-decoration: none;
    font-size: 14px;
    transition: background 0.15s;
}

.mobile-panel-body>ul>li>a:hover {
    background: #f8fafc;
}

.mobile-panel-body>ul>li>a i {
    width: 16px;
    text-align: center;
    color: #64748b;
    font-size: 14px;
}

/* ============================================================================
   MOBILE ACCOUNT MENU ACCORDION
   ============================================================================ */
.mobile-account-menu-list {
    list-style: none;
    margin: 0;
    padding: 0;
}

.mobile-account-menu-list li.mobile-account-group {
    border-bottom: 1px solid #f1f5f9;
}

.mobile-account-menu-list .mobile-account-group-toggle {
    width: 100%;
    border: 0;
    background: #f8fafc;
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 10px;
    padding: 10px 16px;
    cursor: pointer;
    transition: background 0.15s;
}

.mobile-account-menu-list .mobile-account-group-toggle:hover {
    background: #f1f5f9;
}

.mobile-account-menu-list .mobile-account-group-toggle .mobile-link-main {
    display: inline-flex;
    align-items: center;
    gap: 10px;
    min-width: 0;
}

.mobile-account-menu-list .mobile-account-group-toggle .mobile-link-main i:not(.mobile-account-caret) {
    width: 16px;
    text-align: center;
    color: #0f2940;
    font-size: 14px;
    flex: 0 0 16px;
}

.mobile-account-menu-list .mobile-account-group-toggle .mobile-link-text {
    font-size: 13px;
    font-weight: 700;
    color: #0f2940;
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
}

.mobile-account-menu-list .mobile-account-group-toggle .mobile-account-caret {
    color: #94a3b8;
    font-size: 11px;
    transition: transform 0.2s ease;
    flex: 0 0 auto;
}

.mobile-account-menu-list .mobile-account-group-toggle.open .mobile-account-caret {
    transform: rotate(90deg);
}

.mobile-account-menu-list .mobile-account-group-items {
    display: none;
    margin: 0;
    padding: 0;
    list-style: none;
}

.mobile-account-menu-list .mobile-account-group-items.open {
    display: block;
}

.mobile-account-menu-list .mobile-account-group-items li {
    border-bottom: 1px solid #f1f5f9;
}

.mobile-account-menu-list .mobile-account-group-items li:last-child {
    border-bottom: 0;
}

/* Account links (both top-level and nested) */
.mobile-account-link {
    display: flex;
    align-items: center;
    gap: 10px;
    padding: 10px 16px;
    color: #334155 !important;
    text-decoration: none;
    font-size: 13px;
    transition: background 0.15s;
}

.mobile-account-link:hover {
    background: #f8fafc;
}

.mobile-account-link.active {
    color: #0f2940;
    font-weight: 600;
    background: #eff6ff;
    border-left: 3px solid #0f2940;
}

.mobile-account-link .mobile-link-main {
    display: inline-flex;
    align-items: center;
    gap: 10px;
    min-width: 0;
}

.mobile-account-link .mobile-link-main i {
    width: 16px;
    text-align: center;
    color: #64748b;
    font-size: 13px;
    flex: 0 0 16px;
}

.mobile-account-link .mobile-link-text {
    font-size: 13px;
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
}

.mobile-account-group-items .mobile-account-link {
    padding-left: 42px;
}

/* Desktop: Ensure mobile menu is completely hidden */
@media (min-width: 969px) {

    .menu-backdrop,
    .mobile-menu,
    .mobile-menu-btn {
        display: none !important;
    }
}

/* ============================================================================
   Related Listings - Search Card Parity
   ============================================================================ */
.related-listings:not(.is-list) {
    display: grid !important;
    grid-template-columns: repeat(4, minmax(0, 1fr)) !important;
    gap: 16px !important;
}

.related-listings .listing-card {
    background: #fff !important;
    border: 1px solid #dbe4ee !important;
    border-radius: 16px !important;
    overflow: hidden !important;
    box-shadow: 0 8px 20px rgba(15, 23, 42, 0.07) !important;
    transition: transform 0.18s ease, box-shadow 0.18s ease !important;
}

.related-listings .listing-card:hover {
    transform: translateY(-2px) !important;
    box-shadow: 0 14px 28px rgba(15, 23, 42, 0.12) !important;
}

.related-listings:not(.is-list) .listing-media,
.related-listings:not(.is-list) .img-wrapper {
    height: 225px !important;
    background: #eef2f6 !important;
    position: relative !important;
}

.related-listings:not(.is-list) .listing-content {
    display: flex !important;
    flex-direction: column !important;
    gap: 10px !important;
    padding: 16px 14px 12px !important;
    min-height: 176px !important;
}

.related-listings:not(.is-list) .listing-title {
    font-size: 19px !important;
    line-height: 1.13 !important;
    font-weight: 800 !important;
    color: #0f2b50 !important;
    display: -webkit-box !important;
    -webkit-box-orient: vertical;
    -webkit-line-clamp: 2;
    line-clamp: 2;
    overflow: hidden !important;
}

.related-listings:not(.is-list) .price-value {
    color: #26b53c !important;
    font-weight: 900 !important;
    font-size: 25px !important;
   
}

.related-listings:not(.is-list) .listing-desc {
    font-size: 15px !important;
    line-height: 1.2 !important;
    color: #4a607a !important;
    margin: 0 !important;
}

.related-listings:not(.is-list) .listing-meta {
    display: flex !important;
    align-items: center !important;
    justify-content: space-between !important;
    gap: 10px !important;
    font-size: 13px !important;
    color: #5e738c !important;
    margin-top: auto !important;
}

.related-listings:not(.is-list) .listing-condition {
    display: inline-flex !important;
    align-items: center !important;
    padding: 4px 12px !important;
    border-radius: 999px !important;
    background: #eef3f8 !important;
    border: 1px solid #dbe3ee !important;
    color: #0f2b50 !important;
    font-weight: 700 !important;
    font-size: 12px !important;
    line-height: 1 !important;
}

.related-listings .listing-badges {
    position: absolute !important;
    top: 10px !important;
    left: 10px !important;
    z-index: 2 !important;
    display: flex !important;
    flex-direction: column !important;
    gap: 6px !important;
    max-width: calc(100% - 20px) !important;
}

.related-listings .listing-badges .badge-row {
    display: flex !important;
    flex-wrap: wrap !important;
    gap: 6px !important;
}

.related-listings .listing-badges .badge {
    display: inline-flex !important;
    align-items: center !important;
    gap: 5px !important;
    padding: 5px 10px !important;
    border-radius: 12px !important;
    font-size: 14px !important;
    font-weight: 800 !important;
    border: 1px solid transparent !important;
}

.related-listings .listing-badges .badge.badge-verified {
    color: #1f7a2f !important;
    background: #ecf9ef !important;
    border-color: #7bcf8c !important;
}

.related-listings .listing-badges .badge.badge-premium {
    color: #b45309 !important;
    background: #fff5e5 !important;
    border-color: #f2bf6d !important;
}

.related-listings .listing-badges .badge.badge-urgent,
.related-listings .listing-badges .badge.badge-top,
.related-listings .listing-badges .badge.badge-featured,
.related-listings .listing-badges .badge.badge-elite,
.related-listings .listing-badges .badge.badge-inspected,
.related-listings .listing-badges .badge.badge-escrow {
    color: #0f2b50 !important;
    background: #f4f7fb !important;
    border-color: #d7e0ea !important;
}

.related-listings .fav {
    position: absolute !important;
    right: 12px !important;
    bottom: 12px !important;
    width: 44px !important;
    height: 44px !important;
    border: 1px solid #e8d6b3 !important;
    border-radius: 999px !important;
    background: #f6e6be !important;
    color: #8b4513 !important;
    display: inline-flex !important;
    align-items: center !important;
    justify-content: center !important;
    z-index: 3 !important;
}

.related-listings .fav i {
    font-size: 18px !important;
}

.related-listings.is-list {
    display: grid !important;
    grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
    gap: 16px !important;
}

.related-listings.is-list .listing-card {
    width: 100% !important;
    display: flex !important;
    flex-direction: row !important;
    align-items: stretch !important;
}

.related-listings.is-list .listing-media,
.related-listings.is-list .img-wrapper {
    width: 38% !important;
    min-width: 320px !important;
    height: 200px !important;
    min-height: 200px !important;
    align-self: stretch !important;
    overflow: hidden !important;
    flex-shrink: 0 !important;
}

.related-listings.is-list .listing-media img {
    width: 100% !important;
    height: 100% !important;
    object-fit: cover !important;
}

.related-listings.is-list .listing-content {
    flex: 1 1 auto !important;
    min-width: 0 !important;
}

@media (max-width: 991px) {
    .related-listings:not(.is-list) {
        grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
    }

    .related-listings:not(.is-list) .listing-title {
        font-size: 18px !important;
    }

    .related-listings:not(.is-list) .price-value {
        font-size: 30px !important;
    }

    .related-listings:not(.is-list) .listing-desc {
        font-size: 14px !important;
    }

    .related-listings:not(.is-list) .listing-meta {
        font-size: 12px !important;
    }

    .related-listings:not(.is-list) .listing-condition {
        font-size: 12px !important;
    }

    .related-listings .listing-badges .badge {
        font-size: 13px !important;
        padding: 4px 8px !important;
    }

    .related-listings.is-list {
        grid-template-columns: 1fr !important;
    }

    .related-listings.is-list .listing-media,
    .related-listings.is-list .img-wrapper {
        min-width: 240px !important;
        height: 180px !important;
        min-height: 180px !important;
    }
}

@media (max-width: 640px) {

    .related-listings:not(.is-list) .listing-media,
    .related-listings:not(.is-list) .img-wrapper {
        height: 172px !important;
    }

    .related-listings:not(.is-list) .listing-content {
        min-height: 0 !important;
        gap: 8px !important;
        padding: 11px 10px 10px !important;
    }

    .related-listings:not(.is-list) .listing-title {
        font-size: 15px !important;
    }

    .related-listings:not(.is-list) .price-value {
        font-size: 24px !important;
    }

    .related-listings:not(.is-list) .listing-desc {
        font-size: 13px !important;
    }

    .related-listings:not(.is-list) .listing-meta {
        font-size: 12px !important;
    }

    .related-listings:not(.is-list) .listing-condition {
        font-size: 12px !important;
        padding: 4px 10px !important;
    }

    .related-listings .fav {
        width: 34px !important;
        height: 34px !important;
        right: 8px !important;
        bottom: 8px !important;
    }

    .related-listings.is-list .listing-card {
        flex-direction: column !important;
    }

    .related-listings.is-list .listing-media,
    .related-listings.is-list .img-wrapper {
        width: 100% !important;
        min-width: 0 !important;
    }
}

.search-page .price-block-btn.is-active {
    background: #dcfce7;
    color: #166534;
    box-shadow: inset 0 0 0 1px #22c55e;
}

.search-page .brand-item.is-active .brand-logo-circle {
    box-shadow: 0 0 0 2px #22c55e, 0 6px 14px rgba(34, 197, 94, 0.25);
}

.search-page .brand-item.is-active .brand-name {
    color: #166534;
    font-weight: 700;
}

@media (max-width: 991px) {
    body.search-page-mobile-nav-hidden [data-mobile-footer-nav] {
        display: none !important;
    }

    body.search-page-mobile-nav-hidden {
        padding-bottom: 84px !important;
    }

    .search-page .filter-toggle {
        position: fixed;
        left: 5%;
        transform: none;
        bottom: max(12px, calc(env(safe-area-inset-bottom) + 6px));
        z-index: 5200;
        width: 50px;
        min-height: 30px;
        border-radius: 14px;
        padding: 8px 4px;
        display: inline-flex;
        flex-direction: column;
        align-items: center;
        justify-content: center;
        gap: 3px;
        background: rgba(255, 255, 255, 0.92);
        color: #0f172a;
        border: 1px solid rgba(148, 163, 184, 0.35);
        box-shadow: 0 10px 22px rgba(15, 23, 42, 0.2);
        backdrop-filter: blur(8px);
    }

    .search-page .filter-toggle i {
        font-size: 18px;
        line-height: 1;
        color: #15803d;
    }

    .search-page .filter-toggle .filter-toggle-text {
        display: block;
        font-size: 9px;
        font-weight: 700;
        line-height: 1.15;
        letter-spacing: 0.02em;
        text-align: center;
        text-transform: uppercase;
    }

    body.filters-open .search-page .filter-toggle {
        opacity: 0;
        pointer-events: none;
    }
}

/* ============================================================================
   NEW PROFILE DROPDOWN (Compact Collapsible Accordion UI)
   ============================================================================ */
.site-header .new-profile-panel {
    position: absolute;
    top: calc(100% + 10px);
    right: 0;
    display: none;
    width: 280px !important;
    padding: 0 !important;
    border-radius: 14px !important;
    box-shadow:
        0 20px 40px -8px rgba(15, 23, 42, 0.18),
        0 8px 16px -4px rgba(15, 23, 42, 0.08),
        0 0 0 1px rgba(15, 23, 42, 0.04) !important;
    background: #fff;
    overflow: hidden;
    border: none !important;
    z-index: 3000;
    color: #0f172a;
}

.site-header .new-profile-panel.open {
    display: block !important;
    animation: dropdownFadeIn 0.18s cubic-bezier(0.16, 1, 0.3, 1);
}

@keyframes dropdownFadeIn {
    from {
        opacity: 0;
        transform: translateY(-8px) scale(0.98);
    }

    to {
        opacity: 1;
        transform: translateY(0) scale(1);
    }
}

/* -- Header -- */
.new-profile-panel .pp-header {
    background: linear-gradient(135deg, #f0fdf4 0%, #f8fafc 100%);
    padding: 14px 16px;
    border-bottom: 1px solid #e2e8f0;
}

.new-profile-panel .pp-user-info {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 8px;
}

.new-profile-panel .pp-name {
    font-weight: 700;
    font-size: 14px;
    color: #0f172a;
    letter-spacing: -0.01em;
}

.new-profile-panel .pp-dashboard-link {
    font-size: 12px;
    color: #16a34a;
    font-weight: 600;
    text-decoration: none;
    display: inline-flex;
    align-items: center;
    gap: 5px;
    padding: 4px 10px;
    border-radius: 6px;
    background: rgba(22, 163, 74, 0.08);
    transition: all 0.15s ease;
}

.new-profile-panel .pp-dashboard-link:hover {
    background: rgba(22, 163, 74, 0.15);
    text-decoration: none;
}

.new-profile-panel .pp-dashboard-link i {
    font-size: 11px;
}

/* -- Body (scrollable) -- */
.new-profile-panel .pp-body {
    max-height: 360px;
    overflow-y: auto;
    padding: 4px 0;
    scrollbar-width: thin;
    scrollbar-color: #cbd5e1 transparent;
}

.new-profile-panel .pp-body::-webkit-scrollbar {
    width: 4px;
}

.new-profile-panel .pp-body::-webkit-scrollbar-track {
    background: transparent;
}

.new-profile-panel .pp-body::-webkit-scrollbar-thumb {
    background-color: #cbd5e1;
    border-radius: 20px;
}

/* -- Groups -- */
.new-profile-panel .pp-group {
    padding: 0;
    border-bottom: 1px solid #f1f5f9;
}

.new-profile-panel .pp-group:last-child {
    border-bottom: none;
}

/* -- Group Toggle Button (Accordion Header) -- */
.new-profile-panel .pp-group-toggle {
    display: flex;
    align-items: center;
    justify-content: space-between;
    width: 100%;
    padding: 9px 16px;
    background: none;
    border: none;
    cursor: pointer;
    font-family: inherit;
    font-size: 13px;
    font-weight: 600;
    color: #334155;
    transition: all 0.15s ease;
    text-align: left;
    outline: none;
    line-height: 1.3;
}

.new-profile-panel .pp-group-toggle:hover {
    background: #f8fafc;
    color: #0f172a;
}

.new-profile-panel .pp-group-toggle.open {
    color: #16a34a;
    background: #f0fdf4;
}

.new-profile-panel .pp-toggle-left {
    display: flex;
    align-items: center;
    gap: 10px;
}

.new-profile-panel .pp-toggle-left i {
    width: 16px;
    text-align: center;
    font-size: 13px;
    color: #94a3b8;
    transition: color 0.15s ease;
}

.new-profile-panel .pp-group-toggle:hover .pp-toggle-left i,
.new-profile-panel .pp-group-toggle.open .pp-toggle-left i {
    color: #16a34a;
}

/* -- Caret -- */
.new-profile-panel .pp-caret {
    font-size: 10px;
    color: #94a3b8;
    transition: transform 0.2s cubic-bezier(0.16, 1, 0.3, 1), color 0.15s ease;
    flex-shrink: 0;
}

.new-profile-panel .pp-group-toggle.open .pp-caret {
    transform: rotate(90deg);
    color: #16a34a;
}

/* -- Group Items (Collapsible Children) -- */
.new-profile-panel .pp-group-items {
    display: none;
    padding: 2px 0 4px;
    background: #fafbfc;
    border-top: 1px solid #f1f5f9;
}

.new-profile-panel .pp-group-items.open {
    display: block;
    animation: ppSlideDown 0.18s cubic-bezier(0.16, 1, 0.3, 1);
}

@keyframes ppSlideDown {
    from {
        opacity: 0;
        transform: translateY(-4px);
    }

    to {
        opacity: 1;
        transform: translateY(0);
    }
}

/* -- Links (Children) -- */
.new-profile-panel .pp-link {
    display: flex;
    align-items: center;
    gap: 8px;
    padding: 7px 16px 7px 42px;
    font-size: 12.5px;
    color: #475569;
    text-decoration: none;
    transition: all 0.12s ease;
    font-weight: 500;
    border-radius: 0;
    line-height: 1.3;
}

.new-profile-panel .pp-link:hover {
    background: #e0f2fe;
    color: #0369a1;
    padding-left: 46px;
}

.new-profile-panel .pp-link i {
    width: 14px;
    text-align: center;
    font-size: 11px;
    color: #94a3b8;
    transition: color 0.12s;
    flex-shrink: 0;
}

.new-profile-panel .pp-link:hover i {
    color: #0369a1;
}

/* -- Footer -- */
.new-profile-panel .pp-footer {
    padding: 10px 16px;
    background: #fafbfc;
    border-top: 1px solid #e2e8f0;
}

.new-profile-panel .pp-logout {
    display: flex;
    align-items: center;
    gap: 8px;
    color: #ef4444;
    font-size: 12.5px;
    font-weight: 600;
    text-decoration: none;
    transition: color 0.15s;
}

.new-profile-panel .pp-logout:hover {
    color: #dc2626;
}

.new-profile-panel .pp-logout i {
    font-size: 13px;
}