/* ============================================================
   CAPNOMANCIA v1 — Estilos
   Estética: Noche profunda, humo etéreo, plata y violeta oscuro
   Fuentes: Cinzel Decorative (títulos) + EB Garamond (texto)
   ============================================================ */

@import url('https://fonts.googleapis.com/css2?family=Cinzel+Decorative:wght@400;700&family=EB+Garamond:ital,wght@0,400;0,500;1,400;1,500&display=swap');

/* ============================================================
   VARIABLES DE DISEÑO
   ============================================================ */
#capnomancia-app {
    --cap-bg:           #07060d;
    --cap-bg-mid:       #0e0c1a;
    --cap-bg-surface:   #161225;
    --cap-bg-card:      #120f1e;

    --cap-smoke-1:      rgba(200, 195, 220, 0.18);
    --cap-smoke-2:      rgba(160, 150, 190, 0.12);
    --cap-smoke-3:      rgba(120, 110, 160, 0.08);

    --cap-violet:       #7c60c8;
    --cap-violet-light: #a88fd8;
    --cap-violet-pale:  #d0c0f0;
    --cap-silver:       #c8c0d8;
    --cap-silver-light: #e8e2f4;
    --cap-silver-dim:   #7a7490;
    --cap-gold:         #b89a5a;
    --cap-gold-light:   #d4b870;

    --cap-ember:        #ff6030;
    --cap-ember-glow:   rgba(255, 80, 20, 0.35);

    --cap-positivo:     #72c89a;
    --cap-negativo:     #e07878;
    --cap-neutral:      #b89a5a;
    --cap-mistico:      #a88fd8;

    --cap-text:         #d8d0ec;
    --cap-text-dim:     #7a7490;
    --cap-text-muted:   #4a4460;

    --cap-border:       rgba(200, 192, 220, 0.12);
    --cap-border-bright: rgba(200, 192, 220, 0.28);

    font-family: 'EB Garamond', 'Georgia', serif;
    font-size: 17px;
    color: var(--cap-text);
    background: var(--cap-bg);
    min-height: 580px;
    position: relative;
    overflow: hidden;
}

/* ============================================================
   RESET DENTRO DEL SCOPE DE LA APP
   ============================================================ */
#capnomancia-app *, #capnomancia-app *::before, #capnomancia-app *::after {
    box-sizing: border-box;
    margin: 0;
    padding: 0;
}

#capnomancia-app button {
    font-family: inherit;
    cursor: pointer;
    border: none;
    background: none;
}

#capnomancia-app .hidden {
    display: none !important;
}

/* ============================================================
   PANTALLAS BASE
   ============================================================ */
#capnomancia-app .cap-screen {
    position: relative;
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    min-height: 620px;
    padding: 50px 24px 60px;
    text-align: center;
    overflow: hidden;
}

/* ============================================================
   FONDO AMBIENTE — NIEBLA Y PARTÍCULAS
   ============================================================ */
#capnomancia-app .cap-bg {
    position: absolute;
    inset: 0;
    pointer-events: none;
    z-index: 0;
    background:
        radial-gradient(ellipse at 30% 20%, rgba(100, 70, 180, 0.10) 0%, transparent 55%),
        radial-gradient(ellipse at 75% 80%, rgba(70, 50, 140, 0.08) 0%, transparent 50%),
        radial-gradient(ellipse at center, var(--cap-bg-mid) 0%, var(--cap-bg) 100%);
}

#capnomancia-app .cap-bg--ritual {
    background:
        radial-gradient(ellipse at 50% 70%, rgba(255, 80, 20, 0.08) 0%, transparent 50%),
        radial-gradient(ellipse at center, #100d1c 0%, var(--cap-bg) 100%);
}

/* Volutas de niebla de fondo */
#capnomancia-app .cap-bg__mist {
    position: absolute;
    border-radius: 50%;
    background: radial-gradient(ellipse, var(--cap-smoke-1) 0%, transparent 70%);
    animation: cap-mist-drift 18s ease-in-out infinite;
    pointer-events: none;
}

