/*
 * tonleikar.css
 * Styles for the Tónleikar custom post type.
 * Place in your plugin folder (next to tonleikar-cpt.php)
 * or copy into your theme's style.css / theme.json stylesheet.
 *
 * These are sensible defaults – override freely with your theme tokens.
 * CSS custom properties are used so your theme can override them easily.
 */

/* ── Design tokens ─────────────────────────────────────── */
:root {
  --skimo-raudur: #cc0706;
  --skimo-dokkur: #202020;
  --skimo-ljos: #dfdfdf;
  --tlk-accent: #c8102e; /* Change to your brand colour */
  --tlk-accent-hover: #a00d25;
  --tlk-text: #1a1a1a;
  --tlk-muted: #6b6b6b;
  --tlk-border: #e0e0e0;
  --tlk-bg-row: #ffffff;
  --tlk-bg-row-alt: #f9f9f9;
  --tlk-radius: 6px;
  --tlk-font: inherit; /* inherits from your theme */
}

/* ══════════════════════════════════════════════════════════
 * COMPACT LISTING  (shortcode [upcoming_shows] / front page)
 * ══════════════════════════════════════════════════════════ */

.tonleikar-upcoming-list {
  display: flex;
  flex-direction: column;
  gap: 0;
  font-family: var(--tlk-font);
  /* border: 1px solid #202020; */
  border-radius: 14px;
  overflow: hidden;
}

.tonleikar-show-row {
  display: grid;
  grid-template-columns: minmax(120px, 160px) 1fr auto;
  align-items: center;
  gap: 16px;
  padding: 1.5rem 0.5rem;
  background: #dfdfdf;
  color: var(--skimo-dokkur);
  border-bottom: 1px solid var(--skimo-dokkur);
  transition: background 0.15s ease;
}

.tonleikar-show-row:last-child {
  border-bottom: none;
}

/* .tonleikar-show-row:nth-child(even) {
  background: var(--tlk-bg-row-alt);
} */

.tonleikar-show-row:hover {
  background: var(--skimo-raudur);
  color: var(--skimo-ljos);
  a {
    color: var(--skimo-ljos);
  }
  .tonleikar-ticket-btn {
    background-color: var(--skimo-dokkur);
    color: var(--skimo-ljos);
  }
}

/* Date column */
.show-date {
  font-weight: 700;
  font-size: 1.8rem;
  /* color: #202020; */
  line-height: 1.3;
}

.show-date time {
  display: flex;
  flex-direction: column;
}

.show-time {
  font-weight: 400;
  font-size: 0.8rem;
  color: var(--tlk-muted);
  margin-top: 2px;
}

/* Info column */
.show-info {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: 10px 14px;
}

.show-title {
  font-weight: 600;
  font-size: 2.4rem;
  /* color: #202020; */
  text-decoration: none;
  flex: 0 0 100%;
}

.show-title:hover {
  /* color: var(--tlk-accent); */
  text-decoration: underline;
}

.show-venue,
.show-location {
  font-size: 1.125rem;
  /* color: #202020; */
}

.show-venue::after {
  content: "·";
  margin-left: 14px;
  color: var(--tlk-border);
}

/* Ticket button */
.tonleikar-ticket-btn {
  display: inline-block;
  padding: 8px 16px;
  background: var(--skimo-raudur);
  color: var(--skimo-ljos) !important;
  font-size: 0.82rem;
  font-weight: 700;
  text-decoration: none !important;
  border-radius: var(--tlk-radius);
  white-space: nowrap;
  letter-spacing: 0.03em;
  text-transform: uppercase;
  transition:
    background 0.2s ease,
    transform 0.1s ease;
}

.tonleikar-ticket-btn:hover {
  background: var(--skimo-dokkur);
  color: var(--skimo-ljos);
  transform: translateY(-1px);
}

.tonleikar-no-shows {
  color: var(--tlk-muted);
  font-style: italic;
}

/* ══════════════════════════════════════════════════════════
 * ARCHIVE PAGE  (archive-tonleikar.html / Query Loop)
 * ══════════════════════════════════════════════════════════ */

.tonleikar-archive-item {
  display: grid;
  grid-template-columns: minmax(120px, 160px) 1fr auto;
  align-items: center;
  gap: 20px;
  padding: 20px 24px;
  border: 1px solid var(--tlk-border);
  border-radius: var(--tlk-radius);
  background: var(--tlk-bg-row);
  margin-bottom: 12px;
  transition: box-shadow 0.2s ease;
}

.tonleikar-archive-item:hover {
  box-shadow: 0 4px 18px rgba(0, 0, 0, 0.08);
}

/* ══════════════════════════════════════════════════════════
 * SINGLE SHOW PAGE
 * ══════════════════════════════════════════════════════════ */

.tonleikar-single-meta {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(200px, 1fr));
  gap: 16px;
  padding: 24px;
  background: var(--tlk-bg-row-alt);
  border: 1px solid var(--tlk-border);
  border-radius: var(--tlk-radius);
  margin-bottom: 32px;
}

.tonleikar-meta-item {
  display: flex;
  flex-direction: column;
  gap: 4px;
}

.tonleikar-meta-label {
  font-size: 0.75rem;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.08em;
  color: var(--tlk-muted);
}

.tonleikar-meta-value {
  font-size: 1rem;
  font-weight: 600;
  color: var(--tlk-text);
}

.tonleikar-single-ticket {
  margin-top: 24px;
}

.tonleikar-single-ticket .tonleikar-ticket-btn {
  font-size: 1rem;
  padding: 12px 28px;
}

/* ══════════════════════════════════════════════════════════
 * RESPONSIVE
 * ══════════════════════════════════════════════════════════ */

@media (max-width: 640px) {
  .tonleikar-show-row,
  .tonleikar-archive-item {
    grid-template-columns: 1fr;
    gap: 10px;
  }

  .show-ticket {
    justify-self: start;
  }

  .tonleikar-ticket-btn {
    width: 100%;
    text-align: center;
  }
}

@media (min-width: 782px) {
  .tonleikar-show-row {
    padding: 2rem 3rem;
  }
  .show-info {
    margin-left: 10%;
  }
}
