/* ===== Notaris Dewi Permatasari, S.H., M.Kn. — Prototype Stylesheet ===== */
:root{
  --navy:#0f2747;
  --navy-700:#173b66;
  --navy-600:#1e4d85;
  --gold:#c8a14a;
  --gold-soft:#e8d59f;
  --bg:#f4f6fa;
  --card:#ffffff;
  --line:#e3e8f0;
  --ink:#1c2433;
  --muted:#6b7686;
  --green:#1f9d62;
  --green-bg:#e3f6ec;
  --amber:#d68a1a;
  --amber-bg:#fdf1da;
  --red:#d24545;
  --red-bg:#fbe6e6;
  --blue:#2a6fb0;
  --blue-bg:#e6f0fa;
  --radius:14px;
  --shadow:0 1px 2px rgba(16,32,64,.05),0 8px 24px rgba(16,32,64,.06);
  --shadow-lg:0 12px 40px rgba(16,32,64,.16);
}
*{box-sizing:border-box}
html,body{margin:0;padding:0;overflow-x:clip;max-width:100%}
body{
  font-family:'Segoe UI',system-ui,-apple-system,Roboto,Arial,sans-serif;
  background:var(--bg);color:var(--ink);font-size:14px;line-height:1.5;
  -webkit-font-smoothing:antialiased;
}
a{color:inherit;text-decoration:none}
button{font-family:inherit;cursor:pointer;border:none;background:none}
img,svg{display:block}

