@charset "UTF-8";

/* ==============================================
   Flying B Studio Tour 2026 — New Design
   Font: Bebas Neue (display) + Noto Sans JP (body)
============================================== */

:root {
  --bg:      #09060f;
  --bg-2:    #0d0919;
  --bg-3:    #130e21;
  --mag:     #d93bab;
  --mag-dim: rgba(217,59,171,0.12);
  --cyan:    #2dd4c8;
  --text:    #ece4ff;
  --muted:   #7a6a95;
  --danger:  #e04040;
  --bdr:     #1d1330;
  --bdr-mag: rgba(217,59,171,0.22);
}

/* --- Grain overlay --- */
body::after {
  content: '';
  position: fixed;
  inset: 0;
  z-index: 9000;
  pointer-events: none;
  opacity: 0.04;
  background-image: url("data:image/svg+xml,%3Csvg viewBox='0 0 200 200' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.85' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E");
  background-size: 120px 120px;
}

/* --- Base --- */
body {
  background: var(--bg);
  color: var(--text);
  font-family: 'Noto Sans JP', sans-serif;
  font-weight: 400;
  line-height: 1.7;
}

img { display: block; max-width: 100%; }

/* --- Layout wrapper (このページ専用の最大幅) --- */
.t-wrap {
  max-width: 860px;
  margin: 0 auto;
  padding: 0 clamp(18px, 5vw, 44px);
}

main {
  max-width: 100%;
  margin: 0;
}

/* --- Section divider --- */
hr.sec-div {
  border: none;
  height: 1px;
  background: linear-gradient(90deg, transparent, var(--bdr-mag) 25%, var(--bdr-mag) 75%, transparent);
  margin: 0;
}

/* --- Reveal animation --- */
.r {
  opacity: 0;
  transform: translateY(20px);
  transition: opacity 0.75s cubic-bezier(0.16,1,0.3,1),
              transform 0.75s cubic-bezier(0.16,1,0.3,1);
}
.r.on { opacity: 1; transform: none; }
.d1 { transition-delay: 0.08s; }
.d2 { transition-delay: 0.16s; }
.d3 { transition-delay: 0.24s; }
.d4 { transition-delay: 0.32s; }

/* --- Section label --- */
.slbl {
  font-family: 'Bebas Neue', sans-serif;
  font-size: 1.2rem;
  letter-spacing: 0.5em;
  color: var(--mag);
  display: flex;
  align-items: center;
  gap: 14px;
  margin-bottom: 32px;
}
.slbl::after {
  content: '';
  flex: 1;
  height: 1px;
  background: linear-gradient(90deg, var(--bdr-mag), transparent);
}
.slbl i { font-size: 0.75em; opacity: 0.8; }
.slbl-danger { color: var(--danger); }
.slbl-danger::after { background: linear-gradient(90deg, rgba(224,64,64,0.22), transparent); }

/* ============================================================
   TITLE BAND
============================================================ */
.title-band {
  background: var(--bg);
  border-bottom: 1px solid var(--bdr);
  padding: clamp(22px, 4vw, 36px) 0;
}
.fc-badge {
  display: inline-block;
  background: var(--mag);
  color: #fff;
  font-family: 'Bebas Neue', sans-serif;
  font-size: 0.72rem;
  letter-spacing: 0.35em;
  padding: 3px 12px 2px;
  margin-bottom: 12px;
}
.page-title {
  font-family: 'Noto Sans JP', sans-serif;
  font-size: clamp(1.05rem, 3.5vw, 1.55rem);
  font-weight: 700;
  letter-spacing: 0.06em;
  color: #fff;
  line-height: 1.45;
}

/* ============================================================
   KV
============================================================ */
.ak-kv img { width: 100%; display: block; }

/* ============================================================
   DATE & VENUE
============================================================ */
.date-section { padding: clamp(48px, 8vw, 80px) 0; background: var(--bg); }

.date-layout {
  display: grid;
  grid-template-columns: auto 1fr;
  gap: clamp(28px, 6vw, 64px);
  align-items: start;
}
@media (max-width: 560px) {
  .date-layout { grid-template-columns: 1fr; gap: 32px; }
}

.date-block {
    border-left: none;
    padding-left: 22px;
    position: relative;
  }
  .date-block::before {
    content: '';
    position: absolute;
    top: 0; left: 0;
    width: 2px;
    height: 100%;
    background: linear-gradient(to bottom, var(--mag), var(--cyan));
  }

