/* contests.css — NovaSounds Inaugural Contest */

/* HERO FIX: No min-height, content renders immediately */
.contest-hero {
  position: relative;
  overflow: hidden;
  background: var(--card);
  border: 1px solid var(--border);
  border-radius: var(--radius-xl);
  padding: 56px 48px 48px;
  margin-bottom: 24px;
  text-align: center;
}
.hero-glow {
  position: absolute;
  width: 340px; height: 340px;
  border-radius: 50%;
  filter: blur(90px);
  pointer-events: none;
  z-index: 0;
}
.hero-glow-left  { background: rgba(212,168,67,0.1);  top:-80px; left:-80px; }
.hero-glow-right { background: rgba(46,184,164,0.08); bottom:-80px; right:-80px; }
.contest-hero > *:not(.hero-glow) { position: relative; z-index: 1; }

.hero-eyebrow {
  display: inline-flex; align-items: center; gap: 8px;
  font-family: var(--mono); font-size: 11px; letter-spacing: 2px;
  text-transform: uppercase; color: var(--gold);
  background: rgba(212,168,67,0.1); border: 1px solid rgba(212,168,67,0.25);
  padding: 6px 16px; border-radius: 20px; margin-bottom: 24px;
}
.live-dot {
  width: 7px; height: 7px; background: var(--gold);
  border-radius: 50%; flex-shrink: 0;
  animation: pulse-dot 2s ease-in-out infinite;
}
@keyframes pulse-dot { 0%,100%{opacity:1;transform:scale(1)} 50%{opacity:0.4;transform:scale(0.6)} }

.hero-title {
  font-family: var(--serif);
  font-size: clamp(2.4rem, 5vw, 4rem);
  font-weight: 700; color: var(--ink);
  line-height: 1.1; margin-bottom: 18px; letter-spacing: -0.02em;
}
.hero-title em {
  font-style: italic;
  background: linear-gradient(135deg, var(--gold), var(--teal));
  -webkit-background-clip: text; -webkit-text-fill-color: transparent; background-clip: text;
}
.hero-sub { font-size: 14px; color: var(--ink2); max-width: 520px; margin: 0 auto 36px; line-height: 1.75; }

/* Countdown */
.countdown-wrap { margin-bottom: 36px; }
.countdown-label { font-family: var(--mono); font-size: 11px; letter-spacing: 2px; text-transform: uppercase; color: var(--ink3); margin-bottom: 14px; }
.countdown-grid { display: inline-flex; align-items: center; gap: 8px; flex-wrap: wrap; justify-content: center; }
.countdown-unit { background: var(--surface); border: 1px solid var(--border); border-radius: var(--radius-md); padding: 14px 20px; min-width: 74px; text-align: center; }
.countdown-num { font-family: var(--serif); font-size: 2.1rem; font-weight: 700; color: var(--gold); line-height: 1; font-variant-numeric: tabular-nums; }
.countdown-lbl { font-family: var(--mono); font-size: 10px; letter-spacing: 1.5px; text-transform: uppercase; color: var(--ink3); margin-top: 5px; }
.countdown-sep { font-family: var(--serif); font-size: 1.8rem; color: var(--border2); font-weight: 700; margin-bottom: 18px; }

/* Date strip */
.hero-dates { display: inline-flex; align-items: stretch; background: var(--surface); border: 1px solid var(--border); border-radius: var(--radius-lg); overflow: hidden; flex-wrap: wrap; }
.hero-date-item { display: flex; align-items: center; gap: 11px; padding: 15px 22px; text-align: left; }
.hero-date-divider { width: 1px; background: var(--border); flex-shrink: 0; }
.hero-date-icon { font-size: 1.3rem; }
.hero-date-label { font-family: var(--mono); font-size: 10px; letter-spacing: 1px; text-transform: uppercase; color: var(--ink3); margin-bottom: 2px; }
.hero-date-val { font-family: var(--serif); font-size: 0.95rem; font-weight: 600; color: var(--ink); }

