/* =========================================================
   base.css — GLOBAL LAYOUT (dipakai semua sektor)
   Clean • ringan • mobile-first
========================================================= */

:root{
  --bg:#f6f8fb;
  --card:#ffffff;
  --text:#14181f;
  --muted:rgba(20,24,31,.72);
  --line:rgba(20,24,31,.10);
  --shadow:0 10px 30px rgba(20,24,31,.08);
  --radius:18px;

  /* Default fallback (akan dioverride oleh CSS sektor) */
  --accent:#0d6efd;
  --accent-2:#0b57d0;
  --accent-soft: rgba(13,110,253,.08);
}

*{box-sizing:border-box}
html,body{height:100%}

body{
  margin:0;
  font-family:system-ui,-apple-system,Segoe UI,Roboto,Arial,sans-serif;
  background:var(--bg);
  color:var(--text);
  line-height:1.6;
}

a{color:inherit;text-decoration:none}
img{max-width:100%;display:block}

.container{
  width:min(1120px,calc(100% - 32px));
  margin:0 auto;
}

.muted{color:var(--muted)}
.section{padding:18px 0 26px}

/* TOPBAR */
.topbar{
  position:sticky;
  top:0;
  z-index:50;
  background:rgba(246,248,251,.85);
  backdrop-filter:blur(10px);
  border-bottom:1px solid var(--line);
}

.topbar-inner{
  display:flex;
  align-items:center;
  justify-content:space-between;
  padding:14px 0;
  gap:16px;
}

.brand{
  display:flex;
  align-items:center;
  gap:12px;
  min-width:0;
}

.brand-mark{
  width:36px;height:36px;
  border-radius:12px;
  background:linear-gradient(135deg,var(--accent),var(--accent-soft));
  box-shadow:0 10px 20px rgba(0,0,0,.08);
}

.brand-text{
  display:flex;
  flex-direction:column;
  min-width:0;
}
.brand-text strong{font-weight:800;letter-spacing:.2px}
.brand-text span{
  font-size:12px;
  color:var(--muted);
  overflow:hidden;
  text-overflow:ellipsis;
  white-space:nowrap;
}

.topbar-actions{
  display:flex;
  gap:10px;
  flex-wrap:wrap;
  align-items:center;
}

/* BUTTONS */
.btn{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  gap:8px;
  padding:11px 14px;
  border-radius:14px;
  border:1px solid transparent;
  font-weight:750;
  font-size:14px;
  cursor:pointer;
  user-select:none;
}

.btn-primary{
  background:var(--accent);
  color:#fff;
  box-shadow:0 12px 22px rgba(0,0,0,.10);
}
.btn-primary:hover{filter:brightness(.95)}

.btn-secondary{
  background:#111827;
  color:#fff;
}

.btn-outline{
  background:transparent;
  border-color: color-mix(in srgb, var(--accent) 35%, transparent);
  color:var(--accent);
}
.btn-outline:hover{
  background: color-mix(in srgb, var(--accent) 8%, transparent);
}

.btn-ghost{
  background:transparent;
  border-color:rgba(20,24,31,.12);
  color:rgba(20,24,31,.82);
}
.btn-ghost:hover{background:rgba(20,24,31,.04)}

/* HERO */
.hero{
  display:grid;
  grid-template-columns: 1.2fr .8fr;
  gap:16px;
  padding:22px 0 10px;
}

.hero-card{
  background:var(--card);
  border:1px solid var(--line);
  border-radius:var(--radius);
  box-shadow:var(--shadow);
  padding:20px;
  overflow:hidden;
  position:relative;
}

.hero-card h1{
  margin:0 0 10px;
  font-size:clamp(22px,3vw,38px);
  line-height:1.15;
  letter-spacing:-.4px;
}
.hero-card p{margin:0 0 14px;color:var(--muted)}

.hero-cta{
  display:flex;
  gap:10px;
  flex-wrap:wrap;
  margin-top:10px;
}

