/* /vkads/ — Реклама ВКонтакте */

.vkads-root { padding: 0; }

.vkads-beta-badge {
    font-size: 0.65em;
    padding: 2px 7px;
    border-radius: 999px;
    background: rgba(255, 193, 7, 0.18);
    color: #ffc107;
    font-weight: 600;
    text-transform: uppercase;
    letter-spacing: 0.04em;
    vertical-align: middle;
}

/* ============== ЛИМИТ ============== */
.vkads-limit-wrap { display: flex; justify-content: center; padding: 2rem 1rem; }
.vkads-limit-card {
    max-width: 560px; text-align: center;
    background: var(--surface-1); border: 1px solid var(--border-color);
    border-radius: 16px; padding: 2.5rem 2rem;
}
.vkads-limit-icon { font-size: 3rem; color: var(--neon-primary); margin-bottom: 1rem; }
.vkads-limit-title { margin-bottom: 1rem; }
.vkads-limit-text { margin-bottom: 1.5rem; }
.vkads-limit-actions { display: flex; gap: .75rem; justify-content: center; flex-wrap: wrap; }

/* ============== CONNECT ============== */
.vkads-connect-wrap {
    display: grid; grid-template-columns: 1fr 1fr; gap: 1.5rem;
    align-items: start;
}
@media (max-width: 900px) { .vkads-connect-wrap { grid-template-columns: 1fr; } }

.vkads-instructions {
    background: var(--surface-1); border: 1px solid var(--border-color);
    border-radius: 12px; padding: 1.5rem;
}
.vkads-instructions h4 { margin-bottom: .75rem; }
.vkads-steps { padding-left: 1.25rem; line-height: 1.65; }
.vkads-steps li { margin-bottom: .5rem; }
.vkads-steps code {
    background: rgba(123, 109, 240, 0.10);
    color: var(--neon-primary);
    padding: 1px 6px; border-radius: 4px; font-size: 0.92em;
}
.vkads-callout {
    margin-top: 1.25rem; padding: .85rem 1rem;
    background: rgba(56, 189, 248, 0.08);
    border: 1px solid rgba(56, 189, 248, 0.25);
    border-radius: 10px; font-size: 0.92em;
    display: flex; gap: .65rem; align-items: flex-start;
}
.vkads-callout i { color: rgb(56, 189, 248); font-size: 1.1em; flex-shrink: 0; margin-top: 2px; }

.vkads-connect-form {
    background: var(--surface-1); border: 1px solid var(--border-color);
    border-radius: 12px; padding: 1.5rem;
}

/* ============== АККАУНТ ============== */
.vkads-account-card {
    background: var(--surface-1); border: 1px solid var(--border-color);
    border-radius: 12px; overflow: hidden;
    max-width: 640px;
}
.vkads-account-row {
    display: flex; padding: .85rem 1.25rem;
    border-bottom: 1px solid var(--border-color);
}
.vkads-account-row:last-child { border-bottom: none; }
.vkads-account-label {
    flex: 0 0 220px; color: var(--text-secondary);
    font-size: .92rem;
}
.vkads-account-value {
    flex: 1; word-break: break-all;
}

/* ============== EMPTY ============== */
.vkads-empty {
    text-align: center; padding: 3rem 1rem;
    background: var(--surface-1); border: 1px dashed var(--border-color);
    border-radius: 12px;
}
.vkads-empty i { font-size: 3rem; color: var(--text-secondary); margin-bottom: 1rem; display: block; }
.vkads-empty h4 { margin-bottom: .5rem; }

/* ============== TABLE ============== */
.vkads-plans-table {
    background: var(--surface-1);
    border: 1px solid var(--border-color);
    border-radius: 12px;
    overflow: hidden;
    margin-bottom: 0;
}
.vkads-plans-table th {
    background: var(--surface-2);
    border-bottom: 1px solid var(--border-color);
    font-weight: 600;
    font-size: 0.88rem;
    color: var(--text-secondary);
    padding: .75rem 1rem;
}
.vkads-plans-table td { padding: .85rem 1rem; vertical-align: middle; }
.vkads-plan-name { font-weight: 600; }
.vkads-plan-meta { margin-top: 2px; }

/* ============== БРИФ ============== */
.vkads-brief-wrap { max-width: 720px; }
.vkads-brief-form {
    background: var(--surface-1); border: 1px solid var(--border-color);
    border-radius: 12px; padding: 1.5rem;
}
.vkads-brief-cost {
    background: rgba(123, 109, 240, 0.08);
    border: 1px solid rgba(123, 109, 240, 0.2);
    border-radius: 8px; padding: .65rem 1rem;
    margin-bottom: 1rem; font-size: .92em;
}
.vkads-brief-cost i { color: var(--neon-primary); margin-right: .35em; }

/* ============== ПРОГРЕСС ============== */
.vkads-run-wrap {
    max-width: 640px; margin: 0 auto;
    background: var(--surface-1); border: 1px solid var(--border-color);
    border-radius: 12px; padding: 1.5rem;
}
.vkads-run-stage { color: var(--text-secondary); font-size: 0.95em; margin-top: .5rem; }

