/* ==========================================================================
   REWARD REVEAL MODAL
   Full-screen overlay with animated plant/reward reveal
   ========================================================================== */

.reward-overlay {
    position: fixed;
    inset: 0;
    background: rgba(8, 6, 4, 0.92);
    z-index: 200;
    display: flex;
    align-items: center;
    justify-content: center;
    opacity: 0;
    transition: opacity 0.4s ease-out;
}

.reward-overlay.reward-visible {
    opacity: 1;
}

.reward-overlay.reward-closing {
    opacity: 0;
    transition: opacity 0.35s ease-in;
}

/* --- Ambient Background --- */

.reward-ambient {
    position: absolute;
    inset: 0;
    opacity: 0;
    transition: opacity 0.8s ease-out 0.2s;
}

.reward-visible .reward-ambient {
    opacity: 1;
}

/* --- Burst Effect --- */

.reward-burst {
    position: absolute;
    top: 50%;
    left: 50%;
    width: 0;
    height: 0;
    border-radius: 50%;
    transform: translate(-50%, -50%);
    opacity: 0;
    transition: width 0.6s cubic-bezier(0.22, 1, 0.36, 1) 0.1s,
                height 0.6s cubic-bezier(0.22, 1, 0.36, 1) 0.1s,
                opacity 0.8s ease-out 0.1s;
    pointer-events: none;
}

.reward-visible .reward-burst {
    width: 500px;
    height: 500px;
    opacity: 1;
}

.reward-burst-common {
    background: radial-gradient(circle, rgba(138,120,96,0.15) 0%, rgba(138,120,96,0.05) 40%, transparent 70%);
}

.reward-burst-uncommon {
    background: radial-gradient(circle, rgba(104,168,88,0.2) 0%, rgba(104,168,88,0.06) 40%, transparent 70%);
}

.reward-burst-rare {
    background: radial-gradient(circle, rgba(64,112,160,0.25) 0%, rgba(64,112,160,0.08) 40%, transparent 70%);
}

.reward-burst-epic {
    background: radial-gradient(circle, rgba(112,80,160,0.3) 0%, rgba(112,80,160,0.1) 40%, transparent 70%);
}

.reward-burst-legendary {
    background: radial-gradient(circle, rgba(208,160,48,0.35) 0%, rgba(208,160,48,0.12) 40%, transparent 65%);
}

/* --- Particles --- */

.reward-particles {
    position: absolute;
    inset: 0;
    pointer-events: none;
    opacity: 0;
    transition: opacity 1s ease-out 0.5s;
}

.reward-visible .reward-particles {
    opacity: 0.7;
}

/* --- Content Container --- */

.reward-content {
    position: relative;
    z-index: 1;
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: var(--spacing-md);
    padding: var(--spacing-lg);
    max-width: 340px;
    width: 100%;
}

/* --- Label --- */

.reward-label {
    font-family: var(--font-pixel);
    font-size: 11px;
    color: var(--gold-light);
    text-transform: uppercase;
    letter-spacing: 2px;
    text-shadow: 0 0 12px rgba(208,160,48,0.4), 0 2px 4px rgba(0,0,0,0.8);
    opacity: 0;
    transform: translateY(-10px);
    transition: opacity 0.5s ease-out 0.3s, transform 0.5s ease-out 0.3s;
}

.reward-visible .reward-label {
    opacity: 1;
    transform: translateY(0);
}

/* --- Sprite --- */

.reward-sprite-wrap {
    position: relative;
    width: 180px;
    height: 180px;
    display: flex;
    align-items: center;
    justify-content: center;
    opacity: 0;
    transform: scale(0.3);
    transition: opacity 0.5s ease-out 0.4s, transform 0.6s cubic-bezier(0.34, 1.56, 0.64, 1) 0.4s;
}

.reward-visible .reward-sprite-wrap {
    opacity: 1;
    transform: scale(1);
}

.reward-aura {
    position: absolute;
    inset: -30px;
    border-radius: 50%;
    animation: reward-aura-pulse 2.5s ease-in-out infinite alternate;
}

@keyframes reward-aura-pulse {
    from { transform: scale(0.95); opacity: 0.6; }
    to { transform: scale(1.1); opacity: 1; }
}

