@import"https://fonts.googleapis.com/css2?family=Google+Sans+Flex:wght@400;500;600;700;800&display=swap";:root{color:#17212b;background:#f4f6f8;font-family:Google Sans Flex,Google Sans,ui-sans-serif,system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;--border: #d8dee6;--muted: #627083;--surface: #ffffff;--surface-soft: #eef2f6;--brand-yellow: #fec909;--brand-red: #d91f2a;--brand-green: #2f7d63;--brand-blue: #1d6f96;--brand-violet: #7451a9;--shadow: 0 18px 48px rgba(25, 34, 44, .12)}*{box-sizing:border-box}body{margin:0;min-width:320px;min-height:100vh}button,input,select,textarea{font:inherit}button{cursor:pointer}button:disabled{cursor:not-allowed}svg{flex-shrink:0}.spin{animation:spin .85s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.login-shell{display:grid;grid-template-columns:minmax(0,1fr) minmax(360px,1fr);min-height:100vh;background:#f4f6f8}.brand-panel{position:relative;min-height:100vh;overflow:hidden;background:#17212b}.login-side-image{display:block;width:100%;height:100%;min-height:100vh;object-fit:cover;object-position:center}.powered-by{position:absolute;left:clamp(18px,3vw,36px);bottom:clamp(16px,3vw,32px);color:#fff;font-size:.76rem;font-weight:700;line-height:1.35;text-shadow:0 2px 10px rgba(0,0,0,.38)}.brand-logo{width:min(260px,64vw);max-height:92px;object-fit:contain;filter:drop-shadow(0 8px 18px rgba(0,0,0,.22))}.brand-panel h1,.workspace-header h1{margin:8px 0 0;font-size:clamp(2rem,5vw,4rem);line-height:1;letter-spacing:0}.eyebrow{display:inline-flex;align-items:center;gap:6px;width:fit-content;color:#9a5b00;background:#fff3bf;border:1px solid #f2d05d;border-radius:999px;padding:6px 10px;font-size:.76rem;font-weight:800;text-transform:uppercase}.brand-panel .eyebrow{color:#17212b}.login-panel{display:grid;place-items:center;padding:clamp(20px,5vw,72px);background:linear-gradient(180deg,#ffffffe0,#f4f6f8f5),#f4f6f8}.login-form{width:min(100%,480px);padding:clamp(28px,4vw,44px);background:var(--surface);border:1px solid var(--border);border-radius:8px;box-shadow:0 24px 70px #19222c29}.login-form-brand{display:grid;gap:10px;padding-bottom:26px;margin-bottom:26px;border-bottom:1px solid #e5eaf0}.login-form-brand img{width:min(180px,58vw);height:auto;margin-bottom:8px}.login-form-brand h1{margin:2px 0 0;color:#17212b;font-size:clamp(2rem,4vw,2.65rem);line-height:1;letter-spacing:0}.login-form-brand p{margin:0;color:#445365;font-size:1.02rem;font-weight:800}.form-heading{display:flex;align-items:center;gap:16px;margin-bottom:28px}.avatar{display:grid;place-items:center;flex:0 0 52px;width:52px;height:52px;color:#17212b;background:var(--brand-yellow);border:2px solid #f3b400;border-radius:50%;font-weight:900}.form-heading h2{margin:0;font-size:1.45rem;letter-spacing:0}.form-heading p{margin:4px 0 0;color:var(--muted);line-height:1.4}.field{display:grid;gap:8px;margin-top:18px;color:#2b3744;font-weight:700}.field-label{display:inline-flex;align-items:center;gap:6px;width:fit-content}.field input,.field select,.field textarea{width:100%;min-height:48px;padding:0 14px;color:#17212b;background:#fff;border:1px solid #cbd4df;border-radius:6px;outline:none}.field textarea{min-height:96px;padding-top:12px;resize:vertical}.field input:focus,.field select:focus,.field textarea:focus{border-color:#1d6f96;box-shadow:0 0 0 3px #1d6f962e}.password-input{position:relative}.password-input input{padding-right:48px}.password-input button{position:absolute;top:50%;right:8px;display:grid;place-items:center;width:36px;height:36px;color:#556273;background:transparent;border:0;border-radius:6px;transform:translateY(-50%)}.password-input button:hover{color:#17212b;background:#f1f4f7}.error-message{margin:18px 0 0;padding:12px 14px;color:#8c1018;background:#fff1f2;border:1px solid #ffc7cd;border-radius:6px;line-height:1.35}.success-message{margin:16px 22px 0;padding:12px 14px;color:#19563f;background:#edf8f2;border:1px solid #b6ddcf;border-radius:6px;line-height:1.35}.debug-message{margin:12px 22px 0;padding:10px 12px;color:#445365;background:#f7f9fb;border:1px dashed #cbd4df;border-radius:6px;font-size:.84rem;line-height:1.35}.primary-button{display:inline-flex;align-items:center;justify-content:center;gap:8px;width:100%;min-height:48px;margin-top:22px;color:#17212b;background:var(--brand-yellow);border:1px solid #efb500;border-radius:6px;font-weight:900}.primary-button:hover:not(:disabled){background:#ffd737}.primary-button:disabled{opacity:.72}.workspace-shell{display:grid;grid-template-columns:260px minmax(0,1fr);min-height:100vh;background:#f4f6f8}.sidebar{display:flex;flex-direction:column;gap:28px;padding:28px 20px;background:#fff;border-right:1px solid var(--border)}.sidebar-logo{width:168px;height:auto}.sidebar-nav{display:grid;gap:6px}.nav-item{display:flex;align-items:center;gap:10px;width:100%;min-height:42px;padding:0 12px;color:#293545;background:transparent;border:0;text-decoration:none;border-radius:6px;font-weight:800;text-align:left}.nav-item.active{background:#fff3bf;color:#5c3b00}.nav-item.disabled{color:#8a96a6;pointer-events:none}.workspace-content{min-width:0;padding:clamp(24px,4vw,48px)}.workspace-header{display:flex;justify-content:space-between;align-items:flex-start;gap:24px}.header-title-block{min-width:0}.page-title{display:flex;align-items:center;gap:16px;margin-top:14px}.title-icon,.panel-icon,.info-card-icon{display:grid;place-items:center}.title-icon{flex:0 0 54px;width:54px;height:54px;color:#fff;background:#17212b;border-radius:8px;box-shadow:0 14px 26px #17212b29}.workspace-header h1{margin:0;font-size:clamp(2rem,4vw,3rem)}.page-title p{max-width:620px;margin:8px 0 0;color:var(--muted);font-size:1rem;font-weight:700;line-height:1.35}.top-actions{display:flex;align-items:center;justify-content:flex-end;gap:10px;flex-wrap:wrap}.context-select{display:flex;align-items:center;gap:8px;min-height:38px;padding:0 10px;color:#17212b;background:#fff;border:1px solid var(--border);border-radius:999px;font-size:.82rem;font-weight:900}.context-select span{display:inline-flex;align-items:center;gap:6px;color:#2b3744;white-space:nowrap}.context-select select{min-width:180px;height:30px;color:#17212b;background:transparent;border:0;font-weight:900}.context-select select:focus{outline:2px solid rgba(23,33,43,.2);outline-offset:2px}.sync-badge,.logout-button,.badge,.avatar-badge,.count-chip,.muted-meta,.loading-banner,.list-actions button,.pagination button,.modal-footer button{display:inline-flex;align-items:center;justify-content:center;gap:7px}.sync-badge{min-height:38px;padding:0 12px;color:#19563f;background:#edf8f2;border:1px solid #b6ddcf;border-radius:999px;font-size:.86rem;font-weight:900;white-space:nowrap}.sync-badge.is-loading{color:#285375;background:#eef7fb;border-color:#c9e4f0}.logout-button{min-height:38px;padding:0 12px;color:#17212b;background:#fff;border:1px solid var(--border);border-radius:999px;font-weight:900}.logout-button:hover{background:#f7f9fb}.branch-chip{display:inline-grid;gap:2px;min-height:46px;padding:7px 14px;color:#17212b;background:#fff;border:1px solid var(--border);border-radius:999px}.branch-chip span{color:#68778a;font-size:.72rem;font-weight:900;text-transform:uppercase}.branch-chip strong{font-size:.95rem}.user-chip{display:inline-flex;align-items:center;gap:10px;padding:6px 6px 6px 10px;background:#fff;border:1px solid var(--border);border-radius:999px}.user-chip span{display:grid;place-items:center;width:32px;height:32px;color:#fff;background:var(--brand-red);border-radius:50%;font-size:.78rem;font-weight:900}.user-chip button{min-height:32px;padding:0 12px;color:#17212b;background:#f7f9fb;border:1px solid #d7dee8;border-radius:999px;font-weight:800}.header-cards{display:grid;grid-template-columns:repeat(4,minmax(180px,1fr));gap:14px;margin-top:28px}.info-card{position:relative;display:grid;grid-template-columns:auto minmax(0,1fr);gap:14px;min-height:142px;padding:18px;background:#fff;border:1px solid var(--border);border-radius:8px;box-shadow:0 10px 30px #19222c12}.info-card.featured{border-left:6px solid var(--brand-yellow)}.info-card-icon{width:44px;height:44px;border-radius:8px}.info-card-icon.branch{color:#8b6400;background:#fff3bf;border:1px solid #f2d05d}.info-card-icon.company{color:#285375;background:#eef7fb;border:1px solid #c9e4f0}.info-card-icon.user{color:#7b171e;background:#fff1f2;border:1px solid #ffc7cd}.info-card-icon.stock{color:#204236;background:#e7f4ef;border:1px solid #b6ddcf}.info-card-body{min-width:0}.info-card-label{display:block;margin-bottom:8px;color:#68778a;font-size:.74rem;font-weight:900;text-transform:uppercase}.info-card strong{display:block;color:#17212b;font-size:1.22rem;line-height:1.1;overflow-wrap:anywhere}.info-card p{margin:7px 0 0;color:var(--muted);font-size:.9rem;font-weight:700;line-height:1.3;overflow-wrap:anywhere}.badge,.avatar-badge{justify-self:start;align-self:end;grid-column:2;width:fit-content;min-height:28px;margin-top:4px;padding:0 9px;border-radius:999px;font-size:.76rem;font-weight:900;white-space:nowrap}.badge.success{color:#19563f;background:#edf8f2;border:1px solid #b6ddcf}.badge.warning{color:#8b6400;background:#fff8d7;border:1px solid #f2d05d}.badge.info{color:#285375;background:#eef7fb;border:1px solid #c9e4f0}.badge.neutral{color:#445365;background:#f7f9fb;border:1px solid #d7dee8}.avatar-badge{color:#fff;background:var(--brand-red);border:1px solid #bc1b25}.status-panel,.requisitions-panel,.form-panel{display:flex;align-items:center;justify-content:space-between;gap:20px;width:min(100%,1120px);margin-top:36px;padding:22px 24px;background:#fff;border:1px solid var(--border);border-radius:8px}.status-panel,.requisitions-panel{width:100%;max-width:none}.status-panel{border-left:6px solid var(--brand-green)}.status-panel div{display:flex;align-items:center;gap:10px}.status-panel p{margin:0;color:var(--muted);font-weight:700;overflow-wrap:anywhere}.status-dot{width:10px;height:10px;background:var(--brand-green);border-radius:50%}.requisitions-panel{display:block;padding:0;overflow:hidden;margin-top:24px}.form-panel{display:block;padding:0 0 22px}.form-panel-header{display:flex;align-items:center;justify-content:space-between;gap:18px;padding:20px 22px;border-bottom:1px solid var(--border)}.form-panel-header h2{margin:0;font-size:1.2rem}.form-panel-header span{display:inline-block;margin-top:4px;color:var(--muted);font-weight:700}.count-chip{margin:0;padding:6px 10px;color:#293545;background:#eef2f6;border:1px solid #d8dee6;border-radius:999px;font-size:.82rem;white-space:nowrap}.request-form{display:grid;grid-template-columns:repeat(4,minmax(150px,1fr));gap:0 14px;padding:2px 22px 0}.request-form .field{margin-top:18px}.request-form .field:first-child,.request-notes{grid-column:span 2}.autocomplete{position:relative}.suggestions{position:absolute;z-index:20;top:calc(100% + 6px);left:0;right:0;max-height:280px;overflow-y:auto;background:#fff;border:1px solid #cbd4df;border-radius:8px;box-shadow:0 16px 36px #19222c29}.suggestion{display:grid;grid-template-columns:auto minmax(0,1fr);align-items:flex-start;gap:10px;width:100%;min-height:52px;padding:10px 12px;color:#17212b;background:transparent;border:0;border-bottom:1px solid #edf1f5;text-align:left}.suggestion:hover{background:#f7f9fb}.suggestion-icon{display:grid;place-items:center;width:30px;height:30px;color:#285375;background:#eef7fb;border-radius:8px}.suggestion-content{display:grid;gap:3px;min-width:0}.suggestion-content>span{color:var(--muted);font-size:.86rem}.suggestion small,.field-hint{color:#1d6f96;font-size:.78rem;font-weight:800}.suggestion.muted{grid-template-columns:auto auto;align-items:center;justify-content:flex-start;color:var(--muted);cursor:default}.input-with-icon{position:relative}.input-with-icon>svg{position:absolute;top:50%;left:14px;color:#68778a;pointer-events:none;transform:translateY(-50%)}.input-with-icon input{padding-left:42px}.hidden-input{position:absolute;width:1px!important;height:1px!important;min-height:1px!important;padding:0!important;opacity:0;pointer-events:none}.form-actions{display:flex;align-items:flex-end;justify-content:flex-end;gap:10px;grid-column:span 2;margin-top:18px}.form-actions button{min-height:48px;padding:0 16px;color:#17212b;background:#f7f9fb;border:1px solid #cbd4df;border-radius:6px;font-weight:900}.primary-button.compact{width:auto;min-width:180px;margin-top:0;background:var(--brand-yellow);border-color:#efb500}.list-toolbar{display:flex;align-items:center;justify-content:space-between;gap:18px;padding:20px 22px;border-bottom:1px solid var(--border)}.panel-title{display:flex;align-items:center;gap:12px;min-width:0}.panel-icon{flex:0 0 38px;width:38px;height:38px;color:#285375;background:#eef7fb;border:1px solid #c9e4f0;border-radius:8px}.panel-icon.strong{color:#17212b;background:var(--brand-yellow);border-color:#efb500}.list-toolbar h2{margin:0;font-size:1.2rem;letter-spacing:0}.list-toolbar span{display:inline-block;margin-top:4px;color:var(--muted);font-weight:700}.list-toolbar .field-label,.list-toolbar .panel-title div>span{display:inline-flex}.list-toolbar .field-label{margin-top:0;color:#2b3744}.list-actions{display:flex;align-items:flex-end;gap:10px}.list-actions label{display:grid;gap:6px;color:#2b3744;font-size:.82rem;font-weight:800}.list-actions select{min-width:190px;min-height:38px;padding:0 10px;color:#17212b;background:#fff;border:1px solid #cbd4df;border-radius:6px}.list-actions button,.pagination button{min-height:38px;padding:0 14px;color:#17212b;background:#f7f9fb;border:1px solid #cbd4df;border-radius:6px;font-weight:800}.list-actions .primary-action{color:#17212b;background:var(--brand-yellow);border-color:#efb500}.list-actions button:hover:not(:disabled),.pagination button:hover:not(:disabled){background:#eef2f6}.list-actions .primary-action:hover:not(:disabled){background:#ffd737}.inline-error,.inline-status{margin:16px 22px 0}.loading-banner{margin:14px 22px 0;padding:10px 12px;color:#285375;background:#eef7fb;border:1px solid #c9e4f0;border-radius:6px;font-size:.86rem;font-weight:800}.table-wrap{width:100%;overflow-x:auto}.table-wrap.is-refreshing table{opacity:.58}table{width:100%;min-width:920px;border-collapse:collapse}th,td{padding:14px 16px;text-align:left;vertical-align:top;border-bottom:1px solid #e5eaf0}th{color:#556273;background:#f8fafc;font-size:.78rem;text-transform:uppercase}.th-label{display:inline-flex;align-items:center;gap:6px;white-space:nowrap}td{color:#1e2a36;font-size:.92rem}td strong,td span{display:block}td span{margin-top:3px;color:#647184}.status-badge{display:inline-flex;width:fit-content;margin:0;padding:4px 8px;color:#204236;background:#e7f4ef;border:1px solid #b6ddcf;border-radius:999px;font-size:.8rem;font-weight:800}.table-actions{display:flex;align-items:center;gap:8px;flex-wrap:wrap}.table-actions button{display:inline-flex;align-items:center;justify-content:center;gap:6px;min-height:34px;padding:0 10px;border-radius:6px;font-size:.82rem;font-weight:900;white-space:nowrap}.approval-items-dropdown{width:100%}.approval-items-dropdown summary{display:inline-flex;align-items:center;gap:8px;padding:8px 10px;color:#1d4b7a;background:#eef6ff;border:1px solid #cfe0f3;border-radius:8px;font-size:.82rem;font-weight:800;cursor:pointer;list-style:none}.approval-items-dropdown summary::-webkit-details-marker{display:none}.approval-items-dropdown[open] summary{border-bottom-left-radius:0;border-bottom-right-radius:0}.approval-items-list{display:grid;gap:10px;padding:12px;background:#fbfdff;border:1px solid #d9e6f3;border-top:0;border-bottom-left-radius:8px;border-bottom-right-radius:8px}.approval-item-card{display:grid;gap:4px;padding:10px 12px;background:#fff;border:1px solid #e3ebf3;border-radius:8px}.approval-item-row{display:flex;align-items:center;justify-content:space-between;gap:12px}.approval-item-badge{display:inline-flex;flex-shrink:0;align-items:center;padding:3px 8px;color:#4e5f73;background:#f4f7fa;border:1px solid #dde5ee;border-radius:999px;font-size:.74rem;font-weight:800}.success-action{color:#19563f;background:#edf8f2;border:1px solid #b6ddcf}.success-action:hover:not(:disabled){background:#dff2e9}.danger-action{color:#8c1018;background:#fff1f2;border:1px solid #ffc7cd}.danger-action:hover:not(:disabled){background:#ffe4e8}.empty-state{height:120px;color:var(--muted);text-align:center;vertical-align:middle}.empty-state svg{display:block;margin:0 auto 8px;color:#8a96a6}.permission-state{display:grid;place-items:center;gap:8px;min-height:260px;padding:32px 24px;color:var(--muted);text-align:center}.permission-state svg{color:#8a96a6}.permission-state strong{color:#1e2a36;font-size:1.05rem}.permission-state span{max-width:520px;line-height:1.4}.skeleton-line{display:block;width:100%;height:11px;margin:4px 0;background:linear-gradient(90deg,#edf1f5,#f8fafc,#edf1f5);background-size:180% 100%;border-radius:999px;animation:skeleton-pulse 1.15s ease-in-out infinite}.skeleton-line.long{width:88%}.skeleton-line.medium{width:64%}.skeleton-line.short{width:42%}.skeleton-line.tiny{width:26%}@keyframes skeleton-pulse{0%{background-position:100% 0}to{background-position:0 0}}.pagination{display:flex;align-items:center;justify-content:flex-end;gap:10px;padding:14px 22px;background:#fbfcfd}.pagination span{color:#556273;font-weight:800}.modal-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;z-index:100;display:grid;place-items:center;padding:24px;background:#17212b6b}.modal-panel{display:flex;flex-direction:column;width:min(820px,100%);max-height:min(88vh,760px);overflow:hidden;background:#fff;border:1px solid #cbd4df;border-radius:8px;box-shadow:0 28px 80px #111a2447}.modal-header,.modal-footer{display:flex;align-items:center;justify-content:space-between;gap:16px;padding:20px 22px}.modal-header{border-bottom:1px solid var(--border)}.modal-header .panel-title{align-items:flex-start}.modal-header h2{margin:8px 0 0;font-size:1.35rem}.modal-header p,.muted-meta{margin:4px 0 0;color:var(--muted);font-weight:700}.icon-button{display:grid;place-items:center;flex:0 0 38px;width:38px;height:38px;color:#17212b;background:#f7f9fb;border:1px solid #cbd4df;border-radius:50%}.modal-body{min-height:0;overflow-y:auto;padding:20px 22px 24px}.modal-body .inline-error{margin:14px 0 0}.modal-status-row{display:flex;align-items:center;justify-content:space-between;gap:12px;flex-wrap:wrap}.modal-form{grid-template-columns:repeat(2,minmax(0,1fr));padding:0}.modal-form .field:first-child,.modal-form .product-field,.modal-form .request-notes,.purchase-item-actions,.purchase-items-panel{grid-column:1 / -1}.purchase-item-actions{display:flex;justify-content:flex-end}.purchase-item-actions button{display:inline-flex;align-items:center;justify-content:center;gap:8px;min-height:38px;padding:0 12px;color:#173d2c;background:#edf8f2;border:1px solid #b6ddcf;border-radius:6px;font-weight:900}.purchase-items-panel{display:grid;gap:10px;padding:12px;background:#f8fafc;border:1px solid #dce5ef;border-radius:8px}.purchase-items-panel p{margin:0;color:var(--muted);font-weight:700}.purchase-items-header,.purchase-item-card,.purchase-item-main{display:flex;align-items:center;gap:12px}.purchase-items-header,.purchase-item-card{justify-content:space-between}.purchase-items-header span{color:var(--muted);font-size:.86rem;font-weight:800}.purchase-items-list{display:grid;gap:8px}.purchase-item-card{padding:10px 12px;background:#fff;border:1px solid #e3ebf3;border-radius:8px}.purchase-item-main{min-width:0;align-items:flex-start}.purchase-item-main div,.purchase-item-main strong,.purchase-item-main span{min-width:0}.purchase-item-main strong,.purchase-item-main span{display:block}.purchase-item-main span:not(.approval-item-badge){margin-top:3px;color:#647184;font-size:.86rem}.purchase-item-card .icon-button{flex:0 0 34px;width:34px;height:34px}.modal-footer{justify-content:flex-end;border-top:1px solid var(--border);background:#fbfcfd}.modal-footer button{min-height:42px;padding:0 14px;color:#17212b;background:#f7f9fb;border:1px solid #cbd4df;border-radius:6px;font-weight:900}@media(max-width:1180px){.header-cards{grid-template-columns:repeat(2,minmax(0,1fr))}}@media(max-width:820px){.login-shell,.workspace-shell{grid-template-columns:1fr}.brand-panel{min-height:280px}.login-side-image{height:280px;min-height:280px}.workspace-shell{min-height:100vh}.sidebar{border-right:0;border-bottom:1px solid var(--border)}.page-title{align-items:flex-start}.title-icon{width:48px;height:48px;flex-basis:48px}.header-cards{grid-template-columns:1fr}.sync-badge,.context-select,.logout-button{width:100%}.context-select{justify-content:space-between}.context-select select{min-width:0;flex:1}.workspace-header,.status-panel,.form-panel-header,.list-toolbar,.list-actions,.top-actions{flex-direction:column;align-items:stretch}.request-form{grid-template-columns:1fr}.request-form .field:first-child,.request-notes,.form-actions{grid-column:span 1}.form-actions{flex-direction:column;align-items:stretch}.list-actions select,.list-actions button,.purchase-item-actions button,.primary-button.compact{width:100%}.modal-backdrop{align-items:stretch;padding:12px}.modal-panel{max-height:calc(100vh - 24px)}.modal-header,.modal-footer,.modal-status-row{align-items:stretch;flex-direction:column}.modal-header .icon-button{align-self:flex-end}.modal-form{grid-template-columns:1fr}.purchase-item-actions,.purchase-item-card{align-items:stretch;flex-direction:column}}
