@charset "UTF-8";
:root {
  --color-primary: #B36270;
  --color-primary-light: #F98196;
  --color-primary-dark: #ba265d;
  --color-grey-light: #f4f2f2;
  --color-black: #404040;
  --color-grey: #E1E4E8;
  --color-white: #FBFBFB;
  --color-green: #95CF92;
  --color-red: #DE324C;
  --color-purple: #A4A4D3;
  --shadow-dark: 0 2rem 6rem rgba(0, 0, 0, 0.3);
  --shadow-light: 0 2rem 5rem rbga(0, 0, 0, 0.4);
  --border: 1px solid var(--color-grey); }

* {
  margin: 0;
  padding: 0; }

*,
*::before,
*::after {
  box-sizing: inherit;
  font-family: inherit;
  font-size: inherit; }

ul {
  list-style: none; }

a,
a:visited {
  text-decoration: none;
  color: var(--color-black); }

html {
  box-sizing: border-box;
  font-size: 62.5%; }

body {
  font-family: 'Open Sans', sans-serif;
  font-weight: 600;
  line-height: 1.6;
  min-height: 100vh;
  background-color: var(--color-white); }

.color-green {
  color: var(--color-green); }

.color-red {
  color: var(--color-red); }

.bg-pink {
  background-color: var(--color-primary-light) !important; }

.bg-purple {
  background-color: var(--color-purple) !important; }

.text-bold {
  font-weight: bold; }

.mt-1 {
  margin-top: 1rem; }

.mt-2 {
  margin-top: 2rem; }

.mt-3 {
  margin-top: 3rem; }

.mb-1 {
  margin-bottom: 1rem; }

.mb-2 {
  margin-bottom: 2rem; }

.mb-3 {
  margin-bottom: 3rem; }

.container-2-columns {
  display: grid;
  grid-template-columns: 50% 50%;
  column-gap: 0.5rem;
  row-gap: 0.5rem; }

.d-flex-separated {
  display: flex;
  align-items: center;
  justify-content: space-between; }

.container-results-simple {
  display: flex;
  flex-direction: column; }
  .container-results-simple .item {
    padding: 0.5rem 0;
    cursor: pointer; }
  .container-results-simple .item:not(:last-child) {
    margin-bottom: 0.2rem;
    border-bottom: 1px solid var(--color-grey); }

/* Definimos la animación */
@keyframes sacudida {
  0% {
    transform: rotate(0deg); }
  25% {
    transform: rotate(10deg); }
  50% {
    transform: rotate(-10deg); }
  75% {
    transform: rotate(10deg); }
  100% {
    transform: rotate(0deg); } }

.container {
  padding-left: 2rem;
  padding-right: 2rem;
  overflow: hidden; }

.grid-2-columns {
  display: grid;
  grid-template-columns: repeat(2, 49%);
  column-gap: 1rem; }

.image img {
  width: 100%;
  height: 100%;
  object-fit: contain;
  object-position: center; }

.form {
  display: flex;
  flex-direction: column; }
  .form .input:not(:last-child) {
    margin-bottom: 0.5rem; }

.input {
  display: flex;
  flex-direction: column;
  font-size: 1.5rem; }

.input label {
  font-size: 1.8rem; }

input, textarea {
  border-radius: 5px;
  padding: 0.5rem 0.8rem;
  border: var(--border);
  outline: none;
  color: var(--color-black); }

button {
  font-size: 2rem;
  border-radius: 5px;
  border: none;
  padding: 0.5rem;
  font-weight: 800; }

.navbar {
  background-color: var(--color-primary);
  padding: 0.2rem 2rem;
  display: flex;
  align-items: center; }
  .navbar .image {
    width: 5rem; }
  .navbar .title {
    color: var(--color-white);
    font-size: 3rem;
    text-transform: uppercase;
    margin-left: 1rem; }

.btn-float {
  background-color: gray;
  width: 5rem;
  height: 5rem;
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
  position: fixed;
  bottom: 2rem;
  right: 2rem;
  z-index: 600;
  box-shadow: rgba(149, 157, 165, 0.2) 0px 8px 24px; }
  .btn-float img {
    width: 4rem;
    height: 4rem; }
  .btn-float.edit img {
    width: 3rem;
    height: 3rem; }
  .btn-float.btn-float-up {
    bottom: 8rem; }

