.splash-ov{position:fixed;top:0;right:0;bottom:0;left:0;z-index:9999;display:grid;place-items:center;background:radial-gradient(1200px 1200px at 50% 50%,#0a0a0a,#000 60%);opacity:0;transform:scale(.98) translateY(6px);transition:opacity .4s ease,transform .4s ease}.splash-ov.in{opacity:1;transform:scale(1) translateY(0)}.splash-ov.sweep .splash-logo{-webkit-mask-image:linear-gradient(110deg,rgba(0,0,0,.1) 30%,#000 50%,rgba(0,0,0,.1) 70%);mask-image:linear-gradient(110deg,#0000001a 30%,#000,#0000001a 70%);-webkit-mask-size:250% 100%;mask-size:250% 100%;-webkit-mask-position:120% 0%;mask-position:120% 0%;animation:logo-sweep .25s ease forwards}@keyframes logo-sweep{0%{-webkit-mask-position:-20% 0%;mask-position:-20% 0%}to{-webkit-mask-position:120% 0%;mask-position:120% 0%}}.splash-ov.out{opacity:0;transform:scale(.86) translateY(-8px);transition:opacity .7s ease,transform .7s cubic-bezier(.2,.8,.2,1)}.splash-logo-wrap{text-align:center;-webkit-user-select:none;user-select:none}.splash-logo{width:min(42vw,180px);height:auto;filter:drop-shadow(0 6px 24px rgba(0,0,0,.35));transition:filter .24s ease}.splash-sub{margin-top:10px;font-size:12px;letter-spacing:.06em;color:#bdbdbd}@media (prefers-reduced-motion: reduce){.splash-ov,.splash-ov.out{transition:none!important}.splash-ov.sweep .splash-logo{animation:none!important}}:root{--bg:#0f1115;--panel:#171a20;--txt:#e6e9ef;--muted:#8a93a6;--accent:#22c55e;--danger:#ef4444;--warn:#ffb020;--ring:#2a3140;--br:14px}html,body{background:var(--bg);color:var(--txt)}.container{max-width:960px;margin:0 auto;padding:12px 14px}.navbar{display:flex;flex-wrap:wrap;gap:10px;padding:10px 14px;border-bottom:1px solid #1f2430}.card{background:var(--panel);border-radius:var(--br);padding:12px;box-shadow:0 2px 10px #00000040}.grid-tiles{display:grid;gap:12px;grid-template-columns:repeat(auto-fill,minmax(160px,1fr))}.rings{display:grid;gap:12px;grid-template-columns:repeat(auto-fit,minmax(220px,1fr))}.sub{color:var(--muted);font-size:.85rem}:root{color-scheme:dark;--font: "Inter", system-ui, -apple-system, sans-serif;--mono: "JetBrains Mono", "Fira Code", ui-monospace, monospace;--bg: #080a0f;--surface: #0e1016;--lift: #13161e;--hover: #1a1d28;--border: rgba(255,255,255,.06);--border2: rgba(255,255,255,.1);--divider: rgba(255,255,255,.04);--text: #e8eaf0;--sub: #5a6070;--muted: #8b97b0;--dim: #343844;--indigo: #6366f1;--indigo-lt: #818cf8;--indigo-bg: rgba(99,102,241,.1);--indigo-bd: rgba(99,102,241,.25);--green: #34d399;--green-bg: rgba(52,211,153,.1);--green-bd: rgba(52,211,153,.22);--red: #fb7185;--red-bg: rgba(251,113,133,.1);--red-bd: rgba(251,113,133,.22);--amber: #fbbf24;--amber-bg: rgba(251,191,36,.1);--amber-bd: rgba(251,191,36,.22);--blue: #60a5fa;--blue-bg: rgba(96,165,250,.1);--blue-bd: rgba(96,165,250,.22);--teal: #2dd4bf;--teal-bg: rgba(45,212,191,.1);--teal-bd: rgba(45,212,191,.22);--purple: #a78bfa;--purple-bg: rgba(167,139,250,.1);--purple-bd: rgba(167,139,250,.22);--r: 20px;--r-md: 14px;--r-sm: 10px;--r-xs: 8px;--r-full: 999px;--shadow-sm: 0 2px 8px rgba(0,0,0,.4);--shadow: 0 6px 20px rgba(0,0,0,.5);--shadow-lg: 0 16px 48px rgba(0,0,0,.6);font-family:var(--font);font-size:14px;line-height:1.5;font-weight:400;color:var(--text);background:var(--bg);font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}*,*:before,*:after{box-sizing:border-box}html,body,#root{overflow-x:hidden;width:100%}body{margin:0;min-height:100vh;background:var(--bg);color:var(--text);-webkit-tap-highlight-color:transparent}button{font-family:inherit;cursor:pointer;-webkit-tap-highlight-color:transparent}button:focus-visible{outline:2px solid var(--indigo);outline-offset:2px}a{text-decoration:none;color:inherit}input,select,textarea{font-family:inherit}img,svg{max-width:100%}.page-tenants,.page-dashboard,.page-docs,.ap-page,.m-page,.ut2-page,.arsip-page,.ez-wrap,.ip-wrap,.k-main,.k-container{max-width:480px;margin:0 auto;overflow-x:hidden}.page-tenants,.ap-page,.arsip-page,.page-docs{min-height:100vh;padding:0 16px calc(88px + env(safe-area-inset-bottom));background:var(--bg);color:var(--text)}.page-header,.kpHeader,.dash-hdr,.m-header,.ez-header,.ap-header,.docs-hdr{position:sticky;top:0;z-index:40;padding:16px 0 12px;background:linear-gradient(var(--bg) 75%,transparent);backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px)}.page-header,.dash-hdr,.kpHeaderTop,.m-header__wrap,.ap-header{display:flex;align-items:center;justify-content:space-between;gap:12px}.page-eyebrow,.m-section-kicker,.ap-kicker,.ip-eyebrow,.ez-eyebrow,.ut2-eyebrow{font-size:10px;font-weight:700;letter-spacing:.12em;text-transform:uppercase;color:var(--indigo-lt);margin-bottom:2px}.page-title,.kpTitle,.hdr-title,.m-header__title,.ap-title,.ip-title,.ut2-title{margin:0;font-size:19px;font-weight:900;letter-spacing:-.04em;color:var(--text);line-height:1.1}.page-sub,.hdr-sub,.m-header__sub,.ap-sub,.ip-eyebrow+.ip-title,.ut2-sub{font-size:11px;color:var(--sub);margin-top:2px}.hidden{display:none!important}.row{display:flex;align-items:center}.col{display:flex;flex-direction:column}.muted{color:var(--muted)}.small{font-size:12px}.tiny{font-size:11px}.mono{font-family:var(--mono)}.fullBtn{grid-column:1 / -1}.centerPad{padding:12px 0;text-align:center}.errorText{color:var(--red);font-size:12px;font-weight:500}.inline{display:inline}.card{border-radius:var(--r);border:1px solid var(--border);background:var(--surface);padding:14px}.card.lift{background:var(--lift)}.card.inset{background:var(--bg)}.card.accent{border-color:var(--indigo-bd);background:var(--indigo-bg)}.card.green{border-color:var(--green-bd);background:var(--green-bg)}.card.red{border-color:var(--red-bd);background:var(--red-bg)}.card.amber{border-color:var(--amber-bd);background:var(--amber-bg)}.card-divider{height:1px;background:var(--border);margin:12px 0}.btn{display:inline-flex;align-items:center;justify-content:center;gap:7px;min-height:40px;padding:0 14px;border-radius:var(--r-sm);border:1px solid var(--border);background:var(--lift);color:var(--muted);font-size:13px;font-weight:700;font-family:inherit;transition:all .14s ease;white-space:nowrap}.btn:hover{border-color:var(--border2);color:var(--text)}.btn:active{transform:scale(.97)}.btn:disabled{opacity:.45;cursor:not-allowed}.btn.primary{background:var(--indigo);border-color:var(--indigo);color:#fff;box-shadow:0 6px 18px #6366f14d}.btn.primary:hover{background:#5558e8}.btn.ghost{background:transparent;border-color:var(--border);color:var(--muted)}.btn.ghost:hover{background:var(--lift);color:var(--text)}.btn.danger{background:var(--red-bg);border-color:var(--red-bd);color:var(--red)}.btn.success{background:var(--green-bg);border-color:var(--green-bd);color:var(--green)}.btn.warn{background:var(--amber-bg);border-color:var(--amber-bd);color:var(--amber)}.btn.full{width:100%;min-height:44px;border-radius:var(--r-md);font-weight:700}.btn.sml{min-height:32px;padding:0 10px;font-size:12px}.btn.lg{min-height:50px;padding:0 20px;font-size:15px;border-radius:var(--r-md)}.input,.select{width:100%;min-height:44px;padding:0 13px;border-radius:var(--r-sm);border:1px solid var(--border2);background:var(--lift);color:var(--text);font-size:14px;font-family:inherit;outline:none;transition:border-color .15s,box-shadow .15s}.input:focus,.select:focus{border-color:var(--indigo-bd);box-shadow:0 0 0 3px var(--indigo-bg)}.input::placeholder{color:var(--dim)}textarea.input{min-height:88px;padding:11px 13px;resize:vertical;line-height:1.5}.label{display:flex;flex-direction:column;gap:5px;font-size:12px;font-weight:600;color:var(--sub)}.badge{display:inline-flex;align-items:center;gap:4px;padding:3px 9px;border-radius:var(--r-full);font-size:10.5px;font-weight:700;border:1px solid transparent}.badge.ok,.badge.lunas,.badge.paid{background:var(--green-bg);border-color:var(--green-bd);color:var(--green)}.badge.warn,.badge.belum,.badge.unpaid{background:var(--amber-bg);border-color:var(--amber-bd);color:var(--amber)}.badge.danger,.badge.overdue{background:var(--red-bg);border-color:var(--red-bd);color:var(--red)}.badge.info,.badge.accent{background:var(--indigo-bg);border-color:var(--indigo-bd);color:var(--indigo-lt)}.badge.neutral{background:var(--lift);border-color:var(--border);color:var(--muted)}.badge.payType.sewa{background:var(--indigo-bg);border-color:var(--indigo-bd);color:var(--indigo-lt)}.badge.payType.lain{background:var(--green-bg);border-color:var(--green-bd);color:var(--green)}.badge.payType.bayar{background:var(--lift);border-color:var(--border);color:var(--muted)}.badge.payStatus.lunas{background:var(--green-bg);border-color:var(--green-bd);color:var(--green)}.badge.payStatus.cicil{background:var(--amber-bg);border-color:var(--amber-bd);color:var(--amber)}.badge.logType{background:var(--indigo-bg);border-color:var(--indigo-bd);color:var(--indigo-lt)}.badge.logType.edit{background:var(--blue-bg);border-color:var(--blue-bd);color:var(--blue)}.badge.logType.rem{background:var(--amber-bg);border-color:var(--amber-bd);color:var(--amber)}.badge.logType.del{background:var(--red-bg);border-color:var(--red-bd);color:var(--red)}.badge.payPack.bulanan{background:var(--indigo-bg);border-color:var(--indigo-bd);color:var(--indigo-lt)}.badge.payPack.mingguan{background:var(--blue-bg);border-color:var(--blue-bd);color:var(--blue)}.badge.payPack.harian{background:var(--lift);border-color:var(--border);color:var(--muted)}.segmented{display:flex;gap:3px;padding:3px;border-radius:var(--r-full);border:1px solid var(--border);background:var(--surface)}.seg-btn{flex:1;min-height:34px;padding:0 14px;border:none;border-radius:var(--r-full);background:transparent;color:var(--sub);font-size:13px;font-weight:600;font-family:inherit;transition:all .15s}.seg-btn.active{background:var(--indigo);color:#fff;box-shadow:0 4px 12px #6366f140}.seg-btn:hover:not(.active){color:var(--text)}.icon-btn{width:38px;height:38px;display:grid;place-items:center;border-radius:var(--r-sm);border:1px solid var(--border);background:var(--surface);color:var(--muted);transition:all .14s}.icon-btn:hover{border-color:var(--border2);color:var(--text);background:var(--lift)}.icon-btn:active{transform:scale(.96)}.icon-btn.has-badge{position:relative}.icon-btn-badge{position:absolute;top:-4px;right:-4px;min-width:18px;height:18px;padding:0 5px;display:inline-flex;align-items:center;justify-content:center;border-radius:var(--r-full);border:2px solid var(--bg);background:var(--red);color:#fff;font-size:9px;font-weight:700}.sk-line{border-radius:var(--r-full);background:linear-gradient(90deg,var(--surface),var(--lift),var(--surface));background-size:200% 100%;animation:sk-shimmer 1.3s linear infinite}.sk-btn{border-radius:var(--r-sm);background:linear-gradient(90deg,var(--surface),var(--lift),var(--surface));background-size:200% 100%;animation:sk-shimmer 1.3s linear infinite}.sk-card{border-radius:var(--r);border:1px solid var(--border);background:var(--surface);padding:14px;display:flex;flex-direction:column;gap:10px}@keyframes sk-shimmer{0%{background-position:200% 0}to{background-position:-200% 0}}.sk-line.half{width:55%;height:14px}.sk-line.sm{width:30%;height:12px}.sk-line.lg{width:75%;height:14px}.empty-state{display:flex;flex-direction:column;align-items:center;text-align:center;gap:10px;padding:32px 20px;border-radius:var(--r);border:1px dashed var(--border2)}.empty-icon{width:48px;height:48px;border-radius:var(--r-md);display:grid;place-items:center;font-size:22px;background:var(--lift)}.empty-title{font-size:14px;font-weight:800;color:var(--text)}.empty-text{font-size:13px;color:var(--sub);line-height:1.5;max-width:30ch}.toast{position:fixed;left:50%;bottom:calc(80px + env(safe-area-inset-bottom));transform:translate(-50%);z-index:9999;width:min(calc(100vw - 32px),360px);display:flex;align-items:center;gap:10px;padding:12px 14px;border-radius:var(--r-md);border:1px solid var(--border2);background:#0e1016f7;color:var(--text);font-size:13px;font-weight:700;box-shadow:var(--shadow-lg);-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);animation:toast-in .18s ease-out}.toast.success{border-color:var(--green-bd);color:var(--green)}.toast.error{border-color:var(--red-bd);color:var(--red)}@keyframes toast-in{0%{opacity:0;transform:translate(-50%) translateY(8px)}to{opacity:1;transform:translate(-50%) translateY(0)}}.em-floating-success,.income-floating-success,.ed-floating-toast,.id-floating-toast{position:fixed;left:50%;bottom:calc(80px + env(safe-area-inset-bottom));transform:translate(-50%);z-index:9999;width:min(calc(100vw - 32px),360px);display:flex;align-items:center;gap:10px;padding:12px 14px;border-radius:var(--r-md);border:1px solid var(--border2);background:#0e1016f7;color:var(--text);font-size:13px;font-weight:700;box-shadow:var(--shadow-lg);-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);animation:toast-in .18s ease-out}.em-floating-success-icon,.income-floating-success-icon,.ed-floating-toast-icon,.id-floating-toast-icon{width:22px;height:22px;flex:0 0 auto;display:grid;place-items:center;border-radius:var(--r-full);background:currentColor}.kpStats{display:grid;grid-template-columns:repeat(3,1fr);gap:8px;margin:12px 0 0}.kpStat{display:flex;align-items:center;gap:8px;padding:11px 10px;border-radius:var(--r-md);border:1px solid var(--border);background:var(--surface)}.kpStatValue{font-size:18px;font-weight:900;color:var(--text);letter-spacing:-.03em;line-height:1}.kpStatLabel{margin-top:2px;font-size:10px;font-weight:600;color:var(--sub);text-transform:uppercase;letter-spacing:.05em}.kpStat.ok{border-color:var(--green-bd)}.kpStat.ok .kpStatValue{color:var(--green)}.kpStat.bad{border-color:var(--red-bd)}.kpStat.bad .kpStatValue{color:var(--red)}.kpStat.warn{border-color:var(--amber-bd)}.kpStat.warn .kpStatValue{color:var(--amber)}.kpFloor{display:flex;gap:3px;margin:12px 0 0;padding:3px;border-radius:var(--r-full);border:1px solid var(--border);background:var(--surface)}.kpFloorBtn{flex:1;min-height:36px;border:none;border-radius:var(--r-full);background:transparent;color:var(--sub);font-weight:700;font-size:13px;font-family:inherit;transition:all .15s}.kpFloorBtn:hover{color:var(--text)}.kpFloorBtn.active{background:var(--indigo);color:#fff;box-shadow:0 4px 12px #6366f140}.roomSection{padding-top:12px}.kpList{display:flex;flex-direction:column;gap:10px}.kpRow{position:relative;width:100%;display:flex;flex-direction:column;gap:12px;padding:14px;border-radius:var(--r);border:1px solid var(--border);background:var(--surface);transition:border-color .2s,transform .14s}.kpRow:not(.empty){cursor:pointer}.kpRow:not(.empty):active{transform:scale(.99)}.kpRow.paid,.kpRow.lunas{border-color:var(--green-bd)}.kpRow.unpaid,.kpRow.belum{border-color:var(--amber-bd)}.kpRow.overdue{border-color:var(--red-bd)}.kpRow.near,.kpRow.dueToday{border-color:#fb923c4d}.kpRow.empty{border-style:dashed;opacity:.6}.kpLeft{display:flex;flex-direction:column;gap:10px;min-width:0;width:100%}.kpRoomWrap{display:flex;align-items:center;justify-content:space-between;gap:8px}.kpRoom{font-size:20px;font-weight:900;letter-spacing:-.03em;color:var(--text);line-height:1}.kpRoomHash{font-size:15px;font-weight:800;color:var(--sub)}.kpTenant{min-width:0;width:100%}.kpName{font-size:16px;font-weight:800;color:var(--text);letter-spacing:-.02em}.kpMetaLine{display:flex;align-items:center;gap:6px;flex-wrap:wrap;margin-top:4px;color:var(--sub);font-size:12px}.kpPhone{font-family:var(--mono);font-size:11px}.kpDot{opacity:.3}.kpDuration{color:var(--indigo-lt);font-weight:700}.kpEmptyText{font-size:14px;font-weight:700;color:var(--sub)}.kpEmptySub{margin-top:3px;color:var(--dim);font-size:12px}.kpRemainInline{display:inline-flex;align-items:center;gap:5px;margin-top:8px;padding:4px 10px;border-radius:var(--r-full);font-size:12px;font-weight:700;width:fit-content;background:var(--lift);border:1px solid var(--border);color:var(--text)}.kpRemainInline.overdue{color:var(--red);background:var(--red-bg);border-color:var(--red-bd)}.kpRemainInline.near,.kpRemainInline.dueToday{color:var(--amber);background:var(--amber-bg);border-color:var(--amber-bd)}.kpRemainInline.ok,.kpRemainInline.paid{color:var(--green);background:var(--green-bg);border-color:var(--green-bd)}.kpBadge{padding:5px 11px;border-radius:var(--r-full);font-weight:700;font-size:11px;border:1px solid var(--border);background:var(--lift);color:var(--muted);white-space:nowrap}.kpBadge.paid,.kpBadge.lunas{border-color:var(--green-bd);background:var(--green-bg);color:var(--green)}.kpBadge.unpaid,.kpBadge.belum{border-color:var(--amber-bd);background:var(--amber-bg);color:var(--amber)}.kpBadge.overdue{border-color:var(--red-bd);background:var(--red-bg);color:var(--red)}.kpBadge.near,.kpBadge.dueToday{border-color:#fb923c4d;background:#fb923c14;color:#fb923c}.kpBadge.empty{border-color:var(--border);background:transparent;color:var(--sub)}.kpActionBar{display:grid;grid-template-columns:38px 1fr 1fr;gap:8px}.kpActionBar.compactActions{grid-template-columns:1fr 1fr}.kpIconBtn,.kpGhostBtn,.kpPrimaryBtn{min-height:42px;border-radius:var(--r-sm);border:1px solid var(--border);font-weight:700;font-size:13px;font-family:inherit;display:inline-flex;align-items:center;justify-content:center;gap:6px;transition:all .14s}.kpIconBtn{background:var(--lift);color:var(--amber);border-color:var(--amber-bd)}.kpGhostBtn{background:var(--lift);color:var(--muted)}.kpGhostBtn:hover{color:var(--text);border-color:var(--border2)}.kpPrimaryBtn{background:var(--indigo);border-color:var(--indigo);color:#fff;box-shadow:0 4px 14px #6366f140}.kpIconBtn:active,.kpGhostBtn:active,.kpPrimaryBtn:active{transform:scale(.97)}.adminMenuWrap{position:relative}.adminMenuCard{position:absolute;right:0;top:46px;z-index:50;min-width:200px;padding:6px;border:1px solid var(--border2);border-radius:var(--r);background:var(--surface);box-shadow:var(--shadow-lg)}.adminMenuItem{width:100%;text-align:left;padding:10px 12px;border:none;border-radius:var(--r-sm);background:transparent;color:var(--text);font-size:13px;font-weight:600;font-family:inherit;transition:background .12s}.adminMenuItem:hover{background:var(--lift)}.tenantFabAdd{position:fixed;right:16px;bottom:calc(16px + env(safe-area-inset-bottom));z-index:55;display:flex;align-items:center;gap:8px;border:none;border-radius:var(--r-full);padding:13px 18px;background:var(--indigo);color:#fff;font-weight:800;font-family:inherit;box-shadow:0 8px 28px #6366f166;transition:transform .14s,box-shadow .14s}.tenantFabAdd:active{transform:scale(.97)}.tenantFabPlus{font-size:18px;line-height:1}.tenantFabText{font-size:13px}.roomPlusBtn{width:34px;height:34px;display:grid;place-items:center;border-radius:var(--r-full);border:1px solid var(--indigo-bd);background:var(--indigo-bg);color:var(--indigo-lt);font-size:18px;font-weight:800;transition:all .14s}.roomPlusBtn:hover{border-color:var(--indigo);color:#fff;background:var(--indigo)}.roomPlusBtn:active{transform:scale(.96)}.roomPlusBtn.inline{width:42px;height:42px;border-radius:var(--r-sm)}.shortcutRow{display:grid;grid-template-columns:1fr 1fr;gap:8px;margin:8px 0}.shortcutCol{padding:8px;border:1px solid var(--border);border-radius:var(--r-sm);background:var(--surface)}.shortcutTitle{font-weight:700;color:var(--text);font-size:12px;margin-bottom:6px}.roomStatusBar{display:flex;gap:6px;overflow-x:auto;padding:4px;border:1px solid var(--border);border-radius:var(--r-sm);background:var(--surface)}.roomStatusBtn{min-width:42px;height:42px;flex:0 0 auto;border:1px solid transparent;border-radius:var(--r-sm);font-size:14px;font-weight:900;cursor:pointer;transition:all .14s}.roomStatusBtn.occupied{background:var(--green-bg);border-color:var(--green-bd);color:var(--green)}.roomStatusBtn.empty{background:var(--red-bg);border-color:var(--red-bd);color:var(--red)}.roomStatusBtn.all{background:transparent;border-color:var(--border);color:var(--sub)}.roomStatusBtn.active{box-shadow:0 0 0 2px var(--indigo)}.skeletonList{display:flex;flex-direction:column;gap:10px}.skeletonRow{min-height:110px;pointer-events:none}.skLine{border-radius:var(--r-full);background:linear-gradient(90deg,var(--surface),var(--lift),var(--surface));background-size:200% 100%;animation:sk-shimmer 1.3s linear infinite}.skRoom{width:70px;height:18px}.skName{width:50%;height:16px}.skMeta{width:35%;height:13px}.infoGrid{display:grid;grid-template-columns:1fr 1fr;gap:8px}.infoCell{padding:12px;border:1px solid var(--border);border-radius:var(--r-sm);background:var(--bg)}.profileGrid{display:grid;gap:6px}.actionGrid{display:grid;grid-template-columns:1fr 1fr;gap:8px;align-items:center;margin-top:2px}.payPack{display:inline-flex;align-items:center;gap:5px;padding:3px 9px;border-radius:var(--r-full);font-size:11px;font-weight:700;border:1px solid transparent}.payPack.bulanan{background:var(--indigo-bg);color:var(--indigo-lt);border-color:var(--indigo-bd)}.payPack.mingguan{background:var(--blue-bg);color:var(--blue);border-color:var(--blue-bd)}.payPack.harian{background:var(--lift);color:var(--muted);border-color:var(--border)}.histTabs{display:flex;gap:3px;padding:3px;border-bottom:1px solid var(--border);margin-bottom:10px}.histTabBtn{flex:1;padding:8px;border:none;border-radius:var(--r-sm);background:transparent;color:var(--sub);font-size:13px;font-weight:600;font-family:inherit;cursor:pointer;transition:all .14s}.histTabBtn.active{background:var(--lift);color:var(--text)}.histMonthTitle{position:sticky;top:0;z-index:3;display:flex;justify-content:space-between;align-items:center;padding:6px 8px;color:var(--sub);font-size:11px;font-weight:700;letter-spacing:.06em;text-transform:uppercase}.histPayItem{display:flex;gap:10px}.histPayRail{width:16px;flex-shrink:0;display:flex;flex-direction:column;align-items:center;padding-top:14px}.railDot{width:7px;height:7px;border-radius:50%;background:var(--border2);flex-shrink:0}.railDot.sewa{background:var(--indigo)}.railDot.lain{background:var(--green)}.railLine{flex:1;width:1px;background:var(--border);margin:4px 0}.histPayCard{flex:1 1 auto;min-width:0;margin-bottom:10px;padding:12px;border:1px solid var(--border);border-radius:var(--r-md);background:var(--surface);display:flex;flex-direction:column;gap:6px}.histPayTop{display:flex;justify-content:space-between;align-items:flex-start;gap:10px}.dateMain{font-size:12px;font-weight:700;color:var(--muted)}.dateSub{font-size:10px;color:var(--sub);margin-top:1px}.histPayAmount{font-size:16px;font-weight:900;color:var(--text);letter-spacing:-.02em;font-family:var(--mono)}.histPaidBadge{padding:2px 8px;border:1px solid var(--green-bd);border-radius:var(--r-full);background:var(--green-bg);color:var(--green);font-size:10px;font-weight:700}.histPayBadges{display:flex;flex-wrap:wrap;gap:4px}.histKV{display:grid;grid-template-columns:100px 1fr;gap:4px;font-size:12px;line-height:1.4}.histKVLabel{color:var(--sub);font-weight:600}.histKVValue{color:var(--muted);word-break:break-word}.histPayNote{font-size:12px;color:var(--sub);line-height:1.4}.histPayPeriod{display:inline-flex;align-items:center;gap:5px;padding:4px 10px;border:1px solid var(--indigo-bd);border-radius:var(--r-full);background:var(--indigo-bg);color:var(--indigo-lt);font-size:11px;font-weight:700}.histSummaryCard{padding:14px;border:1px solid var(--indigo-bd);border-radius:var(--r);background:var(--indigo-bg);margin-bottom:4px}.hsGrid{display:grid;grid-template-columns:1fr 1fr;gap:8px}.hsItem{min-height:68px;display:flex;flex-direction:column;justify-content:space-between;padding:10px;border:1px solid var(--border);border-radius:var(--r-sm);background:var(--surface)}.hsLabel{color:var(--sub);font-size:10px;font-weight:700;letter-spacing:.06em;text-transform:uppercase}.hsVal{color:var(--text);font-size:14px;font-weight:900;line-height:1.2;margin-top:4px}.logsCards{display:flex;flex-direction:column;gap:8px}.logCard{border:1px solid var(--border);border-radius:var(--r-sm);background:var(--surface);padding:10px 12px}.logCard-top{display:flex;justify-content:space-between;align-items:center}.logCard-time{font-weight:700;color:var(--text);font-size:13px}.logCard-msg{margin-top:5px;color:var(--muted);line-height:1.4;font-size:13px}.histProofBtn{width:100%;display:flex;align-items:center;gap:10px;margin-top:4px;padding:8px;border:1px dashed var(--border2);border-radius:var(--r-sm);background:var(--bg);cursor:pointer;text-align:left;transition:border-color .12s}.histProofBtn:hover{border-color:var(--blue-bd)}.histProofThumb,.ktpThumb{width:68px;height:46px;flex:0 0 auto;display:grid;place-items:center;border:1px solid var(--border);border-radius:var(--r-xs);overflow:hidden;background:var(--lift)}.histProofThumb img,.ktpThumb img{width:100%;height:100%;object-fit:cover}.histProofThumb.noImage{border-style:dashed}.histProofIcon{font-size:20px;opacity:.8}.histProofText .proofTitle,.ktpTitle{color:var(--text);font-weight:700;font-size:12px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.histProofText .proofSub,.ktpSub{color:var(--sub);font-size:11px}.histProofChevron,.ktpChevron{color:var(--sub);font-size:16px;padding:0 4px}.buktiViewer{display:flex;justify-content:center;width:100%;max-height:68vh;overflow:auto;padding:6px;border:1px solid var(--border);border-radius:var(--r-sm)}.buktiViewerImg{width:auto;max-width:100%;max-height:66vh;object-fit:contain;border-radius:var(--r-xs)}.pdfViewer{width:100%;height:68vh;border:1px solid var(--border);border-radius:var(--r-sm);overflow:hidden}.ktpInputHidden{position:fixed;left:-9999px;top:0;opacity:0;width:1px;height:1px}.exSearchWrap{position:relative;display:flex;align-items:center;margin-bottom:10px}.exSearchIcon{position:absolute;left:11px;color:var(--sub);pointer-events:none}.exSearchInput{width:100%;padding:10px 38px 10px 34px;border:1px solid var(--border);border-radius:var(--r-sm);background:var(--surface);color:var(--text);font-size:13px;outline:none;transition:border-color .14s}.exSearchInput:focus{border-color:var(--indigo-bd)}.exSearchClear{position:absolute;right:9px;width:22px;height:22px;display:grid;place-items:center;border:none;border-radius:var(--r-full);background:var(--lift);color:var(--sub);font-size:10px;cursor:pointer}.exStatsBar{display:flex;align-items:center;gap:8px;margin-bottom:12px;padding:10px 12px;border:1px solid var(--border);border-radius:var(--r-sm);background:var(--surface)}.exStatItem{display:flex;flex-direction:column;align-items:center;gap:1px}.exStatVal{font-size:14px;font-weight:800;color:var(--text);line-height:1}.exStatLabel{font-size:9px;font-weight:700;color:var(--sub);text-transform:uppercase;letter-spacing:.06em}.exStatDivider{width:1px;height:26px;background:var(--border);flex-shrink:0}.exExportBtn{margin-left:auto;display:flex;align-items:center;gap:5px;padding:6px 12px;border:1px solid var(--border);border-radius:var(--r-full);background:transparent;color:var(--sub);font-size:12px;font-weight:600;cursor:pointer;transition:all .14s}.exExportBtn:hover{border-color:var(--border2);color:var(--text)}.exMonthWrap{display:flex;flex-direction:column;gap:12px}.exMonthGroup{display:flex;flex-direction:column;gap:8px}.exMonthHead{display:flex;align-items:center;justify-content:space-between;gap:8px}.exMonthHeadLeft{display:flex;align-items:center;gap:8px}.exMonthDot{width:7px;height:7px;border-radius:50%;background:var(--indigo);flex-shrink:0}.exMonthTitle{font-size:13px;font-weight:800;color:var(--text)}.exMonthCount{font-size:11px;color:var(--sub)}.exMonthExport{display:flex;align-items:center;gap:4px;padding:4px 10px;border:1px solid var(--border);border-radius:var(--r-full);background:transparent;color:var(--sub);font-size:11px;cursor:pointer;transition:all .14s}.exMonthExport:hover{color:var(--text);border-color:var(--border2)}.exCard2{border:1px solid var(--border);border-radius:var(--r);background:var(--surface);padding:14px;display:flex;flex-direction:column;gap:10px}.exCard2Head{display:flex;align-items:center;justify-content:space-between;gap:12px}.exCard2HeadLeft{display:flex;align-items:center;gap:10px;min-width:0}.exCard2Avatar{width:36px;height:36px;border-radius:var(--r-sm);background:var(--indigo-bg);border:1px solid var(--indigo-bd);display:grid;place-items:center;font-size:15px;font-weight:900;color:var(--indigo-lt);flex-shrink:0}.exCard2Name{font-size:14px;font-weight:800;color:var(--text)}.exCard2Meta{display:flex;align-items:center;gap:5px;margin-top:2px}.exCard2Room{font-size:11px;font-weight:700;color:var(--indigo-lt)}.exCard2Sep{color:var(--border2);font-size:10px}.exCard2Phone{font-size:11px;color:var(--sub)}.exCard2Total{font-size:14px;font-weight:800;color:var(--text);white-space:nowrap}.exCard2Dates{display:flex;align-items:center;gap:8px}.exCard2DateItem{display:flex;flex-direction:column;gap:2px}.exCard2DateLabel{font-size:9px;font-weight:700;color:var(--sub);text-transform:uppercase;letter-spacing:.06em}.exCard2DateVal{font-size:12px;font-weight:700;color:var(--muted)}.exCard2DateArrow{font-size:13px;color:var(--border2)}.exCard2DaysBadge{margin-left:auto;padding:2px 8px;border:1px solid var(--border);border-radius:var(--r-full);background:var(--lift);font-size:11px;font-weight:700;color:var(--sub);white-space:nowrap}.exCard2Paket{display:flex;align-items:center;gap:5px;font-size:11px;color:var(--sub)}.exCard2Detail{border-top:1px solid var(--border);padding-top:8px}.exCard2DetailToggle{width:100%;display:flex;align-items:center;justify-content:space-between;padding:4px 0;border:none;background:transparent;color:var(--sub);font-size:12px;font-weight:700;cursor:pointer}.exPayList2{display:flex;flex-direction:column;gap:6px;margin-top:8px}.exPayRow2{display:flex;align-items:flex-start;justify-content:space-between;gap:8px}.exPayRow2Left{display:flex;align-items:flex-start;gap:8px}.exPayRow2Dot{width:5px;height:5px;border-radius:50%;background:var(--border2);margin-top:5px;flex-shrink:0}.exPayRow2Date{font-size:11px;color:var(--muted)}.exPayRow2Paket{font-size:10px;color:var(--sub);margin-top:2px}.exPayRow2Amt{font-size:12px;font-weight:700;color:var(--text);white-space:nowrap}.exPayMore{font-size:11px;color:var(--sub);text-align:center;padding:4px}.exEmpty{display:flex;flex-direction:column;align-items:center;text-align:center;gap:10px;padding:32px 16px}.exEmptyTitle{font-size:14px;font-weight:800;color:var(--text)}.exEmptySub{font-size:12px;color:var(--sub);line-height:1.5;max-width:28ch}.exCard-payDetail{margin-top:6px;padding-top:8px;border-top:1px dashed var(--border2)}.exPayList{display:flex;flex-direction:column;gap:6px}.exPayRow{display:flex;align-items:flex-start;justify-content:space-between;gap:10px}.exPayDate{font-weight:700;font-size:12px;color:var(--muted)}.exPayPaket{margin-top:1px;color:var(--sub);font-size:11px}.exPayAmt{font-weight:800;white-space:nowrap;font-size:12px}.proofGallery{display:flex;flex-direction:column;gap:14px}.proofMonth{display:flex;flex-direction:column;gap:8px}.proofMonthTitle{font-size:11px;font-weight:700;color:var(--sub);text-transform:uppercase;letter-spacing:.08em}.proofGrid{display:grid;grid-template-columns:repeat(3,1fr);gap:8px}.proofTile{position:relative;aspect-ratio:1;border-radius:var(--r-md);overflow:hidden;border:1px solid var(--border);background:var(--surface);display:grid;place-items:center;cursor:pointer;transition:border-color .14s}.proofTile:active{transform:scale(.97)}.proofTile.noImage{border-style:dashed}.proofTileIcon{font-size:26px;line-height:1;opacity:.8}.proofTileBadge{position:absolute;left:5px;bottom:5px;padding:2px 7px;border-radius:var(--r-full);background:#000000a6;color:#fff;font-size:10px;font-weight:700}.proofCenter{padding:32px 16px;text-align:center;color:var(--sub)}.proofPreviewOverlay{position:fixed;top:0;right:0;bottom:0;left:0;z-index:10080;display:grid;place-items:center;padding:16px;background:#000c}.proofPreviewCard{position:relative;width:min(96vw,480px);max-height:88vh;overflow-y:auto;border:1px solid var(--border2);border-radius:var(--r);background:var(--surface);box-shadow:var(--shadow-lg)}.proofPreviewClose{position:absolute;top:10px;right:10px;width:30px;height:30px;display:grid;place-items:center;border:none;border-radius:var(--r-full);background:#ffffff1a;color:var(--text);cursor:pointer;z-index:2}.proofPreviewImgWrap{width:100%;max-height:55vh;display:grid;place-items:center;background:#000;border-radius:var(--r) var(--r) 0 0;overflow:hidden}.proofPreviewImgWrap img{width:100%;max-height:55vh;object-fit:contain;display:block}.proofPreviewMeta{padding:14px;display:flex;flex-direction:column;gap:8px}.proofMetaName{font-size:16px;font-weight:800;color:var(--text)}.proofMetaRow{display:flex;justify-content:space-between;align-items:center;padding:7px 0;border-bottom:1px solid var(--border);color:var(--sub);font-size:13px}.proofMetaRow:last-of-type{border-bottom:none}.proofMetaRow b{color:var(--text);font-weight:700}.proofPreviewActions{padding:0 14px 14px}.tenantAvatarKtp{position:relative;width:56px;height:56px;display:grid;place-items:center;border:1px solid var(--border);border-radius:var(--r-md);overflow:hidden;background:var(--lift);cursor:pointer;transition:all .14s}.tenantAvatarKtp:hover{border-color:var(--indigo-bd)}.tenantAvatarKtp.hasKtp{border-color:var(--green-bd);background:var(--green-bg)}.avatarInitial{color:var(--indigo-lt);font-size:20px;font-weight:900}.avatarKtpBadge{width:100%;height:100%;display:grid;place-items:center;color:var(--green);font-size:12px;font-weight:700;letter-spacing:.06em;text-transform:uppercase}.avatarBadge{position:absolute;right:-3px;bottom:-3px;padding:2px 5px;border:1px solid var(--indigo-bd);border-radius:var(--r-full);background:var(--bg);color:var(--indigo-lt);font-size:9px;font-weight:700}.tenantAvatarKtp.hasKtp .avatarBadge{border-color:var(--green-bd);color:var(--green)}.avatarChangeBtn{height:32px;padding:0 10px;border:1px solid var(--border);border-radius:var(--r-xs);background:var(--surface);color:var(--muted);font-weight:700;font-size:12px;font-family:inherit}.board-item{--tint: #6366f1;position:relative;display:flex;flex-direction:column;align-items:center;justify-content:center;border-radius:var(--r-sm);padding:12px 14px;min-height:104px;width:100%;border:1px solid var(--border);background:var(--surface);color:var(--text);text-decoration:none;overflow:hidden;transition:transform .14s,border-color .14s,filter .14s}.board-item:after{content:"";position:absolute;inset:0 0 auto 0;height:2px;border-radius:var(--r-sm) var(--r-sm) 0 0;background:color-mix(in srgb,var(--tint) 60%,transparent);opacity:.6}.board-item:hover{transform:translateY(-1px);filter:brightness(1.06)}.board-item:active{transform:scale(.99)}.board-item .icon{font-size:22px;margin-bottom:8px;opacity:.92}.board-item .big{font-size:15px;font-weight:800;letter-spacing:.2px;line-height:1.1}.board-item .sub{font-size:11.5px;color:var(--muted);display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}.board-item.is-kpi{background:var(--lift)}.board-item.is-kpi .pill{width:36px;height:36px;border-radius:var(--r-xs);display:grid;place-items:center;font-size:18px;margin-bottom:6px;background:color-mix(in srgb,var(--tint) 18%,#ffffff08)}.board-item.is-menu h5{margin:0 0 2px;font-weight:700;font-size:13px;line-height:1.15}.board-item.is-menu p{margin:0;font-size:11.5px;color:var(--muted);line-height:1.25}.board-item[data-type=tenants]{--tint:#6aa9ff;background:#1d2230;border-color:#2a3550}.board-item[data-type=income]{--tint:#a48bff;background:#242035;border-color:#3a3260}.board-item[data-type=dues]{--tint:#f4b35a;background:#302820;border-color:#5a4730}.board-item[data-type=profit]{--tint:#67d19a;background:#1c2a24;border-color:#35594c}.board-item[data-type=schedule]{--tint:#63c6ee;background:#1c2530;border-color:#314760}.board-item[data-type=pending]{--tint:#c1a6ff;background:#261f33;border-color:#3f3360}.board-item[data-type=feedback]{--tint:#ff8ea1;background:#2d1f25;border-color:#503541}.board-item[data-type=report]{--tint:#8fb3ff;background:#1f2433;border-color:#334160}.board-item[data-type=archive]{--tint:#9aa6b2;background:#23272c;border-color:#373d45}.board-item[data-type=inventory]{--tint:#6bd7c9;background:#1b2628;border-color:#2d4d52}.board-item[data-type=manage]{--tint:#f2a370;background:#2c221a;border-color:#50392b}.board-item[data-type=camera]{--tint:#98a0ff;background:#222437;border-color:#34385f}.board-item[data-type=utilities]{--tint:#7cd0e0;background:#1b2b2f;border-color:#32545a}.board-item[data-type=transactions]{--tint:#9ba4b0;background:#23252a;border-color:#3a3e45}.board-item[data-type=payments]{--tint:#c1a6ff;background:#261f33;border-color:#3f3360}.board-grid{display:grid;gap:12px;grid-template-columns:repeat(2,1fr);margin:12px 0 18px}.k-main{padding:16px 16px 90px;max-width:480px;margin:0 auto;overflow-x:hidden}.k-container{width:100%;max-width:480px;margin-inline:auto;overflow-x:hidden}.profileVal.unknown,.masaValue.sisa.unknown{color:var(--muted)}.cdd-logo.cimb{background:#c0392b;color:#fff}.cdd-logo.pmt{background:#1e40af;color:#fff}.cdd-logo.mega{background:#e83e2a;color:#fff}@media (max-width: 480px){.infoGrid{grid-template-columns:1fr}.kpActionBar{grid-template-columns:36px 1fr 1fr;gap:6px}}@media (max-width: 380px){.kpRow{padding:12px}.kpName{font-size:15px}.kpBadge{padding:4px 9px;font-size:10px}.board-item{min-height:96px;padding:10px 12px}.board-grid{gap:10px}}.app-page{width:100%;max-width:480px;min-height:100dvh;margin:0 auto;padding:0 16px calc(96px + env(safe-area-inset-bottom));background:var(--bg);color:var(--text);overflow-x:hidden}.app-header{position:sticky;top:0;z-index:40;padding:16px 0 12px;background:linear-gradient(var(--bg) 75%,transparent);backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px)}.app-header-row{display:flex;align-items:center;justify-content:space-between;gap:12px}.app-kicker{margin-bottom:2px;font-size:10px;font-weight:800;letter-spacing:.12em;text-transform:uppercase;color:var(--indigo-lt)}.app-title{margin:0;font-size:19px;font-weight:900;letter-spacing:-.04em;line-height:1.1;color:var(--text)}.app-sub{margin-top:3px;font-size:11px;color:var(--sub)}.app-summary{border-radius:var(--r);border:1px solid var(--border);background:radial-gradient(420px 180px at 20% 0%,rgba(99,102,241,.12),transparent 62%),var(--surface);padding:16px;margin-bottom:10px}.app-summary.income{border-color:var(--green-bd);background:radial-gradient(420px 180px at 20% 0%,rgba(52,211,153,.13),transparent 62%),var(--surface)}.app-summary.expense{border-color:var(--red-bd);background:radial-gradient(420px 180px at 20% 0%,rgba(251,113,133,.13),transparent 62%),var(--surface)}.app-summary-label{font-size:10px;font-weight:800;color:var(--sub);letter-spacing:.09em;text-transform:uppercase}.app-summary-value{margin-top:7px;font-size:26px;line-height:1;font-family:var(--mono);font-weight:900;letter-spacing:-.05em;color:var(--text)}.app-summary-sub{margin-top:8px;font-size:12px;color:var(--muted)}.app-card{border-radius:var(--r);border:1px solid var(--border);background:var(--surface);padding:14px;margin-bottom:10px;box-shadow:var(--shadow-sm)}.app-card.income{border-color:var(--green-bd)}.app-card.expense{border-color:var(--red-bd)}.app-card.soft{background:linear-gradient(180deg,var(--surface),rgba(255,255,255,.025))}.app-card-top{display:flex;align-items:flex-start;justify-content:space-between;gap:12px}.app-card-main{min-width:0}.app-card-title{font-size:14px;font-weight:900;color:var(--text);line-height:1.25;letter-spacing:-.02em;overflow-wrap:anywhere}.app-card-sub{margin-top:4px;font-size:12px;font-weight:600;color:var(--muted);line-height:1.4;overflow-wrap:anywhere}.app-card-right{flex:0 0 auto;display:flex;flex-direction:column;align-items:flex-end;gap:8px}.app-money{font-family:var(--mono);font-size:14px;font-weight:900;line-height:1.15;white-space:nowrap;color:var(--text)}.app-money.income{color:var(--green)}.app-money.expense{color:var(--red)}.app-info-grid{display:grid;gap:7px;margin-top:12px;padding-top:12px;border-top:1px solid var(--divider)}.app-info-row{display:grid;grid-template-columns:94px minmax(0,1fr);gap:10px;align-items:baseline}.app-info-label{font-size:10px;font-weight:800;color:var(--sub);letter-spacing:.06em;text-transform:uppercase}.app-info-value{min-width:0;font-size:13px;font-weight:650;color:var(--text);line-height:1.35;overflow-wrap:anywhere}.app-meta{display:flex;flex-wrap:wrap;gap:6px;margin-top:10px}.app-pill{display:inline-flex;align-items:center;gap:5px;min-height:24px;padding:0 9px;border-radius:var(--r-full);border:1px solid var(--border);background:var(--lift);color:var(--muted);font-size:11px;font-weight:700}.app-pill.income{border-color:var(--green-bd);background:var(--green-bg);color:var(--green)}.app-pill.expense{border-color:var(--red-bd);background:var(--red-bg);color:var(--red)}.app-pill.info{border-color:var(--blue-bd);background:var(--blue-bg);color:var(--blue)}.app-actions{display:flex;justify-content:flex-end;flex-wrap:wrap;gap:8px;margin-top:12px}.app-action-btn{min-height:34px;padding:0 11px;border-radius:var(--r-full);border:1px solid var(--border);background:var(--lift);color:var(--muted);font-size:12px;font-weight:800;font-family:var(--font);transition:transform .14s ease,border-color .14s ease,background .14s ease,color .14s ease}.app-action-btn:hover{border-color:var(--border2);color:var(--text)}.app-action-btn:active{transform:scale(.96)}.app-action-btn.primary{border-color:var(--indigo-bd);background:var(--indigo-bg);color:var(--indigo-lt)}.app-action-btn.danger{border-color:var(--red-bd);background:var(--red-bg);color:var(--red)}.app-action-btn.success{border-color:var(--green-bd);background:var(--green-bg);color:var(--green)}.app-chip-row{display:flex;gap:7px;overflow-x:auto;padding:2px 0 10px;scrollbar-width:none}.app-chip-row::-webkit-scrollbar{display:none}.app-chip{flex:0 0 auto;min-height:34px;padding:0 12px;border-radius:var(--r-full);border:1px solid var(--border);background:var(--surface);color:var(--muted);font-size:12px;font-weight:800}.app-chip.active{border-color:var(--indigo);background:var(--indigo);color:#fff}.app-empty{border-radius:var(--r);border:1px dashed var(--border2);background:#ffffff06;padding:24px 18px;text-align:center;color:var(--muted);font-size:13px;line-height:1.5}.app-muted{color:var(--muted);font-size:12px}@media (max-width: 380px){.app-page{padding-left:12px;padding-right:12px}.app-info-row{grid-template-columns:86px minmax(0,1fr)}.app-summary-value{font-size:23px}}.app-actions-top{margin-top:0;gap:6px;justify-content:flex-end}.app-actions-top .app-action-btn{min-height:30px;padding:0 10px;font-size:11.5px}.app-proof-btn{width:100%;min-height:42px;margin-top:12px;display:flex;align-items:center;justify-content:center;gap:7px;border-radius:var(--r-sm);border:1px solid var(--indigo-bd);background:var(--indigo-bg);color:var(--indigo-lt);font-size:13px;font-weight:750;font-family:var(--font);transition:transform .14s ease,border-color .14s ease,background .14s ease}.app-proof-btn:hover{border-color:var(--indigo);background:#6366f124}.app-proof-btn:active{transform:scale(.985)}.pp__list{display:flex;flex-direction:column;gap:10px}.pp__list .app-card{margin-bottom:0}.pp__list-wrap .app-info-grid{margin-top:10px}.pp__list-wrap .app-meta{margin-top:0;margin-bottom:8px}.pp__listHeadStack{align-items:center;gap:10px}.pp__viewToggle{flex:0 0 auto;display:flex;gap:3px;padding:3px;border-radius:var(--r-full);border:1px solid var(--border);background:var(--surface)}.pp__viewBtn{min-height:30px;padding:0 10px;border:0;border-radius:var(--r-full);background:transparent;color:var(--sub);font-size:11.5px;font-weight:800;font-family:var(--font)}.pp__viewBtn.isOn{background:var(--indigo);color:#fff}.pp-simple-card{padding:12px 14px}.pp-simple-card .app-card-sub{margin-top:5px;font-size:11.5px}.pp-simple-card .app-money{font-size:13px}.dc-grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:8px}.dc-card{position:relative;display:flex;flex-direction:column;gap:9px;padding:12px 10px;margin-bottom:0;overflow:hidden;transition:transform .15s ease,border-color .18s ease,background .18s ease}.dc-card:before{content:"";position:absolute;inset:0 auto 0 0;width:2px;background:var(--accent);opacity:.75}.dc-card:after{content:"";position:absolute;top:-28px;right:-30px;width:90px;height:90px;background:radial-gradient(circle,var(--accent) 0%,transparent 70%);opacity:.08;pointer-events:none}.dc-card:hover{transform:translateY(-1px);border-color:var(--border2)}.dc-card.dc-neg{border-color:var(--red-bd)}.dc-card.dc-rank-0{animation:dc-fadeup .35s ease .03s both}.dc-card.dc-rank-1{animation:dc-fadeup .35s ease .08s both}.dc-card.dc-rank-2{animation:dc-fadeup .35s ease .13s both}@keyframes dc-fadeup{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}.dc-card-head{position:relative;z-index:1;display:flex;align-items:center;justify-content:flex-start;gap:6px;min-width:0}.dc-card-head .app-pill{min-width:0;max-width:100%;height:24px;padding:0 8px;font-size:9.5px;letter-spacing:.04em;text-transform:uppercase;overflow:hidden;white-space:nowrap;text-overflow:ellipsis}.dc-dot{width:5px;height:5px;border-radius:var(--r-full);background:currentColor;flex:0 0 auto;box-shadow:0 0 8px currentColor}.dc-chart-area{position:relative;z-index:1;display:flex;justify-content:center;color:inherit;text-decoration:none;-webkit-tap-highlight-color:transparent}.dc-donut-wrap{position:relative;display:grid;place-items:center}.dc-donut-skeleton{border-radius:50%;background:conic-gradient(#ffffff14,#ffffff0a 360deg);animation:dc-pulse 1.4s ease-in-out infinite}@keyframes dc-pulse{0%,to{opacity:.5}50%{opacity:1}}.dc-center-pct{position:absolute;top:0;right:0;bottom:0;left:0;display:flex;align-items:center;justify-content:center;pointer-events:none}.dc-pct-num{font-size:13px;font-weight:900;color:var(--text);line-height:1;letter-spacing:-.04em}.dc-pct-sym{margin-top:2px;font-size:8px;font-weight:700;color:var(--sub)}.dc-pct-skeleton{display:block;width:22px;height:10px;border-radius:4px;background:#ffffff1a;animation:dc-pulse 1.4s ease-in-out infinite}.dc-amount-wrap{position:relative;z-index:1;min-width:0;text-align:center}.dc-amount{display:block;max-width:100%;font-size:11.5px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.dc-period{margin-top:3px;color:var(--sub);font-size:9.5px;font-weight:650;letter-spacing:.04em;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.dc-shimmer{color:transparent!important;position:relative}.dc-shimmer:after{content:"";position:absolute;top:0;right:0;bottom:0;left:0;border-radius:5px;background:linear-gradient(90deg,#ffffff0d,#ffffff24,#ffffff0d);background-size:200% 100%;animation:dc-shimmer 1.4s infinite linear}@keyframes dc-shimmer{0%{background-position:200% 0}to{background-position:-200% 0}}@media (max-width: 520px){.dc-grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:8px;overflow:visible;padding:0}.dc-card{min-width:0;max-width:none;flex:initial;padding:11px 7px 12px;border-radius:17px;gap:8px}.dc-card:before{width:2px}.dc-card:after{width:70px;height:70px;top:-22px;right:-24px;opacity:.07}.dc-card-head{align-items:center;justify-content:center;flex-direction:row}.dc-card-head .app-pill{height:22px;max-width:100%;padding:0 7px;font-size:8.5px;letter-spacing:.035em}.dc-dot{width:4px;height:4px}.dc-chart-area{transform:scale(.92);transform-origin:center;margin:-2px 0 -4px}.dc-pct-num{font-size:12px}.dc-pct-sym{font-size:7px}.dc-amount-wrap{margin-top:-2px}.dc-amount{font-size:10.5px;letter-spacing:-.03em;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.dc-period{margin-top:2px;font-size:9px}}@media (max-width: 380px){.dc-grid{gap:7px}.dc-card{padding:10px 6px 11px;border-radius:16px}.dc-card-head .app-pill{height:21px;padding:0 6px;font-size:8px}.dc-chart-area{transform:scale(.86);margin:-5px 0 -8px}.dc-amount{font-size:9.8px}.dc-period{font-size:8.5px}.dc-pct-num{font-size:11px}}.app-form-wrap{width:100%}.app-form{display:flex;flex-direction:column;gap:10px;padding:0 0 16px}.app-form-hero{border-radius:var(--r);border:1px solid var(--border);background:radial-gradient(420px 170px at 20% 0%,rgba(99,102,241,.12),transparent 62%),var(--surface);padding:16px}.app-form-hero.expense{border-color:var(--red-bd);background:radial-gradient(420px 170px at 20% 0%,rgba(251,113,133,.13),transparent 62%),var(--surface)}.app-form-hero.income{border-color:var(--green-bd);background:radial-gradient(420px 170px at 20% 0%,rgba(52,211,153,.13),transparent 62%),var(--surface)}.app-form-hero-label{font-size:10px;font-weight:800;color:var(--sub);letter-spacing:.09em;text-transform:uppercase}.app-form-money-input{display:flex;align-items:center;gap:8px;margin-top:8px}.app-form-money-prefix{font-family:var(--mono);font-size:20px;font-weight:900;color:var(--muted)}.app-form-money-field{width:100%;border:0;outline:0;background:transparent;color:var(--text);font-family:var(--mono);font-size:32px;font-weight:900;letter-spacing:-.06em;line-height:1.1}.app-form-money-field::placeholder{color:var(--dim)}.app-form-hero-sub{margin-top:6px;color:var(--muted);font-size:12px;font-weight:600}.app-form-section{border-radius:var(--r);border:1px solid var(--border);background:var(--surface);padding:13px}.app-form-section-title{margin-bottom:11px;font-size:10px;font-weight:800;color:var(--sub);letter-spacing:.09em;text-transform:uppercase}.app-form-req{margin-left:4px;color:var(--red)}.app-input{width:100%;min-height:44px;padding:0 13px;border-radius:var(--r-sm);border:1px solid var(--border2);background:var(--lift);color:var(--text);font-size:14px;font-family:var(--font);outline:none}.app-input:focus{border-color:var(--indigo-bd);box-shadow:0 0 0 3px var(--indigo-bg)}.app-input::placeholder{color:var(--dim)}.app-field-stack{display:flex;flex-direction:column;gap:10px}.app-field{display:flex;flex-direction:column;gap:6px}.app-field-label{color:var(--sub);font-size:11px;font-weight:750}.app-picker-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:8px}.app-picker-btn{min-height:48px;display:flex;align-items:center;gap:9px;padding:10px;border-radius:var(--r-sm);border:1px solid var(--border);background:var(--lift);color:var(--muted);font-family:var(--font);font-size:12px;font-weight:750;text-align:left;transition:transform .14s ease,border-color .14s ease,background .14s ease,color .14s ease}.app-picker-btn:active{transform:scale(.97)}.app-picker-btn.is-active{color:var(--indigo-lt);border-color:var(--indigo-bd);background:var(--indigo-bg)}.app-picker-btn.is-active.expense{color:var(--red);border-color:var(--red-bd);background:var(--red-bg)}.app-picker-btn.is-active.income{color:var(--green);border-color:var(--green-bd);background:var(--green-bg)}.app-picker-btn.is-active.info{color:var(--blue);border-color:var(--blue-bd);background:var(--blue-bg)}.app-picker-icon{width:28px;height:28px;flex:0 0 auto;display:grid;place-items:center;border-radius:9px;background:#ffffff0b}.app-picker-label{min-width:0;overflow-wrap:anywhere}.app-bank-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:8px}.app-bank-btn{min-height:46px;display:flex;align-items:center;gap:9px;padding:9px 10px;border-radius:var(--r-sm);border:1px solid var(--border);background:var(--lift);color:var(--muted);font-size:12px;font-weight:750;font-family:var(--font)}.app-bank-btn.is-active{color:var(--blue);border-color:var(--blue-bd);background:var(--blue-bg)}.app-bank-logo{width:24px;height:24px;object-fit:contain;border-radius:7px;background:#ffffff0a}.app-bank-label{min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.app-upload-btn{width:100%;min-height:72px;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:3px;border-radius:var(--r-sm);border:1px dashed var(--border2);background:var(--lift);color:var(--muted);font-family:var(--font)}.app-upload-btn:active{transform:scale(.99)}.app-upload-icon{width:28px;height:28px;display:grid;place-items:center;border-radius:var(--r-full);background:var(--indigo-bg);color:var(--indigo-lt);font-weight:900}.app-upload-main{color:var(--text);font-size:13px;font-weight:800}.app-upload-sub{color:var(--sub);font-size:11px;font-weight:600}.app-proof-box{border-radius:var(--r-sm);border:1px solid var(--border);background:var(--lift);overflow:hidden}.app-proof-preview{display:block;width:100%;max-height:220px;object-fit:cover;border-bottom:1px solid var(--border)}.app-proof-row{display:flex;align-items:center;justify-content:space-between;gap:10px;padding:10px}.app-proof-info{min-width:0;display:flex;flex-direction:column;gap:2px}.app-proof-name{color:var(--text);font-size:12px;font-weight:750;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.app-proof-size{color:var(--sub);font-size:11px}.app-form-actions{position:sticky;bottom:0;z-index:5;padding:10px 0 calc(10px + env(safe-area-inset-bottom));background:linear-gradient(transparent,var(--surface) 30%)}.app-submit-btn{width:100%;min-height:46px;display:inline-flex;align-items:center;justify-content:center;gap:8px;border:0;border-radius:var(--r-md);color:#fff;font-size:14px;font-weight:850;font-family:var(--font);box-shadow:var(--shadow-sm)}.app-submit-btn.expense{background:linear-gradient(135deg,var(--red),#e11d48)}.app-submit-btn.income{background:linear-gradient(135deg,var(--green),#059669)}.app-submit-btn:disabled{opacity:.65;cursor:not-allowed}.app-form-hero.income .app-form-money-prefix{color:var(--green)}.app-form-hero.expense .app-form-money-prefix,.app-form-section .app-form-req{color:var(--red)}.app-form-hero.income+.app-form-section .app-form-req{color:var(--green)}.app-stat-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:8px;margin-top:14px}.app-stat-card{min-width:0;border-radius:var(--r-sm);border:1px solid var(--border);background:var(--lift);padding:10px}.app-stat-label{display:block;font-size:9.5px;font-weight:800;color:var(--sub);letter-spacing:.07em;text-transform:uppercase}.app-stat-value{display:block;margin-top:5px;font-family:var(--mono);font-size:13px;font-weight:900;color:var(--text);line-height:1.15;overflow-wrap:anywhere}.app-progress-list{display:flex;flex-direction:column;gap:12px;margin-top:14px}.app-progress-row{min-width:0}.app-progress-head{display:flex;align-items:baseline;justify-content:space-between;gap:10px}.app-progress-name{min-width:0;color:var(--text);font-size:12.5px;font-weight:850;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.app-progress-amount{flex:0 0 auto;color:var(--muted);font-family:var(--mono);font-size:11.5px;font-weight:850;white-space:nowrap}.app-progress-track{height:7px;margin-top:7px;border-radius:var(--r-full);background:#ffffff0f;overflow:hidden}.app-progress-fill{height:100%;border-radius:inherit;background:var(--indigo)}.app-progress-fill.expense{background:linear-gradient(90deg,var(--red),#fb7185)}.app-progress-fill.income{background:linear-gradient(90deg,var(--green),#34d399)}.app-progress-sub{margin-top:5px;color:var(--sub);font-size:10.5px;font-weight:650}.ed-app-header{position:relative;top:auto;z-index:1;padding:0 0 4px;background:transparent;backdrop-filter:none;-webkit-backdrop-filter:none}.ed-refresh-modern{min-width:34px;padding:0;font-size:16px}.ed-summary-modern,.ed-mom-modern,.ed-breakdown-modern{margin-bottom:10px}.ed-breakdown-modern-toggle{width:100%;margin-top:14px;justify-content:center}.ed-danger-text{color:var(--red)}.ed-success-text{color:var(--green)}@media (max-width: 380px){.app-stat-grid{gap:7px}.app-stat-card{padding:9px}.app-stat-value{font-size:12px}.app-progress-amount{font-size:10.8px}}.id-panel-modern{width:100%;max-width:100%;min-width:0;overflow:hidden;background:transparent;border:0;border-radius:0;padding:0;gap:10px}.id-panel-modern .id-groups,.id-panel-modern .id-group,.id-panel-modern .id-items,.id-panel-modern .id-item{min-width:0;max-width:100%}.id-app-header{position:relative;top:auto;z-index:1;padding:0 0 4px;background:transparent;backdrop-filter:none;-webkit-backdrop-filter:none}.id-refresh-modern{min-width:34px;padding:0;font-size:16px}.id-summary-modern,.id-source-modern{margin-bottom:10px}.id-source-grid-modern{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:8px;margin-top:14px}.id-source-card-modern{min-width:0;border-radius:var(--r-sm);border:1px solid var(--green-bd);background:var(--green-bg);padding:10px 8px}.id-source-label-modern{color:var(--green);font-size:9px;font-weight:850;line-height:1.25;letter-spacing:.04em;text-transform:uppercase;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.id-source-amount-modern{margin-top:7px;color:var(--text);font-family:var(--mono);font-size:11.5px;font-weight:900;line-height:1.15;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.id-source-meta-modern{margin-top:4px;color:var(--sub);font-size:9.5px;font-weight:650;white-space:nowrap}@media (max-width: 380px){.id-source-grid-modern{gap:7px}.id-source-card-modern{padding:9px 6px}.id-source-label-modern{font-size:8px}.id-source-amount-modern{font-size:10.5px}.id-source-meta-modern{font-size:8.5px}}.pp-app-header{position:relative;top:auto;z-index:1;padding:0 0 4px;background:transparent;backdrop-filter:none;-webkit-backdrop-filter:none}.pp-summary-modern{margin-bottom:10px}.pp-summary-modern .app-summary-value{overflow-wrap:anywhere}.pp-profit-pos{color:var(--green)}.pp-profit-neg{color:var(--red)}.pp-modern-ratio{height:8px;margin-top:13px;border-radius:var(--r-full);background:#ffffff0f;overflow:hidden}.pp-modern-ratio-fill{height:100%;max-width:100%;border-radius:inherit;transition:width .25s ease}.pp-modern-ratio-fill.income{background:linear-gradient(90deg,var(--green),#34d399)}.pp-modern-ratio-fill.expense{background:linear-gradient(90deg,var(--red),#fb7185)}.pp-filter-modern{margin-bottom:10px}.pp-filter-modern .app-chip{min-width:0}@media (max-width: 380px){.pp-filter-modern .app-chip{padding:0 10px;font-size:11px}}.ap-page-modern{padding-top:0}.ap-app-header{position:relative;top:auto;z-index:1;padding:0 0 4px;background:transparent;backdrop-filter:none;-webkit-backdrop-filter:none}.ap-range-modern{margin-top:12px;padding-bottom:4px}.ap-list-modern{display:flex;flex-direction:column;gap:10px}.ap-summary-modern{margin-bottom:0}.ap-summary-info{margin-top:12px}.ap-section-modern{display:flex;align-items:center;justify-content:space-between;gap:12px;padding:4px 2px 0}.ap-month-modern{margin-bottom:0}.ap-month-modern .app-meta{margin-top:0;margin-bottom:8px}.ap-month-actions-modern{justify-content:stretch;margin-top:14px}.ap-month-actions-modern .app-action-btn{flex:1;justify-content:center}.ap-skeleton-modern{min-height:112px;display:flex;flex-direction:column;gap:10px}.ap-sk-line-modern{height:13px;border-radius:var(--r-full);background:#ffffff12;animation:ap-modern-pulse 1.2s ease-in-out infinite}.ap-sk-line-modern.sm{width:32%}.ap-sk-line-modern.lg{width:78%}.ap-sk-line-modern.half{width:56%}@keyframes ap-modern-pulse{0%,to{opacity:.45}50%{opacity:.85}}@media (max-width: 380px){.ap-month-actions-modern{gap:6px}.ap-month-actions-modern .app-action-btn{padding:0 9px;font-size:11px}}.aed-modern-wrap{width:100%;max-width:100%;min-width:0}.aed-app-header{position:relative;top:auto;z-index:1;padding:0 0 4px;background:transparent;backdrop-filter:none;-webkit-backdrop-filter:none}.aed-refresh-modern{min-width:34px;padding:0;font-size:16px}.aed-summary-modern,.aed-error-modern{margin-bottom:10px}.aed-modern-list,.aed-modern-groups,.aed-modern-items{display:flex;flex-direction:column;gap:10px}.aed-modern-group{display:flex;flex-direction:column;gap:8px}.aed-modern-group-head{display:flex;align-items:center;justify-content:space-between;gap:12px;padding:4px 2px 0}.aed-modern-group-head .app-pill{flex:0 0 auto}.aed-item-modern{margin-bottom:0}.aed-item-modern .app-info-grid{margin-top:11px}.aed-skeleton-modern{min-height:112px;display:flex;flex-direction:column;gap:10px}@media (max-width: 380px){.aed-modern-group-head{align-items:flex-start;flex-direction:column;gap:6px}.aed-item-modern .app-card-top{gap:10px}.aed-item-modern .app-card-right{max-width:42%}.aed-item-modern .app-actions-top .app-action-btn{padding:0 8px;font-size:11px}}.arsip-income-modern{padding-top:0}.arsip-app-header{position:relative;top:auto;z-index:1;padding:0 0 4px;background:transparent;backdrop-filter:none;-webkit-backdrop-filter:none}.arsip-range-modern{margin-top:12px;padding-bottom:4px}.arsip-list-modern{display:flex;flex-direction:column;gap:10px}.arsip-summary-modern{margin-bottom:0}.arsip-summary-info{margin-top:12px}.arsip-section-modern{display:flex;align-items:center;justify-content:space-between;gap:12px;padding:4px 2px 0}.arsip-month-modern{margin-bottom:0}.arsip-month-modern .app-meta{margin-top:0;margin-bottom:8px}.arsip-month-actions-modern{justify-content:stretch;margin-top:14px}.arsip-month-actions-modern .app-action-btn{flex:1;justify-content:center}.arsip-skeleton-modern{min-height:112px;display:flex;flex-direction:column;gap:10px}@media (max-width: 380px){.arsip-month-actions-modern{gap:6px}.arsip-month-actions-modern .app-action-btn{padding:0 9px;font-size:11px}}.dashboard-modern{padding-top:0}.dash-app-header{position:relative;top:auto;z-index:1;padding:0 0 4px;background:transparent;backdrop-filter:none;-webkit-backdrop-filter:none}.dash-settings-modern{position:relative;min-width:36px;padding:0}.dash-notif-badge-modern{position:absolute;top:-6px;right:-6px;min-width:17px;height:17px;display:grid;place-items:center;padding:0 5px;border-radius:var(--r-full);border:2px solid var(--bg);background:var(--red);color:#fff;font-size:9.5px;font-weight:900;line-height:1}.dashboard-error-modern,.dashboard-last-modern,.dashboard-kost-modern,.dashboard-finance-modern,.dashboard-detail-modern{margin-bottom:10px}.dashboard-last-modern .app-meta{margin-top:0;margin-bottom:8px}.dashboard-kpi-grid-modern{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:8px;margin-top:14px}.dashboard-kpi-modern{min-width:0;display:flex;flex-direction:column;gap:5px;min-height:112px;padding:11px;border-radius:var(--r-sm);border:1px solid var(--border);background:var(--lift);color:var(--text);text-decoration:none;overflow:hidden}.dashboard-kpi-modern.ok{border-color:var(--green-bd);background:var(--green-bg)}.dashboard-kpi-modern.warn{border-color:var(--amber-bd);background:var(--amber-bg)}.dashboard-kpi-modern.danger{border-color:var(--red-bd);background:var(--red-bg)}.dashboard-kpi-label{color:var(--sub);font-size:9.5px;font-weight:850;letter-spacing:.07em;text-transform:uppercase}.dashboard-kpi-value{font-family:var(--mono);font-size:18px;font-weight:950;line-height:1.1;letter-spacing:-.05em;color:var(--text);overflow-wrap:anywhere}.dashboard-kpi-value.money{font-size:14px}.dashboard-kpi-value.income{color:var(--green)}.dashboard-kpi-value.expense{color:var(--red)}.dashboard-kpi-sub{color:var(--muted);font-size:11px;font-weight:650;line-height:1.35}.dashboard-kpi-track{height:7px;margin-top:auto;border-radius:var(--r-full);background:#ffffff12;overflow:hidden}.dashboard-kpi-fill{height:100%;border-radius:inherit;background:linear-gradient(90deg,var(--indigo),var(--blue))}.dashboard-kpi-modern.ok .dashboard-kpi-fill{background:linear-gradient(90deg,var(--green),#34d399)}.dashboard-kpi-modern.warn .dashboard-kpi-fill{background:linear-gradient(90deg,var(--amber),#fbbf24)}.dashboard-kpi-modern.danger .dashboard-kpi-fill{background:linear-gradient(90deg,var(--red),#fb7185)}.dashboard-mini-row{display:flex;flex-wrap:wrap;gap:5px;margin-top:auto}.dashboard-mini-row .app-pill{min-height:22px;padding:0 8px;font-size:10px}.dashboard-quick-actions-modern{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:8px;margin-top:12px}.dashboard-qa-modern{min-height:40px;justify-content:center}.dashboard-range-modern{margin-top:12px;padding-bottom:10px}.dashboard-detail-head-modern{margin-bottom:10px}.dashboard-detail-body-modern{min-width:0}.dashboard-detail-body-modern>*{min-width:0}@media (max-width: 380px){.dashboard-kpi-grid-modern{gap:7px}.dashboard-kpi-modern{padding:10px 9px;min-height:106px}.dashboard-kpi-value{font-size:16px}.dashboard-kpi-value.money{font-size:12.5px}.dashboard-kpi-sub{font-size:10.5px}.dashboard-qa-modern{font-size:11.5px}}.dashboard-menu-modern{margin-bottom:10px}.dashboard-menu-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:10px;margin-top:14px}.dashboard-menu-item-wrap{min-width:0}.dashboard-menu-item-wrap.is-dragging{z-index:5}.dashboard-menu-item-wrap.is-dragging .dashboard-menu-item{transform:scale(1.015);border-color:var(--border2);box-shadow:var(--shadow-sm)}.dashboard-menu-item{--menu-tint: var(--indigo);position:relative;min-height:146px;display:flex;flex-direction:column;align-items:stretch;justify-content:space-between;gap:12px;padding:14px;border-radius:var(--r-md);border:1px solid var(--border);background:radial-gradient(130px 90px at 0% 0%,color-mix(in srgb,var(--menu-tint) 9%,transparent),transparent 74%),var(--lift);color:var(--text);text-decoration:none;overflow:hidden;-webkit-tap-highlight-color:transparent;touch-action:none;transition:transform .14s ease,border-color .14s ease,background .14s ease,box-shadow .14s ease}.dashboard-menu-item:before{content:"";position:absolute;inset:0 auto 0 0;width:3px;background:var(--menu-tint);opacity:.75}.dashboard-menu-item:active{transform:scale(.985)}.dashboard-menu-item:hover{border-color:var(--border2);box-shadow:var(--shadow-sm)}.dashboard-menu-item-top{position:relative;z-index:1;display:flex;align-items:flex-start;justify-content:space-between;gap:10px;width:100%}.dashboard-menu-icon{width:54px;height:54px;display:grid;place-items:center;border-radius:18px;background:#ffffff0d;border:1px solid rgba(255,255,255,.06);color:var(--text);box-shadow:inset 0 1px #ffffff0a;flex:0 0 auto}.dashboard-menu-chevron{flex:0 0 auto;margin-top:3px;color:var(--sub);opacity:.72}.dashboard-menu-item:hover .dashboard-menu-icon{background:#ffffff12}.dashboard-menu-item:hover .dashboard-menu-chevron,.dashboard-menu-item:active .dashboard-menu-chevron{color:var(--text);opacity:1}.dashboard-menu-copy{position:relative;z-index:1;min-width:0;width:100%;display:flex;flex-direction:column;gap:5px}.dashboard-menu-copy strong{display:-webkit-box;color:var(--text);font-size:14px;font-weight:850;line-height:1.18;letter-spacing:-.02em;white-space:normal;overflow:hidden;text-overflow:ellipsis;-webkit-line-clamp:2;-webkit-box-orient:vertical}.dashboard-menu-copy small{display:-webkit-box;color:var(--muted);font-size:11px;font-weight:650;line-height:1.32;white-space:normal;overflow:hidden;text-overflow:ellipsis;-webkit-line-clamp:2;-webkit-box-orient:vertical}.dashboard-menu-item[data-type=archive-income]{--menu-tint: #34d399}.dashboard-menu-item[data-type=archive-expense]{--menu-tint: #fb7185}.dashboard-menu-item[data-type=inventory]{--menu-tint: #fbbf24}.dashboard-menu-item[data-type=camera]{--menu-tint: #60a5fa}.dashboard-menu-item[data-type=utilities]{--menu-tint: #38bdf8}.dashboard-menu-item[data-type=document]{--menu-tint: #818cf8}.dashboard-menu-item[data-type=mama-finance]{--menu-tint: #f472b6}@media (max-width: 520px){.dashboard-menu-grid{gap:9px}.dashboard-menu-item{min-height:138px;padding:13px;gap:11px;border-radius:17px}.dashboard-menu-icon{width:50px;height:50px;border-radius:16px}.dashboard-menu-copy strong{font-size:13.5px}.dashboard-menu-copy small{font-size:10.5px}}@media (max-width: 380px){.dashboard-menu-grid{gap:8px}.dashboard-menu-item{min-height:132px;padding:12px;border-radius:16px}.dashboard-menu-icon{width:46px;height:46px;border-radius:15px}.dashboard-menu-copy strong{font-size:13px}.dashboard-menu-copy small{font-size:10px}.dashboard-menu-chevron{opacity:.6}}.tenants-modern-page{padding-top:0}.tenants-app-header{position:relative;top:auto;z-index:30;padding:0 0 4px;background:transparent;backdrop-filter:none;-webkit-backdrop-filter:none}.tenants-admin-modern{position:relative;flex:0 0 auto}.tenants-admin-btn{min-width:58px}.tenants-admin-card-modern{position:absolute;right:0;top:calc(100% + 8px);z-index:60;width:230px;border-radius:var(--r);border:1px solid var(--border);background:var(--surface);box-shadow:var(--shadow);padding:7px}.tenants-admin-item-modern{width:100%;min-height:40px;display:flex;align-items:center;gap:8px;padding:0 10px;border:0;border-radius:var(--r-sm);background:transparent;color:var(--text);font-size:12px;font-weight:750;font-family:var(--font);text-align:left}.tenants-admin-item-modern:hover{background:var(--lift)}.tenants-admin-item-modern.danger{color:var(--red)}.tenants-summary-modern{margin-bottom:10px}.tenants-danger-text{color:var(--red)}.tenants-warn-text{color:var(--amber)}.tenants-floor-modern{margin-bottom:8px;padding-bottom:6px}.tenants-room-section-modern{display:flex;flex-direction:column;gap:10px}.tenants-section-head-modern{display:flex;align-items:center;justify-content:space-between;gap:12px;padding:2px 2px 0}.tenants-room-list-modern{display:flex;flex-direction:column;gap:10px}.tenants-room-card{margin-bottom:0}.tenants-room-card.paid,.tenants-room-card.ok{border-color:var(--green-bd)}.tenants-room-card.overdue,.tenants-room-card.dueToday{border-color:var(--red-bd)}.tenants-room-card.near,.tenants-room-card.unpaid{border-color:var(--amber-bd)}.tenants-room-card.empty{border-color:var(--border);opacity:.9}.tenants-room-topline{display:flex;align-items:center;justify-content:space-between;gap:8px;margin-bottom:9px}.tenants-room-number{min-height:26px;display:inline-flex;align-items:center;padding:0 10px;border-radius:var(--r-full);border:1px solid var(--border);background:var(--lift);color:var(--text);font-family:var(--mono);font-size:12px;font-weight:900}.tenants-status-pill{min-height:26px;display:inline-flex;align-items:center;justify-content:center;padding:0 10px;border-radius:var(--r-full);border:1px solid var(--border);background:var(--lift);color:var(--muted);font-size:11px;font-weight:850;font-family:var(--font)}.tenants-status-pill.paid,.tenants-status-pill.ok{border-color:var(--green-bd);background:var(--green-bg);color:var(--green)}.tenants-status-pill.overdue,.tenants-status-pill.dueToday{border-color:var(--red-bd);background:var(--red-bg);color:var(--red)}.tenants-status-pill.near,.tenants-status-pill.unpaid{border-color:var(--amber-bd);background:var(--amber-bg);color:var(--amber)}.tenants-status-pill.empty,.tenants-status-pill:disabled{border-color:var(--border);background:var(--lift);color:var(--sub)}.tenants-name-modern{font-size:15px}.tenants-meta-modern{margin-top:5px;font-family:var(--mono);font-size:11.5px}.tenants-remain-modern{display:inline-flex;align-items:center;width:fit-content;min-height:24px;margin-top:9px;padding:0 9px;border-radius:var(--r-full);border:1px solid var(--border);background:var(--lift);color:var(--muted);font-size:11px;font-weight:800}.tenants-remain-modern.ok{border-color:var(--green-bd);background:var(--green-bg);color:var(--green)}.tenants-remain-modern.near{border-color:var(--amber-bd);background:var(--amber-bg);color:var(--amber)}.tenants-remain-modern.dueToday,.tenants-remain-modern.overdue{border-color:var(--red-bd);background:var(--red-bg);color:var(--red)}.tenants-actions-modern{justify-content:stretch;margin-top:13px}.tenants-actions-modern .app-action-btn{flex:1;justify-content:center}.tenants-add-room-btn{width:100%}.tenants-skeleton-card{min-height:116px;display:flex;flex-direction:column;gap:10px}@media (max-width: 380px){.tenants-admin-card-modern{width:210px}.tenants-actions-modern{gap:7px}.tenants-actions-modern .app-action-btn{padding:0 9px;font-size:11px}.tenants-name-modern{font-size:14px}.tenants-meta-modern{font-size:10.8px}}.modalBody .modalCard.modalMobile,.modalBody .modalCard{width:100%;max-width:100%;background:transparent;border:0;border-radius:0;padding:14px}.modalBody .col{display:flex;flex-direction:column;gap:10px}.modalBody .formSection{border-radius:var(--r);border:1px solid var(--border);background:var(--surface);padding:13px;margin:0}.modalBody .sectionTitle{margin:0 0 11px;color:var(--sub);font-size:10px;font-weight:850;letter-spacing:.09em;text-transform:uppercase}.modalBody .label{display:flex;flex-direction:column;gap:6px;color:var(--text);font-size:12px;font-weight:750}.modalBody .label>span,.modalBody .labelText{color:var(--sub);font-size:11px;font-weight:800}.modalBody .input,.modalBody .input.big,.modalBody select.input,.modalBody textarea.input{width:100%;min-height:44px;padding:0 13px;border-radius:var(--r-sm);border:1px solid var(--border2);background:var(--lift);color:var(--text);font-size:14px;font-family:var(--font);outline:none}.modalBody textarea.input{min-height:84px;padding-top:11px;padding-bottom:11px;resize:vertical}.modalBody .input:focus,.modalBody .input.big:focus,.modalBody select.input:focus,.modalBody textarea.input:focus{border-color:var(--indigo-bd);box-shadow:0 0 0 3px var(--indigo-bg)}.modalBody .input::placeholder,.modalBody .input.big::placeholder,.modalBody textarea.input::placeholder{color:var(--dim)}.modalBody .errorText,.modalBody .errorText.small{border-radius:var(--r-sm);border:1px solid var(--red-bd);background:var(--red-bg);color:var(--red);padding:10px 11px;font-size:12px;font-weight:750;line-height:1.4}.modalBody .hint,.modalBody .muted,.modalBody .small{color:var(--muted)}.modalBody .cdd-wrap{position:relative;width:100%}.modalBody .cdd-trigger{width:100%;min-height:44px;display:flex;align-items:center;justify-content:space-between;gap:10px;padding:0 13px;border-radius:var(--r-sm);border:1px solid var(--border2);background:var(--lift);color:var(--text);font-family:var(--font)}.modalBody .cdd-trigger.open{border-color:var(--indigo-bd);box-shadow:0 0 0 3px var(--indigo-bg)}.modalBody .cdd-placeholder{color:var(--dim)}.modalBody .cdd-label{color:var(--text);font-size:13px;font-weight:800}.modalBody .cdd-arrow{color:var(--sub);font-size:10px}.modalBody .cdd-list{position:absolute;left:0;right:0;top:calc(100% + 7px);z-index:80;max-height:260px;overflow-y:auto;border-radius:var(--r-sm);border:1px solid var(--border);background:var(--surface);box-shadow:var(--shadow);padding:6px}.modalBody .cdd-item{width:100%;min-height:40px;display:flex;align-items:center;gap:9px;padding:7px 9px;border:0;border-radius:10px;background:transparent;color:var(--text);font-family:var(--font);text-align:left}.modalBody .cdd-item:hover,.modalBody .cdd-item.selected{background:var(--lift)}.modalBody .cdd-logo-img{width:24px;height:24px;object-fit:contain;border-radius:7px;background:#ffffff0d}.modalBody .cdd-item-text{min-width:0;display:flex;flex-direction:column;gap:1px}.modalBody .cdd-item-label{color:var(--text);font-size:12.5px;font-weight:800}.modalBody .cdd-item-sub{color:var(--muted);font-size:10.5px;font-weight:650}.modalBody .cdd-check{margin-left:auto;color:var(--green);font-weight:900}.modalBody input[type=file].input,.modalBody input[type=file].input.big{min-height:auto;padding:11px;font-size:12px}.modalBody .fileBadge{margin-top:8px;border-radius:var(--r-sm);border:1px solid var(--blue-bd);background:var(--blue-bg);color:var(--blue);padding:9px 10px;font-size:12px;font-weight:750}.modalBody .proofPreviewImg,.modalBody .ktpPreviewImg{display:block;width:100%;max-height:220px;margin-top:8px;object-fit:cover;border-radius:var(--r-sm);border:1px solid var(--border);background:var(--lift)}.modalBody .modalActions,.modalBody .stickyActions{position:sticky;bottom:0;z-index:10;display:flex;gap:8px;padding:10px 0 calc(10px + env(safe-area-inset-bottom));margin-top:4px;background:linear-gradient(transparent,var(--surface) 32%)}.modalBody .btn{min-height:42px;display:inline-flex;align-items:center;justify-content:center;gap:7px;padding:0 13px;border-radius:var(--r-sm);border:1px solid var(--border);background:var(--lift);color:var(--text);font-size:13px;font-weight:850;font-family:var(--font)}.modalBody .btn.full{width:100%}.modalBody .btn.primary,.modalBody .btnPrimary,.modalBody .btn.primary.full{border-color:var(--green-bd);background:linear-gradient(135deg,var(--green),#059669);color:#fff}.modalBody .btn.danger,.modalBody .btnDanger{border-color:var(--red-bd);background:var(--red-bg);color:var(--red)}.modalBody .btn:disabled{opacity:.65;cursor:not-allowed}@media (max-width: 380px){.modalBody .modalCard.modalMobile,.modalBody .modalCard,.modalBody .formSection{padding:12px}.modalBody .btn{font-size:12px;padding:0 11px}}.tenantDetailModal{width:100%;min-height:100%;display:flex;flex-direction:column;background:var(--bg);color:var(--text);overflow:hidden}.tenantDetailHead{flex:0 0 auto;display:flex;align-items:center;justify-content:space-between;gap:12px;padding:calc(14px + env(safe-area-inset-top)) 16px 12px;border-bottom:1px solid var(--divider);background:radial-gradient(360px 150px at 20% 0%,rgba(99,102,241,.12),transparent 62%),var(--surface)}.tenantDetailRoom{min-width:0;color:var(--text);font-size:17px;font-weight:900;line-height:1.1;letter-spacing:-.03em}.tenantDetailHeadRight{flex:0 0 auto;display:flex;align-items:center;gap:8px}.tenantDetailHeadRight .kpBadge{min-height:28px;display:inline-flex;align-items:center;padding:0 10px;border-radius:var(--r-full);border:1px solid var(--border);background:var(--lift);color:var(--muted);font-size:11px;font-weight:850}.tenantDetailHeadRight .kpBadge.paid,.tenantDetailHeadRight .kpBadge.ok{border-color:var(--green-bd);background:var(--green-bg);color:var(--green)}.tenantDetailHeadRight .kpBadge.overdue,.tenantDetailHeadRight .kpBadge.dueToday{border-color:var(--red-bd);background:var(--red-bg);color:var(--red)}.tenantDetailHeadRight .kpBadge.near,.tenantDetailHeadRight .kpBadge.unpaid{border-color:var(--amber-bd);background:var(--amber-bg);color:var(--amber)}.tenantDetailClose{width:36px;height:36px;display:grid;place-items:center;border-radius:var(--r-full);border:1px solid var(--border);background:var(--lift);color:var(--muted)}.tenantDetailClose:active{transform:scale(.94)}.tenantDetailIdentity{flex:0 0 auto;display:flex;align-items:center;gap:13px;padding:14px 16px;border-bottom:1px solid var(--divider);background:var(--surface)}.tenantAvatar{position:relative;width:68px;height:68px;flex:0 0 auto;display:grid;place-items:center;border-radius:22px;border:1px solid var(--border);background:radial-gradient(circle at 30% 10%,rgba(255,255,255,.08),transparent 52%),var(--lift);color:var(--text);overflow:hidden}.tenantAvatar.hasKtp{border-color:var(--blue-bd);background:var(--blue-bg)}.tenantAvatar.noKtp{border-color:var(--indigo-bd);background:var(--indigo-bg)}.avatarInitial{font-size:25px;font-weight:950;color:var(--indigo-lt)}.avatarKtpBadge{color:var(--blue);font-size:12px;font-weight:950;letter-spacing:.08em}.avatarBadge{position:absolute;right:5px;bottom:5px;width:22px;height:22px;display:grid;place-items:center;border-radius:var(--r-full);border:1px solid var(--border);background:var(--surface);color:var(--text)}.tenantIdentityText{min-width:0;display:flex;flex-direction:column;gap:7px}.tenantIdName{min-width:0;display:flex;align-items:center;gap:7px;color:var(--text);font-size:16px;font-weight:900;line-height:1.2}.tenantIdName span{min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.tenantIdPhoneRow{min-width:0;display:flex;align-items:center;gap:7px;color:var(--muted)}.tenantIdPhone{min-width:0;color:var(--muted);font-family:var(--mono);font-size:12px;font-weight:750;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.copyBtn{width:30px;height:30px;flex:0 0 auto;display:grid;place-items:center;border-radius:var(--r-full);border:1px solid var(--border);background:var(--lift);color:var(--muted)}.copyBtn:active{transform:scale(.94)}.tenantDetailBody{flex:1 1 auto;min-height:0;overflow-y:auto;overflow-x:hidden;padding:14px 16px 0;-webkit-overflow-scrolling:touch}.tenantInfo{width:100%}.infoGrid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:9px}.infoCell{min-width:0;border-radius:var(--r-sm);border:1px solid var(--border);background:var(--surface);padding:11px}.infoCell.full{grid-column:1 / -1}.profileRow{min-width:0;display:flex;flex-direction:column;gap:6px}.profileKey,.masaLabel{color:var(--sub);font-size:9.5px;font-weight:850;line-height:1.2;letter-spacing:.08em;text-transform:uppercase}.profileVal,.masaValue{min-width:0;color:var(--text);font-size:13px;font-weight:800;line-height:1.35;overflow-wrap:anywhere}.profileVal.ok{color:var(--green)}.profileVal.near{color:var(--amber)}.profileVal.overdue,.profileVal.dueToday{color:var(--red)}.infoCell.full .profileVal,.infoCell.full .masaValue{font-size:13px}.tenants-detail-actions-modern{flex:0 0 auto;display:flex;flex-direction:column;gap:8px;padding:12px 16px calc(14px + env(safe-area-inset-bottom));border-top:1px solid var(--divider);background:linear-gradient(transparent,var(--bg) 18%),var(--bg)}.tenants-detail-action-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:8px}.tenants-detail-action-btn{min-height:44px;justify-content:center;gap:7px}.tenants-detail-pay-btn{min-height:48px;border-radius:var(--r-sm)}@media (max-width: 380px){.tenantDetailHead,.tenantDetailIdentity,.tenantDetailBody,.tenants-detail-actions-modern{padding-left:12px;padding-right:12px}.tenantAvatar{width:62px;height:62px;border-radius:20px}.tenantIdName{font-size:15px}.infoGrid{gap:8px}.infoCell{padding:10px}.profileVal,.masaValue{font-size:12.5px}}@media (max-width: 520px){.tenantDetailBody{padding-bottom:8px}.infoGrid{grid-template-columns:1fr;gap:8px}.infoCell{padding:12px}.profileRow{display:grid;grid-template-columns:112px minmax(0,1fr);align-items:baseline;gap:12px}.profileKey,.masaLabel{font-size:10px;line-height:1.2}.profileVal,.masaValue{font-size:14px;line-height:1.35;overflow-wrap:anywhere;word-break:normal}.infoCell.full{grid-column:auto}}@media (max-width: 380px){.profileRow{grid-template-columns:100px minmax(0,1fr);gap:10px}.profileVal,.masaValue{font-size:13.5px}}.pay-modern-shell{width:100%;min-height:100%;background:transparent;border:0;border-radius:0;padding:14px}.pay-modern-header{display:grid;grid-template-columns:38px minmax(0,1fr) auto;align-items:center;gap:11px;margin-bottom:12px;padding:13px;border-radius:var(--r);border:1px solid var(--border);background:radial-gradient(360px 150px at 20% 0%,rgba(52,211,153,.12),transparent 62%),var(--surface)}.pay-modern-back{width:38px;height:38px;display:grid;place-items:center;border-radius:var(--r-full);border:1px solid var(--border);background:var(--lift);color:var(--muted);font-size:18px;font-weight:900;font-family:var(--font)}.pay-modern-back:active{transform:scale(.94)}.pay-modern-tenant{min-width:0}.pay-modern-kicker{margin-bottom:3px;color:var(--green);font-size:9.5px;font-weight:850;letter-spacing:.1em;text-transform:uppercase}.pay-modern-name{min-width:0;color:var(--text);font-size:14px;font-weight:900;line-height:1.2;letter-spacing:-.02em;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.pay-modern-phone{margin-top:3px;color:var(--muted);font-family:var(--mono);font-size:11.5px;font-weight:750;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.pay-modern-badge{min-height:28px;display:inline-flex;align-items:center;justify-content:center;padding:0 10px;border-radius:var(--r-full);border:1px solid var(--green-bd);background:var(--green-bg);color:var(--green);font-size:11px;font-weight:850;white-space:nowrap}.pay-modern-badge.extend{border-color:var(--indigo-bd);background:var(--indigo-bg);color:var(--indigo-lt)}.pay-modern-badge.other{border-color:var(--blue-bd);background:var(--blue-bg);color:var(--blue)}.pay-modern-badge.installment{border-color:var(--amber-bd);background:var(--amber-bg);color:var(--amber)}.pay-modern-badge.deposit{border-color:var(--border2);background:var(--lift);color:var(--text)}.pay-modern-grid{display:flex;flex-direction:column;gap:9px}.pay-modern-card{--pay-tint: var(--indigo);position:relative;width:100%;min-height:84px;display:grid;grid-template-columns:48px minmax(0,1fr) 18px;align-items:center;gap:12px;padding:13px;border-radius:var(--r);border:1px solid var(--border);background:radial-gradient(180px 100px at 0% 0%,color-mix(in srgb,var(--pay-tint) 10%,transparent),transparent 72%),var(--surface);color:var(--text);text-align:left;font-family:var(--font);overflow:hidden;transition:transform .14s ease,border-color .14s ease,background .14s ease}.pay-modern-card:before{content:"";position:absolute;inset:0 auto 0 0;width:3px;background:var(--pay-tint);opacity:.78}.pay-modern-card:active{transform:scale(.985)}.pay-modern-card.primary{--pay-tint: var(--indigo)}.pay-modern-card.success{--pay-tint: var(--green)}.pay-modern-card.warn{--pay-tint: var(--amber)}.pay-modern-card.neutral{--pay-tint: var(--blue)}.pay-modern-icon{position:relative;z-index:1;width:48px;height:48px;display:grid;place-items:center;border-radius:16px;border:1px solid rgba(255,255,255,.06);background:#ffffff0d;color:var(--text)}.pay-modern-copy{position:relative;z-index:1;min-width:0;display:flex;flex-direction:column;gap:4px}.pay-modern-copy strong{color:var(--text);font-size:14px;font-weight:900;line-height:1.2;letter-spacing:-.02em}.pay-modern-copy small{display:-webkit-box;color:var(--muted);font-size:11.5px;font-weight:650;line-height:1.35;overflow:hidden;-webkit-line-clamp:2;-webkit-box-orient:vertical}.pay-modern-arrow{position:relative;z-index:1;color:var(--sub);font-size:24px;font-weight:500;line-height:1;text-align:right}.pay-modern-pane{margin-top:10px}.pay-modern-pane .modalCard,.pay-modern-pane .formSection{margin-top:0}.pay-modern-pane>.modalCard{padding:0}@media (max-width: 380px){.pay-modern-shell{padding:12px}.pay-modern-header{grid-template-columns:36px minmax(0,1fr) auto;gap:9px;padding:12px}.pay-modern-back{width:36px;height:36px}.pay-modern-name{font-size:13px}.pay-modern-phone{font-size:10.8px}.pay-modern-badge{min-height:26px;padding:0 8px;font-size:10px}.pay-modern-card{min-height:80px;grid-template-columns:44px minmax(0,1fr) 16px;gap:10px;padding:12px}.pay-modern-icon{width:44px;height:44px;border-radius:15px}.pay-modern-copy strong{font-size:13px}.pay-modern-copy small{font-size:10.8px}}.histTenantModal{width:100%;min-height:100%;background:transparent;border:0;border-radius:0;padding:14px}.histTenantModal .modalScroll{display:flex;flex-direction:column;gap:10px}.histTabs{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:6px;padding:4px;border-radius:var(--r-full);border:1px solid var(--border);background:var(--surface)}.histTabBtn{min-height:36px;border:0;border-radius:var(--r-full);background:transparent;color:var(--sub);font-size:12px;font-weight:850;font-family:var(--font)}.histTabBtn.active{background:var(--indigo);color:#fff}.histBody{display:flex;flex-direction:column;gap:10px}.histSummaryCard{border-radius:var(--r);border:1px solid var(--green-bd);background:radial-gradient(420px 170px at 20% 0%,rgba(52,211,153,.13),transparent 62%),var(--surface);padding:14px}.hsGrid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:8px}.hsItem{min-width:0;border-radius:var(--r-sm);border:1px solid var(--border);background:var(--lift);padding:10px}.hsLabel{color:var(--sub);font-size:9.5px;font-weight:850;line-height:1.2;letter-spacing:.08em;text-transform:uppercase}.hsVal{margin-top:6px;color:var(--text);font-family:var(--mono);font-size:13px;font-weight:900;line-height:1.25;overflow-wrap:anywhere}.hsVal.small{font-size:11.5px}.histFilterBar{margin-top:0!important}.histFilterBar .segmented{display:flex;gap:7px;overflow-x:auto;padding:2px 0 4px;scrollbar-width:none}.histFilterBar .segmented::-webkit-scrollbar{display:none}.histFilterBar .segBtn{flex:0 0 auto;min-height:34px;padding:0 12px;border-radius:var(--r-full);border:1px solid var(--border);background:var(--surface);color:var(--muted);font-size:12px;font-weight:850;font-family:var(--font)}.histFilterBar .segBtn.active{border-color:var(--indigo);background:var(--indigo);color:#fff}.histMonthWrap{display:flex;flex-direction:column;gap:12px}.histMonthGroup{display:flex;flex-direction:column;gap:8px}.histMonthHead{display:flex;align-items:center;gap:8px;padding:2px 2px 0}.histMonthRailSpacer{display:none}.histMonthTitle{min-width:0;display:flex;align-items:flex-end;justify-content:space-between;gap:10px;width:100%}.histMonthTitle>span:first-child{color:var(--text);font-size:14px;font-weight:900;letter-spacing:-.02em}.histMonthTitle .tiny{flex:0 0 auto;color:var(--muted);font-size:10.5px;font-weight:700;white-space:nowrap}.historyTimeline{display:flex;flex-direction:column;gap:10px}.histPayItem{display:grid;grid-template-columns:16px minmax(0,1fr);gap:8px}.histPayRail{position:relative;display:flex;justify-content:center;padding-top:16px}.railDot{width:9px;height:9px;border-radius:var(--r-full);background:var(--indigo);box-shadow:0 0 0 4px var(--indigo-bg)}.railDot.sewa{background:var(--green);box-shadow:0 0 0 4px var(--green-bg)}.railDot.lain{background:var(--blue);box-shadow:0 0 0 4px var(--blue-bg)}.railDot.cicil{background:var(--amber);box-shadow:0 0 0 4px var(--amber-bg)}.railLine{position:absolute;top:27px;bottom:-18px;width:1px;background:var(--divider)}.histPayCard{min-width:0;border-radius:var(--r);border:1px solid var(--border);background:var(--surface);padding:13px;box-shadow:var(--shadow-sm)}.histPayTop{display:flex;align-items:flex-start;justify-content:space-between;gap:12px}.histPayDate{min-width:0}.dateMain{color:var(--text);font-size:13px;font-weight:900;line-height:1.25}.dateSub{margin-top:3px;color:var(--muted);font-size:11px;font-weight:650}.histPayRight{flex:0 0 auto;text-align:right}.histPayAmount{color:var(--green);font-family:var(--mono);font-size:13px;font-weight:950;line-height:1.15;white-space:nowrap}.histPayMetaRow{display:flex;flex-direction:column;gap:10px;margin-top:11px;padding-top:11px;border-top:1px solid var(--divider)}.histPayBadges{display:flex;flex-wrap:wrap;gap:6px}.histPayBadges .badge,.histPaidBadge,.badge.logType{min-height:24px;display:inline-flex;align-items:center;gap:5px;padding:0 9px;border-radius:var(--r-full);border:1px solid var(--border);background:var(--lift);color:var(--muted);font-size:10.5px;font-weight:850}.histPayBadges .badge.sewa,.histPayBadges .badge.ok,.histPaidBadge{border-color:var(--green-bd);background:var(--green-bg);color:var(--green)}.histPayBadges .badge.lain{border-color:var(--blue-bd);background:var(--blue-bg);color:var(--blue)}.histPayBadges .badge.cicil,.histPayBadges .badge.warn{border-color:var(--amber-bd);background:var(--amber-bg);color:var(--amber)}.histPayBadges .badge.danger{border-color:var(--red-bd);background:var(--red-bg);color:var(--red)}.histPayDetails{display:grid;gap:7px}.histKV{display:grid;grid-template-columns:112px minmax(0,1fr);gap:10px;align-items:baseline}.histKVLabel{color:var(--sub);font-size:9.5px;font-weight:850;letter-spacing:.06em;text-transform:uppercase}.histKVValue{min-width:0;color:var(--text);font-size:12.5px;font-weight:750;line-height:1.35;overflow-wrap:anywhere}.histPayNote,.histPayPeriod{margin-top:10px;border-radius:var(--r-sm);border:1px solid var(--border);background:var(--lift);color:var(--muted);padding:10px;font-size:12px;font-weight:650;line-height:1.45}.histPayPeriod{border-color:var(--indigo-bd);background:var(--indigo-bg);color:var(--indigo-lt)}.histProofBtn{width:100%;min-height:54px;display:grid;grid-template-columns:38px minmax(0,1fr) 16px;align-items:center;gap:10px;margin-top:11px;padding:9px 10px;border-radius:var(--r-sm);border:1px solid var(--indigo-bd);background:var(--indigo-bg);color:var(--text);font-family:var(--font);text-align:left}.histProofThumb{width:38px;height:38px;display:grid;place-items:center;border-radius:13px;background:#ffffff0f;border:1px solid rgba(255,255,255,.07)}.histProofIcon{font-size:18px}.histProofText{min-width:0}.proofTitle{color:var(--indigo-lt);font-size:12.5px;font-weight:900;line-height:1.2}.proofSub{margin-top:2px;color:var(--muted);font-size:10.5px;font-weight:650;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.histProofChevron{color:var(--indigo-lt);font-size:22px;line-height:1}.logsCards{display:flex;flex-direction:column;gap:10px}.logCard{border-radius:var(--r);border:1px solid var(--border);background:var(--surface);padding:13px}.logCard-top{display:flex;align-items:center;justify-content:space-between;gap:8px}.logCard-time{color:var(--text);font-size:12px;font-weight:850}.logCard-msg{margin-top:8px;color:var(--text);font-size:13px;font-weight:700;line-height:1.45}.histTenantModal .centerPad{border-radius:var(--r);border:1px dashed var(--border2);background:#ffffff06;padding:22px 16px;text-align:center;color:var(--muted);font-size:13px}.histTenantModal .modalActions.stickyActions{position:sticky;bottom:0;z-index:10;padding:10px 0 calc(10px + env(safe-area-inset-bottom));margin-top:8px;background:linear-gradient(transparent,var(--surface) 32%)}.histTenantModal .modalActions .btn{min-height:42px;border-radius:var(--r-sm);border:1px solid var(--border);background:var(--lift);color:var(--text);font-size:13px;font-weight:850}@media (max-width: 520px){.histTenantModal{padding:12px}.hsGrid{grid-template-columns:1fr}.histMonthTitle{align-items:flex-start;flex-direction:column;gap:3px}.histMonthTitle .tiny{white-space:normal}.histPayItem{grid-template-columns:12px minmax(0,1fr);gap:7px}.histPayCard{padding:12px}.histPayTop{flex-direction:column;gap:7px}.histPayRight{text-align:left}.histPayAmount{font-size:14px}.histKV{grid-template-columns:102px minmax(0,1fr);gap:9px}}@media (max-width: 380px){.histTabs{gap:5px}.histTabBtn{font-size:11px}.histFilterBar .segBtn{padding:0 10px;font-size:11px}.histKV{grid-template-columns:92px minmax(0,1fr)}.histKVValue{font-size:12px}.histProofBtn{grid-template-columns:34px minmax(0,1fr) 14px}.histProofThumb{width:34px;height:34px;border-radius:11px}}.modalBody .modalCard.modalScrollable{width:100%;max-width:100%;background:transparent;border:0;border-radius:0;padding:0}.modalBody .modalCard.modalScrollable .modalScroll{display:flex;flex-direction:column;gap:10px}.exSearchWrap{position:sticky;top:0;z-index:12;display:grid;grid-template-columns:20px minmax(0,1fr) 30px;align-items:center;gap:8px;min-height:46px;border-radius:var(--r);border:1px solid var(--border);background:linear-gradient(180deg,rgba(255,255,255,.035),transparent),var(--surface);padding:0 10px;box-shadow:var(--shadow-sm)}.exSearchIcon{color:var(--sub)}.exSearchInput{width:100%;min-width:0;border:0;outline:0;background:transparent;color:var(--text);font-size:13px;font-weight:700;font-family:var(--font)}.exSearchInput::placeholder{color:var(--dim)}.exSearchClear{width:30px;height:30px;display:grid;place-items:center;border:0;border-radius:var(--r-full);background:var(--lift);color:var(--muted)}.exSearchClear:active{transform:scale(.94)}.exStatsBar{display:grid;grid-template-columns:repeat(3,minmax(0,1fr)) auto;align-items:center;gap:8px;border-radius:var(--r);border:1px solid var(--border);background:var(--surface);padding:10px}.exStatItem{min-width:0}.exStatVal{color:var(--text);font-family:var(--mono);font-size:15px;font-weight:950;line-height:1.1}.exStatLabel{margin-top:4px;color:var(--sub);font-size:9.5px;font-weight:850;letter-spacing:.07em;text-transform:uppercase}.exStatDivider{display:none}.exExportBtn,.exMonthExport{min-height:34px;display:inline-flex;align-items:center;justify-content:center;gap:6px;padding:0 10px;border-radius:var(--r-full);border:1px solid var(--indigo-bd);background:var(--indigo-bg);color:var(--indigo-lt);font-size:11px;font-weight:850;font-family:var(--font);white-space:nowrap}.exExportBtn:disabled{opacity:.55;cursor:not-allowed}.exEmpty{border-radius:var(--r);border:1px dashed var(--border2);background:#ffffff06;padding:28px 18px;text-align:center;color:var(--muted)}.exEmptyTitle{color:var(--text);font-size:14px;font-weight:900}.exEmptySub{margin:5px auto 0;max-width:28ch;color:var(--muted);font-size:12px;line-height:1.45}.exMonthWrap{display:flex;flex-direction:column;gap:13px}.exMonthGroup{display:flex;flex-direction:column;gap:9px}.exMonthHead{display:flex;align-items:center;justify-content:space-between;gap:11px;padding:2px 2px 0}.exMonthHeadLeft{min-width:0;display:flex;align-items:center;gap:7px}.exMonthDot{width:8px;height:8px;flex:0 0 auto;border-radius:var(--r-full);background:var(--indigo);box-shadow:0 0 0 4px var(--indigo-bg)}.exMonthTitle{min-width:0;color:var(--text);font-size:14px;font-weight:900;letter-spacing:-.02em;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.exMonthCount{flex:0 0 auto;min-height:24px;display:inline-flex;align-items:center;padding:0 8px;border-radius:var(--r-full);border:1px solid var(--border);background:var(--lift);color:var(--muted);font-size:10.5px;font-weight:800}.exCards{display:flex;flex-direction:column;gap:10px}.exCard2{position:relative;border-radius:var(--r);border:1px solid var(--border);background:radial-gradient(340px 140px at 10% 0%,rgba(99,102,241,.09),transparent 62%),var(--surface);padding:13px;box-shadow:var(--shadow-sm);overflow:hidden}.exCard2:before{content:"";position:absolute;inset:0 auto 0 0;width:3px;background:var(--indigo);opacity:.72}.exCard2Head{position:relative;z-index:1;display:flex;align-items:flex-start;justify-content:space-between;gap:12px}.exCard2HeadLeft{min-width:0;display:flex;align-items:center;gap:10px}.exCard2Avatar{width:42px;height:42px;flex:0 0 auto;display:grid;place-items:center;border-radius:15px;border:1px solid var(--indigo-bd);background:var(--indigo-bg);color:var(--indigo-lt);font-size:16px;font-weight:950}.exCard2Name{min-width:0;color:var(--text);font-size:14px;font-weight:900;line-height:1.25;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.exCard2Meta{min-width:0;display:flex;align-items:center;gap:6px;margin-top:3px;color:var(--muted);font-family:var(--mono);font-size:11px;font-weight:750}.exCard2Room{color:var(--indigo-lt)}.exCard2Phone{min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.exCard2Sep{color:var(--sub)}.exCard2Total{flex:0 0 auto;color:var(--green);font-family:var(--mono);font-size:13px;font-weight:950;line-height:1.15;white-space:nowrap;text-align:right}.exCard2Dates{position:relative;z-index:1;display:grid;grid-template-columns:minmax(0,1fr) auto minmax(0,1fr);align-items:center;gap:8px;margin-top:12px;padding:10px;border-radius:var(--r-sm);border:1px solid var(--border);background:var(--lift)}.exCard2DateItem{min-width:0}.exCard2DateLabel{color:var(--sub);font-size:9.5px;font-weight:850;letter-spacing:.08em;text-transform:uppercase}.exCard2DateVal{margin-top:4px;color:var(--text);font-size:11.5px;font-weight:800;line-height:1.3;overflow-wrap:anywhere}.exCard2DateArrow{color:var(--sub);font-size:14px;font-weight:800}.exCard2DaysBadge{grid-column:1 / -1;width:fit-content;min-height:24px;display:inline-flex;align-items:center;padding:0 9px;border-radius:var(--r-full);border:1px solid var(--blue-bd);background:var(--blue-bg);color:var(--blue);font-size:11px;font-weight:850}.exCard2Paket{position:relative;z-index:1;display:flex;align-items:center;gap:7px;margin-top:10px;padding:9px 10px;border-radius:var(--r-sm);border:1px solid var(--indigo-bd);background:var(--indigo-bg);color:var(--indigo-lt);font-size:12px;font-weight:750}.exCard2Paket b{color:var(--text)}.exCard2Detail{position:relative;z-index:1;margin-top:10px}.exCard2DetailToggle{width:100%;min-height:38px;display:flex;align-items:center;justify-content:space-between;gap:8px;padding:0 11px;border-radius:var(--r-sm);border:1px solid var(--border);background:var(--lift);color:var(--text);font-size:12px;font-weight:850;font-family:var(--font)}.exPayList2{display:flex;flex-direction:column;gap:7px;margin-top:9px}.exPayRow2{display:grid;grid-template-columns:minmax(0,1fr) auto;gap:10px;align-items:start;padding:9px 10px;border-radius:var(--r-sm);border:1px solid var(--border);background:#ffffff06}.exPayRow2Left{min-width:0;display:flex;align-items:flex-start;gap:8px}.exPayRow2Dot{width:7px;height:7px;flex:0 0 auto;margin-top:5px;border-radius:var(--r-full);background:var(--green);box-shadow:0 0 0 4px var(--green-bg)}.exPayRow2Date{color:var(--text);font-size:12px;font-weight:850;line-height:1.25}.exPayRow2Paket{margin-top:3px;color:var(--muted);font-size:10.5px;font-weight:650}.exPayRow2Amt{color:var(--green);font-family:var(--mono);font-size:12px;font-weight:950;white-space:nowrap}.exPayMore{border-radius:var(--r-sm);border:1px dashed var(--border2);background:#ffffff06;padding:9px;text-align:center;color:var(--muted);font-size:11px;font-weight:750}@media (max-width: 520px){.exStatsBar{grid-template-columns:repeat(3,minmax(0,1fr))}.exExportBtn{grid-column:1 / -1;width:100%}.exMonthHead{align-items:flex-start}.exMonthHeadLeft{flex-wrap:wrap}.exCard2Head{flex-direction:column;gap:9px}.exCard2Total{text-align:left;font-size:14px}.exCard2Dates{grid-template-columns:1fr}.exCard2DateArrow{display:none}.exPayRow2{grid-template-columns:1fr}.exPayRow2Amt{padding-left:15px}}@media (max-width: 380px){.exSearchInput{font-size:12px}.exStatVal{font-size:14px}.exStatLabel{font-size:8.8px}.exMonthTitle{font-size:13px}.exCard2{padding:12px}.exCard2Avatar{width:39px;height:39px;border-radius:14px}.exCard2Name{font-size:13px}.exCard2Meta{font-size:10.5px}}.maintenance-modern-page{padding-top:0}.maintenance-app-header{position:relative;top:auto;z-index:1;padding:0 0 4px;background:transparent;backdrop-filter:none;-webkit-backdrop-filter:none}.maintenance-report-btn{min-width:74px}.maintenance-summary-modern{margin-bottom:10px}.maintenance-stat-grid-modern{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:8px;margin-top:14px}.maintenance-stat-grid-modern .m-stat{min-width:0;min-height:78px;display:flex;flex-direction:column;gap:7px;border-radius:var(--r-sm);border:1px solid var(--border);background:var(--lift);padding:10px 8px}.maintenance-stat-grid-modern .m-stat__icon{width:28px;height:28px;display:grid;place-items:center;border-radius:10px;background:#ffffff0d;color:var(--text)}.maintenance-stat-grid-modern .m-stat__body{min-width:0}.maintenance-stat-grid-modern .m-stat__value{color:var(--text);font-family:var(--mono);font-size:16px;font-weight:950;line-height:1}.maintenance-stat-grid-modern .m-stat__label{margin-top:4px;color:var(--sub);font-size:9px;font-weight:850;letter-spacing:.06em;text-transform:uppercase;line-height:1.2}.maintenance-section-modern{display:flex;flex-direction:column;gap:10px;margin-top:10px}.maintenance-section-head-modern{display:flex;align-items:center;justify-content:space-between;gap:12px;padding:2px 2px 0}.maintenance-list-modern{display:flex;flex-direction:column;gap:10px}.maintenance-skeleton-modern{min-height:112px;display:flex;flex-direction:column;gap:10px}.m-section.vendors{margin-top:10px}.m-section.vendors .m-section-head{display:none}.m-vendor-list{display:flex;flex-direction:column;gap:10px}.m-vendor-card{border-radius:var(--r);border:1px solid var(--border);background:var(--surface);padding:13px;box-shadow:var(--shadow-sm)}.m-vendor-main{display:flex;align-items:center;gap:11px}.m-vendor-avatar{width:42px;height:42px;display:grid;place-items:center;flex:0 0 auto;border-radius:15px;border:1px solid var(--indigo-bd);background:var(--indigo-bg);color:var(--indigo-lt);font-weight:950}.m-vendor-name{color:var(--text);font-size:13.5px;font-weight:900;line-height:1.2}.m-vendor-job{margin-top:3px;color:var(--muted);font-size:11.5px;font-weight:650}.m-vendor-phone{display:flex;align-items:center;gap:5px;margin-top:6px;color:var(--sub);font-family:var(--mono);font-size:11px;font-weight:750}.m-vendor-card{display:flex;align-items:center;justify-content:space-between;gap:12px}.m-mini-icon.wa{width:34px;height:34px;display:grid;place-items:center;border-radius:var(--r-full);border:1px solid var(--green-bd);background:var(--green-bg);color:var(--green)}.m-room-list,.m-list{display:flex;flex-direction:column;gap:10px}.m-room-card{border-radius:var(--r);border:1px solid var(--border);background:radial-gradient(360px 150px at 10% 0%,rgba(99,102,241,.09),transparent 62%),var(--surface);padding:13px;box-shadow:var(--shadow-sm)}.m-room-card.ruko{border-color:var(--blue-bd)}.m-room-card__top,.m-room-main{display:flex;align-items:center;gap:10px}.m-room-icon{width:38px;height:38px;display:grid;place-items:center;border-radius:14px;border:1px solid var(--border);background:var(--lift);color:var(--indigo-lt)}.m-room-title{color:var(--text);font-size:14px;font-weight:900;line-height:1.2}.m-room-sub{margin-top:3px;color:var(--muted);font-size:11.5px;font-weight:650}.m-room-history-btn{width:100%;min-height:36px;display:inline-flex;align-items:center;justify-content:center;gap:7px;margin-top:12px;border-radius:var(--r-sm);border:1px solid var(--indigo-bd);background:var(--indigo-bg);color:var(--indigo-lt);font-size:12px;font-weight:850;font-family:var(--font)}.m-routine-grid{display:flex;flex-direction:column;gap:8px;margin-top:12px}.m-routine-meta{display:grid;grid-template-columns:32px minmax(0,1fr);gap:9px;align-items:start;border-radius:var(--r-sm);border:1px solid var(--border);background:var(--lift);padding:10px}.m-routine-meta__icon{width:32px;height:32px;display:grid;place-items:center;border-radius:11px;background:#ffffff0d;color:var(--text)}.m-routine-meta__text{min-width:0}.m-routine-meta__text span{color:var(--sub);font-size:10px;font-weight:850;letter-spacing:.06em;text-transform:uppercase}.m-routine-meta__text strong{display:block;margin-top:4px;color:var(--text);font-size:12.5px;font-weight:850}.m-routine-next{display:flex;flex-wrap:wrap;gap:6px;margin-top:7px}.m-routine-next em{color:var(--muted);font-size:11px;font-style:normal;font-weight:650}.m-next-badge{min-height:22px;display:inline-flex;align-items:center;padding:0 8px;border-radius:var(--r-full);border:1px solid var(--border);background:var(--surface);color:var(--muted);font-size:10.5px;font-weight:850}.m-next-badge.safe{border-color:var(--green-bd);background:var(--green-bg);color:var(--green)}.m-next-badge.soon{border-color:var(--amber-bd);background:var(--amber-bg);color:var(--amber)}.m-next-badge.late{border-color:var(--red-bd);background:var(--red-bg);color:var(--red)}.m-room-actions{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:8px;margin-top:12px}.m-routine-btn{min-height:38px;display:inline-flex;align-items:center;justify-content:center;gap:7px;border-radius:var(--r-sm);border:1px solid var(--border);background:var(--lift);color:var(--text);font-family:var(--font);font-size:11.5px;font-weight:850}.m-routine-btn.ac{border-color:var(--indigo-bd);background:var(--indigo-bg);color:var(--indigo-lt)}.m-routine-btn.room{border-color:var(--green-bd);background:var(--green-bg);color:var(--green)}.m-routine-btn.water{border-color:var(--blue-bd);background:var(--blue-bg);color:var(--blue)}.m-routine-btn.battery{border-color:var(--amber-bd);background:var(--amber-bg);color:var(--amber)}.m-card{border-radius:var(--r);border:1px solid var(--border);background:var(--surface);padding:13px;box-shadow:var(--shadow-sm)}.m-card--red{border-color:var(--red-bd)}.m-card--amber{border-color:var(--amber-bd)}.m-card--green{border-color:var(--green-bd)}.m-card__head{display:flex;align-items:center;justify-content:space-between;gap:12px}.m-card__head-left,.m-card__head-right{display:flex;align-items:center;gap:8px;min-width:0}.m-badge{min-height:24px;display:inline-flex;align-items:center;gap:5px;padding:0 9px;border-radius:var(--r-full);border:1px solid var(--border);background:var(--lift);color:var(--muted);font-size:10.5px;font-weight:850}.m-badge--red{border-color:var(--red-bd);background:var(--red-bg);color:var(--red)}.m-badge--amber{border-color:var(--amber-bd);background:var(--amber-bg);color:var(--amber)}.m-badge--green{border-color:var(--green-bd);background:var(--green-bg);color:var(--green)}.m-card__kamar{color:var(--muted);font-family:var(--mono);font-size:11.5px;font-weight:850}.m-card__biaya{color:var(--green);font-family:var(--mono);font-size:12px;font-weight:950;white-space:nowrap}.m-card__judul{margin-top:10px;color:var(--text);font-size:14px;font-weight:900;line-height:1.3}.m-card__detail{margin-top:12px;padding-top:12px;border-top:1px solid var(--divider)}.m-card__desc{margin:0 0 10px;color:var(--muted);font-size:12.5px;line-height:1.45}.m-card__meta{display:grid;gap:7px}.m-card__meta span{display:flex;align-items:center;gap:6px;color:var(--muted);font-size:11.5px;font-weight:650;line-height:1.35}.m-card__ledger{color:var(--green)!important}.m-proof-link{width:100%;min-height:40px;display:inline-flex;align-items:center;justify-content:center;gap:7px;margin-top:11px;border-radius:var(--r-sm);border:1px solid var(--indigo-bd);background:var(--indigo-bg);color:var(--indigo-lt);text-decoration:none;font-size:12px;font-weight:850}.m-card__actions{display:flex;flex-wrap:wrap;gap:8px;margin-top:12px}.m-btn{min-height:36px;display:inline-flex;align-items:center;justify-content:center;gap:7px;padding:0 11px;border-radius:var(--r-full);border:1px solid var(--border);background:var(--lift);color:var(--text);font-size:12px;font-weight:850;font-family:var(--font)}.m-btn--amber{border-color:var(--amber-bd);background:var(--amber-bg);color:var(--amber)}.m-btn--green,.m-btn--primary{border-color:var(--green-bd);background:var(--green-bg);color:var(--green)}.m-btn--ghost{border-color:var(--border);background:var(--lift);color:var(--muted)}@media (max-width: 520px){.maintenance-stat-grid-modern{grid-template-columns:repeat(4,minmax(0,1fr));gap:7px}.maintenance-stat-grid-modern .m-stat{padding:9px 6px}.maintenance-stat-grid-modern .m-stat__label{font-size:8px}.maintenance-stat-grid-modern .m-stat__value{font-size:14px}.m-room-actions{grid-template-columns:1fr}}@media (max-width: 380px){.maintenance-report-btn{min-width:44px;padding:0 10px}.maintenance-report-btn svg{display:none}.m-card__head{align-items:flex-start}.m-card__head-right{flex-direction:column;align-items:flex-end;gap:5px}}.inventory-modern-page{padding-top:0}.inventory-app-header{position:relative;top:auto;z-index:1;padding:0 0 4px;background:transparent;backdrop-filter:none;-webkit-backdrop-filter:none}.inventory-summary-modern{margin-bottom:10px;border-color:var(--blue-bd);background:radial-gradient(420px 170px at 20% 0%,rgba(96,165,250,.13),transparent 62%),var(--surface)}.inventory-modern-page.ip-wrap{max-width:480px;margin:0 auto;padding-left:16px;padding-right:16px;padding-bottom:calc(96px + env(safe-area-inset-bottom))}.inventory-modern-page .ip-floor-section{margin:0 0 8px}.inventory-modern-page .ip-floor-label{margin:0 0 6px 2px;color:var(--sub);font-size:10px;font-weight:850;letter-spacing:.09em;text-transform:uppercase}.inventory-modern-page .ip-room-bar{display:flex;gap:7px;overflow-x:auto;padding:0 0 4px;scrollbar-width:none}.inventory-modern-page .ip-room-bar::-webkit-scrollbar{display:none}.inventory-modern-page .ip-room-btn{flex:0 0 auto;min-height:34px;padding:0 12px;border-radius:var(--r-full);border:1px solid var(--border);background:var(--surface);color:var(--muted);font-size:12px;font-weight:850;font-family:var(--font)}.inventory-modern-page .ip-room-btn.active{border-color:var(--indigo);background:var(--indigo);color:#fff}.inventory-modern-page .ip-room-btn.all-btn.active{border-color:var(--blue);background:var(--blue);color:#fff}.inventory-modern-page .ip-search-wrap{position:relative;display:grid;grid-template-columns:18px minmax(0,1fr);align-items:center;gap:8px;min-height:44px;margin:10px 0;padding:0 13px;border-radius:var(--r-sm);border:1px solid var(--border2);background:var(--lift)}.inventory-modern-page .ip-search-icon{display:grid;place-items:center;color:var(--sub)}.inventory-modern-page .ip-search{width:100%;min-width:0;border:0;outline:0;background:transparent;color:var(--text);font-size:13px;font-weight:700;font-family:var(--font)}.inventory-modern-page .ip-search::placeholder{color:var(--dim)}.inventory-list-modern{display:flex;flex-direction:column;gap:10px}.inventory-skeleton-modern{min-height:112px;display:flex;flex-direction:column;gap:10px}.inventory-modern-page .ip-room-block{border-radius:var(--r);border:1px solid var(--border);background:radial-gradient(360px 150px at 10% 0%,rgba(96,165,250,.09),transparent 62%),var(--surface);padding:13px;margin:0 0 10px;box-shadow:var(--shadow-sm)}.inventory-modern-page .ip-room-hdr{display:flex;align-items:flex-start;justify-content:space-between;gap:12px;margin-bottom:12px}.inventory-modern-page .ip-room-hdr-left{min-width:0}.inventory-modern-page .ip-room-name{margin:0;color:var(--text);font-size:15px;font-weight:900;line-height:1.2;letter-spacing:-.03em}.inventory-modern-page .ip-room-meta{margin-top:5px;color:var(--muted);font-size:11.5px;font-weight:650;line-height:1.35}.inventory-modern-page .ip-add-btn{min-height:32px;flex:0 0 auto;display:inline-flex;align-items:center;gap:6px;padding:0 10px;border-radius:var(--r-full);border:1px solid var(--green-bd);background:var(--green-bg);color:var(--green);font-size:11.5px;font-weight:850;font-family:var(--font)}.inventory-modern-page .ip-add-btn:active{transform:scale(.96)}.inventory-modern-page .ip-item-list{display:flex;flex-direction:column;gap:9px}.inventory-modern-page .ip-item{border-radius:var(--r-sm);border:1px solid var(--border);background:var(--lift);padding:12px}.inventory-modern-page .ip-item-top{display:flex;align-items:flex-start;justify-content:space-between;gap:10px}.inventory-modern-page .ip-item-left{min-width:0}.inventory-modern-page .ip-item-name{color:var(--text);font-size:13.5px;font-weight:900;line-height:1.25;overflow-wrap:anywhere}.inventory-modern-page .ip-item-name[role=button]{cursor:pointer}.inventory-modern-page .ip-kondisi-badge{min-height:23px;display:inline-flex;align-items:center;width:fit-content;margin-top:7px;padding:0 8px;border-radius:var(--r-full);border:1px solid var(--border);font-size:10.5px;font-weight:850}.inventory-modern-page .ip-item-thumb{width:48px;height:48px;flex:0 0 auto;object-fit:cover;border-radius:15px;border:1px solid var(--border);background:var(--surface)}.inventory-modern-page .ip-item-fields{display:grid;gap:7px;margin-top:11px;padding-top:11px;border-top:1px solid var(--divider)}.inventory-modern-page .ip-field{display:grid;grid-template-columns:92px minmax(0,1fr);gap:10px;align-items:baseline}.inventory-modern-page .ip-field-label{color:var(--sub);font-size:9.5px;font-weight:850;letter-spacing:.06em;text-transform:uppercase}.inventory-modern-page .ip-field-value{min-width:0;color:var(--text);font-size:12.5px;font-weight:750;line-height:1.35;overflow-wrap:anywhere}.inventory-modern-page .ip-field-value.muted{color:var(--muted)}.inventory-modern-page .ip-item-footer{display:flex;justify-content:flex-end;margin-top:11px}.inventory-modern-page .ip-edit-btn{min-height:32px;padding:0 11px;border-radius:var(--r-full);border:1px solid var(--indigo-bd);background:var(--indigo-bg);color:var(--indigo-lt);font-size:11.5px;font-weight:850;font-family:var(--font)}.inventory-empty-room{margin-top:8px}.inventory-modern-page .ip-toast{position:fixed;left:50%;bottom:calc(86px + env(safe-area-inset-bottom));z-index:80;width:min(440px,calc(100vw - 28px));transform:translate(-50%);display:flex;align-items:center;justify-content:space-between;gap:10px;border-radius:var(--r);border:1px solid var(--border2);background:var(--surface);color:var(--text);box-shadow:var(--shadow);padding:11px 12px;font-size:12px}.inventory-modern-page .ip-undo-btn{min-height:30px;padding:0 10px;border-radius:var(--r-full);border:1px solid var(--indigo-bd);background:var(--indigo-bg);color:var(--indigo-lt);font-size:11px;font-weight:850;font-family:var(--font)}.inventory-modern-page .ip-modal-backdrop,.ip-modal-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;z-index:1000;display:flex;align-items:center;justify-content:center;padding:14px;background:#000000a8;backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px)}.inventory-modern-page .ip-modal,.ip-modal{width:min(94vw,520px);max-height:min(88dvh,760px);display:flex;flex-direction:column;overflow:hidden;border-radius:var(--r);border:1px solid var(--border);background:radial-gradient(520px 220px at 15% 0%,rgba(96,165,250,.11),transparent 62%),var(--surface);color:var(--text);box-shadow:var(--shadow)}.inventory-modern-page .ip-modal-hdr,.ip-modal-hdr{flex:0 0 auto;display:flex;align-items:center;justify-content:space-between;gap:12px;padding:15px 16px 13px;border-bottom:1px solid var(--divider)}.inventory-modern-page .ip-modal-eyebrow,.ip-modal-eyebrow{margin-bottom:3px;color:var(--blue);font-size:10px;font-weight:850;letter-spacing:.11em;text-transform:uppercase}.inventory-modern-page .ip-modal-title,.ip-modal-title{margin:0;color:var(--text);font-size:16px;font-weight:900;line-height:1.15;letter-spacing:-.03em}.inventory-modern-page .ip-modal-close,.ip-modal-close{min-height:34px;padding:0 11px;border-radius:var(--r-full);border:1px solid var(--border);background:var(--lift);color:var(--muted);font-size:12px;font-weight:850;font-family:var(--font)}.inventory-modern-page .ip-modal-fields,.ip-modal-fields{flex:1 1 auto;min-height:0;overflow-y:auto;display:flex;flex-direction:column;gap:10px;padding:14px}.inventory-modern-page .ip-field-group,.ip-field-group{display:flex;flex-direction:column;gap:6px}.inventory-modern-page .ip-field-group label,.ip-field-group label{color:var(--sub);font-size:11px;font-weight:800}.inventory-modern-page .ip-input,.ip-input{width:100%;min-height:44px;padding:0 13px;border-radius:var(--r-sm);border:1px solid var(--border2);background:var(--lift);color:var(--text);font-size:14px;font-family:var(--font);outline:none}.inventory-modern-page .ip-input:focus,.ip-input:focus{border-color:var(--indigo-bd);box-shadow:0 0 0 3px var(--indigo-bg)}.inventory-modern-page .ip-photo-btn,.ip-photo-btn{min-height:42px;border-radius:var(--r-sm);border:1px dashed var(--border2);background:var(--lift);color:var(--text);font-size:13px;font-weight:800;font-family:var(--font)}.inventory-modern-page .ip-photo-preview,.ip-photo-preview{display:block;width:100%;max-height:220px;object-fit:cover;border-radius:var(--r-sm);border:1px solid var(--border);background:var(--lift)}.inventory-modern-page .ip-qty-row,.ip-qty-row{display:grid;grid-template-columns:44px minmax(0,1fr) 44px;gap:8px}.inventory-modern-page .ip-qty-stepper,.ip-qty-stepper{min-height:44px;border-radius:var(--r-sm);border:1px solid var(--border);background:var(--lift);color:var(--text);font-size:18px;font-weight:900}.inventory-modern-page .ip-qty-stepper.plus,.ip-qty-stepper.plus{border-color:var(--green-bd);background:var(--green-bg);color:var(--green)}.inventory-modern-page .ip-qty-stepper.minus,.ip-qty-stepper.minus{border-color:var(--red-bd);background:var(--red-bg);color:var(--red)}.inventory-modern-page .ip-qty-input,.ip-qty-input{width:100%;min-height:44px;border-radius:var(--r-sm);border:1px solid var(--border2);background:var(--lift);color:var(--text);text-align:center;font-family:var(--mono);font-size:16px;font-weight:900}.inventory-modern-page .ip-modal-actions,.ip-modal-actions{flex:0 0 auto;display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:8px;padding:12px 14px calc(12px + env(safe-area-inset-bottom));border-top:1px solid var(--divider);background:var(--surface)}.inventory-modern-page .ip-btn,.ip-btn{min-height:42px;border-radius:var(--r-sm);border:1px solid var(--border);background:var(--lift);color:var(--text);font-size:13px;font-weight:850;font-family:var(--font)}.inventory-modern-page .ip-btn-primary,.ip-btn-primary{border-color:var(--green-bd);background:linear-gradient(135deg,var(--green),#059669);color:#fff}.inventory-modern-page .ip-btn-danger,.ip-btn-danger{border-color:var(--red-bd);background:var(--red-bg);color:var(--red)}.inventory-modern-page .ip-photo-viewer,.ip-photo-viewer{position:fixed;top:0;right:0;bottom:0;left:0;z-index:1200;display:flex;align-items:center;justify-content:center;padding:14px;background:#000000b8;backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px)}.inventory-modern-page .ip-photo-viewer-inner,.ip-photo-viewer-inner{width:min(94vw,560px);max-height:88dvh;border-radius:var(--r);border:1px solid var(--border);background:var(--surface);overflow:hidden;box-shadow:var(--shadow)}.inventory-modern-page .ip-photo-viewer-hdr,.ip-photo-viewer-hdr{display:flex;align-items:center;justify-content:space-between;gap:12px;padding:12px 14px;border-bottom:1px solid var(--divider)}.inventory-modern-page .ip-photo-viewer-name,.ip-photo-viewer-name{min-width:0;color:var(--text);font-size:13px;font-weight:850;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.inventory-modern-page .ip-photo-viewer-inner img,.ip-photo-viewer-inner img{display:block;width:100%;max-height:calc(88dvh - 58px);object-fit:contain;background:#000}@media (max-width: 520px){.inventory-modern-page.ip-wrap{padding-left:16px;padding-right:16px}.inventory-modern-page .ip-room-hdr{align-items:flex-start}.inventory-modern-page .ip-field{grid-template-columns:86px minmax(0,1fr)}.inventory-modern-page .ip-modal-backdrop,.ip-modal-backdrop{padding:0;align-items:stretch;justify-content:stretch}.inventory-modern-page .ip-modal,.ip-modal{width:100%;max-height:100dvh;border-radius:0;border-left:0;border-right:0}}@media (max-width: 380px){.inventory-modern-page.ip-wrap{padding-left:12px;padding-right:12px}.inventory-modern-page .ip-room-block{padding:12px}.inventory-modern-page .ip-room-meta{font-size:10.8px}.inventory-modern-page .ip-field{grid-template-columns:78px minmax(0,1fr)}.inventory-modern-page .ip-field-value{font-size:12px}}.utilities-modern-page{padding-top:0}.utilities-modern-page.ut2-page{max-width:480px;margin:0 auto;padding-left:16px;padding-right:16px;padding-bottom:calc(96px + env(safe-area-inset-bottom))}.utilities-app-header{position:relative;top:auto;z-index:1;padding:0 0 4px;background:transparent;backdrop-filter:none;-webkit-backdrop-filter:none}.utilities-summary-modern{margin-bottom:10px;border-color:var(--blue-bd);background:radial-gradient(420px 170px at 20% 0%,rgba(96,165,250,.13),transparent 62%),var(--surface)}.utilities-modern-page .ut2-nav-wrap{display:flex;flex-direction:column;gap:8px;margin:0 0 10px}.utilities-modern-page .ut2-nav-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:8px}.utilities-modern-page .ut2-nav-panel{border-radius:var(--r);border:1px solid var(--border);background:var(--surface);padding:10px}.utilities-modern-page .ut2-nav-panel-label{margin-bottom:8px;color:var(--sub);font-size:9.5px;font-weight:850;letter-spacing:.08em;text-transform:uppercase}.utilities-modern-page .ut2-nav-rooms,.utilities-modern-page .ut2-nav-bottom{display:flex;flex-wrap:wrap;gap:7px}.utilities-modern-page .ut2-nav-bottom{padding:0}.utilities-modern-page .ut2-nav-btn{flex:0 0 auto;min-height:32px;min-width:34px;padding:0 11px;border-radius:var(--r-full);border:1px solid var(--border);background:var(--lift);color:var(--muted);font-size:12px;font-weight:850;font-family:var(--font)}.utilities-modern-page .ut2-nav-btn.big{min-width:72px}.utilities-modern-page .ut2-nav-btn.active{border-color:var(--blue);background:var(--blue);color:#fff}.utilities-list-modern{display:flex;flex-direction:column;gap:10px}.utilities-skeleton-modern{min-height:112px;display:flex;flex-direction:column;gap:10px}.utilities-modern-page .ut2-grid{display:flex;flex-direction:column;gap:10px}.utilities-modern-page .ut2-card{border-radius:var(--r);border:1px solid var(--border);background:radial-gradient(360px 150px at 10% 0%,rgba(96,165,250,.09),transparent 62%),var(--surface);padding:13px;box-shadow:var(--shadow-sm)}.utilities-modern-page .ut2-card.has-data{border-color:var(--blue-bd)}.utilities-modern-page .ut2-card-head{display:flex;align-items:flex-start;justify-content:space-between;gap:12px;margin-bottom:11px}.utilities-modern-page .ut2-card-name{margin:0;color:var(--text);font-size:15px;font-weight:900;line-height:1.2;letter-spacing:-.03em}.utilities-modern-page .ut2-card-date{margin-top:5px;color:var(--muted);font-size:11.5px;font-weight:650}.utilities-modern-page .ut2-status-badge{flex:0 0 auto;min-height:25px;display:inline-flex;align-items:center;padding:0 9px;border-radius:var(--r-full);border:1px solid var(--border);background:var(--lift);color:var(--muted);font-size:10.5px;font-weight:850;white-space:nowrap}.utilities-modern-page .ut2-status-badge.filled{border-color:var(--green-bd);background:var(--green-bg);color:var(--green)}.utilities-modern-page .ut2-status-badge.empty{color:var(--sub)}.utilities-modern-page .ut2-field-card{--fc-color: var(--blue);--fc-glow: rgba(96,165,250,.12);border-radius:var(--r-sm);border:1px solid color-mix(in srgb,var(--fc-color) 32%,var(--border));background:radial-gradient(160px 85px at 0% 0%,var(--fc-glow),transparent 72%),var(--lift);padding:11px;margin-top:8px}.utilities-modern-page .ut2-fc-head{display:flex;align-items:center;justify-content:space-between;gap:8px}.utilities-modern-page .ut2-fc-label{display:inline-flex;align-items:center;gap:7px;color:var(--text);font-size:11px;font-weight:850;letter-spacing:.07em;text-transform:uppercase}.utilities-modern-page .ut2-fc-icon{width:24px;height:24px;display:grid;place-items:center;border-radius:9px;background:#ffffff0e;color:var(--fc-color)}.utilities-modern-page .ut2-copy-btn{min-height:26px;display:inline-flex;align-items:center;gap:5px;padding:0 8px;border-radius:var(--r-full);border:1px solid var(--border);background:var(--surface);color:var(--muted);font-size:10.5px;font-weight:850;font-family:var(--font)}.utilities-modern-page .ut2-fc-value{margin-top:9px;color:var(--text);font-family:var(--mono);font-size:14px;font-weight:900;line-height:1.25;overflow-wrap:anywhere}.utilities-modern-page .ut2-fc-value.empty{color:var(--sub);font-family:var(--font);font-size:12px;font-weight:700}.utilities-modern-page .ut2-ellipsis{overflow-wrap:anywhere}.utilities-modern-page .ut2-card-photo{position:relative;margin-top:8px;border-radius:var(--r-sm);border:1px solid var(--border);background:var(--lift);overflow:hidden}.utilities-modern-page .ut2-card-photo img{display:block;width:100%;max-height:180px;object-fit:cover}.utilities-modern-page .ut2-photo-tag{position:absolute;left:8px;top:8px;z-index:1;min-height:23px;display:inline-flex;align-items:center;padding:0 8px;border-radius:var(--r-full);background:#020617b8;color:#fff;font-size:10px;font-weight:850}.utilities-modern-page .ut2-reminder-box{display:flex;flex-direction:column;gap:7px;margin-top:10px;padding-top:10px;border-top:1px solid var(--divider)}.utilities-modern-page .ut2-reminder-row{display:flex;align-items:flex-start;justify-content:space-between;gap:10px;border-radius:var(--r-sm);border:1px solid var(--border);background:#ffffff06;padding:9px 10px}.utilities-modern-page .ut2-rr-left,.utilities-modern-page .ut2-rr-right{min-width:0}.utilities-modern-page .ut2-rr-label{color:var(--text);font-size:12px;font-weight:850}.utilities-modern-page .ut2-rr-day{margin-top:3px;color:var(--muted);font-size:10.5px;font-weight:650}.utilities-modern-page .ut2-rr-right{text-align:right}.utilities-modern-page .ut2-rr-next,.utilities-modern-page .ut2-rr-avg{color:var(--sub);font-size:10.5px;font-weight:700;line-height:1.35}.utilities-modern-page .ut2-edit-btn{width:100%;min-height:38px;display:inline-flex;align-items:center;justify-content:center;gap:7px;margin-top:12px;border-radius:var(--r-sm);border:1px solid var(--indigo-bd);background:var(--indigo-bg);color:var(--indigo-lt);font-size:12px;font-weight:850;font-family:var(--font)}.utilities-modern-page .ut2-toast{position:fixed;left:50%;bottom:calc(86px + env(safe-area-inset-bottom));z-index:90;transform:translate(-50%);min-height:38px;display:grid;place-items:center;padding:0 14px;border-radius:var(--r-full);border:1px solid var(--green-bd);background:var(--green-bg);color:var(--green);font-size:12px;font-weight:850;box-shadow:var(--shadow)}.utilities-modern-page .ut2-modal-backdrop,.ut2-modal-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;z-index:1000;display:flex;align-items:center;justify-content:center;padding:14px;background:#000000a8;backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px)}.utilities-modern-page .ut2-modal,.ut2-modal{width:min(94vw,520px);max-height:min(88dvh,760px);display:flex;flex-direction:column;overflow-y:auto;border-radius:var(--r);border:1px solid var(--border);background:radial-gradient(520px 220px at 15% 0%,rgba(96,165,250,.11),transparent 62%),var(--surface);color:var(--text);box-shadow:var(--shadow);padding-bottom:env(safe-area-inset-bottom)}.utilities-modern-page .ut2-modal-hdr,.ut2-modal-hdr{position:sticky;top:0;z-index:4;display:flex;align-items:center;justify-content:space-between;gap:12px;padding:15px 16px 13px;border-bottom:1px solid var(--divider);background:var(--surface)}.utilities-modern-page .ut2-modal-eyebrow,.ut2-modal-eyebrow{margin-bottom:3px;color:var(--blue);font-size:10px;font-weight:850;letter-spacing:.11em;text-transform:uppercase}.utilities-modern-page .ut2-modal-title,.ut2-modal-title{margin:0;color:var(--text);font-size:16px;font-weight:900;line-height:1.15;letter-spacing:-.03em}.utilities-modern-page .ut2-modal-close,.ut2-modal-close{min-height:34px;display:inline-flex;align-items:center;gap:6px;padding:0 11px;border-radius:var(--r-full);border:1px solid var(--border);background:var(--lift);color:var(--muted);font-size:12px;font-weight:850;font-family:var(--font)}.utilities-modern-page .ut2-modal-meter-section,.ut2-modal-meter-section,.utilities-modern-page .ut2-modal-section,.ut2-modal-section{margin:12px 14px 0;border-radius:var(--r);border:1px solid var(--border);background:var(--surface);padding:13px}.utilities-modern-page .ut2-mms-head,.ut2-mms-head{display:flex;align-items:center;gap:8px;margin-bottom:10px}.utilities-modern-page .ut2-mms-icon,.ut2-mms-icon{width:28px;height:28px;display:grid;place-items:center;border-radius:10px;background:#ffffff0e;color:var(--ms-color, var(--blue))}.utilities-modern-page .ut2-mms-label,.ut2-mms-label,.utilities-modern-page .ut2-modal-section-title,.ut2-modal-section-title{color:var(--sub);font-size:10px;font-weight:850;letter-spacing:.08em;text-transform:uppercase}.utilities-modern-page .ut2-input,.ut2-input{width:100%;min-height:44px;padding:0 13px;border-radius:var(--r-sm);border:1px solid var(--border2);background:var(--lift);color:var(--text);font-size:14px;font-family:var(--font);outline:none}.utilities-modern-page .ut2-input:focus,.ut2-input:focus{border-color:var(--indigo-bd);box-shadow:0 0 0 3px var(--indigo-bg)}.utilities-modern-page .ut2-input.invalid,.ut2-input.invalid{border-color:var(--red-bd);box-shadow:0 0 0 3px var(--red-bg)}.utilities-modern-page .ut2-error,.ut2-error{margin-top:7px;color:var(--red);font-size:11px;font-weight:750}.utilities-modern-page .ut2-photo-section,.ut2-photo-section{margin-top:10px}.utilities-modern-page .ut2-photo-section-label,.ut2-photo-section-label{margin-bottom:7px;color:var(--sub);font-size:10.5px;font-weight:800}.utilities-modern-page .ut2-upload-row,.ut2-upload-row{display:flex;gap:8px}.utilities-modern-page .ut2-file-label,.ut2-file-label,.utilities-modern-page .ut2-clear-btn,.ut2-clear-btn{min-height:36px;display:inline-flex;align-items:center;justify-content:center;gap:7px;padding:0 11px;border-radius:var(--r-sm);border:1px solid var(--border);background:var(--lift);color:var(--text);font-size:12px;font-weight:850;font-family:var(--font)}.utilities-modern-page .ut2-clear-btn,.ut2-clear-btn{border-color:var(--red-bd);background:var(--red-bg);color:var(--red)}.utilities-modern-page .ut2-photo-thumb,.ut2-photo-thumb{position:relative;margin-top:9px;border-radius:var(--r-sm);border:1px solid var(--border);background:var(--lift);overflow:hidden}.utilities-modern-page .ut2-photo-thumb img,.ut2-photo-thumb img{display:block;width:100%;max-height:180px;object-fit:cover}.utilities-modern-page .ut2-modal-row,.ut2-modal-row{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:8px}.utilities-modern-page .ut2-modal-field,.ut2-modal-field{min-width:0}.utilities-modern-page .ut2-modal-field label,.ut2-modal-field label{display:block;margin-bottom:6px;color:var(--sub);font-size:11px;font-weight:800}.utilities-modern-page .ut2-mini,.ut2-mini{margin-top:5px;color:var(--muted);font-size:10.5px;font-weight:650}.utilities-modern-page .ut2-modal-actions,.ut2-modal-actions{position:sticky;bottom:0;z-index:5;display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:8px;padding:12px 14px calc(12px + env(safe-area-inset-bottom));margin-top:10px;border-top:1px solid var(--divider);background:var(--surface)}.utilities-modern-page .ut2-btn,.ut2-btn{min-height:42px;border-radius:var(--r-sm);border:1px solid var(--border);background:var(--lift);color:var(--text);font-size:13px;font-weight:850;font-family:var(--font)}.utilities-modern-page .ut2-btn.primary,.ut2-btn.primary{border-color:var(--green-bd);background:linear-gradient(135deg,var(--green),#059669);color:#fff}.utilities-modern-page .ut2-btn:disabled,.ut2-btn:disabled{opacity:.65;cursor:not-allowed}.utilities-modern-page .ut2-preview-backdrop,.ut2-preview-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;z-index:1200;display:flex;align-items:center;justify-content:center;padding:14px;background:#000000b8;backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px)}.utilities-modern-page .ut2-preview,.ut2-preview{width:min(94vw,560px);max-height:88dvh;border-radius:var(--r);border:1px solid var(--border);background:var(--surface);overflow:hidden;box-shadow:var(--shadow)}.utilities-modern-page .ut2-preview-head,.ut2-preview-head{display:flex;align-items:center;justify-content:space-between;gap:11px;padding:12px 14px;border-bottom:1px solid var(--divider)}.utilities-modern-page .ut2-preview-title,.ut2-preview-title{min-width:0;color:var(--text);font-size:13px;font-weight:850;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.utilities-modern-page .ut2-preview-close,.ut2-preview-close{min-height:32px;display:inline-flex;align-items:center;gap:6px;padding:0 10px;border-radius:var(--r-full);border:1px solid var(--border);background:var(--lift);color:var(--muted);font-size:12px;font-weight:850;font-family:var(--font)}.utilities-modern-page .ut2-preview img,.ut2-preview img{display:block;width:100%;max-height:calc(88dvh - 58px);object-fit:contain;background:#000}@media (max-width: 520px){.utilities-modern-page.ut2-page{padding-left:16px;padding-right:16px}.utilities-modern-page .ut2-nav-grid{grid-template-columns:1fr}.utilities-modern-page .ut2-card-head{align-items:flex-start}.utilities-modern-page .ut2-reminder-row{flex-direction:column;gap:5px}.utilities-modern-page .ut2-rr-right{text-align:left}.utilities-modern-page .ut2-modal-backdrop,.ut2-modal-backdrop{padding:0;align-items:stretch;justify-content:stretch}.utilities-modern-page .ut2-modal,.ut2-modal{width:100%;max-height:100dvh;border-radius:0;border-left:0;border-right:0}.utilities-modern-page .ut2-modal-row,.ut2-modal-row{grid-template-columns:1fr}}@media (max-width: 380px){.utilities-modern-page.ut2-page{padding-left:12px;padding-right:12px}.utilities-modern-page .ut2-card{padding:12px}.utilities-modern-page .ut2-card-name{font-size:14px}.utilities-modern-page .ut2-status-badge{font-size:10px;padding:0 8px}.utilities-modern-page .ut2-fc-value{font-size:13px}}.ezviz-modern-page{padding-top:0}.ezviz-modern-page.ez-wrap{max-width:480px;margin:0 auto;padding-left:16px;padding-right:16px;padding-bottom:calc(96px + env(safe-area-inset-bottom));background:var(--bg)}.ezviz-app-header{position:relative;top:auto;z-index:1;padding:0 0 4px;background:transparent;backdrop-filter:none;-webkit-backdrop-filter:none}.ezviz-refresh-modern{min-width:88px;justify-content:center}.ezviz-summary-modern{margin-bottom:10px;border-color:var(--blue-bd);background:radial-gradient(420px 170px at 20% 0%,rgba(96,165,250,.13),transparent 62%),var(--surface)}.ezviz-status-modern{display:flex;flex-wrap:wrap;gap:7px;margin-top:12px}.ezviz-filter-modern{margin-bottom:10px}.ezviz-filter-modern .app-chip-row{padding-bottom:10px}.ezviz-search-modern{display:grid;grid-template-columns:20px minmax(0,1fr);align-items:center;gap:8px;min-height:42px;border-radius:var(--r-sm);border:1px solid var(--border2);background:var(--lift);padding:0 12px}.ezviz-search-icon-modern{color:var(--sub);font-size:16px;line-height:1}.ezviz-search-input-modern{min-width:0;width:100%;border:0;outline:0;background:transparent;color:var(--text);font-size:13px;font-weight:700;font-family:var(--font)}.ezviz-search-input-modern::placeholder{color:var(--dim)}.ezviz-error-modern{margin-top:10px;border-radius:var(--r-sm);border:1px solid var(--red-bd);background:var(--red-bg);color:var(--red);padding:10px 11px;font-size:12px;font-weight:750;line-height:1.4}.ezviz-list-modern{display:flex;flex-direction:column;gap:10px}.ezviz-skeleton-modern{min-height:112px;display:flex;flex-direction:column;gap:10px}.ezviz-modern-page .ez-summary-row,.ezviz-modern-page .ez-filter-row,.ezviz-modern-page .ez-error{display:none}.ezviz-modern-page .ez-cards{display:flex;flex-direction:column;gap:10px}.ezviz-modern-page .ez-card{position:relative;border-radius:var(--r);border:1px solid var(--border);background:radial-gradient(360px 150px at 10% 0%,rgba(96,165,250,.09),transparent 62%),var(--surface);padding:13px;box-shadow:var(--shadow-sm);overflow:hidden}.ezviz-modern-page .ez-card-online{border-color:var(--green-bd)}.ezviz-modern-page .ez-card-offline{opacity:.88}.ezviz-modern-page .ez-card-accent{position:absolute;inset:0 0 auto;height:2px;opacity:.8}.ezviz-modern-page .ez-card-head{display:flex;align-items:flex-start;justify-content:space-between;gap:12px}.ezviz-modern-page .ez-card-head-left{min-width:0;display:flex;align-items:center;gap:10px}.ezviz-modern-page .ez-card-icon{width:42px;height:42px;flex:0 0 auto;display:grid;place-items:center;border-radius:15px;border:1px solid var(--blue-bd);background:var(--blue-bg);font-size:20px}.ezviz-modern-page .ez-card-name{color:var(--text);font-size:14px;font-weight:900;line-height:1.25;letter-spacing:-.02em;overflow-wrap:anywhere}.ezviz-modern-page .ez-card-serial{margin-top:3px;color:var(--muted);font-family:var(--mono);font-size:11px;font-weight:750;overflow-wrap:anywhere}.ezviz-modern-page .ez-status-dot{flex:0 0 auto;min-height:25px;display:inline-flex;align-items:center;padding:0 9px;border-radius:var(--r-full);border:1px solid var(--border);background:var(--lift);color:var(--muted);font-size:10.5px;font-weight:850;white-space:nowrap}.ezviz-modern-page .ez-status-dot.online{border-color:var(--green-bd);background:var(--green-bg);color:var(--green)}.ezviz-modern-page .ez-status-dot.offline{border-color:var(--border);background:var(--lift);color:var(--sub)}.ezviz-modern-page .ez-card-badges{display:flex;flex-wrap:wrap;gap:6px;margin-top:11px}.ezviz-modern-page .ez-cat-badge,.ezviz-modern-page .ez-type-badge,.ezviz-modern-page .ez-model-badge{min-height:24px;display:inline-flex;align-items:center;gap:5px;padding:0 9px;border-radius:var(--r-full);border:1px solid var(--border);background:var(--lift);color:var(--muted);font-size:10.5px;font-weight:850}.ezviz-modern-page .ez-cat-badge{border-color:var(--blue-bd);background:var(--blue-bg);color:var(--blue)}.ezviz-modern-page .ez-type-badge.wifi{border-color:var(--green-bd);background:var(--green-bg);color:var(--green)}.ezviz-modern-page .ez-type-badge.wire{border-color:var(--indigo-bd);background:var(--indigo-bg);color:var(--indigo-lt)}.ezviz-modern-page .ez-kv-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:8px;margin-top:12px}.ezviz-modern-page .ez-kv-item{min-width:0;border-radius:var(--r-sm);border:1px solid var(--border);background:var(--lift);padding:10px}.ezviz-modern-page .ez-kv-label{display:block;color:var(--sub);font-size:9.5px;font-weight:850;letter-spacing:.07em;text-transform:uppercase}.ezviz-modern-page .ez-kv-value{display:block;margin-top:5px;color:var(--text);font-size:12px;font-weight:800;line-height:1.25;overflow-wrap:anywhere}.ezviz-modern-page .ez-kv-value.mono{font-family:var(--mono)}.ezviz-modern-page .ez-signal-section{margin-top:12px;border-radius:var(--r-sm);border:1px solid var(--border);background:var(--lift);padding:10px}.ezviz-modern-page .ez-signal-wrap{display:grid;grid-template-columns:minmax(0,1fr) auto;align-items:center;gap:10px;margin-top:7px}.ezviz-modern-page .ez-signal-track{height:8px;border-radius:var(--r-full);background:#ffffff0f;overflow:hidden}.ezviz-modern-page .ez-signal-fill{height:100%;max-width:100%;border-radius:inherit}.ezviz-modern-page .ez-signal-pct{font-family:var(--mono);font-size:11px;font-weight:900;white-space:nowrap}.ezviz-modern-page .ez-card-footer{display:flex;justify-content:flex-end;margin-top:12px}.ezviz-modern-page .ez-detail-btn,.ezviz-modern-page .ez-btn{min-height:34px;display:inline-flex;align-items:center;justify-content:center;gap:7px;padding:0 11px;border-radius:var(--r-full);border:1px solid var(--indigo-bd);background:var(--indigo-bg);color:var(--indigo-lt);font-size:12px;font-weight:850;font-family:var(--font)}.ezviz-modern-page .ez-desktop-table{margin-top:10px;display:none}@media (min-width: 760px){.ezviz-modern-page .ez-desktop-table{display:block;border-radius:var(--r);border:1px solid var(--border);background:var(--surface);padding:10px;overflow-x:auto}}@media (max-width: 520px){.ezviz-modern-page.ez-wrap{padding-left:16px;padding-right:16px}.ezviz-modern-page .ez-card-head{flex-direction:column;gap:10px}.ezviz-modern-page .ez-status-dot{align-self:flex-start}.ezviz-modern-page .ez-kv-grid{grid-template-columns:1fr}.ezviz-refresh-modern{min-width:42px;padding:0 10px}}@media (max-width: 380px){.ezviz-modern-page.ez-wrap{padding-left:12px;padding-right:12px}.ezviz-modern-page .ez-card{padding:12px}.ezviz-modern-page .ez-card-icon{width:38px;height:38px;border-radius:13px;font-size:18px}.ezviz-modern-page .ez-card-name{font-size:13.5px}.ezviz-modern-page .ez-card-serial{font-size:10.5px}}.modalCard{background:var(--surface)}.modalMobile{width:100%;max-width:100%;height:100dvh;max-height:100dvh;border-radius:0;padding-bottom:env(safe-area-inset-bottom)}.modalScrollable{display:flex;flex-direction:column}.modalScroll{flex:1 1 auto;overflow-y:auto;-webkit-overflow-scrolling:touch;padding-bottom:80px}.modalActions{margin-top:8px;display:flex;flex-direction:column;gap:8px}.stickyActions{position:sticky;bottom:0;z-index:10;padding:10px 16px calc(10px + env(safe-area-inset-bottom));background:var(--surface);border-top:1px solid var(--border)}.modalCloseBtn{display:flex;align-items:center;justify-content:center;width:34px;height:34px;border:1px solid var(--border);border-radius:var(--r-full);background:var(--lift);color:var(--muted);cursor:pointer;transition:all .14s}.modalCloseBtn:hover{background:var(--hover);color:var(--text)}.formSection{margin-bottom:10px;padding:14px;border:1px solid var(--border);border-radius:var(--r);background:var(--bg);display:flex;flex-direction:column;gap:12px}.sectionTitle{margin:0;padding-bottom:10px;border-bottom:1px solid var(--border);font-weight:600;color:var(--sub);font-size:10px;letter-spacing:.1em;text-transform:uppercase}.infoHint{padding:10px 12px;border:1px solid var(--border);border-radius:var(--r-sm);background:var(--lift);font-size:13px;color:var(--muted)}.discPreview{margin-top:8px;padding:10px 12px;border:1px dashed var(--border2);border-radius:var(--r-sm);background:var(--bg);color:var(--text);font-weight:600}.fileBadge{margin-top:8px;padding:10px 12px;border:1px solid var(--border);border-radius:var(--r-sm);background:var(--lift);color:var(--text)}.collapseHead{width:100%;display:flex;justify-content:space-between;align-items:center;border:none;background:transparent;color:inherit;cursor:pointer;font-weight:700;padding:0}.pickerBtn{width:100%;display:flex;align-items:center;justify-content:space-between;padding:11px 14px;border:1px solid var(--border);border-radius:var(--r-sm);background:var(--lift);color:var(--text);cursor:pointer;text-align:left;transition:border-color .15s}.pickerBtn:hover{border-color:var(--indigo-bd)}.pickerBtn-main{font-size:15px;font-weight:600}.pickerBtn-sub{font-size:11px;color:var(--sub);margin-top:2px}.dateHint{padding:8px 12px;border-radius:var(--r-sm);background:var(--indigo-bg);border:1px solid var(--indigo-bd);color:var(--indigo-lt);font-size:12px;font-weight:600}.nominalDisplay{display:flex;flex-direction:column;align-items:center;padding:14px 0 6px}.nominalLabel{font-size:10px;font-weight:600;color:var(--sub);text-transform:uppercase;letter-spacing:.08em;margin-bottom:5px}.nominalValue{font-size:30px;font-weight:800;color:var(--text);letter-spacing:-.03em;line-height:1;font-family:var(--mono)}.nominalValue.green{color:var(--green)}.methodChips{display:flex;gap:8px}.methodChip{flex:1;display:flex;flex-direction:column;align-items:center;gap:4px;padding:10px 8px;border:1px solid var(--border);border-radius:var(--r-sm);background:var(--lift);color:var(--sub);font-size:11px;font-weight:600;cursor:pointer;transition:all .15s}.methodChip .methodIcon{font-size:18px;line-height:1}.methodChip.active{border-color:var(--indigo-bd);background:var(--indigo-bg);color:var(--indigo-lt)}.methodChip:disabled{opacity:.4;cursor:not-allowed}.uploadArea{display:flex;flex-direction:column;align-items:center;gap:6px;padding:16px;border:1px dashed var(--border2);border-radius:var(--r-sm);background:transparent;cursor:pointer;transition:all .15s}.uploadArea:hover{border-color:var(--indigo-bd);background:var(--indigo-bg)}.uploadIcon{font-size:22px;opacity:.7}.uploadText{font-size:13px;font-weight:600;color:var(--indigo-lt)}.uploadSub{font-size:11px;color:var(--sub)}.addTenantForm{display:flex;flex-direction:column;gap:0;padding:0 16px 80px}.roomsGrid{display:grid;grid-template-columns:repeat(3,1fr);gap:8px;padding:4px}.roomBtn{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:4px;padding:13px 8px;border:1px solid var(--border);border-radius:var(--r-sm);background:var(--lift);color:var(--text);cursor:pointer;transition:all .15s}.roomBtn:hover{border-color:var(--indigo-bd);background:var(--indigo-bg)}.roomBtn:active{transform:scale(.97)}.roomBtn.disabled{opacity:.35;pointer-events:none}.profileRow{display:grid;grid-template-columns:100px 1fr;gap:8px;align-items:baseline}.profileKey,.masaLabel{color:var(--sub);font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:.04em}.profileVal,.masaValue{color:var(--text);font-size:14px;font-weight:600;line-height:1.35;overflow-wrap:anywhere}.masaValue.unknown{color:var(--muted)}.payHeader{display:flex;align-items:center;gap:10px;padding:13px;margin-bottom:10px;border:1px solid var(--border);border-radius:var(--r);background:var(--surface)}.payBackBtn{width:36px;height:36px;display:flex;align-items:center;justify-content:center;border:1px solid var(--border);border-radius:var(--r-full);background:var(--lift);color:var(--text);cursor:pointer;transition:all .15s;flex-shrink:0}.payBackBtn:hover{border-color:var(--border2)}.payTenant{flex:1;min-width:0}.payTenantName{font-weight:700;color:var(--text);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.payTenantPhone{margin-top:2px;opacity:.6;font-size:12px}.payBadge{padding:5px 11px;border:1px solid var(--border);border-radius:var(--r-full);font-weight:600;font-size:11px;white-space:nowrap;color:var(--muted)}.payBadge.extend{border-color:var(--indigo-bd);background:var(--indigo-bg);color:var(--indigo-lt)}.payBadge.other{border-color:var(--green-bd);background:var(--green-bg);color:var(--green)}.payBadge.installment{border-color:var(--amber-bd);background:var(--amber-bg);color:var(--amber)}.payBadge.deposit{border-color:var(--blue-bd);background:var(--blue-bg);color:var(--blue)}.payMenuGrid{display:flex;flex-direction:column;gap:8px}.payMenuBtn{width:100%;display:flex;align-items:center;gap:14px;padding:14px;border-radius:var(--r);border:1px solid var(--border);background:var(--surface);color:var(--text);cursor:pointer;text-align:left;transition:border-color .15s,background .15s,transform .12s}.payMenuBtn:active{transform:scale(.99)}.payMenuBtn.primary{border-color:var(--indigo-bd);background:var(--indigo-bg)}.payMenuBtn.primary:hover{border-color:var(--indigo)}.payMenuBtn.success{border-color:var(--green-bd);background:var(--green-bg)}.payMenuBtn.warn{border-color:var(--amber-bd);background:var(--amber-bg)}.payMenuBtn.ghost{border-color:var(--border);background:var(--lift)}.payMenuBtn.ghost:hover{border-color:var(--border2)}.payMenuIcon{width:40px;height:40px;flex-shrink:0;display:grid;place-items:center;border-radius:var(--r-sm)}.payMenuBtn.primary .payMenuIcon{background:var(--indigo-bg);color:var(--indigo-lt)}.payMenuBtn.success .payMenuIcon{background:var(--green-bg);color:var(--green)}.payMenuBtn.warn .payMenuIcon{background:var(--amber-bg);color:var(--amber)}.payMenuBtn.ghost .payMenuIcon{background:var(--lift);color:var(--muted)}.payMenuText{flex:1;min-width:0}.payMenuLabel{font-size:14px;font-weight:700;color:var(--text);line-height:1.2}.payMenuSub{margin-top:2px;font-size:12px;color:var(--sub)}.payMenuArrow{color:var(--sub);font-size:16px;flex-shrink:0}.btnSub{margin-top:3px;font-size:11px;opacity:.7}.quickPrice{display:flex;gap:8px;margin-top:4px}.quickPriceBtn{flex:1;padding:10px;border:1px solid var(--border);border-radius:var(--r-sm);background:var(--lift);color:var(--muted);font-size:12px;font-weight:600;transition:all .15s}.quickPriceBtn.active{background:var(--indigo);border-color:var(--indigo);color:#fff}.saldoBar{display:flex;align-items:center;justify-content:space-between;padding:12px 14px;border:1px solid var(--border);border-radius:var(--r-sm);background:var(--surface)}.saldoLabel{font-size:11px;font-weight:600;color:var(--sub);text-transform:uppercase;letter-spacing:.06em}.saldoValue{font-size:17px;font-weight:700;color:var(--text);letter-spacing:-.02em;font-family:var(--mono)}.tenantDetailModal{width:min(94vw,480px);height:100%;max-height:min(88dvh,760px);min-height:0;overflow:hidden;display:flex;flex-direction:column;border-radius:var(--r);border:1px solid var(--border);background:var(--surface);box-shadow:var(--shadow-lg)}.tenantDetailHead{flex:0 0 auto;display:flex;align-items:center;justify-content:space-between;gap:12px;padding:14px 16px;border-bottom:1px solid var(--border)}.tenantDetailRoom{color:var(--indigo-lt);font-size:14px;font-weight:700;letter-spacing:.1em;text-transform:uppercase}.tenantDetailHeadRight{display:flex;align-items:center;gap:8px}.tenantDetailClose{width:34px;height:34px;display:grid;place-items:center;border:1px solid var(--border);border-radius:var(--r-full);background:var(--lift);color:var(--muted);cursor:pointer;transition:all .14s}.tenantDetailClose:hover{background:var(--hover);color:var(--text)}.tenantDetailIdentity{flex:0 0 auto;display:flex;align-items:center;gap:12px;padding:14px 16px;border-bottom:1px solid var(--border)}.tenantIdentityText{display:flex;flex-direction:column;min-width:0;flex:1}.tenantIdName{display:flex;align-items:center;gap:6px;color:var(--text);font-size:16px;font-weight:700;line-height:1.2}.tenantIdPhoneRow{display:flex;align-items:center;gap:6px;margin-top:4px;color:var(--muted)}.tenantIdPhone{font-weight:600;font-size:13px}.copyBtn{width:30px;height:30px;flex:0 0 auto;display:grid;place-items:center;border:1px solid var(--border);border-radius:var(--r-xs);background:var(--lift);color:var(--sub);cursor:pointer;transition:all .14s}.copyBtn:hover{color:var(--text);border-color:var(--border2)}.tenantDetailBody{flex:1 1 auto;min-height:0;overflow-y:auto;padding:14px 16px;padding-bottom:calc(16px + env(safe-area-inset-bottom))}.tenantDetailBody::-webkit-scrollbar{width:4px}.tenantDetailBody::-webkit-scrollbar-thumb{background:var(--border2);border-radius:var(--r-full)}.tenantDetailActions{flex:0 0 auto;display:flex;flex-direction:column;gap:8px;padding:12px 16px calc(12px + env(safe-area-inset-bottom));border-top:1px solid var(--border);background:var(--surface)}.detailStatusPill{display:inline-flex;align-items:center;gap:5px;padding:4px 10px;border-radius:var(--r-full);font-size:12px;font-weight:600;border:1px solid var(--border);background:var(--lift);color:var(--muted)}.detailStatusPill.ok{border-color:var(--green-bd);background:var(--green-bg);color:var(--green)}.detailStatusPill.overdue{border-color:var(--red-bd);background:var(--red-bg);color:var(--red)}.detailStatusPill.near,.detailStatusPill.dueToday{border-color:var(--amber-bd);background:var(--amber-bg);color:var(--amber)}.buktiModalWrap{display:flex;flex-direction:column;height:100%}.buktiHead{display:flex;align-items:center;justify-content:space-between;gap:10px;padding:12px 14px;border-bottom:1px solid var(--border)}.buktiHeadTitle{color:var(--text);font-weight:700}.buktiHeadActions{display:flex;gap:8px}.buktiBody{flex:1 1 auto;min-height:0;overflow:auto}.histPayProof{position:relative;width:100%;min-height:68px;border:none;border-radius:var(--r-sm);overflow:hidden;background:var(--lift);cursor:pointer}.histPayProof img{width:100%;height:100px;object-fit:cover;display:block}.proofOverlay{position:absolute;top:0;right:0;bottom:0;left:0;display:flex;align-items:center;justify-content:center;gap:6px;background:#00000080;color:var(--text);font-size:12px;font-weight:600;opacity:0;transition:opacity .15s}.histPayProof:hover .proofOverlay{opacity:1}.histTenantModal,.histTenantNoFloat{display:flex;flex-direction:column}.reminderModalShell{width:100%}.reminderModalCard{display:flex;flex-direction:column;gap:12px}.reminderHero{padding:14px;border:1px solid var(--indigo-bd);border-radius:var(--r);background:var(--indigo-bg)}.reminderHeroName{margin-bottom:2px;color:var(--text);font-size:17px;font-weight:700;letter-spacing:-.02em}.reminderHeroMeta,.reminderHeroPhone{color:var(--sub);font-size:13px}.reminderHeroStatus{display:inline-flex;align-items:center;gap:6px;margin-top:10px;padding:5px 12px;border:1px solid var(--border);border-radius:var(--r-full);background:var(--lift);color:var(--muted);font-size:12px;font-weight:600}.reminderHeroStatus.ok,.reminderHeroStatus.paid{border-color:var(--green-bd);background:var(--green-bg);color:var(--green)}.reminderHeroStatus.near,.reminderHeroStatus.dueToday,.reminderHeroStatus.installment{border-color:var(--amber-bd);background:var(--amber-bg);color:var(--amber)}.reminderHeroStatus.overdue{border-color:var(--red-bd);background:var(--red-bg);color:var(--red)}.reminderFields{display:flex;flex-direction:column;gap:10px}.reminderField{display:flex;flex-direction:column;gap:5px}.reminderLabel{color:var(--muted);font-size:10px;font-weight:600;letter-spacing:.06em;text-transform:uppercase}.reminderInput,.reminderSelect,.reminderTextarea{width:100%;border:1px solid var(--border);border-radius:var(--r-sm);background:var(--lift);color:var(--text);outline:none;transition:border-color .15s,box-shadow .15s}.reminderInput,.reminderSelect{min-height:42px;padding:0 12px;font-size:14px;font-family:inherit}.reminderTextarea{min-height:96px;padding:10px 12px;resize:vertical;line-height:1.45;font-size:14px;font-family:inherit}.reminderInput:focus,.reminderSelect:focus,.reminderTextarea:focus{border-color:var(--indigo-bd);box-shadow:0 0 0 3px #6366f11a}.reminderInput::placeholder,.reminderTextarea::placeholder{color:var(--dim)}.reminderChip{min-height:40px;padding:8px 12px;border:1px solid var(--border);border-radius:var(--r-sm);background:var(--lift);color:var(--sub);font-size:12px;font-weight:600;text-align:center;transition:all .15s}.reminderChip.active{border-color:var(--indigo-bd);background:var(--indigo-bg);color:var(--indigo-lt)}.reminderQuickType{display:grid;grid-template-columns:repeat(2,1fr);gap:8px}.reminderError{padding:10px 12px;border:1px solid var(--red-bd);border-radius:var(--r-sm);background:var(--red-bg);color:var(--red);font-size:12px;font-weight:600;line-height:1.45}.reminderPreview{padding:12px;border:1px solid var(--border);border-radius:var(--r-sm);background:var(--lift)}.reminderPreviewLabel{margin-bottom:5px;color:var(--sub);font-size:10px;font-weight:700;letter-spacing:.1em;text-transform:uppercase}.reminderPreviewText{color:var(--text);font-size:13px;line-height:1.5;white-space:pre-wrap;word-break:break-word}.reminderHint{margin-top:2px;color:var(--sub);font-size:12px}.reminderActions{display:grid;grid-template-columns:1fr 1fr;gap:10px;margin-top:4px}.reminderBtn{min-height:48px;border:none;border-radius:var(--r);font-size:14px;font-weight:700;transition:transform .13s,opacity .13s}.reminderBtn:active{transform:scale(.98)}.reminderBtnGhost{border:1px solid var(--border);background:var(--lift);color:var(--muted)}.reminderBtnGhost:hover{background:var(--hover);color:var(--text)}.reminderBtnPrimary{background:linear-gradient(135deg,#25d366,#128c7e);color:#fff;box-shadow:0 6px 20px #25d36633}.reminderBtn:disabled{opacity:.45;cursor:not-allowed}.remJenisGrid{display:grid;grid-template-columns:1fr 1fr;gap:8px}.remJenisChip{display:flex;flex-direction:column;align-items:flex-start;gap:3px;padding:11px;border:1px solid var(--border);border-radius:var(--r-sm);background:var(--lift);color:var(--sub);cursor:pointer;text-align:left;transition:all .15s}.remJenisChip:active{transform:scale(.97)}.remJenisIcon{font-size:18px;line-height:1;margin-bottom:2px}.remJenisLabel{font-size:13px;font-weight:700;color:var(--text);line-height:1.2}.remJenisSub{font-size:10px;color:var(--sub)}.remJenisChip.active{border-color:var(--indigo-bd);background:var(--indigo-bg)}.remJenisChip.active .remJenisLabel{color:var(--indigo-lt)}.remJenisChip.active .remJenisSub{color:var(--indigo-bd)}.cdd-wrap{position:relative;width:100%}.cdd-trigger{width:100%;display:flex;align-items:center;justify-content:space-between;gap:10px;padding:0 12px;min-height:42px;border:1px solid var(--border);border-radius:var(--r-sm);background:var(--lift);color:var(--text);font-size:14px;cursor:pointer;text-align:left;transition:border-color .15s}.cdd-trigger:hover{border-color:var(--border2)}.cdd-trigger.open{border-color:var(--indigo-bd);border-bottom-left-radius:0;border-bottom-right-radius:0}.cdd-trigger.disabled{opacity:.45;cursor:not-allowed}.cdd-selected{flex:1;min-width:0}.cdd-placeholder{color:var(--dim)}.cdd-label{color:var(--text)}.cdd-row{display:flex;align-items:center;gap:10px}.cdd-arrow{font-size:10px;color:var(--sub);flex-shrink:0;transition:transform .15s}.cdd-arrow.open{transform:rotate(180deg)}.cdd-list{position:absolute;top:100%;left:0;right:0;z-index:200;background:var(--surface);border:1px solid var(--indigo-bd);border-top:none;border-bottom-left-radius:var(--r-sm);border-bottom-right-radius:var(--r-sm);overflow-y:auto;max-height:220px;display:flex;flex-direction:column;box-shadow:var(--shadow-lg)}.cdd-item{width:100%;display:flex;align-items:center;gap:12px;padding:10px 12px;border:none;border-bottom:1px solid var(--border);background:transparent;color:var(--text);cursor:pointer;text-align:left;transition:background .1s;font-size:14px;font-family:inherit}.cdd-item:last-child{border-bottom:none}.cdd-item:hover{background:var(--lift)}.cdd-item.selected{background:var(--indigo-bg)}.cdd-item-label{font-size:14px;font-weight:600;color:var(--text)}.cdd-item-sub{font-size:11px;color:var(--sub);margin-top:1px}.cdd-check{margin-left:auto;font-size:12px;color:var(--indigo-lt);flex-shrink:0}.cdd-logo-img{width:38px;height:38px;object-fit:contain;border-radius:var(--r-xs);background:#fff;padding:3px}.cdd-logo{width:38px;height:24px;border-radius:4px;display:flex;align-items:center;justify-content:center;font-size:9px;font-weight:800;flex-shrink:0}.cdd-logo.bca{background:#003f8a;color:#fff}.cdd-logo.bni{background:#ef7d00;color:#fff}.cdd-logo.bri{background:#004b8d;color:#fff}.cdd-logo.mdr{background:#003d7a;color:#fdd000}.cdd-logo.bsi{background:#4caf50;color:#fff}.cdd-logo.dana{background:#108ee9;color:#fff}.cdd-logo.ovo{background:#4c3494;color:#fff}.cdd-logo.gpy{background:#00aed6;color:#fff}.cdd-logo.spy{background:#f26522;color:#fff}.cdd-logo.sea{background:#19c2e0;color:#fff}.em-section{display:flex;flex-direction:column;gap:10px;padding:14px;border-radius:var(--r-sm);background:var(--surface);border:1px solid var(--border)}.em-label{font-size:10px;font-weight:600;text-transform:uppercase;letter-spacing:.08em;color:var(--sub);display:flex;align-items:center;gap:4px}.em-label-req{color:var(--red);font-size:12px;line-height:1}.em-input{width:100%;min-height:44px;border-radius:var(--r-sm);border:1px solid var(--border);background:var(--lift);color:var(--text);padding:0 13px;font-size:15px;font-family:inherit;outline:none;transition:border-color .15s,box-shadow .15s}.em-input:focus{border-color:var(--red-bd);box-shadow:0 0 0 3px var(--red-bg)}.em-nominal-prefix{position:absolute;left:13px;top:50%;transform:translateY(-50%);color:var(--sub);font-size:13px;pointer-events:none}.em-nominal-input{padding-left:34px;font-size:22px;font-weight:600;letter-spacing:-.5px}.em-chips{display:flex;flex-wrap:wrap;gap:6px}.em-chip{padding:7px 13px;border-radius:var(--r-full);border:1px solid var(--border);background:var(--lift);color:var(--sub);font-size:13px;font-weight:500;font-family:inherit;cursor:pointer;transition:all .12s}.em-chip:active{transform:scale(.97)}.em-bank-btn{display:flex;flex-direction:column;align-items:center;gap:5px;padding:10px 6px;border:1px solid var(--border);border-radius:var(--r-sm);background:var(--lift);cursor:pointer;transition:all .15s}.em-bank-btn:hover{border-color:var(--indigo-bd);background:var(--indigo-bg)}.em-bank-on{border-color:var(--indigo-bd)!important;background:var(--indigo-bg)!important}.em-bank-logo{width:34px;height:34px;object-fit:contain;border-radius:var(--r-xs);background:#fff;padding:3px}.em-bank-on .em-bank-label{color:var(--indigo-lt)}.em-jenis-btn{display:flex;flex-direction:column;align-items:center;gap:5px;padding:11px 6px;border:1px solid var(--border);border-radius:var(--r-sm);background:var(--lift);cursor:pointer;transition:all .14s;-webkit-tap-highlight-color:transparent}.em-jenis-icon{font-size:18px;line-height:1;display:flex}.em-upload-btn{width:100%;display:flex;flex-direction:column;align-items:center;gap:5px;padding:20px 14px;border-radius:var(--r-sm);border:1.5px dashed var(--border2);background:transparent;color:var(--sub);font-size:13px;font-weight:500;font-family:inherit;cursor:pointer;transition:border-color .15s,color .15s}.em-upload-icon{font-size:20px}.em-bukti-preview{width:100%;max-height:180px;object-fit:contain;border-radius:var(--r-sm);border:1px solid var(--border);background:var(--bg)}.em-bukti-remove{flex-shrink:0;padding:5px 12px;border-radius:var(--r-full);border:1px solid var(--red-bd);background:var(--red-bg);color:var(--red);font-size:12px;font-weight:500;font-family:inherit;cursor:pointer}.em-submit{margin-top:8px;width:100%;padding:15px;border-radius:var(--r-sm);border:none;background:var(--red);color:#fff;font-size:15px;font-weight:700;font-family:inherit;cursor:pointer;display:flex;align-items:center;justify-content:center;gap:8px;transition:opacity .15s}.em-submit:disabled{opacity:.5}.em-submit:active:not(:disabled){opacity:.85}.em-spinner{width:14px;height:14px;flex-shrink:0;border:2px solid rgba(255,255,255,.3);border-top-color:#fff;border-radius:50%;animation:em-spin .7s linear infinite}.income-form{display:flex;flex-direction:column;gap:12px}.field-row{display:grid;grid-template-columns:120px minmax(0,1fr);gap:10px;align-items:center;padding:10px;border:1px solid var(--border);border-radius:var(--r-sm);background:var(--surface)}.field-label{font-size:12px;color:var(--muted);font-weight:600}.field-control{display:flex;flex-direction:column;gap:5px;min-width:0}.income-input{width:100%;min-height:42px;border-radius:var(--r-sm);border:1px solid var(--border);background:var(--lift);color:var(--text);padding:0 12px;font-size:15px;font-family:inherit;outline:none}@media (max-width: 480px){.field-row{grid-template-columns:1fr;gap:6px}}.em-floating-success,.income-floating-success,.ed-floating-toast,.id-floating-toast{position:fixed;left:50%;bottom:calc(80px + env(safe-area-inset-bottom));transform:translate(-50%);z-index:9999;width:min(calc(100vw - 32px),360px);display:flex;align-items:center;gap:10px;padding:12px 14px;border-radius:var(--r);border:1px solid var(--border2);background:#111118f5;color:var(--text);font-size:13px;font-weight:700;box-shadow:var(--shadow-lg);-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);animation:float-toast-in .18s ease-out}.em-floating-success{border-color:var(--red-bd);color:var(--red)}.income-floating-success{border-color:var(--green-bd);color:var(--green)}.ed-floating-toast{border-color:var(--red-bd);color:var(--red)}.id-floating-toast{border-color:var(--green-bd);color:var(--green)}.em-floating-success-icon,.income-floating-success-icon,.ed-floating-toast-icon,.id-floating-toast-icon{width:22px;height:22px;flex:0 0 auto;display:grid;place-items:center;border-radius:var(--r-full);background:currentColor;flex-shrink:0}.em-floating-success-icon svg,.income-floating-success-icon svg,.ed-floating-toast-icon svg,.id-floating-toast-icon svg{color:#fff}@keyframes float-toast-in{0%{opacity:0;transform:translate(-50%) translateY(8px)}to{opacity:1;transform:translate(-50%) translateY(0)}}@media (max-width: 520px){.tenantDetailModal{width:100vw;max-height:100dvh;border-radius:var(--r) var(--r) 0 0;border-left:none;border-right:none;border-bottom:none}.reminderModalCard{gap:10px}}.ap-page,.m-page,.ut2-page,.arsip-page,.page-docs,.page-dashboard,.ez-wrap,.ip-wrap{max-width:480px;margin:0 auto;overflow-x:hidden}.ap-card,.arsip-card,.m-card,.ez-card,.ip-room-block,.ed-panel,.id-panel{border-radius:var(--r)!important}.ap-btn,.m-btn,.ez-btn,.ip-btn,.ed-btn-edit,.aed-btn-save,.aed-btn-cancel{font-family:var(--font)!important}.page-dashboard{min-height:100vh;max-width:430px;margin:0 auto;padding:0 16px 120px;background:var(--bg);color:var(--text);font-family:var(--font);-webkit-font-smoothing:antialiased;font-size:14px;line-height:1.5}.alert-bar{display:flex;gap:12px;align-items:center;justify-content:space-between;margin:0 0 12px;padding:13px 14px;border-radius:var(--r);border:1px solid var(--border);background:var(--surface)}.alert-bar.safe{background:var(--green-bg);border-color:var(--green-bd);color:var(--green)}.alert-bar.warn{background:var(--amber-bg);border-color:var(--amber-bd);color:var(--amber)}.alert-bar.danger{background:var(--red-bg);border-color:var(--red-bd);color:var(--red)}.alert-bar.neutral{background:var(--surface);border-color:var(--border);color:var(--text)}.alert-copy{min-width:0;display:flex;flex-direction:column;gap:2px}.alert-title{font-size:13px;font-weight:500}.alert-text{font-size:11.5px;opacity:.75;line-height:1.4}.alert-cta{flex:0 0 auto;border:1px solid currentColor;background:transparent;color:inherit;padding:6px 12px;border-radius:999px;font-size:11.5px;font-weight:500;cursor:pointer;font-family:var(--font);opacity:.8;transition:opacity .15s;white-space:nowrap}.alert-cta:hover{opacity:1}.dash-error{margin:0 0 12px;padding:12px 14px;border-radius:var(--r);border:1px solid var(--red-bd);background:var(--red-bg);display:flex;align-items:center;gap:10px;flex-wrap:wrap}.dash-error-title{font-weight:500;color:var(--red);font-size:13px}.dash-error-msg{font-size:12px;color:var(--red);opacity:.7}.dash-error-btn{margin-left:auto;padding:5px 12px;border-radius:999px;background:transparent;border:1px solid var(--red-bd);color:var(--red);font-size:12px;font-weight:500;cursor:pointer;font-family:var(--font)}.page-dashboard .segmented{display:flex;gap:2px;margin:14px 0;background:var(--lift);border:1px solid var(--border);border-radius:999px;padding:3px}.page-dashboard .seg-btn{flex:1;border:none;background:transparent;color:var(--sub);padding:7px 12px;border-radius:999px;font-size:12.5px;font-weight:500;font-family:var(--font);cursor:pointer;transition:background .15s,color .15s}.page-dashboard .seg-btn.active{background:var(--surface);color:var(--text)}.page-dashboard .seg-btn:hover:not(.active){color:var(--text)}.k-btn{padding:6px 13px;border:1px solid var(--border);background:var(--lift);border-radius:999px;font-size:12.5px;color:var(--sub);cursor:pointer;font-weight:500;font-family:var(--font);transition:color .15s,border-color .15s}.k-btn:hover{color:var(--text);border-color:#ffffff1f}.k-btn.ghost{background:transparent;color:var(--blue);border-color:#60a5fa40}.settings-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;z-index:1000;display:flex;align-items:flex-end;justify-content:center;padding:16px;background:#0000008c;backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px)}.settings-sheet{width:min(100%,430px);border-radius:24px 24px 18px 18px;border:1px solid var(--border2);background:linear-gradient(180deg,#11141d,var(--bg));box-shadow:0 24px 70px #0000008c;overflow:hidden}.settings-head{display:flex;align-items:flex-start;justify-content:space-between;gap:12px;padding:18px 18px 14px;border-bottom:1px solid var(--divider)}.settings-kicker{color:var(--blue);font-size:10px;font-weight:600;letter-spacing:.12em;text-transform:uppercase}.settings-title{margin:3px 0 0;color:var(--text);font-size:17px;font-weight:600;letter-spacing:-.25px}.settings-close{width:34px;height:34px;display:grid;place-items:center;border-radius:12px;border:1px solid var(--border);background:var(--lift);color:var(--sub);cursor:pointer}.settings-list{display:flex;flex-direction:column;gap:9px;padding:14px}.settings-item,.settings-info{width:100%;min-height:66px;display:flex;align-items:center;justify-content:space-between;gap:12px;padding:13px;border-radius:16px;border:1px solid var(--border);background:#ffffff09;color:var(--text);text-align:left;font-family:var(--font)}.settings-item{cursor:pointer;transition:transform .15s,background .15s,border-color .15s}.settings-item:disabled{opacity:.6;cursor:not-allowed}.settings-item:active:not(:disabled){transform:scale(.985)}.settings-item:hover:not(:disabled){background:#ffffff0e;border-color:var(--border2)}.settings-item-left{min-width:0;display:flex;align-items:center;gap:12px}.settings-item-right{display:flex;align-items:center;gap:8px;flex:0 0 auto}.settings-item-title{font-size:13px;font-weight:500;color:var(--text)}.settings-item-sub{margin-top:2px;color:var(--sub);font-size:11.5px;line-height:1.35}.settings-item.danger{border-color:var(--red-bd);background:var(--red-bg)}.settings-item.danger .settings-item-title{color:var(--red)}.settings-item.has-unread{border-color:#60a5fa38;background:#60a5fa12}.settings-icon{width:38px;height:38px;flex:0 0 auto;display:grid;place-items:center;border-radius:13px;background:var(--lift);border:1px solid var(--border)}.settings-icon.test{color:var(--amber)}.settings-icon.sync{color:var(--blue)}.settings-icon.logout{color:var(--red)}.settings-icon.inbox{color:var(--blue)}.settings-icon.system{color:var(--green)}.settings-badge{min-width:22px;height:22px;display:inline-flex;align-items:center;justify-content:center;padding:0 7px;border-radius:999px;background:var(--blue);color:#07111f;font-size:11px;font-weight:700;line-height:1}.inbox-backdrop{z-index:1100}.inbox-sheet{width:min(100%,430px);max-height:min(86vh,760px);display:flex;flex-direction:column;border-radius:24px 24px 18px 18px;border:1px solid var(--border2);background:linear-gradient(180deg,#11141d,var(--bg));box-shadow:0 24px 70px #0000008c;overflow:hidden}.inbox-summary{display:grid;grid-template-columns:repeat(3,1fr);gap:8px;padding:14px 14px 0}.inbox-summary-card{min-height:58px;display:flex;flex-direction:column;justify-content:center;gap:3px;border:1px solid var(--border);border-radius:15px;background:#ffffff09;padding:10px}.inbox-summary-card span{color:var(--sub);font-size:10px;font-weight:500}.inbox-summary-card b{color:var(--text);font-size:18px;font-weight:600;line-height:1;font-family:var(--mono)}.inbox-actions{padding:10px 14px 0}.inbox-refresh{width:100%;border:1px solid rgba(96,165,250,.22);background:#60a5fa14;color:#bfdbfe;border-radius:14px;padding:10px 12px;font-size:12px;font-weight:500;cursor:pointer;font-family:var(--font)}.inbox-list{min-height:0;overflow:auto;display:flex;flex-direction:column;gap:10px;padding:14px}.inbox-empty{border:1px dashed var(--border);border-radius:16px;padding:18px;color:var(--sub);font-size:13px;text-align:center;background:#ffffff06}.inbox-empty.error{color:var(--red);border-color:var(--red-bd);background:var(--red-bg)}.inbox-item{border:1px solid var(--border);border-radius:18px;background:#ffffff09;padding:13px}.inbox-item.unread{border-color:#60a5fa3d;background:#60a5fa0e}.inbox-item-head{display:flex;align-items:center;justify-content:space-between;gap:10px;margin-bottom:9px}.inbox-type{display:inline-flex;align-items:center;gap:6px;padding:5px 9px;border-radius:999px;font-size:11px;font-weight:600;border:1px solid var(--border);color:var(--sub);background:var(--lift)}.inbox-type.pay{color:var(--green);border-color:var(--green-bd);background:var(--green-bg)}.inbox-type.complaint{color:var(--amber);border-color:var(--amber-bd);background:var(--amber-bg)}.inbox-unread,.inbox-read{font-size:10.5px;font-weight:600;border-radius:999px;padding:4px 8px}.inbox-unread{background:#60a5fa1f;color:#bfdbfe;border:1px solid rgba(96,165,250,.25)}.inbox-read{background:#ffffff09;color:var(--sub);border:1px solid var(--border)}.inbox-title{color:var(--text);font-size:14px;font-weight:600;letter-spacing:-.15px}.inbox-subtitle{margin-top:2px;color:var(--sub);font-size:12px;font-weight:500}.inbox-message{margin-top:9px;display:flex;flex-direction:column;gap:2px;padding:10px;border-radius:14px;border:1px solid var(--border);background:#00000029;color:var(--text);font-size:12.5px;line-height:1.45;white-space:pre-wrap}.inbox-time{margin-top:8px;color:var(--dim, var(--dim));font-size:11px;font-family:var(--mono)}.inbox-buttons{display:flex;flex-wrap:wrap;gap:7px;margin-top:11px}.inbox-btn{display:inline-flex;align-items:center;gap:5px;border:1px solid var(--border);background:var(--lift);color:var(--sub);border-radius:999px;padding:7px 10px;font-size:11.5px;font-weight:500;cursor:pointer;font-family:var(--font)}.inbox-btn:disabled{opacity:.55;cursor:not-allowed}.inbox-btn.view{color:#bfdbfe;border-color:#60a5fa3d;background:#60a5fa14}.inbox-btn.read{color:var(--green);border-color:var(--green-bd);background:var(--green-bg)}.inbox-btn.delete{color:var(--red);border-color:var(--red-bd);background:var(--red-bg)}.system-check-empty{border:1px dashed var(--border);border-radius:16px;padding:18px;color:var(--sub);font-size:13px;text-align:center;background:#ffffff06}.system-check-error{display:flex;align-items:center;gap:8px;border:1px solid var(--red-bd);border-radius:16px;padding:14px;color:var(--red);font-size:13px;background:var(--red-bg)}.system-check-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:8px}.system-check-card{min-height:64px;display:flex;flex-direction:column;justify-content:center;gap:5px;border:1px solid var(--border);border-radius:15px;background:#ffffff09;padding:12px}.system-check-card span{color:var(--sub);font-size:10px;font-weight:500;text-transform:uppercase;letter-spacing:.06em}.system-check-card b{color:var(--text);font-size:15px;font-weight:600;line-height:1.15;font-family:var(--mono);word-break:break-word}.system-check-list{display:flex;flex-direction:column;gap:8px}.system-row{display:flex;align-items:center;justify-content:space-between;gap:12px;min-height:46px;padding:11px 12px;border:1px solid var(--border);border-radius:14px;background:#ffffff08}.system-row span{color:var(--sub);font-size:12px}.system-row b{font-size:12px;font-weight:700;border-radius:999px;padding:4px 8px;border:1px solid var(--border)}.system-row b.ok{color:var(--green);border-color:var(--green-bd);background:var(--green-bg)}.system-row b.bad{color:var(--red);border-color:var(--red-bd);background:var(--red-bg)}.proof-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;z-index:1200;display:flex;align-items:center;justify-content:center;padding:16px;background:#000000b8;backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px)}.proof-card{width:min(100%,430px);max-height:88vh;overflow:hidden;border-radius:22px;border:1px solid rgba(255,255,255,.1);background:var(--bg);box-shadow:0 24px 70px #0009}.proof-head{display:flex;align-items:flex-start;justify-content:space-between;gap:12px;padding:14px;border-bottom:1px solid var(--divider);background:#101521}.proof-title{margin:3px 0 0;color:var(--text);font-size:15px;font-weight:600}.proof-body{display:grid;place-items:center;min-height:260px;max-height:76vh;background:var(--bg)}.proof-body img{width:100%;max-height:76vh;object-fit:contain;display:block}.proof-body iframe{width:100%;height:76vh;border:0;background:#fff}@media (min-width: 520px){.settings-backdrop{align-items:center}.settings-sheet,.inbox-sheet{border-radius:22px}}.m-page{min-height:100vh;max-width:480px;margin:0 auto;padding:0 16px 120px;background:radial-gradient(600px 260px at 10% -40px,rgba(99,102,241,.14),transparent 60%),radial-gradient(400px 200px at 88% 10%,rgba(34,211,153,.08),transparent 60%),var(--bg);color:var(--text);font-family:var(--font);-webkit-font-smoothing:antialiased;font-size:14px}.m-header{position:sticky;top:0;z-index:30;display:flex;align-items:center;justify-content:space-between;gap:12px;padding:18px 0 14px;background:linear-gradient(var(--bg) 72%,transparent)}.m-header__left{display:flex;align-items:center;gap:12px;min-width:0}.m-header__icon{width:42px;height:42px;border-radius:14px;display:grid;place-items:center;flex:0 0 auto;color:#818cf8;background:#6366f11f;border:1px solid rgba(99,102,241,.22)}.m-header__title{margin:0;font-size:19px;font-weight:900;letter-spacing:-.04em;color:var(--text);line-height:1.1}.m-header__sub{margin:3px 0 0;color:var(--sub);font-size:11px;font-weight:600}.m-add-btn{flex:0 0 auto;min-height:40px;display:flex;align-items:center;gap:6px;padding:10px 16px;border:0;border-radius:14px;background:linear-gradient(135deg,#6366f1,#4f46e5);color:#fff;font-family:inherit;font-size:13px;font-weight:900;white-space:nowrap;cursor:pointer;box-shadow:0 8px 22px #6366f147,inset 0 1px #ffffff1f;transition:transform .14s ease,box-shadow .14s ease}.m-add-btn:active{transform:scale(.96)}.m-stats{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:8px;margin-bottom:16px}@media (min-width: 380px){.m-stats{grid-template-columns:repeat(4,minmax(0,1fr))}}.m-stat{min-width:0;display:flex;align-items:center;gap:8px;padding:12px 10px;border-radius:16px;border:1px solid var(--border);background:#0c0e14e6}.m-stat__icon{width:32px;height:32px;flex:0 0 auto;display:grid;place-items:center;border-radius:10px}.m-stat--red .m-stat__icon{background:#fb71851a;color:var(--red)}.m-stat--amber .m-stat__icon{background:#fbbf241a;color:var(--amber)}.m-stat--green .m-stat__icon{background:#34d3991a;color:var(--green)}.m-stat--blue .m-stat__icon{background:#6366f11f;color:#818cf8}.m-stat--cyan .m-stat__icon{background:#22d3ee1a;color:#22d3ee}.m-stat__body{min-width:0}.m-stat__value{font-size:15px;font-weight:900;color:var(--text);letter-spacing:-.03em;white-space:nowrap}.m-stat__label{margin-top:2px;color:var(--sub);font-size:10px;font-weight:700;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.m-section{margin-top:16px}.m-section.history{margin-top:20px}.m-section.vendors{margin-top:14px}.m-section-head{display:flex;align-items:flex-end;justify-content:space-between;gap:12px;margin:0 2px 10px}.m-section-kicker{color:#6366f1;font-size:10px;font-weight:900;letter-spacing:.1em;text-transform:uppercase}.m-section-title{margin:3px 0 0;color:var(--text);font-size:16px;font-weight:900;letter-spacing:-.04em}.m-section-count{padding:4px 9px;border-radius:999px;background:#ffffff0d;border:1px solid var(--border);color:var(--sub);font-size:11px;font-weight:800}.m-vendor-list{display:flex;flex-direction:column;gap:8px}.m-vendor-card{display:flex;align-items:center;justify-content:space-between;gap:12px;padding:12px 14px;border-radius:18px;border:1px solid var(--border);background:#0c0e14eb}.m-vendor-main{display:flex;align-items:center;gap:10px;min-width:0}.m-vendor-avatar{width:40px;height:40px;flex:0 0 auto;display:grid;place-items:center;border-radius:14px;color:#c7d2fe;background:#6366f11f;border:1px solid rgba(99,102,241,.2);font-weight:900;font-size:15px}.m-vendor-info{min-width:0}.m-vendor-name{color:var(--text);font-size:14px;font-weight:900;letter-spacing:-.02em}.m-vendor-job{margin-top:2px;color:var(--sub);font-size:11.5px;font-weight:700;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.m-vendor-phone{margin-top:4px;display:flex;align-items:center;gap:5px;color:var(--sub);font-size:11.5px;font-weight:700}.m-vendor-actions{display:flex;align-items:center;gap:7px;flex:0 0 auto}.m-mini-icon{width:34px;height:34px;display:grid;place-items:center;border-radius:12px;border:1px solid var(--border);background:#ffffff0d;color:var(--sub);cursor:pointer;transition:transform .13s ease}.m-mini-icon.wa{color:var(--green);background:#34d39917;border-color:#34d3992e}.m-mini-icon:active{transform:scale(.94)}.m-room-list{display:flex;flex-direction:column;gap:10px}.m-room-card{padding:14px;border-radius:20px;border:1px solid var(--border);background:#0b0d13f5;will-change:transform}.m-room-card.ruko{border-color:#22d3ee24}.m-room-card__top{display:flex;align-items:flex-start;justify-content:space-between;gap:12px;margin-bottom:10px}.m-room-main{display:flex;align-items:center;gap:10px;min-width:0}.m-room-icon{width:36px;height:36px;flex:0 0 auto;display:grid;place-items:center;border-radius:12px;color:var(--muted);background:#ffffff0d;border:1px solid var(--border)}.m-room-title{color:var(--text);font-size:15px;font-weight:900;letter-spacing:-.03em;line-height:1.15}.m-room-sub{margin-top:3px;color:var(--sub);font-size:12px;font-weight:700;max-width:200px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.m-room-history-btn{width:100%;min-height:36px;display:flex;align-items:center;justify-content:center;gap:6px;margin:-2px 0 10px;border-radius:12px;border:1px solid var(--border);background:var(--divider);color:var(--sub);font-family:inherit;font-size:12px;font-weight:800;cursor:pointer;transition:color .13s ease,border-color .13s ease}.m-room-history-btn:hover{color:var(--muted);border-color:var(--border2)}.m-room-history-btn:active{transform:scale(.98)}.m-routine-grid{display:grid;grid-template-columns:1fr 1fr;gap:8px;margin-bottom:10px}.m-routine-meta{min-width:0;display:flex;align-items:flex-start;gap:8px;padding:10px;border-radius:14px;background:#070910b3;border:1px solid var(--border)}.m-routine-meta__icon{width:26px;height:26px;flex:0 0 auto;display:grid;place-items:center;border-radius:8px;color:var(--sub);background:#ffffff0d}.m-routine-meta__text{min-width:0;display:flex;flex-direction:column}.m-routine-meta__text span{color:var(--sub);font-size:10px;font-weight:800}.m-routine-meta__text strong{margin-top:2px;color:var(--text);font-size:12px;font-weight:800;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.m-routine-meta__text em{color:var(--sub);font-size:10px;font-style:normal;font-weight:700;line-height:1.3}.m-routine-meta__text small{margin-top:4px;color:var(--green);font-size:11px;font-weight:800}.m-routine-next{margin-top:5px;display:flex;flex-direction:column;gap:4px}.m-next-badge{display:inline-flex;align-items:center;width:max-content;max-width:100%;padding:2px 7px;border-radius:999px;border:1px solid var(--border);font-size:10px;font-weight:900;white-space:nowrap}.m-next-badge.safe{color:var(--green);background:#34d39917;border-color:#34d39933}.m-next-badge.soon{color:var(--amber);background:#fbbf2417;border-color:#fbbf2433}.m-next-badge.late{color:var(--red);background:#fb718517;border-color:#fb718533}.m-next-badge.empty{color:var(--sub);background:var(--divider);border-color:var(--border)}.m-room-actions{display:grid;grid-template-columns:1fr 1fr;gap:8px}.m-routine-btn{min-height:42px;display:flex;align-items:center;justify-content:center;gap:6px;border-radius:13px;border:1px solid var(--border);cursor:pointer;font-family:inherit;font-size:12px;font-weight:900;transition:transform .13s ease}.m-routine-btn.ac{color:#818cf8;background:#6366f117;border-color:#6366f133}.m-routine-btn.room{color:var(--green);background:#34d39917;border-color:#34d39933}.m-routine-btn.water{color:#22d3ee;background:#22d3ee17;border-color:#22d3ee33}.m-routine-btn.battery{color:var(--amber);background:#fbbf2417;border-color:#fbbf2433}.m-routine-btn:active{transform:scale(.97)}.m-list{display:flex;flex-direction:column;gap:8px}.m-card{border-radius:18px;background:#0b0d13f7;border:1px solid var(--border);overflow:hidden}.m-card--red{border-left:3px solid rgba(251,113,133,.5)}.m-card--amber{border-left:3px solid rgba(251,191,36,.5)}.m-card--green{border-left:3px solid rgba(52,211,153,.5)}.m-card__head{display:flex;align-items:center;justify-content:space-between;gap:8px;padding:12px 14px 6px;cursor:pointer;color:var(--sub)}.m-card__head-left{display:flex;align-items:center;gap:8px;min-width:0}.m-card__head-right{display:flex;align-items:center;gap:8px;flex:0 0 auto}.m-card__kamar{color:var(--sub);font-size:11px;font-weight:800;letter-spacing:.05em;text-transform:uppercase;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.m-card__biaya{color:var(--green);font-size:12px;font-weight:900;white-space:nowrap}.m-card__judul{padding:4px 14px 12px;color:var(--text);font-size:14px;font-weight:700;line-height:1.45}.m-card__detail{padding:12px 14px 14px;border-top:1px solid var(--divider);background:#07091040}.m-card__desc{margin:0 0 10px;color:var(--sub);font-size:13px;line-height:1.5}.m-card__meta{display:flex;flex-direction:column;gap:5px;margin-bottom:12px}.m-card__meta span{display:flex;align-items:center;gap:6px;color:var(--sub);font-size:11.5px;font-weight:650}.m-card__ledger{color:var(--green)!important;font-weight:800!important}.m-card__actions{display:flex;gap:7px;flex-wrap:wrap}.m-badge{display:inline-flex;align-items:center;gap:4px;padding:4px 9px;border-radius:999px;font-size:10.5px;font-weight:900;white-space:nowrap}.m-badge--red{background:#fb71851a;color:var(--red);border:1px solid rgba(251,113,133,.2)}.m-badge--amber{background:#fbbf241a;color:var(--amber);border:1px solid rgba(251,191,36,.2)}.m-badge--green{background:#34d3991a;color:var(--green);border:1px solid rgba(52,211,153,.2)}.m-proof-link{width:max-content;max-width:100%;display:inline-flex;align-items:center;gap:6px;margin-bottom:12px;padding:7px 11px;border-radius:10px;background:#6366f11a;border:1px solid rgba(99,102,241,.2);color:#a5b4fc;font-size:12px;font-weight:800;text-decoration:none;transition:background .13s ease}.m-proof-link.small{margin-top:9px;margin-bottom:0;padding:6px 9px;font-size:11.5px}.m-btn{display:inline-flex;align-items:center;justify-content:center;gap:6px;min-height:38px;padding:8px 14px;border-radius:12px;border:1px solid transparent;cursor:pointer;font-family:inherit;font-size:12.5px;font-weight:900;transition:transform .13s ease}.m-btn:disabled{opacity:.5;cursor:not-allowed}.m-btn:active:not(:disabled){transform:scale(.97)}.m-btn--primary{background:linear-gradient(135deg,#6366f1,#4f46e5);color:#fff;box-shadow:0 6px 16px #6366f140}.m-btn--green{background:#34d3991f;color:var(--green);border-color:#34d39938}.m-btn--amber{background:#fbbf241c;color:var(--amber);border-color:#fbbf2438}.m-btn--ghost{background:#ffffff0d;color:var(--sub);border-color:var(--border)}.m-state{display:flex;flex-direction:column;align-items:center;gap:10px;padding:48px 16px;color:var(--sub);font-size:13px;font-weight:700;text-align:center}.m-state.compact{padding:28px 14px}.m-state--error{color:var(--red)}.m-room-history{display:flex;flex-direction:column;gap:12px}.m-room-history-hero{display:flex;align-items:center;justify-content:space-between;gap:12px;padding:14px;border-radius:18px;border:1px solid rgba(99,102,241,.18);background:#6366f112}.m-room-history-room{color:var(--text);font-size:18px;font-weight:900;letter-spacing:-.04em}.m-room-history-tenant{margin-top:3px;color:var(--sub);font-size:12px;font-weight:700}.m-room-history-summary{display:grid;grid-template-columns:1fr;gap:8px}.m-room-history-title{color:var(--sub);font-size:10px;font-weight:900;letter-spacing:.1em;text-transform:uppercase;margin:2px 2px -2px}.m-room-history-list{display:flex;flex-direction:column;gap:8px}.m-room-history-item{padding:12px;border-radius:14px;border:1px solid var(--border);background:#070910b3}.m-room-history-item-top{display:flex;align-items:flex-start;justify-content:space-between;gap:10px}.m-room-history-item-title{color:var(--text);font-size:14px;font-weight:800;line-height:1.25}.m-room-history-item-date{margin-top:3px;color:var(--sub);font-size:11.5px;font-weight:700}.m-room-history-price{flex:0 0 auto;color:var(--green);font-size:13px;font-weight:900;white-space:nowrap}.m-room-history-line{margin-top:7px;color:var(--sub);font-size:12px;font-weight:700;line-height:1.4;overflow-wrap:anywhere}.m-form{display:flex;flex-direction:column;gap:14px}.m-field{display:flex;flex-direction:column;gap:7px}.m-label{display:flex;align-items:center;gap:6px;color:var(--sub);font-size:10.5px;font-weight:900;text-transform:uppercase;letter-spacing:.07em}.m-optional{color:var(--sub);font-weight:600;text-transform:none;letter-spacing:0}.m-hint{color:var(--green);font-size:11px;font-weight:700}.m-input,.m-select,.m-textarea{width:100%;padding:12px 14px;border-radius:14px;border:1px solid var(--border2);background:#070910e6;color:var(--text);font-size:14px;font-family:inherit;outline:none;transition:border-color .15s ease,box-shadow .15s ease}.m-input:focus,.m-select:focus,.m-textarea:focus{border-color:#6366f166;box-shadow:0 0 0 3px #6366f114}.m-select option{background:#0a0c12}.m-textarea{resize:vertical;line-height:1.5}.m-chips{display:flex;flex-wrap:wrap;gap:7px}.m-chip{padding:7px 13px;border-radius:999px;border:1px solid var(--border2);background:#0b0d13e6;color:var(--sub);font-size:12px;font-weight:800;cursor:pointer;font-family:inherit;transition:all .15s ease}.m-chip.active{color:#a5b4fc;background:#6366f124;border-color:#6366f152}.m-upload{min-height:52px;display:flex;align-items:center;justify-content:center;gap:8px;border-radius:14px;border:1px dashed rgba(99,102,241,.3);background:#6366f10d;color:var(--sub);font-size:13px;font-weight:800;cursor:pointer;transition:border-color .15s ease,color .15s ease}.m-upload:hover{border-color:#6366f180;color:#a5b4fc}.m-proof-preview{position:relative;overflow:hidden;border-radius:14px;border:1px solid var(--border);background:#070910e6}.m-proof-preview img{width:100%;height:160px;object-fit:cover;display:block}.m-proof-preview button{position:absolute;top:8px;right:8px;width:30px;height:30px;display:grid;place-items:center;border-radius:999px;border:1px solid rgba(255,255,255,.1);background:#070910cc;color:var(--text);cursor:pointer}.m-proof-pdf{min-height:80px;display:flex;align-items:center;justify-content:center;gap:8px;padding:14px;color:var(--text);font-size:13px;font-weight:800}.m-error{padding:10px 13px;border-radius:12px;color:var(--red);background:#fb718517;border:1px solid rgba(251,113,133,.2);font-size:13px;font-weight:700;line-height:1.4}.m-modal-actions{display:grid;grid-template-columns:1fr 1fr;gap:9px;margin-top:4px}.m-modal-actions .m-btn{min-height:46px;border-radius:14px;font-size:13px}.m-modal-actions .m-btn--primary{background:linear-gradient(135deg,#6366f1,#4f46e5);color:#fff;border:0;box-shadow:0 8px 20px #6366f140}.m-done-hero{display:flex;align-items:center;gap:12px;padding:14px;border-radius:18px;background:#0b0d13cc;border:1px solid var(--border)}.m-done-hero__icon{width:44px;height:44px;display:grid;place-items:center;flex:0 0 auto;border-radius:16px;color:var(--sub);background:#ffffff0d;border:1px solid var(--border)}.m-done-hero__icon.ac{color:#818cf8;background:#6366f11c;border-color:#6366f133}.m-done-hero__icon.room{color:var(--green);background:#34d3991c;border-color:#34d39933}.m-done-hero__icon.water{color:#22d3ee;background:#22d3ee1c;border-color:#22d3ee33}.m-done-hero__icon.battery{color:var(--amber);background:#fbbf241c;border-color:#fbbf2433}.m-done-hero__room{color:var(--sub);font-size:10.5px;font-weight:900;letter-spacing:.08em;text-transform:uppercase}.m-done-hero__title{margin-top:3px;color:var(--text);font-size:16px;font-weight:900;letter-spacing:-.03em}@media (max-width: 380px){.m-page{padding-left:12px;padding-right:12px}.m-stats{grid-template-columns:repeat(2,minmax(0,1fr))}.m-routine-grid,.m-room-actions,.m-room-history-summary{grid-template-columns:1fr}}:root{--ut2-bg: var(--bg);--ut2-surface: var(--surface);--ut2-raised: var(--lift);--ut2-hover: var(--lift);--ut2-border: var(--border);--ut2-border-md: var(--border2);--ut2-border-hi: rgba(255,255,255,.18);--ut2-text: var(--text);--ut2-muted: var(--muted);--ut2-dim: var(--sub);--ut2-blue: var(--blue);--ut2-font: var(--font);--ut2-mono: var(--mono)}.ut2-page{font-family:var(--ut2-font);color:var(--ut2-text);padding:16px 12px 100px;max-width:1100px;margin:0 auto;width:100%;box-sizing:border-box}.ut2-eyebrow{font-size:10px;font-weight:700;letter-spacing:.14em;text-transform:uppercase;color:var(--ut2-blue);margin-bottom:3px}.ut2-title{margin:0 0 4px;font-size:20px;font-weight:900;letter-spacing:-.3px}.ut2-sub{font-size:13px;color:var(--ut2-muted);margin:0 0 16px}.ut2-nav-wrap{margin-bottom:16px;display:grid;gap:10px}.ut2-nav-grid{display:grid;grid-template-columns:1fr 1fr;gap:10px}.ut2-nav-panel{border:1px solid var(--ut2-border);background:var(--ut2-surface);border-radius:14px;padding:10px}.ut2-nav-panel-label{font-size:9.5px;font-weight:700;text-transform:uppercase;letter-spacing:.12em;color:var(--ut2-dim);margin-bottom:8px}.ut2-nav-rooms{display:grid;grid-template-columns:1fr 1fr;gap:6px}.ut2-nav-bottom{display:grid;grid-template-columns:1fr 1fr;gap:8px}.ut2-nav-btn{font-family:var(--ut2-font);border:1px solid var(--ut2-border-md);background:var(--ut2-raised);color:var(--ut2-muted);padding:10px 12px;border-radius:10px;font-size:12.5px;font-weight:700;cursor:pointer;min-height:44px;display:flex;align-items:center;justify-content:center;transition:all .15s ease;-webkit-user-select:none;user-select:none}.ut2-nav-btn:hover{color:var(--ut2-text);border-color:var(--ut2-border-hi);background:var(--ut2-hover)}.ut2-nav-btn.active{background:var(--ut2-blue);border-color:var(--ut2-blue);color:#fff;box-shadow:0 4px 14px #3b82f64d}.ut2-nav-btn.big{border-radius:999px;font-size:13px}.ut2-nav-btn.big.active{background:var(--ut2-raised);border-color:var(--ut2-border-hi);color:var(--ut2-text);box-shadow:none}.ut2-state-msg{padding:32px 16px;text-align:center;color:var(--ut2-muted);font-size:13px;font-weight:600}.ut2-state-icon{font-size:28px;display:block;margin-bottom:8px;opacity:.5}.ut2-grid{display:grid;gap:12px;grid-template-columns:repeat(auto-fit,minmax(260px,1fr))}.ut2-card{border-radius:20px;border:1px solid var(--ut2-border);background:var(--ut2-surface);padding:14px;display:flex;flex-direction:column;gap:10px;box-shadow:0 1px #ffffff08 inset,0 16px 32px #0000004d;transition:border-color .2s ease;position:relative;overflow:hidden}.ut2-card:before{content:"";position:absolute;top:0;left:20px;right:20px;height:1px;background:linear-gradient(90deg,transparent,var(--border2),transparent)}.ut2-card.has-data{border-color:#3b82f626}.ut2-card-head{display:flex;align-items:flex-start;justify-content:space-between;gap:8px}.ut2-card-name{font-size:15px;font-weight:900;letter-spacing:-.1px;margin:0 0 4px}.ut2-card-date{font-size:10.5px;color:var(--ut2-dim);font-family:var(--ut2-mono)}.ut2-status-badge{display:inline-flex;align-items:center;gap:4px;padding:3px 9px;border-radius:999px;font-size:10px;font-weight:700;flex:0 0 auto}.ut2-status-badge.filled{background:#10b9811a;border:1px solid rgba(16,185,129,.3);color:#6ee7b7}.ut2-status-badge.empty{background:#f59e0b1a;border:1px solid rgba(245,158,11,.3);color:#fcd34d}.ut2-field-card{border-radius:12px;border:1px solid var(--ut2-border);background:var(--ut2-raised);padding:10px 12px;transition:border-color .15s ease}.ut2-field-card:hover{border-color:var(--ut2-border-md)}.ut2-fc-head{display:flex;align-items:center;justify-content:space-between;margin-bottom:6px}.ut2-fc-label{display:flex;align-items:center;gap:5px;font-size:10px;font-weight:700;letter-spacing:.1em;text-transform:uppercase;color:var(--fc-color, var(--ut2-muted))}.ut2-fc-icon{display:flex;color:var(--fc-color, var(--ut2-muted))}.ut2-fc-value{font-size:14px;font-weight:700;color:var(--ut2-text);font-family:var(--ut2-mono);background:var(--ut2-surface);border:1px solid var(--ut2-border);padding:8px 10px;border-radius:8px;min-height:38px;display:flex;align-items:center}.ut2-fc-value.empty{color:var(--ut2-dim);font-family:var(--ut2-font);font-size:12.5px;font-weight:600;font-style:italic}.ut2-ellipsis{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.ut2-copy-btn{font-family:var(--ut2-font);display:inline-flex;align-items:center;gap:4px;padding:4px 8px;border-radius:6px;border:1px solid var(--ut2-border-md);background:transparent;color:var(--ut2-muted);font-size:10px;font-weight:700;cursor:pointer;transition:all .15s ease}.ut2-copy-btn:hover{color:var(--ut2-text);border-color:var(--ut2-border-hi);background:var(--ut2-hover)}.ut2-reminder-box{border-radius:12px;border:1px solid var(--ut2-border);background:var(--ut2-raised);padding:10px;display:flex;flex-direction:column;gap:1px}.ut2-reminder-row{display:flex;align-items:center;justify-content:space-between;gap:8px;padding:7px 2px;border-bottom:1px solid var(--ut2-border)}.ut2-reminder-row:last-child{border-bottom:none}.ut2-rr-label{font-size:9.5px;font-weight:700;text-transform:uppercase;letter-spacing:.09em;color:var(--ut2-dim);margin-bottom:2px}.ut2-rr-day{font-size:12.5px;font-weight:700;color:var(--ut2-text)}.ut2-rr-right{text-align:right}.ut2-rr-next{font-size:11px;font-weight:600;color:var(--ut2-muted);font-family:var(--ut2-mono)}.ut2-rr-avg{font-size:11px;font-weight:700;color:#6ee7b7;margin-top:2px;font-family:var(--ut2-mono)}.ut2-card-photo{border-radius:10px;overflow:hidden;border:1px solid var(--ut2-border-md);cursor:zoom-in;position:relative}.ut2-card-photo img{width:100%;height:140px;object-fit:cover;display:block;transition:transform .2s ease}.ut2-card-photo:hover img{transform:scale(1.02)}.ut2-photo-tag{position:absolute;left:8px;top:8px;font-size:9.5px;font-weight:800;background:#04060fcc;padding:3px 7px;border-radius:999px;border:1px solid var(--ut2-border-hi);color:var(--ut2-text);-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}.ut2-edit-btn{font-family:var(--ut2-font);width:100%;padding:11px 14px;border-radius:12px;border:1px solid var(--ut2-border-md);background:var(--ut2-raised);color:var(--ut2-muted);font-size:13px;font-weight:700;cursor:pointer;display:flex;align-items:center;justify-content:center;gap:6px;transition:all .15s ease;margin-top:auto}.ut2-edit-btn:hover{color:var(--ut2-text);border-color:var(--ut2-blue);background:#3b82f614}.ut2-toast{position:fixed;right:16px;bottom:90px;z-index:999;background:var(--ut2-raised);border:1px solid var(--ut2-border-hi);color:var(--ut2-text);padding:9px 14px;border-radius:999px;font-size:12.5px;font-weight:700;box-shadow:0 10px 24px #0006;animation:ut2-toast-in .2s ease}@keyframes ut2-toast-in{0%{opacity:0;transform:translateY(6px)}to{opacity:1;transform:translateY(0)}}.ut2-preview-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;z-index:2000;background:#000000d9;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);display:grid;place-items:center;padding:16px}.ut2-preview{width:min(96vw,860px);border-radius:16px;border:1px solid var(--ut2-border-hi);background:var(--ut2-surface);overflow:hidden;box-shadow:0 24px 60px #000000b3}.ut2-preview-head{display:flex;justify-content:space-between;align-items:center;padding:12px 14px;border-bottom:1px solid var(--ut2-border)}.ut2-preview-title{font-size:14px;font-weight:800}.ut2-preview-close{font-family:var(--ut2-font);display:inline-flex;align-items:center;gap:5px;border:1px solid var(--ut2-border-md);background:transparent;color:var(--ut2-muted);padding:6px 11px;border-radius:8px;font-size:12px;font-weight:700;cursor:pointer;transition:all .15s ease}.ut2-preview-close:hover{color:var(--ut2-text);background:var(--ut2-raised)}.ut2-preview img{width:100%;max-height:78vh;object-fit:contain;display:block;background:var(--bg)}.ut2-modal-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;z-index:999;background:#000000b3;-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px);display:grid;place-items:center;padding:12px}.ut2-modal{width:min(96vw,560px);border-radius:20px;border:1px solid var(--ut2-border-hi);background:var(--surface);padding:18px;box-shadow:0 32px 64px #000000a6;max-height:92vh;overflow:auto}.ut2-modal-hdr{display:flex;align-items:flex-start;justify-content:space-between;gap:10px;margin-bottom:16px}.ut2-modal-eyebrow{font-size:10px;font-weight:700;letter-spacing:.12em;text-transform:uppercase;color:var(--ut2-blue);margin-bottom:2px}.ut2-modal-title{margin:0;font-size:16px;font-weight:900}.ut2-modal-close{font-family:var(--ut2-font);display:inline-flex;align-items:center;gap:5px;padding:6px 11px;border-radius:8px;border:1px solid var(--ut2-border-md);background:transparent;color:var(--ut2-muted);font-size:12px;font-weight:700;cursor:pointer;transition:all .15s ease;flex:0 0 auto}.ut2-modal-close:hover{color:var(--ut2-text);background:var(--ut2-raised)}.ut2-modal-meter-section{border:1px solid var(--ut2-border);border-radius:14px;padding:12px;margin-bottom:10px;background:var(--ut2-raised)}.ut2-mms-head{display:flex;align-items:center;gap:6px;margin-bottom:8px}.ut2-mms-icon{color:var(--ms-color, var(--ut2-muted));display:flex}.ut2-mms-label{font-size:10px;font-weight:700;letter-spacing:.1em;text-transform:uppercase;color:var(--ms-color, var(--ut2-muted))}.ut2-input{font-family:var(--ut2-font);width:100%;box-sizing:border-box;padding:10px 12px;min-height:44px;border-radius:10px;border:1px solid var(--ut2-border-md);background:var(--ut2-surface);color:var(--ut2-text);font-size:14px;font-weight:600;outline:none;transition:border-color .15s ease,box-shadow .15s ease}.ut2-input:focus{border-color:var(--ut2-blue);box-shadow:0 0 0 3px #3b82f626}.ut2-input.invalid{border-color:#ef4444;box-shadow:0 0 0 2px #ef444426}.ut2-error{font-size:12px;color:#fca5a5;font-weight:700;margin-top:4px}.ut2-photo-section{margin-top:10px}.ut2-photo-section-label{font-size:10px;font-weight:700;text-transform:uppercase;letter-spacing:.09em;color:var(--ut2-dim);margin-bottom:7px}.ut2-upload-row{display:flex;gap:6px;align-items:center}.ut2-file-label{font-family:var(--ut2-font);display:inline-flex;align-items:center;gap:5px;padding:7px 12px;border-radius:8px;border:1px dashed var(--ut2-border-hi);background:transparent;color:var(--ut2-muted);font-size:12px;font-weight:700;cursor:pointer;transition:all .15s ease}.ut2-file-label:hover{border-color:var(--ut2-blue);color:#93c5fd;background:#3b82f60d}.ut2-clear-btn{font-family:var(--ut2-font);display:inline-flex;align-items:center;gap:4px;padding:7px 10px;border-radius:8px;border:1px solid rgba(239,68,68,.3);background:#ef444414;color:#fca5a5;font-size:11px;font-weight:700;cursor:pointer;transition:all .15s ease}.ut2-clear-btn:hover{background:#ef444426}.ut2-photo-thumb{margin-top:8px;border-radius:10px;overflow:hidden;border:1px solid var(--ut2-border-md);cursor:zoom-in;position:relative}.ut2-photo-thumb img{width:100%;height:140px;object-fit:cover;display:block}.ut2-modal-section{border-top:1px solid var(--ut2-border);padding-top:14px;margin-top:4px}.ut2-modal-section-title{font-size:10px;font-weight:700;text-transform:uppercase;letter-spacing:.12em;color:var(--ut2-muted);margin-bottom:10px}.ut2-modal-row{display:grid;grid-template-columns:1fr 1fr;gap:8px}.ut2-modal-field{display:flex;flex-direction:column;gap:5px}.ut2-modal-field label{font-size:10px;font-weight:700;text-transform:uppercase;letter-spacing:.08em;color:var(--ut2-dim)}.ut2-mini{font-size:11px;color:var(--ut2-muted);font-family:var(--ut2-mono);margin-top:3px}.ut2-modal-actions{display:flex;gap:8px;margin-top:16px;position:sticky;bottom:-18px;background:linear-gradient(to bottom,transparent,var(--surface) 40%);padding-top:12px}.ut2-btn{font-family:var(--ut2-font);flex:1;padding:11px 14px;border-radius:12px;border:1px solid var(--ut2-border-md);background:var(--ut2-raised);color:var(--ut2-muted);font-size:13px;font-weight:800;cursor:pointer;transition:all .15s ease}.ut2-btn:hover{color:var(--ut2-text);background:var(--ut2-hover)}.ut2-btn.primary{background:var(--ut2-blue);border-color:var(--ut2-blue);color:#fff;box-shadow:0 4px 14px #3b82f640}.ut2-btn.primary:hover{background:#2563eb}.ut2-btn:disabled,.ut2-btn.primary:disabled{opacity:.5;pointer-events:none;cursor:not-allowed}@media (max-width: 640px){.ut2-grid{grid-template-columns:1fr}.ut2-page{padding-left:8px;padding-right:8px}}@media (max-width: 540px){.ut2-nav-grid{grid-template-columns:1fr}}@media (max-width: 480px){.ut2-modal-row{grid-template-columns:1fr}}.arsip-page{max-width:520px;margin:0 auto;padding:16px 16px 90px}.arsip-header{display:flex;align-items:flex-start;justify-content:space-between;gap:12px;margin-bottom:12px}.arsip-header-copy{min-width:0}.page-kicker,.section-kicker{font-size:11px;text-transform:uppercase;letter-spacing:.12em;color:var(--muted);font-weight:800;margin-bottom:4px}.title{margin:0;font-size:1.32rem;font-weight:900;letter-spacing:-.02em;line-height:1.1}.subtext{margin:6px 0 0;font-size:.88rem;line-height:1.45;max-width:40ch}.range-filter{display:flex;flex-wrap:wrap;gap:8px;justify-content:flex-end}.range-btn{min-height:34px;padding:0 12px;border-radius:999px;border:1px solid var(--border2);background:var(--divider);color:var(--muted);font-size:12px;font-weight:800;cursor:pointer;transition:all .15s ease}.range-btn:hover{transform:translateY(-1px);border-color:var(--border2)}.range-btn.active{background:var(--green-bg);border-color:var(--green-bd);color:var(--green)}.section-headline{padding:2px 2px 0}.section-title{font-size:1rem;font-weight:800;color:var(--text)}.list{display:flex;flex-direction:column;gap:12px;margin-top:10px}.arsip-card{background:var(--surface);padding:14px;border-radius:20px;border:1px solid var(--border2);box-shadow:0 10px 30px #0f172ad9,inset 0 1px #ffffff05}.income-card{background:radial-gradient(circle at top left,rgba(34,197,94,.1),transparent 30%),var(--surface)}.summary-card{background:radial-gradient(circle at top left,rgba(34,197,94,.16),transparent 32%),var(--surface)}.hero-card{padding:16px}.hero-top{display:flex;justify-content:space-between;align-items:flex-start;gap:14px}.hero-left{display:flex;align-items:center;gap:12px;min-width:0}.hero-icon{width:44px;height:44px;border-radius:14px;display:grid;place-items:center;font-size:20px;background:#22c55e1f;border:1px solid rgba(34,197,94,.18);flex:0 0 auto}.hero-title{font-size:1.06rem}.hero-total{font-size:1.1rem}.hero-meta-grid{display:grid;grid-template-columns:1fr;gap:8px;margin-top:14px}.meta-pill{display:flex;align-items:center;justify-content:space-between;gap:10px;border:1px solid var(--border2);border-radius:14px;padding:10px 12px;background:#ffffff08}.meta-label{font-size:12px;color:var(--muted);font-weight:700}.meta-value{font-size:12px;color:var(--text);font-weight:800;text-align:right}.head{align-items:center;gap:12px}.month-copy{min-width:0}.month{font-size:1.02rem;font-weight:800;line-height:1.2;color:var(--text)}.month-sub{font-size:12px;color:var(--muted);margin-top:4px;font-weight:700}.badge-month{display:inline-flex;padding:4px 10px;border-radius:999px;border:1px solid var(--border2);font-size:.68rem;text-transform:uppercase;letter-spacing:.08em;color:var(--muted);margin-bottom:6px;font-weight:800;background:#ffffff08}.total-wrap{display:flex;flex-direction:column;align-items:flex-end;gap:3px;flex:0 0 auto}.total-label{font-size:11px;color:var(--muted);text-transform:uppercase;letter-spacing:.08em;font-weight:800}.total{font-size:1rem;font-weight:900;white-space:nowrap}.total.income{color:#86efac}.card-divider{height:1px;background:var(--border);margin:12px 0 10px}.modern-btn-row{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:10px}.modern-btn-row .btn:nth-child(3){grid-column:1 / -1}.btn.action{min-height:42px;border-radius:14px;background:var(--lift);border:1px solid var(--border2);color:var(--text);padding:8px 12px;cursor:pointer;display:inline-flex;align-items:center;justify-content:center;gap:8px;font-weight:800;transition:transform .12s ease,border-color .15s ease,opacity .15s ease}.btn.action:hover{transform:translateY(-1px);border-color:var(--border2)}.btn.action:disabled{opacity:.65;cursor:not-allowed;transform:none}.btn.action.primary-soft{background:var(--green-bg);border-color:var(--green-bd)}.loading-grid{display:flex;flex-direction:column;gap:12px;margin-top:16px}.skeleton-card{border-radius:20px;border:1px solid var(--border);padding:14px;background:var(--surface);box-shadow:0 10px 30px #0f172aa6;display:flex;flex-direction:column;gap:12px}.sk-line{height:16px;border-radius:999px;background:linear-gradient(90deg,var(--surface),var(--lift),var(--surface));background-size:200% 100%;animation:shimmer 1.1s infinite}.sk-line.lg{width:74%}.sk-btn-row{display:grid;grid-template-columns:1fr 1fr;gap:10px}.sk-btn{height:42px;border-radius:14px;background:linear-gradient(90deg,var(--surface),var(--lift),var(--surface));background-size:200% 100%;animation:shimmer 1.1s infinite}@keyframes shimmer{0%{background-position:200% 0}to{background-position:-200% 0}}.empty-state{display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center;gap:8px;padding:30px 18px;border-radius:20px;border:1px dashed var(--border2);background:#ffffff05}.empty-icon{width:52px;height:52px;border-radius:16px;display:grid;place-items:center;font-size:24px;background:#94a3b814}.empty-title{font-size:1rem;font-weight:800;color:var(--text)}.empty-text{font-size:.9rem;color:var(--muted);line-height:1.5;max-width:34ch}.modern-modal-shell{border-radius:18px;overflow:hidden}@media (max-width:640px){.arsip-header{flex-direction:column}.range-filter{justify-content:flex-start}.hero-top{flex-direction:column;align-items:flex-start}.head{align-items:flex-start;flex-direction:column}.total-wrap{align-items:flex-start}}.ap-page{max-width:430px;margin:0 auto;padding:0 0 100px;font-family:inherit}.ap-header{display:flex;align-items:flex-start;justify-content:space-between;gap:12px;margin-bottom:14px}.ap-kicker{font-size:10px;text-transform:uppercase;letter-spacing:.1em;color:var(--sub);font-weight:500;margin-bottom:4px}.ap-title{margin:0;font-size:18px;font-weight:600;letter-spacing:-.4px;color:var(--text);line-height:1}.ap-sub{margin:5px 0 0;font-size:12px;color:var(--sub);line-height:1.5;max-width:32ch}.ap-seg{display:flex;flex-direction:column;gap:3px;background:var(--surface);border:1px solid var(--border);border-radius:14px;padding:3px;flex-shrink:0}.ap-seg-btn{border:none;background:transparent;color:var(--sub);padding:6px 10px;border-radius:10px;font-size:11.5px;font-weight:500;font-family:inherit;cursor:pointer;white-space:nowrap;transition:background .15s ease,color .15s ease;-webkit-tap-highlight-color:transparent}.ap-seg-btn.on{background:var(--lift);color:var(--text)}.ap-skeleton-list,.ap-list{display:flex;flex-direction:column;gap:8px}.ap-section-hdr{display:flex;align-items:center;justify-content:space-between;padding:2px 2px 0}.ap-section-label{font-size:12px;font-weight:600;color:var(--text)}.ap-section-count{font-size:11px;color:var(--sub)}.ap-card{border-radius:18px;border:1px solid var(--border);background:var(--surface);padding:14px}.ap-hero{border-color:var(--red-bd);background:var(--red-bg)}.ap-hero-label{font-size:10.5px;text-transform:uppercase;letter-spacing:.08em;color:var(--sub);font-weight:500;margin-bottom:6px}.ap-hero-value{font-size:26px;font-weight:600;color:var(--red);letter-spacing:-.8px;font-family:monospace;line-height:1;margin-bottom:14px}.ap-hero-stats{display:flex;align-items:stretch;gap:0;border:1px solid var(--border);border-radius:12px;overflow:hidden}.ap-hero-stat{flex:1;padding:10px 12px;display:flex;flex-direction:column;gap:3px}.ap-hero-stat-divider{width:1px;background:var(--border);flex-shrink:0}.ap-hero-stat-label{font-size:10px;color:var(--sub);font-weight:500}.ap-hero-stat-value{font-size:12px;font-weight:600;color:var(--text);font-family:monospace}.ap-month-card{padding:13px 14px}.ap-month-top{display:flex;align-items:flex-start;justify-content:space-between;gap:12px}.ap-month-left{min-width:0}.ap-month-name{font-size:14px;font-weight:600;color:var(--text);letter-spacing:-.1px}.ap-month-meta{font-size:11px;color:var(--sub);margin-top:3px}.ap-month-right{text-align:right;flex-shrink:0}.ap-month-total-label{font-size:10px;color:var(--sub);text-transform:uppercase;letter-spacing:.06em;margin-bottom:3px}.ap-month-total{font-size:15px;font-weight:600;color:var(--red);font-family:monospace;letter-spacing:-.2px;white-space:nowrap}.ap-month-divider{height:1px;background:var(--border);margin:12px 0 10px}.ap-month-actions{display:grid;grid-template-columns:1fr 1fr 1fr;gap:6px}.ap-btn{min-height:40px;border-radius:12px;font-size:12.5px;font-weight:500;font-family:inherit;cursor:pointer;display:inline-flex;align-items:center;justify-content:center;gap:6px;transition:background .15s ease,border-color .15s ease;-webkit-tap-highlight-color:transparent;border:1px solid transparent}.ap-btn:disabled{opacity:.55;cursor:default}.ap-btn-detail{background:var(--red-bg);border-color:var(--red-bd);color:var(--red)}.ap-btn-detail:active{background:#fb71852e}.ap-btn-ghost{background:var(--lift);border-color:var(--border2);color:var(--sub)}.ap-btn-ghost:active{background:var(--border);color:var(--text)}.ap-empty{display:flex;flex-direction:column;align-items:center;text-align:center;gap:8px;padding:32px 18px;border-radius:18px;border:1px dashed var(--border2)}.ap-empty-icon{font-size:28px}.ap-empty-title{font-size:14px;font-weight:600;color:var(--text)}.ap-empty-sub{font-size:12px;color:var(--sub);line-height:1.5;max-width:28ch}.skeleton-card{border-radius:18px;border:1px solid var(--border);padding:14px;background:var(--surface);display:flex;flex-direction:column;gap:10px}.sk-line{height:14px;border-radius:999px;background:var(--lift);animation:ap-pulse 1.2s ease-in-out infinite}.sk-line.half{width:60%}.sk-line.sm{width:32%}.sk-line.lg{width:78%}.sk-btn-row{display:grid;grid-template-columns:1fr 1fr;gap:8px}.sk-btn{height:40px;border-radius:12px;background:var(--lift);animation:ap-pulse 1.2s ease-in-out infinite}@keyframes ap-pulse{0%,to{opacity:.4}50%{opacity:.7}}.ap-modal-shell{border-radius:14px;overflow:hidden}.ap-muted{font-size:13px;color:var(--sub)}.ap-iframe{width:100%;height:78vh;border:1px solid var(--border);border-radius:12px;background:var(--bg)}.aed-wrap{display:flex;flex-direction:column;gap:10px;padding:12px;background:var(--surface);font-family:inherit}.aed-topbar{display:flex;align-items:flex-start;justify-content:space-between;gap:12px}.aed-kicker{font-size:10px;text-transform:uppercase;letter-spacing:.1em;color:var(--sub);font-weight:500;margin-bottom:3px}.aed-title{font-size:14px;font-weight:600;color:var(--text)}.aed-total-chip{flex-shrink:0;padding:5px 12px;border-radius:999px;background:var(--red-bg);border:1px solid var(--red-bd);color:var(--red);font-size:12px;font-weight:600;font-family:monospace}.aed-error{display:flex;justify-content:space-between;align-items:center;gap:8px;padding:11px 13px;border-radius:12px;border:1px solid var(--red-bd);background:var(--red-bg);color:var(--red);font-size:13px}.aed-ctrl-btn{border:1px solid var(--red-bd);background:transparent;color:var(--red);padding:5px 10px;border-radius:999px;font-size:11.5px;cursor:pointer;font-family:inherit}.aed-skeleton-stack{display:flex;flex-direction:column;gap:8px}.aed-skeleton{border-radius:14px;border:1px solid var(--border);background:var(--lift);padding:14px;display:flex;flex-direction:column;gap:8px}.aed-sk-line{height:13px;width:100%;border-radius:8px;background:var(--divider);animation:aed-pulse 1.3s ease-in-out infinite}@keyframes aed-pulse{0%,to{opacity:.35}50%{opacity:.7}}.aed-empty{display:flex;flex-direction:column;align-items:center;text-align:center;gap:8px;padding:28px 16px;border-radius:14px;border:1px dashed var(--border2)}.aed-empty-icon{font-size:26px}.aed-empty-title{font-size:14px;font-weight:600;color:var(--text)}.aed-empty-sub{font-size:12px;color:var(--sub)}.aed-groups{display:flex;flex-direction:column;gap:8px}.aed-group{border-radius:14px;border:1px solid var(--border);background:var(--lift);overflow:hidden;border-left:3px solid var(--red-bd)}.aed-group-hdr{padding:11px 14px;border-bottom:1px solid var(--divider)}.aed-group-date{font-size:13px;font-weight:600;color:var(--text)}.aed-group-sub{font-size:11px;color:var(--sub);margin-top:2px}.aed-items{display:flex;flex-direction:column}.aed-item{padding:12px 14px;border-top:1px solid var(--divider);display:flex;flex-direction:column;gap:9px}.aed-item:first-child{border-top:none}.aed-item-top{display:flex;align-items:flex-start;justify-content:space-between;gap:10px}.aed-item-left{flex:1;min-width:0;display:flex;flex-direction:column;gap:3px}.aed-item-right{flex-shrink:0;display:flex;flex-direction:column;align-items:flex-end;gap:6px}.aed-item-kategori{font-size:14px;font-weight:600;color:var(--text);line-height:1.3}.aed-item-sub{font-size:11px;color:var(--sub)}.aed-amount{font-size:14px;font-weight:600;color:var(--red);white-space:nowrap;font-family:monospace}.aed-item-actions{display:flex;gap:5px}.aed-btn-edit{border:1px solid var(--border2);background:var(--divider);color:var(--sub);font-size:11px;font-weight:500;padding:4px 10px;border-radius:999px;cursor:pointer;font-family:inherit}.aed-btn-del{border:1px solid var(--red-bd);background:var(--red-bg);color:var(--red);font-size:11px;font-weight:500;padding:4px 10px;border-radius:999px;cursor:pointer;font-family:inherit}.aed-info-grid{display:flex;flex-direction:column;gap:5px;background:#ffffff06;border-radius:10px;padding:9px 12px}.aed-info-row{display:flex;gap:6px;align-items:baseline}.aed-info-label{font-size:11px;color:var(--sub);font-weight:500;white-space:nowrap;min-width:65px}.aed-info-value{font-size:12.5px;color:var(--text);word-break:break-word;line-height:1.4}.aed-bukti-btn{width:100%;padding:9px 14px;border-radius:10px;border:1px solid var(--red-bd);background:var(--red-bg);color:var(--red);font-size:12.5px;font-weight:500;cursor:pointer;font-family:inherit;text-align:left}.aed-modal-body{display:flex;flex-direction:column;gap:12px;padding:2px 0}.aed-muted{font-size:13px;color:var(--sub)}.aed-edit-id{font-size:10px;color:var(--sub);word-break:break-all;font-family:monospace}.aed-form-section{display:flex;flex-direction:column;gap:10px;border:1px solid var(--border);border-radius:14px;padding:13px;background:#ffffff05}.aed-form-title{font-size:11px;text-transform:uppercase;letter-spacing:.08em;color:var(--sub);font-weight:500}.aed-field{display:flex;flex-direction:column;gap:7px}.aed-field-label{font-size:10.5px;text-transform:uppercase;letter-spacing:.07em;color:var(--sub);font-weight:500}.aed-input{border-radius:11px;border:1px solid var(--border2);background:var(--lift);color:var(--text);padding:10px 13px;font-size:14px;font-family:inherit;outline:none;transition:border-color .15s ease}.aed-input:focus{border-color:var(--red-bd)}.aed-chips{display:flex;flex-wrap:wrap;gap:6px}.aed-chip{padding:7px 12px;border-radius:999px;border:1px solid var(--border2);background:var(--lift);color:var(--sub);font-size:12.5px;font-weight:500;font-family:inherit;cursor:pointer;line-height:1;transition:background .12s ease,border-color .12s ease,color .12s ease;-webkit-tap-highlight-color:transparent}.aed-chip.on{background:var(--red-bg);border-color:var(--red-bd);color:var(--red)}.aed-modal-actions{display:grid;grid-template-columns:1fr 1fr;gap:8px}.aed-btn-save{padding:15px;border-radius:12px;border:none;background:var(--green);color:#0a0f0a;font-size:14px;font-weight:600;cursor:pointer;font-family:inherit;transition:opacity .15s ease}.aed-btn-save:disabled{opacity:.55}.aed-btn-cancel{padding:15px;border-radius:12px;border:1px solid var(--border2);background:var(--lift);color:var(--text);font-size:14px;font-weight:500;cursor:pointer;font-family:inherit}.aed-bukti-iframe{width:100%;height:70vh;border:1px solid var(--border);border-radius:12px;background:var(--bg)}.aed-bukti-img{width:100%;max-height:70vh;object-fit:contain;border-radius:12px;border:1px solid var(--border)}@media (max-width:480px){.ap-header{flex-direction:column}.ap-seg{flex-direction:row}.ap-month-actions{grid-template-columns:1fr 1fr}.ap-month-actions .ap-btn:first-child{grid-column:1 / -1}}:root{--ez-bg: var(--bg);--ez-surface: var(--surface);--ez-raised: var(--lift);--ez-hover: var(--lift);--ez-border: var(--border);--ez-border-md: var(--border2);--ez-border-hi: rgba(255,255,255,.18);--ez-text: var(--text);--ez-muted: var(--muted);--ez-dim: var(--sub);--ez-blue: var(--blue);--ez-green: var(--green);--ez-font: var(--font);--ez-mono: var(--mono)}.ez-wrap{font-family:var(--ez-font);min-height:100vh;background:radial-gradient(ellipse 70% 40% at 20% 0%,rgba(59,130,246,.08) 0,transparent 60%),radial-gradient(ellipse 50% 35% at 80% 80%,rgba(16,185,129,.06) 0,transparent 55%),var(--ez-bg);color:var(--ez-text);padding:0 12px 100px}.ez-header{position:sticky;top:0;z-index:20;padding:16px 0 12px;background:linear-gradient(to bottom,rgba(4,6,15,.98) 0%,rgba(4,6,15,.9) 70%,transparent 100%);backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);margin-bottom:14px}.ez-header-top{display:flex;align-items:flex-start;justify-content:space-between;gap:10px;margin-bottom:10px}.ez-eyebrow{font-size:10px;font-weight:700;letter-spacing:.14em;text-transform:uppercase;color:var(--ez-blue);margin-bottom:3px}.ez-title{margin:0 0 3px;font-size:20px;font-weight:900;letter-spacing:-.3px}.ez-updated{font-size:11px;color:var(--ez-dim);font-family:var(--ez-mono)}.ez-refresh-btn{font-family:var(--ez-font);display:inline-flex;align-items:center;gap:6px;padding:8px 13px;border-radius:999px;border:1px solid var(--ez-border-md);background:var(--ez-surface);color:var(--ez-muted);font-size:12px;font-weight:700;cursor:pointer;transition:all .15s ease;white-space:nowrap}.ez-refresh-btn:hover{color:var(--ez-text);border-color:var(--ez-border-hi);background:var(--ez-raised)}.ez-refresh-btn:disabled{opacity:.5;pointer-events:none}.ez-summary-row{display:flex;gap:6px;flex-wrap:wrap;margin-bottom:10px}.ez-summary-pill{display:inline-flex;align-items:center;gap:5px;padding:4px 10px;border-radius:999px;background:var(--ez-surface);border:1px solid var(--ez-border-md);font-size:11px;font-weight:700;color:var(--ez-muted)}.ez-summary-pill.total{color:var(--ez-text)}.ez-summary-dot{width:6px;height:6px;border-radius:50%}.online-dot{background:var(--ez-green);box-shadow:0 0 5px #10b981b3}.offline-dot{background:var(--ez-dim)}.ez-filter-row{display:flex;gap:6px;align-items:center;flex-wrap:wrap}.ez-chip{font-family:var(--ez-font);border:1px solid var(--ez-border-md);background:var(--ez-surface);color:var(--ez-muted);padding:7px 12px;border-radius:999px;font-size:12px;font-weight:700;cursor:pointer;display:inline-flex;align-items:center;gap:6px;transition:all .15s ease}.ez-chip:hover{color:var(--ez-text);border-color:var(--ez-border-hi)}.ez-chip.active{background:#3b82f61f;border-color:#3b82f666;color:#93c5fd}.ez-chip-badge{padding:1px 7px;border-radius:999px;font-size:10px;font-weight:800;background:var(--ez-raised);border:1px solid var(--ez-border-md);color:var(--ez-muted)}.ez-chip.active .ez-chip-badge{background:#3b82f626;border-color:#3b82f64d;color:#93c5fd}.ez-filter-spacer{flex:1}.ez-search-wrap{position:relative}.ez-search-icon{position:absolute;left:10px;top:50%;transform:translateY(-50%);color:var(--ez-dim);pointer-events:none;display:flex}.ez-search{font-family:var(--ez-font);padding:8px 12px 8px 30px;border:1px solid var(--ez-border-md);border-radius:999px;background:var(--ez-surface);color:var(--ez-text);font-size:12.5px;font-weight:600;min-width:180px;transition:border-color .15s ease,box-shadow .15s ease}.ez-search::placeholder{color:var(--ez-dim)}.ez-search:focus{outline:none;border-color:var(--ez-blue);box-shadow:0 0 0 3px #3b82f61f}.ez-error{display:flex;align-items:center;gap:8px;margin-top:8px;padding:10px 13px;border-radius:12px;border:1px solid var(--red-bd);background:var(--red-bg);color:#fca5a5;font-size:13px;font-weight:600}.ez-skeleton-grid{display:grid;gap:10px;grid-template-columns:repeat(auto-fill,minmax(240px,1fr))}.ez-skeleton-card{border-radius:18px;border:1px solid var(--ez-border);background:var(--ez-surface);padding:14px;display:flex;flex-direction:column;gap:8px;position:relative;overflow:hidden}.ez-skeleton-card:after{content:"";position:absolute;top:0;right:0;bottom:0;left:0;background:linear-gradient(90deg,transparent,var(--divider),transparent);background-size:200% 100%;animation:ez-shimmer 1.4s infinite linear}@keyframes ez-shimmer{0%{background-position:200% 0}to{background-position:-200% 0}}.ez-skeleton-line{height:11px;border-radius:6px;background:var(--border)}.w40{width:40%}.w50{width:50%}.w60{width:60%}.w80{width:80%}.ez-cards{display:grid;gap:10px;grid-template-columns:1fr}@media (min-width:520px){.ez-cards{grid-template-columns:repeat(2,1fr)}}@media (min-width:800px){.ez-cards{grid-template-columns:repeat(3,1fr)}}@media (min-width:1100px){.ez-cards{grid-template-columns:repeat(4,1fr)}}.ez-card{border-radius:18px;border:1px solid var(--ez-border);background:var(--ez-surface);padding:13px 13px 11px;display:flex;flex-direction:column;gap:10px;position:relative;overflow:hidden;transition:transform .12s ease,border-color .15s ease}.ez-card:hover{transform:translateY(-2px)}.ez-card-online{border-color:#10b98140}.ez-card-offline{opacity:.75}.ez-card-accent{position:absolute;top:0;left:20px;right:20px;height:1px;border-radius:0 0 2px 2px}.ez-card-head{display:flex;align-items:flex-start;justify-content:space-between;gap:8px}.ez-card-head-left{display:flex;align-items:center;gap:9px}.ez-card-icon{width:36px;height:36px;border-radius:10px;background:var(--ez-raised);border:1px solid var(--ez-border-md);display:grid;place-items:center;font-size:17px;flex:0 0 auto}.ez-card-name{font-size:13.5px;font-weight:800;color:var(--ez-text);letter-spacing:-.1px}.ez-card-serial{font-size:10.5px;color:var(--ez-dim);font-family:var(--ez-mono);margin-top:1px}.ez-status-dot{font-size:10px;font-weight:700;padding:3px 9px;border-radius:999px;white-space:nowrap;flex:0 0 auto}.ez-status-dot.online{background:#10b9811f;border:1px solid rgba(16,185,129,.35);color:#6ee7b7;animation:ez-pulse-green 2.5s ease-in-out infinite}.ez-status-dot.offline{background:#64748b1a;border:1px solid rgba(100,116,139,.25);color:var(--ez-dim)}@keyframes ez-pulse-green{0%,to{box-shadow:0 0 #10b98100}50%{box-shadow:0 0 0 3px #10b98126}}.ez-card-badges{display:flex;gap:5px;flex-wrap:wrap}.ez-type-badge{display:inline-flex;align-items:center;gap:4px;font-size:10px;font-weight:700;padding:2px 8px;border-radius:999px}.ez-type-badge.wifi{background:#0ea5e91a;border:1px solid rgba(14,165,233,.3);color:#7dd3fc}.ez-type-badge.wire{background:#6366f11a;border:1px solid rgba(99,102,241,.3);color:#a5b4fc}.ez-cat-badge{font-size:10px;font-weight:700;padding:2px 8px;border-radius:999px;background:#10b98114;border:1px solid rgba(16,185,129,.2);color:#6ee7b7}.ez-model-badge{font-size:10px;font-weight:700;padding:2px 8px;border-radius:999px;background:var(--ez-raised);border:1px solid var(--ez-border-md);color:var(--ez-muted);font-family:var(--ez-mono)}.ez-kv-grid{display:grid;grid-template-columns:1fr 1fr;gap:8px}.ez-kv-item{display:flex;flex-direction:column;gap:2px}.ez-kv-label{font-size:9.5px;font-weight:700;text-transform:uppercase;letter-spacing:.09em;color:var(--ez-dim)}.ez-kv-value{font-size:12.5px;font-weight:700;color:var(--ez-text);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.ez-kv-value.mono{font-family:var(--ez-mono);font-size:11.5px}.ez-signal-section{display:flex;flex-direction:column;gap:5px}.ez-signal-wrap{display:flex;align-items:center;gap:8px}.ez-signal-track{flex:1;height:4px;border-radius:999px;background:var(--border);overflow:hidden}.ez-signal-fill{height:100%;border-radius:999px;transition:width .5s ease}.ez-signal-pct{font-size:11.5px;font-weight:800;font-family:var(--ez-mono);white-space:nowrap}.ez-card-footer{margin-top:auto}.ez-detail-btn{font-family:var(--ez-font);width:100%;display:flex;align-items:center;justify-content:center;gap:6px;padding:8px 12px;border-radius:10px;border:1px solid var(--ez-border-md);background:transparent;color:var(--ez-muted);font-size:12px;font-weight:700;cursor:pointer;transition:all .15s ease}.ez-detail-btn:hover{color:var(--ez-text);border-color:var(--ez-border-hi);background:var(--ez-raised)}.ez-empty{grid-column:1/-1;padding:40px 20px;text-align:center;color:var(--ez-dim);font-size:13px;font-weight:600}.ez-empty-icon{font-size:30px;display:block;margin-bottom:10px;opacity:.4}.ez-btn{font-family:var(--ez-font);padding:6px 12px;border:1px solid var(--ez-border-md);background:var(--ez-raised);border-radius:8px;font-size:12px;font-weight:700;color:var(--ez-muted);cursor:pointer;transition:all .15s ease}.ez-btn:hover{color:var(--ez-text)}@media (max-width:480px){.ez-search{min-width:130px}.ez-filter-spacer{display:none}}:root{--ip-bg: var(--bg);--ip-surface: var(--surface);--ip-lift: var(--lift);--ip-border: var(--border);--ip-border2: var(--border2);--ip-text: var(--text);--ip-sub: var(--sub);--ip-dim: var(--dim);--ip-green: var(--green);--ip-red: var(--red);--ip-amber: var(--amber);--ip-blue: var(--blue);--ip-font: var(--font);--ip-mono: var(--mono)}.ip-wrap,.ip-wrap *{box-sizing:border-box}.ip-wrap{max-width:430px;margin:0 auto;padding:0 0 100px;font-family:var(--ip-font);color:var(--ip-text);-webkit-font-smoothing:antialiased}.ip-header{margin-bottom:14px}.ip-eyebrow{font-size:10px;text-transform:uppercase;letter-spacing:.1em;color:var(--ip-sub);font-weight:500;margin-bottom:4px}.ip-title{margin:0 0 10px;font-size:18px;font-weight:600;letter-spacing:-.4px;line-height:1}.ip-summary-row{display:flex;gap:8px}.ip-summary-chip{display:flex;align-items:center;gap:6px;padding:6px 12px;border-radius:999px;background:var(--ip-surface);border:1px solid var(--ip-border);font-size:12px;color:var(--ip-sub)}.ip-summary-chip b{color:var(--ip-text);font-weight:600}.ip-floor-section{margin-bottom:8px}.ip-floor-label{font-size:10px;text-transform:uppercase;letter-spacing:.08em;color:var(--ip-dim);font-weight:500;margin-bottom:5px;padding:0 1px}.ip-room-bar{display:flex;flex-wrap:wrap;gap:5px}.ip-room-btn{padding:7px 13px;border-radius:999px;font-size:12.5px;font-weight:500;border:1px solid var(--ip-border);background:var(--ip-surface);color:var(--ip-sub);cursor:pointer;font-family:var(--ip-font);transition:background .15s ease,color .15s ease,border-color .15s ease;-webkit-tap-highlight-color:transparent}.ip-room-btn:hover{color:var(--ip-text);border-color:var(--ip-border2)}.ip-room-btn.active{background:#60a5fa1f;border-color:#60a5fa66;color:var(--ip-blue)}.ip-room-btn.all-btn.active{background:var(--ip-lift);border-color:var(--ip-border2);color:var(--ip-text)}.ip-search-wrap{position:relative;margin:12px 0}.ip-search-icon{position:absolute;left:12px;top:50%;transform:translateY(-50%);color:var(--ip-dim);pointer-events:none;display:flex}.ip-search{width:100%;height:42px;border-radius:12px;border:1px solid var(--ip-border);background:var(--ip-surface);color:var(--ip-text);padding:0 12px 0 34px;font-size:13px;font-family:var(--ip-font);outline:none;transition:border-color .15s ease}.ip-search::placeholder{color:var(--ip-dim)}.ip-search:focus{border-color:#60a5fa66}.ip-skeleton-list{display:flex;flex-direction:column;gap:8px;margin-top:8px}.ip-skeleton-item{height:80px;border-radius:14px;background:var(--ip-surface);border:1px solid var(--ip-border);overflow:hidden;position:relative}.ip-skeleton-item:after{content:"";position:absolute;top:0;right:0;bottom:0;left:0;background:linear-gradient(90deg,transparent,var(--divider),transparent);background-size:200% 100%;animation:ip-shimmer 1.4s infinite linear}@keyframes ip-shimmer{0%{background-position:200% 0}to{background-position:-200% 0}}.ip-empty{padding:24px 14px;text-align:center;font-size:13px;color:var(--ip-sub);display:flex;flex-direction:column;align-items:center;gap:8px}.ip-empty-icon{font-size:26px;opacity:.6}.ip-room-block{margin-bottom:8px;border-radius:18px;border:1px solid var(--ip-border);background:var(--ip-surface);overflow:hidden;border-left:3px solid rgba(96,165,250,.4)}.ip-room-hdr{display:flex;align-items:center;justify-content:space-between;padding:12px 14px;gap:10px;border-bottom:1px solid var(--ip-border);background:var(--ip-lift)}.ip-room-hdr-left{min-width:0}.ip-room-name{margin:0;font-size:13px;font-weight:600;color:var(--ip-text);letter-spacing:-.1px}.ip-room-meta{font-size:11px;color:var(--ip-sub);margin-top:2px;font-family:var(--ip-mono)}.ip-add-btn{flex-shrink:0;display:inline-flex;align-items:center;gap:5px;padding:6px 12px;border-radius:999px;background:#60a5fa1a;border:1px solid rgba(96,165,250,.3);color:var(--ip-blue);font-size:12px;font-weight:500;font-family:var(--ip-font);cursor:pointer;transition:background .15s ease;-webkit-tap-highlight-color:transparent}.ip-add-btn:active{background:#60a5fa2e}.ip-item-list{display:flex;flex-direction:column}.ip-item{padding:12px 14px;border-top:1px solid var(--ip-border);display:flex;flex-direction:column;gap:8px}.ip-item:first-child{border-top:none}.ip-item-top{display:flex;align-items:flex-start;justify-content:space-between;gap:10px}.ip-item-left{min-width:0;flex:1;display:flex;flex-direction:column;gap:4px}.ip-item-name{font-size:14px;font-weight:600;color:var(--ip-text);line-height:1.3;cursor:pointer;transition:color .15s ease}.ip-item-name:hover{color:var(--ip-blue)}.ip-kondisi-badge{display:inline-block;font-size:10px;font-weight:500;padding:2px 8px;border-radius:999px;border:1px solid;letter-spacing:.03em}.ip-item-thumb{width:50px;height:50px;border-radius:10px;object-fit:cover;border:1px solid var(--ip-border);cursor:pointer;flex:0 0 auto;transition:transform .12s ease}.ip-item-thumb:hover{transform:scale(1.04)}.ip-item-fields{display:grid;grid-template-columns:1fr 1fr;gap:5px 12px}.ip-field{display:flex;flex-direction:column;gap:1px}.ip-field-label{font-size:9.5px;text-transform:uppercase;letter-spacing:.09em;color:var(--ip-dim);font-weight:500}.ip-field-value{font-size:12.5px;font-weight:500;color:var(--ip-text);font-family:var(--ip-mono)}.ip-field-value.muted{color:var(--ip-sub);font-family:var(--ip-font);font-size:12px}.ip-item-footer{display:flex;justify-content:flex-end}.ip-edit-btn{padding:6px 12px;border-radius:999px;font-size:11.5px;font-weight:500;border:1px solid var(--ip-border);background:var(--ip-lift);color:var(--ip-sub);cursor:pointer;font-family:var(--ip-font);transition:color .15s ease,border-color .15s ease}.ip-edit-btn:hover{color:var(--ip-text);border-color:var(--ip-border2)}.ip-toast{position:fixed;left:50%;bottom:90px;transform:translate(-50%);z-index:60;display:flex;align-items:center;gap:12px;padding:11px 14px;border-radius:14px;background:var(--ip-lift);border:1px solid var(--ip-border2);box-shadow:0 8px 32px #00000073;font-size:13px;color:var(--ip-text);white-space:nowrap;animation:ip-toast-in .2s ease}@keyframes ip-toast-in{0%{opacity:0;transform:translate(-50%) translateY(6px)}to{opacity:1;transform:translate(-50%) translateY(0)}}.ip-undo-btn{padding:5px 12px;border-radius:999px;background:#60a5fa26;border:1px solid rgba(96,165,250,.35);color:var(--ip-blue);font-size:12px;font-weight:500;cursor:pointer;font-family:var(--ip-font);transition:background .15s ease}.ip-undo-btn:hover{background:#60a5fa40}.ip-modal-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;z-index:200;display:grid;place-items:flex-end center;background:#0009;backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);padding:0}.ip-modal{width:min(100vw,460px);max-height:92vh;overflow-y:auto;border-radius:24px 24px 0 0;border:1px solid var(--ip-border2);border-bottom:none;background:var(--ip-surface);box-shadow:0 -8px 40px #00000080;padding:20px 16px 32px}.ip-modal-hdr{display:flex;align-items:center;justify-content:space-between;margin-bottom:18px}.ip-modal-eyebrow{font-size:10px;font-weight:500;letter-spacing:.1em;text-transform:uppercase;color:var(--ip-blue);margin-bottom:3px}.ip-modal-title{margin:0;font-size:16px;font-weight:600;color:var(--ip-text)}.ip-modal-close{padding:6px 12px;border-radius:999px;border:1px solid var(--ip-border);background:transparent;color:var(--ip-sub);font-size:12px;font-weight:500;cursor:pointer;font-family:var(--ip-font);transition:color .15s ease}.ip-modal-close:hover{color:var(--ip-text)}.ip-modal-fields{display:grid;gap:12px}.ip-field-group{display:flex;flex-direction:column;gap:6px}.ip-field-group label{font-size:10.5px;font-weight:500;letter-spacing:.07em;text-transform:uppercase;color:var(--ip-sub)}.ip-input{font-family:var(--ip-font);background:var(--ip-lift);color:var(--ip-text);border:1px solid var(--ip-border);border-radius:12px;padding:11px 13px;font-size:14px;font-weight:400;transition:border-color .15s ease;width:100%}.ip-input:focus{outline:none;border-color:#60a5fa73}.ip-input.readonly{opacity:.6;pointer-events:none}.ip-photo-btn{font-family:var(--ip-font);display:flex;align-items:center;justify-content:center;gap:6px;padding:12px;border-radius:12px;width:100%;border:1.5px dashed rgba(255,255,255,.1);background:transparent;color:var(--ip-sub);font-size:13px;font-weight:500;cursor:pointer;transition:border-color .15s ease,color .15s ease}.ip-photo-btn:active{border-color:#60a5fa66;color:var(--ip-blue)}.ip-photo-preview{width:100%;max-height:160px;object-fit:cover;border-radius:10px;border:1px solid var(--ip-border);cursor:pointer;margin-top:6px}.ip-qty-row{display:flex;align-items:center;gap:8px}.ip-qty-stepper{width:42px;height:42px;border-radius:12px;display:grid;place-items:center;border:1px solid var(--ip-border);background:var(--ip-lift);color:var(--ip-text);font-size:18px;cursor:pointer;position:relative;transition:background .12s ease;overflow:hidden;font-family:var(--ip-font)}.ip-qty-stepper:disabled{opacity:.4;pointer-events:none}.ip-qty-stepper.plus{border-color:#34d3994d;background:#34d39914}.ip-qty-stepper.minus{border-color:#fb71854d;background:#fb718514}.ip-qty-stepper.armed{box-shadow:0 0 0 2px #ffffff26}.ip-qty-hint{position:absolute;bottom:2px;left:50%;transform:translate(-50%);font-size:8px;color:var(--ip-text);white-space:nowrap;font-family:var(--ip-font);font-weight:500}.ip-qty-input{font-family:var(--ip-mono);width:70px;text-align:center;background:var(--ip-lift);color:var(--ip-text);border:1px solid var(--ip-border);border-radius:12px;padding:10px 6px;font-size:15px;font-weight:500}.ip-qty-input:focus{outline:none;border-color:#60a5fa66}.ip-modal-actions{display:flex;gap:8px;margin-top:18px;flex-wrap:wrap}.ip-btn{flex:1;padding:14px;border-radius:14px;font-size:14px;font-weight:500;cursor:pointer;border:1px solid var(--ip-border);background:var(--ip-lift);color:var(--ip-sub);font-family:var(--ip-font);transition:color .15s ease,background .15s ease}.ip-btn:hover{color:var(--ip-text)}.ip-btn-primary{background:#60a5fa26;border-color:#60a5fa66;color:var(--ip-blue)}.ip-btn-primary:active{background:#60a5fa38}.ip-btn-danger{background:#fb71851a;border-color:#fb71854d;color:var(--ip-red);flex:0 0 auto}.ip-btn-danger:active{background:#fb71852e}.ip-btn:disabled,.ip-btn-primary:disabled{opacity:.5;pointer-events:none}.ip-photo-viewer{position:fixed;top:0;right:0;bottom:0;left:0;z-index:300;background:#000000e6;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);display:grid;place-items:center;padding:16px}.ip-photo-viewer-inner{width:min(96vw,480px);background:var(--ip-surface);border:1px solid var(--ip-border2);border-radius:18px;overflow:hidden}.ip-photo-viewer-hdr{display:flex;align-items:center;justify-content:space-between;padding:12px 14px;border-bottom:1px solid var(--ip-border)}.ip-photo-viewer-name{font-size:14px;font-weight:600}.ip-photo-viewer img{width:100%;max-height:70vh;object-fit:contain;display:block}@media (max-width:380px){.ip-item-fields{grid-template-columns:1fr}}.ed-panel,.ed-panel *{box-sizing:border-box}.ed-panel{border:1px solid var(--border);border-radius:18px;padding:14px;background:var(--surface);display:flex;flex-direction:column;gap:10px;font-family:inherit}.ed-header{display:flex;align-items:flex-start;justify-content:space-between;gap:8px}.ed-title{margin:0;font-size:14px;font-weight:600;color:var(--text);letter-spacing:-.1px}.ed-sub{font-size:11px;color:var(--sub);margin-top:3px}.ed-refresh-btn{border:1px solid var(--border2);background:var(--lift);color:var(--sub);padding:6px 10px;border-radius:999px;font-size:16px;cursor:pointer;line-height:1;font-family:inherit;transition:color .15s ease}.ed-refresh-btn:hover{color:var(--text)}.ed-stats{display:grid;grid-template-columns:repeat(3,1fr);gap:8px}.ed-stat{background:var(--lift);border:1px solid var(--border);border-radius:14px;padding:13px 14px;display:flex;flex-direction:column;gap:5px}.ed-stat-label{font-size:10px;text-transform:uppercase;letter-spacing:.08em;color:var(--sub);font-weight:500}.ed-stat-value{font-size:15px;font-weight:600;color:var(--text);letter-spacing:-.3px;font-family:monospace;line-height:1.1}.ed-stat-value.red{color:var(--red)}.ed-mom-loading{font-size:11px;color:var(--sub)}.ed-mom{background:var(--lift);border:1px solid var(--border);border-radius:12px;padding:11px 14px;display:flex;flex-direction:column;gap:5px}.ed-mom-label{font-size:10px;text-transform:uppercase;letter-spacing:.08em;color:var(--sub);font-weight:500}.ed-mom-row{display:flex;align-items:baseline;gap:10px;flex-wrap:wrap}.ed-mom-prev{font-size:13px;color:var(--text);font-family:monospace}.ed-mom-diff{font-size:12px;font-weight:500;font-family:monospace}.ed-mom-diff.up{color:var(--red)}.ed-mom-diff.down{color:var(--green)}.ed-breakdown{background:var(--lift);border:1px solid var(--border);border-radius:14px;padding:13px 14px;display:flex;flex-direction:column;gap:10px}.ed-section-label{font-size:10px;text-transform:uppercase;letter-spacing:.08em;color:var(--sub);font-weight:500}.ed-breakdown-list{display:flex;flex-direction:column;gap:8px}.ed-breakdown-row{display:flex;justify-content:space-between;align-items:center;gap:10px}.ed-breakdown-left{flex:1;min-width:0;display:flex;flex-direction:column;gap:4px}.ed-breakdown-name{font-size:12px;font-weight:500;color:var(--text);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.ed-breakdown-bar{height:3px;border-radius:999px;background:var(--border);overflow:hidden}.ed-breakdown-fill{height:100%;background:var(--red);border-radius:999px;transition:width .5s cubic-bezier(.23,1,.32,1)}.ed-breakdown-toggle{width:100%;margin-top:4px;padding:8px;border:none;background:transparent;color:var(--sub);font-size:12px;font-weight:500;font-family:inherit;cursor:pointer;border-radius:8px;transition:color .15s ease,background .15s ease}.ed-breakdown-right{text-align:right;display:flex;flex-direction:column;gap:1px;flex-shrink:0}.ed-breakdown-amt{font-size:12px;font-weight:600;color:var(--red);font-family:monospace}.ed-breakdown-pct{font-size:10px;color:var(--sub)}.ed-controls{display:flex;flex-direction:column;gap:8px}.ed-search{width:100%;height:42px;border-radius:12px;border:1px solid var(--border2);background:var(--lift);color:var(--text);padding:0 14px;font-size:13px;outline:none;font-family:inherit;transition:border-color .15s ease}.ed-search::placeholder{color:var(--dim)}.ed-search:focus{border-color:var(--red-bd)}.ed-select-wrap{position:relative}.ed-select-trigger{width:100%;height:42px;border-radius:12px;border:1px solid var(--border2);background:var(--lift);color:var(--text);padding:0 14px;font-size:13px;font-family:inherit;display:flex;align-items:center;justify-content:space-between;cursor:pointer;text-align:left;transition:border-color .15s ease;-webkit-tap-highlight-color:transparent;text-transform:capitalize}.ed-select-trigger:focus{outline:none;border-color:var(--red-bd)}.ed-select-val{flex:1;min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.ed-select-caret{color:var(--sub);font-size:11px;flex-shrink:0;margin-left:8px}.ed-dropdown{position:absolute;top:calc(100% + 6px);left:0;right:0;z-index:50;background:var(--lift);border:1px solid var(--border2);border-radius:14px;overflow:hidden;box-shadow:0 8px 32px #00000080;max-height:260px;overflow-y:auto}.ed-dropdown::-webkit-scrollbar{width:4px}.ed-dropdown::-webkit-scrollbar-track{background:transparent}.ed-dropdown::-webkit-scrollbar-thumb{background:#ffffff1a;border-radius:999px}.ed-dropdown-item{width:100%;display:flex;align-items:center;gap:10px;padding:12px 14px;background:transparent;border:none;border-bottom:1px solid var(--divider);color:var(--muted);font-size:13px;font-family:inherit;cursor:pointer;text-align:left;text-transform:capitalize;transition:background .1s ease,color .1s ease;-webkit-tap-highlight-color:transparent}.ed-dropdown-item:last-child{border-bottom:none}.ed-dropdown-item:active{background:var(--divider)}.ed-dropdown-item.on{color:var(--red);background:var(--red-bg)}.ed-dropdown-dot{width:7px;height:7px;border-radius:50%;flex-shrink:0;border:1.5px solid rgba(255,255,255,.2);transition:background .1s ease,border-color .1s ease}.ed-dropdown-item.on .ed-dropdown-dot{background:var(--red);border-color:var(--red)}.ed-collapse-row{display:flex;gap:6px}.ed-controls-footer{display:flex;align-items:center;justify-content:space-between;gap:8px;padding-top:4px;border-top:1px solid var(--divider)}.ed-controls-count{font-size:11px;color:var(--sub)}.ed-ctrl-btn{border:1px solid var(--border2);background:var(--lift);color:var(--sub);padding:5px 11px;border-radius:999px;font-size:11.5px;font-weight:500;cursor:pointer;font-family:inherit;transition:color .15s ease,border-color .15s ease}.ed-ctrl-btn:hover{color:var(--text);border-color:var(--border2)}.ed-ctrl-btn:disabled{opacity:.4;cursor:default}.ed-error{display:flex;justify-content:space-between;align-items:center;gap:8px;padding:11px 14px;border-radius:12px;border:1px solid var(--red-bd);background:var(--red-bg);color:var(--red);font-size:13px}.ed-groups{display:flex;flex-direction:column;gap:8px}.ed-empty{font-size:13px;color:var(--sub);padding:8px 0}.ed-skeleton{display:flex;flex-direction:column;gap:8px}.ed-sk-line{height:14px;width:100%;border-radius:8px;background:var(--lift);animation:ed-pulse 1.4s ease-in-out infinite}@keyframes ed-pulse{0%,to{opacity:.4}50%{opacity:.8}}.ed-group{border-radius:14px;border:1px solid var(--border);background:var(--lift);overflow:hidden;border-left:3px solid var(--red-bd)}.ed-group-hdr{width:100%;display:flex;align-items:center;justify-content:space-between;gap:8px;padding:12px 14px;background:transparent;border:none;text-align:left;color:inherit;cursor:pointer;-webkit-tap-highlight-color:transparent}.ed-group-hdr:hover{background:#ffffff05}.ed-group-meta{display:flex;flex-direction:column;gap:2px}.ed-group-date{font-size:13px;font-weight:600;color:var(--text)}.ed-group-sub{font-size:11px;color:var(--sub)}.ed-caret{font-size:13px;color:var(--sub);flex-shrink:0}.ed-collapsed-hint{padding:10px 14px;font-size:12px;color:var(--sub)}.ed-items{display:flex;flex-direction:column}.ed-item{padding:12px 14px;border-top:1px solid var(--divider);display:flex;flex-direction:column;gap:10px}.ed-item:first-child{border-top:none}.ed-item-top{display:flex;align-items:flex-start;justify-content:space-between;gap:10px}.ed-item-left{flex:1;min-width:0;display:flex;flex-direction:column;gap:4px}.ed-item-right{flex-shrink:0;display:flex;flex-direction:column;align-items:flex-end;gap:6px}.ed-item-kategori{font-size:14px;font-weight:600;color:var(--text);line-height:1.3;word-break:break-word}.ed-item-sub{font-size:11px;color:var(--sub)}.ed-amount{font-size:15px;font-weight:600;color:var(--red);white-space:nowrap;font-family:monospace;letter-spacing:-.2px}.ed-item-actions{display:flex;gap:5px}.ed-btn-edit{border:1px solid var(--border2);background:var(--divider);color:var(--sub);font-size:11px;font-weight:500;padding:4px 10px;border-radius:999px;cursor:pointer;font-family:inherit;transition:color .15s ease}.ed-btn-edit:hover{color:var(--text)}.ed-del-item-btn{border:1px solid var(--red-bd);background:var(--red-bg);color:var(--red);font-size:11px;font-weight:500;padding:4px 10px;border-radius:999px;cursor:pointer;font-family:inherit}.ed-del-item-btn:hover{background:#fb718524}.ed-info-grid{display:flex;flex-direction:column;gap:5px;background:#ffffff06;border-radius:10px;padding:10px 12px}.ed-info-row{display:flex;gap:6px;align-items:baseline}.ed-info-label{font-size:11px;color:var(--sub);font-weight:500;white-space:nowrap;min-width:65px}.ed-info-value{font-size:12.5px;color:var(--text);word-break:break-word;line-height:1.4}.ed-bukti-btn{width:100%;padding:10px 14px;border-radius:10px;border:1px solid var(--red-bd);background:var(--red-bg);color:var(--red);font-size:12.5px;font-weight:500;cursor:pointer;font-family:inherit;text-align:left;transition:background .15s ease}.ed-bukti-btn:hover{background:#fb71851a}.ed-modal-body{padding:2px 0;display:flex;flex-direction:column;gap:12px}.ed-muted{font-size:13px;color:var(--sub)}.ed-del-info{display:flex;flex-direction:column;gap:6px}.ed-del-row{display:flex;justify-content:space-between;align-items:baseline;gap:8px}.ed-del-date{font-size:12px;color:var(--sub)}.ed-del-amt{font-size:15px;font-weight:600;color:var(--text);font-family:monospace}.ed-del-ket{font-size:13px;color:var(--sub);line-height:1.5}.ed-caution{padding:11px 13px;border-radius:12px;background:var(--amber-bg);border:1px solid var(--amber-bd);font-size:13px;color:var(--amber);line-height:1.5}.ed-modal-actions{display:grid;grid-template-columns:1fr 1fr;gap:8px}.ed-btn-del{padding:15px;border-radius:12px;border:none;background:var(--red);color:#fff;font-size:14px;font-weight:600;cursor:pointer;font-family:inherit;transition:opacity .15s ease}.ed-btn-del:disabled{opacity:.55}.ed-btn-save{padding:15px;border-radius:12px;border:none;background:var(--green);color:#0a0f0a;font-size:14px;font-weight:600;cursor:pointer;font-family:inherit;transition:opacity .15s ease}.ed-btn-save:disabled{opacity:.55}.ed-btn-cancel{padding:15px;border-radius:12px;border:1px solid var(--border2);background:var(--lift);color:var(--text);font-size:14px;font-weight:500;cursor:pointer;font-family:inherit}.ed-edit-id{font-size:10px;color:var(--sub);word-break:break-all;font-family:monospace}.ed-field{display:flex;flex-direction:column;gap:6px}.ed-field-label{font-size:10.5px;text-transform:uppercase;letter-spacing:.08em;color:var(--sub);font-weight:500}.ed-field-input{border-radius:12px;border:1px solid var(--border2);background:var(--lift);color:var(--text);padding:10px 14px;font-size:14px;outline:none;font-family:inherit;resize:vertical;transition:border-color .15s ease}.ed-field-input:focus{border-color:var(--red-bd)}.ed-field-select{width:100%;cursor:pointer;-moz-appearance:none;appearance:none;-webkit-appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 24 24' fill='none' stroke='%235a6070' stroke-width='2.5' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpolyline points='6 9 12 15 18 9'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 12px center;padding-right:36px}.ed-field-select option{background:var(--lift);color:var(--text)}.ed-bukti-iframe{width:100%;height:70vh;border:1px solid var(--border);border-radius:12px;background:var(--bg)}.ed-bukti-img{width:100%;max-height:70vh;object-fit:contain;border-radius:12px;border:1px solid var(--border)}.ed-bukti-path{font-size:10px;color:var(--sub);word-break:break-all;font-family:monospace}.ed-floating-toast{position:fixed;left:50%;bottom:calc(82px + env(safe-area-inset-bottom));transform:translate(-50%);z-index:9999;width:min(calc(100vw - 32px),390px);display:flex;align-items:center;gap:10px;padding:13px 14px;border-radius:16px;border:1px solid var(--red-bd);background:#120a0df0;color:#fecdd3;font-size:13px;font-weight:800;box-shadow:0 18px 44px #00000073;backdrop-filter:blur(14px);-webkit-backdrop-filter:blur(14px);animation:ed-toast-in .18s ease-out}.ed-floating-toast-icon{width:24px;height:24px;flex:0 0 auto;display:grid;place-items:center;border-radius:999px;background:#fb71852e;color:var(--red);font-size:13px;font-weight:900}@keyframes ed-toast-in{0%{opacity:0;transform:translate(-50%) translateY(10px)}to{opacity:1;transform:translate(-50%) translateY(0)}}@media (max-width:480px){.ed-stats{grid-template-columns:1fr 1fr}.ed-stats .ed-stat:first-child{grid-column:1 / -1}}.id-panel,.id-panel *{box-sizing:border-box}.id-panel{--green: var(--green);--green-dim: var(--green-bg);--green-border: var(--green-bd);--blue: var(--blue);--blue-dim: var(--blue-bg);--blue-border: var(--blue-bd);--red: var(--red);--red-dim: var(--red-bg);--red-border: var(--red-bd);--amber: var(--amber);--amber-dim: var(--amber-bg);--amber-border: var(--amber-bd);--bg: var(--bg);--surface: var(--surface);--surface2: var(--lift);--surface3: var(--lift);--border: var(--border);--border2: var(--border2);--text: var(--text);--text-muted: var(--sub);--text-dim: var(--muted);--radius-sm: var(--r-sm);--radius: var(--r-md);--radius-lg: var(--r);--font: var(--font);--mono: var(--mono);background:var(--bg);border:1px solid var(--border);border-radius:var(--radius-lg);padding:18px;display:flex;flex-direction:column;gap:14px;font-family:var(--font)}.id-header{display:flex;align-items:center;justify-content:space-between;gap:10px}.id-header-left{display:flex;flex-direction:column;gap:3px}.id-title{margin:0;font-size:15px;font-weight:700;color:var(--text);letter-spacing:-.3px;font-family:var(--font)}.id-sub{font-size:11.5px;color:var(--text-muted);font-weight:500;letter-spacing:.02em}.id-refresh-btn{width:36px;height:36px;border-radius:50%;border:1px solid var(--border2);background:var(--surface);color:var(--text-muted);font-size:15px;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .2s ease;flex-shrink:0}.id-refresh-btn:hover{color:var(--green);border-color:var(--green-border);background:var(--green-dim);transform:rotate(45deg)}.id-refresh-btn:disabled{opacity:.45;pointer-events:none}.id-stats{display:grid;grid-template-columns:1fr 1fr;gap:10px}.id-stat{background:linear-gradient(135deg,var(--surface) 0%,var(--surface2) 100%);border:1px solid var(--border);border-radius:var(--radius);padding:16px;display:flex;flex-direction:column;gap:6px;position:relative;overflow:hidden}.id-stat:before{content:"";position:absolute;top:0;left:0;right:0;height:2px;background:linear-gradient(90deg,transparent,var(--green),transparent);opacity:.5}.id-stat-label{font-size:10px;text-transform:uppercase;letter-spacing:.1em;color:var(--text-muted);font-weight:600}.id-stat-value{font-size:20px;font-weight:700;color:var(--text);letter-spacing:-.5px;font-family:var(--mono)}.id-stat-value.green{color:var(--green)}.id-sources{display:grid;grid-template-columns:repeat(3,1fr);gap:8px}.id-src{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-sm);padding:12px;display:flex;flex-direction:column;gap:4px;transition:border-color .2s ease}.id-src:hover{border-color:var(--green-border)}.id-src-label{font-size:9.5px;text-transform:uppercase;letter-spacing:.08em;color:var(--text-muted);font-weight:600}.id-src-amount{font-size:13px;font-weight:700;color:var(--green);font-family:var(--mono);letter-spacing:-.3px;margin-top:2px}.id-src-meta{font-size:10px;color:var(--text-muted)}.id-collapse-row{display:flex;gap:6px;justify-content:flex-end}.id-ctrl-btn{border:1px solid var(--border2);background:var(--surface);color:var(--text-muted);padding:5px 13px;border-radius:999px;font-size:11px;font-weight:600;cursor:pointer;font-family:var(--font);letter-spacing:.02em;transition:all .2s ease}.id-ctrl-btn:hover{color:var(--text);border-color:var(--border2);background:var(--surface2)}.id-groups{display:flex;flex-direction:column;gap:8px}.id-empty{font-size:13px;color:var(--text-muted);padding:20px 0;text-align:center}.id-group{border-radius:var(--radius);border:1px solid var(--border);background:var(--surface);overflow:hidden;transition:border-color .2s ease}.id-group:hover{border-color:var(--border2)}.id-group-hdr{display:flex;align-items:center;justify-content:space-between;gap:10px;padding:13px 16px;cursor:pointer;-webkit-user-select:none;user-select:none;-webkit-tap-highlight-color:transparent;transition:background .15s ease}.id-group-hdr:hover{background:#ffffff06}.id-group-meta{display:flex;flex-direction:column;gap:3px}.id-group-date{font-size:13px;font-weight:700;color:var(--text);letter-spacing:-.1px}.id-group-sub{font-size:11px;color:var(--text-muted);font-weight:500}.id-group-right{display:flex;align-items:center;gap:10px}.id-group-total{font-size:13px;font-weight:700;color:var(--green);font-family:var(--mono);letter-spacing:-.2px}.id-caret{width:22px;height:22px;display:flex;align-items:center;justify-content:center;border-radius:6px;background:var(--surface2);color:var(--text-muted);font-size:10px;flex-shrink:0;transition:background .15s ease,transform .2s ease}.id-group-hdr:hover .id-caret{background:var(--surface3)}.id-collapsed-hint{padding:10px 16px;font-size:12px;color:var(--text-muted);font-style:italic}.id-items{display:flex;flex-direction:column}.id-item{padding:14px 16px;border-top:1px solid var(--border);display:flex;flex-direction:column;gap:10px;transition:background .15s ease}.id-item:hover{background:#ffffff04}.id-item-top{display:flex;align-items:flex-start;justify-content:space-between;gap:12px}.id-item-left{flex:1;min-width:0;display:flex;flex-direction:column;gap:5px}.id-item-right{flex-shrink:0;display:flex;flex-direction:column;align-items:flex-end;gap:8px}.id-pill-row{display:flex;align-items:center;gap:5px;flex-wrap:wrap}.id-pill{font-size:9.5px;font-weight:700;padding:2px 8px;border-radius:999px;border:1px solid var(--border2);color:var(--text-muted);background:var(--surface2);letter-spacing:.05em;text-transform:uppercase}.id-pill.manual{color:var(--green);background:var(--green-dim);border-color:var(--green-border)}.id-pill.auto{color:var(--blue);background:var(--blue-dim);border-color:var(--blue-border)}.id-pill.src{color:var(--text-dim);background:var(--surface2);border-style:dashed;border-color:var(--border2);text-transform:none;font-weight:500;font-size:10px}.id-item-name{font-size:14px;font-weight:700;color:var(--text);line-height:1.3;word-break:break-word;letter-spacing:-.1px}.id-item-sub{font-size:11px;color:var(--text-muted);font-weight:500}.id-amount{font-size:16px;font-weight:700;color:var(--green);white-space:nowrap;font-family:var(--mono);letter-spacing:-.4px}.id-del-btn{border:1px solid var(--red-border);background:var(--red-dim);color:var(--red);font-size:10.5px;font-weight:700;padding:4px 11px;border-radius:999px;cursor:pointer;font-family:var(--font);letter-spacing:.03em;text-transform:uppercase;white-space:nowrap;transition:all .2s ease}.id-del-btn:hover{background:#ff6b7a2e;border-color:#ff6b7a66}.id-info-grid{display:flex;flex-direction:column;gap:6px;background:var(--surface2);border:1px solid var(--border);border-radius:var(--radius-sm);padding:11px 13px}.id-info-row{display:flex;gap:10px;align-items:baseline}.id-info-label{font-size:10.5px;color:var(--text-muted);font-weight:600;white-space:nowrap;min-width:68px;text-transform:uppercase;letter-spacing:.05em}.id-info-value{font-size:12.5px;color:var(--text-dim);word-break:break-word;line-height:1.45;font-weight:500}.id-bukti-btn{width:100%;padding:10px 14px;border-radius:var(--radius-sm);border:1px solid var(--blue-border);background:var(--blue-dim);color:var(--blue);font-size:12.5px;font-weight:600;cursor:pointer;font-family:var(--font);text-align:left;transition:all .2s ease;display:flex;align-items:center;gap:8px}.id-bukti-btn:hover{background:#6cb4ff29;border-color:#6cb4ff59}.id-modal-body{padding:4px 0;display:flex;flex-direction:column;gap:14px}.id-del-info{display:flex;flex-direction:column;gap:8px;padding:14px;background:var(--surface2);border:1px solid var(--border);border-radius:var(--radius-sm)}.id-del-row{display:flex;justify-content:space-between;align-items:baseline;gap:10px}.id-del-date{font-size:12px;color:var(--text-muted);font-weight:500}.id-del-amt{font-size:16px;font-weight:700;color:var(--text);font-family:var(--mono)}.id-del-ket{font-size:13px;color:var(--text-dim);line-height:1.5}.id-del-warn{font-size:12px;color:var(--red);margin-top:4px;font-weight:500}.id-del-caution{padding:13px 14px;border-radius:var(--radius-sm);background:var(--amber-dim);border:1px solid var(--amber-border);font-size:13px;color:var(--amber);line-height:1.6;font-weight:500}.id-del-actions{display:grid;grid-template-columns:1fr 1fr;gap:10px;margin-top:2px}.id-btn-del{padding:14px;border-radius:var(--radius-sm);border:none;background:var(--red);color:#fff;font-size:14px;font-weight:700;cursor:pointer;font-family:var(--font);transition:opacity .15s ease,transform .1s ease;letter-spacing:-.1px}.id-btn-del:hover:not(:disabled){opacity:.88;transform:translateY(-1px)}.id-btn-del:disabled{opacity:.45;cursor:not-allowed}.id-btn-cancel{padding:14px;border-radius:var(--radius-sm);border:1px solid var(--border2);background:var(--surface);color:var(--text);font-size:14px;font-weight:600;cursor:pointer;font-family:var(--font);transition:background .15s ease}.id-btn-cancel:hover{background:var(--surface2)}.id-muted{font-size:13px;color:var(--text-muted)}.id-err{font-size:13px;color:var(--red);font-weight:500}.id-bukti-iframe{width:100%;height:70vh;border:1px solid var(--border);border-radius:var(--radius-sm);background:var(--bg)}.id-bukti-img{max-width:100%;height:auto;border-radius:var(--radius-sm);border:1px solid var(--border)}.id-floating-toast{position:fixed;left:50%;bottom:calc(82px + env(safe-area-inset-bottom));transform:translate(-50%);z-index:9999;width:min(calc(100vw - 32px),390px);display:flex;align-items:center;gap:10px;padding:13px 14px;border-radius:16px;border:1px solid var(--green-bd);background:#08100cf0;color:#bbf7d0;font-size:13px;font-weight:800;box-shadow:0 18px 44px #00000073;backdrop-filter:blur(14px);-webkit-backdrop-filter:blur(14px);animation:id-toast-in .18s ease-out}.id-floating-toast-icon{width:24px;height:24px;flex:0 0 auto;display:grid;place-items:center;border-radius:999px;background:#22d3a52e;color:#86efac;font-size:13px;font-weight:900}@keyframes id-toast-in{0%{opacity:0;transform:translate(-50%) translateY(10px)}to{opacity:1;transform:translate(-50%) translateY(0)}}@media (max-width:480px){.id-sources{grid-template-columns:1fr 1fr}.id-sources .id-src:last-child{grid-column:1 / -1}.id-panel{padding:14px;gap:11px}}.page-docs{min-height:100vh;max-width:520px;margin:0 auto;padding:8px 10px 88px;background:var(--bg);color:var(--text)}.docs-hdr{position:sticky;top:0;z-index:20;display:flex;align-items:center;justify-content:space-between;padding:10px 8px;margin:-8px -6px 8px;background:linear-gradient(to bottom,var(--bg) 75%,transparent);-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);border-bottom:1px solid var(--border)}.docs-hdr-left{display:flex;flex-direction:column;gap:2px}.docs-title{margin:0;font-size:18px;font-weight:800;letter-spacing:.3px}.docs-sub{font-size:12px;color:var(--muted)}.docs-summary{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:8px;margin-bottom:10px}.docs-summary-card{border-radius:16px;padding:8px 10px;border:1px solid var(--border2);background:var(--surface);box-shadow:0 10px 24px #0000008c}.docs-summary-label{font-size:10px;text-transform:uppercase;letter-spacing:.09em;color:var(--muted);font-weight:800}.docs-summary-main{margin-top:2px;font-size:18px;font-weight:900}.docs-filters{margin-bottom:8px}.docs-search-wrap{position:relative}.docs-search{width:100%;border-radius:999px;border:1px solid var(--border2);background:var(--surface);padding:8px 12px;font-size:13px;color:var(--text)}.docs-groups{display:flex;flex-direction:column;gap:10px}.docs-group-card{border-radius:18px;padding:10px 10px 12px;border:1px solid var(--border2);background:var(--surface);box-shadow:0 14px 30px #000000b3}.docs-group-head{display:flex;align-items:flex-start;gap:10px;margin-bottom:8px}.docs-group-icon{width:36px;height:36px;border-radius:12px;background:var(--lift);display:grid;place-items:center;font-size:20px;flex:0 0 auto;box-shadow:0 6px 14px #00000059}.docs-group-title{margin:0;font-size:14px;font-weight:800;letter-spacing:.2px}.docs-group-desc{margin:2px 0 0;font-size:12px;color:var(--muted);font-weight:700}.docs-items{display:flex;flex-direction:column;gap:8px}.docs-item{border-radius:12px;padding:8px;border:1px solid var(--border);background:var(--lift);display:flex;flex-direction:column;gap:6px}.docs-item-main{display:flex;flex-direction:column;gap:2px}.docs-item-name{font-size:13px;font-weight:800}.docs-item-meta{font-size:11px;color:var(--muted);display:flex;gap:4px;flex-wrap:wrap}.docs-item-type{text-transform:uppercase;letter-spacing:.08em}.docs-item-updated{font-style:italic}.docs-dot{opacity:.6}.docs-item-actions{display:flex;gap:6px;flex-wrap:wrap}.docs-btn{border-radius:999px;padding:6px 10px;font-size:11px;font-weight:800;cursor:pointer;border:1px solid transparent;text-decoration:none;display:inline-flex;align-items:center;justify-content:center}.docs-btn.ghost{background:transparent;border-color:var(--border2);color:var(--text)}.docs-btn.primary{background:linear-gradient(135deg,#2563eb,#4ade80);color:#f9fafb}.docs-empty{text-align:center;padding:18px 10px;color:var(--muted);font-size:13px}.docs-empty-title{font-weight:800;margin-bottom:2px}.docs-empty-sub{font-size:12px}.em-wrap{padding:4px 0 2px}.em-form{display:flex;flex-direction:column;gap:6px}.em-section{display:flex;flex-direction:column;gap:10px;padding:14px;border-radius:16px;background:var(--surface);border:1px solid var(--border)}.em-label{font-size:10.5px;font-weight:500;text-transform:uppercase;letter-spacing:.08em;color:var(--sub);display:flex;align-items:center;gap:4px}.em-label-req{color:var(--red);font-size:13px;line-height:1}.em-input{width:100%;min-height:46px;border-radius:12px;border:1px solid var(--border2);background:var(--lift);color:var(--text);padding:10px 14px;font-size:15px;font-family:inherit;outline:none;-webkit-appearance:none;-moz-appearance:none;appearance:none;transition:border-color .15s ease,box-shadow .15s ease}.em-input::placeholder{color:var(--dim)}.em-input:focus{border-color:var(--red-bd);box-shadow:0 0 0 3px #fb718517}.em-soft{background:var(--bg);border-color:var(--border)}.em-nominal-wrap{position:relative}.em-nominal-prefix{position:absolute;left:14px;top:50%;transform:translateY(-50%);color:var(--sub);font-size:13px;pointer-events:none}.em-nominal-input{padding-left:36px;font-size:24px;font-weight:500;letter-spacing:-.5px}.em-chips{display:flex;flex-wrap:wrap;gap:7px}.em-bank-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:8px}.em-bank-btn{display:flex;flex-direction:column;align-items:center;gap:5px;padding:10px 6px;border:1px solid var(--border2);border-radius:12px;background:var(--bg);cursor:pointer;transition:all .18s ease}.em-bank-btn:hover{border-color:var(--blue-bd);background:var(--blue-bg)}.em-bank-on{border-color:var(--blue-bd)!important;background:var(--blue-bg)!important}.em-bank-logo{width:36px;height:36px;object-fit:contain;border-radius:8px;background:#fff;padding:3px}.em-bank-label{font-size:10px;font-weight:700;color:var(--muted);letter-spacing:.03em}.em-bank-on .em-bank-label{color:var(--blue)}.em-jenis-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:8px}.em-jenis-btn{display:flex;flex-direction:column;align-items:center;gap:6px;padding:12px 6px;border:1px solid var(--border);border-radius:14px;background:var(--lift);cursor:pointer;transition:all .15s ease;-webkit-tap-highlight-color:transparent}.em-jenis-btn:active{transform:scale(.96)}.em-jenis-btn:hover{border-color:var(--red-bd);background:var(--red-bg)}.em-jenis-on{border-color:var(--red-bd)!important;background:var(--red-bg)!important}.em-jenis-icon{font-size:20px;line-height:1}.em-jenis-label{font-size:10px;font-weight:600;color:var(--sub);text-align:center;line-height:1.3}.em-jenis-on .em-jenis-label{color:var(--red)}.em-chip{padding:8px 14px;border-radius:999px;border:1px solid var(--border2);background:var(--lift);color:var(--sub);font-size:13px;font-weight:500;font-family:inherit;cursor:pointer;line-height:1;transition:background .12s ease,border-color .12s ease,color .12s ease;-webkit-tap-highlight-color:transparent}.em-chip:active{transform:scale(.96)}.em-chip-on{background:var(--red-bg);border-color:var(--red-bd);color:var(--red)}.em-upload-btn{width:100%;display:flex;flex-direction:column;align-items:center;gap:5px;padding:22px 14px;border-radius:12px;border:1.5px dashed var(--border2);background:transparent;color:var(--sub);font-size:13px;font-weight:500;font-family:inherit;cursor:pointer;transition:border-color .15s ease,color .15s ease;-webkit-tap-highlight-color:transparent}.em-upload-btn:active{border-color:var(--red-bd);color:var(--red)}.em-upload-icon{font-size:22px}.em-upload-hint{font-size:11px;color:var(--dim)}.em-bukti-meta{display:flex;flex-direction:column;gap:10px}.em-bukti-preview{width:100%;max-height:200px;object-fit:contain;border-radius:10px;border:1px solid var(--border);background:var(--bg)}.em-bukti-row{display:flex;align-items:center;justify-content:space-between;gap:10px}.em-bukti-info{display:flex;flex-direction:column;gap:2px;min-width:0}.em-bukti-name{font-size:13px;color:var(--text);font-weight:500;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.em-bukti-size{font-size:11px;color:var(--sub)}.em-bukti-remove{flex-shrink:0;padding:6px 12px;border-radius:999px;border:1px solid var(--red-bd);background:var(--red-bg);color:var(--red);font-size:12px;font-weight:500;font-family:inherit;cursor:pointer}.em-floating-success{position:fixed;left:50%;bottom:calc(82px + env(safe-area-inset-bottom));transform:translate(-50%);z-index:9999;width:min(calc(100vw - 32px),390px);display:flex;align-items:center;gap:10px;padding:13px 14px;border-radius:16px;border:1px solid var(--red-bd);background:#120a0df0;color:#fecdd3;font-size:13px;font-weight:800;box-shadow:0 18px 44px #00000073;backdrop-filter:blur(14px);-webkit-backdrop-filter:blur(14px);animation:em-toast-in .18s ease-out}.em-floating-success-icon{width:24px;height:24px;flex:0 0 auto;display:grid;place-items:center;border-radius:999px;background:#fb71852e;color:var(--red);font-size:13px;font-weight:900}@keyframes em-toast-in{0%{opacity:0;transform:translate(-50%) translateY(10px)}to{opacity:1;transform:translate(-50%) translateY(0)}}.em-submit{margin-top:8px;width:100%;padding:17px;border-radius:14px;border:none;background:var(--red);color:#fff;font-size:15px;font-weight:600;font-family:inherit;cursor:pointer;display:flex;align-items:center;justify-content:center;gap:8px;transition:opacity .15s ease;-webkit-tap-highlight-color:transparent;letter-spacing:-.1px}.em-submit:disabled{opacity:.55}.em-submit:active:not(:disabled){opacity:.82}.em-spinner{width:15px;height:15px;flex-shrink:0;border:2px solid rgba(255,255,255,.3);border-top-color:#fff;border-radius:50%;animation:em-spin .7s linear infinite}@keyframes em-spin{to{transform:rotate(360deg)}}.income-modal-card{padding:6px 2px}.income-form{display:flex;flex-direction:column;gap:14px}.field-row{display:grid;grid-template-columns:130px minmax(0,1fr);gap:12px;align-items:center;padding:10px 8px;border:1px solid var(--border2);border-radius:14px;background:var(--surface)}.field-label{font-size:12px;color:var(--muted);font-weight:700;letter-spacing:.02em}.field-label .req{color:var(--green);margin-left:4px}.field-control{display:flex;flex-direction:column;gap:6px;min-width:0}.income-input{width:100%;min-height:46px;border-radius:12px;border:1px solid var(--border2);background:var(--surface);color:var(--text);padding:10px 12px;font-size:15px;outline:none}.income-input:focus{border-color:var(--green-bd);box-shadow:0 0 0 3px var(--green-bg)}.income-actions{margin-top:6px;display:grid;grid-template-columns:1fr}.btn.success{border-color:var(--green-bd);background:var(--green-bg);color:var(--green);font-weight:800;min-height:48px;border-radius:12px}.income-floating-success{position:fixed;left:50%;bottom:calc(82px + env(safe-area-inset-bottom));transform:translate(-50%);z-index:9999;width:min(calc(100vw - 32px),390px);display:flex;align-items:center;gap:10px;padding:13px 14px;border-radius:16px;border:1px solid var(--green-bd);background:#08100cf0;color:#bbf7d0;font-size:13px;font-weight:800;box-shadow:0 18px 44px #00000073;backdrop-filter:blur(14px);-webkit-backdrop-filter:blur(14px);animation:income-toast-in .18s ease-out}.income-floating-success-icon{width:24px;height:24px;flex:0 0 auto;display:grid;place-items:center;border-radius:999px;background:#22c55e2e;color:#86efac;font-size:13px;font-weight:900}@keyframes income-toast-in{0%{opacity:0;transform:translate(-50%) translateY(10px)}to{opacity:1;transform:translate(-50%) translateY(0)}}@media (max-width:640px){.field-row{grid-template-columns:1fr;gap:6px;padding:10px}}.smart-home-page{min-height:100vh;max-width:480px;margin:0 auto;padding:0 16px 120px;background:radial-gradient(520px 240px at 20% -60px,rgba(99,102,241,.16),transparent 60%),radial-gradient(420px 220px at 100% 8%,rgba(52,211,153,.08),transparent 55%),var(--bg);color:var(--text);font-family:var(--font)}.smart-home-header{position:sticky;top:0;z-index:40;display:flex;align-items:flex-start;justify-content:space-between;gap:12px;padding:18px 0 14px;background:linear-gradient(var(--bg) 72%,transparent);backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px)}.smart-home-kicker{color:var(--indigo-lt);font-size:10px;font-weight:800;letter-spacing:.14em;text-transform:uppercase;margin-bottom:2px}.smart-home-title{margin:0;color:var(--text);font-size:22px;font-weight:950;line-height:1.05;letter-spacing:-.055em}.smart-home-sub{margin-top:4px;color:var(--sub);font-size:11.5px;font-weight:600;line-height:1.35}.smart-home-refresh,.smart-home-btn{display:inline-flex;align-items:center;justify-content:center;gap:7px;min-height:38px;padding:0 13px;border-radius:var(--r-full);border:1px solid var(--border);background:var(--lift);color:var(--muted);font-size:12.5px;font-weight:800;font-family:var(--font);white-space:nowrap;transition:all .14s ease}.smart-home-refresh:hover,.smart-home-btn:hover{border-color:var(--border2);color:var(--text);background:var(--hover)}.smart-home-refresh:active,.smart-home-btn:active{transform:scale(.97)}.smart-home-refresh:disabled,.smart-home-btn:disabled{opacity:.45;cursor:not-allowed;transform:none}.smart-home-btn.primary{border-color:var(--indigo-bd);background:var(--indigo-bg);color:var(--indigo-lt);box-shadow:0 4px 14px #6366f129}.smart-home-btn.primary:hover{border-color:var(--indigo);color:#fff;background:#6366f138}.smart-home-card{margin-top:12px;padding:14px;border-radius:var(--r);border:1px solid var(--border);background:#ffffff09;box-shadow:var(--shadow-sm)}.smart-home-card-head{display:flex;align-items:flex-start;justify-content:space-between;gap:12px;margin-bottom:12px}.smart-home-card-title{color:var(--text);font-size:15px;font-weight:850;letter-spacing:-.02em}.smart-home-card-sub{margin-top:2px;color:var(--sub);font-size:11.8px;font-weight:600;line-height:1.4}.smart-home-alert{margin-top:10px;padding:13px 14px;border-radius:var(--r);border:1px solid var(--border);background:var(--surface)}.smart-home-alert.ok{border-color:var(--green-bd);background:var(--green-bg)}.smart-home-alert.bad{border-color:var(--red-bd);background:var(--red-bg)}.smart-home-alert-title{color:var(--text);font-size:13.5px;font-weight:850}.smart-home-alert.ok .smart-home-alert-title{color:var(--green)}.smart-home-alert.bad .smart-home-alert-title{color:var(--red)}.smart-home-alert-text{margin-top:3px;color:var(--muted);font-size:12px;line-height:1.45}.smart-home-list{display:flex;flex-direction:column;gap:9px}.smart-home-row{width:100%;min-height:66px;display:flex;align-items:center;justify-content:space-between;gap:12px;padding:13px;border-radius:16px;border:1px solid var(--border);background:#ffffff09;color:var(--text);text-align:left;font-family:var(--font);transition:transform .15s,background .15s,border-color .15s}.smart-home-row:hover{background:#ffffff0e;border-color:var(--border2)}.smart-home-row:active{transform:scale(.985)}.smart-home-row-left{min-width:0;display:flex;align-items:center;gap:12px}.smart-home-row-right{display:flex;align-items:center;gap:8px;flex:0 0 auto}.smart-home-row-title{color:var(--text);font-size:13.5px;font-weight:850;letter-spacing:-.01em}.smart-home-row-sub{margin-top:2px;color:var(--sub);font-size:11.5px;font-weight:600;line-height:1.36}.smart-home-icon{width:38px;height:38px;flex:0 0 auto;display:grid;place-items:center;border-radius:13px;border:1px solid var(--border);background:var(--lift);color:var(--muted)}.smart-home-icon.ok,.smart-home-icon.device.on{color:var(--green);border-color:var(--green-bd);background:var(--green-bg)}.smart-home-icon.warn{color:var(--amber);border-color:var(--amber-bd);background:var(--amber-bg)}.smart-home-icon.camera,.smart-home-icon.device.off{color:var(--blue);border-color:var(--blue-bd);background:var(--blue-bg)}.smart-home-icon.device.unknown{color:var(--muted);border-color:var(--border);background:var(--lift)}.smart-home-stats{display:grid;grid-template-columns:repeat(3,1fr);gap:8px;margin-bottom:12px}.smart-home-stat{min-height:58px;display:flex;flex-direction:column;justify-content:center;gap:3px;padding:10px;border-radius:15px;border:1px solid var(--border);background:#ffffff09}.smart-home-stat strong{font-family:var(--mono);font-size:20px;font-weight:900;line-height:1;color:var(--text)}.smart-home-stat span{color:var(--sub);font-size:10px;font-weight:800;letter-spacing:.07em;text-transform:uppercase}.smart-home-stat.on{border-color:var(--green-bd)}.smart-home-stat.on strong{color:var(--green)}.smart-home-stat.off{border-color:var(--blue-bd)}.smart-home-stat.off strong{color:var(--blue)}.smart-home-stat.unknown{border-color:var(--border)}.smart-home-stat.unknown strong{color:var(--muted)}.smart-home-empty{margin-top:10px;padding:16px;border-radius:16px;border:1px dashed var(--border2);background:#ffffff06;color:var(--sub);font-size:12.5px;font-weight:600;line-height:1.45;text-align:center}.smart-home-groups{display:flex;flex-direction:column;gap:16px}.smart-home-group{padding-top:4px}.smart-home-group-head{display:flex;align-items:center;justify-content:space-between;gap:12px;margin-bottom:10px}.smart-home-group-left{min-width:0;display:flex;align-items:center;gap:10px}.smart-home-group-icon{width:32px;height:32px;display:grid;place-items:center;flex:0 0 auto;border-radius:12px;border:1px solid var(--border);background:var(--lift);color:var(--indigo-lt)}.smart-home-group-icon.private{color:var(--purple);border-color:var(--purple-bd);background:var(--purple-bg)}.smart-home-group-icon.kost{color:var(--green);border-color:var(--green-bd);background:var(--green-bg)}.smart-home-group-title{color:var(--text);font-size:13px;font-weight:900;letter-spacing:-.02em}.smart-home-group-sub{margin-top:1px;color:var(--sub);font-size:11px;font-weight:650}.smart-home-mini-pill{display:inline-flex;align-items:center;justify-content:center;min-height:24px;padding:0 9px;border-radius:var(--r-full);border:1px solid var(--border);background:var(--lift);color:var(--muted);font-size:10.5px;font-weight:900;letter-spacing:.02em;white-space:nowrap}.smart-home-device-grid{display:flex;flex-direction:column;gap:10px}.smart-home-device-card{padding:13px;border-radius:18px;border:1px solid var(--border);background:#ffffff09;transition:background .15s,border-color .15s,transform .15s}.smart-home-device-card:hover{background:#ffffff0e;border-color:var(--border2)}.smart-home-device-card:active{transform:scale(.99)}.smart-home-device-card.can-open-remote{cursor:pointer}.smart-home-device-card.can-open-remote:hover{border-color:var(--indigo-bd);background:#6366f112}.smart-home-device-top{display:flex;align-items:flex-start;justify-content:space-between;gap:10px}.smart-home-device-main{min-width:0;flex:1;display:flex;align-items:flex-start;gap:12px}.smart-home-device-copy{min-width:0}.smart-home-device-title{color:var(--text);font-size:14px;font-weight:900;letter-spacing:-.02em}.smart-home-device-sub{margin-top:3px;color:var(--sub);font-size:11.5px;font-weight:600;line-height:1.42}.smart-home-badge{display:inline-flex;align-items:center;justify-content:center;min-height:26px;padding:0 10px;border-radius:var(--r-full);border:1px solid var(--border);background:var(--lift);color:var(--muted);font-size:10.5px;font-weight:900;letter-spacing:.05em;white-space:nowrap;flex:0 0 auto}.smart-home-badge.on{color:var(--green);border-color:var(--green-bd);background:var(--green-bg)}.smart-home-badge.off{color:var(--blue);border-color:var(--blue-bd);background:var(--blue-bg)}.smart-home-badge.unknown{color:var(--muted);border-color:var(--border);background:var(--lift)}.smart-home-device-bottom{margin-top:12px;display:flex;align-items:center;justify-content:space-between;gap:12px}.smart-home-device-meta{color:var(--sub);font-size:12px;font-weight:800;line-height:1.35;letter-spacing:-.01em}.smart-home-toggle{display:inline-flex;align-items:center;gap:10px;padding:0;border:none;background:transparent;color:var(--text);font-family:var(--font);cursor:pointer}.smart-home-toggle:disabled{opacity:.5;cursor:not-allowed}.smart-home-toggle-track{position:relative;width:68px;height:38px;border-radius:999px;border:1px solid var(--border2);background:#ffffff14;box-shadow:inset 0 0 0 1px #ffffff05;transition:background .18s ease,border-color .18s ease,box-shadow .18s ease}.smart-home-toggle-thumb{position:absolute;top:3px;left:3px;width:30px;height:30px;border-radius:999px;background:#fff;box-shadow:0 4px 10px #0003;transition:transform .18s ease}.smart-home-toggle.is-on .smart-home-toggle-track{background:linear-gradient(180deg,#1ddf6f,#17c25f);border-color:#1ed2648c;box-shadow:0 0 0 1px #11b1531a,0 6px 18px #14be5a38}.smart-home-toggle.is-on .smart-home-toggle-thumb{transform:translate(30px)}.smart-home-toggle-text{min-width:36px;color:var(--text);font-size:12.5px;font-weight:900;letter-spacing:-.01em}.smart-home-toggle.is-on .smart-home-toggle-text{color:var(--green)}.smart-home-toggle.is-off .smart-home-toggle-text{color:var(--muted)}.smart-home-toggle.is-loading .smart-home-toggle-track{opacity:.75}.smart-remote-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;z-index:1300;display:flex;align-items:flex-end;justify-content:center;padding:14px;background:#000000a8;backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px)}.smart-remote-panel{width:min(100%,440px);max-height:min(88vh,760px);overflow-y:auto;border-radius:28px 28px 20px 20px;border:1px solid var(--border2);background:radial-gradient(420px 180px at 15% 0%,rgba(99,102,241,.2),transparent 62%),radial-gradient(360px 180px at 90% 12%,rgba(52,211,153,.1),transparent 58%),linear-gradient(180deg,#11141d,var(--bg));box-shadow:0 28px 80px #000000ad;padding:12px 14px 16px;animation:smartRemoteIn .18s ease-out}@keyframes smartRemoteIn{0%{opacity:0;transform:translateY(18px) scale(.98)}to{opacity:1;transform:translateY(0) scale(1)}}.smart-remote-handle{width:44px;height:5px;margin:0 auto 12px;border-radius:999px;background:#ffffff29}.smart-remote-head{display:flex;align-items:flex-start;justify-content:space-between;gap:12px;padding-bottom:14px;border-bottom:1px solid var(--divider)}.smart-remote-kicker{color:var(--indigo-lt);font-size:10px;font-weight:900;letter-spacing:.14em;text-transform:uppercase}.smart-remote-title{margin:4px 0 0;color:var(--text);font-size:22px;font-weight:950;letter-spacing:-.05em;line-height:1.05}.smart-remote-sub{margin-top:5px;color:var(--sub);font-size:11.5px;font-weight:750}.smart-remote-close{width:38px;height:38px;display:grid;place-items:center;border-radius:14px;border:1px solid var(--border);background:var(--lift);color:var(--muted);font-size:25px;line-height:1;font-family:var(--font);transition:transform .14s,background .14s,border-color .14s}.smart-remote-close:hover{border-color:var(--border2);background:#ffffff12}.smart-remote-close:active{transform:scale(.97)}.smart-remote-close:disabled{opacity:.45;cursor:not-allowed}.smart-remote-power-row{display:grid;grid-template-columns:1fr 1fr;gap:10px;padding:14px 0}.smart-remote-power{min-height:70px;display:flex;flex-direction:column;align-items:flex-start;justify-content:center;gap:5px;padding:13px;border-radius:20px;border:1px solid var(--border);background:#ffffff0a;font-family:var(--font);text-align:left;transition:transform .14s,background .14s,border-color .14s}.smart-remote-power span{color:var(--sub);font-size:11px;font-weight:800}.smart-remote-power b{font-size:20px;font-weight:950;letter-spacing:-.04em}.smart-remote-power.on{border-color:var(--green-bd);background:var(--green-bg)}.smart-remote-power.on b{color:var(--green)}.smart-remote-power.off{border-color:var(--red-bd);background:var(--red-bg)}.smart-remote-power.off b{color:var(--red)}.smart-remote-section{margin-top:10px;padding-top:12px;border-top:1px solid var(--divider)}.smart-remote-section-title{margin-bottom:9px;color:var(--sub);font-size:10px;font-weight:900;letter-spacing:.12em;text-transform:uppercase}.smart-remote-volume-grid,.smart-remote-app-grid{display:grid;grid-template-columns:1fr 1fr;gap:10px}.smart-remote-action,.smart-remote-tile,.smart-remote-nav button{border:1px solid var(--border);background:#ffffff0a;color:var(--text);font-family:var(--font);transition:transform .14s,background .14s,border-color .14s}.smart-remote-action{min-height:48px;border-radius:16px;font-size:13px;font-weight:900}.smart-remote-action.wide{grid-column:1 / -1}.smart-remote-tile{min-height:76px;display:flex;flex-direction:column;align-items:flex-start;justify-content:center;padding:13px;border-radius:18px;text-align:left}.smart-remote-tile span{color:var(--text);font-size:14px;font-weight:950;letter-spacing:-.02em}.smart-remote-tile b{margin-top:4px;color:var(--sub);font-size:11px;font-weight:650}.smart-remote-nav{display:flex;flex-direction:column;align-items:center;gap:9px}.smart-remote-nav-mid{display:flex;align-items:center;justify-content:center;gap:9px}.smart-remote-nav button{width:58px;height:48px;border-radius:18px;font-size:18px;font-weight:950}.smart-remote-nav button.ok{width:68px;height:58px;color:#fff;border-color:var(--indigo);background:var(--indigo);box-shadow:0 8px 24px #6366f147;font-size:14px}.smart-remote-action:hover,.smart-remote-tile:hover,.smart-remote-nav button:hover{border-color:var(--border2);background:#ffffff12}.smart-remote-power:active,.smart-remote-action:active,.smart-remote-tile:active,.smart-remote-nav button:active{transform:scale(.97)}.smart-remote-power:disabled,.smart-remote-action:disabled,.smart-remote-tile:disabled,.smart-remote-nav button:disabled{opacity:.45;cursor:not-allowed;transform:none}.smart-remote-loading{margin-top:12px;padding:11px 12px;border-radius:15px;border:1px solid var(--indigo-bd);background:var(--indigo-bg);color:var(--indigo-lt);font-size:12px;font-weight:850;text-align:center}@media (max-width: 420px){.smart-home-device-bottom{flex-direction:column;align-items:flex-start}.smart-home-toggle{align-self:flex-end}.smart-remote-panel{max-height:90vh}}@media (min-width: 520px){.smart-remote-backdrop{align-items:center}.smart-remote-panel{border-radius:26px}}.smart-remote-volume-panel{padding:14px;border-radius:20px;border:1px solid var(--border);background:linear-gradient(180deg,#ffffff0e,#ffffff06)}.smart-remote-volume-slider::-moz-range-track{height:14px;border-radius:999px;background:linear-gradient(90deg,#34d399f2,#6366f1d9);border:1px solid rgba(255,255,255,.08)}.smart-remote-volume-slider::-moz-range-thumb{width:30px;height:30px;border-radius:999px;border:3px solid rgba(255,255,255,.96);background:var(--green);box-shadow:0 8px 22px #00000059}.smart-remote-tile.app-youtube{border-color:#fb718540}.smart-remote-tile.app-netflix{border-color:#fb71854d}.smart-remote-section-head{display:flex;align-items:flex-start;justify-content:space-between;gap:12px;margin-bottom:10px}.smart-remote-section-sub{margin-top:3px;color:var(--dim);font-size:11px;font-weight:650;line-height:1.35}.smart-remote-volume-value{min-width:52px;min-height:32px;display:inline-flex;align-items:center;justify-content:center;border-radius:var(--r-full);border:1px solid var(--green-bd);background:var(--green-bg);color:var(--green);font-family:var(--mono);font-size:12px;font-weight:900}.smart-remote-volume-panel{padding:14px;margin-bottom:10px;border-radius:20px;border:1px solid var(--border);background:linear-gradient(180deg,#ffffff0e,#ffffff06)}.smart-remote-volume-slider{width:100%;height:42px;-moz-appearance:none;appearance:none;-webkit-appearance:none;background:transparent;cursor:pointer}.smart-remote-volume-slider:disabled{opacity:.45;cursor:not-allowed}.smart-remote-volume-slider::-webkit-slider-runnable-track{height:14px;border-radius:999px;background:linear-gradient(90deg,#34d399f2,#6366f1d9);border:1px solid rgba(255,255,255,.08)}.smart-remote-volume-slider::-webkit-slider-thumb{-webkit-appearance:none;width:34px;height:34px;margin-top:-11px;border-radius:999px;border:3px solid rgba(255,255,255,.96);background:var(--green);box-shadow:0 8px 22px #00000059}.smart-remote-volume-presets{display:flex;gap:7px;overflow-x:auto;padding:8px 0 0}.smart-remote-volume-presets button{min-width:38px;min-height:30px;border-radius:var(--r-full);border:1px solid var(--border);background:#ffffff0a;color:var(--muted);font-family:var(--font);font-size:11px;font-weight:850}.smart-remote-volume-presets button.active{border-color:var(--green-bd);background:var(--green-bg);color:var(--green)}.smart-remote-tile.app-youtube,.smart-remote-tile.app-netflix{border-color:#fb71854d}.smart-remote-tile.app-prime{border-color:#60a5fa42}.smart-remote-tile.app-spotify{border-color:#34d39940}.smart-remote-tile.app-youtube span,.smart-remote-tile.app-netflix span{color:var(--red)}.smart-remote-tile.app-prime span{color:var(--blue)}.smart-remote-tile.app-spotify span{color:var(--green)}.smart-remote-voice{width:100%;min-height:52px;border-radius:18px;border:1px solid var(--indigo-bd);background:var(--indigo-bg);color:var(--indigo-lt);font-family:var(--font);font-size:14px;font-weight:900}.smart-remote-voice.listening{border-color:var(--green-bd);background:var(--green-bg);color:var(--green);box-shadow:0 0 0 4px #34d39914}.smart-remote-voice:disabled{opacity:.55;cursor:not-allowed}.smart-remote-voice-text{margin-top:9px;padding:10px 12px;border-radius:14px;border:1px solid var(--border);background:#ffffff09;color:var(--muted);font-size:12px;font-weight:700;line-height:1.4}.smart-remote-app-picker{overflow:hidden;border-radius:24px;border:1px solid var(--border);background:linear-gradient(180deg,#ffffff0f,#ffffff06)}.smart-remote-app-current{min-height:64px;display:flex;flex-direction:column;justify-content:center;padding:13px 16px;border-bottom:1px solid var(--border);background:#ffffff09;text-align:center}.smart-remote-app-current span{color:var(--text);font-size:17px;font-weight:950;letter-spacing:-.03em}.smart-remote-app-current b{margin-top:4px;color:var(--sub);font-size:11px;font-weight:700}.smart-remote-app-wheel{height:246px;overflow-y:auto;scroll-snap-type:y mandatory;scroll-behavior:smooth;-webkit-overflow-scrolling:touch}.smart-remote-app-wheel::-webkit-scrollbar{width:0;display:none}.smart-remote-app-option{width:100%;height:82px;scroll-snap-align:center;scroll-snap-stop:always;display:flex;align-items:center;justify-content:center;border:0;border-bottom:1px solid var(--border);background:transparent;color:var(--muted);font-family:var(--font);cursor:pointer;transition:background .18s ease,color .18s ease,transform .18s ease}.smart-remote-app-option:last-child{border-bottom:0}.smart-remote-app-option span{font-size:16px;font-weight:800;letter-spacing:-.025em;opacity:.58;transition:font-size .18s ease,opacity .18s ease,color .18s ease}.smart-remote-app-option.active{background:radial-gradient(circle at center,rgba(255,255,255,.1),transparent 62%)}.smart-remote-app-option.active span{color:var(--text);font-size:22px;font-weight:950;opacity:1}.smart-remote-app-option:active{transform:scale(.985)}.smart-remote-app-option:disabled{opacity:.45;cursor:not-allowed}.smart-remote-app-footer{padding:10px 12px;border-top:1px solid var(--border);background:#ffffff06;color:var(--dim);text-align:center;font-size:11px;font-weight:700}.smart-remote-app-option.app-youtube.active span,.smart-remote-app-option.app-netflix.active span{color:var(--red)}.smart-remote-app-option.app-prime.active span,.smart-remote-app-option.app-apple.active span,.smart-remote-app-option.app-browser.active span{color:var(--blue)}.smart-remote-app-option.app-spotify.active span,.smart-remote-app-option.app-plex.active span{color:var(--green)}.smart-remote-app-option.app-disney.active span,.smart-remote-app-option.app-max.active span{color:var(--purple)}.smart-remote-mode-tabs{display:grid;grid-template-columns:1fr 1fr;gap:8px;padding:5px;margin-bottom:10px;border-radius:18px;border:1px solid var(--border);background:#ffffff09}.smart-remote-mode-tabs button{min-height:38px;border:0;border-radius:14px;background:transparent;color:var(--muted);font-family:var(--font);font-size:12px;font-weight:900}.smart-remote-mode-tabs button.active{background:#ffffff1a;color:var(--text);box-shadow:inset 0 1px #ffffff14}.smart-remote-trackpad{position:relative;min-height:176px;overflow:hidden;display:flex;align-items:center;justify-content:center;border-radius:28px;border:1px solid rgba(255,255,255,.12);background:radial-gradient(circle at 50% 20%,rgba(255,255,255,.13),transparent 35%),linear-gradient(145deg,#ffffff13,#ffffff06);box-shadow:inset 0 1px #ffffff14,0 18px 40px #0000003d;cursor:pointer;touch-action:none;-webkit-user-select:none;user-select:none}.smart-remote-trackpad:before{content:"";position:absolute;top:14px;right:14px;bottom:14px;left:14px;border-radius:22px;border:1px dashed rgba(255,255,255,.09);pointer-events:none}.smart-remote-trackpad:active{transform:scale(.992)}.smart-remote-trackpad.is-busy{opacity:.55;pointer-events:none}.smart-remote-trackpad-glow{position:absolute;width:150px;height:150px;border-radius:999px;background:#34d3991a;filter:blur(18px)}.smart-remote-trackpad-center{position:relative;z-index:1;text-align:center}.smart-remote-trackpad-center span{display:block;color:var(--text);font-size:20px;font-weight:950;letter-spacing:-.04em}.smart-remote-trackpad-center b{display:block;margin-top:7px;color:var(--sub);font-size:11px;font-weight:750}.smart-remote-trackpad-actions{display:grid;grid-template-columns:repeat(3,1fr);gap:9px;margin-top:10px}.smart-remote-trackpad-actions button{min-height:42px;border-radius:16px;border:1px solid var(--border);background:#ffffff0b;color:var(--text);font-family:var(--font);font-size:12px;font-weight:900}.smart-remote-trackpad-actions button:active{transform:scale(.97)}.smart-remote-trackpad-actions button:disabled{opacity:.45}.smart-remote-nav.compact{margin-top:4px}.smart-remote-channel-list{max-height:220px;overflow-y:auto;display:grid;grid-template-columns:1fr;gap:8px;padding-right:3px;-webkit-overflow-scrolling:touch}.smart-remote-channel-list::-webkit-scrollbar{width:3px}.smart-remote-channel-list::-webkit-scrollbar-track{background:transparent}.smart-remote-channel-list::-webkit-scrollbar-thumb{border-radius:999px;background:#ffffff2e}.smart-remote-channel-list button{min-height:48px;display:flex;align-items:center;justify-content:space-between;gap:12px;padding:10px 12px;border-radius:15px;border:1px solid var(--border);background:#ffffff0a;color:var(--text);font-family:var(--font)}.smart-remote-channel-list button span{min-width:44px;color:var(--green);font-family:var(--mono);font-size:12px;font-weight:950;text-align:left}.smart-remote-channel-list button b{flex:1;color:var(--text);font-size:12px;font-weight:850;text-align:right}.smart-remote-channel-list button:disabled{opacity:.45}
