
:root{--ink:#1b130d;--paper:#f0dfbd;--gold:#d2b06f;--line:rgba(237,205,142,.3);--panel:rgba(19,13,8,.82)}
*{box-sizing:border-box}html,body{margin:0;height:100%;overflow:hidden;background:#16100b;color:#f7ead0;font-family:Georgia,'Times New Roman',serif}body:before{content:"";position:fixed;inset:0;pointer-events:none;background:radial-gradient(circle at 50% 35%,rgba(255,231,173,.06),transparent 42%),linear-gradient(90deg,rgba(255,238,188,.025) 1px,transparent 1px),linear-gradient(rgba(255,238,188,.02) 1px,transparent 1px);background-size:auto,36px 36px,36px 36px;z-index:5}.app{position:fixed;inset:0}.map-wrap{position:absolute;inset:0}canvas{display:block;width:100%;height:100%;cursor:grab;touch-action:none}canvas:active{cursor:grabbing}.topbar{position:fixed;left:16px;right:16px;top:14px;z-index:20;display:flex;align-items:center;justify-content:space-between;gap:12px;pointer-events:none}.brand,.toolbar,.side,.modal,.toast,.loader{pointer-events:auto}.brand{border:1px solid var(--line);background:linear-gradient(180deg,rgba(36,26,16,.90),rgba(16,11,7,.86));border-radius:18px;padding:12px 16px;box-shadow:0 12px 40px rgba(0,0,0,.34)}.brand h1{font-size:24px;line-height:1;margin:0}.brand p{font:12px Arial,sans-serif;letter-spacing:.12em;text-transform:uppercase;margin:5px 0 0;color:#d5bd89}.toolbar{display:flex;gap:8px;flex-wrap:wrap;justify-content:flex-end}.btn{min-height:38px;border:1px solid rgba(237,205,142,.35);background:rgba(255,240,201,.10);color:#f7ead0;border-radius:999px;padding:9px 13px;font:700 13px Arial,sans-serif;cursor:pointer}.btn:hover{background:rgba(255,240,201,.18)}.btn.primary{background:#f1d48d;color:#1b130d}.side{position:fixed;right:16px;top:92px;bottom:16px;z-index:18;width:360px;max-width:calc(100vw - 32px);border:1px solid var(--line);border-radius:24px;background:var(--panel);box-shadow:0 20px 80px rgba(0,0,0,.45);backdrop-filter:blur(12px);display:flex;flex-direction:column;overflow:hidden}.side-head{padding:18px;border-bottom:1px solid rgba(237,205,142,.18)}.eyebrow{font:700 11px Arial,sans-serif;text-transform:uppercase;letter-spacing:.16em;color:#d2b06f;margin:0 0 8px}.side h2{font-size:30px;line-height:1;margin:0}.side p{color:#eadab7}.side-body{padding:16px 18px;overflow:auto}.region-list{display:grid;gap:8px}.region-item{width:100%;text-align:left;border:1px solid rgba(237,205,142,.18);background:rgba(255,245,215,.06);color:#f7ead0;border-radius:16px;padding:12px;cursor:pointer}.region-item:hover,.region-item.active{background:rgba(241,212,141,.16)}.region-item strong{display:block;font-size:16px}.region-item span{display:block;font:12px Arial,sans-serif;color:#d7c398;margin-top:3px}.hero-card{border:1px solid rgba(237,205,142,.18);border-radius:15px;padding:12px;margin:8px 0;background:rgba(255,245,215,.06)}.hero-card strong{display:block}.hero-card span{font:13px Arial,sans-serif;color:#d7c398}.modal{position:fixed;inset:0;z-index:50;background:rgba(7,5,3,.75);display:none;align-items:center;justify-content:center;padding:24px}.modal.open{display:flex}.modal-card{width:min(760px,100%);max-height:86vh;overflow:auto;border:1px solid rgba(237,205,142,.35);border-radius:28px;background:#22170e;color:#f7ead0;box-shadow:0 30px 100px rgba(0,0,0,.5);padding:28px}.modal-card h2{font-size:42px;line-height:1;margin:0 0 12px}.modal-card p{font-size:18px;color:#eadab7}.modal-actions{display:flex;gap:10px;flex-wrap:wrap;margin-top:20px}.toast{position:fixed;left:50%;bottom:22px;z-index:40;transform:translateX(-50%) translateY(20px);opacity:0;transition:.25s ease;border:1px solid rgba(237,205,142,.35);background:#f1d48d;color:#1b130d;border-radius:999px;padding:12px 18px;font:700 14px Arial,sans-serif;box-shadow:0 16px 50px rgba(0,0,0,.35)}.toast.show{opacity:1;transform:translateX(-50%) translateY(0)}.loader{position:fixed;inset:0;z-index:80;display:grid;place-items:center;background:#16100b}.loader-box{width:min(460px,calc(100vw - 40px));border:1px solid var(--line);border-radius:26px;background:var(--panel);padding:28px;text-align:center;box-shadow:0 20px 80px rgba(0,0,0,.5)}.progress{height:10px;background:rgba(255,255,255,.10);border-radius:999px;overflow:hidden;margin-top:18px}.progress i{display:block;height:100%;width:0;background:#f1d48d}.zoom-badge{position:fixed;left:16px;bottom:16px;z-index:18;border:1px solid var(--line);border-radius:18px;background:var(--panel);padding:11px 14px;font:13px Arial,sans-serif;color:#eadab7}.hotspot-note{position:fixed;left:50%;top:90px;transform:translateX(-50%);z-index:22;display:none;border:1px solid rgba(237,205,142,.35);background:rgba(19,13,8,.82);border-radius:999px;padding:10px 16px;color:#f7ead0;font:700 13px Arial,sans-serif}.hotspot-note.show{display:block}@media(max-width:760px){.topbar{align-items:flex-start}.brand h1{font-size:18px}.brand p{display:none}.side{top:auto;height:46vh;left:10px;right:10px;bottom:10px;width:auto}.toolbar{max-width:48vw}.btn{font-size:12px;padding:8px 10px}.side h2{font-size:25px}.modal-card h2{font-size:32px}}

.loader{transition:opacity .25s ease}.loader.is-hidden{opacity:0;pointer-events:none}.loader-box h2{margin:.15em 0}.loader-sub{font:13px Arial,sans-serif;color:#d6c194;margin:8px 0 0}.loading-chip{position:fixed;left:16px;bottom:64px;z-index:21;border:1px solid rgba(237,205,142,.35);background:rgba(19,13,8,.84);border-radius:999px;padding:10px 14px;color:#f7ead0;font:700 13px Arial,sans-serif;display:none;box-shadow:0 10px 35px rgba(0,0,0,.3)}.loading-chip.show{display:block}.sound-on{background:#f1d48d!important;color:#1b130d!important}.sound-off{opacity:.78}.map-help{position:fixed;left:16px;bottom:112px;z-index:18;border:1px solid rgba(237,205,142,.24);background:rgba(19,13,8,.70);border-radius:18px;padding:10px 14px;max-width:360px;color:#eadab7;font:12px Arial,sans-serif;line-height:1.35}.map-help b{color:#f7ead0}.loader .progress small{display:block;position:absolute;left:-9999px}.progress{position:relative}.region-item.loading:after{content:'подгружается';float:right;color:#f1d48d;font:11px Arial,sans-serif;text-transform:uppercase;letter-spacing:.08em}.region-item.cached:after{content:'готово';float:right;color:#9fcf90;font:11px Arial,sans-serif;text-transform:uppercase;letter-spacing:.08em}@media(max-width:760px){.map-help{display:none}.loading-chip{bottom:58vh;left:10px}.zoom-badge{bottom:49vh;left:10px}}


/* v8 stable audio UI + movable side panel */
.btn.main-site{background:#f1d48d;color:#1b130d;text-decoration:none;display:inline-flex;align-items:center;justify-content:center}.btn.small{min-height:32px;padding:7px 11px;font-size:12px}.audio-panel{position:fixed;right:18px;top:82px;z-index:31;width:310px;max-width:calc(100vw - 36px);display:none;border:1px solid rgba(237,205,142,.35);border-radius:20px;background:rgba(19,13,8,.94);box-shadow:0 20px 70px rgba(0,0,0,.46);backdrop-filter:blur(14px);padding:14px;color:#f7ead0;font:13px Arial,sans-serif}.audio-panel.open{display:block}.audio-panel-head{display:flex;align-items:center;justify-content:space-between;gap:12px;margin-bottom:10px}.audio-panel strong{font-family:Georgia,'Times New Roman',serif;font-size:18px}.audio-panel label{display:block;margin:10px 0;color:#eadab7}.audio-panel label span{float:right;color:#f1d48d;font-weight:700}.audio-panel input[type=range]{width:100%;accent-color:#f1d48d;margin-top:8px}.audio-panel p{font-size:12px;line-height:1.35;color:#d6c194;margin:10px 0 0}.panel-mini{border:1px solid rgba(237,205,142,.35);background:rgba(255,240,201,.1);color:#f7ead0;border-radius:999px;padding:5px 9px;font:700 12px Arial,sans-serif;cursor:pointer}.panel-mini:hover{background:rgba(255,240,201,.18)}
.side{transition:box-shadow .2s ease, opacity .2s ease}.side.dragged{right:auto;bottom:auto}.side-dragbar{display:flex;align-items:center;justify-content:space-between;gap:10px;min-height:42px;padding:10px 12px;border-bottom:1px solid rgba(237,205,142,.18);background:rgba(255,240,201,.07);cursor:move;user-select:none;font:700 13px Arial,sans-serif;letter-spacing:.08em;text-transform:uppercase;color:#d2b06f}.side.collapsed{bottom:auto;height:auto;min-height:0;width:260px;overflow:visible}.side.collapsed .side-head,.side.collapsed .side-body{display:none}.side.collapsed .side-dragbar{border-bottom:0;border-radius:23px}.side.is-dragging{box-shadow:0 28px 100px rgba(0,0,0,.58),0 0 0 2px rgba(241,212,141,.22)}.copyright-footer{position:fixed;left:50%;bottom:16px;z-index:19;transform:translateX(-50%);border:1px solid rgba(237,205,142,.24);background:rgba(19,13,8,.72);border-radius:999px;padding:8px 13px;color:#eadab7;font:12px Arial,sans-serif;white-space:nowrap;backdrop-filter:blur(8px)}.copyright-footer a{color:#f7ead0;text-decoration:none}.copyright-footer a:hover{text-decoration:underline}.music-on{background:#f1d48d!important;color:#1b130d!important}.audio-ready{box-shadow:0 0 0 2px rgba(159,207,144,.28) inset}.audio-warn{animation:audioPulse 1.8s ease-in-out infinite}@keyframes audioPulse{0%,100%{box-shadow:0 0 0 0 rgba(241,212,141,.25)}50%{box-shadow:0 0 0 6px rgba(241,212,141,.08)}}
@media(max-width:760px){.audio-panel{left:10px;right:10px;top:96px;width:auto}.side.dragged{max-width:calc(100vw - 20px)}.copyright-footer{bottom:8px;font-size:11px}.zoom-badge{bottom:49vh}.toast{bottom:52px}.toolbar{max-width:62vw;overflow:auto}.btn.main-site{width:100%}.topbar{right:10px;left:10px}.side.collapsed{width:220px}}
