    :root{
      --black:#070707;
      --black2:#101010;
      --black3:#191919;
      --orange:#ff6a00;
      --orange2:#ff8a00;
      --amber:#ffb13b;
      --yellow:#ffd000;
      --white:#ffffff;
      --text:#f7f0e7;
      --muted:#a59a8d;
      --panel:rgba(255,255,255,.07);
      --line:rgba(255,106,0,.34);
      --glow:0 0 32px rgba(255,106,0,.34);
    }

    *{box-sizing:border-box}
    html{scroll-behavior:smooth}
    body{
      margin:0;
      background:#050505;
      color:var(--text);
      font-family:-apple-system,BlinkMacSystemFont,"Hiragino Sans","Yu Gothic","Yu Gothic UI",sans-serif;
      overflow-x:hidden;
    }
    a{color:inherit;text-decoration:none}

    .page{
      width:min(430px,100%);
      margin:0 auto;
      min-height:100vh;
      position:relative;
      overflow:hidden;
      padding-bottom:76px;
      background:
        radial-gradient(circle at 78% 8%,rgba(255,106,0,.42),transparent 165px),
        radial-gradient(circle at 7% 32%,rgba(255,138,0,.18),transparent 210px),
        linear-gradient(180deg,#060606 0%,#111 40%,#080808 100%);
    }

    .page::before{
      content:"";
      position:absolute;
      inset:0;
      pointer-events:none;
      background-image:
        linear-gradient(rgba(255,255,255,.035) 1px,transparent 1px),
        linear-gradient(90deg,rgba(255,255,255,.028) 1px,transparent 1px);
      background-size:22px 22px;
      mask-image:linear-gradient(180deg,black 0 860px,transparent 1120px);
    }

    .base-light{
      position:absolute;
      inset:0;
      pointer-events:none;
      overflow:hidden;
    }
    .base-light::before{
      content:"";
      position:absolute;
      right:-92px;
      top:80px;
      width:280px;
      height:540px;
      background:
        repeating-linear-gradient(90deg,rgba(255,106,0,.2) 0 4px,transparent 4px 14px),
        linear-gradient(180deg,rgba(255,106,0,.26),transparent);
      clip-path:polygon(34% 0,100% 0,66% 100%,0 100%);
      opacity:.9;
    }
    .base-light::after{
      content:"GAME ROOM";
      position:absolute;
      left:-22px;
      top:108px;
      writing-mode:vertical-rl;
      color:rgba(255,255,255,.045);
      font-size:94px;
      line-height:.76;
      letter-spacing:-.1em;
      font-weight:1000;
    }

    .topbar{
      position:relative;
      z-index:5;
      height:60px;
      display:grid;
      grid-template-columns:1fr auto;
      align-items:center;
      gap:10px;
      padding:0 14px;
      background:rgba(7,7,7,.82);
      border-bottom:1px solid var(--line);
      backdrop-filter:blur(14px);
    }
    .logo{display:flex;align-items:center;min-width:0}
    .logo img{height:22px;width:auto;display:block;filter:drop-shadow(0 0 6px rgba(255,106,0,.5))}
    .login{height:34px;display:grid;place-items:center;background:rgba(255,255,255,.1);border:1px solid rgba(255,255,255,.14);color:#fff;padding:0 12px;font-size:12px;font-weight:1000}

    .hero{
      position:relative;
      z-index:2;
      padding:0 14px 0;
      overflow:hidden;
    }

    /* ── LP First Section ── */
    .lp-first{
      position:relative;
      z-index:3;
      overflow:hidden;
    }
    .lp-first-img{
      position:absolute;
      inset:0;
      width:100%;
      height:100%;
      object-fit:cover;
      object-position:center top;
      display:block;
      z-index:0;
    }
    .lp-first::before{
      content:"";
      position:absolute;
      inset:0;
      background:linear-gradient(
        180deg,
        rgba(0,0,0,.12) 0%,
        rgba(0,0,0,.25) 35%,
        rgba(0,0,0,.7) 60%,
        rgba(5,5,5,.95) 85%,
        #050505 100%
      );
      pointer-events:none;
      z-index:1;
    }
    .lp-first-inner{
      position:relative;
      z-index:2;
      display:flex;
      flex-direction:column;
      justify-content:flex-end;
      min-height:340px;
      padding:0 20px 32px;
    }
    .lp-tag{
      display:inline-flex;
      align-items:center;
      gap:6px;
      margin:0 0 14px;
      font-size:9px;
      font-weight:1000;
      letter-spacing:.22em;
      color:var(--amber);
      text-transform:uppercase;
    }
    .lp-tag::before{content:"\25B6";font-size:8px;color:var(--orange)}
    .lp-headline{
      margin:0 0 14px;
    }
    .lp-hl-eyebrow{
      display:block;
      font-size:10px;
      font-weight:1000;
      letter-spacing:.26em;
      color:var(--amber);
      text-transform:uppercase;
      margin-bottom:10px;
      text-shadow:0 1px 6px rgba(0,0,0,.9);
    }
    .lp-hl-jp{
      display:block;
      font-size:34px;
      font-weight:1000;
      letter-spacing:-.03em;
      line-height:1.25;
      margin-bottom:0;
      white-space:nowrap;
      color:#fff;
      text-shadow:0 2px 12px rgba(0,0,0,.9),0 0 2px rgba(0,0,0,.8);
    }
    .lp-hl-main{
      display:block;
      font-size:34px;
      font-weight:1000;
      letter-spacing:-.03em;
      line-height:1.25;
      white-space:nowrap;
      color:#fff;
      text-shadow:0 2px 12px rgba(0,0,0,.9),0 0 2px rgba(0,0,0,.8);
    }
    .lp-hl-solid{
      color:var(--orange);
      text-shadow:0 0 16px rgba(255,140,0,.7);
    }
    .lp-desc{
      margin:0;
      font-size:12px;
      line-height:1.85;
      font-weight:760;
      color:rgba(255,255,255,.7);
      text-shadow:0 1px 6px rgba(0,0,0,.9);
    }

    /* ── Hero Visual (image + button) ── */
    .hero-visual{
      position:relative;
      width:calc(100% + 28px);
      margin-left:-14px;
      overflow:hidden;
      min-height:260px;
      background:#0a0a0a;
    }
    .hero-img{
      position:relative;
      display:block;
      width:100%;
      height:auto;
      object-fit:cover;
    }

    /* ── AI Button wrapper (常時グロー) ── */
    .hero-ai-wrapper{
      --accent-1:#5fa;
      --accent-2:#67ff7b;
      --accent-3:#fbff00;
      --accent-4:#a6ffe466;
      --light-1:#5afa8840;
      --light-2:#8eff6135;
      --duration:3s;
      --transition:0.5s;

      position:absolute;
      bottom:28px;
      left:50%;
      transform:translateX(-50%);
      display:flex;
      justify-content:center;
      align-items:center;
      width:max-content;
      height:max-content;
      z-index:10;
    }

    .hero-ai-wrapper .light-1,
    .hero-ai-wrapper .light-2{
      pointer-events:none;
      position:absolute;
      top:-40px;
      left:-60px;
      width:180px;
      height:120px;
      border-radius:50%;
      background-color:var(--light-1);
      filter:blur(32px);
      z-index:1;
      opacity:.7;
      transition:opacity var(--transition) ease;
    }
    .hero-ai-wrapper .light-2{
      top:auto;
      bottom:-40px;
      left:auto;
      right:-50px;
      width:140px;
      height:70px;
      background-color:var(--light-2);
      z-index:-1;
      opacity:.5;
    }

    .hero-ai-wrapper .ai-bg{
      position:absolute;
      z-index:-1;
      fill:none;
      filter:drop-shadow(0px 0px 4px var(--accent-3));
      transition:filter var(--transition) ease;
    }

    .hero-ai-wrapper .line-bg{
      stroke:#fff1;
      stroke-width:.5;
    }

    .hero-ai-wrapper .line{
      stroke-width:.5;
      stroke-dasharray:16 56;
      animation:ai-dash var(--duration) ease-out infinite;
    }
    .hero-ai-wrapper .line:nth-child(odd){
      animation-direction:normal;
      animation-delay:calc(var(--duration) * 0.1);
    }

    .hero-ai-wrapper .dot{
      fill:var(--accent-1);
      opacity:1;
      animation:ai-dot-opac calc(var(--duration) * 0.5) linear infinite;
    }
    .hero-ai-wrapper .dot:nth-child(odd){
      animation-delay:calc(var(--duration) * 0.1);
    }

    .hero-ai-wrapper .ai-btn{
      width:max-content;
      box-sizing:border-box;
      display:flex;
      align-items:center;
      justify-content:center;
      min-width:340px;
      min-height:96px;
      padding:0 48px;
      border-radius:12px;
      text-decoration:none;
      position:relative;
      z-index:2;
      background-color:#000;
      background-image:url(data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAADIAAAAyCAMAAAAp4XiDAAAAUVBMVEWFhYWDg4N3d3dtbW17e3t1dXWBgYGHh4d5eXlzc3OLi4ubm5uVlZWPj4+NjY19fX2JiYl/f39ra2uRkZGZmZlpaWmXl5dvb29xcXGTk5NnZ2c8TV1mAAAAG3RSTlNAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEAvEOwtAAAFVklEQVR4XpWWB67c2BUFb3g557T/hRo9/WUMZHlgr4Bg8Z4qQgQJlHI4A8SzFVrapvmTF9O7dmYRFZ60YiBhJRCgh1FYhiLAmdvX0CzTOpNE77ME0Zty/nWWzchDtiqrmQDeuv3powQ5ta2eN0FY0InkqDD73lT9c9lEzwUNqgFHs9VQce3TVClFCQrSTfOiYkVJQBmpbq2L6iZavPnAPcoU0dSw0SUTqz/GtrGuXfbyyBniKykOWQWGqwwMA7QiYAxi+IlPdqo+hYHnUt5ZPfnsHJyNiDtnpJyayNBkF6cWoYGAMY92U2hXHF/C1M8uP/ZtYdiuj26UdAdQQSXQErwSOMzt/XWRWAz5GuSBIkwG1H3FabJ2OsUOUhGC6tK4EMtJO0ttC6IBD3kM0ve0tJwMdSfjZo+EEISaeTr9P3wYrGjXqyC1krcKdhMpxEnt5JetoulscpyzhXN5FRpuPHvbeQaKxFAEB6EN+cYN6xD7RYGpXpNndMmZgM5Dcs3YSNFDHUo2LGfZuukSWyUYirJAdYbF3MfqEKmjM+I2EfhA94iG3L7uKrR+GdWD73ydlIB+6hgref1QTlmgmbM3/LeX5GI1Ux1RWpgxpLuZ2+I+IjzZ8wqE4nilvQdkUdfhzI5QDWy+kw5Wgg2pGpeEVeCCA7b85BO3F9DzxB3cdqvBzWcmzbyMiqhzuYqtHRVG2y4x+KOlnyqla8AoWWpuBoYRxzXrfKuILl6SfiWCbjxoZJUaCBj1CjH7GIaDbc9kqBY3W/Rgjda1iqQcOJu2WW+76pZC9QG7M00dffe9hNnseupFL53r8F7YHSwJWUKP2q+k7RdsxyOB11n0xtOvnW4irMMFNV4H0uqwS5ExsmP9AxbDTc9JwgneAT5vTiUSm1E7BSflSt3bfa1tv8Di3R8n3Af7MNWzs49hmauE2wP+ttrq+AsWpFG2awvsuOqbipWHgtuvuaAE+A1Z/7gC9hesnr+7wqCwG8c5yAg3AL1fm8T9AZtp/bbJGwl1pNrE7RuOX7PeMRUERVaPpEs+yqeoSmuOlokqw49pgomjLeh7icHNlG19yjs6XXOMedYm5xH2YxpV2tc0Ro2jJfxC50ApuxGob7lMsxfTbeUv07TyYxpeLucEH1gNd4IKH2LAg5TdVhlCafZvpskfncCfx8pOhJzd76bJWeYFnFciwcYfubRc12Ip/ppIhA1/mSZ/RxjFDrJC5xifFjJpY2Xl5zXdguFqYyTR1zSp1Y9p+tktDYYSNflcxI0iyO4TPBdlRcpeqjK/piF5bklq77VSEaA+z8qmJTFzIWiitbnzR794USKBUaT0NTEsVjZqLaFVqJoPN9ODG70IPbfBHKK+/q/AWR0tJzYHRULOa4MP+W/HfGadZUbfw177G7j/OGbIs8TahLyynl4X4RinF793Oz+BU0saXtUHrVBFT/DnA3ctNPoGbs4hRIjTok8i+algT1lTHi4SxFvONKNrgQFAq2/gFnWMXgwffgYMJpiKYkmW3tTg3ZQ9Jq+f8XN+A5eeUKHWvJWJ2sgJ1Sop+wwhqFVijqWaJhwtD8MNlSBeWNNWTa5Z5kPZw5+LbVT99wqTdx29lMUH4OIG/D86ruKEauBjvH5xy6um/Sfj7ei6UUVk4AIl3MyD4MSSTOFgSwsH/QJWaQ5as7ZcmgBZkzjjU1UrQ74ci1gWBCSGHtuV1H2mhSnO3Wp/3fEV5a+4wz//6qy8JxjZsmxxy5+4w9CDNJY09T072iKG0EnOS0arEYgXqYnXcYHwjTtUNAcMelOd4xpkoqiTYICWFq0JSiPfPDQdnt+4/wuqcXY47QILbgAAAABJRU5ErkJggg==),
        linear-gradient(to bottom,#fff1,transparent);
      color:#fff;
      border:2px solid var(--accent-2);
      font-size:26px;
      font-weight:800;
      font-family:-apple-system,"Hiragino Sans","Yu Gothic UI",sans-serif;
      letter-spacing:.06em;
      cursor:pointer;
      background-color:#0a1a0a;
      background-image:linear-gradient(160deg,#0d2a0d 0%,#000 50%,#0a180a 100%);
      color:#fff;
      text-shadow:0 0 18px #55ff8888,0 1px 0 #000;
      animation:ai-pulse var(--duration) ease-in-out infinite;
      border-color:var(--accent-2);
      box-shadow:
        0 0 0 1px #55ff4422,
        0 0 28px 4px #55ff6644,
        0 0 60px 0px #5fa444,
        inset 0 1px 0 #55ff6633,
        inset 0 -1px 0 #00000088,
        inset -1px 0 0 #55ff4422,
        inset 1px 0 0 #55ff4422;
    }
    .hero-ai-wrapper .ai-btn:hover{
      color:#fff;
      border-color:#88ffaa;
      text-shadow:0 0 24px #5fa,0 1px 0 #000;
      box-shadow:
        0 0 0 1px #67ff7b44,
        0 0 40px 8px #55ff6688,
        0 0 80px 0px #5fa666,
        inset 0 1px 0 #55ff6655,
        inset 0 -1px 0 #00000088,
        inset -1px 0 0 #55ff4433,
        inset 1px 0 0 #55ff4433;
    }
    .hero-ai-wrapper .ai-btn .txt-1{
      position:absolute;
      opacity:1;
    }
    .hero-ai-wrapper .ai-btn .txt-2{
      position:absolute;
      opacity:0;
    }

    @keyframes ai-dash{
      0%{stroke-width:0;stroke-dashoffset:10;stroke:var(--accent-4)}
      50%{stroke-width:.5;stroke-dashoffset:88;stroke:var(--accent-2)}
      100%{stroke-width:0;stroke-dashoffset:166;stroke:var(--accent-4)}
    }
    @keyframes ai-dot-opac{
      0%,100%{opacity:.1}
      20%{opacity:1}
    }
    @keyframes ai-pulse{
      0%,100%{
        box-shadow:
          0 0 0 1px #55ff4422,
          0 0 18px 2px #55ff6633,
          0 0 40px 0px #5fa333,
          inset 0 1px 0 #55ff6622,
          inset 0 -1px 0 #00000088;
        border-color:#55ff6655;
      }
      50%{
        box-shadow:
          0 0 0 2px #67ff7b55,
          0 0 36px 8px #55ff6688,
          0 0 80px 0px #5fa888,
          inset 0 1px 0 #55ff6655,
          inset 0 -1px 0 #00000088;
        border-color:var(--accent-2);
      }
      85%{border-color:#67ff7b99}
    }
    .hero::after{display:none}
    .hero-inner{position:relative;z-index:3}
    .label{display:inline-flex;align-items:center;gap:8px;font-size:10px;font-weight:1000;letter-spacing:.15em;color:var(--amber);margin-bottom:16px;text-shadow:0 0 16px rgba(255,106,0,.5)}
    .label::before{content:"";width:36px;height:9px;background:var(--orange);box-shadow:0 0 18px rgba(255,106,0,.8)}
    .hero h1{margin:0;font-size:clamp(42px,12.5vw,60px);line-height:.94;letter-spacing:-.09em;font-weight:1000;color:#fff;text-shadow:0 0 28px rgba(255,106,0,.16)}
    .hero h1 span{display:inline-block;margin-top:8px;padding:0 8px 9px;background:var(--orange);color:#111;box-shadow:10px 10px 0 rgba(255,255,255,.08),0 0 24px rgba(255,106,0,.48)}
    .hero-copy{width:250px;margin:24px 0 18px;color:rgba(255,255,255,.76);font-size:14px;line-height:1.78;font-weight:760;border-left:4px solid var(--orange);padding-left:12px}
    .hero-actions{display:grid;gap:9px;width:226px;position:relative;z-index:4}
    .btn{min-height:54px;display:grid;place-items:center;padding:0 14px;font-size:15px;font-weight:1000;border:0}
    .btn-main{background:linear-gradient(180deg,var(--orange2),var(--orange));color:#111;box-shadow:inset 0 -6px 0 rgba(0,0,0,.22),0 0 24px rgba(255,106,0,.3)}
    .btn-main::before{content:"\25B6";margin-right:8px}.btn-main{display:flex;align-items:center;justify-content:center}
    .btn-sub{background:rgba(255,255,255,.1);color:#fff;border:1px solid rgba(255,255,255,.16);box-shadow:inset 0 -6px 0 rgba(255,255,255,.035)}

    /* GAME ROOMらしい“基地設備” */
    .main-monitor{
      position:absolute;
      z-index:3;
      right:10px;
      bottom:84px;
      width:214px;
      background:rgba(12,12,12,.96);
      border:1px solid var(--line);
      box-shadow:-10px 10px 0 rgba(255,106,0,.34),0 0 34px rgba(255,106,0,.16);
      transform:rotate(1.5deg);
      overflow:hidden;
    }
    .monitor-head{height:34px;display:flex;justify-content:space-between;align-items:center;padding:0 10px;background:var(--orange);color:#111;font-size:10px;font-weight:1000;letter-spacing:.08em}
    .monitor-body{padding:10px}
    .monitor-screen{background:#fff;color:#111;margin-bottom:8px}.screen-img{height:102px;display:grid;place-items:center;font-size:46px;background:linear-gradient(135deg,#ffd000,#ff4d00);border-bottom:6px solid #111}.screen-body{padding:8px}.chip{display:inline-block;background:#111;color:#fff;padding:4px 7px;font-size:8px;font-weight:1000;margin-bottom:5px}.screen-title{font-size:14px;font-weight:1000;line-height:1.25;margin-bottom:6px}.screen-row{display:flex;justify-content:space-between;color:var(--orange);font-size:10px;font-weight:1000}
    .mini-list{display:grid;gap:6px}.mini{display:grid;grid-template-columns:25px 1fr auto;gap:7px;align-items:center;padding:6px;background:rgba(255,255,255,.08);border-left:5px solid var(--orange);font-size:9px;font-weight:900}.mini i{width:25px;height:25px;display:grid;place-items:center;background:var(--orange);color:#111;font-style:normal}.mini b{color:#ffb06b;font-size:9px}

    .switch-panel{
      position:absolute;
      z-index:4;
      left:14px;
      bottom:108px;
      width:122px;
      display:grid;
      grid-template-columns:repeat(2,1fr);
      gap:7px;
    }
    .switch{height:44px;display:grid;place-items:center;background:rgba(255,255,255,.1);border:1px solid rgba(255,255,255,.12);color:#fff;font-size:10px;font-weight:1000;box-shadow:inset 0 -5px 0 rgba(0,0,0,.22)}
    .switch.on{background:var(--orange);color:#111;box-shadow:0 0 18px rgba(255,106,0,.34),inset 0 -5px 0 rgba(0,0,0,.2)}

    .ticker{position:relative;margin:0 -14px;height:40px;background:var(--orange);color:#111;display:flex;align-items:center;overflow:hidden;font-size:13px;font-weight:1000;white-space:nowrap;z-index:5}.ticker span{display:inline-block;padding-left:100%;animation:ticker 16s linear infinite}@keyframes ticker{to{transform:translateX(-100%)}}

    .main{position:relative;z-index:3;padding:22px 0 0;background:#0b0b0b}

    .zone{margin:0 14px 26px}
    .zone-head{display:flex;align-items:center;gap:8px;margin-bottom:14px;position:relative}
    .zone-head strong{
      position:relative;
      background:transparent;
      color:#fff;
      padding:0;
      font-size:13px;
      font-weight:1000;
      letter-spacing:.18em;
      white-space:nowrap;
      font-family:monospace;
      text-shadow:0 0 12px rgba(255,106,0,.5);
    }
    .zone-head strong::before{
      content:"//";
      color:var(--orange);
      margin-right:6px;
      opacity:.8;
    }
    .zone-head span{
      font-size:10px;
      font-weight:900;
      color:rgba(255,255,255,.6);
      white-space:nowrap;
      letter-spacing:.1em;
      font-family:monospace;
      flex-shrink:0;
    }
    .zone-head::after{
      content:"";
      height:1px;
      flex:1;
      background:linear-gradient(90deg,rgba(255,106,0,.5),rgba(255,106,0,.1) 50%,transparent);
    }

    .entrance-message{background:rgba(255,255,255,.065);color:#fff;border-left:10px solid var(--orange);padding:17px;box-shadow:0 9px 0 rgba(0,0,0,.28);position:relative;overflow:hidden;border-top:1px solid rgba(255,255,255,.08)}.entrance-message::after{content:"BASE";position:absolute;right:-8px;bottom:-14px;font-size:66px;font-weight:1000;letter-spacing:-.08em;color:rgba(255,255,255,.045)}.entrance-message h2{position:relative;z-index:1;margin:0 0 9px;font-size:24px;line-height:1.32;letter-spacing:-.05em;font-weight:1000}.entrance-message p{position:relative;z-index:1;margin:0;color:rgba(255,255,255,.74);font-size:13px;line-height:1.85;font-weight:760}

    .section-visual{margin:0 -14px 12px;overflow:hidden}
    .section-visual img{width:100%;height:auto;display:block}
    .easy-start-visual{margin:0 -14px 0;overflow:hidden}
    .easy-start-visual img{width:100%;height:180px;object-fit:cover;object-position:center 30%;display:block}
    .easy-start-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:0;border-top:2px solid var(--orange)}
    .easy-start-card{display:flex;flex-direction:column;align-items:flex-start;text-align:left;padding:16px 10px 14px;background:rgba(0,0,0,.55);border-right:1px solid rgba(255,106,0,.2);position:relative}
    .easy-start-card:last-child{border-right:none}
    .easy-start-card::after{content:"";position:absolute;top:0;left:0;right:0;height:3px;background:var(--orange);opacity:0;transition:opacity .3s}
    .easy-start-card:hover::after{opacity:1}
    .easy-start-num{display:block;font-size:22px;font-weight:1000;color:var(--orange);letter-spacing:-.04em;line-height:1;margin-bottom:6px;font-style:italic;opacity:.9}
    .easy-start-body b{display:block;color:#fff;font-size:12px;font-weight:1000;line-height:1.35;margin-bottom:4px;letter-spacing:.12em}
    .easy-start-body p{margin:0;color:rgba(255,255,255,.75);font-size:11px;line-height:1.6;font-weight:600}

    .play-scene-visual{margin:0 -14px 0;overflow:hidden}
    .play-scene-visual img{width:100%;height:auto;display:block}
    .play-scene-grid{display:grid;gap:8px}
    .play-scene{
      display:grid;
      grid-template-columns:80px 1fr;
      align-items:center;
      gap:0;
      position:relative;
      overflow:hidden;
      background:
        repeating-linear-gradient(0deg,transparent,transparent 19px,rgba(255,255,255,.018) 19px,rgba(255,255,255,.018) 20px),
        rgba(0,0,0,.55);
      border:1px solid rgba(255,106,0,.3);
      box-shadow:0 4px 0 rgba(0,0,0,.4), inset 0 0 20px rgba(255,106,0,.04);
    }
    .play-scene::after{
      content:"";
      position:absolute;
      inset:0;
      background:linear-gradient(90deg,rgba(255,106,0,.06) 0%,transparent 40%);
      pointer-events:none;
    }
    .play-scene-time{
      display:flex;
      align-items:center;
      justify-content:center;
      height:100%;
      padding:16px 0;
      font-size:16px;
      font-weight:1000;
      font-family:monospace;
      color:var(--orange);
      letter-spacing:.08em;
      text-shadow:0 0 12px rgba(255,106,0,.8), 0 0 28px rgba(255,106,0,.4);
      border-right:1px solid rgba(255,106,0,.3);
      background:rgba(255,60,0,.06);
      position:relative;
    }
    .play-scene-time::before{
      content:"";
      position:absolute;
      top:8px;right:8px;
      width:5px;height:5px;
      border-radius:50%;
      background:var(--orange);
      box-shadow:0 0 6px var(--orange);
      animation:ai-dot-opac 1.8s ease-in-out infinite;
    }
    .play-scene-body{padding:14px 12px;position:relative;z-index:1}
    .play-scene-body b{
      display:block;
      color:#fff;
      font-size:12px;
      font-weight:1000;
      margin-bottom:5px;
      letter-spacing:.02em;
    }
    .play-scene-body p{margin:0;color:rgba(255,255,255,.78);font-size:12px;line-height:1.65;font-weight:600}

    .monitor-zone{position:relative;overflow:hidden;border:1px solid rgba(255,140,0,.35);box-shadow:0 0 24px rgba(255,120,0,.18),0 9px 0 rgba(0,0,0,.3);background:linear-gradient(135deg,#1a0d00,#0d0d0d)}.monitor-zone::before{content:"";position:absolute;inset:0;background:linear-gradient(120deg,rgba(255,100,0,.08) 0%,transparent 55%);pointer-events:none}.monitor-feature{display:grid;grid-template-columns:auto 1fr;gap:0;position:relative;z-index:1}.feature-img{width:120px;height:120px;margin:14px;flex-shrink:0;background:#000;border:2px solid rgba(255,140,0,.4);box-shadow:0 0 16px rgba(255,100,0,.25);display:flex;align-items:center;justify-content:center;overflow:hidden}.feature-img img{width:100%;height:100%;object-fit:contain;display:block}.feature-body{padding:14px 14px 14px 0;display:flex;flex-direction:column;justify-content:center;gap:8px;min-width:0}.feature-body small{display:inline-flex;align-items:center;gap:5px;background:var(--orange);color:#111;padding:4px 9px;font-size:9px;font-weight:1000;letter-spacing:.14em;width:fit-content}.feature-body small::before{content:"&#x25CF;";font-size:6px}.feature-body h3{margin:0;font-size:18px;line-height:1.25;letter-spacing:-.03em;font-weight:1000;color:#fff;text-shadow:0 0 12px rgba(255,120,0,.4);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.feature-body p{margin:0;color:rgba(255,255,255,.72);font-size:11px;line-height:1.6;font-weight:500;display:-webkit-box;-webkit-line-clamp:3;line-clamp:3;-webkit-box-orient:vertical;overflow:hidden}.feature-body a{display:inline-flex;align-items:center;gap:6px;background:var(--orange);color:#111;padding:8px 14px;font-size:10px;font-weight:1000;letter-spacing:.1em;width:fit-content;text-decoration:none;box-shadow:0 0 12px rgba(255,120,0,.5)}

    .cat-zone{display:grid;gap:12px}
    .cat-block{}
    .cat-row-head{
      position:relative;
      display:flex;
      align-items:center;
      gap:10px;
      padding:10px 10px 10px 10px;
      margin-bottom:8px;
      overflow:hidden;
      background:
        repeating-linear-gradient(0deg,transparent,transparent 9px,rgba(255,255,255,.015) 9px,rgba(255,255,255,.015) 10px),
        rgba(0,0,0,.6);
      border:1px solid rgba(255,255,255,.08);
    }
    .cat-row-head::before,.cat-row-head::after{
      content:"";
      position:absolute;
      width:8px;height:8px;
      border-color:var(--orange);
      border-style:solid;
      opacity:.8;
    }
    .cat-row-head::before{top:4px;left:4px;border-width:1.5px 0 0 1.5px}
    .cat-row-head::after{bottom:4px;right:4px;border-width:0 1.5px 1.5px 0}
    .cat-row-label{font-size:8px;font-weight:1000;font-family:monospace;color:var(--orange);letter-spacing:.16em;opacity:.9;flex-shrink:0}
    .cat-row-name{font-size:14px;font-weight:1000;color:#fff;flex:1;letter-spacing:-.01em}
    .cat-row-more{font-size:9px;font-weight:1000;color:rgba(255,255,255,.85);text-decoration:none;letter-spacing:.06em;white-space:nowrap;font-family:monospace}
    .cat-row-more:hover{color:var(--orange)}
    .cat-row-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:6px}
    .cat-game{display:flex;flex-direction:column;gap:5px;text-decoration:none}
    .cat-game-thumb{aspect-ratio:1/1;overflow:hidden;background:rgba(255,255,255,.06);border:1px solid rgba(255,255,255,.08)}
    .cat-game-thumb img{width:100%;height:100%;object-fit:cover;display:block}
    .cat-game span{font-size:11px;font-weight:1000;color:rgba(255,255,255,.9);line-height:1.3;display:-webkit-box;-webkit-line-clamp:2;line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}
    .cat-game:hover .cat-game-thumb{border-color:rgba(255,106,0,.5)}
    .cat-game:hover span{color:#fff}

    .ranking{display:grid;gap:8px}
    .rank-card{position:relative;display:grid;grid-template-columns:72px 1fr;gap:0;overflow:hidden;box-shadow:0 6px 0 rgba(0,0,0,.35);border:1px solid rgba(255,255,255,.08)}
    .rank-card-no{position:absolute;right:-4px;bottom:-10px;font-size:52px;font-weight:1000;line-height:1;letter-spacing:-.06em;pointer-events:none;opacity:.18;font-style:italic}
    .rank-card-thumb{width:72px;height:72px;overflow:hidden;flex-shrink:0;align-self:center}
    .rank-card-thumb img{width:100%;height:100%;object-fit:cover;object-position:center;display:block}
    .rank-card-body{padding:10px 12px;position:relative;z-index:1;display:flex;flex-direction:column;justify-content:center;gap:3px}
    .rank-card-badge{display:inline-block;font-size:10px;font-weight:1000;letter-spacing:.1em;padding:3px 8px;width:fit-content}
    .rank-card-name{display:block;font-size:15px;font-weight:1000;color:#fff;line-height:1.3;letter-spacing:-.02em}
    .rank-card-desc{margin:0;font-size:11px;color:rgba(255,255,255,.72);font-weight:600;line-height:1.55;display:-webkit-box;-webkit-line-clamp:2;line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}

    .ranking .rank-card:nth-child(1){background:linear-gradient(135deg,#1a1200,#0d0900);border-color:rgba(255,210,0,.4)}
    .ranking .rank-card:nth-child(1) .rank-card-no{color:#ffd000}
    .ranking .rank-card:nth-child(1) .rank-card-badge{background:#ffd000;color:#111}
    .ranking .rank-card:nth-child(1)::before{content:"";position:absolute;inset:0;background:linear-gradient(90deg,rgba(255,210,0,.12),transparent 60%);pointer-events:none}

    .ranking .rank-card:nth-child(2){background:linear-gradient(135deg,#111418,#0a0c10);border-color:rgba(180,200,220,.3)}
    .ranking .rank-card:nth-child(2) .rank-card-no{color:#b0bec5}
    .ranking .rank-card:nth-child(2) .rank-card-badge{background:#b0bec5;color:#111}
    .ranking .rank-card:nth-child(2)::before{content:"";position:absolute;inset:0;background:linear-gradient(90deg,rgba(180,200,220,.08),transparent 60%);pointer-events:none}

    .ranking .rank-card:nth-child(3){background:linear-gradient(135deg,#120a00,#0a0600);border-color:rgba(205,127,50,.3)}
    .ranking .rank-card:nth-child(3) .rank-card-no{color:#cd7f32}
    .ranking .rank-card:nth-child(3) .rank-card-badge{background:#cd7f32;color:#fff}
    .ranking .rank-card:nth-child(3)::before{content:"";position:absolute;inset:0;background:linear-gradient(90deg,rgba(205,127,50,.08),transparent 60%);pointer-events:none}

    .shelf-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:6px}
    .shelf{
      position:relative;
      display:flex;
      flex-direction:column;
      justify-content:flex-end;
      padding:12px 10px 10px 10px;
      min-height:76px;
      overflow:hidden;
      background:
        repeating-linear-gradient(0deg,transparent,transparent 9px,rgba(255,255,255,.015) 9px,rgba(255,255,255,.015) 10px),
        rgba(0,0,0,.6);
      border:1px solid rgba(255,255,255,.08);
      box-shadow:0 4px 0 rgba(0,0,0,.4);
      text-decoration:none;
      transition:border-color .2s, box-shadow .2s;
    }
    .shelf::before,.shelf::after{
      content:"";
      position:absolute;
      width:10px;
      height:10px;
      border-color:var(--orange);
      border-style:solid;
      opacity:.8;
    }
    .shelf::before{top:5px;left:5px;border-width:1.5px 0 0 1.5px}
    .shelf::after{bottom:5px;right:5px;border-width:0 1.5px 1.5px 0}
    .shelf:hover{
      border-color:rgba(255,106,0,.4);
      box-shadow:0 4px 0 rgba(0,0,0,.4), 0 0 16px rgba(255,106,0,.15);
    }
    .shelf:hover::before,.shelf:hover::after{opacity:1}
    .shelf em{
      display:block;
      font-style:normal;
      font-size:9px;
      font-weight:1000;
      font-family:monospace;
      color:var(--orange);
      letter-spacing:.14em;
      margin-bottom:4px;
      opacity:.8;
    }
    .shelf span{
      display:block;
      font-size:15px;
      font-weight:1000;
      color:#fff;
      line-height:1;
      letter-spacing:-.02em;
    }
    .shelf small{
      position:absolute;
      top:8px;
      right:8px;
      font-size:8px;
      font-weight:1000;
      letter-spacing:.16em;
      color:rgba(255,255,255,.2);
    }
    .shelf::after{
      content:"\25B6";
      position:absolute;
      bottom:8px;
      right:10px;
      font-size:8px;
      color:var(--orange);
      opacity:.6;
    }

    .switches{display:grid;gap:8px}.mood{min-height:106px;background:rgba(255,255,255,.08);border-left:8px solid var(--orange);box-shadow:0 8px 0 rgba(0,0,0,.25);padding:14px 82px 14px 14px;position:relative;overflow:hidden;border-top:1px solid rgba(255,255,255,.08)}.mood::after{content:"";position:absolute;right:-26px;top:-18px;width:118px;height:140px;background:var(--orange);transform:skewX(-15deg);box-shadow:0 0 30px rgba(255,106,0,.25)}.mood h3,.mood p,.mood a{position:relative;z-index:1}.mood h3{margin:0 0 6px;font-size:16px;line-height:1.35;font-weight:1000;color:#fff}.mood p{margin:0;color:rgba(255,255,255,.58);font-size:11px;line-height:1.65;font-weight:760}.mood a{display:inline-flex;background:#111;color:#fff;margin-top:10px;padding:7px 11px;font-size:10px;font-weight:1000}.mood .emoji{position:absolute;z-index:1;right:17px;top:50%;transform:translateY(-50%);font-size:42px}

    @keyframes puzzleBorderPulse{
      0%,100%{box-shadow:0 0 60px rgba(80,0,200,.3) inset}
      50%{box-shadow:0 0 100px rgba(100,0,255,.5) inset}
    }
    .puzzle-door{
      position:relative;
      margin-left:0;
      margin-right:0;
      background:
        radial-gradient(ellipse 80% 60% at 50% 50%,rgba(80,0,180,.5) 0%,transparent 70%),
        radial-gradient(ellipse 60% 40% at 20% 20%,rgba(100,0,200,.3) 0%,transparent 80%),
        #07000f;
      border-top:1px solid rgba(255,106,0,.9);
      border-bottom:1px solid rgba(255,106,0,.5);
      animation:puzzleBorderPulse 3s ease-in-out infinite;
      padding:20px 14px 28px;
      overflow:hidden;
    }
    .puzzle-door::before{
      content:"";
      position:absolute;
      inset:0;
      background:
        repeating-linear-gradient(0deg,transparent,transparent 23px,rgba(255,255,255,.02) 23px,rgba(255,255,255,.02) 24px),
        repeating-linear-gradient(90deg,transparent,transparent 23px,rgba(255,255,255,.015) 23px,rgba(255,255,255,.015) 24px);
      pointer-events:none;
      z-index:0;
    }
    .puzzle-door .zone-head{
      position:relative;
      z-index:1;
      margin-bottom:16px;
      flex-wrap:wrap;
    }
    .puzzle-door .zone-head span{
      white-space:normal;
      flex-shrink:1;
      min-width:0;
    }
    .puzzle-door .zone-head strong{
      font-size:15px;
      text-shadow:0 0 18px rgba(255,106,0,.9);
    }
    .puzzle-door-box{
      position:relative;
      z-index:1;
      overflow:hidden;
      background:rgba(0,0,0,.45);
      border:1px solid rgba(255,106,0,.35);
      box-shadow:0 0 30px rgba(255,106,0,.12) inset, 0 6px 0 rgba(0,0,0,.5);
      padding:16px;
    }
    .puzzle-copy{
      position:relative;
      padding-bottom:14px;
      margin-bottom:14px;
      border-bottom:1px solid rgba(255,106,0,.2);
    }
    .puzzle-copy::before{
      content:"// HIDDEN GAME";
      display:inline-block;
      background:transparent;
      border:1px solid var(--orange);
      color:var(--orange);
      font-size:9px;
      font-weight:1000;
      letter-spacing:.2em;
      padding:3px 10px;
      margin-bottom:10px;
      font-family:monospace;
      box-shadow:0 0 10px rgba(255,106,0,.3);
    }
    .puzzle-copy h3{
      font-size:20px;
      font-weight:1000;
      color:#fff;
      line-height:1.3;
      letter-spacing:-.03em;
      margin:0 0 8px;
      text-shadow:0 0 30px rgba(255,106,0,.5), 0 0 60px rgba(255,106,0,.2);
    }
    .puzzle-copy p{
      font-size:11px;
      color:rgba(255,255,255,.5);
      line-height:1.65;
      font-weight:760;
      margin:0;
    }
    @keyframes screenGlow{
      0%,100%{box-shadow:0 0 30px rgba(100,0,255,.3) inset, 0 0 0 1px rgba(255,106,0,.5)}
      50%{box-shadow:0 0 60px rgba(120,0,255,.5) inset, 0 0 0 1px rgba(255,106,0,.9)}
    }
    .puzzle-screen{
      position:relative;
      z-index:1;
      overflow:hidden;
      padding:14px;
      margin-bottom:0;
      background:
        linear-gradient(rgba(255,255,255,.03) 1px,transparent 1px),
        linear-gradient(90deg,rgba(255,255,255,.025) 1px,transparent 1px),
        #04000e;
      background-size:16px 16px,16px 16px,auto;
      border:1px solid rgba(255,106,0,.6);
      animation:screenGlow 2.5s ease-in-out infinite;
    }
    .puzzle-screen::before,.puzzle-screen::after{
      content:"";
      position:absolute;
      width:18px;height:18px;
      border-style:solid;
      z-index:2;
      pointer-events:none;
    }
    .puzzle-screen::before{top:6px;left:6px;border-width:2px 0 0 2px;border-color:var(--orange);box-shadow:-3px -3px 12px rgba(255,106,0,.6)}
    .puzzle-screen::after{bottom:6px;right:6px;border-width:0 2px 2px 0;border-color:#a040ff;box-shadow:3px 3px 12px rgba(160,64,255,.6)}
    .puzzle-top{
      display:flex;
      align-items:center;
      justify-content:space-between;
      gap:10px;
      margin-bottom:10px;
    }
    .puzzle-status{
      display:inline-flex;
      align-items:center;
      gap:7px;
      color:var(--orange);
      font-size:9px;
      font-weight:1000;
      letter-spacing:.18em;
      font-family:monospace;
      text-shadow:0 0 8px rgba(255,106,0,.7);
    }
    .puzzle-status::before{
      content:"";
      width:7px;
      height:7px;
      background:var(--orange);
      border-radius:50%;
      box-shadow:0 0 10px rgba(255,106,0,1), 0 0 20px rgba(255,106,0,.5);
      animation:ai-dot-opac 1.4s ease-in-out infinite;
    }
    .puzzle-count{
      color:#fff;
      font-size:13px;
      font-weight:1000;
      letter-spacing:.06em;
      font-family:monospace;
      text-shadow:0 0 10px rgba(255,255,255,.5);
    }
    .thumb-puzzle{
      display:grid;
      grid-template-columns:repeat(3,1fr);
      gap:3px;
      margin-bottom:12px;
      padding:3px;
      background:rgba(80,0,180,.4);
      border:1px solid rgba(255,106,0,.5);
      box-shadow:0 0 20px rgba(80,0,200,.3);
      transition:gap .45s ease, padding .45s ease, border-color .45s ease, box-shadow .45s ease;
    }
    .thumb-puzzle.is-merging{
      gap:0;
      padding:0;
      border-color:var(--orange);
      box-shadow:0 0 32px rgba(255,106,0,.5);
    }
    .puzzle-piece{
      position:relative;
      aspect-ratio:1/1;
      overflow:hidden;
      border:1px solid rgba(255,255,255,.1);
      background-image:var(--piece-img);
      background-size:300% 300%;
      cursor:pointer;
      transition:transform .22s ease, border-color .22s ease, box-shadow .22s ease, opacity .22s ease;
    }
    .puzzle-piece:nth-child(1){background-position:0% 0%}
    .puzzle-piece:nth-child(2){background-position:50% 0%}
    .puzzle-piece:nth-child(3){background-position:100% 0%}
    .puzzle-piece:nth-child(4){background-position:0% 50%}
    .puzzle-piece:nth-child(5){background-position:50% 50%}
    .puzzle-piece:nth-child(6){background-position:100% 50%}
    .puzzle-piece:nth-child(7){background-position:0% 100%}
    .puzzle-piece:nth-child(8){background-position:50% 100%}
    .puzzle-piece:nth-child(9){background-position:100% 100%}
    .puzzle-piece.is-wrong{
      transform:translateY(4px) rotate(-2deg);
      border-color:rgba(255,106,0,.38);
      box-shadow:0 0 14px rgba(255,106,0,.16);
    }
    .puzzle-piece.is-selected{
      transform:scale(.94);
      border-color:var(--orange);
      box-shadow:0 0 22px rgba(255,106,0,.36);
      z-index:2;
    }
    .puzzle-piece.is-complete{
      border-color:rgba(255,255,255,.18);
      box-shadow:none;
      transform:none;
    }
    .puzzle-piece.is-victory{
      animation:pieceVictory .5s ease-out both;
      border-color:var(--orange);
    }
    @keyframes pieceVictory{
      0%  {box-shadow:none}
      50% {box-shadow:0 0 18px rgba(255,180,0,.9),inset 0 0 10px rgba(255,180,0,.3);transform:scale(1.04)}
      100%{box-shadow:0 0 6px rgba(255,106,0,.4);transform:scale(1)}
    }
    .puzzle-help{
      margin:0 0 10px;
      color:rgba(255,255,255,.66);
      font-size:11px;
      line-height:1.65;
      font-weight:760;
      text-align:center;
    }
    .puzzle-actions{
      display:grid;
      grid-template-columns:1fr 1fr;
      gap:8px;
    }
    .puzzle-btn{
      min-height:44px;
      display:grid;
      place-items:center;
      border:0;
      background:rgba(255,255,255,.1);
      color:#fff;
      border:1px solid rgba(255,255,255,.13);
      font-size:12px;
      font-weight:1000;
      cursor:pointer;
    }
    .puzzle-btn.primary{
      background:linear-gradient(180deg,var(--orange2),var(--orange));
      color:#111;
      border:0;
      box-shadow:inset 0 -5px 0 rgba(0,0,0,.24),0 0 22px rgba(255,106,0,.24);
    }
    .puzzle-clear{
      position:absolute;
      inset:0;
      z-index:10;
      display:flex;
      flex-direction:column;
      align-items:center;
      justify-content:space-between;
      padding:12px 14px 12px;
      background:rgba(5,2,0,.94);
      border:1px solid rgba(255,106,0,.5);
      box-shadow:0 0 40px rgba(255,106,0,.22);
      opacity:0;
      visibility:hidden;
      transform:scale(.9);
      transition:opacity .45s cubic-bezier(.17,.67,.35,1.2), transform .45s cubic-bezier(.17,.67,.35,1.2), visibility .45s ease;
      text-align:center;
      overflow:hidden;
    }
    .puzzle-clear.is-show{
      opacity:1;
      visibility:visible;
      transform:scale(1);
    }
    .puzzle-clear-stars{
      display:flex;
      gap:4px;
      margin-bottom:4px;
    }
    .puzzle-clear-stars span{
      font-size:22px;
      opacity:0;
      transform:scale(0) rotate(-20deg);
      display:inline-block;
    }
    .puzzle-clear.is-show .puzzle-clear-stars span{
      animation:starPop .5s cubic-bezier(.17,.67,.35,1.4) both;
    }
    .puzzle-clear.is-show .puzzle-clear-stars span:nth-child(1){animation-delay:.05s}
    .puzzle-clear.is-show .puzzle-clear-stars span:nth-child(2){animation-delay:.18s}
    .puzzle-clear.is-show .puzzle-clear-stars span:nth-child(3){animation-delay:.31s}
    @keyframes starPop{
      0%  {opacity:0;transform:scale(0) rotate(-20deg)}
      70% {transform:scale(1.35) rotate(8deg)}
      100%{opacity:1;transform:scale(1) rotate(0deg)}
    }
    .puzzle-clear-thumb{
      width:100%;
      height:90px;
      background:center/contain no-repeat #000;
      border:2px solid var(--orange);
      box-shadow:0 0 20px rgba(255,106,0,.5);
      margin-bottom:8px;
      flex-shrink:0;
    }
    .puzzle-clear-title{
      margin:0 0 2px;
      font-size:36px;
      font-weight:1000;
      letter-spacing:.2em;
      color:#fff;
      text-shadow:
        0 0 8px #fff,
        0 0 20px rgba(255,220,80,1),
        0 0 40px rgba(255,140,0,.9),
        0 0 70px rgba(200,60,255,.7),
        0 0 110px rgba(120,40,255,.5);
      animation:titleGlow 1s ease-in-out infinite alternate;
    }
    @keyframes titleGlow{
      from{text-shadow:0 0 18px rgba(255,160,0,.7),0 0 40px rgba(255,106,0,.4)}
      to  {text-shadow:0 0 36px rgba(255,200,0,1), 0 0 80px rgba(255,106,0,.7),0 0 120px rgba(255,160,0,.3)}
    }
    .puzzle-clear-moves{
      margin:0 0 8px;
      font-size:11px;
      font-weight:1000;
      letter-spacing:.06em;
      color:rgba(255,255,255,.6);
    }
    .puzzle-clear-game-info{
      width:100%;
      margin-bottom:8px;
      text-align:left;
    }
    .puzzle-clear-game-name{
      margin:0 0 3px;
      font-size:14px;
      font-weight:1000;
      color:#fff;
      letter-spacing:-.02em;
    }
    .puzzle-clear-game-desc{
      margin:0;
      font-size:11px;
      font-weight:760;
      color:rgba(255,255,255,.6);
      line-height:1.55;
      display:-webkit-box;
      -webkit-line-clamp:2;
      line-clamp:2;
      -webkit-box-orient:vertical;
      overflow:hidden;
    }
    /* 紙吹雪 */
    .puzzle-confetti{
      position:absolute;
      width:7px;
      height:11px;
      border-radius:2px;
      pointer-events:none;
      top:-20px;
      animation:confettiFall var(--dur) ease-in var(--delay) both;
    }
    @keyframes confettiFall{
      0%  {transform:translateY(0) rotate(0deg);opacity:1}
      100%{transform:translateY(340px) rotate(720deg);opacity:0}
    }
    /* フラッシュ */
    .puzzle-flash{
      position:absolute;
      inset:0;
      background:rgba(255,220,80,.75);
      pointer-events:none;
      z-index:9;
      animation:flashOut .55s ease-out both;
    }
    @keyframes flashOut{
      0%  {opacity:1}
      100%{opacity:0}
    }
    .puzzle-clear h4{
      margin:0 0 5px;
      color:var(--amber);
      font-size:20px;
      line-height:1;
      font-weight:1000;
      letter-spacing:.04em;
      text-shadow:0 0 20px rgba(255,106,0,.35);
    }
    .puzzle-clear p{
      margin:0 0 10px;
      color:rgba(255,255,255,.72);
      font-size:12px;
      line-height:1.7;
      font-weight:760;
    }
    .puzzle-clear-actions{
      display:flex;
      flex-direction:column;
      align-items:center;
      gap:10px;
      width:100%;
    }
    .puzzle-clear-actions a,
    .puzzle-clear-actions button{
      min-height:46px;
      display:grid;
      place-items:center;
      border:0;
      font-size:13px;
      font-weight:1000;
      cursor:pointer;
    }
    .puzzle-clear-actions a{
      background:linear-gradient(160deg,#ffb800,var(--orange2),var(--orange));
      color:#111;
      font-size:15px;
      font-weight:1000;
      letter-spacing:.04em;
      width:100%;
      text-shadow:none;
      box-shadow:
        0 0 28px rgba(255,140,0,.6),
        0 0 60px rgba(255,106,0,.3),
        inset 0 -4px 0 rgba(0,0,0,.22),
        inset 0 1px 0 rgba(255,255,255,.3);
      animation:playBtnPulse 1.6s ease-in-out infinite;
      position:relative;
      overflow:hidden;
    }
    .puzzle-clear-actions a::before{
      content:"";
      position:absolute;
      top:-50%;left:-60%;
      width:40%;height:200%;
      background:rgba(255,255,255,.18);
      transform:skewX(-20deg);
      animation:playBtnShine 2.4s ease-in-out infinite;
      z-index:0;
    }
    .puzzle-clear-actions a > *,
    .puzzle-clear-actions a{
      position:relative;
      z-index:1;
    }
    @keyframes playBtnPulse{
      0%,100%{box-shadow:0 0 20px rgba(255,140,0,.5),0 0 40px rgba(255,106,0,.2),inset 0 -4px 0 rgba(0,0,0,.22),inset 0 1px 0 rgba(255,255,255,.3)}
      50%    {box-shadow:0 0 40px rgba(255,180,0,.85),0 0 80px rgba(255,106,0,.45),inset 0 -4px 0 rgba(0,0,0,.22),inset 0 1px 0 rgba(255,255,255,.3)}
    }
    @keyframes playBtnShine{
      0%  {left:-60%}
      40%,100%{left:120%}
    }
    .puzzle-clear-actions button{
      background:transparent;
      color:rgba(255,255,255,.5);
      border:none;
      font-size:12px;
      text-shadow:none;
      text-decoration:underline;
      text-underline-offset:3px;
      min-height:auto;
      padding:4px 0;
    }
    @keyframes puzzleClear{
      from{opacity:0;transform:translateY(8px)}
      to{opacity:1;transform:translateY(0)}
    }
    .play-flow{display:grid;gap:10px}
    .flow-step{background:rgba(255,255,255,.06);border-top:1px solid rgba(255,255,255,.08);box-shadow:0 8px 0 rgba(0,0,0,.24);overflow:hidden}
    .flow-step-img{position:relative;overflow:hidden;max-height:160px}
    .flow-step-img img{width:100%;height:160px;object-fit:cover;object-position:center;display:block}
    .flow-step-img::after{content:"";position:absolute;inset:0;background:linear-gradient(180deg,transparent 40%,rgba(0,0,0,.7))}
    .flow-step-body{display:grid;grid-template-columns:42px 1fr;gap:10px;align-items:start;padding:12px}
    .flow-step-body i{height:38px;display:grid;place-items:center;background:var(--orange);color:#111;font-style:normal;font-size:12px;font-weight:1000}
    .flow-step-body b{display:block;color:#fff;font-size:14px;font-weight:1000;margin-bottom:4px}
    .flow-step-body p{margin:0;color:rgba(255,255,255,.58);font-size:11px;line-height:1.65;font-weight:760}

    .voice-list{display:grid;gap:9px}
    .voice-card{background:rgba(255,255,255,.06);border-top:1px solid rgba(255,255,255,.08);border-left:4px solid var(--orange);box-shadow:0 6px 0 rgba(0,0,0,.28);padding:14px 14px 12px;position:relative}
    .voice-stars{color:var(--orange);font-size:13px;letter-spacing:2px;margin-bottom:7px}
    .voice-text{margin:0 0 10px;color:rgba(255,255,255,.8);font-size:12px;line-height:1.75;font-weight:760}
    .voice-user{display:inline-block;font-size:10px;font-weight:1000;color:rgba(255,255,255,.4);letter-spacing:.08em;border:1px solid rgba(255,255,255,.15);padding:2px 8px}

    .faq-banner{
      display:flex;
      align-items:center;
      justify-content:space-between;
      gap:12px;
      padding:16px 16px 16px 14px;
      text-decoration:none;
      color:#fff;
      background:linear-gradient(135deg,rgba(255,106,0,.14) 0%,rgba(255,60,0,.06) 100%);
      border:1.5px solid rgba(255,106,0,.6);
      border-left:4px solid var(--orange);
      border-radius:4px;
      box-shadow:0 0 16px rgba(255,80,0,.2),0 4px 12px rgba(0,0,0,.4);
      position:relative;
      overflow:hidden;
      transition:background .2s,box-shadow .2s;
    }
    .faq-banner::before{
      content:'';
      position:absolute;
      top:0;left:0;right:0;
      height:1px;
      background:linear-gradient(90deg,rgba(255,140,0,.8),transparent);
    }
    .faq-banner:active{
      background:linear-gradient(135deg,rgba(255,106,0,.22) 0%,rgba(255,60,0,.1) 100%);
      box-shadow:0 0 24px rgba(255,80,0,.35),0 4px 12px rgba(0,0,0,.4);
    }
    .faq-banner-body{display:flex;align-items:center;gap:14px}
    .faq-banner-label{
      flex-shrink:0;
      background:var(--orange);
      color:#000;
      font-size:11px;
      font-weight:900;
      letter-spacing:.1em;
      padding:6px 10px;
      border-radius:3px;
      box-shadow:0 0 10px rgba(255,100,0,.5);
    }
    .faq-banner-body b{display:block;font-size:14px;font-weight:800;margin-bottom:4px;color:#fff}
    .faq-banner-body p{margin:0;font-size:11px;color:rgba(255,255,255,.65);font-weight:600;line-height:1.5}
    .faq-banner-arrow{
      color:var(--orange);
      font-size:18px;
      flex-shrink:0;
      filter:drop-shadow(0 0 6px rgba(255,100,0,.7));
    }

    @keyframes gateRotate{0%{transform:rotate(0deg)}100%{transform:rotate(360deg)}}
    @keyframes gatePulse{0%,100%{opacity:1}50%{opacity:.1}}
    @keyframes gateOpacityPulse{0%,100%{opacity:1}50%{opacity:.5}}
    .gate-section{
      position:relative;
      margin:0 -0px 0;
      overflow:hidden;
    }
    .gate-bg{
      position:relative;
      width:100%;
    }
    .gate-bg img{
      width:100%;
      height:260px;
      object-fit:cover;
      object-position:center 20%;
      display:block;
    }
    .gate-bg-overlay{
      position:absolute;
      inset:0;
      background:linear-gradient(180deg,rgba(0,0,0,.1) 0%,rgba(0,0,0,.5) 50%,rgba(0,0,0,.95) 90%,#000 100%);
    }
    .gate-inner{
      position:relative;
      z-index:2;
      margin-top:-80px;
      padding:0 20px 32px;
      text-align:center;
    }
    .gate-eyebrow{
      display:inline-block;
      font-size:9px;
      font-weight:1000;
      font-family:monospace;
      letter-spacing:.22em;
      color:var(--orange);
      text-shadow:0 0 12px rgba(255,106,0,.8);
      margin-bottom:14px;
    }
    .gate-title{
      margin:0 0 14px;
      font-size:32px;
      font-weight:800;
      letter-spacing:-.04em;
      line-height:1.15;
      color:#fff;
      text-shadow:
        0 0 20px rgba(255,255,255,.5),
        0 0 50px rgba(255,106,0,.4),
        0 2px 0 rgba(0,0,0,.8);
    }
    .gate-sub{
      margin:0 0 18px;
      font-size:12px;
      line-height:1.8;
      color:rgba(255,255,255,.65);
      font-weight:400;
    }
    .gate-list{
      list-style:none;
      padding:0;
      margin:0 0 24px;
      display:grid;
      gap:8px;
      text-align:left;
    }
    .gate-list li{
      font-size:12px;
      font-weight:500;
      color:rgba(255,255,255,.8);
      padding-left:20px;
      position:relative;
    }
    .gate-list li::before{
      content:"\2713";
      position:absolute;
      left:0;
      color:var(--orange);
      font-weight:1000;
    }
    .gate-btn-wrap{
      --rad:8px;
      --color-wrapper-border:#ffaa00;
      --color-btn-bg:#ff7700;
      --color-btn-text:#fff;
      --color-btn-text-shadow:#ffe080;
      --color-btn-inset-shadow:#3a0070;
      --color-layer-a:#fff;
      --color-layer-b:#8800ff;
      --color-overlay-text:#1a0000;
      --color-overlay-glow:#ff8800;
      --color-overlay-shadow:#0006;
      --color-overlay-highlight:#fff5;
      position:relative;
      display:flex;
      align-items:center;
      justify-content:center;
      overflow:clip;
      overflow-clip-margin:4px;
      border:2px solid var(--color-wrapper-border);
      border-radius:var(--rad);
      font-family:inherit;
      text-decoration:none;
      cursor:pointer;
      font-size:1.2rem;
      font-weight:700;
      filter:saturate(.65) brightness(1.8);
      width:100%;
      text-decoration:none;
      box-shadow:0 0 28px rgba(255,140,0,.6),0 0 60px rgba(180,0,255,.3);
    }
    .gate-btn-light{
      position:absolute;
      pointer-events:none;
      z-index:1;
      border-radius:50px;
      width:80%;
      height:1.9rem;
      background-color:#fff5;
      filter:blur(5px);
      animation:gatePulse 3s ease-in-out infinite;
    }
    .gate-gradient-layer{
      position:absolute;
      pointer-events:none;
      left:-160px;
      width:500%;
      aspect-ratio:1;
      background:radial-gradient(ellipse at 65% 180%,var(--color-layer-a),var(--color-layer-b),var(--color-layer-a),var(--color-layer-b),var(--color-layer-a),var(--color-layer-b),var(--color-layer-a),var(--color-layer-b),var(--color-layer-a),var(--color-layer-b),var(--color-layer-a));
      mix-blend-mode:difference;
      animation:gateRotate 8s linear infinite;
    }
    .gate-gradient-layer:last-of-type{mix-blend-mode:color-dodge}
    .gate-gradient-btn{
      position:relative;
      z-index:-1;
      padding:18px 32px;
      border:none;
      border-radius:var(--rad);
      font-family:inherit;
      font-size:inherit;
      font-weight:inherit;
      color:transparent;
      background-color:var(--color-btn-bg);
      box-shadow:inset 0 0 10px 9px var(--color-btn-inset-shadow);
      cursor:pointer;
      mix-blend-mode:color-dodge;
      width:100%;
      line-height:1.4;
    }
    .gate-text-overlay{
      position:absolute;
      pointer-events:none;
      z-index:2;
      inset:0;
      display:flex;
      flex-direction:column;
      align-items:center;
      justify-content:center;
      padding:18px 32px;
      border-radius:var(--rad);
      font-family:inherit;
      font-size:inherit;
      font-weight:inherit;
      letter-spacing:.1rem;
      color:#fff;
      background:rgba(0,0,0,.35);
      text-shadow:0 2px 8px rgba(0,0,0,1),0 0 20px rgba(255,210,100,.5);
      mix-blend-mode:normal;
      text-align:center;
      line-height:1.4;
      animation:gateOpacityPulse 5s ease infinite;
    }
    .gate-btn-sub{
      display:block;
      font-size:12px;
      font-weight:600;
      letter-spacing:.13em;
      margin-top:6px;
      color:#ffe8a0;
      text-shadow:
        0 1px 4px rgba(0,0,0,1),
        -1px -1px 0 rgba(0,0,0,.7),
        1px 1px 0 rgba(0,0,0,.7);
    }


    /* ===== STICKY CTA ===== */
    .sticky-cta{
      position:fixed;
      bottom:0;left:0;right:0;
      z-index:50;
      padding:10px 16px calc(10px + env(safe-area-inset-bottom));
      background:linear-gradient(to top,rgba(0,0,0,.98) 70%,transparent);
      display:flex;
      flex-direction:column;
      align-items:center;
      gap:0;
      pointer-events:none;
      transform:translateY(110%);
      transition:transform .4s cubic-bezier(.4,0,.2,1),opacity .4s;
      opacity:0;
    }
    .sticky-cta.is-visible{
      transform:translateY(0);
      opacity:1;
      pointer-events:auto;
    }
    /* Uiverse.io style wrapper */
    .sticky-cta-wrap{
      --rad:10px;
      --layer-a:#fff;
      --layer-b:#9900ff;
      position:relative;
      display:flex;
      align-items:center;
      justify-content:center;
      overflow:clip;
      overflow-clip-margin:4px;
      border:2px solid #ffaa00;
      border-radius:var(--rad);
      font-family:inherit;
      font-size:1.1rem;
      font-weight:900;
      width:100%;
      max-width:400px;
      filter:saturate(.7) brightness(2);
      text-decoration:none;
      box-shadow:
        0 0 24px rgba(255,120,0,.7),
        0 0 60px rgba(255,80,0,.4),
        0 0 100px rgba(200,40,0,.2);
      animation:stickyPulse 2s ease-in-out infinite;
    }
    .sticky-cta-light{
      position:absolute;
      pointer-events:none;
      z-index:1;
      border-radius:50px;
      width:75%;
      height:1.6rem;
      background:#fff5;
      filter:blur(5px);
      animation:gatePulse 3s ease-in-out infinite;
    }
    .sticky-cta-layer{
      position:absolute;
      pointer-events:none;
      left:-160px;
      width:500%;
      aspect-ratio:1;
      background:radial-gradient(ellipse at 65% 180%,var(--layer-a),var(--layer-b),var(--layer-a),var(--layer-b),var(--layer-a),var(--layer-b),var(--layer-a),var(--layer-b),var(--layer-a),var(--layer-b),var(--layer-a));
      mix-blend-mode:difference;
      animation:gateRotate 6s linear infinite;
    }
    .sticky-cta-layer:last-of-type{mix-blend-mode:color-dodge}
    .sticky-cta-inner{
      position:relative;
      z-index:-1;
      padding:14px 28px;
      border:none;
      border-radius:var(--rad);
      background:#ff5500;
      box-shadow:inset 0 0 10px 8px #330060;
      width:100%;
      mix-blend-mode:color-dodge;
      color:transparent;
      display:flex;
      flex-direction:column;
      align-items:center;
      cursor:pointer;
      text-decoration:none;
    }
    .sticky-cta-overlay{
      position:absolute;
      inset:0;
      pointer-events:none;
      z-index:2;
      display:flex;
      flex-direction:column;
      align-items:center;
      justify-content:center;
      padding:14px 28px;
      color:#fff;
      background:rgba(0,0,0,.45);
    }
    .sticky-cta-main{
      font-size:16px;
      font-weight:700;
      letter-spacing:.06em;
      line-height:1;
      text-shadow:0 2px 10px rgba(0,0,0,1),0 0 24px rgba(255,200,80,.4);
    }
    .sticky-cta-sub{
      display:block;
      font-size:10px;
      font-weight:600;
      letter-spacing:.14em;
      color:#ffe88a;
      margin-top:5px;
      text-shadow:0 1px 6px rgba(0,0,0,1);
    }
    @keyframes stickyPulse{
      0%,100%{box-shadow:0 0 24px rgba(255,120,0,.7),0 0 60px rgba(255,80,0,.4),0 0 100px rgba(200,40,0,.2)}
      50%{box-shadow:0 0 40px rgba(255,160,0,1),0 0 90px rgba(255,100,0,.7),0 0 140px rgba(200,60,0,.4)}
    }
    @keyframes stickyShine{
      0%{left:-80%}55%,100%{left:130%}
    }

    /* ===== FOOTER ===== */
    .ftx-wrap{
      background:#0a080f;
      border-top:1px solid rgba(255,106,0,.2);
      padding:36px 20px calc(32px + env(safe-area-inset-bottom));
      position:relative;
      overflow:hidden;
    }
    .ftx-wrap::before{
      content:'';
      position:absolute;
      top:0;left:0;right:0;
      height:2px;
      background:linear-gradient(90deg,transparent 5%,#ff6a00 40%,#aa00ff 60%,transparent 95%);
      filter:blur(1px);
    }
    .ftx-wrap::after{
      content:'';
      position:absolute;
      inset:0;
      background:radial-gradient(ellipse at 50% 0%,rgba(255,80,0,.1) 0%,transparent 60%);
      pointer-events:none;
    }
    .ftx-logo{
      display:flex;
      justify-content:center;
      margin-bottom:28px;
    }
    .ftx-logo img{
      height:20px;
      filter:drop-shadow(0 0 10px rgba(255,106,0,.8)) brightness(1.2);
      opacity:.9;
    }
    .ftx-group{
      margin-bottom:22px;
    }
    .ftx-group-label{
      font-family:monospace;
      font-size:9px;
      font-weight:700;
      letter-spacing:.22em;
      color:#ff8c00;
      text-transform:uppercase;
      margin-bottom:8px;
      padding-left:2px;
      display:flex;
      align-items:center;
      gap:8px;
      text-shadow:0 0 8px rgba(255,120,0,.6);
    }
    .ftx-group-label::after{
      content:'';
      flex:1;
      height:1px;
      background:linear-gradient(90deg,rgba(255,106,0,.5),rgba(255,106,0,.1),transparent);
    }
    .ftx-list{
      list-style:none;
      padding:0;
      margin:0;
      display:grid;
      grid-template-columns:1fr 1fr;
    }
    .ftx-list li{
      border-bottom:1px solid rgba(255,255,255,.07);
    }
    .ftx-list li:nth-child(odd){
      border-right:1px solid rgba(255,255,255,.07);
    }
    .ftx-list a{
      display:flex;
      align-items:center;
      gap:6px;
      padding:11px 12px;
      color:rgba(255,255,255,.7);
      text-decoration:none;
      font-size:12px;
      font-weight:600;
      letter-spacing:.03em;
      transition:color .15s,background .15s;
    }
    .ftx-list a::before{
      content:'\25B8';
      font-size:9px;
      color:#ff7700;
      flex-shrink:0;
      transition:opacity .15s;
    }
    .ftx-list a:active{
      color:#fff;
      background:rgba(255,106,0,.12);
    }
    .ftx-divider{
      height:1px;
      background:linear-gradient(90deg,transparent,rgba(255,255,255,.12) 40%,transparent);
      margin:4px 0 20px;
    }
    .ftx-copy{
      text-align:center;
      font-size:10px;
      color:rgba(255,255,255,.28);
      letter-spacing:.08em;
      font-family:monospace;
      margin-top:8px;
    }
