/* ============================================================
   S-Log TOP — スコープ済みCSS（WordPress / JIN:R 共通ヘッダー版）
   すべてのルールを #slog-top で囲み、JIN:R のスタイルと干渉しないようにしています。
   tokens.css（CSS変数）は別途読み込んでください。
   ============================================================ */

/* ---------- ベースリセット（#slog-top 内のみ適用） ---------- */
#slog-top *,
#slog-top *::before,
#slog-top *::after { box-sizing: border-box; }

#slog-top {
  font-family: var(--font-sans);
  color: var(--fg1);
  -webkit-font-smoothing: antialiased;
  text-rendering: optimizeLegibility;
  overflow-x: hidden;
}

#slog-top img { display: block; max-width: 100%; }
#slog-top a { color: inherit; text-decoration: none; }
#slog-top button { font-family: inherit; }

/* ---------- レイアウトラッパー ---------- */
#slog-top .wrap        { max-width: 1180px; margin: 0 auto; padding: 0 44px; }
#slog-top .wrap-narrow { max-width: 940px;  margin: 0 auto; padding: 0 44px; }

/* ---------- セクションリズム ---------- */
#slog-top .section { padding: clamp(76px, 10vw, 140px) 0; position: relative; }
#slog-top .section.dark  { background: var(--slate-800); color: #fff; }
#slog-top .section.light { background: var(--white);     color: var(--fg1); }
#slog-top .section.warm  { background: var(--cream-100); color: var(--fg1); }
#slog-top .section.warm2 { background: var(--cream-200); color: var(--fg1); }
#slog-top .section.cool  { background: var(--cool-50);   color: var(--fg1); }

/* ---------- eyebrow / 見出し ---------- */
#slog-top .eyebrow {
  font-family: var(--font-sans); font-weight: 700; font-size: 13px;
  letter-spacing: .2em; text-transform: uppercase; color: var(--slog-blue);
  display: inline-flex; align-items: center; gap: 11px;
}
#slog-top .eyebrow::before {
  content: ""; width: 22px; height: 3px; border-radius: 3px;
  background: var(--slog-red); display: inline-block;
}
#slog-top .eyebrow .jp   { color: var(--slate-500); letter-spacing: .08em; font-weight: 600; text-transform: none; }
#slog-top .dark .eyebrow .jp { color: var(--slate-400); }
#slog-top .eyebrow.center { justify-content: center; }

#slog-top .section-head        { margin-bottom: clamp(40px, 5vw, 60px); }
#slog-top .section-head.center { text-align: center; }
#slog-top .section-title {
  font-family: var(--font-display); font-weight: 800;
  font-size: clamp(28px, 3.6vw, 46px); line-height: 1.3; letter-spacing: .01em;
  color: var(--slate-800); margin: 16px 0 0;
}
#slog-top .dark .section-title { color: #fff; }
#slog-top .section-sub {
  margin: 18px 0 0; font-size: clamp(15px, 1.3vw, 17px); line-height: 2;
  color: var(--fg2); max-width: 640px;
}
#slog-top .dark .section-sub { color: rgba(255,255,255,.72); }
#slog-top .center .section-sub { margin-left: auto; margin-right: auto; }
/* Mission / Approach: section-sub を左寄せ */
#slog-top [data-screen-label="mission"] .section-sub,
#slog-top [data-screen-label="approach"] .section-sub { margin-left: 0; margin-right: 0; text-align: left; }

/* ---------- カラーユーティリティ ---------- */
#slog-top .accent-red  { color: var(--slog-red); }
#slog-top .accent-blue { color: var(--slog-blue); }
#slog-top .mark-u      { position: relative; white-space: nowrap; }
#slog-top .mark-u::after {
  content: ""; position: absolute; left: -.04em; right: -.04em;
  bottom: .04em; height: .34em; border-radius: 6px;
  background: rgba(0,160,234,.26); z-index: -1;
}
#slog-top .mark-u.red::after { background: rgba(231,0,18,.20); }

