:root{
  --win-bg:#060815;
  --win-bg2:#0b0f22;
  --win-card:#0c1226;
  --win-card2:#0a1022;

  --win-gold:#d4a54b;
  --win-gold2:#b9872f;
  --win-border:rgba(212,165,75,.35);

  --win-text:#ffffff;
  --win-muted:#a6aebe;

  --shadow: 0 18px 45px rgba(0,0,0,.45);
}

/* Fondo tipo gala */
.spe-page-bg{
  background:
    radial-gradient(circle at 20% 0%, rgba(212,165,75,.10), transparent 35%),
    radial-gradient(circle at 80% 10%, rgba(212,165,75,.08), transparent 40%),
    radial-gradient(circle at 50% 100%, rgba(255,255,255,.04), transparent 50%),
    linear-gradient(180deg, var(--win-bg), var(--win-bg2));
  padding: 35px 0 55px;
}

.spe-wrap{
  max-width: 1180px;
  margin: 0 auto;
  padding: 0 18px;
  font-family: Inter, system-ui, -apple-system, Segoe UI, Roboto, Arial, sans-serif;
  color: var(--win-text);
}

.spe-wow{
  position: relative;
}

/* Hero */
.spe-hero{
  text-align:center;
  padding: 10px 0 22px;
}

.spe-hero-badge{
  display:inline-block;
  border:1px solid var(--win-border);
  color: var(--win-gold);
  padding: 6px 12px;
  border-radius: 999px;
  letter-spacing: 2px;
  font-size: 11px;
  background: rgba(212,165,75,.06);
}

.spe-title{
  margin: 12px 0 6px;
  font-size: 34px;
  letter-spacing: 3px;
  text-transform: uppercase;
  color: var(--win-gold);
}

.spe-subtitle{
  margin: 0;
  color: var(--win-muted);
  font-size: 14px;
}

/* Tabs */
.spe-tabs{
  display:flex;
  gap:10px;
  overflow-x:auto;
  padding: 10px 4px 6px;
  margin: 10px auto 18px;
  scrollbar-width: thin;
}

.spe-tabs::-webkit-scrollbar{height:8px}
.spe-tabs::-webkit-scrollbar-thumb{
  background: rgba(212,165,75,.18);
  border-radius: 999px;
}

.spe-tab{
  position: relative;
  border: 1px solid rgba(212,165,75,.28);
  background: rgba(212,165,75,.06);
  color: var(--win-gold);
  padding: 10px 14px;
  border-radius: 999px;
  cursor: pointer;
  white-space: nowrap;
  font-size: 13px;
  transition: .25s ease;
  outline: none;
}

.spe-tab:hover{
  border-color: rgba(212,165,75,.6);
  transform: translateY(-1px);
}

.spe-tab.active{
  background: linear-gradient(135deg, var(--win-gold), var(--win-gold2));
  color: #0b0b0b;
  font-weight: 700;
  box-shadow: 0 10px 22px rgba(212,165,75,.18);
  border-color: transparent;
}

.spe-tab-dot{
  display:inline-block;
  width:6px;height:6px;
  border-radius: 50%;
  margin-left:8px;
  background: rgba(0,0,0,.25);
}

.spe-tab.active .spe-tab-dot{
  background: rgba(0,0,0,.55);
}

/* Toolbar */
.spe-toolbar{
  display:flex;
  gap:12px;
  align-items:center;
  justify-content: space-between;
  flex-wrap: wrap;
  margin: 4px 0 18px;
}

.spe-search-wrap{
  position: relative;
  flex: 1 1 380px;
  max-width: 520px;
}

.spe-search-ico{
  position:absolute;
  left:14px; top:50%;
  transform: translateY(-50%);
  opacity: .7;
}

.spe-search{
  width: 100%;
  border: 1px solid rgba(212,165,75,.26);
  background: rgba(12,18,38,.75);
  color: var(--win-text);
  border-radius: 999px;
  padding: 12px 14px 12px 38px;
  outline:none;
  transition: .25s ease;
  box-shadow: 0 0 0 transparent;
}

.spe-search:focus{
  border-color: rgba(212,165,75,.75);
  box-shadow: 0 0 0 4px rgba(212,165,75,.10);
}

.spe-hint{
  color: var(--win-muted);
  font-size: 13px;
  flex: 1 1 260px;
  text-align: right;
}

/* Category head */
.spe-category-head{
  display:flex;
  align-items:flex-end;
  justify-content: space-between;
  gap: 14px;
  margin: 10px 0 14px;
}

.spe-category-title{
  font-size: 16px;
  font-weight: 800;
  letter-spacing: 1px;
  color: #fff;
}

.spe-category-status{
  font-size: 13px;
  color: var(--win-muted);
}

/* Grid + cards */
.spe-grid{
  display:grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 18px;
}
@media(max-width: 980px){ .spe-grid{grid-template-columns: repeat(2, minmax(0, 1fr));} }
@media(max-width: 620px){
  .spe-grid{grid-template-columns: 1fr;}
  .spe-hint{ text-align:left; }
}

.spe-card{
  position: relative;
  overflow: hidden;
  border-radius: 18px;
  padding: 22px 18px 18px;
  border: 1px solid rgba(212,165,75,.25);
  background: linear-gradient(180deg, rgba(12,18,38,.92), rgba(10,16,34,.92));
  box-shadow: var(--shadow);
  text-align: center;
  transition: .25s ease;
}

