.login-container{min-height:100vh;display:flex;align-items:center;justify-content:center;padding:24px;background:linear-gradient(180deg,#f7fafc,#eef2f7)}.login-card{width:min(980px,96vw);background:#fff;border:1px solid #e2e8f0;border-radius:18px;box-shadow:0 18px 38px #0f172a1f;display:grid;grid-template-columns:1.2fr 1fr;overflow:visible}.brand-pane{position:relative;background:linear-gradient(155deg,#fff7ed,#ffedd5 40%,#fde68a);padding:28px;display:flex;align-items:center;justify-content:center;flex-direction:column;text-align:center;color:#0f172a}.brand-logo{width:min(260px,60%);height:auto;filter:drop-shadow(0 6px 10px rgba(0,0,0,.15));margin-bottom:10px}.brand-title{margin:6px 0 2px;letter-spacing:6px;font-weight:900;font-size:clamp(26px,3.4vw,36px)}.brand-sub{letter-spacing:4px;font-size:clamp(11px,1.6vw,14px);color:#334155;font-weight:700}.brand-tagline{margin-top:10px;color:#475569;font-weight:500}.login-form{background:#fff;padding:26px 28px 28px;display:flex;flex-direction:column}.login-form h2{text-align:center;margin-bottom:16px}.login-form label{display:block;margin:10px 0 6px;font-weight:600;color:#334155}.login-form input{width:100%;height:42px;padding:0 12px;border:1px solid #cbd5e1;border-radius:10px;font-size:15px;outline:none;transition:all .15s ease;background:#f8fafc}.login-form input:focus{border-color:#f97316;box-shadow:0 0 0 4px #f973161f;background:#fff}.login-form button{width:100%;height:44px;margin-top:10px;border:0;border-radius:10px;cursor:pointer;background:linear-gradient(135deg,#fb923c,#f97316);color:#fff;font-weight:700;letter-spacing:.3px;box-shadow:0 6px 12px #f973162e}.error{color:#b91c1c;text-align:center;margin-top:10px;font-weight:600}.login-help{margin-top:10px;font-size:12px;color:#64748b;text-align:center}@media (max-width:880px){.login-card{grid-template-columns:1fr}.brand-pane{padding:22px 18px}.login-form{padding:20px 18px 24px}.brand-logo{width:min(240px,70%)}}:root{--sb-w: 240px;--sb-w-collapsed: 76px;--top-h: 44px;--bg: #f6f8fb;--card:#fff;--bd:#e5e7eb;--text:#0f172a;--muted:#64748b;--acc:#f97316}*{box-sizing:border-box}body{background:var(--bg);color:var(--text)}.rm-shell{display:flex;min-height:100vh;width:100%}.rm-sidebar{position:fixed;z-index:40;left:0;top:0;bottom:0;width:var(--sb-w);background:#fff;border-right:1px solid var(--bd);padding:10px 8px;transition:width .2s ease,transform .2s ease}.sb-brand{display:flex;align-items:center;gap:8px;padding:4px 6px 8px}.sb-logo{width:32px;height:32px;border-radius:10px;background:linear-gradient(135deg,#fb923c,#f97316);color:#fff;display:flex;align-items:center;justify-content:center;font-weight:800;box-shadow:0 6px 14px #f9731640}.sb-title{font-weight:800;letter-spacing:.4px}.sb-nav{display:flex;flex-direction:column;gap:2px;margin-top:6px}.sb-item{display:flex;align-items:center;gap:10px;padding:2px 10px;border-radius:10px;color:var(--text);text-decoration:none;border:1px solid transparent}.sb-item:hover{background:#fafafa;border-color:#eee}.sb-item.active{background:linear-gradient(180deg,#fff,#fff7ed);border-color:#fde2c6}.sb-ico{width:20px;text-align:center}.sb-text{white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.rm-main{flex:1;margin-left:var(--sb-w);display:flex;flex-direction:column;min-width:0}.rm-topbar{height:var(--top-h);background:#fff;border-bottom:1px solid var(--bd);display:flex;align-items:center;justify-content:space-between;padding:0 10px;gap:8px;position:sticky;top:0;z-index:30}.rm-topbar .left{display:flex;align-items:center;gap:6px;flex:1}.brand-mini{display:none;font-weight:900;color:var(--acc)}.rm-title{font-weight:800;font-size:18px;margin-left:6px}.rm-topbar .right{display:flex;align-items:center;gap:6px}.badge{padding:5px 9px;border:1px dashed #f59e0b;color:#b45309;background:#fffbeb;border-radius:9999px;font-size:11px}.icon-btn{background:#fff;border:1px solid var(--bd);border-radius:8px;height:32px;padding:0 8px;cursor:pointer}.icon-btn:hover{border-color:#d1d5db}.mobile-only{display:none}.desktop-only{display:inline-flex}.rm-content{padding:12px}.sb-collapsed .rm-sidebar{width:var(--sb-w-collapsed)}.sb-collapsed .rm-main{margin-left:var(--sb-w-collapsed)}.sb-collapsed .sb-title,.sb-collapsed .sb-text{display:none}.sb-collapsed .brand-mini{display:block}@media (max-width: 1024px){.rm-sidebar{transform:translate(-100%);width:86vw;max-width:320px}.rm-sidebar.open{transform:translate(0)}.rm-main{margin-left:0}.desktop-only{display:none}.mobile-only{display:inline-flex}.brand-mini{display:block}.rm-title{font-size:17px}}.rm-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#02061773;z-index:35}*,*:before,*:after{box-sizing:border-box}html,body,#root{height:100%}body{margin:0;padding:0;background:linear-gradient(180deg,#f7fafc,#eef2f7);color:#0f172a;font-family:system-ui,Arial,sans-serif;line-height:1.5}a{color:inherit;text-decoration:none}button,input,select,textarea{font:inherit}.container{width:min(1200px,96vw);margin:0 auto}.card{background:#fff;border:1px solid #e5e7eb;border-radius:14px;padding:14px}.card-title{margin:4px 0 8px;font-weight:700}.text-muted{color:#64748b}.hidden{display:none!important}.prod-toolbar{display:flex;align-items:center;justify-content:space-between;margin-bottom:10px}.subtitle{color:#64748b;font-size:13px}.btn{height:36px;border-radius:10px;border:1px solid #e5e7eb;background:#fff;padding:0 12px;cursor:pointer}.btn:hover{border-color:#d1d5db}.btn-primary{background:linear-gradient(135deg,#fb923c,#f97316);color:#fff;border:0;box-shadow:0 6px 12px #f973162e}.prod-controls{display:flex;align-items:center;justify-content:space-between;gap:10px;margin-bottom:10px}.input-icon{position:relative}.input-icon input{height:36px;border:1px solid #e5e7eb;border-radius:10px;padding:0 12px 0 34px;outline:none;min-width:280px;background:#fff}.input-icon span{position:absolute;left:10px;top:8px;opacity:.6}.control-right select{height:36px;border:1px solid #e5e7eb;border-radius:10px;padding:0 10px;background:#fff;margin-left:8px}.table-wrap{overflow:auto;border:1px solid #eef0f3;border-radius:12px;background:#fff}.table{width:100%;border-collapse:separate;border-spacing:0}.table th,.table td{padding:2px 10px;font-size:14px;vertical-align:middle;background:#fff;border-bottom:1px solid #e7edf3;border-right:1px solid #e7edf3}.table th:first-child,.table td:first-child{border-left:1px solid #e7edf3}.table thead th{background:#f8fafc;font-weight:700;color:#334155;border-bottom:1px solid #dbe3ea}.table thead th:first-child{border-top-left-radius:12px}.table thead th:last-child{border-top-right-radius:12px}.table .mono{font-family:ui-monospace,SFMono-Regular,Menlo,Monaco,Consolas,Liberation Mono,Courier New,monospace}.text-right{text-align:right}.text-muted{color:#94a3b8}.pname{display:flex;align-items:center;gap:10px}.thumb{width:32px;height:32px;border-radius:10px;background:#fff7ed;display:flex;align-items:center;justify-content:center;border:1px solid #fde2c6}.created{display:flex;align-items:center;gap:8px}.avatar{width:28px;height:28px;border-radius:9999px;background:#eef2ff;display:flex;align-items:center;justify-content:center;border:1px solid #e5e7eb}.actions{display:flex;gap:8px;justify-content:flex-end}.actions .icon{height:30px;width:30px;border-radius:8px;border:1px solid #e5e7eb;background:#fff;cursor:pointer}.actions .icon:hover{border-color:#d1d5db}.actions .icon.danger:hover{border-color:#fecaca}.prod-footer{display:flex;align-items:center;justify-content:space-between;padding:10px 0}.pager .icon{height:30px;width:30px;border-radius:8px;border:1px solid #e5e7eb;background:#fff;cursor:pointer}.pager .page{display:inline-flex;align-items:center;justify-content:center;min-width:34px;height:30px;border-radius:8px;border:1px dashed #f59e0b;background:#fffbeb;margin:0 6px}.modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#02061773;display:flex;align-items:center;justify-content:center;z-index:50}.modal{width:min(720px,96vw);background:#fff;border:1px solid #e5e7eb;border-radius:16px;box-shadow:0 24px 58px #0f172a38;padding:12px}.modal-header{display:flex;align-items:center;justify-content:space-between;padding:6px 8px 10px;border-bottom:1px solid #f1f5f9}.modal-header h3{margin:0;font-size:18px}.alert{margin:10px 8px;padding:10px;border:1px solid #fecaca;background:#fff1f2;color:#991b1b;border-radius:10px;font-weight:600}.form-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:12px;padding:12px 8px}.form-grid label{display:flex;flex-direction:column;gap:6px;font-size:13px;color:#334155}.form-grid input,.form-grid select{height:38px;border:1px solid #e5e7eb;border-radius:10px;padding:0 10px;outline:none;background:#fff}.form-grid input:focus,.form-grid select:focus{border-color:#f97316;box-shadow:0 0 0 4px #f973161f}.col-span-2{grid-column:span 2}.modal-actions{display:flex;justify-content:flex-end;gap:10px;margin-top:6px}.thumb{width:32px;height:32px;border-radius:10px;background:#fff7ed;display:flex;align-items:center;justify-content:center;border:1px solid #fde2c6;overflow:hidden}.thumb img{width:100%;height:100%;object-fit:cover}.uploader{display:flex;align-items:center;gap:12px;border:1px dashed #f59e0b;background:#fffbeb;border-radius:12px;padding:10px;cursor:pointer}.uploader input[type=file]{display:none}.uploader-empty{color:#b45309;font-size:12px}.preview{width:64px;height:64px;border-radius:10px;overflow:hidden;border:1px solid #e5e7eb;background:#fff}.preview img{width:100%;height:100%;object-fit:cover}.badge-status{display:inline-flex;align-items:center;gap:6px;padding:4px 8px;border-radius:9999px;border:1px solid #e5e7eb;font-size:12px}.badge-status.ok{background:#ecfdf5;border-color:#a7f3d0;color:#065f46}.badge-status.off{background:#fff1f2;border-color:#fecaca;color:#991b1b}.toggle{display:inline-flex;align-items:center;gap:6px;cursor:pointer;-webkit-user-select:none;user-select:none}.toggle input{display:none}.toggle i{width:34px;height:20px;border-radius:9999px;background:#e5e7eb;position:relative;display:inline-block;transition:.15s}.toggle i:after{content:"";position:absolute;width:16px;height:16px;border-radius:9999px;background:#fff;top:2px;left:2px;transition:.15s;box-shadow:0 1px 2px #00000026}.toggle input:checked+i{background:#34d399}.toggle input:checked+i:after{left:16px}.purchases-page .prod-toolbar h2{margin:0;font-size:18px}.purchases-page .purchase-filters{display:flex;flex-wrap:wrap;gap:8px;align-items:flex-end}.purchases-page .purchase-filters label{display:flex;flex-direction:column;gap:4px;font-size:12px;color:#475569}.purchases-page .purchase-filters input,.purchases-page .purchase-filters select{height:32px;border:1px solid #e5e7eb;border-radius:10px;padding:0 8px;outline:none;background:#fff}.purchases-page .purchase-filters input:focus,.purchases-page .purchase-filters select:focus{border-color:#f97316;box-shadow:0 0 0 3px #f973161f}.modal .table input{width:100%;height:32px;border:1px solid #e5e7eb;border-radius:8px;padding:0 6px;outline:none;background:#fff}.modal .table input:focus{border-color:#f97316;box-shadow:0 0 0 3px #f973161f}.sb-logo-has-image{background:transparent!important;box-shadow:none!important}.sb-logo-img{width:100%;height:100%;object-fit:contain;display:block}.res-app{min-height:100vh;background:#f3f4f6;display:flex;flex-direction:column;font-family:system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif}.res-header{padding:10px 12px;background:#fff;box-shadow:0 1px 3px #0f172a14}.res-header-inner{max-width:540px;margin:0 auto;display:flex;align-items:center;justify-content:space-between}.res-header-left{display:flex;align-items:center;gap:8px}.res-header-logo{width:32px;height:32px;border-radius:999px;overflow:hidden;background:transparent;display:flex;align-items:center;justify-content:center}.res-header-logo img{width:100%;height:100%;object-fit:contain}.res-header-text{display:flex;flex-direction:column}.res-brand{font-weight:700;letter-spacing:2px;font-size:15px;color:#111827}.res-sub{font-size:12px;color:#6b7280}.res-header-right{display:flex;align-items:center;gap:8px}.res-home-btn{border-radius:999px;padding:6px 14px;font-size:12px;font-weight:600;border:1px solid #fed7aa;background:#fff;color:#f97316;cursor:pointer}.res-logout-btn{border:0;border-radius:999px;padding:6px 14px;font-size:12px;font-weight:600;color:#fff;background:#ef4444;cursor:pointer;box-shadow:0 3px 8px #f8717159}.res-main{flex:1;padding:14px 12px 18px;max-width:540px;margin:0 auto;width:100%}.res-tabs{display:flex;background:#e5e7eb;border-radius:999px;padding:3px;margin-bottom:14px}.res-tab{flex:1;border:0;background:transparent;border-radius:999px;padding:8px 0;font-size:13px;font-weight:600;color:#4b5563;cursor:pointer}.res-tab.active{background:linear-gradient(135deg,#fb923c,#f97316);color:#fff;box-shadow:0 4px 10px #f973164d}.res-section{margin-top:8px}.res-section-title{font-size:15px;font-weight:700;margin:0 0 4px;color:#111827}.res-section-sub{font-size:12px;color:#6b7280;margin:0 0 10px}.res-card{background:#fff;border-radius:14px;padding:12px 14px;box-shadow:0 1px 3px #0f172a14;margin-bottom:12px}.res-empty{font-size:13px;color:#6b7280;text-align:center;padding:12px 6px}.res-filters{margin-bottom:8px}.res-filter-row{display:flex;gap:8px;flex-wrap:wrap;margin-bottom:6px}.res-filter-group{flex:1;min-width:130px;font-size:12px}.res-filter-group label{display:block;margin-bottom:3px;color:#4b5563}.res-select{width:100%;border-radius:999px;border:1px solid #d1d5db;padding:7px 10px;font-size:13px;background:#f9fafb}.res-table-wrapper{background:#fff;border-radius:14px;box-shadow:0 1px 3px #0f172a14;overflow-x:auto}.res-table{width:100%;border-collapse:collapse;font-size:12px}.res-table th,.res-table td{padding:8px 10px;border-bottom:1px solid #f1f5f9;text-align:left;white-space:nowrap}.res-table th{background:#f9fafb;font-weight:600;color:#4b5563}.res-row-clickable{cursor:pointer}.res-row-clickable:hover{background:#fef3c7}.res-status-pill{display:inline-flex;align-items:center;justify-content:center;padding:3px 8px;border-radius:999px;font-size:11px;font-weight:600}.res-status-pill.paid{background:#dcfce7;color:#15803d}.res-status-pill.unpaid{background:#fee2e2;color:#b91c1c}.res-info-row{display:flex;justify-content:space-between;gap:12px;padding:6px 0;border-bottom:1px dashed #e5e7eb}.res-info-row:last-child{border-bottom:0}.res-info-row .label{font-size:12px;color:#6b7280}.res-info-row .value{font-size:13px;font-weight:600;color:#111827}.res-card-title{font-size:14px;font-weight:700;margin:0 0 10px;color:#111827}.res-field-label{display:block;font-size:12px;color:#4b5563;margin-top:6px;margin-bottom:3px}.res-input{width:100%;border-radius:10px;border:1px solid #d1d5db;padding:8px 10px;font-size:13px;outline:none;background:#f9fafb}.res-input:focus{border-color:#f97316;box-shadow:0 0 0 3px #f9731633;background:#fff}.res-btn-primary{margin-top:10px;width:100%;border:0;border-radius:999px;padding:9px 0;font-size:13px;font-weight:700;background:linear-gradient(135deg,#fb923c,#f97316);color:#fff;cursor:pointer}.res-btn-primary:disabled{opacity:.7;cursor:default}.res-muted{font-size:13px;color:#6b7280}.res-error{font-size:13px;color:#b91c1c}.res-pwd-msg{margin-top:6px;font-size:12px;color:#4b5563}.req{color:#ef4444}.res-modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#0f172a73;display:flex;align-items:center;justify-content:center;z-index:9999}.res-modal{width:100%;max-width:480px;max-height:90vh;background:#fff;border-radius:16px;box-shadow:0 10px 30px #0f172a59;padding:14px 16px 16px;display:flex;flex-direction:column}.res-modal-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:6px}.res-modal-header h3{margin:0;font-size:15px}.res-modal-close{border:0;background:transparent;font-size:18px;line-height:1;cursor:pointer}.res-modal-body{overflow-y:auto;padding-top:4px}.res-modal-info{font-size:13px;margin-bottom:8px}.res-small{font-size:12px;color:#6b7280}.res-modal-items{border-top:1px solid #e5e7eb;border-bottom:1px solid #e5e7eb;margin:8px 0;padding:6px 0}.res-modal-items-header{display:flex;justify-content:space-between;gap:8px;padding:0 0 4px;font-size:11px;font-weight:600;color:#6b7280;border-bottom:1px solid #e5e7eb}.res-modal-items-header .head-product{flex:1.7}.res-modal-items-header .head-unit{flex:1;text-align:right}.res-modal-items-header .head-qty{flex:.6;text-align:right}.res-modal-items-header .head-total{flex:1;text-align:right}.res-modal-item-row{display:flex;justify-content:space-between;align-items:center;gap:8px;padding:6px 0;font-size:12px;border-bottom:1px solid #f3f4f6}.res-modal-item-row:last-child{border-bottom:none}.res-modal-item-product{flex:1.7;display:flex;align-items:center;gap:6px}.res-modal-item-thumb{width:28px;height:28px;border-radius:6px;overflow:hidden;background:#f3f4f6;flex-shrink:0}.res-modal-item-thumb img{width:100%;height:100%;object-fit:cover}.res-modal-item-thumb.placeholder{background:#e5e7eb}.res-modal-item-name{font-weight:500}.res-modal-item-unit{flex:1;text-align:right}.res-modal-item-qty{flex:.6;text-align:right}.res-modal-item-total{flex:1;text-align:right;font-weight:500}.res-unit-code{font-size:11px;color:#6b7280}.res-modal-summary{font-size:12px;margin-top:6px}.res-modal-summary .row{display:flex;justify-content:space-between;padding:2px 0}.res-modal-summary .row.total{font-weight:700}.res-impersonate{margin-bottom:10px;padding:8px 10px;border-radius:12px;background:#fef3c7;border:1px solid #fde68a;font-size:12px;color:#92400e}.res-impersonate-title{font-weight:600}.res-impersonate-sub{margin-top:2px;font-size:11px;color:#b45309}body.rm-reseller-mode{background:#f3f4f6}body.rm-reseller-mode .rm-sidebar,body.rm-reseller-mode .rm-topbar{display:none!important}body.rm-reseller-mode .rm-main,body.rm-reseller-mode .rm-page,body.rm-reseller-mode .rm-content{margin:0!important;max-width:100%!important}
