/**
 * Estilos Públicos - Enquete Master
 * Design profissional isolado do tema
 * 
 * @package Enquete_Master
 * @author Dante Testa <https://dantetesta.com.br>
 * @since 1.4.1
 * @updated 08/12/2024 23:43
 */

/* ========================================
   RESET E ISOLAMENTO DO TEMA
   ======================================== */
.em-poll-wrapper,
.em-poll-wrapper *,
.em-poll-wrapper *::before,
.em-poll-wrapper *::after {
    box-sizing: border-box !important;
    margin: 0 !important;
    padding: 0 !important;
    border: none !important;
    outline: none !important;
    font-family: 'Inter', -apple-system, BlinkMacSystemFont, 'Segoe UI', Roboto, sans-serif !important;
    line-height: 1.5 !important;
    -webkit-font-smoothing: antialiased !important;
    -moz-osx-font-smoothing: grayscale !important;
}

/* ========================================
   WRAPPER PRINCIPAL
   ======================================== */
.em-poll-wrapper {
    max-width: 1400px !important;
    margin: 0 auto !important;
    padding: 40px 20px !important;
    background: transparent !important;
}

/* ========================================
   HEADER DA ENQUETE
   ======================================== */
.em-poll-header {
    text-align: center !important;
    margin-bottom: 40px !important;
    padding: 0 !important;
}

.em-poll-title {
    font-size: 36px !important;
    font-weight: 800 !important;
    color: #1a1a2e !important;
    margin: 0 0 12px 0 !important;
    padding: 0 !important;
    letter-spacing: -0.5px !important;
}

.em-poll-description {
    font-size: 17px !important;
    color: #6b7280 !important;
    margin: 0 0 20px 0 !important;
    padding: 0 !important;
    max-width: 600px !important;
    margin-left: auto !important;
    margin-right: auto !important;
}

.em-poll-meta {
    display: flex !important;
    justify-content: center !important;
    gap: 12px !important;
    align-items: center !important;
    flex-wrap: wrap !important;
}

.em-badge {
    padding: 8px 18px !important;
    border-radius: 50px !important;
    font-size: 13px !important;
    font-weight: 600 !important;
    text-transform: uppercase !important;
    letter-spacing: 0.5px !important;
}

