/* ==========================================================================
   CORPORATE SITE TEMPLATE — style.css
   デザインDNA: モノクロ基調 / 罫線グリッド / 大型タイポ / 差し色2色は動きにのみ使用
   クライアントごとに変更するのは :root の --accent-a / --accent-b のみが原則
   ========================================================================== */
:root{
  --ink:#0d0d0d;
  --paper:#ffffff;
  --gray:#9a9a9a;
  --gray-l:#c9c9c9;
  --line:#e6e6e6;
  --bg-soft:#f7f7f7;
  /* ▼ 差し色2色：クライアントごとにここだけ変更 */
  --accent-a:#FF6B2C;
  --accent-b:#1FB871;
  --gutter:clamp(18px,5vw,80px);
  --en:'Inter',sans-serif;
  --jp:'Noto Sans JP',sans-serif;
}
*{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:smooth}
body{
  font-family:var(--jp);color:var(--ink);background:var(--paper);
  line-height:1.9;font-feature-settings:"palt";
  -webkit-font-smoothing:antialiased;overflow-x:hidden;
}
a{color:inherit;text-decoration:none}
ul{list-style:none}
img,svg{display:block;max-width:100%}
::selection{background:var(--accent-a);color:var(--paper)}

/* ---------- scroll progress ---------- */
.progress{
  position:fixed;top:0;left:0;height:3px;width:0;z-index:200;
  background:linear-gradient(90deg,var(--accent-a),var(--accent-b));
}

/* ---------- utility ---------- */
.en{font-family:var(--en);letter-spacing:-0.02em}
.label{
  font-family:var(--en);font-size:10.5px;font-weight:700;
  letter-spacing:.26em;text-transform:uppercase;
}
.label .lb-dot{display:inline-block;width:6px;height:6px;border-radius:50%;margin-right:8px;vertical-align:1px}
.lb-dot.o{background:var(--accent-a)}
.lb-dot.g{background:var(--accent-b)}
.section{border-top:1px solid var(--ink)}

.btn-fill{
  font-family:var(--en);font-size:11.5px;font-weight:700;letter-spacing:.14em;
  background:var(--ink);color:var(--paper);
  padding:13px 28px;border-radius:999px;display:inline-block;white-space:nowrap;
  transition:transform .25s,box-shadow .25s;
}
.btn-fill:hover{transform:translateY(-2px);box-shadow:0 0 0 2px var(--paper),0 0 0 3.5px var(--accent-a)}
.btn-outline{
  font-family:var(--en);font-size:11.5px;font-weight:700;letter-spacing:.14em;
  border:1.5px solid var(--ink);padding:13px 28px;border-radius:999px;display:inline-block;
  transition:border-color .25s,color .25s;
}
.btn-outline:hover{border-color:var(--accent-a);color:var(--accent-a)}

