:root{
  --bg:#13150F; --bg-2:#1B1E16; --panel:#20241B;
  --ink:#ECE6D6; --ink-soft:#9DA08B; --line:#343829;
  --trail:#CF9C4E; --trail-hi:#E4B764; --ice:#8FBED0;
  --serif:"Newsreader",serif; --mincho:"Shippori Mincho",serif;
  --sans:"Zen Kaku Gothic New","Hanken Grotesk",system-ui,sans-serif;
  --latin:"Hanken Grotesk",sans-serif; --mono:"Spline Sans Mono",ui-monospace,monospace;
}
*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{margin:0;background:var(--bg);color:var(--ink);font-family:var(--sans);font-weight:400;line-height:1.85;-webkit-font-smoothing:antialiased;font-feature-settings:"palt"}
img,video{display:block;max-width:100%}
button{font:inherit;color:inherit;background:none;border:none;cursor:pointer}
a{color:inherit;text-decoration:none}
:focus-visible{outline:2px solid var(--trail);outline-offset:3px}
.cont,.pin,.alist a,.map-zoom button,.worldmap{-webkit-tap-highlight-color:transparent}
.cont:focus,.pin:focus,.alist a:focus,.map-zoom button:focus,.worldmap:focus,#worldmap g:focus,#worldmap a:focus{outline:none}
.cont:focus-visible,.pin:focus-visible,.alist a:focus-visible,.map-zoom button:focus-visible{outline:2px solid var(--trail);outline-offset:2px}
.hidden{display:none !important}
.eyebrow{font-family:var(--mono);font-size:.68rem;letter-spacing:.3em;text-transform:uppercase;color:var(--ink-soft)}

.nav{position:fixed;top:0;left:0;right:0;z-index:60;display:flex;align-items:center;justify-content:space-between;padding:16px clamp(18px,4vw,52px);transition:background .35s}
.nav.solid{background:rgba(19,21,15,.86);backdrop-filter:blur(10px);border-bottom:1px solid var(--line)}
.brand{font-family:var(--latin);font-weight:700;font-size:1.02rem;letter-spacing:.3em;text-transform:uppercase;color:var(--ink)}
.nav-links{display:flex;gap:clamp(16px,2.4vw,32px);align-items:center}
.nav-links a{font-family:var(--latin);font-size:.85rem;letter-spacing:.08em;color:var(--ink)}
.nav-links a:hover{color:var(--trail)}
.nav-toggle{display:none;font-size:.82rem;letter-spacing:.1em;color:var(--ink)}

/* cover */
.cover{position:relative;min-height:100svh;overflow:hidden}
.cover-mosaic{position:absolute;inset:0;display:grid;grid-template-columns:repeat(4,1fr);grid-auto-rows:1fr;gap:5px}
.cover-tile{position:relative;overflow:hidden;display:block}
.cover-tile img{width:100%;height:100%;object-fit:cover;transition:transform 1.1s cubic-bezier(.2,.7,.2,1);filter:brightness(.8)}
.cover-tile:hover img{transform:scale(1.06);filter:brightness(1)}
.cover-tile-label{position:absolute;left:10px;bottom:10px;font-family:var(--mono);font-size:.6rem;letter-spacing:.18em;text-transform:uppercase;color:var(--ink);text-shadow:0 1px 8px rgba(0,0,0,.85);opacity:0;transform:translateY(4px);transition:.3s}
.cover-tile:hover .cover-tile-label{opacity:1;transform:none}
.cover-overlay{position:absolute;inset:0;z-index:3;pointer-events:none;display:flex;flex-direction:column;justify-content:flex-end;background:linear-gradient(180deg,rgba(19,21,15,.5) 0,rgba(19,21,15,0) 26%,rgba(19,21,15,.2) 58%,rgba(19,21,15,.94) 100%)}
.cover-inner{padding:0 clamp(18px,5vw,80px) clamp(40px,7vh,84px);max-width:1240px;margin:0 auto;width:100%}
.cover-eyebrow{margin-bottom:16px;display:block}
.cover-title{font-family:var(--latin);font-weight:700;font-size:clamp(2.4rem,8vw,5.4rem);letter-spacing:.16em;text-transform:uppercase;line-height:1;margin:0}
.cover-tag{font-family:var(--mincho);font-size:clamp(1.2rem,3.2vw,2rem);line-height:1.45;margin:18px 0 6px;color:var(--ink)}
.cover-tag-en{font-family:var(--serif);font-style:italic;font-size:clamp(.95rem,1.8vw,1.15rem);color:var(--ink-soft)}
.cover-strip{display:flex;flex-wrap:wrap;gap:8px 24px;margin-top:26px;font-family:var(--mono);font-size:.66rem;letter-spacing:.14em;color:var(--ink-soft);border-top:1px solid rgba(236,230,214,.18);padding-top:16px}
.cover-cue{pointer-events:auto;display:inline-block;margin-top:20px;font-family:var(--mono);font-size:.68rem;letter-spacing:.22em;color:var(--trail)}