.spe-card:hover{
  transform: translateY(-2px);
  border-color: rgba(212,165,75,.65);
}

.spe-card-glow{
  position:absolute;
  inset: -40px -60px auto -60px;
  height: 120px;
  background: radial-gradient(circle, rgba(212,165,75,.20), transparent 65%);
  filter: blur(2px);
  pointer-events:none;
  transform: rotate(6deg);
}

.spe-avatar{
  width: 118px;
  height: 118px;
  border-radius: 999px;
  overflow: hidden;
  margin: 0 auto 12px;
  border: 2px solid rgba(212,165,75,.85);
  box-shadow: 0 0 18px rgba(212,165,75,.24);
  background: rgba(255,255,255,.06);
}

.spe-avatar img{
  width:100%;
  height:100%;
  object-fit: cover;
}

.spe-info{padding: 0 6px;}
.spe-name{
  font-weight: 900;
  font-size: 16px;
  letter-spacing: .6px;
  margin-bottom: 4px;
}
.spe-role{
  font-size: 13px;
  color: var(--win-muted);
}
.spe-company{
  font-size: 12px;
  color: var(--win-muted);
  margin-top: 2px;
  margin-bottom: 14px;
}

/* Vote button */
.spe-vote-btn{
  width: 100%;
  border: none;
  border-radius: 999px;
  padding: 12px 14px;
  cursor: pointer;
  font-weight: 900;
  letter-spacing: 1px;
  text-transform: uppercase;
  color: #0b0b0b;
  background: linear-gradient(135deg, var(--win-gold), var(--win-gold2));
  transition: .25s ease;
  position: relative;
  overflow: hidden;
}

.spe-vote-btn:hover{
  box-shadow: 0 10px 24px rgba(212,165,75,.22);
  transform: translateY(-1px);
}

.spe-btn-spark{
  position:absolute;
  inset: 0;
  background:
    radial-gradient(circle at 20% 30%, rgba(255,255,255,.45), transparent 35%),
    radial-gradient(circle at 70% 60%, rgba(255,255,255,.25), transparent 35%);
  opacity: .25;
  transform: translateX(-20%);
  transition: .25s ease;
}

.spe-vote-btn:hover .spe-btn-spark{
  opacity: .35;
  transform: translateX(0%);
}

.spe-vote-btn[disabled]{
  opacity: .55;
  cursor: not-allowed;
  transform: none;
  box-shadow: none;
}

/* Messages */
.spe-msg{
  min-height: 18px;
  margin-top: 10px;
  font-size: 13px;
}
.spe-msg.is-ok{ color: #4cd964; }
.spe-msg.is-error{ color: #ff4d4f; }

/* Voted visual lock */
.spe-locked .spe-card{
  opacity: .55;
  filter: grayscale(.15);
}

.spe-locked .spe-card.is-picked{
  opacity: 1;
  filter: none;
  border-color: rgba(212,165,75,.95);
  box-shadow: 0 0 0 2px rgba(212,165,75,.14), var(--shadow);
}

/* Overlay */
.spe-overlay{
  position: fixed;
  inset: 0;
  display: none;
  align-items: center;
  justify-content: center;
  background: rgba(0,0,0,.55);
  z-index: 999999;
  padding: 20px;
}

.spe-overlay.show{ display:flex; }

.spe-overlay-card{
  width: min(520px, 92vw);
  border-radius: 18px;
  border: 1px solid rgba(212,165,75,.35);
  background: linear-gradient(180deg, rgba(12,18,38,.96), rgba(10,16,34,.96));
  box-shadow: 0 24px 70px rgba(0,0,0,.55);
  padding: 22px 18px 18px;
  text-align: center;
  position: relative;
  overflow: hidden;
}

.spe-overlay-card:before{
  content:"";
  position:absolute;
  inset:-60px -80px auto -80px;
  height:180px;
  background: radial-gradient(circle, rgba(212,165,75,.20), transparent 65%);
  pointer-events:none;
}

.spe-check{
  width: 58px;
  height: 58px;
  border-radius: 999px;
  margin: 0 auto 10px;
  display: grid;
  place-items: center;
  color: #0b0b0b;
  font-weight: 900;
  font-size: 26px;
  background: linear-gradient(135deg, var(--win-gold), var(--win-gold2));
  box-shadow: 0 10px 24px rgba(212,165,75,.25);
}

.spe-overlay-title{
  font-size: 18px;
  font-weight: 900;
  letter-spacing: .6px;
}

.spe-overlay-sub{
  margin-top: 6px;
  color: var(--win-muted);
  font-size: 13px;
}

.spe-overlay-btn{
  margin-top: 14px;
  border: 1px solid rgba(212,165,75,.35);
  background: rgba(212,165,75,.10);
  color: var(--win-gold);
  padding: 10px 14px;
  border-radius: 999px;
  cursor: pointer;
  font-weight: 800;
  transition: .2s ease;
}

.spe-overlay-btn:hover{
  border-color: rgba(212,165,75,.7);
  transform: translateY(-1px);
}
.spe-card.pulse{
  animation: spePulse .65s ease;
}
@keyframes spePulse{
  0%{ transform: translateY(-2px) scale(1); }
  35%{ transform: translateY(-2px) scale(1.02); }
  100%{ transform: translateY(-2px) scale(1); }
}