body{
    background:#f1f5f9;
}

.laporan-hero{
    background:#f8fafc;
    padding:90px 0 70px;
    border-bottom:1px solid #e2e8f0;
}

.hero-badge{
    display:inline-flex;
    align-items:center;
    gap:10px;
    background:#dbeafe;
    color:#2563eb;
    padding:10px 18px;
    border-radius:999px;
    font-size:13px;
    font-weight:700;
    margin-bottom:24px;
}

.hero-title{
    font-size:58px;
    font-weight:800;
    line-height:1.1;
    color:#0f172a;
    margin-bottom:22px;
}

.hero-subtitle{
    max-width:760px;
    font-size:17px;
    line-height:1.9;
    color:#64748b;
}

.laporan-wrapper{
    padding:70px 0;
}

.stats-card{
    background:#fff;
    border-radius:28px;
    padding:32px;
    border:1px solid #e2e8f0;
    height:100%;
    box-shadow:0 12px 40px rgba(15,23,42,.05);
}

.stats-top{
    display:flex;
    justify-content:space-between;
    align-items:center;
}

.stats-label{
    font-size:12px;
    font-weight:800;
    letter-spacing:.14em;
    margin-bottom:14px;
}

.stats-label.blue{
    color:#2563eb;
}

.stats-label.orange{
    color:#f59e0b;
}

.stats-label.green{
    color:#16a34a;
}

.stats-number{
    font-size:64px;
    line-height:1;
    font-weight:800;
    color:#0f172a;
}

.stats-icon{
    width:84px;
    height:84px;
    border-radius:24px;
    display:flex;
    align-items:center;
    justify-content:center;
    font-size:34px;
}

.stats-icon.blue{
    background:#dbeafe;
    color:#2563eb;
}

.stats-icon.orange{
    background:#fef3c7;
    color:#f59e0b;
}

.stats-icon.green{
    background:#dcfce7;
    color:#16a34a;
}

.stats-divider{
    height:1px;
    background:#e2e8f0;
    margin:24px 0;
}

.stats-list{
    display:flex;
    flex-direction:column;
    gap:14px;
}

.stats-item{
    display:flex;
    justify-content:space-between;
    align-items:center;
    font-size:15px;
    color:#334155;
}

.stats-item .badge{
    min-width:38px;
    border-radius:999px;
    padding:7px 12px;
}

.chart-card{
    background:#fff;
    border-radius:28px;
    overflow:hidden;
    border:1px solid #e2e8f0;
    box-shadow:0 12px 40px rgba(15,23,42,.05);
}

.chart-header{
    padding:22px 28px;
    color:#fff;
}

.chart-header.primary{
    background:#2563eb;
}

.chart-header.warning{
    background:#f59e0b;
}

.chart-header h5{
    margin:0;
    font-size:18px;
    font-weight:700;
    display:flex;
    align-items:center;
    gap:10px;
}

.chart-body{
    height:360px;
    padding:24px;
}

.laporan-card{
    background:#fff;
    border-radius:28px;
    overflow:hidden;
    border:1px solid #e2e8f0;
    box-shadow:0 12px 40px rgba(15,23,42,.05);
}

