/* BUTTON */
.button {
	--text-color: var(--neutral-0100);
	--text-disabled-color: var(--neutral-1250);

	--bg-color: var(--accent-0500);
	--bg-hover-color: var(--accent-0700);
	--bg-disabled-color: var(--neutral-0200);

	flex-shrink: 0;
	padding: 10px 24px;
	display: inline-flex;
	align-items: center;
	justify-content: center;

	background-color: var(--bg-color);
	border-radius: 3px;

	font-weight: var(--fw-500);
	font-size: 16px;
	line-height: 24px;
	text-align: center;
	color: var(--text-color);

	transition: background-color 120ms cubic-bezier(0, 0, 0.15, 1);
}
.button._compact {
	padding: 6px 24px;
}

.button._outline,
.button._subtle {
	--text-color: var(--neutral-0900);
}

.button._outline {
	--text-disabled-color: var(--neutral-0900);

	--bg-color: transparent;
	--bg-hover-color: var(--neutral-0105);
	--bg-disabled-color: transparent;

	box-shadow: inset 0 0 0 1px var(--neutral-0120);
}
.button._subtle {
	--text-disabled-color: var(--neutral-1250);
	--bg-color: var(--neutral-0110);
	--bg-hover-color: var(--neutral-0120);
	--bg-disabled-color: var(--neutral-0120)
}
.button._danger {
	--text-color: var(--danger-0600);
	--text-disabled-color: var(--danger-0600);

	--bg-color: var(--danger-0110);
	--bg-hover-color: var(--danger-0120);
	--bg-disabled-color: var(--danger-0110);
}

.button:disabled {
	--text-color: var(--text-disabled-color);
	--bg-color: var(--bg-disabled-color);

	opacity: 0.54;
	pointer-events: none;
}

.button[data-resend] {
	gap: 4px;
}
.button[data-resend] span {
	color: var(--neutral-0100);
}

.button:has(img, svg) {
	padding-left: 16px;
}
.button > svg {
	opacity: 0.84;
}


@media (any-hover: hover) {
	.button:hover {
		background-color: var(--bg-hover-color);
	}
}

.button:focus-visible {
	background-color: var(--bg-hover-color);
}

.button:active {
	background-color: var(--bg-color);
	transition: none;
}


/* FORM */
.form-block {
	--gap: 16px;

	display: flex;
	flex-direction: column;
	gap: var(--gap);
	overflow-y: auto;
}
.form-block._center {
	text-align: center;
}

.form-block__image img {
	margin-inline: auto;
	max-height: 180px;
}

.form-block__title {
	font-weight: var(--fw-550);
	font-size: 18px;
	line-height: 24px;
	color: var(--neutral-0900);
}

.form-block__text {
	font-weight: var(--fw-400);
	font-size: 14px;
	line-height: 20px;
	color: var(--neutral-0450);
}

.form-block__title + .form-block__text {
	margin-top: calc(-1 * var(--gap) + 4px);
}

.form-block__button + .form-block__button {
	margin-top: calc(-1 * var(--gap) + 4px);
}

/* info */
.form-info-block {
	padding: 12px 16px 8px;
	background-color: var(--neutral-0105);
	box-shadow: inset 0 0 0 1px var(--neutral-0120);
	border-radius: 0 0 4px 4px;

	font-weight: var(--fw-400);
	font-size: 14px;
	line-height: 20px;
	color: var(--neutral-0600);
}
.input-group + .form-info-block {
	margin-top: calc(-4px - var(--gap));
}

/* respone */
.form-response {
	--main-color: var(--success-0500);
	--bg-color: var(--success-0110);

	display: none;
	padding: 10px 16px;
	background-color: var(--bg-color);
	box-shadow: inset 2px 0 0 var(--main-color);
	font-weight: var(--fw-450);
	font-size: 16px;
	line-height: 24px;
	color: var(--main-color);
}
.form-response._error {
	--main-color: var(--danger-0500);
	--bg-color: var(--danger-0110);
}
.form-response._show {
	display: block;
}
.form-response strong {
	font-weight: var(--fw-600);
}


/* input number */
input::-webkit-outer-spin-button,
input::-webkit-inner-spin-button {
	-webkit-appearance: none;
	margin: 0;
}

input[type="number"] {
	-moz-appearance: textfield;
}


/* fields */
.form-block__form {
	--gap: 12px;

	flex-grow: 1;
	display: flex;
	flex-direction: column;
	gap: var(--gap);
}
.form-block__agreement {
	font-weight: var(--fw-400);
	font-size: 14px;
	line-height: 20px;
	color: var(--neutral-0300);
}
.form-block__agreement a {
	color: var(--neutral-0900);
}