.btn-icon .image {
  width: 2rem;
  height: 2rem; }

.btn-primary {
  background-color: var(--color-primary-dark);
  color: var(--color-white); }

.btn-secondary {
  background-color: var(--color-grey); }

.search-icon {
  cursor: pointer;
  width: fit-content; }
  .search-icon .image {
    width: 2rem;
    height: 2.1rem; }

.card {
  border: 1px solid var(--color-grey);
  padding: 0.5rem 1rem;
  font-size: 1.5rem; }
  .card-title {
    font-size: 1.7rem;
    font-weight: bold;
    border-bottom: 1px solid var(--color-grey);
    padding-bottom: 0.2rem; }
  .card-title-action {
    display: flex;
    align-items: center;
    justify-content: space-between; }

.recipe-resume {
  display: grid;
  grid-template-columns: repeat(3, 33.3%);
  border: 1px solid var(--color-grey);
  background-color: var(--color-white);
  padding: 1rem 2rem;
  font-size: 1.5rem;
  position: fixed;
  bottom: 0;
  left: 0;
  right: 0; }
  .recipe-resume .item:nth-child(2) {
    text-align: center; }
  .recipe-resume .item:nth-child(3) {
    text-align: right; }
  .recipe-resume .value {
    font-size: 1.8rem; }

.modal {
  position: fixed;
  padding-left: 2rem;
  padding-right: 2rem;
  padding-top: 2rem;
  top: 0;
  left: 0;
  right: 0;
  height: 100vh;
  z-index: 1000;
  display: none;
  opacity: 0;
  visibility: hidden;
  background-color: rgba(0, 0, 0, 0.3);
  transition: opacity 0.4s ease, visibility 0.4s ease; }
  .modal-container {
    background-color: var(--color-white);
    font-size: 1.5rem;
    padding: 1rem;
    border-radius: 5px; }
  .modal-title {
    font-size: 1.8rem;
    border-bottom: 1px solid var(--color-grey);
    margin-bottom: 0.5rem; }
  .modal-body .container-results-simple {
    margin-left: 0.2rem;
    margin-right: 0.2rem;
    max-height: 60vh;
    overflow-y: auto;
    font-weight: 400; }
  .modal-body {
    padding-bottom: 1rem; }
  .modal-footer .btn {
    font-size: 1.6rem;
    padding: 0.4rem 1rem; }
  .modal.active {
    display: block;
    opacity: 1;
    visibility: visible; }
  .modal .modal-btn-actions {
    display: grid;
    grid-template-columns: 1fr 1fr;
    column-gap: 1rem; }

.login-container {
  background-image: linear-gradient(to bottom, var(--color-primary-light), var(--color-primary-dark));
  background-size: cover;
  background-repeat: no-repeat;
  height: 100vh; }
  .login-container .form {
    margin-top: 15vh; }
    .login-container .form .input label {
      color: var(--color-white); }
  .login-container .login-image {
    display: flex;
    align-items: center;
    justify-content: center;
    user-select: none; }
    .login-container .login-image:active .image,
    .login-container .login-image:hover .image {
      animation: sacudida 0.5s infinite; }
  .login-container .form .image {
    width: 20rem; }
  .login-container .login-button {
    background-color: transparent;
    color: var(--color-white);
    text-transform: uppercase;
    margin-top: 0.5rem; }
    .login-container .login-button:active {
      transition: background-color 0.2s ease-in-out;
      background-color: var(--color-primary-dark); }

.home-container {
  display: flex;
  flex-direction: column;
  align-items: center;
  padding-bottom: 8rem; }
  .home-container .image-section {
    cursor: pointer; }
    .home-container .image-section .title {
      font-size: 2rem;
      text-align: center;
      font-weight: 800;
      color: var(--color-grey); }
    .home-container .image-section .image {
      width: 30rem;
      opacity: 0.5; }
  .home-container .image-section:not(:last-child) {
    margin-bottom: 2rem; }
  .home-container .content-section {
    display: flex;
    flex-direction: column;
    width: 100%; }
  .home-container .content-section .header {
    display: flex;
    align-items: center;
    justify-content: space-between; }
    .home-container .content-section .header .title-icon {
      display: flex;
      align-items: center;
      justify-content: center;
      font-size: 2rem; }
    .home-container .content-section .header .title-icon .image {
      margin-right: 0.5rem; }
    .home-container .content-section .header .image {
      width: 2rem;
      height: 2.1rem; }
    .home-container .content-section .header .search-icon {
      cursor: pointer; }