/* Tag Notice */
.tag-notice {
  display: flex; align-items: flex-start; gap: 14px;
  background: rgba(212,168,67,0.07); border: 1.5px solid rgba(212,168,67,0.3);
  border-radius: var(--radius-lg); padding: 18px 22px; margin-bottom: 28px;
  font-size: 13px; color: var(--ink2); line-height: 1.65;
}
.tag-notice-icon { font-size: 1.4rem; flex-shrink: 0; margin-top: 1px; }
.tag-notice strong { color: var(--ink); }
.tag-notice em { color: var(--crimson); font-style: normal; font-weight: 600; }
.tag-chip {
  display: inline-block; background: rgba(212,168,67,0.15);
  border: 1px solid rgba(212,168,67,0.35); color: var(--gold);
  font-family: var(--mono); font-size: 12px; padding: 2px 10px;
  border-radius: 4px; font-weight: 600;
}

/* Tabs */
.contest-tabs { display: flex; gap: 4px; margin-bottom: 28px; border-bottom: 1px solid var(--border); overflow-x: auto; }
.ctab-btn { padding: 12px 18px; border: none; background: transparent; color: var(--ink3); font-size: 13px; font-weight: 500; cursor: pointer; border-bottom: 2px solid transparent; margin-bottom: -1px; transition: all var(--transition); white-space: nowrap; }
.ctab-btn:hover { color: var(--ink); }
.ctab-btn.active { color: var(--ink); border-bottom-color: var(--gold); }

/* Layout */
.contest-layout { display: grid; grid-template-columns: 1fr 296px; gap: 22px; align-items: start; }

/* Contest Card */
.contest-card { background: var(--card); border: 1px solid var(--border); border-radius: var(--radius-lg); padding: 30px; margin-bottom: 20px; }
.contest-card-header { display: flex; align-items: flex-start; gap: 16px; margin-bottom: 28px; padding-bottom: 22px; border-bottom: 1px solid var(--border); }
.contest-card-icon { font-size: 2.5rem; line-height: 1; flex-shrink: 0; }
.contest-card-header h2 { font-family: var(--serif); font-size: 1.65rem; font-weight: 700; color: var(--ink); margin-bottom: 3px; }
.contest-card-header p { font-size: 13px; color: var(--ink3); }
.rules-section { padding: 20px 0; border-bottom: 1px solid var(--border); }
.rules-section:last-child { border-bottom: none; padding-bottom: 0; }
.rules-section:first-of-type { padding-top: 0; }
.rules-heading { display: flex; align-items: center; gap: 12px; font-family: var(--serif); font-size: 1.1rem; font-weight: 600; color: var(--ink); margin-bottom: 9px; }
.rules-num { font-family: var(--mono); font-size: 10px; letter-spacing: 1px; color: var(--gold); background: rgba(212,168,67,0.1); border: 1px solid rgba(212,168,67,0.2); padding: 2px 7px; border-radius: 4px; flex-shrink: 0; }
.rules-body { font-size: 13px; color: var(--ink2); line-height: 1.75; }
.rules-body strong { color: var(--ink); font-weight: 600; }

/* Timeline */
.timeline-card { background: var(--card); border: 1px solid var(--border); border-radius: var(--radius-lg); padding: 26px 30px; }
.section-mini-title { font-family: var(--serif); font-size: 1rem; font-weight: 600; color: var(--ink); margin-bottom: 22px; }
.timeline { display: flex; flex-direction: column; position: relative; padding-left: 22px; }
.timeline::before { content:''; position:absolute; left:6px; top:10px; bottom:10px; width:2px; background:var(--border2); }
.timeline-item { display:flex; gap:20px; position:relative; padding-bottom:22px; }
.timeline-item:last-child { padding-bottom:0; }
.timeline-dot { width:14px; height:14px; border-radius:50%; flex-shrink:0; position:absolute; left:-18px; top:3px; border:2px solid; z-index:1; }
.timeline-item.done     .timeline-dot { background:var(--gold);    border-color:var(--gold); }
.timeline-item.upcoming .timeline-dot { background:var(--teal);    border-color:var(--teal); box-shadow:0 0 8px rgba(46,184,164,0.5); }
.timeline-item.future   .timeline-dot { background:var(--surface); border-color:var(--border2); }
.timeline-content { flex:1; }
.timeline-title { font-size:14px; font-weight:600; color:var(--ink); margin-bottom:2px; }
.timeline-date { font-family:var(--mono); font-size:11px; margin-bottom:4px; }
.timeline-item.done     .timeline-date { color:var(--gold); }
.timeline-item.upcoming .timeline-date { color:var(--teal); }
.timeline-item.future   .timeline-date { color:var(--ink3); }
.timeline-desc { font-size:12px; color:var(--ink3); line-height:1.6; }