/* セクション見出し（全ページ共通フォーマット） */
.section-head{padding:44px var(--gutter) 0}
.section-head .top{display:flex;align-items:baseline;gap:22px;flex-wrap:wrap}
.section-head .num{font-family:var(--en);font-size:11px;font-weight:700;color:var(--gray);letter-spacing:.1em}
.section-head h2{
  font-family:var(--en);
  font-size:clamp(38px,7vw,88px);
  font-weight:900;letter-spacing:-0.045em;line-height:.95;
}
.section-head h2 .accent-dot{
  display:inline-block;width:.14em;height:.14em;border-radius:50%;
  margin-left:.08em;vertical-align:.06em;
  transform:scale(0);transition:transform .5s cubic-bezier(.34,1.56,.64,1) .5s;
}
.section-head.on .accent-dot{transform:scale(1)}
.section-head .jp-sub{font-size:12px;font-weight:700;color:var(--gray);letter-spacing:.14em}
.section-head .desc{margin-top:18px;max-width:38em;font-size:13px;color:#555}
.section-head .head-more{margin-top:22px}

/* サブページ見出し（各下層ページの先頭） */
.page-head{
  padding:calc(76px + clamp(48px,8vw,90px)) var(--gutter) clamp(36px,6vw,60px);
  border-bottom:1px solid var(--ink);
}
.page-head .crumb{
  font-family:var(--en);font-size:10.5px;font-weight:700;letter-spacing:.2em;color:var(--gray);
}
.page-head .crumb a:hover{color:var(--accent-a)}
.page-head h1{
  font-family:var(--en);
  font-size:clamp(46px,10vw,120px);
  font-weight:900;letter-spacing:-0.05em;line-height:.95;
  margin-top:14px;
}
.page-head h1 .accent-dot{
  display:inline-block;width:.14em;height:.14em;border-radius:50%;
  margin-left:.08em;vertical-align:.06em;background:var(--accent-a);
}
.page-head .jp{margin-top:16px;font-size:13px;font-weight:700;letter-spacing:.14em}
.page-head .desc{margin-top:10px;max-width:40em;font-size:13px;color:#555}

/* ---------- image placeholder ----------
   画像はここに差し替え：<figure class="ph"> ごと <img> に置き換える */
.ph{
  position:relative;background:var(--bg-soft);border:1px solid var(--line);
  overflow:hidden;display:flex;align-items:center;justify-content:center;
}
.ph::before{
  content:"";position:absolute;inset:0;pointer-events:none;opacity:.5;
  background:
    linear-gradient(to bottom right,transparent calc(50% - .5px),var(--gray-l) 50%,transparent calc(50% + .5px)),
    linear-gradient(to bottom left,transparent calc(50% - .5px),var(--gray-l) 50%,transparent calc(50% + .5px));
}
.ph.has-img::before{display:none}
.ph-guide{position:relative;z-index:1;text-align:center;padding:20px;max-width:36em}
.ph-guide .tag{font-family:var(--en);font-size:10px;font-weight:700;letter-spacing:.3em;color:var(--gray);display:block;margin-bottom:10px}
.ph-guide .desc{font-size:12px;font-weight:700;line-height:2;color:#555}
.ph-guide .spec{display:block;margin-top:10px;font-family:var(--en);font-size:10px;font-weight:500;letter-spacing:.08em;color:var(--gray)}
.ph-guide.mini .desc{font-size:11px;line-height:1.8}
.r-16x9{aspect-ratio:16/9}
.r-4x3{aspect-ratio:4/3}
.r-1x1{aspect-ratio:1/1}

/* ---------- reveal ---------- */
.rv{opacity:0;transform:translateY(32px);transition:opacity 1s cubic-bezier(.22,1,.36,1),transform 1s cubic-bezier(.22,1,.36,1)}
.rv.on{opacity:1;transform:none}
.rv-d1{transition-delay:.12s}.rv-d2{transition-delay:.24s}.rv-d3{transition-delay:.36s}

/* ---------- cut-in ---------- */
.ci{position:relative;display:inline-block;overflow:hidden}
.ci .ci-in{opacity:0;transition:opacity 0s .42s}
.ci::after{content:"";position:absolute;inset:0;background:var(--ci,var(--accent-a));transform:scaleX(0);transform-origin:left}
.ci.on .ci-in{opacity:1}
.ci.on::after{animation:ci-sweep .85s cubic-bezier(.77,0,.18,1) forwards}
.ci.g{--ci:var(--accent-b)}
@keyframes ci-sweep{
  0%{transform:scaleX(0);transform-origin:left}
  45%,55%{transform:scaleX(1);transform-origin:left}
  56%{transform-origin:right}
  100%{transform:scaleX(0);transform-origin:right}
}

/* ---------- header ---------- */
header{
  position:fixed;inset:0 0 auto 0;z-index:100;
  display:flex;align-items:center;justify-content:space-between;
  padding:0 var(--gutter);height:76px;
  background:rgba(255,255,255,.9);backdrop-filter:blur(14px);
  border-bottom:1px solid var(--ink);transition:height .3s;
}
header.slim{height:58px}
.logo{display:flex;flex-direction:column;line-height:1.2}
.logo .mark{font-family:var(--en);font-weight:900;font-size:21px;letter-spacing:-0.03em;display:flex;align-items:center;gap:9px}
.logo .mark .dot{width:9px;height:9px;background:var(--accent-a);border-radius:50%;transition:transform .4s,background .4s}
.logo:hover .mark .dot{transform:scale(1.6);background:var(--accent-b)}
.logo .corp{font-size:9.5px;font-weight:700;letter-spacing:.22em;color:var(--gray);margin-left:18px}
nav.gnav{display:flex;gap:24px;align-items:center}
nav.gnav a{
  font-family:var(--en);font-size:11.5px;font-weight:700;letter-spacing:.16em;
  position:relative;padding:4px 0;
}
nav.gnav a::after{
  content:"";position:absolute;left:0;bottom:0;height:2px;width:0;
  background:linear-gradient(90deg,var(--accent-a),var(--accent-b));transition:width .3s;
}
nav.gnav a:hover::after,nav.gnav a.active::after{width:100%}
.header-right{display:flex;align-items:center;gap:14px}
.menu-btn{display:none}

/* ---------- hero（トップのみ） ---------- */
.hero{
  min-height:100svh;
  display:grid;grid-template-columns:1.05fr .95fr;
  align-items:center;
  padding:130px var(--gutter) 120px;
  position:relative;gap:clamp(30px,5vw,70px);
}
.hero-bg-dot{position:absolute;border-radius:50%;pointer-events:none;opacity:0;transition:opacity 1.2s 1s}
body.loaded .hero-bg-dot{opacity:1}
.hero-bg-dot.a{width:12px;height:12px;background:var(--accent-a);top:22%;right:8%;animation:drift 7s ease-in-out infinite}
.hero-bg-dot.b{width:8px;height:8px;background:var(--accent-b);top:64%;left:46%;animation:drift 9s ease-in-out infinite reverse}
.hero-bg-dot.c{width:6px;height:6px;border:1.5px solid var(--accent-a);background:none;top:38%;left:38%;animation:drift 11s ease-in-out infinite}
@keyframes drift{0%,100%{transform:translate(0,0)}50%{transform:translate(-14px,18px)}}
.hero-corp{font-size:12px;font-weight:700;letter-spacing:.3em;margin-bottom:22px;display:flex;align-items:center;gap:14px}
.hero-corp .bar{width:40px;height:2px;background:linear-gradient(90deg,var(--accent-a),var(--accent-b))}
.hero h1{font-size:clamp(34px,6.6vw,92px);font-weight:900;line-height:1.24;letter-spacing:.015em}
.hero h1 .row{display:block;overflow:hidden;padding-bottom:.08em;margin-bottom:-.08em}
.hero h1 .row span{display:inline-block;transform:translateY(112%);transition:transform 1.1s cubic-bezier(.22,1,.36,1)}
body.loaded .hero h1 .row:nth-child(1) span{transform:none;transition-delay:.15s}
body.loaded .hero h1 .row:nth-child(2) span{transform:none;transition-delay:.32s}
body.loaded .hero h1 .row:nth-child(3) span{transform:none;transition-delay:.49s}
.hero h1 .ul{position:relative;display:inline-block}
.hero h1 .ul::after{
  content:"";position:absolute;left:0;bottom:.04em;height:.1em;width:100%;
  background:linear-gradient(90deg,var(--accent-a),var(--accent-b));
  transform:scaleX(0);transform-origin:left;
  transition:transform 1s cubic-bezier(.22,1,.36,1) 1.15s;z-index:-1;
}
body.loaded .hero h1 .ul::after{transform:scaleX(1)}
.hero-en{font-family:var(--en);font-size:11px;font-weight:700;letter-spacing:.24em;color:var(--gray);margin-top:26px;text-transform:uppercase}
.hero-lead{margin-top:20px;max-width:32em;font-size:14px;font-weight:500;color:#3d3d3d}
.hero-actions{margin-top:44px;display:flex;gap:14px;flex-wrap:wrap}
.hero-visual{position:relative}
.hero-visual .ph{border:1px solid var(--ink)}
.hero-visual .corner{position:absolute;width:22px;height:22px;pointer-events:none}
.hero-visual .corner.tl{top:-6px;left:-6px;border-top:3px solid var(--accent-a);border-left:3px solid var(--accent-a)}
.hero-visual .corner.br{bottom:22px;right:-6px;border-bottom:3px solid var(--accent-b);border-right:3px solid var(--accent-b)}
.hero-visual .caption{
  margin-top:12px;font-family:var(--en);font-size:10px;font-weight:700;letter-spacing:.2em;color:var(--gray);
  display:flex;justify-content:space-between;
}
.scroll-hint{
  position:absolute;bottom:86px;left:var(--gutter);
  display:flex;align-items:center;gap:12px;
  font-family:var(--en);font-size:10px;font-weight:700;letter-spacing:.34em;color:var(--gray);
}
.scroll-hint .tick{width:1px;height:48px;background:var(--ink);position:relative;overflow:hidden}
.scroll-hint .tick::after{
  content:"";position:absolute;left:0;top:-100%;width:100%;height:100%;
  background:linear-gradient(var(--accent-a),var(--accent-b));animation:tick 1.9s ease-in-out infinite;
}
@keyframes tick{0%{top:-100%}60%,100%{top:100%}}

/* ---------- ticker ---------- */
.ticker{
  position:absolute;left:0;right:0;bottom:0;
  border-top:1px solid var(--ink);
  display:grid;grid-template-columns:auto 1fr auto;align-items:stretch;
  background:var(--paper);
}
.ticker .h{
  display:flex;align-items:center;gap:10px;padding:14px var(--gutter);
  border-right:1px solid var(--ink);
  font-family:var(--en);font-size:10px;font-weight:700;letter-spacing:.26em;
}
.ticker .h .pulse{width:7px;height:7px;border-radius:50%;background:var(--accent-b);animation:pulse 1.6s ease-in-out infinite}
@keyframes pulse{0%,100%{transform:scale(1);opacity:1}50%{transform:scale(1.8);opacity:.3}}
.ticker a.body{display:flex;align-items:center;gap:18px;padding:14px 24px;overflow:hidden;transition:background .3s}
.ticker a.body:hover{background:var(--bg-soft)}
.ticker .d{font-family:var(--en);font-size:11px;font-weight:700;color:var(--gray);flex:none;letter-spacing:.08em}
.ticker .t{font-size:12.5px;font-weight:700;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.ticker .all{
  display:flex;align-items:center;padding:0 var(--gutter);
  border-left:1px solid var(--ink);
  font-family:var(--en);font-size:10px;font-weight:700;letter-spacing:.2em;
  transition:background .3s,color .3s;
}
.ticker .all:hover{background:var(--ink);color:var(--paper)}

/* ---------- marquee ---------- */
.marquee{
  border-top:1px solid var(--ink);border-bottom:1px solid var(--ink);
  background:var(--ink);color:var(--paper);overflow:hidden;padding:18px 0;
}
.marquee-track{
  display:flex;gap:64px;width:max-content;
  animation:marq 30s linear infinite;
  font-family:var(--en);font-weight:900;font-size:clamp(17px,2.4vw,26px);
  letter-spacing:-0.02em;white-space:nowrap;align-items:center;
}
.marquee-track .jp{font-family:var(--jp);font-weight:900;letter-spacing:.06em}
.marquee-track .o{color:transparent;-webkit-text-stroke:1px var(--paper)}
.marquee-track .sp{width:7px;height:7px;border-radius:50%;flex:none}
.marquee-track .sp:nth-of-type(odd){background:var(--accent-a)}
.marquee-track .sp:nth-of-type(even){background:var(--accent-b)}
@keyframes marq{to{transform:translateX(-50%)}}

/* ---------- statement / value ---------- */
.statement{
  padding:clamp(80px,11vw,140px) var(--gutter) clamp(56px,8vw,84px);
  display:grid;grid-template-columns:1.2fr .8fr;gap:clamp(36px,6vw,90px);align-items:center;
}
.statement h2{font-size:clamp(25px,4.4vw,54px);font-weight:900;line-height:1.55;letter-spacing:.02em}
.statement .hl{background:linear-gradient(transparent 62%,color-mix(in srgb,var(--accent-a) 28%,transparent) 62%)}
.statement .hl.g{background:linear-gradient(transparent 62%,color-mix(in srgb,var(--accent-b) 28%,transparent) 62%)}
.statement p{margin-top:28px;max-width:36em;font-size:14px;color:#3d3d3d}

.value-grid{display:grid;grid-template-columns:repeat(3,1fr);border-top:1px solid var(--ink)}
.value-cell{padding:52px var(--gutter) 56px;border-left:1px solid var(--line);position:relative;overflow:hidden}
.value-cell:first-child{border-left:none}
.value-cell::before{content:"";position:absolute;top:0;left:0;height:4px;width:0;transition:width .9s cubic-bezier(.22,1,.36,1) .2s}
.value-cell.on::before{width:100%}
.value-cell:nth-child(1)::before{background:var(--accent-a)}
.value-cell:nth-child(2)::before{background:var(--accent-b)}
.value-cell:nth-child(3)::before{background:linear-gradient(90deg,var(--accent-a),var(--accent-b))}
.value-cell .vc-num{font-family:var(--en);font-size:12px;font-weight:700;letter-spacing:.14em;color:var(--gray)}
.value-cell h3{font-size:clamp(17px,1.9vw,23px);font-weight:900;margin:14px 0 12px;letter-spacing:.03em;line-height:1.6}
.value-cell p{font-size:12.5px;color:#555}
.value-cell .vc-point{margin-top:20px;font-family:var(--en);font-size:clamp(23px,2.6vw,34px);font-weight:900;letter-spacing:-0.03em;line-height:1.2}
.value-cell .vc-point small{font-family:var(--jp);font-size:.42em;font-weight:700;letter-spacing:.04em;margin-left:2px}
.value-cell:nth-child(1) .vc-point{color:var(--accent-a)}
.value-cell:nth-child(2) .vc-point{color:var(--accent-b)}
.value-note{padding:18px var(--gutter) 26px;font-size:10.5px;color:var(--gray)}

/* ---------- service ---------- */
.svc-grid{display:grid;grid-template-columns:1fr 1fr;border-top:1px solid var(--ink);margin-top:44px}
.svc{padding:56px var(--gutter) 64px;position:relative}
.svc + .svc{border-left:1px solid var(--ink)}
.svc .label{color:var(--gray)}
.svc h3{font-size:clamp(23px,3vw,38px);font-weight:900;margin:16px 0 4px;letter-spacing:.02em}
.svc .en-sub{font-family:var(--en);font-size:11px;font-weight:700;letter-spacing:.16em;color:var(--gray)}
.svc .ph{margin-top:30px}
.svc p{margin-top:24px;font-size:13.5px;max-width:34em;color:#3d3d3d}
.chips{display:flex;flex-wrap:wrap;gap:8px;margin-top:24px}
.chip{
  font-size:11px;font-weight:700;border:1px solid var(--ink);border-radius:999px;padding:6px 15px;
  transition:border-color .25s,color .25s,transform .25s;
}
.chip:hover{border-color:var(--accent-a);color:var(--accent-a);transform:translateY(-2px)}
.svc:nth-child(2) .chip:hover{border-color:var(--accent-b);color:var(--accent-b)}

/* トップ用サービスダイジェスト */
.svc-digest{display:grid;grid-template-columns:1fr 1fr;border-top:1px solid var(--ink);margin-top:44px}
.svc-digest a{padding:48px var(--gutter) 52px;position:relative;transition:background .3s}
.svc-digest a + a{border-left:1px solid var(--ink)}
.svc-digest a:hover{background:var(--bg-soft)}
.svc-digest h3{font-size:clamp(21px,2.4vw,30px);font-weight:900;margin:14px 0 8px;letter-spacing:.02em}
.svc-digest p{font-size:13px;color:#555;max-width:30em}
.svc-digest .go{
  margin-top:22px;display:inline-flex;align-items:center;gap:10px;
  font-family:var(--en);font-size:11px;font-weight:700;letter-spacing:.2em;
}
.svc-digest .go .arw{transition:transform .3s;font-weight:900}
.svc-digest a:hover .go .arw{transform:translateX(8px);color:var(--accent-a)}

/* ---------- flow ---------- */
.flow{display:grid;grid-template-columns:repeat(4,1fr);border-top:1px solid var(--ink)}
.flow-cell{padding:44px var(--gutter) 48px;border-left:1px solid var(--line);position:relative}
.flow-cell:first-child{border-left:none}
.flow-cell .no{font-family:var(--en);font-size:12px;font-weight:700;letter-spacing:.1em;color:var(--gray);position:relative;padding-left:16px}
.flow-cell .no::before{content:"";position:absolute;left:0;top:50%;transform:translateY(-50%);width:8px;height:8px;border-radius:50%}
.flow-cell:nth-child(odd) .no::before{background:var(--accent-a)}
.flow-cell:nth-child(even) .no::before{background:var(--accent-b)}
.flow-cell h4{font-size:16px;font-weight:900;margin:12px 0 8px;letter-spacing:.04em}
.flow-cell p{font-size:12px;color:#555}
.flow-cell .arw{
  position:absolute;right:-9px;top:50%;transform:translateY(-50%);
  font-family:var(--en);font-weight:900;font-size:16px;
  background:var(--paper);z-index:1;color:var(--gray-l);
}

/* ---------- numbers ---------- */
.nums{display:grid;grid-template-columns:repeat(4,1fr);border-top:1px solid var(--ink);margin-top:44px}
.num-cell{padding:48px var(--gutter) 44px;border-left:1px solid var(--line)}
.num-cell:first-child{border-left:none}
.num-cell .v{font-family:var(--en);font-size:clamp(42px,6vw,80px);font-weight:900;letter-spacing:-0.045em;line-height:1}
.num-cell .v small{font-size:.36em;font-weight:700;margin-left:5px;font-family:var(--jp);letter-spacing:0}
.num-cell .k{margin-top:14px;font-size:11.5px;font-weight:700;color:var(--gray);letter-spacing:.08em;position:relative;padding-left:14px}
.num-cell .k::before{content:"";position:absolute;left:0;top:50%;transform:translateY(-50%);width:7px;height:7px;border-radius:50%}
.num-cell:nth-child(odd) .k::before{background:var(--accent-a)}
.num-cell:nth-child(even) .k::before{background:var(--accent-b)}

/* ---------- results ---------- */
.results-list{margin-top:44px;border-top:1px solid var(--ink)}
.result-row{
  display:grid;grid-template-columns:112px 1fr auto;gap:26px;align-items:center;
  padding:28px var(--gutter);border-bottom:1px solid var(--line);
  transition:background .3s;position:relative;
}
.result-row::before{
  content:"";position:absolute;left:0;top:0;bottom:0;width:3px;
  background:linear-gradient(var(--accent-a),var(--accent-b));
  transform:scaleY(0);transition:transform .35s;
}
.result-row:hover{background:var(--bg-soft)}
.result-row:hover::before{transform:scaleY(1)}
.result-row .tag{font-size:10px;font-weight:700;letter-spacing:.12em;border:1px solid var(--ink);border-radius:999px;padding:5px 0;text-align:center}
.result-row .t{font-size:14.5px;font-weight:700;letter-spacing:.02em}
.result-row .m{font-family:var(--en);font-size:10.5px;font-weight:700;letter-spacing:.14em;color:var(--gray)}

/* ---------- news ---------- */
.news-tabs{display:flex;gap:10px;padding:32px var(--gutter) 0;flex-wrap:wrap}
.news-tab{
  font-size:11px;font-weight:700;letter-spacing:.1em;
  border:1px solid var(--ink);border-radius:999px;padding:8px 20px;
  cursor:pointer;background:none;font-family:var(--jp);
  transition:background .25s,color .25s,border-color .25s;
}
.news-tab.active{background:var(--ink);color:var(--paper)}
.news-tab:not(.active):hover{border-color:var(--accent-a);color:var(--accent-a)}
.news-list{margin-top:28px;border-top:1px solid var(--ink)}
.news-list.compact{margin-top:36px}
.news-row{
  display:grid;grid-template-columns:118px 96px 1fr 28px;gap:22px;align-items:center;
  padding:28px var(--gutter);border-bottom:1px solid var(--line);transition:background .3s;
}
.news-row.hidden{display:none}
.news-row:hover{background:var(--bg-soft)}
.news-row .d{font-family:var(--en);font-size:12px;font-weight:700;letter-spacing:.08em;color:var(--gray)}
.news-row .c{font-size:10px;font-weight:700;text-align:center;background:var(--ink);color:var(--paper);border-radius:999px;padding:4px 0;letter-spacing:.08em}
.news-row .c.res{background:var(--accent-b)}
.news-row .c.med{background:var(--accent-a)}
.news-row .t{font-size:14px;font-weight:500}
.news-row .arw{font-family:var(--en);font-weight:900;font-size:15px;transition:transform .3s,color .3s}
.news-row:hover .arw{transform:translateX(7px);color:var(--accent-a)}
.more-link{display:flex;justify-content:flex-end;padding:28px var(--gutter) 56px}

/* ---------- social ---------- */
.social-grid{display:grid;grid-template-columns:repeat(3,1fr);border-top:1px solid var(--ink);margin-top:44px}
.social-col{border-left:1px solid var(--ink);display:flex;flex-direction:column}
.social-col:first-child{border-left:none}
.social-head{padding:32px var(--gutter) 26px;border-bottom:1px solid var(--line)}
.social-head .pf{font-family:var(--en);font-size:clamp(21px,2.4vw,30px);font-weight:900;letter-spacing:-0.03em;display:flex;align-items:center;gap:12px}
.social-head .pf .ico{
  width:30px;height:30px;border:1.5px solid var(--ink);border-radius:8px;
  display:flex;align-items:center;justify-content:center;font-size:13px;font-weight:900;flex:none;
  transition:background .3s,color .3s;
}
.social-col:hover .pf .ico{background:var(--ink);color:var(--paper)}
.social-head .handle{font-family:var(--en);font-size:11px;font-weight:700;letter-spacing:.1em;color:var(--gray);margin-top:8px;display:block}
.social-head .follow{
  margin-top:14px;display:inline-block;
  font-family:var(--en);font-size:10.5px;font-weight:700;letter-spacing:.16em;
  border:1.5px solid var(--ink);border-radius:999px;padding:9px 22px;
  transition:background .25s,color .25s,border-color .25s;
}
.social-col:nth-child(1) .follow:hover{background:var(--ink);color:var(--paper)}
.social-col:nth-child(2) .follow:hover{border-color:var(--accent-a);color:var(--accent-a)}
.social-col:nth-child(3) .follow:hover{border-color:var(--accent-b);color:var(--accent-b)}
.social-body{padding:26px var(--gutter) 36px;display:flex;flex-direction:column;gap:16px;flex:1}
.social-body .embed-note{font-size:11px;color:var(--gray);line-height:1.9;border:1px dashed var(--gray-l);padding:14px 16px}
.social-body .twitter-timeline{width:100%!important}

/* トップ用SNSダイジェスト（3カード横並び） */
.sns-digest{display:grid;grid-template-columns:repeat(3,1fr);border-top:1px solid var(--ink);margin-top:44px}
.sns-digest a{
  padding:36px var(--gutter) 40px;border-left:1px solid var(--line);
  transition:background .3s;display:flex;flex-direction:column;gap:10px;
}
.sns-digest a:first-child{border-left:none}
.sns-digest a:hover{background:var(--bg-soft)}
.sns-digest .pf{font-family:var(--en);font-size:19px;font-weight:900;display:flex;align-items:center;gap:10px}
.sns-digest .pf .ico{
  width:26px;height:26px;border:1.5px solid var(--ink);border-radius:7px;
  display:flex;align-items:center;justify-content:center;font-size:12px;font-weight:900;
  transition:background .3s,color .3s;
}
.sns-digest a:hover .ico{background:var(--ink);color:var(--paper)}
.sns-digest .tx{font-size:12px;color:#555}
.sns-digest .go{font-family:var(--en);font-size:10px;font-weight:700;letter-spacing:.2em;color:var(--gray);transition:color .3s}
.sns-digest a:nth-child(1):hover .go{color:var(--ink)}
.sns-digest a:nth-child(2):hover .go{color:var(--accent-a)}
.sns-digest a:nth-child(3):hover .go{color:var(--accent-b)}

/* note card */
.note-card{border:1px solid var(--line);transition:border-color .3s,transform .3s;display:flex;flex-direction:column}
.note-card:hover{border-color:var(--accent-b);transform:translateY(-3px)}
.note-card .thumb{aspect-ratio:16/9;overflow:hidden;border-bottom:1px solid var(--line);background:var(--bg-soft)}
.note-card .thumb img{width:100%;height:100%;object-fit:cover}
.note-card .nc-body{padding:18px 20px 20px}
.note-card .nc-title{font-size:13px;font-weight:900;line-height:1.7;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}
.note-card .nc-meta{margin-top:10px;font-family:var(--en);font-size:10px;font-weight:700;letter-spacing:.1em;color:var(--gray);display:flex;justify-content:space-between}
.note-card:hover .nc-meta span:last-child{color:var(--accent-b)}

/* ig placeholder grid */
.ig-grid{display:grid;grid-template-columns:1fr 1fr;gap:10px}
.ig-grid .ph{transition:transform .3s,box-shadow .3s}
.ig-grid .ph:hover{transform:scale(1.02);box-shadow:0 0 0 2px var(--accent-a)}

/* ---------- media ---------- */
.media-grid{display:grid;grid-template-columns:repeat(3,1fr);border-top:1px solid var(--ink);margin-top:44px}
.media-cell{border-left:1px solid var(--line);transition:background .3s;display:flex;flex-direction:column}
.media-cell:first-child{border-left:none}
.media-cell:hover{background:var(--bg-soft)}
.media-cell .ph{border-left:none;border-right:none;border-top:none}
.media-cell .thumb{aspect-ratio:16/9;overflow:hidden;border-bottom:1px solid var(--line);background:var(--bg-soft)}
.media-cell .thumb img{width:100%;height:100%;object-fit:cover}
.media-cell .body{padding:26px var(--gutter) 40px}
.media-cell .src{font-family:var(--en);font-size:15px;font-weight:900;letter-spacing:-0.01em}
.media-cell .d{font-family:var(--en);font-size:10.5px;font-weight:700;color:var(--gray);margin-top:4px;letter-spacing:.1em}
.media-cell p{margin-top:14px;font-size:13px;font-weight:500;color:#3d3d3d}

/* ---------- company ---------- */
.company-wrap{display:grid;grid-template-columns:1fr 1fr;gap:clamp(36px,6vw,90px);padding:56px var(--gutter) 88px;align-items:start}
.company-table{width:100%;border-collapse:collapse}
.company-table th,.company-table td{text-align:left;padding:20px 0;font-size:13.5px;border-bottom:1px solid var(--line);vertical-align:top}
.company-table th{width:8em;font-weight:700;color:var(--gray);font-size:11.5px;letter-spacing:.1em}
.company-side .caption{margin-top:12px;font-family:var(--en);font-size:10px;font-weight:700;letter-spacing:.2em;color:var(--gray)}

/* ---------- partner ---------- */
.partner{display:grid;grid-template-columns:1fr 1fr;border-top:1px solid var(--ink)}
.partner a{padding:64px var(--gutter);position:relative;overflow:hidden;transition:color .35s}
.partner a + a{border-left:1px solid var(--ink)}
.partner a::before{content:"";position:absolute;inset:0;transform:translateY(101%);transition:transform .45s cubic-bezier(.22,1,.36,1);z-index:0}
.partner a:nth-child(1)::before{background:var(--accent-a)}
.partner a:nth-child(2)::before{background:var(--accent-b)}
.partner a:hover::before{transform:translateY(0)}
.partner a:hover{color:var(--paper)}
.partner a>*{position:relative;z-index:1}
.partner .label{color:var(--gray);transition:color .35s}
.partner a:hover .label{color:rgba(255,255,255,.7)}
.partner h3{font-size:clamp(20px,2.8vw,34px);font-weight:900;margin:14px 0 10px;letter-spacing:.02em}
.partner p{font-size:13px;opacity:.75;max-width:30em}
.partner .go{margin-top:26px;display:inline-flex;align-items:center;gap:10px;font-family:var(--en);font-size:11px;font-weight:700;letter-spacing:.2em}
.partner .go .arw{transition:transform .3s;font-weight:900}
.partner a:hover .go .arw{transform:translateX(8px)}

/* ---------- contact ---------- */
.contact{
  background:var(--ink);color:var(--paper);
  padding:clamp(90px,13vw,160px) var(--gutter);
  text-align:center;position:relative;overflow:hidden;
}
.contact .glow{position:absolute;border-radius:50%;filter:blur(90px);opacity:.22;pointer-events:none}
.contact .glow.o{width:420px;height:420px;background:var(--accent-a);top:-140px;left:-120px}
.contact .glow.g{width:420px;height:420px;background:var(--accent-b);bottom:-160px;right:-120px}
.contact .label{color:#8a8a8a;position:relative}
.contact h2{
  font-family:var(--en);
  font-size:clamp(48px,12vw,168px);
  font-weight:900;letter-spacing:-0.05em;line-height:.98;
  margin:22px 0 30px;position:relative;
}
.contact h2 .o{color:transparent;-webkit-text-stroke:1.5px var(--paper)}
.contact h2 .period{color:var(--accent-a)}
.contact p{font-size:13.5px;color:#b5b5b5;max-width:36em;margin:0 auto;position:relative}
.contact .corp-name{margin-top:8px;font-size:12px;font-weight:700;letter-spacing:.3em;color:#8a8a8a;position:relative}
.contact .btn-fill{background:var(--paper);color:var(--ink);font-size:13.5px;padding:19px 52px;margin-top:44px}
.contact .btn-fill:hover{box-shadow:0 0 0 2px var(--ink),0 0 0 4px var(--accent-b)}

/* ---------- footer ---------- */
footer{padding:56px var(--gutter) 36px;border-top:1px solid var(--ink)}
.foot-mark{
  font-family:var(--en);font-size:clamp(44px,10vw,130px);font-weight:900;letter-spacing:-0.05em;line-height:1;
  color:transparent;-webkit-text-stroke:1px var(--ink);user-select:none;transition:color .6s;
}
.foot-mark:hover{background:linear-gradient(90deg,var(--accent-a),var(--accent-b));-webkit-background-clip:text;background-clip:text;-webkit-text-stroke:0}
.foot-row{display:flex;justify-content:space-between;align-items:flex-end;flex-wrap:wrap;gap:18px;margin-top:32px}
.foot-row .corp{font-size:12px;font-weight:700;letter-spacing:.2em}
.foot-row .copy{font-family:var(--en);font-size:10.5px;font-weight:500;letter-spacing:.1em;color:var(--gray);margin-top:6px}
.foot-nav{display:flex;gap:22px;flex-wrap:wrap}
.foot-nav a{font-size:11px;font-weight:700;color:var(--gray);transition:color .3s}
.foot-nav a:hover{color:var(--accent-a)}
.foot-sns{display:flex;gap:12px;margin-top:14px}
.foot-sns a{
  width:36px;height:36px;border:1.5px solid var(--ink);border-radius:10px;
  display:flex;align-items:center;justify-content:center;
  font-family:var(--en);font-size:12px;font-weight:900;
  transition:background .25s,color .25s,border-color .25s,transform .25s;
}
.foot-sns a:hover{transform:translateY(-3px)}
.foot-sns a:nth-child(1):hover{background:var(--ink);color:var(--paper)}
.foot-sns a:nth-child(2):hover{border-color:var(--accent-a);color:var(--accent-a)}
.foot-sns a:nth-child(3):hover{border-color:var(--accent-b);color:var(--accent-b)}

/* ==========================================================================
   RESPONSIVE
   ========================================================================== */
@media(max-width:1100px){
  .social-grid{grid-template-columns:1fr}
  .social-col{border-left:none;border-top:1px solid var(--ink)}
  .social-col:first-child{border-top:none}
  .value-grid{grid-template-columns:1fr}
  .value-cell{border-left:none;border-top:1px solid var(--line)}
  .value-cell:first-child{border-top:none}
}
@media(max-width:900px){
  nav.gnav{display:none}
  .logo .corp{display:none}
  .menu-btn{display:flex;flex-direction:column;gap:5px;background:none;border:none;cursor:pointer;padding:8px}
  .menu-btn span{width:26px;height:2px;background:var(--ink);transition:transform .3s,opacity .3s}
  .menu-btn.open span:nth-child(1){transform:translateY(7px) rotate(45deg)}
  .menu-btn.open span:nth-child(2){opacity:0}
  .menu-btn.open span:nth-child(3){transform:translateY(-7px) rotate(-45deg)}
  .m-nav{
    position:fixed;inset:76px 0 0 0;background:var(--paper);z-index:99;
    display:flex;flex-direction:column;padding:32px var(--gutter);
    transform:translateY(-8px);opacity:0;pointer-events:none;transition:.35s;
    border-top:1px solid var(--ink);overflow:auto;
  }
  .m-nav.open{transform:none;opacity:1;pointer-events:auto}
  .m-nav a{font-family:var(--en);font-size:26px;font-weight:900;letter-spacing:-0.02em;padding:14px 0;border-bottom:1px solid var(--line)}
  .m-nav a .jp{font-family:var(--jp);font-size:11px;font-weight:700;color:var(--gray);margin-left:12px;letter-spacing:.1em}

  .hero{grid-template-columns:1fr;padding:110px var(--gutter) 150px;min-height:auto}
  .hero-actions .btn-fill,.hero-actions .btn-outline{padding:12px 22px;font-size:11px}
  .scroll-hint{display:none}
  .ticker{grid-template-columns:auto 1fr}
  .ticker .all{display:none}
  .ticker .h{padding:12px 16px}
  .ticker a.body{padding:12px 16px;gap:12px}

  .statement{grid-template-columns:1fr;padding-top:64px}
  .svc-grid,.svc-digest{grid-template-columns:1fr}
  .svc + .svc,.svc-digest a + a{border-left:none;border-top:1px solid var(--ink)}
  .flow{grid-template-columns:1fr 1fr}
  .flow-cell{border-top:1px solid var(--line)}
  .flow-cell:nth-child(1),.flow-cell:nth-child(2){border-top:none}
  .flow-cell:nth-child(odd){border-left:none}
  .flow-cell .arw{display:none}
  .nums{grid-template-columns:1fr 1fr}
  .num-cell{border-top:1px solid var(--line);padding:36px var(--gutter) 32px}
  .num-cell:nth-child(1),.num-cell:nth-child(2){border-top:none}
  .num-cell:nth-child(odd){border-left:none}
  .media-grid{grid-template-columns:1fr}
  .media-cell{border-left:none!important;border-bottom:1px solid var(--line)}
  .company-wrap{grid-template-columns:1fr;padding-bottom:64px}
  .partner{grid-template-columns:1fr}
  .partner a + a{border-left:none;border-top:1px solid var(--ink)}
  .partner a{padding:48px var(--gutter)}
  .sns-digest{grid-template-columns:1fr}
  .sns-digest a{border-left:none;border-top:1px solid var(--line)}
  .sns-digest a:first-child{border-top:none}

  .news-row{grid-template-columns:88px 1fr 20px;gap:14px;padding:22px var(--gutter)}
  .news-row .c{display:none}
  .result-row{grid-template-columns:88px 1fr;gap:14px;padding:22px var(--gutter)}
  .result-row .m{grid-column:2;justify-self:start}
  .more-link{padding-bottom:44px}
  .company-table th{width:6.5em}
}
@media(max-width:900px){.m-nav{display:flex}}
@media(min-width:901px){.m-nav{display:none}}
@media(max-width:480px){
  .section-head h2{font-size:clamp(34px,11vw,52px)}
  .page-head h1{font-size:clamp(40px,13vw,64px)}
  .hero h1{font-size:clamp(30px,8.6vw,44px)}
  .contact h2{font-size:clamp(40px,14vw,72px)}
  .value-cell,.svc{padding-left:var(--gutter);padding-right:var(--gutter)}
}

@media(prefers-reduced-motion:reduce){
  *,*::before,*::after{animation:none!important;transition:none!important}
  .rv{opacity:1;transform:none}
  .hero h1 .row span{transform:none}
  .ci .ci-in{opacity:1}
  .ci::after{display:none}
  .value-cell::before{width:100%}
  .hero h1 .ul::after{transform:scaleX(1)}
}
