/* PantauSabah — gaya kongsi portal (tema cerah, padan dashboard migrasi) */
:root{
  --bg:#eef2f7; --panel:#ffffff; --panel-2:#f4f6f9;
  --ink:#0c1320; --ink-2:#28323f; --muted:#5e6b7b; --faint:#93a0b0;
  --line:#e6eaf0; --line-2:#d4dae3;
  --red:#e11d48; --rose:#fff1f3; --teal:#0e7c7b; --blue:#2563cc; --amber:#d97a06; --ok:#0f9d6e;
  --shadow:0 1px 2px rgba(12,19,32,.04),0 10px 30px -12px rgba(12,19,32,.14);
  --shadow-lift:0 2px 4px rgba(12,19,32,.05),0 18px 40px -14px rgba(12,19,32,.22);
  --r:16px;
}
*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{
  margin:0;color:var(--ink);
  background:
    radial-gradient(900px 480px at 88% -10%, #ffe9ec 0%, rgba(255,233,236,0) 55%),
    radial-gradient(820px 460px at 4% 0%, #e6f6f3 0%, rgba(230,246,243,0) 50%),
    linear-gradient(180deg,#f6f8fb 0%, #eaeff5 100%);
  background-attachment:fixed;min-height:100vh;
  font-family:"Inter",-apple-system,BlinkMacSystemFont,"Segoe UI",Roboto,sans-serif;
  font-size:15px;line-height:1.6;-webkit-font-smoothing:antialiased;
}
.disp{font-family:"Space Grotesk","Inter",sans-serif}
.mono{font-family:"JetBrains Mono",ui-monospace,Menlo,Consolas,monospace;font-variant-numeric:tabular-nums}
a{color:var(--blue)}
.wrap{max-width:1080px;margin:0 auto;padding:0 20px}

/* ===== Header / nav ===== */
.site-head{position:sticky;top:0;z-index:50;background:rgba(246,248,251,.85);border-bottom:1px solid var(--line)}
@supports (backdrop-filter:blur(8px)){.site-head{backdrop-filter:saturate(150%) blur(10px);background:rgba(246,248,251,.72)}}
.head-in{max-width:1080px;margin:0 auto;padding:0 20px;height:60px;display:flex;align-items:center;gap:16px}
.brand{display:flex;align-items:center;gap:10px;text-decoration:none;color:var(--ink)}
.brand .mk{width:34px;height:34px;border-radius:10px;flex:none;display:grid;place-items:center;color:#fff;
  background:linear-gradient(135deg,var(--red),#b00d34);box-shadow:0 6px 16px -4px rgba(225,29,72,.5)}
.brand .mk svg{width:19px;height:19px}
.brand b{font-family:"Space Grotesk";font-size:18px;font-weight:700;letter-spacing:.01em}
.brand b span{color:var(--red)}
.brand .brand-tx{display:flex;flex-direction:column;line-height:1.05}
.brand small{font-size:9.5px;letter-spacing:.13em;text-transform:uppercase;color:var(--muted);font-weight:600;margin-top:2px}
.nav{display:flex;gap:4px;margin-left:auto;align-items:center}
.nav a{font-size:14px;font-weight:600;color:var(--muted);text-decoration:none;padding:8px 13px;border-radius:9px;transition:.15s}
.nav a:hover{color:var(--ink);background:var(--panel-2)}
.nav a.active{color:var(--red);background:var(--rose)}
/* Menu berkumpulan (dropdown) */
.navgrp{position:relative}
.navgrp .gbtn{font-family:inherit;font-size:14px;font-weight:600;color:var(--muted);background:none;border:none;cursor:pointer;padding:8px 13px;border-radius:9px;display:inline-flex;align-items:center;gap:5px;transition:.15s}
.navgrp .gbtn:hover{color:var(--ink);background:var(--panel-2)}
.navgrp .gbtn.active{color:var(--red);background:var(--rose)}
.navgrp .gbtn .car{font-size:10px;opacity:.65;transition:transform .15s}
.navgrp:hover .gbtn .car{transform:rotate(180deg)}
.navgrp-menu{position:absolute;top:100%;left:0;min-width:200px;background:var(--panel);border:1px solid var(--line);border-radius:12px;box-shadow:var(--shadow);padding:6px;margin-top:7px;display:none;z-index:60}
/* jambatan hover: tutup jurang antara butang & menu supaya tetikus tak "miss" */
.navgrp-menu::before{content:"";position:absolute;top:-11px;left:0;right:0;height:11px}
.navgrp:hover .navgrp-menu,.navgrp:focus-within .navgrp-menu,.navgrp.open .navgrp-menu{display:block}
.navgrp-menu a{display:block;font-size:13.5px;font-weight:600;color:var(--ink-2);text-decoration:none;padding:8px 12px;border-radius:8px;white-space:nowrap;transition:.12s}
.navgrp-menu a:hover{background:var(--panel-2);color:var(--ink)}
.navgrp-menu a.active{color:var(--red);background:var(--rose)}
.nav-toggle{display:none;margin-left:auto;width:40px;height:40px;border:1px solid var(--line-2);background:#fff;border-radius:10px;
  cursor:pointer;align-items:center;justify-content:center}
.nav-toggle svg{width:20px;height:20px;stroke:var(--ink)}

@media (max-width:720px){
  .nav-toggle{display:inline-flex}
  /* Matikan backdrop-filter di mobile: ia jadikan header "containing block" untuk
     position:fixed (iOS), menyebabkan menu terhad ke 60px. Tanpa blur, fixed dirujuk ke viewport. */
  .site-head{backdrop-filter:none;background:rgba(246,248,251,.97)}
  .nav{position:fixed;top:60px;left:0;right:0;bottom:0;flex-direction:column;align-items:stretch;gap:2px;
    background:var(--panel);border-bottom:1px solid var(--line);padding:10px 14px 40px;margin:0;
    box-shadow:var(--shadow);display:none;
    overflow-y:auto;overscroll-behavior:contain;-webkit-overflow-scrolling:touch}
  .nav.open{display:flex}
  /* Kunci scroll latar bila menu terbuka (iOS 16.4+) */
  body:has(.nav.open){overflow:hidden}
  .nav a{padding:11px 12px;font-size:15px}
  /* kumpulan → tajuk seksyen + anak terbentang */
  .navgrp{width:100%}
  .navgrp .gbtn{width:100%;justify-content:flex-start;padding:12px 12px 4px;font-size:11px;font-weight:700;letter-spacing:.06em;text-transform:uppercase;color:var(--faint);cursor:default;background:none}
  .navgrp .gbtn:hover{background:none;color:var(--faint)}
  .navgrp .gbtn .car{display:none}
  .navgrp-menu{position:static;display:block;border:none;box-shadow:none;padding:0;min-width:0;background:none}
  .navgrp-menu a{padding:11px 12px 11px 20px;font-size:15px}
}

/* ===== Hero ===== */
.hero{padding:42px 0 8px;text-align:center}
.hero .eyebrow{display:inline-block;font-size:12px;font-weight:700;letter-spacing:.14em;text-transform:uppercase;color:var(--red);margin-bottom:12px}
.hero h1{font-family:"Space Grotesk";font-size:clamp(28px,5vw,42px);font-weight:700;letter-spacing:-.02em;margin:0 0 12px;line-height:1.08}
.hero p{font-size:clamp(15px,2.2vw,18px);color:var(--ink-2);max-width:600px;margin:0 auto}

/* ===== Cards ===== */
.section{padding:26px 0 10px}
.card{background:var(--panel);border:1px solid var(--line);border-radius:var(--r);box-shadow:var(--shadow);
  text-decoration:none;color:inherit;display:block;transition:transform .18s,box-shadow .18s;position:relative;overflow:hidden}
.card:hover{transform:translateY(-3px);box-shadow:var(--shadow-lift)}

/* Featured (Migrasi) */
.featured{padding:28px;display:flex;gap:26px;align-items:flex-start;border:1px solid #f3c9d2;
  background:linear-gradient(120deg,#fff 60%, #fff5f7)}
.featured::before{content:"";position:absolute;left:0;top:0;bottom:0;width:5px;background:linear-gradient(180deg,var(--red),var(--amber))}
.featured .ic{width:64px;height:64px;border-radius:16px;flex:none;display:grid;place-items:center;color:#fff;
  background:linear-gradient(135deg,var(--red),#b00d34);box-shadow:0 10px 24px -8px rgba(225,29,72,.5)}
.featured .ic svg{width:34px;height:34px}
.featured .ft-body{flex:1;min-width:0}
.featured .tag{font-size:11px;font-weight:700;letter-spacing:.1em;text-transform:uppercase;color:var(--red)}
.featured h2{font-family:"Space Grotesk";font-size:clamp(20px,3vw,26px);font-weight:700;margin:4px 0 4px;letter-spacing:-.01em}
.featured .stat{font-family:"Space Grotesk";font-size:clamp(26px,4.5vw,38px);font-weight:700;color:var(--red);line-height:1;margin:6px 0}
.featured .stat small{font-size:15px;font-weight:600;color:var(--ink-2)}
.featured p{margin:6px 0 0;color:var(--ink-2);font-size:14.5px}
.featured .cta{display:inline-flex;align-items:center;gap:7px;margin-top:14px;font-family:"JetBrains Mono";font-size:13px;font-weight:600;
  color:#fff;background:var(--red);padding:10px 18px;border-radius:10px}
.featured:hover .cta{background:#c01030}
/* featured mini-dashboard (bar chart daerah) */
.mig-stat{font-size:14px;color:var(--ink-2);margin:2px 0 13px}
.mig-stat b{font-family:"Space Grotesk";font-size:21px;font-weight:700;color:var(--red)}
.mig-chart{display:flex;flex-direction:column;gap:9px;margin-bottom:12px;max-width:460px}
.mig-row{display:grid;grid-template-columns:100px 1fr 38px;align-items:center;gap:11px}
.mig-nm{font-size:13px;font-weight:600;color:var(--ink-2);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.mig-bar{display:flex;height:14px;border-radius:7px;overflow:hidden;background:#eef1f6;box-shadow:inset 0 0 0 1px var(--line)}
.mig-bar i{height:100%;transition:width .6s cubic-bezier(.4,0,.2,1)}
.mig-bar .w{background:linear-gradient(90deg,#3a78b8,#2563cc)}
.mig-bar .n{background:linear-gradient(90deg,#ef5a72,#e11d48)}
.mig-val{font-family:"JetBrains Mono";font-size:12px;font-weight:700;color:var(--red);text-align:right}
.mig-legend{display:flex;gap:16px;font-size:11.5px;color:var(--muted);margin-bottom:14px}
.mig-legend i{display:inline-block;width:11px;height:11px;border-radius:3px;margin-right:5px;vertical-align:-1px}
.mig-legend .lw{background:#2563cc}.mig-legend .ln{background:#e11d48}
.ft-side{flex:none;width:190px;align-self:stretch;border-left:1px solid var(--line);padding-left:22px;
  display:flex;flex-direction:column;justify-content:center;gap:16px}
.ft-side .fs-num{font-family:"Space Grotesk";font-size:23px;font-weight:700;color:var(--red);line-height:1}
.ft-side .fs-lab{font-size:11.5px;color:var(--muted);line-height:1.4;margin-top:3px}
@media (max-width:900px){.ft-side{display:none}}

/* Utility grid */
.grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:16px;margin-top:16px}
.tile{padding:18px 20px;display:flex;flex-direction:column}
.tile-top{display:flex;align-items:center;gap:12px;margin-bottom:14px}
.tile .ic{width:44px;height:44px;border-radius:12px;display:grid;place-items:center;color:#fff;flex:none}
.tile .ic svg{width:23px;height:23px}
.tile.cuaca .ic{background:linear-gradient(135deg,#3a78b8,var(--blue))}
.tile.gempa .ic{background:linear-gradient(135deg,#ef6f43,var(--amber))}
.tile.pasang .ic{background:linear-gradient(135deg,#14b8a6,var(--teal))}
.tile h3{font-family:"Space Grotesk";font-size:17px;font-weight:700;margin:0;line-height:1.15}
.tile .tile-sub{font-size:11px;color:var(--faint);font-family:"JetBrains Mono";margin-top:2px}
.tile p{margin:0;color:var(--muted);font-size:14px}
.tile .go{position:absolute;top:18px;right:18px;color:var(--faint);transition:.15s}
.tile:hover .go{color:var(--red);transform:translateX(2px)}
.tile .ic{transition:transform .2s cubic-bezier(.34,1.56,.64,1)}
.card.tile:hover .ic{transform:scale(1.08) rotate(-4deg)}
.tile .count{font-size:11.5px;color:var(--faint);margin-top:12px;font-family:"JetBrains Mono";display:flex;align-items:center;justify-content:space-between;gap:8px}
.tile .count .more{color:var(--ink-2);font-weight:600}

/* live badge */
.live{display:inline-flex;align-items:center;gap:5px;font-family:"JetBrains Mono";font-size:10px;font-weight:600;color:var(--ok);letter-spacing:.03em}
.live i{width:6px;height:6px;border-radius:50%;background:var(--ok);box-shadow:0 0 0 0 rgba(15,157,110,.5);animation:lpulse 1.8s infinite}
@keyframes lpulse{0%{box-shadow:0 0 0 0 rgba(15,157,110,.5)}70%{box-shadow:0 0 0 6px rgba(15,157,110,0)}100%{box-shadow:0 0 0 0 rgba(15,157,110,0)}}

/* ── mini cuaca ── */
.wx-feature{display:flex;align-items:center;gap:12px;background:linear-gradient(135deg,#edf4fb,#f8fbfe);
  border:1px solid #e2edf7;border-radius:13px;padding:11px 13px}
.wx-feature .wx-ic{width:42px;height:42px;flex:none}
.wx-feature .wx-ic svg{width:100%;height:100%;display:block}
.wx-feature .wx-mid{flex:1;min-width:0}
.wx-city{font-size:13px;font-weight:700;color:var(--ink);line-height:1.15}
.wx-cond{font-size:11px;color:var(--muted);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;margin-top:1px}
.wx-big{font-family:"Space Grotesk";font-size:22px;font-weight:700;color:var(--ink);line-height:1;flex:none}
.wx-big span{font-size:11.5px;color:var(--muted);font-weight:600}
.wx-mini{display:flex;gap:8px;margin-top:9px}
.wx-mini .wm{flex:1;display:flex;align-items:center;gap:6px;background:var(--panel-2);border:1px solid var(--line);
  border-radius:10px;padding:7px 9px;font-size:12px;color:var(--ink-2);font-weight:600;min-width:0}
.wx-mini .wm svg{display:none}
.wx-mini .wm .nm{flex:1;min-width:0;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.wx-mini .wm b{font-family:"JetBrains Mono";font-size:12px;color:var(--ink);flex:none;padding-left:4px}

/* ── mini gempa ── */
.qm{display:flex;align-items:center;gap:13px}
.qring{position:relative;width:50px;height:50px;flex:none;border-radius:50%;display:grid;place-items:center;
  background:var(--qc,#d97a06);color:#fff;box-shadow:0 5px 16px -4px var(--qc,#d97a06)}
.qring b{font-family:"Space Grotesk";font-size:17px;font-weight:700;line-height:1}
.qring::after{content:"";position:absolute;inset:-3px;border-radius:50%;border:2px solid var(--qc,#d97a06);
  opacity:.55;animation:qpulse 2.4s ease-out infinite}
@keyframes qpulse{0%{transform:scale(1);opacity:.55}100%{transform:scale(1.55);opacity:0}}
.qm .qinfo{min-width:0;flex:1}
.qm .qloc{font-weight:700;font-size:14px;line-height:1.25;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.qm .qmeta{font-size:11.5px;color:var(--muted);font-family:"JetBrains Mono";margin-top:2px}
.mag-scale{height:6px;border-radius:4px;margin-top:12px;position:relative;
  background:linear-gradient(90deg,#0f9d6e,#d97a06 45%,#ef6f43 70%,#e11d48)}
.mag-scale .mk{position:absolute;top:-3px;width:3px;height:12px;background:var(--ink);border-radius:2px;
  transform:translateX(-50%);box-shadow:0 0 0 2px #fff}

.segera{display:inline-flex;align-items:center;gap:6px;font-size:11px;font-weight:700;color:var(--amber);
  background:#fdf4e3;border:1px solid #f3d9a8;border-radius:20px;padding:4px 11px}
.tile .pasang-desc{font-size:13px;color:var(--muted);margin-top:11px;line-height:1.5}
.pasang-wave{height:30px;margin-top:12px;border-radius:9px;overflow:hidden;
  background:linear-gradient(180deg,#eafaf7,#f4fbfa);border:1px solid #d9efe9;position:relative}
.pasang-wave svg{position:absolute;inset:0;width:100%;height:100%}
.tile.cuti .ic{background:linear-gradient(135deg,#8a4f8f,#6d3b66)}
.tile.minyak .ic{background:linear-gradient(135deg,#0f9d6e,#0b7d58)}
/* mini cuti */
.cuti-mini{display:flex;align-items:baseline;gap:10px;flex-wrap:wrap}
.cuti-mini .cm-days{font-family:"Space Grotesk";font-size:30px;font-weight:700;color:#6d3b66;line-height:1}
.cuti-mini .cm-days span{font-size:12px;color:var(--muted);font-weight:600;margin-left:3px}
.cuti-mini .cm-name{font-size:13.5px;font-weight:600;color:var(--ink);width:100%;margin-top:2px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.cuti-mini .cm-date{font-family:"JetBrains Mono";font-size:11.5px;color:var(--muted);width:100%}
/* mini minyak */
.fuel-mini{display:flex;flex-direction:column;gap:7px}
.fuel-mini .fm{display:flex;align-items:center;gap:10px;font-size:13.5px;color:var(--ink-2);font-weight:600}
.fuel-mini .fm .nm{flex:1;min-width:0;color:var(--muted);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.fuel-mini .fm .pr{font-family:"JetBrains Mono";font-weight:700;color:var(--ink)}
.fuel-mini .fm .ch{font-family:"JetBrains Mono";font-size:11px;font-weight:600;margin-left:auto}
.fuel-mini .fm .ch.down{color:#0a7a55}.fuel-mini .fm .ch.up{color:#b3122a}.fuel-mini .fm .ch.same{color:var(--faint)}
.tile.berita .ic{background:linear-gradient(135deg,#6366f1,#4f46e5)}
.tile.jalan .ic{background:linear-gradient(135deg,#64748b,#475569)}
.tile.banjir .ic{background:linear-gradient(135deg,#38bdf8,#0369a1)}
.tile.gangguan .ic{background:linear-gradient(135deg,#fbbf24,#d97706)}
.tile.udara .ic{background:linear-gradient(135deg,#34d399,#059669)}
.tile.solat .ic{background:linear-gradient(135deg,#2dd4bf,#0f766e)}
.tile.wakil .ic{background:linear-gradient(135deg,#a78bfa,#6d28d9)}
.tile.sesb .ic{background:linear-gradient(135deg,#fbbf24,#e8853f)}
.tile.catuanair .ic{background:linear-gradient(135deg,#38bdf8,#2563cc)}
.tile.talian .ic{background:linear-gradient(135deg,#f87171,#dc2626)}
.tile.hargabarang .ic{background:linear-gradient(135deg,#4ade80,#15803d)}
.tile.bantuan .ic{background:linear-gradient(135deg,#34d399,#0d9488)}
.news-mini{display:flex;flex-direction:column;gap:8px}
.news-mini .nmi{display:flex;gap:8px;align-items:center;font-size:13px;line-height:1.35;color:var(--ink-2)}
.news-mini .nmi .dot{flex:none;width:6px;height:6px;border-radius:50%;background:#4f46e5}
.news-mini .nmi .t{white-space:nowrap;overflow:hidden;text-overflow:ellipsis;min-width:0}
/* mini pasang surut */
.tide-mini{display:flex;flex-direction:column;gap:7px}
.tide-mini .tm-port{font-size:11px;font-weight:700;letter-spacing:.03em;text-transform:uppercase;color:var(--muted);margin-bottom:1px}
.tide-mini .tm{display:flex;align-items:center;gap:8px;font-size:13px;color:var(--ink-2)}
.tide-mini .tm .tm-ic{width:20px;height:20px;border-radius:6px;display:grid;place-items:center;color:#fff;font-size:10px;font-weight:700;flex:none}
.tide-mini .tm.pasang .tm-ic{background:#2563cc}
.tide-mini .tm.surut .tm-ic{background:#0e7c7b}
.tide-mini .tm b{font-family:"JetBrains Mono"}
.tide-mini .tm .tm-t{font-family:"JetBrains Mono";color:var(--muted);margin-left:auto}

/* Mini keadaan jalan (hub) */
.road-mini{display:flex;align-items:center;gap:13px}
.road-mini .rm-dial{width:56px;height:56px;flex:none;border-radius:50%;display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center;line-height:1;color:#fff;background:var(--dc,#b91c1c);box-shadow:0 1px 4px rgba(0,0,0,.10)}
.road-mini .rm-dial b{font-family:"Space Grotesk";font-size:24px;font-weight:800;line-height:1;margin-top:3px}
.road-mini .rm-dial i{font-size:8px;font-style:normal;font-weight:700;letter-spacing:.06em;text-transform:uppercase;opacity:.92;line-height:1;margin-top:-1px}
.road-mini .rm-info{flex:1;min-width:0}
.road-mini .rm-stat{font-family:"Space Grotesk";font-size:16px;font-weight:700;line-height:1.1}
.road-mini .rm-cats{display:flex;flex-wrap:wrap;gap:5px;margin-top:5px}
.road-mini .rm-c{font-family:"JetBrains Mono";font-size:11px;font-weight:600;color:var(--ink-2);background:var(--panel-2);border:1px solid var(--line);border-radius:20px;padding:2px 8px}

/* ===== Footer ===== */
.site-foot{margin-top:48px;border-top:1px solid var(--line);background:rgba(255,255,255,.6)}
.foot-in{max-width:1080px;margin:0 auto;padding:30px 20px 32px;color:var(--muted)}
.foot-grid{display:grid;grid-template-columns:1.7fr 1fr 1fr 1fr;gap:22px 28px}
.fb-logo{display:inline-flex;align-items:center;gap:9px;text-decoration:none;margin-bottom:9px}
.fb-logo .mk{width:30px;height:30px;border-radius:9px;background:linear-gradient(135deg,#e0466e,#b91c1c);display:grid;place-items:center;color:#fff}
.fb-logo .mk svg{width:18px;height:18px}
.fb-logo b{font-family:"Space Grotesk";font-size:17px;font-weight:700;color:var(--ink)}
.fb-logo b span{color:var(--red)}
.foot-brand p{font-size:12.5px;line-height:1.55;margin:0 0 10px;max-width:300px}
.fb-quick a{font-size:12.5px;color:var(--ink-2);text-decoration:none;font-weight:600}
.fb-quick a:hover{color:var(--red)}
.foot-col h4{font-size:11px;font-weight:700;letter-spacing:.06em;text-transform:uppercase;color:var(--faint);margin:0 0 9px}
.foot-col a{display:block;font-size:13px;color:var(--ink-2);text-decoration:none;padding:3px 0;transition:.12s}
.foot-col a:hover{color:var(--red)}
.foot-bottom{display:flex;flex-wrap:wrap;gap:8px 16px;align-items:center;justify-content:space-between;font-size:12.5px}
.foot-bottom a{color:var(--muted);text-decoration:none;border-bottom:1px solid var(--line-2)}
.foot-bottom a:hover{color:var(--red);border-color:var(--red)}
.foot-src{font-family:"JetBrains Mono";font-size:11px;color:var(--faint);margin-top:12px;line-height:1.65}
@media(max-width:720px){ .foot-grid{grid-template-columns:1fr 1fr} .foot-brand{grid-column:1/-1} }
.badge-upd{display:inline-flex;align-items:center;gap:6px;font-family:"JetBrains Mono";font-size:11px;color:var(--ok);
  background:#e9f9f1;border:1px solid #bfedd6;border-radius:20px;padding:4px 10px}

/* ===== Prose (Tentang / Privasi / Hubungi) ===== */
.prose{max-width:760px;margin:6px auto 0}
.prose h1{font-family:"Space Grotesk";font-size:clamp(26px,4vw,34px);font-weight:700;margin:18px 0 4px;letter-spacing:-.01em}
.prose .lead{color:var(--muted);font-size:15px;margin:0 0 14px}
.prose h2{font-family:"Space Grotesk";font-size:19px;font-weight:700;margin:26px 0 8px}
.prose p,.prose li{font-size:15px;color:var(--ink-2);line-height:1.7}
.prose ul{padding-left:20px;margin:8px 0}
.prose a{color:var(--blue)}
.prose .meta{font-family:"JetBrains Mono";font-size:11.5px;color:var(--faint);margin-top:6px}
.prose .note-card{background:var(--panel);border:1px solid var(--line);border-radius:12px;padding:16px 18px;box-shadow:var(--shadow);margin:16px 0}

/* ===== Borang (Hubungi) ===== */
.form{max-width:560px;margin-top:16px;display:flex;flex-direction:column;gap:14px}
.form label{font-size:13px;font-weight:600;color:var(--ink-2);display:block;margin-bottom:5px}
.form input,.form textarea{width:100%;font:inherit;font-size:15px;padding:11px 13px;border:1px solid var(--line-2);border-radius:10px;background:#fff;color:var(--ink)}
.form input:focus,.form textarea:focus{outline:none;border-color:var(--blue);box-shadow:0 0 0 3px rgba(37,99,204,.12)}
.form .btn{align-self:flex-start;font-family:"JetBrains Mono";font-weight:600;font-size:14px;color:#fff;background:var(--red);border:none;border-radius:10px;padding:12px 22px;cursor:pointer}
.form .btn:hover{background:#c01030}
.hp{position:absolute!important;left:-9999px;width:1px;height:1px;overflow:hidden}
.alert{border-radius:10px;padding:13px 16px;font-size:14px;margin:10px 0}
.alert.ok{background:#e9f9f1;border:1px solid #bfedd6;color:#0a7a55}
.alert.err{background:var(--rose);border:1px solid #f3c9d2;color:#b3122a}

/* ===== Cookie consent ===== */
.cc{position:fixed;left:14px;right:14px;bottom:14px;z-index:200;max-width:560px;margin:0 auto;
  background:var(--panel);border:1px solid var(--line-2);border-radius:14px;
  box-shadow:0 14px 44px -10px rgba(12,19,32,.4);padding:16px 18px;display:none}
.cc.show{display:block}
.cc p{margin:0 0 12px;font-size:13px;color:var(--ink-2);line-height:1.55}
.cc .row{display:flex;gap:10px;flex-wrap:wrap}
.cc button{font-family:"Inter";font-weight:600;font-size:13.5px;border-radius:9px;padding:9px 16px;cursor:pointer;border:1px solid var(--line-2)}
.cc .acc{background:var(--red);color:#fff;border-color:var(--red)}
.cc .acc:hover{background:#c01030}
.cc .rej{background:#fff;color:var(--ink-2)}
.cc a{color:var(--blue)}
