@import url('https://fonts.googleapis.com/css2?family=Sora:wght@400;500;600;700;800&display=swap');
:root{
  --navy:#0c1b3a; --navy2:#16294f; --navy3:#1d3060;
  --blue:#2172ff; --blue2:#3b82f6; --blueSoft:#e9f0ff; --blueDeep:#1652d6;
  --ink:#0f1d39; --ink2:#3a4661; --muted:#6b7689; --muted2:#9aa4b6;
  --bg:#eef1f7; --card:#fff; --line:#e7ebf3; --line2:#f0f3f8;
  --green:#12a06a; --greenSoft:#e4f6ee; --amber:#d98a00; --amberSoft:#fdf1da;
  --red:#e0483b; --redSoft:#fde8e6; --purple:#6b4ef0;
  --radius:16px;
  --shadow:0 1px 2px rgba(16,30,60,.03),0 6px 16px -8px rgba(16,30,60,.10),0 14px 34px -18px rgba(16,30,60,.10);
  --shadow-lg:0 6px 14px -6px rgba(16,30,60,.12),0 24px 50px -18px rgba(16,30,60,.24);
}
*{box-sizing:border-box;margin:0;padding:0}
html,body{height:100%}
body{font-family:'Sora','Inter',system-ui,-apple-system,'Segoe UI',sans-serif;background:var(--bg);background-image:radial-gradient(1200px 600px at 100% -10%,rgba(33,114,255,.05),transparent 60%);background-attachment:fixed;color:var(--ink2);font-size:13.5px;line-height:1.5;-webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility}
h1,h2,h3,h4,h5,.page-head h1,.card-h h3,.kpi .v,.sect-t,.brand-word,.btn{font-family:'Sora','Inter',system-ui,sans-serif}
a{color:inherit;text-decoration:none}
::-webkit-scrollbar{width:9px;height:9px}::-webkit-scrollbar-thumb{background:#c9d2e0;border-radius:6px}

.app{display:grid;grid-template-columns:250px 1fr;min-height:100vh}
.sidebar{background:#fff;border-right:1px solid var(--line);display:flex;flex-direction:column;position:sticky;top:0;height:100vh}
.logo-wrap{height:64px;display:flex;align-items:center;padding:0 20px;border-bottom:1px solid var(--line)}
.logo-wrap img{height:34px;width:auto;display:block}
.logo-wrap a{display:flex;align-items:center}
.nav{flex:1;overflow-y:auto;padding:12px 12px 20px}
.nav-label{font-size:10px;letter-spacing:1.2px;text-transform:uppercase;color:var(--muted2);font-weight:700;margin:16px 12px 6px}
.nav-item{display:flex;align-items:center;gap:11px;padding:10px 12px;border-radius:11px;color:var(--ink2);font-weight:500;cursor:pointer;margin-bottom:2px;transition:background .16s,color .16s,transform .12s}
.nav-item svg{width:18px;height:18px;flex-shrink:0;stroke:var(--muted);stroke-width:1.9;fill:none;transition:stroke .16s}
.nav-item:hover{background:#eef3fb;color:var(--navy)}
.nav-item:hover svg{stroke:var(--blue)}
.nav-item.active{background:linear-gradient(135deg,var(--navy2),var(--navy));color:#fff;box-shadow:0 10px 22px -8px rgba(12,27,58,.45)}
.nav-item.active svg{stroke:#fff}
.nav-item .badge{margin-left:auto;background:var(--blueSoft);color:var(--blue);font-size:10px;font-weight:700;padding:1px 7px;border-radius:20px}
.nav-item.active .badge{background:rgba(255,255,255,.2);color:#fff}
.side-foot{padding:14px 18px;border-top:1px solid var(--line2);font-size:11px;color:var(--muted2)}

.main{display:flex;flex-direction:column;min-width:0}
.topbar{height:64px;background:rgba(255,255,255,.82);backdrop-filter:saturate(180%) blur(12px);-webkit-backdrop-filter:saturate(180%) blur(12px);border-bottom:1px solid var(--line);display:flex;align-items:center;gap:18px;padding:0 26px;position:sticky;top:0;z-index:20}
.icon-btn{transition:border-color .15s,background .15s,transform .12s}
.icon-btn:hover{border-color:var(--blue);background:var(--blueSoft)}
.icon-btn:hover svg{stroke:var(--blue)}
.search{flex:1;max-width:460px;position:relative}
.search input{width:100%;border:1px solid var(--line);background:#f6f8fc;border-radius:10px;padding:9px 13px 9px 38px;font-size:13px;outline:none}
.search input:focus{border-color:var(--blue);background:#fff;box-shadow:0 0 0 3px rgba(31,111,255,.12)}
.search svg{position:absolute;left:12px;top:9px;width:17px;height:17px;stroke:var(--muted);fill:none;stroke-width:2}
.top-actions{margin-left:auto;display:flex;align-items:center;gap:14px}
.icon-btn{width:38px;height:38px;border-radius:10px;border:1px solid var(--line);background:#fff;display:flex;align-items:center;justify-content:center;cursor:pointer;position:relative}
.icon-btn svg{width:18px;height:18px;stroke:var(--ink2);fill:none;stroke-width:1.9}
.icon-btn .dot{position:absolute;top:8px;right:9px;width:7px;height:7px;background:var(--red);border-radius:50%;border:2px solid #fff}
.icon-btn .notif-count{position:absolute;top:-6px;right:-6px;min-width:18px;height:18px;padding:0 5px;background:var(--red);color:#fff;font-size:10px;font-weight:800;border-radius:20px;display:flex;align-items:center;justify-content:center;border:2px solid #fff;z-index:2}
.user{display:flex;align-items:center;gap:10px;cursor:pointer}
.avatar{width:38px;height:38px;border-radius:50%;background:linear-gradient(135deg,var(--blue),var(--navy));color:#fff;display:flex;align-items:center;justify-content:center;font-weight:700;font-size:13px}
.user .nm{font-weight:600;color:var(--ink);font-size:13px;line-height:1.2}
.user .rl{font-size:11px;color:var(--muted)}

.content{padding:26px 30px 60px;flex:1;overflow-x:hidden}
.page-head{display:flex;align-items:flex-end;justify-content:space-between;margin-bottom:22px;flex-wrap:wrap;gap:14px}
.page-head h1{font-size:25px;color:var(--navy);font-weight:800;letter-spacing:-.4px}
.page-head .sub{color:var(--muted);font-size:13px;margin-top:4px}
.btn{display:inline-flex;align-items:center;gap:7px;background:var(--navy);color:#fff;border:none;border-radius:11px;padding:10px 17px;font-size:13px;font-weight:600;cursor:pointer;transition:transform .13s,box-shadow .13s,background .15s;white-space:nowrap;box-shadow:0 4px 12px -5px rgba(12,27,58,.4)}
.btn:hover{background:#0a1730;transform:translateY(-1px);box-shadow:0 8px 18px -6px rgba(12,27,58,.5)}
.btn:active{transform:translateY(0)}
.btn svg{width:16px;height:16px;stroke:#fff;fill:none;stroke-width:2}
.btn.blue{background:linear-gradient(135deg,#3182ff,#1f6fff);box-shadow:0 5px 14px -4px rgba(33,114,255,.5)}
.btn.blue:hover{background:linear-gradient(135deg,#2172ff,var(--blueDeep));box-shadow:0 9px 20px -5px rgba(33,114,255,.6)}
.btn.ghost{background:var(--card);color:var(--ink2);border:1px solid var(--line);box-shadow:0 1px 2px rgba(16,30,60,.04)}.btn.ghost:hover{background:#f5f8fc;border-color:#d3dcec;transform:translateY(-1px)}
.btn.ghost svg{stroke:var(--ink2)}

.grid{display:grid;gap:16px}
.cols-4{grid-template-columns:repeat(4,1fr)}
.cols-3{grid-template-columns:repeat(3,1fr)}
.cols-2{grid-template-columns:repeat(2,1fr)}
.span-2{grid-column:span 2}
.card{background:var(--card);border:1px solid var(--line);border-radius:var(--radius);box-shadow:var(--shadow)}
.card.pad{padding:20px}
.card-h{display:flex;align-items:center;justify-content:space-between;padding:16px 20px;border-bottom:1px solid var(--line2)}
.card-h h3{font-size:14.5px;color:var(--navy);font-weight:700;letter-spacing:-.2px}
.card-h .lnk{font-size:12px;color:var(--blue);font-weight:600;cursor:pointer}
.card-b{padding:20px}

.kpi{background:var(--card);border:1px solid var(--line);border-radius:var(--radius);padding:22px;box-shadow:var(--shadow);position:relative;overflow:hidden;transition:transform .18s cubic-bezier(.3,.7,.4,1),box-shadow .18s,border-color .18s}
.kpi:before{content:'';position:absolute;top:0;left:0;right:0;height:3px;background:linear-gradient(90deg,var(--blue),var(--blue2));opacity:.85}
.kpi:has(.ic.b2):before{background:linear-gradient(90deg,var(--green),#41d29b)}
.kpi:has(.ic.b3):before{background:linear-gradient(90deg,var(--amber),#f2ba52)}
.kpi:has(.ic.b4):before{background:linear-gradient(90deg,var(--purple),#9d88ff)}
.kpi:after{content:'';position:absolute;top:-30px;right:-30px;width:130px;height:130px;border-radius:50%;background:radial-gradient(circle,rgba(33,114,255,.07),transparent 70%);pointer-events:none;z-index:0}
.kpi .ic,.kpi .v,.kpi .l{position:relative;z-index:1}
.kpi:hover{transform:translateY(-4px);box-shadow:var(--shadow-lg)}
.kpi-link{display:block;text-decoration:none;color:inherit;cursor:pointer}
.kpi-link:hover{border-color:#cdd9f0}
.kpi .ic{width:46px;height:46px;border-radius:14px;display:flex;align-items:center;justify-content:center;margin-bottom:18px;box-shadow:inset 0 0 0 1px rgba(255,255,255,.5)}
.kpi .ic svg{width:22px;height:22px;stroke-width:2;fill:none}
.kpi .v{font-size:30px;font-weight:800;color:var(--navy);letter-spacing:-.7px;line-height:1}
.kpi .l{font-size:12.5px;color:var(--muted);margin-top:7px;font-weight:500;letter-spacing:.1px}
.kpi .trend{position:absolute;top:20px;right:20px;font-size:11px;font-weight:700;background:var(--greenSoft);padding:4px 9px;border-radius:20px;display:inline-flex;align-items:center;gap:3px}
.kpi .trend.down{background:var(--redSoft)}
.trend.up{color:var(--green)}.trend.down{color:var(--red)}
.ic.b1{background:var(--blueSoft)}.ic.b1 svg{stroke:var(--blue)}
.ic.b2{background:var(--greenSoft)}.ic.b2 svg{stroke:var(--green)}
.ic.b3{background:var(--amberSoft)}.ic.b3 svg{stroke:var(--amber)}
.ic.b4{background:#efeaff}.ic.b4 svg{stroke:var(--purple)}
html[data-theme="dark"] .ic.b4{background:#241d45}

.tag{display:inline-flex;align-items:center;gap:5px;font-size:11px;font-weight:700;padding:3px 9px;border-radius:20px;white-space:nowrap}
.tag.green{background:var(--greenSoft);color:var(--green)}
.tag.blue{background:var(--blueSoft);color:var(--blue)}
.tag.amber{background:var(--amberSoft);color:var(--amber)}
.tag.red{background:var(--redSoft);color:var(--red)}
.tag.grey{background:#eef1f7;color:var(--muted)}
.tag.navy{background:#e7ecf6;color:var(--navy)}
.dotmark{width:7px;height:7px;border-radius:50%;display:inline-block;background:currentColor}

.tbl-wrap{overflow-x:auto}
/* numbered index column — used across all list tables */
table.data th.rownum,table.data td.rownum{width:48px;text-align:center;padding-left:14px;padding-right:6px}
table.data td.rownum .rn{display:inline-flex;align-items:center;justify-content:center;min-width:23px;height:23px;padding:0 6px;border-radius:7px;background:var(--blueSoft);color:var(--blue);font-size:11px;font-weight:700;font-variant-numeric:tabular-nums}
table.data{width:100%;border-collapse:collapse;font-size:13px}
table.data th{text-align:left;font-size:10.5px;letter-spacing:.7px;text-transform:uppercase;color:var(--muted2);font-weight:700;padding:13px 16px;border-bottom:1px solid var(--line);background:#f7f9fd;white-space:nowrap}
table.data th a{color:inherit}
table.data td{padding:14px 16px;border-bottom:1px solid var(--line2);color:var(--ink2);white-space:nowrap}
table.data tbody tr{transition:background .12s}
table.data tr:hover td{background:#eff4fc}
table.data tr:hover td:first-child{box-shadow:inset 3px 0 0 var(--blue)}
table.data tbody tr:last-child td{border-bottom:none}
.clickrow:hover td{cursor:pointer}
html[data-theme="dark"] table.data tr:hover td:first-child{box-shadow:inset 3px 0 0 var(--blue)}
table.data .mono{font-family:'SF Mono',ui-monospace,Menlo,monospace;font-size:12px;color:var(--blue);font-weight:600}
.asset-mini{display:flex;align-items:center;gap:11px}
.asset-thumb{width:38px;height:38px;border-radius:9px;background:linear-gradient(135deg,#e9eff9,#dbe6f7);display:flex;align-items:center;justify-content:center;flex-shrink:0}
.asset-thumb svg{width:20px;height:20px;stroke:var(--navy2);fill:none;stroke-width:1.7}
.asset-mini .nm{font-weight:700;color:var(--ink);font-size:13px}
.asset-mini .sn{font-size:11px;color:var(--muted)}
.clickrow{cursor:pointer}

.toolbar{display:flex;align-items:center;gap:9px;flex-wrap:wrap;margin-bottom:16px}
/* grouped filter bar (labelled class / status rows + search) */
.filter-bar{display:flex;flex-direction:column;gap:10px;margin-bottom:18px}
.filter-group{display:flex;align-items:center;gap:12px;min-width:0}
.fg-label{flex:0 0 46px;font-size:10px;font-weight:800;letter-spacing:.7px;text-transform:uppercase;color:var(--muted2)}
.chip-row{display:flex;gap:8px;flex:1 1 auto;min-width:0;overflow-x:auto;padding:2px 2px 4px;scrollbar-width:none}
.chip-row::-webkit-scrollbar{display:none}
.chip-row .chip{flex:0 0 auto}
.chip.chip-ghost{border-style:dashed;color:var(--muted);box-shadow:none}
.filter-bar .mini-search{width:100%;max-width:320px}
.filter-bar .mini-search input{width:100%}
@media(max-width:640px){.fg-label{flex-basis:42px;font-size:9.5px}}
.chip{padding:8px 15px;border-radius:22px;border:1px solid var(--line);background:var(--card);font-size:12.5px;font-weight:600;color:var(--ink2);cursor:pointer;transition:.15s;box-shadow:0 1px 2px rgba(16,30,60,.03)}
.chip:hover{border-color:var(--blue);color:var(--blue);background:var(--blueSoft)}
.chip.active{background:linear-gradient(135deg,var(--navy2),var(--navy));color:#fff;border-color:var(--navy);box-shadow:0 6px 14px -5px rgba(12,27,58,.4)}
.chip.active:hover{color:#fff}
.spacer{flex:1}
.mini-search{position:relative}
.mini-search input{border:1px solid var(--line);border-radius:9px;padding:8px 12px 8px 32px;font-size:12.5px;width:230px;outline:none}
.mini-search svg{position:absolute;left:10px;top:8px;width:15px;height:15px;stroke:var(--muted);fill:none;stroke-width:2}

.bar{height:7px;border-radius:6px;background:#eaeef5;overflow:hidden;min-width:70px;display:inline-block;vertical-align:middle}
.bar>i{display:block;height:100%;border-radius:6px;background:linear-gradient(90deg,var(--blue),var(--blue2))}

.pager{display:flex;align-items:center;justify-content:space-between;gap:12px;flex-wrap:wrap;padding:14px 16px;border-top:1px solid var(--line2)}
.pager .pg-info{font-size:12.5px;color:var(--muted)}
.pager .pg-btns{display:flex;gap:5px;align-items:center}
.pg{display:inline-flex;align-items:center;justify-content:center;min-width:32px;height:32px;padding:0 9px;border:1px solid var(--line);border-radius:8px;font-size:13px;font-weight:600;color:var(--ink2);text-decoration:none;background:var(--card);transition:.12s}
.pg:hover{border-color:var(--blue);color:var(--blue)}
.pg.active{background:var(--navy);color:#fff;border-color:var(--navy)}
.pg.disabled{opacity:.4;pointer-events:none}
.pg.dots{border:none;background:none;min-width:18px}
html[data-theme="dark"] .pg.active{background:var(--blue);border-color:var(--blue)}
.list-row{display:flex;align-items:center;gap:13px;padding:13px 0;border-bottom:1px solid var(--line2)}
.list-row:last-child{border-bottom:none}
.rowlink{text-decoration:none;color:inherit;cursor:pointer;padding-left:8px;padding-right:8px;margin:0 -8px;border-radius:10px;transition:background .12s}
.rowlink:hover{background:#f7f9fd}
html[data-theme="dark"] .rowlink:hover{background:#172136}
.act-ic{width:36px;height:36px;border-radius:10px;display:flex;align-items:center;justify-content:center;flex-shrink:0}
.act-ic svg{width:17px;height:17px;fill:none;stroke-width:1.9;stroke:var(--ink2)}
.muted{color:var(--muted)}.small{font-size:12px}
.flex{display:flex;align-items:center}.gap{gap:10px}.between{justify-content:space-between}
.b700{font-weight:700}.b800{font-weight:800}.navy{color:var(--navy)}.right{text-align:right}
.legend{display:flex;gap:16px;flex-wrap:wrap;margin-top:12px}
.legend span{display:flex;align-items:center;gap:6px;font-size:12px;color:var(--muted)}

/* detail page */
.detail-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:16px 24px}
.dl{font-size:11px;text-transform:uppercase;letter-spacing:.4px;color:var(--muted2);font-weight:700;margin-bottom:3px}
.dv{font-size:14px;color:var(--ink);font-weight:600}
.sect-t{font-size:12px;font-weight:800;letter-spacing:.5px;text-transform:uppercase;color:var(--navy);margin:26px 0 14px;display:flex;align-items:center;gap:8px}
.sect-t:before{content:'';width:4px;height:14px;background:var(--blue);border-radius:3px}
.doc-row{display:flex;align-items:center;gap:12px;padding:11px 0;border-bottom:1px solid var(--line2)}
.doc-ic{width:34px;height:34px;border-radius:9px;background:var(--blueSoft);display:flex;align-items:center;justify-content:center}
.doc-ic svg{width:17px;height:17px;stroke:var(--blue);fill:none;stroke-width:1.8}
.timeline{position:relative;padding-left:22px}
.timeline:before{content:'';position:absolute;left:6px;top:4px;bottom:4px;width:2px;background:var(--line)}
.tl-item{position:relative;padding-bottom:16px}
.tl-item:before{content:'';position:absolute;left:-19px;top:3px;width:11px;height:11px;border-radius:50%;background:#fff;border:2.5px solid var(--blue)}
.tl-item .tt{font-weight:700;color:var(--ink);font-size:13px}
.tl-item .td{font-size:12px;color:var(--muted)}
.big-thumb{width:64px;height:64px;border-radius:14px;background:linear-gradient(135deg,var(--navy),var(--blue));display:flex;align-items:center;justify-content:center;flex-shrink:0}
.big-thumb svg{width:32px;height:32px;stroke:#fff;fill:none;stroke-width:1.7}

/* map */
.mapwrap{position:relative;height:520px;border-radius:var(--radius);overflow:hidden;background:radial-gradient(circle at 30% 30%,#16294f,#0b1c3c 70%);border:1px solid var(--line)}
.pin{position:absolute;transform:translate(-50%,-100%);cursor:pointer;text-align:center}
.pin .dotp{width:16px;height:16px;border-radius:50%;background:var(--blue);border:3px solid #fff;box-shadow:0 0 0 4px rgba(31,111,255,.3);margin:0 auto;animation:pulse 2.4s infinite}
.pin .lbl{margin-top:6px;background:#fff;border-radius:8px;padding:5px 9px;font-size:11px;font-weight:700;color:var(--navy);white-space:nowrap;box-shadow:0 4px 12px rgba(0,0,0,.2)}
.pin .lbl span{color:var(--blue)}
@keyframes pulse{0%{box-shadow:0 0 0 4px rgba(31,111,255,.3)}50%{box-shadow:0 0 0 10px rgba(31,111,255,0)}100%{box-shadow:0 0 0 4px rgba(31,111,255,.3)}}

/* forms */
.form-grid{display:grid;grid-template-columns:1fr 1fr;gap:16px 20px}
.field{display:flex;flex-direction:column;gap:6px}
.field label{font-size:12px;font-weight:700;color:var(--ink2)}
.field input,.field select,.field textarea{border:1px solid var(--line);border-radius:10px;padding:11px 13px;font-size:13px;outline:none;font-family:inherit;background:var(--card);color:var(--ink);transition:border-color .15s,box-shadow .15s}
.field input:hover,.field select:hover,.field textarea:hover{border-color:#d1dbec}
.field input:focus,.field select:focus,.field textarea:focus{border-color:var(--blue);box-shadow:0 0 0 3.5px rgba(33,114,255,.14)}
.full{grid-column:1/-1}

/* AI */
.ai-wrap{display:grid;grid-template-columns:1fr 290px;gap:16px}
.chat{background:#fff;border:1px solid var(--line);border-radius:var(--radius);display:flex;flex-direction:column;height:600px;box-shadow:var(--shadow)}
.chat-h{padding:16px 18px;border-bottom:1px solid var(--line2);display:flex;align-items:center;gap:11px}
.ai-orb{width:36px;height:36px;border-radius:11px;background:linear-gradient(135deg,var(--blue),var(--purple));display:flex;align-items:center;justify-content:center}
.ai-orb svg{width:19px;height:19px;stroke:#fff;fill:none;stroke-width:2}
.chat-body{flex:1;overflow-y:auto;padding:20px;display:flex;flex-direction:column;gap:16px}
.msg{display:flex;gap:11px;max-width:88%}
.msg .b{padding:11px 14px;border-radius:13px;font-size:13.5px;line-height:1.55;overflow-wrap:anywhere;word-break:break-word;min-width:0}
.msg{min-width:0}
.ai-tblw{overflow-x:auto;-webkit-overflow-scrolling:touch;max-width:100%;margin:6px 0 10px}
.ai-tblw .ai-tbl{margin:0}
.msg.ai .b{background:#f3f6fc;color:var(--ink2);border-bottom-left-radius:4px}
.msg.me{margin-left:auto;flex-direction:row-reverse}
.msg.me .b{background:var(--navy);color:#fff;border-bottom-right-radius:4px}
.msg .mini-orb{width:30px;height:30px;border-radius:9px;flex-shrink:0;background:linear-gradient(135deg,var(--blue),var(--purple));display:flex;align-items:center;justify-content:center}
.msg .mini-orb svg{width:15px;height:15px;stroke:#fff;fill:none;stroke-width:2.2}
/* Rendered AI markdown */
.msg.ai .b > *:first-child{margin-top:0}
.msg.ai .b > *:last-child{margin-bottom:0}
.msg.ai .b p{margin:0 0 9px}
.msg.ai .b h3{font-size:15px;font-weight:800;color:var(--navy);margin:4px 0 8px}
.msg.ai .b h4{font-size:13px;font-weight:800;color:var(--navy);text-transform:uppercase;letter-spacing:.4px;margin:12px 0 7px}
.msg.ai .b h5{font-size:12.5px;font-weight:700;color:var(--ink2);margin:10px 0 5px}
.msg.ai .b strong{color:var(--navy);font-weight:700}
.msg.ai .b ul,.msg.ai .b ol{margin:4px 0 9px;padding-left:18px}
.msg.ai .b li{margin:3px 0}
.msg.ai .b code{background:#e7edf7;border-radius:5px;padding:1px 5px;font-size:12px;font-family:ui-monospace,Menlo,monospace;color:var(--blueDeep)}
.msg.ai .b hr{border:0;border-top:1px solid var(--line);margin:11px 0}
.msg.ai .b .ai-tbl{width:100%;border-collapse:collapse;margin:6px 0 10px;font-size:12.5px;background:#fff;border-radius:9px;overflow:hidden;box-shadow:0 0 0 1px var(--line)}
.msg.ai .b .ai-tbl th{background:var(--navy);color:#fff;text-align:left;padding:7px 10px;font-weight:700;font-size:11px;text-transform:uppercase;letter-spacing:.3px}
.msg.ai .b .ai-tbl td{padding:7px 10px;border-top:1px solid var(--line);color:var(--ink2);vertical-align:top}
.msg.ai .b .ai-tbl tr:nth-child(even) td{background:#f7f9fd}
.msg.ai .b .ai-tbl td:first-child{font-weight:600;color:var(--navy);white-space:nowrap}
.chat-input{padding:14px 16px;border-top:1px solid var(--line2);display:flex;gap:10px}
.chat-input input{flex:1;border:1px solid var(--line);border-radius:11px;padding:11px 14px;font-size:13.5px;outline:none}
.chat-input button{width:44px;border:none;border-radius:11px;background:var(--blue);color:#fff;cursor:pointer;display:flex;align-items:center;justify-content:center}
.chat-input button svg{width:18px;height:18px;stroke:#fff;fill:none;stroke-width:2}
.suggest{font-size:12.5px;padding:11px 13px;border:1px solid var(--line);border-radius:10px;margin-bottom:9px;cursor:pointer;color:var(--ink2);font-weight:500}
.suggest:hover{border-color:var(--blue);color:var(--blue);background:var(--blueSoft)}

/* brand lockup (inline SVG — renders without any image file) */
.brand-lockup{display:inline-flex;align-items:center;gap:9px;line-height:1}
.brand-mark{width:30px;height:30px;flex-shrink:0;background:url('data:image/png;base64,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') no-repeat center/contain}
.brand-word{font-family:'Sora','Inter',sans-serif;font-weight:800;font-size:21px;letter-spacing:-.6px;color:var(--navy)}
.brand-lockup.on-dark .brand-word{color:#fff}
.brand-lockup.lg .brand-mark{width:44px;height:44px}
.brand-lockup.lg .brand-word{font-size:30px}
html[data-theme="dark"] .brand-word{color:#fff}

/* ===== Auth (login / otp) split layout ===== */
.auth{display:grid;grid-template-columns:1.05fr .95fr;min-height:100vh}
.auth.auth-single{grid-template-columns:1fr}
.auth-brand{position:relative;overflow:hidden;color:#dbe6ff;padding:54px 56px;display:flex;flex-direction:column;
  background:radial-gradient(circle at 82% 12%,rgba(31,111,255,.45),transparent 48%),
             radial-gradient(circle at 10% 90%,rgba(59,130,246,.22),transparent 46%),
             linear-gradient(150deg,#06122a 0%,#0a1c3e 55%,#0c1b3a 120%)}
.auth-grid{position:absolute;inset:0;width:100%;height:100%}
.auth-motif{position:absolute;fill:none;stroke:#ffffff;stroke-width:.5;opacity:.06}
.auth-motif.m1{width:340px;height:340px;right:-40px;top:8%}
.auth-motif.m2{width:300px;height:300px;left:-30px;bottom:-20px}
.auth-motif.m3{width:200px;height:200px;right:18%;bottom:10%}
.auth-brand-inner{position:relative;margin:auto 0}
.auth-brand-inner h1{color:#fff;font-size:34px;line-height:1.15;letter-spacing:-.5px;margin:30px 0 16px;font-weight:800}
.auth-brand-inner p{color:#b9caea;font-size:14.5px;line-height:1.6;max-width:460px}
.auth-features{list-style:none;margin:26px 0 0;padding:0}
.auth-features li{position:relative;padding-left:30px;margin-bottom:14px;color:#cfe0ff;font-size:14px}
.auth-features li:before{content:'';position:absolute;left:0;top:1px;width:19px;height:19px;border-radius:50%;
  background:var(--blue);background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24'%3E%3Cpath d='M20 6 9 17l-5-5' fill='none' stroke='white' stroke-width='3' stroke-linecap='round' stroke-linejoin='round'/%3E%3C/svg%3E");background-size:13px;background-position:center;background-repeat:no-repeat}
.auth-brand-foot{position:relative;margin-top:auto;padding-top:30px;font-size:12px;color:#7e93b8}

.auth-form{display:flex;align-items:center;justify-content:center;padding:40px 24px;background:#fff}
.auth-form-inner{width:100%;max-width:380px}
.auth-form-logo{margin-bottom:26px}
.auth-form h2{font-size:24px;color:var(--navy);font-weight:800;letter-spacing:-.3px}
.auth-sub{color:var(--muted);font-size:14px;margin:4px 0 24px}
.auth-form .field{margin-bottom:16px}
.auth-form .field label{font-size:12.5px;font-weight:700;color:var(--ink2);display:block;margin-bottom:6px}
.auth-form .field input{width:100%;border:1px solid var(--line);border-radius:11px;padding:12px 14px;font-size:14px;outline:none;transition:.15s;background:#fff}
.auth-form .field input:focus{border-color:var(--blue);box-shadow:0 0 0 3px rgba(31,111,255,.13)}
.pw-wrap{position:relative}
.pw-wrap input{padding-right:46px !important}
.pw-toggle{position:absolute;right:6px;top:50%;transform:translateY(-50%);width:34px;height:34px;border:none;background:none;cursor:pointer;display:flex;align-items:center;justify-content:center;border-radius:8px}
.pw-toggle:hover{background:#f0f3fa}
.pw-toggle svg{width:19px;height:19px;stroke:var(--muted);fill:none;stroke-width:1.9}
.auth-submit{width:100%;justify-content:center;padding:13px;font-size:14.5px;font-weight:700;margin-top:4px}
.auth-help{margin-top:26px;padding-top:20px;border-top:1px solid var(--line2);display:flex;flex-direction:column;gap:8px;font-size:12.5px;color:var(--muted)}
.lock-ic{display:flex;align-items:center;gap:7px;font-weight:600;color:var(--ink2)}
.lock-ic svg{width:15px;height:15px;stroke:var(--green);fill:none;stroke-width:1.9}
@media(max-width:900px){.auth{grid-template-columns:1fr}.auth-brand{display:none}.auth-form{background:linear-gradient(160deg,#f4f7fc,#eef2f9)}}

/* legacy login (otp card still uses these) */
.login-wrap{min-height:100vh;display:flex;align-items:center;justify-content:center;background:radial-gradient(circle at 80% 16%,rgba(31,111,255,.25),transparent 46%),linear-gradient(150deg,#06122a,#0b2540 60%,#0c1b3a)}
.login-card{background:#fff;border-radius:18px;padding:38px 36px;width:400px;max-width:92vw;box-shadow:0 30px 80px rgba(0,0,0,.4)}
.login-card .brand-lockup{justify-content:center;margin:0 auto 22px}
.login-card h1{font-size:19px;text-align:center;color:var(--navy);margin-bottom:4px}
.login-card .sub{text-align:center;color:var(--muted);font-size:13px;margin-bottom:24px}
.login-card .field{margin-bottom:14px}
.login-card .btn{width:100%;justify-content:center;padding:12px;font-size:14px}
.alert{display:flex;align-items:center;gap:11px;background:var(--redSoft);color:var(--red);border:1px solid rgba(224,72,59,.26);border-left:3px solid var(--red);border-radius:12px;padding:12px 15px;font-size:13px;font-weight:600;line-height:1.45;margin-bottom:16px;max-width:760px;box-shadow:0 6px 18px -12px rgba(224,72,59,.5)}
.alert:before{content:'';flex:0 0 auto;width:19px;height:19px;background:currentColor;-webkit-mask:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24'%3E%3Cpath fill='black' d='M12 2a10 10 0 100 20 10 10 0 000-20zm-1 5h2v7h-2zm0 9h2v2h-2z'/%3E%3C/svg%3E") center/contain no-repeat;mask:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24'%3E%3Cpath fill='black' d='M12 2a10 10 0 100 20 10 10 0 000-20zm-1 5h2v7h-2zm0 9h2v2h-2z'/%3E%3C/svg%3E") center/contain no-repeat}
.alert.ok{background:var(--greenSoft);color:var(--green);border-color:rgba(18,160,106,.26);border-left-color:var(--green);box-shadow:0 6px 18px -12px rgba(18,160,106,.5)}
.alert.ok:before{-webkit-mask:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24'%3E%3Cpath fill='black' d='M12 2a10 10 0 100 20 10 10 0 000-20zm-1.2 14.4-4.2-4.2 1.4-1.4 2.8 2.8 5.6-5.6 1.4 1.4z'/%3E%3C/svg%3E") center/contain no-repeat;mask:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24'%3E%3Cpath fill='black' d='M12 2a10 10 0 100 20 10 10 0 000-20zm-1.2 14.4-4.2-4.2 1.4-1.4 2.8 2.8 5.6-5.6 1.4 1.4z'/%3E%3C/svg%3E") center/contain no-repeat}
.cred-hint{margin-top:18px;font-size:11.5px;color:var(--muted2);text-align:center;line-height:1.6}
.toast-pop{position:fixed;bottom:26px;left:50%;transform:translateX(-50%);background:var(--navy);color:#fff;padding:12px 22px;border-radius:11px;font-size:13px;font-weight:600;z-index:200;box-shadow:0 14px 36px rgba(0,0,0,.28);animation:toastIn .25s ease}
@keyframes toastIn{from{opacity:0;transform:translate(-50%,10px)}to{opacity:1;transform:translate(-50%,0)}}
.actions-inline{display:flex;gap:8px;align-items:center}
.btn.sm{padding:6px 11px;font-size:12px;border-radius:8px}
.btn.danger{background:var(--red)}.btn.danger:hover{background:#c23b2f}
.iconlink{color:var(--blue);font-weight:700;cursor:pointer}
.toggle{display:inline-flex;align-items:center;gap:7px;font-size:12px;font-weight:600;color:var(--ink2)}

/* media gallery */
.media-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(190px,1fr));gap:14px}
.media-card{position:relative;border:1px solid var(--line);border-radius:12px;overflow:hidden;background:#0b1c3c;aspect-ratio:4/3;display:flex;align-items:center;justify-content:center}
.media-card img,.media-card video{width:100%;height:100%;object-fit:cover;display:block}
.media-badge{position:absolute;top:8px;font-size:10px;font-weight:700;padding:2px 8px;border-radius:20px;letter-spacing:.3px}
.media-badge.kind{right:8px;background:rgba(12,27,58,.78);color:#fff}
.media-badge.primary{left:8px;background:var(--blue);color:#fff}
.media-cap{position:absolute;left:0;right:0;bottom:0;background:linear-gradient(transparent,rgba(8,18,40,.85));color:#fff;font-size:11px;padding:16px 10px 8px}
.media-actions{position:absolute;bottom:8px;right:8px;display:flex;gap:6px;opacity:0;transition:.15s}
.media-card:hover .media-actions{opacity:1}
.media-actions button{width:30px;height:30px;border-radius:8px;border:none;cursor:pointer;font-size:13px;font-weight:700;background:rgba(255,255,255,.92);color:var(--navy);display:flex;align-items:center;justify-content:center}
.media-actions button.del{background:rgba(224,72,59,.95);color:#fff}
.media-ai{position:absolute;left:0;right:0;bottom:0;background:rgba(12,27,58,.92);color:#dce7ff;font-size:10.5px;line-height:1.4;padding:7px 9px;display:flex;gap:6px;align-items:flex-start;max-height:46%;overflow:hidden}
.media-ai svg{width:13px;height:13px;stroke:#7fb0ff;fill:none;stroke-width:2;flex:0 0 auto;margin-top:1px}
.media-ai span{display:-webkit-box;-webkit-line-clamp:3;-webkit-box-orient:vertical;overflow:hidden}
.media-upload{display:flex;gap:14px;align-items:flex-end;flex-wrap:wrap;margin-top:18px;padding-top:18px;border-top:1px solid var(--line2)}
.media-upload .field{display:flex;flex-direction:column;gap:6px;min-width:200px}
.media-upload input[type=file]{border:1px dashed var(--line);border-radius:9px;padding:9px;font-size:12.5px;background:#fafbfe}

/* settings — horizontal tab bar */
.settings-tabs{display:flex;gap:2px;flex-wrap:wrap;border-bottom:1px solid var(--line);margin:-4px 0 22px}
.settings-tab{padding:11px 16px;font-size:13.5px;font-weight:600;color:var(--muted);border-bottom:2px solid transparent;margin-bottom:-1px;cursor:pointer;transition:.15s;white-space:nowrap}
.settings-tab:hover{color:var(--navy)}
.settings-tab.active{color:var(--navy);border-bottom-color:var(--blue)}
.settings-body{min-width:0}
@media(max-width:700px){.settings-tabs{gap:0}.settings-tab{padding:10px 12px;font-size:12.5px}}
/* hamburger + overlay (hidden on desktop) */
.hamburger{display:none;flex-direction:column;justify-content:center;gap:4px;width:40px;height:40px;border:1px solid var(--line);border-radius:10px;background:#fff;cursor:pointer;flex-shrink:0;padding:0}
.hamburger span{display:block;width:18px;height:2px;background:var(--navy);border-radius:2px;margin:0 auto}
.nav-overlay{display:none}
.mobile-search{display:none}
.topbar-brand{display:none}
.topbar-brand .brand-mark{width:24px;height:24px}.topbar-brand .brand-word{font-size:17px}

@media(max-width:1100px){.cols-4{grid-template-columns:repeat(2,1fr)}.detail-grid{grid-template-columns:1fr 1fr}.ai-wrap{grid-template-columns:1fr}}

/* ============ MOBILE / TABLET ============ */
@media(max-width:900px){
  .app{grid-template-columns:1fr}
  .sidebar{position:fixed;left:0;top:0;bottom:0;height:100vh;height:100dvh;width:270px;max-width:84vw;
    transform:translateX(-100%);transition:transform .26s cubic-bezier(.4,0,.2,1);z-index:90;
    box-shadow:6px 0 30px rgba(10,20,40,.18)}
  .sidebar .nav{padding-bottom:10px}
  .side-foot{padding-bottom:calc(14px + env(safe-area-inset-bottom,0px))}
  .sidebar.open{transform:none}
  .nav-overlay{display:block;position:fixed;inset:0;background:rgba(10,20,40,.45);z-index:85;
    opacity:0;pointer-events:none;transition:.2s}
  .nav-overlay.show{opacity:1;pointer-events:auto}
  body.nav-locked{overflow:hidden}
  .hamburger{display:flex}
  .topbar{padding:0 12px;gap:8px;height:60px;overflow:hidden}
  .topbar-brand{display:flex;align-items:center;flex-shrink:0}
  .topbar-brand .brand-mark{width:22px;height:22px}.topbar-brand .brand-word{font-size:16px}
  .search{display:none}
  .mobile-search{display:flex}
  .top-actions{gap:6px;margin-left:auto;flex-shrink:0}
  .icon-btn{width:36px;height:36px;flex-shrink:0}
  .hide-sm{display:none !important}
  .user .nm,.user .rl{display:none}
  .user{padding:0;flex-shrink:0}
  .content{padding:18px 16px 70px;max-width:100%}
  canvas{max-width:100% !important}
  .page-head{flex-direction:column;align-items:flex-start;gap:12px}
  .page-head h1{font-size:20px}
  .page-head .flex.gap{flex-wrap:wrap}

  /* stack every multi-column grid; keep KPIs two-up */
  .grid{grid-template-columns:1fr !important}
  .grid.cols-4{grid-template-columns:repeat(2,1fr) !important}
  .span-2{grid-column:auto !important}
  .detail-grid{grid-template-columns:1fr 1fr}
  .form-grid{grid-template-columns:1fr}
  .two-col{flex-direction:column}
  .ai-wrap{grid-template-columns:1fr}
  .chat{height:auto;min-height:60vh;max-height:74vh;max-width:100%;overflow:hidden}
  .chat-body{overflow-x:hidden;padding:14px}
  .chat-h{flex-wrap:wrap;padding:13px 14px}
  .chat-h .tag{margin-left:auto}
  .msg{max-width:94%}
  .ai-tbl{font-size:12px}
  .card.pad{max-width:none !important}
  .settings-tabs{flex-wrap:nowrap;overflow-x:auto;-webkit-overflow-scrolling:touch;margin:0 0 18px;padding-bottom:1px}
  .settings-tab{flex-shrink:0}
  .media-grid{grid-template-columns:repeat(2,1fr)}
  .kpi .trend{position:static;display:inline-block;margin:0 0 8px}
  .kpi .ic{margin-bottom:8px}
}

@media(max-width:560px){
  .kpi .v{font-size:22px}
  .kpi{padding:14px}
  .kpi .trend{position:static;display:inline-block;margin-bottom:6px}
  .card-b{padding:14px}
  .detail-grid{grid-template-columns:1fr}
  .page-head .btn{flex:1;justify-content:center}
  table.data td,table.data th{padding:10px}
  .media-grid{grid-template-columns:1fr 1fr}
  .auth-form{padding:28px 18px}
}

/* ======================= Dark mode ======================= */
html[data-theme="dark"]{
  --navy:#eaeff9; --navy2:#aab8d6; --navy3:#8fa0c6;
  --ink:#eef2fb; --ink2:#c4cde2; --muted:#94a1bd; --muted2:#74819f;
  --bg:#080d18; --card:#151f38; --line:#2b3a5a; --line2:#20304e;
  --blueSoft:#17294a; --greenSoft:#0f2a1f; --amberSoft:#2c2210; --redSoft:#301715;
  --shadow:0 1px 2px rgba(0,0,0,.35),0 14px 34px -14px rgba(0,0,0,.6);
  --shadow-lg:0 8px 20px -8px rgba(0,0,0,.5),0 30px 60px -24px rgba(0,0,0,.75);
}
html[data-theme="dark"] body{background-image:radial-gradient(1200px 600px at 100% -10%,rgba(33,114,255,.10),transparent 60%)}
html[data-theme="dark"] .card,
html[data-theme="dark"] .kpi{box-shadow:inset 0 1px 0 rgba(255,255,255,.04),var(--shadow)}
html[data-theme="dark"] .card:hover,html[data-theme="dark"] .kpi:hover{border-color:#33456a}
html[data-theme="dark"] body{color:var(--ink2)}
html[data-theme="dark"] .sidebar,
html[data-theme="dark"] .topbar{background:#101829}
html[data-theme="dark"] .topbar{background:rgba(16,24,41,.92)}
html[data-theme="dark"] .icon-btn,
html[data-theme="dark"] .hamburger,
html[data-theme="dark"] .btn.ghost{background:#1a2438;color:var(--ink2);border-color:var(--line)}
html[data-theme="dark"] .btn.ghost:hover{background:#222d45}
html[data-theme="dark"] .chip{background:#1a2438;color:var(--ink2)}
html[data-theme="dark"] .field input,
html[data-theme="dark"] .field select,
html[data-theme="dark"] .field textarea,
html[data-theme="dark"] .chat-input input,
html[data-theme="dark"] .mini-search input,
html[data-theme="dark"] .search input{background:#1a2438;color:var(--ink);border-color:var(--line)}
html[data-theme="dark"] .search input:focus{background:#1a2438}
html[data-theme="dark"] table.data th{background:#172136}
html[data-theme="dark"] table.data tr:hover td,
html[data-theme="dark"] .clickrow:hover{background:#172136}
html[data-theme="dark"] .chat{background:var(--card)}
html[data-theme="dark"] .msg.ai .b{background:#1a2438;color:var(--ink2)}
html[data-theme="dark"] .msg.ai .b .ai-tbl{background:var(--card)}
html[data-theme="dark"] .btn{background:var(--blue);color:#fff}
html[data-theme="dark"] .nav-item.active{background:var(--blue);color:#fff}
html[data-theme="dark"] .chip.active{background:var(--blue);border-color:var(--blue);color:#fff}
html[data-theme="dark"] .msg.me .b{background:var(--blue);color:#fff}
html[data-theme="dark"] .msg.ai .b .ai-tbl th{background:#0f1830;color:#fff}
html[data-theme="dark"] .toast-pop{background:#1a2438;color:var(--ink)}
html[data-theme="dark"] .hamburger span{background:var(--ink)}
html[data-theme="dark"] .card-h,
html[data-theme="dark"] .settings-tab.active{border-color:var(--line)}
html[data-theme="dark"] img.logo,html[data-theme="dark"] .pin .lbl{filter:none}
/* dark-mode polish for the refreshed components */
html[data-theme="dark"]{--line:#28344e;--line2:#1f2b44;--shadow:0 1px 2px rgba(0,0,0,.35),0 10px 30px -12px rgba(0,0,0,.6);--shadow-lg:0 8px 20px -8px rgba(0,0,0,.5),0 28px 56px -18px rgba(0,0,0,.7)}
html[data-theme="dark"] body{background-image:radial-gradient(1200px 600px at 100% -10%,rgba(33,114,255,.10),transparent 60%)}
html[data-theme="dark"] .kpi:before{background:linear-gradient(180deg,rgba(255,255,255,.045),transparent)}
html[data-theme="dark"] .kpi .ic{box-shadow:inset 0 0 0 1px rgba(255,255,255,.05)}
html[data-theme="dark"] table.data th{background:#172136;color:var(--muted2)}
html[data-theme="dark"] table.data tr:hover td{background:#1a2740}
html[data-theme="dark"] .topbar{background:rgba(16,24,41,.72)}
html[data-theme="dark"] .nav-item:hover{background:#1a2438;color:#fff}
html[data-theme="dark"] .chip:hover{background:#1a2438}
html[data-theme="dark"] .icon-btn:hover{background:#1a2438}
/* dark surfaces that were hardcoded light — keep all text legible */
html[data-theme="dark"] .tag.grey{background:#212d47;color:var(--muted2)}
html[data-theme="dark"] .tag.navy{background:#24314f;color:#c7d3ec}
html[data-theme="dark"] .asset-thumb{background:linear-gradient(135deg,#1f2b47,#182338)}
html[data-theme="dark"] .doc-ic{background:#16233f}
html[data-theme="dark"] .bar{background:#22304c}
html[data-theme="dark"] .media-upload input[type=file]{background:#1a2438;color:var(--ink2)}
html[data-theme="dark"] .search input:focus{background:#1a2438}
html[data-theme="dark"] .msg.ai .b code{background:#22304c;color:#8fb4ff}
html[data-theme="dark"] .msg.ai .b .ai-tbl{background:var(--card)}
html[data-theme="dark"] .msg.ai .b .ai-tbl tr:nth-child(even) td{background:#172136}
html[data-theme="dark"] .tl-item:before{background:var(--card)}
html[data-theme="dark"] .kpi-link:hover{border-color:#33406088}
html[data-theme="dark"] .card-h .lnk,html[data-theme="dark"] a.lnk{color:#6fa2ff}
html[data-theme="dark"] ::-webkit-scrollbar-thumb{background:#2c3a58}
html[data-theme="dark"] .pager .pg{background:var(--card)}
