/* ============================================================
   AWaaaKE BAR — style.css  v4
   Black × Neon Blue | Max Immersion | 2026
   ============================================================ */

:root {
  --c-black:    #050508;
  --c-bg:       #07070e;
  --c-bg2:      #0a0a14;
  --c-surface:  #0f0f1e;
  --c-surface2: #161628;
  --c-neon:     #00d4ff;
  --c-neon-dim: rgba(0,212,255,.15);
  --c-neon-glow:rgba(0,212,255,.4);
  --c-text:     #e2e2ee;
  --c-text-dim: #5a5a78;
  --c-border:   rgba(0,212,255,.13);
  --c-border2:  rgba(255,255,255,.05);

  --font-display:'Bebas Neue', sans-serif;
  --font-mincho: 'Shippori Mincho', serif;
  --font-body:   'Noto Sans JP', sans-serif;

  --ease-expo:  cubic-bezier(0.16,1,0.3,1);

  --header-h:  62px;
  --pad-x:     clamp(1.4rem,5vw,5rem);
  --spy:       clamp(6rem,13vw,10rem);
}

/* ── Reset ── */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{font-size:16px;scroll-behavior:smooth;background:var(--c-black);overflow-x:hidden}
body{font-family:var(--font-body);color:var(--c-text);background:var(--c-bg);overflow-x:hidden;-webkit-font-smoothing:antialiased;cursor:none}

/* ── Custom cursor ── */
.cursor{position:fixed;top:0;left:0;z-index:9999;pointer-events:none;width:10px;height:10px;border-radius:50%;background:var(--c-neon);transform:translate(-50%,-50%);box-shadow:0 0 14px var(--c-neon-glow);transition:width .2s,height .2s,opacity .2s;mix-blend-mode:screen;will-change:transform}
.cursor-ring{position:fixed;top:0;left:0;z-index:9998;pointer-events:none;width:36px;height:36px;border-radius:50%;border:1px solid rgba(0,212,255,.55);transform:translate(-50%,-50%);will-change:transform;transition:width .3s var(--ease-expo),height .3s var(--ease-expo),opacity .2s}
.cursor.hovered{width:46px;height:46px;opacity:.55}
.cursor-ring.hovered{width:58px;height:58px}

/* ── Shared ── */
.container{max-width:1200px;margin:0 auto;padding:0 var(--pad-x)}
.ig-icon{width:20px;height:20px;display:block;flex-shrink:0}
.section-label{font-family:var(--font-display);font-size:.66rem;letter-spacing:.45em;color:var(--c-neon);opacity:.8;margin-bottom:1.2rem}

.neon-text{
  color:var(--c-neon);
  text-shadow:0 0 18px rgba(0,212,255,.9),0 0 55px rgba(0,212,255,.45),0 0 110px rgba(0,212,255,.2);
  animation:neonBreath 4s ease-in-out infinite alternate
}
@keyframes neonBreath{
  from{text-shadow:0 0 18px rgba(0,212,255,.8),0 0 50px rgba(0,212,255,.35)}
  to  {text-shadow:0 0 28px rgba(0,212,255,1), 0 0 80px rgba(0,212,255,.6),0 0 140px rgba(0,212,255,.25)}
}

/* ================================================================
   HEADER
   Key fix: use `display:flex` on inner with logo + nav + right.
   Right cluster gets `margin-left:auto` so it always sits at the
   far right — even when nav is hidden (mobile).
================================================================ */
.site-header{
  position:fixed;top:0;left:0;right:0;z-index:800;
  height:var(--header-h);
  background:rgba(5,5,8,.84);
  border-bottom:1px solid var(--c-border);
  backdrop-filter:blur(18px);-webkit-backdrop-filter:blur(18px);
  transition:background .3s
}
.site-header.scrolled{background:rgba(5,5,8,.97)}

.site-header__inner{
  /* Single flex row. Logo | Nav (optional) | Right */
  display:flex;
  align-items:center;
  height:100%;
  padding:0 var(--pad-x);
  gap:0  /* gaps set per-child below */
}

