/* =========================================================
   東京建材協同組合（仮）— 自主制作コンセプトワーク
   デザイン言語：書籍装丁家。極大の余白／明朝×英字／極細罫線／
   墨・紺・生成りの3色／動きは「紙をめくる」フェード一点のみ。
   ========================================================= */

:root{
  --paper:#f7f5f0;        /* 生成りの地 */
  --paper-2:#f1eee7;      /* 章替えの地（わずかに沈める）*/
  --ink:#1a1a1a;          /* 墨：本文・見出し */
  --ink-2:#2b2a27;
  --ink-soft:#56534c;     /* 弱め本文・キャプション（地に対し約7:1）*/
  --navy:#1b2a4a;         /* 紺：唯一のアクセント */
  --navy-deep:#16223c;
  --line:#e2dfd6;         /* 極細罫線 */
  --serif:"Shippori Mincho","Noto Serif JP",serif;
  --sans:"Noto Sans JP",sans-serif;
  --en:"Inter",sans-serif;
  --maxw:1180px;
  --pad:clamp(24px,6vw,80px);
  --sec:clamp(96px,15vw,200px);   /* 圧倒的なセクション余白 */
}

*{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:smooth}
body{
  font-family:var(--sans);color:var(--ink);background:var(--paper);
  line-height:1.9;letter-spacing:.02em;-webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
}
img{display:block;max-width:100%}
a{color:inherit;text-decoration:none}
::selection{background:var(--navy);color:#fff}

.inner{max-width:var(--maxw);margin:0 auto;padding:0 var(--pad)}
.en{font-family:var(--en)}

/* 画像枠：CLS回避（aspect-ratioで先に高さ確保）*/
.frame{position:relative;overflow:hidden;background:var(--paper-2)}
.frame img{width:100%;height:100%;object-fit:cover;display:block}

/* =========================================================
   ヘッダー（細い・スクロールで地がつく）
   ========================================================= */
.site-head{
  position:fixed;top:0;left:0;width:100%;z-index:50;
  transition:background .4s ease,border-color .4s ease,box-shadow .4s ease;
  border-bottom:1px solid transparent;
}
.site-head.scrolled{
  background:rgba(247,245,240,.92);backdrop-filter:blur(8px);
  border-bottom-color:var(--line);box-shadow:0 1px 0 rgba(0,0,0,.01);
}
.head-in{max-width:var(--maxw);margin:0 auto;padding:18px var(--pad);
  display:flex;align-items:center;justify-content:space-between;gap:24px}
.brand{display:flex;flex-direction:column;line-height:1.25}
.brand .ja{font-family:var(--serif);font-weight:600;font-size:19px;letter-spacing:.12em}
.brand .en{font-family:var(--en);font-size:9.5px;letter-spacing:.34em;color:var(--ink-soft);
  text-transform:uppercase;margin-top:3px}
.gnav{display:flex;align-items:center;gap:30px}
.gnav a{font-size:13px;letter-spacing:.08em;color:var(--ink-2);position:relative;padding:4px 0}
.gnav a::after{content:"";position:absolute;left:0;right:100%;bottom:-1px;height:1px;
  background:var(--navy);transition:right .35s ease}
.gnav a:hover::after,.gnav a:focus-visible::after{right:0}
.gnav .nav-cta{font-family:var(--en);font-size:11px;letter-spacing:.18em;text-transform:uppercase;
  color:var(--navy);border:1px solid var(--navy);padding:9px 18px;border-radius:1px}
.gnav .nav-cta::after{display:none}
.gnav .nav-cta:hover{background:var(--navy);color:#fff}
.burger{display:none}

/* =========================================================
   汎用：セクション見出し（番号＋英字ラベル → 明朝 日英併記）
   ========================================================= */
.sec{padding:var(--sec) 0;scroll-margin-top:72px}
.sec.tinted{background:var(--paper-2)}

.shead{margin-bottom:clamp(48px,7vw,84px);max-width:760px}
.shead .kicker{display:flex;align-items:center;gap:14px;margin-bottom:22px}
.shead .num{font-family:var(--en);font-size:12px;letter-spacing:.1em;color:var(--navy)}
.shead .kicker .rule{flex:0 0 40px;height:1px;background:var(--navy);opacity:.5}
.shead .lbl{font-family:var(--en);font-size:11px;letter-spacing:.28em;text-transform:uppercase;
  color:var(--ink-soft)}
.shead h2{font-family:var(--serif);font-weight:600;font-size:clamp(27px,4.2vw,42px);
  line-height:1.4;letter-spacing:.04em}
.shead h2 .slash{color:var(--navy);font-family:var(--en);font-weight:400;
  font-size:.5em;letter-spacing:.06em;margin-left:.5em;opacity:.85}
.shead .desc{margin-top:22px;font-size:15px;color:var(--ink-soft);line-height:2}

/* =========================================================
   HERO（本の扉ページ：大判明朝＋縦書きの署名＋口絵プレート）
   ========================================================= */
.hero{position:relative;padding:clamp(140px,20vh,200px) 0 clamp(80px,10vw,120px)}
.hero-grid{display:grid;grid-template-columns:auto 1fr;gap:clamp(28px,5vw,64px);align-items:start}

/* 縦書きの署名（signature）*/
.hero-sign{writing-mode:vertical-rl;text-orientation:mixed;
  font-family:var(--serif);font-size:13px;letter-spacing:.42em;color:var(--ink-soft);
  height:100%;padding-top:8px;display:flex;align-items:flex-start;gap:18px;
  position:relative}
.hero-sign::before{content:"";writing-mode:horizontal-tb;display:block;
  width:1px;height:64px;background:var(--navy);opacity:.55;margin-bottom:6px}
.hero-sign b{font-weight:600;color:var(--ink-2)}

.hero-body{max-width:880px}
.hero .eyebrow{font-family:var(--en);font-size:11px;letter-spacing:.32em;text-transform:uppercase;
  color:var(--navy);margin-bottom:34px}
.hero h1{font-family:var(--serif);font-weight:600;
  font-size:clamp(40px,8.2vw,96px);line-height:1.22;letter-spacing:.05em;color:var(--ink)}
.hero h1 ruby rt{font-family:var(--sans);font-weight:400;font-size:.17em;letter-spacing:.28em;
  color:var(--ink-soft);text-align:center}
.hero h1 .sm{display:block;font-size:clamp(13px,1.5vw,19px);letter-spacing:.05em;
  color:var(--ink-soft);font-family:var(--en);font-weight:400;margin-top:26px;line-height:1.75}
.hero .lead{margin-top:40px;font-size:16px;line-height:2.1;color:var(--ink-soft);max-width:520px}
.hero .hr{width:64px;height:1px;background:var(--navy);margin:44px 0 0}

/* 口絵プレート（巻頭のtipped-in plateの体裁）*/
.plate{margin-top:clamp(56px,8vw,96px)}
.plate .frame{aspect-ratio:21/9;border:1px solid var(--line)}
.plate .cap{display:flex;justify-content:space-between;gap:16px;flex-wrap:wrap;
  margin-top:14px;font-family:var(--en);font-size:10.5px;letter-spacing:.18em;
  text-transform:uppercase;color:var(--ink-soft)}
.plate .cap .pl{color:var(--navy)}

/* =========================================================
   組合の特長（罫線で仕切る編集的リスト：カード反復を避ける）
   ========================================================= */
.features{border-top:1px solid var(--line)}
.frow{display:grid;grid-template-columns:80px 1fr;gap:clamp(16px,4vw,56px);
  padding:clamp(30px,4.5vw,54px) 0;border-bottom:1px solid var(--line);align-items:baseline}
.frow .fn{font-family:var(--en);font-size:13px;letter-spacing:.06em;color:var(--navy);padding-top:6px}
.frow .fbody{display:grid;grid-template-columns:minmax(0,300px) 1fr;
  gap:clamp(14px,3vw,48px);align-items:baseline}
.frow h3{font-family:var(--serif);font-weight:600;font-size:clamp(20px,2.6vw,26px);
  letter-spacing:.05em;line-height:1.6}
.frow h3 small{display:block;font-family:var(--en);font-size:11px;letter-spacing:.2em;
  text-transform:uppercase;color:var(--ink-soft);margin-top:8px;font-weight:400}
.frow p{font-size:15px;color:var(--ink-soft);line-height:2.05}

/* =========================================================
   事業案内（非対称：テキストと写真を左右で入れ替え）
   ========================================================= */
.biz{display:flex;flex-direction:column;gap:clamp(80px,11vw,150px)}
.brow{display:grid;grid-template-columns:1fr 1fr;gap:clamp(36px,6vw,90px);align-items:center}
.brow.flip .btext{order:2}
.brow .frame{aspect-ratio:5/4;border:1px solid var(--line)}
.brow .bno{font-family:var(--en);font-size:12px;letter-spacing:.22em;color:var(--navy);
  text-transform:uppercase;margin-bottom:18px}
.brow h3{font-family:var(--serif);font-weight:600;font-size:clamp(23px,3.2vw,32px);
  letter-spacing:.05em;line-height:1.5;margin-bottom:8px}
.brow .h-en{font-family:var(--en);font-size:11px;letter-spacing:.24em;text-transform:uppercase;
  color:var(--ink-soft);margin-bottom:24px}
.brow p{font-size:15px;color:var(--ink-soft);line-height:2.1;max-width:460px}
.brow .more{display:inline-flex;align-items:center;gap:9px;margin-top:26px;
  font-family:var(--en);font-size:11px;letter-spacing:.16em;text-transform:uppercase;color:var(--navy)}
.brow .more .arr{width:24px;height:1px;background:var(--navy);transition:width .3s ease}
.brow .more:hover .arr{width:38px}

/* =========================================================
   組合員のメリット（余白で間を持たせた2列、装飾最小）
   ========================================================= */
.mem{display:grid;grid-template-columns:repeat(2,1fr);
  column-gap:clamp(40px,7vw,110px);row-gap:0}
.mitem{padding:clamp(28px,3.5vw,40px) 0;border-top:1px solid var(--line);
  display:grid;grid-template-columns:46px 1fr;gap:20px;align-items:baseline}
.mitem .mn{font-family:var(--en);font-size:12px;color:var(--navy);letter-spacing:.06em}
.mitem h3{font-family:var(--serif);font-weight:600;font-size:18px;letter-spacing:.04em;
  margin-bottom:8px;line-height:1.6}
.mitem p{font-size:14px;color:var(--ink-soft);line-height:1.95}

/* =========================================================
   お知らせ（日付＝明朝が効く。極細罫線のリスト）
   ========================================================= */
.news{border-top:1px solid var(--line)}
.nrow{display:grid;grid-template-columns:150px 96px 1fr auto;gap:clamp(14px,2.5vw,34px);
  align-items:baseline;padding:24px 0;border-bottom:1px solid var(--line);
  transition:background .3s ease}
.nrow:hover{background:var(--paper-2)}
.nrow .date{font-family:var(--serif);font-size:17px;letter-spacing:.06em;color:var(--ink)}
.nrow .cat{font-family:var(--en);font-size:10px;letter-spacing:.16em;text-transform:uppercase;
  color:var(--navy);border:1px solid var(--line);padding:4px 0;text-align:center;border-radius:1px}
.nrow .nt{font-size:15px;color:var(--ink-2);line-height:1.7}
.nrow .arr{font-family:var(--en);font-size:12px;color:var(--ink-soft)}
.news-more{margin-top:38px}
.news-more a{font-family:var(--en);font-size:11px;letter-spacing:.18em;text-transform:uppercase;
  color:var(--navy);border-bottom:1px solid var(--navy);padding-bottom:4px}

/* =========================================================
   組合概要（概要表 ＋ 沿革タイムライン）
   ========================================================= */
.about-grid{display:grid;grid-template-columns:1fr 1fr;gap:clamp(48px,8vw,110px)}
.about-lead{font-family:var(--serif);font-weight:600;font-size:clamp(20px,2.6vw,25px);
  line-height:2;letter-spacing:.05em;margin-bottom:34px}
table.spec{width:100%;border-collapse:collapse;font-size:14.5px}
table.spec th,table.spec td{text-align:left;padding:16px 0;vertical-align:top;
  border-top:1px solid var(--line)}
table.spec tr:last-child th,table.spec tr:last-child td{border-bottom:1px solid var(--line)}
table.spec th{width:108px;font-weight:500;color:var(--ink-soft);white-space:nowrap;
  font-family:var(--en);font-size:11px;letter-spacing:.14em;text-transform:uppercase;padding-top:19px}
table.spec td{color:var(--ink-2);line-height:1.8}

.hist-h{font-family:var(--en);font-size:11px;letter-spacing:.26em;text-transform:uppercase;
  color:var(--ink-soft);margin-bottom:24px}
.timeline{border-left:1px solid var(--line);padding-left:30px;display:flex;flex-direction:column;gap:30px}
.tstep{position:relative}
.tstep::before{content:"";position:absolute;left:-34px;top:9px;width:7px;height:7px;
  border-radius:50%;background:var(--navy)}
.tstep .ty{font-family:var(--serif);font-size:20px;color:var(--navy);letter-spacing:.04em;line-height:1}
.tstep .td{font-size:14px;color:var(--ink-soft);margin-top:7px;line-height:1.8}

/* =========================================================
   加入案内（紺の章。明朝の呼びかけ＋相談フォーム）
   ========================================================= */
.join{background:var(--navy);color:#fff;scroll-margin-top:72px}
.join .shead .num,.join .shead .lbl{color:rgba(255,255,255,.66)}
.join .shead .kicker .rule{background:#fff;opacity:.5}
.join .shead h2{color:#fff}
.join .shead h2 .slash{color:rgba(255,255,255,.7)}
.join-grid{display:grid;grid-template-columns:1fr 1fr;gap:clamp(44px,7vw,96px);align-items:start}
.join .pitch{font-family:var(--serif);font-weight:600;font-size:clamp(22px,3vw,30px);
  line-height:1.9;letter-spacing:.05em;margin-bottom:28px}
.join .pnote{font-size:14.5px;color:rgba(255,255,255,.78);line-height:2.05;
  border-left:1px solid rgba(255,255,255,.4);padding-left:18px}
.join .tel{margin-top:34px;font-size:13px;color:rgba(255,255,255,.7);letter-spacing:.04em}
.join .tel a{font-family:var(--serif);font-size:22px;color:#fff;letter-spacing:.06em}

.jform label{display:block;font-size:12px;letter-spacing:.1em;
  color:rgba(255,255,255,.82);margin-bottom:22px}
.jform input,.jform textarea{display:block;width:100%;margin-top:9px;
  background:rgba(255,255,255,.06);border:1px solid rgba(255,255,255,.26);border-radius:1px;
  color:#fff;font-family:var(--sans);font-size:14.5px;padding:13px 15px;transition:border-color .3s}
.jform input::placeholder,.jform textarea::placeholder{color:rgba(255,255,255,.4)}
.jform input:focus,.jform textarea:focus{outline:none;border-color:#fff}
.jform .submit{margin-top:6px;background:#fff;color:var(--navy);border:1px solid #fff;
  font-family:var(--en);font-size:12px;letter-spacing:.18em;text-transform:uppercase;
  padding:15px 34px;border-radius:1px;cursor:pointer;transition:background .3s,color .3s}
.jform .submit:hover{background:transparent;color:#fff}
.jform .done{margin-top:18px;font-size:13.5px;color:#d7e0f0}

/* =========================================================
   フッター
   ========================================================= */
.site-foot{background:var(--ink);color:rgba(255,255,255,.7);padding:clamp(56px,8vw,84px) 0 36px}
.foot-top{display:grid;grid-template-columns:1.4fr 1fr 1fr;gap:40px;
  padding-bottom:42px;border-bottom:1px solid rgba(255,255,255,.12)}
.foot-brand .ja{font-family:var(--serif);font-weight:600;font-size:20px;letter-spacing:.12em;color:#fff}
.foot-brand .en{font-family:var(--en);font-size:9.5px;letter-spacing:.32em;text-transform:uppercase;
  margin-top:6px;color:rgba(255,255,255,.55)}
.foot-brand address{font-style:normal;font-size:13px;line-height:1.9;margin-top:20px;color:rgba(255,255,255,.62)}
.fcol h4{font-family:var(--en);font-size:10px;letter-spacing:.24em;text-transform:uppercase;
  color:rgba(255,255,255,.5);margin-bottom:16px}
.fcol a{display:block;font-size:13.5px;color:rgba(255,255,255,.78);padding:5px 0;transition:color .25s}
.fcol a:hover{color:#fff}
.foot-bottom{display:flex;justify-content:space-between;gap:16px;flex-wrap:wrap;
  margin-top:28px;font-size:11.5px;color:rgba(255,255,255,.5);letter-spacing:.04em}
.disclaimer{font-size:11.5px;color:rgba(255,255,255,.5);line-height:1.85;margin-top:22px;max-width:680px}

/* モバイル固定CTA（控えめに一本だけ）*/
.mcta{display:none}

/* =========================================================
   モーション：ヒーロー＋見出しの「めくるような」フェード一点のみ。
   no-JS耐性：reveal は html.js 配下のみ初期非表示にする。
   ========================================================= */
.reveal{opacity:0;transform:translateY(26px)}
html:not(.js) .reveal{opacity:1;transform:none}   /* JS無効/失敗時は必ず表示 */
html.js .reveal{opacity:0;transform:translateY(26px);
  transition:opacity 1.1s cubic-bezier(.2,.65,.2,1),transform 1.1s cubic-bezier(.2,.65,.2,1)}
html.js .reveal.show{opacity:1;transform:none}

/* ヒーローの入場はCSSのみ（html.jsで発火＝main.js不達でも表示）*/
html.js .hero-anim{opacity:0;transform:translateY(30px);
  animation:pageturn 1.2s cubic-bezier(.2,.65,.2,1) forwards}
html.js .hero .eyebrow{animation-delay:.05s}
html.js .hero h1{animation-delay:.18s}
html.js .hero .lead{animation-delay:.42s}
html.js .hero .hr{animation-delay:.56s}
html.js .hero .plate{animation-delay:.6s}
html.js .hero-sign{animation-delay:.7s}
@keyframes pageturn{from{opacity:0;transform:translateY(30px)}to{opacity:1;transform:none}}

/* =========================================================
   レスポンシブ
   ========================================================= */
@media(max-width:900px){
  .gnav{position:fixed;inset:0 0 0 auto;width:min(78vw,320px);background:var(--paper);
    flex-direction:column;align-items:flex-start;justify-content:center;gap:8px;
    padding:0 40px;transform:translateX(100%);transition:transform .4s cubic-bezier(.4,0,.2,1);
    box-shadow:-12px 0 50px rgba(0,0,0,.12);z-index:60}
  .gnav.open{transform:none}
  .gnav a{font-size:17px;font-family:var(--serif);letter-spacing:.06em;padding:12px 0}
  .gnav .nav-cta{margin-top:14px;font-family:var(--en);font-size:12px}
  .burger{display:flex;flex-direction:column;gap:6px;background:none;border:0;cursor:pointer;
    padding:8px;z-index:61}
  .burger span{width:26px;height:1.5px;background:var(--ink);transition:transform .3s,opacity .3s}
  .burger.open span:nth-child(1){transform:translateY(7.5px) rotate(45deg)}
  .burger.open span:nth-child(2){opacity:0}
  .burger.open span:nth-child(3){transform:translateY(-7.5px) rotate(-45deg)}

  .hero-grid{grid-template-columns:1fr}
  .hero-sign{writing-mode:horizontal-tb;flex-direction:row;align-items:center;gap:12px;
    height:auto;padding-top:0;margin-bottom:24px;letter-spacing:.24em}
  .hero-sign::before{height:1px;width:40px;margin:0}
  .frow .fbody{grid-template-columns:1fr;gap:10px}
  .brow,.brow.flip{grid-template-columns:1fr;gap:28px}
  .brow.flip .btext{order:0}
  .brow .frame{order:-1}
  .about-grid{grid-template-columns:1fr;gap:clamp(48px,8vw,64px)}
  .join-grid{grid-template-columns:1fr}
  .foot-top{grid-template-columns:1fr;gap:30px}
}
@media(max-width:620px){
  .mem{grid-template-columns:1fr}
  .nrow{grid-template-columns:auto 1fr;gap:10px 16px;row-gap:4px}
  .nrow .cat{grid-row:1;justify-self:start;padding:4px 10px}
  .nrow .date{grid-row:1}
  .nrow .nt{grid-column:1/-1}
  .nrow .arr{display:none}
  .plate .frame{aspect-ratio:4/3}
  /* モバイル固定CTA */
  .mcta{display:block;position:fixed;left:0;right:0;bottom:0;z-index:55}
  .mcta a{display:block;text-align:center;background:var(--navy);color:#fff;
    font-family:var(--serif);font-size:15px;letter-spacing:.1em;padding:16px;height:54px}
  body{padding-bottom:54px}
  .gnav{padding-bottom:54px}
}

@media(prefers-reduced-motion:reduce){
  html{scroll-behavior:auto}
  html.js .reveal,html.js .hero-anim{opacity:1!important;transform:none!important;
    animation:none!important;transition:none!important}
}
