/* ============================================================
 * tool-base.css — 工具页共享基座
 * 设计 token · 兼容垫片 · 明暗主题 · 基础组件 · 悬浮外壳
 *
 * 用法：在每个工具 HTML 的内联 <style> 之前引入
 *   <link rel="stylesheet" href="../../assets/css/tool-base.css" />
 *
 * 改一次设计 = 全站生效。后定义的工具内联 :root/样式仍可覆盖本文件。
 * ============================================================ */

/* ---------- 1. 设计 token（与 assets/css/main.css 对齐）---------- */
:root {
  /* 背景层级 */
  --bg-deep: #0a0a0f;
  --bg-surface: #12121a;
  --bg-card: #1a1a24;
  --bg-card-hover: #22222e;
  --bg-input: #0e0e14;

  /* 文字 */
  --text-primary: #e8e8ed;
  --text-secondary: #8888a0;
  --text-muted: #55556a;

  /* 边框 */
  --border-subtle: #2a2a3a;
  --border-strong: #3a3a4a;

  /* 强调色 */
  --accent-cyan: #00f5d4;
  --accent-magenta: #f72585;
  --accent-yellow: #fee440;
  --accent-blue: #4cc9f0;
  --accent-purple: #7b2cbf;
  --accent-orange: #ff9f1c;
  --accent-red: #ff6b6b;
  --accent-green: #06d6a0;

  /* 辉光 */
  --glow-cyan: rgb(0 245 212 / 15%);
  --glow-magenta: rgb(247 37 133 / 15%);

  /* 字体 */
  --font-sans: 'Space Grotesk', system-ui, -apple-system, 'Segoe UI', sans-serif;
  --font-mono: 'JetBrains Mono', ui-monospace, 'SF Mono', 'Menlo', monospace;

  /* 间距尺度（4px 基数） */
  --space-1: 4px;
  --space-2: 8px;
  --space-3: 12px;
  --space-4: 16px;
  --space-5: 20px;
  --space-6: 24px;
  --space-8: 32px;
  --space-10: 40px;

  /* 圆角 */
  --radius-sm: 4px;
  --radius-md: 8px;
  --radius-lg: 12px;
  --radius-xl: 20px;
  --radius-full: 999px;

  /* 阴影 */
  --shadow-sm: 0 1px 2px rgb(0 0 0 / 40%);
  --shadow-md: 0 4px 12px rgb(0 0 0 / 40%);
  --shadow-lg: 0 8px 32px rgb(0 0 0 / 50%);

  /* 过渡 */
  --transition-fast: 150ms ease;
  --transition: 200ms ease;

  /* 玻璃外壳 */
  --tb-glass-bg: rgb(20 20 28 / 92%);
  --tb-glass-border: rgb(255 255 255 / 10%);
  --tb-fab-shadow: 0 8px 24px rgb(0 0 0 / 38%);

  /* 布局 */
  --nav-height: 56px;
}

/* ---------- 2. 明暗主题 ---------- */
[data-theme='light'] {
  --bg-deep: #fafafa;
  --bg-surface: #fff;
  --bg-card: #fff;
  --bg-card-hover: #f5f5f5;
  --bg-input: #f4f4f6;
  --text-primary: #1a1a1a;
  --text-secondary: #666;
  --text-muted: #999;
  --border-subtle: #e5e5e5;
  --border-strong: #d4d4d4;
  --accent-cyan: #00d4b8;
  --accent-magenta: #e63975;
  --accent-yellow: #f5c518;
  --accent-blue: #0ea5e9;
  --accent-purple: #9333ea;
  --glow-cyan: rgb(0 212 184 / 10%);
  --glow-magenta: rgb(230 57 117 / 10%);
  --shadow-sm: 0 1px 2px rgb(0 0 0 / 6%);
  --shadow-md: 0 4px 12px rgb(0 0 0 / 8%);
  --shadow-lg: 0 8px 32px rgb(0 0 0 / 12%);
  --tb-glass-bg: rgb(255 255 255 / 94%);
  --tb-glass-border: rgb(0 0 0 / 8%);
  --tb-fab-shadow: 0 8px 24px rgb(0 0 0 / 12%);
}

