*{margin:0;padding:0;box-sizing:border-box;font-family:-apple-system,BlinkMacSystemFont,"Segoe UI",Roboto,Helvetica,Arial,sans-serif;-webkit-tap-highlight-color:transparent;-webkit-overflow-scrolling:touch}
html{background:#fad0d2; }
body{margin:0;background:#fad0d2;font-family:-apple-system,BlinkMacSystemFont,"PingFang SC",Arial,sans-serif;color:#333}

/* 允许元素延伸到安全区域之外（必要） */
body {
    /* 禁止整体页面滚动 */
  padding-top: env(safe-area-inset-top);
  padding-bottom: env(safe-area-inset-bottom);
  height: 100vh;
  overflow: hidden;
}

/* Vue 主容器 */
#app {


}
body.home-safe .app-main{
    top: 0vh;
   height:calc(100vh - 8vh);
}
body.home-safe .app-main .main-tab{
    padding-top: 1vh;
}
/* iPhone 刘海机型 */
body.ios-safe .app-main {

  height:calc(100vh - 13vh);
}
body.ios-safe .app-main .main-tab{
    padding-top: 5vh;
}

/* 华为 / 小米 / 安卓刘海屏 */
body.android-safe .app-main {
  top: 8.6vh;
  height:calc(100vh - 18vh);
}

.app-main{position:fixed;width:100%;  left: 0;
  right: 0;  overflow:hidden}

.text-red{color:#ff6b82}
.text-white{color:#fff}
.text-right{text-align:right}
.bg-red{background:#ff6b82}
.bg-white{background:#fff}
.text-bold{font-weight:bold}

/* 卡片列表布局 background: #ffffff;*/
.card-list {
  display: grid;
  grid-template-columns: 1fr 1fr 1fr 1fr;
  gap: 12px;
  margin: 10px;
  border-radius: 12px;
  padding:10px;
  overflow-y: auto;
  
  max-height: 92%;
  scroll-behavior: smooth;
}

/* 中屏（平板，≤ 980px）：2 列 */
@media (max-width: 980px) {
  .card-list {
    grid-template-columns: 1fr 1fr;
    gap: 12px;
  }
}

/* 小屏（手机，≤ 375px）：1 列 */
@media (max-width: 375px) {
  .card-list {
    grid-template-columns: 1fr;
    gap: 8px;
    padding: 8px;
  }
}

.gril-card{
  border-radius:16px;
  overflow:hidden;
  background:#fff;
  box-shadow:0 4px 12px rgba(0,0,0,0.08);
  transition:all 0.3s ease;
  position:relative;
  border:1px solid #f0f0f0;
}
.gril-card:hover{transform:translateY(-4px);box-shadow:0 8px 24px rgba(255,107,130,0.15)}
.gril-card img{width:100%;height:220px;object-fit:cover;display:block;transition:transform 0.3s ease}
.tag-favorite{position:absolute;top:10px;right:10px;width:40px;height:40px}
.tag-favorite i{display:block;border-radius:50%;width:30px;height:30px;border:1px solid #ff6b82;text-align:center;line-height:30px;font-size:16px;}
.tag-bg{width:100%;position:absolute;bottom:0px;left:0;background:linear-gradient(transparent, rgba(0,0,0,0.6));color:#fff;font-size:12px;padding:8px 4px;display:flex;justify-content:space-between;align-items:center;box-sizing:border-box}
.tag-bg i{color:#ffd1d3!important}
.tag-address{color:#fff;padding:4px 8px;border-radius:8px;background:rgba(255,107,130,0.8)}
.tag-date{color:#fff;padding:4px 8px;border-radius:8px;background:rgba(107,156,255,0.8)}
.gril-card .info{padding:12px}
.gril-card .info h3{margin:0;font-size:14px;font-weight:600;color:#333}
.gril-card .info p{margin:4px 0;font-size:12px;color:#666}
.gril-card .info-tag{display:flex;justify-content:space-between;font-size:11px;line-height:20px;background-color:#fad0d2;color:#666;border-radius:10px 0px 10px 0px;padding-right:5px;border:1px solid #e9ecef}
.gril-card .info-tag .info-tagl{display:flex;justify-content:space-between;font-size:11px;background:linear-gradient(45deg, #ff6b82, #ff6b82);min-width:50%;border-radius:10px 0px 0px 0px;padding:0px 5px;color:#fff}

.tags{display:flex;flex-wrap:wrap;gap:4px}
.tags .el-tag{font-size:10px;border-radius:8px;line-height:1.4;padding:0 6px;background:#fad0d2;border:1px solid #e9ecef;color:#666}
.gril-card .tag-group{text-align:center}
.gril-card .tag-group span{margin-top:2px}
.main-tab{ position:sticky; background:#ffffff; transition: all 0.3s ease; border-bottom:1px solid #f0f0f0;}
.el-tabs__header{border-bottom:none}
.main-tab .el-tabs__item{font-size:16px;color:#666!important}
.main-tab .el-tabs__item.is-active{font-weight:bold;color:#ff6b82!important}

.main-tab .el-tabs__active-bar{background-color:#ff6b82!important}
.main-tab .el-tabs__header{margin-bottom:2px}
.main-tab .el-tabs__nav-wrap::after{display:none!important}
.main-tab button{margin-top:0px}
.el-button--primary{border-radius:20px;padding:8px 20px;font-size:14px;background:linear-gradient(45deg,#ff6b82,#ff6b82);border:none;box-shadow:0 2px 8px rgba(255,107,130,0.3)}
.el-tag--dark.el-tag--danger{background:linear-gradient(90deg,#ff6b82,#ff6b82)!important;border-color:#ff6b82!important;border-radius:12px!important;padding:0px 8px; line-height:18px; font-size:12px;color:#fff!important}
marquee p{margin:0;line-height:24px;padding:0 10px}
.homenotice-container{height:72px;overflow:hidden;background:#fff3cd;color:#856404;font-size:12px;line-height:24px;padding-left:10px;border-radius:8px;border:1px solid #ffeaa7}
.homenotice-scroll{display:flex;flex-direction:column;animation:scrollUp linear infinite;padding:0px 10px}
.homenotice-scroll li{line-height:24px;list-style:none}
@keyframes scrollUp{0%{transform:translateY(0)}
100%{transform:translateY(-50%)}
}
.el-button--danger{color:#FFF;background-color:#ff6b82!important;border-color:#ff6b82!important}
.footer-nav{position:fixed;bottom:0;left:0;width:100%;display:flex;border-top:1px solid #e9ecef;background:#fff;box-shadow:0 -2px 12px rgba(0,0,0,0.06);opacity: 0;
  transform: translateY(30px);
  transition: all 0.6s ease-out;}
.footer-nav.show {
  opacity: 1;
  transform: translateY(0);
}
.footer-nav a{ position: relative;flex: 1;color: #666;    font-size: 18px;    transition: color .2s;    display: flex;    align-items: center;    padding: 10px 0px 30px;    touch-action: manipulation;    -webkit-tap-highlight-color: transparent;    flex-direction: column;   transition: all 0.3s; line-height:24px}
.footer-nav a:active {
  animation: shake 0.5s;
}

/* 抖动动画关键帧 */
@keyframes shake {
  0%, 100% { transform: translateX(0); }
  20% { transform: translateX(-3px); }
  40% { transform: translateX(3px); }
  60% { transform: translateX(-2px); }
  80% { transform: translateX(2px); }
}
.footer-nav a.active{color:#ff6b82}
.el-card{ border:1px solid #f0f0f0 !important; background-color:#fff !important; color:#333 !important;}
.footer-nav span{display:block;font-size:22px;margin-bottom:2px; color:#ff4e80; height:24px}
.el-dialog__header{text-align:center;font-weight:bold;font-size:16px;color:#333}
.el-slider__bar{background-color:#ff6b82!important}
.el-slider__button{border:2px solid #ff6b82!important}
.el-slider__stop{background-color:#ffd1d3!important}
.el-tag{background:#fad0d2;border:1px solid #e9ecef;cursor:pointer;transition:0.3s}
.el-tag:hover{background:#ffeef1;color:#ff6b82;border-color:#ff6b82}
.el-radio-button__inner{border-radius:20px!important;margin-right:6px;padding:6px 14px;background:#fad0d2;border:1px solid #e9ecef}
.gril-dialog .el-radio-button__orig-radio:checked+.el-radio-button__inner{background:linear-gradient(45deg, #ff6b82, #ff6b82);border-color:#ff6b82;color:#fff;box-shadow:none}
.gril-dialog .el-checkbox__input.is-checked .el-checkbox__inner{background-color:#ff6b82;border-color:#ff6b82}
.gril-dialog .el-checkbox__input.is-checked+.el-checkbox__label{color:#ff6b82}
.el-dialog__footer{text-align:center!important}
.gril-dialog .el-button--primary{background:linear-gradient(45deg, #ff6b82, #ff6b82);border-color:#ff6b82}
.gril-dialog .el-button--primary:hover{background:linear-gradient(45deg, #ff5a72, #ff8c5a);border-color:#ff5a72}
.user-header{background:linear-gradient(45deg,#6a11cb,#2575fc);display:flex;align-items:center;padding:20px;border-radius:0 0 20px 20px}
.user-info{display:flex;align-items:center}
.user-details{margin-left:15px;line-height:24px}
.user-details .username{font-weight:bold;font-size:18px;color:#fff}
.user-details .user-id{font-size:14px;color:rgba(255,255,255,0.8)}
.my-card{margin-bottom:20px;border-radius:16px!important;background: #fff !important;box-shadow:0 4px 12px rgba(0,0,0,0.08)!important;}
.my-card .card-title{font-weight:bold;margin-bottom:10px;font-size:14px;display:flex;justify-content:space-between;line-height:30px;color:#333}
.my-card .card-title .el-button--text{font-size:12px;color:#ff6b82}
.wallet{display:flex;justify-content:space-between;align-items:center}
.benefit-row{margin-top:10px}
.benefit-card{text-align:center;transition:transform 0.3s ease,box-shadow 0.3s ease;border-radius:12px!important}
.benefit-row .el-col:first-child .benefit-card .el-card__body{background:linear-gradient(135deg,#ffd1d3,#ffeef1)}
.benefit-row .el-col:nth-child(2) .benefit-card .el-card__body{background:linear-gradient(135deg,#d1e8ff,#eef7ff)}
.benefit-row .el-col:last-child .benefit-card .el-card__body{background:linear-gradient(135deg,#d1ffe8,#eefdf7)}
.benefit-card .el-card__body{padding:20px 5px;border-radius:12px}
.benefit-card .icon{font-size:20px;height:34px;transition:transform 0.3s ease;color:#ff6b82}
.benefit-card .text{margin:5px 0;font-weight:bold;font-size:12px;color:#333}
.benefit-card .subtext{font-size:12px;color:#666;line-height:22px}
.invite{display:flex;align-items:center;gap:5px}
.reward-info{margin-top:10px;font-size:12px;color:#666}
.nav-item{text-align:center;font-weight:bold}
.nav-item.active{color:#ff6b82}
.detail-header{position:absolute;align-items:center;padding:10px 16px;z-index:999;top:60px}
.detail-headerbtn{position:absolute;top:23vh;display:flex;justify-content:space-between;width:100%;padding:10px 16px;z-index:999}

.el-carousel__button{ height:6px !important;background:#ff6b82!important;}
.info-row{text-align:center}
.info-col .label{font-size:12px;color:#666;margin-bottom:4px}
.info-col .value{font-size:14px;font-weight:500;color:#333}
.introduction{font-size:14px;line-height:24px;padding:15px;border-top:1px solid #f0f0f0;margin-top:15px;background:#fad0d2;border-radius:12px}
.introduction button{color:#ff6b82}
.media-dialog{background-color:rgba(255,255,255,0.95)}
.media-dialog .el-dialog{background:transparent;width:100%;height:100%;margin:0;padding:0}
.media-dialog .el-dialog__header{display:none}
.media-dialog .el-carousel__arrow{background:rgba(255,107,130,0.9)}
.media-dialog .el-dialog__body{padding:0;height:100%;position:relative}
.carousel-header{position:absolute;top:10px;left:10px;right:10px;display:flex;justify-content:space-between;color:#333;z-index:10;font-size:18px}
.carousel-content{padding:15px}
.media-box{width:100%;height:100%;border-radius:16px;overflow:hidden;display:flex;align-items:center;justify-content:center;background:rgba(255,255,255,0.98)}
.carousel-item-content{width:100%;height:100%;object-fit:contain;display:block}
.close-btn{position:relative;background:#ff6b82!important;color:#fff!important;border-radius:50%!important;padding:10px!important;font-size:18px!important;cursor:pointer;box-shadow:0 4px 12px rgba(255,107,130,0.3)}
.close-btn::after{content:"";position:absolute;top:50%;left:50%;width:0;height:0;background:rgba(255,107,130,0.5);border-radius:50%;transform:translate(-50%,-50%);animation:explode 1.5s infinite;pointer-events:none}
@keyframes explode{0%{width:0;height:0;opacity:0.8}
70%{width:80px;height:80px;opacity:0}
100%{width:0;height:0;opacity:0}
}.custom-list{background-color:#fff}
.list-content .list-item{cursor:pointer;transition:background-color 0.2s; padding:15px 0px;line-height:20px;font-size:14px;border-bottom:1px solid #f0f0f0}
.list-content .list-item:hover{background:#fad0d2 }
.list-content .item-icon{color:#ff6b82;font-size:14px;text-align:center}
.list-content .item-arrow{font-size:12px;color:#999}
.list-content .list-content{font-size:14px;color:#666;padding:12px 0}
.page-header{font-size:13px;font-weight:bold;color:#333;padding:15px;background-color:#fff;border-bottom:1px solid #f0f0f0}
.page-header .el-page-header__content{font-size:15px}
.payment-container{max-width:500px;margin:0 auto;padding:20px;background-color:#fff;min-height:100vh}
.payment-info{background:linear-gradient(135deg,#e3f2fd,#f3e5f5);border-radius:12px;padding:20px;margin-bottom:20px;border-left:4px solid #ff6b82}
.payment-header{display:flex;align-items:center;margin-bottom:15px}
.payment-icon{width:40px;height:40px;background:linear-gradient(45deg,#ff6b82,#ff6b82);border-radius:50%;display:flex;align-items:center;justify-content:center;color:white;font-weight:bold;margin-right:10px}
.payment-title{font-size:16px;font-weight:bold;color:#333}
.countdown{font-size:12px;color:#666;margin-left:auto}
.protocol{font-size:12px;color:#666;margin-bottom:10px}
.address-container{background:#fad0d2;padding:15px;border-radius:8px;margin-bottom:15px;word-break:break-all;font-family:monospace;border:1px solid #e9ecef}
.address{font-size:14px;color:#333}
.btn-group{display:flex;gap:10px;margin-bottom:20px}
.btn-group .el-button{flex:1}
.qr-container{display:flex;flex-direction:column;align-items:center;background:#fad0d2;padding:20px;border-radius:12px;border:1px solid #e9ecef;margin-bottom:20px}
.qr-title{font-size:16px;font-weight:bold;margin-bottom:15px;color:#333}
.qr-code{width:200px;height:200px;background-color:#fff;padding:10px;border:1px solid #e9ecef;margin-bottom:10px;display:flex;align-items:center;justify-content:center;border-radius:8px}
.qr-code img{width:180px;height:180px}
.qr-note{font-size:12px;color:#666}
.notice-container{background:#fff3cd;border-radius:8px;padding:15px;border-left:4px solid #ffc107;border:1px solid #ffeaa7}
.notice-title{display:flex;align-items:center;font-size:14px;font-weight:bold;color:#856404;margin-bottom:10px}
.notice-list{list-style:none;padding:0;margin:0}
.notice-item{font-size:12px;color:#666;margin-bottom:8px;position:relative;padding-left:10px}
.payment-amount{font-size:14px;color:#333;margin-bottom:10px;font-weight:500}
.article-text h3,.article-text H3{background:linear-gradient(45deg,#ff6b82,#ff6b82);color:#fff;border-radius:12px;border:none;padding:12px 20px;text-align:center}
.article-text strong,.article-text h4,.article-text b{color:#ff6b82}
.video-mask{position:absolute;top:0;left:0;width:100%;height:100%;background:rgba(255,255,255,0.9);backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);display:flex;align-items:center;justify-content:center;cursor:pointer;border-radius:8px;color:#333;font-size:16px;border:2px dashed #ff6b82}
.video-mask i{color:#ff6b82;font-size:24px;margin-right:8px}
.media-wrapper{position:relative;width:100%;height:200px;overflow:hidden;border-radius:12px;background:#fad0d2}
.media-wrapper img,.media-wrapper video{width:100%;height:100%;object-fit:cover;display:block}
.video-wrapper{position:relative}
.video-overlay{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);font-size:24px;color:#ff6b82;background:rgba(255,255,255,0.9);border-radius:50%;padding:10px;pointer-events:none;box-shadow:0 4px 12px rgba(0,0,0,0.1)}
.gril-card{position:relative;overflow:hidden; cursor: pointer;transition: all 0.3s;}
.gril-card:active img,.gril-card:hover img {
  transform: scale(1.05); 
}

.img-loading{position:absolute;top:0;left:0;width:100%;height:100%;background:rgba(248,249,250,0.8);display:flex;justify-content:center;align-items:center;font-size:20px;color:#ff6b82}
.sticky-tab{position:sticky;width:100%;height:60px; z-index:99;background:#fff;box-shadow:0 2px 12px rgba(0,0,0,0.08);transition:all 0.2s ease;border-bottom:1px solid #f0f0f0;}
@supports (top: env(safe-area-inset-top)) {
  .sticky-tab {
    top: calc(env(safe-area-inset-top) + 40px);
  }
}

#loading-overlay{position:fixed;top:0;left:0;width:100%;height:100%;background:url('loadbg.jpg') no-repeat;background-size:cover; background-position:center center;  display:flex;align-items:center;flex-direction: column;justify-content:center;z-index:9999;transition: opacity 0.5s ease;}
#loading-overlay img{ width:30vh; margin-bottom:20px;}
/* HTML: <div class="loader"></div> */
.spinner {
  width: 120px;
  height: 20px;
  border-radius: 20px;
  background:
   linear-gradient(#eb3d78 0 0) 0/0% no-repeat
   lightblue;
  animation: spin 3s infinite steps(10);
}
@keyframes spin {
    100% {background-size:110%}
}
/*
#loading-overlay{position:fixed;top:0;left:0;width:100%;height:100%;background:rgba(255,255,255,0.95);display:flex;align-items:center;justify-content:center;z-index:9999}
.spinner{width:50px;height:50px;border:5px solid #f3f3f3;border-top:5px solid #ff6b82;border-radius:50%;animation:spin 1s linear infinite}
@keyframes spin{0%{transform:rotate(0deg)}
100%{transform:rotate(360deg)}
}*/
.video-loading {
  position:absolute;
  top:50%;
  left:50%;
  transform:translate(-50%,-50%);
  background:rgba(255,255,255,0.9);
  color:#ff6b82;
  padding:8px 16px;
  border-radius:8px;
  font-size:14px;
  border:1px solid #ff6b82;
}

.footer-nav a::after {
  content: '';
  position: absolute;
  top: 50%;
  left: 50%;
  width: 0;
  height: 0;
  background: rgba(255,107,130,0.3);
  border-radius: 50%;
  transform: translate(-50%, -50%);
  opacity: 0;
  pointer-events: none;
}
.footer-nav a.ripple::after {
  animation: rippleEffect 0.5s ease-out;
}
@keyframes rippleEffect {
  0% {
    width: 0;
    height: 0;
    opacity: 0.6;
  }
  100% {
    width: 120px;
    height: 120px;
    opacity: 0;
  }
}
.vip-locked-container{height:100vh;width:100vw;display:flex;flex-direction:column;justify-content:center;align-items:center;background:linear-gradient(135deg,#ffffff 0%,#fad0d2 100%);padding:40px 20px;text-align:center}
.vip-lock-icon{font-size:80px;color:#ff6b82;margin-bottom:30px;animation:pulse 2s infinite}
.vip-title{font-size:24px;font-weight:bold;color:#ff6b82;margin-bottom:20px;text-shadow:0 2px 4px rgba(255,107,130,0.1)}
.vip-description{margin-bottom:40px;line-height:1.8}
.vip-description p{font-size:16px;color:#666;margin:8px 0}
.vip-upgrade-btn{background:linear-gradient(45deg,#ff6b82,#ff6b82);border:none;border-radius:25px;padding:15px 40px;font-size:18px;font-weight:bold;color:white;box-shadow:0 4px 15px rgba(255,107,130,0.3);transition:all 0.3s ease;margin-bottom:40px}
.vip-upgrade-btn:hover{transform:translateY(-2px);box-shadow:0 6px 20px rgba(255,107,130,0.4);background:linear-gradient(45deg,#ff5a72,#ff8c5a)}
.vip-upgrade-btn:active{transform:translateY(0)}
.vip-features{display:grid;grid-template-columns:1fr 1fr;gap:15px;max-width:300px}
.feature-item{display:flex;align-items:center;padding:10px 15px;background:rgba(255,107,130,0.1);border-radius:20px;font-size:14px;color:#ff6b82;border:1px solid rgba(255,107,130,0.2)}
.feature-item i{margin-right:8px;font-weight:bold}
@keyframes pulse{0%{transform:scale(1);opacity:1}
50%{transform:scale(1.1);opacity:0.8}
100%{transform:scale(1);opacity:1}
}@media (max-width:768px){.vip-lock-icon{font-size:60px}
.vip-title{font-size:20px}
.vip-description p{font-size:14px}
.vip-upgrade-btn{padding:12px 30px;font-size:16px}
.vip-features{grid-template-columns:1fr;gap:10px}
}