/* ===== Base ===== */
html, body{
    margin:0;
    padding:0;
    overflow-x:hidden;
}

body{
    font-family: Arial, sans-serif;
    background:#f3f4f8;
    color:#1f2937;
}

/* Utilidades */
.oculto{
    display:none !important;
}

/* ===== Modal base ===== */
.modal{
    position:fixed;
    inset:0;
    display:flex;
    justify-content:center;
    align-items:center;
    background:rgba(0,0,0,0.7);
    z-index:999;
    padding:12px;
}

.modal-content{
    background:linear-gradient(180deg,#ffffff,#f7f7f7);
    border-radius:20px;
    padding:16px 14px 20px;
    width:min(420px, calc(100vw - 24px));
    max-height:92vh;
    overflow-y:auto;
    margin:auto;
    box-sizing:border-box;
    animation:aparecerPokemon .25s ease;
}

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

.detalle-imagen-box img{
    transition:transform .2s ease;
}

.detalle-imagen-box img:hover{
    transform:scale(1.1);
}

.tipo{
    box-shadow:0 4px 10px rgba(0,0,0,0.15);
}

.cerrar{
    position:absolute;
    right:14px;
    top:10px;
    font-size:20px;
    cursor:pointer;
}

/* Títulos reutilizables */
.titulo{
    font-size:30px;
    font-weight:800;
    margin:0;
}

.subtitulo{
    color:#6b7280;
    margin-top:6px;
}

.pagina-shell{
    width:100%;
    box-sizing:border-box;
}


/* ===== Starter Journey / Onboarding ===== */
.starter-journey-section{
    width:min(1200px, calc(100% - 32px));
    margin:24px auto 8px;
}

.starter-journey-shell{
    width:100%;
}

.starter-journey-card{
    background:linear-gradient(135deg, #ffffff 0%, #eef6ff 48%, #f8fbff 100%);
    border:1px solid rgba(37,99,235,0.12);
    border-radius:28px;
    padding:24px;
    box-shadow:0 18px 50px rgba(30,64,175,0.10);
}

.starter-journey-top{
    display:flex;
    justify-content:space-between;
    gap:18px;
    align-items:flex-start;
    margin-bottom:18px;
}

.starter-journey-badge,
.starter-modal-badge{
    display:inline-flex;
    align-items:center;
    gap:6px;
    background:#dbeafe;
    color:#1d4ed8;
    border-radius:999px;
    padding:7px 12px;
    font-size:12px;
    font-weight:700;
    text-transform:uppercase;
    letter-spacing:.06em;
}

.starter-journey-top h2{
    margin:12px 0 8px;
    font-size:30px;
    line-height:1.1;
}

.starter-journey-top p{
    margin:0;
    color:#4b5563;
    max-width:760px;
}

.starter-journey-progress-box{
    min-width:180px;
    background:rgba(255,255,255,0.75);
    border:1px solid rgba(59,130,246,0.15);
    border-radius:20px;
    padding:14px 16px;
    text-align:right;
}

.starter-journey-progress-box small{
    display:block;
    color:#6b7280;
    font-size:12px;
    margin-bottom:6px;
}

.starter-journey-progress-box strong{
    display:block;
    font-size:28px;
    line-height:1;
}

.starter-journey-progress-box span{
    display:block;
    margin-top:8px;
    color:#2563eb;
    font-weight:700;
}

.starter-journey-live-rewards{
    margin:0 0 16px;
    background:#ecfdf5;
    border:1px solid rgba(16,185,129,0.20);
    color:#065f46;
    border-radius:18px;
    padding:14px 16px;
    font-size:14px;
}

.starter-journey-grid{
    display:grid;
    grid-template-columns:repeat(3, minmax(0, 1fr));
    gap:16px;
}

.starter-mission-card{
    background:#ffffff;
    border:1px solid rgba(148,163,184,0.18);
    border-radius:22px;
    padding:18px;
    display:flex;
    flex-direction:column;
    gap:12px;
    min-height:220px;
}

.starter-mission-card.is-complete{
    border-color:rgba(16,185,129,0.30);
    box-shadow:0 12px 30px rgba(16,185,129,0.10);
}

.starter-mission-top{
    display:flex;
    justify-content:space-between;
    gap:12px;
    align-items:flex-start;
}

.starter-mission-chip{
    display:inline-flex;
    padding:6px 10px;
    border-radius:999px;
    font-size:11px;
    font-weight:700;
    text-transform:uppercase;
    letter-spacing:.05em;
}

.starter-mission-chip.is-pending{
    background:#eff6ff;
    color:#1d4ed8;
}

.starter-mission-chip.is-complete{
    background:#ecfdf5;
    color:#047857;
}

.starter-mission-icon{
    width:42px;
    height:42px;
    display:flex;
    align-items:center;
    justify-content:center;
    border-radius:14px;
    background:#eff6ff;
    font-size:20px;
}

.starter-mission-card h3{
    margin:0;
    font-size:20px;
}

.starter-mission-card p{
    margin:0;
    color:#4b5563;
    font-size:14px;
    line-height:1.5;
}

.starter-mission-progress{
    display:flex;
    justify-content:space-between;
    gap:10px;
    font-size:13px;
    color:#475569;
    font-weight:700;
}

.starter-mission-reward{
    margin-top:auto;
    background:#f8fafc;
    border-radius:16px;
    padding:12px 14px;
    font-size:13px;
    color:#334155;
}

.starter-mission-reward strong{
    display:block;
    margin-bottom:4px;
    font-size:12px;
    text-transform:uppercase;
    letter-spacing:.05em;
    color:#64748b;
}

.starter-mission-actions{
    display:flex;
}

.starter-mission-link{
    display:inline-flex;
    align-items:center;
    justify-content:center;
    min-height:42px;
    padding:0 16px;
    border-radius:14px;
    background:#2563eb;
    color:#fff;
    text-decoration:none;
    font-weight:700;
}

.starter-mission-link:hover{
    filter:brightness(1.04);
}

.starter-final-reward{
    margin-top:18px;
    display:flex;
    justify-content:space-between;
    gap:16px;
    align-items:center;
    background:linear-gradient(135deg, #1e293b, #334155);
    color:#f8fafc;
    border-radius:22px;
    padding:18px 20px;
}

.starter-final-reward small{
    display:block;
    color:#cbd5e1;
    margin-bottom:6px;
}

.starter-final-reward strong{
    font-size:18px;
    line-height:1.35;
}

.starter-final-reward-status{
    background:rgba(255,255,255,0.10);
    border:1px solid rgba(255,255,255,0.12);
    border-radius:999px;
    padding:8px 14px;
    font-size:12px;
    font-weight:800;
    letter-spacing:.05em;
    text-transform:uppercase;
}

.starter-modal-overlay{
    position:fixed;
    inset:0;
    display:flex;
    align-items:center;
    justify-content:center;
    background:rgba(15,23,42,0.72);
    z-index:1200;
    padding:16px;
}

.starter-modal-box{
    width:min(520px, calc(100vw - 32px));
    background:#fff;
    border-radius:28px;
    padding:26px 24px 22px;
    box-shadow:0 24px 80px rgba(15,23,42,0.35);
}

.starter-modal-box h3{
    margin:14px 0 10px;
    font-size:30px;
    line-height:1.08;
}

.starter-modal-box p{
    margin:0;
    color:#475569;
    line-height:1.6;
}

.starter-modal-actions{
    display:flex;
    justify-content:flex-end;
    gap:10px;
    margin-top:22px;
}

.starter-modal-btn{
    border:none;
    border-radius:14px;
    min-height:44px;
    padding:0 16px;
    font-weight:700;
    cursor:pointer;
}

.starter-modal-btn-primary{
    background:#2563eb;
    color:#fff;
}

.starter-modal-btn-light{
    background:#e2e8f0;
    color:#0f172a;
}


.onboarding-toast-stack{
    position:fixed;
    right:18px;
    bottom:18px;
    display:flex;
    flex-direction:column;
    gap:12px;
    z-index:4200;
    pointer-events:none;
}

.onboarding-toast{
    width:min(360px, calc(100vw - 28px));
    background:linear-gradient(180deg,#ffffff 0%,#f8fbff 100%);
    border:1px solid #dbeafe;
    border-radius:20px;
    box-shadow:0 18px 42px rgba(15,23,42,0.16);
    padding:16px 16px 15px;
    transform:translateY(14px);
    opacity:0;
    transition:transform .22s ease, opacity .22s ease;
    pointer-events:auto;
}

.onboarding-toast.is-visible{
    transform:translateY(0);
    opacity:1;
}

.onboarding-toast.is-leaving{
    transform:translateY(10px);
    opacity:0;
}

.onboarding-toast.is-final{
    border-color:#bfdbfe;
    background:linear-gradient(180deg,#eff6ff 0%,#f8fbff 100%);
}

.onboarding-toast-head{
    display:flex;
    align-items:center;
    justify-content:space-between;
    gap:10px;
    margin-bottom:10px;
}

.onboarding-toast-kicker{
    display:inline-flex;
    align-items:center;
    border-radius:999px;
    padding:6px 10px;
    background:#dbeafe;
    color:#1d4ed8;
    font-size:11px;
    font-weight:900;
    letter-spacing:.04em;
    text-transform:uppercase;
}

.onboarding-toast-close{
    border:none;
    background:transparent;
    color:#64748b;
    font-size:22px;
    line-height:1;
    cursor:pointer;
    padding:0;
}

.onboarding-toast-title{
    display:block;
    margin-bottom:10px;
    color:#0f172a;
    font-size:18px;
    line-height:1.25;
}

.onboarding-toast-reward-label{
    margin:0 0 4px !important;
    font-size:12px;
    font-weight:800;
    color:#64748b;
    text-transform:uppercase;
    letter-spacing:.04em;
}

.onboarding-toast-reward-text{
    margin:0 !important;
    color:#0f172a;
    line-height:1.45;
    font-weight:700;
}

.onboarding-toast-link{
    display:inline-flex;
    margin-top:12px;
    color:#2563eb;
    font-weight:800;
    text-decoration:none;
}

.onboarding-toast-link:hover{
    text-decoration:underline;
}


@media (max-width: 980px){
    .starter-journey-grid{
        grid-template-columns:1fr;
    }

    .starter-journey-top{
        flex-direction:column;
    }

    .starter-journey-progress-box{
        width:100%;
        text-align:left;
    }

    .starter-final-reward{
        flex-direction:column;
        align-items:flex-start;
    }
}

@media (max-width: 640px){
    .starter-journey-section{
        width:min(100%, calc(100% - 20px));
        margin-top:18px;
    }

    .starter-journey-card{
        padding:18px;
        border-radius:22px;
    }

    .starter-journey-top h2{
        font-size:24px;
    }

    .starter-modal-box{
        padding:22px 18px 18px;
        border-radius:24px;
    }

    .starter-modal-box h3{
        font-size:24px;
    }

    .starter-modal-actions{
        flex-direction:column-reverse;
    }

    .starter-modal-btn,
    .starter-mission-link{
        width:100%;
    }
}
