/* =========================================================
   REEK BREWING ─ ブルータリスト / タイポグラフィ主役
   極太可変フォント・非対称グリッド・大胆な色面・写真ゼロ
   ========================================================= */

:root{
  --black:#0d0d0c;
  --concrete:#e4e2da;   /* コンクリの白 */
  --acid:#e8ff00;       /* アシッドイエロー（主張色） */
  --rust:#ff3b1d;       /* 朱赤アクセント */
  --grey:#8c8a82;
  --disp:"Archivo", sans-serif;          /* 可変 wght 100-900 / wdth 62-125 */
  --exp:"Archivo", sans-serif;           /* 同フォントの横広(wdth125)を font-variation-settings で表現 */
  --mono:"Space Mono", monospace;
  --gothic:"Zen Kaku Gothic New", sans-serif;
  --line:3px solid var(--black);
}

*{margin:0;padding:0;box-sizing:border-box}
html{-webkit-text-size-adjust:100%;overflow-x:hidden}
body{
  font-family:var(--gothic);
  background:var(--concrete);
  color:var(--black);
  -webkit-font-smoothing:antialiased;
  overflow-x:hidden;
  line-height:1.7;
}
a{color:inherit;text-decoration:none}
img{display:block;max-width:100%}
::selection{background:var(--acid);color:var(--black)}
.num{font-variant-numeric:tabular-nums}

/* Archivo Expanded を廃し、Archivo の wdth 軸で「横広」を表現。
   旧 --exp を使う全表示要素にデフォルトで横広(wdth125)を効かせる。
   個別アニメ（JS）は font-variation-settings を上書きする。 */
.logo,.bar__cta,.hero__type,.hero__type .line,.sec-head__t,.tap__name,.tap__price,
.big-btn,.manifesto__line,.manifesto__line b,.find__t,.foot__logo,.sheet a,
.room__card h3,.voice__score,.ticker__run{
  font-variation-settings:"wght" 900, "wdth" 125;
}

/* ---------- ヘッダー（太枠ブロック） ---------- */
.bar{position:fixed;top:0;left:0;width:100%;z-index:90;
  display:flex;align-items:stretch;justify-content:space-between;
  background:var(--concrete);border-bottom:var(--line)}
.logo{font-family:var(--exp);font-weight:900;font-size:1.5rem;letter-spacing:-.02em;
  display:flex;align-items:center;padding:.7rem 1.2rem;border-right:var(--line)}
.logo span{color:var(--rust)}
.bar__nav{display:flex;align-items:stretch}
.bar__nav a{font-family:var(--mono);font-weight:700;font-size:.82rem;letter-spacing:.06em;
  display:flex;align-items:center;padding:0 1.2rem;border-left:1px solid rgba(13,13,12,.18);transition:.18s}
.bar__nav a:hover{background:var(--black);color:var(--acid)}
.bar__cta{font-family:var(--exp);font-weight:800;font-size:.9rem;background:var(--acid);
  display:flex;align-items:center;padding:0 1.5rem;border-left:var(--line);transition:.18s}
.bar__cta:hover{background:var(--black);color:var(--acid)}
.bar__burger{display:none;flex-direction:column;gap:5px;background:none;border:0;cursor:pointer;padding:1rem 1.2rem}
.bar__burger span{width:26px;height:3px;background:var(--black)}

.sheet{position:fixed;inset:0;z-index:85;background:var(--black);color:var(--concrete);
  display:flex;flex-direction:column;justify-content:center;gap:.6rem;padding:0 2rem;
  transform:translateX(100%);transition:transform .4s cubic-bezier(.7,0,.2,1);visibility:hidden}
.sheet.is-open{transform:translateX(0);visibility:visible}
.sheet a{font-family:var(--exp);font-weight:900;font-size:2.4rem;letter-spacing:-.02em}
.sheet a:hover{color:var(--acid)}
.sheet__cta{color:var(--acid)!important}

