*,:before,:after{box-sizing:border-box;margin:0;padding:0}:root{--color-primary:#1e3a5f;--color-primary-light:#2c5282;--color-accent:#4fc3f7;--color-success:#48bb78;--color-warning:#ed8936;--color-danger:#f56565;--color-bg:#f0f2f5;--color-card:#fff;--color-text:#2d3748;--color-text-secondary:#718096;--color-border:#e2e8f0;--radius:8px;--shadow:0 1px 3px #00000014, 0 1px 2px #0000000f;--shadow-lg:0 4px 12px #0000001a}body{color:var(--color-text);background:var(--color-bg);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Helvetica Neue,Arial,Noto Sans SC,sans-serif;font-size:14px;line-height:1.6}.card{background:var(--color-card);border-radius:var(--radius);box-shadow:var(--shadow);margin-bottom:20px;padding:24px}.card-header{flex-wrap:wrap;justify-content:space-between;align-items:center;gap:12px;margin-bottom:20px;display:flex}.card-header h2{color:var(--color-text);font-size:18px;font-weight:600}.btn{cursor:pointer;white-space:nowrap;border:none;border-radius:6px;align-items:center;gap:6px;padding:8px 16px;font-size:13px;font-weight:500;text-decoration:none;transition:all .2s;display:inline-flex}.btn-primary{background:var(--color-primary-light);color:#fff}.btn-primary:hover{background:var(--color-primary)}.btn-success{background:var(--color-success);color:#fff}.btn-success:hover{opacity:.9}.btn-warning{background:var(--color-warning);color:#fff}.btn-warning:hover{opacity:.9}.btn-danger{background:var(--color-danger);color:#fff}.btn-danger:hover{opacity:.9}.btn-outline{color:var(--color-text);border:1px solid var(--color-border);background:#fff}.btn-outline:hover{background:var(--color-bg)}.btn-sm{padding:4px 10px;font-size:12px}.form-group{margin-bottom:16px}.form-group label{color:var(--color-text);margin-bottom:4px;font-size:13px;font-weight:500;display:block}.form-control{border:1px solid var(--color-border);width:100%;color:var(--color-text);background:#fff;border-radius:6px;padding:8px 12px;font-size:14px;transition:border-color .2s}.form-control:focus{border-color:var(--color-accent);outline:none;box-shadow:0 0 0 3px #4fc3f726}select.form-control{appearance:auto}textarea.form-control{resize:vertical;min-height:80px}.table-wrapper{overflow-x:auto}table{border-collapse:collapse;width:100%;font-size:13px}thead{background:#f7fafc}th{text-align:left;color:var(--color-text-secondary);border-bottom:2px solid var(--color-border);white-space:nowrap;padding:12px 16px;font-weight:600}td{border-bottom:1px solid var(--color-border);color:var(--color-text);padding:12px 16px}tbody tr:hover{background:#f7fafc}.badge{border-radius:12px;padding:2px 10px;font-size:12px;font-weight:500;display:inline-block}.badge-info{color:#2c5282;background:#bee3f8}.badge-success{color:#276749;background:#c6f6d5}.badge-warning{color:#975a16;background:#fefcbf}.badge-danger{color:#9b2c2c;background:#fed7d7}.modal-overlay{z-index:1000;background:#00000080;justify-content:center;align-items:center;padding:20px;display:flex;position:fixed;inset:0}.modal{border-radius:var(--radius);box-shadow:var(--shadow-lg);background:#fff;width:100%;max-width:560px;max-height:85vh;overflow-y:auto}.modal-header{border-bottom:1px solid var(--color-border);background:#fff;justify-content:space-between;align-items:center;padding:16px 24px;display:flex;position:sticky;top:0}.modal-header h3{font-size:16px;font-weight:600}.modal-close{cursor:pointer;color:var(--color-text-secondary);background:0 0;border:none;padding:4px;font-size:20px}.modal-body{padding:20px 24px}.modal-footer{border-top:1px solid var(--color-border);justify-content:flex-end;gap:8px;padding:16px 24px;display:flex}.empty-state{text-align:center;color:var(--color-text-secondary);padding:48px 20px}.empty-state .icon{margin-bottom:16px;font-size:48px}.empty-state p{font-size:14px}.page-title{color:var(--color-text);margin-bottom:20px;font-size:22px;font-weight:700}.stats-grid{grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:16px;margin-bottom:24px;display:grid}.stat-card{background:var(--color-card);border-radius:var(--radius);box-shadow:var(--shadow);border-left:4px solid var(--color-accent);padding:20px}.stat-card .stat-label{color:var(--color-text-secondary);text-transform:uppercase;letter-spacing:.5px;margin-bottom:8px;font-size:12px}.stat-card .stat-value{color:var(--color-text);font-size:28px;font-weight:700}.stat-card .stat-sub{color:var(--color-text-secondary);margin-top:4px;font-size:12px}.progress-bar{background:var(--color-border);border-radius:4px;width:100%;height:8px;overflow:hidden}.progress-bar .progress-fill{border-radius:4px;height:100%;transition:width .3s}.filters{flex-wrap:wrap;align-items:center;gap:10px;display:flex}.filters .form-control{width:auto;min-width:140px}@media (width<=768px){.main-content{padding:12px 8px}.stats-grid{grid-template-columns:1fr 1fr}.modal{border-radius:0;max-width:100%;min-height:100vh;margin:0}.modal-body{padding:12px}.data-table,.preview-table{white-space:nowrap;-webkit-overflow-scrolling:touch;display:block;overflow-x:auto}.data-table th,.data-table td,.preview-table th,.preview-table td{padding:6px 8px;font-size:11px}.form-row{grid-template-columns:1fr}.form-group input,.form-group select,.form-group textarea{font-size:16px}.sa-filter-bar{flex-wrap:wrap;gap:6px}.sa-filter-bar input{width:120px!important}.card{padding:12px}.card-header{padding:12px 0}.page-title{font-size:16px}.btn{min-height:36px;padding:6px 14px;font-size:13px}.btn-sm{min-height:30px;padding:4px 10px;font-size:11px}.pagination{gap:2px}.pagination button{padding:4px 8px;font-size:12px}.order-modal{max-width:100%!important}.preview-grid{grid-template-columns:1fr 1fr!important}.preview-section{padding:10px}.dash-stats{grid-template-columns:repeat(2,1fr);gap:8px}.dash-stat{padding:12px}.sa-chart-grid{grid-template-columns:1fr}.global-search-input{width:120px!important}}@media (width<=480px){.stats-grid{grid-template-columns:1fr}.dash-stats{grid-template-columns:1fr 1fr}.preview-grid,.sales-row-grid{grid-template-columns:1fr!important}.btn{width:100%}.sa-filter-bar{flex-direction:column}.sa-filter-bar input{width:100%!important}}@media print{.sidebar,.mobile-topbar,.sidebar-overlay,.modal-footer,.modal-close,.card-header .btn,.nav-menu,.global-search,.company-switcher,.sidebar-footer,.sidebar-user,.hamburger,.pagination,.sa-filter-bar,.stats-grid,button:not(.keep-print){display:none!important}.modal-overlay{background:0 0!important;position:static!important;overflow:visible!important}.modal,.order-modal{width:100%!important;max-width:100%!important;box-shadow:none!important;border:none!important;border-radius:0!important;margin:0!important;position:static!important}.modal-body{max-height:none!important;padding:0!important}.main-content{margin-top:0!important;margin-left:0!important;padding:0!important}.app-layout{display:block!important}.preview-table th,.preview-table td{padding:3px 6px!important;font-size:10px!important}img{max-width:100%}body>div[style*="z-index: 9999"]{display:none!important}}.app-layout{min-height:100vh;display:flex}.sidebar{color:#fff;z-index:100;background:linear-gradient(#1a2332 0%,#1e3a5f 100%);flex-direction:column;width:220px;display:flex;position:fixed;top:0;bottom:0;left:0;box-shadow:2px 0 12px #00000026}.sidebar-header{border-bottom:1px solid #ffffff1a;padding:16px 16px 10px}.logo{color:#fff;margin:0;font-size:18px;font-weight:700}.subtitle{color:#ffffff80;margin:2px 0 6px;font-size:11px}.company-switcher{align-items:center;gap:6px;margin-top:2px;display:flex}.company-label{font-size:14px}.company-select{color:#fff;cursor:pointer;background:#ffffff1a;border:1px solid #fff3;border-radius:4px;flex:1;min-width:0;padding:4px 8px;font-size:12px}.company-select:focus{border-color:#4fc3f7;outline:none}.company-select option{color:#fff;background:#1a2332}.global-search{margin-top:6px;position:relative}.global-search-input{color:#fff;background:#ffffff14;border:1px solid #ffffff26;border-radius:4px;outline:none;width:100%;padding:5px 8px;font-size:11px}.global-search-input::placeholder{color:#ffffff59}.global-search-input:focus{border-color:#4fc3f7}.global-search-results{z-index:300;background:#1a2332;border:1px solid #fff3;border-radius:4px;max-height:200px;margin-top:2px;position:absolute;top:100%;left:0;right:0;overflow-y:auto}.global-search-item{color:#fff;cursor:pointer;white-space:nowrap;text-overflow:ellipsis;padding:6px 10px;font-size:11px;overflow:hidden}.global-search-item:hover{background:#2c5282}.sidebar-user{background:#ffffff0d;border-bottom:1px solid #ffffff1a;align-items:center;gap:10px;padding:10px 16px;display:flex}.user-avatar{color:#1a2332;background:#4fc3f7;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:32px;height:32px;font-size:16px;font-weight:700;display:flex}.user-info{flex-direction:column;display:flex;overflow:hidden}.user-name{color:#fff;white-space:nowrap;text-overflow:ellipsis;font-size:13px;font-weight:600;overflow:hidden}.user-role{color:#ffffff80;font-size:11px}.nav-menu{flex-direction:column;flex:1;gap:0;min-height:0;padding:8px 0;display:flex;overflow:hidden auto}.nav-link{color:#ffffffbf;border-left:3px solid #0000;align-items:center;padding:10px 16px;font-size:14px;text-decoration:none;transition:all .2s;display:flex}.nav-link:hover{color:#fff;background:#ffffff14}.nav-link.active{color:#fff;background:#ffffff1f;border-left-color:#4fc3f7;font-weight:600}.nav-badge{color:#fff;background:#f56565;border-radius:9px;justify-content:center;align-items:center;min-width:20px;height:18px;margin-left:auto;padding:0 5px;font-size:10px;font-weight:700;display:flex}.sidebar-footer{color:#ffffff59;border-top:1px solid #ffffff1a;flex-shrink:0;padding:10px 16px;font-size:11px}.sidebar-footer p{margin:0}.logout-btn{color:#ffffffb3;cursor:pointer;background:#ffffff14;border:1px solid #ffffff26;border-radius:6px;width:100%;margin-bottom:8px;padding:8px 12px;font-size:12px;transition:all .2s;display:block}.logout-btn:hover{color:#feb2b2;background:#f565654d;border-color:#f5656580}.main-content{background:#f0f2f5;flex:1;min-height:100vh;margin-left:220px;padding:28px 32px}.mobile-topbar{color:#fff;z-index:200;background:linear-gradient(90deg,#1a2332 0%,#1e3a5f 100%);align-items:center;height:50px;padding:0 16px;display:none;position:fixed;top:0;left:0;right:0;box-shadow:0 2px 8px #00000026}.hamburger{cursor:pointer;background:0 0;border:none;flex-direction:column;gap:5px;margin-right:12px;padding:6px;display:flex}.hamburger span{background:#fff;border-radius:2px;width:22px;height:2px;transition:all .3s;display:block}.mobile-title{font-size:16px;font-weight:600}.mobile-logout{color:#fff;cursor:pointer;background:#ffffff1a;border:1px solid #fff3;border-radius:4px;margin-left:auto;padding:4px 10px;font-size:12px}.sidebar-overlay{display:none}.nav-menu::-webkit-scrollbar{width:4px}.nav-menu::-webkit-scrollbar-track{background:0 0}.nav-menu::-webkit-scrollbar-thumb{background:#fff3;border-radius:2px}@media (width<=768px){.mobile-topbar{display:flex}.sidebar-overlay{z-index:150;background:#0006;display:block;position:fixed;inset:0}.sidebar{z-index:160;height:auto;transition:transform .3s;top:50px;bottom:0;transform:translate(-100%)}.sidebar.open{transform:translate(0)}.main-content{margin-top:50px;margin-left:0;padding:16px 12px}.nav-link{padding:10px 14px;font-size:13px}}.login-page{background:linear-gradient(135deg,#1a2332 0%,#1e3a5f 50%,#2c5282 100%);justify-content:center;align-items:center;min-height:100vh;padding:20px;display:flex}.login-card{background:#fff;border-radius:12px;width:100%;max-width:400px;overflow:hidden;box-shadow:0 20px 60px #0000004d}.login-header{text-align:center;background:linear-gradient(#f7fafc 0%,#fff 100%);padding:32px 24px 20px}.login-icon{margin-bottom:8px;font-size:48px}.login-header h1{color:#1a2332;margin:0 0 4px;font-size:20px;font-weight:700}.login-sub{color:#718096;margin:0;font-size:13px}.login-form{padding:20px 24px 8px}.login-input{height:44px;font-size:15px}.login-error{color:#c53030;background:#fff5f5;border:1px solid #fed7d7;border-radius:6px;margin-bottom:16px;padding:10px 14px;font-size:13px}.login-btn{justify-content:center;width:100%;margin-top:4px;padding:12px;font-size:16px;font-weight:600}.login-btn:disabled{opacity:.7;cursor:not-allowed}.login-footer{text-align:center;border-top:1px solid #e2e8f0;margin-top:8px;padding:12px 24px 20px}.login-footer p{color:#a0aec0;margin-bottom:6px;font-size:12px}.demo-accounts{flex-direction:column;gap:2px;display:flex}.demo-accounts span{color:#718096;font-family:monospace;font-size:11px}:root{--gds-bg:#0f172a;--gds-surface:#1e293b;--gds-border:#334155;--gds-text:#e2e8f0;--gds-text-dim:#94a3b8;--gds-accent:#3b82f6;--gds-success:#22c55e;--gds-warning:#f59e0b;--gds-danger:#ef4444;--gds-toolbar-h:40px;--gds-statusbar-h:24px}.gds-app{background:var(--gds-bg);width:100vw;height:100vh;color:var(--gds-text);flex-direction:column;font-family:Segoe UI,Arial,sans-serif;font-size:13px;display:flex;overflow:hidden}.gds-loading{background:var(--gds-bg);width:100vw;height:100vh;color:var(--gds-accent);justify-content:center;align-items:center;font-size:16px;display:flex}.gds-designer{flex-direction:column;height:100vh;display:flex}.gds-designer-toolbar{height:var(--gds-toolbar-h);background:var(--gds-surface);border-bottom:1px solid var(--gds-border);flex-shrink:0;justify-content:space-between;align-items:center;padding:0 12px;display:flex}.gds-designer-toolbar-left,.gds-designer-toolbar-center,.gds-designer-toolbar-right{align-items:center;gap:4px;display:flex}.gds-designer-screen-name{color:var(--gds-text);margin-right:8px;font-weight:600}.gds-designer-screen-size{color:var(--gds-text-dim);font-size:11px}.gds-toolbar-btn{color:var(--gds-text-dim);cursor:pointer;background:0 0;border:1px solid #0000;border-radius:4px;padding:4px 10px;font-size:12px}.gds-toolbar-btn:hover:not(:disabled){color:var(--gds-text);background:#3b82f626}.gds-toolbar-btn:disabled{opacity:.4;cursor:default}.gds-toolbar-btn-primary{background:var(--gds-success);color:#fff;border-color:var(--gds-success);font-weight:600}.gds-toolbar-btn-primary:hover{background:#16a34a}.gds-toolbar-sep{background:var(--gds-border);width:1px;height:20px;margin:0 6px}.gds-toolbar-toggle{color:var(--gds-text-dim);cursor:pointer;align-items:center;gap:4px;font-size:12px;display:flex}.gds-designer-main{flex:1;display:flex;overflow:hidden}.gds-designer-statusbar{height:var(--gds-statusbar-h);background:var(--gds-surface);border-top:1px solid var(--gds-border);color:var(--gds-text-dim);flex-shrink:0;align-items:center;gap:16px;padding:0 12px;font-size:11px;display:flex}.gds-toolbox{background:var(--gds-surface);border-right:1px solid var(--gds-border);flex-direction:column;flex-shrink:0;width:200px;display:flex;overflow:hidden}.gds-toolbox-header{padding:8px}.gds-toolbox-title{margin-bottom:6px;font-size:13px;font-weight:600;display:block}.gds-toolbox-search{background:var(--gds-bg);border:1px solid var(--gds-border);width:100%;color:var(--gds-text);box-sizing:border-box;border-radius:4px;padding:4px 8px;font-size:12px}.gds-toolbox-categories{flex:1;overflow-y:auto}.gds-toolbox-cat-header{cursor:pointer;color:var(--gds-text-dim);align-items:center;gap:6px;padding:6px 10px;font-size:12px;font-weight:600;display:flex}.gds-toolbox-cat-header:hover{background:#3b82f61a}.gds-toolbox-cat-arrow{margin-left:auto;font-size:9px}.gds-toolbox-items{flex-wrap:wrap;gap:4px;padding:4px 8px;display:flex}.gds-toolbox-item{background:var(--gds-bg);border:1px solid var(--gds-border);cursor:grab;color:var(--gds-text-dim);border-radius:4px;align-items:center;gap:4px;padding:4px 8px;font-size:11px;transition:all .15s;display:flex}.gds-toolbox-item:hover{border-color:var(--gds-accent);color:var(--gds-text);background:#3b82f61a}.gds-toolbox-item:active{cursor:grabbing}.gds-toolbox-item-icon{font-size:14px}.gds-canvas-container{background:#111827;flex:1;position:relative;overflow:hidden}.gds-canvas-container svg{display:block}.gds-canvas-zoom-controls{z-index:10;background:var(--gds-surface);border:1px solid var(--gds-border);border-radius:6px;align-items:center;gap:4px;padding:4px 8px;display:flex;position:absolute;bottom:12px;right:12px}.gds-canvas-zoom-controls button{color:var(--gds-text);cursor:pointer;background:0 0;border:none;border-radius:3px;padding:2px 6px;font-size:14px;font-weight:700}.gds-canvas-zoom-controls button:hover{background:#3b82f633}.gds-canvas-zoom-controls span{color:var(--gds-text-dim);text-align:center;min-width:36px;font-size:11px}.gds-property-panel{background:var(--gds-surface);border-left:1px solid var(--gds-border);flex-direction:column;flex-shrink:0;width:240px;display:flex;overflow:hidden}.gds-property-empty{color:var(--gds-text-dim);text-align:center;padding:24px 16px;font-size:12px}.gds-property-header{border-bottom:1px solid var(--gds-border);justify-content:space-between;align-items:center;padding:8px 12px;display:flex}.gds-property-obj-name{font-size:13px;font-weight:600}.gds-property-obj-type{color:var(--gds-text-dim);background:var(--gds-bg);border-radius:3px;padding:2px 6px;font-size:10px}.gds-property-tabs{border-bottom:1px solid var(--gds-border);display:flex}.gds-property-tab{color:var(--gds-text-dim);cursor:pointer;background:0 0;border:none;border-bottom:2px solid #0000;flex:1;padding:6px 0;font-size:12px}.gds-property-tab.active{color:var(--gds-accent);border-bottom-color:var(--gds-accent)}.gds-property-tab:hover{color:var(--gds-text)}.gds-property-content{flex:1;overflow-y:auto}.gds-property-group{border-bottom:1px solid var(--gds-border)}.gds-property-group-title{color:var(--gds-text-dim);cursor:pointer;align-items:center;gap:4px;padding:6px 10px;font-size:11px;font-weight:600;display:flex}.gds-property-group-title:hover{background:#3b82f60d}.gds-property-group-content{padding:4px 10px 8px}.gds-prop-field{justify-content:space-between;align-items:center;gap:8px;padding:3px 0;display:flex}.gds-prop-label{color:var(--gds-text-dim);min-width:40px;font-size:11px}.gds-prop-input{background:var(--gds-bg);border:1px solid var(--gds-border);width:100px;color:var(--gds-text);border-radius:3px;padding:2px 6px;font-size:11px}.gds-prop-input[type=color]{cursor:pointer;width:32px;height:22px;padding:1px}.gds-prop-checkbox{cursor:pointer;width:auto}.gds-property-events{padding:8px}.gds-property-event{border-bottom:1px solid var(--gds-border);justify-content:space-between;align-items:center;gap:8px;padding:6px 8px;display:flex}.gds-event-label{color:var(--gds-text-dim);min-width:100px;font-family:monospace;font-size:11px}.gds-event-action{background:var(--gds-bg);border:1px solid var(--gds-border);color:var(--gds-text);border-radius:3px;flex:1;padding:3px 6px;font-size:11px}.gds-property-bindings{padding:8px}.gds-binding-item{background:var(--gds-bg);border:1px solid var(--gds-border);border-radius:4px;margin-bottom:4px;padding:6px 8px;font-size:11px}.gds-btn-add-binding{width:100%;color:var(--gds-accent);border:1px dashed var(--gds-accent);background:#3b82f61a;margin-top:8px;font-size:11px}.gds-runtime-wrapper{flex-direction:column;height:100vh;display:flex}.gds-runtime-toolbar{color:#fff;background:#dc2626;flex-shrink:0;justify-content:space-between;align-items:center;height:32px;padding:0 12px;font-size:12px;display:flex}.gds-btn-stop{color:#fff;cursor:pointer;background:#fff3;border:1px solid #ffffff4d;border-radius:3px;padding:2px 12px;font-size:11px}.gds-runtime{flex-direction:column;flex:1;display:flex;overflow:hidden}.gds-runtime-empty{color:var(--gds-text-dim);flex:1;justify-content:center;align-items:center;font-size:16px;display:flex}.gds-runtime-header{background:var(--gds-surface);border-bottom:1px solid var(--gds-border);flex-shrink:0;justify-content:space-between;align-items:center;height:36px;padding:0 12px;display:flex}.gds-runtime-nav-left{align-items:center;gap:8px;font-size:12px;display:flex}.gds-runtime-project{color:var(--gds-accent);font-weight:600}.gds-runtime-divider{color:var(--gds-border)}.gds-runtime-nav-center{gap:2px;display:flex}.gds-runtime-nav-btn{color:var(--gds-text-dim);cursor:pointer;background:0 0;border:none;border-bottom:2px solid #0000;padding:6px 12px;font-size:12px}.gds-runtime-nav-btn.active{color:var(--gds-accent);border-bottom-color:var(--gds-accent)}.gds-runtime-nav-btn:hover{color:var(--gds-text)}.gds-runtime-nav-right{color:var(--gds-text-dim);font-size:13px}.gds-runtime-canvas{flex:1;overflow:hidden}.gds-alarm-bar{background:var(--gds-surface);border-top:1px solid var(--gds-border);flex-shrink:0;align-items:center;gap:12px;height:32px;padding:0 12px;font-size:12px;display:flex}.gds-alarm-bar-left{flex-shrink:0;align-items:center;gap:8px;display:flex}.gds-alarm-bar-blink{color:#ef4444;font-weight:600;animation:1s infinite alarm-blink}@keyframes alarm-blink{0%,to{opacity:1}50%{opacity:.4}}.gds-alarm-bar-count{color:var(--gds-text-dim);font-size:11px}.gds-alarm-bar-scroll{flex:1;gap:16px;display:flex;overflow:hidden}.gds-alarm-bar-item{white-space:nowrap;font-size:11px}.gds-alarm-bar-item.severity-hh{color:#ef4444}.gds-alarm-bar-item.severity-h{color:#f59e0b}.gds-alarm-bar-item.severity-l{color:#3b82f6}.gds-alarm-bar-item.severity-ll{color:#ef4444}.gds-alarm-bar-right{flex-shrink:0}.gds-alarm-bar-btn{color:#ef4444;cursor:pointer;background:#ef444426;border:1px solid #ef44444d;border-radius:3px;padding:2px 8px;font-size:11px}.gds-runtime-label{font-weight:600}.gds-btn{cursor:pointer;border:1px solid var(--gds-border);background:var(--gds-surface);color:var(--gds-text);border-radius:4px;padding:4px 10px;font-size:12px;display:inline-block}.gds-btn:hover{background:#3b82f633}.dash-stats{grid-template-columns:repeat(4,1fr);gap:10px;margin-bottom:12px;display:grid}.dash-stat{text-align:center;border-radius:8px;padding:10px 8px}.stat-today{background:#ebf8ff}.stat-overdue{background:#fff5f5}.stat-pending{background:#fffbeb}.stat-done{background:#f0fff4}.stat-num{font-size:22px;font-weight:800}.stat-today .stat-num{color:#2c5282}.stat-overdue .stat-num{color:#c53030}.stat-pending .stat-num{color:#975a16}.stat-done .stat-num{color:#276749}.stat-label{color:#718096;margin-top:4px;font-size:11px}.cal-header{grid-template-columns:repeat(7,1fr);gap:2px;margin-bottom:2px;display:grid}.cal-hd-cell{text-align:center;color:#718096;padding:6px 0;font-size:11px;font-weight:700}.cal-grid{grid-template-columns:repeat(7,1fr);gap:2px;display:grid}.cal-cell{background:#fff;border:1px solid #edf2f7;border-radius:6px;min-height:72px;padding:4px 5px;overflow:hidden}.cal-cell.empty{background:#f7fafc;border-color:#0000}.cal-cell.today{border-width:2px;border-color:#4fc3f7;box-shadow:0 0 0 2px #4fc3f733}.cal-day{color:#2d3748;margin-bottom:4px;font-size:12px;font-weight:700}.cal-cell.today .cal-day{color:#2c5282}.cal-tasks{flex-direction:column;gap:1px;display:flex}.cal-task{align-items:center;gap:3px;padding:1px 0;font-size:10px;display:flex;position:relative}.cal-task:hover .cal-task-del{display:inline-flex}.cal-task.done{opacity:.5}.cal-task.done .cal-task-text{text-decoration:line-through}.cal-task.overdue .cal-task-text{color:#e53e3e;font-weight:600}.cal-task-dot{background:#4fc3f7;border-radius:50%;flex-shrink:0;width:5px;height:5px}.cal-task-dot.indie{background:#ed8936}.cal-task.overdue .cal-task-dot{background:#e53e3e}.cal-task-text{text-overflow:ellipsis;white-space:nowrap;overflow:hidden}.cal-task-del{color:#fff;text-align:center;cursor:pointer;background:#e53e3e;border:none;border-radius:50%;flex-shrink:0;width:14px;height:14px;margin-left:auto;padding:0;font-size:9px;line-height:14px;display:none}.cal-task-del:hover{background:#c53030}.cal-more{color:#a0aec0;text-align:center;font-size:9px}@media (width<=768px){.dash-stats{grid-template-columns:repeat(2,1fr)}.cal-cell{min-height:56px}}.form-row{grid-template-columns:1fr 1fr;gap:0 12px;display:grid}@media (width<=600px){.form-row{grid-template-columns:1fr}}.order-table th,.order-table td{white-space:nowrap}.order-modal{max-width:950px!important}.order-tabs{border-bottom:2px solid var(--color-border);gap:0;padding:0 24px;display:flex;overflow-x:auto}.order-tab{cursor:pointer;color:var(--color-text-secondary);white-space:nowrap;background:0 0;border:none;border-bottom:2px solid #0000;margin-bottom:-2px;padding:10px 14px;font-size:13px;transition:all .2s}.order-tab:hover{color:var(--color-text)}.order-tab.active{color:var(--color-primary);border-bottom-color:var(--color-primary);font-weight:600}.section-header{justify-content:space-between;align-items:center;margin-bottom:12px;font-size:14px;font-weight:600;display:flex}.sales-row{border:1px solid var(--color-border);background:#fafbfc;border-radius:8px;margin-bottom:10px;padding:12px}.sales-row-header{color:var(--color-primary);margin-bottom:8px;font-size:13px;font-weight:700}.sales-row-grid{grid-template-columns:repeat(auto-fill,minmax(160px,1fr));gap:8px;display:grid}@media (width<=600px){.sales-row-grid{grid-template-columns:1fr 1fr}}.totals-bar{background:#eef2ff;border-radius:6px;gap:24px;margin-top:12px;padding:10px 14px;font-size:13px;display:flex}.totals-bar strong{font-size:15px}.payment-row{align-items:center;gap:6px;margin-bottom:6px;display:flex}.payment-row .form-control{flex:1;min-width:0}.share-row{align-items:center;gap:6px;margin-bottom:6px;display:flex}.share-row .form-control{flex:1;min-width:0}.table-wrapper td{text-overflow:ellipsis;white-space:nowrap;max-width:200px;overflow:hidden}.preview-section{border-bottom:1px solid var(--color-border);margin-bottom:16px;padding-bottom:12px}.preview-section h4{margin-bottom:8px;font-size:14px;font-weight:600}.preview-grid{grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:8px;display:grid}.preview-grid div{flex-direction:column;display:flex}.preview-grid span{color:var(--color-text-secondary);font-size:11px}.preview-grid strong{font-size:13px}.preview-table{border-collapse:collapse;width:100%;font-size:12px}.preview-table th{text-align:left;border-bottom:2px solid var(--color-border);white-space:nowrap;background:#f7fafc;padding:6px 8px;font-weight:600}.preview-table td{border-bottom:1px solid var(--color-border);padding:6px 8px}.customer-fieldset{border:1px solid var(--color-border);border-radius:8px;margin-bottom:16px;padding:16px}.customer-fieldset legend{color:var(--color-text);padding:0 8px;font-size:13px;font-weight:600}.product-thumb{object-fit:cover;border:1px solid var(--color-border);border-radius:4px;width:48px;height:48px}.no-image{opacity:.3;font-size:20px}.image-upload-row{align-items:center;gap:12px;display:flex}.image-upload-btn{border:2px dashed var(--color-border);cursor:pointer;width:80px;height:80px;color:var(--color-text-secondary);border-radius:8px;justify-content:center;align-items:center;font-size:13px;transition:border-color .2s;display:inline-flex}.image-upload-btn:hover{border-color:var(--color-accent);color:var(--color-accent)}.image-preview{flex-direction:column;align-items:center;gap:6px;display:inline-flex;position:relative}.image-preview img{object-fit:cover;border:1px solid var(--color-border);border-radius:8px;width:80px;height:80px}.image-hint{color:var(--color-text-secondary);font-size:11px}.p-card{padding:18px 20px}.p-card-hd{justify-content:space-between;align-items:flex-start;gap:12px;margin-bottom:14px;display:flex}.p-card-hd h3{margin:0 0 4px;font-size:15px;font-weight:700}.p-meta{color:#718096;flex-wrap:wrap;gap:12px;font-size:11px;display:flex}.p-prog{align-items:center;gap:10px;margin-bottom:14px;display:flex}.t-grid{border-top:1px solid #e2e8f0;grid-template-columns:repeat(auto-fill,minmax(260px,1fr));gap:4px;padding-top:12px;display:grid}.t-chip{cursor:pointer;border-radius:6px;align-items:center;gap:6px;padding:6px 8px;font-size:12px;transition:background .15s;display:flex}.t-chip:hover{background:#f7fafc}.t-chip.done .t-text{color:#a0aec0;text-decoration:line-through}.t-text{flex:1;min-width:80px}.t-person{color:#718096;white-space:nowrap;background:#edf2f7;border-radius:4px;padding:1px 6px;font-size:10px}.t-date{color:#a0aec0;white-space:nowrap;font-size:10px}.task-editor{border:1px solid #e2e8f0;border-radius:6px;max-height:300px;padding:8px;overflow-y:auto}.te-row{align-items:center;gap:4px;margin-bottom:4px;display:flex}.te-row .form-control{margin-bottom:0;padding:4px 6px;font-size:12px}@media print{body *{visibility:hidden}.modal-overlay,.modal-overlay *{visibility:visible}.modal-overlay{position:absolute;top:0;left:0;background:#fff!important}.modal{box-shadow:none!important;max-width:100%!important;margin:0!important}.modal-header{border-bottom:2px solid #000!important}.modal-footer,.modal-close,.btn{display:none!important}table{border-collapse:collapse;width:100%}th,td{border:1px solid #ccc;padding:4px 6px;font-size:11px}@page{margin:1cm;size:A4}}.finance-tabs{border-bottom:2px solid var(--color-border);flex-wrap:wrap;gap:4px;margin-bottom:20px;padding-bottom:0;display:flex}.finance-tab{cursor:pointer;color:var(--color-text-secondary);white-space:nowrap;background:0 0;border:none;border-bottom:2px solid #0000;margin-bottom:-2px;padding:8px 14px;font-size:13px;transition:all .2s}.finance-tab:hover{color:var(--color-text)}.finance-tab.active{color:var(--color-primary);border-bottom-color:var(--color-primary);font-weight:600}.stats-grid{grid-template-columns:repeat(4,1fr);gap:10px;display:grid}.stat-card{background:#fff;border:1px solid #edf2f7;border-left:4px solid #4fc3f7;border-radius:8px;padding:14px 16px}.stat-label{color:#718096;margin-bottom:4px;font-size:12px}.stat-value{font-size:22px;font-weight:800}.stat-sub{color:#a0aec0;margin-top:2px;font-size:11px}@media (width<=768px){.finance-tab{padding:8px 10px;font-size:11px}.stats-grid{grid-template-columns:repeat(2,1fr)}.stat-value{font-size:18px}}.sa-filter-bar{background:#fff;border-radius:8px;flex-wrap:wrap;align-items:center;gap:8px;margin-bottom:14px;padding:10px 16px;display:flex;box-shadow:0 1px 3px #0000000f}.sa-filter-bar .form-control{margin-bottom:0;padding:5px 8px;font-size:12px}.sa-kpi-grid{grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:14px;margin-bottom:18px;display:grid}.sa-kpi{background:#fff;border-top:3px solid #4fc3f7;border-radius:8px;padding:18px 20px;box-shadow:0 1px 3px #0000000f}.sa-kpi-label{color:#718096;text-transform:uppercase;letter-spacing:.8px;margin-bottom:6px;font-size:11px}.sa-kpi-value{color:#1a2332;font-size:26px;font-weight:800}.sa-kpi-sub{color:#a0aec0;margin-top:4px;font-size:11px}.sa-chart-grid{grid-template-columns:1fr 1fr;gap:14px;margin-bottom:14px;display:grid}@media (width<=900px){.sa-chart-grid{grid-template-columns:1fr}}.sa-card{background:#fff;border-radius:8px;padding:20px;box-shadow:0 1px 3px #0000000f}.sa-card h3{color:#1a2332;margin:0 0 14px;font-size:14px;font-weight:700}.chart-card{min-height:320px}.metric-toggle{border:1px solid #e2e8f0;border-radius:6px;display:flex;overflow:hidden}.toggle-btn{cursor:pointer;color:#718096;background:#fff;border:none;padding:5px 14px;font-size:12px;transition:all .2s}.toggle-btn.active{color:#fff;background:#1a2332}.bar-chart{border-bottom:2px solid #e2e8f0;align-items:flex-end;gap:4px;height:220px;padding:0 4px 20px;display:flex}.bar-col{flex-direction:column;flex:1;justify-content:flex-end;align-items:center;height:100%;display:flex;position:relative}.bar-value{color:#718096;white-space:nowrap;margin-bottom:2px;font-family:monospace;font-size:8px}.bar-fill{border-radius:4px 4px 0 0;justify-content:center;align-items:flex-start;width:100%;max-width:40px;min-height:2px;padding-top:4px;transition:height .3s;display:flex;position:relative}.bar-count{color:#fffc;font-size:9px}.bar-label{color:#a0aec0;margin-top:4px;font-size:9px}.bar-growth{white-space:nowrap;margin-top:2px;font-size:8px}.hbar-chart{flex-direction:column;gap:8px;display:flex}.hbar-row{align-items:center;gap:8px;display:flex}.hbar-label{color:#1a2332;align-items:center;gap:4px;min-width:60px;font-size:11px;font-weight:600;display:flex}.hbar-track{background:#f0f2f5;border-radius:4px;flex:1;height:22px;overflow:hidden}.hbar-fill{border-radius:4px;align-items:center;min-width:0;height:100%;padding:0 8px;transition:width .5s;display:flex}.hbar-val{color:#fff;white-space:nowrap;font-size:10px;font-weight:600}.hbar-extra{color:#a0aec0;text-align:right;white-space:nowrap;min-width:80px;font-size:10px}.rank-num{color:#fff;border-radius:50%;justify-content:center;align-items:center;width:20px;height:20px;font-size:10px;font-weight:700;display:inline-flex}.status-pie{flex-direction:column;gap:8px;display:flex}.pie-row{align-items:center;gap:8px;display:flex}.pie-label{align-items:center;gap:4px;min-width:60px;font-size:11px;font-weight:600;display:flex}.pie-dot{border-radius:50%;width:8px;height:8px;display:inline-block}.pie-bar-bg{background:#f0f2f5;border-radius:3px;flex:1;height:16px;overflow:hidden}.pie-bar{border-radius:3px;height:100%;transition:width .5s}.pie-num{color:#718096;text-align:right;min-width:70px;font-size:10px}.empty-month td{color:#a0aec0!important}.cust-chip{cursor:pointer;white-space:nowrap;background:#ebf8ff;border:1px solid #bee3f8;border-radius:20px;align-items:center;gap:6px;padding:6px 12px;transition:all .15s;display:inline-flex}.cust-chip:hover{background:#bee3f8;transform:translateY(-1px)}.cust-chip.inactive{background:#fff5f5;border-color:#fed7d7}.cust-chip.inactive:hover{background:#fed7d7}.cust-chip-code{color:#2c5282;font-family:monospace;font-size:10px;font-weight:700}.cust-chip.inactive .cust-chip-code{color:#c53030}.cust-chip-name{color:#2d3748;text-overflow:ellipsis;max-width:80px;font-size:11px;overflow:hidden}.cust-chip-count{color:#48bb78;font-size:10px;font-weight:600}.cust-chip-count.zero{color:#e53e3e;animation:1.5s infinite blink}@keyframes blink{0%,to{opacity:1}50%{opacity:.4}}.contract-preview-doc{color:#1a202c;background:#fff;border:1px solid #e2e8f0;max-width:750px;margin:0 auto;padding:20px 22px;font-size:12px;line-height:1.6;box-shadow:0 2px 12px #00000014}.contract-preview-doc h1{margin:0 0 4px;font-size:20px}.contract-preview-doc h3{border-bottom:1px solid #e2e8f0;margin:0 0 6px;padding-bottom:4px;font-size:14px}.contract-preview-doc p{margin:2px 0}.contract-section{margin-bottom:14px}.contract-form .form-group{margin-bottom:8px}.contract-form .form-row{gap:12px;display:flex}.contract-form .form-row>.form-group{flex:1}.modal-wide{width:95%;max-width:750px}.quotation-preview-doc{color:#1a202c;background:#fff;border:1px solid #e2e8f0;max-width:750px;margin:0 auto;padding:22px 24px;font-size:12px;line-height:1.6;box-shadow:0 2px 12px #00000014}.quotation-preview-doc h1{margin:0 0 2px;font-size:22px}.card-header{justify-content:space-between;align-items:center;margin-bottom:14px;display:flex}.card-header h2{margin:0;font-size:16px}