/* ---------- 線人間キャラクター ---------- */
#slog-top .stick { display: block; width: 100%; height: 100%; color: var(--slate-800); overflow: visible; }
#slog-top .dark .stick { color: #fff; }
#slog-top .char { display: inline-block; }

/* ---------- スクロール reveal ---------- */
#slog-top [data-reveal] { transition: opacity .8s var(--ease-out), transform .8s var(--ease-out); }
html.js #slog-top [data-reveal]    { opacity: 0; transform: translateY(24px); }
html.js #slog-top [data-reveal].in { opacity: 1; transform: none; }
#slog-top [data-reveal][data-delay="1"] { transition-delay: .07s; }
#slog-top [data-reveal][data-delay="2"] { transition-delay: .14s; }
#slog-top [data-reveal][data-delay="3"] { transition-delay: .21s; }
#slog-top [data-reveal][data-delay="4"] { transition-delay: .28s; }

/* ---------- ボタン ---------- */
#slog-top .btn {
  display: inline-flex; align-items: center; gap: 9px; cursor: pointer;
  font-weight: 700; font-size: 15px; letter-spacing: .02em; border-radius: var(--r-pill);
  padding: 14px 28px; border: 2px solid transparent;
  transition: transform .2s var(--ease-out), box-shadow .2s var(--ease-out), background .2s, color .2s, border-color .2s;
}
#slog-top .btn .arr { transition: transform .25s var(--ease-out); }
#slog-top .btn:hover .arr { transform: translateX(4px); }
#slog-top .btn--primary { background: var(--slog-red); color: #fff; box-shadow: 0 10px 22px rgba(231,0,18,.24); }
#slog-top .btn--primary:hover { transform: translateY(-2px); box-shadow: 0 16px 30px rgba(231,0,18,.34); }
#slog-top .btn--blue    { background: var(--slog-blue); color: #fff; box-shadow: 0 10px 22px rgba(0,160,234,.24); }
#slog-top .btn--blue:hover { transform: translateY(-2px); box-shadow: 0 16px 30px rgba(0,160,234,.34); }
#slog-top .btn--ghost   { background: #fff; color: var(--slate-800); border-color: var(--hairline-strong); }
#slog-top .btn--ghost:hover { background: var(--slate-800); color: #fff; border-color: var(--slate-800); transform: translateY(-2px); }
#slog-top .btn--ghost.on-dark { background: transparent; color: #fff; border-color: rgba(255,255,255,.4); }
#slog-top .btn--ghost.on-dark:hover { background: #fff; color: var(--slate-800); }
#slog-top .btn--sm { padding: 11px 22px; font-size: 14px; }
#slog-top .btn:active { transform: scale(.97); }

/* ============================================================
   HERO
   ※ JIN:R のヘッダー分だけ上パディングを調整しています
   ============================================================ */
