/* =========================================================
   VIBES VOLLEYBALL — 共有スタイル
   ブランド: 黒 × 白 × 赤（V/BESロゴ準拠）。ボールド・アスレチック・写真主役。
   参考トーン: leifras / athleteworks / victory の"法人の信頼 × スポーツの熱量"
   ========================================================= */
:root{
  --bg:#ffffff;
  --ink:#14161c;         /* 本文（ほぼ黒） */
  --ink-2:#333844;
  --ink-soft:#6a707c;
  --black:#0c0d11;       /* 濃色セクション */
  --black-2:#15171d;
  --red:#e60028;         /* VIBESレッド */
  --red-deep:#c00021;
  --gray:#f4f5f7;        /* 明るい交互面 */
  --line:#e6e8ec;
  --line-dark:#262933;
  --maxw:1200px;
  --shadow:0 18px 40px rgba(12,13,17,.14);
}
*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{
  margin:0;background:var(--bg);color:var(--ink);
  font-family:-apple-system,BlinkMacSystemFont,"Hiragino Sans","Noto Sans JP",sans-serif;
  line-height:1.85;-webkit-font-smoothing:antialiased;overflow-x:hidden;
}
img{max-width:100%;display:block}
a{color:inherit;text-decoration:none}

.en{font-family:"Anton","Hiragino Kaku Gothic ProN",sans-serif;font-weight:400;letter-spacing:.04em}
.jp-b{font-family:"Zen Kaku Gothic New","Hiragino Kaku Gothic ProN","Noto Sans JP",sans-serif;font-weight:900}