.reward-sprite {
    position: relative;
    z-index: 1;
    animation: reward-float 3s ease-in-out infinite alternate;
}

@keyframes reward-float {
    from { transform: translateY(0); }
    to { transform: translateY(-6px); }
}

/* --- Plant Name --- */

.reward-plant-name {
    font-family: var(--font-pixel);
    font-size: 16px;
    text-align: center;
    opacity: 0;
    transform: translateY(8px);
    transition: opacity 0.4s ease-out 0.7s, transform 0.4s ease-out 0.7s;
}

.reward-visible .reward-plant-name {
    opacity: 1;
    transform: translateY(0);
}

/* --- Type Row --- */

.reward-type-row {
    display: flex;
    align-items: center;
    gap: var(--spacing-sm);
    opacity: 0;
    transform: translateY(6px);
    transition: opacity 0.4s ease-out 0.8s, transform 0.4s ease-out 0.8s;
}

.reward-visible .reward-type-row {
    opacity: 1;
    transform: translateY(0);
}

.reward-type-name {
    font-family: var(--font-pixel);
    font-size: 9px;
    color: var(--text-dim);
    text-transform: uppercase;
    letter-spacing: 1px;
}

/* --- Stats --- */

.reward-stats {
    display: flex;
    gap: var(--spacing-lg);
    opacity: 0;
    transform: translateY(6px);
    transition: opacity 0.4s ease-out 0.9s, transform 0.4s ease-out 0.9s;
}

.reward-visible .reward-stats {
    opacity: 1;
    transform: translateY(0);
}

.reward-stat {
    text-align: center;
    padding: var(--spacing-sm) var(--spacing-md);
    background: rgba(255,255,255,0.03);
    border: 1px solid var(--border-dark);
}

.reward-stat-value {
    font-family: var(--font-pixel);
    font-size: 16px;
    color: var(--text-bright);
    line-height: 1.4;
}

.reward-stat-label {
    font-family: var(--font-pixel);
    font-size: 7px;
    color: var(--text-muted);
    text-transform: uppercase;
    letter-spacing: 1px;
    margin-top: 2px;
}

/* --- Effects --- */

.reward-effects {
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 6px;
    opacity: 0;
    transform: translateY(6px);
    transition: opacity 0.4s ease-out 1s, transform 0.4s ease-out 1s;
}

.reward-visible .reward-effects {
    opacity: 1;
    transform: translateY(0);
}

.reward-effect-tag {
    display: inline-flex;
    align-items: center;
    gap: 6px;
    padding: 4px 10px;
    background: linear-gradient(180deg, rgba(104,168,88,0.12) 0%, rgba(0,0,0,0.2) 100%);
    border: 1px solid var(--green-dark);
    border-left: 3px solid var(--green);
    font-family: var(--font-pixel);
    font-size: 8px;
}

.reward-effect-name {
    color: var(--green-light);
    text-transform: uppercase;
    letter-spacing: 0.5px;
}

.reward-potency {
    display: inline-flex;
    gap: 2px;
}

.reward-potency-dot {
    width: 5px;
    height: 5px;
    background: var(--green);
    border: 1px solid var(--green-light);
    display: inline-block;
}

/* --- Dismiss Button --- */

.reward-dismiss-btn {
    margin-top: var(--spacing-sm);
    min-width: 140px;
    opacity: 0;
    transform: translateY(8px);
    transition: opacity 0.4s ease-out 1.1s, transform 0.4s ease-out 1.1s,
                background 0.15s, border-color 0.15s;
}

.reward-visible .reward-dismiss-btn {
    opacity: 1;
    transform: translateY(0);
}

/* --- Currency Reveal --- */

.reward-currency-icon {
    color: var(--gold);
    filter: drop-shadow(0 0 16px rgba(208,160,48,0.5));
    opacity: 0;
    transform: scale(0.3);
    transition: opacity 0.5s ease-out 0.4s, transform 0.6s cubic-bezier(0.34, 1.56, 0.64, 1) 0.4s;
}

.reward-visible .reward-currency-icon {
    opacity: 1;
    transform: scale(1);
}