@media (any-hover: hover) {
	.form-block__agreement a:hover {
		color: var(--neutral-1250);
	}
}
@media (any-hover: none) {
	.form-block__agreement a:active {
		color: var(--neutral-1250);
	}
}

/* input-group */
.input-group {
	--bg-color: var(--neutral-0100);

	--border-color: var(--neutral-0300);
	--border-hover-color: var(--accent-0500);
	--border-focus-color: var(--accent-0500);
	--border-disabled-color: var(--neutral-0120);

	--placeholder-bg-color: var(--bg-color);
	--placeholder-color: var(--neutral-0300);
	--placeholder-hover-color: var(--neutral-0450);
	--placeholder-focus-color: var(--neutral-0300);
	--placeholder-disabled-color: var(--neutral-0300);

	--label-color: var(--neutral-0700);
	--label-hover-color: var(--accent-0700);
	--label-focus-color: var(--accent-0700);
	--label-disabled-color: var(--neutral-0450);

	--input-padding-y: 10px;
	--input-padding-x: 10px;

	--icon-color: var(--neutral-0600);
	--icon-disabled-color: var(--neutral-0400);

	position: relative;
	min-width: 0;
	display: flex;
	align-items: center;
	border-radius: 3px;
	background-color: var(--bg-color);
	outline: 1px solid var(--border-color);
	outline-offset: -1px;
	font-weight: var(--fw-400);
	font-size: 16px;
	line-height: 24px;
}
.input-group._compact {
	--input-padding-y: 6px;
	--input-padding-x: 6px;
}
.input-group._error {
	--border-color: var(--danger-0500);
	--border-hover-color: var(--danger-0500);
	--border-focus-color: var(--danger-0500);
	--label-color: var(--danger-0500);
	--label-hover-color: var(--danger-0500);
	--label-focus-color: var(--danger-0500);
}
.input-group._error::after {
	content: '';
	width: 21px;
	height: 16px;
	background: url('../images/i-error.svg') no-repeat center center var(--bg-color);
	position: absolute;
	top: 0;
	right: 11px;
	transform: translateY(-50%);
}

@media (any-hover: hover) {
	.input-group:hover {
		--border-color: var(--border-hover-color);
		--placeholder-color: var(--placeholder-hover-color);
		--label-color: var(--label-hover-color);
	}
}
@media (any-hover: none) {
	.input-group:active {
		--border-color: var(--border-hover-color);
		--placeholder-color: var(--placeholder-hover-color);
		--label-color: var(--label-hover-color);
	}
}
.input-group:focus-within {
	--border-color: var(--border-focus-color);
	--placeholder-color: var(--placeholder-focus-color);
	--label-color: var(--label-focus-color);
}
.input-group:has(
	.input-group__input:disabled,
	.input-group__input:read-only ~ .input-group__change
) {
	--border-color: var(--border-disabled-color);
	--placeholder-color: var(--placeholder-disabled-color);
	--label-color: var(--label-disabled-color);
	--icon-color: var(--icon-disabled-color);
}

/* icon */
.input-group__icon {
	margin-inline: var(--input-padding-x) calc(4px - var(--input-padding-x));
	display: flex;
	color: var(--icon-color);
}

.input-group > label {
	--padding: 6px;
	--icon-width: 0px;

	position: absolute;
	top: 0;
	transform: translateY(var(--input-padding-y));
	margin-left: calc(var(--input-padding-x) - var(--padding) + var(--icon-width));
	padding: 0 var(--padding);
	max-width: 100%;
	color: var(--placeholder-color);
	cursor: text;
}
.input-group__input:not(textarea) + label,
.input-group__input:not(:placeholder-shown) + label {
	overflow: hidden;
	text-overflow: ellipsis;
	white-space: nowrap;
}
.input-group__icon ~ .input-group__input:placeholder-shown + label {
	--icon-width: 20px;
}

/* input */
.input-group__input:not(:placeholder-shown) + label {
	transform: translateY(-50%);
	font-weight: var(--fw-400);
	font-size: 13px;
	line-height: 14px;
	background-color: var(--placeholder-bg-color);
	color: var(--label-color);
}
.input-group__input {
	padding: var(--input-padding-y) var(--input-padding-x);
	flex-grow: 1;
	max-width: 100%;
	min-width: 0;
	min-height: 100%;
	color: var(--neutral-0900);
	caret-color: var(--neutral-1250);
}
/* * + .input-group__input {
	padding-left: 2px;
}
.input-group__input:has(+ *) {
	padding-right: 2px;
} */
.input-group__input:is(textarea) {
	resize: none;
}
.input-group__input::placeholder {
	color: var(--placeholder-color);
}

