/* Стили для прокрутки картинок */
.container {
  width: 100%;
  height: 100vh;
  position: relative;
  overflow: hidden;
}

#loading-screen {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  background: rgba(0, 0, 0, 0.65);
  display: flex;
  flex-direction: column;
  justify-content: center;
  align-items: center;
  z-index: 100;
  color: white;
  font-family: 'Manrope', sans-serif;
}

/* Старый fullscreen-loader полностью отключен (используем только нижний прогрессбар). */
#loading-screen {
  display: none !important;
  background: transparent !important;
  pointer-events: none !important;
}

#loading-screen.hidden {
  display: none;
}

.loader {
  width: 50px;
  height: 50px;
  border: 4px solid rgba(255, 255, 255, 0.3);
  border-top: 4px solid white;
  border-radius: 50%;
  animation: spin 1s linear infinite;
  margin-bottom: 20px;
}

@keyframes spin {
  0% { transform: rotate(0deg); }
  100% { transform: rotate(360deg); }
}

#loading-screen p {
  font-size: var(--ui-zoom-btn-font);
  margin: 0;
}

#house-viewer {
  width: 100%;
  height: 100vh;
  position: relative;
  overflow: hidden;
  cursor: grab;
  background: linear-gradient(120deg, #1e3f63 0%, #2d6ea3 45%, #35b8fc 100%);
  background-size: 220% 220%;
  animation: houseViewerBgFlow 7s ease-in-out infinite;
}

#house-viewer:active {
  cursor: grabbing;
}

#house-container {
  width: 100%;
  height: 100%;
  position: relative;
  filter: brightness(0.9);
}

/* Затемнение до полной загрузки preview кадров в legacy-режиме */
.house-viewer-preview-overlay {
  position: absolute;
  inset: 0;
  background: rgba(0, 0, 0, 0.4);
  z-index: 11;
  pointer-events: auto;
}

/* Подсказка: идёт фоновая подгрузка midres/fullres */
.house-viewer-hq-hint {
  position: absolute;
  left: 10px;
  bottom: 10px;
  right: auto;
  max-width: min(92vw, 300px);
  padding: 6px 10px;
  font-size: 11px;
  line-height: 1.35;
  color: rgba(255, 255, 255, 0.9);
  background: rgba(0, 0, 0, 0.5);
  border-radius: 6px;
  z-index: 8;
  pointer-events: none;
  font-family: 'Manrope', sans-serif;
  text-align: left;
  box-shadow: 0 1px 4px rgba(0, 0, 0, 0.35);
}

/* Нижний прогрессбар общей загрузки кадров секвенции */
.house-viewer-global-progress {
  position: absolute;
  left: 0;
  right: 0;
  bottom: 0;
  height: 34px;
  background: rgba(255, 255, 255, 0.14);
  z-index: 12;
  pointer-events: none;
}

.house-viewer-global-progress__bar {
  width: 0%;
  height: 100%;
  background: linear-gradient(90deg, #2f80ed 0%, #56ccf2 100%);
  box-shadow: 0 0 12px rgba(86, 204, 242, 0.6);
  transition: width 220ms ease;
  position: relative;
  overflow: visible;
  min-width: 0;
}

.house-viewer-global-progress__bar::after {
  content: '';
  position: absolute;
  inset: 0;
  background: linear-gradient(
    110deg,
    rgba(255, 255, 255, 0) 0%,
    rgba(255, 255, 255, 0.28) 45%,
    rgba(255, 255, 255, 0) 85%
  );
  transform: translateX(-120%);
  animation: houseProgressShimmer 1.5s linear infinite;
  pointer-events: none;
}

.house-viewer-global-progress__label {
  position: absolute;
  right: 8px;
  top: 50%;
  transform: translateY(-50%);
  font-size: 14px;
  line-height: 1;
  color: #fff;
  font-weight: 800;
  letter-spacing: 0.3px;
  text-shadow: 0 1px 2px rgba(0, 0, 0, 0.5);
  font-family: 'Manrope', sans-serif;
  background: rgba(21, 95, 189, 0.92);
  border: 1px solid rgba(255, 255, 255, 0.35);
  border-radius: 999px;
  padding: 4px 8px;
  white-space: nowrap;
  animation: houseProgressPulse 1.4s ease-in-out infinite;
}

@keyframes houseProgressShimmer {
  0% { transform: translateX(-120%); }
  100% { transform: translateX(130%); }
}

@keyframes houseProgressPulse {
  0%, 100% { box-shadow: 0 0 0 rgba(86, 204, 242, 0); }
  50% { box-shadow: 0 0 10px rgba(86, 204, 242, 0.55); }
}

/* Старый fullscreen-loader скрываем, используем нижний прогрессбар. */
#loading-screen .loader,
#loading-screen p {
  display: none !important;
}