/* ---------- マーキー ---------- */
.ticker{overflow:hidden;background:var(--black);color:var(--acid);border-block:var(--line)}
.ticker--top{margin-top:54px}
.ticker__run{display:flex;gap:1.6rem;white-space:nowrap;font-family:var(--exp);font-weight:800;
  font-size:1rem;letter-spacing:.04em;padding:.5rem 0;width:max-content;will-change:transform;
  animation:march 26s linear infinite}
.ticker__run--rev{animation-direction:reverse}
.ticker__run span{text-transform:uppercase}
@keyframes march{to{transform:translateX(-50%)}}

/* =========================================================
   FV ─ 巨大可変タイポ
   ========================================================= */
.hero{padding:clamp(2rem,5vw,4rem) clamp(1rem,4vw,3rem) 0;position:relative;min-height:88vh;
  display:flex;flex-direction:column;justify-content:center}
.hero__tag{display:flex;flex-wrap:wrap;gap:.4rem 1.4rem;font-family:var(--mono);font-weight:700;
  font-size:.78rem;letter-spacing:.1em;margin-bottom:1rem;text-transform:uppercase}
.hero__tag span{border:2px solid var(--black);padding:.2rem .7rem}
.hero__type{font-family:var(--exp);font-weight:900;line-height:.82;letter-spacing:-.03em;
  font-size:clamp(4.5rem,21vw,20rem);text-transform:uppercase}
.hero__type .line{display:block;font-variation-settings:"wght" 900;position:relative;
  transform-origin:left bottom;--gx:0px;will-change:transform,font-variation-settings}
.hero__type .line--fill{color:transparent;-webkit-text-stroke:3px var(--black)}
.hero__type .line--out{color:var(--rust)}

/* JS有効時のみ：着弾の瞬間に走る色面ワイプ＋RGBグリッチ閃光 */
.hero__type .line::after{content:"";position:absolute;inset:-.06em -.04em;background:var(--acid);
  mix-blend-mode:multiply;transform:scaleX(0);transform-origin:left center;pointer-events:none;z-index:1}
.hero__type .line--out::after{background:var(--rust)}
.hero__type .line--fill::after{background:var(--acid)}
.hero__type .line.slam-hit::after{animation:slamWipe .5s cubic-bezier(.7,0,.15,1) forwards}
@keyframes slamWipe{
  0%{transform:scaleX(0);transform-origin:left center}
  45%{transform:scaleX(1);transform-origin:left center}
  46%{transform-origin:right center}
  100%{transform:scaleX(0);transform-origin:right center}
}
/* 着弾の瞬間だけ RGB スプリットのにじみ（--gx を JS が揺らす）。
   .glitching が付く間のみ。settle 後は外して元のデザイン（黒/中抜き/朱）に戻す。 */
.hero__type .line.glitching{
  text-shadow:calc(var(--gx) * -1) 0 var(--rust), var(--gx) 0 #00e0ff;
}
.hero__foot{display:flex;flex-wrap:wrap;align-items:flex-end;justify-content:space-between;
  gap:1.5rem;margin-top:clamp(1.5rem,3vw,2.5rem);border-top:var(--line);padding-top:1.4rem}
.hero__jp{font-size:clamp(1rem,1.6vw,1.25rem);max-width:30ch;font-weight:500}
.hero__jp b{background:var(--acid);padding:0 .25em;font-weight:700}
.hero__block{position:absolute;top:6rem;right:-2vw;font-family:var(--gothic);font-weight:900;
  font-size:30vh;color:rgba(13,13,12,.10);line-height:1;pointer-events:none;z-index:1;mix-blend-mode:multiply}

/* =========================================================
   FV 動くビジュアル ─ WebGL 液体シェーダー（手SVGビールグラスを置換）
   _shared/webgl-hero（procedural / motif=waves / アシッド黄×黒）で駆動。
   背面いっぱいに敷き、巨大タイポ・コピーは前面（z-index:2）に出る。
   JS無効/WebGL非対応/reduced-motion では .wgl-fallback の色面グラデが残る。
   ========================================================= */
