:root {
  color-scheme: light dark;
  --fade: 1s; /* перезаписывается из script.js (FADE_MS) */
}

html,
body {
  margin: 0;
  height: 100%;
  background: #fff; /* в окне фон белый */
  overflow: hidden;
}

/* В полном экране фон чёрный — чтобы фото не слепило белыми полями на ТВ */
body.is-fullscreen,
html:fullscreen {
  background: #000;
}

#player {
  position: fixed;
  inset: 0;
  cursor: pointer; /* фото кликабельно: клик -> полный экран / следующая */
}

/* Два слоя поверх фона: пока один виден, второй готовит следующее фото */
#player .slide {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  object-fit: contain; /* фото целиком, ничего не обрезаем */
  opacity: 0;
  transition: opacity var(--fade) ease-in-out;
}

#player .slide.is-active {
  opacity: 1;
}

/* Сообщение, когда в папке media/ ещё нет фотографий */
#message {
  position: fixed;
  inset: 0;
  margin: 0;
  display: flex;
  align-items: center;
  justify-content: center;
  color: #555;
  font: 16px/1.4 system-ui, -apple-system, sans-serif;
  text-align: center;
}

#message[hidden] {
  display: none;
}
