/* couleurs */
:root {
  --downloadButtonBg: #e6fffc;
  --downloadButtonBorder: #0083ab;
  --downloadButtonHover: #d0f7f4;
  --controlButtonBg: #b0eac2;
  --controlButtonBorder: #8ec09e;
  --controlButtonHover: #a0d8b0;
  --deleteButtonBg: #eab0b0;
  --deleteButtonBorder: #6e0000;
  --deleteButtonHover: #d3a0a0;
}

body, main {
  font-family: 'Segoe UI', Tahoma, Geneva, Verdana, sans-serif;
  max-width: 1200px;
  margin: 0 auto;
  padding: 20px;
  width: 80%;
  display: flex;
  flex-direction: column;
  scroll-behavior: smooth;
}
/* --------------- Select ALl --------------- */
#selectAll {
  display: none;
  background-color: var(--controlButtonBg);
  color: #003811;
  border: none;
  padding: 10px 20px;
  text-align: center;
  text-decoration: none;
  font-size: 16px;
  margin: 10px 2px;
  cursor: pointer;
  border-radius: 4px;
  transition: background-color 0.3s, transform 0.3s;
}

#selectAll:hover {
  background-color: var(--controlButtonHover);
  transform: scale(1.05);
}
/* --------------- Form & Artwork --------------- */
form {
  display: flex;
  flex-direction: column;
  gap: 20px;
  padding: 20px;
  background-color: #f9f9f9;
  border-radius: 10px;
  box-shadow: 0 4px 8px rgba(0, 0, 0, 0.1);
}
.artwork-container{
  display: flex;
  align-items: baseline;
}
.artwork-container input[type="checkbox"] {
  width: 20px;
  height: 20px;
  cursor: pointer;
  accent-color: #4CAF50; /* Change the color of the checkbox */
  margin-right: 10px;
  border: 2px solid #4CAF50;
  border-radius: 4px;
  transition: background-color 0.3s, border-color 0.3s;
}

.artwork-container input[type="checkbox"]:checked {
  background-color: #4CAF50;
  border-color: #4CAF50;
}

.artwork-form {
  padding: 15px;
  border: 1px solid #ddd;
  border-radius: 8px;
  background-color: #fff;
  position: relative;
  width: 100%;
}
.artwork-form .verify-artwork {
  position: absolute;
  top: 0;
  right: 0;
}


.artwork-form summary {
  font-size: 18px;
  font-weight: bold;
  cursor: pointer;
  position: relative;
}
.artwork-form summary p{
  margin: 0;
}
.artwork-form summary::after {
  content: '\25BC'; /* Down arrow */
  position: absolute;
  right: 10px;
  margin-left: 10px;
  transition: transform 0.3s ease;
}

.artwork-form[open] summary::after {
  transform: rotate(180deg); /* Rotate arrow */
}

.artwork-form label {
  display: block;
  margin-bottom: 5px;
  font-weight: 600;
}
.artwork-form label:first-of-type{
  margin-top: 15px;
}

.artwork-form input[type="text"],
.artwork-form input[type="number"],
.artwork-form textarea {
  width: 100%;
  padding: 10px;
  margin-bottom: 10px;
  border: 1px solid #ccc;
  border-radius: 5px;
  box-sizing: border-box;
}

.artwork-form textarea {
  resize: vertical;
}
.selected {
  background-color: #e0ffe0 !important;
}

/* --------------- Artworks Questions --------------- */
.artwork-form .questions-form {
  display: flex;
  flex-direction: column;
  gap: 10px;
}

.artwork-form .questions-form label {
  display: flex;
  align-items: center;
}

.artwork-form .questions-form input[type="checkbox"] {
  margin-right: 10px;
}
.artwork-form .answers{
  display: flex;
  flex-direction: column;
}
.artwork-form .answers label {
  display: flex;
  align-items: center;
  justify-content: center;
}