.section-pad{padding:clamp(64px,11vh,138px) clamp(18px,5vw,80px)}
.wrap{max-width:1240px;margin:0 auto}
.sec-head{display:flex;align-items:flex-end;justify-content:space-between;gap:16px;margin-bottom:clamp(26px,5vh,48px);border-bottom:1px solid var(--line);padding-bottom:16px;flex-wrap:wrap}
.sec-en{font-family:var(--latin);font-weight:600;margin:0;font-size:clamp(2rem,5.5vw,3.4rem);line-height:1;letter-spacing:.01em;color:var(--ink)}
.sec-ja{display:block;font-family:var(--sans);font-size:.8rem;letter-spacing:.24em;color:var(--ink-soft);margin-top:11px}
.sec-head .idx{font-family:var(--mono);font-size:.7rem;letter-spacing:.16em;color:var(--ink-soft)}

/* featured */
.featured{padding:clamp(56px,9vh,110px) clamp(18px,5vw,80px)}
.feat-lead{font-family:var(--mincho);font-size:clamp(1rem,2vw,1.25rem);color:var(--ink-soft);max-width:44ch;line-height:1.7;margin:0 0 clamp(28px,5vh,52px)}
.feat-rows{display:flex;flex-direction:column;gap:clamp(30px,6vh,72px)}
.feat-more{display:inline-block;margin-top:clamp(28px,5vh,52px);font-family:var(--mono);font-size:.8rem;letter-spacing:.16em;color:var(--ink-soft);text-decoration:none;border-bottom:1px solid var(--line);padding-bottom:3px;transition:color .3s,border-color .3s}.feat-more:hover{color:var(--trail);border-color:var(--trail)}
.feat-row{display:grid;grid-template-columns:1.12fr .88fr;gap:clamp(20px,3.4vw,52px);align-items:center;color:inherit}
.feat-row:nth-child(even){grid-template-columns:.88fr 1.12fr}
.feat-row:nth-child(even) .feat-media{order:2}
.feat-media{position:relative;overflow:hidden;aspect-ratio:3/2;background:var(--panel);border:1px solid var(--line)}
.feat-media img{width:100%;height:100%;object-fit:cover;transition:transform 1s cubic-bezier(.2,.7,.2,1);filter:brightness(.9)}
.feat-row:hover .feat-media img{transform:scale(1.04);filter:brightness(1)}
.feat-folio{font-family:var(--mono);font-size:.74rem;letter-spacing:.2em;color:var(--trail);margin-bottom:10px}
.feat-title{font-family:var(--mincho);font-weight:600;font-size:clamp(1.9rem,4.6vw,3rem);line-height:1.04;margin:0 0 .45em}
.feat-stand{font-family:var(--mincho);font-size:clamp(1rem,1.8vw,1.2rem);line-height:1.75;color:var(--ink);max-width:36ch;margin:0 0 1.1em}
.feat-read{font-family:var(--mono);font-size:.74rem;letter-spacing:.14em;color:var(--trail);transition:color .25s,letter-spacing .25s}
.feat-row:hover .feat-read{color:var(--trail-hi);letter-spacing:.2em}
@media(max-width:760px){.feat-row,.feat-row:nth-child(even){grid-template-columns:1fr;gap:16px}.feat-row:nth-child(even) .feat-media{order:0}}
.badge-new{display:inline-block;font-family:var(--mono);font-size:.58rem;font-weight:600;letter-spacing:.14em;color:var(--bg);background:var(--trail);padding:2px 7px;border-radius:999px;vertical-align:middle;margin-left:10px}
.recent{padding:0 clamp(18px,5vw,80px) clamp(48px,8vh,96px)}
.recent-head{display:flex;align-items:baseline;gap:14px;margin-bottom:16px;flex-wrap:wrap}
.rec-en{font-family:var(--latin);font-weight:600;font-size:clamp(1.3rem,3vw,1.9rem);margin:0;line-height:1;color:var(--ink)}
.rec-ja{font-family:var(--sans);font-size:.72rem;letter-spacing:.2em;color:var(--ink-soft)}
.recent-list{list-style:none;margin:0;padding:0;border-top:1px solid var(--line)}
.recent-list a{display:flex;align-items:baseline;gap:14px;padding:13px 4px;border-bottom:1px solid var(--line);color:inherit;transition:background .2s,padding-left .2s}
.recent-list a:hover{background:var(--bg-2);padding-left:10px}
.recent-date{font-family:var(--mono);font-size:.72rem;letter-spacing:.1em;color:var(--trail);min-width:4.6em;flex:none}
.recent-name{font-family:var(--mincho);font-size:1.05rem;color:var(--ink)}
.recent-name .nm-place{color:var(--ink-soft)}
.recent-go{margin-left:auto;font-family:var(--mono);font-size:.7rem;letter-spacing:.12em;color:var(--ink-soft);flex:none}
.recent-list a:hover .recent-go{color:var(--trail)}
.statement{padding:clamp(84px,15vh,160px) clamp(18px,5vw,80px);text-align:center;display:flex;flex-direction:column;align-items:center}
.st-rule{width:46px;height:1px;background:var(--trail);opacity:.85;margin:28px 0 42px}
.st-body{font-family:var(--mincho);color:var(--ink);font-size:clamp(1.18rem,2.5vw,1.58rem);line-height:1.95;letter-spacing:.05em;max-width:780px}
.st-body p{margin:0;text-wrap:balance}
.st-body p+p{margin-top:1.5em}
.nm-place{color:var(--ink-soft);font-weight:400;font-size:.6em;letter-spacing:.02em;margin-left:.15em}
.nm-place::before{content:"｜"}
.corr-lead{font-family:var(--mincho);font-size:clamp(1rem,1.8vw,1.15rem);color:var(--ink);margin:0 0 clamp(20px,3vh,32px)}

