/* ==========================================================================
   Media Archive Plus — Masonry + Modern Playlist Skin
   Palette: #022a4e (ink) / #00649f (accent) / #f7f9fc (soft)
   Version 1.1
   ========================================================================== */

/* ---------- Tokens ---------- */
:root{
  --ink:#022a4e;
  --accent:#00649f;
  --soft:#f7f9fc;

  --cols:3;      /* پیش‌فرض تصاویر */
  --gap:16px;    /* فاصله بین آیتم‌ها */
  --radius:16px; /* گردی گوشهٔ تصویر */
}

/* ---------- Scoped reset ---------- */
.map-collection, .map-collection *,
.map-playlist,   .map-playlist   *,
.map-lightbox,   .map-lightbox   *,
#map-lightbox,   #map-lightbox   * { box-sizing:border-box; }

.map-collection a, .map-collection button,
.map-playlist a,   .map-playlist button{
  color:inherit; text-decoration:none;
}

/* Anti-conflict: دکمه/تب‌های قالب داخل پلی‌لیست بی‌اثر شوند */
.map-playlist .tabs,
.map-playlist .tab,
.map-playlist .nav,
.map-playlist .nav-tabs { display:none !important; }
.map-playlist button,
.map-pl-player button,
.map-pl-controls button {
  -webkit-appearance:none !important;
  appearance:none !important;
  background:none;
  border:0;
  box-shadow:none;
  color:inherit;
  font:inherit;
  text-transform:none;
}

/* ---------- Masonry Grid ---------- */
.map-collection{
  column-count: var(--cols);
  column-gap: var(--gap);
  background:transparent;
  padding:0; margin:0;
}
.map-collection[data-variant="infographic"]{ --cols:2; }

@media (max-width:1280px){ .map-collection{ --cols:2 } }
@media (max-width:720px) { .map-collection{ --cols:1 } }

.map-card{
  display:block;
  margin:0 0 var(--gap);
  break-inside: avoid;
  -webkit-column-break-inside: avoid;
  page-break-inside: avoid;
  background:none; border:0; padding:0;
  position: relative; overflow: hidden; border-radius: 12px;
}

/* ---------- Image Card ---------- */
button.map-media{
  -webkit-appearance:none; appearance:none;
  background:none; border:0 !important; outline:0 !important;
  padding:0; margin:0; font:inherit; color:inherit;
  position:relative; display:block; width:100%;
  overflow:hidden; border-radius:var(--radius);
  background:var(--soft); cursor:zoom-in;
}
.map-media-inner{ position:relative; display:block; width:100%; height:100%; }

.map-img{
  display:block; width:100%; height:auto;
  object-fit:cover; object-position:center;
  border:0 !important;
  transform:scale(1.01);
  transition:transform .35s ease, filter .35s ease, opacity .2s ease;
}
.map-media:hover .map-img{ transform:scale(1.035); }

/* Overlay gradient */
.map-media::after{
  content:""; position:absolute; inset:0; pointer-events:none;
  background:linear-gradient(180deg, rgba(2,42,78,0) 60%, rgba(2,42,78,.46) 100%);
  opacity:0; transition:opacity .2s ease;
}
.map-media:hover::after{ opacity:1; }

.map-overlay{
  position:absolute; inset:0; pointer-events:none;
  opacity:0; transition:opacity .2s ease;
  display:flex; justify-content:flex-end; align-items:center; flex-direction:column;
  padding:1rem;
  background: linear-gradient(to top, rgba(2,42,78,0.85) 0%, rgba(2,42,78,0) 80%);
}
.map-card:hover .map-overlay{ opacity:1; }

.map-title{
  font-size:.95rem; font-weight:500; color:#f7f9fc;
  white-space:nowrap; overflow:hidden; text-overflow:ellipsis;
  background:linear-gradient(90deg, rgba(0,100,159,.92), rgba(0,100,159,.68));
  padding:8px 12px; border-radius:999px;
  box-shadow:0 6px 16px rgba(0,100,159,.18);
}

/* Badge (اختیاری) */
.map-badge{
  position:absolute; top:10px; right:10px; z-index:2;
  padding:6px 10px; border-radius:999px;
  background:rgba(2,42,78,.92); color:#fff; font-size:11px; letter-spacing:.2px;
}

/* Caption off (اختیاری) */
.map-caption{ display:none }

/* ---------- Load More ---------- */
.map-load-more-wrap{ display:flex; justify-content:center; margin-top:8px }
.map-load-more{
  -webkit-appearance:none; appearance:none;
  border:0; background:var(--accent); color:#fff;
  border-radius:12px; padding:10px 16px; font-size:13px; cursor:pointer;
  transition:filter .15s ease, transform .08s ease;
}
.map-load-more:hover{ filter:brightness(1.06) }
.map-load-more:active{ transform:translateY(1px) }
.map-load-more[disabled]{ opacity:.6; cursor:not-allowed }

/* ---------- Playlist (Modern RTL) ---------- */
.map-playlist{ display:grid; gap:16px; position:relative; }