#slog-top .hero { position: relative; overflow: hidden; background: var(--cream-100); }
#slog-top .hero::before {
  content: ""; position: absolute; inset: 0;
  background-image:
    radial-gradient(rgba(231,0,18,.10) 2px, transparent 2px),
    radial-gradient(rgba(0,160,234,.10) 2px, transparent 2px);
  background-size: 46px 46px, 46px 46px;
  background-position: 0 0, 23px 23px;
  mask-image: linear-gradient(180deg, transparent, #000 40%, #000 70%, transparent);
  opacity: .5; pointer-events: none;
}
#slog-top .hero__inner {
  position: relative; z-index: 2;
  display: grid; grid-template-columns: 1.05fr .95fr; gap: 40px; align-items: center;
  /* JIN:R のヘッダー高さ分を考慮して上パディングを縮小 */
  padding: clamp(60px, 8vw, 100px) 0 clamp(70px, 9vw, 110px);
  padding-left: clamp(8px, 3vw, 56px);
}
#slog-top .hero__eyebrow {
  font-family: var(--font-sans); font-weight: 700; font-size: 13px;
  letter-spacing: .18em; text-transform: uppercase; color: var(--slog-blue);
  display: flex; align-items: center; gap: 12px;
}
#slog-top .hero__eyebrow::before { content: ""; width: 26px; height: 3px; border-radius: 3px; background: var(--slog-red); }
#slog-top .hero__eyebrow .jp { color: var(--slate-600); letter-spacing: .06em; font-weight: 600; text-transform: none; }
#slog-top .hero h1 {
  font-family: var(--font-display); font-weight: 900; letter-spacing: .005em;
  font-size: clamp(40px, 6vw, 82px); line-height: 1.16; margin: 22px 0 0; color: var(--slate-800);
}
#slog-top .hero h1 .pop { display: inline-block; }
#slog-top .hero.in h1 .pop { animation: slog-pop .6s var(--ease-out) backwards; }
#slog-top .hero.in h1 .pop.d1 { animation-delay: .15s; }
@keyframes slog-pop {
  0%   { transform: translateY(14px) rotate(-3deg); opacity: 0; }
  100% { transform: none; opacity: 1; }
}
#slog-top .hero .sub { font-size: clamp(15px, 1.35vw, 17px); line-height: 2.05; color: var(--slate-700); max-width: 500px; margin: 26px 0 0; }
#slog-top .hero .cta-row  { display: flex; gap: 14px; margin-top: 34px; flex-wrap: wrap; }
#slog-top .hero__tags      { display: flex; gap: 9px; flex-wrap: wrap; margin-top: 30px; }
#slog-top .hero__tag {
  font-size: 12.5px; font-weight: 600; color: var(--slate-700);
  background: #fff; border: 1px solid var(--hairline);
  border-radius: var(--r-pill); padding: 8px 15px;
}

/* hero アニメーション */
#slog-top .hero__scene { position: relative; aspect-ratio: 1 / 0.92; }
#slog-top .hero__scene svg { position: absolute; inset: 0; width: 100%; height: 100%; overflow: visible; }

#slog-top .sc-bar { transform-box: fill-box; transform-origin: bottom; }
#slog-top .sc-spark,
#slog-top .ch-bob, #slog-top .ch-arm-l, #slog-top .ch-arm-r,
#slog-top .ch-wave, #slog-top .ch-strike, #slog-top .ch-point, #slog-top .ch-mag { transform-box: fill-box; }

#slog-top .hero.in .sc-bar { animation: slog-grow 2.6s var(--ease-out) infinite; }
#slog-top .hero.in .sc-bar.b2 { animation-delay: .2s; }
#slog-top .hero.in .sc-bar.b3 { animation-delay: .4s; }
#slog-top .hero.in .sc-bar.b4 { animation-delay: .6s; }
@keyframes slog-grow { 0% { transform: scaleY(.18) } 45%,100% { transform: scaleY(1) } }

#slog-top .sc-trend { stroke-dasharray: 360; stroke-dashoffset: 360; }
#slog-top .hero.in .sc-trend { animation: slog-draw 2.6s var(--ease-out) infinite; }
@keyframes slog-draw { 0% { stroke-dashoffset: 360 } 55%,100% { stroke-dashoffset: 0 } }

#slog-top .sc-spark { transform-origin: center; }
#slog-top .hero.in .sc-spark       { animation: slog-twinkle 2.2s ease-in-out infinite; }
#slog-top .hero.in .sc-spark.s2    { animation-delay: .5s; }
#slog-top .hero.in .sc-spark.s3    { animation-delay: 1s; }
#slog-top .hero.in .sc-spark.s4    { animation-delay: 1.4s; }
@keyframes slog-twinkle { 0%,100% { transform: scale(.5); opacity: .3 } 50% { transform: scale(1.1); opacity: 1 } }