.wgl-hero{isolation:isolate}
.wgl-canvas{position:absolute;inset:0;width:100%;height:100%;z-index:0;display:block;pointer-events:none}
/* 静止フォールバック：アシッド黄→黒の大胆な色面（液面メタファ） */
.wgl-fallback{position:absolute;inset:0;z-index:0;
  background:radial-gradient(120% 90% at 75% 30%,rgba(232,255,0,.85),rgba(232,255,0,0) 55%),
             linear-gradient(160deg,#1a1c00 0%,#0d0d0c 60%)}
.wgl-on .wgl-fallback{opacity:0;transition:opacity .6s ease}
/* ヒーロー本文は canvas より前面 */
.hero.wgl-hero > .hero__tag,
.hero.wgl-hero > .hero__type,
.hero.wgl-hero > .hero__foot{position:relative;z-index:2}
@media (prefers-reduced-motion:reduce){
  .wgl-canvas{display:none!important}
  .wgl-fallback{opacity:1!important}
}
/* FV が暗色面（黒×アシッド）になったため、ヒーロー文字を反転して可読性確保。
   下層セクション（concrete 地）は従来の黒文字のまま。ヒーロー内だけ上書き。 */
.hero.wgl-hero .hero__tag span{border-color:var(--concrete);color:var(--concrete)}
/* 1行目(REEK): 黒の極太縁取り付き concrete。明色面でも暗色面でも輪郭が立つ */
.hero.wgl-hero .hero__type .line{color:var(--concrete);
  text-shadow:0 0 1px var(--black),3px 3px 0 rgba(13,13,12,.55)}
/* 2行目(BREW): アシッド黄の上で最大コントラスト＝ベタ黒 */
.hero.wgl-hero .hero__type .line--fill{color:var(--black);-webkit-text-stroke:0}
/* 3行目(ING): 朱赤ベタ＋黒縁。黄でも黒面でも視認 */
.hero.wgl-hero .hero__type .line--out{color:var(--rust);text-shadow:2px 2px 0 var(--black)}
.hero.wgl-hero .hero__foot{border-top-color:var(--concrete)}
.hero.wgl-hero .hero__jp{color:var(--concrete)}
.hero.wgl-hero .hero__jp b{background:var(--acid);color:var(--black)}
.hero.wgl-hero .hero__block{color:rgba(232,255,0,.10);mix-blend-mode:screen}

/* 共通ボタン（極太・矩形） */
.big-btn{font-family:var(--exp);font-weight:800;font-size:1.05rem;letter-spacing:.02em;
  background:var(--black);color:var(--acid);padding:1.1rem 2rem;border:3px solid var(--black);
  display:inline-block;transition:.2s;box-shadow:7px 7px 0 var(--acid)}
.big-btn:hover{transform:translate(3px,3px);box-shadow:2px 2px 0 var(--acid)}
.big-btn--inv{background:var(--acid);color:var(--black);box-shadow:7px 7px 0 var(--black)}
.big-btn--inv:hover{box-shadow:2px 2px 0 var(--black)}
.big-btn--ghost{background:transparent;color:var(--concrete);border-color:var(--concrete);box-shadow:7px 7px 0 var(--rust)}
.big-btn--ghost:hover{box-shadow:2px 2px 0 var(--rust)}

/* ---------- セクション見出し共通 ---------- */
.sec-head{margin-bottom:2.5rem}
.sec-head__no{font-family:var(--mono);font-weight:700;font-size:.85rem;letter-spacing:.1em;
  display:inline-block;background:var(--black);color:var(--acid);padding:.25rem .7rem;margin-bottom:1rem}
.sec-head__t{font-family:var(--exp);font-weight:900;line-height:.9;letter-spacing:-.02em;
  font-size:clamp(2.8rem,8vw,7rem);text-transform:uppercase}
.sec-head__note{font-family:var(--mono);font-size:.85rem;max-width:46ch;margin-top:1rem;color:#3a3a36}
.sec-head--dark .sec-head__t{color:var(--acid)}

/* =========================================================
   TAPS ─ タイポ表組み（写真なし）
   ========================================================= */
.taps{padding:clamp(3rem,7vw,6rem) clamp(1rem,4vw,3rem);border-top:var(--line)}
.taplist{list-style:none;border-top:var(--line)}
.tap{display:grid;grid-template-columns:64px 150px 1fr 130px;align-items:center;gap:1rem;
  padding:1.3rem .6rem;border-bottom:var(--line);position:relative;transition:.2s}
.tap:hover{background:var(--black);color:var(--concrete)}
.tap:hover .tap__style{background:var(--acid);color:var(--black)}
.tap:hover .tap__name{font-variation-settings:"wght" 900}
.tap__n{font-family:var(--mono);font-weight:700;font-size:1.2rem}
.tap__style{font-family:var(--mono);font-weight:700;font-size:.74rem;letter-spacing:.06em;
  border:2px solid currentColor;padding:.2rem .4rem;text-align:center;justify-self:start}
.tap__name{font-family:var(--exp);font-weight:700;font-size:clamp(1.3rem,2.6vw,2.1rem);
  letter-spacing:-.01em;transition:font-variation-settings .3s}
.tap__spec{font-size:.86rem;color:#5a5a54}
.tap:hover .tap__spec{color:var(--grey)}
.tap__price{font-family:var(--exp);font-weight:900;font-size:1.5rem;text-align:right}
.tap__price i{font-family:var(--mono);font-weight:400;font-size:.7rem;font-style:normal;display:block}
.taps__more{margin-top:1.6rem;font-family:var(--mono);font-size:.88rem;background:var(--acid);
  padding:1rem 1.2rem;border:3px solid var(--black);box-shadow:6px 6px 0 var(--black)}

/* =========================================================
   MANIFESTO ─ 大色面ステートメント
   ========================================================= */
.manifesto{background:var(--black);color:var(--concrete);padding:clamp(4rem,9vw,8rem) clamp(1rem,4vw,3rem);
  position:relative;overflow:hidden}
.manifesto__no{font-family:var(--mono);font-weight:700;font-size:.85rem;letter-spacing:.1em;
  color:var(--acid);display:block;margin-bottom:1.5rem}
.manifesto__line{font-family:var(--exp);font-weight:900;line-height:.92;letter-spacing:-.03em;
  font-size:clamp(3rem,14vw,12rem);text-transform:none}
.manifesto__line b{font-weight:900;display:inline-block}
.manifesto__line:nth-child(2) b{color:var(--acid)}
.manifesto__line:nth-child(4) b{-webkit-text-stroke:2px var(--acid);color:transparent}
.manifesto__line--r{color:var(--rust);text-align:right;font-weight:400;font-variation-settings:"wght" 380, "wdth" 110}
.manifesto__read{display:flex;gap:2rem;flex-wrap:wrap;margin-top:2.5rem;border-top:2px solid var(--grey);padding-top:1.6rem}
.manifesto__read p{flex:1;min-width:260px;font-size:1.05rem;color:#cfcdc5}
.stat-row{display:grid;grid-template-columns:repeat(4,1fr);gap:0;margin-top:3rem;border:2px solid var(--grey)}
.stat{padding:1.6rem 1rem;border-right:2px solid var(--grey)}
.stat:last-child{border-right:0}
.stat b{font-family:var(--exp);font-weight:900;font-size:clamp(2.4rem,5vw,4rem);color:var(--acid);display:block;line-height:1}
.stat span{font-family:var(--mono);font-size:.78rem;color:var(--grey);letter-spacing:.04em}

/* =========================================================
   ROOM ─ 使い方カード（グラフィック、写真なし）
   ========================================================= */
.room{padding:clamp(3rem,7vw,6rem) clamp(1rem,4vw,3rem);background:var(--acid);border-block:var(--line)}
.room .sec-head--dark .sec-head__t{color:var(--black)}
.room .sec-head__no{background:var(--black);color:var(--acid)}
.room__grid{display:grid;grid-template-columns:repeat(4,1fr);gap:0;border:var(--line)}
.room__card{padding:1.8rem 1.4rem;border-right:var(--line);background:var(--acid);transition:.2s}
.room__card:last-child{border-right:0}
.room__card:hover{background:var(--black);color:var(--acid)}
.room__ico{font-size:2.6rem;display:block;line-height:1;margin-bottom:1rem}
.room__card h3{font-family:var(--exp);font-weight:800;font-size:1.25rem;margin-bottom:.6rem}
.room__card p{font-size:.9rem}
.room__note{font-family:var(--mono);font-size:.82rem;margin-top:1.4rem;font-weight:700}

/* =========================================================
   VOICE ─ 来店客の声
   ========================================================= */
.voice{padding:clamp(3rem,7vw,6rem) clamp(1rem,4vw,3rem)}
.voice__score{font-family:var(--exp);font-weight:800;font-size:1.4rem;margin-top:1rem}
.voice__score b{color:var(--rust)}
.voice__wall{display:grid;grid-template-columns:repeat(2,1fr);gap:0;border:var(--line)}
.rev{padding:2rem 1.8rem;border-right:var(--line);border-bottom:var(--line);background:var(--concrete);display:flex;flex-direction:column}
.rev:nth-child(2n){border-right:0}
.rev:nth-last-child(-n+2){border-bottom:0}
.rev--accent{background:var(--acid)}
.rev__stars{color:var(--rust);font-size:1.1rem;letter-spacing:.1em;margin-bottom:1rem}
.rev blockquote{font-size:1.08rem;font-weight:500;line-height:1.8;flex:1}
.rev figcaption{font-family:var(--mono);font-weight:700;font-size:.84rem;margin-top:1.2rem;
  border-top:2px solid var(--black);padding-top:1rem}

/* =========================================================
   FIND ─ CTA
   ========================================================= */
.find{background:var(--black);color:var(--concrete);padding:clamp(4rem,9vw,8rem) clamp(1rem,4vw,3rem);border-top:var(--line)}
.find__no{font-family:var(--mono);font-weight:700;color:var(--acid);letter-spacing:.1em;font-size:.85rem;margin-bottom:1rem}
.find__t{font-family:var(--exp);font-weight:900;font-size:clamp(3.5rem,16vw,14rem);line-height:.85;
  letter-spacing:-.03em;color:var(--acid);margin-bottom:2rem}
.find__cta{display:flex;gap:1.4rem;flex-wrap:wrap;margin-bottom:3rem}
.find__dl{display:grid;grid-template-columns:repeat(2,1fr);gap:0;border:2px solid var(--grey)}
.find__dl div{padding:1.2rem 1.4rem;border-right:2px solid var(--grey);border-bottom:2px solid var(--grey)}
.find__dl div:nth-child(2n){border-right:0}
.find__dl div:nth-last-child(-n+2){border-bottom:0}
.find__dl dt{font-family:var(--mono);font-weight:700;color:var(--acid);font-size:.78rem;letter-spacing:.08em;margin-bottom:.3rem}
.find__dl dd{font-size:.95rem}

/* ---------- フッター ---------- */
.foot{background:var(--concrete);display:flex;flex-wrap:wrap;gap:1.2rem;align-items:center;
  justify-content:space-between;padding:1.6rem clamp(1rem,4vw,3rem);border-top:var(--line);
  font-family:var(--mono);font-size:.82rem;font-weight:700}
.foot__logo{font-family:var(--exp);font-weight:900;font-size:1.3rem}
.foot__logo::after{content:"";color:var(--rust)}

/* =========================================================
   レスポンシブ
   ========================================================= */
@media (max-width:980px){
  .bar__nav{display:none}
  .bar__cta{display:none}
  .bar__burger{display:flex}
  .tap{grid-template-columns:48px 1fr 100px;grid-template-areas:"n style price" "n name price" "n spec price";gap:.2rem .8rem}
  .tap__n{grid-area:n}.tap__style{grid-area:style}.tap__name{grid-area:name}.tap__spec{grid-area:spec}.tap__price{grid-area:price;align-self:center}
  .room__grid{grid-template-columns:repeat(2,1fr)}
  .room__card:nth-child(2n){border-right:0}
  .room__card:nth-child(1),.room__card:nth-child(2){border-bottom:var(--line)}
  .stat-row{grid-template-columns:repeat(2,1fr)}
  .stat:nth-child(2n){border-right:0}
  .stat:nth-child(-n+2){border-bottom:2px solid var(--grey)}
}
@media (max-width:600px){
  .ticker--top{margin-top:50px}
  .hero__type{font-size:clamp(3.6rem,24vw,7rem)}
  .hero__foot{flex-direction:column;align-items:flex-start}
  .voice__wall{grid-template-columns:1fr}
  .rev{border-right:0!important;border-bottom:var(--line)!important}
  .rev:last-child{border-bottom:0!important}
  .find__dl{grid-template-columns:1fr}
  .find__dl div{border-right:0!important}
  .find__cta{flex-direction:column}
  .big-btn{text-align:center}
  .room__grid{grid-template-columns:1fr}
  .room__card{border-right:0!important;border-bottom:var(--line)}
  .room__card:last-child{border-bottom:0}
  .stat-row{grid-template-columns:1fr}
  .stat{border-right:0!important;border-bottom:2px solid var(--grey)}
  .stat:last-child{border-bottom:0}
  .manifesto__line--r{text-align:left}
}

/* =========================================================
   JS駆動アニメ用の初期状態
   .js が付くのは GSAP 駆動が確定した瞬間のみ。
   JS無効・GSAP未読込・reduced-motion(=.no-anim) では下記は適用されず、全要素は静止で完全可視。
   ========================================================= */
.js:not(.no-anim) [data-tap],
.js:not(.no-anim) .manifesto__line{opacity:0}
.js:not(.no-anim) .hero__tag span,
.js:not(.no-anim) .hero__foot,
.js:not(.no-anim) .hero__block{opacity:0}
/* data-stretch は scrub も絡むため JS 側 fromTo に初期を委ねる（チラつき防止に薄っすら隠す） */
.js:not(.no-anim) [data-stretch]{opacity:0}

/* 色面ワイプ：tap行・カード・レビューを横切るアシッド帯（--wipe 0→1 を JS が駆動） */
.wipe{position:relative}
.wipe::before{content:"";position:absolute;inset:0;background:var(--acid);z-index:2;pointer-events:none;
  transform-origin:left center;
  transform:scaleX(calc(1 - abs(var(--wipe,0) * 2 - 1)));
  opacity:calc(1 - abs(var(--wipe,0) * 2 - 1))}
.rev.wipe::before{background:var(--rust)}
/* abs() 非対応ブラウザでも崩れないよう、対応しない場合は帯を出さない（出現自体はGSAPのopacityで成立） */
@supports not (width: abs(1px)){
  .wipe::before{display:none}
}

/* body にスラム中クラスが付く間、本文選択を抑制（演出のノイズ防止） */
body.is-slamming{cursor:progress}

/* スクロール時の本文 skewY 用 */
main{transform-origin:center top}

/* reduced-motion：すべて静止。色面ワイプ・グリッチ・マーキーも停止。要素は全可視 */
@media (prefers-reduced-motion:reduce){
  *{animation-duration:.001ms!important;animation-iteration-count:1!important;transition-duration:.001ms!important}
  .ticker__run{animation:none;transform:none}
  .hero__type .line::after,.wipe::before{display:none}
  .hero__type .line{text-shadow:none!important}
  main{transform:none!important}
  /* 念のため：抑制環境でも全文字が見える */
  .hero__type .line,.hero__tag span,.hero__foot,.hero__block,
  [data-tap],[data-stretch],.manifesto__line{opacity:1!important}
}
