mon-site-perso/frontend/app/css/utilities.css
2025-09-20 14:16:14 +02:00

130 lines
3.9 KiB
CSS
Raw Blame History

This file contains ambiguous Unicode characters

This file contains Unicode characters that might be confused with other characters. If you think that this is intentional, you can safely ignore this warning. Use the Escape button to reveal them.

/* Utilitaires légers */
/* Centrer un bloc dans son conteneur et limiter la largeur */
.container--narrow {
max-width: 820px;
margin-inline: auto;
}
/* Centrage */
.u-center {
display: grid;
place-items: center;
}
.u-text-center { text-align: center; }
.u-muted { color: var(--color-muted, #6b7280); }
/* Rythme vertical: ajoute un espace entre les éléments frères */
.flow > * + * {
margin-top: var(--space-4, 1rem);
}
/* Ombre au survol */
.shadow-hover {
transition: box-shadow 0.2s ease, transform 0.15s ease;
}
.shadow-hover:hover {
transform: translateY(-2px);
box-shadow: var(--shadow-md, 0 2px 10px rgba(0,0,0,0.08));
}
/* Visually hidden pour laccessibilité */
.visually-hidden,
.sr-only {
position: absolute !important;
height: 1px; width: 1px;
overflow: hidden;
clip: rect(1px, 1px, 1px, 1px);
white-space: nowrap;
border: 0; padding: 0; margin: -1px;
}
/* Flexbox utilitaires */
.flex { display: flex; }
.flex-col { display: flex; flex-direction: column; }
.flex-row { display: flex; flex-direction: row; }
.items-center { align-items: center; }
.items-start { align-items: flex-start; }
.items-end { align-items: flex-end; }
.justify-between { justify-content: space-between; }
.justify-center { justify-content: center; }
.gap-2 { gap: var(--space-2, 0.5rem); }
.gap-4 { gap: var(--space-4, 1rem); }
.gap-6 { gap: var(--space-6, 1.5rem); }
/* Grilles rapides */
.grid-2 { display: grid; gap: var(--space-6, 1.5rem); grid-template-columns: repeat(2, 1fr); }
.grid-3 { display: grid; gap: var(--space-6, 1.5rem); grid-template-columns: repeat(3, 1fr); }
.grid-4 { display: grid; gap: var(--space-6, 1.5rem); grid-template-columns: repeat(4, 1fr); }
@media (max-width: 900px) {
.grid-3 { grid-template-columns: repeat(2, 1fr); }
.grid-4 { grid-template-columns: repeat(2, 1fr); }
}
@media (max-width: 640px) {
.grid-2, .grid-3, .grid-4 { grid-template-columns: 1fr; }
}
/* Piles verticales */
.stack > * + * { margin-top: var(--space-4, 1rem); }
.stack-sm > * + * { margin-top: var(--space-3, 0.75rem); }
.stack-lg > * + * { margin-top: var(--space-6, 1.5rem); }
/* Espacements rapides */
.mt-0 { margin-top: 0 !important; }
.mt-4 { margin-top: var(--space-4, 1rem) !important; }
.mt-8 { margin-top: var(--space-8, 2rem) !important; }
.mb-0 { margin-bottom: 0 !important; }
.mb-4 { margin-bottom: var(--space-4, 1rem) !important; }
.mb-8 { margin-bottom: var(--space-8, 2rem) !important; }
/* Largeurs utiles */
.max-w-prose { max-width: 65ch; }
.max-w-wide { max-width: var(--container-max, 1100px); }
.w-full { width: 100%; }
/* Groupes de boutons */
.btn-group {
display: inline-flex;
gap: 0.5rem;
flex-wrap: wrap;
}
/* Grilles rapides */
.grid-2 { display: grid; gap: var(--space-6, 1.5rem); grid-template-columns: repeat(2, 1fr); }
.grid-3 { display: grid; gap: var(--space-6, 1.5rem); grid-template-columns: repeat(3, 1fr); }
.grid-4 { display: grid; gap: var(--space-6, 1.5rem); grid-template-columns: repeat(4, 1fr); }
@media (max-width: 900px) {
.grid-3 { grid-template-columns: repeat(2, 1fr); }
.grid-4 { grid-template-columns: repeat(2, 1fr); }
}
@media (max-width: 640px) {
.grid-2, .grid-3, .grid-4 { grid-template-columns: 1fr; }
}
/* Piles verticales */
.stack > * + * { margin-top: var(--space-4, 1rem); }
.stack-sm > * + * { margin-top: var(--space-3, 0.75rem); }
.stack-lg > * + * { margin-top: var(--space-6, 1.5rem); }
/* Espacements rapides */
.mt-0 { margin-top: 0 !important; }
.mt-4 { margin-top: var(--space-4, 1rem) !important; }
.mt-8 { margin-top: var(--space-8, 2rem) !important; }
.mb-0 { margin-bottom: 0 !important; }
.mb-4 { margin-bottom: var(--space-4, 1rem) !important; }
.mb-8 { margin-bottom: var(--space-8, 2rem) !important; }
/* Largeurs utiles */
.max-w-prose { max-width: 65ch; }
.max-w-wide { max-width: var(--container-max, 1100px); }
.w-full { width: 100%; }
/* Groupes de boutons */
.btn-group {
display: inline-flex;
gap: 0.5rem;
flex-wrap: wrap;
}