.layout-constrained {
  width: 100%;
  margin-left: auto;
  margin-right: auto;
}

@media (min-width: 992px) {
  .layout-constrained {
    max-width: 960px;
  }
}

@media (min-width: 1200px) {
  .layout-constrained {
    max-width: 1140px;
  }
}

@media (min-width: 1400px) {
  .layout-constrained {
    max-width: 1260px;
  }
}

/* emotki */
.emoji { font-family: "Apple Color Emoji","Segoe UI Emoji","Noto Color Emoji","Segoe UI Symbol",system-ui,sans-serif; }

.login-form-wrapper {
  display: flex;
  gap: 1.5rem;
  align-items: stretch;
}

.login-logo-wrapper {
  flex: 0 0 auto;
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 1rem;
  background: #f8f9fa;
  border-radius: 0.75rem;
}

.login-logo-wrapper img {
  display: block;
  height: 100%;
  max-height: 100%;
  width: auto;
  max-width: 140px;
  object-fit: contain;
}

.login-form-fields {
  flex: 1 1 auto;
  display: flex;
  flex-direction: column;
  gap: 1rem;
}

@media (max-width: 576px) {
  .login-form-wrapper {
    flex-direction: column;
    align-items: center;
  }

  .login-logo-wrapper {
    width: 100%;
    max-width: 220px;
  }

  .login-logo-wrapper img {
    width: 100%;
    height: auto;
  }

  .login-form-fields {
    width: 100%;
  }

}

.filter-actions {
  gap: 0.75rem;
}

.filter-actions .btn {
  min-width: 140px;
}

.free-slots-toolbar {
  display: flex;
  flex-direction: column;
  gap: 1rem;
}

.free-slots-toolbar-controls {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: 0.5rem;
}

.free-slots-toolbar-switch {
  display: flex;
  align-items: center;
  gap: 0.5rem;
  padding-left: 0;
}

.free-slots-toolbar-switch .form-check-input {
  margin-left: 0;
  float: none;
}

.mobile-full-width {
  width: auto;
}

@media (max-width: 768px) {
  .calendar-wrap .calendar-grid {
    grid-auto-columns: minmax(260px, 1fr);
    padding: 1rem 1.5rem;
  }
}

@media (max-width: 576px) {
  .navbar .navbar-collapse .nav-link {
    padding-left: 0;
  }

  .navbar .navbar-collapse .nav-link,
  .navbar .navbar-collapse .btn,
  .navbar .navbar-collapse form select,
  .navbar .navbar-collapse .mobile-full-width {
    width: 100%;
  }

  .filter-actions {
    flex-direction: column;
  }

  .filter-actions > .btn,
  .filter-actions > a.btn,
  .filter-actions > button,
  .mobile-full-width {
    width: 100%;
  }

  .filter-actions small {
    width: 100%;
  }

  .calendar-wrap {
    margin-left: -0.5rem;
    margin-right: -0.5rem;
  }

  .calendar-wrap .calendar-grid {
    grid-auto-columns: minmax(220px, 1fr);
    padding: 1rem;
  }
}

@media (min-width: 768px) {
  .free-slots-toolbar {
    flex-direction: row;
    justify-content: space-between;
    align-items: center;
  }

  .free-slots-toolbar-switch {
    margin-left: 0.5rem;
  }
}

@media (min-width: 1200px) {
  .free-slots-toolbar-controls {
    gap: 0.75rem;
  }
}