/* atlas */
.atlas-lead{font-family:var(--mincho);font-size:clamp(1rem,2.2vw,1.35rem);max-width:46ch;line-height:1.7;margin:0 0 clamp(24px,4vh,36px)}
.atlas-grid{display:grid;grid-template-columns:1.55fr 1fr;gap:clamp(24px,4vw,48px);align-items:start}
.map-frame{border:1px solid var(--line);background:var(--bg-2);position:relative;padding:8px}
.map-frame .corner{position:absolute;width:13px;height:13px;border:1px solid var(--trail);opacity:.6}
.corner.tl{top:-1px;left:-1px;border-right:0;border-bottom:0}.corner.tr{top:-1px;right:-1px;border-left:0;border-bottom:0}
.corner.bl{bottom:-1px;left:-1px;border-right:0;border-top:0}.corner.br{bottom:-1px;right:-1px;border-left:0;border-top:0}
.worldmap{width:100%;aspect-ratio:2/1;height:auto;display:block;transition:none;cursor:default;touch-action:auto;user-select:none;-webkit-user-select:none}
.map-frame.zoom-on .worldmap{cursor:grab;touch-action:none}
.map-frame.zoom-on .worldmap.drag{cursor:grabbing}
.map-zoom{position:absolute;right:14px;bottom:14px;display:none;flex-direction:column;gap:6px;z-index:2}
.map-frame.zoom-on .map-zoom{display:flex}
.map-zoom button{width:30px;height:30px;border:1px solid var(--line);background:var(--bg-2);color:var(--ink-soft);font-size:1.05rem;line-height:1;border-radius:7px;display:grid;place-items:center}
.map-zoom button:hover{border-color:var(--trail);color:var(--trail)}
.map-hint{font-family:var(--mono);font-size:.58rem;letter-spacing:.12em;text-transform:uppercase;color:var(--ink-soft);text-align:center;margin:8px 0 0;opacity:.8;display:none}
.map-frame.zoom-on .map-hint{display:block}
.countries path{fill:#2A2F22;stroke:#3D442F;stroke-width:.55;stroke-linejoin:round;vector-effect:non-scaling-stroke}
.cont{cursor:pointer}
.cont-dot{fill:var(--ice);opacity:.85}
.cont-label{font-family:var(--mono);letter-spacing:.06em;fill:var(--ink);text-anchor:middle;paint-order:stroke;stroke:var(--bg);stroke-width:1.1px}
.cont:hover .cont-dot{fill:var(--trail-hi)}
.cont:hover .cont-label{fill:var(--trail-hi)}
.pin{cursor:pointer}
.pin-dot{fill:var(--trail);stroke:var(--bg)}
.pin-halo{fill:var(--trail);opacity:.16;transition:opacity .3s}
.pin-label{font-family:var(--mono);letter-spacing:.04em;fill:var(--ink);text-anchor:middle;paint-order:stroke;stroke:var(--bg);opacity:0;transition:opacity .2s}
.pin:hover .pin-label,.pin:focus .pin-label,.pin.hot .pin-label{opacity:1}
.pin:hover .pin-halo,.pin.hot .pin-halo{opacity:.4}
.pin.hot .pin-dot{fill:var(--trail-hi)}
.atlas-aside{display:flex;flex-direction:column;gap:14px}
.atlas-search{width:100%;background:var(--bg-2);border:1px solid var(--line);padding:11px 14px;font-family:var(--sans);font-size:.9rem;color:var(--ink)}
.atlas-search:focus{outline:none;border-color:var(--trail)}
.atlas-bar{display:flex;align-items:center;justify-content:space-between;gap:10px;min-height:24px;user-select:none;-webkit-user-select:none}
.atlas-bar .here{font-family:var(--mono);font-size:.72rem;letter-spacing:.16em;text-transform:uppercase;color:var(--ink-soft)}
.atlas-back{font-family:var(--mono);font-size:.7rem;letter-spacing:.12em;color:var(--trail)}
.atlas-back:hover{color:var(--trail-hi)}
.alist{list-style:none;margin:0;padding:0;border-top:1px solid var(--line);max-height:clamp(340px,50vh,560px);overflow-y:auto;user-select:none;-webkit-user-select:none}
.alist::-webkit-scrollbar{width:8px}.alist::-webkit-scrollbar-thumb{background:#3a402f;border-radius:4px}
.alist a{display:flex;align-items:baseline;gap:12px;padding:15px 6px;border-bottom:1px solid var(--line);transition:background .2s,padding .2s}
.alist a:hover,.alist a.hot{background:var(--bg-2);padding-left:12px}
.a-num{font-family:var(--mono);font-size:.72rem;color:var(--trail);min-width:1.6em}
.a-name{font-family:var(--mincho);font-size:1.2rem;font-weight:600}
.a-name i{font-family:var(--mono);font-style:normal;font-size:.6rem;color:var(--ink-soft);margin-left:.5em;letter-spacing:.14em;text-transform:uppercase}
.a-go{margin-left:auto;font-family:var(--mono);font-size:.62rem;color:var(--ink-soft)}
.a-empty{padding:22px 6px;font-family:var(--mincho);color:var(--ink-soft);border-bottom:1px solid var(--line)}

/* about/contact */
.about{background:var(--bg-2);border-top:1px solid var(--line);border-bottom:1px solid var(--line)}
.about-grid{display:grid;grid-template-columns:.8fr 1.2fr;gap:clamp(28px,5vw,72px);align-items:start}
.about-grid>*{min-width:0}
.portrait{border:1px solid var(--line)}.portrait img{width:100%;aspect-ratio:4/5;object-fit:cover}
.portrait .cap{font-family:var(--mono);font-size:.62rem;letter-spacing:.08em;color:var(--ink-soft);padding:10px 2px 0}
.about-id{text-align:center}
.about-role{font-family:var(--sans);font-weight:500;font-size:.82rem;letter-spacing:.26em;color:var(--ink-soft);margin:20px 0 0}
.about-name{font-family:var(--mincho);font-weight:600;font-size:clamp(1.5rem,3vw,2rem);letter-spacing:.08em;line-height:1.3;margin:6px 0 0}
.about-name-en{display:block;font-family:var(--latin);font-weight:500;font-size:.72rem;letter-spacing:.26em;text-transform:uppercase;color:var(--ink-soft);margin-top:7px}
.about-style{font-family:var(--sans);font-size:.92rem;line-height:1.85;color:var(--ink-soft);margin:20px 0 0;text-align:left;text-wrap:pretty}
.social{list-style:none;display:flex;justify-content:center;gap:14px;padding:0;margin:18px 0 0}
.social a{width:40px;height:40px;border:1px solid var(--line);border-radius:50%;display:flex;align-items:center;justify-content:center;color:var(--ink-soft);transition:color .25s,border-color .25s,transform .25s}
.social a:hover{color:var(--trail);border-color:var(--trail);transform:translateY(-2px)}
.social svg{width:18px;height:18px}
.about-stats{display:flex;justify-content:center;gap:clamp(14px,3vw,28px);margin:20px 0 0;flex-wrap:wrap}
.stat{text-align:center}
.stat-num{display:block;font-family:var(--mincho);font-weight:600;font-size:clamp(1.4rem,3vw,1.9rem);color:var(--trail);line-height:1}
.stat-label{display:block;font-family:var(--mono);font-size:.55rem;letter-spacing:.16em;text-transform:uppercase;color:var(--ink-soft);margin-top:7px}
.bio .pullquote{font-size:clamp(1.55rem,3.9vw,2.4rem)}
.bio p{font-size:clamp(.96rem,1.65vw,1.1rem)}
.bio p{font-family:var(--mincho);font-size:clamp(1rem,1.8vw,1.18rem);line-height:2;margin:0 0 1.3em}
.pullquote{font-family:var(--mincho);font-weight:600;font-size:clamp(1.4rem,3.4vw,2.1rem);line-height:1.5;margin:0 0 1.1em;padding-left:.7em;border-left:2px solid var(--trail);color:var(--ink)}
.kit{list-style:none;padding:18px 0 0;margin:1.3em 0 0;border-top:1px solid var(--line);display:grid;grid-template-columns:repeat(2,1fr);gap:10px 28px}
.kit li{font-family:var(--mono);font-size:.74rem;display:flex;justify-content:space-between;gap:10px;border-bottom:1px dotted var(--line);padding-bottom:6px}
.kit li span:first-child{color:var(--ink-soft)}
.contact-grid{display:grid;grid-template-columns:1fr 1fr;gap:clamp(28px,5vw,72px);align-items:start}
.corr p{font-family:var(--mincho);font-size:1.06rem;line-height:1.95;margin:0 0 1.3em;max-width:34ch}
.corr-links{list-style:none;padding:0;margin:0;border-top:1px solid var(--line)}
.corr-links li{border-bottom:1px solid var(--line)}
.corr-links a{display:flex;justify-content:space-between;align-items:baseline;gap:14px;padding:18px 2px;font-family:var(--serif);font-size:1.3rem;transition:padding .25s}
.corr-links a:hover{padding-left:10px;color:var(--trail)}
.corr-links a span{font-family:var(--mono);font-size:.66rem;letter-spacing:.1em;color:var(--ink-soft);text-transform:uppercase}
.cform{display:flex;flex-direction:column;gap:14px}
.cform label{font-family:var(--mono);font-size:.68rem;letter-spacing:.12em;color:var(--ink-soft)}
.cform input,.cform textarea{width:100%;background:var(--bg);border:1px solid var(--line);padding:12px 14px;font-family:var(--sans);font-size:.95rem;color:var(--ink)}
.cform input:focus,.cform textarea:focus{outline:none;border-color:var(--trail)}
.cform textarea{min-height:120px;resize:vertical}
.cform .field{display:flex;flex-direction:column;gap:6px}
.btn{align-self:flex-start;margin-top:6px;background:var(--trail);color:#15140d;padding:13px 26px;font-family:var(--mono);font-size:.74rem;letter-spacing:.14em;font-weight:500;transition:background .25s}
.btn:hover{background:var(--trail-hi)}
.cform .hint{font-family:var(--mono);font-size:.64rem;color:var(--ink-soft);line-height:1.7}

/* country view */
.cview-hero{position:relative;min-height:80svh;display:flex;flex-direction:column;justify-content:flex-end;background-size:cover;background-position:center;overflow:hidden}
.cview-hero::after{content:"";position:absolute;inset:0;background:linear-gradient(180deg,rgba(19,21,15,.5) 0,rgba(19,21,15,.1) 40%,rgba(19,21,15,.94) 100%)}
.cview-back{position:absolute;top:84px;left:clamp(18px,5vw,80px);z-index:3;font-family:var(--mono);font-size:.7rem;letter-spacing:.14em;color:var(--ink);background:rgba(19,21,15,.5);padding:8px 12px;backdrop-filter:blur(4px)}
.cview-back:hover{color:var(--trail)}
.cview-hero-inner{position:relative;z-index:2;padding:0 clamp(18px,5vw,80px) clamp(34px,6vh,64px);max-width:1240px;margin:0 auto;width:100%}
.cview-folio{font-family:var(--mono);font-size:.78rem;letter-spacing:.2em;color:var(--trail);margin-bottom:8px}
.cview-title{font-family:var(--mincho);font-weight:600;font-size:clamp(2.6rem,10vw,6.5rem);line-height:.95;margin:0}
.cview-title .nm-place{display:block;font-size:.34em;margin:.4em 0 0;line-height:1.2;letter-spacing:.02em;font-weight:400}
.cview-title .nm-place::before{content:none}
@media(max-width:620px){.cview-title .nm-place{font-size:.5em;margin:.5em 0 0;line-height:1.3}}
.cview-standfirst{font-family:var(--mincho);font-size:clamp(1.05rem,2.4vw,1.5rem);max-width:52ch;line-height:1.7;margin:14px 0 0;color:var(--ink);text-wrap:pretty}
.cview-essay{max-width:62ch;margin:clamp(48px,8vh,96px) auto;padding:0 clamp(18px,5vw,40px)}
.cview-essay p{font-family:var(--mincho);font-size:clamp(1.05rem,2vw,1.28rem);line-height:2.05;margin:0 0 1.6em;color:var(--ink)}
.cview-essay .pullquote{font-size:clamp(1.5rem,3.6vw,2.3rem);margin:1.4em 0;padding-left:.7em;line-height:1.5}
.cview-note{max-width:62ch;margin:calc(clamp(48px,8vh,96px) * -0.5) auto clamp(40px,7vh,80px);padding:0 clamp(18px,5vw,40px)}
.cview-note a{display:inline-flex;align-items:center;gap:9px;font-family:var(--mono);font-size:.78rem;letter-spacing:.06em;color:var(--ink-soft);border:1px solid var(--line);border-radius:999px;padding:9px 17px;transition:border-color .2s,color .2s}
.cview-note a:hover{border-color:var(--trail);color:var(--ink)}
.cview-note .note-mark{width:15px;height:15px;flex:none}
.cview-note .note-arrow{color:var(--trail)}
.cview-gallery{padding:0 clamp(18px,5vw,80px) clamp(48px,8vh,96px);max-width:1440px;margin:0 auto}
.cview-foot{display:flex;justify-content:space-between;gap:16px;flex-wrap:wrap;border-top:1px solid var(--line);max-width:1240px;margin:0 auto;padding:28px clamp(18px,5vw,40px);font-family:var(--mono);font-size:.76rem;letter-spacing:.1em}
.cview-foot a:hover{color:var(--trail)}

/* plates */
.plates{display:grid;grid-template-columns:repeat(6,1fr);gap:clamp(8px,1.1vw,15px);grid-auto-flow:dense}
.plate{position:relative;margin:0;overflow:hidden;background:var(--panel);cursor:zoom-in}
.plate img,.plate video{width:100%;height:100%;object-fit:cover;transition:transform .9s cubic-bezier(.2,.7,.2,1)}
.plate:hover img,.plate:hover video{transform:scale(1.05)}
.plate figcaption{display:none}
.tag{position:absolute;top:9px;left:9px;display:flex;align-items:center;gap:6px;font-family:var(--mono);font-size:.56rem;letter-spacing:.14em;color:var(--ink);background:rgba(19,21,15,.62);padding:5px 8px;text-transform:uppercase;backdrop-filter:blur(2px)}
.tag::before{content:"";width:0;height:0;border-left:6px solid currentColor;border-top:4px solid transparent;border-bottom:4px solid transparent}
.dur{position:absolute;top:9px;right:9px;font-family:var(--mono);font-size:.58rem;color:var(--ink);background:rgba(19,21,15,.62);padding:4px 7px;backdrop-filter:blur(2px)}
.play{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;pointer-events:none}
.play span{width:54px;height:54px;border-radius:50%;border:1.5px solid rgba(236,230,214,.85);background:rgba(19,21,15,.32);display:flex;align-items:center;justify-content:center;transition:.3s}
.plate:hover .play span{transform:scale(1.08);background:rgba(207,156,78,.9)}
.play span::after{content:"";margin-left:3px;width:0;height:0;border-left:15px solid var(--ink);border-top:9px solid transparent;border-bottom:9px solid transparent}
.f-2{grid-column:span 2}.f-3{grid-column:span 3}.f-4{grid-column:span 4}.f-6{grid-column:span 6}
.r-wide{aspect-ratio:16/7}.r-land{aspect-ratio:3/2}.r-port{aspect-ratio:4/5}.r-sq{aspect-ratio:1/1}

.colophon{background:#0E100B;color:var(--ink);padding:clamp(40px,7vh,72px) clamp(18px,5vw,80px);border-top:1px solid var(--line)}
.colophon-grid{max-width:1240px;margin:0 auto;display:flex;justify-content:space-between;align-items:flex-end;gap:30px;flex-wrap:wrap}
.colophon .mark{font-family:var(--latin);font-weight:700;letter-spacing:.3em;text-transform:uppercase;font-size:.95rem}
.colophon .meta{font-family:var(--mono);font-size:.66rem;letter-spacing:.08em;line-height:2;color:var(--ink-soft);text-align:right}
.colophon .meta-note{opacity:.58}

.lightbox{position:fixed;inset:0;z-index:90;background:rgba(10,11,8,.95);display:none;align-items:center;justify-content:center;padding:4vw;flex-direction:column;gap:14px}
.lightbox.open{display:flex}
.lb-slot{display:flex;align-items:center;justify-content:center;width:min(1100px,92vw);max-height:84vh}
.lb-slot img,.lb-slot video{max-width:92vw;max-height:84vh;object-fit:contain;box-shadow:0 24px 70px rgba(0,0,0,.6)}
.lb-slot iframe{width:min(1100px,92vw);aspect-ratio:16/9;max-height:84vh;border:0}
.lb-cap{font-family:var(--mono);font-size:.7rem;letter-spacing:.08em;color:var(--ink);opacity:.85}
.lb-close{position:absolute;top:20px;right:24px;color:var(--ink);font-family:var(--mono);font-size:.78rem;letter-spacing:.2em}

.reveal{opacity:0;transform:translateY(24px);transition:opacity 1s ease,transform 1s cubic-bezier(.2,.7,.2,1)}
.reveal.in{opacity:1;transform:none}
@media(max-width:900px){
  .cover-mosaic{grid-template-columns:repeat(2,1fr)}
  .atlas-grid{grid-template-columns:1fr}
  .about-grid,.contact-grid{grid-template-columns:1fr}
  .nav-links{position:absolute;top:100%;right:0;left:0;flex-direction:column;align-items:flex-start;gap:0;background:rgba(19,21,15,.96);border-bottom:1px solid var(--line);max-height:0;overflow:hidden;transition:max-height .35s}
  .nav-links.open{max-height:60vh}.nav-links a{width:100%;padding:14px clamp(18px,4vw,52px);border-top:1px solid var(--line)}
  .nav-toggle{display:block}
}
@media(max-width:620px){.plates{grid-template-columns:repeat(2,1fr);gap:8px}.f-2,.f-3,.f-4,.f-6{grid-column:span 2}.r-wide{aspect-ratio:16/9}.kit{grid-template-columns:1fr}}
@media(prefers-reduced-motion:reduce){html{scroll-behavior:auto}*{transition:none!important;animation:none!important}.reveal{opacity:1;transform:none}}

/* --- 同じ国の他の旅（物語ページ下部） --- */
.cview-more{max-width:1100px;margin:clamp(48px,8vh,88px) auto 0;padding:clamp(28px,5vh,56px) clamp(18px,5vw,80px) 0;border-top:1px solid var(--line)}
.more-head{display:flex;align-items:baseline;gap:14px;margin-bottom:24px}
.more-en{font-family:var(--latin);font-weight:600;font-size:clamp(1.1rem,2.4vw,1.5rem);letter-spacing:.01em;color:var(--ink)}
.more-ja{font-family:var(--sans);font-size:.78rem;letter-spacing:.2em;color:var(--ink-soft)}
.sib-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:16px}
.sib-card{display:block;position:relative;border-radius:6px;overflow:hidden;background:var(--panel);aspect-ratio:3/2;transition:.3s}
.sib-card img{width:100%;height:100%;object-fit:cover;opacity:.88;transition:.5s}
.sib-card:hover img{opacity:1;transform:scale(1.04)}
.sib-cap{position:absolute;left:0;right:0;bottom:0;padding:32px 14px 12px;background:linear-gradient(transparent,rgba(10,11,8,.82));color:var(--ink)}
.sib-place{font-family:var(--sans);font-size:.86rem;font-weight:500;letter-spacing:.02em;margin:0}
.sib-year{font-family:var(--mono);font-size:.62rem;letter-spacing:.16em;color:var(--ink-soft);margin-top:3px}
@media(max-width:760px){.sib-grid{grid-template-columns:repeat(2,1fr)}}
@media(max-width:460px){.sib-grid{grid-template-columns:1fr}}
