/**
 * Styles front de « Mes documents ». Alignés sur la UX de Mon espace : on
 * réutilise les tokens du thème (préfixe --wp--preset--*), avec repli si absents.
 *
 * @package elito-mes-documents
 */

/* La popup est rendue hors du conteneur .mesdoc (ajoutée sur <body>) : on
   redéclare donc les variables aussi sur .mesdoc-modal, sinon le panneau est
   transparent et les textes de l'en-tête deviennent illisibles. */
.mesdoc,
.mesdoc-modal {
	--mesdoc-paper: var( --wp--preset--color--lpo-paper, #fff );
	--mesdoc-ink: var( --wp--preset--color--lpo-ink, #1a1a1a );
	--mesdoc-blue: var( --wp--preset--color--lpo-blue, #1d6fb8 );
	--mesdoc-orange: var( --wp--preset--color--lpo-orange, #e8722a );
	--mesdoc-line: var( --wp--preset--color--lpo-warm-300, #e2ddd4 );
	--mesdoc-soft: var( --wp--preset--color--lpo-warm-50, #faf8f4 );
	--mesdoc-muted: var( --wp--preset--color--lpo-warm-700, #6b6358 );
	--mesdoc-radius: 14px;
	font-family: var( --wp--preset--font-family--lpo, inherit );
	color: var( --mesdoc-ink );
}

/* --- Formulaire de dépôt --- */
.mesdoc-form {
	background: var( --mesdoc-paper );
	border: 1px solid var( --mesdoc-line );
	border-radius: var( --mesdoc-radius );
	box-shadow: var( --wp--preset--shadow--card, 0 1px 3px rgba( 0, 0, 0, .06 ) );
	padding: clamp( 16px, 3vw, 28px );
}

.mesdoc-field {
	display: flex;
	flex-direction: column;
	gap: 6px;
	margin: 0 0 16px;
}

.mesdoc-field label {
	font-weight: 600;
}

.mesdoc-field input[type="text"],
.mesdoc-field input[type="file"] {
	width: 100%;
	max-width: 480px;
	padding: 10px 12px;
	border: 1px solid var( --mesdoc-line );
	border-radius: 8px;
	background: var( --mesdoc-soft );
}

.mesdoc-hint {
	font-size: var( --wp--preset--font-size--small, .85em );
	color: var( --mesdoc-muted );
}

.mesdoc-actions {
	margin: 8px 0 0;
}

/* Formulaire de dépôt « inline » (montant membre) : champs sur une ligne. */
.mesdoc-form--inline .mesdoc-inline {
	display: flex;
	flex-wrap: wrap;
	align-items: flex-end;
	gap: 12px;
}

.mesdoc-form--inline .mesdoc-field {
	margin: 0;
	flex: 1 1 220px;
}

.mesdoc-form--inline .mesdoc-field--submit {
	flex: 0 0 auto;
}

.mesdoc-form--inline .mesdoc-field--submit .wp-element-button {
	white-space: nowrap;
}

.mesdoc-form--inline .mesdoc-hint {
	display: block;
	margin-top: 8px;
}

@media ( max-width: 600px ) {
	.mesdoc-form--inline .mesdoc-field { flex-basis: 100%; }
	.mesdoc-form--inline .mesdoc-field--submit .wp-element-button { width: 100%; }
}

/* Bouton d'envoi des formulaires (dépôt / upload) : pill conforme au thème. */
.mesdoc-form .wp-element-button {
	display: inline-block;
	border: 0;
	border-radius: 999px;
	padding: 13px 26px;
	background: var( --mesdoc-blue );
	color: var( --mesdoc-paper );
	font-family: var( --wp--preset--font-family--sora, inherit );
	font-weight: 700;
	font-size: var( --wp--preset--font-size--normal, 1rem );
	line-height: 1;
	cursor: pointer;
	transition: background-color .15s ease, box-shadow .15s ease, transform .05s ease;
}

.mesdoc-form .wp-element-button:hover {
	background: var( --mesdoc-ink );
	box-shadow: var( --wp--preset--shadow--md, 0 4px 12px rgba( 0, 0, 0, .15 ) );
}

.mesdoc-form .wp-element-button:active {
	transform: translateY( 1px );
}

/* Le formulaire de dépôt est dans une colonne de largeur variable (Mon espace) :
   on observe sa LARGEUR RÉELLE via une container query (et pas le viewport). */
.mesdoc-depot {
	container-type: inline-size;
}

/* Formulaire en deux colonnes (label 25% / contrôle 75%). */
.mesdoc-form--cols .mesdoc-field--row {
	display: grid;
	grid-template-columns: 25% 1fr;
	align-items: start;
	column-gap: 18px;
	row-gap: 4px;
	margin: 0 0 18px;
}

.mesdoc-form--cols .mesdoc-field--row > label {
	padding-top: 10px;
}

.mesdoc-control {
	display: flex;
	flex-direction: column;
	gap: 6px;
	min-width: 0;
}

.mesdoc-control input[type="text"],
.mesdoc-control input[type="file"],
.mesdoc-control select {
	width: 100%;
	max-width: 480px;
}

/* Normalise le <select> du repli (sinon le thème le rend démesuré). */
.mesdoc-control select,
.mesdoc-fallback select {
	height: auto;
	min-height: 0;
	padding: 10px 12px;
	font-size: var( --wp--preset--font-size--small, .95rem );
	line-height: 1.3;
	border: 1px solid var( --mesdoc-line );
	border-radius: 8px;
	background-color: var( --mesdoc-soft );
}

/* Labels au-dessus des champs dès que le formulaire devient étroit
   (≈ petit écran d'ordinateur / colonne réduite). */
@container ( max-width: 700px ) {
	.mesdoc-form--cols .mesdoc-field--row {
		grid-template-columns: 1fr;
	}
	.mesdoc-form--cols .mesdoc-field--row > label { padding-top: 0; }
	.mesdoc-field__spacer { display: none; }
}

/* Repli viewport pour les navigateurs sans support des container queries. */
@media ( max-width: 768px ) {
	.mesdoc-form--cols .mesdoc-field--row {
		grid-template-columns: 1fr;
	}
	.mesdoc-form--cols .mesdoc-field--row > label { padding-top: 0; }
	.mesdoc-field__spacer { display: none; }
}

/* Pills de préremplissage (sous le champ « Nom »). */
.mesdoc-prefills {
	display: flex;
	flex-wrap: wrap;
	gap: 6px;
	margin: 8px 0 0;
}

.mesdoc-pill {
	font-family: var( --wp--preset--font-family--sora, inherit );
	font-size: .72rem;
	line-height: 1;
	font-weight: 600;
	padding: 6px 12px;
	border-radius: 999px;
	border: 1px solid var( --mesdoc-line );
	background: var( --mesdoc-soft );
	color: var( --mesdoc-ink );
	cursor: pointer;
	transition: background-color .15s ease, color .15s ease, border-color .15s ease;
}

.mesdoc-pill:hover {
	background: var( --mesdoc-blue );
	border-color: var( --mesdoc-blue );
	color: var( --mesdoc-paper );
}

/* Autocomplete de recherche de membre (formulaire de dépôt). */
.mesdoc-user-results {
	display: block;
	max-width: 480px;
}

.mesdoc-user-option {
	display: block;
	width: 100%;
	text-align: left;
	padding: 9px 12px;
	border: 1px solid var( --mesdoc-line );
	border-top: 0;
	background: var( --mesdoc-paper );
	color: var( --mesdoc-ink );
	cursor: pointer;
	font: inherit;
}

.mesdoc-user-option:first-child { border-top: 1px solid var( --mesdoc-line ); border-radius: 8px 8px 0 0; }
.mesdoc-user-option:last-child { border-radius: 0 0 8px 8px; }
.mesdoc-user-option:hover,
.mesdoc-user-option.is-active { background: var( --mesdoc-soft ); }

.mesdoc-fallback {
	margin: 0 0 16px;
	font-size: var( --wp--preset--font-size--small, .9em );
}

.mesdoc-fallback select { margin-top: 8px; max-width: 480px; }

/* --- Cartes (vue membre) --- */
.mesdoc-card {
	background: var( --mesdoc-paper );
	border: 1px solid var( --mesdoc-line );
	border-radius: var( --mesdoc-radius );
	box-shadow: var( --wp--preset--shadow--card, 0 1px 3px rgba( 0, 0, 0, .06 ) );
	padding: clamp( 16px, 3vw, 24px );
	margin: 0 0 20px;
}

.mesdoc-card__head {
	margin: 0 0 14px;
}

.mesdoc-card__title {
	margin: 0;
	font-size: var( --wp--preset--font-size--large, 1.25rem );
}

.mesdoc-card__sub {
	margin: 4px 0 0;
	color: var( --mesdoc-muted );
	font-size: var( --wp--preset--font-size--small, .9em );
}

/* --- Liste --- */
.mesdoc-items {
	list-style: none;
	margin: 0;
	padding: 0;
	display: flex;
	flex-direction: column;
	gap: 12px;
}

.mesdoc-item {
	display: flex;
	flex-wrap: wrap;
	align-items: center;
	justify-content: space-between;
	gap: 12px;
	background: var( --mesdoc-paper );
	border: 1px solid var( --mesdoc-line );
	border-radius: var( --mesdoc-radius );
	box-shadow: var( --wp--preset--shadow--card, 0 1px 3px rgba( 0, 0, 0, .06 ) );
	padding: 14px 18px;
}

.mesdoc-item__main {
	display: flex;
	flex-wrap: wrap;
	align-items: center;
	gap: 8px 12px;
	min-width: 0;
}

.mesdoc-item__title {
	font-weight: 600;
}

.mesdoc-item__meta {
	font-size: var( --wp--preset--font-size--small, .85em );
	color: var( --mesdoc-muted );
}

.mesdoc-badge {
	font-size: .72rem;
	font-weight: 600;
	text-transform: uppercase;
	letter-spacing: .03em;
	padding: 2px 8px;
	border-radius: 999px;
	white-space: nowrap;
}

.mesdoc-badge--incoming {
	background: color-mix( in srgb, var( --mesdoc-blue ) 14%, transparent );
	color: var( --mesdoc-blue );
}

.mesdoc-badge--outgoing {
	background: color-mix( in srgb, var( --mesdoc-orange ) 16%, transparent );
	color: var( --mesdoc-orange );
}

.mesdoc-badge--new {
	background: color-mix( in srgb, var( --mesdoc-orange ) 16%, transparent );
	color: #b35309;
}

.mesdoc-badge--seen {
	background: #edf7ed;
	color: #1a7f37;
}

/* --- Ligne de recherche (pleine largeur) --- */
.mesdoc-filter {
	display: flex;
	flex-wrap: wrap;
	align-items: center;
	gap: 8px;
	width: 100%;
	margin: 0 0 14px;
}

.mesdoc-search {
	flex: 1 1 280px;
	max-width: none;
	padding: 6px 8px;
	border: 1px solid var( --mesdoc-line );
	border-radius: 999px;
	background: var( --mesdoc-paper );
	color: var( --mesdoc-ink );
	font: inherit;
	/* Neutralise l'apparence native des champs type="search" (WebKit) qui
	   ignore le border-radius → même arrondi « pill » que les boutons. */
	-webkit-appearance: none;
	appearance: none;
	transition: border-color .15s ease, box-shadow .15s ease;
}

.mesdoc-search::placeholder { color: var( --mesdoc-muted ); }

.mesdoc-search:focus {
	outline: none;
	border-color: var( --mesdoc-blue );
	box-shadow: 0 0 0 3px color-mix( in srgb, var( --mesdoc-blue ) 18%, transparent );
}

.mesdoc-search::-webkit-search-decoration,
.mesdoc-search::-webkit-search-cancel-button {
	-webkit-appearance: none;
}

/* --- Export groupé (ZIP) : ligne dédiée, alignée à droite (au-dessus et
       en dessous du tableau). --- */
.mesdoc-bulk {
	display: flex;
	flex-wrap: wrap;
	justify-content: flex-end;
	gap: 8px;
	margin: 12px 0;
}

/* État de chargement des boutons d'export pendant la génération du ZIP. */
.mesdoc-btn.is-loading {
	opacity: .75;
	pointer-events: none;
	cursor: progress;
}

.mesdoc-btn.is-loading::after {
	content: "";
	width: 14px;
	height: 14px;
	margin-left: 2px;
	border: 2px solid currentColor;
	border-right-color: transparent;
	border-radius: 50%;
	animation: mesdoc-spin .6s linear infinite;
}

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

/* --- Pagination --- */
.mesdoc-pagination {
	display: flex;
	flex-wrap: wrap;
	gap: 6px;
	margin: 16px 0 0;
}

.mesdoc-pagination .page-numbers {
	display: inline-flex;
	align-items: center;
	min-width: 36px;
	justify-content: center;
	padding: 7px 12px;
	border: 1px solid var( --mesdoc-line );
	border-radius: 8px;
	background: var( --mesdoc-paper );
	color: var( --mesdoc-ink );
	text-decoration: none;
	font-family: var( --wp--preset--font-family--sora, inherit );
	font-size: .85rem;
}

.mesdoc-pagination .page-numbers:hover { background: var( --mesdoc-soft ); }

.mesdoc-pagination .page-numbers.current {
	background: var( --mesdoc-blue );
	border-color: var( --mesdoc-blue );
	color: var( --mesdoc-paper );
}

.mesdoc-pagination .page-numbers.dots {
	border-color: transparent;
	background: transparent;
}

/* --- Table de revue (gestionnaires) --- */
.mesdoc-table {
	width: 100%;
	border-collapse: collapse;
	background: var( --mesdoc-paper );
	border: 1px solid var( --mesdoc-line );
	border-radius: var( --mesdoc-radius );
	overflow: hidden;
}

.mesdoc-table th,
.mesdoc-table td {
	text-align: left;
	padding: 12px 14px;
	border-bottom: 1px solid var( --mesdoc-line );
	vertical-align: middle;
}

.mesdoc-table thead th {
	background: var( --mesdoc-blue );
	font-size: var( --wp--preset--font-size--small, .85em );
	font-family: var( --wp--preset--font-family--sora, inherit );
	text-transform: uppercase;
	letter-spacing: .03em;
	color: var( --mesdoc-paper );
}

.mesdoc-table tbody tr:last-child td {
	border-bottom: 0;
}

.mesdoc-table__actions {
	white-space: nowrap;
	text-align: right;
	vertical-align: middle;
}

/* On NE flexe PAS la cellule (cela la sort du flux table et fait apparaître un
   bord vertical parasite entre colonnes). On espace les boutons à l'intérieur. */
.mesdoc-table__actions .mesdoc-btn {
	vertical-align: middle;
}

.mesdoc-table__actions .mesdoc-btn + .mesdoc-btn {
	margin-left: 6px;
}

.mesdoc-item__actions {
	gap: 8px;
}

@media ( max-width: 600px ) {
	.mesdoc-table,
	.mesdoc-table thead,
	.mesdoc-table tbody,
	.mesdoc-table tr,
	.mesdoc-table td {
		display: block;
		width: 100%;
	}

	.mesdoc-table thead {
		display: none;
	}

	.mesdoc-table tr {
		border-bottom: 1px solid var( --mesdoc-line );
		padding: 8px 0;
	}

	.mesdoc-table td {
		border: 0;
		padding: 6px 14px;
	}

	.mesdoc-table td::before {
		content: attr( data-label ) " : ";
		font-weight: 600;
		color: var( --mesdoc-muted );
	}

	.mesdoc-table__actions {
		text-align: left;
	}

	.mesdoc-table__actions::before {
		content: "";
	}
}

.mesdoc-item__actions {
	display: flex;
	gap: 8px;
	flex-shrink: 0;
}

/* Boutons « pill » alignés sur le thème (cf. .wp-element-button du child theme). */
.mesdoc-btn {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	gap: 7px;
	border: 1px solid transparent;
	border-radius: 999px;
	padding: 9px 16px;
	font-family: var( --wp--preset--font-family--sora, inherit );
	font-weight: 600;
	font-size: .82rem;
	line-height: 1.15;
	text-decoration: none;
	cursor: pointer;
	transition: background-color .15s ease, color .15s ease, box-shadow .15s ease, transform .05s ease;
}

.mesdoc-btn:hover { box-shadow: var( --wp--preset--shadow--sm, 0 2px 6px rgba( 0, 0, 0, .1 ) ); }
.mesdoc-btn:active { transform: translateY( 1px ); }

.mesdoc-btn .mesdoc-ic { flex: 0 0 auto; width: 15px; height: 15px; }
.mesdoc-btn span { line-height: 1.15; }

/* Mode « icône seule » : bouton carré, sans texte. */
.mesdoc-btn--icon-only { gap: 0; padding: 9px; }

/* Primaire (Télécharger) : bleu plein. */
.mesdoc-btn--primary {
	background: var( --mesdoc-blue );
	color: var( --mesdoc-paper );
}
.mesdoc-btn--primary:hover { background: var( --mesdoc-ink ); color: var( --mesdoc-paper ); }

/* Secondaire (Aperçu) : contour, fond clair. */
.mesdoc-btn--ghost {
	background: var( --mesdoc-paper );
	color: var( --mesdoc-blue );
	border-color: var( --mesdoc-line );
}
.mesdoc-btn--ghost:hover {
	background: var( --mesdoc-blue );
	color: var( --mesdoc-paper );
	border-color: var( --mesdoc-blue );
}

/* Danger (Supprimer) : contour rouge. */
.mesdoc-btn--danger {
	background: transparent;
	color: #b32d2e;
	border-color: currentColor;
}
.mesdoc-btn--danger:hover { background: #b32d2e; color: #fff; border-color: #b32d2e; }

/* --- Popup d'aperçu (lightbox) --- */
body.mesdoc-modal-open { overflow: hidden; }

.mesdoc-modal {
	position: fixed;
	inset: 0;
	z-index: 100000;
	display: flex;
	align-items: center;
	justify-content: center;
	padding: clamp( 12px, 4vw, 48px );
}

.mesdoc-modal[hidden] { display: none; }

.mesdoc-modal__backdrop {
	position: absolute;
	inset: 0;
	background: rgba( 16, 18, 22, .72 );
	backdrop-filter: blur( 2px );
}

.mesdoc-modal__panel {
	position: relative;
	display: flex;
	flex-direction: column;
	width: min( 960px, 100% );
	height: min( 88vh, 100% );
	background: var( --mesdoc-paper );
	border-radius: 16px;
	box-shadow: var( --wp--preset--shadow--panel, 0 20px 60px rgba( 0, 0, 0, .35 ) );
	overflow: hidden;
}

/* Image : le panneau épouse l'image (pas de marges haut/bas). */
.mesdoc-modal__panel--image {
	width: auto;
	height: auto;
	max-width: min( 960px, 95vw );
	max-height: 92vh;
}

.mesdoc-modal__panel--image .mesdoc-modal__body {
	flex: 0 0 auto;
	background: transparent;
}

.mesdoc-modal__head {
	display: flex;
	align-items: center;
	justify-content: space-between;
	flex-wrap: wrap;
	gap: 10px 12px;
	padding: 12px 16px;
	border-bottom: 1px solid var( --mesdoc-line );
}

.mesdoc-modal__title {
	flex: 1 1 160px;
	min-width: 0;
	font-family: var( --wp--preset--font-family--sora, inherit );
	font-weight: 700;
	overflow: hidden;
	text-overflow: ellipsis;
	white-space: nowrap;
}

.mesdoc-modal__tools {
	display: flex;
	align-items: center;
	gap: 8px;
	flex: 0 0 auto;
}

/* Boutons d'action de l'en-tête (Télécharger / Ouvrir / Supprimer).
   Marge à droite pour détacher visuellement du bouton « Fermer ». */
.mesdoc-modal__actions {
	display: flex;
	flex-wrap: wrap;
	align-items: center;
	gap: 8px;
	margin-right: 2rem;
}

.mesdoc-modal__close {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	width: 34px;
	height: 34px;
	padding: 0;
	font-size: 22px;
	line-height: 1;
	cursor: pointer;
	border-radius: 999px;
	border: 1px solid var( --mesdoc-line );
	background: var( --mesdoc-paper );
	color: var( --mesdoc-muted );
}
.mesdoc-modal__close:hover {
	background: var( --mesdoc-soft );
	color: var( --mesdoc-ink );
}

.mesdoc-modal__body {
	flex: 1 1 auto;
	min-height: 0;
	background: var( --mesdoc-soft );
	display: flex;
	align-items: center;
	justify-content: center;
}

.mesdoc-modal__frame {
	width: 100%;
	height: 100%;
	border: 0;
}

.mesdoc-modal__img {
	display: block;
	width: auto;
	height: auto;
	/* tient compte de la hauteur de l'en-tête (~58px) pour rester dans l'écran */
	max-width: min( 960px, 95vw );
	max-height: calc( 92vh - 58px );
	object-fit: contain;
}

.mesdoc-empty {
	color: var( --mesdoc-muted );
}

/* --- Notices --- */
.mesdoc-notice {
	border-radius: 10px;
	padding: 12px 16px;
	margin: 0 0 16px;
	border: 1px solid transparent;
}

.mesdoc-notice--success {
	background: #edf7ed;
	border-color: #b6e0b6;
	color: #14591d;
}

.mesdoc-notice--error {
	background: #fcebec;
	border-color: #f0b6b8;
	color: #8a1f24;
}

.mesdoc-notice--info {
	background: var( --wp--preset--color--lpo-warm-50, #f4f6fb );
	border-color: var( --wp--preset--color--lpo-warm-300, #cdd7ea );
	color: var( --wp--preset--color--lpo-ink, #1a1a1a );
}

/* --- Placeholder éditeur (Gutenberg) — aligné sur le plugin Mon espace. --- */
.mesdoc-editor-ph {
	border: 1px dashed var( --wp--preset--color--lpo-warm-300, #a8a095 );
	border-radius: 12px;
	padding: var( --wp--preset--spacing--normal, 20px );
	text-align: center;
	background: var( --wp--preset--color--lpo-warm-50, #f7f4ee );
}

.mesdoc-editor-ph__title {
	display: block;
	font-family: var( --wp--preset--font-family--lpo, inherit );
	font-size: var( --wp--preset--font-size--medium, 1rem );
}

.mesdoc-editor-ph__desc {
	margin: 6px 0 0;
	font-size: var( --wp--preset--font-size--small, .85rem );
	color: var( --wp--preset--color--lpo-warm-700, #6b6358 );
}
