/* ============================================================
   SOUKASHI TEAM JAPAN — site.css  共通デザインシステム
   ============================================================ */
@import url('https://fonts.googleapis.com/css2?family=Bebas+Neue&family=Cormorant+Garamond:ital,wght@0,300;0,400;1,300&family=Noto+Sans+JP:wght@300;400;500&family=Noto+Serif+JP:wght@300;400;700&display=swap');

:root {
  --black:  #060606;
  --deep:   #0b0b0b;
  --panel:  #0e0e0e;
  --white:  #f4efe9;
  --red:    #c8102e;
  --red-dk: #9e0b24;
  --gold:   #b8976a;
  --goldl:  #d4b483;
  --border: rgba(184,151,106,0.22);
  --muted:  rgba(244,239,233,0.58);
  --fnt-en: 'Bebas Neue', sans-serif;
  --fnt-jp: 'Noto Sans JP', sans-serif;
  --fnt-sr: 'Noto Serif JP', serif;
  --fnt-cr: 'Cormorant Garamond', serif;
}

*, *::before, *::after { margin:0; padding:0; box-sizing:border-box; }
html { scroll-behavior:smooth; }
body { background:var(--black); color:var(--white); font-family:var(--fnt-jp); overflow-x:hidden; line-height:1.6; }
a { text-decoration:none; color:inherit; }
img { max-width:100%; display:block; }

/* ── HEADER ─────────────────────── */
.sh {
  position:fixed; top:0; left:0; right:0; z-index:200;
  background:rgba(6,6,6,0.93); backdrop-filter:blur(14px);
  border-bottom:1px solid var(--border);
  display:flex; align-items:center; justify-content:space-between;
  padding:0 clamp(20px,4vw,60px); height:62px;
}
.sh-logo img { height:28px; width:auto; filter:brightness(0) invert(1); }
.sh-nav { display:flex; gap:clamp(12px,2vw,30px); align-items:center; }
.sh-nav a { font-size:clamp(10px,.9vw,12px); letter-spacing:.2em; color:var(--muted); transition:color .2s; }
.sh-nav a:hover, .sh-nav a.act { color:var(--gold); }
.sh-sns { display:flex; gap:14px; align-items:center; }
.sh-sns a { color:var(--muted); font-size:17px; transition:color .2s; }
.sh-sns a:hover { color:var(--gold); }
.sh-ham { display:none; flex-direction:row; align-items:center; gap:8px; cursor:pointer; padding:8px; }
.sh-ham-lines { display:flex; flex-direction:column; gap:5px; }
.sh-ham span { display:block; width:22px; height:1.5px; background:var(--white); transition:all .3s; }
.sh-ham-label { font-size:10px; letter-spacing:.2em; color:var(--white); }
.mob-nav {
  display:none; position:fixed; inset:0; background:rgba(6,6,6,.97); z-index:199;
  flex-direction:column; align-items:center; justify-content:center; gap:24px;
}
.mob-nav.open { display:flex; }
.mob-nav a { font-family:var(--fnt-en); font-size:clamp(30px,6vw,50px); letter-spacing:.15em; color:var(--white); transition:color .2s; }
.mob-nav a:hover { color:var(--gold); }
.mob-sns { display:flex; gap:24px; margin-top:16px; }
.mob-sns a { color:var(--muted); font-size:24px; transition:color .2s; }
.mob-sns a:hover { color:var(--gold); }
.mob-x { position:absolute; top:18px; right:22px; font-size:26px; color:var(--muted); cursor:pointer; background:none; border:none; }

/* ── PAGE HERO (inner pages) ─────── */
.ph {
  position:relative; height:52vh; min-height:320px;
  display:flex; align-items:flex-end; overflow:hidden;
  margin-top:62px;
}
.ph-bg {
  position:absolute; inset:0;
  background-size:cover; background-position:center;
  filter:brightness(.32) saturate(1.2); transform:scale(1.06);
  animation:phzoom 22s ease-in-out infinite alternate;
}
@keyframes phzoom { from{transform:scale(1.06)} to{transform:scale(1.13)} }
.ph-grad {
  position:absolute; inset:0;
  background:linear-gradient(to top, rgba(6,6,6,1) 0%, rgba(6,6,6,.3) 55%, transparent 100%);
}
.ph-body { position:relative; z-index:2; padding:0 clamp(24px,7vw,100px) 52px; }
.ph-label { font-size:10px; letter-spacing:.42em; color:var(--gold); margin-bottom:10px; }
.ph-title { font-family:var(--fnt-en); font-size:clamp(52px,9vw,120px); line-height:.88; letter-spacing:.03em; }
.ph-title span { color:var(--red); }
.ph-sub { font-family:var(--fnt-cr); font-weight:300; font-size:clamp(14px,1.5vw,19px); color:var(--gold); letter-spacing:.18em; margin-top:8px; }

/* ── SECTION COMMONS ─────────────── */
.wrap { max-width:1280px; margin:0 auto; padding:clamp(56px,8vw,100px) clamp(24px,6vw,80px); }
.wrap-sm { max-width:900px; margin:0 auto; padding:clamp(56px,8vw,100px) clamp(24px,6vw,80px); }

.sec-label { font-size:10px; letter-spacing:.42em; color:var(--gold); margin-bottom:10px; display:flex; align-items:center; gap:12px; }
.sec-label::after { content:''; width:44px; height:1px; background:var(--gold); flex-shrink:0; }
.sec-title { font-family:var(--fnt-en); font-size:clamp(34px,5vw,64px); line-height:.9; letter-spacing:.03em; margin-bottom:6px; }
.sec-title span { color:var(--red); }
.sec-sub { font-family:var(--fnt-cr); font-weight:300; font-size:clamp(13px,1.4vw,18px); color:var(--gold); letter-spacing:.18em; margin-bottom:40px; }
.divider { width:100%; height:1px; background:linear-gradient(90deg,transparent,var(--border),transparent); }

