/* Base layout extracted from index.html */
:root{--text-light:white}@keyframes fadeIn{from{opacity:0;transform:translate(-50%,-60%)}to{opacity:1;transform:translate(-50%,-50%)}}@keyframes loadingDots{0%,20%{opacity:0}50%{opacity:1}80%,100%{opacity:0}}@keyframes slideInFromRight{from{transform:translateX(120px);opacity:0}to{transform:translateX(0);opacity:1}}*{margin:0;padding:0;box-sizing:border-box}html,body{height:100%;height:var(--app-height,100dvh);width:100%;overflow:hidden;position:fixed;top:0;left:0;background-color:#000}body{margin:0;font-family:"Microsoft JhengHei","PingFang TC","Noto Sans TC","Helvetica Neue","Segoe UI",Tahoma,Arial,sans-serif;color:var(--text-light);overscroll-behavior:none;touch-action:manipulation;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;-webkit-text-size-adjust:100%}#game-container{position:fixed;width:100%;height:var(--app-height,100dvh);top:0;left:0;overflow:hidden;touch-action:manipulation}canvas{display:block;position:absolute;top:0;left:0;touch-action:none}.greeting-dialog{position:fixed;top:50%;left:50%;transform:translate(-50%,-50%);background:linear-gradient(135deg,rgba(15,25,40,0.95) 0%,rgba(25,35,55,0.95) 100%);border:1px solid rgba(255,255,255,0.2);border-radius:20px;text-align:center;z-index:1002;max-width:500px;min-width:450px;box-shadow:0 25px 50px rgba(0,0,0,0.5),0 0 0 1px rgba(255,255,255,0.1),inset 0 1px 0 rgba(255,255,255,0.2);font-family:"Microsoft JhengHei","PingFang TC","Noto Sans TC",sans-serif;font-weight:500;line-height:1.5;font-size:16px;animation:fadeIn 0.3s ease-out;transition:opacity 0.3s ease,transform 0.3s ease;padding:0}.greeting-content{padding:30px 25px 20px}.city-avatar{width:80px;height:80px;border-radius:50%;margin:0 auto 15px;border:3px solid rgba(255,215,0,0.4);box-shadow:0 4px 15px rgba(255,215,0,0.3);object-fit:cover;display:block}.greeting-title{font-size:20px;font-weight:700;color:#ffffff;margin-bottom:15px;text-shadow:0 2px 4px rgba(0,0,0,0.3)}.city-introduction{font-size:15px;color:rgba(255,255,255,0.9);line-height:1.6;margin-bottom:25px;text-align:left;padding:15px;background:rgba(255,255,255,0.05);border-radius:10px;border-left:4px solid rgba(255,215,0,0.6)}.greeting-buttons{display:flex;gap:15px;padding:0 25px 25px;justify-content:center}.greeting-btn{padding:12px 25px;border:none;border-radius:12px;font-size:15px;font-weight:600;cursor:pointer;transition:all 0.3s cubic-bezier(0.4,0,0.2,1);letter-spacing:0.3px;position:relative;overflow:hidden;min-width:100px}.greeting-btn::before{content:"";position:absolute;top:0;left:-100%;width:100%;height:100%;background:linear-gradient(90deg,transparent,rgba(255,255,255,0.2),transparent);transition:left 0.5s}.greeting-btn:hover::before{left:100%}.greeting-btn-accept{background:linear-gradient(135deg,#4CAF50 0%,#45a049 100%);color:#ffffff;border:1px solid rgba(255,255,255,0.2);box-shadow:0 8px 20px rgba(76,175,80,0.3),inset 0 1px 0 rgba(255,255,255,0.2)}.greeting-btn-accept:hover{transform:translateY(-2px);box-shadow:0 12px 25px rgba(76,175,80,0.4),inset 0 1px 0 rgba(255,255,255,0.3)}.greeting-btn-decline{background:rgba(255,255,255,0.1);color:rgba(255,255,255,0.9);border:1px solid rgba(255,255,255,0.2);box-shadow:0 4px 12px rgba(0,0,0,0.2),inset 0 1px 0 rgba(255,255,255,0.1)}.greeting-btn-decline:hover{background:rgba(255,255,255,0.15);transform:translateY(-1px);color:#ffffff;border-color:rgba(255,255,255,0.3)}.greeting-btn:active{transform:translateY(0)}.status-indicator{display:inline-block;margin-right:8px;font-size:18px}.status-available{color:#4CAF50}.loading-indicator{position:fixed;top:50%;left:50%;transform:translate(-50%,-50%);color:rgba(255,255,255,0.9);font-size:18px;font-family:"Microsoft JhengHei","PingFang TC","Noto Sans TC",sans-serif;display:flex;flex-direction:column;align-items:center;gap:12px;z-index:999;background:linear-gradient(135deg,rgba(20,30,50,0.95) 0%,rgba(30,45,70,0.95) 100%);border:2px solid rgba(255,255,255,0.2);border-radius:20px;padding:30px 40px;box-shadow:0 25px 50px rgba(0,0,0,0.5),0 0 0 1px rgba(255,255,255,0.1),inset 0 1px 0 rgba(255,255,255,0.2);animation:slideInFromRight 0.8s ease-out 0s forwards;opacity:1}.loading-indicator.hide{opacity:0;transition:opacity 0.5s ease-out}.loading-dots{display:flex;gap:3px}.loading-dots span{width:4px;height:4px;border-radius:50%;background:#4CAF50;animation:loadingDots 1.5s ease-in-out infinite}.loading-dots span:nth-child(2){animation-delay:0.2s}.loading-dots span:nth-child(3){animation-delay:0.4s}#error-display{position:fixed;top:10px;left:10px;background-color:rgba(255,0,0,0.7);color:white;padding:10px;border-radius:5px;z-index:9999;max-width:80%;display:none;font-family:"Microsoft JhengHei","PingFang TC","Noto Sans TC",sans-serif}.greeting-dialog{max-width:min(520px,92vw) !important;min-width:min(360px,92vw) !important;max-height:86vh !important;overflow:auto !important}body::before{content:"";position:fixed;inset:0;pointer-events:none;z-index:1}body::before{background:radial-gradient(120% 90% at 50% 60%,rgba(0,0,0,0) 0%,rgba(0,0,0,0) 55%,rgba(0,0,0,0.18) 85%,rgba(0,0,0,0.36) 100%)}@media (prefers-reduced-motion:reduce){*{animation:none !important;transition:none !important}}


/* Extracted from #phonebooth-contact-style */
.pb-contact-overlay{
            position: fixed;
            inset: 0;
            z-index: 20050;
            display: flex;
            align-items: center;
            justify-content: center;
            background: radial-gradient(1200px 700px at 20% 10%, rgba(90,220,255,0.14), rgba(0,0,0,0) 55%),
                  radial-gradient(900px 600px at 85% 20%, rgba(255,130,220,0.10), rgba(0,0,0,0) 60%),
                  rgba(0,0,0,0.48);
            backdrop-filter: blur(12px) saturate(125%);
            -webkit-backdrop-filter: blur(12px) saturate(125%);
            padding: 16px;
          }
          .pb-contact-dialog{
            width: min(440px, calc(100vw - 28px));
            border-radius: 20px;
            position: relative;
            overflow: hidden;
            color: #fff;
            background:
              radial-gradient(120% 120% at 18% 0%, rgba(90,220,255,0.22), rgba(0,0,0,0) 50%),
              radial-gradient(120% 120% at 92% 8%, rgba(255,130,220,0.18), rgba(0,0,0,0) 55%),
              linear-gradient(180deg, rgba(16,20,32,0.82), rgba(8,10,18,0.78));
            border: 1px solid rgba(120,220,255,0.22);
            box-shadow: 0 30px 80px rgba(0,0,0,0.62), inset 0 1px 0 rgba(255,255,255,0.10);
            transform: translateZ(0);
            animation: pbPop 240ms ease-out;
          }
          .pb-contact-dialog::before{
            content:"";
            position:absolute;
            inset:-3px;
            background: conic-gradient(from 210deg, rgba(90,220,255,0.0), rgba(90,220,255,0.35), rgba(255,130,220,0.22), rgba(90,220,255,0.0));
            filter: blur(20px);
            opacity: 0.55;
            pointer-events:none;
          }
          .pb-contact-content{ position: relative; z-index:1; padding: 18px 18px 16px; }
          .pb-contact-close{
            position: absolute;
            top: 10px;
            right: 10px;
            width: 34px;
            height: 34px;
            border-radius: 10px;
            display: flex;
            align-items: center;
            justify-content: center;
            background: rgba(255,255,255,0.10);
            box-shadow: 0 10px 20px rgba(0,0,0,0.35), inset 0 1px 0 rgba(255,255,255,0.12);
            cursor: pointer;
            user-select: none;
            -webkit-user-select: none;
            z-index: 5;
            pointer-events: auto;
            color: #ffffff;
            font-size: 22px;
            line-height: 1;
            border: none;
          }
          .pb-contact-close:active{ transform: translateY(1px); }
          .pb-contact-hero{
            width: 96px;
            height: 96px;
            border-radius: 50%;
            margin: 10px auto 10px;
            position: relative;
            background:
              radial-gradient(circle at 30% 25%, rgba(255,255,255,0.16), rgba(255,255,255,0.02)),
              linear-gradient(145deg, rgba(90,220,255,0.16), rgba(255,130,220,0.10));
            box-shadow: 0 18px 36px rgba(0,0,0,0.55), inset 0 1px 0 rgba(255,255,255,0.18);
          }
          .pb-contact-hero::after{
            content:"";
            position:absolute;
            inset:-2px;
            border-radius: 50%;
            border: 1px solid rgba(120,220,255,0.38);
            box-shadow: 0 0 0 1px rgba(0,0,0,0.35), 0 0 22px rgba(90,220,255,0.22);
            pointer-events:none;
          }
          .pb-contact-hero img{
            width:100%; height:100%; border-radius:50%; object-fit:cover;
            display:block;
            filter: saturate(1.12) contrast(1.06);
          }
          .pb-contact-title{
            text-align:center;
            font-size: 20px;
            font-weight: 900;
            letter-spacing: 0.06em;
            margin: 6px 0 10px;
            background: linear-gradient(90deg, rgba(120,220,255,1), rgba(255,130,220,1));
            -webkit-background-clip: text;
            background-clip: text;
            color: transparent;
          }
          .pb-contact-actions{
            display:flex;
            gap: 10px;
            justify-content: center;
            margin-top: 14px;
          }
          .pb-contact-btn{
            border: none;
            border-radius: 14px;
            padding: 11px 16px;
            min-width: 120px;
            font-weight: 900;
            cursor: pointer;
            color: #fff;
            box-shadow: 0 18px 30px rgba(0,0,0,0.45), inset 0 1px 0 rgba(255,255,255,0.18);
            transform: translateZ(0);
          }
          .pb-contact-btn.primary{
            background: linear-gradient(90deg, rgba(120,220,255,1), rgba(255,130,220,1));
          }
          .pb-contact-btn.secondary{
            background: rgba(255,255,255,0.06);
            border: 1px solid rgba(255,255,255,0.14);
          }
          .pb-contact-btn:active{ transform: translateY(1px); }
          .pb-contact-dialog.pb-hide{
            opacity: 0;
            transform: scale(0.98);
            transition: opacity 220ms ease, transform 220ms ease;
          }
          @keyframes pbPop{ from{ opacity: 0; transform: scale(0.96); } to{ opacity: 1; transform: scale(1); } }


/* Extracted from #guide-phone-style */
#guide-phone-overlay-container{
  position:fixed;
  inset:0;
  z-index:2500;
  display:flex;
  align-items:center;
  justify-content:center;
  padding:clamp(14px,4vw,34px);
  pointer-events:none;
  opacity:0;
  transform:scale(.98);
  transition:opacity .22s ease,transform .26s ease;
  background:
    radial-gradient(760px 480px at 18% 10%,rgba(0,229,255,.18),transparent 62%),
    linear-gradient(180deg,rgba(2,8,20,.58),rgba(1,4,12,.76));
  backdrop-filter:blur(16px) saturate(140%);
  -webkit-backdrop-filter:blur(16px) saturate(140%);
}
#guide-phone-overlay-container.active{opacity:1;transform:scale(1);pointer-events:auto;}
#guide-phone-overlay-container .guide-phone-body{
  width:min(92vw,430px);
  height:min(86vh,720px);
  position:relative;
  overflow:hidden;
  border-radius:24px;
  background:linear-gradient(180deg,rgba(8,24,42,.88),rgba(3,10,24,.92));
  border:1px solid rgba(94,229,255,.34);
  box-shadow:0 28px 72px rgba(0,0,0,.58),0 0 34px rgba(0,229,255,.12),inset 0 1px 0 rgba(255,255,255,.16);
}
#guide-phone-overlay-container .guide-phone-body::before{
  content:"";
  position:absolute;
  inset:0;
  pointer-events:none;
  background:
    linear-gradient(90deg,rgba(0,229,255,.18) 0 1px,transparent 1px),
    linear-gradient(180deg,rgba(0,229,255,.10) 0 1px,transparent 1px);
  background-size:28px 28px;
  mask-image:linear-gradient(180deg,rgba(0,0,0,.42),transparent 68%);
  -webkit-mask-image:linear-gradient(180deg,rgba(0,0,0,.42),transparent 68%);
}
#guide-phone-overlay-container .guide-phone-screen{
  position:relative;
  z-index:2;
  width:100%;
  height:100%;
  padding:24px 18px 18px;
  overflow:hidden;
  color:#fff;
  display:flex;
  flex-direction:column;
  gap:14px;
  -webkit-font-smoothing:antialiased;
}
#guide-phone-overlay-container .guide-phone-head{
  padding:4px 48px 10px 2px;
  border-bottom:1px solid rgba(111,232,255,.20);
}
#guide-phone-overlay-container .guide-phone-kicker{
  display:block;
  color:rgba(119,235,255,.78);
  font-size:11px;
  line-height:1.2;
  letter-spacing:.18em;
  font-weight:800;
}
#guide-phone-overlay-container .guide-phone-head strong{
  display:block;
  margin-top:5px;
  color:#fff;
  font-size:24px;
  line-height:1.15;
  letter-spacing:.08em;
  font-weight:900;
}
#guide-phone-overlay-container .guide-phone-head small{
  display:block;
  margin-top:6px;
  color:rgba(222,247,255,.68);
  font-size:13px;
  line-height:1.35;
  letter-spacing:.04em;
}
#guide-phone-overlay-container .guide-phone-close-btn{
  position:absolute;
  top:18px;
  right:18px;
  width:36px;
  height:36px;
  border-radius:12px;
  border:1px solid rgba(118,232,255,.32);
  background:rgba(255,255,255,.06);
  color:#fff;
  font-size:18px;
  cursor:pointer;
  z-index:5;
  display:flex;
  align-items:center;
  justify-content:center;
  transition:transform .18s ease,background .18s ease,border-color .18s ease;
}
#guide-phone-overlay-container .guide-phone-close-btn:hover{
  transform:translateY(-1px);
  background:rgba(0,229,255,.13);
  border-color:rgba(158,242,255,.54);
}
#guide-phone-overlay-container .guide-phone-list{
  flex:1;
  min-height:0;
  overflow-y:auto;
  display:grid;
  grid-template-columns:1fr;
  gap:8px;
  padding:0 2px 4px;
  scrollbar-width:thin;
  scrollbar-color:rgba(0,229,255,.34) rgba(255,255,255,.055);
}
#guide-phone-overlay-container .guide-phone-list::-webkit-scrollbar{width:7px;}
#guide-phone-overlay-container .guide-phone-list::-webkit-scrollbar-track{background:rgba(255,255,255,.055);border-radius:999px;}
#guide-phone-overlay-container .guide-phone-list::-webkit-scrollbar-thumb{background:rgba(0,229,255,.34);border-radius:999px;}
#guide-phone-overlay-container .guide-list-item{
  position:relative;
  min-height:48px;
  width:100%;
  border:1px solid rgba(111,232,255,.22);
  border-radius:14px;
  overflow:hidden;
  cursor:pointer;
  padding:0 14px;
  display:flex;
  align-items:center;
  justify-content:center;
  background:linear-gradient(90deg,rgba(12,40,62,.82),rgba(5,18,38,.70));
  color:#fff;
  box-shadow:inset 0 1px 0 rgba(255,255,255,.10);
  transition:transform .16s ease,border-color .16s ease,background .16s ease,box-shadow .16s ease;
  user-select:none;
}
#guide-phone-overlay-container .guide-list-item::before{
  content:"";
  position:absolute;
  left:0;
  top:10px;
  bottom:10px;
  width:3px;
  border-radius:999px;
  background:rgba(0,229,255,.72);
  box-shadow:0 0 12px rgba(0,229,255,.46);
}
#guide-phone-overlay-container .guide-list-item:hover{
  transform:translateX(3px);
  border-color:rgba(137,239,255,.48);
  background:linear-gradient(90deg,rgba(14,54,82,.90),rgba(6,23,48,.78));
  box-shadow:0 10px 22px rgba(0,0,0,.24),0 0 18px rgba(0,229,255,.10),inset 0 1px 0 rgba(255,255,255,.14);
}
#guide-phone-overlay-container .guide-list-item:active{transform:translateX(1px) scale(.99);}
#guide-phone-overlay-container .guide-list-title{
  position:relative;
  z-index:1;
  display:block;
  flex:1;
  min-width:0;
  font-size:18px;
  line-height:1.2;
  color:#fff;
  font-weight:850;
  letter-spacing:.16em;
  text-align:center;
  white-space:nowrap;
  overflow:hidden;
  text-overflow:ellipsis;
  text-shadow:0 0 12px rgba(0,229,255,.12);
}
@media (max-width:720px){
  #guide-phone-overlay-container{
    padding:10px;
    align-items:stretch;
    backdrop-filter:blur(8px) saturate(120%);
    -webkit-backdrop-filter:blur(8px) saturate(120%);
  }
  #guide-phone-overlay-container .guide-phone-body{
    width:100%;
    height:100%;
    border-radius:20px;
  }
  #guide-phone-overlay-container .guide-phone-screen{
    padding:calc(20px + env(safe-area-inset-top)) max(14px, env(safe-area-inset-right)) calc(16px + env(safe-area-inset-bottom)) max(14px, env(safe-area-inset-left));
    gap:12px;
  }
  #guide-phone-overlay-container .guide-phone-head strong{font-size:22px;}
  #guide-phone-overlay-container .guide-list-item{min-height:48px;border-radius:13px;}
  #guide-phone-overlay-container .guide-list-title{font-size:17px;letter-spacing:.14em;}
}
@media (max-width:380px){
  #guide-phone-overlay-container .guide-list-item{min-height:46px;padding:0 12px;gap:10px;}
  #guide-phone-overlay-container .guide-list-title{font-size:16px;letter-spacing:.12em;}
}


