:root {
  --bro-black: #000000;
  --bro-white: #ffffff;
  --bro-beige: #F9F4EB;
  --bro-grey: #D9D9D9;
  --bro-yellow: #fee32e;
}

::selection {
  background-color: var(--bro-yellow);
  color: var(--bro-black);
  text-shadow: none;
}


/* html.lenis, html.lenis body { height: auto; }
.lenis:not(.lenis-autoToggle).lenis-stopped { overflow: clip; }
.lenis.lenis-smooth [data-lenis-prevent] { overscroll-behavior: contain; }
.lenis.lenis-smooth iframe { pointer-events: none; }
.lenis.lenis-autoToggle { transition-property: overflow; transition-duration: 1ms; transition-behavior: allow-discrete; } */


html, body { background-color: var(--bro-beige); font-family: "Inter", sans-serif; font-optical-sizing: auto; font-weight: 400; font-style: normal; }

.h1-page span { display: inline-block; font-size: 10px; font-weight: 400; }
.h1-page h1 { display: inline-block; font-size: 12px; font-weight: 700; line-height: 1; text-transform: lowercase; margin-top: 0; margin-bottom: 0; width: calc(100% - 12px); white-space: normal; word-break: break-word; }



header, main, footer {position: relative; }

.container-xxl, .container-xl, .container-lg, .container-md, .container-sm, .container { max-width: 100% !important; }


.brand { position: relative; z-index: 99999; display: inline-block; background-color: var(--bro-black); padding: 2px 8px !important; border-radius: 4px; transition: all 0.4s; }
.brand .site-title { font-size: 14px; line-height: 26px; letter-spacing: 0; color: var(--bro-white); text-decoration: none; transition: all 0.2s; }
.brand:hover { background-color: var(--bro-yellow) !important; }
.brand:hover .site-title { color: var(--bro-black) !important; }
.brand.small { position: fixed; top: 20px; left: 20px; z-index: 9999; visibility: hidden; background-color: var(--bro-yellow) !important;  }
.brand.small a { color: var(--bro-black) !important; }

