/**
 * TeleLive — Mobile web app shell (m.* subdomain)
 * Twitch / Kick–inspired: dark neutrals, clear hierarchy, touch-friendly.
 * Scoped under body.tl-mobile-app (see includes/header.php).
 */

/* ── Design tokens ─────────────────────────────────────────── */
.tl-mobile-app {
    --tl-app-bg: #0e0e10;
    --tl-app-surface: #18181b;
    --tl-app-elev: #1f1f23;
    --tl-app-border: #2f2f35;
    --tl-app-text: #efeff1;
    --tl-app-muted: #adadb8;
    --tl-app-accent: #1e56f5;
    --tl-app-accent-2: #5280ff;
    --tl-app-radius: 12px;
    --tl-app-radius-sm: 10px;
    --tl-app-nav-h: calc(56px + env(safe-area-inset-bottom, 0px));
    --tl-app-tap: 44px;
}

.tl-mobile-app {
    background: var(--tl-app-bg);
    color: var(--tl-app-text);
    padding-bottom: env(safe-area-inset-bottom, 0);
}

.tl-mobile-app .tl-page-content,
.tl-mobile-app main {
    padding-bottom: calc(12px + var(--tl-app-nav-h));
}

/* Top bar: slimmer, app-like */
@media (max-width: 900px) {
    .tl-mobile-app .navbar {
        background: rgba(14, 14, 16, 0.92) !important;
        backdrop-filter: blur(12px);
        -webkit-backdrop-filter: blur(12px);
        border-bottom: 1px solid rgba(255, 255, 255, 0.06);
        box-shadow: none;
    }

    .tl-mobile-app .navbar-brand span {
        font-weight: 800;
        letter-spacing: -0.02em;
    }

    .tl-mobile-app .navbar-logo-img {
        border-radius: 10px;
    }
}

/* Bottom tab bar — glass, Kick-style */
.tl-mobile-app .mob-nav-bottom {
    position: fixed;
    left: 0;
    right: 0;
    bottom: 0;
    z-index: 1200;
    background: rgba(24, 24, 27, 0.88) !important;
    backdrop-filter: blur(16px) saturate(1.2);
    -webkit-backdrop-filter: blur(16px) saturate(1.2);
    border-top: 1px solid rgba(255, 255, 255, 0.08);
    padding-bottom: env(safe-area-inset-bottom, 0);
    box-shadow: 0 -8px 32px rgba(0, 0, 0, 0.45);
}

.tl-mobile-app .mob-nav-item {
    min-height: var(--tl-app-tap);
    border-radius: 10px;
    margin: 4px 2px;
    font-size: 0.68rem;
    font-weight: 600;
    color: var(--tl-app-muted);
    transition: color 0.15s, background 0.15s;
}

.tl-mobile-app .mob-nav-item i {
    font-size: 1.15rem;
    margin-bottom: 2px;
    opacity: 0.85;
}

.tl-mobile-app .mob-nav-item.active {
    color: #fff;
    background: rgba(30, 86, 245, 0.2);
}

.tl-mobile-app .mob-nav-item.active i {
    color: var(--tl-app-accent);
    opacity: 1;
}

.tl-mobile-app .mob-nav-item.active .mob-nav-avatar {
    box-shadow: 0 0 0 2px rgba(30, 86, 245, 0.85), 0 0 12px rgba(30, 86, 245, 0.45);
}

/* Stream watch: full-bleed feel */
.tl-mobile-app.page-stream .stream-page,
.tl-mobile-app .stream-page {
    gap: 0;
    background: var(--tl-app-bg);
}

.tl-mobile-app .stream-left-col {
    border-radius: 0;
}

.tl-mobile-app .stream-player {
    border-radius: 0;
    overflow: hidden;
}

.tl-mobile-app .player-wrapper {
    border-radius: 0 !important;
    border: none !important;
    box-shadow: none !important;
}

