:root{--p1: #0F172A;--p2: #1E293B;--p3: #334155;--p4: #64748B;--b1: #FFFFFF;--b2: #F8FAFC;--b3: #F1F5F9;--c1: #1E40AF;--c2: #3B82F6;--c3: #10B981;--c4: #F59E0B;--c5: #DC2626;--bd: #E2E8F0;--purple: #8B5CF6}*{margin:0;padding:0;box-sizing:border-box}.screen-root{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,PingFang SC,Microsoft YaHei,sans-serif;background:var(--b3);color:var(--p1);font-size:13px;line-height:1.4;overflow-x:hidden;min-height:100vh}.hdr{background:linear-gradient(90deg,var(--p1) 0%,var(--c1) 100%);color:#fff;padding:0 20px;height:52px;display:flex;align-items:center;justify-content:space-between;position:fixed;top:0;left:0;right:0;z-index:1000;box-shadow:0 2px 8px #0000001a}.hdr-l{display:flex;align-items:center;gap:32px}.logo{font-size:18px;font-weight:700;display:flex;align-items:center;gap:10px}.nav{display:flex;gap:4px;background:#ffffff1a;padding:4px;border-radius:6px}.nav-i{padding:8px 20px;border-radius:4px;cursor:pointer;font-size:14px;opacity:.9;transition:all .3s;font-weight:500;border:none;background:transparent;color:#fff}.nav-i:hover{opacity:1;background:#ffffff1a}.nav-i.act{background:#fff;color:var(--c1);opacity:1;font-weight:600;box-shadow:0 2px 4px #0000001a}.hdr-r{display:flex;align-items:center;gap:20px;font-size:13px}.stat-dot{width:8px;height:8px;background:var(--c3);border-radius:50%;display:inline-block;margin-right:6px;animation:pulse 2s infinite}@keyframes pulse{0%,to{opacity:1;box-shadow:0 0 #10b981b3}50%{opacity:.8;box-shadow:0 0 0 6px #10b98100}}.clock{font-variant-numeric:tabular-nums}.container{padding:20px;max-width:1920px;margin:52px auto 0;min-height:calc(100vh - 52px)}.page{animation:fadeIn .3s ease}@keyframes fadeIn{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}.grid{display:grid;gap:16px}.g-2{grid-template-columns:repeat(2,1fr)}.g-3{grid-template-columns:repeat(3,1fr)}.g-4{grid-template-columns:repeat(4,1fr)}.g-6{grid-template-columns:repeat(6,1fr)}.g-1-1-1{grid-template-columns:340px 1fr 340px}.card{background:var(--b1);border-radius:10px;border:1px solid var(--bd);box-shadow:0 1px 3px #0000000d;overflow:hidden;display:flex;flex-direction:column}.card-h{padding:14px 16px;border-bottom:1px solid var(--bd);display:flex;align-items:center;justify-content:space-between;background:linear-gradient(to right,var(--b2),var(--b1))}.card-t{font-size:15px;font-weight:600;color:var(--p2);display:flex;align-items:center;gap:8px}.card-t:before{content:"";width:4px;height:16px;background:var(--c1);border-radius:2px}.card-b{padding:16px;flex:1}.kpi-card{padding:20px;position:relative;overflow:hidden}.kpi-card:before{content:"";position:absolute;top:0;left:0;right:0;height:4px}.kpi-card.blue:before{background:var(--c1)}.kpi-card.green:before{background:var(--c3)}.kpi-card.yellow:before{background:var(--c4)}.kpi-card.red:before{background:var(--c5)}.kpi-card.purple:before{background:var(--purple)}.kpi-h{display:flex;justify-content:space-between;align-items:center;margin-bottom:12px}.kpi-t{font-size:13px;color:var(--p4);font-weight:500}.kpi-icon{width:40px;height:40px;border-radius:8px;display:flex;align-items:center;justify-content:center;font-size:20px;background:var(--b2)}.kpi-v{font-size:32px;font-weight:700;color:var(--p1);margin-bottom:8px;font-variant-numeric:tabular-nums;line-height:1}.kpi-sub{display:flex;gap:12px;font-size:12px;color:var(--p4);flex-wrap:wrap}.kpi-sub span{display:flex;align-items:center;gap:4px}.trend{font-size:12px;font-weight:600;padding:2px 6px;border-radius:4px}.trend.up{color:var(--c3);background:#d1fae5}.trend.down{color:var(--c5);background:#fee2e2}.trend.flat{color:var(--p4);background:var(--b3)}.badge{padding:4px 10px;border-radius:6px;font-size:12px;font-weight:600;display:inline-flex;align-items:center;gap:4px}.badge-g{background:#d1fae5;color:var(--c3)}.badge-y{background:#fef3c7;color:var(--c4)}.badge-r{background:#fee2e2;color:var(--c5)}.badge-b{background:#dbeafe;color:var(--c1)}.badge-p{background:#f3e8ff;color:#9333ea}.tbl{width:100%;border-collapse:collapse;font-size:12px}.tbl th{text-align:left;padding:10px;color:var(--p4);font-weight:600;border-bottom:1px solid var(--bd);background:var(--b2);white-space:nowrap}.tbl td{padding:10px;border-bottom:1px solid var(--b3);vertical-align:middle}.tbl tr:hover{background:var(--b2)}.tbl tr.warn{background:#fef2f2}.tbl tr.warn:hover{background:#fee2e2}.rank{width:24px;height:24px;border-radius:50%;display:inline-flex;align-items:center;justify-content:center;font-size:12px;font-weight:700}.rank-1{background:var(--c1);color:#fff}.rank-2{background:var(--c4);color:#fff}.rank-3{background:var(--p4);color:#fff}.rank-r{background:var(--c5);color:#fff}.rank-y{background:var(--c4);color:#fff}.bar-bg{height:6px;background:var(--b3);border-radius:3px;overflow:hidden;width:80px}.bar-fill{height:100%;border-radius:3px;transition:width .3s}.bar-g{background:var(--c3)}.bar-y{background:var(--c4)}.bar-r{background:var(--c5)}.radar-container{display:flex;gap:24px;align-items:center;padding:20px}.radar-chart{width:280px;height:280px;position:relative;flex-shrink:0}.radar-svg{width:100%;height:100%}.radar-center{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);text-align:center}.radar-score{font-size:48px;font-weight:700;color:var(--p1);line-height:1}.radar-label{font-size:13px;color:var(--p4);margin-top:4px}.radar-legend{flex:1;display:grid;grid-template-columns:repeat(2,1fr);gap:12px}.radar-item{display:flex;align-items:center;gap:10px;padding:12px;background:var(--b2);border-radius:8px;border-left:3px solid transparent}.radar-item.warn{background:#fef2f2;border-left-color:var(--c5)}.radar-dot{width:10px;height:10px;border-radius:50%;flex-shrink:0}.radar-info{flex:1}.radar-name{font-size:13px;color:var(--p3);margin-bottom:2px}.radar-val{font-size:16px;font-weight:700}.radar-val.g{color:var(--c3)}.radar-val.y{color:var(--c4)}.radar-val.r{color:var(--c5)}.stream-container{display:flex;flex-direction:column;gap:8px;max-height:400px;overflow-y:auto}.stream-item{display:flex;gap:12px;padding:12px;background:var(--b2);border-radius:8px;border-left:3px solid var(--c3);animation:slideIn .3s ease;align-items:flex-start}.stream-item.warn{border-left-color:var(--c4)}.stream-item.danger{border-left-color:var(--c5);background:#fef2f2}@keyframes slideIn{0%{opacity:0;transform:translate(-20px)}to{opacity:1;transform:translate(0)}}.stream-icon{width:36px;height:36px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:18px;background:#fff;flex-shrink:0}.stream-content{flex:1}.stream-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:4px}.stream-school{font-weight:600;color:var(--p2)}.stream-time{font-size:11px;color:var(--p4)}.stream-text{font-size:13px;color:var(--p3);line-height:1.4}.timeline{position:relative;padding-left:20px}.timeline:before{content:"";position:absolute;left:6px;top:0;bottom:0;width:2px;background:var(--bd)}.tl-item{position:relative;padding:12px 0;border-bottom:1px solid var(--b3)}.tl-item:last-child{border-bottom:none}.tl-dot{position:absolute;left:-18px;top:14px;width:10px;height:10px;border-radius:50%;border:2px solid white;box-shadow:0 0 0 1px var(--bd);background:var(--c4)}.tl-dot.g{background:var(--c3)}.tl-dot.r{background:var(--c5)}.tl-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:4px}.tl-title{font-weight:600;color:var(--p2)}.tl-desc{font-size:12px;color:var(--p4);line-height:1.4;margin-top:4px}.btn{padding:8px 16px;border-radius:6px;font-size:13px;border:none;cursor:pointer;font-weight:500;display:inline-flex;align-items:center;gap:6px;transition:all .2s}.btn:hover{transform:translateY(-1px);box-shadow:0 2px 4px #0000001a}.btn-primary{background:var(--c1);color:#fff}.btn-success{background:var(--c3);color:#fff}.btn-warning{background:var(--c4);color:#fff}.btn-danger{background:var(--c5);color:#fff}.btn-secondary{background:var(--b2);color:var(--p3);border:1px solid var(--bd)}.btn-sm{padding:6px 12px;font-size:12px}.btn-xs{padding:4px 8px;font-size:11px}.tabs{display:flex;gap:4px;border-bottom:2px solid var(--bd);margin-bottom:16px}.tab{padding:10px 20px;font-size:14px;cursor:pointer;border-bottom:2px solid transparent;margin-bottom:-2px;font-weight:500;color:var(--p4);transition:all .2s}.tab:hover{color:var(--c1)}.tab.act{border-bottom-color:var(--c1);color:var(--c1);font-weight:600}.chart-placeholder{background:linear-gradient(135deg,var(--b2) 0%,var(--b3) 100%);border-radius:8px;display:flex;align-items:center;justify-content:center;color:var(--p4);font-size:14px;min-height:200px;border:2px dashed var(--bd)}.alert-item{display:flex;align-items:center;gap:12px;padding:12px;background:#fffbeb;border-radius:8px;margin-bottom:8px;border-left:4px solid var(--c4)}.alert-item.error{background:#fef2f2;border-left-color:var(--c5)}.alert-level{font-size:11px;font-weight:700;padding:4px 8px;border-radius:4px;white-space:nowrap}.lv-1{background:var(--c5);color:#fff}.lv-2{background:var(--c4);color:#fff}.alert-content{flex:1}.alert-title{font-weight:600;margin-bottom:2px}.alert-meta{font-size:11px;color:var(--p4)}.quick-entry{cursor:pointer;transition:transform .2s}.quick-entry:hover{transform:translateY(-2px)}.text-green{color:var(--c3)}.text-red{color:var(--c5)}.text-yellow{color:var(--c4)}.text-blue{color:var(--c1)}.text-gray{color:var(--p4)}.font-bold{font-weight:700}.mb-4{margin-bottom:16px}.mt-4{margin-top:16px}@media (max-width: 1400px){.g-1-1-1{grid-template-columns:280px 1fr 280px}.g-6{grid-template-columns:repeat(3,1fr)}}@media (max-width: 1200px){.g-1-1-1{grid-template-columns:1fr}.g-4,.g-6{grid-template-columns:repeat(2,1fr)}}.sub-nav{display:flex;gap:4px;border-bottom:2px solid var(--bd);margin-bottom:20px;background:var(--b1);padding:0 20px;position:sticky;top:52px;z-index:100}.sub-nav-item{padding:14px 24px;font-size:15px;cursor:pointer;border-bottom:3px solid transparent;margin-bottom:-2px;font-weight:500;color:var(--p4);transition:all .3s;position:relative}.sub-nav-item:hover{color:var(--c1);background:var(--b2)}.sub-nav-item.act{color:var(--c1);font-weight:600;border-bottom-color:var(--c1)}.sub-nav-item .badge{position:absolute;top:8px;right:8px;font-size:10px;padding:2px 6px}.stat-card{padding:20px;border-radius:10px;background:#fff;border:1px solid var(--bd);position:relative;overflow:hidden}.stat-card:before{content:"";position:absolute;top:0;left:0;right:0;height:4px}.stat-card.blue:before{background:var(--c1)}.stat-card.green:before{background:var(--c3)}.stat-card.yellow:before{background:var(--c4)}.stat-card.red:before{background:var(--c5)}.stat-card.purple:before{background:var(--purple)}.stat-label{font-size:13px;color:var(--p4);margin-bottom:8px}.stat-value{font-size:28px;font-weight:700;margin-bottom:8px}.stat-trend{font-size:12px;display:flex;align-items:center;gap:4px}.progress-bg{height:8px;background:var(--b3);border-radius:4px;overflow:hidden}.progress-fill{height:100%;border-radius:4px;transition:width .3s}.eval-item{display:flex;gap:12px;padding:16px;background:var(--b2);border-radius:8px;margin-bottom:12px;border-left:3px solid var(--c3);transition:all .2s}.eval-item:hover{transform:translate(4px);box-shadow:0 2px 8px #0000000d}.eval-item.warning{border-left-color:var(--c4)}.eval-item.danger{border-left-color:var(--c5);background:#fef2f2}.eval-avatar{width:40px;height:40px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:20px;background:#fff;flex-shrink:0}.eval-content{flex:1}.eval-header{display:flex;justify-content:space-between;margin-bottom:6px;align-items:center}.eval-school{font-weight:600;font-size:14px}.eval-time{font-size:12px;color:var(--p4)}.eval-text{color:var(--p3);line-height:1.5;margin-bottom:8px}.eval-actions{display:flex;gap:8px}.process-steps{display:flex;justify-content:space-between;position:relative;margin:20px 0}.process-steps:before{content:"";position:absolute;top:20px;left:50px;right:50px;height:2px;background:var(--bd);z-index:0}.step{display:flex;flex-direction:column;align-items:center;gap:8px;position:relative;z-index:1}.step-icon{width:40px;height:40px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:18px;background:var(--b3);border:2px solid var(--bd)}.step.active .step-icon{background:var(--c1);color:#fff;border-color:var(--c1)}.step.completed .step-icon{background:var(--c3);color:#fff;border-color:var(--c3)}.step-label{font-size:12px;color:var(--p4);font-weight:500}.step.active .step-label{color:var(--c1);font-weight:600}.filter-bar{display:flex;gap:12px;padding:16px;background:var(--b2);border-radius:8px;margin-bottom:16px;align-items:center;flex-wrap:wrap}.tool-card{padding:20px;border:2px solid var(--bd);border-radius:10px;cursor:pointer;transition:all .2s;text-align:center}.tool-card:hover{border-color:var(--c1);transform:translateY(-2px);box-shadow:0 4px 12px #0000001a}.tool-icon{width:48px;height:48px;margin:0 auto 12px;background:var(--b2);border-radius:12px;display:flex;align-items:center;justify-content:center;font-size:24px}.tool-title{font-weight:600;margin-bottom:4px}.tool-desc{font-size:12px;color:var(--p4)}.compare-row{display:flex;align-items:center;gap:16px;padding:12px;background:var(--b2);border-radius:6px;margin-bottom:8px}.compare-label{width:100px;font-weight:500}.compare-bar{flex:1;height:24px;background:var(--b3);border-radius:4px;position:relative;overflow:hidden}.compare-fill{height:100%;border-radius:4px;display:flex;align-items:center;justify-content:flex-end;padding-right:8px;color:#fff;font-size:12px;font-weight:600}.chart-box{background:var(--b2);border-radius:8px;height:300px;display:flex;align-items:center;justify-content:center;color:var(--p4);font-size:14px;border:2px dashed var(--bd)}.metric-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:16px;margin-bottom:20px}.metric-card{background:#fff;border-radius:10px;padding:20px;border:1px solid var(--bd);position:relative;overflow:hidden}.metric-card:before{content:"";position:absolute;top:0;left:0;right:0;height:4px}.metric-card.blue:before{background:var(--c1)}.metric-card.green:before{background:var(--c3)}.metric-card.purple:before{background:var(--purple)}.metric-card.orange:before{background:var(--c4)}.metric-label{font-size:13px;color:var(--p4);margin-bottom:8px}.metric-value{font-size:28px;font-weight:700;margin-bottom:8px}.metric-trend{font-size:12px;display:flex;align-items:center;gap:4px}.diversity-tabs{display:flex;gap:8px;margin-bottom:16px;background:var(--b2);padding:4px;border-radius:8px;width:fit-content}.diversity-tab{padding:6px 16px;border-radius:6px;cursor:pointer;font-size:13px;font-weight:500;color:var(--p4);transition:all .2s}.diversity-tab:hover{color:var(--c1)}.diversity-tab.act{background:#fff;color:var(--c1);box-shadow:0 1px 3px #0000001a}.food-category-grid{display:grid;grid-template-columns:repeat(5,1fr);gap:12px;margin-bottom:20px}.food-cat-item{text-align:center;padding:16px 12px;background:var(--b2);border-radius:8px;border:2px solid transparent;transition:all .2s;cursor:pointer}.food-cat-item:hover{border-color:var(--c1);background:#fff}.food-cat-item.active{border-color:var(--c1);background:#eff6ff}.food-cat-item.warning{border-color:var(--c4);background:#fffbeb}.food-cat-icon{font-size:28px;margin-bottom:8px}.food-cat-name{font-size:13px;font-weight:600;margin-bottom:4px}.food-cat-count{font-size:18px;font-weight:700;color:var(--c1)}.food-cat-target{font-size:11px;color:var(--p4);margin-top:4px}.source-timeline{position:relative;padding-left:24px}.source-timeline:before{content:"";position:absolute;left:8px;top:0;bottom:0;width:2px;background:var(--bd)}.source-item{position:relative;padding:12px 0;border-bottom:1px solid var(--b3)}.source-dot{position:absolute;left:-20px;top:14px;width:10px;height:10px;border-radius:50%;background:var(--c3);border:2px solid white}.season-tag{display:inline-flex;align-items:center;padding:2px 8px;border-radius:4px;font-size:11px;font-weight:600;gap:4px}.season-spring{background:#f0fdf4;color:var(--c3)}.season-summer{background:#fef2f2;color:var(--c5)}.season-autumn{background:#fffbeb;color:var(--c4)}.season-winter{background:#eff6ff;color:var(--c1)}.rate-circle{width:120px;height:120px;position:relative;display:flex;align-items:center;justify-content:center}.rate-circle svg{transform:rotate(-90deg)}.rate-value{position:absolute;text-align:center}.rate-number{font-size:28px;font-weight:700}.rate-label{font-size:12px;color:var(--p4)}.repeat-list-item{display:flex;align-items:center;gap:12px;padding:12px;background:var(--b2);border-radius:8px;margin-bottom:8px;border-left:3px solid transparent}.repeat-list-item.warning{border-left-color:var(--c4);background:#fffbeb}.repeat-list-item.danger{border-left-color:var(--c5);background:#fef2f2}.repeat-rank{width:28px;height:28px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:12px;font-weight:700;background:var(--b3);color:var(--p4)}.repeat-rank.top{background:var(--c5);color:#fff}.repeat-info{flex:1}.repeat-name{font-weight:600;margin-bottom:4px}.repeat-meta{font-size:11px;color:var(--p4)}.repeat-bar{width:120px}.repeat-count{font-size:14px;font-weight:700;width:60px;text-align:right}.progress-r{background:var(--c5)}.progress-y{background:var(--c4)}.progress-g{background:var(--c3)}.progress-b{background:var(--c1)}.progress-gray{background:var(--p4)}.insight-card{display:flex;gap:16px;padding:16px;background:#fff;border-radius:10px;border:1px solid var(--bd);transition:all .2s}.insight-card:hover{box-shadow:0 4px 12px #00000014;transform:translateY(-2px)}.insight-card.warning{border-left:4px solid var(--c4)}.insight-card.danger{border-left:4px solid var(--c5);background:#fef2f2}.insight-card.info{border-left:4px solid var(--c1)}.insight-icon{width:48px;height:48px;border-radius:12px;display:flex;align-items:center;justify-content:center;font-size:24px;background:var(--b2);flex-shrink:0}.insight-content{flex:1}.insight-title{font-size:15px;font-weight:600;color:var(--p2);margin-bottom:8px}.insight-desc{font-size:13px;color:var(--p3);line-height:1.6;margin-bottom:12px}.insight-action{display:flex;justify-content:space-between;align-items:center}.insight-confidence{font-size:12px;color:var(--p4)}.report-types{display:grid;grid-template-columns:repeat(4,1fr);gap:16px}.report-type-card{display:flex;align-items:center;gap:16px;padding:20px;background:#fff;border-radius:12px;border:2px solid var(--bd);cursor:pointer;transition:all .2s}.report-type-card:hover{border-color:var(--c1);box-shadow:0 4px 12px #00000014}.report-type-card.active{border-color:var(--c1);background:#eff6ff}.report-type-icon{width:48px;height:48px;border-radius:12px;display:flex;align-items:center;justify-content:center;font-size:24px}.report-type-info{flex:1}.report-type-title{font-size:16px;font-weight:700;color:var(--p2);margin-bottom:4px}.report-type-desc{font-size:12px;color:var(--p4)}.form-group{margin-bottom:20px}.form-label{display:block;font-size:13px;font-weight:600;color:var(--p2);margin-bottom:8px}.form-select{width:100%;padding:10px 12px;border:1px solid var(--bd);border-radius:6px;font-size:13px}.checkbox-item,.radio-item{display:flex;align-items:center;gap:8px;font-size:13px;cursor:pointer}.checkbox-item input,.radio-item input{width:16px;height:16px;cursor:pointer}.report-preview{background:#fff;padding:24px;border:1px solid var(--bd);border-radius:8px;min-height:400px}.report-empty{background:var(--b2);border-radius:8px;min-height:400px;display:flex;align-items:center;justify-content:center}.chat-container{display:flex;flex-direction:column;height:450px;min-height:450px}.chat-messages{flex:1;overflow-y:auto;padding:16px;background:var(--b2)}.chat-message{display:flex;gap:12px;margin-bottom:16px}.chat-message.user{flex-direction:row-reverse}.chat-avatar{width:36px;height:36px;border-radius:50%;background:#fff;display:flex;align-items:center;justify-content:center;font-size:18px;flex-shrink:0;box-shadow:0 2px 8px #0000001a}.chat-bubble{max-width:70%;padding:12px 16px;border-radius:12px;background:#fff;box-shadow:0 2px 8px #0000000d}.chat-message.user .chat-bubble{background:var(--c1);color:#fff}.chat-message.assistant .chat-bubble{background:#fff;border:1px solid var(--bd)}.chat-content{font-size:14px;line-height:1.6}.chat-message.user .chat-content{color:#fff}.chat-time{font-size:11px;color:var(--p4);margin-top:6px;text-align:right}.chat-message.user .chat-time{color:#ffffffb3}.chat-typing{display:flex;gap:4px;padding:4px 0}.chat-typing span{width:8px;height:8px;border-radius:50%;background:var(--c1);animation:typing 1.4s infinite ease-in-out both}.chat-typing span:nth-child(1){animation-delay:-.32s}.chat-typing span:nth-child(2){animation-delay:-.16s}@keyframes typing{0%,80%,to{transform:scale(.6);opacity:.5}40%{transform:scale(1);opacity:1}}.chat-quick-actions{padding:12px 16px;background:#fff;border-top:1px solid var(--bd)}.quick-action-label{font-size:12px;color:var(--p4);margin-bottom:8px}.quick-action-btns{display:flex;flex-wrap:wrap;gap:8px}.quick-action-btn{padding:6px 12px;font-size:12px;border:1px solid var(--bd);border-radius:16px;background:#fff;cursor:pointer;transition:all .2s}.quick-action-btn:hover{border-color:var(--c1);background:#eff6ff;color:var(--c1)}.chat-input-area{display:flex;gap:12px;padding:16px;background:#fff;border-top:1px solid var(--bd)}.chat-input{flex:1;padding:10px 16px;border:1px solid var(--bd);border-radius:24px;font-size:14px;outline:none;transition:border-color .2s}.chat-input:focus{border-color:var(--c1)}.ai-chat-card{border:2px solid #0fc6c2;box-shadow:0 4px 20px #0fc6c226}.ai-chat-card .card-t{font-weight:600}.chat-input-wrapper{flex:1;display:flex;align-items:center;position:relative}.chat-input-wrapper .chat-input{width:100%;padding-right:80px}.chat-voice-btns{position:absolute;right:8px;display:flex;gap:4px}.voice-btn{width:32px;height:32px;border:none;background:transparent;border-radius:50%;cursor:pointer;display:flex;align-items:center;justify-content:center;font-size:16px;transition:all .2s;position:relative}.voice-btn:hover{background:var(--b2)}.voice-btn.active{background:#fee2e2}.voice-pulse{position:absolute;width:100%;height:100%;border-radius:50%;background:#ef44444d;animation:pulse 1.5s infinite}@keyframes pulse{0%{transform:scale(1);opacity:1}to{transform:scale(1.8);opacity:0}}::-webkit-scrollbar{width:6px;height:6px}::-webkit-scrollbar-track{background:var(--b3)}::-webkit-scrollbar-thumb{background:var(--p4);border-radius:3px}::-webkit-scrollbar-thumb:hover{background:var(--p3)}.ai-float-panel{position:fixed;right:20px;bottom:20px;z-index:1000;display:flex;flex-direction:column;align-items:flex-end}.ai-float-btn{width:56px;height:56px;border-radius:50%;background:linear-gradient(135deg,#0fc6c2,#14b8a6);color:#fff;font-size:24px;display:flex;align-items:center;justify-content:center;cursor:pointer;box-shadow:0 4px 20px #0fc6c266;transition:all .3s ease;position:relative}.ai-float-btn:hover{transform:scale(1.1);box-shadow:0 6px 30px #0fc6c280}.ai-btn-label{position:absolute;right:65px;background:#1e293b;color:#fff;padding:6px 12px;border-radius:6px;font-size:12px;white-space:nowrap;opacity:0;transition:opacity .3s}.ai-float-btn:hover .ai-btn-label{opacity:1}.ai-chat-panel-inner{width:380px;height:520px;background:#fff;border-radius:16px;box-shadow:0 10px 40px #00000026;margin-bottom:12px;display:flex;flex-direction:column;overflow:hidden;border:1px solid #e2e8f0}.ai-panel-header{padding:14px 16px;background:linear-gradient(90deg,#0fc6c2,#14b8a6);color:#fff;display:flex;justify-content:space-between;align-items:center}.ai-panel-title{display:flex;align-items:center;gap:8px;font-weight:600;font-size:15px}.ai-status-dot{width:8px;height:8px;background:#4ade80;border-radius:50%;animation:statusPulse 2s infinite}@keyframes statusPulse{0%,to{opacity:1}50%{opacity:.5}}.ai-panel-actions{display:flex;gap:6px}.ai-action-btn{width:32px;height:32px;border:none;background:#fff3;border-radius:8px;cursor:pointer;font-size:14px;display:flex;align-items:center;justify-content:center;position:relative;transition:background .2s}.ai-action-btn:hover{background:#ffffff4d}.ai-action-btn.recording{background:#ef4444;animation:recordingPulse 1s infinite}@keyframes recordingPulse{0%,to{box-shadow:0 0 #ef444466}50%{box-shadow:0 0 0 8px #ef444400}}.ai-panel-messages{flex:1;overflow-y:auto;padding:16px;background:#f8fafc}.ai-msg{display:flex;gap:10px;margin-bottom:14px}.ai-msg.user{flex-direction:row-reverse}.ai-msg-avatar{width:32px;height:32px;border-radius:50%;background:#fff;display:flex;align-items:center;justify-content:center;font-size:16px;flex-shrink:0;box-shadow:0 2px 6px #00000014}.ai-msg.assistant .ai-msg-avatar{background:linear-gradient(135deg,#0fc6c2,#14b8a6)}.ai-msg-bubble{max-width:75%;padding:10px 14px;border-radius:12px;font-size:13px;line-height:1.5}.ai-msg.user .ai-msg-bubble{background:linear-gradient(135deg,#0fc6c2,#14b8a6);color:#fff}.ai-msg.assistant .ai-msg-bubble{background:#fff;border:1px solid #e2e8f0}.ai-msg-content{word-break:break-word}.ai-msg-time{font-size:10px;opacity:.7;margin-top:4px;text-align:right}.ai-typing-dots{display:flex;gap:4px;padding:4px}.ai-typing-dots span{width:6px;height:6px;background:#0fc6c2;border-radius:50%;animation:typingDot 1.4s infinite ease-in-out both}.ai-typing-dots span:nth-child(1){animation-delay:-.32s}.ai-typing-dots span:nth-child(2){animation-delay:-.16s}@keyframes typingDot{0%,80%,to{transform:scale(.6);opacity:.5}40%{transform:scale(1);opacity:1}}.ai-quick-btns{padding:10px 12px;display:flex;flex-wrap:wrap;gap:6px;background:#fff;border-top:1px solid #e2e8f0}.ai-quick-btn{padding:5px 10px;font-size:11px;border:1px solid #e2e8f0;border-radius:12px;background:#f8fafc;cursor:pointer;transition:all .2s}.ai-quick-btn:hover{border-color:#0fc6c2;color:#0fc6c2;background:#f0fdfa}.ai-input-area{padding:12px;display:flex;gap:8px;background:#fff;border-top:1px solid #e2e8f0}.ai-input{flex:1;padding:10px 14px;border:1px solid #e2e8f0;border-radius:20px;font-size:13px;outline:none;transition:border-color .2s}.ai-input:focus{border-color:#0fc6c2}.ai-voice-btn{width:38px;height:38px;border:none;background:#f1f5f9;border-radius:50%;cursor:pointer;font-size:16px;transition:all .2s}.ai-voice-btn:hover{background:#e2e8f0}.ai-voice-btn.active{background:#fee2e2;animation:voicePulse 1s infinite}@keyframes voicePulse{0%,to{box-shadow:0 0 #ef444466}50%{box-shadow:0 0 0 6px #ef444400}}.ai-send-btn{width:38px;height:38px;border:none;background:linear-gradient(135deg,#0fc6c2,#14b8a6);border-radius:50%;cursor:pointer;font-size:14px;color:#fff;transition:transform .2s}.ai-send-btn:hover{transform:scale(1.05)}.ai-send-btn:disabled{opacity:.5;cursor:not-allowed;transform:none}.slide-fade-enter-active{transition:all .3s ease}.slide-fade-leave-active{transition:all .2s ease}.slide-fade-enter-from,.slide-fade-leave-to{transform:translate(20px);opacity:0}