/* Extracted from #guide-nav-style */
#guide-nav-btn{
        position: fixed !important;
        top: 20px !important;
        right: 20px !important;
        width: 88px !important;
        height: 88px !important;
        display: flex !important;
        align-items: center !important;
        justify-content: center !important;

        /* 導覽鍵改用原互動鍵的藍綠科技色調 */
        background:
          radial-gradient(circle at 28% 18%,rgba(255,255,255,.24),transparent 28%),
          linear-gradient(145deg,rgba(0,246,255,.26),rgba(116,91,255,.12) 46%,rgba(255,255,255,.08)),
          rgba(8,18,34,.38) !important;
        border:1px solid rgba(210,245,255,.52) !important;
        border-radius: 18px !important;
        backdrop-filter:blur(22px) saturate(180%) !important;
        -webkit-backdrop-filter:blur(22px) saturate(180%) !important;

        color: rgba(255,255,255,0.98) !important;
        font-weight: 900 !important;
        letter-spacing: 0.2em !important;
        text-indent: 0.2em !important;
        font-size: 18px !important;

        box-shadow:
          0 14px 30px rgba(0,0,0,.32),
          inset 0 1px 0 rgba(255,255,255,.38),
          inset 0 -12px 24px rgba(0,246,255,.08),
          0 0 30px rgba(0,246,255,.22),
          0 0 70px rgba(116,91,255,.10) !important;

        cursor: pointer !important;
        user-select: none !important;
        -webkit-user-select: none !important;
        touch-action: manipulation !important;
        z-index: 10005 !important;
        transform: translateZ(0);
        transition: transform 120ms ease, box-shadow 120ms ease, border-color 120ms ease, background 120ms ease;
      }

      #guide-nav-btn::before{
        content: "";
        position: absolute;
        inset: 8px;
        border-radius: 10px;
        border: 1px solid rgba(170,245,255,0.28);
        background:linear-gradient(135deg,rgba(255,255,255,.12),transparent 46%,rgba(0,246,255,.08));
        box-shadow: inset 0 0 0 1px rgba(0,0,0,0.10),0 0 18px rgba(0,246,255,.10);
        pointer-events: none;
      }

      #guide-nav-btn:hover{
        border-color: rgba(255,255,255,0.55) !important;
        box-shadow:
          0 12px 26px rgba(0,0,0,0.28),
          inset 0 1px 0 rgba(255,255,255,0.42),
          inset 0 -12px 20px rgba(0,0,0,0.22) !important;
        transform: translateY(-1px);
      }

      #guide-nav-btn:active{
        transform: translateY(1px) scale(0.99);
        box-shadow:
          0 8px 18px rgba(0,0,0,0.24),
          inset 0 1px 0 rgba(255,255,255,0.28),
          inset 0 -14px 22px rgba(0,0,0,0.26) !important;
      }

      @media (max-width: 480px){
        #guide-nav-btn{
          width: 74px !important;
          height: 74px !important;
          font-size: 16px !important;
          top: 14px !important;
          right: 14px !important;
        }
      }

