« Modèle:Header/styles.css » : différence entre les versions
De Nefald
Autres actions
mAucun résumé des modifications Balise : Révocation manuelle |
mAucun résumé des modifications Balise : Révoqué |
||
| Ligne 1 : | Ligne 1 : | ||
/* ============================================================================= | /* ============================================================================= | ||
HEADER COMPONENT - Bandeau horizontal pleine largeur | 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 { | .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 { | .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); | |||
} | } | ||
.home- | /* 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; | |||
} | } | ||
/* Dark mode */ | /* 4) Dark mode */ | ||
.skin-theme-clientpref-night .home-header { | .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 { | .skin-theme-clientpref-night .home-header--has-link:hover { | ||
box-shadow: 0 4px 8px rgba(0, 0, 0, 0.5); | |||
} | } | ||
/* ============================================================================= | /* ============================================================================= | ||
ÉLÉMENTS | |||
========================================================================== */ | |||
/* Badge */ | /* Badge */ | ||
.home-header__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 { | .skin-theme-clientpref-night .home-header__badge { | ||
background: #0b6efd; | |||
color: #fff; | |||
} | } | ||
/* Title */ | /* Title */ | ||
.home-header__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 { | .skin-theme-clientpref-night .home-header__title { | ||
color: #e6edf3; | |||
} | } | ||
/* Subtitle */ | /* Subtitle */ | ||
.home-header__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 { | .skin-theme-clientpref-night .home-header__subtitle { | ||
color: var(--color-subtle, #a2a9b1); | |||
} | } | ||
/* Text */ | /* Text */ | ||
.home-header__text { | .home-header__text { | ||
font-size: 0.9rem; | |||
line-height: 1.5; | |||
color: var(--color-base, #202122); | |||
} | } | ||
.skin-theme-clientpref-night .home-header__text { | .skin-theme-clientpref-night .home-header__text { | ||
color: #e6edf3; | |||
} | } | ||
/* Link wrapper et link */ | /* Link wrapper et link */ | ||
.home-header__link-wrapper { | .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 { | .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__link-wrapper:hover .home-header__link, | ||
.home-header--has-link: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 { | .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__link-wrapper:hover .home-header__link, | ||
.skin-theme-clientpref-night .home-header--has-link:hover .home-header__link { | .skin-theme-clientpref-night .home-header--has-link:hover .home-header__link { | ||
color: #3d8dfe !important; | |||
} | } | ||
/* ============================================================================= | /* ============================================================================= | ||
RESPONSIVE | RESPONSIVE | ||
========================================================================== */ | |||
@media (max-width: 768px) { | @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) { | @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; } | |||
} | |||
Version du 1 novembre 2025 à 20:12
/* =============================================================================
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; }