/* Comms.Church PCO — front-end styles
   Uses CSS custom properties so themes can override easily.
   --pco-brand is set per-block via inline style; falls back to global option. */

:root {
  --pco-brand:     #1a4a8a;
  --pco-radius:    8px;
  --pco-gap:       1.5rem;
  --pco-card-bg:   #ffffff;
  --pco-shadow:    0 2px 12px rgba(0,0,0,.07);
  --pco-text:      #1e293b;
  --pco-muted:     #64748b;
  --pco-border:    #e2e8f0;
  --pco-font-sm:   .875rem;
  --pco-font-xs:   .8rem;
}

/* ---- Grid ---------------------------------------------------------------- */
.pco-signup-list {
  display: grid;
  gap: var(--pco-gap);
}
.pco-display-tiles.pco-cols-1 { grid-template-columns: 1fr; }
.pco-display-tiles.pco-cols-2 { grid-template-columns: repeat(2,1fr); }
.pco-display-tiles.pco-cols-3 { grid-template-columns: repeat(3,1fr); }
.pco-display-tiles.pco-cols-4 { grid-template-columns: repeat(4,1fr); }

.pco-display-list { grid-template-columns: 1fr; }
.pco-display-list .pco-card { flex-direction: row; }
.pco-display-list .pco-card-image { flex: 0 0 220px; }

@media (max-width: 960px) {
  .pco-display-tiles.pco-cols-3,
  .pco-display-tiles.pco-cols-4 { grid-template-columns: repeat(2,1fr); }
}
@media (max-width: 600px) {
  .pco-display-tiles,
  .pco-display-list .pco-card { grid-template-columns: 1fr; flex-direction: column; }
  .pco-display-list .pco-card-image { flex: none; }
}

/* ---- Card ---------------------------------------------------------------- */
.pco-card {
  background: var(--pco-card-bg);
  border-radius: var(--pco-radius);
  box-shadow: var(--pco-shadow);
  overflow: hidden;
  display: flex;
  flex-direction: column;
  transition: transform .2s ease, box-shadow .2s ease;
}
.pco-card:hover {
  transform: translateY(-3px);
  box-shadow: 0 6px 20px rgba(0,0,0,.11);
}
.pco-closed { opacity: .72; }

