@charset "UTF-8";
/*
    Template: swell
    Theme Name: SWELL CHILD
    Theme URI: https://swell-theme.com/
    Description: SWELLの子テーマ
    Version: 1.0.0
    Author: LOOS WEB STUDIO
    Author URI: https://loos-web-studio.com/

    License: GNU General Public License
    License URI: http://www.gnu.org/licenses/gpl.html
*/

/* ============================================================
   ジギョウマート TOP 用 CSS（デモ v3.13 から移植 2026-06-12 法正）
   設置: SWELL CHILD の style.css 末尾に貼り付け
   ※ Google Fonts は functions.php で enqueue（@import 不使用）
   ============================================================ */

    /* ============================================================
       ジギョウマート ヘッダー v3.12（モダン版）+ フッター v1
       - モダンフォント（Inter / Noto Sans JP）
       - ロゴ：ネイビー文字（#1B3A6B）背景透明
       - 主 CTA：UNIQLO レッド（#E60012）背景白文字
       - SP レイアウト：上段 ロゴ｜クイックナビ縦並び / 下段 検索｜ハンバーガー / タグライン
       - SP 主 CTA はハンバーガーメニュー内に格納
       - HTML 構造と class 名は v3.11 と同一（JS の動作互換のため）
       ============================================================ */

    :root {
      --uq-red: #E60012;
      --uq-red-hover: #B8000F;
      --uq-black: #000000;
      --uq-text: #1A1A1A;
      --uq-sub: #666666;
      --uq-line: #E5E5E5;
      --uq-line-strong: #BFBFBF;
      --uq-bg-soft: #F5F5F5;
      --uq-bg-darker: #EFEFEF;
      --uq-white: #FFFFFF;
      --jm-navy: #1B3A6B;
      --jm-navy-deep: #0F2A4F;
    }

    *, *::before, *::after { box-sizing: border-box; }

    html, body {
      margin: 0;
      padding: 0;
      width: 100%;
      max-width: 100%;
      font-family: "Inter", "Noto Sans JP", "Helvetica Neue", Helvetica, Arial, "Yu Gothic", "游ゴシック", sans-serif;
      background: var(--uq-bg-soft);
      color: var(--uq-text);
      -webkit-font-smoothing: antialiased;
      -moz-osx-font-smoothing: grayscale;
    }
    /* 注意：祖先に overflow:hidden を置くと position:sticky が効かなくなるため使用しない */

    a { color: inherit; text-decoration: none; }
    a:hover { color: var(--uq-red); }
    button { font-family: inherit; cursor: pointer; }
    ul { list-style: none; margin: 0; padding: 0; }

    /* ============ HEADER（フローティング・固定追従） ============ */
    .jm-header {
      position: fixed;
      top: 16px;
      left: 50%;
      transform: translateX(-50%);
      z-index: 100;
      width: calc(100% - 32px);
      max-width: 1400px;
      background: rgba(255, 255, 255, 0.78);
      -webkit-backdrop-filter: saturate(180%) blur(20px);
      backdrop-filter: saturate(180%) blur(20px);
      border: 1px solid rgba(15, 42, 79, 0.10);
      border-radius: 8px;
      box-shadow: 0 18px 44px rgba(15, 42, 79, 0.20), 0 6px 14px rgba(15, 42, 79, 0.10), 0 1px 3px rgba(15, 42, 79, 0.06);
    }
    /* ヘッダー固定の分、本文を下にずらす（v3.13 PC 縮小版：従来の 2/3 程度） */
    .demo-main { padding-top: 130px; }

    .jm-header__row1 { background: transparent; }
    .jm-header__row1-inner {
      max-width: 1440px;
      margin: 0 auto;
      padding: 9px 24px;
      display: flex;
      align-items: center;
      gap: 20px;
    }

    /* ロゴ：ネイビー文字（背景透明） */
    .jm-logo {
      display: inline-flex;
      flex-direction: column;
      justify-content: center;
      background: transparent;
      color: var(--jm-navy);
      padding: 4px 0;
      min-width: 0;
      flex-shrink: 0;
      transition: opacity 150ms ease;
    }
    .jm-logo:hover { opacity: 0.7; color: var(--jm-navy); }
    .jm-logo__main {
      font-size: 18px;
      font-weight: 900;
      letter-spacing: 0.06em;
      line-height: 1.1;
      color: var(--jm-navy);
    }
    .jm-logo__sub {
      font-size: 11px;
      font-weight: 500;
      letter-spacing: 0.04em;
      margin-top: 3px;
      color: var(--uq-sub);
    }

    /* SP 用クイックナビは PC では非表示 */
    .jm-mobile-quick { display: none; }

    /* 検索：UNIQLO 風シンプル細罫線 */
    .jm-search-area { flex: 1; min-width: 0; }
    .jm-search {
      display: flex;
      align-items: center;
      background: var(--uq-bg-soft);
      border: 1px solid transparent;
      transition: border-color 150ms ease, background 150ms ease;
    }
    .jm-search:focus-within {
      background: var(--uq-white);
      border-color: var(--uq-black);
    }
    .jm-search__label {
      position: absolute;
      width: 1px; height: 1px;
      overflow: hidden; clip: rect(0 0 0 0);
    }
    .jm-search__input {
      flex: 1;
      border: none;
      background: transparent;
      padding: 8px 14px;
      font-size: 13px;
      color: var(--uq-text);
      outline: none;
    }
    .jm-search__input::placeholder { color: var(--uq-sub); }
    .jm-search__submit {
      background: transparent;
      border: none;
      padding: 6px 12px;
      color: var(--uq-text);
      display: inline-flex;
      align-items: center;
      justify-content: center;
    }
    .jm-search__submit:hover { color: var(--uq-red); }

    /* ハンバーガー（PC では非表示） */
    .jm-hamburger { display: none; }

    /* タグライン：PC では下段、SP は別表示 */
    .jm-tagline { display: none; }

    /* CTA：UNIQLO 風の角張ったボタン */
    .jm-cta--header {
      display: inline-flex;
      align-items: center;
      justify-content: center;
      flex-shrink: 0;
      padding: 8px 16px;
      font-size: 13px;
      font-weight: 700;
      letter-spacing: 0.06em;
      line-height: 1.3;
      text-align: center;
      transition: background 150ms ease, color 150ms ease, border-color 150ms ease;
      border-radius: 0;
    }
    .jm-cta--header.jm-cta--shine {
      background: var(--uq-red);
      color: var(--uq-white);
      border: 1px solid var(--uq-red);
    }
    .jm-cta--header.jm-cta--shine:hover {
      background: var(--uq-red-hover);
      color: var(--uq-white);
      border-color: var(--uq-red-hover);
    }
    .jm-cta--header-secondary {
      background: var(--uq-white);
      color: var(--uq-black);
      border: 1px solid var(--uq-black);
    }
    .jm-cta--header-secondary:hover {
      background: var(--uq-black);
      color: var(--uq-white);
    }
    .jm-cta--header-secondary .jm-cta__line {
      display: block;
      font-size: 11px;
      letter-spacing: 0.04em;
    }

    /* ============ NAV（カテゴリナビ） ============ */
    .jm-nav {
      background: var(--uq-white);
      border-top: 1px solid var(--uq-line);
    }
    .jm-nav__inner {
      max-width: 1440px;
      margin: 0 auto;
      padding: 0 24px;
      display: flex;
      align-items: center;
      justify-content: space-between;
      gap: 24px;
    }
    .jm-nav__list {
      display: flex;
      align-items: stretch;
      gap: 12px;
    }
    .jm-nav__item {
      position: relative;
    }
    .jm-nav__link, .jm-nav__toggle {
      display: inline-flex;
      align-items: center;
      gap: 6px;
      padding: 12px 14px;
      background: transparent;
      border: none;
      font-size: 14px;
      font-weight: 700;
      line-height: 1.3;
      letter-spacing: 0.06em;
      color: var(--uq-black);
      position: relative;
      white-space: nowrap;
    }
    .jm-nav__link::after, .jm-nav__toggle::after {
      content: "";
      position: absolute;
      left: 14px;
      right: 14px;
      bottom: 0;
      height: 2px;
      background: var(--uq-red);
      transform: scaleX(0);
      transform-origin: left center;
      transition: transform 200ms ease;
    }
    .jm-nav__link:hover, .jm-nav__toggle:hover { color: var(--uq-red); }
    .jm-nav__link:hover::after, .jm-nav__toggle:hover::after,
    .jm-nav__toggle[aria-expanded="true"]::after { transform: scaleX(1); }
    .jm-nav__chevron { transition: transform 200ms ease; }
    .jm-nav__toggle[aria-expanded="true"] .jm-nav__chevron { transform: rotate(180deg); }

    /* ドロップダウン */
    .jm-nav__dropdown {
      position: absolute;
      top: 100%;
      left: 0;
      min-width: 240px;
      background: var(--uq-white);
      border: 1px solid var(--uq-line);
      border-top: 2px solid var(--uq-red);
      box-shadow: 0 8px 24px rgba(0, 0, 0, 0.06);
      opacity: 0;
      visibility: hidden;
      transform: translateY(-4px);
      transition: opacity 180ms ease, transform 180ms ease, visibility 180ms;
      z-index: 50;
    }
    .jm-nav__toggle[aria-expanded="true"] + .jm-nav__dropdown {
      opacity: 1;
      visibility: visible;
      transform: translateY(0);
    }
    .jm-nav__dropdown li a {
      display: flex;
      align-items: center;
      gap: 12px;
      padding: 14px 18px;
      font-size: 15px;
      font-weight: 600;
      letter-spacing: 0.06em;
      color: var(--uq-text);
      border-bottom: 1px solid var(--uq-line);
    }
    .jm-nav__dropdown li:last-child a { border-bottom: none; }
    .jm-nav__dropdown li a:hover {
      background: var(--uq-bg-soft);
      color: var(--uq-red);
    }

    /* PC：「業種で探す」の 16 項目を 2 列表示 */
    .jm-nav__dropdown--two-col {
      display: grid;
      grid-template-columns: 1fr 1fr;
      min-width: 380px;
    }
    .jm-nav__dropdown--two-col li:nth-child(odd) a {
      border-right: 1px solid var(--uq-line);
    }
    .jm-nav__dropdown--two-col li:nth-last-child(-n+2) a {
      border-bottom: none;
    }

    /* PC：サブメニュー（経営基盤の中の 7 項目）
       sub-item を static にして、sub-dropdown の絶対配置基準を親 .jm-nav__dropdown に揃える
       → どの項目をホバーしても、サブメニューは経営基盤と同じ高さ（dropdown の最上端）から開く */
    .jm-nav__sub-item {
      position: static;
      border-bottom: 1px solid var(--uq-line);
    }
    .jm-nav__sub-item:last-child { border-bottom: none; }
    .jm-nav__sub-toggle {
      display: flex;
      align-items: center;
      gap: 12px;
      width: 100%;
      padding: 14px 18px;
      background: transparent;
      border: none;
      font-size: 15px;
      font-weight: 600;
      letter-spacing: 0.06em;
      color: var(--uq-text);
      cursor: pointer;
      text-align: left;
      font-family: inherit;
      transition: background 150ms ease, color 150ms ease;
    }
    .jm-nav__sub-toggle:hover,
    .jm-nav__sub-item:hover .jm-nav__sub-toggle {
      background: var(--uq-bg-soft);
      color: var(--uq-red);
    }
    .jm-nav__sub-toggle:hover .jm-icon-color,
    .jm-nav__sub-item:hover .jm-icon-color { color: var(--uq-red); }
    .jm-nav__sub-label { flex: 1; }
    .jm-nav__sub-arrow { transition: transform 200ms ease; flex-shrink: 0; }
    .jm-nav__sub-item:hover .jm-nav__sub-arrow,
    .jm-nav__sub-toggle[aria-expanded="true"] .jm-nav__sub-arrow {
      transform: translateX(2px);
    }
    .jm-nav__sub-dropdown {
      position: absolute;
      top: -2px;       /* 親 dropdown の border-top 2px と揃える */
      left: 100%;
      min-width: 260px; /* 240 → 260px */
      background: var(--uq-white);
      border: 1px solid var(--uq-line);
      border-top: 2px solid var(--uq-red);
      box-shadow: 0 8px 24px rgba(0, 0, 0, 0.06);
      opacity: 0;
      visibility: hidden;
      transform: translateX(-4px);
      transition: opacity 180ms ease, transform 180ms ease, visibility 180ms;
      z-index: 60;
      list-style: none;
      margin: 0;
      padding: 0;
    }
    .jm-nav__sub-item:hover .jm-nav__sub-dropdown,
    .jm-nav__sub-toggle[aria-expanded="true"] + .jm-nav__sub-dropdown {
      opacity: 1;
      visibility: visible;
      transform: translateX(0);
    }
    .jm-nav__sub-dropdown li a {
      display: block;
      padding: 12px 18px;
      font-size: 15px;
      font-weight: 500;
      color: var(--uq-text);
      border-bottom: 1px solid var(--uq-line);
      transition: background 150ms ease, color 150ms ease;
    }
    .jm-nav__sub-dropdown li:last-child a { border-bottom: none; }
    .jm-nav__sub-dropdown li a:hover {
      background: var(--uq-bg-soft);
      color: var(--uq-red);
    }

    /* アイコンの色は UNIQLO 風に黒で統一 */
    .jm-icon-color {
      display: inline-flex;
      align-items: center;
      justify-content: center;
      width: 22px;
      height: 22px;
      color: var(--uq-black);
    }
    .jm-nav__dropdown li a:hover .jm-icon-color { color: var(--uq-red); }

    /* タグライン（旧：カウントバッジ） — PC ナビ右端 */
    .jm-nav__count-badge {
      display: inline-flex;
      align-items: center;
      gap: 10px;
      padding: 4px 14px;
      background: transparent;
      color: var(--jm-navy);
      font-size: 13px;
      font-weight: 700;
      letter-spacing: 0.14em;
      border-left: 1px solid var(--uq-line-strong);
      white-space: nowrap;
    }

    /* row3：PC のみ下段タグライン */
    .jm-header__row3 {
      background: var(--uq-bg-soft);
      border-top: 1px solid var(--uq-line);
    }
    .jm-tagline--pc-bottom {
      display: flex;
      align-items: center;
      justify-content: center;
      gap: 16px;
      max-width: 1440px;
      margin: 0 auto;
      padding: 8px 24px;
      font-size: 14px;
      font-weight: 600;
      letter-spacing: 0.18em;
      color: var(--uq-text);
    }
    .jm-tagline__rule {
      flex: 0 0 32px;
      height: 1px;
      background: var(--uq-line-strong);
    }

    /* モバイルメニュー（PC では非表示） */
    .jm-mobile-menu, .jm-mobile-menu__overlay { display: none; }

    /* ============ MAIN（UNIQLO 風プロダクトグリッド） ============ */
    .demo-main { background: var(--uq-white); }

    .demo-info-bar {
      max-width: 1440px;
      margin: 16px auto 0;
      padding: 10px 24px;
      background: var(--uq-black);
      color: var(--uq-white);
      font-size: 14px;
      letter-spacing: 0.06em;
      text-align: center;
    }

    .demo-section {
      max-width: 1440px;
      margin: 0 auto;
      padding: 32px 24px;
    }

    /* HERO：背景画像 + 暗オーバーレイ + 赤の左ライン（PC で高さ 1.5 倍） */
    .demo-hero {
      color: var(--uq-white);
      padding: 100px 24px;
      min-height: 480px;
      display: flex;
      flex-direction: column;
      align-items: center;
      justify-content: center;
      text-align: center;
      margin-bottom: 0;
      position: relative;
      overflow: hidden;
    }
    .demo-hero > * {
      position: relative;
      z-index: 1;
    }
    .demo-hero__supertitle {
      margin: 0 0 16px;
      font-size: 15px;
      font-weight: 600;
      letter-spacing: 0.16em;
      color: rgba(255, 255, 255, 0.78);
      position: relative;
      display: inline-block;
      padding: 0 18px;
    }
    .demo-hero__supertitle::before,
    .demo-hero__supertitle::after {
      content: "";
      position: absolute;
      top: 50%;
      width: 12px;
      height: 1px;
      background: rgba(255, 255, 255, 0.5);
    }
    .demo-hero__supertitle::before { left: 0; }
    .demo-hero__supertitle::after { right: 0; }
    .demo-hero__title {
      margin: 0 0 14px;
      font-size: 34px;
      font-weight: 900;
      letter-spacing: 0.04em;
      line-height: 1.3;
    }
    .demo-hero__title-line { display: inline; }
    .demo-hero__sub {
      margin: 0;
      font-size: 16px;
      letter-spacing: 0.1em;
      opacity: 0.8;
    }
    /* ジギョウマートの定義文（LLMO 引用最適化、AI Overview 用）— ヒーロー最下部に配置 */
    .demo-hero__define {
      margin: auto auto 0;       /* margin-top: auto で flex 親の最下部へ押し下げ */
      max-width: 720px;
      padding: 12px 18px;
      font-size: 15px;
      letter-spacing: 0.04em;
      line-height: 1.6;
      color: rgba(255, 255, 255, 0.92);
      background: rgba(255, 255, 255, 0.08);
      border-left: 2px solid var(--uq-red);
    }
    @media (max-width: 768px) {
      .demo-hero__define { font-size: 13px; padding: 10px 14px; }
    }

    .demo-section__title {
      margin: 0 0 8px;
      padding: 0;
      border: none;
      font-size: 24px;
      font-weight: 900;
      letter-spacing: 0.06em;
      color: var(--uq-black);
    }
    .demo-section__title::before {
      content: "";
      display: inline-block;
      width: 4px;
      height: 22px;
      background: var(--uq-red);
      margin-right: 10px;
      vertical-align: -4px;
    }
    .demo-section__lead {
      margin: 0 0 24px;
      color: var(--uq-sub);
      font-size: 15px;
      letter-spacing: 0.04em;
    }

    /* デモカードグリッド：横スクロールスライダー（PC: 5 枚表示、SP: 1 枚表示） */
    .demo-grid {
      display: flex;
      overflow-x: auto;
      overflow-y: visible;
      scroll-snap-type: x mandatory;
      gap: 12px;
      padding-bottom: 4px;
      scrollbar-width: none;
      -ms-overflow-style: none;
    }
    .demo-grid::-webkit-scrollbar { display: none; }
    .demo-grid > .demo-card {
      flex: 0 0 calc((100% - 48px) / 5); /* 5 枚並び、gap 12px × 4 = 48px を引く */
      scroll-snap-align: start;
      min-width: 0;
    }

    /* UNIQLO 風プロダクトカード：白背景＋細罫線、ホバーで赤ライン */
    .demo-card {
      background: var(--uq-white);
      border: 1px solid var(--uq-line);
      border-radius: 0;
      padding: 18px 18px 16px;
      box-shadow: none;
      transition: border-color 150ms ease;
      position: relative;
      overflow: hidden;
    }
    /* カード上部のダミー画像（カテゴリ別カラー + 装飾） */
    .demo-card__image {
      height: 130px;
      margin: -18px -18px 14px;
      background: linear-gradient(135deg, var(--jm-navy), #4a6fa5);
      position: relative;
      overflow: hidden;
    }
    .demo-card__image::before {
      content: "";
      position: absolute;
      inset: 0;
      background:
        radial-gradient(circle at 80% 30%, rgba(255,255,255,0.15), transparent 50%),
        radial-gradient(circle at 20% 80%, rgba(0,0,0,0.15), transparent 50%);
    }
    .demo-card__image::after {
      content: attr(data-label);
      position: absolute;
      bottom: 12px;
      left: 14px;
      color: rgba(255, 255, 255, 0.85);
      font-size: 12px;
      font-weight: 700;
      letter-spacing: 0.16em;
    }
    /* ダミー画像（Lorem Picsum）— 本番では実画像に差し替え */
    .demo-card__image[data-cat="ec"]         { background: url('https://picsum.photos/seed/jm-ec/640/360') center/cover #1B3A6B; }
    .demo-card__image[data-cat="hr"]         { background: url('https://picsum.photos/seed/jm-hr/640/360') center/cover #B85C00; }
    .demo-card__image[data-cat="finance"]    { background: url('https://picsum.photos/seed/jm-finance/640/360') center/cover #2E7D32; }
    .demo-card__image[data-cat="ai"]         { background: url('https://picsum.photos/seed/jm-ai/640/360') center/cover #5E35B1; }
    .demo-card__image[data-cat="succession"] { background: url('https://picsum.photos/seed/jm-succession/640/360') center/cover #C62828; }
    .demo-card__image[data-cat="planning"]   { background: url('https://picsum.photos/seed/jm-planning/640/360') center/cover #00838F; }
    .demo-card__image[data-cat="marketing"]  { background: url('https://picsum.photos/seed/jm-marketing/640/360') center/cover #D81B60; }
    .demo-card:hover {
      transform: none;
      box-shadow: none;
      border-color: var(--uq-black);
    }
    .demo-card::after {
      content: "";
      position: absolute;
      left: -1px; right: -1px; bottom: -1px;
      height: 3px;
      background: var(--uq-red);
      transform: scaleX(0);
      transform-origin: left center;
      transition: transform 200ms ease;
    }
    .demo-card:hover::after { transform: scaleX(1); }

    .demo-card__cat {
      display: inline-block;
      padding: 3px 8px;
      background: var(--uq-black);
      color: var(--uq-white);
      font-size: 12px;
      font-weight: 700;
      letter-spacing: 0.1em;
      border-radius: 0;
      margin-bottom: 10px;
    }
    .demo-card__title {
      margin: 0 0 8px;
      font-size: 17px;
      font-weight: 700;
      color: var(--uq-black);
      letter-spacing: 0.02em;
      line-height: 1.45;
    }
    .demo-card__desc {
      margin: 0 0 12px;
      font-size: 14px;
      color: var(--uq-sub);
      line-height: 1.6;
    }
    .demo-card__meta {
      display: flex;
      justify-content: space-between;
      align-items: baseline;
      font-size: 13px;
      color: var(--uq-sub);
      padding-top: 10px;
      border-top: 1px solid var(--uq-line);
      letter-spacing: 0.04em;
    }
    .demo-card__price {
      color: var(--uq-red);
      font-weight: 900;
      font-size: 16px;
    }

    /* スライダー UI ベース（PC では左右ナビ表示、ドット/ヒントは SP のみ表示） */
    .demo-slider-dots, .demo-slider-hint { display: none; }
    .demo-slider-wrap { position: relative; }
    .demo-slider-nav {
      display: flex;
      align-items: center;
      justify-content: center;
      position: absolute;
      top: 50%;
      transform: translateY(-50%);
      width: 44px;
      height: 44px;
      background: rgba(255, 255, 255, 0.96);
      border: 1px solid var(--uq-line-strong);
      border-radius: 50%;
      color: var(--jm-navy);
      cursor: pointer;
      z-index: 10;
      box-shadow: 0 4px 14px rgba(15, 42, 79, 0.20);
      transition: background 150ms ease, color 150ms ease, transform 150ms ease;
      padding: 0;
    }
    .demo-slider-nav:hover {
      background: var(--jm-navy);
      color: var(--uq-white);
      transform: translateY(-50%) scale(1.08);
    }
    .demo-slider-nav--prev { left: -22px; }
    .demo-slider-nav--next { right: -22px; }

    /* ============ SHOP BY INDUSTRY（業種から探す） PC: 6 列 × 3 行 = 16 業種（最後 2 マス空き） */
    .category-grid {
      display: grid;
      grid-template-columns: repeat(6, 1fr);
      gap: 10px;
    }
    .category-card {
      display: flex;
      flex-direction: column;
      background: var(--uq-white);
      text-decoration: none;
      color: var(--uq-text);
      border: 1px solid var(--uq-line);
      transition: border-color 150ms ease, transform 200ms ease;
      position: relative;
    }
    .category-card:hover {
      border-color: var(--uq-black);
      transform: translateY(-2px);
    }
    .category-card::after {
      content: "";
      position: absolute;
      left: -1px; right: -1px; bottom: -1px;
      height: 3px;
      background: var(--uq-red);
      transform: scaleX(0);
      transform-origin: left center;
      transition: transform 200ms ease;
    }
    .category-card:hover::after { transform: scaleX(1); }
    .category-card__image {
      aspect-ratio: 1 / 1;
      display: flex;
      align-items: center;
      justify-content: center;
      background: linear-gradient(135deg, var(--jm-navy), #4a6fa5);
      position: relative;
      overflow: hidden;
    }
    .category-card__image::before {
      content: "";
      position: absolute;
      inset: 0;
      background:
        radial-gradient(circle at 80% 20%, rgba(255,255,255,0.18), transparent 55%),
        radial-gradient(circle at 20% 90%, rgba(0,0,0,0.18), transparent 55%);
    }
    .category-card__icon {
      font-size: 48px;
      filter: drop-shadow(0 2px 4px rgba(0,0,0,0.3));
      position: relative;
      z-index: 1;
    }
    .category-card__label {
      padding: 14px 8px;
      font-size: 15px;
      font-weight: 700;
      letter-spacing: 0.04em;
      text-align: center;
      color: var(--jm-navy);
      transition: color 150ms ease;
    }
    .category-card:hover .category-card__label { color: var(--uq-red); }

    /* 16 業種：Lorem Picsum ダミー画像 — 本番では実画像に差し替え */
    .category-card__image[data-color="1"]  { background: url('https://picsum.photos/seed/jm-mfg/400/400') center/cover #1B3A6B; }       /* 製造業 */
    .category-card__image[data-color="2"]  { background: url('https://picsum.photos/seed/jm-retail/400/400') center/cover #C62828; }    /* 小売・卸 */
    .category-card__image[data-color="3"]  { background: url('https://picsum.photos/seed/jm-info/400/400') center/cover #00838F; }      /* 情報通信業 */
    .category-card__image[data-color="4"]  { background: url('https://picsum.photos/seed/jm-food/400/400') center/cover #B85C00; }      /* 飲食店 */
    .category-card__image[data-color="5"]  { background: url('https://picsum.photos/seed/jm-hotel/400/400') center/cover #5E35B1; }     /* 宿泊業 */
    .category-card__image[data-color="6"]  { background: url('https://picsum.photos/seed/jm-life/400/400') center/cover #D81B60; }      /* 生活サービス */
    .category-card__image[data-color="7"]  { background: url('https://picsum.photos/seed/jm-construct/400/400') center/cover #455A64; } /* 建設業 */
    .category-card__image[data-color="8"]  { background: url('https://picsum.photos/seed/jm-transport/400/400') center/cover #6A4F2A; } /* 運送業 */
    .category-card__image[data-color="9"]  { background: url('https://picsum.photos/seed/jm-medical/400/400') center/cover #2E7D32; }   /* 医療 */
    .category-card__image[data-color="10"] { background: url('https://picsum.photos/seed/jm-care/400/400') center/cover #00695C; }      /* 介護・福祉 */
    .category-card__image[data-color="11"] { background: url('https://picsum.photos/seed/jm-lawyer/400/400') center/cover #4527A0; }    /* 士業 */
    .category-card__image[data-color="12"] { background: url('https://picsum.photos/seed/jm-research/400/400') center/cover #1565C0; }  /* 学術・研究 */
    .category-card__image[data-color="13"] { background: url('https://picsum.photos/seed/jm-bank/400/400') center/cover #2E5BBA; }      /* 金融・保険 */
    .category-card__image[data-color="14"] { background: url('https://picsum.photos/seed/jm-realestate/400/400') center/cover #BF360C; }/* 不動産業 */
    .category-card__image[data-color="15"] { background: url('https://picsum.photos/seed/jm-agri/400/400') center/cover #558B2F; }      /* 農林水産業 */
    .category-card__image[data-color="16"] { background: url('https://picsum.photos/seed/jm-other/400/400') center/cover #424242; }     /* その他 */

    /* ============ SHOP BY ISSUE（課題から探す） ============ */
    .issue-grid {
      display: grid;
      grid-template-columns: repeat(5, 1fr);
      gap: 8px;
    }
    .issue-card {
      display: flex;
      flex-direction: column;
      background: var(--uq-white);
      text-decoration: none;
      color: var(--uq-text);
      border: 1px solid var(--uq-line);
      padding: 24px 18px 20px;
      transition: border-color 150ms ease, transform 200ms ease;
      position: relative;
      min-height: 280px;
    }
    .issue-card:hover {
      border-color: var(--uq-black);
      transform: translateY(-2px);
    }
    .issue-card::after {
      content: "";
      position: absolute;
      left: -1px; right: -1px; bottom: -1px;
      height: 3px;
      background: var(--uq-red);
      transform: scaleX(0);
      transform-origin: left center;
      transition: transform 200ms ease;
    }
    .issue-card:hover::after { transform: scaleX(1); }
    .issue-card__head {
      display: flex;
      justify-content: space-between;
      align-items: baseline;
      margin-bottom: 12px;
    }
    .issue-card__num {
      font-size: 24px;
      font-weight: 900;
      letter-spacing: 0.02em;
      color: var(--jm-navy);
      font-family: "Inter", "Helvetica Neue", sans-serif;
    }
    .issue-card__count {
      font-size: 12px;
      font-weight: 700;
      letter-spacing: 0.08em;
      color: var(--uq-white);
      background: var(--uq-red);
      padding: 3px 8px;
    }
    .issue-card__title {
      margin: 0 0 14px;
      font-size: 18px;
      font-weight: 900;
      letter-spacing: 0.04em;
      color: var(--uq-black);
      padding-bottom: 10px;
      border-bottom: 2px solid var(--uq-black);
    }
    .issue-card__items {
      list-style: none;
      margin: 0 0 14px;
      padding: 0;
      flex: 1;
    }
    .issue-card__items li {
      display: flex;
      align-items: center;
      gap: 8px;
      font-size: 13px;
      letter-spacing: 0.04em;
      color: var(--uq-text);
      padding: 4px 0 4px 12px;
      position: relative;
      line-height: 1.5;
    }
    .issue-card__items li::before {
      content: "";
      position: absolute;
      left: 0;
      top: 50%;
      width: 6px;
      height: 1px;
      background: var(--jm-navy);
    }
    .issue-card__items li::after {
      content: "→";
      margin-left: auto;
      font-size: 14px;
      font-weight: 700;
      color: var(--uq-red);
      opacity: 0.55;
      flex-shrink: 0;
      transition: transform 200ms ease, opacity 200ms ease;
    }
    .issue-card:hover .issue-card__items li::after {
      opacity: 1;
    }
    .issue-card__items li:hover::after {
      transform: translateX(3px);
    }
    .issue-card__more {
      font-size: 13px;
      font-weight: 700;
      letter-spacing: 0.06em;
      color: var(--uq-red);
      transition: color 150ms ease;
    }
    .issue-card:hover .issue-card__more { color: var(--uq-black); }

    /* ============ FAQ ============ */
    .faq-list {
      display: flex;
      flex-direction: column;
      gap: 1px;
      background: var(--uq-line);
      border: 1px solid var(--uq-line);
    }
    .faq-item { background: var(--uq-white); }
    .faq-item__q {
      display: block;
      padding: 18px 56px 18px 56px;
      font-size: 16px;
      font-weight: 700;
      letter-spacing: 0.04em;
      color: var(--uq-black);
      cursor: pointer;
      position: relative;
      list-style: none;
      transition: background 150ms ease;
    }
    .faq-item__q::-webkit-details-marker { display: none; }
    .faq-item__q:hover { background: var(--uq-bg-soft); }
    .faq-item__q::before {
      content: "Q";
      position: absolute;
      left: 18px;
      top: 50%;
      transform: translateY(-50%);
      width: 26px;
      height: 26px;
      background: var(--uq-red);
      color: var(--uq-white);
      font-size: 14px;
      font-weight: 900;
      text-align: center;
      line-height: 26px;
      letter-spacing: 0;
    }
    .faq-item__q::after {
      content: "+";
      position: absolute;
      right: 24px;
      top: 50%;
      transform: translateY(-50%);
      font-size: 24px;
      font-weight: 300;
      color: var(--jm-navy);
      transition: transform 200ms ease;
    }
    .faq-item[open] .faq-item__q::after {
      content: "−";
    }
    .faq-item[open] .faq-item__q { background: var(--uq-bg-soft); }
    .faq-item__a {
      padding: 18px 24px 22px 56px;
      font-size: 15px;
      line-height: 1.8;
      letter-spacing: 0.04em;
      color: var(--uq-text);
      background: var(--uq-bg-soft);
      border-top: 1px solid var(--uq-line);
    }
    .faq-item__a::before {
      content: "A";
      display: inline-block;
      width: 26px;
      height: 26px;
      background: var(--jm-navy);
      color: var(--uq-white);
      font-size: 14px;
      font-weight: 900;
      text-align: center;
      line-height: 26px;
      margin-right: 12px;
      margin-left: -38px;
      vertical-align: 2px;
    }
    @media (max-width: 768px) {
      .faq-item__q { padding: 14px 44px 14px 50px; font-size: 15px; }
      .faq-item__q::before { left: 14px; width: 24px; height: 24px; line-height: 24px; }
      .faq-item__q::after { right: 16px; font-size: 22px; }
      .faq-item__a { padding: 14px 18px 18px 50px; font-size: 14px; }
      .faq-item__a::before { width: 24px; height: 24px; line-height: 24px; margin-left: -36px; margin-right: 10px; }
    }

    /* ============ FOOTER（UNIQLO 風シンプル） ============ */
    .jm-footer {
      background: var(--uq-white);
      color: var(--uq-text);
      border-top: 1px solid var(--uq-line);
      margin-top: 48px;
    }
    .jm-footer__sr-heading {
      position: absolute;
      width: 1px; height: 1px;
      overflow: hidden; clip: rect(0 0 0 0);
    }

    /* CTA バナー：黒帯＋赤ボタン */
    .jm-footer__cta-banner {
      background: var(--uq-black);
      color: var(--uq-white);
    }
    .jm-footer__cta-inner {
      max-width: 1440px;
      margin: 0 auto;
      padding: 36px 24px;
      display: flex;
      align-items: center;
      justify-content: space-between;
      gap: 24px;
      flex-wrap: wrap;
    }
    .jm-footer__cta-text-wrap { flex: 1; min-width: 240px; }
    .jm-footer__cta-lead {
      margin: 0 0 6px;
      font-size: 24px;
      font-weight: 900;
      letter-spacing: 0.08em;
    }
    .jm-footer__cta-sub {
      margin: 0;
      font-size: 15px;
      letter-spacing: 0.06em;
      opacity: 0.85;
    }
    .jm-footer__cta-button {
      display: inline-flex;
      align-items: center;
      gap: 12px;
      padding: 16px 28px;
      background: var(--uq-red);
      color: var(--uq-white);
      font-size: 16px;
      font-weight: 900;
      letter-spacing: 0.1em;
      border-radius: 0;
      transition: background 150ms ease;
      flex-shrink: 0;
    }
    .jm-footer__cta-button:hover {
      background: var(--uq-white);
      color: var(--uq-black);
    }
    .jm-footer__cta-button-icon { transition: transform 150ms ease; }
    .jm-footer__cta-button:hover .jm-footer__cta-button-icon { transform: translateX(3px); }

    /* メインフッター：4 列、白背景 */
    .jm-footer__main {
      background: var(--uq-white);
      border-bottom: 1px solid var(--uq-line);
    }
    .jm-footer__main-inner {
      max-width: 1440px;
      margin: 0 auto;
      padding: 56px 24px 48px;
      display: grid;
      grid-template-columns: 1.4fr 1fr 1fr 1.2fr;
      gap: 40px;
    }
    .jm-footer__col {}

    /* PC ではボタン見出しを通常見出し風に */
    .jm-footer__col-title-wrap { margin: 0 0 18px; }
    .jm-footer__col-title {
      width: 100%;
      background: transparent;
      border: none;
      padding: 0 0 8px;
      display: flex;
      align-items: center;
      justify-content: space-between;
      cursor: default;
      pointer-events: none;
      border-bottom: 2px solid var(--uq-black);
    }
    .jm-footer__col-title-text {
      font-size: 15px;
      font-weight: 900;
      letter-spacing: 0.16em;
      color: var(--uq-black);
      text-transform: uppercase;
    }
    .jm-footer__col-title-icon { display: none; }

    .jm-footer__brand {
      display: inline-flex;
      flex-direction: column;
      background: transparent;
      color: var(--jm-navy);
      padding: 4px 0;
      margin-bottom: 14px;
      align-self: flex-start;
      transition: opacity 150ms ease;
    }
    .jm-footer__brand:hover { opacity: 0.7; color: var(--jm-navy); }
    .jm-footer__brand-main {
      font-size: 20px;
      font-weight: 900;
      letter-spacing: 0.06em;
      color: var(--jm-navy);
    }
    .jm-footer__brand-sub {
      font-size: 12px;
      font-weight: 500;
      letter-spacing: 0.04em;
      margin-top: 3px;
      color: var(--uq-sub);
    }

    /* 認定支援機関バッジ（footer brand 直下、視覚的シグナル強化） */
    .jm-footer__certifications {
      display: flex;
      flex-direction: column;
      gap: 6px;
      margin: 12px 0;
    }
    .jm-footer__cert-badge {
      display: inline-flex;
      align-items: center;
      gap: 8px;
      padding: 7px 10px;
      background: rgba(15, 42, 79, 0.04);
      border: 1px solid rgba(15, 42, 79, 0.10);
      font-size: 12px;
      font-weight: 700;
      letter-spacing: 0.04em;
      color: var(--jm-navy);
      line-height: 1.3;
    }
    .jm-footer__cert-badge svg {
      flex-shrink: 0;
      color: var(--uq-red);
    }

    .jm-footer__address {
      font-style: normal;
      font-size: 14px;
      line-height: 1.7;
      color: var(--uq-text);
      margin-bottom: 12px;
    }
    .jm-footer__address-line { margin: 0 0 4px; }
    .jm-footer__address-line--badge {
      display: inline-flex;
      align-items: center;
      gap: 6px;
      font-size: 13px;
      color: var(--uq-red);
      font-weight: 700;
      letter-spacing: 0.06em;
      padding: 3px 0;
    }
    .jm-footer__address-line--addr { color: var(--uq-sub); font-size: 13px; }
    .jm-footer__address-line--operator {
      font-size: 13px;
      color: var(--uq-sub);
      letter-spacing: 0.04em;
      margin: 2px 0 8px;
    }
    .jm-footer__minicopy {
      margin: 0;
      font-size: 13px;
      color: var(--uq-sub);
      line-height: 1.7;
      letter-spacing: 0.04em;
    }

    .jm-footer__list { display: flex; flex-direction: column; }
    .jm-footer__list li { margin: 0; }
    .jm-footer__list li a {
      display: inline-flex;
      align-items: center;
      gap: 6px;
      padding: 6px 0;
      font-size: 14px;
      letter-spacing: 0.04em;
      color: var(--uq-text);
      transition: color 150ms ease, padding-left 150ms ease;
    }
    .jm-footer__list li a:hover {
      color: var(--uq-red);
      padding-left: 4px;
    }
    .jm-footer__list-icon { opacity: 0.6; }

    .jm-footer__divider {
      border-top: 1px solid var(--uq-line);
      margin: 14px 0 10px;
    }
    .jm-footer__list-label {
      margin: 0 0 4px;
      font-size: 12px;
      font-weight: 700;
      letter-spacing: 0.16em;
      color: var(--uq-sub);
      text-transform: uppercase;
    }

    /* 連絡先 CTA */
    .jm-footer__contact-cta {
      display: flex;
      align-items: center;
      justify-content: space-between;
      gap: 12px;
      padding: 14px 16px;
      background: var(--uq-black);
      color: var(--uq-white);
      margin-bottom: 12px;
      transition: background 150ms ease;
    }
    .jm-footer__contact-cta:hover { background: var(--uq-red); color: var(--uq-white); }
    .jm-footer__contact-cta-line { display: flex; flex-direction: column; }
    .jm-footer__contact-cta-main {
      font-size: 15px;
      font-weight: 900;
      letter-spacing: 0.08em;
    }
    .jm-footer__contact-cta-sub {
      font-size: 12px;
      letter-spacing: 0.06em;
      opacity: 0.85;
      margin-top: 2px;
    }
    .jm-footer__contact-link {
      display: inline-flex;
      align-items: center;
      gap: 8px;
      padding: 8px 0;
      font-size: 14px;
      color: var(--uq-text);
    }
    .jm-footer__contact-link:hover { color: var(--uq-red); }

    /* 法務帯：黒背景白文字 */
    .jm-footer__legal {
      background: var(--uq-black);
      color: var(--uq-white);
    }
    .jm-footer__legal-inner {
      max-width: 1440px;
      margin: 0 auto;
      padding: 16px 24px;
    }
    .jm-footer__legal-list {
      display: flex;
      flex-wrap: wrap;
      gap: 24px;
      align-items: center;
      justify-content: center;
    }
    .jm-footer__legal-list a {
      font-size: 13px;
      letter-spacing: 0.08em;
      color: var(--uq-white);
    }
    .jm-footer__legal-list a:hover { color: var(--uq-red); }

    /* コピーライト */
    .jm-footer__copyright {
      background: var(--uq-black);
      color: var(--uq-white);
      border-top: 1px solid rgba(255, 255, 255, 0.08);
    }
    .jm-footer__copyright-text {
      max-width: 1440px;
      margin: 0 auto;
      padding: 14px 24px;
      font-size: 13px;
      letter-spacing: 0.08em;
      text-align: center;
      opacity: 0.7;
    }

    /* SP 用：コピーライト上部に運営者情報を常時表示（PC では非表示） */
    .jm-footer__sp-owner { display: none; }

    /* ============ レスポンシブ：タブレット ============ */
    @media (max-width: 1023px) {
      .jm-header {
        width: calc(100% - 24px);
        top: 12px;
      }
      .demo-main { padding-top: 180px; }
      .jm-header__row1-inner { gap: 16px; padding: 12px 16px; }
      .jm-cta--header-secondary { display: none; }
      .jm-nav__inner { padding: 0 16px; gap: 16px; }
      .jm-nav__link, .jm-nav__toggle { padding: 14px 12px; font-size: 15px; letter-spacing: 0.06em; }
      .jm-nav__count-badge { display: none; }
      .demo-section { padding: 24px 16px; }
      .demo-hero { padding: 48px 24px; }
      .demo-hero__title { font-size: 28px; }
      /* タブレット：業種 6 列、課題 2 列（5 枚は 2-2-1） */
      .category-grid { grid-template-columns: repeat(6, 1fr); }
      .issue-grid { grid-template-columns: repeat(2, 1fr); }
      .issue-card { min-height: 240px; }
      .jm-footer__main-inner {
        grid-template-columns: 1fr 1fr;
        gap: 32px 24px;
        padding: 40px 16px 32px;
      }
      .jm-footer__cta-inner { padding: 28px 16px; }
      .jm-footer__cta-lead { font-size: 21px; }
    }

    /* ============ レスポンシブ：SP ============ */
    @media (max-width: 768px) {
      .jm-header {
        width: calc(100% - 20px);
        top: 10px;
        border-radius: 6px;
        box-shadow: 0 12px 32px rgba(15, 42, 79, 0.18), 0 4px 10px rgba(15, 42, 79, 0.10), 0 1px 3px rgba(15, 42, 79, 0.06);
      }
      .demo-main { padding-top: 140px; }
      .jm-header__row1-inner {
        display: grid;
        grid-template-columns: 1fr 56px;
        grid-template-rows: auto auto;
        grid-template-areas:
          "logo    quick"
          "search  hamburger";
        column-gap: 8px;
        row-gap: 6px;
        padding: 8px 5px 8px 12px;
        align-items: center;
      }
      .jm-logo {
        grid-area: logo;
        min-width: 0;
        justify-self: start;
        align-self: center;
      }
      .jm-logo__main { font-size: 19px; letter-spacing: 0.04em; }
      .jm-logo__sub { font-size: 9px; margin-top: 2px; }

      /* SP 検索：search 行内で hamburger と並ぶ */
      .jm-search-area {
        grid-area: search;
        align-self: center;
      }
      .jm-search {
        background: var(--uq-white);
        border: 1px solid var(--uq-line-strong);
      }
      .jm-search__input { padding: 7px 10px; font-size: 14px; min-width: 0; text-overflow: ellipsis; }
      .jm-search__submit {
        background: var(--jm-navy);
        color: var(--uq-white);
        padding: 7px 12px;
        flex-shrink: 0;
      }
      .jm-search__submit:hover {
        background: var(--jm-navy-deep);
        color: var(--uq-white);
      }

      /* SP クイックナビ：縦 2 段並び（174 → 184px、右端揃え） */
      .jm-mobile-quick {
        grid-area: quick;
        display: flex;
        flex-direction: column;
        gap: 6px;
        min-width: 0;
        width: 184px;
        justify-self: end;
        align-self: start;
      }
      .jm-mobile-quick__item { position: relative; }
      .jm-mobile-quick__toggle {
        width: 100%;
        background: var(--uq-bg-soft);
        border: 1px solid var(--uq-line-strong);
        padding: 5px 10px;
        font-size: 13px;
        font-weight: 700;
        letter-spacing: 0.04em;
        color: var(--jm-navy);
        display: flex;
        align-items: center;
        justify-content: space-between;
        gap: 4px;
        border-radius: 0;
      }
      .jm-mobile-quick__toggle[aria-expanded="true"] {
        background: var(--jm-navy);
        color: var(--uq-white);
        border-color: var(--jm-navy);
      }
      .jm-mobile-quick__chevron { transition: transform 200ms ease; }
      .jm-mobile-quick__toggle[aria-expanded="true"] .jm-mobile-quick__chevron { transform: rotate(180deg); }
      .jm-mobile-quick__dropdown {
        position: absolute;
        top: calc(100% + 2px);
        left: 0;
        right: 0;
        background: var(--uq-white);
        border: 0 solid var(--uq-line);
        border-top-color: var(--uq-red);
        z-index: 60;
        max-height: 0;
        overflow: hidden;
        transition: max-height 200ms ease, border-width 0s linear 200ms;
      }
      .jm-mobile-quick__toggle[aria-expanded="true"] + .jm-mobile-quick__dropdown {
        max-height: calc(100vh - 130px);
        overflow-y: auto;
        -webkit-overflow-scrolling: touch;
        border-width: 1px 1px 1px 1px;
        border-top-width: 2px;
        transition: max-height 200ms ease, border-width 0s;
      }
      .jm-mobile-quick__dropdown li a {
        display: block;
        padding: 10px 12px;
        font-size: 14px;
        border-bottom: 1px solid var(--uq-line);
        color: var(--uq-text);
      }
      .jm-mobile-quick__dropdown li:last-child a { border-bottom: none; }
      .jm-mobile-quick__dropdown li a:hover { background: var(--uq-bg-soft); color: var(--uq-red); }

      /* SP クイックナビ：サブアコーディオン（経営基盤の中の 7 項目） */
      .jm-mq-sub-item {
        position: relative;
        border-bottom: 1px solid var(--uq-line);
      }
      .jm-mq-sub-item:last-child { border-bottom: none; }
      .jm-mq-sub-toggle {
        width: 100%;
        display: flex;
        align-items: center;
        justify-content: space-between;
        padding: 10px 12px;
        background: transparent;
        border: none;
        font-size: 14px;
        font-weight: 500;
        color: var(--uq-text);
        cursor: pointer;
        font-family: inherit;
        text-align: left;
        transition: background 150ms ease, color 150ms ease;
      }
      .jm-mq-sub-toggle:hover { background: var(--uq-bg-soft); color: var(--uq-red); }
      .jm-mq-sub-toggle[aria-expanded="true"] {
        background: var(--jm-navy);
        color: var(--uq-white);
      }
      .jm-mq-sub-arrow { transition: transform 200ms ease; flex-shrink: 0; }
      .jm-mq-sub-toggle[aria-expanded="true"] .jm-mq-sub-arrow { transform: rotate(180deg); }
      .jm-mq-sub-dropdown {
        list-style: none;
        margin: 0;
        padding: 0;
        background: var(--uq-bg-soft);
        max-height: 0;
        overflow: hidden;
        transition: max-height 250ms ease;
      }
      .jm-mq-sub-toggle[aria-expanded="true"] + .jm-mq-sub-dropdown {
        max-height: 500px;
      }
      .jm-mq-sub-dropdown li a {
        display: block;
        padding: 8px 12px 8px 24px;
        font-size: 14px;
        color: var(--uq-text);
        border-bottom: 1px solid rgba(15, 42, 79, 0.08);
      }
      .jm-mq-sub-dropdown li:last-child a { border-bottom: none; }
      .jm-mq-sub-dropdown li a:hover {
        background: var(--uq-white);
        color: var(--uq-red);
      }

      /* SP では PC 用 CTA は非表示（ハンバーガー内に同 CTA を格納） */
      .jm-cta--header.jm-cta--shine { display: none; }
      .jm-cta--header-secondary { display: none; }

      .jm-hamburger {
        grid-area: hamburger;
        justify-self: end;
        align-self: center;
        display: inline-flex;
        flex-direction: column;
        justify-content: space-between;
        align-items: center;
        background: var(--jm-navy);
        border: 1px solid var(--jm-navy);
        width: 44px;
        height: 44px;
        padding: 13px 11px;
        border-radius: 0;
      }
      .jm-hamburger__bar {
        display: block;
        width: 100%;
        height: 2px;
        background: var(--uq-white);
        transition: transform 200ms ease, opacity 200ms ease, background 200ms ease;
      }
      .jm-hamburger[aria-expanded="true"] {
        background: var(--uq-black);
        border-color: var(--uq-black);
      }
      .jm-hamburger[aria-expanded="true"] .jm-hamburger__bar { background: var(--uq-white); }
      .jm-hamburger[aria-expanded="true"] .jm-hamburger__bar:nth-child(1) { transform: translateY(7px) rotate(45deg); }
      .jm-hamburger[aria-expanded="true"] .jm-hamburger__bar:nth-child(2) { opacity: 0; }
      .jm-hamburger[aria-expanded="true"] .jm-hamburger__bar:nth-child(3) { transform: translateY(-7px) rotate(-45deg); }

      /* SP ではタグラインを非表示 */
      .jm-tagline--sp { display: none; }

      /* PC ナビ・row3 は SP では隠す */
      .jm-nav, .jm-header__row3 { display: none; }

      /* モバイルメニュー */
      .jm-mobile-menu {
        display: block;
        position: fixed;
        top: 0;
        right: 0;
        width: 80%;
        max-width: 320px;
        height: 100vh;
        background: var(--uq-white);
        z-index: 200;
        transform: translateX(100%);
        transition: transform 280ms ease;
        overflow-y: auto;
        border-left: 4px solid var(--uq-red);
      }
      .jm-mobile-menu[aria-hidden="false"] { transform: translateX(0); }
      .jm-mobile-menu__inner { padding: 64px 24px 32px; }
      .jm-mobile-menu__list { margin-bottom: 24px; }
      .jm-mobile-menu__item { border-bottom: 1px solid var(--uq-line); }
      .jm-mobile-menu__link {
        display: block;
        padding: 16px 4px;
        font-size: 16px;
        font-weight: 700;
        letter-spacing: 0.08em;
        color: var(--uq-black);
      }
      .jm-mobile-menu__link:hover { color: var(--uq-red); }
      .jm-mobile-menu__count-badge {
        display: inline-flex;
        align-items: center;
        gap: 6px;
        padding: 6px 12px;
        background: var(--uq-black);
        color: var(--uq-white);
        font-size: 13px;
        font-weight: 700;
        letter-spacing: 0.08em;
        margin-bottom: 18px;
      }
      .jm-mobile-menu__count-badge strong {
        font-size: 16px;
        color: var(--uq-red);
        background: var(--uq-white);
        padding: 1px 6px;
      }
      /* ハンバーガー内 主 CTA：赤背景白文字（PC と統一） */
      .jm-cta--mobile {
        display: block;
        padding: 14px 16px;
        background: var(--uq-red);
        color: var(--uq-white);
        text-align: center;
        font-size: 15px;
        font-weight: 900;
        letter-spacing: 0.08em;
        margin-bottom: 10px;
        border-radius: 0;
        border: 1px solid var(--uq-red);
      }
      .jm-cta--mobile:hover {
        background: var(--uq-red-hover);
        border-color: var(--uq-red-hover);
        color: var(--uq-white);
      }
      .jm-cta--mobile-secondary {
        background: var(--uq-white);
        color: var(--uq-black);
        border: 1px solid var(--uq-black);
      }
      .jm-cta--mobile-secondary:hover { background: var(--uq-black); color: var(--uq-white); border-color: var(--uq-black); }
      .jm-cta--mobile .jm-cta__line { display: block; font-size: 13px; }
      .jm-mobile-menu__overlay {
        display: block;
        position: fixed;
        inset: 0;
        background: rgba(0, 0, 0, 0.45);
        z-index: 190;
        opacity: 0;
        visibility: hidden;
        pointer-events: none;
        cursor: pointer;
        transition: opacity 200ms ease, visibility 200ms ease;
      }
      .jm-mobile-menu[aria-hidden="false"] ~ .jm-mobile-menu__overlay,
      .jm-mobile-menu__overlay.is-visible {
        opacity: 1;
        visibility: visible;
        pointer-events: auto;
      }

      /* SP メニュー：閉じるボタン（明示的なクローズ手段） */
      .jm-mobile-menu__close {
        display: flex;
        align-items: center;
        justify-content: center;
        gap: 8px;
        width: 100%;
        padding: 12px;
        background: transparent;
        border: 1px solid var(--jm-navy);
        color: var(--jm-navy);
        font-size: 14px;
        font-weight: 700;
        letter-spacing: 0.08em;
        font-family: inherit;
        cursor: pointer;
        margin-bottom: 20px;
        border-radius: 0;
        transition: background 150ms ease, color 150ms ease;
      }
      .jm-mobile-menu__close:hover {
        background: var(--jm-navy);
        color: var(--uq-white);
      }
      /* メニュー上部余白を閉じるボタンに合わせて縮小 */
      .jm-mobile-menu__inner { padding: 20px 24px 32px; }

      /* MAIN（SP） */
      .demo-info-bar { margin: 0; padding: 8px 12px; font-size: 13px; }
      .demo-section { padding: 24px 12px; }
      .demo-hero { padding: 56px 16px; min-height: 360px; }
      .demo-hero__supertitle { font-size: 13px; margin-bottom: 12px; padding: 0 14px; letter-spacing: 0.12em; }
      .demo-hero__supertitle::before,
      .demo-hero__supertitle::after { width: 10px; }
      .demo-hero__title { font-size: 30px; letter-spacing: 0.02em; }
      .demo-hero__title-line { display: block; }
      .demo-hero__sub { font-size: 14px; }
      .demo-section__title { font-size: 20px; }
      /* SP：FEATURED SOLUTIONS は横スクロールスライダー */
      .demo-grid {
        display: flex;
        grid-template-columns: none;
        overflow-x: auto;
        overflow-y: hidden;
        scroll-snap-type: x mandatory;
        gap: 12px;
        padding: 4px 12px 16px;
        margin: 0 -12px;
        -webkit-overflow-scrolling: touch;
        scrollbar-width: none;
      }
      .demo-grid::-webkit-scrollbar { display: none; }
      .demo-grid > .demo-card {
        flex: 0 0 76%;
        scroll-snap-align: start;
        min-width: 0;
        cursor: grab;
      }
      .demo-grid > .demo-card:active { cursor: grabbing; }

      /* SP：スライダーカーソル（ドットインジケーター） */
      .demo-slider-dots {
        display: flex;
        justify-content: center;
        gap: 8px;
        margin: 14px 0 6px;
      }
      .demo-slider-dot {
        width: 8px;
        height: 8px;
        background: var(--uq-line-strong);
        border-radius: 50%;
        transition: background 200ms ease, transform 200ms ease, width 200ms ease;
      }
      .demo-slider-dot.is-active {
        background: var(--uq-red);
        width: 22px;
        border-radius: 4px;
      }

      /* SP：スワイプ案内テキスト */
      .demo-slider-hint {
        display: block;
        text-align: center;
        font-size: 12px;
        font-weight: 600;
        letter-spacing: 0.08em;
        color: var(--uq-sub);
        margin: 0 0 4px;
        animation: jm-slider-pulse 2.4s ease-in-out infinite;
      }

      /* SP：スライダー左右ナビゲーション（画像エリアと重なる位置に上書き） */
      .demo-slider-nav {
        top: 70px;            /* 画像（130px 高）の中央あたり */
        transform: none;
        width: 38px;
        height: 38px;
        box-shadow: 0 4px 12px rgba(15, 42, 79, 0.25);
      }
      .demo-slider-nav:hover,
      .demo-slider-nav:active {
        transform: scale(1.08);
      }
      .demo-slider-nav--prev { left: 6px; }
      .demo-slider-nav--next { right: 6px; }
      @keyframes jm-slider-pulse {
        0%, 100% { opacity: 0.5; transform: translateX(0); }
        50% { opacity: 1; transform: translateX(2px); }
      }

      /* SP：業種は 3 列、課題は 1 列縦並び */
      .category-grid {
        grid-template-columns: repeat(3, 1fr);
        gap: 6px;
      }
      .category-card__icon { font-size: 28px; }
      .category-card__label { font-size: 13px; padding: 8px 4px; }
      .issue-grid {
        grid-template-columns: 1fr;
        gap: 8px;
      }
      .issue-card {
        padding: 22px 18px 20px;
        min-height: auto;
      }
      .issue-card__num { font-size: 28px; }
      .issue-card__count { font-size: 13px; padding: 4px 10px; }
      .issue-card__title { font-size: 20px; padding-bottom: 12px; }
      .issue-card__items li { font-size: 16px; padding: 6px 0 6px 14px; line-height: 1.5; }
      .issue-card__items li::before { width: 8px; top: 14px; }
      .issue-card__more { font-size: 15px; }
      .demo-card { padding: 12px; }
      .demo-card__title { font-size: 15px; }
      .demo-card__desc { font-size: 13px; }

      /* FOOTER（SP）：アコーディオン化 */
      .jm-footer__cta-inner {
        flex-direction: column;
        align-items: stretch;
        text-align: center;
        padding: 28px 16px;
      }
      .jm-footer__cta-button { justify-content: center; width: 100%; }
      .jm-footer__main-inner {
        grid-template-columns: 1fr;
        gap: 0;
        padding: 0 16px;
      }
      .jm-footer__col {
        border-bottom: 1px solid var(--uq-line);
      }
      .jm-footer__col-title-wrap { margin: 0; }
      .jm-footer__col-title {
        cursor: pointer;
        pointer-events: auto;
        padding: 18px 0;
        border-bottom: none;
        justify-content: space-between;
      }
      .jm-footer__col-title-icon {
        display: inline-block;
        position: relative;
        width: 14px;
        height: 14px;
      }
      .jm-footer__col-title-icon::before,
      .jm-footer__col-title-icon::after {
        content: "";
        position: absolute;
        background: var(--uq-black);
      }
      .jm-footer__col-title-icon::before {
        top: 50%;
        left: 0; right: 0;
        height: 2px;
        transform: translateY(-50%);
      }
      .jm-footer__col-title-icon::after {
        left: 50%;
        top: 0; bottom: 0;
        width: 2px;
        transform: translateX(-50%) scaleY(1);
        transition: transform 200ms ease;
      }
      .jm-footer__col-title[aria-expanded="true"] .jm-footer__col-title-icon::after {
        transform: translateX(-50%) scaleY(0);
      }
      .jm-footer__col-body {
        max-height: 0;
        overflow: hidden;
        transition: max-height 280ms ease;
        padding-bottom: 0;
      }
      .jm-footer__col[data-jm-accordion] .jm-footer__col-body { padding: 0 0; }
      [data-jm-accordion][data-jm-accordion-open="true"] .jm-footer__col-body {
        max-height: 800px;
        padding-bottom: 18px;
      }

      .jm-footer__legal-list { gap: 12px 16px; padding: 4px 0; }
      .jm-footer__legal-list a { font-size: 12px; }

      /* SP：「運営者情報」アコーディオンを非表示（コピーライト部に常時表示するため） */
      .jm-footer__col--owner { display: none; }

      /* SP：コピーライト直前に運営者情報を常時表示 */
      .jm-footer__sp-owner {
        display: block;
        max-width: 1440px;
        margin: 0 auto;
        padding: 18px 16px 12px;
        text-align: center;
        border-top: 1px solid rgba(255, 255, 255, 0.10);
        color: rgba(255, 255, 255, 0.85);
        line-height: 1.55;
      }
      .jm-footer__sp-owner-name {
        font-size: 14px;
        font-weight: 700;
        color: var(--uq-white);
        margin: 0 0 2px;
        letter-spacing: 0.06em;
      }
      .jm-footer__sp-owner-operator {
        font-size: 12px;
        color: rgba(255, 255, 255, 0.6);
        letter-spacing: 0.04em;
        margin: 0 0 8px;
      }
      .jm-footer__sp-owner-badge {
        font-size: 12px;
        color: rgba(255, 255, 255, 0.75);
        margin: 0 0 3px;
        letter-spacing: 0.04em;
      }
      .jm-footer__sp-owner-addr {
        font-size: 12px;
        color: rgba(255, 255, 255, 0.45);
        margin: 8px 0 0;
        letter-spacing: 0.02em;
      }
    }

    /* ============ アクセシビリティ ============ */
    *:focus-visible {
      outline: 2px solid var(--uq-red);
      outline-offset: 2px;
    }
    @media (prefers-reduced-motion: reduce) {
      *, *::before, *::after {
        transition-duration: 0.01ms !important;
        animation-duration: 0.01ms !important;
      }
    }
    /* ============ TL;DR セクション（周瑜 SEO 戦略 v1.1 依頼④：運営者シグナル可視化） ============ */
    .jm-tldr {
      max-width: 1200px;
      margin: 0 auto;
      padding: 28px 32px;
      background: linear-gradient(135deg, var(--jm-navy) 0%, var(--jm-navy-deep) 100%);
      color: var(--uq-white);
      border-radius: 10px;
      border-left: 4px solid var(--uq-red);
      box-shadow: 0 8px 20px rgba(15, 42, 79, 0.16);
    }
    .jm-tldr__lead {
      font-size: 16px;
      line-height: 1.95;
      margin: 0 0 12px;
      color: var(--uq-white);
    }
    .jm-tldr__sub {
      font-size: 15px;
      line-height: 1.9;
      margin: 0;
      color: rgba(255, 255, 255, 0.92);
    }
    .jm-tldr strong {
      color: var(--uq-white);
      font-weight: 900;
      background: linear-gradient(transparent 65%, rgba(230, 0, 18, 0.40) 65%);
      padding: 0 3px;
    }
    @media (max-width: 600px) {
      .jm-tldr { padding: 22px 20px; border-radius: 8px; }
      .jm-tldr__lead { font-size: 15px; line-height: 1.85; }
      .jm-tldr__sub { font-size: 14px; line-height: 1.85; }
    }

    /* ===== v1.x：注目のメニューカードの「詳しく見る」ボタン ===== */
    .demo-card__detail {
      display: inline-flex;
      align-items: center;
      justify-content: center;
      gap: 8px;
      width: calc(100% - 0px);
      margin: 14px 0 0;
      padding: 12px 16px;
      background: var(--uq-red);
      color: var(--uq-white) !important;
      font-size: 14px;
      font-weight: 700;
      letter-spacing: 0.06em;
      border-radius: 6px;
      text-decoration: none;
      transition: background 0.2s, transform 0.2s;
      box-shadow: 0 4px 12px rgba(230, 0, 18, 0.20);
    }
    .demo-card__detail:hover {
      background: var(--uq-red-hover);
      transform: translateY(-1px);
      box-shadow: 0 6px 16px rgba(230, 0, 18, 0.32);
      color: var(--uq-white) !important;
    }
    .demo-card__detail span {
      transition: transform 0.2s;
    }
    .demo-card__detail:hover span {
      transform: translateX(3px);
    }
    @media (max-width: 600px) {
      .demo-card__detail { font-size: 13px; padding: 10px 14px; }
    }

    /* カード全体をクリック可能に（stretched-link / CVR 改善 2026-06-11 法正） */
    .demo-card__detail::after {
      content: "";
      position: absolute;
      inset: 0;
      z-index: 2;
    }

    /* ============================================================
       v1.x：トップページ メインビジュアル（少し暗い程度の効果）
       — カラー維持、brightness 控えめに低下
       — テキスト可読性確保のため軽いネイビーオーバーレイのみ
       ============================================================ */
    .demo-hero {
      position: relative;
      overflow: hidden;
      isolation: isolate;
    }
    .demo-hero__bg {
      position: absolute;
      inset: 0;
      z-index: -1;
      pointer-events: none;
    }
    .demo-hero__bg img {
      width: 100%;
      height: 100%;
      object-fit: cover;
      object-position: center;
      filter: brightness(0.52) contrast(1.05) saturate(1.05);
      display: block;
    }
    /* 軽いネイビーオーバーレイ（テキスト可読性 + ブランドトンマナ） */
    .demo-hero::before {
      content: "";
      position: absolute;
      inset: 0;
      z-index: -1;
      background:
        linear-gradient(135deg, rgba(15, 42, 79, 0.42) 0%, rgba(27, 58, 107, 0.26) 60%, rgba(15, 42, 79, 0.42) 100%);
      pointer-events: none;
    }
    /* ヒーロー前景要素を確実に上に + テキストを見やすく */
    .demo-hero > p,
    .demo-hero > h1 {
      position: relative;
      z-index: 1;
      text-shadow: 0 2px 12px rgba(0, 0, 0, 0.45);
    }
    @media (max-width: 600px) {
      .demo-hero__bg img {
        object-position: center top;
        filter: brightness(0.48) contrast(1.05) saturate(1.05);
      }
    }

/* ============================================================
   SWELL 記事スタイル干渉の補正 v1（2026-06-12 法正）
   .post_content 内でもカード・リストの余白をデモ設計値で維持する
   設置: SWELL CHILD style.css の末尾（前回貼付分のさらに下）
   ============================================================ */

/* --- 注目のメニュー（demo-card）--- */
.post_content .demo-card__cat    { margin: 0 0 10px !important; }
.post_content .demo-card__title  { margin: 0 0 8px !important; padding: 0 !important; }
.post_content .demo-card__desc   { margin: 0 0 12px !important; }
.post_content .demo-card__meta   { margin: 0 !important; padding: 10px 0 0 !important; }
.post_content .demo-card__detail { margin: 14px 0 0 !important; }
.post_content .demo-card__image  { margin: -18px -18px 14px !important; }

/* --- 課題カード（issue-card）--- */
.post_content .issue-card__head  { margin: 0 0 12px !important; }
.post_content .issue-card__title {
	margin: 0 0 14px !important;
	padding: 0 0 10px !important;
	border-bottom: 2px solid #000 !important; /* 打ち消しCSSで消えていた黒下線を復元 */
}
.post_content .issue-card__items { margin: 0 0 14px !important; padding: 0 !important; }
.post_content .issue-card__items li { margin: 0 !important; padding: 4px 0 4px 12px !important; }

/* --- セクション見出しまわり --- */
.post_content .demo-section__lead { margin: 0 0 24px !important; }

/* --- 業種カード --- */
.post_content .category-card__label { margin: 0 !important; padding: 14px 8px !important; }

/* --- ヒーロー内テキスト --- */
.post_content .demo-hero__supertitle { margin: 0 0 16px !important; }
.post_content .demo-hero__title      { margin: 0 0 14px !important; }
.post_content .demo-hero__sub        { margin: 0 !important; }
.post_content .demo-hero__define     { margin: auto auto 0 !important; }

/* --- SP 用の値（デモのメディアクエリを important で再宣言）--- */
@media (max-width: 768px) {
	.post_content .issue-card__title     { padding: 0 0 12px !important; }
	.post_content .issue-card__items li  { padding: 6px 0 6px 14px !important; }
	.post_content .category-card__label  { padding: 8px 4px !important; }
	.post_content .demo-hero__supertitle { margin: 0 0 12px !important; padding: 0 14px !important; }
}