/* ============== PREVIEW ============== */
.vkads-preview-head {
    display: flex; justify-content: space-between; align-items: flex-start;
    gap: 1rem; flex-wrap: wrap; margin-top: 1rem;
}
.vkads-preview-actions { display: flex; gap: .5rem; align-items: center; flex-wrap: wrap; }

.vkads-analysis {
    background: var(--surface-1); border: 1px solid var(--border-color);
    border-radius: 10px; padding: 1rem;
    line-height: 1.65;
}
.vkads-analysis > div { margin-bottom: .35em; }

.vkads-audience-card {
    background: var(--surface-1); border: 1px solid var(--border-color);
    border-radius: 12px; padding: 1.25rem; margin-bottom: 1rem;
}
.vkads-audience-head { display: flex; gap: .85rem; align-items: flex-start; margin-bottom: .75rem; }
.vkads-audience-num {
    flex: 0 0 36px; height: 36px; border-radius: 50%;
    background: var(--neon-primary); color: white;
    display: flex; align-items: center; justify-content: center;
    font-weight: 600;
}
.vkads-audience-title { flex: 1; }
.vkads-audience-targeting {
    display: flex; flex-wrap: wrap; gap: .65rem;
    padding: .55rem .8rem;
    background: var(--surface-2); border-radius: 8px;
    font-size: .88em; margin-bottom: .85rem;
}
.vkads-audience-targeting span { color: var(--text-secondary); }
.vkads-audience-targeting i { color: var(--neon-primary); margin-right: 4px; }

.vkads-banners {
    display: grid; grid-template-columns: repeat(auto-fill, minmax(260px, 1fr));
    gap: .75rem;
}
.vkads-banner {
    background: var(--surface-2); border: 1px solid var(--border-color);
    border-radius: 8px; padding: .85rem 1rem;
}
.vkads-banner-title { font-weight: 600; font-size: 1em; line-height: 1.3; margin-bottom: .35rem; }
.vkads-banner-text { font-size: .9em; color: var(--text-secondary); line-height: 1.4; margin-bottom: .55rem; }
.vkads-banner-cta {
    display: inline-block; font-size: .85em;
    padding: 3px 10px; border-radius: 999px;
    background: rgba(123, 109, 240, 0.12); color: var(--neon-primary);
    font-weight: 500;
}

/* ============== HISTORY ============== */
.vkads-jobs-table th { background: var(--surface-2); font-size: .88em; color: var(--text-secondary); }
.vkads-jobs-table td { vertical-align: middle; padding: .75rem 1rem; }

/* ============== ОПТИМИЗАТОР ============== */
.vkads-opt-card {
    background: var(--surface-1); border: 1px solid var(--border-color);
    border-radius: 12px; padding: 1.25rem; margin-bottom: 1rem;
}
.vkads-opt-head { margin-bottom: .75rem; }
.vkads-opt-meta {
    display: flex; flex-wrap: wrap; gap: .8rem; align-items: center;
    color: var(--text-secondary); font-size: .92em; margin-top: .35rem;
}
.vkads-opt-meta i { color: var(--neon-primary); margin-right: 4px; }
.vkads-opt-empty {
    padding: .85rem 1rem;
    background: var(--surface-2); border-radius: 8px;
}
.vkads-opt-rec {
    background: var(--surface-2); border: 1px solid var(--border-color);
    border-radius: 8px; padding: .75rem 1rem;
    display: flex; justify-content: space-between; align-items: center;
    gap: .75rem; flex-wrap: wrap; margin-bottom: .5rem;
}
.vkads-opt-rec:last-child { margin-bottom: 0; }
.vkads-opt-rec-head {
    flex: 1 1 auto; display: flex; align-items: flex-start; gap: .65rem;
}
.vkads-opt-rec-reason { font-size: .92em; line-height: 1.45; }
.vkads-opt-rec-actions { flex: 0 0 auto; }

/* ============== ЖУРНАЛ ДЕЙСТВИЙ ============== */
.vkads-actions-table th {
    background: var(--surface-2); font-size: .88em;
    color: var(--text-secondary); padding: .75rem 1rem;
}
.vkads-actions-table td { vertical-align: middle; padding: .75rem 1rem; }

/* Креативы группы (1080×607) под банерами */
.vkads-aud-images {
    margin-top: .85rem;
    padding-top: .85rem;
    border-top: 1px dashed var(--border-color);
}
.vkads-aud-images-label {
    color: var(--text-secondary);
    font-size: .9em;
    margin-bottom: .5rem;
}
.vkads-aud-images-label i { color: var(--neon-primary); margin-right: 4px; }
.vkads-aud-images-grid {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(220px, 1fr));
    gap: .65rem;
}
.vkads-aud-image {
    display: block;
    aspect-ratio: 1080 / 607;
    overflow: hidden;
    border-radius: 8px;
    border: 1px solid var(--border-color);
    background: var(--surface-2);
}
.vkads-aud-image img {
    width: 100%; height: 100%; object-fit: cover; display: block;
    transition: transform .25s;
}
.vkads-aud-image:hover img { transform: scale(1.04); }
