/**
 * Card Publication
 * Styles des cartes CPT nos-publications, variantes par type-publication.
 *
 * Structure :
 *   <article class="ri-publication-card type-{slug}">
 *     <div class="card-illus is-{color}">
 *       <img class="illus-img portrait|portrait-tilted|landscape">
 *     </div>
 *     <div class="card-content">
 *       <div class="card-meta">
 *         <span class="card-type is-{color}">
 *           <span class="dot">...</span></span>
 *         <span class="card-date">...</span>
 *       </div>
 *       <div class="card-body"><h2>.card-title</h2><p>.card-excerpt</p></div>
 *       <div class="card-footer">
 *         <a class="card-link">...</a>
 *         <a class="card-download">...</a>  ← optionnel
 *       </div>
 *     </div>
 *   </article>
 */

/* ── Base ── */

.ri-publication-card {
	display: flex;
	flex-direction: column;
	height: 100%;
	box-shadow: var(--ri-shadow-md);
	overflow: hidden;
}

/* ── Illustration ── */

.ri-publication-card .card-illus {
	position: relative;
	width: 100%;
	height: 240px;
	display: flex;
	align-items: center;
	justify-content: center;
	overflow: hidden;
	flex-shrink: 0;
}

.ri-publication-card .card-illus.is-teal {
	background-color: var(--ri-color-teal);
}

.ri-publication-card .card-illus.is-grey-mid {
	background-color: var(--ri-color-grey);
}

.ri-publication-card .card-illus.is-violet {
	background-color: var(--ri-color-violet-dark);
}

.ri-publication-card .card-illus.is-grey-soft {
	background-color: var(--ri-color-grey-soft);
}

/* Portrait vertical — centré avec ombre, déborde légèrement */
.ri-publication-card .illus-img.portrait {
	width: auto;
	max-width: 212px;
	height: auto;
	max-height: 280px;
	object-fit: contain;
	box-shadow: 8px 12px 20px rgba(0, 0, 0, 0.35);
	position: absolute;
	bottom: -90px;
}

/* Portrait incliné -15° (rapport d'activité — 1 image) */
.ri-publication-card .illus-img.portrait-tilted {
	width: auto;
	max-width: 224px;
	height: auto;
	max-height: 303px;
	object-fit: contain;
	box-shadow: 8px 12px 20px rgba(0, 0, 0, 0.35);
	position: absolute;
	transform: rotate(-15deg);
	transform-origin: center center;
	bottom: -57px;
}

/* Paysage horizontal (dossier de presse) */
.ri-publication-card .illus-img.landscape {
	width: 301px;
	max-width: 80%;
	height: auto;
	object-fit: contain;
	box-shadow: 8px 12px 20px rgba(0, 0, 0, 0.35);
}

/* ── Contenu ── */

.ri-publication-card .card-content {
	display: flex;
	flex-direction: column;
	gap: var(--ri-space-md);
	padding: 16px 16px 24px;
	background-color: var(--ri-color-white);
	flex: 1;
}

/* ── Meta : type + date ── */

.ri-publication-card .card-meta {
	display: flex;
	justify-content: space-between;
	align-items: center;
	gap: var(--ri-space-sm);
}

.ri-publication-card .card-type {
	display: inline-flex;
	align-items: center;
	gap: 4px;
	font: 700 12px/1 var(--ri-font-1);
	flex-shrink: 0;
}

.ri-publication-card .card-type.is-teal {
	color: var(--ri-color-teal);
}

.ri-publication-card .card-type.is-grey {
	color: var(--ri-color-grey);
}

.ri-publication-card .card-type.is-violet {
	color: var(--ri-color-violet-dark);
}

/* Dot indicateur de couleur — forme variable par type de publication */
.ri-publication-card .dot {
	display: inline-block;
	width: 8px;
	height: 8px;
	border-radius: 50%;
	flex-shrink: 0;
}

/* Plaquette commerciale — point plein gris doux */
.ri-publication-card .dot.is-grey-soft {
	background-color: var(--ri-color-grey-mid);
}

/* Communiqué de presse — barre horizontale grise */
.ri-publication-card .dot.is-grey-mid {
	width: 8px;
	height: 5px;
	border-radius: 0;
	background-color: var(--ri-color-grey);
}

/* Rapport d'activité — point bicolore (violet foncé / violet clair) */
.ri-publication-card .dot.is-violet {
	background-image: linear-gradient(to right, var(--ri-color-violet-dark) 0 50%, var(--ri-color-violet-light) 50% 100%);
	border-radius: unset;
}

/* Dossier de presse — barre verticale canard */
.ri-publication-card .dot.is-teal {
	width: 5px;
	height: 8px;
	border-radius: 0;
	background-color: var(--ri-color-teal);
}

/* Poster — anneau jaune avec point central jaune */
.ri-publication-card .dot.is-yellow {
	background-color: transparent;
	border: 1px solid var(--ri-color-yellow);
	box-shadow: inset 0 0 0 1px var(--ri-color-white), inset 0 0 0 5px var(--ri-color-yellow);
}

.ri-publication-card .card-date {
	font: 400 12px/1 var(--ri-font-1);
	white-space: nowrap;
	flex-shrink: 0;
}

/* ── Titre + Extrait ── */

.ri-publication-card .card-body {
	display: flex;
	flex-direction: column;
	gap: var(--ri-space-sm);
	flex: 1;
}

.ri-publication-card .card-title {
	margin: 0;
	font: 700 16px/1.5 var(--ri-font-1);
	display: -webkit-box;
	-webkit-box-orient: vertical;
	-webkit-line-clamp: 3;
	overflow: hidden;
}

.ri-publication-card .card-title a {
	color: inherit;
	text-decoration: none;
	transition: opacity var(--ri-transition-base);
}

.ri-publication-card .card-title a:hover {
	opacity: 0.75;
}

.ri-publication-card .card-excerpt {
	margin: 0;
	font: 400 16px/1.5 var(--ri-font-1);
	display: -webkit-box;
	-webkit-box-orient: vertical;
	-webkit-line-clamp: 3;
	overflow: hidden;
}

/* ── Footer ── */

.ri-publication-card .card-footer {
	display: flex;
	justify-content: space-between;
	align-items: center;
	gap: var(--ri-space-sm);
	margin-top: auto;
	min-height: 47px;
}

.ri-publication-card .card-link {
	display: inline-flex;
	align-items: center;
	gap: 4px;
	font: 700 15px/1 var(--ri-font-1);
	color: var(--ri-color-teal);
	text-decoration: none;
	transition: opacity var(--ri-transition-base);
}

.ri-publication-card .card-link:hover {
	opacity: 0.7;
}

.ri-publication-card .card-link .arrow {
	font-size: 15.4px;
}

.ri-publication-card .card-link .label {
	text-decoration: underline;
	text-decoration-thickness: 1px;
	text-underline-offset: 3px;
}

.ri-publication-card .card-download {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	padding: 12px 16px;
	background-color: var(--ri-color-teal);
	font: 700 15px/1 var(--ri-font-1);
	color: var(--ri-color-white);
	text-decoration: none;
	transition: opacity var(--ri-transition-base);
	flex-shrink: 0;
}

.ri-publication-card .card-download:hover {
	opacity: 0.85;
}
