/* ============ ガンバルNINJA — styles ============ */
/* 日本寄りパステル × ニンジャ墨 × ポップなネオ・ブルータル */

@import url('https://fonts.googleapis.com/css2?family=Bricolage+Grotesque:opsz,wght@12..96,700;12..96,800&family=Zen+Kaku+Gothic+New:wght@400;500;700;900&family=Zen+Maru+Gothic:wght@400;500;700;800;900&display=swap');

:root {
  /* ===== Refined 3-tone palette =====
     Primary  : 墨 ink
     Accent   : 朱 vermillion (brand red)
     Base     : 生成り paper
     Supports : 浅葱 (soft teal) — only for visual breaks
  */
  --shu:       #e94a35;   /* 朱 / vermillion (primary accent — from logo) */
  --shu-2:     #fff0ec;   /* 朱 (薄) */
  --asagi:     #4a90a4;   /* 浅葱 - refined to slate-teal */
  --asagi-2:   #e5eef1;   /* 浅葱 (薄) */
  --sumi:      #1f1d2e;   /* 墨 */
  --sumi-2:    #5a546b;

  --paper:     #fff9ef;   /* 生成り */
  --cream:     #fff4dc;

  /* legacy aliases — kept so older rules keep working, mapped onto the refined palette */
  --sakura:    var(--shu-2);
  --sakura-2:  #fff5f0;
  --matcha:    #cfe1bc;
  --matcha-2:  #eef3e6;
  --yamabuki:  #f7d97e;
  --yamabuki-2:#fdf2cd;
  --fuji:      #d4c8e8;
  --fuji-2:    #efeaf6;
  --kohaku:    var(--shu);
  --ink:       var(--sumi);
  --ink-2:     var(--sumi-2);
  --line:      var(--sumi);
  --shuriken:  var(--sumi);

  --radius:    20px;
  --radius-lg: 30px;
  --shadow:    4px 4px 0 var(--sumi);
  --shadow-lg: 6px 6px 0 var(--sumi);
}

* { box-sizing: border-box; }
html, body { margin: 0; padding: 0; }
body {
  font-family: 'Zen Kaku Gothic New', 'Plus Jakarta Sans', system-ui, sans-serif;
  font-weight: 500;
  color: var(--ink);
  background: var(--paper);
  -webkit-font-smoothing: antialiased;
  line-height: 1.65;
  overflow-x: hidden;
}
a { color: inherit; text-decoration: none; }
button { font: inherit; cursor: pointer; border: 0; background: transparent; color: inherit; }
img, svg { display: block; max-width: 100%; }

.jp-display {
  font-family: 'Zen Maru Gothic', 'Zen Kaku Gothic New', system-ui, sans-serif;
  font-weight: 900;
  letter-spacing: 0.02em;
  line-height: 1.1;
}
.en-display {
  font-family: 'Bricolage Grotesque', 'Zen Maru Gothic', system-ui, sans-serif;
  font-weight: 800;
  letter-spacing: -0.02em;
}

.container { max-width: 1200px; margin: 0 auto; padding: 0 28px; }

/* ===================== BACKGROUND TEXTURE ===================== */
body::before {
  content: '';
  position: fixed; inset: 0;
  background-image:
    radial-gradient(circle at 1px 1px, rgba(31,29,46,.06) 1px, transparent 0);
  background-size: 22px 22px;
  pointer-events: none; z-index: 0;
}
main, header, footer, section { position: relative; z-index: 1; }

/* ===================== NAV ===================== */
.nav {
  position: sticky; top: 0; z-index: 50;
  background: var(--paper);
  border-bottom: 3px solid var(--ink);
}
.nav-inner {
  display: flex; align-items: center; justify-content: space-between;
  height: 78px; gap: 16px;
}
.brand {
  display: flex; align-items: center; gap: 12px;
}
.brand-mark {
  width: 56px; height: 56px;
  border-radius: 50%;
  background: transparent;
  border: 2.5px solid var(--ink);
  display: grid; place-items: center;
  box-shadow: 3px 3px 0 var(--ink);
  overflow: hidden;
  flex-shrink: 0;
}
.brand-mark img {
  width: 100%; height: 100%; object-fit: cover; object-position: center;
}
.brand-name {
  font-family: 'Zen Maru Gothic', sans-serif;
  font-weight: 900; font-size: 22px;
  letter-spacing: 0.02em;
  line-height: 1;
}
.brand-name small {
  display: block; font-size: 11px; font-weight: 700;
  letter-spacing: 0.18em; color: var(--ink-2); margin-top: 4px;
}
.nav-links { display: flex; gap: 12px; font-weight: 700; font-size: 12.5px; white-space: nowrap; }
.nav-links a { position: relative; padding: 6px 2px; color: var(--ink) !important; }
.nav-links a:hover { color: var(--kohaku); }
.nav-links a::after {
  content: ''; position: absolute; left: 0; right: 0; bottom: -2px;
  height: 3px; background: var(--yamabuki); border-radius: 2px;
  transform: scaleX(0); transform-origin: left; transition: transform .2s ease;
}
.nav-links a:hover::after { transform: scaleX(1); }
.nav-cta { display: flex; align-items: center; gap: 12px; }

