.auth-container{min-height:100vh;display:flex;flex-direction:column;align-items:center;justify-content:center;padding:20px;background-color:#fff}.auth-card{width:100%;max-width:400px;padding:30px;border-radius:12px;background:#fff;box-shadow:0 8px 25px #0000001a;text-align:center}.auth-card label{margin:6px 2px;font-size:14px;font-weight:500;color:#0b2027;text-align:left;display:block}.auth-card form{display:flex;flex-direction:column}.title{font-size:22px;margin:18px;color:#0b2027}.subtitle{color:#0b2027;margin-bottom:20px}.auth-form{display:flex;flex-direction:column;gap:14px;margin-top:10px}.input{width:100%;padding:12px;font-size:15px;border:1px solid #ccc;border-radius:8px;outline:none;transition:all .2s ease;box-sizing:border-box}.input:focus{border-color:#0166ff;box-shadow:0 0 0 2px #0166ff1a}.form-group{display:flex;flex-direction:column}.btn-primary{padding:12px;font-size:16px;background:#0166ff;color:#fff;border:none;border-radius:6px;cursor:pointer;margin-top:8px}.btn-primary:hover{background:#3a74d1}.btn-secondary{padding:12px;font-size:16px;background:#ffecaa;border:none;border-radius:6px;cursor:pointer}.logo{width:240px;max-width:60%;height:auto;margin-bottom:20px}.title{margin-top:10px}.btn-secondary:hover{background:#cdd2da}.switch-text{margin-top:5px;font-size:14px;color:#0b2027}.switch-link{color:#4c8bf5;cursor:pointer;font-weight:500}.switch-link:hover{text-decoration:underline}.switch-area{margin-top:0;display:flex;flex-direction:column;gap:5px}@media(max-width:768px){.logo{width:240px}.auth-card{padding:20px}}@media(max-width:480px){.logo{width:180px}}.dashboard{padding:16px;max-width:1400px;margin:auto}.dashboard h2{margin-bottom:8px}.dashboard h3{font-weight:400;opacity:.8;margin-bottom:16px}.tour-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:16px}.tour-card{background:#0b1b28;padding:12px;border-radius:12px;cursor:pointer;transition:transform .2s ease,box-shadow .2s ease}.tour-card:hover{transform:translateY(-4px);box-shadow:0 10px 30px #0006}.tour-card img{width:100%;height:160px;object-fit:cover;border-radius:8px}.tour-info{margin-top:10px}.tour-info b{font-size:14px}.tour-date{font-size:12px;opacity:.7}.tour-card video{width:100%;height:160px;object-fit:cover;border-radius:8px;background:#000}.badge{position:absolute;top:10px;left:10px;font-size:11px;padding:4px 8px;border-radius:12px;color:#fff;font-weight:600}.badge.photo{background:#1fa36b}.badge.video{background:#e5533d}.tour-card{position:relative}@media(max-width:480px){.tour-card img,.tour-card video{height:140px}}:root{--bg-dark: #0B2027;--bg-panel: #132a3a;--accent: #22c55e;--text-light: #cbd5e1}html,body{margin:0;padding:0;height:100%;font-family:system-ui,-apple-system,sans-serif}.viewer-root{width:100vw;height:100vh;background:var(--bg-dark);position:relative}.viewer-header{position:fixed;top:0;width:100%;height:56px;background:linear-gradient(90deg,#0a6847,#0d7a55);display:flex;align-items:center;padding:0 12px;z-index:1000}.header-logo{height:34px}.header-left{margin-left:10px;cursor:pointer}.header-title{font-size:14px;font-weight:600;text-decoration:underline}.header-right{margin-left:auto;display:flex;align-items:center;gap:8px}.toggle-btn{padding:6px 12px;border-radius:20px;font-size:12px;font-weight:500;border:none;cursor:pointer;transition:.2s}.toggle-btn.active{background:#22c55e;color:#fff}.toggle-btn.inactive{background:#ef4444;color:#fff}.viewer-header select{background:#0f2535;color:#fff;border:none;padding:6px 10px;border-radius:10px;font-size:13px}.viewer-canvas{position:absolute;top:56px;width:100%;height:calc(100vh - 56px);background:#000}.hotspot-panel{position:fixed;bottom:0;width:100%;height:38vh;background:#0b1b28f2;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);border-top:1px solid rgba(255,255,255,.1);padding:10px;overflow-y:auto;z-index:900}.hotspot-panel:empty{display:none}.drag-handle{width:40px;height:4px;background:#ffffff4d;border-radius:10px;margin:0 auto 8px}.hotspot-item{background:linear-gradient(135deg,#0f2e2a,#0a3d2f);border-radius:14px;padding:12px;margin-bottom:10px;border:1px solid rgba(255,255,255,.08);box-shadow:0 4px 10px #0000004d}.hotspot-item h4{margin:0;font-size:14px;font-weight:600}.hotspot-item p{font-size:12px;opacity:.8;margin:4px 0 10px}.hotspot-item .row{display:flex;gap:8px}.hotspot-item button{flex:1;border-radius:20px;padding:6px;font-size:12px;font-weight:500;border:none;cursor:pointer}.hotspot-item .jump{background:#1f2937;color:#fff}.hotspot-item .open{background:#22c55e;color:#fff}.hotspot-logo{width:36px;height:36px;animation:pulse 1.5s infinite}@keyframes pulse{0%{transform:scale(1)}50%{transform:scale(1.15)}to{transform:scale(1)}}.modal{position:fixed;inset:0;background:#000000b3;display:none;z-index:2000}.modal.open{display:flex;justify-content:center;align-items:center}.modal-content{background:#132a3a;color:#fff;width:90%;max-width:400px;max-height:80vh;overflow-y:auto;padding:16px;border-radius:12px}.modal-content img{width:100%;border-radius:6px;margin:8px 0}.modal-content button{margin-top:10px;width:100%;padding:8px;border-radius:6px;border:none;background:#22c55e;color:#fff}@media(min-width:769px){.hotspot-panel{top:56px;right:0;width:300px;height:calc(100vh - 56px)}}@media(max-width:480px){.hotspot-panel{position:fixed;inset:auto 0 0;width:100%;height:auto;min-height:70px;max-height:45vh;padding:10px;overflow-y:auto;background:#0b1b28f5;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border-top-left-radius:16px;border-top-right-radius:16px;box-shadow:0 -4px 20px #0006}.drag-handle{width:40px;height:4px;background:#ffffff4d;border-radius:10px;margin:0 auto 8px}.hotspot-item{padding:10px;margin-bottom:8px}.hotspot-item h4{font-size:13px}.hotspot-item p{font-size:11px}.hotspot-item button{font-size:11px;padding:5px}}.admin-home{min-height:calc(100vh - 56px);padding:32px 16px;background:linear-gradient(180deg,#0f2535,#081821);color:#fff}.admin-title{text-align:center;font-size:28px;margin-bottom:8px}.admin-subtitle{text-align:center;opacity:.8;margin-bottom:32px}.admin-cards{display:grid;grid-template-columns:repeat(auto-fit,minmax(260px,1fr));gap:24px;max-width:900px;margin:auto}.admin-card{background:#122f44;border-radius:14px;padding:24px;cursor:pointer;transition:all .25s ease;display:flex;flex-direction:column;align-items:center;text-align:center}.admin-card:hover{transform:translateY(-6px);box-shadow:0 12px 28px #00000059;background:#163b55}.card-icon{font-size:48px;margin-bottom:12px}.admin-card h3{margin-bottom:8px}.admin-card p{font-size:14px;opacity:.85;margin-bottom:20px}.admin-card button{padding:10px 18px;border-radius:20px;border:none;background:#1fa36b;color:#fff;font-weight:600;cursor:pointer}.admin-card button:hover{background:#27c17e}@media(max-width:600px){.admin-title{font-size:22px}}.video-admin-container{max-width:720px;margin:auto;padding:16px;display:flex;flex-direction:column;gap:12px}.video-admin-container h2{text-align:center}.video-admin-container input,.video-admin-container button{padding:10px;font-size:14px}.preview-video{width:100%;max-height:300px;border-radius:8px}.video-360-preview{position:relative;width:100%;height:320px;background:#000;border-radius:10px;overflow:hidden}.video-controls{position:absolute;bottom:8px;left:0;right:0;display:flex;align-items:center;gap:10px;padding:6px 10px;background:#000000a6;color:#fff}.video-controls button{background:none;border:none;color:#fff;font-size:16px;cursor:pointer}.video-controls input[type=range]{flex:1}.play-btn{position:absolute;bottom:12px;left:50%;transform:translate(-50%);padding:10px 20px;background:#000000b3;color:#fff;border:none;border-radius:20px;cursor:pointer;font-size:14px}.play-btn:hover{background:#000000d9}.progress-wrapper{position:relative;height:10px;background:#ddd;border-radius:6px;overflow:hidden}.progress-bar{height:100%;background:#106c36;transition:width .3s ease}.progress-wrapper span{font-size:12px;margin-top:4px;display:block;text-align:right}@media(max-width:600px){.video-admin-container{padding:10px}.preview-video{max-height:220px}.video-360-preview{height:220px}}.watch-360-container{width:100%;height:calc(100vh - 56px);background:#000}.viewer-wrapper{position:relative;width:100%;height:100%}.controls{position:absolute;bottom:10px;left:0;right:0;display:flex;align-items:center;gap:10px;padding:8px 12px;background:#000000a6;color:#fff}.controls button{background:none;border:none;color:#fff;font-size:18px;cursor:pointer}.controls input[type=range]{flex:1}@media(max-width:600px){.controls span{font-size:12px}}.settings-container{display:flex;justify-content:center;align-items:center;height:80vh;color:#000}.settings-card{background:#fff;padding:30px;border-radius:12px;width:350px;box-shadow:0 4px 20px #0000001a}.settings-card h2{text-align:center;margin-bottom:20px}.settings-card form{display:flex;flex-direction:column}.settings-card label{margin-top:10px;font-size:14px;font-weight:500;color:#0b2027}.settings-card input,.settings-card select{padding:10px;margin-top:5px;border-radius:6px;border:1px solid #ccc}.settings-card button{margin-top:20px;padding:10px;background:#0b6b3a;color:#fff;border:none;border-radius:6px;cursor:pointer}.manage-container{padding:20px;text-align:center}.user-table{width:80%;margin:auto;border-collapse:collapse}.user-table th,.user-table td{border:1px solid #ddd;padding:10px}.active-btn{background:#0a6847;color:#fff;padding:6px 10px;border:none;cursor:pointer}.inactive-btn{background:#ff4d4d;color:#fff;padding:6px 10px;border:none;cursor:pointer}.tabs{margin:20px 0}.tabs button{margin:0 10px;padding:8px 16px;cursor:pointer;border:1px solid #ccc;background:#0a6847;border-radius:6px;transition:.2s}.active-tab{background:wheat;color:#fff;transform:scale(1.15);border-color:#0b6b3a}:root{--green: #106c36;--accent: #2ea44f;--bg: #0f2535}*{box-sizing:border-box}html,body{height:100%}body{margin:0;font-family:system-ui,-apple-system,Segoe UI,Roboto,Inter,Arial;background:var(--bg);color:#fff;overflow-y:auto}header{display:flex;flex-wrap:wrap;gap:10px;align-items:center;padding:10px 16px;background:green}.btn,label.btn{background:var(--accent);color:#fff;border:none;border-radius:8px;padding:8px 12px;font-weight:700;cursor:pointer}select,input[type=checkbox]{cursor:pointer}select{padding:8px 10px;border-radius:8px;border:none}#layout{display:grid;grid-template-columns:1fr 380px;min-height:calc(100vh - 56px)}#layout.hide-side{grid-template-columns:1fr}#layout.hide-side #side{display:none}#viewer{width:100%;height:100%;background:#0b1b28;position:relative}#map{position:absolute;bottom:10px;right:10px;width:280px;height:200px;border-radius:12px;overflow:hidden;z-index:1000;border:2px solid #fff}#side{display:grid;grid-template-rows:auto 1fr auto;border-left:1px solid rgba(255,255,255,.1);background:#0b1b28;overflow:hidden}#panel{padding:12px;background:#0d2a19;border-bottom:1px solid rgba(255,255,255,.1)}#form{display:grid;gap:8px}#form input[type=text],#form textarea{width:100%;padding:8px 10px;border-radius:8px;border:none}#hotspotList{padding:10px;overflow:auto}.hotspot-item{padding:8px;border:1px solid rgba(255,255,255,.15);border-radius:8px;margin-bottom:8px;background:#0c1f14}.row{display:flex;gap:8px;align-items:center;flex-wrap:wrap}.pill{padding:6px 10px;background:#ffffff1a;border-radius:999px;font-size:12px}#photo-input,#tour-input,#hsPhotos,#hsAudio{display:none}.modal{position:fixed;inset:0;display:none;place-items:center;background:#000000a6;z-index:9999}.modal.open{display:grid}.card{width:min(880px,92vw);max-height:86vh;overflow:auto;background:#0f2535;border:1px solid rgba(255,255,255,.15);border-radius:14px;padding:14px}.gallery{display:grid;grid-template-columns:repeat(auto-fill,minmax(140px,1fr));gap:10px}.gallery img{width:100%;height:100px;object-fit:cover;border-radius:10px;border:1px solid rgba(255,255,255,.15)}.modal h3{margin:8px 0}.small{font-size:12px;opacity:.85}audio{width:100%;margin-top:8px;outline:none}@keyframes float{0%,to{transform:translateY(0)}50%{transform:translateY(-4px)}}.st-hotspot-wrap{display:inline-flex;align-items:center;justify-content:center;pointer-events:auto}.st-hotspot{width:48px;height:48px;border-radius:50%;box-shadow:0 0 10px #ffffff73;animation:float 3s ease-in-out infinite;transition:transform .18s ease,box-shadow .18s ease,filter .18s ease;-webkit-user-select:none;user-select:none;-webkit-user-drag:none}.st-hotspot-wrap:hover .st-hotspot{transform:scale(1.08);box-shadow:0 0 14px #00ff90d9;filter:saturate(1.05)}.st-hotspot-wrap:active .st-hotspot{transform:scale(.97);box-shadow:0 0 12px #00ff90b3}.env-card{margin:12px;position:relative;width:auto;-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px);background:#0000008c;border:1px solid rgba(255,255,255,.18);border-radius:14px;padding:10px 12px}.env-card__header{display:flex;justify-content:space-between;font-weight:600;font-size:13px;opacity:.9;margin-bottom:6px}.env-card__timestamp{font-weight:500;font-size:11px;opacity:.8}.env-card__row{display:grid;grid-template-columns:1fr auto auto;gap:6px;align-items:baseline;font-size:13px;padding:4px 0;border-top:1px dashed rgba(255,255,255,.15)}.env-card__row:first-of-type{border-top:none}.env-unit{opacity:.8;font-size:11px}.env-card__aqi strong{font-size:16px}.env-chip{margin-left:6px;padding:2px 6px;border-radius:999px;font-size:11px;font-weight:700;background:#ffffff24;border:1px solid rgba(255,255,255,.24)}.env-chip.good{background:#2e7d32;border-color:#2e7d32}.env-chip.moderate{background:#f9a825;border-color:#f9a825;color:#111}.env-chip.usg{background:#ef6c00;border-color:#ef6c00}.env-chip.unhealthy{background:#c62828;border-color:#c62828}.env-chip.vu{background:#6a1b9a;border-color:#6a1b9a}.env-chip.hazard{background:#4e342e;border-color:#4e342e}@media(max-width:1024px){#layout{grid-template-columns:1fr 320px}}@media(max-width:768px){#layout{grid-template-columns:1fr}#side{max-height:none;border-left:none;border-top:1px solid rgba(255,255,255,.1)}#viewer{min-height:300px}#map{width:220px;height:160px}}