#capnomancia-app .cap-bg__mist--1 {
    width: 600px; height: 300px;
    top: -80px; left: -100px;
    animation-duration: 22s;
}
#capnomancia-app .cap-bg__mist--2 {
    width: 500px; height: 250px;
    bottom: -60px; right: -80px;
    animation-duration: 28s;
    animation-delay: -8s;
}
#capnomancia-app .cap-bg__mist--3 {
    width: 400px; height: 200px;
    top: 40%; left: 50%;
    transform: translateX(-50%);
    animation-duration: 20s;
    animation-delay: -4s;
}

#capnomancia-app .cap-bg__mist--dark-1 {
    width: 700px; height: 400px;
    top: -50px; left: -150px;
    background: radial-gradient(ellipse, rgba(80, 60, 120, 0.15) 0%, transparent 70%);
    animation-duration: 25s;
}
#capnomancia-app .cap-bg__mist--dark-2 {
    width: 600px; height: 350px;
    bottom: -80px; right: -100px;
    background: radial-gradient(ellipse, rgba(60, 40, 100, 0.12) 0%, transparent 70%);
    animation-duration: 30s;
    animation-delay: -12s;
}

#capnomancia-app .cap-bg__mist--result-1 {
    width: 500px; height: 280px;
    top: 0; left: 50%;
    transform: translateX(-50%);
    background: radial-gradient(ellipse, rgba(120, 90, 200, 0.10) 0%, transparent 70%);
    animation-duration: 20s;
}
#capnomancia-app .cap-bg__mist--result-2 {
    width: 600px; height: 300px;
    bottom: 0; left: 50%;
    transform: translateX(-50%);
    background: radial-gradient(ellipse, rgba(80, 60, 150, 0.08) 0%, transparent 70%);
    animation-duration: 26s;
    animation-delay: -10s;
}

@keyframes cap-mist-drift {
    0%   { transform: translate(0, 0) scale(1); opacity: 0.6; }
    33%  { transform: translate(30px, -20px) scale(1.08); opacity: 0.9; }
    66%  { transform: translate(-20px, 15px) scale(0.95); opacity: 0.7; }
    100% { transform: translate(0, 0) scale(1); opacity: 0.6; }
}

/* Partículas flotantes */
#capnomancia-app .cap-bg__particle {
    position: absolute;
    color: var(--cap-violet);
    font-size: 10px;
    opacity: 0;
    animation: cap-particle-float 6s ease-in-out infinite;
    pointer-events: none;
}

#capnomancia-app .cap-bg__particle--1 { top: 15%; left: 10%; animation-delay: 0s;   animation-duration: 7s; }
#capnomancia-app .cap-bg__particle--2 { top: 25%; right: 15%; animation-delay: 1.5s; animation-duration: 8s; font-size: 8px; }
#capnomancia-app .cap-bg__particle--3 { top: 60%; left: 20%; animation-delay: 3s;   animation-duration: 6s; }
#capnomancia-app .cap-bg__particle--4 { bottom: 20%; right: 10%; animation-delay: 4.5s; animation-duration: 9s; font-size: 8px; }
#capnomancia-app .cap-bg__particle--5 { bottom: 35%; left: 50%; animation-delay: 2s;   animation-duration: 7.5s; }

@keyframes cap-particle-float {
    0%   { opacity: 0; transform: translateY(0); }
    20%  { opacity: 0.4; }
    60%  { opacity: 0.3; }
    80%  { opacity: 0; }
    100% { opacity: 0; transform: translateY(-30px); }
}

/* ============================================================
   PANTALLA INTRO — CONTENIDO
   ============================================================ */
#capnomancia-app .cap-intro__content {
    position: relative;
    z-index: 1;
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 0;
    max-width: 580px;
    width: 100%;
}

/* Sello SVG animado */
#capnomancia-app .cap-seal {
    position: relative;
    width: 130px;
    height: 130px;
    margin-bottom: 24px;
}

#capnomancia-app .cap-seal__svg {
    width: 100%;
    height: 100%;
    color: var(--cap-violet-light);
    animation: cap-seal-rotate 60s linear infinite;
    filter: drop-shadow(0 0 8px rgba(140, 100, 220, 0.3));
}

