/* ============================================================
   组件层：按钮 · 输入 · 芯片 · 卡片 · 弹窗 · 导航 · 开关
   ============================================================ */
button{
  font-family:var(--font-ui);
  color:inherit;background:none;border:none;cursor:pointer;
  -webkit-tap-highlight-color:transparent;
}
button:focus-visible,input:focus-visible,textarea:focus-visible{
  outline:2px solid var(--spark);outline-offset:2px;
}
.btn-primary{
  display:block;width:100%;
  padding:15px;border-radius:var(--r-s);
  background:var(--foam);color:var(--abyss);
  font-size:17px;font-weight:600;letter-spacing:.08em;
  transition:transform var(--t-tap) var(--ease-out),opacity var(--t-tap);
}
.btn-primary:active{transform:scale(.98)}
.btn-primary:disabled{opacity:.3;cursor:default}
.btn-outline{
  display:block;width:100%;
  padding:13px;border:1px solid var(--water);border-radius:var(--r-s);
  color:var(--foam);font-size:15px;letter-spacing:.08em;
  background:rgba(13,27,40,.6);
  transition:background var(--t-tap);
}
.btn-outline:active{background:var(--tank-2)}
.btn-ghost{
  display:block;width:100%;
  padding:11px;color:var(--mist);
  font-size:14px;letter-spacing:.1em;
}
.link-btn{
  font-size:12px;color:var(--mist);letter-spacing:.1em;
  padding:6px 0;text-decoration:underline;text-underline-offset:3px;
}

/* ---- 输入 ---- */
textarea,input[type=text]{
  width:100%;padding:14px;
  border:1px solid var(--water);border-radius:var(--r-s);
  background:var(--tank);color:var(--foam);
  font-family:var(--font-ui);font-size:16px;line-height:var(--lh-body);
}
textarea{min-height:96px;resize:none}
textarea::placeholder,input::placeholder{color:var(--mist-dim)}
input[type=range]{width:100%;margin:12px 0 4px;appearance:none;-webkit-appearance:none;height:34px;background:transparent}
input[type=range]::-webkit-slider-runnable-track{height:6px;border-radius:3px;background:linear-gradient(90deg,var(--water),#2e5a7d)}
input[type=range]::-webkit-slider-thumb{
  -webkit-appearance:none;width:26px;height:26px;margin-top:-10px;border-radius:50%;
  background:var(--foam);border:2px solid var(--abyss);box-shadow:0 0 12px rgba(232,242,247,.5);
}
input[type=range]::-moz-range-track{height:6px;border-radius:3px;background:linear-gradient(90deg,var(--water),#2e5a7d)}
input[type=range]::-moz-range-thumb{width:26px;height:26px;border-radius:50%;background:var(--foam);border:2px solid var(--abyss)}

/* ---- 芯片 ---- */
.chip{
  padding:9px 16px;
  border:1px solid var(--water);border-radius:var(--r-pill);
  background:var(--tank);font-size:14px;color:var(--foam);
  transition:border-color var(--t-tap),background var(--t-tap);
}
.chip[aria-pressed="true"]{border-color:var(--spark);color:var(--spark);background:var(--tank-2)}
.chip.add{border-style:dashed;color:var(--mist)}
.chips{display:flex;flex-wrap:wrap;gap:9px}

/* ---- 卡片 ---- */
.card{
  border:1px solid var(--water);border-radius:var(--r-s);
  background:var(--tank);padding:14px 16px;
}
.card.gold{border-color:var(--spark-dim);background:var(--glow-1)}

/* ---- 底部导航 ---- */
#tabbar{
  position:absolute;left:0;right:0;bottom:0;
  display:flex;
  border-top:1px solid var(--water);
  background:rgba(6,13,20,.94);
  padding-bottom:var(--safe-bottom);
  z-index:20;
}
#tabbar.hidden{display:none}
#tabbar button{
  flex:1;padding:12px 0 9px;
  font-size:12px;letter-spacing:var(--ls-label);
  color:var(--mist);border-top:2px solid transparent;
  position:relative;
}
#tabbar button[aria-current="true"]{color:var(--spark);border-top-color:var(--spark)}
#tabbar button .dot{
  position:absolute;top:8px;right:calc(50% - 22px);
  width:6px;height:6px;border-radius:50%;background:var(--spark);
}

/* ---- 开关 ---- */
.switch{
  position:relative;width:46px;height:26px;border-radius:13px;
  background:var(--water);transition:background var(--t-card);flex:none;
}
.switch::after{
  content:"";position:absolute;top:3px;left:3px;
  width:20px;height:20px;border-radius:50%;
  background:var(--foam);transition:transform var(--t-card) var(--ease-out);
}
.switch[aria-checked="true"]{background:var(--spark-dim)}
.switch[aria-checked="true"]::after{transform:translateX(20px)}
.setting-row{
  display:flex;justify-content:space-between;align-items:center;gap:10px;
  padding:12px 14px;border:1px solid var(--water);border-radius:var(--r-s);
  background:var(--tank);margin-bottom:8px;
}
.setting-row .sl{font-size:14px}
.setting-row .sd{font-size:var(--fs-micro);color:var(--mist)}
.seg{
  display:flex;border:1px solid var(--water);border-radius:var(--r-s);overflow:hidden;
}
.seg button{
  flex:1;padding:10px 4px;font-size:13px;color:var(--mist);letter-spacing:.06em;
  border-right:1px solid var(--water);
}
.seg button:last-child{border-right:none}
.seg button[aria-pressed="true"]{background:var(--tank-2);color:var(--spark)}

/* ---- 弹窗 / 提示 ---- */
#modal-veil{
  position:absolute;inset:0;z-index:60;
  display:none;align-items:flex-end;justify-content:center;
  background:rgba(3,7,11,.72);
}
#modal-veil.show{display:flex}
#modal{
  width:100%;max-width:480px;
  background:var(--tank);
  border-top:1px solid var(--water);
  border-radius:var(--r-m) var(--r-m) 0 0;
  padding:22px 22px calc(20px + var(--safe-bottom));
  max-height:78dvh;overflow-y:auto;
  animation:modalUp var(--t-card) var(--ease-out);
}
@keyframes modalUp{from{transform:translateY(30px);opacity:0}to{transform:none;opacity:1}}
#modal h3{font-size:18px;margin-bottom:10px}
#modal .mbody{font-size:14px;color:var(--mist);line-height:var(--lh-body);margin-bottom:18px}
#modal .mbody strong{color:var(--foam);font-weight:600}
#toast{
  position:absolute;left:50%;bottom:calc(var(--tabbar-h) + 28px + var(--safe-bottom));
  transform:translateX(-50%) translateY(8px);
  max-width:88%;
  background:rgba(13,27,40,.96);
  border:1px solid var(--water);border-radius:var(--r-pill);
  padding:10px 20px;font-size:13px;letter-spacing:.05em;
  opacity:0;pointer-events:none;
  transition:opacity var(--t-card),transform var(--t-card);
  z-index:70;white-space:nowrap;text-overflow:ellipsis;overflow:hidden;
}
#toast.gold{border-color:var(--spark-dim);color:var(--spark)}
#toast.show{opacity:1;transform:translateX(-50%) translateY(0)}

