
* { box-sizing: border-box; }
html, body { height: 100%; }
body { margin: 0; font-family: system-ui, -apple-system, Segoe UI, Roboto, Arial, sans-serif; line-height: 1.5; }
.container { max-width: 980px; margin:0 auto; padding:16px; }

.site-header.hero { text-align:center; padding: 28px 16px 12px; position:relative; }
.site-header.hero h1 { margin:0 0 8px; font-size:34px; }
.site-header.hero p { margin:0; }

.sparkles { position:absolute; width:80px; right:16px; top:16px; opacity:.7; }
.media-grid { display:grid; grid-template-columns: 280px 1fr; gap:16px; }
.media { position:relative; }

.prize-card, .entry-card, .how-card {
  background: rgba(255, 255, 255, 0.9);
  border-radius: 16px;
  padding: 20px; margin-bottom: 16px;
  border: 1px solid rgba(0,0,0,.08);
  box-shadow: 0 6px 20px rgba(0,0,0,0.08);
}
.prize-image { width:100%; height:auto; border-radius:12px; background:#fff; border:1px solid rgba(0,0,0,.06); }
h2 { margin-top:0; }
.entry-card form { display:grid; gap:10px; }
label { font-weight:700; }
input[type="text"], input[type="email"], input[type="number"] { padding: 12px; border-radius: 10px; border: 1px solid #ddd; background: #fff; color: #111; }
.consent { display:flex; gap:8px; align-items:center; font-size:14px; }
a { text-decoration:underline; }

button { padding:12px 16px; border-radius:12px; border:none; color:#fff; font-weight:800; cursor:pointer; position:relative; overflow:hidden; }
button:disabled { opacity:.6; cursor:not-allowed; }
.shine::after { content:""; position:absolute; top:0; left:-100%; height:100%; width:60%; background: linear-gradient(120deg, rgba(255,255,255,0), rgba(255,255,255,.65), rgba(255,255,255,0)); transform: skewX(-20deg); animation: sweep 2.2s infinite; }
@keyframes sweep { 0%{ left:-100%; } 60%{ left:140%; } 100%{ left:140%; } }

.msg { min-height:20px; font-size:14px; }
.note { font-size:12px; opacity:.9; }
.tickets-box { margin-top:10px; padding:10px; background:#fff; border:1px solid rgba(0,0,0,.1); border-radius:10px; font-family: ui-monospace, SFMono-Regular, Menlo, Consolas, monospace; font-size:13px; }
.admin { text-align:right; margin-top:16px; }
.site-footer { text-align:center; padding:24px 16px; font-size:12px; }

/* ================= FIREWORKS THEME ================= */

/* Fireworks - Dynamic & Energetic with animated bursts */
body { 
  background: radial-gradient(circle at 50% -20%, #ffeaa7, #ffb142 40%, #ff5252 100%); 
  color:#210000; 
}
.site-header.hero { color:#5c0000; }
a { color:#5c0000; }
button { background: linear-gradient(90deg, #ff5252, #ffb142); }

/* Animated fireworks bursts */
.layer-fireworks { 
  pointer-events:none; 
  position:fixed; 
  inset:0; 
  background:
    radial-gradient(circle, rgba(255,255,255,0.9) 0, rgba(255,255,255,0) 60px) 20% 30%/3px 3px no-repeat,
    radial-gradient(circle, rgba(255,255,255,0.9) 0, rgba(255,255,255,0) 60px) 70% 60%/3px 3px no-repeat;
  animation: boom 2.4s infinite;
}
@keyframes boom {
  0% { background-size: 3px 3px, 3px 3px; opacity:.3; }
  30% { background-size: 120px 120px, 3px 3px; opacity:.8; }
  60% { background-size: 3px 3px, 120px 120px; opacity:.8; }
  100% { background-size: 3px 3px, 3px 3px; opacity:.3; }
}

/* Rotate the watch (subtle) */
.rotate { animation: rotateY 6s linear infinite; transform-style: preserve-3d; }
@keyframes rotateY { 0%{ transform: perspective(800px) rotateY(0deg);} 50%{ transform: perspective(800px) rotateY(10deg);} 100%{ transform: perspective(800px) rotateY(0deg);} }

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