/* public/css/_whatsapp.css */

/* Layout principale della pagina chat */
.chat-layout {
    display: flex;
    height: 100%;
    overflow: hidden;
}

/* Colonna sinistra con la lista delle chat */
.chat-list-container {
    width: 320px;
    flex-shrink: 0;
    border-right: 1px solid var(--surface-dark-border);
    display: flex;
    flex-direction: column;
}

.chat-list {
    overflow-y: auto;
    flex-grow: 1;
}

/* Campo di ricerca nella lista chat */
#search-chat-input {
    padding: 12px;
    margin: 16px;
    border-radius: 6px;
    border: 1px solid var(--surface-dark-border);
    background: var(--surface-dark-level2);
    color: white;
}
#search-chat-input:focus {
    outline: none;
    border-color: var(--accent-color);
}

/* Singolo elemento nella lista chat */
.chat-item.active {
    background-color: rgba(37, 211, 102, 0.2); /* Un verde semi-trasparente */
    color: var(--primary-text-color-dark); /* Testo bianco */
    border-left: 4px solid var(--success-color); /* Una barra verde a sinistra per evidenziare */
    padding-left: 12px; /* Adatta il padding per la barra laterale */
}
.chat-item.active strong { /* Assicurati che il nome della chat rimanga leggibile */
    color: var(--primary-text-color-dark);
}
.chat-item.active .message-meta { /* Assicurati che la data rimanga leggibile */
    color: var(--secondary-text-color-dark);
}

/* Area principale dove vengono visualizzati i messaggi */
.message-view {
    padding: 24px;
    overflow-y: auto;
    flex-grow: 1;
    display: flex;
    flex-direction: column;
}

/* Testo placeholder quando non è selezionata nessuna chat */
.message-view .placeholder-text {
    margin: auto;
    color: var(--secondary-text-color-dark);
}

/* "Fumetto" del singolo messaggio */
.message-bubble {
    max-width: 70%;
    padding: 12px 16px;
    border-radius: 18px;
    margin-bottom: 8px;
    line-height: 1.5;
    word-wrap: break-word;
    /* Colore del testo predefinito per tutte le bolle */
    color: var(--chat-text-color);
}

/* Fumetto per i messaggi che tu hai INVIATO (KDiesel, ora allineati a SINISTRA) */
/* In JavaScript, `isSent` è true per KDiesel, quindi usa la classe `.sent` */
.message-bubble.sent {
    background-color: var(--chat-bubble-mine-bg); /* Il tuo colore per i tuoi messaggi */
    align-self: flex-end; /* Allinea a destra */
    margin-left: auto; /* Spinge la bolla a destra */
}

/* Fumetto per i messaggi che tu hai RICEVUTO (Interlocutore, ora allineati a DESTRA) */
/* In JavaScript, `isSent` è false per l'interlocutore, quindi usa la classe `.received` */
.message-bubble.received {
    background-color: var(--chat-bubble-interlocutor-bg); /* Il colore per i messaggi dell'interlocutore */
    align-self: flex-start; /* Allinea a sinistra */
    margin-right: auto; /* Spinge la bolla a sinistra */
}

/* Metadati del messaggio (data, ora) */
.message-meta {
    font-size: 0.75em;
    color: var(--secondary-text-color-dark); /* Un colore secondario per leggibilità */
    margin-top: 4px;
}

/* Contenuto testuale del messaggio */
.message-content-text {
    white-space: pre-wrap; /* Mantiene gli a capo e gli spazi */
    word-break: break-word; /* Va a capo con parole lunghe */
}

.message-view-wrapper {
    display: flex;
    flex-direction: column; /* Impila filtri e messaggi verticalmente */
    flex-grow: 1; /* Occupa il resto dello spazio */
    min-width: 0; /* Necessario per il flexbox */
}

/* Add chat list text readability */
.chat-item strong {
    color: var(--primary-text-color-dark); /* Rende i nomi delle chat ben visibili */
}
.chat-item .message-meta {
    color: var(--secondary-text-color-dark); /* Data di importazione in grigio chiaro */
}

.chat-delete-btn {
    padding: 6px 10px; /* Riduci il padding per renderlo compatto */
    font-size: 0.8em;
    border-color: rgba(224, 49, 49, 0.4); /* Bordo rosso più tenue */
    color: var(--danger-color); /* Colore icona rosso */
    background-color: transparent; /* Sfondo trasparente */
    flex-shrink: 0; /* Non si rimpicciolisce */
}

.chat-delete-btn:hover {
    background-color: rgba(224, 49, 49, 0.15); /* Sfondo rosso semi-trasparente al hover */
    border-color: var(--danger-color); /* Bordo rosso più intenso al hover */
}
.chat-delete-btn svg {
    width: 14px; /* Riduci dimensione icona */
    height: 14px;
    stroke-width: 2;
}

.media-placeholder {
    font-style: italic;
    color: var(--secondary-text-color-dark);
    display: block;
    text-align: center;
    padding: 8px;
}

.message-bubble .media-icon {
    display: flex; /* Permette all'icona e al testo di stare sulla stessa riga */
    align-items: center; /* Centra verticalmente icona e testo */
    gap: 8px; /* Spazio tra icona e testo */
    font-style: italic;
    color: var(--secondary-text-color-dark); /* Colore del testo per media omessi */
    padding: 4px 0; /* Padding interno */
}

.message-bubble .media-icon svg {
    flex-shrink: 0; /* Impedisce all'icona di rimpicciolirsi */
    color: var(--accent-color); /* Colore primario per l'icona */
}

/* Stile specifico per il testo "Media omessi" quando non c'è altro contenuto */
.message-bubble .media-icon .media-placeholder-text {
    font-size: 0.9em;
    font-weight: 500;
    color: var(--secondary-text-color-dark);
}

/* Sovrascrittura per il tema Cyberpunk */
body.theme-cyberpunk .message-bubble .media-icon svg {
    color: var(--accent-color); /* Ciano vibrante per l'icona */
    filter: drop-shadow(0 0 3px var(--accent-color)); /* Effetto neon */
}

body.theme-cyberpunk .message-bubble .media-icon .media-placeholder-text {
    color: var(--accent-color); /* Testo placeholder ciano */
    filter: drop-shadow(0 0 3px var(--accent-color)); /* Effetto neon */
}

.chat-media-img, .chat-media-video {
    max-width: 100%;
    border-radius: 12px;
    margin-bottom: 8px; /* Spazio tra media e testo sottostante */
    display: block;
}

.chat-filter-bar {
    /* Rimuovi position: sticky e le proprietà correlate (top, z-index, margin) */
    display: flex;
    gap: 16px;
    align-items: flex-end;
    padding: 16px;
    background-color: var(--surface-dark-level2);
    border-bottom: 1px solid var(--surface-dark-border);
    flex-shrink: 0; /* Impedisce alla barra di restringersi */
}

.chat-filter-bar .filter-group {
    flex-grow: 1; /* Fa sì che i gruppi di filtri occupino lo spazio disponibile */
    margin-bottom: 0;
}

.chat-filter-bar .filter-group label {
    font-size: 0.8em;
    color: var(--secondary-text-color-dark);
}

.chat-filter-bar input {
    width: 100%;
    color-scheme: dark;
}

.chat-filter-bar button {
    padding: 8px 16px;
    font-size: 0.9em;
    height: fit-content;
}
