:root { --bg: #f8fafc; --panel: #ffffff; --line: #e2e8f0; --text: #1e293b; --muted: #64748b; --accent: #2563eb; --accent-2: #1d4ed8; --accent-soft: #eff6ff; } * { box-sizing: border-box; } body { margin: 0; background: var(--bg); color: var(--text); font-family: Inter, "PingFang SC", "Noto Sans SC", "Microsoft YaHei", sans-serif; height: 100vh; overflow: hidden; } body.simple-page { height: auto; min-height: 100vh; overflow: auto; } .topbar { max-width: 1240px; height: 72px; margin: 0 auto; padding: 0 20px; display: flex; justify-content: space-between; align-items: center; } .brand h1 { margin: 0; font-size: 32px; letter-spacing: -0.02em; } .brand .muted { margin: 6px 0 0; } .badge { font-size: 12px; font-weight: 700; color: #fafafa; background: #334155; border: 1px solid #334155; padding: 5px 10px; border-radius: 999px; } .topbar-actions { display: flex; align-items: center; gap: 8px; flex-wrap: wrap; justify-content: flex-end; } .wechat-account-switch { display: flex; align-items: center; gap: 8px; flex-wrap: wrap; max-width: min(420px, 100%); } .wechat-account-label { font-size: 13px; font-weight: 600; color: var(--muted); white-space: nowrap; } .topbar-select { min-width: 160px; max-width: 260px; flex: 1 1 auto; font: inherit; font-size: 13px; font-weight: 600; color: var(--text); border: 1px solid #cbd5e1; border-radius: 10px; padding: 8px 10px; background: #fff; cursor: pointer; } .topbar-select:disabled { opacity: 0.65; cursor: not-allowed; } .wechat-account-status { max-width: 140px; overflow: hidden; text-overflow: ellipsis; white-space: nowrap; } .topbar-btn { width: auto; margin-top: 0; white-space: nowrap; } .subtle-link { display: inline-block; text-decoration: none; color: var(--accent-2); border: 1px solid #cbd5e1; border-radius: 10px; padding: 8px 12px; background: #fff; font-size: 13px; font-weight: 700; } .simple-wrap { max-width: 760px; margin: 48px auto; padding: 0 20px; } .simple-panel { overflow: visible; } .section-title { margin: 16px 0 4px; font-size: 16px; } .actions-inline { display: flex; gap: 8px; align-items: end; justify-content: flex-end; } .check-row { margin-top: 10px; display: flex; justify-content: space-between; align-items: center; gap: 10px; flex-wrap: wrap; } .check-label { margin: 0; display: inline-flex; align-items: center; gap: 8px; font-size: 13px; font-weight: 600; color: var(--muted); } .check-label input[type="checkbox"] { width: 16px; height: 16px; } .layout { max-width: 1240px; height: calc(100vh - 72px); margin: 0 auto; padding: 0 20px; display: grid; grid-template-columns: minmax(320px, 42%) 1fr; gap: 12px; overflow: hidden; } .panel { background: var(--panel); border: 1px solid var(--line); border-radius: 12px; padding: 14px; box-shadow: 0 6px 18px rgba(15, 23, 42, 0.05); min-height: 0; overflow: hidden; } h1, h2 { margin-top: 0; } .panel-head { margin-bottom: 10px; } .panel-head h2 { margin: 0; font-size: 18px; } .muted { color: var(--muted); margin-top: 2px; } label { display: block; margin-top: 8px; margin-bottom: 4px; font-size: 13px; font-weight: 600; } .field-head { display: flex; justify-content: space-between; align-items: baseline; } .multi-field .field-head label { margin-top: 0; } .multi-field { min-width: 0; } .multi-dropdown { width: 100%; } .multi-dropdown > summary { list-style: none; cursor: pointer; border: 1px solid var(--line); border-radius: 10px; padding: 8px 10px; font-size: 13px; font-weight: 600; background: #fff; display: flex; justify-content: space-between; align-items: center; gap: 8px; transition: border-color 0.2s ease, box-shadow 0.2s ease; } .multi-dropdown > summary::-webkit-details-marker { display: none; } .multi-dropdown > summary::after { content: ""; width: 0; height: 0; border-left: 5px solid transparent; border-right: 5px solid transparent; border-top: 6px solid var(--muted); flex-shrink: 0; transition: transform 0.15s ease; } .multi-dropdown[open] > summary::after { transform: rotate(180deg); } .multi-dropdown[open] > summary { border-color: var(--accent); box-shadow: 0 0 0 3px var(--accent-soft); } .multi-dropdown-text { flex: 1; min-width: 0; overflow: hidden; text-overflow: ellipsis; white-space: nowrap; font-weight: 600; color: var(--text); } .multi-dropdown-body { margin-top: 4px; border: 1px solid var(--line); border-radius: 10px; padding: 6px 4px; background: var(--panel); max-height: 200px; overflow-y: auto; box-shadow: 0 10px 28px rgba(15, 23, 42, 0.1); } .multi-dropdown-option { display: flex; align-items: center; gap: 8px; padding: 8px 10px; font-size: 13px; font-weight: 500; cursor: pointer; margin: 0; border-radius: 8px; width: auto; } .multi-dropdown-option:hover { background: var(--accent-soft); } .multi-dropdown-option input { width: auto; margin: 0; flex-shrink: 0; accent-color: var(--accent); } .multi-extra { margin-top: 4px; } .meta { color: var(--muted); font-size: 12px; } input, select, textarea, button { width: 100%; border-radius: 10px; border: 1px solid var(--line); padding: 8px 10px; font-size: 13px; transition: border-color 0.2s ease, box-shadow 0.2s ease, background-color 0.2s ease; } textarea { resize: vertical; line-height: 1.5; } input:focus, select:focus, textarea:focus { outline: none; border-color: #93c5fd; box-shadow: 0 0 0 3px rgba(37, 99, 235, 0.12); } button { cursor: pointer; margin-top: 8px; font-weight: 700; } button:hover { filter: brightness(0.98); } button.primary { background: var(--accent); color: #fff; border-color: var(--accent); } button.primary:hover { background: var(--accent-2); } button.secondary { background: #fff; color: var(--text); border-color: var(--line); } button.secondary:hover { background: #f8fdff; } .subtle-btn { background: #fff; border-color: #cbd5e1; color: var(--accent-2); } button:disabled { cursor: not-allowed; opacity: 0.65; } .actions { display: grid; grid-template-columns: 1fr 1fr; gap: 10px; } .grid2 { display: grid; grid-template-columns: 1fr 1fr; gap: 10px; } .cover-tools { display: grid; grid-template-columns: 1fr auto; gap: 8px; align-items: center; } .cover-tools button { margin-top: 0; width: auto; white-space: nowrap; } .status { min-height: 18px; margin-top: 6px; color: var(--accent-2); font-weight: 500; font-size: 12px; } .small { font-size: 12px; margin: 0 0 6px; } .body-split { display: grid; grid-template-columns: 1fr 0.9fr; gap: 10px; align-items: stretch; min-height: 0; } .body-split textarea { min-height: 170px; max-height: 240px; } .preview-panel { display: flex; flex-direction: column; min-width: 0; } .markdown-preview { flex: 1; min-height: 170px; max-height: 240px; overflow: auto; padding: 10px 12px; border: 1px solid var(--line); border-radius: 10px; background: #fafcfb; font-size: 14px; line-height: 1.65; } .markdown-preview h2 { font-size: 1.15rem; margin: 1em 0 0.5em; color: #111827; } .markdown-preview h3 { font-size: 1.05rem; margin: 0.9em 0 0.4em; } .markdown-preview p { margin: 0.5em 0; } .markdown-preview ul, .markdown-preview ol { margin: 0.4em 0 0.6em 1.2em; padding: 0; } .markdown-preview li { margin: 0.25em 0; } @media (max-width: 960px) { body { overflow: auto; } .layout { grid-template-columns: 1fr; height: auto; } .body-split { grid-template-columns: 1fr; } .topbar { align-items: flex-start; gap: 8px; flex-direction: column; } .topbar-actions { width: 100%; justify-content: space-between; } .actions-inline { justify-content: flex-start; align-items: center; margin-top: 8px; } }