/* ============== 基础变量（iOS 风格） ============== */
:root{
  --blue:#0A84FF; --blue-soft:rgba(10,132,255,.10);
  --green:#30D158; --green-soft:rgba(48,209,88,.12);
  --red:#FF3B30; --red-soft:rgba(255,59,48,.12);
  --orange:#FF9F0A; --orange-soft:rgba(255,159,10,.14);
  --purple:#BF5AF2; --pink:#FF375F;
  --bg:#F2F2F7; --card:#FFFFFF;
  --sep:rgba(60,60,67,.10); --sep-strong:rgba(60,60,67,.18);
  --t1:#000; --t2:#1C1C1E;
  --t3:rgba(60,60,67,.60); --t4:rgba(60,60,67,.30);
  --radius-l:22px; --radius-m:16px; --radius-s:12px;
  --shadow-card:0 1px 2px rgba(0,0,0,.04),0 8px 24px rgba(15,23,42,.05);
}
*{box-sizing:border-box;-webkit-tap-highlight-color:transparent;}
html,body{margin:0;padding:0;}
body{
  font-family:'Inter','PingFang SC','SF Pro Text','Helvetica Neue',Arial,sans-serif;
  background:#E5E5EA;color:var(--t2);-webkit-font-smoothing:antialiased;
  min-height:100vh;padding:60px 0 60px;
}
#app{display:flex;flex-wrap:wrap;gap:30px;justify-content:center;align-items:flex-start;}