/* CSS formerly assigned via element.style.cssText */
.audio-avatar-wrapper{position:relative;display:inline-block;margin:0 auto 15px;}
.audio-play-indicator{position:absolute;bottom:5px;right:5px;width:35px;height:35px;background:rgba(76,175,80,0.9);border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:18px;pointer-events:none;border:2px solid white;box-shadow:0 2px 8px rgba(0,0,0,0.3);}
.greeting-message-line{margin-bottom:15px;font-size:18px;color:rgba(255,255,255,0.95);text-align:center;}
#company-3d-text{position:absolute;left:0;top:0;color:#ffffff;font-size:28px;font-weight:bold;text-shadow:0 0 10px rgba(255,255,255,0.8),0 0 20px rgba(255,255,255,0.5);white-space:nowrap;font-family:"Microsoft JhengHei","PingFang TC","Noto Sans TC",sans-serif;user-select:none;pointer-events:none;z-index:1000;text-align:center;width:300px;transform:translate3d(-9999px,-9999px,0) translate(-50%,-50%);will-change:transform;display:none;letter-spacing:2px;}
#main-move-control{position:fixed !important;bottom:50px !important;right:20px !important;width:70px !important;height:70px !important;color:#fff !important;border-radius:50% !important;display:flex !important;align-items:center !important;justify-content:center !important;font-size:16px !important;font-weight:bold !important;cursor:pointer !important;z-index:10001 !important;box-shadow:0 4px 10px rgba(0,0,0,0.3) !important;border:0 !important;touch-action:manipulation !important;}