/* Chat column — readable, padded */
@media (max-width: 900px) {
    .tl-mobile-app .chat-panel {
        background: var(--tl-app-surface) !important;
        border-inline-start: 1px solid var(--tl-app-border) !important;
    }
    /* /live full-width — sidebar border was shrinking chat + leaving a gutter */
    .tl-mobile-app.page-stream .stream-page .chat-panel {
        border-inline-start: none !important;
        border-inline-end: none !important;
        width: 100% !important;
        max-width: 100% !important;
    }

    .tl-mobile-app .chat-header {
        background: var(--tl-app-elev) !important;
        border-bottom: 1px solid var(--tl-app-border) !important;
        min-height: 48px;
        padding: 8px 12px;
    }

    .tl-mobile-app .chat-messages {
        padding: 10px 12px 8px;
        gap: 6px;
        font-size: 0.9rem;
        line-height: 1.45;
    }

    .tl-mobile-app .chat-message {
        border-radius: var(--tl-app-radius-sm);
        padding: 8px 10px;
    }

    .tl-mobile-app .chat-input-wrap,
    .tl-mobile-app #chatForm {
        background: var(--tl-app-elev) !important;
        border-top: 1px solid var(--tl-app-border) !important;
        padding-bottom: calc(8px + env(safe-area-inset-bottom, 0));
    }
    /* /live: avoid double bottom gap — style.css pins composer with safe-area only */
    .tl-mobile-app.page-stream .chat-input-wrap,
    .tl-mobile-app.page-stream #chatForm {
        padding-bottom: max(2px, env(safe-area-inset-bottom, 0)) !important;
        border-top: none !important;
    }

    .tl-mobile-app #chatInput {
        border-radius: var(--tl-app-radius-sm) !important;
        min-height: var(--tl-app-tap);
        font-size: 16px; /* avoid iOS zoom */
    }

    .tl-mobile-app .mobile-tab-bar .mob-info-bar {
        background: var(--tl-app-surface) !important;
        border-top: 1px solid var(--tl-app-border);
        border-bottom: 1px solid var(--tl-app-border);
    }

    .tl-mobile-app .mob-info-title {
        font-weight: 700;
        letter-spacing: -0.01em;
    }

    .tl-mobile-app .mob-info-btn,
    .tl-mobile-app .mob-info-btn-txt {
        border-radius: 999px !important;
        min-height: 36px;
    }
    /* /live labeled grid uses rounded rects, not pills */
    .tl-mobile-app.page-stream .mob-info-btn.mob-info-btn-stack,
    .tl-mobile-app.page-stream .mob-info-btn.mob-info-btn-txt,
    .tl-mobile-app.page-stream .mob-info-viewer-pill,
    .tl-mobile-app.page-stream .mob-info-bar-actions > .viewer-count,
    .tl-mobile-app.page-stream .player-mob-viewer {
        border-radius: 10px !important;
        min-height: 44px;
    }
}

/* Home / browse cards — subtle lift */
@media (max-width: 900px) {
    .tl-mobile-app .category-card-scroll,
    .tl-mobile-app .stream-card,
    .tl-mobile-app .browse-card {
        border-radius: var(--tl-app-radius) !important;
        border: 1px solid rgba(255, 255, 255, 0.06) !important;
        background: var(--tl-app-surface) !important;
    }

    .tl-mobile-app .container {
        padding-left: 14px;
        padding-right: 14px;
    }
}

/* Page loader less “heavy” on app */
.tl-mobile-app .page-loader.tele-loader {
    background: var(--tl-app-bg) !important;
}

/* Buttons primary — slight purple tilt like Twitch */
.tl-mobile-app .btn-primary {
    background: linear-gradient(135deg, var(--tl-app-accent-2), var(--tl-app-accent)) !important;
    border: none !important;
    box-shadow: 0 4px 14px rgba(145, 71, 255, 0.25);
}

/* Reduce visual noise on auth pages */
.tl-mobile-app .auth-page .auth-card {
    border-radius: var(--tl-app-radius);
    border: 1px solid var(--tl-app-border);
    background: var(--tl-app-surface);
}

/* Scroll containment for chat tab on stream */
.tl-mobile-app #streamPageWrap[data-mob-tab="chat"] .chat-panel {
    min-height: 50vh;
}
