/* =====================================================================
   JDA web : 新版コンポジション
   Syft 参照のレイアウト言語（分割ヒーロー、マニフェスト帯、サービス
   アコーディオン、三柱カード、ダークなチーム帯、大判透かし）を、
   JDA ブランド（ロイヤルブルー主役 + 真鍮ゴールドの認証 + スウッシュ）で
   再構成する。色・字形・余白・モーションは jda.css のトークンを参照し、
   装飾ドロップシャドウは使わず罫線と背景差で分離する。
   calc / clamp 内の + と - は前後に半角スペースを必ず置く（CSS 仕様）。
   ===================================================================== */

/* ---- スウッシュ・モチーフ ---- */
.sw{display:block;color:var(--accent);line-height:0}
.sw svg{display:block;width:100%;height:auto}

/* ---- リードヒーロー（全面写真・大型タイポ）---- */
.xhero{position:relative;min-height:100vh;min-height:100svh;display:flex;align-items:center;background:var(--navy-deep);overflow:hidden;isolation:isolate}
.xhero-media{position:absolute;inset:0;z-index:0;background-image:url(../img/hero-home.jpg);background-image:image-set(url(../img/hero-home.webp) type("image/webp"), url(../img/hero-home.jpg) type("image/jpeg"));background-size:cover;background-position:center}
/* 明るいブランドブルーに白文字を載せるため、左・上・下にダークスクリムを重ねる */
.xhero-scrim{position:absolute;inset:0;background:linear-gradient(102deg, rgba(8,13,40,0.5) 0%, rgba(8,13,40,0.3) 36%, rgba(8,13,40,0.08) 68%, rgba(8,13,40,0.02) 100%),linear-gradient(to bottom, rgba(8,13,40,0.32) 0%, rgba(8,13,40,0) 22%, rgba(8,13,40,0) 60%, rgba(8,13,40,0.28) 100%)}
.xhero-inner{position:relative;z-index:1;width:100%;display:flex;flex-direction:column;align-items:flex-start;gap:clamp(1.6rem, 1rem + 2.2vh, 2.6rem);padding-block:calc(var(--header-h) + clamp(1.5rem, 5vh, 3.5rem)) clamp(3rem, 8vh, 6rem)}
.xhero-title{font-family:var(--ff-display);font-weight:600;font-size:clamp(2.6rem, 1rem + 7.4vw, 7rem);line-height:1.08;letter-spacing:0.005em;color:#fff;max-width:17ch;text-shadow:0 2px 36px rgba(6,11,34,0.4)}
.xhero-title .accent{color:#fff}
.xhero-title .u{position:relative;color:#fff;font-weight:700}
.xhero-title .u::after{content:"";position:absolute;left:0;right:0;bottom:0.02em;height:0.055em;background:var(--seal);opacity:0.95}
.xhero-lede{font-family:var(--ff-body);font-weight:400;font-size:clamp(1.04rem, 0.96rem + 0.42vw, 1.28rem);color:rgba(255,255,255,0.92);line-height:1.85;max-width:50ch;margin:clamp(0.75rem, 1.8vh, 1.9rem) 0 0;text-shadow:0 1px 22px rgba(6,11,34,0.45)}
.xhero-link{display:inline-flex;align-items:center;gap:1.1rem;color:#fff;font-family:var(--ff-body);font-weight:600;font-size:0.96rem;letter-spacing:0.04em}
.xhero-link-label{position:relative}
.xhero-link-label::after{content:"";position:absolute;left:0;right:0;bottom:-3px;height:1px;background:rgba(255,255,255,0.5);transform:scaleX(0);transform-origin:left;transition:transform .45s var(--ease)}
.xhero-link:hover .xhero-link-label::after{transform:scaleX(1)}
.xhero-arrow{flex-shrink:0;width:3rem;height:3rem;display:grid;place-items:center;color:#fff;border:1.5px solid rgba(255,255,255,0.6);border-radius:50%;transition:background var(--dur) var(--ease),border-color var(--dur) var(--ease),color var(--dur) var(--ease),transform var(--dur) var(--ease)}
.xhero-arrow svg{width:1.15rem;height:1.15rem}
.xhero-link:hover .xhero-arrow{background:#fff;border-color:#fff;color:var(--navy-ink);transform:translateX(5px)}

/* ---- HOME: 写真ヒーローに重なる透過ヘッダー（既存メニューを維持）---- */
.is-home .top-rule{display:none}
.is-home .site-header{position:fixed;top:0;left:0;right:0;background:rgba(255,255,255,0);backdrop-filter:blur(0px);-webkit-backdrop-filter:blur(0px);border-bottom:1px solid rgba(255,255,255,0.18);transition:background var(--dur) var(--ease),backdrop-filter var(--dur) var(--ease),-webkit-backdrop-filter var(--dur) var(--ease),border-color var(--dur) var(--ease),box-shadow var(--dur) var(--ease)}
.is-home .site-header.scrolled{background:rgba(255,255,255,0.92);backdrop-filter:blur(14px);-webkit-backdrop-filter:blur(14px);border-bottom-color:var(--line)}
/* 透過→白の切替を滑らかに: 変化する各プロパティに transition を付与（両方向に効く） */
.is-home .site-header .nav-item>a,.is-home .site-header .nav-item>a::after,.is-home .site-header .brand .org,.is-home .site-header .brand img{transition:color var(--dur) var(--ease),background-color var(--dur) var(--ease),border-color var(--dur) var(--ease),filter var(--dur) var(--ease)}
.is-home .site-header:not(.scrolled) .nav-item>a,.is-home .site-header:not(.scrolled) .nav-item:hover>a,.is-home .site-header:not(.scrolled) .nav-item.current>a{color:#fff}
.is-home .site-header:not(.scrolled) .nav-item>a::after{background:#fff}
.is-home .site-header:not(.scrolled) .brand .org{color:#fff;border-left-color:rgba(255,255,255,0.4)}
.is-home .site-header:not(.scrolled) .brand img{filter:brightness(0) invert(1)}
.is-home .site-header:not(.scrolled) .burger span{background:#fff}
.is-home .site-header:not(.scrolled) .nav-cta .btn-solid{background:transparent;border-color:rgba(255,255,255,0.55);color:#fff}
.is-home .site-header:not(.scrolled) .nav-cta .btn-solid:hover{background:#fff;border-color:#fff;color:var(--navy-ink)}

/* ---- マニフェスト帯 ---- */
.manifesto{background:var(--paper);text-align:center}
.manifesto .wrap{max-width:62rem;padding-block:clamp(3.5rem, 2.6rem + 3vw, 6rem)}
.manifesto .mmark{display:inline-block;width:60px;margin:0 auto 1.6rem;color:var(--accent)}
.manifesto p{font-family:var(--ff-display);font-weight:500;font-size:clamp(1.5rem, 1.1rem + 1.9vw, 2.5rem);line-height:1.6;color:var(--ink)}
.manifesto p .accent{color:var(--accent)}
.manifesto .sub{font-family:var(--ff-body);font-weight:400;font-size:0.98rem;color:var(--mute);line-height:1.9;margin-top:1.8rem;max-width:46rem;margin-inline:auto}

/* ---- サービス（見出し＋リードを上、アコーディオンを全幅で下に縦積み）---- */
.svc-split{display:grid;grid-template-columns:1fr;gap:clamp(2.5rem, 1.8rem + 2.5vw, 4rem);align-items:start}
/* 左見出しは固定しない（通常スクロール。スクロールで右のトグルと一緒に上へ流れる） */
.svc-split .svc-head .kicker{margin-bottom:1.4rem;display:inline-flex}
.svc-split .svc-head h2{font-family:var(--ff-display);font-weight:600;font-size:clamp(1.9rem, 1.4rem + 1.8vw, 2.9rem);line-height:1.3;color:var(--ink);letter-spacing:0.01em}
.svc-split .svc-head p{margin-top:1.5rem;color:var(--text);font-size:1.02rem;line-height:1.95;max-width:55ch}
.svc-split .svc-head .link{margin-top:2rem}

/* ---- 三柱カード（上に細い差し色罫）---- */
.pillars{display:grid;grid-template-columns:repeat(3,1fr);gap:var(--space-m)}
.pillar{position:relative;background:var(--card);border:1px solid var(--line);border-top:3px solid var(--accent);border-radius:0 0 var(--r) var(--r);padding:var(--space-l);display:flex;flex-direction:column;gap:0.7rem;transition:transform var(--dur) var(--ease),border-color var(--dur) var(--ease)}
.pillar:hover{transform:translateY(-5px);border-color:var(--line-2);border-top-color:var(--accent)}
.pillar .p-no{font-family:var(--ff-latin);font-feature-settings:"tnum" 1,"lnum" 1;font-size:0.82rem;font-weight:700;color:var(--accent);letter-spacing:0.04em}
.pillar h3{font-family:var(--ff-display);font-size:1.34rem;font-weight:600;color:var(--ink);letter-spacing:0.005em;line-height:1.4}
.pillar p{font-size:0.94rem;color:var(--text);line-height:1.85;flex:1}
.pillar .go{margin-top:0.6rem;display:inline-flex;align-items:center;gap:0.5rem;font-size:0.9rem;font-weight:700;color:var(--accent);transition:gap .3s var(--ease)}
.pillar .go svg{width:1.05em;height:1.05em;transition:transform var(--dur) var(--ease)}
.pillar:hover .go{gap:0.85rem}
.pillar:hover .go svg{transform:translateX(4px)}

/* ---- CTA にスウッシュを添える（jda.css の .cta を継承）---- */
.cta.cta--sw{position:relative}
.cta.cta--sw .cta-sw{position:absolute;left:50%;bottom:-24%;width:128%;transform:translateX(-50%);color:#fff;opacity:0.06;pointer-events:none;z-index:0}
.cta.cta--sw .wrap{position:relative;z-index:1}

/* ---- フッターの大判透かし ---- */
.site-footer{overflow:hidden}
.site-footer .wrap{position:relative;z-index:1}
.footer-watermark{position:absolute;right:-3%;bottom:-12%;width:min(64%,760px);opacity:0.05;pointer-events:none;z-index:0;line-height:0}
.footer-watermark img{width:100%;height:auto;display:block}

/* ---- 役員/チーム帯（ダーク。about ページで使用）---- */
.team{background:var(--navy-deep);color:#fff;position:relative;overflow:hidden}
.team::before{content:"";position:absolute;top:0;left:50%;transform:translateX(-50%);width:200px;height:2px;background:linear-gradient(90deg,transparent,var(--accent),transparent)}
.team .wrap{position:relative;z-index:1}
.team .sec-head h2{color:#fff}
.team .sec-head p{color:rgba(255,255,255,0.7);max-width:66ch}
.team .sec-head .kicker{color:var(--sky)}
.team .sec-head .kicker::before{background:var(--sky)}
.members{display:grid;grid-template-columns:repeat(3,1fr);gap:var(--space-xl) clamp(3rem, 1.5rem + 5vw, 7rem)}
.member{display:flex;flex-direction:column;max-width:300px}
.member .m-photo{position:relative;aspect-ratio:4/5;max-width:190px;overflow:hidden;border-radius:var(--r);background:linear-gradient(155deg,var(--navy-ink),var(--navy-deep))}
.member .m-photo img{width:100%;height:100%;object-fit:cover;display:block;transition:transform .6s var(--ease)}
.member:hover .m-photo img{transform:scale(1.04)}
.member .m-name{font-family:var(--ff-display);font-size:1.2rem;font-weight:600;color:#fff;margin-top:1.2rem;letter-spacing:0.01em}
.member .m-role{font-family:var(--ff-label);font-size:0.8rem;color:#aeb9ff;margin-top:0.4rem;letter-spacing:0.04em}
.member .m-bio{font-size:0.9rem;color:rgba(255,255,255,0.66);line-height:1.8;margin-top:0.9rem}

/* ---- ミッション/ビジョン（大きな宣言）---- */
.mission-lead{font-family:var(--ff-display);font-weight:500;font-size:clamp(1.5rem, 1.15rem + 1.6vw, 2.3rem);line-height:1.6;color:var(--ink);letter-spacing:0.005em;max-width:30ch}
.mission-lead .hl{color:var(--accent);font-weight:600}

/* ---- 行動の4原則: テキスト + 画像スロット ---- */
/* 各セルは「テキスト左 + 画像右」。上に差し色のヘアライン。
   .p-img に <img> を入れれば写真に、無ければ差し替え用プレースホルダを表示。 */
.principles{display:grid;grid-template-columns:repeat(2,1fr);gap:var(--space-xl) var(--gutter)}
.principle{position:relative;display:grid;grid-template-columns:1fr 0.82fr;gap:var(--space-l);align-items:start;border-top:1px solid var(--line-2);padding-top:1.6rem}
.principle::before{content:"";position:absolute;top:-1px;left:0;width:32px;height:1px;background:var(--accent)}
.principle .p-no{font-family:var(--ff-num);font-feature-settings:"tnum" 1,"lnum" 1;font-size:0.92rem;font-weight:500;color:var(--accent);letter-spacing:0.04em;display:block;margin-bottom:0.5rem}
.principle h3{font-family:var(--ff-display);font-size:1.4rem;font-weight:600;color:var(--ink);margin-bottom:0.8rem;letter-spacing:0.005em;line-height:1.4}
.principle p{font-size:0.96rem;color:var(--text);line-height:1.9}
.principle .p-img{aspect-ratio:3/2;border-radius:var(--r-sm);overflow:hidden;background:var(--card);border:1px solid var(--line-2);display:flex;flex-direction:column;align-items:center;justify-content:center;gap:0.5rem;color:var(--mute)}
.principle .p-img svg{width:30px;height:30px;stroke:currentColor;fill:none;stroke-width:1.4;opacity:0.7}
.principle .p-img .cap{font-family:var(--ff-label);font-size:0.68rem;letter-spacing:0.12em;text-transform:uppercase}
.principle .p-img img{width:100%;height:100%;object-fit:cover;display:block}
@media(max-width:900px){.principles{grid-template-columns:1fr}}
@media(max-width:560px){.principle{grid-template-columns:1fr;gap:var(--space-m)}}

/* ---- グローバルプレゼンス（about の抑制版バンド）---- */
.presence{background:var(--paper-2);border-top:1px solid var(--line);border-bottom:1px solid var(--line);text-align:center}
.presence .wrap{padding-block:var(--space-sm)}
.presence .p-local{font-family:var(--ff-label);font-size:0.74rem;letter-spacing:0.14em;color:var(--accent);text-transform:uppercase;font-weight:600;margin-bottom:1.2rem;display:inline-block}
.presence h2{font-family:var(--ff-display);font-weight:600;font-size:clamp(1.7rem, 1.3rem + 1.5vw, 2.6rem);color:var(--ink);line-height:1.3}
.presence h2 .accent{color:var(--accent)}
.presence p{color:var(--text);max-width:48rem;margin:1.4rem auto 0;line-height:1.9}

/* ---- 連絡先メタ（contact ページ）---- */
.contact-grid{display:grid;grid-template-columns:0.85fr 1.15fr;gap:var(--gutter);align-items:start}
.contact-info{display:flex;flex-direction:column;gap:1.8rem}
.contact-info .ci{border-top:1px solid var(--line-2);padding-top:1.1rem;position:relative}
.contact-info .ci::before{content:"";position:absolute;top:-1px;left:0;width:32px;height:1px;background:var(--accent)}
.contact-info .ci .ci-k{font-family:var(--ff-label);font-size:0.74rem;letter-spacing:0.1em;color:var(--accent);text-transform:uppercase;font-weight:600}
.contact-info .ci .ci-v{font-size:1rem;color:var(--ink);margin-top:0.5rem;line-height:1.7;font-weight:500}
.contact-info .ci .ci-v a:hover{color:var(--accent)}
/* 極小幅(320px等)でのグリッド/フレックスのはみ出し防止。
   select の長い選択肢などで track が min-content まで広がるのを抑える。 */
.contact-grid > *{min-width:0}
.form,.form .row2,.form .field{min-width:0}
.form input,.form select,.form textarea{min-width:0;max-width:100%}

/* ドロワーの遷移項目はボタンでなくリンク（遷移はリンクの責務）。.acc>button と同じ見た目に */
.drawer .acc > a.acc-link{display:flex;align-items:center;padding:1.1rem 0;font-family:var(--ff-body);font-size:1rem;font-weight:700;color:var(--navy)}
.drawer .acc > a.acc-link:hover{color:var(--accent)}

/* ---- jda.css の微調整（本サイト用オーバーライド。真実源は変更しない）---- */
/* sticky を有効化: body の overflow-x:hidden は overflow-y を auto に計算させ
   body をスクロールコンテナ化し、子の position:sticky を無効化する。
   横はみ出しは隠したいので clip に置換（clip はスクロールコンテナを作らない）。 */
body{overflow-x:clip}
.num-cell{padding-top:1.7rem}
/* 数字帯の左上にある差し色アクセントバーを非表示 */
.numbers-sec::before{display:none}

/* アンカー着地位置をスティッキーヘッダー分だけ下げる */
.anchor{scroll-margin-top:calc(var(--header-h) + 2rem)}

/* お知らせ一覧のホバーを滑らかに。
   layout 値(padding)のアニメをやめ、背景の出現を ease-out で減速。
   見出し色と矢印は transform/opacity（compositor-friendly）で。
   開いた行の合図は accordion/FAQ と同じ inset 罫（左の差し色バー）。 */
.news-list .news-row{padding-left:1.5rem;padding-right:1.6rem;transition:background .5s var(--ease-out), box-shadow .5s var(--ease-out)}
.news-list .news-row:hover{padding-left:1.5rem;padding-right:1.6rem;box-shadow:inset 3px 0 0 var(--accent)}
.news-list .news-row .ttl{transition:color .45s var(--ease-out), transform .45s var(--ease-out)}
.news-list .news-row:hover .ttl{transform:translateX(5px)}
.news-list .news-row .date,.news-list .news-row .tag{transition:opacity .45s var(--ease-out)}
.news-list .news-row:hover .date{opacity:0.8}
.news-list .news-row .arw{transition:opacity .45s var(--ease-out), transform .45s var(--ease-out)}
.news-list .news-row:hover .arw{opacity:1;transform:translateX(5px)}

/* about ページ: ミッションの2カラム左見出し */
.mission-grid{display:grid;grid-template-columns:0.95fr 1.05fr;gap:var(--gutter);align-items:start}
@media(max-width:900px){.mission-grid{grid-template-columns:1fr;gap:2.5rem}}
.member .m-role-tag{font-family:var(--ff-label);font-size:0.7rem;letter-spacing:0.1em;text-transform:uppercase;color:var(--seal);font-weight:700;margin-top:1rem}

/* =====================================================================
   記事詳細（ブログ記事 / お知らせ詳細）
   参照スクショのエディトリアル構成（前後ページャ・タグ・大見出し・メタ・
   ドロップキャップ・全幅フィギュア）を JDA の字形と罫線で再構成する。
   テキストは可読幅 var(--maxw-text) の中央カラム、図版は --maxw まで広げる。
   ===================================================================== */

/* 上部の記事ページャ（薄い帯。左に前へ・右に次へ） */
.article-pager{border-bottom:1px solid var(--line);background:var(--paper)}
.article-pager .wrap{display:flex;justify-content:space-between;align-items:stretch;padding:0}
.article-pager .pg{display:inline-flex;align-items:center;gap:0.7rem;padding:1.15rem var(--pad);font-family:var(--ff-label);font-size:0.72rem;letter-spacing:0.18em;text-transform:uppercase;color:var(--mute);font-weight:600;transition:color var(--dur) var(--ease),background var(--dur) var(--ease)}
.article-pager .pg svg{width:1.05em;height:1.05em;transition:transform var(--dur) var(--ease)}
.article-pager .pg.prev{border-right:1px solid var(--line)}
.article-pager .pg.next{border-left:1px solid var(--line)}
.article-pager .pg:hover{color:var(--accent);background:var(--paper-2)}
.article-pager .pg.prev:hover svg{transform:translateX(-4px)}
.article-pager .pg.next:hover svg{transform:translateX(4px)}

/* 記事本体。テキストカラムは可読幅で中央寄せ */
.article{padding-top:clamp(2.4rem,1.8rem + 2.6vw,4.4rem);position:relative}
.article .art-col{max-width:calc(var(--maxw-text) + 2 * var(--pad))}
.article .breadcrumb{margin-bottom:2rem}

/* タグピル（ロイヤルブルーの面） */
.art-tag{display:inline-block;font-family:var(--ff-label);font-size:0.68rem;letter-spacing:0.14em;text-transform:uppercase;font-weight:700;color:#fff;background:var(--accent);padding:0.42rem 1.05rem;border-radius:var(--pill)}

/* 見出し */
.art-title{font-family:var(--ff-display);font-weight:600;font-size:clamp(1.95rem,1.4rem + 2.5vw,3.1rem);line-height:1.34;color:var(--ink);letter-spacing:0.01em;margin-top:1.5rem}

/* メタ帯（日付・コメント・カテゴリ・共有） */
.art-meta{display:flex;align-items:center;gap:1.5rem;margin-top:1.9rem;padding-bottom:2.2rem;border-bottom:1px solid var(--line);flex-wrap:wrap}
.art-meta .m{display:inline-flex;align-items:center;gap:0.5rem;font-size:0.82rem;color:var(--mute);font-family:var(--ff-body)}
.art-meta .m .ico{display:inline-flex;width:1.05rem;height:1.05rem;color:var(--accent)}
.art-meta .m .ico svg{width:100%;height:100%}
.art-meta .m.date{font-family:var(--ff-latin);font-weight:600;letter-spacing:0.02em;color:var(--text)}
.art-share{margin-left:auto;display:inline-flex;gap:0.55rem}
.art-share .sh{position:relative;width:34px;height:34px;display:grid;place-items:center;border:1px solid var(--line-2);border-radius:50%;background:transparent;color:var(--mute);cursor:pointer;font:inherit;transition:color var(--dur) var(--ease),background var(--dur) var(--ease),border-color var(--dur) var(--ease),transform var(--dur) var(--ease)}
.art-share .sh svg{width:0.95rem;height:0.95rem}
.art-share .sh:hover{color:#fff;background:var(--accent);border-color:var(--accent);transform:translateY(-2px)}
.art-share .sh.copied{color:#fff;background:var(--green);border-color:var(--green)}
/* コピー完了トースト */
.art-share .sh-toast{position:absolute;bottom:calc(100% + 8px);left:50%;transform:translateX(-50%) translateY(4px);background:var(--ink);color:#fff;font-family:var(--ff-body);font-size:0.7rem;font-weight:600;letter-spacing:0.04em;white-space:nowrap;padding:0.35rem 0.7rem;border-radius:6px;opacity:0;pointer-events:none;transition:opacity .25s var(--ease),transform .25s var(--ease)}
.art-share .sh.copied .sh-toast{opacity:1;transform:translateX(-50%) translateY(0)}

/* リード（強調導入文。太めのサンセリフ） */
.art-lead{font-family:var(--ff-body);font-weight:600;font-size:clamp(1.08rem,1rem + 0.45vw,1.26rem);line-height:1.9;color:var(--ink);margin:2.3rem 0 0.5rem}

/* 本文 */
.article-body{font-size:1.04rem;margin-top:1.8rem}

/* フィギュア（画像はテキストカラムと同じ幅 704px = --maxw-text におさめる） */
.art-figure{margin:3rem 0}
.art-figure .wrap{max-width:calc(var(--maxw-text) + 2 * var(--pad))}
.art-figure img{width:100%;border-radius:var(--r-sm);display:block;background:var(--paper-2)}
.art-figure figcaption{font-size:0.82rem;color:var(--mute);margin-top:1rem;padding-left:1rem;border-left:2px solid var(--accent);line-height:1.7;max-width:60ch}

/* 開催概要などの定義リストは本文内で上下余白を整える */
.article-body .art-dl{margin:1.6rem 0 2rem}
.article-body .art-dl .row{grid-template-columns:140px 1fr;gap:1.4rem;padding:1.15rem 0.2rem}

/* 記事内の申込み誘導バンド（イベント記事） */
.art-apply{margin-top:2.6rem;display:flex;align-items:center;justify-content:space-between;gap:1.5rem;flex-wrap:wrap;background:var(--accent-soft);border:1px solid var(--line-2);border-left:3px solid var(--accent);border-radius:var(--r-sm);padding:clamp(1.3rem,1rem + 1.2vw,1.9rem) clamp(1.4rem,1.1rem + 1.2vw,2.1rem)}
.art-apply .aa-t{font-family:var(--ff-display);font-weight:600;font-size:1.18rem;color:var(--ink);letter-spacing:0.01em}
.art-apply .aa-d{font-size:0.92rem;color:var(--text);line-height:1.75;margin-top:0.4rem}
.art-apply .btn{flex-shrink:0}

/* 入会案内: 入会の流れの番号サークル（feature-list の .ic を流用） */
.join-steps .fl .ic{background:var(--accent-soft)}
.join-steps .fl .ic .no{font-family:var(--ff-latin);font-feature-settings:"tnum" 1,"lnum" 1;font-weight:800;font-size:1.15rem;color:var(--navy-ink)}

/* 末尾の前後記事カード */
.art-foot-pager{margin-top:var(--space);border-top:1px solid var(--line);border-bottom:1px solid var(--line)}
.art-foot-pager .wrap{display:grid;grid-template-columns:1fr 1fr;padding:0}
.art-foot-pager .fp{display:flex;flex-direction:column;gap:0.45rem;padding:clamp(1.8rem,1.4rem + 1.5vw,2.8rem) var(--pad);transition:background var(--dur) var(--ease)}
.art-foot-pager .fp:hover{background:var(--paper-2)}
.art-foot-pager .fp.prev{border-right:1px solid var(--line)}
.art-foot-pager .fp.next{text-align:right;align-items:flex-end}
.art-foot-pager .fp .dir{display:inline-flex;align-items:center;gap:0.5rem;font-family:var(--ff-label);font-size:0.68rem;letter-spacing:0.16em;text-transform:uppercase;color:var(--accent);font-weight:700}
.art-foot-pager .fp .dir svg{width:1em;height:1em;transition:transform var(--dur) var(--ease)}
.art-foot-pager .fp.prev:hover .dir svg{transform:translateX(-4px)}
.art-foot-pager .fp.next:hover .dir svg{transform:translateX(4px)}
.art-foot-pager .fp .d{font-family:var(--ff-latin);font-size:0.78rem;color:var(--mute);font-weight:600}
.art-foot-pager .fp .t{font-family:var(--ff-display);font-size:1.08rem;font-weight:600;color:var(--ink);line-height:1.5;letter-spacing:0.005em;transition:color var(--dur) var(--ease)}
.art-foot-pager .fp:hover .t{color:var(--accent)}

@media(max-width:640px){
  .art-foot-pager .wrap{grid-template-columns:1fr}
  .art-foot-pager .fp.prev{border-right:none;border-bottom:1px solid var(--line)}
  .art-foot-pager .fp.next{text-align:left;align-items:flex-start}
  .article-pager .pg span{display:none}
  .article-pager .pg{padding-inline:1.3rem}
  .art-meta{gap:1rem 1.2rem}
  .art-share{margin-left:0;width:100%}
}

/* ---- レスポンシブ ---- */
@media(max-width:900px){
  .xhero-title{max-width:18ch}
  .svc-split{grid-template-columns:1fr;gap:2.5rem}
  .svc-split .svc-head{position:static}
  .pillars{grid-template-columns:1fr}
  .members{grid-template-columns:1fr}
  .contact-grid{grid-template-columns:1fr;gap:2.5rem}
}
@media(max-width:560px){
  .xhero-title{max-width:none}
  .xhero-arrow{width:2.7rem;height:2.7rem}
}

/* ---- 和文約物アキの調整 ---- */
/* 明朝ディスプレイ書体（--ff-display）の見出しに palt を適用し、読点・句点後の不自然な広アキを詰める。
   jda.css / jda-web.css 双方の --ff-display 使用セレクタを集約。新規見出しを足したらここにも追記する。 */
.display,.hero h1,.seal-cap .t1,.sec-head h2,.feature h3,.idx h3,.card h3,
.numbers-lead .quote,.split-card h3,.cta h2,.page-header h1,.prose h2,
.tier .t-name,.login-card h2,.sitemap-col h3,.two-col .lead-h,.accordion .ac-t,
.feature-list .fl .ft,.media-row .m-text h3,.edit-quote,.stepper .step-title,.empty h3,
.xhero-title,.svc-split .svc-head h2,.pillar h3,.member .m-name,
.mission-lead,.principle h3,.presence h2,
.art-title,.art-foot-pager .fp .t{font-feature-settings:"palt" 1;font-kerning:normal}

/* ---- 修正依頼対応: カード数の変更にともなうレイアウト調整 ---- */
/* About三本柱 → 二本柱。3列グリッドのまま2枚だと右に間延びするため、
   2列・最大幅を設けて重心を保ち、左揃え（見出しと同じ起点）にする。 */
.pillars.pillars--2{grid-template-columns:repeat(2,minmax(0,1fr));max-width:760px;margin-inline:0}

/* 会員種別 正会員のみ（1枚）。3列グリッドだと横に間延びするため、
   単独カードを読みやすい幅にし、左揃え（見出しと同じ起点）にする。 */
.tiers.tiers--single{grid-template-columns:minmax(0,520px);justify-content:start}

@media(max-width:760px){
  .pillars.pillars--2{grid-template-columns:1fr;max-width:420px}
}
