📜 小乖AIGC
AI图文知识卡片
持续更新中 · 2026.05
小乖
AIGC
📦 AI图文知识卡片 · 共14款工具
小乖
AIGC
图文知识卡片
一键生成图文提示词 · 三平台文案全搞定 · 持续更新中
🧭 使用流程(具体操作请以各工具内说明为准)
1
点击下方工具卡片打开
→
2
按工具内说明选好内容点生成
→
3
复制图片提示词发Claude/即梦/香蕉Pro出图
→
4
出图后复制文案提示词发Claude生成三平台文案
📚 古诗图解系列
统编版语文
📖
免费
V1
🆕 最近更新
古诗图解 · 小学版
统编版1-6年级上下册全部篇目,水彩Q版风格,适合家长和小学语文老师使用。
小学1-6年级
水彩Q版
2026.04
→
📗
V2
完整版
🆕 最近更新
古诗图解 · 完整版
小学+初中全覆盖,初中按单元组织,水墨写实风格,适合初中老师备课使用。
小学+初中
水墨写实
2026.04
→
🎓
规划中
古诗图解 · 高中版
统编版高中必修+选择性必修全部篇目,水墨工笔风格,适合高中老师备课。
高中全册
→
📋 知识卡片系列
图文创作
📚
免费
V1
🆕 最近更新
小学知识卡片生成器 V1
小学各科知识卡片制作工具基础版,语文成语、数学、英语、科学、思维导图五大学科覆盖。
小学学科
五大学科
2026.04
→
🎓
V2
热门
小学知识卡片生成器 V2
全面升级版,联网查教材重难点,更多学科风格,提示词更精准,体验大幅提升。
联网查教材
全面升级
2026.04
→
🏭
V1
各行业知识卡片工坊
餐饮、医疗、法律、宣传等二十多个行业知识卡片生成,专业内容创作首选。
多行业
20+行业
2026.04
→
📝
四级
英语四级词汇记忆图
四级词汇场景连环画记忆图,用故事画面帮助记忆单词,告别死记硬背。
英语四级
连环画记忆
2026.04
→
📖
规划中
英语六级词汇记忆图
六级高频词汇场景记忆图,配合四级版形成完整英语备考体系。
英语六级
→
✨ 图文创作系列
内容创作
🍵
多模块
AI 图文创作套件
养生茶饮、手绘食谱、知识科普、历史图鉴四大模块一键出图,内容创作一站搞定。
四大模块
一键出图
2026.04
→
🍎
V2
新上线
食物的一生
食物从种植到餐桌的完整旅程图解,科普+美食双结合,高传播内容神器。
食物科普
图文创作
2026.04
→
🌿
节气
廿四节气图文工坊
二十四节气全套图文创作工具,解说、习俗、食单、习语一总出,节气内容一网打尽。
二十四节气
图文全套
2026.04
→
🏛️
V1
历史文化图文工坊
历史人物、底蕴文化图文创作,企业历史、人物依传、文化科普一键生成提示词。
历史人物
图文创作
2026.04
→
🏆
爆款
争议榜单图鉴
各类争议性榜单图鉴提示词生成,话题性强,三平台文案一键生成,适合做高传播内容。
榜单图鉴
高传播
2026.04
→
🗺️
新上线
🔥热门
城市文化图文工坊
城市名片·地道美食·非遗手艺·方言梗图,30+热门城市预置,联网查资料出图,城市文旅内容创作神器。
城市文化
方言梗图
2026.05
→
🌸 博物科普系列
科普创作
🌿
中药
一天认识一味中药
中药图文提示词生成工具,每天一味中药,功效、炮制、食用方法图文并茂,科普创作必备。
中药科普
联网核实
2026.04
→
🌸
花卉
每天认识一种花
花卉图文提示词生成工具,花语、习性、养护一图搞定,打造高颜值花卉科普内容。
花卉科普
图文创作
2026.04
→
💬 反馈与建议
使用中有任何问题 / 想加新功能 / 想看新工具
欢迎关注公众号
【凡之有料】
留言反馈
← 返回工具中心
<!DOCTYPE html>
<html lang="zh-CN">
<head>
<meta charset="UTF-8">
<meta name="viewport" content="width=device-width, initial-scale=1.0">
<title>古诗图解提示词工坊 · V1小学版</title>
<style>
*{box-sizing:border-box;margin:0;padding:0}
:root{
  --bg:#fdf6e9;--card:#fffdf7;--border:#e8d9b8;
  --red:#8b1a1a;--red2:#c0392b;--red-light:#fdecea;
  --gold:#c8920a;--gold-light:#fef9e7;
  --ink:#1a1208;--ink2:#4a3820;--ink3:#8a7050;
  --nav:#1a0a00;--scroll:#f5e6c8;
}
body{background:var(--bg);font-family:'PingFang SC','STKaiti','Microsoft YaHei',serif;color:var(--ink);min-height:100vh}

.top-nav{background:var(--nav);color:#d4a96a;text-align:center;padding:10px 20px;font-size:12px;letter-spacing:4px;display:flex;align-items:center;justify-content:center;gap:12px}
.dot{opacity:.4}
.ver{background:#8b1a1a;color:#fde8d0;padding:2px 10px;border-radius:10px;font-size:11px;letter-spacing:2px}

.hero{text-align:center;padding:28px 20px 20px;border-bottom:2px solid var(--border);position:relative}
.hero::after{content:'';position:absolute;bottom:-2px;left:50%;transform:translateX(-50%);width:60px;height:3px;background:var(--red)}
.hero-badge{display:inline-flex;align-items:center;gap:6px;background:var(--red-light);border:1px solid #e8b0a8;border-radius:4px;padding:4px 14px;font-size:12px;color:var(--red);letter-spacing:2px;margin-bottom:12px}
.hero h1{font-size:26px;font-weight:900;color:var(--ink);letter-spacing:3px;margin-bottom:4px}
.hero h1 span{color:var(--red)}
.hero-desc{font-size:12px;color:var(--ink3);letter-spacing:2px}

.main{max-width:700px;margin:0 auto;padding:16px 20px 60px}

/* 折叠卡片 */
.fold-card{background:var(--card);border:1px solid var(--border);border-radius:6px;margin-bottom:10px;overflow:hidden}
.fold-hd{display:flex;align-items:center;justify-content:space-between;padding:13px 18px;cursor:pointer;transition:background .15s}
.fold-hd:hover{background:var(--gold-light)}
.fold-hd-l{display:flex;align-items:center;gap:8px;font-size:13px;font-weight:700;color:var(--ink2);letter-spacing:1px}
.fold-tog{font-size:18px;color:var(--ink3);font-weight:300}
.fold-bd{display:none;padding:4px 18px 16px;border-top:1px solid var(--border)}
.fold-bd.open{display:block}
.step-row{display:flex;align-items:flex-start;gap:10px;margin-top:10px;font-size:12px;color:var(--ink2);line-height:1.9}
.step-num{width:20px;height:20px;border-radius:50%;background:var(--red);color:#fff;font-size:11px;font-weight:700;display:flex;align-items:center;justify-content:center;flex-shrink:0;margin-top:2px}
.info-tip{background:var(--gold-light);border-radius:6px;padding:10px 12px;margin-top:10px;font-size:12px;color:var(--ink2);line-height:1.9;border:1px solid #f0d888}

/* 注意事项 */
.notice-card{background:#fef8ec;border:1px solid #f0d890;border-radius:6px;padding:14px 18px;margin-bottom:10px}
.notice-title{font-size:13px;font-weight:700;color:#8a5a10;margin-bottom:8px;letter-spacing:1px}
.notice-list{list-style:none}
.notice-list li{font-size:12px;color:#7a5010;line-height:2.1;padding-left:14px;position:relative}
.notice-list li::before{content:'·';position:absolute;left:4px;font-size:16px;line-height:1.4}

/* 选择区 */
.sel-card{background:var(--card);border:1px solid var(--border);border-radius:6px;padding:18px 20px;margin-bottom:10px}
.sec-label{font-size:13px;font-weight:700;color:var(--ink2);margin-bottom:12px;letter-spacing:1px;display:flex;align-items:center;gap:8px}
.sec-label::before{content:'';width:4px;height:16px;background:var(--red);border-radius:2px}

.grade-tags{display:flex;flex-wrap:wrap;gap:8px;margin-bottom:16px}
.grade-tag{padding:7px 16px;border-radius:4px;border:1px solid var(--border);background:var(--scroll);font-size:13px;color:var(--ink2);cursor:pointer;font-family:inherit;transition:all .15s;letter-spacing:1px}
.grade-tag:hover{background:var(--gold-light);border-color:var(--gold)}
.grade-tag.active{background:var(--red);border-color:var(--red);color:#fff}

.book-btns{display:flex;gap:8px;margin-bottom:16px}
.book-btn{padding:8px 24px;border-radius:4px;border:1px solid var(--border);background:var(--scroll);font-size:13px;color:var(--ink2);cursor:pointer;font-family:inherit;transition:all .15s;letter-spacing:1px}
.book-btn:hover{background:var(--gold-light);border-color:var(--gold)}
.book-btn.active{background:var(--red);border-color:var(--red);color:#fff}

.poem-group-label{font-size:11px;color:var(--ink3);margin-bottom:8px;letter-spacing:2px;display:flex;align-items:center;gap:8px}
.poem-group-label::after{content:'';flex:1;height:1px;background:var(--border)}
.poem-tags{display:flex;flex-wrap:wrap;gap:7px;margin-bottom:14px}
.poem-tag{padding:6px 14px;border-radius:4px;border:1px solid var(--border);background:var(--scroll);font-size:12px;color:var(--ink2);cursor:pointer;font-family:inherit;transition:all .15s;letter-spacing:.5px}
.poem-tag:hover{background:var(--red-light);border-color:#e8b0a8;color:var(--red)}
.poem-tag.sel{background:var(--red);border-color:var(--red);color:#fff}

.selected-info{background:var(--gold-light);border:1px solid #f0d888;border-radius:4px;padding:8px 14px;font-size:12px;color:var(--ink2);margin-bottom:12px;line-height:1.8;display:none}
.selected-info b{color:var(--gold)}

.btn-gen{width:100%;padding:13px;background:var(--red);color:#fff;border:none;border-radius:6px;font-size:15px;font-weight:700;font-family:inherit;cursor:pointer;letter-spacing:3px;transition:background .2s}
.btn-gen:hover{background:var(--red2)}
.btn-gen:disabled{background:#c8b890;cursor:not-allowed}

/* 结果区 */
.result-area{display:none}
.result-card{background:var(--card);border:1px solid var(--border);border-radius:6px;padding:18px 20px;margin-bottom:10px}
.result-hd{display:flex;align-items:center;justify-content:space-between;margin-bottom:12px}
.result-title{display:flex;align-items:center;gap:8px;font-size:13px;font-weight:700;color:var(--ink2);letter-spacing:1px}
.result-title::before{content:'';width:4px;height:16px;background:var(--red);border-radius:2px}
.result-title.gold::before{background:var(--gold)}
.btn-copy{padding:5px 14px;background:var(--scroll);border:1px solid var(--border);border-radius:4px;font-size:12px;color:var(--ink2);cursor:pointer;font-family:inherit;transition:all .2s}
.btn-copy:hover{background:var(--gold-light);border-color:var(--gold)}
.btn-copy.copied{background:#d4e8c0;border-color:#80c060;color:#2a6010}
.prompt-box{background:var(--scroll);border:1px solid var(--border);border-radius:6px;padding:14px;font-size:12px;color:var(--ink2);line-height:2;white-space:pre-wrap;word-break:break-all;user-select:text;max-height:500px;overflow-y:auto}
.prompt-tip{margin-top:8px;font-size:11px;color:var(--ink3);background:var(--gold-light);padding:7px 12px;border-radius:4px;line-height:1.8;border:1px solid #f0d888}

footer{text-align:center;padding:24px 20px 40px;border-top:1px solid var(--border);margin-top:10px}
.footer-logo{font-size:15px;font-weight:900;color:var(--ink);letter-spacing:3px;margin-bottom:4px}
.footer-sub{font-size:12px;color:var(--ink3);letter-spacing:1px;margin-bottom:14px}
.footer-copy{font-size:11px;color:#a09070;line-height:2.2}
.footer-copy b{color:var(--ink3)}

@keyframes fadeUp{from{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}
.fade-up{animation:fadeUp .3s ease}
/* ===== Tab切换样式 ===== */
.result-tabs{display:flex;gap:0;border-bottom:2px solid var(--border);margin-bottom:0}
.result-tab{padding:10px 18px;font-size:12px;font-weight:700;color:var(--ink3);cursor:pointer;border:none;background:none;font-family:inherit;letter-spacing:1px;border-bottom:2px solid transparent;margin-bottom:-2px;transition:all .2s}
.result-tab.active{color:var(--red);border-bottom-color:var(--red)}
.result-tab:hover{color:var(--ink2)}
.result-pane{display:none}.result-pane.active{display:block}

</style>
</head>
<body>

<div class="top-nav">
  <span>古诗图解</span><span class="dot">·</span>
  <span>提示词工坊</span><span class="dot">·</span>
  <span class="ver">V1 · 小学版</span>
</div>

<div class="hero">
  <div class="hero-badge">📚 统编版小学语文 · 1-6年级 · 上下册全覆盖</div>
  <h1>古诗<span>图解</span>提示词生成器</h1>
  <div style="font-size:13px;color:var(--ink2);margin:4px 0 6px;font-weight:600">V1 · 小学免费版</div>
  <div class="hero-desc">选年级 · 选上下册 · 选古诗 · 一键生成框架提示词</div>
</div>

<div class="main">

  <!-- 使用说明 -->
  <div class="fold-card">
    <div class="fold-hd" onclick="toggleFold(this)">
      <div class="fold-hd-l">📖 使用说明 · 四步完成出图</div>
      <div class="fold-tog">+</div>
    </div>
    <div class="fold-bd">
      <div class="step-row"><div class="step-num">1</div><div>在下方选年级 → 选上/下册 → 勾选要做的古诗（可多选，建议3-6首做一个合集）</div></div>
      <div class="step-row"><div class="step-num">2</div><div>点「生 成」→ 复制<b style="color:var(--red)">图片框架提示词</b> → 发给<b style="color:var(--red)">开联网的Claude或DeepSeek</b>，让它查资料后输出完整出图提示词</div></div>
      <div class="step-row"><div class="step-num">3</div><div>复制Claude输出的完整提示词 → 发给<b style="color:var(--red)">香蕉Pro</b> → 比例选 <b style="color:var(--red)">3:4 竖版</b> → 出图</div></div>
      <div class="step-row"><div class="step-num">4</div><div>出完图后 → 复制<b style="color:var(--red)">三平台文案提示词</b> → 把图片+文案提示词一起发给Claude → 输出视频号+小红书+抖音三套文案</div></div>
      <div class="info-tip">💡 <b>为什么要先发给Claude？</b>工具只内置了各册的古诗篇目，作者背景、逐句解析、注释等内容由Claude联网查询后填入，确保内容准确。</div>
    </div>
  </div>

  <!-- 注意事项 -->
  <div class="notice-card">
    <div class="notice-title">⚠️ 使用前请阅读</div>
    <ul class="notice-list">
      <li>本工具篇目数据基于<b>统编版（人教版）小学语文教材</b>，数据有一定滞后性，以实际教材为准</li>
      <li>发给Claude时请<b>开启联网功能</b>，否则资料不准确，图里内容会出错</li>
      <li>建议每次选 <b>3-6首</b> 做一个合集，太少没有封面价值</li>
      <li>出图后请自行核对诗句和注释的准确性</li>
      <li>本工具版权归 <b>阿坚AIGC</b> 所有，仅供个人创作使用，禁止商业转载</li>
    </ul>
  </div>

  <!-- 选择区 -->
  <div class="sel-card">
    <div class="sec-label">第一步：选择年级</div>
    <div class="grade-tags" id="gradeTags">
      <button class="grade-tag" data-g="一年级">一年级</button>
      <button class="grade-tag" data-g="二年级">二年级</button>
      <button class="grade-tag" data-g="三年级">三年级</button>
      <button class="grade-tag" data-g="四年级">四年级</button>
      <button class="grade-tag" data-g="五年级">五年级</button>
      <button class="grade-tag" data-g="六年级">六年级</button>
    </div>

    <div id="bookSection" style="display:none">
      <div class="sec-label">第二步：选择上/下册</div>
      <div class="book-btns">
        <button class="book-btn" data-b="上册">上册</button>
        <button class="book-btn" data-b="下册">下册</button>
      </div>
    </div>

    <div id="poemSection" style="display:none">
      <div class="sec-label">第三步：选择古诗（可多选）</div>
      <div id="poemList"></div>
      <div class="selected-info" id="selectedInfo"></div>
    </div>

    <button class="btn-gen" id="btnGen" onclick="generate()" disabled>生　成</button>
  </div>

  <!-- 结果区 -->
  <div class="result-area" id="resultArea">
    <div class="result-card">
      <div class="result-tabs">
        <button class="result-tab active" onclick="switchTab('img',this)">📋 图片框架提示词</button>
        <button class="result-tab" onclick="switchTab('wx',this)">📝 三平台文案提示词</button>
      </div>
      <div class="result-pane active" id="pane-img">
        <div class="result-hd" style="margin-top:14px">
          <div class="result-title">📋 图片框架提示词（发给Claude联网查资料用）</div>
          <button class="btn-copy" onclick="copyPrompt('promptImg', this)">一键复制</button>
        </div>
        <div class="prompt-box" id="promptImg"></div>
        <div class="prompt-tip">💡 复制后发给<b>开联网的Claude或DeepSeek</b>，让它联网查资料后填空输出完整出图提示词，再去香蕉Pro出图，比例 <b>3:4 竖版</b></div>
      </div>
      <div class="result-pane" id="pane-wx">
        <div class="result-hd" style="margin-top:14px">
          <div class="result-title gold">📝 三平台文案提示词（出完图后使用）</div>
          <button class="btn-copy" onclick="copyPrompt('promptWx', this)">一键复制</button>
        </div>
        <div class="prompt-box" id="promptWx"></div>
        <div class="prompt-tip">💡 出完图后，把<b>图片 + 这段提示词</b>一起发给Claude → 输出<b>视频号+小红书+抖音</b>三套文案</div>
      </div>
    </div>
  </div>

</div>

<footer>
  <div class="footer-logo">📜 古诗图解</div>
  <div class="footer-sub">提示词工坊 · V1 · 小学免费版 · 统编版1-6年级全册</div>
  <div class="footer-copy">
    版权所有 © <b>阿坚AIGC</b><br>
    篇目数据基于统编版小学语文教材，有一定滞后性，以实际教材为准<br>
    本工具仅供授权用户个人创作使用，<b>禁止商业转载与二次分发</b>
  </div>
</footer>

<script>
// =============================================
// 数据库：只存篇目信息 + 色调关键词
// 色调只作为提示词中的风格参考，不写死内容
// =============================================
const DB = {
  '一年级': {
    '上册': [
      {name:'咏鹅', author:'唐·骆宾王', color:'清新黄绿'},
      {name:'江南', author:'汉乐府', color:'水绿清新'},
      {name:'画', author:'唐·王维', color:'淡墨青绿'},
      {name:'静夜思', author:'唐·李白', color:'深蓝月色'},
      {name:'寻隐者不遇', author:'唐·贾岛', color:'深绿幽静'},
    ],
    '下册': [
      {name:'春晓', author:'唐·孟浩然', color:'粉绿清新'},
      {name:'赠汪伦', author:'唐·李白', color:'青灰惆怅'},
      {name:'池上', author:'唐·白居易', color:'清新黄绿'},
      {name:'小池', author:'宋·杨万里', color:'清新碧绿'},
      {name:'悯农（其二）', author:'唐·李绅', color:'暖黄田野'},
      {name:'古朗月行（节选）', author:'唐·李白', color:'深蓝月色'},
    ]
  },
  '二年级': {
    '上册': [
      {name:'梅花', author:'宋·王安石', color:'冷白雪色'},
      {name:'小儿垂钓', author:'唐·胡令能', color:'清新黄绿'},
      {name:'登鹳雀楼', author:'唐·王之涣', color:'橙金壮阔'},
      {name:'望庐山瀑布', author:'唐·李白', color:'青碧壮阔'},
      {name:'江雪', author:'唐·柳宗元', color:'冷蓝白雪'},
      {name:'敕勒歌', author:'北朝民歌', color:'碧绿草原'},
    ],
    '下册': [
      {name:'村居', author:'清·高鼎', color:'粉绿春日'},
      {name:'咏柳', author:'唐·贺知章', color:'嫩绿清新'},
      {name:'晓出净慈寺送林子方', author:'宋·杨万里', color:'碧绿荷香'},
      {name:'绝句', author:'唐·杜甫', color:'明亮黄绿'},
      {name:'悯农（其一）', author:'唐·李绅', color:'暖黄烈日'},
      {name:'赋得古原草送别', author:'唐·白居易', color:'青绿苍茫'},
    ]
  },
  '三年级': {
    '上册': [
      {name:'山行', author:'唐·杜牧', color:'橙红秋色'},
      {name:'赠刘景文', author:'宋·苏轼', color:'橙金暖秋'},
      {name:'夜书所见', author:'宋·叶绍翁', color:'深蓝秋夜'},
      {name:'望天门山', author:'唐·李白', color:'青碧壮阔'},
      {name:'饮湖上初晴后雨', author:'宋·苏轼', color:'碧绿烟雨'},
      {name:'望洞庭', author:'唐·刘禹锡', color:'银白秋月'},
    ],
    '下册': [
      {name:'绝句', author:'唐·杜甫', color:'明亮黄绿'},
      {name:'惠崇春江晚景', author:'宋·苏轼', color:'粉绿春色'},
      {name:'三衢道中', author:'宋·曾几', color:'清新绿色'},
      {name:'元日', author:'宋·王安石', color:'红色喜庆'},
      {name:'清明', author:'唐·杜牧', color:'青灰烟雨'},
      {name:'九月九日忆山东兄弟', author:'唐·王维', color:'金秋暖色'},
      {name:'咏柳', author:'唐·贺知章', color:'嫩绿清新'},
      {name:'春日', author:'宋·朱熹', color:'粉绿生机'},
      {name:'乞巧', author:'唐·林杰', color:'深蓝星空'},
      {name:'嫦娥', author:'唐·李商隐', color:'深蓝月夜'},
    ]
  },
  '四年级': {
    '上册': [
      {name:'暮江吟', author:'唐·白居易', color:'橙金傍晚'},
      {name:'题西林壁', author:'宋·苏轼', color:'青绿山色'},
      {name:'雪梅', author:'宋·卢钺', color:'冷白雪色'},
      {name:'出塞', author:'唐·王昌龄', color:'黄沙苍凉'},
      {name:'凉州词', author:'唐·王翰', color:'黄沙苍凉'},
      {name:'夏日绝句', author:'宋·李清照', color:'深红豪迈'},
    ],
    '下册': [
      {name:'独坐敬亭山', author:'唐·李白', color:'青灰禅意'},
      {name:'忆江南', author:'唐·白居易', color:'水绿烟雨'},
      {name:'乡村四月', author:'宋·翁卷', color:'暖绿劳动'},
      {name:'四时田园杂兴（其二十五）', author:'宋·范成大', color:'清新绿色'},
      {name:'渔歌子', author:'唐·张志和', color:'水绿烟雨'},
      {name:'塞下曲', author:'唐·卢纶', color:'冷月苍凉'},
      {name:'芙蓉楼送辛渐', author:'唐·王昌龄', color:'青灰送别'},
    ]
  },
  '五年级': {
    '上册': [
      {name:'泊船瓜洲', author:'宋·王安石', color:'青灰月色'},
      {name:'秋思', author:'唐·张籍', color:'金秋惆怅'},
      {name:'长相思', author:'清·纳兰性德', color:'冷蓝月色'},
      {name:'示儿', author:'宋·陆游', color:'深红家国'},
      {name:'题临安邸', author:'宋·林升', color:'沉郁灰红'},
      {name:'己亥杂诗', author:'清·龚自珍', color:'深红豪迈'},
    ],
    '下册': [
      {name:'牧童', author:'唐·吕岩', color:'橙金傍晚'},
      {name:'舟过安仁', author:'宋·杨万里', color:'暖黄绿色'},
      {name:'清平乐·村居', author:'宋·辛弃疾', color:'暖绿田园'},
      {name:'稚子弄冰', author:'宋·杨万里', color:'冷蓝冰雪'},
      {name:'村晚', author:'宋·雷震', color:'橙金傍晚'},
      {name:'四时田园杂兴（其三十一）', author:'宋·范成大', color:'暖黄绿色'},
      {name:'从军行', author:'唐·王昌龄', color:'黄沙苍凉'},
      {name:'秋夜将晓出篱门迎凉有感', author:'宋·陆游', color:'沉郁苍茫'},
      {name:'闻官军收河南河北', author:'唐·杜甫', color:'明亮喜悦'},
    ]
  },
  '六年级': {
    '上册': [
      {name:'宿建德江', author:'唐·孟浩然', color:'深蓝月色'},
      {name:'六月二十七日望湖楼醉书', author:'宋·苏轼', color:'墨色雨景'},
      {name:'西江月·夜行黄沙道中', author:'宋·辛弃疾', color:'深蓝月夜'},
      {name:'七律·长征', author:'毛泽东', color:'深红豪迈'},
      {name:'浪淘沙（其一）', author:'唐·刘禹锡', color:'黄沙壮阔'},
      {name:'江南春', author:'唐·杜牧', color:'粉绿烟雨'},
      {name:'书湖阴先生壁', author:'宋·王安石', color:'清新绿色'},
    ],
    '下册': [
      {name:'寒食', author:'唐·韩翃', color:'淡紫春色'},
      {name:'迢迢牵牛星', author:'汉·无名氏', color:'深蓝星空'},
      {name:'十五夜望月', author:'唐·王建', color:'深蓝月色'},
      {name:'马诗', author:'唐·李贺', color:'月白豪迈'},
      {name:'石灰吟', author:'明·于谦', color:'白灰坚毅'},
      {name:'竹石', author:'清·郑燮', color:'青绿劲竹'},
      {name:'回乡偶书', author:'唐·贺知章', color:'暖黄乡情'},
      {name:'游子吟', author:'唐·孟郊', color:'暖黄温情'},
    ]
  }
};

// =============================================
// 状态
// =============================================
let curGrade = '', curBook = '', selPoems = [];

// =============================================
// 折叠
// =============================================
function toggleFold(hd) {
  const bd = hd.nextElementSibling;
  const tog = hd.querySelector('.fold-tog');
  const open = bd.classList.toggle('open');
  tog.textContent = open ? '×' : '+';
}

// =============================================
// 年级选择
// =============================================
document.querySelectorAll('.grade-tag').forEach(btn => {
  btn.addEventListener('click', () => {
    document.querySelectorAll('.grade-tag').forEach(b => b.classList.remove('active'));
    btn.classList.add('active');
    curGrade = btn.dataset.g;
    curBook = '';
    selPoems = [];
    document.getElementById('bookSection').style.display = 'block';
    document.querySelectorAll('.book-btn').forEach(b => b.classList.remove('active'));
    document.getElementById('poemSection').style.display = 'none';
    document.getElementById('resultArea').style.display = 'none';
    document.getElementById('btnGen').disabled = true;
    updateSelectedInfo();
  });
});

// =============================================
// 上下册选择
// =============================================
document.querySelectorAll('.book-btn').forEach(btn => {
  btn.addEventListener('click', () => {
    document.querySelectorAll('.book-btn').forEach(b => b.classList.remove('active'));
    btn.classList.add('active');
    curBook = btn.dataset.b;
    selPoems = [];
    renderPoems();
    document.getElementById('resultArea').style.display = 'none';
    document.getElementById('btnGen').disabled = true;
    updateSelectedInfo();
  });
});

// =============================================
// 渲染诗列表
// =============================================
function renderPoems() {
  const section = document.getElementById('poemSection');
  const list = document.getElementById('poemList');
  const poems = DB[curGrade]?.[curBook] || [];

  section.style.display = 'block';
  list.innerHTML = `
    <div class="poem-group-label">${curGrade} · ${curBook} · 共 ${poems.length} 首</div>
    <div class="poem-tags">
      ${poems.map((p, i) => `<button class="poem-tag" data-i="${i}">${p.name}</button>`).join('')}
    </div>
  `;

  list.querySelectorAll('.poem-tag').forEach(btn => {
    btn.addEventListener('click', () => {
      const idx = parseInt(btn.dataset.i);
      const poem = poems[idx];
      const pos = selPoems.findIndex(p => p.name === poem.name);
      if (pos >= 0) {
        selPoems.splice(pos, 1);
        btn.classList.remove('sel');
      } else {
        selPoems.push(poem);
        btn.classList.add('sel');
      }
      updateSelectedInfo();
      document.getElementById('btnGen').disabled = selPoems.length === 0;
    });
  });
}

function updateSelectedInfo() {
  const el = document.getElementById('selectedInfo');
  if (selPoems.length === 0) {
    el.style.display = 'none';
  } else {
    el.style.display = 'block';
    el.innerHTML = `已选 <b>${selPoems.length}</b> 首：${selPoems.map(p => `「${p.name}」`).join(' ')}`;
  }
}

// =============================================
// 生成提示词
// =============================================
function generate() {
  if (selPoems.length === 0) return;

  const poemList = selPoems.map(p => `《${p.name}》${p.author}`).join('、');
  const poemNames = selPoems.map(p => `《${p.name}》`).join('、');

  // ---- 图片框架提示词 ----
  let imgPrompt = `你是一位专业的古诗图解设计师。

⚠️ 重要规则：你的任务是「填空」，不是「创作」。
请联网查询以下每首诗的资料，然后将查到的内容直接填入下方提示词的【】标注位置，输出完整的出图提示词。
除了填入【】内的内容，提示词的其他所有文字、结构、色调、格式，一字不改，原样保留输出。

【本次要做的古诗】
${selPoems.map((p, i) => `${i + 1}. 《${p.name}》${p.author}`).join('\n')}

【色调参考库】
查完每首诗的资料后，根据诗意从以下选择最匹配的色调，填入提示词对应位置：
· 粉绿清新 → 春日、生机、儿童、清新
· 暖黄绿色 → 田园、夏日、劳动、温暖
· 橙金傍晚 → 黄昏、夕阳、归家、温馨
· 深蓝月色 → 月夜、思乡、静谧、孤寂
· 深蓝星空 → 七夕、星夜、神话、浪漫
· 冷蓝冰雪 → 冬日、冰雪、寒冷、清骨
· 橙红秋色 → 秋日、霜叶、丰收、明艳
· 金秋惆怅 → 秋思、离别、异乡、惆怅
· 黄沙苍凉 → 边塞、沙漠、豪迈、壮阔
· 深红豪迈 → 家国、壮志、英雄、气概
· 青灰送别 → 送别、离别、依依、惆怅
· 水绿烟雨 → 江南、烟雨、温柔、朦胧
· 淡墨青绿 → 山水、禅意、宁静、空灵
· 白灰坚毅 → 咏物、气节、坚韧、傲骨
· 明亮喜悦 → 喜庆、欢快、明朗、积极

【需要联网查询的内容（每首诗都查，填入下方对应位置）】
- 完整原文（逐句，确保准确）
- 作者简介（2-3句，适合小学生理解）
- 创作背景（2-3句，贴近学生生活）
- 每句诗的白话翻译（口语化，小学生能理解）
- 针对这首诗设计3个背诵技巧名称+1-2句说明（与诗的具体内容直接对应，不要用通用模板）

════════════════════════════════════
请将以下提示词原样输出，只填入【】内的内容，其余一字不改：
════════════════════════════════════

═══════════════════════════
【封面图提示词】${curGrade}${curBook}古诗图解
═══════════════════════════
竖版3:4，水彩手绘古风风格，米黄宣纸底色，整体温馨古雅。
顶部：红色绸缎横幅，白色楷体文字「古诗词图解」，有布料质感和立体感。
标题：超大加粗楷体「${curGrade}${curBook}」，深墨色，占画面宽度约50%。
副标题：深红色小字「轻松背诵·趣味理解」。
人物：Q版古风小童子，5-6头身，浅蓝色汉服，发髻，左手捧线装古书，右手握大毛笔，表情可爱自信，与背景自然融合有光影。
背景：米黄宣纸底色，四角淡淡水墨桃花枝装饰，大量留白，整洁不杂乱。
右下角：红色方形古风印章「阿坚AIGC」，篆刻风格做旧质感。
画面文字只允许出现以下内容，不得生成任何其他文字：
  第一行：「古诗词图解」（红色横幅内）
  第二行：「${curGrade}${curBook}」（超大楷体）
  第三行：「轻松背诵·趣味理解」（深红色小字）
  第四行：「${poemList}」（小字列出收录篇目）
  印章：「阿坚AIGC」
除以上文字外，画面中不得出现任何其他中文、英文、数字或符号。
不要英文，不要其他水印。

（以下依次输出每首诗的解析图提示词）

${selPoems.map((p, i) => `═══════════════════════════
【第${i+1}首：《${p.name}》解析图提示词】
色调：【根据色调参考库，选出最匹配《${p.name}》的色调，填写色调名称及其氛围描述】
═══════════════════════════

整体【色调名称】贯穿全图，从背景到卷轴到每句插图色调完全统一，有「诗人站在自己的诗里」的氛围感，像精美的古风儿童绘本页面，竖版3:4，水彩手绘风格。

【顶部区块：约占25%】
背景：【根据《${p.name}》诗意，用1-2句描述这首诗意境对应的水彩背景画面，色调与上方选定色调一致】，大量留白，背景边缘水墨晕染自然过渡。
「古诗《${p.name}》」大字压在背景上，手写毛笔楷体有笔锋，白色描边深色字，字号极大，与背景融为一体。

作者介绍区左右分栏：
左侧（40%）：${p.author.replace('·','')}全身古风立绘，【朝代】文人形象，站在与诗意境契合的场景里，人物与背景自然融合，有真实光影关系。
右侧（60%）：米色边框文字块：
· 作者简介：【填入查到的${p.author}作者简介，2-3句，适合小学生理解】
· 创作背景：【填入查到的《${p.name}》创作背景，2-3句，贴近学生生活】

【中间区块：约占55%】
整体是一幅真实展开的古代画轴：两端有实体深木色圆柱卷轴棒，有真实木纹质感和阴影。纸面是深米黄偏褐色，像真正用了百年的古纸，有竖向自然折痕和淡淡墨迹晕染，有岁月感。顶部红色书签横幅，白字「解读版」，有绸缎质感。

按每句诗左右分栏排列（左65%文字，右35%插图），严格遵守字体层级：

【填入《${p.name}》完整原文，按每句格式输出，格式如下：

第X句：
左侧：超大加粗手写毛笔楷体「[诗句原文]」，字号极大（是白话解释的3倍），有笔锋
小字灰色标注「（[意象/手法标签，如：视觉/比喻/动作等]）」
中等字号白话：[该句白话解释，口语化，小学生能理解，括号内注明关键字注释]
右侧：对应场景的写实水彩插图，温馨生动，像儿童绘本插图，有背景有景深，整体与选定色调统一

（按以上格式，把《${p.name}》每一句都列出来）】

【底部区块：约占20%】
标题「背诵技巧」红色加粗。
三格并排竖向结构，每格有浅色背景：
每格：顶部与《${p.name}》诗意直接相关的圆形小图标 + 中间加粗大字技巧名称 + 底部1-2句说明

【填入针对《${p.name}》设计的3个背诵技巧：
格一：技巧名称「[名称]」/ 图标描述「[与该诗具体意象对应的图标]」/ 说明：[1-2句，直接对应诗中具体内容]
格二：技巧名称「[名称]」/ 图标描述「[与该诗具体意象对应的图标]」/ 说明：[1-2句，直接对应诗中具体内容]
格三：技巧名称「[名称]」/ 图标描述「[与该诗具体意象对应的图标]」/ 说明：[1-2句，直接对应诗中具体内容]】

右下角：红色方形古风印章，篆刻风格，内写「阿坚AIGC」，做旧质感。

整体要求：选定色调贯穿全图，卷轴纸面深米黄偏褐色有岁月感，两端有实体卷轴棒，插图写实水彩温馨生动，顶部大量留白水墨晕染，诗句超大手写毛笔楷体，不要英文，不要其他水印。`).join('\n\n')}`;

  // ---- 三平台文案提示词 ----
  let wxPrompt = `你是一位擅长三平台运营的AIGC内容创作者。
我上传了${selPoems.length + 1}张「${curGrade}${curBook}古诗图解」系列图（1张封面 + ${selPoems.length}张解析图），请根据图片内容同时输出三平台配套文案：

【图片内容】
${curGrade}${curBook}古诗图解合集，包含${poemNames}，封面+每首解析图，水彩手绘古风风格，温馨活泼，适合小学生和家长。

【受众】小学生家长、小学语文老师

【视频号文案】
- 标题：1个，不超过20字，有吸引力
- 正文：150字，口语化，家长/老师视角，有共鸣感
- 结尾：引导点赞收藏转发

【小红书文案】
- 备选标题：3个，带emoji，有收藏冲动，不超过20字
- 正文：200字，口语化，家长/老师视角，有共鸣感
- 结尾：引导收藏+评论互动
- 话题标签：15个，含 #古诗 #小学语文 #${curGrade} #古诗图解 #语文学习 等

【抖音文案】
- 备选标题：3个，带emoji，有点击欲，不超过20字
- 正文：150字，口语化，节奏感强，家长/老师视角
- 结尾：引导点赞收藏关注
- 话题标签：10个`;

  document.getElementById('promptImg').textContent = imgPrompt;
  document.getElementById('promptWx').textContent = wxPrompt;

  const ra = document.getElementById('resultArea');
  ra.style.display = 'block';
  ra.classList.remove('fade-up');
  void ra.offsetWidth;
  ra.classList.add('fade-up');
  ra.scrollIntoView({ behavior: 'smooth', block: 'start' });
}

// =============================================
// 复制
// =============================================

function switchTab(id, btn) {
  document.querySelectorAll('.result-tab').forEach(b => b.classList.remove('active'));
  document.querySelectorAll('.result-pane').forEach(p => p.classList.remove('active'));
  btn.classList.add('active');
  document.getElementById('pane-' + id).classList.add('active');
}
function copyPrompt(id, btn) {
  const text = document.getElementById(id).textContent;
  navigator.clipboard.writeText(text).then(() => {
    btn.textContent = '已复制 ✓';
    btn.classList.add('copied');
    setTimeout(() => { btn.textContent = '一键复制'; btn.classList.remove('copied'); }, 2000);
  }).catch(() => {
    const ta = document.createElement('textarea');
    ta.value = text;
    document.body.appendChild(ta);
    ta.select();
    try { document.execCommand('copy'); } catch(e) {}
    document.body.removeChild(ta);
    btn.textContent = '已复制 ✓';
    btn.classList.add('copied');
    setTimeout(() => { btn.textContent = '一键复制'; btn.classList.remove('copied'); }, 2000);
  });
}
</script>
</body>
</html>

<!DOCTYPE html>
<html lang="zh-CN">
<head>
<meta charset="UTF-8">
<meta name="viewport" content="width=device-width, initial-scale=1.0">
<title>古诗图解提示词工坊 · V2完整版</title>
<style>
*{box-sizing:border-box;margin:0;padding:0}
:root{
  --bg:#fdf6e9;--card:#fffdf7;--border:#e8d9b8;
  --red:#8b1a1a;--red2:#c0392b;--red-light:#fdecea;
  --gold:#c8920a;--gold-light:#fef9e7;
  --ink:#1a1208;--ink2:#4a3820;--ink3:#8a7050;
  --nav:#1a0a00;--scroll:#f5e6c8;
  --green:#1a4a1a;--green2:#2d6a2d;--green-light:#edf5ed;
}
body{background:var(--bg);font-family:'PingFang SC','STKaiti','Microsoft YaHei',serif;color:var(--ink);min-height:100vh}

.top-nav{background:var(--nav);color:#d4a96a;text-align:center;padding:10px 20px;font-size:12px;letter-spacing:4px;display:flex;align-items:center;justify-content:center;gap:12px}
.dot{opacity:.4}
.ver{background:#8b1a1a;color:#fde8d0;padding:2px 10px;border-radius:10px;font-size:11px;letter-spacing:2px}

.hero{text-align:center;padding:28px 20px 16px;border-bottom:2px solid var(--border);position:relative}
.hero::after{content:'';position:absolute;bottom:-2px;left:50%;transform:translateX(-50%);width:60px;height:3px;background:var(--red)}
.hero-badge{display:inline-flex;align-items:center;gap:6px;background:var(--red-light);border:1px solid #e8b0a8;border-radius:4px;padding:4px 14px;font-size:12px;color:var(--red);letter-spacing:2px;margin-bottom:10px}
.hero h1{font-size:26px;font-weight:900;color:var(--ink);letter-spacing:3px;margin-bottom:4px}
.hero h1 span{color:var(--red)}
.hero-desc{font-size:12px;color:var(--ink3);letter-spacing:2px}

/* 阶段Tab */
.stage-tabs{display:flex;gap:0;margin:16px 20px 0;max-width:700px;margin-left:auto;margin-right:auto;border-radius:6px;overflow:hidden;border:1px solid var(--border)}
.stage-tab{flex:1;padding:12px;text-align:center;cursor:pointer;font-size:14px;font-weight:700;font-family:inherit;border:none;background:var(--scroll);color:var(--ink3);letter-spacing:2px;transition:all .2s}
.stage-tab.active{background:var(--red);color:#fff}
.stage-tab:first-child{border-right:1px solid var(--border)}
.stage-hint{text-align:center;font-size:11px;color:var(--ink3);margin:6px auto 0;max-width:700px;padding:0 20px}

.main{max-width:700px;margin:0 auto;padding:12px 20px 60px}

.fold-card{background:var(--card);border:1px solid var(--border);border-radius:6px;margin-bottom:10px;overflow:hidden}
.fold-hd{display:flex;align-items:center;justify-content:space-between;padding:13px 18px;cursor:pointer;transition:background .15s}
.fold-hd:hover{background:var(--gold-light)}
.fold-hd-l{display:flex;align-items:center;gap:8px;font-size:13px;font-weight:700;color:var(--ink2);letter-spacing:1px}
.fold-tog{font-size:18px;color:var(--ink3);font-weight:300}
.fold-bd{display:none;padding:4px 18px 16px;border-top:1px solid var(--border)}
.fold-bd.open{display:block}
.step-row{display:flex;align-items:flex-start;gap:10px;margin-top:10px;font-size:12px;color:var(--ink2);line-height:1.9}
.step-num{width:20px;height:20px;border-radius:50%;background:var(--red);color:#fff;font-size:11px;font-weight:700;display:flex;align-items:center;justify-content:center;flex-shrink:0;margin-top:2px}
.info-tip{background:var(--gold-light);border-radius:6px;padding:10px 12px;margin-top:10px;font-size:12px;color:var(--ink2);line-height:1.9;border:1px solid #f0d888}

.notice-card{background:#fef8ec;border:1px solid #f0d890;border-radius:6px;padding:14px 18px;margin-bottom:10px}
.notice-title{font-size:13px;font-weight:700;color:#8a5a10;margin-bottom:8px;letter-spacing:1px}
.notice-list{list-style:none}
.notice-list li{font-size:12px;color:#7a5010;line-height:2.1;padding-left:14px;position:relative}
.notice-list li::before{content:'·';position:absolute;left:4px;font-size:16px;line-height:1.4}

.sel-card{background:var(--card);border:1px solid var(--border);border-radius:6px;padding:18px 20px;margin-bottom:10px}
.sec-label{font-size:13px;font-weight:700;color:var(--ink2);margin-bottom:12px;letter-spacing:1px;display:flex;align-items:center;gap:8px}
.sec-label::before{content:'';width:4px;height:16px;background:var(--red);border-radius:2px}

.grade-tags{display:flex;flex-wrap:wrap;gap:8px;margin-bottom:16px}
.grade-tag{padding:7px 16px;border-radius:4px;border:1px solid var(--border);background:var(--scroll);font-size:13px;color:var(--ink2);cursor:pointer;font-family:inherit;transition:all .15s;letter-spacing:1px}
.grade-tag:hover{background:var(--gold-light);border-color:var(--gold)}
.grade-tag.active{background:var(--red);border-color:var(--red);color:#fff}

.book-btns{display:flex;gap:8px;margin-bottom:16px}
.book-btn{padding:8px 24px;border-radius:4px;border:1px solid var(--border);background:var(--scroll);font-size:13px;color:var(--ink2);cursor:pointer;font-family:inherit;transition:all .15s;letter-spacing:1px}
.book-btn:hover{background:var(--gold-light);border-color:var(--gold)}
.book-btn.active{background:var(--red);border-color:var(--red);color:#fff}

/* 单元标签（初中专用）*/
.unit-tags{display:flex;flex-wrap:wrap;gap:8px;margin-bottom:16px}
.unit-tag{padding:7px 16px;border-radius:4px;border:1px solid var(--border);background:var(--scroll);font-size:12px;color:var(--ink2);cursor:pointer;font-family:inherit;transition:all .15s;letter-spacing:.5px}
.unit-tag:hover{background:var(--gold-light);border-color:var(--gold)}
.unit-tag.active{background:var(--green);border-color:var(--green);color:#fff}

.poem-group-label{font-size:11px;color:var(--ink3);margin-bottom:8px;letter-spacing:2px;display:flex;align-items:center;gap:8px}
.poem-group-label::after{content:'';flex:1;height:1px;background:var(--border)}
.poem-tags{display:flex;flex-wrap:wrap;gap:7px;margin-bottom:14px}
.poem-tag{padding:6px 14px;border-radius:4px;border:1px solid var(--border);background:var(--scroll);font-size:12px;color:var(--ink2);cursor:pointer;font-family:inherit;transition:all .15s;letter-spacing:.5px}
.poem-tag:hover{background:var(--red-light);border-color:#e8b0a8;color:var(--red)}
.poem-tag.sel{background:var(--red);border-color:var(--red);color:#fff}

.selected-info{background:var(--gold-light);border:1px solid #f0d888;border-radius:4px;padding:8px 14px;font-size:12px;color:var(--ink2);margin-bottom:12px;line-height:1.8;display:none}
.selected-info b{color:var(--gold)}

.btn-gen{width:100%;padding:13px;background:var(--red);color:#fff;border:none;border-radius:6px;font-size:15px;font-weight:700;font-family:inherit;cursor:pointer;letter-spacing:3px;transition:background .2s}
.btn-gen:hover{background:var(--red2)}
.btn-gen:disabled{background:#c8b890;cursor:not-allowed}

.result-area{display:none}
.result-card{background:var(--card);border:1px solid var(--border);border-radius:6px;padding:18px 20px;margin-bottom:10px}
.result-hd{display:flex;align-items:center;justify-content:space-between;margin-bottom:12px}
.result-title{display:flex;align-items:center;gap:8px;font-size:13px;font-weight:700;color:var(--ink2);letter-spacing:1px}
.result-title::before{content:'';width:4px;height:16px;background:var(--red);border-radius:2px}
.result-title.gold::before{background:var(--gold)}
.btn-copy{padding:5px 14px;background:var(--scroll);border:1px solid var(--border);border-radius:4px;font-size:12px;color:var(--ink2);cursor:pointer;font-family:inherit;transition:all .2s}
.btn-copy:hover{background:var(--gold-light);border-color:var(--gold)}
.btn-copy.copied{background:#d4e8c0;border-color:#80c060;color:#2a6010}
.prompt-box{background:var(--scroll);border:1px solid var(--border);border-radius:6px;padding:14px;font-size:12px;color:var(--ink2);line-height:2;white-space:pre-wrap;word-break:break-all;user-select:text;max-height:500px;overflow-y:auto}
.prompt-tip{margin-top:8px;font-size:11px;color:var(--ink3);background:var(--gold-light);padding:7px 12px;border-radius:4px;line-height:1.8;border:1px solid #f0d888}

footer{text-align:center;padding:24px 20px 40px;border-top:1px solid var(--border);margin-top:10px}
.footer-logo{font-size:15px;font-weight:900;color:var(--ink);letter-spacing:3px;margin-bottom:4px}
.footer-sub{font-size:12px;color:var(--ink3);letter-spacing:1px;margin-bottom:14px}
.footer-copy{font-size:11px;color:#a09070;line-height:2.2}
.footer-copy b{color:var(--ink3)}

@keyframes fadeUp{from{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}
.fade-up{animation:fadeUp .3s ease}
.result-tabs{display:flex;gap:0;border-bottom:2px solid var(--border);margin-bottom:0}
.result-tab{padding:10px 18px;font-size:12px;font-weight:700;color:var(--ink3);cursor:pointer;border:none;background:none;font-family:inherit;letter-spacing:1px;border-bottom:2px solid transparent;margin-bottom:-2px;transition:all .2s}
.result-tab.active{color:var(--red);border-bottom-color:var(--red)}
.result-tab:hover{color:var(--ink2)}
.result-pane{display:none}.result-pane.active{display:block}

</style>
</head>
<body>

<div class="top-nav">
  <span>古诗图解</span><span class="dot">·</span>
  <span>提示词工坊</span><span class="dot">·</span>
  <span class="ver">V2 · 完整版</span>
</div>

<div class="hero">
  <div class="hero-badge">📚 统编版 · 小学1-6年级 + 初中7-9年级 · 全覆盖</div>
  <h1>古诗<span>图解</span>提示词生成器</h1>
  <div style="font-size:13px;color:var(--ink2);margin:4px 0 6px;font-weight:600">V2 · 完整版（小学+初中）</div>
  <div class="hero-desc">选阶段 · 选年级 · 选册/单元 · 选古诗 · 一键生成</div>
</div>

<!-- 阶段切换 -->
<div class="stage-tabs">
  <button class="stage-tab active" id="tabPrimary" onclick="switchStage('primary')">📖 小学版（1-6年级）</button>
  <button class="stage-tab" id="tabMiddle" onclick="switchStage('middle')">📗 初中版（7-9年级）</button>
</div>
<div class="stage-hint" id="stageHint">水彩Q版风格 · 按年级+上下册选诗 · 适合家长和小学老师</div>

<div class="main">

  <!-- 使用说明 -->
  <div class="fold-card">
    <div class="fold-hd" onclick="toggleFold(this)">
      <div class="fold-hd-l">📖 使用说明 · 四步完成出图</div>
      <div class="fold-tog">+</div>
    </div>
    <div class="fold-bd">
      <div class="step-row"><div class="step-num">1</div><div>选阶段（小学/初中）→ 选年级 → 选上/下册 → <b style="color:var(--red)">【初中专有】选单元</b> → 勾选古诗（建议3-6首）</div></div>
      <div class="step-row"><div class="step-num">2</div><div>点「生 成」→ 复制<b style="color:var(--red)">图片框架提示词</b> → 发给<b style="color:var(--red)">开联网的Claude或DeepSeek</b>，让它查资料后填空输出完整出图提示词</div></div>
      <div class="step-row"><div class="step-num">3</div><div>复制Claude输出的完整提示词 → 发给<b style="color:var(--red)">香蕉Pro</b> → 比例选 <b style="color:var(--red)">3:4 竖版</b> → 出图</div></div>
      <div class="step-row"><div class="step-num">4</div><div>出完图后 → 复制<b style="color:var(--red)">三平台文案提示词</b> → 把图片+文案提示词一起发给Claude → 输出视频号+小红书+抖音三套文案</div></div>
      <div class="info-tip">💡 初中版与小学版的主要区别：① 多一层「单元」选择 ② 图解风格自动切换为水墨写实风，更符合初中气质 ③ 色调更丰富，按单元主题匹配</div>
    </div>
  </div>

  <!-- 注意事项 -->
  <div class="notice-card">
    <div class="notice-title">⚠️ 使用前请阅读</div>
    <ul class="notice-list">
      <li>本工具篇目数据基于<b>统编版（人教版）语文教材</b>，数据有一定滞后性，以实际教材为准</li>
      <li>发给Claude时请<b>开启联网功能</b>，否则资料不准确，图里内容会出错</li>
      <li>建议每次选 <b>3-6首</b> 做一个合集，初中版按单元选效率最高</li>
      <li>出图后请自行核对诗句和注释的准确性</li>
      <li>本工具版权归 <b>阿坚AIGC</b> 所有，仅供授权用户个人创作使用，禁止商业转载</li>
    </ul>
  </div>

  <!-- 选择区 -->
  <div class="sel-card">
    <!-- 年级 -->
    <div class="sec-label" id="gradeLabel">第一步：选择年级</div>
    <div class="grade-tags" id="gradeTags"></div>

    <!-- 上下册 -->
    <div id="bookSection" style="display:none">
      <div class="sec-label">第二步：选择上/下册</div>
      <div class="book-btns">
        <button class="book-btn" data-b="上册">上册</button>
        <button class="book-btn" data-b="下册">下册</button>
      </div>
    </div>

    <!-- 单元（初中专有）-->
    <div id="unitSection" style="display:none">
      <div class="sec-label">第三步：选择单元</div>
      <div class="unit-tags" id="unitTags"></div>
    </div>

    <!-- 诗列表 -->
    <div id="poemSection" style="display:none">
      <div class="sec-label" id="poemStepLabel">第三步：选择古诗（可多选）</div>
      <div id="poemList"></div>
      <div class="selected-info" id="selectedInfo"></div>
    </div>

    <button class="btn-gen" id="btnGen" onclick="generate()" disabled>生　成</button>
  </div>

  <!-- 结果区 -->
  <div class="result-area" id="resultArea">
    <div class="result-card">
      <div class="result-tabs">
        <button class="result-tab active" onclick="switchTab('img',this)">📋 图片框架提示词</button>
        <button class="result-tab" onclick="switchTab('wx',this)">📝 三平台文案提示词</button>
      </div>
      <div class="result-pane active" id="pane-img">
        <div class="result-hd" style="margin-top:14px">
          <div class="result-title">📋 图片框架提示词（发给Claude联网查资料用）</div>
          <button class="btn-copy" onclick="copyPrompt('promptImg', this)">一键复制</button>
        </div>
        <div class="prompt-box" id="promptImg"></div>
        <div class="prompt-tip">💡 复制后发给<b>开联网的Claude或DeepSeek</b>，让它联网查资料后填空输出完整出图提示词，再去香蕉Pro出图，比例 <b>3:4 竖版</b></div>
      </div>
      <div class="result-pane" id="pane-wx">
        <div class="result-hd" style="margin-top:14px">
          <div class="result-title gold">📝 三平台文案提示词（出完图后使用）</div>
          <button class="btn-copy" onclick="copyPrompt('promptWx', this)">一键复制</button>
        </div>
        <div class="prompt-box" id="promptWx"></div>
        <div class="prompt-tip">💡 出完图后，把<b>图片 + 这段提示词</b>一起发给Claude → 输出<b>视频号+小红书+抖音</b>三套文案</div>
      </div>
    </div>
  </div>

</div>

<footer>
  <div class="footer-logo">📜 古诗图解</div>
  <div class="footer-sub">提示词工坊 · V2 · 完整版 · 统编版小学1-6年级 + 初中7-9年级</div>
  <div class="footer-copy">
    版权所有 © <b>阿坚AIGC</b><br>
    篇目数据基于统编版语文教材，有一定滞后性，以实际教材为准<br>
    本工具仅供授权用户个人创作使用，<b>禁止商业转载与二次分发</b>
  </div>
</footer>

<script>
// =============================================
// 小学数据库（同V1）
// =============================================
const PRIMARY_DB = {
  '一年级': {
    '上册': [
      {name:'咏鹅', author:'唐·骆宾王', color:'清新黄绿'},
      {name:'江南', author:'汉乐府', color:'水绿清新'},
      {name:'画', author:'唐·王维', color:'淡墨青绿'},
      {name:'静夜思', author:'唐·李白', color:'深蓝月色'},
      {name:'寻隐者不遇', author:'唐·贾岛', color:'深绿幽静'},
    ],
    '下册': [
      {name:'春晓', author:'唐·孟浩然', color:'粉绿清新'},
      {name:'赠汪伦', author:'唐·李白', color:'青灰送别'},
      {name:'池上', author:'唐·白居易', color:'清新黄绿'},
      {name:'小池', author:'宋·杨万里', color:'清新碧绿'},
      {name:'悯农（其二）', author:'唐·李绅', color:'暖黄田野'},
      {name:'古朗月行（节选）', author:'唐·李白', color:'深蓝月色'},
    ]
  },
  '二年级': {
    '上册': [
      {name:'梅花', author:'宋·王安石', color:'冷白雪色'},
      {name:'小儿垂钓', author:'唐·胡令能', color:'清新黄绿'},
      {name:'登鹳雀楼', author:'唐·王之涣', color:'橙金壮阔'},
      {name:'望庐山瀑布', author:'唐·李白', color:'青碧壮阔'},
      {name:'江雪', author:'唐·柳宗元', color:'冷蓝白雪'},
      {name:'敕勒歌', author:'北朝民歌', color:'碧绿草原'},
    ],
    '下册': [
      {name:'村居', author:'清·高鼎', color:'粉绿春日'},
      {name:'咏柳', author:'唐·贺知章', color:'嫩绿清新'},
      {name:'晓出净慈寺送林子方', author:'宋·杨万里', color:'碧绿荷香'},
      {name:'绝句', author:'唐·杜甫', color:'明亮黄绿'},
      {name:'悯农（其一）', author:'唐·李绅', color:'暖黄烈日'},
      {name:'赋得古原草送别', author:'唐·白居易', color:'青绿苍茫'},
    ]
  },
  '三年级': {
    '上册': [
      {name:'山行', author:'唐·杜牧', color:'橙红秋色'},
      {name:'赠刘景文', author:'宋·苏轼', color:'橙金暖秋'},
      {name:'夜书所见', author:'宋·叶绍翁', color:'深蓝秋夜'},
      {name:'望天门山', author:'唐·李白', color:'青碧壮阔'},
      {name:'饮湖上初晴后雨', author:'宋·苏轼', color:'碧绿烟雨'},
      {name:'望洞庭', author:'唐·刘禹锡', color:'银白秋月'},
    ],
    '下册': [
      {name:'绝句', author:'唐·杜甫', color:'明亮黄绿'},
      {name:'惠崇春江晚景', author:'宋·苏轼', color:'粉绿春色'},
      {name:'三衢道中', author:'宋·曾几', color:'清新绿色'},
      {name:'元日', author:'宋·王安石', color:'红色喜庆'},
      {name:'清明', author:'唐·杜牧', color:'青灰烟雨'},
      {name:'九月九日忆山东兄弟', author:'唐·王维', color:'金秋暖色'},
      {name:'咏柳', author:'唐·贺知章', color:'嫩绿清新'},
      {name:'春日', author:'宋·朱熹', color:'粉绿生机'},
      {name:'乞巧', author:'唐·林杰', color:'深蓝星空'},
      {name:'嫦娥', author:'唐·李商隐', color:'深蓝月夜'},
    ]
  },
  '四年级': {
    '上册': [
      {name:'暮江吟', author:'唐·白居易', color:'橙金傍晚'},
      {name:'题西林壁', author:'宋·苏轼', color:'青绿山色'},
      {name:'雪梅', author:'宋·卢钺', color:'冷白雪色'},
      {name:'出塞', author:'唐·王昌龄', color:'黄沙苍凉'},
      {name:'凉州词', author:'唐·王翰', color:'黄沙苍凉'},
      {name:'夏日绝句', author:'宋·李清照', color:'深红豪迈'},
    ],
    '下册': [
      {name:'独坐敬亭山', author:'唐·李白', color:'青灰禅意'},
      {name:'忆江南', author:'唐·白居易', color:'水绿烟雨'},
      {name:'乡村四月', author:'宋·翁卷', color:'暖绿劳动'},
      {name:'四时田园杂兴（其二十五）', author:'宋·范成大', color:'清新绿色'},
      {name:'渔歌子', author:'唐·张志和', color:'水绿烟雨'},
      {name:'塞下曲', author:'唐·卢纶', color:'冷月苍凉'},
      {name:'芙蓉楼送辛渐', author:'唐·王昌龄', color:'青灰送别'},
    ]
  },
  '五年级': {
    '上册': [
      {name:'泊船瓜洲', author:'宋·王安石', color:'青灰月色'},
      {name:'秋思', author:'唐·张籍', color:'金秋惆怅'},
      {name:'长相思', author:'清·纳兰性德', color:'冷蓝月色'},
      {name:'示儿', author:'宋·陆游', color:'深红家国'},
      {name:'题临安邸', author:'宋·林升', color:'沉郁灰红'},
      {name:'己亥杂诗', author:'清·龚自珍', color:'深红豪迈'},
    ],
    '下册': [
      {name:'牧童', author:'唐·吕岩', color:'橙金傍晚'},
      {name:'舟过安仁', author:'宋·杨万里', color:'暖黄绿色'},
      {name:'清平乐·村居', author:'宋·辛弃疾', color:'暖绿田园'},
      {name:'稚子弄冰', author:'宋·杨万里', color:'冷蓝冰雪'},
      {name:'村晚', author:'宋·雷震', color:'橙金傍晚'},
      {name:'四时田园杂兴（其三十一）', author:'宋·范成大', color:'暖黄绿色'},
      {name:'从军行', author:'唐·王昌龄', color:'黄沙苍凉'},
      {name:'秋夜将晓出篱门迎凉有感', author:'宋·陆游', color:'沉郁苍茫'},
      {name:'闻官军收河南河北', author:'唐·杜甫', color:'明亮喜悦'},
    ]
  },
  '六年级': {
    '上册': [
      {name:'宿建德江', author:'唐·孟浩然', color:'深蓝月色'},
      {name:'六月二十七日望湖楼醉书', author:'宋·苏轼', color:'墨色雨景'},
      {name:'西江月·夜行黄沙道中', author:'宋·辛弃疾', color:'深蓝月夜'},
      {name:'七律·长征', author:'毛泽东', color:'深红豪迈'},
      {name:'浪淘沙（其一）', author:'唐·刘禹锡', color:'黄沙壮阔'},
      {name:'江南春', author:'唐·杜牧', color:'粉绿烟雨'},
      {name:'书湖阴先生壁', author:'宋·王安石', color:'清新绿色'},
    ],
    '下册': [
      {name:'寒食', author:'唐·韩翃', color:'淡紫春色'},
      {name:'迢迢牵牛星', author:'汉·无名氏', color:'深蓝星空'},
      {name:'十五夜望月', author:'唐·王建', color:'深蓝月色'},
      {name:'马诗', author:'唐·李贺', color:'月白豪迈'},
      {name:'石灰吟', author:'明·于谦', color:'白灰坚毅'},
      {name:'竹石', author:'清·郑燮', color:'青绿劲竹'},
      {name:'回乡偶书', author:'唐·贺知章', color:'暖黄乡情'},
      {name:'游子吟', author:'唐·孟郊', color:'暖黄温情'},
    ]
  }
};

// =============================================
// 初中数据库：按年级→上下册→单元组织
// 每个单元有主题标签和风格色调
// =============================================
const MIDDLE_DB = {
  '七年级': {
    '上册': {
      '课内古诗（第一单元）': {
        theme:'自然山水·行旅感怀', style:'水墨写实', color:'青碧壮阔',
        poems:[
          {name:'观沧海', author:'东汉·曹操'},
          {name:'闻王昌龄左迁龙标遥有此寄', author:'唐·李白'},
          {name:'次北固山下', author:'唐·王湾'},
          {name:'天净沙·秋思', author:'元·马致远'},
        ]
      },
      '课外古诗词诵读（第一辑）': {
        theme:'羁旅思乡·友情', style:'水墨写实', color:'青灰惆怅',
        poems:[
          {name:'峨眉山月歌', author:'唐·李白'},
          {name:'江南逢李龟年', author:'唐·杜甫'},
          {name:'行军九日思长安故园', author:'唐·岑参'},
          {name:'夜上受降城闻笛', author:'唐·李益'},
        ]
      },
      '课外古诗词诵读（第二辑）': {
        theme:'秋日感怀·家国情', style:'水墨写实', color:'金秋惆怅',
        poems:[
          {name:'秋词（其一）', author:'唐·刘禹锡'},
          {name:'夜雨寄北', author:'唐·李商隐'},
          {name:'十一月四日风雨大作（其二）', author:'宋·陆游'},
          {name:'潼关', author:'清·谭嗣同'},
        ]
      },
    },
    '下册': {
      '课内古诗（第五单元）': {
        theme:'登高抒志·励志豪情', style:'水墨写实', color:'深红豪迈',
        poems:[
          {name:'登幽州台歌', author:'唐·陈子昂'},
          {name:'望岳', author:'唐·杜甫'},
          {name:'登飞来峰', author:'宋·王安石'},
          {name:'游山西村', author:'宋·陆游'},
          {name:'己亥杂诗（其五）', author:'清·龚自珍'},
        ]
      },
      '课外古诗词诵读（第一辑）': {
        theme:'田园隐逸·春日', style:'水墨写实', color:'淡墨青绿',
        poems:[
          {name:'竹里馆', author:'唐·王维'},
          {name:'春夜洛城闻笛', author:'唐·李白'},
          {name:'逢入京使', author:'唐·岑参'},
          {name:'晚春', author:'唐·韩愈'},
        ]
      },
      '课外古诗词诵读（第二辑）': {
        theme:'怀古忧思·人生感悟', style:'水墨写实', color:'青灰送别',
        poems:[
          {name:'泊秦淮', author:'唐·杜牧'},
          {name:'贾生', author:'唐·李商隐'},
          {name:'过松源晨炊漆公店（其五）', author:'宋·杨万里'},
          {name:'约客', author:'宋·赵师秀'},
        ]
      },
    }
  },
  '八年级': {
    '上册': {
      '课内古诗（第四单元）': {
        theme:'山水田园·边塞行旅', style:'水墨写实', color:'黄沙苍凉',
        poems:[
          {name:'野望', author:'唐·王绩'},
          {name:'黄鹤楼', author:'唐·崔颢'},
          {name:'使至塞上', author:'唐·王维'},
          {name:'渡荆门送别', author:'唐·李白'},
          {name:'钱塘湖春行', author:'唐·白居易'},
        ]
      },
      '课内古诗（第六单元）': {
        theme:'忧国忧民·豪情壮志', style:'水墨写实', color:'深红豪迈',
        poems:[
          {name:'饮酒（其五）', author:'晋·陶渊明'},
          {name:'春望', author:'唐·杜甫'},
          {name:'雁门太守行', author:'唐·李贺'},
          {name:'赤壁', author:'唐·杜牧'},
          {name:'渔家傲（天接云涛连晓雾）', author:'宋·李清照'},
        ]
      },
      '课外古诗词诵读（第一辑）': {
        theme:'建安风骨·慷慨悲歌', style:'水墨写实', color:'苍茫深绿',
        poems:[
          {name:'庭中有奇树', author:'汉·无名氏'},
          {name:'龟虽寿', author:'东汉·曹操'},
          {name:'赠从弟（其二）', author:'东汉·刘桢'},
          {name:'梁甫行', author:'三国·曹植'},
        ]
      },
      '课外古诗词诵读（第二辑）': {
        theme:'宋词·闲适雅趣', style:'水墨写实', color:'水绿烟雨',
        poems:[
          {name:'浣溪沙（一曲新词酒一杯）', author:'宋·晏殊'},
          {name:'采桑子（轻舟短棹西湖好）', author:'宋·欧阳修'},
          {name:'相见欢（金陵城上西楼）', author:'宋·朱敦儒'},
          {name:'如梦令（常记溪亭日暮）', author:'宋·李清照'},
        ]
      },
    },
    '下册': {
      '课内古诗（第四单元）': {
        theme:'诗经·先秦风雅', style:'水墨写实', color:'青绿苍茫',
        poems:[
          {name:'关雎', author:'先秦·诗经'},
          {name:'蒹葭', author:'先秦·诗经'},
        ]
      },
      '课内古诗（第六单元）': {
        theme:'民生疾苦·现实主义', style:'水墨写实', color:'暖黄沉郁',
        poems:[
          {name:'茅屋为秋风所破歌', author:'唐·杜甫'},
          {name:'卖炭翁', author:'唐·白居易'},
        ]
      },
      '课外古诗词诵读（第一辑）': {
        theme:'送别友情·山水清幽', style:'水墨写实', color:'青灰送别',
        poems:[
          {name:'题破山寺后禅院', author:'唐·常建'},
          {name:'送友人', author:'唐·李白'},
          {name:'卜算子·黄州定慧院寓居作', author:'宋·苏轼'},
          {name:'卜算子·咏梅', author:'宋·陆游'},
        ]
      },
      '课外古诗词诵读（第二辑）': {
        theme:'边塞军旅·家国情怀', style:'水墨写实', color:'黄沙苍凉',
        poems:[
          {name:'式微', author:'先秦·诗经'},
          {name:'子衿', author:'先秦·诗经'},
          {name:'送杜少府之任蜀州', author:'唐·王勃'},
          {name:'望洞庭湖赠张丞相', author:'唐·孟浩然'},
        ]
      },
    }
  },
  '九年级': {
    '上册': {
      '课内古诗（第三单元）': {
        theme:'人生感悟·豪放旷达', style:'水墨写实', color:'深红豪迈',
        poems:[
          {name:'行路难（其一）', author:'唐·李白'},
          {name:'酬乐天扬州初逢席上见赠', author:'唐·刘禹锡'},
          {name:'水调歌头（明月几时有）', author:'宋·苏轼'},
        ]
      },
      '课外古诗词诵读（第一辑）': {
        theme:'羁旅漂泊·思乡送别', style:'水墨写实', color:'金秋惆怅',
        poems:[
          {name:'月夜忆舍弟', author:'唐·杜甫'},
          {name:'长沙过贾谊宅', author:'唐·刘长卿'},
          {name:'左迁至蓝关示侄孙湘', author:'唐·韩愈'},
          {name:'商山早行', author:'唐·温庭筠'},
        ]
      },
      '课外古诗词诵读（第二辑）': {
        theme:'家国兴亡·愁思百转', style:'水墨写实', color:'青灰惆怅',
        poems:[
          {name:'咸阳城东楼', author:'唐·许浑'},
          {name:'无题（相见时难别亦难）', author:'唐·李商隐'},
          {name:'行香子（树绕村庄）', author:'宋·秦观'},
          {name:'丑奴儿·书博山道中壁', author:'宋·辛弃疾'},
        ]
      },
    },
    '下册': {
      '课内古诗（第六单元）': {
        theme:'豪放词·慷慨激昂', style:'水墨写实', color:'深红豪迈',
        poems:[
          {name:'渔家傲·秋思', author:'宋·范仲淹'},
          {name:'江城子·密州出猎', author:'宋·苏轼'},
          {name:'破阵子·为陈同甫赋壮词以寄之', author:'宋·辛弃疾'},
          {name:'满江红（小住京华）', author:'清·秋瑾'},
        ]
      },
      '课外古诗词诵读（第一辑）': {
        theme:'山水之乐·隐逸情怀', style:'水墨写实', color:'淡墨青绿',
        poems:[
          {name:'定风波（莫听穿林打叶声）', author:'宋·苏轼'},
          {name:'临江仙·夜登小阁忆洛中旧游', author:'宋·陈与义'},
          {name:'太常引·建康中秋夜为吕叔潜赋', author:'宋·辛弃疾'},
          {name:'浣溪沙（身向云山那畔行）', author:'清·纳兰性德'},
        ]
      },
      '课外古诗词诵读（第二辑）': {
        theme:'送别伤怀·离愁别绪', style:'水墨写实', color:'青灰送别',
        poems:[
          {name:'南乡子·登京口北固亭有怀', author:'宋·辛弃疾'},
          {name:'过零丁洋', author:'宋·文天祥'},
          {name:'山坡羊·骊山怀古', author:'元·张养浩'},
          {name:'朝天子·咏喇叭', author:'明·王磐'},
        ]
      },
    }
  }
};

// =============================================
// 状态
// =============================================
let curStage = 'primary'; // primary | middle
let curGrade = '', curBook = '', curUnit = '', selPoems = [];

// =============================================
// 阶段切换
// =============================================
function switchStage(stage) {
  curStage = stage;
  curGrade = ''; curBook = ''; curUnit = ''; selPoems = [];
  document.getElementById('tabPrimary').classList.toggle('active', stage === 'primary');
  document.getElementById('tabMiddle').classList.toggle('active', stage === 'middle');
  document.getElementById('stageHint').textContent = stage === 'primary'
    ? '水彩Q版风格 · 按年级+上下册选诗 · 适合家长和小学老师'
    : '水墨写实风格 · 按年级+上下册+单元选诗 · 适合初中老师备课';
  document.getElementById('gradeLabel').textContent = '第一步：选择年级';
  document.getElementById('poemStepLabel').textContent = stage === 'middle' ? '第四步：选择古诗（可多选）' : '第三步：选择古诗（可多选）';
  document.getElementById('bookSection').style.display = 'none';
  document.getElementById('unitSection').style.display = 'none';
  document.getElementById('poemSection').style.display = 'none';
  document.getElementById('resultArea').style.display = 'none';
  document.getElementById('btnGen').disabled = true;
  document.getElementById('selectedInfo').style.display = 'none';
  renderGrades();
  updateSelectedInfo();
}

// =============================================
// 渲染年级
// =============================================
function renderGrades() {
  const db = curStage === 'primary' ? PRIMARY_DB : MIDDLE_DB;
  const grades = Object.keys(db);
  const container = document.getElementById('gradeTags');
  container.innerHTML = grades.map(g =>
    `<button class="grade-tag" data-g="${g}" onclick="selectGrade('${g}')">${g}</button>`
  ).join('');
}

function selectGrade(g) {
  curGrade = g; curBook = ''; curUnit = ''; selPoems = [];
  document.querySelectorAll('.grade-tag').forEach(b => b.classList.toggle('active', b.dataset.g === g));
  document.getElementById('bookSection').style.display = 'block';
  document.querySelectorAll('.book-btn').forEach(b => b.classList.remove('active'));
  document.getElementById('unitSection').style.display = 'none';
  document.getElementById('poemSection').style.display = 'none';
  document.getElementById('resultArea').style.display = 'none';
  document.getElementById('btnGen').disabled = true;
  updateSelectedInfo();
}

// =============================================
// 上下册
// =============================================
document.querySelectorAll('.book-btn').forEach(btn => {
  btn.addEventListener('click', () => {
    curBook = btn.dataset.b; curUnit = ''; selPoems = [];
    document.querySelectorAll('.book-btn').forEach(b => b.classList.toggle('active', b.dataset.b === curBook));
    document.getElementById('resultArea').style.display = 'none';
    document.getElementById('btnGen').disabled = true;
    updateSelectedInfo();
    if (curStage === 'primary') {
      renderPrimaryPoems();
      document.getElementById('unitSection').style.display = 'none';
    } else {
      renderUnits();
      document.getElementById('poemSection').style.display = 'none';
    }
  });
});

// =============================================
// 渲染单元（初中）
// =============================================
function renderUnits() {
  const units = MIDDLE_DB[curGrade]?.[curBook] || {};
  const names = Object.keys(units);
  const container = document.getElementById('unitTags');
  container.innerHTML = names.map(u =>
    `<button class="unit-tag" data-u="${u}" onclick="selectUnit('${u}')">${u}（${units[u].theme}）</button>`
  ).join('');
  document.getElementById('unitSection').style.display = 'block';
}

function selectUnit(u) {
  curUnit = u; selPoems = [];
  document.querySelectorAll('.unit-tag').forEach(b => b.classList.toggle('active', b.dataset.u === u));
  document.getElementById('resultArea').style.display = 'none';
  document.getElementById('btnGen').disabled = true;
  updateSelectedInfo();
  renderMiddlePoems();
}

// =============================================
// 渲染诗列表
// =============================================
function renderPrimaryPoems() {
  const poems = PRIMARY_DB[curGrade]?.[curBook] || [];
  const section = document.getElementById('poemSection');
  const list = document.getElementById('poemList');
  section.style.display = 'block';
  list.innerHTML = `
    <div class="poem-group-label">${curGrade} · ${curBook} · 共 ${poems.length} 首</div>
    <div class="poem-tags">
      ${poems.map((p,i) => `<button class="poem-tag" data-i="${i}" onclick="togglePoem(${i},'primary')">${p.name}</button>`).join('')}
    </div>`;
}

function renderMiddlePoems() {
  const unit = MIDDLE_DB[curGrade]?.[curBook]?.[curUnit];
  if (!unit) return;
  const poems = unit.poems;
  const section = document.getElementById('poemSection');
  const list = document.getElementById('poemList');
  section.style.display = 'block';
  list.innerHTML = `
    <div class="poem-group-label">${curGrade} · ${curBook} · ${curUnit} · 共 ${poems.length} 首 · ${unit.theme}</div>
    <div class="poem-tags">
      ${poems.map((p,i) => `<button class="poem-tag" data-i="${i}" onclick="togglePoem(${i},'middle')">${p.name}</button>`).join('')}
    </div>`;
}

function togglePoem(idx, stage) {
  const poems = stage === 'primary'
    ? (PRIMARY_DB[curGrade]?.[curBook] || [])
    : (MIDDLE_DB[curGrade]?.[curBook]?.[curUnit]?.poems || []);
  const poem = poems[idx];
  const pos = selPoems.findIndex(p => p.name === poem.name);
  const btn = document.querySelector(`.poem-tag[data-i="${idx}"]`);
  if (pos >= 0) { selPoems.splice(pos,1); btn.classList.remove('sel'); }
  else { selPoems.push(poem); btn.classList.add('sel'); }
  updateSelectedInfo();
  document.getElementById('btnGen').disabled = selPoems.length === 0;
}

function updateSelectedInfo() {
  const el = document.getElementById('selectedInfo');
  if (selPoems.length === 0) { el.style.display = 'none'; return; }
  el.style.display = 'block';
  el.innerHTML = `已选 <b>${selPoems.length}</b> 首：${selPoems.map(p=>`「${p.name}」`).join(' ')}`;
}

// =============================================
// 生成提示词
// =============================================
function generate() {
  if (selPoems.length === 0) return;

  const isPrimary = curStage === 'primary';
  const stage = isPrimary ? `${curGrade}${curBook}` : `${curGrade}${curBook}·${curUnit}`;
  const poemList = selPoems.map(p => `《${p.name}》${p.author}`).join('、');
  const poemNames = selPoems.map(p => `《${p.name}》`).join('、');

  // 初中单元信息
  const unitInfo = !isPrimary ? MIDDLE_DB[curGrade]?.[curBook]?.[curUnit] : null;
  const unitStyle = unitInfo ? unitInfo.style : '水彩手绘';
  const unitTheme = unitInfo ? unitInfo.theme : '';

  // 图解风格说明
  const styleDesc = isPrimary
    ? '水彩手绘古风风格，Q版童趣，色彩温馨明亮，适合小学生审美'
    : `水墨写实古风风格，笔触沉稳，意境深远，适合初中生审美，单元主题「${unitTheme}」`;

  const coverStyle = isPrimary
    ? 'Q版古风小童子，5-6头身，浅蓝色汉服，发髻，左手捧线装古书，右手握大毛笔，表情可爱自信，与背景自然融合有光影'
    : '古风文人形象，身穿儒雅长袍，手持书卷，站立于山水背景前，神情沉静，写实风格，有真实光影关系';

  // ---- 图片框架提示词 ----
  const imgPrompt = `你是一位专业的古诗图解设计师。

⚠️ 重要规则：你的任务是「填空」，不是「创作」。
请联网查询以下每首诗的资料，然后将查到的内容直接填入下方提示词的【】标注位置，输出完整的出图提示词。
除了填入【】内的内容，提示词的其他所有文字、结构、色调、格式，一字不改，原样保留输出。

【本次要做的古诗】
${selPoems.map((p,i) => `${i+1}. 《${p.name}》${p.author}`).join('\n')}
${!isPrimary ? `\n【单元主题】${unitTheme}\n【图解风格】${unitStyle}` : ''}

【色调参考库】
查完每首诗的资料后，根据诗意从以下选择最匹配的色调，填入提示词对应位置：
· 粉绿清新 → 春日、生机、儿童、清新
· 暖黄绿色 → 田园、夏日、劳动、温暖
· 橙金傍晚 → 黄昏、夕阳、归家、温馨
· 深蓝月色 → 月夜、思乡、静谧、孤寂
· 深蓝星空 → 七夕、星夜、神话、浪漫
· 冷蓝冰雪 → 冬日、冰雪、寒冷、清骨
· 橙红秋色 → 秋日、霜叶、丰收、明艳
· 金秋惆怅 → 秋思、离别、异乡、惆怅
· 黄沙苍凉 → 边塞、沙漠、豪迈、壮阔
· 深红豪迈 → 家国、壮志、英雄、气概
· 青灰送别 → 送别、离别、依依、惆怅
· 水绿烟雨 → 江南、烟雨、温柔、朦胧
· 淡墨青绿 → 山水、禅意、宁静、空灵
· 白灰坚毅 → 咏物、气节、坚韧、傲骨
· 明亮喜悦 → 喜庆、欢快、明朗、积极

【需要联网查询的内容（每首诗都查，填入下方对应位置）】
- 完整原文（逐句，确保准确）
- 作者简介（2-3句，适合${isPrimary?'小学':'初中'}生理解）
- 创作背景（2-3句，贴近学生生活）
- 每句诗的白话翻译（口语化，${isPrimary?'小学':'初中'}生能理解）
- 针对这首诗设计3个背诵技巧名称+1-2句说明（与诗的具体内容直接对应，不要用通用模板）

════════════════════════════════════
请将以下提示词原样输出，只填入【】内的内容，其余一字不改：
════════════════════════════════════

═══════════════════════════
【封面图提示词】${stage}古诗图解
═══════════════════════════
竖版3:4，${styleDesc}，米黄宣纸底色，整体温馨古雅。
顶部：红色绸缎横幅，白色楷体文字「古诗词图解」，有布料质感和立体感。
标题：超大加粗楷体「${stage}」，深墨色，占画面宽度约50%。
副标题：深红色小字「${isPrimary?'轻松背诵·趣味理解':'深度解析·诗意传承'}」。
人物：${coverStyle}。
背景：米黄宣纸底色，四角淡淡水墨${isPrimary?'桃花枝':'松竹'}装饰，大量留白，整洁不杂乱。
右下角：红色方形古风印章「阿坚AIGC」，篆刻风格做旧质感。
画面文字只允许出现以下内容，不得生成任何其他文字：
  第一行：「古诗词图解」（红色横幅内）
  第二行：「${stage}」（超大楷体）
  第三行：「${isPrimary?'轻松背诵·趣味理解':'深度解析·诗意传承'}」（深红色小字）
  第四行：「${poemList}」（小字列出收录篇目）
  印章：「阿坚AIGC」
除以上文字外，画面中不得出现任何其他中文、英文、数字或符号。
不要英文，不要其他水印。

（以下依次输出每首诗的解析图提示词）

${selPoems.map((p,i) => `═══════════════════════════
《${p.name}》解析图提示词
色调：【根据色调参考库，选出最匹配《${p.name}》的色调，填写色调名称及其氛围描述】
═══════════════════════════

整体【色调名称】贯穿全图，从背景到卷轴底色到每句插图完全统一，有「诗人站在自己的诗里」的氛围感，像精美的古风${isPrimary?'儿童绘本':'水墨画'}页面，竖版3:4，${isPrimary?'水彩手绘':'水墨写实'}风格。

【顶部】
背景：【根据《${p.name}》诗意，用1-2句描述水墨背景画面，色调与上方色调一致】，大量留白，边缘水墨晕染自然过渡。
「${isPrimary?'古诗':'诗词'}《${p.name}》」大字压在背景上，手写毛笔楷体有笔锋，白色描边深色字，字号极大，与背景融为一体。

作者介绍区，左右并排：
左侧小区域：【朝代】古风文人全身立绘，与诗意境契合，人物与背景自然融合，有真实光影，${isPrimary?'水彩':'水墨写实'}风格。不要在画面中出现任何文字标签。
右侧大区域：米色边框文字块，字号与正文相同不得更小，内容简洁各不超过2句：
· 作者简介：【填入查到的${p.author}作者简介，2句，适合${isPrimary?'小学':'初中'}生理解】
· 创作背景：【填入查到的《${p.name}》创作背景，2句，贴近学生生活】

【卷轴主体】
整体是一幅真实展开的古代画轴：两端有实体深木色圆柱卷轴棒，木纹质感清晰。卷轴纸面是深米黄偏褐色，像百年古纸，有竖向折痕和淡淡墨迹，不得出现纯白底色。顶部红色书签横幅，白字「解读版」，有绸缎质感。

⚠️ 排版规则：若此诗是重章叠唱结构（如《蒹葭》三章、《关雎》各章），则第一章完整展示含插图，后续各章紧凑并排只保留诗句大字+关键词替换标注，各配一幅小插图，不重复白话翻译。

卷轴内每句左右并排（左侧文字区域宽，右侧插图区域窄），右侧插图列必须完整保留不得消失：
左侧：超大加粗手写毛笔楷体「[诗句原文]」，字号极大是白话文字的三倍，有笔锋。小字灰色「（意象/手法标签）」。中等字号白话译文。
右侧：对应场景的${isPrimary?'写实水彩插图，温馨生动':'水墨写实插图，意境深远'}，有背景景深，色调与整体统一。

【填入《${p.name}》完整原文，按上述格式逐句输出，第一章完整，重章叠唱后续章紧凑处理】

【底部背诵技巧】
「背诵技巧」标题红色加粗。三格并排，每格有浅色背景：
每格：顶部与《${p.name}》诗意直接相关的圆形图标 + 加粗技巧名称 + 1-2句说明

【填入针对《${p.name}》的3个背诵技巧，必须与该诗具体意象直接对应：
格一：技巧名称「[名称]」/ 图标「[意象图标]」/ 说明：[1-2句]
格二：技巧名称「[名称]」/ 图标「[意象图标]」/ 说明：[1-2句]
格三：技巧名称「[名称]」/ 图标「[意象图标]」/ 说明：[1-2句]】

右下角：红色方形古风印章，篆刻风格，内写「阿坚AIGC」，做旧质感。

整体要求：选定色调贯穿全图含卷轴底色和每句插图，卷轴纸面深米黄偏褐色不得出现纯白底色，两端有实体卷轴棒，右侧插图列完整保留，诗句超大手写毛笔楷体，不要英文，不要其他水印。画面中不得出现任何百分比数字或布局标注文字。`).join('\n\n')}`;

  // ---- 三平台文案提示词 ----
  const audience = isPrimary ? '小学生家长、小学语文老师' : '初中生家长、初中语文老师';
  const wxPrompt = `你是一位擅长三平台运营的AIGC内容创作者。
我上传了${selPoems.length+1}张「${stage}古诗图解」系列图（1张封面 + ${selPoems.length}张解析图），请根据图片内容同时输出三平台配套文案：

【图片内容】
${stage}古诗图解合集，包含${poemNames}，封面+每首解析图，${isPrimary?'水彩手绘古风风格，温馨活泼，适合小学生和家长':'水墨写实古风风格，意境深远，适合初中生和老师'}。

【受众】${audience}

【视频号文案】
- 标题：1个，不超过20字，有吸引力
- 正文：150字，口语化，家长/老师视角，有共鸣感
- 结尾：引导点赞收藏转发

【小红书文案】
- 备选标题：3个，带emoji，有收藏冲动，不超过20字
- 正文：200字，口语化，家长/老师视角，有共鸣感
- 结尾：引导收藏+评论互动
- 话题标签：15个，含 #古诗 #${isPrimary?'小学语文':'初中语文'} #${curGrade} #古诗图解 #语文学习 等

【抖音文案】
- 备选标题：3个，带emoji，有点击欲，不超过20字
- 正文：150字，口语化，节奏感强，家长/老师视角
- 结尾：引导点赞收藏关注
- 话题标签：10个`;

  document.getElementById('promptImg').textContent = imgPrompt;
  document.getElementById('promptWx').textContent = wxPrompt;

  const ra = document.getElementById('resultArea');
  ra.style.display = 'block';
  ra.classList.remove('fade-up');
  void ra.offsetWidth;
  ra.classList.add('fade-up');
  ra.scrollIntoView({ behavior:'smooth', block:'start' });
}

// =============================================
// 工具函数
// =============================================
function toggleFold(hd) {
  const bd = hd.nextElementSibling;
  const tog = hd.querySelector('.fold-tog');
  const open = bd.classList.toggle('open');
  tog.textContent = open ? '×' : '+';
}


function switchTab(id, btn) {
  document.querySelectorAll('.result-tab').forEach(b => b.classList.remove('active'));
  document.querySelectorAll('.result-pane').forEach(p => p.classList.remove('active'));
  btn.classList.add('active');
  document.getElementById('pane-' + id).classList.add('active');
}
function copyPrompt(id, btn) {
  const text = document.getElementById(id).textContent;
  navigator.clipboard.writeText(text).then(() => {
    btn.textContent = '已复制 ✓'; btn.classList.add('copied');
    setTimeout(() => { btn.textContent = '一键复制'; btn.classList.remove('copied'); }, 2000);
  }).catch(() => {
    const ta = document.createElement('textarea');
    ta.value = text; document.body.appendChild(ta); ta.select();
    try { document.execCommand('copy'); } catch(e) {}
    document.body.removeChild(ta);
    btn.textContent = '已复制 ✓'; btn.classList.add('copied');
    setTimeout(() => { btn.textContent = '一键复制'; btn.classList.remove('copied'); }, 2000);
  });
}

// 初始化
renderGrades();
</script>
</body>
</html>

<!DOCTYPE html>
<html lang="zh-CN">
<head>
<meta charset="UTF-8">
<meta name="viewport" content="width=device-width, initial-scale=1.0">
<title>小学知识卡片提示词生成器</title>
<style>
@import url('https://fonts.googleapis.com/css2?family=Noto+Serif+SC:wght@400;600;700;900&display=swap');

:root {
  --bg: #faf6ef;
  --paper: #fffdf8;
  --white: #fffdf8;
  --nav: #3a1a00;
  --ink: #1a0f00;
  --ink2: #4a3010;
  --ink3: #8a6040;
  --red: #8b1a1a;
  --red-light: #fdecea;
  --gold: #c8920a;
  --gold-light: #fef9e7;
  --border: #e0cfa8;
  --shadow: rgba(26,15,0,.10);
  --text: #1a0f00;
  --text-dim: #8a6040;
  --chinese: #8b1a1a;
  --chinese-light: #fdecea;
  --math: #1a4a1a;
  --math-light: #edf5ed;
  --english: #1a2a6a;
  --english-light: #edf0fd;
  --science: #5a3a00;
  --science-light: #fef9e7;
  --flow: #3a1a5a;
  --flow-light: #f0edf8;
}

* { box-sizing: border-box; margin: 0; padding: 0; }

body {
  background: var(--bg);
  color: var(--text);
  font-family: 'Noto Serif SC', 'STKaiti', 'PingFang SC', serif;
  min-height: 100vh;
}

/* ── Header ── */
.header {
  text-align: center;
  padding: 40px 20px 28px;
  background: var(--nav);
  position: relative;
  border-bottom: 2px solid rgba(200,146,10,.4);
}
.header-badge {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  background: var(--white);
  border: 1.5px solid var(--border);
  border-radius: 99px;
  padding: 6px 18px;
  font-size: 12px;
  color: var(--text-dim);
  margin-bottom: 14px;
  letter-spacing: 0.05em;
}
.header-badge span { font-size: 15px; }
.header h1 { font-size:clamp(22px,4vw,36px);font-weight:900;color:#fff;letter-spacing:3px;margin-bottom:8px; }
.header h1 em { color:#f0c87a;font-style:normal; }
.header p { font-size:12px;color:#c8a060;letter-spacing:2px; }

/* ── Subject Nav ── */
.nav-wrap {
  background: var(--paper);
  border-bottom: 1px solid var(--border);
  padding: 10px 20px;
  overflow-x: auto;
  -webkit-overflow-scrolling: touch;
}
.subject-nav {
  display: flex;
  gap: 8px;
  flex-wrap: nowrap;
  justify-content: flex-start;
  max-width: none;
  min-width: max-content;
  margin: 0 auto;
}
.sub-btn {
  display: flex;
  align-items: center;
  gap: 7px;
  padding: 9px 18px;
  border-radius: 4px;
  border: 1px solid var(--border);
  background: var(--paper);
  font-family: 'Noto Serif SC', serif;
  font-size: 13px;
  font-weight: 700;
  cursor: pointer;
  transition: all 0.18s;
  color: var(--ink3);
  letter-spacing: 1px;
}
.sub-btn .icon { font-size: 16px; }
.sub-btn:hover { background:var(--gold-light);border-color:var(--gold);color:var(--ink2); }

.sub-btn[data-sub="chinese"].active  { background: var(--chinese-light);  border-color: var(--chinese);  color: var(--chinese); }
.sub-btn[data-sub="math"].active     { background: var(--math-light);      border-color: var(--math);      color: var(--math); }
.sub-btn[data-sub="english"].active  { background: var(--english-light);   border-color: var(--english);   color: var(--english); }
.sub-btn[data-sub="science"].active  { background: var(--science-light);   border-color: var(--science);   color: var(--science); }
.sub-btn[data-sub="flow"].active     { background: var(--flow-light);       border-color: var(--flow);       color: var(--flow); }

.sub-btn[data-sub="chinese"]:hover  { border-color: var(--chinese);  color: var(--chinese); }
.sub-btn[data-sub="math"]:hover     { border-color: var(--math);      color: var(--math); }
.sub-btn[data-sub="english"]:hover  { border-color: var(--english);   color: var(--english); }
.sub-btn[data-sub="science"]:hover  { border-color: var(--science);   color: var(--science); }
.sub-btn[data-sub="flow"]:hover     { border-color: var(--flow);       color: var(--flow); }

/* ── Panel ── */
.panels { max-width: 860px; margin: 0 auto; padding: 0 20px 60px; }
.panel { display: none; animation: slideIn 0.22s ease; }
.panel.active { display: block; }
@keyframes slideIn {
  from { opacity: 0; transform: translateY(10px); }
  to   { opacity: 1; transform: translateY(0); }
}

/* ── Card ── */
.card {
  background: var(--white);
  border-radius: var(--radius);
  border: 1.5px solid var(--border);
  overflow: hidden;
  margin-bottom: 16px;
  box-shadow: 0 2px 12px var(--shadow);
}
.card-head {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 14px 20px;
  border-bottom: 1.5px solid var(--border);
}
.card-title {
  display: flex;
  align-items: center;
  gap: 10px;
  font-size: 13px;
  font-weight: 700;
  letter-spacing: 0.05em;
}
.dot {
  width: 8px; height: 8px;
  border-radius: 50%;
  flex-shrink: 0;
}
.card-tag {
  font-size: 11px;
  padding: 4px 12px;
  border-radius: 99px;
  font-weight: 600;
  letter-spacing: 0.04em;
}
.card-body { padding: 20px; }

/* ── Desc box ── */
.desc-box {
  border-radius: var(--radius-sm);
  padding: 14px 16px;
  font-size: 13px;
  line-height: 1.8;
  margin-bottom: 16px;
  border: 1.5px dashed;
}
.desc-box strong { font-weight: 700; }

/* ── Input area ── */
.input-group { margin-bottom: 14px; }
.input-label {
  font-size: 12px;
  font-weight: 700;
  letter-spacing: 0.06em;
  margin-bottom: 7px;
  display: block;
}
.input-field {
  width: 100%;
  background: var(--bg);
  border: 1.5px solid var(--border);
  border-radius: var(--radius-sm);
  padding: 11px 14px;
  font-family: 'Noto Sans SC', sans-serif;
  font-size: 14px;
  color: var(--text);
  outline: none;
  transition: border-color 0.15s, box-shadow 0.15s;
  resize: vertical;
}
.input-field::placeholder { color: var(--text-dim); }

/* ── Generate button ── */
.gen-btn {
  width: 100%;
  padding: 13px;
  border: none;
  border-radius: var(--radius-sm);
  font-family: 'Noto Sans SC', sans-serif;
  font-size: 14px;
  font-weight: 700;
  letter-spacing: 0.08em;
  cursor: pointer;
  transition: all 0.18s;
  color: #fff;
  margin-top: 4px;
}
.gen-btn:hover { transform: translateY(-2px); filter: brightness(1.06); }
.gen-btn:active { transform: translateY(0); }

/* ── Output box ── */
.output-wrap { margin-top: 16px; }
.output-label {
  display: flex;
  align-items: center;
  justify-content: space-between;
  margin-bottom: 8px;
}
.output-label span {
  font-size: 12px;
  font-weight: 700;
  letter-spacing: 0.06em;
  color: var(--text-dim);
}
.copy-btn {
  display: flex;
  align-items: center;
  gap: 5px;
  background: var(--bg);
  border: 1.5px solid var(--border);
  border-radius: 8px;
  padding: 5px 13px;
  font-family: 'Noto Sans SC', sans-serif;
  font-size: 12px;
  font-weight: 600;
  cursor: pointer;
  transition: all 0.15s;
  color: var(--text-dim);
}
.copy-btn:hover { background: var(--white); border-color: #ccc; color: var(--text); }
.copy-btn.ok { color: #22c55e; border-color: #bbf7d0; background: #f0fdf4; }

.output-box {
  background: var(--bg);
  border: 1.5px solid var(--border);
  border-radius: var(--radius-sm);
  padding: 16px;
  font-size: 13.5px;
  line-height: 1.85;
  color: var(--text);
  white-space: pre-wrap;
  word-break: break-all;
  min-height: 160px;
  font-family: 'Noto Sans SC', sans-serif;
}
.output-box.empty {
  color: var(--text-dim);
  font-style: italic;
  font-size: 13px;
  display: flex;
  align-items: center;
  justify-content: center;
}

/* ── Tips ── */
.tips {
  border-radius: var(--radius-sm);
  padding: 14px 16px;
  font-size: 12.5px;
  line-height: 1.8;
  margin-top: 16px;
  border: 1.5px solid;
}
.tips strong { font-weight: 700; }

/* ── Steps ── */
.steps { margin-top: 16px; display: flex; flex-direction: column; gap: 10px; }
.step { display: flex; gap: 12px; align-items: flex-start; }
.step-n {
  width: 24px; height: 24px; min-width: 24px;
  border-radius: 50%;
  font-size: 12px; font-weight: 700;
  display: flex; align-items: center; justify-content: center;
  color: #fff; flex-shrink: 0; margin-top: 1px;
}
.step-t { font-size: 13px; color: var(--text-dim); line-height: 1.7; padding-top: 3px; }
.step-t strong { color: var(--text); }

/* ── Color theming per subject ── */
/* Chinese */
[data-sub="chinese"] .dot { background: var(--chinese); }
[data-sub="chinese"] .card-tag { background: var(--chinese-light); color: var(--chinese); border: 1px solid rgba(255,107,107,0.25); }
[data-sub="chinese"] .desc-box { background: var(--chinese-light); border-color: rgba(255,107,107,0.3); }
[data-sub="chinese"] .input-field:focus { border-color: var(--chinese); box-shadow: 0 0 0 3px rgba(255,107,107,0.1); }
[data-sub="chinese"] .gen-btn { background: linear-gradient(135deg, #ff6b6b, #ff8e8e); }
[data-sub="chinese"] .tips { background: var(--chinese-light); border-color: rgba(255,107,107,0.25); }
[data-sub="chinese"] .step-n { background: var(--chinese); }
[data-sub="chinese"] .card-title { color: var(--chinese); }
[data-sub="chinese"] .input-label { color: var(--chinese); }

/* Math */
[data-sub="math"] .dot { background: var(--math); }
[data-sub="math"] .card-tag { background: var(--math-light); color: var(--math); border: 1px solid rgba(78,205,196,0.3); }
[data-sub="math"] .desc-box { background: var(--math-light); border-color: rgba(78,205,196,0.35); }
[data-sub="math"] .input-field:focus { border-color: var(--math); box-shadow: 0 0 0 3px rgba(78,205,196,0.12); }
[data-sub="math"] .gen-btn { background: linear-gradient(135deg, #4ecdc4, #45b8b0); }
[data-sub="math"] .tips { background: var(--math-light); border-color: rgba(78,205,196,0.3); }
[data-sub="math"] .step-n { background: var(--math); }
[data-sub="math"] .card-title { color: var(--math); }
[data-sub="math"] .input-label { color: var(--math); }

/* English */
[data-sub="english"] .dot { background: var(--english); }
[data-sub="english"] .card-tag { background: var(--english-light); color: var(--english); border: 1px solid rgba(167,139,250,0.3); }
[data-sub="english"] .desc-box { background: var(--english-light); border-color: rgba(167,139,250,0.35); }
[data-sub="english"] .input-field:focus { border-color: var(--english); box-shadow: 0 0 0 3px rgba(167,139,250,0.12); }
[data-sub="english"] .gen-btn { background: linear-gradient(135deg, #a78bfa, #9b72f7); }
[data-sub="english"] .tips { background: var(--english-light); border-color: rgba(167,139,250,0.3); }
[data-sub="english"] .step-n { background: var(--english); }
[data-sub="english"] .card-title { color: var(--english); }
[data-sub="english"] .input-label { color: var(--english); }

/* Science */
[data-sub="science"] .dot { background: var(--science); }
[data-sub="science"] .card-tag { background: var(--science-light); color: var(--science); border: 1px solid rgba(89,184,103,0.3); }
[data-sub="science"] .desc-box { background: var(--science-light); border-color: rgba(89,184,103,0.35); }
[data-sub="science"] .input-field:focus { border-color: var(--science); box-shadow: 0 0 0 3px rgba(89,184,103,0.12); }
[data-sub="science"] .gen-btn { background: linear-gradient(135deg, #59b867, #4caa5a); }
[data-sub="science"] .tips { background: var(--science-light); border-color: rgba(89,184,103,0.3); }
[data-sub="science"] .step-n { background: var(--science); }
[data-sub="science"] .card-title { color: var(--science); }
[data-sub="science"] .input-label { color: var(--science); }

/* Flow */
[data-sub="flow"] .dot { background: var(--flow); }
[data-sub="flow"] .card-tag { background: var(--flow-light); color: var(--flow); border: 1px solid rgba(245,158,66,0.3); }
[data-sub="flow"] .desc-box { background: var(--flow-light); border-color: rgba(245,158,66,0.35); }
[data-sub="flow"] .input-field:focus { border-color: var(--flow); box-shadow: 0 0 0 3px rgba(245,158,66,0.12); }
[data-sub="flow"] .gen-btn { background: linear-gradient(135deg, #f59e42, #e8892a); }
[data-sub="flow"] .tips { background: var(--flow-light); border-color: rgba(245,158,66,0.3); }
[data-sub="flow"] .step-n { background: var(--flow); }
[data-sub="flow"] .card-title { color: var(--flow); }
[data-sub="flow"] .input-label { color: var(--flow); }

/* scrollbar */
::-webkit-scrollbar { width: 5px; }
::-webkit-scrollbar-track { background: transparent; }
::-webkit-scrollbar-thumb { background: var(--border); border-radius: 3px; }

.out-tabs{display:flex;gap:0;border-bottom:2px solid #e0cfa8;margin-top:14px;margin-bottom:0}
.out-tab{padding:9px 16px;font-size:12px;font-weight:700;color:#8a6040;cursor:pointer;border:none;background:none;font-family:inherit;letter-spacing:1px;border-bottom:2px solid transparent;margin-bottom:-2px;transition:all .2s}
.out-tab.active{color:#8b1a1a;border-bottom-color:#8b1a1a}
.out-tab:hover{color:#4a3010}
.out-pane{display:none}.out-pane.active{display:block;padding-top:12px}

.nav-wrap::-webkit-scrollbar { height: 3px; }
.nav-wrap::-webkit-scrollbar-track { background: transparent; }
.nav-wrap::-webkit-scrollbar-thumb { background: var(--border); border-radius: 2px; }
</style>
</head>
<body>

<div class="header">
  <div class="header-badge"><span>🎒</span> 阿坚AIGC · 知识图文卡片课</div>
  <h1>小学知识卡片<em>提示词生成器</em></h1>
  <p>输入知识点 · 一键生成香蕉模型 / 即梦可用的图片提示词</p>
</div>

<div class="nav-wrap">
  <div class="subject-nav">
    <button class="sub-btn active" data-sub="chinese" onclick="switchPanel('chinese')">
      <span class="icon">📖</span> 语文·成语古诗
    </button>
    <button class="sub-btn" data-sub="math" onclick="switchPanel('math')">
      <span class="icon">🔢</span> 数学·解题思路
    </button>
    <button class="sub-btn" data-sub="english" onclick="switchPanel('english')">
      <span class="icon">🔤</span> 英语·词汇语法
    </button>
    <button class="sub-btn" data-sub="science" onclick="switchPanel('science')">
      <span class="icon">🔬</span> 知识图谱·理科
    </button>
    <button class="sub-btn" data-sub="flow" onclick="switchPanel('flow')">
      <span class="icon">📋</span> 流程步骤·实验
    </button>
  </div>
</div>

<div class="panels">

  <!-- ════ 语文 ════ -->
  <div class="panel active" id="panel-chinese" data-sub="chinese">
    <div class="card" data-sub="chinese">
      <div class="card-head">
        <div class="card-title"><span class="dot"></span>语文·成语 / 古诗知识卡片</div>
        <span class="card-tag">4格横版故事卡</span>
      </div>
      <div class="card-body">
        <div class="desc-box">
          <strong>适用内容：</strong>成语故事（拔苗助长、守株待兔……）、古诗寓意讲解、文言文故事图解<br>
          <strong>卡片风格：</strong>4:3横版 · 扁平Q版卡通 · 米黄底淡绿橙配色 · ABCD四格叙事
        </div>
        <div class="input-group">
          <label class="input-label">📝 输入格式：成语名：故事一句话概述</label>
          <textarea class="input-field" id="input-chinese" rows="3"
            placeholder="例：守株待兔：农夫捡到撞树桩的兔子后，天天坐等兔子不耕田，最后颗粒无收。"></textarea>
        </div>
        <button class="gen-btn" onclick="generate('chinese')">✨ 生成提示词</button>
        <div class="output-wrap">
          <div class="out-tabs">
            <button class="out-tab active" onclick="switchOutTab('chinese','img',this)">📋 图片提示词</button>
            <button class="out-tab" onclick="switchOutTab('chinese','wx',this)">📝 三平台文案</button>
          </div>
          <div class="out-pane active" id="out-chinese-img">
            <div class="output-label">
              <span>📋 图片提示词 · 复制发给香蕉Pro出图</span>
              <button class="copy-btn" id="copy-chinese" onclick="copyOutPane('chinese','img')">⎘ 复制</button>
            </div>
            <div class="output-box empty" id="output-chinese">点击「生成提示词」后，结果显示在这里</div>
          </div>
          <div class="out-pane" id="out-chinese-wx">
            <div class="output-label">
              <span>📝 三平台文案提示词 · 复制发给Claude</span>
              <button class="copy-btn" id="copy-chinese-wx" onclick="copyOutPane('chinese','wx')">⎘ 复制</button>
            </div>
            <div class="output-box" id="output-chinese-wx">点击「生成提示词」后，切换此Tab查看文案提示词</div>
          </div>
        </div>
      </div>
    </div>
    <div class="steps">
      <div class="step"><div class="step-n" style="background:var(--chinese)">1</div><div class="step-t">输入成语名称和故事概述，格式参考占位符</div></div>
      <div class="step"><div class="step-n" style="background:var(--chinese)">2</div><div class="step-t">点击生成，复制提示词</div></div>
      <div class="step"><div class="step-n" style="background:var(--chinese)">3</div><div class="step-t">粘贴到<strong>香蕉模型（LibLib）</strong>或<strong>即梦</strong>，比例选 4:3 横版，出图</div></div>
    </div>
  </div>

  <!-- ════ 数学 ════ -->
  <div class="panel" id="panel-math" data-sub="math">
    <div class="card" data-sub="math">
      <div class="card-head">
        <div class="card-title"><span class="dot"></span>数学·经典题型解题思路卡</div>
        <span class="card-tag">4格横版解题卡</span>
      </div>
      <div class="card-body">
        <div class="desc-box">
          <strong>适用内容：</strong>鸡兔同笼、植树问题、行程追及、盈亏、年龄、周长面积、和差倍……<br>
          <strong>卡片风格：</strong>4:3横版 · Q版卡通 · 米黄底淡蓝橙配色 · 错误→分析→解法→验证
        </div>
        <div class="input-group">
          <label class="input-label">📝 输入格式：题目名：完整题目条件和问题</label>
          <textarea class="input-field" id="input-math" rows="3"
            placeholder="例：鸡兔同笼：笼子里有鸡和兔，共35个头，94只脚，问有几只鸡几只兔？"></textarea>
        </div>
        <button class="gen-btn" onclick="generate('math')">✨ 生成提示词</button>
        <div class="output-wrap">
          <div class="out-tabs">
            <button class="out-tab active" onclick="switchOutTab('math','img',this)">📋 图片提示词</button>
            <button class="out-tab" onclick="switchOutTab('math','wx',this)">📝 三平台文案</button>
          </div>
          <div class="out-pane active" id="out-math-img">
            <div class="output-label">
              <span>📋 图片提示词 · 复制发给香蕉Pro出图</span>
              <button class="copy-btn" id="copy-math" onclick="copyOutPane('math','img')">⎘ 复制</button>
            </div>
            <div class="output-box empty" id="output-math">点击「生成提示词」后，结果显示在这里</div>
          </div>
          <div class="out-pane" id="out-math-wx">
            <div class="output-label">
              <span>📝 三平台文案提示词 · 复制发给Claude</span>
              <button class="copy-btn" id="copy-math-wx" onclick="copyOutPane('math','wx')">⎘ 复制</button>
            </div>
            <div class="output-box" id="output-math-wx">点击「生成提示词」后，切换此Tab查看文案提示词</div>
          </div>
        </div>
      </div>
    </div>
    <div class="steps">
      <div class="step"><div class="step-n" style="background:var(--math)">1</div><div class="step-t">输入题目名称和完整条件，包含所有数字</div></div>
      <div class="step"><div class="step-n" style="background:var(--math)">2</div><div class="step-t">点击生成，复制提示词</div></div>
      <div class="step"><div class="step-n" style="background:var(--math)">3</div><div class="step-t">粘贴到<strong>香蕉模型（LibLib）</strong>或<strong>即梦</strong>，比例选 4:3 横版，出图</div></div>
    </div>
  </div>

  <!-- ════ 英语 ════ -->
  <div class="panel" id="panel-english" data-sub="english">
    <div class="card" data-sub="english">
      <div class="card-head">
        <div class="card-title"><span class="dot"></span>英语·词汇 / 语法知识卡片</div>
        <span class="card-tag">对比横版卡</span>
      </div>
      <div class="card-body">
        <div class="desc-box">
          <strong>适用内容：</strong>易混淆词汇（look/see/watch）、时态对比、介词用法、句型结构……<br>
          <strong>卡片风格：</strong>4:3横版 · Q版卡通 · 米黄底淡蓝粉配色 · 词汇卡+场景对比+记忆口诀
        </div>
        <div class="input-group">
          <label class="input-label">📝 输入格式：主题：简要说明知识点</label>
          <textarea class="input-field" id="input-english" rows="3"
            placeholder="例：look/see/watch的区别：这三个词都表示「看」，但用法不同。"></textarea>
        </div>
        <button class="gen-btn" onclick="generate('english')">✨ 生成提示词</button>
        <div class="output-wrap">
          <div class="out-tabs">
            <button class="out-tab active" onclick="switchOutTab('english','img',this)">📋 图片提示词</button>
            <button class="out-tab" onclick="switchOutTab('english','wx',this)">📝 三平台文案</button>
          </div>
          <div class="out-pane active" id="out-english-img">
            <div class="output-label">
              <span>📋 图片提示词 · 复制发给香蕉Pro出图</span>
              <button class="copy-btn" id="copy-english" onclick="copyOutPane('english','img')">⎘ 复制</button>
            </div>
            <div class="output-box empty" id="output-english">点击「生成提示词」后，结果显示在这里</div>
          </div>
          <div class="out-pane" id="out-english-wx">
            <div class="output-label">
              <span>📝 三平台文案提示词 · 复制发给Claude</span>
              <button class="copy-btn" id="copy-english-wx" onclick="copyOutPane('english','wx')">⎘ 复制</button>
            </div>
            <div class="output-box" id="output-english-wx">点击「生成提示词」后，切换此Tab查看文案提示词</div>
          </div>
        </div>
      </div>
    </div>
    <div class="steps">
      <div class="step"><div class="step-n" style="background:var(--english)">1</div><div class="step-t">输入英语主题，说明是词汇对比还是语法点</div></div>
      <div class="step"><div class="step-n" style="background:var(--english)">2</div><div class="step-t">点击生成，复制提示词</div></div>
      <div class="step"><div class="step-n" style="background:var(--english)">3</div><div class="step-t">粘贴到<strong>香蕉模型（LibLib）</strong>或<strong>即梦</strong>，比例选 4:3 横版，出图</div></div>
    </div>
  </div>

  <!-- ════ 知识图谱 ════ -->
  <div class="panel" id="panel-science" data-sub="science">
    <div class="card" data-sub="science">
      <div class="card-head">
        <div class="card-title"><span class="dot"></span>知识图谱·物理 / 化学 / 地理 / 生物</div>
        <span class="card-tag">中心主体+模块卡</span>
      </div>
      <div class="card-body">
        <div class="desc-box">
          <strong>适用内容：</strong>物理定律、化学原理、地理概念、生物知识……<br>
          <strong>卡片风格：</strong>4:3横版 · 数字手绘线条 · 中心主体放射4-6模块 · 科普图鉴风
        </div>
        <div class="input-group">
          <label class="input-label">📝 输入格式：概念名：简要说明</label>
          <input type="text" class="input-field" id="input-science-concept"
            placeholder="例：牛顿第一运动定律">
        </div>
        <div class="input-group">
          <label class="input-label">🔬 学科</label>
          <select class="input-field" id="input-science-sub" style="height:42px;cursor:pointer;">
            <option value="物理" data-color="浅湖蓝">物理（浅蓝色系）</option>
            <option value="化学" data-color="浅紫">化学（浅紫色系）</option>
            <option value="地理" data-color="大地色">地理（大地色系）</option>
            <option value="生物" data-color="浅绿">生物（浅绿色系）</option>
          </select>
        </div>
        <div class="input-group">
          <label class="input-label">📄 概念说明（一句话）</label>
          <textarea class="input-field" id="input-science-desc" rows="2"
            placeholder="例：惯性定律，物体在不受外力时保持静止或匀速直线运动。"></textarea>
        </div>
        <button class="gen-btn" onclick="generate('science')">✨ 生成提示词</button>
        <div class="output-wrap">
          <div class="out-tabs">
            <button class="out-tab active" onclick="switchOutTab('science','img',this)">📋 图片提示词</button>
            <button class="out-tab" onclick="switchOutTab('science','wx',this)">📝 三平台文案</button>
          </div>
          <div class="out-pane active" id="out-science-img">
            <div class="output-label">
              <span>📋 图片提示词 · 复制发给香蕉Pro出图</span>
              <button class="copy-btn" id="copy-science" onclick="copyOutPane('science','img')">⎘ 复制</button>
            </div>
            <div class="output-box empty" id="output-science">点击「生成提示词」后，结果显示在这里</div>
          </div>
          <div class="out-pane" id="out-science-wx">
            <div class="output-label">
              <span>📝 三平台文案提示词 · 复制发给Claude</span>
              <button class="copy-btn" id="copy-science-wx" onclick="copyOutPane('science','wx')">⎘ 复制</button>
            </div>
            <div class="output-box" id="output-science-wx">点击「生成提示词」后，切换此Tab查看文案提示词</div>
          </div>
        </div>
      </div>
    </div>
    <div class="steps">
      <div class="step"><div class="step-n" style="background:var(--science)">1</div><div class="step-t">填写概念名、选择学科、输入一句话说明</div></div>
      <div class="step"><div class="step-n" style="background:var(--science)">2</div><div class="step-t">点击生成，复制提示词</div></div>
      <div class="step"><div class="step-n" style="background:var(--science)">3</div><div class="step-t">粘贴到<strong>香蕉模型（LibLib）</strong>或<strong>即梦</strong>，比例选 4:3 横版，出图</div></div>
    </div>
  </div>

  <!-- ════ 流程步骤 ════ -->
  <div class="panel" id="panel-flow" data-sub="flow">
    <div class="card" data-sub="flow">
      <div class="card-head">
        <div class="card-title"><span class="dot"></span>流程步骤·实验 / 制作 / 操作指南</div>
        <span class="card-tag">竖版步骤卡</span>
      </div>
      <div class="card-body">
        <div class="desc-box">
          <strong>适用内容：</strong>科学实验、手工制作、生活技能、安全教育……<br>
          <strong>卡片风格：</strong>3:4竖版 · 手绘水彩风 · 马卡龙配色步骤卡 · 4-7步流程
        </div>
        <div class="input-group">
          <label class="input-label">📝 输入格式：流程名：步骤1→步骤2→步骤3……</label>
          <textarea class="input-field" id="input-flow" rows="3"
            placeholder="例：种豆子实验：准备材料→浸泡种子→放入容器→观察记录生长过程。"></textarea>
        </div>
        <button class="gen-btn" onclick="generate('flow')">✨ 生成提示词</button>
        <div class="output-wrap">
          <div class="out-tabs">
            <button class="out-tab active" onclick="switchOutTab('flow','img',this)">📋 图片提示词</button>
            <button class="out-tab" onclick="switchOutTab('flow','wx',this)">📝 三平台文案</button>
          </div>
          <div class="out-pane active" id="out-flow-img">
            <div class="output-label">
              <span>📋 图片提示词 · 复制发给香蕉Pro出图</span>
              <button class="copy-btn" id="copy-flow" onclick="copyOutPane('flow','img')">⎘ 复制</button>
            </div>
            <div class="output-box empty" id="output-flow">点击「生成提示词」后，结果显示在这里</div>
          </div>
          <div class="out-pane" id="out-flow-wx">
            <div class="output-label">
              <span>📝 三平台文案提示词 · 复制发给Claude</span>
              <button class="copy-btn" id="copy-flow-wx" onclick="copyOutPane('flow','wx')">⎘ 复制</button>
            </div>
            <div class="output-box" id="output-flow-wx">点击「生成提示词」后，切换此Tab查看文案提示词</div>
          </div>
        </div>
      </div>
    </div>
    <div class="steps">
      <div class="step"><div class="step-n" style="background:var(--flow)">1</div><div class="step-t">输入流程名称和步骤，用→分隔每个步骤</div></div>
      <div class="step"><div class="step-n" style="background:var(--flow)">2</div><div class="step-t">点击生成，复制提示词</div></div>
      <div class="step"><div class="step-n" style="background:var(--flow)">3</div><div class="step-t">粘贴到<strong>香蕉模型（LibLib）</strong>或<strong>即梦</strong>，比例选 <strong>3:4 竖版</strong>，出图</div></div>
    </div>
  </div>

</div><!-- /panels -->

<script>
// ── Tab switch ──
function switchPanel(sub) {
  document.querySelectorAll('.panel').forEach(p => p.classList.remove('active'));
  document.querySelectorAll('.sub-btn').forEach(b => b.classList.remove('active'));
  document.getElementById('panel-' + sub).classList.add('active');
  document.querySelector('.sub-btn[data-sub="' + sub + '"]').classList.add('active');
}

// ── Copy ──
function copyOutput(sub) {
  const box = document.getElementById('output-' + sub);
  const text = box.textContent.trim();
  if (!text || box.classList.contains('empty')) return;
  navigator.clipboard.writeText(text).then(() => {
    const btn = document.getElementById('copy-' + sub);
    const orig = btn.innerHTML;
    btn.innerHTML = '✓ 已复制';
    btn.classList.add('ok');
    setTimeout(() => { btn.innerHTML = orig; btn.classList.remove('ok'); }, 2000);
  });
}

// ── Set output ──
function setOutput(sub, text, topic) {
  const box = document.getElementById('output-' + sub);
  box.textContent = text;
  box.classList.remove('empty');
  // 同步更新文案提示词
  const wxBox = document.getElementById('output-' + sub + '-wx');
  if (wxBox && topic) {
    wxBox.textContent = generate3PlatformPrompt(sub, topic);
    wxBox.classList.remove('empty');
  }
}
function switchOutTab(sub, pane, btn) {
  var wrap = btn.closest('.output-wrap');
  wrap.querySelectorAll('.out-tab').forEach(function(b){ b.classList.remove('active'); });
  wrap.querySelectorAll('.out-pane').forEach(function(p){ p.classList.remove('active'); });
  btn.classList.add('active');
  document.getElementById('out-' + sub + '-' + pane).classList.add('active');
}

function copyOutPane(sub, pane) {
  var id = pane === 'img' ? 'output-' + sub : 'output-' + sub + '-wx';
  var text = document.getElementById(id).textContent;
  if (!text || text.indexOf('点击') === 0) return;
  var btn = document.getElementById('copy-' + sub + (pane === 'wx' ? '-wx' : ''));
  navigator.clipboard.writeText(text).then(function() {
    btn.textContent = '已复制 ✓';
    setTimeout(function(){ btn.textContent = '⎘ 复制'; }, 1800);
  });
}

function generate3PlatformPrompt(sub, topic) {
  return '你是一位擅长三平台运营的AIGC内容创作者。\n我刚刚用AI生成了一张「' + topic + '」知识卡片图，请根据图片内容同时输出三平台配套文案：\n\n【视频号文案】\n- 标题：1个，不超过20字，有吸引力\n- 正文：150字，口语化，有共鸣感\n- 结尾：引导点赞收藏转发\n\n【小红书文案】\n- 备选标题：3个，带emoji，不超过20字\n- 正文：200字，口语化，有共鸣感\n- 结尾：引导收藏+评论互动\n- 话题标签：10个\n\n【抖音文案】\n- 备选标题：3个，带emoji，有点击欲，不超过20字\n- 正文：150字，节奏感强\n- 结尾：引导点赞收藏关注\n- 话题标签：8个';
}


// ══════════════════════════════════════
// ── GENERATORS ──
// ══════════════════════════════════════

function generate(sub) {
  if (sub === 'chinese') generateChinese();
  else if (sub === 'math') generateMath();
  else if (sub === 'english') generateEnglish();
  else if (sub === 'science') generateScience();
  else if (sub === 'flow') generateFlow();
}

// ── 语文 ──
function generateChinese() {
  const raw = document.getElementById('input-chinese').value.trim();
  if (!raw) { alert('请先输入成语名称和故事概述'); return; }

  const colonIdx = raw.indexOf('：') !== -1 ? raw.indexOf('：') : raw.indexOf(':');
  const name = colonIdx > -1 ? raw.substring(0, colonIdx).trim() : raw.split(/\s/)[0];
  const story = colonIdx > -1 ? raw.substring(colonIdx + 1).trim() : raw;

  const prompt =
`【香蕉模型提示词】

4:3横版扁平插画教育信息图，${name}寓言，米黄底淡绿橙配色，Q版卡通。

顶部：深棕木质招牌"${name}"白色大字，下方米色虚线框"${story}"，左上蓝纸胶带右上橙纸胶带斜贴，四角金色星星。

上层问题：左侧Q版主角人物（服装符合故事背景，神情鲜明），核心道具或场景，对话气泡"[核心困惑或错误想法]"，右侧对比元素，红"？！"符号闪电。

中层四格（标题"${name}的故事过程"）：

A格：第一步场景——事件起因，Q版人物开始行动，气泡"[第一步台词]"，虚线箭头指向关键细节
B格：第二步场景——发展过程，动作继续，气泡"[第二步台词]"，时间推移元素（太阳/月亮）
C格：第三步场景——接近结局，气泡"[第三步台词]"，💡或⚠️符号暗示转折
D格：最终结果——失败或教训揭晓，Q版人物表情夸张（震惊/悲伤），气泡"[结局台词]"，☠️符号

四格虚线连接，右下角圆框：正确做法小图（展示正确/聪明的方式）

下层总结：竹简卷轴"道理"+"智"红印章，左侧主角蹲地托腮"？"黄灯泡💡，右侧米色列表：
- 道理要点一（10字内）
- 道理要点二（10字内）
- 道理要点三（10字内）

最底部：蓝色横幅"用这样的方式讲解知识看起来更有趣又高级"，两端打结绳子

装饰：蓝橙纸胶带四角斜贴、铜回形针夹顶部、金星礼盒散布、左下红印章"${name}"

负向：写实照片、3D渲染、暗黑色调、密集文字、现代UI`;

  setOutput('chinese', prompt, name);
}

// ── 数学 ──
function generateMath() {
  const raw = document.getElementById('input-math').value.trim();
  if (!raw) { alert('请先输入题目名称和题目条件'); return; }

  const colonIdx = raw.indexOf('：') !== -1 ? raw.indexOf('：') : raw.indexOf(':');
  const name = colonIdx > -1 ? raw.substring(0, colonIdx).trim() : raw.split(/\s/)[0];
  const problem = colonIdx > -1 ? raw.substring(colonIdx + 1).trim() : raw;

  const prompt =
`【香蕉模型提示词】

4:3横版扁平插画数学教育信息图，${name}，米黄底淡蓝橙配色，Q版卡通。

顶部：深蓝木质招牌"${name}"白字，下方虚线框"${problem}"，左上蓝纸胶带右上橙纸胶带，四角数学符号装饰（+×÷=）。

上层问题：左侧Q版小孩（困惑表情手托腮）面对题目场景的具象化呈现，气泡"怎么算？"，右侧展示关键条件图标化（数字、图形、示意图），红"？"符号。

中层四格（标题"解题思路"）：

A格：小孩尝试最直觉的错误想法，气泡"[初步错误思路]"，计算尝试框，⚠️黄色三角标记"想错了！"，虚线指向错误原因
B格：小孩认真分析（手指画图或数数），气泡"[发现的规律或关键]"，💡黄色灯泡，画出关键分析图示（对比图/数轴/示意图）
C格：小孩恍然大悟（举手跳起兴奋），气泡"[正确思路和计算过程]"，完整列式计算，✓绿色对勾
D格：验证场景，具象化展示最终答案（实物/图形），计算验证框显示"验算正确✓"，气泡"答案正确！"，绿色大对勾

四格虚线连接，右下圆框：其他解法小图标（方程法/图解法/列表法）

下层总结：蓝色卷轴"知识点"+"数"字红色印章，左侧小孩竖大拇指笑脸😊，右侧米色列表框：
- 核心解题方法（一句话）
- 数学思维要点（一句话）
- 解题注意事项（一句话）

最底部：蓝色横幅"用这样的方式讲解知识看起来更有趣又高级"，两端打结绳子

装饰：蓝橙纸胶带四角斜贴、回形针夹顶部、数学符号+×÷=√和星星散布、左下红色印章"${name}"

负向：写实照片、3D渲染、暗黑色调、密集文字、复杂公式堆砌`;

  setOutput('math', prompt, raw.split('\n')[0].trim());
}

// ── 英语 ──
function generateEnglish() {
  const raw = document.getElementById('input-english').value.trim();
  if (!raw) { alert('请先输入英语知识点'); return; }

  const colonIdx = raw.indexOf('：') !== -1 ? raw.indexOf('：') : raw.indexOf(':');
  const name = colonIdx > -1 ? raw.substring(0, colonIdx).trim() : raw.split(/\s/)[0];
  const desc = colonIdx > -1 ? raw.substring(colonIdx + 1).trim() : raw;

  // 提取英文词汇（如 look/see/watch）
  const engMatch = name.match(/[a-zA-Z][a-zA-Z\/\s]+/);
  const engTitle = engMatch ? engMatch[0].trim().toUpperCase() : name;
  const cnTitle = name.replace(/[a-zA-Z\/\s]/g, '').trim() || '词汇对比';

  const prompt =
`【香蕉模型提示词】

4:3横版扁平插画英语教育信息图，${cnTitle || name}，米黄底淡蓝粉配色，Q版卡通。

顶部：淡蓝色圆角横幅"${engTitle}"大字，下方"${desc || name}"小字，左上蓝纸胶带右上粉纸胶带，四角字母ABC装饰。

左侧-词汇卡区：2-3个彩色卡片竖排（粉/蓝/黄渐变色），每张卡片包含：
大号单词/词组，音标（如有），词性标注，中文含义，配相关小图标

中部-场景对比区（2-3个横向场景框）：
每个框内：Q版人物在具体生活场景中使用该词的情境，对话气泡（英文例句），气泡下方中文翻译，右上角对应词汇图标，场景背景简洁明了

右侧-用法对比框：淡黄色圆角框，标题"重点区分✨"：
用简短一句话说明每个词/语法点的核心用法区别，分条列出，每条10字以内

底部-记忆技巧：粉色横幅卷轴"记忆口诀💡"，大字展示记忆口诀或顺口溜（朗朗上口，押韵更好）

装饰：蓝粉纸胶带四角斜贴、回形针夹顶部、字母ABC和星星散布、左下蓝色英文印章"${engTitle.split('/')[0].trim()}"

负向：写实照片、3D渲染、暗黑色调、密集文字、复杂语法表格`;

  setOutput('english', prompt, raw.split('\n')[0].trim());
}

// ── 知识图谱 ──
function generateScience() {
  const concept = document.getElementById('input-science-concept').value.trim();
  const desc = document.getElementById('input-science-desc').value.trim();
  const subSelect = document.getElementById('input-science-sub');
  const subName = subSelect.value;
  const colorMap = { '物理': '浅湖蓝配色', '化学': '浅紫薰衣草配色', '地理': '大地色海洋柔和色系（浅土黄浅湖蓝）', '生物': '浅绿配色' };
  const iconMap = { '物理': '原子符号和星星', '化学': '烧杯和分子结构', '地理': '地球和山脉', '生物': '叶子和细胞' };
  const color = colorMap[subName] || '浅蓝配色';
  const icon = iconMap[subName] || '相关学科图标';

  if (!concept) { alert('请先输入概念名称'); return; }

  const prompt =
`【香蕉模型提示词】

4:3横版数字手绘插画科普信息图，主题${concept}，${color}，柔和圆润线条，科普图鉴风格。

顶部：居中大标题"${concept}"，下方小字"${concept}·${subName}知识图谱"，四角${icon}装饰。

中心主体区（占画面40%）：
${desc ? concept + '的核心视觉呈现——' + desc : concept + '的核心实物/结构/原理图'}，关键部位用标注箭头和简短文字指示，Q版卡通化处理（可爱不失严谨），周围放射状虚线连接四周4-6个模块。

左上模块-基本概念：圆角矩形卡片，标题"是什么？"，用2-3个要点说明核心定义，配相关小图标

右上模块-工作原理/运动规律：圆角矩形卡片，标题"怎么运作？"，用简单流程图或示意图展示，箭头指示方向，配相关小图标

左下模块-生活应用实例：圆角矩形卡片，标题"生活中在哪？"，可爱卡通化生活场景举例（2-3个），每个配小图标

右下模块-数据/图表：圆角矩形卡片，标题"关键数据"，简化柱状图或对比数据，数字直观呈现，配温度计/尺子等量化图标

底部横向长条（如有必要）：卷轴样式，大字展示记忆口诀或重要公式，朗朗上口

整体装饰：简洁圆角矩形模块、放射状指示箭头、少量可爱表情图标、背景纯白或极浅色，留白充足。

负向：写实照片、3D渲染、暗黑色调、密集文字、复杂推导过程`;

  setOutput('science', prompt, raw.split('\n')[0].trim());
}

// ── 流程步骤 ──
function generateFlow() {
  const raw = document.getElementById('input-flow').value.trim();
  if (!raw) { alert('请先输入流程名称和步骤'); return; }

  const colonIdx = raw.indexOf('：') !== -1 ? raw.indexOf('：') : raw.indexOf(':');
  const name = colonIdx > -1 ? raw.substring(0, colonIdx).trim() : raw.split(/[→。\n]/)[0];
  const stepsRaw = colonIdx > -1 ? raw.substring(colonIdx + 1).trim() : raw;

  // 解析步骤
  const steps = stepsRaw.split(/[→→\->]/).map(s => s.trim().replace(/。$/, '')).filter(s => s.length > 0);
  const stepCount = Math.min(steps.length, 7);
  const colors = ['淡蓝', '淡绿', '淡黄', '淡粉', '淡紫', '淡橙', '淡青'];

  let stepsBlock = '';
  steps.slice(0, stepCount).forEach((step, i) => {
    const isLast = i === stepCount - 1;
    stepsBlock += `步骤${i+1}卡片（${colors[i]}马卡龙色块）：
左上角大号"${i+1}"，标题"${step}"，右侧Q版插图（人物正在进行该步骤的具体动作），下方说明文字（操作要点，不超过15字）${isLast ? '，绿色大对勾✓' : '，底部粗箭头↓'}

`;
  });

  const prompt =
`【香蕉模型提示词】

3:4竖版手绘风格流程图，主题${name}，马卡龙配色（淡蓝淡绿淡黄淡粉），温暖亲和，呼吸感排版。

顶部区（15%）：大标题"${name}"，下方小字"Step by Step"，四角与主题相关图标装饰（工具/材料/成品图标），米黄色纸张纹理背景。

主视觉区（20%）：
完成后的成品或场景展示（Q版卡通风格），展现最终目标状态，周围装饰与主题相关的小图标，人物表情开心有成就感

步骤区（60%，竖向排列）：

${stepsBlock}
底部提示区（5%）：马卡龙色横幅卷轴"温馨提示💡"，文字"[操作注意事项或安全提醒，简短]"

整体装饰：彩色纸胶带四角、回形针、手绘线条装饰、留白充足、圆润可爱字体、卡片微错落排列

负向：写实照片、3D渲染、暗黑色调、密集排版、过于复杂的细节`;

  setOutput('flow', prompt, raw.split('\n')[0].trim());
}
</script>

<div style="text-align:center;padding:24px 20px;border-top:1px solid #e0cfa8;margin-top:24px;background:#faf6ef">
  <div style="font-size:14px;font-weight:700;color:#1a0a00;letter-spacing:3px;margin-bottom:6px;font-family:'PingFang SC','Microsoft YaHei',serif">📜 阿坚AIGC · 工具中心</div>
  <div style="font-size:11px;color:#6a4a20;letter-spacing:1px;line-height:2">小学知识卡片提示词生成器 · V1<br>版权所有 © 阿坚AIGC · 仅供授权用户个人创作使用 · 禁止商业转载与二次分发</div>
</div>
</body>
</html>

<!DOCTYPE html>
<html lang="zh-CN">
<head>
<meta charset="UTF-8">
<meta name="viewport" content="width=device-width, initial-scale=1.0">
<title>小学知识卡片提示词生成器 · 阿坚AIGC</title>
<link rel="preconnect" href="https://fonts.googleapis.com">
<link href="https://fonts.googleapis.com/css2?family=Noto+Serif+SC:wght@400;600;700;900&display=swap" rel="stylesheet">
<style>
*{box-sizing:border-box;margin:0;padding:0}
:root{
  --bg:#faf6ef;--paper:#fffdf8;--ink:#1a0f00;--ink2:#4a3010;--ink3:#8a6040;
  --red:#8b1a1a;--red-light:#fdecea;--gold:#c8920a;--gold-light:#fef9e7;
  --border:#e0cfa8;--nav:#3a1a00;--shadow:rgba(26,15,0,.08);
  --green:#1a4a1a;--green-light:#edf5ed;--blue:#1a2a6a;--blue-light:#edf0fd;
}
body{font-family:'Noto Serif SC','STKaiti','PingFang SC',serif;background:var(--bg);color:var(--ink);min-height:100vh}

/* ===== 顶部窄条 ===== */
.top-bar{
  background:var(--nav);color:rgba(212,169,106,.8);
  text-align:center;padding:9px 20px;font-size:11px;letter-spacing:3px;
  display:flex;align-items:center;justify-content:center;gap:10px;
}
.top-dot{width:3px;height:3px;border-radius:50%;background:rgba(212,169,106,.4)}

/* ===== Hero ===== */
.hero{
  text-align:center;padding:40px 20px 32px;
  border-bottom:1px solid var(--border);position:relative;
}
.hero::after{
  content:'';position:absolute;bottom:-1px;left:50%;transform:translateX(-50%);
  width:60px;height:2px;background:var(--red);
}
.hero-badge{
  display:inline-flex;align-items:center;gap:6px;
  background:var(--red-light);border:1px solid #e8b0a8;
  border-radius:4px;padding:4px 14px;font-size:11px;color:var(--red);
  letter-spacing:2px;margin-bottom:14px;
}
.hero h1{font-size:clamp(22px,4vw,34px);font-weight:900;color:var(--ink);letter-spacing:3px;margin-bottom:6px}
.hero h1 em{color:var(--red);font-style:normal}
.hero-desc{font-size:12px;color:var(--ink3);letter-spacing:2px}

/* ===== 主容器 ===== */
.container{max-width:720px;margin:0 auto;padding:24px 16px 60px;display:flex;flex-direction:column;gap:14px}

/* ===== 折叠手册 ===== */
.foldable{background:var(--paper);border:1px solid var(--border);border-radius:6px;overflow:hidden}
.fold-trigger{
  width:100%;display:flex;align-items:center;justify-content:space-between;
  padding:13px 18px;background:none;border:none;cursor:pointer;
  font-family:inherit;font-size:13px;font-weight:700;color:var(--ink2);
  letter-spacing:1px;transition:background .15s;
}
.fold-trigger:hover{background:var(--gold-light)}
.fold-icon{font-size:18px;color:var(--ink3);font-weight:300;transition:transform .2s}
.fold-content{display:none;padding:4px 18px 16px;border-top:1px solid var(--border);font-size:12px;color:var(--ink2);line-height:2}
.fold-content.open{display:block}
.fold-trigger.open .fold-icon{transform:rotate(45deg)}
.fold-content h4{font-size:12px;font-weight:700;color:var(--ink);margin:10px 0 4px}
.fold-content b{color:var(--red)}

/* ===== 参数卡片 ===== */
.param-card{background:var(--paper);border:1px solid var(--border);border-radius:6px;padding:20px 20px 16px}
.param-title{
  font-size:13px;font-weight:700;color:var(--ink2);letter-spacing:1px;
  margin-bottom:16px;display:flex;align-items:center;gap:8px;
}
.param-title::before{content:'';width:4px;height:16px;background:var(--red);border-radius:2px;flex-shrink:0}

.field{margin-bottom:14px}
.field:last-child{margin-bottom:0}
.field-label{
  font-size:12px;font-weight:700;color:var(--ink2);
  margin-bottom:8px;letter-spacing:1px;
  display:flex;align-items:center;gap:6px;
}
.f-dot{width:5px;height:5px;border-radius:50%;background:var(--gold);flex-shrink:0}
.f-hint{font-size:10px;color:var(--ink3);font-weight:400;letter-spacing:.5px}

/* ===== Chip ===== */
.chip-group{display:flex;flex-wrap:wrap;gap:8px}
.chip{
  padding:7px 16px;background:var(--bg);border:1px solid var(--border);
  border-radius:4px;font-family:inherit;font-size:12px;font-weight:600;
  cursor:pointer;transition:all .15s;color:var(--ink3);letter-spacing:.5px;user-select:none;
}
.chip:hover{background:var(--gold-light);border-color:var(--gold);color:var(--ink2)}
.chip.active{background:var(--red);border-color:var(--red);color:#fff}
.chip.active[data-subject="语文"]{background:var(--red);border-color:var(--red)}
.chip.active[data-subject="数学"]{background:var(--green);border-color:var(--green)}
.chip.active[data-subject="英语"]{background:var(--blue);border-color:var(--blue)}

/* ===== 单元推荐 ===== */
#unitSection{
  background:var(--gold-light);border:1px solid rgba(200,146,10,.3);
  border-radius:4px;padding:10px 14px;font-size:11px;color:var(--ink2);line-height:1.8;
}
.unit-chips{display:flex;flex-wrap:wrap;gap:6px;margin-top:8px}
.unit-chip{
  padding:5px 12px;background:var(--paper);border:1px solid var(--border);
  border-radius:4px;font-size:11px;color:var(--ink3);
  cursor:pointer;transition:all .15s;font-family:inherit;
}
.unit-chip:hover{background:var(--red-light);border-color:var(--red);color:var(--red)}
.unit-chip.active{background:var(--red);border-color:var(--red);color:#fff}
.unit-section.empty{color:var(--ink3)}

input.ci{
  width:100%;padding:10px 14px;border:1px solid var(--border);border-radius:4px;
  font-family:inherit;font-size:12px;color:var(--ink);background:var(--paper);
  outline:none;transition:border-color .15s;margin-top:8px;
}
input.ci:focus{border-color:var(--gold)}
input.ci::placeholder{color:var(--ink3);opacity:.7;font-size:11px}

/* ===== 卡片风格 ===== */
.style-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(140px,1fr));gap:10px}
.style-card{
  background:var(--bg);border:1px solid var(--border);border-radius:6px;
  padding:14px 12px;text-align:center;cursor:pointer;transition:all .18s;
}
.style-card:hover{border-color:var(--gold);background:var(--gold-light)}
.style-card.active{border-color:var(--red);background:var(--red-light)}
.style-emoji{font-size:22px;margin-bottom:6px;display:block}
.style-name{font-size:12px;font-weight:700;color:var(--ink2);letter-spacing:.5px;margin-bottom:3px}
.style-desc{font-size:10px;color:var(--ink3);line-height:1.5}
.style-card.active .style-name{color:var(--red)}

/* ===== 生成按钮 ===== */
.gen-btn{
  width:100%;padding:13px;background:var(--red);color:#fff;border:none;
  border-radius:6px;font-size:15px;font-weight:700;font-family:inherit;
  cursor:pointer;letter-spacing:3px;transition:background .2s;
}
.gen-btn:hover{background:#6a1010}
.gen-btn:disabled{background:#c8b890;cursor:not-allowed}

/* ===== 输出区 ===== */
#outputWrap{display:none}
#outputWrap.show{display:block;animation:fadeIn .4s}
@keyframes fadeIn{from{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}

.out-tabs{display:flex;border-bottom:2px solid var(--border)}
.out-tab{
  padding:10px 16px;font-size:12px;font-weight:700;color:var(--ink3);
  cursor:pointer;border:none;background:none;font-family:inherit;
  letter-spacing:1px;border-bottom:2px solid transparent;margin-bottom:-2px;transition:all .2s;
}
.out-tab.active{color:var(--red);border-bottom-color:var(--red)}
.out-pane{display:none;padding-top:12px}
.out-pane.active{display:block}

.out-label{display:flex;align-items:center;justify-content:space-between;margin-bottom:8px}
.out-label span{font-size:12px;font-weight:700;color:var(--ink2);letter-spacing:1px}
.out-box{
  background:var(--bg);border:1px solid var(--border);border-radius:4px;
  padding:14px;font-size:11px;color:var(--ink2);line-height:2;
  white-space:pre-wrap;word-break:break-all;user-select:text;
  max-height:480px;overflow-y:auto;
}
.out-tip{
  margin-top:8px;font-size:11px;color:var(--ink3);
  background:var(--gold-light);padding:8px 12px;border-radius:4px;
  border:1px solid rgba(200,146,10,.2);line-height:1.8;
}
.out-tip b{color:var(--ink2)}

.copy-btn{
  padding:5px 14px;background:var(--bg);border:1px solid var(--border);
  border-radius:4px;font-size:11px;color:var(--ink2);cursor:pointer;
  font-family:inherit;transition:all .2s;letter-spacing:.5px;
}
.copy-btn:hover{background:var(--gold-light);border-color:var(--gold)}
.copy-btn.copied{background:var(--green-light);border-color:var(--green);color:var(--green)}

/* ===== Toast ===== */
.toast{
  position:fixed;bottom:24px;left:50%;transform:translateX(-50%) translateY(20px);
  background:var(--ink);color:#fff;padding:10px 24px;border-radius:4px;
  font-size:12px;opacity:0;transition:all .3s;pointer-events:none;z-index:999;letter-spacing:1px;
}
.toast.show{opacity:1;transform:translateX(-50%) translateY(0)}

/* ===== 版权 ===== */
.footer-bar{
  text-align:center;padding:24px 20px;border-top:1px solid var(--border);
  background:var(--bg);
}
.footer-bar .logo{font-size:14px;font-weight:700;color:var(--ink);letter-spacing:3px;margin-bottom:5px}
.footer-bar .copy{font-size:11px;color:#6a4a20;letter-spacing:1px;line-height:2}

@media(max-width:600px){
  .style-grid{grid-template-columns:repeat(2,1fr)}
}
</style>
</head>
<body>

<div class="top-bar">
  <span>阿坚AIGC</span><div class="top-dot"></div>
  <span>小学知识卡片</span><div class="top-dot"></div>
  <span>提示词工坊</span>
</div>

<div class="hero">
  <div class="hero-badge">📚 PEP统编版 · 1-6年级 · 语数英全覆盖</div>
  <h1>小学知识卡片<br><em>提示词生成器</em></h1>
  <div class="hero-desc">选年级 · 选学科 · 选单元 · 一键生成</div>
</div>

<div class="container">

  <!-- 折叠手册 -->
  <div class="foldable">
    <button class="fold-trigger" onclick="this.classList.toggle('open');this.nextElementSibling.classList.toggle('open')">
      <span>📖 完整操作手册</span>
      <span class="fold-icon">+</span>
    </button>
    <div class="fold-content">
      <h4>三步出图流程</h4>
      <p><b>① 选择参数</b> → 年级 / 学科 / 册次 / 单元（可直接点推荐）/ 风格</p>
      <p><b>② 复制指令</b> → 点「生成」，一键复制发给 Claude（开启联网搜索）</p>
      <p><b>③ 香蕉出图</b> → Claude 返回提示词，发给香蕉Pro / 即梦出图，比例 9:16</p>
      <h4>注意事项</h4>
      <p>· Claude 必须<b>开启联网搜索</b>，否则内容可能基于过时数据</p>
      <p>· 教材每年小幅修订，<b>推荐单元仅供参考</b>，以最新教材为准</p>
      <p>· 英语默认 <b>PEP人教版</b>（三年级起点），一二年级需按地方教材核对</p>
      <p>· 生图时比例选 <b>9:16</b>（小红书竖版最佳）</p>
    </div>
  </div>

  <!-- 参数选择 -->
  <div class="param-card">
    <div class="param-title">填写卡片参数</div>

    <div class="field">
      <div class="field-label"><span class="f-dot"></span>年级<span class="f-hint">（1—6年级）</span></div>
      <div class="chip-group" data-group="grade">
        <div class="chip" data-val="一年级">一年级</div>
        <div class="chip" data-val="二年级">二年级</div>
        <div class="chip" data-val="三年级">三年级</div>
        <div class="chip" data-val="四年级">四年级</div>
        <div class="chip" data-val="五年级">五年级</div>
        <div class="chip" data-val="六年级">六年级</div>
      </div>
    </div>

    <div class="field">
      <div class="field-label"><span class="f-dot"></span>学科<span class="f-hint">（PEP/部编版）</span></div>
      <div class="chip-group" data-group="subject">
        <div class="chip" data-val="语文" data-subject="语文">📖 语文</div>
        <div class="chip" data-val="数学" data-subject="数学">🔢 数学</div>
        <div class="chip" data-val="英语" data-subject="英语">🔤 英语</div>
      </div>
    </div>

    <div class="field">
      <div class="field-label"><span class="f-dot"></span>册次</div>
      <div class="chip-group" data-group="term">
        <div class="chip" data-val="上册">上册</div>
        <div class="chip" data-val="下册">下册</div>
      </div>
    </div>

    <div class="field">
      <div class="field-label"><span class="f-dot"></span>单元<span class="f-hint">（点推荐或自行输入）</span></div>
      <div class="unit-section empty" id="unitSection">👆 请先选好「年级 + 学科 + 册次」，推荐单元将自动出现</div>
      <input type="text" class="ci" id="unitInput" placeholder="也可直接手动输入单元编号+主题">
    </div>

    <div class="field">
      <div class="field-label"><span class="f-dot"></span>卡片风格<span class="f-hint">（单选）</span></div>
      <div class="style-grid" data-group="style">
        <div class="style-card" data-val="Q版卡通">
          <span class="style-emoji">🐰</span>
          <div class="style-name">Q版卡通风</div>
          <div class="style-desc">手绘萌系插画<br>适合单词/生字</div>
        </div>
        <div class="style-card" data-val="思维导图">
          <span class="style-emoji">🗺️</span>
          <div class="style-name">思维导图风</div>
          <div class="style-desc">层级结构清晰<br>适合语法总结</div>
        </div>
        <div class="style-card" data-val="马卡龙信息图">
          <span class="style-emoji">📊</span>
          <div class="style-name">马卡龙信息图</div>
          <div class="style-desc">色块分区明快<br>适合公式对比</div>
        </div>
        <div class="style-card" data-val="场景故事风">
          <span class="style-emoji">🏡</span>
          <div class="style-name">场景故事风</div>
          <div class="style-desc">生活化插画<br>适合句型/课文</div>
        </div>
      </div>
    </div>
  </div>

  <!-- 生成按钮 -->
  <button class="gen-btn" id="generateBtn">生　成</button>

  <!-- 输出区 -->
  <div class="param-card" id="outputWrap">
    <div class="out-tabs">
      <button class="out-tab active" id="outTabImg" onclick="switchV2Tab('img',this)">📋 图片提示词</button>
      <button class="out-tab" id="outTabWx" onclick="switchV2Tab('wx',this)">📝 三平台文案</button>
    </div>
    <div class="out-pane active" id="v2pane-img">
      <div class="out-label">
        <span>图片提示词 · 复制发给Claude联网搜索</span>
        <button class="copy-btn" id="copyBtn">一键复制</button>
      </div>
      <div class="out-box" id="outputBox"></div>
      <div class="out-tip">💡 复制后发给<b>开联网的Claude</b>，让它联网查资料后输出完整出图提示词，再发香蕉Pro出图，比例 <b>9:16</b></div>
    </div>
    <div class="out-pane" id="v2pane-wx">
      <div class="out-label">
        <span>三平台文案提示词 · 出完图后使用</span>
        <button class="copy-btn" id="copyBtnWx">一键复制</button>
      </div>
      <div class="out-box" id="outputBoxWx"></div>
      <div class="out-tip">💡 出完图后，把<b>图片+这段提示词</b>一起发给Claude → 输出<b>视频号+小红书+抖音</b>三套文案</div>
    </div>
  </div>

</div>

<div class="footer-bar">
  <div class="logo">📜 阿坚AIGC · 图文知识卡片</div>
  <div class="copy">小学知识卡片提示词生成器 · V2<br>版权所有 © 阿坚AIGC · 仅供授权用户个人创作使用 · 禁止商业转载与二次分发</div>
</div>

<div class="toast" id="toast"></div>

<script>

  // ════════════════════════════════════════════
  // 单元推荐数据库(PEP 人教版 / 部编版)
  // ════════════════════════════════════════════
  const UNITS = {
    // ───── 英语(PEP 三年级起点) ─────
    '三年级_英语_上册': ['Unit 1 Hello!', 'Unit 2 Colours', 'Unit 3 Look at me!', 'Unit 4 We love animals', "Unit 5 Let's eat!", 'Unit 6 Happy birthday!'],
    '三年级_英语_下册': ['Unit 1 Welcome back to school!', 'Unit 2 My family', 'Unit 3 At the zoo', 'Unit 4 Where is my car?', 'Unit 5 Do you like pears?', 'Unit 6 How many?'],
    '四年级_英语_上册': ['Unit 1 My classroom', 'Unit 2 My schoolbag', 'Unit 3 My friends', 'Unit 4 My home', "Unit 5 Dinner's ready", 'Unit 6 Meet my family!'],
    '四年级_英语_下册': ['Unit 1 My school', 'Unit 2 What time is it?', 'Unit 3 Weather', 'Unit 4 At the farm', 'Unit 5 My clothes', 'Unit 6 Shopping'],
    '五年级_英语_上册': ["Unit 1 What's he like?", 'Unit 2 My week', 'Unit 3 What would you like?', 'Unit 4 What can you do?', 'Unit 5 There is a big bed', 'Unit 6 In a nature park'],
    '五年级_英语_下册': ['Unit 1 My day', 'Unit 2 My favourite season', 'Unit 3 My school calendar', 'Unit 4 When is Easter?', 'Unit 5 Whose dog is it?', 'Unit 6 Work quietly!'],
    '六年级_英语_上册': ['Unit 1 How can I get there?', 'Unit 2 Ways to go to school', 'Unit 3 My weekend plan', 'Unit 4 I have a pen pal', 'Unit 5 What does he do?', 'Unit 6 How do you feel?'],
    '六年级_英语_下册': ['Unit 1 How tall are you?', 'Unit 2 Last weekend', 'Unit 3 Where did you go?', 'Unit 4 Then and now'],

    // ───── 数学(人教版) ─────
    '一年级_数学_上册': ['第1单元 准备课', '第2单元 位置', '第3单元 1-5的认识和加减法', '第4单元 认识图形(一)', '第5单元 6-10的认识和加减法', '第6单元 11-20各数的认识', '第7单元 认识钟表', '第8单元 20以内的进位加法'],
    '一年级_数学_下册': ['第1单元 认识图形(二)', '第2单元 20以内的退位减法', '第3单元 分类与整理', '第4单元 100以内数的认识', '第5单元 认识人民币', '第6单元 100以内的加法和减法(一)', '第7单元 找规律'],
    '二年级_数学_上册': ['第1单元 长度单位', '第2单元 100以内的加法和减法(二)', '第3单元 角的初步认识', '第4单元 表内乘法(一)', '第5单元 观察物体(一)', '第6单元 表内乘法(二)', '第7单元 认识时间', '第8单元 数学广角—搭配(一)'],
    '二年级_数学_下册': ['第1单元 数据收集整理', '第2单元 表内除法(一)', '第3单元 图形的运动(一)', '第4单元 表内除法(二)', '第5单元 混合运算', '第6单元 有余数的除法', '第7单元 万以内数的认识', '第8单元 克和千克', '第9单元 数学广角—推理'],
    '三年级_数学_上册': ['第1单元 时分秒', '第2单元 万以内的加法和减法(一)', '第3单元 测量', '第4单元 万以内的加法和减法(二)', '第5单元 倍的认识', '第6单元 多位数乘一位数', '第7单元 长方形和正方形', '第8单元 分数的初步认识', '第9单元 数学广角—集合'],
    '三年级_数学_下册': ['第1单元 位置与方向(一)', '第2单元 除数是一位数的除法', '第3单元 复式统计表', '第4单元 两位数乘两位数', '第5单元 面积', '第6单元 年月日', '第7单元 小数的初步认识', '第8单元 数学广角—搭配(二)'],
    '四年级_数学_上册': ['第1单元 大数的认识', '第2单元 公顷和平方千米', '第3单元 角的度量', '第4单元 三位数乘两位数', '第5单元 平行四边形和梯形', '第6单元 除数是两位数的除法', '第7单元 条形统计图', '第8单元 数学广角—优化'],
    '四年级_数学_下册': ['第1单元 四则运算', '第2单元 观察物体(二)', '第3单元 运算定律', '第4单元 小数的意义和性质', '第5单元 三角形', '第6单元 小数的加法和减法', '第7单元 图形的运动(二)', '第8单元 平均数与条形统计图', '第9单元 数学广角—鸡兔同笼'],
    '五年级_数学_上册': ['第1单元 小数乘法', '第2单元 位置', '第3单元 小数除法', '第4单元 可能性', '第5单元 简易方程', '第6单元 多边形的面积', '第7单元 数学广角—植树问题'],
    '五年级_数学_下册': ['第1单元 观察物体(三)', '第2单元 因数与倍数', '第3单元 长方体和正方体', '第4单元 分数的意义和性质', '第5单元 图形的运动(三)', '第6单元 分数的加法和减法', '第7单元 折线统计图', '第8单元 数学广角—找次品'],
    '六年级_数学_上册': ['第1单元 分数乘法', '第2单元 位置与方向(二)', '第3单元 分数除法', '第4单元 比', '第5单元 圆', '第6单元 百分数(一)', '第7单元 扇形统计图', '第8单元 数学广角—数与形'],
    '六年级_数学_下册': ['第1单元 负数', '第2单元 百分数(二)', '第3单元 圆柱与圆锥', '第4单元 比例', '第5单元 数学广角—鸽巢问题', '第6单元 整理和复习'],

    // ───── 语文(部编版) ─────
    '一年级_语文_上册': ['第1单元 我上学了·识字', '第2单元 汉语拼音(一)', '第3单元 汉语拼音(二)', '第4单元 课文(秋天·小小的船)', '第5单元 识字(画·大小多少)', '第6单元 课文(影子·比尾巴)', '第7单元 课文(明天要远足·雪地里的小画家)', '第8单元 课文(小蜗牛·雨点)'],
    '一年级_语文_下册': ['第1单元 识字(春夏秋冬)', '第2单元 课文(吃水不忘挖井人·我多想去看看)', '第3单元 课文(小公鸡和小鸭子·树和喜鹊)', '第4单元 课文(静夜思·夜色)', '第5单元 识字(动物儿歌·古对今)', '第6单元 课文(古诗二首·荷叶圆圆)', '第7单元 课文(文具的家)', '第8单元 课文(棉花姑娘·咕咚)'],
    '二年级_语文_上册': ['第1单元 秋天·植物', '第2单元 识字·场景', '第3单元 儿童生活', '第4单元 家乡美景', '第5单元 道理感悟', '第6单元 伟人故事', '第7单元 想象故事', '第8单元 相处之道'],
    '二年级_语文_下册': ['第1单元 春天', '第2单元 关爱', '第3单元 传统文化识字', '第4单元 童心', '第5单元 办法', '第6单元 自然奥秘', '第7单元 改变', '第8单元 想象'],
    '三年级_语文_上册': ['第1单元 校园生活', '第2单元 金秋时节', '第3单元 童话世界', '第4单元 预测', '第5单元 留心观察', '第6单元 祖国河山', '第7单元 我与自然', '第8单元 美好品质'],
    '三年级_语文_下册': ['第1单元 可爱生灵', '第2单元 寓言故事', '第3单元 传统文化', '第4单元 观察与发现', '第5单元 想象的世界', '第6单元 多彩童年', '第7单元 奇妙世界', '第8单元 有趣故事'],
    '四年级_语文_上册': ['第1单元 自然之美', '第2单元 提问策略', '第3单元 连续观察', '第4单元 神话故事', '第5单元 写事情', '第6单元 童年乐事', '第7单元 家国情怀', '第8单元 历史故事'],
    '四年级_语文_下册': ['第1单元 乡村生活', '第2单元 科技之光', '第3单元 现代诗', '第4单元 动物朋友', '第5单元 游记', '第6单元 成长', '第7单元 人物品质', '第8单元 童话世界'],
    '五年级_语文_上册': ['第1单元 万物有情', '第2单元 阅读有速度', '第3单元 民间故事', '第4单元 爱国情怀', '第5单元 说明文', '第6单元 父母之爱', '第7单元 四时景物', '第8单元 读书乐'],
    '五年级_语文_下册': ['第1单元 童年往事', '第2单元 古典名著', '第3单元 遨游汉字王国', '第4单元 家国情怀', '第5单元 人物描写', '第6单元 思维的火花', '第7单元 异域风情', '第8单元 幽默风趣'],
    '六年级_语文_上册': ['第1单元 触摸自然', '第2单元 重温革命岁月', '第3单元 有目的地阅读', '第4单元 小说', '第5单元 以立意为宗', '第6单元 保护环境', '第7单元 艺术之旅', '第8单元 走近鲁迅'],
    '六年级_语文_下册': ['第1单元 民风民俗', '第2单元 外国文学名著', '第3单元 让真情自然流露', '第4单元 理想和信念', '第5单元 科学发现之旅', '第6单元 难忘小学生活']
  };

  // ════════════════════════════════════════════
  // 状态
  // ════════════════════════════════════════════
  const state = {
    grade: '',
    subject: '',
    term: '',
    unit: '',
    style: ''
  };

  // chip 选择通用逻辑
  document.querySelectorAll('.chip-group').forEach(group => {
    const key = group.dataset.group;
    group.addEventListener('click', e => {
      const chip = e.target.closest('.chip');
      if (!chip) return;
      group.querySelectorAll('.chip').forEach(c => c.classList.remove('active'));
      chip.classList.add('active');
      state[key] = chip.dataset.val;
      if (['grade', 'subject', 'term'].includes(key)) {
        refreshUnits();
      }
    });
  });

  // 风格卡片
  document.querySelectorAll('[data-group="style"] .style-card').forEach(card => {
    card.addEventListener('click', () => {
      document.querySelectorAll('[data-group="style"] .style-card').forEach(c => c.classList.remove('active'));
      card.classList.add('active');
      state.style = card.dataset.val;
    });
  });

  // 单元输入手动
  const unitInputEl = document.getElementById('unitInput');
  unitInputEl.addEventListener('input', e => {
    state.unit = e.target.value.trim();
    // 清除推荐高亮
    document.querySelectorAll('.unit-chip').forEach(c => c.classList.remove('active'));
  });

  // 刷新单元推荐
  function refreshUnits() {
    const section = document.getElementById('unitSection');
    if (!state.grade || !state.subject || !state.term) {
      section.className = 'unit-section empty';
      section.innerHTML = '👆 请先选好「年级 + 学科 + 册次」,推荐单元将自动出现';
      return;
    }

    // 英语特殊处理:一二年级提示
    if (state.subject === '英语' && ['一年级', '二年级'].includes(state.grade)) {
      section.className = 'unit-section empty';
      section.innerHTML = `⚠️ PEP 英语为<strong>三年级起点</strong>。<br>一二年级请参考地方教材,或手动输入单元下方再生成。`;
      return;
    }

    const key = `${state.grade}_${state.subject}_${state.term}`;
    const units = UNITS[key];

    if (!units || units.length === 0) {
      section.className = 'unit-section empty';
      section.innerHTML = '📝 暂无内置推荐,请在下方输入框手动填写单元';
      return;
    }

    section.className = 'unit-section';
    section.innerHTML = `
      <div class="unit-rec-label">推荐单元(点一下自动填入,也可自行修改)</div>
      <div class="unit-chips"></div>
    `;
    const chipsBox = section.querySelector('.unit-chips');
    units.forEach(u => {
      const chip = document.createElement('div');
      chip.className = 'unit-chip';
      chip.textContent = u;
      chip.addEventListener('click', () => {
        section.querySelectorAll('.unit-chip').forEach(c => c.classList.remove('active'));
        chip.classList.add('active');
        unitInputEl.value = u;
        state.unit = u;
      });
      chipsBox.appendChild(chip);
    });
  }

  // Toast
  function showToast(msg) {
    const t = document.getElementById('toast');
    t.textContent = msg;
    t.classList.add('show');
    setTimeout(() => t.classList.remove('show'), 2000);
  }

  // 风格视觉描述字典
  const styleDict = {
    'Q版卡通': `手绘卡通插画风格,Q 版萌系人物/动物小插图,每个知识点旁配对应的萌宠或物品小图。
- 马卡龙柔和配色:奶油粉、薄荷绿、鹅黄、天空蓝、淡紫
- 圆角边框,手写感中文字体,可爱装饰元素(星星、彩虹、爱心、云朵)点缀
- 整体氛围:童趣、温暖、像儿童绘本`,

    '思维导图': `思维导图风格,以单元主题为中心发散,层级清晰,分支分明。
- 每个主枝干用不同颜色区分(莫兰迪色系或清新糖果色)
- 分支末端用小图标标示,文字排布整齐,关键词加粗
- 背景极简白或浅米色,线条流畅手绘感
- 整体氛围:结构清晰、一目了然、便于记忆`,

    '马卡龙信息图': `现代信息图风格,马卡龙色块分区排版,每个板块用不同糖果色区分(奶油黄、薄荷绿、樱花粉、天空蓝)。
- 使用大量图标、小插画、对比表格、箭头引导视线
- 字体现代圆润,中英文/数字排版规范,数据可视化元素丰富
- 整体氛围:干净、专业、治愈系学习感`,

    '场景故事': `生活化场景插画风格,以一个温馨场景为画面主体(教室、家庭、公园等)。
- 人物以小学生/卡通形象出现,场景中自然融入知识点对话气泡或标注
- 色调温暖柔和,类似吉卜力动画或绘本插画
- 画面有故事感,知识点嵌入情境而非生硬罗列
- 整体氛围:沉浸、温馨、有代入感`
  };

  const subjectKeywords = {
    '语文': '生字词(带拼音)、多音字、近反义词、重点词语解释、句子赏析、古诗词默写、课文主旨、修辞手法',
    '数学': '核心概念定义、公式及推导、典型例题思路、易错点、记忆口诀、单位换算',
    '英语': '核心词汇(中英对照、音标)、重点短语、核心句型、语法规则、高频易错点、日常交际用语'
  };

  const subjectExtraRule = {
    '语文': '生字必须带拼音,多音字要列全读音',
    '数学': '公式使用规范符号,配文字说明',
    '英语': '必须中英对照,核心词汇标注音标'
  };

  const subjectVersion = {
    '语文': '部编版',
    '数学': '人教版',
    '英语': 'PEP 人教版'
  };

  function generatePrompt() {
    if (!state.grade || !state.subject || !state.term || !state.unit || !state.style) {
      showToast('请把 5 项都填完~');
      return null;
    }

    return `【小学知识卡片生成任务 · 阿坚 AIGC】

你现在是阿坚 AIGC 的小学知识卡片提示词生成助手,请严格按以下流程执行:

━━━━━━━━━━━━━━━━━━━━━━
📥 用户参数
━━━━━━━━━━━━━━━━━━━━━━
• 年级:${state.grade}
• 学科:${state.subject}(${subjectVersion[state.subject]})
• 册次:${state.term}
• 单元:${state.unit}
• 风格:${state.style}

━━━━━━━━━━━━━━━━━━━━━━
🔍 执行步骤
━━━━━━━━━━━━━━━━━━━━━━

【步骤 1】联网搜索(必须执行,不可凭记忆编造)
请使用联网搜索功能,检索以下关键词组合:
- ${subjectVersion[state.subject]} ${state.subject} ${state.grade} ${state.term} ${state.unit} 重难点 知识点
- 小学 ${state.subject} ${state.grade} ${state.term} ${state.unit} 核心内容
重点搜集:${subjectKeywords[state.subject]}

【步骤 2】整理重难点(至少 10—15 个知识点,要丰富详细)
要求:
- ${subjectExtraRule[state.subject]}
- 按「基础 → 重点 → 难点」递进排序
- 每个点简洁但不省略,适合小学生阅读
- 不可凭记忆编造,如搜索结果不明确请说明后再生成

【步骤 3】按下方模板输出两份成品(都用代码块包裹,方便复制)

━━━━━━━━━━━━━━━━━━━━━━
📌 输出 A:AI 生图提示词(放进代码块)
━━━━━━━━━━━━━━━━━━━━━━

\`\`\`
比例 9:16,${state.style}风格,小学${state.subject}${state.grade}${state.term} ${state.unit} 知识卡片,适合小学生阅读。

【主标题】${state.unit}${state.subject === '英语' ? '(中英对照)' : ''}
【副标题】${state.grade} · ${state.term} · ${subjectVersion[state.subject]}

━━ 内容排布 ━━

📘 板块一:[核心词汇 / 核心概念 / 生字词](列出 5—8 个,要丰富)
1. [知识点1]
2. [知识点2]
...

📗 板块二:[重点句型 / 重要公式 / 句子赏析](列出 3—5 条)
1. [知识点]
...

📙 板块三:[难点·易错点 / 记忆口诀 / 拓展提升](列出 2—3 条)
1. [知识点]
...

━━ 视觉要求 ━━

${styleDict[state.style]}

排版要求:
- 字体清晰可辨,标题醒目,正文舒适
- 中英文排版规范,数学符号准确
- 每个知识点配合小图标/小插图辅助理解
- 底部留出小字区标注:「© 阿坚 AIGC · 内容由 AI 联网整理生成 · 仅供参考,请对照教材核对」

整体氛围:温馨可爱,小学生友好,家长愿意收藏转发
\`\`\`

━━━━━━━━━━━━━━━━━━━━━━
📌 输出 B:小红书发布文案(放进代码块)
━━━━━━━━━━━━━━━━━━━━━━

\`\`\`
【标题】
[emoji] ${state.grade}${state.subject}${state.term} ${state.unit} | [钩子型短句]

【正文】(200 字内)
[开头 1 句,引起共鸣或痛点]

这张卡片帮你整理了 ${state.grade}${state.term} ${state.unit} 的核心内容——
✅ [核心知识点 1]
✅ [核心知识点 2]
✅ [核心知识点 3]
✅ [核心知识点 4]

[互动引导]

【标签】
#小学${state.subject} #${state.grade}${state.subject} #${subjectVersion[state.subject]} #知识卡片 #学习干货 #家长必看 #${state.subject}重难点 #阿坚AIGC

━━ 免责说明(放正文末尾小字) ━━
内容由 AI 联网整理生成,仅供参考,请以最新版教材为准
© 阿坚 AIGC 版权所有
\`\`\`

━━━━━━━━━━━━━━━━━━━━━━
🚨 重要规则(必须遵守)
━━━━━━━━━━━━━━━━━━━━━━
1. 所有知识点必须基于联网搜索结果,不可凭记忆编造教材内容
2. 每次输出必须包含版权标识「© 阿坚 AIGC」和免责声明
3. 知识点要丰富详细(不少于 10—15 个),不要偷懒
4. ${subjectExtraRule[state.subject]}
5. 输出 A 和 B 都用代码块包裹,方便用户一键复制
6. 输出完毕后,提醒用户:「A 段丢给 Nano Banana / 香蕉出图(9:16),B 段配图发小红书」
7. 如搜索结果存在多版本差异,先告知用户再生成

开始执行吧!`;
  }

  document.getElementById('generateBtn').addEventListener('click', () => {
    const prompt = generatePrompt();
    if (!prompt) return;
    const output = document.getElementById('outputBox');
    const wrap = document.getElementById('outputWrap');
    output.textContent = prompt;
    wrap.classList.add('show');
    // 同步生成三平台文案提示词
    const topic = (state.grade||'') + state.subject + (state.unit||'');
    const wxBox = document.getElementById('outputBoxWx');
    if (wxBox) wxBox.textContent = generate3Platform(topic);
    setTimeout(() => wrap.scrollIntoView({ behavior: 'smooth', block: 'start' }), 100);
    showToast('✨ 生成成功!滚动查看');
  });


  function switchV2Tab(pane, btn) {
    document.querySelectorAll('.out-tab').forEach(b => b.classList.remove('active'));
    document.querySelectorAll('.out-pane').forEach(p => p.classList.remove('active'));
    btn.classList.add('active');
    document.getElementById('v2pane-' + pane).classList.add('active');
  }

  function generate3Platform(topic) {
    return '你是一位擅长三平台运营的AIGC内容创作者。\n我刚刚用AI生成了一张「' + topic + '」知识卡片图，请根据图片内容同时输出三平台配套文案：\n\n【视频号文案】\n- 标题：1个，不超过20字，有吸引力\n- 正文：150字，口语化，家长/老师视角，有共鸣感\n- 结尾：引导点赞收藏转发\n\n【小红书文案】\n- 备选标题：3个，带emoji，有收藏冲动，不超过20字\n- 正文：200字，口语化，有共鸣感\n- 结尾：引导收藏+评论互动\n- 话题标签：10个\n\n【抖音文案】\n- 备选标题：3个，带emoji，有点击欲，不超过20字\n- 正文：150字，节奏感强\n- 结尾：引导点赞收藏关注\n- 话题标签：8个';
  }

  document.getElementById('copyBtn').addEventListener('click', async () => {
    const text = document.getElementById('outputBox').textContent;
    if (!text) return;
    try {
      await navigator.clipboard.writeText(text);
      const btn = document.getElementById('copyBtn');
      btn.classList.add('copied');
      btn.textContent = '✓ 已复制';
      showToast('📋 已复制!去 Claude 粘贴');
      setTimeout(() => {
        btn.classList.remove('copied');
        btn.textContent = '一键复制';
      }, 2000);
    } catch (err) {
      const ta = document.createElement('textarea');
      ta.value = text;
      document.body.appendChild(ta);
      ta.select();
      document.execCommand('copy');
      document.body.removeChild(ta);
      showToast('📋 已复制!');
    }
  });


  // 三平台文案复制
  var copyBtnWxEl = document.getElementById('copyBtnWx');
  if (copyBtnWxEl) {
    copyBtnWxEl.addEventListener('click', function() {
      var text = document.getElementById('outputBoxWx').textContent;
      if (!text) return;
      navigator.clipboard.writeText(text).then(function() {
        copyBtnWxEl.textContent = '已复制 ✓';
        copyBtnWxEl.classList.add('copied');
        setTimeout(function() {
          copyBtnWxEl.textContent = '一键复制';
          copyBtnWxEl.classList.remove('copied');
        }, 1800);
      }).catch(function() {
        var ta = document.createElement('textarea');
        ta.value = text;
        document.body.appendChild(ta);
        ta.select();
        document.execCommand('copy');
        document.body.removeChild(ta);
        copyBtnWxEl.textContent = '已复制 ✓';
        setTimeout(function() { copyBtnWxEl.textContent = '一键复制'; }, 1800);
      });
    });
  }
</script>
</body>
</html>
<!DOCTYPE html>
<html lang="zh-CN">
<head>
<meta charset="UTF-8">
<meta name="viewport" content="width=device-width, initial-scale=1.0">
<title>AI图文创作套件</title>
<link href="https://fonts.googleapis.com/css2?family=Noto+Serif+SC:wght@400;600&family=Noto+Sans+SC:wght@400;500;700&display=swap" rel="stylesheet">
<style>
*{box-sizing:border-box;margin:0;padding:0}
body{font-family:'Noto Sans SC',sans-serif;background:#f7f4ee;min-height:100vh;color:#2d2417}
.page-header{background:linear-gradient(135deg,#2d2417 0%,#5c3d1e 100%);padding:32px 24px 28px;text-align:center;position:relative;overflow:hidden}
.page-header::before{content:'';position:absolute;top:0;left:0;right:0;bottom:0;background:url("data:image/svg+xml,%3Csvg width='60' height='60' viewBox='0 0 60 60' xmlns='http://www.w3.org/2000/svg'%3E%3Cg fill='none' fill-rule='evenodd'%3E%3Cg fill='%23ffffff' fill-opacity='0.04'%3E%3Cpath d='M36 34v-4h-2v4h-4v2h4v4h2v-4h4v-2h-4zm0-30V0h-2v4h-4v2h4v4h2V6h4V4h-4zM6 34v-4H4v4H0v2h4v4h2v-4h4v-2H6zM6 4V0H4v4H0v2h4v4h2V6h4V4H6z'/%3E%3C/g%3E%3C/g%3E%3C/svg%3E")}
.page-header h1{font-family:'Noto Serif SC',serif;font-size:26px;color:#fff;font-weight:600;letter-spacing:2px;position:relative}
.page-header p{color:rgba(255,255,255,0.65);font-size:13px;margin-top:8px;position:relative;letter-spacing:1px}
.container{max-width:780px;margin:0 auto;padding:28px 20px}
.top-tabs{display:flex;gap:8px;flex-wrap:wrap;margin-bottom:24px}
.top-tab{padding:10px 20px;border-radius:24px;font-size:13px;cursor:pointer;border:1.5px solid #d4c4a8;background:#fff;color:#7a6548;font-weight:500;transition:all 0.2s;letter-spacing:0.5px}
.top-tab:hover{border-color:#a0804a;color:#5c3d1e}
.top-tab.active{color:#fff;border-color:transparent;font-weight:600;box-shadow:0 4px 16px rgba(0,0,0,0.15)}
.panel{display:none}
.panel.active{display:block;animation:fadeIn 0.25s ease}
@keyframes fadeIn{from{opacity:0;transform:translateY(6px)}to{opacity:1;transform:translateY(0)}}
.agent-header{border-radius:16px;padding:20px 24px;margin-bottom:16px;border:1.5px solid #e8dcc8;background:#fffdf8}
.badge{display:inline-block;font-size:11px;font-weight:600;padding:4px 12px;border-radius:20px;margin-bottom:8px;letter-spacing:0.5px}
.agent-title{font-family:'Noto Serif SC',serif;font-size:17px;font-weight:600;color:#2d2417;margin-bottom:4px}
.agent-desc{font-size:13px;color:#8a7560;line-height:1.7}
.section-label{font-size:11px;color:#b0987a;margin-bottom:8px;letter-spacing:1px;text-transform:uppercase}
.chips{display:flex;gap:6px;flex-wrap:wrap;margin-bottom:12px}
.chip{font-size:12px;padding:5px 12px;border:1px solid #d4c4a8;border-radius:20px;cursor:pointer;color:#7a6548;background:#fffdf8;transition:all 0.15s}
.chip:hover{border-color:#a0804a;color:#5c3d1e;background:#f5efe3}
.input-row{display:flex;gap:8px;margin-bottom:14px}
.input-row input{flex:1;padding:12px 16px;font-size:14px;border:1.5px solid #d4c4a8;border-radius:12px;background:#fff;color:#2d2417;font-family:'Noto Sans SC',sans-serif;outline:none;transition:border-color 0.2s}
.input-row input:focus{border-color:#a0804a}
.input-row input::placeholder{color:#c0aa88}
.gen-btn{padding:12px 22px;border-radius:12px;font-size:14px;font-weight:600;cursor:pointer;border:none;color:#fff;white-space:nowrap;font-family:'Noto Sans SC',sans-serif;letter-spacing:0.5px;transition:all 0.2s;box-shadow:0 2px 8px rgba(0,0,0,0.12)}
.gen-btn:hover{opacity:0.88;transform:translateY(-1px);box-shadow:0 4px 14px rgba(0,0,0,0.18)}
.gen-btn:active{transform:translateY(0)}
.out-wrap{border:1.5px solid #e8dcc8;border-radius:16px;background:#fff;overflow:hidden;margin-bottom:0}
.out-tabs{display:flex;border-bottom:1.5px solid #e8dcc8;background:#fffdf8}
.out-tab{padding:10px 18px;font-size:13px;cursor:pointer;color:#a0906e;border-bottom:2.5px solid transparent;background:transparent;border-top:none;border-left:none;border-right:none;font-family:'Noto Sans SC',sans-serif;font-weight:500;transition:all 0.15s}
.out-tab.active{color:#2d2417;font-weight:600}
.out-content{padding:20px;min-height:200px;max-height:420px;overflow-y:auto}
.out-text{font-size:13px;line-height:2;color:#3d2e1e;white-space:pre-wrap;word-break:break-all}
.placeholder{color:#c0aa88;font-style:italic;font-size:13px}
.tips-box{background:#fdf8f0;border-radius:10px;padding:12px 16px;margin:0 20px 12px;font-size:12px;color:#8a7560;line-height:1.8;border:1px solid #e8dcc8}
.tips-box b{color:#5c3d1e;font-weight:600}
.action-row{display:flex;gap:8px;padding:12px 20px 16px}
.copy-btn{padding:8px 18px;border:1.5px solid #d4c4a8;border-radius:10px;background:#fffdf8;color:#7a6548;font-size:13px;cursor:pointer;font-family:'Noto Sans SC',sans-serif;font-weight:500;transition:all 0.15s}
.copy-btn:hover{background:#f5efe3;border-color:#a0804a;color:#5c3d1e}
.footer{text-align:center;padding:28px;color:#b0987a;font-size:12px;letter-spacing:1px}
</style>
</head>
<body>
<div class="page-header">
  <h1>✦ AI 图文创作套件 ✦</h1>
  <p>养生茶饮 · 手绘食谱 · 知识科普 · 历史图鉴</p>
</div>

<div class="container">
<div class="top-tabs">
  <button class="top-tab active" style="background:#4caf7d" onclick="sw(0)">🍃 养生茶饮</button>
  <button class="top-tab" onclick="sw(1)">🍳 手绘食谱</button>
  <button class="top-tab" onclick="sw(2)">📚 知识科普</button>
  <button class="top-tab" onclick="sw(3)">📜 历史图鉴</button>
</div>

<div id="p0" class="panel active">
  <div class="agent-header">
    <div class="badge" style="background:#e8f5e9;color:#2e7d32">养生茶饮 · 水彩复古风</div>
    <div class="agent-title">养生茶饮食谱图 提示词生成器</div>
    <div class="agent-desc">输入茶饮名称 → 生成图片提示词 + 小红书文案提示词</div>
  </div>
  <div class="section-label">示例主题</div>
  <div class="chips">
    <span class="chip" onclick="fi(0,'红枣枸杞姜茶')">红枣枸杞姜茶</span>
    <span class="chip" onclick="fi(0,'荷叶决明子茶')">荷叶决明子茶</span>
    <span class="chip" onclick="fi(0,'五红汤')">五红汤</span>
    <span class="chip" onclick="fi(0,'陈皮玫瑰蜂蜜水')">陈皮玫瑰蜂蜜水</span>
    <span class="chip" onclick="fi(0,'桂圆莲子百合茶')">桂圆莲子百合茶</span>
  </div>
  <div class="input-row">
    <input id="i0" type="text" placeholder="输入养生茶/饮品名称，例如：桑葚菊花茶"/>
    <button class="gen-btn" style="background:#4caf7d" onclick="gen(0)">生成提示词 ↗</button>
  </div>
  <div class="out-wrap">
    <div class="out-tabs">
      <button class="out-tab active" id="ot0-0" onclick="so(0,0)" style="border-bottom-color:#4caf7d">图片提示词</button>
      <button class="out-tab" id="ot0-1" onclick="so(0,1)">小红书文案提示词</button>
    </div>
    <div class="out-content">
      <div id="o0-0" class="out-text"><span class="placeholder">输入主题后点击生成...</span></div>
      <div id="o0-1" class="out-text" style="display:none"><span class="placeholder">输入主题后点击生成...</span></div>
    </div>
  </div>
  <div id="tips0" style="display:none"><div class="tips-box"><b>使用方法：</b>复制上方提示词 → 打开Claude新对话 → 上传刚生成的图片 → 粘贴提示词发送 → 即可获得完整小红书文案</div></div>
  <div class="action-row"><button class="copy-btn" id="cb0" onclick="cp(0)">复制提示词</button></div>
</div>

<div id="p1" class="panel">
  <div class="agent-header">
    <div class="badge" style="background:#fff3e0;color:#e65100">手绘食谱 · 卡通Q版风</div>
    <div class="agent-title">手绘食谱步骤图 提示词生成器</div>
    <div class="agent-desc">输入菜名 → 生成图片提示词 + 小红书文案提示词</div>
  </div>
  <div class="section-label">示例菜名</div>
  <div class="chips">
    <span class="chip" onclick="fi(1,'红烧肉')">红烧肉</span>
    <span class="chip" onclick="fi(1,'麻婆豆腐')">麻婆豆腐</span>
    <span class="chip" onclick="fi(1,'可乐鸡翅')">可乐鸡翅</span>
    <span class="chip" onclick="fi(1,'水煮鱼')">水煮鱼</span>
    <span class="chip" onclick="fi(1,'宫保鸡丁')">宫保鸡丁</span>
    <span class="chip" onclick="fi(1,'酸辣土豆丝')">酸辣土豆丝</span>
  </div>
  <div class="input-row">
    <input id="i1" type="text" placeholder="输入菜名，例如：红烧排骨"/>
    <button class="gen-btn" style="background:#f57c20" onclick="gen(1)">生成提示词 ↗</button>
  </div>
  <div class="out-wrap">
    <div class="out-tabs">
      <button class="out-tab active" id="ot1-0" onclick="so(1,0)" style="border-bottom-color:#f57c20">图片提示词</button>
      <button class="out-tab" id="ot1-1" onclick="so(1,1)">小红书文案提示词</button>
    </div>
    <div class="out-content">
      <div id="o1-0" class="out-text"><span class="placeholder">输入主题后点击生成...</span></div>
      <div id="o1-1" class="out-text" style="display:none"><span class="placeholder">输入主题后点击生成...</span></div>
    </div>
  </div>
  <div id="tips1" style="display:none"><div class="tips-box"><b>使用方法：</b>复制上方提示词 → 打开Claude新对话 → 上传刚生成的图片 → 粘贴提示词发送 → 即可获得完整小红书文案</div></div>
  <div class="action-row"><button class="copy-btn" id="cb1" onclick="cp(1)">复制提示词</button></div>
</div>

<div id="p2" class="panel">
  <div class="agent-header">
    <div class="badge" style="background:#e3f2fd;color:#1565c0">知识科普 · 马卡龙信息图风</div>
    <div class="agent-title">知识科普信息图 提示词生成器</div>
    <div class="agent-desc">输入知识主题 → 生成图片提示词 + 小红书文案提示词</div>
  </div>
  <div class="section-label">示例主题</div>
  <div class="chips">
    <span class="chip" onclick="fi(2,'咖啡')">咖啡</span>
    <span class="chip" onclick="fi(2,'睡眠')">睡眠</span>
    <span class="chip" onclick="fi(2,'维生素')">维生素</span>
    <span class="chip" onclick="fi(2,'香薰精油')">香薰精油</span>
    <span class="chip" onclick="fi(2,'中医五行')">中医五行</span>
    <span class="chip" onclick="fi(2,'葡萄酒')">葡萄酒</span>
  </div>
  <div class="input-row">
    <input id="i2" type="text" placeholder="输入知识主题，例如：茶叶的六大分类"/>
    <button class="gen-btn" style="background:#1976d2" onclick="gen(2)">生成提示词 ↗</button>
  </div>
  <div class="out-wrap">
    <div class="out-tabs">
      <button class="out-tab active" id="ot2-0" onclick="so(2,0)" style="border-bottom-color:#1976d2">图片提示词</button>
      <button class="out-tab" id="ot2-1" onclick="so(2,1)">小红书文案提示词</button>
    </div>
    <div class="out-content">
      <div id="o2-0" class="out-text"><span class="placeholder">输入主题后点击生成...</span></div>
      <div id="o2-1" class="out-text" style="display:none"><span class="placeholder">输入主题后点击生成...</span></div>
    </div>
  </div>
  <div id="tips2" style="display:none"><div class="tips-box"><b>使用方法：</b>复制上方提示词 → 打开Claude新对话 → 上传刚生成的图片 → 粘贴提示词发送 → 即可获得完整小红书文案</div></div>
  <div class="action-row"><button class="copy-btn" id="cb2" onclick="cp(2)">复制提示词</button></div>
</div>

<div id="p3" class="panel">
  <div class="agent-header">
    <div class="badge" style="background:#fce4ec;color:#880e4f">历史图鉴 · 古风工笔画风</div>
    <div class="agent-title">历史图鉴长图 提示词生成器</div>
    <div class="agent-desc">输入历史主题 → 生成图片提示词 + 小红书文案提示词</div>
  </div>
  <div class="section-label">示例主题</div>
  <div class="chips">
    <span class="chip" onclick="fi(3,'中国茶文化演变')">中国茶文化演变</span>
    <span class="chip" onclick="fi(3,'汉字演变史')">汉字演变史</span>
    <span class="chip" onclick="fi(3,'古代文房四宝')">古代文房四宝</span>
    <span class="chip" onclick="fi(3,'中国建筑风格演变')">中国建筑风格演变</span>
    <span class="chip" onclick="fi(3,'丝绸之路')">丝绸之路</span>
  </div>
  <div class="input-row">
    <input id="i3" type="text" placeholder="输入历史主题，例如：唐朝服饰演变"/>
    <button class="gen-btn" style="background:#ad1457" onclick="gen(3)">生成提示词 ↗</button>
  </div>
  <div class="out-wrap">
    <div class="out-tabs">
      <button class="out-tab active" id="ot3-0" onclick="so(3,0)" style="border-bottom-color:#ad1457">图片提示词</button>
      <button class="out-tab" id="ot3-1" onclick="so(3,1)">小红书文案提示词</button>
    </div>
    <div class="out-content">
      <div id="o3-0" class="out-text"><span class="placeholder">输入主题后点击生成...</span></div>
      <div id="o3-1" class="out-text" style="display:none"><span class="placeholder">输入主题后点击生成...</span></div>
    </div>
  </div>
  <div id="tips3" style="display:none"><div class="tips-box"><b>使用方法：</b>复制上方提示词 → 打开Claude新对话 → 上传刚生成的图片 → 粘贴提示词发送 → 即可获得完整小红书文案</div></div>
  <div class="action-row"><button class="copy-btn" id="cb3" onclick="cp(3)">复制提示词</button></div>
</div>

<div class="footer">AI 图文创作套件 · V1.0</div>
</div>

<script>
const C=['#4caf7d','#f57c20','#1976d2','#ad1457'];
let ao=[0,0,0,0],ct=[['',''],['',''],['',''],['','']];
function sw(i){
  document.querySelectorAll('.panel').forEach((p,idx)=>p.classList.toggle('active',idx===i));
  document.querySelectorAll('.top-tab').forEach((t,idx)=>{
    t.classList.toggle('active',idx===i);
    t.style.background=idx===i?C[i]:'';
    t.style.color=idx===i?'#fff':'';
    t.style.borderColor=idx===i?'transparent':'';
  });
}
function fi(p,v){document.getElementById('i'+p).value=v;}
function so(p,i){
  ao[p]=i;
  [0,1].forEach(idx=>{
    const t=document.getElementById('ot'+p+'-'+idx);
    t.classList.toggle('active',idx===i);
    t.style.borderBottomColor=idx===i?C[p]:'transparent';
    document.getElementById('o'+p+'-'+idx).style.display=idx===i?'block':'none';
  });
  document.getElementById('tips'+p).style.display=i===1?'block':'none';
}
function gen(p){
  const t=document.getElementById('i'+p).value.trim();
  if(!t){document.getElementById('o'+p+'-0').innerHTML='<span class="placeholder">请先输入主题～</span>';return;}
  ct[p][0]=getImg(p,t);
  ct[p][1]=getCopy(p,t);
  document.getElementById('o'+p+'-0').textContent=ct[p][0];
  document.getElementById('o'+p+'-1').textContent=ct[p][1];
}
function cp(p){
  const text=ct[p][ao[p]];
  if(!text)return;
  navigator.clipboard.writeText(text).then(()=>{
    const b=document.getElementById('cb'+p);
    b.textContent='已复制 ✓';
    setTimeout(()=>b.textContent='复制提示词',1800);
  });
}
function getImg(p,t){
  return[
`水彩手绘风格，复古做旧泛黄宣纸背景（带自然水渍晕染痕迹），竖版3:4构图，"${t}"养生食谱插画。

⚠️注意：以下是画面结构说明，不要将任何说明文字画进图片中

【标题区】顶部仿古卷轴展开样式，毛笔书法字体写"${t}"，两侧配手绘枸杞/红枣/草药枝条装饰，整体宽度撑满顶部。

【食材清单区】细线描边矩形边框围住，左上角"食材清单"印章标注。食材横向整齐一排，每种：上方手绘实物插图（颗粒纹理清晰），下方中文名称+精确用量（如红枣5颗、枸杞10克）。严禁"适量""少许"等模糊表述。全部中文禁止英文。

【制作步骤区】细线描边矩形边框围住，左上角"制作步骤"印章标注。共3步，每步：圆圈数字+步骤名称+大尺寸步骤插图（占步骤格70%）+简短说明。青花瓷碗有花纹细节，玻璃茶壶有通透感。步骤间箭头连接。

【功效贴士区】底部仿古卷轴横幅，★五角星装饰，格式："养生功效：XXX·XXX·XXX"，全中文。

整体：米黄赭石草木绿砖红主色调，水彩晕染自然，所有文字准确无错别字无英文。`,

`可爱卡通手绘风格，"${t}·手绘食谱"完整竖版长图，比例2:3，整体像手写私房菜谱，有温度感，不是打印表格。

⚠️注意：以下是画面结构说明，不要将任何说明文字画进图片中

【标题区】大标题"${t}·手绘食谱"马克笔圆润手写风，两侧拟人食材图标（辣椒/葱花带笑脸）撑到边缘，副标题"5步搞定！下饭神菜"，星星爱心点缀。

【食材战袍区】区块标题必须写"食材战袍"，圆角矩形框宽度撑满。左区：主食材横排，手绘实物插图带可爱表情，下方中文名+精确用量（如五花肉500克）。右区：调料按圆圈数字编号"①1勺料酒 ②2勺生抽…"配调料瓶勺子图。全部中文禁止英文，禁止"适量""少许"。

【制作步骤区】3-5步，每步独占一整行纵向往下，禁止横向并排。每步：圆圈编号+拟人标题（如"肉肉下锅煎舞""咕嘟桑拿时间"）+大尺寸锅具插图（占步骤格70%，火焰在锅底，油烟蒸汽曲线）+火候时间小标签+底部12字内说明。步骤间向下虚线箭头。

【完成图区】独占完整一行宽度撑满，高度不低于画面20%，成品大图居中色泽鲜亮，配白米饭+碗筷，"完成！开吃啦！"大字+星星爱心。

【小贴士区】底部圆角气泡横幅宽度撑满，①②③格式全部中文，禁止"Tip 1""Tip 2"等任何英文。

整体：背景米白奶油色，两侧留白不超过5%，线条圆润手绘感，所有文字准确无英文。`,

`可爱卡通插画风格，"${t}"知识科普信息图，竖版3:4构图，马卡龙配色，一图看懂系列。

⚠️注意：以下是画面结构说明，不要将任何说明文字画进图片中

【标题区】书名号格式：《${t}》，字体圆润，彩虹渐变缎带横幅副标题"从入门到精通（一图看懂）"，四角星星小云朵爱心装饰。

【三要素导读条】横向三格：每格Q版小图标+核心维度关键词+简短说明，三色圆角矩形（淡粉/浅蓝/嫩绿）。

【一句话点题】云朵形气泡框居中，一句概括${t}价值的话。

【核心知识点2×2分格】标题"核心知识点"，四格2×2排列四色区分（淡粉/浅蓝/嫩绿/鹅黄）。每格：数字编号+小标题+左侧Q版插图（与知识点精确对应）+右侧3条要点。图文全部中文禁止任何英文标注。

【知识关系图】标题"一个好${t}=四件事合在一起"，中心词+四方向要素+Q版插图+虚线箭头，全部中文。

【底部双栏贴士】左栏"避坑清单"红色系+×图标3条，右栏"使用建议"绿色系+✓图标3条，内容具体口语化。

整体：米白奶油背景，马卡龙四色活泼，Q版插图丰富，全程纯中文无任何英文字母。`,

`古风工笔插画风格，"${t}"历史图鉴长图，竖版2:3构图，米黄绢布底色，卷轴装帧感。

⚠️注意：以下是画面结构说明，不要将任何说明文字画进图片中。画面中禁止出现任何区块标注文字，只画内容本身。

【标题卷轴区】顶部仿古书卷展开样式，卷轴两端可见卷起效果。主标题大字"${t}"毛笔楷书风格，副标题"一眼看懂·演变脉络"，两侧祥云纹回纹装饰。

【时间轴主体区】中央纵向时间轴（赭石色或金色）贯穿画面中部。每个节点：
- 中央：时期名称用横幅或圆形框住
- 左侧：该时期代表性插图（根据"${t}"主题决定内容），图下方写简短插图标注（2-4字）
- 右侧：该时期2-3条核心特征文字
- 左右两侧内容必须完全不同，禁止左右出现相同文字
- 节点数量6-8个，工笔细绘，颜色朱砂红/青绿/赭石/靛蓝点缀

【细节展示区】底部2个小边框并排，各放大展示一个典型细节特写，工笔细绘，左右两框内容不同，各写一行中文标注。

【底部总结语】卷轴横幅样式，一句文言风格点题总结（10-16字），两侧传统纹样装饰。

整体：米黄绢布底色带做旧质感，墨色线条勾勒，庄重典雅，全程纯中文无英文。`
  ][p];
}
function getCopy(p,t){
  const templates=[
`你是一位擅长三平台运营的AIGC内容创作者。
我刚刚用AI生成了一张「${t}」养生茶饮图，请根据图片内容同时输出三平台配套文案：

【视频号文案】
- 标题：1个，不超过20字，突出养生功效
- 正文：150字，口语化，闺蜜分享感，有共鸣感
- 结尾：引导点赞收藏转发

【小红书文案】
- 备选标题：3个，带emoji（🍵🌿✨），有收藏冲动，不超过20字
- 正文：200字，口语化，痛点开头+功效+做法+适合人群
- 结尾：引导收藏+评论互动
- 话题标签：10个，含 #养生茶 #${t} #养生日常 #中医养生 #食疗养生

【抖音文案】
- 备选标题：3个，带emoji，有点击欲，不超过20字
- 正文：150字，节奏感强，口语化
- 结尾：引导点赞收藏关注
- 话题标签：8个`,

`你是一位擅长三平台运营的AIGC内容创作者。
我刚刚用AI生成了一张「${t}」手绘食谱图，请根据图片内容同时输出三平台配套文案：

【视频号文案】
- 标题：1个，不超过20字，突出简单好吃
- 正文：150字，口语化，有烟火气，有共鸣感
- 结尾：引导点赞收藏转发

【小红书文案】
- 备选标题：3个，带emoji（🍳🔥😋），有收藏冲动，不超过20字
- 正文：200字，口语化，食材+步骤+亮点+互动
- 结尾：引导收藏+评论
- 话题标签：10个，含 #${t}的做法 #家常菜 #下饭菜 #简单好吃

【抖音文案】
- 备选标题：3个，带emoji，有点击欲，不超过20字
- 正文：150字，节奏感强
- 结尾：引导点赞收藏关注
- 话题标签：8个`,

`你是一位擅长三平台运营的AIGC内容创作者。
我刚刚用AI生成了一张「${t}」知识科普图，请根据图片内容同时输出三平台配套文案：

【视频号文案】
- 标题：1个，不超过20字，有知识感+吸引力
- 正文：150字，口语化，有共鸣感
- 结尾：引导点赞收藏转发

【小红书文案】
- 备选标题：3个，带emoji（📚✨💡），有收藏冲动，不超过20字
- 正文：200字，口语化，涨知识感
- 结尾：引导收藏+评论互动
- 话题标签：10个，含 #${t} #知识科普 #涨知识 #一图看懂

【抖音文案】
- 备选标题：3个，带emoji，有点击欲，不超过20字
- 正文：150字，节奏感强
- 结尾：引导点赞收藏关注
- 话题标签：8个`,

`你是一位擅长三平台运营的AIGC内容创作者。
我刚刚用AI生成了一张「${t}」历史图鉴图，请根据图片内容同时输出三平台配套文案：

【视频号文案】
- 标题：1个，不超过20字，历史感+吸引力
- 正文：150字，口语化，有共鸣感
- 结尾：引导点赞收藏转发

【小红书文案】
- 备选标题：3个，带emoji（🏛️📜✨），有收藏冲动，不超过20字
- 正文：200字，口语化，历史故事感
- 结尾：引导收藏+评论互动
- 话题标签：10个，含 #${t} #中国历史 #历史知识 #传统文化 #涨知识

【抖音文案】
- 备选标题：3个，带emoji，有点击欲，不超过20字
- 正文：150字，节奏感强
- 结尾：引导点赞收藏关注
- 话题标签：8个`
  ];
  return templates[p];
}
</script>

<div style="text-align:center;padding:24px 20px;border-top:1px solid #e0cfa8;margin-top:24px;background:#faf6ef">
  <div style="font-size:14px;font-weight:700;color:#1a0a00;letter-spacing:3px;margin-bottom:6px;font-family:'PingFang SC','Microsoft YaHei',serif">📜 阿坚AIGC · 工具中心</div>
  <div style="font-size:11px;color:#6a4a20;letter-spacing:1px;line-height:2">AI图文创作套件<br>版权所有 © 阿坚AIGC · 仅供授权用户个人创作使用 · 禁止商业转载与二次分发</div>
</div>
</body>
</html>

<!DOCTYPE html>
<html lang="zh-CN">
<head>
<meta charset="UTF-8">
<meta name="viewport" content="width=device-width, initial-scale=1.0">
<title>廿四节气图文工坊</title>
<link href="https://fonts.googleapis.com/css2?family=Noto+Serif+SC:wght@400;600&family=Noto+Sans+SC:wght@400;500&display=swap" rel="stylesheet">
<style>
*{box-sizing:border-box;margin:0;padding:0}
body{font-family:'Noto Sans SC',sans-serif;background:#f5f0e8;min-height:100vh;color:#2d2417}

.brand{background:linear-gradient(135deg,#2d1f0f 0%,#5c3010 55%,#7a4520 100%);padding:2rem 1.5rem 1.75rem;text-align:center;position:relative;overflow:hidden}
.brand::before{content:'✦ 廿四节气图文工坊 ✦';position:absolute;top:10px;left:0;right:0;text-align:center;font-size:10px;color:rgba(255,220,150,0.3);letter-spacing:5px}
.brand::after{content:'';position:absolute;inset:0;background:url("data:image/svg+xml,%3Csvg width='40' height='40' viewBox='0 0 40 40' xmlns='http://www.w3.org/2000/svg'%3E%3Cg fill='%23ffffff' fill-opacity='0.03'%3E%3Cpath d='M20 0L40 20L20 40L0 20z'/%3E%3C/g%3E%3C/svg%3E");pointer-events:none}
.brand-name{font-family:'Noto Serif SC',serif;font-size:26px;font-weight:600;color:#f5e6c8;letter-spacing:4px;margin-bottom:6px;position:relative;z-index:1}
.brand-ver{text-align:center;margin-bottom:16px;position:relative;z-index:1}
.brand-ver span{font-size:11px;color:rgba(245,230,200,0.55);letter-spacing:2px;border:0.5px solid rgba(245,230,200,0.2);padding:2px 12px;border-radius:20px}
.brand-intro{font-size:13px;color:rgba(245,230,200,0.82);line-height:1.95;max-width:560px;margin:0 auto 16px;position:relative;z-index:1}
.brand-tags{display:flex;gap:7px;flex-wrap:wrap;justify-content:center;position:relative;z-index:1}
.brand-tag{font-size:11px;padding:3px 11px;border-radius:20px;background:rgba(245,230,200,0.1);color:rgba(245,230,200,0.7);border:0.5px solid rgba(245,230,200,0.18);letter-spacing:0.5px}

.container{max-width:780px;margin:0 auto;padding:24px 20px}

.manual-toggle{display:flex;align-items:center;justify-content:space-between;padding:11px 16px;background:#fff;border:0.5px solid #ddd4bc;border-radius:10px;cursor:pointer;margin-bottom:16px;user-select:none}
.manual-toggle-left{display:flex;align-items:center;gap:8px;font-size:13px;font-weight:500;color:#2d2417}
.manual-arrow{font-size:11px;color:#9a8870;transition:transform 0.2s}
.manual-arrow.open{transform:rotate(180deg)}
.manual-body{display:none;border:0.5px solid #ddd4bc;border-radius:12px;overflow:hidden;margin-bottom:20px;background:#fff}
.manual-body.open{display:block}
.manual-section{padding:1rem 1.25rem;border-bottom:0.5px solid #ece4d0}
.manual-section:last-child{border-bottom:none}
.manual-section-title{font-size:12px;font-weight:500;color:#7a6548;letter-spacing:0.8px;margin-bottom:10px}
.manual-steps{display:flex;flex-direction:column;gap:9px}
.manual-step{display:flex;gap:10px;align-items:flex-start}
.step-num{width:20px;height:20px;border-radius:50%;background:#c07830;color:#fff;font-size:11px;font-weight:500;display:flex;align-items:center;justify-content:center;flex-shrink:0;margin-top:1px}
.step-text{font-size:13px;color:#3d2e1e;line-height:1.75}
.step-text b{font-weight:500;color:#2d1f0f}
.step-text em{color:#8a7560;font-style:normal;font-size:12px}
.tips-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:8px}
.tip-card{background:#faf6ee;border-radius:8px;padding:10px 12px;border:0.5px solid #ddd4bc}
.tip-card-title{font-size:12px;font-weight:500;color:#2d1f0f;margin-bottom:4px}
.tip-card-desc{font-size:12px;color:#7a6548;line-height:1.65}

.divider{height:0.5px;background:#ddd4bc;margin:1rem 0}
.step-label{font-size:11px;color:#9a8870;letter-spacing:0.8px;margin-bottom:6px;margin-top:1rem}

.chips{display:flex;gap:6px;flex-wrap:wrap;margin-bottom:8px}
.chip{font-size:12px;padding:4px 11px;border:0.5px solid #ddd4bc;border-radius:20px;cursor:pointer;color:#7a6548;background:#fff;transition:all 0.15s}
.chip:hover{border-color:#c07830;color:#5c3010}
.chip.active{color:#fff;border-color:transparent;background:#c07830;font-weight:500}

.dir-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:8px;margin-bottom:1rem}
.dir-btn{padding:13px;border-radius:12px;border:0.5px solid #ddd4bc;background:#fff;cursor:pointer;text-align:left;transition:all 0.15s}
.dir-btn:hover{background:#faf6ee;border-color:#c0a880}
.dir-btn.active{border-width:2px}
.dir-icon{font-size:18px;margin-bottom:4px}
.dir-name{font-size:13px;font-weight:500;color:#2d1f0f}
.dir-style{font-size:11px;color:#9a8870;margin-top:2px}

.sel-box{border:0.5px solid #ddd4bc;border-radius:12px;padding:1rem 1.25rem;margin-bottom:1rem;background:#fff}
.sel-title{font-size:13px;font-weight:500;color:#2d1f0f;margin-bottom:4px}
.sel-desc{font-size:12px;color:#9a8870;margin-bottom:10px}
.sel-chips{display:flex;gap:6px;flex-wrap:wrap;margin-bottom:10px}
.sel-chip{font-size:12px;padding:6px 13px;border:0.5px solid #ddd4bc;border-radius:8px;cursor:pointer;color:#7a6548;background:#faf6ee;transition:all 0.15s}
.sel-chip:hover{border-color:#c0a880;color:#2d1f0f}
.sel-chip.selected{color:#fff;border-color:transparent;font-weight:500}
.custom-row{display:flex;gap:8px;align-items:center}
.custom-row input{flex:1;padding:9px 13px;font-size:13px;border:0.5px solid #ccc0a0;border-radius:8px;background:#fff;color:#2d1f0f;font-family:'Noto Sans SC',sans-serif;outline:none}
.custom-row input:focus{border-color:#c07830}
.custom-row input::placeholder{color:#bba880}
.custom-label{font-size:12px;color:#7a6548;white-space:nowrap}

.btn-row{display:flex;justify-content:flex-end;margin-bottom:1rem}
.gen-btn{padding:11px 22px;border-radius:10px;font-size:14px;font-weight:500;cursor:pointer;border:none;color:#fff;background:#c07830;font-family:'Noto Sans SC',sans-serif;letter-spacing:0.5px;transition:all 0.2s;box-shadow:0 2px 8px rgba(192,120,48,0.25)}
.gen-btn:hover{background:#a86020;box-shadow:0 4px 14px rgba(192,120,48,0.35);transform:translateY(-1px)}

.out-wrap{border:0.5px solid #ddd4bc;border-radius:12px;background:#fff;overflow:hidden}
.out-tabs{display:flex;border-bottom:0.5px solid #ece4d0;background:#faf6ee}
.out-tab{padding:9px 18px;font-size:13px;cursor:pointer;color:#9a8870;border-bottom:2px solid transparent;background:transparent;border-top:none;border-left:none;border-right:none;font-family:'Noto Sans SC',sans-serif;transition:all 0.15s}
.out-tab.active{color:#2d1f0f;font-weight:500}
.out-content{padding:1.25rem;min-height:200px;max-height:440px;overflow-y:auto}
.out-text{font-size:13px;line-height:2;color:#2d1f0f;white-space:pre-wrap;word-break:break-all}
.placeholder{color:#bba880;font-style:italic;font-size:13px}
.use-tips{background:#fdf9f2;border-radius:8px;padding:11px 15px;margin:0 1.25rem 10px;font-size:12px;color:#7a6548;line-height:1.75;border:0.5px solid #ddd4bc}
.use-tips b{color:#5c3010;font-weight:500}
.action-row{display:flex;gap:8px;padding:10px 1.25rem 14px}
.copy-btn{padding:8px 18px;border:0.5px solid #ddd4bc;border-radius:8px;background:#fff;color:#7a6548;font-size:13px;cursor:pointer;font-family:'Noto Sans SC',sans-serif;transition:all 0.15s}
.copy-btn:hover{background:#faf6ee;border-color:#c0a880;color:#2d1f0f}

.footer{text-align:center;padding:24px 0 12px;color:#bba880;font-size:11px;letter-spacing:1.5px}
</style>
</head>
<body>

<div class="brand">
  <div class="brand-name">廿四节气图文工坊</div>
  <div class="brand-ver"><span>V 1.0 · 正式版</span></div>
  <div class="brand-intro">一套为内容创作者打造的节气图文提示词生成引擎。<br>覆盖二十四节气 × 四大创作方向 × 双输出模式，<br>从节气养生到民俗图鉴，从美食步骤到知识科普，<br>输入主题，一键生成可直接投喂即梦 / 香蕉Pro的高质量提示词。</div>
  <div class="brand-tags">
    <span class="brand-tag">24节气全覆盖</span>
    <span class="brand-tag">四大风格方向</span>
    <span class="brand-tag">图片提示词</span>
    <span class="brand-tag">三平台文案提示词</span>
    <span class="brand-tag">支持自定义输入</span>
    <span class="brand-tag">即梦 / 香蕉Pro适配</span>
  </div>
</div>

<div class="container">

<div class="manual-toggle" onclick="toggleManual()">
  <div class="manual-toggle-left"><span>📖</span><span>使用手册 — 三步出图，新手友好</span></div>
  <span class="manual-arrow" id="manual-arrow">▼</span>
</div>

<div class="manual-body" id="manual-body">
  <div class="manual-section">
    <div class="manual-section-title">🚀 快速上手 — 三步生成提示词</div>
    <div class="manual-steps">
      <div class="manual-step"><div class="step-num">1</div><div class="step-text"><b>选择节气</b>：点击下方24个节气标签之一（如清明、冬至、谷雨）。<em>建议优先选择当前或即将到来的节气，追热点效果更好。</em></div></div>
      <div class="manual-step"><div class="step-num">2</div><div class="step-text"><b>选择创作方向</b>：四个方向对应四种风格 —— 🌿节气养生（水彩复古风）· 🍜节气美食（卡通Q版风）· 📖节气科普（马卡龙信息图）· 🏮节气习俗（古风工笔风）。<em>选好方向风格就锁定了。</em></div></div>
      <div class="manual-step"><div class="step-num">3</div><div class="step-text"><b>选择具体内容</b>：系统自动推荐该节气6个真实内容供点选，也可在自定义框填写任意内容。点击「生成提示词」即可输出。<em>可切换两个标签分别复制图片提示词和文案提示词。</em></div></div>
    </div>
  </div>
  <div class="manual-section">
    <div class="manual-section-title">🎨 图片提示词怎么用</div>
    <div class="manual-steps">
      <div class="manual-step"><div class="step-num">1</div><div class="step-text">点击「复制提示词」→ 打开<b>即梦AI</b>或<b>香蕉Pro</b> → 粘贴到文生图输入框 → 生成图片。<em>推荐香蕉Pro，出图质量更稳定，排版更准确。</em></div></div>
      <div class="manual-step"><div class="step-num">2</div><div class="step-text">图片生成后检查：文字是否清晰、结构是否完整、有无乱码英文。<em>不满意可回来重新生成，每次内容略有不同。</em></div></div>
    </div>
  </div>
  <div class="manual-section">
    <div class="manual-section-title">✍️ 三平台文案提示词怎么用</div>
    <div class="manual-steps">
      <div class="manual-step"><div class="step-num">1</div><div class="step-text">切换到「三平台文案提示词」标签 → 复制 → <b>打开Claude新对话</b>。<em>注意：一定要开新对话，不要在当前对话使用。</em></div></div>
      <div class="manual-step"><div class="step-num">2</div><div class="step-text"><b>先上传图片</b>，再粘贴提示词发送 → Claude会结合图片内容生成完整三平台文案。<em>图片是关键，不上传图片文案会失去针对性。</em></div></div>
    </div>
  </div>
  <div class="manual-section">
    <div class="manual-section-title">💡 使用技巧</div>
    <div class="tips-grid">
      <div class="tip-card"><div class="tip-card-title">追节气热点</div><div class="tip-card-desc">节气前3天发布效果最好，搜索流量在节气当天前后达到峰值。</div></div>
      <div class="tip-card"><div class="tip-card-title">四图组合发</div><div class="tip-card-desc">同一节气选养生+美食+科普+习俗各生成一张，组合四图笔记互动率更高。</div></div>
      <div class="tip-card"><div class="tip-card-title">自定义内容</div><div class="tip-card-desc">内置选项之外，自定义框可输入任意主题，灵活度更高，内容更个性化。</div></div>
      <div class="tip-card"><div class="tip-card-title">不满意就换</div><div class="tip-card-desc">同一主题多次点击生成，AI出图结果略有不同，挑最满意的那张发布。</div></div>
    </div>
  </div>
</div>

<div class="step-label">第一步 — 选择节气</div>
<div class="chips" id="jq-chips">
  <span class="chip" onclick="selJQ('立春')">立春</span><span class="chip" onclick="selJQ('雨水')">雨水</span><span class="chip" onclick="selJQ('惊蛰')">惊蛰</span><span class="chip" onclick="selJQ('春分')">春分</span><span class="chip" onclick="selJQ('清明')">清明</span><span class="chip" onclick="selJQ('谷雨')">谷雨</span><span class="chip" onclick="selJQ('立夏')">立夏</span><span class="chip" onclick="selJQ('小满')">小满</span><span class="chip" onclick="selJQ('芒种')">芒种</span><span class="chip" onclick="selJQ('夏至')">夏至</span><span class="chip" onclick="selJQ('小暑')">小暑</span><span class="chip" onclick="selJQ('大暑')">大暑</span><span class="chip" onclick="selJQ('立秋')">立秋</span><span class="chip" onclick="selJQ('处暑')">处暑</span><span class="chip" onclick="selJQ('白露')">白露</span><span class="chip" onclick="selJQ('秋分')">秋分</span><span class="chip" onclick="selJQ('寒露')">寒露</span><span class="chip" onclick="selJQ('霜降')">霜降</span><span class="chip" onclick="selJQ('立冬')">立冬</span><span class="chip" onclick="selJQ('小雪')">小雪</span><span class="chip" onclick="selJQ('大雪')">大雪</span><span class="chip" onclick="selJQ('冬至')">冬至</span><span class="chip" onclick="selJQ('小寒')">小寒</span><span class="chip" onclick="selJQ('大寒')">大寒</span>
</div>

<div class="divider"></div>
<div class="step-label">第二步 — 选择创作方向</div>
<div class="dir-grid">
  <button class="dir-btn" id="d0" onclick="selDir(0)"><div class="dir-icon">🌿</div><div class="dir-name">节气养生</div><div class="dir-style">水彩复古风 · 养生方向+食材</div></button>
  <button class="dir-btn" id="d1" onclick="selDir(1)"><div class="dir-icon">🍜</div><div class="dir-name">节气美食</div><div class="dir-style">卡通Q版风 · 特色美食步骤图</div></button>
  <button class="dir-btn" id="d2" onclick="selDir(2)"><div class="dir-icon">📖</div><div class="dir-name">节气知识科普</div><div class="dir-style">马卡龙信息图风 · 一图看懂</div></button>
  <button class="dir-btn" id="d3" onclick="selDir(3)"><div class="dir-icon">🏮</div><div class="dir-name">节气习俗</div><div class="dir-style">古风工笔风 · 传统习俗图鉴</div></button>
</div>

<div id="sel-box" class="sel-box" style="display:none">
  <div class="sel-title" id="sel-title">第三步 — 选择内容</div>
  <div class="sel-desc" id="sel-desc">点击选择，或在下方自定义输入</div>
  <div class="sel-chips" id="sel-chips"></div>
  <div class="custom-row">
    <span class="custom-label">自定义：</span>
    <input id="custom-input" type="text" placeholder=""/>
  </div>
</div>

<div class="btn-row">
  <button class="gen-btn" onclick="gen()">生成提示词 ↗</button>
</div>

<div class="out-wrap">
  <div class="out-tabs">
    <button class="out-tab active" id="ot0" onclick="so(0)" style="border-bottom-color:#c07830">图片提示词</button>
    <button class="out-tab" id="ot1" onclick="so(1)">三平台文案提示词</button>
  </div>
  <div class="out-content">
    <div id="o0" class="out-text"><span class="placeholder">选择节气和方向后，点击生成提示词...</span></div>
    <div id="o1" class="out-text" style="display:none"><span class="placeholder">选择节气和方向后，点击生成提示词...</span></div>
  </div>
</div>
<div id="tips" style="display:none"><div class="use-tips"><b>文案提示词使用：</b>复制 → 打开Claude新对话 → 先上传生成好的图片 → 再粘贴提示词发送 → 获得完整三平台文案</div></div>
<div class="action-row"><button class="copy-btn" id="copybtn" onclick="doCopy()">复制提示词</button></div>

<div class="footer">廿四节气图文工坊 · V1.0 · 为内容创作者而生</div>
</div>

<script>
const C=['#4caf7d','#f57c20','#1976d2','#ad1457'];
let curJQ='',selD=-1,activeTab=0,selItem='',ct=['',''];
const DEF=[['养肝疏肝','健脾祛湿','温阳补肾','润肺止咳','补气养血','清热解毒','疏肝理气','安神助眠','活血通络','消食导滞','滋阴润燥'],['应季时令粥','节气养生汤','传统节气糕','时令炒蔬菜','节气饮品','应季炖肉','时令野菜','节气甜品','应季鱼虾','节气饺子','时令汤羹'],['节气三候知识','节气含义由来','节气物候变化','节气气候特征','节气饮食指南','节气民间习俗','节气农事活动','节气养生要点','节气防病知识','节气文化历史','节气与农耕关系'],['祭祀祖先活动','踏青游玩习俗','传统饮食习俗','节令手工活动','民间祈福仪式','节气禁忌习俗','传统竞技游戏','节气服饰文化','节气诗词文化','节气农耕习俗','节气音乐习俗']];
const DATA={'立春':{hua:'迎春花、梅花、玉兰花',food:['春饼','荠菜饺子','春笋炒肉','韭菜盒子','萝卜咬春','五辛盘','春芽炒蛋','菠菜猪肝汤','姜枣红糖水','桂圆莲子粥','春卷'],yang:['养肝疏肝','升发阳气','祛寒健脾','补气养血','清热解毒','润肺护肤','疏风解表','温肾补阳','健脾开胃','活血化瘀','安神助眠'],kepu:['立春三候知识','春季养肝要点','咬春习俗由来','立春物候变化','春季饮食禁忌','立春节气含义','东风解冻现象','春季防病指南','立春民间习俗','春季情志养生','立春穿衣要点'],su:['咬春吃萝卜','打春牛','踏青赏春','贴春牛图','挂春幡','戴春胜','游春','迎春祭祀','送春礼','放风筝','赏迎春花']},'雨水':{hua:'油菜花、李花、杏花',food:['荠菜春卷','山药薏米粥','红豆薏米汤','春笋排骨汤','香椿炒鸡蛋','茯苓饼','陈皮绿豆沙','春韭炒豆芽','黄芪红枣鸡汤','薏米莲子羹','蒸春鱼'],yang:['健脾祛湿','疏肝理气','养胃护脾','补气升阳','润燥养肺','温中散寒','益肾固精','清热利湿','养血安神','活血通络','消食导滞'],kepu:['雨水三候知识','雨水节气含义','春雨与农耕关系','雨水湿气特点','雨水饮食指南','雨水民间习俗','雨水节气物候','春季祛湿要点','雨水节气由来','春季脾胃养护','雨水气候特征'],su:['回娘家送节','占稻色','接寿','撞拜寄拜干爹','赏春雨','祭社神','耕田备耕','采茶','踏青','春社活动','拜月老']},'惊蛰':{hua:'桃花、李花、蔷薇',food:['雪梨炖川贝','糯米蒸梨','荠菜豆腐羹','菊花枸杞粥','春笋蒸鸡','蛤蜊豆腐汤','红枣银耳羹','韭菜炒河虾','炒苦瓜','梨膏糖','蒸鳗鱼'],yang:['清肝降火','润肺止咳','健脾开胃','益肾壮骨','祛风散寒','滋阴润燥','补气养血','清热解毒','疏肝理气','温阳化湿','安神定志'],kepu:['惊蛰三候知识','春雷与蛰虫关系','惊蛰吃梨习俗','惊蛰节气含义','春季防病要点','惊蛰物候变化','惊蛰民间习俗','打小人习俗由来','惊蛰气候特征','春季护肝要点','惊蛰饮食指南'],su:['祭白虎','打小人','蒙鼓皮','吃梨','祭雷神','祭田祖','犁头节','除虫','春祭','蒙鼓皮仪式','赏桃花']},'春分':{hua:'春兰、樱花、海棠',food:['糯米圆子','桃花粥','菠菜猪血汤','莴笋炒百合','三色蔬菜饺','枸杞芽炒肉','蒸鳗鱼','红曲米酒鸡','春菜汤','春分蒸春菜','荠菜豆腐'],yang:['平衡阴阳','养肝明目','健脾益胃','补血调经','疏肝解郁','润肺养阴','益气补血','清热祛湿','温经散寒','安神助眠','活血化瘀'],kepu:['春分昼夜等长','春分三候知识','竖蛋习俗原理','春分节气含义','春分物候变化','阴阳平衡养生','春分农耕习俗','春季花卉知识','春分气候特征','春季饮食调养','春分民间禁忌'],su:['竖蛋','送春牛图','粘雀子嘴','犒劳耕牛','踏青郊游','赏春花','祭日','吃春菜','放风筝','春社祭祀','扫墓']},'清明':{hua:'桃花、梨花、杏花',food:['青团','艾草粑粑','清明螺蛳','荠菜煎饼','清明果','马兰头拌香干','香椿炒鸡蛋','糖藕','荠菜豆腐汤','清明鸡蛋饼','菠菜猪肝汤'],yang:['养肝明目','祛湿健脾','清热解毒','疏肝解郁','健脾养胃','补气养血','润肺护肤','活血化瘀','养心安神','益肾固精','温经散寒'],kepu:['清明扫墓由来','清明三候知识','清明节气含义','清明物候变化','清明饮食指南','清明民间习俗','踏青习俗起源','清明放风筝文化','清明插柳习俗','清明节气气候','清明农事活动'],su:['扫墓祭祖','踏青郊游','放风筝','荡秋千','插柳戴柳','蚕花会','拔河','蹴鞠','斗鸡','赏花','吃青团']},'谷雨':{hua:'牡丹、芍药、杜鹃',food:['香椿芽拌豆腐','谷雨茶','鲫鱼豆腐汤','菠菜炒猪肝','薏米红豆粥','春笋炒鸡片','桑葚果冻','牡丹花饼','荠菜粥','木耳炒肉','蒸海鲜'],yang:['祛湿健脾','养肝护肝','清热利湿','补气养血','疏肝理气','润肺止咳','益肾固精','温中健胃','活血通络','安神助眠','滋阴润燥'],kepu:['谷雨三候知识','谷雨节气含义','谷雨茶文化','谷雨物候变化','谷雨祭海习俗','谷雨农事活动','谷雨气候特征','谷雨饮食指南','谷雨民间习俗','春末养生要点','谷雨走谷雨习俗'],su:['赏牡丹','谷雨祭海','走谷雨','喝谷雨茶','贴谷雨贴','摘谷雨茶','祭仓颉','渔家祭海神','踏青','采桑','喂蚕']},'立夏':{hua:'荷花、玫瑰、石榴花',food:['立夏蛋','乌米饭','豌豆糕','五色饭','立夏虾','凉拌折耳根','绿豆汤','西瓜冻','苦菊沙拉','酒酿圆子','樱桃汤'],yang:['养心清热','健脾益胃','清热利湿','补气养血','安神助眠','润肺止咳','益肾固精','疏肝理气','消暑生津','活血通络','滋阴降火'],kepu:['立夏三候知识','立夏节气含义','立夏称人习俗','立夏物候变化','立夏斗蛋游戏','夏季养心要点','立夏气候特征','立夏饮食指南','立夏民间习俗','夏季防暑知识','立夏农事活动'],su:['立夏称人','斗蛋','喝立夏粥','迎夏仪式','吃立夏饭','尝三鲜','赏荷花','踏青','祭神农','煮蛋挂颈','吃乌米饭']},'小满':{hua:'蔷薇、石榴花、紫藤',food:['苦菜炒肉','蚕豆炒韭菜','荷叶粥','麦仁饭','凉拌苦瓜','绿豆糕','杨梅汤','薏米粥','炒莴笋','蒸茄子','苦菊沙拉'],yang:['清热利湿','健脾养胃','消暑生津','补气养血','祛风止痒','疏肝理气','润肺止咳','益肾固精','安神助眠','活血化瘀','滋阴降火'],kepu:['小满三候知识','小满节气含义','麦穗将满含义','小满物候变化','小满祭蚕神习俗','小满气候特征','小满农事活动','小满饮食指南','小满民间习俗','夏季皮肤养护','小满苦菜文化'],su:['祭车神','祈蚕节','赏小满麦','抢水','看麦梢黄','祭蚕神','磨镰刀','收蚕茧','赏荷花','夏收准备','吃苦菜']},'芒种':{hua:'栀子花、荷花、合欢花',food:['梅子酒','话梅排骨','青梅汤','鸭蛋苋菜','绿豆百合汤','荷叶蒸鱼','冬瓜排骨汤','酸梅汁','炒空心菜','芒果布丁','苦瓜黄豆排骨汤'],yang:['祛暑健脾','清热解毒','消暑生津','补气养血','安神助眠','疏肝理气','润肺止咳','益肾固精','利湿排毒','活血通络','清心降火'],kepu:['芒种三候知识','芒种节气含义','送花神习俗','芒种物候变化','芒种农事活动','芒种气候特征','芒种饮食指南','芒种民间习俗','夏季祛湿要点','煮梅文化','芒种安苗节'],su:['送花神','安苗节','打泥巴仗','煮梅','芒种祭祀','开镰收割','插秧','扎稻草人','赏荷花','吃君踏菜','祭龙王']},'夏至':{hua:'荷花、石榴花、栀子花',food:['夏至面','绿豆汤','荔枝鸭','凉拌黄瓜','薄荷绿豆粥','冬瓜汤','酸梅汤','苦瓜炒蛋','蒜泥白肉','冰镇莲子','绿茶冻'],yang:['清热消暑','养心安神','健脾祛湿','滋阴降火','益气生津','润肺止咳','疏肝理气','补肾固精','活血通络','消食导滞','清利头目'],kepu:['夏至三候知识','夏至白昼最长','夏至节气含义','夏至物候变化','夏至饮食指南','夏至民间习俗','夏至祭地文化','数九习俗由来','夏至气候特征','夏季防暑要点','夏至农事活动'],su:['祭地祭祖','吃夏至面','消夏避伏','夏至荐新','互赠扇子','祭神农','赏荷花','避暑游玩','吃凉食','喝伏茶','冬病夏治']},'小暑':{hua:'向日葵、荷花、茉莉',food:['小暑黄鳝','莲藕排骨汤','绿豆南瓜汤','蒜蓉蒸虾','冬瓜薏米汤','荷叶粉蒸肉','山楂糕','凉拌苦瓜','西瓜皮炒肉','薄荷凉茶','百合银耳汤'],yang:['消暑养心','健脾祛湿','清热解毒','益气生津','滋阴降火','润肺止咳','疏肝理气','补肾固精','安神助眠','活血通络','清利头目'],kepu:['小暑三候知识','小暑节气含义','小暑物候变化','小暑气候特征','伏天养生要点','小暑饮食指南','小暑民间习俗','夏季祛湿要点','晒伏习俗由来','小暑黄鳝文化','三伏天知识'],su:['小暑晒伏','吃暑羊','封斋','小暑吃饺子','赏荷花','喝伏茶','吃仙草','贴三伏贴','游泳避暑','祭祀土地神','消夏活动']},'大暑':{hua:'荷花、凤仙花、千日红',food:['大暑羊肉汤','仙草冻','荷叶饭','绿豆百合粥','冬瓜老鸭汤','姜汁撞奶','烫鸭血','凉拌三丝','薏米绿豆汤','龙眼肉粥','酸梅汤'],yang:['清热解暑','养心安神','健脾祛湿','益气生津','滋阴降火','润肺止咳','补肾固精','活血通络','消食导滞','疏肝理气','清利头目'],kepu:['大暑三候知识','大暑节气含义','大暑物候变化','大暑气候特征','三伏天养生','大暑饮食指南','大暑民间习俗','大暑送船习俗','冬病夏治原理','大暑农事活动','大暑防中暑'],su:['大暑送大暑船','吃仙草','斗蟋蟀','喝伏茶','晒伏姜','贴三伏贴','冬病夏治','游泳纳凉','祭祀土地','喝羊肉汤','赏荷花']},'立秋':{hua:'秋菊、桂花、芙蓉',food:['贴秋膘红烧肉','秋梨膏','百合莲子粥','白果炖鸡','银耳红枣汤','秋葵炒虾仁','山药排骨汤','核桃芝麻糊','鸭子汤','桂花藕','莲藕炖牛腩'],yang:['润肺养阴','健脾益胃','补气养血','滋阴润燥','养肝明目','益肾固精','疏肝解郁','安神助眠','活血通络','清热解毒','温中散寒'],kepu:['立秋三候知识','立秋节气含义','贴秋膘习俗','立秋物候变化','立秋气候特征','秋季养肺要点','立秋饮食指南','立秋民间习俗','秋季防燥知识','立秋农事活动','啃秋习俗由来'],su:['贴秋膘','咬秋','摸秋','晒秋','啃瓜','秋社祭祀','收获庆典','祭神农','尝新','晒秋粮','赏秋菊']},'处暑':{hua:'桂花、菊花、芙蓉',food:['处暑鸭肉','冰糖银耳羹','沙参玉竹老鸭汤','百合炒西芹','莲藕绿豆汤','花生红枣汤','秋葵炒鸡蛋','扁豆焖饭','雪梨汤','山楂糕','秋梨膏'],yang:['润燥养肺','健脾益胃','滋阴降火','补气养血','养肝明目','益肾固精','疏肝解郁','安神助眠','清热利湿','活血通络','温中散寒'],kepu:['处暑三候知识','处暑节气含义','处暑物候变化','处暑气候特征','秋燥养生要点','处暑饮食指南','处暑民间习俗','开渔节文化','处暑农事活动','秋季防病知识','处暑放河灯习俗'],su:['出游迎秋','祭祖','放河灯','开渔节','吃鸭子','晒秋粮','秋收准备','赏秋色','祭祀土地','喝处暑茶','泡温泉']},'白露':{hua:'菊花、芙蓉、秋海棠',food:['白露米酒','龙眼米粥','薏米红豆粥','银耳百合汤','白果粥','南瓜饼','核桃仁炒韭菜','枸杞炖鸡','花生猪脚汤','冰糖炖雪梨','板栗烧鸡'],yang:['润肺益气','养阴润燥','健脾益胃','补气养血','养肝明目','益肾固精','疏肝解郁','安神助眠','清热利湿','活血通络','温补肾阳'],kepu:['白露三候知识','白露节气含义','白露物候变化','白露气候特征','秋季养肺要点','白露饮食指南','白露民间习俗','白露收露水习俗','白露农事活动','秋季防病知识','白露米酒文化'],su:['收清露','祭禹王','喝白露茶','酿白露酒','吃龙眼','祭祀月神','赏秋菊','采茶','晒秋','秋收庆典','赏桂花']},'秋分':{hua:'菊花、桂花、芙蓉',food:['秋分汤圆','螃蟹','南瓜饼','板栗红烧肉','山药玉米排骨汤','枸杞炖鸡','银耳莲子羹','芋头焖鸭','红薯粥','石榴汁','菊花茶'],yang:['滋阴润燥','健脾益胃','补气养血','养肝明目','益肾固精','润肺止咳','疏肝解郁','安神助眠','清热利湿','温中散寒','活血通络'],kepu:['秋分昼夜等长','秋分三候知识','秋分节气含义','秋分物候变化','秋分祭月习俗','秋分气候特征','秋分饮食指南','秋分民间习俗','秋季养生要点','秋分农事活动','竖蛋习俗'],su:['秋祭月','吃秋菜','送秋牛','粘雀子嘴','放风筝','赏菊花','赏桂花','吃螃蟹','秋收庆典','祭祀土地','祭神农']},'寒露':{hua:'菊花、茱萸、枫叶',food:['寒露芝麻','菊花螃蟹','山药粥','核桃仁炒鸡丁','桂花糯米藕','红薯姜汤','银耳莲子百合汤','花生猪蹄汤','枸杞炖羊肉','板栗粥','柿饼'],yang:['养阴润燥','健脾益胃','补气养血','温补肾阳','养肝明目','润肺止咳','疏肝解郁','安神助眠','益肾固精','温中散寒','活血通络'],kepu:['寒露三候知识','寒露节气含义','寒露物候变化','寒露气候特征','寒露登高习俗','寒露饮食指南','寒露民间习俗','重阳节文化','寒露农事活动','秋季养肺要点','寒露防寒知识'],su:['登高望远','赏菊','喝菊花酒','斗蛐蛐','吃花糕','插茱萸','赏枫叶','秋收庆典','祭祀祖先','放风筝','赏芙蓉']},'霜降':{hua:'菊花、枫叶、山茶',food:['霜降柿子','羊肉萝卜汤','栗子炖鸡','芋头煮鸭','南瓜羹','腌菜','红薯糯米饼','板栗烧排骨','山楂糕','萝卜炖牛腩','枸杞菊花茶'],yang:['润燥补肾','健脾益胃','温阳散寒','补气养血','养肝明目','润肺止咳','疏肝解郁','安神助眠','益肾固精','活血通络','温中健胃'],kepu:['霜降三候知识','霜降节气含义','霜降物候变化','霜降气候特征','霜降吃柿子习俗','霜降饮食指南','霜降民间习俗','秋末进补知识','霜降农事活动','冬前养生要点','霜降赏菊文化'],su:['吃柿子','登高','赏菊花','扫墓祭祖','进补','腌制腊味','晒萝卜干','赏枫叶','收获庆典','祭祀土地','备冬粮食']},'立冬':{hua:'腊梅、山茶、菊花',food:['立冬饺子','羊肉火锅','糯米糕','红烧牛肉','腊八豆腐','冬笋炒腊肉','核桃粥','当归羊肉汤','姜枣红糖汤','腊肉炒蒜苗','八宝饭'],yang:['温补肾阳','健脾益胃','补气养血','驱寒暖身','养肝护肝','润肺止咳','疏肝解郁','安神助眠','益肾固精','温中散寒','活血通络'],kepu:['立冬三候知识','立冬节气含义','立冬物候变化','立冬气候特征','立冬进补知识','立冬饮食指南','立冬民间习俗','冬季养肾要点','立冬农事活动','冬季防寒知识','立冬吃饺子习俗'],su:['吃饺子','冬泳','补冬进补','祭祀冬神','腌菜','腌腊肉','备冬粮','赏冬景','祭祀祖先','围炉取暖','储存冬菜']},'小雪':{hua:'腊梅、水仙、松柏',food:['小雪腊肉','糍粑','萝卜炖羊肉','红薯姜汤','芝麻糊','腊肠炒饭','南瓜饼','红枣桂圆粥','黑芝麻汤圆','核桃仁炒虾仁','腊味煲仔饭'],yang:['温肾补阳','健脾益胃','补气养血','驱寒暖身','润肺止咳','养肝护肝','安神助眠','益肾固精','温中散寒','活血通络','滋阴润燥'],kepu:['小雪三候知识','小雪节气含义','小雪物候变化','小雪气候特征','腌腊肉习俗','小雪饮食指南','小雪民间习俗','冬季养肾要点','小雪农事活动','冬季防病知识','小雪糍粑文化'],su:['腌腊肉','吃糍粑','晒鱼干','酿小雪酒','腌咸菜','备冬粮','围炉取暖','赏雪景','祭祀祖先','腌制咸货','制作腊味']},'大雪':{hua:'腊梅、松柏、水仙',food:['大雪羊蝎子','腊八粥','冬笋炒腊肉','红薯饼','萝卜牛腩汤','核桃枣糕','腌腊肉','姜汁红薯汤','黑豆炖猪蹄','糖醋萝卜','羊肉串'],yang:['温补强身','健脾益胃','补气养血','驱寒暖身','润肺止咳','益肾固精','温中散寒','活血通络','安神助眠','疏肝理气','滋阴润燥'],kepu:['大雪三候知识','大雪节气含义','大雪物候变化','大雪气候特征','大雪进补知识','大雪饮食指南','大雪民间习俗','冬季养生要点','大雪农事活动','冬季防寒知识','大雪滑冰文化'],su:['腌肉腊味','滑冰','大雪进补','赏雪景','堆雪人','备年货','围炉取暖','祭祀祖先','腌制腊味','储存冬粮','制作年货']},'冬至':{hua:'腊梅、水仙、山茶',food:['冬至饺子','当归羊肉汤','汤圆','八宝粥','黑芝麻糊','冬至姜鸭','核桃黑豆粥','莲藕炖排骨','红糖姜汤圆','糯米红枣糕','赤豆粥'],yang:['温阳补肾','补气养血','驱寒暖身','健脾益胃','润肺滋阴','补肝护眼','养心安神','益肾固精','温中散寒','活血通络','疏肝理气'],kepu:['冬至三候知识','冬至阴气最盛','冬至节气含义','冬至物候变化','冬至进补知识','冬至饮食指南','冬至民间习俗','数九习俗由来','冬至农事活动','冬季养肾要点','冬至祭祖文化'],su:['祭天祭祖','数九计寒','家人团聚','吃饺子汤圆','冬至进补','赏冬景','围炉取暖','祭社神','腌腊味','喝羊汤','冬泳']},'小寒':{hua:'腊梅、山茶、水仙',food:['腊八粥','羊肉萝卜汤','糖炒栗子','腊肉炒饭','红枣桂圆粥','芝麻糊','姜汁撞奶','腊味煲仔饭','核桃仁炒腰花','黑豆炖猪蹄','肉桂姜茶'],yang:['驱寒暖身','温肾补阳','健脾益胃','补气养血','润肺止咳','养肝护肝','安神助眠','益肾固精','温中散寒','活血通络','疏肝理气'],kepu:['小寒三候知识','小寒最冷时节','小寒节气含义','小寒物候变化','腊八节文化','小寒饮食指南','小寒民间习俗','冬季养肾要点','小寒农事活动','冬季防寒知识','小寒进补知识'],su:['腊祭','糊窗','腊八节喝腊八粥','冰上活动','准备年货','祭祀祖先','围炉取暖','腌腊味','储存冬粮','赏腊梅','备年货']},'大寒':{hua:'腊梅、水仙、梅花',food:['大寒八宝饭','年糕','腊味饭','萝卜羊肉汤','糯米糍','腊肠炒饭','红糖糍粑','桂圆枣糕','腊八豆腐','姜撞奶','红豆年糕'],yang:['温补固本','健脾益胃','补气养血','驱寒暖身','润肺止咳','益肾固精','温中散寒','活血通络','安神助眠','疏肝理气','养肝护肝'],kepu:['大寒三候知识','大寒节气含义','大寒物候变化','大寒气候特征','大寒进补知识','大寒饮食指南','大寒民间习俗','冬季养生要点','大寒农事活动','尾牙习俗文化','大寒备年货'],su:['尾牙祭','打年糕','腌年货','赶年集','祭灶神','扫尘','备年货','围炉取暖','祭祀祖先','赏腊梅','腌腊味']}};
const LABELS={0:{title:'第三步 — 选择养生方向',desc:'点击选择养生主题，或在下方自定义输入',ph:'输入其他养生方向，如：强筋健骨、温经通络…',key:'yang'},1:{title:'第三步 — 选择节气美食',desc:'点击选择内置美食，或在下方自定义输入',ph:'输入其他美食名称，如：腊八蒜、糖炒栗子…',key:'food'},2:{title:'第三步 — 选择科普主题',desc:'点击选择知识点，或在下方自定义输入',ph:'输入其他科普主题，如：节气与农耕关系…',key:'kepu'},3:{title:'第三步 — 选择习俗主题',desc:'点击选择传统习俗，或在下方自定义输入',ph:'输入其他习俗，如：舞龙舞狮、祈福活动…',key:'su'}};

function getItems(jq,d){const key=LABELS[d].key;if(jq&&DATA[jq])return DATA[jq][key]||DEF[d];return DEF[d];}
function toggleManual(){const b=document.getElementById('manual-body'),a=document.getElementById('manual-arrow'),o=b.classList.toggle('open');a.classList.toggle('open',o);}
function selJQ(name){curJQ=name;document.querySelectorAll('#jq-chips .chip').forEach(c=>{const on=c.textContent===name;c.classList.toggle('active',on);});selItem='';document.getElementById('custom-input').value='';if(selD>=0)renderChips(name,selD);}
function selDir(i){selD=i;[0,1,2,3].forEach(idx=>{const b=document.getElementById('d'+idx);b.classList.toggle('active',idx===i);b.style.borderColor=idx===i?C[idx]:'';b.style.borderWidth=idx===i?'2px':'';b.style.background=idx===i?'#faf6ee':'';});selItem='';document.getElementById('custom-input').value='';const lb=LABELS[i];document.getElementById('sel-title').textContent=lb.title;document.getElementById('sel-desc').textContent=lb.desc;document.getElementById('custom-input').placeholder=lb.ph;document.getElementById('sel-box').style.display='block';renderChips(curJQ,i);}
function renderChips(jq,d){const items=getItems(jq,d),show=items.slice(0,6),container=document.getElementById('sel-chips');container.innerHTML='';selItem='';show.forEach(f=>{const chip=document.createElement('span');chip.className='sel-chip';chip.textContent=f;chip.onclick=()=>{document.querySelectorAll('.sel-chip').forEach(c=>{c.classList.remove('selected');c.style.background='';});chip.classList.add('selected');chip.style.background=C[d];selItem=f;document.getElementById('custom-input').value='';};container.appendChild(chip);});}
function so(i){activeTab=i;[0,1].forEach(idx=>{const t=document.getElementById('ot'+idx);t.classList.toggle('active',idx===i);t.style.borderBottomColor=idx===i&&selD>=0?C[selD]:idx===i?'#c07830':'transparent';document.getElementById('o'+idx).style.display=idx===i?'block':'none';});document.getElementById('tips').style.display=i===1?'block':'none';}
function gen(){if(!curJQ){document.getElementById('o0').innerHTML='<span class="placeholder">请先选择节气～</span>';return;}if(selD<0){document.getElementById('o0').innerHTML='<span class="placeholder">请先选择创作方向～</span>';return;}const custom=document.getElementById('custom-input').value.trim(),items=getItems(curJQ,selD),item=custom||selItem||items[Math.floor(Math.random()*Math.min(items.length,6))],d=DATA[curJQ],hua=d?d.hua:'应季花卉',su=d?d.su:['传统习俗'];ct[0]=getImg(selD,curJQ,item,hua,su);ct[1]=getCopy(selD,curJQ,item);document.getElementById('o0').textContent=ct[0];document.getElementById('o1').textContent=ct[1];[0,1].forEach(idx=>{document.getElementById('ot'+idx).style.borderBottomColor=idx===activeTab?C[selD]:'transparent';});}
function doCopy(){const text=ct[activeTab];if(!text)return;navigator.clipboard.writeText(text).then(()=>{const b=document.getElementById('copybtn');b.textContent='已复制 ✓';setTimeout(()=>b.textContent='复制提示词',1800);});}

function getImg(d,t,item,hua,su){return[
`水彩手绘风格，复古做旧泛黄宣纸背景（带自然水渍晕染痕迹），竖版3:4构图，"${t}·${item}养生指南"插画。\n\n⚠️严格禁止：画面中不得出现任何结构说明文字，包括"标题区""物候区""养生区""贴士区"等标注词，只画内容本身。\n\n画面从上到下包含以下内容：\n\n顶部卷轴区：仿古书卷展开样式，毛笔书法字体写"${t}·${item}"，两侧配${hua}手绘装饰，整体撑满顶部。\n\n物候展示区：细线描边矩形边框，左上角红色印章刻"${t}物候"四字。横向展示该节气真实三候自然现象，每候：上方手绘对应自然景象（动植物/气候），下方写候名和简短描述，全部中文。\n\n养生展示区：细线描边矩形边框，左上角红色印章刻"${item}"三字。\n- 上半部分：${item}对应的3种养生食材，每种手绘实物插图+中文名称+精确克数+功效（如：薏米20克·利水渗湿）\n- 下半部分：3步养生做法，每步配手绘器具图（青花瓷碗花纹细腻、玻璃茶壶通透）\n\n底部横幅区：仿古卷轴横幅，★★★星星装饰，写"${t}养生要点：${item}·顺时而食·阴阳调和"\n\n整体：米黄赭石草木绿砖红主色调，水彩晕染自然，全程纯中文无任何英文，所有文字内容真实准确无错别字。`,
`可爱卡通手绘风格，"${t}·${item}手绘食谱"完整竖版长图，比例2:3，整体像手写私房菜谱，不是打印表格。\n\n⚠️严格禁止：画面中不得出现任何结构说明文字，包括"标题区""食材战袍区""制作步骤区""完成图区""小贴士区"等标注词，只画内容本身，这些词绝对不能出现在画面任何位置。\n\n画面从上到下包含以下内容：\n\n标题部分：大标题"${t}·${item}"马克笔圆润手写风，两侧配${hua}拟人装饰带笑脸，副标题"${t}必吃！应季传统美食做起来"，星星爱心装饰。\n\n食材部分：圆角矩形框内写"食材战袍"四字标题（注意：只写"食材战袍"这个标题本身，不写"食材战袍区"）。展示${item}所需真实食材，每种：手绘实物插图带可爱表情，下方中文名+精确用量，全部中文禁止英文，禁止"适量""少许"。\n\n步骤部分：写"制作步骤"四字标题（注意：只写"制作步骤"，不写"制作步骤区"）。展示${item}真实制作步骤3-5步，每步独占一整行纵向往下，禁止横向并排。每步：圆圈编号+拟人步骤标题+大尺寸锅具插图（占70%，火焰在锅底，油烟蒸汽曲线）+火候时间小标签+底部12字内说明。步骤间向下虚线箭头。\n\n完成图部分：独占完整一行宽度撑满，${item}成品大图居中色泽诱人，配${t}节气场景装饰，"完成！开吃啦！"大字+星星爱心。\n\n小贴士部分：圆角气泡横幅宽度撑满，写"小贴士"三字标题（不写"小贴士区"），①②③格式写${item}实用贴士，全部中文禁止英文。\n\n整体：背景米白奶油色，两侧留白不超过5%，线条圆润手绘感，所有文字准确无英文。`,
`可爱卡通插画风格，"${t}·${item}"节气知识科普信息图，竖版3:4构图，马卡龙配色，一图看懂系列。\n\n⚠️严格禁止：画面中不得出现任何结构说明文字，只画内容本身。\n\n⚠️严格要求：所有文字内容必须是关于"${t}"节气和"${item}"的真实准确信息，禁止出现乱码、错别字、或与主题无关的内容。\n\n画面从上到下包含以下内容：\n\n标题部分：书名号格式大标题《${t}·${item}》，字体圆润，下方彩虹渐变缎带写"一图看懂（节气科普）"，四角配${hua}自然元素装饰。\n\n三格导读条：横向三个圆角矩形（淡粉/浅蓝/嫩绿），每格：Q版小图标+关键词+简短说明，内容分别是：①${t}时间和季节 ②${item}核心含义 ③养生应用方向。\n\n点题语：云朵形气泡框写一句话："${t}到了，关于${item}你需要知道这些！"\n\n四格知识点：标题"核心知识点"，下方2×2排列四个圆角矩形（淡粉/浅蓝/嫩绿/鹅黄各一格），每格内容：\n- 第①格：${item}的基本含义，配相关Q版插图，文字简洁准确\n- 第②格：${item}与${t}节气的关系，配节气自然景象Q版插图\n- 第③格：${item}的实际应用方法，配生活场景Q版插图\n- 第④格：${item}的注意事项，配提示性Q版插图\n每格文字必须简洁、真实、与主题直接相关，禁止出现乱码。\n\n关系图：写"了解${t}·${item}=四件事"，中心圆+四方向要素+Q版插图+虚线箭头，全部中文。\n\n底部双栏：左栏"避坑清单"红色系+×图标3条真实建议，右栏"实用建议"绿色系+✓图标3条真实建议。\n\n整体：米白奶油背景，马卡龙四色，Q版插图丰富，全程纯中文无任何英文字母，所有内容真实准确。`,
`古风工笔插画风格，"${t}·${item}图鉴"长图，竖版2:3构图，米黄绢布底色，卷轴装帧感。\n\n⚠️严格禁止：画面中不得出现任何结构说明文字，只画内容本身。\n\n画面从上到下包含以下内容：\n\n顶部卷轴：仿古书卷展开样式，卷轴两端可见卷起效果。主标题大字"${t}·${item}"毛笔楷书风格，副标题"一眼看懂·千年风俗"，两侧配${hua}传统纹样装饰。\n\n习俗展示：以"${item}"为核心，依次展示${t}节气相关习俗：${su.slice(0,4).join('、')}\n每个习俗：\n- 左侧：工笔场景插图，人物衣纹器物纹饰细绘，颜色朱砂红/青绿/赭石/靛蓝点缀\n- 右侧：习俗名称（大字）+ 由来简介2-3行 + 各地差异一句话\n- 左右内容完全不同，禁止两侧出现相同文字\n- 各习俗之间用传统回纹或云纹分隔线隔开\n\n诗词区：展示与"${t}"相关的1-2首真实经典古诗词，工笔小插图配合诗意，仿宋体排列，诗词内容必须真实准确。\n\n底部卷轴横幅：一句文言风格点题总结，两侧传统纹样装饰。\n\n整体：米黄绢布底色带做旧质感，墨色线条勾勒，庄重典雅，全程纯中文无英文，习俗和诗词内容历史准确。`
][d];}

function getCopy(d,t,item){
  const dirs=['养生指南','手绘食谱','知识科普','习俗图鉴'];
  const dir = dirs[d] || '内容';
  return[
`你是一位擅长三平台运营的AIGC内容创作者。
我刚刚用AI生成了一张「${t}·${item}${dir}」图，请根据图片内容同时输出三平台配套文案：

【视频号文案】
- 标题：1个，不超过20字，突出节气特色
- 正文：150字，口语化，有节气氛围感，有共鸣感
- 结尾：引导点赞收藏转发

【三平台文案】
- 备选标题：3个，带emoji（🌿🍵✨），有收藏冲动，不超过20字
- 正文：200字，口语化，节气+${item}内容，闺蜜分享感
- 结尾：引导收藏+评论互动
- 话题标签：10个，含 #${t}养生 #${item} #节气养生 #中医养生 #养生日常

【抖音文案】
- 备选标题：3个，带emoji，有点击欲，不超过20字
- 正文：150字，节奏感强，节气特色突出
- 结尾：引导点赞收藏关注
- 话题标签：8个`,
`你是一位擅长三平台运营的AIGC内容创作者。
我刚刚用AI生成了一张「${t}·${item}手绘食谱」图，请根据图片内容同时输出三平台配套文案：

【视频号文案】
- 标题：1个，不超过20字，突出应季好吃
- 正文：150字，口语化，烟火气足，有共鸣感
- 结尾：引导点赞收藏转发

【三平台文案】
- 备选标题：3个，带emoji（🍳🔥😋），有收藏冲动，不超过20字
- 正文：200字，口语化，应季食材+做法+亮点
- 结尾：引导收藏+评论
- 话题标签：10个，含 #${t}必吃 #${item}做法 #应季食材 #家常菜

【抖音文案】
- 备选标题：3个，带emoji，有点击欲，不超过20字
- 正文：150字，节奏感强
- 结尾：引导点赞收藏关注
- 话题标签：8个`,
`你是一位擅长三平台运营的AIGC内容创作者。
我刚刚用AI生成了一张「${t}·${item}」知识科普图，请根据图片内容同时输出三平台配套文案：

【视频号文案】
- 标题：1个，不超过20字，知识感+节气特色
- 正文：150字，口语化，涨知识感
- 结尾：引导点赞收藏转发

【三平台文案】
- 备选标题：3个，带emoji（📚✨💡），有收藏冲动，不超过20字
- 正文：200字，口语化，节气知识感
- 结尾：引导收藏+评论互动
- 话题标签：10个，含 #${t} #${item} #节气科普 #涨知识 #一图看懂

【抖音文案】
- 备选标题：3个，带emoji，有点击欲，不超过20字
- 正文：150字，节奏感强
- 结尾：引导点赞收藏关注
- 话题标签：8个`,
`你是一位擅长三平台运营的AIGC内容创作者。
我刚刚用AI生成了一张「${t}·${item}」习俗图鉴图，请根据图片内容同时输出三平台配套文案：

【视频号文案】
- 标题：1个，不超过20字，传统文化感+吸引力
- 正文：150字，口语化，有文化共鸣感
- 结尾：引导点赞收藏转发

【三平台文案】
- 备选标题：3个，带emoji（🏮🎎✨），有收藏冲动，不超过20字
- 正文：200字，口语化，传统习俗故事感
- 结尾：引导收藏+评论互动
- 话题标签：10个，含 #${t} #${item} #传统习俗 #中国文化 #涨知识

【抖音文案】
- 备选标题：3个，带emoji，有点击欲，不超过20字
- 正文：150字，节奏感强
- 结尾：引导点赞收藏关注
- 话题标签：8个`
  ][d];
}
</script>

<div style="text-align:center;padding:24px 20px;border-top:1px solid #e0cfa8;margin-top:24px;background:#faf6ef">
  <div style="font-size:14px;font-weight:700;color:#1a0a00;letter-spacing:3px;margin-bottom:6px;font-family:'PingFang SC','Microsoft YaHei',serif">📜 阿坚AIGC · 工具中心</div>
  <div style="font-size:11px;color:#6a4a20;letter-spacing:1px;line-height:2">廿四节气图文工坊<br>版权所有 © 阿坚AIGC · 仅供授权用户个人创作使用 · 禁止商业转载与二次分发</div>
</div>
</body>
</html>

<!DOCTYPE html>
<html lang="zh-CN">
<head>
<meta charset="UTF-8">
<meta name="viewport" content="width=device-width, initial-scale=1.0">
<title>历史文化图文工坊 · V1.0</title>
<style>
@import url('https://fonts.googleapis.com/css2?family=Noto+Serif+SC:wght@400;600;700&family=Noto+Sans+SC:wght@300;400;500&display=swap');
*{box-sizing:border-box;margin:0;padding:0}
body{font-family:'Noto Sans SC',sans-serif;background:#fdf5e8;min-height:100vh;color:#2c1a0e}
.page{max-width:780px;margin:0 auto;padding:20px 16px 60px}

/* HEADER */
.hdr{background:linear-gradient(135deg,#1a0a04 0%,#3d1f0a 50%,#1a0a04 100%);border-radius:16px;padding:36px 24px 28px;text-align:center;margin-bottom:20px;position:relative;overflow:hidden}
.hdr::before{content:'';position:absolute;inset:0;background-image:repeating-linear-gradient(45deg,rgba(255,255,255,.025) 0,rgba(255,255,255,.025) 1px,transparent 0,transparent 50%);background-size:14px 14px}
.hdr-badge{display:inline-block;border:1px solid rgba(196,154,60,0.5);color:#c49a3c;font-size:10px;letter-spacing:3px;padding:4px 14px;border-radius:20px;margin-bottom:14px;position:relative}
.hdr h1{font-family:'Noto Serif SC',serif;font-size:28px;font-weight:700;color:#fff;letter-spacing:4px;position:relative;margin-bottom:6px}
.hdr-sub{color:rgba(255,255,255,0.55);font-size:13px;letter-spacing:1px;position:relative}
.hdr-line{width:60px;height:1px;background:linear-gradient(90deg,transparent,#c49a3c,transparent);margin:14px auto}
.hdr-tags{display:flex;flex-wrap:wrap;justify-content:center;gap:8px;margin-top:14px;position:relative}
.hdr-tag{background:rgba(196,154,60,0.15);border:1px solid rgba(196,154,60,0.3);color:#e8c87a;font-size:11px;padding:4px 12px;border-radius:12px}

/* MANUAL */
.manual-wrap{background:#fff9f0;border:1px solid #e8d5b0;border-radius:12px;margin-bottom:16px;overflow:hidden}
.manual-hdr{display:flex;align-items:center;justify-content:space-between;padding:14px 18px;cursor:pointer;user-select:none}
.manual-hdr-left{display:flex;align-items:center;gap:10px}
.manual-icon{width:28px;height:28px;background:linear-gradient(135deg,#3d1f0a,#5c3317);border-radius:8px;display:flex;align-items:center;justify-content:center;font-size:14px}
.manual-title{font-family:'Noto Serif SC',serif;font-size:15px;font-weight:600;color:#3d1f0a}
.manual-sub{font-size:11px;color:#8b5e3c;margin-top:1px}
.manual-arrow{font-size:12px;color:#8b5e3c;transition:transform .3s;display:inline-block}
.manual-arrow.open{transform:rotate(180deg)}
.manual-body{display:none;padding:0 18px 18px}
.manual-body.open{display:block}
.step-list{counter-reset:step}
.step-item{display:flex;gap:14px;margin-bottom:16px;padding-bottom:16px;border-bottom:1px dashed #e8d5b0}
.step-item:last-child{border-bottom:none;margin-bottom:0;padding-bottom:0}
.step-num{width:28px;height:28px;background:linear-gradient(135deg,#5c3317,#8b5e3c);border-radius:50%;color:#fff;font-size:12px;font-weight:700;display:flex;align-items:center;justify-content:center;flex-shrink:0;margin-top:2px}
.step-content h4{font-size:13px;font-weight:600;color:#3d1f0a;margin-bottom:4px}
.step-content p{font-size:12px;color:#5c3317;line-height:1.7}
.step-tip{background:rgba(196,154,60,0.1);border-left:3px solid #c49a3c;border-radius:0 6px 6px 0;padding:8px 12px;margin-top:8px;font-size:11px;color:#5c3317;line-height:1.6}
.workflow{background:linear-gradient(135deg,rgba(92,51,23,0.06),rgba(196,154,60,0.06));border:1px solid #e8d5b0;border-radius:10px;padding:14px;margin-top:14px}
.workflow-title{font-size:12px;font-weight:600;color:#3d1f0a;margin-bottom:10px;letter-spacing:1px}
.workflow-steps{display:flex;align-items:center;flex-wrap:wrap;gap:6px}
.wf-step{background:#fff9f0;border:1px solid #d4b896;border-radius:6px;padding:6px 10px;font-size:11px;color:#5c3317;white-space:nowrap}
.wf-arrow{color:#c49a3c;font-size:12px}

/* FAQ */
.faq-wrap{background:#fff9f0;border:1px solid #e8d5b0;border-radius:12px;margin-bottom:16px;overflow:hidden}
.faq-hdr{display:flex;align-items:center;justify-content:space-between;padding:14px 18px;cursor:pointer;user-select:none}
.faq-hdr-left{display:flex;align-items:center;gap:10px}
.faq-icon{width:28px;height:28px;background:linear-gradient(135deg,#2e6da4,#185fa5);border-radius:8px;display:flex;align-items:center;justify-content:center;font-size:14px}
.faq-title{font-family:'Noto Serif SC',serif;font-size:15px;font-weight:600;color:#3d1f0a}
.faq-body{display:none;padding:0 18px 18px}
.faq-body.open{display:block}
.faq-item{margin-bottom:14px;padding-bottom:14px;border-bottom:1px dashed #e8d5b0}
.faq-item:last-child{border-bottom:none;margin-bottom:0;padding-bottom:0}
.faq-q{display:flex;align-items:flex-start;gap:8px;margin-bottom:6px}
.faq-q-badge{background:#5c3317;color:#fff;font-size:10px;padding:2px 7px;border-radius:4px;white-space:nowrap;margin-top:1px}
.faq-q-text{font-size:13px;font-weight:600;color:#3d1f0a;line-height:1.5}
.faq-a{display:flex;align-items:flex-start;gap:8px}
.faq-a-badge{background:rgba(196,154,60,0.2);color:#8b5e3c;font-size:10px;padding:2px 7px;border-radius:4px;white-space:nowrap;margin-top:1px}
.faq-a-text{font-size:12px;color:#5c3317;line-height:1.7}

/* MAIN TOOL */
.tool-wrap{background:#fff9f0;border:1px solid #e8d5b0;border-radius:12px;padding:20px}
.sl{font-size:10px;letter-spacing:2px;color:#8b5e3c;font-weight:700;margin-bottom:10px;text-transform:uppercase}
.form-row{margin-bottom:18px}
.tog{display:flex;gap:8px}
.tb{flex:1;padding:11px;border:1px solid #d4b896;background:#fff;border-radius:8px;cursor:pointer;font-size:13px;color:#5c3317;font-family:'Noto Sans SC',sans-serif;transition:all .2s;text-align:center}
.tb.active{background:#5c3317;color:#fff;border-color:#5c3317}
.tg{display:grid;grid-template-columns:repeat(3,1fr);gap:8px}
.tc{border:1px solid #d4b896;background:#fff;border-radius:8px;padding:10px 8px;cursor:pointer;text-align:center;transition:all .15s;font-family:'Noto Sans SC',sans-serif}
.tc:hover{border-color:#8b5e3c;background:#fef3e2}
.tc.active{border-color:#5c3317;background:#5c3317;color:#fff}
.tc .icon{font-size:18px;margin-bottom:4px;display:block}
.tc .name{font-size:12px;font-weight:600}
.tc .desc{font-size:10px;opacity:.7;margin-top:2px}
.tags{display:flex;flex-wrap:wrap;gap:6px;margin-bottom:10px}
.tag{padding:5px 12px;border:1px solid #d4b896;border-radius:20px;font-size:12px;cursor:pointer;background:#fff;color:#5c3317;font-family:'Noto Sans SC',sans-serif;transition:all .15s}
.tag:hover{border-color:#8b5e3c}
.tag.active{background:#8b5e3c;color:#fff;border-color:#8b5e3c}
.ci{width:100%;border:1px solid #d4b896;background:#fff;border-radius:8px;padding:10px 12px;font-size:13px;color:#2c1a0e;font-family:'Noto Sans SC',sans-serif;outline:none}
.ci:focus{border-color:#8b5e3c}
.cr{display:flex;gap:8px}
.cb{flex:1;padding:8px 4px;border:1px solid #d4b896;background:#fff;border-radius:6px;cursor:pointer;font-size:13px;color:#5c3317;font-family:'Noto Sans SC',sans-serif;text-align:center;transition:all .15s}
.cb.active{background:#c49a3c;color:#fff;border-color:#c49a3c}
.gb{width:100%;padding:14px;background:linear-gradient(135deg,#3d1f0a,#5c3317);color:#fff;border:none;border-radius:8px;font-size:15px;font-family:'Noto Serif SC',serif;letter-spacing:2px;cursor:pointer;transition:all .2s}
.gb:hover{background:linear-gradient(135deg,#5c3317,#7a4520);transform:translateY(-1px)}
.out{margin-top:20px;display:none}
.otabs{display:flex;border-bottom:2px solid #d4b896;margin-bottom:16px}
.otab{padding:10px 16px;cursor:pointer;font-size:13px;color:#8b5e3c;font-family:'Noto Sans SC',sans-serif;border-bottom:2px solid transparent;margin-bottom:-2px;transition:all .2s;white-space:nowrap}
.otab.active{color:#3d1f0a;border-bottom-color:#5c3317;font-weight:600}
.op{display:none}
.op.active{display:block}
.ob{background:#fff;border:1px solid #d4b896;border-radius:8px;padding:14px;font-size:12px;line-height:1.8;color:#2c1a0e;white-space:pre-wrap;font-family:'Courier New',monospace;max-height:420px;overflow-y:auto}
.cpb{margin-top:10px;padding:8px 20px;border:1px solid #8b5e3c;background:transparent;border-radius:6px;color:#8b5e3c;font-size:12px;cursor:pointer;font-family:'Noto Sans SC',sans-serif;transition:all .15s}
.cpb:hover{background:#8b5e3c;color:#fff}
.tip{background:rgba(139,94,60,0.08);border-left:3px solid #8b5e3c;border-radius:0 8px 8px 0;padding:10px 14px;margin-top:12px;font-size:11px;color:#5c3317;line-height:1.7}
.dv{height:1px;background:linear-gradient(90deg,transparent,#d4b896,transparent);margin:16px 0}
.cl{font-size:11px;color:#8b5e3c;margin-bottom:8px}

/* FOOTER */
.footer{text-align:center;margin-top:32px;font-size:11px;color:#b89878;letter-spacing:1px}
.footer span{color:#c49a3c}
</style>
</head>
<body>
<div class="page">

<!-- HEADER -->
<div class="hdr">
  <div class="hdr-badge">历史文化图文工坊 · V1.0</div>
  <h1>历史人物图文创作站</h1>
  <div class="hdr-line"></div>
  <div class="hdr-sub">正史为据 · 一键生成 · 即梦/香蕉Pro直出</div>
  <div class="hdr-tags">
    <span class="hdr-tag">12大内容赛道</span>
    <span class="hdr-tag">合集+单人双模式</span>
    <span class="hdr-tag">两步即出提示词</span>
    <span class="hdr-tag">图片+正史双输出</span>
    <span class="hdr-tag">内容真实可溯源</span>
  </div>
</div>

<!-- MANUAL -->
<div class="manual-wrap">
  <div class="manual-hdr" onclick="toggleManual()">
    <div class="manual-hdr-left">
      <div class="manual-icon">📖</div>
      <div>
        <div class="manual-title">使用手册</div>
        <div class="manual-sub">三步生成完整图文提示词，点击展开查看</div>
      </div>
    </div>
    <span class="manual-arrow" id="manual-arrow">▼</span>
  </div>
  <div class="manual-body" id="manual-body">
    <div class="step-list">
      <div class="step-item">
        <div class="step-num">1</div>
        <div class="step-content">
          <h4>选择内容形式 + 赛道 + 选题</h4>
          <p>先选<strong>合集型</strong>（多人物横向对比）或<strong>单人故事型</strong>（一人完整叙事），再选12个内容赛道中的一个，最后从热门选题中点选，或在输入框中自定义选题。</p>
          <div class="step-tip">💡 合集型会让你选人物数量（3/5/6/8/10个）；单人故事型会让你选故事节点数（4/5/6张图）。</div>
        </div>
      </div>
      <div class="step-item">
        <div class="step-num">2</div>
        <div class="step-content">
          <h4>复制①正史整理提示词 → 发给 Claude</h4>
          <p>点击「生成提示词」后，切换到「①正史整理提示词」Tab，复制内容，打开 <strong>Claude 新对话</strong>，粘贴发送。Claude 会按格式整理出：每位人物的6个情节节点 + 6句对应正史原文 + 3个标签 + 史实总结。</p>
          <div class="step-tip">💡 整理好的正史原文格式非常关键，后续图片提示词需要用到里面的信息，请完整保存。</div>
        </div>
      </div>
      <div class="step-item">
        <div class="step-num">3</div>
        <div class="step-content">
          <h4>复制②图片提示词 → 填入正史内容 → 发给即梦/香蕉Pro</h4>
          <p>切换到「②图片提示词」Tab，将第②步Claude整理的正史原文内容（人物名、朝代、标签、6句古文、史实总结）填入提示词对应位置，复制后粘贴到<strong>即梦 / 香蕉Pro</strong>，按提示词生成每张图。</p>
          <div class="step-tip">💡 建议按封面图 → 人物图（逐张）→ 汇总图的顺序生成，保持风格一致性。</div>
        </div>
      </div>
    </div>
    <div class="workflow">
      <div class="workflow-title">完整工作流</div>
      <div class="workflow-steps">
        <span class="wf-step">选选题</span>
        <span class="wf-arrow">→</span>
        <span class="wf-step">复制①提示词</span>
        <span class="wf-arrow">→</span>
        <span class="wf-step">发给 Claude 整理正史</span>
        <span class="wf-arrow">→</span>
        <span class="wf-step">复制②图片提示词</span>
        <span class="wf-arrow">→</span>
        <span class="wf-step">填入正史内容</span>
        <span class="wf-arrow">→</span>
        <span class="wf-step">发给即梦/香蕉Pro出图</span>
      </div>
    </div>
  </div>
</div>

<!-- FAQ -->
<div class="faq-wrap">
  <div class="faq-hdr" onclick="toggleFaq()">
    <div class="faq-hdr-left">
      <div class="faq-icon">❓</div>
      <div>
        <div class="faq-title">常见问题 FAQ</div>
        <div class="manual-sub">遇到问题先看这里，点击展开</div>
      </div>
    </div>
    <span class="manual-arrow" id="faq-arrow">▼</span>
  </div>
  <div class="faq-body" id="faq-body">
    <div class="faq-item">
      <div class="faq-q"><span class="faq-q-badge">Q</span><span class="faq-q-text">图片提示词里的【正史原文】怎么填？</span></div>
      <div class="faq-a"><span class="faq-a-badge">A</span><span class="faq-a-text">先用①正史整理提示词让 AI 整理好格式化内容（推荐 Claude，效果最佳；也可用 DeepSeek、豆包等按需选择），然后把每位人物的「人物名+朝代+三个标签+6句正史原文+史实总结」按提示词结构填入②图片提示词的对应位置，替换掉说明文字后再发给绘图工具。</span></div>
    </div>
    <div class="faq-item">
      <div class="faq-q"><span class="faq-q-badge">Q</span><span class="faq-q-text">生成的图片风格对不上，怎么办？</span></div>
      <div class="faq-a"><span class="faq-a-badge">A</span><span class="faq-a-text">固定风格词必须完整复制到每张图的开头，不能省略。如果用即梦，建议选即梦5.0或4.6模型生成效果更佳；如果用香蕉Pro，直接粘贴完整提示词即可，风格一致性更稳定。</span></div>
    </div>
    <div class="faq-item">
      <div class="faq-q"><span class="faq-q-badge">Q</span><span class="faq-q-text">图里出现了结构说明文字（如「标题区」「气泡框区」），怎么处理？</span></div>
      <div class="faq-a"><span class="faq-a-badge">A</span><span class="faq-a-text">这是 AI 把提示词里的说明文字画进了图里。解决方法：在提示词开头手动加一句「画面中禁止出现任何结构说明文字」，或换一次生成即可，概率性问题，多跑几次会消失。</span></div>
    </div>
    <div class="faq-item">
      <div class="faq-q"><span class="faq-q-badge">Q</span><span class="faq-q-text">Claude 整理的正史原文有错误或编造怎么办？</span></div>
      <div class="faq-a"><span class="faq-a-badge">A</span><span class="faq-a-text">①正史整理提示词已要求「禁止编造，注明史书出处」。如遇可疑内容，可在 Claude 对话中追问「请核实第X句原文出处」，Claude 会重新检索并修正。建议发布前对核心古文做一次人工核查。</span></div>
    </div>
    <div class="faq-item">
      <div class="faq-q"><span class="faq-q-badge">Q</span><span class="faq-q-text">汇总图的卡片没有标签，怎么办？</span></div>
      <div class="faq-a"><span class="faq-a-badge">A</span><span class="faq-a-text">提示词已明确要求「每个卡片同时有姓名标签和历史标签，缺一不可」。如果生成结果缺少标签，在提示词末尾追加一句「重要：左列云朵卡片和右列白底卡片必须每个都标注人物姓名和历史标签」后重新生成。</span></div>
    </div>
    <div class="faq-item">
      <div class="faq-q"><span class="faq-q-badge">Q</span><span class="faq-q-text">可以改成其他画风吗？</span></div>
      <div class="faq-a"><span class="faq-a-badge">A</span><span class="faq-a-text">可以。把②图片提示词开头的固定风格词中「粉色渐变背景」「3-4头身古风人物」等替换成你想要的风格词即可，其他结构保持不变。建议每次只改一个参数，方便定位效果差异。</span></div>
    </div>
    <div class="faq-item">
      <div class="faq-q"><span class="faq-q-badge">Q</span><span class="faq-q-text">这个工具可以分享给粉丝/学员使用吗？</span></div>
      <div class="faq-a"><span class="faq-a-badge">A</span><span class="faq-a-text">可以直接把这个 HTML 文件发给他们，在浏览器中打开即可使用，无需安装任何软件，无需联网（字体加载需要网络）。建议配合使用手册一起讲解，第一次使用跑通完整流程后上手会很快。</span></div>
    </div>
  </div>
</div>

<!-- MAIN TOOL -->
<div class="tool-wrap">
  <div class="form-row">
    <div class="sl">第一步：选择内容形式</div>
    <div class="tog">
      <div class="tb active" id="btn-c" onclick="setForm('c')">📚 合集型（多人物）</div>
      <div class="tb" id="btn-s" onclick="setForm('s')">📖 单人故事型</div>
    </div>
  </div>
  <div class="form-row">
    <div class="sl">第二步：选择内容赛道</div>
    <div class="tg" id="tg"></div>
  </div>
  <div class="form-row">
    <div class="sl">第三步：选择或自定义选题</div>
    <div class="tags" id="tags"></div>
    <input class="ci" id="ci" placeholder="" />
  </div>
  <div id="cs" class="form-row">
    <div class="cl" id="cl">人物数量</div>
    <div class="cr" id="cr"></div>
  </div>
  <button class="gb" onclick="generate()">✦ 生成提示词</button>
  <div class="out" id="out">
    <div class="dv"></div>
    <div class="otabs">
      <div class="otab active" onclick="st(0)">① 正史整理提示词</div>
      <div class="otab" onclick="st(1)">② 图片提示词</div>
      <div class="otab" onclick="st(2)">📝 三平台文案提示词</div>
    </div>
    <div class="op active" id="p0">
      <div class="ob" id="t0"></div>
      <button class="cpb" onclick="cp(0)">复制</button>
      <div class="tip">复制 → 打开 Claude 新对话 → 粘贴发送 → 得到格式化正史原文 → 再用②生成图片。</div>
    </div>
    <div class="op" id="p1">
      <div class="ob" id="t1"></div>
      <button class="cpb" onclick="cp(1)">复制</button>
      <div class="tip">把①Claude整理好的正史原文填入提示词后，复制发给即梦 / 香蕉Pro 生成图片。</div>
    </div>
    <div class="op" id="p2">
      <div class="ob" id="t2"></div>
      <button class="cpb" onclick="cp(2)">复制三平台文案提示词</button>
      <div class="tip">出完图后，把图片和这段提示词一起发给Claude → 输出视频号+小红书+抖音三套文案。</div>
    </div>
  </div>
</div>

<div class="footer">历史文化图文工坊 · V1.0 · <span>为内容创作者而生</span><br>版权所有 © <span>阿坚AIGC</span> · 仅供授权用户个人创作使用 · 禁止商业转载</div>

</div>

<script>
const TYPES=[
  {id:'emperor',icon:'👑',name:'帝王系列',desc:'昏君·悲情·亡国',col:['历史上最短命的帝王们','被迫退位的悲情皇帝们','亡国之君的末路','最年幼的皇帝们','被废黜的帝王们'],solo:['崇祯的最后一天','刘禅投降的真相','宋徽宗的亡国之路','汉献帝的悲剧一生','末代皇帝溥仪的命运']},
  {id:'general',icon:'⚔️',name:'将帅系列',desc:'名将·冤案·忠魂',col:['历史上最悲情的名将们','被冤杀的六大名将','战死沙场的英雄们','最被误解的将军们'],solo:['岳飞被害的真相','韩信被杀的经过','项羽的末路悲歌','戚继光的晚年落寞','李广难封的一生']},
  {id:'literati',icon:'📜',name:'文人才子',desc:'诗人·被贬·才女',col:['历史上最惨的诗人们','被贬文人的悲剧人生','最有才华的古代才女们','怀才不遇的文人们'],solo:['苏轼的被贬人生','屈原沉江的真相','李白的落魄晚年','司马迁的宫刑之痛']},
  {id:'women',icon:'💔',name:'历史女性',desc:'殉情·智谋·传奇',col:['历史上最刚烈的殉情女性们','宫廷中的传奇女子们','历史上最有智慧的女性们','为爱牺牲的古代美人们'],solo:['虞姬自刎的最后一夜','王昭君出塞的真相','关盼盼绝食殉情的始末','花木兰的历史原型']},
  {id:'palace',icon:'🏯',name:'宫廷权谋',desc:'后宫·权臣·争斗',col:['历史上最毒辣的后宫女人们','权倾朝野的权臣们','最残酷的宫廷政变','历史上著名的夺嫡之争'],solo:['吕后的复仇之路','武则天称帝始末','慈禧垂帘听政的真相','贾南风乱政的始末']},
  {id:'injustice',icon:'🗡️',name:'千古冤案',desc:'冤杀·平反·悲剧',col:['历史上最著名的六大冤案','被冤杀的忠臣们','千古奇冤大盘点'],solo:['岳飞冤案的真相','商鞅被车裂的始末','于谦被杀的经过','伍子胥被赐死的经过']},
  {id:'mystery',icon:'💀',name:'历史悬案',desc:'谜案·未解·争议',col:['历史上六大千古谜案','至今未解的历史悬案们','最神秘的帝王死亡之谜'],solo:['雍正暴毙之谜','秦始皇真实死因','朱允炆下落之谜','光绪帝死亡真相']},
  {id:'warlord',icon:'🔥',name:'乱世枭雄',desc:'割据·争霸·传奇',col:['三国最猛的武将们','乱世中崛起的枭雄们','最悲壮的乱世英雄们'],solo:['曹操的真实面目','吕布的悲剧人生','袁绍败亡的真相','朱温的篡唐始末']},
  {id:'empress',icon:'👸',name:'传奇女帝',desc:'女性掌权·传奇',col:['中国历史上女性掌权者们','最有权势的太后们','能征善战的女将军们'],solo:['武则天称帝的全过程','吕后专权的始末','萧太后的传奇一生','秦良玉的从军之路']},
  {id:'strategist',icon:'⚗️',name:'奇人异士',desc:'谋士·隐士·神人',col:['历史上最神秘的顶级谋士们','功成身退的智者们','最聪明的古代谋略家们'],solo:['张良的隐退之路','范蠡的功成身退','诸葛亮的鞠躬尽瘁','刘基的晚年悲剧']},
  {id:'dynasty',icon:'🏛️',name:'朝代兴亡',desc:'兴盛·衰败·更迭',col:['历史上最短命的王朝们','盛极而衰的朝代们','亡国之前的最后时刻们'],solo:['秦朝灭亡的真相','隋朝二世而亡的原因','北宋灭亡的经过','大清灭亡的真相']},
  {id:'reverse',icon:'🎭',name:'历史反转',desc:'误解·真相·争议',col:['被误解千年的历史坏人们','历史课没教你的真相们','最大的历史认知误区们'],solo:['秦桧真的是大奸臣吗','曹操到底是奸雄还是英雄','王莽究竟是穿越者吗','李鸿章背锅的真相']}
];
let form='c',selType=0,selTopic='',selCount=5;
const STYLE=`精致古风卡通插画，竖版9:16，粉色渐变背景（浅粉色到白色再到浅粉，柔和梦幻），樱花花瓣从上方飘落，云朵纹样装饰四角，3-4头身古风人物，五官精致大眼睛（女性妆容华美，男性英气或沉稳），服饰华美飘逸符合朝代特征，全程禁止英文字母和拼音`;
const STRUCT=`【每张人物图的6层画面结构——必须严格按此排列，不可改变】
▸ 最顶部·卷轴标题：
  米黄色木质展开卷轴横幅（两端有木质卷轴头），两行文字：
  第一行：第X位：人物名（朝代）
  第二行：标签①·标签②·标签③
  毛笔字风格，朱红印章压角
▸ 第一层（左立绘 + 右气泡）：
  左侧45%：该人物全身立绘，服饰华美符合朝代，周身有金色星星闪光装饰，立绘正下方有人物姓名标签
  右侧55%：白色圆角矩形气泡框，内写节点①正史原文句，文字直接写，15字内
  铁链从立绘右侧向右下延伸，暗金棕色S形铁链，末端金色箭头向下
▸ 第二层（左气泡 + 右云朵场景）：
  左侧：白色圆角矩形气泡框，内写节点②正史原文句
  右侧：云朵形场景插图（边缘由多个圆弧叠加），内部精致卡通场景
  铁链继续S形向下延伸，末端金色箭头
▸ 第三层（左云朵场景 + 右气泡）：
  左侧：云朵形场景插图，展示节点③画面
  右侧：白色圆角矩形气泡框，内写节点③正史原文句
  铁链继续，末端金色箭头
▸ 第四层（左气泡 + 右云朵场景）：
  左侧：白色圆角矩形气泡框，内写节点④正史原文句
  右侧：云朵形场景插图，展示节点④画面
  铁链继续，末端金色箭头
▸ 第五层（左云朵场景 + 右气泡）：
  左侧：云朵形场景插图，展示节点⑤画面
  右侧：白色圆角矩形气泡框，内写节点⑤正史原文句
  铁链继续，末端金色箭头
▸ 第六层（左气泡 + 右云朵场景）：
  左侧：白色圆角矩形气泡框，内写节点⑥正史原文句（最终结局）
  右侧：云朵形场景插图，展示节点⑥画面（最沉重震撼）
  铁链末端金色箭头向右下方，指向底部卷轴
▸ 最底部·红色卷轴史实总结：
  朱红色展开卷轴横幅，写该人物史实总结，关键词金色标注，下方金色流苏垂落
  禁止写任何互动问题
【关键规则】
- 气泡框：白色圆角矩形，只写文字，直接写正史原文，不加任何引号括号
- 场景图：云朵形状（多圆弧叠加边缘），内画精致卡通场景，不写文字
- 铁链：暗金棕色金属质感S形弯曲，每层末端有金色箭头，贯穿全图
- 立绘：只在第一层左侧出现一次，立绘下方有姓名标签，后续5层不再出现
- 严禁将结构说明文字画进图片，禁止写互动问题和ABCD选项`;

function toggleManual(){const b=document.getElementById('manual-body');const a=document.getElementById('manual-arrow');b.classList.toggle('open');a.classList.toggle('open');}
function toggleFaq(){const b=document.getElementById('faq-body');const a=document.getElementById('faq-arrow');b.classList.toggle('open');a.classList.toggle('open');}
function rT(){document.getElementById('tg').innerHTML=TYPES.map((t,i)=>`<div class="tc${i===selType?' active':''}" onclick="sT(${i})"><span class="icon">${t.icon}</span><div class="name">${t.name}</div><div class="desc">${t.desc}</div></div>`).join('');}
function rTags(){const T=TYPES[selType];const list=form==='c'?T.col:T.solo;document.getElementById('tags').innerHTML=list.map(t=>`<div class="tag${selTopic===t?' active':''}" onclick="sTopic('${t}')">${t}</div>`).join('');document.getElementById('ci').placeholder=form==='c'?'或自定义输入合集选题，如：历史上最短命的帝王们':'或自定义输入单人选题，如：岳飞被害的真相';}
function rC(){const label=document.getElementById('cl');const row=document.getElementById('cr');if(form==='c'){label.textContent='人物数量';const opts=[3,5,6,8,10];if(!opts.includes(selCount))selCount=5;row.innerHTML=opts.map(n=>`<div class="cb${selCount===n?' active':''}" onclick="sC(${n})">${n}个</div>`).join('');}else{label.textContent='故事节点数';const opts=[4,5,6];if(!opts.includes(selCount))selCount=5;row.innerHTML=opts.map(n=>`<div class="cb${selCount===n?' active':''}" onclick="sC(${n})">${n}张图</div>`).join('');}}
function setForm(f){form=f;selTopic='';selCount=5;document.getElementById('ci').value='';document.getElementById('btn-c').className='tb'+(f==='c'?' active':'');document.getElementById('btn-s').className='tb'+(f==='s'?' active':'');rTags();rC();document.getElementById('out').style.display='none';}
function sT(i){selType=i;selTopic='';document.getElementById('ci').value='';rT();rTags();document.getElementById('out').style.display='none';}
function sTopic(t){selTopic=t;document.getElementById('ci').value='';rTags();}
function sC(n){selCount=n;rC();}
function st(i){
  document.querySelectorAll('.op').forEach((p,idx)=>p.classList.toggle('active',idx===i));
  document.querySelectorAll('.otab').forEach((t,idx)=>t.classList.toggle('active',idx===i));
}

function genWx(topic){
  return `你是一位擅长三平台运营的AIGC内容创作者。
我刚刚用AI生成了一张「${topic}」历史文化图，请根据图片内容同时输出三平台配套文案：

【视频号文案】
- 标题：1个，不超过20字，历史感+吸引力
- 正文：150字，口语化，有历史故事感，有共鸣感
- 结尾：引导点赞收藏转发

【小红书文案】
- 备选标题：3个，带emoji（🏛️📜✨），有收藏冲动，不超过20字
- 正文：200字，口语化，历史故事感，涨知识
- 结尾：引导收藏+评论互动
- 话题标签：10个，含 #${topic} #中国历史 #历史知识 #传统文化 #涨知识 #历史人物

【抖音文案】
- 备选标题：3个，带emoji，有点击欲，不超过20字
- 正文：150字，节奏感强，历史感
- 结尾：引导点赞收藏关注
- 话题标签：8个`;
}
function cp(i){const txt=document.getElementById('t'+i).textContent;navigator.clipboard.writeText(txt).then(()=>{const bs=document.querySelectorAll('.cpb');if(bs[i]){bs[i].textContent='已复制 ✓';setTimeout(()=>bs[i].textContent=i===2?'复制三平台文案提示词':'复制',2000);}});}
function generate(){const custom=document.getElementById('ci').value.trim();const topic=custom||selTopic;if(!topic){alert('请选择或输入一个选题');return;}document.getElementById('t0').textContent=genP0(topic);document.getElementById('t1').textContent=genP1(topic);document.getElementById('out').style.display='block';st(0);document.getElementById('out').scrollIntoView({behavior:'smooth',block:'start'});
  // 生成三平台文案提示词
  const wxEl = document.getElementById('t2');
  if(wxEl) wxEl.textContent = genWx(topic);
}
function genP0(topic){const isStory=form==='s';const n=selCount;if(isStory){return `你是历史学者。为选题「${topic}」整理正史原文。格式如下，无需前言：\n\n【${topic}】\n▌人物名（朝代·身份·核心标签）\n情节节点（共6个，对应6层画面，情绪起伏分明）：\n· 节点①：15字内场景描述\n· 节点②：15字内场景描述\n· 节点③：15字内场景描述\n· 节点④：15字内场景描述\n· 节点⑤：15字内场景描述\n· 节点⑥：15字内场景描述（最终结局，最震撼）\n\n正史原文（共6句，每句严格对应一个节点）：\n· 句①：原句——《出处》\n· 句②：原句——《出处》\n· 句③：原句——《出处》\n· 句④：原句——《出处》\n· 句⑤：原句——《出处》\n· 句⑥：原句——《出处》\n\n三个标签关键词：标签①·标签②·标签③（每个5字内）\n史实总结：50字内，关键词用【】标注\n\n要求：所有引用必须真实，注明史书，禁止编造`;}else{return `你是历史学者。为选题「${topic}」整理正史原文，选${n}个最有戏剧张力的人物，按戏剧性从弱到强排列。格式如下，无需前言：\n\n【${topic}】\n\n（以下格式重复${n}次，共${n}个人物）\n\n▌第X位：人物名（朝代·身份·核心标签）\n情节节点（共6个，对应6层画面，情绪起伏分明）：\n· 节点①：15字内场景描述\n· 节点②：15字内场景描述\n· 节点③：15字内场景描述\n· 节点④：15字内场景描述\n· 节点⑤：15字内场景描述\n· 节点⑥：15字内场景描述（最终结局，最震撼）\n\n正史原文（共6句，每句严格对应一个节点）：\n· 句①：原句——《出处》\n· 句②：原句——《出处》\n· 句③：原句——《出处》\n· 句④：原句——《出处》\n· 句⑤：原句——《出处》\n· 句⑥：原句——《出处》\n\n三个标签关键词：标签①·标签②·标签③（每个5字内）\n史实总结：50字内，关键词用【】标注\n\n要求：所有引用必须真实，注明史书，禁止编造`;}}
function genP1(topic){const isStory=form==='s';const n=selCount;const lc=Math.ceil(n/2);const rc=Math.floor(n/2);if(isStory){return `你是AI绘图提示词专家。根据以下正史原文，为「${topic}」生成3张绘图提示词。\n\n【正史原文】\n（将Claude整理好的正史原文粘贴于此）\n\n━━━━━━━━━━━━━━━━\n固定风格词（每张开头必须完整复制）：\n${STYLE}\n━━━━━━━━━━━━━━━━\n\n${STRUCT}\n\n═══ 第1张·封面图 ═══\n固定风格词。\n主人公全身立绘居中，立绘正下方有人物姓名标签，服饰华美符合朝代，四周有对应朝代装饰元素。顶部米黄色木质卷轴写「${topic}」大标题毛笔字，朱红印章压角。底部朱红色卷轴写10字内悬念副标题。粉金配色，无气泡框，无铁链。\n\n═══ 第2张·人物情节图 ═══\n固定风格词。\n严格按上述6层画面结构生成一张完整竖版长图。将正史原文中的：人物名、朝代、三个标签、6句气泡原文、史实总结填入对应位置。每一层的云朵场景图，需根据该节点情节描述具体的精致卡通画面细节（人物动作、神情、环境氛围、象征道具）。\n\n═══ 第3张·结局纪念图 ═══\n固定风格词。\n顶部米黄色木质卷轴写「${topic}·史迹长存」。主体：用象征性画面表现人物最终命运（空置的皇位/断剑/熄灭的蜡烛/凋零的花等意象），配合该人物标志性元素，画面哀而不血腥。底部朱红色卷轴写史实总结，关键词金色标注，下方金色流苏垂落。`;}else{return `你是AI绘图提示词专家。根据以下正史原文，为「${topic}」生成${n+2}张绘图提示词。\n\n【正史原文】\n（将Claude整理好的正史原文粘贴于此）\n\n━━━━━━━━━━━━━━━━\n固定风格词（每张开头必须完整复制）：\n${STYLE}\n━━━━━━━━━━━━━━━━\n\n${STRUCT}\n\n═══ 第1张·封面图 ═══\n固定风格词。\n${n}位人物并排站立，各有特色神情，服饰华美符合各自朝代，每人正下方有对应人物姓名标签（毛笔字小标签）。顶部米黄色木质卷轴写「${topic}」大标题毛笔字，朱红印章压角。底部朱红色卷轴写10字内悬念副标题。粉金配色，无气泡框，无铁链，樱花飘落。\n\n═══ 第2至第${n+1}张·人物图（共${n}张） ═══\n固定风格词。\n严格按上述6层画面结构，为每位人物生成一张完整竖版长图。将正史原文中每位人物的：人物名、朝代、三个标签、6句气泡原文、史实总结填入对应位置。每一层的云朵场景图，需根据该节点情节，描述精致卡通画面细节（人物动作、神情、环境氛围、象征道具）。\n\n═══ 第${n+2}张·汇总图 ═══\n固定风格词。\n顶部米黄色木质展开卷轴写「${topic}·千古一叹」，毛笔字，朱红印章压角。\n\n主体采用两列错落排布：\n左列${lc}个大云朵形卡片（云朵边缘由多个圆弧叠加形成）：每个云朵内部是该人物最具代表性的精致卡通场景图，云朵正下方同时标注：①毛笔字姓名标签，②朱红色小色块标注该人物5字内历史标签。\n右列${rc}个竖长方形白底圆角卡片：每个卡片内有该人物Q版全身立绘，立绘下方有毛笔字姓名标签，姓名标签下方有朱红色小色块标注5字内历史标签。\n注意：左列云朵卡片和右列白底卡片，每一个都必须同时有姓名标签和历史标签，缺一不可。\n所有卡片之间以暗金棕色细铁链S形蜿蜒连接，各节点有金色小箭头。整体背景粉色渐变，樱花飘落，蝴蝶翩翩飞舞，金色祥云纹饰四角。\n底部朱红色展开卷轴，写12字内文言金句总结，关键词金色标注，下方金色流苏垂落。禁止写任何互动问题。`;}}
rT();rTags();rC();
</script>
</body>
</html>

<!DOCTYPE html>
<html lang="zh-CN">
<head>
<meta charset="UTF-8">
<meta name="viewport" content="width=device-width, initial-scale=1.0">
<title>各行业知识卡片工坊 · V1.0</title>
<style>
@import url('https://fonts.googleapis.com/css2?family=Noto+Serif+SC:wght@400;600;700&family=Noto+Sans+SC:wght@300;400;500&display=swap');
*{box-sizing:border-box;margin:0;padding:0}
body{font-family:'Noto Sans SC',sans-serif;background:#f7f4ef;color:#1a1209;min-height:100vh}
.page{max-width:800px;margin:0 auto;padding:20px 16px 60px}

.hdr{text-align:center;padding:40px 20px 30px;background:#3a1a00;border-bottom:2px solid rgba(200,146,10,.4);}
.hdr-badge{display:inline-flex;align-items:center;gap:6px;background:rgba(200,146,10,.15);border:1px solid rgba(200,146,10,.4);border-radius:4px;padding:4px 14px;font-size:11px;color:#f0c87a;letter-spacing:2px;margin-bottom:14px;}
.hdr h1{font-family:"Noto Serif SC",serif;font-size:clamp(20px,4vw,32px);font-weight:900;letter-spacing:4px;color:#fff;margin-bottom:8px;}
.hdr p{font-size:11px;color:#c8a060;letter-spacing:2px;margin-bottom:14px;}
.hdr-line{display:none;}
.hdr-pills{display:flex;flex-wrap:wrap;justify-content:center;gap:6px;margin-top:12px}
.hdr-pill{font-size:11px;background:rgba(200,146,10,.15);border:1px solid rgba(200,146,10,.4);color:#f0c87a;padding:4px 12px;border-radius:4px;letter-spacing:.5px;}

.manual-wrap{background:#fff;border:1px solid #e8ddd0;border-radius:12px;margin-bottom:12px;overflow:hidden}
.manual-hdr{display:flex;align-items:center;justify-content:space-between;padding:13px 18px;cursor:pointer;user-select:none}
.manual-hdr-l{display:flex;align-items:center;gap:10px}
.manual-icon{width:26px;height:26px;background:linear-gradient(135deg,#5c3d1a,#8b5e3c);border-radius:7px;display:flex;align-items:center;justify-content:center;font-size:13px}
.manual-ttl{font-size:14px;font-weight:600;color:#2c1a0e}
.manual-sub{font-size:11px;color:#9a8070;margin-top:1px}
.arrow{font-size:11px;color:#9a8070;transition:transform .3s;display:inline-block}
.arrow.open{transform:rotate(180deg)}
.manual-body{display:none;padding:0 18px 16px}
.manual-body.open{display:block}
.step-list{margin:0}
.step-item{display:flex;gap:12px;margin-bottom:14px;padding-bottom:14px;border-bottom:1px dashed #ede5d8}
.step-item:last-child{border-bottom:none;margin-bottom:0;padding-bottom:0}
.snum{width:26px;height:26px;background:linear-gradient(135deg,#8b5e3c,#c49a3c);border-radius:50%;color:#fff;font-size:11px;font-weight:700;display:flex;align-items:center;justify-content:center;flex-shrink:0;margin-top:2px}
.scontent h4{font-size:13px;font-weight:600;color:#2c1a0e;margin-bottom:3px}
.scontent p{font-size:12px;color:#6b5a45;line-height:1.65}
.stip{background:rgba(196,154,60,0.08);border-left:2px solid #c49a3c;border-radius:0 5px 5px 0;padding:7px 11px;margin-top:7px;font-size:11px;color:#6b5a45;line-height:1.6}
.wflow{background:rgba(139,94,60,0.05);border:1px solid #e8ddd0;border-radius:9px;padding:12px;margin-top:12px}
.wflow-title{font-size:11px;font-weight:700;color:#2c1a0e;margin-bottom:8px;letter-spacing:1px}
.wflow-steps{display:flex;align-items:center;flex-wrap:wrap;gap:5px}
.wfs{background:#fff;border:1px solid #e8ddd0;border-radius:5px;padding:5px 9px;font-size:10px;color:#6b5a45;white-space:nowrap}
.wfa{color:#c49a3c;font-size:11px}

.faq-wrap{background:#fff;border:1px solid #e8ddd0;border-radius:12px;margin-bottom:16px;overflow:hidden}
.faq-hdr{display:flex;align-items:center;justify-content:space-between;padding:13px 18px;cursor:pointer;user-select:none}
.faq-icon{width:26px;height:26px;background:linear-gradient(135deg,#2e5fa0,#4a8fd4);border-radius:7px;display:flex;align-items:center;justify-content:center;font-size:13px}
.faq-body{display:none;padding:0 18px 16px}
.faq-body.open{display:block}
.faq-item{margin-bottom:12px;padding-bottom:12px;border-bottom:1px dashed #ede5d8}
.faq-item:last-child{border-bottom:none;margin-bottom:0;padding-bottom:0}
.faq-q{display:flex;align-items:flex-start;gap:7px;margin-bottom:5px}
.faq-qb{background:#5c3d1a;color:#fff;font-size:10px;padding:2px 6px;border-radius:4px;white-space:nowrap;margin-top:1px;flex-shrink:0}
.faq-qt{font-size:13px;font-weight:600;color:#2c1a0e;line-height:1.5}
.faq-a{display:flex;align-items:flex-start;gap:7px}
.faq-ab{background:rgba(196,154,60,0.18);color:#7a5a20;font-size:10px;padding:2px 6px;border-radius:4px;white-space:nowrap;margin-top:1px;flex-shrink:0}
.faq-at{font-size:12px;color:#6b5a45;line-height:1.65}

.ind-tabs{display:flex;overflow-x:auto;gap:6px;padding:2px 0 12px;scrollbar-width:none}
.ind-tabs::-webkit-scrollbar{display:none}
.itab{flex-shrink:0;padding:9px 15px;border:1.5px solid #e8ddd0;background:#fff;border-radius:10px;cursor:pointer;font-size:13px;color:#7a6a55;font-family:'Noto Sans SC',sans-serif;transition:all .18s;text-align:center;white-space:nowrap}
.itab .tie{display:block;font-size:19px;margin-bottom:3px}
.itab .tin{display:block;font-size:11px;font-weight:600}
.itab.active{color:#fff}

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

.ind-banner{border-radius:12px;padding:16px 18px 14px;margin-bottom:14px}
.ind-banner-title{font-family:'Noto Serif SC',serif;font-size:17px;font-weight:700;color:#fff;margin-bottom:3px}
.ind-banner-sub{font-size:11px;color:rgba(255,255,255,0.75)}
.ind-banner-tags{display:flex;gap:6px;margin-top:9px;flex-wrap:wrap}
.ibt{font-size:10px;padding:2px 9px;border-radius:10px;border:1px solid rgba(255,255,255,0.35);color:rgba(255,255,255,0.9);background:rgba(255,255,255,0.12)}

.tool-wrap{background:#fff;border:1px solid #e8ddd0;border-radius:12px;padding:18px}
.sl{font-size:10px;letter-spacing:2px;color:#9a8070;font-weight:700;margin-bottom:9px;text-transform:uppercase}
.form-row{margin-bottom:16px}

.ctype-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:7px}
.ctcard{border:1.5px solid #e8ddd0;background:#faf6f0;border-radius:8px;padding:11px;cursor:pointer;transition:all .14s;font-family:'Noto Sans SC',sans-serif}
.ctcard:hover{border-color:#c49a3c;background:#fef8ee}
.ctcard.active{border-color:var(--ic);background:var(--il)}
.ct-icon{font-size:18px;margin-bottom:3px}
.ct-name{font-size:13px;font-weight:600;color:#1a1209;margin-bottom:2px}
.ct-desc{font-size:11px;color:#9a8070}

.ttags{display:flex;flex-wrap:wrap;gap:5px;margin-bottom:8px}
.ttag{padding:4px 11px;border:1px solid #e8ddd0;border-radius:20px;font-size:12px;cursor:pointer;background:#faf6f0;color:#5a4a35;font-family:'Noto Sans SC',sans-serif;transition:all .13s}
.ttag:hover{border-color:#c49a3c}
.ttag.active{color:#fff;border-color:var(--ic)}
.tph{font-size:12px;color:#b0a090;padding:5px 0}
.ci{width:100%;border:1px solid #e8ddd0;background:#faf6f0;border-radius:8px;padding:9px 12px;font-size:13px;color:#1a1209;font-family:'Noto Sans SC',sans-serif;outline:none;transition:border-color .18s;margin-top:2px}
.ci:focus{border-color:#c49a3c}

.cl{font-size:10px;color:#9a8070;margin-bottom:7px;letter-spacing:1px;font-weight:700;text-transform:uppercase}
.cr{display:flex;gap:7px}
.cb{flex:1;padding:7px 4px;border:1px solid #e8ddd0;background:#faf6f0;border-radius:6px;cursor:pointer;font-size:12px;color:#5a4a35;font-family:'Noto Sans SC',sans-serif;text-align:center;transition:all .13s}
.cb.active{color:#fff;border-color:#c49a3c;background:#c49a3c}

.gb{width:100%;padding:13px;border:none;border-radius:8px;font-size:14px;font-family:'Noto Serif SC',serif;letter-spacing:2px;cursor:pointer;transition:all .18s;color:#fff}
.gb:hover{opacity:.88;transform:translateY(-1px)}

.out{margin-top:18px;display:none}
.dv{height:1px;background:linear-gradient(90deg,transparent,#e8ddd0,transparent);margin:14px 0}
.otabs{display:flex;border-bottom:1.5px solid #e8ddd0;margin-bottom:14px}
.otab{padding:9px 15px;cursor:pointer;font-size:12px;color:#9a8070;font-family:'Noto Sans SC',sans-serif;border-bottom:2px solid transparent;margin-bottom:-1.5px;transition:all .18s;white-space:nowrap}
.otab.active{color:#1a1209;border-bottom-color:var(--ic);font-weight:600}
.op{display:none}
.op.active{display:block}
.ob{background:#faf6f0;border:1px solid #e8ddd0;border-radius:8px;padding:13px;font-size:12px;line-height:1.85;color:#1a1209;white-space:pre-wrap;font-family:'Courier New',monospace;max-height:420px;overflow-y:auto}
.cpb{margin-top:9px;padding:7px 18px;border:1px solid #9a8070;background:transparent;border-radius:6px;color:#9a8070;font-size:12px;cursor:pointer;font-family:'Noto Sans SC',sans-serif;transition:all .13s}
.cpb:hover{background:#9a8070;color:#fff}
.tip{background:rgba(139,111,58,0.07);border-left:3px solid #c49a3c;border-radius:0 7px 7px 0;padding:9px 13px;margin-top:11px;font-size:11px;color:#6b5a45;line-height:1.7}

.footer{text-align:center;margin-top:30px;font-size:11px;color:#b0a080;letter-spacing:1px}
</style>
</head>
<body>
<div class="page">

<div class="hdr">
  <div class="hdr-badge">各行业知识卡片工坊 · V1.0</div>
  <h1>知识卡片提示词生成站</h1>
  <div class="hdr-line"></div>
  <p>选行业 · 选卡片类型 · 输入主题 → 生成图片提示词 + 文案提示词</p>
  <div class="hdr-pills">
    <span class="hdr-pill">👶 宝妈育儿</span>
    <span class="hdr-pill">💼 职场副业</span>
    <span class="hdr-pill">🏪 实体店商家</span>
    <span class="hdr-pill">📚 知识付费</span>
    <span class="hdr-pill">🏋️ 健身美业</span>
  </div>
</div>

<div class="manual-wrap">
  <div class="manual-hdr" onclick="toggleSection('manual')">
    <div class="manual-hdr-l">
      <div class="manual-icon">📖</div>
      <div><div class="manual-ttl">使用手册</div><div class="manual-sub">三步生成完整图文提示词，点击展开</div></div>
    </div>
    <span class="arrow" id="arrow-manual">▼</span>
  </div>
  <div class="manual-body" id="body-manual">
    <div class="step-list">
      <div class="step-item">
        <div class="snum">1</div>
        <div class="scontent">
          <h4>选行业 → 选卡片类型 → 选主题</h4>
          <p>顶部切换5个行业Tab，选对应卡片类型（每个行业4种），从热门选题中点选或自定义输入主题。</p>
          <div class="stip">💡 合集类主题选「干货清单/选购对比」；单条深度主题选「避坑指南/今日打卡」</div>
        </div>
      </div>
      <div class="step-item">
        <div class="snum">2</div>
        <div class="scontent">
          <h4>复制①图片提示词 → 发给即梦5.0 / 香蕉Pro</h4>
          <p>生成后切换到「①图片提示词」Tab，复制内容，粘贴到即梦5.0或香蕉Pro生成图片。风格词已内置，直接用。</p>
          <div class="stip">💡 即梦建议选5.0或4.6模型；香蕉Pro直接粘贴效果更稳定</div>
        </div>
      </div>
      <div class="step-item">
        <div class="snum">3</div>
        <div class="scontent">
          <h4>复制②文案提示词 → 发给 Claude / DeepSeek / 豆包</h4>
          <p>切换到「②文案提示词」Tab，复制后发给任意AI工具，直接生成配套的小红书爆款文案，图文同步出，省一步。</p>
          <div class="stip">💡 推荐用 Claude 生成文案，效果最好；DeepSeek / 豆包也可按需选择</div>
        </div>
      </div>
    </div>
    <div class="wflow">
      <div class="wflow-title">完整工作流</div>
      <div class="wflow-steps">
        <span class="wfs">选行业+类型+主题</span><span class="wfa">→</span>
        <span class="wfs">复制①图片提示词</span><span class="wfa">→</span>
        <span class="wfs">即梦/香蕉Pro出图</span><span class="wfa">→</span>
        <span class="wfs">复制②文案提示词</span><span class="wfa">→</span>
        <span class="wfs">Claude/DeepSeek出文案</span>
      </div>
    </div>
  </div>
</div>

<div class="faq-wrap">
  <div class="faq-hdr" onclick="toggleSection('faq')">
    <div class="manual-hdr-l">
      <div class="faq-icon">❓</div>
      <div><div class="manual-ttl">常见问题 FAQ</div><div class="manual-sub">遇到问题先看这里，点击展开</div></div>
    </div>
    <span class="arrow" id="arrow-faq">▼</span>
  </div>
  <div class="faq-body" id="body-faq">
    <div class="faq-item">
      <div class="faq-q"><span class="faq-qb">Q</span><span class="faq-qt">生成的图片风格不对怎么办？</span></div>
      <div class="faq-a"><span class="faq-ab">A</span><span class="faq-at">固定风格词必须完整复制到提示词开头，不能省略。即梦建议选5.0或4.6模型；如果风格偏差较大，可在提示词末尾追加「参考风格：温柔手绘插画风，配色暖米色系」再生成。</span></div>
    </div>
    <div class="faq-item">
      <div class="faq-q"><span class="faq-qb">Q</span><span class="faq-qt">图片里出现了说明文字（如「标题区」「内容区」）怎么处理？</span></div>
      <div class="faq-a"><span class="faq-ab">A</span><span class="faq-at">这是AI把提示词结构说明画进了图里。在提示词开头追加「画面中禁止出现任何结构区域说明文字」，或重新生成一次，是概率性问题。</span></div>
    </div>
    <div class="faq-item">
      <div class="faq-q"><span class="faq-qb">Q</span><span class="faq-qt">卡片文字太密了怎么优化？</span></div>
      <div class="faq-a"><span class="faq-ab">A</span><span class="faq-at">在提示词「主体内容区」后追加：「每条文字不超过20字，插画占该条70%面积，留白充足，不要过于密集」。</span></div>
    </div>
    <div class="faq-item">
      <div class="faq-q"><span class="faq-qb">Q</span><span class="faq-qt">文案提示词发给哪个AI最好？</span></div>
      <div class="faq-a"><span class="faq-ab">A</span><span class="faq-at">推荐 Claude，文案质量和风格把控最好；DeepSeek、豆包也可以按需使用，效果差异不大。不建议用纯提示词生成工具，文案会比较生硬。</span></div>
    </div>
    <div class="faq-item">
      <div class="faq-q"><span class="faq-qb">Q</span><span class="faq-qt">可以分享给粉丝/学员使用吗？</span></div>
      <div class="faq-a"><span class="faq-ab">A</span><span class="faq-at">可以直接把这个HTML文件发给他们，浏览器打开即用，无需安装任何软件。建议配合使用手册讲解一遍，第一次跑通完整流程后上手会很快。</span></div>
    </div>
  </div>
</div>

<div class="ind-tabs" id="ind-tabs"></div>
<div id="panels"></div>

<div class="footer">各行业知识卡片工坊 · V1.0 · <span style="color:#c49a3c">为内容创作者而生</span></div>
</div>

<script>
const IND={
  mama:{name:'宝妈育儿',em:'👶',
    color:'#c97b63',bg:'linear-gradient(135deg,#c97b63,#e8a090)',
    style:{
      fixed:'竖版3:4比例，米灰亚麻纸张质感底色（类似#f5efe8，非纯白，带纸张纹理感），写实温柔手绘风格（妈妈和孩子形象，人物比例接近真实，服装日常休闲感），配色：暖棕色+赭石+米白为主，局部柔和蓝绿或橙色点缀，全程禁止英文字母和拼音，禁止将结构说明文字画进图片',
      feel:'有温度有共情感，像翻看手绘亲子日记，不是冷冰冰信息图',
      density:'每条文字控制在20字以内，插画占每条格70%面积，留白充足，整体疏密有致'
    },
    types:[
      {id:'avoid',icon:'⚠️',name:'避坑指南',desc:'踩坑经历+解决方案',
        topics:['宝宝辅食添加的5个坑','早教启蒙别走这些弯路','宝宝睡眠问题避坑指南','幼儿园报名不踩雷','儿童用药常见误区'],
        layout:'编号色块①②③ + 坑的名称（加粗10字内）→ 右侧配手绘场景插图（妈妈/孩子发现该坑时的表情动作）→ 下方正确做法（换色15字内）→ 每条间细线分隔纵向排列共3-5条'},
      {id:'guide',icon:'📋',name:'干货清单',desc:'实用方法+快速上手',
        topics:['0-3岁大脑发育必做的事','培养专注力的10个小游戏','宝宝情绪管理实用手册','亲子阅读怎么读才对','正面管教核心方法'],
        layout:'序号圆形色块 + 核心观点（10字内）→ 右侧配手绘小图标或场景插图 → 补充说明（15字内）→ 共3-5个知识点纵向排列疏密有致'},
      {id:'checkin',icon:'✅',name:'今日打卡',desc:'每日习惯+陪伴系列',
        topics:['今日陪娃亲子游戏打卡','宝宝语言发育每日练习','睡前亲子共读打卡计划','宝宝运动打卡系列','每日情绪引导打卡'],
        layout:'顶部Day编号+日期格（手写感）→ 中部主题场景插画（人物完成该任务画面，占图40%）→ 任务清单：方形勾选框+任务内容+时间次数标注（每条15字内）→ 底部「我做到了✓」引导语'},
      {id:'compare',icon:'🔍',name:'对比科普',desc:'是否判断+知识辨析',
        topics:['宝宝爱吃手要不要阻止','孩子哭了要不要马上抱','该不该强迫孩子道歉','孩子撒谎了怎么正确处理','越罚越叛逆的原因'],
        layout:'左右两区（强迫后果 vs 引导的力量 / 是 vs 否）→ 每区标题+3条说明（每条10字内）+对应场景小插图 → 中间VS或双向箭头分隔 → 底部明确结论金句（15字内）'}
    ]
  },
  work:{name:'职场副业',em:'💼',
    color:'#5c8a6a',bg:'linear-gradient(135deg,#5c8a6a,#85b59a)',
    style:{
      fixed:'竖版3:4比例，米白纸张底色（类似#faf7f2，带轻微咖啡色纸感），水彩手绘风格小插图（打工人、咖啡杯、笔记本、植物场景），配色：咖啡棕#7a5c3c+暖米色+局部深绿/橙色点缀，文字深棕，整体像咖啡馆海报，全程禁止将结构说明文字画进图片',
      feel:'治愈系职场，有生活感，像文艺咖啡馆墙上挂的手绘海报，不焦虑不说教',
      density:'每条文字15字以内，配插图清晰，留白自然，整体有节奏感'
    },
    types:[
      {id:'avoid',icon:'⚠️',name:'避坑指南',desc:'亲身踩坑+解决思路',
        topics:['副业接单新手最容易踩的坑','自由职业第一年必踩的雷','职场沟通的高级踩坑现场','做自媒体前没人告诉你的坑','打工人理财常见误区'],
        layout:'编号①②③ + 坑的名称（加粗10字内）→ *正确做法（星号+斜体，15字内）→ 右侧配水彩手绘插图（打工人发现/解决的场景）→ 每条轻细线分隔纵向排列共3条'},
      {id:'tools',icon:'🔧',name:'效率工具',desc:'工具推荐+使用场景',
        topics:['打工人续命咖啡图鉴','AI提效工具实测推荐','职场人必备5个免费工具','做副业必须知道的平台','在家办公效率提升工具箱'],
        layout:'2×2分格卡片（每格圆角矩形）→ 每格：手绘图标+工具名+适用场景（10字）+一句评价（15字）→ 底部底色深棕区金句'},
      {id:'skill',icon:'🧠',name:'技能干货',desc:'一个技能+3步拆解',
        topics:['3步学会职场向上沟通','副业选品的底层逻辑','小红书爆款选题公式','如何快速搭建个人IP','时间管理的正确打开方式'],
        layout:'标题下一句痛点引入 → 核心3步法：大数字圆圈（1/2/3）+步骤名（8字内）+说明（15字内）→ 右侧配水彩小插图 → 步骤间箭头引导纵向流动'},
      {id:'income',icon:'💰',name:'副业测评',desc:'真实收入+可复制路径',
        topics:['我靠知识卡片月入多少','这5个副业不用露脸也能做','普通人适合的3条副业赛道','我用AI做内容的完整工作流','副业3个月的真实复盘'],
        layout:'顶部结果大字呈现（收入/成果数字）→ 主体3条副业赛道横向卡片（每卡：名称+一句特点+水彩小插图）→ 底部金句+引导语'}
    ]
  },
  shop:{name:'实体店商家',em:'🏪',
    color:'#3a7ab8',bg:'linear-gradient(135deg,#3a7ab8,#6aa0d8)',
    style:{
      fixed:'竖版3:4比例，干净白底或极浅灰蓝色底（#f0f5f9），扁平矢量风格插图（专业感图标：建筑/产品/商品），配色：专业蓝#2e6da4+白色+浅蓝绿，数字编号用深蓝圆形背景，全程禁止将结构说明文字画进图片',
      feel:'专业权威有说服力，像行业内部人士在普及知识，不硬广不油腻',
      density:'每条说明文字15字以内，图标清晰，整体信息密度高但不拥挤'
    },
    types:[
      {id:'compare',icon:'📊',name:'选购对比卡',desc:'产品对比+买前必看',
        topics:['买沙发之前先看这张图','咖啡机选购对比全攻略','床垫硬软真相对比指南','护肤品成分怎么看明白','宠物食品对比选购手册'],
        layout:'顶部「优质之选 👍 vs 劣质雷区 👎」标题条 → 左右两栏对比 → 每侧3条：圆形序号+对比点（10字）+说明（15字）+对应矢量小图标 → 底部总结金句（专业建议一句话）'},
      {id:'story',icon:'💡',name:'产品故事卡',desc:'背后故事+差异化卖点',
        topics:['我家手工皂是怎么做出来的','从原料到成品的完整过程','为什么我们坚持不用添加剂','选这个材料而不是那个的原因','一个老师傅的手艺传承'],
        layout:'顶部场景插画（原料/工坊/手工感，占30%）→ 主体流程：1选原料→2工艺→3成品，每步编号圆圈+名称（8字）+说明（15字）+矢量小图 → 底部差异化卖点金句'},
      {id:'avoid',icon:'⚠️',name:'行业避坑',desc:'内行人视角+消费者保护',
        topics:['装修公司不告诉你的猫腻','买二手车前必须知道的事','美容院常见套路大揭秘','健身房会员坑的正确避法','餐厅选食材的隐藏门道'],
        layout:'编号①②③ + 坑的名称（加粗10字内）→ 右侧配对应场景矢量插图 → 下方核心提示（15字内）→ 纵向排列共3条 → 底部深蓝色横条+专业建议'},
      {id:'guide',icon:'📋',name:'选购清单',desc:'明确需求+精准推荐',
        topics:['不同预算怎么选咖啡机','初学者健身器材购买清单','宝宝用品分阶段购买指南','家装软装搭配清单','开店必备设备采购清单'],
        layout:'序号圆圈（深蓝底白字）+ 品类名（10字）→ 右侧配矢量产品图标 → 一句选购建议（15字）→ 纵向排列共4-5条 → 底部「量力而行，安全至上」类总结'}
    ]
  },
  edu:{name:'知识付费',em:'📚',
    color:'#7b5fc8',bg:'linear-gradient(135deg,#7b5fc8,#a888e0)',
    style:{
      fixed:'竖版3:4比例，白底为主，局部金色或深紫色装饰边框/顶部色块，极简人物插画（简笔风格）或真实照片搭配品牌水印，配色：金色#c49a3c+深紫#6b4fa0为主，白底深色字，整体高级感，全程禁止将结构说明文字画进图片',
      feel:'高级权威感，像专业老师认真分享，引发「我要跟TA学」的冲动',
      density:'文字精炼，每条核心观点10字以内，说明15字以内，留白充足显高级感'
    },
    types:[
      {id:'quote',icon:'✨',name:'今日金句卡',desc:'个人IP金句+人物形象',
        topics:['关于学习成长的一句话','创业路上的真实感悟','给普通人的一句忠告','你不知道的财富真相','关于时间最残酷的一件事'],
        layout:'极简布局：顶部「今日金句」标签（金色横条）→ 大字金句居中（2-3行，字号大，有视觉冲击力）→ 下方人物形象（简笔插画或真实照片剪影）→ 右下角品牌水印留空位 → 背景干净留白充足'},
      {id:'preview',icon:'🔓',name:'试看干货卡',desc:'课程核心内容+引流钩子',
        topics:['小红书涨粉最快的一个动作','AI变现最关键的一步','副业入门第一课核心总结','知识付费选品的底层逻辑','做IP只需要搞定这一件事'],
        layout:'顶部「今日干货」深色标签条 → 主体1个核心知识点拆解3步：大数字+步骤名（8字）+说明（15字）+小图标 → 步骤间箭头引导 → 底部悬念钩子「更多内容→」引发好奇'},
      {id:'list',icon:'📋',name:'知识清单卡',desc:'系统知识+收藏价值',
        topics:['新手做小红书必看的5件事','打造个人品牌的完整路径','内容变现的4种主流模式','自媒体运营数据指标解读','从0到1搭建知识付费体系'],
        layout:'清单信息图：序号金色圆圈 + 核心观点（10字）→ 补充说明（15字）→ 右侧小图标 → 共4-5条纵向排列 → 底部「建议收藏」引导 → 左侧或顶部金色竖线装饰'},
      {id:'case',icon:'🏆',name:'学员案例卡',desc:'真实结果+可复制路径',
        topics:['3个月从0到1000粉的复盘','宝妈靠知识卡片月入5位数','普通上班族副业的真实收入','60天做出第一个爆款的方法','从不会到会的完整学习路径'],
        layout:'顶部结果大字（粉丝数/收入/时间，金色数字冲击力强）→ 主体时间线：起点→关键节点→结果（3步，每步15字）→ 底部人物简笔插画+「我是怎么做到的」悬念引导'}
    ]
  },
  fit:{name:'健身美业',em:'🏋️',
    color:'#c4703a',bg:'linear-gradient(135deg,#c4703a,#e8a06a)',
    style:{
      fixed:'竖版3:4比例，白底为主，各分区用彩色色块区分（橙#e8703a/绿#5aab7a/蓝#4a8fc4），扁平卡通运动人物（清晰展示动作姿势，服装运动服），美业则粉色温柔插画风，配色多色分区，全程禁止将结构说明文字画进图片',
      feel:'清爽有活力，像翻开专业健身手册，不沉闷，有温度有鼓励感',
      density:'动作说明精炼，每条10-15字，动作图清晰占主体，文字辅助说明'
    },
    types:[
      {id:'action',icon:'💪',name:'动作图解',desc:'标准动作+错误对比',
        topics:['深蹲标准姿势vs常见错误','平板支撑怎么做才有效','居家无器械全身锻炼','颈肩放松5分钟动作指南','腰腹核心训练入门动作'],
        layout:'顶部「常见错误（×）vs 标准姿势（✓）」两区标题条（红/绿色块）→ 左错误区：人物动作图+红色箭头标注错误部位（标注文字8字内）→ 右正确区：人物动作图+绿色箭头标注正确要点（8字内）→ 底部打卡引导语'},
      {id:'checkin',icon:'✅',name:'今日打卡',desc:'每日计划+跟练系列',
        topics:['Day1开始我的减脂计划','每天5分钟坚持30天挑战','今日腰腹训练打卡','晨间拉伸10分钟打卡','睡前放松瑜伽打卡'],
        layout:'顶部DAY编号+日期格（大字冲击感）→ 中部主题运动场景插画（人物运动中，占35%）→ 打卡任务清单：方形勾选框+任务（15字）+时间/次数标注 → 共3-4条 → 底部「我做到了✓」+鼓励金句'},
      {id:'ingredient',icon:'🔬',name:'成分科普',desc:'产品成分+选购建议',
        topics:['蛋白粉怎么选才对','护肤品里的防腐剂真相','玻尿酸和胶原蛋白的区别','运动饮料和水的选择','防晒霜SPF数值怎么看'],
        layout:'分类色块（每个成分一个颜色区块）→ 每区：成分名大字+「适合人群」标签+右侧使用场景运动插图+「注意：」一句建议（15字）→ 共3个成分 → 底部「根据需求和目标挑选，关键是坚持」'},
      {id:'compare',icon:'📊',name:'效果对比',desc:'前后对比+方法验证',
        topics:['健身3个月身体的真实变化','节食vs科学减脂的差距','有氧vs无氧哪个减脂更好','坚持vs放弃的6个月对比','素颜护肤vs彩妆的皮肤差异'],
        layout:'顶部「健身前 >> 健身3个月后」双区标题（灰/橙色块对比）→ 左前：人物插图（体态/状态）+3条描述（10字内）→ 右后：人物插图（改善后）+3条对比描述（10字内）→ 中间大箭头→ 底部鼓励金句'}
    ]
  }
};

let selInd="mama",curType="",curTopic="";

function toggleSection(id){
  const b=document.getElementById('body-'+id);
  const a=document.getElementById('arrow-'+id);
  b.classList.toggle('open');
  a.classList.toggle('open');
}

function buildTabs(){
  const row=document.getElementById('ind-tabs');
  Object.entries(IND).forEach(([id,I])=>{
    const t=document.createElement('div');
    t.className='itab'+(id==='mama'?' active':'');
    t.dataset.id=id;
    t.innerHTML=`<span class="tie">${I.em}</span><span class="tin">${I.name}</span>`;
    t.style.cssText=id==='mama'?`background:${I.color};border-color:${I.color}`:'';
    t.onclick=()=>switchInd(id);
    row.appendChild(t);
  });
}

function buildPanels(){
  const c=document.getElementById('panels');
  Object.entries(IND).forEach(([id,I])=>{
    const p=document.createElement('div');
    p.className='ind-panel'+(id==='mama'?' active':'');
    p.dataset.id=id;
    p.style.cssText=`--ic:${I.color};--il:${hexToRgba(I.color,0.08)}`;
    p.innerHTML=`
<div class="ind-banner" style="background:${I.bg}">
  <div class="ind-banner-title">${I.em} ${I.name}知识卡片</div>
  <div class="ind-banner-sub">${I.style.feel}</div>
  <div class="ind-banner-tags">
    <span class="ibt">风格已内置</span>
    <span class="ibt">图片+文案双输出</span>
    <span class="ibt">即梦/香蕉Pro直用</span>
  </div>
</div>
<div class="tool-wrap">
  <div class="form-row">
    <div class="sl">第一步：选择卡片类型</div>
    <div class="ctype-grid" id="ctg-${id}">
      ${I.types.map(t=>`<div class="ctcard" data-t="${t.id}" onclick="pickType('${id}','${t.id}')"><div class="ct-icon">${t.icon}</div><div class="ct-name">${t.name}</div><div class="ct-desc">${t.desc}</div></div>`).join('')}
    </div>
  </div>
  <div class="form-row">
    <div class="sl">第二步：选择或自定义主题</div>
    <div class="ttags" id="ttags-${id}"><span class="tph">请先选择卡片类型</span></div>
    <input class="ci" id="ci-${id}" placeholder="或直接输入主题，如：宝宝辅食添加的5个坑" oninput="onCI('${id}')"/>
  </div>
  <button class="gb" style="background:${I.color}" onclick="gen('${id}')">✦ 生成提示词</button>
  <div class="out" id="out-${id}">
    <div class="dv"></div>
    <div class="otabs">
      <div class="otab active" onclick="swTab('${id}',0)">① 图片提示词（即梦/香蕉）</div>
      <div class="otab" onclick="swTab('${id}',1)">📝 三平台文案提示词</div>
    </div>
    <div class="op active" id="p0-${id}"><div class="ob" id="t0-${id}"></div><button class="cpb" onclick="cp('${id}',0)">复制</button><div class="tip">复制 → 发给 即梦5.0 / 香蕉Pro → 生成图片（建议即梦选5.0或4.6模型）</div></div>
    <div class="op" id="p1-${id}"><div class="ob" id="t1-${id}"></div><button class="cpb" onclick="cp('${id}',1)">复制</button><div class="tip">复制 → 发给 Claude / DeepSeek / 豆包 → 生成小红书配套文案</div></div>
  </div>
</div>`;
    c.appendChild(p);
  });
}

function hexToRgba(hex,a){
  const r=parseInt(hex.slice(1,3),16);
  const g=parseInt(hex.slice(3,5),16);
  const b=parseInt(hex.slice(5,7),16);
  return `rgba(${r},${g},${b},${a})`;
}

function switchInd(id){
  selInd=id;curType='';curTopic='';
  document.querySelectorAll('.itab').forEach(t=>{
    const I=IND[t.dataset.id];
    t.classList.toggle('active',t.dataset.id===id);
    t.style.cssText=t.dataset.id===id?`background:${I.color};border-color:${I.color};color:#fff`:'';
  });
  document.querySelectorAll('.ind-panel').forEach(p=>p.classList.toggle('active',p.dataset.id===id));
  document.querySelectorAll('.out').forEach(o=>o.style.display='none');
}

function pickType(id,t){
  curType=t;curTopic='';
  document.getElementById(`ci-${id}`).value='';
  document.querySelectorAll(`#ctg-${id} .ctcard`).forEach(c=>c.classList.toggle('active',c.dataset.t===t));
  const td=IND[id].types.find(x=>x.id===t);
  document.getElementById(`ttags-${id}`).innerHTML=td.topics.map(tp=>`<span class="ttag" onclick="pickTopic('${id}','${tp.replace(/'/g,"&#39;")}')">${tp}</span>`).join('');
  if(document.getElementById('out-'+id))document.getElementById('out-'+id).style.display='none';
}

function pickTopic(id,tp){
  curTopic=tp;
  document.getElementById(`ci-${id}`).value='';
  document.querySelectorAll(`#ttags-${id} .ttag`).forEach(t=>t.classList.toggle('active',t.textContent===tp));
}

function onCI(id){
  curTopic='';
  document.querySelectorAll(`#ttags-${id} .ttag`).forEach(t=>t.classList.remove('active'));
}

function swTab(id,i){
  document.querySelectorAll(`#out-${id} .otab`).forEach((t,idx)=>t.classList.toggle('active',idx===i));
  document.querySelectorAll(`#out-${id} .op`).forEach((p,idx)=>p.classList.toggle('active',idx===i));
}

function cp(id,i){
  const txt=document.getElementById(`t${i}-${id}`).textContent;
  navigator.clipboard.writeText(txt).then(()=>{
    const bs=document.querySelectorAll(`#out-${id} .cpb`);
    bs[i].textContent='已复制 ✓';setTimeout(()=>bs[i].textContent='复制',2000);
  });
}

function gen(id){
  const I=IND[id];
  const ci=document.getElementById(`ci-${id}`).value.trim();
  const topic=ci||curTopic;
  if(!topic){alert('请选择或输入一个主题');return;}
  if(!curType){alert('请先选择卡片类型');return;}
  const td=I.types.find(t=>t.id===curType);
  document.getElementById(`t0-${id}`).textContent=gImg(I,td,topic);
  document.getElementById(`t1-${id}`).textContent=gCopy(I,td,topic);
  document.getElementById(`out-${id}`).style.display='block';
  swTab(id,0);
  document.getElementById(`out-${id}`).scrollIntoView({behavior:'smooth',block:'start'});
}

function gImg(I,td,topic){
  return `【${I.name} · ${td.name}】图片提示词

━━ 固定风格词（必须完整复制到开头）━━
${I.style.fixed}

━━ 文字密度控制 ━━
${I.style.density}

━━ 画面主题 ━━
「${topic}」

━━ 标题区 ━━
大标题手写感字体：「${topic}」
副标题（10字内）：一句戳心的价值说明或痛点场景
${I.name==='宝妈育儿'?'标题区有淡淡纸张水渍晕染，温柔感，配小植物或婴儿元素装饰':
  I.name==='职场副业'?'标题区配温暖小图标（咖啡杯/植物），像咖啡馆手写黑板':
  I.name==='实体店商家'?'标题区右侧配领域相关简洁矢量图标，专业感':
  I.name==='知识付费'?'标题区下方细金色分割线，整体高级感，字体加粗有冲击力':
  '标题区配运动图标或彩色圆形装饰，活力感'}

━━ 主体内容区 ━━
${td.layout}

━━ 底部总结区 ━━
${I.name==='宝妈育儿'?'米棕色圆角矩形，一句有温度的总结金句（15字内），字体温柔，配小图标装饰':
  I.name==='职场副业'?'咖啡棕底部区，一句治愈系金句（15字内），配小植物装饰':
  I.name==='实体店商家'?'深蓝色底部横条，一句专业建议或行动指令（15字内）':
  I.name==='知识付费'?'金色边框底部区，一句引发好奇的悬念钩子（15字内）':
  '橙色渐变底部条，一句激励打卡的金句（15字内）'}

━━ 整体氛围 ━━
${I.style.feel}`;
}

function gCopy(I,td,topic){
  return `你是一位擅长三平台运营的AIGC内容创作者。
我刚刚用AI生成了一张「${topic}」${I.name}知识卡片图，请根据图片内容同时输出三平台配套文案：

【视频号文案】
- 标题：1个，不超过20字，有吸引力，切合${I.name}行业
- 正文：150字，口语化，${I.name}从业者/目标人群视角，有共鸣感
- 结尾：引导点赞收藏转发

【小红书文案】
- 备选标题：3个，带emoji，有收藏冲动，不超过20字
- 正文：200字，口语化，${I.name}专业感+接地气
- 结尾：引导收藏+评论互动
- 话题标签：10个，含 #${topic.replace(/[，,。.「」]/g,'').substring(0,8)} #${I.name} #行业知识 #干货分享

【抖音文案】
- 备选标题：3个，带emoji，有点击欲，不超过20字
- 正文：150字，节奏感强，${I.name}行业特色突出
- 结尾：引导点赞收藏关注
- 话题标签：8个`;
}

buildTabs();
buildPanels();
</script>

<div style="text-align:center;padding:24px 20px;border-top:1px solid #e0cfa8;margin-top:24px;background:#faf6ef">
  <div style="font-size:14px;font-weight:700;color:#1a0a00;letter-spacing:3px;margin-bottom:6px;font-family:'PingFang SC','Microsoft YaHei',serif">📜 阿坚AIGC · 工具中心</div>
  <div style="font-size:11px;color:#6a4a20;letter-spacing:1px;line-height:2">各行业知识卡片工坊 · V1<br>版权所有 © 阿坚AIGC · 仅供授权用户个人创作使用 · 禁止商业转载与二次分发</div>
</div>
</body>
</html>

<!DOCTYPE html>
<html lang="zh">
<head>
<meta charset="UTF-8">
<meta name="viewport" content="width=device-width, initial-scale=1.0">
<title>争议榜单图鉴·提示词工坊</title>
<style>
@import url('https://fonts.googleapis.com/css2?family=Noto+Serif+SC:wght@400;600;700&family=Noto+Sans+SC:wght@300;400;500&display=swap');

:root {
  --paper: #f8f0dc;
  --paper2: #f0e4c4;
  --paper3: #e8d8b0;
  --ink: #2c1a08;
  --ink2: #5c3d1e;
  --ink3: #8a6040;
  --red: #c0321a;
  --gold: #b8860b;
  --gold2: #d4a820;
  --gold3: #f0c840;
  --border: #c8a060;
  --border2: #a07840;
  --bg: #f2e8d0;
}

* { box-sizing: border-box; margin: 0; padding: 0; }

body {
  background: var(--bg);
  background-image:
    radial-gradient(ellipse at 20% 20%, rgba(184,134,11,0.08) 0%, transparent 50%),
    radial-gradient(ellipse at 80% 80%, rgba(192,50,26,0.06) 0%, transparent 50%);
  min-height: 100vh;
  font-family: 'Noto Sans SC', sans-serif;
  color: var(--ink);
}

/* ── 顶部 ── */
.top-bar {
  background: var(--ink);
  padding: 8px 20px;
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 12px;
}
.top-bar span {
  font-size: 11px;
  color: var(--gold2);
  letter-spacing: 3px;
  font-family: 'Noto Serif SC', serif;
}
.top-dot { width: 4px; height: 4px; border-radius: 50%; background: var(--gold2); opacity: 0.6; }

.hero {
  text-align: center;
  padding: 36px 20px 28px;
  position: relative;
}
.hero::after {
  content: '';
  position: absolute;
  bottom: 0; left: 50%; transform: translateX(-50%);
  width: 60%; height: 1px;
  background: linear-gradient(90deg, transparent, var(--border), transparent);
}
.hero-badge {
  display: inline-block;
  border: 1px solid var(--border);
  padding: 3px 14px;
  font-size: 10px;
  letter-spacing: 3px;
  color: var(--ink3);
  margin-bottom: 12px;
  border-radius: 20px;
  background: rgba(184,134,11,0.08);
}
.hero h1 {
  font-family: 'Noto Serif SC', serif;
  font-size: 28px;
  color: var(--ink);
  letter-spacing: 3px;
  margin-bottom: 8px;
  line-height: 1.3;
}
.hero h1 em {
  color: var(--red);
  font-style: normal;
}
.hero p {
  font-size: 13px;
  color: var(--ink3);
  letter-spacing: 1px;
  line-height: 1.8;
}

/* ── 主体 ── */
.container {
  max-width: 720px;
  margin: 0 auto;
  padding: 24px 16px 40px;
  display: flex;
  flex-direction: column;
  gap: 16px;
}

/* ── 卡片 ── */
.card {
  background: var(--paper);
  border: 1px solid var(--border);
  border-radius: 4px;
  padding: 20px 22px;
  position: relative;
  box-shadow: 0 2px 12px rgba(44,26,8,0.08), inset 0 0 40px rgba(184,134,11,0.03);
  transition: opacity 0.2s, transform 0.2s;
}
.card.locked {
  opacity: 0.5;
  pointer-events: none;
}
.card-seal {
  position: absolute;
  top: -1px; right: 16px;
  background: var(--red);
  color: #fff;
  font-size: 10px;
  padding: 3px 10px;
  letter-spacing: 1px;
  font-family: 'Noto Serif SC', serif;
  border-radius: 0 0 4px 4px;
}
.card-title {
  font-family: 'Noto Serif SC', serif;
  font-size: 15px;
  color: var(--ink);
  margin-bottom: 14px;
  display: flex;
  align-items: center;
  gap: 8px;
}
.card-title-num {
  width: 22px; height: 22px;
  border-radius: 50%;
  background: var(--ink);
  color: var(--gold2);
  font-size: 11px;
  display: flex; align-items: center; justify-content: center;
  flex-shrink: 0;
  font-family: 'Noto Serif SC', serif;
}

/* ── 选项按钮 ── */
.opts { display: flex; flex-wrap: wrap; gap: 8px; }
.opt {
  padding: 7px 16px;
  font-size: 13px;
  font-family: 'Noto Sans SC', sans-serif;
  border: 1px solid var(--border);
  background: var(--paper2);
  color: var(--ink2);
  cursor: pointer;
  border-radius: 2px;
  transition: all 0.15s;
  letter-spacing: 0.5px;
}
.opt:hover { background: var(--paper3); border-color: var(--border2); }
.opt.on {
  background: var(--ink);
  border-color: var(--ink);
  color: var(--gold2);
}
.opt.hidden { display: none; }

.opt-custom {
  display: flex; align-items: center; gap: 6px;
  padding: 6px 12px;
  border: 1px dashed var(--border);
  background: transparent;
  border-radius: 2px;
  cursor: text;
}
.opt-custom.on { border-style: solid; background: var(--paper2); }
.opt-custom label { font-size: 12px; color: var(--ink3); white-space: nowrap; }
input.ci {
  background: transparent;
  border: none;
  border-bottom: 1px solid var(--border);
  font-family: 'Noto Sans SC', sans-serif;
  font-size: 13px;
  color: var(--ink);
  outline: none;
  width: 90px;
  padding: 2px 4px;
}
input.ci::placeholder { color: var(--ink3); opacity: 0.6; }

/* ── 数量 ── */
.count-row { display: flex; gap: 8px; align-items: center; flex-wrap: wrap; }
.count-btn {
  width: 52px; height: 44px;
  font-size: 20px;
  font-family: 'Noto Serif SC', serif;
  border: 1px solid var(--border);
  background: var(--paper2);
  color: var(--ink2);
  cursor: pointer;
  border-radius: 2px;
  transition: all 0.15s;
}
.count-btn:hover { background: var(--paper3); }
.count-btn.on { background: var(--ink); border-color: var(--ink); color: var(--gold2); }
.count-custom-wrap { display: flex; align-items: center; gap: 6px; font-size: 12px; color: var(--ink3); }
.count-custom-wrap input {
  width: 52px; height: 44px;
  text-align: center;
  font-size: 18px;
  font-family: 'Noto Serif SC', serif;
  border: 1px solid var(--border);
  background: rgba(255,255,255,0.5);
  color: var(--ink);
  border-radius: 2px;
  outline: none;
}

/* ── 错误提示 ── */
.err { font-size: 11px; color: var(--red); margin-top: 7px; display: none; }

/* ── 生成按钮 ── */
.gen-wrap { position: relative; }
.gen-btn {
  width: 100%;
  padding: 15px;
  background: var(--ink);
  color: var(--gold2);
  border: 1px solid var(--gold);
  font-family: 'Noto Serif SC', serif;
  font-size: 16px;
  letter-spacing: 5px;
  cursor: pointer;
  border-radius: 2px;
  transition: all 0.2s;
  position: relative;
  overflow: hidden;
}
.gen-btn::before {
  content: '';
  position: absolute;
  inset: 2px;
  border: 1px solid rgba(212,168,32,0.3);
  border-radius: 1px;
  pointer-events: none;
}
.gen-btn:hover { background: #3c2010; letter-spacing: 6px; }
.gen-sub {
  text-align: center;
  font-size: 11px;
  color: var(--ink3);
  margin-top: 8px;
  letter-spacing: 1px;
}

/* ── 输出区 ── */
.out-card { display: none; }

.out-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  margin-bottom: 14px;
}
.out-header-title {
  font-family: 'Noto Serif SC', serif;
  font-size: 15px;
  color: var(--ink);
}
.out-header-sub {
  font-size: 11px;
  color: var(--ink3);
  margin-top: 2px;
}

.tab-row {
  display: flex;
  gap: 0;
  border-bottom: 1px solid var(--border);
  margin-bottom: 14px;
  overflow-x: auto;
}
.tab-row::-webkit-scrollbar { display: none; }
.tab-btn {
  padding: 8px 14px;
  font-size: 12px;
  font-family: 'Noto Sans SC', sans-serif;
  border: none;
  background: transparent;
  color: var(--ink3);
  cursor: pointer;
  border-bottom: 2px solid transparent;
  margin-bottom: -1px;
  white-space: nowrap;
  transition: all 0.15s;
}
.tab-btn:hover { color: var(--ink); }
.tab-btn.on { color: var(--red); border-bottom-color: var(--red); font-weight: 500; }

.tab-panel { display: none; }
.tab-panel.show { display: block; }

.panel-hint {
  font-size: 11px;
  color: var(--ink3);
  margin-bottom: 8px;
  line-height: 1.7;
  display: flex;
  align-items: flex-start;
  gap: 5px;
}
.panel-hint::before { content: '▸'; color: var(--gold); flex-shrink: 0; }

.out-box {
  background: rgba(44,26,8,0.04);
  border: 1px solid rgba(200,160,96,0.4);
  border-left: 3px solid var(--gold);
  border-radius: 2px;
  padding: 14px 15px;
  font-size: 12.5px;
  line-height: 1.95;
  color: var(--ink);
  white-space: pre-wrap;
  word-break: break-all;
  max-height: 380px;
  overflow-y: auto;
  margin-bottom: 10px;
  font-family: 'Noto Sans SC', sans-serif;
}
.out-box::-webkit-scrollbar { width: 3px; }
.out-box::-webkit-scrollbar-thumb { background: var(--border); border-radius: 2px; }

.copy-btn {
  padding: 7px 20px;
  font-size: 12px;
  font-family: 'Noto Sans SC', sans-serif;
  border: 1px solid var(--border);
  background: var(--paper);
  color: var(--ink2);
  cursor: pointer;
  border-radius: 2px;
  transition: all 0.15s;
  letter-spacing: 1px;
}
.copy-btn:hover { background: var(--paper3); }

/* ── 折叠区 ── */
.foldable { margin-top: 4px; }
.fold-trigger {
  width: 100%;
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 12px 16px;
  background: var(--paper2);
  border: 1px solid var(--border);
  border-radius: 2px;
  cursor: pointer;
  font-size: 13px;
  color: var(--ink2);
  font-family: 'Noto Sans SC', sans-serif;
  transition: all 0.15s;
  margin-bottom: 2px;
}
.fold-trigger:hover { background: var(--paper3); }
.fold-trigger span { display: flex; align-items: center; gap: 8px; }
.fold-icon { transition: transform 0.2s; font-size: 12px; color: var(--ink3); }
.fold-content {
  display: none;
  background: var(--paper);
  border: 1px solid var(--border);
  border-top: none;
  border-radius: 0 0 2px 2px;
  padding: 14px 16px;
  font-size: 12.5px;
  color: var(--ink2);
  line-height: 1.9;
  margin-bottom: 8px;
}
.fold-content.open { display: block; }
.fold-trigger.open .fold-icon { transform: rotate(45deg); }

/* ── 底部 ── */
footer {
  text-align: center;
  padding: 28px 20px 36px;
  border-top: 1px solid var(--border);
  margin-top: 8px;
}
.footer-brand {
  font-family: 'Noto Serif SC', serif;
  font-size: 16px;
  color: var(--ink);
  letter-spacing: 3px;
  margin-bottom: 6px;
}
.footer-brand em { color: var(--red); font-style: normal; }
.footer-copy {
  font-size: 11px;
  color: var(--ink3);
  line-height: 1.9;
  letter-spacing: 0.5px;
}
.footer-divider {
  width: 40px; height: 1px;
  background: var(--border);
  margin: 10px auto;
}
</style>
</head>
<body>

<div class="top-bar">
  <span>阿坚 AIGC</span>
  <div class="top-dot"></div>
  <span>争议榜单图鉴</span>
  <div class="top-dot"></div>
  <span>提示词工坊</span>
</div>

<div class="hero">
  <div class="hero-badge">复古国风 · 文生图 · 多平台文案</div>
  <h1>争议榜单<em>图鉴</em><br>提示词生成器</h1>
  <p>三步生成 · 总图+分图+四平台文案 · 一键全出<br>适配香蕉Pro / 即梦 · 小红书 / 抖音 / 视频号 / 公众号</p>
</div>

<div class="container">

  <!-- 折叠手册 -->
  <div class="foldable">
    <button class="fold-trigger" onclick="toggleFold(this)">
      <span>📖 完整操作手册</span>
      <span class="fold-icon">+</span>
    </button>
    <div class="fold-content">
      <strong>第一步</strong>：选择类别（美食/水果/城市等）<br>
      <strong>第二步</strong>：选择榜单方向（最好吃/最难吃/最好玩等）<br>
      <strong>第三步</strong>：选择上榜数量（4/5/6个）<br>
      <strong>第四步</strong>：点击「生成全套提示词」<br>
      <strong>第五步</strong>：切换标签，分别复制以下内容：<br>
      　· 标签1「图片提示词」→ 总图+分图提示词全在里面，发给香蕉Pro / 即梦生图<br>
      　· 标签2「文案提示词」→ 小红书/抖音/视频号/公众号四平台发布文案，发给DeepSeek / Claude一次全出
    </div>
  </div>

  <div class="foldable">
    <button class="fold-trigger" onclick="toggleFold(this)">
      <span>⚠️ 注意事项（必读）</span>
      <span class="fold-icon">+</span>
    </button>
    <div class="fold-content">
      · 分图提示词中的 <strong>{名称}{排名}{特征}</strong> 需替换为实际内容后再发给生图工具<br>
      · 香蕉Pro（Nano Banana Pro）对中文提示词响应最好，推荐优先使用<br>
      · 生图有随机性，建议多跑几次选最好的（俗称抽卡）<br>
      · 文案提示词发给 DeepSeek联网版/Kimi/Claude 效果更准确<br>
      · 本工具生成内容仅供参考，请结合实际情况调整
    </div>
  </div>

  <!-- Step 1 -->
  <div class="card" id="card1">
    <div class="card-seal">第一步</div>
    <div class="card-title">
      <div class="card-title-num">1</div>
      想做哪个类别的榜单？
    </div>
    <div class="opts" id="catOpts">
      <button class="opt" data-cat="美食" data-group="food" onclick="selCat(this)">🍜 美食</button>
      <button class="opt" data-cat="水果" data-group="food" onclick="selCat(this)">🍓 水果</button>
      <button class="opt" data-cat="小吃" data-group="food" onclick="selCat(this)">🥟 小吃</button>
      <button class="opt" data-cat="蔬菜" data-group="food" onclick="selCat(this)">🥦 蔬菜</button>
      <button class="opt" data-cat="奶茶" data-group="food" onclick="selCat(this)">🧋 奶茶</button>
      <button class="opt" data-cat="零食" data-group="food" onclick="selCat(this)">🍿 零食</button>
      <button class="opt" data-cat="早餐" data-group="food" onclick="selCat(this)">🍳 早餐</button>
      <button class="opt" data-cat="甜点" data-group="food" onclick="selCat(this)">🍮 甜点</button>
      <button class="opt" data-cat="城市" data-group="place" onclick="selCat(this)">🏙️ 城市</button>
      <button class="opt" data-cat="景点" data-group="place" onclick="selCat(this)">🏔️ 景点</button>
      <div class="opt-custom" id="catCustomWrap">
        <label>自定义：</label>
        <input class="ci" id="catCI" placeholder="输入类别" oninput="onCatCI()" onfocus="focusCatCI()">
      </div>
    </div>
    <div class="err" id="catErr">请先选择一个类别</div>
  </div>

  <!-- Step 2 -->
  <div class="card locked" id="card2">
    <div class="card-seal">第二步</div>
    <div class="card-title">
      <div class="card-title-num">2</div>
      要做哪个方向的榜单？
    </div>
    <div class="opts" id="dirOpts">
      <button class="opt hidden" data-dir="最好吃" data-for="food" onclick="selDir(this)">😋 最好吃</button>
      <button class="opt hidden" data-dir="最难吃" data-for="food" onclick="selDir(this)">🤢 最难吃</button>
      <button class="opt hidden" data-dir="最上瘾" data-for="food" onclick="selDir(this)">🔥 最上瘾</button>
      <button class="opt hidden" data-dir="最奇特" data-for="food,place" onclick="selDir(this)">🤔 最奇特</button>
      <button class="opt hidden" data-dir="最争议" data-for="food" onclick="selDir(this)">⚡ 最争议</button>
      <button class="opt hidden" data-dir="最被低估" data-for="food,place" onclick="selDir(this)">💎 最被低估</button>
      <button class="opt hidden" data-dir="最好玩" data-for="place" onclick="selDir(this)">🎉 最好玩</button>
      <button class="opt hidden" data-dir="最值得去" data-for="place" onclick="selDir(this)">📍 最值得去</button>
      <button class="opt hidden" data-dir="最出片" data-for="place" onclick="selDir(this)">📸 最出片</button>
      <button class="opt hidden" data-dir="最小众" data-for="place" onclick="selDir(this)">🗺️ 最小众</button>
      <button class="opt hidden" data-dir="最好吃" data-for="custom" onclick="selDir(this)">😋 最好吃</button>
      <button class="opt hidden" data-dir="最难吃" data-for="custom" onclick="selDir(this)">🤢 最难吃</button>
      <button class="opt hidden" data-dir="最上瘾" data-for="custom" onclick="selDir(this)">🔥 最上瘾</button>
      <button class="opt hidden" data-dir="最奇特" data-for="custom" onclick="selDir(this)">🤔 最奇特</button>
      <button class="opt hidden" data-dir="最争议" data-for="custom" onclick="selDir(this)">⚡ 最争议</button>
      <button class="opt hidden" data-dir="最被低估" data-for="custom" onclick="selDir(this)">💎 最被低估</button>
      <button class="opt hidden" data-dir="最好玩" data-for="custom" onclick="selDir(this)">🎉 最好玩</button>
      <button class="opt hidden" data-dir="最值得去" data-for="custom" onclick="selDir(this)">📍 最值得去</button>
      <button class="opt hidden" data-dir="最出片" data-for="custom" onclick="selDir(this)">📸 最出片</button>
      <button class="opt hidden" data-dir="最小众" data-for="custom" onclick="selDir(this)">🗺️ 最小众</button>
      <div class="opt-custom hidden" id="dirCustomWrap" data-for="food,place,custom">
        <label>自定义：</label>
        <input class="ci" id="dirCI" placeholder="输入方向" oninput="onDirCI()" onfocus="focusDirCI()">
      </div>
    </div>
    <div class="err" id="dirErr">请选择一个方向</div>
  </div>

  <!-- Step 3 -->
  <div class="card locked" id="card3">
    <div class="card-seal">第三步</div>
    <div class="card-title">
      <div class="card-title-num">3</div>
      榜单上几个？
    </div>
    <div class="count-row">
      <button class="count-btn" onclick="selCount(4,this)">4</button>
      <button class="count-btn" onclick="selCount(5,this)">5</button>
      <button class="count-btn" onclick="selCount(6,this)">6</button>
      <div class="count-custom-wrap">
        <input type="number" id="customCount" min="3" max="10" placeholder="自定" oninput="onCustomCount()">
        <span>个</span>
      </div>
    </div>
    <div class="err" id="cntErr">请选择数量（3-10个）</div>
  </div>

  <!-- 生成按钮 -->
  <div class="gen-wrap">
    <button class="gen-btn" onclick="generate()">生 成 全 套 提 示 词</button>
    <div class="gen-sub">总图 + 分图 + 小红书 + 抖音 + 视频号 · 一键全出</div>
  </div>

  <!-- 输出 -->
  <div class="card out-card" id="outCard">
    <div class="out-header">
      <div>
        <div class="out-header-title" id="outTitle">生成结果</div>
        <div class="out-header-sub">切换标签查看各类提示词，点击复制后发给对应AI工具</div>
      </div>
    </div>
    <div class="tab-row" id="tabRow"></div>
    <div id="tabPanels"></div>
  </div>

  <!-- 折叠手册底部 -->
  <div class="foldable">
    <button class="fold-trigger" onclick="toggleFold(this)">
      <span>🎯 平台使用说明</span>
      <span class="fold-icon">+</span>
    </button>
    <div class="fold-content">
      <strong>📸 总图/分图提示词</strong> → 香蕉Pro（Nano Banana Pro）/ 即梦5.0<br>
      <strong>📝 小红书文案</strong> → DeepSeek联网版 / Kimi / Claude（开启搜索）<br>
      　风格：闺蜜感·emoji多·互动引导·收藏钩子<br>
      <strong>📝 文案提示词（四平台）</strong> → DeepSeek联网版 / Claude / Kimi<br>
      　小红书·抖音·视频号·公众号，各50-100字发布文案，一次全出
      <strong>📱 视频号文案</strong> → DeepSeek / Claude<br>
      　风格：知识感·分享属性强·朋友圈传播
    </div>
  </div>

</div>

<!-- 底部版权 -->
<footer>
  <div class="footer-brand">阿坚 <em>AIGC</em></div>
  <div class="footer-divider"></div>
  <div class="footer-copy">
    © 2026 阿坚 AIGC · 版权所有<br>
    本工具生成内容由 AI 联网整理，仅供娱乐参考，请以实际情况为准<br>
    Made with ❤️ · 争议榜单图鉴提示词工坊 V2.0
  </div>
</footer>

<script>
var state = { cat: '', group: '', dir: '', count: 0 };

function toggleFold(btn) {
  var content = btn.nextElementSibling;
  btn.classList.toggle('open');
  content.classList.toggle('open');
}

function selCat(btn) {
  document.querySelectorAll('#catOpts .opt').forEach(function(b){ b.classList.remove('on'); });
  document.getElementById('catCustomWrap').classList.remove('on');
  document.getElementById('catCI').value = '';
  btn.classList.add('on');
  state.cat = btn.dataset.cat;
  state.group = btn.dataset.group;
  hideErr('catErr');
  updateDirOpts(state.group);
}
function focusCatCI() {
  document.querySelectorAll('#catOpts .opt').forEach(function(b){ b.classList.remove('on'); });
  document.getElementById('catCustomWrap').classList.add('on');
  state.group = 'custom';
  updateDirOpts('custom');
}
function onCatCI() {
  state.cat = document.getElementById('catCI').value.trim();
  state.group = 'custom';
  document.getElementById('catCustomWrap').classList.add('on');
  document.querySelectorAll('#catOpts .opt').forEach(function(b){ b.classList.remove('on'); });
  updateDirOpts('custom');
  hideErr('catErr');
}
function updateDirOpts(group) {
  state.dir = '';
  document.querySelectorAll('#dirOpts .opt, #dirCustomWrap').forEach(function(el){
    el.classList.remove('on'); el.classList.add('hidden');
  });
  document.querySelectorAll('#dirOpts .opt').forEach(function(el){
    if ((el.dataset.for || '').split(',').indexOf(group) !== -1) el.classList.remove('hidden');
  });
  document.getElementById('dirCustomWrap').classList.remove('hidden');
  document.getElementById('card2').classList.remove('locked');
  document.getElementById('card3').classList.add('locked');
  state.count = 0;
  document.querySelectorAll('.count-btn').forEach(function(b){ b.classList.remove('on'); });
  document.getElementById('customCount').value = '';
  hideErr('dirErr'); hideErr('cntErr');
}
function selDir(btn) {
  document.querySelectorAll('#dirOpts .opt').forEach(function(b){ b.classList.remove('on'); });
  document.getElementById('dirCustomWrap').classList.remove('on');
  document.getElementById('dirCI').value = '';
  btn.classList.add('on');
  state.dir = btn.dataset.dir;
  hideErr('dirErr');
  document.getElementById('card3').classList.remove('locked');
}
function focusDirCI() {
  document.querySelectorAll('#dirOpts .opt').forEach(function(b){ b.classList.remove('on'); });
  document.getElementById('dirCustomWrap').classList.add('on');
  state.dir = document.getElementById('dirCI').value.trim();
  document.getElementById('card3').classList.remove('locked');
}
function onDirCI() {
  state.dir = document.getElementById('dirCI').value.trim();
  document.querySelectorAll('#dirOpts .opt').forEach(function(b){ b.classList.remove('on'); });
  document.getElementById('dirCustomWrap').classList.add('on');
  document.getElementById('card3').classList.remove('locked');
  hideErr('dirErr');
}
function selCount(n, btn) {
  state.count = n;
  document.querySelectorAll('.count-btn').forEach(function(b){ b.classList.remove('on'); });
  btn.classList.add('on');
  document.getElementById('customCount').value = '';
  hideErr('cntErr');
}
function onCustomCount() {
  var v = parseInt(document.getElementById('customCount').value);
  if (v >= 3 && v <= 10) { state.count = v; document.querySelectorAll('.count-btn').forEach(function(b){ b.classList.remove('on'); }); hideErr('cntErr'); }
  else state.count = 0;
}
function showErr(id) { document.getElementById(id).style.display = 'block'; }
function hideErr(id) { document.getElementById(id).style.display = 'none'; }

function generate() {
  var cat = state.cat || document.getElementById('catCI').value.trim();
  var dir = state.dir || document.getElementById('dirCI').value.trim();
  var cnt = state.count || parseInt(document.getElementById('customCount').value);
  var ok = true;
  if (!cat) { showErr('catErr'); ok = false; } else hideErr('catErr');
  if (!dir) { showErr('dirErr'); ok = false; } else hideErr('dirErr');
  if (!cnt || cnt < 3 || cnt > 10) { showErr('cntErr'); ok = false; } else hideErr('cntErr');
  if (!ok) return;

  var isPlace = (state.group === 'place');
  var title = '中国' + dir + '的' + cnt + '种' + cat;

  var imgContent = '【总图提示词】\n发给香蕉Pro / 即梦5.0，生成「' + title + '」汇总海报\n\n' + buildMain(title, cat, dir, cnt, isPlace) + '\n\n\n' + '═'.repeat(30) + '\n\n【分图提示词】\n把{名称}{排名}{核心特征}替换为实际内容后，发给香蕉Pro逐张生图\n\n' + buildSub(cat, dir, isPlace);

  var copyContent = '【文案提示词·小红书 / 抖音 / 视频号 三平台全出】\n发给DeepSeek联网版 / Claude / Kimi，一次生成三个平台的配套文案\n\n' + buildAllCopy(title, cat, dir, cnt);

  var panels = [
    { label: '🖼 图片提示词（总图+分图）', hint: '复制发给香蕉Pro / 即梦5.0 · 总图提示词在上方，分图提示词在下方', content: imgContent },
    { label: '📝 文案提示词（四平台）', hint: '复制发给DeepSeek联网版 / Claude · 小红书+抖音+视频号+公众号一次全出', content: copyContent }
  ];

  document.getElementById('outTitle').textContent = '「' + title + '」· 全套提示词';
  renderOutput(panels);
}

function buildMain(title, cat, dir, cnt, isPlace) {
  var isFood = !isPlace;
  var bowl = isFood
    ? '画面正中央是一只精美青花瓷大碗，碗内堆满模糊的' + cat + '，碗的周围有绿色气味波浪向四周扩散，中央图案占画面约20%大小。'
    : '画面正中央是一幅古风地图卷轴，卷轴周围有云雾飘散，中央图案占画面约20%大小。';
  var people = isFood
    ? '第一人远远站着抬手捂鼻表情嫌弃皱眉；第二人弯腰干呕捂嘴表情痛苦；第三人正在吃' + cat + '表情纠结五官扭曲；第四人捂嘴快速跑开身后留下速度线；第五人老者淡然端着碗享用表情满足从容。'
    : '第一人背着行囊兴奋出发；第二人到达目的地张大嘴巴惊叹；第三人举起相机疯狂拍照；第四人坐地摘帽擦汗休息；第五人老者悠然端茶满足欣赏。';
  var sL = isFood ? dir + '榜' : '必去榜';
  var sR = isFood ? '慎入' : '宝藏之地';
  var sub = isFood ? '味觉极限挑战图鉴·民间黑榜合集' : '宝藏地点图鉴·民间好评合集';
  var sBL = isFood ? '民间认证' : '民间推荐';
  var sBR = isFood ? '味觉警示' : '亲测好玩';

  var p = '制作一张竖版9:16的复古中国图鉴海报，主题是「' + title + '」。\n';
  p += '整体风格：仿古博物馆图鉴，泛黄宣纸底色带真实水渍晕染痕迹，传统工笔插画，配色以米黄/赭石/朱红/墨色为主，全程中文，所有文字必须清晰可读。\n\n';
  p += '━━━━━━━━━━\n第一区：顶部卷轴标题（占画面顶部20%）\n━━━━━━━━━━\n';
  p += '一幅完整展开的仿古横卷轴，两端有圆柱形木轴卷起，卷轴边缘有做旧破损感。卷轴正中用粗壮毛笔书法写「' + title + '」，字体饱满有力，占满卷轴宽度。卷轴左上角紧贴一枚朱红方形印章写「' + sL + '」，右上角紧贴一枚朱红方形印章写「' + sR + '」。卷轴下方有一行小字：「' + sub + '」。\n\n';
  p += '━━━━━━━━━━\n第二区：核心榜单区（占画面中部55%）\n━━━━━━━━━━\n';
  p += bowl + '\n\n';
  p += cnt + '种' + cat + '按排名大小呈现，排名越高图标越大，围绕中央图案发散排列，每个旁边有清晰的大号中文名称和排名徽章：\n\n';
  p += '正右方：排名第一的' + cat + '——最大尺寸手绘工笔图，旁边是金色皇冠形状徽章写「第一名」，字号最大视觉最突出。\n';
  p += '右下方：排名第二的' + cat + '——中大尺寸手绘图，旁边银色圆形徽章写「第二名」。\n';
  p += '正上方：排名第三的' + cat + '——中等尺寸手绘图，旁边铜色圆形徽章写「第三名」。\n';
  p += '左下方：排名第四的' + cat + '——中小尺寸手绘图，旁边素色圆形徽章写「第四名」。\n';
  if (cnt >= 5) p += '正左方：排名第五的' + cat + '——最小尺寸手绘图，旁边素色圆形徽章写「第五名」。\n';
  if (cnt >= 6) p += '正下方：排名第六的' + cat + '——最小尺寸手绘图，旁边素色圆形徽章写「第六名」。\n';
  p += '\n每个' + cat + '的名称用粗体大字单独标注在图标旁边，字号明显大于徽章文字，确保清晰可读。' + cnt + '种' + cat + '大小有明显层次差异体现排名高低。\n\n';
  p += '━━━━━━━━━━\n第三区：底部人物场景（占画面底部20%）\n━━━━━━━━━━\n';
  p += '古代集市背景，五个身穿汉服的人物从左到右一字排开，动作夸张生动：' + people + '\n';
  p += '左下角有「' + sBL + '」朱红印章，右下角有「' + sBR + '」朱红印章。\n\n';
  p += '━━━━━━━━━━\n排版要求\n━━━━━━━━━━\n';
  p += '三个区域之间用细线分隔，整体像真实出版的古籍图鉴，所有中文文字准确无误字迹清晰，' + cat + '名称字号要大到一眼能看清，' + cnt + '种' + cat + '大小有明显层次差异体现排名高低。';
  return p;
}

function buildSub(cat, dir, isPlace) {
  var isFood = !isPlace;
  var leftTop = isFood
    ? '【VS对比贴纸】最顶部，米黄色仿古贴纸，横向三格：左格写「外表印象：{外表特征}」，中格朱红粗体大字「VS」，右格写「真实体验：{体验特征}」。'
    : '【亮点对比贴纸】米黄色仿古贴纸，横向：左格写「网友印象：{印象}」，中格朱红粗体「VS」，右格写「实际体验：{实际}」。';
  var leftMid = isFood
    ? '【{名称}整体写实图】精致工笔风格完整{名称}，细节极丰富，占左侧中上部约30%高度。'
    : '【{名称}标志性景观图】精致工笔风格{名称}最具代表性的景观，细节丰富，占左侧中上部约30%高度。';
  var leftBot = isFood
    ? '【{名称}剖面解构图】{名称}切开剖面，清晰露出内部结构。从剖面图四个方位伸出四条朱红色粗壮箭头，每条末端标注框：\n左上→「{结构特征1}」　右上→「{结构特征2}」\n左下→「{结构特征3}」　右下→「{结构特征4}」'
    : '【{名称}地图/全景图】地理位置示意图。四条朱红粗箭头指向：\n左上→「{亮点1}」　右上→「{亮点2}」\n左下→「{亮点3}」　右下→「{亮点4}」';
  var feats = isFood
    ? '✓ {口感特征}\n✓ {气味特征}\n✓ 爱者：{爱的理由}\n✓ 恨者：{恨的理由}\n✓ 争议指数：★★★★★'
    : '✓ 最佳季节：{季节}\n✓ 门票：{价格}\n✓ 必打卡：{景点}\n✓ 交通：{方式}\n✓ 推荐指数：★★★★★';
  var m1 = isFood ? '格1「初见」：古装男子走在街道突然停步，闻到气味四处张望，表情困惑皱眉。'
    : '格1「种草」：旅行者刷到{名称}图片，眼睛发光立刻加入心愿清单，表情兴奋。';
  var m2 = isFood ? '格2「靠近」：同一男子被朋友推着强行靠近{名称}，全身后仰抗拒，表情极度痛苦，朋友兴奋大笑。'
    : '格2「出发」：旅行者背行囊兴奋出发，身后留下速度线，满心期待。';
  var m3 = isFood ? '格3「入口」：男子硬着头皮将{名称}送入口，五官极度扭曲，头顶冒出气味线条和感叹号「！！！」，表情崩溃至极。'
    : '格3「到达」：旅行者亲眼见到{名称}，比图片更震撼，张大嘴双眼发光，疯狂拍照，表情惊叹。';
  var m4 = isFood ? '格4「两极」：左边白发老者淡然端碗享用，表情满足；右边同一男子抱头狂奔逃离，身后速度线，两极对比强烈。'
    : '格4「两极」：左边旅游博主疯狂拍照兴奋尖叫；右边普通游客拍完就走，表情平淡，对比强烈。';
  var dataBar = isFood
    ? '上方：「{名称}爱好者 {X}%」vs「厌恶者 {Y}%」\n横向进度条：左边{X}%金黄色填充写「{X}%」，右边{Y}%灰褐色填充写「{Y}%」，有仿古边框。'
    : '上方：「想去的人 {X}%」vs「去过还想再去 {Y}%」\n横向进度条：左金黄色「{X}%」，右朱红色「{Y}%」。';
  var botInfo = isFood
    ? '最底一行：「产地·{产地}·常见做法·{做法}·营养·{营养}·争议指数★★★★★」'
    : '最底一行：「位置·{省市}·最佳季节·{季节}·门票·{价格}·推荐指数★★★★☆」';

  var p = '制作一张竖版9:16的复古中国图鉴单页，专题介绍「{名称}」。\n';
  p += '整体风格：仿古博物馆图鉴，泛黄宣纸底色带自然水渍晕染痕迹，传统工笔插画风格，笔触细腻精致，配色古朴（米黄/赭石/朱红/墨色），所有文字清晰可读。\n\n';
  p += '【使用说明：把所有{花括号}内容替换为实际内容后再发给香蕉Pro生图】\n\n';
  p += '━━━━━━━━━━\n第一区：顶部标题（占画面顶部10%）\n━━━━━━━━━━\n';
  p += '左侧四分之三用极粗毛笔大字写「第{排名}名：{名称}」，字号极大冲击感强。右侧四分之一放金色大圆形徽章，中央写「' + dir + '榜冠军」红字（第一名），其他名次改为「' + dir + '榜·第{排名}名」，徽章底部有红色丝带垂下。标题下方朱红细横线贯穿分隔，下方居中副标题「{核心特征一句话}」。\n\n';
  p += '━━━━━━━━━━\n第二区：左侧主图区（左边44%宽，纵向10%到78%）\n━━━━━━━━━━\n';
  p += leftTop + '\n\n' + leftMid + '\n\n' + leftBot + '\n\n';
  p += '━━━━━━━━━━\n第三区：中间核心特征栏（中间12%宽，纵向10%到78%）\n━━━━━━━━━━\n';
  p += '朱红色粗线矩形边框竖向长条。顶部「核心特征」四字竖排加粗。框内六条勾选项，每条极短严格单行不换行，间距均匀留白充足：\n' + feats + '\n\n';
  p += '━━━━━━━━━━\n第四区：右侧四格分镜（右边44%宽，纵向10%到78%）\n━━━━━━━━━━\n';
  p += '四个等大方格竖向排列，每格有朱红仿古细线边框，四角卷曲纹样装饰。每格左上角场景名称，右上角阿拉伯数字编号：\n\n';
  p += m1 + '\n\n' + m2 + '\n\n' + m3 + '\n\n' + m4 + '\n\n';
  p += '━━━━━━━━━━\n第五区：底部数据区（占画面底部22%）\n━━━━━━━━━━\n';
  p += '上方朱红细横线贯穿分隔。底部从左到右三部分：\n\n';
  p += '【左侧数据条】\n' + dataBar + '\n\n';
  p += '【中间金句引用框】\n朱红细线矩形框，左上右下大号引号装饰，框内文字：「{名称}：{一句幽默网友金句}」。\n\n';
  p += '【底部通栏信息】\n' + botInfo + '\n\n';
  p += '━━━━━━━━━━\n整体排版要求\n━━━━━━━━━━\n';
  p += '左中右三栏严格对齐，五个区域层次分明，朱红细横线明确分隔。朱红箭头粗壮明显。分镜人物表情极度夸张，古风服饰细节丰富。核心特征框每条极短单行不换行，间距均匀留白充足。全程中文准确清晰。';
  return p;
}

function buildAllCopy(title, cat, dir, cnt) {
  var p = '你是一位专业的多平台内容创作者。\n\n';
  p += '【任务】\n';
  p += '联网搜索「' + title + '」的真实信息（网友评价、争议数据、冷知识），然后一次性输出以下四个平台的发布文案，每个平台单独分区，各平台文案50-100字，风格各有侧重，不要互相复制。\n\n';

  p += '════════════════════════\n';
  p += '一、小红书发布文案\n';
  p += '════════════════════════\n';
  p += '【标题】（20字内，含1-2个emoji，有点击欲）\n\n';
  p += '【正文（50-100字）】\n';
  p += '风格：闺蜜聊天感，口语化，有emoji点缀，开头一句戳心，中间点出' + cnt + '种' + cat + '的核心看点，结尾引导点赞收藏评论\n\n';
  p += '【标签（5-8个）】\n\n';

  p += '════════════════════════\n';
  p += '二、抖音发布文案\n';
  p += '════════════════════════\n';
  p += '【标题】（20字内，含emoji）\n\n';
  p += '【正文（50-100字）】\n';
  p += '风格：极短句，节奏感强，直接点题，有反差感，像随手配文，结尾一句引导评论\n\n';
  p += '【评论区置顶语】（15字内）\n\n';
  p += '【标签（3-5个）】\n\n';

  p += '════════════════════════\n';
  p += '三、视频号发布文案\n';
  p += '════════════════════════\n';
  p += '【标题】（20字内）\n\n';
  p += '【正文（50-100字）】\n';
  p += '风格：稍正式，有知识感，适合朋友圈转发，语言温和，结尾引导留言\n\n';
  p += '【标签（3-5个）】\n\n';

  p += '════════════════════════\n';
  p += '四、公众号发布文案\n';
  p += '════════════════════════\n';
  p += '【标题】（20字内，有悬念或反差感）\n\n';
  p += '【正文（50-100字）】\n';
  p += '风格：有深度，像一个懂生活的人在认真推荐，语言克制有质感，结尾引导阅读全文或留言\n\n';
  p += '【标签（3-5个）】';
  return p;
}

function buildXHS(title, cat, dir, cnt) {
  var p = '你是一位小红书爆款内容创作者，擅长写有争议、有话题的美食/生活类笔记。\n\n';
  p += '【任务】\n';
  p += '联网搜索「' + title + '」的相关信息：真实网友评价、争议数据、有趣冷知识，然后写一篇小红书爆款笔记。\n\n';
  p += '【三个备选标题（选一个最好的）】\n';
  p += '① 挑战型：用「你敢试试吗」「吃过的都沉默了」「99%的人不知道」引发好奇\n';
  p += '② 共鸣型：戳中南北饮食差异/家乡记忆/勇气挑战的场景\n';
  p += '③ 实用型：「一文搞懂」「建议收藏」直接给价值感\n';
  p += '每个标题含1-2个emoji，20字以内，有强烈点击欲\n\n';
  p += '【正文结构（800-1200字）】\n';
  p += '① 开头（3句话）：超强共鸣场景，让目标用户秒感「说的就是我」，第一句话必须是金句或问句\n';
  p += '② 榜单揭晓：从第' + cnt + '名到第1名逐一介绍，每个配真实网友神评论，用「划重点」「敲黑板」「注意了」等引导\n';
  p += '③ 冷知识彩蛋：一个大多数人不知道的有趣事实，用「你知道吗」引出\n';
  p += '④ 互动结尾：引导评论「你吃过哪个」「你是爱它还是怕它」「第X名你投票吗」，引导点赞收藏\n\n';
  p += '【写作风格】\n';
  p += '闺蜜聊天感，口语化，幽默有趣，多引用网友神评论，短句多分段，每段不超过3行，emoji每段1-2个，真实不浮夸\n\n';
  p += '【结尾标签（8-10个）】\n';
  p += '#' + cat + ' #' + dir + cat + ' #中国美食 #饮食文化 #美食冷知识 #争议美食 #' + cat + '推荐 #小红书美食';
  return p;
}

function buildDY(title, cat, dir, cnt) {
  var p = '你是一位抖音爆款短视频脚本创作者，擅长写口播节奏感强、评论区互动效果好的内容。\n\n';
  p += '【任务】\n';
  p += '联网搜索「' + title + '」的真实数据和网友评价，写一个60-90秒的口播脚本。\n\n';
  p += '【视频结构】\n\n';
  p += '【开头钩子（前3秒，必须极强）】\n';
  p += '选一种开头方式：\n';
  p += '· 争议型：「今天说一个让南北方人打起来的话题——」\n';
  p += '· 挑战型：「这' + cnt + '种' + cat + '，每一个都是人间酷刑，你吃过几个？」\n';
  p += '· 反转型：「看起来越好看的' + cat + '，吃起来越让你崩溃，我说的是……」\n\n';
  p += '【主体内容（30-50秒）】\n';
  p += '从第' + cnt + '名到第1名倒数揭晓，每个' + cat + '：\n';
  p += '· 一句话描述外表（制造期待）\n';
  p += '· 一句话描述真实体验（制造反差）\n';
  p += '· 引用一条网友神评论（制造共鸣）\n';
  p += '节奏要快，每个' + cat + '不超过15秒，语言口语化，有停顿感\n\n';
  p += '【结尾互动（最后5秒）】\n';
  p += '引导评论：「你觉得第一名应该是谁？评论区告诉我」\n';
  p += '引导关注：「关注我，下期继续扒」\n\n';
  p += '【口播要求】\n';
  p += '语速适中，重点词加重语气，有节奏感，像朋友聊天不像念稿子，全程口语化，避免书面语\n\n';
  p += '【配套文案】\n';
  p += '同时输出视频标题（20字内含emoji）、封面文案（10字内）、评论区置顶引导语（30字内）';
  return p;
}

function buildSPH(title, cat, dir, cnt) {
  var p = '你是一位微信视频号/公众号内容创作者，擅长写有知识感、适合朋友圈转发分享的图文内容。\n\n';
  p += '【任务】\n';
  p += '联网搜索「' + title + '」的真实信息，写一篇适合视频号图文和公众号推文的内容。\n\n';
  p += '【标题（三选一）】\n';
  p += '① 知识型：「盘点' + title + '，第一名你肯定没想到」\n';
  p += '② 文化型：聚焦地域饮食文化差异，有深度有内涵\n';
  p += '③ 共鸣型：「这' + cnt + '种' + cat + '，终于有人说实话了」\n\n';
  p += '【正文结构（600-800字）】\n';
  p += '① 引言（1段）：从一个有趣的文化现象或社会观察切入，引出话题，有知识感\n';
  p += '② 榜单正文：从第' + cnt + '名到第1名，每个' + cat + '配：\n';
  p += '   · 客观描述（外观/口感/产地背景）\n';
  p += '   · 为什么上榜（争议原因/文化背景）\n';
  p += '   · 有趣的冷知识或历史典故\n';
  p += '③ 总结（1段）：升华到饮食文化多样性，或「好不好吃因人而异」的包容性结尾\n';
  p += '④ 互动引导：「你最不能接受的是哪个？留言告诉我」\n\n';
  p += '【写作风格】\n';
  p += '知识感强但不枯燥，像一位懂吃懂生活的朋友在分享，语言温和客观，有深度，适合转发给父母长辈，分段清晰，小标题辅助阅读\n\n';
  p += '【配套内容】\n';
  p += '同时输出：\n';
  p += '· 视频号封面文案（15字内）\n';
  p += '· 朋友圈转发语（50字内，适合配图转发）\n';
  p += '· 5个话题标签';
  return p;
}

function renderOutput(panels) {
  var card = document.getElementById('outCard');
  var tabRow = document.getElementById('tabRow');
  var tabPanels = document.getElementById('tabPanels');
  card.style.display = 'block';
  tabRow.innerHTML = '';
  tabPanels.innerHTML = '';

  panels.forEach(function(p, idx) {
    var tab = document.createElement('button');
    tab.className = 'tab-btn' + (idx === 0 ? ' on' : '');
    tab.textContent = p.label;
    tab.onclick = (function(i){ return function(){ switchTab(i); }; })(idx);
    tabRow.appendChild(tab);

    var div = document.createElement('div');
    div.className = 'tab-panel' + (idx === 0 ? ' show' : '');

    var hint = document.createElement('div');
    hint.className = 'panel-hint';
    hint.textContent = p.hint;

    var box = document.createElement('div');
    box.className = 'out-box';
    box.id = 'box-' + idx;
    box.textContent = p.content;

    var btn = document.createElement('button');
    btn.className = 'copy-btn';
    btn.textContent = '复制';
    btn.onclick = (function(id, b){ return function(){
      navigator.clipboard.writeText(document.getElementById(id).textContent).catch(function(){});
      b.textContent = '已复制 ✓';
      setTimeout(function(){ b.textContent = '复制'; }, 1500);
    }; })('box-'+idx, btn);

    div.appendChild(hint);
    div.appendChild(box);
    div.appendChild(btn);
    tabPanels.appendChild(div);
  });

  card.scrollIntoView({ behavior: 'smooth', block: 'start' });
}

function switchTab(idx) {
  document.querySelectorAll('.tab-btn').forEach(function(t, i){ t.classList.toggle('on', i === idx); });
  document.querySelectorAll('.tab-panel').forEach(function(p, i){ p.classList.toggle('show', i === idx); });
}
</script>
</body>
</html>

<!DOCTYPE html>
<html lang="zh-CN">
<head>
<meta charset="UTF-8">
<meta name="viewport" content="width=device-width, initial-scale=1.0">
<title>一天认识一味中药 · 提示词工坊</title>
<style>
@import url('https://fonts.googleapis.com/css2?family=Noto+Serif+SC:wght@400;600;700&family=Noto+Sans+SC:wght@300;400;500&display=swap');

:root {
  --paper:  #f8f0dc;
  --paper2: #f0e4c4;
  --paper3: #e8d8b0;
  --ink:    #2c1a08;
  --ink2:   #5c3d1e;
  --ink3:   #8a6040;
  --red:    #c0321a;
  --gold:   #b8860b;
  --gold2:  #d4a820;
  --gold3:  #f0c840;
  --green:  #3d6a38;
  --border: #c8a060;
  --border2:#a07840;
  --bg:     #f2e8d0;
}

* { box-sizing: border-box; margin: 0; padding: 0; }

body {
  background: var(--bg);
  background-image:
    radial-gradient(ellipse at 20% 20%, rgba(184,134,11,0.08) 0%, transparent 50%),
    radial-gradient(ellipse at 80% 80%, rgba(61,106,56,0.06) 0%, transparent 50%);
  min-height: 100vh;
  font-family: 'Noto Sans SC', sans-serif;
  color: var(--ink);
}

/* ── 顶部条 ── */
.top-bar {
  background: var(--ink);
  padding: 8px 20px;
  display: flex; align-items: center; justify-content: center; gap: 12px;
}
.top-bar span {
  font-size: 11px; color: var(--gold2);
  letter-spacing: 3px; font-family: 'Noto Serif SC', serif;
}
.top-dot { width: 4px; height: 4px; border-radius: 50%; background: var(--gold2); opacity: 0.6; }

/* ── 主视觉区 ── */
.hero {
  text-align: center; padding: 36px 20px 28px; position: relative;
}
.hero::after {
  content: ''; position: absolute; bottom: 0; left: 50%; transform: translateX(-50%);
  width: 60%; height: 1px;
  background: linear-gradient(90deg, transparent, var(--border), transparent);
}
.hero-badge {
  display: inline-block; border: 1px solid var(--border);
  padding: 3px 14px; font-size: 10px; letter-spacing: 3px; color: var(--ink3);
  margin-bottom: 12px; border-radius: 20px; background: rgba(184,134,11,0.08);
}
.hero h1 {
  font-family: 'Noto Serif SC', serif; font-size: 28px; color: var(--ink);
  letter-spacing: 3px; margin-bottom: 8px; line-height: 1.3;
}
.hero h1 em { color: var(--red); font-style: normal; }
.hero p { font-size: 13px; color: var(--ink3); letter-spacing: 1px; line-height: 1.9; }

/* ── 主容器 ── */
.container { max-width: 720px; margin: 0 auto; padding: 24px 16px 40px; display: flex; flex-direction: column; gap: 16px; }

/* ── 卡片 ── */
.card {
  background: var(--paper); border: 1px solid var(--border); border-radius: 4px;
  padding: 20px 22px; position: relative;
  box-shadow: 0 2px 12px rgba(44,26,8,0.08), inset 0 0 40px rgba(184,134,11,0.03);
}
.card-seal {
  position: absolute; top: -1px; right: 16px;
  background: var(--red); color: #fff; font-size: 10px;
  padding: 3px 10px; letter-spacing: 1px;
  font-family: 'Noto Serif SC', serif; border-radius: 0 0 4px 4px;
}
.card-title {
  font-family: 'Noto Serif SC', serif; font-size: 15px; color: var(--ink);
  margin-bottom: 14px; display: flex; align-items: center; gap: 8px;
}
.card-title-num {
  width: 22px; height: 22px; border-radius: 50%;
  background: var(--ink); color: var(--gold2); font-size: 11px;
  display: flex; align-items: center; justify-content: center;
  flex-shrink: 0; font-family: 'Noto Serif SC', serif;
}

/* ── 药材输入区 ── */
.input-row { display: flex; gap: 8px; margin-bottom: 14px; }
.herb-input {
  flex: 1; height: 48px; padding: 0 16px;
  border: 1px solid var(--border); border-radius: 3px;
  background: rgba(255,255,255,0.6); color: var(--ink);
  font-family: 'Noto Serif SC', serif; font-size: 18px; letter-spacing: 4px; outline: none;
  transition: border-color .2s;
}
.herb-input:focus { border-color: var(--red); }
.herb-input::placeholder { font-family: 'Noto Sans SC', sans-serif; font-size: 13px; letter-spacing: 1px; color: var(--ink3); }

.gen-btn-main {
  height: 48px; padding: 0 28px;
  background: var(--ink); color: var(--gold2);
  border: 1px solid var(--gold); border-radius: 3px;
  font-family: 'Noto Serif SC', serif; font-size: 14px; letter-spacing: 3px;
  cursor: pointer; white-space: nowrap; transition: all .2s;
}
.gen-btn-main:hover { background: #3c2010; letter-spacing: 4px; }

/* ── 快选药材 ── */
.chips-label { font-size: 11px; color: var(--ink3); letter-spacing: 1px; margin-bottom: 8px; }
.chips { display: flex; flex-wrap: wrap; gap: 6px; }
.chip {
  padding: 5px 13px; border: 1px solid var(--border); border-radius: 2px;
  background: var(--paper2); color: var(--ink2);
  font-family: 'Noto Serif SC', serif; font-size: 13px; letter-spacing: 2px;
  cursor: pointer; transition: all .15s;
}
.chip:hover { background: var(--paper3); border-color: var(--border2); transform: translateY(-1px); }
.chip.toxic { border-color: #c8604040; color: #8a3020; }
.chip.toxic:hover { border-color: var(--red); color: var(--red); }
.chip-toxic-dot { display: inline-block; width: 5px; height: 5px; border-radius: 50%; background: var(--red); margin-right: 3px; vertical-align: middle; opacity: 0.7; }

.err { font-size: 11px; color: var(--red); margin-top: 7px; display: none; }

/* ── 折叠区 ── */
.foldable { margin-top: 0; }
.fold-trigger {
  width: 100%; display: flex; align-items: center; justify-content: space-between;
  padding: 12px 16px; background: var(--paper2); border: 1px solid var(--border);
  border-radius: 2px; cursor: pointer; font-size: 13px; color: var(--ink2);
  font-family: 'Noto Sans SC', sans-serif; transition: all .15s; margin-bottom: 2px;
}
.fold-trigger:hover { background: var(--paper3); }
.fold-trigger span { display: flex; align-items: center; gap: 8px; }
.fold-icon { transition: transform .2s; font-size: 12px; color: var(--ink3); }
.fold-content {
  display: none; background: var(--paper); border: 1px solid var(--border);
  border-top: none; border-radius: 0 0 2px 2px; padding: 14px 16px;
  font-size: 12.5px; color: var(--ink2); line-height: 1.95; margin-bottom: 0;
}
.fold-content.open { display: block; }
.fold-trigger.open .fold-icon { transform: rotate(45deg); }

/* ── 生成按钮（全宽） ── */
.gen-wrap { position: relative; }
.gen-btn-full {
  width: 100%; padding: 15px;
  background: var(--ink); color: var(--gold2);
  border: 1px solid var(--gold);
  font-family: 'Noto Serif SC', serif; font-size: 16px; letter-spacing: 5px;
  cursor: pointer; border-radius: 2px; transition: all .2s; position: relative; overflow: hidden;
}
.gen-btn-full::before {
  content: ''; position: absolute; inset: 2px;
  border: 1px solid rgba(212,168,32,0.3); border-radius: 1px; pointer-events: none;
}
.gen-btn-full:hover { background: #3c2010; letter-spacing: 6px; }
.gen-sub { text-align: center; font-size: 11px; color: var(--ink3); margin-top: 8px; letter-spacing: 1px; }

/* ── 输出区 ── */
.out-card { display: none; }

.out-header { display: flex; align-items: flex-start; justify-content: space-between; margin-bottom: 14px; }
.out-header-title { font-family: 'Noto Serif SC', serif; font-size: 15px; color: var(--ink); }
.out-header-sub { font-size: 11px; color: var(--ink3); margin-top: 2px; }

.tab-row {
  display: flex; gap: 0; border-bottom: 1px solid var(--border);
  margin-bottom: 14px; overflow-x: auto;
}
.tab-row::-webkit-scrollbar { display: none; }
.tab-btn {
  padding: 8px 14px; font-size: 12px; font-family: 'Noto Sans SC', sans-serif;
  border: none; background: transparent; color: var(--ink3);
  cursor: pointer; border-bottom: 2px solid transparent; margin-bottom: -1px;
  white-space: nowrap; transition: all .15s;
}
.tab-btn:hover { color: var(--ink); }
.tab-btn.on { color: var(--red); border-bottom-color: var(--red); font-weight: 500; }

.tab-panel { display: none; }
.tab-panel.show { display: block; }

.panel-hint {
  font-size: 11px; color: var(--ink3); margin-bottom: 8px;
  line-height: 1.7; display: flex; align-items: flex-start; gap: 5px;
}
.panel-hint::before { content: '▸'; color: var(--gold); flex-shrink: 0; }

.out-box {
  background: rgba(44,26,8,0.04); border: 1px solid rgba(200,160,96,0.4);
  border-left: 3px solid var(--gold); border-radius: 2px;
  padding: 14px 15px; font-size: 12.5px; line-height: 1.95; color: var(--ink);
  white-space: pre-wrap; word-break: break-all;
  max-height: 380px; overflow-y: auto; margin-bottom: 10px;
  font-family: 'Noto Sans SC', sans-serif;
}
.out-box::-webkit-scrollbar { width: 3px; }
.out-box::-webkit-scrollbar-thumb { background: var(--border); border-radius: 2px; }

.copy-btn {
  padding: 7px 20px; font-size: 12px; font-family: 'Noto Sans SC', sans-serif;
  border: 1px solid var(--border); background: var(--paper); color: var(--ink2);
  cursor: pointer; border-radius: 2px; transition: all .15s; letter-spacing: 1px;
}
.copy-btn:hover { background: var(--paper3); }
.copy-btn.ok { background: var(--green) !important; border-color: var(--green) !important; color: #fff !important; }

/* ── 徽章行 ── */
.badge-row { display: flex; gap: 8px; flex-wrap: wrap; margin-bottom: 12px; }
.badge {
  display: inline-flex; align-items: center; gap: 4px;
  padding: 3px 10px; border-radius: 20px; font-size: 11px; letter-spacing: 0.5px;
}
.badge-green { background: rgba(61,106,56,0.1); border: 1px solid rgba(61,106,56,0.3); color: var(--green); }
.badge-red   { background: rgba(192,50,26,0.08); border: 1px solid rgba(192,50,26,0.25); color: var(--red); }
.badge-gold  { background: rgba(184,134,11,0.1); border: 1px solid rgba(184,134,11,0.3); color: var(--gold); }

/* ── footer ── */
footer { text-align: center; padding: 28px 20px 36px; border-top: 1px solid var(--border); margin-top: 8px; }
.footer-brand { font-family: 'Noto Serif SC', serif; font-size: 16px; color: var(--ink); letter-spacing: 3px; margin-bottom: 6px; }
.footer-brand em { color: var(--red); font-style: normal; }
.footer-divider { width: 40px; height: 1px; background: var(--border); margin: 10px auto; }
.footer-copy { font-size: 11px; color: var(--ink3); line-height: 1.9; letter-spacing: 0.5px; }

@keyframes rise { from { opacity:0; transform:translateY(14px) } to { opacity:1; transform:none } }
.animate-rise { animation: rise .35s ease both; }
</style>
</head>
<body>

<div class="top-bar">
  <span>一天认识一味中药</span>
  <div class="top-dot"></div>
  <span>文生图提示词工坊</span>
  <div class="top-dot"></div>
  <span>联网核实版</span>
</div>

<div class="hero">
  <div class="hero-badge">水彩工笔 · 信息图谱 · 联网查资料</div>
  <h1>中药图文<em>提示词</em><br>生成器</h1>
  <p>输入药材名 → 生成「图片提示词 + 小红书文案提示词」<br>含联网查资料指令 · 适配 GPT Image 2 / 香蕉Pro / 即梦</p>
</div>

<div class="container">

  <!-- 使用手册 -->
  <div class="foldable">
    <button class="fold-trigger" onclick="toggleFold(this)">
      <span>📖 完整使用手册</span>
      <span class="fold-icon">+</span>
    </button>
    <div class="fold-content">
      <strong>第一步</strong>：输入药材名（或点快选）→ 点「生成提示词」<br>
      <strong>第二步</strong>：切换标签，分别复制两类提示词：<br>
      　· 标签1「🎨 图片提示词」→ 发给 <strong>开了联网的 Claude</strong>，Claude 先联网查资料再输出文生图提示词，再发给 GPT Image 2 / 香蕉Pro / 即梦出图<br>
      　· 标签2「📱 小红书文案提示词」→ 发给 <strong>Claude / DeepSeek（开联网）</strong>，一次生成标题+正文+话题标签<br>
      <br>
      <strong>图片数量：</strong>普通药材 = 总图1 + 分图5，共 <strong>6张</strong>；有毒药材多一张安全用药专项，共 <strong>7张</strong><br>
      <strong>联网指令：</strong>提示词中已内置搜索指令，Claude 会先联网查《中国药典》再输出，确保知识准确
    </div>
  </div>

  <!-- 注意事项 -->
  <div class="foldable">
    <button class="fold-trigger" onclick="toggleFold(this)">
      <span>⚠️ 注意事项（必读）</span>
      <span class="fold-icon">+</span>
    </button>
    <div class="fold-content">
      · 图片提示词请发给 <strong>已开启联网功能的 Claude</strong>，让 Claude 先查资料再输出文生图提示词<br>
      · GPT Image 2（ChatGPT）对医疗词汇审核较严，提示词已替换敏感措辞（如「禁服」→「不适合使用」）<br>
      · 红点 <span style="display:inline-block;width:6px;height:6px;border-radius:50%;background:#c0321a;vertical-align:middle;"></span> 标记的为有毒药材，会自动增加「安全用药专项」分图<br>
      · 文案提示词发给 <strong>DeepSeek 联网版 / Kimi / Claude</strong> 效果最佳<br>
      · 本工具生成内容仅供创作参考，具体医药知识以专业文献为准
    </div>
  </div>

  <!-- 输入卡 -->
  <div class="card">
    <div class="card-seal">输入药材</div>
    <div class="card-title">
      <div class="card-title-num">✦</div>
      输入药材名称，生成完整提示词
    </div>
    <div class="input-row">
      <input class="herb-input" id="herbInput" placeholder="输入药材名，如：川芎、附子、玫瑰花" />
      <button class="gen-btn-main" onclick="generate()">生 成</button>
    </div>
    <div class="chips-label">快速选择：</div>
    <div class="chips">
      <div class="chip" onclick="q('川芎')">川芎</div>
      <div class="chip" onclick="q('麦冬')">麦冬</div>
      <div class="chip" onclick="q('薏苡仁')">薏苡仁</div>
      <div class="chip" onclick="q('人参')">人参</div>
      <div class="chip" onclick="q('丹参')">丹参</div>
      <div class="chip" onclick="q('桂枝')">桂枝</div>
      <div class="chip" onclick="q('玫瑰花')">玫瑰花</div>
      <div class="chip" onclick="q('菊花')">菊花</div>
      <div class="chip" onclick="q('黄连')">黄连</div>
      <div class="chip" onclick="q('银耳')">银耳</div>
      <div class="chip toxic" onclick="q('附子')"><span class="chip-toxic-dot"></span>附子</div>
      <div class="chip toxic" onclick="q('半夏')"><span class="chip-toxic-dot"></span>半夏</div>
    </div>
    <div class="err" id="inputErr">请输入药材名称</div>
  </div>

  <!-- 输出区 -->
  <div class="card out-card animate-rise" id="outCard">
    <div class="out-header">
      <div>
        <div class="out-header-title" id="outTitle">生成结果</div>
        <div class="out-header-sub">切换标签查看两类提示词，复制后发给对应 AI 工具使用</div>
      </div>
    </div>
    <div class="badge-row" id="badgeRow"></div>
    <div class="tab-row" id="tabRow"></div>
    <div id="tabPanels"></div>
  </div>

  <!-- 平台说明 -->
  <div class="foldable">
    <button class="fold-trigger" onclick="toggleFold(this)">
      <span>🎯 各平台使用说明</span>
      <span class="fold-icon">+</span>
    </button>
    <div class="fold-content">
      <strong>🎨 图片提示词</strong> → Claude（开联网）→ Claude 查资料后输出文生图提示词 → 发给：<br>
      　· <strong>GPT Image 2</strong>（ChatGPT）/ <strong>香蕉Pro</strong>（Nano Banana Pro）/ <strong>即梦</strong> 5.0<br><br>
      <strong>📱 小红书文案提示词</strong> → DeepSeek 联网版 / Kimi / Claude（开搜索）<br>
      　风格：干货收藏型 · 3个备选标题 · 400-600字正文 · 15个话题标签 · 发布建议<br><br>
      <strong>⚠️ 关于字符问题</strong>：AI 文生图对中文字符渲染能力有限，出图后可用 Canva / 醒图 在图片上叠加文字
    </div>
  </div>

</div>

<footer>
  <div class="footer-brand">一天认识一味 <em>中药</em></div>
  <div class="footer-divider"></div>
  <div class="footer-copy">
    提示词工坊 · 联网核实版 V3.0 · <strong>阿坚AIGC</strong><br>
    本工具生成的提示词由 AI 联网整理，具体用药知识以《中国药典》为准<br>
    Made with ❤️ · 内容仅供科普学习，不构成任何医疗建议
  </div>
</footer>

<script>
const TOXIC_LIST = [
  '附子','川乌','草乌','白附子','半夏','天南星','马钱子',
  '巴豆','细辛','苍耳子','雷公藤','朱砂','雄黄','轻粉','砒霜',
  '蟾酥','全蝎','蜈蚣','水蛭','斑蝥','商陆','甘遂','芫花',
  '大戟','千金子','藜芦','常山','钩吻','洋金花','曼陀罗'
];

function toggleFold(btn) {
  var c = btn.nextElementSibling;
  btn.classList.toggle('open');
  c.classList.toggle('open');
}

function q(name) {
  document.getElementById('herbInput').value = name;
  generate();
}

document.getElementById('herbInput').addEventListener('keydown', function(e) {
  if (e.key === 'Enter') generate();
});

function generate() {
  var name = document.getElementById('herbInput').value.trim();
  if (!name) { document.getElementById('inputErr').style.display = 'block'; return; }
  document.getElementById('inputErr').style.display = 'none';

  var toxic = TOXIC_LIST.includes(name);
  var imgCount = toxic ? 7 : 6;
  var imgPrompt = buildImg(name, toxic);
  var xhsPrompt = buildXhs(name, toxic);

  // 徽章
  var badgeRow = document.getElementById('badgeRow');
  badgeRow.innerHTML =
    '<span class="badge badge-gold">📄 共 ' + imgCount + ' 张图片提示词</span>' +
    (toxic
      ? '<span class="badge badge-red">⚠ 有毒药材 · 含安全用药专项</span>'
      : '<span class="badge badge-green">✓ 普通药材</span>') +
    '<span class="badge badge-green">🔍 含联网查资料指令</span>';

  // 标题
  document.getElementById('outTitle').textContent = '「' + name + '」· 完整提示词';

  var panels = [
    {
      label: '🎨 图片提示词（含联网指令）',
      hint: '复制 → 发给已开启联网的 Claude → Claude 先查《中国药典》资料 → 再将输出的提示词发给 GPT Image 2 / 香蕉Pro / 即梦出图',
      content: imgPrompt,
      btnId: 'copyImg'
    },
    {
      label: '📝 三平台文案提示词',
      hint: '复制 → 把图片+这段提示词一起发给Claude → 输出视频号+小红书+抖音三套文案',
      content: xhsPrompt,
      btnId: 'copyXhs'
    }
  ];

  renderOutput(panels);

  var card = document.getElementById('outCard');
  card.style.display = 'block';
  card.classList.add('animate-rise');
  setTimeout(function(){ card.classList.remove('animate-rise'); }, 400);
  card.scrollIntoView({ behavior: 'smooth', block: 'start' });
}

function renderOutput(panels) {
  var tabRow = document.getElementById('tabRow');
  var tabPanels = document.getElementById('tabPanels');
  tabRow.innerHTML = '';
  tabPanels.innerHTML = '';

  panels.forEach(function(p, idx) {
    var tab = document.createElement('button');
    tab.className = 'tab-btn' + (idx === 0 ? ' on' : '');
    tab.textContent = p.label;
    tab.onclick = (function(i){ return function(){ switchTab(i); }; })(idx);
    tabRow.appendChild(tab);

    var div = document.createElement('div');
    div.className = 'tab-panel' + (idx === 0 ? ' show' : '');

    var hint = document.createElement('div');
    hint.className = 'panel-hint';
    hint.textContent = p.hint;

    var box = document.createElement('div');
    box.className = 'out-box';
    box.id = p.btnId + 'Box';
    box.textContent = p.content;

    var foot = document.createElement('div');
    foot.style.cssText = 'display:flex;align-items:center;justify-content:space-between;margin-top:2px;';

    var chars = document.createElement('span');
    chars.style.cssText = 'font-size:11px;color:var(--ink3);letter-spacing:1px;';
    chars.textContent = p.content.length + ' 字';

    var btnRow = document.createElement('div');
    btnRow.style.cssText = 'display:flex;gap:8px;';

    var expandBtn = document.createElement('button');
    expandBtn.className = 'copy-btn';
    expandBtn.style.cssText = 'font-size:11px;padding:5px 14px;';
    expandBtn.textContent = '展开全文 ▾';
    expandBtn.onclick = (function(b, btn){ return function(){
      var open = b.style.maxHeight === 'none';
      b.style.maxHeight = open ? '380px' : 'none';
      btn.textContent = open ? '展开全文 ▾' : '收起 ▴';
    }; })(box, expandBtn);

    var copyBtn = document.createElement('button');
    copyBtn.className = 'copy-btn';
    copyBtn.id = p.btnId + 'Btn';
    copyBtn.textContent = '复制提示词';
    copyBtn.onclick = (function(id, btn){ return function(){
      var text = document.getElementById(id).textContent;
      var done = function(){
        btn.textContent = '已复制 ✓'; btn.classList.add('ok');
        setTimeout(function(){ btn.textContent = '复制提示词'; btn.classList.remove('ok'); }, 2200);
      };
      if (navigator.clipboard) {
        navigator.clipboard.writeText(text).then(done).catch(function(){fallback(text);done();});
      } else { fallback(text); done(); }
    }; })(p.btnId + 'Box', copyBtn);

    btnRow.appendChild(expandBtn);
    btnRow.appendChild(copyBtn);
    foot.appendChild(chars);
    foot.appendChild(btnRow);

    div.appendChild(hint);
    div.appendChild(box);
    div.appendChild(foot);
    tabPanels.appendChild(div);
  });
}

function switchTab(idx) {
  document.querySelectorAll('.tab-btn').forEach(function(t, i){ t.classList.toggle('on', i === idx); });
  document.querySelectorAll('.tab-panel').forEach(function(p, i){ p.classList.toggle('show', i === idx); });
}

function fallback(text) {
  var ta = document.createElement('textarea');
  ta.value = text; ta.style.cssText = 'position:fixed;opacity:0;top:0;left:0;';
  document.body.appendChild(ta); ta.select();
  document.execCommand('copy'); document.body.removeChild(ta);
}

/* ═══════════════════════════════════════
   图片提示词构建函数
═══════════════════════════════════════ */
function buildImg(name, toxic) {
  var n = name;
  var imgCount = toxic ? 7 : 6;
  var toxicSearch = toxic ? '\n搜索6：「' + n + ' 毒性 炮制减毒 安全剂量 使用不当反应 处理方法」' : '';
  var toxicData = toxic ? '\n- 活性成分（可能导致不当反应的成分）\n- 炮制品种类及各自毒性强弱\n- 使用不当反应症状\n- 处理方法\n- 煎煮特殊要求（如需先煎）' : '';
  var toxicJudge = '搜索完成后，判断「' + n + '」是否属于有毒中药（依据：查到的资料中是否出现「有毒」「小毒」「大毒」「毒性」等字样）。\n- 若查到有毒性记录 → 图片数量+1，增加「安全用药专项」图，并在所有图的注意事项区重点标注\n- 若查到无毒性记录 → 正常输出6张图\n请在整理资料时注明：「毒性判断：有毒 / 无毒」';
  var toxicImg = toxic ? ('\n\n---\n\n【图7：分图⑥——' + n + ' 安全用药专项（有毒药材，此图必须严肃准确）】\n\n根据联网查到的毒性资料生成：\n\n顶部：大号橙红色警示横幅「⚠ ' + n + '具有毒性，请在专业人士指导下使用」，古典警示边框\n\n左侧「炮制处理」：根据查到的炮制品种类，并排展示生品与各炮制品（颜色形态差异明显），炮制步骤流程来自查到的工艺，每种炮制品标注查到的毒性强弱和适用场景\n\n中央「使用注意」：查到的活性成分（橙色框）；使用不当可能出现的反应列表（橙字，来自查到资料）；处理方法（绿字，来自查到资料）\n\n右侧「安全用法」：查到的建议用量范围（绿框）；需咨询医师的人群（橙框）；煎煮特殊要求如先煎时间（图示）；传统配伍注意标注\n\n底部极小字：「本图为中医药科普学习内容，仅供参考，请在专业人士指导下使用」\n\n配色：警示橙+安全绿强对比，米黄宣纸底\n\n数据来源：联网查询《中国药典》及权威中医药文献') : '';

  return '# 任务：为中药「' + n + '」生成 ' + imgCount + ' 张信息图的文生图提示词\n\n## 第一步：联网搜索（必须先做，不可跳过）\n\n请依次搜索以下关键词，获取准确资料后再开始生成：\n\n搜索1：「' + n + ' 中药 性味归经 功效主治 中国药典」\n搜索2：「' + n + ' 道地产区 采收季节 具体月份」\n搜索3：「' + n + ' 植物形态 药材外观 颜色 尺寸 质地」\n搜索4：「' + n + ' 经典配伍 代表方剂 名称」\n搜索5：「' + n + ' 鉴别要点 选购 真伪辨别 混淆品」' + toxicSearch + '\n\n搜索完成后，将查到的关键信息整理为：\n- 性味归经（来自《中国药典》原文）\n- 真实采收月份（精确到月）\n- 道地产区具体地名\n- 植物/药材真实形态描述\n- 核心功效（药典原文）\n- 经典配伍组合（4-6组）及代表方剂名称\n- 鉴别真伪的关键特征\n- 禁忌人群（药典原文）' + toxicData + '\n\n⚠ 毒性自动判断（必须执行）：\n' + toxicJudge + '\n\n---\n\n## 第二步：生成 ' + imgCount + ' 张文生图提示词（总图1张 + 分图' + (imgCount-1) + '张）\n\n**统一风格基调（所有图必须遵守）：**\n中国传统水彩工笔插画风格，古典宣纸纸张质感（米黄色底），朱红金色为主色调，精细手绘插图，古典卷轴边框装饰，竖版9:16比例，信息图谱排版，高收藏价值感\n\n**统一科普说明（每张图必须包含）：**\n每张图画面底部角落以极小字体注明：「本图为中医药科普学习内容，仅供参考，请在专业人士指导下使用」\n\n**注意事项区措辞规范（适用所有图）：**\n- 「孕妇慎用」→ 「特殊体质人群需咨询医师」\n- 「禁服/禁忌」→ 「不适合使用」\n- 「阴虚火旺」→ 「内热体质」\n- 「血热妄行」→ 「实热出血体质」\n- 「热病高热」→ 「发热人群」\n- 「月经过多」→ 「经期注意用量」\n- 「十九畏/十八反」→ 「传统配伍注意」\n- 「免责声明」→ 「科普说明」\n\n**每张提示词要求：**\n- 不少于300字\n- 所有数据（产区名、月份、功效原文、配伍药名、方剂名）必须来自第一步查到的资料\n- 描述具体到每个区域放什么内容、什么颜色、什么插图\n- 不得使用模糊表述如「相关插图」「适当内容」\n\n---\n\n【图1：总图——' + n + '完整知识图谱（封面主图）】\n\n根据联网查到的资料，详细描述以下画面布局：\n\n① 顶部：毛笔大字「' + n + '」（朱红书法体，字形厚重），横幅注明从药典查到的功效短语，右上角绘制' + n + '药材的精细水彩写实插图（根据查到的真实外形描述绘制：颜色/形状/质感全部准确），搭配古典青花药罐，顶部描金边框\n\n② 来源制作区：左侧绘制' + n + '原植物精细水彩（根据查到的植物形态），右侧绘制制作流程（步骤数量和内容来自查到的真实工艺），标注查到的真实道地产区地名和采收月份\n\n③ 性味归经功效区：左侧中医经络人体轮廓图，金色标注查到的归经（几条经络就画几条），右侧绘制与功效数量对应的圆形功效图标（每圆内有象征该功效的水彩插图），圆下方毛笔字注功效名\n\n④ 配伍区：中央' + n + '药材写实图，放射状展示查到的配伍药材（有几组就画几组），连线旁注配伍功效，查到的代表方剂用红色篆刻印章标注\n\n⑤ 注意事项区：查到的禁忌信息，警告图标+简洁图标化列表，措辞按上方规范\n\n⑥ 底部卷轴：描金卷轴，书法总结语「一句话认识' + n + '」，极小字注明科普说明\n\n数据来源：联网查询《中国药典》及权威中医药文献\n\n---\n\n【图2：分图①——' + n + '来源与制作】\n\n根据联网查到的资料生成详细画面描述（科属/药用部位/别名/植物形态/采收月份/制作步骤/道地产区）：\n\n左侧主图（60%）：根据查到的形态描述绘制' + n + '精细水彩写实图，多角度展示，各部位引线标注名称，颜色准确，有光影层次\n\n右侧流程（40%）：根据查到的真实工艺绘制步骤图，每步配手绘场景，步骤①标注查到的真实采收月份，川产/浙产等不同产区如有差异则分别标注\n\n底部：中国地图标注查到的具体产区地名 + 绿色贴士框（来自查到的知识）+ 极小字科普说明\n\n配色：草绿配米黄，朱红序号，金色标注线\n\n数据来源：联网查询《中国药典》及权威中医药文献\n\n---\n\n【图3：分图②——' + n + '性味归经与功效】\n\n根据联网查到的《中国药典》原文生成：\n\n顶部朱红横幅：白色毛笔字注明查到的「性味：XX，归XX经、XX经」原文\n\n中央左侧（经络图）：中医经络人体线条图，根据查到的归经条数，用金色虚线准确标注每条经络路径，旁注经络名\n\n中央右侧（功效圆图）：根据查到的功效条数生成对应数量的圆形图标（数量以查到为准，不多不少），每圆内设计贴合该功效的象征水彩插图，圆外毛笔字注功效名，圆下方来自查到的功效说明\n\n底部贴士框：来自查到的适用人群信息 + 极小字科普说明\n\n配色：朱红为主，金色装饰，米黄宣纸底\n\n数据来源：联网查询《中国药典》及权威中医药文献\n\n---\n\n【图4：分图③——' + n + '应用与配伍】\n\n根据联网查到的临床应用和配伍资料生成：\n\n上半部分（3格适应证）：根据查到的前3个临床常用症状，每格绘制对应的古典人物场景插图（人物状态体现该症状），格内标注症状名称和1句简短说明\n\n下半部分（配伍放射图）：中央绘制' + n + '药材精细水彩；根据查到的配伍组合，放射状展示对应药材（每味有写实水彩小图）；连线旁注查到的「配XX→功效」；代表方剂名用朱红篆刻印章标注在右下角\n\n底部极小字科普说明\n\n整体：金棕暖色调\n\n数据来源：联网查询《中国药典》及权威中医药文献\n\n---\n\n【图5：分图④——' + n + '鉴别与选购】\n\n根据联网查到的鉴别资料生成：\n\n中央主图（55%）：' + n + '药材精细水彩写实大图，正面+横截面+局部特写三视角，颜色/纹理/光泽按查到的描述精确还原，多条引线标注查到的各鉴别特征（外形/颜色/尺寸/气味/质地/断面）\n\n右上角绿色「选购清单」框：3条✓要点来自查到的优质品标准\n右下角橙色「注意提示」框：3条⚠警示来自查到的劣质品/造假手法/混淆品资料\n左下角：中国地图简图，标注查到的道地产区具体地名\n底部极小字科普说明\n\n配色：紫棕色调，专业鉴定图鉴风格\n\n数据来源：联网查询《中国药典》及权威中医药文献\n\n---\n\n【图6：分图⑤——' + n + '使用方法与注意事项】\n\n根据联网查到的用法用量和禁忌资料生成：\n\n顶部标题：「如何正确使用' + n + '」，朱红横幅\n\n左侧「用法用量」区：绘制常见用法图示（泡茶/煎汤/炖汤/入丸散等，根据查到的资料选择），每种用法配手绘场景小图，标注查到的安全用量范围\n\n中央「适合人群」区：根据查到的资料绘制3类适合人群画像（古典人物插图），每类旁注适用说明\n\n右侧「注意事项」区：橙色提示框，列出查到的全部注意人群，⚠图标逐条标注，措辞按上方规范（特殊体质人群需咨询医师 / 内热体质慎用 / 发热人群慎用 / 经期注意用量 / 传统配伍注意）\n\n底部：金色贴士框（1-2条来自查到的实用建议）+ 极小字科普说明\n\n配色：蓝绿安全色调为主，橙色警示点缀\n\n数据来源：联网查询《中国药典》及权威中医药文献' + toxicImg + '\n\n---\n\n## 第三步：输出格式要求\n\n- 按图1→图' + imgCount + '顺序依次输出，图1为总图，图2-' + imgCount + '为分图\n- 每张图之间用「────────────」分隔\n- 每张提示词末尾注明：「数据来源：联网查询《中国药典》及权威中医药文献」\n- 全部输出完毕后最后加：「本内容已联网核实，仅供学习参考，请在专业人士指导下使用」';
}

/* ═══════════════════════════════════════
   小红书文案提示词构建函数
═══════════════════════════════════════ */
function buildXhs(name, toxic) {
  var n = name;
  var toxicNote = toxic
    ? '\n\n⚠️ 特别提醒：' + n + '是有毒中药，文案中必须明确注明「需在中医师指导下使用」，禁忌部分不可轻描淡写。'
    : '';

  return '你是一位擅长三平台运营的AIGC内容创作者。\n我刚刚用AI生成了一张「' + n + '」中药科普图，请根据图片内容同时输出三平台配套文案：' + toxicNote + '\n\n【视频号文案】\n- 标题：1个，不超过20字，突出' + n + '的核心功效\n- 正文：150字，口语化，像懂中医的朋友分享，有温度\n- 结尾：引导点赞收藏转发\n\n【小红书文案】\n- 备选标题：3个，带emoji（🌿🍵✨），有收藏冲动，不超过20字\n- 正文：200字，口语化，功效+用法+适合人群+注意事项，知识密度高\n- 结尾：引导收藏+评论互动\n- 话题标签：15个，含 #一天认识一味中药 #中药科普 #' + n + ' #药食同源 #中医养生\n\n【抖音文案】\n- 备选标题：3个，带emoji，有点击欲，不超过20字\n- 正文：150字，节奏感强，中药科普感\n- 结尾：引导点赞收藏关注\n- 话题标签：8个\n\n⚠ 所有平台文案末尾固定加：本内容仅供健康科普参考，具体用药请遵医嘱';
}
</script>
</body>
</html>

<!DOCTYPE html>
<html lang="zh-CN">
<head>
<meta charset="UTF-8">
<meta name="viewport" content="width=device-width, initial-scale=1.0">
<title>每天认识一种花 · 提示词工坊</title>
<style>
@import url('https://fonts.googleapis.com/css2?family=Noto+Serif+SC:wght@400;600;700&family=Noto+Sans+SC:wght@300;400;500&display=swap');

:root {
  --paper:  #f5f0e8;
  --paper2: #ede5d0;
  --paper3: #e2d8be;
  --ink:    #1e2a1e;
  --ink2:   #3d5a3d;
  --ink3:   #6a8a6a;
  --accent: #6a8a52;
  --gold:   #8a7240;
  --gold2:  #b09050;
  --green:  #3d6a3d;
  --border: #a8b890;
  --border2:#7a9460;
  --bg:     #eef0e6;
  --fun-ink:   #1a1a2e;
  --fun-acc:   #e63946;
  --fun-acc2:  #ff6b6b;
  --fun-gold:  #ffd166;
  --fun-paper: #fff8f0;
  --fun-border:#ffb347;
}

* { box-sizing: border-box; margin: 0; padding: 0; }

body {
  background: var(--bg);
  min-height: 100vh;
  font-family: 'Noto Sans SC', sans-serif;
  color: var(--ink);
  transition: background 0.4s;
}
body.fun-mode {
  background: #1a1a2e;
  background-image:
    radial-gradient(ellipse at 20% 30%, rgba(230,57,70,0.12) 0%, transparent 50%),
    radial-gradient(ellipse at 80% 70%, rgba(255,209,102,0.1) 0%, transparent 50%);
}

.top-bar {
  background: var(--ink);
  padding: 8px 20px;
  display: flex; align-items: center; justify-content: center; gap: 12px;
  transition: background 0.4s;
}
body.fun-mode .top-bar { background: #0d0d1a; }
.top-bar span { font-size: 11px; color: var(--gold2); letter-spacing: 3px; font-family: 'Noto Serif SC', serif; }
body.fun-mode .top-bar span { color: var(--fun-gold); }
.top-dot { width: 4px; height: 4px; border-radius: 50%; background: var(--gold2); opacity: 0.6; }
body.fun-mode .top-dot { background: var(--fun-acc); }

.hero { text-align: center; padding: 32px 20px 24px; position: relative; }
.hero::after {
  content: ''; position: absolute; bottom: 0; left: 50%; transform: translateX(-50%);
  width: 60%; height: 1px;
  background: linear-gradient(90deg, transparent, var(--border), transparent);
}
body.fun-mode .hero::after { background: linear-gradient(90deg, transparent, var(--fun-border), transparent); }
.hero-badge {
  display: inline-block; border: 1px solid var(--border);
  padding: 3px 14px; font-size: 10px; letter-spacing: 3px; color: var(--ink3);
  margin-bottom: 12px; border-radius: 20px; background: rgba(61,106,61,0.08);
  transition: all 0.4s;
}
body.fun-mode .hero-badge { border-color: var(--fun-acc); color: var(--fun-acc2); background: rgba(230,57,70,0.1); }
.hero h1 { font-family: 'Noto Serif SC', serif; font-size: 26px; color: var(--ink); letter-spacing: 3px; margin-bottom: 6px; transition: color 0.4s; }
body.fun-mode .hero h1 { color: #fff; }
.hero h1 em { color: var(--green); font-style: normal; transition: color 0.4s; }
body.fun-mode .hero h1 em { color: var(--fun-gold); }
.hero p { font-size: 12px; color: var(--ink3); letter-spacing: 1px; line-height: 1.9; transition: color 0.4s; }
body.fun-mode .hero p { color: rgba(255,255,255,0.5); }

.mode-switch-wrap { display: flex; justify-content: center; padding: 20px 16px 0; }
.mode-switch {
  display: flex; border-radius: 4px; overflow: hidden;
  border: 1px solid var(--border); background: var(--paper2); transition: all 0.4s;
}
body.fun-mode .mode-switch { border-color: var(--fun-border); background: #16213e; }
.mode-btn {
  padding: 10px 24px; font-size: 13px; font-family: 'Noto Serif SC', serif;
  border: none; background: transparent; cursor: pointer;
  letter-spacing: 2px; transition: all 0.2s; color: var(--ink3);
}
.mode-btn.active { background: var(--green); color: #fff; }
.mode-btn.active.fun { background: var(--fun-acc); color: #fff; }
body.fun-mode .mode-btn { color: rgba(255,255,255,0.4); }
.mode-tag { font-size: 9px; display: block; letter-spacing: 1px; margin-top: 2px; opacity: 0.7; }

.container { max-width: 720px; margin: 0 auto; padding: 20px 16px 20px; display: flex; flex-direction: column; gap: 14px; }

.card {
  background: var(--paper); border: 1px solid var(--border); border-radius: 4px;
  padding: 20px 22px; position: relative;
  box-shadow: 0 2px 12px rgba(30,42,30,0.08); transition: all 0.4s;
}
body.fun-mode .card { background: #16213e; border-color: #2a2a4a; box-shadow: 0 2px 20px rgba(230,57,70,0.1); }
.card-seal {
  position: absolute; top: -1px; right: 16px;
  background: var(--green); color: #fff; font-size: 10px;
  padding: 3px 10px; letter-spacing: 1px;
  font-family: 'Noto Serif SC', serif; border-radius: 0 0 4px 4px; transition: background 0.4s;
}
body.fun-mode .card-seal { background: var(--fun-acc); }
.card-title { font-family: 'Noto Serif SC', serif; font-size: 15px; color: var(--ink); margin-bottom: 14px; display: flex; align-items: center; gap: 8px; transition: color 0.4s; }
body.fun-mode .card-title { color: #fff; }
.card-title-num {
  width: 22px; height: 22px; border-radius: 50%;
  background: var(--ink); color: var(--gold2); font-size: 11px;
  display: flex; align-items: center; justify-content: center; flex-shrink: 0; transition: all 0.4s;
}
body.fun-mode .card-title-num { background: var(--fun-acc); color: #fff; }

.mode-desc { border-radius: 3px; padding: 10px 14px; font-size: 12px; line-height: 1.8; margin-bottom: 14px; display: none; }
.mode-desc.show { display: block; }
.mode-desc.serious { background: rgba(61,106,61,0.08); border-left: 3px solid var(--green); color: var(--ink2); }
.mode-desc.fun-desc { background: rgba(230,57,70,0.1); border-left: 3px solid var(--fun-acc); color: var(--fun-acc2); }

.input-row { display: flex; gap: 8px; margin-bottom: 14px; }
.herb-input {
  flex: 1; height: 48px; padding: 0 16px;
  border: 1px solid var(--border); border-radius: 3px;
  background: rgba(255,255,255,0.6); color: var(--ink);
  font-family: 'Noto Serif SC', serif; font-size: 18px; letter-spacing: 4px; outline: none; transition: all 0.4s;
}
body.fun-mode .herb-input { background: rgba(255,255,255,0.05); border-color: #2a2a4a; color: #fff; }
body.fun-mode .herb-input::placeholder { color: rgba(255,255,255,0.2); }
.herb-input:focus { border-color: var(--green); }
body.fun-mode .herb-input:focus { border-color: var(--fun-acc); }
.herb-input::placeholder { font-family: 'Noto Sans SC', sans-serif; font-size: 13px; letter-spacing: 1px; color: var(--ink3); }
.gen-btn-main {
  height: 48px; padding: 0 24px;
  background: var(--ink); color: var(--gold2);
  border: 1px solid var(--gold); border-radius: 3px;
  font-family: 'Noto Serif SC', serif; font-size: 14px; letter-spacing: 3px;
  cursor: pointer; white-space: nowrap; transition: all .2s;
}
body.fun-mode .gen-btn-main { background: var(--fun-acc); color: #fff; border-color: var(--fun-acc2); }
.gen-btn-main:hover { opacity: 0.85; letter-spacing: 4px; }

.chips-label { font-size: 11px; color: var(--ink3); letter-spacing: 1px; margin-bottom: 8px; transition: color 0.4s; }
body.fun-mode .chips-label { color: rgba(255,255,255,0.35); }
.chips { display: flex; flex-wrap: wrap; gap: 6px; }
.chip {
  padding: 5px 13px; border: 1px solid var(--border); border-radius: 2px;
  background: var(--paper2); color: var(--ink2);
  font-family: 'Noto Serif SC', serif; font-size: 13px; letter-spacing: 2px;
  cursor: pointer; transition: all .15s;
}
.chip:hover { background: var(--paper3); border-color: var(--border2); transform: translateY(-1px); }
body.fun-mode .chip { background: rgba(255,255,255,0.05); border-color: #2a2a4a; color: rgba(255,255,255,0.6); }
body.fun-mode .chip:hover { background: rgba(230,57,70,0.15); border-color: var(--fun-acc); color: var(--fun-acc2); }
.chip-set { display: none; }
.chip-set.show { display: flex; flex-wrap: wrap; gap: 6px; }

.err { font-size: 11px; color: #c0321a; margin-top: 7px; display: none; }
body.fun-mode .err { color: var(--fun-acc2); }

.foldable { margin-top: 0; }
.fold-trigger {
  width: 100%; display: flex; align-items: center; justify-content: space-between;
  padding: 11px 16px; background: var(--paper2); border: 1px solid var(--border);
  border-radius: 2px; cursor: pointer; font-size: 13px; color: var(--ink2);
  font-family: 'Noto Sans SC', sans-serif; transition: all .15s; margin-bottom: 2px;
}
body.fun-mode .fold-trigger { background: #16213e; border-color: #2a2a4a; color: rgba(255,255,255,0.5); }
.fold-trigger:hover { background: var(--paper3); }
body.fun-mode .fold-trigger:hover { background: #1e2d4a; }
.fold-trigger span { display: flex; align-items: center; gap: 8px; }
.fold-icon { transition: transform .2s; font-size: 12px; }
.fold-content {
  display: none; background: var(--paper); border: 1px solid var(--border);
  border-top: none; border-radius: 0 0 2px 2px; padding: 14px 16px;
  font-size: 12.5px; color: var(--ink2); line-height: 1.95; transition: all 0.4s;
}
body.fun-mode .fold-content { background: #16213e; border-color: #2a2a4a; color: rgba(255,255,255,0.5); }
.fold-content.open { display: block; }
.fold-trigger.open .fold-icon { transform: rotate(45deg); }

.out-card { display: none; }
.out-header { margin-bottom: 14px; }
.out-header-title { font-family: 'Noto Serif SC', serif; font-size: 15px; color: var(--ink); transition: color 0.4s; }
body.fun-mode .out-header-title { color: #fff; }
.out-header-sub { font-size: 11px; color: var(--ink3); margin-top: 2px; transition: color 0.4s; }
body.fun-mode .out-header-sub { color: rgba(255,255,255,0.35); }

.tab-row { display: flex; gap: 0; border-bottom: 1px solid var(--border); margin-bottom: 14px; overflow-x: auto; transition: border-color 0.4s; }
body.fun-mode .tab-row { border-color: #2a2a4a; }
.tab-row::-webkit-scrollbar { display: none; }
.tab-btn {
  padding: 8px 14px; font-size: 12px; font-family: 'Noto Sans SC', sans-serif;
  border: none; background: transparent; color: var(--ink3);
  cursor: pointer; border-bottom: 2px solid transparent; margin-bottom: -1px;
  white-space: nowrap; transition: all .15s;
}
body.fun-mode .tab-btn { color: rgba(255,255,255,0.35); }
.tab-btn.on { color: var(--green); border-bottom-color: var(--green); font-weight: 500; }
body.fun-mode .tab-btn.on { color: var(--fun-acc2); border-bottom-color: var(--fun-acc); }
.tab-panel { display: none; }
.tab-panel.show { display: block; }

.panel-hint { font-size: 11px; color: var(--ink3); margin-bottom: 8px; line-height: 1.7; display: flex; align-items: flex-start; gap: 5px; transition: color 0.4s; }
body.fun-mode .panel-hint { color: rgba(255,255,255,0.35); }
.panel-hint::before { content: '▸'; color: var(--gold); flex-shrink: 0; }
body.fun-mode .panel-hint::before { color: var(--fun-gold); }

.out-box {
  background: rgba(30,42,30,0.04); border: 1px solid rgba(168,184,144,0.4);
  border-left: 3px solid var(--green); border-radius: 2px;
  padding: 14px 15px; font-size: 12.5px; line-height: 1.95; color: var(--ink);
  white-space: pre-wrap; word-break: break-all;
  max-height: 380px; overflow-y: auto; margin-bottom: 10px;
  font-family: 'Noto Sans SC', sans-serif; transition: all 0.4s;
}
body.fun-mode .out-box { background: rgba(230,57,70,0.05); border-color: rgba(230,57,70,0.2); border-left-color: var(--fun-acc); color: rgba(255,255,255,0.75); }
.out-box::-webkit-scrollbar { width: 3px; }
.out-box::-webkit-scrollbar-thumb { background: var(--border); border-radius: 2px; }

.copy-btn {
  padding: 7px 20px; font-size: 12px; font-family: 'Noto Sans SC', sans-serif;
  border: 1px solid var(--border); background: var(--paper); color: var(--ink2);
  cursor: pointer; border-radius: 2px; transition: all .15s; letter-spacing: 1px;
}
body.fun-mode .copy-btn { background: #16213e; border-color: #2a2a4a; color: rgba(255,255,255,0.5); }
.copy-btn:hover { background: var(--paper3); }
body.fun-mode .copy-btn:hover { background: #1e2d4a; }
.copy-btn.ok { background: var(--green) !important; border-color: var(--green) !important; color: #fff !important; }
body.fun-mode .copy-btn.ok { background: var(--fun-acc) !important; border-color: var(--fun-acc) !important; }

.badge-row { display: flex; gap: 8px; flex-wrap: wrap; margin-bottom: 12px; }
.badge { display: inline-flex; align-items: center; gap: 4px; padding: 3px 10px; border-radius: 20px; font-size: 11px; letter-spacing: 0.5px; }
.badge-green { background: rgba(61,106,61,0.1); border: 1px solid rgba(61,106,61,0.3); color: var(--green); }
.badge-gold  { background: rgba(138,114,64,0.1); border: 1px solid rgba(138,114,64,0.3); color: var(--gold); }
.badge-red   { background: rgba(230,57,70,0.1); border: 1px solid rgba(230,57,70,0.3); color: var(--fun-acc); }

/* ── 版权footer ── */
footer {
  text-align: center; padding: 24px 20px 16px;
  border-top: 1px solid var(--border); margin-top: 8px; transition: all 0.4s;
}
body.fun-mode footer { border-color: #2a2a4a; }
.footer-brand { font-family: 'Noto Serif SC', serif; font-size: 16px; color: var(--ink); letter-spacing: 3px; margin-bottom: 6px; transition: color 0.4s; }
body.fun-mode .footer-brand { color: rgba(255,255,255,0.6); }
.footer-brand em { color: var(--green); font-style: normal; transition: color 0.4s; }
body.fun-mode .footer-brand em { color: var(--fun-gold); }
.footer-divider { width: 40px; height: 1px; background: var(--border); margin: 10px auto; transition: background 0.4s; }
body.fun-mode .footer-divider { background: #2a2a4a; }
.footer-copy { font-size: 11px; color: var(--ink3); line-height: 1.9; transition: color 0.4s; }
body.fun-mode .footer-copy { color: rgba(255,255,255,0.25); }
.footer-copyright {
  margin-top: 12px; padding-top: 12px;
  border-top: 1px dashed var(--border);
  font-size: 10px; color: var(--ink3); line-height: 1.8; letter-spacing: 0.5px;
  transition: all 0.4s;
}
body.fun-mode .footer-copyright { border-color: #2a2a4a; color: rgba(255,255,255,0.2); }

@keyframes rise { from { opacity:0; transform:translateY(14px) } to { opacity:1; transform:none } }
.animate-rise { animation: rise .35s ease both; }
</style>
</head>
<body>

<div class="top-bar">
  <span>每天认识一种花</span>
  <div class="top-dot"></div>
  <span id="topMode">正经科普版</span>
  <div class="top-dot"></div>
  <span>提示词工坊 V3.0</span>
</div>

<div class="hero">
  <div class="hero-badge" id="heroBadge">博物馆手绘 · 联网核实 · 三平台文案</div>
  <h1>花卉图文<em>提示词</em>生成器</h1>
  <p id="heroSub">正经科普 · 栀子花玫瑰芍药<br>整活系列 · 没钱花雪花鸡米花</p>
</div>

<div class="mode-switch-wrap">
  <div class="mode-switch">
    <button class="mode-btn active" id="btnSerious" onclick="setMode('serious')">
      🌿 正经科普
      <span class="mode-tag">真实花卉 · 认真花语</span>
    </button>
    <button class="mode-btn fun" id="btnFun" onclick="setMode('fun')">
      🎪 整活系列
      <span class="mode-tag">万物皆花 · 编花语</span>
    </button>
  </div>
</div>

<div class="container">

  <div class="foldable">
    <button class="fold-trigger" onclick="toggleFold(this)">
      <span>📖 使用说明</span>
      <span class="fold-icon">+</span>
    </button>
    <div class="fold-content">
      <strong>正经科普模式</strong>：输入真实花卉名 → 生成「博物馆手绘图片提示词 + 三平台正经科普文案提示词」<br>
      <strong>整活系列模式</strong>：输入任何东西（没钱花/雪花/鸡米花/等离子火花…）→ 生成「博物馆手绘图片提示词（反差感）+ 三平台整活文案提示词」<br><br>
      两个标签分别复制 → 图片提示词发给开了联网的 Claude → 文案提示词发给 Claude/DeepSeek
    </div>
  </div>

  <div class="foldable">
    <button class="fold-trigger" onclick="toggleFold(this)">
      <span>🎯 各平台使用说明</span>
      <span class="fold-icon">+</span>
    </button>
    <div class="fold-content">
      <strong>🎨 图片提示词</strong> → Claude（开联网）→ 查资料后输出文生图提示词 → GPT Image 2 / 香蕉Pro / 即梦<br><br>
      <strong>📱 三平台文案提示词</strong> → DeepSeek 联网版 / Claude（开搜索）→ 一次输出：<br>
      　· 小红书：标题+100字正文+15个标签<br>
      　· 抖音：钩子开场+80字口播风格+标签<br>
      　· 视频号：有意境标题+100字朋友圈调性+标签
    </div>
  </div>

  <div class="card">
    <div class="card-seal" id="inputSeal">输入花卉</div>
    <div class="card-title">
      <div class="card-title-num">✦</div>
      <span id="inputTitle">输入花卉名称，生成完整提示词</span>
    </div>

    <div class="mode-desc serious show" id="descSerious">
      🌿 正经模式：输入真实花卉名，联网查资料后生成准确的植物学内容 + 博物馆手绘图 + 三平台科普文案
    </div>
    <div class="mode-desc fun-desc" id="descFun">
      🎪 整活模式：万物皆可「花」！输入食物、游戏道具、日常概念……给它编花语，正经博物馆风包装，反差感拉满
    </div>

    <div class="input-row">
      <input class="herb-input" id="flowerInput" placeholder="栀子花、玫瑰、芍药……" />
      <button class="gen-btn-main" onclick="generate()">生 成</button>
    </div>

    <div class="chips-label" id="chipsLabel">正经花卉快选：</div>
    <div class="chip-set show" id="chipsSerious">
      <div class="chip" onclick="q('栀子花')">栀子花</div>
      <div class="chip" onclick="q('玫瑰')">玫瑰</div>
      <div class="chip" onclick="q('芍药')">芍药</div>
      <div class="chip" onclick="q('茉莉')">茉莉</div>
      <div class="chip" onclick="q('薰衣草')">薰衣草</div>
      <div class="chip" onclick="q('铃兰')">铃兰</div>
      <div class="chip" onclick="q('绣球花')">绣球花</div>
      <div class="chip" onclick="q('荷花')">荷花</div>
      <div class="chip" onclick="q('梅花')">梅花</div>
      <div class="chip" onclick="q('桂花')">桂花</div>
    </div>
    <div class="chip-set" id="chipsFun">
      <div class="chip" onclick="q('没钱花')">没钱花</div>
      <div class="chip" onclick="q('雪花')">雪花</div>
      <div class="chip" onclick="q('鸡米花')">鸡米花</div>
      <div class="chip" onclick="q('爆米花')">爆米花</div>
      <div class="chip" onclick="q('等离子火花')">等离子火花</div>
      <div class="chip" onclick="q('奶茶花')">奶茶花</div>
      <div class="chip" onclick="q('deadline花')">deadline花</div>
      <div class="chip" onclick="q('打工花')">打工花</div>
      <div class="chip" onclick="q('绿豆冰')">绿豆冰</div>
      <div class="chip" onclick="q('泡面花')">泡面花</div>
    </div>
    <div class="err" id="inputErr">请输入名称</div>
  </div>

  <div class="card out-card" id="outCard">
    <div class="out-header">
      <div class="out-header-title" id="outTitle">生成结果</div>
      <div class="out-header-sub">切换标签查看两类提示词，复制后发给对应 AI 工具</div>
    </div>
    <div class="badge-row" id="badgeRow"></div>
    <div class="tab-row" id="tabRow"></div>
    <div id="tabPanels"></div>
  </div>

</div>

<footer>
  <div class="footer-brand">每天认识一种 <em>花</em></div>
  <div class="footer-divider"></div>
  <div class="footer-copy">
    提示词工坊 · V3.0 · 正经+整活双模式<br>
    Made with 🌿 & 🎪
  </div>
  <div class="footer-copyright">
    AIGC版权所有 © 每天认识一种花系列<br>
    Copyright © 花卉图文创作工坊 All Rights Reserved.<br>
    本工具及提示词模板受版权保护，仅供授权用户使用，禁止商业转载与二次分发。
  </div>
</footer>

<script>
var currentMode = 'serious';

function setMode(mode) {
  currentMode = mode;
  var isFun = mode === 'fun';
  document.body.classList.toggle('fun-mode', isFun);
  document.getElementById('btnSerious').classList.toggle('active', !isFun);
  document.getElementById('btnFun').classList.toggle('active', isFun);
  document.getElementById('topMode').textContent = isFun ? '整活系列版' : '正经科普版';
  document.getElementById('heroBadge').textContent = isFun ? '万物皆花 · 反差感 · 编花语' : '博物馆手绘 · 联网核实 · 三平台文案';
  document.getElementById('inputSeal').textContent = isFun ? '输入任意词' : '输入花卉';
  document.getElementById('inputTitle').textContent = isFun ? '输入任何东西，给它编花语' : '输入花卉名称，生成完整提示词';
  document.getElementById('chipsLabel').textContent = isFun ? '整活题材快选：' : '正经花卉快选：';
  document.getElementById('flowerInput').placeholder = isFun ? '没钱花、雪花、鸡米花、deadline花……' : '栀子花、玫瑰、芍药……';
  document.getElementById('descSerious').classList.toggle('show', !isFun);
  document.getElementById('descFun').classList.toggle('show', isFun);
  document.getElementById('chipsSerious').classList.toggle('show', !isFun);
  document.getElementById('chipsFun').classList.toggle('show', isFun);
  document.getElementById('outCard').style.display = 'none';
}

function toggleFold(btn) {
  btn.classList.toggle('open');
  btn.nextElementSibling.classList.toggle('open');
}

function q(name) {
  document.getElementById('flowerInput').value = name;
  generate();
}

document.getElementById('flowerInput').addEventListener('keydown', function(e) {
  if (e.key === 'Enter') generate();
});

function generate() {
  var name = document.getElementById('flowerInput').value.trim();
  if (!name) { document.getElementById('inputErr').style.display = 'block'; return; }
  document.getElementById('inputErr').style.display = 'none';
  var isFun = currentMode === 'fun';
  var imgPrompt = isFun ? buildImgFun(name) : buildImgSerious(name);
  var copyPrompt = isFun ? buildCopyFun(name) : buildCopySerious(name);

  document.getElementById('badgeRow').innerHTML =
    '<span class="badge badge-gold">🌸 共 6 张图片提示词</span>' +
    (isFun ? '<span class="badge badge-red">🎪 整活模式 · 万物皆花</span>' : '<span class="badge badge-green">🌿 正经模式 · 联网核实</span>') +
    '<span class="badge badge-green">📱 三平台文案</span>';

  document.getElementById('outTitle').textContent = '「' + name + '」· ' + (isFun ? '整活版' : '正经版') + '完整提示词';

  renderOutput([
    {
      label: '🎨 图片提示词',
      hint: isFun
        ? '复制 → 发给 Claude（开联网）→ Claude 用博物馆手绘风生成「' + name + '」的文生图提示词（正经外壳+整活内容）→ 发给 GPT Image 2 / 香蕉Pro / 即梦出图'
        : '复制 → 发给开了联网的 Claude → 查资料后输出博物馆手绘风文生图提示词 → 发给 GPT Image 2 / 香蕉Pro / 即梦出图',
      content: imgPrompt,
      btnId: 'copyImg'
    },
    {
      label: '📱 三平台文案提示词',
      hint: '复制 → 发给 DeepSeek 联网版 / Claude（开搜索）→ 一次输出小红书 + 抖音 + 视频号 三套文案',
      content: copyPrompt,
      btnId: 'copyXhs'
    }
  ]);

  var card = document.getElementById('outCard');
  card.style.display = 'block';
  card.classList.add('animate-rise');
  setTimeout(function(){ card.classList.remove('animate-rise'); }, 400);
  card.scrollIntoView({ behavior: 'smooth', block: 'start' });
}

function renderOutput(panels) {
  var tabRow = document.getElementById('tabRow');
  var tabPanels = document.getElementById('tabPanels');
  tabRow.innerHTML = ''; tabPanels.innerHTML = '';
  panels.forEach(function(p, idx) {
    var tab = document.createElement('button');
    tab.className = 'tab-btn' + (idx === 0 ? ' on' : '');
    tab.textContent = p.label;
    tab.onclick = (function(i){ return function(){ switchTab(i); }; })(idx);
    tabRow.appendChild(tab);
    var div = document.createElement('div');
    div.className = 'tab-panel' + (idx === 0 ? ' show' : '');
    var hint = document.createElement('div');
    hint.className = 'panel-hint';
    hint.textContent = p.hint;
    var box = document.createElement('div');
    box.className = 'out-box';
    box.id = p.btnId + 'Box';
    box.textContent = p.content;
    var foot = document.createElement('div');
    foot.style.cssText = 'display:flex;align-items:center;justify-content:space-between;margin-top:2px;';
    var chars = document.createElement('span');
    chars.style.cssText = 'font-size:11px;color:var(--ink3);letter-spacing:1px;';
    chars.textContent = p.content.length + ' 字';
    var btnRow = document.createElement('div');
    btnRow.style.cssText = 'display:flex;gap:8px;';
    var expandBtn = document.createElement('button');
    expandBtn.className = 'copy-btn';
    expandBtn.style.cssText = 'font-size:11px;padding:5px 14px;';
    expandBtn.textContent = '展开全文 ▾';
    expandBtn.onclick = (function(b, btn){ return function(){
      var open = b.style.maxHeight === 'none';
      b.style.maxHeight = open ? '380px' : 'none';
      btn.textContent = open ? '展开全文 ▾' : '收起 ▴';
    }; })(box, expandBtn);
    var copyBtn = document.createElement('button');
    copyBtn.className = 'copy-btn';
    copyBtn.id = p.btnId + 'Btn';
    copyBtn.textContent = '复制提示词';
    copyBtn.onclick = (function(id, btn){ return function(){
      var text = document.getElementById(id).textContent;
      var done = function(){
        btn.textContent = '已复制 ✓'; btn.classList.add('ok');
        setTimeout(function(){ btn.textContent = '复制提示词'; btn.classList.remove('ok'); }, 2200);
      };
      if (navigator.clipboard) navigator.clipboard.writeText(text).then(done).catch(function(){ fallback(text); done(); });
      else { fallback(text); done(); }
    }; })(p.btnId + 'Box', copyBtn);
    btnRow.appendChild(expandBtn);
    btnRow.appendChild(copyBtn);
    foot.appendChild(chars); foot.appendChild(btnRow);
    div.appendChild(hint); div.appendChild(box); div.appendChild(foot);
    tabPanels.appendChild(div);
  });
}

function switchTab(idx) {
  document.querySelectorAll('.tab-btn').forEach(function(t,i){ t.classList.toggle('on', i===idx); });
  document.querySelectorAll('.tab-panel').forEach(function(p,i){ p.classList.toggle('show', i===idx); });
}

function fallback(text) {
  var ta = document.createElement('textarea');
  ta.value = text; ta.style.cssText = 'position:fixed;opacity:0;top:0;left:0;';
  document.body.appendChild(ta); ta.select(); document.execCommand('copy'); document.body.removeChild(ta);
}

/* ═══════════════ 正经模式：图片提示词 ═══════════════ */
function buildImgSerious(name) {
  var n = name;
  var cr = 'AIGC版权所有©每天认识一种花';
  return '# 任务：为花卉「' + n + '」生成 6 张博物馆植物图鉴风格信息图的文生图提示词\n\n## 第一步：联网搜索（必须先做，不可跳过）\n\n搜索1：「' + n + ' 植物分类 科属 学名 别名 形态特征」\n搜索2：「' + n + ' 花期月份 原产地 主要栽培地区」\n搜索3：「' + n + ' 花语 象征意义 中西方文化含义 历史典故 诗词」\n搜索4：「' + n + ' 赏花地点 著名产地 最佳观赏时间」\n搜索5：「' + n + ' 养护方法 光照浇水土壤 常见问题 家庭种植」\n搜索6：「' + n + ' 插花搭配 香氛 食用价值 生活应用」\n\n整理：学名/科属/别名、真实花期（精确月份）、原产地、真实形态、花语（中西方）、著名典故或诗词、3-5个著名赏花地、养护要点、生活应用\n\n---\n\n## 第二步：生成 6 张文生图提示词\n\n**统一风格：** 博物馆植物图鉴手绘风格，仿18-19世纪欧洲自然史博物馆植物标本绘制风格（Curtis\'s Botanical Magazine），米白羊皮纸底色，墨绿色系与藏青为主色，金色细线标注，精细钢笔线稿+水彩淡染，竖版9:16，四周白边留白\n\n**每张底部角落极小字：「本图为花卉科普学习内容，仅供参考 · ' + cr + '」**\n\n每张不少于300字，所有数据必须来自查到的资料\n\n---\n\n【图1：总图——' + n + '完整知识图谱（封面）】\n顶部：仿古铜版大字「' + n + '」+学名+月桂叶纹章+细线边框\n核心植株图（35%）：根据真实形态多角度精细水彩手绘+金色引注\n三栏知识区：左—原产地地图+花期时间轴；中—核心花语圆形图标；右—五感描述\n搭配区：根据查到的搭配花材手绘组合\n底部：手写体「一句话认识' + n + '」+版权说明\n\n【图2：分图①——植物形态与产地】\n左侧（55%）：整株/花朵特写/花苞/叶片/根部多角度精细手绘，金色引线标注+学名命名人\n右侧：分类树状/形态速记/12月花期圆点时间轴/常见品种\n底部：中国地图手绘+主要栽培地区红点标注+版权说明\n\n【图3：分图②——花语与文化典故】\n上半（45%）：中央' + n + '大图，放射状展开花语（中西方颜色区分）+象征图案+连线\n装饰带：细线+卷草纹\n下半（45%）：2格手绘典故场景（历史典故+文学联结）\n底部：经典诗词手写体+印章装饰+版权说明\n\n【图4：分图③——应季时令与赏花指南】\n顶部（30%）：四季古典罗盘，花期月份金色高亮\n中部（35%）：中国手绘地图+3-5个著名赏花地+景观缩略图\n下部（25%）：4-5条赏花贴士+手绘图标+版权说明\n\n【图5：分图④——养护与种植指南】\n上方（40%）：光照/浇水/土壤/温度/施肥 五圆形博物馆标签图标\n中部（30%）：春夏秋冬四格管理历\n下部（20%）：3个常见问题速查+版权说明\n\n【图6：分图⑤——与生活美学】\n上部（35%）：东方+西式两种插花方案手绘+搭配建议\n中部（30%）：香氛/食用/观赏美学（根据实际情况选择）\n下部（25%）：3个送花时机+情感文案+版权说明\n\n---\n\n## 第三步：图1→图6依次输出，之间用「────────────」分隔，每张末尾注明数据来源\n\n' + cr;
}

/* ═══════════════ 整活模式：图片提示词 ═══════════════ */
function buildImgFun(name) {
  var n = name;
  var cr = 'AIGC版权所有©每天认识一种花';
  return '# 任务：用博物馆植物图鉴风格，为「' + n + '」生成 6 张信息图的文生图提示词\n\n## 重要前提\n\n「' + n + '」不是真实花卉，但本系列用「每天认识一种花」的正经格式包装一切事物。\n用严肃认真的博物馆植物图鉴风格，为「' + n + '」创作一套完全正经的花卉图谱——内容荒诞、风格正经，反差感越大越好。\n\n## 第一步：创作准备（发挥创意，越认真越好）\n\n请为「' + n + '」设定：\n- 学名：用伪拉丁文命名，要有逻辑\n- 花语：根据「' + n + '」的特质编写1-2个，要有意境\n- 产地传说：编写起源故事，可以荒诞但要自圆其说\n- 形态描述：把「' + n + '」的真实外形用植物学语言重新描述\n- 文化典故：编写或引用与「' + n + '」相关的文化/梗/故事\n- 生活应用：「' + n + '」的真实使用场景，用花卉应用方式描述\n\n## 第二步：生成 6 张文生图提示词\n\n**统一风格（必须遵守，绝不破功）：**\n博物馆植物图鉴手绘风格，仿18-19世纪欧洲自然史博物馆植物标本绘制风格，米白羊皮纸底色，墨绿色系与藏青为主色，金色细线标注，精细钢笔线稿+水彩淡染，竖版9:16，四周白边留白。风格必须100%正经严肃，不能有任何卡通或搞笑元素。\n\n**每张底部角落极小字：「本图为花卉科普学习内容，仅供参考 · ' + cr + '」**\n\n每张不少于300字\n\n---\n\n【图1：总图——「' + n + '」完整知识图谱（封面）】\n顶部：仿古铜版大字「' + n + '」+设计的伪拉丁学名+月桂叶纹章+细线边框\n核心主图（35%）：用精细植物学解剖图方式描绘「' + n + '」真实外形，金色细线标注各「部位」名称\n三栏知识区：左—编写的产地+最佳状态时间；中—设计的花语圆形图标；右—五感描述（把「' + n + '」感官体验用植物学语言描述）\n搭配区：「' + n + '」与什么搭配最佳的手绘示意\n底部：手写体「一句话认识' + n + '」+版权说明\n\n【图2：分图①——「' + n + '」形态与产地】\n左侧（55%）：「' + n + '」各角度精细手绘，金色引线标注各「构造」名称，右下角伪学名+田野调查署名\n右侧：编写的分类树状/形态速记/最佳状态时间轴/常见变种2-3个\n底部：产地地图+主要「出没地点」标注+版权说明\n\n【图3：分图②——「' + n + '」花语与文化渊源】\n上半（45%）：中央「' + n + '」精细大图，放射状展开设计的花语（东西方各自解读）+象征图案+金色连线\n装饰带：细线+卷草纹\n下半（45%）：2格叙事手绘（真实文化背景+现代语境）\n底部：与「' + n + '」相关的名言/金句手写体+仿古印章+版权说明\n\n【图4：分图③——「' + n + '」时令与邂逅指南】\n顶部（30%）：四季古典罗盘，「' + n + '」最佳相遇时间金色高亮\n中部（35%）：最容易邂逅的地点地图+各地点手绘缩略图\n下部（25%）：4-5条「邂逅贴士」+手绘图标（保持严肃图鉴风格）+版权说明\n\n【图5：分图④——「' + n + '」养护与获取指南】\n上方（40%）：五圆形图标——把「' + n + '」关键要素用光照/浇水/土壤/温度/施肥格式创意包装\n中部（30%）：四季「状态管理历」\n下部（20%）：3个「常见难题速查」+版权说明\n\n【图6：分图⑤——「' + n + '」与生活美学】\n上部（35%）：两种搭配方案（东方+西式），保持植物图鉴插花示意图风格\n中部（30%）：实际应用场景，用香氛/食用/观赏格式包装\n下部（25%）：3个「赠予场合」（结合花语）+情感金句+版权说明\n\n---\n\n## 第三步：输出格式\n图1→图6依次输出，每张之间用「────────────」分隔\n风格始终保持严肃的博物馆学术风，绝不破功\n末尾加：「本内容为创意花卉科普，仅供娱乐参考 · ' + cr + '」';
}

/* ═══════════════ 正经模式：三平台文案 ═══════════════ */
function buildCopySerious(name) {
  var n = name;
  return '# 任务：为花卉「' + n + '」生成三平台发布文案\n\n## 第一步：联网搜索\n搜索1：「' + n + ' 花语 象征意义 中西方含义 送花场合」\n搜索2：「' + n + ' 植物冷知识 有趣事实 花期 特别之处」\n搜索3：「' + n + ' 文化典故 诗词 历史故事」\n搜索4：「' + n + ' 养护一句话 新手必知」\n\n整理：最意外的1个冷知识、中西方花语各1个、最著名文化联结、最实用养护建议1条、最适合送花的3个场合\n\n---\n\n## 第二步：生成三平台文案（直接输出，不要任何开场白）\n\n每个平台格式：标题 + 正文（100字以内）+ 话题标签\n\n### 【小红书】\n**标题**（3个备选，20字以内）：花语悬念型 / 冷知识惊喜型 / 场景代入型\n**正文**（100字以内）：1句共鸣开头 → 2-3个干货点 → 互动提问结尾\n风格：像懂花的朋友在聊天，有温度，不说教\n**标签**（15个）：固定5个（#每天认识一种花 #花卉科普 #花语 #植物日记 #博物馆美学）+ 动态10个\n\n### 【抖音】\n**标题**（1个，15字以内，直接有冲击力）\n**正文**（80字以内）：强钩子第1句 → 最有趣1-2个知识点 → 引导互动\n风格：直接、有节奏感，像口播稿\n**标签**（5-8个热门标签）\n\n### 【视频号】\n**标题**（1个，20字以内，温和有意境）\n**正文**（100字以内）：有意境场景开头 → 1个最美知识点 → 引发共鸣结尾\n风格：温暖、有生活感，适合朋友圈分享\n**标签**（5个生活/文化类）\n\n---\nAIGC版权所有©每天认识一种花';
}

/* ═══════════════ 整活模式：三平台文案 ═══════════════ */
function buildCopyFun(name) {
  var n = name;
  return '# 任务：用「每天认识一种花」的格式，为「' + n + '」生成三平台整活文案\n\n## 核心玩法\n「' + n + '」不是真实花卉，但用正经的「花卉科普」格式认真介绍它。\n固定句式开头：「每天认识一种花——' + n + '。」\n正经写 > 搞笑写，越认真越有反差感，让读者自己感受，不要解释这是整活。\n\n## 参考风格\n\n鸡米花范例：\n「每天认识一种花——鸡米花。鸡米花的花语是朴素的温暖和朴素的快乐。\n油锅刚泛起细腻的泡，鸡米花便要登场了。冻得紧实的小糖裹着面包糠，白花花的像攒了把碎雪。投进热油里时，起初是汽声沉在底，没一会儿就鼓胀起来，金褐色从边缘慢慢晕开。咬开时能听见咔嚓一声清响，里头的肉却嫩得淌汁。」\n\n没钱花范例：\n「每天认识一种花——没钱花。它的花语是「清醒的温柔」。\n相传它原产于每月二十六日，由一位对账半小时、最终合上手机叹了口气的年轻人无意间培育。翻开钱包的瞬间，没有重量，只有空气和一张会员卡。那种感觉不是疼，是一种非常干净的清醒。」\n\n## 创作要求\n先为「' + n + '」设定：\n- 花语（1-2个，有意境，与它的特质真正吻合）\n- 一个起源传说（可以荒诞但要自圆其说）\n- 感官描写素材（「' + n + '」带给人的真实感受，越具体越好）\n\n---\n\n## 生成三平台文案（直接输出，不要开场白）\n\n每平台：标题 + 正文（100字以内）+ 话题标签\n\n### 【小红书】\n**标题**（3个备选，20字以内）：\n- 备选①：「每天认识一种花｜' + n + '的花语，你绝对猜不到」\n- 备选②：反差型（暗示这不是普通科普）\n- 备选③：情感共鸣型（直击目标受众痛点/爽点）\n\n**正文**（100字以内）：\n开头必须是「每天认识一种花——' + n + '。」\n→ 花语（认真写，有意境）→ 传说/典故（1-2句）→ 感官描写（最精彩部分）→ 结尾留钩\n\n**标签**（15个）：\n固定：#每天认识一种花 #花语 #整活 #反差感 #花卉科普\n动态10个：根据「' + n + '」属性生成\n\n### 【抖音】\n**标题**（1个，15字以内，直接抛出反差感）\n**正文**（80字以内）：\n开头：「每天认识一种花——' + n + '，花语是……」\n→ 最有冲击力的1-2句感官或情感描写 → 口语化互动引导\n**标签**（5-8个）\n\n### 【视频号】\n**标题**（1个，20字以内，温和有意境）\n**正文**（100字以内）：\n开头：「每天认识一种花——' + n + '。」\n→ 用最有温度的方式写花语和感受 → 朋友圈转发调性，让人看完想转给某人\n**标签**（5个）\n\n---\nAIGC版权所有©每天认识一种花';
}
</script>

<div style="text-align:center;padding:24px 20px;border-top:1px solid #e0cfa8;margin-top:24px;background:#faf6ef">
  <div style="font-size:14px;font-weight:700;color:#1a0a00;letter-spacing:3px;margin-bottom:6px;font-family:'PingFang SC','Microsoft YaHei',serif">📜 阿坚AIGC · 工具中心</div>
  <div style="font-size:11px;color:#6a4a20;letter-spacing:1px;line-height:2">每天认识一种花 · 提示词工坊<br>版权所有 © 阿坚AIGC · 仅供授权用户个人创作使用 · 禁止商业转载与二次分发</div>
</div>
</body>
</html>

<!DOCTYPE html>
<html lang="zh-CN">
<head>
<meta charset="UTF-8">
<meta name="viewport" content="width=device-width, initial-scale=1.0">
<title>四级词汇记忆图 · 阿坚AIGC</title>
<style>
@import url('https://fonts.googleapis.com/css2?family=Noto+Serif+SC:wght@400;600;700;900&display=swap');
:root {
  --bg:#faf6ef; --card:#fffdf8; --ink:#1a0f00; --ink2:#4a3010; --muted:#8a6040;
  --border:#e0cfa8; --nav:#3a1a00;
  --accent:#8b1a1a; --al:#fdecea;
  --green:#1a4a1a; --gl:#edf5ed;
  --gold:#c8920a; --gold-light:#fef9e7;
  --orange:#c8920a; --ol:#fef9e7;
  --shadow:0 4px 16px rgba(26,15,0,.08);
}
*{box-sizing:border-box;margin:0;padding:0;}
body{font-family:'Noto Serif SC','STKaiti','PingFang SC',serif;background:var(--bg);color:var(--ink);min-height:100vh;}

.topbar{background:var(--nav);color:#f0c87a;padding:0 20px;height:50px;display:flex;align-items:center;justify-content:space-between;font-size:13px;border-bottom:1px solid rgba(200,146,10,.4);}
.topbar-logo{font-weight:700;letter-spacing:3px;color:#f0c87a;}
.topbar-right{font-size:11px;color:#c8a060;letter-spacing:2px;}
.vtag{background:rgba(200,146,10,.2);border:1px solid rgba(200,146,10,.4);border-radius:4px;padding:2px 8px;font-size:10px;color:#f0c87a;margin-left:6px;}

.hero{background:var(--nav);color:#fff;padding:40px 20px 30px;text-align:center;border-bottom:2px solid rgba(200,146,10,.4);}
.hero h1{font-size:clamp(20px,4vw,32px);font-weight:900;letter-spacing:3px;margin-bottom:8px;color:#fff;}
.hero p{font-size:11px;color:#c8a060;letter-spacing:2px;margin-bottom:14px;}
.hero-chips{display:flex;flex-wrap:wrap;gap:8px;justify-content:center;}
.hchip{background:rgba(200,146,10,.15);border:1px solid rgba(200,146,10,.4);border-radius:4px;padding:4px 12px;font-size:11px;color:#f0c87a;letter-spacing:.5px;}

.main{max-width:860px;margin:0 auto;padding:20px 20px 60px;}

/* collapsible */
.coll{background:var(--card);border:1px solid var(--border);border-radius:12px;margin-bottom:14px;overflow:hidden;}
.coll-h{padding:13px 16px;display:flex;align-items:center;justify-content:space-between;cursor:pointer;font-size:13px;font-weight:500;color:var(--muted);user-select:none;}
.coll-h:hover{color:var(--ink2);}
.coll-b{display:none;padding:0 16px 16px;border-top:1px solid var(--border);}
.coll-b.open{display:block;}
.si{display:flex;gap:10px;align-items:flex-start;padding:8px 0;font-size:13px;color:var(--muted);line-height:1.7;}
.sn{min-width:22px;height:22px;background:var(--accent);color:#fff;border-radius:50%;font-size:11px;display:flex;align-items:center;justify-content:center;font-weight:600;margin-top:2px;}

/* input card */
.ic{background:var(--card);border:1px solid var(--border);border-radius:12px;padding:20px;margin-bottom:14px;}
.lbl{font-size:12px;font-weight:500;color:var(--muted);margin-bottom:8px;letter-spacing:.03em;}

input[type=text]{width:100%;border:1.5px solid var(--border);border-radius:9px;padding:10px 14px;font-size:14px;font-family:inherit;outline:none;background:var(--bg);color:var(--ink);transition:border-color .2s;margin-bottom:10px;}
input[type=text]:focus{border-color:var(--accent);}
input[type=text]::placeholder{color:#bbb;}

.chips{display:flex;flex-wrap:wrap;gap:7px;margin-bottom:16px;}
.chip{padding:5px 13px;background:var(--bg);border:1px solid var(--border);border-radius:20px;font-size:12px;color:var(--ink2);cursor:pointer;transition:all .15s;}
.chip:hover{border-color:var(--accent);color:var(--accent);background:var(--al);}

/* count */
.cr{display:flex;gap:8px;margin-bottom:16px;flex-wrap:wrap;}
.cnt{flex:1;min-width:70px;padding:10px 6px;border:1.5px solid var(--border);border-radius:10px;text-align:center;cursor:pointer;transition:all .15s;color:var(--muted);font-size:12px;}
.cnt:hover{border-color:var(--accent);}
.cnt.on{border-color:var(--accent);background:var(--al);color:var(--accent);font-weight:500;}
.cnt .n{font-size:22px;font-weight:700;color:var(--ink);display:block;line-height:1.2;}
.cnt.on .n{color:var(--accent);}
.custom-row{display:none;align-items:center;gap:8px;margin-top:-8px;margin-bottom:16px;}
.custom-row.show{display:flex;}
.custom-row input[type=number]{width:80px;border:1.5px solid var(--border);border-radius:8px;padding:7px 10px;font-size:14px;font-family:inherit;outline:none;background:var(--bg);color:var(--ink);}
.custom-row input[type=number]:focus{border-color:var(--accent);}

/* style */
.sr{display:flex;gap:8px;}
.sty{flex:1;padding:12px 6px 10px;border:1.5px solid var(--border);border-radius:10px;text-align:center;cursor:pointer;font-size:12px;color:var(--muted);transition:all .15s;}
.sty:hover{border-color:var(--accent);}
.sty.on{border-color:var(--accent);background:var(--al);color:var(--accent);font-weight:500;}
.sty-i{font-size:22px;display:block;margin-bottom:5px;}

.btn-gen{width:100%;padding:15px;background:linear-gradient(135deg,#5561f5,#7c4dff);color:#fff;border:none;border-radius:12px;font-size:16px;font-weight:500;font-family:inherit;cursor:pointer;letter-spacing:.06em;transition:opacity .2s;margin-bottom:20px;}
.btn-gen:hover{opacity:.9;}

/* result */
.rcard{background:var(--card);border:1px solid var(--border);border-radius:6px;overflow:hidden;animation:up .3s ease;margin-bottom:14px;}
@keyframes up{from{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}

.rh{padding:14px 18px;background:var(--card);border-bottom:1px solid var(--border);}
.rt{font-size:13px;font-weight:700;color:var(--ink2);letter-spacing:1px;margin-bottom:6px;}
.brow{display:flex;gap:6px;flex-wrap:wrap;}
.badge{font-size:11px;padding:3px 9px;border-radius:6px;font-weight:500;}
.ba{background:var(--al);color:var(--accent);}
.bg2{background:var(--gl);color:var(--green);}
.bo{background:var(--gold-light);color:var(--gold);}

.tabs{display:flex;border-bottom:2px solid var(--border);background:var(--card);padding:0 16px;}
.tab{padding:10px 16px;font-size:12px;cursor:pointer;color:var(--muted);border-bottom:2px solid transparent;margin-bottom:-1px;transition:all .15s;font-family:inherit;background:none;border-top:none;border-left:none;border-right:none;letter-spacing:1px;font-weight:700;}
.tab.on{color:var(--accent);border-bottom-color:var(--accent);}

.pane{display:none;padding:16px;}
.pane.on{display:block;}

.ibox{background:#f9f9fd;border:1px solid var(--border);border-radius:10px;padding:14px;font-size:13px;line-height:1.9;color:var(--ink2);white-space:pre-wrap;word-break:break-word;max-height:160px;overflow:hidden;position:relative;transition:max-height .3s;}
.ibox.open{max-height:9999px;}
.fade{position:absolute;bottom:0;left:0;right:0;height:50px;background:linear-gradient(transparent,#f9f9fd);pointer-events:none;}
.ibox.open .fade{display:none;}

.abar{display:flex;align-items:center;gap:8px;margin-top:10px;}
.btn-exp{padding:6px 13px;border-radius:7px;font-size:12px;font-family:inherit;cursor:pointer;border:1px solid var(--border);background:#fff;color:var(--muted);transition:all .15s;}
.btn-exp:hover{border-color:var(--accent);color:var(--accent);}
.btn-cp{padding:7px 16px;background:var(--ink);color:#fff;border:none;border-radius:7px;font-size:12px;font-family:inherit;cursor:pointer;transition:all .15s;}
.btn-cp:hover{opacity:.85;}
.btn-cp.ok{background:var(--green);}
.cnum{margin-left:auto;font-size:11px;color:var(--muted);}

.info-box{font-size:12px;color:var(--muted);background:var(--bg);border-left:3px solid var(--accent);border-radius:6px;padding:9px 12px;margin-bottom:12px;line-height:1.7;}

footer{text-align:center;padding:28px 20px;font-size:12px;color:var(--muted);border-top:1px solid var(--border);margin-top:16px;}
</style>
</head>
<body>

<div class="topbar">
  <div class="topbar-logo">📚 四级词汇记忆图</div>
  <div class="topbar-right">阿坚AIGC <span class="vtag">V4.0</span></div>
</div>

<div class="hero">
  <h1>英语四级 · 词汇场景记忆图</h1>
  <p>连环画式故事线 · 每张8词 · 香蕉模型专用</p>
  <div class="hero-chips">
    <span class="hchip">🍌 香蕉模型专用</span>
    <span class="hchip">📖 连环画故事线</span>
    <span class="hchip">✏️ 每张8个词汇</span>
    <span class="hchip">© 阿坚AIGC版权所有</span>
  </div>
</div>

<div class="main">

  <div class="coll">
    <div class="coll-h" onclick="tog('man')">📖 使用手册 <span id="man-a" style="font-size:11px;color:#ccc">▾ 展开</span></div>
    <div class="coll-b" id="man">
      <div class="si"><div class="sn">1</div><div>输入<b>单元主题</b>（如「农业与田园」），或快选</div></div>
      <div class="si"><div class="sn">2</div><div>选择出<b>几张图</b>（即故事有几个章节）</div></div>
      <div class="si"><div class="sn">3</div><div>选<b>插画风格</b> → 点生成</div></div>
      <div class="si"><div class="sn">4</div><div>🖼️ 复制<b>图片提示词</b> → 发给<b>即梦（香蕉）</b>，AI会先规划故事线、查8个词，再出每张图</div></div>
      <div class="si"><div class="sn">5</div><div>📝 复制<b>文案提示词</b> → 发给Claude/DeepSeek生成三平台文案</div></div>
    </div>
  </div>

  <div class="coll">
    <div class="coll-h" onclick="tog('noti')">⚠️ 注意事项 <span id="noti-a" style="font-size:11px;color:#ccc">▾ 展开</span></div>
    <div class="coll-b" id="noti">
      <div class="si"><div class="sn">!</div><div>提示词含联网指令，需在<b>支持联网的AI</b>上使用</div></div>
      <div class="si"><div class="sn">!</div><div>香蕉出图时，<b>一次发一整套提示词</b>，让AI连续出图</div></div>
      <div class="si"><div class="sn">!</div><div>图中文字若有偏差，可在Canva<b>手动叠加文字层</b>修正</div></div>
      <div class="si"><div class="sn">!</div><div>词汇由AI联网查四级考纲，<b>自动控制难度不超纲</b></div></div>
    </div>
  </div>

  <div class="ic">
    <div class="lbl">单元主题</div>
    <input type="text" id="unit-in" placeholder="例：农业与田园 / 医院与健康 / 校园生活…" />

    <div class="lbl">快选主题</div>
    <div class="chips">
      <span class="chip" onclick="fill('农业与田园')">🌾 农业与田园</span>
      <span class="chip" onclick="fill('医院与健康')">🏥 医院与健康</span>
      <span class="chip" onclick="fill('校园与学习')">📚 校园与学习</span>
      <span class="chip" onclick="fill('城市与交通')">🚇 城市与交通</span>
      <span class="chip" onclick="fill('商业与经济')">💼 商业与经济</span>
      <span class="chip" onclick="fill('自然与环境')">🌿 自然与环境</span>
      <span class="chip" onclick="fill('科技与网络')">💻 科技与网络</span>
      <span class="chip" onclick="fill('家庭与生活')">🏠 家庭与生活</span>
      <span class="chip" onclick="fill('情感与心理')">💬 情感与心理</span>
      <span class="chip" onclick="fill('政治与社会')">🏛️ 政治与社会</span>
    </div>

    <div class="lbl">出几张图（每张=故事一个章节，含8个词汇）</div>
    <div class="cr">
      <div class="cnt" data-n="4" onclick="pickN(this)"><span class="n">4</span>张</div>
      <div class="cnt on" data-n="6" onclick="pickN(this)"><span class="n">6</span>张</div>
      <div class="cnt" data-n="8" onclick="pickN(this)"><span class="n">8</span>张</div>
      <div class="cnt" data-n="0" onclick="pickN(this)"><span class="n">✏️</span>自定义</div>
    </div>
    <div class="custom-row" id="custom-row">
      <input type="number" id="custom-n" min="1" max="20" value="5" />
      <span style="font-size:12px;color:var(--muted)">张（1-20）</span>
    </div>

    <div class="lbl">插画风格</div>
    <div class="sr">
      <div class="sty on" data-s="japanese" onclick="pickS(this)"><span class="sty-i">🎌</span>日系清新</div>
      <div class="sty" data-s="flat" onclick="pickS(this)"><span class="sty-i">📐</span>现代扁平</div>
      <div class="sty" data-s="iso" onclick="pickS(this)"><span class="sty-i">🎲</span>2.5D等距</div>
    </div>
  </div>

  <button class="btn-gen" onclick="gen()">🍌 生成提示词</button>
  <div id="result"></div>
</div>

<footer>© 阿坚AIGC版权所有 · 英语四级词汇场景记忆图系列<br>本工具生成内容仅供个人学习备考使用</footer>

<script>
const STYLES = {
  japanese:{name:'日系清新插画',desc:'日系清新教育插画风格，莫兰迪柔和配色，人物Q版圆润大眼，线条干净，整体温馨治愈，类似NHK教育节目插画质感，浅米白背景，无古风无中国传统服饰，现代日常服装'},
  flat:{name:'现代扁平插画',desc:'现代扁平插画风格（Flat Illustration），几何简洁造型，天蓝+珊瑚橙+草绿高饱和配色，纯色块无阴影，人物扁平简约，年轻现代感，纯白背景'},
  iso:{name:'2.5D等距视角',desc:'2.5D等距插画（Isometric），45度俯视等轴测角度，立体卡通风，天蓝+浅绿+米白配色，场景模块化整洁，精致迷你世界感，白色背景'}
};

let curN = 6, curS = 'japanese';

function fill(v){ document.getElementById('unit-in').value = v; }

function tog(id){
  const b = document.getElementById(id);
  const a = document.getElementById(id+'-a');
  const open = b.classList.toggle('open');
  a.textContent = open ? '▴ 收起' : '▾ 展开';
}

function pickN(el){
  document.querySelectorAll('.cnt').forEach(c=>c.classList.remove('on'));
  el.classList.add('on');
  const n = parseInt(el.dataset.n);
  const cr = document.getElementById('custom-row');
  if(n===0){ cr.classList.add('show'); curN=0; }
  else { cr.classList.remove('show'); curN=n; }
}

function pickS(el){
  document.querySelectorAll('.sty').forEach(s=>s.classList.remove('on'));
  el.classList.add('on');
  curS = el.dataset.s;
}

function getN(){
  if(curN>0) return curN;
  const v = parseInt(document.getElementById('custom-n').value)||6;
  return Math.min(Math.max(v,1),20);
}

// ── 保存原始文本的 Map（解决复制按钮问题）
const promptStore = new Map();

function gen(){
  const unit = document.getElementById('unit-in').value.trim();
  if(!unit){ alert('请输入单元主题～'); return; }
  const n = getN();
  const sty = STYLES[curS];
  const imgP = buildImg(unit, n, sty);
  const copyP = buildCopy(unit, n);

  const id = 'r'+Date.now();
  promptStore.set('img_'+id, imgP);
  promptStore.set('copy_'+id, copyP);

  render(unit, n, sty, imgP, copyP, id);
}

function buildImg(unit, n, sty){
return `# 英语四级词汇场景记忆图 · 连环画生成任务

单元主题：${unit}
总张数：${n} 张（连环画共 ${n} 个章节）
每张词汇数：8 个
插画风格：${sty.name}

---

## 第一步：联网查词

请联网搜索「英语四级核心词汇 ${unit}」，找出该主题下 **${n*8} 个**四级考纲高频词汇（不超纲）。

筛选标准：
- 严格在四级考纲范围内
- 优先选该主题下有场景感、高频、易混淆的词
- 覆盖名词、动词、形容词等多种词性
- 每个词记录：英文 / 音标 / 词性 / 中文释义

---

## 第二步：规划连环画故事线

根据「${unit}」这个主题，设计一条有起承转合的故事线，共 ${n} 个章节。

要求：
- 故事要有时间或逻辑上的连续推进（如：准备→行动→高潮→结果）
- 每个章节有一个明确的场景标题（如「第一章：春耕备种」）
- 每个章节场景描述2-3句，具体生动，有人物、动作、环境
- 场景人物为现代普通人，穿现代日常服装，不要古装
- 把第一步查到的词汇，按场景相关性分配到各章节，每章节 8 个词

---

## 第三步：逐张输出图片提示词

按以下格式，为每个章节输出一张完整的香蕉（即梦）图片提示词：

【格式】
========================================
第X张 / 共${n}张 | 章节标题

画面风格：${sty.desc}

场景描述：[第二步的章节场景，2-3句，具体描述画面主体、人物动作、环境氛围]

词汇标注（画面中用对话气泡或标注框标出以下8个词，气泡颜色各异、分布自然）：
1. [单词1] [音标] [词性] [中文释义]
2. [单词2] [音标] [词性] [中文释义]
3. [单词3] [音标] [词性] [中文释义]
4. [单词4] [音标] [词性] [中文释义]
5. [单词5] [音标] [词性] [中文释义]
6. [单词6] [音标] [词性] [中文释义]
7. [单词7] [音标] [词性] [中文释义]
8. [单词8] [音标] [词性] [中文释义]

构图要求（严格固定，每张必须统一，不得自由发挥）：

【整体比例与视角】
• 竖版，3:4比例
• 视角：全部平视角度，禁止俯视或鸟瞰

【三段式版面布局】
• 顶部标题栏（占8%）：白底，黑色文字，标题格式严格固定为：英语四级 · ${unit} · 第X章，不得添加任何引号「」""、书名号《》、装饰符号或边框，字号统一，每张格式完全一致
• 中部场景区（占75%）：插画主场景，平视角度
• 底部说明栏（占17%）：浅灰底，中央固定文字「第X张 / 共${n}张」，右下角极小灰字「© 阿坚AIGC」

【词汇气泡规格——所有气泡必须完全统一】
• 气泡形状：圆角矩形，所有气泡圆角半径相同
• 气泡宽度：统一为画面宽度的26%，高度统一，不得忽大忽小
• 气泡内容固定三行格式：
  第一行：英文单词（加粗，最大字号）
  第二行：音标（字号中等）空格 词性（字号中等）
  第三行：中文释义（字号中等）
• 8个气泡颜色各不同：浅蓝/浅粉/浅绿/浅黄/浅橙/浅紫/浅青/浅红，饱和度低，柔和不刺眼
• 气泡文字：深色，清晰可读

【气泡排列规则】
• 8个气泡沿场景画面四周边缘均匀分布：左侧3个、右侧3个、上方1个、下方1个
• 气泡之间禁止重叠，禁止遮挡人物脸部和关键动作
• 每个气泡用一条细线箭头指向画面中对应的事物
• 禁止气泡集中堆叠在画面某一区域
• 严禁重复标注：8个词汇每个只能出现一次，不得将同一个词贴在不同位置重复出现

========================================

请按此格式，依次输出全部 ${n} 张提示词，每张之间用分隔线隔开。`;
}

function buildCopy(unit, n){
return `# 任务：为「${unit}」四级词汇场景记忆图生成三平台推广文案

## 内容简介
这是一套「${unit}」主题的英语四级词汇连环画记忆图，共 ${n} 张，采用连环画叙事方式，每张图对应故事一个章节，场景中标注 8 个四级核心词汇（含音标+词性+释义），插画风格清新好看，适合大学生备考收藏。

## 核心卖点
• 连环画故事线，记词有情节有画面，不枯燥
• 每张8个词，一套覆盖 ${n*8} 个四级核心词
• 音标+词性+释义全在图里，一图搞定
• 好看可打印，备考神器

## 请生成三平台文案（直接输出，无需开场白）

### 【小红书】
**标题**（3个备选，20字以内，要有钩子）
**正文**（100字以内，开头点题，中间讲记忆方法，结尾互动）
**标签**（15个，含 #四级备考 #英语词汇 #词汇记忆 #插画笔记 等固定标签+动态标签）

### 【抖音】
**标题**（1个，15字以内）
**正文**（80字以内，口语化，结尾引导互动）
**标签**（5-8个）

### 【视频号】
**标题**（1个，20字以内，温暖有意境）
**正文**（100字以内，朋友圈转发调性）
**标签**（5个）

© 阿坚AIGC版权所有`;
}

function render(unit, n, sty, imgP, copyP, id){
  const area = document.getElementById('result');

  const card = document.createElement('div');
  card.className = 'rcard';
  card.innerHTML = `
    <div class="rh">
      <div class="rt">📋 ${unit} · ${n}张连环画提示词</div>
      <div class="brow">
        <span class="badge ba">${sty.name}</span>
        <span class="badge bg2">🍌 香蕉专用</span>
        <span class="badge bo">${n}章 × 8词 = ${n*8}词</span>
      </div>
    </div>
    <div class="tabs">
      <div class="tab on" onclick="swTab(this,'ip-${id}')">🖼️ 图片提示词</div>
      <div class="tab" onclick="swTab(this,'cp-${id}')">📝 文案提示词</div>
    </div>
    <div class="pane on" id="ip-${id}">
      <div class="info-box">💡 复制后发给支持联网的<b>即梦（香蕉）</b> → AI会规划故事线、查词、逐张出图</div>
      <div class="ibox" id="ib-${id}"></div>
      <div class="abar">
        <button class="btn-exp" onclick="expand('ib-${id}',this)">展开全文 ▾</button>
        <button class="btn-cp" id="icp-${id}" onclick="doCopy('img_${id}','icp-${id}')">复制提示词</button>
        <span class="cnum">${imgP.length} 字</span>
      </div>
    </div>
    <div class="pane" id="cp-${id}">
      <div class="info-box">💡 复制后发给 <b>Claude / DeepSeek</b> 生成小红书+抖音+视频号三套文案</div>
      <div class="ibox" id="cb-${id}"></div>
      <div class="abar">
        <button class="btn-exp" onclick="expand('cb-${id}',this)">展开全文 ▾</button>
        <button class="btn-cp" id="ccp-${id}" onclick="doCopy('copy_${id}','ccp-${id}')">复制提示词</button>
        <span class="cnum">${copyP.length} 字</span>
      </div>
    </div>
  `;

  // 用 textContent 安全写入原始文本（避免 HTML 转义问题）
  card.querySelector('#ib-'+id).textContent = imgP;
  card.querySelector('#ib-'+id).insertAdjacentHTML('beforeend','<div class="fade"></div>');
  card.querySelector('#cb-'+id).textContent = copyP;
  card.querySelector('#cb-'+id).insertAdjacentHTML('beforeend','<div class="fade"></div>');

  area.innerHTML = '';
  area.appendChild(card);
  setTimeout(()=>area.scrollIntoView({behavior:'smooth',block:'start'}),50);
}

function swTab(el, pid){
  const card = el.closest('.rcard');
  card.querySelectorAll('.tab').forEach(t=>t.classList.remove('on'));
  card.querySelectorAll('.pane').forEach(p=>p.classList.remove('on'));
  el.classList.add('on');
  document.getElementById(pid).classList.add('on');
}

function expand(id, btn){
  const box = document.getElementById(id);
  const open = box.classList.toggle('open');
  btn.textContent = open ? '收起 ▴' : '展开全文 ▾';
}

// 复制：直接从 promptStore 取原始字符串，完全避免 DOM 转义问题
function doCopy(key, btnId){
  const text = promptStore.get(key);
  if(!text){ alert('未找到内容，请重新生成'); return; }
  navigator.clipboard.writeText(text).then(()=>{
    const btn = document.getElementById(btnId);
    const orig = btn.textContent;
    btn.textContent = '已复制 ✓';
    btn.classList.add('ok');
    setTimeout(()=>{ btn.textContent=orig; btn.classList.remove('ok'); },2000);
  }).catch(()=>{
    // fallback：execCommand
    const ta = document.createElement('textarea');
    ta.value = text;
    ta.style.position='fixed';ta.style.opacity='0';
    document.body.appendChild(ta);
    ta.select();
    document.execCommand('copy');
    document.body.removeChild(ta);
    const btn = document.getElementById(btnId);
    const orig = btn.textContent;
    btn.textContent = '已复制 ✓';
    btn.classList.add('ok');
    setTimeout(()=>{ btn.textContent=orig; btn.classList.remove('ok'); },2000);
  });
}
</script>
</body>
</html>

<!DOCTYPE html>
<html lang="zh-CN">
<head>
<meta charset="UTF-8">
<meta name="viewport" content="width=device-width, initial-scale=1.0">
<title>食物的一生 · 提示词工坊</title>
<style>
* { box-sizing: border-box; margin: 0; padding: 0; }
:root {
  --bg: #f5f0e6;
  --card: #fdfaf4;
  --border: #ddd5b8;
  --green-dark: #2d4a1b;
  --green-mid: #3d6425;
  --green-light: #e8f0d8;
  --green-btn: #4a7a2a;
  --accent: #c87020;
  --text: #2a2010;
  --text-mid: #5a4a28;
  --text-soft: #8a7a58;
  --nav-bg: #1e3010;
  --tag-border: #c8b888;
}
body {
  background: var(--bg);
  font-family: 'PingFang SC','Hiragino Sans GB','Microsoft YaHei',serif;
  color: var(--text);
  min-height: 100vh;
}

/* 顶部导航 */
.top-nav {
  background: var(--nav-bg);
  color: #b8cc98;
  text-align: center;
  padding: 10px 20px;
  font-size: 12px;
  letter-spacing: 3px;
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 12px;
}
.top-nav .dot { opacity: 0.4; }

/* 主标题 */
.hero {
  text-align: center;
  padding: 32px 20px 24px;
  background: var(--bg);
  border-bottom: 1px solid var(--border);
}
.hero-badge {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  background: #e8e0c8;
  border: 1px solid var(--tag-border);
  border-radius: 20px;
  padding: 4px 14px;
  font-size: 12px;
  color: var(--text-mid);
  letter-spacing: 1px;
  margin-bottom: 14px;
}
.hero h1 {
  font-size: 30px;
  font-weight: 900;
  color: var(--green-dark);
  letter-spacing: 2px;
  margin-bottom: 4px;
}
.hero-desc {
  font-size: 13px;
  color: var(--text-soft);
  letter-spacing: 1px;
}

/* Tab切换 */
.tab-wrap {
  display: flex;
  justify-content: center;
  padding: 20px 20px 0;
}
.tab-box {
  display: flex;
  background: #e8e0c8;
  border: 1px solid var(--border);
  border-radius: 14px;
  padding: 4px;
  gap: 4px;
  width: 100%;
  max-width: 600px;
}
.tab-btn {
  flex: 1;
  padding: 12px 16px;
  border-radius: 10px;
  border: none;
  background: transparent;
  font-family: inherit;
  cursor: pointer;
  color: var(--text-mid);
  transition: all 0.2s;
  text-align: center;
}
.tab-btn .tab-icon { font-size: 18px; margin-bottom: 4px; display: block; }
.tab-btn .tab-name { font-size: 14px; font-weight: 700; display: block; }
.tab-btn .tab-sub { font-size: 11px; opacity: 0.65; display: block; margin-top: 2px; }
.tab-btn.active { background: var(--green-dark); color: #e8f0d8; }
.tab-btn.active .tab-sub { opacity: 0.8; }

/* 模式介绍卡 */
.mode-intro {
  margin: 16px 20px 0;
  max-width: 600px;
  margin-left: auto;
  margin-right: auto;
}
.mode-intro-card {
  border-radius: 12px;
  padding: 16px 18px;
  border: 1px solid;
  display: none;
}
.mode-intro-card.show { display: block; }
.mode-intro-card.green {
  background: var(--green-light);
  border-color: #b0d080;
}
.mode-intro-card.orange {
  background: #fef4e0;
  border-color: #f0c870;
}
.mode-intro-title {
  font-size: 14px;
  font-weight: 700;
  margin-bottom: 6px;
  display: flex;
  align-items: center;
  gap: 6px;
}
.mode-intro-card.green .mode-intro-title { color: var(--green-dark); }
.mode-intro-card.orange .mode-intro-title { color: #8a4a10; }
.mode-intro-desc {
  font-size: 12px;
  line-height: 1.9;
  color: var(--text-mid);
}
.mode-intro-desc b { color: var(--green-dark); }
.mode-intro-card.orange .mode-intro-desc b { color: #8a4a10; }
.mode-foods {
  margin-top: 10px;
  font-size: 12px;
  color: var(--text-soft);
  display: flex;
  align-items: center;
  gap: 6px;
  flex-wrap: wrap;
}
.mode-food-tag {
  background: rgba(255,255,255,0.6);
  border-radius: 10px;
  padding: 2px 10px;
  border: 1px solid rgba(0,0,0,0.08);
  font-size: 11px;
}

/* 主内容区 */
.main {
  max-width: 640px;
  margin: 0 auto;
  padding: 16px 20px 60px;
}

/* 折叠卡片 */
.fold-card {
  background: var(--card);
  border: 1px solid var(--border);
  border-radius: 12px;
  margin-bottom: 10px;
  overflow: hidden;
}
.fold-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 13px 18px;
  cursor: pointer;
  user-select: none;
  transition: background 0.15s;
}
.fold-header:hover { background: #f0e8d8; }
.fold-header-left {
  display: flex;
  align-items: center;
  gap: 8px;
  font-size: 13px;
  font-weight: 600;
  color: var(--text-mid);
}
.fold-toggle {
  font-size: 18px;
  color: var(--text-soft);
  line-height: 1;
  transition: transform 0.2s;
  font-weight: 300;
}
.fold-body {
  display: none;
  padding: 4px 18px 16px;
  border-top: 1px solid var(--border);
}
.fold-body.open { display: block; }

.step-row {
  display: flex;
  align-items: flex-start;
  gap: 10px;
  margin-top: 12px;
  font-size: 12px;
  color: var(--text-mid);
  line-height: 1.8;
}
.step-num {
  width: 20px; height: 20px;
  border-radius: 50%;
  background: var(--green-dark);
  color: #e8f0d8;
  font-size: 11px; font-weight: 700;
  display: flex; align-items: center; justify-content: center;
  flex-shrink: 0; margin-top: 2px;
}
.platform-block {
  background: var(--green-light);
  border-radius: 8px;
  padding: 10px 12px;
  margin-top: 10px;
  font-size: 12px;
  color: var(--text-mid);
  line-height: 1.9;
}
.platform-block b { color: var(--green-dark); }

/* 注意事项 */
.notice-card {
  background: #fef8ec;
  border: 1px solid #f0d890;
  border-radius: 12px;
  padding: 14px 18px;
  margin-bottom: 10px;
}
.notice-title {
  font-size: 13px; font-weight: 700;
  color: #8a5a10;
  margin-bottom: 8px;
  display: flex; align-items: center; gap: 6px;
}
.notice-list { list-style: none; }
.notice-list li {
  font-size: 12px; color: #7a5010;
  line-height: 2;
  padding-left: 14px;
  position: relative;
}
.notice-list li::before {
  content: '·';
  position: absolute; left: 4px;
  font-size: 16px; line-height: 1.4;
}

/* 输入区 */
.gen-card {
  background: var(--card);
  border: 1px solid var(--border);
  border-radius: 12px;
  padding: 18px 20px;
  margin-bottom: 10px;
}
.gen-title {
  font-size: 14px; font-weight: 700;
  color: var(--text-mid);
  margin-bottom: 10px;
  display: flex; align-items: center; gap: 8px;
}
.input-row {
  display: flex; gap: 10px;
  margin-bottom: 14px;
}
.gen-input {
  flex: 1;
  padding: 11px 14px;
  border: 1px solid var(--tag-border);
  border-radius: 10px;
  font-size: 14px;
  font-family: inherit;
  background: #fdf9f2;
  color: var(--text);
  outline: none;
  transition: border-color 0.2s;
}
.gen-input:focus { border-color: var(--green-btn); }
.btn-gen {
  padding: 11px 22px;
  background: var(--green-dark);
  color: #e8f0d8;
  border: none; border-radius: 10px;
  font-size: 14px; font-weight: 700;
  font-family: inherit; cursor: pointer;
  white-space: nowrap; letter-spacing: 2px;
  transition: background 0.2s;
}
.btn-gen:hover { background: var(--green-mid); }

.quick-label { font-size: 12px; color: var(--text-soft); margin-bottom: 8px; }
.quick-group { margin-bottom: 12px; }
.quick-group-title {
  font-size: 11px; color: var(--text-soft);
  margin-bottom: 6px;
  display: flex; align-items: center; gap: 6px;
}
.quick-group-title::after {
  content: '';
  flex: 1; height: 1px;
  background: var(--border);
}
.quick-tags { display: flex; flex-wrap: wrap; gap: 7px; }
.quick-tag {
  padding: 5px 13px;
  border-radius: 20px;
  border: 1px solid var(--tag-border);
  background: #f0e8d4;
  font-size: 12px; color: var(--text-mid);
  cursor: pointer; font-family: inherit;
  transition: all 0.15s;
}
.quick-tag:hover {
  background: var(--green-light);
  border-color: var(--green-btn);
  color: var(--green-dark);
}

/* 结果区 */
.result-area { display: none; }
.result-card {
  background: var(--card);
  border: 1px solid var(--border);
  border-radius: 12px;
  padding: 18px 20px;
  margin-bottom: 10px;
}
.result-header {
  display: flex; align-items: center;
  justify-content: space-between;
  margin-bottom: 12px;
}
.result-title {
  display: flex; align-items: center;
  gap: 8px; font-size: 14px; font-weight: 700;
  color: var(--text-mid);
}
.result-bar {
  width: 5px; height: 18px;
  border-radius: 3px; background: var(--green-dark);
}
.result-bar.orange { background: var(--accent); }

.btn-copy {
  padding: 6px 14px;
  background: #ede5d0;
  border: 1px solid var(--tag-border);
  border-radius: 8px;
  font-size: 12px; color: var(--text-mid);
  cursor: pointer; font-family: inherit;
  transition: all 0.2s;
}
.btn-copy:hover { background: var(--green-light); border-color: var(--green-btn); }
.btn-copy.copied { background: #d4e8c0; border-color: #80c060; color: #2a6010; }

.prompt-box {
  background: #faf6ef;
  border: 1px solid #e8dfc8;
  border-radius: 8px;
  padding: 14px;
  font-size: 12px; color: var(--text-mid);
  line-height: 2; white-space: pre-wrap;
  word-break: break-all; min-height: 60px;
  user-select: text;
}
.prompt-tip {
  margin-top: 8px; font-size: 11px;
  color: var(--text-soft);
  background: #f5f0e6;
  padding: 7px 12px; border-radius: 6px;
  line-height: 1.8;
}
.prompt-tip b { color: var(--green-dark); }

/* 阶段预览 */
.stages-bar {
  display: flex; border-radius: 8px;
  overflow: hidden; border: 1px solid var(--border);
  margin-bottom: 14px;
}
.stage-col {
  flex: 1; padding: 10px 4px;
  text-align: center;
  border-right: 1px dashed #c8b888;
}
.stage-col:last-child { border-right: none; }
.stage-name { font-size: 11px; font-weight: 600; color: #3a3020; }
.stage-status { font-size: 15px; margin-top: 3px; font-weight: 700; }

/* 步骤提示 */
.steps-tip {
  background: var(--green-light);
  border: 1px solid #b0d080;
  border-radius: 12px;
  padding: 14px 18px;
  margin-bottom: 10px;
}
.steps-tip-title {
  font-size: 13px; font-weight: 700;
  color: var(--green-dark); margin-bottom: 10px;
}
.step-item {
  display: flex; align-items: flex-start;
  gap: 10px; margin-bottom: 8px;
  font-size: 12px; color: var(--text-mid);
  line-height: 1.7;
}
.step-item:last-child { margin-bottom: 0; }

/* 底部版权 */
footer {
  text-align: center;
  padding: 28px 20px 40px;
  border-top: 1px solid var(--border);
}
.footer-logo { font-size: 18px; font-weight: 900; color: var(--green-dark); letter-spacing: 2px; margin-bottom: 4px; }
.footer-version { font-size: 12px; color: var(--text-soft); letter-spacing: 1px; margin-bottom: 16px; }
.footer-copy { font-size: 11px; color: #a09070; line-height: 2.2; }
.footer-copy b { color: var(--text-soft); }

@keyframes fadeUp {
  from { opacity: 0; transform: translateY(10px); }
  to { opacity: 1; transform: translateY(0); }
}
.fade-up { animation: fadeUp 0.3s ease; }
</style>
</head>
<body>

<!-- 顶部导航栏 -->
<div class="top-nav">
  <span>每天认识一种食物</span>
  <span class="dot">·</span>
  <span>科普信息图</span>
  <span class="dot">·</span>
  <span>提示词工坊 V2.0</span>
</div>

<!-- 主标题 -->
<div class="hero">
  <div class="hero-badge">🌿 图文科普 · 联网核实 · 三平台文案</div>
  <h1>食物的一生</h1>
  <div style="font-size:15px; color:var(--text-mid); margin:4px 0 6px; font-weight:600;">提示词生成器</div>
  <div class="hero-desc">选择模式 · 输入食物 · 一键生成出图提示词</div>
</div>

<!-- Tab模式切换 -->
<div class="tab-wrap">
  <div class="tab-box">
    <button class="tab-btn active" id="tab-grow" onclick="switchTab('grow')">
      <span class="tab-icon">🌱</span>
      <span class="tab-name">成熟周期模式</span>
      <span class="tab-sub">从青涩→成熟→过熟</span>
    </button>
    <button class="tab-btn" id="tab-fresh" onclick="switchTab('fresh')">
      <span class="tab-icon">🔍</span>
      <span class="tab-name">新鲜判断模式</span>
      <span class="tab-sub">买回来能不能吃？</span>
    </button>
  </div>
</div>

<!-- 模式介绍卡 -->
<div style="max-width:640px; margin:14px auto 0; padding:0 20px;">

  <div class="mode-intro-card green show" id="intro-grow">
    <div class="mode-intro-title">🌱 成熟周期模式 · 是什么？</div>
    <div class="mode-intro-desc">
      展示一种食物<b>从青涩未熟到最佳食用期再到过熟腐坏</b>的完整生长变化过程。<br>
      让读者一眼看懂：这个食物<b>什么时候能吃、什么时候最甜、什么时候该扔</b>。<br>
      适合做：水果、蔬菜等有明显成熟周期变化的食材。
    </div>
    <div class="mode-foods">
      <span>适合食材：</span>
      <span class="mode-food-tag">🍉 西瓜</span>
      <span class="mode-food-tag">🌵 榴莲</span>
      <span class="mode-food-tag">🍌 香蕉</span>
      <span class="mode-food-tag">🍒 荔枝</span>
      <span class="mode-food-tag">🫐 蓝莓</span>
      <span class="mode-food-tag">🥭 芒果</span>
      <span class="mode-food-tag">🍑 桃子</span>
      <span class="mode-food-tag">更多……</span>
    </div>
  </div>

  <div class="mode-intro-card orange" id="intro-fresh">
    <div class="mode-intro-title" style="color:#8a4a10;">🔍 新鲜判断模式 · 是什么？</div>
    <div class="mode-intro-desc" style="color:var(--text-mid);">
      展示一种食物<b>从刚买回来到开始变质到完全腐坏</b>的不同状态对比。<br>
      教读者用<b>看/闻/摸/听</b>等简单方法判断食材新不新鲜、能不能安全食用。<br>
      适合做：鸡蛋、生蚝、肉类、切开的水果等容易变质的日常食材。
    </div>
    <div class="mode-foods">
      <span>适合食材：</span>
      <span class="mode-food-tag">🥚 鸡蛋</span>
      <span class="mode-food-tag">🦪 生蚝</span>
      <span class="mode-food-tag">🍞 面包</span>
      <span class="mode-food-tag">🥛 牛奶</span>
      <span class="mode-food-tag">🍉 切开的西瓜</span>
      <span class="mode-food-tag">更多……</span>
    </div>
  </div>

</div>

<!-- 主内容 -->
<div class="main">

  <!-- 使用说明（折叠） -->
  <div class="fold-card">
    <div class="fold-header" onclick="toggleFold('fold1')">
      <div class="fold-header-left">📖 使用说明</div>
      <div class="fold-toggle" id="ftoggle-fold1">+</div>
    </div>
    <div class="fold-body" id="fold1">
      <div class="step-row">
        <div class="step-num">1</div>
        <div>选择上方模式（成熟周期 or 新鲜判断） → 输入食物名称 → 点「生 成」</div>
      </div>
      <div class="step-row">
        <div class="step-num">2</div>
        <div>复制「图片提示词」→ 粘贴给<b>开联网的 Claude 或 DeepSeek</b> → 让它查完资料后输出完整出图提示词</div>
      </div>
      <div class="step-row">
        <div class="step-num">3</div>
        <div>复制 AI 生成的出图提示词 → 打开 <b>Lovart 香蕉Pro / GPT Image 2 / 即梦</b> → 比例选 <b>3:4（竖版）</b> 或 <b>16:9（横版）</b></div>
      </div>
      <div class="step-row">
        <div class="step-num">4</div>
        <div>把生成好的图片 + 「三平台文案提示词」→ 一起发给 Claude/DeepSeek → 直接输出小红书+抖音+公众号三套文案</div>
      </div>
      <div class="platform-block">
        <b>📱 三平台文案各输出什么：</b><br>
        · 小红书：备选标题×3 + 正文200字 + 15个话题标签<br>
        · 抖音：钩子开场 + 80字口播文案 + 10个标签<br>
        · 公众号：完整图文教程（大号教程版 + 小号干货版）
      </div>
    </div>
  </div>

  <!-- 各平台说明（折叠） -->
  <div class="fold-card">
    <div class="fold-header" onclick="toggleFold('fold2')">
      <div class="fold-header-left">🎯 各平台使用说明</div>
      <div class="fold-toggle" id="ftoggle-fold2">+</div>
    </div>
    <div class="fold-body" id="fold2">
      <div class="platform-block">
        🎨 <b>图片提示词</b> → Claude（开联网）→ 查资料后输出出图提示词 → GPT Image 2 / 香蕉Pro / 即梦
      </div>
      <div class="platform-block" style="margin-top:8px;">
        📱 <b>三平台文案提示词</b> → DeepSeek联网 / Claude（开搜索）→ 上传图片一起发 → 一次输出三平台文案
      </div>
      <div class="platform-block" style="margin-top:8px;">
        📐 <b>出图比例建议：</b><br>
        · 竖版 3:4 → 小红书/抖音封面（推荐）<br>
        · 横版 16:9 → 公众号头图 / 视频号封面
      </div>
    </div>
  </div>

  <!-- 注意事项 -->
  <div class="notice-card">
    <div class="notice-title">⚠️ 注意事项</div>
    <ul class="notice-list">
      <li>图片提示词需发给<b>开启联网功能</b>的 Claude 或 DeepSeek，让 AI 先查资料再生成提示词，确保内容准确</li>
      <li>食用建议（✓△✕）仅供科普参考，请以实际食材状态和自身判断为准，不构成医疗或食品安全建议</li>
      <li>出图效果因平台和模型版本不同可能存在差异，建议多生成几张挑选最佳效果</li>
      <li>内置食物数据为常见情况，特殊品种或产地可能有所不同，以联网查询结果为准</li>
      <li>本工具及提示词模板版权归 <b>阿坚AIGC</b> 所有，仅供授权用户个人创作使用，<b>禁止商业转载与二次分发</b></li>
    </ul>
  </div>

  <!-- 输入生成区 -->
  <div class="gen-card">
    <div class="gen-title">
      <span id="gen-icon">🌱</span>
      <span id="gen-title-text">输入食物名称，生成完整提示词</span>
    </div>

    <div class="input-row">
      <input class="gen-input" id="foodInput" type="text" placeholder="西瓜、榴莲、香蕉、鸡蛋……" />
      <button class="btn-gen" onclick="generatePrompt()">生 成</button>
    </div>

    <!-- 成熟周期模式快捷 -->
    <div id="quick-grow">
      <div class="quick-label">快捷选择：</div>
      <div class="quick-group">
        <div class="quick-group-title">🍉 水果类</div>
        <div class="quick-tags">
          <button class="quick-tag" onclick="quickSelect('西瓜')">🍉 西瓜</button>
          <button class="quick-tag" onclick="quickSelect('榴莲')">🌵 榴莲</button>
          <button class="quick-tag" onclick="quickSelect('荔枝')">🍒 荔枝</button>
          <button class="quick-tag" onclick="quickSelect('香蕉')">🍌 香蕉</button>
          <button class="quick-tag" onclick="quickSelect('蓝莓')">🫐 蓝莓</button>
          <button class="quick-tag" onclick="quickSelect('草莓')">🍓 草莓</button>
          <button class="quick-tag" onclick="quickSelect('芒果')">🥭 芒果</button>
          <button class="quick-tag" onclick="quickSelect('龙眼')">🟡 龙眼</button>
          <button class="quick-tag" onclick="quickSelect('牛油果')">🥑 牛油果</button>
          <button class="quick-tag" onclick="quickSelect('桃子')">🍑 桃子</button>
        </div>
      </div>
      <div class="quick-group">
        <div class="quick-group-title">🥦 蔬菜类</div>
        <div class="quick-tags">
          <button class="quick-tag" onclick="quickSelect('番茄')">🍅 番茄</button>
          <button class="quick-tag" onclick="quickSelect('玉米')">🌽 玉米</button>
          <button class="quick-tag" onclick="quickSelect('南瓜')">🎃 南瓜</button>
        </div>
      </div>
    </div>

    <!-- 新鲜判断模式快捷 -->
    <div id="quick-fresh" style="display:none;">
      <div class="quick-label">快捷选择：</div>
      <div class="quick-group">
        <div class="quick-group-title">🥚 日常食材</div>
        <div class="quick-tags">
          <button class="quick-tag" onclick="quickSelect('鸡蛋')">🥚 鸡蛋</button>
          <button class="quick-tag" onclick="quickSelect('生蚝')">🦪 生蚝</button>
          <button class="quick-tag" onclick="quickSelect('面包')">🍞 面包</button>
          <button class="quick-tag" onclick="quickSelect('牛奶')">🥛 牛奶</button>
        </div>
      </div>
      <div class="quick-group">
        <div class="quick-group-title">🍉 切开的水果</div>
        <div class="quick-tags">
          <button class="quick-tag" onclick="quickSelect('切开的西瓜')">🍉 切开的西瓜</button>
          <button class="quick-tag" onclick="quickSelect('切开的榴莲')">🌵 切开的榴莲</button>
          <button class="quick-tag" onclick="quickSelect('切开的芒果')">🥭 切开的芒果</button>
        </div>
      </div>
    </div>
  </div>

  <!-- 结果区 -->
  <div class="result-area" id="resultArea">

    <div class="result-card">
      <div class="result-header">
        <div class="result-title">
          <div class="result-bar"></div>
          <span id="stages-title">阶段预览</span>
        </div>
      </div>
      <div class="stages-bar" id="stagesBar"></div>
    </div>

    <div class="result-card">
      <div class="result-header">
        <div class="result-title">
          <div class="result-bar"></div>
          <span>图片提示词</span>
        </div>
        <button class="btn-copy" id="copyBtn1" onclick="copyText('imgPrompt','copyBtn1')">一键复制</button>
      </div>
      <div class="prompt-box" id="imgPrompt"></div>
      <div class="prompt-tip">
        💡 复制后发给 <b>开联网的 Claude 或 DeepSeek</b>，让它查完资料后生成完整的出图提示词，再去香蕉Pro / GPT Image 2 出图
      </div>
    </div>

    <div class="result-card">
      <div class="result-header">
        <div class="result-title">
          <div class="result-bar orange"></div>
          <span>三平台文案提示词</span>
        </div>
        <button class="btn-copy" id="copyBtn2" onclick="copyText('xhsPrompt','copyBtn2')">一键复制</button>
      </div>
      <div class="prompt-box" id="xhsPrompt"></div>
      <div class="prompt-tip">
        💡 出完图后，把图片 + 这段提示词一起发给 Claude/DeepSeek → 直接输出 <b>小红书 + 抖音 + 公众号</b> 三套文案
      </div>
    </div>

    <div class="steps-tip">
      <div class="steps-tip-title">📋 接下来怎么用</div>
      <div class="step-item">
        <div class="step-num">1</div>
        <div>复制<b>图片提示词</b> → 发给开联网的 Claude 或 DeepSeek → 让它查资料后输出完整出图提示词</div>
      </div>
      <div class="step-item">
        <div class="step-num">2</div>
        <div>复制出图提示词 → 打开 <b>Lovart 香蕉Pro</b>，竖版选 <b>3:4</b>，横版选 <b>16:9</b> → 生成</div>
      </div>
      <div class="step-item">
        <div class="step-num">3</div>
        <div>把图片 + <b>三平台文案提示词</b> → 一起发给 Claude/DeepSeek → 输出三平台配套文案</div>
      </div>
      <div class="step-item">
        <div class="step-num">4</div>
        <div><b>小红书选竖版，公众号选横版</b>，按平台特点发布，效果最佳</div>
      </div>
    </div>

  </div>

</div>

<!-- 底部版权 -->
<footer>
  <div class="footer-logo">🌿 食物的一生</div>
  <div class="footer-version">提示词工坊 · V2.0 · 成熟周期 + 新鲜判断双模式</div>
  <div class="footer-copy">
    版权所有 © <b>阿坚AIGC</b><br>
    本工具及提示词模板受版权保护<br>
    仅供授权用户个人创作使用<br>
    <b>禁止商业转载与二次分发</b>
  </div>
</footer>

<script>
let currentTab = 'grow';

const foodData = {
  '西瓜': { stages:[{name:'青涩期',bg:'#d4e8b4',st:'✕',sc:'#c0392b'},{name:'过渡期',bg:'#e4eec4',st:'△',sc:'#d68910'},{name:'微成熟期',bg:'#fef0c4',st:'✓',sc:'#27ae60'},{name:'成熟期',bg:'#c8e8b4',st:'✓',sc:'#1a8020'},{name:'过熟期',bg:'#e8e0b4',st:'△',sc:'#d68910'}] },
  '榴莲': { stages:[{name:'青涩期',bg:'#c8e0a4',st:'✕',sc:'#c0392b'},{name:'微熟期',bg:'#e4eebc',st:'✕',sc:'#c0392b'},{name:'成熟期',bg:'#fef4c4',st:'✓',sc:'#27ae60'},{name:'香甜期',bg:'#fce8a4',st:'✓',sc:'#1a8020'},{name:'过熟期',bg:'#e8d8a4',st:'△',sc:'#d68910'}] },
  '荔枝': { stages:[{name:'青果期',bg:'#d4e8b0',st:'✕',sc:'#c0392b'},{name:'转色期',bg:'#f4d4c0',st:'✕',sc:'#c0392b'},{name:'半熟期',bg:'#f4c0b0',st:'△',sc:'#d68910'},{name:'成熟期',bg:'#e8a0a0',st:'✓',sc:'#1a8020'},{name:'过熟期',bg:'#d08080',st:'△',sc:'#d68910'}] },
  '香蕉': { stages:[{name:'青涩期',bg:'#c8e4a0',st:'✕',sc:'#c0392b'},{name:'转黄期',bg:'#e8f0b4',st:'△',sc:'#d68910'},{name:'成熟期',bg:'#fef4a0',st:'✓',sc:'#1a8020'},{name:'甜熟期',bg:'#fce890',st:'✓',sc:'#27ae60'},{name:'过熟期',bg:'#e8c870',st:'△',sc:'#d68910'}] },
  '蓝莓': { stages:[{name:'青果期',bg:'#c8d8e0',st:'✕',sc:'#c0392b'},{name:'转色期',bg:'#c8b8d8',st:'✕',sc:'#c0392b'},{name:'半熟期',bg:'#a090c8',st:'△',sc:'#d68910'},{name:'成熟期',bg:'#7878b0',st:'✓',sc:'#1a8020'},{name:'过熟期',bg:'#606090',st:'△',sc:'#d68910'}] },
  '草莓': { stages:[{name:'青涩期',bg:'#d4e8b0',st:'✕',sc:'#c0392b'},{name:'转色期',bg:'#f4d4c0',st:'△',sc:'#d68910'},{name:'半熟期',bg:'#f4b0a0',st:'△',sc:'#d68910'},{name:'成熟期',bg:'#e88080',st:'✓',sc:'#1a8020'},{name:'过熟期',bg:'#c06060',st:'✕',sc:'#c0392b'}] },
  '芒果': { stages:[{name:'青涩期',bg:'#c8e0a0',st:'✕',sc:'#c0392b'},{name:'转黄期',bg:'#e8e8a8',st:'△',sc:'#d68910'},{name:'成熟期',bg:'#fce890',st:'✓',sc:'#1a8020'},{name:'香甜期',bg:'#f8d070',st:'✓',sc:'#27ae60'},{name:'过熟期',bg:'#e8b850',st:'△',sc:'#d68910'}] },
  '龙眼': { stages:[{name:'青果期',bg:'#c8e4a0',st:'✕',sc:'#c0392b'},{name:'膨大期',bg:'#e0e8b0',st:'✕',sc:'#c0392b'},{name:'转色期',bg:'#f0e0c0',st:'△',sc:'#d68910'},{name:'成熟期',bg:'#e8d090',st:'✓',sc:'#1a8020'},{name:'过熟期',bg:'#d8b870',st:'△',sc:'#d68910'}] },
  '牛油果': { stages:[{name:'青硬期',bg:'#c0d890',st:'✕',sc:'#c0392b'},{name:'转色期',bg:'#a8c880',st:'△',sc:'#d68910'},{name:'微熟期',bg:'#909870',st:'△',sc:'#d68910'},{name:'成熟期',bg:'#706850',st:'✓',sc:'#1a8020'},{name:'过熟期',bg:'#584838',st:'✕',sc:'#c0392b'}] },
  '桃子': { stages:[{name:'青果期',bg:'#d0e8a8',st:'✕',sc:'#c0392b'},{name:'转色期',bg:'#f0d0b8',st:'△',sc:'#d68910'},{name:'半熟期',bg:'#f0c0a8',st:'△',sc:'#d68910'},{name:'成熟期',bg:'#f0a888',st:'✓',sc:'#1a8020'},{name:'过熟期',bg:'#d88070',st:'△',sc:'#d68910'}] },
  '番茄': { stages:[{name:'青果期',bg:'#c8e0a0',st:'✕',sc:'#c0392b'},{name:'转色期',bg:'#f0c898',st:'△',sc:'#d68910'},{name:'半熟期',bg:'#f0a878',st:'△',sc:'#d68910'},{name:'成熟期',bg:'#e07858',st:'✓',sc:'#1a8020'},{name:'过熟期',bg:'#c05840',st:'△',sc:'#d68910'}] },
  '玉米': { stages:[{name:'青嫩期',bg:'#e0f0b0',st:'✓',sc:'#1a8020'},{name:'成熟期',bg:'#f8e870',st:'✓',sc:'#27ae60'},{name:'老化期',bg:'#e8c840',st:'△',sc:'#d68910'},{name:'干燥期',bg:'#c8a830',st:'△',sc:'#d68910'},{name:'变质期',bg:'#a08020',st:'✕',sc:'#c0392b'}] },
  '南瓜': { stages:[{name:'幼果期',bg:'#c8e0a0',st:'✕',sc:'#c0392b'},{name:'生长期',bg:'#d0d890',st:'△',sc:'#d68910'},{name:'成熟期',bg:'#e8b850',st:'✓',sc:'#1a8020'},{name:'完熟期',bg:'#d89840',st:'✓',sc:'#27ae60'},{name:'过熟期',bg:'#b07830',st:'△',sc:'#d68910'}] },
  '鸡蛋': { stages:[{name:'新鲜期',bg:'#fef8e8',st:'✓',sc:'#1a8020'},{name:'次新鲜期',bg:'#fef0d0',st:'✓',sc:'#27ae60'},{name:'普通期',bg:'#fce8c0',st:'△',sc:'#d68910'},{name:'临期',bg:'#f8d8a8',st:'△',sc:'#d68910'},{name:'变质期',bg:'#e8c090',st:'✕',sc:'#c0392b'}] },
  '生蚝': { stages:[{name:'幼苗期',bg:'#e8e8d8',st:'✕',sc:'#c0392b'},{name:'生长期',bg:'#d8d8c8',st:'✕',sc:'#c0392b'},{name:'育肥期',bg:'#c8c8b8',st:'△',sc:'#d68910'},{name:'最佳期',bg:'#b8b8a8',st:'✓',sc:'#1a8020'},{name:'变质期',bg:'#909080',st:'✕',sc:'#c0392b'}] },
  '面包': { stages:[{name:'新鲜期',bg:'#fef4d4',st:'✓',sc:'#1a8020'},{name:'回软期',bg:'#fde8c4',st:'✓',sc:'#27ae60'},{name:'老化期',bg:'#f4d8b4',st:'△',sc:'#d68910'},{name:'干硬期',bg:'#e8c8a0',st:'△',sc:'#d68910'},{name:'霉变期',bg:'#d4c094',st:'✕',sc:'#c0392b'}] },
  '牛奶': { stages:[{name:'新鲜期',bg:'#fefef8',st:'✓',sc:'#1a8020'},{name:'次新鲜期',bg:'#f8f8f0',st:'✓',sc:'#27ae60'},{name:'临期',bg:'#f0f0e0',st:'△',sc:'#d68910'},{name:'过期期',bg:'#e0e0c8',st:'✕',sc:'#c0392b'},{name:'变质期',bg:'#c8c8a8',st:'✕',sc:'#c0392b'}] },
  '切开的西瓜': { stages:[{name:'超新鲜',bg:'#ffe0e0',st:'✓',sc:'#1a8020'},{name:'新鲜',bg:'#ffd0c8',st:'✓',sc:'#27ae60'},{name:'临界',bg:'#f8c0b0',st:'△',sc:'#d68910'},{name:'变质初期',bg:'#e8a890',st:'✕',sc:'#c0392b'},{name:'严重变质',bg:'#c08070',st:'✕',sc:'#c0392b'}] },
  '切开的榴莲': { stages:[{name:'超新鲜',bg:'#fef4c0',st:'✓',sc:'#1a8020'},{name:'新鲜',bg:'#fce8a8',st:'✓',sc:'#27ae60'},{name:'临界',bg:'#f8d890',st:'△',sc:'#d68910'},{name:'变质初期',bg:'#e8c070',st:'✕',sc:'#c0392b'},{name:'严重变质',bg:'#c8a050',st:'✕',sc:'#c0392b'}] },
  '切开的芒果': { stages:[{name:'超新鲜',bg:'#fce898',st:'✓',sc:'#1a8020'},{name:'新鲜',bg:'#f8d880',st:'✓',sc:'#27ae60'},{name:'临界',bg:'#f0c868',st:'△',sc:'#d68910'},{name:'变质初期',bg:'#e0a848',st:'✕',sc:'#c0392b'},{name:'严重变质',bg:'#c08830',st:'✕',sc:'#c0392b'}] },
};

function switchTab(tab) {
  currentTab = tab;
  document.getElementById('tab-grow').classList.toggle('active', tab === 'grow');
  document.getElementById('tab-fresh').classList.toggle('active', tab === 'fresh');
  document.getElementById('intro-grow').classList.toggle('show', tab === 'grow');
  document.getElementById('intro-fresh').classList.toggle('show', tab === 'fresh');
  document.getElementById('quick-grow').style.display = tab === 'grow' ? 'block' : 'none';
  document.getElementById('quick-fresh').style.display = tab === 'fresh' ? 'block' : 'none';
  document.getElementById('gen-icon').textContent = tab === 'grow' ? '🌱' : '🔍';
  document.getElementById('foodInput').placeholder = tab === 'grow' ? '西瓜、榴莲、香蕉、荔枝……' : '鸡蛋、生蚝、面包、切开的西瓜……';
  document.getElementById('resultArea').style.display = 'none';
  document.getElementById('foodInput').value = '';
}

function toggleFold(id) {
  const body = document.getElementById(id);
  const toggle = document.getElementById('ftoggle-' + id);
  const isOpen = body.classList.contains('open');
  body.classList.toggle('open', !isOpen);
  toggle.textContent = isOpen ? '+' : '×';
}

function quickSelect(food) {
  document.getElementById('foodInput').value = food;
  generatePrompt();
}

function generatePrompt() {
  const food = document.getElementById('foodInput').value.trim();
  if (!food) { alert('请输入食物名称'); return; }

  const data = foodData[food];
  const ra = document.getElementById('resultArea');
  ra.style.display = 'block';
  ra.classList.remove('fade-up');
  void ra.offsetWidth;
  ra.classList.add('fade-up');

  // 阶段预览
  const bar = document.getElementById('stagesBar');
  const defaultStages = currentTab === 'grow'
    ? [{name:'青涩期',bg:'#d4e8b4',st:'✕',sc:'#c0392b'},{name:'过渡期',bg:'#f4f0c4',st:'△',sc:'#d68910'},{name:'成熟期',bg:'#c8e8b4',st:'✓',sc:'#1a8020'},{name:'过熟期',bg:'#e8e0b4',st:'△',sc:'#d68910'},{name:'变质期',bg:'#d8c8a0',st:'✕',sc:'#c0392b'}]
    : [{name:'超新鲜',bg:'#e8f8e0',st:'✓',sc:'#1a8020'},{name:'新鲜',bg:'#f4f4d0',st:'✓',sc:'#27ae60'},{name:'临界',bg:'#f8e8b8',st:'△',sc:'#d68910'},{name:'变质初期',bg:'#f0c8a0',st:'✕',sc:'#c0392b'},{name:'严重变质',bg:'#d8a880',st:'✕',sc:'#c0392b'}];
  const stages = (data && data.stages) ? data.stages : defaultStages;
  bar.innerHTML = stages.map((s, i) =>
    `<div class="stage-col" style="background:${s.bg};">
      <div class="stage-name">${s.name}</div>
      <div class="stage-status" style="color:${s.sc};">${s.st}</div>
    </div>`
  ).join('');

  document.getElementById('stages-title').textContent = `${food} · ${currentTab === 'grow' ? '成熟周期' : '新鲜度'}预览`;

  const stageCount = stages.length;

  if (currentTab === 'grow') {
    document.getElementById('imgPrompt').textContent =
`你是一位专业食物科普信息图设计师。

请联网搜索「${food}」从未成熟到过熟的完整变化过程，收集：
- 各阶段（共${stageCount}个）的外观特点、颜色、质地变化
- 各阶段内部变化（糖分/淀粉/水分/果肉状态）
- 各阶段食用建议（✓推荐食用 / △适合加工 / ✕不可食用）
- 保存方法和时间 / 科普小知识1-2句

查完资料后，输出完整图片生成提示词：

以"${food}的一生"为主题的科普信息图。
画面必须是"一个完整的单体${food}"，通过横向切片方式表现同一个${food}在不同成熟阶段的变化，不是多个拼接。主体结构连续、形状一致，只是在不同切片区域呈现不同成熟度（像时间被切开）。

画面竖版3:4比例，主体居中横向展开，均匀分割为${stageCount}份：
从左到右：[根据查到的资料填入各阶段名称]

每段体现真实变化：[颜色/质地/特征的具体描述]

每个阶段配中文文字说明：阶段名称 / 外观特点 / 内部变化 / 食用建议（✓△✕）

设计风格：极简浅色背景（米色）/ 高真实感摄影风格 / 清晰白色虚线分割（时间切片感）/ 中文科普排版小红书风格
顶部大标题："${food}的一生"
副标题："同一个${food}，不同时期的成长变化"
底部小知识：[填入科普知识] | 保存时间：[填入保存建议]

关键要求：必须是"同一个${food}随时间变化的切片"，不是多个独立个体拼接。`;

    document.getElementById('xhsPrompt').textContent =
`你是一位擅长三平台运营的AIGC内容创作者。
我上传了一张"${food}的一生"科普信息图，根据图片内容同时输出三平台配套文案：

【小红书】
- 备选标题：3个，带emoji，有收藏冲动，不超过20字
- 正文：200字左右，口语化，有实用知识点，有共鸣感
- 结尾：引导收藏+评论互动
- 话题标签：15个，含 #${food} #食物科普 #涨知识 等
- 语气：轻松活泼，有点小幽默，不要AI味

【抖音】
- 钩子开场：前3秒抓注意力（5-10字）
- 口播正文：80字，口语化，有节奏感
- 结尾：引导点赞收藏关注
- 话题标签：10个

【公众号（小号干货版）】
- 标题：1个，有数字/悬念，不超过25字
- 正文：300字，分段清晰，干货为主
- 结尾：引导关注+评论互动`;

  } else {
    document.getElementById('imgPrompt').textContent =
`你是一位专业食品安全科普信息图设计师。

请联网搜索「${food}」的新鲜度判断方法，收集：
- 从新鲜到变质的完整阶段（${stageCount}个阶段）
- 各阶段外观特点（颜色/气味/质地变化）
- 每个阶段的判断方法（看/闻/摸/听，要具体可操作）
- 各阶段食用安全建议（✓安全 / △谨慎 / ✕危险）
- 正确保存方法和时间 / 食品安全小知识1-2句

查完资料后，输出完整图片生成提示词：

以"${food}新不新鲜，一眼就知道"为主题的食品安全科普信息图。
画面通过对比方式展示${food}从新鲜到变质的${stageCount}个不同状态，横向排列，视觉差异要强烈明显。

画面竖版3:4比例，均匀分割为${stageCount}份：
从左到右：[根据查到的资料填入阶段名称，从新鲜到变质]

每段体现真实变化：[颜色/质地/气味的具体描述]

每个阶段配中文文字说明：阶段名称 / 外观特点 / 判断方法（看/闻/摸）/ 食用建议（✓△✕）

设计风格：极简浅色背景（米白）/ 高真实感摄影风格 / 清晰虚线分割 / 中文科普排版小红书风格
顶部大标题："${food}新不新鲜，一眼就知道"
副标题："这${stageCount}个阶段告诉你能不能吃"
底部保存提示：[保存方法] | [保存时间] | ⚠️[重要食品安全警示]

关键要求：${stageCount}个阶段视觉对比要强烈，从新鲜→变质颜色差异一目了然，每个阶段的判断方法要具体可操作，读者可以直接照着做。`;

    document.getElementById('xhsPrompt').textContent =
`你是一位擅长三平台运营的AIGC内容创作者。
我上传了一张"${food}新不新鲜判断"的食品安全科普信息图，根据图片内容同时输出三平台配套文案：

【小红书】
- 备选标题：3个，带emoji，制造共鸣（如：买${food}踩过坑？一招教你不再买到坏的）
- 正文：200字，口语化，有实操方法，有共鸣感
- 结尾：引导收藏+评论
- 话题标签：15个，含 #${food} #食品安全 #生活小知识 等

【抖音】
- 钩子：前3秒制造紧迫感（5-10字）
- 口播：80字，口语化，给出3个核心判断方法
- 结尾：引导点赞收藏关注
- 话题标签：10个

【公众号（小号干货版）】
- 标题：1个，有数字，不超过25字
- 正文：300字，分段清晰，判断方法为主
- 结尾：引导关注+评论互动`;
  }

  ra.scrollIntoView({ behavior: 'smooth', block: 'start' });
}

function copyText(id, btnId) {
  const text = document.getElementById(id).textContent;
  if (!text) return;
  const btn = document.getElementById(btnId);
  navigator.clipboard.writeText(text).then(() => {
    btn.textContent = '已复制 ✓';
    btn.classList.add('copied');
    setTimeout(() => { btn.textContent = '一键复制'; btn.classList.remove('copied'); }, 2000);
  }).catch(() => {
    const el = document.getElementById(id);
    const range = document.createRange();
    range.selectNode(el);
    window.getSelection().removeAllRanges();
    window.getSelection().addRange(range);
    try { document.execCommand('copy'); } catch(e){}
    window.getSelection().removeAllRanges();
    btn.textContent = '已复制 ✓';
    btn.classList.add('copied');
    setTimeout(() => { btn.textContent = '一键复制'; btn.classList.remove('copied'); }, 2000);
  });
}
</script>
</body>
</html>

<!DOCTYPE html>
<html lang="zh-CN">
<head>
<meta charset="UTF-8">
<meta name="viewport" content="width=device-width, initial-scale=1.0">
<title>城市文化图文工坊 · 阿坚AIGC</title>
<link href="https://fonts.googleapis.com/css2?family=Noto+Serif+SC:wght@400;600;700;900&display=swap" rel="stylesheet">
<style>
*{box-sizing:border-box;margin:0;padding:0}
:root{
  --bg:#faf6ef;--paper:#fffdf8;--ink:#1a0f00;--ink2:#4a3010;--ink3:#8a6040;
  --red:#8b1a1a;--red-light:#fdecea;--gold:#c8920a;--gold-light:#fef9e7;
  --border:#e0cfa8;--nav:#3a1a00;--shadow:rgba(26,15,0,.08);
  --green:#1a4a1a;--green-light:#edf5ed;--blue:#1a2a6a;--blue-light:#edf0fd;
  --teal:#0a4a3a;--teal-light:#edf5f2;--purple:#3a1a6a;--purple-light:#f0edf8;
}
body{font-family:'Noto Serif SC','STKaiti','PingFang SC',serif;background:var(--bg);color:var(--ink);min-height:100vh}

/* ===== 顶部窄条 ===== */
.top-bar{
  background:var(--nav);color:rgba(212,169,106,.8);
  text-align:center;padding:9px 20px;font-size:11px;letter-spacing:3px;
  display:flex;align-items:center;justify-content:center;gap:10px;
}
.top-dot{width:3px;height:3px;border-radius:50%;background:rgba(212,169,106,.4)}

/* ===== Hero ===== */
.hero{
  text-align:center;padding:44px 20px 36px;
  border-bottom:1px solid var(--border);position:relative;
}
.hero::after{
  content:'';position:absolute;bottom:-1px;left:50%;transform:translateX(-50%);
  width:60px;height:2px;background:var(--red);
}
.hero-badge{
  display:inline-flex;align-items:center;gap:6px;
  background:var(--red-light);border:1px solid #e8b0a8;
  border-radius:4px;padding:4px 14px;font-size:11px;color:var(--red);
  letter-spacing:2px;margin-bottom:14px;
}
.hero h1{font-size:clamp(22px,4vw,36px);font-weight:900;color:var(--ink);letter-spacing:3px;margin-bottom:6px;line-height:1.3}
.hero h1 em{color:var(--red);font-style:normal}
.hero-desc{font-size:12px;color:var(--ink3);letter-spacing:2px}

/* ===== 主容器 ===== */
.container{max-width:720px;margin:0 auto;padding:24px 16px 60px;display:flex;flex-direction:column;gap:14px}

/* ===== 折叠手册 ===== */
.foldable{background:var(--paper);border:1px solid var(--border);border-radius:6px;overflow:hidden}
.fold-trigger{
  width:100%;display:flex;align-items:center;justify-content:space-between;
  padding:13px 18px;background:none;border:none;cursor:pointer;
  font-family:inherit;font-size:13px;font-weight:700;color:var(--ink2);
  letter-spacing:1px;transition:background .15s;
}
.fold-trigger:hover{background:var(--gold-light)}
.fold-icon{font-size:18px;color:var(--ink3);font-weight:300;transition:transform .2s}
.fold-content{display:none;padding:4px 18px 16px;border-top:1px solid var(--border);font-size:12px;color:var(--ink2);line-height:2}
.fold-content.open{display:block}
.fold-trigger.open .fold-icon{transform:rotate(45deg)}
.fold-content b{color:var(--red)}

/* ===== 参数卡片 ===== */
.card{background:var(--paper);border:1px solid var(--border);border-radius:6px;padding:20px 20px 16px}
.card-title{
  font-size:13px;font-weight:700;color:var(--ink2);letter-spacing:1px;
  margin-bottom:16px;display:flex;align-items:center;gap:8px;
}
.card-title::before{content:'';width:4px;height:16px;background:var(--red);border-radius:2px;flex-shrink:0}

.field{margin-bottom:16px}
.field:last-child{margin-bottom:0}
.field-label{
  font-size:12px;font-weight:700;color:var(--ink2);
  margin-bottom:10px;letter-spacing:1px;
  display:flex;align-items:center;gap:6px;
}
.f-dot{width:5px;height:5px;border-radius:50%;background:var(--gold);flex-shrink:0}
.f-hint{font-size:10px;color:var(--ink3);font-weight:400;letter-spacing:.5px}

/* ===== 城市分组 ===== */
.city-region{margin-bottom:12px}
.region-label{font-size:10px;color:var(--ink3);letter-spacing:2px;margin-bottom:6px;padding-left:2px}
.chip-group{display:flex;flex-wrap:wrap;gap:7px}
.chip{
  padding:6px 14px;background:var(--bg);border:1px solid var(--border);
  border-radius:4px;font-family:inherit;font-size:12px;font-weight:600;
  cursor:pointer;transition:all .15s;color:var(--ink3);letter-spacing:.5px;user-select:none;
}
.chip:hover{background:var(--gold-light);border-color:var(--gold);color:var(--ink2)}
.chip.active{background:var(--red);border-color:var(--red);color:#fff}

/* 自定义城市输入 */
.city-custom{
  display:flex;gap:8px;align-items:center;margin-top:10px;
  padding-top:10px;border-top:1px dashed var(--border);
}
.city-custom input{
  flex:1;padding:8px 12px;border:1px solid var(--border);border-radius:4px;
  font-family:inherit;font-size:12px;color:var(--ink);background:var(--paper);outline:none;
  transition:border-color .15s;
}
.city-custom input:focus{border-color:var(--gold)}
.city-custom input::placeholder{color:var(--ink3);opacity:.7;font-size:11px}
.city-custom-btn{
  padding:8px 16px;background:var(--bg);border:1px solid var(--border);
  border-radius:4px;font-family:inherit;font-size:11px;color:var(--ink3);
  cursor:pointer;transition:all .15s;white-space:nowrap;
}
.city-custom-btn:hover{background:var(--gold-light);border-color:var(--gold);color:var(--ink2)}

/* ===== 内容方向 ===== */
.dir-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:10px}
.dir-card{
  background:var(--bg);border:1px solid var(--border);border-radius:6px;
  padding:14px;cursor:pointer;transition:all .18s;
}
.dir-card:hover{border-color:var(--gold);background:var(--gold-light)}
.dir-card.active{border-color:var(--red);background:var(--red-light)}
.dir-icon{font-size:22px;margin-bottom:6px;display:block}
.dir-name{font-size:13px;font-weight:700;color:var(--ink2);margin-bottom:3px;letter-spacing:.5px}
.dir-desc{font-size:10px;color:var(--ink3);line-height:1.6}
.dir-tag{
  display:inline-block;margin-top:6px;font-size:9px;
  padding:2px 7px;border-radius:3px;font-weight:700;letter-spacing:.5px;
}
.dir-card.active .dir-name{color:var(--red)}
.dir-card.active .dir-desc{color:var(--red-light)}

/* ===== 图文风格 ===== */
.style-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:10px}
.style-card{
  background:var(--bg);border:1px solid var(--border);border-radius:6px;
  padding:14px 12px;text-align:center;cursor:pointer;transition:all .18s;
}
.style-card:hover{border-color:var(--gold);background:var(--gold-light)}
.style-card.active{border-color:var(--red);background:var(--red-light)}
.style-emoji{font-size:22px;margin-bottom:6px;display:block}
.style-name{font-size:12px;font-weight:700;color:var(--ink2);margin-bottom:2px;letter-spacing:.5px}
.style-desc{font-size:10px;color:var(--ink3);line-height:1.5}
.style-card.active .style-name{color:var(--red)}

/* ===== 生成按钮 ===== */
.gen-btn{
  width:100%;padding:13px;background:var(--red);color:#fff;border:none;
  border-radius:6px;font-size:15px;font-weight:700;font-family:inherit;
  cursor:pointer;letter-spacing:3px;transition:background .2s;
}
.gen-btn:hover{background:#6a1010}

/* ===== 输出区 ===== */
#outputWrap{display:none}
#outputWrap.show{display:block;animation:fadeIn .4s}
@keyframes fadeIn{from{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}

.out-tabs{display:flex;border-bottom:2px solid var(--border)}
.out-tab{
  padding:10px 16px;font-size:12px;font-weight:700;color:var(--ink3);
  cursor:pointer;border:none;background:none;font-family:inherit;
  letter-spacing:1px;border-bottom:2px solid transparent;margin-bottom:-2px;transition:all .2s;
}
.out-tab.active{color:var(--red);border-bottom-color:var(--red)}
.out-pane{display:none;padding-top:12px}
.out-pane.active{display:block}

.out-label{display:flex;align-items:center;justify-content:space-between;margin-bottom:8px}
.out-label span{font-size:12px;font-weight:700;color:var(--ink2);letter-spacing:1px}
.out-box{
  background:var(--bg);border:1px solid var(--border);border-radius:4px;
  padding:14px;font-size:11px;color:var(--ink2);line-height:2;
  white-space:pre-wrap;word-break:break-all;user-select:text;
  max-height:500px;overflow-y:auto;
}
.out-tip{
  margin-top:8px;font-size:11px;color:var(--ink3);
  background:var(--gold-light);padding:8px 12px;border-radius:4px;
  border:1px solid rgba(200,146,10,.2);line-height:1.8;
}
.out-tip b{color:var(--ink2)}

.copy-btn{
  padding:5px 14px;background:var(--bg);border:1px solid var(--border);
  border-radius:4px;font-size:11px;color:var(--ink2);cursor:pointer;
  font-family:inherit;transition:all .2s;
}
.copy-btn:hover{background:var(--gold-light);border-color:var(--gold)}
.copy-btn.ok{background:var(--green-light);border-color:var(--green);color:var(--green)}

/* ===== Toast ===== */
.toast{
  position:fixed;bottom:24px;left:50%;transform:translateX(-50%) translateY(20px);
  background:var(--ink);color:#fff;padding:10px 24px;border-radius:4px;
  font-size:12px;opacity:0;transition:all .3s;pointer-events:none;z-index:999;letter-spacing:1px;
}
.toast.show{opacity:1;transform:translateX(-50%) translateY(0)}

/* ===== 版权 ===== */
.footer-bar{
  text-align:center;padding:24px 20px;border-top:1px solid var(--border);background:var(--bg);
}
.footer-bar .logo{font-size:14px;font-weight:700;color:var(--ink);letter-spacing:3px;margin-bottom:5px}
.footer-bar .copy{font-size:11px;color:#6a4a20;letter-spacing:1px;line-height:2}

@media(max-width:600px){
  .dir-grid{grid-template-columns:1fr}
  .style-grid{grid-template-columns:repeat(2,1fr)}
}
</style>
</head>
<body>

<div class="top-bar">
  <span>阿坚AIGC</span><div class="top-dot"></div>
  <span>城市文化图文工坊</span><div class="top-dot"></div>
  <span>提示词工坊</span>
</div>

<div class="hero">
  <div class="hero-badge">🏙️ 城市文化 · 非遗手艺 · 地域美食 · 方言梗图</div>
  <h1>城市文化<em>图文</em>工坊</h1>
  <div class="hero-desc">选城市 · 选内容方向 · 选图文风格 · 一键生成提示词</div>
</div>

<div class="container">

  <!-- 折叠手册 -->
  <div class="foldable">
    <button class="fold-trigger" onclick="toggleFold(this)">
      <span>📖 使用手册 · 三步出图</span>
      <span class="fold-icon">+</span>
    </button>
    <div class="fold-content">
      <p><b>① 选参数</b> → 选城市 + 内容方向 + 图文风格（+可选子主题）</p>
      <p><b>② 复制提示词</b> → 发给<b>开联网的Claude</b>，让它查资料后输出完整出图提示词</p>
      <p><b>③ 出图</b> → 把Claude输出的提示词发给香蕉Pro / 即梦，比例 <b>3:4 竖版</b></p>
      <br>
      <p>· 内容方向说明：</p>
      <p>· <b>城市名片</b> — 地标建筑/必打卡景点，适合文旅号和城市推广内容</p>
      <p>· <b>地道美食</b> — 当地特色小吃/老字号招牌，适合美食号和种草内容</p>
      <p>· <b>非遗手艺</b> — 传统技艺/民俗活动，#非遗话题8亿+浏览，高热赛道</p>
      <p>· <b>方言文化</b> — 地域梗/方言表情包，传播性强，适合做地域特色账号</p>
    </div>
  </div>

  <!-- 选城市 -->
  <div class="card">
    <div class="card-title">选择城市</div>

    <div class="city-region">
      <div class="region-label">── 华北 ──</div>
      <div class="chip-group" data-group="city">
        <div class="chip" data-val="北京">北京</div>
        <div class="chip" data-val="天津">天津</div>
        <div class="chip" data-val="西安">西安</div>
        <div class="chip" data-val="大同">大同</div>
      </div>
    </div>

    <div class="city-region">
      <div class="region-label">── 华东 ──</div>
      <div class="chip-group" data-group="city">
        <div class="chip" data-val="上海">上海</div>
        <div class="chip" data-val="杭州">杭州</div>
        <div class="chip" data-val="苏州">苏州</div>
        <div class="chip" data-val="南京">南京</div>
        <div class="chip" data-val="扬州">扬州</div>
        <div class="chip" data-val="绍兴">绍兴</div>
      </div>
    </div>

    <div class="city-region">
      <div class="region-label">── 华南 ──</div>
      <div class="chip-group" data-group="city">
        <div class="chip" data-val="广州">广州</div>
        <div class="chip" data-val="深圳">深圳</div>
        <div class="chip" data-val="厦门">厦门</div>
        <div class="chip" data-val="泉州">泉州</div>
        <div class="chip" data-val="潮汕">潮汕</div>
      </div>
    </div>

    <div class="city-region">
      <div class="region-label">── 西南 ──</div>
      <div class="chip-group" data-group="city">
        <div class="chip" data-val="成都">成都</div>
        <div class="chip" data-val="重庆">重庆</div>
        <div class="chip" data-val="云南大理">大理</div>
        <div class="chip" data-val="云南丽江">丽江</div>
        <div class="chip" data-val="贵州">贵州</div>
      </div>
    </div>

    <div class="city-region">
      <div class="region-label">── 华中/华北 ──</div>
      <div class="chip-group" data-group="city">
        <div class="chip" data-val="武汉">武汉</div>
        <div class="chip" data-val="长沙">长沙</div>
        <div class="chip" data-val="洛阳">洛阳</div>
        <div class="chip" data-val="开封">开封</div>
      </div>
    </div>

    <div class="city-region">
      <div class="region-label">── 东北/西北 ──</div>
      <div class="chip-group" data-group="city">
        <div class="chip" data-val="哈尔滨">哈尔滨</div>
        <div class="chip" data-val="沈阳">沈阳</div>
        <div class="chip" data-val="敦煌">敦煌</div>
        <div class="chip" data-val="乌鲁木齐">乌鲁木齐</div>
      </div>
    </div>

    <div class="city-custom">
      <input type="text" id="cityInput" placeholder="其他城市？直接输入城市名">
      <button class="city-custom-btn" onclick="setCustomCity()">确认</button>
    </div>
  </div>

  <!-- 内容方向 -->
  <div class="card">
    <div class="card-title">内容方向</div>
    <div class="dir-grid" id="dirGrid">
      <div class="dir-card" data-val="城市名片" onclick="selectDir(this)">
        <span class="dir-icon">🏛️</span>
        <div class="dir-name">城市名片图鉴</div>
        <div class="dir-desc">地标建筑 / 必打卡景点<br>城市文旅推广首选</div>
        <span class="dir-tag" style="background:var(--blue-light);color:var(--blue)">文旅号</span>
      </div>
      <div class="dir-card" data-val="地道美食" onclick="selectDir(this)">
        <span class="dir-icon">🍜</span>
        <div class="dir-name">地道美食地图</div>
        <div class="dir-desc">特色小吃 / 老字号 / 宵夜<br>种草转化率最高</div>
        <span class="dir-tag" style="background:var(--orange-light,#fff4ed);color:#c07020">美食号</span>
      </div>
      <div class="dir-card" data-val="非遗手艺" onclick="selectDir(this)">
        <span class="dir-icon">🎎</span>
        <div class="dir-name">非遗手艺图鉴</div>
        <div class="dir-desc">传统技艺 / 民俗文化<br>#非遗话题8亿+浏览</div>
        <span class="dir-tag" style="background:var(--red-light);color:var(--red)">🔥 最高热</span>
      </div>
      <div class="dir-card" data-val="方言文化" onclick="selectDir(this)">
        <span class="dir-icon">💬</span>
        <div class="dir-name">方言文化梗图</div>
        <div class="dir-desc">地域梗 / 方言表情包<br>传播性极强</div>
        <span class="dir-tag" style="background:var(--green-light);color:var(--green)">高传播</span>
      </div>
    </div>

    <!-- 子主题（根据方向动态显示） -->
    <div id="subTopicWrap" style="display:none;margin-top:14px;padding-top:14px;border-top:1px dashed var(--border)">
      <div class="field-label" style="margin-bottom:8px"><span class="f-dot"></span>细分主题<span class="f-hint">（点推荐或直接输入）</span></div>
      <div class="chip-group" id="subTopicChips"></div>
      <div style="display:flex;gap:8px;align-items:center;margin-top:10px">
        <input type="text" id="subInput" placeholder="也可自己输入细分主题，如：担担面 / 宽窄巷子 / 蜀绣..."
          style="flex:1;padding:8px 12px;border:1px solid var(--border);border-radius:4px;font-family:inherit;font-size:11px;color:var(--ink);background:var(--paper);outline:none;transition:border-color .15s"
          oninput="state.sub=this.value;document.querySelectorAll('#subTopicChips .chip').forEach(c=>c.classList.remove('active'))"
          onfocus="this.style.borderColor='var(--gold)'"
          onblur="this.style.borderColor='var(--border)'">
        <button onclick="clearSubInput()" style="padding:8px 12px;background:var(--bg);border:1px solid var(--border);border-radius:4px;font-family:inherit;font-size:11px;color:var(--ink3);cursor:pointer;white-space:nowrap">清空</button>
      </div>
    </div>
  </div>

  <!-- 图文风格 -->
  <div class="card">
    <div class="card-title">图文风格</div>
    <div class="style-grid" id="styleGrid">
      <div class="style-card" data-val="国潮水墨古风" onclick="selectStyle(this)">
        <span class="style-emoji">🖌️</span>
        <div class="style-name">国潮水墨古风</div>
        <div class="style-desc">仿古籍线描 · 浅赭灰墨<br>适合非遗/历史文化内容</div>
      </div>
      <div class="style-card" data-val="旅行手账插画" onclick="selectStyle(this)">
        <span class="style-emoji">✏️</span>
        <div class="style-name">旅行手账插画</div>
        <div class="style-desc">温馨手绘插画风 · 烟火气<br>适合美食/街景/城市名片</div>
      </div>
      <div class="style-card" data-val="国潮扁平信息图" onclick="selectStyle(this)">
        <span class="style-emoji">📊</span>
        <div class="style-name">国潮扁平信息图</div>
        <div class="style-desc">扁平插画+传统纹理<br>适合非遗科普/城市图鉴</div>
      </div>
      <div class="style-card" data-val="Q版卡通表情包" onclick="selectStyle(this)">
        <span class="style-emoji">🎨</span>
        <div class="style-name">Q版卡通表情包</div>
        <div class="style-desc">萌系卡通 · 高传播性<br>适合方言梗图/本地梗</div>
      </div>
    </div>
  </div>

  <!-- 生成按钮 -->
  <button class="gen-btn" id="genBtn" onclick="generate()">生　成</button>

  <!-- 输出区 -->
  <div class="card" id="outputWrap">
    <div class="out-tabs">
      <button class="out-tab active" onclick="switchTab('img',this)">📋 图片提示词</button>
      <button class="out-tab" onclick="switchTab('wx',this)">📝 三平台文案提示词</button>
    </div>
    <div class="out-pane active" id="pane-img">
      <div class="out-label">
        <span>图片提示词 · 发给Claude联网查资料</span>
        <button class="copy-btn" id="copyImg" onclick="copyPane('imgBox','copyImg')">一键复制</button>
      </div>
      <div class="out-box" id="imgBox"></div>
      <div class="out-tip">💡 复制后发给<b>开联网的Claude</b>，让它查询城市相关资料后输出完整出图提示词，再发香蕉Pro出图，比例 <b>3:4 竖版</b></div>
    </div>
    <div class="out-pane" id="pane-wx">
      <div class="out-label">
        <span>三平台文案提示词 · 出完图后使用</span>
        <button class="copy-btn" id="copyWx" onclick="copyPane('wxBox','copyWx')">一键复制</button>
      </div>
      <div class="out-box" id="wxBox"></div>
      <div class="out-tip">💡 出完图后，把<b>图片+这段提示词</b>一起发给Claude → 输出<b>视频号+小红书+抖音</b>三套文案</div>
    </div>
  </div>

</div>

<div class="footer-bar">
  <div class="logo">📜 阿坚AIGC · 图文知识卡片</div>
  <div class="copy">城市文化图文工坊 · V1.0<br>版权所有 © 阿坚AIGC · 仅供授权用户个人创作使用 · 禁止商业转载与二次分发</div>
</div>

<div class="toast" id="toast"></div>

<script>
const state = { city:'', dir:'', style:'', sub:'' };

// 子主题数据
const SUB_TOPICS = {
  '城市名片': ['地标建筑','古城古镇','网红打卡地','博物馆','历史街区','自然景观'],
  '地道美食': ['早餐早茶','特色小吃','老字号名店','宵夜夜市','地方面食','街边摊','甜品糕点'],
  '非遗手艺': ['刺绣织造','陶瓷漆器','剪纸年画','民间戏曲','传统服饰','手工编织','民俗节日'],
  '方言文化': ['方言日常用语','地域搞笑梗','本地人才懂的','外地人误解','方言美食叫法','城市性格图鉴'],
};

// 城市chip选择（跨组互斥）
document.querySelectorAll('.chip-group[data-group="city"]').forEach(group => {
  group.addEventListener('click', e => {
    const chip = e.target.closest('.chip');
    if (!chip) return;
    // 清除所有城市chip的active
    document.querySelectorAll('.chip-group[data-group="city"] .chip').forEach(c => c.classList.remove('active'));
    chip.classList.add('active');
    state.city = chip.dataset.val;
    document.getElementById('cityInput').value = '';
    showToast('✓ 已选：' + state.city);
  });
});

function setCustomCity() {
  const v = document.getElementById('cityInput').value.trim();
  if (!v) return;
  document.querySelectorAll('.chip-group[data-group="city"] .chip').forEach(c => c.classList.remove('active'));
  state.city = v;
  showToast('✓ 已设置：' + v);
}

document.getElementById('cityInput').addEventListener('keydown', e => {
  if (e.key === 'Enter') setCustomCity();
});

function selectDir(card) {
  document.querySelectorAll('.dir-card').forEach(c => c.classList.remove('active'));
  card.classList.add('active');
  state.dir = card.dataset.val;
  state.sub = '';
  updateSubTopics(state.dir);
  showToast('✓ 已选：' + state.dir);
}

function updateSubTopics(dir) {
  const wrap = document.getElementById('subTopicWrap');
  const chips = document.getElementById('subTopicChips');
  const subs = SUB_TOPICS[dir] || [];
  if (!subs.length) { wrap.style.display = 'none'; return; }
  wrap.style.display = 'block';
  chips.innerHTML = subs.map(s =>
    `<div class="chip" onclick="selectSub(this,'${s}')" data-val="${s}">${s}</div>`
  ).join('');
}

function selectSub(chip, val) {
  document.querySelectorAll('#subTopicChips .chip').forEach(c => c.classList.remove('active'));
  const input = document.getElementById('subInput');
  if (state.sub === val) {
    state.sub = '';
    if(input) input.value = '';
    return;
  }
  chip.classList.add('active');
  state.sub = val;
  if(input) input.value = val;
}

function clearSubInput() {
  state.sub = '';
  document.getElementById('subInput').value = '';
  document.querySelectorAll('#subTopicChips .chip').forEach(c => c.classList.remove('active'));
}

function selectStyle(card) {
  document.querySelectorAll('.style-card').forEach(c => c.classList.remove('active'));
  card.classList.add('active');
  state.style = card.dataset.val;
  showToast('✓ 已选：' + state.style);
}

function toggleFold(btn) {
  btn.classList.toggle('open');
  btn.nextElementSibling.classList.toggle('open');
}

function generate() {
  if (!state.city) { showToast('⚠️ 请先选择或输入城市'); return; }
  if (!state.dir)  { showToast('⚠️ 请选择内容方向'); return; }
  if (!state.style){ showToast('⚠️ 请选择图文风格'); return; }

  const sub = state.sub ? `·${state.sub}` : '';
  const topic = `${state.city}·${state.dir}${sub}`;

  const imgPrompt = buildImgPrompt(state.city, state.dir, state.style, state.sub);
  const wxPrompt  = buildWxPrompt(topic, state.dir, state.style);

  document.getElementById('imgBox').textContent = imgPrompt;
  document.getElementById('wxBox').textContent  = wxPrompt;

  const wrap = document.getElementById('outputWrap');
  wrap.classList.add('show');
  setTimeout(() => wrap.scrollIntoView({behavior:'smooth',block:'start'}), 100);
  showToast('✨ 生成成功！');
}

function buildImgPrompt(city, dir, style, sub) {
  const subStr = sub ? `，细分主题：${sub}` : '';
  const styleGuides = {
    '国潮水墨古风': '仿古籍线描插图风格，以纤细线条勾画，色彩以浅赭、灰墨、淡青为主，呈现古书插画的文化韵味与历史感，保留传统古印刷风格，留白充足意境深远',
    '旅行手账插画': '旅行手账风格插画，线条温暖手绘感强，色彩饱满明快有烟火气息，融合城市地标与美食美景，像精美的城市旅行手绘日记，亲切自然有温度',
    '国潮扁平信息图': '国潮艺术风格扁平化插画，将城市地标与文化元素融入图文设计，整体配色古朴典雅，红绿蓝黄等传统色调，具有扁平化插画风格和细腻的纹理质感',
    'Q版卡通表情包': 'Q版卡通风格，人物造型圆润萌系，表情夸张生动，色彩鲜艳活泼，画面感幽默有趣，适合制作地域方言梗图和本地生活表情包，传播性极强',
  };
  const dirGuides = {
    '城市名片': `聚焦${city}最具代表性的地标或景点，突出城市独特的历史底蕴和视觉辨识度`,
    '地道美食': `展现${city}最地道的特色美食，突出食物的色香味形，让人产生强烈的食欲和向往感`,
    '非遗手艺': `展现${city}非物质文化遗产的工艺之美，突出传统技艺的精湛细节和文化厚度`,
    '方言文化': `以图文形式展现${city}独特的方言文化和地域性格，轻松幽默，引发本地人强烈共鸣`,
  };

  return `你是一位专业的城市文化图文创作者，请帮我联网查询${city}的${dir}相关资料${subStr}，然后生成一张高质量图文的出图提示词。

【查询要求】
请联网查询以下内容，确保信息真实准确：
· ${city}${sub || dir}的代表性元素/特色（至少5个具体内容）
· 相关历史背景或文化故事（1-2个）
· 适合小红书传播的视觉亮点

【图片提示词格式要求】
请按以下结构输出完整的图片提示词：

整体风格：竖版3:4比例，${styleGuides[style]}。${dirGuides[dir]}。

【顶部区块（约20%）】
背景：（根据查到的${city}${dir}内容，描述顶部背景画面）
标题大字：「${city}${sub || dir}」，手写毛笔或对应风格字体，醒目清晰

【主体内容区（约60%）】
（根据查询到的具体内容，列出3-5个核心元素的图文呈现方式，每个元素包含：
· 图示内容描述
· 文字标注方式
· 色调和细节要求）

【底部区块（约20%）】
阿坚AIGC印章或版权标识，整体收尾设计

整体要求：不要出现英文，不要其他水印，画面信息量丰富但不杂乱，有强烈的城市地域特色感。比例3:4竖版。`;
}

function buildWxPrompt(topic, dir, style) {
  const dirAngle = {
    '城市名片': '城市种草/打卡攻略角度，引发向往感和出行冲动',
    '地道美食': '美食种草角度，突出口感特色和必吃理由，引发食欲',
    '非遗手艺': '文化科普角度，展现非遗之美和传承故事，引发文化自豪感',
    '方言文化': '地域认同角度，引发本地人强烈共鸣，外地人好奇心',
  };
  return `你是一位擅长三平台运营的AIGC内容创作者。
我刚刚用AI生成了一张「${topic}」图文内容，请根据图片内容同时输出三平台配套文案：

内容角度：${dirAngle[dir] || '城市文化科普角度'}
图文风格：${style}

【视频号文案】
- 标题：1个，不超过20字，突出城市特色，有情感共鸣
- 正文：150字，口语化，有温度，引发对这座城市的向往或认同
- 结尾：引导点赞收藏转发

【小红书文案】
- 备选标题：3个，带emoji，有收藏冲动，不超过20字
- 正文：200字，口语化，城市感强，有画面感
- 结尾：引导收藏+评论互动（如「你去过吗？」「你们那边有吗？」）
- 话题标签：12个，含城市名+内容类型+热门话题

【抖音文案】
- 备选标题：3个，带emoji，有点击欲，不超过20字
- 正文：150字，节奏感强，有反转或冷知识切入点
- 结尾：引导点赞收藏关注
- 话题标签：8个`;
}

function switchTab(id, btn) {
  document.querySelectorAll('.out-tab').forEach(b => b.classList.remove('active'));
  document.querySelectorAll('.out-pane').forEach(p => p.classList.remove('active'));
  btn.classList.add('active');
  document.getElementById('pane-' + id).classList.add('active');
}

function copyPane(boxId, btnId) {
  const text = document.getElementById(boxId).textContent;
  if (!text) return;
  const btn = document.getElementById(btnId);
  navigator.clipboard.writeText(text).then(() => {
    btn.textContent = '已复制 ✓'; btn.classList.add('ok');
    setTimeout(() => { btn.textContent = '一键复制'; btn.classList.remove('ok'); }, 1800);
  }).catch(() => {
    const ta = document.createElement('textarea');
    ta.value = text; document.body.appendChild(ta); ta.select();
    document.execCommand('copy'); document.body.removeChild(ta);
    btn.textContent = '已复制 ✓'; btn.classList.add('ok');
    setTimeout(() => { btn.textContent = '一键复制'; btn.classList.remove('ok'); }, 1800);
  });
}

function showToast(msg) {
  const t = document.getElementById('toast');
  t.textContent = msg; t.classList.add('show');
  setTimeout(() => t.classList.remove('show'), 1800);
}
</script>
</body>
</html>
