/* recap.css
   Global styles for recap-player.js cards. Rendered outside Blazor's
   component tree so scoped CSS can't reach them. */

.rw-recap-stage {
    position: relative;
    width: 100%;
    height: 100%;
    overflow: hidden;
}

.rw-recap-card {
    position: absolute;
    inset: 0;
    display: flex;
    flex-direction: row;
    align-items: center;
    justify-content: center;
    gap: 3rem;
    padding: 8vh 8vw;
    opacity: 0;
    transform: scale(0.96);
    transition: opacity 0.5s ease, transform 0.6s cubic-bezier(0.23, 1, 0.32, 1);
}

.rw-recap-card--in {
    opacity: 1;
    transform: scale(1);
}

.rw-recap-card--out {
    opacity: 0;
    transform: scale(1.03);
    transition: opacity 0.4s ease, transform 0.4s ease;
}

.rw-recap-card__image {
    flex: 0 0 auto;
    width: min(34vmin, 360px);
    aspect-ratio: 3 / 4;
    background-size: cover;
    background-position: center;
    border: 2px solid rgba(196, 160, 64, 0.35);
    border-radius: var(--rw-radius-md, 6px);
    box-shadow:
        0 8px 48px rgba(0, 0, 0, 0.55),
        inset 0 0 24px rgba(196, 160, 64, 0.15);
}

.rw-recap-card__sigil {
    flex: 0 0 auto;
    width: min(28vmin, 280px);
    height: min(28vmin, 280px);
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: min(16vmin, 160px);
    border: 2px solid rgba(196, 160, 64, 0.35);
    border-radius: 50%;
    background:
        radial-gradient(circle, rgba(196, 160, 64, 0.12) 0%, transparent 65%);
    box-shadow: 0 0 48px rgba(196, 160, 64, 0.2);
}

.rw-recap-card__body {
    flex: 1 1 auto;
    max-width: 42rem;
    display: flex;
    flex-direction: column;
    gap: 1rem;
}

.rw-recap-card__chip {
    display: inline-block;
    align-self: flex-start;
    padding: 0.35rem 0.9rem;
    background: rgba(7, 14, 20, 0.55);
    border: 1px solid rgba(196, 160, 64, 0.35);
    border-radius: 999px;
    font-family: "Alegreya SC", serif;
    font-size: 0.78rem;
    letter-spacing: 0.2em;
    text-transform: uppercase;
    color: var(--rw-gold-light, #dab855);
}

.rw-recap-card__title {
    font-family: "Fraunces", "MedievalSharp", serif;
    font-size: clamp(2rem, 5vw, 3.4rem);
    line-height: 1.1;
    color: var(--rw-text-bright, #f2e9d5);
    text-shadow: 0 2px 16px rgba(0, 0, 0, 0.7);
    margin: 0;
}

.rw-recap-card__subtitle {
    font-family: "Alegreya", serif;
    font-style: italic;
    font-size: clamp(1rem, 2vw, 1.4rem);
    color: var(--rw-sage-cream, #d8cfb8);
    margin: 0;
    opacity: 0.9;
}

/* ---------- Kind-specific theming ---------- */

.rw-recap-card--crit .rw-recap-card__chip,
.rw-recap-card--crit .rw-recap-card__title,
.rw-recap-card--legendary-loot .rw-recap-card__chip,
.rw-recap-card--legendary-loot .rw-recap-card__title,
.rw-recap-card--level-up .rw-recap-card__chip,
.rw-recap-card--level-up .rw-recap-card__title,
.rw-recap-card--boss-defeated .rw-recap-card__chip,
.rw-recap-card--boss-defeated .rw-recap-card__title {
    color: var(--rw-gold-light, #dab855);
    text-shadow: 0 2px 20px rgba(0, 0, 0, 0.8), 0 0 32px rgba(196, 160, 64, 0.3);
}

.rw-recap-card--pc-downed .rw-recap-card__title {
    color: #e7b8b2;
    text-shadow: 0 2px 20px rgba(80, 10, 10, 0.8);
}

.rw-recap-card--pc-downed .rw-recap-card__sigil {
    border-color: rgba(200, 90, 80, 0.4);
    background: radial-gradient(circle, rgba(180, 50, 40, 0.15) 0%, transparent 65%);
    box-shadow: 0 0 48px rgba(180, 50, 40, 0.2);
}

.rw-recap-card--pc-revived .rw-recap-card__title,
.rw-recap-card--natural-twenty-death-save .rw-recap-card__title {
    color: var(--rw-gold-light, #dab855);
    text-shadow: 0 2px 20px rgba(0, 0, 0, 0.8), 0 0 48px rgba(218, 184, 85, 0.5);
}

.rw-recap-card--legendary-loot .rw-recap-card__sigil,
.rw-recap-card--level-up .rw-recap-card__sigil,
.rw-recap-card--boss-defeated .rw-recap-card__sigil {
    border-color: var(--rw-gold, #c4a040);
    background: radial-gradient(circle, rgba(218, 184, 85, 0.2) 0%, transparent 65%);
    box-shadow: 0 0 64px rgba(196, 160, 64, 0.4);
}

.rw-recap-card--narration .rw-recap-card__chip {
    background: rgba(40, 60, 80, 0.6);
    border-color: rgba(120, 180, 200, 0.4);
    color: #c0e0e8;
}

.rw-recap-card--narration .rw-recap-card__title {
    font-style: italic;
    font-family: "Fraunces", serif;
    font-weight: 400;
    color: #e8e0cc;
    font-size: clamp(1.6rem, 3.5vw, 2.4rem);
}

.rw-recap-card--narration .rw-recap-card__prose {
    font-family: "Fraunces", serif;
    font-style: italic;
    font-size: clamp(1.05rem, 1.9vw, 1.4rem);
    line-height: 1.55;
    color: #e0d8c4;
    margin: 0;
    text-shadow: 0 1px 12px rgba(0, 0, 0, 0.7);
    max-width: 40rem;
    opacity: 0;
    animation: rw-recap-prose-fade-in 0.8s ease-out 0.3s forwards;
}

@keyframes rw-recap-prose-fade-in {
    from { opacity: 0; transform: translateY(4px); }
    to   { opacity: 0.92; transform: translateY(0); }
}

.rw-recap-card--fumble .rw-recap-card__chip,
.rw-recap-card--fumble .rw-recap-card__title {
    color: #d0c4b0;
    text-shadow: 0 2px 20px rgba(60, 40, 20, 0.7);
}

/* Narrow layout — stack vertically on portrait screens. */
@media (max-aspect-ratio: 1/1) {
    .rw-recap-card {
        flex-direction: column;
        gap: 2rem;
        padding: 4vh 4vw;
        justify-content: center;
    }
    .rw-recap-card__body {
        text-align: center;
        align-items: center;
    }
    .rw-recap-card__chip {
        align-self: center;
    }
}

@media (prefers-reduced-motion: reduce) {
    .rw-recap-card,
    .rw-recap-card--in,
    .rw-recap-card--out {
        transition-duration: 0.2s;
        transform: none !important;
    }
}
