:root{--color-primary-50:#eaf1ff;--color-primary-100:#dce7ff;--color-primary-200:#c6d7ff;--color-primary-300:#a8c2f5;--color-primary-400:#6f93e0;--color-primary-500:#3c5fae;--color-primary-600:#0f2a5f;--color-primary-700:#0b214b;--color-primary-800:#081735;--color-primary-900:#061126;--color-accent-50:#ecfeff;--color-accent-600:#14b8a6;--color-accent-700:#0f9e90;--color-bg-app:#f6f8fc;--color-bg-card:#fff;--color-border:#e6eaf2;--color-border-strong:#d7ddea;--color-border-hover:#d7ddea;--color-text:#0b1220;--color-text-secondary:#55627a;--color-text-tertiary:#7c889c;--color-text-disabled:#9aa6b6;--color-sidebar-bg:#071225;--color-sidebar-hover:#0b1730;--color-sidebar-divider:#ffffff14;--color-warning:#d97706;--color-warning-bg:#fef3cd;--color-warning-border:#fcd34d;--color-danger:#dc2626;--color-danger-bg:#fee2e2;--color-danger-border:#fca5a5;--color-success:#16a34a;--color-success-bg:#dcfce7;--color-success-border:#86efac;--color-info:#2563eb;--color-info-bg:#dbeafe;--color-info-border:#93c5fd;--focus-ring:0 0 0 3px #14b8a62e;--shadow-sm:0 1px 2px #1217280a;--shadow-md:0 4px 12px #1217280d;--shadow-lg:0 8px 24px #1217280f;--shadow-xl:0 8px 24px #1217280f;--font-family:"Inter",-apple-system,BlinkMacSystemFont,"Segoe UI",Roboto,sans-serif;--font-size-xs:12px;--font-size-sm:14px;--font-size-base:14px;--font-size-lg:16px;--font-size-xl:18px;--font-size-2xl:20px;--font-size-3xl:24px;--font-weight-regular:400;--font-weight-medium:500;--font-weight-semibold:600;--line-height-tight:1.25;--line-height-normal:1.5;--line-height-relaxed:1.75;--space-1:4px;--space-2:8px;--space-3:12px;--space-4:16px;--space-5:20px;--space-6:24px;--space-8:32px;--space-10:40px;--space-12:48px;--radius-sm:8px;--radius-md:14px;--radius-lg:16px;--radius-full:9999px;--transition-fast:150ms ease;--transition-normal:250ms ease;--transition-slow:350ms ease}*,:after,:before{box-sizing:border-box;margin:0;padding:0}body{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;color:#0b1220;color:var(--color-text);font-family:Inter,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;font-family:var(--font-family);font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Fira Sans,Droid Sans,Helvetica Neue,sans-serif;font-size:14px;font-size:var(--font-size-base);line-height:1.5;line-height:var(--line-height-normal);margin:0}code{font-family:source-code-pro,Menlo,Monaco,Consolas,Courier New,monospace}.cps-app-shell{background-color:var(--color-bg-app);display:flex;font-family:var(--font-family);height:100vh}.cps-app-shell-main{display:flex;flex:1 1;flex-direction:column;overflow:hidden}.cps-app-shell-content{background-color:var(--color-bg-app);flex:1 1;overflow-y:auto;padding:var(--space-6)}.cps-sidebar{background:var(--color-sidebar-bg);border:none;border-radius:0;border-right:1px solid var(--color-sidebar-divider);box-shadow:none;color:#fff;display:flex;flex-direction:column;height:100vh;margin:0;overflow:visible;position:-webkit-sticky;position:sticky;top:0;transition:all var(--transition-normal);z-index:100}.cps-sidebar.collapsed{width:76px!important}.cps-sidebar-header{border-bottom:1px solid var(--color-sidebar-divider);justify-content:space-between;min-height:64px;padding:18px 16px;position:relative}.cps-sidebar-brand,.cps-sidebar-header{align-items:center;display:flex;gap:12px}.cps-sidebar-collapse{align-items:center;background:#ffffff14;border:1px solid #ffffff1f;border-radius:14px;color:#f2f5ff;cursor:pointer;display:inline-flex;flex-shrink:0;height:38px;justify-content:center;transition:all var(--transition-fast);width:38px}.cps-sidebar-collapse:hover{background:#ffffff29;border-color:#ffffff38}.cps-sidebar-collapse:focus-visible{outline:2px solid #9cb7ffb3;outline-offset:2px}.cps-collapse-bars{display:inline-flex;flex-direction:column;gap:4px;width:18px}.cps-collapse-bars span{background:currentColor;border-radius:999px;height:2px;opacity:.8;width:18px}.cps-sidebar.collapsed .cps-sidebar-header{align-items:center;flex-direction:column;gap:10px;justify-content:flex-start;padding-top:16px}.cps-sidebar.collapsed .cps-sidebar-brand{align-items:center;flex-direction:column;gap:6px}.cps-sidebar.collapsed .cps-sidebar-collapse{align-self:center;background:#ffffff29;border-radius:14px;height:42px;position:static;width:42px}.cps-sidebar.collapsed .cps-collapse-bars,.cps-sidebar.collapsed .cps-collapse-bars span{width:20px}.cps-sidebar-header h2{-webkit-line-clamp:2;line-clamp:2;-webkit-box-orient:vertical;display:-webkit-box;font-size:13px;font-weight:var(--font-weight-semibold);margin:0;opacity:.85;overflow:hidden;text-align:left}.cps-logo{align-items:center;background:#ffffff1a;border-radius:var(--radius-sm);color:#fff;display:flex;font-size:var(--font-size-xl);font-weight:var(--font-weight-bold);height:40px;justify-content:center;width:40px}.cps-logo-icon{background:#ffffff14;border-radius:14px;box-shadow:inset 0 0 0 1px #ffffff14;height:44px;padding:8px;width:44px}.cps-sidebar-nav{-ms-overflow-style:none;flex:1 1;overflow-x:visible;overflow-y:auto;padding:12px 8px;scrollbar-width:none}.cps-sidebar-nav::-webkit-scrollbar{height:0;width:0}.cps-sidebar-nav ul{list-style:none;margin:0;padding:0}.cps-nav-section{padding-bottom:var(--space-2)}.cps-nav-section+.cps-nav-section{border-top:1px solid var(--color-sidebar-divider);margin-top:var(--space-2);padding-top:var(--space-2)}.cps-nav-section-title{color:#ffffff8c;font-size:11px;font-weight:var(--font-weight-semibold);letter-spacing:.12em;margin:10px 6px 4px;padding:6px 12px;text-transform:uppercase}.cps-sidebar-nav li{margin-bottom:4px}.cps-nav-link{align-items:center;border-radius:14px;color:#ffffffc7;display:flex;margin:0 6px;padding:10px 14px;position:relative;text-decoration:none;transition:all var(--transition-fast)}.cps-nav-link:hover{background:var(--color-sidebar-hover);color:#fff}.cps-nav-link.active{background:#14b8a61f;box-shadow:none;color:#fff}.cps-nav-link.active:before{background:var(--color-accent-600);border-radius:999px;bottom:8px;content:"";left:0;position:absolute;top:8px;width:3px}.cps-nav-icon{align-items:center;color:currentColor;display:inline-flex;font-size:var(--font-size-lg);justify-content:center;margin-right:12px;min-width:24px;text-align:center}.cps-nav-icon svg{height:20px;width:20px}.cps-nav-link.active .cps-nav-icon{color:var(--color-accent-600)}.cps-nav-text{font-weight:var(--font-weight-medium);opacity:1;transition:opacity var(--transition-normal)}.cps-sidebar.collapsed .cps-nav-text{height:0;opacity:0;overflow:hidden;width:0}.cps-sidebar.collapsed .cps-sidebar-footer{padding:10px}.cps-sidebar-footer{border-top:1px solid var(--color-sidebar-divider);margin-top:auto;padding:14px}.cps-user-badge{align-items:center;background:#ffffff0f;border-radius:var(--radius-md);display:flex;padding:10px;position:relative;transition:all var(--transition-normal)}.cps-sidebar.collapsed .cps-nav-link{justify-content:center;margin:6px auto;padding:10px;width:44px}.cps-sidebar.collapsed .cps-nav-icon{margin-right:0}.cps-sidebar.collapsed .cps-nav-link:after{background:#0f1b33;border-radius:10px;box-shadow:0 10px 24px #0c101e4d;color:#fff;content:attr(data-tooltip);font-size:12px;left:calc(100% + 10px);opacity:0;padding:6px 10px;pointer-events:none;position:absolute;top:50%;transform:translateY(-50%) translateX(-4px);transition:all var(--transition-fast);white-space:nowrap;z-index:300}.cps-sidebar.collapsed .cps-nav-link:hover:after{opacity:1;transform:translateY(-50%) translateX(0)}.cps-user-badge.collapsed{justify-content:center}.cps-user-info{flex:1 1}.cps-user-trigger{align-items:center;background:#0000;border:none;color:inherit;cursor:pointer;display:flex;gap:var(--space-2);padding:0;width:100%}.cps-user-avatar{align-items:center;background:#fff3;border-radius:999px;color:#fff;display:inline-flex;font-size:var(--font-size-xs);font-weight:var(--font-weight-semibold);height:34px;justify-content:center;letter-spacing:.04em;width:34px}.cps-username{font-size:var(--font-size-sm);font-weight:var(--font-weight-medium);margin-bottom:var(--space-1)}.cps-user-position,.cps-username{display:block;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.cps-user-position{color:#ffffffb8;font-size:var(--font-size-xs);margin-bottom:var(--space-2)}.cps-user-caret{color:#ffffffb3;font-size:var(--font-size-sm);margin-left:auto}.cps-user-menu{grid-gap:var(--space-1);background:#fff;border-radius:var(--radius-md);bottom:calc(100% + var(--space-2));box-shadow:var(--shadow-md);display:grid;gap:var(--space-1);left:var(--space-3);padding:var(--space-2);position:absolute;right:var(--space-3);z-index:100}.cps-user-menu.collapsed{bottom:4px;left:calc(100% + 14px);right:auto;width:190px}.cps-user-menu-item{background:#0000;border:none;border-radius:var(--radius-sm);color:var(--color-text);cursor:pointer;font-size:var(--font-size-sm);padding:var(--space-2) var(--space-3);text-align:left;transition:background var(--transition-fast)}.cps-user-menu-item:hover{background:var(--color-bg-card)}.cps-user-menu-item.danger{color:var(--color-danger)}.cps-topbar{background:#fff;border-bottom:1px solid var(--color-border);box-shadow:var(--shadow-sm);height:60px;justify-content:space-between;padding:0 var(--space-6);position:-webkit-sticky;position:sticky;top:0;z-index:90}.cps-topbar,.cps-topbar-left{align-items:center;display:flex}.cps-topbar-left{gap:var(--space-4)}.cps-sidebar-toggle{align-items:center;background:#0000;border:none;color:var(--color-text);cursor:pointer;display:flex;justify-content:center;padding:0;transition:all var(--transition-fast)}.cps-sidebar-toggle:hover{background:#0000}.cps-toggle-pill{align-items:center;background:#0f2a5f0f;border:1px solid #0f2a5f33;border-radius:999px;color:var(--color-primary-600);display:inline-flex;font-size:var(--font-size-sm);font-weight:var(--font-weight-medium);gap:8px;padding:6px 12px;transition:all var(--transition-fast)}.cps-sidebar-toggle:hover .cps-toggle-pill{background:#0f2a5f1f;border-color:#0f2a5f47}.cps-toggle-bars{display:inline-flex;flex-direction:column;gap:4px;width:18px}.cps-toggle-bars span{background:currentColor;border-radius:999px;display:block;height:2px;opacity:.7;width:18px}.cps-toggle-text{color:#0f2a5fb3;font-size:10px;letter-spacing:.06em;text-transform:uppercase}.cps-breadcrumb{color:var(--color-text);font-size:var(--font-size-lg);font-weight:var(--font-weight-semibold)}.cps-topbar-right{align-items:center;display:flex;gap:var(--space-4)}.cps-user-greeting{color:var(--color-text-secondary);font-size:var(--font-size-sm);margin-right:var(--space-3)}.cps-logout-button,.cps-sidebar-logout{background:var(--color-danger);border:none;border-radius:var(--radius-sm);color:#fff;cursor:pointer;font-size:var(--font-size-sm);font-weight:var(--font-weight-medium);padding:var(--space-2) var(--space-4);transition:background var(--transition-fast)}.cps-sidebar-logout{width:100%}.cps-logout-button:hover,.cps-sidebar-logout:hover{background:#c0392b}@media (max-width:768px){.cps-sidebar{position:fixed;z-index:1000}.cps-sidebar.collapsed{transform:translateX(-100%)}.cps-sidebar:not(.collapsed){transform:translateX(0)}.cps-app-shell-content{padding:var(--space-4)}.cps-topbar{padding:0 var(--space-3)}}.home-page{background:#fff;margin:calc(var(--space-6)*-1);min-height:calc(100vh - 72px)}@media (max-width:768px){.home-page{margin:calc(var(--space-4)*-1);min-height:calc(100vh - 64px)}}.cps-card{background:var(--color-bg-card);border:1px solid var(--color-border);border-radius:var(--radius-md);box-shadow:var(--shadow-sm);padding:var(--space-5);transition:all var(--transition-fast)}.cps-card:hover{border-color:var(--color-border-hover);box-shadow:var(--shadow-md)}.cps-card--clickable{cursor:pointer}.cps-card--clickable:hover{box-shadow:var(--shadow-lg);transform:translateY(-2px)}.cps-card__header{margin-bottom:var(--space-4)}.cps-card__title{color:var(--color-text-secondary);font-size:var(--font-size-base);font-weight:var(--font-weight-medium);margin:0 0 var(--space-2) 0}.cps-card__value{font-size:var(--font-size-2xl);font-weight:var(--font-weight-semibold)}.cps-card__content,.cps-card__value{color:var(--color-text)}.cps-card--status{border-left:4px solid var(--color-border)}.cps-card--status.cps-card--success{border-left-color:var(--color-success)}.cps-card--status.cps-card--warning{border-left-color:var(--color-warning)}.cps-card--status.cps-card--error{border-left-color:var(--color-danger)}.cps-card--status.cps-card--info{border-left-color:var(--color-info)}.cps-card--kpi{text-align:center}.cps-card--kpi .cps-card__header{margin-bottom:var(--space-3)}.cps-card--kpi .cps-card__title{color:var(--color-text-secondary);font-size:var(--font-size-sm);margin-bottom:var(--space-1)}.cps-card--kpi .cps-card__value{font-size:var(--font-size-3xl);font-weight:var(--font-weight-bold);margin:0}.cps-card--action{background:linear-gradient(135deg,var(--color-primary-50) 0,var(--color-primary-100) 100%);border-color:var(--color-primary-200)}.cps-card--action .cps-card__title{color:var(--color-primary-800)}.cps-card--action .cps-card__value{color:var(--color-primary-900)}@media (max-width:768px){.cps-card{padding:var(--space-4)}.cps-card__value{font-size:var(--font-size-xl)}.cps-card--kpi .cps-card__value{font-size:var(--font-size-2xl)}}.cps-table-container{border:1px solid var(--color-border);border-radius:var(--radius-md);overflow-x:auto;overflow-y:visible}.cps-table{background:var(--color-bg-card);border-collapse:collapse;min-width:720px;width:100%}.cps-table__header-cell{background-color:var(--color-primary-50);border-bottom:2px solid var(--color-border-strong);color:var(--color-text-secondary);font-size:var(--font-size-sm);font-weight:var(--font-weight-semibold);letter-spacing:.5px;padding:12px 16px;text-align:left;text-transform:uppercase;vertical-align:middle;white-space:nowrap}.cps-table__row{border-bottom:1px solid var(--color-border);height:56px;max-height:72px;transition:background-color var(--transition-fast)}.cps-table__row:last-child{border-bottom:none}.cps-table__row:hover{background-color:var(--color-primary-50)}.cps-table--clickable .cps-table__row{cursor:pointer}.cps-table--clickable .cps-table__row:hover{background-color:var(--color-primary-100)}.cps-table__cell{border-bottom:1px solid var(--color-border);color:var(--color-text);padding:12px 16px;vertical-align:middle}.cps-table__cell.actions,.cps-table__header-cell.actions{max-width:320px;min-width:220px;padding-right:16px;text-align:center;width:260px}.actions-body,.actions-header{display:flex;justify-content:center;width:100%}.actions-body{flex-wrap:wrap;gap:8px}.cps-table__row:last-child .cps-table__cell{border-bottom:none}.cps-table__empty-cell{color:var(--color-text-tertiary);font-style:italic;padding:var(--space-8);text-align:center}@media (max-width:768px){.cps-table__cell,.cps-table__header-cell{font-size:var(--font-size-sm);padding:var(--space-3)}.cps-table-container{border-radius:var(--radius-sm)}}.dashboard{margin:0 auto;max-width:1200px}.dashboard-header{align-items:center;border-bottom:2px solid var(--color-border);display:flex;justify-content:space-between;margin-bottom:var(--space-6);padding-bottom:var(--space-4)}.dashboard-header h1{color:var(--color-text);font-size:var(--font-size-2xl);margin:0}.version-info{background:var(--color-primary-600);border-radius:var(--radius-full);color:#fff;font-size:var(--font-size-sm);padding:var(--space-2) var(--space-4)}.status-grid{grid-gap:var(--space-5);display:grid;gap:var(--space-5);grid-template-columns:repeat(auto-fit,minmax(250px,1fr));margin-bottom:var(--space-6)}.status-text{color:var(--color-text);font-size:var(--font-size-lg);font-weight:var(--font-weight-medium);margin:0}.metrics-grid{grid-gap:var(--space-5);display:grid;gap:var(--space-5);grid-template-columns:repeat(auto-fit,minmax(200px,1fr))}.metrics-grid,.recent-activity{margin-bottom:var(--space-6)}.section-header{margin-bottom:var(--space-4)}.section-header h2{color:var(--color-text);font-size:var(--font-size-xl)}.actions-grid{grid-gap:var(--space-4);display:grid;gap:var(--space-4);grid-template-columns:repeat(auto-fit,minmax(200px,1fr))}.action-icon{font-size:var(--font-size-2xl);margin-top:var(--space-2);text-align:center}.loading-state{color:var(--color-text-tertiary);padding:var(--space-10);text-align:center}.loading-state h2{margin-bottom:var(--space-5)}.error-state{background:var(--color-danger-bg);border:1px solid var(--color-danger-border);border-radius:var(--radius-md);color:var(--color-danger);padding:var(--space-10);text-align:center}.error-state h2{color:var(--color-danger);margin-bottom:var(--space-4)}.error-state p{font-size:var(--font-size-lg);margin:0}@media (max-width:768px){.dashboard-header{flex-direction:column;gap:var(--space-4);text-align:center}.actions-grid,.metrics-grid,.status-grid{grid-template-columns:1fr}.dashboard-header h1{font-size:var(--font-size-xl)}}.error-banner{background-color:#f8d7da;border:1px solid #f5c6cb;border-radius:4px;color:#721c24;margin-bottom:16px;padding:12px}.error-banner,.error-content{align-items:center;display:flex}.error-content{gap:12px;width:100%}.error-icon{font-size:20px}.error-message{flex:1 1;font-weight:500}.retry-button{background-color:#dc3545;border:none;border-radius:4px;color:#fff;cursor:pointer;font-size:14px;padding:6px 12px;transition:background-color .2s}.retry-button:hover{background-color:#c82333}.cps-button{align-items:center;border:none;border-radius:var(--radius-md);cursor:pointer;display:inline-flex;font-family:var(--font-family);font-size:var(--font-size-base);font-weight:var(--font-weight-semibold);gap:var(--space-2);justify-content:center;line-height:1;min-height:44px;padding:var(--space-3) var(--space-5);text-decoration:none;transition:all var(--transition-fast);white-space:nowrap}.cps-button:focus-visible{box-shadow:var(--focus-ring);outline:none}.cps-button:disabled{cursor:not-allowed;opacity:.6}.cps-button--primary{background-color:var(--color-primary-600);color:#fff}.cps-button--primary:hover:not(:disabled){background-color:var(--color-primary-700)}.cps-button--primary:active:not(:disabled){background-color:var(--color-primary-800)}.cps-button--secondary{background-color:#fff;border:1px solid var(--color-border);color:var(--color-primary-600)}.cps-button--secondary:hover:not(:disabled){background-color:var(--color-primary-50);border-color:var(--color-border-strong)}.cps-button--secondary:active:not(:disabled){background-color:var(--color-primary-100)}.cps-button--ghost{background-color:initial;color:var(--color-text-secondary)}.cps-button--ghost:hover:not(:disabled){background-color:var(--color-primary-50);color:var(--color-text)}.cps-button--ghost:active:not(:disabled){background-color:var(--color-primary-100)}.cps-button--loading{cursor:wait;position:relative}.cps-button__spinner{animation:cps-spin 1s linear infinite;display:inline-flex}.cps-button__spinner svg{height:18px;width:18px}.cps-button--primary .cps-button__spinner{color:#fff}.cps-button--ghost .cps-button__spinner,.cps-button--secondary .cps-button__spinner{color:var(--color-text-secondary)}.cps-button__icon{align-items:center;display:inline-flex;justify-content:center}.cps-button__icon svg{height:18px;width:18px}.cps-button--full{width:100%}@keyframes cps-spin{0%{transform:rotate(0deg)}to{transform:rotate(1turn)}}.cps-input-container{display:flex;flex-direction:column;gap:var(--space-2);width:100%}.cps-input-label{color:var(--color-text);font-size:var(--font-size-sm);font-weight:var(--font-weight-medium)}.cps-input-wrapper{align-items:center;display:flex;position:relative}.cps-input{background-color:var(--color-bg-card);border:1px solid var(--color-border);border-radius:var(--radius-md);color:var(--color-text);font-family:var(--font-family);font-size:var(--font-size-base);height:44px;padding:var(--space-3) var(--space-4);transition:all var(--transition-fast);width:100%}.cps-input::placeholder{color:var(--color-text-tertiary)}.cps-input:hover:not(:disabled){border-color:var(--color-border-hover)}.cps-input:focus{border-color:var(--color-accent-600);box-shadow:var(--focus-ring);outline:none}.cps-input:disabled{background-color:var(--color-bg-app);color:var(--color-text-disabled);cursor:not-allowed}.cps-input-container--error .cps-input{border-color:var(--color-danger)}.cps-input-container--error .cps-input:focus{border-color:var(--color-danger);box-shadow:0 0 0 3px #d1434326}.cps-input-error{color:var(--color-danger);font-size:var(--font-size-xs)}.cps-input-icons{align-items:center;display:flex;gap:var(--space-2);position:absolute;right:var(--space-3)}.cps-input-icon-button{align-items:center;background:none;border:none;border-radius:var(--radius-sm);color:var(--color-text-secondary);cursor:pointer;display:flex;height:24px;justify-content:center;padding:0;transition:color var(--transition-fast);width:24px}.cps-input-icon-button:hover{color:var(--color-text)}.cps-input-icon-button:focus-visible{box-shadow:var(--focus-ring);outline:none}.cps-input-icon-button svg{height:18px;width:18px}.cps-input-icon-static{align-items:center;color:var(--color-text-secondary);display:flex}.cps-input-icon-static svg{height:18px;width:18px}.cps-modal-backdrop{align-items:center;animation:cps-fade-in .15s ease;background-color:#12172880;display:flex;inset:0;justify-content:center;padding:var(--space-4);position:fixed;z-index:1000}.cps-modal{animation:cps-slide-up .2s ease;background-color:var(--color-bg-card);border-radius:var(--radius-lg);box-shadow:var(--shadow-xl);display:flex;flex-direction:column;max-height:85vh;max-width:min(560px,calc(100vw - var(--space-8)));outline:none;overflow:hidden;width:100%}.cps-modal.cps-confirm-modal{max-width:480px}.cps-modal-header{align-items:center;border-bottom:1px solid var(--color-border);display:flex;justify-content:space-between;padding:var(--space-5) var(--space-6)}.cps-modal-title{color:var(--color-text);font-size:var(--font-size-lg);font-weight:var(--font-weight-semibold);line-height:var(--line-height-tight);margin:0}.cps-modal-close{align-items:center;background:none;border:none;border-radius:var(--radius-sm);color:var(--color-text-secondary);cursor:pointer;display:flex;height:32px;justify-content:center;padding:0;transition:all var(--transition-fast);width:32px}.cps-modal-close:hover{background-color:var(--color-bg-app);color:var(--color-text)}.cps-modal-close:focus-visible{box-shadow:var(--focus-ring);outline:none}.cps-modal-close svg{height:20px;width:20px}.cps-modal-content{min-height:0;overflow-x:hidden;overflow-y:auto;padding:var(--space-6);scrollbar-gutter:stable}@keyframes cps-fade-in{0%{opacity:0}to{opacity:1}}@keyframes cps-slide-up{0%{opacity:0;transform:translateY(16px) scale(.96)}to{opacity:1;transform:translateY(0) scale(1)}}.cps-confirm-modal__header{border-bottom:1px solid var(--color-border);padding:var(--space-5) var(--space-6)}.cps-confirm-modal__title{color:var(--color-text);font-size:var(--font-size-lg);font-weight:var(--font-weight-semibold);line-height:var(--line-height-tight);margin:0}.cps-confirm-modal__content{color:var(--color-text);padding:var(--space-6)}.cps-confirm-modal__message{color:var(--color-text);line-height:var(--line-height-normal);margin:0}.cps-confirm-modal__actions{border-top:1px solid var(--color-border);display:flex;gap:var(--space-3);justify-content:flex-end;padding:var(--space-5) var(--space-6)}.customers-page{padding:var(--space-6)}.customers-page-header{align-items:center;display:flex;justify-content:space-between;margin-bottom:var(--space-5)}.customers-page-header h1{color:var(--color-text);font-size:52px;line-height:1.05;margin:0}.customers-search-section{margin-bottom:var(--space-4);max-width:420px}.customers-name-cell{display:flex;flex-direction:column;gap:var(--space-1)}.customers-name-link{background:#0000;border:none;color:var(--color-text);cursor:pointer;font-weight:var(--font-weight-semibold);line-height:1.2;margin:0;padding:0;text-align:left}.customers-name-link:hover{color:var(--color-primary-600)}.customers-subline{color:var(--color-text-secondary);font-size:var(--font-size-sm)}.customers-actions-cell{display:flex;flex-wrap:nowrap;gap:var(--space-2);justify-content:flex-end}.customers-table .cps-table__cell.actions,.customers-table .cps-table__header-cell.actions{max-width:340px;min-width:340px;width:340px}.customers-table-footer{color:var(--color-text-secondary);display:flex;font-size:var(--font-size-sm);justify-content:flex-end;margin-top:var(--space-3)}.customers-floating-error{margin-top:var(--space-4)}.customers-create-modal{max-width:760px}.customers-detail-modal{max-width:780px}.customers-details-layout{display:flex;flex-direction:column;gap:var(--space-4)}.customers-details-section h3{color:var(--color-text);font-size:var(--font-size-xl);margin:0 0 var(--space-3)}.customers-details-grid{grid-gap:var(--space-2);display:grid;gap:var(--space-2)}.customers-details-row{grid-gap:var(--space-4);border-bottom:1px solid #ffffff0f;border-bottom:1px solid var(--color-border-light,#ffffff0f);display:grid;gap:var(--space-4);grid-template-columns:180px minmax(0,1fr);padding:var(--space-2) 0}.customers-details-row span{color:var(--color-text-secondary);font-size:var(--font-size-sm)}.customers-details-row strong{color:var(--color-text);font-size:var(--font-size-base);font-weight:var(--font-weight-medium);word-break:break-word}.customers-create-form{display:flex;flex-direction:column;gap:var(--space-4)}.customers-modal-caption{color:var(--color-text-secondary);font-size:var(--font-size-sm);margin:0}.customers-modal-error{background:#d143431a;border:1px solid #d1434359;border-radius:var(--radius-md);color:var(--color-danger);font-size:var(--font-size-sm);padding:var(--space-3)}.customers-form-grid{grid-gap:var(--space-4);display:grid;gap:var(--space-4);grid-template-columns:repeat(2,minmax(0,1fr))}.customers-form-grid--extended{border-top:1px dashed var(--color-border);padding:var(--space-3) 0}.customers-form-field{display:flex;flex-direction:column;gap:var(--space-2)}.customers-form-field--wide{grid-column:1/-1}.customers-form-field label{color:var(--color-text);font-size:var(--font-size-sm);font-weight:var(--font-weight-medium)}.customers-form-select,.customers-form-textarea{background:var(--color-bg-card);border:1px solid var(--color-border);border-radius:var(--radius-md);color:var(--color-text);font-size:var(--font-size-base);padding:10px 12px;transition:all var(--transition-fast);width:100%}.customers-form-select{min-height:44px}.customers-form-textarea{min-height:92px;resize:vertical}.customers-form-select:focus,.customers-form-textarea:focus{border-color:var(--color-primary-600);box-shadow:var(--focus-ring);outline:none}.customers-form-select--error,.customers-form-textarea--error{border-color:var(--color-danger)}.customers-custom-boolean-field{display:flex;flex-direction:column;gap:var(--space-2);justify-content:center}.customers-custom-boolean-field label{align-items:center;color:var(--color-text);display:inline-flex;font-size:var(--font-size-sm);gap:var(--space-2)}.customers-field-error{color:var(--color-danger);font-size:var(--font-size-xs)}.customers-extended-toggle{align-self:flex-start;background:#0000;border:none;color:var(--color-primary-700);cursor:pointer;font-size:var(--font-size-sm);font-weight:var(--font-weight-semibold);padding:0}.customers-extended-toggle:hover{text-decoration:underline}.customers-modal-actions{border-top:1px solid var(--color-border);display:flex;gap:var(--space-3);justify-content:flex-end;padding-top:var(--space-3)}.customers-button-danger{background-color:#d1434314!important;border-color:#d143434d!important;color:var(--color-danger)!important}.customers-button-danger:hover:not(:disabled){background-color:#d1434324!important;border-color:#d1434366!important}.forbidden-container{background:var(--color-bg-card);border:1px solid var(--color-border);border-radius:var(--radius-lg);margin:var(--space-8) auto;max-width:520px;padding:var(--space-8);text-align:center}.forbidden-icon{font-size:52px;line-height:1;margin-bottom:var(--space-4)}@media (max-width:1120px){.customers-table .cps-table__cell.actions,.customers-table .cps-table__header-cell.actions{max-width:300px;min-width:300px;width:300px}}@media (max-width:960px){.customers-page-header h1{font-size:40px}.customers-details-row,.customers-form-grid{grid-template-columns:1fr}.customers-details-row{gap:var(--space-1)}}.audit-log-page{padding:var(--space-6)}.filters-section{margin-bottom:var(--space-5)}.filters-grid{grid-gap:var(--space-4);display:grid;gap:var(--space-4);grid-template-columns:repeat(auto-fit,minmax(200px,1fr));margin-bottom:var(--space-4)}.filter-group label{color:var(--color-text);display:block;font-weight:var(--font-weight-medium);margin-bottom:var(--space-2)}.filter-group input,.filter-group select{border:1px solid var(--color-border);border-radius:var(--radius-sm);font-size:var(--font-size-base);padding:var(--space-2) var(--space-3);width:100%}.filter-group input:focus,.filter-group select:focus{border-color:var(--color-primary-600);box-shadow:var(--focus-ring);outline:none}.filter-actions{text-align:right}.action-badge{border-radius:var(--radius-full);color:#fff;display:inline-block;font-size:var(--font-size-sm);font-weight:var(--font-weight-semibold);padding:var(--space-1) var(--space-3);text-transform:uppercase}.entity-id{color:var(--color-text-tertiary);font-size:var(--font-size-xs);margin-top:var(--space-1)}.details-cell{min-width:150px}.details-summary{cursor:pointer}.details-summary summary{color:var(--color-primary-600);font-weight:var(--font-weight-medium)}.details-summary pre{background:var(--color-bg-app);border-radius:var(--radius-sm);font-size:var(--font-size-xs);margin-top:var(--space-2);max-width:300px;overflow-x:auto;padding:var(--space-3)}@media (max-width:768px){.filters-grid{grid-template-columns:1fr}}.cps-skeleton{animation:cps-skeleton-pulse 1.5s ease-in-out infinite;background:linear-gradient(90deg,var(--color-border) 25%,var(--color-border-hover) 50%,var(--color-border) 75%);background-size:200% 100%;display:inline-block}.cps-skeleton--text{border-radius:var(--radius-sm);height:var(--space-4);margin-bottom:var(--space-2);width:100%}.cps-skeleton--text:last-child{margin-bottom:0}.cps-skeleton--rectangular{border-radius:var(--radius-md);height:64px;width:100%}.cps-skeleton--circular{border-radius:var(--radius-full);height:40px;width:40px}.cps-skeleton--block{border-radius:var(--radius-md);height:120px;width:100%}@keyframes cps-skeleton-pulse{0%{background-position:200% 0}to{background-position:-200% 0}}.pagination{gap:8px}.pagination,.pagination-pages{align-items:center;display:flex}.pagination-pages{gap:4px}.pagination-button{align-items:center;border-radius:6px;display:flex;font-size:14px;font-weight:500;height:36px;justify-content:center;min-width:36px;padding:0 12px;transition:all .2s ease}.pagination-button--next,.pagination-button--prev{padding:0 16px}.pagination-button--number{min-width:36px}.pagination-button--active{font-weight:600}.pagination-button:disabled{cursor:not-allowed;opacity:.5}.pagination-button:not(:disabled):hover{box-shadow:0 2px 4px #0000001a;transform:translateY(-1px)}.pagination-ellipsis{color:#6b7280;color:var(--text-secondary,#6b7280);font-size:14px;padding:0 8px}@media (max-width:768px){.pagination{gap:4px}.pagination-button{font-size:13px;height:32px;min-width:32px;padding:0 8px}.pagination-button--next,.pagination-button--prev{padding:0 12px}.pagination-pages{gap:2px}}.items-per-page-selector{align-items:center;color:#6b7280;color:var(--text-secondary,#6b7280);display:flex;font-size:14px;gap:8px}.items-per-page-selector label{white-space:nowrap}.items-per-page-select{background-color:#fff;border:1px solid #d1d5db;border:1px solid var(--border-color,#d1d5db);border-radius:6px;cursor:pointer;font-size:14px;padding:6px 12px;transition:border-color .2s ease}.items-per-page-select:focus{border-color:#3b82f6;border-color:var(--primary-color,#3b82f6);box-shadow:0 0 0 3px #3b82f61a;outline:none}@media (max-width:768px){.items-per-page-selector{font-size:13px}.items-per-page-select{font-size:13px;padding:4px 8px}}.users-tab{padding:20px 0}.user-count{white-space:nowrap}.actions-cell--compact{flex-wrap:nowrap}.actions-cell button{flex-shrink:0;margin:0}.users-tab .cps-table__cell.actions,.users-tab .cps-table__header-cell.actions{max-width:560px;min-width:560px;padding-right:16px;text-align:center;width:560px}.users-tab .actions-body,.users-tab .actions-header{justify-content:center}.users-tab .actions-body{flex-wrap:nowrap;gap:8px}.user-name-cell{line-height:1.2}.email,.username{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.email{font-size:12px}.users-tab .modal-content{padding:24px}.users-tab .modal-description{color:#6b7280;color:var(--text-secondary,#6b7280);line-height:1.5;margin-bottom:24px}.users-tab .modal-actions{border-top:1px solid #e5e7eb;border-top:1px solid var(--border-color,#e5e7eb);display:flex;gap:12px;justify-content:flex-end;margin-top:24px;padding-top:24px}.users-tab .form-field{margin-bottom:20px}.users-tab .form-grid{grid-gap:12px;display:grid;gap:12px}.users-tab .form-grid--two{grid-template-columns:repeat(2,minmax(0,1fr))}.users-tab .form-field label{color:#1f2937;color:var(--text-primary,#1f2937);display:block;font-weight:500;margin-bottom:6px}.users-tab .form-input{border:1px solid #d1d5db;border:1px solid var(--border-color,#d1d5db);border-radius:6px;font-size:14px;padding:10px 12px;transition:border-color .2s ease;width:100%}.users-tab .form-input:focus{border-color:#3b82f6;border-color:var(--primary-color,#3b82f6);box-shadow:0 0 0 3px #3b82f61a;outline:none}.users-tab .form-input--error{border-color:#f87171;border-color:var(--danger-border,#f87171)}.users-tab .form-error{color:#dc2626;color:var(--danger-text,#dc2626);display:block;font-size:12px;margin-top:4px}.users-tab .warning-message{align-items:center;background-color:#fffbeb;background-color:var(--warning-bg,#fffbeb);border:1px solid #fef3c7;border:1px solid var(--warning-border,#fef3c7);border-radius:6px;color:#92400e;color:var(--warning-text,#92400e);display:flex;gap:8px;margin:16px 0;padding:12px 16px}.users-tab .warning-icon{font-size:18px}.users-tab .roles-checkbox-group{display:flex;flex-direction:column;gap:12px;margin-bottom:24px}.users-tab .current-assignments-list{border:1px solid #e5e7eb;border:1px solid var(--border-color,#e5e7eb);border-radius:8px;display:flex;flex-direction:column;gap:10px;margin-bottom:16px;max-height:240px;overflow-y:auto;padding:12px}.users-tab .assignment-item{align-items:center;border:1px solid #eceff3;border:1px solid var(--border-color,#eceff3);border-radius:8px;display:flex;gap:12px;justify-content:space-between;padding:8px 10px}.users-tab .assignment-scope{color:#6b7280;color:var(--text-secondary,#6b7280);font-size:12px;margin-top:4px}.users-tab .assignment-form-grid{grid-gap:12px;display:grid;gap:12px;grid-template-columns:repeat(3,minmax(0,1fr))}.users-tab .empty-assignment{color:#6b7280;color:var(--text-secondary,#6b7280);font-size:13px}.users-tab .checkbox-label{align-items:flex-start;border-radius:6px;cursor:pointer;display:flex;gap:12px;padding:12px;transition:background-color .2s ease}.users-tab .checkbox-label:hover{background-color:#f9fafb;background-color:var(--bg-hover,#f9fafb)}.users-tab .checkbox-input{margin-top:2px}.users-tab .checkbox-text{display:flex;flex-direction:column;gap:4px}.users-tab .role-name{color:#1f2937;color:var(--text-primary,#1f2937);font-weight:500}.users-tab .role-description{color:#6b7280;color:var(--text-secondary,#6b7280);font-size:13px}.cps-modal.users-form-modal{max-width:720px}.cps-modal.users-roles-modal{max-width:640px}@media (max-width:1200px){.actions-cell{gap:6px}.actions-cell button{font-size:13px;padding:6px 12px}}@media (max-width:768px){.users-tab{padding:16px 0}.users-tab .cps-table__cell.actions,.users-tab .cps-table__header-cell.actions{max-width:540px;min-width:540px;width:540px}.actions-cell{flex-direction:row;gap:4px}.actions-cell,.actions-cell--compact{flex-wrap:wrap}.users-tab .assignment-form-grid,.users-tab .form-grid--two{grid-template-columns:1fr}.actions-cell button{font-size:12px;padding:4px 8px}.table-footer{align-items:stretch;flex-direction:column;gap:16px}.user-count{text-align:center}.user-name-cell{max-width:180px}.email,.username{overflow:hidden;text-overflow:ellipsis}}.roles-tab{padding:20px 0}.role-count{color:#6b7280;color:var(--text-secondary,#6b7280);font-size:14px;white-space:nowrap}.role-name-cell{display:flex;flex-direction:column;gap:4px}.role-title{color:#1f2937;color:var(--text-primary,#1f2937);font-weight:500}.protected-badge{background-color:#fef3c7;background-color:var(--warning-bg,#fef3c7);border-radius:12px;color:#92400e;color:var(--warning-text,#92400e);display:inline-block;font-size:11px;font-weight:500;padding:2px 8px;text-transform:uppercase;width:-webkit-fit-content;width:fit-content}.permissions-cell{display:flex;flex-direction:column;gap:6px}.permission-count{font-size:13px;font-weight:500}.permission-tags{display:flex;flex-wrap:wrap;gap:4px}.permission-tag{background-color:#f3f4f6;background-color:var(--bg-secondary,#f3f4f6);border-radius:4px;color:#6b7280;color:var(--text-secondary,#6b7280);display:inline-block;font-family:monospace;font-size:11px;padding:2px 6px}.permission-more{color:#9ca3af;color:var(--text-secondary,#9ca3af);font-size:11px;font-style:italic}.button-danger:hover:not(:disabled){background-color:#fecaca!important;background-color:var(--danger-hover,#fecaca)!important}.button-danger:disabled{cursor:not-allowed;opacity:.5}.button-small{font-size:13px;padding:6px 12px}.cps-modal.roles-modal{max-height:85vh;max-width:min(900px,calc(100vw - 2rem));overflow:hidden}.cps-modal.roles-modal .cps-modal-header{background:#fff;background:var(--color-bg-card,#fff);border-bottom:1px solid #e5e7eb;border-bottom:1px solid var(--border-color,#e5e7eb);position:-webkit-sticky;position:sticky;top:0;z-index:6}.cps-modal.roles-modal .cps-modal-content{display:flex;flex-direction:column;min-height:0;overflow:hidden;padding:0}.roles-tab .role-dialog{display:flex;flex-direction:column;height:100%;min-height:0}.roles-tab .role-dialog-body{display:flex;flex-direction:column;gap:12px;min-height:0;overflow:hidden;padding:20px 24px 12px}.roles-tab .role-details-section{grid-gap:10px;display:grid;gap:10px;grid-template-columns:1fr}.roles-tab .modal-description{color:#6b7280;color:var(--text-secondary,#6b7280);line-height:1.5;margin:0}.roles-tab .form-field{margin:0}.roles-tab .form-field--compact{margin-bottom:2px}.roles-tab .form-field label{color:#1f2937;color:var(--text-primary,#1f2937);display:block;font-weight:500;margin-bottom:4px}.roles-tab .form-input{background:#fff;background:var(--color-bg-surface,#fff);border:1px solid #d1d5db;border:1px solid var(--border-color,#d1d5db);border-radius:10px;color:#111827;color:var(--text-primary,#111827);font-family:inherit;font-size:14px;min-height:42px;padding:10px 12px;transition:border-color .2s ease;width:100%}.roles-tab .form-input:focus{border-color:#3b82f6;border-color:var(--primary-color,#3b82f6);box-shadow:0 0 0 3px #3b82f61a;outline:none}.roles-tab .role-description-input{max-height:112px;min-height:72px;resize:vertical}.roles-tab .permissions-section{display:flex;flex-direction:column;gap:8px;min-height:0}.roles-tab .permissions-section-title{color:#111827;color:var(--text-primary,#111827);display:block;font-weight:600}.roles-tab .form-hint{color:#6b7280;color:var(--text-secondary,#6b7280);display:block;font-size:12px;font-style:italic;margin:0}.roles-tab .permissions-grid{background-color:#fff;background-color:var(--color-bg-surface,#fff);border:1px solid #e5e7eb;border:1px solid var(--border-color,#e5e7eb);border-radius:14px;display:flex;flex-direction:column;gap:10px;max-height:min(42vh,360px);min-height:220px;overflow:auto;padding:10px 10px 14px;scrollbar-gutter:stable}.roles-tab .permission-module-group{background:#fff;background:var(--color-bg-surface,#fff);border:1px solid #e5e7eb;border:1px solid var(--border-color,#e5e7eb);border-radius:10px;overflow:visible}.roles-tab .permission-module-header{align-items:center;background-color:#f9fafb;background-color:var(--color-bg-app,#f9fafb);border-bottom:1px solid #e5e7eb;border-bottom:1px solid var(--border-color,#e5e7eb);border-radius:10px 10px 0 0;display:flex;gap:8px;justify-content:space-between;padding:8px 12px}.roles-tab .permission-module-collapse{align-items:center;background:none;border:0;color:inherit;cursor:pointer;display:flex;flex:1 1 auto;gap:8px;justify-content:flex-start;line-height:1.4;min-width:0;overflow:visible;padding:2px 0;text-align:left}.roles-tab .permission-module-collapse:focus-visible{border-radius:8px;box-shadow:inset 0 0 0 2px #3b82f640;outline:none}.roles-tab .permission-module-left{width:100%}.roles-tab .permission-module-left,.roles-tab .permission-module-summary{align-items:center;display:flex;gap:8px;min-width:0}.roles-tab .permission-module-chevron{color:#6b7280;color:var(--text-secondary,#6b7280);flex-shrink:0;font-size:12px;line-height:1;width:12px}.roles-tab .permission-module-title{color:#1f2937;color:var(--text-primary,#1f2937);font-size:14px;font-weight:600;letter-spacing:.35px;line-height:1.4;text-transform:uppercase;white-space:nowrap}.roles-tab .permission-module-meta{color:#6b7280;color:var(--text-secondary,#6b7280);font-size:12px;line-height:1.4;margin-left:2px;white-space:nowrap}.roles-tab .permission-module-toggle{appearance:none;-webkit-appearance:none;background:none;border:none;border-radius:8px;color:#3b82f6;color:var(--primary-color,#3b82f6);cursor:pointer;flex-shrink:0;font-size:13px;font-weight:500;line-height:1.3;margin-left:8px;padding:6px 10px;transition:background-color .2s ease;white-space:nowrap}.roles-tab .permission-module-toggle:hover{background-color:#eff6ff;background-color:var(--color-primary-50,#eff6ff)}.roles-tab .permission-module-items{background-color:#fff;display:flex;flex-direction:column}.roles-tab .permission-checkbox{align-items:flex-start;border-radius:0;border-top:1px solid #f1f5f9;border-top:1px solid var(--border-color,#f1f5f9);cursor:pointer;display:flex;gap:12px;min-height:44px;padding:10px 12px;transition:background-color .2s ease;width:100%}.roles-tab .permission-checkbox:hover{background-color:#f9fafb;background-color:var(--bg-hover,#f9fafb)}.roles-tab .checkbox-input{flex-shrink:0;height:16px;margin-top:3px;width:16px}.roles-tab .role-permission-info{display:flex;flex:1 1 auto;flex-direction:column;gap:2px;min-width:0;width:100%}.roles-tab .role-permission-key{color:#1f2937!important;font-family:SF Mono,Menlo,Monaco,Courier New,monospace;font-size:13px;font-weight:500;line-height:1.3}.roles-tab .role-permission-desc,.roles-tab .role-permission-key{display:block;opacity:1!important;visibility:visible!important;word-break:break-word}.roles-tab .role-permission-desc{color:#6b7280!important;font-size:12px;line-height:1.4}.roles-tab .role-dialog-footer{background:#fff;background:var(--color-bg-card,#fff);border-top:1px solid #e5e7eb;border-top:1px solid var(--border-color,#e5e7eb);bottom:0;display:flex;gap:12px;justify-content:flex-end;padding:16px 24px;position:-webkit-sticky;position:sticky;z-index:5}@media (max-height:860px){.roles-tab .role-dialog-body{gap:10px;padding:16px 20px 10px}.roles-tab .role-description-input{max-height:96px;min-height:64px}.roles-tab .permissions-grid{max-height:min(34vh,260px);min-height:180px}.roles-tab .role-dialog-footer{padding:12px 20px}}@media (max-width:768px){.roles-tab{padding:16px 0}.actions-cell{gap:4px}.table-footer{align-items:stretch;flex-direction:column;gap:16px}.role-count{text-align:center}.cps-modal.roles-modal{max-width:95vw}.roles-tab .role-dialog-body{gap:14px;padding:16px}.roles-tab .permissions-grid{max-height:min(32vh,250px);min-height:170px}.roles-tab .role-dialog-footer{flex-wrap:wrap;padding:12px 16px}}.permissions-tab{padding:20px 0}.empty-state p{margin:0 0 24px}.table-footer{flex-wrap:wrap;gap:16px}.pagination-controls{align-items:center;display:flex;flex-wrap:wrap;gap:24px}.permission-count{color:#6b7280;color:var(--text-secondary,#6b7280);font-size:14px;white-space:nowrap}.permission-key-cell{align-items:center;display:flex}.permission-key{background-color:#f9fafb;background-color:var(--bg-subtle,#f9fafb);border-radius:4px;color:#1f2937;color:var(--text-primary,#1f2937);font-family:Courier New,monospace;font-size:13px;font-weight:500;padding:2px 6px}.actions-cell{align-items:center;justify-content:flex-end}.actions-cell button{min-width:-webkit-fit-content;min-width:fit-content;white-space:nowrap;width:auto}.permissions-tab .modal-content{padding:24px}.permissions-tab .modal-actions{border-top:1px solid #e5e7eb;border-top:1px solid var(--border-color,#e5e7eb);display:flex;gap:12px;justify-content:flex-end;margin-top:24px;padding-top:24px}.permissions-tab .form-field{margin-bottom:20px}.permissions-tab .form-field label{color:#1f2937;color:var(--text-primary,#1f2937);display:block;font-weight:500;margin-bottom:6px}.permissions-tab .form-input{border:1px solid #d1d5db;border:1px solid var(--border-color,#d1d5db);border-radius:6px;font-size:14px;padding:10px 12px;transition:border-color .2s ease;width:100%}.permissions-tab .form-input:focus{border-color:#3b82f6;border-color:var(--primary-color,#3b82f6);box-shadow:0 0 0 3px #3b82f61a;outline:none}.permissions-tab .form-hint{color:#6b7280;color:var(--text-secondary,#6b7280);display:block;font-size:12px;margin-top:4px}.cps-modal.permissions-modal{max-width:620px}@media (max-width:768px){.permissions-tab{padding:16px 0}.actions-cell{gap:4px}.table-footer{align-items:stretch;flex-direction:column;gap:16px}.permission-count{text-align:center}}.users-and-access-page{margin:0 auto;max-width:1400px;padding:20px}.section-header{align-items:center;border-bottom:2px solid #e5e7eb;border-bottom:2px solid var(--border-color,#e5e7eb);display:flex;justify-content:space-between;margin-bottom:24px;padding-bottom:16px}.section-header h2{color:#1f2937;color:var(--text-primary,#1f2937);font-size:24px;font-weight:600;margin:0}.subsection{margin-top:32px}.subsection:first-child{margin-top:0}.subsection-header{align-items:center;border-bottom:1px solid #e5e7eb;border-bottom:1px solid var(--border-color,#e5e7eb);display:flex;gap:12px;justify-content:space-between;margin-bottom:20px;padding-bottom:12px}.subsection-header h3{color:#1f2937;color:var(--text-primary,#1f2937);font-size:20px;font-weight:500;margin:0}.users-and-access-page>div:not(:first-child){margin-top:32px}@media (max-width:1200px){.users-and-access-page{padding:16px}}@media (max-width:768px){.users-and-access-page{padding:12px}.section-header h2{font-size:20px}.subsection-header{align-items:flex-start;flex-direction:column}.subsection-header h3{font-size:18px}}.access-control-page{margin:0 auto;max-width:1200px;padding:20px}.page-header{align-items:center;border-bottom:1px solid #e5e7eb;border-bottom:1px solid var(--border-color,#e5e7eb);display:flex;justify-content:space-between;margin-bottom:24px;padding-bottom:16px}.page-header h2{color:#1f2937;color:var(--text-primary,#1f2937);font-size:24px;font-weight:600;margin:0}.header-actions{display:flex;gap:12px}.tabs-container{border-bottom:1px solid #e5e7eb;border-bottom:1px solid var(--border-color,#e5e7eb);margin-bottom:24px}.tabs{gap:0}.tab{background:#0000;border-bottom:2px solid #0000;color:#6b7280;color:var(--text-secondary,#6b7280);font-size:14px;font-weight:500;padding:12px 24px;position:relative;transition:all .2s ease}.tab:hover{background-color:#f9fafb;background-color:var(--bg-hover,#f9fafb);color:#1f2937;color:var(--text-primary,#1f2937)}.tab--active{border-bottom-color:#3b82f6;border-bottom-color:var(--primary-color,#3b82f6);color:#3b82f6;color:var(--primary-color,#3b82f6);font-weight:600}.tab--active:hover{background-color:initial}.tab-content{min-height:400px}@media (max-width:768px){.access-control-page{padding:16px}.page-header{align-items:flex-start;flex-direction:column;gap:16px}.header-actions{justify-content:flex-end;width:100%}.tab{font-size:13px;padding:10px 16px}}.loading-container{display:flex;flex-direction:column;gap:12px;padding:24px 0}.skeleton-row{border-radius:6px}.empty-state{color:#6b7280;color:var(--text-secondary,#6b7280);padding:48px 24px;text-align:center}.empty-icon{font-size:48px;margin-bottom:16px}.empty-state h3{color:#1f2937;color:var(--text-primary,#1f2937);font-size:18px;font-weight:600;margin:0 0 8px}.empty-state p{font-size:14px;margin:0}.search-section{margin-bottom:24px}.search-container{max-width:400px;position:relative}.search-input{border:1px solid #d1d5db;border:1px solid var(--border-color,#d1d5db);border-radius:6px;font-size:14px;padding:10px 12px;transition:border-color .2s ease;width:100%}.search-input:focus{border-color:#3b82f6;border-color:var(--primary-color,#3b82f6);box-shadow:0 0 0 3px #3b82f61a;outline:none}.search-clear{align-items:center;background:none;border:none;border-radius:50%;color:#6b7280;color:var(--text-secondary,#6b7280);cursor:pointer;display:flex;font-size:20px;height:24px;justify-content:center;padding:0;position:absolute;right:12px;top:50%;transform:translateY(-50%);width:24px}.search-clear:hover{background-color:#f3f4f6;background-color:var(--bg-hover,#f3f4f6);color:#1f2937;color:var(--text-primary,#1f2937)}.table-footer{align-items:center;border-top:1px solid #e5e7eb;border-top:1px solid var(--border-color,#e5e7eb);display:flex;justify-content:space-between;margin-top:16px;padding-top:16px}.user-count{color:#6b7280;color:var(--text-secondary,#6b7280);font-size:14px}.status-badge{border-radius:16px;display:inline-block;font-size:12px;font-weight:500;padding:4px 12px;text-transform:uppercase}.status-badge--active{background-color:#dcfce7;background-color:var(--success-bg,#dcfce7);color:#166534;color:var(--success-text,#166534)}.status-badge--disabled{background-color:#fef3c7;background-color:var(--warning-bg,#fef3c7);color:#92400e;color:var(--warning-text,#92400e)}.actions-cell{display:flex;flex-wrap:wrap;gap:8px}.button-danger{background-color:#fee2e2!important;background-color:var(--danger-bg,#fee2e2)!important;border-color:#fecaca!important;border-color:var(--danger-border,#fecaca)!important;color:#991b1b!important;color:var(--danger-text,#991b1b)!important}.button-danger:hover{background-color:#fecaca!important;background-color:var(--danger-hover,#fecaca)!important}.form-field{margin-bottom:20px}.form-field label{color:#1f2937;color:var(--text-primary,#1f2937);display:block;font-weight:500;margin-bottom:6px}.form-input{border:1px solid #d1d5db;border:1px solid var(--border-color,#d1d5db);border-radius:6px;font-size:14px;padding:10px 12px;transition:border-color .2s ease;width:100%}.form-input:focus{border-color:#3b82f6;border-color:var(--primary-color,#3b82f6);box-shadow:0 0 0 3px #3b82f61a;outline:none}.form-input--error{border-color:#f87171;border-color:var(--danger-border,#f87171)}.form-error{color:#dc2626;color:var(--danger-text,#dc2626);display:block;font-size:12px;margin-top:4px}.modal-content{padding:24px}.modal-description{color:#6b7280;color:var(--text-secondary,#6b7280);line-height:1.5;margin-bottom:24px}.modal-actions{border-top:1px solid #e5e7eb;border-top:1px solid var(--border-color,#e5e7eb);display:flex;gap:12px;justify-content:flex-end;margin-top:24px;padding-top:24px}.warning-message{align-items:center;background-color:#fffbeb;background-color:var(--warning-bg,#fffbeb);border:1px solid #fef3c7;border:1px solid var(--warning-border,#fef3c7);border-radius:6px;color:#92400e;color:var(--warning-text,#92400e);display:flex;gap:8px;margin:16px 0;padding:12px 16px}.warning-icon{font-size:18px}.roles-checkbox-group{display:flex;flex-direction:column;gap:12px;margin-bottom:24px}.checkbox-label{align-items:flex-start;border-radius:6px;cursor:pointer;display:flex;gap:12px;padding:12px;transition:background-color .2s ease}.checkbox-label:hover{background-color:#f9fafb;background-color:var(--bg-hover,#f9fafb)}.checkbox-input{margin-top:2px}.checkbox-text{display:flex;flex-direction:column;gap:4px}.role-name{color:#1f2937;color:var(--text-primary,#1f2937);font-weight:500}.role-description{color:#6b7280;color:var(--text-secondary,#6b7280);font-size:13px}.user-name-cell{display:flex;flex-direction:column;gap:4px}.username{color:#1f2937;color:var(--text-primary,#1f2937);font-weight:500}.email{color:#6b7280;color:var(--text-secondary,#6b7280);font-size:13px}.admin-page{padding:var(--space-6)}.page-header{margin-bottom:var(--space-6)}.page-header h1{color:var(--color-text);font-size:var(--font-size-xl);margin:0 0 var(--space-2) 0}.page-description{color:var(--color-text-secondary);font-size:var(--font-size-lg);margin:0}.tabs{border-bottom:2px solid var(--color-border);display:flex;gap:var(--space-1);margin-bottom:var(--space-5)}.tab{background:none;border:none;border-bottom:3px solid #0000;color:var(--color-text-secondary);cursor:pointer;font-size:var(--font-size-base);font-weight:var(--font-weight-medium);padding:var(--space-3) var(--space-5);transition:all var(--transition-fast)}.tab:hover{background:var(--color-bg-app)}.tab.active,.tab:hover{color:var(--color-primary-600)}.tab.active{border-bottom-color:var(--color-primary-600)}.tab-content{padding:var(--space-6)}.info-grid{grid-gap:var(--space-5);display:grid;gap:var(--space-5);grid-template-columns:repeat(auto-fit,minmax(300px,1fr))}.info-card{background:var(--color-bg-app);border-left:4px solid var(--color-primary-600);border-radius:var(--radius-md);padding:var(--space-5)}.info-card h3{color:var(--color-text);font-size:var(--font-size-lg);margin:0 0 var(--space-4) 0}.info-item{align-items:center;display:flex;justify-content:space-between;margin-bottom:var(--space-3)}.info-item:last-child{margin-bottom:0}.label{color:var(--color-text);font-weight:var(--font-weight-medium)}.value{color:var(--color-text-secondary);flex:1 1;font-weight:var(--font-weight-regular);margin-left:var(--space-4);text-align:right}.badge{border-radius:var(--radius-full);color:#fff;display:inline-block;font-size:var(--font-size-xs);font-weight:var(--font-weight-semibold);padding:var(--space-1) var(--space-3);text-transform:uppercase}.badge.success{background:var(--color-success)}.badge.warning{background:var(--color-warning)}.badge.production{background:var(--color-danger)}.badge.development{background:var(--color-primary-600)}.links-section{display:flex;flex-direction:column;gap:var(--space-3)}.external-link{border:1px solid var(--color-primary-600);border-radius:var(--radius-sm);color:var(--color-primary-600);padding:var(--space-2) var(--space-3);text-decoration:none;transition:all var(--transition-fast)}.external-link:hover{background:var(--color-primary-600);color:#fff}.health-overview{margin-bottom:var(--space-6)}.health-status{background:var(--color-bg-app);border-radius:var(--radius-md);gap:var(--space-5);padding:var(--space-5)}.health-status,.status-circle{align-items:center;display:flex}.status-circle{border-radius:50%;color:#fff;font-size:var(--font-size-lg);font-weight:var(--font-weight-bold);height:80px;justify-content:center;text-align:center;width:80px}.status-info h2{color:var(--color-text);margin:0 0 var(--space-1) 0}.status-info p{color:var(--color-text-secondary);margin:0}.checks-section h3{color:var(--color-text);margin:0 0 var(--space-5) 0}.checks-grid{grid-gap:var(--space-4);display:grid;gap:var(--space-4);grid-template-columns:repeat(auto-fit,minmax(250px,1fr));margin-bottom:var(--space-5)}.check-item{align-items:center;background:var(--color-bg-app);border-radius:var(--radius-sm);display:flex;justify-content:space-between;padding:var(--space-3) var(--space-4)}.check-name{color:var(--color-text);font-weight:var(--font-weight-medium)}.check-status{border-radius:var(--radius-full);color:#fff;font-size:var(--font-size-xs);font-weight:var(--font-weight-semibold);padding:var(--space-1) var(--space-3);text-transform:uppercase}.refresh-section{border-top:1px solid var(--color-border);padding-top:var(--space-5);text-align:center}.loading{color:var(--color-text-tertiary);font-size:var(--font-size-lg);padding:var(--space-10);text-align:center}@media (max-width:768px){.info-grid{grid-template-columns:1fr}.health-status{flex-direction:column;gap:var(--space-4);text-align:center}.checks-grid{grid-template-columns:1fr}.tab-content{padding:var(--space-4)}.tabs{flex-wrap:wrap}.tab{flex:1 1;text-align:center}}.cps-select-container{display:flex;flex-direction:column;gap:var(--space-1);width:100%}.cps-select-label{color:var(--color-text);font-size:var(--font-size-sm);font-weight:var(--font-weight-medium)}.cps-select-wrapper{align-items:center;display:flex;position:relative}.cps-select{-webkit-appearance:none;appearance:none;background-color:var(--color-bg-card);border:1px solid var(--color-border);border-radius:var(--radius-md);color:var(--color-text);cursor:pointer;font-family:var(--font-family);font-size:var(--font-size-base);outline:none;padding:var(--space-2) var(--space-4);padding-right:var(--space-10);transition:border-color var(--transition-fast),box-shadow var(--transition-fast);width:100%}.cps-select:hover:not(:disabled){border-color:var(--color-border-hover)}.cps-select:focus{border-color:var(--color-accent-600);box-shadow:var(--focus-ring)}.cps-select:disabled{background-color:var(--color-bg-app);color:var(--color-text-disabled);cursor:not-allowed}.cps-select-arrow{color:var(--color-text-secondary);pointer-events:none;position:absolute;right:var(--space-3)}.cps-select-arrow svg{height:16px;width:16px}.cps-select-container--error .cps-select{border-color:var(--color-danger)}.cps-select-container--error .cps-select:focus{border-color:var(--color-danger);box-shadow:0 0 0 3px #d1434326}.cps-select-error{color:var(--color-danger);font-size:var(--font-size-xs)}.cps-select-container--disabled{opacity:.6}.profile-loading,.profile-page{padding:var(--space-6)}.profile-loading{color:var(--color-text-secondary)}.profile-form-grid{grid-gap:var(--space-4);display:grid;gap:var(--space-4);grid-template-columns:repeat(auto-fit,minmax(260px,1fr))}.profile-actions{display:flex;justify-content:flex-end;margin-top:var(--space-5)}.profile-preferences{grid-gap:var(--space-2);display:grid;gap:var(--space-2);max-width:360px}.profile-help{color:var(--color-text-secondary);font-size:var(--font-size-sm);margin:0}.profile-security{grid-gap:var(--space-3);display:grid;gap:var(--space-3)}.master-data-page{padding:var(--space-6)}.master-data-header{align-items:center;display:flex;gap:var(--space-4);justify-content:space-between;margin-bottom:var(--space-5)}.master-data-header h1{font-size:28px;line-height:1.2;margin:0}.master-data-tabs{display:flex;flex-wrap:wrap;gap:var(--space-2);margin-bottom:var(--space-6)}.master-data-tab{background:#fff;border:1px solid var(--color-border);border-radius:var(--radius-full);color:var(--color-text-secondary);cursor:pointer;font-size:var(--font-size-sm);font-weight:var(--font-weight-semibold);min-height:40px;padding:0 var(--space-4);transition:all var(--transition-fast)}.master-data-tab:hover{border-color:var(--color-primary-300);color:var(--color-primary-700)}.master-data-tab.active{background:var(--color-primary-600);border-color:var(--color-primary-600);color:#fff}.master-data-section{display:flex;flex-direction:column;gap:var(--space-4)}.master-data-section-header{align-items:center;display:flex;gap:var(--space-4);justify-content:space-between}.master-data-section-header h3{font-size:22px;margin:0}.m1-table-toolbar{align-items:center;display:flex;justify-content:flex-start}.m1-table-toolbar .cps-input-container{width:min(420px,100%)}.m1-table-footer{align-items:center;display:flex;flex-wrap:wrap;gap:var(--space-3);justify-content:space-between}.m1-table-count{color:var(--color-text-secondary);font-size:var(--font-size-sm);font-weight:var(--font-weight-medium)}.m1-import-card{border:1px solid var(--color-border);border-radius:var(--radius-md);display:flex;flex-direction:column;gap:var(--space-3);padding:var(--space-4)}.m1-import-card h4{margin:0}.m1-import-card p{color:var(--color-text-secondary);margin:0}.m1-import-result{background:var(--color-info-bg);border-radius:var(--radius-sm);color:var(--color-info);padding:var(--space-3)}.m1-actions{align-items:center;display:flex;gap:var(--space-2)}.m1-inline-note{color:var(--color-text-secondary);font-size:var(--font-size-sm)}.m1-field-block{display:flex;flex-direction:column;gap:6px}.m1-field-hint{color:var(--color-text-secondary);font-size:12px}.m1-modal{max-width:760px}.m1-modal.m1-modal-wide{max-width:980px}.m1-form-grid{grid-gap:var(--space-4);display:grid;gap:var(--space-4);grid-template-columns:repeat(2,minmax(0,1fr))}.m1-form-grid .m1-checkbox-row,.m1-form-grid .m1-custom-fields-grid,.m1-form-grid .m1-document-lines,.m1-form-grid .m1-field-row,.m1-form-grid .m1-modal-actions{grid-column:1/-1}.m1-field-row{display:flex;flex-direction:column;gap:var(--space-2)}.m1-field-row label{color:var(--color-text-secondary);font-size:var(--font-size-sm);font-weight:var(--font-weight-semibold)}.m1-field-row input,.m1-field-row select,.m1-field-row textarea{border:1px solid var(--color-border);border-radius:var(--radius-sm);font-size:var(--font-size-base);min-height:42px;padding:10px 12px}.m1-field-row textarea{min-height:84px;resize:vertical}.m1-field-row-checkbox label{align-items:center;cursor:pointer;display:inline-flex;gap:var(--space-2)}.m1-custom-fields-grid{border:1px dashed var(--color-border-hover);border-radius:var(--radius-md);display:flex;flex-direction:column;gap:var(--space-3);padding:var(--space-4)}.m1-custom-fields-grid h4{margin:0}.m1-document-lines{border:1px solid var(--color-border);border-radius:var(--radius-md);display:flex;flex-direction:column;gap:var(--space-3);padding:var(--space-4)}.m1-document-lines h4{margin:0}.m1-price-line-header{color:var(--color-text-secondary);font-size:var(--font-size-xs);letter-spacing:.4px;text-transform:uppercase}.m1-price-line-header,.m1-price-line-row{grid-gap:var(--space-2);display:grid;gap:var(--space-2);grid-template-columns:2fr 1fr 1fr auto}.m1-price-line-row input,.m1-price-line-row select{border:1px solid var(--color-border);border-radius:var(--radius-sm);min-height:42px;padding:10px 12px}.m1-document-line-header{color:var(--color-text-secondary);font-size:var(--font-size-xs);letter-spacing:.4px;text-transform:uppercase}.m1-document-line-header,.m1-document-line-row{grid-gap:var(--space-2);display:grid;gap:var(--space-2);grid-template-columns:2fr 1fr 1fr 1fr auto}.m1-document-line-row input,.m1-document-line-row select{border:1px solid var(--color-border);border-radius:var(--radius-sm);min-height:42px;padding:10px 12px}.m1-document-line-amount{align-items:center;color:var(--color-text);display:flex;font-weight:var(--font-weight-medium);justify-content:flex-end;padding:0 8px}.m1-modal-actions{border-top:1px solid var(--color-border);display:flex;gap:var(--space-3);justify-content:flex-end;padding-top:var(--space-3)}.m1-checkbox-row{display:flex;gap:var(--space-5)}.m1-checkbox-row label{align-items:center;cursor:pointer;display:inline-flex;gap:var(--space-2)}@media (max-width:1024px){.m1-form-grid{grid-template-columns:1fr}.m1-document-line-header{display:none}.m1-document-line-row{grid-template-columns:1fr}.m1-document-line-amount{justify-content:flex-start}}@media (max-width:768px){.master-data-page{padding:var(--space-4)}.m1-table-footer,.master-data-header,.master-data-section-header{align-items:flex-start;flex-direction:column}.m1-actions{flex-wrap:wrap}}.warehouse-inventory-page{padding:var(--space-6)}.warehouse-inventory-header{align-items:flex-start;display:flex;gap:var(--space-4);justify-content:space-between;margin-bottom:var(--space-4)}.warehouse-inventory-header-actions{display:flex;flex-wrap:wrap;gap:var(--space-3)}.warehouse-inventory-header h1{font-size:32px;margin:0 0 var(--space-2)}.warehouse-inventory-header p{color:var(--color-text-secondary);margin:0}.warehouse-inventory-toolbar{margin-bottom:var(--space-4);max-width:420px}.warehouse-access-warning{background:#facc151f;border:1px solid #facc1559;border-radius:var(--radius-md);color:#b45309;font-size:var(--font-size-sm);margin-bottom:var(--space-3);padding:8px 12px}.warehouse-inventory-footer{align-items:center;display:flex;justify-content:space-between;margin-top:var(--space-4)}.warehouse-inventory-actions{border-top:1px solid var(--color-border);display:flex;gap:var(--space-3);justify-content:flex-end;padding-top:var(--space-3)}.warehouse-inventory-danger{background-color:#d1434314!important;border-color:#d143434d!important;color:var(--color-danger)!important}.warehouse-inventory-item{display:flex;flex-direction:column;gap:4px}.warehouse-inventory-name{font-weight:var(--font-weight-medium)}.warehouse-inventory-meta{color:var(--color-text-secondary);font-size:var(--font-size-xs)}.warehouse-inventory-status{align-items:center;border-radius:999px;display:inline-flex;font-size:var(--font-size-xs);font-weight:var(--font-weight-medium);letter-spacing:.4px;padding:4px 10px;text-transform:uppercase}.warehouse-inventory-status.status-ok{background:#22c55e26;color:#16a34a}.warehouse-inventory-status.status-low{background:#facc152e;color:#ca8a04}.warehouse-inventory-status.status-out{background:#ef444426;color:#dc2626}.warehouse-inventory-status.status-over{background:#3b82f626;color:#2563eb}.warehouse-inventory-modal{max-width:640px}.warehouse-inventory-form{display:flex;flex-direction:column;gap:var(--space-4)}.warehouse-inventory-grid{grid-gap:var(--space-4);display:grid;gap:var(--space-4);grid-template-columns:repeat(2,minmax(0,1fr))}.warehouse-inventory-field{display:flex;flex-direction:column;gap:var(--space-2)}.warehouse-inventory-field select{background:var(--color-bg-card);border:1px solid var(--color-border);border-radius:var(--radius-md);color:var(--color-text);padding:10px 12px;width:100%}.warehouse-access-modal{max-width:720px}.warehouse-access-body{display:flex;flex-direction:column;gap:var(--space-5)}.warehouse-access-form label{display:block;font-weight:var(--font-weight-medium);margin-bottom:var(--space-2)}.warehouse-access-row{align-items:center;display:flex;gap:var(--space-3)}.warehouse-access-row select{background:var(--color-bg-card);border:1px solid var(--color-border);border-radius:var(--radius-md);color:var(--color-text);flex:1 1;padding:10px 12px}.warehouse-access-list{display:flex;flex-direction:column;gap:var(--space-3)}.warehouse-access-list h4{margin:0}.warehouse-access-item{align-items:center;background:var(--color-bg-card);border:1px solid var(--color-border);border-radius:var(--radius-md);display:flex;gap:var(--space-3);justify-content:space-between;padding:var(--space-3)}.warehouse-access-name{font-weight:var(--font-weight-medium)}.warehouse-access-meta{color:var(--color-text-secondary);font-size:var(--font-size-xs)}@media (max-width:960px){.warehouse-inventory-header{align-items:flex-start;flex-direction:column}.warehouse-inventory-grid{grid-template-columns:1fr}.warehouse-inventory-footer{align-items:flex-start;flex-direction:column;gap:var(--space-3)}}.inventory-report-page{padding:var(--space-6)}.inventory-report-header{align-items:flex-start;display:flex;gap:var(--space-4);justify-content:space-between;margin-bottom:var(--space-4)}.inventory-report-header h1{font-size:32px;margin:0 0 var(--space-2)}.inventory-report-header p{color:var(--color-text-secondary);margin:0}.inventory-report-summary{grid-gap:var(--space-3);display:grid;gap:var(--space-3);grid-template-columns:repeat(4,minmax(0,1fr));margin-bottom:var(--space-5)}.inventory-report-summary-card{background:var(--color-bg-card);border:1px solid var(--color-border);border-radius:var(--radius-md);display:flex;flex-direction:column;gap:6px;padding:var(--space-3)}.inventory-report-summary-card strong{font-size:20px}.inventory-report-summary-card.status-ok{border-color:#22c55e33}.inventory-report-summary-card.status-low{border-color:#facc1533}.inventory-report-summary-card.status-out{border-color:#ef444433}.inventory-report-summary-card.status-over{border-color:#3b82f633}.inventory-report-filters{grid-gap:var(--space-4);display:grid;gap:var(--space-4);grid-template-columns:repeat(3,minmax(0,1fr));margin-bottom:var(--space-4)}.inventory-report-cell{display:flex;flex-direction:column;gap:4px}.inventory-report-primary{font-weight:var(--font-weight-medium)}.inventory-report-secondary{color:var(--color-text-secondary);font-size:var(--font-size-xs)}.inventory-report-status{align-items:center;border-radius:999px;display:inline-flex;font-size:var(--font-size-xs);font-weight:var(--font-weight-medium);letter-spacing:.4px;padding:4px 10px;text-transform:uppercase}.inventory-report-status.status-ok{background:#22c55e26;color:#16a34a}.inventory-report-status.status-low{background:#facc152e;color:#ca8a04}.inventory-report-status.status-out{background:#ef444426;color:#dc2626}.inventory-report-status.status-over{background:#3b82f626;color:#2563eb}.inventory-report-footer{align-items:center;display:flex;justify-content:space-between;margin-top:var(--space-4)}@media (max-width:1100px){.inventory-report-summary{grid-template-columns:repeat(2,minmax(0,1fr))}.inventory-report-filters{grid-template-columns:1fr}.inventory-report-footer{align-items:flex-start;flex-direction:column;gap:var(--space-3)}}.inventory-page{padding:var(--space-6)}.inventory-header{align-items:flex-start;display:flex;gap:var(--space-4);justify-content:space-between;margin-bottom:var(--space-4)}.inventory-header h1{font-size:28px;margin:0 0 var(--space-2)}.inventory-header p{color:var(--color-text-secondary);margin:0}.inventory-filters{grid-gap:var(--space-4);display:grid;gap:var(--space-4);grid-template-columns:repeat(4,minmax(0,1fr));margin-bottom:var(--space-4)}.inventory-filters--balances{grid-template-columns:repeat(3,minmax(0,1fr))}.inventory-filters--stocktake{grid-template-columns:repeat(2,minmax(0,1fr))}.inventory-filters--documents{grid-template-columns:repeat(5,minmax(0,1fr))}.inventory-filters--moves,.inventory-filters--turnover{align-items:end;grid-template-columns:repeat(5,minmax(0,1fr))}.inventory-filters-actions{align-items:center;display:flex;gap:var(--space-2);justify-content:flex-end}.inventory-table-footer{align-items:center;display:flex;justify-content:space-between;margin-top:var(--space-4)}.inventory-count{color:var(--color-text-secondary);font-size:var(--font-size-sm)}.inventory-cell{display:flex;flex-direction:column;gap:4px}.inventory-primary{font-weight:var(--font-weight-medium)}.inventory-secondary{color:var(--color-text-secondary);font-size:var(--font-size-xs)}.inventory-mono{font-family:SFMono-Regular,ui-monospace,Menlo,Monaco,Consolas,Liberation Mono,monospace;font-size:var(--font-size-xs)}.inventory-qty{font-weight:var(--font-weight-semibold)}.inventory-qty.positive{color:var(--color-success)}.inventory-qty.negative{color:var(--color-danger)}.inventory-qty.neutral{color:var(--color-text-secondary)}.inventory-doc-id{align-items:center;display:inline-flex;gap:var(--space-2)}.inventory-copy{background:#0000;border:none;color:var(--color-primary-600);cursor:pointer;font-size:var(--font-size-xs);padding:0}.inventory-copy:hover{color:var(--color-primary-700)}.inventory-empty-hint{color:var(--color-text-secondary);font-size:var(--font-size-sm);margin-top:var(--space-2)}.inventory-stocktake-lines{display:flex;flex-direction:column;gap:var(--space-3);margin-top:var(--space-4)}.inventory-section-title{color:var(--color-text-secondary);font-size:var(--font-size-sm);font-weight:var(--font-weight-semibold);letter-spacing:.4px;text-transform:uppercase}.inventory-stocktake-line{grid-gap:var(--space-3);align-items:end;background:var(--color-bg-card);border:1px solid var(--color-border);border-radius:var(--radius-md);display:grid;gap:var(--space-3);grid-template-columns:2fr 1fr 1fr 1fr auto;padding:var(--space-3)}.inventory-stocktake-line--error{background:var(--color-danger-bg);border-color:var(--color-danger-border)}.inventory-line-error{color:var(--color-danger);font-size:var(--font-size-xs);grid-column:1/-1}.inventory-actions{display:flex;gap:var(--space-3);justify-content:flex-end;margin-top:var(--space-4)}.inventory-actions--secondary{justify-content:flex-start}.inventory-summary{color:var(--color-text-secondary);margin-top:var(--space-3)}.inventory-status{align-items:center;border-radius:var(--radius-full);display:inline-flex;font-size:var(--font-size-xs);font-weight:var(--font-weight-semibold);padding:2px 8px;text-transform:capitalize}.inventory-status--draft{background:var(--color-border);color:var(--color-text-secondary)}.inventory-status--posted{background:var(--color-success-bg);color:var(--color-success)}.inventory-status--reversed{background:var(--color-danger-bg);color:var(--color-danger)}.inventory-document-number{color:var(--color-text-secondary);font-weight:var(--font-weight-semibold)}.inventory-form-grid{grid-gap:var(--space-4);display:grid;gap:var(--space-4);grid-template-columns:repeat(2,minmax(0,1fr));margin-bottom:var(--space-4)}.inventory-doc-lines{display:flex;flex-direction:column;gap:var(--space-3);margin-bottom:var(--space-4);margin-top:var(--space-3)}.inventory-doc-line{grid-gap:var(--space-3);align-items:end;background:var(--color-bg-card);border:1px solid var(--color-border);display:grid;gap:var(--space-3);grid-template-columns:repeat(4,minmax(0,1fr)) auto}.inventory-doc-line,.inventory-info{border-radius:var(--radius-md);padding:var(--space-3)}.inventory-info{background:var(--color-warning-bg);color:var(--color-warning);font-size:var(--font-size-sm);margin-bottom:var(--space-3)}.inventory-documents-note{color:var(--color-text-secondary);font-size:var(--font-size-sm);margin-bottom:var(--space-4);margin-top:var(--space-2)}.inventory-danger-button{background:var(--color-danger-bg);border-color:var(--color-danger-border);color:var(--color-danger)}.inventory-preview{margin-top:var(--space-4)}.inventory-diff{align-items:center;border-radius:var(--radius-full);display:inline-flex;font-size:var(--font-size-xs);font-weight:var(--font-weight-semibold);padding:2px 8px}.inventory-diff.positive{background:var(--color-success-bg);color:var(--color-success)}.inventory-diff.negative{background:var(--color-danger-bg);color:var(--color-danger)}.inventory-diff.neutral{background:var(--color-border);color:var(--color-text-secondary)}@media (max-width:1100px){.inventory-filters,.inventory-filters--balances,.inventory-filters--moves,.inventory-filters--stocktake,.inventory-filters--turnover{grid-template-columns:1fr}.inventory-table-footer{align-items:flex-start;flex-direction:column;gap:var(--space-3)}.inventory-doc-line,.inventory-stocktake-line{grid-template-columns:1fr}.inventory-actions{align-items:stretch;flex-direction:column}}.cps-toast-container{display:flex;flex-direction:column;gap:var(--space-3);max-width:380px;position:fixed;right:var(--space-6);top:var(--space-6);z-index:9999}.cps-toast{align-items:center;animation:cps-toast-slide-in .2s ease-out;border-left:4px solid;border-radius:var(--radius-md);box-shadow:var(--shadow-lg);display:flex;min-height:48px;overflow:hidden;padding:var(--space-3) var(--space-4)}.cps-toast--success{background-color:var(--color-success-bg);border-left-color:var(--color-success);color:var(--color-success)}.cps-toast--error{background-color:var(--color-danger-bg);border-left-color:var(--color-danger);color:var(--color-danger)}.cps-toast--warning{background-color:var(--color-warning-bg);border-left-color:var(--color-warning);color:var(--color-warning)}.cps-toast--info{background-color:var(--color-info-bg);border-left-color:var(--color-info);color:var(--color-info)}.cps-toast__content{align-items:center;display:flex;flex:1 1;gap:var(--space-3);justify-content:space-between}.cps-toast__message{flex:1 1;font-size:var(--font-size-sm);font-weight:var(--font-weight-medium);line-height:var(--line-height-normal)}.cps-toast__close{align-items:center;background:none;border:none;border-radius:var(--radius-sm);color:inherit;cursor:pointer;display:flex;height:24px;justify-content:center;padding:0;transition:all var(--transition-fast);width:24px}.cps-toast__close:hover{background-color:#fff3}.cps-toast__close:focus-visible{box-shadow:var(--focus-ring);outline:none}.cps-toast__close svg{height:16px;width:16px}@keyframes cps-toast-slide-in{0%{opacity:0;transform:translateX(100%)}to{opacity:1;transform:translateX(0)}}@media (max-width:768px){.cps-toast-container{left:var(--space-3);max-width:calc(100% - var(--space-6));right:var(--space-3)}.cps-toast{width:100%}}.ar-ap-page{padding:var(--space-6)}.ar-ap-header{align-items:flex-start;display:flex;gap:var(--space-4);justify-content:space-between;margin-bottom:var(--space-4)}.ar-ap-header h1{font-size:28px;margin:0 0 var(--space-2)}.ar-ap-header p{color:var(--color-text-secondary);margin:0}.ar-ap-filters{grid-gap:var(--space-4);align-items:end;display:grid;gap:var(--space-4);grid-template-columns:repeat(4,minmax(0,1fr));margin-bottom:var(--space-4)}.ar-ap-filters--payments{grid-template-columns:repeat(5,minmax(0,1fr))}.ar-ap-filters-actions{align-items:center;display:flex;gap:var(--space-2);justify-content:flex-end}.ar-ap-table-footer{align-items:center;display:flex;gap:var(--space-3);justify-content:space-between;margin-top:var(--space-4)}.ar-ap-count{color:var(--color-text-secondary);font-size:var(--font-size-sm)}.ar-ap-cell{display:flex;flex-direction:column;gap:4px}.ar-ap-primary{font-weight:var(--font-weight-medium)}.ar-ap-secondary{color:var(--color-text-secondary);font-size:var(--font-size-xs)}.ar-ap-number{font-feature-settings:"tnum","tnum";font-variant-numeric:tabular-nums}.ar-ap-number--positive{color:var(--color-success);font-weight:var(--font-weight-semibold)}.ar-ap-number--neutral{color:var(--color-text-primary);font-weight:var(--font-weight-medium)}.ar-ap-number--muted{color:var(--color-text-secondary)}.ar-ap-direction,.ar-ap-status{align-items:center;border-radius:var(--radius-full);display:inline-flex;font-size:var(--font-size-xs);font-weight:var(--font-weight-semibold);justify-content:center;letter-spacing:.04em;padding:4px 10px;text-transform:uppercase}.ar-ap-status--open{background:var(--color-warning-bg);color:var(--color-warning)}.ar-ap-status--partial{background:var(--color-primary-50);background:var(--color-info-bg,var(--color-primary-50));color:var(--color-primary-600);color:var(--color-info,var(--color-primary-600))}.ar-ap-status--paid{background:var(--color-success-bg);color:var(--color-success)}.ar-ap-status--reversed{background:var(--color-danger-bg);color:var(--color-danger)}.ar-ap-direction--ar,.ar-ap-direction--in{background:var(--color-success-bg);color:var(--color-success)}.ar-ap-direction--ap,.ar-ap-direction--out{background:var(--color-warning-bg);color:var(--color-warning)}.ar-ap-empty-hint{color:var(--color-text-secondary);font-size:var(--font-size-sm);margin-top:var(--space-2)}.ar-ap-form{display:flex;flex-direction:column;gap:var(--space-4)}.ar-ap-form-grid{grid-gap:var(--space-4);display:grid;gap:var(--space-4);grid-template-columns:repeat(2,minmax(0,1fr))}.ar-ap-form-actions{display:flex;gap:var(--space-3);justify-content:flex-end}.ar-ap-section{margin-top:var(--space-6)}.ar-ap-section__header{align-items:flex-start;display:flex;gap:var(--space-4);justify-content:space-between;margin-bottom:var(--space-4)}.ar-ap-section__header h2{font-size:20px;margin:0 0 var(--space-2)}.ar-ap-section__header p{color:var(--color-text-secondary);margin:0}.ar-ap-detail-grid,.ar-ap-summary-grid{grid-gap:var(--space-4);display:grid;gap:var(--space-4);grid-template-columns:repeat(3,minmax(0,1fr))}.ar-ap-detail-card,.ar-ap-summary-card{background:var(--color-surface);border:1px solid var(--color-border-default);border-radius:var(--radius-card);display:flex;flex-direction:column;gap:var(--space-2);padding:var(--space-4)}.ar-ap-detail-card--wide{grid-column:span 3}.ar-ap-detail-label{color:var(--color-text-secondary);font-size:var(--font-size-xs);letter-spacing:.04em;text-transform:uppercase}.ar-ap-inline-input{min-width:140px}.ar-ap-filters--statement{grid-template-columns:repeat(4,minmax(0,1fr))}@media (max-width:1100px){.ar-ap-detail-grid,.ar-ap-filters,.ar-ap-filters--payments,.ar-ap-filters--statement,.ar-ap-form-grid,.ar-ap-summary-grid{grid-template-columns:repeat(2,minmax(0,1fr))}.ar-ap-detail-card--wide{grid-column:span 2}}@media (max-width:720px){.ar-ap-page{padding:var(--space-4)}.ar-ap-form-actions,.ar-ap-header,.ar-ap-section__header,.ar-ap-table-footer{align-items:stretch;flex-direction:column}.ar-ap-detail-grid,.ar-ap-filters,.ar-ap-filters--payments,.ar-ap-filters--statement,.ar-ap-form-grid,.ar-ap-summary-grid{grid-template-columns:1fr}.ar-ap-filters-actions{justify-content:stretch}.ar-ap-detail-card--wide{grid-column:span 1}}.cps-checkbox-container{align-items:center;display:flex}.cps-checkbox-label{align-items:center;cursor:pointer;display:inline-flex;gap:var(--space-3);-webkit-user-select:none;user-select:none}.cps-checkbox-input{height:0;opacity:0;position:absolute;width:0}.cps-checkbox-box{align-items:center;background-color:var(--color-bg-card);border:1.5px solid var(--color-border);border-radius:var(--radius-sm);display:flex;flex-shrink:0;height:20px;justify-content:center;transition:all var(--transition-fast);width:20px}.cps-checkbox-box svg{color:#fff;height:14px;opacity:0;transform:scale(.5);transition:all var(--transition-fast);width:14px}.cps-checkbox-label:hover .cps-checkbox-box{border-color:var(--color-primary-600)}.cps-checkbox-input:focus-visible+.cps-checkbox-box{box-shadow:var(--focus-ring)}.cps-checkbox-input:checked+.cps-checkbox-box{background-color:var(--color-primary-600);border-color:var(--color-primary-600)}.cps-checkbox-input:checked+.cps-checkbox-box svg{opacity:1;transform:scale(1)}.cps-checkbox-input:disabled+.cps-checkbox-box{background-color:var(--color-bg-app);border-color:var(--color-border);cursor:not-allowed}.cps-checkbox-input:disabled~.cps-checkbox-text{color:var(--color-text-disabled);cursor:not-allowed}.cps-checkbox-text{color:var(--color-text);font-size:var(--font-size-sm);line-height:1.4}.cps-alert{align-items:flex-start;border:1px solid;border-radius:var(--radius-md);display:flex;gap:var(--space-3);padding:var(--space-4)}.cps-alert--info{background-color:var(--color-info-bg);border-color:var(--color-info-border)}.cps-alert--info .cps-alert-icon{color:var(--color-info)}.cps-alert--warning{background-color:var(--color-warning-bg);border-color:var(--color-warning-border)}.cps-alert--warning .cps-alert-icon{color:var(--color-warning)}.cps-alert--danger{background-color:var(--color-danger-bg);border-color:var(--color-danger-border)}.cps-alert--danger .cps-alert-icon{color:var(--color-danger)}.cps-alert--success{background-color:var(--color-success-bg);border-color:var(--color-success-border)}.cps-alert--success .cps-alert-icon{color:var(--color-success)}.cps-alert-icon{align-items:center;display:flex;flex-shrink:0;justify-content:center}.cps-alert-icon svg{height:20px;width:20px}.cps-alert-content{flex:1 1;min-width:0}.cps-alert-title{font-size:var(--font-size-sm);font-weight:var(--font-weight-semibold);margin-bottom:var(--space-1)}.cps-alert-message{font-size:var(--font-size-sm);line-height:var(--line-height-normal)}.cps-alert-dismiss{align-items:center;background:none;border:none;border-radius:var(--radius-sm);cursor:pointer;display:flex;flex-shrink:0;height:24px;justify-content:center;opacity:.6;padding:0;transition:opacity var(--transition-fast);width:24px}.cps-alert-dismiss:hover{opacity:1}.cps-alert-dismiss:focus-visible{box-shadow:var(--focus-ring);outline:none}.cps-alert-dismiss svg{height:16px;width:16px}.cps-alert--info .cps-alert-icon{color:#2563eb}.cps-alert--info .cps-alert-title{color:#1e40af}.cps-alert--info .cps-alert-message{color:#1e3a8a}.cps-alert--warning .cps-alert-icon{color:#d97706}.cps-alert--warning .cps-alert-title{color:#92400e}.cps-alert--warning .cps-alert-message{color:#78350f}.cps-alert--danger .cps-alert-icon{color:#d14343}.cps-alert--danger .cps-alert-title{color:#991b1b}.cps-alert--danger .cps-alert-message{color:#7f1d1d}.cps-alert--success .cps-alert-icon{color:#16a34a}.cps-alert--success .cps-alert-title{color:#166534}.cps-alert--success .cps-alert-message{color:#14532d}.cps-login-page{background-color:var(--color-bg-app);display:flex;min-height:100vh}.cps-login-panel{background:linear-gradient(135deg,var(--color-primary-600) 0,var(--color-accent-600) 100%);display:none;overflow:hidden;padding:var(--space-12);position:relative;width:50%}.cps-login-panel:before{background:radial-gradient(circle,#ffffff1a 0,#0000 70%);content:"";height:100%;pointer-events:none;position:absolute;right:-50%;top:-50%;width:100%}.cps-login-panel-content{display:flex;flex-direction:column;height:100%;justify-content:center;margin:0 auto;max-width:480px;position:relative;z-index:1}.cps-login-logo{color:#fff;height:72px;margin-bottom:var(--space-8);width:72px}.cps-login-logo svg{height:100%;width:100%}.cps-login-panel-title{color:#fff;font-size:36px;font-weight:var(--font-weight-semibold);line-height:var(--line-height-tight);margin:0 0 var(--space-4) 0}.cps-login-panel-subtitle{color:#fffc;font-size:var(--font-size-lg);line-height:var(--line-height-relaxed);margin:0}.cps-login-main{align-items:center;display:flex;flex:1 1;justify-content:center;padding:var(--space-6)}.cps-login-card{background-color:var(--color-bg-card);border-radius:var(--radius-lg);box-shadow:var(--shadow-lg);max-width:420px;padding:var(--space-8);width:100%}.cps-login-header{margin-bottom:var(--space-6)}.cps-login-brand{align-items:center;display:flex;gap:var(--space-3)}.cps-login-brand-icon{flex-shrink:0;height:32px;width:32px}.cps-login-brand-text{color:var(--color-text-secondary);font-size:var(--font-size-sm);font-weight:var(--font-weight-medium)}.cps-login-alert{margin-bottom:var(--space-5)}.cps-login-title{color:var(--color-text);font-size:var(--font-size-3xl);font-weight:var(--font-weight-semibold);line-height:var(--line-height-tight);margin:0 0 var(--space-2) 0}.cps-login-subtitle{color:var(--color-text-secondary);font-size:var(--font-size-base);margin:0 0 var(--space-6) 0}.cps-login-form{display:flex;flex-direction:column;gap:var(--space-4)}.cps-login-options{align-items:center;display:flex;justify-content:space-between;margin-top:calc(var(--space-2)*-1)}.cps-login-forgot{background:none;border:none;color:var(--color-primary-600);cursor:pointer;font-size:var(--font-size-sm);font-weight:var(--font-weight-medium);padding:0;transition:color var(--transition-fast)}.cps-login-forgot:hover{color:var(--color-primary-700)}.cps-login-forgot:focus-visible{border-radius:var(--radius-sm);box-shadow:var(--focus-ring);outline:none}.cps-login-forgot:disabled{color:var(--color-text-disabled);cursor:not-allowed}.cps-login-submit{margin-top:var(--space-2);width:100%}.cps-login-footer{border-top:1px solid var(--color-border);margin-top:var(--space-6);padding-top:var(--space-5);text-align:center}.cps-login-footer p{color:var(--color-text-tertiary);font-size:var(--font-size-xs);margin:0}.cps-modal-text{color:var(--color-text);font-size:var(--font-size-base);line-height:var(--line-height-relaxed);margin-bottom:var(--space-6)}@media (min-width:768px){.cps-login-panel{display:block;width:40%}}@media (min-width:1024px){.cps-login-panel{display:block;width:50%}.cps-login-card{padding:var(--space-8)}}@media (max-width:767px){.cps-login-main{padding:var(--space-4)}.cps-login-card{border-radius:var(--radius-md);padding:var(--space-6)}.cps-login-title{font-size:var(--font-size-2xl)}.cps-login-panel{display:none}}.forbidden-page{align-items:center;background-color:var(--color-bg-app);display:flex;justify-content:center;min-height:100vh;padding:var(--space-6)}.forbidden-card{background:var(--color-bg-card);border:1px solid var(--color-border);border-radius:var(--radius-lg);box-shadow:var(--shadow-md);max-width:640px;overflow:hidden;width:100%}.forbidden-card__header{background:#11182705;border-bottom:1px solid var(--color-border);padding:var(--space-4) var(--space-6)}.forbidden-card__header h1{color:var(--color-text);font-size:18px;font-weight:var(--font-weight-semibold);margin:0}.forbidden-card__body{align-items:flex-start;display:flex;gap:var(--space-4);padding:var(--space-6)}.forbidden-card__icon{align-items:center;background:#ef44441f;border-radius:12px;color:#ef4444;display:flex;flex-shrink:0;font-size:22px;height:44px;justify-content:center;width:44px}.forbidden-card__subtitle{color:var(--color-text);font-size:14px;font-weight:var(--font-weight-semibold);letter-spacing:.04em;margin-bottom:var(--space-2);text-transform:uppercase}.forbidden-message{color:var(--color-text-secondary);font-size:15px;line-height:1.6;margin:0 0 var(--space-2)}.forbidden-hint{color:var(--color-text-muted);font-size:14px;margin:0}.forbidden-card__footer{border-top:1px solid var(--color-border);display:flex;justify-content:flex-end;padding:var(--space-4) var(--space-6)}.forbidden-actions{display:flex;flex-wrap:wrap;gap:var(--space-3);justify-content:flex-end}.forbidden-available{color:var(--color-text);font-size:14px;font-weight:var(--font-weight-medium);margin:var(--space-3) 0 0}@media (max-width:600px){.forbidden-card__body{flex-direction:column}.forbidden-card__footer{justify-content:stretch}.forbidden-actions,.forbidden-card__footer .cps-button{width:100%}}.App{text-align:center}.App-logo{height:40vmin;pointer-events:none}@media (prefers-reduced-motion:no-preference){.App-logo{animation:App-logo-spin 20s linear infinite}}.App-header{align-items:center;background-color:#282c34;color:#fff;display:flex;flex-direction:column;justify-content:center;min-height:100vh;padding:20px}.App-link{color:#61dafb}@keyframes App-logo-spin{0%{transform:rotate(0deg)}to{transform:rotate(1turn)}}
/*# sourceMappingURL=main.4127f282.css.map*/