164 lines
3.0 KiB
SCSS
164 lines
3.0 KiB
SCSS
|
|
$ao-primary: #4C97E7;
|
||
|
|
$ao-primary-deep: #3A7EDB;
|
||
|
|
$ao-ink: #2E4975;
|
||
|
|
$ao-text: #303A4B;
|
||
|
|
$ao-text-secondary: #8B97A8;
|
||
|
|
$ao-text-muted: #9AA7B8;
|
||
|
|
$ao-text-placeholder: #C7CDD3;
|
||
|
|
$ao-border: #E6ECF3;
|
||
|
|
$ao-bg-page: #EEF3FA;
|
||
|
|
$ao-bg-card: #fff;
|
||
|
|
$ao-bg-field: #fff;
|
||
|
|
$ao-bg-active: #fff;
|
||
|
|
$ao-accent: #FF8A3D;
|
||
|
|
$ao-success: #3AC17C;
|
||
|
|
$ao-radius: 20rpx;
|
||
|
|
$ao-radius-sm: 16rpx;
|
||
|
|
$ao-section-gap: 32rpx;
|
||
|
|
$ao-title-gap: 20rpx;
|
||
|
|
|
||
|
|
@mixin ao-section {
|
||
|
|
margin-bottom: $ao-section-gap;
|
||
|
|
}
|
||
|
|
|
||
|
|
@mixin ao-section-head {
|
||
|
|
display: flex;
|
||
|
|
align-items: center;
|
||
|
|
margin-bottom: $ao-title-gap;
|
||
|
|
|
||
|
|
&::before {
|
||
|
|
content: '';
|
||
|
|
width: 6rpx;
|
||
|
|
height: 28rpx;
|
||
|
|
border-radius: 3rpx;
|
||
|
|
background: linear-gradient(180deg, $ao-primary, $ao-primary-deep);
|
||
|
|
margin-right: 14rpx;
|
||
|
|
flex-shrink: 0;
|
||
|
|
}
|
||
|
|
}
|
||
|
|
|
||
|
|
@mixin ao-section-title {
|
||
|
|
font-size: 30rpx;
|
||
|
|
font-weight: 600;
|
||
|
|
color: $ao-ink;
|
||
|
|
line-height: 1.2;
|
||
|
|
}
|
||
|
|
|
||
|
|
@mixin ao-section-tag {
|
||
|
|
margin-left: 12rpx;
|
||
|
|
font-size: 22rpx;
|
||
|
|
color: $ao-text-muted;
|
||
|
|
background: $ao-bg-card;
|
||
|
|
border: 1rpx solid $ao-border;
|
||
|
|
border-radius: 8rpx;
|
||
|
|
padding: 4rpx 12rpx;
|
||
|
|
}
|
||
|
|
|
||
|
|
@mixin ao-card {
|
||
|
|
background: $ao-bg-card;
|
||
|
|
border-radius: $ao-radius;
|
||
|
|
border: 1rpx solid $ao-border;
|
||
|
|
box-sizing: border-box;
|
||
|
|
}
|
||
|
|
|
||
|
|
@mixin ao-field-box {
|
||
|
|
display: flex;
|
||
|
|
align-items: center;
|
||
|
|
height: 88rpx;
|
||
|
|
background: $ao-bg-field;
|
||
|
|
border: 1rpx solid $ao-border;
|
||
|
|
border-radius: $ao-radius-sm;
|
||
|
|
padding: 0 24rpx;
|
||
|
|
box-sizing: border-box;
|
||
|
|
}
|
||
|
|
|
||
|
|
@mixin ao-option-item {
|
||
|
|
display: flex;
|
||
|
|
align-items: center;
|
||
|
|
background: $ao-bg-card;
|
||
|
|
border-radius: $ao-radius-sm;
|
||
|
|
padding: 24rpx;
|
||
|
|
margin-bottom: 16rpx;
|
||
|
|
border: 2rpx solid $ao-border;
|
||
|
|
box-sizing: border-box;
|
||
|
|
transition: border-color 0.15s, background-color 0.15s;
|
||
|
|
|
||
|
|
&.active {
|
||
|
|
background: $ao-bg-card;
|
||
|
|
border-color: $ao-primary;
|
||
|
|
}
|
||
|
|
|
||
|
|
&:last-child {
|
||
|
|
margin-bottom: 0;
|
||
|
|
}
|
||
|
|
}
|
||
|
|
|
||
|
|
@mixin ao-radio {
|
||
|
|
width: 36rpx;
|
||
|
|
height: 36rpx;
|
||
|
|
border-radius: 50%;
|
||
|
|
border: 3rpx solid #D2DAE5;
|
||
|
|
flex-shrink: 0;
|
||
|
|
box-sizing: border-box;
|
||
|
|
|
||
|
|
&.checked {
|
||
|
|
border-color: $ao-primary;
|
||
|
|
background: $ao-primary;
|
||
|
|
position: relative;
|
||
|
|
|
||
|
|
&::after {
|
||
|
|
content: '';
|
||
|
|
position: absolute;
|
||
|
|
left: 50%;
|
||
|
|
top: 50%;
|
||
|
|
width: 12rpx;
|
||
|
|
height: 12rpx;
|
||
|
|
border-radius: 50%;
|
||
|
|
background: #fff;
|
||
|
|
transform: translate(-50%, -50%);
|
||
|
|
}
|
||
|
|
}
|
||
|
|
}
|
||
|
|
|
||
|
|
@mixin ao-empty-tip {
|
||
|
|
text-align: center;
|
||
|
|
font-size: 26rpx;
|
||
|
|
color: #B0BAC7;
|
||
|
|
padding: 32rpx 0;
|
||
|
|
background: $ao-bg-card;
|
||
|
|
border-radius: $ao-radius-sm;
|
||
|
|
border: 1rpx dashed $ao-border;
|
||
|
|
}
|
||
|
|
|
||
|
|
@mixin ao-primary-btn {
|
||
|
|
height: 88rpx;
|
||
|
|
padding: 0 36rpx;
|
||
|
|
background: linear-gradient(135deg, $ao-primary, $ao-primary-deep);
|
||
|
|
border-radius: $ao-radius-sm;
|
||
|
|
display: flex;
|
||
|
|
align-items: center;
|
||
|
|
justify-content: center;
|
||
|
|
font-size: 30rpx;
|
||
|
|
color: #fff;
|
||
|
|
font-weight: 500;
|
||
|
|
box-shadow: 0 6rpx 16rpx rgba(76, 151, 231, 0.24);
|
||
|
|
}
|
||
|
|
|
||
|
|
@mixin ao-panel-soft {
|
||
|
|
@include ao-card;
|
||
|
|
}
|
||
|
|
|
||
|
|
@mixin ao-popup-head {
|
||
|
|
display: flex;
|
||
|
|
align-items: center;
|
||
|
|
justify-content: space-between;
|
||
|
|
padding: 28rpx 0 20rpx;
|
||
|
|
border-bottom: 1rpx solid #F0F3F8;
|
||
|
|
}
|
||
|
|
|
||
|
|
@mixin ao-popup-panel {
|
||
|
|
background: #fff;
|
||
|
|
padding: 0 32rpx calc(24rpx + env(safe-area-inset-bottom));
|
||
|
|
box-sizing: border-box;
|
||
|
|
}
|