drupal-caravane/web/themes/custom/caravane/assets/scss/main.scss

1385 lines
51 KiB
SCSS

@import 'fonts.scss';
$desktop-min-width: 992px;
$tablet-min-width: 467px;
$body-margin-x: 30px;
$body-margin-y: 5px;
$body-margin-bottom: 4vh;
$modale-x-padding: 5vw;
$modale-bottom-padding: 180px;
$modale-width-mobile: 90vw;
$modale-width-desktop: 50vw;
$brand-pattern-height: 110px;
$sm-font-size-mobile: 0.6rem;
$sm-font-size-desktop: 0.8rem;
$labeur-font-size-mobile: 0.9rem;
$labeur-font-size-desktop: 1rem;
$m-font-size-mobile: 1.1rem;
$m-font-size-desktop: 1.4rem;
$l-font-size-mobile: 1.3rem;
$l-font-size-desktop: 1.8rem;
$xl-font-size-mobile: 1.6rem;
$xl-font-size-desktop: 2.4rem;
$main-color: #1a1918;
$main-color-light: #635b58;
$light-color: #faf1eb;
$brand-color: #80c8bf;
$menu-mobile-width: 60vw;
$menu-desktop-width: 20vw;
$menu-margin: 2rem;
body{
font-family: 'Marianne', sans-serif;
color: $main-color;
margin: 0;
padding: 0;
overflow-y: scroll;
&.no-scroll {
overflow-y: hidden;
}
.layout-container {
> header {
z-index: 2;
transition: opacity 0.3s ease-in-out;
> div {
padding: $body-margin-y $body-margin-x 0 $body-margin-x;
display: grid;
grid-template-columns: repeat(16, 1fr);
> #block-caravane-logorepublique {
grid-column: 7 / span 3;
display: flex;
align-items: center;
@media screen and (min-width: $desktop-min-width) {
grid-column: 1 / span 1;
}
> div > div > a > img {
width: 100%;
height: auto;
}
}
> #block-caravane-logoepau {
grid-column: 10 / span 6;
display: flex;
align-items: center;
padding-right: 2.5rem;
@media screen and (min-width: $desktop-min-width) {
grid-column: 2 / span 2;
}
> div > div > a > img {
width: 100%;
height: auto;
}
}
> #block-caravane-logocaravane {
grid-column: 1 / span 5;
grid-row: 1;
padding-top: 0.5rem;
display: flex;
align-items: center;
@media screen and (min-width: $desktop-min-width) {
grid-column: 8 / span 2;
}
> div > div > a > img {
width: 100%;
height: auto;
}
}
> #block-caravane-mainnavigation {
display: flex;
justify-content: flex-end;
grid-column: 16 / span 1;
width: 10vw;
margin-top: 1.8vh;
position: fixed;
right: $body-margin-x;
> #menu-title {
display: flex;
z-index: 2;
background-color: $brand-color;
position: fixed;
width: $menu-mobile-width;
right: 0;
top: 0;
padding-top: 2.8vh;
margin-right: $body-margin-x;
padding-bottom: 10px;
max-height: 0vh;
overflow: hidden;
height: 5vh;
transition: max-height 0.3s ease-out, opacity 0.2s ease-out;
opacity: 0;
align-items: center;
@media screen and (min-width: $desktop-min-width) {
width: $menu-desktop-width;
}
> p {
padding-left: $menu-margin;
margin: 10px 0;
color: white;
font-size: 2rem;
font-family: 'Joost', sans-serif;
font-weight: bold;
@media screen and (min-width: $desktop-min-width) {
font-size: $l-font-size-desktop;
}
}
}
> #menu-title.open {
opacity: 1;
max-height: 5vh;
}
> #menu {
display: flex;
align-items: center;
justify-content: center;
flex-direction: column;
cursor: pointer;
> h2 {
z-index: 2;
margin-block: 0;
font-size: $sm-font-size-mobile;
color: $main-color-light;
font-weight: normal;
margin-bottom: 5px;
@media screen and (min-width: $desktop-min-width) {
font-size: $sm-font-size-desktop;
}
}
> h2 {
display: none;
}
> #hamburger {
position: fixed;
height: 5vh;
right: 0;
top: 0;
margin-right: $body-margin-x;
padding-top: 2.8vh;
padding-bottom: 10px;
z-index: 2;
display: flex;
flex-direction: column;
justify-content: center;
align-items: center;
width: 2.4rem;
transition: transform 0.3s ease-out, opacity 0.3s ease-out;
> div {
width: 100%;
height: 3px;
margin: 4px 0;
border-radius: 2px;
background-color: white;
opacity: 1;
transition: transform 0.5s, opacity 0.2s;
margin-right: 3vw;
@media screen and (min-width: $desktop-min-width) {
margin-right: 0;
background-color: $main-color-light;
}
}
}
> #hamburger:hover {
transform: scale(1.1);
}
> #hamburger.open {
transform: scale(0.7) translateX(-20px);
> div {
background-color: white;
}
> div:first-of-type {
transform: rotate(45deg);
margin-top: 50%;
}
> div:last-of-type {
transform: rotate(-45deg);
margin-top: -50%;
}
> div:nth-child(2) {
opacity: 0;
}
}
> #hamburger.open:hover {
transform: scale(0.75) translateX(-20px);
}
> ul {
list-style-type: none;
background-color: white;
position: fixed;
width: $menu-mobile-width;
right: $body-margin-x;
padding: 0;
padding-top: 2rem;
padding-bottom: 1.5rem;
top: -5vh;
opacity: 0;
transition: top 0.3s ease-out, opacity 0.2s ease-out;
z-index: 1;
font-size: $m-font-size-mobile;
@media screen and (min-width: $desktop-min-width) {
width: $menu-desktop-width;
}
> li {
padding-left: $menu-margin;
margin: 15px 0;
> a {
color: $main-color;
text-decoration: none;
}
> a.is-active::before,
> a:hover::before {
content: '';
color: $brand-color;
width: 2rem;
display: inline-block;
opacity: 1;
}
> a::before {
content: '';
color: $brand-color;
opacity: 0;
display: inline-block;
width: 0rem;
transition: width 0.2s ease-out, opacity 0.2s ease-out;
}
}
}
> ul.open {
opacity: 1;
top: 6vh;
}
}
}
}
}
> main {
z-index: 1;
position: absolute;
top: 0;
left: 0;
width: 100%;
height: 100vh;
> .layout-content {
z-index: 1;
top: 0;
width: 100%;
height: 100%;
> div {
height: 100%;
> .layout {
display: grid;
grid-template-columns: repeat(16,1fr);
align-items: center;
height: 100%;
width: 100%;
> .layout__region--first {
display: none;
padding-left: $body-margin-x;
grid-column: 1 / span 4;
position: relative;
z-index: 2;
pointer-events: none;
width: fit-content;
> div {
pointer-events: auto;
}
}
> .layout__region--second {
position: fixed;
z-index: 1;
top: 0;
width: 100vw;
.leaflet-container {
background-color: $main-color-light;
.leaflet-popup {
display: none;
}
// add map style here
.leaflet-control-zoom {
border: none;
margin: 0;
left: $body-margin-x;
bottom: $body-margin-bottom;
> a {
display: flex;
justify-content: center;
align-items: center;
font-size: $m-font-size-mobile;
font-family: 'marianne', sans-serif;
font-weight: lighter;
width: 4vh;
height: 4vh;
@media screen and (min-width: $desktop-min-width) {
font-size: $m-font-size-desktop;
}
}
> a:first-of-type {
border-top-left-radius: 2vh;
border-top-right-radius: 2vh;
}
> a:last-of-type {
border-bottom-left-radius: 2vh;
border-bottom-right-radius: 2vh;
> span {
padding-bottom: 10px;
}
}
}
.leaflet-right {
right: unset;
left: 0;
}
.leaflet-map-divicon {
width: 10px;
height: 30px;
display: flex;
flex-direction: column;
justify-content: center;
align-items: center;
transition: transform 0.3s ease-out;
> div {
background-color: red;
display: block;
width: 20px;
height: 10px;
}
> div:first-of-type {
height: 8px;
clip-path: polygon(0 0, 100% 0, 50% 100%);
transform: rotate(180deg);
}
> div:nth-of-type(3) {
height: 8px;
clip-path: polygon(0 0, 100% 0, 50% 100%);
}
}
}
.leaflet-tooltip-pane {
width: 75vw;
pointer-events: none;
@media screen and (min-width: $tablet-min-width) {
width: 40vw;
}
@media screen and (min-width: $desktop-min-width) {
width: 25vw;
}
> div {
padding: 0;
border-radius: none;
box-shadow: none;
opacity: 1 !important;
border-radius: 0 !important;
background-color: transparent;
border: none;
width: 100%;
> div {
max-height: 15vh;
overflow: hidden;
display: grid;
grid-template-columns: minmax(10px, 12.5vw) 12.5vw;
grid-template-rows: 1.5fr 0.5fr;
transform: translateY(-60%);
background-color: white;
opacity: 0;
transition: opacity 0.3s ease-out;
> div:first-of-type {
grid-column: 1 / span 1;
grid-row: 1 / span 1;
font-family: 'Joost', sans-serif;
font-size: $m-font-size-mobile;
/* display: flex;
flex-direction: column;
justify-content: center;
align-items: center;
*/
padding-top: 10px;
padding-left: 20px;
padding-right: 20px;
text-wrap: wrap;
@media screen and (min-width: $desktop-min-width) {
font-size: $m-font-size-desktop;
}
> a {
display: inline-block;
text-align: center;
font-weight: bold;
text-decoration: none;
color: $main-color;
> span {
font-weight: lighter;
}
}
}
> div:nth-of-type(2) {
grid-column: 1 / span 1;
grid-row: 2 / span 1;
text-align: center;
padding: 10px 0;
> time {
font-size: $sm-font-size-mobile;
font-family: 'Marianne', sans-serif;
font-weight: lighter;
@media screen and (min-width: $desktop-min-width) {
font-size: $sm-font-size-desktop;
}
}
}
> div:nth-of-type(3) {
width: 100%;
height: 100%;
display: block;
padding: 0;
grid-column: 2 / span 1;
grid-row: 1 / span 2;
overflow: hidden;
> a {
display: block;
width: 100%;
height: 100%;
padding: 0;
> img {
padding: 0;
height: 100%;
width: auto;
object-fit: cover;
margin: 0;
display: block;
}
}
}
}
}
}
/* .leaflet-tooltip-center {
width: 20vw;
padding: 0;
border-radius: none;
box-shadow: none;
opacity: 1 !important;
border-radius: 0 !important;
background-color: transparent;
border: none;
pointer-events: none;
> div {
display: grid;
grid-template-columns: minmax(10px, 10vw) 10vw;
grid-template-rows: 1.5fr 0.5fr;
transform: translateY(-60%);
background-color: white;
background-color: red;
opacity: 0;
transition: opacity 0.3s ease-out;
> div:first-of-type {
grid-column: 1 / span 1;
grid-row: 1 / span 1;
font-family: 'Joost', sans-serif;
font-size: $m-font-size-mobile;
display: flex;
flex-direction: column;
justify-content: center;
align-items: center;
padding-top: 10px;
padding-left: 20px;
padding-right: 20px;
text-wrap: wrap;
@media screen and (min-width: $desktop-min-width) {
font-size: $m-font-size-desktop;
}
> a {
font-weight: bold;
text-decoration: none;
color: $main-color;
padding-right: 10px;
}
}
> div:nth-of-type(2) {
grid-column: 1 / span 1;
grid-row: 2 / span 1;
text-align: center;
padding: 10px 0;
> time {
font-size: $sm-font-size-mobile;
font-family: 'Marianne', sans-serif;
font-weight: lighter;
@media screen and (min-width: $desktop-min-width) {
font-size: $sm-font-size-desktop;
}
}
}
> a {
display: block;
grid-column: 2 / span 1;
grid-row: 1 / span 2;
overflow: hidden;
width: 100%;
height: 100%;
padding: 0;
> div {
width: 100%;
display: block;
padding: 0;
background-color: blue;
max-height: 0;
> img {
padding: 0;
width: 100%;
height: auto;
object-fit: cover;
margin: 0;
display: block;
}
}
}
}
}*/
}
> .layout__region--third {
height: 100%;
padding-right: $body-margin-x;
// grid-column: 4 / span 13;
position: fixed;
top: 0;
right: 0;
z-index: 4;
display: flex;
background: linear-gradient(to right, #faf1ebaa, #faf1eb);
align-items: center;
justify-content: flex-end;
pointer-events: none;
max-width: 100%;
transition: all 0.3s ease-out;
justify-self: flex-end;
align-self: flex-end;
&.retracted {
max-width: 25%;
// grid-column: 16 / span 1;
}
&.liste-etapes-scrollable {
align-items: start;
}
@media screen and (min-width: $desktop-min-width) {
background: linear-gradient(to right, transparent, #faf1eb);
grid-column: 11 / span 6;
}
> div #etapes-liste {
pointer-events: auto;
padding-right: 0.5rem;
padding-left: $body-margin-x;
box-sizing: border-box;
width: 100%;
overflow: hidden;
opacity: 1;
display: block;
transition: all 0.3s ease-out;
@media screen and (min-width: $desktop-min-width) {
max-width: 30vw;
}
&.retracted {
opacity: 0;
}
&.disapeared {
display: none;
}
&.scrollable {
overflow-y: scroll;
mask-image: linear-gradient(
to bottom,
transparent 0%,
black 7%,
black 85%,
transparent 100%
);
ul {
// padding-top: 0.5rem;
padding-bottom: 1rem;
}
}
ul {
list-style: none;
> li {
display: flex;
justify-content: end;
align-items: center;
margin: 30px 0;
transform: scale(1);
opacity: 1;
padding-right: 0.5rem;
transition: transform 0.3s ease-out, opacity 0.3s ease-out;
cursor: pointer;
> .infos-arret {
display: grid;
grid-template-columns: auto auto;
grid-template-rows: auto auto;
justify-content: end;
margin-right: 20px;
p {
margin: 0;
}
> .views-field-nid {
display: none;
}
> .views-field-title {
grid-column: 1 / span 1;
grid-row: 1 / span 1;
margin-right: 10px;
a {
text-decoration: none;
color: $main-color;
font-family: 'Joost', sans-serif;
font-weight: bold;
font-size: $m-font-size-mobile;
display: inline-block;
text-align: right;
@media screen and (min-width: $desktop-min-width) {
font-size: $m-font-size-desktop;
}
}
}
> .views-field-field-adresse-postal-code {
grid-column: 2 / span 1;
grid-row: 1 / span 1;
color: $main-color;
font-family: 'Joost', sans-serif;
font-weight: lighter;
font-size: $m-font-size-mobile;
align-self: center;
@media screen and (min-width: $desktop-min-width) {
font-size: $m-font-size-desktop;
}
> span {
> p::before {
content: '(';
}
> p::after {
content: ')';
}
}
}
> .views-field-field-dates {
grid-column: 1 / span 2;
grid-row: 2 / span 1;
font-size: $sm-font-size-mobile;
font-family: 'Marianne', sans-serif;
font-weight: lighter;
text-align: right;
margin-top: 7px;
@media screen and (min-width: $desktop-min-width) {
font-size: $sm-font-size-desktop;
}
}
> .views-field-field-couleur {
display: none;
}
}
> .icone-arret {
width: 10px;
height: 30px;
display: flex;
flex-direction: column;
justify-content: center;
align-items: center;
> div {
display: block;
width: 20px;
height: 10px;
&:first-of-type, &:last-of-type {
height: 8px;
clip-path: polygon(0 0, 100% 0, 50% 100%);
}
&:first-of-type {
transform: rotate(180deg);
}
}
}
}
> li:hover {
transform: scale(1.05);
}
> li.inactive {
opacity: 0.6;
}
}
}
#retractable-message {
cursor: pointer;
pointer-events: auto;
color: $light-color;
position: fixed;
top: 50%;
text-wrap: nowrap;
right: calc(100vw - 5rem);
display: flex;
flex-direction: column;
align-items: center;
transform: rotate(90deg) scale(1);
transition: all 0.3s ease-out;
&:hover {
transform: rotate(90deg) scale(1.05);
}
&.retracted {
right: 0vw;
// right: -3vw;
> div {
transform: rotate(0deg);
}
}
@media screen and (min-width: $desktop-min-width) {
display: none;
}
> p {
background-color: $main-color;
padding: 0.5rem 1rem;
border-radius: 1.3rem;
margin: 0;
margin-bottom: 0.2rem;
font-size: $sm-font-size-mobile;
text-wrap: nowrap;
white-space: nowrap;
@media screen and (min-width: $desktop-min-width) {
font-size: $sm-font-size-desktop;
}
}
> div {
width: 20px;
height: 20px;
background-color: $main-color;
mask: url('/themes/custom/caravane/assets/pictograms/chevron-down.svg') no-repeat center;
mask-size: contain;
transform: rotate(180deg);
transition: transform 0.3s ease-out;
}
}
.transparent-gradient {
position:absolute;
z-index:2;
right:0; bottom:0; left:0;
height:200px;
background: linear-gradient(to bottom, rgba(255,255,255,0) 0%,rgba(255,255,255,1) 70%);
}
}
> #content-modale {
padding-bottom: 20vh;
@media screen and (min-width: $desktop-min-width) {
z-index: 6;
}
> div:not(.image-viewer-wrapper, .image-modale) {
padding-bottom: 5vh;
> .content-wrapper {
left: 1.5vw;
width: calc($modale-width-mobile);
top: 15vh;
z-index: 2;
position: relative;
background-color: white;
font-size: $labeur-font-size-mobile;
//padding-bottom: $modale-bottom-padding;
@media screen and (min-width: $desktop-min-width) {
font-size: $labeur-font-size-desktop;
width: $modale-width-desktop;
}
img {
width: 100%;
height: auto;
object-fit: cover;
}
> div {
width: 100%;
overflow: hidden;
}
> header {
margin-bottom: 2rem;
display: grid;
grid-template-rows: auto auto auto auto;
> .cover {
grid-row: 1 / span 1;
max-height: 60vh;
display: flex;
justify-content: center;
overflow: hidden;
position: relative;
z-index: 0;
}
> .cartouche {
font-size: $labeur-font-size-mobile;
grid-row: 4 / span 1;
position: relative;
padding: 1rem 1.5rem;
z-index: 2;
top: 0;
background-color: $brand-color;
z-index: 1;
@media screen and (min-width: $desktop-min-width) {
font-size: $labeur-font-size-desktop;
top: 2rem;
position: absolute;
}
> p {
margin-block-start: 0;
margin-block-end: 0;
}
> p:last-of-type {
font-weight: bold;
}
}
> .locality-wrapper {
position: relative;
> .locality {
position: absolute;
bottom: 0;
> .top-triangle {
display: block;
width: calc($modale-width-mobile - $modale-x-padding * 3);
margin-left: $modale-x-padding * 1.5;
height: 100px;
display: flex;
clip-path: polygon(-1% 100%, 50% 0, 101% 100%);
background-color: white;
margin-bottom: -1px;
@media screen and (min-width: $tablet-min-width) {
width: calc($modale-width-mobile - $modale-x-padding * 6);
margin-left: $modale-x-padding * 3;
}
@media screen and (min-width: $desktop-min-width) {
width: calc($modale-width-desktop - $modale-x-padding * 4);
margin-left: $modale-x-padding * 2;
}
}
> .locality-title {
display: block;
box-sizing: border-box;
width: calc($modale-width-mobile - $modale-x-padding * 3);
top: 99px;
margin-left: $modale-x-padding * 1.5;
min-height: 115px;
background-color: white;
padding: 1rem 2rem;
display: flex;
align-items: center;
text-align: center;
@media screen and (min-width: $tablet-min-width) {
width: calc($modale-width-mobile - $modale-x-padding * 6);
margin-left: $modale-x-padding * 3;
}
@media screen and (min-width: $desktop-min-width) {
width: calc($modale-width-desktop - $modale-x-padding * 4);
margin-left: $modale-x-padding * 2;
}
> h1 {
width: 100%;
text-align: center;
display: block;
font-size: $xl-font-size-mobile;
margin-block-start: 0;
margin-block-end: 0;
font-family: 'Joost', sans-serif;
text-align: center;
@media screen and (min-width: $desktop-min-width) {
font-size: $xl-font-size-desktop;
}
> em {
font-style: normal;
font-weight: lighter;
}
}
}
}
.brand-pattern {
grid-row: 3 / span 1;
display: block;
width: 100%;
height: $brand-pattern-height;
> .pattern {
display: block;
width: 100%;
height: 100%;
background-image: url(/themes/custom/caravane/assets/imgs/motif-caravane-invert-tile.png);
background-size: 300px;
background-size: repeat;
}
}
}
&.not-etape {
> .locality-wrapper {
> .locality {
max-height: $brand-pattern-height;
}
}
}
}
> main {
width: 100%;
padding: 0 $modale-x-padding;
padding-bottom: 5vh;
box-sizing: border-box;
> .partie,
> #equipe {
width: 100%;
display: inline-block;
> .sensible-map {
margin: 0;
width: calc(100% + $modale-x-padding);
margin-left: calc(($modale-x-padding / 2) * -1);
margin-top: calc($modale-x-padding / 2);
.vh--message {
font-size: $sm-font-size-mobile;
top: 1rem;
left: 1rem;
bottom: unset;
background-color: rgba(255, 255, 255, 0.6);
color: $main-color-light;
@media screen and (min-width: $desktop-min-width) {
font-size: $sm-font-size-desktop;
}
}
> figcaption {
margin-left: calc($modale-x-padding / 2);
}
}
.partie-title,
> .chiffres-cles,
> .entretien {
> h3 {
position: relative;
display: inline-block;
> p {
display: inline;
font-size: $l-font-size-mobile;
font-family: 'Joost', sans-serif;
margin: 0;
z-index: 1;
position: relative;
padding: 0 0.5rem;
@media screen and (min-width: $desktop-min-width) {
font-size: $l-font-size-desktop;
}
}
}
.personne {
display: flex;
flex-direction: column;
align-items: center;
margin: 2rem 0;
width: 100%;
@media screen and (min-width: $desktop-min-width) {
flex-direction: row;
}
&:first-of-type {
margin-top: 1rem;
}
> figure {
width: 6rem;
height: 6rem;
margin: 0;
display: flex;
justify-content: center;
align-items: center;
overflow: hidden;
border-radius: 3rem;
> img {
object-fit: cover;
width: 100%;
height: 100%;
}
}
> .description {
width: 100%;
margin-top: 1rem;
@media screen and (min-width: $desktop-min-width) {
width: calc(100% - 6rem);
margin-top: 0;
}
> p {
margin: 0;
padding-left: 2rem;
}
}
}
.questions-reponses {
margin-top: 3rem;
> div {
> .question {
font-weight: bold;
position: relative;
padding-left: 1.8rem;
margin-top: 2rem;
margin-bottom: 1rem;
&::before {
position: absolute;
content: "";
display: block;
height: 100%;
width: 0.8rem;
left: 0;
margin-right: 1rem;
}
}
}
}
}
> .chiffres-cles {
> div {
display: grid;
gap: 2rem;
grid-template-columns: 1fr 1fr;
align-content: flex-start;
margin: 2rem 0;
@media screen and (min-width: $desktop-min-width) {
grid-template-columns: 1fr 1fr 1fr;
}
> div {
display: flex;
flex-direction: column;
align-items: flex-start;
justify-content: flex-start;
> .chiffre {
padding-left: 1rem;
font-size: $xl-font-size-mobile;
font-weight: bold;
font-family: 'Joost', sans-serif;
margin: 0;
@media screen and (min-width: $desktop-min-width) {
font-size: $xl-font-size-desktop;
}
> p {
margin: 0;
}
}
> .chiffre-caption {
padding-left: 1rem;
font-size: $sm-font-size-mobile;
margin: 0;
@media screen and (min-width: $desktop-min-width) {
font-size: $sm-font-size-desktop;
}
}
}
}
}
> .diaporama {
width: calc(100% + 2 * #{$modale-x-padding});
margin-top: 5rem;
margin-bottom: 3rem;
margin-left: -$modale-x-padding;
figure {
margin: 0 calc(#{$modale-x-padding} / 2);
> img {
width: 100%;
}
> figcaption {
line-height: 1.5;
padding-bottom: 2rem;
}
}
}
> .videos iframe {
margin: 2rem 0;
}
}
.caption {
font-size: $sm-font-size-mobile;
color: $main-color-light;
margin-top: 0.2rem;
margin-bottom: 1.8rem;
@media screen and (min-width: $desktop-min-width) {
font-size: $sm-font-size-desktop;
}
}
> #equipe,
> #partenaires {
margin-top: 3vh;
> div.intro {
margin-bottom: 6vh;
@media screen and (min-width: $desktop-min-width) {
}
}
> div.equipe-item {
@media screen and (min-width: $desktop-min-width) {
margin-bottom: 7vh;
}
> .partie-title {
margin-bottom: 3vh;
}
}
> div.equipe-item > div.personne,
> div.partenaire {
display: grid;
grid-template-columns: 0.4fr 1fr;
column-gap: 3rem;
grid-template-rows: auto;
justify-items: start;
margin-bottom: 6vh;
> figure {
grid-column: 1;
grid-row: 1 / span 2;
width: 100%;
margin: 0;
align-self: center;
> img {
aspect-ratio: 1 / 1;
border-radius: 50%;
}
}
> .name,
> .title {
align-self: flex-end;
margin-bottom: 1.3rem;
font-size: $m-font-size-mobile;
@media screen and (min-width: $desktop-min-width) {
font-size: $m-font-size-desktop;
}
> p {
margin: 0;
}
}
> .description {
> p {
margin: 0;
}
}
}
}
#partenaires {
> .partenaire {
> figure {
display: flex;
align-items: center;
> img {
aspect-ratio: unset !important;
border-radius: unset !important;
}
}
}
@media screen and (min-width: $desktop-min-width) {
margin-top: 10vh;
}
}
}
> footer {
.pattern-bottom {
mask-image: linear-gradient(to top, rgba(0,0,0,1), rgba(0,0,0,0));
height: $modale-bottom-padding;
position: absolute;
bottom: 0;
}
.related-etape-links {
position: absolute;
//bottom: calc(($modale-bottom-padding / 2) * -1);
width: 100%;
box-sizing: border-box;
padding: 0 calc($modale-x-padding / 2);
display: grid;
grid-template-rows: 1fr 1fr;
grid-template-columns: 1fr;
@media screen and (min-width: $desktop-min-width) {
grid-template-columns: 1fr 1fr;
margin-top: 2.5rem;
align-items: flex-start;
}
> .card {
width: 80%;
display: flex;
align-items: center;
cursor: pointer;
transition: transform 0.3s ease-out;
justify-self: center;
&:hover {
transform: scale(1.05);
}
&.previous {
grid-column: 1 / span 1;
@media screen and (min-width: $desktop-min-width) {
justify-self: flex-start;
}
}
&:last-of-type {
margin-bottom: 2rem;
}
&.next {
//margin-top: 2rem;
grid-column: 1 / span 2;
@media screen and (min-width: $desktop-min-width) {
grid-column: 2 / span 1;
margin-top: 0;
justify-self: flex-end;
}
}
> .icon {
z-index: 2;
width: 10px;
height: 30px;
display: flex;
flex-direction: column;
justify-content: center;
align-items: center;
> div {
display: block;
width: 20px;
height: 10px;
&:first-of-type, &:last-of-type {
height: 8px;
clip-path: polygon(0 0, 100% 0, 50% 100%);
}
&:first-of-type {
transform: rotate(180deg);
}
}
}
> .card-content {
z-index: 1;
background-color: white;
display: flex;
width: 100%;
> .infos {
width: 60%;
text-align: center;
> .titre {
padding: 1rem 0.5rem;
font-weight: bold;
font-family: 'Joost', sans-serif;
font-size: $m-font-size-mobile;
@media screen and (min-width: $desktop-min-width) {
font-size: $m-font-size-desktop;
}
> span {
font-weight: lighter;
}
}
> .date {
font-size: $sm-font-size-mobile;
font-family: 'Marianne', sans-serif;
font-weight: lighter;
padding-bottom: 1rem;
@media screen and (min-width: $desktop-min-width) {
font-size: $sm-font-size-desktop;
}
}
}
> .vignette {
width: 40%;
position: relative;
> img {
top: 0;
position: absolute;
width: 100%;
height: 100%;
object-fit: cover;
}
}
}
}
}
}
}
}
}
> #animation-toggle {
transition: opacity 0.3s ease-out;
@media screen and (min-width: $desktop-min-width) {
z-index: 5;
}
&.hidden {
opacity: 0;
}
> div {
cursor: pointer;
position: fixed;
bottom: $body-margin-bottom;
right: $body-margin-x;
z-index: 999;
display: flex;
align-items: center;
padding: 0.1rem 1.2rem;
border-radius: 10rem;
background-color: white;
transition: background-color 0.3s ease-out;
> div {
margin-right: 1rem;
> p {
font-size: $sm-font-size-mobile;
@media screen and (min-width: $desktop-min-width) {
font-size: $sm-font-size-desktop;
}
}
}
> .switch {
position: relative;
display: inline-block;
width: 2.2rem;
height: 1.2rem;
> input {
opacity: 0;
width: 0;
height: 0;
&:checked + .slider {
background-color: $brand-color;
}
&:focus + .slider {
box-shadow: 0 0 1px $brand-color;
}
&:checked + .slider::before {
-webkit-transform: translateX(1rem);
-ms-transform: translateX(1rem);
transform: translateX(1rem);
}
}
> .slider {
position: absolute;
cursor: pointer;
top: 0;
left: 0;
right: 0;
bottom: 0;
border-radius: 34px;
background-color: $main-color-light;
-webkit-transition: .4s;
transition: .4s;
&::before {
position: absolute;
content: "";
height: 1rem;
width: 1rem;
border-radius: 50%;
left: 0.1rem;
bottom: 0.1rem;
background-color: $light-color;
-webkit-transition: .4s;
transition: .4s;
}
}
}
}
}
}
> .user-login-form {
height: 90vh;
display: flex;
flex-direction: column;
align-items: center;
justify-content: center;
> div {
margin: 20px 0;
}
}
}
}
}
}
}