/* =========================
   NAVBAR / HEADER
========================= */

.sidebar{

    width:100%;

    height:82px;

    position:fixed;

    top:0;
    left:0;

    display:flex;
    align-items:center;
    justify-content:space-between;

    padding:0 34px;

    background:
    linear-gradient(
        180deg,
        #edf4fb 0%,
        #dfeffc 100%
    );

    backdrop-filter:blur(22px);

    border-bottom:
    1px solid rgba(93,169,255,0.10);

    z-index:1000;

    box-shadow:
    0 10px 35px rgba(93,169,255,0.08);

}

/* GLOW LINE */

.sidebar::after{

    content:'';

    position:absolute;

    bottom:0;
    left:0;

    width:100%;
    height:1px;

    background:
    linear-gradient(
        90deg,
        transparent,
        rgba(93,169,255,0.25),
        transparent
    );

}

/* =========================
   LOGO
========================= */

.logo{

    display:flex;
    align-items:center;

    width:230px;

    overflow:hidden;

}

.logo img,
.logo-img{

    height:58px;

    width:auto !important;

    object-fit:contain;

    display:block;

}

/* =========================
   MENU
========================= */

.menu{

    display:flex;
    align-items:center;

    gap:12px;

}

.menu a{

    height:50px;

    display:flex;
    align-items:center;
    justify-content:center;

    gap:10px;

    padding:0 22px;

    border-radius:18px;

    color:#334155;

    transition:0.25s ease;

    position:relative;

    overflow:hidden;

    font-weight:500;

    font-size:15px;

}

.menu a i{

    font-size:19px;

}

/* HOVER */

.menu a:hover{

    background:
    rgba(93,169,255,0.10);

    color:#2563eb;

    transform:
    translateY(-2px);

}

/* ACTIVE */

.menu a.active{

    transform:
    translateY(-2px);

    background:
    linear-gradient(
        135deg,
        #5da9ff,
        #3b82f6
    );

    color:white;

    box-shadow:
    0 10px 25px rgba(93,169,255,0.20);

}

.menu a.active::before{

    content:'';

    position:absolute;

    inset:0;

    border-radius:18px;

    border:
    1px solid rgba(255,255,255,0.18);

}

/* =========================
   MAIN CONTENT
========================= */

.main-content{

    margin-top:110px;

    padding:34px;

    animation:
    fadeUp 0.5s ease;

}

/* =========================
   PAGE HEADER
========================= */

.page-header{

    display:flex;

    justify-content:space-between;

    align-items:flex-start;

    gap:20px;

    margin-bottom:32px;

}

/* =========================
   TITLES
========================= */

.page-title{

    font-size:58px;

    line-height:0.95;

    letter-spacing:-2px;

    font-weight:800;

    color:#0f172a;

}

.page-subtitle{

    margin-top:14px;

    font-size:17px;

    color:#64748b;

}

/* =========================
   SEARCH
========================= */

.search-box{

    width:320px;

    height:54px;

    display:flex;

    align-items:center;

    gap:12px;

    padding:0 18px;

    border-radius:18px;

    background:
    rgba(255,255,255,0.72);

    border:
    1px solid rgba(15,23,42,0.08);

    backdrop-filter:blur(18px);

    transition:0.25s;

    box-shadow:
    0 10px 25px rgba(93,169,255,0.08);

}

.search-box:focus-within{

    border-color:
    rgba(93,169,255,0.35);

    box-shadow:
    0 0 25px rgba(93,169,255,0.12);

}

.search-box i{

    color:#64748b;

}

.search-box input{

    width:100%;

    background:transparent;

    border:none;

    outline:none;

    color:#0f172a;

    font-size:15px;

}

/* =========================
   BUTTONS
========================= */

.primary-btn{

    height:54px;

    padding:0 26px;

    border:none;

    border-radius:18px;

    background:
    linear-gradient(
        135deg,
        #5da9ff,
        #3b82f6
    );

    color:white;

    font-weight:600;

    font-size:15px;

    display:flex;

    align-items:center;

    justify-content:center;

    gap:10px;

    cursor:pointer;

    transition:0.25s ease;

    box-shadow:
    0 10px 25px rgba(93,169,255,0.16);

}

