/* ============================================================
   COMPONENTS — shared across all pages
   Brand tokens: var(--brand) = primary, var(--brand-2) = secondary
   ============================================================ */

/* ── SIDEBAR ── */
.side{padding:20px 16px;display:flex;flex-direction:column;gap:6px;position:sticky;top:22px;height:calc(100vh - 44px)}
.brand{display:flex;align-items:center;gap:11px;padding:6px 8px 18px}
.logo{width:38px;height:38px;border-radius:12px;background:linear-gradient(135deg,var(--brand),var(--brand-2));color:#fff;display:flex;align-items:center;justify-content:center;font-weight:800;font-size:18px;box-shadow:0 8px 18px -6px rgba(79,70,229,.6)}
.brand b{font-size:14px;letter-spacing:-.01em;display:block;line-height:1.15}
.brand small{font-size:11px;color:var(--muted)}
.navlbl{font-size:10px;font-weight:700;color:var(--faint);text-transform:uppercase;letter-spacing:.08em;padding:10px 10px 4px}
.item{display:flex;align-items:center;gap:12px;padding:10px 12px;border-radius:13px;color:var(--muted);font-size:14px;font-weight:600;cursor:pointer;text-decoration:none}
.item:hover{background:rgba(255,255,255,.55);color:var(--ink)}
.item.on{background:linear-gradient(135deg,var(--brand),var(--brand-2));color:#fff;box-shadow:0 8px 18px -8px rgba(79,70,229,.7)}
.side .spacer{flex:1}
.userchip{display:flex;align-items:center;gap:10px;padding:10px;border-radius:14px;background:rgba(255,255,255,.5);border:1px solid var(--hair)}
.userchip .av{width:34px;height:34px;border-radius:10px;background:var(--indigo-bg);color:var(--brand-2);display:flex;align-items:center;justify-content:center;font-weight:800;font-size:12px}
.userchip b{font-size:12.5px;display:block}
.userchip small{font-size:11px;color:var(--muted)}

/* ── TOPBAR / MAIN SHELL ── */
.main{display:flex;flex-direction:column;gap:20px;padding-bottom:14px}
.top{display:flex;align-items:center;justify-content:space-between;gap:16px}
.top h1{font-size:24px;letter-spacing:-.02em;font-weight:800}
.top p{font-size:13px;color:var(--muted);margin-top:3px}
.actions{display:flex;align-items:center;gap:12px}
.search{display:flex;align-items:center;gap:9px;padding:10px 14px;border-radius:14px;color:var(--muted);min-width:210px}
.search input{border:0;background:transparent;outline:none;font-size:13px;color:var(--ink);width:100%;font-family:inherit}
.btn{display:inline-flex;align-items:center;gap:8px;border:0;cursor:pointer;font-family:inherit;padding:11px 16px;border-radius:14px;font-size:13.5px;font-weight:700;background:linear-gradient(135deg,var(--brand),var(--brand-2));color:#fff;box-shadow:0 10px 22px -8px rgba(79,70,229,.6)}

/* ── STAT CARDS ── */
.stats{display:grid;grid-template-columns:repeat(4,1fr);gap:18px}
.stat{position:relative;overflow:hidden;isolation:isolate;border-radius:22px;padding:18px;min-height:142px;color:#fff;background:linear-gradient(140deg,var(--c2),var(--c));border:1px solid rgba(255,255,255,.25);box-shadow:0 16px 34px -16px color-mix(in srgb,var(--c) 60%,transparent)}
.stat::before{content:"";position:absolute;inset:0;background:radial-gradient(120% 90% at 15% -10%,rgba(255,255,255,.28),transparent 55%);z-index:0}
.stat>*{position:relative;z-index:1}
.stat .ico{width:38px;height:38px;border-radius:12px;display:flex;align-items:center;justify-content:center;margin-bottom:13px;background:rgba(255,255,255,.2);color:#fff}
.stat .lbl{font-size:12.5px;color:rgba(255,255,255,.85)}
.stat .val{font-size:25px;font-weight:800;letter-spacing:-.02em;margin-top:4px;color:#fff}
.stat .delta{font-size:11.5px;margin-top:6px;font-weight:700;color:rgba(255,255,255,.92)}

/* ── CARDS & GRID ── */
.grid2{display:grid;grid-template-columns:1.6fr 1fr;gap:18px}
.card{padding:20px}
.card h3{font-size:15px;letter-spacing:-.01em;font-weight:700}
.card .hd{display:flex;align-items:center;justify-content:space-between;margin-bottom:16px}
.legend{display:flex;gap:14px;font-size:11.5px;color:var(--muted)}
.dot{display:inline-block;width:9px;height:9px;border-radius:3px;margin-right:5px;vertical-align:middle}

/* ── PILLS / STATUS BADGES ── */
.pill{display:inline-block;font-size:10.5px;font-weight:700;padding:4px 10px;border-radius:999px;white-space:nowrap}
.p-red{background:var(--rose-bg);color:var(--rose)}
.p-amber{background:var(--amber-bg);color:var(--amber)}
.p-green{background:var(--green-bg);color:var(--green)}
.p-blue{background:var(--blue-bg);color:var(--blue)}
.p-slate{background:var(--slate-bg);color:#475569}

/* ── TODO / JOB LIST ── */
.todo{display:flex;flex-direction:column;gap:11px}
.todo .it{display:flex;align-items:center;justify-content:space-between;gap:10px;padding:11px 12px;border-radius:14px;background:rgba(255,255,255,.5);border:1px solid var(--hair)}
.todo .who{font-size:13px;font-weight:700}
.todo .sub{font-size:11px;color:var(--muted);margin-top:3px}

/* ── TABLES ── */
table{width:100%;border-collapse:collapse}
th{text-align:left;font-size:11px;color:var(--faint);text-transform:uppercase;letter-spacing:.05em;font-weight:700;padding:0 12px 12px}
td{padding:13px 12px;font-size:13px;border-top:1px solid rgba(148,163,184,.18)}
td.num{font-weight:700;text-align:right}
th.num{text-align:right}
.klien{font-weight:700}
.inv{color:var(--muted);font-size:12px}
.link{font-size:12.5px;color:var(--brand-2);font-weight:700;cursor:pointer}

/* ── CHIPS (filter tabs) ── */
.chips{display:flex;gap:7px}
.chip{font-size:11.5px;font-weight:700;padding:7px 13px;border-radius:999px;background:rgba(255,255,255,.55);border:1px solid var(--hair);color:var(--muted);cursor:pointer}
.chip.on{background:linear-gradient(135deg,var(--brand),var(--brand-2));border-color:transparent;color:#fff}

/* ── INVOICE PAGE — summary row ── */
.sumrow{display:grid;grid-template-columns:repeat(3,1fr);gap:16px}
.sum{padding:15px 17px}
.sum .t{font-size:11.5px;color:var(--muted)}
.sum .n{font-size:20px;font-weight:800;margin-top:4px;letter-spacing:-.02em}
.sum.a .n{color:var(--amber)}
.sum.g .n{color:var(--green)}
.tcard{padding:8px 6px}
table.list{width:100%;border-collapse:collapse}
table.list th{text-align:left;font-size:11px;color:var(--faint);text-transform:uppercase;letter-spacing:.05em;font-weight:700;padding:12px 14px}
table.list td{padding:14px;font-size:13px;border-top:1px solid rgba(148,163,184,.16)}
table.list td.num,table.list th.num{text-align:right}
table.list td.num{font-weight:700}

/* ── A4 INVOICE MODAL ── */
.backdrop{position:fixed;inset:0;background:rgba(15,23,42,.45);backdrop-filter:blur(3px);z-index:40}
.modal{position:fixed;inset:0;z-index:50;display:flex;align-items:flex-start;justify-content:center;padding:34px 20px;overflow:auto}
.sheet{width:100%;max-width:720px;display:flex;flex-direction:column;border-radius:16px;overflow:hidden;box-shadow:0 40px 90px -30px rgba(15,23,42,.6);background:#fff}
.bar{display:flex;align-items:center;justify-content:space-between;padding:13px 18px;background:#0f172a;color:#fff}
.bar .ttl{font-size:13.5px;font-weight:700;display:flex;align-items:center;gap:9px}
.bar .ttl .tag{font-size:10.5px;font-weight:700;background:rgba(255,255,255,.15);padding:3px 9px;border-radius:7px}
.bar .xc{width:30px;height:30px;border-radius:9px;background:rgba(255,255,255,.14);display:flex;align-items:center;justify-content:center;cursor:pointer}
.paper{padding:40px 44px;color:#0f172a}
.ptop{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:30px}
.pco{display:flex;gap:13px}
.pco .sq{width:46px;height:46px;border-radius:13px;background:linear-gradient(135deg,var(--brand),var(--brand-2));color:#fff;display:flex;align-items:center;justify-content:center;font-weight:800;font-size:21px}
.pco b{font-size:15px;letter-spacing:-.01em}
.small{font-size:11.5px;color:var(--muted);line-height:1.6;margin-top:3px}
.ptop .rt{text-align:right}
.ptop .rt .big{font-size:30px;font-weight:800;letter-spacing:.04em;color:var(--brand-2)}
.metab{font-size:12px;color:var(--muted);line-height:1.7;margin-top:6px}
.metab b{color:var(--ink)}
.billto{margin-bottom:22px}
.ll{font-size:10.5px;text-transform:uppercase;letter-spacing:.06em;color:var(--faint);font-weight:700;margin-bottom:7px}
.selbox{display:inline-flex;align-items:center;gap:9px;border:1px solid #e3e6ee;border-radius:10px;padding:9px 13px;font-size:14px;font-weight:700;cursor:pointer}
.selbox svg.ic{width:16px;height:16px;color:var(--faint)}
table.doc{width:100%;border-collapse:collapse;margin-bottom:6px}
table.doc th{font-size:10.5px;text-transform:uppercase;letter-spacing:.05em;color:var(--faint);font-weight:700;text-align:left;padding:10px 8px;border-bottom:2px solid #ecedf2}
table.doc th.r,table.doc td.r{text-align:right}
table.doc td{padding:13px 8px;font-size:13px;border-bottom:1px solid #f1f2f6;vertical-align:top}
table.doc td.d{font-weight:600}
table.doc td.q,table.doc td.h{color:var(--muted)}
.xrow{color:#cbd2dd;cursor:pointer}
.additem{display:inline-flex;align-items:center;gap:7px;font-size:12.5px;font-weight:700;color:var(--brand-2);cursor:pointer;margin:12px 0 0}
.sumwrap{display:flex;justify-content:flex-end;margin-top:18px}
.sumbox{width:260px}
.srow{display:flex;justify-content:space-between;font-size:13px;color:var(--muted);padding:7px 0}
.srow.tot{font-size:18px;font-weight:800;color:var(--ink);border-top:2px solid #ecedf2;margin-top:4px;padding-top:12px}
.payinfo{margin-top:26px;padding:14px 16px;background:#f7f8fb;border-radius:12px;font-size:12px;color:var(--muted);line-height:1.6}
.payinfo b{color:var(--ink)}
.pactions{position:sticky;bottom:0;display:flex;gap:11px;justify-content:flex-end;padding:14px 18px;background:#fff;border-top:1px solid #eef0f4}
.ghost{border:1px solid #e3e6ee;background:#fff;cursor:pointer;font-family:inherit;font-size:13px;font-weight:700;color:var(--ink);padding:11px 18px;border-radius:12px}
.fill{border:0;cursor:pointer;font-family:inherit;font-size:13px;font-weight:800;color:#fff;padding:11px 20px;border-radius:12px;background:linear-gradient(135deg,var(--brand),var(--brand-2));box-shadow:0 12px 24px -10px rgba(79,70,229,.6)}

/* ── KLIEN (CRM master-detail) ── */
.crm{display:grid;grid-template-columns:340px 1fr;gap:18px;align-items:start}
.listcard{padding:14px}
.clist{display:flex;flex-direction:column;gap:4px;max-height:600px;overflow:auto}
.crow{display:flex;align-items:center;gap:11px;padding:10px;border-radius:13px;cursor:pointer;border:1px solid transparent}
.crow:hover{background:rgba(255,255,255,.5)}
.crow.sel{background:rgba(255,255,255,.78);border-color:var(--hair);box-shadow:0 8px 18px -12px rgba(30,41,59,.4)}
.cav{width:38px;height:38px;border-radius:11px;display:flex;align-items:center;justify-content:center;font-weight:800;font-size:12.5px;color:#fff;flex:none}
.crow .nm{font-size:13px;font-weight:700;line-height:1.2}
.crow .pc{font-size:11px;color:var(--muted);margin-top:2px}
.crow .rt{margin-left:auto;text-align:right}
.crow .vv{font-size:12px;font-weight:700}
.detail{padding:24px}
.dhead{display:flex;align-items:center;gap:14px;margin-bottom:20px}
.dav{width:56px;height:56px;border-radius:16px;display:flex;align-items:center;justify-content:center;font-weight:800;font-size:18px;color:#fff;flex:none}
.dhead .nm{font-size:18px;font-weight:800;letter-spacing:-.01em}
.dhead .mt{font-size:12.5px;color:var(--muted);margin-top:4px;display:flex;align-items:center;gap:8px}
.dhead .act{margin-left:auto;display:flex;gap:9px}
.gbtn{display:inline-flex;align-items:center;gap:7px;border:1px solid var(--hair);background:rgba(255,255,255,.6);cursor:pointer;font-family:inherit;font-size:12.5px;font-weight:700;color:var(--ink);padding:9px 13px;border-radius:11px}
.dstats{display:grid;grid-template-columns:repeat(3,1fr);gap:12px;margin-bottom:20px}
.ds{padding:13px 14px;border-radius:14px;background:rgba(255,255,255,.5);border:1px solid var(--hair)}
.ds .t{font-size:11px;color:var(--muted)}
.ds .n{font-size:17px;font-weight:800;margin-top:3px}
.ds.r .n{color:var(--rose)}
.info{display:grid;grid-template-columns:1fr 1fr;gap:13px;margin-bottom:22px}
.inf{display:flex;align-items:center;gap:11px}
.inf .ico{width:34px;height:34px;border-radius:10px;background:var(--indigo-bg);color:var(--brand-2);display:flex;align-items:center;justify-content:center;flex:none}
.inf .t{font-size:10.5px;color:var(--faint);text-transform:uppercase;letter-spacing:.04em;font-weight:700}
.inf .v{font-size:13px;font-weight:600;margin-top:1px}
.seclbl{font-size:12px;font-weight:700;color:var(--muted);text-transform:uppercase;letter-spacing:.05em;margin:0 0 11px}
.mlist{display:flex;flex-direction:column;gap:9px;margin-bottom:20px}
.mrow{display:flex;align-items:center;justify-content:space-between;gap:10px;padding:11px 13px;border-radius:13px;background:rgba(255,255,255,.5);border:1px solid var(--hair)}
.mrow .l{font-size:12.5px;font-weight:700}
.mrow .s{font-size:11px;color:var(--muted);margin-top:2px}
.mrow .amt{font-size:12.5px;font-weight:700}

/* ── KEUANGAN ── */
.monthsel{display:flex;align-items:center;gap:9px;padding:10px 14px;border-radius:14px;color:var(--ink);font-size:13px;font-weight:700;cursor:pointer}
.chart{display:flex;align-items:flex-end;gap:10px;height:188px;padding-top:6px}
.mg{flex:1;display:flex;flex-direction:column;align-items:center;gap:8px;height:100%}
.bars2{display:flex;gap:5px;align-items:flex-end;height:158px}
.bar{width:13px;border-radius:6px 6px 0 0}
.bin{background:linear-gradient(180deg,#34d399,#16a34a)}
.bout{background:linear-gradient(180deg,#fb7185,#dc2626)}
.mg .ml{font-size:11px;color:var(--faint);font-weight:600}
.cat{display:flex;flex-direction:column;gap:15px}
.crow .ct{display:flex;justify-content:space-between;font-size:12.5px;margin-bottom:6px}
.crow .ct .nm{font-weight:600}
.crow .ct .am{font-weight:700}
.track{height:8px;background:#eef1f6;border-radius:999px;overflow:hidden}
.fillb{height:100%;border-radius:999px}
/* ledger */
td.plus{color:var(--green)}
td.minus{color:var(--rose)}
.desc{font-weight:700}
.meta{color:var(--muted);font-size:12px}

/* ── PENGATURAN ── */
.sgrid{display:grid;grid-template-columns:1fr 1fr;gap:18px}
.full{grid-column:1/-1}
.ch{display:flex;align-items:center;gap:10px;margin-bottom:18px}
.ch .ci{width:34px;height:34px;border-radius:10px;background:var(--indigo-bg);color:var(--brand-2);display:flex;align-items:center;justify-content:center}
.ch h3{font-size:15px;font-weight:700;letter-spacing:-.01em}
.ch p{font-size:11.5px;color:var(--muted);margin-top:1px}
.label{font-size:12px;font-weight:700;color:#334155;margin:0 0 7px 2px;display:block}
.field{display:flex;align-items:center;gap:10px;padding:11px 13px;border-radius:12px;background:#fff;border:1px solid #e3e6ee;color:var(--faint);margin-bottom:15px}
.field input{border:0;outline:none;background:transparent;font-family:inherit;font-size:13px;color:var(--ink);width:100%}
.field:focus-within{border-color:var(--brand-2);box-shadow:0 0 0 3px rgba(79,70,229,.12)}
.two{display:grid;grid-template-columns:1fr 1fr;gap:13px}
textarea{width:100%;border:1px solid #e3e6ee;border-radius:12px;padding:11px 13px;font-family:inherit;font-size:13px;resize:none;outline:none;color:var(--ink)}
.logorow{display:flex;align-items:center;gap:16px;margin-bottom:20px}
.logobox{width:64px;height:64px;border-radius:16px;background:linear-gradient(135deg,var(--brand),var(--brand-2));color:#fff;display:flex;align-items:center;justify-content:center;font-weight:800;font-size:28px;flex:none;box-shadow:0 10px 20px -8px rgba(79,70,229,.6)}
.uploadbtn{display:inline-flex;align-items:center;gap:8px;border:1px solid #e3e6ee;background:#fff;cursor:pointer;font-family:inherit;font-size:12.5px;font-weight:700;color:var(--ink);padding:9px 14px;border-radius:11px}
.hint{font-size:11px;color:var(--faint);margin-top:6px}
.swatches{display:flex;gap:10px;margin:4px 0 8px}
.sw{width:30px;height:30px;border-radius:9px;cursor:pointer;border:2px solid transparent}
.sw.sel{border-color:#0f172a;box-shadow:0 0 0 3px rgba(15,23,42,.08)}
.wlnote{font-size:11.5px;color:var(--brand-2);background:var(--indigo-bg);border-radius:10px;padding:9px 12px;margin-top:14px;font-weight:600}
.togrow{display:flex;align-items:center;justify-content:space-between;padding:11px 0}
.togrow .tl{font-size:13px;font-weight:600}
.togrow .ts{font-size:11px;color:var(--muted)}
.toggle{width:42px;height:24px;border-radius:999px;background:#cbd5e1;position:relative;cursor:pointer;flex:none}
.toggle.on{background:var(--brand-2)}
.toggle .knob{position:absolute;top:3px;left:3px;width:18px;height:18px;border-radius:50%;background:#fff;transition:.15s}
.toggle.on .knob{left:21px}
.trow{display:flex;align-items:center;gap:12px;padding:11px 0;border-top:1px solid rgba(148,163,184,.16)}
.trow:first-of-type{border-top:0}
.tav{width:38px;height:38px;border-radius:11px;display:flex;align-items:center;justify-content:center;font-weight:800;font-size:12.5px;color:#fff;flex:none}
.trow .nm{font-size:13px;font-weight:700}
.trow .em{font-size:11.5px;color:var(--muted);margin-top:1px}
.rolebadge{margin-left:auto;font-size:10.5px;font-weight:700;padding:4px 11px;border-radius:999px}
.r-admin{background:var(--indigo-bg);color:var(--brand-2)}
.r-staff{background:rgba(100,116,139,.14);color:#475569}
.invite{display:inline-flex;align-items:center;gap:8px;margin-top:14px;border:1px dashed #cbd5e1;background:transparent;cursor:pointer;font-family:inherit;font-size:12.5px;font-weight:700;color:var(--brand-2);padding:11px;border-radius:12px;width:100%;justify-content:center}

/* ── LOGIN ── */
.wrap{width:100%;max-width:940px;display:grid;grid-template-columns:1.05fr 1fr;background:rgba(255,255,255,.55);backdrop-filter:blur(22px) saturate(165%);-webkit-backdrop-filter:blur(22px) saturate(165%);border:1px solid var(--hair);border-radius:26px;overflow:hidden;box-shadow:0 30px 70px -28px rgba(30,41,59,.5)}
.brandside{position:relative;overflow:hidden;isolation:isolate;color:#fff;padding:38px 34px;background:linear-gradient(160deg,var(--brand),var(--brand-2))}
.brandside::before{content:"";position:absolute;top:-60px;right:-50px;width:230px;height:230px;border-radius:50%;background:radial-gradient(circle,rgba(255,255,255,.28),transparent 65%)}
.brandside::after{content:"";position:absolute;bottom:-70px;left:-40px;width:200px;height:200px;border-radius:50%;background:radial-gradient(circle,rgba(34,211,238,.45),transparent 68%)}
.brandside>*{position:relative;z-index:1}
.blogo{display:flex;align-items:center;gap:12px;margin-bottom:30px}
.blogo .sq{width:42px;height:42px;border-radius:13px;background:rgba(255,255,255,.18);border:1px solid rgba(255,255,255,.35);display:flex;align-items:center;justify-content:center;font-weight:800;font-size:20px}
.blogo b{font-size:15px;display:block;letter-spacing:-.01em}
.blogo small{font-size:11.5px;opacity:.8}
.brandside h2{font-size:26px;font-weight:800;letter-spacing:-.02em;line-height:1.2;margin-bottom:10px}
.brandside p.tag{font-size:13.5px;opacity:.9;line-height:1.5;margin-bottom:28px;max-width:330px}
.feat{display:flex;flex-direction:column;gap:13px}
.feat .f{display:flex;align-items:center;gap:11px;font-size:13px;opacity:.95}
.feat .tick{width:24px;height:24px;border-radius:8px;background:rgba(255,255,255,.18);display:flex;align-items:center;justify-content:center;flex:none}
.feat .tick svg.ic{width:15px;height:15px}
.formside{padding:42px 38px;display:flex;flex-direction:column;justify-content:center;background:rgba(255,255,255,.4)}
.formside h1{font-size:23px;font-weight:800;letter-spacing:-.02em}
.formside .sub{font-size:13px;color:var(--muted);margin-top:5px;margin-bottom:26px}
.rowx{display:flex;align-items:center;justify-content:space-between;margin-bottom:22px;font-size:12.5px}
.rowx label{display:flex;align-items:center;gap:7px;color:var(--muted);cursor:pointer}
.rowx input{accent-color:var(--brand-2);width:15px;height:15px}
.rowx a{color:var(--brand-2);font-weight:700;text-decoration:none}
.submit{display:flex;align-items:center;justify-content:center;gap:9px;width:100%;border:0;cursor:pointer;font-family:inherit;padding:14px;border-radius:14px;font-size:14px;font-weight:800;color:#fff;background:linear-gradient(135deg,var(--brand),var(--brand-2));box-shadow:0 14px 26px -10px rgba(79,70,229,.65)}
.foot{text-align:center;font-size:12px;color:var(--muted);margin-top:22px}
.foot a{color:var(--brand-2);font-weight:700;text-decoration:none}
@media(max-width:720px){.wrap{grid-template-columns:1fr;max-width:420px}.brandside{display:none}}
