:root{
  --sg-bg:#f5f1eb;--sg-bg2:#ede9e1;--sg-bg3:#e4dfd5;
  --sg-white:#ffffff;--sg-card:#faf8f4;
  --sg-ink:#1c1a17;--sg-ink2:#5a5650;--sg-ink3:#777777;
  --sg-accent:#2d5a3d;--sg-accent2:#3a7a52;--sg-accent-light:#d6ead9;
  --sg-border:#d8d3ca;--sg-border2:#c8c2b8;
  --sg-step:#d4622a;
  --sg-sell:#7c3aed;--sg-sell-bg:#f3f0ff;--sg-sell-tc:#5b21b6;
  --sg-grow:#0369a1;--sg-grow-bg:#e0f2fe;--sg-grow-tc:#0c4a6e;
  --sg-trust:#b45309;--sg-trust-bg:#fef3c7;--sg-trust-tc:#78350f;
}

/* ── ページヘッド ── */
.sg-page-head{max-width:1400px;margin:0 auto;padding:10px 32px 0;}
.sg-page-head .page-title{font-size:24px;font-weight:800;letter-spacing:-.5px;margin-bottom:4px;color:var(--sg-ink); text-align:center;}
.sg-page-head .page-sub{font-size: 15px;  text-align: center;  margin: 0 auto 40px;  color: #555;}

/* ── ラッパー ── */
.sg-wrap{max-width:1400px;margin:0 auto;}
.sg-wrap *{box-sizing:border-box;}

/* ── プラットフォームグリッド ── */
.platform-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:8px;}
.plat-btn{background:#f5f2ed;border:1px solid #d7d1c9;border-radius:2px;padding:12px 8px;cursor:pointer;transition:all .15s;font-family:'DM Sans',sans-serif;font-size:13px;font-weight:600;color:#111;display:flex;align-items:center;justify-content:center;gap:8px;width:100%;min-height:56px;}
.plat-btn:hover{border-color:#bdb3a8;background:#f1ece4;}
.plat-btn .fa-brands{font-size:17px;line-height:1;}
.plat-btn .plat-label{line-height:1;}
.plat-btn.sel-ig{background:linear-gradient(135deg,#f9ce34,#ee2a7b,#6228d7);border-color:transparent;color:#fff;text-shadow:0 1px 2px rgba(0,0,0,.3);}
.plat-btn.sel-x {background:#14171a;border-color:#14171a;color:#fff;}
.plat-btn.sel-tt{background:#e8005a;border-color:#e8005a;color:#fff;}
.plat-btn.sel-yt{background:#cc0000;border-color:#cc0000;color:#fff;}

/* ── 1カラムレイアウト ── */
.sg-cols{display:block;}
.sg-col-in{min-width:0;}
.sg-col-out{min-width:0;margin-top:20px;}

/* ── 大枠ボックス（トップと同じ黒線1つで囲む） ── */
.sg-box{background:var(--paper);border:2px solid var(--sg-ink);overflow:hidden; padding:15px 0;}

/* ── ボックス内セクション区切り ── */
.sg-sec{border-bottom:1px solid var(--sg-border);padding:18px 22px;}
.sg-sec:last-child{border-bottom:none;}

/* ── セクションヘッダー行 ── */
.sg-sec-head{display:flex;align-items:center;justify-content:space-between;margin-bottom:14px;}
.sg-sec-left{display:flex;align-items:center;gap:10px;}
.sg-sec-num{width:24px;height:24px;border-radius:50%;background:var(--sg-step);color:#fff;font-size:12px;font-weight:700;display:flex;align-items:center;justify-content:center;flex-shrink:0;}
.sg-sec-title{font-size:17px;font-weight:700;color:var(--sg-ink);}
.sg-sec-hint{font-size:11px;color:var(--sg-ink3);}

/* ── 出力ボックスのヘッダー ── */
.sg-out-head{display:flex;align-items:center;justify-content:space-between;padding:14px 20px;border-bottom:1px solid var(--sg-border);}
.sg-out-badge{width:28px;height:28px;border-radius:50%;background:var(--sg-accent);color:#fff;font-size:11px;font-weight:700;display:flex;align-items:center;justify-content:center;flex-shrink:0;}
.sg-out-title{font-size:14px;font-weight:700;color:var(--sg-ink);}
.sg-out-hint{font-size:11px;color:var(--sg-ink3);}

/* ── 目的ボタン ── */
.purpose-grid{display:grid;grid-template-columns:1fr 1fr 1fr;gap:8px;}
.purpose-btn{background:var(--sg-bg);border:1.5px solid var(--sg-border);border-radius:0;padding:22px 14px;cursor:pointer;transition:all .15s;font-family:'DM Sans',sans-serif;width:100%;display:flex;flex-direction:row;align-items:center;gap:14px;text-align:left;}
.purpose-btn:hover{border-color:var(--sg-border2);transform:translateY(-1px);}
.purpose-btn .p-icon{font-size: 27px;
  line-height: 1;
  flex-shrink: 0;
  text-align: center;
  display: flex;
  align-items: center;
  justify-content: center;
  color: white;
  background: gray;
  padding: 5px;
  width: 40px;
  height: 40px;
  border-radius: 3px;}
.purpose-btn .p-text{display:flex;flex-direction:column;gap:3px;min-width:0;}
.purpose-btn .p-label{font-family:'Syne',sans-serif;font-size:16px;font-weight:700;display:block;color:var(--sg-ink);line-height:1.2;}
.purpose-btn .p-desc{font-size:11px;color:var(--sg-ink3);line-height:1.5;display:block;}
.purpose-btn.active-sell{background:var(--sg-sell-bg);border-color:var(--sg-sell);color:var(--sg-sell-tc);}
.purpose-btn.active-sell .p-desc{color:var(--sg-sell-tc);opacity:.7;}
.purpose-btn.active-sell .p-icon{background:var(--sg-sell);}
.purpose-btn.active-grow{background:var(--sg-grow-bg);border-color:var(--sg-grow);color:var(--sg-grow-tc);}
.purpose-btn.active-grow .p-desc{color:var(--sg-grow-tc);opacity:.7;}
.purpose-btn.active-grow .p-icon{background:var(--sg-grow);}
.purpose-btn.active-trust{background:var(--sg-trust-bg);border-color:var(--sg-trust);color:var(--sg-trust-tc);}
.purpose-btn.active-trust .p-desc{color:var(--sg-trust-tc);opacity:.7;}
.purpose-btn.active-trust .p-icon{background:var(--sg-trust);}

/* ── テンプレ（カード内下部） ── */
.tpl-section{border-top:1px solid var(--sg-border);padding:12px 0 0;margin:14px 0 0;}
.tpl-label{font-size:10px;font-weight:500;color:var(--sg-ink3);letter-spacing:1.1px;text-transform:uppercase;margin-bottom:8px;}
.template-row{display:flex;gap:6px;flex-wrap:wrap;}
.tpl-chip{background:var(--sg-bg);border:1px solid var(--sg-border);border-radius:100px;color:var(--sg-ink2);font-size:12px;padding:7px 14px;cursor:pointer;transition:all .15s;font-family:'DM Sans',sans-serif;flex:1 1 125px;display:inline-flex;flex-direction:column;align-items:center;justify-content:center;gap:3px;text-align:center;}
.tpl-emoji{font-size:18px;line-height:1;}
.tpl-text{font-size:11px;line-height:1.2;white-space:nowrap;}
.tpl-chip:hover{border-color:var(--sg-accent2);color:var(--sg-accent);background:var(--sg-accent-light);}
.tpl-chip.active{background:var(--sg-accent);border-color:var(--sg-accent);color:#fff;font-weight:500;}

/* ── テキストエリア ── */
.sg-wrap textarea{width:100%;background:white;border:1px solid var(--sg-border);border-radius:8px;color:var(--sg-ink);font-family:'DM Sans',sans-serif;font-size:14px;line-height:1.65;padding:14px 16px;resize:vertical;outline:none;min-height:120px;transition:border-color .2s;}
.sg-wrap textarea:focus{border-color:var(--sg-accent);}
.sg-wrap textarea::placeholder{color:var(--sg-ink3);}

/* ── トーン ── */
.tone-section{border-top:1px solid var(--sg-border);padding:12px 0 0;margin:14px 0 0;}
.tone-label{font-size:10px;font-weight:500;color:var(--sg-ink3);letter-spacing:1.1px;text-transform:uppercase;margin-bottom:8px;}
.tone-row{display:flex;gap:6px;flex-wrap:wrap;}
.tone-btn{background:var(--sg-bg);border:1px solid var(--sg-border);border-radius:100px;color:var(--sg-ink2);font-family:'DM Sans',sans-serif;font-size:12px;padding:7px 14px;cursor:pointer;transition:all .15s;flex:1 1 125px;text-align:center;}
.tone-btn:hover{border-color:var(--sg-accent2);color:var(--sg-accent);}
.tone-btn.active{background:var(--sg-accent);border-color:var(--sg-accent);color:#fff;font-weight:500;}

/* ── 生成ボタン ── */
.gen-btn{width:100%;background:var(--sg-ink);border:none;border-radius:10px;color:#fff;font-family:'Syne',sans-serif;font-size:15px;font-weight:700;padding:16px;cursor:pointer;transition:all .15s;display:flex;align-items:center;justify-content:center;gap:8px;margin-top:30px;}
.gen-btn:hover{background:#2d2a26;transform:translateY(-1px);}
.gen-btn:active{transform:translateY(0);}
.gen-btn:disabled{opacity:.4;cursor:not-allowed;transform:none;}

/* ── 結果エリア ── */
.result-wrap{margin-top:0;padding:20px;}
.sg-col-out{display:none;}
.sg-col-out.is-visible{display:block;}
.result-placeholder{padding:48px 20px;text-align:center;color:var(--sg-ink3);font-size:13px;line-height:1.8;}
.result-placeholder .ph-icon{font-size:28px;margin-bottom:10px;opacity:.3;display:block;}
/* ── 再生成ボタン ── */
.rewite_area{
  display:flex;
  align-items: center;
  gap: 20px;
  padding: 10px 20px 0;
}
@media(max-width:640px){.rewite_area{gap: 5px;}}
.regen-top-btn{width: 50%;
  background: var(--sg-card);
  border: 1.5px solid var(--sg-border2);
  border-radius: 10px;
  color: var(--sg-ink2);
  font-family: 'Syne',sans-serif;
  font-size: 14px;
  font-weight: 700;
  padding: 22px; white-space: nowrap;
  cursor: pointer;
  transition: all .15s;
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 8px; height: 60px;
  margin: 0;}
.regen-top-btn:hover{border-color:var(--sg-ink);color:var(--sg-ink);}
.rcard{background:var(--sg-white);padding:20px;}
/* IG：グラデーション枠 */
.rcard.ig{border:2px solid transparent;background-clip:padding-box;position:relative;margin:2px;}
.rcard.ig::before{content:'';position:absolute;inset:0;border-radius:inherit;padding:2px;background:linear-gradient(135deg,#f9ce34,#ee2a7b,#6228d7);-webkit-mask:linear-gradient(#fff 0 0) content-box,linear-gradient(#fff 0 0);-webkit-mask-composite:destination-out;mask-composite:exclude;pointer-events:none;}
/* X：黒枠 */
.rcard.x{border:2px solid #14171a;}
/* TikTok：赤枠 */
.rcard.tt{border:2px solid #e8005a;}
/* YouTube：赤枠 */
.rcard.yt{border:2px solid #cc0000;}
.card-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:14px;}
.plabel{font-family:'Syne',sans-serif;font-size:13px;font-weight:700;letter-spacing:.4px;}
.plabel.ig{background:linear-gradient(135deg,#f9ce34,#ee2a7b,#6228d7);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;}
.plabel.x{color:#14171a;}
.plabel.tt{color:#e8005a;}
.plabel.yt{color:#cc0000;}
.char-count{font-size:11px;color:var(--sg-ink3);}
.result-text{font-size:14px;line-height:1.8;color:var(--sg-ink);margin-bottom:14px;white-space:pre-wrap;word-break:break-word;min-height:80px;}
.tag-block{display:flex;flex-wrap:wrap;gap:8px;margin-bottom:16px;padding:2px 0;}
/* タグもブランドカラー対応 */
.htag{font-size:11px;border-radius:6px;padding:4px 10px;cursor:pointer;transition:background .15s;font-weight:500;display:inline-flex;align-items:center;}
.rcard.ig .htag{background:#fdeef5;border:1px solid #e8a0c4;color:#a0286a;}
.rcard.ig .htag:hover{background:#f9d6ea;}
.rcard.x .htag{background:#eef0f2;border:1px solid #adb5bd;color:#14171a;}
.rcard.x .htag:hover{background:#dde1e5;}
.rcard.tt .htag{background:#fde8f0;border:1px solid #f5a0c0;color:#b3004a;}
.rcard.tt .htag:hover{background:#fbd0e2;}
.rcard.yt .htag{background:#fde8e8;border:1px solid #f5a0a0;color:#aa0000;}
.rcard.yt .htag:hover{background:#fbd0d0;}
.card-actions{display:flex;gap:8px;}
.copy-btn{flex:1;background:var(--sg-bg2);border:1px solid var(--sg-border);border-radius:8px;color:var(--sg-ink2);font-family:'DM Sans',sans-serif;font-size:12px;padding:10px;cursor:pointer;transition:all .15s;}
.copy-btn:hover{border-color:var(--sg-accent);color:var(--sg-accent);}
.copy-btn.copied{border-color:var(--sg-accent);color:var(--sg-accent);background:var(--sg-accent-light);}
.regen-btn{background:transparent;border:1px solid var(--sg-border);border-radius:8px;color:var(--sg-ink3);font-size:16px;padding:10px 14px;cursor:pointer;transition:all .15s;}
.regen-btn:hover{border-color:var(--sg-border2);color:var(--sg-ink);}
.err-text{font-size:13px;color:#9b2c2c;min-height:80px;line-height:1.6;}

/* ── スケルトン ── */
.skel{background:var(--sg-bg3);border-radius:4px;height:13px;margin-bottom:7px;animation:sh 1.4s infinite;}
@keyframes sh{0%,100%{opacity:.5;}50%{opacity:1;}}
.ldots{display:inline-flex;gap:4px;align-items:center;}
.ldots span{width:5px;height:5px;background:#fff;border-radius:50%;animation:bnc .8s infinite;}
.ldots span:nth-child(2){animation-delay:.15s;}.ldots span:nth-child(3){animation-delay:.3s;}
@keyframes bnc{0%,60%,100%{transform:translateY(0);}30%{transform:translateY(-5px);}}

/* ── description ── */
.desc-section:last-child{border-bottom:none;}
.desc-section h2, .desc-section h3{
  font-size: 20px;
  font-weight: bold;
  text-align: left;
  margin: 50px 0 10px;
  border-bottom: 1px solid #777;
  padding: 10px;
  color: var(--accent);}
.desc-section h2 span, .desc-section h3 span{ color: var(--accent); }
.desc-section p{font-size: 13px;
  padding: 10px;
  line-height: 1.8;}

/* ── 英語翻訳 ── */
[data-en]{transition:opacity .15s;}


@media(max-width:640px){
  .sg-wrap{padding:0 0 60px;}
  .sg-page-head{padding:20px 0 12px;}
  .purpose-grid{grid-template-columns:auto;}
  .platform-grid{display:grid !important;grid-template-columns:repeat(2,1fr) !important;}
  .sg-sec-hint{display:none;}
  .sg-out-hint{display:none;}
}

@media(max-width:1200px){
  .platform-grid{grid-template-columns:repeat(4,1fr);}
}

/* ── 入力例（ロード時プリフィル） ── */
#mainInput.is-example{color:var(--sg-ink3);}

/* ── 入力ヒント（textarea 直下） ── */
.sg-input-tip{
  display:block;align-items:center;gap:5px;
  margin:7px 0 0;
  font-size:11.5px;color:var(--sg-ink3);line-height:1.5;
}
.sg-input-tip i{color:var(--sg-accent);font-size:11px;flex-shrink:0;}
.sg-input-tip a{color:var(--sg-accent);text-decoration:underline;text-underline-offset:2px;white-space:nowrap;}
.sg-input-tip a:hover{opacity:.75;}

/* ── 生成完了後ノート ── */
.sg-result-note{
  display:none;opacity:0;
  align-items:center;gap:6px;
  margin:10px 0 4px;
  font-size:11.5px;color:var(--sg-ink3);line-height:1.5;
  transition:opacity .4s;
}
.sg-result-note.is-visible{display: flex;  opacity: 1;  padding: 0 25px;  flex-wrap: wrap;  line-height: 1;}
.sg-result-note i{color:var(--sg-accent);font-size:11px;flex-shrink:0;}
.sg-result-note a{color:var(--sg-accent);text-decoration:underline;text-underline-offset:2px;font-weight:600;}
.sg-result-note a:hover{opacity:.75;}

/* ── 生成ボタン行（生成＋直す横並び） ── */
.gen-row{display:flex;gap:10px;align-items:stretch;margin-top:0;}
.gen-row .gen-btn{flex:1;margin-top:30px;}
.fix-btn{flex:0 0 auto;background:transparent;border:1.5px solid var(--sg-border2);border-radius:10px;color:var(--sg-ink2);font-family:'Syne',sans-serif;font-size:13px;font-weight:700;padding:0 20px;cursor:pointer;transition:all .15s;display:flex;align-items:center;justify-content:center;gap:6px;margin-top:30px;white-space:nowrap;}
.fix-btn:hover{border-color:var(--sg-accent);color:var(--sg-accent);}
.fix-btn:disabled{opacity:.4;cursor:not-allowed;}
.rewite{width: 50%;  height: 60px; padding: 0;  font-size: 14px;  background: var(--sg-card);  margin: 0;}

/* ── 広告ブロック ── */
.sg-ad-block{margin-top:16px;padding-top:16px;border-top:1px solid var(--sg-border);text-align:center;}
.sg-ad-label{font-size:11px;color:var(--sg-ink3);margin-bottom:8px;letter-spacing:.5px;}
.sg-ad-block img{max-width:100%;height:auto;border-radius:4px;}
/* PC用（728x90）: 640px以上で表示 */
.sg-ad-pc{display:block;}
.sg-ad-sp{display:none;}
/* SP用（300x250）: 640px未満で表示 */
@media(max-width:640px){
  .sg-ad-pc{display:none;}
  .sg-ad-sp{display:block;}
}

/* ── 広告PC/SP切り替え ── */
.sg-ad-pc{display:block;}
.sg-ad-sp{display:none;}
@media(max-width:640px){
  .sg-ad-pc{display:none;}
  .sg-ad-sp{display:block;}
}

/* ── インラインスタイルから抽出 ── */
.sg-out-head-left { display: flex; align-items: center; gap: 10px; }

#fitly-share-wrap {
  margin: 20px 0 6px;
  padding: 16px 20px;
  border-top: 1px solid var(--sg-border);
}

.sg-col-out .sg-ad-block { margin: 12px 20px 0; }
.sg-col-out .sg-ad-label { color: #9a9590; }
