/*!*********************************************************************************************************************************************************************************************************************************************************************************!*\
  !*** css ./node_modules/next/dist/build/webpack/loaders/css-loader/src/index.js??ruleSet[1].rules[14].oneOf[7].use[2]!./node_modules/next/dist/build/webpack/loaders/postcss-loader/src/index.js??ruleSet[1].rules[14].oneOf[7].use[3]!./styles/components/ui/input.module.css ***!
  \*********************************************************************************************************************************************************************************************************************************************************************************/
.input_input__cyPv4 {
  width: 100%;
  height: var(--control-height);
  border: 1px solid #d1d5db;
  border-radius: var(--radius);
  padding: 0 12px;
  background: var(--c-white);
  outline: none;
  transition: border-color .15s ease, box-shadow .15s ease;
  font-size: 16px;
}

.input_input__cyPv4:focus {
  border-color: var(--c-primary);
  box-shadow: 0 0 0 3px rgba(41,95,152,.15);
}

/*!**********************************************************************************************************************************************************************************************************************************************************************************!*\
  !*** css ./node_modules/next/dist/build/webpack/loaders/css-loader/src/index.js??ruleSet[1].rules[14].oneOf[7].use[2]!./node_modules/next/dist/build/webpack/loaders/postcss-loader/src/index.js??ruleSet[1].rules[14].oneOf[7].use[3]!./styles/components/ui/button.module.css ***!
  \**********************************************************************************************************************************************************************************************************************************************************************************/
.button_button__FHIR8 {
  display: inline-flex;
  align-items: center;
  justify-content: center;

  width: 100%;
  height: var(--control-height);

  border-radius: var(--radius);
  border: none;
  cursor: pointer;

  font-weight: 700;
  letter-spacing: .2px;

  padding: 0 16px;
  white-space: nowrap;

  transition:
    transform .05s ease,
    box-shadow .15s ease,
    opacity .15s ease,
    filter .15s ease;

  color: var(--c-white);
  box-shadow: var(--shadow-1);
}

.button_button__FHIR8:active {
  transform: translateY(1px);
}

.button_button__FHIR8:disabled {
  opacity: .6;
  cursor: not-allowed;
  box-shadow: none;
  transform: none;
  filter: grayscale(0.25) brightness(0.95);
}

.button_button__FHIR8:disabled:hover {
  transform: none;
  filter: grayscale(0.25) brightness(0.95);
}

/* Цвета */

