/* ==========================================================================
   DESIGN SYSTEM & VARIABLES - O TARÔ DE MALUCA (Místico & Folha de Ouro)
   ========================================================================== */

:root {
    /* Color Palette - Mystical Obsidian & Gold Foil */
    --color-paper: #f5f2eb;        /* Authentic aged card stock */
    --color-paper-dark: #e8e3d5;   /* Shadows on card stock */
    --color-ink: #110e13;          /* Deep carbon charcoal woodblock ink */
    --color-crimson: #a62424;      /* Glowing blood/wine accent */
    --color-gold: #d9b461;         /* Shiny metallic gold leaf */
    --color-gold-dark: #8c6a23;    /* Antique tarnished gold */
    --color-obsidian: #121017;     /* Dark grimoire leather cover */
    --color-velvet: #08060c;       /* Void background space */
    --color-shadow: rgba(0, 0, 0, 0.7);

    /* Fonts */
    --font-heading-fancy: 'Cinzel Decorative', Georgia, serif;
    --font-heading: 'Cinzel', Georgia, serif;
    --font-body: 'Almendra', Georgia, serif;

    /* Transitions */
    --transition-slow: 0.8s cubic-bezier(0.175, 0.885, 0.32, 1.2);
    --transition-medium: 0.4s cubic-bezier(0.25, 0.8, 0.25, 1);
    --transition-fast: 0.2s ease;
}

/* ==========================================================================
   GLOBAL LAYOUT & RESET
   ========================================================================== */

*, *::before, *::after {
    box-sizing: border-box;
    margin: 0;
    padding: 0;
}

body {
    background-color: var(--color-velvet);
    color: var(--color-paper);
    font-family: var(--font-body);
    font-size: 1.15rem;
    line-height: 1.5;
    min-height: 100vh;
    display: flex;
    justify-content: center;
    align-items: center;
    overflow-x: hidden;
    position: relative;
}

/* Atmospheric candlelight velvet table background */
.mystic-bg-overlay {
    position: fixed;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    /* Smooth radial vignette that glows warm amber in the center (candlelight) fading to deep purple/black velvet */
    background: radial-gradient(circle at center, rgba(217, 180, 97, 0.12) 0%, rgba(18, 14, 28, 0.95) 75%),
                radial-gradient(circle at 50% 30%, rgba(166, 36, 36, 0.1) 0%, transparent 60%),
                var(--color-velvet);
    z-index: -2;
}

/* Flicker effect overlay simulating real candle flames */
.mystic-bg-overlay::after {
    content: "";
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    background: radial-gradient(circle at 50% 40%, rgba(217, 180, 97, 0.05) 0%, transparent 70%);
    opacity: 0.8;
    pointer-events: none;
    animation: candleFlicker 6s infinite ease-in-out;
}

/* Runic dust sparkles */
body::before {
    content: "";
    position: fixed;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    opacity: 0.05;
    pointer-events: none;
    z-index: -1;
    background-image: radial-gradient(var(--color-gold) 1.2px, transparent 1.2px);
    background-size: 24px 24px;
}

/* Main Container: Mystical Obsidian Grimoire Book */
.app-container {
    width: 100%;
    max-width: 520px;
    margin: 1.5rem auto;
    padding: 2rem 1.8rem;
    display: flex;
    flex-direction: column;
    min-height: calc(100vh - 3rem);
    background-color: var(--color-obsidian);
    border: 3px double var(--color-gold);
    box-shadow: 0 20px 50px rgba(0, 0, 0, 0.95),
                0 0 120px rgba(219, 180, 97, 0.08); /* Gold leaf aura */
    position: relative;
    border-radius: 8px;
    background-image: radial-gradient(rgba(219, 180, 97, 0.02) 1px, transparent 0);
    background-size: 8px 8px;
}

/* Screens setup */
.screens-container {
    flex-grow: 1;
    display: flex;
    flex-direction: column;
    justify-content: center;
    position: relative;
    margin: 1.5rem 0;
}

.game-screen {
    display: none;
    flex-direction: column;
    width: 100%;
    animation: fadeIn 0.6s cubic-bezier(0.25, 0.8, 0.25, 1) forwards;
    outline: none;
}

.game-screen.active {
    display: flex;
}

.sr-only {
    position: absolute;
    width: 1px;
    height: 1px;
    padding: 0;
    margin: -1px;
    overflow: hidden;
    clip: rect(0, 0, 0, 0);
    border: 0;
}

/* ==========================================================================
   TYPOGRAPHY & TITLE STYLES
   ========================================================================== */

.app-header {
    text-align: center;
    border-bottom: 2px solid var(--color-gold-dark);
    padding-bottom: 1.2rem;
    margin-bottom: 1rem;
    position: relative;
}

/* Diamond design ornament under header */
.app-header::after {
    content: "🔸 ❖ 🔸";
    position: absolute;
    bottom: -10px;
    left: 50%;
    transform: translateX(-50%);
    background-color: var(--color-obsidian);
    padding: 0 10px;
    font-size: 0.75rem;
    color: var(--color-gold);
    letter-spacing: 2px;
}

