/* ================================================
   COWBOY EVENT — Standalone dark-theme styles
   ================================================ */

/* --- Variables --- */
:root {
  --ce-bg:          #5c4a3a;
  --ce-bg-alt:      #4e3d2e;
  --ce-bg-footer:   #3e2f22;
  --ce-text:        #fff;
  --ce-text-muted:  #aaa;
  --ce-accent:      #ff9600;
  --ce-accent-hover:#ffb923;
  --ce-font-body:   'Inter', sans-serif;
  --ce-font-display:'Bebas Neue', sans-serif;
  --ce-max-width:   1280px;
  --ce-gap:         24px;
  --ce-radius:      6px;
}

/* --- Scoped base styles (ce- elements only) --- */
main {
  font-family: var(--ce-font-body);
  background: var(--ce-bg);
  color: var(--ce-text);
  line-height: 1.6;
  -webkit-font-smoothing: antialiased;
}

main img { max-width: 100%; height: auto; display: block; }
main a   { color: var(--ce-accent); text-decoration: none; }
main a:hover { color: var(--ce-accent-hover); }

/* --- Container --- */
.ce-container {
  max-width: var(--ce-max-width);
  margin: 0 auto;
  padding: 0 24px;
}

/* ================================================
   HEADER
   ================================================ */
.ce-header {
  position: fixed;
  top: 0; left: 0; right: 0;
  z-index: 1000;
  padding: 16px 0;
  transition: background .3s, padding .3s;
}
.ce-header.scrolled {
  background: rgba(0,0,0,.92);
  backdrop-filter: blur(10px);
  padding: 10px 0;
}
.ce-header__inner {
  max-width: var(--ce-max-width);
  margin: 0 auto;
  padding: 0 24px;
  display: flex;
  align-items: center;
  gap: 32px;
}
.ce-logo img {
  height: 48px;
  width: auto;
}
.ce-nav--desktop ul {
  list-style: none;
  display: flex;
  gap: 28px;
}
.ce-nav--desktop a {
  color: var(--ce-text);
  font-weight: 600;
  font-size: .95rem;
  text-transform: uppercase;
  letter-spacing: .05em;
  transition: color .2s;
}
.ce-nav--desktop a:hover { color: var(--ce-accent); }
.ce-btn--nav {
  margin-left: auto;
}

