:root{
  --teal:#0d7377; --teal-d:#0a5a5d; --navy:#0b2545; --ink:#13212e;
  --amber:#f5a524; --amber-d:#d98a0b; --paper:#fbfaf7; --card:#ffffff;
  --line:#e7e3da; --muted:#5c6b78; --soft:#eef4f4;
  --radius:16px; --shadow:0 1px 2px rgba(11,37,69,.06),0 8px 24px rgba(11,37,69,.07);
  --wrap:1120px;
  --sans:'Plus Jakarta Sans',system-ui,-apple-system,Segoe UI,Roboto,sans-serif;
  --serif:'Lora',Georgia,serif;
}
*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{margin:0;font-family:var(--sans);color:var(--ink);background:var(--paper);line-height:1.65;-webkit-font-smoothing:antialiased}
img{max-width:100%;display:block}
a{color:var(--teal);text-decoration:none}
a:hover{text-decoration:underline}
.wrap{max-width:var(--wrap);margin:0 auto;padding:0 22px}
h1,h2,h3,h4{line-height:1.2;letter-spacing:-.01em}

/* ---- Header ---- */
.site-head{position:sticky;top:0;z-index:50;background:rgba(251,250,247,.9);backdrop-filter:blur(10px);border-bottom:1px solid var(--line)}
.head-inner{display:flex;align-items:center;justify-content:space-between;height:72px}
.brand{display:flex;align-items:center;gap:11px;text-decoration:none}
.brand-mark{display:grid;place-items:center;width:40px;height:40px;border-radius:11px;background:linear-gradient(135deg,var(--teal),var(--navy));color:#fff;font-weight:800;font-size:15px;letter-spacing:.5px}
.brand-text strong{display:block;font-size:20px;color:var(--navy);font-weight:800;line-height:1}
.brand-text strong span{color:var(--teal)}
.brand-text small{display:block;font-size:11px;color:var(--muted);letter-spacing:.04em;text-transform:uppercase;margin-top:2px}
.site-nav{display:flex;align-items:center;gap:6px}
.site-nav a{color:var(--ink);font-size:14.5px;font-weight:500;padding:8px 12px;border-radius:9px}
.site-nav a:hover{background:var(--soft);text-decoration:none;color:var(--teal)}
.nav-cta{background:var(--navy);color:#fff!important}
.nav-cta:hover{background:var(--teal)!important}
.nav-toggle{display:none;flex-direction:column;gap:5px;background:none;border:0;cursor:pointer;padding:8px}
.nav-toggle span{width:24px;height:2px;background:var(--navy);border-radius:2px}

/* ---- Hero ---- */
.hero{background:linear-gradient(160deg,#0b2545 0%,#0d7377 100%);color:#fff;position:relative;overflow:hidden}
.hero:after{content:"";position:absolute;right:-120px;top:-80px;width:420px;height:420px;border-radius:50%;background:radial-gradient(circle,rgba(245,165,36,.22),transparent 70%)}
.hero-inner{display:grid;grid-template-columns:1.15fr .85fr;gap:48px;align-items:center;padding:74px 22px}
.eyebrow{display:inline-block;font-size:12px;font-weight:700;letter-spacing:.12em;text-transform:uppercase;color:var(--amber);margin-bottom:14px}
.hero h1{font-size:clamp(34px,5vw,52px);margin:0 0 16px;font-weight:800}
.hero-copy p{font-size:18px;color:rgba(255,255,255,.86);max-width:50ch;margin:0 0 28px}
.hero-actions{display:flex;gap:12px;flex-wrap:wrap}
.btn{display:inline-block;font-weight:700;font-size:15px;padding:13px 22px;border-radius:11px;transition:.18s;cursor:pointer;border:0}
.btn:hover{text-decoration:none;transform:translateY(-1px)}
.btn-primary{background:var(--amber);color:var(--navy)}
.btn-primary:hover{background:var(--amber-d)}
.btn-ghost{background:rgba(255,255,255,.1);color:#fff;border:1px solid rgba(255,255,255,.3)}
.btn-ghost:hover{background:rgba(255,255,255,.18)}
.btn-light{background:#fff;color:var(--navy)}
.hero-card{display:block;background:rgba(255,255,255,.97);color:var(--ink);border-radius:var(--radius);overflow:hidden;box-shadow:var(--shadow);transition:.18s}
.hero-card:hover{text-decoration:none;transform:translateY(-3px)}
.hero-card-img img{width:100%;height:210px;object-fit:cover;display:block}
.hero-card-body{display:block;padding:22px 24px 24px}
.hero-card .card-cat{color:var(--teal)}
.hero-card-title{display:block;font-size:22px;font-weight:800;color:var(--navy);margin:4px 0 10px;line-height:1.25}
.hero-card-ex{display:block;color:var(--muted);font-size:15px;margin:0 0 14px}
.read-more{font-weight:700;font-size:14.5px;color:var(--teal)}

/* ---- Sections ---- */
.section{padding:58px 22px}
.section-head{margin-bottom:30px}
.section-head h2{font-size:30px;color:var(--navy);margin:0 0 6px}
.section-head p{color:var(--muted);margin:0;font-size:16px}

/* category tiles */
.cat-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:18px}
.cat-tile{background:var(--card);border:1px solid var(--line);border-radius:var(--radius);padding:24px;transition:.18s;border-top:4px solid var(--teal)}
.cat-tile:hover{text-decoration:none;transform:translateY(-3px);box-shadow:var(--shadow)}
.cat-tile.cat-kesehatan-perjalanan{border-top-color:var(--amber)}
.cat-tile.cat-karantina-dokumen{border-top-color:var(--navy)}
.cat-tile.cat-kesehatan-maritim{border-top-color:#2a9d8f}
.cat-tile h3{color:var(--navy);font-size:19px;margin:0 0 8px}
.cat-tile p{color:var(--muted);font-size:14px;margin:0 0 14px}
.cat-go{color:var(--teal);font-weight:700;font-size:14px}

/* article cards */
.card-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:22px}
.card{background:var(--card);border:1px solid var(--line);border-radius:var(--radius);overflow:hidden;transition:.18s}
.card:hover{transform:translateY(-3px);box-shadow:var(--shadow)}
.card-link{display:block;color:inherit}
.card-link:hover{text-decoration:none}
.card-thumb{display:block;aspect-ratio:16/9;overflow:hidden;background:var(--soft)}
.card-thumb img{width:100%;height:100%;object-fit:cover;display:block;transition:.3s}
.card:hover .card-thumb img{transform:scale(1.05)}
.card-body{display:block;padding:20px 22px 22px}
.card-cat{display:inline-block;font-size:11.5px;font-weight:700;letter-spacing:.06em;text-transform:uppercase;color:var(--teal);margin-bottom:10px}
.card-title{font-size:19px;color:var(--navy);margin:0 0 10px;line-height:1.3}
.card-excerpt{color:var(--muted);font-size:14.5px;margin:0 0 14px}
.card-meta{color:#94a3ad;font-size:13px}

/* CTA band */
.band{background:var(--navy);color:#fff;margin-top:20px}
.band-inner{display:flex;align-items:center;justify-content:space-between;gap:24px;padding:44px 22px;flex-wrap:wrap}
.band h2{font-size:26px;margin:0 0 6px}
.band p{margin:0;color:rgba(255,255,255,.82)}

/* ---- Article ---- */
.crumbs{font-size:13.5px;color:var(--muted);padding:22px 0 0}
.crumbs a{color:var(--teal)}
.crumbs span{margin:0 4px;color:#b8c0c7}
.crumb-cur{color:var(--muted)}
.article{max-width:760px}
.article-head{padding:14px 0 8px;border-bottom:1px solid var(--line);margin-bottom:26px}
.article-head h1{font-size:clamp(28px,4vw,40px);color:var(--navy);margin:10px 0 12px}
.article-lede{font-size:19px;color:var(--muted);font-family:var(--serif);font-style:italic;margin:0 0 16px}
.article-hero{margin:6px 0 0;border-radius:var(--radius);overflow:hidden}
.article-hero img{width:100%;aspect-ratio:16/9;object-fit:cover;display:block}
.article-meta{display:flex;gap:8px;flex-wrap:wrap;font-size:13.5px;color:#8a97a1;margin-bottom:4px}
.article-body{font-size:17.5px;color:#26333f}
.article-body h2{font-size:25px;color:var(--navy);margin:36px 0 12px}
.article-body h3{font-size:20px;color:var(--navy);margin:26px 0 10px}
.article-body p{margin:0 0 18px}
.article-body ul,.article-body ol{margin:0 0 18px;padding-left:24px}
.article-body li{margin-bottom:9px}
.article-body strong{color:var(--ink)}
.article-body a{font-weight:600;border-bottom:1px solid rgba(13,115,119,.3)}
.article-body a:hover{text-decoration:none;border-bottom-color:var(--teal)}

/* FAQ */
.faq{margin:40px 0 8px}
.faq h2{font-size:24px;color:var(--navy);margin:0 0 16px}
.faq-item{border:1px solid var(--line);border-radius:12px;margin-bottom:10px;background:var(--card);overflow:hidden}
.faq-item summary{cursor:pointer;padding:16px 20px;font-weight:700;color:var(--navy);list-style:none;position:relative}
.faq-item summary::-webkit-details-marker{display:none}
.faq-item summary:after{content:"+";position:absolute;right:20px;color:var(--teal);font-size:20px}
.faq-item[open] summary:after{content:"−"}
.faq-item p{padding:0 20px 16px;margin:0;color:var(--muted);font-size:15.5px}

/* notice / disclaimer / contact */
.notice-box{background:#fff7e8;border:1px solid #f3dca3;border-left:4px solid var(--amber);border-radius:12px;padding:16px 18px;font-size:15px;color:#6b5418;margin:8px 0 26px}
.article-disclaimer{background:var(--soft);border-radius:12px;padding:16px 20px;margin:34px 0 0;font-size:14px;color:var(--muted)}
.article-disclaimer p{margin:0}
.notice-strong{background:#fdecea;border-color:#f3b7ae;border-left-color:#d9534f;color:#7a2b22}
.official-card{background:linear-gradient(135deg,#0b2545,#0d7377);color:#fff;border-radius:var(--radius);padding:24px 26px;margin:0 0 26px}
.official-card h2{color:#fff;margin:0 0 10px;font-size:20px}
.official-card p{color:rgba(255,255,255,.9);margin:0 0 10px}
.official-card strong{color:#fff}
.official-link{font-size:18px;font-weight:700;display:flex;align-items:center;flex-wrap:wrap;gap:10px}
.official-link a{color:#ffe2b0;border-bottom:1px solid rgba(255,226,176,.5)}
.badge-official{display:inline-block;font-size:11px;font-weight:700;letter-spacing:.04em;text-transform:uppercase;background:rgba(255,255,255,.15);color:#fff;padding:4px 10px;border-radius:20px}
.info-table{width:100%;border-collapse:collapse;margin:6px 0 18px;font-size:15.5px}
.info-table th,.info-table td{text-align:left;vertical-align:top;padding:11px 14px;border-bottom:1px solid var(--line)}
.info-table th{width:34%;color:var(--navy);font-weight:700;background:var(--soft)}
@media(max-width:560px){.info-table th{width:40%}}
.contact-card{background:var(--soft);border-radius:14px;padding:22px 24px;margin:8px 0 24px}
.contact-card h2{margin:0 0 6px;font-size:20px;color:var(--navy)}
.muted{color:var(--muted);font-size:14px}

/* category hero */
.cat-hero{padding-bottom:6px}
.cat-hero h1{font-size:36px;color:var(--navy);margin:8px 0 8px}
.cat-desc{color:var(--muted);font-size:17px;max-width:60ch}
.empty{color:var(--muted);padding:30px 0}

/* error */
.error-page{text-align:center;padding-top:70px}
.error-page .eyebrow{color:var(--amber)}
.error-page h1{font-size:38px;color:var(--navy)}
.error-page>p{color:var(--muted);max-width:46ch;margin:0 auto 24px}
.error-page .hero-actions{justify-content:center}

/* footer */
.site-foot{background:var(--ink);color:#c4cdd5;margin-top:40px;padding:48px 0 0}
.foot-grid{display:grid;grid-template-columns:1.6fr 1fr 1fr 1fr;gap:34px;padding-bottom:34px}
.site-foot .brand-text strong{color:#fff}
.foot-brand p{font-size:14px;color:#93a1ab;margin:14px 0 0;max-width:38ch}
.foot-col h4{color:#fff;font-size:14px;text-transform:uppercase;letter-spacing:.06em;margin:0 0 14px}
.foot-col a{display:block;color:#aab6bf;font-size:14.5px;padding:5px 0}
.foot-col a:hover{color:var(--amber)}
.foot-disclaimer{border-top:1px solid rgba(255,255,255,.1);padding-top:22px;padding-bottom:26px}
.foot-disclaimer p{font-size:12.5px;color:#8593a0;margin:0 0 10px;line-height:1.6}
.foot-copy{color:#6b7884!important}

/* ---- Responsive ---- */
@media(max-width:900px){
  .hero-inner{grid-template-columns:1fr;gap:30px;padding:50px 22px}
  .cat-grid{grid-template-columns:repeat(2,1fr)}
  .card-grid{grid-template-columns:repeat(2,1fr)}
  .foot-grid{grid-template-columns:1fr 1fr}
}
@media(max-width:640px){
  .nav-toggle{display:flex}
  .site-nav{display:none;position:absolute;top:72px;left:0;right:0;flex-direction:column;align-items:stretch;background:var(--paper);border-bottom:1px solid var(--line);padding:10px 16px;gap:2px}
  body.nav-open .site-nav{display:flex}
  .site-nav a{padding:12px 10px}
  .cat-grid,.card-grid{grid-template-columns:1fr}
  .foot-grid{grid-template-columns:1fr;gap:24px}
  .band-inner{flex-direction:column;align-items:flex-start}
  .section{padding:42px 22px}
}
