*,:after,:before{box-sizing:border-box}body{background:#f0f6ff;color:#1e3a5f;font-family:Segoe UI,system-ui,-apple-system,sans-serif;margin:0}@keyframes slideIn{0%{opacity:0;transform:translateY(12px)}to{opacity:1;transform:translateY(0)}}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.app-shell,.sidebar{display:flex;min-height:100vh}.sidebar{background:linear-gradient(180deg,#0056b3,#003d82);flex-direction:column;flex-shrink:0;height:100vh;overflow:hidden;position:sticky;top:0;transition:width .22s ease}.sidebar--open{width:224px}.sidebar--closed{width:62px}.sidebar__logo{align-items:center;border-bottom:1px solid #ffffff21;display:flex;gap:10px;padding:18px 13px 13px}.sidebar__logo-icon{align-items:center;background:#fff;border-radius:10px;display:flex;flex-shrink:0;font-size:20px;height:36px;justify-content:center;width:36px}.sidebar__biz-name{color:#fff;font-size:15px;font-weight:800;line-height:1.2}.sidebar__biz-sub{color:#93c5fd;font-size:10px}.sidebar__meta{border-bottom:1px solid #ffffff17;padding:7px 13px}.sidebar__meta-label{color:#93c5fd;font-size:10px;margin-bottom:1px}.sidebar__meta-value{color:#fff;font-size:12px;font-weight:700;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.sidebar__ar-ap{grid-gap:6px;border-bottom:1px solid #ffffff17;display:grid;gap:6px;grid-template-columns:1fr 1fr;padding:7px 13px}.sidebar__ar-ap-label{font-size:9px;font-weight:700}.sidebar__ar-ap-val{color:#fff;font-size:11px;font-weight:800}.sidebar__nav{flex:1 1;padding:10px 8px}.sidebar__foot{border-top:1px solid #ffffff17;display:flex;flex-direction:column;gap:6px;padding:10px 8px}.presence-section{border-top:1px solid #ffffff17;padding:6px 12px 8px}.presence-label{color:#6ee7b7;font-size:10px;font-weight:700;letter-spacing:.06em;margin-bottom:4px;text-transform:uppercase}.presence-user{align-items:center;color:#cbd5e1;display:flex;font-size:12px;gap:6px;overflow:hidden;padding:2px 0;text-overflow:ellipsis;white-space:nowrap}.presence-dot{background:#10b981;border-radius:50%;box-shadow:0 0 4px #10b981;flex-shrink:0;height:7px;width:7px}.sidebar__user{padding:6px 4px 2px}.sidebar__user-name{color:#fff;font-size:13px;font-weight:700;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.sidebar__user-role{color:#93c5fd;font-size:11px;margin-top:1px}.btn-logout{align-items:center;background:#ef44441f;border:none;border-radius:8px;color:#fca5a5;cursor:pointer;display:flex;font-size:13px;font-weight:500;gap:7px;padding:8px 10px;text-align:left;transition:background .15s;width:100%}.btn-logout:hover{background:#ef444440}.login-page{align-items:center;background:#f0f6ff;display:flex;justify-content:center;min-height:100vh;padding:24px}.login-card{background:#fff;border:1px solid #c7ddf7;border-radius:16px;box-shadow:0 4px 24px #1e3a5f1a;max-width:400px;padding:40px 36px 36px;text-align:center;width:100%}.login-logo{font-size:40px;margin-bottom:8px}.login-title{color:#1e3a5f;font-size:26px;font-weight:800;margin:0 0 4px}.login-subtitle{color:#6b7280;font-size:13px;margin:0 0 28px}.login-field{margin-bottom:16px;text-align:left}.login-label{color:#1e3a5f;display:block;font-size:13px;font-weight:600;margin-bottom:5px}.login-field .form-input{box-sizing:border-box;width:100%}.login-error{background:#fef2f2;border:1px solid #fca5a5;border-radius:8px;color:#991b1b;font-size:13px;margin-bottom:16px;padding:10px 14px;text-align:left}.login-btn{font-size:15px;margin-top:4px;padding:11px;width:100%}.login-password-wrapper{position:relative}.login-password-wrapper .form-input{padding-right:40px}.login-password-toggle{align-items:center;background:none;border:none;border-radius:4px;cursor:pointer;display:flex;justify-content:center;padding:4px;position:absolute;right:10px;top:50%;transform:translateY(-50%)}.login-password-toggle:focus-visible{outline:2px solid #007bff}.login-password-toggle:disabled{cursor:not-allowed;opacity:.5}.spinner{animation:spin .8s linear infinite;border:4px solid #c7ddf7;border-radius:50%;border-top-color:#007bff;height:40px;width:40px}@keyframes spin{to{transform:rotate(1turn)}}.modal-overlay--blocking{pointer-events:auto}.nav-item{align-items:center;border-radius:10px;color:#93c5fd;cursor:pointer;display:flex;font-size:14px;font-weight:500;gap:10px;margin-bottom:3px;padding:10px;position:relative;transition:background .15s,color .15s;-webkit-user-select:none;user-select:none}.nav-item:hover{background:#ffffff1f;color:#fff}.nav-item--active{background:#ffffff38;color:#fff;font-weight:700}.nav-item__icon{flex-shrink:0}.nav-item__badge{background:#ef4444;border-radius:999px;color:#fff;flex-shrink:0;font-size:10px;font-weight:800;margin-left:auto;padding:1px 6px}.sidebar__toggle{align-items:center;border-radius:10px;color:#93c5fd;cursor:pointer;display:flex;font-size:13px;gap:10px;padding:8px 10px}.sidebar__toggle:hover{background:#ffffff1a}.main-content{flex:1 1;max-width:100%;min-width:0;overflow-x:hidden;padding:24px 24px 40px}.page-header{align-items:center;display:flex;justify-content:space-between;margin-bottom:18px}.page-title{color:#1e3a5f;font-size:24px;font-weight:800;margin:0}.btn{align-items:center;border:none;border-radius:9px;cursor:pointer;display:inline-flex;font-size:13px;font-weight:700;gap:6px;padding:8px 16px;transition:opacity .15s}.btn:hover{opacity:.88}.btn:focus-visible{outline:2px solid #007bff;outline-offset:2px}.btn-primary{background:linear-gradient(135deg,#007bff,#0056b3);box-shadow:0 2px 10px #007bff4d;color:#fff}.btn-secondary{background:#f3f4f6;color:#374151}.btn-danger{background:linear-gradient(135deg,#ef4444,#dc2626);box-shadow:0 2px 8px #ef444447;color:#fff}.btn-danger-outline{background:#fef2f2;border:1.5px solid #fca5a5;color:#ef4444}.btn-outline{background:#e7f3ff;border:1.5px solid #007bff;color:#007bff}.btn-sm{font-size:12px;padding:5px 10px}.btn-lg{font-size:15px;padding:11px 20px}.btn-close{background:none;border:none;color:#9ca3af;cursor:pointer;font-size:20px}.btn-close:hover{color:#374151}.alert-banner{align-items:center;border-radius:10px;display:flex;font-size:12px;font-weight:600;gap:8px;margin-bottom:14px;padding:9px 15px}.alert-banner--warning{background:#fef3c7;border:1.5px solid #f59e0b;color:#92400e}.alert-banner--danger{background:#fee2e2;border:1.5px solid #ef4444;color:#991b1b}.summary-grid{grid-gap:12px;display:grid;gap:12px}.summary-grid--2{grid-template-columns:repeat(2,1fr)}.summary-grid--3{grid-template-columns:repeat(3,1fr)}.summary-card{background:#fff;border-radius:14px;box-shadow:0 2px 12px #007bff0f;padding:14px 16px}.summary-card--clickable{cursor:pointer;transition:box-shadow .18s,transform .14s,background .14s;-webkit-user-select:none;user-select:none}.summary-card--clickable:hover{box-shadow:0 6px 22px #007bff2e;transform:translateY(-2px)}.summary-card--clickable:focus-visible{outline:2px solid #007bff;outline-offset:3px}.summary-card--active{background:#eef5ff;box-shadow:0 0 0 2.5px #007bff,0 4px 16px #007bff2e;transform:translateY(-1px)}.summary-card__hint{color:#93c5fd;font-size:9px;font-weight:600;letter-spacing:.3px;margin-top:5px;opacity:0;text-transform:uppercase;transition:opacity .15s}.summary-card--active .summary-card__hint,.summary-card--clickable:hover .summary-card__hint{opacity:1}.summary-card--blue{background:linear-gradient(135deg,#007bff,#0056b3);box-shadow:0 2px 12px #007bff40}.summary-card__header{align-items:center;display:flex;gap:7px;margin-bottom:5px}.summary-card__icon{border-radius:7px;padding:5px}.summary-card__label{color:#6b7280;font-size:11px}.summary-card__value{font-size:19px;font-weight:800}.summary-card__tag{color:#6b7280;font-size:10px;font-weight:700;letter-spacing:.5px;margin-bottom:4px;text-transform:uppercase}.summary-card__sub{color:#9ca3af;font-size:10px;margin-top:2px}.active-filter-chip{align-items:center;animation:slideIn .2s ease;background:#dbeafe;border:1.5px solid #007bff;border-radius:999px;color:#1e3a5f;display:inline-flex;font-size:12px;font-weight:700;gap:6px;padding:5px 10px}.active-filter-chip__clear{background:none;border:none;color:#007bff;cursor:pointer;font-size:13px;font-weight:800;line-height:1;padding:0 2px;transition:color .12s}.active-filter-chip__clear:hover{color:#ef4444}.active-filter-chip__clear:focus-visible{border-radius:3px;outline:2px solid #007bff}.mini-card{background:#f8fbff;border-radius:9px;padding:10px}.mini-card__label{color:#6b7280;font-size:10px}.mini-card__value{font-size:13px;font-weight:800}.filter-bar{align-items:center;display:flex;flex-wrap:wrap;gap:8px;margin-bottom:12px}.filter-btn{background:#fff;border:1.5px solid #c7ddf7;border-radius:8px;color:#374151;cursor:pointer;font-size:12px;font-weight:600;padding:7px 12px;transition:all .15s}.filter-btn--active{background:#007bff;border-color:#007bff;color:#fff}.filter-btn:focus-visible{outline:2px solid #007bff}.type-filter-btn{background:#fff;border:1.5px solid #c7ddf7;border-radius:8px;color:#374151;cursor:pointer;font-size:13px;font-weight:600;padding:7px 12px;transition:all .15s}.type-filter-btn.active-all{background:#007bff;border-color:#007bff;color:#fff}.type-filter-btn.active-income{background:#10b981;border-color:#10b981;color:#fff}.type-filter-btn.active-expense{background:#ef4444;border-color:#ef4444;color:#fff}.type-filter-btn:focus-visible{outline:2px solid #007bff}.dot-matrix-preview{background:#f5f5f5;border:1px solid #ccc;border-radius:6px;font-family:Courier New,Courier,monospace;font-size:12px;line-height:1.4;max-height:60vh;overflow-x:auto;overflow-y:auto;padding:16px;white-space:pre}.sort-select{background:#fff;border:1.5px solid #c7ddf7;border-radius:8px;cursor:pointer;font-size:12px;outline:none;padding:7px 10px}.search-wrap{align-items:center;display:flex;flex:1 1;min-width:200px;position:relative}.search-icon{left:9px;pointer-events:none;position:absolute}.search-input{background:#fff;border:1.5px solid #c7ddf7;border-radius:8px;box-sizing:border-box;font-size:13px;outline:none;padding:8px 10px 8px 30px;width:100%}.search-input:focus{border-color:#007bff}.search-bar-wrapper{align-items:stretch;border-radius:10px;box-shadow:0 1px 4px #007bff14;display:flex;flex:1 1;min-width:0;overflow:hidden;transition:box-shadow .15s}.search-bar-wrapper:focus-within{box-shadow:0 0 0 2.5px #007bff4d}.search-bar__category{appearance:none;-webkit-appearance:none;background:#f0f7ff;background-image:url("data:image/svg+xml;charset=utf-8,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 24 24' fill='none' stroke='%23007BFF' stroke-width='2.5'%3E%3Cpath d='m6 9 6 6 6-6'/%3E%3C/svg%3E");background-position:right 10px center;background-repeat:no-repeat;border:1.5px solid #c7ddf7;border-radius:10px 0 0 10px;border-right:none;color:#1e3a5f;cursor:pointer;flex-shrink:0;font-size:13px;font-weight:600;min-width:140px;outline:none;padding:10px 28px 10px 12px}.search-bar__category:focus{outline:none}.search-bar__input{background:#fff;border:1.5px solid #c7ddf7;border-left:none;border-radius:0;border-right:none;flex:1 1;font-size:13px;min-width:0;outline:none;padding:10px 14px}.search-bar__input:focus{outline:none}.search-bar__sort{appearance:none;-webkit-appearance:none;background:#f0f7ff;background-image:url("data:image/svg+xml;charset=utf-8,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 24 24' fill='none' stroke='%23007BFF' stroke-width='2.5'%3E%3Cpath d='m6 9 6 6 6-6'/%3E%3C/svg%3E");background-position:right 10px center;background-repeat:no-repeat;border:1.5px solid #c7ddf7;border-left:none;border-radius:0 10px 10px 0;color:#1e3a5f;cursor:pointer;flex-shrink:0;font-size:13px;font-weight:600;min-width:130px;outline:none;padding:10px 28px 10px 12px}.search-bar__sort:focus{outline:none}@media (max-width:600px){.search-bar__category,.search-bar__sort{font-size:11px;min-width:80px;padding:8px 20px 8px 8px}.search-bar__input{font-size:12px;padding:8px 10px}}.table-card{background:#fff;border-radius:14px;box-shadow:0 2px 12px #007bff0f;overflow:hidden}.table-header-bar{background:#e7f3ff;border-bottom:1px solid #c7ddf7;color:#1e3a5f;font-size:13px;padding:10px 14px}.data-table{border-collapse:collapse;font-size:12px;width:100%}.data-table thead tr{background:linear-gradient(180deg,#dbeafe,#e7f3ff);border-bottom:2px solid #c7ddf7}.data-table th{color:#1e3a5f;font-size:11px;font-weight:800;letter-spacing:.4px;padding:12px;text-align:left;text-transform:uppercase;white-space:nowrap}.td-check,.th-check{padding-left:12px!important;width:32px}.td-center,.th-center{text-align:center!important}.td-right,.th-right{text-align:right!important}.data-table td{padding:10px 12px}.data-table .row-alt{background:#f8fbff}.data-table tbody tr{border-bottom:1px solid #f0f6ff}.data-table tbody tr:hover{background:#eef5ff!important}.outstanding-row--overdue{border-left:3px solid #fca5a5}.outstanding-row--overdue,.outstanding-row--overdue td{background-color:#fef2f2!important}.outstanding-row--near-due{border-left:3px solid #fcd34d}.outstanding-row--near-due,.outstanding-row--near-due td{background-color:#fffbeb!important}.outstanding-row--flash{border-left:4px solid #3b82f6;box-shadow:inset 0 0 0 1px #3b82f633}.outstanding-row--flash,.outstanding-row--flash td{background-color:#dbeafe!important}@keyframes tx-flash-fade{0%,60%{background-color:#bfdbfe}to{background-color:initial}}.tx-row--flash{border-left:4px solid #3b82f6;box-shadow:inset 0 0 0 1px #3b82f633}.tx-row--flash,.tx-row--flash td{animation:tx-flash-fade 3s ease forwards}.td-date{color:#6b7280;font-size:11px;white-space:nowrap}.td-name{color:#1e3a5f;font-weight:600}.td-value{font-weight:700;white-space:nowrap}.text-muted{color:#6b7280}.text-green{color:#10b981}.text-red{color:#ef4444}.text-amber{color:#f59e0b}.whitespace-nowrap{white-space:nowrap}.hidden{display:none}.action-btns{display:flex;gap:3px}.action-btn{border:none;border-radius:5px;cursor:pointer;padding:5px;transition:opacity .15s}.action-btn:hover{opacity:.75}.action-btn:focus-visible{outline:2px solid #007bff}.action-btn--edit{background:#e7f3ff}.action-btn--invoice{background:#f0fdf4}.action-btn--paid{background:#d1fae5;color:#065f46;font-size:13px;font-weight:800;line-height:1}.action-btn--paid:hover{background:#a7f3d0}.action-btn--delete{background:#fef2f2}.action-btn--archive{background:#fffbeb}.action-btn--archive:hover{background:#fef3c7}.type-badge{align-items:center;border-radius:999px;display:inline-flex;font-size:11px;font-weight:700;gap:4px;padding:3px 10px;white-space:nowrap}.type-badge--income{background:#d1fae5;color:#065f46}.type-badge--expense{background:#fee2e2;color:#991b1b}.stock-delta{font-size:12px;font-weight:700}.badge{border-radius:999px;font-size:11px;font-weight:600;padding:2px 8px;white-space:nowrap}.stock-chip{border-radius:999px;display:inline-flex;font-weight:700;padding:2px 9px}.save-indicator,.stock-chip{align-items:center;font-size:12px;gap:4px}.save-indicator{display:flex}.save-indicator.saved{color:#10b981}.save-indicator.saving{color:#9ca3af}.save-indicator__time{color:#9ca3af;font-size:.9em}.rupiah-input-wrap{align-items:center;display:flex;position:relative}.rupiah-prefix{color:#6b7280;font-size:13px;font-weight:600;left:10px;pointer-events:none;position:absolute;-webkit-user-select:none;user-select:none}.rupiah-input{font-feature-settings:"tnum";background:#f8fbff;border:1.5px solid #c7ddf7;border-radius:8px;box-sizing:border-box;font-size:14px;font-variant-numeric:tabular-nums;letter-spacing:.3px;outline:none;padding:8px 10px 8px 30px;width:100%}.rupiah-input:focus{border-color:#007bff}.rupiah-input.input-error{border-color:#ef4444}.form-card{background:#fff;border-radius:16px;box-shadow:0 4px 24px #007bff17;padding:22px}.form-title{color:#1e3a5f;font-size:17px;font-weight:800;margin:0 0 14px}.form-grid{grid-gap:0 14px;display:grid;gap:0 14px;grid-template-columns:1fr 1fr}.form-section-label{border-bottom:1px solid #e7f3ff;color:#93c5fd;font-size:10px;font-weight:800;letter-spacing:1px;margin-bottom:2px;margin-top:6px;padding-bottom:3px;text-transform:uppercase}.field-error{color:#ef4444;display:block;font-size:11px;line-height:1.3;margin-top:2px}.stock-preview{color:#6b7280;font-size:11px;margin-top:3px}.type-btn{background:#f8fbff;border:1.5px solid #c7ddf7;border-radius:8px;color:#374151;cursor:pointer;flex:1 1;font-size:12px;font-weight:700;padding:8px 0;transition:all .15s}.type-btn--income{background:#10b981;border:none;color:#fff}.type-btn--expense{background:#ef4444;border:none;color:#fff}.type-hint{color:#6b7280;font-size:10px;margin-top:3px}.autocomplete-dropdown{background:#fff;border:1.5px solid #c7ddf7;border-radius:8px;box-shadow:0 4px 16px #00000014;left:0;position:absolute;right:0;top:100%;z-index:99}.autocomplete-item{cursor:pointer;font-size:14px;padding:8px 12px}.autocomplete-item:hover{background:#e7f3ff}.autocomplete-item--stock{display:flex;justify-content:space-between}.autocomplete-stock-hint{color:#6b7280;font-size:12px}.item-fields-row{grid-gap:10px;display:grid;gap:10px;grid-template-columns:repeat(4,1fr)}.item-field-label{align-items:flex-end;color:#1e3a5f;display:flex;font-size:11px;font-weight:800;letter-spacing:.5px;margin-bottom:3px;min-height:36px;text-transform:uppercase}.cp-input-wrap{align-items:center;display:flex;position:relative}.cp-input{background:#f8fbff;border:1.5px solid #c7ddf7;border-radius:8px;box-sizing:border-box;cursor:pointer;font-size:14px;outline:none;padding:8px 32px 8px 10px;transition:border-color .15s;width:100%}.cp-input:focus{border-color:#007bff}.cp-input.input-error{border-color:#ef4444}.cp-chevron{color:#9ca3af;cursor:pointer;font-size:14px;line-height:1;position:absolute;right:10px;transition:transform .18s,color .15s;-webkit-user-select:none;user-select:none}.cp-chevron--open{color:#007bff;transform:rotate(180deg)}.client-dropdown{animation:slideIn .15s ease;background:#fff;border:1.5px solid #c7ddf7;border-radius:10px;box-shadow:0 8px 24px #007bff21;left:0;max-height:280px;overflow-y:auto;position:absolute;right:0;top:calc(100% + 4px);z-index:200}.new-client-option{align-items:center;border-bottom:1px solid #e7f3ff;cursor:pointer;display:flex;gap:8px;padding:10px 12px;transition:background .12s}.new-client-option--highlighted,.new-client-option:hover{background:#f0fdf4}.new-client-option__icon{align-items:center;background:#10b981;border-radius:50%;color:#fff;display:flex;flex-shrink:0;font-size:14px;font-weight:800;height:22px;justify-content:center;line-height:1;width:22px}.new-client-option__text{color:#065f46;font-size:13px;font-weight:600}.new-client-option__text strong{color:#059669}.client-dropdown__divider{background:#f8fbff;border-bottom:1px solid #e7f3ff;color:#9ca3af;font-size:10px;font-weight:700;letter-spacing:.6px;padding:5px 12px;text-transform:uppercase}.contact-suggestion-row{align-items:center;border-bottom:1px solid #f0f6ff;cursor:pointer;display:flex;gap:8px;justify-content:space-between;padding:9px 12px;transition:background .1s}.contact-suggestion-row:last-child{border-bottom:none}.contact-suggestion-row--highlighted,.contact-suggestion-row:hover{background:#e7f3ff}.contact-suggestion-row__main{display:flex;flex-direction:column;gap:2px;min-width:0}.contact-suggestion-row__name{color:#1e3a5f;font-size:13px;font-weight:700;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.contact-suggestion-row__secondary{color:#6b7280;font-size:11px}.contact-suggestion-row__badge{border-radius:999px;flex-shrink:0;font-size:10px;font-weight:700;padding:2px 7px;white-space:nowrap}.badge--ar{background:#d1fae5;color:#065f46}.badge--ap{background:#fee2e2;color:#991b1b}.client-dropdown__empty{color:#9ca3af;font-size:12px;padding:14px 12px;text-align:center}.cp-toast{animation:slideIn .2s ease;background:#d1fae5;border:1px solid #6ee7b7;border-radius:8px;color:#065f46;font-size:12px;font-weight:600;gap:6px;margin-bottom:12px;padding:7px 12px}.cp-toast,.modal-overlay{align-items:center;display:flex}.modal-overlay{animation:fadeIn .18s ease;background:#00000087;inset:0;justify-content:center;padding:20px;position:fixed;z-index:2000}.modal-box{animation:slideIn .2s ease;background:#fff;border-radius:16px;box-shadow:0 8px 40px #00000038;padding:28px;width:100%}.modal-title{color:#1e3a5f;font-size:18px;margin:0 0 8px}.modal-body{color:#374151;font-size:13px;margin:0 0 6px}.modal-actions{display:flex;gap:10px;margin-top:4px}.modal-actions .btn{flex:1 1;font-size:14px;justify-content:center;padding:10px 0}.delete-icon-circle{align-items:center;background:#fee2e2;border-radius:999px;display:flex;height:52px;justify-content:center;margin:0 auto 12px;width:52px}.delete-tx-summary{background:#f8fbff;border:1px solid #e7f3ff;border-radius:10px;margin-bottom:18px;padding:10px 14px}.delete-tx-name{color:#1e3a5f;font-size:13px;font-weight:700}.delete-tx-meta{color:#6b7280;font-size:12px;margin-top:2px}.paid-icon-circle{font-size:36px;margin-bottom:10px;text-align:center}.paid-tx-summary{background:#f0fdf4;border:1px solid #a7f3d0;border-radius:10px;display:flex;flex-direction:column;gap:5px;padding:10px 14px}.paid-tx-label{color:#6b7280;display:inline-block;font-size:11px;width:90px}.paid-tx-value{color:#1e3a5f;font-size:12px}.btn-paid{background:linear-gradient(135deg,#10b981,#059669);box-shadow:0 2px 8px #10b9814d;color:#fff}.payment-field{margin:14px 0 6px}.payment-field__label{color:#1e3a5f;display:block;font-size:11px;font-weight:800;letter-spacing:.5px;margin-bottom:5px;text-transform:uppercase}.payment-field__error{color:#ef4444;font-size:11px;font-weight:600;margin-top:4px}.payment-preview{font-size:12px;margin-bottom:4px;min-height:22px;text-align:center}.payment-preview--full{color:#059669;font-weight:600}.payment-preview--partial{color:#0056b3;font-weight:600}.toast{align-items:center;animation:slideIn .25s ease;border-radius:12px;bottom:24px;box-shadow:0 4px 20px #00000026;display:flex;font-size:13px;font-weight:600;gap:8px;max-width:360px;padding:12px 18px;position:fixed;right:24px;z-index:4000}.filter-card{background:#fff;border-radius:14px;box-shadow:0 2px 10px #007bff0f;margin-bottom:18px;padding:16px}.field-label{color:#6b7280;display:block;font-size:11px;font-weight:600;margin-bottom:3px}.date-input{background:#fff;border:1.5px solid #c7ddf7;border-radius:7px;font-size:13px;outline:none;padding:7px 9px}.date-input:focus{border-color:#007bff}.reports-filter-summary{align-items:center;background:#f0f6ff;border-radius:8px;color:#1e3a5f;display:flex;flex-wrap:wrap;font-size:12px;gap:6px;margin-top:12px;padding:7px 10px}.reports-filter-summary__icon{flex-shrink:0;font-size:13px}.reports-filter-summary__count{color:#007bff;font-weight:700;margin-left:auto;white-space:nowrap}.reports-confirm-banner{background:#fffbeb;border:1.5px solid #f59e0b;border-radius:10px;color:#92400e;font-size:13px;margin-bottom:16px;padding:12px 16px}.ms-wrap{display:inline-block;position:relative;width:100%}.ms-trigger{align-items:center;background:#fff;border:1.5px solid #c7ddf7;border-radius:7px;color:#1e3a5f;cursor:pointer;display:flex;font-size:13px;gap:6px;justify-content:space-between;overflow:hidden;padding:7px 9px;text-align:left;transition:border-color .15s;white-space:nowrap;width:100%}.ms-trigger--active,.ms-trigger--open,.ms-trigger:hover{border-color:#007bff}.ms-trigger--active{background:#f0f8ff}.ms-placeholder{color:#9ca3af}.ms-all-label{color:#6b7280;font-style:italic}.ms-value{color:#1e3a5f;font-weight:600;overflow:hidden;text-overflow:ellipsis}.ms-chevron{color:#9ca3af;flex-shrink:0;font-size:11px;transition:transform .15s}.ms-chevron--open{transform:rotate(180deg)}.ms-dropdown{background:#fff;border:1.5px solid #c7ddf7;border-radius:9px;box-shadow:0 6px 24px #007bff1f;left:0;min-width:100%;overflow:hidden;position:absolute;top:calc(100% + 4px);z-index:3000}.ms-search-wrap{border-bottom:1px solid #f0f6ff;padding:7px 8px 5px;position:relative}.ms-search{background:#f8fbff;border:1.5px solid #c7ddf7;border-radius:6px;box-sizing:border-box;font-size:12px;outline:none;padding:5px 24px 5px 8px;width:100%}.ms-search:focus{border-color:#007bff}.ms-search-clear{background:none;border:none;color:#9ca3af;cursor:pointer;font-size:11px;line-height:1;padding:0;position:absolute;right:14px;top:50%;transform:translateY(-50%)}.ms-divider{background:#f0f6ff;height:1px;margin:0}.ms-option{align-items:center;color:#1e3a5f;cursor:pointer;display:flex;font-size:13px;gap:7px;padding:7px 10px;transition:background .1s;-webkit-user-select:none;user-select:none}.ms-option:hover{background:#f0f6ff}.ms-option--checked{background:#e7f3ff}.ms-option--checked:hover{background:#dbeafe}.ms-option--all{color:#007bff;font-weight:600}.ms-checkbox{color:#007bff;flex-shrink:0;font-size:14px}.ms-option-label{flex:1 1;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.ms-count-badge{background:#007bff;border-radius:99px;color:#fff;flex-shrink:0;font-size:10px;margin-left:auto;padding:1px 6px}.ms-empty{color:#9ca3af;font-size:12px;padding:10px;text-align:center}.ms-filter-badge{align-items:center;background:#007bff;border-radius:99px;color:#fff;display:inline-flex;font-size:9px;font-weight:700;justify-content:center;line-height:1.4;margin-left:4px;padding:1px 5px;vertical-align:middle}.contacts-page{display:block}.contacts-page--split{align-items:flex-start;display:flex;gap:0;min-width:0}.contacts-page--split .contacts-list-panel{border-right:1px solid #e2e8f0;flex-shrink:0;max-width:380px;min-width:280px;padding-right:16px;width:340px}.contacts-detail-panel{animation:contactDetailSlideIn .18s ease-out;flex:1 1;min-width:0;overflow-x:hidden;padding-left:20px}@keyframes contactDetailSlideIn{0%{opacity:0;transform:translateX(14px)}to{opacity:1;transform:translateX(0)}}.contacts-detail-hdr{align-items:flex-start;border-bottom:1px solid #e2e8f0;display:flex;gap:12px;margin-bottom:16px;padding-bottom:14px}.contacts-detail-hdr__name{flex:1 1;min-width:0}.contacts-detail-back{align-self:center;background:none;border:1.5px solid #c7ddf7;border-radius:8px;color:#007bff;cursor:pointer;flex-shrink:0;font-size:12px;font-weight:600;padding:6px 12px;transition:background .15s,color .15s;white-space:nowrap}.contacts-detail-back:hover{background:#007bff;color:#fff}.contacts-table-scroll{border:1px solid #e2e8f0;border-radius:10px;overflow:hidden;overflow-x:auto;width:100%}.contacts-history-table{border-collapse:collapse;min-width:850px;width:100%}.contacts-history-table td{background:#fff;border-bottom:1px solid #e2e8f0}.contacts-history-table .row-alt td{background:#fff}.contacts-history-table tbody tr:last-child td{border-bottom:none}.contacts-history-table tbody tr:hover td{background:#f8faff}.contact-item{align-items:center;border-bottom:1px solid #f0f6ff;cursor:pointer;display:flex;gap:10px;padding:10px 12px;transition:background .12s}.contact-item:hover{background:#f0f6ff}.contact-item--active{background:#e7f3ff}.contact-item__name{color:#1e3a5f;font-size:14px;font-weight:700}.contact-item__left{flex-shrink:0;min-width:0}.contact-item__right{flex-shrink:0;text-align:right}.contact-item__middle{align-items:center;display:none;flex:1 1;flex-wrap:wrap;gap:8px}.contacts-page--split .contact-item__middle{display:none}.contacts-page--split .contact-item__left{flex:1 1;min-width:0}.contacts-page--full .contact-item{background:#fff;border:1px solid #e2e8f0;border-radius:10px;margin-bottom:6px;padding:12px 16px}.contacts-page--full .contact-item:hover{background:#f0f7ff;border-color:#007bff}.contacts-page--full .contact-item--active{background:#e7f3ff;border-color:#007bff}.contacts-page--full .contact-item__middle{display:flex}.contacts-page--full .contact-item__left{flex-shrink:0;min-width:160px}.contacts-page--full .row-alt{background:none}.contacts-page--full .table-card{background:none;border-radius:0;box-shadow:none;padding:4px 0!important}.contact-item__tag{align-items:center;border-radius:20px;display:inline-flex;font-size:11px;font-weight:600;padding:2px 9px}.contact-item__tag--ar{background:#f0fdf4;border:1px solid #bbf7d0;color:#059669}.contact-item__tag--ap{background:#fef2f2;border:1px solid #fecaca;color:#ef4444}.contact-form-card{background:#fff;border-radius:12px;box-shadow:0 2px 10px #007bff14;margin-bottom:10px;padding:14px}.contact-form-title{color:#1e3a5f;font-size:13px;margin:0 0 8px}.contact-input{border:1.5px solid #c7ddf7;border-radius:7px;box-sizing:border-box;font-size:13px;margin-bottom:6px;outline:none;padding:7px 10px;width:100%}.contact-input:focus{border-color:#007bff}.contact-detail-name{color:#1e3a5f;font-size:18px;font-weight:700;margin:0}.section-subtitle{color:#1e3a5f;font-size:13px;margin:0 0 8px}.alpha-filter{display:flex;flex-wrap:wrap;gap:3px;margin-bottom:8px}.alpha-btn{background:#fff;border:1px solid #c7ddf7;border-radius:4px;color:#1e3a5f;cursor:pointer;font-size:11px;font-weight:700;min-width:22px;padding:2px 5px;text-align:center;transition:background .1s,color .1s}.alpha-btn:hover:not(:disabled){background:#e7f3ff}.alpha-btn--active{background:#007bff;border-color:#007bff;color:#fff}.alpha-btn--empty{cursor:not-allowed;opacity:.3}.alpha-btn--all{min-width:44px}.contacts-sort-row{align-items:center;display:flex;font-size:12px;justify-content:space-between;margin-bottom:8px}.contacts-sort-label{color:#6b7280}.contacts-count{color:#6b7280;font-size:11px}.settings-card{background:#fff;border-radius:14px;box-shadow:0 2px 12px #007bff0f;margin-bottom:18px;padding:22px}.settings-section-title{color:#1e3a5f;font-size:16px;font-weight:700;margin:0 0 14px}.import-msg{border-radius:7px;font-size:13px;margin-top:12px;padding:8px 12px}.import-msg--success{background:#d1fae5;color:#065f46}.import-msg--error{background:#fee2e2;color:#991b1b}.sort-btn{align-items:center;background:none;border:none;color:#1e3a5f;cursor:pointer;display:flex;font-size:11px;font-weight:700;gap:2px;padding:0}.sort-btn:focus-visible{border-radius:3px;outline:2px solid #007bff}.empty-state{color:#9ca3af;font-size:13px;padding:40px;text-align:center}.edit-modal-overlay{align-items:center;background:#00000080;display:flex;inset:0;justify-content:center;padding:20px;position:fixed;z-index:1000}.edit-modal-box{background:#fff;border-radius:16px;box-shadow:0 8px 40px #00000038;max-height:92vh;max-width:580px;overflow:auto;padding:22px;width:100%}.report-stok-out{color:#ef4444}.report-stok-in{color:#10b981}.report-stok-cell{font-size:11px;font-weight:600;white-space:nowrap}.report-stok-item{display:block;line-height:1.6}@media (max-width:768px){.sidebar{position:fixed;z-index:500}.sidebar--open{width:200px}.sidebar--closed{overflow:hidden;width:0}.main-content{padding:16px 14px 32px}.summary-grid--3{grid-template-columns:1fr 1fr}.summary-grid--3>:last-child{grid-column:1/-1}.contacts-page--split{flex-direction:column}.contacts-page--split .contacts-list-panel{border-bottom:1px solid #e2e8f0;border-right:none;margin-bottom:12px;max-width:100%;padding-bottom:12px;padding-right:0;width:100%}.contacts-detail-panel{padding-left:0}.form-grid{grid-template-columns:1fr}.form-grid>*{grid-column:1/-1!important}}@media (min-width:768px){.md\:table-cell{display:table-cell}}.item-list{display:flex;flex-direction:column;gap:3px}.item-list__row{align-items:center;display:flex;font-size:12px;gap:5px}.item-list__bullet{color:#007bff;flex-shrink:0;font-size:8px}.item-list__subtotal{border-top:1px solid #e5e7eb;color:#6b7280;font-size:10px;margin-top:4px;padding-top:4px}.item-list__divider{border:none;border-top:1px solid #e5e7eb;margin:3px 0;width:100%}.item-filter-primary{font-weight:600}.item-filter-secondary{color:#9ca3af;font-size:11px}.item-filter-value-primary{font-weight:700}.item-filter-value-secondary{color:#9ca3af;font-size:10px;margin-top:2px}.item-filter-note{color:#6b7280;font-size:10px;font-style:italic;margin-top:4px}.payment-history-row{background:#f8faff}.payment-history-cell{border-bottom:2px solid #e0eaff;border-top:2px solid #e0eaff;padding:12px 18px 16px 32px}.payment-history-row td{animation:slideDown .2s ease-out}@keyframes slideDown{0%{opacity:0;transform:translateY(-8px)}to{opacity:1;transform:translateY(0)}}.payment-progress-wrap{align-items:center;display:flex;gap:5px;margin-top:4px}.payment-progress-bar{background:#e5e7eb;border-radius:99px;height:5px;overflow:hidden;width:80px}.payment-progress-bar__fill{background:#10b981;border-radius:99px;height:100%;transition:width .3s ease}.payment-progress-pct{color:#6b7280;font-size:10px}.action-btn--history{align-items:center;background:#f0f4ff;border:1px solid #c7ddf7;border-radius:6px;color:#007bff;cursor:pointer;display:inline-flex;font-size:12px;height:24px;justify-content:center;padding:0;position:relative;transition:background .15s;width:24px}.action-btn--history:hover{background:#dbeafe}.action-btn--history-badge{align-items:center;background:#ef4444;border:1.5px solid #fff;border-radius:99px;color:#fff;display:flex;font-size:8px;font-weight:700;height:13px;justify-content:center;min-width:13px;padding:0 2px;pointer-events:none;position:absolute;right:-5px;top:-5px}.payment-timeline{padding:8px 0 4px 8px}.payment-timeline__header{align-items:flex-start;border-bottom:1px solid #e5e7eb;display:flex;justify-content:space-between;margin-bottom:12px;padding-bottom:10px}.payment-timeline__title{color:#1e3a5f;font-size:13px;font-weight:700}.payment-timeline__total{color:#6b7280;font-size:11px;margin-top:2px}.payment-timeline__progress-wrap{text-align:right}.payment-timeline__progress-bar{background:#e5e7eb;border-radius:99px;height:7px;margin-bottom:3px;overflow:hidden;width:160px}.payment-timeline__progress-fill{background:linear-gradient(90deg,#10b981,#059669);border-radius:99px;height:100%}.payment-timeline__progress-label{color:#6b7280;font-size:10px}.payment-timeline__nodes{padding-left:20px;position:relative}.payment-timeline__node{padding-bottom:16px;padding-left:16px;position:relative}.payment-timeline__dot{background:#007bff;border:2px solid #fff;border-radius:50%;box-shadow:0 0 0 2px #007bff;height:12px;left:-20px;position:absolute;top:2px;width:12px}.payment-timeline__dot--lunas{background:#10b981;box-shadow:0 0 0 2px #10b981}.payment-timeline__dot--empty{background:#fff;box-shadow:0 0 0 2px #9ca3af}.payment-timeline__dot--pending{background:#fff;border:2px dashed #f59e0b;box-shadow:0 0 0 2px #f59e0b}.payment-timeline__line{background:#e5e7eb;bottom:0;left:-15px;position:absolute;top:14px;width:2px}.payment-timeline__datetime{color:#9ca3af;font-size:10px;margin-bottom:2px}.payment-timeline__label{color:#1e3a5f;font-size:12px;font-weight:700;margin-bottom:2px}.payment-timeline__amount{color:#10b981;font-size:12px;font-weight:700}.payment-timeline__remaining{color:#f59e0b;font-size:11px;margin-top:1px}.payment-timeline__remaining--lunas{color:#10b981}.payment-timeline__user-note{color:#6b7280;font-size:11px;font-style:italic;margin-top:2px}.payment-timeline__data-warning{color:#9ca3af;font-size:10px;margin-top:2px}.payment-timeline__pending-node{padding-left:16px;padding-top:4px}.payment-timeline__pending-label{color:#f59e0b;font-size:11px;font-weight:600}.payment-timeline__pending-info{color:#9ca3af;font-size:10px;margin-top:1px}.payment-timeline__footer{grid-gap:6px 20px;border-top:1px solid #e5e7eb;display:grid;font-size:11px;gap:6px 20px;grid-template-columns:repeat(2,1fr);margin-top:14px;padding-top:10px}.payment-timeline__footer-item{display:flex;justify-content:space-between}.payment-timeline__footer-label{color:#6b7280}.payment-timeline__footer-value{color:#111827;font-weight:700}.payment-timeline__footer-value--green{color:#10b981}.payment-timeline__footer-value--amber{color:#f59e0b}.payment-timeline__close{background:none;border:none;border-radius:4px;color:#9ca3af;cursor:pointer;font-size:13px;font-weight:600;padding:2px 8px}.payment-timeline__close:hover{background:#f3f4f6;color:#374151}input[type=number]::-webkit-inner-spin-button,input[type=number]::-webkit-outer-spin-button{-webkit-appearance:none;margin:0}input[type=number]{-moz-appearance:textfield}.stock-ledger-wrap{padding:14px 16px 16px}.stock-ledger-header{align-items:flex-start;border-bottom:1px solid #e5e7eb;display:flex;justify-content:space-between;margin-bottom:12px;padding-bottom:10px}.stock-ledger-title{align-items:center;color:#1e3a5f;display:flex;font-size:13px;font-weight:700;gap:6px}.stock-ledger-subtitle{color:#9ca3af;font-size:11px;margin-top:2px}.stock-ledger-summary{display:flex;flex-wrap:wrap;gap:10px;margin-bottom:12px}.stock-ledger-mini-card{background:#fff;border:1px solid #e5e7eb;border-radius:8px;flex:1 1;min-width:120px;padding:8px 12px}.stock-ledger-mini-card__label{color:#9ca3af;font-size:10px;font-weight:600;letter-spacing:.4px;margin-bottom:3px;text-transform:uppercase}.stock-ledger-mini-card__value{font-size:13px;font-weight:700}.stock-ledger-filters{display:flex;flex-wrap:wrap;gap:8px;margin-bottom:12px}.stock-ledger-filter-group{display:flex;gap:4px}.stock-ledger-timeline{padding-left:8px}.stock-ledger-entry{display:flex;gap:10px;margin-bottom:12px}.stock-ledger-entry__track{align-items:center;display:flex;flex-direction:column;flex-shrink:0;width:14px}.stock-ledger-entry__dot{border-radius:50%;flex-shrink:0;height:10px;margin-top:3px;width:10px}.stock-ledger-entry__dot--diamond{border-radius:2px;transform:rotate(45deg)}.stock-ledger-entry__line{background:#e5e7eb;flex:1 1;margin-top:3px;min-height:10px;width:2px}.stock-ledger-entry__body{flex:1 1;padding-bottom:4px}.stock-ledger-entry__datetime{color:#9ca3af;font-size:10px;margin-bottom:2px}.stock-ledger-entry__label{font-size:12px;margin-bottom:2px}.stock-ledger-entry__delta{font-size:12px;font-weight:700}.stock-ledger-entry__running{color:#6b7280;font-size:10px;font-weight:400;margin-left:8px}.action-btn--history-active{background:#007bff}.inventory-date-nav{align-items:center;background:#e8f0fe;border:1.5px solid #c7ddf7;border-radius:12px;display:flex;flex-wrap:wrap;gap:12px;justify-content:space-between;margin-bottom:16px;padding:10px 16px}.inventory-date-nav__label{color:#6b7280;font-size:11px;font-weight:600;white-space:nowrap}.inventory-date-nav__date{color:#1e3a5f;font-size:15px;font-weight:700;-webkit-user-select:none;user-select:none}.inventory-date-nav__btn{background:#fff;border:1.5px solid #c7ddf7;border-radius:8px;color:#374151;cursor:pointer;font-size:12px;font-weight:600;padding:6px 14px;transition:background .15s,color .15s,border-color .15s}.inventory-date-nav__btn:hover:not(:disabled){background:#007bff;border-color:#007bff;color:#fff}.inventory-date-nav__btn:disabled{cursor:not-allowed;opacity:.4}.inventory-date-nav__btn--today{background:#007bff;border-color:#007bff;color:#fff}.inventory-date-nav__btn--today:disabled{background:#c7ddf7;border-color:#c7ddf7;color:#fff;opacity:1}.inventory-historical-banner{align-items:center;background:#fef3c7;border:1px solid #f59e0b;border-radius:8px;color:#92400e;display:flex;font-size:12px;gap:8px;margin-bottom:14px;padding:8px 14px}.inventory-group-header{background:#1e3a5f}.inventory-group-header td{border-bottom:2px solid #c7ddf7;color:#fff;font-size:12px;font-weight:700;letter-spacing:.5px;padding:8px 12px!important;text-transform:uppercase}.inventory-group-header:hover,.inventory-group-header:hover td{background:#1e3a5f!important;cursor:default}.stock-ledger-filter-label{color:#9ca3af;font-size:10px;font-weight:700;letter-spacing:.5px;margin-bottom:4px;text-transform:uppercase}.stock-ledger-date-range{align-items:center;display:flex;flex-wrap:wrap;gap:8px}.stock-ledger-date-input{background:#fff;border:1.5px solid #c7ddf7;border-radius:6px;color:#374151;font-size:12px;outline:none;padding:5px 8px}.stock-ledger-date-input:focus{border-color:#007bff}.stock-ledger-date-label{color:#6b7280;font-size:11px;font-weight:600;white-space:nowrap}.stock-ledger-summary-box{background:#f8faff;border:1px solid #c7ddf7;border-radius:10px;margin-bottom:14px;padding:12px 16px}.stock-ledger-summary-box__title{color:#6b7280;font-size:11px;font-weight:700;letter-spacing:.5px;margin-bottom:8px;text-transform:uppercase}.stock-ledger-summary-box__row{align-items:flex-start;display:flex;flex-wrap:wrap;gap:24px;margin-bottom:4px}.stock-ledger-summary-box__item{display:flex;flex-direction:column;gap:2px}.stock-ledger-summary-box__item-label{color:#9ca3af;font-size:10px}.stock-ledger-summary-box__item-value{font-size:14px;font-weight:700}.stock-ledger-summary-box__divider{border:none;border-top:1px solid #e5e7eb;margin:8px 0}.stock-ledger-summary-box__total{align-items:center;display:flex;justify-content:space-between}.stock-ledger-summary-box__total-label{color:#374151;font-size:12px;font-weight:600}.stock-ledger-summary-box__total-value{font-size:16px;font-weight:800}.action-btn--view{align-items:center;background:#f0f4ff;border:1px solid #c7ddf7;border-radius:6px;color:#007bff;cursor:pointer;display:inline-flex;height:24px;justify-content:center;padding:0;transition:background .15s;width:24px}.action-btn--view:hover{background:#dbeafe}.action-btn--adjust{align-items:center;background:#f0fdf4;border:1px solid #a7f3d0;border-radius:6px;color:#10b981;cursor:pointer;display:inline-flex;height:24px;justify-content:center;padding:0;transition:background .15s;width:24px}.action-btn--adjust:hover{background:#d1fae5}.tx-date-nav{align-items:center;background:#fff;border:1px solid #c7ddf7;border-left:4px solid #10b981;border-radius:10px;box-shadow:0 1px 4px #003c780f;display:flex;gap:8px;margin-bottom:10px;padding:10px 14px}.tx-date-nav__arrow{align-items:center;background:none;border:1px solid #c7ddf7;border-radius:6px;color:#1e3a5f;cursor:pointer;display:flex;flex-shrink:0;font-size:18px;height:30px;justify-content:center;line-height:1;transition:background .15s;width:30px}.tx-date-nav__arrow:hover{background:#f0f6ff}.tx-date-nav__center{flex:1 1;min-width:0;position:relative}.tx-date-nav__center,.tx-date-nav__date-text{align-items:center;display:flex;justify-content:center}.tx-date-nav__date-text{color:#1e3a5f;cursor:pointer;flex-wrap:wrap;font-size:14px;font-weight:700;gap:8px;-webkit-user-select:none;user-select:none}.tx-date-nav__date-text:hover{color:#007bff}.tx-date-nav__today-pill{border-radius:999px;color:#fff;font-size:10px;font-weight:600;letter-spacing:.02em;padding:2px 8px}.tx-date-nav__hidden-input{height:1px;left:50%;opacity:0;pointer-events:none;position:absolute;top:50%;width:1px}.tx-date-nav__today-btn{border:none;border-radius:6px;color:#fff;cursor:pointer;flex-shrink:0;font-size:12px;font-weight:600;padding:5px 12px;transition:opacity .15s}.tx-date-nav__today-btn:hover{opacity:.87}.day-summary-row{grid-gap:10px;display:grid;gap:10px;grid-template-columns:repeat(3,1fr);margin-bottom:12px}.day-summary-card{background:#fff;border:1px solid #c7ddf7;border-radius:10px;box-shadow:0 1px 3px #003c780d;min-width:0;padding:10px 14px}.day-summary-card__label{color:#6b7280;font-size:11px;font-weight:500;margin-bottom:2px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.day-summary-card__value{color:#1e3a5f;font-size:17px;font-weight:800;line-height:1.2}.day-summary-card__sub{color:#9ca3af;font-size:10px;margin-top:2px}.empty-state-icon{font-size:40px;margin-bottom:8px}.empty-state-title{color:#374151;font-size:15px;font-weight:700;margin-bottom:4px}.empty-state-subtitle{color:#9ca3af;font-size:12px;line-height:1.5;margin:0 auto;max-width:320px}.backup-banner{align-items:center;background:#fef9c3;border:1px solid #fde047;border-left:4px solid #ca8a04;border-radius:8px;display:flex;font-size:12px;gap:10px;justify-content:space-between;margin:0 0 12px;padding:7px 12px}.backup-banner__text{align-items:center;color:#854d0e;display:flex;flex-wrap:wrap;gap:6px}.backup-banner__link{background:none;border:none;color:#a16207;cursor:pointer;font-size:12px;font-weight:700;padding:0;text-decoration:underline}.backup-banner__link:hover{color:#78350f}.backup-banner__dismiss{background:none;border:none;color:#a16207;cursor:pointer;flex-shrink:0;font-size:14px;font-weight:700;line-height:1;padding:2px 4px}.backup-banner__dismiss:hover{color:#78350f}.surat-jalan-overlay{align-items:flex-start;background:#00000080;display:flex;inset:0;justify-content:center;overflow-y:auto;padding:20px;position:fixed;z-index:1000}.surat-jalan-modal{background:#fff;border-radius:12px;box-shadow:0 8px 40px #0000002e;max-width:680px;width:100%}.surat-jalan-controls{align-items:flex-start;background:#f8faff;border-bottom:1px solid #e5e7eb;border-radius:12px 12px 0 0;display:flex;flex-wrap:wrap;gap:10px;padding:16px 20px}.surat-jalan-controls__title{color:#1e3a5f;flex:1 1;font-size:14px;font-weight:700;margin-bottom:4px;min-width:100%}.surat-jalan-controls__input-group{display:flex;flex:1 1;flex-direction:column;gap:3px;min-width:200px}.surat-jalan-controls__label{color:#6b7280;font-size:10px;font-weight:700;text-transform:uppercase}.surat-jalan-controls__input{border:1.5px solid #c7ddf7;border-radius:6px;box-sizing:border-box;font-size:12px;outline:none;padding:6px 10px;width:100%}.surat-jalan-controls__input:focus{border-color:#007bff}.surat-jalan-preview{background:#f3f4f6;padding:24px}.surat-jalan-doc{background:#fff;border:1px solid #d1d5db;color:#000;font-family:Arial,sans-serif;margin:0 auto;max-width:580px;padding:32px 36px}.surat-jalan-doc__title{font-size:26px;font-weight:900;letter-spacing:3px;margin-bottom:6px;text-align:center;text-transform:uppercase}.surat-jalan-doc__title-line{border:2px solid #000;margin-bottom:16px}.surat-jalan-doc__info{grid-gap:8px 16px;display:grid;font-size:12px;gap:8px 16px;grid-template-columns:1fr 1fr;margin-bottom:16px}.surat-jalan-doc__info-block{display:flex;flex-direction:column;gap:6px}.surat-jalan-doc__info-row{align-items:baseline;display:flex;gap:8px}.surat-jalan-doc__info-label{font-size:11px;font-weight:700;min-width:90px;white-space:nowrap}.surat-jalan-doc__info-value{border-bottom:1px solid #000;flex:1 1;font-size:12px;min-width:80px}.surat-jalan-doc__info-value--blank{border-bottom:1px solid #000;display:inline-block;flex:1 1;min-height:16px;min-width:80px}.surat-jalan-doc__table{border-collapse:collapse;font-size:12px;margin-bottom:8px;width:100%}.surat-jalan-doc__table td,.surat-jalan-doc__table th{border:1.5px solid #000;padding:7px 10px}.surat-jalan-doc__table th{background:#fff;font-size:11px;font-weight:900;text-align:center;text-transform:uppercase}.surat-jalan-doc__table td:first-child{text-align:center;width:40px}.surat-jalan-doc__table td:last-child{text-align:center;white-space:nowrap}.surat-jalan-doc__total{font-size:12px;font-weight:700;margin-bottom:12px;padding-right:4px;text-align:right}.surat-jalan-doc__notes{border:1px solid #000;font-size:11px;margin-bottom:12px;padding:8px 10px}.surat-jalan-doc__notes-label{font-size:10px;font-weight:700;margin-bottom:3px;text-transform:uppercase}.surat-jalan-doc__signatures{grid-gap:20px;display:grid;gap:20px;grid-template-columns:1fr 1fr;margin-top:28px}.surat-jalan-doc__sig-block{align-items:center;display:flex;flex-direction:column}.surat-jalan-doc__sig-label{font-size:12px;font-weight:700;margin-bottom:4px;text-align:center}.surat-jalan-doc__sig-space{height:60px;width:100%}.surat-jalan-doc__sig-line{border-top:1.5px solid #000;width:100%}.surat-jalan-doc__sig-name{font-size:11px;font-style:italic;margin-top:3px;text-align:center}.surat-jalan-doc__footer{border-top:1px solid #d1d5db;color:#6b7280;font-size:9px;margin-top:16px;padding-top:8px;text-align:center}.action-btn--surat-jalan{align-items:center;background:#f5f3ff;border:1px solid #ddd6fe;border-radius:6px;color:#8b5cf6;cursor:pointer;display:inline-flex;height:24px;justify-content:center;padding:0;transition:background .15s;width:24px}.action-btn--surat-jalan:hover{background:#ede9fe}.surat-jalan-print-tip{color:#6b7280;font-size:11px;font-style:italic;margin-top:6px;width:100%}#print-portal{display:none}@media print{body.print-portal-active #root{display:none!important}body.print-portal-active #print-portal{display:block!important}#print-portal pre{page-break-inside:auto}}.cat-modal__header{border-bottom:1px solid #e5e7eb;margin-bottom:4px;padding-bottom:12px}.cat-modal__body{max-height:60vh;overflow-y:auto;padding:12px 0}.cat-modal__group{background:#fafcff;border:1px solid #c7ddf7;border-radius:10px;margin-bottom:10px;padding:14px;transition:background .15s,border-color .15s,box-shadow .15s}.cat-modal__group--drag-over{background:#e7f3ff;border-color:#007bff;box-shadow:inset 0 0 0 1px #007bff}.cat-modal__group--merge-target{background:#dbeafe;border:2px dashed #007bff;box-shadow:0 0 8px #007bff2e}.cat-modal__group--uncategorized{background:#fffbeb;border-color:#f59e0b;border-style:dashed}.cat-modal__group-header{align-items:center;display:flex;gap:8px}.cat-modal__group-drag{color:#9ca3af;cursor:grab;flex-shrink:0;font-size:16px;line-height:1;-webkit-user-select:none;user-select:none}.cat-modal__group-drag:active{cursor:grabbing}.cat-modal__group-name{border-bottom:1px dashed #0000;color:#1e3a5f;cursor:pointer;font-size:14px;font-weight:700;transition:border-color .15s}.cat-modal__group-name:hover{border-bottom-color:#93c5fd}.cat-modal__group-name-input{background:#0000;border:none;border-bottom:2px solid #007bff;color:#1e3a5f;font-size:14px;font-weight:700;min-width:120px;outline:none;padding:0 0 2px}.cat-modal__group-code{background:#e7f3ff;border:1px dashed #0000;border-radius:4px;color:#007bff;cursor:pointer;display:inline-block;font-size:11px;font-weight:800;letter-spacing:.5px;padding:2px 8px;transition:border-color .15s}.cat-modal__group-code:hover{border-color:#93c5fd}.cat-modal__group-code-input{background:#e7f3ff;border:none;border-bottom:2px solid #007bff;border-radius:4px;color:#007bff;font-size:11px;font-weight:800;letter-spacing:.5px;outline:none;padding:2px 6px;text-transform:uppercase;width:56px}.cat-modal__group-count{color:#9ca3af;flex-shrink:0;font-size:12px;margin-left:auto;white-space:nowrap}.cat-modal__group-delete{align-items:center;background:none;border:none;border-radius:6px;color:#9ca3af;cursor:pointer;display:flex;flex-shrink:0;justify-content:center;padding:4px;transition:color .15s,background .15s}.cat-modal__group-delete:hover{background:#fee2e2;color:#ef4444}.cat-modal__group-items{display:flex;flex-wrap:wrap;gap:6px;margin-top:8px}.cat-modal__item-pill{align-items:center;background:#f3f4f6;border:1px solid #e5e7eb;border-radius:20px;color:#374151;cursor:grab;display:inline-flex;font-size:12px;padding:3px 12px;transition:opacity .15s,background .15s;-webkit-user-select:none;user-select:none}.cat-modal__item-pill:active{cursor:grabbing}.cat-modal__item-pill:hover{background:#e5e7eb}.cat-modal__item-pill--dragging{opacity:.35}.cat-modal__item-pill--archived{opacity:.55;text-decoration:line-through}.cat-modal__archive-toggle{align-items:center;color:#374151;display:flex;font-size:13px;gap:10px;margin-bottom:12px}.cat-modal__archive-toggle label{align-items:center;cursor:pointer;display:flex;gap:6px}.cat-modal__archive-hint{color:#9ca3af;font-size:12px}.cat-modal__footer{align-items:center;border-top:1px solid #e5e7eb;display:flex;justify-content:space-between;margin-top:16px;padding-top:14px}.cat-modal__footer-actions{display:flex;gap:8px}.inventory-search-sort{align-items:center;display:flex;gap:10px;margin:16px 0 12px}.inventory-cards{display:flex;flex-direction:column;gap:10px}.inventory-item-card{background:#fff;border:1.5px solid #e5e7eb;border-radius:12px;overflow:hidden;transition:box-shadow .15s}.inventory-item-card:hover{box-shadow:0 2px 10px #00000012}.inventory-item-card--uncataloged{background:#fffdf5;border-color:#fde68a}.inventory-item-card__header{align-items:center;background:#f8fafc;border-bottom:1px solid #f3f4f6;display:flex;gap:8px;justify-content:space-between;padding:10px 14px}.inventory-item-card--uncataloged .inventory-item-card__header{background:#fef9e7}.inventory-item-card__title{align-items:center;display:flex;gap:8px;min-width:0}.inventory-item-card__name{color:#1e3a5f;font-size:14px;font-weight:700;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.inventory-item-card__unit-badge{background:#e0e7ff;border-radius:99px;color:#4338ca;flex-shrink:0;font-size:11px;font-weight:600;padding:2px 8px}.inventory-item-card__unit-badge--muted{background:#f3f4f6;color:#9ca3af}.inventory-item-card__header-actions{display:flex;flex-shrink:0;gap:4px}.inventory-item-card__body{padding:6px 14px}.inventory-item-card__stock-row{align-items:center;border-bottom:1px dashed #f3f4f6;display:flex;gap:8px;padding:6px 0}.inventory-item-card__stock-row:last-child{border-bottom:none}.inventory-item-card__subtype-name{color:#374151;flex:1 1;font-size:13px;min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.inventory-item-card__subtype-qty{flex-shrink:0;font-size:14px;font-weight:700;min-width:90px;text-align:right;white-space:nowrap}.inventory-item-card__subtype-actions{display:flex;flex-shrink:0;gap:3px}.inventory-item-card__add-subtype{background:#fafbfc;border-top:1px solid #f3f4f6;padding:8px 14px}.category-add-subtype-btn{background:#ffffff26;border:1px solid #ffffff4d;border-radius:4px;color:#fff;cursor:pointer;font-size:11px;font-weight:600;letter-spacing:.3px;padding:2px 10px;white-space:nowrap}.category-add-subtype-btn:hover{background:#ffffff47}.inventory-item-card__inline-qty{flex-shrink:0;font-size:14px;font-weight:700;margin-left:4px}.inventory-item-card__action-sep{background:#e5e7eb;flex-shrink:0;height:16px;margin:0 2px;width:1px}.inventory-uncataloged{margin-top:24px}.inventory-uncataloged__header{align-items:center;background:#fef3c7;border:1px dashed #f59e0b;border-radius:8px;color:#92400e;display:flex;font-size:13px;gap:8px;margin-bottom:10px;padding:8px 12px}.form-input--error,.form-select--error{border-color:#ef4444!important;box-shadow:0 0 0 2px #ef444426}@media (min-width:769px) and (max-width:1024px){.sidebar--open{width:200px}.main-content{padding:20px 20px 32px}.page-title{font-size:20px}.summary-grid{flex-wrap:wrap}.summary-grid>*{min-width:180px}.day-summary-card{padding:8px 10px}.day-summary-card__value{font-size:15px}.inventory-search-sort{gap:8px}.action-btn{padding:4px}.table-scroll{-webkit-overflow-scrolling:touch;overflow-x:auto}.edit-modal-box,.modal-box,.surat-jalan-modal{max-height:90vh;overflow-y:auto}.surat-jalan-modal{max-width:95vw}}@media (min-width:769px) and (max-width:900px){.item-fields-row{grid-template-columns:1fr 1fr!important}.md\:table-cell{display:none}.contacts-page--split{flex-direction:column}.contacts-page--split .contacts-list-panel{border-bottom:1px solid #e2e8f0;border-right:none;margin-bottom:12px;max-width:100%;padding-bottom:12px;padding-right:0;width:100%}.contacts-detail-panel{padding-left:0}}@media (min-width:901px) and (max-width:1024px){.contacts-page--split .contacts-list-panel{max-width:320px;min-width:260px;width:40%}}
/*# sourceMappingURL=main.5850132d.css.map*/