.recipe-container {
  display: flex;
  align-items: center;
  overflow-x: auto;
  padding-top: 1rem;
  padding-bottom: 1rem;
  width: 100%;
  margin-bottom: 1rem; }
  .recipe-container .recipe-item:not(:last-child) {
    margin-right: 1rem; }
  .recipe-container .recipe-item {
    color: #FBFBFB;
    background-color: #F98196;
    border-radius: 1rem;
    width: 15rem;
    height: 15rem;
    padding: 0.5rem;
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    flex: 0 0 15rem; }
    .recipe-container .recipe-item .image {
      width: 6rem;
      height: 6rem; }
    .recipe-container .recipe-item .title {
      text-align: center;
      font-size: 1.6rem;
      overflow: hidden;
      text-overflow: ellipsis; }
    .recipe-container .recipe-item .price {
      font-size: 1.8rem;
      font-weight: bold; }
  .recipe-container .recipe-item.add {
    padding-left: 1rem;
    padding-right: 1rem;
    flex: 0 0 max-content; }

.ingredient-container {
  display: flex;
  flex-direction: column; }
  .ingredient-container .ingredient-item:not(:last-child) {
    margin-bottom: 1rem; }
  .ingredient-container .ingredient-item {
    width: 100%;
    font-size: 1.6rem;
    color: #FBFBFB;
    background-color: #A4A4D3;
    border-radius: 1rem;
    padding: 1rem;
    display: flex;
    justify-content: space-between; }
    .ingredient-container .ingredient-item .values {
      font-weight: bold;
      min-width: 10rem;
      font-size: 1.5rem;
      display: flex;
      flex-direction: column;
      align-items: end;
      width: max-content; }

.results-container {
  margin-top: 1rem; }
  .results-container .results-items {
    margin-top: 2rem;
    display: flex;
    flex-direction: column; }
  .results-container .results-items .item:not(:last-child) {
    margin-bottom: 1rem; }
  .results-container .results-items .item {
    border: 1px solid var(--color-grey);
    border-radius: 5px;
    padding: 0.5rem 1rem;
    font-size: 1.5rem; }
  .results-container .results-items .item .title {
    font-weight: bold;
    font-size: 1.7rem;
    padding-bottom: 0.2rem;
    border-bottom: 1px solid var(--color-grey); }

.item-recipe .details {
  display: grid;
  grid-template-columns: 1fr 1fr;
  column-gap: 0.4rem;
  row-gap: 0.2rem; }

.item-recipe .details > :nth-child(2n) {
  text-align: right; }

.item-recipe .price {
  font-weight: bold;
  font-size: 1.7rem; }

.recipe-ingredient-list {
  display: flex;
  flex-direction: column; }
  .recipe-ingredient-list .item:not(:last-child) {
    border-bottom: 1px solid var(--color-grey);
    margin-bottom: 1rem; }
  .recipe-ingredient-list .item .details {
    display: flex;
    align-items: center;
    justify-content: space-between; }

.recipe-ingredientes .item {
  border: 1px solid var(--color-grey);
  border-radius: 5px;
  padding: 0.8rem; }

.recipe-ingredientes .item:not(:last-child) {
  margin-bottom: 1rem; }

.recipe-ingredientes .item .title {
  display: flex;
  align-items: center;
  justify-content: space-between; }

.recipe-ingredientes .item-bottom {
  display: flex;
  align-items: center;
  justify-content: space-between;
  font-size: 1.8rem;
  font-weight: 500; }

.recipe-ingredientes .item-bottom .controls {
  display: flex;
  align-items: center; }
  .recipe-ingredientes .item-bottom .controls .value {
    margin: 0 1rem; }

.item-ingredient {
  cursor: pointer; }
  .item-ingredient-metrics {
    display: grid;
    grid-template-columns: 1fr 1fr; }
  .item-ingredient-metrics > :nth-child(2n) {
    text-align: right; }