.kpis{
  display:grid;
  grid-template-columns:repeat(2,minmax(0,1fr));
  gap:10px;
}
.kpi{
  background:var(--card);
  border:1px solid var(--line);
  border-radius:16px;
  box-shadow:var(--shadow);
  padding:14px;
}
.kpi strong{display:block;font-size:14px}
.kpi span{display:block;font-size:12px;color:var(--muted);margin-top:2px}

/* CONTENT BLOCKS */
.grid-3{
  display:grid;
  grid-template-columns:repeat(3,minmax(0,1fr));
  gap:12px;
}

.card{
  background:var(--card);
  border:1px solid var(--line);
  border-radius:16px;
  box-shadow:0 10px 24px rgba(20,24,31,.06);
  padding:16px;
}

.card h3{margin:0 0 6px;font-size:15px;letter-spacing:-.2px}
.card p{margin:0;color:var(--muted);font-size:13px}

/* LIST */
.ul{
  margin:10px 0 0;
  padding-left:18px;
  color:rgba(20,24,31,.78);
}
.ul li{margin:6px 0}

/* FOOTER */
.footer{
  border-top:1px solid var(--line);
  padding:16px 0 24px;
  margin-top:18px;
}
.footer-inner{
  display:flex;
  justify-content:space-between;
  gap:16px;
  flex-wrap:wrap;
}
.footer a{color:rgba(20,24,31,.78)}
.footer a:hover{color:rgba(20,24,31,.95)}

/* RESPONSIVE */
@media(max-width:980px){
  .hero{grid-template-columns:1fr}
  .grid-3{grid-template-columns:repeat(2,minmax(0,1fr))}
}
@media(max-width:560px){
  .grid-3{grid-template-columns:1fr}
  .btn{width:100%}
  .topbar-actions{width:100%}
}

/* =========================================================
   SECTOR CARDS (untuk index.html)
   Nuansa warna S01–S17 tampil di kartu + badge
========================================================= */

/* 17 warna sektor (dipakai khusus kartu index) */
:root{
  --s01:#2e7d32;
  --s02:#546e7a;
  --s03:#1565c0;
  --s04:#f9a825;
  --s05:#00897b;
  --s06:#ef6c00;
  --s07:#c62828;
  --s08:#283593;
  --s09:#ff8f00;
  --s10:#6a1b9a;
  --s11:#1b5e20;
  --s12:#6d4c41;
  --s13:#00838f;
  --s14:#0d47a1;
  --s15:#1976d2;
  --s16:#ad1457;
  --s17:#455a64;
}

/* Grid kartu sektor */
.sector-grid{
  display:grid;
  grid-template-columns:repeat(3,minmax(0,1fr));
  gap:12px;
}

/* Kartu sektor */
.sector-card{
  background:var(--card);
  border:1px solid var(--line);
  border-radius:16px;
  padding:16px 16px 14px;
  box-shadow:0 10px 24px rgba(20,24,31,.06);
  position:relative;
  overflow:hidden;
  transition:transform .18s ease, box-shadow .18s ease, border-color .18s ease;
}

.sector-card:hover{
  transform:translateY(-2px);
  box-shadow:0 14px 30px rgba(20,24,31,.10);
  border-color:rgba(20,24,31,.16);
}

/* Accent strip kiri */
.sector-card::before{
  content:"";
  position:absolute;
  inset:0 auto 0 0;
  width:5px;
  background:rgba(13,110,253,.22);
}

/* Glow lembut kanan bawah */
.sector-card::after{
  content:"";
  position:absolute;
  width:240px;
  height:240px;
  right:-140px;
  bottom:-160px;
  border-radius:999px;
  background:radial-gradient(circle at 30% 30%, rgba(13,110,253,.16), transparent 60%);
  pointer-events:none;
}

.sector-code{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  height:26px;
  padding:0 10px;
  border-radius:999px;
  font-weight:900;
  font-size:12px;
  color:#fff;
  letter-spacing:.2px;
}

.sector-card h3{
  margin:10px 0 6px;
  font-size:15px;
  letter-spacing:-.2px;
}

