@font-face {
    font-family: 'Nunito';
    src: url('./assets/fonts/Nunito-Black.ttf') format('truetype');
    font-weight: 900;
    font-display: swap;
}

html, body {
    cursor: url('./assets/images/cursor.png') 16 16, auto;
    /* Yandex Games moderation: long-tap не должен открывать контекстное меню,
       выделять элементы или триггерить системный скролл/swipe-to-refresh. */
    -webkit-touch-callout: none;
    -webkit-user-select: none;
    -ms-user-select: none;
    user-select: none;
    -webkit-tap-highlight-color: transparent;
    touch-action: none;
    overscroll-behavior: none;
}

* {
    -webkit-touch-callout: none;
    -webkit-user-select: none;
    user-select: none;
}

/* Tiled фон игры — покрывает всю видимую область, canvas поверх прозрачный.
   background-color подобран под средний тон bg.jpeg — fallback на случай,
   если картинка не догрузилась (CSS background не имеет onerror/ретрая). */
body {
    background-color: #2d1810;
    background-image: url('./assets/images/bg.jpeg');
    background-repeat: repeat;
}

#game-canvas {
    cursor: url('./assets/images/cursor.png') 16 16, auto;
}

canvas[style*="pointer"] {
    cursor: url('./assets/images/cursor_pointer.png') 16 16, pointer !important;
}

/* Прелоадер во время bootstrap. Снимается из main.ts после loop.startLoop().
   Если bootstrap упадёт — спиннер останется крутиться: визуальный сигнал
   игроку что что-то не так (вместо «просто чёрный фон»). */
#loading-spinner {
    position: fixed;
    inset: 0;
    display: flex;
    align-items: center;
    justify-content: center;
    pointer-events: none;
    z-index: 9999;
}
#loading-spinner .spinner {
    width: 24px;
    height: 24px;
    border-radius: 50%;
    display: block;
    position: relative;
    color: #FFF;
    box-sizing: border-box;
    animation: loading-spin 2s linear infinite;
}
@keyframes loading-spin {
    0%   { box-shadow:  28px 0 0 -4px,  76px 0 0 -4px,  -28px 0 0 -4px,  -76px 0 0 -4px; }
    25%  { box-shadow:  28px 0 0 -4px,  76px 0 0 -4px,  -28px 0 0 -4px,  -76px 0 0  4px; }
    50%  { box-shadow:  28px 0 0 -4px,  76px 0 0 -4px,  -28px 0 0  4px,  -76px 0 0 -4px; }
    75%  { box-shadow:  28px 0 0  4px,  76px 0 0 -4px,  -28px 0 0 -4px,  -76px 0 0 -4px; }
    100% { box-shadow:  28px 0 0 -4px,  76px 0 0  4px,  -28px 0 0 -4px,  -76px 0 0 -4px; }
}
