/* ============================================================
   QAページ 共有QAデザイン（B案：ダーク×ライム）
   #QA スコープ限定。このページ（index.php?mode=QA）のみ読込。
   移植元: php/www/html/test-results/qa_mockup/qa_b.html <style>
   ============================================================ */

#QA{
  --bg:#f7f8f4;
  --card:#ffffff;
  --ink:#14171a;
  --ink-soft:#5b636b;
  --lime:#84cc16;
  --lime-deep:#65a30d;
  --lime-bg:#eef6dc;
  --lime-bg-soft:#f4f9e8;
  --dark:#0d0f14;
  --border:#e6e8eb;
  --shadow:0 1px 2px rgba(20,23,26,.04), 0 4px 16px rgba(20,23,26,.05);
  --shadow-soft:0 1px 2px rgba(20,23,26,.04);
  --radius:18px;
  --radius-sm:12px;
  --radius-pill:999px;
  background:var(--bg);
  color:var(--ink);
  font-family:"Noto Sans JP", system-ui, sans-serif;
  line-height:1.8;
  -webkit-font-smoothing:antialiased;
}
#QA, #QA *{ box-sizing:border-box; }

#QA .sr-only{
  position:absolute;width:1px;height:1px;padding:0;margin:-1px;
  overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0;
}
#QA a{color:inherit;}
#QA :focus-visible{
  outline:3px solid var(--lime);
  outline-offset:2px;
  border-radius:6px;
}

/* ---------- page title（style_top.css の白 h1 を上書き） ---------- */
#QA h1{
  margin:28px 0 16px;border:none;background:none;padding:0;
  text-align:center;color:var(--ink);font-weight:700;
  font-size:30px;line-height:1.3;
}

/* ---------- layout ---------- */
#QA .qa-wrap{max-width:1080px;margin:0 auto;padding:28px 20px 64px;}

/* PC（>=768px）: .site-header が position:fixed; top:0; height:50px になる
   （top_header.css L820、各ページ CSS でクリアランスを取る規約 L911）。
   モバイルはヘッダーが position:relative で流れるため不要。 */
@media (min-width:768px){
  #QA{ padding-top:50px; }
}

/* ---------- hero feature card ---------- */
#QA .hero{
  background:var(--lime-bg);
  border:1px solid #dcebbf;
  border-radius:24px;
  padding:30px 30px;
  display:flex;gap:26px;align-items:center;
  box-shadow:var(--shadow-soft);
}
#QA .hero__icon{
  flex:0 0 auto;
  width:88px;height:88px;border-radius:22px;
  background:#fff;
  display:flex;align-items:center;justify-content:center;
  border:1px solid #dcebbf;
}
#QA .hero__icon svg{width:50px;height:50px;}
#QA .hero__body{flex:1 1 auto;min-width:0;}
#QA .hero__eyebrow{
  display:inline-flex;align-items:center;gap:7px;
  font-size:12.5px;font-weight:700;color:var(--lime-deep);
  letter-spacing:.04em;margin-bottom:6px;
}
#QA .hero__eyebrow .pip{width:6px;height:6px;border-radius:50%;background:var(--lime);}
#QA .hero__title{
  margin:0 0 6px;border:none;background:none;padding:0;
  font-size:26px;font-weight:700;line-height:1.45;color:var(--ink);
}
/* ヒーロー見出しの改行はモバイルのみ有効（PCは1行） */
#QA .hero__title .br-sp{display:none;}
#QA .hero p{
  margin:0 0 16px;font-size:15px;color:#4f5a3a;line-height:1.75;
}
#QA .chips{display:flex;flex-wrap:wrap;gap:9px;}
#QA .chip{
  display:inline-flex;align-items:center;gap:6px;
  background:#fff;border:1px solid #d4e6ad;
  color:var(--lime-deep);font-weight:500;font-size:13px;
  padding:10px 15px;border-radius:var(--radius-pill);
  text-decoration:none;cursor:pointer;
  transition:transform .12s ease, background .15s ease, border-color .15s ease;
}
#QA .chip:hover{background:var(--lime-deep);border-color:var(--lime-deep);color:#fff;transform:translateY(-1px);}
#QA .chip svg{width:13px;height:13px;}

