/* ===================== */
/*  SimcardPlus Product  */
/*  Scope prefix: sp-    */
/* ===================== */

/* ---------- Variables fallback ---------- */
:root{
  --sp-bg-tile: var(--tile-bg, #0f1620);
  --sp-accent:  var(--blue-accent, #007DB8);
  --sp-text:    var(--text-light, #E0E0E0);
  --sp-chip-bg: rgba(12,22,30,.70);
  --sp-shadow:  0 8px 20px rgba(0,0,0,.20);
}
/* utility */
[hidden]{ display:none !important; }

/* ========================= */
/*  Category (product grid)  */
/* ========================= */
.product-page main.container{
  background:#f8fafc;
  color:#111;
}
body.product-page{
  background:#f8fafc;
  color:#111;
}

.sp-catalog{ max-width:1320px; margin:0 auto; padding:24px; }
.sp-grid{
  display:grid; gap:22px;
  grid-template-columns:repeat(4,minmax(0,1fr));
}
@media (max-width:1200px){ .sp-grid{ grid-template-columns:repeat(3,1fr); } }
@media (max-width:900px) { .sp-grid{ grid-template-columns:repeat(2,1fr); } }
@media (max-width:520px) { .sp-grid{ grid-template-columns:1fr; } }

/* ========================= */
/*   White Product Cards     */
/* ========================= */

/* خود کارت محصول – قاب سفید */
.sp-card{
  background: #ffffff;
  color: #111827;
  border-radius: 12px;
  overflow: hidden;
  box-shadow: 0 8px 20px rgba(0,0,0,.10);
  transition: transform .18s ease, box-shadow .18s ease;
  contain: content;
}
.sp-card:hover{ transform:translateY(-3px); box-shadow:0 12px 28px rgba(0,0,0,.18); }

.sp-card-body{ padding:12px 14px 16px; }
.sp-card-title{ font-size:1rem; font-weight:600; margin:8px 0 6px; color:#111827; }
.sp-card-price{ font-weight:700; color:#15803d; margin-top:2px; }
.sp-card-link{ color:var(--link-color, #00ADEF); text-decoration:none; }
.sp-card-link:hover{ text-decoration:underline; }
.sp-card-desc{
  font-size: 0.88rem;
  color: #374151;
  margin-top: 6px;
  line-height: 1.5;
  white-space: pre-line;
}

.sp-card-specs{
  margin: 8px 0 0;
  padding-left: 18px;
  font-size: .92rem;
  opacity: .92;
}
.sp-card-specs li{
  margin: 2px 0;
  line-height: 1.35;
}

/* ----- Mini slider on cards (Dell-like) ----- */
.sp-card-media{ position:relative; aspect-ratio:16/9; background:#ffffff; }
.sp-mini-stage{ display:block; width:100%; height:100%; }
.sp-mini-stage img{
  background: #ffffff;
  padding: 8px;
  border-radius: 10px;
}
.sp-mini-slide{
  display:none; width:100%; height:100%;
  object-fit:contain; background:#ffffff;
}
.sp-mini-slide.is-active{ display:block; }

.sp-mini-nav{
  position:absolute; top:50%; transform:translateY(-50%);
  width:32px; height:32px; border-radius:50%;
  border:0; background:rgba(0,0,0,.35); color:#fff;
  cursor:pointer; line-height:32px; text-align:center;
  opacity: 0;
  transition: opacity .2s ease;
}
.sp-card-media:hover .sp-mini-nav{
  opacity: 1;
}
.sp-mini-prev{ left:8px; } .sp-mini-next{ right:8px; }
.sp-mini-nav:focus-visible{ outline:3px solid rgba(0,125,184,.55); }

.sp-mini-counter{
  position:absolute; bottom:8px; left:50%; transform:translateX(-50%);
  background:rgba(0,0,0,.45); color:#fff;
  border-radius:14px; padding:2px 8px; font-weight:600; font-size:.9rem;
  box-shadow:0 2px 4px rgba(0,0,0,.25);
}
@media (max-width:768px){ .sp-mini-nav{ display:none; } }

/* ===================== */
/*  Product detail view  */
/* ===================== */
.sp-details{ max-width:1100px; margin:0 auto; padding:16px 24px 32px; }

.sp-gallery{
  display:grid; grid-template-columns:90px 1fr;
  gap:12px; align-items:start; margin:0 auto 16px; max-width:900px;
}
.sp-stage{ position:relative; overflow:hidden; border-radius:12px; box-shadow:var(--sp-shadow); background:var(--sp-bg-tile); }
.sp-slide{ display:none; width:100%; height:auto; }
.sp-slide.is-active{ display:block; }

.sp-nav{
  position:absolute; top:50%; transform:translateY(-50%);
  border:0; background:rgba(0,0,0,.35); color:#fff;
  width:36px; height:36px; border-radius:50%; cursor:pointer;
}
.sp-prev{ left:8px; } .sp-next{ right:8px; }
.sp-nav:focus-visible{ outline:3px solid rgba(0,125,184,.55); }

.sp-counter{
  position:absolute; bottom:8px; left:50%; transform:translateX(-50%);
  background:rgba(0,0,0,.45); color:#fff; border-radius:16px; padding:4px 10px; font-weight:600;
}

.sp-thumbs{ display:flex; flex-direction:column; gap:8px; }
.sp-thumb{
  border:2px solid transparent; border-radius:8px; padding:0; background:none; cursor:pointer;
}
.sp-thumb.is-active{ border-color:var(--sp-accent); }
.sp-thumb img{
  display:block; width:72px; height:72px; object-fit:cover; border-radius:6px; background:var(--sp-bg-tile);
}

/* ---------- Layout: sidebar + results ---------- */
.search-layout {
  display: flex;
  align-items: flex-start;
  gap: 16px;
}

.filters-left {
  flex: 0 0 260px;
  max-width: 260px;
}

.results-right {
  flex: 1;
  min-width: 0;
}

/* Category page cards grid (matches product/index.php markup) */
.results-grid{
  display:grid;
  grid-template-columns:repeat(auto-fill, minmax(280px, 1fr));
  gap:20px;
  margin:24px 0;
  align-items:start;
}

/* فیلتر سایدبار (دسکتاپ، مثل قبل) */
.sp-filter {
  width: 260px;
  border-right: 1px solid #e6e6e6;
  background: #fff;
  padding: 16px;
  position: sticky;
  top: 80px;
  height: fit-content;
}

/* اگر جایی از sp-filters استفاده شده بود، هر دو یکی باشند */
.sp-filters {
  width: 260px;
  border-right: 1px solid #e6e6e6;
  background: #fff;
  padding: 16px;
  position: sticky;
  top: 80px;
  height: fit-content;
}

/* نوار ابزار بالای نتایج (فقط برای موبایل نمایش می‌دهیم) */
.results-toolbar {
  display: none;          /* دسکتاپ: مخفی */
  margin-bottom: 12px;
  justify-content: flex-end;
}

.btn-filters-toggle {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  padding: 8px 14px;
  border-radius: 999px;
  border: 1px solid #0a63d1;
  background: #fff;
  color: #0a63d1;
  font-weight: 600;
  cursor: pointer;
}

.btn-filters-toggle::before {
  content: "\2263"; /* ≣ آیکون ساده فیلتر/منو */
  font-size: 1.1rem;
}

/* دکمه بستن داخل پنل فیلتر (فقط موبایل) */
.sp-filter-close {
  display: none;
  position: absolute;
  top: 12px;
  right: 16px;
  border: none;
  background: none;
  font-size: 1.8rem;
  cursor: pointer;
}

.sp-filter-title {
  margin: 0 0 12px;
  font-size: 1.2rem;
  font-weight: 700;
}

/* موبایل: فیلتر به صورت پنل تمام‌صفحه باز می‌شود */
@media (max-width: 900px) {
  .search-layout {
    flex-direction: column;
    align-items: stretch;
  }

  .filters-left {
    width: 100%;
    max-width: 100%;
  }

  .results-toolbar {
    display: flex;      /* موبایل: دکمه Filters را نشان بده */
  }

  /* در حالت عادی فیلتر مخفی باشد */
  .sp-filter,
  .sp-filters {
    position: static;
    display: none;
    border-right: none;
    border-bottom: 1px solid #e6e6e6;
  }

  /* وقتی کلاس is-open گرفت، مثل یک پنل/مودال تمام‌صفحه باز شود */
  .sp-filter.is-open,
  .sp-filters.is-open {
    display: block;
    position: fixed;
    inset: 0;
    background: #f7f7f7;
    z-index: 999;
    max-width: none;
    overflow-y: auto;
    padding: 16px;

    height: 100vh;
    -webkit-overflow-scrolling: touch;
    overscroll-behavior: contain;
    touch-action: pan-y;
  }

  .sp-filter__form {
    position: relative;
    padding-top: 32px; /* جا برای دکمه × */
  }

  .sp-filter-close {
    display: block;
  }
}

/* وقتی پنل فیلتر باز است، اسکرول صفحه قفل شود (همه حالت‌ها) */
body.sp-filter-open { overflow: hidden; }

.sp-filters__head{font-weight:700;margin-bottom:8px}
details{border:1px solid #eee;border-radius:10px;padding:8px 10px;margin-bottom:10px;background:#fafafa}
summary{cursor:pointer;font-weight:600;list-style:none}
summary::-webkit-details-marker{display:none}
.facet{margin-top:8px;display:grid;gap:6px}
.chk{display:flex;justify-content:space-between;align-items:center;gap:8px}
.chk input{margin-right:6px}
.chk span{flex:1}
.chk em{font-style:normal;color:#888;font-size:.85rem}
.facet-range{display:flex;align-items:center;gap:8px}
.facet-range input{width:100%}
.btn-apply{width:100%;margin-top:10px;background:#0a63d1;color:#fff;border:none;padding:10px;border-radius:8px;cursor:pointer}
.btn-reset{display:block;text-align:center;margin-top:6px;color:#0a63d1}

.sp-price-lg{ font-size:1.25rem; margin:10px 0 16px; color:#c9f27c; }
.sp-specs{ width:100%; border-collapse:collapse; margin-top:12px; }
.sp-specs th,.sp-specs td{ padding:8px 10px; border-bottom:1px solid rgba(255,255,255,.08); }
.sp-specs th{ text-align:left; opacity:.85; white-space:nowrap; }

@media (max-width:900px){
  .sp-gallery{ grid-template-columns:1fr; }
  .sp-thumbs{ flex-direction:row; flex-wrap:wrap; }
}

/* ===== Active filters chips + badge ===== */
.btn-filters-toggle { position: relative; }
.sp-filter-badge{
  margin-left: 8px;
  min-width: 18px;
  height: 18px;
  padding: 0 6px;
  border-radius: 999px;
  background: #0a63d1;
  color: #fff;
  font-size: 12px;
  font-weight: 700;
  align-items: center;
  justify-content: center;
  display: none; /* JS کنترل می‌کند */
}

.sp-active-filters{
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  margin: 10px 0 14px;
}

.sp-chip{
  display: inline-flex;
  align-items: center;
  gap: 8px;
  border: 1px solid #d1d5db;
  background: #fff;
  color: #111827;
  border-radius: 999px;
  padding: 6px 10px;
  cursor: pointer;
  font-size: 0.9rem;
}
.sp-chip:hover{ background:#f3f4f6; }
.sp-chip-x{ font-size: 1.1rem; line-height: 1; opacity: .7; }
.sp-chip-clearall{
  border-color:#0a63d1;
  color:#0a63d1;
  font-weight:700;
}

/* ===== Mobile panel animation + scroll fix ===== */
@media (max-width: 900px) {
  .sp-filter.is-open,
  .sp-filters.is-open{
    height: 100vh;
    overflow-y: auto;
    -webkit-overflow-scrolling: touch;
    overscroll-behavior: contain;
    touch-action: pan-y;

    animation: spFilterIn .18s ease-out;
  }
  @keyframes spFilterIn{
    from{ transform: translateY(8px); opacity: .6; }
    to  { transform: translateY(0); opacity: 1; }
  }

  /* اگر iOS اسکرول را قفل می‌کند، این بهتر است */
}

/* ===== Facet list: vertical, readable ===== */
.facet-list{
  display: grid;
  gap: 8px;
  margin-top: 8px;
}

.facet-item{
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 10px;

  padding: 8px 10px;
  border: 1px solid #eee;
  border-radius: 10px;
  background: #fff;
}

.facet-item:hover{
  background: #f6f7f9;
}

.facet-item input{
  margin: 0;
  flex: 0 0 auto;
}

.facet-label{
  flex: 1;
  margin-left: 8px;
  font-size: 0.95rem;
  color: #111827;
}

.facet-count{
  flex: 0 0 auto;
  font-style: normal;
  font-size: 0.85rem;
  color: #6b7280;
}