/* ── BUTTONS ─────────────────────── */
.btn-r {
  display:inline-flex; align-items:center; gap:10px;
  padding:15px 36px; background:var(--red); color:var(--white);
  font-family:var(--fnt-jp); font-size:13px; font-weight:500;
  letter-spacing:.25em; transition:background .25s, transform .2s;
}
.btn-r::after { content:'→'; font-size:15px; transition:transform .2s; }
.btn-r:hover { background:var(--red-dk); }
.btn-r:hover::after { transform:translateX(4px); }
.btn-g {
  display:inline-flex; align-items:center; gap:10px;
  padding:15px 36px; border:1px solid var(--gold); color:var(--gold);
  font-family:var(--fnt-jp); font-size:13px; letter-spacing:.25em; transition:all .25s;
}
.btn-g:hover { background:var(--gold); color:var(--black); }

/* ── PHOTO CARD ──────────────────── */
.pc { position:relative; overflow:hidden; background:#111; cursor:default; }
.pc img { width:100%; height:100%; object-fit:cover; display:block; filter:brightness(.78) saturate(1.1); transition:transform .65s ease,filter .4s; }
.pc:hover img { transform:scale(1.05); filter:brightness(1) saturate(1.22); }
.pc-g { position:absolute; inset:0; background:linear-gradient(to top,rgba(6,6,6,.9) 0%,rgba(6,6,6,.08) 55%,transparent 100%); pointer-events:none; }
.pc-i { position:absolute; bottom:0; left:0; right:0; padding:clamp(14px,1.8vw,22px); z-index:2; }
.pc-tag { font-size:9px; letter-spacing:.36em; color:var(--gold); margin-bottom:5px; display:flex; align-items:center; gap:7px; }
.pc-t { font-family:var(--fnt-en); font-size:clamp(14px,1.9vw,22px); letter-spacing:.07em; line-height:1.15; color:var(--white); }
.pc-t a:hover { color:var(--goldl); }
.pc-d { font-family:var(--fnt-cr); font-size:12px; color:var(--muted); margin-top:3px; }

/* ── GRIDS ───────────────────────── */
.g2 { display:grid; grid-template-columns:1fr 1fr; gap:3px; }
.g3 { display:grid; grid-template-columns:1fr 1fr 1fr; gap:3px; }
.g4 { display:grid; grid-template-columns:repeat(4,1fr); gap:3px; }
.g2-3 { display:grid; grid-template-columns:2fr 1fr; gap:3px; }
.g3-2 { display:grid; grid-template-columns:1fr 1fr 2fr; gap:3px; }
.ar43 { aspect-ratio:4/3; }
.ar169 { aspect-ratio:16/9; }
.ar34 { aspect-ratio:3/4; }
.ar11 { aspect-ratio:1/1; }

/* ── LIST ────────────────────────── */
.sl-item { display:flex; align-items:center; gap:14px; padding:13px 6px; border-bottom:1px solid rgba(255,255,255,.05); transition:background .2s,padding-left .2s; }
.sl-item:hover { background:rgba(255,255,255,.018); padding-left:12px; }
.sl-flag { font-size:17px; flex-shrink:0; width:22px; text-align:center; }
.sl-name { font-size:clamp(12px,1.2vw,14px); font-weight:300; letter-spacing:.06em; flex:1; }
.sl-name a { color:var(--goldl); }
.sl-name a:hover { text-decoration:underline; }
.sl-yr { font-family:var(--fnt-cr); font-size:13px; color:var(--muted); letter-spacing:.1em; flex-shrink:0; }

/* ── REVEAL ──────────────────────── */
.rev { opacity:0; transform:translateY(22px); transition:opacity .75s ease,transform .75s ease; }
.rev.on { opacity:1; transform:translateY(0); }

/* ── FOOTER ──────────────────────── */
.sf { background:#020202; border-top:1px solid var(--border); padding:44px clamp(24px,6vw,80px) 28px; }
.sf-inner { max-width:1280px; margin:0 auto; display:grid; grid-template-columns:auto 1fr; gap:52px; align-items:start; padding-bottom:32px; border-bottom:1px solid var(--border); margin-bottom:24px; }
.sf-logo img { height:30px; width:auto; filter:brightness(0) invert(1) opacity(.7); }
.sf-nav { display:flex; flex-wrap:wrap; gap:7px 20px; list-style:none; }
.sf-nav a { font-size:12px; color:var(--muted); letter-spacing:.1em; transition:color .2s; }
.sf-nav a:hover { color:var(--gold); }
.sf-sns { display:flex; gap:18px; margin-top:18px; }
.sf-sns a { color:var(--muted); font-size:19px; transition:color .2s; }
.sf-sns a:hover { color:var(--gold); }
.sf-copy { font-size:11px; color:rgba(244,239,233,.26); letter-spacing:.1em; text-align:center; }

/* ── RESPONSIVE ──────────────────── */
@media(max-width:900px){
  .sh-nav,.sh-sns { display:none; }
  .sh-ham { display:flex; }
  .g3,.g4 { grid-template-columns:1fr 1fr; }
  .g2-3,.g3-2 { grid-template-columns:1fr; }
  .sf-inner { grid-template-columns:1fr; gap:24px; }
}
@media(max-width:600px){
  .g2,.g3,.g4,.g2-3,.g3-2 { grid-template-columns:1fr; }
  .ar169,.ar43,.ar34,.ar11 { aspect-ratio:4/3; }
}
