:root{--safe-bottom: env(safe-area-inset-bottom, 0px);--safe-top: env(safe-area-inset-top, 0px);--primary-gradient: linear-gradient(135deg, #667eea 0%, #764ba2 100%)}body{background:url(/JP_building.jpeg) center/cover no-repeat fixed;font-family:Inter,system-ui,sans-serif;margin:0;padding:0;overflow:hidden}.glass{background:#ffffff26;backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);border:1px solid rgba(255,255,255,.3);box-shadow:0 8px 32px #0000001a}.page{position:fixed;top:0;right:0;bottom:0;left:0;opacity:0;visibility:hidden;transition:opacity .3s ease,visibility .3s ease}.page.active{opacity:1;visibility:visible}.action-card{background:#ffffff1a;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border:2px solid rgba(255,255,255,.2);border-radius:1.5rem;padding:2rem;color:#fff;display:flex;flex-direction:column;align-items:center;text-align:center;cursor:pointer;transition:all .3s ease}.action-card:hover{background:#ffffff2e;border-color:#fff6;transform:translateY(-4px);box-shadow:0 12px 24px #0003}.context-bar{position:sticky;top:0;z-index:100;background:var(--primary-gradient);color:#fff;padding:1rem 1.5rem;display:flex;align-items:center;justify-content:space-between;box-shadow:0 4px 20px #0000004d}.breadcrumb{display:flex;align-items:center;gap:.75rem;flex-wrap:wrap;font-size:15px;font-weight:500}.breadcrumb-back{display:flex;align-items:center;gap:.5rem;padding:.5rem 1rem;background:#ffffff26;border:1px solid rgba(255,255,255,.25);border-radius:.75rem;color:#fff;cursor:pointer;transition:all .2s}.breadcrumb-back:hover{background:#ffffff40;transform:translate(-2px)}.breadcrumb-items{display:flex;align-items:center;gap:.5rem}.breadcrumb-item{padding:.5rem 1rem;background:#fff3;border-radius:.75rem;font-weight:600}.breadcrumb-separator{opacity:.6;font-size:18px}.context-actions{display:flex;gap:.75rem;align-items:center}.cast-btn-top{display:flex;align-items:center;gap:.5rem;padding:.5rem 1.25rem;background:#fff3;border:2px solid rgba(255,255,255,.3);border-radius:.75rem;color:#fff;font-weight:600;cursor:pointer;transition:all .2s}.cast-btn-top:hover{background:#ffffff4d;transform:scale(1.05)}.cast-btn-top.active{background:#ef4444cc;border-color:#ffffff80;animation:pulse 2s ease-in-out infinite}@keyframes pulse{0%,to{opacity:1}50%{opacity:.8}}.icon-btn{width:44px;height:44px;display:flex;align-items:center;justify-content:center;background:#ffffff26;border:1px solid rgba(255,255,255,.25);border-radius:.75rem;color:#fff;cursor:pointer;transition:all .2s}.icon-btn:hover{background:#ffffff40}.viewer-layout{display:flex;height:calc(100vh - 68px);overflow:hidden}.floor-selector{width:200px;background:#000000b3;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border-left:1px solid rgba(255,255,255,.1);padding:1.5rem 1rem;overflow-y:auto;display:flex;flex-direction:column;gap:1rem}.floor-selector-title{font-size:14px;font-weight:700;color:#ffffffb3;text-transform:uppercase;letter-spacing:.05em;margin-bottom:.5rem}.floor-buttons{display:flex;flex-direction:column;gap:.5rem}.floor-btn{padding:.75rem 1rem;background:#ffffff1a;border:2px solid transparent;border-radius:.75rem;color:#fff;font-weight:600;font-size:14px;cursor:pointer;transition:all .2s;text-align:left}.floor-btn:hover{background:#ffffff2e;transform:translate(-4px)}.floor-btn.active{background:#6366f1cc;border-color:#fff6;box-shadow:0 4px 12px #6366f166}.view-container{flex:1;position:relative;overflow:hidden;background:#0000004d}.view-wrapper{width:100%;height:100%;position:relative;display:flex;align-items:center;justify-content:center;padding:2rem;transform-origin:center center;transition:transform .3s ease}.main-image{max-width:100%;max-height:100%;object-fit:contain;border-radius:1rem;-webkit-user-select:none;user-select:none;pointer-events:none;display:block}.polygon-overlay{position:absolute;top:0;left:0;right:0;bottom:0;margin:auto;width:100%;height:100%;pointer-events:none}.polygon-overlay polygon{fill:#62d462cb;stroke:#00a700;stroke-width:2;cursor:pointer;pointer-events:auto;transition:all .2s}.polygon-overlay polygon:hover{fill:transparent;stroke-width:3}.direction-buttons{position:absolute;top:1rem;right:1rem;display:flex;gap:.5rem;flex-wrap:wrap;max-width:300px;z-index:10}.dir-btn{padding:.75rem 1.25rem;background:#ffffffe6;-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px);border:2px solid rgba(255,255,255,.5);border-radius:9999px;font-weight:800;font-size:14px;color:#1f2937;cursor:pointer;transition:all .2s;box-shadow:0 4px 12px #00000026}.dir-btn:hover{background:#fff;transform:translateY(-2px);box-shadow:0 6px 16px #0003}.zoom-controls{position:absolute;bottom:1rem;right:1rem;display:flex;gap:.5rem;z-index:10}.zoom-btn{width:44px;height:44px;display:flex;align-items:center;justify-content:center;background:#ffffffd9;-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px);border:1px solid rgba(255,255,255,.5);border-radius:.75rem;font-weight:800;font-size:20px;cursor:pointer;transition:all .2s;color:#1f2937}.zoom-btn:hover{background:#fff;transform:scale(1.1)}.controls-sidebar{position:fixed;top:0;right:-400px;width:380px;max-width:90vw;height:100vh;background:#0f172af2;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);border-left:1px solid rgba(255,255,255,.1);z-index:200;transition:right .3s ease;overflow-y:auto}.controls-sidebar.active{right:0}.controls-content{padding:2rem 1.5rem}.controls-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:2rem;padding-bottom:1rem;border-bottom:1px solid rgba(255,255,255,.1)}.close-btn-simple{width:40px;height:40px;display:flex;align-items:center;justify-content:center;background:#ffffff1a;border:1px solid rgba(255,255,255,.2);border-radius:.5rem;color:#fff;cursor:pointer;transition:all .2s}.close-btn-simple:hover{background:#fff3}.controls-body{display:flex;flex-direction:column;gap:2rem}.control-section{display:flex;flex-direction:column;gap:1rem}.section-title{font-size:14px;font-weight:700;color:#ffffffb3;text-transform:uppercase;letter-spacing:.05em}.control-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:.75rem}.control-btn{padding:1rem;background:#ffffff1a;border:2px solid rgba(255,255,255,.2);border-radius:.75rem;color:#fff;font-weight:600;font-size:14px;cursor:pointer;transition:all .2s;text-align:center}.control-btn:hover{background:#ffffff26;border-color:#ffffff4d;transform:translateY(-2px)}.control-btn.active{background:#6366f199;border-color:#6366f1cc}.controls-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;background:#0009;z-index:199;opacity:0;visibility:hidden;transition:opacity .3s,visibility .3s}.controls-backdrop.active{opacity:1;visibility:visible}.cast-banner{position:fixed;top:-60px;left:50%;transform:translate(-50%);background:var(--primary-gradient);color:#fff;padding:12px 30px;border-radius:9999px;font-weight:500;box-shadow:0 4px 20px #0000004d;z-index:150;transition:all .4s ease;max-width:92vw;text-align:center}.cast-banner.active{top:calc(14px + var(--safe-top))}@media (max-width: 768px){.floor-selector{position:fixed;right:0;top:68px;width:160px;height:calc(100vh - 68px);transform:translate(100%);transition:transform .3s ease;z-index:90}.floor-selector.mobile-open{transform:translate(0)}.view-wrapper{padding:1rem}.direction-buttons{top:.5rem;right:.5rem;max-width:200px}.dir-btn{padding:.5rem 1rem;font-size:12px}.zoom-controls{bottom:.5rem;right:.5rem}.zoom-btn{width:40px;height:40px}}.hidden{display:none!important}