/* ===================== BUTTONS ===================== */
.btn {
  display: inline-flex; align-items: center; gap: 10px;
  padding: 13px 22px;
  border-radius: 999px;
  font-weight: 800;
  border: 2.5px solid var(--ink);
  background: white;
  transition: transform .1s ease, box-shadow .1s ease;
  box-shadow: 3px 3px 0 var(--ink);
  white-space: nowrap;
  font-size: 14px;
  font-family: 'Zen Maru Gothic', sans-serif;
}
.btn:hover { transform: translate(-2px,-2px); box-shadow: 5px 5px 0 var(--ink); color: inherit; }
.btn:active { transform: translate(2px,2px); box-shadow: 1px 1px 0 var(--ink); }
.btn-primary { background: var(--sakura); color: var(--ink); }
.btn-ink {
  background: var(--ink);
  color: var(--paper);
  border-color: rgba(255,255,255,0.12);
  box-shadow: 3px 3px 0 rgba(0,0,0,0.75);
}
.btn-ink.btn-lg { box-shadow: 5px 5px 0 rgba(0,0,0,0.75); }
.btn-ink:hover { background: #2e2c42; color: var(--paper); box-shadow: 5px 5px 0 rgba(0,0,0,0.75); }
.btn-ink.btn-lg:hover { box-shadow: 7px 7px 0 rgba(0,0,0,0.75); }
.btn-yamabuki { background: var(--yamabuki); color: var(--ink); }
.btn-yamabuki:hover { color: var(--ink); }
.btn-matcha { background: var(--matcha); color: var(--ink); }
.btn-fb { background: #1877F2; color: white; }
.btn-lg { padding: 18px 32px; font-size: 17px; box-shadow: 5px 5px 0 var(--ink); }
.btn-lg:hover { box-shadow: 7px 7px 0 var(--ink); }

/* ===================== HERO ===================== */
.hero {
  padding: 56px 0 100px;
  overflow: hidden;
  background:
    radial-gradient(ellipse at top right, var(--sakura-2) 0%, transparent 55%),
    radial-gradient(ellipse at bottom left, var(--asagi-2) 0%, transparent 55%);
}
.hero-grid {
  display: grid;
  grid-template-columns: 1.5fr 1fr;
  gap: 40px;
  align-items: center;
}
.eyebrow {
  display: inline-flex; align-items: center; gap: 8px;
  background: white; padding: 8px 16px; border-radius: 999px;
  border: 2.5px solid var(--ink);
  font-weight: 800; font-size: 13px;
  box-shadow: 3px 3px 0 var(--ink);
  font-family: 'Zen Maru Gothic', sans-serif;
}
.eyebrow .dot { width: 9px; height: 9px; border-radius: 50%; background: var(--matcha); border: 1.5px solid var(--ink); animation: blink 1.8s infinite; }
@keyframes blink { 50% { opacity: .35; } }

.hero h1 {
  font-family: 'Zen Maru Gothic', sans-serif;
  font-weight: 900;
  font-size: clamp(26px, 3.2vw, 44px);
  line-height: 1.18;
  letter-spacing: 0.01em;
  margin: 20px 0 0;
}
.hero h1 .high {
  display: inline-block;
  background: var(--yamabuki);
  padding: 4px 18px 6px;
  border-radius: 12px;
  border: 2.5px solid var(--ink);
  transform: rotate(-1.5deg);
  box-shadow: 4px 4px 0 var(--ink);
  margin-top: 8px;
  line-height: 1.3;
}
.hero h1 .high.s2 { background: var(--sakura); transform: rotate(2deg); }
.hero h1 .ruby {
  position: relative; display: inline-block;
}
.hero h1 .ruby rt {
  font-size: 0.32em; font-weight: 700; letter-spacing: 0.08em;
  color: var(--ink-2);
}
.hero h1 .underline {
  position: relative; display: inline-block;
}
.hero h1 .underline::after {
  content: ''; position: absolute; left: -2%; right: -2%; bottom: 6px; height: 14px;
  background: var(--matcha); z-index: -1; border-radius: 8px;
  transform: skewX(-6deg);
}
.hero-en {
  margin-top: 18px;
  font-family: 'Bricolage Grotesque', sans-serif;
  font-weight: 700;
  font-size: 22px;
  letter-spacing: -0.01em;
  color: var(--ink-2);
}
.hero p.lead {
  font-size: 16px; max-width: 540px; margin: 16px 0 20px; color: var(--ink-2);
  line-height: 1.7;
}
.hero .cta-row { display: flex; gap: 14px; flex-wrap: wrap; }

.hero-trust {
  display: flex; gap: 28px; margin-top: 44px;
  padding-top: 26px; border-top: 2px dashed var(--ink);
  flex-wrap: wrap;
}
.stat-num {
  font-family: 'Zen Maru Gothic', sans-serif;
  font-weight: 900; font-size: 34px; line-height: 1;
  color: var(--ink);
}
.stat-num .unit { font-size: 18px; margin-left: 4px; }
.stat-lbl { font-size: 12px; color: var(--ink-2); margin-top: 4px; font-weight: 700; }

/* HERO ART */
.hero-art {
  position: relative;
  aspect-ratio: 1/1.05;
}
.hero-art .ring {
  position: absolute; inset: 8%;
  border-radius: 50%;
  background:
    conic-gradient(from 0deg,
      var(--sakura) 0deg 60deg,
      var(--yamabuki) 60deg 120deg,
      var(--matcha) 120deg 180deg,
      var(--asagi) 180deg 240deg,
      var(--fuji) 240deg 300deg,
      var(--kohaku) 300deg 360deg);
  border: 3px solid var(--ink);
  filter: saturate(.9);
  animation: spin 60s linear infinite;
}
@keyframes spin { to { transform: rotate(360deg); } }
.hero-art .ring::after {
  content: ''; position: absolute; inset: 8%;
  background: var(--paper);
  border-radius: 50%;
  border: 3px solid var(--ink);
}
.hero-art .char-main {
  position: absolute; inset: 18%;
  z-index: 3;
}
.hero-art .speech {
  position: absolute; top: 8%; right: -2%;
  background: white; border: 2.5px solid var(--ink);
  padding: 10px 16px; border-radius: 18px;
  font-weight: 800; font-size: 15px;
  box-shadow: 3px 3px 0 var(--ink);
  font-family: 'Zen Maru Gothic', sans-serif;
  z-index: 4;
  transform: rotate(4deg);
}
.hero-art .speech::after {
  content: ''; position: absolute;
  width: 14px; height: 14px; background: white;
  border-right: 2.5px solid var(--ink); border-bottom: 2.5px solid var(--ink);
  bottom: -9px; left: 24px;
  transform: rotate(45deg);
}
.hero-art .badge {
  position: absolute;
  background: var(--ink); color: var(--paper);
  border-radius: 50%;
  display: grid; place-items: center;
  font-family: 'Zen Maru Gothic', sans-serif;
  font-weight: 900;
  text-align: center;
  border: 2.5px solid var(--ink);
  box-shadow: 4px 4px 0 var(--ink);
  z-index: 4;
}
.hero-art .badge.b1 {
  width: 110px; height: 110px;
  bottom: 4%; left: -2%;
  background: var(--sakura); color: var(--ink);
  font-size: 14px; line-height: 1.2;
  animation: wobble-b1 3s ease-in-out infinite;
}
.hero-art .badge.b2 {
  width: 96px; height: 96px;
  top: 24%; left: -6%;
  background: var(--yamabuki); color: var(--ink);
  font-size: 28px;
  animation: wobble-b2 4s ease-in-out infinite -1s;
}
/* b1 と b2 を別々のキーフレームにしないと、アニメーション開始時に
   b2 が -18deg → -12deg へ瞬間ジャンプするバグが発生するため分離 */
@keyframes wobble-b1 {
  0%,100% { transform: rotate(-12deg) translateY(0); }
  50%     { transform: rotate(-8deg)  translateY(-6px); }
}
@keyframes wobble-b2 {
  0%,100% { transform: rotate(-18deg) translateY(0); }
  50%     { transform: rotate(-14deg) translateY(-6px); }
}

/* SHURIKEN decoration */
.shuriken {
  position: absolute;
  width: 60px; height: 60px;
  animation: spin 4s linear infinite;
  z-index: 2;
}
.shuriken.r { animation-duration: 3s; }

/* ===================== MARQUEE ===================== */
.marquee {
  background: var(--ink); color: var(--paper);
  padding: 18px 0; overflow: hidden;
  border-top: 3px solid var(--ink);
  border-bottom: 3px solid var(--ink);
}
.marquee-track {
  display: flex; gap: 40px; white-space: nowrap;
  animation: marquee-scroll 28s linear infinite;
  font-family: 'Zen Maru Gothic', sans-serif;
  font-weight: 900; font-size: 22px;
  align-items: center;
}
.marquee-track span { display: inline-flex; align-items: center; gap: 16px; }
.marquee-track .star {
  display: inline-flex; color: var(--yamabuki);
}
/* "scroll" は CSS Scroll Timeline の予約語と将来衝突する可能性があるため改名 */
@keyframes marquee-scroll {
  from { transform: translateX(0); }
  to   { transform: translateX(-50%); }
}

/* ===================== SECTIONS ===================== */
.section { padding: 110px 0; }
.section-tight { padding: 80px 0; }
.section-head { text-align: center; margin-bottom: 56px; max-width: 720px; margin-left: auto; margin-right: auto; }
.section-tag {
  display: inline-flex; align-items: center; gap: 8px;
  background: var(--ink); color: var(--paper);
  padding: 8px 16px; border-radius: 999px;
  font-weight: 800; font-size: 12px; letter-spacing: 0.18em; text-transform: uppercase;
  font-family: 'Bricolage Grotesque', sans-serif;
}
.section h2 {
  font-family: 'Zen Maru Gothic', sans-serif;
  font-weight: 900;
  font-size: clamp(32px, 4.2vw, 52px);
  letter-spacing: 0.01em;
  line-height: 1.15;
  margin: 20px 0 14px;
}
.section h2 .accent { color: var(--kohaku); }
.section h2 .high {
  background: var(--yamabuki); padding: 0 8px; border-radius: 6px;
  border: 2px solid var(--ink); display: inline-block;
}
.section .sub { color: var(--ink-2); font-size: 17px; }

.bg-paper { background: var(--paper); }
.bg-cream { background: var(--cream); }
.bg-asagi { background: var(--asagi-2); }
.bg-sakura { background: var(--sakura-2); }
.bg-matcha { background: var(--matcha-2); }
.bg-yamabuki { background: var(--yamabuki-2); }
.bg-fuji { background: var(--fuji-2); }

/* ===================== ENTRY CARDS (第2階層) ===================== */
.entries {
  display: grid; grid-template-columns: repeat(3, 1fr); gap: 22px;
}
.entry {
  background: white; border: 2.5px solid var(--ink); border-radius: var(--radius-lg);
  padding: 32px 28px;
  box-shadow: 5px 5px 0 var(--ink);
  display: flex; flex-direction: column; gap: 14px;
  position: relative; overflow: hidden;
  transition: transform .15s ease, box-shadow .15s ease;
  min-height: 240px;
}
.entry:hover { transform: translate(-3px,-3px); box-shadow: 8px 8px 0 var(--ink); }
.entry .e-ico {
  width: 64px; height: 64px; border-radius: 18px;
  display: grid; place-items: center;
  border: 2.5px solid var(--ink);
  box-shadow: 3px 3px 0 var(--ink);
  font-size: 32px;
  align-self: flex-start;
}
.entry h3 {
  font-family: 'Zen Maru Gothic', sans-serif;
  font-weight: 900; font-size: 22px;
  margin: 4px 0 0; line-height: 1.3;
}
.entry .e-en {
  font-family: 'Bricolage Grotesque', sans-serif;
  font-weight: 700; font-size: 13px;
  color: var(--ink-2); letter-spacing: 0.04em;
  text-transform: uppercase;
}
.entry p { font-size: 14px; color: var(--ink-2); margin: 0; }
.entry .e-arrow {
  position: absolute; top: 24px; right: 24px;
  width: 36px; height: 36px; border-radius: 50%;
  background: var(--ink); color: var(--paper);
  display: grid; place-items: center;
  border: 2px solid var(--ink);
  transition: transform .2s ease;
}
.entry:hover .e-arrow { transform: rotate(-45deg); }

.entry.e1 .e-ico { background: var(--matcha); }
.entry.e2 .e-ico { background: var(--asagi); }
.entry.e3 .e-ico { background: var(--sakura); }
.entry.e4 .e-ico { background: var(--yamabuki); }
.entry.e5 .e-ico { background: var(--fuji); }
.entry.e6 .e-ico { background: var(--kohaku); }

/* Featured entries: 2 big ones (海外から来たい / 採用したい企業様) */
.entries-feature {
  display: grid; grid-template-columns: 1fr 1fr; gap: 28px;
  margin-bottom: 28px;
}
.entry-big {
  background: white; border: 3px solid var(--ink); border-radius: var(--radius-lg);
  padding: 40px; box-shadow: 6px 6px 0 var(--ink);
  display: grid; grid-template-columns: 1fr auto; gap: 20px; align-items: center;
  position: relative; overflow: hidden;
  min-height: 240px;
  transition: transform .15s ease, box-shadow .15s ease;
}
.entry-big:hover { transform: translate(-3px,-3px); box-shadow: 9px 9px 0 var(--ink); }
.entry-big.b1 { background: var(--sakura-2); }
.entry-big.b2 { background: var(--asagi-2); }
.entry-big h3 {
  font-family: 'Zen Maru Gothic', sans-serif;
  font-weight: 900; font-size: 28px;
  margin: 10px 0 8px; line-height: 1.25;
}
.entry-big .b-en {
  font-family: 'Bricolage Grotesque', sans-serif;
  font-weight: 800; font-size: 14px;
  letter-spacing: 0.04em;
}
.entry-big p { font-size: 14px; color: var(--ink-2); margin: 0 0 18px; }
.entry-big .b-art {
  width: 220px; height: 220px;
  background: white; border-radius: 50%;
  border: 3px solid var(--ink); box-shadow: 4px 4px 0 var(--ink);
  display: grid; place-items: center;
  overflow: hidden;
  flex-shrink: 0;
}
.entry-big .b-art img {
  width: 100%; height: 100%; object-fit: cover; object-position: center top;
}
.entry-big .b-link {
  display: inline-flex; align-items: center; gap: 8px;
  font-weight: 800; font-size: 15px;
  font-family: 'Zen Maru Gothic', sans-serif;
}
.entry-big .b-link::after {
  content: ''; width: 28px; height: 28px; border-radius: 50%;
  background: var(--ink); color: var(--paper);
  display: inline-grid; place-items: center;
  background-image: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%23fff9ef' stroke-width='3' stroke-linecap='round'><path d='M5 12h14M13 6l6 6-6 6'/></svg>");
  background-repeat: no-repeat; background-position: center; background-size: 14px;
}

/* ===================== JOB CATEGORIES (8業種) — image-on-top card ===================== */
.cats {
  display: grid; grid-template-columns: repeat(4, 1fr); gap: 22px;
}
.cat {
  background: white;
  border: 2.5px solid var(--ink);
  border-radius: 24px;
  box-shadow: 5px 5px 0 var(--ink);
  overflow: hidden;
  display: flex; flex-direction: column;
  cursor: pointer;
  transition: transform .12s ease, box-shadow .12s ease;
  text-decoration: none; color: inherit;
}
.cat:hover { transform: translate(-3px,-3px); box-shadow: 8px 8px 0 var(--ink); }
.cat .cat-photo {
  width: 100%;
  aspect-ratio: 1/1;
  border-bottom: 2.5px solid var(--ink);
  overflow: hidden;
  background: var(--paper);
  position: relative;
}
.cat:nth-child(8n+1) .cat-photo { background: var(--sakura-2); }
.cat:nth-child(8n+2) .cat-photo { background: var(--asagi-2); }
.cat:nth-child(8n+3) .cat-photo { background: var(--matcha-2); }
.cat:nth-child(8n+4) .cat-photo { background: var(--yamabuki-2); }
.cat:nth-child(8n+5) .cat-photo { background: var(--fuji-2); }
.cat:nth-child(8n+6) .cat-photo { background: var(--sakura-2); }
.cat:nth-child(8n+7) .cat-photo { background: var(--asagi-2); }
.cat:nth-child(8n)   .cat-photo { background: var(--matcha-2); }
.cat .cat-photo img {
  width: 100%; height: 100%;
  object-fit: cover; object-position: center top;
  transition: transform .25s ease;
}
.cat:hover .cat-photo img { transform: scale(1.04); }
.cat .cat-body {
  display: grid;
  grid-template-columns: 1fr auto;
  grid-template-rows: auto auto;
  column-gap: 12px;
  row-gap: 0;
  align-items: center;
  padding: 16px 18px;
}
.cat .h4-en  { grid-column: 1; grid-row: 1; }
.cat h4      { grid-column: 1; grid-row: 2; }
.cat .arrow-mini { grid-column: 2; grid-row: 1 / span 2; align-self: center; }
.cat h4 {
  font-family: 'Zen Maru Gothic', sans-serif;
  font-weight: 900; font-size: 19px;
  margin: 0; line-height: 1.2;
}
.cat .h4-en {
  font-family: 'Bricolage Grotesque', sans-serif;
  font-weight: 700; font-size: 11px;
  letter-spacing: 0.1em; color: var(--ink-2);
  text-transform: uppercase;
  margin-bottom: 2px;
}
.cat .arrow-mini {
  width: 30px; height: 30px;
  background: var(--ink); color: var(--paper);
  border: 2px solid var(--ink);
  border-radius: 50%;
  display: grid; place-items: center;
  font-size: 13px; font-weight: 900;
  transition: transform .2s ease;
}
.cat .arrow-mini::before { content: '→'; }
.cat:hover .arrow-mini { transform: rotate(-45deg); }

/* ===================== CHARACTERS TRIO ===================== */
.char-trio {
  display: grid;
  grid-template-columns: 1.25fr 1fr 1fr;
  gap: 22px;
  align-items: stretch;
}
.char-card {
  background: white;
  border: 3px solid var(--ink); border-radius: var(--radius-lg);
  box-shadow: 6px 6px 0 var(--ink);
  padding: 0;
  overflow: hidden;
  display: flex; flex-direction: column;
  position: relative;
  transition: transform .15s ease, box-shadow .15s ease;
}
.char-card:hover { transform: translate(-3px,-3px); box-shadow: 9px 9px 0 var(--ink); }
.char-card.main { background: linear-gradient(160deg, #ffffff 0%, var(--sakura-2) 100%); }
.char-card.sub1 { background: linear-gradient(160deg, #ffffff 0%, var(--asagi-2) 100%); }
.char-card.sub2 { background: linear-gradient(160deg, #ffffff 0%, var(--matcha-2) 100%); }
.char-card .char-tag {
  position: absolute; top: 16px; left: 16px;
  background: var(--ink); color: var(--paper);
  font-family: 'Bricolage Grotesque', sans-serif;
  font-weight: 800; font-size: 11px;
  letter-spacing: 0.16em; padding: 5px 11px;
  border-radius: 999px;
  z-index: 2;
}
.char-card.main .char-tag {
  background: var(--yamabuki); color: var(--ink);
  border: 2px solid var(--ink);
}
.char-card .char-photo {
  width: 100%;
  aspect-ratio: 1/0.95;
  display: grid; place-items: center;
  overflow: hidden;
  border-bottom: 3px solid var(--ink);
  position: relative;
}
.char-card .char-photo img {
  width: 100%; height: 100%; object-fit: contain;
  padding: 8px;
}
.char-card .char-info {
  padding: 22px 26px 26px;
  display: flex; flex-direction: column; gap: 10px;
}
.char-card .char-en {
  font-family: 'Bricolage Grotesque', sans-serif;
  font-weight: 800; font-size: 13px;
  letter-spacing: 0.14em; color: var(--ink-2);
  text-transform: uppercase;
}
.char-card h3 {
  font-family: 'Zen Maru Gothic', sans-serif;
  font-weight: 900; font-size: 28px;
  margin: 0; line-height: 1;
}
.char-card.main h3 { font-size: 32px; }
.char-card .char-meta {
  display: flex; gap: 8px; flex-wrap: wrap; margin-top: 4px;
}
.char-card .meta-pill {
  font-family: 'Zen Maru Gothic', sans-serif;
  font-weight: 800; font-size: 12px;
  padding: 4px 12px;
  border: 2px solid var(--ink); border-radius: 999px;
  background: var(--paper);
  white-space: nowrap;
  line-height: 1.4;
  display: inline-flex; align-items: center;
}
.char-card p {
  margin: 6px 0 0;
  font-size: 14px; color: var(--ink-2); line-height: 1.7;
}

/* ===================== SCENES GALLERY — image-on-top card ===================== */
.scenes {
  display: grid; grid-template-columns: repeat(4, 1fr); gap: 18px;
}
.scene {
  margin: 0;
  background: white;
  border: 2.5px solid var(--ink);
  border-radius: 20px;
  box-shadow: 4px 4px 0 var(--ink);
  overflow: hidden;
  display: flex; flex-direction: column;
  transition: transform .12s ease, box-shadow .12s ease;
}
.scene:hover { transform: translate(-2px,-2px); box-shadow: 6px 6px 0 var(--ink); }
.scene img {
  width: 100%; aspect-ratio: 1/1;
  object-fit: cover; object-position: center top;
  border-bottom: 2.5px solid var(--ink);
  transition: transform .25s ease;
}
.scene:hover img { transform: scale(1.04); }
.scenes > .scene:nth-child(8n+1) { background: var(--sakura-2); }
.scenes > .scene:nth-child(8n+2) { background: var(--asagi-2); }
.scenes > .scene:nth-child(8n+3) { background: var(--matcha-2); }
.scenes > .scene:nth-child(8n+4) { background: var(--fuji-2); }
.scenes > .scene:nth-child(8n+5) { background: var(--yamabuki-2); }
.scenes > .scene:nth-child(8n+6) { background: var(--sakura-2); }
.scenes > .scene:nth-child(8n+7) { background: var(--asagi-2); }
.scenes > .scene:nth-child(8n)   { background: var(--matcha-2); }
.scenes > .scene:nth-child(8n+1) img,
.scenes > .scene:nth-child(8n+2) img,
.scenes > .scene:nth-child(8n+3) img,
.scenes > .scene:nth-child(8n+4) img,
.scenes > .scene:nth-child(8n+5) img,
.scenes > .scene:nth-child(8n+6) img,
.scenes > .scene:nth-child(8n+7) img,
.scenes > .scene:nth-child(8n)   img { background: inherit; }
.scene figcaption {
  padding: 14px 16px 16px;
  display: flex; flex-direction: column; gap: 2px;
  background: white;
}
.scene .sc-jp {
  font-family: 'Zen Maru Gothic', sans-serif;
  font-weight: 900; font-size: 15px;
}
.scene .sc-en {
  font-family: 'Bricolage Grotesque', sans-serif;
  font-weight: 700; font-size: 11px;
  letter-spacing: 0.1em; color: var(--ink-2);
  text-transform: uppercase;
}
.scenes-note {
  margin: 36px auto 0; max-width: 720px;
  text-align: center;
  font-size: 14px; color: var(--ink-2);
  background: white;
  padding: 14px 22px;
  border: 2.5px dashed var(--ink);
  border-radius: 999px;
  display: flex; align-items: center; justify-content: center; gap: 10px;
}
.scenes-note .note-pin { font-size: 18px; }

/* ===================== SYSTEMS (2 cards) ===================== */
.systems {
  display: grid; grid-template-columns: 1fr 1fr; gap: 28px;
}
.system {
  background: white;
  border: 2.5px solid var(--ink);
  border-radius: var(--radius-lg);
  padding: 40px 36px;
  box-shadow: 6px 6px 0 var(--ink);
  position: relative;
  transition: transform .15s ease, box-shadow .15s ease;
}
.system:hover { transform: translate(-3px,-3px); box-shadow: 9px 9px 0 var(--ink); }
.system.s1 { background: var(--sakura-2); }
.system.s2 { background: var(--asagi-2); }
.system .system-num {
  font-family: 'Bricolage Grotesque', sans-serif;
  font-weight: 800; font-size: 12px;
  letter-spacing: 0.16em; color: var(--ink-2);
  text-transform: uppercase;
}
.system h3 {
  font-family: 'Zen Maru Gothic', sans-serif;
  font-weight: 900; font-size: 32px;
  margin: 8px 0 14px; line-height: 1.25;
}
.system p { margin: 0 0 22px; font-size: 15px; color: var(--ink-2); line-height: 1.85; }
.system .more {
  display: inline-flex; align-items: center; gap: 10px;
  font-family: 'Zen Maru Gothic', sans-serif;
  font-weight: 800; font-size: 15px;
  color: var(--ink);
  padding: 10px 18px;
  background: white;
  border: 2px solid var(--ink); border-radius: 999px;
  box-shadow: 2px 2px 0 var(--ink);
}
.system .more:hover { transform: translate(-1px,-1px); box-shadow: 3px 3px 0 var(--ink); }

/* ===================== RESULTS strip (TOP page) ===================== */
.results-strip {
  display: grid; grid-template-columns: repeat(4, 1fr);
  background: white; border: 2.5px solid var(--ink);
  border-radius: var(--radius-lg);
  box-shadow: 5px 5px 0 var(--ink);
  overflow: hidden;
}
.result {
  padding: 32px 26px;
  text-align: center;
  border-right: 2px dashed rgba(31,29,46,.18);
}
.result:last-child { border-right: 0; }
.result .r-num {
  font-family: 'Zen Maru Gothic', sans-serif;
  font-weight: 900; font-size: 44px; line-height: 1;
  color: var(--ink);
}
.result .r-num .unit { font-size: 16px; margin-left: 4px; }
.result .r-lbl { font-size: 13px; font-weight: 700; color: var(--ink-2); margin-top: 8px; }

/* Flag pills (TOP) */
.flag-row {
  margin-top: 32px;
  display: flex; flex-wrap: wrap; gap: 10px; justify-content: center;
}
.flag-pill {
  background: white;
  border: 2px solid var(--ink); border-radius: 999px;
  padding: 8px 16px;
  font-family: 'Zen Maru Gothic', sans-serif;
  font-weight: 800; font-size: 13px;
  box-shadow: 2px 2px 0 var(--ink);
}

/* ===================== FBCTA (TOP page) ===================== */
.fbcta {
  background: var(--ink); color: var(--paper);
  padding: 90px 0 100px;
  border-top: 3px solid var(--ink);
  border-bottom: 3px solid var(--ink);
  position: relative;
  overflow: hidden;
}
.fbcta::before {
  content: ''; position: absolute;
  top: -100px; right: -80px;
  width: 320px; height: 320px;
  background: var(--shu);
  border-radius: 50%;
  opacity: 0.18;
}
.fbcta::after {
  content: ''; position: absolute;
  bottom: -120px; left: -100px;
  width: 380px; height: 380px;
  background: var(--asagi);
  border-radius: 50%;
  opacity: 0.18;
}
.fbcta-inner {
  text-align: center;
  position: relative; z-index: 2;
}
.fbcta-ninja {
  width: 200px; height: 200px;
  background: var(--paper);
  border: 3px solid var(--paper);
  border-radius: 50%;
  margin: 0 auto 24px;
  overflow: hidden;
  box-shadow: 6px 6px 0 rgba(0,0,0,0.4);
}
.fbcta-ninja img {
  width: 100%; height: 100%; object-fit: cover; object-position: center top;
}
.fbcta h2 {
  font-family: 'Zen Maru Gothic', sans-serif;
  font-weight: 900;
  font-size: clamp(34px, 4.4vw, 56px);
  line-height: 1.2;
  margin: 0 0 16px;
}
.fbcta h2 .stamp {
  display: inline-block;
  background: var(--shu);
  color: var(--paper);
  padding: 4px 18px;
  border-radius: 16px;
  transform: rotate(-3deg);
  margin: 0 4px;
}
.fbcta p {
  font-size: 17px; line-height: 1.85;
  margin: 0 auto 32px;
  max-width: 600px;
  opacity: 0.85;
}
.fbcta .cta-row { display: flex; gap: 14px; justify-content: center; flex-wrap: wrap; }
.fbcta .btn { background: var(--paper); color: var(--ink); }
.fbcta .btn-fb { background: #1877F2; color: white; border-color: var(--paper); box-shadow: 4px 4px 0 var(--paper); }
.fbcta .btn-fb:hover { box-shadow: 6px 6px 0 var(--paper); }

/* ===================== FLOATING SNS ===================== */
.fsns {
  position: fixed;
  right: 22px; bottom: 22px;
  z-index: 80;
}
.fsns-toggle {
  width: 84px; height: 84px;
  border-radius: 50%;
  background: var(--shu);
  color: var(--paper);
  border: 3px solid var(--ink);
  box-shadow: 4px 4px 0 var(--ink);
  font-family: 'Zen Maru Gothic', sans-serif;
  font-weight: 900; font-size: 12px;
  display: grid; place-items: center;
  position: relative;
  text-align: center;
  line-height: 1.2;
  cursor: pointer;
  transition: transform .15s ease;
}
.fsns-toggle:hover { transform: scale(1.05); }
.fsns-toggle .badge-dot {
  position: absolute;
  top: -6px; right: -6px;
  width: 26px; height: 26px;
  background: var(--asagi);
  color: var(--paper);
  border-radius: 50%;
  border: 2px solid var(--ink);
  display: grid; place-items: center;
  font-family: 'Bricolage Grotesque', sans-serif;
  font-weight: 800; font-size: 13px;
}
.fsns-panel {
  position: absolute;
  bottom: 100px;
  right: 0;
  width: 290px;
  background: white;
  border: 2.5px solid var(--ink);
  border-radius: 18px;
  box-shadow: 5px 5px 0 var(--ink);
  padding: 20px;
  opacity: 0;
  transform: translateY(8px) scale(0.96);
  pointer-events: none;
  transition: opacity .18s ease, transform .18s ease;
}
.fsns-panel.open { opacity: 1; transform: translateY(0) scale(1); pointer-events: auto; }
.fsns-panel h5 {
  margin: 0 0 14px;
  font-family: 'Zen Maru Gothic', sans-serif;
  font-weight: 900; font-size: 15px;
}
.fsns-list { display: flex; flex-direction: column; gap: 8px; }
.fsns-link {
  display: flex; align-items: center; gap: 12px;
  padding: 10px 14px;
  background: var(--paper);
  border: 2px solid var(--ink);
  border-radius: 999px;
  font-family: 'Zen Maru Gothic', sans-serif;
  font-weight: 800; font-size: 13px;
}
.fsns-link:hover { background: var(--shu-2); }
.fsns-link .flag-em { font-size: 18px; }
.fsns-link .sns-ico {
  margin-left: auto;
  flex-shrink: 0;
  width: 28px; height: 28px;
  background: #1877F2; color: white;
  border-radius: 50%;
  border: 2px solid var(--ink);
  display: flex; align-items: center; justify-content: center;
}

/* ===================== FOOTER ===================== */
footer {
  background: var(--ink); color: var(--paper);
  padding: 72px 0 32px;
  border-top: 3px solid var(--ink);
}
footer .container { color: var(--paper); }
.foot-grid {
  display: grid;
  grid-template-columns: 1.4fr 1fr 1fr 1fr;
  gap: 40px;
  padding-bottom: 56px;
  border-bottom: 1px solid rgba(255,249,239,0.18);
}
.foot-brand .brand { color: var(--paper); }
.foot-brand .brand-mark { background: var(--paper); border-color: var(--paper); box-shadow: 3px 3px 0 var(--shu); }
.foot-brand .brand-name { color: var(--paper); }
.foot-brand .brand-name small { color: rgba(255,249,239,0.55); }
.foot-brand p {
  margin: 18px 0 0;
  font-size: 13.5px;
  line-height: 1.85;
  color: rgba(255,249,239,0.7);
  max-width: 320px;
}
.foot-col h5 {
  margin: 4px 0 18px;
  font-family: 'Zen Maru Gothic', sans-serif;
  font-weight: 900; font-size: 14px;
  letter-spacing: 0.05em;
  padding-bottom: 8px;
  border-bottom: 2px dashed rgba(255,249,239,0.25);
}
.foot-col ul {
  list-style: none;
  margin: 0; padding: 0;
  display: flex; flex-direction: column; gap: 10px;
}
.foot-col ul li a {
  font-size: 13.5px;
  font-weight: 600;
  color: rgba(255,249,239,0.7);
  transition: color .15s ease;
}
.foot-col ul li a:hover { color: var(--shu); }
.foot-bottom {
  margin-top: 28px;
  display: flex; justify-content: space-between; align-items: center;
  gap: 16px; flex-wrap: wrap;
  font-size: 12.5px;
  color: rgba(255,249,239,0.45);
}

/* ===================== RESPONSIVE ===================== */
@media (max-width: 980px) {
  .hero-grid { grid-template-columns: 1fr; }
  .nav-links { display: none; }
  .entries, .entries-feature { grid-template-columns: 1fr; }
  .cats { grid-template-columns: repeat(2, 1fr); }
  .systems { grid-template-columns: 1fr; }
  .results-strip { grid-template-columns: 1fr 1fr; }
  .result { border-right: 0; border-bottom: 2px dashed var(--ink); }
  .result:nth-child(2n) { border-right: 0; }
  .result:nth-last-child(-n+2) { border-bottom: 0; }
  .foot-grid { grid-template-columns: 1fr 1fr; }
  .entry-big { grid-template-columns: 1fr; }
  .entry-big .b-art { width: 160px; height: 160px; justify-self: center; }
  .char-trio { grid-template-columns: 1fr; }
  .scenes { grid-template-columns: repeat(2, 1fr); }
  .hero-art .name-tag { display: none; }
  .hero-art .mini-char { width: 72px; }
  .hero-art .mini-char.mc1 { left: 0; bottom: 0; }
  .hero-art .mini-char.mc2 { right: 0; bottom: 0; }
}

/* =========================================================
   CLOUD TITLE — section heading, pill style with side icon
   ========================================================= */
.cloud-title {
  margin: 0 auto 56px;
  max-width: 720px;
  text-align: center;
  display: flex; flex-direction: column; align-items: center;
}
.cloud-title .ct-char { display: none; }
.cloud-title .ct-pill {
  position: relative;
  display: inline-flex; align-items: center; gap: 16px;
  padding: 18px 32px;
  background: white;
  border: 2.5px solid var(--ink);
  border-radius: 999px;
  box-shadow: 5px 5px 0 var(--ink);
  font-family: 'Zen Maru Gothic', sans-serif;
  font-weight: 900;
  font-size: clamp(22px, 3vw, 32px);
  color: var(--ink);
  line-height: 1.2;
}
.cloud-title .ct-icon {
  width: 44px; height: 44px;
  border: 2.5px solid var(--ink);
  border-radius: 50%;
  display: grid; place-items: center;
  font-size: 20px;
  flex-shrink: 0;
  background: var(--sakura);
  box-shadow: 2px 2px 0 var(--ink);
}
.cloud-title.color-sakura   .ct-icon { background: var(--sakura); }
.cloud-title.color-asagi    .ct-icon { background: var(--asagi); }
.cloud-title.color-matcha   .ct-icon { background: var(--matcha); }
.cloud-title.color-yamabuki .ct-icon { background: var(--yamabuki); }
.cloud-title.color-fuji     .ct-icon { background: var(--fuji); }
.cloud-title.color-kohaku   .ct-icon { background: var(--kohaku); }
.cloud-title .ct-text { white-space: nowrap; }
.cloud-title .ct-cta { display: none; }
.cloud-title .ct-dots {
  display: block;
  width: 80px; height: 6px;
  margin: 24px auto 14px;
  background-image: radial-gradient(circle, rgba(31,29,46,0.35) 2px, transparent 2.5px);
  background-size: 14px 6px;
  background-repeat: repeat-x;
}
.cloud-title .ct-sub {
  color: var(--ink-2); font-size: 16px; line-height: 1.85;
  margin: 0; max-width: 600px;
}

/* =========================================================
   CLOUD ENTRY — navigation cards. Picture-on-top card with cloud-style title pill below.
   ========================================================= */
.cloud-entry {
  display: flex; flex-direction: column;
  text-decoration: none; color: inherit;
  background: white;
  border: 2.5px solid var(--ink);
  border-radius: 28px;
  box-shadow: 5px 5px 0 var(--ink);
  overflow: hidden;
  position: relative;
  transition: transform .14s ease, box-shadow .14s ease;
}
.cloud-entry:hover { transform: translate(-3px,-3px); box-shadow: 8px 8px 0 var(--ink); }

.cloud-entry .ce-char {
  position: relative;
  width: 100%;
  aspect-ratio: 1/1;
  background: var(--paper);
  border-bottom: 2.5px solid var(--ink);
  overflow: hidden;
}
.cloud-entry.c-sakura   .ce-char { background: var(--sakura-2); }
.cloud-entry.c-asagi    .ce-char { background: var(--asagi-2); }
.cloud-entry.c-matcha   .ce-char { background: var(--matcha-2); }
.cloud-entry.c-yamabuki .ce-char { background: var(--yamabuki-2); }
.cloud-entry.c-fuji     .ce-char { background: var(--fuji-2); }
.cloud-entry.c-kohaku   .ce-char { background: var(--yamabuki-2); }

.cloud-entry .ce-char img {
  width: 100%; height: 100%;
  object-fit: cover; object-position: center top;
  transition: transform .3s ease;
}
.cloud-entry:hover .ce-char img { transform: scale(1.04); }

/* no-character variant: large illustrated glyph (kanji/icon) */
.cloud-entry.no-char .ce-char {
  display: grid; place-items: center;
  position: relative;
  background: var(--paper);
}
.cloud-entry.no-char .ce-char::before {
  content: '';
  position: absolute; inset: 0;
  background-image: radial-gradient(circle at 1px 1px, rgba(31,29,46,0.12) 1px, transparent 0);
  background-size: 22px 22px;
}
.cloud-entry.no-char .ce-char img { display: none; }
.cloud-entry.no-char .ce-glyph {
  position: relative;
  width: 60%; aspect-ratio: 1/1;
  background: white;
  border: 2.5px solid var(--ink);
  border-radius: 50%;
  box-shadow: 5px 5px 0 var(--ink);
  display: grid; place-items: center;
  font-family: 'Zen Maru Gothic', sans-serif;
  font-weight: 900;
  font-size: clamp(72px, 12vw, 140px);
  color: var(--ink);
  z-index: 1;
  line-height: 1;
}

/* Title pill at bottom */
.cloud-entry .ce-pill {
  display: grid;
  grid-template-columns: auto 1fr auto;
  align-items: center;
  gap: 14px;
  padding: 20px 22px 4px;
  background: white;
  font-family: 'Zen Maru Gothic', sans-serif;
  font-weight: 900;
  font-size: 20px;
  color: var(--ink);
}
.cloud-entry .ce-icon {
  width: 40px; height: 40px;
  border: 2.5px solid var(--ink);
  border-radius: 50%;
  display: grid; place-items: center;
  font-size: 19px;
  flex-shrink: 0;
  background: var(--sakura);
  box-shadow: 2px 2px 0 var(--ink);
}
.cloud-entry.c-sakura   .ce-icon { background: var(--sakura); }
.cloud-entry.c-asagi    .ce-icon { background: var(--asagi); }
.cloud-entry.c-matcha   .ce-icon { background: var(--matcha); }
.cloud-entry.c-yamabuki .ce-icon { background: var(--yamabuki); }
.cloud-entry.c-fuji     .ce-icon { background: var(--fuji); }
.cloud-entry.c-kohaku   .ce-icon { background: var(--kohaku); }
.cloud-entry .ce-text { line-height: 1.25; }
.cloud-entry .ce-cta {
  width: 32px; height: 32px;
  border: 2px solid var(--ink);
  border-radius: 50%;
  background: var(--ink);
  color: var(--paper);
  display: grid; place-items: center;
  font-size: 14px; font-weight: 900;
  transition: transform .2s ease;
}
.cloud-entry:hover .ce-cta { transform: rotate(-45deg); }
.cloud-entry .ce-dots { display: none; }
.cloud-entry .ce-sub {
  margin: 0;
  padding: 6px 22px 22px;
  color: var(--ink-2); font-size: 13.5px; line-height: 1.75;
  background: white;
}

@media (max-width: 980px) {
  .cloud-title .ct-pill { font-size: 20px; padding: 14px 22px; gap: 10px; max-width: calc(100vw - 48px); }
  .cloud-title .ct-icon { width: 36px; height: 36px; font-size: 16px; }
}


/* =========================================================
   ▼▼▼ 下層ページ共通 (Sub-page shared)  ▼▼▼
   ========================================================= */

/* --- BREADCRUMB --- */
.crumbs {
  background: var(--paper);
  border-bottom: 2px solid var(--ink);
}
.crumbs-inner {
  display: flex; align-items: center; flex-wrap: wrap;
  gap: 8px; padding: 12px 0; font-size: 13px; font-weight: 700;
}
.crumbs a { color: var(--ink-2); }
.crumbs a:hover { color: var(--kohaku); }
.crumbs .sep { color: var(--ink-2); }
.crumbs .now { color: var(--ink); }

/* --- PAGE HERO (compact, used on sub-pages) --- */
.phero {
  padding: 64px 0 80px;
  position: relative;
  border-bottom: 3px solid var(--ink);
  overflow: hidden;
}
.phero-inner {
  display: grid;
  grid-template-columns: 1.2fr 1fr;
  gap: 40px;
  align-items: center;
}
.phero-copy .ptag {
  display: inline-flex; align-items: center; gap: 8px;
  background: var(--ink); color: var(--paper);
  padding: 6px 14px; border-radius: 999px;
  font-family: 'Bricolage Grotesque', sans-serif;
  font-weight: 800; font-size: 12px; letter-spacing: 0.14em;
  text-transform: uppercase;
}
.phero h1 {
  font-family: 'Zen Maru Gothic', sans-serif;
  font-weight: 900;
  font-size: clamp(36px, 4.4vw, 60px);
  line-height: 1.12;
  margin: 18px 0 14px;
  letter-spacing: 0.01em;
}
.phero h1 .high {
  display: inline-block; background: var(--yamabuki);
  padding: 0 12px; border-radius: 10px;
  border: 2.5px solid var(--ink);
  transform: rotate(-2deg);
  box-shadow: 3px 3px 0 var(--ink);
}
.phero h1 .high.s2 { background: var(--sakura); transform: rotate(2deg); }
.phero h1 .high.s3 { background: var(--matcha); transform: rotate(-1deg); }
.phero .phero-en {
  font-family: 'Bricolage Grotesque', sans-serif;
  font-weight: 700; font-size: 18px;
  color: var(--ink-2);
  margin-top: 8px;
}
.phero .lead {
  margin: 22px 0 0; font-size: 16px; color: var(--ink-2);
  max-width: 540px; line-height: 1.8;
}
.phero-meta {
  margin-top: 28px;
  display: flex; gap: 14px; flex-wrap: wrap;
}
.phero-meta .pill {
  background: white; border: 2.5px solid var(--ink); border-radius: 999px;
  padding: 8px 16px; font-weight: 800; font-size: 13px;
  box-shadow: 3px 3px 0 var(--ink);
  font-family: 'Zen Maru Gothic', sans-serif;
  white-space: nowrap;
  line-height: 1.2;
  display: inline-flex; align-items: center;
}

.phero-art {
  position: relative;
  aspect-ratio: 1/1.05;
  max-width: 440px;
  margin-left: auto;
}
.phero-art .disc {
  position: absolute;
  left: 8%; right: 8%; bottom: 0;
  height: 78%;
  border-radius: 50%;
  background: var(--sakura);
  border: 3px solid var(--ink);
  box-shadow: 6px 6px 0 var(--ink);
  z-index: 1;
}
.phero-art .disc.matcha { background: var(--matcha); }
.phero-art .disc.asagi  { background: var(--asagi); }
.phero-art .disc.yamabuki { background: var(--yamabuki); }
.phero-art .disc.fuji   { background: var(--fuji); }
.phero-art .pchar {
  position: absolute;
  left: 0; right: 0; top: 0; bottom: 8%;
  z-index: 3;
  filter: drop-shadow(4px 5px 0 rgba(31,29,46,0.2));
}
.phero-art .pchar img {
  width: 100%; height: 100%; object-fit: contain; object-position: bottom center;
}
.phero-art .pstamp {
  position: absolute; bottom: -10px; right: -10px;
  width: 100px; height: 100px;
  background: var(--ink); color: var(--paper);
  border-radius: 50%;
  border: 3px solid var(--ink);
  box-shadow: 4px 4px 0 var(--ink);
  display: grid; place-items: center;
  text-align: center;
  font-family: 'Zen Maru Gothic', sans-serif;
  font-weight: 900; font-size: 14px;
  line-height: 1.2;
  transform: rotate(-10deg);
  z-index: 4;
  pointer-events: none;
}
@media (max-width: 980px) {
  .phero-art .pstamp { right: 8px; bottom: 8px; width: 84px; height: 84px; font-size: 12px; }
}

/* --- FLOW STEPS (numbered vertical/horizontal) --- */
.flow {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 18px;
}
.flow.cols-3 { grid-template-columns: repeat(3, 1fr); }
.flow.cols-5 { grid-template-columns: repeat(5, 1fr); }
.flow .step {
  background: white;
  border: 2.5px solid var(--ink);
  border-radius: var(--radius-lg);
  padding: 26px 22px 24px;
  box-shadow: 5px 5px 0 var(--ink);
  position: relative;
  display: flex; flex-direction: column; gap: 10px;
}
.flow .step .step-num {
  position: absolute; top: -18px; left: -10px;
  width: 56px; height: 56px;
  background: var(--yamabuki);
  border: 2.5px solid var(--ink);
  border-radius: 50%;
  display: grid; place-items: center;
  font-family: 'Bricolage Grotesque', sans-serif;
  font-weight: 800; font-size: 22px;
  box-shadow: 3px 3px 0 var(--ink);
  transform: rotate(-6deg);
}
.flow .step:nth-child(4n+1) .step-num { background: var(--sakura); }
.flow .step:nth-child(4n+2) .step-num { background: var(--asagi); }
.flow .step:nth-child(4n+3) .step-num { background: var(--matcha); }
.flow .step:nth-child(4n)   .step-num { background: var(--yamabuki); }
.flow .step .step-ico {
  font-size: 30px; align-self: flex-end; opacity: .55;
}
.flow .step h4 {
  font-family: 'Zen Maru Gothic', sans-serif;
  font-weight: 900; font-size: 19px;
  margin: 4px 0 0; line-height: 1.3;
}
.flow .step p {
  font-size: 13.5px; color: var(--ink-2); margin: 0;
}

/* --- FEATURE GRID (icon cards with body) --- */
.feature-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 22px;
}
.feature-card {
  background: white;
  border: 2.5px solid var(--ink);
  border-radius: var(--radius-lg);
  padding: 28px 26px;
  box-shadow: 5px 5px 0 var(--ink);
  display: flex; flex-direction: column; gap: 14px;
  transition: transform .12s ease, box-shadow .12s ease;
}
.feature-card:hover { transform: translate(-3px,-3px); box-shadow: 8px 8px 0 var(--ink); }
.feature-card .f-ico {
  width: 64px; height: 64px;
  border: 2.5px solid var(--ink);
  border-radius: 18px;
  display: grid; place-items: center;
  font-size: 30px;
  background: var(--matcha);
  box-shadow: 3px 3px 0 var(--ink);
}
.feature-card:nth-child(6n+1) .f-ico { background: var(--matcha); }
.feature-card:nth-child(6n+2) .f-ico { background: var(--asagi); }
.feature-card:nth-child(6n+3) .f-ico { background: var(--sakura); }
.feature-card:nth-child(6n+4) .f-ico { background: var(--yamabuki); }
.feature-card:nth-child(6n+5) .f-ico { background: var(--fuji); }
.feature-card:nth-child(6n)   .f-ico { background: var(--kohaku); }
.feature-card h4 {
  font-family: 'Zen Maru Gothic', sans-serif;
  font-weight: 900; font-size: 21px;
  margin: 0; line-height: 1.3;
}
.feature-card p { font-size: 14px; color: var(--ink-2); margin: 0; }
.feature-card .f-list {
  list-style: none; padding: 0; margin: 4px 0 0;
  display: flex; flex-direction: column; gap: 6px;
}
.feature-card .f-list li {
  position: relative; padding-left: 20px;
  font-size: 13.5px; color: var(--ink); font-weight: 700;
}
.feature-card .f-list li::before {
  content: '✓'; position: absolute; left: 0; top: 0;
  color: var(--kohaku); font-weight: 900;
}

/* --- 2COL CONTENT (image + text) --- */
.split {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 56px;
  align-items: center;
}
.split.flip { grid-template-columns: 1fr 1fr; }
.split-art {
  position: relative;
  aspect-ratio: 1/1;
  overflow: visible;
}
.split-art .frame {
  position: absolute;
  left: 6%; right: 6%; bottom: 4%; top: 22%;
  background: var(--sakura);
  border: 3px solid var(--ink);
  border-radius: 50% / 38%;
  box-shadow: 8px 8px 0 var(--ink);
  overflow: visible;
  display: grid; place-items: end center;
  z-index: 1;
}
.split-art .frame.matcha { background: var(--matcha-2); }
.split-art .frame.asagi  { background: var(--asagi-2); }
.split-art .frame.yamabuki { background: var(--yamabuki-2); }
.split-art .frame img {
  position: absolute;
  left: 8%; right: 8%; top: -28%; bottom: 0;
  width: 84%; height: 124%;
  object-fit: contain; object-position: bottom center;
  filter: drop-shadow(4px 5px 0 rgba(31,29,46,0.18));
  z-index: 2;
}
.split-art .stk {
  position: absolute; z-index: 2;
  background: var(--ink); color: var(--paper);
  border-radius: 999px;
  padding: 8px 16px;
  font-family: 'Zen Maru Gothic', sans-serif;
  font-weight: 800; font-size: 14px;
  border: 2.5px solid var(--ink);
  box-shadow: 3px 3px 0 var(--paper), 3px 3px 0 3px var(--ink);
}
.split-copy h3 {
  font-family: 'Zen Maru Gothic', sans-serif;
  font-weight: 900;
  font-size: clamp(26px, 3vw, 38px);
  line-height: 1.2;
  margin: 0 0 16px;
}
.split-copy h3 .high {
  background: var(--yamabuki); padding: 0 8px; border-radius: 8px;
  border: 2px solid var(--ink); display: inline-block;
}
.split-copy p { font-size: 15.5px; color: var(--ink-2); line-height: 1.85; }
.split-copy .key-list {
  list-style: none; padding: 0; margin: 18px 0 0;
  display: flex; flex-direction: column; gap: 10px;
}
.split-copy .key-list li {
  background: white; border: 2.5px solid var(--ink);
  border-radius: 14px; padding: 12px 18px;
  font-weight: 700; font-size: 14.5px;
  box-shadow: 3px 3px 0 var(--ink);
  display: flex; align-items: center; gap: 12px;
}
.split-copy .key-list li::before {
  content: ''; width: 12px; height: 12px;
  background: var(--kohaku);
  border: 2px solid var(--ink);
  border-radius: 50%;
  flex-shrink: 0;
}

/* --- FAQ ACCORDION --- */
.faq {
  display: flex; flex-direction: column; gap: 14px;
  max-width: 880px; margin: 0 auto;
}
.faq details {
  background: white;
  border: 2.5px solid var(--ink);
  border-radius: var(--radius);
  box-shadow: 4px 4px 0 var(--ink);
  overflow: hidden;
}
.faq summary {
  list-style: none;
  padding: 22px 28px;
  cursor: pointer;
  display: flex; align-items: center; gap: 16px;
  font-family: 'Zen Maru Gothic', sans-serif;
  font-weight: 900; font-size: 17px;
}
.faq summary::-webkit-details-marker { display: none; }
.faq summary .q-mark {
  width: 36px; height: 36px; flex-shrink: 0;
  border-radius: 50%;
  background: var(--sakura);
  border: 2.5px solid var(--ink);
  display: grid; place-items: center;
  font-family: 'Bricolage Grotesque', sans-serif;
  font-weight: 800; font-size: 18px;
}
.faq summary .q-toggle {
  margin-left: auto;
  flex-shrink: 0;
  width: 32px; height: 32px;
  border-radius: 50%;
  background: var(--ink); color: var(--paper);
  display: flex; align-items: center; justify-content: center;
  font-family: 'Bricolage Grotesque', sans-serif;
  font-weight: 900; font-size: 20px; line-height: 1;
  transition: transform .2s ease;
}
.faq details[open] summary .q-toggle { transform: rotate(45deg); }
.faq .a-body {
  padding: 0 28px 24px 80px;
  font-size: 14.5px; color: var(--ink-2);
  line-height: 1.85;
}
.faq details:nth-child(4n+2) summary .q-mark { background: var(--asagi); }
.faq details:nth-child(4n+3) summary .q-mark { background: var(--matcha); }
.faq details:nth-child(4n)   summary .q-mark { background: var(--yamabuki); }

/* --- BIG CTA (banner) --- */
.bigcta {
  background: var(--ink); color: var(--paper);
  border-radius: var(--radius-lg);
  border: 3px solid var(--ink);
  padding: 56px 56px;
  display: grid;
  grid-template-columns: 1fr auto;
  gap: 32px;
  align-items: center;
  box-shadow: 8px 8px 0 var(--yamabuki), 8px 8px 0 3px var(--ink);
}
.bigcta h3 {
  font-family: 'Zen Maru Gothic', sans-serif;
  font-weight: 900; font-size: clamp(28px, 3.4vw, 40px);
  margin: 0 0 10px; line-height: 1.25;
}
.bigcta h3 .high {
  background: var(--yamabuki); color: var(--ink);
  padding: 0 10px; border-radius: 8px;
}
.bigcta p { margin: 0; font-size: 15px; opacity: .8; }
.bigcta .cta-row { display: flex; gap: 12px; flex-wrap: wrap; justify-content: flex-end; }

/* --- INFO TABLE (会社概要) --- */
.info-table {
  background: white;
  border: 2.5px solid var(--ink);
  border-radius: var(--radius-lg);
  box-shadow: 5px 5px 0 var(--ink);
  overflow: hidden;
}
.info-table dl {
  margin: 0;
  display: grid;
  grid-template-columns: 200px 1fr;
}
.info-table dt, .info-table dd {
  padding: 20px 28px;
  border-bottom: 2px dashed rgba(31,29,46,.18);
  margin: 0;
}
.info-table dt {
  font-family: 'Zen Maru Gothic', sans-serif;
  font-weight: 900; font-size: 14px;
  background: var(--paper);
  border-right: 2px dashed rgba(31,29,46,.18);
}
.info-table dd { font-size: 15px; color: var(--ink); }
.info-table dl > :nth-last-child(-n+2) { border-bottom: 0; }

/* --- STAT BIG (for results page) --- */
.stat-big-grid {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 18px;
}
.stat-big {
  background: white;
  border: 2.5px solid var(--ink);
  border-radius: var(--radius-lg);
  padding: 32px 28px;
  box-shadow: 5px 5px 0 var(--ink);
  position: relative;
  overflow: hidden;
}
.stat-big::before {
  content: ''; position: absolute; top: -30px; right: -30px;
  width: 120px; height: 120px; border-radius: 50%;
  background: var(--yamabuki); opacity: .35;
}
.stat-big:nth-child(4n+1)::before { background: var(--sakura); }
.stat-big:nth-child(4n+2)::before { background: var(--asagi); }
.stat-big:nth-child(4n+3)::before { background: var(--matcha); }
.stat-big:nth-child(4n)   ::before { background: var(--yamabuki); }
.stat-big .stat-en {
  font-family: 'Bricolage Grotesque', sans-serif;
  font-weight: 800; font-size: 12px; letter-spacing: 0.14em;
  color: var(--ink-2); text-transform: uppercase;
  position: relative; z-index: 1;
}
.stat-big .stat-n {
  font-family: 'Zen Maru Gothic', sans-serif;
  font-weight: 900; font-size: 56px; line-height: 1;
  margin: 8px 0 6px;
  position: relative; z-index: 1;
}
.stat-big .stat-n .unit { font-size: 22px; margin-left: 4px; }
.stat-big .stat-l { font-size: 14px; font-weight: 700; color: var(--ink-2); position: relative; z-index: 1; }

/* --- JOB-CATEGORY HERO STRIP (chips) --- */
.cat-chip-row {
  display: flex; flex-wrap: wrap; gap: 10px;
  margin: 24px 0 0;
}
.cat-chip {
  background: white;
  border: 2px solid var(--ink); border-radius: 999px;
  padding: 8px 14px;
  font-size: 13px; font-weight: 800;
  box-shadow: 2px 2px 0 var(--ink);
  font-family: 'Zen Maru Gothic', sans-serif;
}
.cat-chip.active { background: var(--ink); color: var(--paper); }

/* --- JOB CARD (求人カード) --- */
.job-grid {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 20px;
}
.job-card {
  background: white;
  border: 2.5px solid var(--ink);
  border-radius: var(--radius-lg);
  padding: 26px 28px;
  box-shadow: 5px 5px 0 var(--ink);
  display: flex; flex-direction: column; gap: 14px;
  transition: transform .12s ease, box-shadow .12s ease;
}
.job-card:hover { transform: translate(-2px,-2px); box-shadow: 7px 7px 0 var(--ink); }
.job-card .j-head {
  display: flex; align-items: center; gap: 12px;
}
.job-card .j-logo {
  width: 52px; height: 52px;
  border: 2.5px solid var(--ink);
  border-radius: 14px;
  display: grid; place-items: center;
  background: var(--sakura);
  font-family: 'Zen Maru Gothic', sans-serif;
  font-weight: 900; font-size: 22px;
  box-shadow: 2px 2px 0 var(--ink);
}
.job-card .j-co {
  font-size: 12px; font-weight: 700; color: var(--ink-2);
}
.job-card h4 {
  font-family: 'Zen Maru Gothic', sans-serif;
  font-weight: 900; font-size: 20px;
  margin: 0; line-height: 1.3;
}
.job-card .j-meta {
  display: flex; flex-direction: column; gap: 6px;
  font-size: 13.5px; color: var(--ink-2);
}
.job-card .j-meta span strong {
  color: var(--ink); font-weight: 800; margin-right: 8px;
  display: inline-block; width: 60px;
  flex-shrink: 0;
}
.job-card .j-meta span {
  display: flex; align-items: flex-start;
}
.job-card .j-tags {
  display: flex; gap: 6px; flex-wrap: wrap;
}
.job-card .j-tags .tag {
  background: var(--paper);
  border: 2px solid var(--ink);
  border-radius: 999px;
  padding: 3px 10px;
  font-size: 11px; font-weight: 800;
  font-family: 'Zen Maru Gothic', sans-serif;
  white-space: nowrap;
  line-height: 1.4;
  display: inline-flex; align-items: center;
}
.job-card .j-tags .tag:nth-child(2) { background: var(--sakura); }
.job-card .j-tags .tag:nth-child(3) { background: var(--asagi); }
.job-card .j-foot {
  margin-top: 6px; padding-top: 14px;
  border-top: 2px dashed rgba(31,29,46,.18);
  display: flex; justify-content: space-between; align-items: center;
}
.job-card .j-foot .salary {
  font-family: 'Zen Maru Gothic', sans-serif;
  font-weight: 900; font-size: 17px;
}

/* --- STAFF CARD --- */
.staff-grid {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 20px;
}
.staff-card {
  background: white;
  border: 2.5px solid var(--ink);
  border-radius: var(--radius-lg);
  padding: 22px 22px 24px;
  box-shadow: 5px 5px 0 var(--ink);
  display: flex; flex-direction: column; gap: 12px;
  align-items: center; text-align: center;
}
.staff-card .s-photo {
  width: 100%; aspect-ratio: 1/1;
  background: var(--asagi-2);
  border: 2.5px solid var(--ink);
  border-radius: 20px;
  display: grid; place-items: center;
  font-size: 60px;
  overflow: hidden;
}
.staff-card:nth-child(4n+1) .s-photo { background: var(--sakura-2); }
.staff-card:nth-child(4n+2) .s-photo { background: var(--asagi-2); }
.staff-card:nth-child(4n+3) .s-photo { background: var(--matcha-2); }
.staff-card:nth-child(4n)   .s-photo { background: var(--yamabuki-2); }
.staff-card .s-flag { font-size: 26px; }
.staff-card h4 {
  font-family: 'Zen Maru Gothic', sans-serif;
  font-weight: 900; font-size: 20px;
  margin: 4px 0 0;
}
.staff-card .s-role {
  font-size: 12.5px; font-weight: 700; color: var(--ink-2);
}
.staff-card .s-quote {
  font-size: 13.5px; color: var(--ink); line-height: 1.65;
  background: var(--paper);
  border: 2px dashed var(--ink); border-radius: 14px;
  padding: 10px 14px; margin-top: 4px;
}

/* --- TIMELINE --- */
.timeline {
  position: relative; padding: 20px 0 20px 36px;
  border-left: 3px dashed var(--ink);
  display: flex; flex-direction: column; gap: 32px;
}
.timeline .t-item {
  position: relative;
}
.timeline .t-item::before {
  content: ''; position: absolute;
  left: -47px; top: 6px;
  width: 22px; height: 22px; border-radius: 50%;
  background: var(--yamabuki);
  border: 2.5px solid var(--ink);
  box-shadow: 2px 2px 0 var(--ink);
}
.timeline .t-item:nth-child(4n+1)::before { background: var(--sakura); }
.timeline .t-item:nth-child(4n+2)::before { background: var(--asagi); }
.timeline .t-item:nth-child(4n+3)::before { background: var(--matcha); }
.timeline .t-item .t-year {
  font-family: 'Bricolage Grotesque', sans-serif;
  font-weight: 800; font-size: 14px; letter-spacing: 0.1em;
  color: var(--kohaku);
}
.timeline .t-item h4 {
  font-family: 'Zen Maru Gothic', sans-serif;
  font-weight: 900; font-size: 19px;
  margin: 4px 0 6px;
}
.timeline .t-item p {
  font-size: 14px; color: var(--ink-2); margin: 0; line-height: 1.8;
}

/* --- RESPONSIVE for sub-pages --- */
@media (max-width: 980px) {
  .phero-inner { grid-template-columns: 1fr; }
  .phero-art { max-width: 320px; margin: 0 auto; }
  .flow, .flow.cols-3, .flow.cols-5 { grid-template-columns: 1fr; gap: 32px; }
  .feature-grid { grid-template-columns: 1fr; }
  .split { grid-template-columns: 1fr; gap: 32px; }
  .split-art .stk { display: none; }
  .stat-big-grid { grid-template-columns: 1fr 1fr; }
  .bigcta { grid-template-columns: 1fr; padding: 32px 28px; }
  .bigcta .cta-row { justify-content: flex-start; }
  .info-table dl { grid-template-columns: 1fr; }
  .info-table dt { border-right: 0; }
  .job-grid { grid-template-columns: 1fr; }
  .staff-grid { grid-template-columns: 1fr 1fr; }
}

/* =========================================================
   ▼▼▼ REFINED PALETTE OVERRIDES — keep the design restrained
   single accent (朱), single supporting tint (浅葱), neutralize the rest
   ========================================================= */

/* Section backgrounds — collapse multi-color into 2 tones */
.bg-paper, .bg-cream { background: var(--paper); }
.bg-sakura  { background: #fff5f0; }     /* faint shu wash */
.bg-asagi   { background: var(--asagi-2); }
.bg-matcha  { background: var(--matcha-2); }
.bg-yamabuki { background: var(--yamabuki-2); }
.bg-fuji    { background: var(--fuji-2); }

/* Cloud-entry icons — all use the same restrained look, only accent differs */
.cloud-entry .ce-icon {
  background: var(--paper) !important;
}
.cloud-entry.c-sakura   .ce-icon,
.cloud-entry.c-kohaku   .ce-icon { background: var(--shu-2) !important; color: var(--shu); }
.cloud-entry.c-asagi    .ce-icon { background: var(--asagi-2) !important; color: var(--asagi); }
.cloud-entry.c-matcha   .ce-icon,
.cloud-entry.c-yamabuki .ce-icon,
.cloud-entry.c-fuji     .ce-icon { background: var(--paper) !important; }

/* Cloud-entry photo backdrops — match the icon's tone (subtle) */
.cloud-entry .ce-char { background: var(--paper) !important; }
.cloud-entry.c-sakura   .ce-char,
.cloud-entry.c-kohaku   .ce-char { background: #fff5f0 !important; }
.cloud-entry.c-asagi    .ce-char { background: var(--asagi-2) !important; }

/* Cat (8業種) — photo backdrop unified */
.cat .cat-photo { background: var(--paper) !important; }
.cat:nth-child(odd) .cat-photo { background: #fff5f0 !important; }
.cat:nth-child(even) .cat-photo { background: var(--asagi-2) !important; }

/* Scenes — same idea, alternating only 2 tones */
.scenes > .scene:nth-child(odd)   { background: #fff5f0; }
.scenes > .scene:nth-child(even)  { background: var(--asagi-2); }
.scenes > .scene:nth-child(odd) figcaption  { background: #fff5f0; }
.scenes > .scene:nth-child(even) figcaption { background: var(--asagi-2); }

/* Feature-card icons — unified accent */
.feature-card .f-ico {
  background: var(--shu-2) !important;
  color: var(--shu);
}
.feature-card:nth-child(2n) .f-ico {
  background: var(--asagi-2) !important;
  color: var(--asagi);
}

/* Flow step numbers — restrained */
.flow .step .step-num {
  background: var(--shu) !important;
  color: var(--paper);
}
.flow .step:nth-child(2n) .step-num {
  background: var(--sumi) !important;
  color: var(--paper);
}

/* Stat-big bg accent */
.stat-big::before {
  background: var(--shu-2) !important;
  opacity: 1;
}
.stat-big:nth-child(2n)::before { background: var(--asagi-2) !important; }

/* FAQ q-mark unified */
.faq summary .q-mark { background: var(--shu-2) !important; color: var(--shu); }
.faq details:nth-child(2n) summary .q-mark { background: var(--asagi-2) !important; color: var(--asagi); }

/* Job-card logos */
.job-card .j-logo { background: var(--shu-2); color: var(--shu); }
.job-card:nth-child(2n) .j-logo { background: var(--asagi-2); color: var(--asagi); }
.job-card .j-tags .tag,
.job-card .j-tags .tag:nth-child(2),
.job-card .j-tags .tag:nth-child(3) { background: var(--paper); }

/* Staff-card photo bgs */
.staff-card:nth-child(odd) .s-photo  { background: #fff5f0 !important; }
.staff-card:nth-child(even) .s-photo { background: var(--asagi-2) !important; }

/* Timeline dots */
.timeline .t-item::before { background: var(--shu) !important; }
.timeline .t-item:nth-child(2n)::before { background: var(--asagi) !important; }
.timeline .t-item .t-year { color: var(--shu); }

/* Phero discs — restrained */
.phero-art .disc,
.phero-art .disc.matcha,
.phero-art .disc.fuji,
.phero-art .disc.yamabuki { background: var(--shu-2); }
.phero-art .disc.asagi { background: var(--asagi-2); }
.phero-art .pstamp { background: var(--sumi) !important; color: var(--paper) !important; }

/* Hero ring — 2-color spiral instead of 6-color */
.hero-art .ring {
  background: conic-gradient(from 0deg,
    var(--shu) 0deg 120deg,
    var(--paper) 120deg 180deg,
    var(--asagi) 180deg 300deg,
    var(--paper) 300deg 360deg) !important;
}

/* Hero h1 .high accent boxes — use brand red instead of yellow */
.hero h1 .high { background: var(--shu) !important; color: var(--paper) !important; border-color: var(--sumi) !important; }
.hero h1 .high.s2 { background: var(--shu-2) !important; color: var(--sumi) !important; }

/* Cloud-title icon colors */
.cloud-title.color-sakura .ct-icon,
.cloud-title.color-kohaku .ct-icon { background: var(--shu-2); color: var(--shu); }
.cloud-title.color-asagi  .ct-icon { background: var(--asagi-2); color: var(--asagi); }
.cloud-title.color-matcha   .ct-icon { background: var(--matcha-2);   color: var(--sumi); }
.cloud-title.color-yamabuki .ct-icon { background: var(--yamabuki-2); color: var(--sumi); }
.cloud-title.color-fuji     .ct-icon { background: var(--fuji-2);     color: var(--sumi); }

/* Section h2 .high accent */
.section h2 .high { background: var(--shu) !important; color: var(--paper) !important; }

/* Btn-primary uses brand red */
.btn-primary { background: var(--shu) !important; color: var(--paper) !important; }
.btn-yamabuki { background: var(--shu-2) !important; color: var(--ink) !important; }
.btn-yamabuki:hover { color: var(--ink) !important; }

/* Entry-big variants */
.entry-big.b1 { background: var(--shu-2) !important; }
.entry-big.b2 { background: var(--asagi-2) !important; }

/* Bigcta keeps yellow shadow → vermillion */
.bigcta { box-shadow: 8px 8px 0 var(--shu), 8px 8px 0 3px var(--sumi) !important; }
.bigcta h3 .high { background: var(--shu) !important; color: var(--paper) !important; }

/* Nav active link */
.nav-links a:hover { color: var(--shu); }
.nav-links a::after { background: var(--shu); }

/* Brand-name accent — HTML側で <span class="brand-accent"> を使うこと
   （インラインstyle属性を文字列検索するセレクターは壊れやすいため削除）*/
.brand-accent { color: var(--shu); }

/* Marquee stars */
.marquee-track .star { color: var(--shu); }

/* Phero h1 .high */
.phero h1 .high { background: var(--shu) !important; color: var(--paper) !important; border-color: var(--sumi) !important; }
.phero h1 .high.s2 { background: var(--shu-2) !important; color: var(--sumi) !important; }
.phero h1 .high.s3 { background: var(--asagi-2) !important; color: var(--sumi) !important; }

/* Split key-list dots */
.split-copy .key-list li::before { background: var(--shu) !important; }

/* Char-card MAIN accent — keep tag visible */
.char-card .char-tag { background: var(--shu) !important; color: var(--paper) !important; }
.char-card.main { border-color: var(--sumi); }

/* Reduce shuriken decoration to just one */
.shuriken { opacity: 0.6; }

/* Tighten Marquee */
.marquee { background: var(--sumi); color: var(--paper); }




/* ================================================================
   Elementor セクション & ページ固有スタイル
   （all-sections.html + 各ページの <style> ブロックを統合）
   ================================================================ */

/* ── gbn-hero ────────────────────────────────── */
.gbn-hero {
      --ink:#1f1d2e; --paper:#fff9ef; --sakura:#ffd6e1; --sakura-2:#ffe6ec;
      --yamabuki:#ffe28a; --matcha:#c9e7b2; --asagi:#b3dfe6; --kohaku:#ffb37a; --fuji:#d6c5f0;
      font-family:'Zen Kaku Gothic New',system-ui,sans-serif;
      color:var(--ink); line-height:1.65;
      padding:56px 24px 80px;
      background:
        radial-gradient(ellipse at top right, var(--sakura-2) 0%, transparent 55%),
        radial-gradient(ellipse at bottom left, var(--asagi) 0%, transparent 55%),
        var(--paper);
      border-radius:0;
    }
    .gbn-hero *, .gbn-hero *::before, .gbn-hero *::after { box-sizing:border-box; }
    .gbn-hero-grid {
      max-width:1200px; margin:0 auto;
      display:grid; grid-template-columns:1.05fr 1fr; gap:48px; align-items:center;
    }
    .gbn-hero .eyebrow {
      display:inline-flex; align-items:center; gap:8px;
      background:#fff; padding:8px 16px; border-radius:999px;
      border:2.5px solid var(--ink);
      font-family:'Zen Maru Gothic',sans-serif;
      font-weight:800; font-size:13px;
      box-shadow:3px 3px 0 var(--ink);
    }
    .gbn-hero .eyebrow .dot {
      width:9px; height:9px; border-radius:50%;
      background:var(--matcha); border:1.5px solid var(--ink);
      animation:gbn-blink 1.8s infinite;
    }
    @keyframes gbn-blink { 50% { opacity:.35; } }

    .gbn-hero h1 {
      font-family:'Zen Maru Gothic',sans-serif;
      font-weight:900;
      font-size:clamp(40px, 5.6vw, 76px);
      line-height:1.08; letter-spacing:.01em;
      margin:24px 0 0;
    }
    .gbn-hero h1 .high {
      display:inline-block; background:var(--yamabuki);
      padding:0 14px; border-radius:12px;
      border:2.5px solid var(--ink);
      box-shadow:4px 4px 0 var(--ink);
      transform:rotate(-2deg); margin:0 4px;
    }
    .gbn-hero h1 .high.s2 { background:var(--sakura); transform:rotate(2deg); }
    .gbn-hero .hero-en {
      margin-top:18px;
      font-family:'Bricolage Grotesque',sans-serif;
      font-weight:700; font-size:22px; color:#5a546b;
    }
    .gbn-hero p.lead {
      font-size:17px; max-width:540px; margin:28px 0 32px; color:#5a546b;
    }
    .gbn-hero .cta-row { display:flex; gap:14px; flex-wrap:wrap; }
    .gbn-hero .btn {
      display:inline-flex; align-items:center; gap:10px;
      padding:16px 26px; border-radius:999px;
      font-family:'Zen Maru Gothic',sans-serif;
      font-weight:900; font-size:15px;
      border:2.5px solid var(--ink);
      background:#fff;
      box-shadow:4px 4px 0 var(--ink);
      transition:transform .12s, box-shadow .12s;
      text-decoration:none; color:var(--ink); white-space:nowrap;
    }
    .gbn-hero .btn:hover { transform:translate(-2px,-2px); box-shadow:6px 6px 0 var(--ink); }
    .gbn-hero .btn-ink { background:var(--ink); color:var(--paper); }
    .gbn-hero .btn-yamabuki { background:var(--yamabuki); }

    .gbn-hero .hero-trust {
      display:flex; gap:28px; margin-top:40px;
      padding-top:24px; border-top:2px dashed var(--ink);
      flex-wrap:wrap;
    }
    .gbn-hero .stat-num {
      font-family:'Zen Maru Gothic',sans-serif;
      font-weight:900; font-size:32px; line-height:1;
    }
    .gbn-hero .stat-num .unit { font-size:18px; margin-left:4px; }
    .gbn-hero .stat-lbl { font-size:12px; color:#5a546b; margin-top:4px; font-weight:700; }

    /* HERO ART */
    .gbn-hero-art { position:relative; aspect-ratio:1/1.05; }
    .gbn-hero-art .ring {
      position:absolute; inset:8%; border-radius:50%;
      background:conic-gradient(from 0deg,
        var(--sakura) 0deg 60deg, var(--yamabuki) 60deg 120deg,
        var(--matcha) 120deg 180deg, var(--asagi) 180deg 240deg,
        var(--fuji) 240deg 300deg, var(--kohaku) 300deg 360deg);
      border:3px solid var(--ink);
      animation:gbn-spin 60s linear infinite;
    }
    @keyframes gbn-spin { to { transform:rotate(360deg); } }
    .gbn-hero-art .ring::after {
      content:''; position:absolute; inset:8%;
      background:var(--paper); border-radius:50%;
      border:3px solid var(--ink);
    }
    .gbn-hero-art .char-main {
      position:absolute; inset:18%;
      border-radius:50%; overflow:hidden;
      border:3px solid var(--ink); box-shadow:5px 5px 0 var(--ink);
      background:var(--paper); z-index:3;
    }
    .gbn-hero-art .char-main img { width:100%; height:100%; object-fit:cover; }
    .gbn-hero-art .speech {
      position:absolute; top:8%; right:-2%; z-index:4;
      background:#fff; border:2.5px solid var(--ink);
      padding:10px 16px; border-radius:18px;
      font-family:'Zen Maru Gothic',sans-serif;
      font-weight:800; font-size:15px;
      box-shadow:3px 3px 0 var(--ink);
      transform:rotate(4deg);
    }
    .gbn-hero-art .speech::after {
      content:''; position:absolute;
      width:14px; height:14px; background:#fff;
      border-right:2.5px solid var(--ink); border-bottom:2.5px solid var(--ink);
      bottom:-9px; left:24px; transform:rotate(45deg);
    }
    .gbn-hero-art .badge {
      position:absolute; border-radius:50%;
      display:grid; place-items:center;
      font-family:'Zen Maru Gothic',sans-serif;
      font-weight:900; text-align:center;
      border:2.5px solid var(--ink);
      box-shadow:4px 4px 0 var(--ink); z-index:4;
    }
    .gbn-hero-art .badge.b1 {
      width:110px; height:110px; bottom:4%; left:-2%;
      background:var(--sakura); font-size:14px; line-height:1.2;
      animation:gbn-wob-b1 3s infinite ease-in-out;
    }
    .gbn-hero-art .badge.b2 {
      width:96px; height:96px; top:24%; left:-6%;
      background:var(--yamabuki); font-size:28px;
      animation:gbn-wob-b2 4s infinite ease-in-out -1s;
    }
    @keyframes gbn-wob-b1 {
      0%,100% { transform:rotate(-12deg) translateY(0); }
      50%     { transform:rotate(-8deg)  translateY(-6px); }
    }
    @keyframes gbn-wob-b2 {
      0%,100% { transform:rotate(-18deg) translateY(0); }
      50%     { transform:rotate(-14deg) translateY(-6px); }
    }
    .gbn-hero-art .shuriken { position:absolute; animation:gbn-spin 4s linear infinite; }

    @media (max-width:980px) {
      .gbn-hero-grid { grid-template-columns:1fr; gap:32px; }
    }

/* ── gbn-marquee ────────────────────────────────── */
.gbn-marquee {
      background:#1f1d2e; color:#fff9ef;
      padding:18px 0; overflow:hidden;
      border-top:3px solid #1f1d2e; border-bottom:3px solid #1f1d2e;
    }
    .gbn-marquee-track {
      display:flex; gap:40px; white-space:nowrap;
      animation:gbn-mq 28s linear infinite;
      font-family:'Zen Maru Gothic',sans-serif;
      font-weight:900; font-size:22px;
      align-items:center; width:max-content;
    }
    .gbn-marquee-track span { display:inline-flex; align-items:center; gap:14px; }
    .gbn-marquee-track .star { color:#ffe28a; }
    @keyframes gbn-mq { to { transform:translateX(-50%); } }

/* ── gbn-entries ────────────────────────────────── */
.gbn-entries {
      --ink:#1f1d2e; --paper:#fff9ef;
      --sakura:#ffd6e1; --sakura-2:#ffe6ec;
      --asagi:#b3dfe6; --asagi-2:#d6eef3;
      --matcha:#c9e7b2; --yamabuki:#ffe28a; --fuji:#d6c5f0; --kohaku:#ffb37a;
      font-family:'Zen Kaku Gothic New',sans-serif;
      color:var(--ink); padding:90px 24px; background:var(--paper);
    }
    .gbn-entries *, .gbn-entries *::before, .gbn-entries *::after { box-sizing:border-box; }
    .gbn-entries-inner { max-width:1200px; margin:0 auto; }
    .gbn-entries .head { text-align:center; margin-bottom:48px; }
    .gbn-entries .tag {
      display:inline-block; background:var(--ink); color:var(--paper);
      padding:8px 16px; border-radius:999px;
      font-weight:800; font-size:12px; letter-spacing:.18em; text-transform:uppercase;
    }
    .gbn-entries h2 {
      font-family:'Zen Maru Gothic',sans-serif; font-weight:900;
      font-size:clamp(32px,4.2vw,52px); line-height:1.15;
      margin:18px 0 12px;
    }
    .gbn-entries h2 .high {
      background:var(--yamabuki); padding:0 8px; border-radius:6px;
      border:2px solid var(--ink); display:inline-block;
    }
    .gbn-entries .sub { color:#5a546b; font-size:17px; max-width:600px; margin:0 auto; }

    .gbn-entries-feature { display:grid; grid-template-columns:1fr 1fr; gap:24px; margin-bottom:24px; }
    .gbn-entries .feat {
      background:#fff; border:3px solid var(--ink); border-radius:28px;
      padding:36px; box-shadow:6px 6px 0 var(--ink);
      display:grid; grid-template-columns:1fr auto; gap:20px; align-items:center;
      text-decoration:none; color:var(--ink);
      transition:transform .15s, box-shadow .15s;
    }
    .gbn-entries .feat:hover { transform:translate(-3px,-3px); box-shadow:9px 9px 0 var(--ink); }
    .gbn-entries .feat.f1 { background:linear-gradient(135deg, var(--sakura-2), var(--sakura)); }
    .gbn-entries .feat.f2 { background:linear-gradient(135deg, var(--asagi-2),  var(--asagi)); }
    .gbn-entries .feat .en {
      font-family:'Bricolage Grotesque',sans-serif;
      font-weight:800; font-size:13px; letter-spacing:.04em;
    }
    .gbn-entries .feat h3 {
      font-family:'Zen Maru Gothic',sans-serif; font-weight:900;
      font-size:26px; margin:10px 0 8px; line-height:1.25;
    }
    .gbn-entries .feat p { font-size:14px; color:#5a546b; margin:0 0 16px; }
    .gbn-entries .feat .link {
      display:inline-flex; align-items:center; gap:8px;
      font-family:'Zen Maru Gothic',sans-serif;
      font-weight:800; font-size:15px;
    }
    .gbn-entries .feat .link::after {
      content:''; width:26px; height:26px; border-radius:50%; background:var(--ink);
      background-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%23fff9ef' stroke-width='3' stroke-linecap='round'><path d='M5 12h14M13 6l6 6-6 6'/></svg>");
      background-repeat:no-repeat; background-position:center; background-size:12px;
    }
    .gbn-entries .feat .art {
      width:130px; height:130px; border-radius:50%;
      border:2.5px solid var(--ink); background:#fff;
      box-shadow:4px 4px 0 var(--ink); overflow:hidden;
    }
    .gbn-entries .feat .art img { width:100%; height:100%; object-fit:cover; }

    .gbn-entries .four { display:grid; grid-template-columns:repeat(4,1fr); gap:18px; }
    .gbn-entries .card {
      position:relative; background:#fff;
      border:2.5px solid var(--ink); border-radius:24px;
      padding:26px 24px; box-shadow:5px 5px 0 var(--ink);
      text-decoration:none; color:var(--ink);
      display:flex; flex-direction:column; gap:8px; min-height:220px;
      transition:transform .15s, box-shadow .15s;
    }
    .gbn-entries .card:hover { transform:translate(-3px,-3px); box-shadow:8px 8px 0 var(--ink); }
    .gbn-entries .card .ico {
      width:58px; height:58px; border-radius:16px;
      display:grid; place-items:center; font-size:30px;
      border:2.5px solid var(--ink); box-shadow:2px 2px 0 var(--ink);
    }
    .gbn-entries .card:nth-child(6n+1) .ico { background:var(--matcha); }
    .gbn-entries .card:nth-child(6n+2) .ico { background:var(--asagi); }
    .gbn-entries .card:nth-child(6n+3) .ico { background:var(--sakura); }
    .gbn-entries .card:nth-child(6n+4) .ico { background:var(--yamabuki); }
    .gbn-entries .card:nth-child(6n+5) .ico { background:var(--fuji); }
    .gbn-entries .card:nth-child(6n)   .ico { background:var(--kohaku); }
    .gbn-entries .card h3 {
      font-family:'Zen Maru Gothic',sans-serif; font-weight:900;
      font-size:20px; margin:8px 0 0;
    }
    .gbn-entries .card .en {
      font-family:'Bricolage Grotesque',sans-serif;
      font-weight:700; font-size:11px; color:#5a546b; letter-spacing:.08em; text-transform:uppercase;
    }
    .gbn-entries .card p { font-size:13px; color:#5a546b; margin:4px 0 0; }
    .gbn-entries .card .arr {
      position:absolute; top:22px; right:22px;
      width:32px; height:32px; border-radius:50%;
      background:var(--ink); color:var(--paper);
      display:grid; place-items:center;
      transition:transform .15s;
    }
    .gbn-entries .card:hover .arr { transform:rotate(-45deg); }

    @media (max-width:980px) {
      .gbn-entries-feature { grid-template-columns:1fr; }
      .gbn-entries .four { grid-template-columns:1fr 1fr; }
      .gbn-entries .feat { grid-template-columns:1fr; }
      .gbn-entries .feat .art { justify-self:center; }
    }
    @media (max-width:560px) { .gbn-entries .four { grid-template-columns:1fr; } }

/* ── gbn-systems ────────────────────────────────── */
.gbn-systems {
      --ink:#1f1d2e; --asagi-2:#d6eef3; --matcha-2:#e2f1d3; --fuji-2:#ebe2f7; --yamabuki:#ffe28a;
      font-family:'Zen Kaku Gothic New',sans-serif; color:var(--ink);
      padding:90px 24px; background:var(--asagi-2);
    }
    .gbn-systems *, .gbn-systems *::before, .gbn-systems *::after { box-sizing:border-box; }
    .gbn-systems-inner { max-width:1200px; margin:0 auto; }
    .gbn-systems .head { text-align:center; margin-bottom:48px; }
    .gbn-systems .tag {
      display:inline-block; background:var(--ink); color:#fff9ef;
      padding:8px 16px; border-radius:999px;
      font-weight:800; font-size:12px; letter-spacing:.18em; text-transform:uppercase;
    }
    .gbn-systems h2 {
      font-family:'Zen Maru Gothic',sans-serif; font-weight:900;
      font-size:clamp(32px,4.2vw,52px); line-height:1.15; margin:18px 0 12px;
    }
    .gbn-systems h2 .high {
      background:var(--yamabuki); padding:0 8px; border-radius:6px;
      border:2px solid var(--ink); display:inline-block;
    }
    .gbn-systems .sub { color:#5a546b; font-size:17px; }

    .gbn-systems .grid { display:grid; grid-template-columns:1fr 1fr; gap:24px; }
    .gbn-systems .card {
      border:3px solid var(--ink); border-radius:28px;
      padding:36px; box-shadow:6px 6px 0 var(--ink);
      text-decoration:none; color:var(--ink); display:block;
      transition:transform .15s, box-shadow .15s;
    }
    .gbn-systems .card:hover { transform:translate(-3px,-3px); box-shadow:9px 9px 0 var(--ink); }
    .gbn-systems .card.s1 { background:var(--matcha-2); }
    .gbn-systems .card.s2 { background:var(--fuji-2); }
    .gbn-systems .num {
      font-family:'Bricolage Grotesque',sans-serif;
      font-weight:800; font-size:13px; letter-spacing:.15em; color:#5a546b;
    }
    .gbn-systems h3 {
      font-family:'Zen Maru Gothic',sans-serif; font-weight:900;
      font-size:28px; margin:8px 0 14px; line-height:1.25;
    }
    .gbn-systems p { font-size:14px; color:#5a546b; margin:0 0 22px; }
    .gbn-systems .more {
      display:inline-flex; align-items:center; gap:8px;
      font-family:'Zen Maru Gothic',sans-serif; font-weight:800;
      font-size:15px; padding-bottom:4px; border-bottom:2px solid var(--ink);
    }
    @media (max-width:780px) { .gbn-systems .grid { grid-template-columns:1fr; } }

/* ── gbn-results ────────────────────────────────── */
.gbn-results {
      --ink:#1f1d2e; --paper:#fff9ef;
      --sakura-2:#ffe6ec; --asagi-2:#d6eef3; --yamabuki-2:#fff1c2; --matcha-2:#e2f1d3;
      --yamabuki:#ffe28a;
      font-family:'Zen Kaku Gothic New',sans-serif; color:var(--ink);
      padding:90px 24px; background:var(--paper);
    }
    .gbn-results *, .gbn-results *::before, .gbn-results *::after { box-sizing:border-box; }
    .gbn-results-inner { max-width:1200px; margin:0 auto; }
    .gbn-results .head { text-align:center; margin-bottom:48px; }
    .gbn-results .tag {
      display:inline-block; background:var(--ink); color:var(--paper);
      padding:8px 16px; border-radius:999px;
      font-weight:800; font-size:12px; letter-spacing:.18em; text-transform:uppercase;
    }
    .gbn-results h2 {
      font-family:'Zen Maru Gothic',sans-serif; font-weight:900;
      font-size:clamp(32px,4.2vw,52px); line-height:1.15; margin:18px 0 12px;
    }
    .gbn-results h2 .high {
      background:var(--yamabuki); padding:0 8px; border-radius:6px;
      border:2px solid var(--ink); display:inline-block;
    }
    .gbn-results .sub { color:#5a546b; font-size:17px; }

    .gbn-results .strip {
      display:grid; grid-template-columns:repeat(4,1fr); gap:0;
      background:#fff; border:3px solid var(--ink); border-radius:28px;
      box-shadow:6px 6px 0 var(--ink); overflow:hidden;
    }
    .gbn-results .cell {
      padding:32px 24px; text-align:center;
      border-right:2px dashed var(--ink);
    }
    .gbn-results .cell:last-child { border-right:0; }
    .gbn-results .num {
      font-family:'Zen Maru Gothic',sans-serif;
      font-weight:900; font-size:52px; line-height:1;
    }
    .gbn-results .num .unit { font-size:20px; margin-left:4px; }
    .gbn-results .lbl { margin-top:10px; font-weight:800; font-size:14px; }
    .gbn-results .cell:nth-child(1) { background:var(--sakura-2); }
    .gbn-results .cell:nth-child(2) { background:var(--asagi-2); }
    .gbn-results .cell:nth-child(3) { background:var(--yamabuki-2); }
    .gbn-results .cell:nth-child(4) { background:var(--matcha-2); }

    .gbn-results .flags {
      display:flex; gap:10px; flex-wrap:wrap; justify-content:center;
      margin-top:32px;
    }
    .gbn-results .pill {
      display:inline-flex; align-items:center; gap:8px;
      background:#fff; border:2px solid var(--ink); border-radius:999px;
      padding:8px 16px; font-weight:800; font-size:14px;
      box-shadow:2px 2px 0 var(--ink);
      font-family:'Zen Maru Gothic',sans-serif; white-space:nowrap;
    }
    @media (max-width:780px) {
      .gbn-results .strip { grid-template-columns:1fr 1fr; }
      .gbn-results .cell { border-right:0; border-bottom:2px dashed var(--ink); }
      .gbn-results .cell:nth-child(2n) { border-right:0; }
      .gbn-results .cell:nth-last-child(-n+2) { border-bottom:0; }
    }

/* ── gbn-fbcta ────────────────────────────────── */
.gbn-fbcta {
      --ink:#1f1d2e; --sakura:#ffd6e1; --yamabuki:#ffe28a; --matcha:#c9e7b2;
      background:var(--sakura);
      border-top:3px solid var(--ink); border-bottom:3px solid var(--ink);
      padding:90px 24px 100px;
      font-family:'Zen Kaku Gothic New',sans-serif; color:var(--ink);
      text-align:center; position:relative; overflow:hidden;
    }
    .gbn-fbcta::before, .gbn-fbcta::after {
      content:''; position:absolute; width:220px; height:220px;
      border-radius:50%; border:14px solid var(--yamabuki); opacity:.5;
    }
    .gbn-fbcta::before { top:-80px; left:-60px; }
    .gbn-fbcta::after  { bottom:-90px; right:-80px; border-color:var(--matcha); }
    .gbn-fbcta-inner { position:relative; z-index:2; max-width:780px; margin:0 auto; }
    .gbn-fbcta h2 {
      font-family:'Zen Maru Gothic',sans-serif; font-weight:900;
      font-size:clamp(34px,5.4vw,58px); line-height:1.15; margin:0 0 18px;
    }
    .gbn-fbcta h2 .stamp {
      display:inline-block; background:#fff;
      padding:0 14px; border-radius:14px;
      border:3px solid var(--ink); box-shadow:5px 5px 0 var(--ink);
      transform:rotate(-3deg);
    }
    .gbn-fbcta p { font-size:17px; margin:0 auto 32px; max-width:560px; }
    .gbn-fbcta .row { display:flex; gap:14px; justify-content:center; flex-wrap:wrap; }
    .gbn-fbcta .btn {
      display:inline-flex; align-items:center; gap:10px;
      padding:18px 32px; border-radius:999px;
      font-family:'Zen Maru Gothic',sans-serif; font-weight:900;
      border:2.5px solid var(--ink); background:#fff;
      box-shadow:5px 5px 0 var(--ink);
      text-decoration:none; color:var(--ink);
      font-size:17px; transition:transform .12s, box-shadow .12s;
    }
    .gbn-fbcta .btn:hover { transform:translate(-2px,-2px); box-shadow:7px 7px 0 var(--ink); }
    .gbn-fbcta .btn-fb { background:#1877F2; color:#fff; }

/* ── 結果ページ (.bar-row / .country-card / .case-card) ──────────────────────────────── */
.bar-row{display:grid;grid-template-columns:120px 1fr 60px;gap:14px;align-items:center;margin:0 0 10px;}
.bar-row .bar-lbl{font-family:'Zen Maru Gothic',sans-serif;font-weight:800;font-size:14px;}
.bar-row .bar-bg{height:18px;background:var(--paper);border:2px solid var(--sumi);border-radius:999px;overflow:hidden;}
.bar-row .bar-fill{height:100%;background:var(--shu);border-right:2px solid var(--sumi);}
.bar-row:nth-child(2n) .bar-fill{background:var(--asagi);}
.bar-row .bar-n{font-family:'Bricolage Grotesque',sans-serif;font-weight:800;font-size:14px;text-align:right;}
.country-card{background:white;border:2.5px solid var(--sumi);border-radius:18px;padding:18px 16px;box-shadow:4px 4px 0 var(--sumi);text-align:center;}
.country-card .flag{font-size:36px;line-height:1;margin-bottom:6px;}
.country-card .cn{font-family:'Zen Maru Gothic',sans-serif;font-weight:900;font-size:15px;}
.country-card .cn-en{font-family:'Bricolage Grotesque',sans-serif;font-weight:700;font-size:11px;color:var(--sumi-2);letter-spacing:0.08em;}
.country-card .cn-num{margin-top:6px;font-family:'Bricolage Grotesque',sans-serif;font-weight:800;font-size:13px;color:var(--shu);}
.case-card{background:white;border:2.5px solid var(--sumi);border-radius:24px;padding:28px 26px;box-shadow:5px 5px 0 var(--sumi);}
.case-card .case-tag{display:inline-block;background:var(--shu);color:var(--paper);padding:4px 12px;border-radius:999px;border:2px solid var(--sumi);font-family:'Bricolage Grotesque',sans-serif;font-weight:800;font-size:11px;letter-spacing:0.12em;}
.case-card h4{font-family:'Zen Maru Gothic',sans-serif;font-weight:900;font-size:20px;margin:10px 0 8px;}
.case-card .case-meta{display:flex;gap:8px;flex-wrap:wrap;margin:8px 0 14px;}
.case-card .case-meta span{font-size:12px;background:var(--paper);border:2px solid var(--sumi);border-radius:999px;padding:3px 10px;font-weight:800;font-family:'Zen Maru Gothic',sans-serif;}
.case-card p{margin:0;font-size:14px;color:var(--sumi-2);line-height:1.8;}

/* ── サイトマップ (.map-hero / .map-tier) ──────────────────────────────── */
.map-hero {
    padding: 80px 0 40px;
    text-align: center;
  }
  .map-hero h1 {
    font-family: 'Zen Maru Gothic', sans-serif;
    font-weight: 900;
    font-size: clamp(36px, 4.6vw, 64px);
    margin: 12px 0;
  }
  .map-hero h1 .high {
    background: var(--yamabuki); padding: 0 14px; border-radius: 12px;
    border: 2.5px solid var(--ink); display: inline-block;
    transform: rotate(-2deg);
    box-shadow: 4px 4px 0 var(--ink);
  }
  .map-hero .lead { color: var(--ink-2); max-width: 640px; margin: 16px auto 0; font-size: 15.5px; line-height: 1.85; }

  .map-tier {
    margin: 56px 0 0;
    padding: 32px;
    background: var(--paper);
    border: 3px dashed var(--ink);
    border-radius: 26px;
    position: relative;
  }
  .map-tier .tier-label {
    position: absolute; top: -16px; left: 28px;
    background: var(--ink); color: var(--paper);
    padding: 6px 16px; border-radius: 999px;
    font-family: 'Bricolage Grotesque', sans-serif;
    font-weight: 800; font-size: 12px; letter-spacing: 0.14em;
  }
  .map-tier h2 {
    font-family: 'Zen Maru Gothic', sans-serif;
    font-weight: 900; font-size: 26px;
    margin: 0 0 24px;
  }

  .page-grid {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 20px;
  }
  .page-grid.two { grid-template-columns: repeat(2, 1fr); }
  .page-grid.four { grid-template-columns: repeat(4, 1fr); }

  .page-card {
    background: white;
    border: 2.5px solid var(--ink);
    border-radius: 20px;
    box-shadow: 5px 5px 0 var(--ink);
    overflow: hidden;
    display: flex; flex-direction: column;
    transition: transform .12s ease, box-shadow .12s ease;
    text-decoration: none; color: inherit;
  }
  .page-card:hover { transform: translate(-3px,-3px); box-shadow: 8px 8px 0 var(--ink); }
  .page-card .pc-thumb {
    height: 130px;
    background: var(--sakura-2);
    border-bottom: 2.5px solid var(--ink);
    display: grid; place-items: center;
    position: relative;
    overflow: hidden;
  }
  .page-card .pc-thumb img {
    width: 72%; height: 72%; object-fit: contain; z-index: 1;
  }
  .page-card .pc-thumb .ring {
    position: absolute; width: 110px; height: 110px;
    border-radius: 50%; background: var(--paper);
    border: 2.5px solid var(--ink);
  }
  .page-card .pc-body {
    padding: 18px 20px 20px;
    display: flex; flex-direction: column; gap: 6px;
  }
  .page-card .pc-en {
    font-family: 'Bricolage Grotesque', sans-serif;
    font-weight: 800; font-size: 11px;
    color: var(--ink-2); letter-spacing: 0.14em; text-transform: uppercase;
  }
  .page-card h4 {
    font-family: 'Zen Maru Gothic', sans-serif;
    font-weight: 900; font-size: 18px;
    margin: 0; line-height: 1.3;
  }
  .page-card p {
    margin: 4px 0 0; font-size: 12.5px; color: var(--ink-2); line-height: 1.6;
  }
  .page-card .pc-foot {
    margin-top: auto; padding-top: 12px;
    display: flex; align-items: center; justify-content: space-between;
  }
  .page-card .pc-state {
    font-size: 11px; font-weight: 800;
    background: var(--matcha); border: 2px solid var(--ink); border-radius: 999px;
    padding: 3px 10px;
    font-family: 'Zen Maru Gothic', sans-serif;
  }
  .page-card .pc-state.todo { background: var(--paper); }
  .page-card .pc-arrow { font-weight: 900; }

  .page-card .pc-thumb.c-sakura { background: var(--sakura-2); }
  .page-card .pc-thumb.c-asagi  { background: var(--asagi-2); }
  .page-card .pc-thumb.c-matcha { background: var(--matcha-2); }
  .page-card .pc-thumb.c-yamabuki { background: var(--yamabuki-2); }
  .page-card .pc-thumb.c-fuji   { background: var(--fuji-2); }

  .page-card.todo { opacity: .55; }
  .page-card.todo .pc-thumb { background: repeating-linear-gradient(45deg, var(--paper), var(--paper) 8px, rgba(31,29,46,.06) 8px, rgba(31,29,46,.06) 16px); }
  .page-card.todo .pc-thumb img { opacity: .25; }

  @media (max-width: 980px) {
    .page-grid, .page-grid.two, .page-grid.four { grid-template-columns: 1fr 1fr; }
  }

/* ── サポートページ (.duty-row) ──────────────────────────────── */
.duty-row{background:white;border:2.5px solid var(--sumi);border-radius:14px;padding:14px 22px;box-shadow:3px 3px 0 var(--sumi);font-family:'Zen Maru Gothic',sans-serif;font-weight:800;font-size:15px;display:flex;align-items:center;}

/* ── 育成就労ページ (.compare-table) ──────────────────────────────── */
.compare-table{background:white;border:2.5px solid var(--sumi);border-radius:24px;overflow:hidden;box-shadow:5px 5px 0 var(--sumi);}
.compare-table table{width:100%;border-collapse:collapse;}
.compare-table th,.compare-table td{padding:18px 22px;text-align:left;border-bottom:2px dashed rgba(31,29,46,.18);vertical-align:top;font-size:14.5px;}
.compare-table th{background:var(--paper);font-family:'Zen Maru Gothic',sans-serif;font-weight:900;font-size:13px;letter-spacing:0.04em;border-right:2px dashed rgba(31,29,46,.18);width:160px;}
.compare-table thead th{background:var(--sumi);color:var(--paper);font-size:15px;text-align:center;border-right:2px solid var(--paper);}
.compare-table thead th:last-child{border-right:0;}
.compare-table tbody tr:last-child td,.compare-table tbody tr:last-child th{border-bottom:0;}
.compare-table .pill-shu{display:inline-block;background:var(--shu);color:var(--paper);border:2px solid var(--sumi);border-radius:999px;padding:3px 12px;font-family:'Zen Maru Gothic',sans-serif;font-weight:800;font-size:12px;}
.compare-table .pill-asagi{display:inline-block;background:var(--asagi-2);color:var(--asagi);border:2px solid var(--sumi);border-radius:999px;padding:3px 12px;font-family:'Zen Maru Gothic',sans-serif;font-weight:800;font-size:12px;}

/* ── 特定技能ページ (.industry-tile / .duty-row) ──────────────────────────────── */
.industry-tile {
    background: white;
    border: 2.5px solid var(--ink);
    border-radius: 16px;
    padding: 18px 14px;
    box-shadow: 4px 4px 0 var(--ink);
    font-family: 'Zen Maru Gothic', sans-serif;
    font-weight: 900; font-size: 15px;
    text-align: center;
    position: relative;
    color: var(--ink-2);
  }
  .industry-tile.cov {
    background: var(--matcha-2);
    color: var(--ink);
  }
  .industry-tile.cov::after {
    content: '✓';
    position: absolute;
    top: -10px; right: -10px;
    width: 28px; height: 28px;
    background: var(--ink); color: var(--paper);
    border-radius: 50%;
    border: 2px solid var(--ink);
    display: grid; place-items: center;
    font-weight: 900; font-size: 14px;
    box-shadow: 2px 2px 0 var(--paper);
  }
  
  @media (max-width: 980px) {
    .industry-tile { font-size: 13px; padding: 14px 10px; }
  }

/* ===================== HAMBURGER BUTTON ===================== */
.nav-hamburger {
  display: none;
  flex-direction: column; justify-content: center; align-items: center;
  gap: 5px;
  width: 44px; height: 44px;
  padding: 8px;
  border: 2px solid var(--ink);
  border-radius: 10px;
  background: white;
  box-shadow: 2px 2px 0 var(--ink);
  cursor: pointer;
  flex-shrink: 0;
  transition: box-shadow .1s ease, transform .1s ease;
}
.nav-hamburger:hover { transform: translate(-1px,-1px); box-shadow: 3px 3px 0 var(--ink); }
.nav-hamburger span {
  display: block;
  width: 20px; height: 2.5px;
  background: var(--ink);
  border-radius: 2px;
  transition: transform .22s ease, opacity .18s ease;
}
.nav-hamburger.is-open span:nth-child(1) { transform: translateY(7.5px) rotate(45deg); }
.nav-hamburger.is-open span:nth-child(2) { opacity: 0; transform: scaleX(0); }
.nav-hamburger.is-open span:nth-child(3) { transform: translateY(-7.5px) rotate(-45deg); }

@media (max-width: 980px) {
  .nav-hamburger { display: flex; }
  .nav-cta { display: none; }
}

/* ===================== MOBILE DRAWER ===================== */
.nav-drawer {
  position: fixed;
  inset: 0;
  z-index: 49;
  visibility: hidden;
  pointer-events: none;
}
.nav-drawer.is-open {
  visibility: visible;
  pointer-events: auto;
}

.nav-drawer-overlay {
  position: absolute;
  inset: 0;
  background: rgba(31, 29, 46, 0.5);
  opacity: 0;
  transition: opacity .28s ease;
}
.nav-drawer.is-open .nav-drawer-overlay { opacity: 1; }

.nav-drawer-panel {
  position: absolute;
  top: 0; right: 0; bottom: 0;
  width: min(320px, 88vw);
  background: var(--paper);
  display: flex; flex-direction: column;
  border-left: 3px solid var(--ink);
  box-shadow: -4px 0 24px rgba(31, 29, 46, 0.18);
  transform: translateX(100%);
  transition: transform .3s cubic-bezier(.4, 0, .2, 1);
  overflow-y: auto;
}
.nav-drawer.is-open .nav-drawer-panel { transform: translateX(0); }

.nav-drawer-head {
  display: flex; align-items: center; justify-content: space-between;
  padding: 18px 20px;
  border-bottom: 2.5px solid var(--ink);
  background: white;
  flex-shrink: 0;
}

.nav-drawer-close {
  width: 38px; height: 38px;
  border: 2px solid var(--ink);
  border-radius: 50%;
  background: white;
  box-shadow: 2px 2px 0 var(--ink);
  font-size: 15px; font-weight: 900;
  cursor: pointer;
  display: grid; place-items: center;
  flex-shrink: 0;
  transition: transform .1s ease, box-shadow .1s ease;
}
.nav-drawer-close:hover { transform: translate(-1px,-1px); box-shadow: 3px 3px 0 var(--ink); }

.nav-drawer-links {
  display: flex; flex-direction: column;
  padding: 20px 16px;
  gap: 8px;
  flex: 1;
}
.nav-drawer-links a {
  display: flex; align-items: center; gap: 12px;
  padding: 16px 18px;
  font-family: 'Zen Maru Gothic', sans-serif;
  font-weight: 900; font-size: 17px;
  border: 2.5px solid var(--ink);
  border-radius: 16px;
  background: white;
  box-shadow: 3px 3px 0 var(--ink);
  color: var(--ink);
  text-decoration: none;
  transition: transform .1s ease, box-shadow .1s ease;
}
.nav-drawer-links a:hover { transform: translate(-2px,-2px); box-shadow: 5px 5px 0 var(--ink); }

.nav-drawer-cta {
  padding: 16px 16px 32px;
  flex-shrink: 0;
}
.nav-drawer-cta .btn {
  width: 100%;
  justify-content: center;
}

/* ===================== SMALL MOBILE (≤767px) ===================== */
@media (max-width: 767px) {
  .section { padding: 64px 0; }
  .section-tight { padding: 48px 0; }
  .phero { padding: 40px 0 52px; }
  .fbcta { padding: 56px 0 64px; }
  .hero { padding: 36px 0 48px; }
  .hero-art {
    order: -1;
    margin: 0 auto;
    max-width: 300px;
    width: 100%;
  }
  .hero h1 { margin: 12px 0 0; }
  .hero p.lead { font-size: 15px; margin: 10px 0 14px; }
  .hero-trust { gap: 16px; margin-top: 24px; padding-top: 18px; }
  .foot-grid { grid-template-columns: 1fr; }
  .cloud-title .ct-text { white-space: normal; }
  .cloud-title .ct-pill { flex-wrap: wrap; justify-content: center; }
  .bigcta { padding: 28px 20px; gap: 20px; }
  .phero-meta { justify-content: center; }
}

/* ===================== EXTRA SMALL (≤480px) ===================== */
@media (max-width: 480px) {
  /* hero h1 .high がはみ出さないよう block 化 */
  .hero h1 .high {
    display: block;
    max-width: 100%;
    transform: rotate(-1deg);
  }
  .hero-art { max-height: 340px; }
  .hero-art .badge.b1 { width: 84px; height: 84px; font-size: 11px; left: 0; }
  .hero-art .badge.b2 { width: 72px; height: 72px; font-size: 22px; left: 0; }
  .hero-art .speech { right: 2%; font-size: 13px; padding: 8px 12px; }
  .stat-big-grid { grid-template-columns: 1fr; }
  .scenes { grid-template-columns: 1fr 1fr; }
  .flow, .flow.cols-3, .flow.cols-5 { gap: 40px; }
  .container { padding: 0 16px; }
}

/* ================================================================
   ページ固有スタイル（各ページの <style> ブロックから統合）
   ================================================================ */

/* ── abroad / 来日STEP ──────────────────────────── */
.step-cards {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 20px;
  max-width: 720px;
  margin: 0 auto;
}
.step-card-last { grid-column: 1 / -1; max-width: 340px; width: 100%; margin: 0 auto; }
.step-card {
  background: #fff;
  border: 2.5px solid var(--sumi);
  border-radius: 20px;
  padding: 0; /* 画像がカード端まで広がるため padding は text に移動 */
  overflow: hidden;
  display: flex; flex-direction: column; gap: 0;
}
.step-card-img {
  width: 100%;
  aspect-ratio: 4/3;
  overflow: hidden;
  border-bottom: 2.5px solid var(--sumi);
  background: var(--asagi-2);
  flex-shrink: 0;
}
.step-card-img img { width: 100%; height: 100%; object-fit: cover; display: block; }
/* step-card テキストエリア（padding をここで付ける） */
.step-card-text { padding: 18px 22px 20px; display: flex; flex-direction: column; gap: 8px; }
.step-card-num { font-family: 'Bricolage Grotesque', sans-serif; font-weight: 800; font-size: 12px; color: var(--shu); letter-spacing: .06em; }
.step-card h4 { font-family: 'Zen Maru Gothic', sans-serif; font-weight: 900; font-size: 17px; margin: 0 0 2px; }
.step-card p { margin: 0; font-size: 14px; color: var(--sumi-2); line-height: 1.7; }

/* ── シンプル枠線フレーム（背景なし・枠線のみ） ─── */
.split-img-frame {
  position: relative;
  border: 3px solid var(--ink);
  border-radius: 20px;
  box-shadow: 6px 6px 0 var(--ink);
  overflow: hidden;
  aspect-ratio: 4/3;
  background: transparent;
}
.split-img-frame img {
  width: 100%; height: 100%;
  object-fit: cover;
  display: block;
}
/* キャラクターイラスト用：正方形・隙間なし */
.split-img-frame.is-char {
  aspect-ratio: 1/1;
}
.split-img-frame.is-char img {
  object-fit: cover;
  padding: 0;
}

/* ── TOPページ業種カード：スマホでも2列を維持 ── */
@media (max-width: 600px) {
  .gbn-scope .cats { grid-template-columns: repeat(2, 1fr) !important; }
}

/* ── 求人カード：j-tableは詳細ページに任せて非表示 ── */
.gbn-scope .job-card .j-table { display: none; }

/* ── 求人グリッド：スマホ2列 ── */
@media (max-width: 980px) {
  .gbn-scope .job-grid { grid-template-columns: repeat(2, 1fr) !important; }
}
@media (max-width: 480px) {
  .gbn-scope .job-grid { grid-template-columns: 1fr !important; }
}

/* ── 職種ページ「どんな仕事をするの？」テキスト中央 ── */
.job-what-wrap {
  max-width: 760px;
  margin: 0 auto;
  text-align: center;
}
.job-what-wrap h3 {
  font-family: 'Zen Maru Gothic', sans-serif;
  font-weight: 900;
  font-size: clamp(26px, 3vw, 36px);
  margin: 0 0 16px;
  line-height: 1.25;
}
.job-what-wrap p {
  font-size: 15.5px;
  color: var(--ink-2);
  line-height: 1.85;
  margin: 0 0 18px;
}
/* .high ハイライト（h3内） */
.job-what-wrap h3 .high {
  background: var(--shu);
  color: var(--paper);
  padding: 0 12px;
  border-radius: 10px;
  border: 2.5px solid var(--sumi);
  display: inline-block;
  box-shadow: 3px 3px 0 var(--sumi);
}

/* key-list：.split-copy外でも動くよう独立定義 */
.job-what-wrap .key-list {
  list-style: none;
  padding: 0;
  margin: 0 auto;
  max-width: 560px;
  text-align: left;
  display: flex;
  flex-direction: column;
  gap: 10px;
}
.job-what-wrap .key-list li {
  background: white;
  border: 2.5px solid var(--ink);
  border-radius: 14px;
  padding: 12px 18px;
  font-weight: 700;
  font-size: 14.5px;
  box-shadow: 3px 3px 0 var(--ink);
  display: flex;
  align-items: center;
  gap: 12px;
}
.job-what-wrap .key-list li::before {
  content: '';
  width: 12px;
  height: 12px;
  background: var(--shu);
  border: 2px solid var(--ink);
  border-radius: 50%;
  flex-shrink: 0;
}

@media (max-width: 480px) {
  .step-cards { grid-template-columns: 1fr; }
  .step-card-last { max-width: 100%; }
}

/* ── abroad / 日本語レベル表 ────────────────────── */
.jlpt-table { width: 100%; border-collapse: collapse; font-family: 'Zen Maru Gothic', sans-serif; font-size: 14px; margin-top: 28px; }
.jlpt-table th, .jlpt-table td { border: 2px solid var(--sumi); padding: 12px 16px; vertical-align: top; }
.jlpt-table thead th { font-weight: 900; font-size: 15px; text-align: center; background: var(--paper); }
.jlpt-table tbody td { font-weight: 500; line-height: 1.7; }
.jlpt-n4 th { background: #e8f5e9; color: #2e7d32; }
.jlpt-n3 th { background: #fff9c4; color: #f57f17; }
.jlpt-n2 th { background: #ffebee; color: #c62828; }
.level-dot { display: inline-block; width: 12px; height: 12px; border-radius: 50%; margin-right: 6px; vertical-align: middle; }
.dot-n4 { background: #4caf50; }
.dot-n3 { background: #ffc107; }
.dot-n2 { background: #f44336; }

/* ── support / チェックリスト ──────────────────── */
.support-checklist { list-style: none; padding: 0; margin: 18px 0 0; display: flex; flex-wrap: wrap; gap: 10px; }
.support-checklist li { display: flex; align-items: center; gap: 7px; font-family: 'Zen Maru Gothic', sans-serif; font-weight: 800; font-size: 14px; background: white; border: 2px solid var(--sumi); border-radius: 999px; padding: 6px 16px; }
.support-checklist li::before { content: "✅"; font-size: 15px; }

/* ── hire / カテゴリー選択 ──────────────────────── */
.cat-selector { display: flex; flex-direction: column; gap: 20px; max-width: 860px; margin: 0 auto; }
.cat-row {
  display: grid;
  grid-template-columns: 1fr auto 180px;
  align-items: center;
  gap: 20px;
  background: white;
  border: 2.5px solid var(--sumi);
  border-radius: 20px;
  padding: 24px 28px;
  box-shadow: 5px 5px 0 var(--sumi);
}
.cat-row .cat-body-text h4 { font-family: 'Zen Maru Gothic', sans-serif; font-weight: 900; font-size: 18px; margin: 0 0 8px; color: var(--ink); }
.cat-row .cat-body-text p { font-size: 13.5px; color: var(--sumi-2); line-height: 1.75; margin: 0; }
.cat-row .cat-arrow { font-size: 28px; color: var(--asagi); flex-shrink: 0; }
.cat-btn-col { display: flex; flex-direction: column; gap: 10px; }
.cat-anchor-btn {
  display: block; background: var(--asagi); color: white;
  border: 2.5px solid var(--sumi); border-radius: 12px;
  padding: 12px 16px;
  font-family: 'Zen Maru Gothic', sans-serif; font-weight: 900; font-size: 13px;
  text-align: center; text-decoration: none;
  box-shadow: 3px 3px 0 var(--sumi); transition: transform .1s, box-shadow .1s; line-height: 1.4;
}
.cat-anchor-btn:hover { transform: translate(2px, 2px); box-shadow: 1px 1px 0 var(--sumi); }
.cat-anchor-btn.btn-contact { background: var(--shu); }

/* ── hire / セクション番号・タイトル ──────────── */
.section-with-cta { position: relative; }
.sticky-cta-bar { position: sticky; bottom: 24px; z-index: 50; display: flex; justify-content: center; margin-top: 36px; pointer-events: none; }
.sticky-cta-bar a {
  pointer-events: auto;
  display: inline-flex; align-items: center; gap: 10px;
  background: var(--shu); color: white;
  font-family: 'Zen Maru Gothic', sans-serif; font-weight: 900; font-size: 16px;
  padding: 14px 36px; border: 2.5px solid var(--sumi); border-radius: 999px;
  box-shadow: 4px 4px 0 var(--sumi); text-decoration: none; transition: transform .1s, box-shadow .1s;
}
.sticky-cta-bar a:hover { transform: translate(2px, 2px); box-shadow: 2px 2px 0 var(--sumi); }
.section-num-badge {
  display: inline-flex; align-items: center; justify-content: center;
  width: 48px; height: 48px; border-radius: 50%;
  background: var(--asagi); color: white;
  font-family: 'Bricolage Grotesque', sans-serif; font-weight: 800; font-size: 22px;
  border: 2.5px solid var(--sumi); box-shadow: 3px 3px 0 var(--sumi);
  margin-right: 14px; flex-shrink: 0;
}
.section-title-row { display: flex; align-items: center; margin-bottom: 28px; }
.section-title-row h2 { font-family: 'Zen Maru Gothic', sans-serif; font-weight: 900; font-size: 28px; margin: 0; }
.dummy-content {
  background: white; border: 2.5px solid var(--sumi); border-radius: 20px;
  padding: 36px 40px; box-shadow: 5px 5px 0 var(--sumi); line-height: 1.9; font-size: 15px; color: var(--ink-2);
}
.dummy-content h3 { font-family: 'Zen Maru Gothic', sans-serif; font-weight: 900; font-size: 20px; color: var(--ink); margin: 28px 0 12px; border-left: 4px solid var(--asagi); padding-left: 12px; }
.dummy-content h3:first-child { margin-top: 0; }
.dummy-content ul { padding-left: 20px; margin: 8px 0; }
.dummy-content ul li { margin-bottom: 6px; }

/* ── hire / お問い合わせフォーム ──────────────── */
.contact-form { max-width: 760px; margin: 0 auto; background: white; border: 2.5px solid var(--sumi); border-radius: 24px; padding: 48px; box-shadow: 6px 6px 0 var(--sumi); }
.form-note { font-size: 13px; color: var(--sumi-2); margin-bottom: 32px; line-height: 1.8; }
.form-row-2 { display: grid; grid-template-columns: 1fr 1fr; gap: 20px; }
.form-group { margin-bottom: 24px; }
.form-group label { display: block; font-family: 'Zen Maru Gothic', sans-serif; font-weight: 900; font-size: 14px; margin-bottom: 8px; }
.form-group label .req { display: inline-block; background: var(--shu); color: white; font-size: 11px; padding: 2px 8px; border-radius: 4px; margin-left: 8px; vertical-align: middle; }
.form-group label .opt { display: inline-block; background: var(--sumi-2); color: white; font-size: 11px; padding: 2px 8px; border-radius: 4px; margin-left: 8px; vertical-align: middle; }
.form-group input[type="text"],
.form-group input[type="email"],
.form-group input[type="tel"],
.form-group input[type="url"],
.form-group select,
.form-group textarea {
  width: 100%; padding: 12px 16px; border: 2px solid var(--sumi); border-radius: 10px;
  font-family: 'Zen Kaku Gothic New', sans-serif; font-size: 15px; background: var(--paper);
  box-sizing: border-box; transition: border-color .15s, box-shadow .15s;
}
.form-group input:focus, .form-group select:focus, .form-group textarea:focus {
  outline: none; border-color: var(--asagi); box-shadow: 0 0 0 3px rgba(74,144,164,.2);
}
.form-group textarea { resize: vertical; min-height: 100px; }
.privacy-row {
  display: flex; align-items: center; gap: 12px;
  background: var(--paper); border: 2px solid var(--sumi); border-radius: 10px; padding: 14px 18px;
  font-family: 'Zen Maru Gothic', sans-serif; font-weight: 700; font-size: 14px;
}
.privacy-row input[type="checkbox"] { width: 18px; height: 18px; accent-color: var(--asagi); }
.privacy-row a { color: var(--asagi); }
.submit-btn {
  width: 100%; padding: 18px; background: var(--shu); color: white;
  border: 2.5px solid var(--sumi); border-radius: 14px;
  font-family: 'Zen Maru Gothic', sans-serif; font-weight: 900; font-size: 18px;
  cursor: pointer; box-shadow: 4px 4px 0 var(--sumi); transition: transform .1s, box-shadow .1s; margin-top: 12px;
}
.submit-btn:hover { transform: translate(2px, 2px); box-shadow: 2px 2px 0 var(--sumi); }

@media (max-width: 680px) {
  .cat-row { grid-template-columns: 1fr; }
  .cat-row .cat-arrow { display: none; }
  .contact-form { padding: 28px 20px; }
  .form-row-2 { grid-template-columns: 1fr; }
}

/* ================================================================
   FV：縦型3スロットカルーセル（中央拡大・常に正位置）
   ================================================================ */
.gbn-car {
  position: absolute;
  inset: 0;
  pointer-events: none;
  z-index: 3;
}

.car-slot {
  position: absolute;
  left: 50%; top: 50%;
  width: 64%;
  aspect-ratio: 1;
  border-radius: 50%;
  overflow: hidden;
  border: 3px solid var(--ink);
  background: var(--paper);
  box-shadow: 5px 5px 0 rgba(0,0,0,0.2);
  transition: transform 0.75s cubic-bezier(0.33, 1, 0.68, 1),
              opacity   0.75s ease;
}

.car-slot img {
  width: 100%; height: 100%;
  object-fit: contain;
  display: block;
}


/* ================================================================
   FV：mini-char（ガンバくん・ルンバくん）絶対配置
   ================================================================ */
.hero-art .mini-char {
  position: absolute;
  z-index: 4;
  width: 100px;
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 0;
}
.hero-art .mini-char img {
  width: 100%;
  display: block;
  filter: drop-shadow(0 4px 8px rgba(31,29,46,0.18));
}
.hero-art .mini-char .mc-tag {
  background: white;
  border: 2px solid var(--ink);
  border-radius: 999px;
  padding: 2px 10px;
  font-family: 'Zen Maru Gothic', sans-serif;
  font-weight: 800; font-size: 11px;
  box-shadow: 2px 2px 0 var(--ink);
  white-space: nowrap;
  margin-top: -6px;
}
.hero-art .mini-char.mc1 { bottom: 2%; left: -6%; }
.hero-art .mini-char.mc2 { bottom: 2%; right: -6%; }


/* ================================================================
   FV：言語対応バッジ行
   ================================================================ */
.hero-lang-row {
  display: flex; align-items: center; gap: 8px;
  margin-top: 14px; flex-wrap: wrap;
}
.hero-lang-row .lang-label {
  font-size: 11px; font-weight: 800; letter-spacing: 0.12em;
  color: var(--ink-2); text-transform: uppercase;
  margin-right: 4px;
}
.hero-lang-row .lang-flag { font-size: 22px; line-height: 1; }
.hero-lang-row .lang-more {
  background: var(--ink); color: var(--paper);
  padding: 3px 10px; border-radius: 999px;
  font-size: 11px; font-weight: 800;
  font-family: 'Bricolage Grotesque', sans-serif;
  letter-spacing: 0.06em;
}

/* ================================================================
   TOPページ：海外から来たい方へセクション
   ================================================================ */

/* メインバナー（キャラ＋コピー横並び） */
.abroad-banner {
  display: grid;
  grid-template-columns: 420px 1fr;
  gap: 48px;
  align-items: center;
  background: white;
  border: 3px solid var(--ink);
  border-radius: 30px;
  box-shadow: 6px 6px 0 var(--ink);
  padding: 0;
  margin-bottom: 28px;
  overflow: hidden;
}
.abroad-banner-img {
  aspect-ratio: 1/1;
  background: var(--asagi-2);
  display: flex;
  align-items: flex-end;
  justify-content: center;
  padding: 10px;
  overflow: hidden;
}
.abroad-banner-img img {
  width: 100%;
  max-height: 100%;
  object-fit: contain;
  object-position: bottom center;
  display: block;
}
.abroad-banner-copy {
  padding: 40px 48px 40px 0;
}
.abroad-banner-copy h3 {
  font-family: 'Zen Maru Gothic', sans-serif;
  font-weight: 900;
  font-size: clamp(26px, 3vw, 38px);
  line-height: 1.25; margin: 0 0 16px;
}
.abroad-banner-copy h3 .high {
  background: var(--shu) !important; color: var(--paper) !important;
  padding: 0 12px; border-radius: 10px;
  border: 2.5px solid var(--sumi);
  display: inline-block;
  box-shadow: 3px 3px 0 var(--sumi);
}
.abroad-banner-copy p {
  font-size: 15.5px; color: var(--ink-2); line-height: 1.85; margin: 0;
}
.abroad-flags {
  display: flex; flex-wrap: wrap; gap: 8px; margin-top: 18px;
}
.abroad-flags span {
  background: var(--paper); border: 2px solid var(--ink); border-radius: 999px;
  padding: 5px 14px; font-size: 13px; font-weight: 800;
  font-family: 'Zen Maru Gothic', sans-serif;
  box-shadow: 2px 2px 0 var(--ink);
}

/* 3ステップカード */
.abroad-step-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 20px;
}
.abroad-step-card {
  border: 2.5px solid var(--ink); border-radius: 22px;
  padding: 28px 24px; box-shadow: 5px 5px 0 var(--ink);
  display: flex; flex-direction: column; gap: 10px;
  background: linear-gradient(to bottom, var(--shu) 6px, white 6px);
}
.abroad-step-card:nth-child(2) {
  background: linear-gradient(to bottom, var(--asagi) 6px, white 6px);
}
.abroad-step-card:nth-child(3) {
  background: linear-gradient(to bottom, var(--sumi) 6px, white 6px);
}
.abroad-step-num {
  font-family: 'Bricolage Grotesque', sans-serif; font-weight: 800;
  font-size: 12px; letter-spacing: 0.12em; color: var(--shu); margin-top: 6px;
}
.abroad-step-card:nth-child(2) .abroad-step-num { color: var(--asagi); }
.abroad-step-card:nth-child(3) .abroad-step-num { color: var(--sumi); }
.abroad-step-card h4 {
  font-family: 'Zen Maru Gothic', sans-serif; font-weight: 900;
  font-size: 18px; margin: 0; line-height: 1.3;
}
.abroad-step-card p {
  font-size: 13.5px; color: var(--ink-2); margin: 0; line-height: 1.75;
}

/* レスポンシブ */
@media (max-width: 980px) {
  .abroad-banner { grid-template-columns: 1fr; gap: 0; }
  .abroad-banner-img { aspect-ratio: 4/3; }
  .abroad-banner-copy { padding: 28px; }
  .abroad-step-grid { grid-template-columns: repeat(2, 1fr); gap: 14px; }
}
@media (max-width: 640px) {
  .abroad-banner { border-radius: 20px; box-shadow: 4px 4px 0 var(--ink); }
  .abroad-banner-img { aspect-ratio: 1/1; }
  .abroad-banner-copy { padding: 20px 20px 24px; }
  .abroad-banner-copy h3 { font-size: clamp(18px, 5.5vw, 24px); margin-bottom: 12px; }
  .abroad-banner-copy p { font-size: 14px; line-height: 1.75; }
  .abroad-flags { gap: 6px; margin-top: 12px; }
  .abroad-flags span { font-size: 12px; padding: 4px 10px; }
  .abroad-banner-copy .btn { width: 100%; justify-content: center; }
  .abroad-step-grid { grid-template-columns: 1fr; gap: 12px; }
  .abroad-step-card { padding: 18px 16px; border-radius: 16px; }
  .abroad-step-card h4 { font-size: 16px; }
  .abroad-step-card p { font-size: 13px; line-height: 1.65; }
  .abroad-step-num { font-size: 11px; }
}

/* ================================================================
   非リンク要素のhoverアニメーション無効化
   <a>タグ以外のカード・セクションは transform しない
   ================================================================ */
.char-card:hover,
.feature-card:hover,
.scene:hover,
.system:hover,
.entry:hover,
.entry-big:hover,
.stat-big:hover,
.gbn-scope .staff-card:hover {
  transform: none !important;
  box-shadow: 6px 6px 0 var(--ink);
}
.scene:hover          { box-shadow: 4px 4px 0 var(--ink); }
.stat-big:hover       { box-shadow: 5px 5px 0 var(--ink); }
.gbn-scope .staff-card:hover { box-shadow: 5px 5px 0 var(--ink); }
