/* NOX GALLERY — rich layouts (additive; loaded after style.css). Reuses :root tokens. */

/* ---- Logo wall (Recognition / press) ---- */
.logowall{display:grid;grid-template-columns:repeat(4,1fr);gap:1px;background:var(--line2);border:0.5px solid var(--line2);border-radius:14px;overflow:hidden}
.logowall .lw{display:flex;align-items:center;justify-content:center;min-height:88px;background:#fff;padding:18px 16px;text-align:center;transition:background .2s}
.logowall .lw:hover{background:#fcfcf9}
.logowall .lw img{max-height:38px;max-width:150px;width:auto;height:auto;filter:grayscale(1) opacity(.62);transition:filter .25s}
.logowall .lw:hover img{filter:grayscale(0) opacity(1)}
.logowall .lw span{font-family:var(--gothic);font-size:15px;letter-spacing:.03em;font-weight:500;color:var(--muted);transition:color .25s}
.logowall .lw:hover span{color:var(--ink)}
.logowall .lw small{display:block;font-size:10px;letter-spacing:.14em;color:var(--muted2);text-transform:uppercase;margin-top:3px;font-weight:400}

/* ---- Team roster (portrait + monogram) ---- */
.team-roster{display:grid;grid-template-columns:repeat(3,1fr);gap:16px}
.member .pf{position:relative;aspect-ratio:3/4;border-radius:14px;overflow:hidden;background:var(--ink);background-size:cover;background-position:center;display:flex;align-items:flex-end;padding:14px}
.member .pf::after{content:"";position:absolute;inset:0;background:linear-gradient(180deg,rgba(10,10,12,0) 45%,rgba(10,10,12,.55) 100%)}
.member .mono{position:absolute;top:14px;left:14px;z-index:2;width:40px;height:40px;border-radius:50%;background:rgba(250,250,246,.08);border:1px solid var(--lime);color:var(--lime);display:flex;align-items:center;justify-content:center;font-size:16px;font-family:var(--gothic)}
.member .pf .nm{position:relative;z-index:2;color:#fff;font-family:var(--gothic);font-size:12px;letter-spacing:.08em}
.member .minfo{padding:12px 2px 0}
.member .minfo h3{font-size:16px;font-weight:500;margin:0}
.member .minfo p{font-size:13px;color:var(--muted);margin:3px 0 0;font-family:var(--gothic)}

/* ---- Bento (Services) ---- */
.bento{display:grid;grid-template-columns:repeat(4,1fr);grid-auto-rows:148px;gap:14px}
.bento .b{position:relative;border-radius:14px;overflow:hidden;background:var(--ink);background-size:cover;background-position:center;display:flex;flex-direction:column;justify-content:flex-end;padding:18px;color:#fff;transition:transform .25s}
.bento .b::after{content:"";position:absolute;inset:0;background:linear-gradient(180deg,rgba(10,10,12,.05) 30%,rgba(10,10,12,.72) 100%)}
.bento .b:hover{transform:translateY(-3px)}
.bento .b>*{position:relative;z-index:2}
.bento .b .bn{font-family:var(--gothic);font-size:11px;letter-spacing:.18em;color:var(--lime);margin-bottom:6px}
.bento .b h3{font-size:17px;font-weight:500;margin:0;line-height:1.3}
.bento .b p{font-size:13px;line-height:1.6;color:rgba(250,250,246,.82);margin:6px 0 0;font-family:var(--gothic)}
.bento .b-feat{grid-column:span 2;grid-row:span 2}
.bento .b-wide{grid-column:span 2}

/* ---- Masonry (Archive gallery) ---- */
.masonry{display:grid;grid-template-columns:repeat(4,1fr);gap:14px}
.masonry .mcard{position:relative;display:block;border-radius:12px;overflow:hidden;background:var(--ink);aspect-ratio:5/4}
.masonry .mcard img{width:100%;height:auto;display:block;transition:transform .4s,opacity .25s}
.masonry .mcard:hover img{transform:scale(1.04)}
.masonry .mcard .mcap{position:absolute;left:0;right:0;bottom:0;padding:54px 12px 12px;color:#fff;font-family:var(--gothic);font-size:12px;letter-spacing:.06em;background:linear-gradient(180deg,rgba(8,8,10,0) 0%,rgba(8,8,10,.45) 38%,rgba(8,8,10,.92) 100%)}
.masonry .mcard .mcap small{display:block;font-size:10px;letter-spacing:.12em;color:rgba(255,255,255,.7);margin-top:2px;text-transform:uppercase}
.masonry .mcard.dark{display:flex;align-items:flex-end;padding:12px 14px;color:rgba(250,250,246,.82);font-family:var(--gothic);font-size:12px;letter-spacing:.08em}
.masonry .mcard.feat{outline:2px solid var(--lime);outline-offset:-2px}

@media (max-width:1080px){
  .bento{grid-auto-rows:130px}
  .masonry{grid-template-columns:repeat(3,1fr)}
}
@media (max-width:820px){
  .logowall{grid-template-columns:repeat(2,1fr)}
  .team-roster{grid-template-columns:1fr 1fr}
  .bento{grid-template-columns:repeat(2,1fr);grid-auto-rows:130px}
  .bento .b-feat{grid-column:span 2;grid-row:span 2}
  .bento .b-wide{grid-column:span 2}
  .masonry{grid-template-columns:repeat(2,1fr)}
}
@media (max-width:520px){
  .team-roster{grid-template-columns:1fr}
  .masonry{grid-template-columns:repeat(2,1fr)}
}

/* ---- HEX location map + justified gallery + floorplan ---- */
.hexmap{width:100%;height:360px;border:0.5px solid var(--line3);border-radius:12px;overflow:hidden;margin-top:6px}
.hexmap iframe{width:100%;height:100%;border:0;display:block}
.hexgal{display:flex;flex-wrap:wrap;gap:8px}
.hexgal a{flex-grow:var(--ar);flex-basis:calc(var(--ar) * 320px);height:320px;position:relative;overflow:hidden;background:var(--ink);display:block}
.hexgal a img{width:100%;height:100%;object-fit:cover;display:block}
.hexgal a .cap{position:absolute;left:0;bottom:0;padding:10px 12px;color:#fff;font-family:var(--gothic);font-size:12px;letter-spacing:.08em;background:linear-gradient(180deg,rgba(10,10,12,0),rgba(10,10,12,.55))}
.hexgal2{display:grid;grid-template-columns:1fr 1fr;grid-template-rows:1fr 1fr;gap:8px;height:min(72vh,620px)}
.hexgal2 a{position:relative;overflow:hidden;background:var(--ink);display:block}
.hexgal2 a img{width:100%;height:100%;object-fit:cover;display:block}
.hexgal2 a.r{grid-column:2;grid-row:1 / span 2}
.hexgal2 a .cap{position:absolute;left:0;bottom:0;padding:10px 12px;color:#fff;font-family:var(--gothic);font-size:12px;letter-spacing:.08em;background:linear-gradient(180deg,rgba(10,10,12,0),rgba(10,10,12,.55))}
@media (max-width:760px){.hexgal2{height:min(62vh,480px)}}
.floorplan{display:flex;gap:22px;align-items:center;flex-wrap:wrap;margin-top:18px;padding-top:18px;border-top:0.5px solid var(--line)}
.floorplan img{width:220px;max-width:42vw;border:0.5px solid var(--line3);background:#fff;display:block}
.floorplan .fpinfo .lab2{font-family:var(--gothic);font-size:11px;letter-spacing:.14em;color:var(--muted2);text-transform:uppercase}
.floorplan .fpinfo h3{font-size:16px;font-weight:500;margin:4px 0 12px}
@media (max-width:760px){.hexgal a{height:240px;flex-basis:calc(var(--ar) * 240px)}.hexmap{height:280px}}

/* ---- Story (PC=editorial big-year / mobile=vertical timeline) ---- */
.story .era{display:grid;grid-template-columns:200px 1fr;gap:28px;padding:26px 4px;border-top:0.5px solid var(--line)}
.story .era:last-child{border-bottom:0.5px solid var(--line)}
.story .yr{font-size:18px;font-weight:500;line-height:1;letter-spacing:.01em;color:var(--muted)}
.story .ev h3{font-size:18px;font-weight:500;margin:0 0 7px}
.story .ev p{font-size:14px;line-height:1.85;color:#4a4d51;margin:0;font-family:var(--gothic);max-width:560px}
/* ---- Services (text-only numbered) ---- */
.svc{display:grid;grid-template-columns:1fr 1fr;gap:0 40px}
.svc .si{display:flex;gap:16px;padding:20px 2px;border-top:0.5px solid var(--line)}
.svc .sn{font-size:17px;font-weight:500;color:var(--lime-d);font-family:var(--gothic);min-width:28px;line-height:1.35}
.svc .si h3{font-size:16px;font-weight:500;margin:0 0 5px}
.svc .si p{font-size:13px;line-height:1.7;color:var(--muted);margin:0;font-family:var(--gothic)}

/* ---- Exhibition preview minis (replaces tiny chips) ---- */
.exmini{display:grid;grid-template-columns:repeat(auto-fill,minmax(160px,1fr));gap:12px;margin-top:16px}
.exmini a{position:relative;border-radius:12px;overflow:hidden;background:var(--ink);border:0.5px solid var(--line3);display:block;aspect-ratio:16/10;transition:border-color .2s,transform .2s}
.exmini a:hover{border-color:var(--lime-d);transform:translateY(-2px)}
.exmini a img{width:100%;height:100%;object-fit:cover;display:block}
.exmini a .nm{position:absolute;left:0;right:0;bottom:0;padding:16px 11px 9px;color:#fff;font-family:var(--gothic);font-size:11px;letter-spacing:.07em;background:linear-gradient(180deg,rgba(10,10,12,0),rgba(10,10,12,.62))}
.exmini a.allcard{display:flex;align-items:center;justify-content:center;text-align:center;background:var(--lime);color:var(--ink);font-family:var(--gothic);font-size:13px;font-weight:500;border-color:var(--lime);padding:12px}
.exmini a.allcard:hover{background:var(--lime-d);border-color:var(--lime-d)}

@media (max-width:760px){
  .svc{grid-template-columns:1fr;gap:0}
  .story{position:relative;margin-left:6px}
  .story .era{display:block;border:none;padding:0 0 26px 22px;border-left:2px solid var(--line3);position:relative}
  .story .era:last-child{border-left-color:transparent;padding-bottom:0}
  .story .era::before{content:"";position:absolute;left:-7px;top:3px;width:12px;height:12px;border-radius:50%;background:var(--lime);border:2px solid var(--bg)}
  .story .yr{font-size:13px;letter-spacing:.1em;color:var(--lime-d);font-family:var(--gothic);margin-bottom:5px}
  .story .ev h3{font-size:16px}
}

/* ===== TOKYO SOLID branded dark hero (旧サイト準拠) ===== */
.banner.page.tsx{height:auto;background:#0b0b0d}
.banner.page.tsx canvas{display:none}
.banner.page.tsx .tsx-in{position:relative;z-index:2;display:flex;flex-direction:column;align-items:center;text-align:center;gap:clamp(14px,3vw,26px);padding:clamp(82px,12vh,116px) 20px clamp(40px,6vh,60px);color:#fff}
.tsx-jp{font-family:var(--gothic);font-weight:800;letter-spacing:.06em;font-size:clamp(36px,9.5vw,82px);line-height:1}
.tsx-emblem{width:clamp(140px,32vw,230px);height:auto;display:block}
.tsx-en{font-family:var(--gothic);font-weight:800;letter-spacing:.005em;font-size:clamp(34px,9vw,68px);line-height:.96}
.tsx-sub{font-family:var(--gothic);font-weight:300;letter-spacing:.32em;font-size:clamp(14px,3.6vw,22px);color:rgba(255,255,255,.82)}
/* white header over the dark hero */
.banner.page.tsx .site-header .logo{color:#fff}
.banner.page.tsx .site-header nav a{color:#fff}
.banner.page.tsx .site-header nav .lang{color:rgba(255,255,255,.65)}
.banner.page.tsx .nav-toggle i,.banner.page.tsx .nav-toggle i::before,.banner.page.tsx .nav-toggle i::after{background:#fff}
.banner.page.tsx .langsw{border-color:rgba(255,255,255,.42)}
.banner.page.tsx .langsw .seg{color:rgba(255,255,255,.7)}
.banner.page.tsx .langsw .seg.on{background:#fff;color:#0b0b0d}
@media (max-width:820px){
  /* opened mobile menu uses light bg → keep its links dark */
  .banner.page.tsx .site-header nav.open a{color:var(--ink)}
}
