:root{font-family:Inter,ui-sans-serif,system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;color:#f5f2ea;background:#111;font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;--panel: rgba(16, 16, 15, .74);--panel-soft: rgba(20, 21, 20, .58);--line: rgba(255, 255, 255, .16);--muted: rgba(245, 242, 234, .68);--accent: #d6ff72;--warm: #ffd99f}*{box-sizing:border-box}body{margin:0;min-width:320px;min-height:100vh;overflow:hidden}button,a{font:inherit}.gallery-shell{position:relative;width:100vw;height:100vh;overflow:hidden;background:#0d0d0c}.gallery-canvas{display:block;width:100%;height:100%;touch-action:none}.panel{position:absolute;z-index:3;border:1px solid var(--line);border-radius:8px;background:linear-gradient(180deg,var(--panel),var(--panel-soft));box-shadow:0 24px 90px #00000057;-webkit-backdrop-filter:blur(18px) saturate(135%);backdrop-filter:blur(18px) saturate(135%)}.top-left{top:14px;left:14px;width:min(310px,calc(100vw - 28px));padding:14px}.brand-row{display:flex;align-items:center;gap:12px}.brand-row strong{display:block;font-size:18px;line-height:1.1}.brand-row small,.metric-row,.control-dock small{color:var(--muted)}.brand-mark{display:grid;width:38px;height:38px;place-items:center;border-radius:8px;background:#f4efe5;color:#111}.metric-row{display:flex;justify-content:space-between;gap:10px;margin-top:14px;padding-top:12px;border-top:1px solid var(--line);font-size:13px}.frame-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:8px;margin-top:12px}.frame-grid span{min-height:28px;border:1px solid rgba(255,255,255,.14);border-radius:6px;padding:6px 8px;color:#f5f2ea;font-size:12px;white-space:nowrap}.top-center{top:18px;left:50%;width:min(430px,calc(100vw - 360px));min-width:280px;padding:16px 22px;transform:translate(-50%);text-align:center}.exhibition-title small{color:var(--warm);font-size:11px;font-weight:800;letter-spacing:.18em}.exhibition-title h1{margin:6px 0 4px;font-size:25px;line-height:1.1;letter-spacing:0}.exhibition-title p{margin:0;color:var(--muted);font-size:13px}.top-right{top:14px;right:14px;width:280px;padding:14px}.panel-title{display:flex;align-items:center;gap:8px;margin-bottom:12px;font-weight:700}.minimap{position:relative;height:175px;overflow:hidden;border:1px solid rgba(255,255,255,.14);border-radius:6px;background:linear-gradient(rgba(255,255,255,.04) 1px,transparent 1px),linear-gradient(90deg,rgba(255,255,255,.04) 1px,transparent 1px),#ffffff0a;background-size:24px 24px}.map-wall{position:absolute;background:#fff3}.wall-a{left:12%;top:18%;width:76%;height:6px}.wall-b{left:28%;top:48%;width:44%;height:6px}.wall-c{left:49%;top:22%;width:6px;height:58%}.visitor-dot{position:absolute;width:0;height:0;border-right:8px solid transparent;border-bottom:18px solid #69a7ff;border-left:8px solid transparent;filter:drop-shadow(0 0 10px rgba(105,167,255,.9))}.art-dot{position:absolute;width:6px;height:6px;border-radius:999px;background:#ffd99f9e}.art-dot.active{width:10px;height:10px;background:var(--accent);box-shadow:0 0 16px #d6ff72db}.right-info{right:14px;top:240px;width:292px;max-height:calc(100vh - 280px);padding:16px;overflow:auto}.selected-image{display:block;width:100%;aspect-ratio:4 / 3;object-fit:cover;border-radius:6px;background:#222}.right-info h2{margin:14px 0 6px;font-size:19px;line-height:1.2}.artist-line,.frame-type,.description{margin:0;color:var(--muted);line-height:1.55}.frame-type{margin-top:8px;color:var(--warm);font-size:13px;font-weight:700}.description{margin-top:12px;font-size:13px}.database-link{display:flex;align-items:center;justify-content:center;gap:9px;min-height:46px;margin-top:18px;border:1px solid rgba(255,255,255,.32);border-radius:6px;color:#fff;text-decoration:none}.bottom-left{bottom:16px;left:14px;width:340px;max-width:calc(100vw - 28px);padding:14px}.lighting-row{display:flex;gap:10px;padding:9px 0;border-top:1px solid rgba(255,255,255,.1)}.lighting-row:first-of-type{border-top:0}.lighting-row svg{flex:0 0 auto;margin-top:4px;color:var(--accent)}.lighting-row strong{display:block;font-size:13px}.lighting-row p{margin:2px 0 0;color:var(--muted);font-size:12px;line-height:1.45}.bottom-center{bottom:18px;left:50%;display:grid;grid-template-columns:repeat(3,98px);min-height:74px;transform:translate(-50%)}.control-dock div{display:grid;place-items:center;gap:3px;padding:10px;border-left:1px solid rgba(255,255,255,.12)}.control-dock div:first-child{border-left:0}.control-dock span{font-size:13px;font-weight:800}.loading-panel,.error-panel{position:absolute;z-index:5;top:50%;left:50%;display:flex;align-items:center;gap:10px;min-height:54px;padding:0 18px;border-radius:8px;background:#0e0e0ed6;transform:translate(-50%,-50%);-webkit-backdrop-filter:blur(14px);backdrop-filter:blur(14px)}.error-panel{color:#ffd3cc}.spin{animation:spin .9s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}@media(max-width:920px){.top-center{top:104px;width:min(430px,calc(100vw - 28px))}.top-right{display:none}.right-info{top:auto;right:12px;bottom:102px;width:min(300px,calc(100vw - 24px));max-height:36vh}.bottom-left{display:none}.bottom-center{grid-template-columns:repeat(3,1fr);width:min(360px,calc(100vw - 24px))}}@media(max-width:560px){.top-left{padding:12px}.metric-row,.frame-grid{display:none}.top-center{top:78px;padding:12px 14px}.exhibition-title h1{font-size:20px}.right-info{left:12px;right:12px;width:auto;display:grid;grid-template-columns:118px minmax(0,1fr);column-gap:12px;max-height:32vh;padding:12px}.right-info .panel-title,.right-info .database-link{grid-column:1 / -1}.selected-image{aspect-ratio:1;align-self:start}.right-info h2{margin-top:0;font-size:15px}.artist-line,.frame-type,.description{font-size:11px;line-height:1.35}.description{display:none}.database-link{min-height:38px;margin-top:10px}}
