.rui__2x3vw {
  margin: 0;
  padding: 0;
  position: relative;
}

.rui__QgrPb {
  -webkit-box-sizing: border-box;
          box-sizing: border-box;
  width: 100%;
  padding-right: 124px;
  position: relative;
}

.rui__A4yZy {
  -webkit-box-sizing: border-box;
          box-sizing: border-box;
  font-family: Roboto, sans-serif;
  height: 40px;
  font-size: 15px;
  line-height: 15px;
  padding: 0;
  border-radius: 1px 0 0 1px;
  background-color: #fff;
  border: solid 2px #315efb;
  width: 100%;
  border-right: 0;
  padding-left: 13px;

  /* padding-right: 100px; TODO включенные режимы */
  padding-right: 42px;
  -webkit-appearance: none;
}

.rui__A4yZy::-webkit-input-placeholder {
  line-height: normal !important;
}

.rui__A4yZy::-ms-clear {
  display: none;
}

.rui__A4yZy::-webkit-input-placeholder {
  font-family: Roboto, sans-serif;
  color: #8d96b2;
  -webkit-transition: all 0.2s ease-in;
  transition: all 0.2s ease-in;
  height: 40px;
  font-size: 15px;
}

.rui__A4yZy::-ms-input-placeholder {
  font-family: Roboto, sans-serif;
  color: #8d96b2;
  -webkit-transition: all 0.2s ease-in;
  transition: all 0.2s ease-in;
  height: 40px;
  font-size: 15px;
}

.rui__A4yZy::placeholder {
  font-family: Roboto, sans-serif;
  color: #8d96b2;
  -webkit-transition: all 0.2s ease-in;
  transition: all 0.2s ease-in;
  height: 40px;
  font-size: 15px;
}

.rui__A4yZy:focus::-webkit-input-placeholder {
  opacity: 0.5;
}

.rui__A4yZy:focus::-ms-input-placeholder {
  opacity: 0.5;
}

.rui__A4yZy:focus::placeholder {
  opacity: 0.5;
}

.rui__A4yZy:focus {
  border-color: #2446cb;
  outline: none;
}

.rui__s9rdb {
}

.rui__s9rdb::-webkit-input-placeholder {
  color: #fff;
}

.rui__s9rdb::-ms-input-placeholder {
  color: #fff;
}

.rui__s9rdb::placeholder {
  color: #fff;
}

.rui__OLIqO {
  -webkit-box-sizing: border-box;
          box-sizing: border-box;
  font-family: Roboto, Arial, sans-serif;
  width: 125px;
  height: 40px;
  border-radius: 0 1px 1px 0;
  background-color: #315efb;
  padding: 0 0 0 18px;
  font-size: 12px;
  line-height: 40px;
  font-weight: 500;
  letter-spacing: 1.4px;
  color: #fff;
  text-transform: uppercase;
  position: absolute;
  overflow: hidden;
  cursor: pointer;
  top: 0;
  right: 0;
  border: 0;
  -webkit-transition: background 0.2s;
  transition: background 0.2s;
}

.rui__OLIqO::before {
  content: "";
  position: absolute;
  left: 26px;
  top: 14px;
  width: 12px;
  height: 12px;
  line-height: 12px;
  background-image: url("../../icons/search-form/search.svg");
}

.rui__uAYZs .rui__OLIqO::before {
  width: 20px;
  height: 20px;
  left: 18px;
  top: 13px;
  background-image: url("../../icons/search-form/search_mobile.svg");
}

.rui__2MI9o .rui__OLIqO::before {
  width: 15px;
  height: 15px;
  left: 5px;
  top: 9px;
  background-image: url("../../icons/search-form/search_tiny.svg");
}

.rui__2MI9o .rui__A4yZy:focus + .rui__OLIqO {
  border-color: #315efb;
  border-width: 2px;
}

.rui__2MI9o .rui__A4yZy:focus + .rui__OLIqO::before {
  top: 8px;
}

