/* =========================================================
   〇〇FES 2026 — Dream Project LP  (v2: ink/brush signature)
   Energy kept, "AI-generated" gloss removed.
   One gradient only: the main ticket CTA button.
   ========================================================= */

:root{
  --ink:#0E0B0E;
  --ink-2:#120D12;
  --paper:#F2ECDE;
  --paper-2:#FAF6EA;
  --paper-ink:#1A1410;
  --red:#E8261C;
  --red-deep:#B41710;
  --orange:#FF7A18;
  --white:#FAF6EE;
  --muted:rgba(250,246,238,.62);
  --muted-2:rgba(250,246,238,.40);
  --line:rgba(250,246,238,.12);
  --line-strong:rgba(250,246,238,.22);
  --cta:linear-gradient(95deg,#FFB020,#FF6A12 52%,#E8261C);

  --maxw:1120px;
  --pad:clamp(18px,5vw,40px);
  --header-h:60px;
  --topbar-h:60px;
  --font-jp:"Zen Kaku Gothic New",-apple-system,"Hiragino Kaku Gothic ProN","Noto Sans JP",sans-serif;
  --font-num:"Anton","Zen Kaku Gothic New",sans-serif;

  --u-underline:url(brush-underline.png);
  --u-band:url(brush-band.png);
  --u-swoosh:url(brush-swoosh.png);
  --u-divider:url(ink-divider.png);
}

*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%}
body{
  font-family:var(--font-jp);background:var(--ink);color:var(--white);
  line-height:1.7;font-weight:500;letter-spacing:.01em;overflow-x:hidden;
  padding-bottom:84px;-webkit-font-smoothing:antialiased;
}
/* film grain — whisper-subtle, adapts on dark & paper */
body::after{
  content:"";position:fixed;inset:0;z-index:90;pointer-events:none;
  background:var(--u-divider);/*placeholder, overridden below*/
  background:url(grain.png) repeat;background-size:200px 200px;
  mix-blend-mode:overlay;opacity:.5;
}
a{color:inherit;text-decoration:none}
img{display:block;max-width:100%}
::selection{background:var(--red);color:#fff}

/* ---------- helpers ---------- */
.wrap{max-width:var(--maxw);margin-inline:auto;padding-inline:var(--pad)}
.num{font-family:var(--font-num);font-weight:400;line-height:.86;letter-spacing:.005em;font-feature-settings:"tnum"}
.jp-strong{font-weight:900}

/* brush emphasis: white word + red dry-brush underline */
.em{position:relative;display:inline;color:var(--white);font-weight:900;white-space:nowrap}
.em::after{content:"";position:absolute;left:-.05em;right:-.05em;bottom:-.18em;height:.34em;
  background:var(--red);
  -webkit-mask:var(--u-underline) no-repeat center/100% 100%;
  mask:var(--u-underline) no-repeat center/100% 100%;}
.em.flip::after{transform:scaleX(-1)}
/* red brush highlight band behind word */
.em--band{position:relative;display:inline-block;color:var(--white);font-weight:900;white-space:nowrap;padding:0 .16em;isolation:isolate}
.em--band::after{display:none}
.em--band::before{content:"";position:absolute;inset:-.08em -.06em;z-index:-1;
  background:var(--red);
  -webkit-mask:var(--u-band) no-repeat center/100% 100%;
  mask:var(--u-band) no-repeat center/100% 100%;}

.eyebrow{font-family:var(--font-num);letter-spacing:.22em;font-size:clamp(.72rem,2.4vw,.92rem);
  color:var(--red);text-transform:uppercase;display:inline-flex;align-items:center;gap:.6em}
.eyebrow::before{content:"";width:30px;height:2px;background:var(--red)}

/* section frame + ragged ink divider at top */
section{position:relative}
.sec{position:relative;padding-block:clamp(64px,11vw,128px)}
.sec::before{content:"";position:absolute;top:0;left:50%;transform:translateX(-50%);
  width:min(86%,1080px);height:22px;pointer-events:none;opacity:.34;
  background:var(--white);
  -webkit-mask:var(--u-divider) no-repeat center/100% 100%;
  mask:var(--u-divider) no-repeat center/100% 100%;}
.sec-head{margin-bottom:clamp(28px,5vw,52px)}
.sec-title{font-weight:900;font-size:clamp(1.9rem,7vw,3.6rem);line-height:1.12;letter-spacing:.01em;margin-top:.4em;text-wrap:balance}
.sec-sub{color:var(--muted);margin-top:1em;max-width:46ch;font-size:clamp(.95rem,2.5vw,1.05rem)}

.bg-navy{background:var(--ink-2)}
.bg-ink{background:var(--ink)}

/* paper (inverted) section */
.sec--paper{background:var(--paper);color:var(--paper-ink)}
.sec--paper::before{background:var(--paper-ink);opacity:.4}
.sec--paper .sec-title{color:var(--paper-ink)}
.sec--paper .eyebrow,.sec--paper .eyebrow::before{color:var(--red);background:var(--red)}
.sec--paper .eyebrow{background:none}
.sec--paper .em{color:var(--paper-ink)}

/* ======================= HEADER ======================= */
.header{position:fixed;top:0;left:0;right:0;z-index:100;height:var(--header-h);display:flex;align-items:center;
  background:rgba(14,11,14,.55);backdrop-filter:blur(14px) saturate(1.1);-webkit-backdrop-filter:blur(14px) saturate(1.1);
  border-bottom:1px solid var(--line);transition:background .3s}
.header .wrap{display:flex;align-items:center;gap:18px;width:100%}
.header__logo{display:flex;align-items:center;gap:10px;flex-shrink:0}
.header__logo img{height:30px;width:auto}
.header__meta{font-family:var(--font-num);letter-spacing:.08em;font-size:.74rem;color:var(--muted);display:flex;align-items:center;gap:8px;white-space:nowrap}
.header__meta b{color:var(--white)}
.header__meta .dot{width:4px;height:4px;border-radius:50%;background:var(--red)}
.header__nav{margin-left:auto;display:flex;gap:4px;align-items:center}
.header__nav a{font-size:.82rem;font-weight:700;color:var(--muted);padding:7px 12px;border-radius:6px;transition:color .2s,background .2s}
.header__nav a:hover{color:var(--white);background:rgba(250,246,238,.06)}
.header__cta{font-family:var(--font-jp);font-weight:900;font-size:.82rem;padding:9px 16px;border-radius:4px;color:#fff;background:var(--cta);white-space:nowrap}
@media(max-width:860px){.header__nav,.header__cta{display:none}.header__meta{margin-left:auto}}

/* ======================= TOP ANNOUNCEMENT BAR (instant FREE) ======================= */
.topbar{position:fixed;bottom:0;left:0;right:0;z-index:120;height:var(--topbar-h);
  display:flex;align-items:center;justify-content:center;gap:12px;
  background:linear-gradient(95deg,#FFB020,#FF6A12 52%,#E8261C);color:#fff;text-decoration:none;
  font-family:var(--font-jp);font-weight:900;font-size:clamp(.95rem,3.4vw,1.18rem);letter-spacing:.02em;
  padding:0 14px;box-shadow:0 -4px 20px rgba(0,0,0,.4);overflow:hidden}
.tb-free{position:relative;z-index:2;font-family:var(--font-num);letter-spacing:.1em;font-size:clamp(.92rem,3vw,1.18rem);
  background:#fff;color:var(--red);padding:5px 11px;border-radius:4px;line-height:1}
.tb-main{position:relative;z-index:2;white-space:nowrap}
.tb-main b{font-size:1.08em}
.tb-go{position:relative;z-index:2;white-space:nowrap;background:#fff;color:var(--red);padding:7px 16px;border-radius:99px;font-size:.92em;font-weight:900}
.topbar::after{content:"";position:absolute;inset:0;z-index:1;
  background:linear-gradient(105deg,transparent 32%,rgba(255,255,255,.4) 48%,transparent 64%);
  transform:translateX(-120%);animation:tbshine 5s ease-in-out infinite}
@keyframes tbshine{0%,55%{transform:translateX(-120%)}100%{transform:translateX(120%)}}
@media(max-width:520px){.tb-go{display:none}}
:where(section[id],footer[id]){scroll-margin-top:calc(var(--header-h) + 8px)}
body{padding-bottom:var(--topbar-h)}
@media(max-width:430px){.header__meta .hide-xs{display:none}}

/* ======================= FLOATING CTA ======================= */
.floatcta{position:fixed;left:0;right:0;bottom:0;z-index:95;
  padding:10px var(--pad) calc(10px + env(safe-area-inset-bottom));
  background:linear-gradient(180deg,rgba(14,11,14,0),rgba(14,11,14,.92) 38%);pointer-events:none;
  transition:transform .35s cubic-bezier(.4,0,.2,1),opacity .3s ease}
.floatcta.is-hidden{transform:translateY(110%);opacity:0;pointer-events:none}
.floatcta__inner{max-width:var(--maxw);margin-inline:auto;pointer-events:auto;display:flex;align-items:center;gap:14px}
.floatcta .hint{flex-shrink:0;line-height:1.15}
.floatcta .hint .from{font-family:var(--font-num);font-size:1.5rem;color:var(--white)}
.floatcta .hint .lbl{font-size:.62rem;color:var(--muted);letter-spacing:.08em;display:block}
@media(max-width:560px){.floatcta .hint{display:none}}

/* ======================= BUTTONS (only place a gradient lives) ======================= */
.btn{position:relative;display:inline-flex;align-items:center;justify-content:center;gap:.7em;flex-wrap:wrap;white-space:nowrap;
  font-family:var(--font-jp);font-weight:900;color:#fff;background:var(--cta);border:none;cursor:pointer;
  padding:18px 30px;border-radius:6px;font-size:clamp(1rem,3.4vw,1.18rem);letter-spacing:.02em;
  box-shadow:0 8px 22px -12px rgba(232,38,28,.6);
  transition:transform .18s cubic-bezier(.3,1.2,.5,1),box-shadow .25s,filter .2s;overflow:hidden;text-align:center}
.btn:hover{transform:translateY(-2px);filter:brightness(1.05);box-shadow:0 12px 30px -14px rgba(232,38,28,.7)}
.btn:active{transform:translateY(0)}
.btn .arw{font-family:var(--font-num);font-size:1.05em;transform:translateY(-1px)}
.btn--block{width:100%}
.btn--xl{padding:22px 34px;font-size:clamp(1.1rem,4vw,1.42rem);border-radius:7px}
.btn__note{flex-basis:100%;width:100%;display:block;font-size:.62rem;font-weight:600;opacity:.9;letter-spacing:.06em;margin-top:2px}
.cta-row{margin-top:clamp(28px,5vw,44px)}

/* ---- U29 free-invite CTA (hero star) ---- */
.u29{margin-top:clamp(24px,4.5vw,38px);width:100%;max-width:580px}
.u29__head{display:flex;align-items:center;gap:12px;flex-wrap:wrap;margin-bottom:14px}
.u29__badge{font-family:var(--font-num);font-size:clamp(1rem,3.2vw,1.3rem);letter-spacing:.1em;color:#fff;line-height:1;
  background:linear-gradient(95deg,#FF6A12,#E8261C);padding:6px 13px;border-radius:5px;box-shadow:0 4px 16px -6px rgba(232,38,28,.85)}
.u29__title{font-family:var(--font-jp);font-weight:900;color:#fff;line-height:1.08;letter-spacing:.01em;
  font-size:clamp(1.6rem,7vw,2.6rem);display:inline-flex;align-items:baseline;gap:.18em;flex-wrap:wrap}
.u29__title small{font-size:.42em;font-weight:700;color:var(--muted);letter-spacing:.02em}
.u29__title b{color:#FFC85A}
.btn--u29{width:100%;padding:clamp(22px,4.5vw,30px) 28px;border-radius:10px;
  font-size:clamp(1.35rem,6.2vw,2rem);letter-spacing:.02em;
  background:linear-gradient(95deg,#FFB020,#FF6A12 50%,#E8261C);
  box-shadow:0 16px 40px -12px rgba(232,38,28,.7);animation:u29pulse 2.4s ease-in-out infinite}
.btn--u29:hover{filter:brightness(1.06)}
.btn--u29 .btn__note{font-size:clamp(.66rem,2vw,.78rem);margin-top:6px;opacity:.95}
.btn--u29 .arw{font-size:1.1em}
@keyframes u29pulse{0%,100%{box-shadow:0 16px 40px -14px rgba(232,38,28,.5)}50%{box-shadow:0 16px 52px -8px rgba(255,150,30,.9)}}
.u29__note{font-family:var(--font-jp);font-weight:600;color:var(--muted);margin-top:11px;
  font-size:clamp(.7rem,2.1vw,.8rem);letter-spacing:.01em}
.u29__pia{display:inline-block;margin-top:14px;font-family:var(--font-jp);font-weight:700;
  font-size:clamp(.84rem,2.4vw,.95rem);color:var(--muted);text-decoration:underline;text-underline-offset:3px;transition:color .2s}
.u29__pia:hover{color:#fff}
.cta-band{display:flex;flex-direction:column;align-items:center;gap:10px;text-align:center}
.cta-band .kick{font-size:.85rem;color:var(--muted);letter-spacing:.04em}
.sec--paper .cta-band .kick{color:rgba(26,20,16,.6)}

/* ======================= HERO ======================= */
.hero{position:relative;overflow:hidden;min-height:100svh;padding-top:calc(var(--header-h) + 24px);display:flex;align-items:center;background:var(--ink)}
.hero__art{position:absolute;inset:0;background:url(hero-fes.jpg) no-repeat;background-size:cover;background-position:66% 12%}
@media(min-width:760px){.hero__art{background-position:58% 22%}}
/* bright festival art: veil deepens text-left + header + bottom so white copy and the CTA stay legible while the twin円相 motif stays vivid */
.hero__scrim{position:absolute;inset:0;background:
  linear-gradient(90deg,rgba(14,11,14,.82) 0%,rgba(14,11,14,.6) 26%,rgba(14,11,14,.24) 50%,rgba(14,11,14,0) 72%),
  linear-gradient(180deg,rgba(14,11,14,.62) 0%,rgba(14,11,14,.12) 16%,rgba(14,11,14,0) 46%,rgba(14,11,14,.74) 82%,#0E0B0E 100%)}
/* SMARTPHONE: vertical festival key-visual (∞ motif + crowd). Center is bright,
   so the veil ramps darker through the copy band while the ∞ glows at top. */
@media(max-width:759px){
  .hero__art{background-image:url(hero-fes-mobile.jpg);background-position:50% 16%}
  .hero__scrim{background:
    linear-gradient(180deg,
      rgba(14,11,14,.28) 0%,
      rgba(14,11,14,.4) 22%,
      rgba(14,11,14,.6) 46%,
      rgba(14,11,14,.78) 72%,
      rgba(14,11,14,.92) 88%,
      #0E0B0E 100%),
    linear-gradient(90deg,rgba(14,11,14,.55) 0%,rgba(14,11,14,.18) 52%,rgba(14,11,14,0) 100%)}
}
.hero__embers{position:absolute;inset:0;overflow:hidden;pointer-events:none}
.ember{position:absolute;bottom:-12px;width:5px;height:5px;border-radius:50%;
  background:radial-gradient(circle,#FFC98a,#FF6a1a 60%,transparent 72%);filter:blur(.4px);opacity:0;animation:rise linear infinite}
@keyframes rise{0%{transform:translateY(0) scale(.7);opacity:0}14%{opacity:.55}82%{opacity:.4}100%{transform:translateY(-84vh) translateX(var(--drift,16px)) scale(1);opacity:0}}
.hero__inner{position:relative;z-index:3;width:100%;text-shadow:0 2px 22px rgba(8,6,8,.55),0 1px 4px rgba(8,6,8,.4)}
.hero__eyebrow{margin-bottom:clamp(16px,3vw,26px)}
.hero__copy{font-weight:900}
.lead-line{display:flex;align-items:baseline;flex-wrap:wrap;gap:.06em .12em;font-size:clamp(1.5rem,6.6vw,3rem);line-height:1.05;letter-spacing:.01em}
.lead-line .num{font-size:clamp(3rem,15vw,7rem);transform:translateY(.06em);color:var(--white)}
.huge-line{display:flex;align-items:flex-end;gap:.04em;margin-top:clamp(10px,2.4vw,30px);flex-wrap:wrap}
.huge-line .pre{font-size:clamp(1.5rem,6vw,2.8rem);line-height:1;padding-bottom:.45em;letter-spacing:.02em}
.huge-line .num{font-size:clamp(7rem,33vw,17rem);color:var(--white)}
.huge-line .suf{font-size:clamp(2.4rem,11vw,6rem);line-height:1;padding-bottom:.18em;font-weight:900}
.huge5{position:relative}
.hero__sub{font-size:clamp(1.05rem,3.6vw,1.5rem);font-weight:700;margin-top:clamp(14px,2.5vw,22px);line-height:1.45}
.hero__pull{color:var(--muted);font-size:clamp(.95rem,2.8vw,1.12rem);margin-top:.7em;font-weight:600}
.hero__meta{display:flex;flex-wrap:wrap;gap:8px 12px;align-items:center;margin-top:clamp(22px,4vw,34px);font-family:var(--font-num);letter-spacing:.06em;font-size:clamp(.82rem,2.6vw,1rem)}
.hero__meta .chip{display:inline-flex;align-items:center;gap:8px;padding:8px 14px;border:1px solid var(--line-strong);border-radius:4px;background:rgba(14,11,14,.35)}
.hero__meta .chip b{color:var(--orange)}

/* count-up figures: tabular to limit reflow while ticking */
[data-count]{font-variant-numeric:tabular-nums}

/* countdown */
.countdown{display:inline-flex;align-items:center;gap:clamp(10px,2vw,18px);margin-top:clamp(18px,3vw,26px);
  padding:12px 18px;border:1px solid var(--line-strong);border-radius:8px;background:rgba(14,11,14,.5);
  -webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px)}
.cd__lbl{font-family:var(--font-jp);font-weight:900;font-size:clamp(.74rem,2.4vw,.86rem);letter-spacing:.06em;color:var(--orange);white-space:nowrap}
.cd__units{display:flex;align-items:flex-start;gap:clamp(6px,1.4vw,10px)}
.cd__u{display:flex;flex-direction:column;align-items:center;min-width:clamp(40px,9vw,52px)}
.cd__n{font-family:var(--font-num);font-size:clamp(1.5rem,5.4vw,2.2rem);line-height:1;color:var(--white);font-variant-numeric:tabular-nums;letter-spacing:.02em}
.cd__k{font-size:clamp(.5rem,1.5vw,.58rem);letter-spacing:.14em;color:var(--muted);font-weight:700;margin-top:5px}
.cd__sep{font-family:var(--font-num);font-size:clamp(1.1rem,3.4vw,1.6rem);line-height:1;color:var(--muted-2);transform:translateY(.04em);animation:cdblink 1s steps(1) infinite}
.countdown.is-live .cd__lbl{color:var(--red)}
@keyframes cdblink{50%{opacity:.25}}
@media(max-width:420px){.countdown{gap:8px;padding:10px 12px}}

/* hero FREE callout — 29歳以下 入場無料 */
.hero__free{display:inline-flex;align-items:center;gap:14px;flex-wrap:wrap;margin-top:clamp(18px,3vw,26px);
  padding:9px 18px 9px 9px;border-radius:9px;background:rgba(232,38,28,.16);border:1.5px solid rgba(232,38,28,.6);
  -webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px);box-shadow:0 10px 30px -16px rgba(232,38,28,.85);
  animation:freepulse 2.6s ease-in-out infinite}
.ff-badge{font-family:var(--font-num);font-size:clamp(1rem,3vw,1.25rem);letter-spacing:.08em;color:#fff;
  background:var(--red);padding:8px 13px;border-radius:6px;line-height:1;flex-shrink:0}
.ff-text{font-weight:900;font-size:clamp(1.05rem,3.8vw,1.45rem);line-height:1.18;color:#fff}
.ff-text b{color:#FFC85A}
.ff-note{display:block;font-family:var(--font-jp);font-size:clamp(.66rem,2vw,.74rem);font-weight:600;color:var(--muted);letter-spacing:.01em;margin-top:4px}
@keyframes freepulse{0%,100%{box-shadow:0 10px 30px -16px rgba(232,38,28,.85)}50%{box-shadow:0 12px 38px -12px rgba(232,38,28,1)}}

/* flow diagram — solid colors, no glow */
.flow{margin-top:clamp(26px,4.5vw,40px);display:grid;gap:12px;grid-template-columns:1fr}
.flow__node{position:relative;border:1px solid var(--line);border-radius:4px;background:rgba(250,246,238,.03);padding:16px 18px;display:flex;align-items:center;gap:16px;overflow:hidden}
.flow__node::before{content:"";position:absolute;left:0;top:0;bottom:0;width:4px;background:var(--red)}
.flow__node .fn{font-family:var(--font-num);font-size:clamp(2.4rem,9vw,3.4rem);line-height:.85;flex-shrink:0;color:var(--white)}
.flow__node .ft{line-height:1.3}
.flow__node .ft .k{font-family:var(--font-num);letter-spacing:.14em;font-size:.68rem;color:var(--red);display:block;margin-bottom:2px}
.flow__node .ft .d{font-size:.9rem;font-weight:700}
.flow__node .ft .s{font-size:.78rem;color:var(--muted);font-weight:500}
.flow__arrow{justify-self:center;color:var(--red);font-family:var(--font-num);font-size:1.3rem;line-height:.5;transform:rotate(90deg);opacity:.85}
@media(min-width:760px){.flow{grid-template-columns:1fr auto 1fr auto 1fr;align-items:stretch}
  .flow__arrow{transform:none;align-self:center}
  .flow__node{flex-direction:column;text-align:center;gap:8px;justify-content:center}}

/* ======================= EVENT CONTENT ======================= */
.pillars{display:grid;gap:20px;grid-template-columns:1fr}
@media(min-width:720px){.pillars{grid-template-columns:repeat(3,1fr);gap:0}}
/* break uniformity: open card + two ink-washed cards, varied padding */
.pillar{position:relative;padding:26px 4px 8px;background:none;border:none}
@media(min-width:720px){.pillar{padding:30px 26px 18px}}
.pillar .pno{font-family:var(--font-num);font-size:2.2rem;color:var(--red);line-height:1;display:block;margin-bottom:12px;opacity:.92}
.pillar h3{font-size:1.12rem;font-weight:900;line-height:1.45;margin-bottom:10px;text-wrap:balance}
.pillar p{font-size:.9rem;color:var(--muted);font-weight:500}
.pillar.is-dp{background:rgba(232,38,28,.07);border-left:3px solid var(--red);padding:26px 22px 22px;border-radius:0 4px 4px 0}
.pillar .tag{display:inline-block;font-family:var(--font-num);font-size:.6rem;letter-spacing:.16em;color:var(--red);border:1px solid rgba(232,38,28,.5);border-radius:3px;padding:3px 9px;margin-bottom:14px}

/* dreampro spotlight — flat, no glow */
.dp{margin-top:30px;border:1px solid var(--line);border-top:3px solid var(--red);border-radius:4px;overflow:hidden;background:var(--ink-2)}
.dp__top{padding:clamp(26px,5vw,44px);display:grid;gap:clamp(20px,4vw,40px);align-items:center;grid-template-columns:1fr}
@media(min-width:820px){.dp__top{grid-template-columns:auto 1fr}}
.dp__stat{text-align:center;flex-shrink:0}
.dp__stat .k{font-family:var(--font-num);letter-spacing:.2em;font-size:.7rem;color:var(--red);display:block;margin-bottom:6px}
.dp__odds{display:flex;align-items:baseline;justify-content:center;gap:.06em;font-weight:900}
.dp__odds .big{font-family:var(--font-num);font-size:clamp(4.4rem,18vw,8.5rem);line-height:.8;color:var(--red)}
.dp__odds .of{font-family:var(--font-num);font-size:clamp(1.6rem,6vw,2.6rem);color:var(--muted-2);padding:0 .15em}
.dp__odds .sm{font-family:var(--font-num);font-size:clamp(2.6rem,10vw,4.6rem);line-height:.8;color:var(--white)}
.dp__stat .cap{font-size:.82rem;color:var(--muted);margin-top:10px;font-weight:600}
.dp__txt h3{font-size:clamp(1.3rem,4.4vw,1.9rem);font-weight:900;line-height:1.4;margin-bottom:.6em;text-wrap:balance}
.dp__txt p{color:var(--muted);font-size:.96rem;font-weight:500}
.dp__steps{border-top:1px solid var(--line);display:grid;grid-template-columns:1fr}
@media(min-width:720px){.dp__steps{grid-template-columns:repeat(4,1fr)}}
.dp__step{padding:20px 22px;border-top:1px solid var(--line)}
@media(min-width:720px){.dp__step{border-top:none;border-left:1px solid var(--line)}.dp__step:first-child{border-left:none}}
.dp__step .sn{font-family:var(--font-num);font-size:1rem;color:var(--red);letter-spacing:.1em}
.dp__step .sh{font-weight:900;font-size:1rem;margin:6px 0 4px}
.dp__step .sd{font-size:.82rem;color:var(--muted);font-weight:500}

/* ======================= DREAMS — どんな夢でもいい ======================= */
.dreams__grid{display:grid;gap:clamp(10px,1.6vw,16px);grid-template-columns:repeat(2,1fr);margin-top:clamp(8px,2vw,18px)}
@media(min-width:760px){.dreams__grid{grid-template-columns:repeat(3,1fr)}}
.dcard{position:relative;border:1px solid var(--line);border-radius:4px;overflow:hidden;background:var(--ink-2);aspect-ratio:1/1.2;display:flex;align-items:flex-end}
.dcard__img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;object-position:center 30%}
.dcard::after{content:"";position:absolute;inset:0;
  background:linear-gradient(180deg,rgba(14,11,14,.04) 22%,rgba(14,11,14,.5) 58%,rgba(14,11,14,.94) 100%)}
.dcard__body{position:relative;z-index:2;padding:clamp(15px,2.4vw,24px)}
.dcard__body h3{font-size:clamp(1.02rem,3.2vw,1.45rem);font-weight:900;line-height:1.24;color:var(--white);letter-spacing:.01em;text-shadow:0 2px 14px rgba(8,6,8,.55)}
.dcard__body p{margin-top:.5em;font-size:clamp(.72rem,1.9vw,.85rem);font-weight:600;line-height:1.5;color:rgba(250,246,238,.85);text-shadow:0 1px 10px rgba(8,6,8,.5)}
/* emphasized closing card — flat red veil over distant lanterns; no border-glow */
.dcard--cap{border-color:var(--red-deep);align-items:center;justify-content:center;text-align:center}
.dcard--cap .dcard__img{object-position:center;opacity:.9}
.dcard--cap::after{background:rgba(184,23,16,.82)}
.dcard--cap .dcard__body h3{font-size:clamp(1.14rem,3.6vw,1.62rem);text-shadow:0 2px 16px rgba(80,6,4,.6)}
.dcard--cap .dcard__body p{color:rgba(255,255,255,.88);text-shadow:none;margin-top:.6em}
/* center-aligned section header */
#dreams .sec-head{text-align:center}
#dreams .sec-sub{margin-inline:auto;max-width:52ch}
.sub-br{display:none}
@media(min-width:680px){.sub-br{display:inline}}
.dreams__close{margin:clamp(30px,5vw,48px) auto 0;text-align:center;font-weight:900;
  font-size:clamp(1.18rem,4vw,1.75rem);line-height:1.5;text-wrap:balance;max-width:30ch}
.dreams__close .dl-1,.dreams__close .dl-2{display:block}
.dreams__close .dl-2 .ph{display:inline-block}
.dreams__close .dl-1{color:var(--muted);font-size:.82em;font-weight:800;margin-bottom:.35em}
.dreams__note{margin:1.1em auto 0;text-align:center;font-size:.8rem;color:var(--muted);font-weight:500}
.dreams__note::before{content:"※ ";color:var(--red)}

/* ======================= TICKETS (paper) — stub motif ======================= */
.tix{display:grid;gap:30px 18px;grid-template-columns:1fr}
@media(min-width:760px){.tix{grid-template-columns:repeat(3,1fr)}}
.tcard{position:relative;background:var(--paper-2);color:var(--paper-ink);border:1.5px solid var(--paper-ink);border-radius:3px;padding:26px 24px 24px;display:flex;flex-direction:column;overflow:visible}
.tcard .tname{font-family:var(--font-num);letter-spacing:.08em;font-size:1.15rem;color:var(--paper-ink)}
.tcard .tjp{font-size:.78rem;color:rgba(26,20,16,.6);font-weight:700;margin-bottom:12px}
.tcard .tprice{display:flex;align-items:baseline;gap:.12em;font-weight:900;margin-bottom:2px}
.tcard .tprice .cur{font-family:var(--font-num);font-size:1.4rem;color:var(--red)}
.tcard .tprice .amt{font-family:var(--font-num);font-size:clamp(2.6rem,9vw,3.4rem);line-height:.9;color:var(--paper-ink)}
.tcard .ttax{font-size:.72rem;color:rgba(26,20,16,.5)}
/* perforation + punched notches */
.tcard .perf{position:relative;height:0;border-top:2px dashed rgba(26,20,16,.4);margin:18px 0}
.tcard .perf::before,.tcard .perf::after{content:"";position:absolute;top:-13px;width:24px;height:24px;border-radius:50%;background:var(--paper)}
.tcard .perf::before{left:-36px}
.tcard .perf::after{right:-36px}
.tcard .tbtn{margin-top:2px}
/* premium = inverted ink stub */
.tcard.is-premium{background:var(--ink);color:var(--white);border-color:var(--ink)}
.tcard.is-premium .tname{color:var(--white)}
.tcard.is-premium .tjp{color:var(--muted)}
.tcard.is-premium .tprice .amt{color:var(--white)}
.tcard.is-premium .ttax{color:var(--muted)}
.tcard.is-premium .perf{border-color:rgba(250,246,238,.35)}
.tcard .flag{position:absolute;top:-11px;right:16px;font-family:var(--font-num);font-size:.6rem;letter-spacing:.14em;color:#fff;background:var(--red);padding:5px 11px;border-radius:2px}
/* U29 = free: red-accented stub */
.tcard.is-free{border-color:var(--red);box-shadow:0 0 0 4px rgba(232,38,28,.10)}
.tcard.is-free .tname{color:var(--red)}
.tprice--free{align-items:flex-end}
.tcard .tprice--free .amt--free{font-family:var(--font-num);font-size:clamp(3rem,11vw,4rem);line-height:.82;color:var(--red);letter-spacing:.02em}
.tix-notes{margin-top:30px;display:grid;gap:6px}
.tix-notes li{list-style:none;font-size:.8rem;color:rgba(26,20,16,.6);padding-left:1.2em;position:relative;font-weight:500}
.tix-notes li::before{content:"※";position:absolute;left:0;color:var(--red)}

/* ======================= PERFORMERS — editorial, borderless ======================= */
.cat{margin-top:clamp(34px,5vw,52px)}
.cat:first-of-type{margin-top:clamp(20px,3vw,28px)}
.cat__head{display:flex;align-items:center;gap:14px;margin-bottom:18px}
.cat__head h3{font-family:var(--font-num);letter-spacing:.16em;font-size:clamp(1.1rem,4vw,1.5rem)}
.cat__head .line{flex:1;height:2px;background:var(--white);opacity:.28;
  -webkit-mask:var(--u-divider) no-repeat center/100% 100%;mask:var(--u-divider) no-repeat center/100% 100%}
.cat__head .n{font-family:var(--font-num);font-size:.8rem;color:var(--red)}
.grid{display:grid;gap:12px;grid-template-columns:repeat(2,1fr);grid-auto-flow:dense}
@media(min-width:560px){.grid{grid-template-columns:repeat(3,1fr)}}
@media(min-width:880px){.grid{grid-template-columns:repeat(4,1fr)}}
.pf{position:relative;display:block;overflow:hidden;border-radius:2px;background:#141019;transition:transform .25s}
.pf:hover{transform:translateY(-3px)}
.pf__img{aspect-ratio:4/5;width:100%;object-fit:cover;background:#141019;transition:transform .5s,filter .4s;filter:saturate(.96)}
.pf:hover .pf__img{transform:scale(1.04)}
/* one feature card spans 2 columns (wide editorial) */
.pf--wide{grid-column:span 2}
.pf--wide .pf__img{aspect-ratio:16/10}
.pf--wide .pf__cap .nm{font-size:1.15rem}
.pf__blank{aspect-ratio:4/5;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:8px;
  background:repeating-linear-gradient(135deg,#161019 0 10px,#120d15 10px 20px)}
.pf__blank .ico{font-family:var(--font-num);font-size:1.7rem;color:rgba(232,38,28,.7)}
.pf__blank .soon{font-family:var(--font-num);font-size:.58rem;letter-spacing:.2em;color:var(--muted-2)}
.pf__cap{position:absolute;left:0;right:0;bottom:0;padding:28px 12px 11px;background:linear-gradient(180deg,transparent,rgba(14,11,14,.92));display:flex;align-items:flex-end;justify-content:space-between;gap:8px}
.pf__cap .nm{font-weight:900;font-size:.92rem;line-height:1.2;text-wrap:balance}
.pf__cap .ig{flex-shrink:0;width:26px;height:26px;border-radius:6px;display:grid;place-items:center;border:1px solid var(--line-strong);background:rgba(0,0,0,.3);transition:background .2s,border-color .2s}
.pf:hover .pf__cap .ig{background:var(--red);border-color:transparent}
.pf__cap .ig svg{width:14px;height:14px;fill:#fff}
.pf.is-blank .pf__cap{background:linear-gradient(180deg,transparent,rgba(14,11,14,.7))}

/* ======================= TIMETABLE ======================= */
.tt-meta{display:flex;flex-wrap:wrap;gap:10px 14px;margin-bottom:30px;font-family:var(--font-num);letter-spacing:.06em;font-size:.86rem}
.tt-meta .chip{display:inline-flex;gap:8px;align-items:center;padding:8px 14px;border:1px solid var(--line-strong);border-radius:4px}
.tt-meta .chip b{color:var(--orange)}
.timeline{position:relative;max-width:680px;margin-inline:auto;padding-left:8px}
.timeline::before{content:"";position:absolute;left:64px;top:8px;bottom:8px;width:2px;background:linear-gradient(180deg,var(--red),rgba(180,23,16,.2))}
.tl{position:relative;display:grid;grid-template-columns:56px 1fr;gap:22px;padding:14px 0;align-items:baseline}
.tl .tm{font-family:var(--font-num);font-size:1.15rem;text-align:right;color:var(--white);letter-spacing:.02em}
.tl::after{content:"";position:absolute;left:58px;top:20px;width:14px;height:14px;border-radius:50%;background:var(--ink);border:3px solid var(--red)}
.tl .body{padding-left:6px}
.tl .body h4{font-weight:900;font-size:1.05rem;letter-spacing:.02em}
.tl .body p{font-size:.84rem;color:var(--muted);font-weight:500}
.tl.is-key .tm{color:var(--red)}
.tl.is-key::after{background:var(--red);border-color:transparent;width:18px;height:18px;left:56px}
.tl.is-key .body h4{font-family:var(--font-num);font-size:clamp(1.2rem,5vw,1.7rem);letter-spacing:.08em}
.tt-note{text-align:center;margin-top:24px;font-size:.78rem;color:var(--muted-2)}

/* ======================= FINAL CTA ======================= */
.finalcta{position:relative;overflow:hidden;background:var(--ink);
  padding-block:clamp(64px,12vw,120px);text-align:center;border-top:1px solid var(--line)}
.finalcta__art{position:absolute;inset:0;background:url(hero-fes-mobile.jpg) no-repeat;background-size:cover;background-position:50% 30%;opacity:.55}
@media(min-width:760px){.finalcta__art{background-image:url(hero-fes.jpg);background-position:50% 26%}}
.finalcta__scrim{position:absolute;inset:0;background:
  radial-gradient(120% 90% at 50% 40%,rgba(14,11,14,.5),rgba(14,11,14,.84) 70%,#0E0B0E 100%)}
.finalcta__inner{position:relative;z-index:2;display:flex;flex-direction:column;align-items:center;gap:clamp(14px,2.4vw,20px)}
.fc-kick{font-family:var(--font-num);letter-spacing:.14em;font-size:clamp(.74rem,2.4vw,.9rem);color:var(--orange)}
.fc-head{font-weight:900;font-size:clamp(1.9rem,7vw,3.4rem);line-height:1.18;letter-spacing:.01em;color:var(--white);text-shadow:0 2px 20px rgba(8,6,8,.5)}
.fc-head .fc-em{background:linear-gradient(176deg,#FFF0B8 0%,#FFC24D 46%,#FF9128 76%,#FF6A1E 100%);
  -webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent;color:transparent}
.fc-sub{max-width:34em;font-size:clamp(.95rem,2.8vw,1.12rem);line-height:1.75;color:var(--muted);font-weight:500}
.fc-sub b{color:#FFC85A;font-weight:900}
.fc-btn{margin-top:clamp(8px,1.5vw,14px)}

/* ======================= FOOTER ======================= */
.footer{position:relative;background:var(--ink-2);border-top:1px solid var(--line);padding-block:clamp(48px,8vw,76px)}
.foot-grid{display:grid;gap:34px;grid-template-columns:1fr}
@media(min-width:760px){.foot-grid{grid-template-columns:1.3fr 1fr}}
.foot-venue h3{font-family:var(--font-num);letter-spacing:.12em;font-size:1.1rem;margin-bottom:12px}
.foot-venue .vn{font-weight:900;font-size:1.15rem;margin-bottom:4px}
.foot-venue .ad{color:var(--muted);font-size:.9rem;font-weight:500}
.foot-venue .ax{color:var(--muted-2);font-size:.82rem;margin-top:6px;font-weight:500}
.foot-venue .map{margin-top:16px;display:inline-flex;align-items:center;gap:8px;font-weight:700;font-size:.86rem;color:var(--orange);border-bottom:1px solid rgba(255,122,24,.4);padding-bottom:2px}
.foot-venue .map:hover{color:var(--white);border-color:var(--white)}
.acc{border:1px solid var(--line);border-radius:4px;overflow:hidden;background:rgba(250,246,238,.02)}
.acc summary{cursor:pointer;list-style:none;padding:16px 18px;font-weight:800;font-size:.92rem;display:flex;align-items:center;justify-content:space-between;gap:10px}
.acc summary::-webkit-details-marker{display:none}
.acc summary .pm{font-family:var(--font-num);color:var(--red);font-size:1.2rem;transition:transform .25s}
.acc[open] summary .pm{transform:rotate(45deg)}
.acc__body{padding:0 18px 18px}
.acc[open] .acc__body{max-height:min(58vh,520px);overflow-y:auto;-webkit-overflow-scrolling:touch}
.acc__lead{font-size:.84rem;color:var(--muted);font-weight:600;line-height:1.6;padding:14px 0 4px}
.acc__h{font-size:.72rem;font-weight:800;letter-spacing:.12em;color:var(--orange);text-transform:uppercase;margin:18px 0 2px;padding-top:14px;border-top:1px solid var(--line)}
.acc__body li{list-style:none;font-size:.84rem;color:var(--muted);padding:7px 0 7px 1.3em;position:relative;border-top:1px solid var(--line);font-weight:500;line-height:1.55}
.acc__body li:first-child{border-top:none}
.acc__h + ul li:first-child{border-top:none}
.acc__body li::before{content:"—";position:absolute;left:0;color:var(--red)}
.acc__contact{margin-top:20px;padding-top:16px;border-top:1px solid var(--line)}
.acc__contact .acc__ct{display:inline-block;font-size:.72rem;font-weight:800;letter-spacing:.12em;color:var(--orange);text-transform:uppercase;margin-bottom:8px}
.acc__contact p{font-size:.86rem;color:var(--white);font-weight:700}
.acc__contact a{display:inline-block;margin-top:4px;font-size:.86rem;color:var(--orange);border-bottom:1px solid rgba(255,122,24,.4);padding-bottom:2px;font-weight:600}
.acc__contact a:hover{color:var(--white);border-color:var(--white)}
.foot-bottom{margin-top:42px;padding-top:26px;border-top:1px solid var(--line);display:flex;flex-wrap:wrap;gap:20px;align-items:center;justify-content:space-between}
.foot-bottom .sns{display:flex;gap:10px}
.sns a{width:40px;height:40px;border-radius:6px;display:grid;place-items:center;border:1px solid var(--line-strong);transition:background .2s,border-color .2s,transform .2s}
.sns a:hover{background:var(--red);border-color:transparent;transform:translateY(-2px)}
.sns svg{width:18px;height:18px;fill:var(--white)}
.foot-bottom .handle{font-family:var(--font-num);letter-spacing:.08em;color:var(--muted);font-size:.84rem}
.foot-credit{margin-top:24px;color:var(--muted-2);font-size:.74rem;line-height:1.8}
.foot-credit .cr{font-family:var(--font-num);letter-spacing:.06em}

/* ======================= SCROLL ANIM ======================= */
.reveal{opacity:0;transform:translateY(24px);transition:opacity .8s cubic-bezier(.2,.7,.2,1),transform .8s cubic-bezier(.2,.7,.2,1)}
.reveal.in{opacity:1;transform:none}
.reveal.s1{transition-delay:.08s}.reveal.s2{transition-delay:.16s}.reveal.s3{transition-delay:.24s}
.reveal.s4{transition-delay:.32s}.reveal.s5{transition-delay:.4s}
.pop{opacity:0;transform:scale(.9);transition:opacity .7s,transform .7s cubic-bezier(.2,1.2,.4,1)}
.pop.in{opacity:1;transform:none}
@media(prefers-reduced-motion:reduce){.reveal,.pop{opacity:1;transform:none;transition:none}.ember,.cd__sep,.hero__free,.topbar::after{animation:none}html{scroll-behavior:auto}}

/* ======================= MOBILE TYPE FIT =======================
   On phones, shrink short headings so 1-line titles don't wrap to
   2 lines. Long paragraphs (sec-sub / fc-sub) keep wrapping. */
@media(max-width:560px){
  .sec-title{font-size:clamp(1.3rem,6.2vw,1.7rem)}
  .fc-head{font-size:clamp(1.45rem,6.8vw,1.9rem)}
  .dreams__close{font-size:clamp(1.06rem,4.4vw,1.4rem)}
}
