﻿:root{--bg:#f5f7fb;--panel:#fff;--text:#172033;--muted:#667085;--brand:#2f6bff;--brand2:#00c2a8;--danger:#ff5c7a;--line:#e8edf5;--shadow:0 18px 50px rgba(24,39,75,.08)}*{box-sizing:border-box}body{margin:0;font-family:-apple-system,BlinkMacSystemFont,"Segoe UI",Roboto,"PingFang SC","Microsoft YaHei",sans-serif;background:linear-gradient(135deg,#edf4ff,#f8fbff 42%,#eefbf8);color:var(--text)}button,input,select{font:inherit}.login{min-height:100vh;display:grid;place-items:center;padding:24px}.login-card{width:min(960px,100%);display:grid;grid-template-columns:1.1fr .9fr;background:rgba(255,255,255,.85);backdrop-filter:blur(18px);border:1px solid rgba(255,255,255,.8);border-radius:28px;box-shadow:var(--shadow);overflow:hidden}.hero{padding:56px;background:radial-gradient(circle at 20% 10%,#7bb2ff 0,#2f6bff 45%,#163c9e 100%);color:#fff}.hero h1{font-size:42px;margin:0 0 18px}.hero p{opacity:.86;line-height:1.8}.orb{width:180px;height:180px;border-radius:999px;background:conic-gradient(from 90deg,#00e0b8,#8ab4ff,#fff,#00e0b8);filter:drop-shadow(0 25px 40px rgba(0,0,0,.25));margin-top:38px}.form{padding:48px}.form h2{margin:0 0 24px}.field{display:flex;flex-direction:column;gap:8px;margin:14px 0}.field input,.field select{border:1px solid var(--line);border-radius:14px;padding:13px 14px;background:#fff}.btn{border:0;border-radius:14px;padding:12px 16px;background:var(--brand);color:#fff;cursor:pointer;box-shadow:0 10px 24px rgba(47,107,255,.25)}.btn.secondary{background:#eef3ff;color:var(--brand);box-shadow:none}.btn.danger{background:var(--danger)}.hint{color:var(--muted);font-size:13px;line-height:1.7}.error{color:var(--danger);min-height:22px}.layout{display:grid;grid-template-columns:260px 1fr;min-height:100vh}.side{background:#101828;color:#d0d5dd;padding:24px;position:sticky;top:0;height:100vh}.brand{font-weight:800;font-size:20px;color:#fff;margin-bottom:26px}.nav button{width:100%;display:flex;gap:10px;align-items:center;margin:8px 0;padding:12px;border:0;border-radius:14px;background:transparent;color:#d0d5dd;cursor:pointer;text-align:left}.nav button.active,.nav button:hover{background:#1d2939;color:#fff}.main{padding:28px 34px}.top{display:flex;justify-content:space-between;align-items:center;margin-bottom:22px}.top h1{margin:0;font-size:26px}.cards{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:16px}.card,.panel{background:rgba(255,255,255,.92);border:1px solid rgba(232,237,245,.9);border-radius:22px;box-shadow:var(--shadow)}.card{padding:20px}.card .num{font-size:30px;font-weight:800;margin-top:12px}.grid{display:grid;grid-template-columns:1.4fr .9fr;gap:16px;margin-top:16px}.panel{padding:20px;overflow:hidden}.panel h3{margin:0 0 16px}.table{width:100%;border-collapse:collapse}.table th,.table td{padding:12px;border-bottom:1px solid var(--line);text-align:left;font-size:14px}.tag{display:inline-flex;padding:5px 9px;border-radius:999px;background:#eef3ff;color:#2454c6;font-size:12px}.tag.ok{background:#e7fff8;color:#00856f}.tag.warn{background:#fff6e6;color:#a15c00}.actions{display:flex;gap:8px;flex-wrap:wrap}.modal{position:fixed;inset:0;background:rgba(16,24,40,.42);display:grid;place-items:center;padding:20px}.modal>div{width:min(560px,100%);background:#fff;border-radius:24px;padding:24px;box-shadow:var(--shadow)}.health{display:grid;grid-template-columns:repeat(5,1fr);gap:12px}.metric{padding:16px;border-radius:18px;background:#f7f9fc}.metric b{display:block;font-size:24px;margin-top:8px}.sdk{white-space:pre-wrap;background:#0b1220;color:#d7e5ff;border-radius:18px;padding:16px;overflow:auto}.empty{padding:40px;text-align:center;color:var(--muted)}@media(max-width:900px){.login-card{grid-template-columns:1fr}.hero{display:none}.layout{grid-template-columns:1fr}.side{height:auto;position:relative}.cards,.grid,.health{grid-template-columns:1fr}.main{padding:20px}.nav{display:grid;grid-template-columns:repeat(2,1fr);gap:8px}}

/* ===== 智慧服务平台大屏样式 ===== */
.bigscreen{min-height:100vh;background:#020b16;color:#e9f6ff;overflow:hidden;font-family:"Microsoft YaHei",Arial,sans-serif}.bs-header{height:126px;position:relative;text-align:center;background:linear-gradient(180deg,#03101f 0,#062949 68%,#020b16 69%)}.bs-header:before{content:"";position:absolute;left:0;right:0;top:24px;height:25px;background:linear-gradient(90deg,transparent,#1768b8 26%,#2789e8 33%,transparent 34%,transparent 66%,#2789e8 72%,#1768b8 79%,transparent)}.bs-header:after{content:"";position:absolute;left:31%;right:31%;bottom:8px;height:32px;background:#2582dc;clip-path:polygon(0 0,100% 0,94% 100%,6% 100%)}.bs-header h1{position:relative;z-index:2;margin:0;padding-top:36px;font-size:40px;font-weight:400;letter-spacing:4px;text-shadow:0 0 18px #40a7ff}.bs-wing{position:absolute;top:102px;width:31%;height:14px;background:repeating-linear-gradient(120deg,#08335b 0 4px,#20a3ff 5px 8px,transparent 9px 13px);opacity:.8}.bs-wing.left{left:20px}.bs-wing.right{right:20px}.bs-exit,.bs-logout{position:absolute;right:96px;top:18px;z-index:5;border:1px solid #1c78bd;background:#07233e;color:#bfe9ff;border-radius:3px;padding:6px 10px;cursor:pointer}.bs-logout{right:34px}.bs-grid{height:calc(100vh - 126px);padding:18px 20px 20px;display:grid;grid-template-columns:28% 41% 28%;gap:18px}.bs-left,.bs-right,.bs-center{display:grid;gap:18px;min-height:0}.bs-left{grid-template-rows:31% 19% 1fr}.bs-right{grid-template-rows:27% 24% 1fr}.bs-center{grid-template-rows:58% 1fr}.bs-bottom-row{display:grid;grid-template-columns:37% 63%;gap:18px}.bs-box{position:relative;background:rgba(7,31,56,.92);border:1px solid #10588e;box-shadow:inset 0 0 18px rgba(20,108,174,.28),0 0 12px rgba(0,89,170,.25);padding:28px 26px 18px;min-height:0}.bs-title{position:absolute;left:-1px;top:-10px;height:30px;line-height:26px;padding:0 24px 0 13px;border-left:1px solid #1981cf;border-top:1px solid #1981cf;background:#06213a;color:#fff;font-weight:700;font-size:14px;clip-path:polygon(0 0,82% 0,100% 100%,0 100%)}.bs-total{display:flex;align-items:center;gap:28px;margin-top:2px;margin-left:22px}.bs-total span{font-size:20px;font-weight:700}.bs-total b{display:flex;gap:5px}.bs-total i{font-style:normal;display:inline-grid;place-items:center;width:25px;height:38px;font-size:31px;color:#ffae1d;background:linear-gradient(180deg,#063c70,#0c5494 48%,#062748);box-shadow:0 0 12px rgba(26,141,255,.7);border-radius:3px}.bs-rings{display:grid;grid-template-columns:repeat(3,1fr);gap:26px;margin-top:30px;text-align:center}.bs-rings>div{position:relative;height:120px}.bs-rings canvas{width:118px!important;height:118px!important}.bs-rings em{position:absolute;left:50%;top:-5px;transform:translateX(-50%);font-style:normal;font-weight:700;color:#43d8ff}.bs-rings strong{position:absolute;left:0;right:0;top:49px;text-align:center;font-size:14px}.bs-rings small{display:block;margin-top:42px;font-size:15px;color:#fff}.bs-warn-cards{display:grid;grid-template-columns:repeat(3,1fr);gap:26px 40px;align-content:center;height:100%}.bs-warn{height:35px;border:1px solid #178bd8;background:linear-gradient(90deg,#0d65a6,#07345b);box-shadow:inset 0 -3px 0 #109ee8}.bs-warn label{display:block;width:82px;height:18px;line-height:18px;color:#fff;padding-left:8px;font-size:14px}.bs-warn b{display:block;padding-left:10px;font-size:16px}.bs-scroll p,.bs-health-list p{display:flex;justify-content:space-between;gap:10px;margin:0 0 12px;padding:9px 10px;border-left:3px solid #1aa6ff;background:rgba(13,78,124,.38);color:#cdeeff}.bs-empty{height:100%;display:grid;place-items:center;color:#4f8cb8}.bs-map{position:relative;background:#02060b;border-right:2px solid rgba(80,105,130,.6);overflow:hidden}.bs-map:before{content:"";position:absolute;inset:0;background:radial-gradient(circle at 58% 45%,rgba(16,116,193,.25),transparent 35%),radial-gradient(circle at 50% 70%,rgba(9,57,113,.42),transparent 48%)}.bs-map svg{position:absolute;inset:0;width:100%;height:100%;filter:drop-shadow(0 0 8px #0b54af)}.bs-map path,.bs-map circle{fill:rgba(7,20,38,.75);stroke:#223f97;stroke-width:2}.bs-map path:first-child{stroke:#b9272c}.city{position:absolute;color:#00d5ff;font-size:13px;text-shadow:0 0 8px #00c4ff}.c1{right:25%;top:35%}.c2{right:18%;top:54%}.c3{right:32%;bottom:18%}.c4{left:42%;top:57%}.c5{left:19%;top:34%}.c6{right:10%;top:14%}.rank p,.bars p{display:grid;grid-template-columns:80px 1fr 45px;align-items:center;gap:10px;margin:13px 0}.rank b{color:#45d7ff}.bars i,.genderbar{height:12px;border-radius:20px;background:#123d64;overflow:hidden}.bars i b{display:block;height:100%;background:#125e9a}.legend{display:flex;gap:13px;justify-content:center;font-size:12px;margin-top:-10px}.legend span:before{content:"";display:inline-block;width:24px;height:12px;border-radius:3px;background:var(--c);margin-right:5px;vertical-align:-2px}.warncount canvas{height:145px!important}.users canvas{display:block;margin:auto;width:160px!important;height:160px!important}.gender{display:flex;justify-content:center;gap:46px;text-align:center;font-size:15px}.gender b{color:#fff}.genderbar{width:145px;margin:12px auto}.genderbar i{display:block;width:100%;height:100%;background:#b486ff}.bs-health-list i{width:8px;height:8px;border-radius:50%;background:#ff5252;box-shadow:0 0 9px #ff5252;margin-top:6px}.bs-health-list p{justify-content:flex-start}.bs-health-list span{margin-left:auto;color:#ffd166}@media(max-width:1100px){.bs-grid{height:auto;grid-template-columns:1fr}.bs-left,.bs-right,.bs-center,.bs-bottom-row{grid-template-rows:auto;grid-template-columns:1fr}.bigscreen{overflow:auto}.bs-box{min-height:220px}.bs-map{height:420px}}

/* ===== AI健康监测运营中心视觉系统 ===== */
.ai-screen{min-height:100vh;background:#050816;color:#eaf7ff;position:relative;overflow:hidden;padding:18px 22px 20px;font-family:"Inter","DIN Alternate","Microsoft YaHei",sans-serif}.ai-bg{position:absolute;inset:0;pointer-events:none;background:radial-gradient(circle at 50% 12%,rgba(0,148,255,.22),transparent 32%),radial-gradient(circle at 18% 48%,rgba(151,71,255,.16),transparent 30%),radial-gradient(circle at 82% 50%,rgba(0,255,209,.12),transparent 28%),linear-gradient(180deg,#060b1d,#030711 58%,#040915)}.ai-bg:before{content:"";position:absolute;inset:0;background-image:linear-gradient(rgba(90,190,255,.045) 1px,transparent 1px),linear-gradient(90deg,rgba(90,190,255,.045) 1px,transparent 1px);background-size:44px 44px;mask-image:radial-gradient(circle at center,#000,transparent 80%)}.ai-bg i{position:absolute;border-radius:999px;filter:blur(20px);opacity:.55;animation:floatGlow 8s ease-in-out infinite}.ai-bg i:nth-child(1){width:260px;height:260px;background:#008cff;left:8%;top:12%}.ai-bg i:nth-child(2){width:220px;height:220px;background:#9b5cff;right:11%;top:20%;animation-delay:1.3s}.ai-bg i:nth-child(3){width:280px;height:280px;background:#00ffd1;left:45%;bottom:8%;animation-delay:2s}@keyframes floatGlow{50%{transform:translateY(18px) scale(1.08);opacity:.75}}.ai-head,.ai-kpis,.ai-layout,.ai-bottom{position:relative;z-index:1}.ai-head{height:74px;display:grid;grid-template-columns:1fr auto 1fr;align-items:center;border:1px solid rgba(86,196,255,.22);background:linear-gradient(90deg,rgba(5,20,44,.45),rgba(8,46,86,.58),rgba(5,20,44,.45));box-shadow:0 0 34px rgba(0,140,255,.18),inset 0 0 28px rgba(74,183,255,.08);clip-path:polygon(0 0,38% 0,40% 18px,60% 18px,62% 0,100% 0,100% 100%,0 100%)}.ai-head h1{margin:0;font-size:34px;font-weight:700;letter-spacing:8px;text-shadow:0 0 18px rgba(66,198,255,.85)}.ai-head-left,.ai-head-right{padding:0 22px;color:#8bdcff;font-size:13px;letter-spacing:1px}.ai-head-right{text-align:right}.ai-head-right button{border:1px solid rgba(82,206,255,.45);background:rgba(7,33,66,.72);color:#dff7ff;border-radius:10px;padding:8px 12px;margin-left:8px;cursor:pointer}.pulse-dot{display:inline-block;width:9px;height:9px;background:#25f0b1;border-radius:50%;box-shadow:0 0 14px #25f0b1;margin-right:8px}.ai-kpis{display:grid;grid-template-columns:repeat(5,1fr);gap:14px;margin:14px 0}.ai-kpi{height:92px;padding:15px 18px;border:1px solid rgba(65,176,255,.24);border-radius:18px;background:linear-gradient(135deg,rgba(12,29,59,.78),rgba(7,13,32,.66));box-shadow:inset 0 0 24px rgba(63,168,255,.07),0 12px 34px rgba(0,0,0,.22);position:relative;overflow:hidden}.ai-kpi:after{content:"";position:absolute;right:-30px;top:-45px;width:115px;height:115px;border-radius:50%;background:#2f7cff;filter:blur(14px);opacity:.22}.ai-kpi.cyan:after{background:#36d1ff}.ai-kpi.green:after{background:#28f0b0}.ai-kpi.orange:after{background:#ff9f43}.ai-kpi.purple:after{background:#b06cff}.ai-kpi p{margin:0;color:#9fc9e8}.ai-kpi b{display:block;margin-top:4px;font-size:32px;line-height:1;color:#fff;text-shadow:0 0 16px rgba(75,201,255,.55)}.ai-kpi em{font-style:normal;color:#5f87a8;font-size:11px}.ai-layout{height:calc(100vh - 282px);min-height:560px;display:grid;grid-template-columns:25.5% 47% 25.5%;gap:14px}.ai-col{display:grid;gap:14px;min-height:0}.ai-col.left{grid-template-rows:39% 25% 1fr}.ai-col.right{grid-template-rows:32% 28% 1fr}.neo-card{position:relative;border:1px solid rgba(80,193,255,.24);border-radius:20px;background:linear-gradient(180deg,rgba(8,23,52,.76),rgba(5,12,31,.72));box-shadow:0 18px 45px rgba(0,0,0,.24),inset 0 0 34px rgba(60,177,255,.065);backdrop-filter:blur(12px);overflow:hidden;padding:18px}.neo-card:before{content:"";position:absolute;left:18px;right:18px;top:0;height:1px;background:linear-gradient(90deg,transparent,#5be7ff,transparent);opacity:.7}.neo-card h3{margin:0 0 14px;font-size:15px;letter-spacing:1px;color:#d9f6ff}.vital-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:8px;margin-bottom:12px}.vital-grid div{border-radius:14px;background:rgba(255,255,255,.045);padding:10px;text-align:center}.vital-grid span{color:#7bb9d8;font-size:12px}.vital-grid b{display:block;color:#fff;font-size:24px}.vital-grid small{color:#6187a4}.vital-card canvas{height:145px!important}.ai-tags{display:grid;grid-template-columns:1fr 1fr;gap:10px}.ai-tags span{border:1px solid color-mix(in srgb,var(--c),transparent 35%);background:color-mix(in srgb,var(--c),transparent 86%);color:#fff;border-radius:12px;padding:10px;font-size:13px}.model-lines{margin-top:12px}.model-lines p{display:flex;justify-content:space-between;margin:8px 0;color:#9fc9e8}.model-lines i{font-style:normal;color:#2df0bb}.stream p{display:grid;grid-template-columns:12px 1fr 42px;align-items:center;gap:10px;margin:9px 0;padding:10px;border-radius:12px;background:rgba(66,159,255,.07);border:1px solid rgba(66,159,255,.11)}.stream i{width:8px;height:8px;border-radius:50%;background:#ff4d6d;box-shadow:0 0 10px #ff4d6d}.stream time{color:#78a9c8}.soft-empty{height:120px;display:grid;place-items:center;color:#6687a5}.ai-center{display:grid;grid-template-rows:48% 1fr;gap:14px;min-height:0}.ai-orbit-card{border-radius:26px;position:relative;overflow:hidden;background:radial-gradient(circle at 50% 48%,rgba(48,131,255,.18),transparent 44%),linear-gradient(180deg,rgba(8,25,58,.62),rgba(4,10,26,.72));border:1px solid rgba(91,218,255,.22);display:grid;grid-template-columns:52% 48%;align-items:center;padding:20px 42px}.orbit{width:330px;height:330px;margin:auto;position:relative;display:grid;place-items:center}.core{width:150px;height:150px;border-radius:50%;display:grid;place-items:center;text-align:center;background:radial-gradient(circle,#102d5e,#071126 72%);border:1px solid rgba(95,226,255,.7);box-shadow:0 0 34px rgba(64,199,255,.52),inset 0 0 32px rgba(42,184,255,.22);z-index:2}.core b{font-size:44px}.core span{font-size:13px;color:#9fdfff;margin-top:-30px}.orbit .r{position:absolute;inset:20px;border:1px solid rgba(72,206,255,.22);border-radius:50%;animation:spin 16s linear infinite}.orbit .r2{inset:55px;border-style:dashed;animation-duration:10s;animation-direction:reverse}.orbit .r3{inset:92px;border-color:rgba(176,108,255,.3);animation-duration:7s}.node{position:absolute;width:13px;height:13px;border-radius:50%;background:#28f0b0;box-shadow:0 0 18px #28f0b0}.n1{left:70px;top:70px}.n2{right:48px;top:142px;background:#36d1ff;box-shadow:0 0 18px #36d1ff}.n3{left:126px;bottom:38px;background:#ff4d6d;box-shadow:0 0 18px #ff4d6d}.n4{right:102px;bottom:82px;background:#ffd166;box-shadow:0 0 18px #ffd166}@keyframes spin{to{transform:rotate(360deg)}}.orbit-copy h2{font-size:30px;margin:0 0 14px}.orbit-copy p{color:#9fc9e8;line-height:1.8}.map-card{padding:18px}.ai-map{height:100%;min-height:260px;position:relative;border-radius:18px;overflow:hidden;background:radial-gradient(circle at 57% 48%,rgba(26,132,255,.22),transparent 34%),#030813}.ai-map svg{position:absolute;inset:7% 5%;width:90%;height:82%;filter:drop-shadow(0 0 11px rgba(54,209,255,.5))}.ai-map path{fill:rgba(7,23,52,.55);stroke:#2268d8;stroke-width:2}.hot{position:absolute;width:14px;height:14px;border-radius:50%;background:#27f0b0;box-shadow:0 0 0 8px rgba(39,240,176,.14),0 0 24px #27f0b0}.h1{left:68%;top:42%}.h2{left:72%;top:56%;background:#36d1ff}.h3{left:58%;top:64%;background:#ff4d6d}.h4{left:46%;top:52%;background:#ffd166}.province{position:absolute;color:#88dcff;font-size:13px}.p1{left:57%;top:69%}.p2{left:68%;top:51%}.p3{left:63%;top:37%}.risk-meter{height:142px;position:relative;display:grid;place-items:center}.risk-meter canvas{width:142px!important;height:142px!important}.risk-meter div{position:absolute;text-align:center}.risk-meter b{display:block;font-size:32px}.risk-meter span{color:#9fc9e8}.risk-list p{margin:10px 0}.risk-list span{display:block;color:#9fc9e8;font-size:12px;margin-bottom:6px}.risk-list i{display:block;height:8px;border-radius:20px;background:linear-gradient(90deg,#28f0b0,#ffd166,#ff4d6d);box-shadow:0 0 14px rgba(255,77,109,.22)}#devicePie{height:160px!important}.donut-legend{display:flex;justify-content:center;gap:22px;color:#9fc9e8}.rank-card p{display:grid;grid-template-columns:42px 1fr 72px;gap:8px;align-items:center;padding:10px;border-bottom:1px solid rgba(255,255,255,.07);margin:0}.rank-card em{font-style:normal;color:#36d1ff}.rank-card b{color:#28f0b0}.ai-bottom{height:136px;margin-top:14px}.ai-bottom canvas{height:84px!important}.ai-bottom h3{position:absolute;left:18px;top:12px}.ai-bottom canvas{margin-top:20px}@media(max-width:1200px){.ai-screen{overflow:auto}.ai-kpis,.ai-layout{grid-template-columns:1fr}.ai-layout{height:auto}.ai-col.left,.ai-col.right,.ai-center{grid-template-rows:auto}.ai-bottom{height:220px}.ai-head{grid-template-columns:1fr}.ai-head-left,.ai-head-right{display:none}.ai-head h1{font-size:24px;text-align:center}.ai-orbit-card{grid-template-columns:1fr}.orbit{width:260px;height:260px}}

/* ===== AI大屏尺寸兼容修正版：覆盖前面的尺寸规则 ===== */
.ai-screen{height:100vh;min-height:720px;overflow:hidden;padding:14px 22px 14px;background:#050816}.ai-head{height:74px}.ai-kpis{height:92px;margin:14px 0;grid-template-columns:repeat(5,minmax(0,1fr))}.ai-layout{height:calc(100vh - 74px - 92px - 28px - 120px - 42px);min-height:405px;grid-template-columns:25.5% 47% 25.5%;gap:14px}.ai-bottom{height:120px;margin-top:14px;padding:14px 18px}.ai-bottom h3{position:static;margin:0 0 4px}.ai-bottom canvas{height:78px!important;margin-top:0}.ai-col.left{grid-template-rows:35% 28% 1fr}.ai-col.right{grid-template-rows:33% 30% 1fr}.ai-center{grid-template-rows:48% 1fr}.neo-card{padding:14px 18px;border-radius:18px;min-height:0}.neo-card h3{font-size:15px;margin:0 0 10px}.vital-grid{gap:8px;margin-bottom:8px}.vital-grid div{padding:8px 6px;border-radius:12px}.vital-grid b{font-size:24px}.vital-grid small{font-size:12px}.vital-card canvas{height:calc(100% - 98px)!important;min-height:85px}.ai-tags{gap:8px}.ai-tags span{padding:9px 10px;font-size:13px}.model-lines{margin-top:8px}.model-lines p{margin:5px 0;font-size:13px}.stream{overflow:hidden}.stream p{margin:7px 0;padding:8px 10px;font-size:14px}.ai-orbit-card{padding:12px 32px;border-radius:22px;grid-template-columns:50% 50%}.orbit{width:min(30vh,270px);height:min(30vh,270px)}.core{width:124px;height:124px}.core b{font-size:38px}.core span{font-size:12px;margin-top:-24px}.orbit-copy h2{font-size:27px;margin-bottom:12px}.orbit-copy p{font-size:15px;line-height:1.75}.map-card{padding:14px 18px}.ai-map{min-height:0;height:calc(100% - 30px)}.risk-meter{height:124px}.risk-meter canvas{width:124px!important;height:124px!important}.risk-meter b{font-size:30px}.risk-list p{margin:7px 0}.risk-list span{font-size:12px;margin-bottom:5px}#devicePie{display:block;margin:0 auto;height:125px!important;max-height:125px!important}.donut-legend{font-size:13px;margin-top:0}.rank-card{overflow:hidden}.rank-card p{padding:8px 10px;font-size:14px}.ai-kpi{height:92px;padding:15px 18px}.ai-kpi b{font-size:32px}.ai-head h1{font-size:34px}.ai-head-left,.ai-head-right{white-space:nowrap}.ai-map svg{inset:7% 5%;height:82%}.soft-empty{height:80px}.rank-card .soft-empty{height:120px}

@media(max-height:820px){
  .ai-screen{padding:12px 22px;min-height:680px}.ai-head{height:66px}.ai-head h1{font-size:30px}.ai-kpis{height:78px;margin:10px 0}.ai-kpi{height:78px;padding:11px 16px}.ai-kpi b{font-size:27px}.ai-kpi p{font-size:14px}.ai-kpi em{font-size:10px}.ai-layout{height:calc(100vh - 66px - 78px - 20px - 104px - 34px);min-height:390px}.ai-bottom{height:104px;margin-top:10px;padding:12px 18px}.ai-bottom canvas{height:62px!important}.neo-card{padding:12px 18px}.neo-card h3{font-size:14px;margin-bottom:8px}.vital-grid div{padding:7px 5px}.vital-grid b{font-size:22px}.vital-card canvas{height:calc(100% - 88px)!important;min-height:75px}.ai-tags span{padding:8px 9px;font-size:12px}.model-lines p{font-size:12px;margin:4px 0}.stream p{padding:7px 9px;margin:6px 0;font-size:13px}.orbit{width:238px;height:238px}.core{width:112px;height:112px}.core b{font-size:34px}.orbit-copy h2{font-size:24px}.orbit-copy p{font-size:14px;line-height:1.65}.risk-meter{height:112px}.risk-meter canvas{width:112px!important;height:112px!important}.risk-list p{margin:5px 0}#devicePie{height:108px!important;max-height:108px!important}.rank-card p{padding:7px 10px}.ai-map{height:calc(100% - 28px)}
}

@media(max-width:1500px){
  .ai-screen{padding:12px 18px}.ai-layout{grid-template-columns:26% 46% 26%;gap:12px}.ai-kpis{gap:12px}.ai-head h1{font-size:30px;letter-spacing:6px}.ai-head-left{font-size:12px}.ai-head-right button{padding:7px 10px}.vital-grid b{font-size:21px}.ai-tags span{font-size:12px}.orbit-copy h2{font-size:23px}.orbit-copy p{font-size:13px}.rank-card p{grid-template-columns:38px 1fr 66px;font-size:13px}.ai-kpi b{font-size:28px}
}

/* 账号权限页优化 */
.perm-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:8px;margin-top:6px}.perm-check{display:flex;align-items:center;gap:6px;padding:8px 10px;border:1px solid var(--line);border-radius:12px;background:#f7f9fc;color:#172033;font-size:13px}.perm-check input{width:16px;height:16px}.account-panel .table td:nth-child(6){max-width:280px;line-height:1.6;color:#344054}
.invite-code{display:inline-block;padding:4px 8px;border-radius:8px;background:#eef3ff;color:#2454c6;font-weight:800;letter-spacing:1px}.link-btn{border:0;background:transparent;color:#2f6bff;cursor:pointer;padding:4px 6px;font-size:12px}.link-btn:hover{text-decoration:underline}.account-panel .table td:nth-child(7){max-width:260px;line-height:1.6;color:#344054}

/* 弹窗滚动与固定按钮 */
.modal{z-index:1000;align-items:center;justify-items:center}.modal-card{width:min(640px,calc(100vw - 32px))!important;max-height:calc(100vh - 32px);padding:0!important;display:flex;flex-direction:column;overflow:hidden}.modal-head{display:flex;align-items:center;justify-content:space-between;padding:22px 24px 10px}.modal-head h3{margin:0}.modal-x{border:0;background:#f2f4f7;color:#344054;border-radius:10px;width:36px;height:36px;font-size:24px;line-height:30px;cursor:pointer}.modal-form{display:flex;flex-direction:column;min-height:0}.modal-body{padding:0 24px 12px;overflow:auto;max-height:calc(100vh - 170px)}.modal-foot{display:flex;gap:10px;justify-content:flex-end;padding:14px 24px 22px;border-top:1px solid var(--line);background:#fff}.invite-row{display:flex;align-items:center;gap:8px}.btn.mini{padding:7px 10px;border-radius:10px}.account-modal .hint{margin-top:6px}.account-modal .perm-grid{padding-bottom:4px}

.detail-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:16px;align-items:start}.detail-panel h3{margin:0 0 12px}.info-table{width:100%;border-collapse:collapse;table-layout:fixed;background:#fff;border-radius:12px;overflow:hidden}.info-table th,.info-table td{border:1px solid var(--line);padding:11px 14px;vertical-align:middle;line-height:1.45;font-size:14px;height:44px}.info-table th{width:92px;background:#f8fafc;color:var(--muted);font-weight:500;text-align:left;white-space:nowrap}.info-table td{color:var(--text);font-weight:600;word-break:break-word;overflow-wrap:anywhere}@media (max-width:960px){.detail-grid{grid-template-columns:1fr}}

/* 健康详情页 */
.detail-page-head{margin-bottom:20px}
.detail-page-actions{display:flex;flex-wrap:wrap;gap:10px;margin-bottom:18px}
.detail-page-head h3{margin:0 0 10px;font-size:22px;line-height:1.35}
.detail-page-head .hint{margin:0;line-height:1.7}
.detail-page{padding:20px}.detail-head{display:flex;justify-content:space-between;gap:16px;align-items:flex-start;margin-bottom:16px}.detail-head h3{margin:12px 0 6px}.detail-controls{display:grid;gap:10px;justify-items:end}.detail-tabs,.detail-ranges{display:flex;flex-wrap:wrap;gap:8px;justify-content:flex-end}.detail-tab,.detail-range{border:1px solid var(--line);background:#f7f9fc;color:var(--text);border-radius:999px;padding:8px 12px;cursor:pointer}.detail-tab.active,.detail-range.active{background:#2f6bff;color:#fff;border-color:#2f6bff}.detail-summary{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:12px;margin:16px 0}.detail-stat{background:#f8fafc;border:1px solid var(--line);border-radius:16px;padding:14px 16px}.detail-stat span{display:block;color:var(--muted);font-size:12px}.detail-stat b{display:block;margin-top:10px;font-size:24px;color:var(--text)}.detail-stat small{display:block;margin-top:4px;color:var(--muted)}.detail-chart-box{height:340px;border:1px solid var(--line);border-radius:18px;background:#fff;padding:12px}.detail-chart-box canvas{width:100%!important;height:100%!important}.detail-meta{display:flex;flex-wrap:wrap;gap:12px;color:var(--muted);margin:12px 2px}.detail-table{margin-top:8px}.detail-note{margin-top:12px;color:var(--muted);font-size:13px;line-height:1.7}.clickable-metric,.clickable-row{cursor:pointer;transition:transform .12s ease,box-shadow .12s ease}.clickable-metric:hover,.clickable-row:hover{transform:translateY(-1px);box-shadow:0 10px 20px rgba(24,39,75,.08)}
.metric-overview{grid-template-columns:repeat(4,minmax(0,1fr));margin-top:12px}.metric-tile{min-height:92px;border:1px solid var(--line);background:#f8fafc}.metric-tile span{display:block;color:var(--muted);font-size:13px}.metric-tile b{font-size:22px;line-height:1.25}.metric-tile small{display:block;margin-top:7px;color:#2f6bff;font-size:12px}.section-title-row{display:flex;align-items:center;justify-content:space-between;gap:12px;margin-bottom:12px}.section-title-row h3{margin:0}.sleep-compact{display:grid;grid-template-columns:repeat(6,minmax(0,1fr));gap:10px}.sleep-mini{padding:10px 12px;border:1px solid var(--line);border-radius:12px;background:#f8fafc}.sleep-mini span{display:block;color:var(--muted);font-size:12px}.sleep-mini b{display:block;margin-top:6px;font-size:15px;color:var(--text);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.sleep-segments{display:flex;flex-wrap:wrap;gap:8px;margin-top:10px}.sleep-segments span{padding:6px 9px;border-radius:999px;background:#eef3ff;color:#2454c6;font-size:12px}.detail-table{overflow:auto}.detail-table .table{min-width:680px}.btn.mini{padding:7px 10px;border-radius:10px}
.detail-chart-box{height:360px}.detail-chart-box canvas{height:calc(100% - 42px)!important}.detail-chart-title{height:38px;display:flex;align-items:flex-start;justify-content:space-between;gap:12px;color:#667085}.detail-chart-title b{color:#172033;font-size:15px}.detail-chart-title span{font-size:12px;line-height:1.5;text-align:right}.time-source{display:inline-flex;align-items:center;white-space:nowrap;border-radius:999px;padding:4px 9px;font-size:12px;background:#f2f4f7;color:#475467}.time-source.sample{background:#e7fff8;color:#00856f}.time-source.receive{background:#eef3ff;color:#2454c6}.time-source.daily{background:#fff6e6;color:#a15c00}
.ai-btn{background:#f0f7ff;color:#0b63ce}.ai-report-page{min-height:560px}.ai-loading{padding:60px;text-align:center;color:var(--muted);background:#f8fafc;border-radius:18px;border:1px dashed var(--line)}.ai-report-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:16px;margin-top:16px}.ai-report-hero{grid-column:1/-1;display:flex;justify-content:space-between;gap:20px;align-items:center;padding:24px;border-radius:20px;background:linear-gradient(135deg,#eef5ff,#f4fffb);border:1px solid var(--line)}.ai-report-hero span{color:var(--brand);font-weight:700}.ai-report-hero h3{margin:8px 0 10px;font-size:28px}.ai-report-hero p{margin:0;color:var(--muted);line-height:1.8}.ai-report-hero b{display:grid;place-items:center;min-width:96px;height:96px;border-radius:50%;background:#2f6bff;color:#fff;box-shadow:0 18px 36px rgba(47,107,255,.22)}.ai-report-card{padding:20px;border-radius:18px;background:#fff;border:1px solid var(--line);box-shadow:var(--shadow)}.ai-report-card h3{margin:0 0 12px}.ai-report-card ul{margin:0;padding:0;list-style:none;display:grid;gap:10px;color:#344054}.ai-report-card li{padding:10px 12px;border-radius:12px;background:#f8fafc;border:1px solid var(--line);line-height:1.7}.ai-report-card li b{display:block;color:#172033;margin-bottom:3px}.ai-report-card li span{color:#475467}.ai-config-form{max-width:820px}.ai-config-page .field input{border-radius:12px}.actions .btn{white-space:nowrap}@media(max-width:900px){.ai-report-grid{grid-template-columns:1fr}.sleep-compact,.metric-overview{grid-template-columns:1fr 1fr}.ai-report-hero{align-items:flex-start;flex-direction:column}}
.ai-report-meta-line{margin:-2px 0 8px!important;color:#4b5f7f!important;font-size:14px;line-height:1.7}
.ai-report-letter{margin-top:16px;padding:28px;border:1px solid var(--line);border-radius:20px;background:linear-gradient(135deg,#eef5ff,#f8fffb);box-shadow:var(--shadow)}.ai-report-letter-head{display:flex;justify-content:space-between;align-items:flex-start;gap:18px;margin-bottom:14px}.ai-report-letter-head span{display:inline-flex;color:#2f6bff;font-weight:700;margin-bottom:8px}.ai-report-letter-head h3{margin:0;font-size:28px}.ai-report-letter-head small{display:block;margin-top:8px;color:#4b5f7f;font-size:14px;font-weight:400}.ai-report-letter-head b{display:grid;place-items:center;min-width:96px;height:96px;border-radius:50%;background:#2f6bff;color:#fff;box-shadow:0 18px 36px rgba(47,107,255,.22)}.ai-report-summary{margin:0 0 18px;color:#344054;line-height:1.8}.ai-report-body{display:grid;gap:12px}.ai-report-body p{margin:0;padding:16px 18px;border:1px solid #dfe8f5;border-radius:14px;background:rgba(255,255,255,.72);line-height:1.9}.ai-report-body b{display:block;margin-bottom:6px;color:#172033;font-size:16px}.ai-report-body span{display:block;color:#344054}@media(max-width:900px){.ai-report-letter-head{flex-direction:column}.ai-report-letter-head b{min-width:82px;height:82px}}
.ai-report-letter{margin-top:16px;border:1px solid #dce8f6;border-radius:20px;background:linear-gradient(135deg,#f7fbff,#fff 55%,#f3fffb);padding:24px;box-shadow:0 18px 45px rgba(24,39,75,.08)}.ai-report-letter-head{display:flex;justify-content:space-between;gap:20px;align-items:flex-start;border-bottom:1px solid #e7edf6;padding-bottom:16px;margin-bottom:16px}.ai-report-letter-head span{color:var(--brand);font-weight:700}.ai-report-letter-head h3{margin:8px 0 6px;font-size:28px}.ai-report-letter-head small{display:block;color:#4b5f7f;font-size:14px;line-height:1.7}.ai-report-letter-head>b{display:grid;place-items:center;min-width:92px;height:92px;border-radius:999px;background:#2f6bff;color:#fff;box-shadow:0 18px 36px rgba(47,107,255,.22)}.ai-report-summary{margin:0 0 16px;color:#344054;line-height:1.9;font-size:16px}.ai-report-body{display:grid;gap:12px}.ai-report-body p{margin:0;padding:16px 18px;border:1px solid #e5ebf4;border-radius:14px;background:rgba(255,255,255,.72);line-height:1.9}.ai-report-body b{display:block;margin-bottom:6px;color:#172033;font-size:17px}.ai-report-body span{display:block;color:#344054}@media(max-width:900px){.ai-report-letter-head{flex-direction:column}.ai-report-letter-head>b{min-width:78px;height:78px}}

/* 后台活体心电图表 */
.ecg-page{background:#f5f7fb}.ecg-head h3{font-size:24px}.ecg-live-card{width:100%;max-width:none;margin:0 0 16px;background:#fff;border:1px solid var(--line);border-radius:14px;overflow:hidden;box-shadow:0 18px 40px rgba(24,39,75,.08)}.ecg-live-paper{position:relative;height:480px;overflow-x:auto;overflow-y:hidden;background:#fff5f5;border-bottom:1px solid #eef0f3}.ecg-live-paper canvas{position:relative;display:block;min-width:100%;width:auto!important;height:480px!important;max-width:none!important}.ecg-scale-label{position:absolute;left:12px;bottom:12px;z-index:3;pointer-events:none;background:#fff;border:1px solid #e8a0a0;border-radius:10px;padding:10px 14px;box-shadow:0 6px 18px rgba(198,40,40,.12);min-width:168px}.ecg-scale-label p{margin:0;display:flex;justify-content:space-between;gap:16px;align-items:baseline;line-height:1.55;font-size:13px;color:#344054}.ecg-scale-label p+p{margin-top:4px}.ecg-scale-label span{color:#667085;white-space:nowrap}.ecg-scale-label b{color:#1a1a1a;font-size:14px;font-weight:700;white-space:nowrap}.ecg-live-paper span{display:none}.ecg-live-paper em{position:absolute;left:50%;top:50%;transform:translate(-50%,-50%);color:#98a2b3;font-style:normal;z-index:2;pointer-events:none;background:rgba(255,255,255,.9);border:1px dashed #d0d5dd;border-radius:999px;padding:8px 14px}.ecg-live-summary{display:grid;grid-template-columns:repeat(3,1fr);gap:10px;padding:30px 28px 24px;text-align:center}.ecg-live-summary b{display:block;font-size:34px;line-height:1.1;color:#07152e;font-weight:800}.ecg-live-summary small{display:block;margin-top:8px;color:#53627c;font-size:14px}.ecg-analysis-inline{width:100%;margin:0 0 14px;padding:16px 20px;background:#fff;border:1px solid var(--line);border-radius:14px;display:grid;grid-template-columns:110px 1fr;gap:12px;align-items:start}.ecg-analysis-inline b{color:#07152e;display:block;line-height:1.4}.ecg-ai-source{color:#2f6bff;font-size:12px;font-weight:600}.ecg-analysis-body{display:grid;gap:12px}.ecg-ai-text{margin:0;color:#344054;line-height:1.75;white-space:pre-wrap;font-size:14px}.ecg-ai-btn{justify-self:start}@media(max-width:900px){.ecg-live-paper{height:400px}.ecg-live-paper canvas{height:400px!important}.ecg-live-summary b{font-size:28px}.ecg-analysis-inline{grid-template-columns:1fr}}
.ecg-trend-box{width:min(960px,100%);height:320px;margin:0 auto 14px}.ecg-trend-box .section-title-row{margin:0 0 8px}.ecg-trend-box h3{font-size:16px}
.sleep-page{background:#fff}.sleep-date-nav-wrap{display:flex;justify-content:flex-end;width:100%}.sleep-date-nav{display:flex;align-items:center;gap:10px;flex-wrap:wrap;justify-content:flex-end}.sleep-date-nav-btn{border:1px solid var(--line);background:#f8fafc;color:#344054;border-radius:999px;padding:8px 14px;cursor:pointer;font-size:13px;font-weight:600}.sleep-date-nav-btn.active{background:#ff6b4a;color:#fff;border-color:#ff6b4a}.sleep-date-nav-picker{display:flex;align-items:center;gap:4px;border:1px solid var(--line);border-radius:999px;background:#fff;padding:4px 8px;box-shadow:0 1px 2px rgba(16,24,40,.04)}.sleep-date-nav-arrow{border:none;background:transparent;color:#667085;font-size:22px;line-height:1;width:34px;height:34px;cursor:pointer;border-radius:999px;padding:0}.sleep-date-nav-arrow:hover:not(.disabled){background:#f2f4f7;color:#344054}.sleep-date-nav-arrow.disabled{opacity:.35;cursor:not-allowed}.sleep-date-nav-current{position:relative;display:flex;flex-direction:column;align-items:center;justify-content:center;min-width:118px;padding:2px 10px;cursor:pointer}.sleep-date-nav-label{font-size:14px;color:#172033;font-weight:700;line-height:1.2;pointer-events:none}.sleep-date-nav-sub{font-size:11px;color:var(--muted);line-height:1.2;margin-top:2px;pointer-events:none}.sleep-date-nav-current input[type=date]{position:absolute;inset:0;opacity:0;cursor:pointer;width:100%;height:100%}.sleep-hero{display:grid;grid-template-columns:260px 1fr;gap:16px;align-items:stretch;margin:14px 0 16px}.sleep-hero>div:first-child{border:1px solid var(--line);border-radius:18px;background:linear-gradient(135deg,#fff7f2,#fff);padding:20px}.sleep-hero p{margin:0;color:var(--muted)}.sleep-hero h2{margin:12px 0 0;font-size:30px;line-height:1.18;color:#172033;white-space:nowrap;word-break:keep-all}.sleep-stats{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:10px}.sleep-stat{border:1px solid var(--line);border-radius:14px;background:#f8fafc;padding:14px}.sleep-stat span{display:block;color:var(--muted);font-size:13px}.sleep-stat b{display:block;margin-top:8px;font-size:21px;color:#172033;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.sleep-timeline{border:1px solid var(--line);border-radius:18px;background:#fff;padding:16px;margin-bottom:16px}.sleep-timeline-track{height:176px;display:flex;align-items:flex-end;gap:2px;padding:18px 12px 10px;border-radius:14px;background:repeating-linear-gradient(0deg,#f1f4f8 0,#f1f4f8 1px,transparent 1px,transparent 34px)}.sleep-seg{display:block;min-width:3px;border-radius:8px 8px 3px 3px;box-shadow:0 8px 18px rgba(23,32,51,.08)}.sleep-timeline-foot{display:flex;justify-content:space-between;color:var(--muted);font-size:13px;margin:8px 4px 0}.sleep-legend{display:flex;flex-wrap:wrap;gap:12px;margin-top:12px;color:#344054;font-size:13px}.sleep-legend span{display:inline-flex;align-items:center;gap:6px}.sleep-legend i{width:10px;height:10px;border-radius:999px}.sleep-empty{border:1px dashed var(--line);border-radius:18px;background:#f8fafc;color:var(--muted);padding:48px;text-align:center}.sleep-table .table{min-width:760px}@media(max-width:900px){.sleep-hero{grid-template-columns:1fr}.sleep-stats{grid-template-columns:repeat(2,minmax(0,1fr))}.sleep-date-nav-wrap{justify-content:flex-start}.sleep-date-nav{justify-content:flex-start}.sleep-hero h2{font-size:28px}}
.sleep-timeline-track{position:relative;display:block;height:210px;padding:0 12px;border-radius:14px;background:repeating-linear-gradient(0deg,#f1f4f8 0,#f1f4f8 1px,transparent 1px,transparent 34px)}.sleep-step{position:absolute;display:block;height:12px;min-width:7px;border-top:0;border-radius:999px;transform:translateY(-5px);cursor:default;z-index:2;box-shadow:0 8px 18px rgba(23,32,51,.10)}.sleep-step b{position:absolute;left:0;top:6px;width:1px;height:92px;background:rgba(23,32,51,.14);transform:translateY(-50%);content:""}.sleep-step em{display:none;position:absolute;left:50%;bottom:22px;transform:translateX(-50%);white-space:nowrap;background:#101828;color:#fff;border-radius:10px;padding:8px 10px;font-size:12px;font-style:normal;box-shadow:0 12px 26px rgba(16,24,40,.22);z-index:8;pointer-events:none}.sleep-step em:after{content:"";position:absolute;left:50%;bottom:-5px;transform:translateX(-50%) rotate(45deg);width:10px;height:10px;background:#101828}.sleep-step:hover{filter:brightness(1.06);z-index:7}.sleep-step:hover em{display:block}.sleep-connector{position:absolute;width:4px;border-radius:999px;transform:translate(-2px,-5px);opacity:.72;z-index:1}.sleep-timeline-foot{display:grid;grid-template-columns:1fr auto 1fr;align-items:center}.sleep-timeline-foot span:last-child{text-align:right}
.sleep-connector{display:none}.sleep-axis{position:relative;height:28px;margin:2px 12px 0;border-top:1px solid #edf1f6;color:var(--muted);font-size:12px}.sleep-axis span{position:absolute;top:0;transform:translateX(-50%);padding-top:8px;white-space:nowrap}.sleep-axis span.start{transform:translateX(0)}.sleep-axis span.end{transform:translateX(-100%)}.sleep-axis i{position:absolute;left:50%;top:-1px;width:1px;height:7px;background:#d7e0ec}.sleep-axis .start i{left:0}.sleep-axis .end i{left:100%}.sleep-timeline-foot{margin-top:0}.sleep-time-note{margin:10px 2px 0;color:var(--muted);font-size:12px;line-height:1.6}
/* 大屏按真实设备数据重排：去掉底部趋势与英文说明 */
.ai-screen{height:100vh;min-height:720px;overflow:hidden;padding:14px 22px 16px}
.ai-head-left{font-size:13px;letter-spacing:0;color:#9adfff}
.ai-kpis{grid-template-columns:repeat(4,minmax(0,1fr))!important}
.ai-kpi em{font-style:normal;color:#6f9ab8;font-size:12px}
.ai-layout{height:calc(100vh - 74px - 92px - 28px - 30px)!important;min-height:500px;grid-template-columns:25.5% 47% 25.5%}
.ai-col.left{grid-template-rows:38% 26% 1fr!important}
.ai-col.right{grid-template-rows:31% 27% 1fr!important}
.ai-center{grid-template-rows:44% 1fr!important}
.ai-bottom{display:none!important}
.current-device{margin:-2px 0 10px;color:#8ebbd6;font-size:13px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.current-device b{color:#eaf7ff}
.vital-grid div{min-width:0;padding:10px 6px}
.vital-grid b{font-size:22px;line-height:1.25;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.vital-grid small{font-size:12px}
.vital-card canvas{height:calc(100% - 118px)!important;min-height:90px}
.ai-orbit-card{padding:16px 38px}
.orbit{width:min(31vh,300px);height:min(31vh,300px)}
.core{width:138px;height:138px}
.core b{font-size:42px}
.orbit-copy p{line-height:1.7}
.ai-map{min-height:300px}
.rank-card p{grid-template-columns:42px 1fr 84px}
@media(max-height:820px){.ai-layout{height:calc(100vh - 66px - 78px - 20px - 26px)!important;min-height:430px}.vital-grid b{font-size:20px}.vital-card canvas{height:calc(100% - 104px)!important;min-height:70px}.orbit{width:238px;height:238px}.core{width:112px;height:112px}}
@media(max-width:1200px){.ai-screen{height:auto;overflow:auto}.ai-kpis{grid-template-columns:1fr!important}.ai-layout{height:auto!important}}

/* 中国地图：指环使用者定位 */
.china-map{position:relative;width:100%;height:100%;min-height:300px;border-radius:16px;overflow:hidden;background:
  radial-gradient(circle at 58% 45%,rgba(49,156,255,.22),transparent 38%),
  linear-gradient(180deg,rgba(3,18,43,.96),rgba(2,8,24,.98))}
.china-map:before{content:"";position:absolute;inset:0;background-image:
  linear-gradient(rgba(73,188,255,.055) 1px,transparent 1px),
  linear-gradient(90deg,rgba(73,188,255,.055) 1px,transparent 1px);background-size:30px 30px;mask-image:radial-gradient(circle at center,#000 35%,transparent 82%)}
.china-svg-map{position:absolute;inset:2% 4% 3%;width:92%;height:92%;object-fit:contain;filter:drop-shadow(0 0 15px rgba(47,162,255,.78))}
.map-scanline{position:absolute;left:8%;right:8%;top:8%;height:2px;background:linear-gradient(90deg,transparent,#2df0bb,transparent);box-shadow:0 0 18px #2df0bb;animation:mapScan 4.6s linear infinite;opacity:.75}
@keyframes mapScan{0%{transform:translateY(0);opacity:.15}12%,85%{opacity:.75}100%{transform:translateY(250px);opacity:.1}}
.map-device{position:absolute;transform:translate(-50%,-50%);border:0;background:transparent;color:#dffaff;cursor:default;padding:0;z-index:3;text-shadow:0 0 10px rgba(30,210,255,.75)}
.map-device i{display:block;width:13px;height:13px;border-radius:50%;background:#28f0b0;box-shadow:0 0 0 7px rgba(40,240,176,.15),0 0 22px #28f0b0;margin:0 auto 4px}
.map-device.offline i{background:#ff4d6d;box-shadow:0 0 0 7px rgba(255,77,109,.13),0 0 20px #ff4d6d}
.map-device span{display:block;max-width:92px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;font-size:12px;background:rgba(4,18,42,.72);border:1px solid rgba(88,205,255,.25);border-radius:999px;padding:3px 8px}
.map-summary{position:absolute;right:14px;bottom:12px;z-index:4;display:grid;grid-template-columns:auto auto;gap:2px 10px;align-items:end;padding:10px 12px;border:1px solid rgba(79,195,255,.28);border-radius:12px;background:rgba(3,14,34,.78);box-shadow:0 0 22px rgba(40,169,255,.16)}
.map-summary b{grid-row:1/3;font-size:34px;line-height:1;color:#45d9ff;text-shadow:0 0 14px rgba(69,217,255,.75)}
.map-summary span{font-size:13px;color:#dffaff}
.map-summary em{font-style:normal;font-size:12px;color:#2df0bb}

/* 大屏二次紧凑排版：减少空隙，避免卡片内容被裁切 */
.ai-layout{gap:10px!important}
.ai-col{gap:10px!important}
.ai-center{gap:10px!important}
.ai-col.left{grid-template-rows:42% 30% 1fr!important}
.ai-col.right{grid-template-rows:35% 27% 1fr!important}
.ai-center{grid-template-rows:42% 1fr!important}
.neo-card{padding:12px 16px!important;border-radius:16px}
.neo-card h3{margin-bottom:8px!important}
.current-device{margin-bottom:8px}
.vital-grid{gap:7px;margin-bottom:6px!important}
.vital-grid div{padding:8px 5px!important;border-radius:11px}
.vital-grid b{font-size:20px}
.vital-card canvas{height:calc(100% - 100px)!important;min-height:118px}
.ai-tags{gap:8px}
.ai-tags span{padding:8px 10px!important;font-size:13px}
.model-lines{margin-top:8px!important}
.model-lines p{margin:5px 0!important;font-size:13px}
.stream p{margin:7px 0!important;padding:8px 10px!important}
.ai-orbit-card{padding:10px 30px!important;border-radius:18px;grid-template-columns:44% 56%}
.orbit{width:min(24vh,225px)!important;height:min(24vh,225px)!important}
.core{width:100px!important;height:100px!important}
.core b{font-size:34px!important}
.core span{margin-top:-22px!important}
.orbit .r{inset:14px}
.orbit .r2{inset:43px}
.orbit .r3{inset:72px}
.node{width:11px;height:11px}
.n1{left:54px;top:54px}.n2{right:38px;top:108px}.n3{left:96px;bottom:30px}.n4{right:78px;bottom:62px}
.orbit-copy h2{font-size:25px!important;margin-bottom:6px!important}
.orbit-copy p{font-size:13px;line-height:1.5!important;margin:0}
.map-card{padding:12px 16px!important}
.ai-map{height:calc(100% - 26px)!important;min-height:0!important}
.risk-meter{height:108px!important}
.risk-meter canvas{width:108px!important;height:108px!important}
.risk-meter b{font-size:28px!important}
.risk-list p{margin:7px 0!important}
#devicePie{height:118px!important;max-height:118px!important}
.donut-legend{font-size:13px;margin-top:2px}
.rank-card p{padding:8px 10px!important}

@media(max-height:820px){
  .ai-col.left{grid-template-rows:41% 30% 1fr!important}
  .ai-col.right{grid-template-rows:36% 27% 1fr!important}
  .neo-card{padding:10px 14px!important}
  .vital-grid b{font-size:19px}
  .vital-card canvas{height:calc(100% - 92px)!important;min-height:95px}
.risk-meter{height:96px!important}
  .risk-meter canvas{width:96px!important;height:96px!important}
  #devicePie{height:100px!important;max-height:100px!important}
}

/* 大屏二次紧凑排版补丁：压缩图表和状态行，防止裁切 */
.vital-card{display:flex!important;flex-direction:column!important;min-height:0!important}
.vital-card .vital-chart-wrap{
  flex:1 1 auto;
  min-height:128px;
  margin-top:4px;
  padding:0 0 8px;
  box-sizing:border-box;
  overflow-x:auto;
  overflow-y:hidden;
  position:relative;
}
.vital-card .vital-chart-inner{position:relative;min-width:100%;height:100%}
.vital-card .vital-chart-wrap canvas{width:100%!important;height:100%!important;display:block}
.vital-card>canvas{display:none!important}
.vital-chart-empty{
  display:none;
  position:absolute;
  inset:0;
  align-items:center;
  justify-content:center;
  text-align:center;
  padding:12px 16px;
  color:#6687a5;
  font-size:12px;
  line-height:1.6;
}
.vital-chart-wrap::-webkit-scrollbar{height:6px}
.vital-chart-wrap::-webkit-scrollbar-thumb{background:rgba(111,190,255,.35);border-radius:999px}
.vital-chart-wrap::-webkit-scrollbar-track{background:rgba(255,255,255,.04)}
.current-device{font-size:12px;margin-bottom:6px}
.vital-grid div{padding:7px 5px!important}
.vital-grid b{font-size:19px}
.vital-grid small{font-size:11px}
.ai-tags span{padding:6px 9px!important;font-size:12px}
.model-lines{margin-top:6px!important}
.model-lines p{font-size:12px;margin:2px 0!important}
.risk-meter{height:82px!important}
.risk-meter canvas{width:82px!important;height:82px!important}
.risk-meter b{font-size:25px!important}
.risk-list p{margin:3px 0!important}
.risk-list span{margin-bottom:4px!important}
#devicePie{height:108px!important;max-height:108px!important}
.donut-legend{font-size:12px}

@media(max-height:820px){
  .vital-card .vital-chart-wrap{min-height:112px;padding-bottom:10px}
  .vital-card .vital-chart-wrap canvas{min-height:102px!important}
  .ai-tags span{padding:6px 8px!important}
  .risk-meter{height:82px!important}
  .risk-meter canvas{width:82px!important;height:82px!important}
  #devicePie{height:92px!important;max-height:92px!important}
}

.ecg-live-summary .ecg-metric-empty b { color: #98a2b3; font-weight: 600; }
.ecg-live-summary .ecg-metric-hint { display: block; margin-top: 2px; font-size: 11px; color: #98a2b3; line-height: 1.3; }

/* 大屏 KPI 与生命体征图表间距修正 */
.ai-kpis{height:auto!important;min-height:102px;margin:14px 0!important}
.ai-kpi{
  height:auto!important;
  min-height:102px;
  padding:14px 18px 16px!important;
  display:flex!important;
  flex-direction:column!important;
  justify-content:flex-start!important;
  overflow:visible!important;
}
.ai-kpi p{margin:0!important}
.ai-kpi b{margin-top:8px!important;margin-bottom:8px!important}
.ai-kpi em{
  display:block!important;
  margin-top:auto!important;
  padding-top:4px!important;
  line-height:1.45!important;
  font-size:12px!important;
  color:#6f9ab8!important;
}
.vital-card canvas{height:auto!important}
.vital-card .vital-chart-wrap{min-height:128px;padding-bottom:8px!important}
.vital-card .vital-chart-inner{min-height:120px}

/* 品牌名：两个「健」之间的间隔点垂直居中 */
.side .brand,.hero h1{display:flex;align-items:center;flex-wrap:wrap;line-height:1.35}
.brand-sep{display:inline-flex;align-items:center;justify-content:center;line-height:1;font-weight:500;padding:0 3px;opacity:.92;transform:translateY(.04em)}
.hero h1 .brand-sep{padding:0 5px}

/* 健康详情：设备信息 + 用户资料齐平布局 */
.detail-grid-profile{grid-template-columns:minmax(240px,.85fr) minmax(0,2.15fr)!important;gap:16px;align-items:stretch}
.detail-panel{display:flex;flex-direction:column;min-height:100%;padding:18px 20px!important}
.detail-panel-body{flex:1;display:flex;flex-direction:column;justify-content:space-between;min-height:0}
.detail-panel-device .profile-grid-device,.detail-panel-profile .profile-grid-preview{flex:1}
.profile-panel-head{display:flex;justify-content:space-between;align-items:center;gap:12px;margin-bottom:14px;padding-bottom:12px;border-bottom:1px solid var(--line)}
.profile-panel-head h3{margin:0;font-size:16px}
.profile-panel-head .actions{display:flex;gap:8px;flex-wrap:wrap}
.profile-empty{margin:auto 0;padding:24px;text-align:center}
.profile-grid{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:10px}
.profile-grid-device{grid-template-columns:repeat(4,minmax(0,1fr))}
.profile-grid-preview .profile-cell,.profile-grid-device .profile-cell{min-height:68px;display:flex;flex-direction:column;justify-content:center}
.profile-cell{min-width:0;padding:11px 13px;border:1px solid #e6edf5;border-radius:12px;background:linear-gradient(180deg,#fbfdff,#f6f9fc);box-shadow:0 1px 0 rgba(255,255,255,.8) inset}
.profile-label{display:block;font-size:12px;color:var(--muted);margin-bottom:5px;letter-spacing:.02em}
.profile-value{font-size:14px;font-weight:600;color:var(--text);word-break:break-word;line-height:1.35}
.profile-readonly{font-size:14px;font-weight:600;color:#667085}
.profile-input{width:100%;border:1px solid var(--line);border-radius:10px;padding:8px 10px;font-size:14px;background:#fff}
.profile-input:focus,.profile-textarea:focus{outline:none;border-color:#93b4ff;box-shadow:0 0 0 3px rgba(47,107,255,.12)}
.profile-textarea{width:100%;border:1px solid var(--line);border-radius:10px;padding:10px 12px;font-size:14px;background:#fff;resize:vertical}
.profile-summary-line{display:flex;align-items:center;gap:10px;margin-top:12px;padding:11px 14px;border-radius:12px;background:linear-gradient(90deg,#eef5ff,#f4fbff);border:1px solid #dce8f6;font-size:13px}
.profile-summary-line span{color:var(--muted);white-space:nowrap}
.profile-summary-line b{color:var(--text);font-weight:600}
.profile-extended-edit{margin-top:16px;padding-top:16px;border-top:1px dashed var(--line);display:grid;gap:14px}
.profile-ext-block h4{margin:0 0 10px;font-size:14px;color:#344054}
.profile-check-edit,.profile-check-list{display:flex;flex-wrap:wrap;gap:8px}
.profile-check-edit label,.profile-check-list label{font-size:13px;padding:6px 12px;border-radius:999px;border:1px solid var(--line);background:#fff;color:#344054}
.profile-check-list label.on{background:#eef5ff;border-color:#b8d4ff;color:#1d4ed8;font-weight:600}
.profile-check-edit label{display:inline-flex;align-items:center;gap:6px;cursor:pointer}
.profile-check-edit label:has(input:checked){background:#eef5ff;border-color:#b8d4ff;color:#1d4ed8;font-weight:600}
.profile-surgery-row{display:grid;grid-template-columns:1fr 160px;gap:10px;margin-bottom:8px}
.profile-full-modal{align-items:flex-start;padding-top:4vh}
.profile-modal-sheet{width:min(920px,96vw);max-height:90vh;overflow:auto;background:#fff;border-radius:20px;padding:22px 24px;box-shadow:var(--shadow)}
.profile-full-head{display:flex;justify-content:space-between;gap:16px;align-items:flex-start;margin-bottom:16px}
.profile-full-head h3{margin:0 0 6px}
.profile-modal-actions{display:flex;gap:10px;justify-content:flex-end;margin-top:18px;padding-top:16px;border-top:1px solid var(--line);position:sticky;bottom:0;background:#fff}
.profile-full-section{margin-bottom:18px;padding-bottom:16px;border-bottom:1px solid var(--line)}
.profile-full-section:last-child{border-bottom:0;margin-bottom:0;padding-bottom:0}
.profile-full-section h4{margin:0 0 12px;font-size:15px;color:#172033}
.profile-full-grid{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:10px}
.profile-full-grid-2{grid-template-columns:repeat(2,minmax(0,1fr))}
.profile-full-grid>div,.profile-full-grid-2>div{padding:10px 12px;border:1px solid var(--line);border-radius:12px;background:#f8fafc}
.profile-full-grid span,.profile-full-grid-2 span{display:block;font-size:12px;color:var(--muted);margin-bottom:4px}
.profile-full-grid b,.profile-full-grid-2 b{font-size:14px;font-weight:600;color:var(--text);word-break:break-word}
.profile-text-block{padding:12px 14px;border:1px solid var(--line);border-radius:12px;background:#f8fafc;line-height:1.7;font-size:14px;white-space:pre-wrap}
.profile-mini-table{margin-top:0}
@media(max-width:1100px){.profile-grid,.profile-full-grid{grid-template-columns:repeat(2,minmax(0,1fr))}.detail-grid-profile{grid-template-columns:1fr!important}}
@media(max-width:640px){.profile-grid,.profile-full-grid,.profile-full-grid-2{grid-template-columns:1fr}.profile-surgery-row{grid-template-columns:1fr}.profile-grid-device{grid-template-columns:1fr}}
.profile-retention-banner{margin:0 0 16px;padding:12px 16px;border-radius:12px;background:linear-gradient(90deg,#fff8eb,#fffdf5);border:1px solid #f5dfb8;color:#7a4b12;font-size:13px;line-height:1.65}
.profile-wechat-chat-entry{display:flex;align-items:center;justify-content:center;width:100%;min-height:44px;margin-top:10px;padding:11px 14px;border-radius:12px;border:1px dashed #b8d4ff;background:linear-gradient(90deg,#eef5ff,#f4fbff);cursor:pointer;transition:transform .15s ease,box-shadow .15s ease}
.profile-wechat-chat-entry:hover{transform:translateY(-1px);box-shadow:0 6px 18px rgba(47,107,255,.12)}
.profile-wechat-chat-entry.is-static{cursor:default}
.profile-wechat-chat-label{font-size:14px;font-weight:600;color:#1d4ed8;letter-spacing:.02em}
.wx-chat-modal{align-items:flex-start;padding-top:2vh}
.wx-chat-sheet{width:min(980px,96vw);max-height:90vh;overflow:hidden;display:flex;flex-direction:column}
.wx-chat-sheet.is-maximized{width:min(1280px,98vw);max-height:96vh}
.wx-chat-body{display:grid;grid-template-columns:1.2fr .8fr;gap:14px;flex:1;min-height:0;padding-top:8px}
.wx-chat-panel{display:flex;flex-direction:column;min-height:0;border:1px solid var(--line);border-radius:14px;background:#f8fafc;overflow:hidden}
.wx-chat-panel h4{margin:0;padding:12px 14px;border-bottom:1px solid var(--line);font-size:14px;background:#fff}
.wx-chat-scroll,.wx-chat-image-scroll{flex:1;min-height:280px;max-height:min(58vh,620px);overflow:auto;padding:12px 14px}
.wx-chat-line{margin-bottom:10px;padding:10px 12px;border-radius:12px;background:#fff;border:1px solid #e6edf5}
.wx-chat-line.in{border-left:3px solid #07C160}
.wx-chat-line.out{border-left:3px solid #2f6bff}
.wx-chat-meta{display:block;font-size:12px;color:var(--muted);margin-bottom:4px}
.wx-chat-text{font-size:14px;line-height:1.65;white-space:pre-wrap;word-break:break-word}
.wx-chat-empty{padding:24px 12px;text-align:center;color:var(--muted);font-size:13px;line-height:1.7}
.wx-chat-image-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:10px}
.wx-chat-image-thumb{display:flex;flex-direction:column;gap:6px;padding:0;border:none;background:transparent;cursor:pointer;text-align:left}
.wx-chat-image-thumb img{width:100%;aspect-ratio:1/1;object-fit:cover;border-radius:10px;border:1px solid var(--line);background:#fff}
.wx-chat-image-thumb span{font-size:11px;color:var(--muted)}
.wx-image-viewer{position:fixed;inset:0;z-index:10050;display:flex;align-items:center;justify-content:center;padding:20px}
.wx-image-viewer-backdrop{position:absolute;inset:0;background:rgba(15,23,42,.72)}
.wx-image-viewer-panel{position:relative;z-index:1;width:min(920px,96vw);max-height:92vh;display:flex;flex-direction:column;background:#fff;border-radius:16px;overflow:hidden;box-shadow:0 20px 60px rgba(0,0,0,.28)}
.wx-image-viewer-toolbar{display:flex;align-items:center;gap:8px;flex-wrap:wrap;padding:10px 12px;border-bottom:1px solid var(--line);background:#f8fafc}
.wx-image-viewer-toolbar span{margin:0 auto;font-size:13px;color:var(--muted)}
.wx-image-viewer-stage{flex:1;display:flex;align-items:center;justify-content:center;padding:16px;background:#0f172a;min-height:320px;max-height:calc(92vh - 56px);overflow:auto}
.wx-image-viewer-stage img{max-width:100%;max-height:100%;object-fit:contain;border-radius:8px}
.wx-image-viewer-stage.is-full img{max-width:none;max-height:none;width:auto;height:auto}
@media(max-width:900px){.wx-chat-body{grid-template-columns:1fr}.wx-chat-image-grid{grid-template-columns:repeat(3,minmax(0,1fr))}}
@media(max-width:640px){.wx-chat-image-grid{grid-template-columns:repeat(2,minmax(0,1fr))}}
.nav button span{display:inline-flex;align-items:center;justify-content:center;width:22px;flex-shrink:0}
.nav-wechat-icon{width:18px;height:18px;display:block}

/* 微信设置页 */
.wx-settings{display:grid;gap:16px}
.wx-hero{padding:20px 22px!important}
.wx-hero-head{display:flex;align-items:flex-start;gap:14px;flex-wrap:wrap}
.wx-hero-head h3{margin:0 0 6px;font-size:18px}
.wx-hero-head .wx-logo{width:44px;height:44px;flex-shrink:0;margin-top:2px}
.wx-hero-head .tag{margin-left:auto;align-self:center}
.wx-path{margin:12px 0 14px}
.wx-actions{flex-wrap:wrap}
.wx-connect{background:linear-gradient(135deg,#07C160,#06ad56)!important;border-color:#06ad56!important}
.wx-btn-disconnected{background:linear-gradient(135deg,#ef4444,#dc2626)!important;border-color:#dc2626!important;color:#fff!important}
.wx-btn-disconnected:hover{filter:brightness(1.05)}
.wx-btn-connected{background:linear-gradient(135deg,#07C160,#06ad56)!important;border-color:#06ad56!important;color:#fff!important;opacity:1!important;cursor:default!important}
.wx-status-dot{display:inline-block;width:10px;height:10px;border-radius:50%;margin-left:8px;vertical-align:middle;box-shadow:0 0 0 2px rgba(255,255,255,.8)}
.wx-status-dot.on{background:#07C160}
.wx-status-dot.off{background:#ef4444}
.wx-hint-soft{margin:10px 0 0;padding:10px 12px;border-radius:10px;background:#f8fafc;border:1px solid #e4e7ec;color:#475467;font-size:13px}
.wx-owner-panel{margin-top:0}
.wx-owner-checks{display:grid;gap:10px;margin:12px 0}
.wx-owner-check{display:flex;gap:10px;align-items:flex-start;padding:10px 12px;border:1px solid #edf1f6;border-radius:10px;background:#fafbfc;cursor:pointer}
.wx-owner-check input{margin-top:3px}
.wx-owner-check strong{display:block;font-size:14px;color:#101828}
.wx-owner-check em{display:block;font-size:12px;color:#667085;font-style:normal;margin-top:2px}
.wx-dual-grid{display:grid;grid-template-columns:1fr 1fr;gap:16px;margin-top:16px;align-items:stretch}
@media (max-width:960px){.wx-dual-grid{grid-template-columns:1fr}}
.wx-sop-panel{margin-top:0;height:100%;display:flex;flex-direction:column;min-height:420px}
.wx-sop-top-row{margin:8px 0 12px}
.wx-sop-top-row .btn{width:100%}
.wx-sop-task-block{margin-top:0;padding-top:12px;border-top:1px solid #edf1f6;flex:1;min-height:0;display:flex;flex-direction:column}
.wx-sop-task-head{display:flex;justify-content:space-between;align-items:center;margin-bottom:8px}
.wx-sop-task-scroll{flex:1;overflow:auto;min-height:280px;max-height:420px;border:1px solid #edf1f6;border-radius:10px}
.wx-sop-name-col{min-width:88px}
.wx-sop-customer-input{width:100%;padding:4px 8px;border:1px solid #d0d5dd;border-radius:6px;font-size:12px}
.wx-sop-customer-input::placeholder{color:#98a2b3}
.wx-sop-all-btn{padding:4px 12px;font-size:12px}
.wx-sop-status-col{display:flex;align-items:center;gap:6px;flex-wrap:wrap;white-space:nowrap}
.wx-sop-edit-person{padding:4px 10px;font-size:12px;white-space:nowrap}
.wx-sop-check-col{width:36px;text-align:center}
.wx-sop-check-col input[type=checkbox]{width:16px;height:16px;cursor:pointer}
.wx-sop-modal .profile-modal-sheet{width:min(520px,94vw);max-height:88vh;overflow:auto}
.wx-sop-all-modal .profile-modal-sheet{width:min(720px,96vw)}
.wx-sop-modal-sub{margin:14px 0 8px;font-size:13px;color:#344054}
.wx-sop-all-scroll{overflow:auto;max-height:180px;border:1px solid #edf1f6;border-radius:10px;margin-bottom:8px}
.wx-sop-all-scroll-tall{max-height:240px}
.wx-sop-send-time{margin:8px 0 12px}
.wx-sop-steps{display:flex;flex-direction:column;gap:8px;max-height:360px;overflow-y:auto}
.wx-sop-step{display:grid;grid-template-columns:52px 56px 20px 1fr;gap:6px;align-items:start;padding:8px;background:#fafbfc;border:1px solid #edf1f6;border-radius:8px}
.wx-sop-step label{font-size:12px;color:#667085;padding-top:8px}
.wx-sop-step-day{width:100%;padding:6px 8px;border:1px solid #d0d5dd;border-radius:6px;font-size:13px}
.wx-sop-step-unit{font-size:12px;color:#667085;padding-top:8px}
.wx-sop-step-msg{width:100%;padding:6px 8px;border:1px solid #d0d5dd;border-radius:6px;font-size:12px;resize:vertical;min-height:44px}
.wx-sop-task-table{font-size:12px;margin:0}
.wx-sop-task-table th,.wx-sop-task-table td{padding:8px 10px}
.wx-sop-msg-cell{max-width:120px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.wx-warn{margin:10px 0 0;padding:10px 12px;border-radius:10px;background:#fff4f4;border:1px solid #ffd0d0;color:#b42318;font-size:13px}
.wx-agent-modal{align-items:flex-start;padding-top:3vh}
.wx-agent-modal .profile-modal-sheet{width:min(880px,96vw);max-height:88vh;overflow:auto}
.wx-agent-section{margin-bottom:18px;padding-bottom:16px;border-bottom:1px solid var(--line)}
.wx-agent-section:last-of-type{border-bottom:0}
.wx-agent-section h4{margin:0 0 12px;font-size:15px;color:#172033}
.wx-agent-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:10px}
.wx-agent-field{margin:0}
.wx-agent-field textarea{width:100%;border:1px solid var(--line);border-radius:10px;padding:10px 12px;font-size:14px;resize:vertical;min-height:88px}
.wx-send-log-table{margin-top:8px}
@media(max-width:720px){.wx-agent-grid{grid-template-columns:1fr}}
.wx-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:16px}
.wx-switch{display:flex;align-items:center;gap:10px;margin:12px 0;font-size:14px;cursor:pointer}
.wx-switch input{width:18px;height:18px;accent-color:#07C160}
.wx-time-row{margin:10px 0 14px}
.wx-time-row input[type=time]{padding:8px 12px;border:1px solid var(--line);border-radius:10px;font-size:14px}
.wx-hangup-row{margin:10px 0 14px}
.wx-target-table{margin-top:8px}
.wx-toast{position:fixed;right:24px;bottom:24px;z-index:9999;padding:12px 18px;border-radius:12px;background:#172033;color:#fff;font-size:14px;box-shadow:0 8px 24px rgba(0,0,0,.18);max-width:min(420px,90vw)}
.wx-toast.err{background:#b42318}
@media(max-width:900px){.wx-grid{grid-template-columns:1fr}}

/* AI 报警规则配置中心 */
.ar-page{display:grid;gap:16px}
.ar-head{display:flex;justify-content:space-between;align-items:flex-start;gap:16px}
.ar-title{margin:0 0 6px;font-size:22px}
.ar-grid{display:grid;grid-template-columns:280px 1fr;gap:16px;align-items:start}
.ar-metric-list{display:grid;gap:0}
.ar-metric{display:flex;gap:10px;align-items:flex-start;padding:10px 0;border-bottom:1px solid var(--line);cursor:pointer}
.ar-metric:last-child{border-bottom:none}
.ar-metric strong{display:block;font-size:14px}
.ar-metric em{display:block;font-size:12px;color:var(--muted);font-style:normal;margin-top:2px}
.ar-main{display:grid;gap:16px}
.ar-mode-row{display:grid;gap:10px;margin-bottom:14px}
.ar-mode{display:flex;gap:10px;align-items:flex-start;padding:12px;border:1px solid var(--line);border-radius:14px;background:#f8fafc;cursor:pointer}
.ar-mode strong{display:block}
.ar-mode em{display:block;font-size:12px;color:var(--muted);font-style:normal;margin-top:4px}
.ar-rule-grid,.ar-action-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:8px 16px}
.ar-check{display:flex;align-items:center;gap:8px;font-size:14px;cursor:pointer}
.ar-action-simple{grid-template-columns:1fr 1fr;max-width:420px}
.ar-actions-panel{margin-bottom:0}
.ar-custom-list{display:grid;gap:8px}
.ar-custom-metric{border:1px solid var(--line);border-radius:12px;padding:0 12px;background:#fafbfd}
.ar-custom-metric summary{padding:12px 0;cursor:pointer;font-weight:600}
.ar-custom-body{padding:0 0 12px;display:grid;gap:8px}
.ar-inline{display:flex;align-items:center;gap:8px;flex-wrap:wrap;font-size:13px}
.ar-inline input[type=number]{width:72px;padding:6px 8px;border:1px solid var(--line);border-radius:8px}
.ar-device-table input[type=checkbox]{width:16px;height:16px}
.ar-weight-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:10px 18px}
.ar-weight-row{display:grid;grid-template-columns:1fr 72px 20px;align-items:center;gap:8px;font-size:14px}
.ar-weight-input{padding:8px 10px;border:1px solid var(--line);border-radius:10px}
.ar-risk-meta{margin-top:14px;display:grid;gap:10px}
.ar-risk-badges{display:flex;flex-wrap:wrap;gap:8px}
.ar-risk-badge.info{background:#eef3ff;color:#2454c6}
.ar-risk-badge.danger{background:#ffe8ec;color:#b42318}
@media(max-width:960px){.ar-grid{grid-template-columns:1fr}.ar-rule-grid,.ar-action-grid,.ar-weight-grid{grid-template-columns:1fr}}

