/* ===========================================================
   ZEKU FITNESS — Sub Pages stylesheet
   shared chrome: page-hero / breadcrumb / page-nav

   ※ TYPOGRAPHY RULES は styles.css 先頭参照
   日本語の最低 14px 原則をこのファイルでも厳守。
   本文 15/16px、サブ本文 14/15px、キャプション 13/14px、注釈 12px、EN装飾は10〜13px。
=========================================================== */

/* ============ PAGE HERO ============ */
.page-hero{
  position:relative;
  padding:160px 0 80px;
  background:var(--black);
  overflow:hidden;
  isolation:isolate;
}
@media (min-width:900px){.page-hero{padding:200px 0 110px;}}
.page-hero::before{
  content:"";position:absolute;inset:0;z-index:0;
  background-image:
    linear-gradient(rgba(255,255,255,.025) 1px,transparent 1px),
    linear-gradient(90deg, rgba(255,255,255,.025) 1px,transparent 1px);
  background-size:48px 48px;
  mask-image:radial-gradient(ellipse at center, #000 30%, transparent 80%);
}
.page-hero::after{
  content:attr(data-bg);
  position:absolute;right:-20px;top:50%;transform:translateY(-50%);
  font-family:var(--font-en);font-weight:800;font-style:italic;
  font-size:clamp(140px,26vw,360px);
  color:rgba(255,229,0,.05);
  letter-spacing:-.04em;line-height:.85;
  pointer-events:none;white-space:nowrap;z-index:0;
}
.page-hero__inner{position:relative;z-index:2;}
.breadcrumb{
  display:flex;align-items:center;gap:10px;flex-wrap:wrap;
  font-family:var(--font-en);font-size:11px;letter-spacing:.18em;
  color:var(--text-mute);margin-bottom:24px;font-weight:700;
}
.breadcrumb a{color:var(--text-mute);transition:color .3s;}
.breadcrumb a:hover{color:var(--yellow);}
.breadcrumb__sep{color:rgba(255,229,0,.4);}
.breadcrumb__current{color:var(--yellow);}

.page-hero__label{
  display:inline-flex;align-items:center;gap:12px;
  font-family:var(--font-en);font-size:12px;letter-spacing:.3em;font-weight:700;
  color:var(--yellow);margin-bottom:18px;
}

/* Brand lockup (logo + label) — used on BLACKOUT page hero */
.page-hero__brand{
  display:flex;align-items:center;gap:16px;
  margin-bottom:22px;
}
.page-hero__brand .page-hero__label{margin-bottom:0;}
.page-hero__emblem{
  display:block;width:auto;height:64px;
  filter:
    drop-shadow(0 0 12px rgba(255,0,212,.65))
    drop-shadow(0 0 28px rgba(180,0,255,.45));
  animation:emblemBreathe 3.4s ease-in-out infinite;
  pointer-events:none;user-select:none;flex-shrink:0;
  position:relative;z-index:3;
}
@media (min-width:760px){.page-hero__emblem{height:88px;}}
.page-hero__label::before{
  content:"";width:32px;height:1px;background:var(--yellow);
}
.page-hero__title{
  font-family:var(--font-en);font-weight:800;font-style:italic;
  font-size:clamp(56px,12vw,140px);
  line-height:1.15;letter-spacing:-.02em;
  margin-bottom:22px;
  color:#fff;
  text-wrap:balance;
}

/* BLACKOUT page neon title — glitch + flicker (TOP page と同じ世界観) */
.page-hero__title.neon-title{
  line-height:.95;letter-spacing:-.02em;
  text-shadow:
    0 0 20px rgba(255,255,255,.5),
    0 0 40px rgba(255,0,212,.5),
    0 0 80px rgba(0,240,255,.3);
  position:relative;
}
.page-hero__title.neon-title .shake{
  display:inline-block;position:relative;
  animation:neonFlicker 4s linear infinite;
}
.page-hero__title.neon-title .shake::before,
.page-hero__title.neon-title .shake::after{
  content:attr(data-text);
  position:absolute;top:0;left:0;width:100%;
  mix-blend-mode:screen;pointer-events:none;
}
.page-hero__title.neon-title .shake::before{
  color:#FF00D4;
  animation:glitch1 3s steps(1) infinite;
  text-shadow:0 0 20px #FF00D4;
}
.page-hero__title.neon-title .shake::after{
  color:#00F0FF;
  animation:glitch2 3s steps(1) infinite;
  text-shadow:0 0 20px #00F0FF;
}

/* BLACKOUT page-hero — オーブ・レーザー・スキャンライン演出 */
.page-hero.neon{
  overflow:hidden;
  isolation:isolate;
}
.page-hero.neon > .container{position:relative;z-index:10;}

.page-hero.neon .orb{
  position:absolute;border-radius:50%;
  pointer-events:none;z-index:1;
  mix-blend-mode:screen;filter:blur(60px);
}
.page-hero.neon .orb-1{
  width:300px;height:300px;top:-80px;left:-100px;
  background:radial-gradient(circle, #FF00D4 0%, transparent 60%);
  animation:orbPulse 6s ease-in-out infinite, orbFloat1 14s ease-in-out infinite;
}
.page-hero.neon .orb-2{
  width:380px;height:380px;bottom:-140px;right:-120px;
  background:radial-gradient(circle, #00F0FF 0%, transparent 60%);
  animation:orbPulse 8s ease-in-out infinite -2s, orbFloat2 18s ease-in-out infinite;
}
.page-hero.neon .orb-3{
  width:240px;height:240px;top:30%;right:8%;
  background:radial-gradient(circle, #B400FF 0%, transparent 60%);
  animation:orbPulse 7s ease-in-out infinite -3s, orbFloat3 16s ease-in-out infinite;
}
.page-hero.neon .orb-4{
  width:200px;height:200px;bottom:18%;left:12%;
  background:radial-gradient(circle, #FFE500 0%, transparent 60%);
  animation:orbPulse 5s ease-in-out infinite -1s, orbFloat1 12s ease-in-out infinite reverse;
}
@media (min-width:900px){
  .page-hero.neon .orb-1{width:420px;height:420px;}
  .page-hero.neon .orb-2{width:500px;height:500px;}
  .page-hero.neon .orb-3{width:340px;height:340px;}
  .page-hero.neon .orb-4{width:260px;height:260px;}
}

.page-hero.neon .laser{
  position:absolute;left:-20%;width:140%;height:2px;
  pointer-events:none;z-index:2;filter:blur(.5px);
}
.page-hero.neon .laser::before{
  content:"";position:absolute;inset:0;
  background:linear-gradient(90deg, transparent, var(--c) 20%, #fff 50%, var(--c) 80%, transparent);
  box-shadow:0 0 8px var(--c),0 0 16px var(--c),0 0 40px var(--c),0 0 80px var(--c);
}
.page-hero.neon .laser-1{top:22%;--c:#FF00D4;animation:laserSweep 7s ease-in-out infinite;transform:rotate(-6deg);}
.page-hero.neon .laser-2{top:55%;--c:#00F0FF;animation:laserSweep 9s ease-in-out infinite -2s;transform:rotate(4deg);}
.page-hero.neon .laser-3{top:80%;--c:#FFE500;animation:laserSweep 6s ease-in-out infinite -4s;transform:rotate(-3deg);}

/* CRT scanline overlay (TOPの.blackout::afterと同じ) */
.page-hero.neon::after{
  content:"";position:absolute;inset:0;z-index:5;
  background:repeating-linear-gradient(0deg,transparent 0,transparent 3px,rgba(255,255,255,.012) 3px,rgba(255,255,255,.012) 4px);
  pointer-events:none;mix-blend-mode:overlay;
}
.page-hero__title .yellow{color:var(--yellow);}
.page-hero__title .outline{
  -webkit-text-stroke:2px var(--yellow);color:transparent;
}
.page-hero__sub{
  font-size:clamp(16px,2.6vw,22px);font-weight:900;
  margin-bottom:14px;line-height:1.6;text-wrap:balance;
}
.page-hero__desc{
  color:var(--text-soft);font-size:15px;line-height:1.95;
  max-width:560px;
}
@media (min-width:760px){.page-hero__desc{font-size:16px;}}

/* ============ PAGE NAV (sub-pages quick links) ============ */
.page-nav{
  background:var(--black-2);
  border-top:1px solid var(--line);
  border-bottom:1px solid var(--line);
  position:relative;z-index:2;
}
.page-nav__inner{
  display:flex;gap:0;
  overflow-x:auto;
  scrollbar-width:none;
}
.page-nav__inner::-webkit-scrollbar{display:none;}
.page-nav__item{
  flex:1;min-width:140px;
  padding:18px 16px;text-align:center;
  font-family:var(--font-en);font-size:11px;letter-spacing:.2em;font-weight:700;
  color:var(--text-soft);
  border-right:1px solid var(--line);
  transition:all .3s;
  position:relative;
  display:flex;flex-direction:column;align-items:center;gap:4px;
}
.page-nav__item:last-child{border-right:none;}
.page-nav__item .jp{
  font-family:var(--font-jp);font-size:11px;letter-spacing:.05em;
  color:var(--text-mute);font-weight:500;
}
.page-nav__item:hover{color:var(--yellow);background:rgba(255,229,0,.04);}
.page-nav__item:hover .jp{color:var(--yellow);}
.page-nav__item.active{color:var(--yellow);}
.page-nav__item.active::after{
  content:"";position:absolute;bottom:0;left:0;right:0;height:2px;
  background:var(--yellow);
  box-shadow:0 0 10px var(--yellow);
}

/* ============ TRAINER CARDS ============ */
.trainers{background:var(--black);}
.trainer-grid{
  display:grid;grid-template-columns:1fr;gap:24px;margin-top:40px;
}
@media (min-width:760px){.trainer-grid{grid-template-columns:1fr 1fr;gap:28px;}}
.trainer-card{
  background:var(--gray);
  border:1px solid var(--line);
  overflow:hidden;
  transition:transform .5s var(--ease),border-color .3s ease;
  position:relative;
}
.trainer-card:hover{transform:translateY(-8px);border-color:rgba(255,229,0,.4);}
.trainer-card__photo{
  position:relative;aspect-ratio:4/3;overflow:hidden;
  background:#1a1a1a;
}
.trainer-card__photo img{
  width:100%;height:100%;object-fit:cover;
  transition:transform .8s var(--ease);
  filter:saturate(.9) contrast(1.05);
}
.trainer-card:hover .trainer-card__photo img{transform:scale(1.06);}
.trainer-card__badge{
  position:absolute;top:14px;left:14px;z-index:2;
  background:var(--yellow);color:#000;
  padding:6px 12px;font-family:var(--font-en);font-weight:800;
  font-size:11px;letter-spacing:.2em;font-style:italic;
}
.trainer-card__photo::after{
  content:"";position:absolute;inset:0;
  background:linear-gradient(180deg,transparent 60%, rgba(0,0,0,.85));
  z-index:1;
}
.trainer-card__name-overlay{
  position:absolute;bottom:14px;left:18px;right:18px;z-index:2;
}
.trainer-card__en{
  font-family:var(--font-en);font-weight:800;font-style:italic;
  font-size:clamp(28px,5vw,42px);line-height:.95;color:var(--yellow);
  letter-spacing:.02em;margin-bottom:2px;
}
.trainer-card__jp{font-size:14px;color:#fff;font-weight:700;}
.trainer-card__body{padding:22px;}
.trainer-card__role{
  display:inline-flex;align-items:center;gap:8px;
  font-family:var(--font-en);font-size:10px;letter-spacing:.25em;font-weight:700;
  color:var(--yellow);margin-bottom:10px;
}
.trainer-card__role::before{content:"";width:14px;height:1px;background:var(--yellow);}
.trainer-card__title{font-size:17px;font-weight:900;margin-bottom:10px;line-height:1.55;}
.trainer-card__desc{font-size:14px;color:var(--text-soft);line-height:1.95;margin-bottom:16px;}
@media (min-width:760px){.trainer-card__desc{font-size:15px;}}
.trainer-card__skills{display:flex;flex-wrap:wrap;gap:6px;margin-bottom:14px;}
.trainer-card__skill{
  font-family:var(--font-en);font-size:10px;letter-spacing:.1em;font-weight:700;
  padding:4px 10px;background:rgba(255,229,0,.10);color:var(--yellow);
}
.trainer-card__stats{
  display:grid;grid-template-columns:repeat(3,1fr);gap:8px;
  border-top:1px solid var(--line);padding-top:14px;margin-top:14px;
}
.trainer-card__stat-num{
  font-family:var(--font-en);font-weight:800;font-style:italic;
  font-size:24px;color:var(--yellow);line-height:1;
}
.trainer-card__stat-num small{font-size:.45em;font-style:normal;}
.trainer-card__stat-label{font-size:10px;color:var(--text-mute);letter-spacing:.05em;margin-top:2px;}

/* ============ COMPARE TABLE (price page) ============ */
.compare-wrap{margin-top:40px;overflow-x:auto;-webkit-overflow-scrolling:touch;}
.compare-table{
  width:100%;min-width:760px;
  border-collapse:separate;border-spacing:0;
  background:var(--gray);
  border:1px solid var(--line);
}
.compare-table thead th{
  padding:24px 16px;
  background:var(--black);
  text-align:center;
  border-bottom:1px solid var(--line);
  border-right:1px solid var(--line);
  font-weight:900;
  position:sticky;top:0;
}
.compare-table thead th:last-child{border-right:none;}
.compare-table thead th.featured{
  background:linear-gradient(180deg, rgba(255,229,0,.18), rgba(255,229,0,.04));
  border-bottom:2px solid var(--yellow);
}
.compare-table .col-name{
  display:block;font-family:var(--font-en);font-size:18px;letter-spacing:.05em;
  font-weight:800;margin-bottom:4px;
}
.compare-table .col-sub{font-size:11px;color:var(--text-mute);font-weight:500;letter-spacing:.05em;display:block;margin-bottom:10px;}
.compare-table .col-price{
  font-family:var(--font-en);font-weight:800;font-style:italic;
  font-size:34px;color:var(--yellow);line-height:1;
}
.compare-table .col-price small{font-size:.4em;color:var(--text-soft);font-style:normal;font-weight:500;margin-left:4px;}
.compare-table .col-tax{font-size:10px;color:var(--text-mute);margin-top:4px;}
.compare-table thead .featured-tag{
  position:absolute;top:-10px;left:50%;transform:translateX(-50%);
  background:var(--yellow);color:#000;padding:3px 12px;font-size:10px;font-weight:900;letter-spacing:.2em;font-family:var(--font-en);
  white-space:nowrap;
}
.compare-table thead th{position:relative;}
.compare-table tbody th{
  text-align:left;padding:16px 18px;
  background:var(--black-2);
  font-size:13px;font-weight:700;
  border-bottom:1px solid var(--line);
  border-right:1px solid var(--line);
  white-space:nowrap;
}
.compare-table tbody td{
  padding:16px 12px;text-align:center;
  font-size:13px;color:var(--text-soft);
  border-bottom:1px solid var(--line);
  border-right:1px solid var(--line);
}
.compare-table tbody td:last-child{border-right:none;}
.compare-table tbody tr:last-child td,
.compare-table tbody tr:last-child th{border-bottom:none;}
.compare-table .ok{color:var(--yellow);font-size:18px;font-weight:900;}
.compare-table .ng{color:var(--text-mute);font-size:18px;}
.compare-table .featured-col{background:rgba(255,229,0,.04);}
.compare-table tfoot td{padding:18px 12px;text-align:center;border-right:1px solid var(--line);}
.compare-table tfoot td:last-child{border-right:none;}
.compare-table tfoot .table-cta{
  display:inline-block;padding:10px 16px;
  background:transparent;border:1px solid var(--yellow);color:var(--yellow);
  font-size:11px;font-weight:700;letter-spacing:.1em;
  transition:all .3s;
}
.compare-table tfoot .featured-col .table-cta{background:var(--yellow);color:#000;}
.compare-table tfoot .table-cta:hover{background:var(--yellow);color:#000;}

/* ============ FLOOR MAP (facility) ============ */
.floor-map{
  position:relative;background:var(--gray);
  border:1px solid var(--line);
  margin-top:40px;
  overflow:hidden;
}
.floor-map__stage{
  position:relative;width:100%;
  aspect-ratio:16/10;
  background:
    linear-gradient(135deg, #1a1a1a 0%, #0d0d0d 100%);
}
.floor-map__stage::before{
  content:"";position:absolute;inset:0;
  background-image:
    linear-gradient(rgba(255,229,0,.06) 1px,transparent 1px),
    linear-gradient(90deg,rgba(255,229,0,.06) 1px,transparent 1px);
  background-size:40px 40px;
}
.floor-map__svg{
  position:absolute;inset:0;width:100%;height:100%;
  pointer-events:none;
}
.floor-map__svg path,
.floor-map__svg rect{
  fill:rgba(255,255,255,.02);
  stroke:rgba(255,229,0,.25);
  stroke-width:1.5;
  vector-effect:non-scaling-stroke;
}
.floor-pin{
  position:absolute;
  width:36px;height:36px;
  transform:translate(-50%,-50%);
  cursor:pointer;
  z-index:2;
}
.floor-pin__dot{
  position:absolute;inset:0;
  background:var(--yellow);
  border-radius:50%;
  display:flex;align-items:center;justify-content:center;
  font-family:var(--font-en);font-weight:800;font-size:14px;color:#000;font-style:italic;
  box-shadow:0 0 0 3px rgba(0,0,0,.6), 0 6px 18px rgba(255,229,0,.4);
  transition:transform .3s ease;
  z-index:2;
}
.floor-pin::before{
  content:"";position:absolute;inset:-4px;
  border-radius:50%;background:var(--yellow);opacity:.4;
  animation:pinPulse 2.4s ease-out infinite;
  z-index:0;
}
@keyframes pinPulse{
  0%{transform:scale(.6);opacity:.7;}
  100%{transform:scale(1.8);opacity:0;}
}
.floor-pin:hover .floor-pin__dot,
.floor-pin.active .floor-pin__dot{transform:scale(1.2);background:#fff;color:#000;}
.floor-pin.active::before{animation-duration:1.4s;}

.floor-detail{
  display:grid;grid-template-columns:1fr;gap:0;
  border-top:1px solid var(--line);
}
@media (min-width:900px){.floor-detail{grid-template-columns:1.1fr .9fr;min-height:380px;}}
.floor-detail__photo{
  position:relative;aspect-ratio:4/3;background:#0a0a0a;overflow:hidden;
}
@media (min-width:900px){.floor-detail__photo{aspect-ratio:auto;}}
.floor-detail__photo img{
  width:100%;height:100%;object-fit:cover;display:block;
  transition:opacity .4s ease;
}
.floor-detail__body{padding:28px 24px;display:flex;flex-direction:column;justify-content:center;}
@media (min-width:900px){.floor-detail__body{padding:40px;}}
.floor-detail__num{
  font-family:var(--font-en);font-weight:800;font-style:italic;
  font-size:48px;color:var(--yellow);line-height:1;margin-bottom:10px;
}
.floor-detail__num small{font-size:11px;letter-spacing:.3em;font-style:normal;color:var(--text-mute);font-weight:700;display:block;margin-bottom:6px;}
.floor-detail__title{font-size:24px;font-weight:900;margin-bottom:14px;line-height:1.4;}
.floor-detail__desc{font-size:14px;color:var(--text-soft);line-height:1.95;margin-bottom:18px;}
@media (min-width:760px){.floor-detail__desc{font-size:15px;}}
.floor-detail__list{list-style:none;display:flex;flex-direction:column;gap:8px;}
.floor-detail__list li{
  font-size:13px;color:#CFCFCF;padding-left:18px;position:relative;line-height:1.7;
}
@media (min-width:760px){.floor-detail__list li{font-size:14px;}}
.floor-detail__list li::before{content:"";position:absolute;left:0;top:9px;width:10px;height:2px;background:var(--yellow);}

/* ============ MAP THUMBS (mobile fallback / list view) ============ */
.area-list{
  display:grid;grid-template-columns:repeat(2,1fr);gap:8px;margin-top:24px;
}
@media (min-width:760px){.area-list{grid-template-columns:repeat(4,1fr);gap:12px;}}
.area-list__btn{
  padding:12px 10px;background:var(--gray);border:1px solid var(--line);
  font-size:11px;font-weight:700;letter-spacing:.05em;color:var(--text-soft);
  display:flex;flex-direction:column;align-items:center;gap:4px;
  transition:all .3s;
  cursor:pointer;
}
.area-list__btn .num{
  font-family:var(--font-en);font-weight:800;font-style:italic;font-size:18px;color:var(--yellow);
}
.area-list__btn:hover,.area-list__btn.active{
  border-color:var(--yellow);background:rgba(255,229,0,.06);color:var(--yellow);
}

/* ============ STORY (unique page) ============ */
.story{background:var(--black-2);}
.story-block{
  display:grid;grid-template-columns:1fr;gap:32px;margin-bottom:80px;align-items:center;
}
@media (min-width:900px){
  .story-block{grid-template-columns:1.1fr .9fr;gap:60px;margin-bottom:120px;}
  .story-block.reverse{grid-template-columns:.9fr 1.1fr;}
  .story-block.reverse .story-block__visual{order:-1;}
}
.story-block:last-child{margin-bottom:0;}
.story-block__num{
  font-family:var(--font-en);font-weight:800;font-style:italic;
  font-size:80px;line-height:.85;
  color:transparent;-webkit-text-stroke:1.5px var(--yellow);
  margin-bottom:16px;
}
.story-block__label{
  font-family:var(--font-en);font-size:11px;letter-spacing:.3em;font-weight:700;
  color:var(--yellow);margin-bottom:14px;display:block;
}
.story-block__title{
  font-size:clamp(24px,5vw,36px);font-weight:900;line-height:1.4;
  margin-bottom:18px;text-wrap:balance;
}
.story-block__desc{font-size:15px;color:var(--text-soft);line-height:2;margin-bottom:18px;}
@media (min-width:760px){.story-block__desc{font-size:16px;}}
.story-block__visual{
  position:relative;aspect-ratio:4/3;overflow:hidden;background:#0a0a0a;
  border:1px solid var(--line);
}
.story-block__visual img{width:100%;height:100%;object-fit:cover;display:block;
  transition:transform 1s var(--ease);}
.story-block__visual:hover img{transform:scale(1.05);}
.story-block__visual::after{
  content:"";position:absolute;inset:0;
  background:linear-gradient(135deg, rgba(255,229,0,.06), transparent 50%);
  pointer-events:none;
}

/* ============ KPI ROW ============ */
.kpi-row{
  display:grid;grid-template-columns:repeat(2,1fr);gap:1px;
  background:var(--line);
  margin-top:40px;
  border:1px solid var(--line);
}
@media (min-width:760px){.kpi-row{grid-template-columns:repeat(4,1fr);}}
.kpi{
  padding:28px 18px;background:var(--black);text-align:center;
  position:relative;overflow:hidden;
}
.kpi::before{
  content:"";position:absolute;top:0;left:0;width:0;height:2px;background:var(--yellow);
  transition:width .8s var(--ease);
}
.kpi.in::before{width:100%;}
.kpi__num{
  font-family:var(--font-en);font-weight:800;font-style:italic;
  font-size:clamp(36px,7vw,52px);color:var(--yellow);line-height:1;
}
.kpi__num .unit{font-size:.4em;font-style:normal;margin-left:2px;color:var(--text-soft);}
.kpi__label{font-size:11px;color:var(--text-mute);letter-spacing:.15em;margin-top:8px;font-weight:700;}

/* ============ REVIEWS ============ */
.reviews{background:var(--black);}
.review-grid{
  display:grid;grid-template-columns:1fr;gap:14px;margin-top:32px;
}
@media (min-width:760px){.review-grid{grid-template-columns:repeat(2,1fr);gap:16px;}}
@media (min-width:1100px){.review-grid{grid-template-columns:repeat(3,1fr);gap:18px;}}
.review-card{
  background:var(--gray);padding:24px 22px;
  border:1px solid var(--line);
  position:relative;
  transition:all .4s var(--ease);
}
.review-card:hover{transform:translateY(-4px);border-color:rgba(255,229,0,.3);}
.review-card__quote{
  font-family:var(--font-en);font-weight:800;font-style:italic;
  font-size:48px;color:var(--yellow);line-height:.7;
  position:absolute;top:14px;right:18px;opacity:.4;
}
.review-card__stars{color:var(--yellow);font-size:13px;letter-spacing:.1em;margin-bottom:12px;}
.review-card__title{font-size:15px;font-weight:900;line-height:1.5;margin-bottom:10px;}
.review-card__body{font-size:14px;color:var(--text-soft);line-height:1.95;margin-bottom:18px;}
@media (min-width:760px){.review-card__body{font-size:15px;}}
.review-card__person{
  display:flex;align-items:center;gap:12px;
  border-top:1px solid var(--line);padding-top:14px;
}
.review-card__avatar{
  width:38px;height:38px;border-radius:50%;
  background:linear-gradient(135deg,var(--yellow),var(--yellow-deep));
  color:#000;display:flex;align-items:center;justify-content:center;
  font-weight:900;font-family:var(--font-en);font-size:13px;
  flex-shrink:0;
}
.review-card__meta{font-size:11px;color:var(--text-mute);}
.review-card__name{font-size:13px;font-weight:700;color:#fff;}

/* ============ ACCESS / MAP ============ */
.access{background:var(--black-2);}
.access-grid{
  display:grid;grid-template-columns:1fr;gap:24px;margin-top:32px;
}
@media (min-width:900px){.access-grid{grid-template-columns:1.2fr .8fr;gap:32px;}}
.access-map{
  position:relative;aspect-ratio:4/3;
  background:#1a1a1a;
  border:1px solid var(--line);
  overflow:hidden;
}
.access-map iframe{width:100%;height:100%;border:0;filter:invert(.9) hue-rotate(180deg) saturate(.8);}
.access-info{
  display:flex;flex-direction:column;gap:14px;
}
.access-row{
  background:var(--gray);padding:18px 20px;border-left:3px solid var(--yellow);
}
.access-row__label{
  font-family:var(--font-en);font-size:10px;letter-spacing:.25em;font-weight:700;
  color:var(--yellow);margin-bottom:6px;
}
.access-row__value{font-size:14px;color:#fff;font-weight:700;line-height:1.7;}
.access-row__sub{font-size:13px;color:var(--text-soft);margin-top:4px;line-height:1.75;}
@media (min-width:760px){.access-row__value{font-size:15px;}.access-row__sub{font-size:14px;}}

/* ============ NEXT NAV (page footer) ============ */
.next-nav{
  background:var(--black);padding:80px 0;
  border-top:1px solid var(--line);
}
.next-nav__grid{
  display:grid;grid-template-columns:1fr;gap:14px;
}
@media (min-width:760px){.next-nav__grid{grid-template-columns:1fr 1fr;gap:18px;}}
.next-nav__card{
  position:relative;padding:32px 24px;
  background:var(--gray);
  border:1px solid var(--line);
  overflow:hidden;
  transition:all .4s var(--ease);
  display:flex;flex-direction:column;justify-content:space-between;
  gap:18px;min-height:160px;
}
.next-nav__card::before{
  content:"";position:absolute;inset:0;
  background:linear-gradient(135deg, rgba(255,229,0,.10), transparent 60%);
  opacity:0;transition:opacity .4s ease;
}
.next-nav__card:hover{transform:translateY(-4px);border-color:var(--yellow);}
.next-nav__card:hover::before{opacity:1;}
.next-nav__card > *{position:relative;z-index:2;}
.next-nav__lead{
  font-family:var(--font-en);font-size:11px;letter-spacing:.3em;font-weight:700;
  color:var(--yellow);margin-bottom:6px;
}
.next-nav__title{
  font-family:var(--font-en);font-weight:800;font-style:italic;
  font-size:clamp(28px,5vw,40px);line-height:.95;letter-spacing:.02em;
}
.next-nav__title-jp{font-family:var(--font-jp);font-size:13px;color:var(--text-soft);font-style:normal;font-weight:500;margin-top:4px;}
.next-nav__arrow{
  align-self:flex-end;
  width:48px;height:48px;border:1px solid var(--yellow);border-radius:50%;
  display:flex;align-items:center;justify-content:center;color:var(--yellow);
  transition:all .3s;
}
.next-nav__card:hover .next-nav__arrow{background:var(--yellow);color:#000;transform:rotate(-45deg);}

/* ============ MEDIA HELPERS ============ */
.bg-photo{
  position:relative;
}
.bg-photo img{width:100%;height:100%;object-fit:cover;display:block;}
.bg-photo::after{
  content:"";position:absolute;inset:0;
  background:linear-gradient(180deg, rgba(0,0,0,0) 40%, rgba(0,0,0,.85));
}
img.hero-photo{
  width:100%;height:100%;object-fit:cover;display:block;
  filter:saturate(.85) contrast(1.05);
}

/* ============ FILMSTRIP (horizontal photo scroll) ============ */
.filmstrip{
  margin:0 -20px;
  padding:8px 0 24px;
}
@media (min-width:900px){.filmstrip{margin:0 calc(50% - 50vw);padding-left:max(20px, calc(50vw - 640px));}}
.filmstrip__track{
  display:grid;grid-auto-flow:column;
  grid-auto-columns:75%;
  gap:14px;overflow-x:auto;padding:0 20px 8px;
  scroll-snap-type:x mandatory;
  -webkit-overflow-scrolling:touch;
  scrollbar-width:thin;
  scrollbar-color:var(--yellow) rgba(255,255,255,.05);
}
@media (min-width:600px){.filmstrip__track{grid-auto-columns:42%;}}
@media (min-width:900px){.filmstrip__track{grid-auto-columns:30%;}}
.filmstrip__track::-webkit-scrollbar{height:5px;}
.filmstrip__track::-webkit-scrollbar-track{background:rgba(255,255,255,.04);}
.filmstrip__track::-webkit-scrollbar-thumb{background:var(--yellow);}
.filmstrip__item{
  scroll-snap-align:start;
  position:relative;aspect-ratio:4/5;overflow:hidden;
  background:#0a0a0a;border:1px solid var(--line);
}
.filmstrip__item img{width:100%;height:100%;object-fit:cover;display:block;
  transition:transform .8s var(--ease);}
.filmstrip__item:hover img{transform:scale(1.05);}
.filmstrip__item-cap{
  position:absolute;left:14px;bottom:14px;
  font-family:var(--font-en);font-weight:800;font-style:italic;font-size:12px;
  letter-spacing:.15em;color:var(--yellow);
  background:rgba(0,0,0,.6);padding:4px 10px;
}

/* ============ BA HERO (results-first personal page) ============ */
.ba-hero{
  position:relative;background:var(--black-2);
  padding:80px 0;
}
@media (min-width:900px){.ba-hero{padding:120px 0;}}
.ba-hero__head{margin-bottom:40px;}

.ba-flex{
  display:grid;grid-template-columns:1fr;gap:24px;
}
@media (min-width:900px){.ba-flex{grid-template-columns:1fr 1fr;gap:32px;}}

/* photo BA card variant — uses real photo via bg-image */
.ba-photo{
  position:relative;aspect-ratio:3/2;
  background:#0a0a0a;overflow:hidden;
  cursor:ew-resize;user-select:none;margin-bottom:18px;
  border:1px solid var(--line);
}
.ba-photo__before,
.ba-photo__after{
  position:absolute;inset:0;
  background-size:cover;background-position:center;
}
.ba-photo__after{clip-path:inset(0 0 0 50%);}
.ba-photo__handle{
  position:absolute;top:0;bottom:0;left:50%;width:2px;
  background:var(--yellow);z-index:3;box-shadow:0 0 12px var(--yellow);
}
.ba-photo__handle::before{
  content:"";position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);
  width:36px;height:36px;border-radius:50%;background:var(--yellow);
  box-shadow:0 0 20px var(--yellow);
}
.ba-photo__handle::after{
  content:"⇄";position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);
  font-size:14px;color:#000;font-weight:900;z-index:1;
}
.ba-photo__label{
  position:absolute;top:12px;
  font-family:var(--font-en);font-weight:800;font-size:11px;letter-spacing:.2em;
  padding:4px 10px;background:rgba(0,0,0,.7);color:#fff;z-index:2;
}
.ba-photo__label.before{left:12px;}
.ba-photo__label.after{right:12px;background:var(--yellow);color:#000;}

/* ============ FLOATING CTA ============ */
.float-cta{
  position:fixed;right:18px;bottom:18px;z-index:90;
  display:none;
}
@media (min-width:900px){.float-cta{display:flex;flex-direction:column;gap:8px;}}
.float-cta a{
  display:flex;align-items:center;gap:10px;
  padding:14px 18px;background:var(--yellow);color:#000;
  font-weight:800;font-size:13px;letter-spacing:.05em;
  box-shadow:0 8px 24px rgba(255,229,0,.35);
  transition:transform .3s ease;
}
.float-cta a:hover{transform:translateY(-3px);}

/* ============ PILL META ROW ============ */
.pill-row{display:flex;flex-wrap:wrap;gap:6px;margin-bottom:18px;}
.pill{
  font-family:var(--font-en);font-size:10px;letter-spacing:.18em;font-weight:700;
  padding:5px 10px;border:1px solid var(--line-y);color:var(--yellow);
  background:rgba(255,229,0,.04);
}

/* ============ NEON variant overrides for blackout page ============ */
.page-hero.neon{
  background:#000;
}
.page-hero.neon::after{color:rgba(255,0,212,.06);}
.page-hero.neon .page-hero__title{
  text-shadow:
    0 0 20px rgba(255,255,255,.4),
    0 0 40px rgba(255,0,212,.5),
    0 0 80px rgba(0,240,255,.3);
}
.page-hero.neon .page-hero__label{
  color:#FF00D4;text-shadow:0 0 10px #FF00D4;
}
.page-hero.neon .page-hero__label::before{background:#FF00D4;box-shadow:0 0 8px #FF00D4;}

/* ============ PAGE-HERO STATS (PERSONAL) ============ */
.page-hero__stats{display:flex;flex-wrap:wrap;gap:32px;margin-top:36px;}
.phs{display:flex;flex-direction:column;gap:4px;}
.phs__num{
  font-family:var(--font-en);font-weight:800;font-style:italic;
  font-size:clamp(40px,7vw,64px);color:var(--yellow);line-height:.95;
}
.phs__num i{font-style:italic;font-size:.55em;margin-left:2px;color:var(--yellow);opacity:.85;}
.phs__label{font-size:11px;color:var(--text-mute);letter-spacing:.18em;font-weight:700;}

/* ============ BA HERO (large draggable) ============ */
.ba-hero{padding:80px 0;background:var(--black);}
@media (min-width:900px){.ba-hero{padding:120px 0;}}
.ba-stage{
  display:grid;grid-template-columns:1fr;gap:24px;margin-top:40px;
}
@media (min-width:900px){.ba-stage{grid-template-columns:1.4fr 1fr;gap:40px;align-items:start;}}
/* ba-card 配下の .ba-photo は静的写真(スライダー無効) — TOPページと同じ挙動 */
.ba-card .ba-photo{
  aspect-ratio:auto;
  background:#000;
  cursor:default;
  border:1px solid var(--line);
  margin-bottom:18px;
  overflow:hidden;
  line-height:0;
  transition:border-color .4s ease;
}
.ba-card:hover .ba-photo{border-color:rgba(255,229,0,.35);}
.ba-card .ba-photo img{display:block;width:100%;height:auto;}
.ba-card .ba-photo::after{
  content:"";position:absolute;inset:0;pointer-events:none;
  background:
    linear-gradient(180deg, transparent 75%, rgba(0,0,0,.45) 100%),
    linear-gradient(90deg, rgba(0,0,0,.18) 0%, transparent 22%, transparent 78%, rgba(255,229,0,.06) 100%);
}
.ba-card .ba-photo__label{
  font-style:italic;
  letter-spacing:.22em;
  padding:5px 11px;z-index:3;
}
.ba-card .ba-photo__label.before{border-left:2px solid #888;}
.ba-card .ba-photo__label.after{box-shadow:0 0 18px rgba(255,229,0,.4);}
.ba-card .ba-photo__arrow{
  position:absolute;bottom:14px;left:50%;transform:translateX(-50%);
  z-index:3;
  font-family:var(--font-en);font-weight:800;font-style:italic;
  font-size:14px;letter-spacing:.15em;
  color:var(--yellow);
  text-shadow:0 0 10px rgba(255,229,0,.7);
  background:rgba(0,0,0,.6);
  padding:5px 14px;
  border:1px solid rgba(255,229,0,.5);
}

.ba-photo{
  position:relative;aspect-ratio:4/3;
  background:#0a0a0a;overflow:hidden;
  cursor:ew-resize;user-select:none;
  border:1px solid var(--line);
}
.ba-photo__before, .ba-photo__after{
  position:absolute;inset:0;
}
.ba-photo__before img, .ba-photo__after img{
  width:100%;height:100%;object-fit:cover;display:block;
  pointer-events:none;
}
.ba-photo__after{clip-path:inset(0 0 0 50%);}
.ba-photo__handle{
  position:absolute;top:0;bottom:0;left:50%;width:2px;
  background:var(--yellow);
  box-shadow:0 0 16px var(--yellow);z-index:3;
  pointer-events:none;
}
.ba-photo__handle::before{
  content:"";position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);
  width:48px;height:48px;border-radius:50%;
  background:var(--yellow);box-shadow:0 0 24px var(--yellow);
}
.ba-photo__handle::after{
  content:"⇆";position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);
  font-family:var(--font-en);font-weight:800;font-size:18px;color:#000;z-index:1;
}
.ba-photo__label{
  position:absolute;top:16px;
  font-family:var(--font-en);font-weight:800;font-style:italic;
  font-size:14px;letter-spacing:.2em;
  padding:6px 12px;background:rgba(0,0,0,.7);color:#fff;
  z-index:2;transition:opacity .2s;
}
.ba-photo__label.before{left:16px;}
.ba-photo__label.after{right:16px;background:var(--yellow);color:#000;}
.ba-photo__hint{
  position:absolute;bottom:16px;left:50%;transform:translateX(-50%);
  font-family:var(--font-en);font-size:11px;letter-spacing:.25em;font-weight:700;
  color:#fff;background:rgba(0,0,0,.7);padding:6px 14px;z-index:2;
  animation:fadeOut 4s ease 3s forwards;
}
@keyframes fadeOut{to{opacity:0;}}

.ba-stage__side{display:flex;flex-direction:column;gap:18px;}
.ba-meta{
  background:var(--gray);padding:24px;
  border-left:3px solid var(--yellow);
}
.ba-meta__chip{
  font-family:var(--font-en);font-size:11px;letter-spacing:.25em;font-weight:700;
  color:var(--yellow);margin-bottom:10px;
}
.ba-meta__name{font-size:22px;font-weight:900;margin-bottom:4px;}
.ba-meta__name span{font-size:12px;color:var(--text-mute);font-weight:500;margin-left:8px;}
.ba-meta__period{font-size:12px;color:var(--text-soft);margin-bottom:14px;letter-spacing:.05em;}
.ba-meta__quote{
  font-size:15px;line-height:1.85;color:#E8E8E8;
  padding-top:14px;border-top:1px solid var(--line);
  font-style:italic;
}
.ba-results-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:8px;}
.ba-r{
  background:var(--gray);padding:14px 16px;
  display:flex;flex-direction:column;gap:2px;
}
.ba-r__label{font-size:10px;color:var(--text-mute);letter-spacing:.15em;font-weight:700;}
.ba-r__delta{
  font-family:var(--font-en);font-weight:800;font-style:italic;
  font-size:30px;color:var(--yellow);line-height:1;margin-top:4px;
}
.ba-r__delta i{font-size:.5em;font-style:italic;margin-left:1px;}
.ba-r__from{font-size:10px;color:var(--text-soft);font-family:var(--font-mono,monospace);margin-top:4px;}

.ba-trainer{
  display:flex;align-items:center;gap:14px;
  background:rgba(255,229,0,.05);padding:14px 16px;
  border:1px dashed rgba(255,229,0,.3);
}
.ba-trainer img{width:48px;height:48px;border-radius:50%;object-fit:cover;}
.ba-trainer__role{font-size:10px;letter-spacing:.18em;color:var(--text-mute);font-weight:700;}
.ba-trainer__name{font-family:var(--font-en);font-weight:800;font-size:18px;color:var(--yellow);font-style:italic;}

/* ============ BA GALLERY ============ */
.ba-gallery{padding:80px 0;background:var(--black-2);}
@media (min-width:900px){.ba-gallery{padding:120px 0;}}
.ba-cases{
  display:grid;grid-template-columns:1fr;gap:18px;margin-top:40px;
}
@media (min-width:600px){.ba-cases{grid-template-columns:1fr 1fr;}}
@media (min-width:1000px){.ba-cases{grid-template-columns:repeat(3,1fr);}}
.ba-case{
  background:var(--gray);border:1px solid var(--line);overflow:hidden;
  transition:transform .4s var(--ease),border-color .3s;
}
.ba-case:hover{transform:translateY(-4px);border-color:rgba(255,229,0,.4);}
.ba-case__img{position:relative;aspect-ratio:4/3;overflow:hidden;}
.ba-case__img img{width:100%;height:100%;object-fit:cover;filter:saturate(.85) contrast(1.05);transition:transform .6s var(--ease);}
.ba-case:hover .ba-case__img img{transform:scale(1.05);}
.ba-case__tag{
  position:absolute;top:12px;left:12px;
  background:var(--yellow);color:#000;
  padding:4px 10px;font-family:var(--font-en);font-weight:800;font-size:10px;
  letter-spacing:.18em;
}
.ba-case__body{padding:18px 20px 22px;}
.ba-case__meta{font-size:11px;color:var(--text-mute);letter-spacing:.1em;margin-bottom:6px;font-weight:700;}
.ba-case__name{font-size:16px;font-weight:900;margin-bottom:12px;}
.ba-case__delta{display:flex;gap:18px;margin-bottom:12px;flex-wrap:wrap;}
.ba-case__delta span{
  font-size:11px;color:var(--text-soft);letter-spacing:.05em;
  display:inline-flex;align-items:baseline;gap:3px;
}
.ba-case__delta b{
  font-family:var(--font-en);font-weight:800;font-style:italic;
  font-size:22px;color:var(--yellow);line-height:1;
}
.ba-case__quote{
  font-size:13px;color:#CFCFCF;line-height:1.75;font-style:italic;
  padding-top:12px;border-top:1px solid var(--line);
}

/* ============ TRAINER DETAIL (large) ============ */
.trainers{padding:90px 0;background:var(--black);}
@media (min-width:900px){.trainers{padding:130px 0;}}
.trainer-detail{
  display:grid;grid-template-columns:1fr;gap:32px;
  margin-top:50px;padding-top:50px;
  border-top:1px solid var(--line);
}
.trainer-detail:first-of-type{border-top:none;padding-top:0;margin-top:50px;}
@media (min-width:900px){.trainer-detail{grid-template-columns:1fr 1.2fr;gap:60px;align-items:start;}}
.trainer-detail.reverse .trainer-detail__media{order:2;}
@media (max-width:899px){.trainer-detail.reverse .trainer-detail__media{order:0;}}
.trainer-detail__media{
  position:relative;aspect-ratio:3/4;overflow:hidden;
  background:#1a1a1a;border:1px solid var(--line);
}
.trainer-detail__media img{
  width:100%;height:100%;object-fit:cover;
  filter:saturate(.9) contrast(1.05);
}
.trainer-detail__badge{
  position:absolute;top:18px;left:18px;
  background:var(--yellow);color:#000;
  padding:8px 14px;font-family:var(--font-en);font-weight:800;
  font-size:11px;letter-spacing:.22em;font-style:italic;
}
.trainer-detail__chip{
  display:inline-flex;align-items:center;gap:10px;
  font-family:var(--font-en);font-size:11px;letter-spacing:.25em;font-weight:700;
  color:var(--yellow);margin-bottom:14px;
}
.trainer-detail__chip::before{content:"";width:24px;height:1px;background:var(--yellow);}
.trainer-detail__name{
  font-size:clamp(26px,4vw,38px);font-weight:900;line-height:1.3;margin-bottom:16px;
}
.trainer-detail__name .en{
  display:block;font-family:var(--font-en);font-style:italic;
  font-weight:600;font-size:14px;letter-spacing:.15em;
  color:var(--text-mute);margin-top:4px;
}
.trainer-detail__motto{
  font-size:18px;font-weight:700;color:var(--yellow);
  padding:16px 18px;background:rgba(255,229,0,.06);
  border-left:3px solid var(--yellow);margin-bottom:24px;
}
.trainer-detail__stats{
  display:grid;grid-template-columns:repeat(3,1fr);gap:1px;
  background:var(--line);margin-bottom:24px;
}
.trainer-detail__stats > div{
  background:var(--gray);padding:16px;display:flex;flex-direction:column;gap:4px;
}
.trainer-detail__stats b{
  font-family:var(--font-en);font-weight:800;font-style:italic;
  font-size:28px;color:var(--yellow);line-height:1;
}
.trainer-detail__stats b i{font-size:.5em;font-style:italic;margin-left:2px;}
.trainer-detail__stats span{font-size:10px;color:var(--text-mute);letter-spacing:.1em;font-weight:700;}
.trainer-detail__bio p{font-size:15px;color:var(--text-soft);line-height:2;margin-bottom:18px;}
@media (min-width:760px){.trainer-detail__bio p{font-size:16px;}}
.trainer-detail__tags{display:flex;flex-wrap:wrap;gap:6px;}
.trainer-detail__tags span{
  font-size:11px;font-weight:700;
  padding:5px 10px;background:rgba(255,229,0,.08);color:var(--yellow);
  letter-spacing:.05em;
}

/* ============ PROCESS TIMELINE ============ */
.process{padding:90px 0;background:var(--black-2);}
@media (min-width:900px){.process{padding:130px 0;}}
.process-timeline{
  display:grid;grid-template-columns:1fr;gap:14px;margin-top:40px;
  position:relative;
}
@media (min-width:760px){.process-timeline{grid-template-columns:repeat(4,1fr);gap:1px;background:var(--line);}}
.process-step{
  background:var(--gray);padding:24px 22px;position:relative;
  transition:background .3s,transform .4s var(--ease);
}
.process-step:hover{background:#1a1a1a;}
.process-step__time{
  font-family:var(--font-en);font-weight:800;font-style:italic;
  font-size:30px;color:var(--yellow);line-height:1;margin-bottom:14px;
  display:flex;align-items:baseline;gap:6px;
}
.process-step__time span{font-size:11px;color:var(--text-mute);letter-spacing:.15em;font-weight:700;font-style:normal;}
.process-step__title{
  font-family:var(--font-en);font-weight:800;font-size:14px;letter-spacing:.18em;
  margin-bottom:10px;color:#fff;
}
.process-step p{font-size:14px;color:var(--text-soft);line-height:1.9;}
@media (min-width:760px){.process-step p{font-size:15px;}}

/* ============ TRIAL CTA ============ */
.trial-cta{padding:80px 0;background:var(--black);}
.trial-cta__inner{
  max-width:760px;margin:0 auto;text-align:center;
  padding:48px 28px;
  background:linear-gradient(135deg, rgba(255,229,0,.08), rgba(255,229,0,.02));
  border:1px dashed rgba(255,229,0,.4);
  position:relative;
}
/* ============ STRENGTHS (Personal page 3 USP) ============ */
.strengths{padding:80px 0;background:var(--black-2);}
@media (min-width:900px){.strengths{padding:120px 0;}}
.strengths-grid{
  display:grid;grid-template-columns:1fr;gap:18px;margin-top:40px;
}
@media (min-width:760px){.strengths-grid{grid-template-columns:repeat(3,1fr);gap:20px;}}
.strength-item{
  background:var(--gray);
  padding:32px 26px 28px;
  border-top:3px solid var(--yellow);
  position:relative;
  transition:transform .4s var(--ease), background .3s ease;
}
.strength-item:hover{transform:translateY(-6px);background:var(--gray-2);}
.strength-item__num{
  font-family:var(--font-en);font-weight:800;font-style:italic;
  font-size:clamp(40px,6vw,56px);color:var(--yellow);line-height:.9;letter-spacing:-.02em;
  -webkit-text-stroke:1px var(--yellow);
  margin-bottom:14px;
}
.strength-item h3{
  font-size:18px;font-weight:900;line-height:1.5;margin-bottom:14px;
}
.strength-item p{
  font-size:14px;color:var(--text-soft);line-height:1.95;
}
@media (min-width:760px){
  .strength-item h3{font-size:20px;}
  .strength-item p{font-size:15px;}
}

/* ============ PERSONAL PRICE TABLE ============ */
.personal-price{padding:80px 0;background:var(--black);}
@media (min-width:900px){.personal-price{padding:120px 0;}}
.ppt-table{
  margin-top:40px;
  border:1px solid var(--line);
  overflow-x:auto;
  background:var(--gray);
}
.ppt-table table{
  width:100%;min-width:680px;border-collapse:collapse;
}
.ppt-table th, .ppt-table td{
  padding:16px 18px;text-align:left;font-size:14px;
  border-bottom:1px solid var(--line);
}
@media (min-width:760px){.ppt-table th, .ppt-table td{font-size:15px;padding:18px 22px;}}
.ppt-table thead th{
  background:#181818;color:#fff;font-weight:900;font-size:12px;
  letter-spacing:.1em;
}
.ppt-table tbody tr:last-child td{border-bottom:none;}
.ppt-table tbody td:nth-child(2) .ppt-price,
.ppt-table tbody td:nth-child(3){
  font-family:var(--font-en);font-weight:800;font-style:italic;color:var(--yellow);font-size:18px;letter-spacing:.02em;
}
@media (min-width:760px){
  .ppt-table tbody td:nth-child(2) .ppt-price,
  .ppt-table tbody td:nth-child(3){font-size:22px;}
}
.ppt-table tr.popular{
  background:linear-gradient(180deg, rgba(255,229,0,.08), transparent);
  position:relative;
}
.ppt-table tr.popular td:first-child{border-left:3px solid var(--yellow);}
.popular-tag{
  display:inline-block;
  margin-left:8px;background:var(--yellow);color:#000;
  padding:2px 10px;font-family:var(--font-en);font-weight:900;font-size:10px;
  letter-spacing:.15em;font-style:italic;vertical-align:middle;
}

.ppt-payment{
  margin-top:32px;padding:32px 28px;
  background:linear-gradient(135deg, rgba(255,229,0,.08), transparent 70%);
  border:1px solid rgba(255,229,0,.18);
  position:relative;
}
.ppt-payment__head{display:flex;align-items:center;gap:16px;margin-bottom:14px;flex-wrap:wrap;}
.ppt-payment__chip{
  font-family:var(--font-en);font-weight:800;font-size:11px;letter-spacing:.25em;
  color:var(--yellow);
  border:1px solid var(--yellow);
  padding:4px 10px;
}
.ppt-payment h3{
  font-size:18px;font-weight:900;line-height:1.4;
}
@media (min-width:760px){.ppt-payment h3{font-size:20px;}}
.ppt-payment p{
  font-size:14px;line-height:1.95;color:var(--text-soft);
  margin-bottom:18px;
}
@media (min-width:760px){.ppt-payment p{font-size:15px;}}
.ppt-payment p strong{color:#fff;}
.ppt-payment p .yellow{color:var(--yellow);font-family:var(--font-en);font-style:italic;font-size:1.05em;}
.ppt-payment__cards{
  display:flex;flex-wrap:wrap;gap:8px;
}
.ppt-payment__cards span{
  font-family:var(--font-en);font-weight:700;font-size:11px;
  letter-spacing:.1em;
  padding:6px 12px;
  background:rgba(255,255,255,.06);
  border:1px solid var(--line);
  color:var(--text-soft);
}

.trial-cta__lead{font-family:var(--font-en);font-size:11px;letter-spacing:.3em;color:var(--yellow);font-weight:700;margin-bottom:14px;}
.trial-cta__title{
  font-size:clamp(32px,6vw,52px);font-weight:900;margin-bottom:14px;line-height:1.2;
}
.trial-cta__title .yellow{
  font-family:var(--font-en);font-style:italic;font-size:1.4em;color:var(--yellow);
  margin-left:8px;
}
.trial-cta__desc{font-size:15px;color:var(--text-soft);line-height:1.85;margin-bottom:28px;}
@media (min-width:760px){.trial-cta__desc{font-size:16px;}}
.trial-cta__actions{display:flex;flex-wrap:wrap;gap:12px;justify-content:center;}

/* ============ VOICES ============ */
.voices{padding:90px 0;background:var(--black-2);}
.voices-grid{
  display:grid;grid-template-columns:1fr;gap:18px;margin-top:40px;
}
@media (min-width:760px){.voices-grid{grid-template-columns:1fr 1fr;}}
.voice{
  background:var(--gray);padding:28px 26px;
  border:1px solid var(--line);
  transition:border-color .3s,transform .4s var(--ease);
}
.voice:hover{border-color:rgba(255,229,0,.4);transform:translateY(-3px);}
.voice__rating{color:var(--yellow);letter-spacing:.15em;margin-bottom:14px;font-size:14px;}
.voice blockquote{
  font-size:15px;line-height:1.95;color:#E8E8E8;
  padding-left:18px;border-left:2px solid var(--yellow);
  margin-bottom:16px;
}
@media (min-width:760px){.voice blockquote{font-size:16px;}}
.voice figcaption{
  font-size:14px;font-weight:900;
  display:flex;align-items:baseline;gap:10px;
}
.voice figcaption span{font-size:11px;color:var(--text-mute);font-weight:500;letter-spacing:.05em;}

/* ============ SECTION COMMON ============ */
.section-lead{
  max-width:680px;margin:0 0 36px;
  font-size:15px;color:var(--text-soft);line-height:2;
}


/* ============ PLAN CATEGORY TABS ============ */
.plan-tabs-wrap{padding:50px 0 20px;background:var(--black);}
.plan-cats{
  display:grid;grid-template-columns:1fr;gap:8px;
  border:1px solid var(--line);
}
@media (min-width:760px){.plan-cats{grid-template-columns:repeat(3,1fr);gap:0;}}
.plan-cat{
  background:var(--gray);border:none;cursor:pointer;
  padding:24px 22px;text-align:left;
  display:flex;flex-direction:column;gap:8px;color:#fff;
  border-right:1px solid var(--line);
  transition:background .3s,color .3s;
  position:relative;
  font-family:inherit;
}
.plan-cat:last-child{border-right:none;}
.plan-cat:hover{background:#1a1a1a;}
.plan-cat.active{background:var(--yellow);color:#000;}
.plan-cat__num{
  font-family:var(--font-en);font-weight:800;font-style:italic;
  font-size:13px;letter-spacing:.2em;opacity:.7;
}
.plan-cat__title{font-size:20px;font-weight:900;letter-spacing:.02em;}
.plan-cat__from{font-size:11px;letter-spacing:.1em;opacity:.7;font-weight:700;}
.plan-cat.active::after{
  content:"";position:absolute;left:50%;bottom:-1px;
  width:0;height:0;border-left:10px solid transparent;border-right:10px solid transparent;
  border-top:10px solid var(--yellow);
  transform:translateX(-50%) translateY(100%);
}

/* ============ PLAN SECTIONS (toggleable) ============ */
.plans-section{display:none;padding:80px 0;background:var(--black);}
.plans-section.active{display:block;}
@media (min-width:900px){.plans-section{padding:110px 0;}}

.plan-grid--3{display:grid;grid-template-columns:1fr;gap:18px;margin-top:40px;}
@media (min-width:760px){.plan-grid--3{grid-template-columns:repeat(3,1fr);}}
.plan-grid--4{display:grid;grid-template-columns:1fr;gap:14px;margin-top:40px;}
@media (min-width:600px){.plan-grid--4{grid-template-columns:repeat(2,1fr);}}
@media (min-width:1000px){.plan-grid--4{grid-template-columns:repeat(4,1fr);}}

.plan__head{margin-bottom:18px;}
.plan__cat{
  font-family:var(--font-en);font-size:11px;letter-spacing:.25em;font-weight:800;font-style:italic;
  color:var(--yellow);margin-bottom:8px;
}
.plan__hint{font-size:13px;color:var(--text-soft);margin:6px 0 16px;line-height:1.7;}
@media (min-width:760px){.plan__hint{font-size:14px;}}

/* compact plans (studio) */
.plan.compact{padding:24px 20px;}
.plan.compact .plan__price .num{font-size:42px;}

/* ============ COMPARE MATRIX ============ */
.compare-wrap{margin-top:60px;}
.compare-title{
  font-family:var(--font-en);font-weight:800;font-style:italic;
  font-size:24px;color:#fff;margin-bottom:16px;letter-spacing:.04em;
}
.compare-scroll{overflow-x:auto;border:1px solid var(--line);}
.compare{
  width:100%;min-width:680px;border-collapse:collapse;background:var(--gray);
}
.compare th,.compare td{
  padding:14px 16px;text-align:center;
  font-size:14px;border-bottom:1px solid var(--line);border-right:1px solid var(--line);
}
.compare th:last-child,.compare td:last-child{border-right:none;}
.compare thead th{
  background:#181818;color:#fff;font-weight:900;font-size:14px;
  letter-spacing:.05em;padding:18px 16px;
}
.compare thead th span{
  display:block;font-family:var(--font-en);font-weight:800;font-style:italic;
  font-size:18px;color:var(--yellow);margin-top:4px;
}
.compare thead th.featured{background:var(--yellow);color:#000;}
.compare thead th.featured span{color:#000;}
.compare tbody td:first-child{
  text-align:left;font-weight:700;color:#fff;
  background:#141414;
}
.compare tbody td.featured{background:rgba(255,229,0,.04);}
.compare tbody td i[data-icon]{
  display:inline-flex;width:18px;height:18px;color:var(--yellow);
}
.compare tbody td{color:var(--text-soft);}

/* ============ COST SUMMARY ============ */
.cost-summary{
  margin-top:50px;max-width:560px;
  background:var(--gray);padding:28px 26px;
  border-left:3px solid var(--yellow);
}
.cost-summary__title{
  font-size:16px;font-weight:900;margin-bottom:18px;
}
.cost-summary__title span{font-size:11px;color:var(--text-mute);font-weight:500;letter-spacing:.05em;margin-left:6px;}
.cost-rows{display:flex;flex-direction:column;}
.cost-row{
  display:flex;justify-content:space-between;align-items:baseline;
  padding:11px 0;border-bottom:1px dashed rgba(255,255,255,.08);
  font-size:14px;color:var(--text-soft);
}
.cost-row b{
  font-family:var(--font-en);font-weight:800;font-style:italic;
  font-size:18px;color:#fff;
}
.cost-row.total{border-bottom:none;border-top:2px solid var(--yellow);margin-top:6px;padding-top:14px;}
.cost-row.total b{color:var(--yellow);font-size:28px;}
.cost-summary__note{font-size:12px;color:var(--text-mute);margin-top:12px;line-height:1.7;}
.cost-options-title{
  font-size:14px;font-weight:900;margin-top:22px;margin-bottom:14px;
  color:var(--yellow);letter-spacing:.05em;
}

/* ============ COST CALCULATOR (interactive simulator) ============ */
.cost-calc{
  margin-top:60px;
  background:linear-gradient(180deg, rgba(255,229,0,.05), transparent 60%);
  border:1px solid rgba(255,229,0,.2);
  padding:32px 24px;
}
@media (min-width:760px){.cost-calc{padding:40px 36px;}}

.cost-calc__head{margin-bottom:28px;text-align:center;}
.cost-calc__chip{
  display:inline-block;
  font-family:var(--font-en);font-weight:800;font-style:italic;font-size:11px;
  letter-spacing:.3em;color:var(--yellow);
  border:1px solid var(--yellow);padding:4px 14px;margin-bottom:14px;
}
.cost-calc__title{
  font-size:clamp(22px,4vw,32px);font-weight:900;line-height:1.4;margin-bottom:8px;
}
.cost-calc__lead{
  font-size:14px;color:var(--text-soft);line-height:1.85;
}
@media (min-width:760px){.cost-calc__lead{font-size:15px;}}

.cost-calc__grid{
  display:grid;grid-template-columns:1fr;gap:28px;
}
@media (min-width:900px){.cost-calc__grid{grid-template-columns:1fr 1fr;gap:36px;}}

.cost-calc__controls{display:flex;flex-direction:column;gap:24px;}
.calc-field{
  border:1px solid var(--line);
  background:var(--gray);
  padding:20px 20px 18px;
}
.calc-field__title{
  font-size:13px;font-weight:900;color:var(--yellow);letter-spacing:.06em;
  margin-bottom:6px;
  padding-bottom:10px;
  border-bottom:1px solid rgba(255,229,0,.2);
}
@media (min-width:760px){.calc-field__title{font-size:14px;}}
.calc-radios, .calc-checks{
  display:grid;grid-template-columns:1fr;gap:8px;
  margin-top:10px;
}
@media (min-width:520px){.calc-radios{grid-template-columns:1fr 1fr;}}
.calc-radios label, .calc-checks label{
  display:flex;align-items:flex-start;gap:10px;
  padding:10px 12px;
  background:var(--black);border:1px solid var(--line);
  cursor:pointer;
  transition:all .25s ease;
}
.calc-radios label:hover, .calc-checks label:hover{
  border-color:rgba(255,229,0,.5);
}
.calc-radios input, .calc-checks input{
  margin-top:3px;
  accent-color:var(--yellow);
  flex-shrink:0;
}
.calc-radios label:has(input:checked),
.calc-checks label:has(input:checked){
  border-color:var(--yellow);
  background:rgba(255,229,0,.05);
  box-shadow:0 0 12px rgba(255,229,0,.2);
}
.calc-radios span, .calc-checks span{
  display:flex;flex-direction:column;gap:2px;
  flex:1;
}
.calc-radios span b, .calc-checks span b{
  font-size:13px;font-weight:900;color:#fff;
}
@media (min-width:760px){.calc-radios span b, .calc-checks span b{font-size:14px;}}
.calc-radios span small, .calc-checks span small{
  font-size:11px;color:var(--text-soft);font-weight:500;
}

/* Date trigger button — looks like a card, opens native picker on click */
.calc-date-trigger{
  width:100%;
  background:var(--black);border:1px solid var(--line);
  color:#fff;font-family:inherit;
  padding:14px 16px;margin-top:10px;
  display:flex;align-items:center;gap:12px;
  cursor:pointer;
  transition:all .25s ease;
  text-align:left;
}
.calc-date-trigger:hover{
  border-color:var(--yellow);
  background:rgba(255,229,0,.05);
  box-shadow:0 0 16px rgba(255,229,0,.15);
}
.calc-date-trigger:focus-visible{outline:none;border-color:var(--yellow);box-shadow:0 0 0 3px rgba(255,229,0,.3);}
.calc-date-icon{
  width:22px;height:22px;color:var(--yellow);flex-shrink:0;
  filter:drop-shadow(0 0 6px rgba(255,229,0,.4));
}
.calc-date-icon svg{width:100%;height:100%;display:block;}
.calc-date-display{
  flex:1;
  font-size:15px;font-weight:700;color:#fff;letter-spacing:.05em;
}
@media (min-width:760px){.calc-date-display{font-size:16px;}}
.calc-date-arrow{
  font-size:10px;color:var(--yellow);flex-shrink:0;
  transition:transform .3s ease;
}
.calc-date-trigger:hover .calc-date-arrow{transform:translateY(2px);}

/* Hidden native date input (used for showPicker only) */
.calc-date-native{
  position:absolute;
  width:1px;height:1px;
  opacity:0;pointer-events:none;
  margin:0;padding:0;border:0;
  /* Keep in DOM for showPicker() but invisible */
}
.calc-hint{
  font-size:11px;color:var(--text-mute);margin-top:8px;line-height:1.6;
}

.cost-calc__result{
  display:flex;flex-direction:column;gap:18px;
}
.cost-calc__result-block{
  background:var(--gray);
  border:1px solid var(--line);
  padding:20px 22px;
}
.cost-calc__result-block h4{
  font-size:13px;font-weight:900;color:var(--yellow);letter-spacing:.08em;
  margin-bottom:14px;padding-bottom:10px;border-bottom:1px solid var(--line);
}
.cost-calc__result-block .calc-rows{display:flex;flex-direction:column;gap:6px;}
.cost-calc__result-block .calc-row{
  display:flex;justify-content:space-between;align-items:baseline;
  font-size:13px;color:var(--text-soft);
  padding:4px 0;
}
/* hidden属性の display:none を CSS の display:flex で打ち消されないよう明示 */
.cost-calc__result-block .calc-row[hidden]{display:none;}
@media (min-width:760px){.cost-calc__result-block .calc-row{font-size:14px;}}
.cost-calc__result-block .calc-row b{
  font-size:15px;color:#fff;font-weight:700;
}
@media (min-width:760px){.cost-calc__result-block .calc-row b{font-size:16px;}}
.cost-calc__result-block .calc-total{
  display:flex;justify-content:space-between;align-items:baseline;
  margin-top:12px;padding-top:14px;
  border-top:2px solid var(--yellow);
}
.cost-calc__result-block .calc-total span{
  font-size:13px;color:#fff;font-weight:900;letter-spacing:.05em;
}
@media (min-width:760px){.cost-calc__result-block .calc-total span{font-size:14px;}}
.cost-calc__result-block .calc-total b{
  font-family:var(--font-en);font-weight:800;font-style:italic;
  font-size:32px;color:var(--yellow);
  text-shadow:0 0 12px rgba(255,229,0,.4);
}
@media (min-width:760px){.cost-calc__result-block .calc-total b{font-size:36px;}}

.cost-calc__cta{
  display:block;text-align:center;
  background:var(--yellow);color:#000;
  padding:16px;font-weight:900;font-size:14px;letter-spacing:.05em;
  transition:all .3s;
}
.cost-calc__cta:hover{background:#fff;transform:translateY(-2px);box-shadow:0 8px 24px rgba(255,229,0,.3);}
.cost-calc__note{font-size:11px;color:var(--text-mute);line-height:1.7;}

/* ============ ANNUAL INFO (年会費プラン案内) ============ */
.annual-info{
  margin-top:48px;padding:32px 28px;
  background:linear-gradient(135deg, rgba(255,229,0,.08), transparent 70%);
  border:1px solid rgba(255,229,0,.18);
  position:relative;
}
.annual-info__head{display:flex;align-items:center;gap:16px;margin-bottom:14px;flex-wrap:wrap;}
.annual-info__chip{
  font-family:var(--font-en);font-weight:800;font-size:11px;letter-spacing:.25em;
  color:var(--yellow);
  border:1px solid var(--yellow);
  padding:4px 12px;
  font-style:italic;
}
.annual-info__head h3{
  font-size:18px;font-weight:900;line-height:1.4;
}
@media (min-width:760px){.annual-info__head h3{font-size:22px;}}
.annual-info > p{
  font-size:14px;line-height:1.85;color:var(--text-soft);
  margin-bottom:20px;
}
@media (min-width:760px){.annual-info > p{font-size:15px;}}
.annual-info__rows{
  display:grid;grid-template-columns:1fr;gap:8px;
  margin-bottom:18px;
}
@media (min-width:760px){.annual-info__rows{grid-template-columns:1fr 1fr;gap:10px 18px;}}
.annual-info__row{
  display:grid;grid-template-columns:1fr auto auto;gap:10px;align-items:baseline;
  padding:10px 14px;
  background:rgba(0,0,0,.4);
  border-left:2px solid var(--yellow);
  font-size:13px;
}
@media (min-width:760px){.annual-info__row{font-size:14px;}}
.annual-info__row span{color:#fff;font-weight:700;}
.annual-info__row b{
  font-family:var(--font-en);font-weight:800;font-style:italic;
  font-size:18px;color:var(--yellow);
}
.annual-info__row b small{font-size:.55em;color:var(--text-soft);font-style:normal;font-weight:500;margin-left:2px;}
.annual-info__row em{
  font-style:normal;font-size:11px;color:#FFE500;font-weight:700;
  background:rgba(255,229,0,.12);
  padding:3px 8px;
  white-space:nowrap;
}
.annual-info__note{font-size:12px;color:var(--text-mute);margin-top:12px;line-height:1.7;}

/* ============ TRIAL CTA mini (personal section bottom) ============ */
.trial-cta-mini{
  margin-top:40px;padding:28px 24px;text-align:center;
  background:linear-gradient(135deg, rgba(255,229,0,.10), transparent 80%);
  border:1px dashed rgba(255,229,0,.4);
}
.trial-cta-mini p{
  font-size:14px;color:var(--text-soft);line-height:1.85;margin-bottom:18px;
}
@media (min-width:760px){.trial-cta-mini p{font-size:15px;}}
.trial-cta-mini p strong{color:var(--yellow);}

/* ============ VISITOR PRICING ============ */
.visitor-blocks{
  display:grid;grid-template-columns:1fr;gap:20px;margin-top:40px;
}
@media (min-width:760px){.visitor-blocks{grid-template-columns:1fr 1fr;gap:24px;}}
.visitor-block{
  background:var(--gray);
  border:1px solid var(--line);
  padding:26px 24px;
  border-top:3px solid var(--yellow);
}
.visitor-block h3{
  font-size:18px;font-weight:900;margin-bottom:18px;
  letter-spacing:.02em;
}
@media (min-width:760px){.visitor-block h3{font-size:20px;}}
.visitor-rows{display:flex;flex-direction:column;gap:10px;}
.visitor-row{
  display:grid;grid-template-columns:auto 1fr auto;gap:10px;align-items:baseline;
  padding:12px 0;
  border-bottom:1px solid var(--line);
}
.visitor-row:last-child{border-bottom:none;}
.visitor-row span{font-size:13px;color:#cfcfcf;font-weight:500;}
@media (min-width:760px){.visitor-row span{font-size:14px;}}
.visitor-row b{
  font-family:var(--font-en);font-weight:800;font-style:italic;
  font-size:22px;color:var(--yellow);
}
.visitor-row em{
  font-style:normal;font-size:11px;color:var(--text-mute);font-weight:500;
  text-align:right;
  grid-column:1 / -1;margin-top:-4px;
}
@media (min-width:760px){
  .visitor-row em{grid-column:auto;margin-top:0;}
}
.visitor-note{
  margin-top:28px;padding:22px 24px;
  background:rgba(255,229,0,.04);
  border:1px solid var(--line);
}
.visitor-note h4{
  font-size:13px;font-weight:900;letter-spacing:.05em;
  color:var(--yellow);margin-bottom:12px;
}
.visitor-note ul{list-style:none;display:flex;flex-direction:column;gap:6px;}
.visitor-note li{
  font-size:13px;color:var(--text-soft);line-height:1.7;
  padding-left:14px;position:relative;
}
@media (min-width:760px){.visitor-note li{font-size:14px;}}
.visitor-note li::before{
  content:"";position:absolute;left:0;top:11px;width:6px;height:1px;background:var(--yellow);
}

/* ============ TICKETS (personal supplemental) ============ */
.ticket-grid{
  display:grid;grid-template-columns:1fr;gap:12px;margin-top:30px;
}
@media (min-width:760px){.ticket-grid{grid-template-columns:repeat(3,1fr);}}
.ticket{
  background:var(--gray);padding:22px 22px;
  border:1px solid var(--line);
  display:flex;flex-direction:column;gap:6px;
}
.ticket__label{
  font-family:var(--font-en);font-size:11px;letter-spacing:.22em;font-weight:800;
  color:var(--yellow);
}
.ticket__price{
  font-family:var(--font-en);font-weight:800;font-style:italic;
  font-size:30px;color:#fff;line-height:1;
}
.ticket__price span{font-size:12px;color:var(--text-mute);font-weight:500;font-style:normal;margin-left:4px;}
.ticket p{font-size:13px;color:var(--text-soft);line-height:1.75;margin-top:6px;}
@media (min-width:760px){.ticket p{font-size:14px;}}

/* ============ BUNDLE ============ */
.bundle{padding:80px 0;background:var(--black-2);}
.bundle__inner{
  max-width:760px;margin:0 auto;
  background:linear-gradient(135deg, rgba(255,229,0,.10), rgba(255,229,0,.02));
  border:1px dashed rgba(255,229,0,.45);
  padding:40px 32px;
}
.bundle__lead{font-family:var(--font-en);font-size:11px;letter-spacing:.3em;color:var(--yellow);font-weight:700;margin-bottom:14px;}
.bundle__title{font-size:clamp(24px,4.5vw,36px);font-weight:900;margin-bottom:24px;line-height:1.3;}
.bundle__rows{display:flex;flex-direction:column;gap:1px;background:var(--line);}
.bundle__row{
  display:flex;justify-content:space-between;align-items:baseline;
  padding:14px 18px;background:rgba(0,0,0,.4);
  font-size:14px;color:var(--text-soft);
}
.bundle__row b{
  font-family:var(--font-en);font-weight:800;font-style:italic;
  font-size:22px;color:var(--yellow);
}
.bundle__note{font-size:12px;color:var(--text-mute);margin-top:14px;line-height:1.7;}

/* ============ FAQ SECTION ============ */
.faq-section{padding:80px 0;background:var(--black);}
@media (min-width:900px){.faq-section{padding:120px 0;}}
.faq-list{display:flex;flex-direction:column;gap:8px;margin-top:40px;}
.faq-item{
  background:var(--gray);border:1px solid var(--line);
  transition:border-color .3s;
}
.faq-item:hover{border-color:rgba(255,229,0,.3);}
.faq-item.open{border-color:var(--yellow);}
.faq-item__q{
  width:100%;background:none;border:none;color:#fff;
  text-align:left;cursor:pointer;font-family:inherit;
  padding:18px 22px;font-size:15px;font-weight:700;line-height:1.6;
  display:flex;align-items:flex-start;gap:14px;
  position:relative;
}
.faq-item__q::after{
  content:"+";position:absolute;right:22px;top:50%;transform:translateY(-50%);
  font-family:var(--font-en);font-weight:800;font-size:24px;color:var(--yellow);
  transition:transform .3s;
}
.faq-item.open .faq-item__q::after{transform:translateY(-50%) rotate(45deg);}
.faq-item__q > span:first-child{
  font-family:var(--font-en);font-weight:800;font-style:italic;
  color:var(--yellow);font-size:18px;line-height:1.2;flex-shrink:0;
}
.faq-item__q-text{
  flex:1;
  font-family:inherit;font-weight:700;font-style:normal;
  color:#fff;font-size:15px;line-height:1.6;
  padding-right:30px;
}
@media (min-width:760px){.faq-item__q-text{font-size:16px;}}
.faq-item__a{
  max-height:0;overflow:hidden;
  transition:max-height .4s var(--ease);
}
.faq-item.open .faq-item__a{max-height:800px;}
.faq-item__a p{
  padding:0 22px 20px 56px;
  font-size:14px;color:var(--text-soft);line-height:2;
}
@media (min-width:760px){.faq-item__a p{font-size:15px;}}


/* ============ FACILITY MAP ============ */
.map-section{padding:80px 0;background:var(--black);}
@media (min-width:900px){.map-section{padding:120px 0;}}
.map-stage{
  /* 縦並び固定: SVGを全幅で大きく表示し視認性を最大化、詳細パネルは下に */
  display:flex;flex-direction:column;gap:28px;margin-top:40px;align-items:center;
}
@media (min-width:1000px){
  .map-stage{gap:36px;}
}
.map-canvas{
  background:#0d0d0d;border:1px solid var(--line);
  padding:14px;position:relative;overflow:hidden;
  width:100%;max-width:1200px;
}
.map-detail{width:100%;max-width:900px;}
.map-canvas::before{
  content:"";position:absolute;inset:0;
  background-image:
    linear-gradient(rgba(255,255,255,.02) 1px,transparent 1px),
    linear-gradient(90deg, rgba(255,255,255,.02) 1px,transparent 1px);
  background-size:24px 24px;pointer-events:none;
}
.map-svg{display:block;width:100%;height:auto;position:relative;z-index:1;}
.map-zone{cursor:pointer;transition:fill .3s,stroke .3s;}
.map-zone:hover{fill:rgba(255,229,0,.15);stroke:var(--yellow);}
.map-zone.active{fill:rgba(255,229,0,.18);stroke:var(--yellow);stroke-width:2;}
.map-zone[data-zone="studio"]:hover{fill:rgba(255,0,212,.18);stroke:#FF00D4;}
.map-zone[data-zone="studio"].active{fill:rgba(255,0,212,.22);stroke:#FF00D4;stroke-width:2;}
.map-pin{cursor:pointer;transition:transform .3s;}
.map-pin:hover{transform:translate(var(--tx,0),var(--ty,0)) scale(1.15);}
.map-pin circle{transition:filter .3s;}
.map-pin:hover circle{filter:drop-shadow(0 0 8px var(--yellow));}
.map-pin.active circle{
  filter:drop-shadow(0 0 14px var(--yellow));
  animation:pinPulse 1.5s ease-in-out infinite;
}
.map-pin.special.active circle{filter:drop-shadow(0 0 14px #FF00D4);}
@keyframes pinPulse{0%,100%{r:14;}50%{r:17;}}

.map-detail{
  background:var(--gray);border:1px solid var(--line);
  padding:28px 26px;min-height:480px;
  position:relative;
}
.map-detail.neon{border-color:rgba(255,0,212,.4);background:linear-gradient(135deg,#0a0a0a,#1a0a1a);}
.map-detail.flash .map-detail__inner{animation:fadeInUp .35s ease;}
@keyframes fadeInUp{from{opacity:0;transform:translateY(8px);}to{opacity:1;transform:translateY(0);}}
.map-detail__num{
  font-family:var(--font-en);font-weight:800;font-style:italic;
  font-size:54px;color:var(--yellow);line-height:1;letter-spacing:-.02em;
}
.map-detail.neon .map-detail__num{color:#FF00D4;text-shadow:0 0 12px #FF00D4;}
.map-detail__label{
  font-family:var(--font-en);font-size:11px;letter-spacing:.25em;font-weight:700;
  color:var(--text-mute);margin-top:4px;
}
.map-detail__title{font-size:24px;font-weight:900;margin:14px 0 18px;}
.map-detail__media{aspect-ratio:16/10;overflow:hidden;background:#1a1a1a;margin-bottom:18px;}
.map-detail__media img{width:100%;height:100%;object-fit:cover;display:block;}
.map-detail p{font-size:14px;color:var(--text-soft);line-height:1.95;margin-bottom:16px;}
@media (min-width:760px){.map-detail p{font-size:15px;}}
.map-detail__list{list-style:none;}
.map-detail__list li{
  font-size:13px;color:#CFCFCF;padding:6px 0 6px 18px;position:relative;line-height:1.75;
}
.map-detail__list li::before{
  content:"";position:absolute;left:0;top:13px;width:10px;height:2px;background:var(--yellow);
}
.map-detail.neon .map-detail__list li::before{background:#FF00D4;}
.map-hint{
  font-family:var(--font-en);font-size:11px;letter-spacing:.2em;color:var(--text-mute);
  text-align:center;margin-top:24px;font-weight:700;
}

/* ============ AREA GALLERY ============ */
.area-gallery{padding:80px 0;background:var(--black-2);}
@media (min-width:900px){.area-gallery{padding:120px 0;}}
.area-grid{
  display:grid;grid-template-columns:1fr;gap:14px;margin-top:40px;
}
@media (min-width:600px){.area-grid{grid-template-columns:repeat(2,1fr);}}
@media (min-width:1000px){.area-grid{grid-template-columns:repeat(3,1fr);}}
.area-card{
  background:var(--gray);border:1px solid var(--line);overflow:hidden;
  display:flex;flex-direction:column;position:relative;
  transition:transform .4s var(--ease),border-color .3s;
}
.area-card:hover{transform:translateY(-4px);border-color:rgba(255,229,0,.4);}
.area-card.neon:hover{border-color:rgba(255,0,212,.5);}
.area-card__num{
  position:absolute;top:14px;left:14px;z-index:2;
  background:var(--yellow);color:#000;
  padding:5px 11px;font-family:var(--font-en);font-weight:800;font-size:11px;
  letter-spacing:.18em;font-style:italic;
}
.area-card.neon .area-card__num{background:#FF00D4;color:#fff;}
.area-card__img{aspect-ratio:4/3;overflow:hidden;background:#1a1a1a;}
.area-card__img img{width:100%;height:100%;object-fit:cover;transition:transform .6s var(--ease);}
.area-card:hover .area-card__img img{transform:scale(1.05);}
.area-card__body{padding:18px 20px 22px;}
.area-card__body h4{font-size:15px;font-weight:900;margin-bottom:8px;}
.area-card__body p{font-size:14px;color:var(--text-soft);line-height:1.9;}
@media (min-width:760px){.area-card__body p{font-size:15px;}}

/* ============ ACCESS ============ */
.access{padding:80px 0;background:var(--black);}
@media (min-width:900px){.access{padding:120px 0;}}
.access-grid{
  display:grid;grid-template-columns:1fr;gap:24px;margin-top:40px;
}
@media (min-width:900px){.access-grid{grid-template-columns:1fr 1fr;gap:36px;align-items:start;}}
.access-info{background:var(--gray);padding:28px 26px;}
.access-info__row{
  display:grid;grid-template-columns:90px 1fr;gap:16px;
  padding:14px 0;border-bottom:1px dashed rgba(255,255,255,.08);
  font-size:14px;
}
@media (min-width:760px){.access-info__row{font-size:15px;}}
.access-info__row:last-of-type{border-bottom:none;}
.access-info__label{
  font-family:var(--font-en);font-size:11px;letter-spacing:.18em;font-weight:700;
  color:var(--yellow);
}
.access-info__value{color:var(--text-soft);line-height:1.85;}
.access-info__value a{color:#fff;font-weight:700;}
.access-around{margin-top:24px;padding-top:20px;border-top:2px solid var(--yellow);}
.access-around h4{font-size:14px;font-weight:900;margin-bottom:12px;letter-spacing:.05em;}
.access-around ul{list-style:none;display:flex;flex-direction:column;gap:8px;}
.access-around li{
  font-size:14px;color:var(--text-soft);
  display:flex;align-items:center;gap:10px;line-height:1.7;
}
@media (min-width:760px){.access-around li{font-size:15px;}}
.access-around li span{font-size:16px;}
.access-map__exterior{position:relative;aspect-ratio:16/10;overflow:hidden;border:1px solid var(--line);}
.access-map__exterior img{width:100%;height:100%;object-fit:cover;}
.access-map__exterior-label{
  position:absolute;left:14px;bottom:12px;
  font-family:var(--font-en);font-size:11px;letter-spacing:.2em;font-weight:700;
  background:rgba(0,0,0,.7);color:var(--yellow);padding:5px 10px;
}
.access-map__btn{
  display:flex;align-items:center;justify-content:center;gap:10px;
  margin-top:14px;padding:16px;background:var(--yellow);color:#000;
  font-weight:800;font-size:13px;letter-spacing:.05em;
  transition:transform .3s;
}
.access-map__btn:hover{transform:translateY(-2px);}
.access-map__btn i{display:inline-flex;width:18px;height:18px;}


/* ============ DIFF NUMBERS (UNIQUE) ============ */
.diff-numbers{padding:60px 0;background:var(--black);}
.diff-grid{
  display:grid;grid-template-columns:repeat(2,1fr);gap:1px;background:var(--line);
}
@media (min-width:760px){.diff-grid{grid-template-columns:repeat(4,1fr);}}
.diff-num{
  background:var(--gray);padding:30px 22px;
  display:flex;flex-direction:column;gap:8px;
  border-top:2px solid var(--yellow);
}
.diff-num b{
  font-family:var(--font-en);font-weight:800;font-style:italic;
  font-size:clamp(48px,8vw,72px);color:var(--yellow);line-height:.95;
}
.diff-num b i{font-size:.4em;font-style:italic;margin-left:3px;opacity:.85;}
.diff-num span{font-size:13px;color:var(--text-soft);line-height:1.75;letter-spacing:.02em;}
@media (min-width:760px){.diff-num span{font-size:14px;}}

/* ============ REASONS BLOCKS ============ */
.reasons{padding:90px 0;background:var(--black-2);}
@media (min-width:900px){.reasons{padding:130px 0;}}
.reason-block{
  display:grid;grid-template-columns:1fr;gap:24px;
  margin-top:50px;padding-top:50px;border-top:1px solid var(--line);
  position:relative;
}
.reason-block:first-of-type{border-top:none;padding-top:0;margin-top:40px;}
@media (min-width:900px){
  /* normal: [番号] [本文] [画像] */
  .reason-block{
    grid-template-columns:80px 1.4fr 1fr;
    grid-template-areas:"num body media";
    gap:40px;align-items:center;
  }
  .reason-block__num{grid-area:num;}
  .reason-block__body{grid-area:body;}
  .reason-block__media{grid-area:media;}
  /* reverse: 完全ミラー [画像] [本文] [番号] — 本文は常に中央(読みやすさ優先) */
  .reason-block.reverse{
    grid-template-columns:1fr 1.4fr 80px;
    grid-template-areas:"media body num";
  }
  .reason-block.reverse .reason-block__num{text-align:right;}
}
.reason-block__num{
  font-family:var(--font-en);font-weight:800;font-style:italic;
  font-size:clamp(48px,8vw,80px);color:var(--yellow);line-height:.9;letter-spacing:-.02em;
  -webkit-text-stroke:1px var(--yellow);
}
.reason-block__chip{
  display:inline-flex;align-items:center;gap:10px;
  font-family:var(--font-en);font-size:11px;letter-spacing:.25em;font-weight:700;
  color:var(--yellow);margin-bottom:12px;
}
.reason-block__chip::before{content:"";width:18px;height:1px;background:var(--yellow);}
.reason-block__body h3{
  font-size:clamp(20px,3.4vw,28px);font-weight:900;line-height:1.5;margin-bottom:14px;
}
.reason-block__body p{font-size:14.5px;color:var(--text-soft);line-height:2;}
@media (min-width:760px){.reason-block__body p{font-size:15.5px;}}
.reason-block__media{
  aspect-ratio:4/3;overflow:hidden;background:#1a1a1a;
  border:1px solid var(--line);
}
.reason-block__media img{width:100%;height:100%;object-fit:cover;filter:saturate(.9) contrast(1.05);transition:transform .8s var(--ease);}
.reason-block:hover .reason-block__media img{transform:scale(1.04);}
.reason-block__media.neon{border-color:rgba(255,0,212,.4);box-shadow:0 0 30px rgba(255,0,212,.15);}

/* ============ VS TABLE ============ */
.vs-section{padding:80px 0;background:var(--black);}
@media (min-width:900px){.vs-section{padding:120px 0;}}
.vs-table{
  margin-top:40px;border:1px solid var(--line);
  display:flex;flex-direction:column;
}
.vs-row{
  display:grid;grid-template-columns:120px 1fr 1fr;
  border-bottom:1px solid var(--line);font-size:14px;
}
@media (min-width:760px){.vs-row{font-size:15px;}}
@media (min-width:760px){.vs-row{grid-template-columns:200px 1fr 1fr;}}
.vs-row:last-child{border-bottom:none;}
.vs-row > div{padding:16px 18px;}
.vs-head{background:#181818;}
.vs-head > div{
  font-family:var(--font-en);font-weight:800;font-size:13px;letter-spacing:.15em;
}
.vs-other{color:var(--text-mute);background:rgba(255,255,255,.02);border-right:1px solid var(--line);}
.vs-zeku{color:var(--yellow);background:rgba(255,229,0,.04);font-weight:700;}
.vs-head .vs-zeku{font-style:italic;}
.vs-label{font-weight:700;color:#fff;background:#141414;border-right:1px solid var(--line);}
.vs-row:not(.vs-head) .vs-other{color:var(--text-mute);text-decoration:line-through;text-decoration-color:rgba(255,255,255,.2);}
.vs-row:not(.vs-head) .vs-zeku{color:#fff;font-weight:700;}
.vs-row:not(.vs-head) .vs-zeku::before{
  content:"✓";color:var(--yellow);font-weight:900;margin-right:8px;
}

/* ============ STORY ============ */
.story{padding:90px 0;background:var(--black-2);}
@media (min-width:900px){.story{padding:130px 0;}}
.story-grid{
  display:grid;grid-template-columns:1fr;gap:32px;align-items:center;
}
@media (min-width:900px){.story-grid{grid-template-columns:1fr 1.2fr;gap:60px;}}
.story__media{aspect-ratio:4/5;overflow:hidden;border:1px solid var(--line);background:#1a1a1a;position:relative;}
.story__media img{width:100%;height:100%;object-fit:cover;filter:saturate(.9) contrast(1.05);}
.story__media::before{
  content:"";position:absolute;inset:-1px;border:2px solid var(--yellow);
  pointer-events:none;clip-path:polygon(0 0,40px 0,40px 4px,4px 4px,4px 100%,0 100%);
}
.story__title{font-size:clamp(28px,5vw,42px);font-weight:900;line-height:1.4;margin:14px 0 24px;}
.story__body p{font-size:15px;color:var(--text-soft);line-height:2;margin-bottom:14px;}
@media (min-width:760px){.story__body p{font-size:16px;}}
.story__sign{
  margin-top:24px;font-family:var(--font-en);font-weight:800;font-style:italic;
  font-size:14px;letter-spacing:.2em;color:var(--yellow) !important;
}


/* ============ BLACKOUT NEON PAGE ============ */
.page-hero.neon .neon-title{
  font-family:var(--font-en);font-weight:800;font-style:italic;
  font-size:clamp(56px,12vw,140px);line-height:.9;letter-spacing:-.02em;
  margin-bottom:20px;
}
.page-hero.neon .neon-title .cyan{color:#00F0FF;text-shadow:0 0 24px rgba(0,240,255,.6),0 0 60px rgba(0,240,255,.3);display:block;}
.page-hero.neon .neon-title .magenta{color:#FF00D4;text-shadow:0 0 24px rgba(255,0,212,.6),0 0 60px rgba(255,0,212,.3);display:block;}
.page-hero.neon .page-hero__desc{color:#cfcfcf;}
.neon-stats{display:flex;flex-wrap:wrap;gap:30px;margin-top:36px;}
.ns{display:flex;flex-direction:column;gap:4px;}
.ns b{
  font-family:var(--font-en);font-weight:800;font-style:italic;
  font-size:clamp(36px,7vw,56px);line-height:.95;
  background:linear-gradient(135deg,#FF00D4,#00F0FF);
  -webkit-background-clip:text;background-clip:text;color:transparent;
}
.ns b i{font-size:.5em;font-style:italic;margin-left:2px;}
.ns span{font-size:11px;color:#888;letter-spacing:.18em;font-weight:700;}

/* strip */
.neon-strip{background:#000;padding:0;overflow:hidden;border-top:1px solid rgba(255,0,212,.3);border-bottom:1px solid rgba(0,240,255,.3);}
.neon-strip__inner{display:grid;grid-template-columns:1fr 1fr 1fr;gap:1px;background:rgba(255,0,212,.3);}
.neon-strip__img{aspect-ratio:16/9;overflow:hidden;}
.neon-strip__img img{width:100%;height:100%;object-fit:cover;filter:saturate(1.2) contrast(1.1);}

/* what is */
.neon-what{padding:80px 0;background:#050008;}
@media (min-width:900px){.neon-what{padding:120px 0;}}
.neon-what .section-title{color:#fff;}
.magenta-text{color:#FF00D4;text-shadow:0 0 16px rgba(255,0,212,.5);}
.cyan-text{color:#00F0FF;text-shadow:0 0 16px rgba(0,240,255,.5);}
.neon-pillars{display:grid;grid-template-columns:1fr;gap:14px;margin-top:50px;}
@media (min-width:760px){.neon-pillars{grid-template-columns:repeat(3,1fr);}}
.np{
  padding:32px 26px;background:linear-gradient(135deg,rgba(255,0,212,.06),rgba(0,240,255,.04));
  border:1px solid rgba(255,0,212,.3);position:relative;
  transition:transform .4s var(--ease),border-color .3s,box-shadow .3s;
}
.np:hover{transform:translateY(-6px);border-color:#FF00D4;box-shadow:0 0 30px rgba(255,0,212,.2);}
.np__icon{
  width:60px;height:60px;
  margin-bottom:18px;
  color:#FF00D4;
  filter:drop-shadow(0 0 10px rgba(255,0,212,.7)) drop-shadow(0 0 22px rgba(255,0,212,.3));
  animation:npIconBreathe 3.6s ease-in-out infinite;
}
@media (min-width:760px){.np__icon{width:68px;height:68px;}}
.np__icon svg{width:100%;height:100%;display:block;}
.np:nth-child(2) .np__icon{
  color:#00F0FF;
  filter:drop-shadow(0 0 10px rgba(0,240,255,.7)) drop-shadow(0 0 22px rgba(0,240,255,.3));
  animation-delay:-1.2s;
}
.np:nth-child(3) .np__icon{
  color:#FFE500;
  filter:drop-shadow(0 0 10px rgba(255,229,0,.7)) drop-shadow(0 0 22px rgba(255,229,0,.3));
  animation-delay:-2.4s;
}
@keyframes npIconBreathe{
  0%,100%{transform:scale(1);opacity:.92;}
  50%{transform:scale(1.06);opacity:1;}
}
.np h3{font-family:var(--font-en);font-weight:800;font-style:italic;font-size:24px;color:#FF00D4;margin-bottom:10px;letter-spacing:.04em;}
.np p{font-size:14px;color:#cfcfcf;line-height:1.95;}
@media (min-width:760px){.np p{font-size:15px;}}
.np:nth-child(2){border-color:rgba(0,240,255,.3);}
.np:nth-child(2):hover{border-color:#00F0FF;box-shadow:0 0 30px rgba(0,240,255,.2);}
.np:nth-child(2) h3{color:#00F0FF;}
.np:nth-child(3){border-color:rgba(255,229,0,.3);}
.np:nth-child(3):hover{border-color:var(--yellow);box-shadow:0 0 30px rgba(255,229,0,.2);}
.np:nth-child(3) h3{color:var(--yellow);}

/* programs */
.neon-programs{padding:80px 0;background:#000;}
@media (min-width:900px){.neon-programs{padding:120px 0;}}
.neon-programs .section-title{color:#fff;}
.neon-prog-grid{display:grid;grid-template-columns:1fr;gap:14px;margin-top:40px;}
@media (min-width:600px){.neon-prog-grid{grid-template-columns:1fr 1fr;}}
@media (min-width:1000px){.neon-prog-grid{grid-template-columns:repeat(3,1fr);}}
.neon-prog{
  background-color:#0a0a0a;
  border:1px solid rgba(255,255,255,.08);
  position:relative;overflow:hidden;
  cursor:pointer;
  -webkit-tap-highlight-color:transparent;
  display:flex;flex-direction:column;
  transition:transform .4s var(--ease),border-color .3s;
}
.neon-prog__photo{
  aspect-ratio:16/10;
  background-size:cover;background-position:center;
  position:relative;
  overflow:hidden;
  border-bottom:1px solid rgba(255,0,212,.25);
  transition:filter .4s ease;
}
.neon-prog__photo::after{
  content:"";position:absolute;inset:0;
  background:linear-gradient(180deg, transparent 65%, rgba(10,0,15,.6) 100%);
  pointer-events:none;
}
.neon-prog:hover .neon-prog__photo{filter:brightness(1.08) saturate(1.1);}
.neon-prog__body{
  padding:18px 22px 22px;
  display:flex;flex-direction:column;flex:1;
  background:linear-gradient(180deg, #0d0010 0%, #0a0008 100%);
  position:relative;
}
.neon-prog__body > .neon-prog__tag{align-self:flex-start;}
.neon-prog::before{
  content:"";position:absolute;left:0;top:0;bottom:0;width:3px;z-index:2;
  background:linear-gradient(180deg,#FF00D4,#00F0FF);opacity:0;transition:opacity .3s;
}
.neon-prog:hover{transform:translateY(-4px);border-color:rgba(255,0,212,.4);}
.neon-prog:hover::before{opacity:1;}
.neon-prog__tag{
  display:inline-block;font-family:var(--font-en);font-weight:800;font-size:10px;letter-spacing:.2em;
  padding:4px 10px;background:rgba(255,0,212,.15);color:#FF00D4;margin-bottom:14px;
}
.neon-prog h3{
  font-family:var(--font-en);font-weight:800;font-style:italic;
  font-size:18px;color:#fff;letter-spacing:.03em;line-height:1.2;
  margin-bottom:6px;
}
@media (min-width:760px){.neon-prog h3{font-size:20px;}}
.neon-prog__sub{font-size:12px;color:#FF00D4;letter-spacing:.05em;margin-bottom:12px;font-weight:700;text-shadow:0 0 6px rgba(255,0,212,.4);}
.neon-prog p{font-size:13px;color:#cfcfcf;line-height:1.85;margin-bottom:14px;}
@media (min-width:760px){.neon-prog p{font-size:14px;}}
.neon-prog__meta{font-size:11px;color:#FF00D4;letter-spacing:.05em;font-weight:700;padding-top:12px;border-top:1px solid rgba(255,255,255,.08);margin-top:auto;}

.neon-prog-hint{
  text-align:center;font-family:var(--font-en);font-size:11px;letter-spacing:.2em;font-weight:700;
  color:rgba(255,0,212,.7);margin:20px 0 10px;
  text-shadow:0 0 8px rgba(255,0,212,.4);
}

/* ============ NEON DETAIL MODAL (BLACKOUT page) ============ */
.neon-detail{
  position:fixed;inset:0;z-index:300;
  display:flex;align-items:center;justify-content:center;
  padding:40px 50px;
  opacity:0;visibility:hidden;
  transition:opacity .4s var(--ease), visibility .4s;
  background:radial-gradient(ellipse at center, rgba(0,0,0,.85) 0%, rgba(0,0,0,.96) 100%);
  backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px);
  overflow:hidden;
}
.neon-detail.open{opacity:1;visibility:visible;}
.neon-detail__photo{
  position:absolute;inset:0;z-index:0;
  background-size:cover;background-position:center;
  filter:saturate(.95) brightness(.4);
  opacity:0;transform:scale(1.05);
  transition:opacity .5s ease, transform .8s var(--ease);
}
.neon-detail__photo.show{opacity:.55;transform:scale(1);}
.neon-detail::after{
  content:"";position:absolute;inset:0;z-index:1;pointer-events:none;
  background:radial-gradient(ellipse at center, transparent 25%, rgba(0,0,0,.6) 100%);
}
.neon-detail__body{
  position:relative;z-index:2;
  width:100%;max-width:520px;
  max-height:calc(100vh - 100px);
  overflow-y:auto;
  text-align:center;color:#fff;
}
.neon-detail__num{
  font-family:var(--font-en);font-weight:800;font-style:italic;
  font-size:36px;line-height:1;
  margin-bottom:8px;
  color:var(--neon-c, #FF00D4);
  text-shadow:0 0 20px var(--neon-c, #FF00D4);
}
.neon-detail__title{
  font-family:var(--font-en);font-weight:800;font-style:italic;
  font-size:clamp(28px,5.5vw,46px);line-height:1.05;
  letter-spacing:-.01em;
  margin-bottom:8px;
  text-shadow:0 0 28px var(--neon-c, #FF00D4);
}
.neon-detail__catch{
  font-family:var(--font-en);font-weight:800;font-style:italic;
  font-size:14px;letter-spacing:.04em;
  color:var(--neon-c, #FF00D4);
  margin-bottom:14px;
  text-shadow:0 0 12px var(--neon-c, #FF00D4);
}
.neon-detail__desc{
  font-size:14px;line-height:1.85;color:#dedede;
  margin-bottom:18px;padding:0 6px;
}
@media (min-width:760px){.neon-detail__desc{font-size:15px;}}
.neon-detail__tags{
  display:flex;flex-wrap:wrap;gap:6px;justify-content:center;margin-bottom:18px;
}
.neon-detail__tag{
  font-family:var(--font-en);font-size:10px;font-weight:700;letter-spacing:.15em;
  padding:4px 10px;
  border:1px solid var(--neon-c, #FF00D4);
  color:var(--neon-c, #FF00D4);
  background:rgba(0,0,0,.4);
  text-shadow:0 0 4px var(--neon-c, #FF00D4);
}
.neon-detail__meta{
  display:grid;grid-template-columns:auto 1fr;gap:8px 16px;
  margin:0 auto;padding:16px 20px;
  background:rgba(0,0,0,.55);
  border:1px solid var(--neon-c, #FF00D4);
  text-align:left;max-width:420px;
  box-shadow:inset 0 0 14px rgba(0,0,0,.4), 0 0 18px rgba(255,0,212,.2);
}
.neon-detail__meta .meta-row{display:contents;}
.neon-detail__meta .meta-label{
  font-family:var(--font-en);font-size:10px;letter-spacing:.18em;font-weight:700;
  color:var(--neon-c, #FF00D4);white-space:nowrap;align-self:center;
  text-shadow:0 0 6px var(--neon-c, #FF00D4);
}
.neon-detail__meta .meta-value{font-size:13px;color:#fff;line-height:1.5;font-weight:500;}
@media (min-width:760px){.neon-detail__meta .meta-value{font-size:14px;}}
.neon-detail__meta .meta-value.stars{
  font-family:var(--font-en);font-weight:800;letter-spacing:.1em;
  color:var(--neon-c, #FF00D4);font-size:14px;
}

.neon-detail__close{
  position:absolute;top:16px;right:16px;z-index:5;
  width:42px;height:42px;border-radius:50%;
  background:rgba(0,0,0,.7);color:#fff;
  display:flex;align-items:center;justify-content:center;
  font-size:16px;font-weight:700;
  border:1px solid rgba(255,255,255,.3);
  transition:all .3s;cursor:pointer;
}
.neon-detail__close:hover{
  background:var(--neon-c, #FF00D4);color:#fff;
  border-color:var(--neon-c, #FF00D4);
  box-shadow:0 0 16px var(--neon-c, #FF00D4);
}
.neon-detail__nav{
  position:absolute;top:50%;transform:translateY(-50%);z-index:5;
  width:46px;height:46px;border-radius:50%;
  background:rgba(0,0,0,.65);color:#fff;
  font-family:var(--font-en);font-weight:800;font-size:30px;line-height:1;
  display:flex;align-items:center;justify-content:center;
  border:1px solid rgba(255,255,255,.25);
  transition:all .3s;cursor:pointer;padding-bottom:3px;
}
.neon-detail__nav:hover{
  background:var(--neon-c, #FF00D4);color:#fff;
  border-color:var(--neon-c, #FF00D4);
  box-shadow:0 0 16px var(--neon-c, #FF00D4);
}
.neon-detail__nav.prev{left:8px;}
.neon-detail__nav.next{right:8px;}
@media (min-width:760px){
  .neon-detail__nav{width:54px;height:54px;font-size:34px;}
  .neon-detail__nav.prev{left:18px;}
  .neon-detail__nav.next{right:18px;}
}
.neon-detail__pager{
  position:absolute;bottom:18px;left:50%;transform:translateX(-50%);z-index:5;
  font-family:var(--font-en);font-size:11px;letter-spacing:.25em;font-weight:700;
  color:rgba(255,255,255,.55);text-align:center;
}
.neon-detail__pager small{display:block;font-size:9px;letter-spacing:.2em;color:rgba(255,255,255,.35);margin-top:2px;}

/* color tokens for modal */
.neon-detail.color-magenta{--neon-c:#FF00D4;}
.neon-detail.color-cyan{--neon-c:#00F0FF;}
.neon-detail.color-yellow{--neon-c:#FFE500;}
.neon-detail.color-purple{--neon-c:#B400FF;}

/* schedule */
.neon-schedule{padding:80px 0;background:#050008;}
@media (min-width:900px){.neon-schedule{padding:120px 0;}}
.neon-schedule .section-title{color:#fff;}
.schedule-scroll{overflow-x:auto;border:1px solid rgba(255,0,212,.2);margin-top:40px;}
.schedule{width:100%;min-width:760px;border-collapse:collapse;background:#0a0a0a;}
.schedule th,.schedule td{padding:12px 10px;text-align:center;font-size:13px;border-bottom:1px solid rgba(255,255,255,.05);border-right:1px solid rgba(255,255,255,.05);}
.schedule th:last-child,.schedule td:last-child{border-right:none;}
.schedule thead th{background:#000;color:#FF00D4;font-family:var(--font-en);font-weight:800;font-size:13px;letter-spacing:.15em;padding:14px 10px;}
.schedule tbody th{background:#141414;color:#fff;font-family:var(--font-en);font-weight:700;font-style:italic;font-size:14px;}
.schedule td{color:#666;}
.schedule td.cell{font-family:var(--font-en);font-weight:800;font-style:italic;font-size:13px;letter-spacing:.05em;cursor:pointer;transition:filter .2s;}
.schedule td.cell:hover{filter:brightness(1.4);}
.schedule td.c1{background:rgba(255,0,212,.18);color:#FF00D4;}
.schedule td.c2{background:rgba(0,240,255,.18);color:#00F0FF;}
.schedule td.c3{background:rgba(255,229,0,.18);color:var(--yellow);}
.schedule td.c4{background:rgba(168,85,247,.18);color:#C77DFF;}
.schedule td.c5{background:rgba(255,80,80,.2);color:#FF6B6B;}
.neon-note{font-size:12px;color:#888;margin-top:14px;letter-spacing:.05em;line-height:1.7;}

/* first time */
.neon-first{padding:80px 0;background:#000;text-align:center;}
@media (min-width:900px){.neon-first{padding:120px 0;}}
.neon-first .section-title{color:#fff;}
.neon-first-grid{display:grid;grid-template-columns:1fr;gap:14px;margin-top:50px;text-align:left;}
@media (min-width:760px){.neon-first-grid{grid-template-columns:repeat(3,1fr);}}
.neon-first__card{
  padding:30px 24px;background:#0a0a0a;border:1px solid rgba(0,240,255,.25);
  position:relative;transition:transform .4s,border-color .3s;
}
.neon-first__card:hover{transform:translateY(-4px);border-color:#00F0FF;box-shadow:0 0 28px rgba(0,240,255,.18);}
.neon-first__card b{
  font-family:var(--font-en);font-weight:800;font-style:italic;
  font-size:48px;color:#00F0FF;line-height:1;text-shadow:0 0 16px rgba(0,240,255,.4);
}
.neon-first__card h3{font-size:18px;font-weight:900;color:#fff;margin:14px 0 10px;}
.neon-first__card p{font-size:14px;color:#cfcfcf;line-height:1.9;}
@media (min-width:760px){.neon-first__card p{font-size:15px;}}
.neon-cta{
  display:inline-flex;align-items:center;gap:14px;
  margin-top:50px;padding:20px 40px;
  font-family:var(--font-en);font-weight:800;font-style:italic;font-size:16px;letter-spacing:.15em;
  background:linear-gradient(135deg,#FF00D4,#00F0FF);color:#fff;
  box-shadow:0 0 30px rgba(255,0,212,.4),0 0 60px rgba(0,240,255,.2);
  transition:transform .3s,box-shadow .3s;
}
.neon-cta:hover{transform:translateY(-3px);box-shadow:0 0 40px rgba(255,0,212,.6),0 0 80px rgba(0,240,255,.3);}
.neon-cta i{font-style:italic;}

.neon-tagline{
  font-family:var(--font-en);font-weight:700;font-style:italic;
  font-size:13px;letter-spacing:.18em;
  color:#FF00D4;text-shadow:0 0 12px rgba(255,0,212,.6);
  margin-top:22px;opacity:.85;
}

/* Live schedule CTA — opens hacomono with today's date */
.neon-schedule__live{margin-top:28px;text-align:center;}
.neon-schedule__cta{
  display:inline-flex;flex-direction:column;align-items:center;gap:6px;
  padding:18px 28px;
  background:linear-gradient(135deg, rgba(255,0,212,.18), rgba(0,240,255,.10));
  border:1px solid rgba(255,0,212,.55);
  color:#fff;
  transition:all .3s;
  box-shadow:0 0 18px rgba(255,0,212,.25);
  position:relative;overflow:hidden;
}
.neon-schedule__cta::before{
  content:"";position:absolute;inset:0;
  background:linear-gradient(90deg, transparent, rgba(255,255,255,.08), transparent);
  transform:translateX(-100%);
  transition:transform .8s var(--ease);
}
.neon-schedule__cta:hover{
  border-color:#FF00D4;
  background:linear-gradient(135deg, rgba(255,0,212,.28), rgba(0,240,255,.16));
  box-shadow:0 0 32px rgba(255,0,212,.55), 0 0 60px rgba(0,240,255,.2);
  transform:translateY(-2px);
}
.neon-schedule__cta:hover::before{transform:translateX(100%);}
.neon-schedule__cta-main{
  font-family:var(--font-en);font-weight:800;font-style:italic;
  font-size:15px;letter-spacing:.1em;
  text-shadow:0 0 12px rgba(255,0,212,.6);
}
@media (min-width:760px){.neon-schedule__cta-main{font-size:17px;}}
.neon-schedule__cta-date{
  font-family:var(--font-jp);font-weight:500;font-style:normal;
  font-size:12px;letter-spacing:.05em;color:#cfcfcf;
}
@media (min-width:760px){.neon-schedule__cta-date{font-size:13px;}}
@media (min-width:760px){.neon-tagline{font-size:15px;}}

/* ============ NEON STUDIO PRICING (BLACKOUT page) ============ */
.neon-pricing{padding:80px 0;background:#0a0008;text-align:center;position:relative;}
@media (min-width:900px){.neon-pricing{padding:120px 0;}}
.neon-pricing::before{
  content:"";position:absolute;inset:0;
  background:
    radial-gradient(ellipse 40% 30% at 30% 20%, rgba(255,0,212,.12) 0%, transparent 60%),
    radial-gradient(ellipse 40% 30% at 70% 80%, rgba(0,240,255,.10) 0%, transparent 60%);
  pointer-events:none;
}
.neon-pricing > .container{position:relative;z-index:1;}
.neon-pricing .section-title{color:#fff;}
.magenta-text{color:#FF00D4;text-shadow:0 0 14px rgba(255,0,212,.6);}

.neon-price-grid{
  display:grid;grid-template-columns:1fr;gap:18px;margin-top:50px;text-align:left;
}
@media (min-width:760px){.neon-price-grid{grid-template-columns:repeat(3,1fr);gap:22px;}}

.neon-price{
  background:linear-gradient(180deg, rgba(20,5,30,.9) 0%, rgba(0,0,0,.95) 100%);
  border:1px solid rgba(255,255,255,.12);
  padding:28px 26px;
  position:relative;
  transition:transform .4s var(--ease), border-color .3s ease, box-shadow .3s ease;
}
.neon-price:hover{
  transform:translateY(-6px);
  border-color:rgba(0,240,255,.5);
  box-shadow:0 0 32px rgba(0,240,255,.18);
}
.neon-price.featured{
  border-color:#FF00D4;
  background:linear-gradient(180deg, rgba(60,5,40,.9) 0%, rgba(10,0,15,.95) 100%);
  box-shadow:0 0 30px rgba(255,0,212,.25);
}
.neon-price.featured::before{
  content:"POPULAR";
  position:absolute;top:-12px;left:50%;transform:translateX(-50%);
  background:#FF00D4;color:#fff;
  padding:5px 16px;font-family:var(--font-en);font-weight:900;font-size:10px;letter-spacing:.25em;font-style:italic;
  text-shadow:0 0 8px rgba(0,0,0,.4);
}

.neon-price__head{margin-bottom:14px;}
.neon-price__cat{
  font-family:var(--font-en);font-weight:800;font-size:11px;letter-spacing:.22em;
  color:#00F0FF;margin-bottom:6px;
}
.neon-price.featured .neon-price__cat{color:#FF00D4;}
.neon-price__head h3{font-size:18px;font-weight:900;color:#fff;line-height:1.4;}
@media (min-width:760px){.neon-price__head h3{font-size:20px;}}

.neon-price__amount{display:flex;align-items:baseline;gap:2px;margin-bottom:18px;flex-wrap:wrap;}
.neon-price__amount .currency{font-size:18px;font-weight:700;color:#00F0FF;}
.neon-price.featured .neon-price__amount .currency{color:#FF00D4;}
.neon-price__amount .num{
  font-family:var(--font-en);font-weight:800;font-style:italic;
  font-size:48px;color:#fff;line-height:1;letter-spacing:-.01em;
  text-shadow:0 0 18px rgba(0,240,255,.4);
}
.neon-price.featured .neon-price__amount .num{text-shadow:0 0 18px rgba(255,0,212,.5);}
.neon-price__amount .period{font-size:13px;color:#888;margin-left:4px;}

.neon-price__list{list-style:none;border-top:1px solid rgba(255,255,255,.1);padding-top:16px;margin-bottom:20px;}
.neon-price__list li{
  padding:7px 0;font-size:13px;color:#cfcfcf;padding-left:18px;position:relative;line-height:1.7;
}
@media (min-width:760px){.neon-price__list li{font-size:14px;}}
.neon-price__list li::before{
  content:"";position:absolute;left:0;top:14px;width:10px;height:2px;
  background:#00F0FF;box-shadow:0 0 6px rgba(0,240,255,.6);
}
.neon-price.featured .neon-price__list li::before{background:#FF00D4;box-shadow:0 0 6px rgba(255,0,212,.6);}
.neon-price__list strong{color:#fff;}

.neon-price__cta{
  display:block;width:100%;text-align:center;
  padding:14px;
  background:transparent;border:1px solid #00F0FF;color:#00F0FF;
  font-weight:700;font-size:13px;letter-spacing:.1em;
  transition:all .3s;
  font-family:var(--font-en);font-style:italic;
}
.neon-price__cta:hover{background:#00F0FF;color:#000;}
.neon-price.featured .neon-price__cta{background:#FF00D4;color:#fff;border-color:#FF00D4;}
.neon-price.featured .neon-price__cta:hover{background:#fff;color:#000;border-color:#fff;}

.neon-pricing__note{
  font-size:12px;color:#888;margin-top:24px;letter-spacing:.05em;
}

/* ============================================================
   MACHINE LINEUP — facility page
   ============================================================ */
.machine-lineup{padding:80px 0;background:var(--black);position:relative;}
@media (min-width:900px){.machine-lineup{padding:120px 0;}}
.machine-lineup::before{
  content:"";position:absolute;left:0;right:0;top:0;height:1px;
  background:linear-gradient(90deg,transparent,rgba(255,229,0,.5),transparent);
}
.machine-lineup .section-lead{margin-bottom:36px;}

.machine-stats{
  display:grid;grid-template-columns:repeat(2,1fr);gap:1px;
  background:rgba(255,229,0,.2);
  border:1px solid rgba(255,229,0,.25);
  margin:32px 0 40px;
}
@media (min-width:760px){.machine-stats{grid-template-columns:repeat(4,1fr);}}
.machine-stats__cell{
  background:var(--black-2);padding:22px 16px;text-align:center;
}
.machine-stats__num{
  font-family:var(--font-en);font-style:italic;font-weight:800;
  color:var(--yellow);font-size:42px;line-height:1;letter-spacing:.02em;
}
.machine-stats__num small{font-size:18px;font-style:normal;margin-left:4px;color:var(--yellow);}
.machine-stats__label{
  font-size:11px;color:var(--text-soft);letter-spacing:.18em;font-weight:700;
  margin-top:8px;
}

.machine-strip{
  display:grid;grid-template-columns:repeat(5,1fr);gap:6px;
  margin:0 0 56px;
  border:1px solid rgba(255,229,0,.15);
  padding:6px;background:#000;
}
@media (max-width:760px){
  .machine-strip{grid-template-columns:repeat(2,1fr);grid-auto-rows:120px;}
  .machine-strip img:nth-child(1){grid-column:span 2;grid-row:span 2;}
}
.machine-strip img{
  width:100%;height:100%;aspect-ratio:4/3;object-fit:cover;
  filter:contrast(1.05) saturate(1.05);
  transition:transform .6s var(--ease),filter .4s ease;
}
.machine-strip img:hover{transform:scale(1.04);filter:contrast(1.1) saturate(1.2);}
@media (min-width:760px){.machine-strip img{aspect-ratio:1/1;}}

.machine-cat{margin-bottom:48px;}
.machine-cat:last-child{margin-bottom:0;}
.machine-cat__head{
  display:flex;align-items:center;gap:18px;margin-bottom:22px;
  padding-bottom:14px;border-bottom:1px solid rgba(255,229,0,.2);
}
.machine-cat__num{
  display:inline-flex;align-items:center;justify-content:center;
  width:44px;height:44px;flex:none;
  background:var(--yellow);color:#000;
  font-family:var(--font-en);font-style:italic;font-weight:800;font-size:22px;
}
.machine-cat__name{
  font-family:var(--font-en);font-weight:800;font-style:italic;
  font-size:24px;letter-spacing:.04em;color:#fff;line-height:1.1;
}
.machine-cat__name .ja{
  display:block;font-family:"Noto Sans JP",sans-serif;font-style:normal;
  font-size:12px;letter-spacing:.18em;color:var(--yellow);font-weight:700;
  margin-top:4px;
}
@media (min-width:760px){.machine-cat__name{font-size:28px;}}

.machine-grid{display:none;}

/* ----- machine viewer (per-category visual + list) ----- */
.machine-viewer{
  display:grid;grid-template-columns:1fr;gap:18px;
  align-items:start;
}
@media (min-width:900px){
  .machine-viewer{grid-template-columns:1.3fr 1fr;gap:28px;}
}

.machine-viewer__main{
  display:flex;flex-direction:column;
  position:relative;
}
@media (min-width:900px){
  .machine-viewer__main{position:sticky;top:96px;}
}

.machine-viewer__visual{
  width:100%;
  aspect-ratio:4/3;
  background:#000;
  border:1px solid rgba(255,229,0,.25);
  position:relative;overflow:hidden;
  max-height:55vh;
}
.machine-viewer__visual::before{
  content:"";position:absolute;inset:0;
  background:repeating-linear-gradient(135deg,rgba(255,229,0,.04) 0 2px,transparent 2px 18px);
  pointer-events:none;z-index:0;
}
.machine-viewer__visual::after{
  content:attr(data-num);position:absolute;left:14px;top:12px;
  font-family:var(--font-en);font-style:italic;font-weight:800;
  color:rgba(255,229,0,.7);font-size:22px;letter-spacing:.05em;z-index:2;
  pointer-events:none;
}
.machine-viewer__visual img{
  width:100%;height:100%;object-fit:contain;background:#0a0a0a;display:block;
  position:relative;z-index:1;
  transition:opacity .25s ease,transform .5s var(--ease);
}
.machine-viewer__visual.is-changing img{opacity:.15;transform:scale(.98);}

.machine-viewer__caption{padding:16px 2px 0;}
.machine-viewer__en{
  display:block;
  font-family:var(--font-en);font-style:italic;font-weight:700;
  color:var(--yellow);font-size:11px;letter-spacing:.18em;
}
.machine-viewer__name{
  margin-top:6px;
  font-size:20px;font-weight:900;color:#fff;letter-spacing:.02em;
  display:flex;align-items:baseline;gap:10px;flex-wrap:wrap;line-height:1.3;
}
.machine-viewer__name .count{
  font-family:var(--font-en);font-style:italic;font-weight:700;
  font-size:14px;color:var(--yellow);letter-spacing:.04em;
}
.machine-viewer__desc{
  margin-top:10px;
  font-size:14px;color:var(--text-soft);line-height:1.85;
}
@media (min-width:760px){
  .machine-viewer__name{font-size:22px;}
  .machine-viewer__desc{font-size:15px;}
}

.machine-viewer__list{
  list-style:none;
  display:grid;
  grid-template-columns:repeat(2,1fr);gap:1px;
  background:rgba(255,229,0,.18);
  border:1px solid rgba(255,229,0,.22);
}
.machine-viewer__item{
  background:var(--black-2);
  padding:13px 14px;cursor:pointer;
  display:flex;align-items:center;gap:10px;
  font-size:13px;font-weight:700;color:#fff;
  letter-spacing:.02em;line-height:1.35;
  transition:background .2s ease,color .2s ease;
  user-select:none;
  min-height:46px;
}
.machine-viewer__item:hover{background:#1a1815;color:var(--yellow);}
.machine-viewer__item.is-active{background:var(--yellow);color:#000;}
.machine-viewer__item .num{
  font-family:var(--font-en);font-style:italic;font-weight:700;
  font-size:11px;color:rgba(255,229,0,.55);
  flex:none;width:22px;letter-spacing:.04em;
}
.machine-viewer__item:hover .num{color:var(--yellow);}
.machine-viewer__item.is-active .num{color:rgba(0,0,0,.55);}

/* single-machine category (D) */
.machine-viewer.is-single .machine-viewer__list{grid-template-columns:1fr;}

/* hide legacy floating preview if HTML still has it */
.machine-preview{display:none!important;}


/* ============================================================
   RECRUIT — recruit.html
   ============================================================ */
.recruit-why{padding:80px 0;background:var(--black);}
@media (min-width:900px){.recruit-why{padding:120px 0;}}

.recruit-stats{
  display:grid;grid-template-columns:repeat(2,1fr);gap:1px;
  background:rgba(255,229,0,.2);
  border:1px solid rgba(255,229,0,.25);
  margin:32px 0 28px;
}
@media (min-width:760px){.recruit-stats{grid-template-columns:repeat(4,1fr);}}
.recruit-stats__cell{
  background:var(--black-2);padding:24px 16px;text-align:center;
}
.recruit-stats__num{
  font-family:var(--font-en);font-style:italic;font-weight:800;
  color:var(--yellow);font-size:38px;line-height:1;letter-spacing:.02em;
}
.recruit-stats__num small{font-size:16px;font-style:normal;margin-left:4px;color:var(--yellow);}
.recruit-stats__label{
  font-size:11px;color:var(--text-soft);letter-spacing:.16em;font-weight:700;
  margin-top:8px;
}

.benefit-strip{
  list-style:none;display:flex;flex-wrap:wrap;gap:8px;
  margin-top:18px;
}
.benefit-strip li{
  font-size:12px;font-weight:700;letter-spacing:.04em;color:#fff;
  padding:8px 14px;
  background:#171615;
  border:1px solid rgba(255,229,0,.25);
}
@media (min-width:760px){.benefit-strip li{font-size:13px;}}

.job-openings{padding:80px 0;background:var(--black-2);}
@media (min-width:900px){.job-openings{padding:120px 0;}}

.job-list{
  display:grid;grid-template-columns:1fr;gap:24px;
  margin-top:36px;
}
@media (min-width:1100px){.job-list{gap:28px;}}

.job-card{
  background:var(--black);
  border:1px solid rgba(255,255,255,.08);
  position:relative;overflow:hidden;
  transition:border-color .25s ease,transform .25s var(--ease);
}
.job-card::before{
  content:"";position:absolute;left:0;top:0;bottom:0;width:4px;
  background:var(--yellow);
}
.job-card.neon::before{background:#FF00D4;}
.job-card:hover{border-color:rgba(255,229,0,.5);transform:translateY(-2px);}
.job-card.neon:hover{border-color:rgba(255,0,212,.5);}

.job-card__head{
  display:grid;grid-template-columns:auto 1fr;gap:16px 18px;
  align-items:center;
  padding:24px 24px 20px;
  border-bottom:1px solid rgba(255,229,0,.15);
}
@media (min-width:900px){
  .job-card__head{grid-template-columns:auto 1fr auto;padding:28px 32px 22px;}
}
.job-card__num{
  display:inline-flex;align-items:center;justify-content:center;
  width:52px;height:52px;flex:none;
  background:var(--yellow);color:#000;
  font-family:var(--font-en);font-style:italic;font-weight:800;font-size:24px;
}
.job-card.neon .job-card__num{background:#FF00D4;color:#fff;}
.job-card__title-wrap{min-width:0;}
.job-card__en{
  display:block;font-family:var(--font-en);font-style:italic;font-weight:700;
  color:var(--yellow);font-size:11px;letter-spacing:.18em;
}
.job-card.neon .job-card__en{color:#FF00D4;}
.job-card__title{
  margin-top:4px;
  font-size:20px;font-weight:900;color:#fff;letter-spacing:.02em;line-height:1.3;
}
@media (min-width:760px){.job-card__title{font-size:24px;}}

.job-card__rate{
  display:flex;flex-direction:column;align-items:flex-start;gap:4px;
  padding:14px 18px;
  background:#0a0a0a;border:1px solid rgba(255,229,0,.3);
  grid-column:1 / -1;
}
@media (min-width:900px){
  .job-card__rate{grid-column:auto;align-items:flex-end;text-align:right;min-width:220px;}
}
.job-card.neon .job-card__rate{border-color:rgba(255,0,212,.4);}
.job-card__rate-label{
  font-size:11px;color:var(--text-soft);letter-spacing:.14em;font-weight:700;
}
.job-card__rate-num{
  font-family:var(--font-en);font-style:italic;font-weight:800;
  color:var(--yellow);font-size:26px;line-height:1;letter-spacing:.01em;
}
.job-card.neon .job-card__rate-num{color:#FF00D4;}
.job-card__rate-num small{font-size:14px;margin-left:2px;color:var(--yellow);font-style:normal;}
.job-card.neon .job-card__rate-num small{color:#FF00D4;}
.job-card__rate-form{
  font-size:11px;color:#888;letter-spacing:.06em;margin-top:2px;
}

.job-card__body{
  display:grid;grid-template-columns:1fr;gap:20px;
  padding:24px;
}
@media (min-width:760px){
  .job-card__body{grid-template-columns:1fr 1fr;gap:24px 32px;padding:28px 32px;}
}
@media (min-width:1200px){
  .job-card__body{grid-template-columns:repeat(3,1fr);}
}

.job-card__sec h4{
  font-size:13px;font-weight:900;color:var(--yellow);letter-spacing:.06em;
  padding-bottom:8px;margin-bottom:10px;
  border-bottom:1px solid rgba(255,229,0,.18);
}
.job-card.neon .job-card__sec h4{color:#FF00D4;border-bottom-color:rgba(255,0,212,.3);}
.job-card__sec ul{list-style:none;display:flex;flex-direction:column;gap:6px;}
.job-card__sec li{
  font-size:13px;color:var(--text-soft);line-height:1.7;
  padding-left:14px;position:relative;
}
.job-card__sec li::before{
  content:"";position:absolute;left:0;top:.7em;width:6px;height:1px;
  background:var(--yellow);
}
.job-card.neon .job-card__sec li::before{background:#FF00D4;}
@media (min-width:760px){.job-card__sec li{font-size:14px;}}

.job-card__foot{
  padding:0 24px 24px;
}
@media (min-width:900px){.job-card__foot{padding:0 32px 28px;}}

.job-card__apply{
  display:inline-flex;align-items:center;gap:10px;
  padding:14px 24px;
  background:var(--yellow);color:#000;
  font-weight:900;font-size:13px;letter-spacing:.1em;
  border:1px solid var(--yellow);
  transition:background .2s,color .2s;
  font-family:var(--font-en);font-style:italic;
}
.job-card__apply:hover{background:transparent;color:var(--yellow);}
.job-card.neon .job-card__apply{background:#FF00D4;color:#fff;border-color:#FF00D4;}
.job-card.neon .job-card__apply:hover{background:transparent;color:#FF00D4;}
.job-card__apply i{display:inline-flex;width:14px;height:14px;}


.recruit-apply{padding:80px 0;background:var(--black);}
@media (min-width:900px){.recruit-apply{padding:120px 0;}}

.apply-grid{
  display:grid;grid-template-columns:1fr;gap:18px;
  margin-top:32px;
}
@media (min-width:900px){.apply-grid{grid-template-columns:1fr 1fr;gap:24px;}}

.apply-card{
  padding:28px 24px;
  background:var(--black-2);
  border:1px solid rgba(255,229,0,.25);
  display:flex;flex-direction:column;gap:14px;
}
.apply-card.neon{border-color:rgba(255,0,212,.4);}
.apply-card__head{display:flex;flex-direction:column;gap:6px;}
.apply-card__num{
  font-family:var(--font-en);font-style:italic;font-weight:700;
  color:var(--yellow);font-size:11px;letter-spacing:.18em;
}
.apply-card.neon .apply-card__num{color:#FF00D4;}
.apply-card__head h3{
  font-size:18px;font-weight:900;color:#fff;letter-spacing:.02em;
}
.apply-card p{font-size:14px;color:var(--text-soft);line-height:1.85;}

.apply-card__channels{display:flex;flex-direction:column;gap:10px;}

.apply-card__cta{
  display:inline-flex;align-items:center;justify-content:center;gap:10px;
  padding:14px 22px;
  background:var(--yellow);color:#000;
  font-weight:900;font-size:13px;letter-spacing:.08em;
  border:1px solid var(--yellow);
  transition:background .2s,color .2s,border-color .2s;
}
.apply-card__cta:hover{background:transparent;color:var(--yellow);}
.apply-card.neon .apply-card__cta:not(.apply-card__cta--ghost){background:#FF00D4;color:#fff;border-color:#FF00D4;}
.apply-card.neon .apply-card__cta:not(.apply-card__cta--ghost):hover{background:transparent;color:#FF00D4;}
.apply-card__cta--ghost{background:transparent;color:#fff;border-color:rgba(255,255,255,.3);}
.apply-card__cta--ghost:hover{border-color:var(--yellow);color:var(--yellow);}
.apply-card.neon .apply-card__cta--ghost:hover{border-color:#FF00D4;color:#FF00D4;}
.apply-card__cta i{display:inline-flex;width:14px;height:14px;}
.apply-card__note{font-size:12px;color:#888;line-height:1.7;}

.apply-faq{
  margin-top:36px;
  padding:24px;
  border-left:3px solid var(--yellow);
  background:#0c0c0c;
}
.apply-faq h4{
  font-size:13px;font-weight:900;color:var(--yellow);letter-spacing:.08em;
  margin-bottom:8px;
}
.apply-faq p{font-size:14px;color:var(--text-soft);line-height:1.85;}
.apply-faq a{color:var(--yellow);text-decoration:underline;}
.apply-faq a:hover{opacity:.8;}


/* ============================================================
   CONTACT — contact.html
   ============================================================ */
.contact-redirect{padding:48px 0;background:var(--black);}
@media (min-width:900px){.contact-redirect{padding:72px 0 48px;}}

.redirect-card{
  display:grid;grid-template-columns:1fr;gap:18px;
  padding:24px;
  background:linear-gradient(135deg,#0f0e0a,#1a1812);
  border:1px solid rgba(255,229,0,.5);
  position:relative;overflow:hidden;
  align-items:center;
}
.redirect-card::before{
  content:"";position:absolute;left:0;top:0;bottom:0;width:4px;
  background:var(--yellow);
}
@media (min-width:900px){
  .redirect-card{grid-template-columns:auto 1fr auto;gap:28px;padding:28px 32px;}
}

.redirect-card__icon{
  display:none;
}
@media (min-width:900px){
  .redirect-card__icon{
    display:inline-flex;align-items:center;justify-content:center;
    width:56px;height:56px;
    background:var(--yellow);color:#000;
  }
  .redirect-card__icon i{display:inline-flex;width:22px;height:22px;}
}
.redirect-card__label{
  font-family:var(--font-en);font-style:italic;font-weight:700;
  color:var(--yellow);font-size:11px;letter-spacing:.18em;margin-bottom:6px;
}
.redirect-card__body h2{
  font-size:18px;font-weight:900;color:#fff;letter-spacing:.02em;line-height:1.4;
}
@media (min-width:760px){.redirect-card__body h2{font-size:22px;}}
.redirect-card__body p{
  font-size:13px;color:var(--text-soft);line-height:1.85;margin-top:8px;
}
.redirect-card__cta{
  display:inline-flex;align-items:center;justify-content:center;gap:10px;
  padding:14px 22px;
  background:var(--yellow);color:#000;
  font-weight:900;font-size:13px;letter-spacing:.08em;
  border:1px solid var(--yellow);
  transition:background .2s,color .2s;
  font-family:var(--font-en);font-style:italic;
  white-space:nowrap;
}
.redirect-card__cta:hover{background:transparent;color:var(--yellow);}
.redirect-card__cta i{display:inline-flex;width:14px;height:14px;}


.contact-cats{padding:60px 0 80px;background:var(--black-2);}
@media (min-width:900px){.contact-cats{padding:80px 0 120px;}}

.contact-cat-grid{
  display:grid;grid-template-columns:1fr;gap:1px;
  background:rgba(255,229,0,.18);
  border:1px solid rgba(255,229,0,.22);
  margin-top:32px;
}
@media (min-width:760px){.contact-cat-grid{grid-template-columns:1fr 1fr;}}

.contact-cat{
  display:grid;grid-template-columns:auto 1fr auto;align-items:center;gap:14px;
  padding:20px 22px;
  background:var(--black);color:#fff;
  transition:background .2s ease,color .2s ease;
  position:relative;
}
.contact-cat:hover{background:#15140f;}
.contact-cat:hover .contact-cat__arrow{color:var(--yellow);transform:translateX(4px);}

.contact-cat__num{
  font-family:var(--font-en);font-style:italic;font-weight:800;
  color:rgba(255,229,0,.6);font-size:22px;letter-spacing:.04em;
  flex:none;width:36px;
}
.contact-cat__main{min-width:0;}
.contact-cat__en{
  display:block;font-family:var(--font-en);font-style:italic;font-weight:700;
  color:var(--yellow);font-size:11px;letter-spacing:.18em;
}
.contact-cat__main h3{
  margin-top:4px;
  font-size:16px;font-weight:900;color:#fff;letter-spacing:.02em;line-height:1.35;
}
.contact-cat__main p{
  margin-top:4px;
  font-size:12px;color:var(--text-soft);line-height:1.7;
}
.contact-cat__main p a{color:var(--yellow);text-decoration:underline;}
.contact-cat__arrow{
  display:inline-flex;align-items:center;justify-content:center;
  color:rgba(255,255,255,.4);
  transition:color .2s,transform .2s var(--ease);
}
.contact-cat__arrow i{display:inline-flex;width:18px;height:18px;}

.contact-cats__note{
  margin-top:24px;
  font-size:12px;color:#888;letter-spacing:.02em;line-height:1.85;
}
.contact-cats__note a{color:var(--yellow);text-decoration:underline;}


.contact-channels{padding:80px 0;background:var(--black);}
@media (min-width:900px){.contact-channels{padding:120px 0;}}

.channel-grid{
  display:grid;grid-template-columns:1fr;gap:18px;
  margin-top:32px;
}
@media (min-width:760px){.channel-grid{grid-template-columns:repeat(3,1fr);gap:24px;}}

.channel-card{
  padding:32px 24px;
  background:var(--black-2);
  border:1px solid rgba(255,229,0,.25);
  display:flex;flex-direction:column;gap:8px;
  transition:border-color .25s ease,transform .25s var(--ease);
}
.channel-card:hover{border-color:rgba(255,229,0,.5);transform:translateY(-2px);}
.channel-card__icon{
  display:inline-flex;align-items:center;justify-content:center;
  width:48px;height:48px;
  background:var(--yellow);color:#000;
  margin-bottom:8px;
}
.channel-card__icon i,.channel-card__icon svg{display:inline-flex;width:22px;height:22px;}
.channel-card__label{
  font-family:var(--font-en);font-style:italic;font-weight:700;
  color:var(--yellow);font-size:11px;letter-spacing:.18em;
}
.channel-card__main{
  display:block;
  font-family:var(--font-en);font-style:italic;font-weight:800;
  color:#fff;font-size:22px;letter-spacing:.02em;line-height:1.2;
  margin-top:2px;word-break:break-all;
}
.channel-card__main:hover{color:var(--yellow);}
.channel-card__sub{
  font-size:12px;color:var(--text-soft);line-height:1.85;margin-top:6px;
}

.contact-note{
  margin-top:32px;
  padding:18px 22px;
  background:#0c0c0c;
  border-left:3px solid var(--yellow);
}
.contact-note p{font-size:13px;color:var(--text-soft);line-height:1.85;}
.contact-note strong{color:var(--yellow);font-weight:900;}

/* ===========================================================
   FLOOR MAP — タブ切替式 3SVG マップ
   .floor-tab / .floor-tab__btn / .floor-tab__panel
   .map-zone.is-green (パワーラックエリア)
   =========================================================== */
.floor-tab{
  display:flex;flex-wrap:wrap;gap:4px;justify-content:center;
  margin:36px 0 28px;
  border-bottom:1px solid var(--line);
}
.floor-tab__btn{
  padding:14px 20px;
  background:transparent;border:0;
  color:var(--text-soft);
  font-family:var(--font-jp);font-weight:700;font-size:14px;
  cursor:pointer;
  border-bottom:3px solid transparent;
  transition:color .2s ease, border-color .2s ease, background .2s ease;
  letter-spacing:.04em;
}
@media (min-width:640px){
  .floor-tab__btn{padding:14px 28px;font-size:15px;}
}
.floor-tab__btn:hover{color:var(--yellow);background:rgba(255,229,0,.04);}
.floor-tab__btn.is-active{
  color:var(--yellow);
  border-bottom-color:var(--yellow);
}
.floor-tab__panel{display:none;}
.floor-tab__panel.is-active{display:block;animation:fadeInUp .35s ease;}

/* 緑エリア（パワーラック3台＋スミスマシン） */
.map-zone.is-green{fill:rgba(0,200,80,.10);stroke:rgba(0,200,80,.55);}
.map-zone.is-green:hover{fill:rgba(0,220,90,.20);stroke:rgba(0,230,100,.85);}
.map-zone.is-green.active{fill:rgba(0,220,90,.28);stroke:rgba(0,230,100,1);stroke-width:2;}

/* タブ周辺のリードテキストとの間隔 */
.floor-map-section .section-lead{margin-bottom:0;}
.floor-map-section .section-title{margin-bottom:14px;}