.date-block .dm {
  font-family: 'Bebas Neue', sans-serif;
  font-size: clamp(4.5rem, 13vw, 7.5rem);
  line-height: 0.85;
  color: #fff;
  display: block;
  letter-spacing: -0.01em;
}
.date-block .wk {
  font-family: 'Bebas Neue', sans-serif;
  font-size: clamp(0.9rem, 2.5vw, 1.2rem);
  letter-spacing: 0.45em;
  color: var(--mag);
  display: block;
  margin-top: 10px;
}

.venue-block { padding-top: 6px; }
.venue-label {
  font-family: 'Bebas Neue', sans-serif;
  font-size: 0.6rem;
  letter-spacing: 0.45em;
  color: var(--muted);
  margin-bottom: 10px;
  display: block;
}
.venue-name {
  font-size: clamp(1rem, 2.5vw, 1.1rem);
  font-weight: 700;
  color: #fff;
  line-height: 1.5;
  margin-bottom: 6px;
}
.venue-name span { color: var(--muted); font-weight: 300; font-size: 0.88em; }
.venue-note { font-size: 0.8rem; color: var(--muted); }

/* --- Schedule --- */
.sch-label {
  font-family: 'Bebas Neue', sans-serif;
  font-size: 0.99rem;
  letter-spacing: 0.5em;
  color: var(--muted);
  margin: 44px 0 14px;
  display: block;
}

.ticket-row {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 6px;
}
@media (max-width: 480px) {
  .ticket-row { grid-template-columns: repeat(2, 1fr); }
}

.ticket {
  background: var(--bg-3);
  border: 1px solid var(--bdr);
  position: relative;
  overflow: hidden;
  padding: 18px 14px 16px 18px;
  transition: border-color 0.2s, background 0.2s;
}
.ticket::before {
  content: '';
  position: absolute;
  top: 0; left: 0; right: 0;
  height: 2px;
  background: var(--mag);
}
.ticket::after {
  content: '';
  position: absolute;
  top: 8px; bottom: 8px;
  left: 24px;
  border-left: 1px dashed rgba(255,255,255,0.07);
}
.ticket:hover {
  border-color: var(--bdr-mag);
  background: #18102a;
}
.t-inner { padding-left: 14px; }
.t-num {
  font-family: 'Bebas Neue', sans-serif;
  font-size: 0.75rem;
  letter-spacing: 0.45em;
  color: var(--cyan);
  display: block;
  margin-bottom: 8px;
}
.t-time {
  font-family: 'Bebas Neue', sans-serif;
  font-size: clamp(2.3rem, 5vw, 2.6rem);
  color: #fff;
  line-height: 1;
  display: block;
}
.t-dot {
  width: 4px;
  height: 4px;
  background: var(--mag);
  border-radius: 50%;
  margin-top: 10px;
  display: block;
}

.sch-note { margin-top: 12px; font-size: 0.8rem; color: var(--muted); }
.mk { color: var(--danger); }

/* ============================================================
   PRICE
============================================================ */
.price-section {
  background: var(--bg-2);
  padding: clamp(52px, 9vw, 88px) 0;
  text-align: center;
}
.price-num {
  font-family: 'Bebas Neue', sans-serif;
  font-size: clamp(5.5rem, 20vw, 10rem);
  line-height: 0.85;
  color: #fff;
  display: block;
  letter-spacing: 0.01em;
  text-shadow:
    0 0 50px rgba(217,59,171,0.4),
    0 0 100px rgba(217,59,171,0.15);
}
.price-tax {
  font-size: 0.8rem;
  color: var(--muted);
  letter-spacing: 0.2em;
  margin-top: 10px;
}
.price-notes {
  margin-top: 36px;
  display: inline-block;
  text-align: left;
  font-size: 0.84rem;
  color: var(--muted);
  line-height: 2;
}

/* ============================================================
   EVENT CONTENTS
============================================================ */
.contents-section { padding: clamp(48px, 8vw, 80px) 0; background: var(--bg); }

