// nvue下hover-class无效
$spui-button-before-top:50% !default;
$spui-button-before-left:50% !default;
$spui-button-before-width:100% !default;
$spui-button-before-height:100% !default;
$spui-button-before-transform:translate(-50%, -50%) !default;
$spui-button-before-opacity:0 !default;
$spui-button-before-background-color:#000 !default;
$spui-button-before-border-color:#000 !default;
$spui-button-active-before-opacity:.15 !default;
$spui-button-icon-margin-left:4px !default;
$spui-button-plain-u-button-info-color:$sp-info;
$spui-button-plain-u-button-success-color:$sp-success;
$spui-button-plain-u-button-error-color:$sp-error;
$spui-button-plain-u-button-warning-color:$sp-error;

.u-button {
	width: 100%;
	
	&__text {
		white-space: nowrap;
		line-height: 1;
	}
	
	&:before {
		position: absolute;
		top:$spui-button-before-top;
		left:$spui-button-before-left;
		width:$spui-button-before-width;
		height:$spui-button-before-height;
		border: inherit;
		border-radius: inherit;
		transform:$spui-button-before-transform;
		opacity:$spui-button-before-opacity;
		content: " ";
		background-color:$spui-button-before-background-color;
		border-color:$spui-button-before-border-color;
	}
	
	&--active {
		&:before {
			opacity: .15
		}
	}
	
	&__icon+&__text:not(:empty),
	&__loading-text {
		margin-left:$spui-button-icon-margin-left;
	}
	
	&--plain {
		&.u-button--primary {
			color: $sp-primary;
		}
	}
	
	&--plain {
		&.u-button--info {
			color:$spui-button-plain-u-button-info-color;
		}
	}
	
	&--plain {
		&.u-button--success {
			color:$spui-button-plain-u-button-success-color;
		}
	}
	
	&--plain {
		&.u-button--error {
			color:$spui-button-plain-u-button-error-color;
		}
	}
	
	&--plain {
		&.u-button--warning {
			color:$spui-button-plain-u-button-warning-color;
		}
	}
}
