From 93de43267e1663031fe5dc2f5ae40d128a182a76 Mon Sep 17 00:00:00 2001
From: doum <doum>
Date: 星期四, 18 六月 2026 17:24:51 +0800
Subject: [PATCH] 新增智能电表、空调管理

---
 h5/styles/customer.scss | 1115 +++++++++++++++++++++++++++++++++++++++++++++++++++++++++
 1 files changed, 1,097 insertions(+), 18 deletions(-)

diff --git a/h5/styles/customer.scss b/h5/styles/customer.scss
index f6723d5..8b7223e 100644
--- a/h5/styles/customer.scss
+++ b/h5/styles/customer.scss
@@ -41,6 +41,87 @@
   align-items: center;
 }
 
+.cu-profile-bar {
+  display: flex;
+  align-items: center;
+  justify-content: space-between;
+  gap: 16rpx;
+}
+
+.cu-profile-bar__info {
+  display: flex;
+  align-items: center;
+  flex: 1;
+  min-width: 0;
+}
+
+.cu-profile-actions {
+  display: flex;
+  align-items: center;
+  gap: 16rpx;
+  flex-shrink: 0;
+}
+
+.cu-profile-action {
+  width: 72rpx;
+  height: 72rpx;
+  border-radius: 50%;
+  background: rgba(255, 255, 255, 0.2);
+  border: 2rpx solid rgba(255, 255, 255, 0.35);
+  display: flex;
+  align-items: center;
+  justify-content: center;
+  transition: opacity 0.2s ease;
+}
+
+.cu-profile-action--pill {
+  width: auto;
+  height: 56rpx;
+  padding: 0 20rpx;
+  border-radius: 999rpx;
+  gap: 6rpx;
+  flex-direction: row;
+  background: rgba(255, 255, 255, 0.18);
+  border: 2rpx solid rgba(255, 255, 255, 0.4);
+}
+
+.cu-profile-action__text {
+  font-size: 24rpx;
+  color: #fff;
+  line-height: 1;
+  font-weight: 500;
+}
+
+.cu-profile-action:active {
+  opacity: 0.75;
+}
+
+/* 鍟嗘埛瀛愰〉鍥為椤� */
+.cu-workbench-fab {
+  position: fixed;
+  top: 50%;
+  right: 24rpx;
+  z-index: 200;
+  display: flex;
+  align-items: center;
+  justify-content: center;
+  width: 84rpx;
+  height: 84rpx;
+  padding: 0;
+  border-radius: 50%;
+  background: rgba(255, 255, 255, 0.96);
+  border: 1rpx solid rgba(15, 35, 95, 0.08);
+  box-shadow: 0 6rpx 24rpx rgba(15, 35, 95, 0.1);
+  transform: translateY(-50%);
+  transition: transform 0.2s ease, box-shadow 0.2s ease, opacity 0.2s ease;
+}
+
+.cu-workbench-fab:active {
+  transform: translateY(-50%) scale(0.96);
+  opacity: 0.94;
+  box-shadow: 0 4rpx 16rpx rgba(15, 35, 95, 0.08);
+}
+
 .cu-avatar {
   width: 88rpx;
   height: 88rpx;
@@ -89,12 +170,147 @@
   padding-left: 8rpx;
 }
 
