:root {
--levage-orange:        #F97316;
--levage-orange-dark:   #EA580C;
--levage-orange-light:  #FFF5EE;
--levage-noir:          #1A1A1A;
--levage-gris-90:       #2A2A2A;
--levage-gris-50:       #6B7280;
--levage-gris-20:       #E5E7EB;
--levage-gris-10:       #F3F4F6;
--levage-blanc:         #FFFFFF;
--levage-radius-card:   12px;
--levage-radius-pill:   999px;
--levage-shadow-soft:   0 1px 3px rgba(0, 0, 0, 0.04);
--levage-shadow-hover:  0 4px 12px rgba(0, 0, 0, 0.08);
--levage-transition:    200ms ease;
--levage-container:     1200px;
--levage-font:          'Roboto', system-ui, -apple-system, "Segoe UI", "Helvetica Neue", Arial, sans-serif;
--levage-font-headings: 'Libre Franklin', system-ui, -apple-system, "Segoe UI", "Helvetica Neue", Arial, sans-serif;
--levage-font-body:     'Roboto', system-ui, -apple-system, "Segoe UI", "Helvetica Neue", Arial, sans-serif;
} .levage-catalogue {
font-family: var(--levage-font-body);
}
.levage-catalogue__title,
.levage-card__title {
font-family: var(--levage-font-headings);
} .levage-catalogue {
max-width: var(--levage-container);
margin: 0 auto;
padding: 64px 24px 80px;
font-family: var(--levage-font);
color: var(--levage-noir);
} body:has(.levage-catalogue),
body:has(.levage-categorie-main) {
background-color: #F5F6F6;
}
.levage-page-bg { background-color: #F5F6F6; }
.levage-catalogue.alignfull {
max-width: none;
padding-left: 24px;
padding-right: 24px;
}
.levage-catalogue * { box-sizing: border-box; } .levage-catalogue__header {
text-align: center;
margin-bottom: 72px; max-width: 820px;
margin-left: auto;
margin-right: auto;
}
.levage-catalogue__title {
font-size: clamp(32px, 5vw, 52px);
line-height: 1.1;
font-weight: 700;
letter-spacing: -0.015em;
margin: 0 0 16px;
color: var(--levage-noir);
}
.levage-catalogue__subtitle {
font-size: 17px;
line-height: 1.6;
color: var(--levage-noir);
margin: 0 0 28px;
}
.levage-catalogue__cta {
margin: 0 auto;
} .levage-cta {
display: inline-flex;
align-items: center;
gap: 12px;
padding: 6px 8px 6px 22px;
background: var(--levage-orange);
color: var(--levage-blanc);
border-radius: 14px;
font-weight: 600;
font-size: 16px;
line-height: 1;
text-decoration: none;
transition: background-color var(--levage-transition),
transform var(--levage-transition);
margin: 0 auto;
box-shadow: 0 1px 2px rgba(0,0,0,0.06);
}
.levage-cta:hover {
background: var(--levage-orange-dark);
transform: translateY(-1px);
}
.levage-cta:focus-visible {
outline: 2px solid var(--levage-orange);
outline-offset: 3px;
}
.levage-cta__label { white-space: nowrap; }
.levage-cta__icon {
display: inline-flex;
align-items: center;
justify-content: center;
width: 36px;
height: 36px;
background: var(--levage-blanc);
color: var(--levage-orange);
border-radius: 10px;
flex-shrink: 0;
transition: transform var(--levage-transition);
}
.levage-cta:hover .levage-cta__icon { transform: translateX(2px); } .levage-btn {
display: inline-flex;
align-items: center;
justify-content: center;
gap: 8px;
padding: 12px 22px;
border-radius: 999px;
font-size: 15px;
font-weight: 600;
line-height: 1;
text-decoration: none;
cursor: pointer;
transition: background-color var(--levage-transition),
color var(--levage-transition),
border-color var(--levage-transition),
transform var(--levage-transition),
box-shadow var(--levage-transition);
border: 1px solid transparent;
font-family: inherit;
}
.levage-btn--primary {
background: var(--levage-orange);
color: var(--levage-blanc);
}
.levage-btn--primary:hover { background: var(--levage-orange-dark); }
.levage-btn--ghost {
background: var(--levage-blanc);
color: var(--levage-noir);
border-color: var(--levage-gris-20);
}
.levage-btn--ghost:hover {
border-color: var(--levage-gris-50);
background: var(--levage-gris-10);
}
.levage-btn__icon { flex-shrink: 0; } .levage-catalogue__search-wrap {
display: flex;
justify-content: center;
align-items: center; margin-bottom: 56px;
} @media (max-width: 900px) {
.levage-catalogue {
overflow: visible;
}
.levage-catalogue__search-wrap {
position: -webkit-sticky;
position: sticky;
top: 56px; z-index: 30;
background: #F5F6F6; width: 100vw;
max-width: 100vw;
margin-left: 50%;
transform: translateX(-50%); padding: 14px 24px;
margin-bottom: 24px;
box-shadow: 0 1px 0 rgba(0, 0, 0, 0.06);
transition: background-color 200ms ease,
box-shadow 200ms ease,
padding-top 200ms ease,
padding-bottom 200ms ease;
} .levage-catalogue__search-wrap:has(.levage-search__input:focus) {
background: #FFFFFF;
box-shadow: 0 4px 14px rgba(0, 0, 0, 0.08);
padding-top: 18px;
padding-bottom: 18px;
}
}
@media (max-width: 600px) { .levage-catalogue__search-wrap {
padding: 12px 16px;
}
}
.levage-search {
position: relative;
width: 100%;
max-width: 700px; box-sizing: border-box;
} @media (min-width: 901px) {
.levage-search {
max-width: 720px !important;
margin-left: auto !important;
margin-right: auto !important;
}
} @media (max-width: 900px) {
.levage-search {
max-width: 100%;
}
}
.levage-search__icon {
position: absolute;
left: 18px; top: 50%;
transform: translateY(-50%);
color: var(--levage-gris-50);
pointer-events: none; display: flex;
align-items: center;
justify-content: center;
width: 20px;
height: 20px;
flex-shrink: 0;
}
.levage-search__input {
display: block; width: 100%;
box-sizing: border-box; padding: 16px 20px 16px 50px;
border-radius: 999px;
border: 1px solid var(--levage-gris-20);
background: var(--levage-blanc);
font-size: 16px; font-family: inherit;
color: var(--levage-noir);
line-height: 1.4; vertical-align: middle;
transition: border-color var(--levage-transition),
box-shadow var(--levage-transition);
-webkit-appearance: none;
appearance: none;
}
.levage-search__input::placeholder { color: var(--levage-gris-50); }
.levage-search__input:focus {
outline: none;
border-color: var(--levage-orange);
box-shadow: 0 0 0 3px rgba(249, 115, 22, 0.12);
}
.levage-search__input::-webkit-search-cancel-button { -webkit-appearance: none; } .levage-catalogue__pills {
display: flex;
flex-wrap: wrap;
gap: 10px;
justify-content: center;
margin-bottom: 28px;
}
.levage-pill {
--levage-pill-color: var(--levage-orange);
display: inline-flex;
align-items: center;
gap: 8px;
padding: 9px 16px;
border-radius: var(--levage-radius-pill);
background: var(--levage-blanc);
border: 1px solid var(--levage-gris-20);
color: var(--levage-noir);
font-size: 14px;
font-weight: 500;
font-family: inherit;
cursor: pointer;
transition: background-color var(--levage-transition),
color var(--levage-transition),
border-color var(--levage-transition),
transform var(--levage-transition);
white-space: nowrap;
}
.levage-pill:hover {
border-color: var(--levage-gris-50);
background: var(--levage-gris-10);
}
.levage-pill__dot {
display: inline-block;
width: 10px;
height: 10px;
border-radius: 2px;
background: var(--levage-pill-color);
flex-shrink: 0;
transition: background-color var(--levage-transition);
}
.levage-pill[aria-pressed="true"] {
background: var(--levage-orange);
border-color: var(--levage-orange);
color: var(--levage-blanc);
}
.levage-pill[aria-pressed="true"] .levage-pill__dot {
background: var(--levage-blanc);
}
.levage-pill:focus-visible {
outline: 2px solid var(--levage-orange);
outline-offset: 2px;
} .levage-filters-trigger {
display: none; align-items: center;
gap: 10px;
margin: 0 0 24px;
padding: 12px 18px;
background: var(--levage-blanc);
border: 1px solid var(--levage-gris-20);
border-radius: 12px;
font-size: 15px;
font-weight: 600;
color: var(--levage-noir);
font-family: inherit;
cursor: pointer;
transition: border-color var(--levage-transition),
background-color var(--levage-transition),
box-shadow var(--levage-transition);
width: 100%;
justify-content: center;
}
.levage-filters-trigger:hover {
border-color: var(--levage-orange);
background: #FFF5EE;
}
.levage-filters-trigger__count {
display: inline-flex;
align-items: center;
justify-content: center;
min-width: 22px;
height: 22px;
padding: 0 7px;
background: var(--levage-orange);
color: var(--levage-blanc);
border-radius: 999px;
font-size: 12px;
font-weight: 700;
} .levage-filters-sheet {
display: contents; }
.levage-filters-sheet__backdrop,
.levage-filters-sheet__header,
.levage-filters-sheet__footer,
.levage-filters-sheet__close {
display: none; } @media (max-width: 900px) {
.levage-filters-trigger {
display: inline-flex;
} .levage-filters-sheet {
display: block; position: fixed;
inset: 0;
z-index: 9999;
pointer-events: none; visibility: hidden;
transition: visibility 0s linear 280ms;
}
.levage-filters-sheet.is-open {
pointer-events: auto;
visibility: visible;
transition: visibility 0s linear 0s;
}
.levage-filters-sheet__backdrop {
display: block;
position: absolute;
inset: 0;
background: rgba(0, 0, 0, 0.45);
opacity: 0;
transition: opacity 280ms ease;
}
.levage-filters-sheet.is-open .levage-filters-sheet__backdrop {
opacity: 1;
}
.levage-filters-sheet__panel {
position: absolute;
bottom: 0;
left: 0;
right: 0;
background: var(--levage-blanc);
border-radius: 18px 18px 0 0;
box-shadow: 0 -10px 40px rgba(0, 0, 0, 0.18);
max-height: 88vh;
display: flex;
flex-direction: column;
transform: translateY(100%);
transition: transform 320ms cubic-bezier(0.32, 0.72, 0, 1);
}
.levage-filters-sheet.is-open .levage-filters-sheet__panel {
transform: translateY(0);
} .levage-filters-sheet__panel::before {
content: '';
display: block;
width: 40px;
height: 4px;
background: var(--levage-gris-20);
border-radius: 999px;
margin: 10px auto 0;
}
.levage-filters-sheet__header {
display: flex;
align-items: center;
justify-content: space-between;
padding: 16px 20px 12px;
border-bottom: 1px solid var(--levage-gris-20);
}
.levage-filters-sheet__title {
margin: 0;
font-size: 17px;
font-weight: 700;
color: var(--levage-noir);
}
.levage-filters-sheet__close {
display: inline-flex;
align-items: center;
justify-content: center;
width: 36px;
height: 36px;
background: var(--levage-gris-10);
border: none;
border-radius: 999px;
color: var(--levage-noir);
cursor: pointer;
transition: background var(--levage-transition);
}
.levage-filters-sheet__close:hover {
background: var(--levage-gris-20);
} .levage-filters-sheet__pills {
flex: 1;
overflow-y: auto;
padding: 20px;
margin-bottom: 0 !important;
display: grid;
grid-template-columns: repeat(2, minmax(0, 1fr));
gap: 10px;
}
.levage-filters-sheet__pills .levage-pill {
margin: 0;
width: 100%;
justify-content: flex-start; padding: 12px 14px;
font-size: 14px;
border-radius: 10px;
min-height: 48px; }
.levage-filters-sheet__pills .levage-pill__label {
overflow: hidden;
text-overflow: ellipsis;
white-space: nowrap;
flex: 1;
text-align: left;
}
.levage-filters-sheet__pills .levage-pill__dot {
width: 12px;
height: 12px;
border-radius: 3px;
} @media (min-width: 600px) and (max-width: 900px) {
.levage-filters-sheet__pills {
grid-template-columns: repeat(3, minmax(0, 1fr));
}
}
.levage-filters-sheet__footer {
display: flex;
align-items: stretch; gap: 12px;
padding: 16px 20px calc(16px + env(safe-area-inset-bottom, 0px));
border-top: 1px solid var(--levage-gris-20);
background: var(--levage-blanc);
} .levage-filters-sheet__footer .levage-btn {
min-height: 42px; padding: 0 14px; font-size: 14px; line-height: 1;
border-radius: 10px; display: inline-flex;
align-items: center;
justify-content: center;
gap: 6px;
white-space: nowrap;
}
.levage-filters-sheet__reset {
flex: 0 0 auto;
}
.levage-filters-sheet__apply {
flex: 1;
} .levage-filters-sheet__apply [data-levage-filters-apply-count] {
display: inline-block;
font-variant-numeric: tabular-nums; margin: 0 4px;
} }
.levage-filters-open,
.levage-filters-open body {
overflow: hidden;
} .levage-catalogue__toolbar {
display: flex;
align-items: center;
justify-content: space-between;
gap: 16px;
margin-bottom: 20px;
flex-wrap: wrap;
}
.levage-catalogue__counter {
margin: 0;
font-size: 14px;
color: var(--levage-gris-50);
font-weight: 500;
}
.levage-catalogue__counter [data-levage-count] {
color: var(--levage-noir);
font-weight: 700;
}
.levage-catalogue__reset {
background: transparent;
border: 1px solid var(--levage-gris-20);
color: var(--levage-noir);
padding: 8px 14px;
border-radius: 999px;
font-size: 13px;
font-weight: 500;
cursor: pointer;
font-family: inherit;
transition: border-color var(--levage-transition),
background-color var(--levage-transition);
}
.levage-catalogue__reset:hover {
border-color: var(--levage-orange);
color: var(--levage-orange);
} .levage-catalogue__grid {
display: grid;
grid-template-columns: repeat(4, minmax(0, 1fr));
gap: 24px;
}
@media (max-width: 1199px) {
.levage-catalogue__grid { grid-template-columns: repeat(3, minmax(0, 1fr)); }
}
@media (max-width: 899px) {
.levage-catalogue__grid { grid-template-columns: repeat(2, minmax(0, 1fr)); }
}
@media (max-width: 599px) {
.levage-catalogue__grid { grid-template-columns: 1fr; }
} .levage-card {
display: flex;
flex-direction: column;
position: relative;
background: var(--levage-blanc);
border: 1px solid var(--levage-gris-20);
border-radius: 0; overflow: hidden;
text-decoration: none;
color: inherit;
transition: transform var(--levage-transition),
box-shadow var(--levage-transition),
border-color var(--levage-transition),
opacity var(--levage-transition);
opacity: 1;
}
.levage-card:hover {
transform: translateY(-2px);
box-shadow: var(--levage-shadow-hover);
border-color: var(--levage-gris-20);
}
.levage-card[hidden] {
display: none !important;
} .levage-card.levage-card--filtering {
opacity: 0;
pointer-events: none;
} .levage-card__tag {
position: absolute;
top: 18px;
left: 18px;
z-index: 2;
display: inline-flex;
align-items: center;
gap: 6px;
padding: 5px 10px;
background: rgba(255, 255, 255, 0.96);
backdrop-filter: blur(4px);
-webkit-backdrop-filter: blur(4px);
border-radius: 999px;
font-size: 11px;
font-weight: 600;
color: var(--levage-noir);
box-shadow: var(--levage-shadow-soft);
max-width: calc(100% - 24px);
}
.levage-card__tag-dot {
display: inline-block;
width: 8px;
height: 8px;
border-radius: 2px;
flex-shrink: 0;
}
.levage-card__tag-label {
white-space: nowrap;
overflow: hidden;
text-overflow: ellipsis;
} .levage-card__media {
display: block;
width: calc(100% - 20px);
height: 190px;
margin: 10px 10px 0;
overflow: hidden;
background: #EBEBEB; flex-shrink: 0;
}
.levage-card__media img {
width: 100%;
height: 100%;
object-fit: cover;
display: block;
transition: transform 600ms ease;
}
.levage-card:hover .levage-card__media img { transform: scale(1.03); }
.levage-card__media-placeholder {
display: block;
width: 100%;
height: 100%;
background: #EBEBEB;
} .levage-card__body {
display: flex;
flex-direction: column;
gap: 8px;
padding: 18px 20px 20px;
}
.levage-card__title {
font-size: 16px;
font-weight: 600;
line-height: 1.35;
color: var(--levage-noir);
}
.levage-card__desc {
font-size: 13px;
line-height: 1.55;
color: var(--levage-gris-50);
} .levage-catalogue__noresults {
text-align: center;
padding: 48px 24px;
background: var(--levage-gris-10);
border-radius: var(--levage-radius-card);
margin-top: 32px;
}
.levage-catalogue__noresults-title {
font-size: 18px;
font-weight: 600;
color: var(--levage-noir);
margin: 0 0 16px;
}
.levage-catalogue__noresults-suggest-msg {
font-size: 14px;
color: var(--levage-gris-50);
margin: 24px 0 16px;
}
.levage-catalogue__suggestions {
display: grid;
grid-template-columns: repeat(3, minmax(0, 1fr));
gap: 16px;
max-width: 900px;
margin: 0 auto 24px;
}
.levage-catalogue__suggestions .levage-card {
font-size: 13px;
}
.levage-catalogue__suggestions .levage-card__media { height: 140px; }
@media (max-width: 700px) {
.levage-catalogue__suggestions { grid-template-columns: 1fr; }
} .levage-catalogue__empty {
text-align: center;
padding: 64px 24px;
background: var(--levage-gris-10);
border-radius: var(--levage-radius-card);
color: var(--levage-gris-50);
} @media (max-width: 600px) {
.levage-catalogue { padding: 40px 16px 56px; }
.levage-search__input { padding: 14px 18px 14px 46px; font-size: 14px; }
.levage-catalogue__pills { gap: 8px; }
.levage-pill { padding: 8px 12px; font-size: 13px; }
} .levage-card:focus-visible {
outline: 2px solid var(--levage-orange);
outline-offset: 2px;
}
.levage-search__input:focus-visible { }
.levage-catalogue__reset:focus-visible {
outline: 2px solid var(--levage-orange);
outline-offset: 2px;
}