:root{
  --bg:#ffffff; --fg:#0f172a; --muted:#64748b; --line:#e5e7eb; --brand:#0ea5e9; --brand-ink:#075985;
  --chip-bg:#f8fafc; --chip-line:#e5e7eb; --card:#ffffff; --hover:#f1f5f9; --shadow:0 6px 24px rgba(2,6,23,.08);
  --radius:14px; --success:#16a34a; --danger:#ef4444;
}
@media (prefers-color-scheme: dark){
  :root{
    --bg:#0b1220; --fg:#e5e7eb; --muted:#94a3b8; --line:#1f2937; --brand:#38bdf8; --brand-ink:#7dd3fc;
    --chip-bg:#0f172a; --chip-line:#1f2937; --card:#0d1627; --hover:#111a2e; --shadow:0 8px 28px rgba(0,0,0,.35);
  }
}

*{box-sizing:border-box}
html,body{margin:0;padding:0;background:var(--bg);color:var(--fg);font:16px/1.65 system-ui,-apple-system,Segoe UI,Roboto,Inter,sans-serif}
a{color:inherit}
img{max-width:100%;height:auto}
.container{max-width:1040px;margin:0 auto;padding:12px 16px}
.pill{font-size:.875rem;color:var(--muted);padding:8px 10px;border:1px solid var(--line);border-radius:999px;background:var(--chip-bg)}

