/* ============================================================
   music.css — Son du moment styles
   ============================================================ */

/* ── Public listing page ────────────────────────────────────── */

.music-grid {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(280px, 1fr));
    gap: var(--nv-space-lg);
}

.music-card {
    background: var(--nv-surface-card);
    border: 1px solid var(--nv-border-light);
    border-radius: 10px;
    overflow: hidden;
    transition: box-shadow var(--nv-transition-base), transform var(--nv-transition-base);
}

.music-card:hover {
    box-shadow: var(--nv-shadow-md);
    transform: translateY(-2px);
}

.music-card__cover-wrap {
    aspect-ratio: 1;
    overflow: hidden;
    background: var(--nv-bg-elevated);
}

.music-card__cover {
    width: 100%;
    height: 100%;
    object-fit: cover;
    display: block;
    transition: transform var(--nv-transition-slow);
}

.music-card:hover .music-card__cover {
    transform: scale(1.04);
}

.music-card__cover--placeholder {
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 2.5rem;
    color: var(--nv-ink-faint);
}

.music-card__body {
    padding: var(--nv-space-md);
}

.music-card__date {
    font-family: var(--nv-font-ui);
    font-size: 0.75rem;
    color: var(--nv-ink-muted);
    margin: 0 0 var(--nv-space-xs);
    text-transform: uppercase;
    letter-spacing: 0.04em;
}

.music-card__title {
    font-family: var(--nv-font-display);
    font-size: 1.1rem;
    font-weight: 600;
    color: var(--nv-ink-primary);
    margin: 0 0 0.2rem;
    line-height: 1.3;
}

.music-card__artist {
    font-family: var(--nv-font-ui);
    font-size: 0.875rem;
    color: var(--nv-ink-secondary);
    margin: 0 0 var(--nv-space-sm);
}

.music-card__note {
    font-family: var(--nv-font-body);
    font-size: 0.875rem;
    font-style: italic;
    color: var(--nv-ink-secondary);
    border-left: 2px solid var(--nv-accent);
    margin: 0 0 var(--nv-space-sm);
    padding: 0.25rem 0 0.25rem var(--nv-space-sm);
    line-height: 1.5;
}

.music-card__platforms {
    display: flex;
    flex-wrap: wrap;
    gap: var(--nv-space-xs);
    margin-top: var(--nv-space-sm);
}

.music-platform-btn {
    display: inline-flex;
    align-items: center;
    gap: 0.35rem;
    padding: 0.3rem 0.65rem;
    border-radius: 20px;
    border: 1px solid var(--nv-border-medium);
    background: transparent;
    color: var(--nv-ink-secondary);
    font-family: var(--nv-font-ui);
    font-size: 0.75rem;
    font-weight: 500;
    text-decoration: none;
    transition: background var(--nv-transition-fast), color var(--nv-transition-fast), border-color var(--nv-transition-fast);
    white-space: nowrap;
}

.music-platform-btn:hover {
    background: var(--nv-accent);
    color: #fff;
    border-color: var(--nv-accent);
}

.music-platform-btn--all {
    color: var(--nv-accent);
    border-color: var(--nv-accent-soft);
}

.music-platform-btn--all:hover {
    background: var(--nv-accent);
    color: #fff;
}

.music-platform-btn__label {
    font-size: 0.75rem;
}

.music-platform-logo {
    display: block;
    width: 1em;
    height: 1em;
    object-fit: contain;
}

.music-empty {
    color: var(--nv-ink-muted);
    font-family: var(--nv-font-ui);
    font-size: 0.9375rem;
    padding: var(--nv-space-xl) 0;
}

/* ── Sidebar widget ─────────────────────────────────────────── */

.music-widget {
    display: flex;
    gap: var(--nv-space-sm);
    align-items: flex-start;
}

.music-widget__cover {
    width: 56px;
    height: 56px;
    border-radius: 6px;
    object-fit: cover;
    flex-shrink: 0;
}

.music-widget__cover--placeholder {
    width: 56px;
    height: 56px;
    border-radius: 6px;
    background: var(--nv-bg-elevated);
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 1.25rem;
    color: var(--nv-ink-faint);
    flex-shrink: 0;
}

.music-widget__info {
    flex: 1;
    min-width: 0;
}

.music-widget__title {
    font-family: var(--nv-font-ui);
    font-size: 0.875rem;
    font-weight: 600;
    color: var(--nv-ink-primary);
    margin: 0 0 0.1rem;
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
}

.music-widget__artist {
    font-family: var(--nv-font-ui);
    font-size: 0.8125rem;
    color: var(--nv-ink-muted);
    margin: 0 0 var(--nv-space-xs);
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
}

.music-widget__note {
    font-family: var(--nv-font-body);
    font-size: 0.8125rem;
    font-style: italic;
    color: var(--nv-ink-secondary);
    margin: 0 0 var(--nv-space-xs);
    line-height: 1.4;
    display: -webkit-box;
    -webkit-line-clamp: 2;
    -webkit-box-orient: vertical;
    overflow: hidden;
}