.artwork-form .answers input[type="radio"] {
  margin-right: 10px;
  margin-bottom: 10px;
}
.artwork-form .questions-form .answers p{
  width: 15%;
  margin-left: auto;

}
.artwork-form .questions-form .answers input[type="text"] {
  display: flex;
  width: 70%;
}
.artwork-form .questions-form .answers input[type="radio"] {
  margin-left: auto;
  margin-right: auto;
}

/* --------------- Artworks Buttons --------------- */
.artwork-form summary {
  display: flex;
  background-color: #f8f9fa;
  border: 1px solid #dee2e6;
  border-radius: 4px;
  padding: 10px;
  font-weight: bold; /
  cursor: pointer;
  position: sticky;
  top: 10px;
  z-index: 1;
  box-shadow: 0 2px 4px rgba(0, 0, 0, 0.1);
  background-clip: padding-box;
}
.artwork-form .question-block{
  display: flex;
  flex-direction: column;
  background-color: #e7e7e7;
  padding: 1em;
  border-radius: 7px;
}
.artwork-form  button {
  margin-top: 10px;
  padding: 10px 20px;
  background-color: var(--controlButtonBg);
  border: none;
  border-radius: 5px;
  cursor: pointer;
  transition: background-color 0.3s;
}
.artwork-form  button:hover {
  background-color: var(--controlButtonHover);
}
.artwork-form  .delete-question{
  background-color: var(--deleteButtonBg);
  align-self: end;
}

.artwork-form  .delete-question:hover, .artwork-form .delete-artwork:hover {
  background-color: var(--deleteButtonHover);
}
.artwork-form .delete-artwork{
  position: absolute;
  top: 15%;
  bottom: 15%;
  right: -90px;
  margin: 0;
  z-index: 5;
  padding: 7px 15px;
  background-color: #ff7c7c;
  border: 1px solid #b30000;
  font-size: 1.7em;
  display: flex;
  align-items: center;
  justify-content: center;
  color: #fff;
  border-radius: 5px;
  transition: background-color 0.3s, transform 0.3s;
}

.artwork-form .delete-artwork:hover {
  background-color: #ff1c1c;
}

#addArtwork{
  display: flex;
  flex-direction: column;
  align-items: center;
  margin-top: 20px;
  padding: 10px;
  border: 1px solid #ddd;
  border-radius: 8px;
  background-color: #fff;
  font-size: 1.2em;
  cursor: pointer;
}
#addArtwork:hover{
  background-color: #e7e7e7;
  transition: background-color 0.3s;
}
#addArtwork span{
  font-size: 1.2em;
  font-weight: 600;
}


#storySegment {
  margin-top: 20px;
  padding: 10px;
  border: 1px solid #ddd;
}

#questionSection {
  margin-top: 20px;
}

.hidden {
  opacity: 0;
  z-index: -1 !important;
}
.zIndexPopup {
  z-index: 9999 !important;
}

.disabled{
  background-color: #d3d3d3 !important;
  border: 1px solid #9d9d9d !important;
}
/* --------------- Controls --------------- */
#controls {
  display: flex;
  justify-content: space-between;
  margin-bottom: 1em;
  padding: 1em;
  background-color: #f0f0f0;
  border: 1px solid #ccc;
  border-radius: 8px;
  gap: 1em;
}

/* --------------- Controls Left --------------- */
#controls #left {
  background-color: #e6f7ff;
  border: 1px solid #b3d7ff;
  display: flex;
  flex-direction: column;
  border-radius: 8px;
  padding: 1em;
  flex: 1;
}

#uploadDiv {
  display: flex;
  align-items: center;
  justify-content: center;
  margin-top: 1em;
}

#uploadDiv p {
  margin-left: 1em;
  margin-right: 1em;
  font-size: 0.9em;
}

#uploadDiv input {
  width: 50%;
}

