
/* general rules */

.shell {
  border-radius: 1rem;
  overflow: hidden;
  padding: 0;
}
.grid {
  display: grid;
  gap: 1rem;
  align-items: stretch;
  padding: 0;
}

/* component level rules */
/* .component_grid {
  display: grid;
  gap: 0.75rem;
  padding: 0;
} */

/* header rules */
.header {
  display: grid; 
  grid-template-columns: 1fr auto 1fr;
  gap: 1rem;
  /* justify-content: center; */
  align-items: center;
  height: 2.5rem;
}
.header > span {
  padding-inline-start: 1rem;
  padding-inline-end: 1rem;
}
.header > span:first-child {
  justify-self: start;
  text-align: left;
}
.header > span:nth-child(2) {
  justify-self: center;
  text-align: center;
}
.header > span:last-child {
  justify-self: end;
  text-align: right;
}

/* footer rules */

.footer {
  display: flex; 
  align-items: center; 
  justify-content: space-between;
  height: 2rem;
  color: #888;
  border: 1px solid #e0e0e0;
  border-radius: 0.75rem;
  padding: 0 0.75rem 0 0.75rem;
}