#slog-top .ch-bob { transform-origin: 70px 120px; }
#slog-top .in .ch-bob,
#slog-top .hero.in .ch-bob { animation: slog-bob 1.7s ease-in-out infinite; }
@keyframes slog-bob { 0%,100% { transform: translateY(0) } 50% { transform: translateY(-7px) } }
#slog-top .in .ch-arm-l { animation: slog-wig 1.7s ease-in-out infinite; }
#slog-top .in .ch-arm-r { animation: slog-wig 1.7s ease-in-out infinite reverse; }
@keyframes slog-wig { 0%,100% { transform: rotate(0) } 50% { transform: rotate(-9deg) } }
#slog-top .in .ch-wave  { animation: slog-wave  1s   ease-in-out infinite; }
@keyframes slog-wave  { 0%,100% { transform: rotate(0) } 50% { transform: rotate(18deg) } }
#slog-top .in .ch-strike { animation: slog-strike 2.4s ease-in-out infinite; }
@keyframes slog-strike { 0%,100% { transform: rotate(0) } 50% { transform: rotate(-8deg) } }
#slog-top .in .ch-point { animation: slog-point 2s ease-in-out infinite; }
@keyframes slog-point { 0%,100% { transform: rotate(0) } 50% { transform: rotate(-6deg) } }
#slog-top .in .ch-mag   { animation: slog-point 2.4s ease-in-out infinite; }
#slog-top .ch-smoke { stroke-dasharray: 90; stroke-dashoffset: 90; }
#slog-top .in .ch-smoke { animation: slog-smoke 3.2s linear infinite; }
@keyframes slog-smoke {
  0%   { stroke-dashoffset: 90; opacity: 0 }
  30%  { opacity: .5 }
  100% { stroke-dashoffset: -90; opacity: 0 }
}

/* chain アニメーション */
#slog-top .chain-fig { transform-box: fill-box; opacity: 0; transform: scale(.2) translateY(8px); }
#slog-top .chain-link { stroke-dasharray: 240; stroke-dashoffset: 240; }
#slog-top .about__fig.in .chain-fig { animation: slog-chpop .55s var(--ease-out) forwards; }
#slog-top .about__fig.in .chain-fig.f0 { animation-delay: .10s; }
#slog-top .about__fig.in .chain-fig.f1 { animation-delay: .34s; }
#slog-top .about__fig.in .chain-fig.f2 { animation-delay: .58s; }
#slog-top .about__fig.in .chain-fig.f3 { animation-delay: .82s; }
#slog-top .about__fig.in .chain-link   { animation: slog-chdraw .4s var(--ease-out) forwards; }
#slog-top .about__fig.in .chain-link.l0 { animation-delay: .30s; }
#slog-top .about__fig.in .chain-link.l1 { animation-delay: .54s; }
#slog-top .about__fig.in .chain-link.l2 { animation-delay: .78s; }
@keyframes slog-chpop {
  0%  { opacity: 0; transform: scale(.2) translateY(8px) }
  65% { opacity: 1; transform: scale(1.08) }
  100%{ opacity: 1; transform: scale(1) }
}
@keyframes slog-chdraw { to { stroke-dashoffset: 0 } }

/* ---------- モーション低減 ---------- */
@media (prefers-reduced-motion: reduce) {
  #slog-top [data-reveal] { opacity: 1 !important; transform: none !important; }
  #slog-top .hero.in .sc-bar, #slog-top .hero.in .sc-trend, #slog-top .hero.in .sc-spark,
  #slog-top .ch-bob, #slog-top .ch-arm-l, #slog-top .ch-arm-r,
  #slog-top .ch-wave, #slog-top .ch-strike, #slog-top .ch-point, #slog-top .ch-mag, #slog-top .ch-smoke,
  #slog-top .hero.in h1 .pop { animation: none !important; }
  #slog-top .sc-trend { stroke-dashoffset: 0; }
  #slog-top .ch-smoke { stroke-dashoffset: 0; opacity: .5; }
  #slog-top .chain-fig { opacity: 1 !important; transform: none !important; }
  #slog-top .chain-link { stroke-dashoffset: 0 !important; }
}

