/* Estilo principal del panel */

:root{
    --sidebar-bg: linear-gradient(180deg, #0f172a 0%, #111827 100%);
    --sidebar-text: #cbd5e1;
    --sidebar-active: #ffffff;
    --main-bg: #f4f7fb;
    --card-radius: 20px;
    --card-shadow: 0 12px 28px rgba(15, 23, 42, .08);
    --border-color: #e2e8f0;
    --text-main: #0f172a;
    --text-soft: #64748b;
    --primary: #2563eb;
    --success: #10b981;
    --warning: #f59e0b;
    --danger: #ef4444;
}

body.app-body{
    background: var(--main-bg);
    color: var(--text-main);
}

.app-shell{
    min-height: 100vh;
    display: grid;
    grid-template-columns: 280px 1fr;
}

.sidebar{
    background: var(--sidebar-bg);
    color: var(--sidebar-text);
    padding: 26px 18px;
    display: flex;
    flex-direction: column;
    gap: 18px;
    position: sticky;
    top: 0;
    height: 100vh;
}

.sidebar-brand{
    display: flex;
    align-items: center;
    gap: 14px;
    padding: 12px 10px 18px 10px;
    border-bottom: 1px solid rgba(255,255,255,.08);
}

.sidebar-brand-icon{
    width: 46px;
    height: 46px;
    border-radius: 14px;
    display: flex;
    align-items: center;
    justify-content: center;
    font-weight: 800;
    background: linear-gradient(135deg, #3b82f6, #06b6d4);
    color: white;
    box-shadow: 0 10px 20px rgba(59,130,246,.25);
}

.sidebar-brand-title{
    font-size: 1.05rem;
    font-weight: 700;
    color: #fff;
}

.sidebar-brand-subtitle{
    font-size: .82rem;
    color: #94a3b8;
}

.sidebar-nav{
    display: flex;
    flex-direction: column;
    gap: 8px;
}

.sidebar-link{
    color: var(--sidebar-text);
    padding: 12px 14px;
    border-radius: 14px;
    transition: all .18s ease;
    font-weight: 600;
    font-size: .96rem;
}

.sidebar-link:hover{
    color: #fff;
    background: rgba(255,255,255,.08);
}

.sidebar-link.active{
    color: var(--sidebar-active);
    background: rgba(59,130,246,.22);
    box-shadow: inset 0 0 0 1px rgba(147,197,253,.25);
}

.sidebar-footer{
    margin-top: auto;
    padding-top: 8px;
    border-top: 1px solid rgba(255,255,255,.08);
}

.app-main{
    padding: 26px;
    min-width: 0;
}

.topbar{
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 18px;
    margin-bottom: 20px;
}

.topbar-title{
    margin: 0 0 6px 0;
    font-size: 1.9rem;
    font-weight: 800;
    letter-spacing: -.02em;
}

.topbar-subtitle{
    color: var(--text-soft);
    font-size: .95rem;
}

.topbar-user{
    background: #fff;
    border: 1px solid #e7edf5;
    border-radius: 18px;
    padding: 12px 16px;
    min-width: 220px;
    text-align: right;
    box-shadow: var(--card-shadow);
}

.topbar-user-name{
    font-weight: 700;
}

.topbar-user-role{
    color: var(--text-soft);
    font-size: .85rem;
}

.content-area{
    display: flex;
    flex-direction: column;
    gap: 18px;
}

.panel-card{
    background: #fff;
    border-radius: var(--card-radius);
    box-shadow: var(--card-shadow);
    border: 1px solid #e7edf5;
}

.panel-card-header{
    padding: 18px 22px;
    border-bottom: 1px solid #eef2f7;
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 12px;
}

.panel-card-title{
    margin: 0;
    font-size: 1.02rem;
    font-weight: 800;
}

.panel-card-subtitle{
    color: var(--text-soft);
    font-size: .87rem;
    margin-top: 4px;
}

.panel-card-body{
    padding: 22px;
}

.kpi-card{
    background: #fff;
    border-radius: 22px;
    padding: 20px;
    border: 1px solid #e7edf5;
    box-shadow: var(--card-shadow);
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 16px;
}

.kpi-label{
    color: var(--text-soft);
    font-size: .92rem;
    margin-bottom: 8px;
}

.kpi-value{
    font-size: 2rem;
    font-weight: 800;
    line-height: 1;
    margin-bottom: 6px;
}

.kpi-foot{
    color: var(--text-soft);
    font-size: .82rem;
}

.kpi-icon{
    min-width: 58px;
    width: 58px;
    height: 58px;
    border-radius: 18px;
    display: flex;
    align-items: center;
    justify-content: center;
    font-weight: 800;
    color: #fff;
    background: linear-gradient(135deg, #2563eb, #38bdf8);
}

.filters-grid{
    display: grid;
    grid-template-columns: repeat(5, minmax(0, 1fr));
    gap: 12px;
}

@media (max-width: 1100px){
    .filters-grid{
        grid-template-columns: repeat(2, minmax(0, 1fr));
    }
}

@media (max-width: 680px){
    .filters-grid{
        grid-template-columns: 1fr;
    }
}

.table-wrap{
    overflow: auto;
}

.app-table th,
.app-table td{
    white-space: nowrap;
}

.app-table td.text-wrap{
    white-space: normal;
    min-width: 250px;
}

.mono{
    font-family: Consolas, Monaco, monospace;
    font-size: .85rem;
}

.json-block{
    background: #0f172a;
    color: #e2e8f0;
    padding: 14px;
    border-radius: 14px;
    overflow: auto;
    max-height: 260px;
    border: 1px solid rgba(255,255,255,.08);
}

.message-item{
    padding: 16px 18px;
    border-radius: 18px;
    border: 1px solid #e7edf5;
    margin-bottom: 12px;
    background: #fff;
    box-shadow: 0 8px 20px rgba(15,23,42,.04);
}

.message-head{
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 12px;
    margin-bottom: 10px;
    flex-wrap: wrap;
}

.message-meta{
    color: var(--text-soft);
    font-size: .84rem;
}

.message-text{
    font-size: .98rem;
    line-height: 1.55;
    white-space: pre-wrap;
    word-break: break-word;
}

.login-wrap{
    min-height: 100vh;
    display: grid;
    place-items: center;
    background: radial-gradient(circle at top left, #dbeafe, #eff6ff 35%, #f8fafc 72%);
    padding: 22px;
}

.login-card{
    width: 100%;
    max-width: 430px;
    background: #fff;
    border-radius: 26px;
    border: 1px solid #e6edf5;
    box-shadow: 0 20px 60px rgba(15,23,42,.12);
    overflow: hidden;
}

.login-top{
    padding: 28px 28px 18px 28px;
    background: linear-gradient(135deg, #0f172a, #1d4ed8);
    color: white;
}

.login-title{
    font-size: 1.6rem;
    font-weight: 800;
    margin: 0 0 6px 0;
}

.login-subtitle{
    margin: 0;
    color: rgba(255,255,255,.82);
}

.login-body{
    padding: 28px;
}

.login-help{
    margin-top: 14px;
    color: var(--text-soft);
    font-size: .86rem;
}

.info-grid{
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 14px;
}

.info-box{
    background: #f8fafc;
    border: 1px solid #e5edf5;
    border-radius: 16px;
    padding: 14px 16px;
}

.info-box-label{
    color: var(--text-soft);
    font-size: .8rem;
    text-transform: uppercase;
    letter-spacing: .04em;
    margin-bottom: 6px;
}

.info-box-value{
    font-weight: 700;
    word-break: break-word;
}

.section-title{
    font-weight: 800;
    font-size: 1.08rem;
    margin-bottom: 14px;
}

.empty-state{
    padding: 28px;
    border: 1px dashed #cbd5e1;
    border-radius: 18px;
    text-align: center;
    color: var(--text-soft);
    background: #f8fafc;
}

.toolbar{
    display:flex;
    align-items:center;
    justify-content:space-between;
    gap:12px;
    flex-wrap:wrap;
    margin-bottom:14px;
}

@media (max-width: 980px){
    .app-shell{
        grid-template-columns: 1fr;
    }

    .sidebar{
        position: relative;
        height: auto;
    }

    .topbar{
        flex-direction: column;
        align-items: stretch;
    }

    .topbar-user{
        text-align: left;
        min-width: auto;
    }

    .info-grid{
        grid-template-columns: 1fr;
    }
}