@keyframes cap-seal-rotate {
    from { transform: rotate(0deg); }
    to   { transform: rotate(360deg); }
}

/* Humo dentro del sello */
#capnomancia-app .cap-seal__smoke {
    position: absolute;
    bottom: 18px;
    left: 50%;
    transform: translateX(-50%);
    width: 30px;
    height: 60px;
}

#capnomancia-app .cap-seal__smoke-tendril {
    position: absolute;
    bottom: 0;
    width: 6px;
    border-radius: 50%;
    background: linear-gradient(to top, rgba(180, 160, 220, 0.6), transparent);
    animation: cap-seal-smoke-rise 3s ease-out infinite;
}
#capnomancia-app .cap-seal__smoke-tendril--1 { left: 4px;  height: 40px; animation-delay: 0s;    animation-duration: 3.2s; }
#capnomancia-app .cap-seal__smoke-tendril--2 { left: 12px; height: 55px; animation-delay: 0.8s;  animation-duration: 2.8s; }
#capnomancia-app .cap-seal__smoke-tendril--3 { left: 20px; height: 35px; animation-delay: 1.6s;  animation-duration: 3.5s; }

@keyframes cap-seal-smoke-rise {
    0%   { transform: translateX(0)   scaleX(1); opacity: 0.7; }
    40%  { transform: translateX(-4px) scaleX(1.3); opacity: 0.5; }
    70%  { transform: translateX(3px)  scaleX(0.9); opacity: 0.3; }
    100% { transform: translateX(-2px) scaleX(0.8) translateY(-15px); opacity: 0; }
}

/* Tipografía intro */
#capnomancia-app .cap-title {
    font-family: 'Cinzel Decorative', serif;
    font-size: clamp(2rem, 5vw, 2.8rem);
    font-weight: 400;
    letter-spacing: 0.06em;
    color: var(--cap-silver-light);
    text-shadow: 0 0 30px rgba(160, 130, 230, 0.4), 0 2px 4px rgba(0,0,0,0.6);
    margin-bottom: 8px;
    line-height: 1.2;
}

#capnomancia-app .cap-subtitle {
    font-family: 'EB Garamond', serif;
    font-style: italic;
    font-size: clamp(1rem, 2.5vw, 1.2rem);
    color: var(--cap-violet-light);
    letter-spacing: 0.12em;
    margin-bottom: 20px;
    text-transform: uppercase;
    font-size: 0.9rem;
}

#capnomancia-app .cap-divider {
    margin: 0 0 20px;
    color: var(--cap-violet);
    letter-spacing: 0.3em;
    font-size: 0.8rem;
    opacity: 0.6;
}

#capnomancia-app .cap-description {
    font-size: clamp(0.95rem, 2vw, 1.05rem);
    line-height: 1.75;
    color: var(--cap-silver-dim);
    font-style: italic;
    max-width: 500px;
    margin-bottom: 36px;
}

/* ============================================================
   BOTONES
   ============================================================ */
#capnomancia-app .cap-btn {
    display: inline-flex;
    align-items: center;
    gap: 10px;
    padding: 14px 34px;
    border-radius: 2px;
    font-family: 'Cinzel Decorative', serif;
    font-size: 0.78rem;
    font-weight: 400;
    letter-spacing: 0.12em;
    text-transform: uppercase;
    transition: all 0.3s ease;
    position: relative;
    overflow: hidden;
    cursor: pointer;
}

#capnomancia-app .cap-btn::before {
    content: '';
    position: absolute;
    inset: 0;
    background: linear-gradient(135deg, transparent 40%, rgba(255,255,255,0.04) 100%);
    pointer-events: none;
}

#capnomancia-app .cap-btn--invocar {
    background: linear-gradient(135deg, #2a2040 0%, #1e1830 50%, #2a2040 100%);
    border: 1px solid var(--cap-violet);
    color: var(--cap-violet-pale);
    box-shadow:
        0 0 20px rgba(120, 90, 200, 0.25),
        inset 0 1px 0 rgba(180, 150, 255, 0.1);
}

