.reap-overlay{position:fixed;inset:0;display:flex;align-items:center;justify-content:center;background:rgba(10,12,14,.55);backdrop-filter:blur(6px);-webkit-backdrop-filter:blur(6px);z-index:999999;opacity:0;pointer-events:none;transition:opacity .28s ease}
.reap-overlay.show{opacity:1;pointer-events:auto}
.reap-modal{position:relative;max-width:560px;width:92%;padding:30px 26px;border-radius:18px;background:
  radial-gradient(120% 120% at 0% 0%, rgba(255,255,255,.22), rgba(255,255,255,.10) 70%),
  rgba(22,24,28,.78);
  border:1px solid rgba(255,255,255,.18);
  box-shadow:0 20px 60px rgba(0,0,0,.35);
  color:#fff;font-family:system-ui,-apple-system,Segoe UI,Roboto,Helvetica,Arial}
.reap-title{margin:0 0 6px;font-size:26px;letter-spacing:.2px;text-align:center}
.reap-sub{margin:0 12px 10px;font-size:18px;opacity:.95;text-align:center}
.reap-date{display:block;margin:0 auto 12px;font-size:18px;opacity:.9;text-align:center}
.reap-count{display:flex;gap:10px;justify-content:center;margin-top:8px}
.reap-box{min-width:86px;padding:10px 12px;border-radius:14px;border:1px solid rgba(255,255,255,.2);background:rgba(255,255,255,.12);text-align:center}
.reap-num{display:block;font-weight:700;font-size:26px;line-height:1}
.reap-lab{display:block;font-size:12px;opacity:.85;margin-top:4px;letter-spacing:.3px}
.reap-close{position:absolute;top:10px;right:10px;width:36px;height:36px;border-radius:999px;border:1px solid rgba(255,255,255,.25);background:rgba(255,255,255,.12);color:#fff;cursor:pointer;font-size:18px;line-height:36px;text-align:center}
.reap-close:hover{background:rgba(255,255,255,.18)}
/* Banner abierto (fase abierta) */
.open-banner{position:fixed;top:0;left:0;right:0;z-index:1000000;background:linear-gradient(90deg, #12c2e9, #c471ed, #f64f59);color:#fff;text-align:center;font-weight:800;letter-spacing:.6px;padding:14px 10px;font-size:22px;box-shadow:0 6px 24px rgba(0,0,0,.24)}
@media (prefers-reduced-motion: reduce){.reap-overlay{transition:none}}