/* Inlined from app.3b29c2a59bb9.css */
/* 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;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 #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(8px) saturate(122%);
  -webkit-backdrop-filter:blur(8px) saturate(122%);
}
#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(12px) saturate(145%) !important;
        -webkit-backdrop-filter:blur(12px) saturate(145%) !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: calc(14px + env(safe-area-inset-top)) !important;
          right: calc(14px + env(safe-area-inset-right)) !important;
        }
      }

/* Activity venue title highlight */
.activity-venue-title-highlight{color:#FFD700;text-shadow:none;}
#guide-phone-overlay-container .guide-list-title.activity-venue-title-highlight{color:#FFD700 !important;text-shadow:none !important;}
/* CSS formerly assigned via element.style.cssText */
.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(8px) saturate(118%);
  -webkit-backdrop-filter:blur(8px) saturate(118%);
  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:-8vmax;z-index:50000;pointer-events:none;opacity:0;background:radial-gradient(circle at center,rgba(255,255,255,1) 0%,rgba(255,255,255,.98) 12%,rgba(196,245,255,.97) 26%,rgba(88,202,255,.94) 46%,rgba(10,88,220,.90) 64%,rgba(2,18,48,.98) 82%,rgba(0,0,0,1) 100%),linear-gradient(180deg,rgba(255,255,255,.34),rgba(152,226,255,.18) 42%,rgba(0,0,0,.24) 100%);transform:scale(.92);transition:opacity .14s ease,transform .28s ease;filter:brightness(1.28) saturate(1.18);} 
#aitw-industry-launch-glow.active{opacity:1;transform:scale(1.08);animation:aitwFullGlow .72s cubic-bezier(.18,.78,.22,1) forwards;}
@keyframes aitwFullGlow{0%{opacity:0;filter:brightness(1.1) saturate(1.08) blur(0px);}38%{opacity:1;filter:brightness(2.45) saturate(1.42) blur(1.2px);}100%{opacity:1;filter:brightness(3.08) saturate(1.62) blur(2px);}}
@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,
  #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 {
    right: calc(14px + env(safe-area-inset-right)) !important;
  }

  #guide-nav-btn {
    top: calc(14px + env(safe-area-inset-top)) !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;
  }
}

/* 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;
  }
}

/*
 * Mobile GPU relief: backdrop-filter blur is extremely expensive on iOS Safari
 * and low-end Android. Strip blur from inner dialog/panel layers (the outer
 * surface still has a light blur from the rule above) and replace with solid
 * tinted backgrounds. Keeps the visual hierarchy while eliminating fillrate
 * cost on every frame the dialog is open.
 */
@media (max-width: 720px), (pointer: coarse) {
  #guide-phone-overlay-container {
    backdrop-filter: none !important;
    -webkit-backdrop-filter: none !important;
  }
}