/* Extracted from aitwEnsureIndustryStyles */
#aitw-industry-phone{
  position:fixed;
  inset:0;
  z-index:3600;
  display:flex;
  align-items:center;
  justify-content:center;
  padding:clamp(14px,3vw,40px);
  pointer-events:none;
  opacity:0;
  transform:scale(.965);
  transition:opacity .28s ease,transform .34s cubic-bezier(.2,.9,.24,1);
  background:
    radial-gradient(900px 540px at 18% 8%,rgba(0,238,255,.16),rgba(0,0,0,0) 62%),
    radial-gradient(760px 520px at 84% 22%,rgba(170,90,255,.14),rgba(0,0,0,0) 58%),
    rgba(0,0,0,.42);
  backdrop-filter:blur(14px) saturate(130%);
  -webkit-backdrop-filter:blur(14px) saturate(130%);
  contain:layout paint;
}
#aitw-industry-phone.active{opacity:1;transform:scale(1);pointer-events:auto;}
#aitw-industry-phone .aitw-phone-body{
  position:relative;
  width:min(1080px,calc(100vw - 32px));
  height:min(760px,calc(var(--app-height,100dvh) - 40px));
  border-radius:28px;
  overflow:hidden;
  pointer-events:auto;
  color:#fff;
  background:
    linear-gradient(135deg,rgba(255,255,255,.14),rgba(255,255,255,.035) 26%,rgba(255,255,255,.015) 100%),
    radial-gradient(120% 120% at 0% 0%,rgba(0,238,255,.18),rgba(0,0,0,0) 52%),
    radial-gradient(90% 120% at 100% 0%,rgba(168,85,247,.16),rgba(0,0,0,0) 58%),
    linear-gradient(180deg,rgba(8,18,30,.82),rgba(4,8,16,.76));
  border:1px solid rgba(116,232,255,.34);
  box-shadow:
    0 30px 90px rgba(0,0,0,.68),
    inset 0 1px 0 rgba(255,255,255,.18),
    inset 0 0 0 1px rgba(255,255,255,.06),
    0 0 38px rgba(0,238,255,.10);
}
#aitw-industry-phone .aitw-phone-body::before,
#aitw-industry-phone .aitw-phone-body::after{
  content:"";
  position:absolute;
  pointer-events:none;
  z-index:2;
}
#aitw-industry-phone .aitw-phone-body::before{
  inset:10px;
  border-radius:22px;
  border:1px solid rgba(255,255,255,.09);
  box-shadow:inset 0 0 30px rgba(0,238,255,.08);
}
#aitw-industry-phone .aitw-phone-body::after{
  inset:0;
  background:
    linear-gradient(90deg,rgba(255,255,255,.12) 0 1px,transparent 1px 100%),
    linear-gradient(180deg,rgba(255,255,255,.10) 0 1px,transparent 1px 100%);
  background-size:44px 44px;
  opacity:.055;
}
#aitw-industry-phone .aitw-phone-close{
  position:absolute;
  top:18px;
  right:18px;
  width:40px;
  height:40px;
  border-radius:14px;
  border:1px solid rgba(255,255,255,.20);
  background:rgba(255,255,255,.10);
  color:#fff;
  font-size:21px;
  display:flex;
  align-items:center;
  justify-content:center;
  cursor:pointer;
  z-index:5;
  box-shadow:0 10px 24px rgba(0,0,0,.38),inset 0 1px 0 rgba(255,255,255,.16);
  transition:transform .16s ease,background .16s ease,border-color .16s ease;
}
#aitw-industry-phone .aitw-phone-close:hover{background:rgba(255,255,255,.16);border-color:rgba(116,232,255,.38);}
#aitw-industry-phone .aitw-phone-close:active{transform:translateY(1px) scale(.98);}
#aitw-industry-phone .aitw-phone-screen{
  position:relative;
  z-index:3;
  width:100%;
  height:100%;
  display:flex;
  flex-direction:column;
  gap:18px;
  padding:26px clamp(18px,3vw,38px) 28px;
  overflow:hidden;
  color:#fff;
  -webkit-font-smoothing:antialiased;
}
#aitw-industry-phone .aitw-panel-head{
  position:relative;
  flex:0 0 auto;
  padding:18px clamp(14px,2vw,22px);
  padding-right:64px;
  border-radius:22px;
  background:linear-gradient(135deg,rgba(255,255,255,.10),rgba(255,255,255,.035));
  border:1px solid rgba(255,255,255,.12);
  box-shadow:inset 0 1px 0 rgba(255,255,255,.12),0 16px 34px rgba(0,0,0,.28);
}
#aitw-industry-phone .aitw-kicker{
  margin-bottom:6px;
  font-size:11px;
  font-weight:800;
  letter-spacing:.22em;
  color:rgba(116,232,255,.82);
  text-transform:uppercase;
}
#aitw-industry-phone .aitw-title{
  margin:0;
  padding:0;
  border:0;
  background:none;
  font-size:clamp(24px,3.2vw,38px);
  line-height:1.15;
  font-weight:950;
  letter-spacing:.08em;
  text-align:left;
  color:#fff;
  text-shadow:0 0 18px rgba(0,238,255,.28),0 2px 10px rgba(0,0,0,.55);
}
#aitw-industry-phone .aitw-context{
  margin:8px 0 0;
  font-size:14px;
  line-height:1.55;
  color:rgba(255,255,255,.70);
  text-align:left;
}
#aitw-industry-phone .aitw-list-count{
  position:absolute;
  right:18px;
  bottom:16px;
  padding:6px 10px;
  border-radius:999px;
  background:rgba(0,238,255,.09);
  border:1px solid rgba(116,232,255,.22);
  font-size:12px;
  font-weight:800;
  color:rgba(230,250,255,.86);
  text-align:right;
}
#aitw-industry-phone .aitw-list{
  flex:1 1 auto;
  min-height:0;
  overflow-y:auto;
  display:grid;
  grid-template-columns:repeat(auto-fill,minmax(150px,1fr));
  grid-auto-rows:minmax(52px,auto);
  gap:10px;
  padding:2px 4px 8px 2px;
  scrollbar-width:thin;
  scrollbar-color:rgba(116,232,255,.36) rgba(255,255,255,.05);
}
#aitw-industry-phone .aitw-list::-webkit-scrollbar{width:8px;}
#aitw-industry-phone .aitw-list::-webkit-scrollbar-track{background:rgba(255,255,255,.05);border-radius:999px;}
#aitw-industry-phone .aitw-list::-webkit-scrollbar-thumb{background:rgba(116,232,255,.36);border-radius:999px;}
#aitw-industry-phone .aitw-industry-item{
  position:relative;
  width:100%;
  min-height:52px;
  display:flex;
  align-items:center;
  justify-content:center;
  padding:12px 10px;
  border-radius:15px;
  background:
    linear-gradient(180deg,rgba(255,255,255,.092),rgba(255,255,255,.038)),
    rgba(6,16,28,.58);
  border:1px solid rgba(116,232,255,.18);
  color:#fff;
  text-align:center;
  cursor:pointer;
  box-shadow:0 10px 20px rgba(0,0,0,.22),inset 0 1px 0 rgba(255,255,255,.10);
  overflow:hidden;
  transition:transform .16s ease,border-color .16s ease,background .16s ease,box-shadow .16s ease;
}
#aitw-industry-phone .aitw-industry-item::before{
  content:"";
  position:absolute;
  inset:0;
  background:linear-gradient(120deg,transparent,rgba(116,232,255,.12),transparent);
  transform:translateX(-120%);
  transition:transform .45s ease;
  pointer-events:none;
}
#aitw-industry-phone .aitw-industry-item:hover{
  transform:translateY(-2px);
  border-color:rgba(116,232,255,.42);
  background:linear-gradient(180deg,rgba(116,232,255,.12),rgba(255,255,255,.048)),rgba(6,16,28,.68);
  box-shadow:0 14px 26px rgba(0,0,0,.28),0 0 18px rgba(0,238,255,.08),inset 0 1px 0 rgba(255,255,255,.14);
}
#aitw-industry-phone .aitw-industry-item:hover::before{transform:translateX(120%);}
#aitw-industry-phone .aitw-industry-item:active{transform:translateY(0) scale(.985);}
#aitw-industry-phone .aitw-industry-name{
  display:block;
  width:100%;
  color:rgba(255,255,255,.98);
  font-size:clamp(15px,1.55vw,18px);
  line-height:1.35;
  font-weight:900;
  letter-spacing:.05em;
  text-shadow:0 1px 0 rgba(0,0,0,.70),0 0 12px rgba(0,238,255,.12);
  word-break:keep-all;
  overflow-wrap:anywhere;
}
#aitw-industry-phone .aitw-no-result{
  grid-column:1/-1;
  text-align:center;
  align-self:center;
  padding:40px 10px;
  color:rgba(255,255,255,.58);
  font-size:16px;
  line-height:1.8;
}
#aitw-industry-launch-glow{position:fixed;inset:0;z-index:50000;pointer-events:auto;opacity:0;background:radial-gradient(circle at center,rgba(255,255,255,1) 0%,rgba(0,238,255,.95) 18%,rgba(0,85,255,.78) 44%,rgba(0,8,25,.96) 100%);transform:scale(.96);transition:opacity .18s ease,transform .32s ease;}
#aitw-industry-launch-glow.active{opacity:1;transform:scale(1.04);animation:aitwFullGlow .52s ease-out forwards;}
@keyframes aitwFullGlow{0%{filter:brightness(1);}50%{filter:brightness(1.55) saturate(1.35);}100%{filter:brightness(2.15) saturate(1.5);}}
@media (max-width:720px){
  #aitw-industry-phone{padding:10px;align-items:flex-end;}
  #aitw-industry-phone .aitw-phone-body{width:100%;height:min(88vh,calc(var(--app-height,100dvh) - 18px));border-radius:24px 24px 0 0;}
  #aitw-industry-phone .aitw-phone-screen{padding:18px 12px calc(18px + env(safe-area-inset-bottom));gap:12px;}
  #aitw-industry-phone .aitw-panel-head{padding:16px 14px 14px;padding-right:58px;border-radius:18px;}
  #aitw-industry-phone .aitw-title{font-size:24px;}
  #aitw-industry-phone .aitw-context{font-size:12px;}
  #aitw-industry-phone .aitw-list-count{position:static;display:inline-block;margin-top:10px;text-align:left;}
  #aitw-industry-phone .aitw-list{grid-template-columns:repeat(2,minmax(0,1fr));gap:9px;}
  #aitw-industry-phone .aitw-industry-item{min-height:50px;padding:10px 8px;border-radius:14px;}
  #aitw-industry-phone .aitw-industry-name{font-size:14px;letter-spacing:.03em;}
}
@media (max-width:380px){#aitw-industry-phone .aitw-list{grid-template-columns:1fr;}}



/* Low-risk mobile compatibility refinements: keep desktop visuals unchanged. */
@media (max-width: 720px), (pointer: coarse) {
  .greeting-dialog,
  .loading-indicator,
  #guide-nav-btn,
  #guide-interaction-btn,
  #aitw-industry-phone {
    backdrop-filter: blur(6px) saturate(115%) !important;
    -webkit-backdrop-filter: blur(6px) saturate(115%) !important;
  }

  #aitw-industry-phone .aitw-phone-body,
  #aitw-industry-phone .aitw-panel-head,
  #aitw-industry-phone .aitw-industry-item {
    backdrop-filter: none !important;
    -webkit-backdrop-filter: none !important;
  }

  #guide-nav-btn {
    top: calc(14px + env(safe-area-inset-top)) !important;
    right: calc(14px + env(safe-area-inset-right)) !important;
  }

  #main-move-control {
    right: calc(20px + env(safe-area-inset-right)) !important;
    bottom: calc(50px + env(safe-area-inset-bottom)) !important;
  }

  #aitw-industry-phone {
    padding:
      calc(10px + env(safe-area-inset-top))
      calc(10px + env(safe-area-inset-right))
      calc(10px + env(safe-area-inset-bottom))
      calc(10px + env(safe-area-inset-left));
  }

  #aitw-industry-phone .aitw-phone-body {
    height: min(88vh, calc(var(--app-height, 100dvh) - 18px - env(safe-area-inset-top) - env(safe-area-inset-bottom)));
  }
}

