#root{width:100vw;height:100vh;display:flex;flex-direction:column}.app{flex:1;display:flex;flex-direction:column;min-height:0}.app-header{padding:8px 12px;background:#16213e;display:flex;align-items:center;flex-wrap:wrap;gap:12px}.app-header h1{font-size:18px;margin:0;color:#fff}.header-sub{font-size:12px;color:#8a8;margin-right:8px}.app-nav{display:flex;gap:8px;align-items:center;flex-wrap:wrap;margin-left:auto}.app-nav a{color:#aaa;text-decoration:none;padding:4px 10px;border-radius:4px;font-size:14px}.app-nav a:hover{color:#fff;background:#ffffff1a}.app-nav a.active{color:#e94560;font-weight:600}.app-main-single{flex:1;padding:16px;overflow:auto;min-height:0}.page-loading{padding:24px;color:#888}.page-title{margin:0 0 8px;color:#e94560;font-size:20px}.page-desc{margin:0 0 16px;color:#8a8;font-size:13px}.city-chat-page .city-chat-list{list-style:none;padding:0;margin:0}.city-chat-item{padding:12px;border-bottom:1px solid rgba(255,255,255,.08)}.city-chat-item-author{font-weight:600;color:#e94560;margin-right:8px}.city-chat-item-time{font-size:11px;color:#666}.city-chat-item-text{margin-top:4px;color:#ccc;white-space:pre-wrap;word-break:break-word}.city-chat-form{display:flex;gap:8px;margin-bottom:16px;flex-wrap:wrap}.city-chat-form input{padding:8px 12px;border:1px solid rgba(255,255,255,.2);border-radius:6px;background:#0003;color:#eee}.city-chat-input-author{width:120px}.city-chat-input-text{flex:1;min-width:200px}.city-chat-form button{padding:8px 16px;background:#e94560;color:#fff;border:none;border-radius:6px;cursor:pointer}.city-chat-form button:disabled{opacity:.5;cursor:not-allowed}.social-feed,.forum-thread-list{list-style:none;padding:0;margin:0}.social-post,.forum-thread{padding:12px;border-bottom:1px solid rgba(255,255,255,.08)}.social-post-author,.forum-post-author{font-weight:600;color:#e94560;margin-right:8px}.social-post-time,.forum-post-time{font-size:11px;color:#666}.social-post-text,.forum-post-text{margin-top:4px;color:#ccc}.forum-thread-title{background:none;border:none;color:#eee;cursor:pointer;font-size:15px;text-align:left;width:100%;padding:4px 0}.forum-thread-title:hover{color:#e94560}.forum-thread-meta{font-size:12px;color:#888;display:block;margin-bottom:8px}.forum-posts{list-style:none;padding:0 0 0 16px;margin:8px 0 0;border-left:2px solid #333}.forum-post{padding:8px 0}.header-link{color:#e94560;text-decoration:none}.header-link:hover{text-decoration:underline}.btn-link{background:none;border:none;cursor:pointer;font:inherit;color:#e94560;padding:0}.btn-link:hover{text-decoration:underline}.stream-overlay{position:fixed;top:0;right:0;bottom:0;left:0;z-index:100;background:#0f0f1a;display:flex;flex-direction:column}.stream-header{display:flex;align-items:center;gap:12px;padding:8px 12px;background:#16213e;flex-shrink:0}.stream-header .btn-back{background:#e94560;color:#fff;border:none;padding:6px 12px;cursor:pointer;border-radius:4px}.stream-header .btn-back:hover{opacity:.9}.stream-hint{font-size:12px;color:#8a8}.stream-img{flex:1;width:100%;object-fit:contain;min-height:0}.stream-inline{display:flex;flex-direction:column;flex:1;min-height:0;background:#0f0f1a;overflow:hidden}.stream-inline .stream-img{width:100%;height:100%;object-fit:cover;min-height:0;display:block}.stream-viewport{flex:1;min-height:320px;min-width:200px;background:#0a0a12;overflow:hidden;position:relative;-webkit-user-select:none;user-select:none;touch-action:none}.stream-viewport .stream-transform-wrap{position:absolute;top:0;right:0;bottom:0;left:0;display:flex;align-items:center;justify-content:center;will-change:transform}.stream-viewport .stream-img{width:100%;height:100%;min-width:200px;min-height:200px;object-fit:contain;display:block;pointer-events:none;background:#0a0a12}.stream-map-controls{position:absolute;bottom:20px;right:20px;display:flex;flex-direction:column;gap:10px;z-index:1000;pointer-events:auto}.stream-map-controls-title{font-size:12px;font-weight:700;color:#e94560;text-align:center;text-transform:uppercase;letter-spacing:.05em}.stream-map-zoom{display:flex;align-items:center;gap:6px;background:#1a1a2e;padding:8px 10px;border-radius:10px;border:2px solid #444;box-shadow:0 4px 20px #00000080}.stream-map-zoom button{width:44px;height:44px;border:2px solid #555;background:#252540;color:#fff;font-size:22px;font-weight:700;line-height:1;cursor:pointer;border-radius:8px;display:flex;align-items:center;justify-content:center}.stream-map-zoom button:hover{background:#e94560;border-color:#e94560;color:#fff}.stream-map-zoom-label{font-size:14px;color:#ccc;min-width:48px;text-align:center;font-weight:600}.stream-map-arrows{display:flex;flex-direction:column;align-items:center;gap:4px;background:#1a1a2e;padding:10px;border-radius:10px;border:2px solid #444;box-shadow:0 4px 20px #00000080}.stream-map-arrows-mid{display:flex;gap:6px;align-items:center}.stream-map-controls button{width:48px;height:48px;border:2px solid #555;background:#252540;color:#fff;font-size:18px;line-height:1;cursor:pointer;border-radius:8px;display:flex;align-items:center;justify-content:center}.stream-map-controls button:hover,.stream-map-arrows button:hover{background:#e94560;border-color:#e94560;color:#fff}.stream-map-hint{position:absolute;top:12px;left:12px;font-size:13px;color:#aaa;z-index:1000;pointer-events:none;background:#000000bf;padding:10px 14px;border-radius:8px;border:1px solid #444}.stream-hint-inline{font-size:12px;color:#8a8;margin:8px 0 0}.canvas-wrap{flex:1;position:relative;min-height:320px;background:#0f0f1a}.canvas-wrap canvas{display:block;width:100%;height:100%}.city-map{image-rendering:pixelated}.city-map-pixi canvas{display:block;image-rendering:pixelated;image-rendering:crisp-edges}.city-map-world{background-size:200% 200%;animation:city-map-bg-shift 20s ease-in-out infinite}@keyframes city-map-bg-shift{0%,to{background-position:0% 50%}50%{background-position:100% 50%}}.city-map-glow{position:absolute;top:-20%;right:-20%;bottom:-20%;left:-20%;background:radial-gradient(ellipse 60% 50% at 50% 50%,rgba(0,180,255,.06) 0%,rgba(180,0,255,.04) 50%,transparent 65%);pointer-events:none;animation:city-glow-pulse 8s ease-in-out infinite}@keyframes city-glow-pulse{0%,to{opacity:.6}50%{opacity:1}}.city-map-scan{position:absolute;top:0;right:0;bottom:0;left:0;background:linear-gradient(180deg,transparent 0%,rgba(0,200,255,.02) 50%,transparent 100%);background-size:100% 200%;animation:city-scan 12s linear infinite;pointer-events:none}@keyframes city-scan{0%{background-position:0 0}to{background-position:0 100%}}.city-map-particles{position:absolute;top:0;right:0;bottom:0;left:0;pointer-events:none;background-image:radial-gradient(2px 2px at 20% 30%,rgba(0,220,255,.25),transparent),radial-gradient(2px 2px at 80% 70%,rgba(255,80,200,.2),transparent),radial-gradient(1px 1px at 50% 50%,rgba(180,255,100,.15),transparent);background-size:200% 200%;animation:city-particles 15s ease-in-out infinite}@keyframes city-particles{0%,to{opacity:.8;transform:translate(0)}50%{opacity:1;transform:translate(2%,-2%)}}.city-map-pulse-ring{position:absolute;left:50%;top:50%;width:120px;height:120px;margin-left:-60px;margin-top:-60px;border:1px solid rgba(0,200,255,.2);border-radius:50%;animation:city-pulse-ring 4s ease-out infinite;pointer-events:none}@keyframes city-pulse-ring{0%{transform:scale(.6);opacity:.8}to{transform:scale(2.5);opacity:0}}.city-parallax-sky,.city-parallax-hills{z-index:0}.city-vignette{z-index:4}.city-sun-overlay{z-index:3}.city-map-inner{z-index:2}.city-entity{will-change:transform}.city-building-depth:hover{filter:drop-shadow(0 4px 12px rgba(0,0,0,.5)) brightness(1.05)}.city-parallax-hills{animation:city-hills-drift 25s ease-in-out infinite}@keyframes city-hills-drift{0%,to{opacity:.9;transform:translate(0)}50%{opacity:1;transform:translate(2%)}}.city-map-label{position:absolute;bottom:12px;left:50%;transform:translate(-50%);font-size:11px;color:#00dcffbf;letter-spacing:.12em;text-transform:uppercase;text-shadow:0 0 10px rgba(0,200,255,.5);pointer-events:none}.city-tile-empty{animation:tile-breathe 5s ease-in-out infinite}.city-building{box-shadow:inset 0 -2px #0000004d,0 2px 4px #0006;transition:transform .15s ease,box-shadow .15s ease}.city-building:hover{transform:scale(1.08);box-shadow:inset 0 -2px #0003,0 4px 12px #00000080}.city-building-mayor{animation:building-pulse 2.5s ease-in-out infinite}.city-building-bank{animation:building-shine 3s ease-in-out infinite}.city-building-cafe{animation:building-pulse 3s ease-in-out infinite .5s}.city-building-office{animation:building-pulse 4s ease-in-out infinite 1s}.pixel-building-in-cell{transition:transform .15s ease}.pixel-building-in-cell:hover{transform:scale(1.15)}@keyframes pixel-window-flicker{0%,90%,to{opacity:1}92%,96%{opacity:.6}94%{opacity:1}}@keyframes tile-breathe{0%,to{opacity:1}50%{opacity:.85}}@keyframes building-pulse{0%,to{filter:brightness(1)}50%{filter:brightness(1.15)}}@keyframes building-shine{0%,to{filter:brightness(1)}50%{filter:brightness(1.12)}}.city-activity-dot{position:absolute;width:8px;height:8px;border-radius:50%;background:#b8ff00;box-shadow:0 0 12px #b8ff00,0 0 24px #b8ff0080;animation:activity-walk 8s linear infinite;pointer-events:none}.city-activity-dot-2{animation:activity-walk-2 10s linear infinite}.city-activity-dot-3{animation:activity-walk-3 7s linear infinite}@keyframes activity-walk{0%{left:5%;top:20%}25%{left:40%;top:15%}50%{left:70%;top:50%}75%{left:30%;top:75%}to{left:5%;top:20%}}@keyframes activity-walk-2{0%{left:80%;top:70%}33%{left:60%;top:25%}66%{left:20%;top:60%}to{left:80%;top:70%}}@keyframes activity-walk-3{0%{left:40%;top:45%}50%{left:55%;top:35%}to{left:40%;top:45%}}.sidebar{width:320px;background:#16213e;padding:12px;overflow-y:auto;font-size:13px}.sidebar h3{margin-bottom:8px;color:#e94560}.sidebar-muted{font-size:12px;color:#888;margin-bottom:8px}.agent-list{list-style:none;padding:0;margin:0 0 12px}.agent-list li{display:flex;align-items:center;gap:8px;padding:4px 0;font-size:12px;color:#ccc}.agent-list li.agent-active{color:#b8e986}.agent-dot{width:8px;height:8px;border-radius:50%;flex-shrink:0}.live-toast{position:fixed;bottom:24px;left:50%;transform:translate(-50%);background:#16213e;color:#4ade80;padding:10px 20px;border-radius:8px;box-shadow:0 4px 20px #0006;display:flex;align-items:center;gap:10px;font-size:14px;z-index:2000;animation:live-toast-in .25s ease}.live-toast-pulse{width:8px;height:8px;border-radius:50%;background:#4ade80;animation:pulse 1s ease infinite}@keyframes live-toast-in{0%{opacity:0;transform:translate(-50%) translateY(10px)}to{opacity:1;transform:translate(-50%) translateY(0)}}@keyframes pulse{0%,to{opacity:1}50%{opacity:.4}}.sidebar ul{list-style:none}.sidebar li{padding:4px 0;border-bottom:1px solid rgba(255,255,255,.08)}.events li{font-size:12px;color:#aaa}.city-chat{max-height:320px;overflow-y:auto}.city-chat-message{margin-bottom:8px;padding:6px 0;border-bottom:1px solid rgba(255,255,255,.06)}.city-chat-author{font-weight:600;color:#e94560;flex-shrink:0}.city-chat-text{color:#ccc;word-break:break-word}.btn{background:#e94560;color:#fff;border:none;padding:8px 14px;border-radius:6px;cursor:pointer;margin-top:8px;font-size:13px}.btn:hover{background:#ff6b6b}.btn-secondary{background:#2a2a4a}.btn-secondary:hover{background:#3a3a5a}.settings-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#0009;display:flex;align-items:center;justify-content:center;z-index:1000}.settings-modal{background:#16213e;border-radius:12px;padding:0;max-width:420px;width:90%;box-shadow:0 8px 32px #0006}.settings-header{display:flex;justify-content:space-between;align-items:center;padding:12px 16px;border-bottom:1px solid #2a2a4a}.settings-header h2{font-size:18px}.btn-close{background:none;border:none;color:#aaa;font-size:24px;cursor:pointer;line-height:1}.btn-close:hover{color:#fff}.settings-body{padding:16px}.settings-body h3{font-size:14px;margin-bottom:8px;color:#e94560}.settings-hint{font-size:12px;color:#888;margin-bottom:12px}.settings-input{width:100%;padding:10px 12px;border:1px solid #333;border-radius:8px;background:#1a1a2e;color:#fff;font-size:14px;margin-bottom:12px}.settings-input:focus{outline:none;border-color:#e94560}.settings-actions{margin-top:8px}.settings-message,.settings-status{font-size:12px;margin-top:8px;color:#8f8}.layout{display:flex;height:100%}.content{flex:1;display:flex;flex-direction:column;min-width:0;min-height:280px}.office-view{padding:12px;background:#1a1a2e;border-bottom:1px solid #333}.office-view h2{font-size:16px;color:#e94560}.office-view p{margin:4px 0;color:#aaa}.office-view-pixel .office-room{image-rendering:pixelated}.office-view-pixel .office-desk{animation:office-desk-idle 3s ease-in-out infinite}.office-view-pixel .office-worker{animation:office-worker-idle 2.5s ease-in-out infinite}@keyframes office-desk-idle{0%,to{filter:brightness(1)}50%{filter:brightness(1.05)}}@keyframes office-worker-idle{0%,to{transform:translateY(0)}50%{transform:translateY(-1px)}}