/* CTA button */
.ce-btn {
  display: inline-block;
  background: var(--ce-accent);
  color: #000;
  font-weight: 700;
  font-size: .95rem;
  padding: 12px 28px;
  border-radius: var(--ce-radius);
  text-transform: uppercase;
  letter-spacing: .04em;
  transition: background .2s;
  border: none;
  cursor: pointer;
}
.ce-btn:hover { background: var(--ce-accent-hover); color: #000; }
.ce-btn-wrap { text-align: center; }

/* Mobile menu toggle */
.ce-menu-toggle {
  display: none;
  background: none; border: none; cursor: pointer;
  flex-direction: column; gap: 5px;
  padding: 4px;
}
.ce-menu-toggle span {
  display: block;
  width: 26px; height: 2px;
  background: #fff;
  transition: transform .3s, opacity .3s;
}
.ce-nav--mobile {
  display: none;
  position: fixed;
  top: 70px; left: 0; right: 0; bottom: 0;
  background: rgba(0,0,0,.96);
  z-index: 999;
}
.ce-nav--mobile ul {
  list-style: none;
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 24px;
  padding-top: 48px;
}
.ce-nav--mobile a {
  color: #fff;
  font-size: 1.25rem;
  font-weight: 600;
  text-transform: uppercase;
}

body.ce-menu-open .ce-nav--mobile { display: block; }
body.ce-menu-open .ce-menu-toggle span:nth-child(1) { transform: translateY(7px) rotate(45deg); }
body.ce-menu-open .ce-menu-toggle span:nth-child(2) { opacity: 0; }
body.ce-menu-open .ce-menu-toggle span:nth-child(3) { transform: translateY(-7px) rotate(-45deg); }

/* ================================================
   HERO
   ================================================ */
.ce-hero {
  position: relative;
  width: 100%;
  height: 100vh;
  overflow: hidden;
}
.ce-hero__bg {
  position: absolute;
  inset: 0;
  width: 100%; height: 100%;
  object-fit: cover;
}
.ce-hero__overlay {
  position: absolute;
  inset: 0;
  z-index: 2;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  padding-top: 20%;
  text-align: center;
}
.ce-hero__heading {
  font-family: var(--ce-font-display);
  font-size: clamp(3rem, 8vw, 7rem);
  line-height: 1;
  text-transform: uppercase;
  margin-bottom: 16px;
}
.ce-hero__sub {
  font-size: 1.25rem;
  color: var(--ce-text-muted);
  margin-bottom: 32px;
}
.ce-btn--hero {
  font-size: 1.1rem;
  padding: 16px 40px;
}

/* ================================================
   SECTIONS
   ================================================ */
.ce-section {
  padding: 80px 0;
}

/* Headings */
.ce-heading {
  font-family: var(--ce-font-display);
  font-size: clamp(2rem, 5vw, 3.5rem);
  text-transform: uppercase;
  text-align: center;
  letter-spacing: .04em;
  margin-bottom: 40px;
}

/* Text */
.ce-text {
  max-width: 800px;
  margin: 0 auto;
  text-align: center;
  font-size: 1.05rem;
  line-height: 1.8;
  color: var(--ce-text-muted);
}
.ce-text .ce-heading {
  color: var(--ce-text);
}

/* Tagline */
.ce-tagline {
  padding: 40px 0;
}
.ce-tagline__text {
  text-align: center;
  font-family: var(--ce-font-display);
  font-size: clamp(1.2rem, 3vw, 1.8rem);
  text-transform: uppercase;
  letter-spacing: .12em;
  color: var(--ce-accent);
}

/* ================================================
   COUNTDOWN
   ================================================ */
.ce-section--countdown {
  padding: 60px 0;
}
.ce-countdown {
  display: flex;
  justify-content: center;
  gap: 32px;
  flex-wrap: wrap;
}
.ce-countdown__block {
  text-align: center;
  min-width: 100px;
}
.ce-countdown__num {
  display: block;
  font-family: var(--ce-font-display);
  font-size: clamp(3rem, 8vw, 5rem);
  line-height: 1;
  color: var(--ce-accent);
}
.ce-countdown__label {
  display: block;
  font-size: .85rem;
  text-transform: uppercase;
  letter-spacing: .1em;
  color: var(--ce-text-muted);
  margin-top: 8px;
}

/* ================================================
   GRID
   ================================================ */
.ce-grid {
  display: grid;
  gap: var(--ce-gap);
}
.ce-grid--4col { grid-template-columns: repeat(4, 1fr); }
.ce-grid--3col { grid-template-columns: repeat(3, 1fr); }
.ce-grid--2col { grid-template-columns: repeat(2, 1fr); }

/* ================================================
   ARTIST CARDS
   ================================================ */
.ce-artist {
  display: block;
  text-decoration: none;
  color: var(--ce-text);
  transition: transform .3s;
}
.ce-artist:hover { transform: translateY(-6px); color: var(--ce-text); }
.ce-artist__img-wrap {
  position: relative;
  border-radius: var(--ce-radius);
  overflow: hidden;
  aspect-ratio: 3 / 2;
}
.ce-artist__img-wrap img {
  width: 100%; height: 100%;
  object-fit: cover;
  transition: transform .4s;
}
.ce-artist:hover .ce-artist__img-wrap img { transform: scale(1.05); }
.ce-artist__overlay {
  position: absolute;
  inset: 0;
  background: rgba(0,0,0,.65);
  display: flex;
  align-items: center;
  justify-content: center;
  opacity: 0;
  transition: opacity .3s;
}
.ce-artist:hover .ce-artist__overlay { opacity: 1; }
.ce-artist__name {
  font-family: var(--ce-font-display);
  font-size: 1.4rem;
  text-transform: uppercase;
  letter-spacing: .04em;
  text-align: center;
  padding: 0 12px;
}

/* ================================================
   GALLERY
   ================================================ */
.ce-gallery {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 8px;
}
.ce-gallery__item {
  aspect-ratio: 1;
  overflow: hidden;
  border-radius: 4px;
}
.ce-gallery__item img {
  width: 100%; height: 100%;
  object-fit: cover;
  transition: transform .4s, opacity .3s;
}
.ce-gallery__item:hover img {
  transform: scale(1.08);
  opacity: .85;
}

/* ================================================
   IMAGE
   ================================================ */
.ce-img {
  width: 100%;
  border-radius: var(--ce-radius);
}
.ce-section--full .ce-img { border-radius: 0; }

/* ================================================
   DIVIDER
   ================================================ */
.ce-divider {
  border: none;
  border-top: 1px solid #333;
  margin: 0;
}

/* ================================================
   SPONSORS
   ================================================ */
.ce-sponsors {
  padding: 48px 0;
  background: var(--ce-bg-footer);
  border-top: 1px solid #222;
}
.ce-sponsors__track {
  display: flex;
  align-items: center;
  justify-content: center;
  flex-wrap: wrap;
  gap: 40px;
}
.ce-sponsors__item img {
  height: 48px;
  width: auto;
  filter: brightness(0) invert(.6);
  transition: filter .3s;
}
.ce-sponsors__item img:hover {
  filter: brightness(0) invert(1);
}

/* ================================================
   FOOTER
   ================================================ */
.ce-footer__main {
  background: var(--ce-bg-footer);
  padding: 40px 0;
  text-align: center;
}
.ce-footer__social {
  display: flex;
  justify-content: center;
  gap: 20px;
  margin-bottom: 24px;
}
.ce-footer__social a {
  color: var(--ce-text-muted);
  transition: color .2s;
}
.ce-footer__social a:hover { color: var(--ce-accent); }
.ce-footer__social svg { width: 24px; height: 24px; fill: currentColor; }

.ce-footer__links {
  display: flex;
  justify-content: center;
  flex-wrap: wrap;
  gap: 8px 24px;
  margin-bottom: 24px;
}
.ce-footer__links a {
  font-size: .85rem;
  color: var(--ce-text-muted);
}
.ce-footer__links a:hover { color: var(--ce-text); }

.ce-footer__copy {
  font-size: .8rem;
  color: #555;
}

/* ================================================
   RESPONSIVE
   ================================================ */
@media (max-width: 1024px) {
  .ce-grid--4col { grid-template-columns: repeat(2, 1fr); }
  .ce-gallery   { grid-template-columns: repeat(3, 1fr); }
}

@media (max-width: 767px) {
  .ce-nav--desktop { display: none; }
  .ce-btn--nav     { display: none; }
  .ce-menu-toggle  { display: flex; margin-left: auto; }

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

  .ce-gallery { grid-template-columns: repeat(2, 1fr); }

  .ce-section  { padding: 48px 0; }
  .ce-hero     { min-height: 80vh; }
  .ce-countdown { gap: 16px; }
  .ce-countdown__block { min-width: 70px; }
}