.site-header__logo{
  font-family:var(--font-display);
  font-size:clamp(1.3rem,2.8vw,1.75rem);
  letter-spacing:.04em;color:var(--c-text);
  text-decoration:none;cursor:none;flex-shrink:0;
  margin-right:clamp(1rem,3vw,2.5rem);
  transition:color .2s
}
.site-header__logo:hover{color:var(--c-neon)}

.site-header__nav{
  display:flex;
  gap:clamp(.8rem,2.2vw,2rem);
  flex-shrink:0
}
.site-header__nav a{
  font-family:var(--font-display);font-size:.76rem;letter-spacing:.2em;
  color:var(--c-text-dim);text-decoration:none;cursor:none;transition:color .2s
}
.site-header__nav a:hover{color:var(--c-neon)}

/*
  RIGHT cluster: margin-left:auto pushes it all the way to the
  right end of the flex row, regardless of whether nav is shown.
  This works on BOTH desktop and mobile.
*/
.site-header__right{
  display:flex;
  align-items:center;
  gap:1.1rem;
  margin-left:auto;   /* ← THE critical fix */
  flex-shrink:0
}

.header-ig-link{display:flex;align-items:center;color:var(--c-text-dim);cursor:none;transition:color .2s,filter .2s}
.header-ig-link:hover{color:var(--c-neon);filter:drop-shadow(0 0 6px var(--c-neon-glow))}

.lang-toggle{display:flex;align-items:center;gap:.28rem}
.lang-btn{font-family:var(--font-display);font-size:.7rem;letter-spacing:.1em;color:var(--c-text-dim);background:none;border:none;cursor:none;padding:.18rem .32rem;transition:color .2s}
.lang-btn.active{color:var(--c-neon)}
.lang-divider{color:rgba(0,212,255,.2);font-size:.6rem;user-select:none}

/* Section bg parallax layer */
.s-section{position:relative;overflow:hidden}
.s-bg-layer{position:absolute;inset:-30% 0;pointer-events:none;z-index:0;will-change:transform}

/* ================================================================
   HERO
================================================================ */
.hero{
  position:relative;height:100svh;min-height:600px;
  display:flex;align-items:center;justify-content:center;
  overflow:hidden;background:var(--c-black);
  padding-top:var(--header-h)
}

