Modèle:Header/styles.css
De Nefald
Autres actions
/* =============================================================================
HEADER COMPONENT - Bandeau horizontal pleine largeur (full-bleed)
Compatible TemplateStyles (pas de fonctions CSS non supportées).
========================================================================== */
/* 1) Étendre le composant sur toute la largeur du viewport */
.mw-parser-output > .home-header {
max-width: none !important;
/* technique full-bleed fiable, sans scrollbar */
margin-left: calc(50% - 50vw) !important;
margin-right: calc(50% - 50vw) !important;
/* pas de padding ici (TemplateStyles refuse env()/max()) */
}
/* 2) Bloc principal — hauteur modérée */
.home-header {
display: flex;
width: 100%;
min-height: 70px;
overflow: visible;
background: var(--color-surface-1, #f8f9fa);
border-radius: 0;
box-shadow: 0 2px 4px rgba(0, 0, 0, 0.1);
transition: box-shadow 0.2s ease, transform 0.2s ease, background 0.2s ease;
}
.home-header--has-link { cursor: pointer; }
.home-header--has-link:hover {
box-shadow: 0 4px 8px rgba(0, 0, 0, 0.15);
transform: translateY(-1px);
}
/* 3) Contenu interne (garde les “gouttières”) */
.home-header__content {
display: flex;
align-items: center;
gap: 16px;
width: 100%;
padding: 16px 20px; /* les marges internes sont gérées ici */
flex-wrap: wrap;
}
/* 4) Dark mode */
.skin-theme-clientpref-night .home-header {
background: var(--color-surface-1, #1e1e1e);
box-shadow: 0 2px 4px rgba(0, 0, 0, 0.3);
}
.skin-theme-clientpref-night .home-header--has-link:hover {
box-shadow: 0 4px 8px rgba(0, 0, 0, 0.5);
}
/* =============================================================================
ÉLÉMENTS
========================================================================== */
/* Badge */
.home-header__badge {
display: inline-flex;
align-items: center;
gap: 6px;
padding: 4px 8px;
border-radius: 6px;
font-size: 0.78rem;
line-height: 1;
font-weight: 600;
letter-spacing: .02em;
background: #0b6efd;
color: #fff;
}
.skin-theme-clientpref-night .home-header__badge {
background: #0b6efd;
color: #fff;
}
/* Title */
.home-header__title {
font-size: 1.12rem;
line-height: 1.3;
font-weight: 700;
color: var(--color-base, #202122);
}
.skin-theme-clientpref-night .home-header__title {
color: #e6edf3;
}
/* Subtitle */
.home-header__subtitle {
font-size: 0.95rem;
line-height: 1.4;
color: var(--color-subtle, #54595d);
flex-grow: 1;
}
.skin-theme-clientpref-night .home-header__subtitle {
color: var(--color-subtle, #a2a9b1);
}
/* Text */
.home-header__text {
font-size: 0.9rem;
line-height: 1.5;
color: var(--color-base, #202122);
}
.skin-theme-clientpref-night .home-header__text {
color: #e6edf3;
}
/* Link wrapper et link */
.home-header__link-wrapper {
display: inline-flex;
align-items: center;
margin-left: auto;
flex-shrink: 0;
}
.home-header__link-wrapper a { text-decoration: none !important; }
.home-header__link {
display: inline-flex;
align-items: center;
font-size: 0.9rem;
color: var(--color-progressive, #36c) !important;
font-weight: 500;
white-space: nowrap;
transition: color 0.2s ease;
}
.home-header__link-wrapper:hover .home-header__link,
.home-header--has-link:hover .home-header__link {
color: var(--color-progressive-hover, #2a9) !important;
}
.skin-theme-clientpref-night .home-header__link {
color: #4d90fe !important;
}
.skin-theme-clientpref-night .home-header__link-wrapper:hover .home-header__link,
.skin-theme-clientpref-night .home-header--has-link:hover .home-header__link {
color: #3d8dfe !important;
}
/* =============================================================================
RESPONSIVE
========================================================================== */
@media (max-width: 768px) {
.home-header { min-height: 80px; }
.home-header__content {
gap: 12px;
padding: 12px 16px;
}
.home-header__title { font-size: 1rem; }
.home-header__subtitle,
.home-header__text,
.home-header__link { font-size: 0.85rem; }
}
@media (max-width: 480px) {
.home-header { min-height: 90px; }
.home-header__content { gap: 10px; padding: 12px; }
.home-header__badge { flex-basis: 100%; }
.home-header__title { font-size: 0.95rem; flex-basis: 100%; }
.home-header__subtitle { flex-basis: 100%; font-size: 0.8rem; }
.home-header__text { display: none; }
.home-header__link-wrapper {
margin-left: 0;
flex-basis: 100%;
justify-content: flex-end;
}
.home-header__link { font-size: 0.85rem; }
}
/* Sécurité : couleurs de lien internes héritées */
.home-header a,
.home-header a:visited { color: inherit; }