.mystic-title {
    font-family: var(--font-heading-fancy);
    font-size: 2.3rem;
    color: var(--color-paper);
    text-shadow: 1px 1px 0px var(--color-ink),
                 0 0 15px rgba(219, 180, 97, 0.4);
    line-height: 1.2;
    letter-spacing: 2px;
}

.mystic-subtitle {
    font-family: var(--font-heading);
    font-size: 0.85rem;
    text-transform: uppercase;
    letter-spacing: 3px;
    margin-top: 0.5rem;
    color: var(--color-gold);
    font-weight: 700;
}

.section-title {
    font-family: var(--font-heading);
    font-size: 1.2rem;
    text-align: center;
    margin-bottom: 1.2rem;
    text-transform: uppercase;
    letter-spacing: 2px;
    border-bottom: 1px solid var(--color-gold-dark);
    padding-bottom: 0.4rem;
    color: var(--color-gold);
}

/* ==========================================================================
   BUTTONS & INPUTS (Gold Foil / Charcoal Contrast)
   ========================================================================== */

.btn-mystic {
    font-family: var(--font-heading);
    background-color: var(--color-gold);
    color: var(--color-ink);
    border: 2px solid var(--color-gold);
    padding: 0.7rem 1.4rem;
    cursor: pointer;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: 2px;
    font-size: 0.95rem;
    transition: all var(--transition-fast);
    filter: url(#woodcut-roughness);
    position: relative;
    box-shadow: 3px 3px 0px var(--color-ink);
}

.btn-mystic:hover:not(:disabled) {
    background-color: var(--color-ink);
    color: var(--color-gold);
    box-shadow: 0px 0px 8px rgba(219, 180, 97, 0.6);
    border-color: var(--color-gold);
}

.btn-mystic:active:not(:disabled) {
    transform: scale(0.98);
}

.btn-mystic:disabled, .btn-mystic.disabled {
    opacity: 0.35;
    cursor: not-allowed;
    box-shadow: none;
    border-color: var(--color-gold-dark);
    color: rgba(255, 255, 255, 0.4);
    background-color: transparent;
}

.btn-large {
    display: block;
    width: 100%;
    padding: 1.1rem;
    font-size: 1.15rem;
    margin-top: 1rem;
}

/* Inputs styling */
.lobby-form .input-group {
    display: flex;
    gap: 0.5rem;
    margin-bottom: 1rem;
}

.lobby-form input[type="text"] {
    flex-grow: 1;
    font-family: var(--font-body);
    font-size: 1.2rem;
    background-color: rgba(255, 255, 255, 0.05);
    border: 2px solid var(--color-gold-dark);
    color: var(--color-paper);
    padding: 0.7rem 1.2rem;
    filter: url(#woodcut-roughness);
    outline: none;
    transition: all var(--transition-fast);
}

.lobby-form input[type="text"]::placeholder {
    color: rgba(245, 242, 235, 0.4);
}

.lobby-form input[type="text"]:focus {
    background-color: rgba(255, 255, 255, 0.09);
    border-color: var(--color-gold);
    box-shadow: 0 0 10px rgba(219, 180, 97, 0.25);
}

/* Sound control Button */
.sound-control-wrapper {
    position: fixed;
    top: 1rem;
    right: 1rem;
    z-index: 10;
}

.btn-icon {
    background: var(--color-obsidian);
    border: 2px solid var(--color-gold);
    color: var(--color-gold);
    width: 42px;
    height: 42px;
    border-radius: 50%;
    cursor: pointer;
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 1.15rem;
    box-shadow: 2px 2px 0 var(--color-ink);
    transition: all var(--transition-fast);
    filter: url(#woodcut-roughness);
}

.btn-icon:hover {
    transform: scale(1.08);
    box-shadow: 0 0 8px var(--color-gold);
}

/* ==========================================================================
   SCREEN 1: LOBBY STYLES
   ========================================================================== */

.intro-box {
    border: 1px dashed var(--color-gold-dark);
    padding: 1.3rem;
    margin-bottom: 1.5rem;
    background-color: rgba(255, 255, 255, 0.03);
    position: relative;
}

.intro-text {
    font-size: 1.05rem;
    text-align: justify;
    font-style: italic;
    color: #c7c3bd;
    line-height: 1.4;
}

/* Player Badge list */
.players-lobby-section {
    margin-bottom: 1.5rem;
    flex-grow: 1;
}

.players-list-badge {
    list-style: none;
    display: flex;
    flex-wrap: wrap;
    gap: 0.8rem;
    justify-content: center;
    padding: 0.8rem 0;
}

.empty-list-msg {
    font-style: italic;
    color: rgba(245, 242, 235, 0.4);
    margin: 1rem auto;
}

.player-badge {
    background-color: rgba(255, 255, 255, 0.04);
    color: var(--color-paper);
    padding: 0.5rem 0.9rem;
    display: inline-flex;
    align-items: center;
    gap: 0.6rem;
    font-family: var(--font-heading);
    font-weight: 700;
    font-size: 0.9rem;
    filter: url(#woodcut-roughness);
    border: 1px solid var(--color-gold-dark);
    box-shadow: 2px 2px 0px var(--color-ink);
    animation: popIn 0.3s cubic-bezier(0.175, 0.885, 0.32, 1.2);
}

.player-badge .remove-player-btn {
    background: transparent;
    border: none;
    color: var(--color-crimson);
    font-weight: 900;
    cursor: pointer;
    font-size: 1.2rem;
    display: inline-flex;
    align-items: center;
    padding: 0 2px;
}

.player-badge .remove-player-btn:hover {
    color: #ff5555;
    transform: scale(1.1);
}

.player-badge .player-icon {
    color: var(--color-gold);
}

/* Archetype Labrador/Cat Selector styling */
.archetype-selector {
    display: flex;
    flex-direction: column;
    gap: 0.4rem;
    margin-bottom: 1.2rem;
    padding: 0.5rem;
    border: 1px solid rgba(219, 180, 97, 0.15);
    background-color: rgba(0, 0, 0, 0.15);
}

.selector-label {
    font-family: var(--font-heading);
    font-size: 0.8rem;
    font-weight: 700;
    color: var(--color-gold);
    text-transform: uppercase;
    letter-spacing: 2px;
    text-align: center;
    margin-bottom: 0.2rem;
}

.archetype-options {
    display: flex;
    gap: 0.8rem;
}

.radio-label {
    flex: 1;
    cursor: pointer;
}

.radio-label input {
    position: absolute;
    opacity: 0;
    width: 0;
    height: 0;
}

.radio-label .custom-radio {
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 0.5rem;
    width: 100%;
    padding: 0.6rem;
    border: 2px solid var(--color-gold-dark);
    background-color: rgba(255, 255, 255, 0.03);
    color: var(--color-paper);
    font-family: var(--font-heading);
    font-weight: 700;
    font-size: 0.9rem;
    filter: url(#woodcut-roughness);
    transition: all var(--transition-fast);
}

.radio-label input:checked + .custom-radio {
    background-color: var(--color-gold);
    color: var(--color-ink);
    border-color: var(--color-gold);
    box-shadow: 0 0 10px rgba(219, 180, 97, 0.4);
}

/* ==========================================================================
   SCREEN 2: GAMEPLAY (DECK SCREEN) STYLES
   ========================================================================== */

.turn-announcement {
    text-align: center;
    margin-bottom: 1rem;
}

.turn-subtitle {
    font-family: var(--font-heading);
    font-size: 0.85rem;
    text-transform: uppercase;
    letter-spacing: 3px;
    color: var(--color-gold);
    font-weight: 700;
}

.active-player-title {
    font-family: var(--font-heading-fancy);
    font-size: 2.1rem;
    color: var(--color-paper);
    margin-top: 0.4rem;
    text-shadow: 0 0 10px rgba(255, 255, 255, 0.2);
}

/* Deck visual stacking */
.deck-area {
    display: flex;
    justify-content: center;
    align-items: center;
    margin: 1.5rem 0;
    min-height: 270px;
}

.deck-container {
    position: relative;
    width: 170px;
    height: 250px;
    perspective: 1000px;
}

.card-deck-visual {
    width: 100%;
    height: 100%;
    position: relative;
    cursor: pointer;
    transform-style: preserve-3d;
    transition: transform var(--transition-medium);
}

.card-deck-visual:hover {
    transform: translateY(-10px) rotateY(-5deg);
}

.deck-card-layer {
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    background-color: var(--color-obsidian);
    border: 3px solid var(--color-gold-dark);
    border-radius: 6px;
    box-shadow: 2px 2px 0px var(--color-ink);
}

.layer-1 {
    transform: translateZ(-15px) rotate(-4deg);
    opacity: 0.3;
}

.layer-2 {
    transform: translateZ(-10px) rotate(3deg);
    opacity: 0.6;
}

.layer-3 {
    transform: translateZ(-5px) rotate(-1.5deg);
    opacity: 0.85;
}

.top-card {
    background-color: var(--color-obsidian);
    border: 3px solid var(--color-gold);
    z-index: 5;
    display: flex;
    flex-direction: column;
    padding: 0.6rem;
    box-shadow: 5px 5px 15px rgba(0, 0, 0, 0.8),
                0 0 15px rgba(219, 180, 97, 0.15);
    transform: rotate(0deg);
}

.deck-back-art {
    flex-grow: 1;
    border: 2px solid var(--color-gold-dark);
    background-image: url('assets/card-back.png');
    background-size: cover;
    background-position: center;
    filter: sepia(0.2) contrast(1.1);
}

.deck-prompt-text {
    font-family: var(--font-heading);
    font-size: 0.85rem;
    text-align: center;
    text-transform: uppercase;
    letter-spacing: 2px;
    margin-top: 0.6rem;
    font-weight: 700;
    color: var(--color-gold);
    border-top: 1px solid var(--color-gold-dark);
    padding-top: 0.4rem;
}

.deck-helper-text {
    font-family: var(--font-heading);
    font-size: 0.8rem;
    text-align: center;
    color: var(--color-gold);
    letter-spacing: 2px;
    text-transform: uppercase;
    font-weight: 700;
    margin-bottom: 1.5rem;
    animation: pulseGold 2s infinite ease-in-out;
}

/* Scoreboard Panel */
.game-scoreboard {
    border-top: 2px solid var(--color-gold-dark);
    padding-top: 1.2rem;
}

.scoreboard-title {
    font-family: var(--font-heading);
    font-size: 0.85rem;
    text-transform: uppercase;
    letter-spacing: 2px;
    text-align: center;
    margin-bottom: 0.8rem;
    color: var(--color-gold);
}

.scoreboard-grid {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(130px, 1fr));
    gap: 0.8rem;
    justify-content: center;
}

.score-item {
    border: 1px solid var(--color-gold-dark);
    padding: 0.6rem;
    background-color: rgba(255, 255, 255, 0.03);
    display: flex;
    flex-direction: column;
    align-items: center;
    text-align: center;
    filter: url(#woodcut-roughness);
    transition: all var(--transition-fast);
}

.score-item.active-turn {
    border: 2px solid var(--color-gold);
    background-color: rgba(255, 255, 255, 0.08);
    box-shadow: 0 0 12px rgba(219, 180, 97, 0.3);
}

.score-name {
    font-family: var(--font-heading);
    font-weight: 700;
    font-size: 0.95rem;
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
    max-width: 100%;
    color: var(--color-paper);
    display: flex;
    align-items: center;
    gap: 0.3rem;
}

.score-lives {
    display: flex;
    gap: 3px;
    margin-top: 0.3rem;
    font-size: 1.05rem;
}

.chalice-icon {
    color: var(--color-crimson);
    text-shadow: 0 0 5px rgba(166, 36, 36, 0.7);
}

.chalice-icon.lost {
    opacity: 0.15;
    filter: grayscale(1);
    transform: scale(0.8) rotate(12deg);
    text-shadow: none;
}

/* ==========================================================================
   SCREEN 3: CARD REVEAL & 3D FLIP STYLES
   ========================================================================== */

.reveal-card-viewport {
    width: 100%;
    display: flex;
    justify-content: center;
    align-items: center;
    perspective: 1200px;
    margin: 0.5rem 0 1.5rem 0;
    height: 380px;
}

.tarot-card-3d {
    width: 250px;
    height: 370px;
    position: relative;
    transform-style: preserve-3d;
    transition: transform var(--transition-slow);
}

.tarot-card-3d.flipped {
    transform: rotateY(180deg);
}

.card-side {
    position: absolute;
    width: 100%;
    height: 100%;
    backface-visibility: hidden;
    border-radius: 6px;
    border: 4px solid var(--color-gold); /* Gold-foiled cards */
    background-color: var(--color-paper);
    color: var(--color-ink);
    padding: 0.6rem;
    box-shadow: 0 20px 40px rgba(0, 0, 0, 0.8),
                0 0 30px rgba(219, 180, 97, 0.1);
}

.card-side.back {
    transform: rotateY(0deg);
    z-index: 2;
    background-color: var(--color-obsidian);
}

.card-side.front {
    transform: rotateY(180deg);
    z-index: 1;
}

.card-inner-border {
    border: 2px solid var(--color-ink);
    height: 100%;
    width: 100%;
    display: flex;
    flex-direction: column;
    padding: 0.6rem;
    position: relative;
}

/* Gold foil highlights for inner border on front */
.card-side.front .card-inner-border {
    border: 2px solid var(--color-ink);
    outline: 1px solid var(--color-gold-dark);
    outline-offset: -5px;
}

.card-art-back {
    flex-grow: 1;
    border: 2px solid var(--color-gold-dark);
    background-image: url('assets/card-back.png');
    background-size: cover;
    background-position: center;
}

.card-header-info {
    text-align: center;
    border-bottom: 2px solid var(--color-ink);
    padding-bottom: 0.4rem;
    margin-bottom: 0.6rem;
}

.arcana-num {
    font-family: var(--font-heading);
    font-size: 0.85rem;
    font-weight: 700;
    letter-spacing: 3px;
    display: block;
    color: var(--color-crimson);
}

.arcana-name {
    font-family: var(--font-heading-fancy);
    font-size: 1.3rem;
    color: var(--color-ink);
    margin-top: 0.1rem;
}

.card-illustration-container {
    height: 165px;
    border: 2px solid var(--color-ink);
    margin-bottom: 0.6rem;
    overflow: hidden;
    background-color: var(--color-paper-dark);
    position: relative;
}

.card-illustration {
    width: 100%;
    height: 100%;
    background-size: cover;
    background-position: center;
    background-repeat: no-repeat;
    transition: transform var(--transition-slow);
}

.card-illustration.placeholder-art {
    display: flex;
    align-items: center;
    justify-content: center;
    background-image: radial-gradient(rgba(219, 180, 97, 0.1) 1px, transparent 0);
    background-size: 6px 6px;
}

.card-illustration.placeholder-art::before {
    content: "🔮";
    font-size: 3rem;
    filter: drop-shadow(0 0 5px rgba(219,180,97,0.5));
}

.card-statement-container {
    flex-grow: 1;
    display: flex;
    flex-direction: column;
    justify-content: center;
    text-align: center;
    border-top: 1px dashed var(--color-ink);
    padding-top: 0.5rem;
}

.statement-prefix {
    font-family: var(--font-heading);
    font-size: 0.8rem;
    text-transform: uppercase;
    letter-spacing: 2px;
    color: var(--color-crimson);
    font-weight: 700;
    margin-bottom: 0.2rem;
}

.statement-text {
    font-family: var(--font-body);
    font-size: 1.1rem;
    font-weight: 700;
    line-height: 1.35;
    font-style: italic;
    color: var(--color-ink);
}

/* Confession panel styles */
.confession-panel {
    border-top: 2px solid var(--color-gold-dark);
    padding-top: 1.2rem;
    text-align: center;
}

.confession-title {
    font-family: var(--font-heading);
    font-size: 1.2rem;
    text-transform: uppercase;
    letter-spacing: 2px;
    color: var(--color-gold);
}

.confession-subtitle {
    font-size: 0.9rem;
    color: #c7c3bd;
    margin-bottom: 1rem;
}

.confession-grid {
    display: grid;
    grid-template-columns: repeat(2, 1fr);
    gap: 0.8rem;
    margin-bottom: 1rem;
}

.confession-btn {
    font-family: var(--font-heading);
    background-color: rgba(255, 255, 255, 0.04);
    border: 2px solid var(--color-gold-dark);
    color: var(--color-paper);
    padding: 0.7rem;
    cursor: pointer;
    font-weight: 700;
    text-transform: uppercase;
    font-size: 0.85rem;
    letter-spacing: 1px;
    transition: all var(--transition-fast);
    filter: url(#woodcut-roughness);
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 0.5rem;
}

.confession-btn:hover {
    background-color: rgba(255, 255, 255, 0.08);
    border-color: var(--color-gold);
}

.confession-btn.confessed {
    background-color: var(--color-crimson);
    color: var(--color-paper);
    border-color: var(--color-gold);
    box-shadow: inset 0 0 15px rgba(0,0,0,0.6), 0 0 8px rgba(166, 36, 36, 0.5);
}

.confession-btn .confession-mark {
    opacity: 0.25;
    font-size: 1rem;
    filter: grayscale(1);
    transition: all var(--transition-fast);
}

.confession-btn.confessed .confession-mark {
    opacity: 1;
    filter: none;
    transform: scale(1.15);
}

/* ==========================================================================
   SCREEN 4: GAME OVER STYLES
   ========================================================================== */

.gameover-summary {
    margin-bottom: 1.5rem;
}

.standings-box {
    border: 2px solid var(--color-gold);
    padding: 1.5rem;
    background-color: rgba(0, 0, 0, 0.3);
    margin-bottom: 2rem;
    filter: url(#woodcut-roughness);
}

.rankings-list {
    display: flex;
    flex-direction: column;
    gap: 0.9rem;
}

.ranking-item {
    display: flex;
    align-items: center;
    justify-content: space-between;
    border-bottom: 1px dashed rgba(219, 180, 97, 0.2);
    padding-bottom: 0.6rem;
}

.ranking-item:last-child {
    border-bottom: none;
}

.ranking-player-name {
    font-family: var(--font-heading);
    font-weight: 700;
    font-size: 1.15rem;
    display: flex;
    align-items: center;
    gap: 0.5rem;
}

.ranking-lives-info {
    font-family: var(--font-body);
    color: var(--color-gold);
    font-weight: 700;
}

.ranking-title-badge {
    background-color: rgba(255, 255, 255, 0.08);
    color: var(--color-paper);
    font-family: var(--font-heading);
    font-size: 0.75rem;
    padding: 0.2rem 0.6rem;
    text-transform: uppercase;
    letter-spacing: 1.5px;
    margin-left: 0.5rem;
    font-weight: 700;
    border: 1px solid var(--color-gold-dark);
}

.ranking-title-badge.pure {
    background-color: var(--color-gold);
    color: var(--color-ink);
    border-color: var(--color-gold);
    box-shadow: 0 0 10px rgba(219,180,97,0.3);
}

.ranking-title-badge.doomed {
    background-color: var(--color-crimson);
    color: var(--color-paper);
    border-color: var(--color-crimson);
    box-shadow: 0 0 10px rgba(166,36,36,0.3);
}

/* ==========================================================================
   ANIMATIONS & EFFECTS
   ========================================================================== */

@keyframes fadeIn {
    from {
        opacity: 0;
        transform: translateY(12px);
    }
    to {
        opacity: 1;
        transform: translateY(0);
    }
}

@keyframes popIn {
    0% {
        transform: scale(0.85);
        opacity: 0;
    }
    100% {
        transform: scale(1);
        opacity: 1;
    }
}

@keyframes candleFlicker {
    0%, 100% {
        opacity: 0.85;
        transform: scale(1);
    }
    30% {
        opacity: 0.75;
        transform: scale(1.02) translate(1px, -1px);
    }
    60% {
        opacity: 0.95;
        transform: scale(0.98) translate(-1px, 1px);
    }
    80% {
        opacity: 0.8;
        transform: scale(1.01) translate(0.5px, 0.5px);
    }
}

@keyframes pulseGold {
    0%, 100% {
        text-shadow: 0 0 2px rgba(219, 180, 97, 0.3);
        opacity: 0.85;
    }
    50% {
        text-shadow: 0 0 10px rgba(219, 180, 97, 0.7);
        opacity: 1;
    }
}

/* Responsive adjust for mobile */
@media (max-width: 480px) {
    .app-container {
        margin: 0;
        border: none;
        border-radius: 0;
        box-shadow: none;
        min-height: 100vh;
        padding: 1.5rem 1rem;
    }
    
    .mystic-title {
        font-size: 1.9rem;
    }
    
    .reveal-card-viewport {
        height: 330px;
    }
    
    .tarot-card-3d {
        width: 220px;
        height: 320px;
    }
    
    .card-illustration-container {
        height: 130px;
    }
}

/* ==========================================================================
   PARTICLES CANVAS & CUSTOM DIALOGS (Evolução do Motor)
   ========================================================================== */

#mystic-particles {
    position: fixed;
    top: 0;
    left: 0;
    width: 100vw;
    height: 100vh;
    pointer-events: none;
    z-index: -1;
}

dialog#custom-card-dialog {
    border: 3px double var(--color-gold-dark);
    background-color: var(--color-paper);
    color: var(--color-ink);
    border-radius: 8px;
    padding: 1.5rem;
    max-width: 440px;
    width: 90%;
    margin: auto;
    box-shadow: 0 30px 60px rgba(0, 0, 0, 0.95), 0 0 40px rgba(217, 180, 97, 0.2);
    filter: url(#woodcut-roughness);
    outline: none;
    position: fixed;
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%);
}

dialog#custom-card-dialog[open] {
    display: flex;
    flex-direction: column;
}

dialog#custom-card-dialog::backdrop {
    background-color: rgba(8, 6, 12, 0.88);
    backdrop-filter: blur(5px);
}

dialog#custom-card-dialog .section-title {
    color: var(--color-ink);
    border-bottom: 2px solid var(--color-gold-dark);
    margin-bottom: 1.2rem;
    text-align: center;
}

.input-group-vertical {
    display: flex;
    flex-direction: column;
    gap: 0.4rem;
    text-align: left;
}

.dialog-label {
    font-family: var(--font-heading);
    font-weight: 700;
    font-size: 0.95rem;
    color: var(--color-ink);
    letter-spacing: 1px;
}

dialog#custom-card-dialog input[type="text"],
dialog#custom-card-dialog textarea {
    font-family: var(--font-body);
    font-size: 1.15rem;
    background-color: rgba(0, 0, 0, 0.04);
    border: 2px solid var(--color-gold-dark);
    color: var(--color-ink);
    padding: 0.6rem 0.9rem;
    filter: url(#woodcut-roughness);
    outline: none;
    transition: all var(--transition-fast);
}

dialog#custom-card-dialog input[type="text"]:focus,
dialog#custom-card-dialog textarea:focus {
    border-color: var(--color-ink);
    background-color: rgba(0, 0, 0, 0.08);
}

.symbol-options {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 0.5rem;
    margin-top: 0.4rem;
    width: 100%;
}

.symbol-options .radio-label {
    position: relative;
    cursor: pointer;
    flex: 1;
    margin: 0;
}

.symbol-options .custom-radio {
    display: flex;
    justify-content: center;
    align-items: center;
    gap: 0.4rem;
    padding: 0.5rem;
    border: 2px solid var(--color-gold-dark);
    background-color: rgba(255, 255, 255, 0.5);
    color: var(--color-ink);
    font-family: var(--font-body);
    font-size: 1rem;
    font-weight: 700;
    filter: url(#woodcut-roughness);
    transition: all var(--transition-fast);
    text-align: center;
}

.symbol-options input[type="radio"]:checked + .custom-radio {
    background-color: var(--color-ink);
    color: var(--color-paper);
    border-color: var(--color-ink);
    box-shadow: 2px 2px 0 var(--color-gold-dark);
}

/* Custom card illustration mockup styling */
.custom-card-symbol-badge {
    font-size: 3.5rem;
    display: flex;
    align-items: center;
    justify-content: center;
    width: 100%;
    height: 100%;
    background-color: rgba(17, 14, 19, 0.03);
    border: 2px dashed var(--color-ink);
}

/* ==========================================================================
   THEME STYLE OVERRIDES (Gold, Classic, Cosmic)
   ========================================================================== */

/* Theme Selector Container */
.theme-control-wrapper {
    position: fixed;
    top: 1rem;
    left: 1rem;
    z-index: 10;
}

.theme-select {
    background: var(--color-obsidian);
    border: 2px solid var(--color-gold);
    color: var(--color-paper);
    font-family: var(--font-heading);
    font-size: 0.85rem;
    padding: 0.4rem 0.8rem;
    border-radius: 4px;
    cursor: pointer;
    box-shadow: 2px 2px 0 var(--color-ink);
    transition: all var(--transition-fast);
    outline: none;
    filter: url(#woodcut-roughness);
}

.theme-select:hover {
    transform: scale(1.03);
    border-color: var(--color-paper);
}

/* 1. MÍSTICO & FOLHA DE OURO (DEFAULT OR .theme-gold) */
body.theme-gold {
    /* Gold is default but explicitly declared for variable scoping */
}

body.theme-gold .mystic-bg-overlay {
    background: radial-gradient(circle at center, rgba(217, 180, 97, 0.12) 0%, rgba(14, 9, 27, 0.98) 75%),
                radial-gradient(circle at 50% 30%, rgba(166, 36, 36, 0.08) 0%, transparent 60%),
                #0e091b;
}

body.theme-gold .app-container {
    background-color: rgba(18, 16, 23, 0.85);
    backdrop-filter: blur(12px);
    -webkit-backdrop-filter: blur(12px);
    border: 2px solid var(--color-gold);
    box-shadow: 0 20px 50px rgba(0, 0, 0, 0.9),
                0 0 50px rgba(217, 180, 97, 0.12);
}

body.theme-gold .btn-mystic {
    background-color: rgba(217, 180, 97, 0.08);
    color: var(--color-gold);
    border: 2px solid var(--color-gold);
    backdrop-filter: blur(4px);
    box-shadow: 0 4px 10px rgba(0, 0, 0, 0.3), inset 0 0 10px rgba(217, 180, 97, 0.05);
}

body.theme-gold .btn-mystic:hover:not(:disabled) {
    background-color: var(--color-gold);
    color: #110e13;
    box-shadow: 0 0 15px rgba(217, 180, 97, 0.8);
}


/* 2. XILOGRAVURA MEDIEVAL CLÁSSICA (.theme-classic) */
body.theme-classic {
    --color-paper: #1c130d;
    --color-paper-dark: #eddcb9;
    --color-ink: #1c130d;
    --color-crimson: #a62424;
    --color-gold: #1c130d;
    --color-gold-dark: #3a2c22;
    --color-obsidian: #eddcb9;
    --color-velvet: #15100c;
}

body.theme-classic::before {
    display: none; /* Hide runic gold dust sparkles */
}

body.theme-classic .mystic-bg-overlay {
    background-color: #1c1511;
    background-image: 
        linear-gradient(rgba(0,0,0,0.65), rgba(0,0,0,0.92)),
        repeating-linear-gradient(0deg, transparent, transparent 40px, rgba(0,0,0,0.15) 40px, rgba(0,0,0,0.15) 80px),
        linear-gradient(90deg, #2d1d13, #150d09);
    background-size: auto;
}

body.theme-classic .app-container {
    background-color: #f3e6cd;
    background-image: radial-gradient(rgba(0, 0, 0, 0.04) 1px, transparent 0);
    background-size: 8px 8px;
    color: #1c130d;
    border: 4px double #1c130d;
    border-radius: 4px;
    box-shadow: 0 15px 35px rgba(0, 0, 0, 0.85);
}

/* Worn wood block stamp buttons for theme-classic */
body.theme-classic .btn-mystic {
    background-color: #1c130d;
    color: #f3e6cd;
    border: 3px solid #1c130d;
    box-shadow: 4px 4px 0px #4d3a2f;
    font-family: var(--font-heading-fancy);
    font-weight: 900;
    text-transform: uppercase;
    border-radius: 0;
}

body.theme-classic .btn-mystic:hover:not(:disabled) {
    background-color: #4d3a2f;
    color: #f3e6cd;
    box-shadow: none;
    transform: translate(2px, 2px);
}

body.theme-classic .input-group input[type="text"],
body.theme-classic dialog#custom-card-dialog input[type="text"],
body.theme-classic dialog#custom-card-dialog textarea {
    background-color: rgba(28, 19, 13, 0.08);
    border-color: #1c130d;
    color: #1c130d;
}

body.theme-classic .score-item {
    background-color: rgba(28, 19, 13, 0.05);
    border: 1px solid #1c130d;
    color: #1c130d;
}

body.theme-classic .score-item.active-turn {
    background-color: rgba(28, 19, 13, 0.12);
    border-width: 2px;
}

body.theme-classic .card-side.front,
body.theme-classic .card-side.back {
    background-color: #f7ede2;
    border-color: #1c130d;
    color: #1c130d;
}

body.theme-classic .card-side.back .card-inner-border {
    border-color: #1c130d;
}

body.theme-classic .card-header-info {
    border-bottom-color: #1c130d;
}

body.theme-classic .card-illustration-container {
    border-color: #1c130d;
}

body.theme-classic .card-statement-container {
    border-top-color: #1c130d;
}

body.theme-classic .confession-btn {
    border: 2px solid #1c130d;
    background-color: transparent;
    color: #1c130d;
}

body.theme-classic .confession-btn.confessed {
    background-color: #1c130d;
    color: #f3e6cd;
}


/* 3. SÁFICO CÓSMICO (.theme-cosmic) */
body.theme-cosmic {
    --color-paper: #fef5ff;
    --color-paper-dark: #ebd3ff;
    --color-ink: #1a082c;
    --color-crimson: #ff2e63;
    --color-gold: #da70d6;
    --color-gold-dark: #ba55d3;
    --color-obsidian: #10061e;
    --color-velvet: #07020d;
}

body.theme-cosmic::before {
    background-image: radial-gradient(#da70d6 1.2px, transparent 1.2px); /* Pink/violet cosmic dust */
    opacity: 0.08;
}

body.theme-cosmic .mystic-bg-overlay {
    background: radial-gradient(circle at 20% 30%, rgba(186, 85, 211, 0.15) 0%, transparent 65%),
                radial-gradient(circle at 80% 80%, rgba(219, 112, 147, 0.15) 0%, transparent 65%),
                radial-gradient(circle at center, rgba(218, 112, 147, 0.05) 0%, transparent 70%),
                #0b0416;
}

/* Add an extra nebulous animation to cosmic bg */
body.theme-cosmic .mystic-bg-overlay::after {
    animation: cosmicPulse 10s infinite ease-in-out;
}

@keyframes cosmicPulse {
    0%, 100% { opacity: 0.4; filter: hue-rotate(0deg); }
    50% { opacity: 0.7; filter: hue-rotate(45deg); }
}

body.theme-cosmic .app-container {
    background-color: rgba(16, 6, 30, 0.85);
    border: 2px solid #da70d6;
    box-shadow: 0 20px 50px rgba(0, 0, 0, 0.95),
                0 0 45px rgba(219, 112, 147, 0.18);
}

body.theme-cosmic .btn-mystic {
    background-color: rgba(218, 112, 147, 0.1);
    color: #ff9cfb;
    border: 2px solid #da70d6;
    box-shadow: 3px 3px 0px #1a082c;
}

body.theme-cosmic .btn-mystic:hover:not(:disabled) {
    background-color: #da70d6;
    color: #1a082c;
    box-shadow: 0 0 15px rgba(218, 112, 147, 0.6);
}

body.theme-cosmic .chalice-icon {
    filter: drop-shadow(0 0 3px #ff2e63) hue-rotate(-10deg) saturate(1.8);
}

body.theme-cosmic .chalice-icon.lost {
    opacity: 0.15;
}

/* Cosmic fade transition for screens */
body.theme-cosmic .game-screen {
    animation: cosmicFadeIn 0.8s cubic-bezier(0.19, 1, 0.22, 1) forwards;
}

@keyframes cosmicFadeIn {
    from { opacity: 0; filter: blur(6px) brightness(1.3); transform: scale(0.96); }
    to { opacity: 1; filter: blur(0) brightness(1); transform: scale(1); }
}

/* Soft glowing auras by archetype in cosmic mode */
body.theme-cosmic .score-item.arch-labrador {
    box-shadow: 0 0 12px rgba(217, 180, 97, 0.22);
    border: 1px solid rgba(217, 180, 97, 0.35);
}

body.theme-cosmic .score-item.arch-gato-preto {
    box-shadow: 0 0 12px rgba(186, 85, 211, 0.28);
    border: 1px solid rgba(186, 85, 211, 0.42);
}

/* Scoreboard Archetype Styles for all themes */
.score-item.arch-labrador {
    border-left: 3.5px solid var(--color-gold);
    padding-left: 0.5rem;
    transition: all var(--transition-fast);
}

.score-item.arch-gato-preto {
    border-left: 3.5px solid var(--color-crimson);
    padding-left: 0.5rem;
    transition: all var(--transition-fast);
}

.score-item.active-turn.arch-labrador {
    box-shadow: inset 4px 0 0 var(--color-gold), 0 0 10px rgba(219, 180, 97, 0.15);
}

.score-item.active-turn.arch-gato-preto {
    box-shadow: inset 4px 0 0 var(--color-crimson), 0 0 10px rgba(166, 36, 36, 0.15);
}


