:root {
  --theme-color: #005095;
  --sub-theme-color: #79b251;
  --import-color: #aaa;
  --main-color: #aaa;
  --linearTheme: -webkit-gradient(linear, 0 0, 100% 0, color-stop(0, #015281), color-stop(.5, #005095), color-stop(1, #00557c));
}
html, body {overflow-x: hidden;width: 100%;height: 100%;}
html {font-size:16px;}
body {width: 100%;margin:0 auto;font-family:'Segoe UI', sans-serif;color: #333;max-width:800px;background: #f5f5f5;}
a {text-decoration: none;color:#333;}
img {
  border: 0 none;
  vertical-align: top;
  max-width: 100%;
}
.headimg-box {
 flex: 0 0 auto;
 background: var(--theme-color);
 position: relative;
}
.headimg img {
 width: 100%;
 cursor: pointer;
 display: block;
}

.headimg .overray {
  position: absolute;
  bottom: 0;
  width: 100%;
  height:auto;
  background-color: rgba(0, 0, 0, 0.5);
}

.headimg .overray .zi {
  padding:0.5rem;
  color: white;
  font-size: 1.2rem;
}

.hide {
 opacity: 0;
 user-select: none;
 pointer-events: none;
}
.job-guide-mask {
 position: fixed;
 top: 0;
 left: 0;
 width: 100%;
 height: 100%;
 background: rgba(0, 0, 0, 0.3);
 transition: all 0.3s ease-in-out;
 z-index: 8;
}
.job-guide-btns {
 position: fixed;
 right: 15px;
 bottom: 95px;
 z-index: 9;
}
.job-guide-btn {
 margin: 0 0 10px;
 text-align: center;
 box-shadow: 0 0 0 2px rgba(0, 0, 0, 0.3);
 background: rgba(0, 0, 0, 0.5);
 color: var(--guide-font-color, #fff);
 padding: 2px;
 border-radius: 100rem;
 overflow: hidden;
 display: flex;
 align-items: center;
 justify-content: center;
}
.job-guide-btn span {
 display: block;
 vertical-align: middle;
 font-size: 14px;
 padding: 5px;
 line-height: 1;
}
.switch-btn-box {
 margin-right: 15px;
}
.check-switch {
 position: relative;
 display: block;
}
.check-switch:after,.check-switch:before {
 position: absolute;
 top: 0;
 bottom: 0;
 z-index: 2;
 width: 50%;
 text-align: center;
 color: #777;
 font-size: 0.78em;
 transition: all 0.3s ease-in-out;
}
.check-switch:after {
 content: "EN";
 right: 0;
}
.check-switch:before {
 content: "中";
 margin-left: 2px;
}
.check-switch .status {
 display: block;
 border-radius: 500px;
 background: #eee;
 width: 3em;
 height: 1.5em;
 position: relative;
 transition: all 0.3s ease-in-out;
 box-sizing: content-box;
 padding: 2px;
}
.check-switch .status::after {
 content: "";
 width: 1.5em;
 height: 1.5em;
 background: var(--theme-color, #6baf70);
 color: #fff;
 border-radius: 500px;
 display: block;
 position: absolute;
 transition: all 0.3s ease-in-out;
 left: 0;
 margin: 0 2px;
}
.check-switch.cn:before {
 color: #fff;
 margin-left: 1px;
}
.check-switch.en .status:after {
 left: 50%;
}
.check-switch.en:after {
 color: #fff;
 margin-right: -1px;
}
.job-guide-lang {
 position: absolute;
 right: 0;
 top: 0;
 z-index: 9;
 margin: 1rem;
 font-size: 1.5rem;
}
.job-guide-lang .job-guide-btn {
 background: #fff;
 color: var(--theme-color, #000);
 box-shadow: 0 0 0 2px rgba(0, 0, 0, 0.05);
}
.job-guide-lang .job-guide-btn .i-lang-switch {
 font-size: 1.5rem;
 padding: 5px;
}
.job-guide-lang.avoid-bulletin {
 top: 3rem;
}


.share-section {width:100%;display:flex;position: sticky;z-index:5;top: 3rem;}
.btn-shared {margin:10px auto;font-size: 0.75rem;display: flex;align-items: center;border-radius: 0.5em;
justify-content: center;background: var(--theme-color);color: #fff;padding:.5rem;margin-right: 10px;}
.btn-shared i {padding-right: .2rem;}
.filter-section { 
  display: flex;
  position: sticky;
  padding:0;
  background: var(--linearTheme);
  top: 0;
  z-index: 1;
}

.filter-btn { 
  padding: 1rem 0; 
  background:transparent;
  font-size:0.83rem;
  flex: 1;
  color:white;
  text-align: center;
  position: relative;
  transition: all 0.3s;
}

.filter-btn.active {
  background: var(--sub-theme-color);
  color: white;
}

.filter-btn::after {
  content: "▼";
  margin-left: 0.3rem;
}

.filter-btn.active::after {
  content: "▲";
}
.filter-btn i {
  padding-right:.2rem;
}
.search-container {
  display: none;
  padding: 0.65rem 0;
  background: #f8f8f8;
  border-bottom: 1px solid #eee;
  position: absolute;
  width: 100%;
  margin-top:46px;
  text-align: center;
}

.search-container #keyword {
  width:96%;
  padding: 0.75rem 0.9375rem;
  border: 1px solid #ddd;
  border-radius: 1.5625rem;
  font-size: 0.875rem;
  box-sizing: border-box;
}


/* 遮罩层优化 */
.mask {
  position: fixed;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  background: rgba(0,0,0,0.5);
  display: none;
  z-index: 1000;
  overflow: hidden;
}

.mask-content {
  position: absolute;
  bottom: 0;
  left: 0;
  width: 100%;
  background: white;
  /*max-height: 80vh;*/
  height: 40%;
  display: flex;
  flex-direction: column;
}

.mask-header {
  padding: 0.9375rem 1.25rem;
  border-bottom: 1px solid #eee;
  display: flex;
  justify-content: space-between;
  align-items: center;
}

.mask-body {
  flex: 1;
  overflow-y: auto;
  -webkit-overflow-scrolling: touch;
  padding: 0 1rem;
  /* 隐藏滚动条 */
  scrollbar-width: none; /* Firefox */
}

/* 隐藏滚动条 */
.mask-body::-webkit-scrollbar {
  display: none; /* Chrome/Safari */
}


.filter-options {
  display: flex;
  flex-direction: column;
  /*gap: 0.9375rem;*/
  max-height:9rem;
  overflow-y: auto;
  -webkit-overflow-scrolling: touch; /* 优化移动端滚动体验 */
  /* 隐藏滚动条 */
  scrollbar-width: none; /* Firefox */
}

.filter-options::-webkit-scrollbar {
  display: none; /* Chrome/Safari */
}

.option-item {
  padding: 0.6rem 0;
  border-bottom: 1px solid #f0f0f0;
  cursor: pointer;
  font-size:.9rem;
  transition: all 0.2s;
  position: relative;
  text-align: center;
  min-height:2rem;
  line-height:2rem;
   /*display: flex; */
  align-items: center;
  justify-content: center;
}

.option-item.selected {
  color: #005095;
  font-weight: bold;
  background-color: #f8f9ff;
}

.option-item .clear-selection {
  position: absolute;
  right: 0.625rem;
  top: 50%;
  transform: translateY(-50%);
  font-size: 0.875rem;
  color: #999;
  display: none;
}

.option-item.selected .clear-selection {
  display: block;
}

.action-buttons {
  display: flex;
  gap: 0.9375rem;
  padding: 0.9375rem 1.25rem;
  /*border-top: 1px solid #eee;*/
  background: white;
}

.btn {
  flex: 1;
  padding: 0.875rem;
  border: none;
  border-radius: 0.5rem;
  cursor: pointer;
  font-size: 1rem;
  font-weight: 500;
}

.btn-confirm {
  background: #005095;
  color: white;
}

.btn-cancel {
  background: #f0f0f0;
  color: #333;
}
        /* 招聘列表 */
.job-list {
    padding: 1.25rem 0.9375rem;
}

.job-item {
    background: white;
    border-radius: 0.75rem;
    box-shadow: 0 0.25rem 0.75rem rgba(0,0,0,0.05);
    margin-bottom: 1.5625rem;
    overflow: hidden;
    transition: all 0.3s;
}

.job-item:hover {
    transform: translateY(-0.1875rem);
    box-shadow: 0 0 .4rem 0 rgba(0, 0, 0, 0.2);
}

.job-header {
    padding: .5rem;
    border-bottom: 0.0625rem solid #f1f1f1;
    cursor: pointer;
    position: relative;
}

/*.job-header::after {
    content: '';
    position: absolute;
    transform: translateY(-50%);
    width: 0.5rem;
    height: 0.5rem;
    border-right: 0.125rem solid #4a90e2;
    border-bottom: 0.125rem solid #4a90e2;
    transform: translateY(-50%) rotate(45deg);
    transition: all 0.3s;
    left: 45%;
}

.job-item.active .job-header::after {
    transform: translateY(-50%) rotate(225deg);
}*/

.more{width:100%;text-align:center;font-size:0.5rem;margin:0.5rem auto;}

.job-header h3 {
    margin: 0 0 0.375rem 0;
    font-size: 0.92rem;
    font-weight: normal;
}

.job-header h3 label {
    padding:0 0.3rem;
}

.job-header p {
    color: #666;
    font-size: 0.875rem;
}

.conta {display: flex;justify-content: space-between;width: 100%;}
.conta span:first-child {float: left;margin-left:.5rem;}
.conta span:last-child {float: right;margin-right:.5rem;}
.conta span i {padding-right:.4rem;color: var(--theme-color);}


.job-detail {
    display: none;
    padding: 1.25rem;
    background: #f9f9f9;
    border-top: 0.0625rem solid #eee;
    animation: fadeIn 0.4s ease;
}

.job-item.active .job-detail {
    display: block;
    background:#fff;
    text-align: center;
}

@keyframes fadeIn {
    from { 
        opacity: 0; 
        transform: translateY(0.625rem); 
    }
    to { 
        opacity: 1; 
        transform: translateY(0); 
    }
}

.job-detail iframe {
  width: 100%;
  min-height: 300px;
  border: none;
}

.button-container {
    display: flex;
    gap: 0.9375rem;
    margin-top: 1.25rem;
}

.recommend-btn, .apply-btn {
    flex: 1;
    padding: 0.5rem;
    border: none;
    font-size:0.82rem;
    cursor: pointer;
    transition: all 0.3s;
}

.recommend-btn {
    background: #f1f1f1;
    color: #333;
}

.recommend-btn:hover {
    background: #fff;
}

.apply-btn {
    background: #f1f1f1;
    color:#333;
}

.apply-btn:hover {
    background: #fff;
}

/* 响应式调整 */
@media (max-width: 480px) {
.filter-btn {flex: none;width:33.33%;}
.job-list {padding:.83rem;}
}

/* 加载/错误状态 */
.loading, .error, .no-result {
  padding: 1.25rem;
  text-align: center;
  color: #888;
  font-size: 1rem;
}

/* 滚动条优化 */
.mask-body::-webkit-scrollbar {
  width: 0.375rem;
}

.mask-body::-webkit-scrollbar-thumb {
  background-color: #c1c1c1;
  border-radius: 0.1875rem;
}

.mask-body::-webkit-scrollbar-track {
  background-color: #f1f1f1;
}

/* 清除选择按钮 */
.clear-selection-btn {
  padding: 0.5rem 0.625rem;
  background: #005095;
  border-radius: 0.375rem;
  cursor: pointer;
  color: #fff;
  font-size: 1rem;
  height: fit-content;
}

/********** 二维码 **********/
.job-guide-show-qr {
 position: fixed;
 z-index: 9;
 top: 0;
 left: 0;
 right: 0;
 bottom: 0;
 display: flex;
 align-items: center;
 justify-content: center;
 pointer-events: none;
}
.job-guide-show-qr .qr-box {
 pointer-events: initial;
 width: 55%;
}
.job-guide-show-qr.hide .qr-box {
 pointer-events: none;
}
.qr-close {
 display: block;
 width: 1em;
 height: 1em;
 line-height: 1;
 border-radius: 500px;
 font-size: 16px;
 padding: 8px;
 box-sizing: content-box;
 margin: 0 auto;
 color: var(--re-font-color, #fff);
 border: solid 1px #fff;
 margin-top: 15px;
}
.qr-notice {
 background: #fff;
 font-size: 3.75vw;
 color: #333;
 text-align: center;
 padding: 2px 0 4px;
}
.qr-notice .company {
 color: #006ea0;
 font-weight: bold;
}
.qr-unfollow-alert {
 flex-direction: column;
}
.qr-unfollow-alert .qr-box {
 width: 66.7%;
} /*********** 圆盘 ***********/
.job-guide-menus {
 width: 68vw;
 height: 68vw;
 left: 16%;
 bottom: 20%;
 background: rgba(0, 0, 0, 0.6);
 position: fixed;
 z-index: 9;
 border-radius: 50%;
 color: var(--guide-font-color, #fff);
 border: solid 3px rgba(225, 225, 225, 0.8);
 box-sizing: border-box;
}
.jg-menus-center {
 background: rgba(0, 0, 0, 0.5);
 position: absolute;
 width: 35%;
 height: 35%;
 border-radius: 50%;
 top: 50%;
 left: 50%;
 transform: translate(-50%, -50%);
 box-shadow: 0 0 0 5px rgba(255, 255, 255, 0.1);
 display: flex;
 display: -webkit-flex;
 align-items: center;
 justify-content: center;
 text-align: center;
 line-height: 120%;
}
.disks-box > *:not(.job-guide-mask) {
 animation: showMenu 0.5s ease-in-out;
} /* animates */
@keyframes showMenu {
 from {
  transform-origin: 50% 50%;
  transform: scale(0) translate3d(100%, 100%, 0);
 }
 to {
  transform-origin: 50% 50%;
  transform: scale(1) translate3d(0, 0, 0);
 }
}
.jg-mc-inner {
 max-width: 50%;
}
.jg-menu {
 display: flex;
 display: -webkit-flex;
 flex-direction: row-reverse;
 color: var(--re-font-color, #fff);
 text-align: center;
 position: absolute;
}
.jg-menu:nth-child(1) {
 top: 50%;
 left: 5%;
 transform: translateY(-50%);
}
.jg-menu:nth-child(2) {
 left: 50%;
 top: 5%;
 transform: translateX(-50%);
}
.jg-menu:nth-child(3) {
 right: 5%;
 top: 50%;
 transform: translateY(-50%);
}
.jg-menu:nth-child(4) {
 left: 50%;
 bottom: 5%;
 transform: translateX(-50%);
}
.jg-menu span {
 display: block;
}
.jg-menu .icons {
 font-size: 1.625rem;
}
.jg-menu a {
 color: var(--guide-font-color, #fff);
}
.jg-menu-name {
 font-size: 12px;
} 

/* 顶部公告栏样式 */
.notice-bar {
/*position: fixed; */
position:inherit;
top: 0;
left: 0;
width: 100%;
height: 50px;
display: flex;
align-items: center;
padding: 0 10px;
}
        
/* 图标样式 */
.notice-icon {
color: white;
font-size:1.2rem;
margin-right:.8rem;
flex-shrink: 0;
padding: 4px 8px;
border-radius: 50%;
background-color: var(--sub-theme-color);
}
        
/* 滚动区域容器 - 关键修复 */
.scroll-container {
position: relative;
height:2rem;
overflow: hidden;
flex-grow: 1;
margin-right:.8rem;
}
        
/* 滚动公告项 - 关键修复 */
.scroll-item {
position: absolute;
width: 100%;
height:2rem;
line-height:2rem;
color:#333;
font-size:.875rem;
white-space: nowrap;
text-overflow: ellipsis;
overflow: hidden;
opacity: 0;
animation: scroll 12s infinite;
}
        
/* 为每个滚动项添加延迟 - 关键修复 */
.scroll-item:nth-child(1) {
animation-delay: 0s;
}
.scroll-item:nth-child(2) {
animation-delay: 4s;
}
.scroll-item:nth-child(3) {
animation-delay: 8s;
}
        
/* 滚动动画 - 关键修复 */
@keyframes scroll {
0% {
transform: translateY(30px);
opacity: 0;
}
5% {
transform: translateY(0);
opacity: 1;
}
25% {
transform: translateY(0);
opacity: 1;
}
30% {
transform: translateY(-30px);
opacity: 0;
}
100% {
transform: translateY(-30px);
opacity: 0;
}
}
        
/* 信息总数样式 */
.info-count {
color: white;
font-size:0.95rem;
margin-right:.3rem;
background:#005095;
padding: 3px 10px;
border-radius: 50%;
}
        
/* 箭头按钮样式 */
.arrow-btn {
background: none;
border: none;
font-size: 1.2rem;
cursor: pointer;
padding:1rem;
transition: background 0.3s;
}
        
.arrow-btn:hover {
background: rgba(255,255,255,0.2);
}
        
/* 弹出层样式 */
.popup-layer {
position: fixed;
bottom: -100%;
left: 0;
width: 100%;
height:auto;
background: white;
transition: bottom 0.4s ease-in-out;
z-index: 2000;
}
        
.popup-layer.active {
bottom: 0;
}
        
/* 弹出层头部 */
.popup-header {
height:3.2rem;
border-bottom: 1px solid #eee;
display: flex;
justify-content: space-between;
align-items: center;
padding: 0 20px;
}
        
.popup-header h2 {
font-size:1.05rem;
color: #333;
font-weight: 500;
}
        
.close-btn {
background: none;
border: none;
font-size:1.8rem;
color: #999;
cursor: pointer;
}
        
/* 公告列表样式 */
.notice-list {
padding: 20px;
overflow-y: auto;
/*height: calc(80vh - 50px);*/
}
        
.notice-item {
padding: 10px 0;
border-bottom: 1px solid #f0f0f0;
display: flex;
align-items: center;
}
        
.notice-item .icon {
color: #2a7af3;
margin-right: 10px;
}
        
.notice-content {
flex-grow: 1;
}
        
.notice-title {
    display: -webkit-box;
    -webkit-box-orient: vertical;
    -webkit-line-clamp: 1; /* 限制显示一行 */
    overflow: hidden;
    text-overflow: ellipsis;
    font-size: .875rem;
}
        
.notice-date {
font-size: 12px;
color: #999;
}
        
/* 遮罩层 */
.overlay {
position: fixed;
top: 0;
left: 0;
width: 100%;
height: 100%;
background: rgba(0,0,0,0.5);
z-index: 1500;
opacity: 0;
visibility: hidden;
transition: opacity 0.3s;
}
        
.overlay.active {
opacity: 1;
visibility: visible;
}

/* 新增遮罩层样式 */
.mask-layer {
  position: fixed;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  background-color: rgba(0,0,0,0.5);
  display: none;
  justify-content: center;
  align-items: center;
  z-index: 1000;
}

.maskcontent {
  width: 90%;    
  background-color: white;
  padding:1.4rem;
  border-radius:0.5rem;
  text-align: center;
  word-break: break-word;
  max-width:80%;
}

.maskcontent img{
  width: 12rem;    
}


.mask-btn {
  margin-top:0.875rem;
  padding:0.5rem 1.4rem;
  background:#005095;
  color: white;
  border: none;
  border-radius:0.2rem;
  cursor: pointer;
}

 /* 提示消息弹层 */
.alert-wrap {
 position: fixed;
 min-height: 100vh;
 background: rgba(0, 0, 0, 0.7);
 width: 100vw;
 top: 0;
 left: 0;
 bottom: 0;
 right: 0;
 display: flex;
 display: -webkit-flex;
 align-items: center;
 justify-content: center;
 z-index: 9999;
}
.alert-wrap#alertClipDialog {
 z-index: 10000;
}
.alert-wrap .alert-title {
 font-size: 1rem;
 text-align: center;
}
.alert-content {
 width: 90%;
 border-radius: 8px;
 overflow: hidden;
 position: relative;
 background-color:#fff;
 color: var(--re-font-color, #fff);
 max-width: 32rem;
 top: 40%;
 margin: 0 auto;
}
.alert-content .btn {
 background-color: #fff;
 color: var(--theme-color, #f0f0f0);
}
.alert-logo {
 padding: 15px 0;
 text-align: center;
 background: #fff;
 justify-content: center;
 align-items: center;
}
.alert-logo img {
 max-width:32vw;
}
.alert-txt,
.alert-ctrls {
 padding: 2% 0;
 text-align: center;
 white-space: normal;
}
.alert-txt {
 padding: 1rem 1rem 0.5rem;
}
.alert-ctrls {
 display: flex;
 align-items: center;
 justify-content: center;
 padding-bottom: 1rem;
}
.alert-ctrls .check-modify {
 margin: 0 2px;
 color: var(--re-font-color, #fff);
}
.alert-ctrls .check-modify.radio {
 margin: 0 10px;
}
.alert-ctrls .check-modify .txt:before {
 border-color: inherit;
 color: inherit;
}
.alert-inner {
 padding: 15px;
 max-height: 80vh;
background-color: var(--theme-color, #f0f0f0);
}
.alert-close {
 position: absolute;
 right: 0;
 top: 0;
 margin: 10px;
 border-radius: 100px;
 color: #333;
 padding: 2px;
 width: 25px;
 height: 25px;
 font-size: 14px;
 text-align: center;
}