.reward-currency-amount {
    font-family: var(--font-pixel);
    font-size: 28px;
    color: var(--gold-light);
    text-shadow: 0 0 16px rgba(208,160,48,0.4), 0 2px 4px rgba(0,0,0,0.6);
    opacity: 0;
    transform: translateY(8px);
    transition: opacity 0.4s ease-out 0.7s, transform 0.4s ease-out 0.7s;
}

.reward-visible .reward-currency-amount {
    opacity: 1;
    transform: translateY(0);
}

.reward-currency-label {
    font-family: var(--font-pixel);
    font-size: 9px;
    color: var(--text-dim);
    text-transform: uppercase;
    letter-spacing: 2px;
    opacity: 0;
    transition: opacity 0.4s ease-out 0.85s;
}

.reward-visible .reward-currency-label {
    opacity: 1;
}

/* --- Generic Reveal --- */

.reward-generic-desc {
    font-family: var(--font-pixel);
    font-size: 10px;
    color: var(--text-bright);
    text-align: center;
    line-height: 1.8;
    opacity: 0;
    transform: translateY(8px);
    transition: opacity 0.4s ease-out 0.5s, transform 0.4s ease-out 0.5s;
}

.reward-visible .reward-generic-desc {
    opacity: 1;
    transform: translateY(0);
}

/* --- Rarity Text Colors (for reward context) --- */

/* --- Collection Reveal --- */

.reward-collection-content {
    max-width: 420px;
}

.reward-collection-count {
    font-family: var(--font-pixel);
    font-size: 10px;
    text-transform: uppercase;
    letter-spacing: 1px;
    opacity: 0;
    transform: translateY(6px);
    transition: opacity 0.4s ease-out 0.4s, transform 0.4s ease-out 0.4s;
}

.reward-visible .reward-collection-count {
    opacity: 1;
    transform: translateY(0);
}

.reward-collection-grid {
    display: grid;
    grid-template-columns: repeat(5, 1fr);
    gap: 6px;
    width: 100%;
    max-height: 340px;
    overflow-y: auto;
}

.reward-collection-card {
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 4px;
    padding: 6px 4px;
    background: rgba(255,255,255,0.03);
    border: 1px solid var(--border-dark);
    cursor: pointer;
    opacity: 0;
    transform: scale(0.6);
    transition: opacity 0.4s ease-out, transform 0.5s cubic-bezier(0.34, 1.56, 0.64, 1),
                border-color 0.15s, background 0.15s;
}

.reward-visible .reward-collection-card {
    opacity: 1;
    transform: scale(1);
}

.reward-collection-card:hover {
    border-color: var(--gold-dark);
    background: rgba(208,160,48,0.06);
}

.reward-collection-sprite {
    image-rendering: pixelated;
}

.reward-collection-name {
    font-family: var(--font-pixel);
    font-size: 7px;
    text-align: center;
    line-height: 1.3;
}

.reward-collection-stats {
    display: flex;
    gap: 4px;
    font-family: var(--font-pixel);
    font-size: 6px;
    color: var(--text-muted);
}

.reward-collection-effects {
    font-family: var(--font-pixel);
    font-size: 6px;
    color: var(--green);
}

.rarity-text-common    { color: var(--rarity-common); text-shadow: 0 2px 4px rgba(0,0,0,0.6); }
.rarity-text-uncommon  { color: var(--rarity-uncommon); text-shadow: 0 0 8px rgba(104,168,88,0.3), 0 2px 4px rgba(0,0,0,0.6); }
.rarity-text-rare      { color: var(--rarity-rare); text-shadow: 0 0 10px rgba(64,112,160,0.35), 0 2px 4px rgba(0,0,0,0.6); }
.rarity-text-epic      { color: var(--rarity-epic); text-shadow: 0 0 12px rgba(112,80,160,0.4), 0 2px 4px rgba(0,0,0,0.6); }
.rarity-text-legendary { color: var(--rarity-legendary); text-shadow: 0 0 16px rgba(208,160,48,0.5), 0 0 32px rgba(208,160,48,0.2), 0 2px 4px rgba(0,0,0,0.6); }
