/* =====================================================================
   SinarBea — Design System
   Tema: Navy / Biru / Netral · Aksen amber (matahari) · Enterprise
   ===================================================================== */

:root {
  --navy-900: #06182E;
  --navy-800: #0A2540;
  --navy-700: #0F3257;
  --navy-600: #14406F;
  --blue-600: #1D5FD8;
  --blue-500: #2D72F0;
  --blue-50:  #EAF1FE;
  --amber:    #F5A623;
  --amber-soft:#FEF3DC;

  --green-600:#10885A; --green-50:#E6F6EF;
  --amber-600:#B5790B; --amber-bg:#FCF3E2;
  --red-600:#D14343;   --red-50:#FBEAEA;
  --teal-600:#0E8C99;  --teal-50:#E3F6F8;
  --slate-600:#5A6B82; --slate-50:#EEF2F7;

  --ink-900:#0E1B2E;
  --ink-700:#33425B;
  --ink-500:#647189;
  --ink-400:#8A96AB;
  --line:#E4E9F1;
  --bg:#F4F7FB;
  --card:#FFFFFF;

  --r-sm:10px; --r:14px; --r-lg:20px; --r-xl:26px;
  --sh-sm:0 1px 2px rgba(13,38,76,.06), 0 1px 3px rgba(13,38,76,.04);
  --sh:0 4px 16px rgba(13,38,76,.08);
  --sh-lg:0 12px 40px rgba(13,38,76,.14);
  --sidebar-w:248px;
  --topbar-h:62px;
  --font:"Plus Jakarta Sans", system-ui, -apple-system, "Segoe UI", Roboto, sans-serif;
}

*{box-sizing:border-box;margin:0;padding:0}
html,body{height:100%}
body{
  font-family:var(--font);
  background:var(--bg);
  color:var(--ink-900);
  -webkit-font-smoothing:antialiased;
  font-size:15px; line-height:1.5;
}
button{font-family:inherit;cursor:pointer;border:none;background:none}
a{color:inherit;text-decoration:none}
input,select,textarea{font-family:inherit;font-size:15px}
::selection{background:var(--blue-50)}

