/* ===== Effects Page - 效果展示 ===== */
.eff-page{padding:20px 32px 40px;overflow-y:auto}
.eff-page::-webkit-scrollbar{width:4px}.eff-page::-webkit-scrollbar-thumb{background:var(--md-surface-4);border-radius:2px}
.eff-section{margin-bottom:28px}
.eff-section-head{display:flex;align-items:center;justify-content:space-between;margin-bottom:16px}
.eff-section-title{font-family:'Google Sans',sans-serif;font-size:16px;font-weight:600;display:flex;align-items:center;gap:8px}
.eff-section-title .material-symbols-outlined{font-size:22px}
.eff-tabs{display:flex;gap:4px;background:var(--md-surface-2);padding:4px;border-radius:var(--radius-sm)}
.eff-tab{display:flex;align-items:center;gap:5px;padding:8px 16px;border-radius:var(--radius-xs);font-size:13px;font-weight:500;color:var(--md-on-surface-variant);cursor:pointer;transition:all .2s;border:none;background:none}
.eff-tab .material-symbols-outlined{font-size:16px}
.eff-tab:hover{color:var(--md-on-surface)}
.eff-tab.active{background:var(--md-surface);color:var(--md-primary);font-weight:600;box-shadow:var(--shadow-1)}
/* 分组维度下拉选择器 */
.eff-dimension-select{position:relative;display:flex;align-items:center;gap:8px}
.eff-dimension-select .dim-label{font-size:12px;color:var(--md-on-surface-variant);font-weight:500}
.eff-dimension-select .dim-dropdown{display:flex;align-items:center;gap:4px;padding:6px 10px 6px 14px;border-radius:var(--radius-xs);border:1.5px solid var(--md-surface-4);background:var(--md-surface);cursor:pointer;transition:all .2s;min-width:100px}
.eff-dimension-select .dim-dropdown:hover{border-color:var(--md-primary)}
.eff-dimension-select.open .dim-dropdown{border-color:var(--md-primary);box-shadow:0 0 0 3px rgba(0,82,217,.12)}
.eff-dimension-select .dim-value{font-size:13px;font-weight:600;color:var(--md-on-surface)}
.eff-dimension-select .dim-arrow{font-size:18px;color:var(--md-on-surface-variant);transition:transform .2s}
.eff-dimension-select.open .dim-arrow{transform:rotate(180deg)}
.eff-dimension-select .dim-options{position:absolute;top:calc(100% + 6px);left:0;min-width:160px;background:var(--md-surface);border:1px solid var(--md-surface-3);border-radius:var(--radius-sm);box-shadow:var(--shadow-3);padding:6px;opacity:0;visibility:hidden;transform:translateY(-8px);transition:all .2s;z-index:100}
.eff-dimension-select.open .dim-options{opacity:1;visibility:visible;transform:translateY(0)}
.eff-dimension-select .dim-option{display:flex;align-items:center;gap:10px;padding:10px 14px;border-radius:var(--radius-xs);font-size:13px;font-weight:500;color:var(--md-on-surface-variant);cursor:pointer;transition:all .15s}
.eff-dimension-select .dim-option:hover{background:var(--md-surface-2);color:var(--md-on-surface)}
.eff-dimension-select .dim-option.active{background:var(--md-primary-container);color:var(--md-on-primary-container);font-weight:600}
.eff-dimension-select .dim-option .material-symbols-outlined{font-size:18px}
.eff-time-selector{display:flex;align-items:center;gap:8px}
.eff-time-btn{padding:6px 14px;border-radius:16px;border:1px solid var(--md-surface-4);background:var(--md-surface);font-family:inherit;font-size:12px;font-weight:500;color:var(--md-on-surface-variant);cursor:pointer;transition:all .2s}
.eff-time-btn:hover{border-color:var(--md-primary);color:var(--md-primary)}
.eff-time-btn.active{border-color:var(--md-primary);background:var(--md-primary-container);color:var(--md-on-primary-container);font-weight:600}
/* 效果概览指标卡片 */
.eff-metrics{display:grid;grid-template-columns:repeat(5,1fr);gap:12px;margin-bottom:20px}
.eff-metric-card{padding:16px;border-radius:var(--radius-sm);background:var(--md-surface);border:1px solid var(--md-surface-3);transition:box-shadow .25s var(--ease-spring),border-color .25s var(--ease-spring),transform .25s var(--ease-spring);position:relative;overflow:hidden}
.eff-metric-card::before{content:'';position:absolute;top:0;left:0;right:0;height:2px;background:var(--brand-gradient);background-size:200% 200%;opacity:0;transition:opacity .3s}
.eff-metric-card:hover{box-shadow:0 6px 20px rgba(0,82,217,.08);border-color:var(--md-primary-container);transform:translateY(-2px)}
.eff-metric-card:hover::before{opacity:1}
.eff-metric-label{font-size:12px;color:var(--md-on-surface-variant);margin-bottom:6px;display:flex;align-items:center;gap:4px}
.eff-metric-value{font-family:'Google Sans',sans-serif;font-size:24px;font-weight:600;color:var(--md-on-surface)}
.eff-metric-change{font-size:11px;margin-top:4px;display:flex;align-items:center;gap:2px}
.eff-metric-change.up{color:var(--md-success)}
.eff-metric-change.down{color:var(--md-error)}
.eff-metric-change.neutral{color:var(--md-on-surface-variant)}
/* 效果趋势图表 */
.eff-chart-container{height:200px;border-radius:var(--radius-sm);background:var(--md-surface);border:1px solid var(--md-surface-3);padding:16px;position:relative;overflow:hidden}
.eff-chart-placeholder{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;flex-direction:column;gap:8px;color:var(--md-on-surface-variant);font-size:13px}
.eff-chart-placeholder .material-symbols-outlined{font-size:40px;opacity:.4}
/* 趋势图表 canvas */
#eff-trend-canvas{width:100%!important;height:100%!important}
.eff-chart-container.has-chart{overflow:visible}
.eff-chart-container.has-chart .eff-chart-placeholder{display:none}
.eff-chart-container.has-chart #eff-trend-canvas{display:block!important}
/* 图表加载中状态 */
.eff-chart-loading{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;flex-direction:column;gap:10px;color:var(--md-on-surface-variant);font-size:13px;background:var(--md-surface);z-index:2}
.eff-loading-spinner{width:28px;height:28px;border:3px solid var(--md-surface-4);border-top-color:var(--md-primary);border-radius:50%;animation:eff-spin .8s linear infinite}
@keyframes eff-spin{to{transform:rotate(360deg)}}
/* 图表错误状态 */
.eff-chart-error{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;flex-direction:column;gap:8px;color:var(--md-error);font-size:13px;background:var(--md-surface);z-index:2}
.eff-chart-error .material-symbols-outlined{font-size:36px;opacity:.6}
.eff-chart-retry-btn{margin-top:4px;padding:6px 18px;border-radius:16px;border:1.5px solid var(--md-primary);background:transparent;color:var(--md-primary);font-family:inherit;font-size:12px;font-weight:600;cursor:pointer;transition:all .2s}
.eff-chart-retry-btn:hover{background:var(--md-primary);color:#fff}
/* 卡片骨架屏加载状态 */
.eff-metric-card.loading .eff-metric-value,.eff-metric-card.loading .eff-metric-change{background:var(--md-surface-3);border-radius:4px;color:transparent!important;animation:eff-skeleton 1.2s ease-in-out infinite;min-width:60px;min-height:16px}
.eff-metric-card.loading .eff-metric-value{min-height:28px;min-width:80px}
@keyframes eff-skeleton{0%,100%{opacity:.5}50%{opacity:1}}
/* Agent 工作成果 */
.eff-agent-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:16px}
.eff-inst-card{border-radius:var(--radius-sm);background:var(--md-surface);border:1px solid var(--md-surface-3);overflow:hidden;transition:box-shadow .25s var(--ease-spring),transform .25s var(--ease-spring)}
.eff-inst-card:hover{box-shadow:0 6px 20px rgba(0,82,217,.08);transform:translateY(-1px)}
.eff-inst-head{padding:14px 16px;display:flex;align-items:center;gap:12px;border-bottom:1px solid var(--md-surface-3);cursor:pointer;transition:background .2s}
.eff-inst-head:hover{background:var(--md-surface-1)}
.eff-inst-avatar{width:36px;height:36px;border-radius:10px;display:flex;align-items:center;justify-content:center;flex-shrink:0}
.eff-inst-avatar .material-symbols-outlined{font-size:20px;color:#fff}
.eff-inst-info{flex:1;min-width:0}
.eff-inst-name{font-size:14px;font-weight:600;display:flex;align-items:center;gap:6px}
.eff-inst-name .status-dot{width:8px;height:8px;border-radius:50%}
.eff-inst-meta{font-size:11px;color:var(--md-on-surface-variant);margin-top:2px}
.eff-inst-stats{display:flex;gap:16px;font-size:12px;color:var(--md-on-surface-variant)}
.eff-inst-stat{display:flex;align-items:center;gap:4px}
.eff-inst-stat strong{font-weight:600;color:var(--md-on-surface)}
.eff-inst-expand{color:var(--md-on-surface-variant);transition:transform .2s}
.eff-inst-card.expanded .eff-inst-expand{transform:rotate(180deg)}
.eff-inst-body{max-height:0;overflow:hidden;transition:max-height .3s ease-out}
.eff-inst-card.expanded .eff-inst-body{max-height:400px}
.eff-agent-list{display:grid;grid-template-columns:repeat(4,1fr);gap:10px;padding:14px 16px}
.eff-agent-item{padding:12px;border-radius:var(--radius-xs);background:var(--md-surface-1);border:1px solid var(--md-surface-3);transition:all .2s}
.eff-agent-item:hover{border-color:var(--md-primary-container);box-shadow:var(--shadow-1)}
.eff-agent-head{display:flex;align-items:center;gap:8px;margin-bottom:10px}
.eff-agent-icon{width:28px;height:28px;border-radius:8px;display:flex;align-items:center;justify-content:center;font-size:14px}
.eff-agent-name{font-size:12px;font-weight:600}
.eff-agent-stats{display:flex;flex-direction:column;gap:6px}
.eff-agent-stat-row{display:flex;justify-content:space-between;align-items:center;font-size:11px}
.eff-agent-stat-label{color:var(--md-on-surface-variant)}
.eff-agent-stat-value{font-weight:600;color:var(--md-on-surface)}
/* 实时动态 Feed & 报告 */
.eff-bottom-grid{display:grid;grid-template-columns:1fr 1fr;gap:20px}
.eff-feed-container{border-radius:var(--radius-sm);background:var(--md-surface);border:1px solid var(--md-surface-3);overflow:hidden;max-height:320px;display:flex;flex-direction:column}
.eff-feed-head{padding:12px 16px;border-bottom:1px solid var(--md-surface-3);display:flex;align-items:center;justify-content:space-between}
.eff-feed-title{font-size:13px;font-weight:600;display:flex;align-items:center;gap:6px}
.eff-feed-actions{display:flex;gap:6px}
.eff-feed-btn{width:28px;height:28px;border-radius:6px;border:1px solid var(--md-surface-4);background:var(--md-surface);cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .2s}
.eff-feed-btn:hover{border-color:var(--md-primary);color:var(--md-primary)}
.eff-feed-btn .material-symbols-outlined{font-size:16px;color:var(--md-on-surface-variant)}
.eff-feed-btn:hover .material-symbols-outlined{color:var(--md-primary)}
.eff-feed-list{flex:1;overflow-y:auto;padding:8px 0}
.eff-feed-list::-webkit-scrollbar{width:3px}.eff-feed-list::-webkit-scrollbar-thumb{background:var(--md-surface-4);border-radius:2px}
.eff-feed-item{padding:10px 16px;display:flex;gap:10px;align-items:flex-start;transition:background .15s;cursor:default}
.eff-feed-item:hover{background:var(--md-surface-1)}
.eff-feed-icon{width:24px;height:24px;border-radius:6px;display:flex;align-items:center;justify-content:center;flex-shrink:0;font-size:12px}
.eff-feed-content{flex:1;min-width:0}
.eff-feed-text{font-size:12px;color:var(--md-on-surface);line-height:1.5}
.eff-feed-text strong{font-weight:600}
.eff-feed-meta{font-size:10px;color:var(--md-outline);margin-top:3px;display:flex;align-items:center;gap:8px}
/* 报告列表 */
.eff-report-list{display:flex;flex-direction:column}
.eff-report-item{padding:14px 16px;display:flex;align-items:center;gap:12px;border-bottom:1px solid var(--md-surface-3);transition:background .15s;cursor:pointer}
.eff-report-item:last-child{border-bottom:none}
.eff-report-item:hover{background:var(--md-surface-1)}
.eff-report-icon{width:36px;height:36px;border-radius:8px;background:var(--md-surface-2);display:flex;align-items:center;justify-content:center;flex-shrink:0}
.eff-report-icon .material-symbols-outlined{font-size:18px;color:var(--md-primary)}
.eff-report-info{flex:1;min-width:0}
.eff-report-title{font-size:13px;font-weight:600;color:var(--md-on-surface)}
.eff-report-meta{font-size:11px;color:var(--md-on-surface-variant);margin-top:2px}
.eff-report-badge{padding:4px 10px;border-radius:12px;font-size:10px;font-weight:600;background:var(--md-surface-2);color:var(--md-on-surface-variant)}
.eff-report-badge.new{background:var(--md-primary-container);color:var(--md-on-primary-container)}
/* 效果概览表格 */
.eff-table-container{border-radius:var(--radius-sm);background:var(--md-surface);border:1px solid var(--md-surface-3);overflow:hidden}
.eff-table{width:100%;border-collapse:collapse;font-size:13px}
.eff-table th{padding:12px 16px;text-align:left;font-weight:600;color:var(--md-on-surface-variant);background:var(--md-surface-1);border-bottom:1px solid var(--md-surface-3);font-size:12px}
.eff-table td{padding:12px 16px;border-bottom:1px solid var(--md-surface-3)}
.eff-table tr:last-child td{border-bottom:none}
.eff-table tr:hover td{background:rgba(0,82,217,.03)}
.eff-table .channel-icon{width:24px;height:24px;border-radius:6px;display:inline-flex;align-items:center;justify-content:center;font-size:10px;font-weight:700;color:#fff;margin-right:8px;vertical-align:middle}
/* 渠道绑定状态样式 */
.eff-ch-status{display:inline-flex;align-items:center;gap:4px;padding:3px 10px;border-radius:12px;font-size:11px;font-weight:600;white-space:nowrap}
.eff-ch-status.st-ok{background:var(--md-success-container);color:#0D652D}
.eff-ch-status.st-warn{background:var(--md-warning-container);color:#7A4100}
.eff-ch-status.st-error{background:var(--md-error-container);color:var(--md-error)}
.eff-ch-status.st-unbound{background:var(--md-surface-2);color:var(--md-outline)}
.eff-ch-status .material-symbols-outlined{font-size:14px}
.eff-ch-hint{font-size:11px;color:var(--md-outline);padding:8px 16px;background:var(--md-surface-1);border-top:1px dashed var(--md-surface-3);display:flex;align-items:center;gap:8px}
.eff-ch-hint.hint-warn{background:rgba(227,116,0,.06);border-top-color:rgba(227,116,0,.2)}
.eff-ch-hint.hint-error{background:rgba(217,48,37,.06);border-top-color:rgba(217,48,37,.2)}
.eff-ch-hint .material-symbols-outlined{font-size:16px}
.eff-ch-hint .hint-action{margin-left:auto;padding:4px 12px;border-radius:14px;font-size:11px;font-weight:600;border:1.5px solid;cursor:pointer;background:transparent;font-family:inherit;transition:all .2s}
.eff-ch-hint .hint-action.act-warn{border-color:var(--md-warning);color:var(--md-warning)}
.eff-ch-hint .hint-action.act-warn:hover{background:var(--md-warning);color:#fff}
.eff-ch-hint .hint-action.act-error{border-color:var(--md-primary);color:var(--md-primary)}
.eff-ch-hint .hint-action.act-error:hover{background:var(--md-primary);color:#fff}
.eff-table tr.row-unbound td{color:var(--md-outline);font-style:italic}
.eff-table tr.row-unbound .channel-icon{opacity:.5;filter:grayscale(1)}
.eff-ch-unbound-notice{padding:16px;background:var(--md-surface-1);border-radius:var(--radius-sm);margin-bottom:16px;display:flex;align-items:flex-start;gap:12px;border:1px solid var(--md-surface-3)}
.eff-ch-unbound-notice .notice-icon{width:36px;height:36px;border-radius:50%;background:var(--md-warning-container);display:flex;align-items:center;justify-content:center;flex-shrink:0}
.eff-ch-unbound-notice .notice-icon .material-symbols-outlined{font-size:20px;color:var(--md-warning)}
.eff-ch-unbound-notice .notice-content{flex:1}
.eff-ch-unbound-notice .notice-title{font-size:13px;font-weight:600;color:var(--md-on-surface);margin-bottom:4px}
.eff-ch-unbound-notice .notice-desc{font-size:12px;color:var(--md-on-surface-variant);line-height:1.5}
.eff-ch-unbound-notice .notice-btn{padding:6px 16px;border-radius:16px;font-size:12px;font-weight:600;border:none;cursor:pointer;font-family:inherit;transition:all .2s;background:var(--md-primary);color:#fff;margin-top:10px;display:inline-flex;align-items:center;gap:4px}
.eff-ch-unbound-notice .notice-btn:hover{box-shadow:0 2px 8px rgba(0,82,217,.3)}

/* 目标维度二级下钻表格样式 */
.eff-table .goal-parent-row:hover td{background:rgba(0,82,217,.04)}
.eff-table .goal-parent-row td{font-weight:500}
.eff-table .goal-parent-row .goal-expand-icon{transition:transform .2s;user-select:none}
.eff-table .goal-parent-row.goal-expanded .goal-expand-icon{transform:rotate(0)}
.eff-table .goal-child-row td{padding-left:16px;color:var(--md-on-surface-variant);font-size:12px;background:var(--md-surface-1)}
.eff-table .goal-child-row:hover td{background:var(--md-surface-2)}
.eff-table .goal-child-row td:first-child{padding-left:20px}

/* Work-in-progress placeholder */
.eff-wip-placeholder{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:64px 24px;border:2px dashed var(--md-outline-variant);border-radius:var(--radius-m,12px);background:var(--md-surface-1)}
