
@import url('https://fonts.googleapis.com/css2?family=Inter:wght@400;500;600;700;800;900&display=swap');
:root{--red:#e91b3c;--red2:#bf1029;--red3:#8b0018;--dark:#111827;--muted:#6b7280;--bg:#f3f6fb;--card:#fff;--line:#e7ecf4;--soft:#fff1f3;--green:#22c55e;--blue:#3b82f6;--amber:#f59e0b;--purple:#8b5cf6}
*{box-sizing:border-box}html,body{margin:0;font-family:Inter,Segoe UI,Arial,sans-serif;background:var(--bg);color:var(--dark);font-size:14px}a{text-decoration:none;color:inherit}button,.btn{border:0;border-radius:12px;padding:11px 17px;background:linear-gradient(135deg,#ef3346,#b5091d);color:#fff;font-weight:800;cursor:pointer;box-shadow:0 12px 24px rgba(191,16,41,.18);display:inline-flex;align-items:center;gap:8px}button:hover,.btn:hover{filter:brightness(.98);transform:translateY(-1px)}.btn-light{background:#fff;color:#344256;border:1px solid var(--line);box-shadow:0 8px 18px rgba(15,23,42,.04)}input,select,textarea{width:100%;height:44px;border:1px solid #dfe6f0;border-radius:12px;background:#fff;padding:0 14px;outline:none;color:#243247;font-family:inherit}textarea{height:96px;padding:13px}input:focus,select:focus,textarea:focus{border-color:#ef3346;box-shadow:0 0 0 4px rgba(239,51,70,.08)}label{display:block;margin:0 0 8px;font-weight:800;color:#334155;font-size:13px}.small,.muted{color:var(--muted);font-size:12px}.alert{background:#fff1f2;border:1px solid #fecdd3;color:#be123c;border-radius:14px;padding:12px 14px;margin:14px 0}.ok{background:#f0fdf4;border-color:#bbf7d0;color:#15803d}.danger{color:#dc2626}
/* LOGIN / REGISTER */
.auth-page{min-height:100vh;display:grid;grid-template-columns:48% 52%;background:#f7f9fd;overflow:auto}.auth-left{position:relative;background:radial-gradient(circle at 60% 20%,rgba(255,255,255,.14),transparent 28%),linear-gradient(135deg,#9c0618,#ef233c 55%,#b8071d);color:white;display:flex;align-items:center;justify-content:center;padding:54px;min-height:100vh}.auth-left:before{content:"";position:absolute;inset:0;background-image:radial-gradient(rgba(255,255,255,.16) 1px,transparent 1px);background-size:18px 18px;opacity:.35}.auth-brand{position:relative;max-width:480px}.auth-icon{width:74px;height:74px;border-radius:24px;background:rgba(255,255,255,.14);padding:9px;box-shadow:0 20px 45px rgba(0,0,0,.18);margin-bottom:24px}.auth-brand h1{font-size:46px;margin:0 0 8px;font-weight:900;letter-spacing:-1px}.auth-brand .tag{font-size:20px;font-style:italic;font-weight:600;margin-bottom:28px;opacity:.95}.auth-brand p{line-height:1.8;color:#ffe7eb;margin:0 0 22px}.auth-features{display:grid;gap:15px;margin-top:28px}.auth-feature{display:flex;gap:14px;align-items:center;font-weight:800}.auth-feature span{width:39px;height:39px;border-radius:13px;background:rgba(255,255,255,.15);display:grid;place-items:center}.auth-stats{display:flex;gap:42px;border-top:1px solid rgba(255,255,255,.22);margin-top:38px;padding-top:26px}.auth-stats b{font-size:28px;display:block}.auth-right{display:grid;place-items:center;padding:40px;min-height:100vh;position:relative}.auth-right:before{content:"";position:absolute;width:560px;height:560px;border-radius:50%;background:#f3e7e9;right:10%;top:22%;opacity:.75}.auth-card{position:relative;background:rgba(255,255,255,.92);backdrop-filter:blur(10px);width:min(460px,94vw);border-radius:28px;padding:48px 44px 36px;box-shadow:0 35px 85px rgba(15,23,42,.12)}.auth-card .floating-logo{position:absolute;left:50%;top:-45px;transform:translateX(-50%);width:88px;height:88px;border-radius:25px;background:#fff;padding:10px;box-shadow:0 22px 45px rgba(185,9,29,.16)}.auth-card h2{font-size:30px;margin:12px 0 6px;letter-spacing:-.6px}.auth-card .subtitle{color:#728094;margin-bottom:26px}.input-wrap{position:relative;margin-bottom:17px}.input-wrap .i{position:absolute;left:14px;top:38px;color:#9aa7ba}.input-wrap input{padding-left:41px;height:48px}.pass-eye{position:absolute;right:12px;top:39px;color:#94a3b8;cursor:pointer}.auth-submit{width:100%;height:51px;justify-content:center;border-radius:17px;font-size:15px;margin-top:8px}.auth-links{display:flex;justify-content:space-between;align-items:center;margin-top:15px;color:#718096}.auth-links a{color:#b5091d;font-weight:800}.auth-divider{display:flex;align-items:center;gap:13px;margin:24px 0;color:#a5afbe}.auth-divider:before,.auth-divider:after{content:"";height:1px;background:#e5eaf2;flex:1}.auth-help{font-size:13px;color:#475569;line-height:1.6}
.auth-register{grid-template-columns:1fr;background:linear-gradient(135deg,#990817,#e91b3c);min-height:100vh;display:grid;place-items:center;padding:38px;position:relative}.auth-register:before{content:"";position:absolute;inset:0;background-image:radial-gradient(rgba(255,255,255,.18) 1px,transparent 1px);background-size:18px 18px}.register-card{position:relative;width:min(520px,96vw);background:#fff;border-radius:28px;padding:38px 38px 30px;box-shadow:0 35px 95px rgba(0,0,0,.24)}.register-top{text-align:center;margin-bottom:22px}.register-top img{width:76px;border-radius:22px;box-shadow:0 18px 38px rgba(191,16,41,.20)}.register-top h2{font-size:28px;margin:16px 0 8px}.register-card .grid2{display:grid;grid-template-columns:1fr 1fr;gap:14px}.register-card .full{grid-column:1/-1}
/* APP */
.app{min-height:100vh}.sidebar{position:fixed;top:0;bottom:0;left:0;width:268px;background:linear-gradient(180deg,#f12448 0%,#be0f2f 52%,#7b0017 100%);color:#fff;z-index:20;overflow-y:auto;overflow-x:hidden;box-shadow:14px 0 35px rgba(126,0,24,.18);transition:width .22s ease}.sidebar::-webkit-scrollbar{width:4px}.sidebar::-webkit-scrollbar-thumb{background:rgba(255,255,255,.25);border-radius:5px}.tenant-box{height:86px;padding:15px 17px;display:flex;gap:12px;align-items:center;border-bottom:1px solid rgba(255,255,255,.12)}.tenant-box img{width:52px;height:52px;border-radius:17px;background:#fff;padding:5px;object-fit:cover}.tenant-box b{display:block;max-width:170px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.tenant-box small{opacity:.86;font-weight:700}.nav{padding:16px 12px 24px}.nav-title{font-size:10px;font-weight:900;letter-spacing:2px;text-transform:uppercase;color:#ffd2d9;margin:18px 12px 8px}.nav-link,.nav-group{display:flex;align-items:center;gap:11px;min-height:43px;border-radius:14px;padding:11px 13px;font-weight:800;color:#fff;margin:4px 0;cursor:pointer;transition:.16s}.nav-link:hover,.nav-link.active,.nav-group.active{background:rgba(255,255,255,.16)}.nav-link .icon,.nav-group .icon{font-size:18px;width:22px;text-align:center;flex:0 0 22px}.nav-group .chev{margin-left:auto;transition:.2s;opacity:.8}.nav-group.open .chev{transform:rotate(180deg)}.nav-sub{display:none;border-left:1px solid rgba(255,255,255,.25);margin-left:23px;padding:5px 0 7px 11px}.nav-sub.open{display:block}.nav-sub a{display:block;color:#fff;border-radius:11px;padding:9px 12px;font-size:13px;font-weight:750;margin:2px 0;opacity:.92}.nav-sub a:hover,.nav-sub a.active{background:#fff;color:#c70f2a;opacity:1}.logout{display:block;margin:18px 16px;text-align:center;background:rgba(0,0,0,.18);border-radius:14px;padding:13px;font-weight:900}.main{margin-left:268px;transition:margin-left .22s ease}.topbar{height:66px;background:#fff;border-bottom:1px solid var(--line);display:flex;align-items:center;justify-content:space-between;padding:0 26px;position:sticky;top:0;z-index:10}.hamb{width:39px;height:39px;border:1px solid var(--line);border-radius:12px;display:grid;place-items:center;color:#64748b;background:#fff;cursor:pointer;font-size:20px}.title-wrap{display:flex;gap:12px;align-items:center}.crumb{font-size:12px;color:#9aa7ba}.page-title{font-size:19px;font-weight:900;color:#172036}.top-actions{display:flex;align-items:center;gap:15px;color:#516073;font-weight:700}.round{width:34px;height:34px;border-radius:10px;background:#fff1f2;color:#bd0d1f;display:grid;place-items:center;font-size:12px;font-weight:900}.user-menu{position:relative}.dropdown{display:none;position:absolute;right:0;top:40px;width:220px;background:#fff;border:1px solid var(--line);border-radius:14px;box-shadow:0 20px 50px rgba(15,23,42,.12);overflow:hidden}.dropdown a{display:block;padding:13px 16px}.dropdown a:hover{background:#f8fafc}.user-menu.open .dropdown{display:block}.content{padding:24px 28px 50px}.toast{position:fixed;top:18px;left:50%;transform:translateX(-50%);z-index:100;background:#fff;border-radius:14px;box-shadow:0 18px 55px rgba(15,23,42,.16);padding:13px 18px;font-weight:800}.toast:before{content:'✓';color:#22c55e;margin-right:8px}.toast.err:before{content:'✕';color:#ef233c}.hero{border-radius:22px;background:linear-gradient(135deg,#fff,#fff7f8);border:1px solid #ffe1e6;padding:24px;display:flex;align-items:center;justify-content:space-between;margin-bottom:19px;box-shadow:0 16px 40px rgba(15,23,42,.04)}.hero h1{margin:0;font-size:30px}.hero p{margin:8px 0 0;color:#65758b}.badge{display:inline-flex;align-items:center;gap:7px;border-radius:999px;padding:9px 13px;background:#fff7ed;color:#9a3412;border:1px solid #fed7aa;font-weight:900}.stat-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:17px;margin-bottom:18px}.stat{background:#fff;border:1px solid var(--line);border-radius:18px;padding:20px;box-shadow:0 12px 28px rgba(15,23,42,.035);min-height:112px}.stat .ico{width:43px;height:43px;border-radius:14px;display:grid;place-items:center;background:#f0fdf4;font-size:20px;margin-bottom:14px}.stat b{font-size:24px}.stat p{margin:4px 0 0;color:var(--muted);font-size:13px}.panel{background:#fff;border:1px solid var(--line);border-radius:18px;box-shadow:0 12px 28px rgba(15,23,42,.035);margin-bottom:18px}.panel-head{padding:18px 20px;border-bottom:1px solid var(--line);display:flex;align-items:center;justify-content:space-between}.panel-head h3{margin:0;font-size:17px}.panel-body{padding:20px}.grid2{display:grid;grid-template-columns:1.35fr .85fr;gap:18px}.menu-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:13px}.menu-card{background:#fff;border:1px solid var(--line);border-radius:17px;padding:18px;box-shadow:0 8px 20px rgba(15,23,42,.03);transition:.18s}.menu-card:hover{transform:translateY(-2px);box-shadow:0 18px 32px rgba(15,23,42,.08)}.menu-card .ico{width:42px;height:42px;border-radius:14px;background:#fff1f2;color:#c9182b;display:grid;place-items:center;font-size:20px;margin-bottom:12px}.toolbar{background:#fff;border:1px solid var(--line);border-radius:18px 18px 0 0;padding:16px 18px;display:flex;justify-content:space-between;align-items:center;gap:12px}.filters{display:flex;gap:10px;width:min(760px,70%)}.filters input,.filters select{max-width:280px}.tablebox{background:#fff;border:1px solid var(--line);border-top:0;border-radius:0 0 18px 18px;overflow:hidden}.table{width:100%;border-collapse:collapse}.table th{background:#fbfcfe;color:#334155;text-transform:uppercase;letter-spacing:.02em;font-size:12px;text-align:left;padding:16px;border-bottom:1px solid var(--line);font-weight:900}.table td{padding:15px 16px;border-bottom:1px solid #f1f5f9;color:#475569}.empty{text-align:center!important;color:#cbd5e1!important;padding:60px 0!important}.empty:before{content:'▱';display:block;font-size:38px;margin-bottom:8px;color:#e2e8f0}.cards2{display:grid;grid-template-columns:1fr 1fr;gap:18px}.report-box{padding:22px}.rowline{display:flex;justify-content:space-between;border:1px solid var(--line);background:#fbfcfe;border-radius:12px;padding:15px;margin:10px 0;font-weight:800}.notice{background:#fff8e6;border:1px solid #f6d98d;border-left:5px solid #e49b16;color:#8a5a05;border-radius:14px;padding:15px 18px;margin-bottom:16px;font-weight:800}.modal{position:fixed;inset:0;display:none;align-items:center;justify-content:center;background:rgba(15,23,42,.56);z-index:50;padding:20px}.modal.open{display:flex}.modal-card{width:min(660px,96vw);max-height:92vh;overflow:auto;background:#fff;border-radius:22px;box-shadow:0 35px 100px rgba(15,23,42,.28)}.modal-wide{width:min(820px,96vw)}.modal-head{padding:23px 26px;background:linear-gradient(135deg,#ef3346,#a50719);color:#fff;display:flex;gap:15px;align-items:center;position:relative}.modal-head .plus{width:48px;height:48px;border-radius:13px;background:rgba(255,255,255,.18);display:grid;place-items:center;font-size:24px}.modal-head h3{margin:0;font-size:20px}.modal-head p{margin:4px 0 0;opacity:.9;font-size:13px}.closex{position:absolute;right:18px;top:13px;font-size:26px;cursor:pointer;opacity:.75}.modal-body{padding:26px}.form-grid{display:grid;grid-template-columns:1fr 1fr;gap:17px}.form-grid .full{grid-column:1/-1}.actions{display:flex;justify-content:flex-end;gap:10px;border-top:1px solid var(--line);margin-top:24px;padding-top:18px}.upload-box{width:190px;height:140px;border:2px dashed #d1d5db;border-radius:13px;display:grid;place-items:center;text-align:center;color:#9aa3af;background:#fafafa}.config-section{border-top:2px solid #cf2936;padding:18px 0 28px}.config-row{display:grid;grid-template-columns:1fr 1fr;gap:18px;background:#f8fbff;border:1px solid #e1e9f6;border-radius:14px;padding:18px;margin:12px 0}.pos-hero{background:linear-gradient(135deg,#bd1028,#ef3346);color:#fff;border-radius:18px;padding:24px;display:flex;align-items:center;justify-content:space-between;box-shadow:0 18px 36px rgba(191,16,41,.22)}
body.sidebar-collapsed .sidebar{width:72px}body.sidebar-collapsed .main{margin-left:72px}body.sidebar-collapsed .tenant-box{justify-content:center;padding:12px}body.sidebar-collapsed .tenant-box img{width:44px;height:44px}body.sidebar-collapsed .tenant-box div,body.sidebar-collapsed .nav-title,body.sidebar-collapsed .nav-link span:not(.icon),body.sidebar-collapsed .nav-group span:not(.icon),body.sidebar-collapsed .nav-group .chev,body.sidebar-collapsed .nav-sub,body.sidebar-collapsed .logout span{display:none}body.sidebar-collapsed .nav-link,body.sidebar-collapsed .nav-group{justify-content:center;padding:12px}body.sidebar-collapsed .logout{margin:18px 12px;padding:12px}
@media(max-width:980px){.auth-page{grid-template-columns:1fr}.auth-left{display:none}.auth-right:before{display:none}.main{margin-left:0}.sidebar{transform:translateX(-100%)}body.mobile-open .sidebar{transform:translateX(0)}.stat-grid,.menu-grid,.cards2,.grid2,.form-grid,.register-card .grid2{grid-template-columns:1fr}.filters{width:100%;flex-wrap:wrap}.toolbar{flex-direction:column;align-items:stretch}}

/* === KOPDES ONE PATCH: sidebar collapse + konfigurasi sesuai referensi === */
body.sidebar-collapsed .sidebar, html.sidebar-collapsed .sidebar{width:74px!important;}
body.sidebar-collapsed .main, html.sidebar-collapsed .main{margin-left:74px!important;}
body.sidebar-collapsed .tenant-box, html.sidebar-collapsed .tenant-box{justify-content:center!important;padding:12px 8px!important;}
body.sidebar-collapsed .tenant-box img, html.sidebar-collapsed .tenant-box img{width:46px!important;height:46px!important;}
body.sidebar-collapsed .tenant-box div,
body.sidebar-collapsed .nav-title,
body.sidebar-collapsed .nav-link span:not(.icon),
body.sidebar-collapsed .nav-group .txt,
body.sidebar-collapsed .nav-group .chev,
body.sidebar-collapsed .nav-sub,
body.sidebar-collapsed .logout span,
html.sidebar-collapsed .tenant-box div,
html.sidebar-collapsed .nav-title,
html.sidebar-collapsed .nav-link span:not(.icon),
html.sidebar-collapsed .nav-group .txt,
html.sidebar-collapsed .nav-group .chev,
html.sidebar-collapsed .nav-sub,
html.sidebar-collapsed .logout span{display:none!important;}
body.sidebar-collapsed .nav-link,body.sidebar-collapsed .nav-group,
html.sidebar-collapsed .nav-link,html.sidebar-collapsed .nav-group{justify-content:center!important;padding:13px 0!important;margin:8px 5px!important;}
body.sidebar-collapsed .nav-link .icon,body.sidebar-collapsed .nav-group .icon,
html.sidebar-collapsed .nav-link .icon,html.sidebar-collapsed .nav-group .icon{margin:0!important;font-size:20px!important;}
body.sidebar-collapsed .logout, html.sidebar-collapsed .logout{padding:12px 0!important;margin:18px 10px!important;}
.hamb{position:relative;z-index:25;}
.config-page{max-width:1500px;margin:0 auto 40px;}
.config-card{background:#fff;border:1px solid #e7edf5;border-radius:18px;box-shadow:0 12px 30px rgba(15,23,42,.035);padding:24px 24px 0;}
.config-head{display:flex;justify-content:space-between;gap:18px;align-items:flex-start;margin-bottom:20px;}
.config-head h2{margin:0;color:#172036;font-size:25px;letter-spacing:-.4px;}
.config-head p{margin:4px 0 0;color:#718096;}
.config-actions{display:flex;gap:10px;flex-wrap:wrap;justify-content:flex-end;}
.btn-danger{background:linear-gradient(135deg,#ef3346,#b5091d)!important;color:#fff!important;}
.config-section.pro{border-top:0;padding:0 0 28px;margin:0 0 22px;}
.config-section.pro h3{font-size:18px;margin:0 0 18px;padding-bottom:12px;border-bottom:2px solid #cf2936;color:#243247;}
.config-total{color:#64748b;font-weight:800;font-size:15px;}
.config-grid{display:grid;grid-template-columns:1fr 1fr;gap:18px;}
.config-grid .full{grid-column:1/-1;}
.fund-list{display:grid;gap:14px;}
.fund-row{display:grid;grid-template-columns:1fr 1fr;gap:18px;padding:18px;border:1px solid #e5eaf2;background:#fbfcfe;border-radius:15px;}
.fund-row.soft{background:#f1f6ff;border-color:#dbe8ff;}
.sticky-actions{position:sticky;bottom:0;background:linear-gradient(180deg,rgba(255,255,255,.72),#fff 45%);border-top:1px solid #edf2f7;margin:10px -24px 0;padding:18px 24px;display:flex;justify-content:flex-end;border-radius:0 0 18px 18px;}
@media(max-width:980px){.config-head,.config-grid,.fund-row{grid-template-columns:1fr;display:grid}.config-actions{justify-content:flex-start}.config-card{padding:18px 14px 0}.sticky-actions{margin-left:-14px;margin-right:-14px}.sidebar{transition:transform .22s ease,width .22s ease!important}}