#capnomancia-app .cap-btn--invocar:hover {
    background: linear-gradient(135deg, #352850 0%, #28204a 50%, #352850 100%);
    border-color: var(--cap-violet-light);
    box-shadow:
        0 0 35px rgba(140, 100, 230, 0.45),
        0 0 10px rgba(140, 100, 230, 0.2),
        inset 0 1px 0 rgba(200, 170, 255, 0.15);
    transform: translateY(-1px);
}

#capnomancia-app .cap-btn--invocar:active {
    transform: translateY(0);
}

#capnomancia-app .cap-btn__icon {
    font-size: 1.1em;
}

#capnomancia-app .cap-btn--nueva {
    background: transparent;
    border: 1px solid var(--cap-border-bright);
    color: var(--cap-silver-dim);
    padding: 12px 28px;
    font-size: 0.72rem;
    letter-spacing: 0.15em;
    margin-top: 28px;
}

#capnomancia-app .cap-btn--nueva:hover {
    border-color: var(--cap-violet);
    color: var(--cap-violet-light);
    box-shadow: 0 0 15px rgba(120, 90, 200, 0.2);
    transform: translateY(-1px);
}

/* ============================================================
   PANTALLA RITUAL — BRASERO Y HUMO
   ============================================================ */
#capnomancia-app .cap-incense {
    position: relative;
    z-index: 1;
    display: flex;
    flex-direction: column;
    align-items: center;
    margin-bottom: 30px;
}

/* Columnas de humo principal */
#capnomancia-app .cap-smoke-stage {
    position: relative;
    width: 120px;
    height: 260px;
    display: flex;
    justify-content: center;
    align-items: flex-end;
}

#capnomancia-app .cap-smoke--main {
    position: absolute;
    bottom: 0;
    left: 50%;
    transform: translateX(-50%);
    width: 80px;
    height: 100%;
}

#capnomancia-app .cap-smoke__tendril {
    position: absolute;
    bottom: 0;
    border-radius: 40% 60% 60% 40% / 40% 40% 60% 60%;
    background: linear-gradient(to top,
        rgba(200, 192, 230, 0.55),
        rgba(160, 150, 210, 0.3),
        rgba(120, 110, 180, 0.1),
        transparent
    );
    animation: cap-tendril-rise var(--dur, 4s) ease-out infinite;
    transform-origin: bottom center;
    filter: blur(var(--blur, 3px));
}

#capnomancia-app .cap-smoke__tendril--1 {
    width: 22px; height: 180px;
    left: 10px;
    --dur: 4.2s; --blur: 4px;
    animation-delay: 0s;
}
#capnomancia-app .cap-smoke__tendril--2 {
    width: 28px; height: 220px;
    left: 26px;
    --dur: 3.8s; --blur: 5px;
    animation-delay: 0.3s;
}
#capnomancia-app .cap-smoke__tendril--3 {
    width: 24px; height: 200px;
    left: 44px;
    --dur: 4.6s; --blur: 4px;
    animation-delay: 0.6s;
}
#capnomancia-app .cap-smoke__tendril--4 {
    width: 20px; height: 160px;
    left: 8px;
    --dur: 3.5s; --blur: 3px;
    animation-delay: 1.2s;
    opacity: 0.7;
}
#capnomancia-app .cap-smoke__tendril--5 {
    width: 26px; height: 240px;
    left: 32px;
    --dur: 5s; --blur: 6px;
    animation-delay: 0.9s;
    opacity: 0.8;
}
#capnomancia-app .cap-smoke__tendril--6 {
    width: 18px; height: 150px;
    left: 52px;
    --dur: 4s; --blur: 3px;
    animation-delay: 1.8s;
    opacity: 0.6;
}

@keyframes cap-tendril-rise {
    0% {
        transform: translateX(0) scaleX(1) translateY(0);
        opacity: 0.8;
    }
    25% {
        transform: translateX(-8px) scaleX(1.3) translateY(-15px);
        opacity: 0.7;
    }
    55% {
        transform: translateX(10px) scaleX(0.9) translateY(-30px);
        opacity: 0.4;
    }
    80% {
        transform: translateX(-5px) scaleX(1.1) translateY(-50px);
        opacity: 0.15;
    }
    100% {
        transform: translateX(4px) scaleX(0.7) translateY(-80px);
        opacity: 0;
    }
}

