/* Importing fonts */
@import url('https://fonts.googleapis.com/css2?family=Montserrat:ital,wght@0,100..900;1,100..900&display=swap');
@import url('https://fonts.googleapis.com/css2?family=Fraunces:ital,opsz,wght@0,9..144,100..900;1,9..144,100..900&display=swap');

:root {
  /* Colors */
  --green-color-500: hsl(158, 36%, 37%);
  --green-color-700: hsl(158, 42%, 18%);
  --black-color: hsl(212, 21%, 14%);
  --grey-color: hsl(228, 12%, 48%);
  --cream-color: hsl(30, 38%, 92%);
  --white-color: hsl(0, 0%, 100%);

  /* Fonts */
  --montserrat-font: "Montserrat", sans-serif;
  --fraunces-font: "Fraunces", serif;
}

body {
  background-color: var(--cream-color);
  display: flex;
  justify-content: center;
  align-items: center;
  margin: 0;
  min-height: 100vh;
  padding: 1rem;
}

/* Mobile first card layout */
#container {
  display: flex;
  flex-direction: column;
  width: 100%;
  max-width: 375px; /* Mobile width from style guide */
  border-radius: 12px;
  overflow: hidden;
  background: var(--white-color);
}

/* Image */
#prod__image img {
  width: 100%;
  height: auto;
  object-fit: cover;
  display: block;
}

/* Description section */
#prod__image__description {
  display: flex;
  flex-direction: column;
  gap: 1rem;
  padding: 1.5rem;
}

/* Text elements */
#product_category p {
  font-family: var(--montserrat-font);
  font-weight: 500;
  font-size: clamp(0.7rem, 2vw, 0.9rem);
  letter-spacing: 4px;
  text-transform: uppercase;
  color: var(--grey-color);
  margin: 0;
}

#product_name p {
  font-family: var(--fraunces-font);
  font-size: clamp(1.5rem, 3vw, 2rem);
  font-weight: 700;
  line-height: 1.2;
  margin: 0;
}

#product_description p {
  font-family: var(--montserrat-font);
  font-size: clamp(0.85rem, 2vw, 1rem);
  line-height: 1.5;
  color: var(--grey-color);
  margin: 0;
}

#product_cost_container {
  display: flex;
  align-items: center;
  gap: 1rem;
}

#product_price p {
  font-family: var(--fraunces-font);
  font-weight: 700;
  color: var(--green-color-500);
  font-size: clamp(1.5rem, 4vw, 2rem);
  margin: 0;
}

#prodcut_price_cut p {
  text-decoration: line-through;
  font-family: var(--montserrat-font);
  font-size: clamp(0.85rem, 2vw, 1rem);
  color: var(--grey-color);
  margin: 0;
}

/* Button */
#cart_btn_container {
  display: flex;
  justify-content: center;
  align-items: center;
  gap: 0.7rem;
  padding: 0.8rem;
  width: 100%;
  background-color: var(--green-color-500);
  color: var(--white-color);
  border: none;
  border-radius: 8px;
  font-family: var(--montserrat-font);
  font-size: clamp(0.9rem, 2.5vw, 1rem);
}

#cart_btn_container img {
  width: 1rem;
  height: 1rem;
}

#cart_btn_container:hover {
  cursor: pointer;
  background-color: var(--green-color-700);
}

/* Dsektop override */
@media (min-width: 768px) {
  #container {
    max-width:40rem; /* Desktop card width, fits within 1440px screen */
    flex-direction: row;
    height:max-content; 
  }

  #prod__image,
  #prod__image__description {
    flex: 1;
  }

  #prod__image img {
    height: 100%;
    width: 100%;
    object-fit: cover;
  }

 
  #prod__image__description > #product_name{
    font-weight: 700;
    line-height: 1.2;  
    margin-bottom: 1rem; 
    width: 15rem;
    
  }
  #product_description{
    width: 16rem;
  }

  #product_cost_container{
    margin-top: 1.5rem;
    gap: 2rem;
  }
  #cart_btn_container{
    margin-top: 1rem;
    width: 18rem;
    
  }
}

