/* ================================================================
   YouTube Video Idea Generator — Page-specific styles
   Uses shared component classes from /css/components/*.css
   ================================================================ */

/* ── Social proof ── */
.vig-social-proof {
    color: var(--color-gray-500);
    font-size: var(--font-size-sm);
    margin-top: var(--space-3);
}
.vig-social-proof i {
    color: var(--color-primary);
    margin-right: var(--space-1);
}

/* ── Section headers ── */
.vig-section {
    margin-bottom: var(--space-5);
}

.vig-section-title {
    font-size: var(--font-size-base);
    font-weight: 700;
    color: var(--color-gray-800);
    margin: 0 0 var(--space-3) 0;
    display: flex;
    align-items: center;
    gap: var(--space-2);
}

.vig-section-title i {
    color: var(--color-primary);
    font-size: var(--font-size-sm);
}

/* ── Niche Grid (visual cards) ── */
.vig-niche-grid {
    display: grid;
    grid-template-columns: repeat(5, 1fr);
    gap: var(--space-3);
}

.vig-niche-card {
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: var(--space-2);
    padding: var(--space-4) var(--space-2);
    border: 1px solid var(--color-gray-200);
    border-radius: var(--radius-lg);
    background: var(--color-white, #fff);
    cursor: pointer;
    transition: all 150ms ease;
    font-family: var(--font-body);
    font-size: var(--font-size-sm);
    font-weight: 500;
    color: var(--color-gray-700);
}

.vig-niche-card i {
    font-size: 22px;
    color: var(--color-gray-400);
    transition: color 150ms ease;
}

.vig-niche-card:hover {
    border-color: var(--color-primary);
    background: rgba(79, 70, 229, 0.04);
    transform: translateY(-1px);
    box-shadow: var(--shadow-sm);
}

.vig-niche-card:hover i {
    color: var(--color-primary);
}

.vig-niche-card--active {
    border-color: var(--color-primary);
    background: rgba(79, 70, 229, 0.08);
    color: var(--color-primary);
    box-shadow: 0 0 0 2px rgba(79, 70, 229, 0.15);
}

.vig-niche-card--active i {
    color: var(--color-primary);
}

/* ── Format Filter Tabs ── */
.vig-format-tabs {
    display: flex;
    flex-wrap: wrap;
    gap: var(--space-2);
}

.vig-format-tab {
    padding: var(--space-2) var(--space-4);
    border: 1px solid var(--color-gray-300);
    border-radius: 999px;
    background: var(--color-white, #fff);
    color: var(--color-gray-600);
    font-size: var(--font-size-sm);
    font-weight: 500;
    font-family: var(--font-body);
    cursor: pointer;
    transition: all 150ms ease;
}

.vig-format-tab:hover {
    border-color: var(--color-primary);
    color: var(--color-primary);
    background: rgba(79, 70, 229, 0.04);
}

.vig-format-tab--active {
    background: var(--color-primary);
    color: var(--color-white);
    border-color: var(--color-primary);
}

.vig-format-tab--active:hover {
    background: var(--color-primary-dark);
    border-color: var(--color-primary-dark);
    color: var(--color-white);
}

/* ── Filters Row (faceless + difficulty) ── */
.vig-filters-row {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: var(--space-4);
    padding: var(--space-4) var(--space-5);
    background: var(--color-gray-50);
    border: 1px solid var(--color-gray-200);
    border-radius: var(--radius-lg);
    margin-bottom: var(--space-5);
    flex-wrap: wrap;
}

/* ── Faceless Toggle ── */
.vig-faceless-toggle {
    display: flex;
    align-items: center;
    gap: var(--space-3);
    cursor: pointer;
    user-select: none;
}

.vig-faceless-toggle__switch {
    position: relative;
    width: 44px;
    height: 24px;
    flex-shrink: 0;
}

.vig-faceless-toggle__switch input {
    opacity: 0;
    width: 0;
    height: 0;
    position: absolute;
}

.vig-faceless-toggle__slider {
    position: absolute;
    top: 0;
    left: 0;
    right: 0;
    bottom: 0;
    background: var(--color-gray-300);
    border-radius: 12px;
    transition: background 200ms ease;
}

.vig-faceless-toggle__slider::after {
    content: '';
    position: absolute;
    top: 2px;
    left: 2px;
    width: 20px;
    height: 20px;
    background: var(--color-white, #fff);
    border-radius: 50%;
    transition: transform 200ms ease;
    box-shadow: var(--shadow-sm);
}

.vig-faceless-toggle__switch input:checked + .vig-faceless-toggle__slider {
    background: var(--color-primary);
}

.vig-faceless-toggle__switch input:checked + .vig-faceless-toggle__slider::after {
    transform: translateX(20px);
}

.vig-faceless-toggle__label {
    font-size: var(--font-size-sm);
    font-weight: 600;
    color: var(--color-gray-700);
    display: flex;
    align-items: center;
    gap: var(--space-2);
}

.vig-faceless-toggle__label i {
    color: var(--color-gray-500);
}

.vig-faceless-toggle__switch input:checked ~ .vig-faceless-toggle__label i,
.vig-faceless-toggle input:checked ~ .vig-faceless-toggle__label i {
    color: var(--color-primary);
}

/* ── Difficulty Filter ── */
.vig-difficulty-filter {
    display: flex;
    align-items: center;
    gap: var(--space-3);
}

.vig-difficulty-label {
    font-size: var(--font-size-sm);
    font-weight: 600;
    color: var(--color-gray-700);
}

.vig-difficulty-btns {
    display: flex;
    gap: var(--space-1);
}

.vig-diff-btn {
    padding: var(--space-1) var(--space-3);
    border: 1px solid var(--color-gray-300);
    border-radius: var(--radius-md);
    background: var(--color-white, #fff);
    color: var(--color-gray-600);
    font-size: var(--font-size-xs);
    font-weight: 500;
    font-family: var(--font-body);
    cursor: pointer;
    transition: all 150ms ease;
}

.vig-diff-btn:hover {
    border-color: var(--color-primary);
    color: var(--color-primary);
}

.vig-diff-btn--active {
    background: var(--color-primary);
    color: var(--color-white);
    border-color: var(--color-primary);
}

/* ── Actions row ── */
.vig-actions {
    display: flex;
    gap: var(--space-3);
    margin-bottom: var(--space-5);
}

.vig-generate-btn {
    flex: 1;
    padding: var(--space-3) var(--space-6);
    font-size: var(--font-size-base);
    font-weight: 600;
}

.vig-shuffle-btn {
    padding: var(--space-3) var(--space-5);
    font-size: var(--font-size-base);
    font-weight: 600;
}

/* ── Hint ── */
.vig-hint {
    text-align: center;
    padding: var(--space-8) 0;
    color: var(--color-gray-400);
    font-size: var(--font-size-sm);
}

.vig-hint i {
    margin-right: var(--space-1);
}

/* ── Results ── */
.vig-results-header {
    display: flex;
    justify-content: space-between;
    align-items: center;
    margin-bottom: var(--space-4);
    flex-wrap: wrap;
    gap: var(--space-2);
}

.vig-results-count {
    font-size: var(--font-size-lg);
    font-weight: 700;
    color: var(--color-gray-900);
}

.vig-results-meta {
    font-size: var(--font-size-sm);
    color: var(--color-gray-500);
}

/* ── Idea Cards Grid ── */
.vig-ideas-grid {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: var(--space-4);
}

/* ── Idea Card ── */
.vig-idea-card {
    background: var(--color-white, #fff);
    border: 1px solid var(--color-gray-200);
    border-radius: var(--radius-lg);
    padding: var(--space-5);
    transition: all 150ms ease;
    display: flex;
    flex-direction: column;
}

.vig-idea-card:hover {
    border-color: var(--color-primary);
    box-shadow: var(--shadow-sm);
    transform: translateY(-1px);
}

.vig-idea-card__title {
    font-size: var(--font-size-base);
    font-weight: 700;
    color: var(--color-gray-900);
    margin: 0 0 var(--space-2) 0;
    line-height: 1.4;
}

.vig-idea-card__hook {
    font-size: var(--font-size-sm);
    color: var(--color-gray-600);
    margin: 0 0 var(--space-3) 0;
    line-height: 1.5;
    flex: 1;
}

.vig-idea-card__meta {
    display: flex;
    flex-wrap: wrap;
    gap: var(--space-2);
    margin-bottom: var(--space-3);
    align-items: center;
}

.vig-idea-badge {
    display: inline-flex;
    align-items: center;
    gap: 4px;
    padding: 2px 10px;
    border-radius: 999px;
    font-size: var(--font-size-xs);
    font-weight: 600;
    line-height: 1.6;
}

.vig-idea-badge--easy {
    background: rgba(34, 197, 94, 0.1);
    color: var(--color-success-dark);
}

.vig-idea-badge--medium {
    background: rgba(245, 158, 11, 0.1);
    color: var(--color-warning-dark);
}

.vig-idea-badge--advanced {
    background: rgba(239, 68, 68, 0.1);
    color: var(--color-danger);
}

.vig-idea-badge--time {
    background: var(--color-gray-100);
    color: var(--color-gray-600);
}

.vig-idea-badge--faceless {
    background: rgba(79, 70, 229, 0.1);
    color: var(--color-primary);
}

/* ── Idea Card Actions ── */
.vig-idea-card__actions {
    display: flex;
    gap: var(--space-2);
    padding-top: var(--space-3);
    border-top: 1px solid var(--color-gray-100);
}

.vig-idea-action {
    display: inline-flex;
    align-items: center;
    gap: var(--space-1);
    padding: var(--space-1) var(--space-3);
    border: 1px solid var(--color-gray-200);
    border-radius: var(--radius-md);
    background: var(--color-white, #fff);
    color: var(--color-gray-600);
    font-size: var(--font-size-xs);
    font-weight: 500;
    font-family: var(--font-body);
    cursor: pointer;
    transition: all 150ms ease;
}

.vig-idea-action:hover {
    border-color: var(--color-primary);
    color: var(--color-primary);
    background: rgba(79, 70, 229, 0.04);
}

.vig-idea-action--saved {
    background: var(--color-primary);
    color: var(--color-white);
    border-color: var(--color-primary);
}

.vig-idea-action--saved:hover {
    background: var(--color-primary-dark);
    border-color: var(--color-primary-dark);
    color: var(--color-white);
}

.vig-idea-action--copied {
    background: var(--color-success-dark);
    color: var(--color-white);
    border-color: var(--color-success-dark);
}

/* ── Saved Ideas Section ── */
.vig-saved {
    margin-top: var(--space-6);
    border: 2px solid var(--color-primary);
    border-radius: var(--radius-lg);
    padding: var(--space-5);
}

.vig-saved-header {
    display: flex;
    justify-content: space-between;
    align-items: center;
    margin-bottom: var(--space-4);
    flex-wrap: wrap;
    gap: var(--space-2);
}

.vig-saved-title {
    font-size: var(--font-size-base);
    font-weight: 700;
    color: var(--color-gray-900);
    margin: 0;
    display: flex;
    align-items: center;
    gap: var(--space-2);
}

.vig-saved-title i {
    color: var(--color-primary);
}

.vig-saved-count {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    background: var(--color-primary);
    color: var(--color-white);
    border-radius: 999px;
    font-size: var(--font-size-xs);
    font-weight: 700;
    min-width: 22px;
    height: 22px;
    padding: 0 6px;
}

.vig-saved-list {
    display: flex;
    flex-direction: column;
    gap: var(--space-3);
}

.vig-saved-item {
    display: flex;
    align-items: center;
    gap: var(--space-3);
    padding: var(--space-3) var(--space-4);
    background: var(--color-gray-50);
    border: 1px solid var(--color-gray-200);
    border-radius: var(--radius-md);
}

.vig-saved-item__text {
    flex: 1;
}

.vig-saved-item__title {
    font-size: var(--font-size-sm);
    font-weight: 600;
    color: var(--color-gray-900);
}

.vig-saved-item__hook {
    font-size: var(--font-size-xs);
    color: var(--color-gray-500);
    margin-top: 2px;
}

.vig-saved-item__remove {
    padding: var(--space-1) var(--space-2);
    border: none;
    background: none;
    color: var(--color-gray-400);
    cursor: pointer;
    font-size: var(--font-size-sm);
    transition: color 150ms ease;
}

.vig-saved-item__remove:hover {
    color: var(--color-danger);
}

/* ── Notification fallback ── */
.vig-notification {
    position: fixed;
    bottom: 20px;
    right: 20px;
    padding: 12px 20px;
    border-radius: var(--radius-md);
    color: var(--color-white);
    font-size: var(--font-size-sm);
    font-weight: 600;
    z-index: 9999;
    box-shadow: var(--shadow-lg);
    transition: opacity 300ms ease;
}

.vig-notification--success { background: var(--color-success-dark); }
.vig-notification--error { background: var(--color-danger); }
.vig-notification--warning { background: var(--color-warning-dark); }
.vig-notification--info { background: var(--color-primary); }


/* ================================================================
   RESPONSIVE
   ================================================================ */
@media (max-width: 991px) {
    .vig-niche-grid {
        grid-template-columns: repeat(4, 1fr);
    }

    .vig-ideas-grid {
        grid-template-columns: 1fr;
    }
}

@media (max-width: 767px) {
    .vig-niche-grid {
        grid-template-columns: repeat(3, 1fr);
        gap: var(--space-2);
    }

    .vig-niche-card {
        padding: var(--space-3) var(--space-2);
        font-size: var(--font-size-xs);
    }

    .vig-niche-card i {
        font-size: 18px;
    }

    .vig-format-tabs {
        overflow-x: auto;
        flex-wrap: nowrap;
        -webkit-overflow-scrolling: touch;
        scrollbar-width: none;
        padding-bottom: var(--space-1);
    }

    .vig-format-tabs::-webkit-scrollbar {
        display: none;
    }

    .vig-format-tab {
        white-space: nowrap;
        flex-shrink: 0;
        font-size: var(--font-size-xs);
        padding: var(--space-2) var(--space-3);
    }

    .vig-filters-row {
        flex-direction: column;
        align-items: flex-start;
        padding: var(--space-3) var(--space-4);
    }

    .vig-difficulty-filter {
        flex-direction: column;
        align-items: flex-start;
        gap: var(--space-2);
        width: 100%;
    }

    .vig-difficulty-btns {
        width: 100%;
    }

    .vig-diff-btn {
        flex: 1;
        text-align: center;
    }

    .vig-actions {
        flex-direction: column;
    }

    .vig-shuffle-btn {
        width: 100%;
        text-align: center;
    }

    .vig-ideas-grid {
        grid-template-columns: 1fr;
        gap: var(--space-3);
    }

    .vig-idea-card {
        padding: var(--space-4);
    }

    .vig-idea-card__title {
        font-size: var(--font-size-sm);
    }

    .vig-results-header {
        flex-direction: column;
        align-items: flex-start;
    }

    .vig-saved {
        padding: var(--space-4);
    }

    .vig-saved-header {
        flex-direction: column;
        align-items: flex-start;
    }

    .vig-saved-item {
        flex-direction: column;
        align-items: flex-start;
    }

    .vig-saved-item__remove {
        align-self: flex-end;
    }
}

@media (max-width: 479px) {
    .vig-niche-grid {
        grid-template-columns: repeat(2, 1fr);
    }
}
