    :root{
      --paper:#F4F3EF; --ink:#0D0D0D; --mute:#8C8C88; --line:#E3E2DD; --panel:#EAE8E2;
      --serif:"Cormorant Garamond","Noto Serif JP",serif;
      --serif-jp:"Noto Serif JP","Cormorant Garamond",serif;
      --sans:"Inter","Noto Sans JP",sans-serif;
      --jp:"Noto Sans JP","Inter",sans-serif;
      --photo-filter:grayscale(.2) saturate(.98) contrast(1.02) brightness(1.03);
    }
    *{ box-sizing:border-box; }
    body{ background:var(--paper); color:var(--ink); font-family:var(--jp); font-weight:300;
      font-size:14px; line-height:1.85; letter-spacing:.02em; -webkit-font-smoothing:antialiased; margin:0; }
    a{ color:inherit; text-decoration:none; }
    img{ max-width:100%; }

    /* ===== ヘッダー ===== */
    .site-header{ position:fixed; inset:0 0 auto 0; z-index:50; padding:24px 40px;
      transition:background .4s,padding .4s,border-color .4s; border-bottom:1px solid transparent; }
    .header-inner{ max-width:1120px; margin:0 auto; display:flex; align-items:center; justify-content:space-between; }
    .site-header.scrolled{ background:rgba(244,243,239,.92); backdrop-filter:saturate(120%) blur(8px);
      -webkit-backdrop-filter:saturate(120%) blur(8px); border-bottom-color:var(--line); padding:14px 40px; }
    .logo{ display:inline-flex; align-items:center; }
    .logo img{ height:40px; width:auto; display:block; transition:height .4s; }
    .site-header.scrolled .logo img{ height:32px; }
    .site-nav{ display:flex; gap:30px; }
    /* ナビは上端では写真に重なるため白＋影。スクロールで黒に戻す */
    .site-nav a{ font:500 11px/1 var(--sans); letter-spacing:.14em; text-transform:uppercase;
      color:#fff; text-shadow:0 1px 12px rgba(0,0,0,.45); transition:opacity .3s, color .4s, text-shadow .4s; }
    .site-header.scrolled .site-nav a{ color:var(--ink); text-shadow:none; }
    .site-nav a:hover{ opacity:.55; }

    /* ハンバーガー（モバイルのみ表示） */
    .nav-toggle{ display:none; flex-direction:column; justify-content:center; gap:6px;
      width:30px; height:30px; padding:0; background:none; border:0; cursor:pointer; z-index:70; }
    .nav-toggle span{ display:block; width:24px; height:1.5px; background:var(--ink); transition:transform .35s, opacity .3s; }
    .nav-toggle.open span:nth-child(1){ transform:translateY(3.75px) rotate(45deg); }
    .nav-toggle.open span:nth-child(2){ transform:translateY(-3.75px) rotate(-45deg); }

    /* モバイル全画面メニュー */
    .mobile-menu{ position:fixed; inset:0; z-index:55; background:var(--paper);
      display:flex; align-items:center; justify-content:center; opacity:0; pointer-events:none; transition:opacity .4s; }
    .mobile-menu.open{ opacity:1; pointer-events:auto; }
    .mobile-menu nav{ display:flex; flex-direction:column; gap:30px; text-align:center; }
    .mobile-menu a{ font:400 40px/1 var(--serif); letter-spacing:.01em; }

    /* ===== FV（グロテスク × 写真）===== */
    .hero{ min-height:100vh; display:grid; grid-template-columns:1.15fr .85fr; align-items:stretch; position:relative; }
    /* 左テキストの左端を1120pxコンテナ（=ロゴ）に揃える */
    .hero-left{ display:flex; flex-direction:column; justify-content:center; padding:120px 48px 64px;
      padding-left:max(40px, calc(50vw - 560px)); }
    .hero-eyebrow{ font:500 11px/1 var(--sans); letter-spacing:.2em; text-transform:uppercase; color:var(--mute);
      display:inline-flex; align-items:center; gap:12px; margin-bottom:38px; }
    .hero-eyebrow .dot{ width:6px;height:6px;border-radius:50%;background:var(--ink);
      animation:blink 2.4s ease-in-out infinite; }
    @keyframes blink{ 0%,100%{opacity:.25;} 50%{opacity:1;} }
    .hero-title{ font:400 clamp(50px,7vw,98px)/1.02 var(--serif); letter-spacing:-.005em; margin:0 0 34px; }
    .hero-title em{ font-style:italic; font-weight:400; }
    /* 行マスク・リビール（動き）。padding-bottomで descender(g等)の見切れを防ぐ */
    .mask-line{ display:block; overflow:hidden; padding-bottom:.16em; margin-bottom:-.10em; }
    .mask-line > span{ display:inline-block; transform:translateY(120%); transition:transform 1.05s cubic-bezier(.16,1,.3,1); }
    .in .mask-line:nth-child(1) > span{ transition-delay:.20s; }
    .in .mask-line:nth-child(2) > span{ transition-delay:.34s; }
    .in .mask-line > span{ transform:translateY(0); }
    .hero-sub{ font:400 15px/2.1 var(--serif-jp); letter-spacing:.08em; color:#3a3a3a; max-width:34ch; margin:0 0 40px;
      line-break:strict; }
    .hero-actions{ display:flex; align-items:center; gap:26px; }
    .link-cta{ font:600 11px/1 var(--sans); letter-spacing:.16em; text-transform:uppercase;
      padding:15px 0; border-bottom:1px solid var(--ink); display:inline-flex; gap:10px; transition:gap .3s; }
    .link-cta:hover{ gap:18px; }
    .link-ghost{ font:600 11px/1 var(--sans); letter-spacing:.16em; text-transform:uppercase; color:var(--mute); }
    .link-ghost:hover{ color:var(--ink); }

    .hero-right{ position:relative; overflow:hidden; background:var(--panel); }
    .photo-wrap{ position:absolute; inset:-12% 0; will-change:transform; } /* scroll視差用ラッパ */
    .hero-photo{ position:absolute; inset:0; width:100%; height:100%; object-fit:cover;
      filter:var(--photo-filter); transform:scale(1.06); animation:kenburns 22s ease-in-out infinite alternate;
      will-change:transform; }
    @keyframes kenburns{ from{ transform:scale(1.06); } to{ transform:scale(1.15); } }

    /* 90度回転して写真の右端に配置（白＋影で写真上でも可読）。translate(50%,-50%)で幅非依存に右30px・縦中央 */
    .scroll-cue{ position:absolute; right:30px; bottom:96px; z-index:5; font:600 10px/1 var(--sans); letter-spacing:.24em;
      text-transform:uppercase; color:#fff; text-shadow:0 1px 10px rgba(0,0,0,.45);
      display:flex; align-items:center; gap:14px; transform:translateX(50%) rotate(90deg); transform-origin:center; }
    .scroll-cue::after{ content:""; width:46px; height:1px; background:#fff; opacity:.6;
      animation:slide 2.4s ease-in-out infinite; transform-origin:left; }
    @keyframes slide{ 0%,100%{transform:scaleX(.3);opacity:.25;} 50%{transform:scaleX(1);opacity:.7;} }

    /* ===== セクション共通 ===== */
    .section{ padding:120px 40px; }
    .section-inner{ max-width:960px; margin:0 auto; }
    .eyebrow{ font:600 10px/1 var(--sans); letter-spacing:.22em; text-transform:uppercase; color:var(--mute); margin:0 0 26px; }
    /* ===== 統一タイプスケール =====
       L1 .section-title : serif 最大（セクション見出し）
       L2 .subhead       : serif 中（節内の小見出し・著書/受賞/認定）caps使わない
       L3 .eyebrow / メタ : 極小caps（セクション冒頭ラベル・メタ専用） */
    .section-title{ font:400 clamp(40px,5.2vw,62px)/1.04 var(--serif); letter-spacing:-.008em; margin:0 0 14px; }
    .section-title em{ font-style:italic; font-weight:400; }
    .section-jp{ font:500 14px/1.9 var(--jp); letter-spacing:.04em; color:var(--mute); }
    .subhead{ font:500 18px/1.4 var(--serif-jp); letter-spacing:.02em; color:var(--ink); margin:0 0 28px; }
    .placeholder{ color:var(--mute); margin-top:36px; }
    .bg-panel{ background:var(--panel); }

    /* 100連発の控えめな中盤バンド */
    .now-band{ padding:74px 40px; border-top:1px solid var(--line); border-bottom:1px solid var(--line); }
    .now-band__inner{ max-width:960px; margin:0 auto; display:flex; align-items:center; justify-content:space-between; gap:30px; flex-wrap:wrap; }
    .now-band__lead{ font:400 clamp(20px,2.4vw,30px)/1.5 var(--serif-jp); letter-spacing:.04em; margin:0; }
    .now-band__lead span{ color:var(--mute); }
    .now-band__link{ font:600 11px/1 var(--sans); letter-spacing:.16em; text-transform:uppercase;
      border-bottom:1px solid var(--ink); padding-bottom:6px; display:inline-flex; gap:8px; white-space:nowrap; transition:gap .3s; }
    .now-band__link:hover{ gap:14px; }

    /* ===== 実績（横スクロール・番号付きインデックス）===== */
    .works-head{ display:flex; align-items:baseline; justify-content:space-between; gap:20px; flex-wrap:wrap; }
    .works-count{ font:600 11px/1 var(--sans); letter-spacing:.18em; text-transform:uppercase; color:var(--mute); }
    /* 1件目を見出し（960pxコンテナ）の左端に揃える。右はフルブリードでスクロール */
    .works-track{ display:flex; gap:26px; padding:54px 40px 10px; overflow-x:auto;
      scrollbar-width:none; cursor:grab;
      padding-left:max(0px, calc(50vw - 520px));
      /* スナップ位置を見出しの左端（=padding-leftと同値）に合わせてカチッと揃える */
      scroll-snap-type:x mandatory; scroll-padding-left:max(0px, calc(50vw - 520px)); }
    .works-track::-webkit-scrollbar{ display:none; }
    .works-track.dragging{ cursor:grabbing; }
    .works-track.dragging .work{ pointer-events:none; }
    .work{ flex:0 0 auto; width:min(74vw,440px); cursor:pointer; scroll-snap-align:start; }
    .work__img{ aspect-ratio:1200/770; overflow:hidden; background:var(--panel); }
    .work__img img{ width:100%; height:100%; object-fit:cover; /* フィルターなし=元の色 */
      transition:transform 1s cubic-bezier(.16,1,.3,1); }
    .work:hover .work__img img{ transform:scale(1.05); }
    .work__meta{ display:flex; align-items:baseline; gap:14px; margin-top:16px; padding-top:16px; border-top:1px solid var(--line); }
    .work__no{ font:600 11px/1 var(--sans); letter-spacing:.1em; color:var(--mute); }
    .work__title{ font:400 21px/1.25 var(--serif); }
    .work__cat{ margin-left:auto; font:600 10px/1 var(--sans); letter-spacing:.16em; text-transform:uppercase; color:var(--mute); white-space:nowrap; }
    .works-hint{ margin-top:24px; }
    .works-hint span{ font:600 10px/1 var(--sans); letter-spacing:.22em; text-transform:uppercase; color:var(--mute); }

    /* ===== 事業内容（3つのつくり方リスト）===== */
    .svc{ border-top:1px solid var(--line); margin-top:54px; }
    /* 2カラム統一: 左(.svc-l)=番号＋名前 / 右=説明。番号は名前とグループ化 */
    .svc-item{ display:grid; grid-template-columns:300px 1fr; gap:64px; align-items:start;
      padding:44px 6px; border-bottom:1px solid var(--line); color:inherit; text-decoration:none;
      transition:padding-left .45s cubic-bezier(.16,1,.3,1); }
    .svc-item:hover{ padding-left:14px; }
    .svc-no{ display:block; font:600 11px/1 var(--sans); letter-spacing:.1em; color:var(--mute); margin-bottom:20px; }
    .svc-name{ margin:0; }
    .svc-name .nm{ display:block; font:400 27px/1.25 var(--serif-jp); margin-bottom:9px; }
    .svc-name .en{ font:600 10px/1 var(--sans); letter-spacing:.18em; text-transform:uppercase; color:var(--mute); }
    .svc-desc{ font:300 14px/1.95 var(--jp); letter-spacing:.03em; color:#333; margin:0; }
    .svc-arrow{ font-size:.55em; vertical-align:.22em; margin-left:.4em; color:var(--mute); display:inline-block; transition:transform .35s; }
    a.svc-item:hover .svc-arrow, .svc-extra:hover .svc-arrow{ transform:translate(4px,-4px); color:var(--ink); }
    /* テンプレート配布: 別枠だが3ウェイズと同じ2カラムに揃える */
    .svc-extra{ display:grid; grid-template-columns:300px 1fr; gap:64px; align-items:start;
      padding:38px 6px 0; color:inherit; text-decoration:none; }
    .svc-extra .lab{ display:block; font:600 10px/1 var(--sans); letter-spacing:.2em; text-transform:uppercase; color:var(--mute); margin-bottom:20px; }
    .svc-extra .nm{ display:block; font:400 21px/1.3 var(--serif-jp); }
    .svc-extra__desc{ font:300 13px/1.85 var(--jp); color:var(--mute); margin:0; }
    @media (max-width:880px){
      .svc-item, .svc-extra{ grid-template-columns:1fr; gap:16px; }
      .svc-item{ padding:34px 0; }
      .svc-extra{ padding:32px 0 0; }
      /* スマホ: 項目名を小さくしセクション見出しとの段差を明確に */
      .svc-name .nm{ font-size:22px; }
    }

    /* ===== プロフィール ===== */
    /* 写真は小さめ・3:4。テキスト列は読みやすい幅に固定し右の空きを解消 */
    .profile-grid{ display:grid; grid-template-columns:230px minmax(0,720px); gap:56px; align-items:start; margin-top:52px; }
    .profile-photo{ aspect-ratio:3/4; overflow:hidden; background:var(--panel); }
    .profile-photo img{ width:100%; height:100%; object-fit:cover; }
    .profile-name{ font:400 30px/1.2 var(--serif-jp); margin:0 0 8px; }
    .profile-name .read{ font:600 11px/1 var(--sans); letter-spacing:.16em; color:var(--mute); margin-left:14px; white-space:nowrap; }
    .profile-role{ font:600 10px/1 var(--sans); letter-spacing:.2em; text-transform:uppercase; color:var(--mute); margin:0 0 28px; }
    .profile-bio{ font:300 14px/2.05 var(--jp); letter-spacing:.03em; color:#333; margin:0; }
    /* ジンドゥーExpert 認定（大きく見せる）*/
    .expert{ display:flex; align-items:center; gap:40px; margin-top:60px; padding:38px 44px; background:var(--panel); flex-wrap:wrap; }
    .expert img{ width:210px; height:auto; flex:0 0 auto; }
    .expert h3{ font:500 18px/1.4 var(--serif-jp); letter-spacing:.02em; color:var(--ink); margin:0 0 10px; }
    .expert p{ font:300 13px/1.9 var(--jp); color:#444; margin:0; max-width:52ch; }
    .cred-block{ margin-top:60px; padding-top:50px; border-top:1px solid var(--line); }
    .cred-block h4{ font:500 18px/1.4 var(--serif-jp); letter-spacing:.02em; color:var(--ink); margin:0 0 30px; }
    .book-row{ display:flex; flex-wrap:wrap; gap:30px; }
    .book{ width:114px; text-decoration:none; color:inherit; }
    .book__cover{ width:114px; height:160px; object-fit:cover; object-position:top; background:var(--panel);
      box-shadow:0 6px 22px rgba(0,0,0,.14); transition:transform .4s cubic-bezier(.16,1,.3,1); display:block; }
    .book:hover .book__cover{ transform:translateY(-7px); }
    .book__ph{ display:flex; align-items:center; justify-content:center; text-align:center; padding:10px; box-sizing:border-box;
      font:300 9px/1.6 var(--jp); color:var(--mute); border:1px solid var(--line); }
    .book__t{ display:block; margin-top:11px; font:300 10px/1.55 var(--jp); color:#3a3a3a; }
    .book__pub{ display:block; margin-top:3px; font:600 9px/1.4 var(--sans); letter-spacing:.08em; color:var(--mute); }
    /* 受賞 */
    .award-row{ display:grid; grid-template-columns:repeat(3,1fr); gap:40px; margin:0; }
    .award .yr{ display:block; font:600 10px/1 var(--sans); letter-spacing:.14em; color:var(--mute); margin-bottom:10px; }
    .award dt{ font:400 16px/1.45 var(--serif-jp); margin-bottom:5px; }
    .award dd{ margin:0; font:600 10px/1.6 var(--sans); letter-spacing:.08em; text-transform:uppercase; color:var(--mute); }
    .cred-note{ margin:18px 0 0; font:300 12px/1.7 var(--jp); color:var(--mute); }
    @media (max-width:880px){
      .profile-grid{ grid-template-columns:1fr; gap:30px; }
      /* スマホ: 写真は中央寄せ（テキストは左のまま）*/
      .profile-photo{ max-width:210px; margin-left:auto; margin-right:auto; }
      /* スマホ: 名前を小さくしセクション見出しとの段差を明確に */
      .profile-name{ font-size:24px; }
      /* スマホ: Expertはバッジ（ロゴ）だけ中央寄せ・テキストは左 */
      .expert{ padding:28px; gap:20px; flex-direction:column; align-items:stretch; text-align:left; }
      .expert img{ width:170px; align-self:center; }
      .award-row{ grid-template-columns:1fr; gap:28px; }
      /* スマホ: 著書は2列・カバー少し小さめ・余白を左中右で均等に（space-evenly）*/
      .book-row{ display:flex; flex-wrap:wrap; justify-content:space-evenly; column-gap:0; row-gap:28px; margin:0 -22px; }
      .book{ width:140px; }
      .book__cover{ width:100%; height:auto; aspect-ratio:114/160; }
    }

    /* ===== 会社概要（About）===== */
    /* 問い合わせ（Tally埋め込み）*/
    /* 問い合わせ: 左=見出し / 右=フォーム の2カラム */
    .contact-grid{ display:grid; grid-template-columns:280px 1fr; gap:56px; align-items:start; }
    .contact-lead{ font:300 14px/1.95 var(--jp); letter-spacing:.03em; color:#444; margin:24px 0 0; }
    .contact-note{ font:300 12px/1.8 var(--jp); letter-spacing:.02em; color:var(--mute); margin:20px 0 0; }
    .contact-form{ margin:0; }
    .contact-form iframe{ width:100%; border:0; }
    @media (max-width:880px){
      .contact-grid{ grid-template-columns:1fr; gap:34px; }
    }

    /* 2カラムで横幅を満たす（右の空き解消）*/
    .info-table{ margin:50px 0 0; border-top:1px solid var(--line); display:grid; grid-template-columns:1fr 1fr; column-gap:64px; }
    /* ラベルの真下に値を積んで密着（組みを明確に）*/
    .info-table > div{ padding:22px 4px; border-bottom:1px solid var(--line); }
    .info-table dt{ font:600 10px/1.6 var(--sans); letter-spacing:.16em; text-transform:uppercase; color:var(--mute); margin:0 0 9px; }
    .info-table dd{ margin:0; font:300 14px/1.85 var(--jp); letter-spacing:.03em; color:#2a2a2a; }
    @media (max-width:880px){
      .info-table{ grid-template-columns:1fr; column-gap:0; }
      .info-table > div{ grid-template-columns:1fr; gap:7px; padding:20px 0; }
    }

    /* ===== 実績モーダル（ライトボックス）===== */
    .lightbox{ position:fixed; inset:0; z-index:80; background:rgba(10,10,11,.93);
      display:flex; align-items:center; justify-content:center; padding:6vh 5vw;
      opacity:0; pointer-events:none; transition:opacity .35s; }
    .lightbox.open{ opacity:1; pointer-events:auto; }
    .lightbox figure{ margin:0; max-width:1100px; }
    .lightbox img{ display:block; max-width:100%; max-height:82vh; object-fit:contain;
      box-shadow:0 30px 80px rgba(0,0,0,.5); transform:scale(.97); transition:transform .35s; }
    .lightbox.open img{ transform:none; }
    .lightbox figcaption{ display:flex; align-items:baseline; gap:14px; margin-top:18px; color:#fff; }
    .lightbox figcaption .t{ font:400 18px/1.2 var(--serif); }
    .lightbox figcaption .x{ margin-left:auto; font:600 10px/1 var(--sans); letter-spacing:.16em; text-transform:uppercase; color:rgba(255,255,255,.6); }
    .lightbox__close{ position:absolute; top:22px; right:28px; width:40px; height:40px; background:none; border:0;
      color:#fff; font-size:30px; line-height:1; cursor:pointer; opacity:.8; transition:opacity .3s; }
    .lightbox__close:hover{ opacity:1; }

    /* ===== 動き（最小）===== */
    .rise{ opacity:0; transform:translateY(20px); transition:opacity .9s cubic-bezier(.16,1,.3,1),transform .9s cubic-bezier(.16,1,.3,1); }
    .rise.in{ opacity:1; transform:none; }
    .rise.d1{transition-delay:.08s;} .rise.d2{transition-delay:.18s;} .rise.d3{transition-delay:.28s;} .rise.d4{transition-delay:.38s;}
    .reveal{ opacity:0; transform:translateY(24px); transition:opacity .9s ease,transform .9s cubic-bezier(.16,1,.3,1); }
    .reveal.in{ opacity:1; transform:none; }
    @media (prefers-reduced-motion:reduce){ *,::before,::after{animation:none!important;transition:none!important;} .rise,.reveal{opacity:1!important;transform:none!important;} }

    @media (max-width:880px){
      .hero{ grid-template-columns:1fr; }
      .hero-right{ min-height:42vh; order:-1; }       /* MV天地を抑え、WORKS→ボタンをFV内に */
      /* 表示領域を最上部へ＋ズーム基準も上にして窓の外を見せる */
      .hero-photo{ object-position:center top; transform-origin:center top; }
      /* SPは写真の上側（植物〜机）を見せ、テーブル下の余白をカット */
      .photo-wrap{ inset:-2% 0 -22% 0; }
      .hero-left{ padding:40px 22px 52px; }            /* コピー上下のマージンを詰める */
      .hero-eyebrow{ margin-bottom:22px; }
      .hero-title{ margin-bottom:20px; }
      .hero-sub{ margin-bottom:28px; }
      .site-header,.section{ padding-left:22px; padding-right:22px; }
      /* セクションの右paddingを相殺して右端までブリード。最後の項目のトレーリングは22pxで残す */
      .works-track{ padding-left:0; padding-right:22px; margin-right:-22px; }
      .scroll-cue{ display:none; }
      /* モバイル: ヘッダーは地色つき（ロゴが写真に埋もれないように）＋ハンバーガー */
      .site-header{ background:rgba(244,243,239,.96); backdrop-filter:saturate(120%) blur(8px);
        -webkit-backdrop-filter:saturate(120%) blur(8px); border-bottom:1px solid var(--line); padding:14px 22px; z-index:60; }
      .logo img{ height:30px; }
      .site-nav{ display:none; }
      .nav-toggle{ display:flex; }
    }