.contents-list {
  list-style: none;
  counter-reset: item;
  padding: 0;
}
.contents-list li {
  counter-increment: item;
  display: grid;
  grid-template-columns: 42px 1fr;
  gap: 18px;
  padding: 20px 0;
  border-bottom: 1px solid var(--bdr);
  align-items: start;
  font-size: 0.94rem;
  line-height: 1.75;
  color: var(--text);
  font-weight: normal;
}
.contents-list li:first-child { padding-top: 0; }
.contents-list li:last-child { border-bottom: none; }
.contents-list li::before {
  content: counter(item, decimal-leading-zero);
  font-family: 'Bebas Neue', sans-serif;
  font-size: 1.35rem;
  color: var(--mag);
  letter-spacing: 0.03em;
  line-height: 1;
  padding-top: 3px;
}
.contents-list li > span {
  min-width: 0;
}

/* ============================================================
   CAUTION
============================================================ */
.caution-section { padding: clamp(48px, 8vw, 80px) 0; background: var(--bg-2); }

.c-intro {
  font-size: 0.86rem;
  color: var(--muted);
  margin-bottom: 40px;
  line-height: 1.9;
}
.c-block { margin-bottom: 36px; }
.c-block:last-child { margin-bottom: 0; }
.c-head {
  font-family: 'Bebas Neue', sans-serif;
  font-size: clamp(0.85rem, 2.5vw, 1.05rem);
  letter-spacing: 0.35em;
  color: var(--danger);
  border-bottom: 1px solid rgba(224,64,64,0.18);
  padding-bottom: 8px;
  margin-bottom: 16px;
  background: transparent;
}
.c-text {
  font-size: 0.86rem;
  line-height: 2.1;
  color: var(--muted);
}
.c-text strong { color: var(--text); font-weight: 500; }

/* ============================================================
   APPLICATION
============================================================ */
.apply-section { padding: clamp(48px, 8vw, 80px) 0; background: var(--bg); }

.apply-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 2px;
  background: var(--bdr);
}
@media (max-width: 540px) {
  .apply-grid { grid-template-columns: 1fr; }
}

.a-card { background: var(--bg-3); padding: clamp(24px, 5vw, 36px); }

.a-tier {
  font-family: 'Bebas Neue', sans-serif;
  font-size: clamp(1.05rem, 2.8vw, 1.0rem);
  letter-spacing: 0.3em;
  color: var(--mag);
  margin-bottom: 22px;
  display: flex;
  align-items: center;
  gap: 10px;
  background: transparent;
}
.a-tier i { font-size: 0.75em; opacity: 0.7; }
.a-tier-reg { color: var(--cyan); }

.a-row { margin-bottom: 18px; }
.a-lbl {
  font-family: 'Bebas Neue', sans-serif;
  font-size: 0.6rem;
  letter-spacing: 0.4em;
  color: var(--muted);
  display: block;
  margin-bottom: 4px;
}
.a-val { font-size: 0.9rem; color: var(--text); font-weight: 500; }

.apply-btn {
  display: block;
  width: 100%;
  border: 1px solid var(--mag);
  background: transparent;
  color: var(--mag);
  font-family: 'Bebas Neue', sans-serif;
  font-size: 0.95rem;
  letter-spacing: 0.45em;
  padding: 14px 20px;
  cursor: pointer;
  margin-top: 22px;
  border-radius: 0;
  transition: background 0.2s, color 0.2s, box-shadow 0.25s;
}
.apply-btn:hover {
  background: var(--mag);
  color: #fff;
  box-shadow: 0 0 28px rgba(217,59,171,0.45);
}
.apply-btn-reg {
  border-color: var(--cyan);
  color: var(--cyan);
}
.apply-btn-reg:hover {
  background: var(--cyan);
  color: #09060f;
  box-shadow: 0 0 28px rgba(45,212,200,0.4);
}

.before-open {
  margin-top: 22px;
  font-size: 0.8rem;
  color: var(--muted);
  text-align: center;
  padding: 14px;
  border: 1px dashed var(--bdr);
  line-height: 1.8;
}

/* ============================================================
   CONTACT
============================================================ */
.contact-section { padding: clamp(40px, 7vw, 64px) 0; background: var(--bg-2); }

.ct-body { font-size: 0.87rem; color: var(--muted); line-height: 2.1; }
.ct-name {
  font-size: 0.95rem;
  color: var(--text);
  font-weight: 500;
  margin-bottom: 8px;
  display: block;
}
.ct-body a {
  color: var(--cyan);
  text-decoration: none;
  border-bottom: 1px solid rgba(45,212,200,0.2);
  transition: border-color 0.2s;
}
.ct-body a:hover { border-bottom-color: var(--cyan); }
