/* ═══════════════════════════════════════════════════════════
   Citation Generator — Page-Specific Styles
   /tools/youtube-citation-generator
   ═══════════════════════════════════════════════════════════ */

/* ── Mode Toggle ────────────────────────────────────────── */
.cite-mode-toggle {
    display: flex;
    gap: var(--space-2);
    margin-bottom: var(--space-5);
}

.cite-mode-btn {
    flex: 1;
    display: flex;
    align-items: center;
    justify-content: center;
    gap: var(--space-2);
    padding: var(--space-3) var(--space-4);
    background: var(--color-gray-50);
    border: 2px solid var(--color-gray-200);
    border-radius: var(--radius-md);
    color: var(--color-gray-600);
    font-size: var(--font-size-sm);
    font-weight: 600;
    cursor: pointer;
    transition: all 150ms ease;
}

.cite-mode-btn:hover {
    background: var(--color-gray-100);
    border-color: var(--color-gray-300);
}

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

/* ── Input Row ──────────────────────────────────────────── */
.cite-input-row {
    display: flex;
    gap: var(--space-3);
}

.cite-input-row .form-control {
    flex: 1;
}

/* ── Manual Mode Grid ──────────────────────────────────── */
.cite-manual-grid {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: var(--space-4);
}

.cite-manual-full {
    grid-column: 1 / -1;
}

.cite-required {
    color: var(--color-danger);
}

.cite-optional {
    color: var(--color-gray-400);
    font-weight: 400;
    font-size: var(--font-size-xs);
}

.form-hint {
    font-size: var(--font-size-xs);
    color: var(--color-gray-500);
    margin-top: var(--space-1);
}

/* ── Loading ────────────────────────────────────────────── */
.cite-loading[hidden] {
    display: none !important;
}

.cite-loading {
    display: flex;
    align-items: center;
    justify-content: center;
    gap: var(--space-3);
    padding: var(--space-8);
    color: var(--color-gray-500);
}

.cite-loading__spinner {
    width: 24px;
    height: 24px;
    border: 3px solid var(--color-gray-200);
    border-top-color: var(--color-primary);
    border-radius: 50%;
    animation: cite-spin 0.8s linear infinite;
}

@keyframes cite-spin {
    to { transform: rotate(360deg); }
}

/* ── Video Info Card ───────────────────────────────────── */
.cite-video-card {
    display: flex;
    gap: var(--space-4);
    padding: var(--space-4);
    background: var(--color-white);
    border: 1px solid var(--color-gray-200);
    border-radius: var(--radius-md);
    margin-bottom: var(--space-5);
}

.cite-video-card__thumb {
    width: 160px;
    height: 90px;
    object-fit: cover;
    border-radius: var(--radius-sm);
    flex-shrink: 0;
}

.cite-video-card__info {
    flex: 1;
    min-width: 0;
}

.cite-video-card__title {
    font-size: var(--font-size-base);
    font-weight: 600;
    color: var(--color-gray-900);
    margin: 0 0 var(--space-1);
    overflow: hidden;
    text-overflow: ellipsis;
    display: -webkit-box;
    -webkit-line-clamp: 2;
    -webkit-box-orient: vertical;
}

.cite-video-card__channel {
    font-size: var(--font-size-sm);
    color: var(--color-gray-600);
    margin: 0 0 var(--space-1);
}

.cite-video-card__date {
    font-size: var(--font-size-xs);
    color: var(--color-gray-500);
    margin: 0 0 var(--space-2);
}

/* ── Edit Panel ────────────────────────────────────────── */
.cite-edit-panel {
    padding: var(--space-4);
    background: var(--color-gray-50);
    border: 1px solid var(--color-gray-200);
    border-radius: var(--radius-md);
    margin-bottom: var(--space-5);
}

/* ── Style Tabs ────────────────────────────────────────── */
.cite-style-tabs {
    margin-bottom: var(--space-4);
    flex-wrap: wrap;
}