.laporan-header{
    background:linear-gradient(135deg,#0f172a,#020617);
    padding:24px 30px;
    color:#fff;
}

.laporan-header h5{
    margin:0;
    font-size:20px;
    font-weight:700;
    display:flex;
    align-items:center;
    gap:12px;
}

.laporan-body{
    padding:10px 30px 24px;
}

.laporan-item{
    display:flex;
    align-items:center;
    gap:20px;
    padding:22px 0;
    border-bottom:1px solid #e2e8f0;
    text-decoration:none;
    transition:.2s ease;
}

.laporan-item:hover{
    transform:translateX(4px);
}

.laporan-item:last-child{
    border-bottom:none;
}

.laporan-icon{
    width:62px;
    height:62px;
    border-radius:20px;
    background:#fef2f2;
    color:#dc2626;
    display:flex;
    align-items:center;
    justify-content:center;
    font-size:28px;
    flex-shrink:0;
}

.laporan-content h6{
    margin:0 0 8px;
    font-size:18px;
    font-weight:700;
    color:#0f172a;
}

.laporan-content small{
    color:#64748b;
}

.empty-state{
    text-align:center;
    padding:70px 20px;
    color:#94a3b8;
}

.empty-state i{
    font-size:54px;
    margin-bottom:20px;
}

@media(max-width:768px){

    .hero-title{
        font-size:40px;
    }

    .stats-number{
        font-size:52px;
    }

    .stats-top{
        flex-direction:column;
        align-items:flex-start;
        gap:20px;
    }

    .chart-body{
        height:300px;
    }

}

.laporan-item{
    display:flex;
    gap:20px;
    padding:24px;
    border-bottom:1px solid #eef2f7;
    text-decoration:none;
    transition:.25s ease;
}

.laporan-item:hover{
    background:#f8fafc;
}

.laporan-icon{
    width:64px;
    height:64px;
    border-radius:18px;
    background:#fef2f2;
    color:#dc2626;
    display:flex;
    align-items:center;
    justify-content:center;
    font-size:24px;
    flex-shrink:0;
}

.laporan-content{
    flex:1;
}

.laporan-meta{
    display:flex;
    align-items:center;
    gap:14px;
    margin-bottom:10px;
    flex-wrap:wrap;
}

.laporan-badge{
    background:#dbeafe;
    color:#1d4ed8;
    padding:6px 12px;
    border-radius:999px;
    font-size:12px;
    font-weight:700;
}

.laporan-date{
    color:#64748b;
    font-size:13px;
}

.laporan-content h6{
    font-size:18px;
    font-weight:700;
    color:#0f172a;
    line-height:1.5;
    margin-bottom:10px;
}

.laporan-content p{
    color:#64748b;
    line-height:1.7;
    margin-bottom:14px;
}

.laporan-footer{
    display:flex;
    justify-content:space-between;
    align-items:center;
    gap:20px;
    flex-wrap:wrap;
}

.laporan-footer span{
    color:#475569;
    font-size:14px;
}

.laporan-link{
    color:#2563eb !important;
    font-weight:700;
}

.laporan-body{
    padding:0;
}

.laporan-item{
    display:flex;
    gap:24px;
    align-items:flex-start;
    padding:28px 32px;
    border-bottom:1px solid #edf2f7;
    text-decoration:none;
    transition:.25s ease;
    background:#fff;
}

.laporan-item:hover{
    background:#f8fafc;
}

.laporan-item:last-child{
    border-bottom:none;
}

.laporan-icon{
    width:68px;
    height:68px;
    border-radius:20px;
    background:#fef2f2;
    color:#dc2626;
    display:flex;
    align-items:center;
    justify-content:center;
    font-size:28px;
    flex-shrink:0;
}

.laporan-content{
    flex:1;
    min-width:0;
}

.laporan-meta-top{
    display:flex;
    align-items:center;
    gap:10px;
    flex-wrap:wrap;
    margin-bottom:14px;
}

.badge-kategori{
    background:#dbeafe;
    color:#1d4ed8;
    padding:7px 14px;
    border-radius:999px;
    font-size:12px;
    font-weight:700;
}

.badge-grup{
    background:#ecfdf3;
    color:#047857;
    padding:7px 14px;
    border-radius:999px;
    font-size:12px;
    font-weight:700;
}

.laporan-title{
    font-size:22px;
    line-height:1.5;
    font-weight:800;
    color:#0f172a;
    margin-bottom:14px;
}

.laporan-desc{
    color:#475569;
    line-height:1.8;
    font-size:15px;
    margin-bottom:18px;
}

.laporan-meta-bottom{
    display:flex;
    gap:18px;
    flex-wrap:wrap;
    align-items:center;
    color:#64748b;
    font-size:13px;
}

.format-badge{
    background:#111827;
    color:#fff;
    padding:6px 10px;
    border-radius:8px;
    font-size:11px;
    font-weight:700;
}

.laporan-arrow{
    width:46px;
    height:46px;
    border-radius:14px;
    background:#eff6ff;
    color:#2563eb;
    display:flex;
    align-items:center;
    justify-content:center;
    font-size:18px;
    flex-shrink:0;
    transition:.25s ease;
}

.laporan-item:hover .laporan-arrow{
    transform:translateX(4px);
}

@media(max-width:768px){

    .laporan-item{
        padding:22px;
        gap:18px;
    }

    .laporan-title{
        font-size:18px;
    }

    .laporan-meta-bottom{
        gap:12px;
    }

}