.rui__2MI9o .rui__OLIqO:hover::before {
  /* Отказываемся от transition в пользу простоты кода из-за второстепенности tiny-компонента,
    поэтому эмулируем (приблизительно) #315efb => #274bc9 через фильтр */
  filter: url('data:image/svg+xml;charset=utf-8,<svg xmlns="http://www.w3.org/2000/svg"><filter id="filter"><feComponentTransfer color-interpolation-filters="sRGB"><feFuncR type="linear" slope="0.85" /><feFuncG type="linear" slope="0.85" /><feFuncB type="linear" slope="0.85" /></feComponentTransfer></filter></svg>#filter');
  -webkit-filter: brightness(0.85);
          filter: brightness(0.85);
}

.rui__OLIqO:focus {
  outline: none;
}

.rui__OLIqO:hover {
  background: #2c54e2;
}

.rui__OLIqO:active {
  background: #274bc9;
  outline: none;
}

.rui__OLIqO::-ms-clear {
  display: none;
}

.rui__2MI9o {
}

.rui__2MI9o .rui__QgrPb {
  padding-right: 30px;
}

.rui__2MI9o .rui__A4yZy {
  padding-right: 75px;
  border-color: rgb(199, 203, 217);
  border-width: 1px;
  height: 35px;
  font-size: 13px;
  padding-left: 14px;
}

.rui__2MI9o .rui__A4yZy:focus {
  border-color: #315efb;
  border-width: 2px;
  height: 35px;
  font-size: 13px;
  padding-left: 13px;
}

.rui__2MI9o .rui__A4yZy::-webkit-input-placeholder {
  font-size: 13px;
  height: 35px;
}

.rui__2MI9o .rui__A4yZy::-ms-input-placeholder {
  font-size: 13px;
  height: 35px;
}

.rui__2MI9o .rui__A4yZy::placeholder {
  font-size: 13px;
  height: 35px;
}

.rui__2MI9o .rui__OLIqO {
  font-size: 0;
  width: 35px;
  height: 35px;
  background-color: #fff;
  border: rgb(199, 203, 217) 1px solid;
  border-left: none;
}

.rui__2MI9o .rui__2l_CV {
  padding-right: 0;
}

.rui__gkB3w {
  position: absolute;
  height: 20px;
  min-width: 20px;
  right: 124px;
  margin-right: 15px;
  top: 10px;
}

.rui__2MI9o .rui__gkB3w {
  right: 30px;
}

.rui__4u39V {
  display: inline-block;
  height: 20px;
  width: 20px;
  cursor: pointer;
  border: 10px transparent solid; /* расширяем границы для более простого прицеливания */
  margin: -10px -14px -10px -10px;
  border-right-width: 15px;
  position: relative;
  -webkit-box-sizing: content-box;
          box-sizing: content-box;
}

.rui__4u39V::before,
.rui__4u39V::after {
  content: "";
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  bottom: 0;
  opacity: 1;
  -webkit-transition: opacity 0.2s;
  transition: opacity 0.2s;
  background: transparent no-repeat 0 0 url("../../icons/search-form/clear.svg");
}

.rui__4u39V::after {
  background-position: 0 -20px;
  opacity: 0;
}

.rui__4u39V:hover::before {
  opacity: 0;
}

.rui__4u39V:hover::after {
  opacity: 1;
}

.rui__4u39V:active::before {
  opacity: 0;
}

.rui__4u39V:active::after {
  background-position: 0 -40px;
  opacity: 1;
}

/* TODO На некоторых бордах мобильный крестик отличается от десктопного, запросил уточнения в https://zpl.io/2y6mZKG
.root_mobile .clear::before,
.root_mobile .clear::after {
  background-image: url("https://www.rambler.ru/icons/search-form/clear_mobile.svg");
} */

.rui__2MI9o .rui__4u39V {
  display: none;
}

