:root {
  --white: #ffffff;
  --cream-bg: #f2eae2;
  --aurometal-saurus: #6c7289;
  --deep-aquamarine: #3d8168;
  --deep-aquamarine-hover: #1a4032;
  --gunmetal: #1c232b;
}

.txt-display {
  font-family: "Fraunces", serif;
  font-optical-sizing: auto;
  font-weight: 700;
  font-style: normal;
  font-variation-settings: "SOFT" 0, "WONK" 1;
  font-size: 2rem;
  line-height: 2rem;
}

.txt-montserrat {
  font-family: "Montserrat", sans-serif;
  font-optical-sizing: auto;
  font-style: normal;
}

.font-body {
  font-weight: 500;
  font-size: 0.875rem;
  line-height: 1.375rem;
}

.font-button-text {
  font-weight: 700;
  font-size: 0.875rem;
}

.font-overline {
  font-weight: 500;
  font-size: 0.75rem;
  letter-spacing: 0.3125rem;
  color: var(--aurometal-saurus);
}

.text-line-trough {
  text-decoration: line-through;
}

.no-margin {
  margin: 0;
}

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

.color-deep-aquamarine {
  color: var(--deep-aquamarine);
}

.color-aurometal-saurus {
  color: var(--aurometal-saurus);
}

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

body {
  background-color: var(--cream-bg);
}

main {
  block-size: 100vh;
  display: flex;
  justify-content: center;
  align-items: center;
}

.product-card {
  background-color: var(--white);
  inline-size: min(21.5rem, 91.7vw);
  border-radius: 0.625rem;
}

.img-wrapper {
  border-start-start-radius: inherit;
  border-start-end-radius: inherit;
  overflow: hidden;
}

img {
  inline-size: 100%;
  block-size: auto;
  display: block;
}

.content {
  padding: 1.5rem;
}

.margin-overline {
  display: block;
  margin-block-end: 0.75rem;
}

.margin-title {
  margin-block: 0 1rem;
}

.margin-p {
  margin-block: 0 1.5rem;
}

.margin-price {
  margin-block-end: 1.25rem;
}

.price-box {
  display: flex;
  align-items: center;
  gap: 1.25rem;
}

button {
  all: unset;
  background-color: var(--deep-aquamarine);
  inline-size: 100%;
  padding-block: 1rem;
  text-align: center;
  border-radius: 0.5rem;
}

button:hover {
  background-color: var(--deep-aquamarine-hover);
  cursor: pointer;
}

svg {
  margin-inline-end: 0.65rem;
}

/* 48rem = 768px assuming 1rem=16px */
@media (min-width: 48rem) {
  .product-card {
    display: flex;
    inline-size: 37.5rem;
  }
  .img-wrapper {
    border-start-start-radius: inherit;
    border-start-end-radius: 0;
    border-end-start-radius: inherit;
  }
  img {
    block-size: 100%;
  }
  .content {
    padding: 2rem;
    max-inline-size: 14.78rem;
  }
  .margin-overline {
    margin-block-end: 1.25rem;
  }
  .margin-title {
    margin-block: 0 1.5rem;
  }
  .margin-p {
    margin-block: 0 1.875rem;
  }
  .margin-price {
    margin-block-end: 1.875rem;
  }
}