#downloads, #creerOeuvresDiv {
  display: flex;
  flex-direction: column;
  gap: 0.5em;
  padding: 1em;
  border-radius: 5px;
}

#downloads button, #exports button {
  background-color: var(--downloadButtonBg);
  border: 1px solid var(--downloadButtonBorder);
  padding: 0.5em;
  border-radius: 5px;
  cursor: pointer;
  transition: background-color 0.3s;
  width: 100%;
  text-align: center;
  display: flex;
  align-items: center;
  justify-content: center;
}
#downloads button svg, #exports button svg {
  margin-right: 0.5em;
}
#downloads button:hover, #exports button:hover {
  background-color: var(--downloadButtonHover);
}

#populateForm, #initForm, #submitArtworks {
  align-self: center;
  background-color: var(--controlButtonBg);
  border: 1px solid var(--controlButtonBorder);
  border-radius: 5px;
  padding: 0.5em;
  text-align: center;
  cursor: pointer;
  transition: background-color 0.3s;
  width: 100%;
  display: flex;
  align-items: center;
  justify-content: center;
}
#submitArtworks svg{
  padding: 0.7em;
}

#populateForm:hover, #initForm:hover, #submitArtworks:hover {
  background-color: var(--controlButtonHover);
}

/* --------------- Controls Right --------------- */
#controls #right {
  display: flex;
  flex-direction: column;
  justify-content: space-between;
  align-items: center;
  background-color: #d9fae7;
  border: 1px solid #006e23;
  border-radius: 8px;
  padding: 1em;
}

#exports {
  display: flex;
  flex-direction: column;
  gap: 0.5em;
  padding: 1em;
  border-radius: 5px;
}

#bottomRight{
  display: flex;
  flex-direction: column;
  padding: 1em;
}

#audioDiv {
  display: flex;
  justify-content: left;
  margin-bottom: 15px;
  align-items: center;
}

#audioDiv input {
  display: flex;
}

#audioDiv label {
  font-size: 0.9em;
}
/* --------------- Popup   --------------- */
/* Popup container */
#popup {
  transition: opacity 0.6s, transform 0.3s;
  position: fixed;
  z-index: 3;
  right: 5%;
  top: 5%;
  width: 35%;
  overflow: auto;
  background-color: rgb(246, 246, 246);
  border: 1px solid #888;
  border-radius: 9px;
  box-shadow: 0 4px 8px rgba(0, 0, 0, 0.1);
  opacity: 0;
}

#popup.show {
  animation: popupFadeIn 0.6s forwards;
}

#popup.hidden {
  animation: popupFadeOut 0.6s forwards;
}

/* Popup content */
#popup p {
  border-left: #005b1c solid 3px;
  margin-left: 15px;
  padding: 2% 10% 2% 15px;
  font-size: 1em;
  color: #333;
}

/* Close button */
#closePopup {
  position: absolute;
  top: 5px;
  right: 5px;
  background: none;
  border: none;
  font-size: 1.2em;
  cursor: pointer;
}
/* --------------- Bouton Quitter la visite --------------- */
#leave{
  position: fixed;
  bottom: 5%;
  right: 5%;
  z-index: 1;
  background-color: var(--deleteButtonBg);
  border: 1px solid var(--deleteButtonBorder);
  padding: 0.5em;
  border-radius: 7px;
  cursor: pointer;
}
#leave:hover {
  background-color: var(--deleteButtonHover);
}
/* -------------- Popup Quitter la visite --------------- */
#leaveVisitPopup, #deleteArtworkPopup{
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  position: fixed;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  background-color: rgba(0, 0, 0, 0.5);
  z-index: 2;
  backdrop-filter: blur(3px);
}
#contentLeavePopup{
  align-items: center;
  justify-content: center;
  display: flex;
  flex-direction: column;
  background-color: #ffffff;
  padding: 10px 20px 10px 20px;
  border-radius: 7px;
  border: 1px solid #000000;
}

