/* Parrish Choir Sponsors front styles v2.0 */

.pcbsp-featured,
.pcbsp-tier-grid{
  display:grid;
  grid-template-columns: repeat(3, minmax(0,1fr));
  gap: 14px;
}
.pcbsp-cols-1{ grid-template-columns: 1fr !important; }
.pcbsp-cols-2{ grid-template-columns: repeat(2, minmax(0,1fr)) !important; }
.pcbsp-cols-3{ grid-template-columns: repeat(3, minmax(0,1fr)) !important; }
.pcbsp-cols-4{ grid-template-columns: repeat(4, minmax(0,1fr)) !important; }
@media (max-width: 980px){
  .pcbsp-featured,
  .pcbsp-tier-grid{ grid-template-columns: 1fr; }
}

.pcbsp-card{
  background:#fff;
  border: 1px solid rgba(15,23,42,.14);
  border-radius: 22px;
  box-shadow: 0 12px 30px rgba(15,23,42,.12);
  padding: 14px;
  display:flex;
  flex-direction: column;
  gap: 10px;
  overflow:hidden;
}
.pcbsp-top{
  display:flex;
  align-items:flex-start;
  justify-content: space-between;
  gap: 10px;
}
.pcbsp-name{
  font-weight: 1000;
  letter-spacing: -0.01em;
  color:#0f172a;
  font-size: 1.05rem;
}
.pcbsp-desc{
  color:#475569;
  line-height: 1.55;
}
.pcbsp-tier{
  font-size: .78rem;
  padding: 7px 12px;
  border-radius: 999px;
  color:#fff;
  white-space: nowrap;
  min-width: 86px;
  display:inline-flex;
  align-items:center;
  justify-content:center;
  line-height: 1;
  flex: 0 0 auto;
}
.pcbsp-tier-platinum{ background: linear-gradient(135deg, #0f172a, #334155); }
.pcbsp-tier-gold{ background: linear-gradient(135deg, #b45309, #f59e0b); }
.pcbsp-tier-silver{ background: linear-gradient(135deg, #64748b, #94a3b8); }
.pcbsp-tier-bronze{ background: linear-gradient(135deg, #92400e, #c2410c); }

.pcbsp-img{
  width:100%;
  height: 150px;
  object-fit: cover;
  border-radius: 16px;
  border: 1px solid rgba(15,23,42,.14);
  background:#fff;
}
.pcbsp-img-ph{
  display:flex;
  align-items:center;
  justify-content:center;
  color:#64748b;
  font-weight: 900;
}

.pcbsp-actions{
  margin-top:auto;
  display:flex;
  gap: 10px;
  flex-wrap: wrap;
}
.pcbsp-btn{
  appearance:none;
  border:0;
  cursor:pointer;
  font-weight: 900;
  border-radius: 999px;
  padding: 11px 15px;
  display:inline-flex;
  align-items:center;
  justify-content:center;
  gap: 10px;
  text-decoration:none;
  transition: transform .15s ease, box-shadow .15s ease, opacity .15s ease;
}
.pcbsp-btn:active{ transform: translateY(1px); }
.pcbsp-btn-primary{
  color:#fff;
  background: linear-gradient(135deg, #1e3a8a, #0f3a6b);
  box-shadow: 0 16px 34px rgba(30,58,138,.22);
}
.pcbsp-btn-ghost{
  color:#0f172a;
  background: rgba(255,255,255,.92);
  border: 1px solid rgba(15,23,42,.14);
  box-shadow: none;
}
.pcbsp-btn:hover{ box-shadow: 0 12px 30px rgba(15,23,42,.12); }

.pcbsp-wall{
  display:flex;
  flex-direction: column;
  gap: 16px;
}
.pcbsp-intro{
  color:#475569;
  line-height: 1.65;
  padding: 10px 2px 0;
}
.pcbsp-tier-head{
  background: rgba(255,255,255,.92);
  border: 1px solid rgba(15,23,42,.14);
  border-radius: 18px;
  box-shadow: 0 12px 30px rgba(15,23,42,.10);
  padding: 14px;
}
.pcbsp-tier-title{
  font-weight: 1000;
  color:#0f172a;
  font-size: 1.15rem;
}
.pcbsp-empty{
  color:#64748b;
  font-weight: 900;
}

.pcbsp-overlay{
  position: fixed;
  inset: 0;
  background: rgba(15,23,42,.62);
  backdrop-filter: blur(7px);
  display:none;
  align-items:center;
  justify-content:center;
  padding: 18px;
  z-index: 99999;
}
.pcbsp-overlay.is-open{ display:flex; }
.pcbsp-modal{
  width: min(860px, 100%);
  background:#fff;
  border-radius: 24px;
  box-shadow: 0 30px 110px rgba(0,0,0,.35);
  overflow:hidden;
  transform: translateY(6px);
  animation: pcbspPop .18s ease forwards;
}
@keyframes pcbspPop{ to { transform: translateY(0); } }
.pcbsp-modal-head{
  padding: 16px 16px 10px;
  display:flex;
  align-items:flex-start;
  justify-content:space-between;
  gap: 12px;
  border-bottom: 1px solid rgba(15,23,42,.14);
  background:
    radial-gradient(420px 120px at 18% 0%, rgba(30,58,138,.14), transparent 60%),
    linear-gradient(135deg, rgba(30,58,138,.08), rgba(241,245,249,.75));
}
.pcbsp-modal-title{
  font-weight: 1000;
  font-size: 1.25rem;
  color:#0f172a;
}
.pcbsp-modal-tier{
  margin-top: 4px;
  color:#475569;
  font-weight: 800;
}
.pcbsp-x{
  border: 1px solid rgba(15,23,42,.22);
  background: rgba(255,255,255,.98);
  border-radius: 12px;
  padding: 8px 10px;
  font-weight: 1000;
  cursor:pointer;
  color:#0f172a;
}
.pcbsp-x:hover{ box-shadow: 0 12px 30px rgba(15,23,42,.12); }
.pcbsp-modal-body{ padding: 16px; }
.pcbsp-modal-img{
  width:100%;
  max-height: 340px;
  object-fit: contain;
  border-radius: 16px;
  border: 1px solid rgba(15,23,42,.14);
}
.pcbsp-modal-desc{
  margin: 12px 0 0;
  color:#475569;
  line-height: 1.65;
}
.pcbsp-modal-contact{
  margin-top: 12px;
  padding: 12px;
  border: 1px solid rgba(15,23,42,.14);
  border-radius: 16px;
  background: rgba(241,245,249,.60);
  color:#0f172a;
}
.pcbsp-modal-actions{
  margin-top: 14px;
  display:flex;
  gap: 10px;
  flex-wrap: wrap;
}

.pcbsp-strip{
  background: rgba(255,255,255,.92);
  border: 1px solid rgba(15,23,42,.14);
  border-radius: 22px;
  box-shadow: 0 12px 30px rgba(15,23,42,.10);
  padding: 14px;
  overflow:hidden;
}
.pcbsp-strip-head{
  display:flex;
  align-items:baseline;
  gap: 10px;
  flex-wrap: wrap;
  margin-bottom: 10px;
}
.pcbsp-strip-ico{ font-size: 1.05rem; }
.pcbsp-strip-title{ font-weight: 1000; color:#0f172a; }
.pcbsp-strip-sub{ color:#475569; font-weight: 700; font-size:.92rem; }
.pcbsp-strip-items{
  display:grid;
  grid-template-columns: repeat(6, minmax(0,1fr));
  gap: 10px;
}
@media (max-width: 980px){
  .pcbsp-strip-items{ grid-template-columns: repeat(2, minmax(0,1fr)); }
}
@media (max-width: 420px){
  .pcbsp-strip-items{ grid-template-columns: 1fr; }
}
.pcbsp-chip{
  border: 1px solid rgba(15,23,42,.14);
  background:#fff;
  border-radius: 18px;
  padding: 10px;
  display:flex;
  flex-direction: column;
  gap: 8px;
  align-items:flex-start;
  text-decoration:none;
  cursor:pointer;
  transition: transform .15s ease, box-shadow .15s ease;
}
.pcbsp-chip:hover{ transform: translateY(-1px); box-shadow: 0 12px 30px rgba(15,23,42,.12); }
.pcbsp-chip-logo{
  width: 100%;
  aspect-ratio: 16/10;
  border-radius: 14px;
  object-fit: cover;
  border: 1px solid rgba(15,23,42,.10);
  background:#fff;
}
.pcbsp-chip-ph{
  display:flex; align-items:center; justify-content:center;
  color:#64748b; font-weight:1000;
}
.pcbsp-chip-name{ font-weight: 1000; color:#0f172a; font-size: .95rem; }
.pcbsp-chip-tier{ color:#475569; font-weight: 800; font-size: .82rem; }

.pcbsp-spotlight{
  background: rgba(255,255,255,.92);
  border: 1px solid rgba(15,23,42,.14);
  border-radius: 28px;
  box-shadow: 0 12px 30px rgba(15,23,42,.12);
  overflow:hidden;
}
.pcbsp-spot-head{
  padding: 14px 14px 0;
  display:flex;
  align-items:flex-end;
  justify-content:space-between;
  gap: 12px;
  flex-wrap: wrap;
}
.pcbsp-spot-title{ font-weight: 1000; font-size: 1.25rem; color:#0f172a; }
.pcbsp-spot-sub{ color:#475569; font-weight: 700; margin-top: 4px; }
.pcbsp-spot-dots{
  display:flex; gap: 8px; align-items:center;
  padding-bottom: 6px;
}
.pcbsp-dot{
  width: 9px; height: 9px;
  border-radius: 99px;
  border: 1px solid rgba(15,23,42,.24);
  background: rgba(255,255,255,.9);
  cursor:pointer;
}
.pcbsp-dot.is-on{
  background: linear-gradient(135deg, #1e3a8a, #0f3a6b);
  border-color: transparent;
}
.pcbsp-spot-slides{ padding: 14px; }
.pcbsp-spot-slide{
  display:none;
  grid-template-columns: 1.1fr .9fr;
  gap: 14px;
  align-items: stretch;
}
.pcbsp-spot-slide.is-on{ display:grid; }
@media (max-width: 980px){
  .pcbsp-spot-slide{ grid-template-columns: 1fr; }
}
.pcbsp-spot-left{
  background:#fff;
  border: 1px solid rgba(15,23,42,.14);
  border-radius: 22px;
  box-shadow: 0 12px 30px rgba(15,23,42,.10);
  padding: 14px;
  display:flex;
  flex-direction: column;
  gap: 10px;
}
.pcbsp-spot-right{
  background:#fff;
  border: 1px solid rgba(15,23,42,.14);
  border-radius: 22px;
  box-shadow: 0 12px 30px rgba(15,23,42,.10);
  padding: 14px;
  display:flex;
  align-items:center;
  justify-content:center;
}
.pcbsp-spot-name{ font-weight: 1000; font-size: 1.3rem; color:#0f172a; }
.pcbsp-spot-desc{ color:#475569; line-height: 1.65; }
.pcbsp-spot-actions{
  margin-top: auto;
  display:flex; gap: 10px; flex-wrap: wrap;
}
.pcbsp-spot-img{
  width:100%;
  max-height: 260px;
  object-fit: contain;
  border-radius: 16px;
  border: 1px solid rgba(15,23,42,.14);
  background:#fff;
}
.pcbsp-spot-ph{
  width:100%; height: 220px;
  border-radius: 16px;
  border: 1px dashed rgba(15,23,42,.22);
  display:flex; align-items:center; justify-content:center;
  color:#64748b; font-weight: 900;
}
