/* roll-overlay.css — the single dice-roll overlay shell.
   Card-less: banner, wireframe dice, DC, and verdict float on a dark
   transparent backdrop matching the target picker. One timing system. */

:root {
  --roll-backdrop: rgba(0, 0, 0, 0.74);
  --roll-backdrop-blur: 4px;
  --roll-t-backdrop-in: 160ms;
  --roll-t-verdict: 220ms;
  --roll-t-hold: 1300ms;        /* read by JS via ROLL_TIMING; keep in sync */
  --roll-t-crossfade: 240ms;
  --roll-t-backdrop-out: 260ms;
  --roll-ink: #e8dcc8;
  --roll-ink-dim: rgba(232, 220, 200, 0.5);
  --roll-accent: #b48cff;
}

.roll-overlay {
  position: fixed;
  inset: 0;
  z-index: 9100;
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 24px;
  background: var(--roll-backdrop);
  backdrop-filter: blur(var(--roll-backdrop-blur));
  -webkit-backdrop-filter: blur(var(--roll-backdrop-blur));
  animation: roll-overlay-in var(--roll-t-backdrop-in) ease-out;
}
.roll-overlay--out { animation: roll-overlay-out var(--roll-t-backdrop-out) ease-in forwards; }

@keyframes roll-overlay-in  { from { opacity: 0; } to { opacity: 1; } }
@keyframes roll-overlay-out { from { opacity: 1; } to { opacity: 0; } }

/* Floating content column — no card. */
.roll-overlay__col {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 14px;
  text-align: center;
  color: var(--roll-ink);
}
.roll-overlay__col--enter { animation: roll-col-enter var(--roll-t-crossfade) ease-out; }
.roll-overlay__col--leave { animation: roll-col-leave var(--roll-t-crossfade) ease-in forwards; }

@keyframes roll-col-enter { from { opacity: 0; transform: translateY(10px); } to { opacity: 1; transform: none; } }
@keyframes roll-col-leave { from { opacity: 1; transform: none; } to { opacity: 0; transform: translateY(-10px); } }

.roll-overlay__banner-title {
  font-size: 0.78rem; letter-spacing: 1.6px; text-transform: uppercase;
  color: var(--roll-ink-dim);
}
.roll-overlay__banner-action { font-size: 1.1rem; font-weight: 700; margin-top: 2px; color: #f0e6d2; }

.roll-overlay__dice {
  display: flex; gap: 22px; align-items: center; justify-content: center; flex-wrap: wrap;
}
.roll-overlay__die-canvas { display: block; border-radius: 12px; }

.roll-overlay__dc { font-size: 0.82rem; color: rgba(232, 220, 200, 0.6); display: flex; gap: 8px; align-items: center; }
.roll-overlay__dc-badge {
  display: inline-flex; min-width: 24px; height: 24px; padding: 0 7px;
  align-items: center; justify-content: center; border-radius: 7px; font-weight: 700;
}

.roll-overlay__verdict {
  font-size: 1.05rem; font-weight: 700; letter-spacing: 0.5px;
  opacity: 0; transform: translateY(6px);
}
.roll-overlay__verdict--visible { opacity: 1; transform: none; transition: opacity var(--roll-t-verdict) ease, transform var(--roll-t-verdict) ease; }
.roll-overlay__verdict--success { color: #4ade80; text-shadow: 0 0 14px rgba(74, 222, 128, 0.4); }
.roll-overlay__verdict--failure { color: #f87171; }
.roll-overlay__verdict--crit    { color: #f5d76e; text-shadow: 0 0 16px rgba(245, 215, 110, 0.45); }
.roll-overlay__verdict--neutral { color: var(--roll-ink); }
.roll-overlay__verdict-sub { display: block; font-size: 0.78rem; color: var(--roll-ink-dim); margin-top: 3px; font-weight: 400; }

.roll-overlay__btn {
  margin-top: 4px; padding: 9px 26px; border-radius: 10px;
  border: 1px solid rgba(180, 140, 255, 0.5);
  background: rgba(180, 140, 255, 0.12); color: var(--roll-ink);
  font-weight: 700; letter-spacing: 0.5px; cursor: pointer;
  box-shadow: 0 0 14px 2px rgba(180, 140, 255, 0.3);
  transition: background 150ms, box-shadow 150ms;
}
.roll-overlay__btn:hover { background: rgba(180, 140, 255, 0.2); }
.roll-overlay__btn:disabled { opacity: 0; pointer-events: none; }

.roll-overlay__close {
  position: absolute; top: 10px; right: 14px; width: 36px; height: 36px;
  display: flex; align-items: center; justify-content: center;
  background: rgba(255, 255, 255, 0.08); border: 1px solid rgba(255, 255, 255, 0.18);
  border-radius: 50%; color: rgba(255, 255, 255, 0.7); font-size: 1.35rem; line-height: 1;
  cursor: pointer;
}

/* After resolve, clicking the dimmed backdrop closes it; show a hint.
   Replaces the old .bl-roll-overlay--resolved rule. */
.roll-overlay--resolved { cursor: pointer; }
.roll-overlay--resolved::after {
  content: 'Tap to close';
  position: fixed; bottom: 18px; left: 50%; transform: translateX(-50%);
  font-size: 0.75rem; color: rgba(255, 255, 255, 0.4);
  pointer-events: none; letter-spacing: 0.04em;
}

/* Advantage keep/drop reuse the existing classes from dice-roller.css
   (.adv-kept / .adv-dropped) — do not redefine here. */

@media (prefers-reduced-motion: reduce) {
  .roll-overlay, .roll-overlay--out,
  .roll-overlay__col--enter, .roll-overlay__col--leave { animation-duration: 1ms; }
  .roll-overlay__verdict--visible { transition-duration: 1ms; }
}
