/* ============================================================
 * P015 智小盛CEO · 全局样式 + 组件样式
 * Design System v1.0 · 零外部依赖
 * ============================================================ */

/* === RESET ================================================ */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{font-size:16px;-webkit-text-size-adjust:100%}
body{font-family:var(--fontFamily);background:#1a1a2e;display:flex;justify-content:center;align-items:center;min-height:100vh;padding:20px 0}
img{max-width:100%;display:block}
button,input,textarea,select{font-family:inherit;font-size:inherit;border:none;outline:none}
button{cursor:pointer;background:none}
a{text-decoration:none;color:inherit}
ul{list-style:none}

/* === PHONE FRAME ========================================= */
.phone-frame{
  width:375px;height:812px;background:var(--bgPrimary);
  border-radius:24px;overflow:hidden;position:relative;
  display:flex;flex-direction:column;
  box-shadow: 0 20px 60px rgba(0,0,0,0.3), 0 0 0 2px #1a1a2e;
  transition: background 0.3s ease, color 0.3s ease;
}

/* === OFFLINE BANNER ====================================== */
.offline-banner{
  display:none;align-items:center;justify-content:center;gap:6px;
  height:36px;background:#9CA3AF;color:#fff;font-size:var(--fontSize-sm);
  flex-shrink:0;transition:opacity 0.3s;
}
.offline-banner.show{display:flex}
.offline-banner .retry-icon{width:16px;height:16px;display:inline-flex;align-items:center;justify-content:center}

/* === STATUS BAR ========================================== */
.status-bar{
  height:28px;background:var(--navBg);display:flex;
  align-items:center;justify-content:flex-end;padding:0 var(--spacing-md);
  font-size:var(--fontSize-xs);color:var(--textSecondary);flex-shrink:0;
  border-bottom:1px solid transparent;
}

/* === NAVIGATION BAR ====================================== */
.nav-bar{
  height:44px;background:var(--navBg);display:flex;
  align-items:center;justify-content:center;
  font-size:var(--fontSize-lg);font-weight:var(--fontWeight-bold);
  color:var(--navText);flex-shrink:0;position:relative;
  border-bottom:1px solid var(--navBorder);
}
.nav-bar .back-btn{
  position:absolute;left:var(--spacing-md);
  width:var(--touch-min);height:var(--touch-min);
  display:none;align-items:center;justify-content:center;
  font-size:18px;color:var(--accent);
}
.nav-bar .back-btn.show{display:flex}
.nav-bar .nav-action{
  position:absolute;right:var(--spacing-md);
  min-width:var(--touch-min);height:var(--touch-min);
  display:flex;align-items:center;justify-content:center;
  font-size:var(--fontSize-sm);color:var(--accent);
}

/* === SKIN SELECTOR ======================================= */
.skin-selector{
  display:flex;align-items:center;justify-content:center;
  gap:6px;padding:8px var(--spacing-md);
  background:var(--bgSecondary);flex-shrink:0;
  border-bottom:1px solid var(--border);overflow-x:auto;
}
.skin-selector .skin-btn{
  min-width:var(--touch-min);height:32px;padding:0 10px;
  border-radius:var(--radius-full);font-size:var(--fontSize-xs);
  font-weight:var(--fontWeight-medium);
  color:var(--textSecondary);background:var(--bgCard);
  border:1px solid var(--border);transition:all 0.2s;
  white-space:nowrap;
}
.skin-selector .skin-btn.active{
  background:var(--accent);color:var(--textOnAccent);
  border-color:var(--accent);
}

/* === PAGE CONTAINER ====================================== */
.page-container{
  flex:1;overflow-y:auto;overflow-x:hidden;
  -webkit-overflow-scrolling:touch;
  background:var(--bgPrimary);position:relative;
}

/* Page transition: fadeIn on content swap */
.scroll-content{
  animation: pageFadeIn 0.3s ease;
}
@keyframes pageFadeIn{
  from{opacity:0;transform:translateY(6px)}
  to{opacity:1;transform:translateY(0)}
}

/* === TAB BAR ============================================= */
.tab-bar{
  height:56px;background:var(--tabBarBg);display:flex;
  flex-shrink:0;border-top:1px solid var(--tabBarBorder);
}
.tab-bar .tab-item{
  flex:1;display:flex;flex-direction:column;
  align-items:center;justify-content:center;gap:2px;
  min-height:var(--touch-min);font-size:var(--fontSize-xs);
  color:var(--tabInactive);transition:color 0.2s;
}
.tab-bar .tab-item.active{color:var(--tabActive)}
.tab-bar .tab-icon{font-size:20px;line-height:1}

/* === COMPONENTS ========================================== */

/* Scrollable content area */
.scroll-content{padding:var(--spacing-md);padding-bottom:var(--spacing-lg)}

/* Cards */
.card{
  background:var(--bgCard);border-radius:var(--radius-md);
  padding:var(--spacing-md);margin-bottom:var(--spacing-md);
  box-shadow:var(--shadow-sm);border:1px solid var(--border);
}

/* Stats card */
.stats-row{display:flex;gap:var(--spacing-sm);margin-bottom:var(--spacing-md)}
.stat-card{
  flex:1;background:var(--bgCard);border-radius:var(--radius-md);
  padding:var(--spacing-md);text-align:center;
  box-shadow:var(--shadow-sm);border:1px solid var(--border);
}
.stat-card .stat-value{
  font-size:var(--fontSize-xxl);font-weight:var(--fontWeight-bold);
  color:var(--accent);line-height:var(--lineHeight-tight);
}
.stat-card .stat-label{
  font-size:var(--fontSize-xs);color:var(--textSecondary);margin-top:4px;
}

/* Section title */
.section-title{
  font-size:var(--fontSize-lg);font-weight:var(--fontWeight-bold);
  color:var(--textPrimary);margin:var(--spacing-lg) 0 var(--spacing-sm);
  padding:0;
}
.section-title:first-child{margin-top:0}

/* Buttons */
.btn{
  display:inline-flex;align-items:center;justify-content:center;
  min-width:var(--touch-min);min-height:var(--touch-min);
  padding:10px 20px;border-radius:var(--radius-full);
  font-size:var(--fontSize-base);font-weight:var(--fontWeight-medium);
  transition:all 0.2s;gap:6px;user-select:none;
}
.btn-primary{background:var(--btnPrimaryBg);color:var(--btnPrimaryText)}
.btn-secondary{background:var(--btnSecondaryBg);color:var(--btnSecondaryText)}
.btn-danger{background:var(--btnDangerBg);color:var(--btnDangerText)}
.btn-ghost{
  background:transparent;color:var(--btnGhostText);
  border:1px solid var(--btnGhostBorder);
}
.btn-disabled,.btn:disabled{
  background:var(--bgDisabled);color:var(--textDisabled);
  cursor:not-allowed;opacity:0.6;
}
.btn-block{width:100%}
.btn-sm{min-height:32px;padding:6px 14px;font-size:var(--fontSize-sm)}
.btn:active{opacity:0.8;transform:scale(0.98)}

/* Tags / Labels */
.tag{
  display:inline-flex;align-items:center;padding:2px 8px;
  border-radius:var(--radius-xs);font-size:var(--fontSize-xs);
  font-weight:var(--fontWeight-medium);line-height:1.4;
}
.tag-green{background:var(--tagGreen);color:var(--tagGreenText)}
.tag-yellow{background:var(--tagYellow);color:var(--tagYellowText)}
.tag-red{background:var(--tagRed);color:var(--tagRedText)}
.tag-gray{background:var(--tagGray);color:var(--tagGrayText)}
.tag-blue{background:var(--tagBlue);color:var(--tagBlueText)}
.tag-purple{background:var(--tagPurple);color:var(--tagPurpleText)}
.tag-teal{background:var(--tagTeal);color:var(--tagTealText)}
.tag-orange{background:var(--tagOrange);color:var(--tagOrangeText)}

/* Input fields */
.input{
  width:100%;min-height:var(--touch-min);padding:10px 14px;
  background:var(--bgInput);border:1px solid var(--border);
  border-radius:var(--radius-sm);font-size:var(--fontSize-base);
  color:var(--textPrimary);transition:border-color 0.2s;
}
.input:focus{border-color:var(--inputFocusBorder)}
.input::placeholder{color:var(--textPlaceholder)}
.input:disabled{background:var(--bgDisabled);color:var(--textDisabled)}
select.input{-webkit-appearance:none;appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12'%3E%3Cpath d='M6 8L2 4h8' fill='%23999'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 12px center;padding-right:32px}
textarea.input{min-height:80px;resize:vertical}

/* Progress bar */
.progress-bar{
  height:8px;background:var(--progressBg);border-radius:var(--radius-full);
  overflow:hidden;
}
.progress-bar .progress-fill{
  height:100%;background:var(--progressFill);border-radius:var(--radius-full);
  transition:width 0.5s ease;
}

/* Progress steps (12-step) */
.progress-steps{
  display:flex;justify-content:space-between;padding:0;
  margin:var(--spacing-md) 0;position:relative;
}
.progress-steps::before{
  content:'';position:absolute;top:12px;left:8px;right:8px;
  height:2px;background:var(--progressBg);z-index:0;
}
.progress-step{
  position:relative;z-index:1;display:flex;flex-direction:column;
  align-items:center;gap:4px;width:24px;
}
.progress-step .step-dot{
  width:24px;height:24px;border-radius:50%;
  background:var(--progressBg);display:flex;
  align-items:center;justify-content:center;
  font-size:10px;color:#fff;font-weight:var(--fontWeight-bold);
  transition:all 0.3s;
}
.progress-step.completed .step-dot{background:var(--success)}
.progress-step.current .step-dot{background:var(--accent);box-shadow:0 0 0 3px rgba(74,108,247,0.2)}
.progress-step .step-label{
  font-size:8px;color:var(--textSecondary);
  writing-mode:vertical-lr;text-align:center;max-height:40px;
}

/* Empty state */
.empty-state{
  display:flex;flex-direction:column;align-items:center;
  justify-content:center;padding:var(--spacing-xl) var(--spacing-md);
  text-align:center;min-height:200px;
}
.empty-state .empty-icon{font-size:56px;margin-bottom:var(--spacing-md);opacity:0.6}
.empty-state .empty-title{
  font-size:var(--fontSize-lg);font-weight:var(--fontWeight-medium);
  color:var(--textPrimary);margin-bottom:var(--spacing-sm);
}
.empty-state .empty-desc{
  font-size:var(--fontSize-sm);color:var(--textSecondary);
  margin-bottom:var(--spacing-lg);max-width:240px;line-height:var(--lineHeight-normal);
}

/* Welcome hero */
.welcome-hero{
  text-align:center;padding:var(--spacing-xl) var(--spacing-md);
}
.welcome-hero .hero-icon{
  width:100px;height:100px;margin:0 auto var(--spacing-lg);
  background:linear-gradient(135deg, var(--accent), var(--progressFill));
  border-radius:50%;display:flex;align-items:center;justify-content:center;
  font-size:48px;color:#fff;box-shadow:var(--shadow-md);
}
.welcome-hero .hero-title{
  font-size:var(--fontSize-xl);font-weight:var(--fontWeight-bold);
  color:var(--textPrimary);margin-bottom:var(--spacing-sm);
}
.welcome-hero .hero-desc{
  font-size:var(--fontSize-base);color:var(--textSecondary);
  margin-bottom:var(--spacing-lg);line-height:var(--lineHeight-loose);
}

/* Agent cards */
.agent-grid{display:grid;grid-template-columns:1fr 1fr;gap:var(--spacing-sm)}
.agent-card{
  background:var(--bgCard);border-radius:var(--radius-md);
  padding:var(--spacing-md);box-shadow:var(--shadow-sm);
  border:1px solid var(--border);display:flex;align-items:center;gap:var(--spacing-sm);
  min-height:var(--touch-min);position:relative;cursor:pointer;
}
.agent-card .agent-icon{
  width:40px;height:40px;border-radius:var(--radius-sm);
  display:flex;align-items:center;justify-content:center;
  font-size:20px;flex-shrink:0;
}
.agent-card .agent-info{flex:1;min-width:0}
.agent-card .agent-name{font-size:var(--fontSize-sm);font-weight:var(--fontWeight-medium);color:var(--textPrimary)}
.agent-card .agent-desc{font-size:var(--fontSize-xs);color:var(--textSecondary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}

/* Chat bubbles */
.chat-area{display:flex;flex-direction:column;gap:var(--spacing-md);padding:0}
.chat-bubble{
  max-width:85%;padding:12px var(--spacing-md);border-radius:var(--radius-md);
  font-size:var(--fontSize-base);line-height:var(--lineHeight-normal);
  position:relative;word-break:break-word;
}
.chat-bubble.ai{
  align-self:flex-start;background:var(--bubbleAI);
  box-shadow:var(--shadow-sm);border:1px solid var(--border);
  border-bottom-left-radius:var(--radius-xs);
}
.chat-bubble.user{
  align-self:flex-end;background:var(--bubbleUser);color:var(--textPrimary);
  border-bottom-right-radius:var(--radius-xs);
}
.chat-bubble.system{
  align-self:center;background:var(--bubbleSystem);color:var(--textSecondary);
  font-size:var(--fontSize-sm);max-width:100%;text-align:center;
}
.chat-bubble .bubble-time{
  font-size:var(--fontSize-xs);color:var(--textSecondary);margin-top:4px;
}

/* Confirm card */
.confirm-card{
  background:var(--bgCard);border:2px solid var(--accent);
  border-radius:var(--radius-lg);padding:var(--spacing-md);
  margin:var(--spacing-sm) 0;
}
.confirm-card .confirm-header{
  font-size:var(--fontSize-base);font-weight:var(--fontWeight-bold);
  color:var(--accent);margin-bottom:var(--spacing-sm);
  display:flex;align-items:center;gap:6px;
}
.confirm-card .confirm-item{
  font-size:var(--fontSize-sm);color:var(--textPrimary);
  padding:4px 0;display:flex;align-items:flex-start;gap:6px;
  line-height:var(--lineHeight-normal);
}
.confirm-card .confirm-item .confirm-key{
  color:var(--textSecondary);min-width:60px;flex-shrink:0;
}
.confirm-card .confirm-item .confirm-val{
  color:var(--textPrimary);word-break:break-word;
}
.confirm-card .confirm-sufficiency{
  font-size:var(--fontSize-sm);color:var(--textSecondary);
  margin-bottom:var(--spacing-sm);padding:6px 10px;
  background:var(--bgSecondary);border-radius:var(--radius-sm);
}
.confirm-card .confirm-items{
  margin:var(--spacing-sm) 0;
}
.confirm-card .confirm-meta{
  display:flex;gap:var(--spacing-md);margin:var(--spacing-sm) 0;
  font-size:var(--fontSize-sm);
}
.confirm-card .confirm-meta span{color:var(--textSecondary)}
.confirm-card .confirm-meta strong{color:var(--accent)}
.confirm-card .confirm-actions{
  display:flex;gap:var(--spacing-sm);margin-top:var(--spacing-sm);
}

/* Task card */
.task-card{
  background:var(--bgCard);border-radius:var(--radius-md);
  padding:var(--spacing-md);margin-bottom:var(--spacing-sm);
  box-shadow:var(--shadow-sm);border:1px solid var(--border);
  position:relative;
}
.task-card .task-header{
  display:flex;align-items:center;justify-content:space-between;
  margin-bottom:var(--spacing-sm);
}
.task-card .task-title{
  font-size:var(--fontSize-base);font-weight:var(--fontWeight-medium);
  color:var(--textPrimary);flex:1;min-width:0;
  white-space:nowrap;overflow:hidden;text-overflow:ellipsis;
}
.task-card .task-meta{
  display:flex;align-items:center;gap:var(--spacing-md);
  font-size:var(--fontSize-xs);color:var(--textSecondary);
}
.task-card .task-progress{margin-top:var(--spacing-sm)}

/* Search bar */
.search-bar{
  display:flex;align-items:center;background:var(--bgInput);
  border-radius:var(--radius-full);padding:8px var(--spacing-md);
  margin-bottom:var(--spacing-md);gap:8px;
}
.search-bar .search-icon{font-size:16px;color:var(--textSecondary)}
.search-bar input{
  flex:1;background:transparent;border:none;outline:none;
  font-size:var(--fontSize-base);color:var(--textPrimary);
}
.search-bar input::placeholder{color:var(--textPlaceholder)}

/* Wallet balance card */
.balance-card{
  background:linear-gradient(135deg, var(--accent), var(--progressFill));
  border-radius:var(--radius-lg);padding:var(--spacing-lg);
  color:#fff;margin-bottom:var(--spacing-md);
}
.balance-card .balance-label{font-size:var(--fontSize-sm);opacity:0.85}
.balance-card .balance-amount{
  font-size:36px;font-weight:var(--fontWeight-bold);
  margin:var(--spacing-sm) 0;line-height:1.1;
}
.balance-card .balance-detail{
  display:flex;gap:var(--spacing-lg);font-size:var(--fontSize-xs);opacity:0.8;
}

/* Package card */
.package-card{
  background:var(--bgCard);border:1px solid var(--border);
  border-radius:var(--radius-md);padding:var(--spacing-md);
  margin-bottom:var(--spacing-sm);box-shadow:var(--shadow-sm);
  display:flex;align-items:center;justify-content:space-between;cursor:pointer;
}
.package-card.recommended{border-color:var(--accent);border-width:2px}
.package-card .pkg-info{flex:1}
.package-card .pkg-name{font-size:var(--fontSize-base);font-weight:var(--fontWeight-bold);color:var(--textPrimary)}
.package-card .pkg-tokens{font-size:var(--fontSize-sm);color:var(--accent);margin:2px 0}
.package-card .pkg-desc{font-size:var(--fontSize-xs);color:var(--textSecondary)}
.package-card .pkg-price{text-align:right}
.package-card .pkg-price .price{font-size:var(--fontSize-xl);font-weight:var(--fontWeight-bold);color:var(--textPrimary)}
.package-card .pkg-price .unit{font-size:var(--fontSize-xs);color:var(--textSecondary)}

/* Transaction item */
.tx-item{
  display:flex;align-items:center;gap:var(--spacing-md);
  padding:var(--spacing-md) 0;border-bottom:1px solid var(--divider);
}
.tx-item:last-child{border-bottom:none}
.tx-item .tx-icon{
  width:40px;height:40px;border-radius:50%;
  display:flex;align-items:center;justify-content:center;
  font-size:18px;flex-shrink:0;
}
.tx-item .tx-info{flex:1;min-width:0}
.tx-item .tx-title{font-size:var(--fontSize-base);color:var(--textPrimary)}
.tx-item .tx-time{font-size:var(--fontSize-xs);color:var(--textSecondary)}
.tx-item .tx-billing{font-size:var(--fontSize-xs);color:var(--textSecondary);margin-top:2px;display:flex;gap:6px}
.tx-item .tx-amount{
  font-size:var(--fontSize-lg);font-weight:var(--fontWeight-bold);
  text-align:right;
}
.tx-item .tx-amount.positive{color:var(--success)}
.tx-item .tx-amount.negative{color:var(--danger)}

/* Notification item */
.notif-item{
  display:flex;gap:var(--spacing-md);padding:12px 0;
  border-bottom:1px solid var(--divider);align-items:flex-start;
  min-height:var(--touch-min);cursor:pointer;
}
.notif-item:last-child{border-bottom:none}
.notif-item .notif-dot{
  width:8px;height:8px;border-radius:50%;background:var(--danger);
  flex-shrink:0;margin-top:6px;
}
.notif-item .notif-dot.read{background:transparent}
.notif-item .notif-icon{
  width:36px;height:36px;border-radius:50%;
  display:flex;align-items:center;justify-content:center;
  font-size:18px;flex-shrink:0;background:var(--bgSecondary);
}
.notif-item .notif-info{flex:1;min-width:0}
.notif-item .notif-title{font-size:var(--fontSize-base);color:var(--textPrimary)}
.notif-item .notif-body{font-size:var(--fontSize-sm);color:var(--textSecondary);line-height:var(--lineHeight-normal)}
.notif-item .notif-time{font-size:var(--fontSize-xs);color:var(--textDisabled)}

/* File grid */
.file-grid{
  display:grid;grid-template-columns:repeat(3,1fr);
  gap:var(--spacing-sm);
}
.file-card{
  background:var(--bgCard);border-radius:var(--radius-sm);
  overflow:hidden;box-shadow:var(--shadow-sm);
  border:1px solid var(--border);
}
.file-card .file-thumb{
  height:100px;background:var(--bgSecondary);
  display:flex;align-items:center;justify-content:center;
  font-size:32px;color:var(--textSecondary);
}
.file-card .file-thumb img{width:100%;height:100%;object-fit:cover}
.file-card .file-info{padding:8px}
.file-card .file-name{
  font-size:var(--fontSize-xs);color:var(--textPrimary);
  white-space:nowrap;overflow:hidden;text-overflow:ellipsis;
}
.file-card .file-meta{
  font-size:9px;color:var(--textSecondary);
  display:flex;justify-content:space-between;margin-top:2px;
}

/* Tab switcher */
.tab-switcher{
  display:flex;gap:0;margin-bottom:var(--spacing-md);
  border-bottom:1px solid var(--border);
}
.tab-switcher .tab-btn{
  flex:1;min-height:var(--touch-min);display:flex;align-items:center;
  justify-content:center;font-size:var(--fontSize-base);
  color:var(--textSecondary);position:relative;
  font-weight:var(--fontWeight-medium);cursor:pointer;
}
.tab-switcher .tab-btn.active{
  color:var(--accent);font-weight:var(--fontWeight-bold);
}
.tab-switcher .tab-btn.active::after{
  content:'';position:absolute;bottom:-1px;left:20%;right:20%;
  height:2px;background:var(--accent);border-radius:1px;
}

/* Consumption chart placeholder */
.chart-area{
  background:var(--bgSecondary);border-radius:var(--radius-md);
  padding:var(--spacing-md);margin-bottom:var(--spacing-md);
}
.chart-area .chart-title{
  font-size:var(--fontSize-sm);font-weight:var(--fontWeight-medium);
  color:var(--textPrimary);margin-bottom:var(--spacing-sm);
}
.bar-chart{display:flex;align-items:flex-end;gap:8px;height:120px;padding-top:8px}
.bar-chart .bar-col{flex:1;display:flex;flex-direction:column;align-items:center;gap:4px}
.bar-chart .bar{
  width:100%;max-width:28px;background:var(--accent);
  border-radius:4px 4px 0 0;min-height:4px;transition:height 0.5s ease;
  opacity:0.8;
}
.bar-chart .bar-label{font-size:9px;color:var(--textSecondary)}

/* Menu list */
.menu-list{margin:var(--spacing-md) 0}
.menu-item{
  display:flex;align-items:center;justify-content:space-between;
  padding:14px 0;border-bottom:1px solid var(--divider);
  min-height:var(--touch-min);cursor:pointer;
}
.menu-item:last-child{border-bottom:none}
.menu-item .menu-left{display:flex;align-items:center;gap:var(--spacing-sm)}
.menu-item .menu-icon{font-size:20px;width:28px;text-align:center}
.menu-item .menu-label{font-size:var(--fontSize-base);color:var(--textPrimary)}
.menu-item .menu-arrow{color:var(--textSecondary);font-size:14px}

/* Profile header */
.profile-header{
  display:flex;align-items:center;gap:var(--spacing-md);
  padding:var(--spacing-lg) var(--spacing-md);
}
.profile-header .avatar{
  width:64px;height:64px;border-radius:50%;background:var(--bgSecondary);
  display:flex;align-items:center;justify-content:center;
  font-size:28px;overflow:hidden;flex-shrink:0;
}
.profile-header .avatar img{width:100%;height:100%;object-fit:cover}
.profile-header .profile-name{font-size:var(--fontSize-lg);font-weight:var(--fontWeight-bold);color:var(--textPrimary)}
.profile-header .profile-id{font-size:var(--fontSize-sm);color:var(--textSecondary)}

/* Form group */
.form-group{margin-bottom:var(--spacing-md)}
.form-group .form-label{
  font-size:var(--fontSize-sm);color:var(--textSecondary);
  margin-bottom:6px;display:block;
}

/* Toast notification */
.toast{
  position:fixed;top:50%;left:50%;transform:translate(-50%,-50%);
  background:rgba(0,0,0,0.8);color:#fff;padding:12px 24px;
  border-radius:var(--radius-full);font-size:var(--fontSize-sm);
  z-index:9999;opacity:0;transition:opacity 0.3s;
  pointer-events:none;
}
.toast.show{opacity:1}

/* Avatar upload area */
.avatar-upload{
  display:flex;flex-direction:column;align-items:center;gap:var(--spacing-sm);
  padding:var(--spacing-lg);
}
.avatar-upload .avatar-preview{
  width:88px;height:88px;border-radius:50%;background:var(--bgSecondary);
  display:flex;align-items:center;justify-content:center;
  font-size:36px;color:var(--textSecondary);overflow:hidden;
  border:2px dashed var(--border);
}
.avatar-upload .avatar-preview img{width:100%;height:100%;object-fit:cover}

/* Thinking animation */
.thinking-dots{display:flex;gap:3px;padding:4px 0}
.thinking-dots span{
  width:6px;height:6px;border-radius:50%;background:var(--textSecondary);
  animation:dotPulse 1.4s infinite ease-in-out both;
}
.thinking-dots span:nth-child(1){animation-delay:-0.32s}
.thinking-dots span:nth-child(2){animation-delay:-0.16s}
@keyframes dotPulse{0%,80%,100%{transform:scale(0);opacity:0.3}40%{transform:scale(1);opacity:1}}

/* Sending indicator */
.sending-indicator{
  display:flex;align-items:center;gap:6px;
  font-size:var(--fontSize-sm);color:var(--textSecondary);
}
.sending-indicator .spinner{
  width:12px;height:12px;border:2px solid var(--border);
  border-top-color:var(--accent);border-radius:50%;
  animation:spin 0.8s linear infinite;
}
@keyframes spin{to{transform:rotate(360deg)}}

/* Offline toggle button (floating) */
.offline-toggle{
  font-size:10px;color:var(--textSecondary);
  border:1px solid var(--border);border-radius:var(--radius-xs);
  padding:2px 6px;cursor:pointer;background:var(--bgCard);
}
.offline-toggle:hover{background:var(--bgSecondary)}

/* Danger zone */
.danger-zone{
  border:1px solid var(--danger);border-radius:var(--radius-md);
  padding:var(--spacing-md);margin-top:var(--spacing-xl);
}
.danger-zone .danger-title{font-size:var(--fontSize-sm);font-weight:var(--fontWeight-bold);color:var(--danger);margin-bottom:var(--spacing-sm)}
.danger-zone .danger-desc{font-size:var(--fontSize-xs);color:var(--textSecondary);margin-bottom:var(--spacing-sm)}

/* Skin preview cards */
.skin-grid{display:grid;grid-template-columns:1fr 1fr;gap:var(--spacing-sm)}
.skin-preview{
  border-radius:var(--radius-md);overflow:hidden;
  border:2px solid var(--border);cursor:pointer;
  transition:border-color 0.2s;
}
.skin-preview.selected{border-color:var(--accent)}
.skin-preview .skin-thumb{height:80px;display:flex;align-items:center;justify-content:center;font-size:24px}
.skin-preview .skin-name{
  padding:var(--spacing-sm);font-size:var(--fontSize-sm);
  font-weight:var(--fontWeight-medium);text-align:center;
  background:var(--bgCard);color:var(--textPrimary);
}

/* Agent category tabs */
.category-tabs{
  display:flex;gap:var(--spacing-sm);margin-bottom:var(--spacing-md);
  overflow-x:auto;-webkit-overflow-scrolling:touch;padding-bottom:4px;
}
.category-tabs .cat-tag{
  padding:6px 14px;border-radius:var(--radius-full);
  font-size:var(--fontSize-sm);white-space:nowrap;
  background:var(--bgSecondary);color:var(--textSecondary);
  border:1px solid var(--border);min-height:32px;
  display:flex;align-items:center;
}
.category-tabs .cat-tag.active{
  background:var(--accent);color:var(--textOnAccent);border-color:var(--accent);
}

/* Filter row */
.filter-row{
  display:flex;gap:var(--spacing-sm);margin-bottom:var(--spacing-md);
  flex-wrap:wrap;
}
.filter-chip{
  padding:4px 12px;border-radius:var(--radius-full);
  font-size:var(--fontSize-xs);background:var(--bgSecondary);
  color:var(--textSecondary);border:1px solid var(--border);
  min-height:28px;display:flex;align-items:center;cursor:pointer;
}
.filter-chip.active{background:var(--accent);color:var(--textOnAccent);border-color:var(--accent)}

/* Page title for sub-pages */
.page-title{
  font-size:var(--fontSize-xl);font-weight:var(--fontWeight-bold);
  color:var(--textPrimary);margin-bottom:var(--spacing-md);
}

/* Summary card (consumption) */
.summary-card{
  background:linear-gradient(135deg, var(--accent), var(--progressFill));
  border-radius:var(--radius-lg);padding:var(--spacing-lg);
  color:#fff;margin-bottom:var(--spacing-md);
}
.summary-card .summary-row{display:flex;gap:var(--spacing-lg)}
.summary-card .summary-item{flex:1}
.summary-card .summary-value{font-size:var(--fontSize-xl);font-weight:var(--fontWeight-bold)}
.summary-card .summary-label{font-size:var(--fontSize-xs);opacity:0.8}

/* Link text */
.link-text{color:var(--accent);font-size:var(--fontSize-sm);cursor:pointer}

/* Divider section */
.section-divider{
  height:8px;background:var(--bgSecondary);
  margin:0 calc(-1 * var(--spacing-md));
}

/* Retry / timeout message */
.timeout-msg{
  text-align:center;font-size:var(--fontSize-sm);color:var(--textSecondary);
  padding:var(--spacing-md);
}

/* Payment method */
.pay-method{
  display:flex;align-items:center;gap:var(--spacing-sm);
  padding:var(--spacing-md);background:var(--bgCard);
  border-radius:var(--radius-md);margin-bottom:var(--spacing-md);
  border:1px solid var(--border);
}
.pay-method .pay-icon{
  width:28px;height:28px;background:#09BB07;border-radius:6px;
  display:flex;align-items:center;justify-content:center;
  color:#fff;font-size:14px;font-weight:var(--fontWeight-bold);
}
.pay-method .pay-name{font-size:var(--fontSize-base);color:var(--textPrimary)}
.pay-method .pay-check{color:var(--accent);font-weight:var(--fontWeight-bold)}

/* Recommended badge */
.recommend-badge{
  background:var(--accent);color:var(--textOnAccent);
  font-size:9px;padding:2px 8px;border-radius:var(--radius-full);
  margin-bottom:4px;display:inline-block;
}

/* Red dot (unread indicator) */
.red-dot{
  width:8px;height:8px;border-radius:50%;background:var(--danger);
  display:inline-block;
}

/* Read all button */
.read-all-btn{
  font-size:var(--fontSize-sm);color:var(--accent);
  font-weight:var(--fontWeight-medium);cursor:pointer;
}

/* Tab bar badge */
.tab-badge{
  position:absolute;top:2px;right:calc(50% - 16px);
  width:8px;height:8px;border-radius:50%;background:var(--danger);
}

/* === MODAL (Bottom Sheet Confirm Dialog) =============== */
.modal-overlay{
  position:fixed;top:0;left:0;right:0;bottom:0;
  background:var(--bgOverlay);display:none;
  align-items:flex-end;justify-content:center;
  z-index:10000;
}
.modal-overlay.show{display:flex}
.modal-sheet{
  width:100%;max-width:375px;
  background:var(--bgCard);
  border-radius:var(--radius-lg) var(--radius-lg) 0 0;
  padding:var(--spacing-lg);
  animation:slideUp 0.25s ease;
}
@keyframes slideUp{from{transform:translateY(100%)}to{transform:translateY(0)}}
.modal-title{
  font-size:var(--fontSize-lg);font-weight:var(--fontWeight-bold);
  color:var(--textPrimary);margin-bottom:8px;
}
.modal-desc{
  font-size:var(--fontSize-sm);color:var(--textSecondary);
  margin-bottom:16px;line-height:1.6;
}
.modal-actions{
  display:flex;gap:12px;
}

/* === Task Actions Card (Detail Page) =================== */
.task-actions-card{
  margin-top:var(--spacing-md);margin-bottom:var(--spacing-md);
}
.task-actions-card .ta-header{
  font-size:var(--fontSize-base);font-weight:var(--fontWeight-bold);
  color:var(--textPrimary);margin-bottom:12px;
}
.task-actions-card .ta-buttons{
  display:flex;gap:var(--spacing-sm);margin-bottom:12px;flex-wrap:wrap;
}
.task-actions-card .ta-warning{
  font-size:var(--fontSize-xs);color:var(--textSecondary);
  padding-top:10px;border-top:1px solid var(--divider);
  line-height:1.6;
}

/* === Task Card Popup Menu ============================== */
.task-menu-btn{
  position:absolute;bottom:var(--spacing-md);right:var(--spacing-md);
  width:28px;height:28px;display:flex;align-items:center;justify-content:center;
  font-size:16px;color:var(--textSecondary);border-radius:var(--radius-xs);
  background:var(--bgSecondary);line-height:1;
  z-index:2;letter-spacing:1px;
}
.task-menu-btn:active{opacity:0.7}
.task-menu{
  display:none;position:absolute;bottom:48px;right:var(--spacing-md);
  background:var(--bgCard);border-radius:var(--radius-md);
  box-shadow:var(--shadow-lg);border:1px solid var(--border);
  z-index:10;min-width:120px;overflow:hidden;
}
.task-menu.show{display:block}
.task-menu-item{
  display:block;width:100%;padding:10px 16px;font-size:var(--fontSize-sm);
  color:var(--textPrimary);text-align:left;background:none;border:none;
  cursor:pointer;border-bottom:1px solid var(--divider);
  white-space:nowrap;
}
.task-menu-item:last-child{border-bottom:none}
.task-menu-item:active{background:var(--bgSecondary)}
.task-menu-item.danger{color:var(--danger)}

/* === Storage Quota Bar ================================== */
.storage-quota{
  margin-bottom:var(--spacing-md);
}
.storage-quota .sq-text{
  font-size:var(--fontSize-xs);color:var(--textSecondary);
  margin-bottom:6px;display:flex;justify-content:space-between;
}
.storage-quota .sq-bar{
  height:6px;background:var(--progressBg);border-radius:var(--radius-full);overflow:hidden;
}
.storage-quota .sq-fill{
  height:100%;border-radius:var(--radius-full);transition:width 0.3s;
}
.storage-quota .sq-fill.green{background:var(--success)}
.storage-quota .sq-fill.yellow{background:var(--warning)}
.storage-quota .sq-fill.red{background:var(--danger)}

/* === File Toolbar ======================================= */
.file-toolbar{
  display:flex;justify-content:space-between;align-items:center;
  margin-bottom:var(--spacing-sm);
}

/* === File Card Actions ================================== */
.file-card-actions{
  display:flex;gap:4px;padding:4px 8px;
}
.file-card-actions .fca-btn{
  font-size:var(--fontSize-xs);padding:2px 8px;border-radius:var(--radius-xs);
  cursor:pointer;background:none;border:none;font-weight:var(--fontWeight-medium);
}
.file-card-actions .fca-btn.delete{color:var(--danger)}
.file-card-actions .fca-btn.share{color:var(--accent)}

/* === Share Panel ======================================== */
.share-panel{
  display:none;background:var(--bgCard);border-radius:var(--radius-md);
  padding:var(--spacing-md);margin-bottom:var(--spacing-md);
  border:1px solid var(--border);box-shadow:var(--shadow-sm);
}
.share-panel.show{display:block}
.share-panel .sp-title{
  font-size:var(--fontSize-sm);font-weight:var(--fontWeight-medium);
  color:var(--textPrimary);margin-bottom:8px;
}
.share-panel .sp-link-row{
  display:flex;gap:8px;align-items:center;
}
.share-panel .sp-link-input{
  flex:1;font-size:var(--fontSize-xs);padding:6px 10px;
  background:var(--bgInput);border:1px solid var(--border);
  border-radius:var(--radius-sm);color:var(--textPrimary);
  overflow:hidden;text-overflow:ellipsis;
}

/* === Loading spinner ==================================== */
.loading-spin{
  display:flex;flex-direction:column;align-items:center;
  justify-content:center;padding:40px;gap:12px;
  color:var(--textSecondary);font-size:var(--fontSize-sm);
}
.loading-spin .spinner{
  width:28px;height:28px;border:3px solid var(--border);
  border-top-color:var(--accent);border-radius:50%;
  animation:spin 0.8s linear infinite;
}

/* === Agent rank badge === */
.login-page{
  display:flex;flex-direction:column;align-items:center;
  justify-content:center;min-height:100%;padding:var(--spacing-xl);
  text-align:center;
}
.login-logo{font-size:72px;margin-bottom:var(--spacing-md)}
.login-title{font-size:var(--fontSize-xl);font-weight:var(--fontWeight-bold);color:var(--textPrimary);margin-bottom:var(--spacing-sm)}
.login-subtitle{font-size:var(--fontSize-sm);color:var(--textSecondary);margin-bottom:var(--spacing-xl);line-height:var(--lineHeight-loose)}
.login-btn{
  width:100%;max-width:280px;padding:14px;
  background:linear-gradient(135deg, var(--accent), var(--progressFill));
  color:#fff;border:none;border-radius:var(--radius-full);
  font-size:var(--fontSize-lg);font-weight:var(--fontWeight-bold);cursor:pointer;
}
.login-btn:active{opacity:0.85}

/* === Pending action row ================================== */
.action-row{
  display:flex;gap:var(--spacing-sm);margin-bottom:var(--spacing-md);
}
.action-row .btn{flex:1}

/* === Profile detail card ================================ */
.detail-row{
  display:flex;justify-content:space-between;align-items:center;
  padding:8px 0;
}
.detail-row + .detail-row{border-top:1px solid var(--divider)}
.detail-row .dl{font-size:var(--fontSize-sm);color:var(--textSecondary);min-width:60px}
.detail-row .dv{font-size:var(--fontSize-base);color:var(--textPrimary);text-align:right;word-break:break-all}

/* === Global text fix ==================================== */
.scroll-content{word-break:break-word;overflow-wrap:break-word}
.agent-desc,.member-desc,.dept-count{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}

/* === Agent Detail ======================================= */
.agent-detail-header{
  text-align:center;padding:var(--spacing-lg) 0 var(--spacing-md);
}
.agent-detail-header h2{
  font-size:var(--fontSize-xl);font-weight:var(--fontWeight-bold);
  color:var(--textPrimary);margin-bottom:8px;word-break:break-word;
}
.agent-detail-meta{
  display:flex;gap:6px;justify-content:center;margin-top:8px;flex-wrap:wrap;
}
.agent-detail-icon-wrap{
  width:64px;height:64px;border-radius:18px;display:flex;align-items:center;
  justify-content:center;font-size:32px;margin:0 auto 14px;
  background:var(--tagBlue);flex-shrink:0;
}
.feature-list{padding:4px 0}
.feature-item{
  font-size:var(--fontSize-base);color:var(--textPrimary);
  padding:6px 0;line-height:1.5;
}
.example-list{padding:4px 0}
.example-item{
  font-size:var(--fontSize-base);color:var(--accent);cursor:pointer;
  padding:10px 0;border-bottom:1px solid var(--divider);line-height:1.4;
}
.example-item:last-child{border-bottom:none}
.example-item:active{opacity:0.7}

/* Agent rank badge */
.agent-rank{
  position:absolute;top:4px;right:8px;
  font-size:11px;font-weight:700;color:var(--textSecondary);
}

/* === Department Grid ==================================== */
.dept-grid{display:flex;flex-direction:column;gap:8px;margin-bottom:16px}
.dept-card{
  display:flex;align-items:center;padding:14px 12px;
  background:var(--bgCard);border-radius:var(--radius-md);
  box-shadow:var(--shadow-sm);border:1px solid var(--border);
  cursor:pointer;transition:transform 0.15s;
}
.dept-card:active{transform:scale(0.98)}
.dept-icon{font-size:28px;margin-right:12px;width:40px;text-align:center}
.dept-info{flex:1}
.dept-name{font-size:var(--fontSize-base);font-weight:var(--fontWeight-medium);color:var(--textPrimary)}
.dept-count{font-size:var(--fontSize-xs);color:var(--textSecondary);margin-top:2px}
.dept-arrow{font-size:20px;color:var(--textSecondary)}

/* Department header (detail page) */
.dept-header{
  text-align:center;padding:var(--spacing-lg) 0 var(--spacing-md);
}
.dept-header-icon{font-size:48px;margin-bottom:8px}
.dept-header h2{
  font-size:var(--fontSize-xl);font-weight:var(--fontWeight-bold);
  color:var(--textPrimary);margin-bottom:4px;
}

/* === Member List ======================================== */
.member-list{display:flex;flex-direction:column;gap:6px}
.member-card{
  display:flex;align-items:center;padding:12px;
  background:var(--bgCard);border-radius:var(--radius-md);
  box-shadow:var(--shadow-sm);border:1px solid var(--border);
  cursor:pointer;transition:transform 0.15s;
}
.member-card:active{transform:scale(0.98)}
.member-icon{font-size:24px;margin-right:10px;width:32px;text-align:center}
.member-info{flex:1}
.member-name{font-size:var(--fontSize-base);font-weight:var(--fontWeight-medium);color:var(--textPrimary)}
.member-desc{font-size:var(--fontSize-xs);color:var(--textSecondary);margin-top:2px}
.member-arrow{font-size:18px;color:var(--textSecondary)}

/* === Feedback / Rating System ============================ */
.feedback-card {
  background: var(--bgCard);
  border-radius: var(--radius-md);
  padding: var(--spacing-md);
  margin-bottom: var(--spacing-md);
  box-shadow: var(--shadow-sm);
  border: 1px solid var(--border);
}

.feedback-card .feedback-header {
  font-size: var(--fontSize-base);
  font-weight: var(--fontWeight-bold);
  color: var(--textPrimary);
  margin-bottom: 12px;
  text-align: center;
}

.star-rating {
  display: flex;
  justify-content: center;
  gap: 8px;
  margin-bottom: 12px;
}

.star-rating .star {
  font-size: 32px;
  cursor: pointer;
  transition: transform 0.15s ease;
  user-select: none;
  color: var(--textSecondary);
  line-height: 1;
}

.star-rating .star:hover {
  transform: scale(1.2);
}

.star-rating .star:active {
  transform: scale(0.95);
}

.feedback-input {
  margin-bottom: 12px;
}

/* Feedback history items */
.feedback-item {
  background: var(--bgCard);
  border-radius: var(--radius-md);
  padding: var(--spacing-md);
  margin-bottom: var(--spacing-sm);
  box-shadow: var(--shadow-sm);
  border: 1px solid var(--border);
}

.feedback-item-stars {
  font-size: 20px;
  letter-spacing: 2px;
  margin-bottom: 8px;
}

.feedback-item-content {
  font-size: var(--fontSize-sm);
  color: var(--textPrimary);
  line-height: var(--lineHeight-normal);
  margin-bottom: 8px;
  padding: 8px 0;
}

.feedback-item-meta {
  display: flex;
  align-items: center;
  font-size: var(--fontSize-xs);
  color: var(--textSecondary);
  padding-top: 8px;
  border-top: 1px solid var(--divider);
}

/* === Responsive ========================================= */
@media (max-width:400px) {
  .phone-frame{width:100vw;height:100vh;border-radius:0}
}