/* ---------- レイアウト ---------- */
.container{max-width:var(--maxw);margin:0 auto;padding:0 28px}
.section{padding:100px 0}
.section--tight{padding:70px 0}
.section--dark{background:var(--black);color:#eef0f4}
.section--gray{background:var(--gray)}
@media(max-width:700px){.section{padding:64px 0}.container{padding:0 20px}}

/* 見出しキッカー（英字・赤）＋大見出し */
.kicker{
  font-family:"Anton","Hiragino Kaku Gothic ProN",sans-serif;
  font-size:clamp(30px,6vw,52px);line-height:1;letter-spacing:.03em;
  color:var(--red);text-transform:uppercase;margin:0 0 6px;display:block;
}
.section--dark .kicker{color:var(--red)}
.h2{
  font-family:"Zen Kaku Gothic New","Hiragino Kaku Gothic ProN","Noto Sans JP",sans-serif;font-weight:900;
  font-size:clamp(22px,4.4vw,30px);line-height:1.5;letter-spacing:.01em;margin:0 0 20px;color:var(--ink);
}
.section--dark .h2{color:#fff}
.lead{font-size:clamp(15px,2.4vw,16px);color:var(--ink-soft);line-height:2.0;margin:0;max-width:640px}
.section--dark .lead{color:#b9c0cc}
.center{text-align:center}.center .lead{margin-left:auto;margin-right:auto}
.head-block{margin-bottom:52px}
.center.head-block{display:flex;flex-direction:column;align-items:center}

/* 赤いスラッシュ装飾 */
.slash{display:inline-block;width:46px;height:5px;background:var(--red);transform:skewX(-20deg);margin-bottom:18px}
.center .slash{margin-left:auto;margin-right:auto}

/* ---------- ボタン ---------- */
.btn{display:inline-flex;align-items:center;justify-content:center;gap:10px;
  font-family:"Zen Kaku Gothic New","Hiragino Kaku Gothic ProN",sans-serif;font-weight:900;
  font-size:15px;letter-spacing:.05em;padding:17px 34px;border:2px solid transparent;border-radius:3px;
  transition:transform .2s ease,background .2s ease,color .2s ease,box-shadow .2s ease;cursor:pointer;line-height:1.2}
.btn svg{width:18px;height:18px;flex:0 0 auto}
.btn-red{background:var(--red);color:#fff;box-shadow:0 10px 24px rgba(230,0,40,.28)}
.btn-red:hover{background:var(--red-deep);transform:translateY(-2px)}
.btn-line{background:#06c755;color:#fff;box-shadow:0 10px 24px rgba(6,199,85,.28)}
.btn-line:hover{filter:brightness(1.06);transform:translateY(-2px)}
.btn-dark{background:var(--ink);color:#fff}
.btn-dark:hover{background:#000;transform:translateY(-2px)}
.btn-ghost{background:transparent;border-color:rgba(255,255,255,.55);color:#fff}
.btn-ghost:hover{background:rgba(255,255,255,.12);transform:translateY(-2px)}
.btn-out{background:#fff;border-color:var(--ink);color:var(--ink)}
.btn-out:hover{background:var(--ink);color:#fff;transform:translateY(-2px)}
.btn-lg{padding:19px 40px;font-size:16px}
.btn-row{display:flex;flex-wrap:wrap;gap:14px}
.center .btn-row{justify-content:center}
.btn small{font-weight:500;font-size:11px;opacity:.85;letter-spacing:.08em}

/* ---------- ヘッダー ---------- */
.site-header{position:sticky;top:0;z-index:60;background:rgba(255,255,255,.96);backdrop-filter:blur(10px);border-bottom:1px solid var(--line);transition:box-shadow .3s}
.site-header.scrolled{box-shadow:0 4px 20px rgba(12,13,17,.08)}
.nav{display:flex;align-items:center;justify-content:space-between;height:76px;gap:20px}
.brand{display:flex;align-items:center;gap:12px;flex:0 0 auto}
.brand img{height:38px;width:auto;display:block}
.nav-links{display:flex;align-items:center;gap:30px}
.nav-links a:not(.btn){font-weight:700;font-size:14px;color:var(--ink);position:relative;padding:6px 0;letter-spacing:.02em}
.nav-links a:not(.btn) .en-sm{display:block;font-family:"Anton",sans-serif;font-size:10px;color:var(--red);letter-spacing:.1em;line-height:1;margin-bottom:3px}
.nav-links a:not(.btn)::after{content:"";position:absolute;left:0;right:0;bottom:0;height:2px;background:var(--red);transform:scaleX(0);transform-origin:left;transition:transform .25s}
.nav-links a:not(.btn):hover::after{transform:scaleX(1)}
.nav-toggle{display:none;background:none;border:0;padding:8px;cursor:pointer}
.nav-toggle span{display:block;width:26px;height:3px;background:var(--ink);margin:5px 0;transition:.3s;border-radius:2px}
@media(max-width:960px){
  .nav-links{position:fixed;inset:76px 0 auto 0;flex-direction:column;gap:0;background:#fff;padding:10px 22px 24px;
    transform:translateY(-130%);transition:transform .32s ease;box-shadow:0 20px 30px rgba(12,13,17,.1);align-items:stretch;border-bottom:1px solid var(--line)}
  .nav.open .nav-links{transform:translateY(0)}
  .nav-links a:not(.btn){padding:16px 4px;border-bottom:1px solid var(--line);font-size:15.5px}
  .nav-links a:not(.btn) .en-sm{display:inline;margin-right:10px}
  .nav-links a:not(.btn)::after{display:none}
  .nav-links .btn{margin-top:14px}
  .nav-toggle{display:block}
  .nav.open .nav-toggle span:nth-child(1){transform:translateY(8px) rotate(45deg)}
  .nav.open .nav-toggle span:nth-child(2){opacity:0}
  .nav.open .nav-toggle span:nth-child(3){transform:translateY(-8px) rotate(-45deg)}
}

/* ---------- ヒーロー ---------- */
.hero{position:relative;background:var(--black);color:#fff;overflow:hidden;min-height:min(88vh,760px);display:flex;align-items:center}
.hero-media{position:absolute;inset:0;z-index:0}
.hero-media img{width:100%;height:100%;object-fit:cover;object-position:center 30%;opacity:.62}
.hero-media::after{content:"";position:absolute;inset:0;
  background:linear-gradient(90deg,rgba(8,9,12,.9) 0%,rgba(8,9,12,.55) 55%,rgba(8,9,12,.35) 100%),
    linear-gradient(0deg,rgba(8,9,12,.85),transparent 55%)}
.hero-red{position:absolute;top:0;bottom:0;left:0;width:12px;background:var(--red);z-index:2}
.hero-inner{position:relative;z-index:3;padding:120px 0}
.hero-eyebrow{display:inline-flex;align-items:center;gap:12px;font-family:"Anton",sans-serif;font-size:14px;letter-spacing:.18em;color:#fff;margin-bottom:22px;text-transform:uppercase}
.hero-eyebrow::before{content:"";width:34px;height:4px;background:var(--red);transform:skewX(-20deg)}
.hero h1{font-family:"Zen Kaku Gothic New","Hiragino Kaku Gothic ProN",sans-serif;font-weight:900;
  font-size:clamp(30px,7vw,60px);line-height:1.28;letter-spacing:.01em;margin:0 0 24px;text-shadow:0 4px 30px rgba(0,0,0,.5)}
.hero h1 em{color:var(--red);font-style:normal}
.hero-sub{font-size:clamp(14.5px,2.6vw,17px);line-height:1.95;color:#d6dae2;max-width:560px;margin:0 0 34px;text-shadow:0 2px 16px rgba(0,0,0,.5)}
.hero .btn-row{margin-bottom:30px}
.hero-tags{display:flex;flex-wrap:wrap;gap:10px}
.hero-tags span{font-size:12.5px;font-weight:700;letter-spacing:.02em;border:1px solid rgba(255,255,255,.3);
  background:rgba(255,255,255,.06);padding:8px 16px;border-radius:2px;backdrop-filter:blur(4px);display:inline-flex;align-items:center;gap:8px}
.hero-tags span::before{content:"";width:7px;height:7px;background:var(--red);transform:skewX(-20deg);flex:0 0 auto}
/* 巨大英字ウォーターマーク */
.hero-watermark{position:absolute;right:-2%;bottom:-6%;z-index:1;font-family:"Anton",sans-serif;
  font-size:min(26vw,320px);line-height:.8;color:rgba(255,255,255,.045);letter-spacing:.02em;pointer-events:none;white-space:nowrap}

/* ---------- 実績ストリップ ---------- */
.statstrip{background:var(--red);color:#fff}
.statstrip .row{display:grid;grid-template-columns:repeat(4,1fr);gap:0}
@media(max-width:760px){.statstrip .row{grid-template-columns:repeat(2,1fr)}}
.statstrip .cell{padding:30px 20px;text-align:center;border-right:1px solid rgba(255,255,255,.16)}
.statstrip .cell:last-child{border-right:0}
@media(max-width:760px){.statstrip .cell:nth-child(2){border-right:0}.statstrip .cell:nth-child(1),.statstrip .cell:nth-child(2){border-bottom:1px solid rgba(255,255,255,.16)}}
.statstrip .num{font-family:"Anton",sans-serif;font-size:clamp(34px,7vw,48px);line-height:1;letter-spacing:.02em}
.statstrip .num small{font-size:.5em;margin-left:4px}
.statstrip .lb{font-size:12.5px;margin-top:8px;color:#ffdfe4;letter-spacing:.04em}

/* ---------- 汎用グリッド ---------- */
.grid{display:grid;gap:26px}
.g2{grid-template-columns:1fr 1fr}.g3{grid-template-columns:repeat(3,1fr)}.g4{grid-template-columns:repeat(4,1fr)}
@media(max-width:900px){.g3,.g4{grid-template-columns:1fr 1fr}}
@media(max-width:640px){.g2,.g3,.g4{grid-template-columns:1fr}}

/* ---------- ABOUT（写真＋テキスト） ---------- */
.split{display:grid;grid-template-columns:1.05fr .95fr;gap:56px;align-items:center}
@media(max-width:900px){.split{grid-template-columns:1fr;gap:34px}}
.split.rev .split-media{order:2}@media(max-width:900px){.split.rev .split-media{order:0}}
.split-media{position:relative}
.split-media img{width:100%;height:100%;max-height:480px;object-fit:cover;border-radius:4px}
.split-media::before{content:"";position:absolute;left:-16px;top:-16px;width:120px;height:120px;border:5px solid var(--red);border-radius:4px;z-index:-1}
.split-media .badge{position:absolute;right:-14px;bottom:-14px;background:var(--red);color:#fff;padding:16px 22px;border-radius:4px;box-shadow:var(--shadow)}
.split-media .badge b{font-family:"Anton",sans-serif;font-size:28px;line-height:1;display:block}
.split-media .badge span{font-size:11px;letter-spacing:.06em}

/* エコシステム・チップ */
.eco-chips{display:flex;flex-wrap:wrap;gap:10px;margin-top:22px}
.eco-chips span{font-size:13px;font-weight:700;color:var(--ink);background:var(--gray);border:1px solid var(--line);border-radius:2px;padding:9px 15px}
.eco-chips span b{color:var(--red)}

/* ---------- REASON（理由カード） ---------- */
.reason{background:#fff;border:1px solid var(--line);border-radius:5px;padding:34px 28px;position:relative;overflow:hidden;transition:transform .25s ease,box-shadow .25s ease}
.reason:hover{transform:translateY(-5px);box-shadow:var(--shadow)}
.reason .no{font-family:"Anton",sans-serif;font-size:56px;line-height:.8;color:var(--gray);position:absolute;top:16px;right:18px}
.reason .ic{width:56px;height:56px;border-radius:4px;background:var(--red);display:flex;align-items:center;justify-content:center;margin-bottom:18px;position:relative;z-index:1}
.reason .ic svg{width:28px;height:28px;stroke:#fff;fill:none;stroke-width:1.9;stroke-linecap:round;stroke-linejoin:round}
.reason h3{font-family:"Zen Kaku Gothic New","Hiragino Kaku Gothic ProN",sans-serif;font-weight:900;font-size:19px;margin:0 0 10px;color:var(--ink);line-height:1.45;position:relative;z-index:1}
.reason p{margin:0;font-size:14px;color:var(--ink-soft);line-height:1.95;position:relative;z-index:1}

/* ---------- OPERATING CLUBS（クラブカード） ---------- */
.club{position:relative;border-radius:6px;overflow:hidden;color:#fff;min-height:420px;display:flex;flex-direction:column;justify-content:flex-end;box-shadow:var(--shadow)}
.club-bg{position:absolute;inset:0;z-index:0}
.club-bg img{width:100%;height:100%;object-fit:cover;transition:transform .6s ease}
.club:hover .club-bg img{transform:scale(1.06)}
.club-bg::after{content:"";position:absolute;inset:0;background:linear-gradient(0deg,rgba(8,9,12,.92) 8%,rgba(8,9,12,.35) 60%,rgba(8,9,12,.15) 100%)}
.club-body{position:relative;z-index:2;padding:30px 30px 32px}
.club-logo{height:44px;width:auto;margin-bottom:16px;filter:brightness(0) invert(1)}
.club-tag{display:inline-block;font-family:"Anton",sans-serif;font-size:12px;letter-spacing:.14em;color:#fff;background:var(--red);padding:4px 12px;border-radius:2px;margin-bottom:14px}
.club h3{font-family:"Zen Kaku Gothic New","Hiragino Kaku Gothic ProN",sans-serif;font-weight:900;font-size:24px;margin:0 0 8px}
.club p{margin:0 0 20px;font-size:13.5px;color:#c8cdd6;line-height:1.8}
.club .btn-row .btn{padding:13px 22px;font-size:13.5px}

/* ---------- VOICE（声） ---------- */
.voice{background:#fff;border:1px solid var(--line);border-top:4px solid var(--red);border-radius:4px;padding:30px 26px}
.voice .q{font-family:"Anton",sans-serif;font-size:40px;color:var(--red);line-height:.6;display:block;margin-bottom:8px}
.voice h3{font-weight:900;color:var(--ink);font-size:17px;margin:0 0 12px;line-height:1.5}
.voice p{margin:0 0 16px;font-size:14px;color:var(--ink-2);line-height:1.9}
.voice .who{font-size:12px;color:var(--ink-soft);border-top:1px solid var(--line);padding-top:12px}
.voice .who .smp{color:var(--red);font-weight:700}

/* ---------- CONTACT band ---------- */
.contact-band{background:linear-gradient(120deg,#0c0d11,#1a1d25);color:#fff;position:relative;overflow:hidden}
.contact-band::before{content:"";position:absolute;right:-60px;top:-60px;width:280px;height:280px;background:radial-gradient(circle,rgba(230,0,40,.35),transparent 70%)}
.contact-band .inner{position:relative;z-index:2;text-align:center}
.contact-band .en-big{font-family:"Anton",sans-serif;font-size:clamp(40px,9vw,84px);line-height:.95;color:#fff;letter-spacing:.02em}
.contact-band .en-big em{color:var(--red);font-style:normal}

/* ---------- COMPANY（運営母体） ---------- */
.company-grid{display:grid;grid-template-columns:1fr 1fr;gap:24px}
@media(max-width:640px){.company-grid{grid-template-columns:1fr}}
.company{background:#fff;border:1px solid var(--line);border-radius:5px;padding:34px 30px;display:flex;flex-direction:column;align-items:flex-start;gap:16px;transition:transform .2s,box-shadow .2s}
.company:hover{transform:translateY(-3px);box-shadow:var(--shadow)}
.company img{height:54px;width:auto;object-fit:contain}
.company p{margin:0;font-size:13.5px;color:var(--ink-soft);line-height:1.85}
.company .link{font-family:"Anton",sans-serif;font-size:14px;letter-spacing:.06em;color:var(--red);display:inline-flex;align-items:center;gap:7px}

/* ---------- フッター ---------- */
.site-footer{background:#0a0b0e;color:#9aa1ad;font-size:13.5px}
.footer-top{padding:60px 0 40px;display:grid;grid-template-columns:1.4fr 1fr 1fr;gap:36px}
@media(max-width:820px){.footer-top{grid-template-columns:1fr}}
.footer-brand img{height:40px;margin-bottom:16px}
.footer-brand p{margin:0;line-height:1.9;color:#7f8794;max-width:330px}
.footer-col h4{color:#fff;font-family:"Anton",sans-serif;font-size:15px;letter-spacing:.08em;margin:0 0 14px}
.footer-col a{display:block;padding:6px 0;color:#9aa1ad}.footer-col a:hover{color:#fff}
.footer-bottom{border-top:1px solid #1c1e24;padding:18px 0;display:flex;flex-wrap:wrap;gap:8px;justify-content:space-between;font-size:12px;color:#6b7280}
.footer-note{background:#070809;color:#5a616c;font-size:11.5px;line-height:1.7;padding:14px 0}

/* ---------- リビール ---------- */
.js .reveal{opacity:0;transform:translateY(26px);transition:opacity .7s ease,transform .7s ease}
.js .reveal.in{opacity:1;transform:none}
.js .reveal.d1{transition-delay:.09s}.js .reveal.d2{transition-delay:.18s}.js .reveal.d3{transition-delay:.27s}
@media(prefers-reduced-motion:reduce){.js .reveal{opacity:1;transform:none;transition:none}html{scroll-behavior:auto}}

/* focus */
a:focus-visible,button:focus-visible{outline:3px solid var(--red);outline-offset:3px;border-radius:3px}
.section--dark a:focus-visible,.hero a:focus-visible,.contact-band a:focus-visible{outline-color:#fff}
:focus:not(:focus-visible){outline:none}

.mt-s{margin-top:16px}.mt-m{margin-top:30px}.mt-l{margin-top:48px}

/* ==========================================================
   横スクロールの動き — マーキー帯 ＋ ピン留め横スクロールギャラリー
   ========================================================== */
/* --- マーキー（自動で横に流れる） --- */
.marquee{background:var(--red);color:#fff;overflow:hidden;padding:15px 0;border-top:3px solid #0c0d11;border-bottom:3px solid #0c0d11}
.marquee-inner{display:flex;width:max-content;animation:marq 30s linear infinite}
.marquee:hover .marquee-inner{animation-play-state:paused}
.marquee-inner .grp{display:flex;align-items:center;gap:40px;padding-right:40px}
.marquee-inner .grp span{font-family:"Anton","Hiragino Kaku Gothic ProN",sans-serif;font-size:clamp(20px,3.2vw,32px);letter-spacing:.05em;text-transform:uppercase;white-space:nowrap}
.marquee-inner .grp .dot{color:rgba(255,255,255,.5);font-size:.8em}
@keyframes marq{to{transform:translateX(-50%)}}
@media(prefers-reduced-motion:reduce){.marquee-inner{animation:none}}

/* --- 横スクロール・ギャラリー（既定=スワイプ可能な横並び / デスクトップJSでピン留め） --- */
.hscroll{background:var(--black);color:#fff;overflow:hidden;position:relative}
.hscroll-inner{padding:84px 0}
.hscroll-head{max-width:var(--maxw);margin:0 auto 32px;padding:0 28px}
.hscroll-track{display:flex;gap:22px;padding:0 28px;overflow-x:auto;scroll-snap-type:x proximity;-webkit-overflow-scrolling:touch;scrollbar-width:none;will-change:transform}
.hscroll-track::-webkit-scrollbar{display:none}
.hs-card{flex:0 0 auto;width:min(78vw,440px);scroll-snap-align:center;position:relative;border-radius:6px;overflow:hidden;aspect-ratio:4/5;background:#15171d}
.hs-card img{width:100%;height:100%;object-fit:cover}
.hs-card::after{content:"";position:absolute;inset:0;background:linear-gradient(transparent 45%,rgba(8,9,12,.85))}
.hs-card figcaption{position:absolute;left:0;right:0;bottom:0;z-index:2;padding:26px 22px 18px;color:#fff;font-weight:900;font-size:16px;font-family:"Zen Kaku Gothic New","Hiragino Kaku Gothic ProN",sans-serif}
.hs-card .n{position:absolute;top:14px;left:16px;z-index:2;font-family:"Anton",sans-serif;font-size:20px;color:var(--red)}
.hs-hint{max-width:var(--maxw);margin:22px auto 0;padding:0 28px;font-family:"Anton",sans-serif;font-size:12px;letter-spacing:.18em;color:rgba(255,255,255,.5);display:flex;align-items:center;gap:10px}
.hs-hint::before{content:"";width:40px;height:2px;background:var(--red)}

/* デスクトップ: JSが .is-pin を付与 → 縦スクロールで横に流れる */
.hscroll.is-pin .hscroll-inner{position:sticky;top:0;min-height:100vh;display:flex;flex-direction:column;justify-content:center;padding:0}
.hscroll.is-pin .hscroll-track{overflow:visible;flex-wrap:nowrap}
.hscroll.is-pin .hs-card{width:min(38vw,460px)}
.hscroll.is-pin .hs-hint{display:none}

/* 修正: position:sticky が親のoverflow:hiddenで壊れる → overflowをinnerへ移す */
.hscroll{overflow:visible}
.hscroll.is-pin .hscroll-inner{overflow:hidden}

/* ==========================================================
   現場ギャラリー v2 — 自動横スクロール2列(反対方向)・タップで停止
   全デバイスで自動。hoverで一時停止(PC)・タップでトグル停止(モバイル)
   ========================================================== */
.gallery{background:var(--black);color:#fff;padding:90px 0 96px;overflow:hidden;position:relative}
.gallery-head{max-width:var(--maxw);margin:0 auto 40px;padding:0 28px}
.gal-rows{position:relative;-webkit-mask-image:linear-gradient(90deg,transparent,#000 5%,#000 95%,transparent);mask-image:linear-gradient(90deg,transparent,#000 5%,#000 95%,transparent);cursor:pointer}
.gal-row{display:flex;overflow:hidden}
.gal-row+.gal-row{margin-top:20px}
.gal-track{display:flex;gap:20px;width:max-content;padding-right:20px;will-change:transform}
.gal-row.r1 .gal-track{animation:galL 48s linear infinite}
.gal-row.r2 .gal-track{animation:galR 56s linear infinite}
.gallery:hover .gal-track,.gallery.is-paused .gal-track{animation-play-state:paused}
@keyframes galL{from{transform:translateX(0)}to{transform:translateX(-50%)}}
@keyframes galR{from{transform:translateX(-50%)}to{transform:translateX(0)}}
.gal-card{flex:0 0 auto;width:clamp(230px,30vw,330px);aspect-ratio:4/5;position:relative;border-radius:8px;overflow:hidden;background:#15171d}
.gal-card img{width:100%;height:100%;object-fit:cover;transition:transform .7s ease}
.gallery:not(.is-paused) .gal-card:hover img{transform:scale(1.05)}
.gal-card::after{content:"";position:absolute;inset:0;background:linear-gradient(transparent 44%,rgba(8,9,12,.9))}
.gal-card figcaption{position:absolute;left:0;right:0;bottom:0;z-index:2;padding:22px 20px 16px;font-weight:900;font-size:15.5px;font-family:"Zen Kaku Gothic New","Hiragino Kaku Gothic ProN",sans-serif;line-height:1.4}
.gal-card .n{position:absolute;top:12px;left:14px;z-index:2;font-family:"Anton",sans-serif;font-size:18px;color:var(--red)}
/* 停止/再生の操作ヒント */
.gallery-hint{position:absolute;right:24px;top:26px;z-index:5;font-family:"Anton",sans-serif;font-size:11px;letter-spacing:.14em;
  color:rgba(255,255,255,.62);display:inline-flex;align-items:center;gap:9px;cursor:pointer;user-select:none;background:rgba(255,255,255,.06);border:1px solid rgba(255,255,255,.16);padding:8px 14px;border-radius:99px;transition:background .2s,color .2s}
.gallery-hint:hover{background:rgba(255,255,255,.12);color:#fff}
.gallery-hint .ic{width:16px;height:16px;position:relative}
.gallery-hint .ic::before,.gallery-hint .ic::after{content:"";position:absolute;top:2px;bottom:2px;width:4px;background:currentColor;border-radius:1px}
.gallery-hint .ic::before{left:3px}.gallery-hint .ic::after{right:3px}
.gallery.is-paused .gallery-hint .ic::before{left:2px;width:0;height:0;top:2px;background:transparent;border-left:11px solid currentColor;border-top:6px solid transparent;border-bottom:6px solid transparent;border-radius:0}
.gallery.is-paused .gallery-hint .ic::after{display:none}
@media(max-width:600px){.gallery-hint{top:auto;bottom:-2px;right:20px}}
@media(prefers-reduced-motion:reduce){.gal-row{overflow-x:auto;-webkit-overflow-scrolling:touch}.gal-track{animation:none!important}.gal-rows{cursor:default}}

/* モバイル: 停止ボタンを下部の見やすい位置に */
@media(max-width:600px){.gallery-hint{top:auto;bottom:18px;right:18px}}
