/* ============================================================
   DevPortal — Pages (Dashboard, Layanan)
   ============================================================ */

/* ---------- Stat cards ---------- */
.stat-grid { display: grid; grid-template-columns: repeat(4, 1fr); gap: var(--space-4); margin-bottom: var(--space-5); }
.stat-card { padding: var(--space-4) var(--space-5); display: flex; flex-direction: column; gap: 2px; }
.stat-top { display: flex; align-items: center; justify-content: space-between; margin-bottom: var(--space-2); }
.stat-ico { width: 34px; height: 34px; border-radius: var(--r-sm); display: flex; align-items: center; justify-content: center; }
.stat-ico svg { width: 18px; height: 18px; }
.stat-trend { display: inline-flex; align-items: center; gap: 3px; font-size: 10px; font-weight: 700; color: var(--ok); background: var(--ok-bg); padding: 2px 6px; border-radius: 999px; }
.stat-trend svg { width: 11px; height: 11px; }
.stat-val { font-size: 26px; font-weight: 800; letter-spacing: -.02em; line-height: 1.1; }
.stat-label { font-size: var(--fs-sm); font-weight: 700; color: var(--text); }
.stat-sub { font-size: var(--fs-2xs); color: var(--text-3); }

/* ---------- Dashboard grid ---------- */
.dash-grid { display: grid; grid-template-columns: 1.7fr 1fr; gap: var(--space-5); align-items: start; }
@media (max-width: 1080px) { .dash-grid { grid-template-columns: 1fr; } .stat-grid { grid-template-columns: repeat(2, 1fr); } }

/* ---------- Launcher ---------- */
.launcher-grid { display: grid; grid-template-columns: repeat(4, 1fr); gap: var(--space-3); padding: var(--space-4); }
@media (max-width: 1380px) { .launcher-grid { grid-template-columns: repeat(3, 1fr); } }
@media (max-width: 560px) { .launcher-grid { grid-template-columns: repeat(2, 1fr); } }
.launch-card {
  position: relative; overflow: hidden; display: flex; flex-direction: column; gap: var(--space-3);
  padding: var(--space-4); text-align: left; border: 1px solid var(--border); border-radius: var(--r-lg);
  background: var(--surface); cursor: pointer; transition: transform .14s, box-shadow .14s, border-color .14s;
}
.launch-card:hover { transform: translateY(-3px); box-shadow: var(--shadow-md); border-color: color-mix(in srgb, var(--app-c) 45%, var(--border)); }
.launch-card.offline { opacity: .58; cursor: not-allowed; }
.launch-card.offline:hover { transform: none; box-shadow: none; }
.launch-glow { position: absolute; top: -40px; right: -40px; width: 90px; height: 90px; border-radius: 50%; background: var(--app-c); opacity: 0; filter: blur(30px); transition: opacity .2s; }
.launch-card:hover .launch-glow { opacity: .22; }
.launch-meta { display: flex; flex-direction: column; gap: 2px; min-width: 0; }
.launch-name { display: flex; align-items: center; gap: 5px; font-size: var(--fs-sm); font-weight: 700; color: var(--text); }
.launch-ext { width: 12px; height: 12px; color: var(--text-3); opacity: 0; transition: opacity .15s; }
.launch-card:hover .launch-ext { opacity: 1; }
.launch-cat { font-size: var(--fs-2xs); color: var(--text-3); }
.launch-foot { display: flex; align-items: center; justify-content: space-between; gap: var(--space-2); }

/* ---------- Activity ---------- */
.activity-list { padding: var(--space-2); }
.activity-row { display: flex; align-items: center; gap: var(--space-3); padding: var(--space-2) var(--space-3); border-radius: var(--r-sm); transition: background .1s; }
.activity-row:hover { background: var(--surface-2); }
.activity-text { font-size: var(--fs-sm); color: var(--text-2); }
.activity-text b { color: var(--text); font-weight: 700; }
.activity-time { font-size: var(--fs-2xs); color: var(--text-3); }
.activity-ico { width: 28px; height: 28px; border-radius: 8px; display: flex; align-items: center; justify-content: center; flex-shrink: 0; }
.activity-ico svg { width: 15px; height: 15px; }