.button_blue__TwADt   { background: var(--c-primary); }
.button_orange__fzCQj { background: var(--c-warning); }
.button_green__7wD8L  { background: var(--c-success); }
.button_gray__SnV_d   { background: #6b7280; }
.button_red__oQDgh    { background: var(--c-del); }

/*!****************************************************************************************************************************************************************************************************************************************************************************************!*\
  !*** css ./node_modules/next/dist/build/webpack/loaders/css-loader/src/index.js??ruleSet[1].rules[14].oneOf[7].use[2]!./node_modules/next/dist/build/webpack/loaders/postcss-loader/src/index.js??ruleSet[1].rules[14].oneOf[7].use[3]!./styles/components/ui/notification.module.css ***!
  \****************************************************************************************************************************************************************************************************************************************************************************************/
.notification_wrap__10kCh {
  display: grid;
  grid-gap: 8px;
  gap: 8px;
}

.notification_note__R708d {
  display: grid;
  grid-template-columns: 1fr auto;
  align-items: center;
  border-radius: var(--radius);
  padding: 10px 12px;
  font-weight: 600;
  background: var(--c-white);
}

.notification_noteFloating__DLhPm {
  width: -moz-fit-content;
  width: fit-content;
  max-width: 100%;
}

.notification_error__bC_3J {
  color: #7f1d1d;
  background: #fee2e2;
  border: 1px solid #fecaca;
}

.notification_info__tdCOG {
  color: #965b04;
  background: #f7c05c;
  border: 1px solid #dbd8d1;
}

.notification_success__n2MCc {
  color: #064e3b;
  background: #d1fae5;
  border: 1px solid #a7f3d0;
}

.notification_close___k8U0 {
  border: none;
  background: transparent;
  cursor: pointer;
  color: inherit;
  width: 28px;
  height: 28px;
  display: inline-grid;
  place-items: center;
  font-size: 20px;
  line-height: 1;
  margin-left: 8px;
  padding: 0;
  border-radius: 6px;
}

/* Плавающее уведомление «тост» */
.notification_toast__d4IMo {
  position: fixed;
  z-index: 1000;
  width: -moz-fit-content;
  width: fit-content;
  max-width: calc(100vw - 32px);
}

.notification_toastTopLeft__kC_Gq {
  top: 16px;
  left: 16px;
}

.notification_toastTopRight__BkqO5 {
  top: 16px;
  right: 16px;
}

.notification_toastBottomLeft__DP6kS {
  bottom: 16px;
  left: 16px;
}

.notification_toastBottomRight__rtDnr {
  bottom: 16px;
  right: 16px;
}

.notification_toastTopCenter__ZV4RW {
  top: 16px;
  left: 50%;
  transform: translateX(-50%);
}

.notification_toastBottomCenter__qsYNC {
  bottom: 16px;
  left: 50%;
  transform: translateX(-50%);
}

.notification_toastRightCenter__7swyd {
  top: 50%;
  right: 16px;
  transform: translateY(-50%);
}

.notification_toastLeftCenter__NFMiE {
  top: 50%;
  left: 16px;
  transform: translateY(-50%);
}

.notification_toastCenter__SKMPw {
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
}

/*!***************************************************************************************************************************************************************************************************************************************************************************************!*\
  !*** css ./node_modules/next/dist/build/webpack/loaders/css-loader/src/index.js??ruleSet[1].rules[14].oneOf[7].use[2]!./node_modules/next/dist/build/webpack/loaders/postcss-loader/src/index.js??ruleSet[1].rules[14].oneOf[7].use[3]!./styles/components/ui/icon-button.module.css ***!
  \***************************************************************************************************************************************************************************************************************************************************************************************/
.icon-button_button__yHgPe {
  --icon-btn-size: var(--control-height);

  /* базовый фон берём из переменной --icon-bg */
  background: var(--icon-bg, var(--c-primary));

  display: inline-flex;
  align-items: center;
  justify-content: center;

  width: var(--icon-btn-size);
  height: var(--icon-btn-size);
  flex: 0 0 var(--icon-btn-size); /* не даём колонкам сжать кнопку */

  border-radius: var(--radius);
  border: none;
  cursor: pointer;

  color: var(--c-white);
  box-shadow: var(--shadow-1);

  transition:
    transform .05s ease,
    box-shadow .15s ease,
    opacity .15s ease,
    filter .15s ease,
    background-color .15s ease;
}

.icon-button_button__yHgPe:active {
  transform: translateY(1px);
}

/* disabled — явно неактивная */

.icon-button_button__yHgPe:disabled {
  opacity: .6;
  cursor: not-allowed;
  box-shadow: none;
  transform: none;
  filter: grayscale(0.3) brightness(0.95);
}

.icon-button_button__yHgPe:disabled:hover {
  transform: none;
  filter: grayscale(0.3) brightness(0.95);
}

/* Цвета: задаём переменную --icon-bg */

.icon-button_blue__6mX1v   { --icon-bg: var(--c-primary); }
.icon-button_orange__kCKSx { --icon-bg: var(--c-warning); }
.icon-button_green__3Ud3d  { --icon-bg: var(--c-success); }
.icon-button_red__UDlPr    { --icon-bg: var(--c-del); }
.icon-button_gray__Gic4_   { --icon-bg: #6b7280; }

/* Иконка */

.icon-button_icon__oeHPe {
  display: block;
  width: calc(var(--icon-btn-size) * 0.55);
  height: calc(var(--icon-btn-size) * 0.55);
  color: inherit;
  fill: currentColor;
  stroke: currentColor;
}

/* Режим с текстом */

.icon-button_withText__enopR {
  width: auto;
  padding: 0 10px;
  gap: 8px;
  flex: 0 0 auto;
}

.icon-button_text__1EylV {
  font: inherit;
  white-space: nowrap;
}

/* Нажатое состояние (toggle) */

.icon-button_pressed__ffK7R {
  filter: brightness(0.78) saturate(0.95);
}

/* Ховер: меняем ИМЕННО фон (если цвет передан через --icon-hover-bg) */

.icon-button_button__yHgPe:hover:not(:disabled) {
  background: var(--icon-hover-bg, var(--icon-bg, var(--c-primary)));
  filter: brightness(1.03);
}

.icon-button_fullWidth__dKXLe {
  width: 100%;
}

.icon-button_ghost__TnORk {
  background: transparent !important;
  color: #111 !important;
  box-shadow: none !important;
  border: 1px solid #d1d5db !important;
}

.icon-button_ghost__TnORk:hover:not(:disabled) {
  background: transparent !important;
  filter: none !important;
}

.icon-button_ghost__TnORk .icon-button_icon__oeHPe {
  color: #111 !important;
  fill: currentColor !important;
  stroke: currentColor !important;
}
/*!******************************************************************************************************************************************************************************************************************************************************************************************!*\
  !*** css ./node_modules/next/dist/build/webpack/loaders/css-loader/src/index.js??ruleSet[1].rules[14].oneOf[7].use[2]!./node_modules/next/dist/build/webpack/loaders/postcss-loader/src/index.js??ruleSet[1].rules[14].oneOf[7].use[3]!./styles/components/modals/base-modal.module.css ***!
  \******************************************************************************************************************************************************************************************************************************************************************************************/
.base-modal_backdrop__Yh2_K {
  position: fixed;
  inset: 0;
  background: rgba(0, 0, 0, 0.45);
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 16px;
  z-index: 70;
}

.base-modal_card__YVlKq {
  background: var(--c-white);
  border-radius: 12px;
  max-height: 90vh;
  width: min(560px, 96vw);
  max-width: 96vw;
  display: flex;
  flex-direction: column;
  box-shadow: var(--shadow-1);
  border: 1px solid #e5e7eb;
}

.base-modal_header__z_eCT {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
  padding: 14px 16px;
  border-bottom: 1px solid #eef0f2;
}

.base-modal_title__VZOr9 {
  margin: 0;
  font-size: 16px;
  line-height: 1.2;
  font-weight: 700;
}

.base-modal_headerActions__dUaOT {
  display: inline-flex;
  align-items: center;
  gap: 8px;
}

.base-modal_content__I_112 {
  padding: 14px 16px;
  flex: 1 1;
  min-height: 0;
  overflow: auto;
  display: flex;
  flex-direction: column;
  gap: 12px;
}

.base-modal_footer__258kG {
  padding: 12px 16px 16px;
  display: flex;
  align-items: center;
  justify-content: flex-end;
  gap: 10px;
  border-top: 1px solid #eef0f2;
}

/*!*********************************************************************************************************************************************************************************************************************************************************************************************!*\
  !*** css ./node_modules/next/dist/build/webpack/loaders/css-loader/src/index.js??ruleSet[1].rules[14].oneOf[7].use[2]!./node_modules/next/dist/build/webpack/loaders/postcss-loader/src/index.js??ruleSet[1].rules[14].oneOf[7].use[3]!./styles/components/modals/session-ended.module.css ***!
  \*********************************************************************************************************************************************************************************************************************************************************************************************/
.session-ended_content__KrcXO {
  display: grid;
  grid-template-columns: 40px minmax(0, 1fr);
  grid-gap: 12px;
  gap: 12px;
  align-items: start;
}

.session-ended_iconWrap__E0aKk {
  width: 40px;
  height: 40px;
  border-radius: var(--radius);
  display: inline-flex;
  align-items: center;
  justify-content: center;
  background: #295f98;
  border: 1px solid rgba(41, 95, 152, 0.18);
}

.session-ended_icon__qbJKE {
  width: 22px;
  height: 22px;
}

.session-ended_message__5zcdb {
  margin: 0;
  color: var(--c-text);
  font-size: 16px;
  line-height: 1.45;
}

.session-ended_actionButton__SNImi {
  width: auto !important;
  min-width: 120px;
}

/*!************************************************************************************************************************************************************************************************************************************************************************!*\
  !*** css ./node_modules/next/dist/build/webpack/loaders/css-loader/src/index.js??ruleSet[1].rules[14].oneOf[7].use[2]!./node_modules/next/dist/build/webpack/loaders/postcss-loader/src/index.js??ruleSet[1].rules[14].oneOf[7].use[3]!./styles/pages/auth.module.css ***!
  \************************************************************************************************************************************************************************************************************************************************************************/
.auth_container__HgfNj {
  width: 30%;
  margin: 24px 0;
  padding: 24px;
}

.auth_title__1KMoe {
  margin: 0 0 12px;
}

.auth_subtitleBlock__z6ISL {
  margin-bottom: 16px;
}

.auth_subtitle__AmUXY {
  margin: 0 0 6px;
  color: #333;
}

.auth_subtitleList__M55yq {
  margin: 0;
  padding-left: 18px;
  list-style: none;
  font-size: 14px;
  color: #444;
}

.auth_subtitleList__M55yq li {
  margin-bottom: 2px;
}

.auth_subtitleEmoji__meOps {
  margin-right: 4px;
}

.auth_form__nrfV1 {
  display: grid;
  grid-gap: 12px;
  gap: 12px;
}

.auth_link__LcdQ7 {
  color: #295f98;
  text-decoration: underline;
}

.auth_checkboxRow__G445a {
  display: flex;
  flex-direction: row;
  justify-content: flex-start;
  align-items: center;
  gap: 10px;
}

.auth_checkboxText__SZajS {
  font-size: 13px;
  color: #333;
}

.auth_bottomRow__2B3d2 {
  display: flex;
  flex-direction: row;
  justify-content: center;
  align-items: center;
  width: 100%;
  gap: 5px;
  margin-top: 10px;
}

.auth_muted__R5zEp {
  color: #666;
  font-size: 13px;
}

.auth_fieldMessage__J0Sg0 {
  margin-top: 4px;
  font-size: 12px;
  line-height: 1.3;
}

.auth_fieldMessage_error__9zuWR {
  color: #d80000;
}

.auth_fieldMessage_success__RRmbJ {
  color: #00a64c;
}

.auth_requiredStar__WpOPf {
  color: #d80000;
  font-weight: 700;
}

@media (max-width: 900px) {
  .auth_container__HgfNj {
    width: 60%;
    margin: 20px auto;
  }
}

@media (max-width: 640px) {
  .auth_container__HgfNj {
    width: 100%;
    margin: 16px auto;
    padding: 16px;
  }

  .auth_bottomRow__2B3d2 {
    flex-wrap: wrap;
    text-align: center;
  }
}