/* ── Citation Card ─────────────────────────────────────── */
.cite-citation-card {
    background: var(--color-white);
    border: 1px solid var(--color-gray-200);
    border-radius: var(--radius-md);
    padding: var(--space-4);
    margin-bottom: var(--space-3);
}

.cite-citation-card--secondary {
    background: var(--color-gray-50);
    border-color: var(--color-gray-150, var(--color-gray-200));
}

.cite-citation-card__header {
    display: flex;
    align-items: center;
    gap: var(--space-3);
    margin-bottom: var(--space-3);
}

.cite-citation-card__use {
    font-size: var(--font-size-xs);
    color: var(--color-gray-500);
}

.cite-citation-text {
    font-family: var(--font-body);
    font-size: var(--font-size-base);
    line-height: 1.7;
    color: var(--color-gray-800);
    padding: var(--space-3) var(--space-4);
    background: var(--color-gray-50);
    border: 1px solid var(--color-gray-200);
    border-radius: var(--radius-sm);
    word-break: break-word;
    overflow-wrap: break-word;
}

.cite-citation-card--secondary .cite-citation-text {
    background: var(--color-white);
}

.cite-citation-text--intext {
    font-size: var(--font-size-sm);
    padding: var(--space-2) var(--space-3);
}

.cite-citation-text--code {
    font-family: 'SFMono-Regular', Consolas, 'Liberation Mono', Menlo, monospace;
    font-size: var(--font-size-sm);
    white-space: pre-wrap;
    line-height: 1.6;
    margin: 0;
}

.cite-citation-card__actions {
    display: flex;
    justify-content: flex-end;
    margin-top: var(--space-3);
}

/* ── Copy Button Success State ─────────────────────────── */
.cite-copy-btn--success {
    background: var(--color-success) !important;
    border-color: var(--color-success) !important;
    color: var(--color-white) !important;
}

/* ── Output Actions ────────────────────────────────────── */
.cite-output-actions {
    display: flex;
    gap: var(--space-3);
    justify-content: center;
    margin-top: var(--space-5);
    padding-top: var(--space-4);
    border-top: 1px solid var(--color-gray-200);
}

/* ── Italic Hint ──────────────────────────────────────── */
.cite-italic-hint {
    font-size: var(--font-size-xs);
    color: var(--color-gray-500);
    margin-bottom: var(--space-3);
    display: flex;
    align-items: center;
    gap: var(--space-2);
}

.cite-italic-hint i {
    color: var(--color-primary);
    flex-shrink: 0;
}

/* ── BibTeX Download Button ──────────────────────────── */
.cite-citation-card__actions {
    display: flex;
    justify-content: flex-end;
    gap: var(--space-2);
    margin-top: var(--space-3);
}

/* ── Output Section Spacing ────────────────────────────── */
.cite-output-section {
    margin-top: var(--space-6);
}

/* ═══════════════════════════════════════════════════════════
   RESPONSIVE
   ═══════════════════════════════════════════════════════════ */
@media (max-width: 767px) {
    .cite-input-row {
        flex-direction: column;
    }

    .cite-manual-grid {
        grid-template-columns: 1fr;
    }

    .cite-video-card {
        flex-direction: column;
    }

    .cite-video-card__thumb {
        width: 100%;
        height: auto;
        max-height: 200px;
    }

    .cite-mode-toggle {
        flex-direction: column;
    }

    .cite-mode-btn {
        padding: var(--space-3);
    }

    .cite-style-tabs {
        gap: var(--space-1);
    }

    .cite-style-tabs .tabs__item {
        font-size: var(--font-size-xs);
        padding: var(--space-2) var(--space-2);
    }

    .cite-citation-text {
        font-size: var(--font-size-sm);
        padding: var(--space-2) var(--space-3);
    }

    .cite-output-actions {
        flex-direction: column;
    }

    .cite-output-actions .button {
        width: 100%;
        justify-content: center;
    }
}