/* Brasas flotantes */
#capnomancia-app .cap-embers {
    position: absolute;
    bottom: 10px;
    left: 50%;
    transform: translateX(-50%);
    width: 60px;
    height: 40px;
}

#capnomancia-app .cap-ember {
    position: absolute;
    width: 3px; height: 3px;
    border-radius: 50%;
    background: var(--cap-ember);
    box-shadow: 0 0 6px 2px var(--cap-ember-glow);
    animation: cap-ember-rise var(--ed, 2s) ease-out infinite;
    opacity: 0;
}

#capnomancia-app .cap-ember--1 { left: 10px; --ed: 2.2s; animation-delay: 0s; }
#capnomancia-app .cap-ember--2 { left: 28px; --ed: 1.8s; animation-delay: 0.4s; }
#capnomancia-app .cap-ember--3 { left: 44px; --ed: 2.5s; animation-delay: 0.8s; }
#capnomancia-app .cap-ember--4 { left: 20px; --ed: 2s;   animation-delay: 1.2s; }

@keyframes cap-ember-rise {
    0%   { opacity: 0; transform: translate(0, 0); }
    15%  { opacity: 1; }
    60%  { opacity: 0.6; transform: translate(calc(var(--ex, 5px) * 1), -30px); }
    100% { opacity: 0; transform: translate(calc(var(--ex, -5px) * 1), -60px) scale(0.3); }
}

/* Cuerpo del brasero */
#capnomancia-app .cap-brazier {
    display: flex;
    flex-direction: column;
    align-items: center;
    position: relative;
    z-index: 2;
}

#capnomancia-app .cap-brazier__bowl {
    width: 72px; height: 36px;
    background: linear-gradient(180deg, #2a1810 0%, #1a0e08 50%, #0e0806 100%);
    border-radius: 50% 50% 45% 45% / 60% 60% 40% 40%;
    border: 1px solid rgba(180, 100, 40, 0.3);
    position: relative;
    box-shadow:
        inset 0 -4px 12px rgba(255, 80, 20, 0.15),
        0 2px 8px rgba(0,0,0,0.6);
}

#capnomancia-app .cap-brazier__glow {
    position: absolute;
    bottom: 6px;
    left: 50%;
    transform: translateX(-50%);
    width: 40px; height: 10px;
    background: radial-gradient(ellipse, rgba(255, 100, 30, 0.5) 0%, transparent 80%);
    border-radius: 50%;
    animation: cap-brazier-glow-pulse 2s ease-in-out infinite;
}

@keyframes cap-brazier-glow-pulse {
    0%, 100% { opacity: 0.6; transform: translateX(-50%) scale(1); }
    50%      { opacity: 1; transform: translateX(-50%) scale(1.15); }
}

#capnomancia-app .cap-brazier__stem {
    width: 8px; height: 20px;
    background: linear-gradient(180deg, #1e1510, #141010);
    border-left: 1px solid rgba(120, 80, 40, 0.2);
    border-right: 1px solid rgba(120, 80, 40, 0.2);
}

#capnomancia-app .cap-brazier__base {
    width: 50px; height: 8px;
    background: linear-gradient(180deg, #1e1510, #0e0c0a);
    border-radius: 2px;
    border: 1px solid rgba(100, 70, 30, 0.2);
    box-shadow: 0 2px 6px rgba(0,0,0,0.5);
}

#capnomancia-app .cap-ritual__msg {
    position: relative;
    z-index: 1;
    font-family: 'EB Garamond', serif;
    font-style: italic;
    font-size: 1.05rem;
    color: var(--cap-silver-dim);
    letter-spacing: 0.05em;
    animation: cap-msg-pulse 3s ease-in-out infinite;
}

@keyframes cap-msg-pulse {
    0%, 100% { opacity: 0.5; }
    50%      { opacity: 0.9; }
}

/* ============================================================
   PANTALLA RESULTADO
   ============================================================ */

