/* Moonlight-Web — Layout: app shell (header, main, footer) */

/* ── Header ────────────────────────────────────────────────────────────── */
.app-header {
    display: flex;
    align-items: center;
    gap: var(--space-3);
    padding: var(--space-3) var(--space-5);
    /* Mobile: viewport-fit=cover + translucent status bar push content under
       the notch/status bar — inset the header so the title stays visible. */
    padding-top: max(var(--space-3), env(safe-area-inset-top));
    padding-left: max(var(--space-5), env(safe-area-inset-left));
    padding-right: max(var(--space-5), env(safe-area-inset-right));
    background: var(--surface-glass);
    backdrop-filter: blur(16px) saturate(140%);
    -webkit-backdrop-filter: blur(16px) saturate(140%);
    border-bottom: 1px solid var(--border-1);
    box-shadow: var(--shadow-1);
    flex-shrink: 0;
    z-index: 100;
}

.app-header h1 {
    font-size: var(--fs-lg);
    font-weight: 700;
    letter-spacing: 2px;
    color: var(--text-1);
    text-shadow: 0 0 12px var(--accent-ring);
}

.version {
    font-size: var(--fs-xs);
    font-weight: 600;
    color: var(--text-2);
    background: rgba(255, 255, 255, 0.05);
    border: 1px solid var(--border-1);
    border-radius: var(--radius-pill);
    padding: 2px 10px;
}

.header-actions {
    display: flex;
    align-items: center;
    gap: var(--space-2);
    margin-left: auto;
}

/* ── Main content — the ONLY scroll container of the app ────────────────── */
#main-content {
    flex: 1;
    min-height: 0;
    overflow-y: auto;
    overflow-x: hidden;
    padding: var(--space-6) var(--space-5) var(--space-8);
    width: 100%;
}

/* Inner views are centered with a max width — the scrollbar stays on the
   right edge of the viewport, below the header. */
.hosts-view,
.apps-view,
.settings-view,
.admin-view,
.login-view {
    max-width: 960px;
    margin: 0 auto;
}

.settings-view,
.admin-view {
    max-width: 680px;
}

/* ── Footer ────────────────────────────────────────────────────────────── */
.app-footer {
    text-align: center;
    padding: var(--space-2) var(--space-5);
    /* Extend the footer's dark background into the home-indicator safe area
       so its text clears the indicator and no white bar shows underneath. */
    padding-bottom: max(var(--space-2), env(safe-area-inset-bottom));
    padding-left: max(var(--space-5), env(safe-area-inset-left));
    padding-right: max(var(--space-5), env(safe-area-inset-right));
    font-size: var(--fs-xs);
    color: var(--text-3);
    border-top: 1px solid var(--border-1);
    background-color: rgba(13, 17, 24, 0.6);
    flex-shrink: 0;
}

/* ── Responsive ────────────────────────────────────────────────────────── */
@media (max-width: 600px) {
    #main-content {
        padding: var(--space-3);
    }

    .app-header {
        padding: var(--space-3) var(--space-4);
        /* Keep the safe-area insets — the shorthand above would otherwise
           reset padding-top and let the title slide under the status bar. */
        padding-top: max(var(--space-3), env(safe-area-inset-top));
        padding-left: max(var(--space-4), env(safe-area-inset-left));
        padding-right: max(var(--space-4), env(safe-area-inset-right));
    }
}
