/* ============================================================
   MY LIBRARY PAGE
   ============================================================ */

/* ── Empty state ── */
.lib-empty-state {
    text-align: center;
    padding: 4rem 2rem;
    color: var(--color-muted);
}
.lib-empty-icon   { font-size: 3rem; line-height: 1; margin-bottom: .75rem; }
.lib-empty-title  { font-size: 1.1rem; font-weight: 600; color: var(--color-text); margin-bottom: .4rem; }
.lib-empty-body   { font-size: .9rem; max-width: 420px; margin: 0 auto 1.5rem; }

/* ── Stats bar ── */
.lib-stats {
    font-size: .82rem;
    color: var(--color-muted);
    margin-bottom: 1.25rem;
}

/* ── Groups ── */
.lib-group { margin-bottom: 2rem; }

.lib-group-header {
    font-size: .7rem;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: .06em;
    color: var(--color-muted);
    padding-bottom: .4rem;
    border-bottom: 1px solid var(--color-border);
    margin-bottom: .6rem;
}

.lib-group-body {
    display: flex;
    flex-direction: column;
    gap: .5rem;
}

/* ── Library card ── */
.lib-card {
    display: flex;
    align-items: flex-start;
    justify-content: space-between;
    gap: 1rem;
    padding: .75rem 1rem;
    background: var(--color-surface);
    border: 1px solid var(--color-border);
    border-radius: var(--radius);
    transition: border-color .12s;
}
.lib-card:hover { border-color: var(--color-primary); }

.lib-card-main  { flex: 1; min-width: 0; }
.lib-card-label {
    font-size: .9rem;
    font-weight: 600;
    color: var(--color-text);
    text-decoration: none;
    display: block;
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
}
a.lib-card-label:hover { color: var(--color-primary); text-decoration: underline; }

.lib-card-caption {
    font-size: .78rem;
    color: var(--color-muted);
    margin-top: .2rem;
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
}
.lib-card-note {
    font-size: .75rem;
    color: var(--color-muted);
    margin-top: .25rem;
    font-style: italic;
}
.lib-card-meta {
    font-size: .7rem;
    color: var(--color-muted);
    margin-top: .3rem;
}

.lib-card-actions {
    display: flex;
    gap: .5rem;
    align-items: center;
    flex-shrink: 0;
}

/* ============================================================
   UNIFIED ATTACHMENT PICKER  (.ap-*)
   ============================================================ */

.ap-wrap {
    background: var(--color-surface-alt);
    border: 1px solid var(--color-border);
    border-radius: var(--radius);
    padding: .65rem .85rem;
    margin-bottom: 1rem;
    position: relative;
}

.ap-header {
    display: flex;
    align-items: center;
    gap: .75rem;
    flex-wrap: wrap;
}

.ap-label {
    font-size: .8rem;
    font-weight: 600;
    color: var(--color-muted);
    text-transform: uppercase;
    letter-spacing: .04em;
    white-space: nowrap;
    margin: 0;
}

/* ── Report section "or" divider ── */
.ap-report-or {
    display: flex;
    align-items: center;
    font-size: .73rem;
    color: var(--color-muted);
    margin-bottom: .4rem;
    gap: .5rem;
}
.ap-report-or::before,
.ap-report-or::after {
    content: '';
    flex: 1;
    height: 1px;
    background: var(--color-border);
}

/* ── Collapsed custom URL block ── */
.ap-report-custom-collapsed { display: none !important; }

/* ── My Library panel ── */
.ap-library-panel {
    position: absolute;
    top: calc(100% + 4px);
    left: 0;
    right: 0;
    z-index: 200;
    background: var(--color-surface);
    border: 1px solid var(--color-border);
    border-radius: var(--radius);
    box-shadow: var(--shadow-sm);
    overflow: hidden;
}

.ap-library-header {
    display: flex;
    align-items: center;
    justify-content: space-between;
    padding: .5rem .75rem;
    background: var(--color-surface-alt);
    border-bottom: 1px solid var(--color-border);
}

.ap-library-close {
    background: none;
    border: none;
    font-size: .8rem;
    color: var(--color-muted);
    cursor: pointer;
    padding: 0 .2rem;
}
.ap-library-close:hover { color: var(--color-danger); }

.ap-library-list {
    max-height: 220px;
    overflow-y: auto;
    padding: .3rem 0;
}

.ap-library-item {
    display: flex;
    align-items: center;
    gap: .5rem;
    width: 100%;
    background: none;
    border: none;
    padding: .4rem .75rem;
    font-size: .82rem;
    text-align: left;
    cursor: pointer;
    transition: background .1s;
}
.ap-library-item:hover { background: var(--color-hover); }

.ap-lib-icon  { font-size: .9rem; flex-shrink: 0; }
.ap-lib-label {
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
    color: var(--color-text);
}

.ap-library-footer {
    padding: .4rem .75rem;
    border-top: 1px solid var(--color-border);
    background: var(--color-surface-alt);
    text-align: right;
}
