/* ============================================================
   VnY SITE COMMUNITY — rediseño de páginas comunitarias
   peticiones.php / reportar.php / faq.php
   Aplica tokens del design system sobre las clases existentes.
   ============================================================ */

/* ============================================================
   PETICIONES — list de cards + form + estados
   ============================================================ */

/* Info pill arriba */
body:not(.admin-body) .peticiones-info {
    background: rgba(var(--site-accent-rgb), .05) !important;
    border: 1px solid rgba(var(--site-accent-rgb), .2) !important;
    border-radius: var(--radius-md) !important;
    color: var(--site-text-muted) !important;
    font-family: var(--font-body) !important;
    font-size: 13px !important;
    line-height: 1.6 !important;
    padding: 13px 16px !important;
    margin: 18px 0 20px !important;
}
body:not(.admin-body) .peticiones-info i { color: var(--site-accent) !important; }
body:not(.admin-body) .peticiones-info strong { color: #fff !important; }

/* Notice "ya tienes una peticion activa" */
body:not(.admin-body) .peticiones-limit-notice {
    background: rgba(255, 217, 61, .06) !important;
    border: 1px solid rgba(255, 217, 61, .25) !important;
    color: #ffd93d !important;
    border-radius: var(--radius-md) !important;
    padding: 13px 16px !important;
    font-family: var(--font-body) !important;
    font-size: 13px !important;
    margin-bottom: 20px !important;
}

/* Guest box "exclusivo para registrados" — refinada con tokens */
body:not(.admin-body) .peticiones-guest-box {
    background: var(--site-surface) !important;
    border: 1px solid var(--site-border-2) !important;
    border-radius: var(--radius-lg) !important;
    padding: 44px 28px !important;
    text-align: center;
    margin: 24px 0 30px !important;
    position: relative;
    overflow: hidden;
}
body:not(.admin-body) .peticiones-guest-box::before {
    content: '';
    position: absolute;
    top: 0; left: 0; right: 0;
    height: 3px;
    background: linear-gradient(90deg, transparent, var(--site-accent), transparent);
}
body:not(.admin-body) .peticiones-guest-icon {
    width: 64px !important;
    height: 64px !important;
    background: rgba(var(--site-accent-rgb), .1) !important;
    border: 1px solid rgba(var(--site-accent-rgb), .3) !important;
    color: var(--site-accent) !important;
    font-size: 24px !important;
    box-shadow: 0 0 24px rgba(var(--site-accent-rgb), .15);
}
body:not(.admin-body) .peticiones-guest-box h2 {
    font-family: var(--font-display) !important;
    font-size: 17px !important;
    text-transform: uppercase;
    letter-spacing: 1.5px;
    color: #fff !important;
}
body:not(.admin-body) .peticiones-guest-box p {
    color: var(--site-text-muted) !important;
    font-family: var(--font-body) !important;
    font-size: 13.5px !important;
}
body:not(.admin-body) .peticiones-btn {
    border-radius: var(--radius-md) !important;
    font-family: var(--font-body) !important;
    text-transform: uppercase;
    letter-spacing: 1px;
    padding: 11px 22px !important;
    font-size: 12.5px !important;
    transition: filter var(--dur-fast) var(--ease),
                background var(--dur-fast) var(--ease),
                transform var(--dur-fast) var(--ease),
                box-shadow var(--dur-fast) var(--ease) !important;
}
body:not(.admin-body) .peticiones-btn-primary {
    background: var(--site-accent) !important;
    color: var(--site-accent-text) !important;
    box-shadow: 0 6px 18px rgba(var(--site-accent-rgb), .25);
}
body:not(.admin-body) .peticiones-btn-primary:hover {
    background: var(--site-accent) !important;
    filter: brightness(1.1);
    transform: translateY(-2px);
    box-shadow: 0 10px 24px rgba(var(--site-accent-rgb), .4);
}
body:not(.admin-body) .peticiones-btn-outline {
    background: transparent !important;
    color: var(--site-accent) !important;
    border: 1px solid var(--site-accent) !important;
}
body:not(.admin-body) .peticiones-btn-outline:hover {
    background: rgba(var(--site-accent-rgb), .12) !important;
    color: #fff !important;
    transform: translateY(-2px);
}

/* Form wrapper para enviar peticion */
body:not(.admin-body) .peticiones-form-wrapper {
    background: var(--site-surface) !important;
    border: 1px solid var(--site-border-2) !important;
    border-radius: var(--radius-md) !important;
    padding: 18px !important;
    margin-bottom: 22px !important;
}
body:not(.admin-body) .peticiones-form-field label {
    font-family: var(--font-display) !important;
    font-size: 11px !important;
    color: var(--site-text-muted) !important;
    text-transform: uppercase;
    letter-spacing: 1.4px !important;
}
body:not(.admin-body) .peticiones-form-field label i {
    color: var(--site-accent) !important;
}
body:not(.admin-body) .peticiones-form-field input {
    background: var(--site-surface-2) !important;
    border: 1px solid var(--site-border-2) !important;
    border-radius: var(--radius-md) !important;
    color: var(--site-text) !important;
    font-size: 13.5px !important;
    padding: 11px 14px !important;
    transition: border-color var(--dur-fast) var(--ease),
                box-shadow var(--dur-fast) var(--ease) !important;
}
body:not(.admin-body) .peticiones-form-field input:focus {
    border-color: var(--site-accent) !important;
    box-shadow: 0 0 0 2px var(--site-accent-soft) !important;
    background: rgba(0, 0, 0, .4) !important;
}
body:not(.admin-body) .peticiones-form-field input::placeholder {
    color: var(--site-text-faded) !important;
}
body:not(.admin-body) .peticiones-submit-btn {
    background: linear-gradient(135deg,
        var(--site-accent) 0%,
        rgba(var(--site-accent-rgb), .85) 100%) !important;
    color: var(--site-accent-text) !important;
    border: 1px solid rgba(var(--site-accent-rgb), .8) !important;
    border-radius: var(--radius-md) !important;
    font-family: var(--font-body) !important;
    font-weight: var(--fw-bold) !important;
    font-size: 13px !important;
    text-transform: uppercase;
    letter-spacing: 1px;
    padding: 12px 22px !important;
    box-shadow: 0 6px 18px rgba(var(--site-accent-rgb), .25) !important;
    transition: filter var(--dur-fast) var(--ease),
                transform var(--dur-fast) var(--ease),
                box-shadow var(--dur-fast) var(--ease) !important;
}
body:not(.admin-body) .peticiones-submit-btn:hover {
    background: var(--site-accent) !important;
    filter: brightness(1.1);
    transform: translateY(-2px);
    box-shadow: 0 10px 24px rgba(var(--site-accent-rgb), .4) !important;
}

/* Empty state */
body:not(.admin-body) .peticiones-empty {
    text-align: center;
    padding: 50px 20px;
    color: var(--site-text-muted) !important;
    font-family: var(--font-body) !important;
}
body:not(.admin-body) .peticiones-empty i {
    font-size: 40px;
    color: var(--site-text-faded);
    margin-bottom: 14px;
    display: block;
}

/* Cards de la lista de peticiones */
body:not(.admin-body) .peticion-card {
    background: var(--site-surface) !important;
    border: 1px solid var(--site-border-2) !important;
    border-radius: var(--radius-md) !important;
    padding: 14px 16px !important;
    gap: 14px !important;
    transition: background var(--dur-fast) var(--ease),
                border-color var(--dur-fast) var(--ease),
                transform var(--dur-fast) var(--ease) !important;
}
body:not(.admin-body) .peticion-card:hover {
    background: var(--site-surface-2) !important;
    border-color: var(--site-border-2) !important;
    transform: translateX(2px);
}
body:not(.admin-body) .peticion-rank {
    font-family: var(--font-display) !important;
    font-size: 14px !important;
    color: var(--site-accent) !important;
    min-width: 34px !important;
}
/* Top 3 con badge especial */
body:not(.admin-body) .peticiones-list .peticion-card:nth-child(1) .peticion-rank,
body:not(.admin-body) .peticiones-list .peticion-card:nth-child(2) .peticion-rank,
body:not(.admin-body) .peticiones-list .peticion-card:nth-child(3) .peticion-rank {
    font-size: 16px !important;
}
body:not(.admin-body) .peticiones-list .peticion-card:nth-child(1) .peticion-rank {
    color: #ffb800 !important;
    text-shadow: 0 0 12px rgba(255, 184, 0, .35);
}
body:not(.admin-body) .peticion-artist {
    font-family: var(--font-display) !important;
    font-size: 14px !important;
    color: #fff !important;
    letter-spacing: .5px;
}
body:not(.admin-body) .peticion-meta {
    font-family: var(--font-body) !important;
    color: var(--site-text-faded) !important;
}
body:not(.admin-body) .peticion-meta i {
    color: var(--site-text-faded) !important;
}
body:not(.admin-body) .peticion-vote-btn {
    background: var(--site-surface-2) !important;
    border: 1px solid var(--site-border-2) !important;
    color: var(--site-text-muted) !important;
    border-radius: var(--radius-md) !important;
    transition: border-color var(--dur-fast) var(--ease),
                background var(--dur-fast) var(--ease),
                color var(--dur-fast) var(--ease),
                transform var(--dur-fast) var(--ease) !important;
}
body:not(.admin-body) .peticion-vote-btn:hover:not(.voted):not(:disabled) {
    border-color: var(--site-accent) !important;
    color: var(--site-accent) !important;
    background: rgba(var(--site-accent-rgb), .1) !important;
    transform: translateY(-1px);
}
body:not(.admin-body) .peticion-vote-btn.voted {
    background: rgba(var(--site-accent-rgb), .15) !important;
    border-color: var(--site-accent) !important;
    color: var(--site-accent) !important;
}
body:not(.admin-body) .peticion-vote-count {
    font-family: var(--font-display) !important;
    color: var(--site-text) !important;
    font-size: 13px;
}

/* ============================================================
   REPORTAR — formulario refinado
   ============================================================ */
body:not(.admin-body) .report-form-wrapper {
    background: var(--site-surface) !important;
    border: 1px solid var(--site-border-2) !important;
    border-radius: var(--radius-lg) !important;
    padding: 24px !important;
    margin-top: 18px !important;
    backdrop-filter: none !important;
}
body:not(.admin-body) .report-intro {
    background: rgba(var(--site-accent-rgb), .06) !important;
    border: 1px solid rgba(var(--site-accent-rgb), .2) !important;
    border-radius: var(--radius-md) !important;
    color: var(--site-text-muted) !important;
    font-family: var(--font-body) !important;
    font-size: 13.5px !important;
    line-height: 1.6 !important;
    padding: 13px 16px !important;
    margin-bottom: 22px !important;
}
body:not(.admin-body) .report-intro i {
    color: var(--site-accent) !important;
}
body:not(.admin-body) .report-field label {
    font-family: var(--font-display) !important;
    font-size: 11px !important;
    color: var(--site-text-muted) !important;
    text-transform: uppercase;
    letter-spacing: 1.4px !important;
}
body:not(.admin-body) .report-field label i {
    color: var(--site-accent) !important;
}
body:not(.admin-body) .optional-label {
    color: var(--site-text-faded) !important;
    font-weight: var(--fw-regular) !important;
}
body:not(.admin-body) .report-field select,
body:not(.admin-body) .report-field input,
body:not(.admin-body) .report-field textarea {
    background: var(--site-surface-2) !important;
    border: 1px solid var(--site-border-2) !important;
    border-radius: var(--radius-md) !important;
    color: var(--site-text) !important;
    font-family: var(--font-body) !important;
    font-size: 13.5px !important;
    padding: 11px 14px !important;
    transition: border-color var(--dur-fast) var(--ease),
                box-shadow var(--dur-fast) var(--ease),
                background var(--dur-fast) var(--ease) !important;
}
body:not(.admin-body) .report-field select:focus,
body:not(.admin-body) .report-field input:focus,
body:not(.admin-body) .report-field textarea:focus {
    border-color: var(--site-accent) !important;
    box-shadow: 0 0 0 2px var(--site-accent-soft) !important;
    background: rgba(0, 0, 0, .4) !important;
}
body:not(.admin-body) .report-field select option {
    background: var(--site-surface) !important;
    color: var(--site-text) !important;
}
/* Botón submit con accent (no rojo como antes) */
body:not(.admin-body) .report-submit-btn {
    background: linear-gradient(135deg,
        var(--site-accent) 0%,
        rgba(var(--site-accent-rgb), .85) 100%) !important;
    color: var(--site-accent-text) !important;
    border: 1px solid rgba(var(--site-accent-rgb), .8) !important;
    border-radius: var(--radius-md) !important;
    font-family: var(--font-body) !important;
    font-size: 13.5px !important;
    text-transform: uppercase;
    letter-spacing: 1.5px;
    padding: 14px 22px !important;
    box-shadow: 0 6px 18px rgba(var(--site-accent-rgb), .25) !important;
    transition: filter var(--dur-fast) var(--ease),
                transform var(--dur-fast) var(--ease),
                box-shadow var(--dur-fast) var(--ease) !important;
}
body:not(.admin-body) .report-submit-btn:hover {
    filter: brightness(1.1);
    transform: translateY(-2px);
    box-shadow: 0 12px 28px rgba(var(--site-accent-rgb), .4) !important;
}

/* Alerts del reportar — coherentes con auth alerts */
body:not(.admin-body) .report-alert {
    border-radius: var(--radius-md) !important;
    padding: 13px 16px !important;
    font-family: var(--font-body) !important;
    font-size: 13px !important;
    line-height: 1.55 !important;
}
body:not(.admin-body) .report-alert-success {
    background: rgba(46, 204, 113, .08) !important;
    border: 1px solid rgba(46, 204, 113, .25) !important;
    color: #5fe09b !important;
}
body:not(.admin-body) .report-alert-error {
    background: rgba(255, 107, 107, .08) !important;
    border: 1px solid rgba(255, 107, 107, .25) !important;
    color: #ff8b8b !important;
}

/* ============================================================
   FAQ — secciones con accordion-like layout
   ============================================================ */
body:not(.admin-body) .faq-page-container {
    margin-top: 18px;
}
body:not(.admin-body) .faq-card {
    background: var(--site-surface) !important;
    border: 1px solid var(--site-border-2) !important;
    border-radius: var(--radius-lg) !important;
    padding: 8px 28px !important;
    backdrop-filter: none !important;
}
body:not(.admin-body) .faq-section {
    padding: 24px 0 !important;
}
body:not(.admin-body) .faq-section:not(:last-child) {
    border-bottom: 1px solid var(--site-border) !important;
}
/* H2 de cada sección con barra accent + underline degradado */
body:not(.admin-body) .faq-section h2 {
    position: relative;
    font-family: var(--font-display) !important;
    font-size: 19px !important;
    font-weight: var(--fw-bold) !important;
    color: #fff !important;
    text-transform: uppercase;
    letter-spacing: 1.5px !important;
    margin: 0 0 18px !important;
    padding: 0 0 14px !important;
    display: flex !important;
    align-items: center !important;
    gap: 12px !important;
    /* Reset del border-left heredado de pages.css — la barra ahora la dibuja ::before */
    border-left: none !important;
    padding-left: 0 !important;
}
body:not(.admin-body) .faq-section h2::before {
    content: '';
    width: 5px;
    height: 22px;
    background: var(--site-accent);
    border-radius: 3px;
    box-shadow: 0 0 12px rgba(var(--site-accent-rgb), .55);
    flex-shrink: 0;
}
body:not(.admin-body) .faq-section h2::after {
    content: '';
    position: absolute;
    bottom: 0;
    left: 0;
    right: 0;
    height: 1px;
    background: linear-gradient(90deg,
        var(--site-accent) 0%,
        rgba(var(--site-accent-rgb), .35) 30%,
        transparent 70%);
}
body:not(.admin-body) .faq-section h2 strong {
    color: var(--site-accent) !important;
}
body:not(.admin-body) .faq-section h3 {
    font-family: var(--font-display) !important;
    font-size: 14px !important;
    color: var(--site-accent) !important;
    text-transform: uppercase;
    letter-spacing: 1px;
    margin: 18px 0 10px !important;
}
body:not(.admin-body) .faq-section p {
    font-family: var(--font-body) !important;
    color: var(--site-text-muted) !important;
    font-size: 14px !important;
    line-height: 1.7 !important;
    margin: 0 0 14px !important;
}
body:not(.admin-body) .faq-section p strong {
    color: var(--site-text) !important;
}

/* Steps list (numerados) */
body:not(.admin-body) .steps-list {
    display: flex;
    flex-direction: column;
    gap: 10px;
    margin: 18px 0;
}
body:not(.admin-body) .step-item {
    display: flex;
    align-items: center;
    gap: 14px;
    padding: 12px 14px !important;
    background: var(--site-surface-2) !important;
    border: 1px solid var(--site-border) !important;
    border-radius: var(--radius-md) !important;
    transition: border-color var(--dur-fast) var(--ease),
                background var(--dur-fast) var(--ease),
                transform var(--dur-fast) var(--ease) !important;
}
body:not(.admin-body) .step-item:hover {
    border-color: var(--site-accent) !important;
    background: rgba(var(--site-accent-rgb), .06) !important;
    transform: translateX(2px);
}
body:not(.admin-body) .step-number {
    width: 32px !important;
    height: 32px !important;
    border-radius: 50% !important;
    background: var(--site-accent) !important;
    color: var(--site-accent-text) !important;
    font-family: var(--font-display) !important;
    font-size: 14px !important;
    font-weight: var(--fw-bold) !important;
    display: flex !important;
    align-items: center;
    justify-content: center;
    flex-shrink: 0;
    box-shadow: 0 0 12px rgba(var(--site-accent-rgb), .35);
}
body:not(.admin-body) .step-text {
    font-family: var(--font-body) !important;
    color: var(--site-text) !important;
    font-size: 13.5px !important;
    line-height: 1.55 !important;
}
body:not(.admin-body) .step-text strong {
    color: var(--site-accent) !important;
}

/* Optional steps list (con check icons) */
body:not(.admin-body) .optional-steps {
    list-style: none;
    margin: 18px 0 0;
    padding: 0;
    display: flex;
    flex-direction: column;
    gap: 8px;
}
body:not(.admin-body) .optional-steps li {
    display: flex;
    align-items: flex-start;
    gap: 12px;
    padding: 10px 14px;
    background: var(--site-surface-2) !important;
    border: 1px solid var(--site-border) !important;
    border-radius: var(--radius-md);
    font-family: var(--font-body) !important;
    color: var(--site-text) !important;
    font-size: 13.5px !important;
    line-height: 1.6;
}
body:not(.admin-body) .optional-steps li i {
    color: var(--site-accent) !important;
    font-size: 14px;
    margin-top: 2px;
    flex-shrink: 0;
}
body:not(.admin-body) .optional-steps li strong {
    color: var(--site-accent) !important;
}

/* CTA wrapper para el botón WinRAR */
body:not(.admin-body) .faq-winrar-cta {
    margin: 20px 0;
}

/* Última sección del FAQ — sin border-bottom y sin padding extra */
body:not(.admin-body) .faq-section.faq-section-last {
    border-bottom: none !important;
    padding-bottom: 0 !important;
}

/* Botón "Descargar WinRAR" */
body:not(.admin-body) .winrar-btn {
    display: inline-flex;
    align-items: center;
    gap: 10px;
    background: linear-gradient(135deg,
        var(--site-accent) 0%,
        rgba(var(--site-accent-rgb), .85) 100%) !important;
    color: var(--site-accent-text) !important;
    text-decoration: none;
    padding: 12px 22px !important;
    border-radius: var(--radius-md) !important;
    font-family: var(--font-body) !important;
    font-size: 13px !important;
    font-weight: var(--fw-bold) !important;
    letter-spacing: 1.2px !important;
    text-transform: uppercase;
    border: 1px solid rgba(var(--site-accent-rgb), .8);
    box-shadow: 0 6px 18px rgba(var(--site-accent-rgb), .25) !important;
    transition: filter var(--dur-fast) var(--ease),
                transform var(--dur-fast) var(--ease),
                box-shadow var(--dur-fast) var(--ease) !important;
}
body:not(.admin-body) .winrar-btn:hover {
    filter: brightness(1.1);
    transform: translateY(-2px);
    box-shadow: 0 12px 28px rgba(var(--site-accent-rgb), .4) !important;
}

/* Video container del FAQ */
body:not(.admin-body) .faq-section .video-container {
    border: 1px solid var(--site-border-2) !important;
    border-radius: var(--radius-lg) !important;
    box-shadow: 0 16px 40px rgba(0, 0, 0, .5) !important;
    overflow: hidden;
}

/* ============================================================
   RESPONSIVE
   ============================================================ */
@media (max-width: 768px) {
    body:not(.admin-body) .peticiones-form-wrapper { padding: 14px !important; }
    body:not(.admin-body) .peticion-card {
        padding: 12px 14px !important;
        gap: 10px !important;
    }
    body:not(.admin-body) .peticion-rank { font-size: 13px !important; min-width: 28px !important; }
    body:not(.admin-body) .peticion-artist { font-size: 13px !important; }
    body:not(.admin-body) .peticion-meta { font-size: 10.5px !important; gap: 10px !important; }

    body:not(.admin-body) .report-form-wrapper { padding: 16px !important; }

    body:not(.admin-body) .faq-card { padding: 4px 16px !important; }
    body:not(.admin-body) .faq-section h2 {
        font-size: 15px !important;
        letter-spacing: 1px !important;
    }
    body:not(.admin-body) .faq-section h2::before { height: 18px; width: 4px; }
    body:not(.admin-body) .faq-section h3 { font-size: 13px !important; }
    body:not(.admin-body) .faq-section p { font-size: 13px !important; }
    body:not(.admin-body) .step-item { padding: 10px 12px !important; gap: 12px; }
    body:not(.admin-body) .step-number { width: 28px !important; height: 28px !important; font-size: 12px !important; }
    body:not(.admin-body) .step-text { font-size: 12.5px !important; }
}