/* Brasero pequeño decorativo */
#capnomancia-app .cap-result-brazier {
    position: relative;
    z-index: 1;
    display: flex;
    flex-direction: column;
    align-items: center;
    margin-bottom: 20px;
}

#capnomancia-app .cap-result-smoke {
    position: relative;
    width: 50px;
    height: 70px;
    display: flex;
    justify-content: center;
}

#capnomancia-app .cap-result-smoke__t {
    position: absolute;
    bottom: 0;
    border-radius: 40% 60% 60% 40% / 40% 40% 60% 60%;
    background: linear-gradient(to top,
        rgba(160, 150, 210, 0.4),
        rgba(120, 110, 180, 0.15),
        transparent
    );
    filter: blur(2px);
    animation: cap-result-smoke-rise 3.5s ease-out infinite;
}

#capnomancia-app .cap-result-smoke__t--1 { width: 14px; height: 55px; left: 6px;  animation-delay: 0s;    animation-duration: 3.8s; }
#capnomancia-app .cap-result-smoke__t--2 { width: 18px; height: 65px; left: 16px; animation-delay: 0.6s;  animation-duration: 3.2s; }
#capnomancia-app .cap-result-smoke__t--3 { width: 12px; height: 48px; left: 30px; animation-delay: 1.2s;  animation-duration: 4s; }

@keyframes cap-result-smoke-rise {
    0%   { transform: translateX(0); opacity: 0.7; }
    40%  { transform: translateX(-5px) scaleX(1.2); opacity: 0.4; }
    100% { transform: translateX(4px) scaleX(0.8) translateY(-20px); opacity: 0; }
}

#capnomancia-app .cap-result-brazier__bowl {
    width: 40px; height: 20px;
    background: linear-gradient(180deg, #251a12 0%, #160f0a 100%);
    border-radius: 50% 50% 45% 45% / 60% 60% 40% 40%;
    border: 1px solid rgba(180, 100, 40, 0.2);
    box-shadow: inset 0 -2px 6px rgba(255, 80, 20, 0.1);
}

#capnomancia-app .cap-result-brazier__stem {
    width: 5px; height: 12px;
    background: #141010;
}

/* Tarjeta de resultado */
#capnomancia-app .cap-result-card {
    position: relative;
    z-index: 1;
    width: 100%;
    max-width: 560px;
    opacity: 0;
    transform: translateY(22px) scale(0.98);
    transition: opacity 0.7s ease, transform 0.7s ease;
}

#capnomancia-app .cap-result-card.visible {
    opacity: 1;
    transform: translateY(0) scale(1);
}

#capnomancia-app .cap-result-card__inner {
    background: linear-gradient(160deg, #1c1630 0%, #161228 60%, #1a1530 100%);
    border: 1px solid var(--cap-border-bright);
    border-radius: 3px;
    padding: 36px 32px 32px;
    box-shadow:
        0 0 40px rgba(100, 70, 180, 0.15),
        0 0 1px rgba(200, 180, 255, 0.1),
        inset 0 1px 0 rgba(200, 180, 255, 0.06),
        0 8px 32px rgba(0,0,0,0.5);
    position: relative;
    overflow: hidden;
}

#capnomancia-app .cap-result-card__inner::before {
    content: '';
    position: absolute;
    top: 0; left: 0; right: 0;
    height: 1px;
    background: linear-gradient(90deg, transparent, rgba(160, 130, 230, 0.5), transparent);
}

#capnomancia-app .cap-result-card__inner::after {
    content: '';
    position: absolute;
    bottom: 0; left: 0; right: 0;
    height: 1px;
    background: linear-gradient(90deg, transparent, rgba(120, 90, 200, 0.3), transparent);
}

/* Label de tipo */
#capnomancia-app .cap-result__label {
    font-family: 'Cinzel Decorative', serif;
    font-size: 0.62rem;
    letter-spacing: 0.2em;
    text-transform: uppercase;
    margin-bottom: 16px;
    padding: 5px 14px;
    display: inline-block;
    border-radius: 1px;
}

