/* ===== 全局重置 ===== */
*{margin:0;padding:0;box-sizing:border-box;-webkit-tap-highlight-color:transparent;}

/* ===== CSS 变量 ===== */
:root{
  --primary:#1a9a5c;
  --primary-dark:#157a49;
  --primary-light:#e8f7ef;
  --text-main:#333;
  --text-sub:#666;
  --text-light:#999;
  --border:#e5e5e5;
  --bg:#f4f4f4;
  --white:#fff;
  --tabbar-h:calc(49px + env(safe-area-inset-bottom, 0px));
  --nav-h:44px;
  --status-bar:env(safe-area-inset-top, 20px);
  --bottom-safe:env(safe-area-inset-bottom, 0px);
  /* JS 计算的 viewport 高度单位 */
  --vh:1vh;
}

/* ===========================
   启动 Splash 遮罩 — iOS 原生风格
   =========================== */
#splash-screen{
  position:fixed;inset:0;
  background:var(--primary);
  display:flex;
  flex-direction:column;
  align-items:center;
  justify-content:center;
  gap:16px;
  z-index:99999;
  transition:opacity .25s ease, visibility .25s ease;
}
#splash-screen.hidden{
  opacity:0;
  visibility:hidden;
  pointer-events:none;
}
.splash-logo{
  width:80px;height:80px;
  border-radius:20px;
  box-shadow:0 4px 20px rgba(0,0,0,0.25);
}
.splash-app-name{
  font-size:20px;font-weight:700;
  color:#fff;letter-spacing:3px;
  margin-top:4px;
}
.splash-spinner{
  width:36px;height:36px;
  margin-top:8px;
}
.splash-spinner svg{width:36px;height:36px;}

/* ===========================
   导游证照片 Loading 骨架
   =========================== */
.pp-photo-loading{
  position:absolute;inset:0;
  background:rgba(141,185,138,0.5);
  display:flex;align-items:center;justify-content:center;
  z-index:2;
}
.pp-photo-spinner{width:36px;height:36px;}

/* ===== 基础排版 ===== */

html,body{
  width:100%;
  /* 使用 JS 计算的 --vh 单位，或回退到 100% */
  height:calc(var(--vh) * 100);
  height:100%;
  background:#f4f4f4;
  font-family:-apple-system,BlinkMacSystemFont,'PingFang SC','Helvetica Neue',Arial,sans-serif;
  font-size:14px;
  color:var(--text-main);
  overflow:hidden;
  /* iOS 14+ 兼容：禁止弹性滚动 */
  overscroll-behavior:none;
  -webkit-overflow-scrolling:auto;
}

/* iOS standalone 模式专用修复 */
body.ios-standalone {
  position: fixed;
  width: 100%;
  height: 100%;
  overflow: hidden;
}

/* ===== 页面基础 ===== */
.page{position:fixed;top:0;left:0;right:0;bottom:0;width:100%;height:100%;}
.page.active{display:flex;flex-direction:column;}
.page.hidden,.hidden{display:none!important;}

/* ===== 工具类 ===== */
.flex{display:flex;}
.flex-center{display:flex;align-items:center;justify-content:center;}

/* ===== Toast ===== */
.toast{
  position:fixed;top:50%;left:50%;
  transform:translate(-50%,-50%);
  background:rgba(0,0,0,.75);
  color:#fff;padding:10px 20px;
  border-radius:8px;font-size:14px;
  z-index:9999;pointer-events:none;
  max-width:240px;text-align:center;
}

/* ===== 确认弹窗 ===== */
.modal-overlay{position:fixed;inset:0;background:rgba(0,0,0,.5);z-index:8000;display:flex;align-items:center;justify-content:center;}
.modal-box{background:#fff;border-radius:12px;width:280px;overflow:hidden;}
.modal-title{padding:18px 20px 8px;font-size:16px;font-weight:600;text-align:center;color:var(--text-main);}
.modal-content{padding:8px 20px 18px;font-size:14px;color:var(--text-sub);text-align:center;line-height:1.6;}
.modal-actions{display:flex;border-top:1px solid var(--border);}
.modal-btn{flex:1;padding:14px;font-size:16px;border:none;background:transparent;cursor:pointer;}
.modal-cancel{color:var(--text-sub);border-right:1px solid var(--border);}
.modal-ok{color:var(--primary);font-weight:600;}

/* ===========================
   登录页
   =========================== */
#page-login{background:#fff;overflow:hidden;}
.login-wrap{flex:1;display:flex;flex-direction:column;align-items:center;padding:0 32px;overflow-y:auto;}
.login-logo-area{display:flex;flex-direction:column;align-items:center;margin-top:calc(var(--status-bar) + 40px);margin-bottom:32px;}
.login-logo{width:80px;height:80px;border-radius:18px;}
.login-logo-text{margin-top:12px;font-size:20px;font-weight:700;color:var(--primary);}
.login-tabs{display:flex;width:100%;border-bottom:2px solid var(--border);margin-bottom:24px;}
.login-tab{flex:1;text-align:center;padding-bottom:10px;font-size:15px;color:var(--text-sub);cursor:pointer;border-bottom:2px solid transparent;margin-bottom:-2px;transition:all .2s;}
.login-tab.active{color:var(--primary);border-bottom-color:var(--primary);font-weight:600;}
.login-form{width:100%;}
.login-input-row{display:flex;align-items:center;border-bottom:1px solid var(--border);padding:12px 0;margin-bottom:4px;position:relative;}
.login-input-icon{width:22px;height:22px;margin-right:12px;object-fit:contain;flex-shrink:0;}
.login-input-row input{flex:1;border:none;outline:none;font-size:15px;color:var(--text-main);background:transparent;}
.login-input-row input::placeholder{color:var(--text-light);}
.login-eye{width:22px;height:22px;cursor:pointer;object-fit:contain;}
.login-btn{width:100%;height:48px;background:var(--primary);color:#fff;border:none;border-radius:24px;font-size:16px;font-weight:600;margin-top:28px;cursor:pointer;letter-spacing:2px;}
.login-btn:active{background:var(--primary-dark);}
.login-btn-quick{width:100%;height:44px;background:transparent;color:var(--primary);border:1.5px solid var(--primary);border-radius:22px;font-size:15px;margin-top:12px;cursor:pointer;}
.login-agreement{display:flex;align-items:center;flex-wrap:wrap;justify-content:center;margin-top:20px;font-size:12px;color:var(--text-sub);}
.login-check{width:16px;height:16px;margin-right:6px;cursor:pointer;}
.login-link{color:var(--primary);cursor:pointer;}
.login-register-link{text-align:center;margin-top:16px;font-size:13px;color:var(--text-sub);}

/* ===========================
   主界面
   =========================== */
#page-main{
  display:none;
  flex-direction:column;
  background:var(--bg);
  position:fixed;
  top:0;left:0;right:0;
  /* 使用 svh 解决 iOS PWA 底部问题 */
  height:100svh;
  height:calc(var(--vh) * 100);
  height:100%;
  height:100vh;
  height:100dvh;
  height:-webkit-fill-available;
  /* 确保延伸到 safe area 底部 */
  padding-bottom:0;
}

/* iOS standalone 模式下强制全屏 */
body.ios-standalone #page-main {
  height: 100svh !important;
  height: 100% !important;
  bottom: 0;
}

/* 底部白色遮罩层 - 终极保险 */
body.ios-standalone::after {
  content: '';
  position: fixed;
  left: 0;
  right: 0;
  bottom: 0;
  height: 50px;
  background: #fff;
  z-index: 99999;
  pointer-events: none;
}
#page-main.active{display:flex;}

