/* ===== mobile ===== */
img {
  max-width: 100%;
  height: auto;
}

p {
  color: #444;
}

h2 {
  color: #444;
  margin-top: 50px;
  margin-bottom: 0;
}

.title-underline {
  position: relative;
  display: inline-block;
  padding-bottom: 8px;
}

.title-underline::after {
  content: "";
  position: absolute;
  left: -10%;
  bottom: 0;
  width: 120%;
  height: 3px;
  background-color: #d9d9d9;
  border-radius: 2px;
}

.concept-image {
  width: 100%;
  height: auto;
  border-radius: 20px;
}

.custom-card {
  border-top: 1px solid #ccc;
  border-radius: 20px;
  overflow: hidden;              /* Ensure the content doesn't overflow the rounded corners. */
}

.date {
  font-size: 0.75rem;
  color: #666;
}

.clamp {
  display: -webkit-box;
  -webkit-box-orient: vertical;
  -webkit-line-clamp: 3; /* Specify the number of lines to display */
  overflow: hidden;
  text-overflow: ellipsis;
}

.menu-image {
  width: 100%;
  height: auto;
  border-radius: 20px;
}

.contact-btn {
  color: #fff;
  background-color: #d9d9d9;
}

.footer {
  background-color: #d9d9d9;
  margin-top: 80px;
}

.footer p {
  color: #fff;
}

/* ===== pc ===== */
@media (min-width: 769px) {
  h2 {
    margin-top: 100px; 
  }

  .footer {
  margin-top: 100px;
}
}