/* Контейнер виджетов поверх canvas (кнопки прогулок, подписи домов) */
.house-viewer-widgets {
  position: absolute;
  left: 0;
  top: 0;
  width: 100%;
  height: 100%;
  pointer-events: none;
  z-index: 5;
}
/* Позиционирование пинов; внешний вид — в panorama-pins.css */
.house-viewer-widgets .house-viewer-widget {
  position: absolute;
  pointer-events: auto;
  transform: translate(-50%, -50%);
  transition: visibility 0s, opacity 0s;
}
/* Круг и иконка — без своего перехода, чтобы исчезали/появлялись вместе с контейнером */
.house-viewer-widgets .house-viewer-widget .btn.circle,
.house-viewer-widgets .house-viewer-widget .btn.circle .icon,
.house-viewer-widgets .house-viewer-widget .btn.circle .icon i {
  transition: none;
}

/* Canvas для плавной смены кадров секвенции */
#house-viewer-canvas {
  display: block;
  width: 100%;
  height: 100%;
  object-fit: contain;
  user-select: none;
  -webkit-user-drag: none;
  pointer-events: none;
  /* Вынос на отдельный слой для плавной отрисовки */
  transform: translateZ(0);
  /* Резкость только для картинки; пины (#house-viewer-widgets) не затрагиваются */
  filter: url(#sharpen);
}

/* Кнопка автоповорота скрыта при круговой панораме */
body.show-house-viewer #auto-rotate {
  display: none !important;
}

.controls {
  position: fixed;
  bottom: 50%;
  right: 20px;
  transform: translateX(-50%);
  z-index: 1000;
  display: flex;
  gap: 10px;
  flex-wrap: wrap;
  justify-content: center;
  pointer-events: none;
  touch-action: manipulation;
}

.house-viewer-zoom-controls {
  pointer-events: auto;
  position: fixed;
  right: calc(var(--ui-edge) / 2);
  top: 50%;
  transform: translateY(-50%);
  z-index: 1000;
  display: flex;
  flex-direction: column;
  align-items: stretch;
  gap: var(--ui-zoom-gap);
  touch-action: manipulation;
}

#house-viewer-zoom-out,
#house-viewer-zoom-in,
#house-viewer-zoom-reset {
  margin: 0;
  padding: 0 var(--ui-zoom-btn-pad-x);
  width: 100%;
  min-height: var(--ui-zoom-btn-min);
  min-width: var(--ui-zoom-btn-min);
  display: flex;
  align-items: center;
  justify-content: center;
  background-color: var(--window, rgba(255, 255, 255, 0.95));
  border: 2px solid var(--stroke, rgba(0, 0, 0, 0.1));
  border-radius: 50px;
  cursor: pointer;
  font-size: var(--ui-zoom-btn-font);
  font-weight: 600;
  line-height: 1;
  font-family: 'Manrope', sans-serif;
  color: var(--text, #333);
  transition: all 0.3s ease;
  position: relative;
  z-index: 1001;
  -webkit-tap-highlight-color: transparent;
  user-select: none;
  box-shadow: 0 2px 8px rgba(0, 0, 0, 0.15);
}
#house-viewer-zoom-reset {
  font-size: 13px;
  padding: 0 10px;
}
#house-viewer-zoom-out:hover,
#house-viewer-zoom-in:hover,
#house-viewer-zoom-reset:hover {
  border-color: var(--color, #007bff);
  background-color: var(--color, #007bff);
  color: var(--window, #fff);
  box-shadow: 0 2px 12px rgba(0, 0, 0, 0.2);
}

/* Кнопки этажей отключены (работали с SVG) */
#show-floor-8,
#show-all-floors {
  display: none;
}

/* Контейнер Pannellum не скрываем (display: none ломает createImageBitmap), только уводим под слой круговой панорамы */
body.show-house-viewer #panorama {
  position: relative;
  z-index: 1;
  pointer-events: none;
}

/* При переходе с круговой: контейнер Pannellum не показываем до события load (чтобы не мелькала старая панорама) */
body.pannellum-loading-from-house-viewer #panorama {
  visibility: hidden !important;
  opacity: 0 !important;
  pointer-events: none !important;
}

/* Интерфейс меню поверх просмотрщика, чтобы можно было переключать панорамы и закрыть */
body.show-house-viewer .ui {
  display: block !important;
  z-index: 100;
  pointer-events: auto;
}

/* Контейнер прокрутки картинок */
#house-viewer-wrapper {
  position: fixed;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  z-index: 10;
  background: linear-gradient(120deg, #1e3f63 0%, #2d6ea3 45%, #35b8fc 100%);
  background-size: 220% 220%;
  animation: houseViewerBgFlow 7s ease-in-out infinite;
}

@keyframes houseViewerBgFlow {
  0% { background-position: 0% 50%; }
  50% { background-position: 100% 50%; }
  100% { background-position: 0% 50%; }
}

 