/* 顶部原型切换条 */
.proto-bar{
  position:fixed;top:0;left:0;right:0;z-index:99;
  background:rgba(255,255,255,.85);
  backdrop-filter:saturate(180%) blur(20px);
  -webkit-backdrop-filter:saturate(180%) blur(20px);
  border-bottom:1px solid var(--sep);padding:10px 16px;
  display:flex;gap:8px;flex-wrap:wrap;justify-content:center;font-size:12px;
}
.proto-bar button{
  border:1px solid var(--sep-strong);background:#fff;color:var(--t2);
  padding:6px 14px;border-radius:999px;cursor:pointer;font-weight:500;
  transition:.2s;font-family:inherit;font-size:12px;
}
.proto-bar button.active{background:var(--blue);color:#fff;border-color:var(--blue);}
.proto-bar button:hover{transform:translateY(-1px);}

/* iPhone 外壳 */
.device{
  width:390px;height:844px;background:var(--bg);border-radius:54px;
  box-shadow:0 0 0 12px #0c0c0e,0 30px 80px rgba(0,0,0,.25);
  overflow:hidden;position:relative;flex-shrink:0;
}
.dynamic-island{
  position:absolute;top:11px;left:50%;transform:translateX(-50%);
  width:120px;height:34px;background:#000;border-radius:20px;z-index:50;
}
.home-ind{
  position:absolute;bottom:8px;left:50%;transform:translateX(-50%);
  width:134px;height:5px;background:#000;border-radius:3px;opacity:.85;z-index:60;pointer-events:none;
}

/* 状态栏 */
.status-bar{
  height:54px;padding:18px 32px 0;display:flex;justify-content:space-between;
  align-items:center;font-weight:600;font-size:15px;color:var(--t1);position:relative;z-index:5;
}
.status-bar .right{display:flex;gap:6px;align-items:center;}
.status-bar svg{display:block;}

/* 屏幕容器 */
.screen{
  height:calc(100% - 54px);overflow-y:auto;overflow-x:hidden;position:relative;
  scroll-behavior:smooth;-webkit-overflow-scrolling:touch;animation:fade .35s ease;
}
.screen::-webkit-scrollbar{display:none;}
@keyframes fade{from{opacity:0;transform:translateY(6px);}to{opacity:1;transform:none;}}
.has-tab .screen{padding-bottom:90px;}

/* 顶部导航 + 大标题 */
.nav{padding:8px 20px 4px;display:flex;justify-content:space-between;align-items:center;}
.nav .back{color:var(--blue);font-size:22px;font-weight:700;line-height:1;cursor:pointer;}
.nav .title{font-size:17px;font-weight:600;}
.nav .right-act{color:var(--blue);font-size:17px;cursor:pointer;}
.nav .right-act.icon{font-size:22px;}
.large-title{padding:8px 20px 12px;}
.large-title h1{font-size:34px;font-weight:800;letter-spacing:-.5px;margin:0;color:var(--t1);}
.large-title .sub{font-size:14px;color:var(--t3);margin-top:4px;}

/* 通用 section/card */
.section{padding:0 16px;margin-bottom:18px;}
.section-title{
  padding:6px 6px 8px;font-size:13px;font-weight:600;color:var(--t3);
  text-transform:uppercase;letter-spacing:.5px;
  display:flex;justify-content:space-between;align-items:center;
}
.section-title .more{color:var(--blue);font-weight:500;text-transform:none;
  letter-spacing:0;cursor:pointer;font-size:14px;}
.card{background:var(--card);border-radius:var(--radius-m);padding:16px;
  box-shadow:var(--shadow-card);transition:transform .15s ease;}
.card.tappable:active{transform:scale(.98);}

/* badge */
.badge{width:32px;height:32px;border-radius:8px;display:flex;align-items:center;
  justify-content:center;color:#fff;flex-shrink:0;}
.badge.lg{width:44px;height:44px;border-radius:12px;}
.badge svg{width:18px;height:18px;}
.badge.lg svg{width:24px;height:24px;}
.b-red{background:var(--red);} .b-green{background:var(--green);}
.b-blue{background:var(--blue);} .b-orange{background:var(--orange);}
.b-purple{background:var(--purple);} .b-pink{background:var(--pink);}
.b-gray{background:#8E8E93;}

/* tab bar - 浮动圆角玻璃 */
.tabbar{
  position:absolute;bottom:18px;left:50%;transform:translateX(-50%);width:170px;height:64px;
  background:rgba(255,255,255,.78);
  backdrop-filter:saturate(180%) blur(24px);
  -webkit-backdrop-filter:saturate(180%) blur(24px);
  border:.5px solid rgba(255,255,255,.6);
  border-radius:32px;
  box-shadow:0 12px 36px rgba(15,23,42,.14),
             0 2px 6px rgba(15,23,42,.06),
             inset 0 1px 0 rgba(255,255,255,.6);
  display:flex;justify-content:space-around;align-items:center;
  padding:0 8px;z-index:40;
}
.tab{
  flex:1;display:flex;flex-direction:column;align-items:center;gap:2px;
  color:#8E8E93;font-size:10px;cursor:pointer;font-weight:500;
  height:48px;justify-content:center;border-radius:24px;transition:.2s;
}
.tab svg{width:24px;height:24px;}
.tab.active{color:var(--blue);}
.tab.active{background:var(--blue-soft);}
.has-tab .screen{padding-bottom:100px;}

/* ============ 登录页 ============ */
.login-wrap{
  height:100%;display:flex;flex-direction:column;
  padding:60px 28px 40px;
  background:linear-gradient(180deg,#F2F8FF 0%,#FFFFFF 60%);
}
.logo-mark{
  width:auto;height:auto;margin-bottom:22px;
  background:transparent;
  display:flex;align-items:center;justify-content:center;
  padding:0;border:none;box-shadow:none;
}
/* 与登录区渐变底色一体：去掉衬底，Logo 图形直接落在背景上 */
.logo-mark img{
  display:block;width:76px;height:76px;object-fit:contain;
}
.login-wrap h1{font-size:28px;font-weight:800;margin:0 0 6px;color:var(--t1);letter-spacing:-.3px;}
.login-wrap .desc{font-size:15px;color:var(--t3);margin-bottom:40px;line-height:1.5;}
.field{
  background:#fff;border-radius:999px;padding:14px 20px;border:1px solid var(--sep);
  margin-bottom:12px;display:flex;align-items:center;gap:10px;
  box-shadow:0 2px 8px rgba(15,23,42,.04);
}
.field:focus-within{border-color:var(--blue);box-shadow:0 0 0 3px rgba(10,132,255,.12);}
.field input{flex:1;border:none;outline:none;font-size:16px;background:transparent;
  font-family:inherit;color:var(--t1);min-width:0;}
.field .prefix{color:var(--t3);font-size:16px;font-weight:500;}
.field .send-code{color:var(--blue);font-size:14px;font-weight:600;cursor:pointer;
  padding-left:10px;border-left:1px solid var(--sep);}
.btn-primary{
  width:100%;background:var(--blue);color:#fff;border:none;height:52px;border-radius:999px;
  font-size:17px;font-weight:600;margin-top:20px;cursor:pointer;font-family:inherit;
  transition:.2s;box-shadow:0 10px 24px rgba(10,132,255,.32);
}
.btn-primary:active{transform:scale(.98);}
.btn-secondary{
  width:100%;background:#fff;color:var(--blue);border:1px solid var(--sep);
  height:50px;border-radius:999px;font-size:15px;font-weight:600;margin-top:10px;
  cursor:pointer;font-family:inherit;transition:.2s;
}
.btn-secondary:active{transform:scale(.98);}
.agree{text-align:center;font-size:12px;color:var(--t3);margin-top:auto;line-height:1.6;}
.agree a{color:var(--blue);text-decoration:none;}

/* ============ 首页 ============ */
.home-greet{padding:0 20px 12px;display:flex;align-items:center;gap:10px;}
.home-greet .av{
  width:34px;height:34px;border-radius:50%;
  background:linear-gradient(135deg,#FFB199,#FF6B6B);color:#fff;
  display:flex;align-items:center;justify-content:center;font-weight:700;font-size:14px;
}
.home-greet .txt{flex:1;}
.home-greet .t{font-size:13px;color:var(--t3);}
.home-greet .b{font-size:18px;font-weight:700;color:var(--t1);letter-spacing:-.3px;}
.home-greet .ico-btn{
  width:36px;height:36px;border-radius:50%;background:#fff;display:flex;align-items:center;
  justify-content:center;color:var(--t2);box-shadow:var(--shadow-card);position:relative;cursor:pointer;
}
.home-greet .ico-btn .red-dot{
  position:absolute;top:6px;right:8px;width:8px;height:8px;border-radius:50%;
  background:var(--red);border:1.5px solid #fff;
}

/* 健康评分 */
.score-card{
  background:linear-gradient(135deg,#0A84FF 0%,#5E5CE6 100%);color:#fff;
  border-radius:22px;padding:20px;box-shadow:0 12px 30px rgba(10,132,255,.28);
  position:relative;overflow:hidden;cursor:pointer;
}
.score-card::before{content:"";position:absolute;right:-40px;top:-40px;width:180px;height:180px;
  border-radius:50%;background:rgba(255,255,255,.08);}
.score-card::after{content:"";position:absolute;right:-80px;bottom:-80px;width:200px;height:200px;
  border-radius:50%;background:rgba(255,255,255,.06);}
.score-head{display:flex;justify-content:space-between;align-items:flex-start;position:relative;z-index:2;}
.score-head .who{display:flex;align-items:center;gap:10px;}
.avatar{
  width:40px;height:40px;border-radius:50%;background:rgba(255,255,255,.22);
  display:flex;align-items:center;justify-content:center;font-weight:700;font-size:16px;color:#fff;
  border:2px solid rgba(255,255,255,.3);
}
.who .name{font-size:15px;font-weight:600;}
.who .role{font-size:12px;opacity:.85;margin-top:2px;}
.status-pill{
  background:rgba(255,255,255,.22);padding:5px 10px;border-radius:999px;
  font-size:12px;font-weight:600;display:flex;align-items:center;gap:5px;
}
.status-pill .dot{width:6px;height:6px;border-radius:50%;background:#30D158;
  box-shadow:0 0 0 3px rgba(48,209,88,.3);}
.score-main{display:flex;align-items:flex-end;gap:6px;margin-top:18px;position:relative;z-index:2;}
.score-num{font-size:64px;font-weight:800;line-height:1;letter-spacing:-2px;}
.score-unit{font-size:18px;font-weight:600;margin-bottom:8px;opacity:.9;}
.score-tag{margin-left:auto;background:rgba(48,209,88,.95);color:#fff;
  padding:6px 12px;border-radius:999px;font-size:13px;font-weight:600;margin-bottom:10px;}
.score-desc{font-size:13px;opacity:.9;margin-top:8px;position:relative;z-index:2;line-height:1.5;}
.score-desc b{font-weight:600;}

/* 告警横幅 */
.alert-banner{
  background:linear-gradient(135deg,#FF3B30 0%,#FF9F0A 100%);color:#fff;border-radius:16px;
  padding:14px 16px;display:flex;align-items:center;gap:12px;
  box-shadow:0 8px 22px rgba(255,59,48,.28);cursor:pointer;animation:pulse 2s ease infinite;
}
@keyframes pulse{0%,100%{box-shadow:0 8px 22px rgba(255,59,48,.28);}
  50%{box-shadow:0 8px 28px rgba(255,59,48,.5);}}
.alert-banner .ico{width:40px;height:40px;border-radius:12px;background:rgba(255,255,255,.22);
  display:flex;align-items:center;justify-content:center;flex-shrink:0;}
.alert-banner .txt{flex:1;}
.alert-banner .t{font-size:14px;font-weight:600;}
.alert-banner .d{font-size:12px;opacity:.9;margin-top:2px;}

/* 指标网格 */
.metric-grid{display:grid;grid-template-columns:1fr 1fr;gap:12px;}
.metric{
  background:var(--card);border-radius:16px;padding:14px;box-shadow:var(--shadow-card);
  cursor:pointer;transition:transform .15s ease;position:relative;overflow:hidden;
}
.metric:active{transform:scale(.97);}
.metric .head{display:flex;align-items:center;gap:8px;font-size:13px;font-weight:600;color:var(--t2);}
.metric .head .ic{width:22px;height:22px;border-radius:6px;display:flex;align-items:center;
  justify-content:center;color:#fff;}
.metric .ic svg{width:13px;height:13px;}
.metric .val{margin-top:10px;display:flex;align-items:baseline;gap:4px;}
.metric .num{font-size:28px;font-weight:800;color:var(--t1);letter-spacing:-.5px;}
.metric .unit{font-size:13px;color:var(--t3);font-weight:500;}
.metric .trend{margin-top:6px;font-size:11px;color:var(--t3);display:flex;align-items:center;gap:4px;}
.metric .trend .up{color:var(--green);} .metric .trend .down{color:var(--red);}
.spark{height:30px;margin-top:6px;}
.spark svg{width:100%;height:100%;display:block;}

/* 设备行 */
.row-list{background:var(--card);border-radius:16px;overflow:hidden;box-shadow:var(--shadow-card);}
.row{padding:12px 14px;display:flex;align-items:center;gap:12px;cursor:pointer;transition:background .15s;}
.row:active{background:#F2F2F7;}
.row + .row{border-top:.5px solid var(--sep);}
.row .info{flex:1;min-width:0;}
.row .info .t{font-size:15px;font-weight:600;color:var(--t1);}
.row .info .d{font-size:12px;color:var(--t3);margin-top:2px;
  white-space:nowrap;overflow:hidden;text-overflow:ellipsis;}
.row .right{display:flex;align-items:center;gap:6px;color:var(--t4);font-size:13px;}
.row .right .val{color:var(--t3);}
.chev{color:var(--t4);}

/* pills */
.pill{font-size:11px;font-weight:600;padding:3px 8px;border-radius:999px;}
.pill.green{background:var(--green-soft);color:#1F8E3D;}
.pill.red{background:var(--red-soft);color:#C81E1E;}
.pill.orange{background:var(--orange-soft);color:#B45309;}
.pill.gray{background:rgba(60,60,67,.1);color:var(--t3);}
.pill.blue{background:var(--blue-soft);color:var(--blue);}

/* 快捷功能 */
.quick-grid{
  display:grid;grid-template-columns:repeat(4,1fr);gap:8px;background:var(--card);
  border-radius:16px;padding:14px 8px;box-shadow:var(--shadow-card);
}
.quick{display:flex;flex-direction:column;align-items:center;gap:6px;padding:6px 4px;
  cursor:pointer;border-radius:10px;}
.quick:active{background:#F2F2F7;}
.quick .qi{width:42px;height:42px;border-radius:14px;display:flex;align-items:center;
  justify-content:center;color:#fff;}
.quick .ql{font-size:11px;color:var(--t2);font-weight:500;text-align:center;}

/* ============ 设备卡片 ============ */
.device-card{
  background:var(--card);border-radius:18px;padding:16px;box-shadow:var(--shadow-card);
  margin-bottom:12px;cursor:pointer;transition:transform .15s ease;
}
.device-card:active{transform:scale(.98);}
.device-card .top{display:flex;gap:14px;align-items:flex-start;}
.device-img{
  width:64px;height:64px;border-radius:14px;flex-shrink:0;display:flex;align-items:center;
  justify-content:center;background:linear-gradient(135deg,#E8F2FF,#F5F8FF);color:var(--blue);
}
.device-img.fall{background:linear-gradient(135deg,#FFE8E8,#FFF5F5);color:var(--red);}
.device-img svg{width:32px;height:32px;}
.device-card .info{flex:1;min-width:0;}
.device-card .info .n{font-size:16px;font-weight:600;color:var(--t1);}
.device-card .info .m{font-size:12px;color:var(--t3);margin-top:6px;}
.device-card .device-care-top{
  display:flex;flex-wrap:wrap;align-items:baseline;gap:4px 6px;margin-top:6px;
}
.device-card .device-care-top .dcd-l{font-size:12px;color:var(--t3);font-weight:500;}
.device-card .device-care-top .dcd-v{
  font-size:20px;font-weight:800;letter-spacing:-.4px;color:var(--blue);line-height:1;
}
.device-card .device-care-top .dcd-u{font-size:12px;font-weight:600;color:var(--t3);}
.device-card .device-care-top.is-offline .dcd-v{color:var(--t4);font-size:18px;}
.device-card .device-care-top .dcd-hint{
  width:100%;font-size:11px;color:var(--t3);line-height:1.35;margin-top:2px;
}
.device-card .device-signal-row{
  display:flex;align-items:center;flex-wrap:wrap;gap:8px;margin-top:8px;
}
.device-card .device-signal-row .dsl{font-size:11px;color:var(--t3);font-weight:500;}
.device-card .sig-bars{display:inline-flex;align-items:flex-end;gap:3px;height:14px;}
.device-card .sig-bars i{
  width:4px;border-radius:1px;background:rgba(60,60,67,.15);align-self:flex-end;
}
.device-card .sig-bars i:nth-child(1){height:5px;}
.device-card .sig-bars i:nth-child(2){height:8px;}
.device-card .sig-bars i:nth-child(3){height:11px;}
.device-card .sig-bars i:nth-child(4){height:14px;}
.device-card .sig-bars i.on{background:var(--green);}
.device-card .device-signal-row .dsv{font-size:12px;font-weight:600;color:var(--t2);}
.device-card .device-signal-row .dsv-good{color:#1F8E3D;}
.device-card .stats{display:flex;gap:10px;margin-top:14px;padding-top:14px;border-top:.5px solid var(--sep);}
.device-card .stats .s{flex:1;}
.device-card .stats .s .lv{font-size:11px;color:var(--t3);font-weight:500;}
.device-card .stats .s .vv{font-size:14px;color:var(--t1);font-weight:600;margin-top:2px;}

.add-device-card{
  background:var(--card);border:2px dashed var(--sep-strong);border-radius:18px;padding:18px;
  text-align:center;color:var(--blue);font-size:15px;font-weight:600;cursor:pointer;
  display:flex;flex-direction:column;align-items:center;gap:6px;transition:.2s;
}
.add-device-card:hover{background:var(--blue-soft);}
.add-device-card .ic{
  width:42px;height:42px;border-radius:50%;background:var(--blue-soft);color:var(--blue);
  display:flex;align-items:center;justify-content:center;
}
.add-actions{display:grid;grid-template-columns:1fr 1fr;gap:12px;margin-top:8px;}
.add-act{
  background:var(--card);border-radius:16px;padding:18px 14px;text-align:center;
  cursor:pointer;box-shadow:var(--shadow-card);
}
.add-act .ic{
  width:48px;height:48px;border-radius:14px;background:var(--blue-soft);color:var(--blue);
  display:flex;align-items:center;justify-content:center;margin:0 auto 8px;
}
.add-act .t{font-size:14px;font-weight:600;color:var(--t1);}
.add-act .d{font-size:11px;color:var(--t3);margin-top:3px;}

/* ============ 详情图表 ============ */
.chart-card{background:var(--card);border-radius:18px;padding:18px;box-shadow:var(--shadow-card);}
.chart-head{display:flex;justify-content:space-between;align-items:flex-start;gap:10px;}
.chart-head .l .label{font-size:13px;color:var(--t3);font-weight:500;}
.chart-head .l .big{font-size:36px;font-weight:800;color:var(--t1);letter-spacing:-1px;
  display:flex;align-items:baseline;gap:4px;}
.chart-head .l .big .u{font-size:14px;color:var(--t3);font-weight:500;}
.chart-head .l .when{font-size:12px;color:var(--t3);margin-top:2px;}
.seg{display:inline-flex;background:#F2F2F7;border-radius:9px;padding:2px;font-size:13px;}
.seg span{padding:5px 10px;border-radius:7px;cursor:pointer;color:var(--t2);font-weight:500;}
.seg span.on{background:#fff;color:var(--t1);font-weight:600;box-shadow:0 1px 3px rgba(0,0,0,.08);}
.chart{margin-top:14px;height:160px;width:100%;}
.chart svg{width:100%;height:100%;display:block;}
.legend{display:flex;gap:14px;margin-top:10px;font-size:12px;color:var(--t3);flex-wrap:wrap;}
.legend .it{display:flex;align-items:center;gap:5px;}
.legend .it .dt{width:8px;height:8px;border-radius:50%;}

.sleep-bar{height:36px;border-radius:8px;display:flex;overflow:hidden;margin-top:12px;}
.sleep-bar .seg-d{height:100%;}
.sleep-deep{background:#5E5CE6;} .sleep-light{background:#64D2FF;}
.sleep-rem{background:#BF5AF2;} .sleep-awake{background:#FFD60A;}
.stats-row{display:grid;grid-template-columns:repeat(3,1fr);gap:10px;margin-top:12px;}
.stats-row .b{background:#F2F2F7;border-radius:12px;padding:10px;text-align:center;}
.stats-row .b .n{font-size:18px;font-weight:700;color:var(--t1);}
.stats-row .b .l{font-size:11px;color:var(--t3);margin-top:2px;}

.tabs-pill{background:#F2F2F7;border-radius:10px;padding:3px;display:flex;margin:0 0 12px;}
.tabs-pill .it{flex:1;text-align:center;padding:7px;border-radius:8px;font-size:13px;
  font-weight:600;color:var(--t2);cursor:pointer;}
.tabs-pill .it.on{background:#fff;color:var(--t1);box-shadow:0 1px 3px rgba(0,0,0,.08);}
.detail-live-bar{
  display:flex;align-items:center;justify-content:space-between;gap:10px;margin:0 0 10px;
}
.detail-live-status{
  display:inline-flex;align-items:center;gap:6px;font-size:12px;color:var(--t3);font-weight:600;
}
.detail-live-status .dot{
  width:7px;height:7px;border-radius:50%;background:#B8BCC7;
}
.detail-live-status.on{color:#1F8E4A;}
.detail-live-status.on .dot{background:#30D158;box-shadow:0 0 0 4px rgba(48,209,88,.16);}
.detail-live-btn{
  border:none;border-radius:999px;padding:7px 12px;font-size:12px;font-weight:700;cursor:pointer;
  color:#0A84FF;background:#EAF3FF;
}
.detail-live-btn.on{color:#fff;background:#0A84FF;}
.detail-date-filters{
  display:flex;gap:8px;align-items:center;justify-content:space-between;margin-bottom:10px;
}
.detail-date-filters .date-seg{font-size:12px;}
.detail-date-filters .date-seg span{padding:5px 8px;}
.detail-date-nav{
  display:inline-flex;align-items:center;gap:8px;background:#F2F2F7;border-radius:9px;padding:2px 4px;
}
.detail-date-nav button{
  width:24px;height:24px;border:none;background:#fff;border-radius:7px;cursor:pointer;color:var(--t2);font-weight:700;
  box-shadow:0 1px 3px rgba(0,0,0,.08);
}
.detail-date-nav span{
  font-size:12px;color:var(--t2);font-weight:600;min-width:128px;text-align:center;
}
.date-seg span{min-width:30px;text-align:center;}

.sleep-phase-wrap{margin-top:6px;}
.sleep-phase-card{
  background:#fff;border-radius:18px;padding:14px 12px 12px;
  box-shadow:var(--shadow-card);margin-bottom:14px;
}
.sleep-phase-head{
  display:flex;align-items:center;gap:6px;font-weight:800;color:#1F1F1F;
  font-size:18px;margin:2px 4px 8px;
}
.sleep-phase-head .arr{font-weight:700;color:#666;cursor:pointer;user-select:none;}
.sleep-phase-head .arr.disabled{opacity:.35;cursor:not-allowed;pointer-events:none;}
.sleep-phase-chart{height:230px;margin:0 12px;}
.sleep-phase-chart svg{width:100%;height:100%;display:block;}
.sleep-phase-legend{
  margin:4px 8px 2px;display:flex;flex-wrap:wrap;gap:12px;font-size:12px;color:#666;font-weight:600;
}
.sleep-phase-legend span{display:inline-flex;align-items:center;gap:4px;}
.sleep-phase-legend .c{font-style:normal;font-size:12px;line-height:1;}
.sleep-phase-legend .c.awake{color:#F05B4E;}
.sleep-phase-legend .c.rem{color:#8FD9E5;}
.sleep-phase-legend .c.core{color:#2F99D8;}
.sleep-phase-legend .c.deep{color:#473A97;}

/* ============ 告警中心 ============ */
.alert-list .alert-card{
  background:var(--card);border-radius:14px;padding:14px;box-shadow:var(--shadow-card);
  margin-bottom:10px;display:flex;gap:12px;align-items:flex-start;cursor:pointer;
  border-left:3px solid transparent;
}
.alert-list .alert-card.lv-high{border-left-color:var(--red);}
.alert-list .alert-card.lv-mid{border-left-color:var(--orange);}
.alert-list .alert-card.lv-low{border-left-color:var(--blue);}
.alert-card .ico{
  width:38px;height:38px;border-radius:10px;flex-shrink:0;display:flex;
  align-items:center;justify-content:center;color:#fff;
}
.alert-card .body{flex:1;min-width:0;}
.alert-card .top{display:flex;align-items:center;justify-content:space-between;gap:8px;}
.alert-card .t{font-size:15px;font-weight:600;color:var(--t1);}
.alert-card .time{font-size:11px;color:var(--t3);white-space:nowrap;}
.alert-card .d{font-size:13px;color:var(--t3);margin-top:4px;line-height:1.45;}
.alert-card .meta{margin-top:8px;display:flex;gap:6px;flex-wrap:wrap;}

.filter-bar{display:flex;gap:8px;padding:0 4px 12px;overflow-x:auto;}
.filter-bar::-webkit-scrollbar{display:none;}
.filter-bar .ck{
  border:1px solid var(--sep-strong);background:#fff;padding:6px 12px;border-radius:999px;
  font-size:13px;font-weight:500;color:var(--t2);cursor:pointer;white-space:nowrap;
}
.filter-bar .ck.on{background:var(--blue);color:#fff;border-color:var(--blue);}

/* ============ 分享 ============ */
.invite-card{
  background:linear-gradient(135deg,#0A84FF,#5E5CE6);color:#fff;border-radius:18px;
  padding:20px;box-shadow:0 12px 30px rgba(10,132,255,.28);position:relative;overflow:hidden;
}
.invite-card::before{content:"";position:absolute;right:-30px;top:-30px;width:140px;height:140px;
  border-radius:50%;background:rgba(255,255,255,.08);}
.invite-card .t{font-size:17px;font-weight:700;}
.invite-card .d{font-size:13px;opacity:.9;margin-top:4px;line-height:1.5;}
.invite-card .qr-wrap{
  margin-top:14px;background:#fff;border-radius:14px;padding:14px;display:flex;gap:14px;
  align-items:center;color:var(--t1);position:relative;z-index:2;
}
.qr{
  width:80px;height:80px;flex-shrink:0;background:#fff;border:1px solid #eee;
  background-image:
    linear-gradient(45deg,#000 25%,transparent 25%),
    linear-gradient(-45deg,#000 25%,transparent 25%),
    linear-gradient(45deg,transparent 75%,#000 75%),
    linear-gradient(-45deg,transparent 75%,#000 75%);
  background-size:8px 8px;
  background-position:0 0,0 4px,4px -4px,-4px 0;
}
.invite-card .qrtext .a{font-weight:700;font-size:14px;color:var(--t1);}
.invite-card .qrtext .b{font-size:12px;color:var(--t3);margin-top:4px;line-height:1.5;}
.invite-card .actions{display:flex;gap:8px;margin-top:14px;position:relative;z-index:2;}
.invite-card .actions button{
  flex:1;background:rgba(255,255,255,.2);border:none;color:#fff;padding:10px;
  border-radius:10px;font-size:13px;font-weight:600;cursor:pointer;font-family:inherit;
  backdrop-filter:blur(10px);
}
.invite-card .actions button.solid{background:#fff;color:var(--blue);}

.member-row{padding:12px 14px;display:flex;align-items:center;gap:12px;}
.member-row + .member-row{border-top:.5px solid var(--sep);}
.member-row .av{
  width:40px;height:40px;border-radius:50%;color:#fff;display:flex;align-items:center;
  justify-content:center;font-weight:700;font-size:15px;
}
.member-row .info{flex:1;}
.member-row .info .n{font-size:15px;font-weight:600;color:var(--t1);}
.member-row .info .m{font-size:12px;color:var(--t3);margin-top:2px;}

/* ============ 设置 ============ */
.settings-list{background:var(--card);border-radius:16px;overflow:hidden;box-shadow:var(--shadow-card);}
.set-row{padding:12px 14px;display:flex;align-items:center;gap:12px;}
.set-row + .set-row{border-top:.5px solid var(--sep);}
.set-row .lab{flex:1;font-size:15px;color:var(--t1);}
.set-row .val{color:var(--t3);font-size:14px;}
.switch{
  position:relative;width:51px;height:31px;border-radius:31px;background:#E9E9EA;
  cursor:pointer;transition:.25s;flex-shrink:0;
}
.switch::after{
  content:"";position:absolute;top:2px;left:2px;width:27px;height:27px;border-radius:50%;
  background:#fff;transition:.25s;box-shadow:0 2px 4px rgba(0,0,0,.15),0 0 0 .5px rgba(0,0,0,.04);
}
.switch.on{background:var(--green);} .switch.on::after{left:22px;}

.slider-row{padding:14px;background:var(--card);border-radius:14px;box-shadow:var(--shadow-card);margin-bottom:10px;}
.slider-row .head{display:flex;justify-content:space-between;font-size:14px;color:var(--t2);margin-bottom:10px;}
.slider-row .head b{color:var(--blue);font-weight:600;}
.slider-track{height:6px;background:#E9E9EA;border-radius:3px;position:relative;margin:6px 10px;}
.slider-fill{position:absolute;top:0;height:100%;background:var(--blue);border-radius:3px;}
.slider-handle{
  position:absolute;top:50%;width:22px;height:22px;border-radius:50%;background:#fff;
  box-shadow:0 2px 6px rgba(0,0,0,.2);transform:translate(-50%,-50%);border:1px solid rgba(0,0,0,.04);
}
.threshold-learn-tip{
  font-size:12px;color:var(--t3);line-height:1.45;margin:-2px 0 12px;padding:10px 12px;
  background:rgba(10,132,255,.06);border-radius:12px;border:1px solid rgba(10,132,255,.1);
}
.slider-row.threshold-group > .head:first-child{
  margin-bottom:14px;padding-bottom:10px;border-bottom:1px solid rgba(0,0,0,.06);
}
.slider-row.threshold-group .head.sub{
  font-size:13px;color:var(--t3);margin-bottom:6px;margin-top:0;
}
.range-dual-wrap{margin-top:4px;padding:6px 0 2px;}
.range-dual-track{
  position:relative;height:10px;margin:22px 10px 10px;background:#E9E9EA;border-radius:5px;
}
.range-dual-zone{
  position:absolute;top:0;height:100%;border-radius:5px;background:var(--blue);
  opacity:.55;pointer-events:none;
}
.range-dual-handle{
  position:absolute;top:50%;width:26px;height:26px;margin-top:-13px;margin-left:-13px;border-radius:50%;
  background:#fff;border:1px solid rgba(0,0,0,.08);
  box-shadow:0 2px 8px rgba(0,0,0,.18);z-index:2;pointer-events:none;
}
.range-dual-scale{
  display:flex;justify-content:space-between;font-size:11px;color:var(--t4);margin:0 10px 6px;
}

/* ============ 新首页（生命体征引擎） ============ */
.engine-bg{
  background:linear-gradient(180deg,#EEF1FF 0%,#F4F0FF 30%,#F2F2F7 100%);
  min-height:100%;
}
.engine-header{
  display:flex;align-items:center;justify-content:space-between;
  padding:8px 18px 6px;
}
.engine-header .left{display:flex;align-items:center;gap:10px;}
.engine-header .logo{
  width:34px;height:34px;border-radius:11px;
  background:linear-gradient(135deg,#1F2A44,#0A84FF);
  display:flex;align-items:center;justify-content:center;color:#fff;
  box-shadow:0 4px 10px rgba(10,132,255,.25);
}
.engine-header .ttl{font-size:17px;font-weight:700;color:var(--t1);letter-spacing:-.2px;}

/* 左上角长者切换 chips */
.elder-picker{
  display:flex;align-items:center;gap:6px;flex:1;min-width:0;
  overflow-x:auto;scrollbar-width:none;-webkit-overflow-scrolling:touch;
  margin-right:10px;padding:2px 0;
}
.elder-picker::-webkit-scrollbar{display:none;}
.elder-picker .ech{
  display:inline-flex;align-items:center;gap:6px;flex-shrink:0;
  padding:4px 12px 4px 4px;border-radius:999px;
  background:rgba(255,255,255,.55);border:1px solid rgba(255,255,255,.7);
  cursor:pointer;transition:.2s;backdrop-filter:blur(8px);
}
.elder-picker .ech .ph{
  width:28px;height:28px;border-radius:50%;color:#fff;
  display:flex;align-items:center;justify-content:center;
  font-size:13px;font-weight:700;flex-shrink:0;
  box-shadow:0 2px 6px rgba(0,0,0,.1);
}
.elder-picker .ech .nm{
  font-size:13px;font-weight:600;color:var(--t2);white-space:nowrap;
}
.elder-picker .ech.on{
  background:#fff;border-color:var(--blue);
  box-shadow:0 4px 12px rgba(10,132,255,.22);
}
.elder-picker .ech.on .nm{color:var(--blue);}
.elder-picker .ech.add{
  padding:4px;width:34px;height:34px;justify-content:center;
}
.elder-picker .ech.add .ph{
  width:26px;height:26px;background:transparent;
  color:var(--t3);box-shadow:none;
  border:1.5px dashed var(--sep-strong);
}
.engine-header .bell{
  width:38px;height:38px;border-radius:50%;background:#fff;
  display:flex;align-items:center;justify-content:center;color:var(--t2);
  box-shadow:var(--shadow-card);position:relative;cursor:pointer;
}
.engine-header .bell .red-dot{
  position:absolute;top:8px;right:10px;width:8px;height:8px;border-radius:50%;
  background:var(--red);border:1.5px solid #fff;
}

/* 圆环评分 */
.ring-wrap{
  display:flex;justify-content:center;align-items:center;
  padding:18px 16px 8px;position:relative;
}
.ring-wrap svg{width:230px;height:230px;display:block;}
.ring-center{
  position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);
  text-align:center;
}
.ring-center .v{font-size:46px;font-weight:800;color:var(--t1);letter-spacing:-1.5px;line-height:1;}
.ring-center .v small{font-size:20px;font-weight:700;color:var(--t1);}
.ring-center .l{font-size:13px;color:var(--t3);margin-top:4px;font-weight:500;}

/* 家人头像行 */
.family-row{
  display:flex;justify-content:center;gap:18px;padding:6px 16px 18px;
}
.family-row .fam{
  display:flex;flex-direction:column;align-items:center;gap:5px;cursor:pointer;
}
.family-row .ph{
  width:48px;height:48px;border-radius:50%;
  background:linear-gradient(135deg,#FFB199,#FF6B6B);
  display:flex;align-items:center;justify-content:center;color:#fff;
  font-weight:700;font-size:16px;
  border:2.5px solid #fff;box-shadow:0 4px 10px rgba(0,0,0,.06);
  background-size:cover;background-position:center;
}
.family-row .fam.active .ph{
  outline:2.5px solid var(--blue);outline-offset:1px;
}
.family-row .fam .nm{font-size:11px;color:var(--t2);font-weight:500;}
.family-row .fam.active .nm{color:var(--blue);font-weight:700;}
.family-row .ph.add{
  background:#fff;color:var(--t3);border:1.5px dashed var(--sep-strong);
  box-shadow:none;
}

/* 紧急警报卡 */
.urgent-card{
  background:linear-gradient(180deg,#FFE4E2 0%,#FFEFEC 100%);
  border:1px solid rgba(255,59,48,.18);
  border-radius:18px;padding:14px 14px 12px;
  position:relative;
}
.urgent-card .top{display:flex;align-items:center;gap:10px;}
.urgent-card .ic{
  width:36px;height:36px;border-radius:10px;background:#fff;
  display:flex;align-items:center;justify-content:center;color:var(--red);
  box-shadow:0 2px 6px rgba(255,59,48,.18);
}
.urgent-card .tt{font-size:15px;font-weight:700;color:#C81E1E;flex:1;}
.urgent-card .now{
  font-size:10px;font-weight:800;color:#fff;background:var(--red);
  padding:3px 7px;border-radius:6px;letter-spacing:.5px;
  box-shadow:0 2px 6px rgba(255,59,48,.4);
}
.urgent-card .desc{
  font-size:13px;color:#7A1F1A;margin-top:8px;line-height:1.5;
  padding-left:46px;
}
.urgent-card .acts{
  display:flex;gap:8px;margin-top:12px;padding-left:46px;
}
.urgent-card .acts button{
  flex:1;height:34px;border-radius:10px;border:none;font-family:inherit;
  font-size:13px;font-weight:600;cursor:pointer;
}
.urgent-card .acts .primary{background:var(--red);color:#fff;}
.urgent-card .acts .ghost{background:rgba(255,255,255,.85);color:#C81E1E;}

/* 体征概览卡 */
.h2-row{
  display:flex;justify-content:space-between;align-items:center;
  padding:14px 4px 10px;
}
.h2-row h2{font-size:18px;font-weight:700;color:var(--t1);margin:0;letter-spacing:-.3px;}
.h2-row .more{color:var(--t3);font-size:13px;cursor:pointer;font-weight:500;}

.vi-card{
  background:#fff;border-radius:20px;padding:16px 16px 0;
  box-shadow:var(--shadow-card);margin-bottom:14px;overflow:hidden;
}
.vi-card .head{display:flex;align-items:center;justify-content:space-between;}
.vi-card .head .lbl{display:flex;align-items:center;gap:8px;font-size:13px;color:var(--t3);font-weight:500;}
.vi-card .head .lbl .ic{
  width:28px;height:28px;border-radius:9px;display:flex;align-items:center;
  justify-content:center;color:#fff;
}
.vi-card .head .efx{font-size:12px;color:var(--t3);}
.vi-card .head .efx b{color:var(--blue);font-weight:700;font-size:14px;margin-left:4px;}
.vi-card .head .efx.red b{color:var(--red);}
.vi-card .head .efx.green b{color:var(--green);}
.vi-card .head .efx.red{font-weight:600;}
.vi-card .head .efx.green{font-weight:600;}

.cp-card .cp-grid{
  margin-top:10px;display:grid;grid-template-columns:1fr 1fr;gap:10px;
}
.cp-card .cp-col{
  background:#F7F9FC;border-radius:14px;padding:10px 12px;
}
.cp-card .cp-col .k{font-size:12px;color:var(--t3);font-weight:600;}
.cp-card .cp-col .v{
  margin-top:4px;font-size:26px;font-weight:800;color:var(--t1);letter-spacing:-.8px;line-height:1;
}
.cp-card .cp-col .v small{
  font-size:12px;font-weight:600;color:var(--t3);margin-left:3px;
}
.cp-card .cp-col .s{
  margin-top:7px;display:inline-flex;align-items:center;padding:2px 8px;border-radius:999px;
  font-size:11px;font-weight:700;
}
.cp-card .cp-col .s.ok{color:#1F8E4A;background:#ECFDF3;border:1px solid #BEEBCF;}
.cp-card .cp-col .s.warn{color:#D93025;background:#FFF3F2;border:1px solid #FFD5D2;}
.cp-card .cp-summary{
  margin-top:10px;font-size:12px;color:var(--t2);line-height:1.45;padding:0 2px;
}

.vi-subhead{
  font-size:15px;font-weight:700;color:var(--t1);margin:4px 0 10px;letter-spacing:-.2px;
}
.vi-two-col{
  display:grid;grid-template-columns:1fr 1fr;gap:10px;margin-bottom:14px;
}
.vi-mini-card{
  padding:12px 12px 10px;margin-bottom:0;border-radius:16px;
  display:flex;flex-direction:column;height:100%;
}
.vi-mini-card .head .lbl{font-size:12px;gap:6px;}
.vi-mini-card .head .lbl .ic{width:24px;height:24px;border-radius:8px;}
.vi-mini-card .pill{
  font-size:10px;font-weight:700;border-radius:999px;padding:2px 7px;line-height:1.4;
}
.vi-mini-card .pill.ok{background:#ECFDF3;color:#1F8E4A;border:1px solid #BEEBCF;}
.vi-mini-card .pill.warn{background:#FFF3F2;color:#D93025;border:1px solid #FFD5D2;}
.vi-mini-right{display:flex;align-items:center;gap:6px;}
.vi-mini-right .mini-chev{color:var(--t4);opacity:.9;}
.vi-mini-val{margin-top:8px;display:flex;align-items:baseline;gap:4px;}
.vi-mini-val .v{font-size:26px;font-weight:800;color:var(--t1);letter-spacing:-.8px;line-height:1;}
.vi-mini-val .u{font-size:11px;color:var(--t3);font-weight:600;}
.vi-mini-bottom{margin-top:auto;}
.vi-mini-updated{
  margin-top:10px;padding-top:10px;border-top:.5px solid var(--sep);
  font-size:11px;color:var(--t4);font-weight:600;
}
.vi-range-caption{
  margin-top:10px;display:flex;align-items:center;justify-content:space-between;gap:10px;font-size:12px;line-height:1.35;
}
.vi-range-caption.compact{margin-top:8px;font-size:11px;}
.vi-range-caption .k{color:var(--t3);}
.vi-range-caption .v{font-weight:700;color:var(--t1);font-variant-numeric:tabular-nums;}
.vi-range-gauge{margin-top:8px;padding:6px 2px 2px;}
.vi-range-track{
  position:relative;height:10px;border-radius:999px;background:#EAECEF;overflow:visible;
}
.vi-range-track .zone{
  position:absolute;top:0;bottom:0;border-radius:999px;
  background:linear-gradient(90deg,rgba(48,209,88,.38),rgba(48,209,88,.62));
}
.vi-range-track .tick{
  position:absolute;top:50%;width:11px;height:11px;margin-top:-5.5px;margin-left:-5.5px;border-radius:50%;
  background:#fff;border:2.5px solid var(--blue);
  box-shadow:0 1px 4px rgba(15,23,42,.2);
}
.vi-range-scale{
  display:flex;justify-content:space-between;margin-top:4px;font-size:11px;font-weight:600;
  color:var(--t3);font-variant-numeric:tabular-nums;padding:0 2px;
}

.vi-card .big-val{
  margin-top:6px;display:flex;align-items:baseline;gap:8px;
}
.vi-card .big-val .lab{font-size:13px;color:var(--t3);}
.vi-card .big-val .vv{font-size:30px;font-weight:800;color:var(--t1);letter-spacing:-1px;}
.vi-card .big-val .delta{font-size:12px;color:var(--t3);font-weight:500;}
.vi-card .big-val .delta.up{color:var(--red);}
.vi-card .big-val .delta.down{color:var(--green);}

.vi-card .vi-chart{margin-top:10px;height:80px;}
.vi-card .vi-chart svg{width:100%;height:100%;display:block;}

.vi-detail{
  margin:12px -16px 0;padding:11px 16px;border-top:.5px solid var(--sep);
  display:flex;align-items:center;justify-content:center;gap:6px;
  font-size:13px;color:var(--blue);font-weight:500;cursor:pointer;
}

/* 睡眠特殊柱 */
.sleep-bubble{
  display:flex;align-items:flex-end;justify-content:center;gap:10px;height:80px;margin-top:10px;
}
.sleep-bubble .b{
  width:32px;border-radius:16px;background:linear-gradient(180deg,#C7CFFF,#E8ECFF);
}
.sleep-bubble .b.on{background:linear-gradient(180deg,#0A84FF,#5E5CE6);box-shadow:0 6px 14px rgba(10,132,255,.35);}
.sleep-stage-mini{margin-top:10px;}
.sleep-stage-mini .track{
  height:12px;border-radius:999px;background:#EEF1F7;overflow:hidden;display:flex;
}
.sleep-stage-mini .track .seg{height:100%;display:block;}
.sleep-stage-mini .track .deep{background:#5E5CE6;}
.sleep-stage-mini .track .light{background:#64D2FF;}
.sleep-stage-mini .track .rem{background:#BF5AF2;}
.sleep-stage-mini .track .awake{background:#FFD60A;}
.sleep-stage-mini .legend{
  margin-top:6px;display:flex;flex-wrap:wrap;gap:10px;font-size:10px;color:var(--t3);font-weight:600;
}
.sleep-stage-mini .legend span{display:inline-flex;align-items:center;gap:4px;}
.sleep-stage-mini .legend .lg{width:7px;height:7px;border-radius:50%;display:inline-block;}
.sleep-stage-mini .legend .lg.deep{background:#5E5CE6;}
.sleep-stage-mini .legend .lg.light{background:#64D2FF;}
.sleep-stage-mini .legend .lg.rem{background:#BF5AF2;}
.sleep-stage-mini .legend .lg.awake{background:#FFD60A;}

/* 呼吸波形 */
.brth-bars{
  display:flex;align-items:center;justify-content:center;gap:3px;height:60px;margin-top:6px;
}
.brth-bars .b{width:3px;border-radius:2px;background:#30D158;}

/* ============ Stepper（多步向导） ============ */
.stepper{
  display:flex;align-items:center;padding:10px 20px 14px;gap:6px;
}
.stepper .st{
  display:flex;flex-direction:column;align-items:center;gap:4px;flex-shrink:0;
}
.stepper .st .dot{
  width:26px;height:26px;border-radius:50%;background:#E9E9EA;color:var(--t3);
  display:flex;align-items:center;justify-content:center;font-size:12px;font-weight:700;
  border:2px solid #fff;
}
.stepper .st.done .dot{background:var(--blue);color:#fff;}
.stepper .st.cur .dot{
  background:#fff;color:var(--blue);border:2px solid var(--blue);
  box-shadow:0 0 0 3px rgba(10,132,255,.18);
}
.stepper .st .lb{font-size:10px;color:var(--t3);font-weight:500;white-space:nowrap;}
.stepper .st.cur .lb{color:var(--blue);font-weight:600;}
.stepper .ln{flex:1;height:2px;background:#E9E9EA;border-radius:1px;margin:0 -2px 14px;}
.stepper .ln.done{background:var(--blue);}

/* 扫码框 */
.scan-frame{
  margin:30px auto;width:240px;height:240px;position:relative;
  background:#0c0c0e;border-radius:24px;overflow:hidden;
  background-image:linear-gradient(180deg,#1a1d2e,#0c0c0e);
}
.scan-frame::before{
  content:"";position:absolute;inset:0;
  background:
    linear-gradient(90deg,#fff 0,#fff 30px,transparent 30px,transparent calc(100% - 30px),#fff calc(100% - 30px),#fff 100%) top/100% 3px no-repeat,
    linear-gradient(90deg,#fff 0,#fff 30px,transparent 30px,transparent calc(100% - 30px),#fff calc(100% - 30px),#fff 100%) bottom/100% 3px no-repeat,
    linear-gradient(0deg,#fff 0,#fff 30px,transparent 30px,transparent calc(100% - 30px),#fff calc(100% - 30px),#fff 100%) left/3px 100% no-repeat,
    linear-gradient(0deg,#fff 0,#fff 30px,transparent 30px,transparent calc(100% - 30px),#fff calc(100% - 30px),#fff 100%) right/3px 100% no-repeat;
  pointer-events:none;
}
.scan-frame .scanline{
  position:absolute;left:8%;right:8%;height:2px;
  background:linear-gradient(90deg,transparent,#0A84FF,transparent);
  box-shadow:0 0 12px #0A84FF;
  animation:scanmv 2.4s ease-in-out infinite;border-radius:2px;
}
@keyframes scanmv{
  0%,100%{top:14%;} 50%{top:80%;}
}
.scan-tip{text-align:center;color:var(--t3);font-size:13px;margin-top:6px;}

/* SN 输入 */
.sn-card{
  background:var(--card);border-radius:16px;padding:20px;box-shadow:var(--shadow-card);
}
.sn-input{
  display:flex;gap:8px;justify-content:center;margin:18px 0 6px;
}
.sn-input .digit{
  width:36px;height:46px;border-radius:10px;background:#F2F2F7;
  display:flex;align-items:center;justify-content:center;font-size:20px;
  font-weight:700;color:var(--t1);font-family:'SF Mono',monospace;
  border:1.5px solid transparent;
}
.sn-input .digit.on{border-color:var(--blue);background:#fff;
  box-shadow:0 0 0 3px rgba(10,132,255,.15);}
.sn-input .digit.empty{color:var(--t4);}
.sn-input .sep{display:flex;align-items:center;color:var(--t4);font-weight:700;}

/* 进度搜索（loading 圆环 + 文字） */
.searching{text-align:center;padding:30px 20px;}
.search-ring{
  width:100px;height:100px;border-radius:50%;margin:0 auto 18px;
  background:conic-gradient(var(--blue) 0deg 270deg,#E9E9EA 270deg 360deg);
  display:flex;align-items:center;justify-content:center;
  animation:spin 1.4s linear infinite;
}
.search-ring::after{
  content:"";width:80px;height:80px;border-radius:50%;background:#fff;
}
.search-ring .ic{
  position:absolute;color:var(--blue);
}
@keyframes spin{to{transform:rotate(360deg);}}
.searching .ttl{font-size:18px;font-weight:700;color:var(--t1);}
.searching .sub{font-size:13px;color:var(--t3);margin-top:6px;line-height:1.5;}

/* 表单 */
.form-list{
  background:var(--card);border-radius:16px;overflow:hidden;box-shadow:var(--shadow-card);
}
.form-row{
  padding:13px 14px;display:flex;align-items:center;gap:12px;min-height:50px;
}
.form-row + .form-row{border-top:.5px solid var(--sep);}
.form-row .lab{font-size:15px;color:var(--t1);min-width:90px;}
.form-row .req{color:var(--red);font-size:13px;margin-left:2px;}
.form-row input,.form-row select,.form-row textarea{
  flex:1;border:none;outline:none;background:transparent;font-size:15px;color:var(--t1);
  font-family:inherit;text-align:right;min-width:0;
}
.form-row input::placeholder{color:var(--t4);}
.form-row .v{flex:1;color:var(--t3);font-size:15px;text-align:right;}
.form-row.col{flex-direction:column;align-items:flex-start;gap:6px;}
.form-row.col textarea{
  width:100%;text-align:left;min-height:60px;resize:none;
}
.form-list-tight .form-row{min-height:44px;padding:10px 14px;}

/* 关联长辈 · 多紧急联系人 */
.ec-card{
  background:var(--card);border-radius:16px;overflow:hidden;box-shadow:var(--shadow-card);
  margin-bottom:10px;border:1px solid rgba(15,23,42,.05);
}
.ec-hd{
  display:flex;align-items:center;justify-content:space-between;gap:10px;padding:11px 14px;
  border-bottom:.5px solid var(--sep);background:rgba(247,248,251,.9);
}
.ec-hd-l{display:flex;align-items:center;flex-wrap:wrap;gap:8px;}
.ec-del{
  font-size:13px;font-weight:600;color:var(--red);cursor:pointer;
  flex-shrink:0;padding:4px 2px;
}
.ec-del:active{opacity:.72;}
.ec-idx{
  font-size:12px;font-weight:800;color:var(--t3);
  min-width:22px;height:22px;padding:0 6px;border-radius:8px;background:var(--bg);
  display:inline-flex;align-items:center;justify-content:center;
}
.ec-intro{font-size:12px;color:var(--t3);line-height:1.5;margin:-4px 0 10px;}
.ec-cap{font-size:11px;color:var(--t4);text-align:center;margin-top:8px;line-height:1.4;}
.remark-ta{
  width:100%;border:none;outline:none;resize:vertical;min-height:88px;
  font-size:14px;line-height:1.5;color:var(--t1);font-family:inherit;background:transparent;
}
.remark-ta::placeholder{color:var(--t4);}

.flash-bar{
  margin:0 16px 10px;padding:10px 14px;border-radius:12px;
  background:var(--green-soft);color:#1F8E3D;font-size:13px;font-weight:600;
  border:1px solid rgba(48,209,88,.22);
}

/* chip 选择器 */
.chips{display:flex;flex-wrap:wrap;gap:6px;}
.chip{
  padding:6px 12px;border-radius:999px;font-size:13px;font-weight:500;
  background:#F2F2F7;color:var(--t2);border:1px solid transparent;cursor:pointer;
}
.chip.on{background:var(--blue-soft);color:var(--blue);border-color:var(--blue);}
.chip.add{
  background:transparent;border:1.5px dashed var(--sep-strong);color:var(--t3);
}

/* 长者大头像 */
.elder-hero{
  background:linear-gradient(135deg,#0A84FF 0%,#5E5CE6 100%);
  color:#fff;border-radius:0 0 26px 26px;padding:14px 20px 22px;
  box-shadow:0 8px 22px rgba(10,132,255,.22);position:relative;overflow:hidden;
}
.elder-hero::before{content:"";position:absolute;right:-30px;top:-30px;
  width:160px;height:160px;border-radius:50%;background:rgba(255,255,255,.1);}
.elder-hero .who{display:flex;align-items:center;gap:14px;position:relative;z-index:2;margin-top:6px;}
.elder-hero .who.elder-who-single{align-items:center;gap:12px;}
.elder-hero .who-main{flex:1;min-width:0;}
.elder-hero .who-main .nm{white-space:nowrap;overflow:hidden;text-overflow:ellipsis;}
.elder-hero .who-main .meta{
  white-space:nowrap;overflow:hidden;text-overflow:ellipsis;font-size:13px;opacity:.92;margin-top:3px;
}
.elder-hero .elder-dev-inline{
  flex-shrink:0;text-align:right;padding-left:8px;border-left:1px solid rgba(255,255,255,.28);
  margin-left:4px;min-width:88px;
}
.elder-hero .elder-dev-inline .dv{font-size:17px;font-weight:700;line-height:1.15;}
.elder-hero .elder-dev-inline .dv small{font-size:12px;opacity:.82;font-weight:600;}
.elder-hero .elder-dev-inline .dl{font-size:10px;opacity:.88;margin-top:3px;white-space:nowrap;line-height:1.2;}
.elder-hero .pic{
  width:64px;height:64px;border-radius:50%;background:rgba(255,255,255,.25);
  display:flex;align-items:center;justify-content:center;font-size:24px;font-weight:700;
  border:3px solid rgba(255,255,255,.35);
}
.elder-hero .nm{font-size:22px;font-weight:800;letter-spacing:-.3px;}
.elder-hero .meta{font-size:13px;opacity:.92;margin-top:3px;}
.elder-hero .stat{
  display:flex;gap:18px;margin-top:14px;position:relative;z-index:2;
}
.elder-hero .stat.stat-one{justify-content:center;}
.elder-hero .stat.stat-one .b{min-width:120px;text-align:center;}
.elder-hero .stat .b .v{font-size:18px;font-weight:700;}
.elder-hero .stat .b .l{font-size:11px;opacity:.85;margin-top:2px;}

/* 长者切换头像（横滚） */
.elder-switch{
  display:flex;gap:12px;padding:14px 20px 10px;overflow-x:auto;-webkit-overflow-scrolling:touch;
}
.elder-switch::-webkit-scrollbar{display:none;}
.elder-switch .e{
  flex-shrink:0;display:flex;flex-direction:column;align-items:center;gap:4px;cursor:pointer;
  position:relative;z-index:0;
}
.elder-switch .e.on{z-index:1;}
.elder-switch .e .ph{
  width:54px;height:54px;border-radius:50%;color:#fff;font-weight:700;font-size:18px;
  display:flex;align-items:center;justify-content:center;
  border:3px solid #fff;box-shadow:0 4px 10px rgba(0,0,0,.06);box-sizing:border-box;
}
/* 不使用 outline：横向滚动容器 overflow-x:auto 会裁切外部描边 */
.elder-switch .e.on .ph{
  border:3px solid var(--blue);
  box-shadow:0 4px 12px rgba(10,132,255,.28);
}
.elder-switch .e .nm{font-size:11px;color:var(--t2);font-weight:500;}
.elder-switch .e.on .nm{color:var(--blue);font-weight:700;}
.elder-switch .e .ph.add{
  background:#F2F2F7;color:var(--t3);border:1.5px dashed var(--sep-strong);box-shadow:none;
}

/* 健康档案分组 */
.archive-group{
  background:var(--card);border-radius:16px;overflow:hidden;box-shadow:var(--shadow-card);margin-bottom:14px;
}
.archive-group .gh{
  padding:12px 14px;font-size:13px;font-weight:600;color:var(--t3);
  text-transform:uppercase;letter-spacing:.5px;display:flex;justify-content:space-between;align-items:center;
  border-bottom:.5px solid var(--sep);
}
.archive-group .gh .edit{color:var(--blue);font-size:13px;text-transform:none;letter-spacing:0;cursor:pointer;font-weight:500;}
.archive-row{
  padding:11px 14px;display:flex;align-items:center;gap:10px;font-size:14px;color:var(--t1);
}
.archive-row + .archive-row{border-top:.5px solid var(--sep);}
.archive-row .k{color:var(--t3);min-width:80px;font-size:13px;}
.archive-row .vv{flex:1;text-align:right;color:var(--t1);font-weight:500;}
.archive-row.col{flex-direction:column;align-items:flex-start;gap:6px;}
.archive-row.col .vv{text-align:left;font-weight:400;line-height:1.5;}
.tag-list{display:flex;flex-wrap:wrap;gap:6px;}
.tag{
  font-size:12px;padding:4px 9px;border-radius:8px;background:#F2F2F7;color:var(--t2);font-weight:500;
}
.tag.warn{background:var(--red-soft);color:#C81E1E;}
.tag.med{background:var(--blue-soft);color:var(--blue);}
.tag.ok{background:var(--green-soft);color:#1F8E3D;}

/* 紧急联系人 */
.contact-row{
  padding:12px 14px;display:flex;align-items:center;gap:12px;
}
.contact-row + .contact-row{border-top:.5px solid var(--sep);}
.contact-row .av{
  width:38px;height:38px;border-radius:50%;color:#fff;display:flex;align-items:center;
  justify-content:center;font-size:14px;font-weight:700;
}
.contact-row .info{flex:1;}
.contact-row .info .n{font-size:14px;font-weight:600;color:var(--t1);}
.contact-row .info .m{font-size:12px;color:var(--t3);margin-top:2px;}
.contact-row .call{
  width:34px;height:34px;border-radius:50%;background:var(--green-soft);color:var(--green);
  display:flex;align-items:center;justify-content:center;cursor:pointer;
}

/* 长者列表卡片 */
.elder-item{
  background:var(--card);border-radius:20px;padding:14px 16px;
  display:flex;align-items:center;gap:14px;
  box-shadow:var(--shadow-card);margin-bottom:12px;
  cursor:pointer;transition:transform .15s ease;
}
.elder-item:active{transform:scale(.985);}
.elder-item .ph{
  width:54px;height:54px;border-radius:50%;flex-shrink:0;
  display:flex;align-items:center;justify-content:center;
  color:#fff;font-size:20px;font-weight:700;
  box-shadow:0 4px 10px rgba(0,0,0,.08);
}
.elder-item .info{flex:1;min-width:0;}
.elder-item .info .n{font-size:16px;font-weight:600;color:var(--t1);}
.elder-item .info .m{font-size:13px;color:var(--t3);margin-top:3px;}
.elder-item .chev{color:var(--t4);flex-shrink:0;}

/* 悬浮操作按钮（透明背景，浮在页面之上） */
.foot-bar{
  position:absolute;left:18px;right:18px;bottom:22px;z-index:30;
  display:flex;gap:10px;background:transparent;pointer-events:none;
}
.foot-bar button{
  flex:1;height:52px;border:none;border-radius:999px;font-family:inherit;font-size:16px;
  font-weight:600;cursor:pointer;transition:.2s;pointer-events:auto;
}
.foot-bar button.primary{
  background:var(--blue);color:#fff;
  box-shadow:0 12px 28px rgba(10,132,255,.38),0 2px 6px rgba(10,132,255,.2);
}
.foot-bar button.primary:active{transform:scale(.98);}
.foot-bar button.ghost{
  background:#fff;color:var(--t2);border:1px solid var(--sep);
  box-shadow:0 10px 22px rgba(15,23,42,.10),0 2px 6px rgba(15,23,42,.05);
}
.foot-bar button.ghost:active{transform:scale(.98);}
/* 给 screen 预留足够的底部空间，保证最后一个输入项可以滚到按钮之上 */
.has-foot .screen{padding-bottom:140px;}

/* ============ 我的 / Profile 页 ============ */
.mine-hero{
  background:linear-gradient(135deg,#0A84FF 0%,#5E5CE6 100%);
  color:#fff;padding:20px 20px 30px;border-radius:0 0 28px 28px;
  position:relative;overflow:hidden;
}
.mine-hero::before{content:"";position:absolute;right:-40px;top:-50px;
  width:180px;height:180px;border-radius:50%;background:rgba(255,255,255,.12);}
.mine-hero::after{content:"";position:absolute;left:-30px;bottom:-40px;
  width:120px;height:120px;border-radius:50%;background:rgba(255,255,255,.08);}
.mine-hero .who{display:flex;align-items:center;gap:14px;position:relative;z-index:2;}
.mine-hero .av{
  width:64px;height:64px;border-radius:50%;
  background:rgba(255,255,255,.25);border:3px solid rgba(255,255,255,.5);
  display:flex;align-items:center;justify-content:center;
  font-size:22px;font-weight:700;flex-shrink:0;
}
.mine-hero .mine-name-row{display:flex;align-items:center;gap:8px;min-width:0;}
.mine-hero .mine-name-row .n{
  font-size:20px;font-weight:800;letter-spacing:-.3px;
  min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;
}
.mine-hero .mine-member-badge{
  flex-shrink:0;display:inline-flex;align-items:center;justify-content:center;
  width:26px;height:26px;border-radius:50%;
  font-size:12px;font-weight:900;line-height:1;
  letter-spacing:-.04em;color:#FFFEF8;
  text-shadow:0 1px 0 rgba(120,72,8,.35);
  background:linear-gradient(165deg,#FFEBAE 0%,#F5A623 45%,#C87A08 100%);
  border:1.5px solid rgba(255,255,255,.55);
  box-shadow:
    0 2px 10px rgba(0,0,0,.22),
    inset 0 1px 1px rgba(255,255,255,.42);
}
.mine-hero .mine-member-badge span{display:block;margin-top:1px;}
.mine-hero .m{font-size:13px;opacity:.9;margin-top:4px;}
.mine-hero .edit-profile{
  margin-left:auto;background:rgba(255,255,255,.22);
  padding:6px 12px;border-radius:999px;font-size:12px;font-weight:600;
  backdrop-filter:blur(8px);cursor:pointer;
}
.mine-hero .stats{
  display:flex;justify-content:space-around;margin-top:18px;
  background:rgba(255,255,255,.15);border-radius:16px;padding:12px;
  position:relative;z-index:2;backdrop-filter:blur(8px);
}
.mine-hero .stats .b{text-align:center;}
.mine-hero .stats .v{font-size:18px;font-weight:700;}
.mine-hero .stats .l{font-size:11px;opacity:.9;margin-top:2px;}

.mine-menu{
  background:var(--card);border-radius:16px;overflow:hidden;
  box-shadow:var(--shadow-card);margin-bottom:14px;
}
.mine-menu .mi{
  padding:14px 16px;display:flex;align-items:center;gap:14px;cursor:pointer;
}
.mine-menu .mi + .mi{border-top:.5px solid var(--sep);}
.mine-menu .mi:active{background:#F7F8FB;}
.mine-menu .mi .ic{
  width:34px;height:34px;border-radius:10px;
  display:flex;align-items:center;justify-content:center;color:#fff;flex-shrink:0;
}
.mine-menu .mi .t{flex:1;font-size:15px;color:var(--t1);font-weight:500;}
.mine-menu .mi .v{font-size:13px;color:var(--t3);margin-right:2px;}
.mine-menu .mi .badge-num{
  background:var(--red);color:#fff;font-size:11px;font-weight:700;
  padding:1px 7px;border-radius:999px;margin-right:2px;
}
.mine-menu .mi .chev{color:var(--t4);}

.btn-logout{
  width:100%;height:52px;border:none;border-radius:999px;
  background:#fff;color:var(--red);font-size:16px;font-weight:600;
  font-family:inherit;cursor:pointer;box-shadow:var(--shadow-card);
  margin-top:8px;transition:.2s;
}
.btn-logout:active{transform:scale(.98);background:#FFF1F0;}

/* 成功页 */
.success-wrap{
  text-align:center;padding:60px 24px 30px;
}
.success-wrap .check{
  width:88px;height:88px;border-radius:50%;background:var(--green);
  display:flex;align-items:center;justify-content:center;color:#fff;
  margin:0 auto 22px;box-shadow:0 12px 30px rgba(48,209,88,.35);
  animation:popin .5s cubic-bezier(.34,1.56,.64,1);
}
@keyframes popin{from{transform:scale(.4);opacity:0;}to{transform:scale(1);opacity:1;}}
.success-wrap h2{font-size:22px;font-weight:800;color:var(--t1);margin:0 0 6px;}
.success-wrap p{font-size:14px;color:var(--t3);margin:0;line-height:1.6;}

/* ============ 健康周报 ============ */
.report-list-sec{display:flex;flex-direction:column;gap:12px;}
.report-row-card{
  background:var(--card);border-radius:16px;padding:16px;
  box-shadow:var(--shadow-card);cursor:pointer;
  border:1px solid rgba(15,23,42,.04);transition:.15s;
}
.report-row-card:active{transform:scale(.99);opacity:.96;}
.rr-top{display:flex;align-items:center;justify-content:space-between;gap:10px;margin-bottom:6px;}
.rr-name{font-size:16px;font-weight:700;color:var(--t1);}
.rr-period{font-size:12px;color:var(--t3);margin-bottom:8px;}
.rr-sum{font-size:14px;color:var(--t2);line-height:1.55;margin-bottom:10px;}
.rr-meta{display:flex;justify-content:space-between;font-size:11px;color:var(--t4);}

.report-summary-card{
  background:linear-gradient(135deg,#F2F8FF,#FFF);border-radius:14px;padding:14px 16px;
  font-size:15px;line-height:1.55;color:var(--t1);border:1px solid rgba(10,132,255,.12);
}

.report-metrics-grid{
  display:grid;grid-template-columns:1fr 1fr;gap:10px;
}
.rm-card{
  background:var(--card);border-radius:14px;padding:14px;
  box-shadow:var(--shadow-card);border:1px solid rgba(15,23,42,.05);
}
.rm-card-wide{grid-column:1/-1;}
.rm-ic{
  width:36px;height:36px;border-radius:10px;display:flex;align-items:center;
  justify-content:center;color:#fff;margin-bottom:8px;
}
.rm-lab{font-size:11px;font-weight:600;color:var(--t3);text-transform:uppercase;letter-spacing:.04em;margin-bottom:4px;}
.rm-main{font-size:14px;color:var(--t1);line-height:1.35;}
.rm-main b{font-size:17px;font-weight:800;}
.rm-main small{font-size:11px;color:var(--t3);font-weight:500;}
.rm-sub{font-size:12px;color:var(--t3);margin-top:6px;}
.rm-note{font-size:12px;color:var(--t2);margin-top:10px;line-height:1.45;padding-top:10px;border-top:.5px solid var(--sep);}

.report-anomaly-stack{display:flex;flex-direction:column;gap:10px;}
.report-anomaly{
  border-radius:14px;padding:12px 14px;border-left:4px solid var(--sep);
  background:var(--card);box-shadow:var(--shadow-card);
}
.report-anomaly.ra-high{border-left-color:var(--red);background:linear-gradient(90deg,#FFF5F5,#fff);}
.report-anomaly.ra-mid{border-left-color:var(--orange);background:linear-gradient(90deg,#FFFBF5,#fff);}
.report-anomaly.ra-low{border-left-color:var(--blue);background:linear-gradient(90deg,#F5FAFF,#fff);}
.ra-cat{font-size:11px;font-weight:700;color:var(--t3);margin-bottom:4px;}
.ra-t{font-size:15px;font-weight:700;color:var(--t1);margin-bottom:6px;}
.ra-d{font-size:13px;color:var(--t2);line-height:1.5;}

.ai-report-head{
  display:flex;align-items:flex-start;gap:12px;margin-bottom:12px;
}
.ai-report-head .ai-icon{
  width:44px;height:44px;border-radius:12px;
  background:linear-gradient(135deg,#BF5AF2,#5E5CE6);color:#fff;
  display:flex;align-items:center;justify-content:center;flex-shrink:0;
  box-shadow:0 8px 20px rgba(94,92,230,.25);
}
.ai-report-title{font-size:16px;font-weight:800;color:var(--t1);}
.ai-report-sub{font-size:12px;color:var(--t3);margin-top:2px;line-height:1.35;}

.ai-report-card{
  background:linear-gradient(180deg,#FAF8FF 0%,#FFF 40%);
  border-radius:16px;padding:16px 18px;border:1px solid rgba(94,92,230,.15);
  box-shadow:0 8px 24px rgba(94,92,230,.08);
}
.ai-report-card .ai-lead{
  font-size:15px;font-weight:600;color:var(--t1);line-height:1.55;margin:0 0 14px;
}
.ai-report-card .ai-list{
  margin:0;padding-left:18px;color:var(--t2);font-size:14px;line-height:1.55;
}
.ai-report-card .ai-list li{margin-bottom:10px;}
.ai-report-card .ai-list li:last-child{margin-bottom:0;}
.ai-report-card .ai-disclaimer{
  margin:14px 0 0;font-size:11px;color:var(--t4);line-height:1.45;
  padding-top:12px;border-top:.5px solid rgba(94,92,230,.12);
}

/* ============ 会员 · 周报 / 月报 ============ */
.member-paywall{padding:8px 18px 28px;text-align:center;}
.member-paywall .large-title{text-align:center;}
.member-paywall .large-title h1{font-size:26px;}
.mp-crown{
  width:72px;height:72px;margin:0 auto 12px;border-radius:20px;
  background:linear-gradient(135deg,#FFF6D9,#FFE6A8);
  color:#B8860B;display:flex;align-items:center;justify-content:center;
  box-shadow:0 8px 24px rgba(255,159,10,.18);
}
.mp-benefits{text-align:left;padding:14px 16px!important;margin-bottom:16px;}
.mp-benefits .mp-bt{font-size:13px;font-weight:700;color:var(--t1);margin-bottom:10px;}
.mp-benefits ul{margin:0;padding-left:18px;color:var(--t2);font-size:14px;line-height:1.55;}
.mp-benefits li{margin-bottom:8px;}
.mp-cta{width:100%;display:block;box-sizing:border-box;}
.mp-skip{width:100%;display:block;box-sizing:border-box;margin-top:10px;}
.mp-hint{font-size:12px;color:var(--t4);margin:14px 12px 0;line-height:1.45;}

.member-strip{
  margin:14px 0 0;padding:12px 14px;border-radius:14px;display:flex;
  align-items:center;justify-content:space-between;font-size:13px;line-height:1.35;
  cursor:pointer;position:relative;z-index:2;
}
.member-strip-off{
  background:linear-gradient(90deg,#FFF8E8,#FFEECD);color:#4A3B12;border:1px solid rgba(255,159,10,.28);
  font-weight:600;
}
.member-strip-off b{font-weight:700;color:#C95600;font-size:14px;}

.member-sub-hero{padding:10px 18px 6px;}
.member-sub-hero .msh-badge{
  display:inline-block;font-size:11px;font-weight:700;color:var(--blue);
  background:rgba(10,132,255,.1);padding:4px 10px;border-radius:20px;margin-bottom:10px;
}
.member-sub-hero h1{font-size:26px;font-weight:800;margin:0 0 8px;color:var(--t1);letter-spacing:-.4px;}
.member-sub-hero p{margin:0;font-size:14px;color:var(--t3);line-height:1.55;}

.member-benefit-list{padding-top:8px!important;padding-bottom:8px!important;}
.member-benefit-list .mbl-it{display:flex;gap:12px;padding:12px 0;border-bottom:.5px solid var(--sep);}
.member-benefit-list .mbl-it:last-child{border-bottom:none;padding-bottom:2px;}
.mbl-ic{
  flex-shrink:0;width:44px;height:44px;border-radius:12px;
  background:linear-gradient(135deg,#FFEEB8,#FFD66A);font-size:12px;font-weight:800;color:#6B5414;
  display:flex;align-items:center;justify-content:center;
}
.mbl-it b{display:block;font-size:15px;color:var(--t1);margin-bottom:4px;}
.mbl-it span{display:block;font-size:12px;color:var(--t3);line-height:1.4;font-weight:400;}

.member-price-card-wrap{padding-top:10px!important;}
.member-price-card{padding:16px!important;margin-bottom:16px;}
.member-price-card .mpc-row{display:flex;justify-content:space-between;align-items:baseline;margin-bottom:4px;}
.member-price-card .mpc-row.mpc-alt{margin-top:10px;padding-top:10px;border-top:.5px solid var(--sep);margin-bottom:0;}
.mpc-name{font-size:15px;color:var(--t1);font-weight:600;}
.mpc-price b{font-size:22px;font-weight:800;color:var(--t1);}
.mpc-price small{font-size:12px;color:var(--t3);font-weight:500;margin-left:2px;}
.mpc-tip{font-size:12px;color:var(--green);font-weight:600;margin:4px 0 10px;}
.member-open-btn{width:100%;display:block;box-sizing:border-box;}
.mpc-law{font-size:11px;color:var(--t4);text-align:center;line-height:1.45;margin:12px 8px 0;}
.member-plan-radio{display:flex;gap:10px;}
.member-plan-radio label{
  flex:1;display:flex;align-items:center;justify-content:center;gap:8px;
  padding:10px 12px;border:1px solid var(--sep);border-radius:12px;
  background:#fff;font-size:14px;color:var(--t2);cursor:pointer;user-select:none;
}
.member-plan-radio label input{accent-color:var(--blue);}
.member-plan-radio label.on{
  border-color:rgba(10,132,255,.35);background:rgba(10,132,255,.06);
  color:var(--t1);font-weight:600;
}

.report-tab-seg{width:100%;box-sizing:border-box;}
.member-detail-gate{padding:18px;margin-top:8px!important;}
.sim-pack{cursor:pointer;transition:.15s;border:1px solid transparent;border-radius:12px;}
.sim-pack.on{border-color:rgba(10,132,255,.35);background:rgba(10,132,255,.05);}
.sim-topup-hero{
  background:linear-gradient(135deg,#F7FAFF,#FFFFFF 48%,#F6FFF9);
}
.sim-picker-card{padding:14px!important;}
.sim-stepper{
  display:flex;align-items:center;justify-content:space-between;gap:10px;
}
.sim-stepper button{
  width:42px;height:42px;border-radius:12px;border:1px solid var(--sep);
  background:#fff;color:var(--t1);font-size:24px;line-height:1;cursor:pointer;
}
.sim-stepper .val{
  flex:1;text-align:center;font-size:30px;font-weight:800;color:var(--t1);letter-spacing:-.5px;
}
.sim-stepper .val small{font-size:14px;font-weight:600;color:var(--t3);margin-left:4px;}
.sim-total-row{
  margin-top:14px;padding-top:12px;border-top:.5px solid var(--sep);
  display:flex;align-items:center;justify-content:space-between;font-size:13px;color:var(--t3);
}
.sim-total-row b{font-size:20px;color:var(--t1);}
.sheet-mask{
  position:absolute;inset:0;background:rgba(0,0,0,.28);z-index:45;
}
.sheet-panel{
  position:absolute;left:0;right:0;bottom:0;background:#fff;border-radius:18px 18px 0 0;
  padding:16px 16px calc(16px + env(safe-area-inset-bottom));z-index:46;
  box-shadow:0 -12px 32px rgba(15,23,42,.18);
}
.sheet-title{
  font-size:16px;font-weight:700;color:var(--t1);text-align:center;margin-bottom:12px;
}
.sheet-input-wrap{
  border:1px solid var(--sep);border-radius:12px;padding:0 12px;background:#fff;
}
.sheet-input{
  width:100%;height:44px;border:none;outline:none;font-size:15px;color:var(--t1);
}
.sheet-actions{
  display:flex;gap:10px;margin-top:14px;
}
.sheet-actions .btn-primary,.sheet-actions .btn-secondary{
  flex:1;margin:0;
}
.sheet-scroll{max-height:min(360px,46vh);overflow-y:auto;-webkit-overflow-scrolling:touch;}
.sheet-field{margin-bottom:12px;}
.sheet-field:last-child{margin-bottom:4px;}
.sheet-label{font-size:13px;color:var(--t3);margin-bottom:6px;font-weight:500;}
.sheet-textarea{
  width:100%;min-height:100px;max-height:260px;border:1px solid var(--sep);border-radius:12px;
  padding:10px 12px;font-size:15px;line-height:1.45;color:var(--t1);font-family:inherit;
  resize:vertical;outline:none;background:#fff;
}

@media (max-width:480px){
  body{padding:50px 0 30px;}
  #app{gap:20px;}
  .device{width:100%;height:auto;min-height:calc(100vh - 60px);border-radius:0;box-shadow:none;}
  .device .dynamic-island,.home-ind{display:none;}
}