/* ============================================================
   STATS
   ============================================================ */
#slog-top .stats__grid {
  display: grid; grid-template-columns: repeat(4, 1fr); gap: 18px;
}
#slog-top .stat {
  text-align: center; background: var(--cream-50);
  border: 1px solid var(--hairline); border-radius: var(--r-lg);
  padding: clamp(26px, 3vw, 40px) 16px;
}
#slog-top .stat__num {
  font-family: var(--font-display); font-weight: 800;
  font-size: clamp(36px, 4.4vw, 58px); line-height: 1; color: var(--slate-800);
  display: flex; align-items: baseline; justify-content: center; gap: 3px;
}
#slog-top .stat__num .unit { font-size: .42em; font-weight: 700; }
#slog-top .stat:nth-child(odd)  .stat__num .unit { color: var(--slog-red); }
#slog-top .stat:nth-child(even) .stat__num .unit { color: var(--slog-blue); }
#slog-top .stat__label { margin-top: 12px; font-size: 13.5px; color: var(--slate-600); font-weight: 600; }
#slog-top .stats__note { text-align: center; margin: 26px 0 0; font-size: 13px; color: var(--slate-500); }

/* ============================================================
   SERVICE
   ============================================================ */
#slog-top .svc-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 20px; }
#slog-top .svc-card {
  background: #fff; border: 1px solid var(--hairline); border-radius: var(--r-lg);
  padding: 30px 28px;
  transition: transform .35s var(--ease-out), box-shadow .35s var(--ease-out);
  position: relative;
}
#slog-top .svc-card:hover { transform: translateY(-6px); box-shadow: var(--shadow-lg); }
#slog-top .svc-card__top { display: flex; justify-content: space-between; align-items: flex-start; margin-bottom: 18px; }
#slog-top .svc-card__icon { width: 54px; height: 54px; border-radius: 15px; display: grid; place-items: center; }
#slog-top .svc-card__icon img { width: 28px; height: 28px; }
#slog-top .svc-card.red  .svc-card__icon { background: rgba(231,0,18,.08); }
#slog-top .svc-card.blue .svc-card__icon { background: rgba(0,160,234,.10); }
#slog-top .svc-card__n { font-family: var(--font-display); font-weight: 800; font-size: 14px; letter-spacing: .1em; }
#slog-top .svc-card.red  .svc-card__n { color: var(--slog-red); }
#slog-top .svc-card.blue .svc-card__n { color: var(--slog-blue); }
#slog-top .svc-card h3 { font-family: var(--font-display); font-size: 19px; font-weight: 800; color: var(--slate-800); margin: 0 0 10px; }
#slog-top .svc-card p  { font-size: 14px; line-height: 1.9; color: var(--slate-600); margin: 0; }

/* ============================================================
   APPROACH
   ============================================================ */
#slog-top .approach__head {
  display: grid; grid-template-columns: 1.3fr .7fr; gap: 30px;
  align-items: end; margin-bottom: clamp(36px, 4vw, 56px);
}
#slog-top .approach__mascot { height: 150px; }