.sector-desc{
  margin:0;
  font-size:12.5px;
  color:var(--muted);
}

/* WARNA PER SEKTOR */
.s01 .sector-code{background:var(--s01)} .s01::before{background:var(--s01)} .s01::after{background:radial-gradient(circle at 30% 30%, rgba(46,125,50,.18), transparent 60%)}
.s02 .sector-code{background:var(--s02)} .s02::before{background:var(--s02)} .s02::after{background:radial-gradient(circle at 30% 30%, rgba(84,110,122,.18), transparent 60%)}
.s03 .sector-code{background:var(--s03)} .s03::before{background:var(--s03)} .s03::after{background:radial-gradient(circle at 30% 30%, rgba(21,101,192,.18), transparent 60%)}
.s04 .sector-code{background:var(--s04)} .s04::before{background:var(--s04)} .s04::after{background:radial-gradient(circle at 30% 30%, rgba(249,168,37,.20), transparent 60%)}
.s05 .sector-code{background:var(--s05)} .s05::before{background:var(--s05)} .s05::after{background:radial-gradient(circle at 30% 30%, rgba(0,137,123,.18), transparent 60%)}
.s06 .sector-code{background:var(--s06)} .s06::before{background:var(--s06)} .s06::after{background:radial-gradient(circle at 30% 30%, rgba(239,108,0,.20), transparent 60%)}
.s07 .sector-code{background:var(--s07)} .s07::before{background:var(--s07)} .s07::after{background:radial-gradient(circle at 30% 30%, rgba(198,40,40,.18), transparent 60%)}
.s08 .sector-code{background:var(--s08)} .s08::before{background:var(--s08)} .s08::after{background:radial-gradient(circle at 30% 30%, rgba(40,53,147,.18), transparent 60%)}
.s09 .sector-code{background:var(--s09)} .s09::before{background:var(--s09)} .s09::after{background:radial-gradient(circle at 30% 30%, rgba(255,143,0,.20), transparent 60%)}
.s10 .sector-code{background:var(--s10)} .s10::before{background:var(--s10)} .s10::after{background:radial-gradient(circle at 30% 30%, rgba(106,27,154,.18), transparent 60%)}
.s11 .sector-code{background:var(--s11)} .s11::before{background:var(--s11)} .s11::after{background:radial-gradient(circle at 30% 30%, rgba(27,94,32,.18), transparent 60%)}
.s12 .sector-code{background:var(--s12)} .s12::before{background:var(--s12)} .s12::after{background:radial-gradient(circle at 30% 30%, rgba(109,76,65,.18), transparent 60%)}
.s13 .sector-code{background:var(--s13)} .s13::before{background:var(--s13)} .s13::after{background:radial-gradient(circle at 30% 30%, rgba(0,131,143,.18), transparent 60%)}
.s14 .sector-code{background:var(--s14)} .s14::before{background:var(--s14)} .s14::after{background:radial-gradient(circle at 30% 30%, rgba(13,71,161,.18), transparent 60%)}
.s15 .sector-code{background:var(--s15)} .s15::before{background:var(--s15)} .s15::after{background:radial-gradient(circle at 30% 30%, rgba(25,118,210,.18), transparent 60%)}
.s16 .sector-code{background:var(--s16)} .s16::before{background:var(--s16)} .s16::after{background:radial-gradient(circle at 30% 30%, rgba(173,20,87,.18), transparent 60%)}
.s17 .sector-code{background:var(--s17)} .s17::before{background:var(--s17)} .s17::after{background:radial-gradient(circle at 30% 30%, rgba(69,90,100,.18), transparent 60%)}

/* Responsive grid sektor */
@media(max-width:980px){
  .sector-grid{grid-template-columns:repeat(2,minmax(0,1fr))}
}
@media(max-width:560px){
  .sector-grid{grid-template-columns:1fr}
}

/* =========================================================
   ASSISTENKU BRAND OVERRIDES (Blue/White) — SAFE (NO GLOBAL DAMAGE)
   Catatan: Jangan ubah --card global. Branding fokus ke topbar/footer/button saja.
========================================================= */