/* ---------- search ---------- */
#QA .searchwrap{margin:26px 0 8px;position:relative;}
#QA .searchwrap svg.glass{
  position:absolute;left:18px;top:50%;transform:translateY(-50%);
  width:20px;height:20px;color:var(--ink-soft);pointer-events:none;
}
#QA #qa-search{
  width:100%;height:54px;
  border:1px solid var(--border);border-radius:var(--radius-pill);
  background:#fff;
  padding:0 20px 0 48px;
  font-family:inherit;font-size:15.5px;color:var(--ink);
  box-shadow:var(--shadow-soft);
  transition:border-color .15s ease, box-shadow .15s ease;
}
#QA #qa-search::placeholder{color:#9aa1a8;}
#QA #qa-search:focus{
  outline:none;border-color:var(--lime);
  box-shadow:0 0 0 4px rgba(132,204,22,.18);
}
#QA .noresult{
  display:none;
  margin:14px 2px 0;font-size:14.5px;color:var(--ink-soft);
  padding:14px 18px;background:#fff;border:1px dashed var(--border);
  border-radius:var(--radius-sm);
}
#QA .noresult.show{display:block;}

/* ---------- category cards ---------- */
#QA .cats{
  display:grid;grid-template-columns:repeat(4,1fr);gap:14px;
  margin:22px 0 8px;
}
#QA .cat{
  background:var(--card);border:1px solid var(--border);
  border-radius:var(--radius-sm);
  padding:18px 16px;text-align:left;text-decoration:none;
  display:flex;flex-direction:column;gap:10px;cursor:pointer;
  box-shadow:var(--shadow-soft);
  transition:transform .12s ease, box-shadow .15s ease, border-color .15s ease;
}
#QA .cat:hover{transform:translateY(-2px);box-shadow:var(--shadow);border-color:#cfd4d9;}
#QA .cat__ic{
  width:42px;height:42px;border-radius:12px;
  background:var(--bg);display:flex;align-items:center;justify-content:center;
}
#QA .cat__ic svg{width:23px;height:23px;color:var(--ink);}
#QA .cat__t{font-weight:700;font-size:14.5px;color:var(--ink);line-height:1.5;}
#QA .cat__d{font-size:12px;color:var(--ink-soft);line-height:1.55;}
#QA .cat--lime{background:var(--lime-bg-soft);border-color:#d4e6ad;}
#QA .cat--lime .cat__ic{background:#fff;border:1px solid #d4e6ad;}
#QA .cat--lime .cat__ic svg{color:var(--lime-deep);}
#QA .cat--lime .cat__t{color:var(--lime-deep);}

/* ---------- sections ---------- */
#QA .section{
  background:var(--card);border:1px solid var(--border);
  border-radius:var(--radius);
  padding:24px 24px 12px;margin-top:22px;
  box-shadow:var(--shadow-soft);
  scroll-margin-top:80px;
}
#QA .section__head{
  display:flex;align-items:center;gap:12px;
  margin:0 0 6px;padding-bottom:14px;border-bottom:1px solid var(--border);
}
#QA .section__ic{
  width:40px;height:40px;border-radius:12px;flex:0 0 auto;
  background:var(--bg);display:flex;align-items:center;justify-content:center;
}
#QA .section__ic svg{width:22px;height:22px;color:var(--ink);}
#QA .section--star .section__ic{background:var(--lime-bg);}
#QA .section--star .section__ic svg{color:var(--lime-deep);}
#QA .section h2{margin:0;font-size:19px;font-weight:700;color:var(--ink);line-height:1.45;}
#QA .section__sub{margin:1px 0 0;font-size:12.5px;color:var(--ink-soft);font-weight:400;}
#QA .badge-star{
  margin-left:auto;
  display:inline-flex;align-items:center;gap:5px;
  background:var(--lime-bg);color:var(--lime-deep);
  font-size:11.5px;font-weight:700;letter-spacing:.03em;
  padding:5px 11px;border-radius:var(--radius-pill);
}
#QA .badge-star svg{width:12px;height:12px;}

