/* =========================================================
   MKS CRM - UI CLARA (cards brancos + KPIs coloridos)
   ========================================================= */

:root{
    --mks-bg: #f6f8fb;
    --mks-card: #ffffff;
    --mks-border: #e6eaf0;
    --mks-text: #1f2a37;
    --mks-muted: #6b7280;

    --mks-primary: #2563eb;
    --mks-success: #16a34a;
    --mks-warning: #f59e0b;
    --mks-danger: #dc2626;
    --mks-info: #0891b2;

    --sidebar-width: 280px;
    --sidebar-collapsed-width: 78px;
}

* { box-sizing: border-box; }
html, body { height: 100%; }

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

  body.mks-body:not(.authenticated) {
  background: #f6f8fb;
}

.mks-app{
    display: flex;
    min-height: 100vh;
}

/* =========================================================
   SIDEBAR (CLARA)
   ========================================================= */

.mks-sidebar{
    width: var(--sidebar-width);
    background: #ffffff !important;
    border-right: 1px solid var(--mks-border);
    position: sticky;
    top: 0;
    height: 100vh;
    padding: 14px 12px;
    overflow-y: auto;
    transition: width .22s ease;
}

.sidebar-collapsed .mks-sidebar{
    width: var(--sidebar-collapsed-width);
}

.mks-sidebar .brand{
    display: flex;
    align-items: center;
    gap: 10px;
    padding: 8px 10px;
    margin-bottom: 10px;
    border-radius: 12px;
}

.mks-sidebar .brand .logo{
    width: 42px;
    height: 42px;
    border-radius: 12px;
    background: linear-gradient(135deg, var(--mks-primary), #7c3aed);
    display: grid;
    place-items: center;
    color: #fff;
    font-weight: 800;
}

.mks-sidebar .brand .title{
    line-height: 1.2;
}

.mks-sidebar .brand .title .name{
    font-weight: 800;
}

.mks-sidebar .brand .title .sub{
    font-size: .78rem;
    color: var(--mks-muted);
}

.sidebar-collapsed .mks-sidebar .brand .title{
    display: none;
}

.mks-nav-section{
    margin-top: 12px;
}

.mks-nav-title{
    font-size: .74rem;
    text-transform: uppercase;
    letter-spacing: .08em;
    color: var(--mks-muted);
    font-weight: 800;
    padding: 8px 10px;
}

.sidebar-collapsed .mks-nav-title{
    display:none;
}

.mks-nav a{
    display: flex;
    align-items: center;
    gap: 12px;
    padding: 10px 12px;
    margin: 6px 0;
    border-radius: 12px;
    text-decoration: none;
    color: var(--mks-text);
    font-weight: 600;
    transition: background .15s ease, color .15s ease;
    border: 1px solid transparent;
}

.mks-nav a i{
    width: 22px;
    text-align: center;
    color: var(--mks-muted);
}

.mks-nav a:hover{
    background: #f3f6ff;
    border-color: #e9eeff;
}

.mks-nav a.active{
    background: #eef2ff;
    border-color: #dbe3ff;
    color: var(--mks-primary);
}

.mks-nav a.active i{
    color: var(--mks-primary);
}

.sidebar-collapsed .mks-nav a span{
    display:none;
}

.sidebar-collapsed .mks-nav a{
    justify-content: center;
}

/* =========================================================
   MAIN + TOPBAR
   ========================================================= */

.mks-main{
    flex: 1;
    display: flex;
    flex-direction: column;
    min-width: 0;
}

.mks-topbar{
    background: #ffffff;
    border-bottom: 1px solid var(--mks-border);
    padding: 12px 16px;
    position: sticky;
    top: 0;
    z-index: 40;
}

.mks-topbar .btn{
    border-radius: 12px;
}

.mks-content{
    padding: 18px 18px 40px;
}

/* =========================================================
   CARDS / DASH
   ========================================================= */

.card{
    border: 1px solid var(--mks-border) !important;
    border-radius: 16px !important;
}

.card-header{
    border-bottom: 1px solid var(--mks-border) !important;
}

.mks-kpi{
    display:flex;
    align-items:center;
    justify-content:space-between;
    gap: 14px;
}

.mks-kpi .label{
    font-size: .78rem;
    color: var(--mks-muted);
    font-weight: 800;
    text-transform: uppercase;
    letter-spacing: .06em;
}

.mks-kpi .value{
    font-size: 1.4rem;
    font-weight: 900;
}

.mks-kpi .icon{
    width: 46px;
    height: 46px;
    border-radius: 14px;
    display:grid;
    place-items:center;
}

.icon-primary{ background:#e8efff; color: var(--mks-primary); }
.icon-success{ background:#e9f9ef; color: var(--mks-success); }
.icon-warning{ background:#fff5e6; color: var(--mks-warning); }
.icon-danger{  background:#ffeaea; color: var(--mks-danger); }
.icon-info{    background:#e6fbff; color: var(--mks-info); }

/* Tables */
.table thead th{
    font-size: .82rem;
    text-transform: uppercase;
    letter-spacing: .04em;
}
.table td{
    vertical-align: middle;
}

/* Footer */
.mks-footer{
    margin-top: auto;
    background: transparent;
}

/* Badges nicer */
.badge{
    border-radius: 10px;
    padding: .45rem .65rem;
}

/* Utility: subtle separators */
.mks-divider{
    height: 1px;
    background: var(--mks-border);
    margin: 12px 0;

}

.chart-box{ position: relative; height: 320px; }
.chart-box-sm{ height: 320px; } /* top seguradoras também grande */


