:root{--green:#047a34;--green2:#0e9447;--dark:#073b20;--bg:#f4f7f6;--text:#13202b;--muted:#667085;--border:#e3e8ef;--card:#fff;--danger:#b42318;--warn:#b54708}*{box-sizing:border-box}body{margin:0;font-family:Inter,system-ui,-apple-system,Segoe UI,Arial,sans-serif;color:var(--text);background:var(--bg)}a{color:inherit}.app{display:flex;min-height:100vh}.sidebar{width:270px;background:#063b20;color:#fff;padding:24px 18px;position:fixed;inset:0 auto 0 0;overflow:auto}.brand{display:flex;gap:12px;align-items:center;margin-bottom:28px}.brand-logo{width:48px;height:48px;object-fit:contain;background:#fff;border-radius:14px;padding:4px}.brand-mark{width:56px;height:56px;border-radius:16px;background:linear-gradient(135deg,#24b15a,#7bd121);display:grid;place-items:center;font-weight:800;color:#fff}.brand span{display:block;font-size:13px;opacity:.8}.sidebar nav a{display:block;text-decoration:none;padding:12px 14px;border-radius:12px;margin:4px 0;font-weight:650;font-size:14px}.sidebar nav a:hover,.sidebar nav a.active{background:rgba(255,255,255,.12)}.main{margin-left:270px;padding:24px;width:calc(100% - 270px)}.topbar{display:flex;align-items:center;justify-content:space-between;background:#fff;border-radius:22px;padding:18px 22px;margin-bottom:18px}.topbar h1{margin:0;font-size:24px}.topbar p{margin:4px 0 0;color:var(--muted)}.pill{padding:10px 16px;border-radius:999px;background:#ecfdf3;color:#027a48;font-weight:700}.hero{background:linear-gradient(135deg,var(--green),var(--green2));color:#fff;border-radius:24px;padding:28px 30px;margin-bottom:18px}.hero h2{font-size:32px;margin:0 0 8px}.grid{display:grid;gap:14px}.grid-2{grid-template-columns:repeat(2,minmax(0,1fr))}.grid-3{grid-template-columns:repeat(3,minmax(0,1fr))}.grid-4{grid-template-columns:repeat(4,minmax(0,1fr))}.card{background:#fff;border:1px solid var(--border);border-radius:18px;padding:18px;box-shadow:0 10px 30px rgba(16,24,40,.06)}.stat b{display:block;color:var(--green);font-size:34px;margin-top:6px}.stat span{color:var(--muted)}.table-wrap{overflow:auto}.table{width:100%;border-collapse:collapse;background:#fff}.table th,.table td{border-bottom:1px solid var(--border);padding:12px;text-align:left;vertical-align:top}.table th{background:#f8fafc;font-size:13px}.form{display:grid;gap:12px}.form-row{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:12px}label{font-weight:700;font-size:14px}input,select,textarea{width:100%;padding:11px 12px;border:1px solid #cfd8e3;border-radius:12px;background:#fff;font:inherit}textarea{min-height:88px}.btn,button{border:0;border-radius:12px;background:var(--green);color:#fff;padding:11px 16px;font-weight:800;cursor:pointer;text-decoration:none;display:inline-block}.btn.secondary{background:#eef2f6;color:#182230}.btn.danger{background:var(--danger)}.actions{display:flex;gap:8px;align-items:center;flex-wrap:wrap}.alert{padding:12px 14px;border-radius:12px;margin:12px 0;background:#ecfdf3;color:#027a48}.alert.danger{background:#fef3f2;color:var(--danger)}.alert.warning{background:#fffaeb;color:var(--warn)}.login-body{min-height:100vh;display:grid;place-items:center;background:linear-gradient(135deg,#03451f,#0b7a35)}.login-card{width:min(420px,92vw);background:#fff;padding:34px;border-radius:26px;box-shadow:0 30px 80px rgba(0,0,0,.2);display:grid;gap:12px}.login-card h1{margin:0;font-size:32px}.login-card p{margin:0 0 8px;color:var(--muted)}.print-only{display:none}@media(max-width:900px){.sidebar{position:static;width:100%;height:auto}.app{display:block}.main{margin:0;width:100%;padding:14px}.grid-2,.grid-3,.grid-4,.form-row{grid-template-columns:1fr}.topbar{display:block}.pill{display:inline-block;margin-top:12px}}@media print{.sidebar,.topbar,.no-print,.btn,button{display:none!important}.main{margin:0;width:100%;padding:0}.card{box-shadow:none;border:0}.print-only{display:block}body{background:#fff}.table th,.table td{font-size:12px;padding:7px}}

:root {
    --sidebar-width: 260px;
    --primary: #2563eb;
    --dark: #111827;
    --muted: #6b7280;
    --border: #e5e7eb;
    --bg: #f3f4f6;
    --white: #ffffff;
    --danger: #dc2626;
}

* {
    box-sizing: border-box;
}

html,
body {
    margin: 0;
    min-height: 100%;
    font-family: Arial, sans-serif;
    background: var(--bg);
    color: var(--dark);
}

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

.sidebar {
    width: var(--sidebar-width);
    min-width: var(--sidebar-width);
    background: #0f172a;
    color: #ffffff;
    min-height: 100vh;
    position: fixed;
    inset: 0 auto 0 0;
    z-index: 1000;
    overflow-y: auto;
    transition: transform 0.25s ease;
}

.brand {
    display: flex;
    align-items: center;
    gap: 12px;
    padding: 20px;
    border-bottom: 1px solid rgba(255,255,255,0.12);
}

.brand-mark {
    width: 42px;
    height: 42px;
    border-radius: 12px;
    background: #2563eb;
    color: #ffffff;
    display: flex;
    align-items: center;
    justify-content: center;
    font-weight: 700;
}

.brand strong,
.brand small {
    display: block;
}

.brand small {
    color: #cbd5e1;
    margin-top: 3px;
}

.menu {
    padding: 12px;
}

.menu a {
    display: block;
    padding: 12px 14px;
    margin-bottom: 6px;
    color: #e5e7eb;
    text-decoration: none;
    border-radius: 10px;
    font-size: 14px;
}

.menu a:hover,
.menu a.active {
    background: #2563eb;
    color: #ffffff;
}

.main {
    flex: 1;
    margin-left: var(--sidebar-width);
    min-width: 0;
}

.topbar {
    min-height: 74px;
    background: #ffffff;
    border-bottom: 1px solid var(--border);
    padding: 14px 24px;
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 16px;
    position: sticky;
    top: 0;
    z-index: 900;
}

.topbar-left {
    display: flex;
    align-items: center;
    gap: 14px;
    min-width: 0;
}

.topbar h1 {
    margin: 0;
    font-size: 22px;
    line-height: 1.2;
}

.topbar p {
    margin: 4px 0 0;
    color: var(--muted);
    font-size: 14px;
}

.sidebar-toggle {
    display: none;
    width: 42px;
    height: 42px;
    border: 1px solid var(--border);
    border-radius: 10px;
    background: #ffffff;
    color: #111827;
    font-size: 22px;
    cursor: pointer;
}

.userbox {
    display: flex;
    align-items: center;
    gap: 12px;
    text-align: right;
    white-space: nowrap;
}

.userbox strong,
.userbox small {
    display: block;
}

.userbox small {
    color: var(--muted);
}

.content {
    padding: 24px;
}

.sidebar-overlay {
    display: none;
}

/* Komponen umum agar responsive */
.card,
.panel,
.box {
    background: #ffffff;
    border: 1px solid var(--border);
    border-radius: 16px;
    padding: 18px;
    margin-bottom: 18px;
}

.grid,
.stats-grid {
    display: grid;
    grid-template-columns: repeat(4, minmax(0, 1fr));
    gap: 16px;
}

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

.table-responsive {
    width: 100%;
    overflow-x: auto;
}

table {
    width: 100%;
    border-collapse: collapse;
    background: #ffffff;
}

th,
td {
    padding: 10px 12px;
    border-bottom: 1px solid var(--border);
    text-align: left;
    vertical-align: top;
}

th {
    background: #f9fafb;
    font-weight: 700;
}

input,
select,
textarea,
button {
    max-width: 100%;
}

input,
select,
textarea {
    width: 100%;
    padding: 10px 12px;
    border: 1px solid var(--border);
    border-radius: 10px;
}

.btn,
button {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: 6px;
    padding: 10px 14px;
    border-radius: 10px;
    border: 0;
    background: var(--primary);
    color: #ffffff;
    text-decoration: none;
    cursor: pointer;
}

.btn.small {
    padding: 8px 10px;
    font-size: 13px;
}

.btn.danger,
button.danger {
    background: var(--danger);
}

.alert {
    padding: 12px 14px;
    border-radius: 10px;
    margin-bottom: 14px;
}

.alert.danger {
    background: #fee2e2;
    color: #991b1b;
}

/* Tablet */
@media (max-width: 1024px) {
    .grid,
    .stats-grid {
        grid-template-columns: repeat(2, minmax(0, 1fr));
    }

    .content {
        padding: 18px;
    }
}

/* Mobile */
@media (max-width: 768px) {
    .sidebar {
        transform: translateX(-100%);
        box-shadow: 8px 0 24px rgba(0,0,0,0.25);
    }

    body.sidebar-open .sidebar {
        transform: translateX(0);
    }

    .sidebar-overlay {
        display: none;
        position: fixed;
        inset: 0;
        background: rgba(15, 23, 42, 0.55);
        z-index: 999;
    }

    body.sidebar-open .sidebar-overlay {
        display: block;
    }

    .main {
        margin-left: 0;
        width: 100%;
    }

    .sidebar-toggle {
        display: inline-flex;
        align-items: center;
        justify-content: center;
    }

    .topbar {
        padding: 12px 14px;
        align-items: flex-start;
    }

    .topbar h1 {
        font-size: 18px;
    }

    .topbar p {
        font-size: 12px;
    }

    .userbox {
        gap: 8px;
        font-size: 12px;
    }

    .userbox div {
        display: none;
    }

    .content {
        padding: 14px;
    }

    .grid,
    .stats-grid,
    .form-grid {
        grid-template-columns: 1fr;
    }

    .card,
    .panel,
    .box {
        padding: 14px;
        border-radius: 14px;
    }

    table {
        min-width: 720px;
    }
}

/* HP kecil */
@media (max-width: 480px) {
    .topbar {
        gap: 8px;
    }

    .sidebar-toggle {
        width: 38px;
        height: 38px;
    }

    .btn.small {
        padding: 7px 9px;
        font-size: 12px;
    }

    .content {
        padding: 10px;
    }
}