/* ---------- accordion ---------- */
#QA .acc{border-bottom:1px solid var(--border);}
#QA .acc:last-child{border-bottom:none;}
#QA .acc__btn{
  width:100%;background:transparent;border:none;
  font-family:inherit;text-align:left;cursor:pointer;
  display:flex;align-items:center;gap:14px;
  padding:16px 6px;min-height:44px;
  color:var(--ink);font-size:15px;font-weight:500;line-height:1.6;
  border-radius:10px;
  transition:background .15s ease;
}
#QA .acc__btn:hover{background:#fafbf6;}
#QA .acc__q{
  flex:0 0 auto;width:26px;height:26px;border-radius:8px;
  background:var(--lime-bg);color:var(--lime-deep);
  font-weight:700;font-size:13px;
  display:flex;align-items:center;justify-content:center;
  line-height:1;
}
#QA .acc__txt{flex:1 1 auto;}
#QA .acc__chev{
  flex:0 0 auto;width:20px;height:20px;color:var(--ink-soft);
  transition:transform .25s ease;
}
#QA .acc__btn[aria-expanded="true"] .acc__chev{transform:rotate(180deg);}
#QA .acc__panel{
  display:grid;grid-template-rows:0fr;
  transition:grid-template-rows .28s ease;
}
#QA .acc__panel-inner{overflow:hidden;}
#QA .acc__btn[aria-expanded="true"] + .acc__panel{grid-template-rows:1fr;}
#QA .acc__a{
  margin:0 6px 16px 46px;
  padding:14px 16px;
  background:var(--lime-bg-soft);
  border-left:3px solid var(--lime);
  border-radius:0 10px 10px 0;
  color:#3f4733;font-size:14px;line-height:1.85;
}
@media (prefers-reduced-motion: reduce){
  #QA .acc__panel{transition:none;}
  #QA .acc__chev{transition:none;}
  #QA *{transition:none !important; animation:none !important;}
}

/* ---------- service link cards ---------- */
#QA .svc-head{margin:40px 2px 14px;}
#QA .svc-head h2{margin:0 0 2px;font-size:18px;font-weight:700;color:var(--ink);}
#QA .svc-head p{margin:0;font-size:13px;color:var(--ink-soft);}
#QA .svcs{display:grid;grid-template-columns:repeat(auto-fit, minmax(220px, 1fr));gap:16px;}
#QA .svc{
  position:relative;
  background:var(--card);border:1px solid var(--border);
  border-radius:var(--radius);
  padding:22px 22px;text-decoration:none;
  display:flex;flex-direction:column;gap:14px;
  box-shadow:var(--shadow-soft);
  transition:transform .12s ease, box-shadow .15s ease, border-color .15s ease;
}
#QA .svc:hover{transform:translateY(-2px);box-shadow:var(--shadow);border-color:#d4e6ad;}
#QA .svc__ic{
  flex:0 0 auto;width:48px;height:48px;border-radius:14px;
  background:var(--lime-bg);display:flex;align-items:center;justify-content:center;
}
#QA .svc__ic svg{width:26px;height:26px;color:var(--lime-deep);}
#QA .svc__t{font-weight:700;font-size:15.5px;color:var(--ink);margin:0 0 4px;line-height:1.5;}
#QA .svc__d{font-size:13px;color:var(--ink-soft);margin:0 0 12px;line-height:1.7;}
#QA .svc__cta{
  display:inline-flex;align-items:center;gap:5px;
  color:var(--lime-deep);font-weight:700;font-size:13.5px;
}
#QA .svc__cta svg{width:15px;height:15px;}
#QA .svc__note{
  position:absolute;right:14px;bottom:10px;
  font-size:10px;color:#aab0b6;
}

/* ---------- responsive ---------- */
@media (max-width:760px){
  #QA .qa-wrap{padding:20px 14px 48px;}
  #QA .hero{flex-direction:column;align-items:flex-start;gap:18px;padding:24px 20px;}
  #QA .hero__icon{width:64px;height:64px;border-radius:18px;}
  #QA .hero__icon svg{width:38px;height:38px;}
  #QA h1{font-size:22px;margin:16px 0 12px;}
  #QA .hero__title{font-size:21px;}
  #QA .hero__title .br-sp{display:inline;}
  /* モバイル: 横スクロール carousel を廃止し、全カテゴリが一度に見える2列グリッドへ。
     コンパクトな小ボタン（アイコン＋見出しの横並び）にし、説明文はモバイルでは省略。 */
  #QA .cats{
    grid-template-columns:repeat(2,1fr);
    gap:10px;
  }
  #QA .cat{
    flex-direction:row;align-items:center;gap:9px;
    padding:12px 11px;
  }
  #QA .cat__ic{width:32px;height:32px;border-radius:9px;flex:0 0 auto;}
  #QA .cat__ic svg{width:18px;height:18px;}
  #QA .cat__t{font-size:12.5px;line-height:1.3;}
  #QA .cat__d{display:none;}
  #QA .svcs{grid-template-columns:none;}
  #QA .section{padding:20px 16px 8px;}
  #QA .section h2{font-size:17px;}
  #QA .badge-star{display:none;}
  #QA .acc__a{margin-left:8px;}
}
