/* ============================================================
   Partage-Thicar — viewer.css
   Vue lecture seule : propre, lisible, non interactive
   ============================================================ */

/* ============================================================
   Header
   ============================================================ */
.viewer-header {
    background: var(--c-surface);
    border-bottom: 1px solid var(--c-border);
    padding: 0 var(--space-4);
    height: var(--header-height);
    display: flex;
    align-items: center;
    box-shadow: var(--shadow-sm);
    position: sticky;
    top: 0;
    z-index: 10;
}

.viewer-header__inner {
    display: flex;
    align-items: center;
    justify-content: space-between;
    width: 100%;
    max-width: 760px;
    margin: 0 auto;
}

.viewer-header__logo {
    display: flex;
    align-items: center;
    gap: var(--space-2);
    font-weight: 700;
    font-size: 1rem;
    color: var(--c-text);
}

.viewer-header__logo-icon {
    width: 30px;
    height: 30px;
    background: var(--c-primary);
    border-radius: var(--radius-sm);
    color: white;
    font-size: 0.75rem;
    font-weight: 700;
    display: flex;
    align-items: center;
    justify-content: center;
}

.viewer-header__logo-text {
    font-size: 0.95rem;
}

.viewer-header__badge {
    font-size: 0.75rem;
    font-weight: 600;
    padding: 0.2rem 0.6rem;
    background: var(--c-surface-2);
    border: 1px solid var(--c-border);
    border-radius: var(--radius-full);
    color: var(--c-text-muted);
    letter-spacing: 0.03em;
}

/* ============================================================
   Contenu principal
   ============================================================ */
.viewer-main {
    max-width: 760px;
    margin: 0 auto;
    padding: var(--space-8) var(--space-4);
}

/* En-tête du document */
.viewer-doc-header {
    margin-bottom: var(--space-8);
    padding-bottom: var(--space-6);
    border-bottom: 2px solid var(--c-border);
}

.viewer-doc-title {
    font-size: 1.75rem;
    font-weight: 700;
    color: var(--c-text);
    margin-bottom: var(--space-3);
    line-height: 1.2;
}

.viewer-doc-meta {
    font-size: 0.875rem;
    color: var(--c-text-muted);
}

/* ============================================================
   Sections
   ============================================================ */
.viewer-sections {
    display: flex;
    flex-direction: column;
    gap: var(--space-6);
}

.viewer-section {
    background: var(--c-surface);
    border: 1px solid var(--c-border);
    border-radius: var(--radius-lg);
    overflow: hidden;
}

.viewer-section-title {
    font-size: 1.05rem;
    font-weight: 700;
    color: var(--c-text);
    padding: var(--space-4) var(--space-5);
    background: var(--c-surface-2);
    border-bottom: 1px solid var(--c-border);
    margin: 0;
}

.viewer-section-empty {
    padding: var(--space-4) var(--space-5);
    color: var(--c-text-light);
    font-style: italic;
    font-size: 0.875rem;
}

/* ============================================================
   Items (lignes texte + badge)
   ============================================================ */
.viewer-items {
    display: flex;
    flex-direction: column;
}

.viewer-item {
    display: flex;
    align-items: center;
    gap: var(--space-3);
    padding: var(--space-3) var(--space-5);
    border-bottom: 1px solid var(--c-border);
    min-height: 48px;
}

.viewer-item:last-child {
    border-bottom: none;
}

.viewer-item__content {
    flex: 1;
    font-size: 0.9rem;
    color: var(--c-text);
    line-height: 1.5;
    word-break: break-word;
}

/* Badge non cliquable en lecture seule */
.viewer-item__badge {
    cursor: default;
    pointer-events: none;
    flex-shrink: 0;
    font-size: 0.75rem;
}

/* ============================================================
   États vides / erreurs
   ============================================================ */
.viewer-empty {
    text-align: center;
    padding: var(--space-10) var(--space-4);
    color: var(--c-text-muted);
    font-size: 0.9rem;
}

.viewer-error-page {
    min-height: 100vh;
    display: flex;
    align-items: center;
    justify-content: center;
    padding: var(--space-4);
    background: var(--c-bg);
}

.viewer-error-card {
    background: var(--c-surface);
    border: 1px solid var(--c-border);
    border-radius: var(--radius-xl);
    padding: var(--space-10) var(--space-8);
    max-width: 420px;
    width: 100%;
    text-align: center;
    box-shadow: var(--shadow-lg);
}

.viewer-error-icon {
    font-size: 2.5rem;
    margin-bottom: var(--space-4);
    opacity: 0.5;
}

.viewer-error-title {
    font-size: 1.3rem;
    font-weight: 700;
    color: var(--c-text);
    margin-bottom: var(--space-3);
}

.viewer-error-text {
    font-size: 0.95rem;
    color: var(--c-error);
    font-weight: 500;
    margin-bottom: var(--space-3);
}

.viewer-error-hint {
    font-size: 0.85rem;
    color: var(--c-text-muted);
    line-height: 1.5;
}

/* ============================================================
   Footer
   ============================================================ */
.viewer-footer {
    text-align: center;
    padding: var(--space-8) var(--space-4);
    font-size: 0.8rem;
    color: var(--c-text-light);
    border-top: 1px solid var(--c-border);
    max-width: 760px;
    margin: 0 auto;
}

/* ============================================================
   Responsive
   ============================================================ */
@media (min-width: 640px) {
    .viewer-main {
        padding: var(--space-10) var(--space-6);
    }
    .viewer-header {
        padding: 0 var(--space-6);
    }
}
