/* ===================================================================
   MARKETING - ESTILOS ESPECÍFICOS REFINADOS
   Sistema GestãoBLZ - Módulo de Marketing e Campanhas
   =================================================================== */

/* ===== KPIs DE MARKETING ===== */
.marketing-kpis {
    margin-bottom: 2rem;
}

.kpi-card {
    background: var(--theme-card-bg);
    border: 1px solid var(--theme-border-color);
    border-radius: 16px;
    padding: 1.5rem;
    height: 100%;
    display: flex;
    align-items: center;
    gap: 1.25rem;
    box-shadow: 0 4px 20px rgba(0, 0, 0, 0.05);
    transition: all 0.3s ease;
    position: relative;
    overflow: hidden;
}

.kpi-card:hover {
    transform: translateY(-4px);
    box-shadow: 0 8px 30px rgba(0, 0, 0, 0.1);
}

.kpi-card::before {
    content: '';
    position: absolute;
    top: 0;
    right: 0;
    width: 100px;
    height: 100px;
    opacity: 0.1;
    border-radius: 50%;
    transform: translate(30px, -30px);
}

.kpi-card.campaigns::before {
    background: linear-gradient(135deg, #ff6b6b, #ffa500);
}

.kpi-card.conversion::before {
    background: linear-gradient(135deg, #4ecdc4, #44a08d);
}

.kpi-card.revenue::before {
    background: linear-gradient(135deg, #667eea, #764ba2);
}

.kpi-card.whatsapp::before {
    background: linear-gradient(135deg, #25d366, #128c7e);
}

.kpi-icon {
    width: 60px;
    height: 60px;
    border-radius: 16px;
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 1.5rem;
    color: white;
    flex-shrink: 0;
}

.kpi-card.campaigns .kpi-icon {
    background: linear-gradient(135deg, #ff6b6b, #ffa500);
    box-shadow: 0 4px 15px rgba(255, 107, 107, 0.3);
}

.kpi-card.conversion .kpi-icon {
    background: linear-gradient(135deg, #4ecdc4, #44a08d);
    box-shadow: 0 4px 15px rgba(78, 205, 196, 0.3);
}

.kpi-card.revenue .kpi-icon {
    background: linear-gradient(135deg, #667eea, #764ba2);
    box-shadow: 0 4px 15px rgba(102, 126, 234, 0.3);
}

.kpi-card.whatsapp .kpi-icon {
    background: linear-gradient(135deg, #25d366, #128c7e);
    box-shadow: 0 4px 15px rgba(37, 211, 102, 0.3);
}

.kpi-content {
    flex: 1;
}

.kpi-value {
    font-size: 2rem;
    font-weight: 800;
    color: var(--theme-text-primary);
    margin: 0;
    line-height: 1;
}

.kpi-label {
    font-size: 0.875rem;
    color: var(--theme-text-secondary);
    margin: 0.25rem 0 0.5rem 0;
    font-weight: 500;
}

.kpi-trend {
    display: flex;
    align-items: center;
    gap: 0.375rem;
    font-size: 0.8125rem;
    font-weight: 600;
}

.kpi-trend.positive {
    color: #28a745;
}

.kpi-trend.negative {
    color: #dc3545;
}

.kpi-trend.neutral {
    color: var(--theme-text-secondary);
}

/* ===== MARKETING SECTIONS ===== */
.marketing-sections {
    margin-bottom: 2rem;
}

.marketing-card {
    background: var(--theme-card-bg);
    border: 1px solid var(--theme-border-color);
    border-radius: 16px;
    box-shadow: 0 4px 20px rgba(0, 0, 0, 0.05);
    transition: all 0.3s ease;
    height: fit-content;
    overflow: hidden;
}

.marketing-card:hover {
    transform: translateY(-2px);
    box-shadow: 0 8px 30px rgba(0, 0, 0, 0.1);
}

.marketing-card .card-header {
    background: var(--theme-bg-primary);
    border-bottom: 1px solid var(--theme-border-color);
    padding: 1.25rem 1.5rem;
    display: flex;
    align-items: center;
    justify-content: space-between;
}

.marketing-card .card-title {
    margin: 0;
    display: flex;
    align-items: center;
    gap: 0.75rem;
}

.marketing-card .card-title i {
    font-size: 1.25rem;
    color: var(--primary-color);
}

.marketing-card .card-title h5 {
    margin: 0;
    font-size: 1.125rem;
    font-weight: 600;
    color: var(--theme-text-primary);
}

.marketing-card .card-content {
    padding: 1.5rem;
}

/* ===== CAMPANHAS DE REATIVAÇÃO ===== */
.marketing-card.reactivation .card-title i {
    color: #ff6b6b;
}

.campaign-list {
    display: flex;
    flex-direction: column;
    gap: 1.25rem;
}

.campaign-item {
    display: flex;
    align-items: flex-start;
    gap: 1rem;
    padding: 1.25rem;
    background: var(--theme-bg-secondary);
    border-radius: 12px;
    border: 1px solid var(--theme-border-color);
    transition: all 0.3s ease;
    position: relative;
}

.campaign-item:hover {
    transform: translateY(-2px);
    box-shadow: 0 4px 15px rgba(0, 0, 0, 0.08);
}

.campaign-item::before {
    content: '';
    position: absolute;
    left: 0;
    top: 0;
    bottom: 0;
    width: 4px;
    border-radius: 0 2px 2px 0;
}

.campaign-item.urgent::before {
    background: linear-gradient(180deg, #ff6b6b, #ffa500);
}

.campaign-item.high-priority::before {
    background: linear-gradient(180deg, #667eea, #764ba2);
}

.campaign-item.medium-priority::before {
    background: linear-gradient(180deg, #4ecdc4, #44a08d);
}

.campaign-icon {
    width: 50px;
    height: 50px;
    border-radius: 12px;
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 1.25rem;
    color: white;
    flex-shrink: 0;
}

.campaign-item.urgent .campaign-icon {
    background: linear-gradient(135deg, #ff6b6b, #ffa500);
}

.campaign-item.high-priority .campaign-icon {
    background: linear-gradient(135deg, #667eea, #764ba2);
}

.campaign-item.medium-priority .campaign-icon {
    background: linear-gradient(135deg, #4ecdc4, #44a08d);
}

.campaign-content {
    flex: 1;
}

.campaign-title {
    font-size: 1rem;
    font-weight: 600;
    color: var(--theme-text-primary);
    margin: 0 0 0.5rem 0;
}

.campaign-description {
    font-size: 0.875rem;
    color: var(--theme-text-secondary);
    margin: 0 0 0.75rem 0;
}

.campaign-stats {
    display: flex;
    gap: 1rem;
    flex-wrap: wrap;
}

.campaign-stats .stat {
    display: flex;
    align-items: center;
    gap: 0.375rem;
    font-size: 0.8125rem;
    color: var(--theme-text-secondary);
    background: var(--theme-card-bg);
    padding: 0.25rem 0.5rem;
    border-radius: 6px;
    border: 1px solid var(--theme-border-color);
}

.campaign-stats .stat i {
    font-size: 0.75rem;
}

.campaign-stats .potential-revenue {
    color: #28a745;
    border-color: rgba(40, 167, 69, 0.2);
    background: rgba(40, 167, 69, 0.05);
}

.campaign-action {
    flex-shrink: 0;
}

/* ===== PROMOÇÕES ===== */
.marketing-card.promotions .card-title i {
    color: #ffa500;
}

.promotion-list {
    display: flex;
    flex-direction: column;
    gap: 1.25rem;
}

.promotion-item {
    display: flex;
    align-items: center;
    gap: 1rem;
    padding: 1.25rem;
    background: var(--theme-bg-secondary);
    border-radius: 12px;
    border: 1px solid var(--theme-border-color);
    transition: all 0.3s ease;
    position: relative;
}

.promotion-item:hover {
    transform: translateY(-2px);
    box-shadow: 0 4px 15px rgba(0, 0, 0, 0.08);
}

.promotion-item::before {
    content: '';
    position: absolute;
    left: 0;
    top: 0;
    bottom: 0;
    width: 4px;
    border-radius: 0 2px 2px 0;
}

.promotion-item.seasonal::before {
    background: linear-gradient(180deg, #ffa500, #ff8c00);
}

.promotion-item.time-based::before {
    background: linear-gradient(180deg, #17a2b8, #138496);
}

.promotion-item.premium::before {
    background: linear-gradient(180deg, #6f42c1, #563d7c);
}

.promotion-icon {
    width: 50px;
    height: 50px;
    border-radius: 12px;
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 1.25rem;
    color: white;
    flex-shrink: 0;
}

.promotion-item.seasonal .promotion-icon {
    background: linear-gradient(135deg, #ffa500, #ff8c00);
}

.promotion-item.time-based .promotion-icon {
    background: linear-gradient(135deg, #17a2b8, #138496);
}

.promotion-item.premium .promotion-icon {
    background: linear-gradient(135deg, #6f42c1, #563d7c);
}

.promotion-content {
    flex: 1;
}

.promotion-title {
    font-size: 1rem;
    font-weight: 600;
    color: var(--theme-text-primary);
    margin: 0 0 0.5rem 0;
}

.promotion-description {
    font-size: 0.875rem;
    color: var(--theme-text-secondary);
    margin: 0 0 0.75rem 0;
}

.promotion-details {
    display: flex;
    gap: 1rem;
    flex-wrap: wrap;
}

.promotion-details .detail {
    font-size: 0.8125rem;
    color: var(--theme-text-secondary);
    background: var(--theme-card-bg);
    padding: 0.25rem 0.5rem;
    border-radius: 6px;
    border: 1px solid var(--theme-border-color);
}

.promotion-action {
    flex-shrink: 0;
}

/* ===== CROSS-SELL ===== */
.marketing-card.crosssell .card-title i {
    color: #4ecdc4;
}

.success-rate {
    background: rgba(40, 167, 69, 0.1);
    color: #28a745;
    padding: 0.25rem 0.75rem;
    border-radius: 20px;
    font-size: 0.8125rem;
    font-weight: 600;
}

.crosssell-list {
    display: flex;
    flex-direction: column;
    gap: 1.25rem;
}

.crosssell-item {
    display: flex;
    align-items: flex-start;
    gap: 1rem;
    padding: 1.25rem;
    background: var(--theme-bg-secondary);
    border-radius: 12px;
    border: 1px solid var(--theme-border-color);
    transition: all 0.3s ease;
    position: relative;
}

.crosssell-item:hover {
    transform: translateY(-2px);
    box-shadow: 0 4px 15px rgba(0, 0, 0, 0.08);
}

.crosssell-item::before {
    content: '';
    position: absolute;
    left: 0;
    top: 0;
    bottom: 0;
    width: 4px;
    border-radius: 0 2px 2px 0;
}

.crosssell-item.high-conversion::before {
    background: linear-gradient(180deg, #28a745, #20c997);
}

.crosssell-item.excellent-conversion::before {
    background: linear-gradient(180deg, #007bff, #0056b3);
}

.crosssell-item.special-case::before {
    background: linear-gradient(180deg, #ffc107, #e0a800);
}

.crosssell-icon {
    width: 50px;
    height: 50px;
    border-radius: 12px;
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 1.25rem;
    color: white;
    flex-shrink: 0;
}

.crosssell-item.high-conversion .crosssell-icon {
    background: linear-gradient(135deg, #28a745, #20c997);
}

.crosssell-item.excellent-conversion .crosssell-icon {
    background: linear-gradient(135deg, #007bff, #0056b3);
}

.crosssell-item.special-case .crosssell-icon {
    background: linear-gradient(135deg, #ffc107, #e0a800);
}

.crosssell-content {
    flex: 1;
}

.crosssell-title {
    font-size: 1rem;
    font-weight: 600;
    color: var(--theme-text-primary);
    margin: 0 0 0.5rem 0;
}

.crosssell-description {
    font-size: 0.875rem;
    color: var(--theme-text-secondary);
    margin: 0 0 0.75rem 0;
}

.crosssell-stats {
    display: flex;
    gap: 1rem;
    flex-wrap: wrap;
}

.crosssell-stats .stat {
    display: flex;
    align-items: center;
    gap: 0.375rem;
    font-size: 0.8125rem;
    color: var(--theme-text-secondary);
    background: var(--theme-card-bg);
    padding: 0.25rem 0.5rem;
    border-radius: 6px;
    border: 1px solid var(--theme-border-color);
}

.crosssell-stats .conversion-rate {
    color: #007bff;
    border-color: rgba(0, 123, 255, 0.2);
    background: rgba(0, 123, 255, 0.05);
}

.crosssell-action {
    flex-shrink: 0;
}

/* ===== FIDELIDADE ===== */
.marketing-card.loyalty .card-title i {
    color: #e74c3c;
}

.loyalty-list {
    display: flex;
    flex-direction: column;
    gap: 1.25rem;
}

.loyalty-item {
    display: flex;
    align-items: center;
    gap: 1rem;
    padding: 1.25rem;
    background: var(--theme-bg-secondary);
    border-radius: 12px;
    border: 1px solid var(--theme-border-color);
    transition: all 0.3s ease;
    position: relative;
}

.loyalty-item:hover {
    transform: translateY(-2px);
    box-shadow: 0 4px 15px rgba(0, 0, 0, 0.08);
}

.loyalty-item::before {
    content: '';
    position: absolute;
    left: 0;
    top: 0;
    bottom: 0;
    width: 4px;
    border-radius: 0 2px 2px 0;
}

.loyalty-item.ltv-program::before {
    background: linear-gradient(180deg, #6f42c1, #563d7c);
}

.loyalty-item.nps-program::before {
    background: linear-gradient(180deg, #28a745, #20c997);
}

.loyalty-icon {
    width: 50px;
    height: 50px;
    border-radius: 12px;
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 1.25rem;
    color: white;
    flex-shrink: 0;
}

.loyalty-item.ltv-program .loyalty-icon {
    background: linear-gradient(135deg, #6f42c1, #563d7c);
}

.loyalty-item.nps-program .loyalty-icon {
    background: linear-gradient(135deg, #28a745, #20c997);
}

.loyalty-content {
    flex: 1;
}

.loyalty-title {
    font-size: 1rem;
    font-weight: 600;
    color: var(--theme-text-primary);
    margin: 0 0 0.5rem 0;
}

.loyalty-description {
    font-size: 0.875rem;
    color: var(--theme-text-secondary);
    margin: 0 0 0.75rem 0;
}

.loyalty-benefits {
    display: flex;
    gap: 0.75rem;
    flex-wrap: wrap;
}

.loyalty-benefits .benefit {
    font-size: 0.8125rem;
    background: rgba(40, 167, 69, 0.1);
    color: #28a745;
    padding: 0.25rem 0.5rem;
    border-radius: 6px;
    font-weight: 600;
}

.loyalty-action {
    flex-shrink: 0;
}

/* ===== FERRAMENTAS AVANÇADAS ===== */
.marketing-card.tools .card-title i {
    color: #17a2b8;
}

.tools-grid {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(280px, 1fr));
    gap: 1.25rem;
}

.tool-item {
    background: var(--theme-bg-secondary);
    border: 1px solid var(--theme-border-color);
    border-radius: 12px;
    padding: 1.5rem;
    text-align: center;
    transition: all 0.3s ease;
    position: relative;
    overflow: hidden;
}

.tool-item:hover {
    transform: translateY(-2px);
    box-shadow: 0 4px 15px rgba(0, 0, 0, 0.08);
}

.tool-item.special {
    background: linear-gradient(135deg, rgba(255, 107, 107, 0.05), rgba(255, 165, 0, 0.05));
    border-color: rgba(255, 107, 107, 0.2);
}

.tool-item.special::before {
    content: '🌟';
    position: absolute;
    top: 0.75rem;
    right: 0.75rem;
    font-size: 1rem;
}

.tool-icon {
    width: 60px;
    height: 60px;
    border-radius: 16px;
    background: linear-gradient(135deg, var(--primary-color), var(--primary-hover));
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 1.5rem;
    color: white;
    margin: 0 auto 1rem;
}

.tool-item.special .tool-icon {
    background: linear-gradient(135deg, #ff6b6b, #ffa500);
}

.tool-title {
    font-size: 1rem;
    font-weight: 600;
    color: var(--theme-text-primary);
    margin: 0 0 0.75rem 0;
}

.tool-description {
    font-size: 0.875rem;
    color: var(--theme-text-secondary);
    margin: 0 0 1.25rem 0;
    line-height: 1.5;
}

/* ===== CAMPANHAS ESPECIAIS ===== */
.marketing-card.special-campaigns .card-title i {
    color: #ff8c00;
}

.special-campaigns-grid {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(300px, 1fr));
    gap: 1.25rem;
}

.campaign-special {
    background: var(--theme-bg-secondary);
    border: 1px solid var(--theme-border-color);
    border-radius: 12px;
    padding: 1.5rem;
    transition: all 0.3s ease;
    position: relative;
}

.campaign-special:hover {
    transform: translateY(-2px);
    box-shadow: 0 4px 15px rgba(0, 0, 0, 0.08);
}

.campaign-special.birthday::before {
    content: '';
    position: absolute;
    left: 0;
    top: 0;
    bottom: 0;
    width: 4px;
    background: linear-gradient(180deg, #ff6b6b, #ffa500);
    border-radius: 0 2px 2px 0;
}

.campaign-special.team::before {
    content: '';
    position: absolute;
    left: 0;
    top: 0;
    bottom: 0;
    width: 4px;
    background: linear-gradient(180deg, #ffc107, #e0a800);
    border-radius: 0 2px 2px 0;
}

.campaign-special .campaign-icon {
    width: 50px;
    height: 50px;
    border-radius: 12px;
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 1.25rem;
    color: white;
    margin-bottom: 1rem;
}

.campaign-special.birthday .campaign-icon {
    background: linear-gradient(135deg, #ff6b6b, #ffa500);
}

.campaign-special.team .campaign-icon {
    background: linear-gradient(135deg, #ffc107, #e0a800);
}

.campaign-content h6 {
    font-size: 1rem;
    font-weight: 600;
    color: var(--theme-text-primary);
    margin: 0 0 0.5rem 0;
}

.campaign-content p {
    font-size: 0.875rem;
    color: var(--theme-text-secondary);
    margin: 0 0 1rem 0;
}

.birthday-list {
    display: flex;
    flex-direction: column;
    gap: 0.5rem;
    margin-bottom: 1rem;
}

.birthday-client {
    font-size: 0.8125rem;
    color: var(--theme-text-primary);
    background: var(--theme-card-bg);
    padding: 0.375rem 0.75rem;
    border-radius: 6px;
    border: 1px solid var(--theme-border-color);
}

.achievement {
    margin-bottom: 1rem;
}

.achievement-badge {
    display: inline-block;
    background: linear-gradient(135deg, #ffc107, #e0a800);
    color: white;
    padding: 0.375rem 0.75rem;
    border-radius: 20px;
    font-size: 0.8125rem;
    font-weight: 600;
}

/* ===== BOTÕES ===== */
.btn {
    border-radius: 10px;
    font-weight: 600;
    transition: all 0.3s ease;
    display: flex;
    align-items: center;
    gap: 0.5rem;
    text-decoration: none;
}

.btn:hover {
    transform: translateY(-1px);
}

.btn-sm {
    padding: 0.5rem 1rem;
    font-size: 0.8125rem;
}

.btn-primary {
    background: linear-gradient(135deg, var(--primary-color), var(--primary-hover));
    border: none;
    color: white;
    box-shadow: 0 2px 8px rgba(var(--primary-r), var(--primary-g), var(--primary-b), 0.3);
}

.btn-primary:hover {
    box-shadow: 0 4px 15px rgba(var(--primary-r), var(--primary-g), var(--primary-b), 0.4);
}

.btn-success {
    background: linear-gradient(135deg, #28a745, #20c997);
    border: none;
    color: white;
    box-shadow: 0 2px 8px rgba(40, 167, 69, 0.3);
}

.btn-success:hover {
    box-shadow: 0 4px 15px rgba(40, 167, 69, 0.4);
}

.btn-warning {
    background: linear-gradient(135deg, #ffc107, #e0a800);
    border: none;
    color: white;
    box-shadow: 0 2px 8px rgba(255, 193, 7, 0.3);
}

.btn-warning:hover {
    box-shadow: 0 4px 15px rgba(255, 193, 7, 0.4);
}

.btn-info {
    background: linear-gradient(135deg, #17a2b8, #138496);
    border: none;
    color: white;
    box-shadow: 0 2px 8px rgba(23, 162, 184, 0.3);
}

.btn-info:hover {
    box-shadow: 0 4px 15px rgba(23, 162, 184, 0.4);
}

.btn-danger {
    background: linear-gradient(135deg, #dc3545, #c82333);
    border: none;
    color: white;
    box-shadow: 0 2px 8px rgba(220, 53, 69, 0.3);
}

.btn-danger:hover {
    box-shadow: 0 4px 15px rgba(220, 53, 69, 0.4);
}

/* ===== MODAIS ===== */
.modal-content {
    border: none;
    border-radius: 16px;
    box-shadow: 0 20px 60px rgba(0, 0, 0, 0.15);
}

.modal-header {
    border-bottom: 1px solid var(--theme-border-color);
    background: var(--theme-bg-primary);
    border-radius: 16px 16px 0 0;
    padding: 1.5rem;
}

.modal-title {
    display: flex;
    align-items: center;
    gap: 0.5rem;
    color: var(--theme-text-primary);
    font-weight: 600;
}

.modal-body {
    background: var(--theme-card-bg);
    padding: 1.5rem;
}

.modal-footer {
    border-top: 1px solid var(--theme-border-color);
    background: var(--theme-bg-primary);
    border-radius: 0 0 16px 16px;
    padding: 1.25rem 1.5rem;
}

/* ===== FORMULÁRIOS ===== */
.form-label {
    font-weight: 500;
    color: var(--theme-text-primary);
    margin-bottom: 0.5rem;
}

.form-control,
.form-select {
    border: 1px solid var(--theme-border-color);
    border-radius: 8px;
    background: var(--theme-bg-secondary);
    color: var(--theme-text-primary);
    padding: 0.75rem;
    transition: all 0.3s ease;
}

.form-control:focus,
.form-select:focus {
    border-color: var(--primary-color);
    box-shadow: 0 0 0 2px rgba(var(--primary-r), var(--primary-g), var(--primary-b), 0.1);
    background: var(--theme-card-bg);
}

/* ===== ROLETA DE PRÊMIOS ===== */
.wheel-preview {
    display: flex;
    justify-content: center;
    align-items: center;
    padding: 2rem 0;
}

.wheel-container {
    position: relative;
    display: inline-block;
}

#wheelCanvas {
    border: 4px solid var(--theme-border-color);
    border-radius: 50%;
    box-shadow: 0 8px 30px rgba(0, 0, 0, 0.15);
}

.wheel-center {
    position: absolute;
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%);
    width: 40px;
    height: 40px;
    background: linear-gradient(135deg, var(--primary-color), var(--primary-hover));
    border-radius: 50%;
    display: flex;
    align-items: center;
    justify-content: center;
    color: white;
    font-size: 1rem;
    cursor: pointer;
    box-shadow: 0 4px 15px rgba(0, 0, 0, 0.2);
}

.prize-config {
    display: flex;
    flex-direction: column;
    gap: 1rem;
    margin-bottom: 1rem;
}

.prize-item {
    padding: 1rem;
    background: var(--theme-bg-secondary);
    border: 1px solid var(--theme-border-color);
    border-radius: 8px;
}

/* ===== RESPONSIVIDADE ===== */
@media (max-width: 1200px) {
    .tools-grid {
        grid-template-columns: repeat(auto-fit, minmax(250px, 1fr));
    }
}

@media (max-width: 992px) {
    .marketing-kpis .row {
        text-align: center;
    }
    
    .kpi-card {
        flex-direction: column;
        text-align: center;
        gap: 1rem;
    }
    
    .tools-grid {
        grid-template-columns: repeat(auto-fit, minmax(280px, 1fr));
    }
    
    .special-campaigns-grid {
        grid-template-columns: 1fr;
    }
}

@media (max-width: 768px) {
    .marketing-card .card-header {
        flex-direction: column;
        gap: 1rem;
        align-items: stretch;
    }
    
    .campaign-item,
    .promotion-item,
    .crosssell-item,
    .loyalty-item {
        flex-direction: column;
        text-align: center;
        gap: 1rem;
    }
    
    .campaign-stats,
    .promotion-details,
    .crosssell-stats,
    .loyalty-benefits {
        justify-content: center;
    }
    
    .tools-grid {
        grid-template-columns: 1fr;
    }
    
    .modal-dialog {
        margin: 0.5rem;
    }
}

@media (max-width: 576px) {
    .marketing-card .card-content {
        padding: 1rem;
    }
    
    .kpi-card {
        padding: 1rem;
    }
    
    .kpi-value {
        font-size: 1.5rem;
    }
    
    .campaign-item,
    .promotion-item,
    .crosssell-item,
    .loyalty-item,
    .tool-item,
    .campaign-special {
        padding: 1rem;
    }
    
    .campaign-icon,
    .promotion-icon,
    .crosssell-icon,
    .loyalty-icon,
    .kpi-icon,
    .tool-icon {
        width: 45px;
        height: 45px;
        font-size: 1.125rem;
    }
    
    .modal-header,
    .modal-body,
    .modal-footer {
        padding: 1rem;
    }
}

/* ===== TEMA ESCURO ===== */
.theme-dark .marketing-card:hover {
    box-shadow: 0 8px 30px rgba(255, 255, 255, 0.1);
}

.theme-dark .campaign-item:hover,
.theme-dark .promotion-item:hover,
.theme-dark .crosssell-item:hover,
.theme-dark .loyalty-item:hover,
.theme-dark .tool-item:hover,
.theme-dark .campaign-special:hover {
    box-shadow: 0 4px 15px rgba(255, 255, 255, 0.08);
}

.theme-dark #wheelCanvas {
    border-color: var(--theme-border-color);
}

/* ===== ANIMAÇÕES ===== */
@keyframes fadeInUp {
    from {
        opacity: 0;
        transform: translateY(20px);
    }
    to {
        opacity: 1;
        transform: translateY(0);
    }
}

.campaign-item,
.promotion-item,
.crosssell-item,
.loyalty-item,
.tool-item {
    animation: fadeInUp 0.3s ease-out;
}

.kpi-card {
    animation: fadeInUp 0.4s ease-out;
}

.marketing-card {
    animation: fadeInUp 0.5s ease-out;
}

/* ===== UTILIDADES ===== */
.text-success {
    color: #28a745 !important;
}

.text-danger {
    color: #dc3545 !important;
}

.text-warning {
    color: #ffc107 !important;
}

.text-info {
    color: #17a2b8 !important;
}

.bg-light-success {
    background-color: rgba(40, 167, 69, 0.1) !important;
}

.bg-light-danger {
    background-color: rgba(220, 53, 69, 0.1) !important;
}

.bg-light-warning {
    background-color: rgba(255, 193, 7, 0.1) !important;
}

.bg-light-info {
    background-color: rgba(23, 162, 184, 0.1) !important;
}