/* ============================================
   DESKTOP.CSS — Адаптация под десктоп
   Подключить ПОСЛЕ common.css в base.html:
   <link rel="stylesheet" href="...css/desktop.css">
   
   ПРИНЦИП:
   body { max-width; margin: 0 auto; position: relative }
   → все position:absolute дочерние элементы с inset:0
     АВТОМАТИЧЕСКИ ограничены шириной body.
     НЕ НАДО им ставить left:50%+translateX(-50%) —
     это ломает их позиционирование и 3D-трансформы.
   
   → position:fixed элементы (tab-bar, topbar, input-area)
     НЕ привязаны к body — им нужно:
     left:0; right:0; max-width + margin:auto
     (НЕ через transform, чтобы не бить чужие transform)
   ============================================ */


/* ─────────────────────────────────────────────
   1. ОПРЕДЕЛЕНИЕ ДЕСКТОПА
   ───────────────────────────────────────────── */

@media (hover: hover) and (pointer: fine) {

    /* === КОРНЕВЫЕ ПЕРЕМЕННЫЕ ДЛЯ ДЕСКТОПА === */
    :root {
        --desktop-max-width: 480px;
        --desktop-shell-bg: #080808;
        --desktop-border-color: #1a1a1a;
        --safe-top: 0px;
        --safe-bottom: 0px;
    }


    /* === HTML / BODY === */
    html {
        background: var(--desktop-shell-bg);
        height: 100%;
    }

    body {
        max-width: var(--desktop-max-width);
        margin: 0 auto;
        min-height: 100vh;
        position: relative;
        border-left: 1px solid var(--desktop-border-color);
        border-right: 1px solid var(--desktop-border-color);
        box-shadow:
            -1px 0 40px rgba(255, 215, 0, 0.02),
             1px 0 40px rgba(255, 215, 0, 0.02);
    }

    @media (min-width: 1200px) {
        :root {
            --desktop-max-width: 540px;
        }
    }


    /* ═══════════════════════════════════════════
       FIXED ELEMENTS — не привязаны к body,
       центрируем через max-width + margin:auto
       ═══════════════════════════════════════════ */

    /* === TAB BAR === */
    .tab-bar {
        left: 0;
        right: 0;
        max-width: var(--desktop-max-width);
        margin-left: auto;
        margin-right: auto;
        border-radius: 0;
        padding-bottom: 8px;
    }

    /* === TRAINER TOPBAR === */
    .trainer-topbar {
        left: 0;
        right: 0;
        max-width: var(--desktop-max-width);
        margin-left: auto;
        margin-right: auto;
    }

    .bank-topbar {
        left: 0;
        right: 0;
        max-width: var(--desktop-max-width);
        margin-left: auto;
        margin-right: auto;
    }

    /* === FLOATING CONTROLS === */
    .floating-controls {
        right: calc(50% - var(--desktop-max-width) / 2 + 16px);
    }

    /* === TIMER FLOATING === */
    .timer-floating {
        max-width: calc(var(--desktop-max-width) - 32px);
    }

    /* === FADE OVERLAY (position:fixed) === */
    #fadeOverlay {
        left: 0;
        right: 0;
        max-width: var(--desktop-max-width);
        margin-left: auto;
        margin-right: auto;
    }

    /* === LOADERS (position:fixed) === */
    .pixel-loader {
        left: 0;
        right: 0;
        max-width: var(--desktop-max-width);
        margin-left: auto;
        margin-right: auto;
        overflow: hidden;
    }

    .pixel-loader canvas {
        position: relative;
        left: 50%;
        transform: translateX(-50%);
    }

    #loader {
        left: 0;
        right: 0;
        max-width: var(--desktop-max-width);
        margin-left: auto;
        margin-right: auto;
    }

    .page-loader {
        left: 0;
        right: 0;
        max-width: var(--desktop-max-width);
        margin-left: auto;
        margin-right: auto;
    }

    #loadingScreen {
        left: 0;
        right: 0;
        max-width: var(--desktop-max-width);
        margin-left: auto;
        margin-right: auto;
        overflow: hidden;
    }

    #loadingScreen canvas {
        position: relative;
        left: 50%;
        transform: translateX(-50%);
    }


    /* ═══════════════════════════════════════════
       ABSOLUTE ELEMENTS INSIDE BODY
       body { position:relative; max-width:480px }
       → position:absolute + inset:0 уже ограничены.
       НЕ ТРОГАЕМ left/right/transform!
       Просто убедимся что width:100% (от body).
       ═══════════════════════════════════════════ */

    .trainer-page {
        max-width: var(--desktop-max-width);
        margin: 0 auto;
    }

    #video-container {
        max-width: 100%;
        margin-left: auto;
        margin-right: auto;
    }

    #startScreen {
        max-width: var(--desktop-max-width);
        margin: 0 auto;
        position: relative;
    }


    /* === MODALS === */
    .modal-content {
        max-width: 380px;
    }

    #popup-content-wrapper {
        max-width: 440px;
    }


    /* ═══════════════════════════════════════════
       PAGE-SPECIFIC: GAME WORDS
       
       Все слои (#level-menu, #scene, #bg-scene, 
       #ui-layer, #result-screen) имеют
       position:absolute; inset:0 (или top/left:0 + w/h:100%)
       → body с max-width их уже ограничивает.
       НЕ НАДО НИЧЕГО ПЕРЕОПРЕДЕЛЯТЬ!

       Единственное что нужно — position:fixed элементы.
       ═══════════════════════════════════════════ */

    /* #global-stars-display — position:fixed, right:var(--spacing-lg)
       Нужно привязать к правому краю контейнера */
    #global-stars-display {
        right: calc(50% - var(--desktop-max-width) / 2 + var(--spacing-lg)) !important;
    }

    /* HUD кнопки справа внизу (inline styled position:fixed right:16px) */
    body > div[style*="position:fixed"][style*="right:16px"],
    body > div[style*="position:fixed"][style*="right: 16px"] {
        right: calc(50% - var(--desktop-max-width) / 2 + 16px) !important;
    }

    /* Premium block modal — position:fixed */
    #premium-block-modal {
        left: 0;
        right: 0;
        max-width: var(--desktop-max-width);
        margin-left: auto;
        margin-right: auto;
    }

    /* Fail-line: позиция управляется в game_words.html (синхронизирована с FAIL_OFFSET) */


    /* ═══════════════════════════════════════════
       PAGE-SPECIFIC: AI TUTOR
       
       Те же принципы: absolute-слои уже в body.
       Только #input-area (position:fixed) нужно центрировать.
       ═══════════════════════════════════════════ */

    /* #input-area — position:fixed, в ai_tutor имеет left:50%+transform:translateX(-50%).
       Сбрасываем transform и центрируем через margin:auto */
    #input-area {
        left: 0 !important;
        right: 0 !important;
        transform: none !important;
        width: auto !important;
        max-width: calc(var(--desktop-max-width) - 40px) !important;
        margin-left: auto !important;
        margin-right: auto !important;
    }

    /* #limit-modal — position:fixed */
    #limit-modal {
        left: 0;
        right: 0;
        max-width: var(--desktop-max-width);
        margin-left: auto;
        margin-right: auto;
    }


    /* ═══════════════════════════════════════════
       PAGE-SPECIFIC: RATING PAGE
       ═══════════════════════════════════════════ */

    #loading-spinner {
        left: 0;
        right: 0;
        max-width: var(--desktop-max-width);
        margin-left: auto;
        margin-right: auto;
    }

    .rating-gradient {
        left: 0;
        right: 0;
        max-width: var(--desktop-max-width);
        margin-left: auto;
        margin-right: auto;
    }

    /* #join-league-button — position:fixed, на mobile центрируется
       left:50%+translateX(-50%) по viewport. На десктопе сбрасываем
       transform и центрируем по полосе 480px через max-width+margin:auto. */
    #join-league-button {
        left: 0 !important;
        right: 0 !important;
        transform: none !important;
        max-width: calc(var(--desktop-max-width) - 60px);
        margin-left: auto !important;
        margin-right: auto !important;
    }


    /* ═══════════════════════════════════════════
       HOVER EFFECTS
       ═══════════════════════════════════════════ */

    .btn-primary:hover {
        opacity: 0.92;
        transition: opacity 0.15s;
    }

    .btn-secondary:hover {
        border-color: var(--accent-border);
        color: var(--accent);
    }

    .btn-ghost:hover {
        color: var(--text);
    }

    .card:hover {
        background: var(--bg-card-hover);
        cursor: pointer;
    }

    .chip:hover {
        border-color: var(--accent-border);
        color: var(--accent);
    }

    .tab-bar__item:hover .tab-bar__icon-img {
        opacity: 0.7;
    }

    .tab-bar__item:hover .tab-bar__label {
        color: var(--text-secondary);
    }

    #play-btn:hover,
    #repeat-btn:hover,
    #speed-select:hover {
        background: linear-gradient(to bottom, #f8f8f8 0%, #e8e8e8 100%);
    }

    .theme-button {
        width: 140px;
        transition: transform 0.15s;
    }

    .theme-button:hover {
        transform: scale(1.03);
    }

    #option1:hover, #option2:hover {
        background: var(--bg-card-hover);
        border-left-color: var(--accent2);
    }

    .session-duration-btn:hover:not(.premium-only) {
        border-color: var(--accent-border);
        background: var(--bg-card-hover);
    }

    .nav-button:hover {
        background-color: #f0f0f0;
    }

    .theme-button:active {
        transform: scale(1.03);
    }

    .premium-banner:hover {
        opacity: 0.95;
    }

    .premium-banner:hover::after {
        animation-duration: 2s;
    }

    /* Level card hover for game_words */
    .level-card:hover {
        background: var(--bg-card-hover);
    }


    /* === СКРОЛЛБАР === */
    * {
        scrollbar-width: thin;
        scrollbar-color: var(--border-light) transparent;
    }

    *::-webkit-scrollbar {
        width: 8px;
    }

    *::-webkit-scrollbar-track {
        background: transparent;
    }

    *::-webkit-scrollbar-thumb {
        background-color: var(--border-light);
        border-radius: 4px;
        border: 2px solid transparent;
        background-clip: content-box;
    }

    *::-webkit-scrollbar-thumb:hover {
        background-color: var(--text-muted);
        background-clip: content-box;
    }

    #custom-controls-wrapper {
        max-width: 100%;
    }


    /* ═══════════════════════════════════════════
       VISUAL SCALING — постеры/карточки 9/16 в узкой
       полосе 480px дают 270px высоты, забивают экран.
       Сжимаем до 3/4 чтобы первый экран помещался.
       ═══════════════════════════════════════════ */

    .drama-card__poster,
    .random-card {
        aspect-ratio: 3 / 4;
    }

    /* TRAINER: видео-блок центрируем в полосе trainer-page (540-600px).
       В flex-column родителе align-self: center перебивает stretch. */
    .trainer-page #video-container {
        align-self: center !important;
        width: 100%;
        max-width: 420px;
    }

    /* ═══════════════════════════════════════════
       TRAINER: переключатели режимов на десктопе —
       компактные. На mobile flex:1 растягивает кнопки
       на всю ширину, на десктопе это смотрится огромно.
       Сжимаем по содержимому, центрируем в строке.
       ═══════════════════════════════════════════ */

    .lang-toggle-btn {
        flex: 0 0 auto !important;
        min-width: 72px;
        max-width: 110px;
    }
    #language-toggle-container {
        gap: 10px;
        padding: 8px 20px 10px;
    }
    #language-toggle-container .lang-toggle-btn {
        height: 32px !important;
        gap: 1px;
    }
    #language-toggle-container .lang-toggle-btn img {
        width: 14px;
        height: 14px;
    }
    #language-toggle-container .lang-toggle-btn .lt-label {
        font-size: 8px;
        letter-spacing: 0.8px;
    }
    .lang-toggle-choice .lt-icon-row {
        height: 16px !important;
        font-size: 11px;
    }
}