:root{
  --accent:#0d6efd;
  --accent-2:#0b5ed7;
  --accent-soft: rgba(13,110,253,.10);
}

/* Topbar: rapih dan compact */
.topbar{
  background: rgba(255,255,255,.88);
  border-bottom: 1px solid var(--line);
  backdrop-filter: blur(10px);
}

.topbar-inner{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:12px;
  padding:10px 0;
  flex-wrap:nowrap;         /* penting: jangan wrap */
}

/* Brand wrapper */
.brand{
  display:flex;
  align-items:center;
  gap:10px;
  min-width:0;
}

.brand-link{
  display:flex;
  align-items:center;
  gap:10px;
  min-width:0;
  text-decoration:none;
  color:inherit;
}

/* Logo: kecil, tidak bikin layout meledak */
.brand-logo{
  width:34px;
  height:34px;
  border-radius:10px;
  object-fit:contain;
  background:#fff;
  border:1px solid rgba(13,110,253,.18);
  box-shadow:none;
}

/* fallback mark kalau logo tidak ada */
.brand-mark{
  width:34px;
  height:34px;
  border-radius:10px;
  background: linear-gradient(180deg, var(--accent), var(--accent-2));
  border:1px solid rgba(13,110,253,.22);
  box-shadow:none;
}

/* teks jangan dorong tombol */
.brand-text{
  display:flex;
  flex-direction:column;
  line-height:1.15;
  min-width:0;
}

.brand-text strong{
  font-size:14px;
  font-weight:900;
  letter-spacing:-.2px;
  white-space:nowrap;
  overflow:hidden;
  text-overflow:ellipsis;
  max-width:52vw;
}

.brand-text span{
  font-size:11.5px;
  color:var(--muted);
  white-space:nowrap;
  overflow:hidden;
  text-overflow:ellipsis;
  max-width:52vw;
}

/* Actions: jangan wrap, jangan full width */
.topbar-actions{
  display:flex;
  align-items:center;
  gap:8px;
  flex-wrap:nowrap;
  width:auto;
  flex-shrink:0;
}

/* Button branding (tanpa ubah sektor) */
.btn-primary{
  background: var(--accent);
  color:#fff;
  border-color:transparent;
  box-shadow:0 10px 20px rgba(13,110,253,.18);
}
.btn-primary:hover{background:var(--accent-2); filter:none}

.btn-secondary{
  background: rgba(13,110,253,.10);
  border: 1px solid rgba(13,110,253,.22);
  color: rgba(15,23,42,.92);
}
.btn-secondary:hover{background: rgba(13,110,253,.14);}

.btn-outline{
  background: transparent;
  border: 1px solid rgba(13,110,253,.30);
  color: var(--accent-2);
}
.btn-outline:hover{background: rgba(13,110,253,.08);}

.btn-ghost{
  background: transparent;
  border: 1px solid var(--line);
}
.btn-ghost:hover{background: rgba(13,110,253,.06);}

/* Footer: putih bersih */
.footer{
  background:#fff;
  border-top:1px solid var(--line);
}

/* Mobile: topbar tetap rapi, tombol tidak jadi full-width */
@media(max-width:560px){
  .topbar-actions{gap:8px}
  .topbar-actions .btn{width:auto}  /* override global .btn{width:100%} */
  .btn{padding:9px 10px;font-size:12.5px;border-radius:12px}
}

/* HP kecil: sembunyikan tombol beranda agar tidak sempit */
@media(max-width:420px){
  .topbar-actions .btn-ghost{display:none}
  .brand-text strong, .brand-text span{max-width:62vw}
   }

.select{
  height:42px;
  padding:0 12px;
  border-radius:14px;
  border:1px solid var(--line);
  background:#fff;
  color:var(--text);
  font-weight:650;
  width:100%;
}
.filter-label{
  display:block;
  font-size:12px;
  color:var(--muted);
  font-weight:700;
  margin-bottom:6px;
}
