@import url('https://fonts.googleapis.com/css2?family=Fraunces:opsz,wght@9..144,400;9..144,500;9..144,600&family=Space+Grotesk:wght@400;500;600;700&family=Newsreader:opsz,wght@6..72,400;6..72,500&display=swap');

:root{
  /* 暖纸白 + 墨绿编辑风（去 AI 味：衬线标题、克制单色、发丝边框） */
  --bg:#F6F3EA; --card:#FFFDF8; --soft:#EFEBDF; --line:#E2DCCC;
  --text:#1B1E18; --muted:#6C6F63; --faint:#9B9C8C;
  --accent:#1F4D3A; --accent2:#2E6B50; --accentsoft:#E6EFE7;
  --green:#1f7a52; --greenbg:#E6F1E8; --greenline:#bfd9c5;
  --red:#b23b2e; --redbg:#F6E7E2; --redline:#e6c3b9;
  --amber:#9a6a12; --amberbg:#F6ECD8; --amberline:#e6d3a8;
  --radius:12px; --radius-lg:16px;
  --shadow:0 1px 2px rgba(27,30,24,.05);
  --font-ui:"Space Grotesk",-apple-system,"Segoe UI","Microsoft YaHei",sans-serif;
  --font-display:"Fraunces",Georgia,"Songti SC",serif;
  --font-read:"Newsreader",Georgia,"Songti SC",serif;
}
*{box-sizing:border-box}
body{margin:0;background:var(--bg);color:var(--text);
  font-family:var(--font-ui);font-size:14px;line-height:1.6;-webkit-font-smoothing:antialiased}
h1,h2,h3{font-family:var(--font-display);font-weight:500;letter-spacing:-0.01em}
a{color:var(--accent);text-decoration:none}
.wrap{max-width:900px;margin:0 auto;padding:24px 20px 100px}
.muted{color:var(--muted)} .small{font-size:12px}

/* 顶部导航 */
.nav{display:flex;align-items:center;gap:12px;max-width:900px;margin:0 auto;padding:18px 20px;border-bottom:1px solid var(--line)}
.nav .logo{width:32px;height:32px;border-radius:8px;background:var(--accent);
  display:flex;align-items:center;justify-content:center;color:#F6F3EA;font-family:var(--font-display);font-weight:600;font-size:14px}
.nav .brand{font-family:var(--font-display);font-weight:600;font-size:16px}
.nav .grow{flex:1}
.nav a.navlink{color:var(--muted);font-size:13px;padding:6px 10px;border-radius:8px}
.nav a.navlink:hover{background:var(--soft);color:var(--text)}
.nav .keybtn{background:transparent;border:1px solid var(--line);border-radius:9px;padding:7px 13px;font-size:13px;cursor:pointer;color:var(--text);font-family:var(--font-ui)}
.nav .keybtn:hover{background:var(--soft)}
.nav .keybtn.warn{border-color:var(--amberline);background:var(--amberbg);color:var(--amber)}

button{background:var(--accent);border:1px solid var(--accent);border-radius:9px;color:#F6F3EA;font-weight:500;font-family:var(--font-ui);
  padding:10px 20px;font-size:14px;cursor:pointer;transition:background .15s,transform .05s}
button:hover{background:var(--accent2);border-color:var(--accent2)} button:active{transform:scale(.99)} button:disabled{opacity:.5;cursor:default}
input,select,textarea{background:var(--card);border:1px solid var(--line);border-radius:9px;color:var(--text);
  padding:9px 11px;font-size:14px;outline:none;font-family:var(--font-ui);transition:border .15s,box-shadow .15s}
input:focus,select:focus,textarea:focus{border-color:var(--accent);box-shadow:0 0 0 3px var(--accentsoft)}
.panel{background:var(--card);border:1px solid var(--line);border-radius:var(--radius-lg);box-shadow:var(--shadow)}

/* key 设置弹窗 */
#keys-modal{display:none;position:fixed;inset:0;z-index:50}
#keys-modal .km-bg{position:absolute;inset:0;background:rgba(27,30,24,.42)}
#keys-modal .km-card{position:relative;max-width:440px;margin:12vh auto;background:var(--card);border-radius:var(--radius-lg);
  padding:24px;box-shadow:0 24px 70px rgba(27,30,24,.28);border:1px solid var(--line)}
#keys-modal .km-h{font-family:var(--font-display);font-size:19px;font-weight:600;margin-bottom:6px}
#keys-modal .km-sub{color:var(--muted);font-size:12px;margin:0 0 16px;line-height:1.6}
#keys-modal label{display:block;font-size:12px;font-weight:500;margin:12px 0 5px}
#keys-modal label a{font-weight:400;font-size:11px}
#keys-modal input{width:100%}
#keys-modal .km-btns{display:flex;justify-content:flex-end;gap:8px;margin-top:20px}
#keys-modal .km-ghost{background:transparent;border:1px solid var(--line);color:var(--muted)}
