/* =========================================================
   tools.css (TOOLS ONLY)
   - 仅包含 tools 模块的“页面布局/按钮/输入框/提示框”补充样式
   - 全站通用按钮/输入框仍由 /assets/layout.css 提供
   ========================================================= */


/* =========================================================
   ✅ 通用：工具页头部 tool-head（标题永远居中 + 返回按钮右侧）
   - 用 grid 三列：左占位 / 中间标题 / 右按钮
   - 解决：返回按钮不再影响标题居中
   ========================================================= */

.tools-page .tool-head{
  display:grid;
  grid-template-columns:1fr auto 1fr;  /* ✅ 中间永远居中 */
  align-items:center;
  gap:10px;
  margin:4px 0 14px;
  text-align:center;
}

.tools-page .tool-head h2{margin:0}
.tools-page .tool-head .tool-sub{
  color:var(--muted);
  font-size:13px;
  margin:4px 0 0;
  max-width:900px;
}

/* 中间标题块放中间列 */
.tools-page .tool-head > div{
  grid-column:2;
  display:flex;
  flex-direction:column;
  align-items:center;
  justify-content:center;
}

/* 返回按钮放右侧列，并贴右 */
.tools-page .tool-head > a.btn{
  grid-column:3;
  justify-self:end;
  white-space:nowrap;
  margin:0;
}

/* 手机端：改为竖排（按钮在下方居中） */
@media (max-width: 520px){
  .tools-page .tool-head{ grid-template-columns:1fr; }
  .tools-page .tool-head > div{ grid-column:1; }
  .tools-page .tool-head > a.btn{
    grid-column:1;
    justify-self:center;
    margin-top:6px;
  }
}


/* =========================================================
   ✅ 通用：工具页按钮条/表单/容器
   ========================================================= */

.pad{padding:18px}

/* 兼容旧版 tools/txt 的 .btns */
.btns{
  display:flex;
  gap:10px;
  flex-wrap:wrap;
  justify-content:center;
  margin-top:12px;
}

/* 工具页表单按钮居中 */
.tools-page .form button,
.tools-page .form .btn{
  justify-self:center;
}

.tool-actions{
  display:flex;
  gap:10px;
  flex-wrap:wrap;
  margin:12px 0;
  justify-content:center;
}

.tool-title{
  text-align:center;
  margin:6px 0 14px;
}


/* =========================================================
   ✅ tabs
   ========================================================= */

.tool-tabs{
  display:flex;
  gap:10px;
  flex-wrap:wrap;
  margin:12px 0;
  justify-content:center;
}

.tool-tab{
  padding:8px 12px;
  border-radius:10px;
  border:1px solid rgba(0,0,0,.12);
  background:#fff;
  cursor:pointer;
  font-weight:700;
  font-size:14px;
}
.tool-tab.active{
  background:rgba(22,119,255,.10);
  border-color:rgba(22,119,255,.35);
}

.tool-panel{display:none}
.tool-panel.active{display:block}


/* =========================================================
   ✅ layout helpers
   ========================================================= */

.tool-row{
  display:grid;
  grid-template-columns:1.2fr .8fr;
  gap:14px;
}
@media (max-width:860px){
  .tool-row{grid-template-columns:1fr}
}

.tool-code{
  font-family:ui-monospace,SFMono-Regular,Menlo,Consolas,monospace;
  white-space:pre-wrap;
}


/* =========================================================
   ✅ toast / help / alert
   ========================================================= */

.tool-toast{
  position:fixed;
  left:50%;
  top:110px;
  transform:translateX(-50%);
  background:rgba(17,17,17,.92);
  color:#fff;
  padding:10px 14px;
  border-radius:10px;
  box-shadow:0 10px 26px rgba(0,0,0,.20);
  z-index:9999;
  display:none;
  max-width:min(720px, 92vw);
}

.tool-help{
  color:var(--muted);
  font-size:13px;
  line-height:1.6;
}

.tool-alert{
  background:rgba(255,77,79,.08);
  border:1px solid rgba(255,77,79,.25);
  color:#9a1d1f;
  padding:10px 12px;
  border-radius:10px;
  margin:10px 0;
}


/* =========================================================
   ✅ split / exchange
   ========================================================= */

.tool-split-inline{
  display:grid;
  grid-template-columns:repeat(4, minmax(0, 1fr));
  gap:10px;
  align-items:end;
}
@media (max-width:980px){
  .tool-split-inline{grid-template-columns:repeat(2, minmax(0, 1fr))}
}

.tool-exchange-row{
  display:grid;
  grid-template-columns:1fr auto 1fr;
  gap:10px;
  align-items:end;
}
@media (max-width:860px){
  .tool-exchange-row{grid-template-columns:1fr}
}

.tool-swap{
  user-select:none;
  width:44px;height:44px;
  display:flex;
  align-items:center;
  justify-content:center;
  border-radius:12px;
  border:1px solid rgba(0,0,0,.12);
  background:#fff;
  cursor:pointer;
  font-weight:900;
}


/* =========================================================
   ✅ Tools 首页（/tools）
   - 标题文字居中
   - 分组间距更大
   - ✅ 每行固定 5 个按钮（grid）
   ========================================================= */

.tools-home .tools-title,
.tools-home .tools-section-title{
  text-align:center;
  padding: 20px;
}

.tools-home .tools-section{
  margin-top:18px; /* 分组之间的纵向间距 */
}

/* ✅ 关键：每行 5 个按钮 */
.tools-home .tools-btns{
  display:grid;
  grid-template-columns:repeat(5, minmax(0, 1fr));
  gap:15px 0px; /* row-gap / column-gap（纵向更大） */
  align-items:stretch;
}

/* 按钮填满格子，文字居中，不换行 */
/* 工具首页：按钮网格 */
.tools-home .tools-btns{
  display:grid;
  grid-template-columns:repeat(5, minmax(0, 1fr));
  /*gap:15px 14px;  行间距 / 列间距 */
  align-items:stretch;
}

/* ✅ 关键：让按钮在每个格子里水平居中 */
.tools-home .tools-btns .tool-btn{
  width:90%;                 /* 不要 80%，否则视觉不稳 */
  display:flex;               /* 用 flex 做内容居中 */
  align-items:center;
  justify-content:center;     /* ✅ 文字居中 */
  text-align:center;
  white-space:nowrap;         /* 不换行 */
  margin:0 auto;              /* 双保险 */
}

/* 如果 tool-btn 不是 a，而是 button，也一起兼容 */
.tools-home .tools-btns button.tool-btn{
  width:100%;
}

/* 响应式降列 */
@media (max-width: 1100px){
  .tools-home .tools-btns{ grid-template-columns:repeat(4, minmax(0, 1fr)); }
}
@media (max-width: 820px){
  .tools-home .tools-btns{ grid-template-columns:repeat(3, minmax(0, 1fr)); }
}
@media (max-width: 560px){
  .tools-home .tools-btns{ grid-template-columns:repeat(2, minmax(0, 1fr)); }
}