/* Slideshow */
.hero__slideshow{position:absolute;inset:0;z-index:0}
.hero__slide{
  position:absolute;inset:0;
  background-size:cover;background-position:center;
  background-color:var(--c-black);
  background-image:
    radial-gradient(ellipse 70% 55% at 50% 28%,#060625 0%,#050508 82%),
    radial-gradient(ellipse 40% 30% at 72% 65%,rgba(0,40,70,.3) 0%,transparent 60%);
  opacity:0;
  transition:opacity 1.4s cubic-bezier(.4,0,.2,1);
}
.hero__slide--active{opacity:1;animation:kenBurns 7s ease-in-out forwards}
@keyframes kenBurns{from{transform:scale(1.06)}to{transform:scale(1)}}

/* Parallax layers */
.hero__layer{position:absolute;inset:-22%;will-change:transform;pointer-events:none}
.hero__smoke{z-index:2;background:radial-gradient(ellipse 50% 35% at 20% 70%,rgba(0,60,120,.14) 0%,transparent 60%),radial-gradient(ellipse 45% 30% at 80% 40%,rgba(0,30,80,.1) 0%,transparent 55%);animation:smokeDrift 14s ease-in-out infinite alternate}
@keyframes smokeDrift{from{transform:translateX(-2%) scaleX(1)}to{transform:translateX(2%) scaleX(1.04)}}
.hero__mid{z-index:3}.hero__lights{z-index:4}.hero__fg{z-index:5}

.hero__counter{position:absolute;bottom:23%;left:50%;transform:translateX(-50%);width:145%;height:15%;background:linear-gradient(180deg,#0e0e20 0%,#08080f 55%,#050508 100%);border-top:1px solid rgba(0,212,255,.18)}
.hero__bottles{position:absolute;bottom:34%;left:50%;transform:translateX(-50%);display:flex;gap:clamp(10px,2vw,22px);align-items:flex-end}
.bottle{width:clamp(9px,1.4vw,15px);border-radius:2px 2px 1px 1px;background:linear-gradient(180deg,rgba(0,90,130,.38) 0%,rgba(0,30,60,.72) 100%);box-shadow:0 0 10px rgba(0,212,255,.07)}
.b1{height:clamp(58px,8.5vw,86px)}.b2{height:clamp(78px,11.5vw,106px)}.b3{height:clamp(68px,10vw,90px)}.b4{height:clamp(52px,7.5vw,76px)}.b5{height:clamp(72px,10.5vw,98px)}.b6{height:clamp(60px,9vw,82px)}.b7{height:clamp(84px,12vw,112px)}

.spot{position:absolute;border-radius:50%;filter:blur(100px);animation:spotBreath 8s ease-in-out infinite}
.s1{width:300px;height:580px;background:radial-gradient(ellipse,rgba(0,130,210,.16) 0%,transparent 70%);top:-20%;left:16%;animation-delay:0s}
.s2{width:240px;height:480px;background:radial-gradient(ellipse,rgba(0,212,255,.11) 0%,transparent 70%);top:-15%;right:20%;animation-delay:3s}
.s3{width:180px;height:300px;background:radial-gradient(ellipse,rgba(0,160,255,.08) 0%,transparent 70%);top:10%;left:50%;animation-delay:6s}
@keyframes spotBreath{0%,100%{opacity:.65}50%{opacity:1}}

.neon-bar{position:absolute;bottom:37%;left:50%;transform:translateX(-50%);width:55%;height:1px;background:linear-gradient(90deg,transparent,rgba(0,212,255,.55),transparent);box-shadow:0 0 22px 2px rgba(0,212,255,.18);animation:neonFlicker 6s ease-in-out infinite}
@keyframes neonFlicker{0%,100%{opacity:1}90%{opacity:1}92%{opacity:.3}93%{opacity:1}97%{opacity:.6}98%{opacity:1}}

.stool{position:absolute;bottom:0;width:clamp(50px,8.5vw,92px);height:clamp(105px,19vw,185px);background:linear-gradient(180deg,#0f0f1e 0%,#07070e 100%);border-top:1px solid rgba(0,212,255,.09)}
.sl{left:clamp(-8px,3.5vw,48px);transform:perspective(280px) rotateY(5deg)}
.sr{right:clamp(-8px,3.5vw,48px);transform:perspective(280px) rotateY(-5deg)}
.bar-lip{position:absolute;bottom:0;left:50%;transform:translateX(-50%);width:135%;height:clamp(32px,5.5vw,58px);background:linear-gradient(180deg,#0f0f1e 0%,#07070e 100%);border-top:1px solid rgba(0,212,255,.07)}

/* Hero content */
.hero__content{
  position:relative;z-index:10;text-align:center;
  padding:0 1.5rem;pointer-events:none;will-change:transform
}
.hero__eyebrow{font-family:var(--font-display);font-size:clamp(.58rem,1.5vw,.78rem);letter-spacing:.42em;color:var(--c-neon);opacity:0;transform:translateY(20px);animation:fadeUp .8s .4s var(--ease-expo) forwards;margin-bottom:.9rem}
.hero__title{
  font-family: "Satoshi","Clash Display","Space Grotesk",system-ui,-apple-system,BlinkMacSystemFont,sans-serif;
  font-size: clamp(5.5rem,19vw,17rem);
  line-height: .88;
  letter-spacing: -.01em;
  color: var(--c-text);
  opacity: 0;
  transform: translateY(38px) scale(.97);
  animation: fadeUp 1s .62s var(--ease-expo) forwards;
  text-shadow: 0 2px 80px rgba(0,0,0,.95);
}
.hero__tagline{font-family:var(--font-mincho);font-size:clamp(.95rem,3vw,1.65rem);font-weight:400;letter-spacing:.15em;color:var(--c-text);margin-top:1.4rem;opacity:0;transform:translateY(20px);animation:fadeUp .8s 1s var(--ease-expo) forwards}
.hero__sub{font-family:var(--font-display);font-size:clamp(.65rem,1.7vw,.9rem);letter-spacing:.42em;color:var(--c-text-dim);margin-top:.85rem;opacity:0;animation:fadeUp .8s 1.3s var(--ease-expo) forwards}
@keyframes fadeUp{to{opacity:1;transform:none}}

/*
  SCROLL CUE — absolutely centred horizontally.
  position:absolute + left:50% + translateX(-50%) is the only
  reliable way to centre an absolutely-positioned element.
  DO NOT use margin:auto here.
*/
.hero__scroll-cue{
  position:absolute;
  bottom:clamp(1.4rem,3.5vw,2.5rem);

  left:0;
  right:0;
  margin-inline:auto;

  z-index:10;
  display:flex;
  flex-direction:column;
  align-items:center;
  gap:.65rem;

  opacity:0;
  animation:fadeUp .8s 2s var(--ease-expo) forwards;

  cursor:none;
  width:max-content;
}

.hero__scroll-label{
  font-family:var(--font-display);
  font-size:.62rem;
  letter-spacing:.32em;
  color:var(--c-neon);
  opacity:.6
}

.hero__scroll-line{
  width:1px;
  height:46px;
  background:linear-gradient(to bottom,var(--c-neon),transparent);
  box-shadow:0 0 6px rgba(0,212,255,.35);
  animation:scrollPulse 2.4s ease-in-out infinite
}

@keyframes scrollPulse{
  0%,100%{transform:scaleY(1);opacity:.5}
  50%{transform:scaleY(.55);opacity:1}
}

/* ================================================================
   CONCEPT
================================================================ */
.concept{padding:var(--spy) 0;background:var(--c-bg)}
.orb{position:absolute;border-radius:50%;filter:blur(120px);pointer-events:none}
.orb1{width:500px;height:500px;background:radial-gradient(circle,rgba(0,80,140,.12) 0%,transparent 70%);top:0%;left:-10%}
.orb2{width:400px;height:400px;background:radial-gradient(circle,rgba(0,120,180,.08) 0%,transparent 70%);bottom:0%;right:-5%}

/* ================================================================
   MARQUEE — seamless infinite loop
   The JS clones the track once so the two copies sit end-to-end.
   CSS animates the INNER wrapper (which is track-width * 2 wide)
   from 0 to -50% so it loops perfectly with zero gap.
================================================================ */
.marquee-outer{
  overflow:hidden;
  padding:1.3rem 0;margin-bottom:3rem;
  border-top:1px solid var(--c-border2);
  border-bottom:1px solid var(--c-border2);
  position:relative;z-index:2
}
.marquee-inner{
  display:flex;width:max-content;
  /* Animation set by JS after cloning */
  will-change:transform
}
.marquee-track{
  display:flex;align-items:center;gap:2rem;padding-right:2rem;
  font-family:var(--font-display);font-size:clamp(.88rem,1.9vw,1.15rem);
  letter-spacing:.18em;color:var(--c-text-dim);white-space:nowrap;
  flex-shrink:0
}
.marquee-track span{white-space:nowrap}
.marquee-track em{color:var(--c-neon);opacity:.5;font-style:normal}
@keyframes marqueeRun{from{transform:translateX(0)}to{transform:translateX(-50%)}}

.concept__inner{display:grid;grid-template-columns:1fr 1fr;gap:clamp(3rem,8vw,8rem);align-items:center;position:relative;z-index:2}
.concept__heading{font-family:var(--font-mincho);font-size:clamp(2rem,5vw,3.4rem);font-weight:800;line-height:1.18;color:var(--c-text);margin-bottom:1.8rem}
.concept__body{font-family:var(--font-mincho);font-size:clamp(.9rem,1.65vw,1.03rem);line-height:2.15;color:var(--c-text-dim)}
.concept__card-stack{display:flex;flex-direction:column;gap:1rem}

/* concept cards — scroll-driven animation handled by JS */
.concept__card{
  background:var(--c-surface);border:1px solid var(--c-border2);border-radius:12px;
  padding:1.35rem 1.55rem;display:flex;align-items:center;gap:1.15rem;
  position:relative;overflow:hidden;
  transition:border-color .3s,box-shadow .35s,transform .35s var(--ease-expo)
}
.concept__card::before{content:'';position:absolute;inset:0;background:linear-gradient(135deg,rgba(0,212,255,.04) 0%,transparent 60%);opacity:0;transition:opacity .35s}
.concept__card:hover{border-color:var(--c-border);box-shadow:0 0 30px rgba(0,212,255,.07),0 14px 40px rgba(0,0,0,.4);transform:translateY(-4px) scale(1.01)}
.concept__card:hover::before{opacity:1}
.concept__card-icon{flex-shrink:0;width:36px;height:36px;color:var(--c-text-dim);transition:color .3s}
.concept__card-icon svg{width:100%;height:100%}
.concept__card:hover .concept__card-icon{color:var(--c-neon);filter:drop-shadow(0 0 6px var(--c-neon-glow))}
.concept__card div{display:flex;flex-direction:column;gap:.22rem}
.concept__card strong{font-family:var(--font-mincho);font-size:.93rem;font-weight:700;color:var(--c-text)}
.concept__card span{font-size:.76rem;color:var(--c-text-dim)}

/* ================================================================
   MENU
================================================================ */
.menu{padding:var(--spy) 0;background:var(--c-bg2)}
.menu-bg-grid{position:absolute;inset:0;background-image:linear-gradient(rgba(0,212,255,.025) 1px,transparent 1px),linear-gradient(90deg,rgba(0,212,255,.025) 1px,transparent 1px);background-size:60px 60px;mask-image:radial-gradient(ellipse 70% 70% at 50% 50%,black 20%,transparent 80%)}
.menu__header{text-align:center;margin-bottom:4rem;position:relative;z-index:2}
.menu__title-outline{font-family:var(--font-display);font-size:clamp(4.5rem,13vw,9.5rem);letter-spacing:.04em;line-height:1;color:transparent;-webkit-text-stroke:1px rgba(0,212,255,.28);margin-bottom:.7rem}
.menu__subtitle{font-family:var(--font-mincho);font-size:clamp(.92rem,2vw,1.15rem);color:var(--c-text-dim)}
.menu__block{margin-bottom:5rem;position:relative;z-index:2}
.menu__block:last-child{margin-bottom:0}
.menu__block-label{margin-bottom:1.8rem}

.menu__grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(clamp(230px,26vw,285px),1fr));gap:clamp(1rem,2.2vw,1.7rem)}

/* menu-card: JS drives transform/opacity via CSS custom props */
.menu-card{
  background:var(--c-surface);border:1px solid var(--c-border2);
  border-radius:16px;overflow:hidden;cursor:none;
  /* Base transition for hover micro-interactions only */
  transition:border-color .4s,box-shadow .4s;
  transform-style:preserve-3d;position:relative;
  will-change:transform,opacity
}
.menu-card:hover{border-color:var(--c-border);box-shadow:0 0 45px rgba(0,212,255,.08),18px 26px 55px rgba(0,0,0,.55)}
.menu-card__img-wrap{height:clamp(155px,23vw,205px);position:relative;overflow:hidden}
.menu-card__img{width:100%;height:100%;background-size:cover;background-position:center;transition:transform .65s var(--ease-expo)}
.menu-card:hover .menu-card__img{transform:scale(1.07)}
.menu-card__neon-edge{position:absolute;bottom:0;left:0;right:0;height:1px;background:linear-gradient(90deg,transparent,var(--c-neon),transparent);box-shadow:0 0 12px var(--c-neon-glow);opacity:0;transition:opacity .35s}
.menu-card:hover .menu-card__neon-edge{opacity:1}
.mcimg-dagashi{background:radial-gradient(circle at 35% 45%,rgba(50,50,75,.7),transparent 55%),linear-gradient(135deg,#0b0b18 0%,#161626 100%)}
.mcimg-beer{background:radial-gradient(circle at 50% 30%,rgba(0,90,130,.22),transparent 55%),linear-gradient(180deg,#080814 0%,#050510 100%)}
.mcimg-set{background:radial-gradient(circle at 38% 55%,rgba(0,70,110,.2),transparent 55%),radial-gradient(circle at 65% 32%,rgba(35,35,55,.35),transparent 50%),linear-gradient(135deg,#090916 0%,#111120 100%)}
.mcimg-cocktail{background:radial-gradient(circle at 42% 32%,rgba(0,55,95,.25),transparent 55%),linear-gradient(135deg,#07070e 0%,#0e0e1a 100%)}
.menu-card__body{padding:1.35rem 1.45rem}
.menu-card__name{font-family:var(--font-mincho);font-size:.98rem;font-weight:700;margin-bottom:.45rem;color:var(--c-text)}
.menu-card__desc{font-size:.8rem;line-height:1.8;color:var(--c-text-dim);margin-bottom:.9rem}
.menu-card__price{font-family:var(--font-display);font-size:1.28rem;letter-spacing:.05em;color:var(--c-neon);text-shadow:0 0 14px rgba(0,212,255,.45)}

/* Text menu — cols driven by JS scroll animation */
.text-menu{display:grid;grid-template-columns:repeat(3,1fr);gap:clamp(1.8rem,4.5vw,3.5rem);background:var(--c-surface);border:1px solid var(--c-border2);border-radius:16px;padding:clamp(1.8rem,3.8vw,3rem);position:relative;overflow:hidden;will-change:transform,opacity}
.text-menu::before{content:'';position:absolute;inset:0;background:linear-gradient(135deg,rgba(0,212,255,.03) 0%,transparent 50%);pointer-events:none}
.text-menu__col{will-change:transform,opacity}
.text-menu__category{font-family:var(--font-display);font-size:.88rem;letter-spacing:.2em;color:var(--c-neon);margin-bottom:1.3rem;padding-bottom:.75rem;border-bottom:1px solid var(--c-border)}
.text-menu__list{list-style:none;display:flex;flex-direction:column;gap:.65rem}
.text-menu__item{display:flex;align-items:baseline;gap:.45rem}
.text-menu__name{font-family:var(--font-mincho);font-size:.86rem;color:var(--c-text-dim);white-space:nowrap;flex-shrink:0}
.text-menu__dots{flex:1;border-bottom:1px dotted rgba(255,255,255,.08);margin-bottom:3px;min-width:8px}
.text-menu__price{font-family:var(--font-display);font-size:.98rem;letter-spacing:.04em;color:var(--c-text);flex-shrink:0}

/* ================================================================
   INSTAGRAM
================================================================ */
.instagram{padding:var(--spy) 0;background:var(--c-bg)}
.ig-bg-orb{position:absolute;width:600px;height:600px;border-radius:50%;background:radial-gradient(circle,rgba(0,90,150,.09) 0%,transparent 70%);filter:blur(80px);top:10%;right:-10%}
.instagram__inner{display:grid;grid-template-columns:1fr 1fr;gap:clamp(3rem,8vw,8rem);align-items:center;position:relative;z-index:2}
.instagram__title{font-family:var(--font-mincho);font-size:clamp(1.55rem,3.8vw,2.7rem);font-weight:800;line-height:1.3;color:var(--c-text);margin-bottom:1.3rem}
.instagram__body{font-family:var(--font-mincho);font-size:clamp(.87rem,1.55vw,.98rem);line-height:2.1;color:var(--c-text-dim);margin-bottom:2.3rem}
.instagram__cta{display:inline-flex;align-items:center;gap:.85rem;color:var(--c-neon);border:1px solid var(--c-border);text-decoration:none;border-radius:4px;padding:.85rem 1.9rem;font-family:var(--font-display);font-size:.85rem;letter-spacing:.1em;cursor:none;transition:background .3s,border-color .3s,box-shadow .3s,transform .3s var(--ease-expo)}
.instagram__cta:hover{background:rgba(0,212,255,.06);border-color:var(--c-neon);box-shadow:0 0 22px rgba(0,212,255,.18);transform:translateY(-3px)}
.instagram__cta .ig-icon{width:17px;height:17px}
.instagram__grid{display:grid;grid-template-columns:repeat(3,1fr);grid-template-rows:repeat(2,1fr);gap:6px;border-radius:12px;overflow:hidden;border:1px solid var(--c-border2)}
.ig-thumb{aspect-ratio:1;background-size:cover;background-position:center;transition:filter .3s,transform .4s;cursor:none}
.ig-thumb:hover{filter:brightness(1.25);transform:scale(1.03)}
.ig-thumb--tall{grid-column:3;grid-row:1/3;aspect-ratio:auto}
.it1{background:linear-gradient(135deg,#0c0c1c 0%,#141428 100%)}.it2{background:linear-gradient(135deg,#090914 0%,#111122 100%)}.it3{background:linear-gradient(135deg,#0e0e1e 0%,#0b0b1a 100%)}.it4{background:linear-gradient(135deg,#0a0a18 0%,#12121e 100%)}.it5{background:linear-gradient(180deg,#0d0d1c 0%,#080812 100%)}

/* ================================================================
   ACCESS
================================================================ */
.access{padding:var(--spy) 0;background:var(--c-bg2)}
.al{position:absolute;left:0;right:0;height:1px;background:linear-gradient(90deg,transparent,rgba(0,212,255,.07),transparent)}
.al1{top:20%}.al2{top:50%}.al3{top:80%}
.access__inner{display:grid;grid-template-columns:1fr 1fr;gap:clamp(3rem,8vw,8rem);align-items:center;position:relative;z-index:2}
.access__title{font-family:var(--font-display);font-size:clamp(2.8rem,7.5vw,5.5rem);letter-spacing:.05em;line-height:1;color:transparent;-webkit-text-stroke:1px rgba(0,212,255,.28);margin-bottom:2.8rem}
.access__dl{display:flex;flex-direction:column}
.access__row{display:grid;grid-template-columns:5.5rem 1fr;gap:1rem;padding:1.15rem 0;border-bottom:1px solid var(--c-border2)}
.access__row:first-child{padding-top:0}
.access__row dt{font-family:var(--font-display);font-size:.66rem;letter-spacing:.22em;color:var(--c-neon);padding-top:.14rem}
.access__row dd{font-family:var(--font-mincho);font-size:clamp(.86rem,1.65vw,.98rem);line-height:1.75;color:var(--c-text)}
.access__map-wrap{border-radius:16px;overflow:hidden;border:1px solid var(--c-border);aspect-ratio:4/3;box-shadow:0 0 45px rgba(0,212,255,.06)}
.access__map-placeholder{width:100%;height:100%;background:var(--c-surface);display:flex;align-items:center;justify-content:center;flex-direction:column;gap:1.5rem;min-height:280px;position:relative;overflow:hidden}
.access__map-label{font-family:var(--font-display);font-size:.82rem;letter-spacing:.3em;color:var(--c-neon);z-index:2}
.access__crosshair{position:absolute;inset:0;display:flex;align-items:center;justify-content:center}
.ch-h{position:absolute;left:0;right:0;height:1px;background:linear-gradient(90deg,transparent,rgba(0,212,255,.2),transparent)}
.ch-v{position:absolute;top:0;bottom:0;width:1px;background:linear-gradient(180deg,transparent,rgba(0,212,255,.2),transparent)}
.ch-dot{width:8px;height:8px;border-radius:50%;background:var(--c-neon);box-shadow:0 0 14px var(--c-neon-glow),0 0 32px rgba(0,212,255,.3);animation:dotPulse 2.6s ease-in-out infinite}
@keyframes dotPulse{0%,100%{transform:scale(1);opacity:1}50%{transform:scale(1.6);opacity:.6}}

/* ================================================================
   FOOTER
================================================================ */
.footer{background:var(--c-black);border-top:1px solid var(--c-border2);padding:clamp(2.8rem,6vw,5rem) var(--pad-x);padding-bottom:calc(clamp(2.8rem,6vw,5rem) + env(safe-area-inset-bottom,0px))}
.footer__inner{max-width:1200px;margin:0 auto}
.footer__top{display:flex;align-items:center;justify-content:space-between;margin-bottom:1.8rem}
.footer__logo{font-family:var(--font-display);font-size:clamp(1.9rem,4.5vw,2.9rem);letter-spacing:.04em;color:var(--c-text)}
.footer__ig{display:inline-flex;align-items:center;gap:.65rem;color:var(--c-text-dim);text-decoration:none;cursor:none;font-family:var(--font-display);font-size:.72rem;letter-spacing:.18em;transition:color .2s,filter .2s}
.footer__ig:hover{color:var(--c-neon);filter:drop-shadow(0 0 6px var(--c-neon-glow))}
.footer__ig .ig-icon{width:17px;height:17px}
.footer__rule{width:100%;height:1px;background:var(--c-border2);margin-bottom:1.8rem}
.footer__bottom{display:flex;align-items:center;justify-content:space-between;gap:1.5rem;flex-wrap:wrap}
.footer__sub{font-family:var(--font-mincho);font-size:.76rem;color:var(--c-text-dim);letter-spacing:.07em}
.footer__nav{display:flex;gap:1.7rem;flex-wrap:wrap}
.footer__nav a{font-family:var(--font-display);font-size:.7rem;letter-spacing:.18em;color:var(--c-text-dim);text-decoration:none;cursor:none;transition:color .2s}
.footer__nav a:hover{color:var(--c-neon)}
.footer__copy{font-size:.65rem;color:rgba(90,90,120,.4);width:100%;margin-top:.8rem}
.brand {
  font-family: 'Exo 2', sans-serif;
  letter-spacing: 0.08em;
}
.brand .xi {
  color: #00BFFF;
}

/* ================================================================
   REVEAL — generic (for elements not using scroll-card system)
================================================================ */
[data-reveal]{will-change:opacity,transform}
[data-reveal="slide-left"] {opacity:0;transform:perspective(900px) rotateY(12deg) translateX(-55px);transition:opacity .9s var(--ease-expo),transform .9s var(--ease-expo)}
[data-reveal="slide-right"]{opacity:0;transform:perspective(900px) rotateY(-12deg) translateX(55px);transition:opacity .9s var(--ease-expo),transform .9s var(--ease-expo)}
[data-reveal="fade-up"]    {opacity:0;transform:translateY(48px);transition:opacity .8s var(--ease-expo),transform .8s var(--ease-expo)}
[data-reveal="depth"]      {opacity:0;transform:perspective(900px) translateZ(-90px) rotateX(10deg) scale(.92);transition:opacity .75s var(--ease-expo),transform .75s var(--ease-expo)}
[data-reveal].revealed     {opacity:1;transform:none}

/* ================================================================
   RESPONSIVE
================================================================ */
@media(max-width:900px){
  .concept__inner,.instagram__inner,.access__inner{grid-template-columns:1fr;gap:3rem}
  .text-menu{grid-template-columns:1fr;gap:2rem}
  .instagram__grid{grid-template-columns:repeat(3,1fr);grid-template-rows:auto}
  .ig-thumb--tall{grid-column:auto;grid-row:auto}
}
@media(max-width:768px){
  :root{--spy:clamp(4rem,13vw,6rem)}
  body{cursor:auto}
  .cursor,.cursor-ring{display:none}
  /* Hide nav on mobile — right cluster stays via margin-left:auto */
  .site-header__nav{display:none}
  .menu__grid{grid-template-columns:1fr 1fr}
  .footer__bottom{flex-direction:column;align-items:flex-start}
}
@media(max-width:480px){
  .menu__grid{grid-template-columns:1fr}
  .stool{display:none}
  .access__row{grid-template-columns:4.2rem 1fr}
}

/* Accessibility */
:focus-visible{outline:1px solid var(--c-neon);outline-offset:3px;border-radius:3px}
@media(prefers-reduced-motion:reduce){
  *,*::before,*::after{animation-duration:.01ms!important;transition-duration:.3s!important}
  .hero__grain{display:none}
  .marquee-inner{animation:none!important}
}
