:root{
  --yellow:#ffd400;
  --yellow-soft:#fff4a8;
  --black:#111;
  --dark:#1a1a1a;
  --muted:#676767;
  --line:#e8e2c8;
  --card:#fffdf2;
  --white:#fff;
  --danger:#b00020;
  --ok:#0d7a32;
}

*{box-sizing:border-box}
body{
  margin:0;
  font-family:Inter,Arial,Helvetica,sans-serif;
  background:
    radial-gradient(circle at top left, rgba(255,212,0,.28), transparent 32%),
    linear-gradient(135deg,#101010 0%,#252525 52%,#080808 100%);
  color:var(--black);
  min-height:100vh;
}

.page{
  width:min(980px,100%);
  min-height:100vh;
  margin:auto;
  padding:28px 16px;
  display:grid;
  place-items:center;
}

.hero-card,.panel-card,.admin-header{
  width:100%;
  background:rgba(255,253,242,.96);
  border:1px solid rgba(255,212,0,.45);
  box-shadow:0 24px 90px rgba(0,0,0,.35);
  border-radius:28px;
}

.hero-card{
  padding:28px;
}

.brand-row{
  display:flex;
  gap:16px;
  align-items:center;
  margin:0 auto 18px;
  width:110px;
  height:110px;
  font-size:56px;
}

.logo-mark{
  width:64px;
  height:64px;
  border-radius:18px;
  background:var(--yellow);
  color:var(--black);
  display:grid;
  place-items:center;
  font-size:25px;
  font-weight:900;
  box-shadow:8px 8px 0 #111;
}

.main-logo{
  width:128px;
  height:128px;
  object-fit:contain;
  border-radius:22px;
  background:var(--yellow);
  padding:8px;
  box-shadow:8px 8px 0 #111;
  flex:0 0 auto;
}

.brand-row-logo{
  align-items:center;
}

.eyebrow{
  margin:0;
  text-transform:uppercase;
  letter-spacing:.16em;
  color:#6a5a00;
  font-size:12px;
  font-weight:800;
}

h1,h2,h3,p{margin-top:0}
h1{font-size:clamp(30px,5vw,54px);margin-bottom:0;line-height:.95}
h2{font-size:clamp(24px,3vw,36px);line-height:1.1}
h3{font-size:clamp(28px,5vw,48px);margin:8px 0 14px}

.muted{color:var(--muted);line-height:1.5}
.big{font-size:20px;margin-bottom:0}
.note{
  background:#111;
  color:#fff;
  padding:14px 16px;
  border-radius:16px;
  display:inline-block;
}

.stepper{
  display:flex;
  gap:10px;
  flex-wrap:wrap;
  margin:10px 0 28px;
}

.step{
  padding:9px 13px;
  border-radius:999px;
  background:#eee8cd;
  font-size:14px;
  font-weight:800;
  color:#6a6a6a;
}

.step.active{
  background:var(--yellow);
  color:#111;
}

.screen{display:none}
.screen.active{display:block}

.form-grid{
  display:grid;
  grid-template-columns:repeat(2,minmax(0,1fr));
  gap:14px;
}

label{
  display:grid;
  gap:7px;
  font-weight:800;
}

input,select{
  width:100%;
  appearance:none;
  border:1px solid #d3c98e;
  border-radius:14px;
  background:#fff;
  padding:14px 14px;
  font:inherit;
  outline:none;
}

input:focus,select:focus{
  border-color:#111;
  box-shadow:0 0 0 4px rgba(255,212,0,.45);
}

.full{grid-column:1/-1}
.check{
  grid-template-columns:auto 1fr;
  align-items:start;
  gap:10px;
  font-weight:600;
  line-height:1.45;
}
.check input{
  width:22px;
  height:22px;
  margin-top:1px;
  appearance:auto;
  -webkit-appearance:checkbox;
  accent-color:var(--yellow);
  cursor:pointer;
}
.check span{cursor:pointer}

button{
  border:0;
  cursor:pointer;
  font:inherit;
  font-weight:900;
  border-radius:16px;
  padding:15px 18px;
}

.primary{
  background:var(--yellow);
  color:#111;
  box-shadow:0 7px 0 #111;
  transition:.15s transform,.15s box-shadow;
}
.primary:hover{transform:translateY(-2px);box-shadow:0 9px 0 #111}
.primary:disabled{opacity:.55;cursor:not-allowed;transform:none;box-shadow:none}

.ghost{
  background:#111;
  color:#fff;
}

.error{
  color:var(--danger);
  font-weight:800;
  min-height:22px;
  margin-top:14px;
}

.toolbar{
  display:grid;
  grid-template-columns:1fr auto;
  gap:10px;
  margin:18px 0;
}

.number-grid{
  display:grid;
  grid-template-columns:repeat(auto-fill,minmax(58px,1fr));
  gap:9px;
  max-height:520px;
  overflow:auto;
  padding:4px;
}

.num-btn{
  background:#fff;
  border:1px solid #ded39b;
  border-radius:12px;
  padding:12px 6px;
  font-weight:900;
}
.num-btn:hover{background:var(--yellow)}
.num-btn.claimed{
  background:#ddd;
  color:#888;
  cursor:not-allowed;
  text-decoration:line-through;
}
.num-btn.selected{
  background:var(--yellow);
  outline:3px solid #111;
}


.result-screen{
  text-align:center;
}

.winner-card{
  max-width:720px;
  margin:8px auto 0;
  text-align:center;
  background:linear-gradient(180deg, #fffdf2 0%, #fff8cf 100%);
  border:3px solid var(--yellow);
  border-radius:30px;
  padding:26px 18px 30px;
  box-shadow:0 18px 60px rgba(0,0,0,.16), inset 0 0 0 2px rgba(17,17,17,.05);
  position:relative;
  overflow:hidden;
}

.winner-card::before,
.winner-card::after{
  content:"";
  position:absolute;
  width:180px;
  height:180px;
  border-radius:50%;
  background:rgba(255,212,0,.20);
  z-index:0;
}
.winner-card::before{top:-60px;left:-40px}
.winner-card::after{right:-40px;bottom:-60px}

.winner-card > *{
  position:relative;
  z-index:1;
}

.winner-topline{
  display:inline-block;
  margin:0 0 8px;
  padding:8px 16px;
  border-radius:999px;
  background:#111;
  color:#fff;
  font-size:13px;
  font-weight:900;
  letter-spacing:.18em;
}

.winner-emoji{
  width:140px;
  height:140px;
  margin:14px auto 12px;
  border-radius:32px;
  background:var(--yellow);
  border:4px solid #111;
  display:grid;
  place-items:center;
  font-size:74px;
  box-shadow:0 12px 0 #111;
}

#winnerPrize{
  font-size:clamp(34px,5.6vw,58px);
  margin:10px auto 14px;
  line-height:1.05;
  max-width:12ch;
}

.winner-details{
  font-size:18px;
  max-width:46ch;
  margin:0 auto 18px;
}

.winner-note{
  display:block;
  max-width:500px;
  margin:0 auto;
}

.result-badge{
  width:96px;
  height:96px;
  display:grid;
  place-items:center;
  background:var(--yellow);
  border-radius:28px;
  font-size:48px;
  box-shadow:10px 10px 0 #111;
  margin-bottom:22px;
}

.admin-page{
  width:min(1240px,100%);
  margin:0 auto;
  padding:24px 14px 60px;
}

.admin-header{
  padding:24px;
  display:flex;
  justify-content:space-between;
  align-items:center;
  margin-bottom:18px;
}

.panel-card{
  padding:22px;
  margin-bottom:18px;
  box-shadow:0 18px 70px rgba(0,0,0,.22);
}

.hidden{display:none!important}

.stats-grid{
  display:grid;
  grid-template-columns:repeat(3,minmax(0,1fr));
  gap:14px;
  margin-bottom:18px;
}
.stat{
  background:#111;
  color:#fff;
  border-radius:22px;
  padding:20px;
}
.stat span{display:block;color:#ffec76;font-weight:800;font-size:14px}
.stat strong{display:block;font-size:34px;margin-top:5px}

.panel-title{
  display:flex;
  justify-content:space-between;
  gap:16px;
  align-items:flex-start;
  margin-bottom:14px;
}
.filters{
  display:flex;
  gap:10px;
  flex-wrap:wrap;
}
.table-wrap{overflow:auto;border:1px solid var(--line);border-radius:18px;background:#fff}
table{width:100%;border-collapse:collapse;min-width:900px}
th,td{padding:13px 12px;border-bottom:1px solid #eee;text-align:left}
th{background:#111;color:#fff;position:sticky;top:0}
td.prize{font-weight:900}

.qr-links{
  display:grid;
  grid-template-columns:repeat(3,minmax(0,1fr));
  gap:12px;
}
.qr-links a{
  display:block;
  background:#fff;
  border:2px solid #111;
  border-radius:16px;
  padding:14px;
  color:#111;
  font-weight:900;
  text-decoration:none;
  word-break:break-all;
}

.summary-grid{
  display:grid;
  grid-template-columns:repeat(auto-fill,minmax(220px,1fr));
  gap:10px;
}
.summary-item{
  background:#fff;
  border:1px solid #e8e2c8;
  border-radius:16px;
  padding:14px;
}
.summary-item strong{display:block}
.summary-item span{color:var(--muted);font-weight:700}



.danger-card{
  border:2px solid rgba(176,0,32,.28);
}
.danger,
.danger-outline{
  border:2px solid #b00020;
  font-weight:900;
}
.danger{
  background:#b00020;
  color:#fff;
  box-shadow:0 7px 0 #111;
}
.danger-outline{
  background:#fff;
  color:#b00020;
  box-shadow:0 7px 0 #111;
}
.danger:disabled,
.danger-outline:disabled{
  opacity:.55;
  cursor:not-allowed;
  box-shadow:none;
}

@media(max-width:760px){
  .hero-card{padding:18px;border-radius:22px}
  .brand-row-logo{align-items:flex-start}
  .main-logo{width:96px;height:96px;border-radius:18px}
  .form-grid,.stats-grid,.qr-links{grid-template-columns:1fr}
  .toolbar{grid-template-columns:1fr}
  .admin-header,.panel-title{display:block}
  .filters{margin-top:12px}
}