.rui__4u39V + .rui__LvL7X {
  margin-left: 10px;
}

.rui__LvL7X {
  margin: 2px;
  margin-left: 8px;
  display: inline-block;
  height: 16px;
  width: 16px;
  cursor: pointer;
  -webkit-transition: color 0.1s ease-in;
  transition: color 0.1s ease-in;
  color: #c6cbd8;
}

.rui__LvL7X:hover {
  color: #315efb;
}

.rui__LvL7X:active {
  color: #274bc9;
}

.rui__rek7Y {
  color: #8d97b1;
}

.rui__2MI9o .rui__LvL7X {
  margin-left: 12px;
}

.rui__2l_CV {
  z-index: 10;
  position: absolute;
  top: 100%;
  width: 100%;
  padding-right: 125px;
  -webkit-box-sizing: border-box;
          box-sizing: border-box;
}

.rui__23aUk {
  position: relative;
}

.rui__5uOyN {
  font-family: Roboto, sans-serif;
  background-color: #343b4c;
  color: #fff;
  padding: 11px 15px;
  -webkit-box-sizing: border-box;
          box-sizing: border-box;
  font-size: 13px;
  line-height: 13px;
  border-radius: 1px;
  text-transform: none;
  letter-spacing: normal;
  white-space: nowrap;
  word-wrap: break-word;
  z-index: 100;
  position: absolute;
  left: 50%;
  bottom: 100%;
  visibility: hidden;
  opacity: 0;
  -webkit-transform: translate(-50%, 0) translate3d(0, 10px, 0);
          transform: translate(-50%, 0) translate3d(0, 10px, 0);
  -webkit-transition:
    visibility 0.5s linear 0s,
    opacity 0.2s ease,
    -webkit-transform 0.3s cubic-bezier(0.175, 0.885, 0.135, 1.425);
  transition:
    visibility 0.5s linear 0s,
    opacity 0.2s ease,
    -webkit-transform 0.3s cubic-bezier(0.175, 0.885, 0.135, 1.425);
  transition:
    visibility 0.5s linear 0s,
    opacity 0.2s ease,
    transform 0.3s cubic-bezier(0.175, 0.885, 0.135, 1.425);
  transition:
    visibility 0.5s linear 0s,
    opacity 0.2s ease,
    transform 0.3s cubic-bezier(0.175, 0.885, 0.135, 1.425),
    -webkit-transform 0.3s cubic-bezier(0.175, 0.885, 0.135, 1.425);
  pointer-events: none;
  margin-left: 3px;
  margin-bottom: 12px;
}

.rui__23aUk:hover .rui__5uOyN {
  visibility: visible;
  opacity: 1;
  -webkit-transform: translate(-50%, 0) translate3d(0, 0, 0);
          transform: translate(-50%, 0) translate3d(0, 0, 0);
}

.rui__5uOyN::after {
  content: "";
  width: 0;
  height: 0;
  border-style: solid;
  border-width: 10px 10px 0 10px;
  border-color: #343b4c transparent transparent transparent;
  position: absolute;
  left: 50%;
  -webkit-transform: translate(-50%, -50%);
          transform: translate(-50%, -50%);
  top: 100%;
}

.rui__uAYZs {
}

.rui__uAYZs .rui__QgrPb {
  padding-right: 55px;
}

.rui__uAYZs .rui__A4yZy {
  height: 45px;
  font-size: 16px;
  line-height: 16px;
  padding-left: 15px;
  padding-right: 50px;
}

.rui__uAYZs .rui__A4yZy::-webkit-input-placeholder {
  font-size: 16px;
}

.rui__uAYZs .rui__A4yZy::-ms-input-placeholder {
  font-size: 16px;
}

.rui__uAYZs .rui__A4yZy::placeholder {
  font-size: 16px;
}

.rui__uAYZs .rui__OLIqO {
  width: 55px;
  height: 45px;
  font-size: 0;
}