/* Header + nav */
.site-header{position:relative;border-bottom:1px solid var(--line);background:var(--bg)}
.nav{display:flex;align-items:center;justify-content:space-between;gap:12px}
.brand{display:flex;align-items:center;gap:10px;text-decoration:none}
.brand-name{font-weight:800;letter-spacing:.2px;font-size:1.06rem}
.brand-name em{font-style:normal;background:linear-gradient(90deg,var(--brand),color-mix(in oklab,var(--brand) 45%,#22d3ee));
  -webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent}
.nav-right{display:flex;align-items:center;gap:8px}
.menu{display:flex;gap:8px;align-items:center}
.menu a{color:var(--muted);text-decoration:none;padding:8px 10px;border-radius:10px}
.menu a[aria-current="page"], .menu a:hover{background:var(--hover);color:var(--fg)}
.hamb{display:none;appearance:none;border:1px solid var(--line);background:var(--card);border-radius:10px;padding:8px 10px}
.hamb svg{display:block}

/* Mobile menu (drawer) */
.drawer{display:none;border-top:1px solid var(--line);background:var(--bg)}
.drawer.open{display:block}
.drawer a{display:block;padding:12px 16px;text-decoration:none;color:var(--fg)}
.drawer a + a{border-top:1px solid var(--line)}
.drawer a:hover{background:var(--hover)}

@media (max-width:880px){
  .menu{display:none}
  .hamb{display:inline-flex}
}

/* Hero */
.hero{padding:36px 0 14px;background:
  radial-gradient(60rem 60rem at -10% -20%, color-mix(in oklab, var(--brand) 14%, transparent) 0%, transparent 60%),
  radial-gradient(48rem 48rem at 110% -10%, color-mix(in oklab, var(--brand) 10%, transparent) 0%, transparent 55%);
  border-bottom:1px solid var(--line)
}
.hero h1{font-size:clamp(1.6rem, 2.4vw + 1rem, 2.25rem);line-height:1.2;margin:0 0 8px}
.hero p{margin:.25rem 0;color:var(--muted)}
.tools{display:flex;gap:10px;align-items:center;flex-wrap:wrap;margin:14px 0 0}
.search{position:relative;flex:1 1 360px}
.search input{
  width:100%;padding:12px 44px 12px 44px;border:1px solid var(--line);border-radius:var(--radius);
  background:var(--card);color:var(--fg);box-shadow:var(--shadow)
}
.search .icon{position:absolute;left:12px;top:50%;transform:translateY(-50%);pointer-events:none}
.search .clear{position:absolute;right:10px;top:50%;transform:translateY(-50%);display:none;
  border:1px solid var(--line);background:var(--card);border-radius:10px;padding:4px;cursor:pointer}

/* A–Z nav (non-sticky) */
.az-wrap{background:var(--bg)}
.az-nav{display:flex;flex-wrap:wrap;gap:6px;padding:12px 16px 0}
.az-nav a{
  padding:6px 10px;border:1px solid var(--chip-line);border-radius:10px;text-decoration:none;color:var(--fg);
  background:var(--chip-bg);white-space:nowrap;transition:transform .12s ease
}
.az-nav a:hover{outline:2px solid var(--brand);outline-offset:2px;transform:translateY(-1px)}

/* Glossary body */
.glossary{max-width:880px;margin:10px auto 24px;padding:0 16px}
.glossary h2{font-size:1.22rem;margin:28px 0 10px}
.letter{background:var(--bg);border:1px solid var(--line);border-radius:16px;padding:14px;margin:10px 0;box-shadow:var(--shadow)}
.letter dl{margin:0}
.letter dt{margin-top:14px;font-weight:700;position:relative;padding-right:40px}
.letter dd{margin:6px 0 0 0}
.tag{display:inline-block;font-size:.76rem;color:var(--brand-ink);background:color-mix(in oklab, var(--brand) 16%, transparent);padding:2px 8px;border-radius:999px;margin-left:6px}
.note{display:block;font-size:.9rem;color:var(--muted)}
mark{background:color-mix(in oklab, var(--brand) 38%, transparent);padding:0 .15em;border-radius:4px}

/* copy link button (visible) */
.copy-link{position:absolute;right:4px;top:2px;border:1px solid var(--line);background:var(--card);
  border-radius:10px;padding:4px;opacity:.8;transition:opacity .15s ease, transform .12s ease;cursor:pointer;display:inline-flex;align-items:center;gap:6px}
.copy-link:hover{opacity:1;transform:translateY(-1px)}
.copy-msg{font-size:.85rem;color:var(--success);margin-left:6px;display:none}

/* Footer (lega) */
.site-footer{border-top:1px solid var(--line);margin-top:40px}
.footer-grid{display:grid;grid-template-columns:1.3fr .7fr;gap:20px;padding:28px 0}
.footer-grid h3{margin:.25rem 0 .5rem;font-size:1rem}
.footer-grid a{color:var(--muted);text-decoration:none}
.footer-grid a:hover{color:var(--fg);text-decoration:underline}
.copyright{font-size:.95rem;color:var(--muted);border-top:1px dashed var(--line);padding:16px 0}

@media (max-width:720px){
  .footer-grid{grid-template-columns:1fr}
}

/* Content scaffolding for inner pages */
.section{max-width:880px;margin:14px auto 28px;padding:0 16px}
.section h1{font-size:clamp(1.4rem, 2vw + 1rem, 2rem);margin:.25rem 0 .5rem}
.section p{margin:.4rem 0}
.section ul{margin:.4rem 0 0 1.2rem}
.section .lead{color:var(--muted)}

/* Search result list */
.results{max-width:880px;margin:8px auto 28px;padding:0 16px}
.result{border:1px solid var(--line);border-radius:16px;padding:12px;margin:10px 0;background:var(--bg);box-shadow:var(--shadow)}
.result h3{margin:.2rem 0 .4rem;font-size:1.06rem}
.badge{display:inline-block;font-size:.75rem;border:1px solid var(--chip-line);border-radius:999px;padding:2px 8px;background:var(--chip-bg);margin-left:6px;color:var(--muted)}
.meta{font-size:.85rem;color:var(--muted)}
.copy-btn{display:inline-flex;align-items:center;gap:6px;border:1px solid var(--line);background:var(--card);border-radius:10px;padding:4px 8px;cursor:pointer}
.copy-btn svg{display:block}

.breadcrumbs{font-size:.9rem;color:var(--muted);margin-bottom:8px}
.breadcrumbs a{text-decoration:none;color:var(--muted)}
.breadcrumbs a:hover{text-decoration:underline;color:var(--fg)}

.notice{padding:10px;border:1px dashed var(--line);border-radius:12px;background:var(--chip-bg);color:var(--muted);margin:8px 0}

/* ========== FOOTER — MOBILE POLISH & UPGRADE ========== */
:root{
  /* gutter responsif buat footer */
  --footer-gutter: clamp(22px, 6vw, 34px);
  --footer-gap: clamp(14px, 2.2vw, 22px);
}

/* padding kiri/kanan lebih besar + dukung safe-area (iPhone) */
.site-footer .container{
  padding-left: max(var(--footer-gutter), env(safe-area-inset-left));
  padding-right: max(var(--footer-gutter), env(safe-area-inset-right));
}

/* layout & spacing yang lebih “lega” */
.footer-grid{
  gap: var(--footer-gap);
  align-items: start;
}
.footer-grid h3{
  font-size: 1.06rem;
  letter-spacing: .2px;
  margin: .25rem 0 .35rem;
}
.site-footer .footer-grid p{
  margin: .35rem 0 .6rem;
  line-height: 1.7;
}

/* link nyaman disentuh, ada hover/focus tanpa norak */
.site-footer .footer-grid a{
  display: inline-flex;
  align-items: center;
  padding: 6px 8px;
  border-radius: 10px;
  text-decoration: none;
  color: var(--muted);
  transition: background-color .15s ease, color .15s ease, transform .12s ease;
}
.site-footer .footer-grid a:hover{
  background: var(--hover);
  color: var(--fg);
}
.site-footer .footer-grid a:focus-visible{
  outline: 2px solid var(--brand);
  outline-offset: 2px;
}

/* bar copyright lebih “bernafas” */
.copyright{
  padding: 18px 0 26px;
  font-size: .95rem;
  color: var(--muted);
  border-top: 1px dashed var(--line);
}

/* tone halus di background footer (subtle, gak ganggu dark mode) */
.site-footer{
  background:
    linear-gradient(180deg,
      color-mix(in oklab, var(--brand) 4%, var(--bg)) 0%,
      var(--bg) 50%);
}

/* mikro-tweak khusus layar kecil */
@media (max-width: 720px){
  .footer-grid{ grid-template-columns: 1fr; }
  .site-footer .container{
    padding-top: 24px;
    padding-bottom: 18px;
  }
  /* cegah teks “mepet kiri” jika ada paragraf panjang */
  .site-footer .footer-grid > *{ max-width: 60ch; }
}

/* dark mode halusinasi warna hover/focus */
@media (prefers-color-scheme: dark){
  .site-footer .footer-grid a:hover{
    background: color-mix(in oklab, var(--brand) 18%, transparent);
    color: var(--fg);
  }
}

/* ==== Pill link polish: no underline, align icon, subtle hover ==== */
.pill { text-decoration: none; } /* hilangin garis bawah untuk semua komponen bergaya pill */
.pill-link{
  display:inline-flex; align-items:center; gap:8px;
  text-decoration:none; /* jaga-jaga */
}
.pill-link svg{ flex:0 0 auto; width:16px; height:16px; transition:transform .15s ease; }
.pill-link:hover{ outline:2px solid var(--brand); outline-offset:2px; }
.pill-link:hover svg{ transform:translateX(1px); }
.pill-link:focus-visible{ outline:2px solid var(--brand); outline-offset:2px; }


/* ==== HERO: gutters & readable measure ==== */
:root{
  --hero-gutter: clamp(24px, 6vw, 48px); /* ruang kiri–kanan yang responsif */
  --hero-measure: 68ch;                  /* panjang baris ideal */
}

/* tambah padding kiri–kanan khusus hero (+safe-area iPhone) */
.container.hero{
  padding-left: max(var(--hero-gutter), env(safe-area-inset-left));
  padding-right: max(var(--hero-gutter), env(safe-area-inset-right));
}

/* batasi lebar baris supaya paragraf gak melebar */
.container.hero > p,
.container.hero .tools{
  max-width: var(--hero-measure);
}

/* judul lebih rapi untuk 2–3 baris */
@supports (text-wrap: balance){
  .container.hero > h1{ text-wrap: balance; }
}

/* sedikit spasi antar elemen di hero */
.container.hero > h1{ margin-bottom: 10px; }
.container.hero > p{ margin-top: .4rem; margin-bottom: .5rem; }


.section,
.results{
  padding-left: max(var(--hero-gutter), env(safe-area-inset-left));
  padding-right: max(var(--hero-gutter), env(safe-area-inset-right));
}


/* === Wordmark PesonaDieng.com (scoped, no side effects) === */
.wordmark{
  display:inline-flex; align-items:baseline; gap:.22rem;
  text-decoration:none; line-height:1; letter-spacing:.1px;
}
.wordmark .wm-type{
  font-weight:800;
  font-size:clamp(1.05rem, 1.2vw + .9rem, 1.35rem);
}
.wordmark .wm-dot{
  color: var(--ring, #0ea5e9);
  font-weight:900; margin:0 .04rem; transform:translateY(-.02em);
}
.wordmark .wm-tld{
  font-weight:700; opacity:.9;
}

/* fokus/hover elegan & aksesibel, tidak mengubah gaya link lain */
.wordmark:where(:hover, :focus-visible){
  outline:3px solid color-mix(in oklab, var(--ring, #0ea5e9) 40%, transparent);
  outline-offset:3px; border-radius:.5rem; text-decoration:none;
}

@media (max-width:640px){
  .wordmark .wm-type{ font-size:1.12rem; }
}
