

/* RÉGLAGES FONTS */

.rando .rando_text { font: var(--maru-mono-1);}

.rando .rando_title,
.template_home .rando_level { font: var(--maru-mono-2); }

#intro article,
.day_moments,
.day_name_number { font: var(--maru-mono-3); }

#intro button#scroll,
.unfilled_button { font: var(--maru-mono-4); }

.month_name *,
.day_number,
.rando .rando_code { font: var(--maru-mono-5); }

#map .rando_icon span { font: var(--maru-mono-6); }

.rando .rando_details { font: var(--neue_montreal_squeezed-1); }



/* RÉGLAGES TYPOS/COULEURS/BORDERS */

#intro {
  text-align: center;
}
.caption .day_moments,
.day_name_number { text-transform: uppercase; }

.rando .rando_code,
.rando .rando_title {
  font-weight: 900;
  font-style: italic;
}

.template_home .rando_level {
  font-style: italic;
}

/* bouton intro */
#intro button#scroll {
  color: var(--theme_color);
  border: 1px solid var(--theme_color);
  border-radius: 1.7rem;
  padding: .8rem 1.5rem;
  cursor: pointer; background: unset;
}
#intro button#scroll:hover {
  background-color: var(--theme_lightcolor);
}
.unfilled_button {
  text-decoration: none;
}
/* map */
#map .rando_icon span {
  color: var(--theme_color);
  border: 2px solid var(--theme_color);
  border-radius: 10px;
  background-color: var(--lightwhite);
  font-style: italic;
  font-weight: 600;
  text-transform: lowercase;
  display: block;
  width: fit-content;
  padding: 0px 3px;
}
#map .rando_icon span:first-letter {
  text-transform: uppercase;
}



/* LAYOUT */

#intro {
  position: sticky;
  top: 0px;
  z-index: 1;
  
  padding: 1rem;
  min-height: 100vh;
  display: grid;
  place-items: center;
}
#intro article {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 2rem;
}
#intro article p {
  max-width: 700px;
}
#intro article p:not(:last-child) {
  margin-bottom: 1rem;
}
#intro h1 span {
  display: block;
}

main {
  background-color: white;
  position: relative;
  z-index: 2;
}

#calendar {}
.month {
  min-height: calc(100vh - 150px);
  display: flex;
  flex-direction: column;
  gap: 1rem;
  padding: 1rem var(--padding-x);
  color: var(--grey);
}

.month_name {
  --theme_color: var(--grey);
  padding: 1rem;
  text-align: center;
  text-transform: uppercase;

  display: flex;
  justify-content: space-between;
}
.month_name button {
  background: unset;
  border: none;
  cursor: pointer;
  color: var(--grey);
}
.month_name button[disabled] {
  visibility: hidden;
  cursor: unset
}
.day {
  display: grid;
  grid-template-columns: 100px 1fr;
  gap: 1rem;
}
.day.caption .day_moments {
  grid-column-start: 2;
}


.day_name_number {
  --theme_color: var(--grey);
  padding: 1rem;
  display: grid;
  place-items: center;
  text-align: center;
}
.day_name_number .day_number {
  display: block;
}

.day_moments {
  display: grid;
  gap: 1rem;
  grid-template-columns: repeat(3, 1fr);
}

.day_moments .randos_list {
  display: grid;
  align-items: start;
  gap: 1rem;
}

.day.caption .day_moments > div {
  --theme_color: var(--grey);
  padding: 1rem;
  text-align: center;
}

.rando {
  position: relative;
  padding: calc(17rem/16);
  padding-top: calc(9rem/16);
  text-decoration: none;
}
.rando .rando_text {
  margin: calc(8rem/16) 0px;
  display: -webkit-box;
  -webkit-box-orient: vertical;
  overflow: hidden;
  -webkit-line-clamp: 2;
}
.rando:hover { background: var(--theme_lightcolor); }
/* cas soldout */
.rando.soldout:after {
  content: "complet";
  position: absolute;
  top: 1rem;
  right: 1rem;
  font: var(--maru-mono-2);
  font-style: italic;
  font-weight: 900;
  text-transform: uppercase;
  color: var(--theme_color);
  padding: 7px;
  border: 1px solid var(--theme_color);
  border-radius: var(--border-radius);
}



