/* Gaycal Embed Template v1 */
:root {
  --gc-font: "Work Sans", "Helvetica Neue", Arial, sans-serif;
  --gc-bg: #f8fafc;
  --gc-text: #0f172a;
  --gc-accent: #0a7ea4;
  --gc-link-hover: #075985;
  --gc-border: #e2e8f0;
  --gc-muted: #64748b;
  --gc-card-bg: #ffffff;
  --gc-card-border: var(--gc-border);
  --gc-card-shadow: none;
  --gc-padding: 16px;
  --gc-gap: 10px;
  --gc-event-padding: 12px;
  --gc-event-gap: 12px;
  --gc-event-radius: 8px;
  --gc-header-size: 20px;
  --gc-title-size: 16px;
  --gc-meta-size: 13px;
  --gc-date-size: 13px;
  --gc-empty-bg: transparent;
  --gc-empty-border: var(--gc-border);
  --gc-error-text: #b91c1c;
  --gc-error-border: #fecaca;
  --gc-error-bg: #fef2f2;
}

.gaycal-embed {
  font-family: var(--gc-font);
  color: var(--gc-text);
  background: var(--gc-bg);
  border: 1px solid var(--gc-border);
  border-radius: 12px;
  padding: var(--gc-padding);
  max-width: 900px;
}

.gaycal-embed__header {
  display: flex;
  justify-content: space-between;
  gap: 12px;
  align-items: baseline;
  margin-bottom: 12px;
}

.gaycal-embed__title {
  font-size: var(--gc-header-size);
  font-weight: 700;
}

.gaycal-embed__range {
  font-size: 12px;
  color: var(--gc-muted);
}

.gaycal-embed__list {
  display: grid;
  gap: var(--gc-gap);
}

.gaycal-embed--cards .gaycal-embed__list {
  grid-template-columns: repeat(auto-fit, minmax(220px, 1fr));
  gap: 12px;
}

.gaycal-embed__event {
  display: grid;
  grid-template-columns: 120px 1fr;
  gap: var(--gc-event-gap);
  padding: var(--gc-event-padding);
  border: 1px solid var(--gc-card-border);
  border-radius: var(--gc-event-radius);
  background: var(--gc-card-bg);
  box-shadow: var(--gc-card-shadow);
}

.gaycal-embed--cards .gaycal-embed__event {
  grid-template-columns: 1fr;
  gap: 8px;
}

.gaycal-embed__event-image {
  width: 100%;
  aspect-ratio: 16 / 9;
  overflow: hidden;
  border-radius: calc(var(--gc-event-radius) + 2px);
  border: 1px solid var(--gc-card-border);
  background: #e2e8f0;
}

.gaycal-embed__event-image img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
}

.gaycal-embed__event-date {
  font-size: var(--gc-date-size);
  color: var(--gc-muted);
}

.gaycal-embed__event-title {
  font-size: var(--gc-title-size);
  font-weight: 700;
  color: var(--gc-text);
  margin-bottom: 4px;
}

.gaycal-embed__event-meta {
  font-size: var(--gc-meta-size);
  color: var(--gc-muted);
}

.gaycal-embed__event a {
  color: var(--gc-accent);
  text-decoration: none;
}

.gaycal-embed__event a:hover {
  color: var(--gc-link-hover);
  text-decoration: underline;
}

.gaycal-embed__empty {
  font-size: 14px;
  color: var(--gc-muted);
  padding: 12px;
  border: 1px dashed var(--gc-empty-border);
  background: var(--gc-empty-bg);
  border-radius: var(--gc-event-radius);
  text-align: center;
}

.gaycal-embed__error {
  font-size: 14px;
  color: var(--gc-error-text);
  padding: 12px;
  border: 1px solid var(--gc-error-border);
  border-radius: var(--gc-event-radius);
  background: var(--gc-error-bg);
}

.gaycal-embed__loading {
  font-size: 14px;
  color: var(--gc-muted);
  padding: 12px;
  border: 1px solid var(--gc-border);
  border-radius: var(--gc-event-radius);
  text-align: center;
  background: var(--gc-card-bg);
}

.dark .gaycal-embed__error {
  color: #fca5a5;
  border-color: rgba(248, 113, 113, 0.4);
  background: rgba(127, 29, 29, 0.3);
}

.gaycal-embed--compact {
  --gc-padding: 12px;
  --gc-gap: 8px;
  --gc-event-padding: 8px;
  --gc-event-gap: 8px;
  --gc-header-size: 18px;
  --gc-title-size: 14px;
  --gc-meta-size: 12px;
  --gc-date-size: 12px;
}

.gaycal-embed--compact .gaycal-embed__event {
  grid-template-columns: 96px 1fr;
}

@media (max-width: 640px) {
  .gaycal-embed__event {
    grid-template-columns: 1fr;
  }
}