/* Prize Card */
.prize-card { background:var(--card); border:1px solid var(--border); border-radius:var(--radius-lg); padding:22px; margin-bottom:14px; text-align:center; }
.prize-card-title { font-family:var(--mono); font-size:10px; letter-spacing:1.5px; text-transform:uppercase; color:var(--ink3); margin-bottom:10px; }
.prize-total { font-family:var(--serif); font-size:2.7rem; font-weight:700; color:var(--gold); line-height:1; }
.prize-total-lbl { font-size:11px; color:var(--ink3); margin:4px 0 18px; }
.prize-list { display:flex; flex-direction:column; gap:9px; margin-bottom:14px; }
.prize-row { display:flex; align-items:center; justify-content:space-between; padding:10px 13px; border-radius:var(--radius-sm); border:1px solid; }
.prize-gold   { background:rgba(212,168,67,0.08);   border-color:rgba(212,168,67,0.25); }
.prize-silver { background:rgba(180,180,200,0.05);  border-color:rgba(180,180,200,0.18); }
.prize-rank { display:flex; align-items:center; gap:7px; font-size:13px; font-weight:600; color:var(--ink); }
.prize-medal { font-size:1.05rem; }
.prize-amount { font-family:var(--serif); font-size:1.1rem; font-weight:700; color:var(--gold); }
.cert-banner { display:flex; align-items:flex-start; gap:11px; background:rgba(46,184,164,0.07); border:1px solid rgba(46,184,164,0.2); border-radius:var(--radius-sm); padding:11px 13px; text-align:left; margin-bottom:12px; }
.cert-icon { font-size:1.35rem; flex-shrink:0; }
.cert-title { font-size:12px; font-weight:600; color:var(--teal); margin-bottom:2px; }
.cert-desc { font-size:11px; color:var(--ink3); line-height:1.5; }
.prize-note { font-size:11px; color:var(--ink3); line-height:1.5; padding-top:12px; border-top:1px solid var(--border); font-style:italic; }

/* Eligibility */
.eligibility-card { background:var(--card); border:1px solid var(--border); border-radius:var(--radius-lg); padding:20px 22px; margin-bottom:14px; }
.eligibility-card h3 { font-size:12px; font-weight:600; color:var(--ink); margin-bottom:13px; }
.eligibility-list { list-style:none; display:flex; flex-direction:column; gap:8px; }
.eligibility-list li { display:flex; align-items:flex-start; gap:8px; font-size:12px; color:var(--ink2); line-height:1.5; }
.eligibility-list li strong { color:var(--ink); }
.eli-check { color:var(--teal);   font-weight:700; flex-shrink:0; }
.eli-cross  { color:var(--crimson); font-weight:700; flex-shrink:0; }

/* CTA */
.cta-card { background:var(--card); border:1px solid var(--border); border-radius:var(--radius-lg); padding:20px 22px; text-align:center; }
.cta-card > p:first-child { font-family:var(--serif); font-size:1rem; color:var(--ink2); margin-bottom:11px; }
.cta-note { font-size:11px; color:var(--ink3); margin-top:7px; font-family:var(--mono); }

