/* Structure */
.form-field {
	display: grid;
	grid-template-columns: repeat(4, minmax(0, 1fr));
	gap: .5rem;
}

.form-field > * {
	grid-column: span 4;
}

/* Texts */
.form-lbl {
	color: var(--text-color-strong);
	font-size: .9rem;
	font-weight: 600;
}

p.confirmation,
p.error {
	border: 1px solid transparent;
	padding: .7rem 1rem;
	text-align: center;
}

p.confirmation {
	background-color: rgba(17, 144, 63, .1);
	border-color: #11903F;
	color: #11903F;
}

p.error {
	background-color: rgba(217, 10, 14, .1);
	border-color: #D90A0E;
	color: #D90A0E;
}

/* Inputs */
input,
select,
textarea {
	--inp-height: 3rem;
	--inp-outline: 1px;
	--inp-bgr: var(--surface);
	--inp-color: var(--text-color-strong);
	--inp-accent: var(--primary);
	--inp-font-size: .9rem;
}

input:-webkit-autofill,
textarea:-webkit-autofill,
select:-webkit-autofill {
	outline: 2px solid var(--inp-bgr) !important;
	-webkit-box-shadow: 0 0 0 1000px var(--inp-bgr) inset !important;
			box-shadow: 0 0 0 1000px var(--inp-bgr) inset !important;
	-webkit-text-fill-color: var(--inp-color) !important;
	transition: none !important;
}

input:focus:-webkit-autofill,
textarea:focus:-webkit-autofill,
select:focus:-webkit-autofill {
	outline: 2px solid var(--inp-accent) !important;
}

input.inp-size1 {grid-column: span 1;}
input.inp-size2 {grid-column: span 2;}
input.inp-size3 {grid-column: span 3;}

.inp,
.sel,
.textarea {
	width: 100%;
	border: none;
	outline: var(--inp-outline) solid transparent;
	outline-offset: -1px;
	background-color: var(--inp-bgr);
	color: var(--inp-color);
	font-family: var(--font-text);
	font-size: var(--inp-font-size);
	letter-spacing: .05em;
	transition: outline-color .2s;
}

.inp,
.sel {
	padding-inline: 10px;
}

.inp {
	line-height: var(--inp-height);
}

.sel {
	height: var(--inp-height);
}

.sel optgroup {
	font-family: var(--font-text);
}

.textarea {
	height: 6rem;
	resize: none;
	padding: 5px 10px;
	line-height: 1.3;
}

.inp:focus,
.textarea:focus {
	outline-color: var(--inp-accent);
	box-shadow: 0 0 5px rgba(16, 114, 191, .1);
}

.inp-num {
	box-shadow: none !important;
	-moz-appearance: textfield;
}

.inp-num::-webkit-outer-spin-button,
.inp-num::-webkit-inner-spin-button {
	-webkit-appearance: none;
	margin: 0;
}

/* Checkboxes */
.cbx {
	display: grid;
	width: max-content;
	margin-top: .5rem;
	grid-template-columns: calc(1rem + 2px) max-content;
	gap: .5rem;
	align-items: center;
}

.cbx input {
	opacity: 0;
	position: absolute;
	pointer-events: none;
}

.cbx .icon {
	display: grid;
	aspect-ratio: 1;
	border-radius: 50%;
	outline: 1px solid var(--text-color-fade);
	margin-block: 2px;
	margin-left: 2px;
	place-items: center;
	cursor: pointer;
	transition: outline-color .15s;
}

.cbx .icon:hover,
.cbx input:checked + .icon {
	outline: 2px solid var(--text-color);
}

.cbx .icon::after {
	content: '';
	opacity: 0;
	background-color: var(--primary);
	border-radius: inherit;
	width: 50%;
	aspect-ratio: 1;
	transition: opacity .15s;
}

.cbx input:checked + .icon::after {opacity: 1;}
.cbx:hover .icon::after {opacity: .8;}

.cbx p {
	line-height: 1;
	cursor: pointer;
}

/* Buttons */
.pbtn,
.sbtn {
	--_btn-border: 1px;
	--_btn-height: 3.1rem;
	width: max-content;
	min-width: 13rem;
	padding-inline: 2rem;
	font-size: .8rem;
	font-family: var(--font-text);
	letter-spacing: .07em;
	line-height: calc(var(--_btn-height) - var(--_btn-border) * 2);
	text-align: center;
	text-transform: uppercase;
	transition: background-color .3s, border .3s, color .3s;
	cursor: pointer;
}

.pbtn {
	background-color: var(--primary);
	border: 1px solid transparent;
	color: #fff;
}

.sbtn {
	background-color: transparent;
	border: var(--_btn-border) solid #707070;
}

.pbtn:hover {
	background-color: var(--primary-variant);
}

.sbtn:hover {
	border-color: var(--primary);
}

.pbtn:disabled,
.sbtn:disabled {
	filter: saturate(0);
	pointer-events: none;
}

/* Icons */
.icon-box svg {
	display: block;
	width: 100%;
	height: 100%;
	transition: fill .3s;
}

.icon,
.txt-icon {
	mask-size: contain !important;
	mask-repeat: no-repeat !important;
	-webkit-mask-size: contain !important;
	-webkit-mask-repeat: no-repeat !important;
	transition: background-color .3s;
}

.txt-icon {
	display: inline-block;
	background-size: contain;
	background-position: center;
	width: 1.4rem;
	height: 1.4rem;
	margin-right: 10px;
	vertical-align: middle;
}

.txt-icon.right {
	margin-left: 10px;
	margin-right: 0;
}

.txt-icon.small {width: 1.2rem;	height: 1.2rem;}
.txt-icon.big {width: 1.6rem; height: 1.6rem;}