.rando_details {
  display: flex;
  /*justify-content: space-between;*/
  flex-wrap: wrap;
  gap: 1rem;
}
.rando_details * {
  flex: 1;
}
#calendar .rando_details .rando_price { display: none; }
#calendar .rando_image { display:none; }

/* responsive */
@media screen and (max-width: 1000px) {

.day {
  grid-template-rows: auto 1fr;
  grid-template-columns: 1fr;
  gap: 1rem;
}
.day.caption { grid-template-rows: auto; }
.day.caption .day_moments { grid-column-start: 1; }

}


@media screen and (min-width: 800px) {
  /* put month_name and day caption sticky*/
  .month_name{
    position:sticky;
    top:1rem;
    background-color:var(--white);
    z-index:999;
  }
  .day.caption{
    position:sticky;
    top:calc(82px + 2rem);
    z-index:999;
  }
  .day.caption .morning,
  .day.caption .afternoon,
  .day.caption .night {
    background-color:var(--white);
  }
}
@media screen and (max-width: 800px) {

.day.caption { display: none; }
.day_moments .empty { display:none; }
.day_moments {
  grid-template-columns: auto;
}
.day_moments > div {
  display: grid;
  gap: 1rem;
}

.day_moments .randos_list {
  --col_width: 260px;
  --col_gap: 1rem;
  --min_cols: 1;
  --max_cols: 2;
  display: grid;
  gap: var(--col_gap);
  grid-template-columns: repeat(auto-fill, minmax(min((100%/var(--min_cols) - var(--col_gap)*(var(--min_cols) - 1)/var(--min_cols)), max(var(--col_width), (100%/var(--max_cols) - var(--col_gap)*(var(--max_cols) - 1)/var(--max_cols)))), 1fr));
}


.day_moments > div:before {
  display: block;
  border: 1px solid;
  border-radius: calc(12rem/16);
  padding: 1rem;
  text-align: center;
  width: 100%;
}
.morning:before { content: "MATIN"; }
.afternoon:before { content: "APRÈS-MIDI"; }
.night:before { content: "CRÉPUSCULE"; }

}

.moment .rando_text * {
  font-weight: normal !important;
}


/* HIDE/SHOW MONTH */

.month:not(.visible) {
  display: none;
}


/* MAP */

body[data-view="calendar"] #calendar { display: grid; }
body[data-view="calendar"] #map_container { display: none; }
body[data-view="map"] #calendar { display: none; }
body[data-view="map"] #map_container { display: block; }

#map {
  height: calc(100vh - 200px);
  z-index: 0;
}
#map_container {
  position: relative;
  padding: 1rem var(--padding-x);
}
.template_home .rando_card {
  position: absolute;
  z-index: 1000;
  top: 1rem; left: var(--padding-x);
  background-color: white;
  max-width: 700px;
  margin-right: var(--padding-x);
}



/* FILTER CONTAINER */
#filter_container {
  display: flex;
  gap: 1rem;
}
body:not(.winter) #filter_container button:nth-child(n+4) { display: none; }
body.winter #filter_container button:nth-child(-n+3) { display: none; }

@media screen and (max-width: 800px) {
  #filter_container { display: none; }
}
#toggle_view_container {
  margin-left: auto;
}

/* FILTER */
.calendar_filter.active {
  color: var(--black);
}
#calendar.filtered .rando:not(.visible) {
  display: none;
}
/* TOGGLE VIEW */
#toggle_view_container {
  display: flex;
  gap: 1rem;
  justify-content: end;
}
#toggle_view_container input { display:none; }
#toggle_view_container label { cursor: pointer; }
body[data-view="calendar"] label[for="view_calendar"] {
  color: black;
  border: 1px solid black;
}
body[data-view="map"] label[for="view_map"] {
  color: black;
  border: 1px solid black;
}

.randos_for_map {
  display: none;
}

.close_rando_card {
  background: unset; border: 0;
  font: var(--maru-mono-6);
  font-style: italic;
  cursor: pointer;
  position: absolute;
  top: 0px;
  right: 1rem;
  color: var(--theme_color);
}