.noscript-warning{position:fixed;inset:0;display:flex;align-items:center;justify-content:center;background:#020814;color:#fff;font-family:system-ui,sans-serif;z-index:999999;padding:24px;text-align:center;}

/* Proximity interaction dialogs added for phone booth notice and cafe laptop service flow */
.aitw-proximity-dialog-overlay{
  position:fixed;
  inset:0;
  z-index:26000;
  display:flex;
  align-items:center;
  justify-content:center;
  padding:18px;
  background:
    radial-gradient(900px 520px at 22% 12%,rgba(92,220,255,.16),transparent 62%),
    radial-gradient(780px 520px at 82% 24%,rgba(190,130,255,.12),transparent 60%),
    rgba(0,0,0,.34);
  backdrop-filter:blur(8px) saturate(122%);
  -webkit-backdrop-filter:blur(8px) saturate(122%);
  opacity:1;
  transition:opacity .16s ease;
  pointer-events:auto;
}
.aitw-proximity-dialog-overlay.closing{opacity:0;}
.aitw-proximity-dialog-panel{
  position:relative;
  width:min(500px,calc(100vw - 32px));
  overflow:hidden;
  border-radius:22px;
  color:#fff;
  background:
    linear-gradient(135deg,rgba(255,255,255,.13),rgba(255,255,255,.035) 36%,rgba(255,255,255,.018)),
    radial-gradient(120% 120% at 16% 0%,rgba(96,226,255,.22),transparent 54%),
    radial-gradient(120% 120% at 92% 8%,rgba(196,128,255,.16),transparent 56%),
    rgba(9,15,28,.70);
  border:1px solid rgba(160,235,255,.30);
  box-shadow:0 28px 82px rgba(0,0,0,.62),inset 0 1px 0 rgba(255,255,255,.18),0 0 34px rgba(88,220,255,.12);
  transform:translateZ(0) scale(1);
  animation:aitwDialogPop .22s cubic-bezier(.2,.9,.24,1);
}
.aitw-proximity-dialog-panel::before{
  content:"";
  position:absolute;
  inset:0;
  pointer-events:none;
  background:linear-gradient(90deg,rgba(255,255,255,.10) 0 1px,transparent 1px),linear-gradient(180deg,rgba(255,255,255,.08) 0 1px,transparent 1px);
  background-size:34px 34px;
  opacity:.09;
  mask-image:linear-gradient(180deg,rgba(0,0,0,.72),transparent 86%);
  -webkit-mask-image:linear-gradient(180deg,rgba(0,0,0,.72),transparent 86%);
}
.aitw-proximity-dialog-close{
  position:absolute;
  top:12px;
  right:12px;
  width:38px;
  height:38px;
  z-index:3;
  display:flex;
  align-items:center;
  justify-content:center;
  border-radius:13px;
  border:1px solid rgba(255,255,255,.18);
  background:rgba(255,255,255,.10);
  color:#fff;
  font-size:25px;
  line-height:1;
  cursor:pointer;
  box-shadow:0 12px 26px rgba(0,0,0,.34),inset 0 1px 0 rgba(255,255,255,.16);
  touch-action:manipulation;
}
.aitw-proximity-dialog-close:active{transform:translateY(1px) scale(.98);}
.aitw-proximity-dialog-content{
  position:relative;
  z-index:2;
  padding:30px 24px 24px;
  text-align:center;
}
.aitw-proximity-dialog-title{
  padding:0 44px 12px;
  color:#9FEFFF;
  font-size:13px;
  font-weight:900;
  line-height:1.35;
  letter-spacing:.18em;
  text-transform:uppercase;
  text-shadow:0 0 18px rgba(92,226,255,.30);
}
.aitw-proximity-dialog-message{
  margin:4px auto 0;
  max-width:410px;
  color:rgba(255,255,255,.96);
  font-size:clamp(17px,4.2vw,22px);
  line-height:1.65;
  font-weight:850;
  letter-spacing:.055em;
  text-shadow:0 2px 12px rgba(0,0,0,.42);
}
.aitw-proximity-dialog-actions{
  display:flex;
  justify-content:center;
  gap:12px;
  margin-top:22px;
  flex-wrap:wrap;
}
.aitw-proximity-dialog-btn{
  min-width:116px;
  min-height:44px;
  padding:11px 18px;
  border-radius:15px;
  border:1px solid rgba(255,255,255,.16);
  color:#fff;
  font-size:16px;
  font-weight:900;
  letter-spacing:.08em;
  cursor:pointer;
  touch-action:manipulation;
  box-shadow:0 15px 28px rgba(0,0,0,.36),inset 0 1px 0 rgba(255,255,255,.16);
}
.aitw-proximity-dialog-btn.primary{
  background:linear-gradient(90deg,rgba(80,220,255,.98),rgba(178,124,255,.96));
}
.aitw-proximity-dialog-btn.secondary{
  background:rgba(255,255,255,.075);
}
.aitw-proximity-dialog-btn:active{transform:translateY(1px) scale(.99);}
@keyframes aitwDialogPop{
  from{opacity:0;transform:translateY(8px) scale(.965);}
  to{opacity:1;transform:translateY(0) scale(1);}
}
@media (max-width:720px), (pointer:coarse){
  .aitw-proximity-dialog-overlay{
    padding:14px;
    backdrop-filter:none;
    -webkit-backdrop-filter:none;
  }
  .aitw-proximity-dialog-panel{border-radius:20px;}
  .aitw-proximity-dialog-content{padding:28px 18px 22px;}
  .aitw-proximity-dialog-message{font-size:18px;line-height:1.7;}
  .aitw-proximity-dialog-btn{min-width:108px;min-height:46px;}
}