.form-block:has(.input-group__input:required) .input-group__input:placeholder-shown:not(:required) + label::after {
	content: ' — необязательно';
	color: var(--neutral-0200);
}

.input-group__input:required + label::after {
	/* content: ' *';
	color: var(--primary-0400); */
}
.input-group:has(> label) .input-group__input::placeholder {
	color: transparent;
}
.input-group__input:disabled,
.input-group__input:read-only:has(~ .input-group__change) {
	color: var(--neutral-0450);
}

/* buttons */
.input-group__clear,
.input-group__toggle {
	flex-shrink: 0;
	align-self: flex-start;
	margin-top: var(--input-padding-y);
	margin-right: var(--input-padding-x);
	width: 24px;
	height: 24px;
	display: flex;
	justify-content: center;
	align-items: center;
	color: var(--neutral-0300);
}

.input-group__clear {
	display: none;
}
.input-group:hover:has(.input-group__input:not(:placeholder-shown)) .input-group__clear,
.input-group:focus-within:has(.input-group__input:not(:placeholder-shown)) .input-group__clear {
	display: flex;
}

.input-group__toggle svg:last-child,
.input-group__toggle._show svg:first-child {
	display: none;
}
.input-group__toggle svg:first-child,
.input-group__toggle._show svg:last-child {
	display: block;
}

@media (any-hover: hover) {
	.input-group__clear:hover,
	.input-group__toggle:hover {
		color: var(--neutral-0900);
	}
}
@media (any-hover: none) {
	.input-group__clear:active,
	.input-group__toggle:active {
		color: var(--neutral-0900);
	}
}

/* change */
.input-group__change {
	margin-right: var(--input-padding-x);
	font-weight: var(--fw-400);
	font-size: 16px;
	line-height: 20px;
	text-decoration: underline;
	color: var(--accent-0500);
}
.input-group__input:not(:read-only) ~ .input-group__change {
	display: none;
}

@media (any-hover: hover) {
	.input-group__change:hover {
		color: var(--accent-0700);
	}
}
@media (any-hover: none) {
	.input-group__change:active {
		color: var(--accent-0700);
	}
}

/* error */
.input-group__error {
	display: none;
	position: absolute;
	right: 0;
	top: calc(100% - 1px);
	z-index: 1;

	padding: 4px 8px;
	background-color: var(--danger-0500);
	border-radius: 0 0 4px 4px;

	font-weight: var(--fw-400);
	font-size: 13px;
	line-height: 14px;
	color: var(--neutral-0100);
}
.input-group__error::before {
	content: '';
	position: absolute;
	top: 0;
	right: calc(100% - 1px);
	width: 5px;
	height: 5px;
	background-image: radial-gradient(closest-side, transparent 4px, var(--danger-0500) 4px);
	background-repeat: no-repeat;
	background-size: 10px 10px;
	background-position: 100% 0;
}
.input-group._error:hover,
.input-group._error:focus-within {
	border-bottom-right-radius: 0;
}
.input-group:hover .input-group__error,
.input-group:focus-within .input-group__error {
	display: block;
}


/* mail-services */
.mail-services {
	display: grid;
	grid-template-columns: repeat(4, 1fr);
	gap: 4px;
}
.mail-services p {
	margin-bottom: 10px;
	grid-column: 1 / -1;
	font-weight: var(--fw-400);
	font-size: 14px;
	line-height: 20px;
	color: var(--neutral-0450);
}
.mail-services a {
	padding: 8px;
	height: 42px;
	display: flex;
	justify-content: center;
	border-radius: 3px;
	background-color: var(--neutral-0105);
}
.mail-services a img {
	width: 100%;
	height: 100%;
	object-fit: contain;
}

@media (any-hover: hover) {
	.mail-services a:hover {
		background-color: var(--neutral-0110);
	}
}
@media (any-hover: none) {
	.mail-services a:active {
		background-color: var(--neutral-0110);
	}
}



/* AUTH */
.authorization {
	padding: 20px;
	display: flex;
	justify-content: center;
}
.authorization__content {
	width: 100%;
	max-width: 340px;
	display: flex;
	flex-direction: column;
	gap: 16px;
}

/* logo */
.authorization__logo {
	align-self: flex-start;
	max-height: 64px;
	max-width: 100%;
}
.authorization__logo img {
	width: 100%;
	height: 100%;
	object-fit: contain;
}