.primary-btn:hover{

    transform:
    translateY(-2px);

    box-shadow:
    0 14px 32px rgba(93,169,255,0.24);

}

/* =========================
   KPI GRID
========================= */

.kpi-grid{

    display:grid;

    grid-template-columns:
    repeat(auto-fit,minmax(260px,1fr));

    gap:22px;

    margin-top:28px;

}

/* =========================
   GLASS CARD
========================= */

.glass-card{

    background:
    rgba(255,255,255,0.60);

    border:
    1px solid rgba(255,255,255,0.7);

    border-radius:30px;

    backdrop-filter:blur(18px);

    box-shadow:
    0 10px 35px rgba(93,169,255,0.08);

}

/* =========================
   KPI CARD
========================= */

.kpi-card{

    min-height:190px;

    padding:28px;

}

/* =========================
   TABLE CONTAINER
========================= */

.table-container{

    margin-top:28px;

    padding:28px;

    border-radius:32px;

}

/* =========================
   PROFILE
========================= */

.topbar-right{

    display:flex;
    align-items:center;

    gap:18px;

}

/* NOTIFICATION */

.notification{

    width:52px;
    height:52px;

    border-radius:18px;

    background:
    rgba(255,255,255,0.72);

    border:
    1px solid rgba(15,23,42,0.08);

    display:flex;
    align-items:center;
    justify-content:center;

    position:relative;

    transition:0.25s;

    backdrop-filter:blur(18px);

    box-shadow:
    0 10px 25px rgba(93,169,255,0.08);

}

.notification:hover{

    transform:
    translateY(-3px);

    box-shadow:
    0 0 25px rgba(93,169,255,0.15);

}

.notification i{

    color:#0f172a;

}

.notification span{

    position:absolute;

    top:-4px;
    right:-4px;

    width:20px;
    height:20px;

    border-radius:50%;

    background:#ef4444;

    color:white;

    font-size:11px;
    font-weight:bold;

    display:flex;
    align-items:center;
    justify-content:center;

}

/* PROFILE */

.profile{

    display:flex;
    align-items:center;

    gap:14px;

}

.profile img{

    width:52px;
    height:52px;

    border-radius:50%;

    border:
    2px solid rgba(93,169,255,0.28);

    box-shadow:
    0 0 20px rgba(93,169,255,0.12);

}

.profile h3{

    color:#0f172a;

    font-size:16px;

}

.profile p{

    color:#64748b;

    font-size:13px;

}

/* =========================
   LOGOUT
========================= */

.sidebar-footer{

    margin-top:auto;

}

#logoutBtn{

    height:52px;

    border:none;

    border-radius:16px;

    background:
    rgba(255,255,255,0.72);

    color:#0f172a;

    display:flex;
    align-items:center;

    gap:12px;

    padding:0 18px;

    font-size:15px;

    cursor:pointer;

    transition:0.3s ease;

    border:
    1px solid rgba(15,23,42,0.08);

    backdrop-filter:blur(18px);

    box-shadow:
    0 10px 25px rgba(93,169,255,0.08);

}

#logoutBtn:hover{

    background:
    rgba(239,68,68,0.10);

    color:#ef4444;

    border-color:
    rgba(239,68,68,0.15);

    transform:
    translateY(-2px);

}

/* =========================
   RESPONSIVO
========================= */

@media(max-width:1100px){

    .menu a span{

        display:none;

    }

}

@media(max-width:768px){

    .sidebar{

        height:auto;

        padding:20px;

        flex-direction:column;

        gap:20px;

    }

    .main-content{

        margin-top:150px;

        padding:22px;

    }

    .page-header{

        flex-direction:column;

    }

    .page-title{

        font-size:42px;

    }

    .search-box{

        width:100%;

    }

    .menu{

        width:100%;

        justify-content:center;

        flex-wrap:wrap;

    }

}