/* 内容区：flex:1 自动填满，留出tabbar空间（fixed定位后需要手动padding） */
.page-content{
  flex:1;
  overflow:hidden;
  position:relative;
  min-height:0;
  /* 为fixed定位的tabbar留出空间：图标区 + safe-area */
  padding-bottom:calc(49px + env(safe-area-inset-bottom, 0px));
}

/* 每个 tab 页内容区：绝对定位充满 page-content */
.tab-page{
  position:absolute;
  top:0;left:0;right:0;bottom:0;
  overflow-y:auto;
  -webkit-overflow-scrolling:touch;
  background:var(--bg);
  /* padding-bottom 在 .page-content 统一处理 */
}
.tab-page.hidden{display:none;}

/* ===========================
   TabBar — fixed定位紧贴屏幕底部，覆盖home indicator区域
   =========================== */
.tabbar{
  position:fixed;
  left:0;right:0;bottom:0;
  width:100%;
  /* 使用border-box让padding包含在height内 */
  box-sizing:border-box;
  /* 高度 = 图标区 + safe-area */
  height:calc(49px + env(safe-area-inset-bottom, 0px));
  min-height:49px;
  display:flex;
  align-items:flex-start;
  padding-top:6px;
  /* safe-area padding-bottom让内容避开home indicator */
  padding-bottom:env(safe-area-inset-bottom, 0px);
  background:#fff;
  border-top:0.5px solid rgba(0,0,0,.1);
  z-index:90;
  -webkit-transform:translateZ(0);
  transform:translateZ(0);
}
.tabbar-item{
  flex:1;
  display:flex;
  flex-direction:column;
  align-items:center;
  justify-content:flex-start;
  cursor:pointer;
  position:relative;
  padding:0;
}
.tabbar-icon{width:24px;height:24px;object-fit:contain;}
.tabbar-item .active-icon{display:none;}
.tabbar-item .inactive-icon{display:block;}
.tabbar-item.active .active-icon{display:block;}
.tabbar-item.active .inactive-icon{display:none;}
.tabbar-label{font-size:10px;color:#bbb;margin-top:3px;letter-spacing:.3px;}
.tabbar-item.active .tabbar-label{color:var(--primary);}

/* ===========================
   通用 导航栏
   =========================== */
.page-header-bar{
  height:calc(var(--nav-h) + var(--status-bar));
  padding-top:var(--status-bar);
  background:#fff;
  display:flex;align-items:center;justify-content:center;
  border-bottom:0.5px solid var(--border);
  flex-shrink:0;
}
.page-header-title{font-size:17px;font-weight:600;color:var(--text-main);}

/* ===========================
   首页（行程）
   =========================== */
#tab-home{background:#f4f4f4;}

/* --- 背景 --- */
.home-header{position:relative;width:100%;height:280px;overflow:hidden;flex-shrink:0;}
.home-bg{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;}
.home-bg-gradient{
  position:absolute;left:0;right:0;bottom:0;height:60%;
  background:linear-gradient(to bottom, rgba(244,244,244,0) 0%, #f4f4f4 100%);
  z-index:1;
}

/* --- 顶部导航栏（固定在顶部） --- */
.home-nav-bar{
  position:absolute;top:0;left:0;right:0;z-index:3;
  display:flex;align-items:center;justify-content:space-between;
  padding:calc(var(--status-bar) + 4px) 16px 8px;
}
.home-nav-left,.home-nav-right{width:36px;height:36px;display:flex;align-items:center;justify-content:center;cursor:pointer;border-radius:50%;transition:background .2s;}
.home-nav-left:active,.home-nav-right:active{background:rgba(255,255,255,.2);}
.home-nav-title{color:#fff;font-size:17px;font-weight:600;text-shadow:0 1px 3px rgba(0,0,0,.3);}

/* --- 日期+天气+定位（整体下移，与导航栏不重叠） --- */
.home-header-content{
  position:absolute;left:0;right:0;top:130px;z-index:2;
  padding:0 20px;
  display:flex;flex-direction:column;gap:4px;
}
.home-quote-mark{
  color:rgba(255,255,255,.85);font-size:48px;font-weight:700;line-height:1;
  font-family:Georgia,serif;text-shadow:0 2px 8px rgba(0,0,0,.3);margin-bottom:-6px;
}
.home-date-big{display:flex;align-items:baseline;gap:6px;}
.date-day{color:#fff;font-size:42px;font-weight:700;line-height:1;text-shadow:0 2px 6px rgba(0,0,0,.3);}
.date-sub{display:flex;align-items:baseline;gap:3px;}
.date-sub span{color:rgba(255,255,255,.85);font-size:13px;}
.date-slash{color:rgba(255,255,255,.5)!important;font-size:12px!important;}
.home-divider-row{display:flex;align-items:center;gap:10px;margin:2px 0;}
.home-divider-line{flex:1;height:1px;background:rgba(255,255,255,.3);}
.home-location{display:flex;align-items:center;gap:3px;cursor:pointer;flex-shrink:0;}
.home-location:active{opacity:.7;}
.location-name{color:rgba(255,255,255,.85);font-size:13px;}
.home-weather-row{display:flex;align-items:center;gap:6px;}
.weather-icon{width:18px;height:18px;object-fit:contain;}
.home-weather-row span{color:rgba(255,255,255,.9);font-size:14px;}

/* --- 行程卡片（无行程时全屏图片） --- */
.home-body{padding:12px 5%;}
.home-trip-card{width:100%;border-radius:10px;overflow:hidden;background:#fff;display:flex;align-items:center;justify-content:center;min-height:207px;}
/* 飞机图片缩小版 - 如需回滚，恢复为 width:90% */
.trip-card-img{width:55%;display:block;max-width:280px;}

/* 行程卡片 */
.trip-card{background:#fff;border-radius:10px;margin-bottom:10px;overflow:hidden;box-shadow:0 1px 4px rgba(0,0,0,.06);}
.trip-card-header{background:var(--primary-light);padding:10px 14px;display:flex;align-items:center;justify-content:space-between;}
.trip-card-title{font-size:14px;font-weight:600;color:var(--primary);}
.trip-card-status{font-size:12px;color:var(--primary);}
.trip-card-body{padding:12px 14px;}
.trip-card-row{display:flex;justify-content:space-between;font-size:13px;color:var(--text-sub);margin-bottom:6px;}

/* ===========================
   日历
   =========================== */
#tab-calendar{background:#f4f4f4;}
.calendar-wrap{padding:12px;}
.cal-nav{display:flex;align-items:center;justify-content:space-between;background:#fff;border-radius:10px;padding:12px 16px;margin-bottom:10px;}
.cal-arrow{width:22px;height:22px;object-fit:contain;cursor:pointer;}
.cal-month-title{font-size:16px;font-weight:600;color:var(--text-main);}
.cal-week-header{display:grid;grid-template-columns:repeat(7,1fr);background:#fff;border-radius:10px 10px 0 0;overflow:hidden;margin-bottom:2px;}
.cal-week-header span{text-align:center;padding:8px 0;font-size:12px;color:var(--text-sub);}
.cal-week-header span:first-child{color:#f55;}
.cal-week-header span:last-child{color:#55f;}
.cal-grid{display:grid;grid-template-columns:repeat(7,1fr);background:#fff;border-radius:0 0 10px 10px;overflow:hidden;margin-bottom:10px;}
.cal-cell{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:8px 4px;min-height:44px;cursor:pointer;position:relative;}
.cal-cell.today .cal-day{background:var(--primary);color:#fff;width:28px;height:28px;border-radius:50%;display:flex;align-items:center;justify-content:center;}
.cal-cell.other-month .cal-day{color:#ccc;}
.cal-day{font-size:14px;color:var(--text-main);}
.cal-dot{width:6px;height:6px;border-radius:50%;margin-top:2px;}
.cal-dot.free{background:var(--primary);}
.cal-dot.busy{background:#f90;}
.cal-dot.rest{background:#999;}
.cal-legend{display:flex;gap:16px;justify-content:center;background:#fff;border-radius:10px;padding:10px;margin-bottom:10px;}
.cal-legend-item{display:flex;align-items:center;gap:4px;font-size:12px;color:var(--text-sub);}
.legend-dot{width:8px;height:8px;border-radius:50%;display:inline-block;}
.legend-free{background:var(--primary);}
.legend-busy{background:#f90;}
.legend-rest{background:#999;}
.cal-career-card{display:flex;align-items:center;background:#fff;border-radius:10px;padding:14px 16px;gap:12px;cursor:pointer;}
.cal-career-icon{width:32px;height:32px;object-fit:contain;}
.cal-career-text{flex:1;}
.cal-career-title{font-size:15px;font-weight:600;color:var(--text-main);}
.cal-career-sub{font-size:12px;color:var(--text-light);margin-top:2px;}
.cal-career-arrow{width:16px;height:16px;object-fit:contain;}

/* ===========================
   群发消息
   =========================== */
#tab-infos{background:#f4f4f4;}
.infos-wrap{padding:12px;}
.infos-section{background:#fff;border-radius:10px;padding:14px 16px;margin-bottom:10px;}
.infos-label{font-size:14px;font-weight:600;color:var(--text-main);margin-bottom:8px;}
.infos-receivers{display:flex;flex-wrap:wrap;gap:8px;}
.infos-add-btn{display:flex;align-items:center;gap:4px;border:1.5px dashed var(--border);border-radius:20px;padding:6px 14px;font-size:13px;color:var(--text-sub);cursor:pointer;}
.infos-add-icon{width:16px;height:16px;}
.infos-textarea{width:100%;min-height:100px;border:none;outline:none;font-size:14px;color:var(--text-main);resize:none;background:transparent;font-family:inherit;}
.infos-textarea::placeholder{color:var(--text-light);}
.infos-char-count{text-align:right;font-size:12px;color:var(--text-light);margin-top:4px;}
.infos-template-btn{display:flex;align-items:center;background:#fff;border-radius:10px;padding:14px 16px;gap:10px;cursor:pointer;margin-bottom:10px;}
.infos-tpl-icon{width:22px;height:22px;object-fit:contain;}
.infos-template-btn span{flex:1;font-size:14px;color:var(--text-main);}
.infos-tpl-arrow{width:16px;height:16px;object-fit:contain;}
.infos-tips{background:#fff8e7;border-radius:10px;padding:14px 16px;margin-bottom:20px;}
.infos-tips-title{display:flex;align-items:center;gap:6px;font-size:14px;font-weight:600;color:#f90;margin-bottom:8px;}
.tips-dot{width:16px;height:16px;object-fit:contain;}
.infos-tips-content{font-size:13px;color:#a07020;line-height:1.6;}
.infos-send-btn{width:100%;height:48px;background:var(--primary);color:#fff;border:none;border-radius:24px;font-size:16px;font-weight:600;cursor:pointer;letter-spacing:2px;}

/* ===========================
   我的页面 — 严格对照原版 APK 截图
   =========================== */

/* 页面整体背景：浅绿，header 之外区域用此色 */
#tab-mine{background:#f0f5f0;}
.mine-pull-wrapper{position:relative;overflow:hidden;}

/* ---- 顶部绿色 header ---- */
.mine-header{position:relative;overflow:hidden;
  /* 原版：较深绿渐变 */
  background:linear-gradient(160deg,#2db87c 0%,#1a9a5c 100%);
  flex-shrink:0;
}
.mine-header::after{content:'';position:absolute;inset:0;background:rgba(255,255,255,.12);filter:url(#tex-fine);pointer-events:none;z-index:0;}
.mine-header-bg,.mine-header-content{z-index:1;position:relative;}
.mine-header-bg{
  position:absolute;inset:0;
  width:100%;height:100%;
  object-fit:cover;
  opacity:0.35;
}
.mine-header-content{
  position:relative;
  padding:calc(var(--status-bar) + 16px) 16px 0;
}

/* 头像行 */
.mine-avatar-row{
  display:flex;
  align-items:center;
  gap:14px;
  position:relative;
  padding-bottom:16px;
}
.mine-avatar-wrap{
  width:62px;height:62px;
  border-radius:50%;
  overflow:hidden;
  flex-shrink:0;
}
.mine-avatar{width:100%;height:100%;object-fit:cover;}
.mine-user-info{flex:1;}
.mine-username{font-size:19px;font-weight:700;color:#fff;margin-bottom:4px;}
.mine-phone{font-size:13px;color:rgba(255,255,255,.85);}
/* 证号行隐藏 */
.mine-cert-row{display:none;}

/* 右侧星星：与头像行右端对齐，与姓名/手机号垂直居中 */
.mine-stars-top{
  display:flex;
  flex-direction:row;
  gap:3px;
  align-items:center;
  flex-shrink:0;
  margin-left:4px;
}
.mine-star{width:18px;height:18px;object-fit:contain;}

/* ---- 导游等级黑卡 ---- */
/* 黑卡紧接头像行，位于 header 底部 */
.mine-vip-card{
  position:relative;
  height:56px;
  border-radius:10px 10px 0 0;
  overflow:hidden;
  cursor:pointer;
  /* 纯黑色背景 + 水纹纹理，与参考图一致 */
  background:#111;
  position:relative;
}
.mine-vip-card::after{
  content:'';position:absolute;inset:0;
  background:rgba(255,255,255,.03);
  filter:url(#tex-water);
  pointer-events:none;z-index:0;
}
.mine-vip-bg{display:none;}
.mine-vip-inner{
  position:relative;
  display:flex;
  align-items:center;
  padding:0 16px;
  height:100%;
}
.mine-vip-left{display:flex;align-items:center;gap:8px;flex:1;}
/* 等级 icon：金黄色调 */
.mine-vip-icon{
  width:20px;height:20px;
  object-fit:contain;
  filter:brightness(3) sepia(1) saturate(3) hue-rotate(10deg);
  flex-shrink:0;
}
.mine-vip-info{color:#fff;}
.mine-vip-level{font-size:14px;font-weight:700;color:#e8c56a;letter-spacing:.5px;}
.vip-level-sub{font-size:11px;font-weight:400;color:rgba(232,197,106,.65);margin-left:2px;}
.mine-vip-right{
  display:flex;align-items:center;gap:4px;
  flex-shrink:0;
}
.vip-right-text{
  font-size:12px;
  color:#e8c56a;
  letter-spacing:.3px;
}
.vip-right-arrow{
  font-size:16px;
  color:#e8c56a;
  line-height:1;
}

/* ---- 白色主体卡片：紧接黑卡，无缝衔接，无深绿空白 ---- */
.mine-body-card{
  background:#fff;
  /* 上方圆角：左右各10px，与黑卡底部圆角一致 */
  border-radius:0;
  margin-top:0;
  overflow:hidden;
  padding-bottom:16px;
}

/* 4格快捷入口 */
.mine-quick-grid{
  display:grid;
  grid-template-columns:repeat(4,1fr);
  padding:16px 0 12px;
  background:#fff;
  border-radius:16px 16px 0 0;
  margin-top:0;
}
.mine-quick-item{
  display:flex;flex-direction:column;align-items:center;
  padding:4px 4px 8px;
  background:transparent;cursor:pointer;gap:8px;
}
.mine-quick-item:active{opacity:.7;}
.mine-quick-icon{width:44px;height:44px;object-fit:contain;}
.mine-quick-item span{font-size:12px;color:var(--text-sub);text-align:center;}

/* 分隔线：灰色粗线，原版风格 */
.mine-section-divider{height:8px;background:#f4f4f4;}

/* 菜单列表 */
.mine-menu-list{background:#fff;}
.mine-menu-item{
  display:flex;align-items:center;justify-content:space-between;
  background:#fff;
  padding:14px 16px;
  border-bottom:0.5px solid #f0f0f0;
  cursor:pointer;
  -webkit-user-select:none;user-select:none;
}
.mine-menu-item:last-child{border-bottom:none;}
.mine-menu-item:active{background:#f7f7f7;}
.mine-menu-left{display:flex;align-items:center;gap:12px;}
.mine-menu-icon{width:22px;height:22px;object-fit:contain;flex-shrink:0;}
/* SVG 图标容器 —— 橙色主调，与参考图一致 */
.mine-menu-svg-icon{
  width:22px;height:22px;
  display:flex;align-items:center;justify-content:center;
  flex-shrink:0;
}
.mine-menu-svg-icon svg{width:22px;height:22px;}
.mine-menu-svg-icon.orange{color:#e07850;}
.mine-menu-left span{font-size:15px;color:var(--text-main);}
.mine-menu-arrow{width:15px;height:15px;object-fit:contain;opacity:.3;}

/* 退出登录菜单项：文字橙红色 */
.mine-menu-item.logout-item .mine-menu-left span{color:var(--text-main);}

/* 底部按钮区 */
.mine-action-wrap{padding:20px 16px 8px;}
/* 注销按钮：红色实心大按钮，与参考图完全一致 */
.mine-cancel-btn{
  width:100%;height:50px;
  background:#e85c4a;
  color:#fff;
  border:none;
  border-radius:25px;
  font-size:17px;
  font-weight:600;
  cursor:pointer;
  letter-spacing:2px;
  display:flex;align-items:center;justify-content:center;
  transition:background 0.2s;
}
.mine-cancel-btn:active{background:#c84535;}

/* ===========================
   子页面通用
   =========================== */
#sub-pages{position:fixed;inset:0;pointer-events:none;z-index:100;}
.sub-page{
  position:absolute;inset:0;
  background:#f4f4f4;
  overflow-y:auto;
  -webkit-overflow-scrolling:touch;
  pointer-events:auto;
  transform:translateX(100%);
  transition:transform .3s cubic-bezier(.25,.46,.45,.94);
}
/* 导游证专属：需要 flex 列撑满让底部绿条紧贴 */
#sub-passport{display:flex;flex-direction:column;overflow-y:auto;}
.sub-page.slide-in{transform:translateX(0);}

.sub-nav-bar{
  position:sticky;top:0;z-index:10;
  display:flex;align-items:center;
  background:#fff;
  height:calc(var(--nav-h) + var(--status-bar));
  padding-top:var(--status-bar);
  padding-left:16px;padding-right:16px;
  border-bottom:0.5px solid var(--border);
  flex-shrink:0;
}
.sub-back-btn{width:24px;height:24px;object-fit:contain;cursor:pointer;margin-right:8px;}
.sub-nav-title{flex:1;text-align:center;font-size:17px;font-weight:600;color:var(--text-main);margin-right:32px;}
.pp-app-badge{font-size:12px;color:#62b1ac;font-weight:600;white-space:nowrap;letter-spacing:1px;}

/* ===========================
   导游证页面（像素级还原版 v3）
   =========================== */
#sub-passport{display:flex;flex-direction:column;overflow-y:auto;}
.sub-page.slide-in{transform:translateX(0);}

.sub-nav-bar{
  position:sticky;top:0;z-index:10;
  display:flex;align-items:center;
  background:#fff;
  height:calc(var(--nav-h) + var(--status-bar));
  padding-top:var(--status-bar);
  padding-left:16px;padding-right:16px;
  border-bottom:0.5px solid var(--border);
  flex-shrink:0;
}
.sub-back-btn{width:24px;height:24px;object-fit:contain;cursor:pointer;margin-right:8px;}
.sub-nav-title{flex:1;text-align:center;font-size:17px;font-weight:600;color:var(--text-main);margin-right:32px;}

/* ===========================
   导游证页面
   =========================== */
/* 整页白底纵向，flex撑满 */
.pp-page{
  background:#fff;
  flex:1;
  min-height:0;
  display:flex;
  flex-direction:column;
  position:relative;
}

/* 右上角 APP 开启标记：小旗子 + 文字，与参考图一致 */
.pp-app-badge{
  position:absolute;top:14px;right:16px;
  font-size:12px;color:#62b1ac;z-index:2;
  display:flex;align-items:center;gap:3px;
  font-weight:500;letter-spacing:.3px;
}
.pp-flag-icon{width:14px;height:14px;flex-shrink:0;}

/* ① 顶部等级横条 */
.pp-level-bar{display:flex;align-items:center;justify-content:center;gap:10px;padding:24px 28px 22px;background:#fff;}
.pp-level-line{flex:1;height:10px;background:#99bc80;border-radius:1px;}
.pp-level-text{font-size:28px;font-weight:700;color:#99bc80;letter-spacing:6px;white-space:nowrap;}

/* ② 绿色照片区：无阴影，与参考图一致 */
.pp-photo-section{background:#99bc80;display:flex;flex-direction:column;align-items:center;padding:30px 0 28px;flex-shrink:0;}
/* 照片框：无阴影，纯白边框，position:relative供loading遮罩定位 */
.pp-big-photo-wrap{width:148px;height:196px;background:#fff;overflow:hidden;border:3px solid #fff;position:relative;}
.pp-big-photo{width:100%;height:100%;object-fit:cover;object-position:center top;}
/* 姓名：与参考图间距一致 */
.pp-name-cn{margin-top:18px;font-size:22px;font-weight:700;color:#fff;letter-spacing:10px;}
.pp-name-en{margin-top:4px;font-size:12px;color:rgba(255,255,255,.8);letter-spacing:3px;}

/* ③ 白色信息区 — flex:1 撑满，把底绿条推到底 */
.pp-info-section{flex:1;background:#fff;padding:0 0 8px;}
.pp-info-item{padding:18px 0 16px;text-align:center;}
.pp-info-label{font-size:13px;color:#99bc80;font-weight:500;margin-bottom:8px;letter-spacing:1px;}
.pp-info-value{font-size:16px;color:#333;font-weight:400;letter-spacing:.5px;}
.pp-info-divider{height:1px;background:#efefef;margin:0 32px;}

/* ④ 底部绿色落款 */
.pp-footer-bar{
  background:#99bc80;
  color:#fff;
  text-align:center;
  padding:16px 0;
  font-size:13px;
  letter-spacing:2px;
  flex-shrink:0;
}
/* 导游证底部图片 */
.pp-bottom-image{
  width:100%;
  flex-shrink:0;
}
.pp-bottom-image img{
  width:100%;
  display:block;
  /* iOS禁止所有触摸交互 */
  -webkit-touch-callout:none !important;
  -webkit-user-select:none !important;
  user-select:none !important;
  pointer-events:none;
  touch-action:none;
  -webkit-tap-highlight-color:transparent;
}

/* ⑤ 底部分享卡片区 */
.pp-share-section{
  background:#fff;
  display:flex;
  flex-direction:column;
  align-items:center;
  position:relative;
  overflow:hidden;
  flex-shrink:0;
}
/* 波浪纹理背景 */
.pp-share-waves{
  position:absolute;
  top:0;left:0;right:0;
  height:140px;
  z-index:0;
  pointer-events:none;
}
/* 标语 */
.pp-share-slogan{
  position:relative;
  z-index:1;
  text-align:center;
  padding:36px 20px 16px;
}
.pp-share-slogan-line{
  font-size:32px;
  font-weight:800;
  color:#222;
  letter-spacing:6px;
  line-height:1.4;
}
/* 机构信息 */
.pp-share-info{
  position:relative;
  z-index:1;
  width:100%;
  padding:12px 28px 20px;
}
.pp-share-info-row{
  display:flex;
  align-items:center;
  gap:12px;
  padding:6px 0;
}
.pp-share-info-label{
  font-size:14px;
  color:#666;
  font-weight:500;
  flex-shrink:0;
  min-width:56px;
}
.pp-share-info-value{
  font-size:14px;
  color:#333;
  font-weight:600;
}
/* 绿色底部：二维码区域 */
.pp-share-qr-area{
  width:100%;
  background:#99bc80;
  display:flex;
  flex-direction:column;
  align-items:center;
  padding:20px 0 24px;
  position:relative;
  z-index:1;
}
.pp-share-qr-wrap{
  background:#fff;
  border-radius:8px;
  padding:6px;
  box-shadow:0 2px 12px rgba(0,0,0,.12);
}
.pp-share-qr{
  width:120px;height:120px;
  background:#fff;
  border-radius:4px;
  display:flex;
  align-items:center;
  justify-content:center;
}
.pp-share-qr canvas{width:100%!important;height:100%!important;}
.pp-share-text{
  margin-top:12px;
  font-size:14px;
  color:#fff;
  letter-spacing:3px;
  font-weight:500;
}

/* ===========================
   电子证照
   =========================== */
.ecert-wrap{padding:16px;}
.ecert-card{background:linear-gradient(145deg,#1a9a5c,#0d7a45);border-radius:16px;padding:20px;color:#fff;}
.ecert-card-header{font-size:16px;font-weight:700;text-align:center;margin-bottom:18px;letter-spacing:1px;}
.ecert-card-body{display:flex;gap:16px;margin-bottom:20px;}
.ecert-photo-wrap{width:80px;height:100px;border:2px solid rgba(255,255,255,.5);border-radius:6px;overflow:hidden;background:rgba(255,255,255,.1);}
.ecert-photo{width:100%;height:100%;object-fit:cover;}
.ecert-info{flex:1;display:flex;flex-direction:column;justify-content:center;gap:8px;}
.ecert-name{font-size:20px;font-weight:700;}
.ecert-no{font-size:13px;color:rgba(255,255,255,.8);}
.ecert-level{font-size:13px;background:rgba(255,255,255,.2);display:inline-block;padding:3px 10px;border-radius:12px;}
.ecert-qr-area{display:flex;flex-direction:column;align-items:center;gap:6px;margin-bottom:16px;}
.ecert-qr{width:80px;height:80px;background:#fff;border-radius:4px;display:flex;align-items:center;justify-content:center;}
.ecert-qr-tip{font-size:11px;color:rgba(255,255,255,.7);}
.ecert-footer{text-align:center;font-size:12px;color:rgba(255,255,255,.7);}
.ecert-change-photo-btn{width:100%;margin-top:16px;padding:14px 20px;background:rgba(255,255,255,.25);color:#fff;border:2px solid rgba(255,255,255,.7);border-radius:10px;font-size:15px;font-weight:700;display:flex;align-items:center;justify-content:center;gap:8px;cursor:pointer;transition:all .2s;-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px);position:relative;z-index:10;box-shadow:0 2px 12px rgba(0,0,0,.15);}
.ecert-change-photo-btn:active{background:rgba(255,255,255,.35);transform:scale(.97);}
.ecert-change-photo-btn svg{flex-shrink:0;}
.ecert-restore-photo-btn{width:100%;margin-top:10px;padding:12px 20px;background:rgba(255,100,100,.2);color:#ffcccc;border:2px solid rgba(255,150,150,.5);border-radius:10px;font-size:14px;font-weight:600;display:flex;align-items:center;justify-content:center;gap:8px;cursor:pointer;transition:all .2s;position:relative;z-index:10;}
.ecert-restore-photo-btn:active{background:rgba(255,100,100,.35);transform:scale(.97);}
.ecert-restore-photo-btn svg{flex-shrink:0;}

/* ===========================
   基本资料（可编辑）
   =========================== */

.info-wrap{padding:0 0 20px;}
.info-avatar-section{
  background:var(--primary);
  padding:30px 0 24px;
  display:flex;
  flex-direction:column;
  align-items:center;
  gap:10px;
}
.info-big-avatar{width:80px;height:80px;border-radius:50%;object-fit:cover;}
.info-avatar-wrap{position:relative;}
.info-picker-btn{
  flex:1;text-align:right;padding:8px 4px;font-size:15px;color:#333;
  cursor:pointer;background:transparent;border:none;outline:none;
}
.info-picker-btn::after{content:' ›';font-size:14px;color:#ccc;margin-left:2px;}
.info-row.editable .info-picker-btn{
  background:#f0f7f3;padding:7px 8px;border-radius:6px;border:1px solid #c8e6d5;
}
.info-row.editable .info-picker-btn::after{color:#1a9a5c;}

/* ===== 滚动选择器 ===== */
.scroll-picker-overlay{
  position:fixed;inset:0;background:rgba(0,0,0,.5);z-index:99999;
  display:flex;align-items:flex-end;justify-content:center;
}
.sp-inner{
  background:#fff;border-radius:16px 16px 0 0;width:100%;max-width:500px;
  padding:20px 0 env(safe-area-inset-bottom,20px);
}
.sp-title{text-align:center;font-size:16px;font-weight:600;padding:0 0 16px;color:#333;}
.sp-wheel{
  display:flex;justify-content:center;align-items:center;
  height:200px;position:relative;
}
.sp-wheel::before,.sp-wheel::after{
  content:'';position:absolute;left:0;right:0;height:40px;pointer-events:none;z-index:1;
}
.sp-wheel::before{top:0;background:linear-gradient(to bottom,rgba(255,255,255,.8),transparent);}
.sp-wheel::after{bottom:0;background:linear-gradient(to top,rgba(255,255,255,.8),transparent);}
.sp-scroll-area{height:100%;overflow-y:auto;width:100%;scroll-behavior:smooth;-webkit-overflow-scrolling:touch;}
.sp-item{
  height:40px;line-height:40px;text-align:center;font-size:18px;color:#333;cursor:pointer;
  transition:color .15s;
}
.sp-item.selected{color:#1a9a5c;font-weight:600;font-size:20px;}
.sp-btns{display:flex;border-top:1px solid #eee;margin-top:8px;}
.sp-cancel,.sp-ok{flex:1;height:48px;border:none;font-size:16px;cursor:pointer;background:transparent;}
.sp-cancel{color:#999;}
.sp-ok{color:#1a9a5c;font-weight:600;}

/* ===== 日期选择器 ===== */
.dp-wheels{display:flex;}
.dp-col{flex:1;height:200px;overflow:hidden;}
.dp-col .sp-wheel{height:200px;}
.dp-col .sp-item{font-size:15px;}

/* ===== 地区选择器 ===== */
.area-picker-overlay{
  position:fixed;inset:0;background:rgba(0,0,0,.5);z-index:99999;
  display:flex;align-items:flex-end;justify-content:center;
}
.ap-inner{
  background:#fff;border-radius:16px 16px 0 0;width:100%;max-width:500px;
  padding:20px 0 env(safe-area-inset-bottom,20px);
}
.ap-title{text-align:center;font-size:16px;font-weight:600;padding:0 0 12px;color:#333;}
.ap-tabs{display:flex;padding:0 20px;gap:20px;border-bottom:1px solid #eee;margin-bottom:12px;}
.ap-tab{font-size:14px;color:#999;padding-bottom:8px;cursor:pointer;}
.ap-tab.active{color:#1a9a5c;font-weight:600;border-bottom:2px solid #1a9a5c;}
.ap-content{padding:0 16px;max-height:260px;overflow-y:auto;}
.ap-list{display:none;}
.ap-list.active{display:block;}
.ap-item{
  height:44px;line-height:44px;font-size:15px;color:#333;padding:0 4px;
  cursor:pointer;border-radius:8px;transition:background .1s;
}
.ap-item:hover{background:#f0f7f3;}
.ap-item.selected{color:#1a9a5c;font-weight:600;background:#e8f7ef;}
.ap-btns{display:flex;border-top:1px solid #eee;margin-top:8px;}
.ap-cancel,.ap-ok{flex:1;height:48px;border:none;font-size:16px;cursor:pointer;background:transparent;}
.ap-cancel{color:#999;}
.ap-ok{color:#1a9a5c;font-weight:600;}
/* .info-edit-btn 样式在文件末尾统一定义 */
/* 编辑/保存浮动按钮 */
.info-save-bar{
  position:sticky;
  bottom:0;
  background:#fff;
  padding:10px 16px;
  border-top:1px solid var(--border);
  display:none;
}
.info-save-bar.show{display:block;}
.info-save-btn{
  width:100%;height:46px;
  background:var(--primary);color:#fff;border:none;
  border-radius:23px;font-size:16px;font-weight:600;cursor:pointer;
}

.info-list{background:#fff;margin:10px 0 0;}
.info-row{display:flex;align-items:center;justify-content:space-between;padding:14px 16px;border-bottom:0.5px solid var(--border);}
.info-row:last-child{border-bottom:none;}
.info-label{font-size:14px;color:var(--text-sub);flex-shrink:0;width:80px;}
.info-value{font-size:14px;color:var(--text-main);font-weight:500;flex:1;text-align:right;}
/* 可编辑 input 样式 */
.info-input{
  font-size:14px;color:var(--text-main);font-weight:500;
  text-align:right;border:none;outline:none;
  background:transparent;width:100%;
  font-family:inherit;
  /* 默认只读状态，不显示光标 */
  pointer-events:none;
}
.info-row.editable .info-input{
  pointer-events:auto;
  border-bottom:1px solid var(--primary);
  color:var(--primary);
}
.info-edit-indicator{
  width:16px;height:16px;
  margin-left:6px;
  object-fit:contain;
  opacity:0;
  flex-shrink:0;
  transition:opacity .2s;
}
.info-mode-edit .info-edit-indicator{opacity:.5;}

/* ===========================
   执业记录
   =========================== */
.occ-wrap{padding:12px;}
.occ-summary{display:flex;background:#fff;border-radius:10px;padding:16px;margin-bottom:12px;}
.occ-stat{flex:1;text-align:center;}
.occ-num{display:block;font-size:22px;font-weight:700;color:var(--primary);}
.occ-lbl{font-size:12px;color:var(--text-sub);}
.occ-list{display:flex;flex-direction:column;gap:8px;}
.occ-item{background:#fff;border-radius:10px;padding:14px 16px;}

/* ===========================
   奖惩记录
   =========================== */
.award-wrap{padding:0;}
.award-tabs{display:flex;background:#fff;border-bottom:1px solid var(--border);}
.award-tab{flex:1;text-align:center;padding:13px 0;font-size:14px;color:var(--text-sub);cursor:pointer;border-bottom:2px solid transparent;margin-bottom:-1px;}
.award-tab.active{color:var(--primary);border-bottom-color:var(--primary);font-weight:600;}
.award-list{padding:12px;}

/* ===========================
   游客评价
   =========================== */
.eval-wrap{padding:12px;}
.eval-score-card{background:#fff;border-radius:10px;padding:24px;display:flex;flex-direction:column;align-items:center;margin-bottom:12px;}
.eval-score-big{font-size:48px;font-weight:700;color:var(--primary);}
.eval-score-label{font-size:13px;color:var(--text-sub);margin-top:4px;}
.eval-stars{display:flex;gap:4px;margin-top:8px;}
.eval-star{font-size:20px;color:#f90;}
.eval-list{display:flex;flex-direction:column;gap:8px;}

/* ===========================
   执业信息（日历）
   =========================== */
.career-wrap{padding:12px;}
.career-card{background:#fff;border-radius:10px;overflow:hidden;}
.career-row{display:flex;align-items:center;justify-content:space-between;padding:14px 16px;border-bottom:0.5px solid var(--border);}
.career-row:last-child{border-bottom:none;}
.career-label{font-size:14px;color:var(--text-sub);}
.career-value{font-size:14px;color:var(--text-main);font-weight:500;}
.career-status-ok{color:var(--primary);}

/* ===========================
   在线培训
   =========================== */
.training-wrap{padding:12px;}
.training-banner{
  border-radius:12px;overflow:hidden;margin-bottom:12px;
  background:linear-gradient(135deg,#1a9a5c,#0d7a45);
  padding:24px 20px;color:#fff;
}
.training-banner-title{font-size:18px;font-weight:700;margin-bottom:6px;}
.training-banner-sub{font-size:13px;opacity:.8;}
.training-section-title{font-size:15px;font-weight:600;color:var(--text-main);padding:8px 0 10px;}
.training-list{display:flex;flex-direction:column;gap:8px;}
.training-item{
  background:#fff;border-radius:10px;padding:14px 16px;
  display:flex;align-items:center;gap:12px;cursor:pointer;
}
.training-item:active{background:#f5f5f5;}
.training-item-icon{
  width:44px;height:44px;border-radius:8px;overflow:hidden;
  background:var(--primary-light);
  display:flex;align-items:center;justify-content:center;
  font-size:20px;flex-shrink:0;
}
.training-item-info{flex:1;}
.training-item-title{font-size:14px;font-weight:600;color:var(--text-main);}
.training-item-meta{font-size:12px;color:var(--text-light);margin-top:3px;}
.training-item-badge{
  font-size:11px;background:var(--primary-light);color:var(--primary);
  padding:2px 8px;border-radius:10px;flex-shrink:0;
}

/* ===========================
   微信公众号 / 赞赏码
   =========================== */
.wechat-wrap{
  padding:16px;
  display:flex;flex-direction:column;align-items:center;
  gap:16px;
}
/* 顶部感谢横幅 */
.wechat-thanks-banner{
  width:100%;background:linear-gradient(135deg,#1a9a5c,#0d7a45);
  border-radius:16px;padding:24px 20px;
  display:flex;flex-direction:column;align-items:center;
  gap:6px;
}
.wechat-thanks-icon{font-size:36px;}
.wechat-thanks-text{font-size:20px;font-weight:700;color:#fff;letter-spacing:2px;}
.wechat-thanks-sub{font-size:13px;color:rgba(255,255,255,.8);}
/* 赞赏码卡片 */
.wechat-qr-card{
  background:#fff;border-radius:16px;padding:24px;
  display:flex;flex-direction:column;align-items:center;
  width:100%;
  box-shadow:0 2px 16px rgba(0,0,0,.08);
}
.wechat-logo{width:64px;height:64px;border-radius:16px;margin-bottom:12px;}
.wechat-name{font-size:18px;font-weight:700;color:var(--text-main);margin-bottom:4px;}
.wechat-desc{font-size:13px;color:var(--text-sub);margin-bottom:20px;text-align:center;}
/* 赞赏码图片框 */
.wechat-qr-box{
  width:310px;
  background:#f9f9f9;
  border-radius:12px;
  display:flex;
  align-items:center;
  justify-content:center;
  overflow:hidden;
  border:2px solid #f0f0f0;
  padding:20px;
}
.wechat-zanshang-img{
  width:100%;
  max-width:320px;
  height:auto;
  display:block;
  border-radius:10px;
}
/* 保存到相册按钮 - 大按钮样式 */
.wechat-save-btn{
  width:100%;
  margin-top:16px;
  padding:14px 20px;
  background:#1a9a5c;
  color:#fff;
  border:none;
  border-radius:10px;
  font-size:15px;
  font-weight:700;
  display:flex;
  align-items:center;
  justify-content:center;
  gap:8px;
  cursor:pointer;
  transition:all .2s;
  box-shadow:0 2px 12px rgba(26,154,92,.3);
}
.wechat-save-btn:active{
  background:#148a52;
  transform:scale(.97);
}
.wechat-save-btn svg{
  flex-shrink:0;
}
.wechat-qr-tip{
  font-size:12px;color:var(--text-light);margin-top:10px;
  text-align:center;
}
/* 底部感谢语 */
.wechat-footer-text{
  font-size:13px;color:#666;
  text-align:center;line-height:1.8;
  padding:4px 0 8px;
}
.wechat-follow-btn{
  width:100%;height:48px;
  background:#1a9a5c;color:#fff;border:none;
  border-radius:24px;font-size:16px;font-weight:600;cursor:pointer;
  display:flex;align-items:center;justify-content:center;gap:8px;
}

/* ===========================
   知识库
   =========================== */
.knowledge-wrap{padding:12px;}
.knowledge-search{
  display:flex;align-items:center;
  background:#fff;border-radius:22px;
  padding:10px 16px;gap:8px;margin-bottom:12px;
}
.knowledge-search-icon{font-size:16px;color:var(--text-light);}
.knowledge-search input{
  flex:1;border:none;outline:none;font-size:14px;
  color:var(--text-main);background:transparent;
}
.knowledge-tags{display:flex;flex-wrap:wrap;gap:8px;margin-bottom:12px;}
.knowledge-tag{
  background:#fff;border-radius:16px;
  padding:6px 14px;font-size:13px;
  color:var(--text-sub);cursor:pointer;
}
.knowledge-tag.active{background:var(--primary);color:#fff;}
.knowledge-list{display:flex;flex-direction:column;gap:8px;}
.knowledge-item{
  background:#fff;border-radius:10px;padding:14px 16px;cursor:pointer;
}
.knowledge-item:active{background:#f5f5f5;}
.knowledge-item-title{font-size:14px;font-weight:600;color:var(--text-main);margin-bottom:4px;}
.knowledge-item-meta{font-size:12px;color:var(--text-light);}
.knowledge-update-log{
  margin-top:8px;padding:8px 10px;
  background:#f8f9fa;border-radius:6px;
  font-size:12px;color:#555;line-height:1.8;
}

/* ===========================
   隐私政策
   =========================== */
.privacy-wrap{padding:16px;}
.privacy-title{font-size:18px;font-weight:700;color:var(--text-main);text-align:center;margin-bottom:6px;}
.privacy-date{font-size:13px;color:var(--text-light);text-align:center;margin-bottom:16px;}
.privacy-section{margin-bottom:16px;}
.privacy-section h3{font-size:15px;font-weight:600;color:var(--text-main);margin-bottom:8px;}
.privacy-section p{font-size:14px;color:var(--text-sub);line-height:1.7;}

/* ===========================
   设置
   =========================== */
.settings-wrap{padding:10px 0;}
.settings-list{background:#fff;}
.settings-item{
  display:flex;align-items:center;justify-content:space-between;
  padding:15px 16px;border-bottom:0.5px solid var(--border);cursor:pointer;
  transition:background 0.15s;
}
.settings-item:last-child{border-bottom:none;}
.settings-item:active{background:#f5f5f5;}
.settings-item span{font-size:15px;color:var(--text-main);}
.settings-arrow{width:16px;height:16px;object-fit:contain;}

/* ===== 账号设置 - 操作面板 ===== */
.settings-panel{
  margin:12px 0 0;background:#fff;border-radius:12px;
  padding:20px 16px;
  animation:fadeSlideDown 0.25s ease;
}
@keyframes fadeSlideDown{
  from{opacity:0;transform:translateY(-8px);}
  to{opacity:1;transform:translateY(0);}
}
.settings-panel-title{
  font-size:16px;font-weight:600;color:var(--text-main);
  margin-bottom:16px;padding-bottom:12px;
  border-bottom:1px solid var(--border);
}
.settings-field{margin-bottom:14px;}
.settings-field-label{
  display:block;font-size:13px;color:var(--text-sub);
  margin-bottom:6px;
}
.settings-input-wrap{
  display:flex;align-items:center;
  border:1px solid var(--border);border-radius:8px;
  background:#fafafa;overflow:hidden;
  transition:border-color 0.2s;
}
.settings-input-wrap:focus-within{border-color:var(--primary);}
.settings-input{
  flex:1;height:44px;padding:0 12px;
  font-size:15px;color:var(--text-main);
  background:transparent;border:none;outline:none;
  -webkit-appearance:none;
}
.settings-input::placeholder{color:#bbb;}
.settings-eye{
  padding:0 12px;font-size:18px;cursor:pointer;
  user-select:none;-webkit-user-select:none;
  color:var(--text-sub);flex-shrink:0;
}
/* 验证码行 */
.settings-sms-wrap{padding-right:0;}
.settings-sms-input{border-radius:8px 0 0 8px;}
.settings-sms-btn{
  flex-shrink:0;height:44px;padding:0 14px;
  background:var(--primary);color:#fff;
  border:none;font-size:13px;font-weight:500;cursor:pointer;
  white-space:nowrap;border-radius:0 8px 8px 0;
  transition:background 0.2s;
}
.settings-sms-btn:disabled{background:#aaa;cursor:not-allowed;}
.settings-sms-btn:active:not(:disabled){background:var(--primary-dark);}
/* 错误提示 */
.settings-tips{
  min-height:18px;font-size:12px;color:#e53935;
  margin-bottom:4px;padding:0 2px;
}
/* 提交按钮 */
.settings-submit-btn{
  display:block;width:100%;height:46px;margin-top:8px;
  background:var(--primary);color:#fff;border:none;
  border-radius:10px;font-size:16px;font-weight:600;
  cursor:pointer;letter-spacing:1px;
  transition:background 0.2s,transform 0.1s;
}
.settings-submit-btn:active{background:var(--primary-dark);transform:scale(0.98);}

/* ===== 基本资料 - 更换头像按钮（白色半透明，适配绿色背景） ===== */
.info-edit-btn{
  display:block;margin:2px auto 0;
  padding:7px 22px;
  background:rgba(255,255,255,0.22);
  color:#fff;
  border:none;
  border-radius:20px;
  font-size:13px;
  cursor:pointer;
  transition:background 0.18s;
  -webkit-backdrop-filter:blur(4px);
  backdrop-filter:blur(4px);
}
.info-edit-btn:active{background:rgba(255,255,255,0.38);}

/* 头像容器：固定尺寸，防止删除头像/隐藏图片时容器塌缩 */
.info-avatar-wrap{
  position:relative;
  width:80px;height:80px;
  flex-shrink:0;
}

/* 默认灰色头像 */
.info-default-avatar{
  width:80px;height:80px;border-radius:50%;
  /* border:3px solid rgba(255,255,255,.8); */
  overflow:hidden;position:absolute;inset:0;
  display:flex;align-items:center;justify-content:center;
  background:#e8e8e8;
}
.info-default-avatar svg{width:100%;height:100%;}

/* 删除头像按钮：覆盖在头像右上角 */
.info-delete-avatar{
  position:absolute;top:-4px;right:-4px;
  width:24px;height:24px;
  border-radius:50%;border:none;
  background:transparent;
  cursor:pointer;
  padding:0;
  display:flex;align-items:center;justify-content:center;
  -webkit-tap-highlight-color:transparent;
  z-index:2;
}
.info-delete-avatar svg{width:24px;height:24px;}

/* ===========================
   空状态
   =========================== */
.empty-tip{text-align:center;padding:48px 0;font-size:14px;color:var(--text-light);}

/* ===========================
   iOS 兼容性补丁 (iOS 14–26)
   =========================== */

/* iOS < 15 不支持 dvh，回退到 100vh */
@supports not (height: 100dvh) {
  #page-main{height:100vh;}
}

/* iOS 安全区兼容 — tabbar fixed定位覆盖home indicator区域 */
@supports (padding: max(0px)) {
  .tabbar{
    /* fixed定位 + 高度包含safe-area */
    height:calc(49px + max(env(safe-area-inset-bottom, 0px), 0px));
    padding-bottom: max(env(safe-area-inset-bottom, 0px), 0px);
  }
  /* 登录页底部安全区 */
  .login-wrap{
    padding-bottom: max(env(safe-area-inset-bottom, 20px), 20px);
  }
  /* 主界面内容区留出tabbar空间 */
  .page-content{
    padding-bottom: calc(49px + max(env(safe-area-inset-bottom, 0px), 0px));
  }
}

/* iOS standalone 模式终极修复 */
body.ios-standalone .tabbar {
  /* 强制延伸到屏幕最底部 */
  bottom: 0 !important;
  /* 增加高度确保覆盖 home indicator 区域 */
  height: calc(49px + 34px) !important;
  padding-bottom: 34px !important;
  background: #fff !important;
  /* 确保在遮罩层之上 */
  z-index: 100000 !important;
}

body.ios-standalone .page-content {
  /* 为增高的 tabbar 留出空间 */
  padding-bottom: calc(49px + 34px) !important;
}

/* 底部白色遮罩层 - 覆盖灰色区域 */
body.ios-standalone::after {
  content: '';
  position: fixed;
  left: 0;
  right: 0;
  bottom: 0;
  height: 40px;
  background: #fff;
  z-index: 99999;
  pointer-events: none;
}

/* Safari 中 position:sticky 在某些情况下失效 */
.sub-nav-bar{
  -webkit-position:sticky;
  position:sticky;
}

/* iOS WebKit 滚动惯性（iOS 14 需要） */
.sub-page,.tab-page{
  -webkit-overflow-scrolling:touch;
}

/* iOS 16+ backdrop-filter 支持 */
@supports (-webkit-backdrop-filter:blur(1px)){


}

/* 强制刷新按钮（清除缓存） */

/* ===========================
   下拉刷新指示器（TabBar 双击触发）
   =========================== */
#pull-refresh-indicator{
  position:fixed;top:0;left:0;right:0;z-index:999999;
  display:flex;align-items:center;justify-content:center;
  padding-top:calc(var(--status-bar, 20px) + 8px);
  background:transparent;
  pointer-events:none;
  /* 默认隐藏 */
  opacity:0;
  transform:translateY(-8px);
  transition:opacity 0.25s ease, transform 0.25s ease;
}
#pull-refresh-indicator.pri-show{
  opacity:1;
  transform:translateY(0);
}
.pri-inner{
  display:flex;flex-direction:column;align-items:center;gap:6px;
  background:rgba(0,0,0,.75);
  border-radius:16px;
  padding:14px 24px 12px;
  box-shadow:0 4px 20px rgba(0,0,0,.3);
}
.pri-spinner{width:36px;height:36px;}
.pri-spinner svg{width:36px;height:36px;}
.pri-text{font-size:14px;color:#fff;font-weight:500;letter-spacing:1px;}

/* ===========================
   二维码验真页面
   =========================== */
.verify-page{
  min-height:100vh;
  background:linear-gradient(180deg, #4A90E2 0%, #357ABD 50%, #2E6DA4 100%);
  position:relative;
  overflow:hidden;
  display:flex;
  flex-direction:column;
  align-items:center;
  padding:20px;
}

/* 蓝色渐变天空背景 */
.verify-sky-bg{
  position:absolute;
  inset:0;
  background:linear-gradient(180deg, #87CEEB 0%, #4A90E2 30%, #357ABD 70%, #2E6DA4 100%);
  z-index:0;
}

/* 白色卡片 */
.verify-card{
  position:relative;
  z-index:10;
  background:#fff;
  border-radius:20px;
  padding:24px;
  width:100%;
  max-width:340px;
  box-shadow:0 8px 32px rgba(0,0,0,0.2);
  margin-top:40px;
}

.verify-card-header{
  text-align:center;
  margin-bottom:20px;
}

.verify-title{
  font-size:20px;
  font-weight:700;
  color:#333;
  letter-spacing:1px;
}

.verify-subtitle{
  margin-top:6px;
  font-size:13px;
  color:#666;
}

.verify-card-body{
  display:flex;
  flex-direction:column;
  align-items:center;
}

/* 照片 */
.verify-photo-wrap{
  width:120px;
  height:160px;
  border-radius:8px;
  overflow:hidden;
  border:3px solid #f0f0f0;
  box-shadow:0 4px 12px rgba(0,0,0,0.1);
}

.verify-photo{
  width:100%;
  height:100%;
  object-fit:cover;
  object-position:center top;
}

/* 姓名 */
.verify-name{
  margin-top:16px;
  font-size:22px;
  font-weight:700;
  color:#333;
  letter-spacing:2px;
}

/* 纸飞机图标 */
.verify-paper-plane{
  width:48px;
  height:48px;
  margin:20px 0;
  opacity:0.9;
}

.verify-paper-plane svg{
  width:100%;
  height:100%;
}

/* 大二维码 */
.verify-qr-wrap{
  display:flex;
  flex-direction:column;
  align-items:center;
  margin-bottom:20px;
}

.verify-qr{
  width:180px;
  height:180px;
  background:#fff;
  border:3px solid #e0e0e0;
  border-radius:12px;
  display:flex;
  align-items:center;
  justify-content:center;
  overflow:hidden;
  box-shadow:0 4px 16px rgba(0,0,0,0.1);
}

.verify-qr-tip{
  margin-top:12px;
  font-size:13px;
  color:#666;
  text-align:center;
  line-height:1.6;
}

/* 证号信息 */
.verify-cert-info{
  width:100%;
  background:#f8f8f8;
  border-radius:12px;
  padding:16px;
}

.verify-cert-row{
  display:flex;
  justify-content:space-between;
  align-items:center;
  padding:8px 0;
}

.verify-cert-row:not(:last-child){
  border-bottom:1px solid #e0e0e0;
}

.verify-cert-label{
  font-size:13px;
  color:#888;
}

.verify-cert-value{
  font-size:14px;
  color:#333;
  font-weight:600;
}

/* 底部装饰：青山 + 树木 + 云朵 */
.verify-landscape{
  position:absolute;
  bottom:0;
  left:0;
  right:0;
  height:160px;
  pointer-events:none;
  z-index:1;
}

/* 云朵 */
.verify-cloud{
  position:absolute;
  opacity:0.7;
  animation:cloudFloat 20s ease-in-out infinite;
}

.cloud-1{
  top:20px;
  left:5%;
  width:100px;
  animation-delay:0s;
}

.cloud-2{
  top:40px;
  right:10%;
  width:80px;
  animation-delay:-10s;
}

@keyframes cloudFloat{
  0%, 100%{ transform:translateX(0); }
  50%{ transform:translateX(20px); }
}

/* 青山 */
.verify-mountains{
  position:absolute;
  bottom:0;
  left:0;
  right:0;
  height:120px;
}

.verify-mountains svg{
  width:100%;
  height:100%;
}

/* 树木 */
.verify-trees{
  position:absolute;
  bottom:0;
  left:0;
  right:0;
  height:80px;
}

.verify-trees svg{
  width:100%;
  height:100%;
}

