:root{--c1:#00e5ff;--c2:#ffd740;--c3:#ff9100;--c4:#ff4081;--c5:#ff1744;--c6:#b388ff;--bg:#06060f;--b1:rgba(255,255,255,0.06);--b2:rgba(255,255,255,0.10)}
*{margin:0;padding:0;box-sizing:border-box}
body{font-family:-apple-system,BlinkMacSystemFont,'Segoe UI','PingFang SC','Microsoft YaHei',sans-serif;background:var(--bg);color:#e0e0e0;height:100dvh;display:flex;flex-direction:column;overflow:hidden}
#map{flex:1;width:100%}
.maplibregl-ctrl-attrib{display:none!important}
.maplibregl-ctrl-group{border:1px solid var(--b2)!important;border-radius:8px!important;overflow:hidden}
.maplibregl-ctrl-group button{width:34px!important;height:34px!important;background:rgba(10,12,30,0.9)!important}
.maplibregl-ctrl-group button:hover{background:rgba(179,136,255,0.15)!important}
.maplibregl-ctrl-group button span{filter:invert(0.6)}
.header{background:linear-gradient(180deg,rgba(8,8,25,0.96),rgba(6,6,18,0.88));padding:8px 16px;display:flex;align-items:center;justify-content:space-between;border-bottom:1px solid var(--b1);flex-shrink:0;z-index:1001}
.header-l{display:flex;align-items:center;gap:10px}
.header-l .logo{width:28px;height:28px;flex-shrink:0}
.header-l .logo svg{width:100%;height:100%}
.header-l .t{font-size:15px;font-weight:600;color:#ddd;letter-spacing:1px}
.header-r{display:flex;gap:8px;align-items:center}
.btn{background:rgba(255,255,255,0.04);border:1px solid var(--b2);color:#ccc;padding:6px 14px;border-radius:6px;font-size:11px;cursor:pointer;transition:all 0.25s;display:flex;align-items:center;gap:6px;font-family:inherit;letter-spacing:0.5px}
.btn:hover{background:rgba(179,136,255,0.1);border-color:var(--c6);color:#fff}
.btn.is-active{background:rgba(0,229,255,0.12);border-color:rgba(0,229,255,0.72);color:#e9fbff;box-shadow:0 0 0 1px rgba(0,229,255,0.16) inset,0 0 18px rgba(0,229,255,0.16)}
.btn.is-active:hover{background:rgba(0,229,255,0.16);border-color:rgba(0,229,255,0.9);color:#fff}
.btn-ai{border-color:rgba(0,229,255,0.22);color:#e9fbff;background:linear-gradient(135deg,rgba(0,229,255,0.08),rgba(179,136,255,0.08))}
.btn-ai:hover{border-color:rgba(0,229,255,0.45);box-shadow:0 0 18px rgba(0,229,255,0.12)}
#btnAi{position:fixed;right:16px;bottom:16px;z-index:1500;display:flex;width:82px;height:82px;padding:0;border:0;border-radius:0;align-items:center;justify-content:center;font-size:0;background:transparent;box-shadow:none;color:transparent;animation:aiFloat 3.2s ease-in-out infinite}
#btnAi::before{content:'';width:82px;height:82px;background:url('../generated-assets/ai-potato-logo.svg') center/contain no-repeat}
#btnAi:active{transform:scale(0.96)}
@keyframes aiFloat{0%,100%{transform:translateY(0)}50%{transform:translateY(-4px)}}
.btn svg.icon{width:14px;height:14px;flex-shrink:0;transition:transform 0.6s}
.btn.refreshing svg.icon{animation:sp 0.8s linear infinite}
@keyframes sp{to{transform:rotate(360deg)}}
.search-w{position:relative}
.search-b{background:rgba(255,255,255,0.04);border:1px solid var(--b2);color:#ccc;padding:7px 14px 7px 34px;border-radius:6px;font-size:12px;width:160px;outline:none;transition:all 0.3s;font-family:inherit}
.search-b:focus{border-color:var(--c1);background:rgba(0,229,255,0.06);width:200px}
.search-b::placeholder{color:#778}
.search-ic{position:absolute;left:10px;top:50%;transform:translateY(-50%);width:14px;height:14px;opacity:0.5;pointer-events:none}
.search-d{position:absolute;top:calc(100%+6px);right:0;background:rgba(12,12,30,0.94);border:1px solid rgba(255,255,255,0.1);border-radius:10px;max-height:360px;overflow-y:auto;width:300px;display:none;z-index:2000;box-shadow:0 12px 40px rgba(0,0,0,0.6)}
.search-d.show{display:block}
.si{padding:9px 14px;cursor:pointer;font-size:13px;border-bottom:1px solid rgba(255,255,255,0.03);display:flex;align-items:center;justify-content:space-between;transition:background 0.15s}
.si:hover,.si.active{background:rgba(179,136,255,0.1)}
.si .sr{font-size:10px;padding:2px 8px;border-radius:10px;font-weight:600}
.se{padding:18px;text-align:center;color:#778;font-size:12px}
.lu{font-size:10px;color:#778;display:none}
.legend{position:fixed;bottom:30px;left:12px;z-index:500;background:rgba(10,12,28,0.9);padding:10px 14px;border-radius:8px;border:1px solid var(--b1);font-size:11px;line-height:2;box-shadow:0 4px 20px rgba(0,0,0,0.5)}
.legend strong{font-size:11px;color:#bbb;letter-spacing:1px;font-weight:600}
.legend i{width:10px;height:10px;display:inline-block;margin-right:6px;border-radius:2px;vertical-align:middle}
.legend .l0{background:#1a3a2a}.legend .l1{background:#1a5c3a}.legend .l2{background:#2d8a4e}
.legend .l3{background:#4caf50}.legend .l4{background:#8bc34a}.legend .l5{background:#fdd835}
.layer-control{position:fixed;left:50%;top:58px;transform:translateX(-50%);z-index:700;display:flex;align-items:center;gap:6px;padding:6px;background:rgba(10,12,28,0.88);border:1px solid var(--b1);border-radius:8px;box-shadow:0 8px 28px rgba(0,0,0,0.45);backdrop-filter:blur(10px)}
.legend-toggle{height:30px;display:flex;align-items:center;gap:7px;padding:0 10px;border:1px solid transparent;border-radius:6px;background:rgba(255,255,255,0.025);color:#d1d6e6;font-size:12px;line-height:1.2;text-align:left;cursor:pointer;transition:background 0.18s,border-color 0.18s,opacity 0.18s,color 0.18s;font-family:inherit;white-space:nowrap}
.legend-toggle:hover{background:rgba(255,255,255,0.045);border-color:rgba(255,255,255,0.08);color:#eef2ff}
.legend-toggle::after{content:'✓';margin-left:auto;font-size:10px;color:rgba(0,229,255,0.85)}
.legend-toggle.off{opacity:0.45;color:#7b8092}
.legend-toggle.off::after{content:''}
.monitor-toggle{border-color:rgba(0,229,255,0.1);color:#e9fbff;background:rgba(0,229,255,0.04)}
.monitor-toggle::after{content:''}
.monitor-toggle:hover{border-color:rgba(0,229,255,0.26);background:rgba(0,229,255,0.08)}
.pt-dom,.pt-over,.pt-for,.pt-reg{width:10px;height:10px;display:inline-block;border-radius:50%;flex-shrink:0}
.pt-dom{background:#00e5ff;box-shadow:0 0 8px rgba(0,229,255,0.45)}
.pt-over{background:#b388ff;border:1px solid rgba(255,255,255,0.9);box-shadow:0 0 10px rgba(179,136,255,0.45)}
.pt-for{background:#ef5350;opacity:0.55}
.pt-reg{background:#ff9800;box-shadow:0 0 8px rgba(255,152,0,0.35)}
.backdrop{position:fixed;inset:0;background:rgba(0,0,0,0.5);z-index:1001;opacity:0;pointer-events:none;transition:opacity 0.4s}
.backdrop.show{opacity:1;pointer-events:auto}
.panel{position:fixed;z-index:1002;background:rgba(10,12,28,0.88);border:1px solid rgba(255,255,255,0.06);overflow-y:auto;display:flex;flex-direction:column;transition:transform 0.4s cubic-bezier(0.22,0.61,0.36,1),opacity 0.4s;box-shadow:-8px 0 40px rgba(0,0,0,0.6);scrollbar-width:thin;scrollbar-color:rgba(0,229,255,0.42) rgba(255,255,255,0.035)}
.panel{right:10px;top:12px;bottom:12px;width:min(520px,calc(100vw - 28px));border-radius:14px;transform:translateX(110%);opacity:0}
.panel.open{transform:translateX(0);opacity:1}
.panel::-webkit-scrollbar{width:8px;height:8px}
.panel::-webkit-scrollbar-track{background:rgba(255,255,255,0.025);border-radius:999px;margin:12px 0}
.panel::-webkit-scrollbar-thumb{background:linear-gradient(180deg,rgba(0,229,255,0.36),rgba(179,136,255,0.34));border:2px solid rgba(10,12,28,0.92);border-radius:999px}
.panel::-webkit-scrollbar-thumb:hover{background:linear-gradient(180deg,rgba(0,229,255,0.58),rgba(179,136,255,0.52))}
.panel::-webkit-scrollbar-corner{background:transparent}
.panel-h{display:none;width:36px;height:4px;background:rgba(255,255,255,0.15);border-radius:2px;margin:10px auto 0;flex-shrink:0}
.panel-hd{padding:16px 20px;position:sticky;top:0;z-index:2;background:linear-gradient(180deg,rgba(10,12,30,0.98),rgba(8,10,25,0.9));border-bottom:1px solid rgba(255,255,255,0.04);border-radius:14px 14px 0 0}
.panel-hd .cn{font-size:18px;font-weight:700;margin-bottom:2px;padding-right:54px}
.panel-hd .cp{font-size:12px;color:#999}
.panel-x{position:absolute;top:16px;right:16px;width:34px;height:34px;min-width:34px;min-height:34px;background:rgba(255,255,255,0.04);border:1px solid var(--b2);border-radius:50%;color:#bbb;font-size:16px;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all 0.3s;font-family:inherit;z-index:5;flex-shrink:0}
.panel-x:hover,.panel-x:active{background:rgba(255,64,129,0.15);border-color:var(--c4);color:#fff}
.panel-bd{padding:12px 20px 24px;flex:1}
.sec{margin-bottom:20px}
.sec-tt{font-size:10px;color:#888;text-transform:uppercase;letter-spacing:2px;margin-bottom:8px;font-weight:600}
.rh{text-align:center;padding:8px 0 12px}
.rr{position:relative;width:110px;height:110px;margin:0 auto 10px;border-radius:50%;display:flex;align-items:center;justify-content:center}
.rr-bg{position:absolute;inset:4px;border-radius:50%;border:7px solid rgba(255,255,255,0.04)}
.rr-fg{position:absolute;inset:4px;border-radius:50%;border:7px solid transparent;border-top-color:var(--c1);border-right-color:var(--c4);animation:rrSpin 3s linear infinite}
@keyframes rrSpin{to{transform:rotate(360deg)}}
.rv{position:relative;z-index:1;text-align:center}
.rv .n{font-size:40px;font-weight:800;line-height:1;letter-spacing:-2px;color:#eee}
.rv .u{font-size:15px;font-weight:600;color:#999}
.rt{font-size:12px;font-weight:600;padding:4px 16px;border-radius:20px;display:inline-block;letter-spacing:1px;margin-top:6px}
.rt.low{background:rgba(0,229,255,0.08);color:var(--c1);border:1px solid rgba(0,229,255,0.2)}
.rt.ml{background:rgba(255,215,64,0.08);color:var(--c2);border:1px solid rgba(255,215,64,0.2)}
.rt.med{background:rgba(255,145,0,0.08);color:var(--c3);border:1px solid rgba(255,145,0,0.2)}
.rt.mh{background:rgba(255,64,129,0.08);color:var(--c4);border:1px solid rgba(255,64,129,0.2)}
.rt.high{background:rgba(255,23,68,0.1);color:var(--c5);border:1px solid rgba(255,23,68,0.25);animation:tp 2s ease-in-out infinite}
@keyframes tp{0%,100%{box-shadow:0 0 10px rgba(255,23,68,0.2)}50%{box-shadow:0 0 20px rgba(255,23,68,0.4)}}
.cards{display:grid;grid-template-columns:1fr 1fr 1fr;gap:6px}
.card{background:rgba(255,255,255,0.015);border:1px solid var(--b1);border-radius:10px;padding:14px 10px;text-align:center;transition:all 0.3s}
.card:hover{border-color:rgba(179,136,255,0.15);transform:translateY(-1px)}
.card .cv{font-size:18px;font-weight:700;color:#eee;line-height:1.2}
.card .cv u{font-size:12px;color:#999;text-decoration:none;margin-left:2px}
.card .cl{font-size:11px;color:#778;letter-spacing:1px;margin-bottom:4px}
.card .cs{font-size:10px;color:#888;margin-top:2px}
.heatmap{display:flex;gap:3px;align-items:flex-end;height:72px}
.hc{flex:1;display:flex;flex-direction:column;align-items:center;gap:1px}
.hb{display:flex;flex-direction:column-reverse;gap:1px;width:100%}
.hb-d{height:4px;border-radius:1px;transition:all 0.4s}
.hl{font-size:10px;color:#778;margin-top:4px}
.hleg{display:flex;justify-content:center;gap:6px;margin-top:8px;align-items:center}
.hleg .hd{width:10px;height:10px;border-radius:2px}
.hleg .ht{font-size:10px;color:#888}
.he{text-align:center;color:#778;padding:16px;font-size:12px}
.fn{padding:14px;background:rgba(255,255,255,0.015);border-radius:8px;font-size:11px;color:#888;line-height:1.7;border:1px solid var(--b1)}
.fn strong{color:#aaa;font-weight:600}
.point-loading{padding:18px;text-align:center;color:#778;font-size:12px;border:1px solid var(--b1);border-radius:8px;margin-bottom:16px;background:rgba(255,255,255,0.015)}
.point-weather{margin-bottom:18px}
.risk-sentence{padding:10px 12px;border-radius:8px;border:1px solid rgba(255,215,64,0.18);background:rgba(255,215,64,0.06);color:#ffd740;font-size:13px;line-height:1.5;margin-bottom:10px}
.risk-conclusion{padding:11px 12px;border-radius:8px;font-size:13px;font-weight:700;line-height:1.55;margin-bottom:10px;border:1px solid rgba(255,255,255,0.08);background:rgba(255,255,255,0.026);color:#e8eaf4}
.risk-conclusion.low{border-color:rgba(0,229,255,0.18);background:rgba(0,229,255,0.045)}
.risk-conclusion.ml{border-color:rgba(255,215,64,0.2);background:rgba(255,215,64,0.055);color:#ffe178}
.risk-conclusion.medium{border-color:rgba(255,145,0,0.22);background:rgba(255,145,0,0.055);color:#ffc56d}
.risk-conclusion.mh{border-color:rgba(255,64,129,0.22);background:rgba(255,64,129,0.055);color:#ff9abd}
.risk-conclusion.high{border-color:rgba(255,23,68,0.25);background:rgba(255,23,68,0.07);color:#ff8fa3}
.weather-cards{margin-bottom:10px}
.forecast-strip{display:grid;grid-template-columns:repeat(4,1fr);gap:6px}
.weather-now-main{display:flex;align-items:center;justify-content:center;gap:6px;min-height:26px}
.weather-now-main b{font-size:13px;color:#eee;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.weather-icon{display:inline-flex;align-items:center;justify-content:center;width:28px;height:28px;border-radius:50%;font-style:normal;font-size:17px;font-weight:700;line-height:1;background:rgba(255,255,255,0.04);border:1px solid rgba(255,255,255,0.08);flex-shrink:0}
.weather-icon.sun{color:#ffd740;background:rgba(255,215,64,0.09);border-color:rgba(255,215,64,0.18)}
.weather-icon.cloud{color:#b8bfd6;background:rgba(184,191,214,0.07);border-color:rgba(184,191,214,0.14)}
.weather-icon.rain{color:#4dd0e1;background:rgba(77,208,225,0.08);border-color:rgba(77,208,225,0.18)}
.weather-icon.fog{color:#c7cbe0;background:rgba(199,203,224,0.07);border-color:rgba(199,203,224,0.14)}
.weather-icon.snow{color:#e1f5fe;background:rgba(225,245,254,0.08);border-color:rgba(225,245,254,0.18)}
.weather-icon.storm{color:#ffca28;background:rgba(255,202,40,0.09);border-color:rgba(255,202,40,0.2)}
.forecast-day{background:rgba(255,255,255,0.018);border:1px solid var(--b1);border-radius:8px;padding:8px 6px;text-align:center;min-width:0;display:flex;flex-direction:column;align-items:center;gap:3px}
.forecast-day div{font-size:10px;color:#778}.forecast-day em{font-style:normal;font-size:10px;color:#c8ccda;max-width:100%;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.forecast-day b{display:block;font-size:12px;color:#ddd;margin:0}
.rain-note{font-size:13px;line-height:1.6;color:#aaa;padding:10px 12px;background:rgba(0,229,255,0.035);border:1px solid rgba(0,229,255,0.12);border-radius:8px}
.potato-line{display:flex;gap:8px;flex-wrap:wrap}
.potato-line span{flex:1 1 110px;min-width:0;background:rgba(255,255,255,0.015);border:1px solid var(--b1);border-radius:8px;padding:9px 10px;font-size:11px;color:#778}
.potato-line b{display:block;color:#eee;font-size:13px;margin-top:2px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.location-card{display:grid;grid-template-columns:repeat(3,1fr);gap:8px}
.location-card div{min-width:0;background:rgba(255,255,255,0.018);border:1px solid var(--b1);border-radius:8px;padding:9px 10px}
.location-card span{display:block;font-size:10px;color:#778;margin-bottom:4px}
.location-card b{display:block;font-size:12px;color:#e8eaf4;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.inline-curve{margin-top:12px;border:1px solid rgba(0,229,255,0.12);border-radius:8px;background:rgba(0,0,0,0.16);overflow:hidden}
.inline-curve-title{padding:10px 12px;border-bottom:1px solid rgba(255,255,255,0.06);font-size:12px;font-weight:800;color:#e9fbff;letter-spacing:.4px;background:linear-gradient(135deg,rgba(0,229,255,0.06),rgba(179,136,255,0.06))}
.inline-curve-emergence{display:grid;grid-template-columns:1fr auto auto;gap:8px;align-items:end;padding:12px;border-bottom:1px solid rgba(255,255,255,0.05);background:linear-gradient(180deg,rgba(255,255,255,0.018),rgba(255,255,255,0.006))}
.inline-curve-emergence label{display:flex;min-width:0;flex-direction:column;gap:5px}
.inline-curve-emergence label span{font-size:11px;font-weight:800;color:#dbefff;letter-spacing:.4px}
.inline-curve-emergence input{height:36px;min-width:0;background:rgba(0,229,255,0.055);border:1px solid rgba(0,229,255,0.22);border-radius:8px;color:#f3fbff;padding:0 10px;font-family:inherit;font-size:12px;outline:none}
.inline-curve-emergence input:focus{border-color:rgba(0,229,255,0.55);box-shadow:0 0 0 2px rgba(0,229,255,0.08)}
.inline-curve-emergence p{grid-column:1/-1;margin:0;color:#858da3;font-size:11px;line-height:1.55}
.inline-curve-head{display:flex;align-items:end;gap:8px;flex-wrap:wrap;padding:10px 12px;border-bottom:1px solid rgba(255,255,255,0.05)}
.inline-curve-head[hidden]{display:none}
.inline-curve-head label{display:flex;flex:1 1 116px;min-width:0;flex-direction:column;gap:4px;font-size:10px;color:#858da3}
.inline-curve-head input{height:32px;min-width:0;background:rgba(255,255,255,0.04);border:1px solid rgba(255,255,255,0.1);border-radius:7px;color:#ddd;padding:0 8px;font-family:inherit;font-size:11px;outline:none}
.inline-curve-head input:focus{border-color:rgba(0,229,255,0.36)}
.panel-curve-calc{height:32px;padding:0 12px;border:1px solid rgba(0,229,255,0.22);border-radius:7px;background:rgba(0,229,255,0.08);color:#e9fbff;font-family:inherit;font-size:11px;font-weight:800;cursor:pointer}
.panel-curve-calc:hover{border-color:rgba(0,229,255,0.42);background:rgba(0,229,255,0.13)}
.panel-curve-calc.primary{height:36px;background:linear-gradient(135deg,rgba(0,229,255,0.16),rgba(179,136,255,0.14));border-color:rgba(0,229,255,0.34)}
.inline-curve-advanced{height:36px;padding:0 10px;border:1px solid rgba(255,255,255,0.08);border-radius:8px;background:rgba(255,255,255,0.035);color:#9ba3b8;font-family:inherit;font-size:11px;font-weight:700;cursor:pointer}
.inline-curve-advanced:hover,.inline-curve-advanced.active{color:#e9fbff;border-color:rgba(179,136,255,0.24);background:rgba(179,136,255,0.08)}
.inline-curve-body{padding:8px;min-height:190px}
.icm-canvas-row{display:flex;flex-direction:column;gap:8px;min-width:0;overflow:hidden}
.icm-canvas-row canvas{display:block;max-width:100%;border-radius:6px}
.echart-curve{width:100%;height:430px;min-height:360px;border:1px solid rgba(255,255,255,0.055);border-radius:8px;overflow:hidden;background:rgba(6,6,15,0.92)}
.curve-canvas-legend{display:flex;align-items:center;justify-content:center;gap:10px 14px;flex-wrap:wrap;padding:2px 4px 8px;color:#8d95a8;font-size:9px;line-height:1.2}
.curve-canvas-legend span{display:inline-flex;align-items:center;gap:5px;min-width:0}
.curve-canvas-legend i{width:14px;height:3px;border-radius:999px;flex:0 0 auto}
.curve-canvas-legend span.dashed i{height:0;border-top:2px dashed currentColor;background:transparent!important;color:#29b6f6}
.curve-canvas-legend b{font-weight:600;white-space:nowrap}
.icm-subchart-title{margin:2px 4px -2px;padding-top:8px;border-top:1px solid rgba(255,255,255,0.06);color:#7d879c;font-size:10px;font-weight:800;letter-spacing:.4px;text-transform:uppercase}
.ai-backdrop{position:fixed;inset:0;background:rgba(0,0,0,0.58);z-index:3200;display:flex;align-items:center;justify-content:center;opacity:0;pointer-events:none;transition:opacity 0.3s}
.ai-backdrop.show{opacity:1;pointer-events:auto}
.ai-dialog{width:min(980px,92vw);height:min(760px,86dvh);overflow:hidden;background:rgba(12,14,32,0.97);border:1px solid rgba(179,136,255,0.18);border-radius:14px;box-shadow:0 18px 60px rgba(0,0,0,0.75);display:flex;flex-direction:column}
.ai-dialog,.ai-answer,.ai-msg-content pre{scrollbar-width:thin;scrollbar-color:rgba(154,166,196,0.34) rgba(255,255,255,0.035)}
.ai-dialog::-webkit-scrollbar,.ai-answer::-webkit-scrollbar,.ai-msg-content pre::-webkit-scrollbar{width:8px;height:8px}
.ai-dialog::-webkit-scrollbar-track,.ai-answer::-webkit-scrollbar-track,.ai-msg-content pre::-webkit-scrollbar-track{background:rgba(255,255,255,0.025);border-radius:999px}
.ai-dialog::-webkit-scrollbar-thumb,.ai-answer::-webkit-scrollbar-thumb,.ai-msg-content pre::-webkit-scrollbar-thumb{background:linear-gradient(180deg,rgba(0,229,255,0.28),rgba(179,136,255,0.34));border:2px solid rgba(12,14,32,0.96);border-radius:999px}
.ai-dialog::-webkit-scrollbar-thumb:hover,.ai-answer::-webkit-scrollbar-thumb:hover,.ai-msg-content pre::-webkit-scrollbar-thumb:hover{background:linear-gradient(180deg,rgba(0,229,255,0.45),rgba(179,136,255,0.5))}
.ai-dialog::-webkit-scrollbar-corner,.ai-answer::-webkit-scrollbar-corner,.ai-msg-content pre::-webkit-scrollbar-corner{background:transparent}
.ai-hd{position:sticky;top:0;background:rgba(12,14,32,0.98);padding:14px 18px;border-bottom:1px solid var(--b1);display:flex;justify-content:space-between;align-items:center}
.ai-title{font-weight:800;font-size:16px;color:#eee;letter-spacing:1px}
.ai-subtitle{font-size:11px;color:#858aa0;margin-top:3px;letter-spacing:0}
.ai-x{width:32px;height:32px;border-radius:50%;border:1px solid var(--b2);background:rgba(255,255,255,0.04);color:#aaa;cursor:pointer}
.ai-bd{padding:14px 18px 10px;display:block;min-height:0;flex:1}
.ai-main{height:100%;display:flex;flex-direction:column;gap:10px;min-width:0;min-height:0}
.ai-orb{width:54px;height:54px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-weight:900;color:#061018;background:linear-gradient(135deg,#00e5ff,#ffd740);box-shadow:0 0 24px rgba(0,229,255,0.24);margin-bottom:12px}
.ai-answer{flex:1;min-height:0;overflow-y:auto;padding:12px;border-radius:10px;background:rgba(0,0,0,0.16);border:1px solid var(--b1)}
.ai-msg{margin:10px 0;display:flex;flex-direction:column;gap:4px}
.ai-msg.user{align-items:flex-end}.ai-msg.assistant{align-items:flex-start}
.ai-msg-content{max-width:86%;font-size:13px;line-height:1.78;color:#d6d6df;padding:12px 14px;border-radius:10px;border:1px solid var(--b1);background:rgba(255,255,255,0.025)}
.ai-msg.user .ai-msg-content{background:rgba(0,229,255,0.08);border-color:rgba(0,229,255,0.18);color:#e9fbff}
.ai-msg-provider{font-size:9px;color:#00e5ff;letter-spacing:1px;text-transform:uppercase;margin-left:4px}
.ai-msg-content p{margin:0 0 8px}.ai-msg-content p:last-child{margin-bottom:0}.ai-msg-content ul{margin:0;padding-left:18px}.ai-msg-content li{margin:4px 0}
.ai-msg-content h1,.ai-msg-content h2,.ai-msg-content h3{font-size:14px;line-height:1.45;margin:10px 0 6px;color:#f3f6ff}
.ai-msg-content h1:first-child,.ai-msg-content h2:first-child,.ai-msg-content h3:first-child{margin-top:0}
.ai-msg-content ol{margin:0;padding-left:18px}.ai-msg-content blockquote{margin:8px 0;padding:8px 10px;border-left:3px solid rgba(0,229,255,0.45);background:rgba(0,229,255,0.05);color:#cfd9ef;border-radius:0 6px 6px 0}
.ai-msg-content table{width:100%;border-collapse:collapse;margin:8px 0;font-size:12px;overflow:hidden;border-radius:6px}
.ai-msg-content th,.ai-msg-content td{border:1px solid rgba(255,255,255,0.08);padding:6px 8px;text-align:left;vertical-align:top}
.ai-msg-content th{background:rgba(255,255,255,0.06);color:#eef2ff}
.ai-msg-content code{font-family:Consolas,'SFMono-Regular',monospace;font-size:12px;background:rgba(255,255,255,0.07);border:1px solid rgba(255,255,255,0.07);border-radius:5px;padding:1px 4px;color:#e9fbff}
.ai-msg-content pre{margin:8px 0;padding:10px;border-radius:8px;background:rgba(0,0,0,0.28);border:1px solid rgba(255,255,255,0.08);overflow:auto}
.ai-msg-content pre code{background:transparent;border:0;padding:0;color:#dbe7ff}
.ai-suggestions{display:flex;gap:8px;flex-wrap:wrap;flex-shrink:0}
.ai-suggestions button{background:rgba(255,255,255,0.035);border:1px solid var(--b1);color:#aaa;border-radius:999px;padding:7px 11px;font-size:11px;cursor:pointer}
.ai-suggestions button:hover{border-color:rgba(0,229,255,0.25);color:#e9fbff;background:rgba(0,229,255,0.06)}
.ai-input{width:100%;min-height:72px;max-height:130px;resize:vertical;background:rgba(255,255,255,0.035);border:1px solid var(--b2);border-radius:8px;color:#ddd;padding:12px 14px;font-family:inherit;font-size:13px;line-height:1.55;outline:none;flex-shrink:0}
.ai-input:focus{border-color:var(--c6)}
.ai-ft{padding:0 20px 18px;display:flex;gap:10px;justify-content:flex-end;align-items:center}
.ai-clear,.ai-send{height:36px;border-radius:8px;font-family:inherit;font-size:12px;font-weight:700;letter-spacing:0;border:1px solid transparent;cursor:pointer;transition:background 0.2s,border-color 0.2s,color 0.2s,box-shadow 0.2s,transform 0.2s}
.ai-clear{padding:0 12px;background:transparent;color:#7f879b;border-color:rgba(255,255,255,0.06)}
.ai-clear:hover{color:#d7dbea;background:rgba(255,255,255,0.045);border-color:rgba(255,255,255,0.12)}
.ai-send{min-width:92px;padding:0 18px;color:#061018;background:linear-gradient(135deg,#00e5ff,#b388ff);box-shadow:0 8px 24px rgba(0,229,255,0.16)}
.ai-send:hover{transform:translateY(-1px);box-shadow:0 12px 30px rgba(0,229,255,0.22)}
.ai-send:active{transform:translateY(0)}
.ai-ft button:disabled{opacity:0.72;cursor:wait;transform:none}
.ai-ft .loading{position:relative;overflow:hidden}
.ai-ft .loading::after{content:'';position:absolute;inset:0;background:linear-gradient(90deg,transparent,rgba(255,255,255,0.12),transparent);animation:aiSweep 1.1s linear infinite}
@keyframes aiSweep{from{transform:translateX(-100%)}to{transform:translateX(100%)}}
.screen-backdrop{position:fixed;inset:0;background:rgba(0,0,0,0.72);z-index:3100;display:flex;align-items:center;justify-content:center;opacity:0;pointer-events:none;transition:opacity 0.3s}
.screen-backdrop.show{opacity:1;pointer-events:auto}
.screen-dialog{width:min(1180px,94vw);height:min(780px,88vh);background:rgba(8,10,24,0.98);border:1px solid rgba(0,229,255,0.16);border-radius:14px;box-shadow:0 18px 70px rgba(0,0,0,0.78);display:flex;flex-direction:column;overflow:hidden}
.screen-backdrop.is-fullscreen{padding:0;background:#03040a}
.screen-backdrop.is-fullscreen .screen-dialog{width:100vw;height:100dvh;border-radius:0;border-color:rgba(0,229,255,0.1);box-shadow:none}
.screen-hd{padding:12px 14px;border-bottom:1px solid var(--b1);display:flex;align-items:center;justify-content:space-between;gap:12px;background:linear-gradient(90deg,rgba(0,229,255,0.08),rgba(179,136,255,0.08))}
.screen-title{font-size:15px;font-weight:800;color:#eee}.screen-sub{font-size:10px;color:#778;margin-top:2px}.screen-actions{display:flex;align-items:center;gap:8px}
.screen-fullscreen{height:30px;min-width:36px;padding:0 10px;border:1px solid rgba(255,255,255,0.1);border-radius:7px;background:rgba(255,255,255,0.04);color:#d7def2;display:inline-flex;align-items:center;justify-content:center;gap:7px;font-family:inherit;font-size:11px;font-weight:700;cursor:pointer;transition:background .18s,border-color .18s,color .18s}
.screen-fullscreen:hover{background:rgba(0,229,255,0.08);border-color:rgba(0,229,255,0.26);color:#fff}
.screen-full-icon{position:relative;width:14px;height:14px;display:inline-block;flex-shrink:0}
.screen-full-icon:before,.screen-full-icon:after{content:'';position:absolute;inset:0;border:2px solid currentColor;border-radius:2px}
.screen-full-icon:before{clip-path:polygon(0 0,42% 0,42% 16%,16% 16%,16% 42%,0 42%,0 0,58% 0,100% 0,100% 42%,84% 42%,84% 16%,58% 16%)}
.screen-full-icon:after{clip-path:polygon(0 58%,16% 58%,16% 84%,42% 84%,42% 100%,0 100%,0 58%,58% 84%,84% 84%,84% 58%,100% 58%,100% 100%,58% 100%)}
.screen-backdrop.is-fullscreen .screen-full-icon:before{clip-path:polygon(16% 0,58% 0,58% 16%,42% 16%,42% 42%,16% 42%,16% 0,84% 0,100% 0,100% 42%,74% 42%,74% 16%,84% 16%)}
.screen-backdrop.is-fullscreen .screen-full-icon:after{clip-path:polygon(16% 58%,42% 58%,42% 84%,58% 84%,58% 100%,16% 100%,16% 58%,74% 84%,74% 58%,100% 58%,100% 100%,84% 100%,84% 84%)}
.screen-frame{border:0;flex:1;width:100%;background:#050510}
.loading{position:fixed;inset:0;background:var(--bg);z-index:9999;display:flex;flex-direction:column;align-items:center;justify-content:center}
.loading.hidden{display:none}
.ld{position:relative;width:48px;height:48px;margin-bottom:24px}
.ld div{position:absolute;width:100%;height:100%;border-radius:50%;border:1.5px solid transparent;animation:lda 1.6s cubic-bezier(0.68,-0.55,0.27,1.55) infinite}
.ld div:nth-child(1){border-top-color:var(--c6);animation-delay:0s}
.ld div:nth-child(2){width:70%;height:70%;top:15%;left:15%;border-right-color:var(--c1);animation-delay:-0.5s}
.ld div:nth-child(3){width:40%;height:40%;top:30%;left:30%;border-bottom-color:var(--c4);animation-delay:-1s}
@keyframes lda{0%{transform:rotate(0)}50%{transform:rotate(300deg)}100%{transform:rotate(360deg)}}
.lt{color:#778;font-size:12px;letter-spacing:3px;font-weight:500}
@media(max-width:768px){
  .header{padding:6px 8px;gap:6px}
  .header-l{gap:6px;min-width:0;flex:0 1 auto}
  .header-l .logo{width:24px;height:24px}
  .header-l .t{display:block;font-size:11px;letter-spacing:0;max-width:26vw;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
  .header-r{gap:5px;min-width:0;flex:1;justify-content:flex-end}
  .btn{height:30px;padding:0 8px;font-size:10px;border-radius:6px;gap:0;flex-shrink:0}
  #btnR{width:30px;padding:0;justify-content:center}
  #btnRLabel{display:none}
  #btnToggle{width:30px;padding:0;justify-content:center}
  #btnLang{min-width:32px;padding:0 7px}
  #btnScreen{display:flex}
  #btnAi{right:12px;bottom:16px;width:72px;height:72px}
  #btnAi::before{width:72px;height:72px}
  .search-w{flex:1;min-width:0}
  .search-b{width:100%;font-size:11px;padding:6px 8px 6px 28px}
  .search-b:focus{width:100%}
  .search-d{width:210px;right:-30px}
  .lu{display:none!important}
  .legend{padding:6px 8px;font-size:10px;line-height:1.8;border-radius:6px;bottom:22px}
  .legend strong{font-size:10px}.legend i{width:8px;height:8px;margin-right:4px}
  .layer-control{top:54px;max-width:calc(100vw - 20px);gap:5px;padding:5px;flex-wrap:wrap;justify-content:center}
  .legend-toggle{height:28px;max-width:calc(100vw - 34px);font-size:10px;padding:0 8px;gap:5px}
  .legend-toggle::after{font-size:9px}
  .maplibregl-ctrl-group button{width:30px!important;height:30px!important}
  .panel{top:auto;bottom:0;left:0;right:0;width:100%;max-height:78dvh;border-radius:18px 18px 0 0;transform:translateY(100%);opacity:0;box-shadow:0 -8px 40px rgba(0,0,0,0.6);overscroll-behavior:contain}
  .panel.open{transform:translateY(0);opacity:1}
  .panel-h{display:block}
  .panel-hd{padding:14px 16px;border-radius:18px 18px 0 0}
  .panel-hd .cn{font-size:16px}
  .panel-hd .cp{font-size:11px}
  .panel-bd{padding:12px 16px 24px}
  .panel-x{width:36px;height:36px;min-width:36px;min-height:36px;top:12px;right:12px}
  .rr{width:90px;height:90px;margin-bottom:8px}
  .rr-bg{border-width:5px!important;inset:3px!important}
  .rr-fg{border-width:5px!important;inset:3px!important}
  .rv .n{font-size:32px}.rt{font-size:11px;padding:3px 12px}
  .cards{gap:4px}.card{padding:10px 6px;border-radius:8px}
  .card .cv{font-size:15px}.card .cl{font-size:10px}.card .cs{font-size:9px}
  .heatmap{height:54px}.hb-d{height:3px!important}
  .sec-tt{font-size:10px}.fn{font-size:10px;padding:10px}.si{font-size:12px;padding:8px 12px}
  .forecast-strip{grid-template-columns:repeat(2,1fr)}
  .location-card{grid-template-columns:1fr}
  .inline-curve-emergence{grid-template-columns:1fr 1fr}
  .inline-curve-emergence label{grid-column:1/-1}
  .inline-curve-advanced,.panel-curve-calc.primary{width:100%}
  .echart-curve{height:400px;min-height:360px}
  .ai-backdrop{align-items:flex-end;justify-content:center;background:rgba(0,0,0,0.48)}
  .ai-dialog{width:100vw;height:min(82dvh,720px);border-radius:18px 18px 0 0;border-left:0;border-right:0;border-bottom:0}
  .ai-hd{padding:12px 14px}
  .ai-title{font-size:14px}.ai-subtitle{font-size:10px;max-width:calc(100vw - 72px);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
  .ai-answer{flex:1}
  .ai-msg-content{max-width:96%}
  .ai-suggestions{flex-wrap:nowrap;overflow-x:auto;padding-bottom:2px}
  .ai-suggestions button{white-space:nowrap;flex-shrink:0}
  .ai-input{min-height:64px;max-height:104px;font-size:12px}
  .ai-bd{padding:12px}.ai-ft{padding:0 12px 12px}
  .screen-dialog{width:96vw;height:84vh}.screen-title{font-size:13px}.screen-sub{display:none}
}
@media(max-height:720px) and (min-width:769px){
  .ai-backdrop{justify-content:flex-end;align-items:stretch;background:rgba(0,0,0,0.36);padding:12px}
  .ai-dialog{width:min(620px,46vw);height:calc(100dvh - 24px);max-height:none;border-radius:14px}
  .ai-hd{padding:11px 14px}
  .ai-title{font-size:14px}.ai-subtitle{display:none}
  .ai-bd{padding:10px 12px 8px}
  .ai-answer{padding:10px;border-radius:8px}
  .ai-msg{margin:8px 0}.ai-msg-content{font-size:12px;line-height:1.6;max-width:94%;padding:10px 12px}
  .ai-suggestions{flex-wrap:nowrap;overflow-x:auto;gap:6px;padding-bottom:2px}
  .ai-suggestions button{white-space:nowrap;flex-shrink:0;padding:6px 10px;font-size:10px}
  .ai-input{min-height:52px;max-height:88px;font-size:12px;padding:9px 11px}
  .ai-ft{padding:0 12px 10px}
  .ai-clear,.ai-send{height:32px;font-size:11px}.ai-send{min-width:78px}
}
@media(max-width:400px){
  .header-l::after{font-size:12px}
  .search-b,.search-b:focus{width:100%}
  .layer-control{gap:4px;padding:4px;max-width:calc(100vw - 14px)}
  .legend-toggle{height:26px;font-size:9px;padding:0 7px}
  .card .cv{font-size:15px}
  .panel{max-height:82dvh}
  .rr{width:75px;height:75px}.rv .n{font-size:28px}
}
@supports(padding-bottom:env(safe-area-inset-bottom)){.panel{padding-bottom:env(safe-area-inset-bottom)}}
/* === 气象站 Popup === */
.sp-overlay{position:fixed;z-index:900;pointer-events:none;transform:translate(-50%,-100%);margin-top:-14px;display:none}
.sp-overlay.show{display:block}
.sp-arrow{width:0;height:0;border-left:8px solid transparent;border-right:8px solid transparent;border-top:8px solid rgba(14,16,32,0.95);margin:0 auto}
.sp-card{background:rgba(14,16,32,0.95);border:1px solid rgba(255,255,255,0.08);border-radius:12px;width:300px;overflow:hidden;pointer-events:auto;box-shadow:0 8px 32px rgba(0,0,0,0.6)}
.sp-hd{display:flex;justify-content:space-between;align-items:flex-start;padding:12px 14px 8px;border-bottom:1px solid rgba(255,255,255,0.04)}
.sp-hd .sp-name{font-size:14px;font-weight:700;color:#eee;padding-right:28px;line-height:1.3}
.sp-hd .sp-addr{font-size:10px;color:#888;margin-top:2px}
.sp-close{position:absolute;top:8px;right:8px;width:24px;height:24px;min-width:24px;min-height:24px;border-radius:50%;background:rgba(255,255,255,0.04);border:1px solid rgba(255,255,255,0.08);color:#999;font-size:12px;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all 0.2s}
.sp-close:hover{background:rgba(255,64,129,0.15);border-color:var(--c4);color:#fff}
.sp-stat{display:inline-block;width:8px;height:8px;border-radius:50%;margin-right:6px;flex-shrink:0}
.sp-stat.safe{background:var(--c1);box-shadow:0 0 6px var(--c1)}
.sp-stat.warning{background:var(--c2);box-shadow:0 0 6px var(--c2)}
.sp-stat.danger{background:var(--c5);box-shadow:0 0 8px var(--c5);animation:spPulse 1.5s ease-in-out infinite}
@keyframes spPulse{0%,100%{box-shadow:0 0 4px var(--c5)}50%{box-shadow:0 0 12px var(--c5),0 0 20px rgba(255,23,68,0.3)}}
.sp-bd{padding:10px 14px 6px}
.sp-sec-tt{font-size:10px;color:#888;text-transform:uppercase;letter-spacing:2px;margin-bottom:6px;font-weight:600}
.sp-grid{display:grid;grid-template-columns:1fr 1fr;gap:4px 12px;margin-bottom:10px}
.sp-kv .sp-k{font-size:10px;color:#777}.sp-kv .sp-v{font-size:13px;color:#ddd;font-weight:500}
.sp-forecast{max-height:0;overflow:hidden;transition:max-height 0.35s}
.sp-forecast.open{max-height:200px;overflow-y:auto}
.sp-fc-toggle{font-size:10px;color:var(--c6);cursor:pointer;margin:4px 0 8px;display:flex;align-items:center;gap:4px;letter-spacing:1px}
.sp-fc-toggle:hover{color:#d0b8ff}
.sp-fc-toggle .arr{transition:transform 0.25s;font-size:8px}
.sp-fc-toggle .arr.open{transform:rotate(90deg)}
.sp-fc-day{display:flex;justify-content:space-between;padding:3px 0;font-size:11px;border-bottom:1px solid rgba(255,255,255,0.02)}
.sp-fc-day .sp-fd{color:#999;min-width:48px}.sp-fc-day .sp-ft{color:#ef9a9a;min-width:36px;text-align:center}.sp-fc-day .sp-fh{color:#90caf9;min-width:36px;text-align:center}.sp-fc-day .sp-fr{color:#a5d6a7;min-width:36px;text-align:right}
.sp-loading{text-align:center;padding:20px;color:#777;font-size:12px}
.sp-ft{padding:8px 14px 12px}
.sp-btn{display:block;width:100%;background:linear-gradient(135deg,rgba(179,136,255,0.2),rgba(0,229,255,0.1));border:1px solid rgba(179,136,255,0.3);color:#d0c4ff;padding:8px;border-radius:8px;font-size:12px;font-weight:600;cursor:pointer;transition:all 0.3s;font-family:inherit;letter-spacing:1px}
.sp-btn:hover{background:linear-gradient(135deg,rgba(179,136,255,0.35),rgba(0,229,255,0.2));border-color:var(--c6);color:#fff}
/* === 侵染曲线 Modal === */
.icm-backdrop{position:fixed;inset:0;background:rgba(0,0,0,0.65);z-index:3000;display:flex;align-items:center;justify-content:center;opacity:0;pointer-events:none;transition:opacity 0.35s}
.icm-backdrop.show{opacity:1;pointer-events:auto}
.icm-dialog{background:rgba(12,14,32,0.96);border:1px solid rgba(255,255,255,0.08);border-radius:16px;width:90vw;max-width:600px;max-height:85vh;overflow-y:auto;overflow-x:hidden;box-shadow:0 16px 48px rgba(0,0,0,0.7);display:flex;flex-direction:column;box-sizing:border-box}
.icm-dialog *{box-sizing:border-box;max-width:100%}
.icm-hd{padding:16px 20px;border-bottom:1px solid rgba(255,255,255,0.04);display:flex;justify-content:space-between;align-items:center;position:sticky;top:0;background:rgba(12,12,32,0.98);z-index:1;border-radius:16px 16px 0 0}
.icm-hd .icm-title{font-size:16px;font-weight:700;color:#eee}
.icm-hd .icm-x{width:32px;height:32px;min-width:32px;min-height:32px;border-radius:50%;background:rgba(255,255,255,0.04);border:1px solid rgba(255,255,255,0.08);color:#999;font-size:16px;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all 0.2s}
.icm-hd .icm-x:hover{background:rgba(255,64,129,0.15);border-color:var(--c4);color:#fff}
.icm-bd{padding:16px 20px;flex:1;overflow-x:hidden;word-wrap:break-word}
.icm-dates{display:flex;gap:12px;align-items:center;margin-bottom:16px;flex-wrap:wrap}
.icm-dates label{font-size:12px;color:#aaa;white-space:nowrap}
.icm-dates input[type=date]{background:rgba(255,255,255,0.04);border:1px solid rgba(255,255,255,0.1);color:#ddd;padding:6px 10px;border-radius:6px;font-size:12px;font-family:inherit;outline:none}
.icm-dates input[type=date]:focus{border-color:var(--c6)}
.icm-canvas-w{position:relative;background:rgba(0,0,0,0.2);border-radius:10px;border:1px solid rgba(255,255,255,0.04);overflow:hidden}
.icm-canvas-w canvas{display:block;max-width:100%;height:auto}
.icm-canvas-row{display:block;width:100%}
.icm-canvas-row canvas{display:block;width:100%}
.icm-legend{display:flex;gap:16px;justify-content:center;margin-top:10px;flex-wrap:wrap}
.icm-legend .icm-litem{display:flex;align-items:center;gap:4px;font-size:11px;color:#aaa}
.icm-legend .icm-lsw{width:20px;height:3px;border-radius:1px}
.icm-loading{color:#888;font-size:13px;text-align:center;padding:40px}
.icm-error{color:var(--c4);font-size:13px;text-align:center;padding:40px}
.icm-empty{color:#777;font-size:13px;text-align:center;padding:40px}
.icm-ft{padding:12px 20px 20px;display:flex;gap:8px;justify-content:flex-end;flex-wrap:wrap}
.icm-ft .icm-calc{background:linear-gradient(135deg,rgba(179,136,255,0.25),rgba(0,229,255,0.15));border:1px solid rgba(179,136,255,0.35);color:#d0c4ff;padding:8px 20px;border-radius:8px;font-size:12px;font-weight:600;cursor:pointer;transition:all 0.3s;font-family:inherit;letter-spacing:1px}
.icm-ft .icm-calc:hover{background:linear-gradient(135deg,rgba(179,136,255,0.4),rgba(0,229,255,0.3));border-color:var(--c6);color:#fff}
.icm-ft .icm-cancel{background:rgba(255,255,255,0.04);border:1px solid rgba(255,255,255,0.08);color:#999;padding:8px 20px;border-radius:8px;font-size:12px;cursor:pointer;font-family:inherit}
.icm-ft .icm-cancel:hover{background:rgba(255,255,255,0.08);color:#bbb}
/* 专业统计面板 */
.icm-stats{display:flex;flex-wrap:wrap;gap:6px 14px;margin-bottom:10px;align-items:center}
.icm-stat{font-size:13px;color:#ccc;white-space:nowrap}
.icm-sv{font-weight:800;color:#fff;font-size:15px}
/* 用药建议 */
.icm-spray{margin-top:12px;background:rgba(255,255,255,0.015);border:1px solid rgba(255,255,255,0.06);border-radius:10px;padding:12px 14px}
.icm-spray-tt{font-size:12px;font-weight:700;color:#ccc;margin-bottom:8px}
.icm-spray-urgent{padding:6px 10px;border-radius:6px;font-size:11px;font-weight:600;margin-bottom:8px}
.icm-spray-urgent.immediate{background:rgba(255,23,68,0.12);color:#ff4081;border:1px solid rgba(255,23,68,0.2)}
.icm-spray-urgent.soon{background:rgba(255,215,64,0.1);color:#ffd740;border:1px solid rgba(255,215,64,0.2)}
.icm-spray-urgent.watch{background:rgba(66,165,245,0.08);color:#64b5f6;border:1px solid rgba(66,165,245,0.15)}
.icm-spray-grid{display:flex;flex-direction:column;gap:4px}
.icm-spray-item{background:rgba(255,255,255,0.02);border-radius:6px;padding:6px 10px;font-size:10px;color:#aaa;line-height:1.5;display:flex;align-items:center;gap:8px;flex-wrap:wrap}
.icm-spray-item b{color:#ddd;font-size:11px;min-width:56px;flex-shrink:0}
/* 多模型对比 */
.icm-compare{margin-top:10px;overflow-x:auto}
.icm-compare-tt{font-size:11px;font-weight:700;color:#ccc;margin-bottom:6px}
.icm-compare table{width:100%;border-collapse:collapse;font-size:10px;min-width:300px}
.icm-compare th{text-align:left;color:#777;padding:3px 6px;border-bottom:1px solid rgba(255,255,255,0.04);font-weight:500}
.icm-compare td{padding:3px 6px;color:#aaa;border-bottom:1px solid rgba(255,255,255,0.02)}
.icm-canvas-row{margin:8px 0;overflow:hidden}
@media(max-width:768px){
  .sp-card{width:260px}
  .icm-dialog{width:95vw;max-height:90vh;border-radius:14px}
  .icm-hd{padding:12px 14px;border-radius:14px 14px 0 0}
  .icm-hd .icm-title{font-size:14px}
  .icm-bd{padding:12px 14px}
  .icm-ft{padding:10px 14px 16px}
  .icm-dates{gap:8px}
}
