*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}.mobile-topbar{display:none}.sidebar-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#00000080;z-index:149}.sidebar-close-btn{display:none;background:none;border:none;color:#94a3b8;font-size:24px;cursor:pointer;line-height:1;padding:0 4px;margin-left:auto}@media (max-width: 768px){.mobile-topbar{display:flex;align-items:center;justify-content:space-between;padding:12px 16px;background:#1e293b;position:sticky;top:0;z-index:100}.mobile-logo{font-size:15px;font-weight:700;color:#fff}.hamburger{display:flex;flex-direction:column;gap:5px;background:none;border:none;cursor:pointer;padding:4px;width:40px}.hamburger span{display:block;height:2px;background:#fff;border-radius:2px;width:100%}.sidebar{transform:translate(-240px);transition:transform .25s ease;z-index:150}.sidebar.open{transform:translate(0)}.sidebar-logo{display:flex;align-items:center}.sidebar-close-btn{display:block}.main-content{margin-left:0}.page-header{flex-wrap:wrap;gap:10px;padding:12px 16px;position:static}.page-title{font-size:16px}.page-body{padding:14px 16px}.order-detail-grid{grid-template-columns:1fr}.chat-section{position:static;height:70vh;min-height:400px}.status-stepper{overflow-x:auto;flex-wrap:nowrap}.status-step{flex:0 0 auto;font-size:11px;padding:8px 10px;white-space:nowrap}.order-card{flex-wrap:wrap;gap:10px;padding:12px 14px}.order-stats{order:3}.filter-tabs{flex-wrap:nowrap;overflow-x:auto;padding-bottom:4px;-webkit-overflow-scrolling:touch}.filter-tab{flex:0 0 auto;white-space:nowrap}.stats-grid{grid-template-columns:repeat(2,1fr)}.analytics-grid{grid-template-columns:1fr}.bar-label{width:110px}.modal{max-width:100%;border-radius:12px;padding:20px;margin:0}.modal-overlay{padding:12px;align-items:flex-end}.modal{border-radius:16px 16px 0 0;max-height:95vh}.card:has(table){overflow-x:auto}.table th,.table td{padding:10px 12px;white-space:nowrap}.view-toggle-btn{padding:5px 10px;font-size:12px}.kanban-column{flex:0 0 200px}.btn{padding:7px 12px;font-size:13px}.btn-sm{padding:4px 8px;font-size:12px}.chat-input-area{padding:8px 10px;gap:6px}.file-item{flex-wrap:wrap;gap:8px}.file-item>div:last-child{width:100%;justify-content:flex-end}.info-row{margin-bottom:12px}}.view-toggle{display:flex;border:1px solid var(--border);border-radius:8px;overflow:hidden}.view-toggle-btn{padding:6px 14px;font-size:13px;font-weight:500;border:none;background:var(--surface);color:var(--muted);cursor:pointer;transition:background .15s,color .15s}.view-toggle-btn:first-child{border-right:1px solid var(--border)}.view-toggle-btn.active{background:var(--primary);color:#fff}.kanban-board{display:flex;gap:12px;overflow-x:auto;padding-bottom:20px;align-items:flex-start;min-height:calc(100vh - 200px)}.kanban-column{flex:0 0 240px;background:var(--bg);border-radius:12px;padding:12px;min-height:200px;border:2px solid transparent;transition:border-color .15s,background .15s}.kanban-column.drag-over{border-color:var(--primary);background:#eff6ff}.kanban-column-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:10px;padding:0 2px}.kanban-count{font-size:12px;font-weight:700;color:var(--muted);background:var(--surface);padding:2px 8px;border-radius:12px;border:1px solid var(--border)}.kanban-cards{display:flex;flex-direction:column;gap:8px;min-height:60px}.kanban-empty{text-align:center;color:#cbd5e1;font-size:12px;padding:20px 0;border:2px dashed #e2e8f0;border-radius:8px}.kanban-card{background:var(--surface);border:1px solid var(--border);border-radius:10px;padding:12px;cursor:grab;transition:box-shadow .15s,opacity .15s,transform .1s;-webkit-user-select:none;user-select:none}.kanban-card:hover{box-shadow:0 4px 14px #0000001a;transform:translateY(-1px)}.kanban-card.dragging{opacity:.35;cursor:grabbing;transform:rotate(1.5deg)}.kanban-card-id{font-size:11px;color:var(--muted);margin-bottom:4px}.kanban-card-title{font-weight:600;font-size:13px;line-height:1.35;margin-bottom:6px;color:var(--text)}.kanban-card-material{font-size:11px;color:var(--muted);margin-bottom:8px;background:var(--bg);padding:3px 7px;border-radius:5px;display:inline-block}.kanban-card-footer{display:flex;justify-content:space-between;align-items:center;margin-top:8px;font-size:11px;color:var(--muted)}.kanban-card-author{font-weight:500;font-size:11px}.kanban-card-assignee{font-size:11px;color:var(--primary);margin-bottom:6px}.file-drop-zone{border:2px dashed var(--border);border-radius:8px;padding:16px;text-align:center;color:var(--muted);font-size:13px;cursor:pointer;transition:border-color .15s,background .15s;margin-bottom:8px}.file-drop-zone:hover,.file-drop-zone.drag-over{border-color:var(--primary);background:#eff6ff;color:var(--primary)}.file-list-preview{display:flex;flex-direction:column;gap:5px}.file-preview-item{display:flex;align-items:center;gap:8px;padding:6px 10px;background:var(--bg);border-radius:6px;font-size:13px}.file-preview-name{flex:1;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.file-preview-size{color:var(--muted);font-size:11px;flex-shrink:0}.file-preview-remove{border:none;background:none;color:var(--muted);cursor:pointer;font-size:18px;line-height:1;padding:0 2px;flex-shrink:0}.file-preview-remove:hover{color:var(--danger)}.assigned-badge{background:#ede9fe;color:#6d28d9;padding:1px 8px;border-radius:12px;font-weight:500}.assigned-badge-lg{background:#ede9fe;color:#6d28d9;padding:3px 12px;border-radius:12px;font-weight:600;font-size:14px}.stats-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:12px;margin-bottom:16px}.stat-card{background:var(--surface);border:1px solid var(--border);border-radius:12px;padding:20px}.stat-number{font-size:38px;font-weight:800;line-height:1;margin-bottom:6px}.stat-label{font-weight:600;font-size:13px;color:var(--text)}.stat-sub{font-size:12px;color:var(--muted);margin-top:3px}.analytics-grid{display:grid;grid-template-columns:1fr 1fr;gap:16px}@media (max-width: 900px){.analytics-grid{grid-template-columns:1fr}}.bar-chart{display:flex;flex-direction:column;gap:10px}.bar-row{display:flex;align-items:center;gap:10px}.bar-label{width:160px;flex-shrink:0}.bar-track{flex:1;height:26px;background:var(--bg);border-radius:6px;overflow:hidden}.bar-fill{height:100%;border-radius:6px;display:flex;align-items:center;padding-left:8px;font-size:12px;font-weight:700;color:#fff;transition:width .6s ease;min-width:0}.bar-count{font-size:14px;font-weight:700;width:28px;text-align:right;flex-shrink:0}.day-chart{display:flex;gap:6px;align-items:flex-end;height:160px;padding-bottom:24px;position:relative}.day-col{flex:1;display:flex;flex-direction:column;align-items:center;height:100%}.day-bar-wrap{flex:1;width:100%;display:flex;align-items:flex-end}.day-bar{width:100%;background:var(--primary);border-radius:4px 4px 0 0;min-height:0;transition:height .4s ease;position:relative;display:flex;align-items:flex-start;justify-content:center}.day-bar-val{font-size:10px;font-weight:700;color:#fff;padding-top:3px}.day-label{font-size:9px;color:var(--muted);text-align:center;position:absolute;bottom:0;white-space:nowrap}:root{--primary: #2563eb;--primary-dark: #1d4ed8;--primary-light: #dbeafe;--bg: #f1f5f9;--surface: #ffffff;--border: #e2e8f0;--text: #1e293b;--muted: #64748b;--danger: #ef4444;--danger-light: #fee2e2;--success: #10b981;--sidebar-bg: #1e293b}body{font-family:Inter,system-ui,-apple-system,sans-serif;background:var(--bg);color:var(--text);font-size:14px;line-height:1.5}.layout{display:flex;min-height:100vh}.sidebar{width:240px;background:var(--sidebar-bg);display:flex;flex-direction:column;position:fixed;top:0;left:0;height:100vh;z-index:50}.sidebar-logo{padding:20px 16px;font-size:16px;font-weight:700;color:#fff;border-bottom:1px solid rgba(255,255,255,.1);letter-spacing:-.3px}.sidebar-nav{flex:1;padding:10px 8px;display:flex;flex-direction:column;gap:2px}.sidebar-link{display:flex;align-items:center;gap:10px;padding:9px 12px;border-radius:8px;color:#94a3b8;text-decoration:none;font-size:14px;font-weight:500;transition:background .15s,color .15s;cursor:pointer}.sidebar-link:hover{background:#ffffff12;color:#e2e8f0}.sidebar-link.active{background:var(--primary);color:#fff}.sidebar-bottom{padding:14px;border-top:1px solid rgba(255,255,255,.1)}.user-info{display:flex;align-items:center;gap:10px;margin-bottom:10px}.user-avatar{width:34px;height:34px;border-radius:50%;background:var(--primary);display:flex;align-items:center;justify-content:center;color:#fff;font-weight:700;font-size:13px;flex-shrink:0}.user-name{color:#e2e8f0;font-weight:500;font-size:13px}.user-role{color:#64748b;font-size:11px}.logout-btn{display:flex;align-items:center;gap:8px;color:#64748b;cursor:pointer;font-size:13px;padding:6px 4px;border-radius:6px;transition:color .15s}.logout-btn:hover{color:#fff}.main-content{margin-left:240px;flex:1;display:flex;flex-direction:column;min-height:100vh}.page-header{background:var(--surface);border-bottom:1px solid var(--border);padding:14px 24px;display:flex;align-items:center;justify-content:space-between;position:sticky;top:0;z-index:40}.page-title{font-size:18px;font-weight:700}.page-body{padding:20px 24px;flex:1}.btn{display:inline-flex;align-items:center;gap:6px;padding:8px 16px;border-radius:8px;font-size:14px;font-weight:500;border:none;cursor:pointer;transition:background .15s,opacity .15s;text-decoration:none;white-space:nowrap}.btn:disabled{opacity:.6;cursor:not-allowed}.btn-primary{background:var(--primary);color:#fff}.btn-primary:hover:not(:disabled){background:var(--primary-dark)}.btn-secondary{background:var(--surface);color:var(--text);border:1px solid var(--border)}.btn-secondary:hover:not(:disabled){background:var(--bg)}.btn-danger{background:var(--danger);color:#fff}.btn-danger:hover:not(:disabled){background:#dc2626}.btn-sm{padding:5px 10px;font-size:12px}.card{background:var(--surface);border:1px solid var(--border);border-radius:12px;padding:20px}.form-group{margin-bottom:16px}.form-label{display:block;font-weight:500;margin-bottom:5px;font-size:13px}.form-control{width:100%;padding:8px 12px;border:1px solid var(--border);border-radius:8px;font-size:14px;font-family:inherit;color:var(--text);background:var(--surface);transition:border-color .15s,box-shadow .15s}.form-control:focus{outline:none;border-color:var(--primary);box-shadow:0 0 0 3px #2563eb1f}textarea.form-control{resize:vertical;min-height:80px}select.form-control{-webkit-appearance:none;-moz-appearance:none;appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' fill='none' viewBox='0 0 20 20'%3E%3Cpath stroke='%236b7280' stroke-linecap='round' stroke-linejoin='round' stroke-width='1.5' d='m6 8 4 4 4-4'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 10px center;background-size:16px;padding-right:32px;cursor:pointer}.error-msg{color:var(--danger);font-size:13px;margin-top:6px}.badge{display:inline-flex;align-items:center;padding:3px 10px;border-radius:20px;font-size:12px;font-weight:600}.badge-new{background:#f1f5f9;color:#475569}.badge-accepted{background:#dbeafe;color:#1d4ed8}.badge-manufacturing{background:#fef3c7;color:#b45309}.badge-qc{background:#ede9fe;color:#6d28d9}.badge-ready{background:#d1fae5;color:#065f46}.badge-shipped{background:#e5e7eb;color:#374151}.role-badge{font-size:11px;font-weight:600;padding:2px 8px;border-radius:12px}.role-admin{background:#fee2e2;color:#991b1b}.role-manager{background:#dbeafe;color:#1d4ed8}.role-production{background:#d1fae5;color:#065f46}.table{width:100%;border-collapse:collapse}.table th{text-align:left;padding:10px 16px;font-weight:600;color:var(--muted);font-size:11px;text-transform:uppercase;letter-spacing:.06em;border-bottom:1px solid var(--border)}.table td{padding:12px 16px;border-bottom:1px solid var(--border)}.table tr:last-child td{border-bottom:none}.table tbody tr:hover td{background:var(--bg)}.modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#0f172a80;display:flex;align-items:center;justify-content:center;z-index:100;padding:20px;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px)}.modal{background:var(--surface);border-radius:16px;padding:24px;width:100%;max-width:520px;max-height:90vh;overflow-y:auto}.modal-title{font-size:17px;font-weight:700;margin-bottom:20px}.modal-actions{display:flex;gap:10px;justify-content:flex-end;margin-top:20px}.filter-tabs{display:flex;gap:6px;margin-bottom:14px;flex-wrap:wrap}.filter-tab{padding:5px 14px;border-radius:20px;font-size:13px;font-weight:500;cursor:pointer;border:1px solid var(--border);background:var(--surface);color:var(--muted);transition:all .15s}.filter-tab:hover{border-color:var(--primary);color:var(--primary)}.filter-tab.active{background:var(--primary);color:#fff;border-color:var(--primary)}.order-list{display:flex;flex-direction:column;gap:6px}.order-card{background:var(--surface);border:1px solid var(--border);border-radius:10px;padding:14px 18px;display:flex;align-items:center;gap:14px;cursor:pointer;transition:border-color .15s,box-shadow .15s;text-decoration:none;color:inherit}.order-card:hover{border-color:var(--primary);box-shadow:0 2px 10px #2563eb1a}.order-info{flex:1;min-width:0}.order-title{font-weight:600;font-size:14px;margin-bottom:3px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.order-meta{font-size:12px;color:var(--muted);display:flex;flex-wrap:wrap;gap:10px}.order-stats{display:flex;gap:10px;align-items:center;color:var(--muted);font-size:13px;flex-shrink:0}.order-detail-grid{display:grid;grid-template-columns:1fr 360px;gap:18px;align-items:start}.status-stepper{display:flex;overflow:hidden;border:1px solid var(--border);border-radius:10px}.status-step{flex:1;padding:9px 6px;text-align:center;cursor:pointer;font-size:12px;font-weight:500;color:var(--muted);background:var(--surface);border:none;border-right:1px solid var(--border);transition:background .15s,color .15s}.status-step:last-child{border-right:none}.status-step:hover{background:var(--bg)}.status-step.active{font-weight:700}.status-step.active.s-new{background:#f1f5f9;color:#475569}.status-step.active.s-accepted{background:#dbeafe;color:#1d4ed8}.status-step.active.s-manufacturing{background:#fef3c7;color:#b45309}.status-step.active.s-qc{background:#ede9fe;color:#6d28d9}.status-step.active.s-ready{background:#d1fae5;color:#065f46}.status-step.active.s-shipped{background:#e5e7eb;color:#374151}.status-step.done{opacity:.55}.chat-section{background:var(--surface);border:1px solid var(--border);border-radius:12px;display:flex;flex-direction:column;height:calc(100vh - 130px);position:sticky;top:74px}.chat-header{border-bottom:1px solid var(--border);font-weight:600;font-size:14px;flex-shrink:0;display:flex}.chat-tab{flex:1;padding:13px 10px;border:none;background:none;font-size:13px;font-weight:500;color:var(--muted);cursor:pointer;border-bottom:2px solid transparent;transition:color .15s,border-color .15s;display:flex;align-items:center;justify-content:center;gap:6px}.chat-tab:hover{color:var(--text)}.chat-tab.active{color:var(--primary);border-bottom-color:var(--primary)}.chat-tab-count{background:var(--border);color:var(--muted);font-size:11px;font-weight:700;padding:1px 6px;border-radius:10px}.chat-tab.active .chat-tab-count{background:var(--primary-light);color:var(--primary)}.chat-messages{flex:1;overflow-y:auto;padding:14px;display:flex;flex-direction:column;gap:10px}.msg{display:flex;flex-direction:column;gap:2px}.msg.system{align-items:center;margin:4px 0}.msg-row{display:flex;align-items:flex-end;gap:8px}.msg-row-own{display:flex;align-items:flex-end;gap:8px;justify-content:flex-end}.msg-content{display:flex;flex-direction:column;gap:2px;max-width:72%}.msg-content-own{display:flex;flex-direction:column;gap:2px;max-width:72%;align-items:flex-end}.msg-name{font-size:11px;font-weight:600;color:var(--muted);margin-bottom:1px;padding-left:2px}.msg-bubble{padding:8px 12px;border-radius:14px;font-size:13.5px;line-height:1.45;word-break:break-word}.msg:not(.own):not(.system) .msg-bubble{background:#f1f5f9;border-bottom-left-radius:4px}.msg.own .msg-bubble{background:var(--primary);color:#fff;border-bottom-right-radius:4px}.msg.system .msg-bubble{background:#fef9c3;color:#713f12;font-size:12px;border-radius:20px;padding:4px 14px}.msg-time{font-size:10px;color:var(--muted);padding:0 2px}.chat-input-area{padding:10px 14px;border-top:1px solid var(--border);display:flex;gap:8px;flex-shrink:0;align-items:flex-end}.chat-input{flex:1;padding:8px 12px;border:1px solid var(--border);border-radius:8px;font-size:13.5px;font-family:inherit;resize:none;max-height:120px;background:var(--bg)}.chat-input:focus{outline:none;border-color:var(--primary);box-shadow:0 0 0 3px #2563eb1a}.history-list{display:flex;flex-direction:column;gap:2px}.history-item{display:flex;gap:10px;padding:10px 4px;border-bottom:1px solid var(--border)}.history-item:last-child{border-bottom:none}.history-icon{font-size:16px;flex-shrink:0;width:24px;text-align:center;margin-top:1px}.history-body{flex:1;min-width:0}.history-text{font-size:13px;line-height:1.4;margin-bottom:4px;word-break:break-word}.history-meta{display:flex;align-items:center;gap:5px;font-size:11px;color:var(--muted)}.file-item{display:flex;align-items:center;gap:10px;padding:9px 12px;border:1px solid var(--border);border-radius:8px;margin-bottom:6px}.file-icon{font-size:22px;flex-shrink:0}.file-info{flex:1;min-width:0}.file-name{font-weight:500;font-size:13px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.file-meta{font-size:11px;color:var(--muted)}.empty-state{text-align:center;padding:60px 20px;color:var(--muted)}.empty-state-icon{font-size:48px;margin-bottom:12px}.login-page{min-height:100vh;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,#0f172a,#1e3a5f)}.login-card{background:var(--surface);border-radius:20px;padding:40px;width:100%;max-width:400px;box-shadow:0 25px 50px #0006}.login-logo{font-size:28px;font-weight:800;margin-bottom:6px}.login-sub{color:var(--muted);margin-bottom:28px;font-size:14px}.toast{position:fixed;top:20px;right:20px;background:#1e293b;color:#fff;padding:12px 20px;border-radius:10px;font-size:14px;z-index:200;box-shadow:0 8px 24px #0000004d;animation:toastIn .25s ease;max-width:320px}@keyframes toastIn{0%{transform:translateY(-12px);opacity:0}to{transform:translateY(0);opacity:1}}::-webkit-scrollbar{width:5px}::-webkit-scrollbar-track{background:transparent}::-webkit-scrollbar-thumb{background:#cbd5e1;border-radius:3px}::-webkit-scrollbar-thumb:hover{background:#94a3b8}.info-row{margin-bottom:14px}.info-label{font-size:11px;color:var(--muted);font-weight:500;text-transform:uppercase;letter-spacing:.05em;margin-bottom:3px}.info-value{font-size:14px}
