:root{--accent:oklch(50% .15 262);--accent-strong:oklch(42% .16 262);--accent-soft:oklch(96% .03 262);--accent-soft-2:oklch(93% .05 262);--accent-ring:oklch(50% .15 262/.3);--on-accent:#fff;--bg:oklch(98.5% .003 250);--surface:#fff;--surface-2:oklch(97.5% .004 250);--surface-3:oklch(96.5% .005 250);--ink:oklch(24% .02 260);--ink-2:oklch(42% .018 260);--ink-3:oklch(58% .015 260);--ink-4:oklch(70% .012 260);--line:oklch(92% .005 260);--line-2:oklch(88% .006 260);--line-strong:oklch(83% .008 260);--st-new:oklch(62% .16 55);--st-new-bg:oklch(96% .04 70);--st-proc:oklch(55% .14 250);--st-proc-bg:oklch(96% .03 250);--st-done:oklch(55% .13 155);--st-done-bg:oklch(96% .04 160);--st-rej:oklch(55% .02 260);--st-rej-bg:oklch(95% .004 260);--danger:oklch(55% .2 25);--danger-bg:oklch(96% .04 25);--r-sm:7px;--r:10px;--r-lg:14px;--r-xl:20px;--row-h:56px;--pad:28px;--gap:20px;--shadow-sm:0 1px 2px oklch(30% .02 260/.06), 0 1px 3px oklch(30% .02 260/.05);--shadow-md:0 4px 12px oklch(30% .02 260/.07), 0 2px 4px oklch(30% .02 260/.05);--shadow-lg:0 18px 50px oklch(25% .03 260/.16), 0 6px 16px oklch(25% .03 260/.08);--sidebar-w:268px;--topbar-h:64px;--font:"Public Sans", ui-sans-serif, system-ui, -apple-system, sans-serif;--mono:"IBM Plex Mono", ui-monospace, "SF Mono", Menlo, monospace}[data-density=compact]{--row-h:46px;--pad:18px;--gap:14px}[data-density=comfy]{--row-h:66px;--pad:36px;--gap:26px}*{box-sizing:border-box;margin:0;padding:0}html,body{height:100%}body{font-family:var(--font);background:var(--bg);color:var(--ink);-webkit-font-smoothing:antialiased;text-rendering:optimizelegibility;font-size:14px;line-height:1.5}button{cursor:pointer;color:inherit;background:0 0;border:none;font-family:inherit}input,select,textarea{font-family:inherit;font-size:inherit;color:inherit}::selection{background:var(--accent-soft-2)}.app{grid-template-columns:var(--sidebar-w) 1fr;grid-template-rows:100vh;display:grid}.sidebar{transition:width .26s cubic-bezier(.4,0,.2,1)}.app[data-collapsed=true]{--sidebar-w:76px}.sidebar{background:var(--surface);border-right:1px solid var(--line);z-index:20;flex-direction:column;height:100vh;display:flex;position:relative;overflow:hidden}.sb-brand{min-height:var(--topbar-h);border-bottom:1px solid var(--line);flex-shrink:0;align-items:center;gap:12px;padding:12px 16px;display:flex}.sb-logo-slot{background:var(--surface-2);width:40px;height:40px;box-shadow:var(--shadow-sm);border-radius:10px;flex-shrink:0;display:block;overflow:hidden}.sb-logo{background:linear-gradient(150deg, var(--accent), var(--accent-strong));width:38px;height:38px;color:var(--on-accent);letter-spacing:-.5px;box-shadow:0 4px 10px var(--accent-ring);border-radius:11px;flex-shrink:0;place-items:center;font-size:17px;font-weight:800;display:grid}.sb-brand-text{flex-direction:column;flex:1;min-width:0;display:flex;overflow:hidden}.sb-brand-text b{letter-spacing:-.2px;font-size:12.5px;font-weight:800;line-height:1.2}.sb-brand-text span{color:var(--ink-3);white-space:nowrap;font-size:11px}.sb-user{border-radius:var(--r);background:var(--surface-2);border:1px solid var(--line);align-items:center;gap:11px;margin:14px 14px 6px;padding:9px 10px;display:flex}.sb-avatar{background:var(--accent-soft-2);width:34px;height:34px;color:var(--accent-strong);border-radius:9px;flex-shrink:0;place-items:center;font-size:14px;font-weight:700;display:grid}.sb-user-text{flex-direction:column;min-width:0;display:flex}.sb-user-text b{white-space:nowrap;text-overflow:ellipsis;font-size:13px;font-weight:700;overflow:hidden}.sb-user-text span{color:var(--ink-3);font-size:11px;font-family:var(--mono)}.sb-nav{flex:1;padding:8px 12px 18px;overflow:hidden auto}.sb-nav::-webkit-scrollbar{width:8px}.sb-nav::-webkit-scrollbar-thumb{background:var(--line-2);border:2px solid var(--surface);border-radius:4px}.sb-group-label{letter-spacing:.7px;text-transform:uppercase;color:var(--ink-4);white-space:nowrap;padding:16px 12px 7px;font-size:10.5px;font-weight:700}.sb-item{border-radius:var(--r-sm);width:100%;color:var(--ink-2);text-align:left;white-space:nowrap;align-items:center;gap:12px;margin-bottom:1px;padding:9px 12px;font-size:13.5px;font-weight:500;transition:background .14s,color .14s;display:flex;position:relative}.sb-item:hover{background:var(--surface-2);color:var(--ink)}.sb-item.active{background:var(--accent-soft);color:var(--accent-strong);font-weight:700}.sb-item.active:before{content:"";background:var(--accent);border-radius:0 3px 3px 0;width:3px;height:20px;position:absolute;top:50%;left:-12px;transform:translateY(-50%)}.sb-item .ico{flex-shrink:0;place-items:center;width:19px;height:19px;display:grid}.sb-item .ico svg{width:18px;height:18px}.sb-item .lbl{text-overflow:ellipsis;overflow:hidden}.sb-item .badge-n{font-size:11px;font-weight:700;font-family:var(--mono);background:var(--st-new-bg);color:var(--st-new);border-radius:20px;margin-left:auto;padding:1px 7px}.app[data-collapsed=true] .sb-brand-text,.app[data-collapsed=true] .sb-user-text,.app[data-collapsed=true] .sb-group-label .txt,.app[data-collapsed=true] .sb-item .lbl,.app[data-collapsed=true] .sb-item .badge-n{display:none}.app[data-collapsed=true] .sb-item{justify-content:center;padding:10px}.app[data-collapsed=true] .sb-item.active:before{left:-12px}.app[data-collapsed=true] .sb-user{justify-content:center;padding:8px}.app[data-collapsed=true] .sb-group-label{text-align:center;padding:14px 0 6px}.app[data-collapsed=true] .sb-group-label .txt{display:none}.app[data-collapsed=true] .sb-group-label:after{content:"•••";color:var(--line-strong)}.main{flex-direction:column;min-width:0;height:100vh;display:flex;overflow:hidden}.topbar{height:var(--topbar-h);background:color-mix(in oklch, var(--surface) 88%, transparent);-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);border-bottom:1px solid var(--line);z-index:10;flex-shrink:0;align-items:center;gap:16px;padding:0 24px;display:flex;position:relative}.tb-toggle{width:36px;height:36px;color:var(--ink-2);border-radius:9px;place-items:center;transition:background .14s;display:grid}.tb-toggle:hover{background:var(--surface-2)}.tb-crumbs{color:var(--ink-3);align-items:center;gap:8px;font-size:13px;display:flex}.tb-crumbs b{color:var(--ink);font-weight:700}.tb-crumbs .sep{color:var(--line-strong)}.tb-search{background:var(--surface-2);border:1px solid var(--line);border-radius:var(--r);width:300px;max-width:34vw;height:38px;color:var(--ink-3);align-items:center;gap:9px;margin-left:auto;padding:0 13px;transition:border-color .14s,box-shadow .14s,background .14s;display:flex}.tb-search:focus-within{border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-ring);background:var(--surface)}.tb-search input{color:var(--ink);background:0 0;border:none;outline:none;flex:1;font-size:13px}.tb-search kbd{font-family:var(--mono);color:var(--ink-4);background:var(--surface);border:1px solid var(--line-2);border-radius:5px;padding:1px 6px;font-size:10.5px}.tb-icon-btn{width:38px;height:38px;color:var(--ink-2);border:1px solid var(--line);background:var(--surface);border-radius:9px;place-items:center;transition:background .14s,border-color .14s;display:grid;position:relative}.tb-icon-btn:hover{background:var(--surface-2);border-color:var(--line-2)}.tb-icon-btn .dot{background:var(--st-new);border:1.5px solid var(--surface);border-radius:50%;width:7px;height:7px;position:absolute;top:8px;right:9px}.tb-user{border:1px solid var(--line);background:var(--surface);border-radius:22px;align-items:center;gap:9px;height:40px;padding:4px 11px 4px 4px;display:flex}.tb-user .av{background:linear-gradient(150deg, var(--accent), var(--accent-strong));width:30px;height:30px;color:var(--on-accent);border-radius:50%;place-items:center;font-size:13px;font-weight:700;display:grid}.tb-user b{font-size:12.5px;font-weight:600}.content{flex:1;overflow-y:auto}.content::-webkit-scrollbar{width:11px}.content::-webkit-scrollbar-thumb{background:var(--line-2);border:3px solid var(--bg);border-radius:6px}.page{max-width:1280px;padding:var(--pad) 32px 80px;margin:0 auto}.page-head{margin-bottom:var(--gap);flex-wrap:wrap;justify-content:space-between;align-items:flex-end;gap:24px;display:flex}.page-head h1{letter-spacing:-.6px;color:var(--ink);font-size:25px;font-weight:800}.page-head .sub{color:var(--ink-3);max-width:60ch;margin-top:4px;font-size:13.5px}.page-head .sub code{font-family:var(--mono);background:var(--surface-3);color:var(--ink-2);border-radius:5px;padding:1px 6px;font-size:12px}.btn{border-radius:var(--r);white-space:nowrap;border:1px solid #0000;align-items:center;gap:8px;height:40px;padding:0 16px;font-size:13.5px;font-weight:600;transition:background .14s,border-color .14s,box-shadow .14s,transform 60ms;display:inline-flex}.btn:active{transform:translateY(1px)}.btn svg{width:17px;height:17px}.btn-primary{background:var(--accent);color:var(--on-accent);box-shadow:0 2px 6px var(--accent-ring)}.btn-primary:hover{background:var(--accent-strong)}.btn-ghost{background:var(--surface);border-color:var(--line-2);color:var(--ink-2)}.btn-ghost:hover{background:var(--surface-2);border-color:var(--line-strong)}.btn-sm{height:34px;padding:0 12px;font-size:12.5px}.btn-danger-ghost{background:var(--danger-bg);color:var(--danger)}.btn-danger-ghost:hover{filter:brightness(.97)}.kpis{gap:var(--gap);margin-bottom:var(--gap);grid-template-columns:repeat(4,1fr);display:grid}.kpi{background:var(--surface);border:1px solid var(--line);border-radius:var(--r-lg);box-shadow:var(--shadow-sm);cursor:pointer;flex-direction:column;gap:10px;padding:18px 20px;transition:border-color .14s,box-shadow .14s,transform .12s;display:flex;position:relative;overflow:hidden}.kpi:hover{border-color:var(--line-strong);box-shadow:var(--shadow-md);transform:translateY(-2px)}.kpi.sel{border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-ring)}.kpi-top{justify-content:space-between;align-items:center;display:flex}.kpi-label{color:var(--ink-3);letter-spacing:.2px;font-size:12px;font-weight:600}.kpi-ico{border-radius:9px;place-items:center;width:32px;height:32px;display:grid}.kpi-ico svg{width:17px;height:17px}.kpi-val{letter-spacing:-1px;color:var(--ink);font-size:30px;font-weight:800;line-height:1}.kpi-val small{color:var(--ink-4);letter-spacing:0;font-size:13px;font-weight:600}.kpi-trend{color:var(--ink-3);align-items:center;gap:5px;font-size:11.5px;display:flex}.kpi-trend .up{color:var(--st-done);font-weight:700}.kpi-trend .dn{color:var(--danger);font-weight:700}.toolbar{flex-wrap:wrap;align-items:center;gap:12px;margin-bottom:14px;display:flex}.seg{background:var(--surface-2);border:1px solid var(--line);border-radius:var(--r);gap:2px;padding:3px;display:inline-flex}.seg button{color:var(--ink-3);white-space:nowrap;border-radius:7px;align-items:center;gap:7px;padding:6px 13px;font-size:12.5px;font-weight:600;transition:all .14s;display:inline-flex}.seg button .cnt{font-size:11px;font-family:var(--mono);opacity:.7}.seg button:hover{color:var(--ink)}.seg button.on{background:var(--surface);color:var(--ink);box-shadow:var(--shadow-sm)}.seg button.on .dotc{opacity:1}.seg button .dotc{opacity:.85;border-radius:50%;width:7px;height:7px}.toolbar .filter-search{background:var(--surface);border:1px solid var(--line);border-radius:var(--r);min-width:220px;height:38px;color:var(--ink-3);align-items:center;gap:8px;padding:0 12px;transition:border-color .14s,box-shadow .14s;display:flex}.toolbar .filter-search:focus-within{border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-ring)}.toolbar .filter-search input{color:var(--ink);background:0 0;border:none;outline:none;flex:1;font-size:13px}.toolbar .spacer{flex:1}.select-wrap{position:relative}.select-wrap select{appearance:none;background:var(--surface);border:1px solid var(--line);border-radius:var(--r);height:38px;color:var(--ink);cursor:pointer;padding:0 34px 0 12px;font-size:13px;font-weight:500}.select-wrap select:focus{border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-ring);outline:none}.select-wrap .chev{pointer-events:none;color:var(--ink-3);position:absolute;top:50%;right:11px;transform:translateY(-50%)}.tcard{background:var(--surface);border:1px solid var(--line);border-radius:var(--r-lg);box-shadow:var(--shadow-sm);overflow:hidden}.tcard-head{border-bottom:1px solid var(--line);justify-content:space-between;align-items:center;padding:14px 20px;display:flex}.tcard-head .ttl{align-items:center;gap:9px;font-size:14px;font-weight:700;display:flex}.tcard-head .count{font-family:var(--mono);color:var(--ink-3);background:var(--surface-3);border-radius:20px;padding:2px 8px;font-size:11.5px}.tcard-head .meta{color:var(--ink-3);font-size:12px}.tbl{border-collapse:collapse;width:100%}.tbl thead th{text-align:left;letter-spacing:.5px;text-transform:uppercase;color:var(--ink-4);border-bottom:1px solid var(--line);background:var(--surface-2);white-space:nowrap;padding:11px 16px;font-size:11px;font-weight:700;position:sticky;top:0}.tbl thead th.sortable{cursor:pointer;-webkit-user-select:none;user-select:none}.tbl thead th.sortable:hover{color:var(--ink-2)}.tbl tbody tr{cursor:pointer;transition:background .12s}.tbl tbody tr:hover,.tbl tbody tr.active-row{background:var(--accent-soft)}.tbl tbody td{height:var(--row-h);border-bottom:1px solid var(--line);vertical-align:middle;padding:0 16px;font-size:13px}.tbl tbody tr:last-child td{border-bottom:none}.tbl tbody tr.group-row{cursor:default;background:var(--surface-2)}.tbl tbody tr.group-row:hover{background:var(--surface-2)}.tbl tbody tr.group-row td{border-bottom:1px solid var(--line);height:auto;padding:9px 16px}.tbl tbody tr.group-row .g-code{font-family:var(--mono);color:var(--accent-strong);background:var(--accent-soft);border:1px solid var(--accent-soft-2);border-radius:7px;margin-right:11px;padding:2px 9px;font-size:11px;font-weight:700}.tbl tbody tr.group-row .g-name{letter-spacing:-.2px;color:var(--ink);font-size:13px;font-weight:800}.tbl tbody tr.group-row .g-count{font-family:var(--mono);color:var(--ink-3);margin-left:10px;font-size:11px}.cell-code{font-family:var(--mono);color:var(--accent-strong);font-size:12px;font-weight:600}.cell-asset{align-items:center;gap:11px;display:flex}.asset-ico{background:var(--surface-3);width:36px;height:36px;color:var(--ink-2);border-radius:9px;flex-shrink:0;place-items:center;display:grid}.asset-ico svg{width:18px;height:18px}.cell-asset .a-name{color:var(--ink);font-weight:600}.cell-asset .a-room{color:var(--ink-3);font-size:11.5px}.cell-reporter{align-items:center;gap:9px;display:flex}.cell-reporter .r-av{background:var(--surface-3);width:28px;height:28px;color:var(--ink-2);border-radius:50%;place-items:center;font-size:11px;font-weight:700;display:grid}.cell-reporter .r-name{font-weight:500}.cell-reporter .r-role{color:var(--ink-3);font-size:11px}.cell-date{color:var(--ink-2);white-space:nowrap}.cell-date small{color:var(--ink-4);font-size:11px;display:block}.badge{white-space:nowrap;border-radius:20px;align-items:center;gap:6px;padding:4px 10px;font-size:11.5px;font-weight:700;display:inline-flex}.badge .d{border-radius:50%;width:6px;height:6px}.badge.new{background:var(--st-new-bg);color:var(--st-new)}.badge.new .d{background:var(--st-new)}.badge.proc{background:var(--st-proc-bg);color:var(--st-proc)}.badge.proc .d{background:var(--st-proc)}.badge.done{background:var(--st-done-bg);color:var(--st-done)}.badge.done .d{background:var(--st-done)}.badge.closed{background:var(--st-rej-bg);color:var(--st-rej)}.badge.closed .d{background:var(--st-rej)}.tag-type{color:var(--ink-2);align-items:center;gap:6px;font-size:12px;font-weight:600;display:inline-flex}.tag-type svg{width:14px;height:14px}.tag-type.loss{color:var(--danger)}.sev{gap:3px;display:inline-flex}.sev i{background:var(--line-2);border-radius:2px;width:6px;height:16px;display:block}.sev[data-lvl="1"] i:nth-child(-n+1),.sev[data-lvl="2"] i:nth-child(-n+2),.sev[data-lvl="3"] i:nth-child(-n+3){background:var(--st-new)}.sev[data-lvl="3"] i:nth-child(-n+3){background:var(--danger)}.row-action{width:32px;height:32px;color:var(--ink-3);border-radius:8px;place-items:center;transition:background .14s,color .14s;display:grid}.row-action:hover{background:var(--surface-3);color:var(--ink)}.empty{text-align:center;padding:80px 20px}.empty .ico{background:var(--accent-soft);width:72px;height:72px;color:var(--accent);border-radius:18px;place-items:center;margin:0 auto 22px;display:grid}.empty .ico svg{width:34px;height:34px}.empty h3{margin-bottom:8px;font-size:18px;font-weight:800}.empty p{color:var(--ink-3);max-width:40ch;margin:0 auto 22px}.scrim{-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px);z-index:60;opacity:0;background:oklch(20% .02 260/.42);animation:.2s forwards fade;position:fixed;inset:0}@keyframes fade{to{opacity:1}}.drawer{background:var(--surface);z-index:70;width:480px;max-width:94vw;box-shadow:var(--shadow-lg);border-left:1px solid var(--line);flex-direction:column;animation:.3s cubic-bezier(.4,0,.2,1) forwards slidein;display:flex;position:fixed;top:0;bottom:0;right:0;transform:translate(100%)}@keyframes slidein{to{transform:translate(0)}}.drawer-head{border-bottom:1px solid var(--line);align-items:flex-start;gap:14px;padding:20px 24px;display:flex}.drawer-head .x{width:34px;height:34px;color:var(--ink-3);border-radius:9px;place-items:center;margin-left:auto;display:grid}.drawer-head .x:hover{background:var(--surface-2);color:var(--ink)}.drawer-body{flex:1;padding:22px 24px;overflow-y:auto}.drawer-body::-webkit-scrollbar{width:9px}.drawer-body::-webkit-scrollbar-thumb{background:var(--line-2);border:2px solid var(--surface);border-radius:5px}.drawer-foot{border-top:1px solid var(--line);background:var(--surface-2);gap:10px;padding:16px 24px;display:flex}.d-section{margin-bottom:24px}.d-section>.lbl{letter-spacing:.6px;text-transform:uppercase;color:var(--ink-4);margin-bottom:11px;font-size:11px;font-weight:700}.d-asset-card{background:var(--surface-2);border:1px solid var(--line);border-radius:var(--r);align-items:center;gap:14px;padding:14px;display:flex}.d-asset-card .big-ico{background:var(--surface);border:1px solid var(--line);width:52px;height:52px;color:var(--accent-strong);border-radius:12px;flex-shrink:0;place-items:center;display:grid}.d-asset-card .big-ico svg{width:26px;height:26px}.d-asset-card b{font-size:15px;font-weight:700;display:block}.d-asset-card span{color:var(--ink-3);font-size:12.5px}.d-asset-card .code{font-family:var(--mono);color:var(--accent-strong);font-size:11.5px}.d-grid{background:var(--line);border:1px solid var(--line);border-radius:var(--r);grid-template-columns:1fr 1fr;gap:1px;display:grid;overflow:hidden}.d-grid .item{background:var(--surface);padding:12px 14px}.d-grid .item .k{color:var(--ink-3);margin-bottom:4px;font-size:11px}.d-grid .item .v{color:var(--ink);font-size:13.5px;font-weight:600}.d-desc{color:var(--ink-2);background:var(--surface-2);border:1px solid var(--line);border-radius:var(--r);padding:14px 16px;font-size:13.5px;line-height:1.65}.timeline{padding-left:8px;position:relative}.tl-item{gap:13px;padding-bottom:18px;display:flex;position:relative}.tl-item:last-child{padding-bottom:0}.tl-item .tl-dot{border:2px solid var(--surface);width:12px;height:12px;box-shadow:0 0 0 2px var(--line-2);background:var(--ink-4);z-index:1;border-radius:50%;flex-shrink:0;margin-top:3px}.tl-item.cur .tl-dot{background:var(--accent);box-shadow:0 0 0 2px var(--accent-ring)}.tl-item:before{content:"";background:var(--line-2);width:2px;position:absolute;top:14px;bottom:-4px;left:5px}.tl-item:last-child:before{display:none}.tl-item .tl-body b{font-size:13px;font-weight:700;display:block}.tl-item .tl-body span{color:var(--ink-3);font-size:11.5px}.attach-row{flex-wrap:wrap;gap:10px;display:flex}.attach{border-radius:var(--r);border:1px solid var(--line);background:repeating-linear-gradient(45deg, var(--surface-2), var(--surface-2) 7px, var(--surface-3) 7px, var(--surface-3) 14px);place-items:center;width:84px;height:84px;display:grid;position:relative;overflow:hidden}.attach span{font-family:var(--mono);color:var(--ink-4);text-align:center;padding:4px;font-size:9px}.modal{z-index:70;background:var(--surface);border-radius:var(--r-xl);width:620px;max-width:94vw;max-height:90vh;box-shadow:var(--shadow-lg);opacity:0;flex-direction:column;animation:.24s cubic-bezier(.34,1.4,.5,1) forwards pop;display:flex;position:fixed;top:50%;left:50%;overflow:hidden;transform:translate(-50%,-48%)}@keyframes pop{to{opacity:1;transform:translate(-50%,-50%)}}.modal-head{border-bottom:1px solid var(--line);padding:22px 26px 18px}.modal-head h2{letter-spacing:-.4px;font-size:19px;font-weight:800}.modal-head p{color:var(--ink-3);margin-top:3px;font-size:13px}.modal-head .x{width:34px;height:34px;color:var(--ink-3);border-radius:9px;place-items:center;display:grid;position:absolute;top:18px;right:18px}.modal-head .x:hover{background:var(--surface-2);color:var(--ink)}.modal-body{flex:1;padding:22px 26px;overflow-y:auto}.modal-foot{border-top:1px solid var(--line);background:var(--surface-2);justify-content:flex-end;gap:11px;padding:16px 26px;display:flex}.field{margin-bottom:17px}.field>label{color:var(--ink-2);margin-bottom:7px;font-size:12.5px;font-weight:600;display:block}.field>label .req{color:var(--danger)}.field .hint{color:var(--ink-4);margin-top:5px;font-size:11.5px}.input,.textarea{background:var(--surface);border:1px solid var(--line-2);border-radius:var(--r);width:100%;color:var(--ink);padding:10px 13px;font-size:13.5px;transition:border-color .14s,box-shadow .14s}.input:focus,.textarea:focus{border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-ring);outline:none}.textarea{resize:vertical;min-height:92px;line-height:1.6}.field-row{grid-template-columns:1fr 1fr;gap:14px;display:grid}.choice-row{gap:10px;display:flex}.choice{border:1.5px solid var(--line-2);border-radius:var(--r);cursor:pointer;background:var(--surface);flex:1;align-items:center;gap:11px;padding:13px 14px;transition:all .14s;display:flex}.choice:hover{border-color:var(--line-strong)}.choice.on{border-color:var(--accent);background:var(--accent-soft)}.choice .ci{background:var(--surface-3);width:34px;height:34px;color:var(--ink-2);border-radius:9px;flex-shrink:0;place-items:center;display:grid}.choice.on .ci{background:var(--accent);color:var(--on-accent)}.choice b{font-size:13px;font-weight:700;display:block}.choice span{color:var(--ink-3);font-size:11px}.sev-pick{gap:9px;display:flex}.sev-pick button{border:1.5px solid var(--line-2);border-radius:var(--r);color:var(--ink-2);flex:1;padding:9px;font-size:12.5px;font-weight:600;transition:all .14s}.sev-pick button.on{color:var(--on-accent);border-color:#0000}.sev-pick button[data-l="1"].on{background:var(--st-proc)}.sev-pick button[data-l="2"].on{background:var(--st-new)}.sev-pick button[data-l="3"].on{background:var(--danger)}.dropzone{border:1.5px dashed var(--line-strong);border-radius:var(--r);text-align:center;color:var(--ink-3);cursor:pointer;padding:22px;font-size:13px;transition:all .14s}.dropzone:hover{border-color:var(--accent);background:var(--accent-soft);color:var(--accent-strong)}.dropzone svg{width:26px;height:26px;margin-bottom:8px}.toast-wrap{z-index:90;flex-direction:column;align-items:center;gap:10px;display:flex;position:fixed;bottom:24px;left:50%;transform:translate(-50%)}.toast{background:var(--ink);color:#fff;border-radius:var(--r);box-shadow:var(--shadow-lg);align-items:center;gap:12px;padding:13px 18px;font-size:13px;font-weight:500;animation:.3s cubic-bezier(.34,1.3,.5,1) toastin;display:flex}.toast .ti{background:var(--st-done);border-radius:50%;flex-shrink:0;place-items:center;width:22px;height:22px;display:grid}.toast .ti svg{width:14px;height:14px}@keyframes toastin{0%{opacity:0;transform:translateY(14px)}}.stub{text-align:center;place-items:center;padding:90px 20px;display:grid}.stub .ico{background:var(--accent-soft);width:64px;height:64px;color:var(--accent);border-radius:16px;place-items:center;margin:0 auto 18px;display:grid}.stub .ico svg{width:30px;height:30px}.stub h3{margin-bottom:7px;font-size:19px;font-weight:800}.stub p{color:var(--ink-3);max-width:42ch}.badge.tone-blue{color:oklch(50% .14 250);background:oklch(96% .03 250)}.badge.tone-blue .d{background:oklch(50% .14 250)}.badge.tone-green{color:oklch(50% .13 160);background:oklch(96% .04 160)}.badge.tone-green .d{background:oklch(50% .13 160)}.badge.tone-amber{color:oklch(55% .13 60);background:oklch(96% .05 75)}.badge.tone-amber .d{background:oklch(62% .15 60)}.badge.tone-red{color:oklch(53% .18 25);background:oklch(96% .04 25)}.badge.tone-red .d{background:oklch(55% .2 25)}.badge.tone-gray{color:oklch(48% .02 260);background:oklch(95% .004 260)}.badge.tone-gray .d{background:oklch(55% .02 260)}.badge.tone-violet{color:oklch(48% .16 295);background:oklch(96% .04 295)}.badge.tone-violet .d{background:oklch(48% .16 295)}.badge.tone-teal{color:oklch(48% .1 200);background:oklch(95% .04 195)}.badge.tone-teal .d{background:oklch(52% .1 200)}.cell-tag{color:var(--ink-2);background:var(--surface-3);border-radius:7px;align-items:center;padding:3px 9px;font-size:12px;font-weight:600;display:inline-flex}.cell-mono{font-family:var(--mono);color:var(--accent-strong);font-size:12px;font-weight:600}.cell-sub{line-height:1.25}.cell-sub b{color:var(--ink);font-weight:600;display:block}.cell-sub span{color:var(--ink-3);font-size:11.5px}.cell-num{font-variant-numeric:tabular-nums;font-weight:600}.actions{justify-content:flex-end;gap:4px;display:flex}.actions .row-action.danger:hover{background:var(--danger-bg);color:var(--danger)}.modal.modal-sm{width:420px}.confirm-body{text-align:center;padding:24px 26px}.confirm-body .ci{background:var(--danger-bg);width:56px;height:56px;color:var(--danger);border-radius:14px;place-items:center;margin:0 auto 16px;display:grid}.confirm-body .ci svg{width:27px;height:27px}.confirm-body h3{margin-bottom:7px;font-size:17px;font-weight:800}.confirm-body p{color:var(--ink-3);font-size:13px}.confirm-body p b{color:var(--ink)}.btn-danger{background:var(--danger);color:#fff;box-shadow:0 2px 6px oklch(55% .2 25/.3)}.btn-danger:hover{filter:brightness(1.05)}.dash-grid{gap:var(--gap);grid-template-columns:2fr 1fr;align-items:start;display:grid}.panel{background:var(--surface);border:1px solid var(--line);border-radius:var(--r-lg);box-shadow:var(--shadow-sm);overflow:hidden}.panel-head{border-bottom:1px solid var(--line);justify-content:space-between;align-items:center;padding:15px 20px;display:flex}.panel-head .ttl{align-items:center;gap:9px;font-size:14px;font-weight:700;display:flex}.panel-head a{color:var(--accent-strong);font-size:12.5px;font-weight:600}.feed{padding:6px 8px}.feed-item{border-radius:var(--r);gap:12px;padding:11px 12px;transition:background .12s;display:flex}.feed-item:hover{background:var(--surface-2)}.feed-item .fi{border-radius:9px;flex-shrink:0;place-items:center;width:34px;height:34px;display:grid}.feed-item .ft b{font-size:13px;font-weight:600}.feed-item .ft span{color:var(--ink-3);font-size:11.5px}.feed-item .fm{color:var(--ink-4);white-space:nowrap;margin-left:auto;font-size:11px}.mini-list{padding:6px 8px}.mini-row{border-radius:var(--r);align-items:center;gap:11px;padding:10px 12px;display:flex}.mini-row:hover{background:var(--surface-2)}.mini-row .mb{color:var(--ink-3);font-size:12px}.mini-row .mv{font-variant-numeric:tabular-nums;margin-left:auto;font-weight:700}.bar{background:var(--surface-3);border-radius:5px;flex:1;height:8px;overflow:hidden}.bar i{background:var(--accent);border-radius:5px;height:100%;display:block}.prof-card{max-width:720px}.prof-hero{border-bottom:1px solid var(--line);background:var(--surface-2);align-items:center;gap:18px;padding:24px;display:flex}.prof-hero .pa{background:linear-gradient(150deg, var(--accent), var(--accent-strong));color:#fff;border-radius:18px;place-items:center;width:72px;height:72px;font-size:28px;font-weight:800;display:grid}.prof-hero h2{font-size:20px;font-weight:800}.prof-hero p{color:var(--ink-3);margin-top:2px;font-size:13px}.prof-body{padding:24px}.readonly-note{color:var(--ink-4);align-items:center;gap:6px;font-size:12px;display:inline-flex}.hero{border-radius:var(--r-lg);border:1px solid var(--line);background:var(--surface);box-shadow:var(--shadow-sm);margin-bottom:var(--gap);grid-template-columns:1.6fr 1fr;gap:0;display:grid;overflow:hidden}.hero-text{padding:28px 30px}.hero .eyebrow{letter-spacing:1px;text-transform:uppercase;color:var(--accent-strong);align-items:center;gap:7px;margin-bottom:11px;font-size:11px;font-weight:700;display:inline-flex}.hero .eyebrow svg{width:14px;height:14px}.hero h2{letter-spacing:-.5px;color:var(--ink);margin-bottom:13px;font-size:23px;font-weight:800;line-height:1.2}.hero p{color:var(--ink-2);text-wrap:pretty;max-width:62ch;margin-bottom:11px;font-size:13.5px;line-height:1.7}.hero .chips{flex-wrap:wrap;gap:8px;margin-top:16px;display:flex}.hero .chip{color:var(--ink-2);background:var(--surface-2);border:1px solid var(--line);border-radius:20px;align-items:center;gap:7px;padding:6px 12px;font-size:12px;font-weight:600;display:inline-flex}.hero .chip svg{width:14px;height:14px;color:var(--accent);flex-shrink:0}.hero-media{background:var(--accent-soft);min-height:220px;position:relative}.hero-media image-slot{width:100%;height:100%;display:block}.room-grid{gap:var(--gap);grid-template-columns:repeat(auto-fill,minmax(280px,1fr));display:grid}.room-card{background:var(--surface);border:1px solid var(--line);border-radius:var(--r-lg);box-shadow:var(--shadow-sm);flex-direction:column;transition:border-color .14s,box-shadow .14s,transform .12s;display:flex;overflow:hidden}.room-card:hover{border-color:var(--line-strong);box-shadow:var(--shadow-md);transform:translateY(-2px)}.room-banner{background:linear-gradient(135deg, var(--accent-soft) 0%, var(--accent-soft-2) 100%);border-bottom:1px solid var(--line);align-items:flex-end;height:92px;padding:12px 16px;display:flex;position:relative}.room-banner .rtype{letter-spacing:.4px;text-transform:uppercase;color:var(--accent-strong);font-size:11px;font-weight:700;position:absolute;top:12px;left:16px}.room-banner .ricon{color:var(--accent);opacity:.55;position:absolute;top:10px;right:14px}.room-banner .ricon svg{width:30px;height:30px}.room-banner .rcode{font-family:var(--mono);color:var(--accent-strong);background:var(--surface);border:1px solid var(--line);border-radius:20px;padding:2px 9px;font-size:11.5px;font-weight:600}.room-body{flex:1;padding:15px 16px}.room-body h3{letter-spacing:-.3px;margin-bottom:5px;font-size:15.5px;font-weight:800}.room-meta{color:var(--ink-3);flex-wrap:wrap;align-items:center;gap:7px;font-size:12px;display:flex}.room-meta .dot{background:var(--line-strong);border-radius:50%;width:3px;height:3px}.room-stats{border-top:1px solid var(--line);gap:16px;margin-top:13px;padding-top:13px;display:flex}.room-stats .rs{flex-direction:column;gap:2px;display:flex}.room-stats .rs b{letter-spacing:-.5px;font-size:17px;font-weight:800;line-height:1}.room-stats .rs span{color:var(--ink-3);font-size:11px}.room-foot{border-top:1px solid var(--line);background:var(--surface-2);align-items:center;gap:10px;padding:12px 16px;display:flex}.room-foot .btn{flex:1;justify-content:center}.room-tarif{border-top:1px solid var(--line);letter-spacing:-.3px;color:var(--ink);white-space:nowrap;align-items:center;gap:6px;margin-top:13px;padding-top:13px;font-size:14px;font-weight:800;display:flex}.room-tarif svg{width:14px;height:14px;color:var(--accent);flex-shrink:0}.room-tarif span{color:var(--ink-3);letter-spacing:0;white-space:nowrap;font-size:12px;font-weight:500}.eq-summary{gap:10px;margin-bottom:18px;display:flex}.eq-summary .es{background:var(--surface-2);border:1px solid var(--line);border-radius:var(--r);text-align:center;flex:1;padding:12px 14px}.eq-summary .es b{letter-spacing:-.5px;font-size:20px;font-weight:800;display:block}.eq-summary .es span{color:var(--ink-3);font-size:11px}.eq-list{flex-direction:column;gap:9px;display:flex}.eq-item{border:1px solid var(--line);border-radius:var(--r);background:var(--surface);align-items:center;gap:12px;padding:11px 13px;transition:border-color .12s;display:flex}.eq-item:hover{border-color:var(--line-strong)}.eq-item .ei{background:var(--surface-3);width:38px;height:38px;color:var(--ink-2);border-radius:9px;flex-shrink:0;place-items:center;display:grid}.eq-item .ei svg{width:19px;height:19px}.eq-item .et{flex:1;min-width:0}.eq-item .et b{font-size:13.5px;font-weight:600;display:block}.eq-item .et span{font-family:var(--mono);color:var(--accent-strong);font-size:11px}.eq-item .eq-qty{font-variant-numeric:tabular-nums;color:var(--ink-2);background:var(--surface-3);white-space:nowrap;border-radius:20px;padding:3px 9px;font-size:12px;font-weight:700}.cond{white-space:nowrap;border-radius:20px;padding:3px 9px;font-size:11px;font-weight:700}.cond.baik{background:var(--st-done-bg);color:var(--st-done)}.cond.perlu{background:var(--st-new-bg);color:var(--st-new)}.cond.rusak{background:var(--danger-bg);color:var(--danger)}.room-alert{color:var(--danger);background:var(--surface);border:1px solid var(--danger);border-radius:20px;align-items:center;gap:5px;padding:2px 9px;font-size:11px;font-weight:700;display:inline-flex;position:absolute;top:10px;right:56px}.room-alert svg{width:12px;height:12px}.eq-item.flagged{border-color:color-mix(in oklch, var(--danger) 35%, var(--line));background:color-mix(in oklch, var(--danger-bg) 50%, var(--surface))}.eq-report-link{color:var(--danger);cursor:pointer;align-items:center;gap:5px;margin-top:5px;font-size:11px;font-weight:600;display:inline-flex}.eq-report-link svg{width:12px;height:12px}.eq-report-link:hover{text-decoration:underline}.link-note{background:var(--accent-soft);border:1px solid var(--accent-soft-2);border-radius:var(--r);color:var(--ink-2);align-items:flex-start;gap:10px;margin-bottom:16px;padding:12px 14px;font-size:12.5px;line-height:1.5;display:flex}.link-note svg{width:17px;height:17px;color:var(--accent-strong);flex-shrink:0;margin-top:1px}.ba-loan-pick{flex-direction:column;gap:8px;display:flex}.ba-loan{border:1.5px solid var(--line-2);border-radius:var(--r);cursor:pointer;background:var(--surface);align-items:center;gap:12px;padding:11px 13px;transition:all .14s;display:flex}.ba-loan:hover{border-color:var(--line-strong)}.ba-loan.on{border-color:var(--accent);background:var(--accent-soft)}.ba-loan .li{background:var(--surface-3);width:36px;height:36px;color:var(--ink-2);border-radius:9px;flex-shrink:0;place-items:center;display:grid}.ba-loan.on .li{background:var(--accent);color:var(--on-accent)}.ba-loan .lt{flex:1;min-width:0}.ba-loan .lt b{font-size:13.5px;font-weight:600;display:block}.ba-loan .lt span{color:var(--ink-3);font-size:11.5px}.ba-loan .lcode{font-family:var(--mono);color:var(--accent-strong);font-size:11px}.report-block{border:1.5px solid color-mix(in oklch, var(--danger) 40%, var(--line));border-radius:var(--r);background:color-mix(in oklch, var(--danger-bg) 45%, var(--surface));margin-top:4px;overflow:hidden}.report-block-head{align-items:center;gap:11px;padding:13px 15px;display:flex}.report-block-head .ri{background:var(--danger-bg);width:34px;height:34px;color:var(--danger);border-radius:9px;flex-shrink:0;place-items:center;display:grid}.report-block-head .rt{flex:1}.report-block-head .rt b{color:var(--danger);font-size:13.5px;font-weight:700;display:block}.report-block-head .rt span{color:var(--ink-3);font-size:11.5px}.report-block-body{padding:0 15px 15px}.switch{background:var(--line-strong);border-radius:20px;flex-shrink:0;width:42px;height:24px;transition:background .16s;position:relative}.switch.on{background:var(--danger)}.switch:after{content:"";width:20px;height:20px;box-shadow:var(--shadow-sm);background:#fff;border-radius:50%;transition:transform .16s;position:absolute;top:2px;left:2px}.switch.on:after{transform:translate(18px)}.cond-pick{flex-wrap:wrap;gap:8px;display:flex}.cond-pick button{border:1.5px solid var(--line-2);border-radius:var(--r);color:var(--ink-2);padding:8px 13px;font-size:12.5px;font-weight:600;transition:all .14s}.cond-pick button.on{color:#fff;border-color:#0000}.cond-pick button.on[data-c=Baik]{background:var(--st-done)}.cond-pick button.on[data-c=Perlu\ Perbaikan]{background:var(--st-new)}.cond-pick button.on[data-c=Rusak]{background:var(--danger)}.cond-pick button.on[data-c=Hilang]{background:oklch(45% .02 260)}.cond-pick button.on[data-c=Kotor]{background:oklch(60% .11 90)}.ba-asset-list{flex-direction:column;gap:8px;display:flex}.ba-asset{border:1px solid var(--line);border-radius:var(--r);background:var(--surface);flex-wrap:wrap;align-items:center;gap:12px;padding:11px 13px;display:flex}.ba-asset.issue{border-color:color-mix(in oklch, var(--danger) 38%, var(--line));background:color-mix(in oklch, var(--danger-bg) 40%, var(--surface))}.ba-asset .ai{background:var(--surface-3);width:36px;height:36px;color:var(--ink-2);border-radius:9px;flex-shrink:0;place-items:center;display:grid}.ba-asset .at{flex:1;min-width:160px}.ba-asset .at b{font-size:13.5px;font-weight:600;display:block}.ba-asset .at span{color:var(--ink-3);font-size:11.5px}.ba-asset .acode{font-family:var(--mono);color:var(--accent-strong)}.cond-pick.mini{gap:5px}.cond-pick.mini button{padding:5px 9px;font-size:11px}.doc-list{flex-direction:column;gap:8px;display:flex}.doc-row{border:1px solid var(--line);border-radius:var(--r);background:var(--surface);flex-wrap:wrap;align-items:center;gap:11px;padding:10px 13px;display:flex}.doc-row .di{background:var(--surface-3);width:34px;height:34px;color:var(--ink-2);border-radius:9px;flex-shrink:0;place-items:center;display:grid}.doc-row .dt{flex:1;min-width:140px}.doc-row .dt b{font-size:13px;font-weight:600;display:block}.doc-row .dt span{color:var(--ink-3);font-size:11px}.doc-chips{flex-wrap:wrap;align-items:center;gap:6px;display:flex}.doc-chip{color:var(--accent-strong);background:var(--accent-soft);border:1px solid var(--accent-soft-2);border-radius:20px;align-items:center;gap:7px;max-width:220px;padding:4px 6px 4px 11px;font-size:12px;font-weight:600;display:inline-flex}.doc-chip .fn{white-space:nowrap;text-overflow:ellipsis;overflow:hidden}.doc-chip button{width:18px;height:18px;color:var(--ink-3);border-radius:50%;flex-shrink:0;place-items:center;display:grid}.doc-chip button:hover{background:var(--surface);color:var(--danger)}.btn-upload{border-radius:var(--r-sm);height:32px;color:var(--accent-strong);background:var(--accent-soft);border:1px dashed var(--accent);align-items:center;gap:7px;padding:0 12px;font-size:12.5px;font-weight:600;transition:background .14s;display:inline-flex}.btn-upload:hover{background:var(--accent-soft-2)}.btn-upload svg{width:15px;height:15px}.ba-agree{border:1.5px solid var(--line-2);border-radius:var(--r);cursor:pointer;color:var(--ink-2);background:var(--surface);align-items:flex-start;gap:11px;padding:13px 15px;font-size:12.5px;line-height:1.5;transition:all .14s;display:flex}.ba-agree:hover{border-color:var(--line-strong)}.ba-agree.on{border-color:var(--accent);background:var(--accent-soft)}.ba-agree .ck{border:1.5px solid var(--line-strong);color:#fff;background:var(--surface);border-radius:6px;flex-shrink:0;place-items:center;width:20px;height:20px;margin-top:1px;transition:all .14s;display:grid}.ba-agree .ck.on{background:var(--accent);border-color:var(--accent)}.ba-group-list{gap:var(--gap);flex-direction:column;display:flex}.ba-group{background:var(--surface);border:1px solid var(--line);border-radius:var(--r-lg);box-shadow:var(--shadow-sm);overflow:hidden}.ba-group-head{border-bottom:1px solid var(--line);background:var(--surface-2);flex-wrap:wrap;align-items:center;gap:14px;padding:16px 20px;display:flex}.ba-gcode{font-family:var(--mono);color:var(--accent-strong);background:var(--accent-soft);border:1px solid var(--accent-soft-2);border-radius:8px;padding:4px 11px;font-size:12px;font-weight:700}.ba-gh-title{flex:1;min-width:180px}.ba-gh-title b{letter-spacing:-.3px;font-size:15px;font-weight:800;display:block}.ba-gh-title span{color:var(--ink-3);font-size:12px}.ba-gh-actions{align-items:center;gap:10px;display:flex}.ba-group-body{grid-template-columns:1fr 1fr;gap:0;display:grid}.ba-group-body .ba-col{padding:16px 20px}.ba-group-body .ba-col+.ba-col{border-left:1px solid var(--line)}.ba-col>.lbl{letter-spacing:.6px;text-transform:uppercase;color:var(--ink-4);align-items:center;gap:7px;margin-bottom:11px;font-size:11px;font-weight:700;display:flex}.ba-col>.lbl .n{font-family:var(--mono);color:var(--ink-3);background:var(--surface-3);border-radius:20px;padding:1px 7px;font-size:10.5px}.ba-mini{border:1px solid var(--line);border-radius:var(--r);align-items:center;gap:11px;margin-bottom:7px;padding:9px 11px;display:flex}.ba-mini:last-child{margin-bottom:0}.ba-mini .mi{background:var(--surface-3);width:32px;height:32px;color:var(--ink-2);border-radius:8px;flex-shrink:0;place-items:center;display:grid}.ba-mini .mt{flex:1;min-width:0}.ba-mini .mt b{font-size:13px;font-weight:600;display:block}.ba-mini .mt span{color:var(--ink-3);font-size:11px}.ba-mini .mcode{font-family:var(--mono);color:var(--accent-strong)}.eq-check-list{border:1px solid var(--line);border-radius:var(--r);overflow:hidden}.ecl-head{letter-spacing:.5px;text-transform:uppercase;color:var(--ink-4);background:var(--surface-2);border-bottom:1px solid var(--line);justify-content:space-between;align-items:center;padding:9px 13px;font-size:11px;font-weight:700;display:flex}.ecl-head span{font-family:var(--mono);color:var(--accent-strong);letter-spacing:0;text-transform:none;font-weight:600}.ecl-all{cursor:pointer;text-transform:none;letter-spacing:0;gap:11px}.ecl-all .ck{border:1.5px solid var(--line-strong);color:#fff;background:var(--surface);border-radius:6px;flex-shrink:0;place-items:center;width:19px;height:19px;transition:all .14s;display:grid}.ecl-all .ck.on{background:var(--accent);border-color:var(--accent)}.ecl-all .ecl-all-label{color:var(--ink);letter-spacing:.3px;text-transform:uppercase;font-size:12px;font-weight:700}.ecl-all .ecl-count{font-family:var(--mono);color:var(--accent-strong);margin-left:auto;font-weight:600}.ecl-item{cursor:pointer;border-bottom:1px solid var(--line);align-items:center;gap:11px;padding:9px 13px;transition:background .12s;display:flex}.ecl-item:last-child{border-bottom:none}.ecl-item:hover{background:var(--surface-2)}.ecl-item.on{background:var(--accent-soft)}.ecl-item .ck{border:1.5px solid var(--line-strong);color:#fff;background:var(--surface);border-radius:6px;flex-shrink:0;place-items:center;width:19px;height:19px;transition:all .14s;display:grid}.ecl-item .ck.on{background:var(--accent);border-color:var(--accent)}.ecl-item .ei2{background:var(--surface-3);width:32px;height:32px;color:var(--ink-2);border-radius:8px;flex-shrink:0;place-items:center;display:grid}.ecl-item .et2{flex:1;min-width:0}.ecl-item .et2 b{font-size:13px;font-weight:600;display:block}.ecl-item .et2 span{color:var(--ink-3);font-size:11px;font-family:var(--mono)}.pm-box{border:1px solid var(--line);border-radius:var(--r);background:var(--surface);overflow:hidden}.pm-box.empty{border-style:dashed}.pm-empty{color:var(--ink-3);text-align:center;padding:16px;font-size:13px}.pm-ro{border-bottom:1px solid var(--line);background:var(--surface-2);justify-content:space-between;align-items:center;gap:12px;padding:10px 14px;display:flex}.pm-ro:last-child{border-bottom:none}.pm-ro .pk{color:var(--ink-3);font-size:12px;font-weight:500}.pm-ro .pv{color:var(--ink);text-align:right;font-size:13px;font-weight:700}.pm-input{border-bottom:1px solid var(--line);padding:11px 14px}.pm-input:last-child{border-bottom:none}.pm-input label{color:var(--ink-2);margin-bottom:6px;font-size:11.5px;font-weight:600;display:block}.res-list{flex-direction:column;gap:8px;margin-bottom:4px;display:flex}.res-row{flex-wrap:wrap;align-items:center;gap:8px;display:flex}.res-total{color:var(--ink-3);text-align:right;padding-top:4px;font-size:12.5px}.res-total b{color:var(--ink);font-size:13.5px;font-weight:800}.vf-room{color:var(--accent-strong);text-transform:uppercase;letter-spacing:.4px;align-items:center;gap:6px;margin-bottom:6px;font-size:12px;font-weight:700;display:flex}.vf-room svg{width:13px;height:13px}.room-tarif-line{color:var(--ink-2);align-items:center;gap:6px;margin-bottom:9px;font-size:12.5px;display:flex}.room-tarif-line svg{width:13px;height:13px;color:var(--accent)}.room-tarif-line b{color:var(--ink);font-weight:800}.room-tarif-line span{color:var(--ink-3);font-size:11.5px}.ecl-foot{border-top:1px solid var(--line);background:var(--surface-2);color:var(--ink-3);text-align:right;padding:10px 13px;font-size:12.5px}.ecl-foot b{color:var(--ink);font-size:13.5px;font-weight:800}.ecl-foot .ecl-biaya{border-top:1px dashed var(--line-2);color:var(--accent-strong);margin-top:5px;padding-top:5px}.ecl-foot .ecl-hint{color:var(--ink-4);margin-top:5px;font-size:11.5px;font-style:italic}.surat-sheet{border:1px solid var(--line);border-radius:var(--r);color:#1a1a1a;background:#fff;padding:32px 36px;font-size:13px;line-height:1.6}.surat-kop{border-bottom:3px double #333;align-items:center;gap:14px;margin-bottom:16px;padding-bottom:14px;display:flex}.surat-logo{background:var(--accent);color:#fff;border-radius:10px;flex-shrink:0;place-items:center;width:48px;height:48px;font-size:18px;font-weight:800;display:grid}.surat-kop b{letter-spacing:.3px;font-size:16px;font-weight:800;display:block}.surat-kop span{color:#555;font-size:11.5px}.surat-meta{margin-bottom:16px}.surat-meta div{gap:4px;display:flex}.surat-meta span{width:56px;display:inline-block}.surat-to{margin-bottom:14px}.surat-to b{font-weight:700}.surat-p{text-align:justify;margin:12px 0}.surat-tbl{border-collapse:collapse;width:100%;margin:10px 0}.surat-tbl td{vertical-align:top;padding:3px 0}.surat-tbl td:first-child{color:#444;width:130px}.surat-tbl.bordered td,.surat-tbl.bordered th{border:1px solid #ccc;padding:7px 10px}.surat-tbl.bordered th{text-align:left;background:#f3f3f3;font-size:12px}.surat-tbl .surat-total td{background:#fafafa;font-weight:800}.surat-sign{width:240px;margin-top:22px;margin-left:auto}.surat-sign .surat-space{height:54px}.surat-cc{border-top:1px dashed #bbb;margin-top:18px;padding-top:12px;font-size:12px}.surat-cc ol{margin:6px 0 0 18px}.surat-cc li{margin-bottom:2px}@media print{body *{visibility:hidden!important}.surat-modal,.surat-modal *{visibility:visible!important}.surat-modal{width:100%!important;max-width:100%!important;box-shadow:none!important;border-radius:0!important;position:fixed!important;inset:0!important;transform:none!important}.surat-modal .modal-head,.surat-modal .modal-foot{display:none!important}.surat-modal .modal-body{padding:0!important;overflow:visible!important}.surat-sheet{border:none!important}.scrim{display:none!important}}.appr-list{gap:var(--gap);flex-direction:column;display:flex}.appr-card{background:var(--surface);border:1px solid var(--line);border-radius:var(--r-lg);box-shadow:var(--shadow-sm);overflow:hidden}.appr-head{border-bottom:1px solid var(--line);background:var(--surface-2);flex-wrap:wrap;align-items:center;gap:12px;padding:15px 20px;display:flex}.appr-ht{flex:1;min-width:200px}.appr-code{font-family:var(--mono);color:var(--accent-strong);font-size:11px;font-weight:700}.appr-ht b{letter-spacing:-.3px;margin:2px 0;font-size:15px;font-weight:800;display:block}.appr-ht span{color:var(--ink-3);font-size:12px}.appr-body{padding:16px 20px}.appr-info{flex-wrap:wrap;gap:26px;margin-bottom:18px;display:flex}.appr-info>div{flex-direction:column;gap:3px;display:flex}.appr-info .k{color:var(--ink-4);text-transform:uppercase;letter-spacing:.4px;font-size:11px;font-weight:600}.appr-info .v{color:var(--ink);font-size:13px;font-weight:600}.stepper{gap:0;display:flex}.step{flex:1;align-items:flex-start;gap:10px;padding-right:14px;display:flex;position:relative}.step:not(:last-child):after{content:"";background:var(--line-2);height:2px;position:absolute;top:26px;left:13px;right:14px}.step.done:not(:last-child):after{background:var(--st-done)}.step-dot{background:var(--surface-3);width:27px;height:27px;color:var(--ink-3);border:2px solid var(--line-2);z-index:1;border-radius:50%;flex-shrink:0;place-items:center;font-size:12px;font-weight:700;display:grid}.step.done .step-dot{background:var(--st-done);color:#fff;border-color:var(--st-done)}.step.cur .step-dot{background:var(--accent);color:#fff;border-color:var(--accent);box-shadow:0 0 0 4px var(--accent-ring)}.step.rej .step-dot{background:var(--danger);color:#fff;border-color:var(--danger)}.step-label b{font-size:11.5px;font-weight:700;display:block}.step-label span{color:var(--ink-3);font-size:11px;line-height:1.3;display:block}.appr-log{border-top:1px dashed var(--line-2);flex-direction:column;gap:6px;margin-top:16px;padding-top:12px;display:flex}.al-item{color:var(--ink-2);align-items:flex-start;gap:8px;font-size:12px;display:flex}.al-item.ok svg{color:var(--st-done);flex-shrink:0;margin-top:2px}.al-item.rej svg{color:var(--danger);flex-shrink:0;margin-top:2px}.appr-foot{border-top:1px solid var(--line);background:var(--surface-2);align-items:center;gap:10px;padding:13px 20px;display:flex}.appr-cur{color:var(--ink-3);flex:1;font-size:12.5px}.appr-cur b{color:var(--ink);font-weight:700}@media (width<=760px){.stepper{flex-direction:column;gap:14px}.step:not(:last-child):after{display:none}}.pb-list{flex-direction:column;gap:12px;display:flex}.pb-card{background:var(--surface);border:1px solid var(--line);border-radius:var(--r-lg);box-shadow:var(--shadow-sm);cursor:pointer;align-items:center;gap:16px;padding:15px 18px;transition:border-color .14s,box-shadow .14s,transform .1s;display:flex}.pb-card:hover{border-color:var(--line-strong);box-shadow:var(--shadow-md);transform:translateY(-1px)}.pb-card-main{flex:1;min-width:0}.pb-no{font-family:var(--mono);color:var(--accent-strong);font-size:11px;font-weight:700}.pb-card-main b{letter-spacing:-.2px;margin:2px 0 3px;font-size:14.5px;font-weight:800;display:block}.pb-meta{color:var(--ink-3);font-size:12px}.pb-card-stats{flex-shrink:0;align-items:center;gap:14px;display:flex}.pb-stat{color:var(--ink-3);align-items:center;gap:5px;font-size:12px;display:flex}.pb-stat .ok{color:var(--st-done);font-weight:700}.pb-stat .warn{color:var(--st-new);font-weight:700}.pb-stat .bad{color:var(--danger);font-weight:700}.pb-flag-pill{background:var(--st-new-bg);color:var(--st-new);border-radius:20px;padding:2px 8px;font-size:10.5px;font-weight:700}@media (width<=820px){.pb-card{flex-wrap:wrap}.pb-card-main{flex-basis:100%}}.pb-doc-grid{flex-direction:column;gap:6px;display:flex}.pb-doc{border-radius:var(--r-sm);border:1px solid var(--line);align-items:center;gap:8px;padding:8px 11px;font-size:12.5px;font-weight:600;display:flex}.pb-doc.ok{background:var(--st-done-bg);color:var(--st-done);border-color:#0000}.pb-doc.miss{background:var(--danger-bg);color:var(--danger);border-color:#0000}.pb-doc.extra{background:var(--surface-2);color:var(--ink-2)}.pb-issues{flex-direction:column;gap:8px;display:flex}.pb-issue{background:var(--surface-2);border:1px solid var(--line);border-radius:var(--r-sm);align-items:center;gap:11px;padding:9px 12px;display:flex}.pb-issue svg{color:var(--ink-3);flex-shrink:0}.pb-issue>div{flex:1;min-width:0}.pb-issue b{font-size:13px;font-weight:600;display:block}.pb-issue span{color:var(--ink-3);font-size:11px}.pb-report-note{margin-top:9px;font-size:12px}.pb-report-note .ok{color:var(--st-done);align-items:center;gap:5px;display:inline-flex}.pb-report-note .warn{color:var(--danger);align-items:center;gap:5px;font-weight:600;display:inline-flex}.pb-rep-list{flex-direction:column;gap:9px;margin-top:11px;display:flex}.pb-rep{border:1px solid var(--line);border-left:3px solid var(--danger);border-radius:var(--r-sm);background:var(--surface);cursor:pointer;padding:11px 13px;transition:background .12s,box-shadow .12s}.pb-rep:hover{background:var(--surface-2);box-shadow:0 2px 8px #0000000d}.pb-rep-head{flex-wrap:wrap;align-items:center;gap:8px;margin-bottom:8px;display:flex}.pb-rep-id{font-family:var(--mono);color:var(--accent-strong);font-size:11px;font-weight:700}.pb-rep-sev{border-radius:20px;padding:1px 7px;font-size:10.5px;font-weight:700}.pb-rep-sev.sev-hi{background:var(--danger-bg);color:var(--danger)}.pb-rep-sev.sev-mid{background:var(--st-new-bg);color:var(--st-new)}.pb-rep-sev.sev-lo{background:var(--surface-3);color:var(--ink-3)}.pb-rep-status{color:var(--ink-3);margin-left:auto;font-size:11px;font-weight:600}.pb-rep-status.st-new{color:var(--st-new)}.pb-rep-status.st-proc{color:var(--accent-strong)}.pb-rep-status.st-done{color:var(--st-done)}.pb-rep-status.st-closed{color:var(--ink-4)}.pb-rep-asset{color:var(--ink);align-items:center;gap:7px;font-size:13px;font-weight:700;display:flex}.pb-rep-asset svg{color:var(--ink-3);flex-shrink:0}.pb-rep-code{font-family:var(--mono);color:var(--ink-4);background:var(--surface-3);border-radius:5px;padding:1px 6px;font-size:10.5px;font-weight:600}.pb-rep-loc{color:var(--ink-3);align-items:center;gap:6px;margin-top:4px;font-size:11.5px;display:flex}.pb-rep-loc svg{flex-shrink:0}.pb-rep-desc{color:var(--ink-2);border-top:1px solid var(--line);margin-top:7px;padding-top:7px;font-size:12px;line-height:1.5}.pb-rep-open{color:var(--accent-strong);align-items:center;gap:3px;margin-top:8px;font-size:11px;font-weight:600;display:inline-flex}.pb-check-list{flex-direction:column;gap:7px;display:flex}.pb-check{border:1px solid var(--line);border-radius:var(--r-sm);cursor:pointer;align-items:center;gap:11px;padding:11px 13px;transition:background .12s,border-color .12s;display:flex}.pb-check:hover{background:var(--surface-2)}.pb-check.on{background:var(--accent-soft);border-color:var(--accent-soft-2)}.pb-check.flag{background:var(--st-new-bg);border-color:oklch(62% .16 55/.5)}.pb-check .ck{border:1.5px solid var(--line-strong);color:#fff;background:var(--surface);border-radius:6px;flex-shrink:0;place-items:center;width:19px;height:19px;transition:all .14s;display:grid}.pb-check .ck.on{background:var(--accent);border-color:var(--accent)}.pbc-text{flex:1;min-width:0}.pbc-text b{font-size:12.5px;font-weight:700;display:block}.pbc-text span{color:var(--ink-3);font-size:11.5px}.pbc-auto-flag{color:var(--st-new);flex-shrink:0}.pb-score{color:var(--ink-3);text-align:right;margin-top:10px;font-size:12.5px}.pb-score b{color:var(--ink);font-weight:800}.pb-stamp{color:var(--ink-2);background:var(--surface-2);border:1px solid var(--line);border-radius:var(--r-sm);align-items:flex-start;gap:9px;padding:11px 13px;font-size:12.5px;display:flex}.pb-stamp svg{color:var(--st-done);flex-shrink:0;margin-top:2px}@media (width<=720px){.ba-group-body{grid-template-columns:1fr}.ba-group-body .ba-col+.ba-col{border-left:none;border-top:1px solid var(--line)}}@media (width<=1100px){.kpis{grid-template-columns:repeat(2,1fr)}.dash-grid,.hero{grid-template-columns:1fr}.hero-media{order:-1;min-height:170px}}@media (width<=720px){.app{grid-template-columns:0 1fr}.kpis{grid-template-columns:1fr 1fr}}