#leaveVisitPopup p {
  margin-top: 10%;
  font-size: 120%;
  color: #000000;
  text-align: center;
  font-weight: 600;
}

#leaveVisitPopup #leaveYes, #deleteArtworkPopup #deleteYes {
  background-color: #f1f1f1;
  border: 1px solid #000000;
  border-radius: 7px;
  padding: 1em;
  margin-right: 20px;
}
#leaveVisitPopup #leaveNo, #deleteArtworkPopup #deleteNo {
  background-color: #d3d3d3;
  border: 1px solid #000000;
  border-radius: 7px;
  padding: 1em;
}
#leaveVisitPopup #leaveNo:hover, #deleteArtworkPopup #deleteNo:hover {
  background-color: #c3c3c3;
}
#leaveVisitPopup #leaveYes:hover, #deleteArtworkPopup #deleteYes:hover {
  background-color: #e1e1e1;
}

#contentDeletePopup{
  z-index: 999;
  align-items: center;
  justify-content: center;
  display: flex;
  flex-direction: column;
  background-color: #ffffff;
  padding: 10px 20px 10px 20px;
  border-radius: 7px;
  border: 1px solid #000000;
}

/* --------------- Réponses a la question --------------- */
#answerButtons{
  display: flex;
  justify-content: space-evenly;
}
#answerButtons button {
  padding: 1em;
  background-color: var(--controlButtonBg);
  border: 1px solid var(--controlButtonBorder);
  border-radius: 7px;
  cursor: pointer;
}
#answerButtons button:hover {
  background-color: var(--controlButtonHover);
}
#downloadFullStory{
  padding: 1em;
  background-color: var(--downloadButtonBg);
  border: 1px solid var(--downloadButtonBorder);
  border-radius: 7px;
  margin-top: 1em;
  cursor: pointer;
  display: flex;
  justify-content: space-between;
  align-items: center;
}
#downloadFullStory svg{
  margin-right: 10px;
}
#downloadFullStory:hover {
  background-color: var(--downloadButtonHover);
}


/* --------------- Loading --------------- */
 #loading {
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  position: fixed;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  background-color: rgba(255, 255, 255, 0.8);
  z-index: -1;
}

#loading p {
  margin-bottom: 20px;
  font-size: 18px;
  color: #333;
}

#loading svg {
  animation: rotate 1s linear infinite;
}

#loading circle {
  stroke-linecap: round;
}

/* --------------- Compteur Oeuvre sélectionnée --------------- */
#compteurOeuvreSelectionnee{
  display: flex;
  justify-content: center;
  align-items: center;
  position: fixed;
  bottom: 5%;
  right: 5%;
  background-color: #f9f9f9;
  border: 1px solid #ccc;
  border-radius: 7px;
  padding: 0.5em;
  z-index: 500;
}
/* --------------- Engrenage --------------- */
#apiKeysToggle {
  position: fixed;
  top: 10px;
  right: 10px;
  z-index: 1000;
}

#toggleApiKeys {
  background: none;
  border: none;
  cursor: pointer;
  padding: 5px;
}

#toggleApiKeys svg {
  width: 24px;
  height: 24px;
  color: #333;
}

#apiKeys {
  position: fixed;
  top: 50px;
  right: 10px;
  background-color: #f9f9f9;
  border: 2px solid #ccc;
  border-radius: 5px;
  padding: 10px;
  z-index: 1000;
}

#apiKeys.hidden {
  display: none;
}

#apiKeys input {
  display: block;
  width: 100%;
  margin-bottom: 10px;
  border: 1px solid #ccc;
  border-radius: 3px;
}

#apiKeys input:last-child {
  margin-bottom: 0;
}

#apiKeys label {
  display: block;
  margin-bottom: 5px;
  color: #333;
  font-size: 0.8em;
}

#apiKeys label:not(:first-child) {
  margin-top: 10px;
}