.em-badge-active {
    background: linear-gradient(135deg, #10b981, #059669) !important;
    color: #fff !important;
}

.em-badge-closed {
    background: #fef2f2 !important;
    color: #dc2626 !important;
}

.em-total-votes {
    color: #6b7280 !important;
    font-size: 14px !important;
    font-weight: 500 !important;
}

.em-instruction {
    text-align: center !important;
    color: #9ca3af !important;
    margin: 0 0 30px 0 !important;
    padding: 0 !important;
    font-size: 15px !important;
    display: none !important;
}

/* ========================================
   GRID DE CARDS
   ======================================== */
.em-cards-grid {
    display: grid !important;
    grid-template-columns: repeat(var(--em-columns, 4), 1fr) !important;
    gap: 24px !important;
    background: transparent !important;
    border-radius: 0 !important;
    padding: 0 !important;
    box-shadow: none !important;
}

@media (max-width: 1200px) {
    .em-cards-grid { grid-template-columns: repeat(3, 1fr) !important; }
}

@media (max-width: 900px) {
    .em-cards-grid { grid-template-columns: repeat(2, 1fr) !important; }
}

@media (max-width: 560px) {
    .em-cards-grid { grid-template-columns: 1fr !important; gap: 16px !important; }
}

/* ========================================
   CARD INDIVIDUAL
   ======================================== */
.em-card {
    display: flex !important;
    flex-direction: column !important;
    align-items: stretch !important;
    background: #ffffff !important;
    border-radius: 16px !important;
    overflow: hidden !important;
    box-shadow: 0 4px 6px -1px rgba(0, 0, 0, 0.1), 0 2px 4px -1px rgba(0, 0, 0, 0.06) !important;
    transition: all 0.3s cubic-bezier(0.4, 0, 0.2, 1) !important;
    position: relative !important;
    border: 1px solid rgba(0, 0, 0, 0.05) !important;
}

.em-card:hover {
    transform: translateY(-8px) !important;
    box-shadow: 0 20px 25px -5px rgba(0, 0, 0, 0.1), 0 10px 10px -5px rgba(0, 0, 0, 0.04) !important;
}

/* ========================================
   IMAGEM / CARROSSEL
   ======================================== */
.em-card-carousel {
    position: relative !important;
    width: 100% !important;
    height: 220px !important;
    overflow: hidden !important;
    background: linear-gradient(135deg, #f3f4f6, #e5e7eb) !important;
    border-radius: 0 !important;
}

.em-carousel-track {
    position: relative !important;
    width: 100% !important;
    height: 100% !important;
}

.em-carousel-slide {
    position: absolute !important;
    top: 0 !important;
    left: 0 !important;
    width: 100% !important;
    height: 100% !important;
    opacity: 0 !important;
    transition: opacity 0.5s ease !important;
}

.em-carousel-slide.active {
    opacity: 1 !important;
    z-index: 1 !important;
}

.em-carousel-slide img {
    width: 100% !important;
    height: 100% !important;
    object-fit: cover !important;
}

/* Setas do Carrossel - Cantos Superiores */
.em-carousel-btn {
    position: absolute !important;
    top: 8px !important;
    width: 28px !important;
    height: 28px !important;
    background: rgba(0, 0, 0, 0.5) !important;
    border: none !important;
    border-radius: 6px !important;
    cursor: pointer !important;
    display: flex !important;
    align-items: center !important;
    justify-content: center !important;
    z-index: 10 !important;
    opacity: 0 !important;
    transition: all 0.3s ease !important;
}

.em-card:hover .em-carousel-btn {
    opacity: 1 !important;
}

.em-carousel-btn:hover {
    background: rgba(0, 0, 0, 0.7) !important;
}

.em-carousel-prev {
    left: 8px !important;
}

.em-carousel-next {
    right: 8px !important;
}

.em-carousel-btn svg {
    width: 14px !important;
    height: 14px !important;
    color: #fff !important;
    stroke-width: 2.5 !important;
}

/* Esconde os dots */
.em-carousel-dots {
    display: none !important;
}

/* Imagem estática */
.em-card-image {
    width: 100% !important;
    height: 220px !important;
    overflow: hidden !important;
    background: linear-gradient(135deg, #f3f4f6, #e5e7eb) !important;
}

.em-card-image img {
    width: 100% !important;
    height: 100% !important;
    object-fit: cover !important;
    transition: transform 0.5s ease !important;
}

.em-card:hover .em-card-image img {
    transform: scale(1.05) !important;
}

/* Ícone placeholder */
.em-card-icon {
    width: 100% !important;
    height: 220px !important;
    display: flex !important;
    align-items: center !important;
    justify-content: center !important;
    background: linear-gradient(135deg, #6366f1, #8b5cf6) !important;
}

.em-card-icon span {
    font-size: 64px !important;
    font-weight: 800 !important;
    color: rgba(255, 255, 255, 0.9) !important;
    text-shadow: 0 4px 12px rgba(0, 0, 0, 0.1) !important;
}

/* ========================================
   CONTEÚDO DO CARD
   ======================================== */
.em-card-content {
    padding: 20px !important;
    display: flex !important;
    flex-direction: column !important;
    gap: 12px !important;
    background: #fff !important;
}

.em-card-title {
    font-size: 16px !important;
    font-weight: 700 !important;
    color: #1f2937 !important;
    margin: 0 !important;
    padding: 0 !important;
    line-height: 1.4 !important;
    display: -webkit-box !important;
    -webkit-line-clamp: 2 !important;
    line-clamp: 2 !important;
    -webkit-box-orient: vertical !important;
    overflow: hidden !important;
}

.em-card-stats {
    display: flex !important;
    flex-direction: column !important;
    gap: 8px !important;
    margin: 0 !important;
    padding: 0 !important;
}

.em-card-bar {
    width: 100% !important;
    height: 6px !important;
    background: #e5e7eb !important;
    border-radius: 100px !important;
    overflow: hidden !important;
}

.em-card-bar-fill {
    height: 100% !important;
    background: linear-gradient(90deg, #6366f1, #8b5cf6) !important;
    border-radius: 100px !important;
    transition: width 0.5s ease !important;
}

.em-card-votes {
    font-size: 13px !important;
    color: #6b7280 !important;
    font-weight: 500 !important;
}

/* ========================================
   BOTÃO VOTAR
   ======================================== */
.em-vote-btn {
    width: 100% !important;
    height: 42px !important;
    padding: 0 20px 10px 20px !important;
    margin: 8px 0 0 0 !important;
    background: linear-gradient(135deg, #6366f1, #8b5cf6) !important;
    color: #fff !important;
    border: none !important;
    border-radius: 10px !important;
    font-size: 14px !important;
    font-weight: 600 !important;
    line-height: 1 !important;
    cursor: pointer !important;
    transition: all 0.2s ease !important;
    box-shadow: 0 2px 8px rgba(99, 102, 241, 0.3) !important;
    text-transform: uppercase !important;
    letter-spacing: 0.8px !important;
    text-align: center !important;
    display: flex !important;
    align-items: center !important;
    justify-content: center !important;
}

.em-vote-btn:hover {
    transform: translateY(-1px) !important;
    box-shadow: 0 4px 12px rgba(99, 102, 241, 0.4) !important;
    background: linear-gradient(135deg, #4f46e5, #7c3aed) !important;
}

.em-vote-btn:active {
    transform: translateY(0) !important;
    box-shadow: 0 2px 6px rgba(99, 102, 241, 0.3) !important;
}

/* Esconde hover overlay antigo */
.em-card-hover {
    display: none !important;
}

/* ========================================
   MODAL DE VOTAÇÃO
   ======================================== */
.em-modal {
    position: fixed !important;
    inset: 0 !important;
    z-index: 999999 !important;
    display: none !important;
    align-items: center !important;
    justify-content: center !important;
    padding: 15px !important;
    margin: 0 !important;
}

.em-modal.active {
    display: flex !important;
}

.em-modal-overlay {
    position: absolute !important;
    inset: 0 !important;
    background: rgba(15, 23, 42, 0.8) !important;
    backdrop-filter: blur(8px) !important;
    margin: 0 !important;
    padding: 0 !important;
}

.em-modal-content {
    position: relative !important;
    background: #ffffff !important;
    border-radius: 24px !important;
    width: 100% !important;
    max-width: 420px !important;
    max-height: 90vh !important;
    overflow-y: auto !important;
    padding: 28px !important;
    margin: 0 !important;
    box-shadow: 0 25px 60px -12px rgba(0, 0, 0, 0.35) !important;
    animation: emModalIn 0.3s cubic-bezier(0.4, 0, 0.2, 1) !important;
}

@keyframes emModalIn {
    from { opacity: 0; transform: scale(0.95) translateY(10px); }
    to { opacity: 1; transform: scale(1) translateY(0); }
}

.em-modal-close {
    position: absolute !important;
    top: 12px !important;
    right: 12px !important;
    width: 32px !important;
    height: 32px !important;
    border: none !important;
    background: #f1f5f9 !important;
    border-radius: 8px !important;
    font-size: 20px !important;
    line-height: 1 !important;
    color: #64748b !important;
    cursor: pointer !important;
    display: flex !important;
    align-items: center !important;
    justify-content: center !important;
    padding: 0 !important;
    margin: 0 !important;
    transition: all 0.2s !important;
}

.em-modal-close:hover {
    background: #e2e8f0 !important;
    color: #334155 !important;
}

/* Modal Header */
.em-modal-header {
    text-align: center !important;
    margin: 0 0 28px 0 !important;
    padding: 0 !important;
}

.em-selected-option {
    display: flex !important;
    align-items: center !important;
    gap: 16px !important;
    text-align: left !important;
    padding: 20px !important;
    background: linear-gradient(135deg, #6366f1 0%, #8b5cf6 50%, #a855f7 100%) !important;
    border-radius: 16px !important;
    margin: 0 !important;
    box-shadow: 0 4px 15px rgba(99, 102, 241, 0.3) !important;
}

.em-selected-icon {
    font-size: 32px !important;
    line-height: 1 !important;
    background: rgba(255, 255, 255, 0.2) !important;
    width: 56px !important;
    height: 56px !important;
    display: flex !important;
    align-items: center !important;
    justify-content: center !important;
    border-radius: 12px !important;
}

.em-selected-option small {
    color: rgba(255, 255, 255, 0.9) !important;
    font-size: 12px !important;
    font-weight: 600 !important;
    text-transform: uppercase !important;
    letter-spacing: 1px !important;
    display: block !important;
    margin: 0 0 4px 0 !important;
    padding: 0 !important;
}

.em-selected-option h3 {
    margin: 0 !important;
    padding: 0 !important;
    font-size: 20px !important;
    font-weight: 700 !important;
    color: #ffffff !important;
    line-height: 1.3 !important;
    text-shadow: 0 1px 2px rgba(0, 0, 0, 0.1) !important;
}

.em-token-icon {
    font-size: 40px !important;
    display: block !important;
    margin: 0 0 12px 0 !important;
    line-height: 1 !important;
}

.em-modal-header h3 {
    font-size: 20px !important;
    font-weight: 700 !important;
    color: #1e293b !important;
    margin: 0 0 4px 0 !important;
    padding: 0 !important;
    line-height: 1.3 !important;
}

.em-modal-header p {
    color: #64748b !important;
    font-size: 13px !important;
    margin: 0 !important;
    padding: 0 !important;
    line-height: 1.4 !important;
}

/* Form Compacto e Moderno */
.em-vote-form {
    margin: 0 !important;
    padding: 0 !important;
}

.em-field {
    margin: 0 0 20px 0 !important;
    padding: 0 !important;
}

.em-field label {
    display: block !important;
    font-size: 13px !important;
    font-weight: 600 !important;
    color: #374151 !important;
    margin: 0 0 8px 0 !important;
    padding: 0 !important;
    text-transform: uppercase !important;
    letter-spacing: 0.5px !important;
}

.em-field input,
.em-field input[type="text"],
.em-field input[type="email"] {
    width: 100% !important;
    height: 52px !important;
    padding: 0 16px !important;
    margin: 0 !important;
    border: 2px solid #e5e7eb !important;
    border-radius: 12px !important;
    font-size: 16px !important;
    font-weight: 500 !important;
    color: #1f2937 !important;
    background: #f9fafb !important;
    box-sizing: border-box !important;
    transition: all 0.2s ease !important;
    outline: none !important;
    box-shadow: none !important;
    -webkit-appearance: none !important;
    appearance: none !important;
}

.em-field input:focus {
    border-color: #6366f1 !important;
    background: #fff !important;
    box-shadow: 0 0 0 4px rgba(99, 102, 241, 0.1) !important;
}

.em-field input::placeholder {
    color: #94a3b8 !important;
    font-weight: 400 !important;
}

.em-token-input,
.em-token-input[type="text"] {
    height: 56px !important;
    font-size: 24px !important;
    text-align: center !important;
    letter-spacing: 8px !important;
    font-family: 'SF Mono', 'Monaco', 'Consolas', monospace !important;
    font-weight: 700 !important;
}

/* Botões Modernos */
.em-submit-btn,
.em-confirm-btn,
.em-modal-close-btn {
    width: 100% !important;
    height: 48px !important;
    padding: 0 20px !important;
    margin: 0 !important;
    background: linear-gradient(135deg, #6366f1, #8b5cf6) !important;
    color: #fff !important;
    border: none !important;
    border-radius: 12px !important;
    font-size: 15px !important;
    font-weight: 600 !important;
    cursor: pointer !important;
    transition: all 0.2s !important;
    box-shadow: 0 4px 14px rgba(99, 102, 241, 0.4) !important;
    display: flex !important;
    align-items: center !important;
    justify-content: center !important;
    gap: 8px !important;
    text-decoration: none !important;
    outline: none !important;
}

.em-submit-btn:hover,
.em-confirm-btn:hover,
.em-modal-close-btn:hover {
    transform: translateY(-1px) !important;
    box-shadow: 0 6px 20px rgba(99, 102, 241, 0.5) !important;
}

.em-submit-btn:active,
.em-confirm-btn:active {
    transform: translateY(0) !important;
}

.em-submit-btn:disabled,
.em-confirm-btn:disabled {
    opacity: 0.7 !important;
    cursor: wait !important;
    transform: none !important;
}

/* Loading só aparece quando visível via JS */
.em-btn-loading {
    align-items: center !important;
    justify-content: center !important;
    gap: 8px !important;
}

.em-btn-loading[style*="display: none"] {
    display: none !important;
}

.em-spinner {
    width: 16px !important;
    height: 16px !important;
    border: 2px solid rgba(255,255,255,0.3) !important;
    border-top-color: #fff !important;
    border-radius: 50% !important;
    animation: emSpin 0.7s linear infinite !important;
}

@keyframes emSpin {
    to { transform: rotate(360deg); }
}

.em-privacy-notice {
    text-align: center !important;
    font-size: 11px !important;
    color: #94a3b8 !important;
    margin: 12px 0 0 0 !important;
    padding: 0 !important;
}

.em-resend-link {
    text-align: center !important;
    margin: 16px 0 0 0 !important;
    padding: 0 !important;
    font-size: 13px !important;
    color: #64748b !important;
}

.em-resend-link a {
    color: #6366f1 !important;
    text-decoration: none !important;
    font-weight: 600 !important;
}

.em-resend-link a:hover {
    text-decoration: underline !important;
}

/* Sucesso Compacto */
.em-success-content {
    text-align: center !important;
    padding: 10px 0 !important;
    margin: 0 !important;
}

.em-success-icon {
    width: 64px !important;
    height: 64px !important;
    background: linear-gradient(135deg, #10b981 0%, #059669 100%) !important;
    border-radius: 50% !important;
    display: flex !important;
    align-items: center !important;
    justify-content: center !important;
    font-size: 32px !important;
    color: #fff !important;
    margin: 0 auto 16px auto !important;
    box-shadow: 0 4px 14px rgba(16, 185, 129, 0.4) !important;
}

.em-success-content h3 {
    font-size: 20px !important;
    font-weight: 700 !important;
    color: #1e293b !important;
    margin: 0 0 6px 0 !important;
    padding: 0 !important;
}

.em-success-content p {
    color: #64748b !important;
    font-size: 14px !important;
    margin: 0 0 20px 0 !important;
    padding: 0 !important;
}

/* Results */
.em-results-standalone {
    max-width: 700px;
    margin: 0 auto;
    padding: 20px;
}

.em-chart-wrapper {
    height: 300px;
    margin-bottom: 25px;
}

.em-results-list {
    display: flex;
    flex-direction: column;
    gap: 12px;
}

.em-result-item {
    display: flex;
    align-items: center;
    gap: 15px;
}

.em-result-title {
    width: 150px;
    font-size: 14px;
    font-weight: 600;
    color: var(--em-text);
}

.em-result-bar-wrapper {
    flex: 1;
    height: 20px;
    background: var(--em-bg);
    border-radius: 10px;
    overflow: hidden;
}

.em-result-bar {
    height: 100%;
    background: linear-gradient(90deg, var(--em-primary), var(--em-secondary));
    border-radius: 10px;
}

.em-result-stats {
    width: 80px;
    text-align: right;
    font-size: 13px;
    color: var(--em-text-light);
}

.em-results-total {
    text-align: center;
    margin-top: 20px;
    color: var(--em-text-light);
}

/* Error */
.em-error {
    background: #fed7d7;
    color: var(--em-error);
    padding: 15px 20px;
    border-radius: 8px;
    text-align: center;
}

/* Responsivo */
@media (max-width: 480px) {
    .em-poll-title { font-size: 24px; }
    .em-modal-content { padding: 20px; }
    .em-card-icon { height: 100px; }
    .em-card-icon span { font-size: 36px; }
}