#slog-top .process {
  display: grid; grid-template-columns: repeat(4, 1fr); gap: 16px;
  margin-bottom: clamp(40px, 5vw, 60px);
}
#slog-top .pstep {
  position: relative; padding: 24px 20px;
  border: 1px solid rgba(255,255,255,.16); border-radius: var(--r-md);
  background: rgba(255,255,255,.04);
}
#slog-top .pstep__fig { height: 76px; margin-bottom: 14px; color: #fff; }
#slog-top .pstep__n   { font-family: var(--font-display); font-size: 12px; letter-spacing: .16em; color: var(--slog-blue); margin-bottom: 8px; font-weight: 700; }
#slog-top .pstep h4   { font-family: var(--font-display); font-size: 18px; font-weight: 800; color: #fff; margin: 0 0 8px; }
#slog-top .pstep p    { font-size: 13px; line-height: 1.8; color: rgba(255,255,255,.66); margin: 0; }
#slog-top .pstep__arrow { position: absolute; right: -11px; top: 40%; z-index: 3; color: var(--slog-red); font-weight: 800; font-size: 18px; }
#slog-top .pstep:nth-child(2) .pstep__arrow { color: var(--slog-blue); }
#slog-top .pstep:last-child   .pstep__arrow { display: none; }

#slog-top .pillars { display: grid; grid-template-columns: 1fr 1fr; gap: 20px; }
#slog-top .pillar {
  padding: 34px 32px; border-radius: var(--r-lg);
  background: rgba(255,255,255,.05); border: 1px solid rgba(255,255,255,.16);
}
#slog-top .pillar__n { font-family: var(--font-display); font-weight: 800; font-size: clamp(36px, 4.4vw, 56px); line-height: .9; color: rgba(255,255,255,.16); }
#slog-top .pillar h3  { font-family: var(--font-display); font-size: clamp(20px, 2vw, 26px); font-weight: 800; color: #fff; margin: 6px 0 12px; }
#slog-top .pillar p   { font-size: 14.5px; line-height: 1.95; color: rgba(255,255,255,.7); margin: 0 0 16px; }
#slog-top .pillar__tags { display: flex; gap: 8px; flex-wrap: wrap; }
#slog-top .pillar__tags span { font-size: 12px; font-weight: 600; color: rgba(255,255,255,.85); background: rgba(255,255,255,.08); border-radius: var(--r-pill); padding: 6px 13px; }

/* ============================================================
   MISSION / VISION (S-TRIAD)
   ============================================================ */
#slog-top .sv-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: clamp(18px, 2.2vw, 28px); }
#slog-top .sv-card {
  position: relative; padding: 32px 28px; border-radius: var(--r-lg);
  background: #fff; border: 1px solid var(--hairline); box-shadow: var(--shadow-sm);
}
#slog-top .warm  .sv-card,
#slog-top .warm2 .sv-card { background: var(--cream-50); }
#slog-top .sv-card__fig { height: 84px; margin-bottom: 14px; }
#slog-top .sv-card__n   { font-family: var(--font-display); font-weight: 800; font-size: 13px; letter-spacing: .12em; color: var(--slate-400); }
#slog-top .sv-card__bar { width: 36px; height: 4px; border-radius: 2px; margin: 12px 0 14px; }
#slog-top .sv-card .lead-eng { font-family: var(--font-display); font-weight: 800; font-size: clamp(20px, 2vw, 25px); margin: 0 0 4px; }
#slog-top .sv-card__t { font-family: var(--font-display); font-size: clamp(16px, 1.6vw, 19px); font-weight: 800; line-height: 1.4; margin: 0 0 10px; color: var(--slate-800); }
#slog-top .sv-card__d { font-size: 14px; line-height: 1.95; margin: 0; color: var(--slate-600); }
#slog-top .sv-card.red   .sv-card__bar  { background: var(--slog-red); }
#slog-top .sv-card.red   .lead-eng      { color: var(--slog-red); }
#slog-top .sv-card.blue  .sv-card__bar  { background: var(--slog-blue); }
#slog-top .sv-card.blue  .lead-eng      { color: var(--slog-blue); }
#slog-top .sv-card.cream .sv-card__bar  { background: var(--cream-400); }
#slog-top .sv-card.cream .lead-eng      { color: #B98A26; }

/* ============================================================
   ABOUT
   ============================================================ */