/* ---------- 3. 兼容垫片：旧工具的孤儿变量映射到新 token ---------- */
:root {
  --color-bg-deep: var(--bg-deep);
  --color-bg-surface: var(--bg-surface);
  --color-bg-subtle: var(--bg-card);
  --color-bg-card: var(--bg-card);
  --color-bg-input: var(--bg-input);
  --color-text-primary: var(--text-primary);
  --color-text-secondary: var(--text-secondary);
  --color-text-muted: var(--text-muted);
  --color-border-default: var(--border-subtle);
  --color-border-subtle: var(--border-subtle);
  --color-border-strong: var(--border-strong);
  --color-accent-primary: var(--accent-cyan);
  --color-accent-secondary: var(--accent-magenta);
  --color-accent-cyan: var(--accent-cyan);
  --color-accent-purple: var(--accent-purple);
  --color-accent-pink: var(--accent-magenta);
  --color-success: var(--accent-green);
  --color-warning: var(--accent-yellow);
  --color-error: var(--accent-red);
  --color-danger: var(--accent-red);
  --color-info: var(--accent-blue);

  /* 旧单名约定 */
  --bg-color: var(--bg-deep);
  --bg-secondary: var(--bg-surface);
  --bg-tertiary: var(--bg-card);
  --bg-elevated: var(--bg-card-hover);
  --bg-hover: var(--bg-card-hover);
  --text-color: var(--text-primary);
  --primary-color: var(--accent-cyan);
  --secondary-color: var(--accent-magenta);
  --accent-color: var(--accent-cyan);
  --success-color: var(--accent-green);
  --warning-color: var(--accent-yellow);
  --error-color: var(--accent-red);
  --danger-color: var(--accent-red);
  --info-color: var(--accent-blue);
  --border-default: var(--border-subtle);
  --border-color: var(--border-subtle);
  --border-radius: var(--radius-md);
  --card-shadow: var(--shadow-md);
  --transition-normal: var(--transition);
}

/* ---------- 4. 基础重置（工具内联样式可覆盖）---------- */
*,
*::before,
*::after {
  box-sizing: border-box;
}

html {
  -webkit-text-size-adjust: 100%;
}

body {
  margin: 0;
  font-family: var(--font-sans);
  background: var(--bg-deep);
  color: var(--text-primary);
  line-height: 1.6;
  -webkit-font-smoothing: antialiased;
  -webkit-tap-highlight-color: transparent;
}

/* 移除移动端点击的双击缩放延迟与高亮闪烁，点击更跟手 */
button,
a,
label,
input,
select,
textarea,
summary,
[role='button'] {
  touch-action: manipulation;
}

/* ---------- 5. 共享组件（新工具可直接使用 .tb-* 类）---------- */
.tb-card {
  background: var(--bg-card);
  border: 1px solid var(--border-subtle);
  border-radius: var(--radius-lg);
  box-shadow: var(--shadow-md);
}

.tb-btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: var(--space-2);
  padding: 10px 18px;
  font-family: var(--font-sans);
  font-size: 14px;
  font-weight: 600;
  color: var(--text-primary);
  background: var(--bg-card-hover);
  border: 1px solid var(--border-strong);
  border-radius: var(--radius-md);
  cursor: pointer;
  transition:
    transform var(--transition-fast),
    border-color var(--transition-fast),
    background var(--transition-fast);
}

.tb-btn:hover {
  transform: translateY(-1px);
  border-color: var(--accent-cyan);
}

.tb-btn:active {
  transform: translateY(0);
}

.tb-btn-primary {
  color: #06121a;
  background: var(--accent-cyan);
  border-color: var(--accent-cyan);
}

.tb-btn-primary:hover {
  filter: brightness(1.08);
}

