/* ========================================================================== 
   PORTAL UNIFIED LAYER
   Alinea look & feel entre modulos del portal sin romper estilos base.
   ========================================================================== */

:root {
    --portal-radius: 14px;
    --portal-surface: rgba(15, 23, 42, 0.62);
    --portal-border: rgba(148, 163, 184, 0.18);
}

@import url('https://fonts.googleapis.com/css2?family=Orbitron:wght@400;700&display=swap');

/* Tipografia y render consistente */
body.bnk-page,
body.ptr-page,
body.tj-page,
body.bm-page,
body.esc-page {
    font-family: var(--font-body, 'Roboto', 'Segoe UI', Tahoma, sans-serif);
    text-rendering: optimizeLegibility;
}

/* Marcas y navegacion en la misma linea visual */
.bnk-brand span,
.ptr-brand span,
.tj-brand span,
.bm-brand span,
.sidebar-brand h2 {
    font-family: 'Inter', sans-serif;
    letter-spacing: 0.06em;
    text-transform: uppercase;
}

.bnk-brand img,
.ptr-brand img,
.tj-brand img,
.bm-brand img {
    width: auto;
    height: 36px;
    border-radius: 0;
    border: none;
    box-shadow: none;
    object-fit: contain;
}

.bnk-user-pill img,
.ptr-user-pill img,
.tj-user-pill img,
.bm-user-pill img {
    width: 32px;
    height: 32px;
    border-radius: 50%;
    object-fit: cover;
}

.bnk-user-pill span,
.ptr-user-pill span,
.tj-user-pill span,
.bm-user-pill span {
    font-family: 'Inter', sans-serif;
    font-size: 0.84rem;
    font-weight: 700;
    color: #f8fafc;
    letter-spacing: 0.08em;
    text-transform: uppercase;
    white-space: nowrap;
}

.bnk-nav-item,
.ptr-nav-item,
.tj-nav-item,
.bm-nav-item,
.exp-nav-item {
    font-weight: 700;
}

/* Topbars: misma sensacion de vidrio tactico */
.bnk-topbar,
.ptr-topbar,
.tj-topbar,
.bm-topbar {
    background: rgba(8, 14, 28, 0.84) !important;
    backdrop-filter: blur(18px);
    -webkit-backdrop-filter: blur(18px);
    border-bottom: 1px solid rgba(148, 163, 184, 0.14) !important;
}

/* Compactacion vertical global en paginas internas */
.bnk-main,
.ptr-main,
.tj-main,
.bm-main {
    padding-top: 1.25rem !important;
    padding-bottom: 2.5rem !important;
}

/* Compactar heroes/headers para reducir scroll innecesario */
.bnk-hero,
.mercado-hero,
.ma-hero,
.tienda-hero,
.mb-hero,
.tj-hero,
.bm-balance-row {
    margin-bottom: 1rem !important;
}

.mercado-hero,
.ma-hero,
.tienda-hero,
.mb-hero,
.tj-hero {
    border-radius: var(--portal-radius);
}

/* Tarjetas y barras con radios/bordes coherentes */
.mercado-balance-bar,
.ma-stats-grid .ma-stat-card,
.dept-nav,
.mb-tabs,
.tj-tabs,
.bm-category-nav,
.bnk-actions-row,
.bm-balance-card,
.bm-section-header,
.mb-section-header,
.mercado-filters,
.mercado-results-bar,
.ma-actions-bar {
    border-radius: var(--portal-radius);
}

/* Ajuste de color para boton secundario de mercado */
.mercado-publish-btn--secondary {
    background: rgba(14, 165, 233, 0.12) !important;
    color: #7dd3fc !important;
    border-color: rgba(14, 165, 233, 0.28) !important;
}

/* Escenas: integrar con estilo del portal y compactar layout */
body.esc-page {
    background: #0b1220;
}

body.esc-page .escenas-app {
    flex: 1;
    min-height: 0;
}

body.esc-page .escenas-sidebar {
    border-right: 1px solid rgba(148, 163, 184, 0.14);
}

body.esc-page .sidebar-header {
    padding: 14px 16px 12px;
}

body.esc-page .sidebar-brand h2 {
    font-size: 1rem;
}

body.esc-page .chat-header,
body.esc-page .chat-input-area,
body.esc-page .esc-modal {
    border-color: rgba(148, 163, 184, 0.16);
}

/* Compactacion adicional en mobile */
@media (max-width: 920px) {
    .bnk-main,
    .ptr-main,
    .tj-main,
    .bm-main {
        padding-top: 1rem !important;
        padding-bottom: 1.8rem !important;
    }

    .mercado-hero,
    .ma-hero,
    .tienda-hero,
    .mb-hero,
    .tj-hero {
        margin-bottom: 0.75rem !important;
    }

    .mercado-filters,
    .ma-tabs,
    .dept-nav,
    .mb-tabs,
    .tj-tabs,
    .bm-category-nav {
        gap: 0.45rem;
    }
}

