*,*::before,*::after{margin:0;padding:0;box-sizing:border-box}
:root{
  --bg:linear-gradient(165deg,#0b1628 0%,#0f1f3d 30%,#132244 60%,#0d1a33 100%);
  --glass:rgba(20,40,80,.45);
  --glass2:rgba(25,50,95,.55);
  --glass-border:rgba(100,160,255,.15);
  --glass-border2:rgba(100,160,255,.25);
  --accent:#4da6ff;
  --accent2:#80c4ff;
  --red:#ff6b6b;
  --red2:#ff4757;
  --green:#51cf66;
  --yellow:#fcc419;
  --text:#ecf0f6;
  --text2:rgba(200,215,240,.7);
  --text3:rgba(160,180,210,.45);
  --radius:16px;
}
html{font-size:16px;-webkit-text-size-adjust:100%}
body{
  font-family:-apple-system,BlinkMacSystemFont,'PingFang SC','Noto Sans SC','Helvetica Neue',sans-serif;
  background:#0b1628;color:var(--text);
  min-height:100vh;min-height:100dvh;
  overflow-x:hidden;-webkit-tap-highlight-color:transparent;
}
body::before{
  content:'';position:fixed;inset:0;z-index:0;
  background:var(--bg);
}

/* Background art */
.bg-art{position:fixed;z-index:0;left:0;right:0;background-size:cover;background-position:center;pointer-events:none}
.bg-art.banner{top:0;height:200px;opacity:.25;
  background-image:url(https://firigames.com/images/page_banner/phoenix2_banner.jpg);
  -webkit-mask:linear-gradient(to bottom,black 20%,transparent 100%);
  mask:linear-gradient(to bottom,black 20%,transparent 100%);
}
.bg-art.footer{bottom:0;height:250px;opacity:.15;
  background-image:url(https://firigames.com/images/page_banner/phoenix2_footer.jpg);
  -webkit-mask:linear-gradient(to top,black 20%,transparent 100%);
  mask:linear-gradient(to top,black 20%,transparent 100%);
}

.app{position:relative;z-index:1;max-width:520px;margin:0 auto;padding:0 14px 120px}

/* ── Header 悬浮胶囊 ── */
.header{
  position:fixed;top:12px;left:50%;transform:translateX(-50%);
  z-index:200;
  width:calc(100% - 28px);max-width:492px;
  background:rgba(14,28,56,.82);
  backdrop-filter:blur(28px);-webkit-backdrop-filter:blur(28px);
  border:1px solid var(--glass-border2);
  border-radius:20px;
  padding:10px 14px;
  box-shadow:0 4px 24px rgba(0,0,0,.35);
}
.h-row{display:flex;align-items:center;justify-content:space-between;gap:8px}
.h-left{min-width:0;flex:1}
.logo{font-size:.88rem;font-weight:700;letter-spacing:.5px;color:var(--accent2);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.clock{font-size:.65rem;color:var(--text2);margin-top:1px;font-variant-numeric:tabular-nums;letter-spacing:.5px}
.h-btns{display:flex;gap:6px;flex-shrink:0}
.h-btn{
  width:36px;height:36px;border-radius:12px;border:1px solid var(--glass-border);
  background:rgba(20,40,80,.5);color:var(--accent);
  display:flex;align-items:center;justify-content:center;
  cursor:pointer;transition:all .2s;
}
.h-btn:active{transform:scale(.88);background:var(--glass2)}
.h-btn.spinning svg{animation:spin .5s ease}
@keyframes spin{from{transform:rotate(0)}to{transform:rotate(360deg)}}

/* header 占位，防止卡片被遮住 */
.header-spacer{height:72px}

/* ── Sort bar ── */
.sort-bar{
  display:flex;gap:6px;margin-top:8px;margin-bottom:2px;
  overflow-x:auto;-webkit-overflow-scrolling:touch;
  scrollbar-width:none;
}
.sort-bar::-webkit-scrollbar{display:none}
.sort-btn{
  padding:6px 12px;border-radius:10px;border:1px solid var(--glass-border);
  background:var(--glass);color:var(--text3);font-size:.7rem;font-weight:500;
  cursor:pointer;font-family:inherit;transition:all .2s;white-space:nowrap;
  backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px);
}
.sort-btn:active{transform:scale(.95)}
.sort-btn.on{background:rgba(77,166,255,.15);color:var(--accent);border-color:rgba(77,166,255,.35)}

/* ── Cards ── */
.cards{display:flex;flex-direction:column;gap:10px;margin-top:10px}
.card{
  background:var(--glass);
  backdrop-filter:blur(24px);-webkit-backdrop-filter:blur(24px);
  border:1px solid var(--bcol, var(--glass-border));
  border-radius:var(--radius);padding:14px;
  /* 静态边缘光晕：颜色/强度随时间渐变（由 render 注入 --glow/--gcol），不脉动 */
  box-shadow:0 0 var(--glow, 0px) var(--gcol, transparent);
  transition:border-color .8s linear, box-shadow .8s linear;
}

.card-top{display:flex;align-items:center;justify-content:space-between;gap:10px;margin-bottom:8px}
.card-left{display:flex;align-items:center;gap:10px;flex:1;min-width:0}
.dot-green,.dot-gray{width:10px;height:10px;border-radius:50%;flex-shrink:0}
.dot-green{background:var(--green);box-shadow:0 0 8px rgba(81,207,102,.5)}
.dot-gray{background:var(--text3);opacity:.6}

.card-info{min-width:0;flex:1}
.card-meta{font-size:.62rem;color:var(--text3);margin-top:2px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}

.card-cd{
  font-size:1.3rem;font-weight:700;font-variant-numeric:tabular-nums;
  letter-spacing:.5px;flex-shrink:0;color:var(--c1, var(--accent));
  transition:color .8s linear;
}

/* Progress bar */
.card-bar{height:3px;border-radius:2px;background:rgba(100,160,255,.1);margin-bottom:8px;overflow:hidden}
.card-bar-fill{height:100%;border-radius:2px;background:linear-gradient(90deg,var(--c1,var(--accent)),var(--c2,var(--accent2)));transition:width .5s, background .8s linear}

.card-bot{display:flex;align-items:center;justify-content:space-between;gap:8px}
.card-status{font-size:.78rem;display:flex;align-items:center;gap:6px;flex-wrap:wrap;flex:1;min-width:0}
.red-num{font-weight:700;font-size:1rem;color:var(--red)}
.red-label{color:var(--red);opacity:.7;font-size:.7rem}
.wave-tags{display:inline-flex;gap:3px;margin-left:4px}
.wt{font-size:.58rem;padding:1px 5px;border-radius:4px;background:rgba(100,160,255,.12);color:var(--text2)}
.no-roc-tag{font-size:.62rem;padding:2px 8px;border-radius:5px;background:rgba(160,180,210,.1);color:var(--text3);margin-left:4px}
.no-intel{color:var(--text3);font-size:.72rem}

.card-actions{display:flex;gap:4px;flex-shrink:0}
.card-action{
  height:32px;border-radius:10px;border:1px solid var(--glass-border);
  background:rgba(20,40,80,.5);color:var(--text2);font-size:.72rem;
  display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all .15s;
  padding:0 10px;gap:3px;white-space:nowrap;
}
.card-action:active{transform:scale(.88)}
.act-roc{font-size:.7rem}
.act-edit{width:32px;padding:0;font-size:.82rem}

/* Name row with copy */
.card-name-row{display:flex;align-items:center;gap:6px}
.card-name{font-size:.92rem;font-weight:600;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.copy-btn{
  flex-shrink:0;width:24px;height:24px;border-radius:6px;border:none;
  background:transparent;color:var(--text3);cursor:pointer;
  display:flex;align-items:center;justify-content:center;transition:all .15s;
}
.copy-btn:active{transform:scale(.85);color:var(--accent)}

/* Big action buttons at card bottom */
.card-btns{display:flex;gap:8px;margin-top:10px}
.card-big-btn{
  flex:1;padding:9px 0;border-radius:10px;border:1px solid var(--glass-border);
  background:var(--glass);color:var(--text2);font-size:.75rem;font-weight:500;
  cursor:pointer;font-family:inherit;transition:all .2s;text-align:center;
  backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px);
}
.card-big-btn:active{transform:scale(.96);background:rgba(77,166,255,.1);color:var(--accent)}

/* ── Empty ── */
.empty{text-align:center;padding:80px 20px;color:var(--text3)}
.empty-ico{font-size:2.5rem;margin-bottom:12px;opacity:.5}
.empty-txt{font-size:.85rem;line-height:1.8}

/* ── Overlay / Sheet (iOS style) ── */
.overlay{
  position:fixed;inset:0;z-index:200;
  background:rgba(0,0,0,.5);
  backdrop-filter:blur(4px);-webkit-backdrop-filter:blur(4px);
  display:none;align-items:flex-end;justify-content:center;
}
.overlay.show{display:flex;animation:fadeIn .2s ease}
@keyframes fadeIn{from{opacity:0}to{opacity:1}}
.sheet{
  width:100%;max-width:520px;
  background:rgba(18,35,65,.92);
  backdrop-filter:blur(40px);-webkit-backdrop-filter:blur(40px);
  border:1px solid var(--glass-border2);
  border-bottom:none;
  border-radius:20px 20px 0 0;
  padding:8px 22px 34px;
  max-height:88vh;overflow-y:auto;
  animation:slideUp .3s cubic-bezier(.32,.72,.24,1);
}
@keyframes slideUp{from{transform:translateY(100%)}to{transform:translateY(0)}}
.sheet-bar{display:flex;justify-content:center;padding:8px 0 12px}
.sheet-pill{width:36px;height:4px;border-radius:2px;background:rgba(160,180,210,.25)}
.sheet-title{font-size:.95rem;font-weight:700;color:var(--accent2);margin-bottom:16px}

.fld{margin-bottom:14px}
.fld label{display:block;font-size:.7rem;color:var(--text2);margin-bottom:6px;font-weight:500}
.fld-sub{font-size:.6rem;color:var(--text3);margin-top:4px;line-height:1.5}
.fld input,.fld textarea{
  width:100%;padding:10px 12px;border-radius:12px;
  border:1px solid var(--glass-border);
  background:rgba(10,20,40,.6);color:var(--text);
  font-size:.85rem;font-family:inherit;outline:none;transition:border-color .2s;
}
.fld input:focus,.fld textarea:focus{border-color:var(--accent)}
.fld textarea{resize:vertical;font-size:.72rem}

.qt{display:flex;gap:6px;flex-wrap:wrap;margin-top:8px}
.qt-btn{
  padding:5px 10px;border-radius:8px;border:1px solid var(--glass-border);
  background:rgba(10,20,40,.5);color:var(--text2);font-size:.68rem;cursor:pointer;
  font-family:inherit;transition:all .15s;
}
.qt-btn:active{background:rgba(77,166,255,.15);color:var(--accent);border-color:var(--accent)}

/* Wave buttons */
.wave-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:8px}
.wave-btn{
  padding:10px 0;border-radius:12px;border:1px solid var(--glass-border);
  background:rgba(10,20,40,.5);color:var(--text2);font-size:.82rem;font-weight:600;
  cursor:pointer;font-family:inherit;transition:all .2s;text-align:center;
}
.wave-btn:active{transform:scale(.93)}
.wave-btn.on{
  background:rgba(255,71,87,.15);color:var(--red);
  border-color:rgba(255,71,87,.4);box-shadow:0 0 12px rgba(255,71,87,.1);
}

/* No-roc toggle */
.no-roc-btn{
  width:100%;padding:12px;border-radius:12px;border:1px solid var(--glass-border);
  background:rgba(10,20,40,.5);color:var(--text2);font-size:.85rem;font-weight:600;
  cursor:pointer;font-family:inherit;transition:all .2s;text-align:center;
}
.no-roc-btn:active{transform:scale(.97)}
.no-roc-btn.on{
  background:rgba(160,180,210,.12);color:var(--text2);
  border-color:rgba(160,180,210,.35);
}
#waveSection.dimmed{opacity:.3;pointer-events:none}

.roc-info{margin-bottom:12px}
.roc-info-sub{font-size:.7rem;color:var(--text3)}
.roc-calc{
  display:flex;align-items:center;justify-content:space-between;
  padding:10px 14px;border-radius:12px;
  background:rgba(255,71,87,.08);border:1px solid rgba(255,71,87,.2);
  margin-bottom:14px;
}
.roc-calc-label{font-size:.75rem;color:var(--text2)}
.roc-calc-val{font-size:1.3rem;font-weight:700;color:var(--red)}

.sheet-acts{display:flex;gap:8px;margin-top:16px}
.btn-ok{
  flex:1;padding:12px;border-radius:14px;border:none;
  background:var(--accent);color:#0b1628;font-weight:700;font-size:.82rem;
  cursor:pointer;font-family:inherit;transition:all .2s;
}
.btn-ok:active{transform:scale(.97);opacity:.85}
.btn-cancel{
  flex:1;padding:12px;border-radius:14px;border:1px solid var(--glass-border);
  background:rgba(10,20,40,.5);color:var(--text2);font-size:.8rem;
  cursor:pointer;font-family:inherit;transition:all .2s;
}
.btn-cancel:active{transform:scale(.97)}
.btn-danger-sm{
  padding:12px 16px;border-radius:14px;border:1px solid rgba(255,71,87,.3);
  background:rgba(255,71,87,.08);color:var(--red);font-size:.75rem;
  cursor:pointer;font-family:inherit;transition:all .2s;white-space:nowrap;
}
.btn-danger-sm:active{transform:scale(.97)}

/* ── Delete zone in edit modal ── */
.del-zone{margin-top:20px}
.del-sep{height:1px;background:rgba(255,71,87,.15);margin-bottom:16px}
.btn-del-full{
  width:100%;padding:12px;border-radius:14px;border:1px solid rgba(255,71,87,.3);
  background:rgba(255,71,87,.08);color:var(--red);font-size:.8rem;font-weight:600;
  cursor:pointer;font-family:inherit;transition:all .2s;
}
.btn-del-full:active{transform:scale(.97);background:rgba(255,71,87,.15)}
.del-confirm{margin-top:10px}
.del-warn{font-size:.72rem;color:var(--red);margin-bottom:10px;text-align:center}
.del-confirm-btns{display:flex;gap:8px}

/* ── Toast ── */
.toast{
  position:fixed;bottom:30px;left:50%;transform:translateX(-50%) translateY(80px);
  z-index:300;padding:10px 22px;border-radius:14px;
  background:rgba(18,35,65,.9);border:1px solid var(--glass-border2);
  backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);
  color:var(--accent2);font-size:.78rem;font-weight:500;
  opacity:0;transition:all .35s cubic-bezier(.4,0,.2,1);
  pointer-events:none;white-space:nowrap;
}
.toast.show{transform:translateX(-50%) translateY(0);opacity:1}

::-webkit-scrollbar{width:4px}
::-webkit-scrollbar-track{background:transparent}
::-webkit-scrollbar-thumb{background:rgba(100,160,255,.15);border-radius:4px}
@media(max-width:380px){.card-cd{font-size:1.1rem}.card-name{font-size:.84rem}}

/* ── Search bar ── */
.search-bar{
  position:relative;margin-top:8px;margin-bottom:2px;
}
.search-bar input{
  width:100%;padding:8px 12px 8px 34px;border-radius:10px;
  border:1px solid var(--glass-border);
  background:var(--glass);color:var(--text);
  font-size:.78rem;font-family:inherit;outline:none;transition:border-color .2s;
  backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px);
}
.search-bar input:focus{border-color:var(--accent)}
.search-bar input::placeholder{color:var(--text3)}
.search-bar .search-icon{
  position:absolute;left:10px;top:50%;transform:translateY(-50%);
  color:var(--text3);pointer-events:none;display:flex;align-items:center;
}
.search-bar .search-clear{
  position:absolute;right:8px;top:50%;transform:translateY(-50%);
  width:22px;height:22px;border-radius:6px;border:none;
  background:transparent;color:var(--text3);cursor:pointer;
  display:none;align-items:center;justify-content:center;font-size:.7rem;transition:all .15s;
}
.search-bar .search-clear.show{display:flex}
.search-bar .search-clear:active{color:var(--accent);transform:translateY(-50%) scale(.85)}

