/* ========================================
   help.css (v1.7.28)
   ヘルプモーダル：左サイドバー型レイアウト
   ======================================== */

/* トリガーボタン（トップバー、サイドバー） */
.help-btn{display:inline-flex;align-items:center;justify-content:center;width:26px;height:26px;border-radius:50%;background:var(--bg3);border:1px solid var(--border);color:var(--text2);font-size:13px;font-weight:700;cursor:pointer;transition:.15s;font-family:inherit}
.help-btn:hover{background:var(--blue);color:#fff;border-color:var(--blue)}

/* サイドバー用ヘルプ項目 */
.sb-item.sb-help{color:var(--text2)}

/* v1.7.30: side-panel 用のスタイル。.side-panel の display:none / .open .side-panel{display:flex} を上書きしないため display は指定しない */
#panel-help{padding:0;flex-direction:column;height:100%}

/* モーダル本体（v1.7.28：横長レイアウト） */
.help-modal-v2{
  background:var(--bg2);
  border:1px solid var(--border);
  border-radius:var(--r2);
  width:100%;
  max-width:1080px;
  height:90vh;
  display:flex;
  flex-direction:column;
  overflow:hidden;
}
/* v1.7.30: パネルモードでは枠なし・全画面 */
.help-modal-v2.help-panel-mode{
  background:transparent;
  border:none;
  border-radius:0;
  max-width:100%;
  height:100%;
  flex:1;
}

/* ヘッダー */
.help-hdr{
  display:flex;align-items:center;justify-content:space-between;
  padding:14px 18px;border-bottom:1px solid var(--border);
  background:var(--bg3);flex-shrink:0;gap:8px;
}
.help-hdr-title{font-size:16px;font-weight:700;color:var(--text);display:flex;align-items:center;gap:8px;flex:1}
.help-mobile-toggle{display:none;background:transparent;border:1px solid var(--border);color:var(--text2);font-size:16px;cursor:pointer;width:32px;height:32px;border-radius:6px}
.help-close{background:transparent;border:none;color:var(--text2);font-size:18px;cursor:pointer;width:32px;height:32px;border-radius:6px}
.help-close:hover{background:var(--bg4);color:var(--text)}

/* 本体 */
.help-body-wrap{flex:1;display:flex;overflow:hidden}

/* ── 左サイドバー（目次）── */
.help-sidebar{
  width:260px;flex-shrink:0;
  border-right:1px solid var(--border);
  background:var(--bg2);
  overflow-y:auto;
  padding:10px 6px 30px;
}
.help-sb-search-wrap{padding:6px 8px 12px}
.help-sb-search{
  width:100%;padding:8px 10px;
  background:var(--bg3);border:1px solid var(--border);border-radius:8px;
  color:var(--text);font-size:12px;font-family:inherit;
}
.help-sb-search:focus{outline:none;border-color:var(--blue)}
.help-sb-cat{
  font-size:11px;font-weight:700;color:var(--text3);
  padding:14px 12px 6px;letter-spacing:.05em;
}
.help-sb-cat-adv{
  border-top:1px dashed var(--border);
  margin-top:14px;padding-top:18px;
}
.help-sb-item{
  font-size:13px;color:var(--text2);
  padding:7px 14px;cursor:pointer;border-radius:6px;
  margin:1px 4px;line-height:1.4;
}
.help-sb-item:hover{background:var(--bg3);color:var(--text)}
.help-sb-item.active{
  background:var(--blue);color:#fff;font-weight:600;
}
.help-sb-item-adv{color:var(--text3)}
.help-sb-item-adv:hover{color:var(--text2)}

/* ── 右コンテンツ（本文）── */
.help-content{
  flex:1;overflow-y:auto;
  padding:24px 32px 60px;
}
.help-sec{display:none}
.help-sec.active{display:block}
.help-sec h2{
  font-size:20px;font-weight:700;color:var(--text);
  margin:0 0 16px;padding-bottom:10px;
  border-bottom:2px solid var(--blue);
}
.help-sec h3{
  font-size:15px;font-weight:700;color:var(--text);
  margin:22px 0 8px;
  display:flex;align-items:center;gap:6px;
}
.help-sec p{
  font-size:14px;color:var(--text2);line-height:1.8;
  margin:0 0 12px;
}
.help-sec p strong{color:var(--text);font-weight:600}
.help-sec ul, .help-sec ol{
  margin:0 0 14px 22px;padding:0;
}
.help-sec li{
  font-size:14px;color:var(--text2);line-height:1.8;
  margin-bottom:5px;
}
.help-sec li strong{color:var(--text);font-weight:600}

/* 手順ボックス */
.help-step{
  background:var(--bg3);
  border-left:3px solid var(--blue);
  border-radius:6px;
  padding:12px 14px 12px 18px;
  margin:10px 0 14px;
}
.help-step ol{margin:0;padding-left:22px}
.help-step li{margin-bottom:4px}

/* ヒント */
.help-tip{
  background:rgba(55,138,221,.10);
  border:1px solid rgba(55,138,221,.35);
  border-radius:8px;
  padding:10px 14px;
  font-size:13px;color:var(--text2);line-height:1.7;
  margin:14px 0;
}

/* 注意 */
.help-warn{
  background:rgba(245,158,11,.12);
  border:1px solid rgba(245,158,11,.4);
  border-radius:8px;
  padding:10px 14px;
  font-size:13px;color:var(--orange);line-height:1.7;
  margin:14px 0;
}

/* WIP */
.help-wip{
  background:rgba(245,158,11,.10);
  border:1px dashed rgba(245,158,11,.4);
  border-radius:6px;
  padding:14px;
  font-size:13px;color:var(--text3);
  text-align:center;
}

/* 用語ボックス */
.help-term{
  background:var(--bg3);
  border:1px solid var(--border);
  border-radius:8px;
  padding:11px 14px;margin-bottom:8px;
}
.help-term-name{
  font-size:13px;font-weight:700;color:var(--blue);
  margin-bottom:4px;
}
.help-term-desc{
  font-size:12px;color:var(--text2);line-height:1.7;
}

/* FAQ */
.help-faq{
  background:var(--bg3);
  border:1px solid var(--border);
  border-radius:8px;
  padding:11px 14px;margin-bottom:8px;
}
.help-faq-q{
  font-size:13px;font-weight:600;color:var(--text);
  margin-bottom:6px;display:flex;gap:8px;align-items:flex-start;
}
.help-faq-q::before{
  content:'Q';color:var(--blue);font-weight:700;
  background:rgba(55,138,221,.15);
  width:20px;height:20px;border-radius:50%;
  display:inline-flex;align-items:center;justify-content:center;
  font-size:11px;flex-shrink:0;
}
.help-faq-a{
  font-size:12px;color:var(--text2);line-height:1.7;
  display:flex;gap:8px;align-items:flex-start;
}
.help-faq-a::before{
  content:'A';color:var(--green);font-weight:700;
  background:rgba(29,185,122,.15);
  width:20px;height:20px;border-radius:50%;
  display:inline-flex;align-items:center;justify-content:center;
  font-size:11px;flex-shrink:0;
}
.help-faq-a strong{color:var(--text);font-weight:600}

/* ========================================
   スマホ対応：サイドバー collapse
   ======================================== */
@media (max-width: 768px) {
  .help-modal-v2{height:100vh;max-height:100vh;border-radius:0;max-width:100%}
  .help-mobile-toggle{display:inline-flex;align-items:center;justify-content:center}
  .help-body-wrap{position:relative}
  .help-sidebar{
    position:absolute;
    top:0;left:0;bottom:0;
    width:80%;max-width:300px;
    z-index:5;
    transform:translateX(-100%);
    transition:transform .25s;
    box-shadow:4px 0 20px rgba(0,0,0,.4);
  }
  body.help-sb-mobile-open .help-sidebar{
    transform:translateX(0);
  }
  body.help-sb-mobile-open .help-content::before{
    content:'';position:absolute;inset:0;background:rgba(0,0,0,.5);z-index:4;
  }
  .help-content{padding:18px 16px 60px}
  .help-sec h2{font-size:17px}
  .help-sec h3{font-size:14px}
}