/* ---- 语音输入 ---- */
.voice-row{display:flex;align-items:center;gap:10px;margin-top:10px;min-height:38px}
.mic-btn{
  display:flex;align-items:center;gap:8px;
  padding:8px 16px;border:1px solid var(--water);border-radius:var(--r-pill);
  color:var(--mist);font-size:13px;letter-spacing:.08em;background:var(--tank);
}
.mic-btn svg{width:16px;height:16px;flex:none}
.mic-btn.listening{border-color:var(--spark);color:var(--spark)}
.voice-unsupported{font-size:12px;color:var(--mist-faint)}
.wave{display:inline-flex;gap:3px;align-items:center;height:14px}
.wave i{width:3px;height:6px;border-radius:2px;background:var(--spark);animation:wv 1s ease-in-out infinite}
.wave i:nth-child(2){animation-delay:.15s}
.wave i:nth-child(3){animation-delay:.3s}
.wave i:nth-child(4){animation-delay:.45s}
@keyframes wv{0%,100%{height:5px}50%{height:14px}}

/* ---- 进度点 ---- */
.dots{display:flex;gap:8px;justify-content:center;margin:6px 0 18px}
.dots i{width:6px;height:6px;border-radius:50%;background:var(--water)}
.dots i.on{background:var(--spark)}

/* ---- 勋章 ---- */
.medal-list{display:flex;flex-direction:column;gap:10px;padding-bottom:16px}
.medal{
  display:flex;gap:14px;align-items:center;
  border:1px solid var(--water);border-radius:var(--r-s);
  background:var(--tank);padding:14px 16px;
}
.medal svg{width:48px;height:48px;flex:none}
.medal .mi{flex:1;min-width:0}
.medal .n{font-family:var(--font-display);font-size:16px}
.medal .d{font-size:12px;color:var(--mist);line-height:1.6}
.medal .prog{margin-top:7px;height:4px;border-radius:2px;background:var(--water-soft);overflow:hidden}
.medal .prog i{display:block;height:100%;background:var(--spark);border-radius:2px}
.medal .pv{font-family:var(--font-num);font-size:11px;color:var(--mist);margin-top:4px;letter-spacing:.08em}
.medal.locked{opacity:.55}
.medal.unlocked{border-color:var(--spark-dim);box-shadow:0 0 24px rgba(255,215,106,.07)}
.medal.unlocked .pv{color:var(--spark)}

/* ---- 全局特效画布 ---- */
#fx{position:absolute;inset:0;width:100%;height:100%;pointer-events:none;z-index:50}