/* ---------- Scrollbar ---------- */
::-webkit-scrollbar{width:10px;height:10px}
::-webkit-scrollbar-thumb{background:#cdd6e3;border-radius:20px;border:3px solid var(--bg)}

/* =====================================================================
   LOGIN / LANDING
   ===================================================================== */
.auth{
  min-height:100vh;min-height:100dvh;display:grid;
  grid-template-columns:1.1fr .9fr;
}
.auth__brandside{
  position:relative;overflow:hidden;
  background:radial-gradient(1200px 600px at 80% -10%, var(--navy-600), transparent),
             linear-gradient(160deg, var(--navy-800), var(--navy-900));
  color:#fff;padding:48px;display:flex;flex-direction:column;justify-content:space-between;
}
.auth__sun{position:absolute;top:-120px;right:-120px;width:420px;height:420px;border-radius:50%;
  background:radial-gradient(circle at center, rgba(245,166,35,.35), rgba(245,166,35,0) 62%);}
.auth__brandtop{display:flex;align-items:center;gap:12px;position:relative;z-index:2}
.auth__brandmid{position:relative;z-index:2;max-width:460px}
.auth__brandmid h1{font-size:34px;line-height:1.18;font-weight:800;letter-spacing:-.02em;margin-bottom:16px}
.auth__brandmid p{color:#B9C7DC;font-size:15.5px;line-height:1.7}
.auth__points{list-style:none;margin-top:28px;display:grid;gap:14px}
.auth__points li{display:flex;gap:12px;align-items:flex-start;color:#D6E0EE;font-size:14.5px}
.auth__points .tick{flex:0 0 22px;height:22px;border-radius:50%;background:rgba(245,166,35,.18);
  color:var(--amber);display:grid;place-items:center;font-size:12px;margin-top:1px}
.auth__brandfoot{position:relative;z-index:2;color:#7E92AE;font-size:12.5px}
.auth__formside{display:flex;align-items:center;justify-content:center;padding:40px 24px;background:var(--card)}
.auth__form{width:100%;max-width:368px}
.auth__form h2{font-size:23px;font-weight:800;letter-spacing:-.01em}
.auth__form .sub{color:var(--ink-500);margin:6px 0 26px;font-size:14px}
.field{margin-bottom:16px}
.field label{display:block;font-size:13px;font-weight:600;color:var(--ink-700);margin-bottom:7px}
.field input{width:100%;padding:12px 14px;border:1.5px solid var(--line);border-radius:var(--r-sm);
  background:#FBFCFE;transition:.15s;color:var(--ink-900)}
.field input:focus{outline:none;border-color:var(--blue-500);background:#fff;box-shadow:0 0 0 4px var(--blue-50)}
.demo-hint{background:var(--blue-50);border:1px dashed #B9CFF6;color:var(--navy-700);
  font-size:12.5px;border-radius:var(--r-sm);padding:11px 13px;margin-bottom:20px;line-height:1.6}
.demo-hint b{color:var(--navy-800)}

/* =====================================================================
   APP SHELL
   ===================================================================== */
.shell{display:grid;grid-template-columns:var(--sidebar-w) 1fr;min-height:100vh;min-height:100dvh}

.sidebar{
  background:linear-gradient(180deg,var(--navy-800),var(--navy-900));
  color:#C6D2E4;padding:18px 14px;position:sticky;top:0;height:100vh;height:100dvh;
  display:flex;flex-direction:column;overflow-y:auto;
}
.sidebar__brand{display:flex;align-items:center;gap:11px;padding:6px 8px 18px}
.sidebar__brand .logo-txt b{color:#fff;font-size:15.5px;font-weight:800;display:block;letter-spacing:-.01em;line-height:1}
.sidebar__brand .logo-txt span{color:#7E93B2;font-size:10.5px;letter-spacing:.06em;text-transform:uppercase}
.nav-group{font-size:10.5px;text-transform:uppercase;letter-spacing:.08em;color:#5F7493;padding:16px 12px 7px;font-weight:700}
.nav-item{display:flex;align-items:center;gap:12px;padding:11px 12px;border-radius:11px;color:#B7C5DA;
  font-size:14px;font-weight:500;transition:.14s;margin-bottom:2px;position:relative}
.nav-item:hover{background:rgba(255,255,255,.06);color:#fff}
.nav-item.active{background:linear-gradient(90deg,var(--blue-600),var(--blue-500));color:#fff;
  box-shadow:0 6px 16px rgba(29,95,216,.35)}
.nav-item .ico{flex:0 0 20px;display:grid;place-items:center;opacity:.95}
.nav-item .badge-n{margin-left:auto;background:var(--amber);color:#3a2a00;font-size:11px;font-weight:800;
  min-width:20px;height:20px;border-radius:20px;display:grid;place-items:center;padding:0 6px}
.sidebar__foot{margin-top:auto;padding:14px 10px 4px;border-top:1px solid rgba(255,255,255,.08)}
.sidebar__user{display:flex;align-items:center;gap:11px}
.sidebar__user .ava{flex:0 0 38px;height:38px;border-radius:11px;background:linear-gradient(135deg,var(--amber),#e08e0c);
  color:#3a2a00;font-weight:800;display:grid;place-items:center;font-size:14px}
.sidebar__user b{color:#fff;font-size:13px;display:block;line-height:1.2}
.sidebar__user span{color:#7E93B2;font-size:11px}

/* ---------- Main ---------- */
.main{display:flex;flex-direction:column;min-width:0}
.topbar{height:var(--topbar-h);background:rgba(255,255,255,.85);backdrop-filter:blur(10px);
  border-bottom:1px solid var(--line);display:flex;align-items:center;gap:14px;padding:0 22px;
  position:sticky;top:0;z-index:30}
.topbar__title{display:flex;flex-direction:column;min-width:0}
.topbar__title b{font-size:16px;font-weight:800;letter-spacing:-.01em;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.topbar__title .crumb{font-size:11.5px;color:var(--ink-400)}
.topbar__search{margin-left:auto;position:relative;width:min(320px,34vw)}
.topbar__search input{width:100%;padding:9px 12px 9px 36px;border:1.5px solid var(--line);
  border-radius:30px;background:var(--bg);font-size:13.5px}
.topbar__search input:focus{outline:none;border-color:var(--blue-500);background:#fff}
.topbar__search .si{position:absolute;left:12px;top:50%;transform:translateY(-50%);color:var(--ink-400)}
.topbar__ico{position:relative;width:40px;height:40px;border-radius:11px;display:grid;place-items:center;
  color:var(--ink-700);background:var(--bg)}
.topbar__ico:hover{background:var(--blue-50);color:var(--blue-600)}
.topbar__ico .dot{position:absolute;top:8px;right:9px;width:8px;height:8px;border-radius:50%;
  background:var(--red-600);border:2px solid #fff}
.topbar__menu-btn{display:none}

.content{padding:22px;max-width:1240px;width:100%;margin:0 auto;flex:1}
.page-head{display:flex;align-items:flex-end;justify-content:space-between;gap:14px;margin-bottom:18px;flex-wrap:wrap}
.page-head h1{font-size:22px;font-weight:800;letter-spacing:-.02em}
.page-head p{color:var(--ink-500);font-size:13.5px;margin-top:3px}

/* =====================================================================
   COMPONENTS
   ===================================================================== */
.btn{display:inline-flex;align-items:center;gap:8px;padding:10px 16px;border-radius:11px;font-weight:700;
  font-size:13.5px;transition:.15s;white-space:nowrap;border:1.5px solid transparent}
.btn:active{transform:translateY(1px)}
.btn--primary{background:linear-gradient(135deg,var(--blue-600),var(--blue-500));color:#fff;
  box-shadow:0 6px 16px rgba(29,95,216,.28)}
.btn--primary:hover{filter:brightness(1.06)}
.btn--ghost{background:#fff;color:var(--ink-700);border-color:var(--line)}
.btn--ghost:hover{border-color:var(--blue-500);color:var(--blue-600)}
.btn--soft{background:var(--blue-50);color:var(--blue-600)}
.btn--amber{background:linear-gradient(135deg,var(--amber),#e08e0c);color:#3a2a00;box-shadow:0 6px 16px rgba(245,166,35,.3)}
.btn--sm{padding:7px 12px;font-size:12.5px;border-radius:9px}
.btn--block{width:100%;justify-content:center}

.card{background:var(--card);border:1px solid var(--line);border-radius:var(--r-lg);box-shadow:var(--sh-sm)}
.card__head{display:flex;align-items:center;justify-content:space-between;gap:10px;padding:16px 18px;border-bottom:1px solid var(--line)}
.card__head h3{font-size:14.5px;font-weight:800;letter-spacing:-.01em}
.card__head .sub{font-size:12px;color:var(--ink-400)}
.card__body{padding:16px 18px}

.grid{display:grid;gap:16px}
.grid--kpi{grid-template-columns:repeat(4,1fr)}
.grid--2{grid-template-columns:repeat(2,1fr)}
.grid--3{grid-template-columns:repeat(3,1fr)}
.span-2{grid-column:span 2}

/* KPI */
.kpi{background:var(--card);border:1px solid var(--line);border-radius:var(--r-lg);padding:17px;box-shadow:var(--sh-sm);position:relative;overflow:hidden}
.kpi__ico{width:42px;height:42px;border-radius:12px;display:grid;place-items:center;margin-bottom:14px}
.kpi__ico.blue{background:var(--blue-50);color:var(--blue-600)}
.kpi__ico.amber{background:var(--amber-bg);color:var(--amber-600)}
.kpi__ico.green{background:var(--green-50);color:var(--green-600)}
.kpi__ico.navy{background:#E7EDF6;color:var(--navy-700)}
.kpi__val{font-size:25px;font-weight:800;letter-spacing:-.02em;line-height:1}
.kpi__label{color:var(--ink-500);font-size:13px;margin-top:6px}
.kpi__delta{position:absolute;top:17px;right:17px;font-size:11.5px;font-weight:800;padding:3px 8px;border-radius:20px}
.kpi__delta.up{background:var(--green-50);color:var(--green-600)}
.kpi__delta.down{background:var(--amber-bg);color:var(--amber-600)}
.kpi__sub{font-size:11px;color:var(--ink-400);margin-top:3px}

/* Status badge */
.badge{display:inline-flex;align-items:center;gap:6px;font-size:11.5px;font-weight:700;padding:4px 10px;border-radius:30px;white-space:nowrap}
.badge .d{width:6px;height:6px;border-radius:50%;background:currentColor}
.badge.draft{background:var(--slate-50);color:var(--slate-600)}
.badge.submitted{background:var(--blue-50);color:var(--blue-600)}
.badge.review{background:var(--amber-bg);color:var(--amber-600)}
.badge.approved{background:var(--green-50);color:var(--green-600)}
.badge.completed{background:var(--teal-50);color:var(--teal-600)}
.badge.rejected{background:var(--red-50);color:var(--red-600)}
.badge.aktif{background:var(--green-50);color:var(--green-600)}
.badge.proses{background:var(--amber-bg);color:var(--amber-600)}
.badge.lengkap{background:var(--green-50);color:var(--green-600)}
.badge.kurang{background:var(--red-50);color:var(--red-600)}
.badge.perlu_revisi{background:var(--amber-bg);color:var(--amber-600)}

.chip-ceisa{display:inline-flex;align-items:center;gap:6px;font-size:11px;font-weight:700;padding:3px 8px;border-radius:8px}
.chip-ceisa.synced{background:var(--green-50);color:var(--green-600)}
.chip-ceisa.pending{background:var(--amber-bg);color:var(--amber-600)}
.chip-ceisa.error{background:var(--red-50);color:var(--red-600)}
.chip-ceisa.draft{background:var(--slate-50);color:var(--slate-600)}

/* Table */
.tbl-wrap{overflow-x:auto}
table.tbl{width:100%;border-collapse:collapse;font-size:13.5px;min-width:680px}
.tbl thead th{text-align:left;font-size:11px;text-transform:uppercase;letter-spacing:.05em;color:var(--ink-400);
  font-weight:700;padding:11px 14px;border-bottom:1px solid var(--line);background:#FAFBFD;white-space:nowrap}
.tbl tbody td{padding:13px 14px;border-bottom:1px solid var(--line);vertical-align:middle}
.tbl tbody tr{cursor:pointer;transition:.12s}
.tbl tbody tr:hover{background:var(--blue-50)}
.tbl tbody tr:last-child td{border-bottom:none}
.tbl .id{font-weight:700;color:var(--navy-700);font-size:13px}
.tbl .muted{color:var(--ink-500);font-size:12.5px}
.tbl .num{text-align:right;font-variant-numeric:tabular-nums;font-weight:600}

/* Filter bar */
.filterbar{display:flex;gap:10px;flex-wrap:wrap;align-items:center;margin-bottom:14px}
.filterbar .search{position:relative;flex:1;min-width:180px}
.filterbar .search input{width:100%;padding:9px 12px 9px 34px;border:1.5px solid var(--line);border-radius:11px;background:#fff}
.filterbar .search input:focus{outline:none;border-color:var(--blue-500)}
.filterbar .search .si{position:absolute;left:11px;top:50%;transform:translateY(-50%);color:var(--ink-400)}
.seg{display:inline-flex;background:var(--slate-50);border-radius:11px;padding:4px;gap:2px}
.seg button{padding:7px 13px;border-radius:8px;font-size:12.5px;font-weight:700;color:var(--ink-500)}
.seg button.on{background:#fff;color:var(--blue-600);box-shadow:var(--sh-sm)}
select.flt{padding:9px 30px 9px 12px;border:1.5px solid var(--line);border-radius:11px;background:#fff;font-weight:600;font-size:13px;color:var(--ink-700);
  appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='14' height='14' fill='none' stroke='%23647189' stroke-width='2'%3E%3Cpath d='M3 5l4 4 4-4'/%3E%3C/svg%3E");
  background-repeat:no-repeat;background-position:right 11px center}

/* Timeline */
.timeline{position:relative;padding-left:6px}
.tl-item{display:flex;gap:14px;padding-bottom:20px;position:relative}
.tl-item:last-child{padding-bottom:0}
.tl-item::before{content:"";position:absolute;left:10px;top:24px;bottom:-2px;width:2px;background:var(--line)}
.tl-item:last-child::before{display:none}
.tl-dot{flex:0 0 22px;height:22px;border-radius:50%;display:grid;place-items:center;font-size:11px;z-index:1;
  background:var(--slate-50);color:var(--ink-400);border:2px solid #fff;box-shadow:0 0 0 1px var(--line)}
.tl-item.done .tl-dot{background:var(--green-600);color:#fff;box-shadow:none}
.tl-item.active .tl-dot{background:var(--blue-600);color:#fff;box-shadow:0 0 0 4px var(--blue-50)}
.tl-item.error .tl-dot{background:var(--red-600);color:#fff;box-shadow:0 0 0 4px var(--red-50)}
.tl-body b{font-size:13.5px;font-weight:700;display:block}
.tl-item.active .tl-body b{color:var(--blue-600)}
.tl-item.error .tl-body b{color:var(--red-600)}
.tl-body span{font-size:12px;color:var(--ink-400)}
.tl-body .oleh{color:var(--ink-500);font-weight:600}

/* Progress */
.prog{height:7px;background:var(--slate-50);border-radius:20px;overflow:hidden}
.prog>i{display:block;height:100%;border-radius:20px;background:linear-gradient(90deg,var(--blue-600),var(--blue-500))}
.prog.green>i{background:linear-gradient(90deg,var(--green-600),#15a06c)}
.prog.amber>i{background:linear-gradient(90deg,var(--amber),#e08e0c)}
.prog-row{display:flex;align-items:center;gap:10px}
.prog-row .prog{flex:1}
.prog-row b{font-size:12px;font-variant-numeric:tabular-nums;color:var(--ink-700);min-width:34px;text-align:right}

/* Doc list */
.doc{display:flex;align-items:center;gap:13px;padding:13px 0;border-bottom:1px solid var(--line)}
.doc:last-child{border-bottom:none}
.doc__ico{flex:0 0 40px;height:46px;border-radius:9px;display:grid;place-items:center;background:var(--blue-50);color:var(--blue-600);font-size:11px;font-weight:800}
.doc__ico.red{background:var(--red-50);color:var(--red-600)}
.doc__ico.amber{background:var(--amber-bg);color:var(--amber-600)}
.doc__main{flex:1;min-width:0}
.doc__main b{font-size:13.5px;font-weight:700;display:block}
.doc__main span{font-size:12px;color:var(--ink-400)}

/* Upload area */
.dropzone{border:2px dashed #C2D2EA;border-radius:var(--r);background:linear-gradient(180deg,#FBFDff,#F4F8FE);
  padding:32px 20px;text-align:center;transition:.18s;cursor:pointer}
.dropzone:hover{border-color:var(--blue-500);background:var(--blue-50)}
.dropzone.drag{border-color:var(--blue-500);background:var(--blue-50)}
.dropzone .dz-ico{width:54px;height:54px;border-radius:16px;background:#fff;color:var(--blue-600);
  display:grid;place-items:center;margin:0 auto 12px;box-shadow:var(--sh-sm)}
.dropzone b{font-size:14.5px;display:block}
.dropzone span{font-size:12.5px;color:var(--ink-500);display:block;margin-top:4px}

/* Alerts */
.alert{display:flex;gap:12px;padding:13px 15px;border-radius:var(--r);font-size:13px;align-items:flex-start;border:1px solid}
.alert .ai{flex:0 0 20px;margin-top:1px}
.alert b{display:block;font-weight:700;margin-bottom:1px}
.alert.info{background:var(--blue-50);border-color:#C9DcFc;color:var(--navy-700)}
.alert.success{background:var(--green-50);border-color:#BDE6D3;color:#0c6b47}
.alert.warning{background:var(--amber-bg);border-color:#F1DCAC;color:#8a5d06}
.alert.error{background:var(--red-50);border-color:#F2C9C9;color:#9e2f2f}

/* Notif list */
.notif{display:flex;gap:12px;padding:13px 0;border-bottom:1px solid var(--line)}
.notif:last-child{border-bottom:none}
.notif__ico{flex:0 0 36px;height:36px;border-radius:10px;display:grid;place-items:center}
.notif__ico.warning{background:var(--amber-bg);color:var(--amber-600)}
.notif__ico.success{background:var(--green-50);color:var(--green-600)}
.notif__ico.error{background:var(--red-50);color:var(--red-600)}
.notif__ico.info{background:var(--blue-50);color:var(--blue-600)}
.notif__b b{font-size:13.5px;display:block}
.notif__b p{font-size:12.5px;color:var(--ink-500);margin:2px 0}
.notif__b span{font-size:11px;color:var(--ink-400)}
.notif.unread{position:relative}
.notif.unread::after{content:"";position:absolute;left:-2px;top:18px;width:7px;height:7px;border-radius:50%;background:var(--blue-500)}

/* Service tiles */
.svc{display:flex;flex-direction:column;gap:12px;padding:18px;border-radius:var(--r-lg);background:var(--card);
  border:1px solid var(--line);box-shadow:var(--sh-sm);transition:.16s;cursor:pointer;height:100%}
.svc:hover{box-shadow:var(--sh);transform:translateY(-2px);border-color:#cfddf5}
.svc__ico{width:46px;height:46px;border-radius:13px;display:grid;place-items:center;color:#fff}
.svc__ico.b1{background:linear-gradient(135deg,var(--blue-600),var(--blue-500))}
.svc__ico.b2{background:linear-gradient(135deg,var(--teal-600),#15a7b5)}
.svc__ico.b3{background:linear-gradient(135deg,var(--navy-700),var(--navy-600))}
.svc h4{font-size:15px;font-weight:800;letter-spacing:-.01em}
.svc p{font-size:12.5px;color:var(--ink-500);line-height:1.55;flex:1}
.svc .svc__foot{display:flex;align-items:center;gap:8px;font-size:12.5px;font-weight:700;color:var(--blue-600)}

/* Stat mini row */
.statrow{display:flex;gap:10px;flex-wrap:wrap}
.stat-mini{flex:1;min-width:120px;background:#FAFBFD;border:1px solid var(--line);border-radius:var(--r);padding:13px 14px}
.stat-mini b{font-size:20px;font-weight:800;display:block;letter-spacing:-.02em}
.stat-mini span{font-size:11.5px;color:var(--ink-500)}

/* Detail meta */
.meta-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:14px 22px}
.meta-grid .m label{font-size:11px;text-transform:uppercase;letter-spacing:.04em;color:var(--ink-400);font-weight:700;display:block;margin-bottom:3px}
.meta-grid .m b{font-size:13.5px;font-weight:700}

/* Code/payload */
.code{background:var(--navy-900);color:#CFE0F5;border-radius:var(--r);padding:15px 17px;font-size:12px;
  font-family:ui-monospace,SFMono-Regular,Menlo,monospace;line-height:1.65;overflow-x:auto;white-space:pre}
.code .k{color:#7FB4FF}.code .s{color:#9BE6B0}.code .n{color:#F5C26B}

/* Log rows */
.logrow{display:grid;grid-template-columns:80px 1fr auto;gap:12px;align-items:center;padding:11px 0;border-bottom:1px solid var(--line);font-size:12.5px}
.logrow:last-child{border-bottom:none}
.logrow .t{color:var(--ink-400);font-variant-numeric:tabular-nums}
.logrow .ep{font-family:ui-monospace,Menlo,monospace;font-size:11.5px;color:var(--ink-700)}
.logrow .ep small{color:var(--ink-400);display:block;margin-top:2px}
.kode{font-weight:800;font-size:11.5px;padding:3px 8px;border-radius:7px;font-variant-numeric:tabular-nums}
.kode.ok{background:var(--green-50);color:var(--green-600)}
.kode.warn{background:var(--amber-bg);color:var(--amber-600)}
.kode.err{background:var(--red-50);color:var(--red-600)}

/* Section title */
.sect-title{font-size:13px;font-weight:800;text-transform:uppercase;letter-spacing:.05em;color:var(--ink-400);margin:6px 0 12px}

/* Toast */
#toast-host{position:fixed;bottom:22px;right:22px;z-index:120;display:flex;flex-direction:column;gap:10px}
.toast{display:flex;align-items:center;gap:11px;background:var(--navy-800);color:#fff;padding:13px 16px;border-radius:13px;
  box-shadow:var(--sh-lg);font-size:13.5px;font-weight:600;animation:toastIn .25s ease;max-width:340px}
.toast .ti{flex:0 0 22px;height:22px;border-radius:50%;display:grid;place-items:center;background:rgba(255,255,255,.14)}
.toast.success .ti{background:var(--green-600)}.toast.error .ti{background:var(--red-600)}.toast.info .ti{background:var(--blue-500)}
@keyframes toastIn{from{opacity:0;transform:translateY(16px)}to{opacity:1;transform:none}}

/* Modal / drawer */
#modal-host:empty{display:none}
.overlay{position:fixed;inset:0;background:rgba(8,22,44,.5);backdrop-filter:blur(2px);z-index:100;
  display:flex;align-items:flex-end;justify-content:center;animation:fade .2s}
@media(min-width:721px){.overlay{align-items:center;padding:24px}}
@keyframes fade{from{opacity:0}to{opacity:1}}
.sheet{background:#fff;width:100%;max-width:560px;border-radius:22px 22px 0 0;max-height:92vh;overflow-y:auto;animation:sheetIn .28s cubic-bezier(.2,.8,.2,1)}
@media(min-width:721px){.sheet{border-radius:22px}}
@keyframes sheetIn{from{transform:translateY(40px);opacity:.6}to{transform:none;opacity:1}}
.sheet__head{display:flex;align-items:center;justify-content:space-between;padding:18px 20px;border-bottom:1px solid var(--line);position:sticky;top:0;background:#fff;z-index:2}
.sheet__head h3{font-size:16px;font-weight:800}
.sheet__head .x{width:34px;height:34px;border-radius:10px;background:var(--bg);color:var(--ink-500);display:grid;place-items:center}
.sheet__body{padding:20px}

/* Notif dropdown */
.notif-pop{position:absolute;top:54px;right:14px;width:min(360px,92vw);background:#fff;border:1px solid var(--line);
  border-radius:var(--r-lg);box-shadow:var(--sh-lg);z-index:60;overflow:hidden;animation:fade .15s}
.notif-pop__head{padding:14px 16px;border-bottom:1px solid var(--line);display:flex;justify-content:space-between;align-items:center}
.notif-pop__head b{font-size:14px;font-weight:800}
.notif-pop__body{max-height:60vh;overflow-y:auto;padding:4px 16px}

/* Bottom nav (mobile) */
.bottomnav{display:none}

/* helpers */
.muted{color:var(--ink-500)}.tiny{font-size:11.5px}.mt{margin-top:14px}.mt-lg{margin-top:22px}
.row{display:flex;align-items:center;gap:10px}.between{justify-content:space-between}
.wrap{flex-wrap:wrap}.fill{flex:1}.center{text-align:center}
.divider{height:1px;background:var(--line);margin:14px 0}
.pill{display:inline-flex;align-items:center;gap:6px;background:var(--blue-50);color:var(--blue-600);font-size:11.5px;font-weight:700;padding:4px 10px;border-radius:20px}
.amber-pill{background:var(--amber-bg);color:var(--amber-600)}

/* =====================================================================
   RESPONSIVE
   ===================================================================== */
@media (max-width:1080px){ .grid--kpi{grid-template-columns:repeat(2,1fr)} }

@media (max-width:720px){
  body{font-size:14.5px}
  .auth{grid-template-columns:1fr}
  .auth__brandside{display:none}
  .auth__formside{min-height:100dvh}

  .shell{grid-template-columns:1fr}
  .sidebar{display:none}
  .topbar{padding:0 14px}
  .topbar__menu-btn{display:grid;place-items:center;width:40px;height:40px;border-radius:11px;background:var(--bg);color:var(--navy-800)}
  .topbar__search{display:none}
  .content{padding:14px 14px 92px}

  .grid--kpi{grid-template-columns:repeat(2,1fr);gap:11px}
  .grid--2,.grid--3{grid-template-columns:1fr}
  .span-2{grid-column:auto}
  .kpi__val{font-size:22px}
  .page-head h1{font-size:19px}
  .meta-grid{grid-template-columns:1fr 1fr}

  /* Bottom nav */
  .bottomnav{display:grid;grid-template-columns:repeat(5,1fr);position:fixed;bottom:0;left:0;right:0;z-index:50;
    background:rgba(255,255,255,.94);backdrop-filter:blur(12px);border-top:1px solid var(--line);
    padding:7px 6px calc(7px + env(safe-area-inset-bottom));}
  .bn-item{display:flex;flex-direction:column;align-items:center;gap:3px;padding:5px 2px;border-radius:10px;color:var(--ink-400);font-size:10px;font-weight:600}
  .bn-item.active{color:var(--blue-600)}
  .bn-item.active .bn-ico{background:var(--blue-50)}
  .bn-ico{width:30px;height:26px;border-radius:9px;display:grid;place-items:center}
  .bn-item.fab .bn-ico{background:linear-gradient(135deg,var(--blue-600),var(--blue-500));color:#fff;width:42px;height:42px;border-radius:14px;margin-top:-16px;box-shadow:0 6px 16px rgba(29,95,216,.4)}
  .bn-item.fab{color:var(--blue-600)}

  /* mobile drawer */
  .drawer-ov{position:fixed;inset:0;background:rgba(8,22,44,.5);z-index:90;animation:fade .2s}
  .drawer{position:fixed;top:0;left:0;bottom:0;width:264px;z-index:91;animation:drawerIn .25s ease;
    background:linear-gradient(180deg,var(--navy-800),var(--navy-900));padding:18px 14px;overflow-y:auto;display:flex;flex-direction:column}
  @keyframes drawerIn{from{transform:translateX(-100%)}to{transform:none}}
}

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