/* ============================================================
   ArabOverclockers Hardware Compare — compare.css
   Dark / Tech aesthetic · RTL-first
   ============================================================ */

:root {
    --aoc-bg:          #0f1117;
    --aoc-surface:     #181c27;
    --aoc-surface2:    #1e2336;
    --aoc-border:      #2a3050;
    --aoc-accent:      #00d4ff;
    --aoc-accent2:     #7c5cfc;
    --aoc-best:        #00ff88;
    --aoc-text:        #e8eaf0;
    --aoc-text-muted:  #7a85a0;
    --aoc-price:       #ffd166;
    --aoc-danger:      #ff4d6d;
    --aoc-radius:      10px;
    --aoc-shadow:      0 4px 24px rgba(0,0,0,.45);
    --aoc-font:        'Tajawal', 'Cairo', 'Segoe UI', sans-serif;
}

/* ── Wrapper ─────────────────────────────────────────── */
.aoc-compare-wrapper,
.aoc-selector-wrap {
    font-family: var(--aoc-font);
    color: var(--aoc-text);
    direction: rtl;
    max-width: 100%;
}

/* ── Selector Header ─────────────────────────────────── */
.aoc-selector-header {
    background: var(--aoc-surface);
    border: 1px solid var(--aoc-border);
    border-radius: var(--aoc-radius);
    padding: 24px 28px 20px;
    margin-bottom: 20px;
}
.aoc-selector-header h3 {
    margin: 0 0 6px;
    font-size: 1.4rem;
    background: linear-gradient(90deg, var(--aoc-accent), var(--aoc-accent2));
    -webkit-background-clip: text;
    -webkit-text-fill-color: transparent;
    background-clip: text;
}
.aoc-selector-hint {
    margin: 0 0 16px;
    color: var(--aoc-text-muted);
    font-size: .9rem;
}
.aoc-category-filter {
    display: flex;
    align-items: center;
    gap: 12px;
}
.aoc-category-filter label { color: var(--aoc-text-muted); font-size: .9rem; }
.aoc-category-filter select {
    background: var(--aoc-surface2);
    border: 1px solid var(--aoc-border);
    color: var(--aoc-text);
    border-radius: 6px;
    padding: 6px 12px;
    font-family: var(--aoc-font);
    cursor: pointer;
}

