  :root{
    --paper:#EFEEEC; --ink:#1A1A1C; --soft:#6B6A66; --faint:#A9A79F; --accent:#B5121B; --line:#CDCAC2;
    --didone:"Bodoni Moda","Playfair Display",serif;
    --serif:"Cormorant Garamond","Yu Mincho",serif;
    --jp:"Yu Mincho",YuMincho,"Hiragino Mincho ProN","Noto Serif JP",serif;
    --mono:"IBM Plex Mono",ui-monospace,monospace;
  }
  *{box-sizing:border-box;margin:0;padding:0}
  body{background:#E4E2DC;color:var(--ink);-webkit-font-smoothing:antialiased;overflow-x:auto;-webkit-text-size-adjust:100%}
  .stage{width:1180px;max-width:1180px;margin:0 auto;background:var(--paper);box-shadow:0 0 60px rgba(0,0,0,.08)}
  .canvas{position:relative;width:100%;aspect-ratio:864/2180;container-type:inline-size;background:var(--paper);font-family:var(--jp);overflow:hidden}
  .a{position:absolute}
  img.a{height:auto}
  #spine{position:absolute;inset:0;width:100%;height:100%;z-index:0;pointer-events:none}

  .t-wm{font-family:var(--didone);font-size:9.6cqw;letter-spacing:.005em;line-height:.92;font-weight:500}
  .t-wmsub{font-family:var(--mono);font-size:1.08cqw;letter-spacing:.5em;color:var(--soft)}
  .t-nav{font-family:var(--mono);font-size:0.99cqw;letter-spacing:.24em;color:var(--soft);text-transform:uppercase}
  .t-nav span{margin-right:1.6cqw}
  .red{color:var(--accent)}
  .t-eye{font-family:var(--mono);font-size:0.99cqw;letter-spacing:.24em;text-transform:uppercase}
  .t-bigjp{font-family:var(--jp);font-size:2.7cqw;font-weight:500;line-height:1.45;letter-spacing:.04em}
  .t-subjp{font-family:var(--jp);font-size:1.24cqw;font-weight:300;line-height:2.05;letter-spacing:.06em;color:var(--soft)}
  .t-sectitle{font-family:var(--mono);font-size:1.41cqw;letter-spacing:.22em;text-transform:uppercase;color:var(--ink)}
  .t-secjp{font-family:var(--jp);font-size:1.23cqw;letter-spacing:.12em;color:var(--soft)}
  .t-body{font-family:var(--jp);font-size:1.23cqw;font-weight:300;line-height:1.95;color:var(--soft)}
  .t-mono{font-family:var(--mono);font-size:0.95cqw;letter-spacing:.06em;line-height:1.85;color:var(--soft)}
  .t-monolab{font-family:var(--mono);font-size:0.92cqw;letter-spacing:.18em;color:var(--faint);text-transform:uppercase}
  .t-fig{font-family:var(--mono);font-size:0.92cqw;font-style:italic;letter-spacing:.1em;color:var(--faint)}
  .t-coord{font-family:var(--mono);font-size:1.08cqw;letter-spacing:.1em;line-height:1.9;color:var(--soft)}
  .box{border:1px solid var(--line);padding:.7cqw .8cqw;background:rgba(239,238,236,.5)}
  .code{display:inline-block;border:1px solid var(--accent);color:var(--accent);padding:.05em .4em;font-size:0.92cqw;letter-spacing:.1em}
  /* enlarged right-column scale */
  .t-rtitle{font-family:var(--mono);font-size:1.32cqw;letter-spacing:.2em;text-transform:uppercase;color:var(--ink)}
  .t-rjp{font-family:var(--jp);font-size:1.15cqw;letter-spacing:.1em;color:var(--soft)}
  .t-rbody{font-family:var(--jp);font-size:1.38cqw;font-weight:300;line-height:1.95;color:var(--soft)}
  .t-rmono{font-family:var(--mono);font-size:1.29cqw;letter-spacing:.06em;line-height:1.9;color:var(--soft)}

  .t-temple-lab{font-family:var(--mono);font-size:1.19cqw;letter-spacing:.4em;text-transform:uppercase;color:var(--faint);text-align:center}
  .t-formula{font-family:var(--didone);font-size:5.4cqw;line-height:1;text-align:center}
  .t-formula .op{color:var(--accent);font-style:italic}
  .t-formula sup{font-size:.4em;vertical-align:.7em;text-decoration:underline;text-underline-offset:.12em}
  .t-arrow{font-family:var(--didone);font-size:3.9cqw;color:var(--faint);text-align:center}
  .t-formula2{font-family:var(--didone);font-size:4.2cqw;line-height:1;text-align:center}
  .t-formula2 .op{color:var(--accent);font-style:italic}
  .t-formula2 sup{font-size:.4em;vertical-align:.7em;text-decoration:underline;text-underline-offset:.12em}

  .t-decl{font-family:var(--serif);font-size:2.2cqw;line-height:1.4;text-align:center;color:var(--ink);pointer-events:none}
  .t-decl .it{font-style:italic}
  .t-decl .dash{display:block;color:var(--faint);font-size:.5em;margin:.6cqw 0}
  .t-finale{font-family:var(--didone);font-size:3.9cqw;letter-spacing:.2em;color:var(--accent);text-align:center;pointer-events:none}
  .t-finsub{font-family:var(--mono);font-size:1.41cqw;letter-spacing:.5em;color:var(--soft);text-align:center}
  .t-finname{font-family:var(--serif);font-size:1.61cqw;font-style:italic;letter-spacing:.14em;color:var(--ink);text-align:center;pointer-events:none}
  .t-findef{font-family:var(--jp);font-size:1.35cqw;font-weight:300;line-height:2.1;letter-spacing:.05em;color:var(--soft);text-align:center;pointer-events:none}
  .t-finhr{height:1px;background:var(--line);pointer-events:none}
  .t-inf{font-family:var(--didone);font-size:2.4cqw;color:var(--ink);text-align:center;pointer-events:none}

  .hr{height:1px;background:var(--line)}
  .vfade{opacity:.95}
  .a svg{display:block;width:100%;height:100%;overflow:visible}
  .scrollv{font-family:var(--mono);font-size:0.92cqw;letter-spacing:.4em;color:var(--faint);writing-mode:vertical-rl}
  .panhint{position:fixed;left:50%;bottom:16px;transform:translateX(-50%);font-family:var(--mono);font-size:11px;letter-spacing:.12em;color:#6B6A66;background:rgba(239,238,236,.92);border:1px solid #CDCAC2;padding:7px 13px;z-index:60;display:none;transition:opacity .8s;white-space:nowrap}
  @media(max-width:1179px){.panhint{display:block}}
  @media(max-width:640px){.stage{box-shadow:none}}

  /* =================================================================
     MOBILE / TABLET REFLOW  ―  案C 縦1カラム再構築
     PC(>=1180px)は一切不変。下記は追加のみ。
     ================================================================= */
  .mobile{display:none}

  /* TIER 2 ― 小型ノート/横持ちタブレット(1024-1179px)
     既存ポスターを画面幅にフィットさせ横スクロールを解消(構図は同一) */
  @media(min-width:1024px) and (max-width:1179px){
    .stage{width:100%;max-width:100%}
    .panhint{display:none}
  }

  /* TIER 3 ― スマホ/縦持ちタブレット(<=1023px) : 縦1カラムへ切替 */
  @media(max-width:1023px){
    body{overflow-x:hidden}
    .stage{display:none}
    .panhint{display:none}
    .mobile{display:block;background:var(--paper);color:var(--ink);font-family:var(--jp)}
  }

  /* ---- mobile inner layout ---- */
  .m-wrap{max-width:700px;margin:0 auto;padding:0 22px 90px;container-type:inline-size}
  .m-sec{padding:38px 0;border-top:1px solid var(--line)}
  .m-sec.m-first{border-top:0;padding-top:30px}
  .m-lab{font-family:var(--mono);font-size:11px;letter-spacing:.28em;text-transform:uppercase;color:var(--faint)}
  .m-jplab{font-family:var(--mono);font-size:12px;letter-spacing:.26em;color:var(--accent);text-transform:none}
  .m-sectitle{font-family:var(--mono);font-size:13px;letter-spacing:.22em;text-transform:uppercase;color:var(--ink)}
  .m-secjp{font-family:var(--jp);font-size:13px;letter-spacing:.1em;color:var(--soft);margin-top:3px}
  .m-h1{font-family:var(--didone);font-size:15.2cqw;line-height:.92;font-weight:500;letter-spacing:.01em;white-space:nowrap}
  .m-h2{font-family:var(--jp);font-size:clamp(22px,6vw,32px);font-weight:500;line-height:1.5;letter-spacing:.03em}
  .m-h3{font-family:var(--jp);font-size:clamp(19px,5.2vw,26px);font-weight:500;line-height:1.55;letter-spacing:.03em}
  .m-sub{font-family:var(--jp);font-size:clamp(14px,3.8vw,16px);font-weight:300;line-height:2.05;color:#403f37;letter-spacing:.04em}
  .m-body{font-family:var(--jp);font-size:clamp(14px,3.9vw,16px);font-weight:300;line-height:1.95;color:var(--soft)}
  .m-mono{font-family:var(--mono);font-size:12.5px;letter-spacing:.05em;line-height:2;color:var(--soft)}
  .m-coord{font-family:var(--mono);font-size:12px;letter-spacing:.18em;line-height:1.9;color:var(--soft)}
  .m-img{width:100%;display:block;background:#e4e2dc}
  .m-gap{margin-top:14px}.m-gap-s{margin-top:8px}.m-gap-l{margin-top:24px}
  .mobile .red{color:var(--accent)}

  /* masthead */
  .m-head{padding-top:24px}
  .m-subrow{display:flex;justify-content:space-between;align-items:baseline;margin-top:8px}
  .m-wmsub{font-family:var(--mono);font-size:11px;letter-spacing:.42em;color:var(--soft)}
  .m-hero{padding-top:20px;padding-bottom:0}

  /* specimen card + formula */
  .m-card{border:1px solid var(--line);background:rgba(239,238,236,.5);padding:14px 16px}
  .m-didtag{font-family:var(--didone);font-size:20px;letter-spacing:.12em;margin:2px 0}
  .m-code{display:inline-block;border:1px solid var(--accent);color:var(--accent);padding:3px 8px;font-family:var(--mono);font-size:11px;letter-spacing:.1em;margin-top:8px}
  .m-formula{font-family:var(--didone);font-size:clamp(34px,11vw,54px);line-height:1.05;text-align:center;color:var(--ink)}
  .m-formula .op{color:var(--accent);font-style:italic}
  .m-formula sup{font-size:.42em;vertical-align:.7em}
  .m-formarrow{font-family:var(--didone);font-size:30px;color:var(--faint);text-align:center;margin:6px 0}

  /* collage / image grids */
  .m-grid2{display:grid;grid-template-columns:1fr 1fr;gap:10px}
  .m-grid3{display:grid;grid-template-columns:1fr 1fr 1fr;gap:10px}

  /* ability list */
  .m-abil{font-family:var(--mono);font-size:14px;line-height:2.3;letter-spacing:.02em;color:var(--ink)}
  .m-abil span{color:var(--accent);margin-right:10px}

  /* operator definition cards */
  .m-defs{display:flex;flex-direction:column;gap:12px;margin-top:18px}
  .m-def{border:1px solid var(--line);background:rgba(239,238,236,.5);padding:13px 15px}
  .m-def .k{font-family:var(--mono);font-size:13px;letter-spacing:.06em;color:var(--ink)}
  .m-def .v{font-family:var(--jp);font-size:14px;font-weight:300;line-height:1.8;color:var(--ink);margin-top:4px}

  /* media row (img + text) */
  .m-row{display:flex;gap:16px;align-items:flex-start;margin-top:20px}
  .m-row .m-thumb{width:34%;flex-shrink:0;border:1px solid var(--line)}
  .m-row .m-rtxt{flex:1;min-width:0}

  /* link cards */
  .m-link{display:flex;align-items:center;border:1px solid rgba(150,148,140,.5);background:rgba(255,255,255,.6);text-decoration:none;color:var(--ink);margin-top:12px}
  .m-link img{width:34%;max-width:140px;aspect-ratio:16/10;object-fit:cover;display:block;flex-shrink:0;filter:grayscale(.12)}
  .m-link .m-linktxt{flex:1;font-family:var(--mono);font-size:14px;line-height:1.5;padding:0 14px}
  .m-link .m-linktxt small{display:block;font-family:var(--jp);color:#86857a;font-size:12px;letter-spacing:.14em;margin-top:2px}
  .m-link .m-arrow{color:var(--accent);font-size:18px;padding-right:14px}

  /* topography svg holder */
  .m-topo{width:100%;height:150px;margin-top:14px}
  .m-topo svg{width:100%;height:100%}

  /* finale */
  .m-finale-wrap{text-align:center;padding:60px 0 30px}
  .m-decl{font-family:var(--serif);font-size:clamp(20px,5.6vw,28px);line-height:1.55;color:var(--ink)}
  .m-decl .it{font-style:italic}
  .m-decl .dash{display:block;color:var(--faint);font-size:.6em;margin:14px 0}
  .m-finale{font-family:var(--didone);font-size:clamp(30px,9vw,46px);letter-spacing:.2em;color:var(--accent);margin-top:34px}
  .m-findef-wrap{max-width:480px;margin:22px auto 0;padding:0}
  .m-finname{font-family:var(--serif);font-size:clamp(18px,4.9vw,21px);font-style:italic;letter-spacing:.1em;color:var(--ink);text-align:center}
  .m-findef{font-family:var(--jp);font-size:clamp(16px,4.2vw,18px);font-weight:300;line-height:2.1;letter-spacing:.04em;color:var(--soft);text-align:center;margin-top:12px}
  .m-finhr{width:56px;height:1px;background:var(--line);margin:24px auto 0}
  .m-inf{font-family:var(--didone);font-size:30px;color:var(--ink);margin-top:20px}

  /* tablet portrait comfort (640-1023): 2-up collage already; widen rhythm */
  @media(min-width:640px) and (max-width:1023px){
    .m-wrap{padding:0 34px 100px}
    .m-sec{padding:46px 0}
  }