/* Controls bar: راست=قبلی | وسط=عنوان | چپ=بعدی */
.map-pl-controlsbar{
  display:grid;
  grid-template-columns: 1fr auto 1fr; /* RTL: start راست، end چپ */
  gap: 8px; align-items: center; direction: rtl;
  padding: 6px 0;
}
.map-pl-controlsbar .map-pl-prev,
.map-pl-controlsbar .map-pl-next{
  border: 1px solid #e6e8ee; background:#fff; border-radius:10px;
  padding:6px 10px; cursor:pointer; font-size:13px;
}
.map-pl-controlsbar .map-pl-prev{ justify-self:start; } /* راست */
.map-pl-controlsbar .map-pl-next{ justify-self:end; }   /* چپ */
.map-pl-controlsbar .map-pl-now{
  text-align:center; font-size:14px; font-weight:600; color:#111827;
  white-space:nowrap; overflow:hidden; text-overflow:ellipsis;
}

/* Head: سرچ مینیمال + شمارش */
.map-pl-head{
  display:flex; align-items:center; gap:8px;
}

/* Toggle button برای باز/بستن سرچ */
.map-pl-search-toggle{
  border:1px solid #e6e8ee; background:#fff; border-radius:10px; padding:6px 10px;
  cursor:pointer; line-height:1;
}

/* خود سرچ: پیش‌فرض بسته، فقط عرض کوچیک باز میشه */
.map-pl-search{
  width:0; min-width:0; opacity:0; pointer-events:none;
  transition: width .18s ease, opacity .18s ease;
  border:1px solid #e6e8ee; border-radius:10px; padding:6px 10px; outline:none;
  font-size:14px;
}
.map-playlist.is-search-open .map-pl-search{ width:180px; opacity:1; pointer-events:auto; }
@media (max-width:480px){
  .map-playlist.is-search-open .map-pl-search{ width:140px; }
}
.map-pl-count{
  font-size:12px; color:#6b7280; background:#f3f4f6;
  border-radius:999px; padding:4px 10px;
}

/* Layout: لیست + پلیر */
.map-pl-wrap{ display:grid; grid-template-columns:360px 1fr; gap:16px; }
@media (max-width:980px){ .map-pl-wrap{ grid-template-columns:1fr; } }

/* لیست کارت‌ها */
.map-pl-list{
  max-height:560px; overflow:auto;
  padding-right:4px; display:grid; gap:10px;
}

/* کارت ویدیو */
.map-vid-card{
  display:grid; grid-template-columns:96px 1fr; gap:12px; align-items:center;
  width:100%; text-align:right; direction:rtl;
  border:1px solid #eef0f6; background:#fff; border-radius:14px; padding:10px; cursor:pointer;
  transition: box-shadow .15s ease, border-color .15s ease, transform .1s ease;
}
.map-vid-card:hover{ box-shadow:0 6px 20px rgba(15,23,42,.06); transform: translateY(-1px); }
.map-vid-card.is-active{ border-color:#d7dbec; background:#fbfcff; }
.map-vid-card.is-hidden{ display:none; }

.map-vid-thumb{ width:96px; height:54px; border-radius:10px; overflow:hidden; background:#e5e7eb; display:inline-flex; align-items:center; justify-content:center; }
.map-vid-thumb img{ width:100%; height:100%; object-fit:cover; display:block; }
.map-vid-thumb--placeholder{ width:96px; height:54px; border-radius:10px; background:linear-gradient(135deg,#f3f4f6,#e5e7eb); }

.map-vid-meta{ display:grid; gap:6px; align-items:center; }
.map-vid-title{ font-size:14px; font-weight:600; line-height:1.35; color:#111827; }
.map-vid-duration{ font-size:12px; color:#6b7280; background:#f3f4f6; padding:2px 8px; border-radius:999px; width:fit-content; }

/* پلیر */
.map-pl-player{ position:relative; border:1px solid #eef0f6; border-radius:16px; background:#fff; padding:10px; }
.map-video-player{ width:100%; border-radius:12px; background:#000; outline:none; display:block; }

/* پل قدیمی درصورت وجود (سازگاری) */
.map-pl-controls{
  margin-top:8px; display:flex; align-items:center; gap:10px; justify-content:space-between;
}
.map-pl-controls button{
  border:1px solid #e6e8ee; background:#fff; border-radius:10px; padding:6px 10px; cursor:pointer;
}
.map-pl-controls button:hover{ background:#f9fafb; }
.map-pl-now{ font-size:13px; color:#374151; }

/* Sticky mini player وقتی از ویو خارج شد */
.map-playlist.is-sticky .map-pl-player{ position:sticky; top:12px; }

/* ---------- Lightbox (ID-based, هماهنگ با JS) ---------- */
#map-lightbox{
  position:fixed; inset:0; z-index:99999;
  display:none; background:rgba(2,42,78,.90);
  backdrop-filter:saturate(1.1) blur(3px);
  align-items:center; justify-content:center; padding:24px;
}
#map-lightbox.is-open{ display:flex; }
#map-lightbox img{
  max-width:96vw; max-height:84vh; object-fit:contain; display:block; border-radius:12px; background:#000;
}
#map-lightbox .map-lb-close{
  position:absolute; top:12px; left:12px;
  width:36px; height:36px; border-radius:999px;
  border:1px solid #e6e8ee; background:#fff; cursor:pointer; font-size:18px; line-height:34px;
}
#map-lightbox .map-lb-caption{
  position:absolute; bottom:16px; left:50%; transform:translateX(-50%);
  max-width:92vw; color:#fff; text-align:center; font-size:14px; background:rgba(0,0,0,.35);
  padding:6px 10px; border-radius:999px;
}

/* ---------- قالب‌های ناسازگار ---------- */
figure.map-card{ margin:0 0 var(--gap) !important; }
.map-collection img{ border:0 !important; box-shadow:none !important; }