#capnomancia-app .cap-result__label--positivo {
    color: var(--cap-positivo);
    border: 1px solid rgba(114, 200, 154, 0.3);
    background: rgba(114, 200, 154, 0.06);
}
#capnomancia-app .cap-result__label--negativo {
    color: var(--cap-negativo);
    border: 1px solid rgba(224, 120, 120, 0.3);
    background: rgba(224, 120, 120, 0.06);
}
#capnomancia-app .cap-result__label--neutral {
    color: var(--cap-gold);
    border: 1px solid rgba(184, 154, 90, 0.3);
    background: rgba(184, 154, 90, 0.06);
}
#capnomancia-app .cap-result__label--mistico {
    color: var(--cap-mistico);
    border: 1px solid rgba(168, 143, 216, 0.3);
    background: rgba(168, 143, 216, 0.06);
}

/* Icono resultado */
#capnomancia-app .cap-result__icon {
    font-size: 2.6rem;
    margin-bottom: 10px;
    filter: drop-shadow(0 0 12px rgba(160, 130, 230, 0.4));
    animation: cap-icon-float 4s ease-in-out infinite;
}

@keyframes cap-icon-float {
    0%, 100% { transform: translateY(0); }
    50%      { transform: translateY(-5px); }
}

/* Pretexto ("el humo ha revelado") */
#capnomancia-app .cap-result__pretext {
    font-style: italic;
    color: var(--cap-silver-dim);
    font-size: 0.9rem;
    letter-spacing: 0.08em;
    margin-bottom: 8px;
}

/* Título del fenómeno */
#capnomancia-app .cap-result__titulo {
    font-family: 'Cinzel Decorative', serif;
    font-size: clamp(1.1rem, 3vw, 1.5rem);
    font-weight: 400;
    color: var(--cap-silver-light);
    text-shadow: 0 0 20px rgba(160, 130, 230, 0.3);
    margin-bottom: 20px;
    letter-spacing: 0.04em;
    line-height: 1.3;
}

/* Divisor de tarjeta */
#capnomancia-app .cap-result-card__divider {
    display: flex;
    align-items: center;
    gap: 12px;
    margin-bottom: 20px;
}

#capnomancia-app .cap-result-card__divider-line {
    flex: 1;
    height: 1px;
    background: linear-gradient(90deg, transparent, var(--cap-border-bright), transparent);
}

#capnomancia-app .cap-result-card__divider-gem {
    color: var(--cap-violet);
    font-size: 0.7rem;
    opacity: 0.7;
}

/* Texto interpretación */
#capnomancia-app .cap-result__interpretacion {
    font-size: clamp(0.92rem, 2vw, 1.02rem);
    line-height: 1.8;
    color: var(--cap-text);
    font-style: italic;
    text-align: justify;
    hyphens: auto;
}

/* ============================================================
   PANTALLA ERROR
   ============================================================ */
#capnomancia-app .cap-error__content {
    position: relative;
    z-index: 1;
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 16px;
}

#capnomancia-app .cap-error__icon {
    font-size: 3rem;
    opacity: 0.4;
    filter: grayscale(1);
}

#capnomancia-app .cap-error__msg {
    color: var(--cap-silver-dim);
    font-style: italic;
    font-size: 1rem;
    max-width: 360px;
}

/* ============================================================
   RESPONSIVE
   ============================================================ */
@media (max-width: 480px) {
    #capnomancia-app .cap-screen {
        min-height: 560px;
        padding: 36px 18px 48px;
    }

    #capnomancia-app .cap-seal {
        width: 100px;
        height: 100px;
    }

    #capnomancia-app .cap-result-card__inner {
        padding: 28px 20px 24px;
    }

    #capnomancia-app .cap-btn--invocar {
        padding: 12px 24px;
        font-size: 0.7rem;
    }

    #capnomancia-app .cap-smoke__tendril--4,
    #capnomancia-app .cap-smoke__tendril--5,
    #capnomancia-app .cap-smoke__tendril--6 {
        display: none;
    }
}

@media (max-width: 360px) {
    #capnomancia-app .cap-title {
        font-size: 1.7rem;
    }
    #capnomancia-app .cap-result-card__inner {
        padding: 22px 16px 20px;
    }
    #capnomancia-app .cap-result__titulo {
        font-size: 1rem;
    }
}