/* ---- Image --------------------------------------------------------------- */
.pco-card-image { position: relative; overflow: hidden; background: #f1f5f9; }
.pco-shape-cinematic { padding-top: 56.25%; }
.pco-shape-square    { padding-top: 100%; }
.pco-shape-portrait  { padding-top: 133%; }

.pco-card-image img {
  position: absolute; inset: 0; width: 100%; height: 100%; object-fit: cover;
}
.pco-image-placeholder {
  position: absolute; inset: 0;
  background: var(--pco-brand);
  display: flex; align-items: center; justify-content: center;
  color: #fff; font-weight: 600; font-size: 1rem; padding: 1rem; text-align: center;
}
.pco-closed-badge {
  position: absolute; top: .6rem; right: .6rem;
  background: rgba(0,0,0,.55); color: #fff;
  font-size: .7rem; font-weight: 700; letter-spacing: .05em;
  text-transform: uppercase; padding: .2rem .55rem;
  border-radius: 99px;
}

/* ---- Card body ----------------------------------------------------------- */
.pco-card-body {
  padding: 1.25rem;
  display: flex; flex-direction: column; gap: .5rem; flex: 1;
}
.pco-card-title {
  font-size: 1.05rem; font-weight: 700;
  color: var(--pco-text); margin: 0 0 .25rem; line-height: 1.3;
}
.pco-card-meta { display: flex; flex-direction: column; gap: .3rem; }

.pco-meta-date,
.pco-meta-location,
.pco-meta-price {
  display: flex; align-items: flex-start; gap: .35rem;
  font-size: var(--pco-font-sm); color: var(--pco-muted); margin: 0;
}
.pco-meta-date svg,
.pco-meta-location svg {
  width: 14px; height: 14px; flex-shrink: 0; margin-top: 2px;
  color: var(--pco-brand);
}
.pco-card-desc {
  font-size: var(--pco-font-sm); color: var(--pco-muted);
  margin: 0; overflow: hidden;
  display: -webkit-box; -webkit-line-clamp: 3; -webkit-box-orient: vertical;
}
.pco-price      { font-weight: 600; color: var(--pco-brand); }
.pco-price-free { font-weight: 600; color: #16a34a; }

.pco-card-actions {
  margin-top: auto; padding-top: .75rem;
  display: flex; flex-wrap: wrap; gap: .6rem; align-items: center;
}

/* ---- Progress bar -------------------------------------------------------- */
.pco-progress { margin: .25rem 0; }
.pco-progress-bar {
  height: 6px; background: var(--pco-border);
  border-radius: 3px; overflow: hidden;
}
.pco-progress-fill {
  height: 100%; background: var(--pco-brand);
  border-radius: 3px; transition: width .4s ease;
}
.pco-progress-fill.pco-full { background: #dc2626; }
.pco-progress-label { font-size: var(--pco-font-xs); color: var(--pco-muted); margin: 3px 0 0; }

/* ---- Buttons ------------------------------------------------------------- */
.pco-btn {
  display: inline-flex; align-items: center; justify-content: center;
  padding: .5rem 1.25rem;
  border-radius: calc(var(--pco-radius) / 1.5);
  font-size: var(--pco-font-sm); font-weight: 600;
  text-decoration: none; cursor: pointer; border: none;
  transition: filter .15s, opacity .15s;
  white-space: nowrap;
}
.pco-btn-primary {
  background-color: var(--pco-brand); color: #fff !important;
}
.pco-btn-primary:hover { filter: brightness(1.12); }
.pco-btn-disabled { background: #e2e8f0; color: #94a3b8 !important; cursor: not-allowed; }

/* ---- Add to Calendar ----------------------------------------------------- */
.pco-cal-wrap { position: relative; display: inline-block; }
.pco-cal-trigger {
  display: inline-flex; align-items: center; gap: .35rem;
  background: transparent; border: 1.5px solid var(--pco-brand);
  color: var(--pco-brand); border-radius: calc(var(--pco-radius) / 1.5);
  padding: .45rem .9rem; font-size: var(--pco-font-xs); font-weight: 600;
  cursor: pointer; transition: background .15s, color .15s; white-space: nowrap;
}
.pco-cal-trigger:hover { background: var(--pco-brand); color: #fff; }
.pco-cal-trigger svg { width: 13px; height: 13px; flex-shrink: 0; }
.pco-cal-chevron { transition: transform .2s; }
.pco-cal-wrap.open .pco-cal-chevron { transform: rotate(180deg); }
.pco-cal-dropdown {
  display: none; position: absolute; bottom: calc(100% + 6px); left: 0;
  background: #fff; border: 1px solid var(--pco-border);
  border-radius: calc(var(--pco-radius) / 1.5);
  box-shadow: 0 4px 18px rgba(0,0,0,.12);
  min-width: 210px; z-index: 9999; overflow: hidden;
}
.pco-cal-wrap.open .pco-cal-dropdown { display: block; }
.pco-cal-option {
  display: flex; align-items: center; gap: .6rem;
  padding: .6rem 1rem; color: var(--pco-text) !important;
  text-decoration: none !important; font-size: var(--pco-font-sm);
  transition: background .1s;
}
.pco-cal-option:hover { background: #f8fafc; }
.pco-cal-option svg { width: 18px; height: 18px; flex-shrink: 0; }

/* ---- Single detail ------------------------------------------------------- */
.pco-signup-detail { max-width: 720px; }
.pco-detail-hero {
  width: 100%; border-radius: var(--pco-radius);
  display: block; margin-bottom: 1.5rem;
}
.pco-detail-body { }
.pco-detail-title { font-size: 1.6rem; font-weight: 700; margin: 0 0 1rem; }
.pco-detail-desc  { line-height: 1.65; margin: 0 0 1.5rem; }
.pco-detail-meta  { display: grid; gap: 1rem; margin-bottom: 1.5rem; }

@media (min-width: 600px) {
  .pco-detail-meta { grid-template-columns: repeat(auto-fill, minmax(220px,1fr)); }
}

.pco-meta-block {
  padding: 1rem; background: #f8fafc;
  border: 1px solid var(--pco-border);
  border-radius: calc(var(--pco-radius) / 1.5);
}
.pco-meta-block h3 {
  font-size: var(--pco-font-xs); font-weight: 700;
  text-transform: uppercase; letter-spacing: .05em;
  color: var(--pco-muted); margin: 0 0 .6rem;
}
.pco-times-list, .pco-tickets-list {
  list-style: none; margin: 0; padding: 0;
}
.pco-times-list li, .pco-tickets-list li {
  padding: .35rem 0; border-bottom: 1px solid var(--pco-border);
  font-size: var(--pco-font-sm);
}
.pco-times-list li:last-child, .pco-tickets-list li:last-child { border: none; }
.pco-tickets-list li { display: flex; justify-content: space-between; }
.pco-ticket-price { font-weight: 600; color: var(--pco-brand); }
.pco-detail-actions { display: flex; flex-wrap: wrap; gap: .75rem; align-items: center; }

/* ---- Misc ---------------------------------------------------------------- */
.pco-no-results { color: var(--pco-muted); font-style: italic; }
.pco-count { font-weight: 600; }
.pco-admin-notice {
  border: 1px solid #f87171; background: #fef2f2;
  border-radius: 4px; padding: .6rem .9rem;
  color: #dc2626; font-size: var(--pco-font-sm);
}

/* ---- Font size scale (set by global option) ------------------------------ */
body.pco-font-small  { --pco-font-sm: .8125rem; --pco-font-xs: .75rem; }
body.pco-font-large  { --pco-font-sm: 1rem;     --pco-font-xs: .875rem; }