/* ─────────────────────────────────────────────
   2b. ШИРОКИЙ DESKTOP БРАУЗЕР (>= 700px окно):
   доп. ужатие текстов, ориентир — не TG-WebApp
   ───────────────────────────────────────────── */

@media (hover: hover) and (pointer: fine) and (min-width: 700px) {

    /* offer2 hook 25px на 480px — крупно, сжимаем */
    .offer-hook { font-size: 22px; line-height: 1.25; }
    .offer-demo__phrase { font-size: 26px; }
    .offer-demo__score { font-size: 34px; }
}


/* ─────────────────────────────────────────────
   2. ШИРОКИЙ ЭКРАН (>= 900px)
   ───────────────────────────────────────────── */

@media (hover: hover) and (pointer: fine) and (min-width: 900px) {

    body {
        border-radius: 16px;
        overflow: hidden;
        margin-top: 20px;
        margin-bottom: 20px;
        min-height: calc(100vh - 40px);
        box-shadow:
            0 0 0 1px var(--desktop-border-color),
            0 20px 80px rgba(0, 0, 0, 0.6),
            0 0 60px rgba(255, 215, 0, 0.03);
    }

    .tab-bar {
        border-radius: 0 0 16px 16px;
    }
}


/* ─────────────────────────────────────────────
   3. TELEGRAM DESKTOP WEBAPP (~400-500px окно)
   ───────────────────────────────────────────── */

@media (hover: hover) and (pointer: fine) and (max-width: 550px) {

    body {
        border-left: none;
        border-right: none;
        box-shadow: none;
        border-radius: 0;
        margin-top: 0;
        margin-bottom: 0;
        min-height: 100vh;
        max-width: 100%;
    }

    .tab-bar {
        max-width: 100%;
        left: 0;
        right: 0;
        margin-left: 0;
        margin-right: 0;
        border-radius: 0;
    }

    .trainer-topbar,
    .bank-topbar {
        max-width: 100%;
        left: 0;
        right: 0;
        margin-left: 0;
        margin-right: 0;
    }

    .floating-controls {
        right: 16px;
    }

    #fadeOverlay,
    .pixel-loader,
    #loader,
    .page-loader,
    #loadingScreen,
    #premium-block-modal,
    #limit-modal,
    #loading-spinner {
        left: 0;
        right: 0;
        max-width: 100%;
        margin-left: 0;
        margin-right: 0;
    }

    #input-area {
        width: 90% !important;
        max-width: 100% !important;
        left: 0 !important;
        right: 0 !important;
        transform: none !important;
        margin-left: auto !important;
        margin-right: auto !important;
    }

    #global-stars-display {
        right: var(--spacing-lg) !important;
    }
}