/* ── Timezone selector ── */
.tz-bar{
  display:flex;align-items:center;gap:8px;margin-top:6px;
}
.tz-select{
  flex:1;padding:6px 10px;border-radius:10px;
  border:1px solid var(--glass-border);
  background:var(--glass);color:var(--text2);
  font-size:.68rem;font-family:inherit;outline:none;cursor:pointer;
  backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px);
  transition:border-color .2s;
  -webkit-appearance:none;appearance:none;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='10' height='6'%3E%3Cpath d='M0 0l5 6 5-6z' fill='rgba(160,180,210,.45)'/%3E%3C/svg%3E");
  background-repeat:no-repeat;background-position:right 10px center;
  padding-right:26px;
}
.tz-select:focus{border-color:var(--accent)}
.tz-select option{background:#0f1f3d;color:var(--text)}
.tz-label{font-size:.62rem;color:var(--text3);white-space:nowrap;flex-shrink:0}

/* ── Countdown input ── */
.countdown-inputs{display:flex;gap:10px;margin-bottom:8px}
.cd-input-wrap{flex:1;display:flex;align-items:center;gap:6px;
  background:rgba(10,20,40,.6);border:1px solid var(--glass-border);
  border-radius:12px;padding:8px 12px;}
.cd-input-wrap input{
  flex:1;width:0;background:transparent;border:none;outline:none;
  color:var(--text);font-size:1.1rem;font-weight:700;font-family:inherit;
  font-variant-numeric:tabular-nums;text-align:center;
}
.cd-unit{font-size:.72rem;color:var(--text3);white-space:nowrap;flex-shrink:0}

/* ── Token / Settings ── */
.role-badge{
  display:inline-flex;align-items:center;gap:4px;
  padding:3px 8px;border-radius:6px;font-size:.6rem;font-weight:600;
  margin-left:6px;vertical-align:middle;
}
.role-badge.admin{background:rgba(252,196,25,.15);color:var(--yellow);border:1px solid rgba(252,196,25,.3)}
.role-badge.user{background:rgba(77,166,255,.12);color:var(--accent);border:1px solid rgba(77,166,255,.25)}
.token-status{font-size:.68rem;color:var(--text3);margin-top:6px}
.token-status.ok{color:var(--green)}
.token-status.err{color:var(--red)}


/* ── 登录门禁 Gate ── */
.gate-overlay{align-items:center;z-index:500}
.gate-sheet{
  width:calc(100% - 32px);max-width:420px;
  border-radius:20px;border-bottom:1px solid var(--glass-border2);
  padding:24px 22px 28px;
  animation:fadeIn .25s ease;
}
.gate-logo{font-size:1.05rem;font-weight:700;color:var(--accent2);text-align:center;margin-bottom:4px}
.gate-tip{font-size:.62rem;color:var(--text3);line-height:1.6;margin-top:14px;text-align:center}