.music-widget__platforms {
    display: flex;
    flex-wrap: wrap;
    gap: 6px;
}

.music-widget__platform-link {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 26px;
    height: 26px;
    border-radius: 6px;
    border: 1px solid var(--nv-border-light);
    color: var(--nv-ink-muted);
    text-decoration: none;
    font-size: 0.9rem;
    transition: background var(--nv-transition-fast), color var(--nv-transition-fast), border-color var(--nv-transition-fast);
}

.music-widget__platform-link:hover {
    background: var(--nv-accent);
    color: #fff;
    border-color: var(--nv-accent);
}

.music-widget__platform-link--all {
    color: var(--nv-accent);
    border-color: var(--nv-accent-soft);
}

.music-widget__more {
    display: inline-block;
    margin-top: var(--nv-space-sm);
    font-family: var(--nv-font-ui);
    font-size: 0.8125rem;
    color: var(--nv-accent);
    text-decoration: none;
    font-weight: 500;
}

.music-widget__more:hover {
    text-decoration: underline;
}

/* ── Admin styles ───────────────────────────────────────────── */

.music-add-panel {
    background: var(--bg-elevated, #f8f7f5);
    border: 1px solid var(--border-light, #e2ddd6);
    border-radius: 10px;
    padding: 1.5rem;
    margin-bottom: 2rem;
}

.music-add-panel__title {
    font-size: 1.0625rem;
    font-weight: 600;
    margin: 0 0 1rem;
    color: var(--ink-primary, #1a1815);
}

.music-fetch-row {
    display: flex;
    gap: 0.75rem;
    align-items: center;
    flex-wrap: wrap;
}

.music-fetch-row .field__input {
    flex: 1;
    min-width: 0;
}

.music-preview {
    display: flex;
    gap: 1rem;
    align-items: flex-start;
    margin-top: 1.25rem;
    padding: 1rem;
    background: var(--bg-paper, #faf9f7);
    border: 1px solid var(--border-light, #e2ddd6);
    border-radius: 8px;
}

.music-preview--edit {
    margin-bottom: 1.5rem;
}

.music-preview__cover-wrap {
    flex-shrink: 0;
}

.music-preview__cover {
    width: 80px;
    height: 80px;
    border-radius: 8px;
    object-fit: cover;
    display: block;
}

.music-preview__info {
    flex: 1;
    min-width: 0;
}

.music-preview__title {
    font-weight: 600;
    font-size: 0.9375rem;
    margin: 0 0 0.25rem;
    color: var(--ink-primary, #1a1815);
}

.music-preview__artist {
    color: var(--ink-secondary, #4a4540);
    font-size: 0.875rem;
    margin: 0 0 0.5rem;
}

.music-preview__platforms {
    display: flex;
    flex-wrap: wrap;
    gap: 6px;
}

.platform-icon-link {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 28px;
    height: 28px;
    border-radius: 6px;
    border: 1px solid var(--border-light, #e2ddd6);
    color: var(--ink-muted, #7a7570);
    text-decoration: none;
    font-size: 0.95rem;
    transition: background 0.15s, color 0.15s;
}

.platform-icon-link:hover {
    background: var(--accent, #c0392b);
    color: #fff;
    border-color: var(--accent, #c0392b);
}

.platform-icon-link--all {
    color: var(--accent, #c0392b);
    border-color: color-mix(in srgb, var(--accent, #c0392b) 30%, transparent);
}

.music-form {
    margin-top: 1.25rem;
    display: flex;
    flex-direction: column;
    gap: 1rem;
}

.music-form--edit {
    margin-top: 0;
}

.fieldset {
    border: 1px solid var(--border-light, #e2ddd6);
    border-radius: 8px;
    padding: 1rem 1.25rem;
    margin: 0;
}

.fieldset__legend {
    font-size: 0.8125rem;
    font-weight: 600;
    color: var(--ink-muted, #7a7570);
    padding: 0 0.5rem;
    text-transform: uppercase;
    letter-spacing: 0.04em;
}

.form-row--platforms {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(220px, 1fr));
    gap: 0.75rem;
}

.field--platform .field__label {
    display: flex;
    align-items: center;
    gap: 0.4rem;
}

.music-row-cover {
    width: 40px;
    height: 40px;
    border-radius: 6px;
    object-fit: cover;
    display: block;
}

.music-row-cover--empty {
    display: flex;
    align-items: center;
    justify-content: center;
    background: var(--bg-elevated, #f8f7f5);
    color: var(--ink-faint, #b0aaa5);
    font-size: 1rem;
}

.td-cover {
    width: 56px;
}

.td-platforms {
    white-space: nowrap;
}

.music-error {
    color: #c0392b;
    font-size: 0.875rem;
    margin-top: 0.75rem;
    font-weight: 500;
}