@media (max-width: 380px) {
  #guide-nav-btn {
    width: 68px !important;
    height: 68px !important;
    font-size: 14px !important;
    border-radius: 16px !important;
  }
}


/* 戶外看板互動提示鍵與提示框 */
#guide-interaction-btn{
  position:fixed !important;
  top:116px !important;
  right:20px !important;
  width:88px !important;
  height:88px !important;
  display:flex !important;
  align-items:center !important;
  justify-content:center !important;
  border-radius:18px !important;
  border:1px solid rgba(255,255,255,.30) !important;
  color:rgba(255,255,255,.96) !important;
  background:linear-gradient(145deg,rgba(190,194,202,.30),rgba(80,84,92,.18)) !important;
  box-shadow:
    0 10px 22px rgba(0,0,0,.25),
    inset 0 1px 0 rgba(255,255,255,.30),
    inset 0 -10px 18px rgba(0,0,0,.20) !important;
  backdrop-filter:blur(14px) saturate(125%) !important;
  -webkit-backdrop-filter:blur(14px) saturate(125%) !important;
  font-size:16px !important;
  font-weight:900 !important;
  letter-spacing:.16em !important;
  text-indent:.16em !important;
  cursor:pointer !important;
  z-index:10005 !important;
  touch-action:manipulation !important;
  opacity:1 !important;
  transform:translateZ(0) !important;
  transition:opacity .2s ease,transform .18s ease,border-color .16s ease,background .16s ease,box-shadow .16s ease !important;
}
#guide-interaction-btn:hover{
  transform:translateY(-1px) !important;
  border-color:rgba(255,255,255,.45) !important;
  background:linear-gradient(145deg,rgba(205,208,214,.34),rgba(92,96,104,.20)) !important;
}
#guide-interaction-btn:active{transform:translateY(1px) scale(.98) !important;}
#guide-interaction-btn.guide-interaction-hidden{
  opacity:0 !important;
  transform:translateY(6px) scale(.96) !important;
  pointer-events:none !important;
}
#billboard-interaction-overlay{
  position:fixed;
  inset:0;
  z-index:10008;
  display:flex;
  align-items:center;
  justify-content:center;
  padding:24px;
  pointer-events:none;
}
#billboard-interaction-overlay .billboard-interaction-panel{
  position:relative;
  width:min(420px,calc(100vw - 44px));
  min-height:118px;
  display:flex;
  align-items:center;
  justify-content:center;
  padding:34px 46px 30px;
  border-radius:22px;
  color:#fff;
  background:
    radial-gradient(120% 120% at 20% 0%,rgba(255,255,255,.16),rgba(255,255,255,0) 52%),
    linear-gradient(180deg,rgba(78,82,90,.48),rgba(22,25,31,.40));
  border:1px solid rgba(255,255,255,.26);
  box-shadow:
    0 26px 72px rgba(0,0,0,.46),
    inset 0 1px 0 rgba(255,255,255,.28),
    inset 0 -18px 38px rgba(0,0,0,.16);
  backdrop-filter:blur(18px) saturate(135%);
  -webkit-backdrop-filter:blur(18px) saturate(135%);
  pointer-events:auto;
  animation:billboardInteractionPop .22s ease-out both;
}
#billboard-interaction-overlay.closing .billboard-interaction-panel{
  animation:billboardInteractionClose .2s ease-in both;
}
#billboard-interaction-overlay .billboard-interaction-close{
  position:absolute;
  top:10px;
  right:10px;
  width:32px;
  height:32px;
  border-radius:11px;
  border:1px solid rgba(255,255,255,.22);
  background:rgba(255,255,255,.12);
  color:rgba(255,255,255,.94);
  font-size:22px;
  line-height:1;
  display:flex;
  align-items:center;
  justify-content:center;
  cursor:pointer;
  box-shadow:inset 0 1px 0 rgba(255,255,255,.20),0 8px 18px rgba(0,0,0,.24);
  touch-action:manipulation;
}
#billboard-interaction-overlay .billboard-interaction-close:active{transform:translateY(1px) scale(.98);}
#billboard-interaction-overlay .billboard-interaction-message{
  color:rgba(255,255,255,.96);
  font-size:20px;
  line-height:1.55;
  font-weight:800;
  letter-spacing:.06em;
  text-align:center;
  text-shadow:0 2px 14px rgba(0,0,0,.34);
}
@keyframes billboardInteractionPop{
  from{opacity:0;transform:translateY(10px) scale(.96);}
  to{opacity:1;transform:translateY(0) scale(1);}
}
@keyframes billboardInteractionClose{
  from{opacity:1;transform:translateY(0) scale(1);}
  to{opacity:0;transform:translateY(8px) scale(.97);}
}
@media (max-width:480px){
  #guide-interaction-btn{
    top:calc(96px + env(safe-area-inset-top)) !important;
    right:calc(14px + env(safe-area-inset-right)) !important;
    width:74px !important;
    height:74px !important;
    font-size:15px !important;
    border-radius:18px !important;
    backdrop-filter:blur(6px) saturate(115%) !important;
    -webkit-backdrop-filter:blur(6px) saturate(115%) !important;
  }
  #billboard-interaction-overlay{padding:18px;}
  #billboard-interaction-overlay .billboard-interaction-panel{
    width:min(360px,calc(100vw - 32px));
    min-height:112px;
    padding:32px 40px 28px;
    border-radius:20px;
    backdrop-filter:blur(10px) saturate(120%);
    -webkit-backdrop-filter:blur(10px) saturate(120%);
  }
  #billboard-interaction-overlay .billboard-interaction-message{font-size:18px;}
}
@media (max-width:380px){
  #guide-interaction-btn{
    top:calc(88px + env(safe-area-inset-top)) !important;
    width:68px !important;
    height:68px !important;
    font-size:14px !important;
    border-radius:16px !important;
  }
}


/* Final mobile viewport hardening: prevent scene-edge white frame */
html, body, #game-container {
  background:#000 !important;
  min-width:100vw;
  min-height:100vh;
  min-height:100dvh;
}
#game-container canvas {
  background:#000 !important;
  max-width:none !important;
}
@supports (-webkit-touch-callout: none) {
  html, body {
    background:#000 !important;
    overflow:hidden !important;
  }
}