#slog-top .about__statement {
  font-family: var(--font-display); font-weight: 800;
  font-size: clamp(24px, 3.2vw, 40px); line-height: 1.5; color: var(--slate-800);
}
#slog-top .about__row {
  display: grid; grid-template-columns: 1.15fr .85fr; gap: 48px;
  align-items: center; margin-top: 36px;
}
#slog-top .about__row p    { margin: 0 0 16px; font-size: 15px; line-height: 2.05; color: var(--slate-700); }
#slog-top .about__youth    { font-size: 13.5px; color: var(--slate-500); line-height: 1.9; padding-left: 16px; border-left: 3px solid var(--cream-300); }
#slog-top .about__fig      { height: 230px; display: grid; place-items: center; color: var(--slate-800); }
#slog-top .s-chips         { display: flex; gap: 12px; flex-wrap: wrap; margin-top: 30px; }
#slog-top .s-chip {
  display: inline-flex; align-items: baseline; gap: 9px;
  padding: 13px 20px; border-radius: var(--r-pill);
  background: #fff; border: 1px solid var(--hairline); box-shadow: var(--shadow-sm);
}
#slog-top .s-chip b    { font-family: var(--font-display); font-size: 18px; font-weight: 800; }
#slog-top .s-chip span { font-size: 12.5px; color: var(--slate-600); font-weight: 600; }
#slog-top .s-chip.red   b { color: var(--slog-red); }
#slog-top .s-chip.blue  b { color: var(--slog-blue); }
#slog-top .s-chip.cream b { color: #B98A26; }

/* ============================================================
   ME-KOU
   ============================================================ */
#slog-top .mekou { background: linear-gradient(180deg, var(--cream-200), var(--cream-100)); }
#slog-top .mekou__grid {
  display: grid; grid-template-columns: .8fr 1.2fr;
  gap: clamp(32px, 5vw, 64px); align-items: center;
}
#slog-top .mekou__art     { position: relative; display: grid; place-items: center; }
#slog-top .mekou__disc    {
  width: min(300px, 88%); aspect-ratio: 1; background: #fff;
  border-radius: 50%; display: grid; place-items: center; box-shadow: var(--shadow-lg);
}
#slog-top .mekou__disc .stick { width: 100%; height: 100%; color: var(--slate-700); }
#slog-top .mekou__badge {
  position: absolute; top: 6%; right: 8%;
  background: var(--slog-red); color: #fff;
  font-family: var(--font-display); font-weight: 800; font-size: 13px;
  padding: 8px 16px; border-radius: var(--r-pill); box-shadow: var(--shadow-md);
  transform: rotate(6deg);
}
#slog-top .mekou__msg h2  { font-family: var(--font-display); font-weight: 800; font-size: clamp(24px, 3vw, 38px); line-height: 1.35; color: var(--slate-800); margin: 14px 0 16px; }
#slog-top .mekou__msg p   { font-size: 15.5px; line-height: 2.05; color: var(--slate-700); margin: 0 0 26px; max-width: 540px; }
#slog-top .mekou__links   { display: flex; gap: 14px; flex-wrap: wrap; }

/* ============================================================
   COMPANY
   ============================================================ */
#slog-top .company__grid { display: grid; grid-template-columns: .85fr 1.15fr; gap: clamp(36px, 5vw, 72px); align-items: start; }
#slog-top .itable         { border-top: 1px solid var(--hairline); }
#slog-top .itable__row    { display: grid; grid-template-columns: 150px 1fr; gap: 20px; padding: 20px 4px; border-bottom: 1px solid var(--hairline); }
#slog-top .itable__row dt { font-weight: 700; font-size: 14px; color: var(--slate-800); }
#slog-top .itable__row dd { margin: 0; font-size: 15px; line-height: 1.85; color: var(--slate-600); }
#slog-top .company__mark  { display: block; }
#slog-top .company__smileband {
  width: 100%; height: 172px; border-radius: var(--r-lg);
  background-image: url(assets/smile.png);
  background-repeat: repeat-x;
  background-position: center 44%;
  background-size: auto 232%;
  box-shadow: var(--shadow-sm);
  border: 1px solid var(--hairline);
}