/* ===== Top bar ===== */
.topbar{
  position:sticky;top:0;z-index:50;height:60px;
  background:var(--navy);color:#fff;display:flex;align-items:center;
  padding:0 20px;gap:18px;box-shadow:0 2px 10px rgba(15,39,71,.25);
}
.brand{display:flex;align-items:center;gap:10px;font-weight:700;font-size:17px;letter-spacing:.3px}
.brand .logo{
  width:34px;height:34px;border-radius:9px;
  background:linear-gradient(135deg,var(--gold),#a8842f);
  display:grid;place-items:center;color:var(--navy);font-weight:800;font-size:16px;
}
.brand-logo{width:38px;height:38px;border-radius:9px;object-fit:contain;flex-shrink:0;background:rgba(255,255,255,.06)}
.brand small{display:block;font-size:10px;font-weight:500;color:var(--gold-soft);letter-spacing:1px}
.topbar .spacer{flex:1}
.role-switch{display:flex;background:rgba(255,255,255,.1);border-radius:10px;padding:4px;gap:4px}
.role-switch button{
  color:#cdd8e8;padding:7px 14px;border-radius:7px;font-size:13px;font-weight:600;transition:.15s;
}
.role-switch button.active{background:#fff;color:var(--navy)}
.bell{position:relative;font-size:19px;width:38px;height:38px;border-radius:10px;
  background:rgba(255,255,255,.1);color:#fff;display:grid;place-items:center;transition:.12s}
.bell:hover{background:rgba(255,255,255,.2)}
.bell-dot{position:absolute;top:4px;right:4px;background:var(--red);color:#fff;font-size:10px;font-weight:700;
  min-width:16px;height:16px;border-radius:9px;display:grid;place-items:center;padding:0 4px}
.topbar .user{display:flex;align-items:center;gap:9px;font-size:13px}
/* Dropdown profil pengguna di topbar */
.userbox{position:relative}
.topbar .user{background:rgba(255,255,255,.06);border:1px solid rgba(255,255,255,.08);color:#fff;
  border-radius:12px;padding:5px 9px 5px 6px;cursor:pointer;transition:.12s;max-width:230px}
.topbar .user:hover{background:rgba(255,255,255,.14)}
.topbar .user .ud{min-width:0;text-align:left}
.topbar .user .un{font-weight:600;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:150px}
.topbar .user .ur{font-size:11px;color:var(--gold-soft)}
.topbar .user .ucaret{color:var(--gold-soft);font-size:11px;margin-left:2px}
.usermenu{position:absolute;top:calc(100% + 8px);right:0;min-width:210px;background:#fff;border:1px solid var(--line);
  border-radius:14px;box-shadow:var(--shadow-lg);padding:6px;z-index:200;animation:umIn .12s ease}
@keyframes umIn{from{opacity:0;transform:translateY(-6px)}to{opacity:1;transform:none}}
.usermenu a{display:flex;align-items:center;gap:10px;padding:10px 12px;border-radius:9px;color:var(--ink);
  font-size:13.5px;font-weight:500;cursor:pointer;white-space:nowrap}
.usermenu a:hover{background:var(--bg)}
.usermenu .um-sep{height:1px;background:var(--line);margin:5px 4px}
.usermenu .um-danger{color:var(--red)}
.usermenu .um-danger:hover{background:var(--red-bg)}
@media(max-width:680px){ .topbar .user .ud{display:none} .topbar .user{padding:5px;max-width:none} }
.avatar{width:34px;height:34px;border-radius:50%;background:var(--gold);color:var(--navy);
  display:grid;place-items:center;font-weight:700}
.avatar.sm{width:28px;height:28px;font-size:12px}
.avatar.lg{width:66px;height:66px;font-size:24px;overflow:hidden}
/* Editor alur proses (workflow) */
.wf-row{display:flex;align-items:center;gap:8px;padding:6px 0;border-bottom:1px solid var(--line-2)}
.wf-ord{display:flex;flex-direction:column;align-items:center;gap:0;width:26px;flex-shrink:0}
.wf-ord button{border:none;background:transparent;cursor:pointer;color:var(--muted);font-size:9px;line-height:1.1;padding:0}
.wf-ord button:disabled{opacity:.25;cursor:default}
.wf-ord b{font-size:11px;color:var(--navy)}
.wf-row>input{flex:1;min-width:0;padding:8px 10px;border:1px solid var(--line);border-radius:8px;font-size:13px}
.wf-gate{display:flex;align-items:center;gap:4px;font-size:15px;cursor:pointer;flex-shrink:0;background:var(--bg);border:1px solid var(--line);border-radius:8px;padding:7px 9px}
.wf-gate input{width:auto;margin:0}
.wf-del{border:none;background:transparent;cursor:pointer;font-size:14px;flex-shrink:0;opacity:.65;padding:4px}
.wf-del:hover{opacity:1}
.p-svc-group{font-size:17px;font-weight:800;color:var(--navy);margin:6px 0 12px;display:flex;align-items:center;gap:10px}
.p-svc-group::after{content:"";flex:1;height:1px;background:var(--line)}
.avatar img{border-radius:inherit}

/* ===== Layout ===== */
.shell{display:flex;min-height:calc(100vh - 60px)}
.sidebar{
  width:236px;background:var(--card);border-right:1px solid var(--line);
  padding:16px 12px;flex-shrink:0;position:sticky;top:60px;height:calc(100vh - 60px);overflow-y:auto;
}
.nav-group-label{font-size:10px;font-weight:700;letter-spacing:1.2px;color:var(--muted);
  text-transform:uppercase;padding:14px 12px 6px}
.nav-item{
  display:flex;align-items:center;gap:11px;padding:10px 12px;border-radius:9px;
  color:var(--ink);font-weight:500;margin-bottom:2px;transition:.12s;font-size:13.5px;
  cursor:pointer;user-select:none;
}
.nav-item .ico{width:20px;text-align:center;font-size:16px}
.nav-item:hover{background:var(--bg)}
.nav-item.active{background:var(--navy);color:#fff}
.nav-item.active .ico{filter:none}
.nav-badge{margin-left:auto;background:var(--red);color:#fff;font-size:11px;font-weight:700;
  min-width:19px;height:19px;border-radius:10px;display:grid;place-items:center;padding:0 5px}
.nav-item.active .nav-badge{background:var(--gold);color:var(--navy)}

/* Sidebar accordion: judul grup + caption isi menu */
.nav-acc{margin-bottom:9px;background:#dfe5ef;border:1px solid #cdd6e4;border-radius:12px;overflow:hidden;transition:.15s}
.nav-acc.open{background:var(--card);border-color:var(--navy);box-shadow:0 4px 14px rgba(15,23,42,.07)}
.nav-acc-head{width:100%;display:flex;align-items:flex-start;gap:8px;text-align:left;background:transparent;
  border:none;cursor:pointer;padding:11px 13px;transition:.12s}
.nav-acc-head:hover{background:rgba(15,23,42,.04)}
.nav-acc.open .nav-acc-head{border-bottom:1px solid var(--line)}
.nav-acc-ico{font-size:18px;line-height:1;flex-shrink:0;margin-top:1px;width:24px;text-align:center;
  filter:drop-shadow(0 1px 1px rgba(15,39,71,.12))}
.nav-acc-ttl{flex:1;min-width:0}
.nav-acc-g{display:block;font-size:10.5px;font-weight:800;letter-spacing:.9px;text-transform:uppercase;color:var(--navy)}
.nav-acc-cap{display:block;font-size:10.5px;color:var(--muted);font-weight:500;margin-top:2px;line-height:1.35;white-space:normal}
.nav-acc-head .nav-badge{margin-left:0}
.nav-acc-chev{transition:transform .2s;color:var(--muted);font-size:12px;flex-shrink:0;margin-top:2px}
.nav-acc.open .nav-acc-chev{transform:rotate(180deg)}
.nav-acc-body{display:none;padding:6px 8px 8px}
.nav-acc.open .nav-acc-body{display:block;animation:navAccIn .18s ease}
@keyframes navAccIn{from{opacity:0;transform:translateY(-4px)}to{opacity:1;transform:none}}

.main{flex:1;min-width:0;padding:26px 30px;max-width:1240px;width:100%}
.page-head{display:flex;align-items:flex-end;justify-content:space-between;margin-bottom:22px;gap:16px;flex-wrap:wrap}
.page-head h1{margin:0;font-size:23px;font-weight:700;letter-spacing:-.2px}
.page-head .sub{color:var(--muted);font-size:13px;margin-top:4px}

/* ===== Buttons ===== */
.btn{display:inline-flex;align-items:center;gap:7px;padding:9px 16px;border-radius:9px;
  font-weight:600;font-size:13px;transition:.15s;border:1px solid transparent;white-space:nowrap}
.btn-primary{background:var(--navy);color:#fff}
.btn-primary:hover{background:var(--navy-700)}
.btn-gold{background:linear-gradient(135deg,var(--gold),#b08c33);color:#fff}
.btn-gold:hover{filter:brightness(1.06)}
.btn-ghost{background:#fff;border-color:var(--line);color:var(--ink)}
.btn-ghost:hover{background:var(--bg)}
.btn-sm{padding:6px 11px;font-size:12px}

/* ===== Cards ===== */
.card{background:var(--card);border:1px solid var(--line);border-radius:var(--radius);box-shadow:var(--shadow)}
.card-pad{padding:18px}
.grid{display:grid;gap:16px}
.stat-grid{grid-template-columns:repeat(4,1fr)}
.stat{padding:18px;position:relative;overflow:hidden}
.stat .label{color:var(--muted);font-size:12.5px;font-weight:600}
.stat .val{font-size:28px;font-weight:800;margin-top:6px;letter-spacing:-.5px}
.stat .delta{font-size:12px;font-weight:600;margin-top:6px;display:inline-flex;gap:4px;align-items:center}
.delta.up{color:var(--green)} .delta.down{color:var(--red)}
.stat .ico-bubble{position:absolute;top:16px;right:16px;width:42px;height:42px;border-radius:12px;
  display:grid;place-items:center;font-size:20px}
.ib-blue{background:var(--blue-bg)} .ib-green{background:var(--green-bg)}
.ib-gold{background:#f6edd5} .ib-red{background:var(--red-bg)}

.section-title{font-size:15px;font-weight:700;margin:0 0 2px}
.row{display:flex;gap:16px}
.col{flex:1;min-width:0}

/* ===== Table ===== */
.card:has(> table.tbl){overflow-x:auto}
table.tbl{width:100%;border-collapse:collapse;font-size:13px;min-width:520px}
.tbl thead th{text-align:left;color:var(--muted);font-weight:600;font-size:11.5px;
  text-transform:uppercase;letter-spacing:.5px;padding:11px 14px;border-bottom:1px solid var(--line)}
.tbl tbody td{padding:13px 14px;border-bottom:1px solid var(--line)}
.tbl tbody tr{transition:.1s}
.tbl tbody tr:hover{background:var(--bg);cursor:pointer}
.tbl tbody tr:last-child td{border-bottom:none}
.mono{font-family:'Consolas',monospace;font-size:12.5px;color:var(--navy-600);font-weight:600}

/* ===== Badges / chips ===== */
.badge{display:inline-flex;align-items:center;gap:5px;padding:4px 10px;border-radius:20px;
  font-size:11.5px;font-weight:700;letter-spacing:.2px}
.b-green{background:var(--green-bg);color:var(--green)}
.b-amber{background:var(--amber-bg);color:var(--amber)}
.b-red{background:var(--red-bg);color:var(--red)}
.b-blue{background:var(--blue-bg);color:var(--blue)}
.b-gray{background:#eef1f6;color:var(--muted)}
.dot{width:8px;height:8px;border-radius:50%}
.dot.green{background:var(--green)} .dot.amber{background:var(--amber)} .dot.red{background:var(--red)}

.chip{display:inline-flex;align-items:center;gap:6px;background:var(--bg);border:1px solid var(--line);
  padding:6px 11px;border-radius:8px;font-size:12.5px;font-weight:500}

/* ===== Avatar list ===== */
.avset{display:flex}
.avset .avatar{margin-left:-8px;border:2px solid #fff}
.avset .avatar:first-child{margin-left:0}

/* ===== Kanban ===== */
.kanban{display:flex;gap:14px;overflow-x:auto;padding-bottom:10px}
.kcol{min-width:260px;width:260px;flex-shrink:0;background:#eef1f6;border-radius:12px;padding:10px}
.kcol-head{display:flex;align-items:center;justify-content:space-between;padding:6px 8px 10px;font-weight:700;font-size:13px}
.kcol-head .count{background:#fff;color:var(--muted);font-size:11px;border-radius:10px;padding:2px 8px;font-weight:700}
.kcard{background:#fff;border-radius:10px;padding:12px;margin-bottom:9px;box-shadow:var(--shadow);
  border-left:4px solid var(--line);cursor:pointer;transition:.12s}
.kcard:hover{transform:translateY(-2px);box-shadow:var(--shadow-lg)}
.kcard.green{border-left-color:var(--green)}
.kcard.amber{border-left-color:var(--amber)}
.kcard.red{border-left-color:var(--red)}
.kcard .kc-type{font-size:11px;color:var(--muted);font-weight:600;text-transform:uppercase;letter-spacing:.4px}
.kcard .kc-title{font-weight:700;font-size:13.5px;margin:3px 0 8px}
.kcard .kc-foot{display:flex;align-items:center;justify-content:space-between;margin-top:8px}

/* ===== Timeline / stepper ===== */
.timeline{position:relative;padding-left:8px}
.tl-item{display:flex;gap:14px;padding-bottom:4px;position:relative}
.tl-item:not(:last-child)::before{content:"";position:absolute;left:13px;top:28px;bottom:-4px;width:2px;background:var(--line)}
.tl-item.done:not(:last-child)::before{background:var(--green)}
.tl-mark{width:28px;height:28px;border-radius:50%;flex-shrink:0;display:grid;place-items:center;
  font-size:13px;background:#fff;border:2px solid var(--line);color:var(--muted);z-index:1}
.tl-item.done .tl-mark{background:var(--green);border-color:var(--green);color:#fff}
.tl-item.active .tl-mark{background:var(--blue);border-color:var(--blue);color:#fff;
  box-shadow:0 0 0 4px var(--blue-bg)}
.tl-body{padding-bottom:18px;flex:1}
.tl-body .t{font-weight:700;font-size:13.5px}
.tl-body .m{color:var(--muted);font-size:12px;margin-top:2px}

/* ===== Progress stepper (client, horizontal) ===== */
.stepper{display:flex;align-items:flex-start;justify-content:space-between;margin:8px 0;position:relative}
.step{flex:1;text-align:center;position:relative;z-index:1}
.step .bubble{width:48px;height:48px;border-radius:50%;margin:0 auto 9px;display:grid;place-items:center;
  font-size:22px;background:#fff;border:3px solid var(--line);transition:.2s}
.step.done .bubble{background:var(--green-bg);border-color:var(--green)}
.step.active .bubble{background:var(--blue-bg);border-color:var(--blue);box-shadow:0 0 0 5px rgba(42,111,176,.12)}
.step .lbl{font-size:12.5px;font-weight:600}
.step .sub{font-size:11px;color:var(--muted);margin-top:2px}
.step.todo .lbl{color:var(--muted)}
.stepper::before{content:"";position:absolute;top:24px;left:8%;right:8%;height:3px;background:var(--line);z-index:0}
.stepper .progress-line{position:absolute;top:24px;left:8%;height:3px;background:var(--green);z-index:0;transition:.4s}

/* ===== Progress bar ===== */
.pbar{height:8px;background:#eef1f6;border-radius:8px;overflow:hidden}
.pbar > span{display:block;height:100%;border-radius:8px;background:linear-gradient(90deg,var(--navy-600),var(--blue))}
.pbar.gold > span{background:linear-gradient(90deg,var(--gold),#b08c33)}
.pbar.green > span{background:var(--green)}

/* ===== Client portal ===== */
.portal-hero{
  background:linear-gradient(120deg,var(--navy),var(--navy-600));
  color:#fff;border-radius:18px;padding:30px 34px;margin-bottom:24px;position:relative;overflow:hidden;
}
.portal-hero::after{content:"⚖️";position:absolute;right:30px;top:50%;transform:translateY(-50%);
  font-size:120px;opacity:.08}
.portal-hero h1{margin:0 0 6px;font-size:26px}
.portal-hero p{margin:0;color:#cdd8e8;max-width:540px}
.svc-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:18px}
.svc-card{background:#fff;border:1px solid var(--line);border-radius:var(--radius);padding:20px;
  transition:.15s;cursor:pointer;box-shadow:var(--shadow)}
.svc-card:hover{transform:translateY(-3px);box-shadow:var(--shadow-lg);border-color:var(--gold)}
.svc-card .emoji{font-size:32px;margin-bottom:10px}
.svc-card h3{margin:0 0 6px;font-size:16px}
.svc-card .desc{color:var(--muted);font-size:13px;min-height:38px}
.svc-meta{display:flex;gap:14px;margin-top:14px;padding-top:14px;border-top:1px solid var(--line);font-size:12px}
.svc-meta b{display:block;color:var(--ink);font-size:13px}
.svc-meta span{color:var(--muted)}

.doc-item{display:flex;align-items:center;gap:12px;padding:12px 14px;border:1px solid var(--line);
  border-radius:10px;margin-bottom:9px;background:#fff}
.doc-item .ck{width:24px;height:24px;border-radius:7px;display:grid;place-items:center;font-size:13px;flex-shrink:0}
.ck.ok{background:var(--green-bg);color:var(--green)}
.ck.no{background:var(--red-bg);color:var(--red)}
.doc-item .name{font-weight:600;flex:1}
.doc-item .st{font-size:12px;color:var(--muted)}

/* ===== Misc ===== */
.searchbar{display:flex;align-items:center;gap:10px;background:#fff;border:1px solid var(--line);
  border-radius:11px;padding:11px 15px;box-shadow:var(--shadow)}
.searchbar input{border:none;outline:none;flex:1;font-size:14.5px;background:transparent}
.searchbar .ico{font-size:18px;color:var(--muted)}
.filterbar{display:flex;gap:9px;flex-wrap:wrap;margin-bottom:16px}
.fchip{padding:7px 14px;border-radius:9px;background:#fff;border:1px solid var(--line);
  font-size:12.5px;font-weight:600;color:var(--muted);cursor:pointer;transition:.12s}
.fchip:hover{border-color:var(--navy-600)}
.fchip.active{background:var(--navy);color:#fff;border-color:var(--navy)}

.kv{display:grid;grid-template-columns:130px 1fr;gap:8px 14px;font-size:13px}
.kv dt{color:var(--muted);font-weight:600}
.kv dd{margin:0;font-weight:600}

.qr{width:110px;height:110px;border-radius:10px;background:
  repeating-conic-gradient(var(--ink) 0% 25%, #fff 0% 50%) 50%/14px 14px;
  border:6px solid #fff;box-shadow:var(--shadow);position:relative}
.qr::after{content:"";position:absolute;inset:34px;background:#fff;border-radius:4px}

.note{background:var(--amber-bg);border:1px solid #f0d9a8;border-radius:10px;padding:12px 14px;
  font-size:12.5px;color:#8a6313;display:flex;gap:9px}

.bars{display:flex;align-items:flex-end;gap:10px;height:130px;padding-top:10px}
.bars .bar{flex:1;background:linear-gradient(180deg,var(--blue),var(--navy-600));border-radius:6px 6px 0 0;
  position:relative;min-height:6px;transition:.3s}
.bars .bar span{position:absolute;bottom:-22px;left:0;right:0;text-align:center;font-size:11px;color:var(--muted);font-weight:600}
.bars .bar b{position:absolute;top:-20px;left:0;right:0;text-align:center;font-size:11px;font-weight:700}

.empty{text-align:center;padding:50px 20px;color:var(--muted)}
.empty .e-ico{font-size:46px;margin-bottom:10px;opacity:.5}

/* ===== Modal ===== */
.modal-bg{position:fixed;inset:0;background:rgba(15,39,71,.45);backdrop-filter:blur(2px);
  z-index:100;display:grid;place-items:center;padding:20px;animation:fade .15s}
.modal{background:#fff;border-radius:16px;max-width:560px;width:100%;box-shadow:var(--shadow-lg);
  max-height:88vh;overflow-y:auto;animation:pop .18s}
.modal-head{padding:20px 22px;border-bottom:1px solid var(--line);display:flex;align-items:center;justify-content:space-between}
.modal-head h3{margin:0;font-size:18px}
.modal-body{padding:22px}
.modal-foot{padding:16px 22px;border-top:1px solid var(--line);display:flex;justify-content:flex-end;gap:10px}
.x{font-size:22px;color:var(--muted);line-height:1;cursor:pointer}
@keyframes fade{from{opacity:0}} @keyframes pop{from{transform:scale(.96);opacity:0}}

/* ===== Form ===== */
.field{margin-bottom:15px}
.field label{display:block;font-size:12.5px;font-weight:600;margin-bottom:6px}
.field input,.field select,.field textarea{
  width:100%;padding:10px 12px;border:1px solid var(--line);border-radius:9px;font-size:13.5px;
  font-family:inherit;outline:none;transition:.12s}
.field input:focus,.field select:focus,.field textarea:focus{border-color:var(--navy-600);box-shadow:0 0 0 3px var(--blue-bg)}

.toast{position:fixed;bottom:24px;right:24px;background:var(--navy);color:#fff;padding:14px 20px;
  border-radius:11px;box-shadow:var(--shadow-lg);z-index:200;display:flex;align-items:center;gap:10px;
  font-weight:600;font-size:13.5px;animation:slidein .25s}
@keyframes slidein{from{transform:translateY(20px);opacity:0}}

.upload{border:2px dashed var(--line);border-radius:11px;padding:22px;text-align:center;color:var(--muted);
  cursor:pointer;transition:.12s}
.upload:hover{border-color:var(--navy-600);background:var(--bg)}

/* task list */
.task{display:flex;align-items:center;gap:13px;padding:13px 15px;border:1px solid var(--line);
  border-radius:11px;margin-bottom:9px;background:#fff;transition:.12s}
.task.done{opacity:.55}
.task .cb{width:22px;height:22px;border-radius:6px;border:2px solid var(--line);flex-shrink:0;cursor:pointer;
  display:grid;place-items:center;font-size:13px;color:#fff;transition:.12s}
.task.done .cb{background:var(--green);border-color:var(--green)}
.task .tt{flex:1;font-weight:600}
.task.done .tt{text-decoration:line-through}
.prio{font-size:10.5px;font-weight:700;padding:3px 9px;border-radius:20px;text-transform:uppercase;letter-spacing:.4px}
.prio.tinggi{background:var(--red-bg);color:var(--red)}
.prio.sedang{background:var(--amber-bg);color:var(--amber)}
.prio.rendah{background:#eef1f6;color:var(--muted)}

/* notif drawer */
.notif-drawer{position:fixed;top:0;right:0;width:380px;max-width:90vw;height:100vh;background:#fff;z-index:120;
  box-shadow:var(--shadow-lg);display:flex;flex-direction:column;animation:slidedrawer .2s}
@keyframes slidedrawer{from{transform:translateX(100%)}}
.notif-item{padding:14px 18px;border-bottom:1px solid var(--line);display:flex;gap:12px}
.notif-item.unread{background:var(--blue-bg)}
.notif-kanal{width:36px;height:36px;border-radius:9px;display:grid;place-items:center;font-size:16px;flex-shrink:0}
.k-wa{background:var(--green-bg)} .k-email{background:var(--blue-bg)}

/* akta editor */
.akta-paper{background:#fff;border:1px solid var(--line);border-radius:10px;padding:26px 30px;
  font-family:'Times New Roman',Georgia,serif;font-size:14px;line-height:1.9;white-space:pre-wrap;min-height:320px}
.akta-paper mark{background:var(--gold-soft);padding:1px 3px;border-radius:3px;font-style:normal}
.ver-item{display:flex;gap:11px;padding:11px 0;border-bottom:1px solid var(--line)}
.ver-tag{font-weight:800;color:var(--navy-600);font-family:'Consolas',monospace}

/* integration card */
.intg{display:flex;gap:15px;align-items:flex-start;padding:18px}
.intg .ic{width:48px;height:48px;border-radius:12px;background:var(--bg);display:grid;place-items:center;font-size:24px;flex-shrink:0}

@media(max-width:1080px){
  .stat-grid{grid-template-columns:repeat(2,1fr)}
  .svc-grid{grid-template-columns:repeat(2,1fr)}
  .sidebar{width:64px}.nav-item span.txt,.nav-group-label{display:none}
  .nav-item{justify-content:center}
  /* Mode rel mini: sembunyikan judul/caption accordion, tampilkan semua ikon */
  .nav-acc-head{display:none}
  .nav-acc-body{display:block!important;padding:0}
  .nav-acc{background:transparent;border:none;box-shadow:none;margin-bottom:0}
}
@media(max-width:680px){
  .stat-grid,.svc-grid{grid-template-columns:1fr}
  .row{flex-direction:column}
  .main{padding:18px}
  .role-switch button{padding:7px 9px;font-size:12px}
}

/* ===== Topbar global search ===== */
.gsearch{width:340px;max-width:34vw;background:rgba(255,255,255,.14);border:1px solid rgba(255,255,255,.2);
  color:#fff;border-radius:10px;padding:9px 13px;font-size:13px;outline:none;transition:.15s}
.gsearch::placeholder{color:#c2cee1}
.gsearch:focus{background:#fff;color:var(--ink);border-color:#fff}
.gsearch:focus::placeholder{color:var(--muted)}

/* ===== Mobile native: bottom navigation + sheet (Modul K) ===== */
.app-bottomnav{display:none}
.app-sheet-bg{position:fixed;inset:0;background:rgba(15,39,71,.45);z-index:140;opacity:0;transition:.2s;pointer-events:none}
.app-sheet-bg.open{opacity:1;pointer-events:auto}
.app-sheet{position:fixed;left:0;right:0;bottom:0;z-index:141;background:#fff;border-radius:20px 20px 0 0;
  box-shadow:0 -16px 50px rgba(15,39,71,.3);transform:translateY(100%);transition:transform .28s cubic-bezier(.4,0,.2,1);
  max-height:82vh;overflow-y:auto;padding:8px 16px calc(20px + env(safe-area-inset-bottom))}
.app-sheet.open{transform:translateY(0)}
.app-sheet .grip{width:42px;height:5px;border-radius:5px;background:var(--line);margin:10px auto 12px}
.app-sheet .sheet-user{display:flex;align-items:center;gap:12px;padding:8px 6px 16px;border-bottom:1px solid var(--line);margin-bottom:8px}
.app-sheet .m-item{display:flex;align-items:center;gap:13px;padding:13px 10px;border-radius:11px;font-weight:600;font-size:14px;color:var(--ink)}
.app-sheet .m-item:hover,.app-sheet .m-item.active{background:var(--bg);color:var(--navy)}
.app-sheet .m-item .ico{width:22px;text-align:center}
.app-sheet .m-group{font-size:10.5px;font-weight:700;letter-spacing:1px;color:var(--muted);text-transform:uppercase;padding:12px 10px 4px}

/* ===== Owner mobile (kartu native, tanpa tabel lebar) ===== */
.o-stats{display:grid;grid-template-columns:repeat(auto-fit,minmax(150px,1fr));gap:10px;margin-bottom:16px}
.o-stat{background:var(--card);border:1px solid var(--line);border-radius:16px;padding:15px;box-shadow:var(--shadow);position:relative;overflow:hidden}
.o-stat .v{font-size:23px;font-weight:800;line-height:1.05;letter-spacing:-.5px}
.o-stat .l{font-size:11.5px;color:var(--muted);margin-top:4px;display:flex;align-items:center;gap:5px}
.o-stat.tap{cursor:pointer;transition:.15s}.o-stat.tap:active{transform:scale(.98)}
.o-stat .arr{position:absolute;top:12px;right:13px;color:var(--line);font-size:14px}
.o-list{display:flex;flex-direction:column;gap:10px}
.o-card{background:var(--card);border:1px solid var(--line);border-radius:16px;padding:13px 15px;box-shadow:var(--shadow)}
.o-card .top{display:flex;justify-content:space-between;align-items:flex-start;gap:12px}
.o-card .ttl{font-weight:700;color:var(--ink);font-size:14.5px;line-height:1.3}
.o-card .sub{font-size:12px;color:var(--muted);margin-top:2px}
.o-card .rt{text-align:right;flex-shrink:0}
.o-card .meta{display:flex;flex-wrap:wrap;gap:6px;margin-top:11px}
.o-mc{background:var(--bg);border:1px solid var(--line);border-radius:9px;padding:5px 9px;font-size:11px;font-weight:600;color:var(--muted);text-align:center;flex:1;min-width:54px}
.o-mc b{display:block;font-size:14px;color:var(--ink);font-weight:800}
.o-card .act{margin-top:11px;display:flex;gap:8px}
.o-sec{font-size:12px;font-weight:700;letter-spacing:.04em;text-transform:uppercase;color:var(--muted);margin:18px 2px 9px}
.o-money{font-size:13px;font-weight:800;white-space:nowrap}
/* alert actionable */
.o-alert{display:flex;align-items:center;gap:12px;padding:12px 14px;border-radius:14px;background:var(--card);border:1px solid var(--line);box-shadow:var(--shadow);cursor:pointer;transition:.15s}
.o-alert:active{transform:scale(.99)}
.o-alert .ai{font-size:20px;flex-shrink:0}
.o-alert .ax{flex:1;font-size:13px;color:var(--ink)}
.o-alert .an{font-weight:800;font-size:16px;min-width:26px;text-align:center}
.o-alert .arr{color:var(--line)}
/* mini bar chart penerimaan */
.o-bars{display:flex;align-items:flex-end;gap:7px;height:96px;margin-top:8px}
.o-bars .b{flex:1;display:flex;flex-direction:column;align-items:center;gap:5px;justify-content:flex-end;height:100%}
.o-bars .b i{display:block;width:100%;max-width:28px;background:linear-gradient(180deg,var(--gold),var(--gold-600));border-radius:6px 6px 0 0;min-height:3px}
.o-bars .b u{font-size:9.5px;color:var(--muted);font-style:normal}
.o-bars .b em{font-size:8.5px;color:var(--muted-2);font-style:normal}
/* komposisi layanan */
.o-comp{display:flex;flex-direction:column;gap:9px;margin-top:4px}
.o-comp .cr{font-size:12.5px}
.o-comp .ch{display:flex;justify-content:space-between;margin-bottom:3px}
.o-comp .bar{height:8px;background:var(--bg);border-radius:5px;overflow:hidden}
.o-comp .bar i{display:block;height:100%;background:linear-gradient(90deg,var(--navy),var(--navy-600));border-radius:5px}

/* ===== Onboarding coach-marks (tur) ===== */
.tour-ov{position:fixed;border-radius:12px;box-shadow:0 0 0 9999px rgba(15,23,42,.66);z-index:55;pointer-events:none;transition:left .2s,top .2s,width .2s,height .2s}
.tour-spot{box-shadow:0 0 0 3px var(--gold), 0 8px 22px rgba(0,0,0,.4)!important;border-radius:10px;position:relative;z-index:60;background:rgba(255,255,255,.10)}
.tour-tip{position:fixed;z-index:130;width:266px;max-width:calc(100vw - 16px);background:var(--card);
  border:1px solid var(--line);border-radius:14px;box-shadow:var(--shadow-lg);padding:15px 17px;animation:tipin .16s ease}
.tour-tip .tt-step{font-size:11px;font-weight:700;color:var(--gold);text-transform:uppercase;letter-spacing:.08em}
.tour-tip .tt-title{font-weight:800;color:var(--navy);font-size:15.5px;margin:3px 0 6px}
.tour-tip .tt-body{font-size:13px;color:var(--muted);line-height:1.55}
.tour-tip .tt-act{display:flex;gap:6px;justify-content:flex-end;margin-top:13px;flex-wrap:wrap}
@keyframes tipin{from{opacity:0;transform:translateY(5px)}to{opacity:1;transform:none}}

/* ===== Accordion (Wiki / FAQ) ===== */
.faq-list{display:flex;flex-direction:column;gap:10px}
.faq{background:var(--card);border:1px solid var(--line);border-radius:12px;box-shadow:var(--shadow);overflow:hidden}
.faq summary{list-style:none;cursor:pointer;display:flex;align-items:center;justify-content:space-between;gap:14px;
  padding:14px 18px;font-weight:700;font-size:14.5px;color:var(--navy)}
.faq summary::-webkit-details-marker{display:none}
.faq summary svg{width:18px;height:18px;color:var(--gold);flex-shrink:0;transition:transform .2s}
.faq[open] summary svg{transform:rotate(180deg)}
.faq[open] summary{border-bottom:1px solid var(--line)}
.faq .faq-a{padding:14px 18px;color:var(--muted);font-size:13.5px;line-height:1.7}

@media(max-width:680px){
  body{padding-bottom:calc(80px + env(safe-area-inset-bottom))}
  .sidebar{display:none}
  .gsearch{display:none}
  .main{padding:16px 14px;max-width:100%}
  .topbar{padding:0 14px;gap:10px;padding-top:env(safe-area-inset-top);height:calc(56px + env(safe-area-inset-top))}
  .topbar .brand small{display:none}
  .brand{font-size:14px}
  .page-head h1{font-size:19px}
  .kanban{gap:10px}
  /* Bottom navigation bar */
  /* Floating "dynamic island" dock — glass pill mengambang */
  .app-bottomnav{display:flex;position:fixed;left:50%;transform:translateX(-50%);
    bottom:calc(10px + env(safe-area-inset-bottom));z-index:90;
    background:rgba(15,23,42,.80);backdrop-filter:blur(20px) saturate(1.4);-webkit-backdrop-filter:blur(20px) saturate(1.4);
    border:1px solid rgba(255,255,255,.12);border-radius:22px;padding:4px;gap:1px;
    max-width:calc(100vw - 24px);
    box-shadow:0 8px 24px rgba(0,0,0,.28), inset 0 1px 0 rgba(255,255,255,.08)}
  .app-bottomnav a{position:relative;display:flex;flex-direction:column;align-items:center;gap:2px;
    padding:5px 10px;min-width:48px;border-radius:15px;cursor:pointer;
    color:rgba(255,255,255,.6);font-size:9px;font-weight:600;
    transition:color .25s ease, background .3s ease, transform .2s ease}
  .app-bottomnav a .ico{font-size:17px;line-height:1;transition:transform .3s cubic-bezier(.34,1.56,.64,1)}
  .app-bottomnav a:active{transform:scale(.9)}
  .app-bottomnav a.active{color:var(--navy);
    background:linear-gradient(135deg,var(--gold,#d8b768),var(--gold-600,#c8a24a));
    box-shadow:0 4px 12px rgba(200,162,74,.45);animation:dockPop .38s cubic-bezier(.34,1.56,.64,1)}
  .app-bottomnav a.active .ico{transform:scale(1.1)}
  @keyframes dockPop{0%{transform:scale(.74);opacity:.5}60%{transform:scale(1.06)}100%{transform:scale(1);opacity:1}}
  .app-bottomnav .bdot{position:absolute;top:1px;right:5px;background:var(--red);color:#fff;
    font-size:8.5px;font-weight:700;min-width:14px;height:14px;border-radius:7px;display:grid;place-items:center;padding:0 3px;
    border:1.5px solid rgba(15,23,42,.9)}
}