.tb-input,
.tb-select {
  width: 100%;
  padding: 12px 14px;
  font-family: var(--font-mono);
  font-size: 15px;
  color: var(--text-primary);
  background: var(--bg-input);
  border: 1px solid var(--border-strong);
  border-radius: var(--radius-md);
  transition:
    border-color var(--transition-fast),
    box-shadow var(--transition-fast);
}

.tb-input:focus,
.tb-select:focus {
  outline: none;
  border-color: var(--accent-cyan);
  box-shadow: 0 0 0 3px var(--glow-cyan);
}

.tb-label {
  display: block;
  margin-bottom: var(--space-2);
  font-size: 13px;
  font-weight: 600;
  letter-spacing: 0.02em;
  color: var(--text-secondary);
}

/* ---------- 6. 悬浮外壳：返回首页 + 主题切换（由 tool-chrome.js 注入）---------- */
/* 分组容器自身不生成盒子，避免多一个视口大小的合成层 */
#tbChrome {
  display: contents;
}

.tb-fab {
  position: fixed;
  bottom: 22px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: var(--space-2);
  font-family: var(--font-sans);
  font-size: 14px;
  font-weight: 600;
  color: var(--text-primary);
  text-decoration: none;
  background: var(--tb-glass-bg);
  border: 1px solid var(--tb-glass-border);
  box-shadow: var(--tb-fab-shadow);
  cursor: pointer;
  z-index: 2147483000;
  will-change: transform;
  -webkit-backdrop-filter: blur(8px) saturate(150%);
  backdrop-filter: blur(8px) saturate(150%);
  transition:
    transform var(--transition),
    border-color var(--transition),
    box-shadow var(--transition);
}

.tb-fab:hover {
  transform: translateY(-2px);
  border-color: var(--accent-cyan);
  box-shadow:
    var(--tb-fab-shadow),
    0 0 0 1px var(--accent-cyan);
}

.tb-fab:active {
  transform: translateY(0);
}

.tb-fab:focus-visible {
  outline: 2px solid var(--accent-cyan);
  outline-offset: 3px;
}

.tb-fab-home {
  left: 22px;
  padding: 11px 17px 11px 14px;
  border-radius: var(--radius-full);
}

.tb-fab-home svg {
  width: 17px;
  height: 17px;
  flex-shrink: 0;
}

.tb-fab-theme {
  right: 22px;
  width: 46px;
  height: 46px;
  padding: 0;
  border-radius: 50%;
}

.tb-fab-theme svg {
  width: 19px;
  height: 19px;
}

.tb-icon-sun {
  display: none;
}

[data-theme='light'] .tb-icon-sun {
  display: block;
}

[data-theme='light'] .tb-icon-moon {
  display: none;
}

@media (max-width: 600px) {
  .tb-fab {
    bottom: 16px;
  }

  .tb-fab-home {
    left: 16px;
  }

  .tb-fab-home span {
    display: none;
  }

  .tb-fab-home {
    width: 46px;
    height: 46px;
    padding: 0;
    border-radius: 50%;
  }

  .tb-fab-theme {
    right: 16px;
  }
}

@media print {
  #tbChrome {
    display: none;
  }
}

/* 切换主题时临时关闭全页过渡，避免大面积颜色渐变造成的卡顿 */
.tb-anim-off,
.tb-anim-off *,
.tb-anim-off *::before,
.tb-anim-off *::after {
  transition: none !important;
}

@media (prefers-reduced-motion: reduce) {
  *,
  *::before,
  *::after {
    animation-duration: 0.01ms !important;
    animation-iteration-count: 1 !important;
    transition-duration: 0.01ms !important;
    scroll-behavior: auto !important;
  }
}

/* ---------- 7. 隐藏旧版页内导航（被悬浮外壳取代）---------- */
.breadcrumb,
nav.nav-bar,
.theme-toggle {
  display: none !important;
}

/* 新模板 nav-bar 移除后回收顶部留白 */
.main-content {
  padding-top: var(--space-6) !important;
}