/* ============================================================
   CTA / CONTACT
   ============================================================ */
#slog-top .cta__card {
  background: var(--cream-200); border-radius: var(--r-xl);
  padding: clamp(46px, 6vw, 72px) clamp(28px, 5vw, 64px);
  text-align: center; position: relative; overflow: hidden;
}
#slog-top .cta__fig     { height: 120px; margin: 0 auto 8px; color: var(--slate-800); }
#slog-top .cta__card h2 { font-family: var(--font-display); font-weight: 900; font-size: clamp(26px, 3.4vw, 42px); color: var(--slate-800); margin: 6px 0 14px; }
#slog-top .cta__card p  { font-size: 16px; line-height: 1.95; color: var(--slate-700); margin: 0 auto 30px; max-width: 540px; text-align: center; }
#slog-top .cta__methods { display: flex; gap: 14px; justify-content: center; flex-wrap: wrap; margin-bottom: 30px; }
#slog-top .cta__method  {
  display: flex; flex-direction: column; align-items: center; gap: 4px;
  background: #fff; border-radius: var(--r-md); padding: 16px 32px;
  box-shadow: var(--shadow-sm); transition: transform .2s;
}
#slog-top .cta__method:hover { transform: translateY(-2px); }
#slog-top .cta__method .k   { font-size: 11px; letter-spacing: .18em; font-weight: 700; color: var(--slog-blue); text-transform: uppercase; }
#slog-top .cta__method .v   { font-family: var(--font-display); font-weight: 700; font-size: 18px; color: var(--slate-800); }

/* ============================================================
   レスポンシブ
   ============================================================ */
@media (max-width: 980px) {
  #slog-top .process { grid-template-columns: repeat(2, 1fr); }
  #slog-top .pstep:nth-child(2) .pstep__arrow { display: none; }
}
@media (max-width: 900px) {
  #slog-top .wrap,
  #slog-top .wrap-narrow          { padding: 0 22px; }
  #slog-top .approach__mascot     { display: none; }
  #slog-top .hero__inner          { grid-template-columns: 1fr; padding-left: 0; text-align: center; }
  #slog-top .hero__eyebrow,
  #slog-top .hero .cta-row,
  #slog-top .hero__tags           { justify-content: center; }
  #slog-top .hero .sub            { margin-left: auto; margin-right: auto; }
  #slog-top .approach__head       { grid-template-columns: 1fr; }
  #slog-top .stats__grid          { grid-template-columns: repeat(2, 1fr); }
  #slog-top .svc-grid             { grid-template-columns: 1fr; }
  #slog-top .pillars              { grid-template-columns: 1fr; }
  #slog-top .sv-grid              { grid-template-columns: 1fr; }
  #slog-top .about__row           { grid-template-columns: 1fr; gap: 26px; }
  #slog-top .about__fig           { order: -1; height: 180px; }
  #slog-top .mekou__grid          { grid-template-columns: 1fr; }
  #slog-top .mekou__art           { order: -1; max-width: 300px; margin: 0 auto; }
  #slog-top .company__grid        { grid-template-columns: 1fr; }
  #slog-top .company__mark        { order: -1; }
  #slog-top .hero__scene          { max-width: 420px; margin: 8px auto 0; }
}
@media (max-width: 560px) {
  #slog-top .stats__grid          { grid-template-columns: 1fr 1fr; }
  #slog-top .process              { grid-template-columns: 1fr; }
  #slog-top .pstep__arrow         { display: none !important; }
  #slog-top .itable__row          { grid-template-columns: 1fr; gap: 4px; }
  #slog-top .cta__methods         { flex-direction: column; align-items: stretch; }
  #slog-top .mekou__links         { flex-direction: column; }
}
