/*
Theme Name: NT Tokyo — Open-Air Archive
Theme URI: https://www.instagram.com/nt.tokyo.jp/
Author: nt.tokyo.jp
Description: An open-air archive — garments, collage, sound & scenery. A warm, filmic gallery theme with bilingual (EN-led) typography, faded-print grading, a crossfading key-visual / scenery slideshow, and a blue-white firefly ambience. Works on activation; add works via the "Works" admin menu.
Version: 1.2.1
Requires at least: 6.0
Requires PHP: 7.4
License: GPL-2.0-or-later
Text Domain: nt-tokyo
*/

:root{
  --espresso:#17120d; --cream:#e8ddca; --cream-dim:#8c8170; --ember:#b9663a;
  --hair:rgba(232,221,202,.14);
  --serif:"Fraunces",serif; --mincho:"Shippori Mincho",serif;
}
*{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:smooth}
body{background:var(--espresso);color:var(--cream);font-family:var(--serif);-webkit-font-smoothing:antialiased;overflow-x:hidden}
::selection{background:var(--ember);color:#fff}
a{color:inherit;text-decoration:none}
img{display:block;max-width:100%}
/* 英語＝主役14px / 日本語＝注釈10.5px */
.en{font-family:var(--serif);font-weight:400;font-size:14px;letter-spacing:.05em;color:var(--cream);line-height:1.7}
.jp{font-family:var(--mincho);font-weight:400;font-size:10.5px;letter-spacing:.15em;color:var(--cream-dim);line-height:1.95}

#wind{position:fixed;inset:0;z-index:1;pointer-events:none;opacity:.82}
.glow{position:fixed;inset:0;z-index:0;pointer-events:none;background:radial-gradient(60% 45% at 80% 8%,rgba(185,102,58,.09),transparent 60%),radial-gradient(55% 50% at 8% 95%,rgba(120,110,70,.07),transparent 60%);animation:drift 38s ease-in-out infinite}
@keyframes drift{0%,100%{transform:translate(0,0)}50%{transform:translate(-2%,1.4%)}}
.filmgrain{position:fixed;inset:0;z-index:62;pointer-events:none;opacity:.08;mix-blend-mode:overlay;background-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='150' height='150'><filter id='fg'><feTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='2'/></filter><rect width='100%25' height='100%25' filter='url(%23fg)'/></svg>")}

/* nav */
.nav{position:fixed;top:0;left:0;right:0;z-index:50;display:flex;justify-content:space-between;align-items:center;padding:1.5rem clamp(1.3rem,4vw,3rem);mix-blend-mode:difference}
.nav .logo{font-style:italic;font-size:14px;letter-spacing:.05em;color:#fff}
.nav .links{display:flex;gap:1.6rem;font-size:10px;letter-spacing:.26em;text-transform:uppercase;color:#fff}
.nav .links a{opacity:.8}.nav .links a:hover{opacity:1}
@media(max-width:680px){.nav .links{gap:.9rem;font-size:9px;letter-spacing:.18em}}

main{position:relative;z-index:10}

/* hero — 英語のロックアップを主役に */
.hero{position:relative;height:100vh;overflow:hidden;background:#0a0705}
.hero .bg{position:absolute;inset:-6% -3%;will-change:transform;animation:kb 26s ease-in-out infinite alternate}
.hero .bg .slide{position:absolute;inset:0;opacity:0;transition:opacity 1.8s ease}
.hero .bg .slide:first-child{opacity:1}
.hero .bg .slide picture{position:absolute;inset:0;display:block}
.hero .bg .slide img{width:100%;height:100%;object-fit:cover;object-position:center;filter:saturate(.86) contrast(.94) sepia(.06)}
@keyframes kb{from{transform:scale(1.03)}to{transform:scale(1.11) translate(-1.3%,-1%)}}
/* PC（横長画面）だけ：画像を切らず全体表示（contain）＋静的スポット。SPは現状のcoverのまま。 */
.hero::after{content:"";position:absolute;inset:0;z-index:4;pointer-events:none;opacity:0;background:radial-gradient(120% 86% at 50% 44%,transparent 38%,rgba(8,5,3,.5) 78%,rgba(8,5,3,.92))}
@media(min-width:900px){
  .hero .bg{animation:none;inset:0}
  .hero .bg .slide img{object-fit:contain}
  .hero::after{opacity:1}
}
/* KVオーバーレイ：左上＝日付＋4色バー、右下＝タイトル・日付（PCのみ・JSで内容更新） */
.kvover{position:absolute;inset:0;z-index:6;pointer-events:none;opacity:1;transition:opacity .6s ease}
@media(max-width:899px){.kvfoot{display:none}}
.kvtop{position:absolute;top:clamp(2rem,9vh,6rem);left:clamp(1.4rem,3.2vw,3.4rem)}
.kvdate{font-style:italic;font-size:6px;letter-spacing:.18em;color:rgba(236,226,207,.92);margin-bottom:.6rem;text-shadow:0 2px 12px rgba(0,0,0,.6)}
.kvbar{display:flex;flex-direction:column;gap:4px}
.kvbar span{display:block;width:15px;height:21px;box-shadow:0 1px 6px rgba(0,0,0,.35)}
.kvfoot{position:absolute;right:clamp(1.4rem,3.2vw,3.4rem);bottom:clamp(2rem,7vh,4.5rem);text-align:right}
.kvfoot .t{font-style:italic;font-size:6.5px;letter-spacing:.12em;color:rgba(236,226,207,.92);text-shadow:0 2px 12px rgba(0,0,0,.6)}
.kvfoot .d{font-style:italic;font-size:8.5px;letter-spacing:.1em;color:#fff;margin-top:.2rem;text-shadow:0 2px 12px rgba(0,0,0,.6)}
/* 映画的なスクリム：左の縦帯＋下の焼き込み＋全体のごく薄いヴィネット */
.hero .scrim{position:absolute;inset:0;background:linear-gradient(90deg,rgba(8,5,3,.72),rgba(8,5,3,.12) 42%,transparent 70%),linear-gradient(0deg,rgba(8,5,3,.66),rgba(8,5,3,.12) 38%,transparent 60%),radial-gradient(120% 90% at 50% 40%,transparent 55%,rgba(8,5,3,.4))}
.hero .copy{position:absolute;left:clamp(1.3rem,7vw,7rem);bottom:clamp(3.2rem,10vh,7rem);z-index:5;display:flex;align-items:flex-end;justify-content:flex-start;gap:.7rem}
.hero .copy .en{writing-mode:vertical-rl;text-orientation:mixed;font-style:italic;font-size:15px;letter-spacing:.16em;line-height:1.7;color:#fff;text-shadow:0 2px 30px rgba(0,0,0,.65)}
.hero .copy .jp{writing-mode:vertical-rl;font-size:11px;letter-spacing:.26em;line-height:1.85;color:rgba(236,226,207,.85);text-shadow:0 2px 20px rgba(0,0,0,.65)}
@media(min-width:900px){
  .hero .copy{gap:1rem}
  .hero .copy .en{font-size:19px;letter-spacing:.2em}
  .hero .copy .jp{font-size:12.5px;letter-spacing:.3em}
}
.hero .scroll{position:absolute;bottom:1.6rem;left:50%;transform:translateX(-50%);font-size:9px;letter-spacing:.3em;text-transform:uppercase;color:var(--cream-dim)}
.hero .scroll span{display:block;width:1px;height:30px;background:var(--cream-dim);margin:.6rem auto 0;animation:fall 2.8s ease-in-out infinite}
@keyframes fall{0%{transform:scaleY(0);transform-origin:top}50%{transform:scaleY(1);transform-origin:top}50.1%{transform-origin:bottom}100%{transform:scaleY(0);transform-origin:bottom}}

/* intro */
.intro{padding:18vh clamp(1.3rem,5vw,4rem);max-width:46rem;margin:0 auto;text-align:center}
.intro .en{font-size:14px;line-height:2.2;letter-spacing:.04em}
.intro .jp{margin-top:1.6rem;line-height:2.4;letter-spacing:.13em}

/* 借景 */
.vista{position:relative;height:84vh;overflow:hidden}
.vista .bg{position:absolute;inset:-6%;will-change:transform}
.vista .bg .slide{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;opacity:0;transition:opacity 1.8s ease;filter:saturate(.82) contrast(.93) sepia(.08)}
.vista .bg .slide:first-child{opacity:1}
.vista .scrim{position:absolute;inset:0;background:linear-gradient(0deg,rgba(8,5,3,.45),transparent 55%)}
.vista .cap{position:absolute;right:clamp(1.3rem,5vw,4rem);bottom:clamp(1.5rem,5vw,3rem);text-align:right;transition:opacity .8s ease}
.vista .cap .en{font-size:14px;color:#fff;letter-spacing:.06em;text-shadow:0 2px 18px rgba(0,0,0,.7)}
.vista .cap .jp{margin-top:.2rem;letter-spacing:.16em;color:rgba(236,226,207,.82);text-shadow:0 2px 14px rgba(0,0,0,.7)}

/* ARCHIVE */
.archive{padding:13vh clamp(1.3rem,5vw,4rem) 9vh}
.archive .head{display:flex;justify-content:space-between;align-items:baseline;flex-wrap:wrap;gap:1.2rem;margin-bottom:4.5rem}
.archive .head h2{display:flex;align-items:baseline;gap:.8rem;font-weight:400}
.archive .head h2 .en{font-style:italic;font-size:14px;letter-spacing:.1em}
.archive .head h2 .jp{font-size:10.5px}
.filters{display:flex;gap:1.3rem}
.filters button{font-family:var(--mincho);font-size:11px;letter-spacing:.12em;color:var(--cream-dim);background:none;border:none;padding:.3rem 0;cursor:pointer;transition:color .35s;position:relative}
.filters button:first-child{font-family:var(--serif);font-style:italic;font-size:12px}
.filters button::after{content:"";position:absolute;left:0;right:0;bottom:-.1rem;height:1px;background:var(--cream);transform:scaleX(0);transition:transform .35s}
.filters button:hover{color:var(--cream)}
.filters button.on{color:var(--cream)}.filters button.on::after{transform:scaleX(1)}

/* 幅に応じて自動可変。最小幅170px・最大8カラム（1512pxで6・広い外部モニタで最大8） */
.grid{columns:8 170px;column-gap:clamp(1rem,2.2vw,2.2rem)}
.card{break-inside:avoid;margin-bottom:clamp(1.4rem,2.6vw,2.6rem);cursor:pointer}
.card.hide{display:none}
.thumb{position:relative;overflow:hidden;background:#0e0a07}
.thumb img{width:100%;height:auto;display:block;transition:transform 1.4s cubic-bezier(.16,.84,.3,1),filter .8s;filter:saturate(.76) contrast(.87) brightness(1.03) sepia(.14)}
.card:hover .thumb img{transform:scale(1.035);filter:saturate(.9) contrast(.94) brightness(1.04) sepia(.06)}
.thumb::before{content:"";position:absolute;inset:0;z-index:2;pointer-events:none;mix-blend-mode:multiply;opacity:.5;box-shadow:inset 0 0 90px rgba(14,7,2,.9);background-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='640' height='640'><filter id='br'><feTurbulence type='fractalNoise' baseFrequency='0.006 0.009' numOctaves='4' seed='8'/><feColorMatrix values='0 0 0 0 0.30  0 0 0 0 0.22  0 0 0 0 0.13  0 0 0 1.2 -0.2'/></filter><rect width='100%25' height='100%25' filter='url(%23br)'/></svg>");background-size:cover}
.thumb::after{content:"";position:absolute;inset:0;z-index:3;pointer-events:none;mix-blend-mode:overlay;opacity:.42;background-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='180' height='180'><filter id='gn'><feTurbulence type='fractalNoise' baseFrequency='0.8' numOctaves='2'/></filter><rect width='100%25' height='100%25' filter='url(%23gn)'/></svg>");background-size:190px 190px}
.meta{display:flex;align-items:baseline;gap:.6rem;padding:.85rem .1rem 0}
.meta .no{font-style:italic;font-size:10.5px;color:var(--cream-dim);letter-spacing:.04em}
.meta .en{font-size:14px;letter-spacing:.07em}
.meta .jp{font-size:10.5px;margin-left:.1rem}
@media(max-width:680px){.grid{columns:2 150px}}

/* about */
.about{position:relative;height:84vh;overflow:hidden}
.about img{width:100%;height:100%;object-fit:cover;filter:saturate(.78) contrast(.9) brightness(.72) sepia(.12)}
.about .txt{position:absolute;inset:0;display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center;padding:2rem;background:radial-gradient(85% 85% at 50% 50%,rgba(10,7,3,.28),rgba(10,7,3,.72))}
.about .txt .k{font-style:italic;font-size:9px;letter-spacing:.34em;text-transform:uppercase;color:var(--ember);margin-bottom:1.3rem}
.about .txt .en{font-size:14px;line-height:2.1;letter-spacing:.05em;color:#fff;max-width:34ch;text-shadow:0 2px 18px rgba(0,0,0,.55)}
.about .txt .jp{margin-top:1.2rem;line-height:2.3;letter-spacing:.13em;color:rgba(236,226,207,.78);max-width:32ch}

/* footer */
footer{position:relative;z-index:10;padding:11vh clamp(1.3rem,5vw,4rem) 5vh;border-top:1px solid var(--hair)}
footer .fl{text-align:center;margin-bottom:6vh}
footer .fl .en{font-size:14px;line-height:2;letter-spacing:.05em}
footer .fl .jp{margin-top:1rem;line-height:2;letter-spacing:.13em}
footer .row{display:flex;justify-content:space-between;align-items:baseline;flex-wrap:wrap;gap:1rem}
footer .l{font-style:italic;font-size:14px;letter-spacing:.05em}
footer .ig{font-size:10px;letter-spacing:.26em;text-transform:uppercase;color:var(--cream-dim)}
footer .ig:hover{color:var(--cream)}
footer .copy{width:100%;font-size:9px;letter-spacing:.2em;text-transform:uppercase;color:var(--cream-dim);opacity:.55;margin-top:3rem;text-align:center}

/* lightbox */
.lb{position:fixed;inset:0;z-index:100;background:rgba(10,7,3,.97);display:flex;align-items:center;justify-content:center;gap:2.4rem;opacity:0;visibility:hidden;transition:opacity .5s,visibility .5s;padding:8vh 6vw}
.lb.open{opacity:1;visibility:visible}
.lb .stage img{max-height:80vh;max-width:56vw;object-fit:contain;box-shadow:0 50px 120px rgba(0,0,0,.6)}
.lb .cap{align-self:flex-end;padding-bottom:1vh}
.lb .cap .no{font-style:italic;font-size:11px;color:var(--cream-dim);letter-spacing:.06em}
.lb .cap .en{font-size:14px;letter-spacing:.1em;color:#fff;margin-top:.5rem}
.lb .cap .jp{font-size:10.5px;letter-spacing:.2em;color:var(--cream-dim);margin-top:.6rem}
.lb .cap .m{font-style:italic;font-size:10px;letter-spacing:.16em;color:var(--cream-dim);margin-top:1rem}
.lb .x{position:absolute;top:1.8rem;right:2.2rem;font-size:10px;letter-spacing:.2em;text-transform:uppercase;color:var(--cream);cursor:pointer;opacity:.75}
.lb .x:hover{opacity:1}
@media(max-width:760px){.lb{flex-direction:column;gap:1rem;padding:9vh 7vw}.lb .stage img{max-width:84vw;max-height:60vh}.lb .cap{align-self:center;text-align:center}}

.rise{opacity:0;transform:translateY(30px);transition:opacity 1.2s cubic-bezier(.16,.84,.3,1),transform 1.2s cubic-bezier(.16,.84,.3,1)}
.rise.in{opacity:1;transform:none}

/* ================================================================
   v1.1 — 下層テンプレート（柱/ブランド/場所/ジャンル・作品個別・
   Journal・記事・固定ページ・地図・For Clients）
   ================================================================ */

/* card がリンクになっても見た目は据え置き */
a.card{color:inherit}

/* フィルターボタン内の英語サブラベル */
.filters button span{font-family:var(--serif);font-style:italic;font-size:10px;letter-spacing:.08em;opacity:.7;margin-left:.2rem}

/* 共通：下層ページの導入見出し */
.lp-head{max-width:60rem;margin:0 auto;padding:22vh clamp(1.3rem,5vw,4rem) 2vh;text-align:center}
.eyebrow{font-family:var(--mincho);font-size:10.5px;letter-spacing:.26em;color:var(--ember);text-transform:uppercase;margin-bottom:1.6rem}
.lp-en{font-weight:300;font-style:italic;font-size:clamp(1.9rem,4.4vw,3rem);letter-spacing:.01em;line-height:1.18}
.lp-jp{font-family:var(--mincho);font-size:12px;letter-spacing:.2em;color:var(--cream-dim);margin-top:1.1rem}
.lp-intro{font-size:13.5px;line-height:2.1;letter-spacing:.03em;color:var(--cream);opacity:.9;max-width:42rem;margin:2.2rem auto 0}
.lp-spots{display:flex;flex-wrap:wrap;gap:.6rem;justify-content:center;margin-top:2rem}
.lp-spots a{font-family:var(--mincho);font-size:11px;letter-spacing:.08em;color:var(--cream-dim);padding:.5rem 1rem;border:1px solid var(--hair);border-radius:2px;transition:.4s}
.lp-spots a i{font-style:normal;color:var(--cream);margin-left:.3rem}
.lp-spots a:hover{border-color:rgba(185,102,58,.5);color:var(--cream)}
.lp-maplink{display:inline-block;margin-top:1.8rem;font-size:11px;letter-spacing:.14em;color:var(--ember)}
.lp-maplink:hover{color:var(--cream)}

/* ページネーション（共通） */
.pagination,.nav-links{margin:5rem auto 0;display:flex;gap:.5rem;justify-content:center;flex-wrap:wrap}
.pagination .page-numbers{font-family:var(--mincho);font-size:12px;letter-spacing:.1em;color:var(--cream-dim);padding:.5rem .85rem;border:1px solid var(--hair);border-radius:2px;transition:.35s}
.pagination .page-numbers.current,.pagination a.page-numbers:hover{color:var(--cream);border-color:rgba(185,102,58,.5)}
.empty{text-align:center;padding:8vh 0;opacity:.7}

/* 関連コラム */
.related{max-width:60rem;margin:2vh auto 0;padding:7vh clamp(1.3rem,5vw,4rem);border-top:1px solid var(--hair)}
.related .rh{display:flex;align-items:baseline;gap:.8rem;margin-bottom:2rem}
.related .rh .en{font-style:italic;font-size:14px;letter-spacing:.1em}
.related .rh .jp{font-family:var(--mincho);font-size:10.5px;color:var(--cream-dim);letter-spacing:.18em}
.related .rlist{display:flex;flex-direction:column;gap:.2rem}
.ritem{display:flex;justify-content:space-between;align-items:baseline;gap:1rem;padding:1.1rem 0;border-bottom:1px solid var(--hair)}
.ritem .rt{font-size:14px;letter-spacing:.03em}
.ritem .rd{font-style:italic;font-size:10.5px;color:var(--cream-dim);white-space:nowrap}
.ritem:hover .rt{color:var(--ember)}

/* 作品個別 */
.work-single{max-width:62rem;margin:0 auto;padding:20vh clamp(1.3rem,5vw,4rem) 10vh}
.ws-head{text-align:center;margin-bottom:3.5rem}
.ws-no{font-family:var(--mincho);font-size:10.5px;letter-spacing:.22em;color:var(--ember);margin-bottom:1.2rem}
.ws-en{font-weight:300;font-style:italic;font-size:clamp(1.8rem,4vw,2.7rem);letter-spacing:.02em;line-height:1.2}
.ws-jp{font-family:var(--mincho);font-size:13px;letter-spacing:.2em;color:var(--cream-dim);margin-top:.9rem}
.ws-date{font-style:italic;font-size:11px;letter-spacing:.14em;color:var(--cream-dim);margin-top:.8rem;opacity:.8}
.ws-fig{position:relative;overflow:hidden;background:#0e0a07;margin:0 auto}
.ws-fig img{width:100%;height:auto;filter:saturate(.78) contrast(.88) brightness(1.02) sepia(.12)}
.ws-body{max-width:40rem;margin:3.5rem auto 0;font-size:14px;line-height:2.1;letter-spacing:.02em}
.ws-body p{margin-bottom:1.4rem}
.ws-tax{max-width:40rem;margin:3.5rem auto 0;display:flex;flex-direction:column;gap:1rem}
.ws-tg{display:flex;gap:1rem;align-items:baseline;border-top:1px solid var(--hair);padding-top:1rem}
.ws-tg .lbl{font-family:var(--mincho);font-size:10px;letter-spacing:.16em;color:var(--cream-dim);min-width:9rem}
.ws-tg .vals{display:flex;flex-wrap:wrap;gap:.4rem 1rem}
.ws-tg .vals a{font-size:13px;letter-spacing:.04em}
.ws-tg .vals a i{font-style:normal;font-family:var(--mincho);font-size:10px;color:var(--cream-dim);margin-left:.25rem}
.ws-tg .vals a:hover{color:var(--ember)}
.ws-nav,.art-nav{max-width:40rem;margin:5rem auto 0;display:flex;justify-content:space-between;align-items:center;gap:1rem;flex-wrap:wrap;border-top:1px solid var(--hair);padding-top:2rem;font-size:11.5px;letter-spacing:.06em}
.ws-nav .up,.art-nav .up{font-style:italic;color:var(--cream-dim)}
.ws-nav a:hover,.art-nav a:hover{color:var(--ember)}

/* Journal 一覧 */
.journal-list{max-width:54rem;margin:0 auto;padding:4vh clamp(1.3rem,5vw,4rem) 10vh}
.jcard{border-bottom:1px solid var(--hair)}
.jlink{display:grid;grid-template-columns:200px 1fr;gap:2rem;padding:3rem 0;align-items:center}
.jthumb{overflow:hidden;background:#0e0a07}
.jthumb img{width:100%;height:140px;object-fit:cover;filter:saturate(.78) contrast(.88) brightness(1.02) sepia(.12);transition:transform 1.2s cubic-bezier(.16,.84,.3,1)}
.jcard:hover .jthumb img{transform:scale(1.04)}
.jmeta{font-style:italic;font-size:10.5px;letter-spacing:.12em;color:var(--cream-dim);margin-bottom:.8rem}
.jtitle{font-weight:400;font-size:1.2rem;line-height:1.4;letter-spacing:.01em}
.jcard:hover .jtitle{color:var(--ember)}
.jexcerpt{font-family:var(--mincho);font-size:11px;line-height:1.95;letter-spacing:.04em;color:var(--cream-dim);margin-top:.8rem}
@media(max-width:680px){.jlink{grid-template-columns:1fr;gap:1rem}.jthumb img{height:200px}}

/* 記事・固定ページ */
article.article,article.page{max-width:42rem;margin:0 auto;padding:20vh clamp(1.3rem,5vw,4rem) 10vh}
.art-head{margin-bottom:2.5rem;text-align:center}
.art-meta{font-style:italic;font-size:11px;letter-spacing:.12em;color:var(--cream-dim);margin-bottom:1rem}
.art-meta .art-cat{color:var(--ember)}
.art-title{font-weight:300;font-size:clamp(1.7rem,3.6vw,2.4rem);line-height:1.3;letter-spacing:.01em}
.art-fig{overflow:hidden;background:#0e0a07;margin:0 -2vw 3rem}
.art-fig img{width:100%;filter:saturate(.78) contrast(.88) brightness(1.02) sepia(.12)}
.art-body{font-size:14.5px;line-height:2.15;letter-spacing:.02em;color:var(--cream)}
.art-body p{margin-bottom:1.6rem}
.art-body h2{font-weight:400;font-size:1.35rem;font-style:italic;margin:3rem 0 1.2rem;letter-spacing:.02em}
.art-body h3{font-weight:400;font-size:1.1rem;margin:2.4rem 0 1rem;color:var(--cream)}
.art-body a{color:var(--ember);border-bottom:1px solid rgba(185,102,58,.4)}
.art-body a:hover{border-color:var(--ember)}
.art-body blockquote{border-left:2px solid var(--ember);padding-left:1.4rem;margin:2rem 0;font-style:italic;color:var(--cream-dim)}
.art-body img{margin:2rem auto;filter:saturate(.82) contrast(.9) sepia(.08)}
.art-body ul,.art-body ol{margin:0 0 1.6rem 1.3rem}
.art-body li{margin-bottom:.6rem}
.art-tags{max-width:42rem;margin:3rem auto 0;display:flex;flex-wrap:wrap;gap:.6rem}
.art-tags a{font-family:var(--mincho);font-size:11px;color:var(--cream-dim);letter-spacing:.06em}
.art-tags a:hover{color:var(--ember)}

/* 場所マップ */
.mapwrap{position:relative;z-index:10;max-width:68rem;margin:0 auto;padding:18vh clamp(1.3rem,5vw,4rem) 8vh}
.mapwrap .head{display:flex;justify-content:space-between;align-items:baseline;flex-wrap:wrap;gap:1rem;border-bottom:1px solid var(--hair);padding-bottom:1.4rem;margin-bottom:2rem}
.mapwrap .head .t .en{font-style:italic;font-size:1.5rem;letter-spacing:.04em}
.mapwrap .head .t .jp{font-family:var(--mincho);font-size:11px;letter-spacing:.2em;color:var(--cream-dim);margin-top:.5rem}
.mapwrap .head .count{font-style:italic;font-size:13px;color:var(--cream-dim);letter-spacing:.08em}
.mapwrap .head .count b{color:var(--ember);font-size:1.5rem;font-style:normal}
.map-intro{font-size:13px;line-height:2;color:var(--cream-dim);max-width:44rem;margin-bottom:2.5rem}
.mapwrap .layout{display:grid;grid-template-columns:1.6fr 1fr;gap:3rem;align-items:start}
@media(max-width:760px){.mapwrap .layout{grid-template-columns:1fr}}
.mapbox{position:relative}
.geolonia-svg-map{width:100%;height:auto;overflow:visible}
.geolonia-svg-map .prefecture polygon,.geolonia-svg-map .prefecture path{fill:rgba(232,221,202,.04);stroke:rgba(232,221,202,.22);stroke-width:.8;transition:fill .6s ease,stroke .6s ease}
.geolonia-svg-map .prefecture:hover polygon,.geolonia-svg-map .prefecture:hover path{fill:rgba(185,102,58,.3);cursor:pointer}
.geolonia-svg-map .prefecture.has polygon,.geolonia-svg-map .prefecture.has path{fill:var(--ember);stroke:rgba(255,210,160,.6);cursor:pointer}
.geolonia-svg-map .prefecture.has.sel polygon,.geolonia-svg-map .prefecture.has.sel path{fill:#d98a52}
.geolonia-svg-map .boundary-line{stroke:rgba(232,221,202,.1)}
.mapbox .lbl{position:absolute;top:0;left:0;font-family:var(--mincho);font-size:12px;letter-spacing:.12em;color:var(--cream-dim);pointer-events:none}
.panel{border-left:1px solid var(--hair);padding-left:2rem;min-height:200px}
@media(max-width:760px){.panel{border-left:none;border-top:1px solid var(--hair);padding-left:0;padding-top:2rem}}
.panel .ph{font-family:var(--mincho);font-size:12px;letter-spacing:.16em;color:var(--cream-dim);line-height:2}
.panel .pn .en{font-style:italic;font-size:1.6rem;letter-spacing:.04em}
.panel .pn .jp{font-family:var(--mincho);font-size:11px;letter-spacing:.2em;color:var(--cream-dim);margin-top:.4rem}
.panel .spots{margin-top:1.8rem;display:flex;flex-direction:column;gap:.9rem}
.panel .spot{display:flex;align-items:baseline;gap:.8rem;padding-bottom:.9rem;border-bottom:1px solid var(--hair)}
.panel .spot .no{font-style:italic;font-size:11px;color:var(--cream-dim)}
.panel .spot .en{font-size:14px;letter-spacing:.06em}
.panel .spot .jp{font-family:var(--mincho);font-size:10.5px;color:var(--cream-dim);letter-spacing:.14em}
.panel .spot .ct{margin-left:auto;font-style:italic;font-size:10px;color:var(--ember)}
.panel a.spot:hover .en{color:var(--ember)}
.panel .more{display:inline-block;margin-top:1.6rem;font-size:11px;letter-spacing:.14em;color:var(--ember)}
.legend{margin-top:2.5rem;display:flex;gap:1.6rem;font-family:var(--mincho);font-size:10.5px;letter-spacing:.14em;color:var(--cream-dim)}
.legend i{display:inline-block;width:11px;height:11px;margin-right:.5rem;vertical-align:middle;border:1px solid rgba(232,221,202,.3)}
.legend i.on{background:var(--ember);border-color:rgba(255,210,160,.6)}
.cred{margin-top:4rem;font-style:italic;font-size:10px;letter-spacing:.1em;color:var(--cream-dim);opacity:.6}

/* ================= For Clients（試作 for-clients.html を移植） ============ */
.forclients{--dim:var(--cream-dim);position:relative;z-index:10;line-height:1.7}
.forclients section{padding:8vh 5vw;max-width:920px;margin:0 auto}
.forclients .sec-h{display:flex;align-items:baseline;gap:1rem;margin-bottom:3rem}
.forclients .sec-h .en{font-style:italic;font-size:1.6rem}
.forclients .sec-h .jp{font-family:var(--mincho);font-size:11px;letter-spacing:.2em;color:var(--dim)}
.forclients .fc-hero{min-height:78vh;display:flex;flex-direction:column;justify-content:center;padding-top:18vh;padding-bottom:6vh}
.forclients .fc-hero h1{font-weight:300;font-style:italic;font-size:clamp(1.9rem,4.6vw,3.1rem);line-height:1.22;letter-spacing:.01em;max-width:780px}
.forclients .fc-hero .h-jp{font-family:var(--mincho);font-size:12px;letter-spacing:.14em;color:var(--cream);opacity:.78;margin-top:1.5rem;line-height:2}
.forclients .fc-hero .lead{margin-top:2.6rem;max-width:640px}
.forclients .fc-hero .lead .en{font-size:14px;color:var(--cream);opacity:.92}
.forclients .fc-hero .lead .jp{font-family:var(--mincho);font-size:11px;letter-spacing:.1em;color:var(--dim);margin-top:.7rem;line-height:1.9}
.forclients .bridge{border-top:1px solid var(--hair);border-bottom:1px solid var(--hair);padding-top:6vh;padding-bottom:6vh}
.forclients .bridge .en{font-style:italic;font-size:clamp(1.15rem,2.5vw,1.6rem);font-weight:300;line-height:1.55;max-width:760px}
.forclients .bridge .jp{font-family:var(--mincho);font-size:11.5px;letter-spacing:.1em;color:var(--dim);margin-top:1.4rem;line-height:2.1;max-width:720px}
.forclients .pillars{display:grid;grid-template-columns:1.3fr 1fr;gap:4rem}
.forclients .pillar h3{font-weight:400;font-size:13px;letter-spacing:.06em;color:var(--ember);font-style:italic;padding-bottom:1rem;margin-bottom:1.4rem;border-bottom:1px solid var(--hair)}
.forclients .pillar h3 span{font-family:var(--mincho);font-style:normal;font-size:10px;color:var(--dim);letter-spacing:.14em;margin-left:.5rem}
.forclients .pillar ul{list-style:none;display:flex;flex-direction:column;gap:1.05rem}
.forclients .pillar li{display:flex;flex-direction:column}
.forclients .pillar li .en{font-size:13.5px}
.forclients .pillar li .jp{font-family:var(--mincho);font-size:10.5px;color:var(--dim);letter-spacing:.1em;margin-top:.25rem}
.forclients .msub{font-family:var(--mincho);font-size:11px;letter-spacing:.1em;color:var(--dim);margin-bottom:3rem;margin-top:-1.6rem}
.forclients .steps{display:grid;grid-template-columns:repeat(2,1fr);gap:2.6rem 4rem}
.forclients .step{display:flex;gap:1.3rem;align-items:flex-start}
.forclients .step .no{font-style:italic;font-size:1.4rem;color:var(--ember);opacity:.8;min-width:2.2rem}
.forclients .step .b .en{font-size:15px;font-style:italic}
.forclients .step .b .jp{font-family:var(--mincho);font-size:10.5px;color:var(--dim);letter-spacing:.1em;margin-top:.2rem}
.forclients .step .b .d{font-family:var(--mincho);font-size:11px;color:var(--dim);margin-top:.5rem;line-height:1.8}
.forclients .proof .lead-jp{font-family:var(--mincho);font-size:11px;color:var(--dim);letter-spacing:.1em;margin-top:-1.6rem;margin-bottom:1rem}
.forclients .case{padding:3.6rem 0;border-top:1px solid var(--hair)}
.forclients .case:first-of-type{border-top:none;padding-top:.5rem}
.forclients .case .ttl .en{font-style:italic;font-size:1.25rem;letter-spacing:.01em}
.forclients .case .ttl .jp{font-family:var(--mincho);font-size:11px;letter-spacing:.1em;color:var(--dim);margin-top:.45rem}
.forclients .case .thumb{margin:1.7rem 0;max-width:560px}
.forclients .case .thumb img{width:100%;display:block;border:1px solid var(--hair);filter:saturate(.82) contrast(.9) brightness(.97) sepia(.08)}
.forclients .case .ach{list-style:none;display:flex;flex-direction:column;gap:.55rem;max-width:720px}
.forclients .case .ach li{font-size:13px;line-height:1.65;color:var(--cream);letter-spacing:.01em;padding-left:1rem;position:relative}
.forclients .case .ach li::before{content:"—";position:absolute;left:0;color:var(--dim)}
.forclients .case .ach li b{font-weight:400;color:var(--ember);font-style:italic}
.forclients .case .body{margin-top:1.7rem;max-width:720px}
.forclients .case .body .jp{font-family:var(--mincho);font-size:11.5px;color:var(--dim);letter-spacing:.06em;line-height:2}
.forclients .case .body .en{font-size:13px;color:var(--dim);line-height:1.85;margin-top:.9rem;opacity:.85}
.forclients .proof .note,.forclients .clients .note{font-style:italic;font-size:10.5px;color:var(--dim);opacity:.65;margin-top:3rem}
.forclients .clients .wall{display:flex;flex-wrap:wrap;gap:.6rem .4rem}
.forclients .cl{font-family:var(--mincho);font-size:12px;letter-spacing:.05em;color:var(--dim);padding:.5rem .9rem;border:1px solid var(--hair);border-radius:2px;transition:.4s}
.forclients .cl:hover{color:var(--cream);border-color:rgba(185,102,58,.45)}
.forclients .clients .note{margin-top:1.5rem}
.forclients .profile{display:grid;grid-template-columns:1fr 1.35fr;gap:3.4rem;align-items:start}
.forclients .profile .ph img{width:100%;display:block;filter:saturate(.8) contrast(.92) brightness(.98) sepia(.08)}
.forclients .profile .nm .en{font-style:italic;font-size:1.7rem}
.forclients .profile .nm .jp{font-family:var(--mincho);font-size:11px;letter-spacing:.14em;color:var(--dim);margin-top:.4rem}
.forclients .profile .role{font-family:var(--mincho);font-size:11px;color:var(--cream);opacity:.85;letter-spacing:.06em;margin-top:1.3rem;line-height:1.9}
.forclients .profile .career{font-family:var(--mincho);font-size:11.5px;color:var(--dim);line-height:2;margin-top:1.5rem}
.forclients .profile .book{font-family:var(--mincho);font-size:11px;color:var(--dim);letter-spacing:.04em;margin-top:1.3rem;padding-top:1.1rem;border-top:1px solid var(--hair)}
.forclients .contact{text-align:center;padding-top:10vh;padding-bottom:10vh}
.forclients .contact .en{font-style:italic;font-weight:300;font-size:clamp(1.7rem,4vw,2.7rem);line-height:1.3}
.forclients .contact .jp{font-family:var(--mincho);font-size:12px;letter-spacing:.14em;color:var(--dim);margin-top:1.1rem}
.forclients .contact .cta{display:inline-flex;gap:1.6rem;margin-top:2.8rem;flex-wrap:wrap;justify-content:center}
.forclients .contact .cta a{font-size:13px;letter-spacing:.05em;color:var(--cream);border:1px solid rgba(232,221,202,.28);padding:.85rem 1.9rem;border-radius:2px;transition:.4s}
.forclients .contact .cta a:hover{border-color:var(--ember);color:#fff}
@media(max-width:760px){
 .forclients .pillars{grid-template-columns:1fr;gap:3rem}
 .forclients .steps{grid-template-columns:1fr;gap:2rem}
 .forclients .profile{grid-template-columns:1fr;gap:1.8rem}
}