+.cu-service-panel {
+  background: $cu-card-bg;
+  border-radius: $cu-radius;
+  padding: 28rpx 20rpx 20rpx;
+  box-shadow: $cu-shadow;
+  border: 1rpx solid rgba(15, 35, 95, 0.04);
+}
+
+.cu-section-head {
+  display: flex;
+  align-items: center;
+  gap: 12rpx;
+  margin-bottom: 24rpx;
+  padding: 0 8rpx;
+}
+
+.cu-section-head__bar {
+  width: 6rpx;
+  height: 28rpx;
+  border-radius: 4rpx;
+  background: linear-gradient(180deg, #2080f7 0%, #4a9bff 100%);
+  flex-shrink: 0;
+}
+
+.cu-section-head__title {
+  font-size: 32rpx;
+  font-weight: 600;
+  color: $cu-text;
+  line-height: 1.2;
+}
+
 .cu-service-grid {
   display: flex;
   flex-wrap: wrap;
-  gap: 20rpx;
+  gap: 16rpx;
 }
 
+.cu-service-card {
+  width: calc(50% - 8rpx);
+  background: linear-gradient(180deg, #fafbfd 0%, #fff 100%);
+  border-radius: 20rpx;
+  padding: 22rpx 20rpx 24rpx;
+  border: 1rpx solid rgba(15, 35, 95, 0.06);
+  box-sizing: border-box;
+  position: relative;
+  overflow: hidden;
+  transition: transform 0.2s ease, opacity 0.2s ease;
+}
+
+.cu-service-card::before {
+  content: '';
+  position: absolute;
+  top: 0;
+  left: 0;
+  right: 0;
+  height: 4rpx;
+}
+
+.cu-service-card:active {
+  transform: scale(0.98);
+  opacity: 0.92;
+}
+
+.cu-service-card__top {
+  display: flex;
+  justify-content: space-between;
+  align-items: flex-start;
+  margin-bottom: 14rpx;
+}
+
+.cu-service-card__icon {
+  width: 76rpx;
+  height: 76rpx;
+  border-radius: 22rpx;
+  display: flex;
+  align-items: center;
+  justify-content: center;
+  flex-shrink: 0;
+}
+
+.cu-service-card__arrow {
+  font-size: 36rpx;
+  color: rgba(154, 163, 178, 0.7);
+  line-height: 1;
+  font-weight: 300;
+  margin-top: 4rpx;
+}
+
+.cu-service-card__label {
+  display: block;
+  font-size: 30rpx;
+  font-weight: 600;
+  color: $cu-text;
+  line-height: 1.3;
+}
+
+.cu-service-card__desc {
+  display: block;
+  font-size: 22rpx;
+  color: $cu-text-muted;
+  margin-top: 8rpx;
+  line-height: 1.4;
+}
+
+.cu-service-card--electric::before {
+  background: linear-gradient(90deg, #fa8c16 0%, #ffc069 100%);
+}
+
+.cu-service-card--electric .cu-service-card__icon {
+  background: linear-gradient(135deg, #fff7e6 0%, #ffe7ba 100%);
+  box-shadow: 0 6rpx 16rpx rgba(250, 140, 22, 0.15);
+}
+
+.cu-service-card--contract::before {
+  background: linear-gradient(90deg, #40a9ff 0%, #69c0ff 100%);
+}
+
+.cu-service-card--contract .cu-service-card__icon {
+  background: linear-gradient(135deg, #e6f4ff 0%, #bae7ff 100%);
+  box-shadow: 0 6rpx 16rpx rgba(64, 169, 255, 0.18);
+}
+
+.cu-service-card--bill::before {
+  background: linear-gradient(90deg, #597ef7 0%, #85a5ff 100%);
+}
+
+.cu-service-card--bill .cu-service-card__icon {
+  background: linear-gradient(135deg, #eef2ff 0%, #d6e4ff 100%);
+  box-shadow: 0 6rpx 16rpx rgba(89, 126, 247, 0.15);
+}
+
+.cu-service-card--record::before {
+  background: linear-gradient(90deg, #9254de 0%, #b37feb 100%);
+}
+
+.cu-service-card--record .cu-service-card__icon {
+  background: linear-gradient(135deg, #f9f0ff 0%, #efdbff 100%);
+  box-shadow: 0 6rpx 16rpx rgba(146, 84, 222, 0.15);
+}
+
+/* 鍏煎鏃х被鍚� */
 .cu-service-item {
   width: calc(50% - 10rpx);
   background: $cu-card-bg;
@@ -137,25 +353,112 @@
 .cu-service-item--bill .cu-service-item__icon { background: #eef2ff; }
 .cu-service-item--record .cu-service-item__icon { background: #fce8f3; }
 
-.cu-footer-bar {
-  margin-top: 64rpx;
-  display: flex;
-  justify-content: center;
-  gap: 24rpx;
+/* 璁よ瘉 / 瑙掕壊閫夋嫨 */
+.cu-auth-page {
+  min-height: 100vh;
+  padding: 120rpx 48rpx 48rpx;
+  background: linear-gradient(180deg, #dce9ff 0%, #f4f6fb 45%, #fff 100%);
+  box-sizing: border-box;
 }
 
-.cu-footer-btn {
-  font-size: 28rpx;
-  padding: 18rpx 48rpx;
-  border-radius: 999rpx;
-  background: #fff;
-  color: $cu-text-secondary;
+.cu-auth-page__title {
+  font-size: 44rpx;
+  font-weight: 700;
+  color: $cu-text;
+  margin-bottom: 12rpx;
+}
+
+.cu-auth-page__sub {
+  font-size: 26rpx;
+  color: $cu-text-muted;
+  margin-bottom: 48rpx;
+  line-height: 1.5;
+}
+
+.cu-role-card {
+  display: flex;
+  align-items: center;
+  background: $cu-card-bg;
+  border-radius: $cu-radius;
+  padding: 32rpx 28rpx;
+  margin-bottom: 24rpx;
   box-shadow: $cu-shadow;
 }
 
-.cu-footer-btn--primary {
-  color: $cu-primary;
-  border: 1rpx solid rgba(32, 128, 247, 0.35);
+.cu-role-card:active {
+  opacity: 0.92;
+}
+
+.cu-role-card__icon {
+  width: 88rpx;
+  height: 88rpx;
+  border-radius: 22rpx;
+  display: flex;
+  align-items: center;
+  justify-content: center;
+  margin-right: 24rpx;
+  flex-shrink: 0;
+}
+
+.cu-role-card--ops .cu-role-card__icon {
+  background: linear-gradient(135deg, #e6f4ff 0%, #bae7ff 100%);
+  box-shadow: 0 6rpx 16rpx rgba(105, 192, 255, 0.28);
+}
+
+.cu-role-card--merchant .cu-role-card__icon {
+  background: linear-gradient(135deg, #fff7e6 0%, #ffe7ba 100%);
+  box-shadow: 0 6rpx 16rpx rgba(250, 173, 20, 0.22);
+}
+
+.cu-role-card__main {
+  flex: 1;
+  min-width: 0;
+}
+
+.cu-role-card__name {
+  font-size: 34rpx;
+  font-weight: 600;
+  color: $cu-text;
+  margin-bottom: 8rpx;
+}
+
+.cu-role-card__desc {
+  font-size: 24rpx;
+  color: $cu-text-muted;
+  line-height: 1.4;
+}
+
+.cu-role-card__arrow {
+  font-size: 32rpx;
+  color: $cu-text-muted;
+  flex-shrink: 0;
+  margin-left: 12rpx;
+}
+
+.cu-auth-topbar {
+  position: fixed;
+  top: 0;
+  left: 0;
+  right: 0;
+  z-index: 10;
+  display: flex;
+  justify-content: flex-end;
+  padding: 24rpx 32rpx;
+}
+
+.cu-auth-topbar__btn {
+  width: 72rpx;
+  height: 72rpx;
+  border-radius: 50%;
+  background: rgba(255, 255, 255, 0.9);
+  box-shadow: $cu-shadow;
+  display: flex;
+  align-items: center;
+  justify-content: center;
+}
+
+.cu-auth-topbar__btn:active {
+  opacity: 0.8;
 }
 
 /* 鍗$墖 */
@@ -229,10 +532,13 @@
 
 /* 鐘舵�� */
 .cu-status {
+  flex-shrink: 0;
+  white-space: nowrap;
   font-size: 24rpx;
   padding: 4rpx 16rpx;
   border-radius: 999rpx;
   font-weight: 500;
+  line-height: 1.4;
 }
 
 .cu-status--ok {
@@ -402,7 +708,9 @@
 .cu-login {
   min-height: 100vh;
   padding: 120rpx 48rpx 48rpx;
+  padding-top: 160rpx;
   background: linear-gradient(180deg, #dce9ff 0%, #f4f6fb 45%, #fff 100%);
+  box-sizing: border-box;
 }
 
 .cu-login__brand {
@@ -509,6 +817,200 @@
   padding: 8rpx 24rpx 16rpx;
 }
 
+.cu-list-header--inline {
+  padding: 0 8rpx 12rpx;
+}
+
+.cu-device-page .cu-list-wrap {
+  padding-top: 0;
+}
+
+.cu-device-page__header {
+  padding-bottom: 8rpx;
+}
+
+.cu-device-type-tabs {
+  display: flex;
+  gap: 20rpx;
+  margin: 24rpx 24rpx 20rpx;
+}
+
+.cu-device-type-card {
+  flex: 1;
+  display: flex;
+  align-items: center;
+  gap: 16rpx;
+  padding: 22rpx 20rpx;
+  background: $cu-card-bg;
+  border-radius: $cu-radius;
+  box-shadow: $cu-shadow;
+  border: 2rpx solid transparent;
+  transition: all 0.22s ease;
+  box-sizing: border-box;
+}
+
+.cu-device-type-card:active {
+  transform: scale(0.97);
+}
+
+.cu-device-type-card__icon-wrap {
+  width: 72rpx;
+  height: 72rpx;
+  border-radius: 20rpx;
+  display: flex;
+  align-items: center;
+  justify-content: center;
+  flex-shrink: 0;
+  transition: background 0.22s ease;
+}
+
+.cu-device-type-card__icon {
+  font-size: 34rpx;
+  line-height: 1;
+}
+
+.cu-device-type-card__text {
+  flex: 1;
+  min-width: 0;
+}
+
+.cu-device-type-card__label {
+  display: block;
+  font-size: 30rpx;
+  font-weight: 600;
+  color: $cu-text;
+  line-height: 1.3;
+  transition: color 0.22s ease;
+}
+
+.cu-device-type-card__hint {
+  display: block;
+  font-size: 22rpx;
+  color: $cu-text-muted;
+  margin-top: 4rpx;
+  line-height: 1.3;
+  transition: color 0.22s ease;
+}
+
+.cu-device-type-card--electric .cu-device-type-card__icon-wrap {
+  background: linear-gradient(135deg, #fff7e6, #ffe8b3);
+}
+
+.cu-device-type-card--conditioner .cu-device-type-card__icon-wrap {
+  background: linear-gradient(135deg, #e8f7ef, #c8f0dc);
+}
+
+.cu-device-type-card--electric:not(.cu-device-type-card--active) {
+  border-color: rgba(250, 140, 22, 0.18);
+}
+
+.cu-device-type-card--conditioner:not(.cu-device-type-card--active) {
+  border-color: rgba(25, 190, 107, 0.18);
+}
+
+.cu-device-type-card--electric.cu-device-type-card--active {
+  background: linear-gradient(135deg, #ffb347 0%, #fa8c16 100%);
+  border-color: transparent;
+  box-shadow: 0 10rpx 28rpx rgba(250, 140, 22, 0.32);
+}
+
+.cu-device-type-card--electric.cu-device-type-card--active .cu-device-type-card__icon-wrap {
+  background: rgba(255, 255, 255, 0.28);
+}
+
+.cu-device-type-card--electric.cu-device-type-card--active .cu-device-type-card__label,
+.cu-device-type-card--electric.cu-device-type-card--active .cu-device-type-card__hint {
+  color: #fff;
+}
+
+.cu-device-type-card--electric.cu-device-type-card--active .cu-device-type-card__hint {
+  opacity: 0.88;
+}
+
+.cu-device-type-card--conditioner.cu-device-type-card--active {
+  background: linear-gradient(135deg, #5cdbd3 0%, #13c2c2 100%);
+  border-color: transparent;
+  box-shadow: 0 10rpx 28rpx rgba(19, 194, 194, 0.32);
+}
+
+.cu-device-type-card--conditioner.cu-device-type-card--active .cu-device-type-card__icon-wrap {
+  background: rgba(255, 255, 255, 0.28);
+}
+
+.cu-device-type-card--conditioner.cu-device-type-card--active .cu-device-type-card__label,
+.cu-device-type-card--conditioner.cu-device-type-card--active .cu-device-type-card__hint {
+  color: #fff;
+}
+
+.cu-device-type-card--conditioner.cu-device-type-card--active .cu-device-type-card__hint {
+  opacity: 0.88;
+}
+
+.cu-ac-balance-card {
+  display: flex;
+  align-items: center;
+  justify-content: space-between;
+  gap: 20rpx;
+  margin: 0 24rpx 16rpx;
+  padding: 28rpx 24rpx;
+  background: linear-gradient(135deg, #f0f7ff 0%, #fff 100%);
+  border-radius: $cu-radius;
+  border: 1rpx solid rgba(32, 128, 247, 0.12);
+  box-shadow: $cu-shadow;
+}
+
+.cu-ac-balance-card__main {
+  flex: 1;
+  min-width: 0;
+}
+
+.cu-ac-balance-card__label {
+  display: block;
+  font-size: 24rpx;
+  color: $cu-text-muted;
+  margin-bottom: 8rpx;
+}
+
+.cu-ac-balance-card__value {
+  display: block;
+  font-size: 44rpx;
+  font-weight: 700;
+  color: $cu-primary;
+  line-height: 1.2;
+}
+
+.cu-ac-balance-card__value--danger {
+  color: $cu-danger;
+}
+
+.cu-ac-balance-card__value--success {
+  color: $cu-success;
+}
+
+.cu-ac-balance-card__btn {
+  flex-shrink: 0;
+  padding: 16rpx 32rpx;
+  background: linear-gradient(135deg, #2080f7 0%, #4a9bff 100%);
+  border-radius: 999rpx;
+  font-size: 26rpx;
+  font-weight: 600;
+  color: #fff;
+  box-shadow: 0 6rpx 18rpx rgba(32, 128, 247, 0.28);
+}
+
+.cu-ac-balance-card__btn:active {
+  opacity: 0.9;
+}
+
+.cu-list-card--readonly .cu-list-card__meta-row {
+  padding: 16rpx 24rpx 24rpx;
+  border-top: 1rpx solid #f0f2f6;
+}
+
+.cu-list-card__meta-row {
+  padding: 0 24rpx 24rpx;
+}
+
 .cu-list-header__count {
   font-size: 24rpx;
   color: $cu-text-muted;
@@ -570,13 +1072,21 @@
   justify-content: space-between;
   gap: 12rpx;
   margin-bottom: 8rpx;
+  min-width: 0;
+}
+
+.cu-list-card__title-wrap {
+  flex: 1;
+  min-width: 0;
+  overflow: hidden;
 }
 
 .cu-list-card__title {
+  display: block;
   font-size: 30rpx;
   font-weight: 600;
   color: $cu-text;
-  flex: 1;
+  width: 100%;
   overflow: hidden;
   text-overflow: ellipsis;
   white-space: nowrap;
@@ -645,6 +1155,10 @@
 
 .cu-info-cell__value--danger {
   color: $cu-danger;
+}
+
+.cu-info-cell__value--success {
+  color: $cu-success;
 }
 
 .cu-info-cell__value--primary {
@@ -1067,6 +1581,163 @@
 }
 
 /* 鍏呭��/缂磋垂椤� */
+.cu-recharge-hero {
+  margin: 24rpx 24rpx 0;
+  border-radius: $cu-radius;
+  overflow: hidden;
+  box-shadow: $cu-shadow;
+}
+
+.cu-recharge-hero__gradient {
+  padding: 40rpx 32rpx 56rpx;
+  background: linear-gradient(145deg, #2080f7 0%, #4a9bff 52%, #6eb3ff 100%);
+}
+
+.cu-recharge-hero--electric .cu-recharge-hero__gradient {
+  background: linear-gradient(145deg, #1a6fe0 0%, #2080f7 45%, #ffb84d 165%);
+}
+
+.cu-recharge-hero__balance-block {
+  text-align: center;
+}
+
+.cu-recharge-hero__balance-label {
+  display: block;
+  font-size: 24rpx;
+  color: rgba(255, 255, 255, 0.88);
+  margin-bottom: 12rpx;
+  letter-spacing: 1rpx;
+}
+
+.cu-recharge-hero__balance-value {
+  display: block;
+  font-size: 64rpx;
+  font-weight: 700;
+  color: #fff;
+  line-height: 1.15;
+  font-variant-numeric: tabular-nums;
+}
+
+.cu-recharge-hero__balance-value--danger {
+  color: #ffb4b0;
+  text-shadow: 0 2rpx 8rpx rgba(250, 53, 52, 0.35);
+}
+
+.cu-recharge-hero__balance-value--success {
+  color: #b8f5d0;
+  text-shadow: 0 2rpx 8rpx rgba(25, 190, 107, 0.35);
+}
+
+.cu-recharge-hero__panel {
+  margin-top: -28rpx;
+  padding: 28rpx 24rpx 24rpx;
+  background: $cu-card-bg;
+  border-radius: $cu-radius $cu-radius 0 0;
+}
+
+.cu-recharge-hero__device {
+  display: flex;
+  align-items: flex-start;
+  gap: 20rpx;
+  padding-bottom: 20rpx;
+  border-bottom: 1rpx solid #f0f2f6;
+}
+
+.cu-recharge-hero__icon {
+  width: 80rpx;
+  height: 80rpx;
+  border-radius: 20rpx;
+  display: flex;
+  align-items: center;
+  justify-content: center;
+  font-size: 38rpx;
+  flex-shrink: 0;
+}
+
+.cu-recharge-hero__icon--electric {
+  background: linear-gradient(135deg, #fff7e6, #ffe8b3);
+}
+
+.cu-recharge-hero__device-main {
+  flex: 1;
+  min-width: 0;
+}
+
+.cu-recharge-hero__title-row {
+  display: flex;
+  align-items: center;
+  justify-content: space-between;
+  gap: 12rpx;
+  margin-bottom: 8rpx;
+  min-width: 0;
+}
+
+.cu-recharge-hero__title-wrap {
+  flex: 1;
+  min-width: 0;
+  overflow: hidden;
+}
+
+.cu-recharge-hero__title {
+  display: block;
+  font-size: 30rpx;
+  font-weight: 600;
+  color: $cu-text;
+  overflow: hidden;
+  text-overflow: ellipsis;
+  white-space: nowrap;
+  width: 100%;
+}
+
+.cu-recharge-hero__status {
+  flex-shrink: 0;
+  font-size: 22rpx;
+  padding: 4rpx 14rpx;
+  border-radius: 999rpx;
+}
+
+.cu-recharge-hero__status--ok {
+  color: $cu-success;
+  background: rgba(25, 190, 107, 0.12);
+}
+
+.cu-recharge-hero__status--bad {
+  color: $cu-danger;
+  background: rgba(250, 53, 52, 0.1);
+}
+
+.cu-recharge-hero__sub {
+  display: block;
+  font-size: 24rpx;
+  color: $cu-text-secondary;
+  line-height: 1.5;
+}
+
+.cu-recharge-hero__meta {
+  padding-top: 20rpx;
+}
+
+.cu-recharge-hero__meta-item {
+  display: flex;
+  align-items: center;
+  justify-content: space-between;
+  gap: 16rpx;
+}
+
+.cu-recharge-hero__meta-label {
+  font-size: 24rpx;
+  color: $cu-text-muted;
+  flex-shrink: 0;
+}
+
+.cu-recharge-hero__meta-value {
+  font-size: 26rpx;
+  color: $cu-text;
+  font-weight: 500;
+  text-align: right;
+  word-break: break-all;
+}
+
 .cu-device-summary {
   margin: 24rpx 24rpx 0;
   padding: 28rpx;
@@ -1075,12 +1746,19 @@
   box-shadow: $cu-shadow;
 }
 
+.cu-device-summary__title {
+  font-size: 28rpx;
+  font-weight: 600;
+  color: $cu-text;
+  margin-bottom: 4rpx;
+}
+
 .cu-device-summary__balance {
   margin-top: 20rpx;
   padding: 24rpx;
-  background: linear-gradient(135deg, #fff5f5, #fff);
+  background: linear-gradient(135deg, #f0f7ff 0%, #fff 100%);
   border-radius: 16rpx;
-  border: 1rpx solid rgba(250, 53, 52, 0.12);
+  border: 1rpx solid rgba(32, 128, 247, 0.12);
   text-align: center;
 }
 
@@ -1093,7 +1771,15 @@
 .cu-device-summary__balance-value {
   font-size: 48rpx;
   font-weight: 700;
+  color: $cu-primary;
+}
+
+.cu-device-summary__balance-value--danger {
   color: $cu-danger;
+}
+
+.cu-device-summary__balance-value--success {
+  color: $cu-success;
 }
 
 .cu-pay-amount-box {
@@ -1277,6 +1963,399 @@
   transform: translateY(2rpx);
 }
 
+.cu-bill-cost-picker--status-ok {
+  border-color: #52c41a;
+  background: linear-gradient(135deg, #f0faf4 0%, #fff 100%);
+}
+
+.cu-bill-cost-picker--status-ok .cu-bill-cost-picker__label {
+  color: $cu-text;
+  font-weight: 600;
+}
+
+.cu-bill-cost-picker--status-bad {
+  border-color: $cu-danger;
+  background: linear-gradient(135deg, #fff1f0 0%, #fff 100%);
+}
+
+.cu-bill-cost-picker--status-bad .cu-bill-cost-picker__label {
+  color: $cu-danger;
+  font-weight: 600;
+}
+
+.cu-bill-cost-picker--status-pending {
+  border-color: $cu-warning;
+  background: linear-gradient(135deg, #fff7e6 0%, #fff 100%);
+}
+
+.cu-bill-cost-picker--status-pending .cu-bill-cost-picker__label {
+  color: $cu-warning;
+  font-weight: 600;
+}
+
+.cu-recharge-record-page__header {
+  padding: 24rpx 24rpx 8rpx;
+}
+
+.cu-recharge-filter-panel {
+  background: $cu-card-bg;
+  border-radius: $cu-radius;
+  box-shadow: $cu-shadow;
+  padding: 24rpx;
+  margin-bottom: 16rpx;
+}
+
+.cu-recharge-filter-panel__section + .cu-recharge-filter-panel__section {
+  margin-top: 0;
+}
+
+.cu-recharge-filter-panel__label {
+  display: block;
+  font-size: 24rpx;
+  color: $cu-text-muted;
+  margin-bottom: 16rpx;
+  line-height: 1.2;
+}
+
+.cu-recharge-filter-panel__row {
+  display: flex;
+  align-items: center;
+  justify-content: space-between;
+  gap: 16rpx;
+  margin-bottom: 16rpx;
+}
+
+.cu-recharge-filter-panel__row .cu-recharge-filter-panel__label {
+  margin-bottom: 0;
+  flex-shrink: 0;
+}
+
+.cu-recharge-filter-panel__divider {
+  height: 1rpx;
+  background: #f0f2f6;
+  margin: 24rpx 0;
+}
+
+.cu-recharge-filter-panel__dates {
+  display: flex;
+  align-items: center;
+  flex-wrap: wrap;
+  gap: 12rpx;
+}
+
+.cu-recharge-status-tabs {
+  white-space: nowrap;
+  width: 100%;
+}
+
+.cu-recharge-status-tab {
+  display: inline-block;
+  padding: 14rpx 28rpx;
+  margin-right: 12rpx;
+  font-size: 26rpx;
+  color: $cu-text-secondary;
+  background: #f4f6fb;
+  border-radius: 999rpx;
+  line-height: 1.2;
+  border: 2rpx solid transparent;
+  transition: all 0.2s ease;
+}
+
+.cu-recharge-status-tab:last-child {
+  margin-right: 0;
+}
+
+.cu-recharge-status-tab--active {
+  color: $cu-primary;
+  background: linear-gradient(135deg, #e8f2ff 0%, #f0f7ff 100%);
+  border-color: rgba(32, 128, 247, 0.25);
+  font-weight: 600;
+}
+
+.cu-recharge-status-tab--active.cu-recharge-status-tab--ok {
+  color: $cu-success;
+  background: linear-gradient(135deg, #f0faf4 0%, #fff 100%);
+  border-color: rgba(25, 190, 107, 0.25);
+}
+
+.cu-recharge-status-tab--active.cu-recharge-status-tab--bad {
+  color: $cu-danger;
+  background: linear-gradient(135deg, #fff1f0 0%, #fff 100%);
+  border-color: rgba(250, 53, 52, 0.25);
+}
+
+.cu-recharge-status-tab--active.cu-recharge-status-tab--pending {
+  color: $cu-warning;
+  background: linear-gradient(135deg, #fff7e6 0%, #fff 100%);
+  border-color: rgba(255, 153, 0, 0.25);
+}
+
+.cu-recharge-date-mode {
+  display: flex;
+  padding: 4rpx;
+  background: #eef1f6;
+  border-radius: 999rpx;
+  flex-shrink: 0;
+}
+
+.cu-recharge-date-mode__item {
+  padding: 10rpx 22rpx;
+  font-size: 22rpx;
+  color: $cu-text-secondary;
+  border-radius: 999rpx;
+  line-height: 1.2;
+}
+
+.cu-recharge-date-mode__item--active {
+  background: #fff;
+  color: $cu-primary;
+  font-weight: 600;
+  box-shadow: 0 4rpx 12rpx rgba(15, 35, 95, 0.08);
+}
+
+.cu-recharge-date-range {
+  display: flex;
+  align-items: center;
+  gap: 12rpx;
+  flex: 1;
+  min-width: 0;
+}
+
+.cu-recharge-date-field {
+  flex: 1;
+  min-width: 0;
+  display: flex;
+  align-items: center;
+  justify-content: space-between;
+  gap: 8rpx;
+  padding: 16rpx 20rpx;
+  background: #f8fafc;
+  border-radius: 16rpx;
+  border: 2rpx solid #eef1f6;
+}
+
+.cu-recharge-date-field--active {
+  background: #f0f7ff;
+  border-color: rgba(32, 128, 247, 0.2);
+}
+
+.cu-recharge-date-field__text {
+  flex: 1;
+  min-width: 0;
+  font-size: 26rpx;
+  color: $cu-text-secondary;
+  line-height: 1.3;
+  overflow: hidden;
+  text-overflow: ellipsis;
+  white-space: nowrap;
+}
+
+.cu-recharge-date-field--active .cu-recharge-date-field__text {
+  color: $cu-primary;
+  font-weight: 600;
+}
+
+.cu-recharge-date-field__arrow {
+  flex-shrink: 0;
+  font-size: 22rpx;
+  color: $cu-text-muted;
+  line-height: 1;
+}
+
+.cu-recharge-date-sep {
+  flex-shrink: 0;
+  font-size: 24rpx;
+  color: $cu-text-muted;
+}
+
+.cu-recharge-date-clear {
+  flex-shrink: 0;
+  font-size: 24rpx;
+  color: $cu-primary;
+  padding: 8rpx 0;
+}
+
+.cu-recharge-summary {
+  display: flex;
+  align-items: baseline;
+  gap: 8rpx;
+  padding: 0 8rpx 16rpx;
+}
+
+.cu-recharge-summary__count {
+  font-size: 44rpx;
+  font-weight: 700;
+  color: $cu-text;
+  line-height: 1;
+}
+
+.cu-recharge-summary__label {
+  font-size: 26rpx;
+  color: $cu-text-muted;
+}
+
+.cu-recharge-record-page .cu-list-wrap {
+  padding-top: 0;
+}
+
+.cu-recharge-card {
+  display: flex;
+  background: $cu-card-bg;
+  border-radius: $cu-radius;
+  box-shadow: $cu-shadow;
+  overflow: hidden;
+  margin-bottom: 20rpx;
+}
+
+.cu-recharge-card__accent {
+  width: 8rpx;
+  flex-shrink: 0;
+}
+
+.cu-recharge-card__accent--electric {
+  background: linear-gradient(180deg, #ffc069 0%, #fa8c16 100%);
+}
+
+.cu-recharge-card__accent--conditioner {
+  background: linear-gradient(180deg, #5cdbd3 0%, #13c2c2 100%);
+}
+
+.cu-recharge-card__body {
+  flex: 1;
+  min-width: 0;
+  padding: 24rpx 24rpx 20rpx;
+}
+
+.cu-recharge-card__top {
+  display: flex;
+  align-items: center;
+  justify-content: space-between;
+  gap: 16rpx;
+  margin-bottom: 16rpx;
+}
+
+.cu-recharge-card__type {
+  display: flex;
+  align-items: center;
+  gap: 8rpx;
+  padding: 8rpx 16rpx;
+  border-radius: 999rpx;
+  flex-shrink: 0;
+}
+
+.cu-recharge-card__type--electric {
+  background: #fff7e6;
+}
+
+.cu-recharge-card__type--conditioner {
+  background: #e6fffb;
+}
+
+.cu-recharge-card__type-icon {
+  font-size: 22rpx;
+  line-height: 1;
+}
+
+.cu-recharge-card__type-text {
+  font-size: 22rpx;
+  font-weight: 600;
+  line-height: 1.2;
+}
+
+.cu-recharge-card__type--electric .cu-recharge-card__type-text {
+  color: #d46b08;
+}
+
+.cu-recharge-card__type--conditioner .cu-recharge-card__type-text {
+  color: #08979c;
+}
+
+.cu-recharge-card__title {
+  display: block;
+  font-size: 30rpx;
+  font-weight: 600;
+  color: $cu-text;
+  line-height: 1.4;
+  overflow: hidden;
+  text-overflow: ellipsis;
+  white-space: nowrap;
+}
+
+.cu-recharge-card__operator {
+  display: block;
+  font-size: 24rpx;
+  color: $cu-text-muted;
+  margin-top: 8rpx;
+  line-height: 1.4;
+}
+
+.cu-recharge-card__amount-box {
+  display: flex;
+  align-items: flex-end;
+  justify-content: space-between;
+  gap: 24rpx;
+  margin-top: 20rpx;
+  padding: 20rpx;
+  background: #f8fafc;
+  border-radius: 16rpx;
+}
+
+.cu-recharge-card__amount-main {
+  flex: 1;
+  min-width: 0;
+}
+
+.cu-recharge-card__amount-side {
+  flex-shrink: 0;
+  text-align: right;
+}
+
+.cu-recharge-card__amount-label {
+  display: block;
+  font-size: 22rpx;
+  color: $cu-text-muted;
+  margin-bottom: 8rpx;
+  line-height: 1.2;
+}
+
+.cu-recharge-card__amount-value {
+  display: block;
+  font-size: 36rpx;
+  font-weight: 700;
+  color: $cu-primary;
+  line-height: 1.2;
+  font-variant-numeric: tabular-nums;
+}
+
+.cu-recharge-card__amount-side-value {
+  display: block;
+  font-size: 28rpx;
+  font-weight: 600;
+  color: $cu-text;
+  line-height: 1.2;
+  font-variant-numeric: tabular-nums;
+}
+
+.cu-recharge-card__amount-side-value--success {
+  color: $cu-success;
+}
+
+.cu-recharge-card__amount-side-value--danger {
+  color: $cu-danger;
+}
+
+.cu-recharge-card__foot {
+  margin-top: 16rpx;
+  padding-top: 16rpx;
+  border-top: 1rpx solid #f0f2f6;
+}
+
+.cu-recharge-card__time {
+  font-size: 24rpx;
+  color: $cu-text-muted;
+  line-height: 1.4;
+}
+
 .cu-bill-tabs {
   margin-bottom: 16rpx;
 }

--
Gitblit v1.9.3