/* =====================================================
   SIP SMEKES — Stylesheet
   ===================================================== */
*,*::before,*::after{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:smooth}
body{font-family:'Inter',sans-serif;background:#f1f5f9;color:#0f172a;min-height:100vh}
::selection{background:rgba(37,99,235,.15);color:#2563eb}
::-webkit-scrollbar{width:4px;height:4px}
::-webkit-scrollbar-track{background:transparent}
::-webkit-scrollbar-thumb{background:#cbd5e1;border-radius:10px}

/* --- Sidebar Links (dipakai oleh inline sidebar) --- */
.sidebar-link{display:flex;align-items:center;gap:10px;padding:11px 14px;border-radius:10px;color:rgba(255,255,255,.45);font-size:13px;text-decoration:none;-webkit-tap-highlight-color:transparent;transition:background .15s,color .15s;font-weight:500}
.sidebar-link:active{background:rgba(255,255,255,.1)}
.sidebar-link.active{background:rgba(255,255,255,.08);color:white;font-weight:600;border-right:3px solid #f97316}
.sidebar-link.disabled{opacity:.25;cursor:default}
.sidebar-link.disabled:active{background:none}
.sb-icon{font-size:16px;width:22px;text-align:center;flex-shrink:0;line-height:1}

/* --- Topbar --- */
.topbar{height:52px;background:white;border-bottom:1px solid #e2e8f0;display:flex;align-items:center;justify-content:space-between;padding:0 12px;margin:-14px -14px 14px -14px;position:sticky;top:0;z-index:50;box-shadow:0 1px 3px rgba(0,0,0,.04)}
.topbar-left{display:flex;align-items:center;gap:8px;min-width:0;flex:1}
.topbar-menu-btn{width:38px;height:38px;border:1px solid #e2e8f0;background:white;border-radius:9px;cursor:pointer;display:flex;align-items:center;justify-content:center;color:#334155;font-size:18px;font-weight:700;flex-shrink:0;-webkit-tap-highlight-color:transparent;line-height:1}
.topbar-menu-btn:active{background:#f1f5f9}
.topbar-title{font-family:'Space Grotesk',sans-serif;font-size:15px;font-weight:700;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.topbar-breadcrumb{font-size:10px;color:#94a3b8;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;display:none}
.topbar-right{display:flex;align-items:center;gap:6px;flex-shrink:0}
.topbar-logout-btn{width:38px;height:38px;border:1px solid #e2e8f0;background:white;border-radius:9px;display:flex;align-items:center;justify-content:center;color:#64748b;-webkit-tap-highlight-color:transparent;text-decoration:none;line-height:1}
.topbar-logout-btn:active{background:#fef2f2;border-color:#fca5a5}

/* --- Main Content --- */
.main-content{padding:14px;min-height:100vh;min-height:100dvh}

/* --- Cards --- */
.card{background:white;border-radius:14px;border:1px solid #e2e8f0;overflow:hidden;margin-bottom:14px}
.card-header{padding:12px 14px;border-bottom:1px solid #f1f5f9;display:flex;align-items:center;justify-content:space-between;gap:8px}
.card-title{font-family:'Space Grotesk',sans-serif;font-size:13px;font-weight:700}
.card-empty{padding:32px 16px;text-align:center;color:#94a3b8;font-size:12px}
.card-placeholder{background:#f8fafc;border:2px dashed #e2e8f0;display:flex;flex-direction:column;align-items:center;justify-content:center;padding:20px;text-align:center;opacity:.5}
.placeholder-icon{font-size:24px;margin-bottom:4px}
.placeholder-cards{display:grid;grid-template-columns:1fr;gap:10px;margin-top:14px}
.placeholder-cards h4{font-size:12px;font-weight:600;color:#475569;margin-bottom:2px}
.placeholder-cards p{font-size:10px;color:#94a3b8}

/* --- Stats --- */
.stats-grid{display:grid;grid-template-columns:1fr 1fr;gap:8px;margin-bottom:14px}
.stat-card{background:white;border-radius:12px;border:1px solid #e2e8f0;padding:12px;display:flex;align-items:center;gap:10px}
.stat-icon{width:34px;height:34px;border-radius:9px;display:flex;align-items:center;justify-content:center;flex-shrink:0;font-size:16px}
.stat-icon.blue{background:#eff6ff;color:#2563eb}
.stat-icon.green{background:#dcfce7;color:#22c55e}
.stat-icon.orange{background:#fff7ed;color:#f97316}
.stat-icon.red{background:#fef2f2;color:#ef4444}
.stat-icon.purple{background:#faf5ff;color:#7c3aed}
.stat-info{display:flex;flex-direction:column;min-width:0}
.stat-value{font-family:'Space Grotesk',sans-serif;font-size:15px;font-weight:700;line-height:1.2;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.stat-label{font-size:10px;color:#94a3b8;margin-top:1px}

/* --- Welcome --- */
.welcome-card{background:linear-gradient(135deg,#2563eb,#4f46e5);border-radius:14px;padding:16px 18px;color:white;display:flex;align-items:center;justify-content:space-between;margin-bottom:14px;flex-wrap:wrap;gap:10px}
.welcome-title{font-family:'Space Grotesk',sans-serif;font-size:16px;font-weight:700}
.welcome-sub{font-size:11px;color:rgba(255,255,255,.55);margin-top:2px}

/* --- Tables --- */
.table-wrap{overflow-x:auto;-webkit-overflow-scrolling:touch;margin:-1px;padding:1px}
.data-table{width:100%;border-collapse:collapse;font-size:11px;min-width:480px}
.data-table thead{background:#f8fafc}
.data-table th{padding:8px 12px;text-align:left;font-size:9px;font-weight:700;text-transform:uppercase;letter-spacing:.06em;color:#94a3b8;border-bottom:1px solid #e2e8f0;white-space:nowrap}
.data-table td{padding:8px 12px;border-bottom:1px solid #f1f5f9}
.text-muted{color:#64748b}.text-success{color:#16a34a}.text-danger{color:#dc2626}
.font-mono{font-family:'JetBrains Mono',monospace;font-size:10px}.font-medium{font-weight:600}

/* --- Badges --- */
.badge{display:inline-block;padding:2px 7px;border-radius:999px;font-size:9px;font-weight:600;white-space:nowrap}
.badge-success{background:#dcfce7;color:#16a34a}
.badge-danger{background:#fee2e2;color:#dc2626}
.badge-warning{background:#fef9c3;color:#ca8a04}
.badge-neutral{background:#f1f5f9;color:#475569}

/* --- Buttons --- */
.btn{display:inline-flex;align-items:center;gap:5px;padding:8px 14px;border-radius:9px;font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.04em;border:none;cursor:pointer;text-decoration:none;font-family:'Inter',sans-serif;white-space:nowrap;-webkit-tap-highlight-color:transparent}
.btn-primary{background:#2563eb;color:white}.btn-primary:active{background:#1d4ed8}
.btn-accent{background:#f97316;color:white}.btn-accent:active{background:#ea580c}
.btn-danger{background:#ef4444;color:white}.btn-danger:active{background:#dc2626}
.btn-ghost{background:transparent;color:#64748b;border:1px solid #e2e8f0}.btn-ghost:active{background:#f1f5f9}
.btn-sm{padding:5px 10px;font-size:10px}

/* --- Forms --- */
.form-grid{padding:16px;display:grid;grid-template-columns:1fr;gap:12px}
.form-group{display:flex;flex-direction:column}
.form-label{display:block;font-size:10px;font-weight:700;text-transform:uppercase;letter-spacing:.06em;color:#64748b;margin-bottom:4px}
.form-input{width:100%;padding:10px 12px;border:1px solid #e2e8f0;border-radius:9px;font-size:14px;outline:none;font-family:'Inter',sans-serif;background:white;-webkit-appearance:none}
.form-input:focus{border-color:#2563eb;box-shadow:0 0 0 3px rgba(37,99,235,.1)}
textarea.form-input{resize:vertical;min-height:60px}
.form-hint{font-size:10px;color:#94a3b8;margin-top:2px;line-height:1.4}
.form-divider{height:1px;background:#e2e8f0;margin:4px 0}

/* --- Profile --- */
.profile-grid{padding:14px;display:grid;grid-template-columns:1fr 1fr;gap:8px}
.profile-item{display:flex;flex-direction:column}
.profile-label{font-size:9px;font-weight:700;text-transform:uppercase;letter-spacing:.06em;color:#94a3b8;margin-bottom:1px}
.profile-value{font-size:12px;font-weight:600;word-break:break-word}

/* --- Alerts --- */
.alert{padding:10px 12px;border-radius:9px;font-size:12px;font-weight:500;margin-bottom:14px;line-height:1.4}
.alert-success{background:#dcfce7;color:#166534;border:1px solid #86efac}
.alert-danger{background:#fee2e2;color:#991b1b;border:1px solid #fca5a5}
.alert-info{background:#dbeafe;color:#1e40af;border:1px solid #93c5fd}

/* =============== DESKTOP ≥769px =============== */
@media(min-width:769px){
.main-content{margin-left:264px;padding:24px}
.topbar{height:64px;padding:0 24px;margin:-24px -24px 24px -24px;box-shadow:none}
.topbar-title{font-size:18px}
.topbar-breadcrumb{display:block}
.stats-grid{grid-template-columns:repeat(4,1fr);gap:14px}
.stat-card{padding:18px;gap:14px}
.stat-value{font-size:22px}
.stat-label{font-size:12px}
.welcome-card{padding:24px 28px}
.welcome-title{font-size:20px}
.form-grid{grid-template-columns:1fr 1fr;gap:16px;padding:24px}
.form-group.full{grid-column:1/-1}
.form-input{font-size:13px}
.profile-grid{grid-template-columns:1fr 1fr 1fr;gap:12px;padding:20px}
.profile-value{font-size:13px}
.card{margin-bottom:20px;border-radius:16px}
.card-header{padding:18px 22px}
.card-title{font-size:14px}
.card-empty{padding:48px 24px;font-size:13px}
.placeholder-cards{grid-template-columns:1fr 1fr}
.data-table{font-size:13px;min-width:auto}
.data-table th{padding:12px 18px;font-size:10px}
.data-table td{padding:12px 18px}
.font-mono{font-size:12px}
.badge{font-size:11px;padding:3px 10px}
.btn{padding:10px 20px;font-size:12px}
.placeholder-icon{font-size:32px}
.card-placeholder{padding:32px}
}

/* =============== TABLET =============== */
@media(min-width:769px) and (max-width:1024px){
.stats-grid{grid-template-columns:repeat(2,1fr)}
.form-grid{grid-template-columns:1fr 1fr}
}

/* =============== SMALL PHONE ≤360px =============== */
@media(max-width:360px){
.stats-grid{gap:6px}
.stat-card{padding:10px;gap:8px}
.stat-icon{width:28px;height:28px;border-radius:7px;font-size:14px}
.stat-value{font-size:13px}
.stat-label{font-size:9px}
.welcome-title{font-size:14px}
.topbar-title{font-size:14px}
}

/* =============== PRINT =============== */
@media print{
.no-print,.sidebar,.sidebar-overlay,.topbar{display:none!important}
.main-content{margin-left:0!important;padding:0!important}
body{background:white}
.card{border:1px solid #ddd;break-inside:avoid}
}