/* ── Search Box ──────────────────────────────────────── */
.aoc-search-row { position: relative; margin-bottom: 20px; }
.aoc-search-box { position: relative; }
#aoc-product-search {
    width: 100%;
    background: var(--aoc-surface);
    border: 1px solid var(--aoc-border);
    border-radius: var(--aoc-radius);
    color: var(--aoc-text);
    padding: 12px 18px;
    font-family: var(--aoc-font);
    font-size: 1rem;
    box-sizing: border-box;
    transition: border-color .2s;
}
#aoc-product-search:focus {
    outline: none;
    border-color: var(--aoc-accent);
    box-shadow: 0 0 0 3px rgba(0,212,255,.12);
}
.aoc-search-dropdown {
    position: absolute;
    top: calc(100% + 4px);
    right: 0; left: 0;
    background: var(--aoc-surface2);
    border: 1px solid var(--aoc-border);
    border-radius: var(--aoc-radius);
    z-index: 9999;
    max-height: 340px;
    overflow-y: auto;
    box-shadow: var(--aoc-shadow);
}
.aoc-result-item {
    display: flex;
    align-items: center;
    gap: 12px;
    padding: 10px 14px;
    cursor: pointer;
    transition: background .15s;
}
.aoc-result-item:hover { background: rgba(0,212,255,.07); }
.aoc-result-item.aoc-result-selected { opacity: .55; pointer-events: none; }
.aoc-result-item img { width: 48px; height: 48px; object-fit: contain; border-radius: 6px; background: #fff; }
.aoc-result-info strong { display: block; font-size: .95rem; }
.aoc-result-info small  { color: var(--aoc-text-muted); font-size: .8rem; }
.aoc-result-check { margin-right: auto; color: var(--aoc-best); font-size: 1.1rem; }
.aoc-loading, .aoc-no-results { padding: 14px; color: var(--aoc-text-muted); text-align: center; }

/* ── Tray ────────────────────────────────────────────── */
.aoc-selected-tray {
    background: var(--aoc-surface);
    border: 1px solid var(--aoc-border);
    border-radius: var(--aoc-radius);
    padding: 20px;
    margin-bottom: 20px;
}
.aoc-tray-slots {
    display: grid;
    grid-template-columns: repeat(4, 1fr);
    gap: 14px;
    margin-bottom: 16px;
}
@media (max-width: 700px) { .aoc-tray-slots { grid-template-columns: repeat(2, 1fr); } }

.aoc-slot {
    border: 2px dashed var(--aoc-border);
    border-radius: var(--aoc-radius);
    min-height: 110px;
    display: flex;
    align-items: center;
    justify-content: center;
    text-align: center;
    transition: border-color .2s, background .2s;
    position: relative;
    overflow: hidden;
}
.aoc-slot-empty { cursor: pointer; }
.aoc-slot-empty:hover { border-color: var(--aoc-accent); background: rgba(0,212,255,.04); }
.aoc-slot-placeholder { color: var(--aoc-text-muted); font-size: .85rem; }
.aoc-slot-placeholder .dashicons { display: block; font-size: 1.6rem; margin-bottom: 4px; color: var(--aoc-border); }

.aoc-slot-filled {
    border-style: solid;
    border-color: var(--aoc-accent);
    flex-direction: column;
    gap: 6px;
    padding: 10px 8px;
    background: rgba(0,212,255,.05);
}
.aoc-slot-filled img { width: 56px; height: 56px; object-fit: contain; border-radius: 6px; background: #fff; }
.aoc-slot-title { font-size: .78rem; line-height: 1.3; max-width: 100%; word-break: break-word; }
.aoc-slot-remove {
    position: absolute;
    top: 4px;
    left: 4px;
    background: var(--aoc-danger);
    border: none;
    color: #fff;
    border-radius: 50%;
    width: 20px;
    height: 20px;
    font-size: .7rem;
    cursor: pointer;
    display: flex;
    align-items: center;
    justify-content: center;
    line-height: 1;
}

.aoc-tray-actions { display: flex; gap: 12px; }

/* ── Buttons ─────────────────────────────────────────── */
.aoc-btn {
    padding: 10px 22px;
    border: none;
    border-radius: 8px;
    font-family: var(--aoc-font);
    font-size: .95rem;
    font-weight: 600;
    cursor: pointer;
    transition: opacity .2s, transform .1s;
}
.aoc-btn:hover:not(:disabled) { opacity: .88; transform: translateY(-1px); }
.aoc-btn:disabled { opacity: .35; cursor: not-allowed; }
.aoc-btn-primary  { background: linear-gradient(135deg, var(--aoc-accent), var(--aoc-accent2)); color: #0f1117; }
.aoc-btn-secondary { background: var(--aoc-surface2); border: 1px solid var(--aoc-border); color: var(--aoc-text); }

/* ── Comparison Table ────────────────────────────────── */
.aoc-compare-wrapper { margin-top: 10px; }
.aoc-compare-heading {
    font-size: 1.5rem;
    margin-bottom: 16px;
    background: linear-gradient(90deg, var(--aoc-accent), var(--aoc-accent2));
    -webkit-background-clip: text;
    -webkit-text-fill-color: transparent;
    background-clip: text;
}
.aoc-compare-scroll {
    overflow-x: auto;
    border-radius: var(--aoc-radius);
    border: 1px solid var(--aoc-border);
    box-shadow: var(--aoc-shadow);
}
.aoc-compare-table {
    width: 100%;
    border-collapse: collapse;
    background: var(--aoc-surface);
    font-size: .9rem;
    min-width: 560px;
}
.aoc-compare-table th,
.aoc-compare-table td {
    padding: 12px 16px;
    border-bottom: 1px solid var(--aoc-border);
    vertical-align: middle;
    text-align: center;
}
.aoc-compare-table th { background: var(--aoc-bg); }
.aoc-spec-label {
    text-align: right !important;
    color: var(--aoc-text-muted);
    font-weight: 600;
    white-space: nowrap;
    background: var(--aoc-bg) !important;
    min-width: 140px;
}
.aoc-spec-label.aoc-custom-badge::after {
    content: ' ★';
    color: var(--aoc-accent2);
}
.aoc-spec-row:nth-child(even) td { background: rgba(255,255,255,.02); }
.aoc-spec-row:hover td { background: rgba(0,212,255,.04); }

/* Product header */
.aoc-row-header th { padding: 20px 16px; }
.aoc-product-thumb {
    width: 90px; height: 90px;
    margin: 0 auto 10px;
    background: #fff;
    border-radius: 8px;
    overflow: hidden;
    display: flex;
    align-items: center;
    justify-content: center;
}
.aoc-product-thumb img { max-width: 100%; max-height: 100%; object-fit: contain; }
.aoc-product-title a { color: var(--aoc-text); font-weight: 700; text-decoration: none; font-size: .95rem; }
.aoc-product-title a:hover { color: var(--aoc-accent); }
.aoc-product-brand { color: var(--aoc-text-muted); font-size: .8rem; margin-top: 4px; }

/* Price row */
.aoc-row-price td { padding: 16px; }
.aoc-row-highlight td { background: rgba(255,209,102,.04) !important; }
.aoc-price { font-size: 1.2rem; font-weight: 700; color: var(--aoc-price); display: block; margin-bottom: 8px; }
.aoc-buy-btn {
    display: inline-block;
    padding: 6px 16px;
    background: linear-gradient(135deg, var(--aoc-accent), var(--aoc-accent2));
    color: #0f1117;
    border-radius: 6px;
    text-decoration: none;
    font-size: .82rem;
    font-weight: 700;
    transition: opacity .2s;
}
.aoc-buy-btn:hover { opacity: .85; }

/* Rating */
.aoc-rating-bar {
    background: var(--aoc-border);
    border-radius: 4px;
    height: 6px;
    margin-bottom: 4px;
    overflow: hidden;
}
.aoc-rating-fill {
    height: 100%;
    background: linear-gradient(90deg, var(--aoc-accent), var(--aoc-best));
    border-radius: 4px;
    transition: width .6s ease;
}
.aoc-rating-num { font-size: .85rem; color: var(--aoc-text-muted); }

/* Best value highlight */
.aoc-best { color: var(--aoc-best) !important; font-weight: 700; }
.aoc-best .aoc-rating-fill { background: var(--aoc-best); }

.aoc-na { color: var(--aoc-border); }
.aoc-error { color: var(--aoc-danger); }

/* ── Floating bar ────────────────────────────────────── */
#aoc-floating-bar {
    position: fixed;
    bottom: 0; left: 0; right: 0;
    background: var(--aoc-surface2);
    border-top: 2px solid var(--aoc-accent);
    display: flex;
    align-items: center;
    gap: 12px;
    padding: 10px 20px;
    z-index: 99999;
    flex-wrap: wrap;
    box-shadow: 0 -4px 24px rgba(0,0,0,.5);
}
.aoc-bar-item {
    display: flex;
    align-items: center;
    gap: 8px;
    background: var(--aoc-surface);
    border: 1px solid var(--aoc-border);
    border-radius: 8px;
    padding: 6px 10px;
    font-size: .85rem;
}
.aoc-bar-item img { width: 36px; height: 36px; object-fit: contain; border-radius: 4px; background: #fff; }
.aoc-bar-remove {
    background: none;
    border: none;
    color: var(--aoc-text-muted);
    cursor: pointer;
    font-size: .9rem;
    padding: 0 2px;
}
.aoc-bar-remove:hover { color: var(--aoc-danger); }

/* ── Add-to-compare button (standalone) ─────────────── */
.aoc-add-compare {
    display: inline-flex;
    align-items: center;
    gap: 6px;
    padding: 8px 16px;
    background: transparent;
    border: 1px solid var(--aoc-accent);
    color: var(--aoc-accent);
    border-radius: 8px;
    font-family: var(--aoc-font);
    font-size: .85rem;
    cursor: pointer;
    transition: all .2s;
}
.aoc-add-compare:hover,
.aoc-add-compare.aoc-active {
    background: var(--aoc-accent);
    color: var(--aoc-bg);
}

/* ── Result area ─────────────────────────────────────── */
.aoc-result-area { margin-top: 28px; }

/* ── Scrollbar ───────────────────────────────────────── */
.aoc-compare-scroll::-webkit-scrollbar       { height: 6px; }
.aoc-compare-scroll::-webkit-scrollbar-track { background: var(--aoc-bg); }
.aoc-compare-scroll::-webkit-scrollbar-thumb { background: var(--aoc-border); border-radius: 3px; }