/* auth-title */
.auth-title {
	padding: 10px 12px;
	display: flex;
	flex-direction: column;
	gap: 2px;

	background: linear-gradient(90deg, var(--accent-0103) 0%, var(--neutral-0100) 100%);
	box-shadow: inset 2px 0 0 var(--accent-0500);

	font-weight: var(--fw-400);
	font-size: 14px;
	line-height: 20px;
	color: var(--neutral-0450);
}

.auth-title__address {
	line-height: 24px;
	color: var(--neutral-0300);
}
.auth-title__address strong {
	font-weight: var(--fw-550);
	font-size: 18px;
	color: var(--accent-0700);
}


/* cabinets */
.authorization__cabinets {
	display: flex;
	flex-direction: column;
	overflow-y: auto;
	border: 1px solid var(--neutral-0120);
	border-radius: 3px;
	box-sizing: border-box;
}

.cabinet {
	--title-color: var(--neutral-0900);
	--subtitle-color: var(--neutral-0450);
	--arrow-color: var(--neutral-0450);
	--edge-color: var(--neutral-0100);
	--status-bg-color: var(--accent-0110);

	padding: 12px;
	display: flex;
	gap: 12px;
	background-color: var(--neutral-0100);
	border-radius: 3px;
}
.cabinet:not(:first-child) {
	box-shadow: inset 0 1px 0 var(--neutral-0120);
}
.cabinet__logo {
	flex-shrink: 0;
}
.cabinet__content {
	flex-grow: 1;
	overflow: hidden;
	display: flex;
	flex-direction: column;
	justify-content: center;
}
.cabinet__title-group {
	display: flex;
	gap: 4px;
}
.cabinet__title,
.cabinet__subtitle {
	overflow: hidden;
	text-overflow: ellipsis;
	white-space: nowrap;
}
.cabinet__title {
	font-weight: var(--fw-450);
	font-size: 16px;
	line-height: 20px;
	color: var(--title-color);
}
.cabinet__subtitle {
	font-weight: var(--fw-400);
	font-size: 14px;
	line-height: 20px;
	color: var(--subtitle-color);
}

.cabinet__status {
	flex-shrink: 0;
	padding-inline: 4px;
	background-color: var(--status-bg-color);
	border-radius: 3px;
	font-weight: var(--fw-500);
	font-size: 12px;
	line-height: 20px;
	color: var(--accent-0700);
}

.cabinet__logo {
	flex-shrink: 0;
	width: 40px;
	height: 40px;
	border-radius: 3px;
	overflow: hidden;
	background-color: var(--neutral-0120);
}
.cabinet__logo img {
	width: 100%;
	height: 100%;
	object-fit: cover;
}

.cabinet__arrow {
	flex-shrink: 0;
	width: 28px;
	position: relative;
	display: flex;
	align-items: center;
	justify-content: flex-end;
	color: var(--arrow-color);
}
.cabinet__arrow::before {
	content: '';
	position: absolute;
	left: 0;
	top: 0;
	bottom: 0;
	width: 1px;
	background: linear-gradient(180deg, var(--edge-color) 0%, var(--neutral-0120) 50%, var(--edge-color) 100%);
}

@media (any-hover: hover) {
	.cabinet:hover {
		--title-color: var(--neutral-1250);
		--subtitle-color: var(--neutral-0600);
		--arrow-color: var(--neutral-0900);
		--edge-color: var(--neutral-0105);
		--status-bg-color: var(--accent-0120);

		background-color: var(--neutral-0105);
	}
}

.cabinet:focus-visible {
	--title-color: var(--neutral-1250);
	--subtitle-color: var(--neutral-0600);
	--arrow-color: var(--neutral-0900);
	--edge-color: var(--neutral-0105);
	--status-bg-color: var(--accent-0120);

	background-color: var(--neutral-0105);
}

@media (any-hover: none) {
	.cabinet:active {
		--title-color: var(--neutral-1250);
		--subtitle-color: var(--neutral-0600);
		--arrow-color: var(--neutral-0900);
		--edge-color: var(--neutral-0105);
		--status-bg-color: var(--accent-0120);

		background-color: var(--neutral-0105);
	}
}


/* modal */
.authorization__modal {
	position: relative;
	display: flex;
	flex-direction: column;
	background-color: #ffffff;
	overflow: hidden;
}
.authorization__modal:not(._show) {
	display: none;
}

@media (max-width: 639.98px) {
	.authorization__content::before {
		content: '';
		flex-shrink: 0;
		display: block;
		margin-bottom: 20px;
		width: 100%;
		height: 1px;
		background-color: var(--neutral-0110);
	}
}

@media (min-width: 640px) {
	.authorization {
		padding: 40px;
	}
}

@media (min-width: 1140px) {
	.authorization {
		height: 100dvh;
	}
}