/* ---------- Integration list ---------- */
.integ-list { padding: var(--space-2); display: flex; flex-direction: column; }
.integ-row { display: flex; align-items: center; gap: var(--space-3); padding: var(--space-2) var(--space-3); border-radius: var(--r-sm); transition: background .1s; }
.integ-row:hover { background: var(--surface-2); }
.integ-name { display: block; font-size: var(--fs-sm); font-weight: 700; }
.integ-sync { display: block; font-size: var(--fs-2xs); color: var(--text-3); }

/* ---------- Security widget ---------- */
.sec-ring-row { display: flex; align-items: center; gap: var(--space-5); }
.sec-ring { width: 76px; height: 76px; border-radius: 50%; flex-shrink: 0; display: flex; align-items: center; justify-content: center;
  background: conic-gradient(var(--accent) calc(var(--pct) * 1%), var(--surface-3) 0); position: relative; }
.sec-ring::before { content: ""; position: absolute; inset: 9px; border-radius: 50%; background: var(--surface); }
.sec-ring span { position: relative; font-size: var(--fs-md); font-weight: 800; }
.sec-stats { display: grid; grid-template-columns: repeat(3, 1fr); gap: var(--space-3); }
.sec-stat { display: flex; align-items: center; gap: var(--space-2); }
.sec-stat svg { width: 18px; height: 18px; flex-shrink: 0; }
.sec-stat b { display: block; font-size: var(--fs-md); font-weight: 800; line-height: 1.1; }
.sec-stat span { font-size: 10px; color: var(--text-3); }

/* ---------- Layanan catalog ---------- */
.cat-toolbar { display: flex; align-items: center; gap: var(--space-3); margin-bottom: var(--space-4); flex-wrap: wrap; }
.cat-toolbar .input-group { width: min(280px, 100%); }
.chip-filter { display: flex; gap: var(--space-2); flex-wrap: wrap; }
.chip { display: inline-flex; align-items: center; gap: 6px; height: 30px; padding: 0 var(--space-3); border: 1px solid var(--border-strong); background: var(--surface); border-radius: 999px; font-size: var(--fs-xs); font-weight: 600; color: var(--text-2); cursor: pointer; transition: all .12s; }
.chip:hover { border-color: var(--text-3); color: var(--text); }
.chip[data-on="1"] { background: var(--accent); border-color: var(--accent); color: #fff; }
.chip .chip-c { width: 8px; height: 8px; border-radius: 50%; }
.chip .chip-n { font-size: 10px; opacity: .7; }

.svc-grid { display: grid; grid-template-columns: repeat(auto-fill, minmax(280px, 1fr)); gap: var(--space-4); }
.svc-card { display: flex; flex-direction: column; padding: var(--space-4); border: 1px solid var(--border); border-radius: var(--r-lg); background: var(--surface); transition: box-shadow .14s, transform .14s, border-color .14s; }
.svc-card:hover { box-shadow: var(--shadow-md); transform: translateY(-2px); border-color: var(--border-strong); }
.svc-top { display: flex; align-items: flex-start; gap: var(--space-3); margin-bottom: var(--space-3); }
.svc-title { font-size: var(--fs-md); font-weight: 700; display: flex; align-items: center; gap: 6px; }
.svc-url { font-size: var(--fs-2xs); color: var(--text-3); font-family: var(--font-mono); }
.svc-desc { font-size: var(--fs-xs); color: var(--text-2); line-height: 1.5; margin-bottom: var(--space-3); min-height: 32px; }
.svc-tags { display: flex; align-items: center; gap: var(--space-2); flex-wrap: wrap; margin-bottom: var(--space-3); }
.svc-foot { display: flex; align-items: center; justify-content: space-between; gap: var(--space-2); margin-top: auto; padding-top: var(--space-3); border-top: 1px solid var(--border); }
.svc-role { display: inline-flex; align-items: center; gap: 5px; font-size: var(--fs-2xs); color: var(--text-2); font-weight: 600; }
.svc-role .avatar { width: 18px; height: 18px; font-size: 8px; }

.list-toggle { display: flex; gap: var(--space-2); align-items: center; }
