:root{--brand:#0077ff;--brand-2:#00a8ff;--bg:#eef2f9;--bg2:#f1f5fb;--card:#ffffff;--card2:#f8fafc;--line:#e5e9f2;--txt:#1f2430;--muted:#6b7280;--green:#16a34a;--red:#ef4444;--amber:#f59e0b;--accent:var(--brand);--accent2:var(--brand-2);--shadow:0 10px 28px rgba(20,40,90,0.08)}[data-color=green]{--brand:#15a34a;--brand-2:#34d27a}[data-color=purple]{--brand:#7c3aed;--brand-2:#a855f7}[data-color=orange]{--brand:#ea6a0c;--brand-2:#f59e0b}[data-mode=dark]{--bg:#0a0e1a;--bg2:#0f1530;--card:#141b2e;--card2:#1a2344;--line:#243049;--txt:#e9edf7;--muted:#9aa6c0;--shadow:0 12px 28px rgba(0,0,0,0.35)}*{box-sizing:border-box}body,html{margin:0;padding:0}body{background:var(--bg);color:var(--txt);font-family:ui-sans-serif,system-ui,-apple-system,Segoe UI,Roboto,sans-serif;min-height:100vh;-webkit-text-size-adjust:100%}a{color:inherit;text-decoration:none}.wrap{max-width:1100px;margin:0 auto;padding:20px 16px 80px}.topbar{position:-webkit-sticky;position:sticky;top:0;z-index:20;justify-content:space-between;gap:12px;padding:12px 18px;color:#fff;background:linear-gradient(135deg,var(--brand),var(--brand-2));box-shadow:0 4px 18px rgba(0,80,200,.25)}.brand,.topbar{display:flex;align-items:center}.brand{gap:11px;min-width:0}.logo{width:38px;height:38px;border-radius:11px;background:rgba(255,255,255,.22);display:grid;place-items:center;font-weight:900;font-size:20px;color:#fff;flex:none}.brand h1{font-size:15px;margin:0;color:#fff;white-space:nowrap}.brand p{margin:1px 0 0;font-size:11px;color:rgba(255,255,255,.85)}.nav{display:flex;gap:8px}.btn,.nav{align-items:center}.btn{display:inline-flex;justify-content:center;gap:7px;min-height:40px;padding:0 14px;border-radius:999px;border:1px solid var(--line);background:var(--card);color:var(--txt);font-size:13px;font-weight:600;cursor:pointer;transition:.15s}.btn:hover{border-color:var(--brand)}.btn:active{transform:scale(.98)}.btn:disabled{opacity:.5;cursor:not-allowed}.btn-primary{background:linear-gradient(135deg,var(--brand),var(--brand-2));border:none;color:#fff}.btn-ghost{background:transparent;border:1px solid var(--line);color:var(--txt)}.btn-ghost:hover{border-color:var(--brand);color:var(--brand)}.btn-green{background:var(--green)}.btn-green,.btn-red{border:none;color:#fff}.btn-red{background:var(--red)}.btn-amber{background:var(--amber);border:none;color:#2a1c00}.grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));grid-gap:16px;gap:16px}.card{background:var(--card);border:1px solid var(--line);border-radius:16px;padding:18px;box-shadow:var(--shadow)}.card-head{display:flex;align-items:flex-start;justify-content:space-between;gap:10px}.vm-name{font-size:16px;font-weight:700;margin:0}.vm-id{font-size:12px;color:var(--muted);margin:3px 0 0}.badge{font-size:11px;font-weight:700;padding:4px 10px;border-radius:999px;text-transform:uppercase;letter-spacing:.4px}.badge.RUNNING{background:rgba(22,163,74,.14);color:var(--green)}.badge.STOPPED{background:rgba(107,114,128,.16);color:var(--muted)}.badge.CREATING{background:rgba(245,158,11,.16);color:#b45309}.badge.ERROR{background:rgba(239,68,68,.14);color:var(--red)}.specs{display:flex;gap:14px;margin:14px 0;flex-wrap:wrap}.spec{font-size:12px;color:var(--muted)}.spec b{color:var(--txt);font-weight:700}.owner{font-size:12px;color:var(--muted);margin:0 0 12px}.actions{display:flex;gap:8px;flex-wrap:wrap}.login{max-width:420px;margin:8vh auto 0;text-align:center;background:var(--card);border-radius:22px;padding:34px 26px;box-shadow:var(--shadow)}.login .logo{width:66px;height:66px;margin:0 auto 18px;font-size:32px;border-radius:18px;background:linear-gradient(135deg,var(--brand),var(--brand-2))}.login h1{font-size:21px;margin:0 0 6px}.login p{margin:0 0 22px}.empty,.login p{color:var(--muted);font-size:14px}.empty{text-align:center;padding:48px 0}.note{background:color-mix(in srgb,var(--brand) 8%,var(--card));border:1px solid color-mix(in srgb,var(--brand) 25%,var(--line));color:var(--txt);padding:12px 14px;border-radius:12px;font-size:13px;margin-bottom:18px}.msg{font-size:12px;margin:10px 0 0;min-height:16px}.msg.ok{color:var(--green)}.msg.err{color:var(--red)}.create-box{margin:8px 0 20px}.create-form,.cred-box{background:var(--card);border:1px solid var(--line);border-radius:16px;padding:16px 18px;margin-top:10px;max-width:460px;box-shadow:var(--shadow)}.create-form h3,.cred-box h3{margin:0 0 12px;font-size:15px}.create-form label{display:block;font-size:13px;color:var(--muted);margin-bottom:12px}.create-form input,.create-form select{display:block;width:100%;margin-top:5px;min-height:42px;padding:9px 12px;background:var(--bg2);border:1px solid var(--line);border-radius:10px;color:var(--txt);font-size:15px}.cred-box{border-color:var(--green);background:color-mix(in srgb,var(--green) 7%,var(--card))}.cred-box ul{list-style:none;padding:0;margin:0 0 10px;font-size:14px;line-height:1.9}.cred-box b{font-family:ui-monospace,Cascadia Code,monospace;color:var(--txt);-webkit-user-select:all;-moz-user-select:all;user-select:all}.hint{font-size:12px;color:var(--muted);margin:4px 0 10px}.search-row{display:flex;gap:8px;margin:14px 0;max-width:460px}.search-row input{flex:1 1;min-height:42px;padding:9px 12px;background:var(--card);border:1px solid var(--line);border-radius:10px;color:var(--txt);font-size:15px}.qtable{width:100%;border-collapse:collapse;margin-top:8px;font-size:14px;background:var(--card);border-radius:14px;overflow:hidden;box-shadow:var(--shadow)}.qtable td,.qtable th{text-align:left;padding:11px 12px;border-bottom:1px solid var(--line)}.qtable th{color:var(--muted);font-weight:600;font-size:12px;background:var(--card2)}.qtable .center{text-align:center}.qtable .nisn{color:var(--muted);font-size:12px}.qtable .num{width:64px;min-height:38px;padding:6px 8px;background:var(--bg2);border:1px solid var(--line);border-radius:8px;color:var(--txt);text-align:center;font-size:15px}.switch{display:inline-flex;align-items:center;gap:6px;cursor:pointer;font-size:13px}.switch input{width:18px;height:18px;accent-color:var(--green)}.ok{color:var(--green)}.err{color:var(--red)}.theme-fab{position:fixed;right:14px;bottom:14px;z-index:50}.theme-fab .toggle-btn{width:50px;height:50px;border-radius:50%;border:0;font-size:22px;cursor:pointer;color:#fff;background:linear-gradient(135deg,var(--brand),var(--brand-2));box-shadow:var(--shadow)}.theme-pop{position:absolute;right:0;bottom:60px;background:var(--card);border:1px solid var(--line);border-radius:16px;padding:14px;box-shadow:var(--shadow);width:200px}.theme-pop h4{margin:0 0 8px;font-size:12px;color:var(--muted);font-weight:600}.swatches{display:flex;gap:8px;margin-bottom:12px}.swatch{width:30px;height:30px;border-radius:50%;border:2px solid transparent;cursor:pointer}.swatch.active{border-color:var(--txt)}.modes{display:flex;gap:8px}.modes button{flex:1 1;padding:8px;border-radius:10px;border:1px solid var(--line);background:transparent;color:var(--txt);font-size:13px;cursor:pointer}.modes button.active{background:var(--brand);color:#fff;border-color:var(--brand)}.table-scroll{overflow-x:auto;-webkit-overflow-scrolling:touch}.muted{color:var(--muted)}.inline{display:flex;align-items:center;gap:8px;font-size:13px;cursor:pointer}.inline input[type=checkbox]{width:18px;height:18px;accent-color:var(--brand);flex:none}.vm-name-link{display:inline-block;cursor:pointer}.vm-name-link:hover{color:var(--brand)}.vm-toolbar{gap:8px;margin:16px 0}.tabs,.vm-toolbar{display:flex;flex-wrap:wrap}.tabs{gap:6px;border-bottom:1px solid var(--line);margin:18px 0 16px}.tab{min-height:40px;padding:0 16px;border:1px solid transparent;border-bottom:none;border-radius:12px 12px 0 0;background:transparent;color:var(--muted);font-size:13px;font-weight:600;cursor:pointer}.tab:hover{color:var(--txt)}.tab.on{background:var(--card);border-color:var(--line);color:var(--brand);box-shadow:0 -2px 8px rgba(20,40,90,.05)}.stat-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));grid-gap:14px;gap:14px;margin-bottom:16px}.stat-card{padding:16px}.statbar-head{display:flex;justify-content:space-between;font-size:13px;margin-bottom:8px}.statbar-track{height:10px;border-radius:999px;background:var(--bg2);overflow:hidden}.statbar-fill{height:100%;border-radius:999px;transition:width .4s ease}.bar-green{background:var(--green)}.bar-amber{background:var(--amber)}.bar-red{background:var(--red)}.kv{display:grid;grid-template-columns:repeat(auto-fit,minmax(160px,1fr));grid-gap:12px 18px;gap:12px 18px;margin-bottom:16px}.kv>div{display:flex;flex-direction:column;gap:2px}.kv span{font-size:11px;color:var(--muted);text-transform:uppercase;letter-spacing:.3px}.kv b{font-size:14px}.settings{display:flex;flex-direction:column;gap:14px}.settings h3{margin:0 0 12px;font-size:15px}.form-row{display:flex;gap:10px;flex-wrap:wrap;align-items:flex-end}.form-row label{display:flex;flex-direction:column;gap:5px;font-size:12px;color:var(--muted)}.form-row input,.form-row select{min-height:42px;padding:9px 12px;background:var(--bg2);border:1px solid var(--line);border-radius:10px;color:var(--txt);font-size:15px}.card.danger{border-color:color-mix(in srgb,var(--red) 40%,var(--line))}.list{display:flex;flex-direction:column;gap:10px}.list-row{display:flex;align-items:center;justify-content:space-between;gap:12px;padding:14px 16px}.list-row p{margin:3px 0 0;font-size:12px}.bulk-controls{display:flex;flex-wrap:wrap;gap:18px;align-items:center;margin-bottom:14px}.bulk-max{display:flex;flex-direction:column;gap:4px;font-size:12px;color:var(--muted)}.bulk-max input{width:90px;min-height:40px;padding:8px 10px;background:var(--bg2);border:1px solid var(--line);border-radius:10px;color:var(--txt);font-size:15px;text-align:center}.tree{display:flex;flex-direction:column;gap:12px}.tree-jur{border:1px solid var(--line);border-radius:14px;padding:12px 14px;background:var(--card)}.tree-jur-head{font-size:14px}.tree-kelas{display:flex;flex-wrap:wrap;gap:8px;margin-top:10px;padding-left:26px}.chip-check{display:inline-flex;align-items:center;gap:6px;padding:7px 12px;border:1px solid var(--line);border-radius:999px;font-size:13px;cursor:pointer;background:var(--bg2)}.chip-check.on{border-color:var(--brand);background:color-mix(in srgb,var(--brand) 12%,var(--card));color:var(--brand)}.chip-check input{width:16px;height:16px;accent-color:var(--brand)}.bulk-foot{display:flex;align-items:center;justify-content:space-between;gap:12px;flex-wrap:wrap;margin-top:16px}@media (max-width:560px){.topbar{flex-wrap:wrap;padding:10px 12px}.brand h1{font-size:14px}.brand p{display:none}.nav{gap:6px}.nav .btn{min-height:38px;padding:0 11px;font-size:12px}.grid{grid-template-columns:1fr}.actions{gap:6px}.actions .btn{flex-grow:1;flex-shrink:1;flex-basis:calc(50% - 6px)}.qtable{font-size:13px;min-width:480px}.qtable td,.qtable th{padding:9px 7px}.create-form,.cred-box{max-width:100%}}.shell{display:flex;min-height:100vh}.sidebar{width:248px;flex:none;background:var(--card);border-right:1px solid var(--line);display:flex;flex-direction:column;position:-webkit-sticky;position:sticky;top:0;height:100vh}.sb-brand{display:flex;align-items:center;gap:10px;padding:16px;border-bottom:1px solid var(--line)}.sb-brand .logo{width:38px;height:38px;border-radius:11px;background:linear-gradient(135deg,var(--brand),var(--brand-2));display:grid;place-items:center;font-weight:900;color:#fff;font-size:18px;flex:none}.sb-brand b{display:block;font-size:14px}.sb-brand span{display:block;font-size:11px;color:var(--muted)}.sb-nav{flex:1 1;padding:10px;display:flex;flex-direction:column;gap:3px;overflow-y:auto}.sb-foot{padding:10px;border-top:1px solid var(--line)}.sb-item{display:flex;align-items:center;gap:11px;padding:10px 12px;border-radius:11px;color:var(--txt);font-size:14px;font-weight:600;cursor:pointer}.sb-item:hover{background:var(--bg2)}.sb-item.on{background:color-mix(in srgb,var(--brand) 14%,var(--card));color:var(--brand)}.sb-ico{width:22px;text-align:center;font-size:16px;flex:none}.sb-label{flex:1 1}.sb-badge{background:var(--bg2);color:var(--muted);font-size:11px;font-weight:700;padding:2px 8px;border-radius:999px}.sb-item.on .sb-badge{background:var(--brand);color:#fff}.content{flex:1 1;min-width:0;display:flex;flex-direction:column}.apptop{position:-webkit-sticky;position:sticky;top:0;z-index:15;display:flex;align-items:center;gap:10px;padding:10px 18px;background:var(--card);border-bottom:1px solid var(--line)}.apptop-sp{flex:1 1}.hamb{display:none;background:transparent;border:1px solid var(--line);border-radius:10px;width:40px;height:40px;font-size:18px;cursor:pointer;color:var(--txt)}.role-pill{font-size:12px;font-weight:700;padding:6px 12px;border-radius:999px;background:var(--bg2);color:var(--muted)}.role-pill.admin{background:color-mix(in srgb,var(--brand) 16%,var(--card));color:var(--brand)}.online-pill{display:flex;align-items:center;gap:6px;font-size:12px;color:var(--green);font-weight:600}.online-pill .dot{width:8px;height:8px;border-radius:50%;background:var(--green);box-shadow:0 0 0 3px color-mix(in srgb,var(--green) 25%,transparent)}.who{font-size:13px;color:var(--muted);max-width:120px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.appmain{padding:22px 24px 70px;max-width:1160px;width:100%}.page-head{margin-bottom:18px}.page-head h1{font-size:22px;margin:0 0 4px;display:flex;align-items:center;gap:10px;flex-wrap:wrap}.page-head p{margin:0}.page-head .btn{margin-top:10px}.sec-title{font-size:15px;margin:18px 0 10px}.panel-sec{margin-bottom:26px}.quick-links{display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));grid-gap:14px;gap:14px;margin-top:18px}.quick{display:flex;flex-direction:column;gap:4px;text-decoration:none;transition:.15s}.quick:hover{border-color:var(--brand);transform:translateY(-2px)}.quick .q-ico{font-size:24px}.os-list{display:flex;flex-wrap:wrap;gap:8px}.os-chip{display:inline-flex;align-items:center;gap:6px;padding:7px 13px;border-radius:999px;background:var(--bg2);border:1px solid var(--line);font-size:13px}.graph-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));grid-gap:14px;gap:14px}.graph-card{padding:14px}.graph-svg{width:100%;height:120px;display:block;margin:8px 0}.tf-row{display:flex;gap:6px;margin-bottom:12px}.chip{padding:6px 14px;font-weight:600;cursor:pointer;text-transform:capitalize}.chip.on{background:var(--brand);color:#fff;border-color:var(--brand)}.link{color:var(--brand);text-decoration:underline}@media (max-width:820px){.sidebar{position:fixed;left:0;top:0;z-index:60;transform:translateX(-100%);transition:transform .22s;box-shadow:var(--shadow)}.shell.sb-open .sidebar{transform:translateX(0)}.sb-scrim{position:fixed;inset:0;background:rgba(0,0,0,.4);z-index:55}.hamb{display:block}.appmain{padding:18px 14px 70px}}.fld{display:block;font-size:12px;color:var(--muted);margin-bottom:12px}.fld input,.fld textarea{display:block;width:100%;margin-top:5px;min-height:42px;padding:9px 12px;background:var(--bg2);border:1px solid var(--line);border-radius:10px;color:var(--txt);font-size:15px;font-family:inherit}.fld textarea{font-size:13px;resize:vertical}.fld textarea,.mono-ellip{font-family:ui-monospace,Cascadia Code,monospace}.mono-ellip{font-size:11px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;max-width:100%}code{background:var(--bg2);padding:1px 5px;border-radius:5px}.recipe-out,code{font-family:ui-monospace,Cascadia Code,monospace;font-size:12px}.recipe-out{margin-top:12px;background:#0b1020;color:#c8e1ff;padding:12px 14px;border-radius:10px;max-height:280px;overflow:auto;white-space:pre-wrap;word-break:break-word}.dash-cards{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));grid-gap:14px;gap:14px;margin-bottom:20px}.dash-card{display:flex;align-items:center;gap:14px;padding:18px}.dc-ico{font-size:28px;width:54px;height:54px;display:grid;place-items:center;border-radius:14px;background:color-mix(in srgb,var(--brand) 12%,var(--card));flex:none}.dash-card>div{display:flex;flex-direction:column;min-width:0}.dc-label{font-size:12px;color:var(--muted)}.dc-num{font-size:26px;font-weight:800;line-height:1.15}.dc-sub{font-size:11px;color:var(--muted)}.suffix-input{display:flex;align-items:stretch}.suffix-input input{border-top-right-radius:0;border-bottom-right-radius:0;flex:1 1;min-width:0}.suffix-input span{padding:0 10px;display:flex;align-items:center;background:var(--card2);border:1px solid var(--line);border-left:0;border-radius:0 10px 10px 0;color:var(--muted);font-size:13px;white-space:nowrap}.inp{width:100%;padding:9px 11px;border:1px solid var(--line);border-radius:10px;background:var(--card);color:var(--txt);font-size:14px;outline:none}.inp:focus{border-color:var(--accent)}.filterbar{display:flex;flex-wrap:wrap;gap:8px;margin-bottom:14px;align-items:center}.filterbar .inp{flex:1 1 160px;width:auto;min-width:120px}.filterbar .btn{flex:0 0 auto}.pager{display:flex;align-items:center;justify-content:center;gap:14px;margin-top:14px}.rowlink{cursor:pointer}.rowlink:hover td{background:var(--card2)}.detail-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));grid-gap:14px;gap:14px}.kv-row{display:flex;justify-content:space-between;gap:12px;padding:7px 0;border-bottom:1px dashed var(--line);align-items:center}.kv-row>span{color:var(--muted);font-size:13px;flex:0 0 auto}.kv-row>b{text-align:right}.kv-row .inp{max-width:60%}.card-actions{display:flex;gap:8px;margin-top:12px;flex-wrap:wrap}.form-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));grid-gap:12px;gap:12px}.form-grid label{display:flex;flex-direction:column;gap:4px}.form-grid label>span{color:var(--muted);font-size:13px}.role-cat{display:grid;grid-template-columns:repeat(auto-fit,minmax(240px,1fr));grid-gap:10px;gap:10px;margin-top:10px}.role-card{border:1px solid var(--line);border-radius:12px;padding:12px;background:var(--card2)}.role-card>b{text-transform:capitalize}.chips{display:flex;flex-wrap:wrap;gap:6px;margin-top:8px}.chip{background:var(--card);border:1px solid var(--line);border-radius:999px;padding:3px 10px;font-size:12px;color:var(--muted)}.chip-role{color:var(--txt);border-color:var(--accent);display:inline-flex;align-items:center;gap:6px}.chip-x{border:none;background:transparent;color:var(--red);cursor:pointer;font-size:15px;line-height:1;padding:0}.user-row{margin-bottom:10px}.user-head{display:flex;justify-content:space-between;align-items:flex-start;gap:10px}.addrole{display:flex;flex-wrap:wrap;gap:8px;margin-top:10px;padding-top:10px;border-top:1px dashed var(--line)}.addrole .inp{flex:1 1 150px;width:auto}.bio-wrap{display:flex;gap:18px;flex-wrap:wrap;align-items:flex-start}.foto-box{flex:0 0 120px;display:flex;flex-direction:column;align-items:center;gap:6px}.foto-img{object-fit:cover;border:1px solid var(--line);border-radius:8px}.foto-img,.foto-ph{width:113px;height:151px;background:var(--card2)}.foto-ph{border:1px dashed var(--line);border-radius:8px;display:flex;align-items:center;justify-content:center;text-align:center;color:var(--muted);font-size:12px}.btn-sm{padding:4px 10px;font-size:12px}.bio-fields{flex:1 1 280px;min-width:240px}.bio-row{display:flex;gap:10px;padding:5px 0;border-bottom:1px dashed var(--line)}.bio-label{flex:0 0 180px;color:var(--muted);font-size:13px}.bio-val{flex:1 1}.bio-sub{margin-top:14px;padding-top:10px;border-top:1px solid var(--line)}.bio-sub h4{margin:0 0 6px;font-size:14px}@media (max-width:600px){.bio-label{flex-basis:130px}}.rapor-sheet{max-width:800px;margin:0 auto}.rapor-kop{text-align:center;border-bottom:2px solid var(--txt);padding-bottom:8px;margin-bottom:12px}.rapor-kop h2{margin:0;font-size:18px}.rapor-kop p{margin:2px 0 0;font-weight:600}.rapor-id{display:grid;grid-template-columns:1fr 1fr;grid-gap:4px 16px;gap:4px 16px;font-size:13px;margin-bottom:12px}.rapor-id span{display:inline-block;width:130px;color:var(--muted)}.rapor-tbl{width:100%;border-collapse:collapse;font-size:13px}.rapor-tbl td,.rapor-tbl th{border:1px solid var(--line);padding:5px 8px;vertical-align:top}.rapor-group td,.rapor-tbl th{background:var(--card2)}.rapor-group td{font-weight:700}.rapor-ttd{display:flex;justify-content:space-between;margin-top:28px;font-size:13px;text-align:center}.rapor-ttd>div{width:45%}@media print{.apptop,.noprint,.sb-scrim,.sidebar{display:none!important}.appmain,.content,.shell{display:block!important;margin:0!important;padding:0!important}.card{box-shadow:none!important;border:none!important}.rapor-tbl th{background:#eee!important;-webkit-print-color-adjust:exact}}.rapor-print{overflow-x:auto}.tpl-editor{display:grid;grid-template-columns:1fr 1fr;grid-gap:12px;gap:12px}.tpl-editor textarea{width:100%;min-height:460px;font-family:ui-monospace,Menlo,monospace;font-size:12px;padding:10px;background:var(--card);color:var(--txt)}.tpl-editor textarea,.tpl-prev{border:1px solid var(--line);border-radius:10px}.tpl-prev{padding:12px;background:#fff;color:#000;overflow:auto;max-height:70vh}@media (max-width:800px){.tpl-editor{grid-template-columns:1fr}}@media print{.apptop,.noprint,.sb-scrim,.sidebar{display:none!important}.appmain,.content,.shell{display:block!important;margin:0!important;padding:0!important}.card{box-shadow:none!important;border:none!important;padding:0!important}}