:root {
  --colourBg: rgb(222, 236, 222);
  --colourHeader: hsl(114, 12%, 15%);
  --colourFooter: hsl(114, 12%, 15%);
  --colourButton: rgb(119, 146, 116);
  --colourButtonHighlight: rgb(91, 112, 89);
  --colourWhite: white;
  --colorDarkTransparent: rgba(0,0,0,0.2);
  --fontMain: ui-rounded, "SF Pro Rounded", system-ui, san-serif;
  --sizeHeader: 4rem;
  --sizeFooter: 3rem;
  --sizeContent: 50ch;
}

body {
  margin: 0;
	font-family: var(--fontMain);
  background-color: var(--colourBg);
  -webkit-tap-highlight-color: transparent;
  user-select: none;
}

p {
  font-size: 1rem;
  line-height: 1em;
}
h1, h2, h3, h4, h5, h6 {
  font-weight: 600;
}
h1 {
  font-size: 1.25rem;
  font-size: clamp(1.25rem, 1rem + 1.25vw, 2rem);
  line-height: 1em;
}
h2 {
  font-size: 1.8rem;
  line-height: 1em;
}

button {
  padding: 0.25em 0.5em;
  font-size: 1rem;
  font-family: var(--fontMain);
  border: 2px solid transparent;
  border-radius: 0.3em;
  background-color: var(--colourButton);
  color: var(--colourWhite);
  transition: background-color 0.3s ease;
  font-family: var(--fontMain);
  cursor: pointer;
  user-select: none;
}
button:hover {
  background-color: var(--colourButtonHighlight);
}

textarea, input {
  font-size: 1em;
  font-family: var(--fontMain);
}


header {
  position: fixed;
  top: 0;
  left: 0;
  height: var(--sizeHeader);
  width: 100%;
  display: flex;
  align-items: center;
  background-color: var(--colourHeader);
  color: white;
  box-shadow: 0 0 5px rgba(0,0,0,0.1);
  z-index: 20;
}
header > div {
  width: 100%;
  max-width: var(--sizeContent);
  margin: 0 auto;
  padding: 0.5rem 1rem;
  display: flex;
  align-items: center;
  justify-content: space-between;
}

main {
  min-height: calc(calc(100vh - var(--sizeHeader)) - var(--sizeFooter));
  /* width: 100%; */
  max-width: var(--sizeContent);
  margin: 0 auto;
  padding: 1rem 0.5rem;
  margin-top: var(--sizeHeader);
  margin-bottom: var(--sizeFooter);
  overflow-y: auto;
  -webkit-overflow-scrolling: touch;
}

footer {
  position: fixed;
  bottom: 0;
  left: 0;
  width: 100%;
  height: var(--sizeFooter);
  display: flex;
  align-items: center;
  background-color: var(--colourFooter);
  z-index: 10;
}

footer > div {
  width: 100%;
  max-width: var(--sizeContent);
  margin: 0 auto;
  padding: 0.5rem;
  display: flex;
  align-items: center;
  justify-content: space-between;
}

#new-recipe-button {
  position: absolute;
  bottom: 0;
  left: 50%;
  width: 2em;
  height: 2em;
  font-size: 3em;
  transform: translate(-50%, 0);
  border-radius: 100%;
  background-color: var(--colourFooter);
}

@media screen and (display-mode: fullscreen) {
  header {
    padding-top: env(safe-area-inset-top);
    height: calc(var(--sizeHeader) + env(safe-area-inset-top));
  }
  main {
    min-height: calc(100vh - (var(--sizeHeader) + var(--sizeFooter) + 2rem + env(safe-area-inset-top) + env(safe-area-inset-bottom)));
    margin-top: calc(var(--sizeHeader) + env(safe-area-inset-top));
    margin-bottom: calc(var(--sizeFooter) + env(safe-area-inset-bottom)); 
  }
  footer {
    padding-bottom: env(safe-area-inset-bottom);
    height: calc(var(--sizeFooter) + env(safe-area-inset-bottom));
  }
  #new-recipe-button {
    bottom: calc(0 + env(safe-area-inset-bottom));
    transform: translate(-50%, calc(0px - env(safe-area-inset-bottom)));
  }
}


.recipe-view {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  column-gap: 0.5em;
  row-gap: 0.5em;
}

recipe-link {
  width: 100%;
  height: 8ch;
}






.new-recipe-view {
  position: fixed;
  bottom: 0;
  left: 0.2rem;
  width: calc(100% - 2.4rem);
  height: calc(100vh - (var(--sizeHeader) + var(--sizeFooter) - 2em));
  padding: 1rem;
  padding-top: 1.5em; 
  background-color: var(--colourFooter);
  border-radius: 0.5em 0.5em 0 0;
  opacity: 1;
  z-index: 11;
  transform: translateY(0);
  color: white;

  display: flex;
  justify-content: center;
  flex-direction: column;

  transition: transform 0.5s ease;
}
.new-recipe-view.hidden {
  transform: translateY(100%);
  /* opacity: 0; */
}
.new-recipe-view::before {
  content: "";
  position: absolute;
  top: 8px;
  left: 50%;
  transform: translateX(-50%);
  width: 3ch;
  height: 4px;
  border-radius: 2px;
  background-color: var(--colourBg);
}
.view-title {
  margin-bottom: 1em;
}
.new-recipe-view .form {
  flex-grow: 1;
  display: flex;
  flex-direction: column;
}
.recipe-input-line {
  padding: 4px;
  width: 100%;
  display: grid;
  grid-template-columns: 1fr 5ch;
}
.recipe-input-line input, .recipe-input-line textarea {
  font-size: 1.3rem;
  padding: 0.5em;
  border-radius: 0.3em 0 0 0.3em;
  border: none;
}
.recipe-input-line button {
  border-radius: 0 0.3em 0.3em 0;  
}
.new-recipe-view .recipe-input-line:last-child {
  flex-grow: 1;
}
.new-recipe-view .done-button {
  padding: 0.5em;
  font-size: 1.3em;
}
@media screen and (display-mode: fullscreen) {
  .new-recipe-view {
    bottom: env(safe-area-inset-top);
    height: calc(100vh - (var(--sizeHeader) + var(--sizeFooter) + env(safe-area-inset-top) + 2em));
    padding-bottom: calc(var(--sizeFooter) + env(safe-area-inset-bottom)); 
  }
}


a.ingredients-view-link {
   width: 3ch;
   text-align: center;
   font-size: 2rem;
   text-decoration: none;
}





.ingredient {
  width: 100%;
  aspect-ratio: 1;
}
.ingredient img {
  display: block;
  width: 80%;
  margin: 0 auto;
}
.ingredient p {
  display: block;
  text-align: center;
  font-weight: bold;
  font-size: 2em;
}
