:root{
  --bg:#ffffff;
  --fg:#0f172a;
  --muted:#64748b;
  --border:#e2e8f0;
  --accent:#2563eb;
  --accent-fg:#ffffff;
  --callout:#f8fafc;
  --code-bg:#0b1220;
  --code-fg:#e2e8f0;
}
/*
@media (prefers-color-scheme: dark){
  :root{
    --bg:#0b1220;
    --fg:#e2e8f0;
    --muted:#94a3b8;
    --border:#1f2937;
    --accent:#3b82f6;
    --accent-fg:#0b1220;
    --callout:#0f172a;
    --code-bg:#0f172a;
    --code-fg:#cbd5e1;
  }
}
*/

.page-static{padding:24px 16px;}
.page-wrap{
  display:grid;
  grid-template-columns: 280px minmax(0,1fr);
  gap:32px;
}
@media (max-width: 992px){
  .page-wrap{grid-template-columns: 1fr;}
  .page-aside{order:2;}
}

.page-aside{
  position: sticky;
  top: 90px;
  height: fit-content;
}
.aside-card{
  border:1px solid var(--border);
  border-radius:14px;
  padding:16px;
  background:var(--bg);
}
.aside-title{
  font-size:13px;
  font-weight:700;
  letter-spacing:.02em;
  color:var(--muted);
  text-transform: uppercase;
  margin-bottom:8px;
}
.aside-section{margin-bottom:16px;}
.aside-section.meta .meta-row{
  display:flex; justify-content:space-between; gap:12px;
  padding:6px 0; border-bottom:1px dashed var(--border);
}
.aside-section.meta .meta-row:last-child{border-bottom:0;}
.meta-label{color:var(--muted); font-size:12px;}

.toc{max-height:50vh; overflow:auto; padding-right:8px;}
.toc ul{list-style:none; margin:0; padding:0;}
.toc li{margin:6px 0;}
.toc a{
  font-size:14px; color:var(--muted); text-decoration:none; display:block;
  padding:4px 6px; border-radius:8px;
}
.toc a.active{color:var(--fg); background:var(--callout);}

.share-row{display:flex; gap:8px; flex-wrap:wrap;}
.btn{
  border:1px solid var(--border);
  background:var(--bg);
  color:var(--fg);
  border-radius:10px;
  padding:8px 12px;
  font-size:14px;
  cursor:pointer;
}
.btn:hover{border-color:var(--accent);}
.share-wa{background:#25D366; border-color:#25D366; color:#fff;}
.share-copy{background:var(--callout);}

.page-content{
  min-width:0;
  border:1px solid var(--border);
  border-radius:16px;
  padding:24px;
  background:var(--bg);
}
.page-header{margin-bottom:8px;}
.page-title{
  font-size:clamp(22px, 2.2vw, 32px);
  line-height:1.25;
  margin:0 0 8px;
}
.page-submeta{color:var(--muted); font-size:14px;}

/* Typography (prose) */
.prose{
  color:var(--fg);
  line-height:1.75;
  font-size:16px;
}
.prose p{margin:0 0 1em;}
.prose h2, .prose h3, .prose h4{
  margin:1.6em 0 .6em; line-height:1.3; position:relative; scroll-margin-top:90px;
}
.prose h2{font-size:clamp(20px,2vw,26px);}
.prose h3{font-size:clamp(18px,1.8vw,22px);}
.prose h4{font-size:clamp(16px,1.6vw,18px);}
.prose a{color:var(--accent); text-decoration:underline;}

/* Lists */
.prose ul, .prose ol{
  padding-left:1.25rem;
  /* lebih rapat di atas list */
  margin:0.25em 0 1em;
}
.prose li{
  /* rapatkan jarak antar bullet */
  margin:0.2em 0;
}
/* Parsedown sering membungkus isi <li> dengan <p> — rapatkan margin-nya */
.prose li > p{
  margin:0.15em 0;
}

.prose ul br { display: none !important; }

/* list bertingkat tetap rapat */
.prose ul ul, .prose ol ol, .prose ul ol, .prose ol ul{
  margin:0.2em 0 0.6em;
}

.prose blockquote{
  border-left:4px solid var(--accent);
  background:var(--callout);
  padding:12px 16px;
  border-radius: 0 12px 12px 0;
  color:var(--fg);
}
.prose img, .prose video, .prose iframe{
  max-width:100%; height:auto; display:block; margin:16px auto; border-radius:12px;
}
.prose table{
  width:100%; border-collapse: collapse; margin:16px 0; font-size:14px;
}
.prose table th, .prose table td{
  border:1px solid var(--border); padding:10px; text-align:left;
}
.prose pre{
  background:var(--code-bg);
  color:var(--code-fg);
  padding:14px;
  border-radius:12px;
  overflow:auto;
  font-size:13px;
}
.prose code{
  background:var(--callout);
  padding:.2em .4em;
  border-radius:6px;
  font-family: ui-monospace, SFMono-Regular, Menlo, Monaco, Consolas, "Liberation Mono", monospace;
}

/* Heading anchor icon */
.prose .anchor{
  visibility:hidden;
  position:absolute; left:-24px; top:50%; transform:translateY(-50%);
  opacity:.7; text-decoration:none; font-size:18px;
}
.prose h2:hover .anchor,
.prose h3:hover .anchor,
.prose h4:hover .anchor{visibility:visible;}

/* Callout info/warn/success (optional class names in Markdown) */
.prose .callout{padding:12px 14px; border-radius:12px; border:1px solid var(--border); background:var(--callout);}
.prose .callout.info{border-left:4px solid #2563eb;}
.prose .callout.warn{border-left:4px solid #f59e0b;}
.prose .callout.success{border-left:4px solid #10b981;}