/* ==========================================================================
   Red61 VIA Events — Frontend Styles
   ========================================================================== */

:root {
  --red61-accent:       #c0392b;
  --red61-accent-dark:  #962d22;
  --red61-text:         #1a1a1a;
  --red61-text-muted:   #5a5a5a;
  --red61-border:       #e2e2e2;
  --red61-bg:           #ffffff;
  --red61-bg-hover:     #fafafa;
  --red61-radius:       10px;
  --red61-shadow:       0 2px 12px rgba(0,0,0,0.08);
  --red61-shadow-hover: 0 6px 24px rgba(0,0,0,0.14);
  --red61-transition:   0.2s ease;
  --red61-badge-bg:     #f0f0f0;
}

/* --------------------------------------------------------------------------
   Grid layout
   -------------------------------------------------------------------------- */

.red61-events--grid {
  display:               grid;
  gap:                   1.5rem;
  grid-template-columns: repeat(3, 1fr);
}

.red61-cols-1 { grid-template-columns: 1fr; }
.red61-cols-2 { grid-template-columns: repeat(2, 1fr); }
.red61-cols-3 { grid-template-columns: repeat(3, 1fr); }
.red61-cols-4 { grid-template-columns: repeat(4, 1fr); }

@media (max-width: 900px) {
  .red61-cols-3,
  .red61-cols-4 { grid-template-columns: repeat(2, 1fr); }
}

@media (max-width: 600px) {
  .red61-events--grid { grid-template-columns: 1fr; }
}

/* --------------------------------------------------------------------------
   Card
   -------------------------------------------------------------------------- */

.red61-event-card {
  background:     var(--red61-bg);
  border:         1px solid var(--red61-border);
  border-radius:  var(--red61-radius);
  box-shadow:     var(--red61-shadow);
  display:        flex;
  flex-direction: column;
  overflow:       hidden;
  transition:     box-shadow var(--red61-transition),
                  transform  var(--red61-transition);
}

.red61-event-card:hover {
  box-shadow: var(--red61-shadow-hover);
  transform:  translateY(-3px);
}

/* Image area */
.red61-card__image {
  aspect-ratio: 16 / 9;
  overflow:     hidden;
  background:   #f5f5f5;
}

.red61-card__image img {
  width:      100%;
  height:     100%;
  object-fit: cover;
  display:    block;
  transition: transform 0.4s ease;
}

.red61-event-card:hover .red61-card__image img {
  transform: scale(1.04);
}

