:root{
    --ink:#161616;
    --ink-soft:#4a4a4a;
    --white:#ffffff;
    --yellow:#ffd200;
    --yellow-deep:#d9ac00;
    --line:rgba(23,20,17,.16);
    --mincho:"Inter", "Noto Sans JP", sans-serif;
    --goth:"Inter", "Noto Sans JP", sans-serif;
    --latin:"Inter", sans-serif;
  }
  *{margin:0;padding:0;box-sizing:border-box}
  html{scroll-behavior:smooth}
  body{
    font-family:var(--goth);font-weight:400;
    background:var(--yellow);color:var(--ink);
    line-height:1.95;letter-spacing:normal;overflow-x:hidden;
    -webkit-font-smoothing:antialiased;
  }
  ::selection{background:var(--ink);color:var(--yellow)}
  a{color:inherit;text-decoration:none}
  .wrap{max-width:1140px;margin:0 auto;padding:0 32px}
  .logo{display:block;height:auto;width:auto}
  .brand .logo{height:32px;width:128px;color:var(--yellow);transition:color .35s ease}
  header.scrolled .brand .logo{color:var(--ink)}
  .hero .lockup .logo{height:30px;width:120px;color:var(--white)}
  footer .logo{height:56px;width:auto;color:var(--ink)}

  /* filmic grain */
  .grain{position:fixed;inset:0;z-index:999;pointer-events:none;opacity:.05;mix-blend-mode:multiply;
    background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='140' height='140'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.85' numOctaves='2' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E")}

  /* eyebrow / labels */
  .kicker{font-family:var(--latin);font-size:13px;letter-spacing:.18em;text-transform:uppercase;color:var(--ink-soft)}
  .nt{font-family:var(--goth);letter-spacing:normal}

  /* logo mark */
  .mark{display:inline-flex;flex-direction:column;align-items:center;gap:5px;color:currentColor}
  .mark .screen{border:2.5px solid currentColor;border-radius:3px;padding:4px 11px 3px;display:flex;align-items:center;justify-content:center;line-height:1}
  .mark .screen b{font-family:var(--latin);font-weight:600;letter-spacing:1px}
  .mark .seats{display:flex;gap:5px}
  .mark .seats i{display:block;width:12px;height:9px;background:currentColor;border-radius:4px 4px 1px 1px}
  .z{display:inline-block;vertical-align:-0.1em;height:.86em;width:.72em;margin-right:.06em}

  /* intro splash */
  .intro{position:fixed;inset:0;z-index:2000;display:flex;align-items:center;justify-content:center;pointer-events:none}
  .intro .curtain{position:absolute;top:0;bottom:0;width:50.5%;background:var(--yellow);z-index:1;transition:transform .9s cubic-bezier(.76,0,.24,1)}
  .intro .curtain-l{left:0}
  .intro .curtain-r{right:0}
  .intro .logo-intro{position:relative;z-index:2;transition:opacity .45s ease}
  .intro.open .curtain-l{transform:translateX(-100%)}
  .intro.open .curtain-r{transform:translateX(100%)}
  .intro.logo-out .logo-intro{animation:none;opacity:0}
  .intro .logo-intro{width:clamp(220px,34vw,440px);height:auto;color:var(--ink)}
  @keyframes introIn{from{opacity:0;transform:scale(.94)}to{opacity:1;transform:none}}
  @keyframes introOut{to{opacity:0;visibility:hidden}}
  @media(prefers-reduced-motion:reduce){.intro{animation-delay:.6s}.intro .logo-intro{animation:none}}

  /* intro number slot */
  .intro-slot{position:relative;z-index:2;display:flex;gap:5px;user-select:none;color:var(--ink);transition:opacity .5s ease}
  .intro-slot .is-col{width:83px;height:200px;overflow:visible;clip-path:inset(0 -40px);position:relative}
  .intro-slot .is-col::before,.intro-slot .is-col::after{content:"";position:absolute;left:0;right:0;height:30px;z-index:2;pointer-events:none}
  .intro-slot .is-col::before{top:0;background:linear-gradient(var(--yellow),transparent)}
  .intro-slot .is-col::after{bottom:0;background:linear-gradient(transparent,var(--yellow))}
  .intro-slot .is-tape{display:flex;flex-direction:column;align-items:center;will-change:transform}
  .intro-slot .is-tape>div{width:100%;text-align:center;height:200px;line-height:200px;font-family:system-ui,-apple-system,"Helvetica Neue",Arial,sans-serif;font-size:140px;font-weight:700;letter-spacing:0;font-variant-numeric:tabular-nums;color:var(--ink)}
  .intro.logo-out .intro-slot{opacity:0}

  /* header */
  header{position:fixed;top:0;left:0;right:0;z-index:60;background:transparent;border-bottom:1px solid transparent;transition:background .35s ease,border-color .35s ease}
  header.scrolled{background:rgba(255,210,0,.92);-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);border-bottom-color:var(--line)}
  header .bar{display:flex;align-items:center;justify-content:space-between;padding:28px clamp(20px,3vw,44px);max-width:none;margin:0}
  header .brand{display:flex;align-items:center;gap:12px}
  header .mini .screen{padding:2px 6px 1px;border-width:2px;font-size:12px;border-radius:2px}
  header .mini .seats i{width:7px;height:5px}
  header .name{font-family:var(--mincho);font-weight:600;font-size:20px;letter-spacing:.08em}
  header .nav{display:flex;align-items:center;gap:30px}
  header .nav a{font-size:13px;font-weight:500;letter-spacing:.04em;color:var(--yellow);transition:color .35s ease}
  header.scrolled .nav a{color:var(--ink)}
  header .nav a.book{font-family:var(--goth);font-weight:700;background:var(--yellow);color:var(--ink);padding:11px 22px;border-radius:50px;letter-spacing:normal;transition:opacity .2s,background .35s ease,color .35s ease}
  header.scrolled .nav a.book{background:var(--ink);color:#fff}
  header .nav a.book:hover{opacity:.82}
  @media(max-width:680px){header .nav a:not(.book){display:none}header .name{display:none}}

  /* hero — floating rounded card */
  .herowrap{padding:0}
  .hero{position:relative;background:#000;border-radius:0;overflow:hidden;min-height:100vh;display:flex;flex-direction:column;justify-content:space-between;padding:120px clamp(28px,5vw,66px) clamp(48px,5vw,72px)}
  .hero-video{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;z-index:0;filter:brightness(1.14) saturate(1.04)}
  .hero-scrim{position:absolute;inset:0;z-index:1;background:linear-gradient(180deg,rgba(0,0,0,.32) 0%,rgba(0,0,0,0) 24%),linear-gradient(0deg,rgba(0,0,0,.26),rgba(0,0,0,0) 20%),linear-gradient(rgba(0,0,0,.08),rgba(0,0,0,.08))}
  .hero .watermark{display:none}
  .hero .top{position:relative;z-index:3;display:flex;align-items:flex-start;justify-content:space-between;gap:30px}
  .hero .lockup{display:flex;align-items:center;gap:13px}
  .hero .lockup .screen{font-size:19px;padding:4px 10px 3px;border-width:2.5px;border-radius:4px}
  .hero .lockup .seats i{width:11px;height:8px}
  .hero .lockup .wm{font-family:var(--mincho);font-weight:600;font-size:21px;letter-spacing:.08em}
  .hero .nowshowing{text-align:right}
  .hero .nowshowing .lbl{font-family:var(--latin);font-size:12px;letter-spacing:.16em;color:rgba(255,255,255,.6);margin-bottom:13px}
  .hero .nowshowing a{display:block;font-family:var(--mincho);font-weight:500;font-size:15px;letter-spacing:normal;color:rgba(255,255,255,.55);line-height:2.05;transition:color .25s}
  .hero .nowshowing a:hover{color:var(--white)}
  .hero .copy{position:relative;z-index:3;max-width:820px}
  .hero .eyebrow{display:flex;align-items:center;gap:16px;margin-bottom:18px}
  .hero .eyebrow .rule{width:46px;height:1px;background:var(--white)}
  .hero .six{font-family:var(--goth);font-weight:700;font-size:clamp(14px,1.6vw,16px);color:#fff;letter-spacing:normal}
  .hero .kicker{color:rgba(255,255,255,.82)}
  .hero h1{font-family:var(--mincho);font-weight:600;font-size:clamp(32px,5.6vw,62px);line-height:1.28;letter-spacing:normal;margin-bottom:20px;color:var(--white)}
  .hero p.lead{font-family:var(--goth);font-weight:400;font-size:clamp(15px,1.9vw,18px);line-height:1.85;max-width:520px;color:rgba(255,255,255,.92);margin-bottom:26px}
  .ctas{display:flex;gap:26px;align-items:center;flex-wrap:wrap}
  .pill{display:inline-flex;align-items:center;gap:18px;background:var(--yellow);color:var(--ink);border-radius:50px;padding:9px 10px 9px 28px;font-family:var(--goth);font-weight:700;font-size:15px;letter-spacing:normal;transition:transform .25s}
  .pill:hover{transform:translateY(-2px)}
  .pill .c{width:38px;height:38px;border-radius:50%;background:var(--ink);color:var(--yellow);display:flex;align-items:center;justify-content:center;font-size:16px}
  .btn{font-family:var(--goth);font-weight:700;font-size:14px;letter-spacing:normal;background:var(--ink);color:var(--white);padding:16px 34px;border-radius:50px;transition:transform .25s,background .25s}
  .btn:hover{transform:translateY(-2px);background:#000}
  .link-arrow{font-family:var(--goth);font-weight:500;font-size:14px;letter-spacing:normal;border-bottom:1px solid var(--ink);padding-bottom:5px;transition:opacity .2s}
  .link-arrow:hover{opacity:.55}
  @media(max-width:780px){.hero .nowshowing{display:none}.herowrap{padding:0}.hero{border-radius:0;min-height:100vh;min-height:100dvh;padding:96px 24px 48px;gap:64px}}

  /* section scaffolding */
  section{position:relative}
  .seclead{display:flex;align-items:baseline;gap:18px;margin-bottom:48px}
  .seclead .num{font-family:var(--latin);font-size:15px;letter-spacing:.2em;color:var(--ink-soft)}
  .seclead h2{font-family:var(--mincho);font-weight:700;font-size:clamp(24px,3.6vw,38px);letter-spacing:normal;line-height:1.4}

  /* concept */
  .concept{background:var(--ink);color:var(--white);padding:120px 32px;text-align:center;position:relative;overflow:hidden}
  .concept .big{font-family:var(--latin);font-weight:300;font-size:clamp(120px,26vw,260px);line-height:.78;letter-spacing:-.02em;color:var(--yellow)}
  .concept .big sub{font-family:var(--latin);font-size:.18em;letter-spacing:.3em;vertical-align:.9em;color:var(--white)}
  .concept .lede{font-family:var(--mincho);font-weight:500;font-size:clamp(22px,3.6vw,36px);line-height:1.7;letter-spacing:normal;margin:30px 0 36px}
  .concept p{font-family:var(--goth);font-weight:300;font-size:clamp(15px,1.9vw,17px);line-height:2.4;max-width:600px;margin:0 auto;color:#e7e0d2}
  .concept .em{color:var(--yellow);font-weight:500}

  /* lineup */
  .lineup{padding:120px 32px}
  .lineup .wrap{max-width:920px}
  .lineup .topnote{font-family:var(--goth);font-weight:400;font-size:16px;line-height:1.9;color:var(--ink);max-width:640px;margin:-38px 0 32px;letter-spacing:normal}
  .subnote{font-family:var(--goth);font-weight:400;font-size:16px;line-height:1.9;color:var(--ink);max-width:640px;margin:-38px 0 32px;letter-spacing:normal}
  .grid{display:grid;grid-template-columns:repeat(3,1fr);gap:56px 48px}
  .film{cursor:pointer}
  .film .frame{position:relative;overflow:hidden;background:#000;border-radius:0}
  .film .frame .img{position:absolute;inset:0;transition:transform 1.1s cubic-bezier(.2,.7,.2,1);filter:saturate(.7) contrast(1.02)}
  .film .frame img{display:block;width:100%;height:auto}
  .film .frame .vig{position:absolute;inset:0;z-index:2;box-shadow:inset 0 0 70px rgba(0,0,0,.5)}
  .film .frame .grainy{position:absolute;inset:0;z-index:2;opacity:.16;background-image:radial-gradient(rgba(255,255,255,.6) .5px,transparent .6px);background-size:5px 5px}
  .film .frame .mo{position:absolute;top:12px;left:12px;z-index:3;font-family:var(--latin);font-size:12px;letter-spacing:.18em;color:var(--yellow);background:rgba(0,0,0,.5);padding:5px 11px;border-radius:0;-webkit-backdrop-filter:blur(3px);backdrop-filter:blur(3px)}
  .mo-badge{position:absolute;top:12px;left:12px;z-index:4;font-family:var(--goth);font-weight:700;font-size:13px;letter-spacing:.02em;color:var(--ink);background:var(--yellow);padding:5px 9px;border-radius:7px;box-shadow:0 2px 8px rgba(0,0,0,.25);line-height:1}
  .month-card .mc-poster{position:relative}
  .hero-poster-wrap{position:relative;display:inline-block;line-height:0}
  .hero-poster-wrap .mo-badge{top:14px;left:14px;font-size:14px;padding:6px 10px}
  .img1{background:linear-gradient(150deg,#54606f,#262d38)}
  .img2{background:linear-gradient(150deg,#4f5f50,#272f28)}
  .img3{background:linear-gradient(150deg,#6a5947,#332a20)}
  .img4{background:linear-gradient(150deg,#445862,#1f2a30)}
  .img5{background:linear-gradient(150deg,#6a4d46,#331f1c)}
  .img6{background:linear-gradient(150deg,#56506b,#2a273a)}
  .film .cap{margin-top:16px}
  .film .cap h3{font-family:var(--goth);font-weight:700;font-size:17px;color:var(--ink);line-height:1.4;letter-spacing:normal}
  .film .cap .meta{display:flex;flex-wrap:wrap;align-items:center;gap:7px 12px;margin-top:9px}
  .film .cap .period{font-family:var(--goth);font-size:12.5px;color:var(--ink);letter-spacing:normal}
  .film .cap .period i{font-style:normal;color:var(--ink);font-size:11px;margin-right:5px}
  .film .cap .genre{font-family:var(--goth);font-size:10px;color:var(--ink);border:1px solid rgba(0,0,0,.32);padding:2px 8px;letter-spacing:normal;order:-1}
  .film .cap .copy{font-family:var(--goth);font-size:13.5px;line-height:1.65;color:var(--ink);margin-top:11px}

  /* why */
  .why{background:var(--yellow);border-top:1px solid var(--line);border-bottom:1px solid var(--line);padding:110px 32px}
  .why .grid3{display:grid;grid-template-columns:repeat(3,1fr);gap:56px;margin-top:0}
  .why .item .n{font-family:var(--latin);font-weight:400;font-size:46px;color:var(--yellow-deep);line-height:1;letter-spacing:.04em}
  .why .item h4{font-family:var(--mincho);font-weight:600;font-size:21px;letter-spacing:normal;margin:18px 0 14px}
  .why .item p{font-family:var(--goth);font-weight:400;font-size:14.5px;line-height:2.05;color:var(--ink-soft)}
  .why .item .hr{width:34px;height:1px;background:var(--ink);margin:16px 0 0}
  @media(max-width:760px){.why .grid3{grid-template-columns:1fr;gap:40px}}

  /* schedule */
  .sched{padding:118px 32px}
  .timeline{margin-top:8px;border-top:1px solid var(--line)}
  .ev{display:grid;grid-template-columns:130px 1fr auto;gap:30px;align-items:baseline;padding:30px 4px;border-bottom:1px solid var(--line);transition:background .3s}
  .ev:hover{background:rgba(255,210,0,.12)}
  .ev .mo{font-family:var(--latin);font-size:17px;letter-spacing:.16em;color:var(--ink-soft)}
  .ev .mo small{display:block;font-family:var(--goth);font-size:11px;letter-spacing:.18em;opacity:.6;margin-top:6px}
  .ev .ttl{font-family:var(--mincho);font-weight:600;font-size:21px;letter-spacing:normal}
  .ev .ttl .meta{display:block;font-family:var(--goth);font-weight:400;font-size:13px;color:var(--ink-soft);margin-top:6px;letter-spacing:normal}
  .ev .arr{font-family:var(--latin);font-size:18px;color:var(--ink-soft)}
  .sched .info{display:grid;grid-template-columns:1fr 1fr;gap:0;border:1px solid var(--line);margin-top:54px}
  .sched .info .box{padding:30px 34px;background:var(--white)}
  .sched .info .box:first-child{border-right:1px solid var(--line)}
  .sched .info .box span{font-family:var(--latin);font-size:12px;letter-spacing:.16em;color:var(--ink-soft);display:block;margin-bottom:10px}
  .sched .info .box strong{font-family:var(--mincho);font-weight:600;font-size:19px;letter-spacing:normal}
  .sched .cta{margin-top:50px}
  @media(max-width:680px){.ev{grid-template-columns:84px 1fr;gap:18px}.ev .arr{display:none}.sched .info{grid-template-columns:1fr}.sched .info .box:first-child{border-right:none;border-bottom:1px solid var(--line)}}

  /* present / repeater benefits */
  .present{background:var(--yellow);padding:110px 32px 150px;text-align:left}
  .repeat{max-width:880px;margin:0 auto;border:2px dashed rgba(0,0,0,.45);border-radius:22px;padding:clamp(32px,5vw,56px)}
  .repeat .rp-head{display:flex;gap:clamp(16px,2.4vw,24px);align-items:flex-start}
  .repeat .rp-gift{width:clamp(40px,6vw,56px);height:auto;color:var(--ink);flex:0 0 auto;margin-top:2px}
  .repeat .rp-head h2{font-family:var(--mincho);font-weight:700;font-size:clamp(22px,3.4vw,32px);line-height:1.35;color:var(--ink);letter-spacing:normal}
  .repeat .rp-head p{font-family:var(--goth);font-weight:400;font-size:clamp(14px,1.8vw,16px);line-height:1.85;color:var(--ink);margin-top:10px}
  .repeat .rp-hr{border-top:2px dashed rgba(0,0,0,.38);margin:clamp(26px,4vw,38px) 0}
  .repeat .rp-item{display:flex;gap:clamp(18px,3vw,30px);align-items:flex-start}
  .repeat .rp-item + .rp-item{margin-top:clamp(28px,4vw,42px)}
  .repeat .rp-badge{flex:0 0 auto;width:clamp(84px,12vw,104px);height:clamp(84px,12vw,104px);border:2px solid var(--ink);border-radius:50%;display:flex;align-items:center;justify-content:center;text-align:center}
  .repeat .rp-badge span{font-family:var(--goth);font-weight:700;font-size:clamp(14px,1.9vw,17px);line-height:1.3;color:var(--ink)}
  .repeat .rp-body{flex:1;min-width:0;padding-top:6px}
  .repeat .rp-complete{display:flex;align-items:center;gap:5px;font-family:var(--goth);font-weight:700;font-size:clamp(13px,1.7vw,15px);color:var(--ink);margin-bottom:6px}
  .repeat .rp-body h3{font-family:var(--goth);font-weight:700;font-size:clamp(17px,2.4vw,23px);line-height:1.45;color:var(--ink);letter-spacing:normal}
  .repeat .rp-body h3 mark{background:linear-gradient(transparent 58%, rgba(255,255,255,.6) 0);color:var(--ink);padding:0 1px}
  .repeat .rp-body h3 small{font-family:var(--goth);font-weight:500;font-size:clamp(11px,1.4vw,13px);color:var(--ink);white-space:nowrap}
  .repeat .rp-body > p{font-family:var(--goth);font-weight:400;font-size:clamp(12.5px,1.5vw,14px);line-height:1.9;color:var(--ink);margin-top:12px}

  /* samansa */
  .samansa{background:var(--yellow);color:var(--ink);padding:110px 32px}
  .samansa .inner{max-width:1040px;margin:0 auto;display:grid;grid-template-columns:1.1fr .9fr;gap:64px;align-items:center}
  .samansa .logo{display:flex;align-items:center;gap:13px;margin-bottom:26px}
  .samansa .logo .sq{width:30px;height:30px;background:transparent;display:flex;align-items:center;justify-content:center}
  .samansa .logo .sq svg{width:16px;height:16px}
  .samansa .logo b{font-family:var(--latin);font-weight:500;font-size:25px;letter-spacing:.28em}
  .samansa h3{font-family:var(--mincho);font-weight:500;font-size:clamp(24px,3.8vw,34px);letter-spacing:normal;line-height:1.6;margin-bottom:22px}
  .samansa h3 em{color:var(--ink);font-style:normal}
  .samansa .feat{font-family:var(--goth);font-weight:300;font-size:14.5px;line-height:2.05;color:var(--ink-soft);margin-bottom:30px;max-width:430px}
  .samansa .price{display:flex;align-items:baseline;gap:10px;margin-bottom:8px}
  .samansa .price .y{font-family:var(--latin);font-weight:400;font-size:72px;line-height:.9;color:var(--ink)}
  .samansa .price .u{font-family:var(--goth);font-weight:500;font-size:15px;letter-spacing:normal}
  .samansa .trial{font-family:var(--goth);font-weight:700;font-size:14px;color:var(--ink);letter-spacing:normal;margin-bottom:30px}
  .samansa .stores{display:flex;gap:12px;flex-wrap:wrap}
  .store{display:flex;align-items:center;gap:8px;border:1px solid rgba(0,0,0,.24);padding:10px 18px;transition:background .25s,color .25s}
  .store:hover{background:var(--ink);color:var(--white)}
  .store .big{font-family:var(--latin);font-weight:500;font-size:15px;line-height:1.1;letter-spacing:.04em}
  .store small{display:block;font-family:var(--goth);font-size:9px;letter-spacing:.14em;opacity:.65}
  .samansa .qrwrap{justify-self:center;text-align:center}
  .samansa .qr{width:158px;height:158px;background:var(--white);border:1px solid var(--line);display:grid;grid-template-columns:repeat(7,1fr);grid-template-rows:repeat(7,1fr);gap:4px;padding:15px}
  .samansa .qr i{background:var(--ink)}
  .samansa .qr i.off{background:transparent}
  .samansa .qrwrap p{font-family:var(--goth);font-size:11.5px;color:var(--ink-soft);margin-top:14px;letter-spacing:normal}
  @media(max-width:840px){.samansa .inner{grid-template-columns:1fr;gap:42px}.samansa .qrwrap{order:-1;justify-self:start}}

  /* footer */
  footer{background:var(--yellow);color:var(--ink);padding:56px 32px 110px;border-top:1px solid rgba(0,0,0,.18)}
  footer .ft{max-width:1140px;margin:0 auto;text-align:center}
  footer .ft-top{display:flex;flex-direction:column;align-items:center;gap:46px}
  footer .sns{display:flex;gap:18px;justify-content:center}
  footer .sns a{color:var(--ink);opacity:.78;transition:opacity .2s;display:inline-flex}
  footer .sns a:hover{opacity:1}
  footer .sns svg{width:22px;height:22px;display:block}
  footer .ft-links{display:flex;flex-wrap:wrap;gap:12px 28px;margin-top:36px;justify-content:center}
  footer .ft-links a{font-family:var(--goth);font-weight:500;font-size:13px;color:var(--ink);border-bottom:1px solid transparent;padding-bottom:2px;transition:border-color .2s}
  footer .ft-links a:hover{border-bottom-color:var(--ink)}
  footer .mark{color:var(--white)}
  footer .mark .screen{padding:3px 8px 2px;border-width:2px;font-size:14px}
  footer .mark .seats i{width:8px;height:6px}
  footer .legal{font-family:var(--goth);font-weight:400;font-size:11px;line-height:1.95;max-width:760px;letter-spacing:normal;color:rgba(0,0,0,.55);margin:30px auto 0}
  footer .eirin{height:34px;width:auto;display:block;margin:24px auto 0}

  /* reveal */
  /* hero poster stage */
  .hero-stage{position:absolute;inset:0;z-index:2;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:16px;padding:0 24px;pointer-events:none}
  .hero-poster{height:min(52vh,475px);width:auto;box-shadow:0 36px 90px -24px rgba(0,0,0,.7);pointer-events:auto;cursor:pointer;transition:transform .3s ease,box-shadow .3s ease}
  .hero-poster-wrap{animation:posterIn 1.25s cubic-bezier(.2,.8,.2,1) 1.85s both}
  .hero-poster:hover{transform:translateY(-4px);box-shadow:0 44px 100px -22px rgba(0,0,0,.78)}
  @keyframes posterIn{from{opacity:0;transform:translateY(26px) scale(.97)}to{opacity:1;transform:none}}
  .hero-toplabel{font-family:var(--goth);font-weight:600;font-size:clamp(13px,1.5vw,15px);color:var(--yellow);letter-spacing:normal;pointer-events:auto;transition:opacity .2s;animation:fade 1.1s 2.0s both}
  .hero-toplabel:hover{opacity:.82}
  .hero-dates{font-family:var(--goth);font-weight:600;font-size:clamp(13px,1.5vw,15px);color:var(--yellow);letter-spacing:.06em;pointer-events:auto;transition:opacity .2s;animation:fade 1.1s 2.3s both}
  .hero-dates:hover{opacity:.82}
  @media(max-width:780px){.hero-label{display:none}.hero-poster{height:min(40vh,330px)}}

  /* scroll cue */
  .scroll-cue{position:absolute;left:50%;bottom:30px;transform:translateX(-50%);z-index:3;display:flex;flex-direction:column;align-items:center;gap:12px;color:#fff;font-family:var(--latin);font-size:11px;letter-spacing:.34em;text-decoration:none}
  .scroll-cue i{position:relative;display:block;width:1px;height:40px;background:rgba(255,255,255,.35);overflow:hidden}
  .scroll-cue i::after{content:"";position:absolute;left:0;top:0;width:1px;height:40px;background:#fff;transform:translateY(-100%);animation:scrolldash 1.9s cubic-bezier(.7,0,.3,1) infinite}
  @keyframes scrolldash{0%{transform:translateY(-100%)}55%,100%{transform:translateY(100%)}}

  /* marquee */
  .marquee{background:var(--ink);overflow:hidden;padding:16px 0;position:relative}
  .marquee::before,.marquee::after{content:"";position:absolute;top:0;bottom:0;width:90px;z-index:2;pointer-events:none}
  .marquee::before{left:0;background:linear-gradient(90deg,var(--ink),transparent)}
  .marquee::after{right:0;background:linear-gradient(270deg,var(--ink),transparent)}
  .mq-track{display:inline-flex;align-items:center;gap:30px;white-space:nowrap;animation:mq 24s linear infinite;will-change:transform}
  .marquee:hover .mq-track{animation-play-state:paused}
  .mq-track span{font-family:var(--goth);font-weight:700;font-size:clamp(22px,3.2vw,40px);color:var(--yellow);letter-spacing:normal}
  .mq-track b{display:inline-block;color:#ff7a00;font-size:.5em;transform:translateY(-.2em);text-shadow:0 0 5px rgba(255,120,0,.9),0 0 12px rgba(255,80,0,.6);animation:dotpulse 1.3s ease-in-out infinite}
  @keyframes dotpulse{0%,100%{opacity:.35;text-shadow:0 0 3px rgba(255,120,0,.5)}50%{opacity:1;text-shadow:0 0 7px rgba(255,120,0,1),0 0 18px rgba(255,70,0,.75)}}
  @keyframes mq{to{transform:translateX(-50%)}}

  /* hero headline line reveal */
  .hero h1 .ln{display:block;overflow:hidden}
  .hero h1 .ln>span{display:block;transform:translateY(108%);animation:lnup 1.05s cubic-bezier(.2,.85,.2,1) both}
  .hero h1 .ln:nth-child(1)>span{animation-delay:1.85s}
  .hero h1 .ln:nth-child(2)>span{animation-delay:1.98s}
  @keyframes lnup{to{transform:none}}

  /* richer lineup hover */
  .film{transition:opacity .25s ease}
  .film:hover{opacity:.78}

  .rv{opacity:0;transform:translateY(26px);transition:opacity 1s ease,transform 1s cubic-bezier(.2,.7,.2,1)}
  .rv.in{opacity:1;transform:none}
  .hero .top{animation:fade 1s 1.7s both}
  .hero .eyebrow{animation:fade 1s 1.78s both}
  .hero h1{animation:none}
  .hero p.lead{animation:fade 1.1s 2.15s both}
  .hero .ctas{animation:fade 1.1s 2.3s both}
  @keyframes fade{from{opacity:0;transform:translateY(22px)}to{opacity:1;transform:none}}

  /* about / brand */
  .about{background:var(--yellow);padding:170px 32px;text-align:center}
  .about-in{max-width:780px;margin:0 auto}
  .about .brand-symbol{display:block;width:clamp(116px,15vw,168px);height:auto;color:var(--ink);margin:0 auto}
  .about .brand-word{display:block;width:clamp(190px,26vw,300px);height:auto;color:var(--ink);margin:20px auto 0}
  .about h2{font-family:var(--goth);font-weight:700;font-size:clamp(26px,4.4vw,46px);color:var(--ink);line-height:1.4;letter-spacing:normal;margin:38px 0 28px}
  .about p{font-family:var(--goth);font-weight:400;font-size:clamp(14px,1.8vw,16px);line-height:2.15;color:var(--ink);max-width:660px;margin:0 auto}
  @media(max-width:680px){.about p br{display:none}}

  /* access */
  .access{padding:80px 32px}
  .access-grid{margin-top:24px}
  .ac-photos{display:grid;grid-template-columns:repeat(3,1fr);gap:7px}
  .ac-photos img{width:100%;aspect-ratio:3/2;object-fit:cover;display:block}
  .ac-map{display:inline-flex;align-items:center;gap:7px;margin-top:26px;font-family:var(--goth);font-weight:700;font-size:14px;color:var(--ink);border:1.5px solid var(--ink);border-radius:50px;padding:11px 24px;transition:background .2s,color .2s}
  .ac-map:hover{background:var(--ink);color:var(--yellow)}
  .ac-addr{font-family:var(--goth);font-weight:400;font-size:15px;line-height:2;color:var(--ink)}
  .ac-addr a{border-bottom:1px solid rgba(0,0,0,.4)}
  .ac-block{margin-top:34px}
  .ac-block h3{font-family:var(--goth);font-weight:700;font-size:17px;color:var(--ink);margin-bottom:16px}
  .ac-route{margin-bottom:18px}
  .ac-route .r{font-family:var(--goth);font-weight:700;font-size:14.5px;color:var(--ink);line-height:1.6}
  .ac-route .n{font-family:var(--goth);font-weight:400;font-size:13px;line-height:1.85;color:rgba(0,0,0,.62);margin-top:5px;padding-left:1.1em}
  .ac-info{margin-top:40px}
  @media(max-width:820px){
    .ac-photos{display:flex;grid-template-columns:none;gap:10px;overflow-x:auto;scroll-snap-type:x mandatory;-webkit-overflow-scrolling:touch;padding-bottom:10px;scrollbar-width:none;scroll-padding:0 22px}
    .ac-photos::-webkit-scrollbar{display:none}
    .ac-photos img{flex:0 0 86%;scroll-snap-align:center}
  }

  /* this month's film */
  .month{padding:120px 32px 90px}
  .month-card{display:grid;grid-template-columns:248px 1fr;gap:44px;align-items:start}
  .month-card .mc-poster img{display:block;width:100%;height:auto}
  .mc-top{display:flex;gap:30px;align-items:flex-start}
  .mc-copy{flex:1;min-width:0}
  .mc-catch{font-family:var(--goth);font-weight:600;font-size:clamp(18px,2.3vw,25px);line-height:1.45;color:var(--ink);letter-spacing:normal}
  .mc-namelabel{font-family:var(--goth);font-size:12px;color:var(--ink);margin-top:16px}
  .mc-title{font-family:var(--goth);font-weight:700;font-size:clamp(25px,3.2vw,35px);line-height:1.25;color:var(--ink);margin-top:4px;letter-spacing:normal}
  .mc-tags{display:flex;flex-wrap:wrap;align-items:center;gap:10px 16px;margin-top:20px}
  .mc-tags .genre{font-family:var(--goth);font-size:12px;color:var(--ink);border:1px solid rgba(0,0,0,.32);padding:4px 12px;letter-spacing:normal}
  .mc-tags .dir{font-family:var(--goth);font-size:13px;color:var(--ink);letter-spacing:normal}
  .mc-syn{font-family:var(--goth);font-weight:400;font-size:14.5px;line-height:1.85;color:var(--ink);margin-top:22px;max-width:620px}
  .mc-cta{display:inline-flex;align-items:center;gap:7px;margin-top:30px;font-family:var(--goth);font-weight:700;font-size:15px;color:var(--ink);letter-spacing:normal;border-bottom:1.5px solid var(--ink);padding-bottom:3px;transition:opacity .2s}
  .mc-cta:hover{opacity:.6}
  .mc-side{flex:0 0 auto;display:flex;flex-direction:column;align-items:flex-end;gap:16px}
  .mc-period{border:1.5px solid var(--ink);border-radius:8px;padding:9px 18px;text-align:center;line-height:1.15}
  .mc-period span{display:block;font-family:var(--goth);font-size:10px;line-height:1;color:var(--ink);margin-bottom:5px;letter-spacing:normal}
  .mc-period strong{display:block;font-family:var(--goth);font-weight:700;font-size:18px;line-height:1;color:var(--ink);letter-spacing:normal}
  .mc-runtime{font-family:var(--goth);font-weight:700;font-size:17px;color:var(--ink);background:rgba(0,0,0,.08);border-radius:9px;padding:6px 16px}
  .mc-stills{display:grid;grid-template-columns:repeat(4,1fr);gap:7px;margin-top:52px}
  .mc-stills .still{aspect-ratio:3/2;position:relative;overflow:hidden;background:#1b1b1b}
  .mc-stills .still img{width:100%;height:100%;object-fit:cover;display:block}
  .mc-stills .still .g{position:absolute;inset:0;opacity:.5;background:radial-gradient(rgba(255,255,255,.25),transparent 70%)}
  .mc-stills .s1{background:linear-gradient(135deg,#3a4456,#171c26)}
  .mc-stills .s2{background:linear-gradient(135deg,#5a4a3a,#241c14)}
  .mc-stills .s3{background:linear-gradient(135deg,#2f4636,#13211a)}
  .mc-stills .s4{background:linear-gradient(135deg,#5a3630,#251412)}
  .mc-stillnote{font-family:var(--goth);font-size:12px;color:var(--ink-soft);margin-top:12px}
  @media(max-width:820px){
    .month-card{grid-template-columns:1fr;gap:26px}
    .month-card .mc-poster{max-width:340px}
    .mc-top{flex-direction:column;gap:20px}
    .mc-side{flex-direction:row;align-items:center;align-self:flex-start;order:-1}
    .mc-stills{grid-template-columns:repeat(2,1fr)}
  }

  @media(max-width:680px){.grid{grid-template-columns:1fr 1fr;gap:26px 18px}.film .cap h3{min-height:2.7em}}
  /* film modal */
  .modal-overlay{position:fixed;inset:0;z-index:3000;background:rgba(0,0,0,.55);display:none;align-items:flex-start;justify-content:center;overflow-y:auto;padding:clamp(24px,6vh,72px) 20px}
  .modal-overlay.open{display:flex}
  .modal{position:relative;background:var(--yellow);width:100%;max-width:1060px;padding:clamp(40px,4vw,56px) clamp(24px,4vw,52px);box-shadow:0 40px 90px -24px rgba(0,0,0,.55);animation:modalIn .3s ease}
  @keyframes modalIn{from{opacity:0;transform:translateY(14px)}to{opacity:1;transform:none}}
  .modal-close{position:fixed;top:18px;right:22px;z-index:3100;width:46px;height:46px;border:0;background:var(--ink);color:#fff;font-size:26px;line-height:1;cursor:pointer;border-radius:50%;display:flex;align-items:center;justify-content:center;padding-bottom:3px;box-shadow:0 4px 16px rgba(0,0,0,.28);transition:transform .2s,background .2s}
  .modal-close:hover{background:#000;transform:scale(1.07)}
  .modal .mc-stills{margin-top:26px}

  /* modal: rich film detail */
  .mc-detail{max-width:760px;margin:44px auto 0;padding-top:38px;border-top:1px solid var(--line);text-align:left}
  .mc-detail .det-award{display:inline-block;font-family:var(--goth);font-weight:700;font-size:12px;letter-spacing:.01em;line-height:1.55;color:var(--ink);border:1.5px solid var(--ink);border-radius:7px;padding:8px 15px}
  .mc-detail .det-entitle{font-family:var(--latin);font-weight:500;font-size:13px;letter-spacing:.04em;color:var(--ink-soft);margin-top:15px}
  .mc-detail .det-lead{font-family:var(--goth);font-weight:700;font-size:clamp(16px,2vw,19px);line-height:1.7;color:var(--ink);margin-top:13px}
  .mc-detail .det-sec{margin-top:36px}
  .mc-detail .det-h{font-family:var(--mincho);font-weight:700;font-size:19px;color:var(--ink);letter-spacing:normal;padding-left:13px;border-left:4px solid var(--ink);line-height:1.3}
  .mc-detail .det-sub{font-family:var(--goth);font-weight:600;font-size:15px;color:var(--ink);margin-top:15px}
  .mc-detail .det-h5{font-family:var(--goth);font-weight:700;font-size:14.5px;color:var(--ink);margin-top:24px}
  .mc-detail .det-name{font-family:var(--goth);font-weight:700;font-size:16px;color:var(--ink);margin-top:15px}
  .mc-detail p{font-family:var(--goth);font-weight:400;font-size:14.5px;line-height:1.95;color:var(--ink);margin-top:11px}
  .mc-detail .det-refs{margin-top:38px;border-top:1px solid var(--line);padding-top:18px}
  .mc-detail .det-refs summary{font-family:var(--goth);font-weight:600;font-size:13px;color:var(--ink-soft);cursor:pointer;letter-spacing:normal;list-style:revert}
  .mc-detail .det-refs summary:hover{color:var(--ink)}
  .mc-detail .det-refs .ref-group{font-family:var(--goth);font-weight:700;font-size:12px;color:var(--ink);margin-top:16px}
  .mc-detail .det-refs ul{list-style:none;margin:5px 0 0;padding:0}
  .mc-detail .det-refs li{font-size:12px;line-height:1.7;margin-top:7px}
  .mc-detail .det-refs a{color:var(--ink-soft);border-bottom:1px solid rgba(0,0,0,.25);word-break:break-word}
  .mc-detail .det-refs a:hover{color:var(--ink)}
  @media(max-width:680px){.mc-detail{margin-top:34px;padding-top:30px}.mc-detail .det-h{font-size:17px}}

  /* this-month: read-more toggle */
  .month-more{max-width:760px;margin:40px auto 0;display:flex;flex-direction:column;align-items:center}
  .month-more>summary{order:0;display:inline-flex;align-items:center;gap:9px;cursor:pointer;font-family:var(--goth);font-weight:700;font-size:15px;letter-spacing:normal;color:var(--ink);background:transparent;border:1.5px solid var(--ink);border-radius:50px;padding:12px 28px;list-style:none;transition:background .2s,color .2s}
  .month-more>summary::-webkit-details-marker{display:none}
  .month-more>summary::after{content:"＋";font-weight:700;font-size:15px;line-height:1}
  .month-more[open]>summary{order:1;margin-top:36px}
  .month-more[open]>summary::after{content:"−"}
  .month-more>summary:hover{background:var(--ink);color:var(--yellow)}
  .month-more .close-lbl{display:none}
  .month-more[open] .more-lbl{display:none}
  .month-more[open] .close-lbl{display:inline}
  .month-more .mc-detail{order:0;width:100%;margin-top:30px;padding-top:0;border-top:0;text-align:left}
  .month-more:not([open]) .mc-detail{display:none}
  .det-refs:not([open])>:not(summary){display:none}

  /* ---- mobile responsive ---- */
  @media(max-width:640px){
    body{overflow-x:hidden}
    .wrap{padding:0 22px}
    header .bar{padding:15px 20px}
    header .brand .logo{height:27px;width:108px}
    .seclead{margin-bottom:30px}
    .subnote,.lineup .topnote{margin:8px 0 26px}
    .about{padding:92px 22px}
    .about h2{margin:30px 0 22px}
    .about .brand-word{margin-top:16px}
    .month{padding:78px 22px 60px}
    .lineup{padding:78px 22px}
    .grid{gap:26px 14px}
    .film .cap h3{font-size:16px}
    .film .cap .copy{font-size:13px}
    .access{padding:78px 22px}
    .present{padding:78px 22px}
    .repeat{padding:28px 20px;border-radius:16px}
    .repeat .rp-item{gap:14px}
    .repeat .rp-badge{width:74px;height:74px}
    .repeat .rp-badge span{font-size:13px}
    footer{padding:52px 22px 72px}
  }
  @media(max-width:380px){
    .grid{grid-template-columns:1fr;gap:30px}
    .grid .film .frame img{max-width:300px;margin:0 auto}
  }
