/* ===================================
   base.css — 基础样式
   变量 / 重置 / 排版 / 按钮 / 表单
   =================================== */

:root {
  --bg-primary: #1a1a1a;
  --bg-secondary: #212121;
  --bg-card: #2a2a2a;
  --bg-input: #1a1a1a;
  --border: rgba(255,255,255,.08);
  --border-hover: rgba(68,204,68,.2);
  --text-bright: #fff;
  --text-normal: #bebebe;
  --text-dim: #6d6d6d;
  --text-accent: #0fb6d6;
  --accent: #44CC44;
  --accent-hover: #3bb83b;
  --danger: #ef4444;
  --danger-hover: #dc2626;
  --warning: #f59e0b;
  --gradient: linear-gradient(135deg, #44CC44, #22ddbb);
  --radius: 12px;
  --radius-sm: 8px;
  --shadow: 0 8px 30px rgba(0,0,0,.3);
}

*{margin:0;padding:0;box-sizing:border-box}
body{
  font-family:-apple-system,BlinkMacSystemFont,'Segoe UI','PingFang SC','Microsoft YaHei',sans-serif;
  background:var(--bg-primary);color:var(--text-normal);min-height:100vh;line-height:1.6
}
a{color:var(--accent);text-decoration:none;transition:opacity .2s}
a:hover{opacity:.7}

/* ── 顶部导航 ── */
.nav{
  background:var(--bg-secondary);border-bottom:1px solid var(--border);
  padding:0 24px;height:56px;display:flex;align-items:center;justify-content:space-between;
  position:sticky;top:0;z-index:100
}
.nav .logo{font-size:18px;font-weight:700;background:var(--gradient);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}
.nav .links{display:flex;gap:8px}
.nav .links a{color:var(--text-normal);font-size:14px;padding:6px 12px;border-radius:6px;transition:.2s}
.nav .links a:hover{background:rgba(255,255,255,.06);color:var(--text-bright);opacity:1}

/* ── 容器 ── */
.container{max-width:440px;margin:60px auto;padding:0 16px}
.container.wide{max-width:960px}

/* ── 卡片 ── */
.card{
  background:var(--bg-secondary);border:1px solid var(--border);
  border-radius:var(--radius);padding:40px 32px;box-shadow:var(--shadow)
}
.card h1{font-size:24px;font-weight:700;color:var(--text-bright);margin-bottom:8px;text-align:center}
.card h1 .hl{background:var(--gradient);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}
.card .sub{text-align:center;color:var(--text-dim);font-size:14px;margin-bottom:32px}

/* ── 表单 ── */
.fg{margin-bottom:20px}
.fg label{display:block;font-size:13px;color:var(--text-bright);margin-bottom:6px;font-weight:500}
.fg .hint{font-size:12px;color:var(--text-dim);margin-top:4px}

input,select,textarea{
  width:100%;padding:12px 16px;background:var(--bg-input);
  border:1px solid var(--border);border-radius:var(--radius-sm);
  color:var(--text-bright);font-size:15px;transition:border-color .2s;outline:none
}
input:focus,select:focus{border-color:var(--accent);box-shadow:0 0 0 3px rgba(68,204,68,.1)}
input::placeholder{color:var(--text-dim)}

select{cursor:pointer;appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' fill='%236d6d6d' viewBox='0 0 16 16'%3E%3Cpath d='M8 11L3 6h10z'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 12px center;padding-right:36px}

/* ── 按钮 ── */
.btn{
  display:inline-flex;align-items:center;justify-content:center;
  padding:12px 24px;border-radius:var(--radius-sm);border:none;
  font-size:15px;font-weight:600;cursor:pointer;transition:all .2s;gap:6px;text-decoration:none
}
.btn-block{width:100%}
.btn-primary{background:var(--accent);color:#0f172a}
.btn-primary:hover{background:var(--accent-hover)}
.btn-secondary{background:rgba(255,255,255,.06);color:var(--text-bright);border:1px solid var(--border)}
.btn-secondary:hover{background:rgba(255,255,255,.1)}
.btn-danger{background:rgba(239,68,68,.15);color:var(--danger);border:1px solid rgba(239,68,68,.2)}
.btn-danger:hover{background:rgba(239,68,68,.25)}
.btn-warning{background:rgba(245,158,11,.15);color:var(--warning);border:1px solid rgba(245,158,11,.2)}
.btn-warning:hover{background:rgba(245,158,11,.25)}
.btn-sm{padding:8px 16px;font-size:13px}

/* ── 消息提示 ── */
.msg{display:none;padding:12px 16px;border-radius:var(--radius-sm);font-size:14px;margin-bottom:16px}
.msg.show{display:block}
.msg.error{background:rgba(239,68,68,.1);border:1px solid rgba(239,68,68,.2);color:#fca5a5}
.msg.success{background:rgba(68,204,68,.1);border:1px solid rgba(68,204,68,.2);color:#86efac}
.msg.info{background:rgba(15,182,214,.1);border:1px solid rgba(15,182,214,.2);color:#67e8f9}

/* ── 页脚链接 ── */
.footer-link{text-align:center;margin-top:24px;font-size:14px;color:var(--text-dim)}
.footer-link a{color:var(--accent)}
.contact{text-align:center;margin-top:24px;padding:16px;background:rgba(255,255,255,.03);border-radius:var(--radius-sm);font-size:14px;line-height:2}

/* ── 页脚 ── */
.footer{
  text-align:center;padding:24px 16px;
  border-top:1px solid var(--border);margin-top:40px
}
.footer a{color:var(--text-dim);font-size:12px}
.footer a:hover{color:var(--text-normal)}
.footer .copy{font-size:12px;color:var(--text-dim);margin-top:4px}

/* ── 响应式 ── */
@media(max-width:640px){
  .container{margin:30px auto}
  .card{padding:24px 16px}
  .nav{padding:0 12px}
  .nav .links{overflow-x:auto}
  .nav .links a{font-size:13px;padding:4px 8px}
}