/* Placeholder image */
.red61-card__image--placeholder {
  display:         flex;
  align-items:     center;
  justify-content: center;
  background:      linear-gradient(135deg, #f5f5f5, #e8e8e8);
}

.red61-placeholder-icon {
  font-size: 3rem;
  opacity:   0.4;
}

/* Body */
.red61-card__body {
  padding: 1.2rem;
  flex:    1;
  display: flex;
  flex-direction: column;
  gap:     0.5rem;
}

/* Badge */
.red61-badge {
  display:          inline-block;
  padding:          0.2em 0.7em;
  background:       var(--red61-badge-bg);
  border-radius:    100px;
  font-size:        0.72rem;
  font-weight:      600;
  text-transform:   uppercase;
  letter-spacing:   0.05em;
  color:            var(--red61-text-muted);
  margin-bottom:    0.1rem;
}

/* Title */
.red61-card__title {
  font-size:   1.05rem;
  font-weight: 700;
  line-height: 1.3;
  color:       var(--red61-text);
  margin:      0;
}

/* Subtitle */
.red61-card__subtitle {
  font-size:   0.88rem;
  color:       var(--red61-text-muted);
  font-style:  italic;
  margin:      0;
}

/* Description */
.red61-card__description {
  font-size:   0.88rem;
  color:       var(--red61-text-muted);
  line-height: 1.5;
  margin:      0;
  flex:        1;
}

/* Meta */
.red61-card__meta {
  display:    flex;
  flex-wrap:  wrap;
  gap:        0.4rem 1rem;
  font-size:  0.8rem;
  color:      var(--red61-text-muted);
  margin-top: auto;
  padding-top: 0.5rem;
}

.red61-meta-item {
  display:     flex;
  align-items: center;
  gap:         0.3em;
}

.red61-meta-item svg {
  width:  12px;
  height: 12px;
  fill:   currentColor;
  flex-shrink: 0;
}

/* Performances list */
.red61-performances {
  list-style: none;
  padding:    0;
  margin:     0.5rem 0 0;
  font-size:  0.82rem;
  display:    flex;
  flex-direction: column;
  gap:        0.25rem;
}

.red61-perf {
  padding:       0.3em 0.6em;
  background:    var(--red61-bg-hover);
  border-left:   3px solid var(--red61-accent);
  border-radius: 0 4px 4px 0;
}

.red61-perf a {
  color:           var(--red61-accent);
  text-decoration: none;
  font-weight:     500;
}

.red61-perf a:hover {
  text-decoration: underline;
}

.red61-perf--soldout {
  opacity:     0.55;
  border-color: #aaa;
}

.red61-perf--more {
  font-style:  italic;
  color:       var(--red61-text-muted);
  border-color: transparent;
  background:   transparent;
  padding-left: 0;
}

/* CTA Button */
.red61-btn {
  display:         block;
  margin:          1rem 1.2rem 1.2rem;
  padding:         0.75em 1.2em;
  background:      var(--red61-accent);
  color:           #fff !important;
  text-align:      center;
  text-decoration: none;
  border-radius:   6px;
  font-size:       0.9rem;
  font-weight:     600;
  letter-spacing:  0.02em;
  transition:      background var(--red61-transition),
                   transform  var(--red61-transition);
  border:          none;
  cursor:          pointer;
}

.red61-btn:hover {
  background: var(--red61-accent-dark);
  transform:  translateY(-1px);
}

/* --------------------------------------------------------------------------
   List layout
   -------------------------------------------------------------------------- */

.red61-events--list {
  display:        flex;
  flex-direction: column;
  gap:            1rem;
}

.red61-event-row {
  display:       flex;
  gap:           1.2rem;
  align-items:   center;
  background:    var(--red61-bg);
  border:        1px solid var(--red61-border);
  border-radius: var(--red61-radius);
  box-shadow:    var(--red61-shadow);
  padding:       1rem;
  transition:    box-shadow var(--red61-transition);
}

.red61-event-row:hover {
  box-shadow: var(--red61-shadow-hover);
}

.red61-row__thumb {
  width:         90px;
  height:        68px;
  flex-shrink:   0;
  border-radius: 6px;
  overflow:      hidden;
}

.red61-row__thumb img {
  width:      100%;
  height:     100%;
  object-fit: cover;
}

.red61-row__body {
  flex:    1;
  min-width: 0;
}

.red61-row__header {
  display:     flex;
  align-items: center;
  gap:         0.5rem;
  flex-wrap:   wrap;
}

.red61-row__title {
  font-size:   1rem;
  font-weight: 700;
  margin:      0;
  color:       var(--red61-text);
}

.red61-row__description {
  font-size:   0.84rem;
  color:       var(--red61-text-muted);
  margin:      0.3rem 0 0;
  line-height: 1.5;
}

.red61-row__action {
  flex-shrink: 0;
}

.red61-row__action .red61-btn {
  margin: 0;
  white-space: nowrap;
}

@media (max-width: 600px) {
  .red61-event-row {
    flex-wrap: wrap;
  }
  .red61-row__action {
    width: 100%;
  }
  .red61-row__action .red61-btn {
    display: block;
  }
}

/* --------------------------------------------------------------------------
   States: error / no-events
   -------------------------------------------------------------------------- */

.red61-notice {
  padding:       1rem 1.2rem;
  border-radius: 6px;
  font-size:     0.9rem;
}

.red61-notice--error {
  background:  #fff5f5;
  border:      1px solid #fcc;
  color:       #c0392b;
}

.red61-no-events {
  color:      var(--red61-text-muted);
  font-style: italic;
  text-align: center;
  padding:    2rem 0;
}
