
#wrapper {
  display: flex;
  justify-content: center;
  align-items: stretch;
  min-height: 100vh;
}

.layout-parent {
  display: grid;
  grid-template-areas:
    "header header"
    "menu main"
    "footer footer";
  min-width: 420px;
  grid-template-columns: auto 1fr;
  grid-template-rows: auto 1fr auto;
  width: 100%;
  background: var(--white-color);
  box-shadow: 0 8px 24px rgba(0, 0, 0, 0.08);
}

.layout-header {
  grid-area: header;
  display: flex;
  justify-content: space-between;
  align-items: center;
  background: var(--primary-gradient);
  color: var(--white-color);
  padding: 16px 24px;
}

.layout-user-header {
  display: flex;
  align-items: center;
  gap: 10px;
}

.layout-title h1 {
  font-size: 1.4rem;
  font-weight: 600;
}

.layout-aside {
  grid-area: menu;
  background: var(--background-color-light);
  border-right: 1px solid var(--grey-light-color);
  padding: 24px 12px;
  min-width: 260px;
}

.layout-middle {
  grid-area: main;
  padding: 24px;
  overflow: auto;
}

.layout-footer {
  grid-area: footer;
  text-align: center;
  background: var(--background-color-light);
  color: var(--text-color-light);
  font-size: 0.9rem;
}

.layout-title img {
  height: 40px;
}

.layout-title {
  display: flex;
  align-items: center;
  gap: 15px;
}

@media (max-width: 768px) {
  .layout-parent {
    grid-template-areas:
      "header"
      "menu"
      "main"
      "footer";
    grid-template-columns: 1fr;
  }

  .layout-aside {
    border-right: none;
    border-bottom: 1px solid var(--grey-light-color);
  }
}