/*
Theme Name: JBiz Global Advisory
Theme URI: https://hiroshijbsaito.com
Author: CREATERIUM
Author URI: https://createrium.co.jp
Description: J-Biz Education 株式会社 JBizグローバルアドバイザリー 1Pカスタムテーマ
Version: 1.0.0
License: GNU General Public License v2 or later
Text Domain: jbiz
*/

:root{
  --ink:#1a1a2e;--ink-2:#3d3d5c;--ink-3:#7a7a9a;
  --white:#ffffff;--off-white:#f8f9fc;--light-gray:#f0f2f8;
  --gold:#b8972a;--gold-light:#d4b44a;--gold-pale:#fdf6e3;
  --navy:#16223f;--navy-2:#22335c;
  --accent:#2b5ce6;--accent-light:#e8eefb;
  --teal:#0f7a6b;--teal-light:#e0f4f1;
  --border:#e2e6f0;--border-dark:rgba(0,0,0,0.1);
}
*{margin:0;padding:0;box-sizing:border-box;}
html{scroll-behavior:smooth;}
body{font-family:'Noto Sans JP',sans-serif;background:var(--white);color:var(--ink);font-weight:300;line-height:1.75;overflow-x:hidden;}

/* ── NAV (EdulinX風: 白背景・シンプル) ── */
nav{
  position:fixed;top:0;left:0;right:0;z-index:200;
  display:flex;align-items:center;justify-content:space-between;
  padding:0 48px;height:68px;
  background:rgba(255,255,255,0.97);
  backdrop-filter:blur(8px);
  border-bottom:1px solid var(--border);
}
.nav-logo{
  font-family:'Cormorant Garamond',serif;font-size:22px;font-weight:600;
  letter-spacing:.02em;color:var(--navy);text-decoration:none;
  display:flex;align-items:center;gap:10px;
}
.nav-logo .sub{
  font-family:'Noto Sans JP',sans-serif;font-size:10px;
  letter-spacing:.15em;color:var(--gold);font-weight:500;
}
.nav-links{display:flex;gap:28px;list-style:none;align-items:center;}
.nav-links a{
  font-size:13px;letter-spacing:.06em;color:var(--ink-2);
  text-decoration:none;transition:color .2s;
}
.nav-links a:hover{color:var(--accent);}
.nav-cta{
  background:#2b5ce6!important;color:#fff!important;
  padding:10px 24px;font-size:12px!important;letter-spacing:.1em!important;
  transition:background .2s!important;border-radius:2px;
}
.nav-cta:hover{background:#1a4ad4!important;}
/* ── ハンバーガー（モバイルのみ表示） ── */
.nav-toggle{display:none;background:none;border:0;cursor:pointer;width:42px;height:42px;flex-direction:column;justify-content:center;align-items:center;gap:5px;padding:0;margin-left:auto;}
.nav-toggle span{display:block;width:24px;height:2px;background:var(--navy);border-radius:2px;transition:transform .3s,opacity .3s;}
nav.nav-open .nav-toggle span:nth-child(1){transform:translateY(7px) rotate(45deg);}
nav.nav-open .nav-toggle span:nth-child(2){opacity:0;}
nav.nav-open .nav-toggle span:nth-child(3){transform:translateY(-7px) rotate(-45deg);}


/* ── HERO v4 (白ベース・センター寄せ・クリーン) ── */
.hero{
  min-height:100vh;padding-top:68px;
  background:#ffffff;
  display:flex;flex-direction:column;
  align-items:center;justify-content:center;
  position:relative;overflow:hidden;
}
/* 背景の淡いグラデーション装飾 */
.hero::before{
  content:'';position:absolute;
  top:-200px;right:-200px;
  width:600px;height:600px;border-radius:50%;
  background:radial-gradient(circle, rgba(43,92,230,0.06) 0%, transparent 70%);
  pointer-events:none;
}
.hero::after{
  content:'';position:absolute;
  bottom:-150px;left:-150px;
  width:400px;height:400px;border-radius:50%;
  background:radial-gradient(circle, rgba(184,151,42,0.06) 0%, transparent 70%);
  pointer-events:none;
}
.hero-inner{
  position:relative;z-index:1;
  display:grid;grid-template-columns:1fr 1fr;
  max-width:1200px;width:100%;
  padding:60px 80px;gap:80px;align-items:center;
}
.hero-left-new{display:flex;flex-direction:column;gap:0;}
.hero-eyebrow-new{
  display:inline-flex;align-items:center;gap:10px;
  font-size:11px;letter-spacing:.22em;color:var(--gold);
  font-weight:500;margin-bottom:28px;
}
.hero-eyebrow-new::before{
  content:'';display:block;width:28px;height:1.5px;background:var(--gold);
}
.hero-title-new{
  font-family:'Cormorant Garamond',serif;
  font-size:clamp(38px,4.5vw,58px);font-weight:300;
  color:var(--navy);line-height:1.2;margin-bottom:20px;
  letter-spacing:-.01em;
}
.hero-title-new b{color:#2b5ce6;font-weight:400;}
.hero-subtitle-new{
  font-size:15px;font-weight:400;color:var(--ink-2);
  line-height:1.7;letter-spacing:.02em;
  padding-left:18px;border-left:3px solid var(--gold);
  margin-bottom:48px;
}
.hero-cta-row-new{display:flex;gap:14px;align-items:center;}
.hero-btn-new{
  display:inline-flex;align-items:center;gap:8px;
  padding:16px 40px;background:#2b5ce6;color:#fff;
  text-decoration:none;font-size:13px;letter-spacing:.1em;
  transition:background .2s;border-radius:2px;
}
.hero-btn-new:hover{background:#1a4ad4;}
.hero-btn-ghost-new{
  display:inline-flex;align-items:center;gap:8px;
  padding:15px 28px;border:1.5px solid var(--border);
  color:var(--ink-2);text-decoration:none;
  font-size:13px;letter-spacing:.06em;transition:all .2s;border-radius:2px;
}
.hero-btn-ghost-new:hover{border-color:var(--navy);color:var(--navy);}

/* 右側：地球儀ビジュアル */
.hero-right-new{
  display:flex;align-items:center;justify-content:center;
  position:relative;
}
.globe-wrap{
  position:relative;width:420px;height:420px;
  display:flex;align-items:center;justify-content:center;
}
.globe-bg-ring{
  position:absolute;inset:-20px;border-radius:50%;
  border:1.5px solid rgba(43,92,230,0.1);
}
.globe-bg-ring2{
  position:absolute;inset:-48px;border-radius:50%;
  border:1px solid rgba(184,151,42,0.12);
}
.globe-svg{
  width:360px;height:360px;
  filter:drop-shadow(0 24px 60px rgba(26,58,92,0.18));
}
/* 浮かぶバッジ群 */
.globe-badge{
  position:absolute;background:#fff;
  border-radius:8px;padding:10px 16px;
  box-shadow:0 6px 24px rgba(0,0,0,0.10);
  display:flex;align-items:center;gap:10px;
  white-space:nowrap;
}
.globe-badge-icon{font-size:18px;}
.globe-badge-text{font-size:11px;font-weight:500;color:var(--navy);line-height:1.4;}
.globe-badge-sub{font-size:10px;color:var(--ink-3);font-weight:300;}
.badge-top{top:10px;right:0;}
.badge-mid{bottom:80px;right:-20px;}
.badge-bot{bottom:10px;left:10px;}


/* ── PROBLEM (ビザスク風: 上下対比) ── */
.problem-section{padding:96px 80px;background:var(--white);}
.problem-pairs{display:flex;flex-direction:column;gap:32px;margin-top:52px;}
.problem-pair{display:flex;flex-direction:column;border-radius:6px;overflow:hidden;box-shadow:0 4px 24px rgba(0,0,0,0.07);}
.problem-pair-top{
  background:#f5f6f8;padding:28px 36px;
  display:grid;grid-template-columns:auto 1fr;gap:20px;align-items:start;
}
.problem-pair-bottom{
  background:#2b5ce6;padding:28px 36px;
  display:grid;grid-template-columns:auto 1fr;gap:20px;align-items:start;
}
.pp-icon-box{
  width:48px;height:48px;border-radius:50%;flex-shrink:0;
  display:flex;align-items:center;justify-content:center;font-size:20px;
}
.pp-icon-box.gray{background:rgba(0,0,0,0.08);}
.pp-icon-box.blue{background:rgba(255,255,255,0.15);}
.pp-label{
  font-size:10px;letter-spacing:.16em;font-weight:600;
  margin-bottom:6px;
}
.pp-label.gray{color:#888;}
.pp-label.blue{color:rgba(255,255,255,0.65);}
.pp-title{
  font-size:16px;font-weight:500;line-height:1.55;margin-bottom:4px;
}
.pp-title.gray{color:var(--navy);}
.pp-title.blue{color:#fff;}
.pp-desc{font-size:12px;line-height:1.75;}
.pp-desc.gray{color:var(--ink-3);}
.pp-desc.blue{color:rgba(255,255,255,0.78);}
.pp-tag{
  display:inline-block;font-size:10px;padding:3px 10px;
  border-radius:10px;margin-top:6px;font-weight:500;
}
.pp-tag.service{background:rgba(255,255,255,0.2);color:#fff;}
.pp-tag.out{background:rgba(255,255,255,0.12);color:rgba(255,255,255,0.65);}

/* ── FLOW : 縦型タイムライン（CMSで枠の増減・編集を想定） ── */
.flow-section{padding:96px 80px;background:var(--white);}
.flow-steps{counter-reset:flow;max-width:760px;margin:48px auto 0;}
.flow-step{position:relative;display:flex;gap:26px;padding-bottom:34px;}
.flow-step:last-child{padding-bottom:0;}
.flow-step::before{content:"";position:absolute;left:31px;top:64px;bottom:0;width:2px;background:var(--border);}
.flow-step:last-child::before{display:none;}
.flow-marker{flex-shrink:0;width:64px;display:flex;justify-content:center;}
.flow-num{width:64px;height:64px;border-radius:50%;background:var(--navy);color:#fff;display:flex;align-items:center;justify-content:center;font-family:'Bebas Neue',sans-serif;font-size:26px;letter-spacing:.04em;position:relative;z-index:1;box-shadow:0 0 0 5px var(--white);}
.flow-num::before{counter-increment:flow;content:counter(flow,decimal-leading-zero);}
.flow-content{flex:1;background:var(--off-white);border:1px solid var(--border);border-radius:8px;padding:22px 26px;transition:box-shadow .2s;}
.flow-content:hover{box-shadow:0 8px 28px rgba(22,34,63,.07);}
.flow-content-head{display:flex;align-items:center;justify-content:space-between;gap:12px;flex-wrap:wrap;margin-bottom:9px;}
.flow-step-title{font-size:16px;font-weight:600;color:var(--navy);letter-spacing:.02em;line-height:1.5;}
.flow-step-body{font-size:13px;color:var(--ink-2);line-height:1.85;}
.flow-step-time{flex-shrink:0;font-size:11px;padding:4px 12px;background:var(--accent-light);color:var(--accent);border-radius:12px;white-space:nowrap;}

/* ── VOICES : 導入企業の声（一覧カード → モーダル） ── */
.voice-section{padding:96px 80px;background:var(--light-gray);}
.voice-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:20px;margin-top:52px;}
.voice-card{background:#fff;border:1px solid var(--border);border-radius:8px;overflow:hidden;cursor:pointer;display:flex;flex-direction:column;transition:box-shadow .2s,transform .2s;}
.voice-card:hover{box-shadow:0 14px 34px rgba(22,34,63,.12);transform:translateY(-3px);}
.vc-thumb{position:relative;aspect-ratio:16/9;background:var(--navy-2);overflow:hidden;}
.vc-thumb img{width:100%;height:100%;object-fit:cover;display:block;}
.vc-play{position:absolute;inset:0;margin:auto;width:46px;height:46px;border-radius:50%;background:rgba(255,255,255,.94);color:var(--accent);display:flex;align-items:center;justify-content:center;font-size:15px;padding-left:3px;box-shadow:0 4px 14px rgba(0,0,0,.22);}
.vc-meta{padding:16px 18px 18px;display:flex;flex-direction:column;gap:6px;flex:1;}
.vc-company{font-size:11px;letter-spacing:.04em;color:var(--gold);font-weight:600;}
.vc-name{font-size:14px;font-weight:600;color:var(--navy);}
.vc-quote{font-size:12.5px;color:var(--ink-2);line-height:1.7;}
.vc-more{margin-top:auto;padding-top:8px;font-size:11px;color:var(--accent);font-weight:600;}
.voice-card.is-placeholder{cursor:default;border-style:dashed;background:#fafbfd;}
.voice-card.is-placeholder:hover{box-shadow:none;transform:none;}
.vc-thumb.ph{display:flex;align-items:center;justify-content:center;background:#eef1f6;}
.vc-thumb.ph svg{width:40px;height:40px;}
.voice-yt-link{display:block;width:max-content;max-width:100%;margin:30px auto 0;font-size:13px;color:var(--ink-3);text-decoration:none;border:1px solid var(--border);background:#fff;padding:13px 26px;border-radius:4px;transition:all .2s;}
.voice-yt-link:hover{border-color:var(--gold);color:var(--gold);}
/* モーダル */
.voice-modal{position:fixed;inset:0;z-index:1000;display:none;}
.voice-modal.open{display:block;}
.vm-overlay{position:absolute;inset:0;background:rgba(16,22,40,.62);backdrop-filter:blur(2px);}
.vm-dialog{position:relative;max-width:760px;width:calc(100% - 36px);max-height:88vh;overflow-y:auto;margin:6vh auto;background:#fff;border-radius:10px;box-shadow:0 30px 80px rgba(0,0,0,.4);animation:vmIn .25s ease;}
@keyframes vmIn{from{opacity:0;transform:translateY(16px);}to{opacity:1;transform:none;}}
.vm-close{position:absolute;top:12px;right:12px;z-index:2;width:36px;height:36px;border:none;border-radius:50%;background:rgba(255,255,255,.92);color:var(--ink-2);font-size:22px;line-height:1;cursor:pointer;box-shadow:0 2px 10px rgba(0,0,0,.18);}
.vm-content{padding:0 0 30px;}
.vd-media{position:relative;aspect-ratio:16/9;background:var(--navy);border-radius:10px 10px 0 0;overflow:hidden;}
.vd-media iframe{position:absolute;inset:0;width:100%;height:100%;border:none;}
.vd-media img{width:100%;height:100%;object-fit:cover;}
.vd-body-wrap{padding:26px 34px 0;}
.vd-company{font-size:12px;letter-spacing:.06em;color:var(--gold);font-weight:600;margin-bottom:4px;}
.vd-name{font-size:19px;font-weight:700;color:var(--navy);margin-bottom:16px;}
.vd-body{font-size:14px;color:var(--ink-2);line-height:1.95;}

/* ── POSITIONING v2 ── */
.position-section{padding:96px 80px;background:var(--white);}
.pos-wrap{
  position:relative;max-width:720px;margin:52px auto 0;
  aspect-ratio:1/1;background:var(--off-white);border:1px solid var(--border);
}
/* 象限背景 */
.pos-q{position:absolute;width:50%;height:50%;}
.pos-q.tl{top:0;left:0;background:rgba(240,242,248,0.6);}
.pos-q.tr{top:0;right:0;background:rgba(232,238,251,0.7);}
.pos-q.bl{bottom:0;left:0;background:rgba(245,245,245,0.5);}
.pos-q.br{bottom:0;right:0;background:rgba(228,242,250,0.4);}
/* 軸線 */
.pos-axis-h{
  position:absolute;top:50%;left:4%;right:4%;
  height:1px;background:rgba(0,0,0,0.2);
  transform:translateY(-50%);
}
.pos-axis-v{
  position:absolute;left:50%;top:4%;bottom:4%;
  width:1px;background:rgba(0,0,0,0.2);
  transform:translateX(-50%);
}
/* 矢印 */
.pos-arrow-r,.pos-arrow-l,.pos-arrow-t,.pos-arrow-b{
  position:absolute;font-size:13px;color:rgba(0,0,0,0.4);
}
.pos-arrow-r{top:50%;right:1%;transform:translateY(-50%);}
.pos-arrow-l{top:50%;left:1%;transform:translateY(-50%);}
.pos-arrow-t{left:50%;top:1%;transform:translateX(-50%);}
.pos-arrow-b{left:50%;bottom:1%;transform:translateX(-50%);}
/* 軸ラベル */
.pos-axis-label{
  position:absolute;font-size:12px;letter-spacing:.04em;
  white-space:nowrap;
}
.pos-axis-label.top{
  top:2%;left:50%;transform:translateX(-50%);
  color:var(--navy);font-weight:600;font-size:13px;
}
.pos-axis-label.bottom{
  bottom:2%;left:50%;transform:translateX(-50%);
  color:var(--ink-3);font-size:12px;
}
.pos-axis-label.left{
  left:1.5%;top:50%;transform:translateY(-50%) rotate(-90deg);
  color:var(--ink-3);font-size:12px;
}
.pos-axis-label.right{
  right:1.5%;top:50%;transform:translateY(-50%) rotate(90deg);
  color:var(--navy);font-weight:600;font-size:13px;
}
/* Blue Ocean ラベル */
.pos-blue-ocean{
  position:absolute;top:6%;right:3%;
  font-size:11px;color:var(--accent);
  background:var(--accent-light);padding:4px 12px;
  border-radius:2px;letter-spacing:.06em;font-weight:600;
}
/* マーカー */
.pos-marker{
  position:absolute;transform:translate(-50%,-50%);
  display:flex;flex-direction:column;align-items:center;
  gap:4px;cursor:default;z-index:2;
}
.pos-marker:hover .pos-tooltip{display:block;}
/* JBiz: 星アイコン */
.pos-marker-jbiz .pos-dot{
  width:44px;height:44px;border-radius:50%;
  background:var(--gold);
  display:flex;align-items:center;justify-content:center;
  font-size:20px;
  box-shadow:0 0 0 6px rgba(184,151,42,0.2),0 4px 16px rgba(184,151,42,0.4);
}
.pos-marker-jbiz .pos-name{
  font-size:11px;font-weight:700;color:var(--gold);
  background:var(--navy);padding:2px 8px;border-radius:2px;
  white-space:nowrap;
}
/* 競合: 統一サイズ丸アイコン */
.pos-marker-comp .pos-dot{
  width:32px;height:32px;border-radius:50%;
  background:rgba(120,130,160,0.2);
  border:1.5px solid rgba(120,130,160,0.5);
  display:flex;align-items:center;justify-content:center;
  font-size:11px;font-weight:600;color:rgba(60,70,100,0.8);
}
.pos-marker-comp .pos-name{
  font-size:10px;color:var(--ink-2);
  white-space:nowrap;text-align:center;
  background:rgba(255,255,255,0.9);
  padding:1px 5px;border-radius:2px;
  line-height:1.35;
}
/* ツールチップ */
.pos-tooltip{
  display:none;position:absolute;bottom:calc(100% + 8px);left:50%;
  transform:translateX(-50%);
  background:var(--navy);color:#fff;
  font-size:11px;padding:6px 12px;border-radius:3px;
  white-space:nowrap;z-index:10;
  box-shadow:0 4px 12px rgba(0,0,0,0.2);
}
.pos-tooltip::after{
  content:'';position:absolute;top:100%;left:50%;
  transform:translateX(-50%);
  border:5px solid transparent;
  border-top-color:var(--navy);
}
/* 凡例 */
.pos-legend{
  display:flex;gap:24px;justify-content:center;
  margin-top:20px;flex-wrap:wrap;
}
.pos-legend-item{
  display:flex;align-items:center;gap:8px;
  font-size:12px;color:var(--ink-2);
}
.pos-legend-dot{
  width:14px;height:14px;border-radius:50%;flex-shrink:0;
}

.posm{display:none;}

/* ── COMPARISON ── */
.comp-section{padding:96px 80px;background:var(--off-white);}
.comp-table{width:100%;border-collapse:collapse;margin-top:52px;font-size:13px;}
.comp-table th,.comp-table td{padding:14px 16px;border:1px solid var(--border);vertical-align:middle;}
.comp-table thead th{
  background:var(--navy);color:#fff;
  font-weight:500;letter-spacing:.04em;text-align:center;
}
.comp-table thead th.jbiz-col{background:var(--gold);}
.comp-table tbody tr:nth-child(even){background:var(--light-gray);}
.comp-table tbody tr:hover{background:var(--accent-light);}
.comp-table td.item-col{
  font-weight:500;color:var(--navy);
  background:var(--light-gray)!important;
  font-size:12px;
}
.comp-table td.jbiz-col{
  background:var(--gold-pale)!important;
  font-weight:500;text-align:center;
}
.rating-good{color:#22a06b;font-size:16px;}
.rating-mid{color:#f59e0b;font-size:16px;}
.rating-bad{color:#ef4444;font-size:16px;}
.rating-note{font-size:11px;color:var(--ink-3);display:block;margin-top:3px;line-height:1.5;}

/* 比較表 調整（2026-06-22）: 自社強調／他社中央ぞろえ／説明文を濃く */
.comp-table tbody td{text-align:center;}
.comp-table td.item-col{text-align:left;}
.rating-note{color:var(--ink);font-size:11.5px;}
.comp-table td.jbiz-col{font-weight:600;font-size:14px;}
.comp-table td.jbiz-col .rating-good,
.comp-table td.jbiz-col .rating-mid,
.comp-table td.jbiz-col .rating-bad{font-size:22px;}
.comp-table td.jbiz-col .rating-note{color:var(--navy);font-size:12.5px;font-weight:500;}

/* ── TEAM ── */
.team-section{padding:100px 80px;background:var(--white);}
.team-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px;margin-top:52px;}
.team-card{border:1px solid var(--border);overflow:hidden;transition:all .25s;}
.team-card:hover{box-shadow:0 16px 48px rgba(0,0,0,.08);transform:translateY(-3px);}
.team-photo{width:100%;aspect-ratio:1;overflow:hidden;background:var(--light-gray);}
.team-photo img{width:100%;height:100%;object-fit:cover;object-position:center top;}
.team-photo-ph{width:100%;height:100%;display:flex;align-items:center;justify-content:center;background:var(--light-gray);font-family:'Cormorant Garamond',serif;font-size:32px;color:var(--ink-3);}
.team-body{padding:28px 26px;}
.team-name{font-family:'Cormorant Garamond',serif;font-size:24px;font-weight:400;color:var(--navy);margin-bottom:2px;}
.team-name-en{font-size:11px;letter-spacing:.1em;color:var(--gold);margin-bottom:14px;}
.team-role{font-size:11px;letter-spacing:.04em;color:var(--ink-3);margin-bottom:14px;padding-bottom:14px;border-bottom:1px solid var(--border);}
.team-bio{font-size:12px;color:var(--ink-2);line-height:1.85;}

/* ── ACADEMY (教育プログラム) ── */
.academy-section{padding:96px 80px;background:var(--off-white);}
.academy-grid{display:grid;grid-template-columns:1fr 1fr;gap:24px;margin-top:52px;}
.academy-card{
  padding:44px 40px;background:#fff;border:1px solid var(--border);border-radius:8px;
  text-decoration:none;display:block;transition:all .25s;
}
.academy-card:hover{border-color:var(--gold-light);box-shadow:0 14px 40px rgba(22,34,63,.10);transform:translateY(-3px);}
.academy-cat{
  font-size:10px;letter-spacing:.18em;color:var(--gold);
  margin-bottom:12px;font-weight:500;
}
.academy-title{
  font-family:'Cormorant Garamond',serif;font-size:28px;
  font-weight:300;color:var(--navy);margin-bottom:10px;line-height:1.2;
}
.academy-body{font-size:13px;color:var(--ink-2);line-height:1.85;margin-bottom:20px;}
.academy-link{
  display:inline-flex;align-items:center;gap:6px;
  font-size:12px;letter-spacing:.08em;color:var(--gold);
  border-bottom:1px solid rgba(184,151,42,.3);padding-bottom:2px;
}

/* ── CTA ── */
.cta-section{
  padding:96px 80px;
  background:linear-gradient(160deg,#ffffff 0%,#eaf0fb 100%);
  text-align:center;
}
.cta-title{
  font-family:'Cormorant Garamond',serif;font-size:48px;
  font-weight:300;color:var(--navy);margin-bottom:14px;line-height:1.2;
}
.cta-sub{font-size:14px;color:var(--ink-2);margin-bottom:44px;line-height:1.8;}
.cta-btn{
  display:inline-block;padding:18px 60px;
  background:#2b5ce6;color:#fff;text-decoration:none;
  font-size:13px;letter-spacing:.15em;transition:background .2s;
}
.cta-btn:hover{background:#1a4ad4;}

/* ── FOOTER ── */
footer{background:#0e1628;padding:52px 80px 28px;}
.ft-top{
  display:grid;grid-template-columns:2fr 1fr 1fr 1fr;gap:48px;
  margin-bottom:40px;padding-bottom:36px;border-bottom:1px solid rgba(255,255,255,.07);
}
.ft-logo{
  font-family:'Cormorant Garamond',serif;font-size:20px;
  color:rgba(255,255,255,.7);font-weight:300;margin-bottom:8px;
}
.ft-tag{font-size:11px;color:rgba(255,255,255,.3);line-height:1.7;margin-bottom:14px;}
.ft-company{font-size:11px;color:rgba(255,255,255,.2);line-height:1.9;}
.ft-col-title{font-size:11px;letter-spacing:.12em;color:rgba(255,255,255,.3);margin-bottom:14px;font-weight:500;}
.ft-links{list-style:none;display:flex;flex-direction:column;gap:8px;}
.ft-links a{font-size:12px;color:rgba(255,255,255,.4);text-decoration:none;transition:color .2s;}
.ft-links a:hover{color:var(--gold);}
.ft-bottom{display:flex;align-items:center;justify-content:space-between;}
.ft-copy{font-size:11px;color:rgba(255,255,255,.18);}

/* ── HERO VISUAL ── */
.hero-right{background:linear-gradient(135deg,#f0f4ff 0%,#e8f0fb 100%);
  display:flex;align-items:center;justify-content:center;padding:40px;}
.hero-visual{position:relative;width:100%;max-width:480px;display:flex;
  flex-direction:column;align-items:center;gap:24px;}
.hero-globe-svg{width:100%;max-width:440px;height:auto;filter:drop-shadow(0 20px 60px rgba(26,58,92,0.2));}
.hero-visual-badge{background:rgba(255,255,255,0.95);padding:16px 28px;
  border-left:3px solid var(--gold);backdrop-filter:blur(8px);
  box-shadow:0 4px 24px rgba(0,0,0,0.08);width:100%;}
.hero-visual-badge-title{font-size:13px;font-weight:600;color:var(--navy);margin-bottom:4px;letter-spacing:.04em;}
.hero-visual-badge-sub{font-size:11px;color:var(--ink-3);}


/* ===== PROBLEM × SOLUTION : ビザスク風マトリクス ===== */
.problem-section .sec-head{text-align:left;}
.problem-section .sec-label{display:inline-block;font-size:11px;letter-spacing:.22em;color:var(--gold);font-weight:600;margin-bottom:20px;}
.problem-section .sec-title{font-size:clamp(23px,2.9vw,34px);font-weight:700;color:var(--navy);line-height:1.55;letter-spacing:.02em;}
.problem-section .sec-title .u{display:inline-block;border-bottom:4px solid #2b5ce6;padding-bottom:3px;line-height:1;}

.pm-scroll{margin-top:56px;overflow-x:auto;-webkit-overflow-scrolling:touch;}
.pm-grid{display:grid;grid-template-columns:128px repeat(5,1fr);min-width:980px;}
.pm-grid>div{display:flex;}

/* row1: アイコン＋カテゴリ */
.pm-h{flex-direction:column;align-items:center;justify-content:flex-end;text-align:center;padding:6px 10px 22px;}
.pm-h svg{width:48px;height:48px;margin-bottom:14px;}
.pm-h-title{font-size:14.5px;font-weight:600;color:var(--navy);line-height:1.45;letter-spacing:.01em;}

/* row2: 悩み帯（グレー） */
.pm-p{background:#f4f5f7;align-items:center;justify-content:center;text-align:center;padding:30px 16px;font-size:13.5px;color:var(--ink-2);line-height:1.75;}

/* 左ラベル（行2・行4共通の枠） */
.pm-lab{flex-direction:column;align-items:stretch;padding:14px 12px;}
.pm-lab .box{flex:1;display:flex;align-items:center;justify-content:center;text-align:center;border-radius:4px;font-size:13px;font-weight:600;color:#fff;line-height:1.55;padding:12px 4px;}
.pm-lab.gray{background:#f4f5f7;}
.pm-lab.gray .box{background:#8a8f99;}
.pm-lab.blue{background:#e9f1fe;}
.pm-lab.blue .box{background:#2b5ce6;}

/* row3: 点線矢印 */
.pm-a{align-items:center;justify-content:center;padding:14px 0;background:#fff;}

/* row4: 解決帯（ブルー）＋白カード */
.pm-s{flex-direction:column;align-items:stretch;justify-content:center;background:#e9f1fe;padding:20px 12px;}
.pm-s .card{flex:1;display:flex;align-items:center;justify-content:center;text-align:center;background:#fff;border-radius:6px;padding:22px 16px;font-size:13.5px;font-weight:500;color:var(--navy);line-height:1.75;box-shadow:0 2px 12px rgba(22,34,63,.06);}


/* ===================== RESPONSIVE（全体） ===================== */
@media (max-width:1024px){
  nav{padding:0 28px;}
  .nav-links{gap:20px;}
  .hero-inner{padding:48px 40px;gap:48px;}
  .problem-section,.flow-section,.voice-section,.position-section,
  .comp-section,.team-section,.academy-section,.cta-section{padding-left:40px;padding-right:40px;}
  footer{padding-left:40px;padding-right:40px;}
  .team-grid{gap:18px;}
}
@media (max-width:860px){
  .hero{padding-top:60px;min-height:auto;}
  .hero-inner{grid-template-columns:1fr;gap:40px;padding:48px 28px;text-align:center;}
  .hero-left-new{align-items:center;}
  .hero-eyebrow-new{justify-content:center;}
  .hero-subtitle-new{border-left:none;border-top:3px solid var(--gold);padding-left:0;padding-top:14px;text-align:left;}
  .hero-cta-row-new{flex-direction:column;align-items:stretch;width:100%;max-width:340px;margin:0 auto;}
  .hero-btn-new,.hero-btn-ghost-new{justify-content:center;}
  .globe-wrap{width:min(320px,72vw);height:min(320px,72vw);}
  .globe-svg{width:80%;height:80%;}
  .globe-bg-ring{inset:-12px;}
  .globe-bg-ring2{inset:-30px;}
  .badge-top{top:0;right:auto;left:0;}
  .badge-mid{bottom:54px;right:-6px;}
  .badge-bot{bottom:0;left:0;}
  .voice-grid{grid-template-columns:repeat(2,1fr);}
  .team-grid{grid-template-columns:repeat(2,1fr);}
}
@media (max-width:768px){
  nav{padding:0 18px;height:60px;}
  .nav-toggle{display:flex;}
  .nav-links{
    display:block;
    position:absolute;top:60px;left:0;right:0;
    background:rgba(255,255,255,0.98);backdrop-filter:blur(8px);
    border-bottom:1px solid var(--border);box-shadow:0 10px 24px rgba(0,0,0,.07);
    max-height:0;overflow:hidden;transition:max-height .35s ease;
  }
  nav.nav-open .nav-links{max-height:80vh;}
  .nav-links li{display:block;}
  .nav-links li a{display:block;padding:15px 22px;border-top:1px solid var(--border);font-size:14px;}
  .nav-links li:first-child a{border-top:none;}
  .nav-links li .nav-cta{display:block;margin:12px 22px;border-top:none;text-align:center;border-radius:4px;}
  .problem-section,.flow-section,.voice-section,.position-section,
  .comp-section,.team-section,.academy-section,.cta-section{
    padding-top:60px;padding-bottom:60px;padding-left:18px;padding-right:18px;}
  footer{padding:44px 18px 26px;}
  .pm-scroll{margin-top:40px;}
  .comp-table-wrap{overflow-x:auto;-webkit-overflow-scrolling:touch;margin-top:40px;}
  .comp-table{min-width:680px;margin-top:0;}
  /* POSITIONING v2: モバイルは原寸のまま横スクロール（配置は原本のまま・重なり回避） */
  .pos-scroll{display:none;}
  .posm{display:block;margin-top:34px;}
  .posm-axis{text-align:center;font-size:11.5px;font-weight:600;color:var(--navy);letter-spacing:.03em;margin:0 0 10px;}
  .posm-axis.bot{color:var(--ink-3);font-weight:500;margin:10px 0 0;font-size:10.5px;}
  .posm-grid{display:grid;grid-template-columns:1fr 1fr;gap:8px;}
  .posm-q{background:var(--off-white);border:1px solid var(--border);border-radius:8px;padding:12px 12px 13px;}
  .posm-q-head{font-size:10px;font-weight:600;color:var(--ink-3);letter-spacing:.02em;margin-bottom:8px;padding-bottom:6px;border-bottom:1px dashed var(--border);line-height:1.3;}
  .posm-q ul{list-style:none;margin:0;padding:0;}
  .posm-q li{font-size:12px;color:var(--ink-2);line-height:1.45;padding:3.5px 0;}
  .posm-q.jbiz{background:var(--gold-pale);border-color:var(--gold);}
  .posm-q.jbiz .posm-q-head{color:var(--gold);border-bottom-color:rgba(184,151,42,.4);}
  .posm-q.jbiz li{color:var(--navy);font-weight:700;font-size:13px;}
  .team-grid{grid-template-columns:1fr;}
  .academy-grid{grid-template-columns:1fr;}
  .cta-section{padding-top:64px;padding-bottom:64px;}
  .cta-title{font-size:clamp(28px,7vw,40px);}
  .ft-top{grid-template-columns:1fr 1fr;gap:28px 22px;}
  .ft-top>div:first-child{grid-column:1 / -1;}
  .ft-bottom{flex-direction:column;gap:10px;text-align:center;}
  /* FLOW モバイル（旧FLOW専用@mediaを統合） */
  .flow-steps{margin-top:36px;}
  .flow-step{gap:15px;padding-bottom:26px;}
  .flow-step::before{left:21px;top:44px;}
  .flow-marker{width:44px;}
  .flow-num{width:44px;height:44px;font-size:19px;box-shadow:0 0 0 4px var(--white);}
  .flow-content{padding:15px 16px;border-radius:7px;}
  .flow-content-head{gap:8px;margin-bottom:6px;}
  .flow-step-title{font-size:15px;line-height:1.45;}
  .flow-step-body{font-size:12.5px;line-height:1.8;}
  .flow-step-time{font-size:10.5px;padding:3px 10px;}
}
@media (max-width:430px){
  .hero-title-new{font-size:clamp(30px,9vw,40px);}
  .globe-badge{padding:8px 12px;}
  .globe-badge-text{font-size:10px;}
  .team-grid{grid-template-columns:1fr;}
  .voice-grid{grid-template-columns:1fr;}
  .ft-top{grid-template-columns:1fr;}
}

/* ===== HERO 動画背景（FV動画化） ===== */
.hero.hero-has-video{position:relative;min-height:100vh;padding-top:68px;display:flex;align-items:center;justify-content:flex-start;overflow:hidden;background:#0a1224;}
.hero-video{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;z-index:0;}
.hero-video-overlay{position:absolute;inset:0;z-index:1;background:linear-gradient(90deg,rgba(8,16,33,.88) 0%,rgba(8,16,33,.62) 38%,rgba(8,16,33,.28) 70%,rgba(8,16,33,.5) 100%),linear-gradient(0deg,rgba(8,16,33,.55) 0%,transparent 42%);}
.hero-video-content{position:relative;z-index:2;max-width:1200px;width:100%;margin:0 auto;padding:60px 80px;}
.hero-has-video .hero-title-new{color:#fff;text-shadow:0 2px 24px rgba(0,0,0,.25);}
.hero-has-video .hero-title-new b{color:var(--gold-light);font-weight:400;}
.hero-has-video .hero-subtitle-new{color:rgba(255,255,255,.88);border-left-color:var(--gold);}
.hero-has-video .hero-btn-ghost-new{border-color:rgba(255,255,255,.55);color:#fff;}
.hero-has-video .hero-btn-ghost-new:hover{border-color:#fff;color:#fff;background:rgba(255,255,255,.12);}
@media (max-width:768px){
  .hero-video-content{padding:40px 22px;}
  .hero.hero-has-video{min-height:86vh;}
}

/* ===== HERO テキスト アニメーション（動画に合わせてフェードアップ） ===== */
@keyframes jbizHeroRise{from{opacity:0;transform:translateY(28px);}to{opacity:1;transform:translateY(0);}}
.hero-has-video .hero-eyebrow-new,
.hero-has-video .hero-title-new,
.hero-has-video .hero-subtitle-new{opacity:0;animation:jbizHeroRise .95s cubic-bezier(.22,.61,.36,1) forwards;}
.hero-has-video .hero-eyebrow-new{animation-delay:.35s;}
.hero-has-video .hero-title-new{animation-delay:.7s;}
.hero-has-video .hero-subtitle-new{animation-delay:1.15s;}
@media (prefers-reduced-motion: reduce){
  .hero-has-video .hero-eyebrow-new,.hero-has-video .hero-title-new,.hero-has-video .hero-subtitle-new{opacity:1;animation:none;}
}

/* 日本語の改行最適化（文節単位・auto-phrase） */
.pm-p,.pm-s .card{word-break:auto-phrase;}

/* PROBLEM アイコン（CMS化・currentColor／独自画像） */
.pm-h svg{color:var(--navy);}
.pm-h-img{width:46px;height:46px;object-fit:contain;margin-bottom:14px;}
.pm-h-title{word-break:auto-phrase;}

/* ===== FLOW フィルタータブ ===== */
.flow-tabs{display:flex;justify-content:center;gap:10px;flex-wrap:wrap;margin-top:6px;}
.flow-tab{border:1px solid var(--border);background:#fff;color:var(--ink-2);font-size:13px;letter-spacing:.02em;padding:9px 24px;border-radius:30px;cursor:pointer;transition:all .2s;font-family:inherit;}
.flow-tab:hover{border-color:var(--accent);color:var(--accent);}
.flow-tab.is-active{background:var(--navy);border-color:var(--navy);color:#fff;}
.flow-step.is-hidden{display:none;}
.flow-step.is-lastvis::before{display:none;}

/* FLOW ユースケース（タブ連動） */
.flow-usecase{max-width:760px;margin:26px auto 0;background:var(--off-white);border:1px solid var(--border);border-left:4px solid var(--accent);border-radius:8px;padding:20px 26px;}
.flow-usecase.is-hidden{display:none;}
.fu-label{font-size:13px;font-weight:600;color:var(--accent);letter-spacing:.02em;margin-bottom:6px;}
.fu-target{font-size:12px;color:var(--ink-3);margin-bottom:9px;}
.fu-body{font-size:13.5px;color:var(--ink-2);line-height:1.85;word-break:auto-phrase;}

/* PROBLEM 解決カードのボタン */
.pm-s{gap:12px;}
.pm-s-btnwrap{min-height:46px;display:flex;align-items:center;justify-content:center;flex-shrink:0;}
.pm-btn{display:inline-flex;align-items:center;justify-content:center;gap:7px;align-self:center;padding:11px 26px;border-radius:10px;font-size:13px;font-weight:700;letter-spacing:.05em;color:#fff;text-decoration:none;white-space:nowrap;transition:transform .25s,filter .25s,box-shadow .25s;}
.pm-btn:hover{transform:translateY(-2px);filter:brightness(1.07);}
.pm-btn .pm-btn-arrow{transition:transform .25s;font-weight:600;}
.pm-btn:hover .pm-btn-arrow{transform:translateX(3px);}
.pm-btn.t-small{background:linear-gradient(135deg,#2b5ce6,#1a4ad4);box-shadow:0 7px 18px rgba(43,92,230,.34);}
.pm-btn.t-jbiz{background:linear-gradient(135deg,#13a890,#0f7a6b);box-shadow:0 7px 18px rgba(15,122,107,.34);}
.pm-btn.t-mid{background:linear-gradient(135deg,#d8b13c,#b8972a);box-shadow:0 7px 18px rgba(184,151,42,.34);}

/* ===== 固定ページ（法的ページ等） ===== */
.legal-page{padding:120px 24px 84px;background:var(--white);}
.legal-inner{max-width:820px;margin:0 auto;}
.legal-eyebrow{font-size:11px;letter-spacing:.2em;color:var(--gold);font-weight:600;margin-bottom:14px;}
.legal-title{font-size:clamp(23px,3vw,32px);font-weight:700;color:var(--navy);line-height:1.5;margin-bottom:34px;padding-bottom:20px;border-bottom:2px solid var(--border);}
.legal-body{font-size:14.5px;line-height:1.95;color:var(--ink-2);word-break:auto-phrase;}
.legal-body h2{font-size:16px;font-weight:600;color:var(--navy);margin:34px 0 10px;}
.legal-body p{margin-bottom:16px;}
.legal-body a{color:var(--accent);}
.legal-table{width:100%;border-collapse:collapse;margin-top:8px;}
.legal-table th,.legal-table td{border:1px solid var(--border);padding:14px 16px;text-align:left;vertical-align:top;font-size:13.5px;line-height:1.85;}
.legal-table th{background:var(--off-white);color:var(--navy);font-weight:600;width:32%;}
@media(max-width:600px){
  .legal-page{padding:96px 18px 60px;}
  .legal-table tr{display:block;border:1px solid var(--border);margin-bottom:10px;}
  .legal-table th,.legal-table td{display:block;width:auto;border:none;}
  .legal-table th{background:var(--off-white);padding-bottom:6px;}
  .legal-table td{padding-top:4px;}
}


/* ===== お問い合わせフォーム（Contact Form 7） ===== */
.legal-body .wpcf7{margin-top:10px;}
.legal-body .wpcf7 label{display:block;font-weight:600;color:var(--navy);font-size:14px;margin:20px 0 0;}
.legal-body .wpcf7-form-control-wrap{display:block;margin-top:7px;}
.legal-body .wpcf7-form-control:not(.wpcf7-submit){width:100%;padding:12px 14px;border:1px solid var(--border);border-radius:6px;font-size:15px;font-family:inherit;background:#fff;color:var(--ink);box-sizing:border-box;transition:border-color .2s,box-shadow .2s;}
.legal-body .wpcf7-form-control:not(.wpcf7-submit):focus{outline:none;border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-light);}
.legal-body textarea.wpcf7-form-control{min-height:160px;resize:vertical;}
.legal-body .wpcf7-submit{display:block;margin:32px auto 0;background:var(--accent);color:#fff;border:none;padding:15px 56px;font-size:15px;font-weight:700;letter-spacing:.06em;border-radius:8px;cursor:pointer;transition:background .2s,transform .2s;font-family:inherit;}
.legal-body .wpcf7-submit:hover{background:#1a4ad4;transform:translateY(-2px);}
.legal-body .wpcf7-not-valid-tip{color:#d63638;font-size:12.5px;margin-top:5px;}
.legal-body .wpcf7-response-output{margin:22px 0 0!important;padding:14px 18px!important;border-radius:6px;font-size:14px;line-height:1.7;}
.legal-body .wpcf7-spinner{margin:0 auto;display:block;}