*, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }

    html { scroll-behavior: smooth; }

    body {
      background: #111!important;
      font-family: 'Noto Serif JP', serif!important;
      color: #fff!important;
      overflow-x: hidden!important;
    }

    .wrap {
      max-width: 480px;
      margin: 0 auto;
      background: #000;
      position: relative;
    }

    @media (min-width: 700px) {
      .wrap { box-shadow: 0 0 80px rgba(255,255,255,.04); }
    }

    /* ── HEADER ── */
    .hd {
      position: absolute;
      top: 0; left: 0; right: 0;
      z-index: 10;
      padding: 12px 14px;
      display: flex;
      align-items: center;
      justify-content: space-between;
      gap: 20px;
      background: linear-gradient(to bottom, rgba(0,0,0,.75) 0%, transparent 100%);
    }

    .hd-logo {
      height: 34px;
      width: auto;
      display: block;
    }

    .hd-nav {
      list-style: none;
      display: flex;
      gap: 8px;
      padding: 0;
      margin: 0;
    }

    .hd-nav li {
      margin: 0;
      padding: 0;
    }

    .hd-nav a {
      display: block;
    }

    .hd-nav a img {
      height: 34px;
      width: auto;
      display: block;
    }

    .hd-nav a:hover {
      opacity: 0.7;
    }

    /* ── KV ── */
    .kv {
      display: block;
      width: 100%;
      height: auto;
      vertical-align: bottom;
    }

    /* ── RULES ── */
    .rules {
      margin-top: -20px;
      background: #000;
      padding: 0px 25px 8px;
      text-align: center;
    }

    .rule-list {
      list-style: none;
      display: flex;
      flex-direction: column;
      margin-bottom: 72px;
		margin-left: 0;
    }

    .rule-list li {
      font-size: 20px;
      font-weight: 300;
      letter-spacing: .18em;
      color: #fff;
      opacity: 0;
      transform: translateY(36px);
      transition: opacity 1s cubic-bezier(0.22,1,0.36,1), transform 1s cubic-bezier(0.22,1,0.36,1);
    }
    .rule-list li:nth-child(2) { transition-delay: .18s; }
    .rule-list li:nth-child(3) { transition-delay: .36s; }
    .rule-list li.on { opacity: 1; transform: none; }

    .rules-note {
      font-size: 18px;
      font-weight: 300;
      letter-spacing: .12em;
      color: #fff;
      line-height: 1.8;
      opacity: 0;
      transform: translateY(24px);
      transition: opacity 1.1s cubic-bezier(0.22,1,0.36,1) .45s, transform 1.1s cubic-bezier(0.22,1,0.36,1) .45s;
    }
    .rules-note.on { opacity: 1; transform: none; }

    /* ── CTA ── */
    .cta {
      background: #000;
      padding: 54px 20px;
      text-align: center;
    }

    .cta-title {
      font-size: 16px;
      letter-spacing: .16em;
      color: #fff;
      margin-bottom: 30px;
      opacity: 0;
      transform: translateY(20px);
      transition: opacity .9s cubic-bezier(0.22,1,0.36,1), transform .9s cubic-bezier(0.22,1,0.36,1);
    }
    .cta-title.on { opacity: 1; transform: none; }

    .cta-small {
      font-size: 18px;
      letter-spacing: .2em;
      color: #fff;
      margin-bottom: 5px;
      opacity: 0;
      transform: translateY(20px);
      transition: opacity .9s cubic-bezier(0.22,1,0.36,1), transform .9s cubic-bezier(0.22,1,0.36,1);
    }
    .cta-small.on { opacity: 1; transform: none; }

    .cta-big {
      font-size: 30px;
      font-weight: 300;
      letter-spacing: .04em;
      color: #fff;
      line-height: 1.5;
      margin-bottom: 70px;
      opacity: 0;
      transform: translateY(32px);
      transition: opacity 1.1s cubic-bezier(0.22,1,0.36,1) .15s, transform 1.1s cubic-bezier(0.22,1,0.36,1) .15s;
    }
    .cta-big.on { 
      opacity: 1;
      transform: none;
      font-style: italic;
    }

    .cta-btn {
      display: block;
      width: 100%;
      cursor: pointer;
      opacity: 0;
      transform: translateY(24px);
      transition: opacity 1s cubic-bezier(0.22,1,0.36,1) .35s, transform 1s cubic-bezier(0.22,1,0.36,1) .35s;
    }
    .cta-btn.on { opacity: 1; transform: none; }
    .cta-btn img {
      width: 100%;
      height: auto;
      display: block;
      transition: filter .3s;
    }
    .cta-btn:hover img { filter: brightness(1.1); }

    .cta-instagram {
      margin-top: 40px;
      display: block;
      width: 40px;
      height: auto;
      margin-inline: auto;
      cursor: pointer;
      opacity: 0;
      transform: translateY(24px);
      transition: opacity 1s cubic-bezier(0.22,1,0.36,1) .35s, transform 1s cubic-bezier(0.22,1,0.36,1) .35s;
    }
    .cta-instagram.on { opacity: 1; transform: none; }

    .line-img {
      display: block;
      margin-inline: auto;
    }

    /* ── MALE ── */
    .male {
      background: #000;
      padding: 59px 25px 80px;
      text-align: center;
    }

    .male-intro {
      font-size: 16px;
      letter-spacing: .16em;
      color: #fff;
      margin-bottom: 40px;
      line-height: 1.8;
      opacity: 0;
      transition: opacity 1.2s cubic-bezier(0.22,1,0.36,1);
    }
    .male-intro.on { opacity: 1; }

    .male-conc {
      font-size: 15px;
      font-weight: 300;
      letter-spacing: .1em;
      color: #fff;
      line-height: 2.4;
      margin-bottom: 40px;
      opacity: 0;
      transform: translateY(30px);
      transition: opacity 1.1s cubic-bezier(0.22,1,0.36,1) .1s, transform 1.1s cubic-bezier(0.22,1,0.36,1) .1s;
    }
    .male-conc.on { opacity: 1; transform: none; }

    .mission-label {
      margin-bottom: 0;
      font-size: 16px;
      letter-spacing: .1em;
      color: #fff;
      opacity: 0;
      transform: translateX(-20px);
      transition: opacity 1s cubic-bezier(0.22,1,0.36,1) .1s, transform 1s cubic-bezier(0.22,1,0.36,1) .1s;
    }
    .mission-label.on { opacity: 1; transform: none; }

    .mission-body {
      font-size: 16px;
      font-weight: 300;
      letter-spacing: .1em;
      color: #fff;
      line-height: 2.6;
      margin-bottom: 20px;
      opacity: 0;
      transform: translateY(28px);
      transition: opacity 1.1s cubic-bezier(0.22,1,0.36,1) .2s, transform 1.1s cubic-bezier(0.22,1,0.36,1) .2s;
    }
    .mission-body.on { opacity: 1; transform: none; }

    .quote-line {
      font-size: 15px;
      font-weight: 300;
      letter-spacing: .06em;
      line-height: 2.4;
      color: #fff;
      margin-bottom: 40px;
      opacity: 0;
      transform: translateY(26px);
      transition: opacity 1.1s cubic-bezier(0.22,1,0.36,1) .25s, transform 1.1s cubic-bezier(0.22,1,0.36,1) .25s;
    }
    .quote-line.on { opacity: 1; transform: none; }

    .closing {
      font-size: 14px;
      font-weight: 300;
      letter-spacing: .2em;
      color: #fff;
      margin-top: 12px;
      margin-bottom: 120px;
      opacity: 0;
      transition: opacity 1s cubic-bezier(0.22,1,0.36,1) .4s;
    }
    .closing.on { opacity: 1; }

    .inq-btn {
      display: block;
      width: 100%;
      cursor: pointer;
      opacity: 0;
      transform: translateY(24px);
      transition: opacity 1s cubic-bezier(0.22,1,0.36,1) .5s, transform 1s cubic-bezier(0.22,1,0.36,1) .5s, border-color .3s, background .3s;
      cursor: pointer;
    }
    .inq-btn.on { opacity: 1; transform: none; }
    .inq-btn:hover img { filter: brightness(1.1); }

    /* ── BANNERS ── */
    .banners {
      background: #000;
      padding: 100px 25px 40px;
    }

    .escura-banner-title {
      padding-left: 10px;
      font-size: 12px;
      letter-spacing: .16em;
      color: #fff;
      margin-bottom: 0;
      line-height: 1.8;
      opacity: 0;
      transition: opacity 1.2s cubic-bezier(0.22,1,0.36,1);
    }
    .escura-banner-title.on { opacity: 1; }

    .escura-banner_wrap {
      padding: 0 50px;
    }

    .group-btn {
      display: block;
      width: 100%;
      margin-bottom: 16px;
      opacity: 0;
      transform: translateY(30px);
      transition: opacity 1s cubic-bezier(0.22,1,0.36,1), transform 1s cubic-bezier(0.22,1,0.36,1);
    }
    .group-btn.on { opacity: 1; transform: none; }
    .group-btn img {
      width: 100%;
      height: auto;
      display: block;
      transition: filter .3s;
    }
    .group-btn:hover img { filter: brightness(1.08); }

    .aff-grid {
      padding: 0 50px;
      display: grid;
      grid-template-columns: repeat(3, 1fr);
      gap: 6px;
    }

    .aff-item {
      display: block;
      border-radius: 4px;
      overflow: hidden;
      cursor: pointer;
      opacity: 0;
      transform: translateY(28px);
      transition: opacity .9s cubic-bezier(0.22,1,0.36,1), transform .9s cubic-bezier(0.22,1,0.36,1), filter .25s, scale .25s;
    }
    .aff-item:nth-child(1) { transition-delay: .0s,  .0s,  0s, 0s; }
    .aff-item:nth-child(2) { transition-delay: .12s, .12s, 0s, 0s; }
    .aff-item:nth-child(3) { transition-delay: .24s, .24s, 0s, 0s; }
    .aff-item:nth-child(4) { transition-delay: .36s, .36s, 0s, 0s; }
    .aff-item.on { opacity: 1; transform: none; }
    .aff-item:hover { transform: scale(1.04) !important; filter: brightness(1.08); }
    .aff-item img { width: 100%; height: auto; display: block; }

    /* ── FOOTER ── */
    footer {
      background: #000;
      border-top: 1px solid rgba(255,255,255,.08);
      padding: 28px 20px;
      text-align: center;
    }

    .ft-copy {
      font-size: 9.5px;
      letter-spacing: .15em;
      color: rgba(255,255,255,.3);
      text-transform: uppercase;
      opacity: 0;
      transition: opacity 1s cubic-bezier(0.22,1,0.36,1) .3s;
    }
    .ft-copy.on { opacity: 1; }

    /* ── SECTION SEPARATOR ── */