:root{
  --bg:#ffffff; --fg:#0f172a; --muted:#64748b; --line:#e2e8f0;
  --primary:#0b57d0; --primary-ink:#ffffff;
  --card:#ffffff; --soft:#f8fafc;
  --radius:12px; --pad:12px; --shadow:0 6px 20px rgba(2,6,23,.08);
}
@media (prefers-color-scheme: dark){
  :root{ --bg:#0b1220; --fg:#e6edf5; --muted:#93a2b8; --line:#1f2a44; --card:#0f172a; --soft:#0c1426;
         --primary:#4c8dff; --primary-ink:#0b1220; --shadow:0 8px 28px rgba(0,0,0,.4); }
}
*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{margin:0;background:var(--bg);color:var(--fg);font:15.5px/1.7 system-ui,-apple-system,Segoe UI,Roboto,Ubuntu,Noto Sans,Helvetica,Arial}
a{color:var(--primary)}
.container{max-width:100%;padding:0 var(--pad);margin:0 auto}
main{padding:18px 0}

/* Header */
.skip-link{position:absolute;left:-9999px;top:auto;width:1px;height:1px;overflow:hidden}
.skip-link:focus{position:fixed;left:12px;top:12px;width:auto;height:auto;background:var(--primary);color:var(--primary-ink);padding:8px 12px;border-radius:10px;z-index:1000}
header.site{position:sticky;top:0;z-index:50;background:var(--card);border-bottom:1px solid var(--line)}
.site-bar{display:flex;align-items:center;justify-content:space-between;gap:12px;padding:10px 0}
.brand a{color:inherit;text-decoration:none;font-weight:700}
nav.main{display:flex;gap:10px;flex-wrap:wrap}
nav.main a{padding:7px 10px;border-radius:10px;text-decoration:none;color:inherit}
nav.main a:hover, nav.main a:focus{background:var(--soft)}
.nav-toggle{display:none}
@media (max-width:860px){
  .nav-toggle{display:inline-flex;align-items:center;gap:6px;padding:7px 10px;border:1px solid var(--line);border-radius:10px;background:var(--soft);cursor:pointer}
  nav.main{display:none;width:100%}
  .nav-open nav.main{display:flex;flex-direction:column;padding:8px 0}
}

/* Cards/Buttons/Forms */
.card{background:var(--card);border:1px solid var(--line);border-radius:var(--radius)}
.card:not(.flat){padding:12px}
.card:hover{box-shadow:var(--shadow)}
.btn{display:inline-flex;align-items:center;gap:6px;padding:8px 12px;border:1px solid var(--line);border-radius:10px;background:var(--soft);color:inherit;text-decoration:none;cursor:pointer}
.btn.primary{background:var(--primary);color:var(--primary-ink);border-color:var(--primary)}
.btn.danger{background:#ef4444;color:#fff;border-color:#ef4444}
.btn:focus-visible{outline:3px solid color-mix(in oklab, var(--primary) 60%, transparent);outline-offset:2px}
input[type=text],input[type=password],input[type=url],input[type=number],textarea,select{width:100%;padding:10px;border:1px solid var(--line);border-radius:10px;background:var(--card);color:inherit}
textarea{min-height:160px}

/* Listing grid */
.grid-2{display:grid;gap:12px;grid-template-columns:1fr}
@media(min-width:900px){.grid-2{grid-template-columns:repeat(2,minmax(0,1fr));align-items:stretch}}
.post-card{display:flex;flex-direction:column;height:100%;border:1px solid var(--line);border-radius:var(--radius);background:var(--card);overflow:hidden}
.post-card:hover{box-shadow:var(--shadow)}
.post-thumb{position:relative;aspect-ratio:16/9;background:var(--soft);overflow:hidden}
.post-thumb img{width:100%;height:100%;object-fit:cover;display:block}
.post-body{padding:12px}
.post-title{margin:0 0 4px 0;font-size:clamp(18px,2.6vw,20px);line-height:1.35}
.post-meta{font-size:13px;opacity:.8;margin:6px 0 8px}
.post-excerpt{margin-top:4px;text-align:justify;text-justify:inter-word;display:-webkit-box;-webkit-line-clamp:4;-webkit-box-orient:vertical;overflow:hidden}
.badge,.badge-cat{display:inline-block;border:1px solid var(--line);border-radius:999px;padding:2px 8px;font-size:12px;margin-right:6px}

/* Article */
.article-wrap{max-width:820px;margin:0 auto}
.entry-content p{text-align:justify;text-justify:inter-word}
.entry-content img{border-radius:10px}

/* Tables & pagination */
.table-wrap{width:100%;overflow:auto}
table{border-collapse:collapse;width:100%;background:var(--card)}
th,td{border:1px solid var(--line);padding:9px 10px;text-align:left;vertical-align:top}
th{background:var(--soft);font-weight:600}
.pagination{display:flex;gap:8px;flex-wrap:wrap;margin-top:12px}
.pagination a,.pagination span{padding:6px 10px;border:1px solid var(--line);border-radius:8px;text-decoration:none;color:inherit}
.pagination .active{background:var(--primary);color:var(--primary-ink);border-color:var(--primary)}
.pager{display:flex;gap:8px;flex-wrap:wrap;margin-top:8px}

/* Footer & misc */
footer.site{border-top:1px solid var(--line);padding:18px 0;margin-top:28px;font-size:13px;opacity:.9}
.alert{background:var(--soft);border:1px solid var(--line);border-radius:var(--radius);padding:10px;margin:8px 0}
blockquote{border-left:3px solid var(--line);margin:12px 0;padding:8px 12px;color:var(--muted)}
.focus-ring:focus-visible{outline:3px solid color-mix(in oklab, var(--primary) 60%, transparent);outline-offset:2px}

/* ==== Tambahan kecil: di mobile, paragraf tidak di-justify agar baris tidak pecah ==== */
@media (max-width: 768px){
  .entry-content p{ text-align:left; text-justify:auto; }
}
