:root {
	      --bg: #101014;
      --card: #1a1a22;
      --soft: #3d3d47;

      --text: #d0d1db;

      --muted: #9a9aa5;

      --border: #2a2a34;

      --accent: #e6e6e6;

      --max-width: 1400px;

      --radius: 18px;
  --pico-font-size: 100%;
  --pico-border-radius: 16px;
  --pico-spacing: 1rem;
}
html {
      background: var(--bg);
    }
body {
background: var(--bg);

      color: var(--text);

      font-family: "Open Sans", sans-serif;

      margin: 0;

      padding: 0;
}

/* layout */

    main {

      width: min(100% - 32px, var(--max-width));

      margin-inline: auto;

      padding-block: 40px;

    }
	    header {

      border-bottom: 1px solid var(--border);

      background: rgba(16,16,20,.92);

      backdrop-filter: blur(12px);

      position: sticky;

      top: 0;

      z-index: 1000;

    }
	    .nav {

      width: min(100% - 32px, var(--max-width));

      margin-inline: auto;

      display: flex;

      justify-content: space-between;

      align-items: center;

      padding: 18px 0;

    }

/* hero */

    .hero {

      padding: 80px 0 50px;

    }

    .hero h1 {

      font-size: clamp(2.8rem, 6vw, 5rem);

      line-height: 1;

      margin-bottom: 16px;

      max-width: 900px;

    }

    .hero p {

      font-size: 1.1rem;

      color: var(--muted);

      max-width: 720px;

    }
/* search */
    .search-form {

      margin-top: 32px;

      display: flex;

      gap: 12px;

      flex-wrap: wrap;

    }

    .search-form input {

      background: var(--card);

      border: 1px solid var(--border);

      color: var(--text);

      border-radius: 999px;

      padding: 14px 20px;

    }

    .search-form button {

      background: var(--accent);

      color: #101014;

      border: none;

      border-radius: 999px;

      font-weight: 700;

      padding: 14px 22px;

    }
/* sections */

 section {
      margin-top: 70px;
    }

    .section-header {

      display: flex;

      justify-content: space-between;

      align-items: center;

      margin-bottom: 24px;

    }
    .section-header h2 {

      margin: 0;

      font-size: 1.6rem;

    }
	
/* grids */

    .events-grid,
    .country-grid,
    .city-grid,
    .artist-grid {

      display: grid;

      grid-template-columns:
        repeat(auto-fill, minmax(260px, 1fr));

      gap: 24px;

    }
	
/* cards */

    .event-card,
    .country-card,
    .city-card,
    .artist-card {

      background: var(--card);

      border: 1px solid var(--border);

      border-radius: var(--radius);

      overflow: hidden;

      transition: 0.25s ease;

    }

    .event-card:hover,
    .country-card:hover,
    .city-card:hover,
    .artist-card:hover {

      transform: translateY(-4px);

      border-color: var(--soft);

    }

    .event-content {

      padding: 18px;

    }

    .event-content h3 {

      margin-top: 0;

      margin-bottom: 10px;

      font-size: 1.1rem;

      line-height: 1.4;

    }

    .event-content p {

      margin: 6px 0;

      color: var(--muted);

      font-size: .95rem;

    }

/* IMPORTANT - 16:9 IMAGES */

    .event-card img {

      width: 100%;

      aspect-ratio: 16 / 9;

      object-fit: cover;

      display: block;

    }

/* country/city cards */

    .country-card,
    .city-card,
    .artist-card {

      padding: 22px;

      display: flex;

      flex-direction: column;

      gap: 10px;

    }
	
	    .country-card small,
    .city-card small,
    .artist-card small {

      color: var(--muted);

    }

.country-card:hover,
.city-card:hover,
.artist-card:hover {
  transform: translateY(-4px);
}

.country-card span,
.city-card span,
.artist-card span {
  display: block;
  font-weight: 700;
  margin-bottom: 0.4rem;
}

/* links */

a {
 color: var(--accent);

      text-decoration: none;

      transition: 0.2s ease;
}

a:hover {
  opacity: 0.8;
}


/* EVENT PAGE */

.event-hero {
  display: grid;
  grid-template-columns: 1.2fr 1fr;
  gap: 2rem;
  margin: 3rem 0;
  align-items: center;
}

.event-hero-image img {
  width: 100%;
  aspect-ratio: 16 / 9;
  object-fit: cover;
  border-radius: 24px;
  display: block;
}

.event-hero-content h1 {
  font-size: 3rem;
  margin: 1rem 0;
  line-height: 1.1;
}

.event-artist {
  color: #ff6b6b;
  font-weight: 700;
  text-decoration: none;
  font-size: 1rem;
  text-transform: uppercase;
  letter-spacing: 1px;
}

.event-meta {
  display: grid;
  gap: 1rem;
  margin: 2rem 0;
}

.meta-item {
  background: #181b22;
  border: 1px solid #242833;
  border-radius: 16px;
  padding: 1rem;
}

.meta-item small {
  display: block;
  color: #8f96a8;
  margin-bottom: 0.35rem;
}

.meta-item strong {
  font-size: 1.05rem;
}

.primary-button {
  display: inline-block;
  background: #ff4d4d;
  color: white;
  padding: 1rem 1.4rem;
  border-radius: 14px;
  font-weight: 700;
  text-decoration: none;
}

.primary-button:hover {
  opacity: 0.9;
  text-decoration: none;
}

.event-details {
  margin: 4rem 0;
}

.detail-card {
  background: #181b22;
  border: 1px solid #242833;
  border-radius: 24px;
  padding: 2rem;
  margin-bottom: 2rem;
}

.related-grid {
  display: grid;
  gap: 1rem;
}

.related-card {
  display: grid;
  grid-template-columns: 140px 1fr;
  gap: 1rem;
  align-items: center;
  text-decoration: none;
}

.related-card img {
  width: 100%;
  aspect-ratio: 16 / 9;
  object-fit: cover;
  border-radius: 14px;
}

.related-card small {
  display: block;
  margin-top: 0.35rem;
  color: #9aa2b4;
}

   footer {

      margin-top: 100px;

      border-top: 1px solid var(--border);

      padding: 40px 0;

      color: var(--muted);

    }

/* mobile */

@media (max-width: 768px) {
	
	 .hero {
        padding-top: 40px;
      }

  .hero h1 {
    font-size: 2rem;
  }

  .events-grid {
    grid-template-columns: 1fr;
  }

}

@media (max-width: 900px) {

  .event-hero {
    grid-template-columns: 1fr;
  }

  .event-hero-content h1 {
    font-size: 2rem;
  }

  .related-card {
    grid-template-columns: 1fr;
  }

}