.alert { margin-top: 24px; }
.alert-success { --bs-alert-bg: #3ce398; }

.bottom-bar { display: block; width: 100%; height: 3px; border-radius: 4px; background: var(--bro-black); margin-top: 10px; }


.accordion-item { color: var(--bro-black); background-color: transparent; border: none; border-bottom: solid 1px #000; }
.accordion-button { background-color: transparent; padding: 8px 0; border-radius: 0; font-weight: 700; font-size: 20px; line-height: 1.25; }
.accordion-body { padding: 12px 0; }
.accordion-item:last-of-type { border-radius: 0; }
.accordion-button:not(.collapsed) { color: #000; background-color: var(--bro-yellow); box-shadow: none;  }
.accordion-button:focus { box-shadow: none }
.accordion-item:last-of-type > .accordion-header .accordion-button.collapsed { border-radius: 0; }



.small-title { margin-bottom: 8px; }
.small-title p, .small-title h2 { display: inline-block; background: var(--bro-black); color: var(--bro-beige); margin: 0; line-height: 1; font-size: 12px; padding: 6px 8px; font-weight: 200; text-transform: uppercase; border-radius: 4px; }
.small-title span { display: inline-block; background: var(--bro-black); width: 6px; margin: -8px 0; height: 24px; line-height: 1; border-radius: 4px; }






/* nav */

.navbar { padding: 0; position: fixed; z-index: 9999; margin: auto; left: 50%; transform: translateX(-50%);}
.navbar .nav-item { font-weight: 700; }
.navbar .nav-link { background-color: var(--bro-grey); margin: 0 2px; }
.navbar .nav-link.active.is-active { background-color: var(--bro-black); color: var(--bro-beige); padding: 2px 22px !important; }
.navbar { padding: 0; margin: 0; }
.navbar .nav-link { padding: 2px 16px !important; font-size: 14px; line-height: 26px; letter-spacing: 0; border-radius: 26px; }
.navbar .nav-item a { transition: all 0.3s; }
.navbar .nav-item:hover a { padding: 2px 22px !important; }

.btn-hamburger { display: none; cursor: pointer; font-family: "Inter", sans-serif; font-optical-sizing: auto; font-weight: 400; position: fixed; z-index: 9999; font-size: 14px; right: 22px; top: 22px; background-color: var(--bro-black); padding: 4px 8px; border-radius: 4px; color: var(--bro-beige); line-height: 1; padding: 8px 12px !important; height: 30px; }
.btn-hamburger svg { display: inline-block; margin-top: -2px; margin-left: 4px; width: 10px; }
.btn-hamburger span { display: inline-block; }

@media only screen and (max-width: 991px) {
  .navbar { margin: inherit !important;}
  .btn-hamburger { display: block; }
}

header .btn-cta-header { position: fixed; z-index: 999; top: 22px; right: 22px; background-color: var(--bro-yellow) !important; padding: 7px 8px; font-size: 0.875em; transition: all 0.3s; line-height: 1; }
header .btn-cta-header::before { content: ''; background-image: url("/themes/custom/subtheme/img/arrow-right.svg"); display: inline-block; margin: 0 8px 0 0; width: 20px; height: 10px; background-size: contain; background-repeat: no-repeat; }
header .btn-cta-header::after { content: ''; background-image: url("/themes/custom/subtheme/img/arrow-right.svg"); display: inline-block; margin: 0 0 0 8px; width: 20px; height: 10px; background-size: contain; background-repeat: no-repeat; }

@media only screen and (max-width: 991px) {
  header .btn-cta-header { top: 56px; }
}

.dropdown-menu { background: var(--bro-black); padding: 8px; }
.dropdown-item.active, .media-library-view--widget .view-header a.dropdown-item.is-active, .dropdown-item:active { background-color: var(--bro-beige); border-radius: 6px; color: var(--bro-black) !important; }
.dropdown-item { color: var(--bro-beige); }

/* page black portfolio*/

.page-portfolio .grid .bar { opacity: 0.06; background: #00b2ff; }
.page-portfolio { background-color: var(--bro-black); color: var(--bro-beige); }
.page-portfolio a, .page-portfolio .block-header-simple-center .hero-titre { color: var(--bro-beige); }
.page-portfolio .bottom-bar, .page-portfolio .navbar .nav-link.active.is-active { background-color: #222; }
.page-portfolio .navbar .nav-link { background-color: var(--bro-black); color: var(--bro-beige); }
.page-portfolio .brand { background-color: var(--bro-beige);  }
.page-portfolio .brand .site-title { color: var(--bro-black); }
.page-portfolio .star-pixcel { filter: invert(1);}
.page-portfolio .navbar .nav-item:hover a{ background-color: var(--bro-beige); color: var(--bro-black) !important; }
.page-portfolio .navbar .dropdown-menu .nav-item:hover a.dropdown-item { background-color: var(--bro-beige); color: var(--bro-black); }

.page-portfolio .dropdown-menu { background-color: var(--bro-beige;) color: var(--bro-black); }
.page-portfolio .navbar .nav-link.active.is-active:hover { color: var(--bro-white); }


.page-portfolio .drawer {
  background: var(--bro-yellow);
  color:  var(--bro-black);
}
.page-portfolio .drawer .navbar-nav .nav-link.is-active { color: #444; }
.page-portfolio .drawer .navbar-nav .nav-link { color: var(--bro-black); }


.page-portfolio #closeDrawer { filter: invert(1);}





/* Block */


/* - */
.block-header-full-center { position: relative; min-height: calc(100vh - 111px); display: flex; flex-direction: column; justify-content: space-between; }
.block-header-full-center .hero-titre { font-family: "Anton", sans-serif; line-height: 1; color: var(--bro-black); text-align: center; margin-top: max(10vh, 44px); }
.block-header-full-center .hero-titre .big { font-size: 11.5vw; line-height: 16vw; }
.block-header-full-center .hero-titre .small { font-size: 8vw; margin-top: -3vw; }
.block-header-full-center .hero-titre .small .image-wrapper .field--name-field-image { display: inline-block; }
.block-header-full-center .hero-titre .small .image-wrapper { overflow: hidden; width: 0; transform-origin: center center; display: inline-block; }
.block-header-full-center .hero-titre .small .image-wrapper .field--name-field-image img { height: calc(8vw - 11px); width: auto; border-radius: 4px; aspect-ratio: 3 / 2;  object-fit: cover; margin-top: -15px; }
.block-header-full-center .hero-titre .small .field--name-field-titre-big-bas { display: inline-block; }
.block-header-full-center .hero-about { margin-bottom: 17px; margin-top: 17px; }
.block-header-full-center .hero-about .field--name-body { font-weight: 700; font-size: 20px; line-height: 1.25; }
.block-header-full-center .hero-about .field--name-body p { margin-bottom: 0; }
.block-header-full-center .hero-about .field--name-field-slogan { font-weight: 700; font-size: 12px; text-transform: uppercase; }

.page-services .block-header-full-center .hero-titre .big { font-size: 11vw; }


@media only screen and (max-width: 991px) {
  .block-header-full-center { min-height: calc(100vh - 132px); }
  .block-header-full-center .hero-titre { text-align: left; margin-top: 32px; }
  .block-header-full-center .hero-titre .big { font-size: 10vw !important; }
  .block-header-full-center .hero-titre .small { font-size: 10vw; margin-top: -9vw; }
  .block-header-full-center .hero-titre .small .image-wrapper .field--name-field-image img { height: 10vw; margin-top: -4px; }
}

/* - */
.block-header-full-left { position: relative; min-height: calc(100vh - 111px); display: flex; flex-direction: column; justify-content: space-between; }
.block-header-full-left .hero-titre { font-family: "Anton", sans-serif; line-height: 1; color: var(--bro-black); margin-top: max(10vh, 44px); }
.block-header-full-left .hero-titre .big { font-size: 11.5vw; line-height: 16vw; }
.block-header-full-left .hero-titre .small { font-size: 8vw; margin-top: -3vw; }
.block-header-full-left .hero-titre .small .image-wrapper { overflow: hidden; width: 0; transform-origin: center center; display: inline-block; }
.block-header-full-left .hero-titre .small .image-wrapper .field--name-field-image { display: inline-block; }
.block-header-full-left .hero-titre .small .image-wrapper .field--name-field-image img { height: calc(8vw - 11px); width: auto; border-radius: 4px; aspect-ratio: 3 / 2; object-fit: cover; margin-top: -15px; }
.block-header-full-left .hero-titre .small .field--name-field-titre-big-bas { display: inline-block; }
.block-header-full-left .hero-about { margin-bottom: 17px; margin-top: 17px; }
.block-header-full-left .hero-about .field--name-body { font-weight: 700; font-size: 20px; line-height: 1.25; }
.block-header-full-left .hero-about .field--name-body p { margin-bottom: 0; }
.block-header-full-left .hero-about .field--name-field-slogan { font-weight: 700; font-size: 12px; text-transform: uppercase; }
.block-header-full-left .field--name-field-mail a { font-size: 4vw; text-decoration: none; color: var(--bro-black); line-height: 5vw; }

@media only screen and (max-width: 991px) {
  .block-header-full-left { min-height: calc(100vh - 132px); }
  .block-header-full-left .hero-titre { text-align: left; margin-top: 32px; }
  .block-header-full-left .hero-titre .big { font-size: 10vw; }
  .block-header-full-left .hero-titre .small { font-size: 10vw; margin-top: -9vw; }
  .block-header-full-left .hero-titre .small .image-wrapper .field--name-field-image img { height: 10vw; margin-top: -4px; }

  .block-header-full-left .field--name-field-slogan { text-align: left; }
  .block-header-full-left .mail { display: block; width: 100%;  }
  .block-header-full-left .mail .field--name-field-mail a { font-size: 36px !important; line-height: normal; }
}


.block-header-simple-left { position: relative; display: flex; flex-direction: column; justify-content: space-between; }
.block-header-simple-left .hero-titre { font-family: "Anton", sans-serif; line-height: 1; color: var(--bro-black); margin-top: max(10vh, 44px); }
.block-header-simple-left .hero-titre .big { font-size: 5vw; line-height: 6vw; }
.block-header-simple-left .hero-about { margin-bottom: 17px; margin-top: 17px; }
.block-header-simple-left .hero-about .field--name-body { font-weight: 700; font-size: 20px; line-height: 1.25; }
.block-header-simple-left .hero-about .field--name-body p { margin-bottom: 0; }
.block-header-simple-left .hero-about .field--name-field-slogan { font-weight: 700; font-size: 12px; text-transform: uppercase; }
.block-header-simple-left .field--name-field-mail a { font-size: 4vw; text-decoration: none; color: var(--bro-black); line-height: 5vw; }

@media only screen and (max-width: 991px) {
  .block-header-simple-left { min-height: calc(100vh - 132px); }
  .block-header-simple-left .hero-titre { text-align: left; margin-top: 32px; }
  .block-header-simple-left .hero-titre .big { font-size: 10vw; line-height: 11vw; }

  .block-header-simple-left .field--name-field-slogan { text-align: left; }
  .block-header-simple-left .mail { display: block; width: 100%;  }
  .block-header-simple-left .mail .field--name-field-mail a { font-size: 36px !important; line-height: normal; }
}





/* - */
.block-header-simple-center { }
.block-header-simple-center .hero-titre { font-family: "Anton", sans-serif; line-height: 1; color: var(--bro-black); text-align: center; margin-top: max(10vh, 44px); }
.block-header-simple-center .hero-titre .big { font-size: 13vw; }
.block-header-simple-center .field--name-body { font-weight: 700; font-size: 20px; line-height: 1.25; font-family: "Inter", sans-serif; text-align: center; }






/* - */
.block-qa { margin: 22px 0; }
.block-qa .field--name-field-question-reponse .field__item .paragraph--type--question-reponse { border-bottom: solid 1px #000; } 
.block-qa .field--name-field-question-reponse .field__item .paragraph--type--question-reponse .field--name-field-question { font-weight: 700; font-size: 20px; line-height: 1.25; }
.block-qa h2 { display: inline-block; background: var(--bro-black); color: var(--bro-beige); margin: 0; line-height: 1; font-size: 12px; padding: 6px 8px; font-weight: 200; text-transform: uppercase; border-radius: 4px; }


.text-reveal-wrapper {
  display: inline-block;
  overflow: hidden;
  height: 0; 
}

.text-content {
  transform: translateY(0);
}

.parallax-block {
  will-change: transform;
  transition: transform 0.1s;
}


.scroll-bounce-wrapper {
  position: relative;
  height: 80px; /* hauteur du rebond */
}

.scroll-bounce-icon {
  position: absolute;
  left: 0;
  bottom: 4px;
  width: 10px;
  height: auto;
}


/* - */
.block-services-var-rond { position: relative; background-color: var(--bro-black); color: var(--bro-beige); margin: 0 -20px; padding: calc(111px + 17vh) 20px calc(55px + 4vh) 20px; text-align: center;  overflow: hidden; will-change: transform; }
.block-services-var-rond::before { content: ''; position: absolute; bottom: 0; left: 0; width: 100%; background-color: var(--bro-black); z-index: 9; height: 50%; }

.block-services-var-rond .grid-container, .block-services-var-rond h2 { position: relative; z-index: 9; }
.block-services-var-rond h2 { font-family: "Anton", sans-serif; font-size: 8vw; }
.block-services-var-rond .plan_wheel { transform: translateZ(0); backface-visibility: hidden; will-change: transform; }
.block-services-var-rond .plan_wheel-wrap { position: absolute; top: 10vh; width: 100%; left: 0; pointer-events: none; padding-top: 17.42px; grid-area: 1 / 1; justify-content: center; display: grid; }
.block-services-var-rond .plan_wheel-overlay { z-index: 1; margin-top: calc(17.42px * -1); width: 100%;left: 0;grid-area: 1 / 1; justify-self: center; height: 100%; }
.block-services-var-rond .plan_wheel-gradient { background-image: linear-gradient(#fff0, #0000003d 9%, #00000080 16%, #000000b8 22%, #000 32%); width: 100%; height: 100%; }
.block-services-var-rond .plan_wheel-items { width: 100%; height: 100%; display: grid; }
.block-services-var-rond .plan_wheel-item-wrap { transform: rotate(calc(18deg * var(--wheel-index))); grid-area: 1 / 1; justify-self: center; height: 100%; }
.block-services-var-rond .plan_wheel-item-wrap img { object-fit: cover; border-radius: 8px; height: 150px; }
.block-services-var-rond .plan_wheel { aspect-ratio: 1; pointer-events: none; grid-area: 1 / 1; place-self: flex-start center; width: 80em; }
.block-services-var-rond .plan_wheel { will-change: transform; }
.block-services-var-rond .field--name-field-lignes { font-size: 14px; font-weight: 300; }
.block-services-var-rond .separator { padding: 0 0 40px 0; margin-top: -40px; }
.block-services-var-rond .separator .star-pixcel { filter: invert(1); }
.block-services-var-rond .field--name-field-texte-bottom-gros { font-family: "Anton", sans-serif; font-size: 36px; line-height: 1.2; }
.block-services-var-rond .field--name-field-texte-bottom-slim { font-weight: 400; font-size: 16px; margin-top: 10px; }
.block-services-var-rond .field--name-field-texte-bottom-slim .field__item { margin-bottom: 10px; }
.block-services-var-rond .field--name-field-lignes { text-align: right; }
.block-services-var-rond .list-service { font-weight: 300; text-transform: uppercase; font-size: 14px; }
.block-services-var-rond .label-service span { background-color: var(--bro-black); position: relative; z-index: 9; padding-left: 10px; }
.block-services-var-rond .label-service {  position: relative; overflow: hidden; left: 0;}
.block-services-var-rond .label-service::before { content: "........................................................................................................................................................................................................................"; position: absolute; letter-spacing: 1px; font-weight: 100; right: 0; text-align: right; white-space: nowrap; overflow: hidden; pointer-events: none; z-index: 0; }
.block-services-var-rond .index-service {  position: relative; overflow: hidden; left: 0; }
.block-services-var-rond .index-service::before { content: "........................................................................................................................................................................................................................"; position: absolute; letter-spacing: 1px; font-weight: 100; left: 20px; text-align: right; white-space: nowrap; overflow: hidden; pointer-events: none; z-index: 0;}

.block-services-var-rond .droitegauche { transform: translateY(-100%); font-size: 10px; line-height: 20px; font-weight: 300; text-transform: uppercase; }

@media only screen and (max-width: 769px) {
  .block-services-var-rond .droitegauche { transform: none; margin-top: 48px; }
  .block-services-var-rond .droitegauche .droite { }
}





.block-services-simple-liste { position: relative; background-color: var(--bro-black); color: var(--bro-beige); margin: 0 -20px; padding: calc(55px + 4vh) 20px; text-align: center;  overflow: hidden; will-change: transform; }
.block-services-simple-liste .field--name-body { font-family: "Anton", sans-serif; font-size: 36px; line-height: 1.2; }


.block-services-simple-liste .field--type-entity-reference-revisions { display: flex; flex-wrap: wrap; gap: 1rem; justify-content: center; padding: 1rem 0; }
.block-services-simple-liste .field--type-entity-reference-revisions .field__item { flex: 0 1 auto; }
.block-services-simple-liste .field--type-entity-reference-revisions .field__item .paragraph--type--liste-service { text-align: left; background: var(--bro-beige); color: var(--bro-black); padding: 8px 16px; border-radius: 8px; display: inline-block; }
.block-services-simple-liste .field--type-entity-reference-revisions .field__item .paragraph--type--liste-service .field--name-field-titre { font-weight: 700; font-size: 16px; line-height: 1.25; }
.block-services-simple-liste .field--type-entity-reference-revisions .field__item .paragraph--type--liste-service .field--name-field-description { font-weight: 300; font-size: 14px; line-height: 1.25; }

.block-services-simple-liste .field--name-field-texte-bottom-slim { font-weight: 400; font-size: 16px; margin-top: 10px; }
.block-services-simple-liste .field--name-field-texte-bottom-slim .field__item { margin-bottom: 10px; }





.block-feature-grid { margin: 48px 0; }
.block-feature-grid .feature-mise-en-avant { background: var(--bro-black); color: var(--bro-beige); padding: 16px; border-radius: 8px; height: 100%; text-align: right; }
.block-feature-grid .field--name-field-mise-en-avant-titre { font-family: "Anton", sans-serif; font-size: 36px; line-height: 1.2; margin-bottom: 8px; }
.block-feature-grid .field--name-field-mise-en-avant-description { font-weight: 300; font-size: 14px; line-height: 1.25; }
.block-feature-grid .grid-mise-en-avant { position: sticky; top: 20px; }

.block-feature-grid .grid-container { grid-auto-flow: row; row-gap: 20px; }

.block-feature-grid .item-grid { background: #ffffff; color: var(--bro-black); padding: 16px; border-radius: 8px; height: 100%; }
.block-feature-grid .item-grid .field--name-field-titre-big-service { font-size: 24px; margin-bottom: 8px; font-weight: 600; line-height: 1.2; }
.block-feature-grid .item-grid .field--name-field-description-big { }
.block-feature-grid .item-grid .field--name-field-description-big .field__item { background-color: #f9f9f9; margin-bottom: 8px; padding: 8px; border-radius: 8px; font-size: 14px; line-height: 1.2; }


@media only screen and (max-width: 1194px) {
  .block-feature-grid .grid-mise-en-avant { position: relative; top: initial; }
}







/* view */
.view-works { margin: 10vh 0; }
.view-works .work-item { border-bottom: solid 4px #222; margin: 16px 0;  padding: 16px 0; font-size: 12px; font-weight: 300; transition: all 0.3s; }
.view-works .work-item h2 { margin-bottom: 0; line-height: 1; }
.view-works .work-item a { text-decoration: none; }
.view-works .work-item:hover { background: var(--bro-beige); color: var(--bro-black); padding: 16px; border-radius: 8px; }
.view-works .work-item:hover a { color: var(--bro-black);}
.view-works .work-item:hover .star-pixcel { filter: invert(0); }

.view-works .work-item .item-list ul { list-style: none; margin: 0; }
.view-works .work-item .item-list ul li { margin: 0; }

.view-works .work-item .img-cover { position: fixed; z-index: 999; bottom: 22px; left: 0; width: 100%; pointer-events: none; }
.view-works .work-item .img-cover img { opacity: 0; transition: all 0.3s; border-radius: 8px; margin-bottom: 22px; }

.view-works .work-item:hover .img-cover img { opacity: 1; margin-bottom: 0; }

@media only screen and (max-width: 769px) {

  .view-works .work-item .img-cover { position: relative; padding: 22px 0; bottom: 0; }
  .view-works .work-item .img-cover img { opacity: 1; margin-bottom: 0; }
}




.page-mentions-legales .region-content { margin-top: 48px; }


/* Footer */
footer { background-color: #111; color: var(--bro-beige); position: relative; z-index: 0; font-weight: 200; font-size: 14px; padding: 0; }
footer .star-pixcel { filter: invert(1); }
footer .int-legal { min-height: 333px; padding: 10vh 22px 8px 22px; }
footer .int-legal .icotype { font-size: 48px; font-weight: 500; line-height: 1; }
footer .bottom-bar { background-color: #444; }
footer .slogan { font-family: "Anton", sans-serif; font-size: 24px; line-height: 1.2; }
footer h4 { font-family: "Anton", sans-serif; font-size: 24px; line-height: 1.2; color: #444; }
footer .nav-footer { padding: 0; list-style: none; margin-bottom: 0; }
footer .nav-footer li a { color: var(--bro-beige); text-decoration: none; }
footer .mail { color: var(--bro-beige); text-decoration: none; }
footer .legal { margin-bottom: 10px;}
footer a { text-decoration: none; color: var(--bro-beige); }


#click-explosion {  position: fixed; top: 0; left: 0; pointer-events: none; z-index: 9999; mix-blend-mode:difference; }
.explode-bar { position: absolute; z-index: 100000; width: 8px; transform-origin: center center; border: solid 2px var(--bro-beige); opacity: 0; border-radius: 12px; mix-blend-mode:difference; pointer-events:none }


#cookie-banner { position: fixed; width: 100%; bottom: 20px; left: 0; padding: 0 20px; }
#cookie-banner .cookie-conteneur { background: var(--bro-black); color: var(--bro-beige); font-size: 12px; padding: 20px; border-radius: 8px; }

#cookie-banner .btn { margin: 0 8px 0 0 !important;     background: var(--bro-black);
  color: var(--bro-beige);
  margin: 0;
  line-height: 1;
  font-size: 12px;
  padding: 6px 8px;
  font-weight: 200;
  border: none;
  text-transform: uppercase;
  border-radius: 4px; }

  #cookie-banner .btn.btn-primary { background-color: var(--bro-beige); color: var(--bro-black); }

  .hidden { display: none !important; }





  /* CSS */
.drawer-overlay {
  position: fixed;
  inset: 0;
  background: rgba(0, 0, 0, 0.5);
  display: none;
  z-index: 10000;
}

.drawer {
  position: fixed;
  background: var(--bro-beige);
  z-index: 10001;
  display: flex;
  flex-direction: column;
  background: var(--bro-black);
  color: var(--bro-beige);
  transform: translateY(100%);
  visibility: hidden;
}

/* Variantes direction */
.drawer.bottom {
  left: 0;
  right: 0;
  bottom: 0;
  border-radius: 8px;
}
.drawer.top {
  top: 0;
  left: 0;
  right: 0;
  transform: translateY(-100%);
  border-radius: 8px;
}
.drawer.left {
  top: 0;
  bottom: 0;
  left: 0;
  transform: translateX(-100%);
  border-radius: 8px;
}
.drawer.right {
  top: 0;
  bottom: 0;
  right: 0;
  transform: translateX(100%);
  border-radius: 8px;
}

/* Inset (margin depuis les bords) */
.drawer.inset.bottom {
  left: 20px;
  right: 20px;
  bottom: 20px;
}
.drawer.inset.top {
  left: 20px;
  right: 20px;
  top: 20px;
}
.drawer.inset.left {
  top: 20px;
  bottom: 20px;
  left: 20px;
}
.drawer.inset.right {
  top: 20px;
  bottom: 20px;
  right: 20px;
}

.drawer-content {
  padding: 20px;
  flex: 1;
  display: flex;
  flex-direction: column;
}

.drawer-header h2 {
  font-size: 12px;
  text-transform: uppercase;
  line-height: 1;
  margin-bottom: 2px;
}

.drawer-header {
  border-bottom: solid 2px;
  padding-bottom: 4px;
}

.drawer .navbar-nav .nav-link { padding: 0 0 8px 0;  font-family: "Anton", sans-serif; font-size: 32px; line-height: 1; }

.drawer .navbar-nav .nav-link.is-active { color: #444; }

.drawer-header,
.drawer-footer {
  display: flex;
  justify-content: space-between;
  align-items: flex-end;
}
.drawer-body {
  flex: 1;
  margin: 16px 0;
  overflow-y: auto;
}