/* General Terms */
.terms-grid { display:grid; grid-template-columns:repeat(3,1fr); gap:18px; margin-bottom:24px; }
.terms-card { background:var(--card); border:1px solid var(--border); border-radius:var(--radius-lg); padding:22px; transition:border-color var(--transition); }
.terms-card:hover { border-color:var(--gold); }
.terms-icon { font-size:1.7rem; margin-bottom:11px; }
.terms-card h3 { font-family:var(--serif); font-size:1rem; font-weight:600; color:var(--ink); margin-bottom:7px; }
.terms-card p { font-size:13px; color:var(--ink2); line-height:1.7; }
.terms-card p strong { color:var(--ink); font-weight:600; }
.terms-footer-note { display:flex; align-items:flex-start; gap:12px; background:rgba(212,168,67,0.06); border:1px solid rgba(212,168,67,0.2); border-radius:var(--radius-lg); padding:16px 20px; font-size:13px; color:var(--ink2); line-height:1.7; }
.terms-footer-note > span { font-size:1.2rem; flex-shrink:0; margin-top:1px; }

/* FAQs */
.faq-intro { margin-bottom:28px; }
.faq-intro h2 { font-family:var(--serif); font-size:1.6rem; font-weight:700; color:var(--ink); margin-bottom:5px; }
.faq-intro p { font-size:13px; color:var(--ink3); }
.faq-group-label { font-family:var(--mono); font-size:10px; letter-spacing:2px; text-transform:uppercase; color:var(--gold); margin-bottom:12px; padding-bottom:7px; border-bottom:1px solid var(--border); }
.faq-list { display:flex; flex-direction:column; gap:0; margin-bottom:8px; }
.faq-item { border:1px solid var(--border); border-radius:var(--radius-md); background:var(--card); margin-bottom:9px; overflow:hidden; transition:border-color var(--transition); }
.faq-item:hover { border-color:var(--border2); }
.faq-item.open  { border-color:var(--gold); }
.faq-q { width:100%; display:flex; align-items:center; justify-content:space-between; gap:12px; padding:16px 18px; background:transparent; border:none; text-align:left; font-size:14px; font-weight:500; color:var(--ink); cursor:pointer; transition:color var(--transition); }
.faq-q:hover { color:var(--gold); }
.faq-q span:first-child { flex:1; }
.faq-arrow { font-size:0.9rem; color:var(--ink3); transition:transform 0.25s ease, color 0.25s ease; flex-shrink:0; }
.faq-item.open .faq-arrow { transform:rotate(180deg); color:var(--gold); }
.faq-a { display:none; padding:0 18px 16px; border-top:1px solid var(--border); padding-top:14px; font-size:13px; color:var(--ink2); line-height:1.75; }
.faq-a strong { color:var(--ink); font-weight:600; }
.faq-item.open .faq-a { display:block; }

/* Light theme */
html.light-theme .contest-hero { background: #faf8f5; }
html.light-theme .contest-card,
html.light-theme .timeline-card,
html.light-theme .prize-card,
html.light-theme .eligibility-card,
html.light-theme .cta-card,
html.light-theme .terms-card,
html.light-theme .faq-item { background: #fff; }

/* Responsive */
@media (max-width: 1100px) {
  .contest-layout { grid-template-columns: 1fr; }
  .contest-sidebar { display:grid; grid-template-columns:repeat(2,1fr); gap:14px; }
  .contest-sidebar > * { margin-bottom:0 !important; }
  .terms-grid { grid-template-columns:repeat(2,1fr); }
}
@media (max-width: 768px) {
  .contest-hero { padding:36px 20px 30px; }
  .hero-dates { flex-direction:column; width:100%; }
  .hero-date-divider { width:100%; height:1px; }
  .countdown-unit { min-width:56px; padding:10px 12px; }
  .countdown-num  { font-size:1.6rem; }
  .contest-card, .timeline-card { padding:18px; }
  .contest-sidebar { grid-template-columns:1fr; }
  .terms-grid { grid-template-columns:1fr; }
  .tag-notice { flex-direction:column; gap:8px; }
}