/* Persian Election Cards - Frontend Styles (Material Design 3 inspired) */
:root{
  --peec-primary:#009C87;
  --peec-radius:16px;
  --peec-shadow-sm:0 1px 2px rgba(0,0,0,.08);
  --peec-shadow-md:0 4px 12px rgba(0,0,0,.12);
  --peec-shadow-lg:0 12px 28px rgba(0,0,0,.18);
}

.peec-card{
  font-family: Vazirmatn, Vazir, 'Vazir', -apple-system, BlinkMacSystemFont, 'Segoe UI', Roboto, 'Helvetica Neue', Arial, sans-serif;
  background:#fff;
  border-radius: var(--peec-radius);
  overflow:hidden;
  border:1px solid rgba(0,0,0,.06);
  transition: transform .2s ease, box-shadow .2s ease;
}
.peec-card:hover{ transform: translateY(-2px); box-shadow: var(--peec-shadow-lg);}

.peec-shadow-none{ box-shadow:none!important; }
.peec-shadow-sm{ box-shadow:var(--peec-shadow-sm); }
.peec-shadow-md{ box-shadow:var(--peec-shadow-md); }
.peec-shadow-lg{ box-shadow:var(--peec-shadow-lg); }

.peec-size-sm .peec-card-title{ font-size:14px; }
.peec-size-md .peec-card-title{ font-size:16px; }
.peec-size-lg .peec-card-title{ font-size:18px; }

.peec-card-media{
  display:block;
  width:100%;
  aspect-ratio:1/1; /* 1:1 square */
  background:#f5f5f5;
  overflow:hidden;
}
.peec-card-media img{
  width:100%; height:100%; object-fit:cover; display:block;
}

.peec-card-body{ padding:12px; }
.peec-card-date{
  color:#fff; background:var(--peec-primary); display:inline-block; padding:4px 8px; border-radius:999px; font-size:12px; margin-bottom:8px;
}
.peec-card-title{ margin:8px 0; line-height:1.5; }
.peec-card-title a{ color:#1b1b1b; text-decoration:none; }
.peec-card-title a:hover{ color:var(--peec-primary); }
.peec-card-meta{ display:flex; gap:8px; flex-wrap:wrap; opacity:.85; font-size:13px; }

/* Carousel */
.peec-carousel{ position:relative; }
.peec-carousel-track{ display:flex; transition: transform .4s ease; will-change: transform; }
.peec-carousel-item{ padding: var(--peec-gap, 16px) 8px; box-sizing:border-box; min-width: 100%; }
.peec-carousel .peec-carousel-prev,
.peec-carousel .peec-carousel-next{
  position:absolute; top:50%; transform:translateY(-50%); background:#fff; border:1px solid rgba(0,0,0,.12);
  border-radius:50%; width:40px; height:40px; display:flex; align-items:center; justify-content:center; cursor:pointer;
  box-shadow:var(--peec-shadow-md);
}
.peec-carousel .peec-carousel-prev{ left:8px; }
.peec-carousel .peec-carousel-next{ right:8px; }
.peec-carousel-dots{ display:flex; gap:6px; justify-content:center; margin-top:8px; }
.peec-carousel-dots button{ width:8px; height:8px; border-radius:50%; border:none; background:#d0d0d0; cursor:pointer; }
.peec-carousel-dots button.is-active{ background:var(--peec-primary); }

/* Responsive widths for items */
@media (min-width: 640px){
  .peec-carousel-item{ min-width: 50%; }
}
@media (min-width: 960px){
  .peec-carousel-item{ min-width: 33.3333%; }
}

/* List/Grid */
.peec-list{ --peec-gap:16px; }
.peec-list-toolbar{ display:flex; flex-wrap:wrap; gap:8px; margin-bottom:12px; }
.peec-list-toolbar input[type="search"],
.peec-list-toolbar select{
  padding:8px 10px; border-radius:10px; border:1px solid rgba(0,0,0,.12); background:#fff; min-width:160px;
}
.peec-grid{ display:grid; gap: var(--peec-gap); grid-template-columns: repeat(var(--peec-cols,3), minmax(0,1fr)); }
@media (max-width:640px){
  .peec-grid{ grid-template-columns: repeat(var(--peec-cols-mobile,1), minmax(0,1fr)); }
}
@media (min-width:641px) and (max-width:1024px){
  .peec-grid{ grid-template-columns: repeat(var(--peec-cols-tablet,2), minmax(0,1fr)); }
}
