*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}:root{--font-pixel: "VT323", monospace;--font-ui: "Noto Sans TC", "Helvetica Neue", sans-serif;--wa-header-bg: #075e54;--wa-header-text: #ffffff;--wa-body-bg: #e5ddd5;--wa-bubble-in: #ffffff;--wa-bubble-out: #dcf8c6;--wa-meta-text: #999;--wa-input-bg: #f0f0f0;--wa-send-btn: #128c7e;--accent: #f4a261}html,body{width:100%;height:100%;overflow:hidden;background:#000;cursor:crosshair}#app{position:relative;width:100vw;height:100vh;overflow:hidden}#scene-container{position:absolute;top:0;right:0;bottom:0;left:0;display:none}#scene-container canvas{display:block;width:100%!important;height:100%!important;image-rendering:pixelated;image-rendering:crisp-edges}#fade-overlay{position:absolute;top:0;right:0;bottom:0;left:0;background:#000;opacity:0;pointer-events:none;z-index:80;transition:opacity 3s ease}#fade-overlay.fade-in{opacity:1;pointer-events:all}#fade-overlay.fade-out{opacity:0}#start-screen{position:absolute;top:0;right:0;bottom:0;left:0;background:#000;display:flex;flex-direction:column;align-items:center;justify-content:center;z-index:100;gap:2.5rem}.start-title{font-family:var(--font-pixel);font-size:clamp(1.1rem,2.8vw,2.2rem);color:#e8d5b0;text-align:center;line-height:1.6;letter-spacing:.02em;max-width:70vw;text-shadow:0 0 30px rgba(244,162,97,.35)}.start-title.lang-zh{font-family:DotGothic16,monospace;font-size:clamp(.78rem,1.9vw,1.55rem);letter-spacing:.18em;line-height:1.9}.start-btn.lang-zh{font-family:DotGothic16,monospace;font-size:1.05rem}.start-subtitle{font-family:var(--font-pixel);font-size:clamp(.9rem,1.5vw,1.2rem);color:#888;letter-spacing:.08em}.lang-select{display:flex;gap:1.5rem}.lang-btn{font-family:var(--font-pixel);font-size:1.4rem;color:#aaa;background:none;border:1px solid #333;padding:.5rem 1.8rem;cursor:pointer;letter-spacing:.1em;transition:color .2s,border-color .2s,text-shadow .2s}.lang-btn:hover,.lang-btn.selected{color:#e8d5b0;border-color:#666;text-shadow:0 0 12px rgba(232,213,176,.5)}.start-btn{font-family:var(--font-pixel);font-size:1.5rem;color:#000;background:#e8d5b0;border:none;padding:.6rem 3rem;cursor:pointer;letter-spacing:.12em;transition:background .2s,box-shadow .2s;opacity:0;pointer-events:none}.start-btn.visible{opacity:1;pointer-events:all}.start-btn:hover{background:#f4c980;box-shadow:0 0 20px #f4c98066}#end-screen{position:absolute;top:0;right:0;bottom:0;left:0;background:#000;display:none;flex-direction:column;align-items:center;justify-content:center;z-index:90}#end-screen.visible{display:flex}.end-attribution{font-family:var(--font-ui);font-size:clamp(.9rem,2vw,1.4rem);font-weight:300;color:#ccc;letter-spacing:.25em;opacity:0;transition:opacity 4s ease 1s}.end-attribution.show{opacity:1}#phone-overlay{position:absolute;top:0;right:0;bottom:0;left:0;display:none;pointer-events:none;z-index:50}#phone-overlay.active{display:block}.phone{position:absolute;bottom:4vh;right:18vw;width:18vw;min-width:160px;max-width:240px;aspect-ratio:9 / 19.5;background:#1c1c1e;border-radius:2.5vw;box-shadow:0 8px 32px #000000b3,inset 0 1px #ffffff14;transform:rotate(4deg) perspective(600px) rotateX(6deg) rotateY(-8deg);transform-origin:bottom right;transition:all .45s cubic-bezier(.25,.46,.45,.94);pointer-events:all;cursor:pointer;overflow:visible;z-index:0}.phone:before{content:"";position:absolute;top:5%;left:5%;right:5%;bottom:5%;background:#111;border-radius:1.5vw;z-index:2}.phone-screen{position:absolute;top:5%;left:5%;right:5%;bottom:5%;overflow:hidden;z-index:2}.phone-hand{position:absolute;bottom:-20%;left:60%;right:-60%;height:80%;z-index:-1;image-rendering:pixelated;background:#c8956c;transform:rotate(-37deg);transform-origin:bottom right;box-shadow:inset 0 40px #dba878,inset 0 -20px #9b6a3d}.phone.enlarged .phone-hand{display:none}.phone.enlarged{width:min(380px,55vw);min-width:unset;max-width:unset;bottom:50%;right:50%;transform:translate(50%,50%) rotate(0) perspective(600px) rotateX(0) rotateY(0);border-radius:1.5rem;cursor:default;z-index:60}.phone:after{content:"";position:absolute;top:0;right:0;bottom:0;left:0;background:#1c1c1e;border-radius:2.5vw;z-index:0;pointer-events:none}.phone.enlarged:before{display:none}.phone.enlarged:after{border-radius:1.5rem}.phone.enlarged .phone-screen{top:0;left:0;right:0;bottom:0;border-radius:1.5rem;animation:phoneScreenReveal .35s ease-out both}@keyframes phoneScreenReveal{0%{opacity:0}60%{opacity:0}to{opacity:1}}.phone.enlarged .phone-hand{bottom:-18%;left:-8%;right:-8%;height:22%}.phone-chat{display:none;flex-direction:column;height:100%;font-family:var(--font-ui);font-size:14px;overflow:hidden}.phone.enlarged .phone-chat{display:flex}.chat-header{display:flex;align-items:center;gap:10px;background:var(--wa-header-bg);padding:10px 14px;flex-shrink:0}.chat-header .back-arrow{display:none;color:#fff;font-size:1.3rem;line-height:1;cursor:pointer;padding-right:4px}.chat-header .avatar{width:38px;height:38px;border-radius:50%;object-fit:cover;background:#ccc;flex-shrink:0}.chat-header .header-info{flex:1;min-width:0}.chat-header .contact-name{color:#fff;font-weight:600;font-size:1rem;display:block;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.chat-header .last-seen{color:#ffffffbf;font-size:.78rem;display:block}.call-btn{background:none;border:none;cursor:pointer;padding:4px;color:#fff;display:flex;align-items:center;justify-content:center;flex-shrink:0;opacity:.9;transition:opacity .15s}.call-btn:hover{opacity:1}.call-btn svg{width:22px;height:22px;fill:#fff}.chat-overlay{position:absolute;top:0;right:0;bottom:0;left:0;z-index:20;display:none;flex-direction:column;background:#fff;border-radius:inherit;overflow:hidden}.chat-overlay.visible{display:flex}.overlay-header{display:flex;align-items:center;gap:10px;background:var(--wa-header-bg);color:#fff;padding:10px 14px;flex-shrink:0}.overlay-title{font-weight:600;font-size:1rem;flex:1}.overlay-close{background:none;border:none;color:#fff;font-size:1.1rem;cursor:pointer;padding:2px 6px;opacity:.85;transition:opacity .15s}.overlay-close:hover{opacity:1}.profile-modal{background:#f0f2f5}.profile-photo-header{position:relative;flex-shrink:0;height:210px;background:#2a2a2a;overflow:hidden}.profile-photo{width:100%;height:100%;object-fit:cover;display:block;opacity:.85}.profile-photo-header:after{content:"";position:absolute;top:0;right:0;bottom:0;left:0;background:linear-gradient(to bottom,transparent 40%,rgba(0,0,0,.65) 100%);pointer-events:none}.profile-back{position:absolute;top:10px;left:10px;z-index:2;background:none;border:none;color:#fff;font-size:1.6rem;line-height:1;cursor:pointer;padding:2px 6px;text-shadow:0 1px 3px rgba(0,0,0,.5)}.profile-photo-info{position:absolute;bottom:12px;left:16px;right:16px;z-index:2}.profile-photo-name{display:block;color:#fff;font-size:1.25rem;font-weight:700;text-shadow:0 1px 4px rgba(0,0,0,.5)}.profile-photo-status{display:block;color:#ffffffbf;font-size:.78rem;margin-top:2px}.profile-scroll-body{flex:1;overflow-y:auto;display:flex;flex-direction:column;gap:8px;padding:8px 0 16px}.profile-actions{display:flex;justify-content:center;gap:24px;background:#fff;padding:14px 20px}.profile-action{display:flex;flex-direction:column;align-items:center;gap:5px;background:none;border:none;cursor:pointer;color:var(--wa-header-bg);font-family:var(--font-ui);font-size:.75rem;font-weight:500;transition:opacity .15s;min-width:56px}.profile-action:hover{opacity:.75}.profile-action svg{width:24px;height:24px;fill:var(--wa-header-bg)}.profile-section{background:#fff;padding:14px 20px}.profile-info-row{display:flex;align-items:flex-start;gap:18px}.profile-info-icon{width:22px;height:22px;fill:#8696a0;flex-shrink:0;margin-top:2px}.profile-info-text{flex:1}.profile-info-value{font-size:.88rem;color:#111;line-height:1.5}.profile-info-label{font-size:.72rem;color:#8696a0;margin-top:3px}.profile-media-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:10px}.profile-media-title{font-size:.82rem;color:#8696a0;font-weight:500;text-transform:uppercase;letter-spacing:.04em}.profile-media-count{font-size:.78rem;color:var(--wa-header-bg)}.profile-media-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:3px}.profile-media-cell{aspect-ratio:1;border-radius:4px;display:flex;align-items:center;justify-content:center;font-size:1.4rem;cursor:pointer;transition:opacity .15s}.profile-media-cell:hover{opacity:.8}.call-screen{align-items:center;justify-content:center;gap:18px;background:#1a1a2e;color:#fff}.call-avatar{width:90px;height:90px;border-radius:50%;object-fit:cover;background:#333;border:3px solid rgba(255,255,255,.2)}.call-name{font-size:1.4rem;font-weight:600;letter-spacing:.02em}.call-status{font-size:.9rem;color:#fff9;animation:callPulse 1.8s ease-in-out infinite}@keyframes callPulse{0%,to{opacity:.5}50%{opacity:1}}.call-end-btn{margin-top:24px;width:62px;height:62px;border-radius:50%;background:#e53935;border:none;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:background .15s}.call-end-btn:hover{background:#c62828}.call-end-btn svg{width:28px;height:28px;fill:#fff;transform:rotate(135deg)}.photo-lightbox{background:#000;align-items:stretch;justify-content:flex-end;flex-direction:column;gap:0}.lightbox-close{position:absolute;top:12px;right:14px;font-size:1.2rem;z-index:2}.lightbox-tile-wrap{flex:1;display:flex;align-items:center;justify-content:center;overflow:hidden;padding:0}.lightbox-tile-wrap .photo-tile{width:100%;height:auto;border-radius:0;margin:0}.lightbox-tile-wrap .photo-tile .photo-img{width:100%;height:auto;object-fit:contain;border-radius:0}.photo-tile--xl{width:200px;height:200px;border-radius:12px}.photo-tile--xl .photo-emoji{font-size:4rem}.lightbox-caption{padding:12px 24px 20px;font-size:.88rem;color:#ffffffb3;text-align:center}.voice-play-btn{background:#0000001f;border:none;border-radius:50%;width:30px;height:30px;cursor:pointer;font-size:.85rem;display:flex;align-items:center;justify-content:center;flex-shrink:0;transition:background .15s}.voice-play-btn:hover{background:#00000038}.chat-messages{flex:1;overflow-y:auto;overflow-x:hidden;background:var(--wa-body-bg);padding:10px 10px 6px;display:flex;flex-direction:column;gap:3px;scroll-behavior:smooth}.chat-messages::-webkit-scrollbar{width:3px}.chat-messages::-webkit-scrollbar-thumb{background:#00000026;border-radius:2px}.msg-row{display:flex;flex-direction:column;max-width:78%}.msg-row.incoming{align-self:flex-start}.msg-row.outgoing{align-self:flex-end}.msg-bubble{padding:6px 9px;border-radius:7.5px;line-height:1.4;font-size:.88rem;word-break:break-word;position:relative}.incoming .msg-bubble{background:var(--wa-bubble-in);border-top-left-radius:2px;box-shadow:0 1px 2px #0000001a}.outgoing .msg-bubble{background:var(--wa-bubble-out);border-top-right-radius:2px;box-shadow:0 1px 2px #0000001a}.msg-meta{font-size:.67rem;color:var(--wa-meta-text);margin-top:2px;display:flex;align-items:center;gap:3px}.incoming .msg-meta{align-self:flex-start}.outgoing .msg-meta{align-self:flex-end}.msg-tick{font-size:.75rem;line-height:1;letter-spacing:-.1em}.msg-tick--sending{color:#bbb;opacity:.6}.msg-tick--sent{color:#9e9e9e}.msg-tick--seen{color:#4fc3f7}.msg-bubble.sending{opacity:.6}.date-separator{align-self:center;background:#e1f5fed9;color:#777;font-size:.72rem;padding:3px 10px;border-radius:8px;margin:6px 0}.typing-indicator{display:none;align-self:flex-start;background:var(--wa-bubble-in);border-radius:7.5px;padding:8px 14px;gap:4px}.typing-indicator.visible{display:flex}.typing-dot{width:6px;height:6px;border-radius:50%;background:#aaa;animation:typingBounce 1.2s infinite}.typing-dot:nth-child(2){animation-delay:.2s}.typing-dot:nth-child(3){animation-delay:.4s}@keyframes typingBounce{0%,80%,to{transform:translateY(0);opacity:.5}40%{transform:translateY(-5px);opacity:1}}.branch-choices{display:flex;flex-direction:column;gap:5px;align-self:flex-end;max-width:78%}.branch-btn{font-family:var(--font-ui);font-size:.82rem;background:var(--wa-header-bg);color:#fff;border:none;border-radius:16px;padding:6px 14px;cursor:pointer;text-align:left;transition:background .15s}.branch-btn:hover{background:#0a8a7a}.msg-voice{display:flex;align-items:center;gap:8px;min-width:140px;padding:8px 12px}.voice-icon{font-size:.95rem;opacity:.75;flex-shrink:0}.voice-bars{display:flex;align-items:center;gap:2px;flex:1}.voice-bar{display:inline-block;width:3px;background:currentColor;border-radius:2px;opacity:.55}.voice-duration{font-size:.75rem;opacity:.65;flex-shrink:0}.msg-photo{padding:6px 6px 8px;min-width:140px}.photo-tile{width:100%;height:100px;border-radius:6px;display:flex;align-items:center;justify-content:center;margin-bottom:6px}.photo-tile--teal{background:linear-gradient(135deg,#0d7377,#14a085)}.photo-tile--amber{background:linear-gradient(135deg,#d4831a,#f4a261)}.photo-tile--orange{background:linear-gradient(135deg,#e05c1a,#f4793b)}.photo-tile--warm{background:linear-gradient(135deg,#c8893a,#e4b56a)}.photo-emoji{font-size:2.2rem}.photo-img{width:100%;height:100%;object-fit:cover;border-radius:inherit;display:block}.photo-img--full{border-radius:12px}.photo-caption{font-size:.78rem;font-style:italic;opacity:.75;padding:0 6px}.photo-text{font-size:.82rem;padding:4px 6px 0}.network-banner{background:#fef3c7;color:#92400e;font-size:.72rem;padding:4px 10px;text-align:center;display:none;flex-shrink:0}.network-banner.visible{display:block}.chat-input-area{display:flex;align-items:center;gap:8px;background:#f0f0f0;padding:7px 10px;flex-shrink:0}.chat-input{flex:1;background:#fff;border:none;border-radius:20px;padding:8px 14px;font-family:var(--font-ui);font-size:.88rem;outline:none;color:#333}.chat-input::placeholder{color:#bbb}.send-btn{width:38px;height:38px;border-radius:50%;background:var(--wa-send-btn);border:none;cursor:pointer;display:flex;align-items:center;justify-content:center;flex-shrink:0;transition:background .15s}.send-btn:hover{background:#0a8a7a}.send-btn svg{width:18px;height:18px;fill:#fff}.phone-backdrop{position:absolute;top:0;right:0;bottom:0;left:0;background:#00000073;opacity:0;pointer-events:none;transition:opacity .45s;z-index:55}.phone-backdrop.visible{opacity:1;pointer-events:all}.hidden{display:none!important}