.rui__uAYZs .rui__OLIqO svg {
  background: transparent;
  position: absolute;
  top: 13px;
  left: 18px;
  fill: #fff;
  -webkit-transition: all 0.2s ease-in;
  transition: all 0.2s ease-in;
}

.rui__uAYZs .rui__gkB3w {
  top: 13px;
  right: 55px;
}

.rui__uAYZs .rui__23aUk {
  display: none;
}

.rui__uAYZs .rui__2l_CV {
  padding-right: 0;
}

.rui__uAYZs .rui__2o98_ {
  width: 20px;
  height: 20px;
  line-height: 20px;
}

.rui__uAYZs .rui__2o98_ path {
  fill: white;
}

.rui__1UQnZ {
  border-radius: 0 0 1px 1px;
  background-color: #fff;
  -webkit-box-shadow: 0 2px 5px 0 rgba(102, 116, 166, .15);
          box-shadow: 0 2px 5px 0 rgba(102, 116, 166, .15);
}

.rui__11K-1 {
  padding: 0 15px;
  font-family: Roboto, Arial, sans-serif;
  font-size: 15px;
  line-height: 40px;
  color: #262626;
  height: 40px;
  overflow: hidden;
  text-overflow: ellipsis;
  position: relative;
  cursor: pointer;
  white-space: nowrap;
  display: block;
  text-decoration: none;
}

.rui__242R2 {
  background-color: rgba(141, 150, 178, .1);
}

.rui__Z2EGE {
  -webkit-box-sizing: border-box;
          box-sizing: border-box;
  background-color: rgba(141, 150, 178, .05);
  border-bottom: 1px solid #e8eaf0;
  position: relative;
  padding-left: 45px;
}

.rui__bG50t {
  color: #315efb;
  position: absolute;
  line-height: 40px;
  right: 15px;
  top: 0;
  display: block;
  text-decoration: none;
}

.rui__bG50t:visited {
  color: #315efb;
}

.rui__bG50t:hover {
  color: #274bc8;
}

.rui__11K-1 span b {
  font-weight: 600;
}

.rui__1B4G3 {
  padding-left: 0;
}

.rui__JE2JP {
  padding-left: 26px;
}

.rui__1vFdk {
  color: #8d96b2;
}

.rui__3ZT_f {
  display: block;
  position: absolute;
  height: 16px;
  width: 16px;
  top: 12px;
  left: 15px;
  overflow: hidden;
  border-radius: 1px;
  background-position: center center;
}

.rui__12iMH {
  background-image: url("../../icons/search-form/breaking.svg");
}

.rui__3DR6t {
  display: block;
}

.rui__1815y {
  position: relative;
  -webkit-box-shadow: inset 0 8px 5px -5px rgba(102, 116, 166, .15);
          box-shadow: inset 0 8px 5px -5px rgba(102, 116, 166, .15);
}

.rui__1815y::after {
  content: "";
  position: absolute;
  height: 150vh;
  width: 100%;
  background-color: rgba(98, 104, 127, .8);
}

.rui__1815y .rui__11K-1 {
  font-size: 16px;
  height: 45px;
  line-height: 45px;
  padding: 0 10px;
}

.rui__1815y .rui__11K-1:first-child {
  border-top: 1px solid #e8eaf0;
}

.rui__1815y .rui__3ZT_f {
  top: 15px;
  left: 10px;
}

.rui__2EzZo {
  overflow-x: scroll;
  padding-bottom: 10px;

  /* Убирает скролл бар в firefox */
  scrollbar-width: none;
}

/* Убирает скролл бар в chrome & safari */

.rui__2EzZo::-webkit-scrollbar {
  display: none;
}

.rui__1pK6f {
  font-size: 16px;
  font-family: Roboto, Arial, sans-serif;
  background: #e8eaf0;
  height: 35px;
  line-height: 35px;
  display: inline-block;
  margin: 10px 0 0 10px;
  padding: 0 15px;
  white-space: nowrap;
}