:root{--text-main:#374151;--text-muted:#6b7280;--text-heading:#111827;--bg-app:#f9fafb;--bg-card:#fff;--bg-sidebar:#111;--accent:#f59e0b;--accent-hover:#d97706;--border-color:#e5e7eb;--success:#10b981;--warning:#f59e0b;--danger:#ef4444;--info:#3b82f6;--sans:"Inter", system-ui, -apple-system, sans-serif;--heading:"Outfit", "Inter", system-ui, sans-serif;--mono:ui-monospace, SFMono-Regular, Menlo, Monaco, Consolas, monospace;font-family:var(--sans);--lightningcss-light:initial;--lightningcss-dark: ;color-scheme:light;color:var(--text-main);background-color:var(--bg-app)}body{margin:0;padding:0;overflow-x:hidden}#root{box-sizing:border-box;min-height:100vh;display:flex}*{box-sizing:border-box}h1,h2,h3,h4,h5,h6{font-family:var(--heading);color:var(--text-heading);margin-top:0}.app-container{background-color:var(--bg-app);width:100%;min-height:100vh;display:flex}.sidebar{background-color:var(--bg-sidebar);color:#fff;border-right:1px solid #222;flex-direction:column;flex-shrink:0;justify-content:space-between;width:260px;padding:24px 16px;display:flex}.sidebar-brand{border-bottom:1px solid #222;align-items:center;gap:12px;padding:8px 12px 24px;display:flex}.brand-logo{background:radial-gradient(circle,#f59e0b 0%,#d97706 100%);border-radius:50% 50% 0;width:32px;height:32px;display:inline-block;transform:rotate(-45deg);box-shadow:0 0 10px #f59e0b66}.brand-text{font-family:var(--heading);letter-spacing:-.5px;font-size:18px;font-weight:700;line-height:1.1}.brand-subtext{color:var(--text-muted);text-transform:uppercase;letter-spacing:1px;font-size:10px;font-weight:600}.sidebar-nav{flex-direction:column;flex-grow:1;gap:6px;margin-top:24px;display:flex}.nav-item{color:#ccc;cursor:pointer;text-align:left;background:0 0;border:none;border-radius:8px;align-items:center;gap:12px;width:100%;padding:12px 16px;font-size:14px;font-weight:500;text-decoration:none;transition:all .2s;display:flex}.nav-item:hover{color:#fff;background-color:#222}.nav-item.active{color:var(--accent);border-left:3px solid var(--accent);background-color:#f59e0b26;padding-left:13px;font-weight:600}.sidebar-footer{border-top:1px solid #222;flex-direction:column;gap:16px;padding-top:16px;display:flex}.system-status{background-color:#1a1a1a;border-radius:8px;padding:10px 12px;font-size:12px}.status-indicator{align-items:center;gap:8px;margin-bottom:6px;font-weight:600;display:flex}.status-dot{background-color:var(--success);width:8px;height:8px;box-shadow:0 0 8px var(--success);border-radius:50%;display:inline-block}.status-dot.pulse{animation:2s infinite pulse-green}@keyframes pulse-green{0%{box-shadow:0 0 #10b981b3}70%{box-shadow:0 0 0 6px #10b98100}to{box-shadow:0 0 #10b98100}}.status-chart{align-items:flex-end;gap:2px;height:18px;margin-top:8px;display:flex}.status-chart-bar{opacity:.7;background-color:#22c55e;border-radius:1px;flex-grow:1}.user-profile{background-color:#1a1a1a;border-radius:8px;align-items:center;gap:12px;padding:8px;display:flex}.avatar{color:#fff;background-color:#374151;border-radius:50%;justify-content:center;align-items:center;width:36px;height:36px;font-size:14px;font-weight:700;display:flex}.user-info{flex-direction:column;display:flex}.user-name{font-size:13px;font-weight:600}.user-role{color:var(--text-muted);font-size:11px}.main-workspace{flex-direction:column;flex-grow:1;min-width:0;height:100vh;display:flex;overflow-y:auto}.app-header{background-color:var(--bg-card);border-bottom:1px solid var(--border-color);flex-shrink:0;justify-content:space-between;align-items:center;padding:16px 32px;display:flex}.header-welcome h1{letter-spacing:-.5px;margin-bottom:2px;font-size:24px;font-weight:600}.header-welcome p{color:var(--text-muted);font-size:14px}.header-actions{align-items:center;gap:20px;display:flex}.search-container{width:260px;position:relative}.search-input{border:1px solid var(--border-color);background-color:#f3f4f6;border-radius:8px;outline:none;width:100%;padding:8px 12px 8px 36px;font-size:13px;transition:all .2s}.search-input:focus{border-color:var(--accent);background-color:#fff;box-shadow:0 0 0 3px #f59e0b26}.search-icon{color:var(--text-muted);font-size:14px;position:absolute;top:50%;left:12px;transform:translateY(-50%)}.date-selector{border:1px solid var(--border-color);color:var(--text-main);cursor:pointer;background-color:#f3f4f6;border-radius:8px;align-items:center;gap:8px;padding:8px 14px;font-size:13px;font-weight:500;display:flex}.notification-bell{color:var(--text-main);cursor:pointer;background:0 0;border:none;border-radius:50%;padding:6px;font-size:18px;transition:background-color .2s;position:relative}.notification-bell:hover{background-color:#f3f4f6}.bell-badge{background-color:var(--danger);color:#fff;border-radius:50%;justify-content:center;align-items:center;width:15px;height:15px;font-size:9px;font-weight:700;display:flex;position:absolute;top:4px;right:4px}.dashboard-content{flex-direction:column;gap:24px;padding:24px 32px;display:flex}.flow-container{align-items:center;gap:16px;margin-bottom:8px;display:flex}.flow-card{background-color:var(--bg-card);border:1px solid var(--border-color);border-radius:12px;flex:1;align-items:center;gap:16px;padding:16px 20px;transition:all .2s;display:flex;position:relative;box-shadow:0 1px 3px #0000000d}.flow-card:hover{transform:translateY(-2px);box-shadow:0 4px 6px #0000000d}.flow-icon-container{width:48px;height:48px;color:var(--accent);background-color:#f59e0b1a;border-radius:50%;justify-content:center;align-items:center;font-size:20px;display:flex}.flow-card.blue .flow-icon-container{color:var(--info);background-color:#3b82f61a}.flow-card.green .flow-icon-container{color:var(--success);background-color:#10b9811a}.flow-details h3{color:var(--text-muted);text-transform:uppercase;letter-spacing:.5px;margin-bottom:2px;font-size:13px;font-weight:500}.flow-value{font-size:24px;font-weight:700;line-height:1.1;font-family:var(--heading)}.flow-status{align-items:center;gap:6px;margin-top:4px;font-size:12px;font-weight:500;display:flex}.flow-arrow{color:var(--text-muted);font-size:20px}.metrics-row{grid-template-columns:repeat(auto-fit,minmax(160px,1fr));gap:16px;display:grid}.metric-widget{background-color:var(--bg-card);border:1px solid var(--border-color);border-radius:10px;flex-direction:column;justify-content:space-between;padding:14px 16px;display:flex;box-shadow:0 1px 2px #00000005}.metric-widget-header{color:var(--text-muted);text-transform:uppercase;letter-spacing:.5px;justify-content:space-between;align-items:center;margin-bottom:8px;font-size:11px;font-weight:500;display:flex}.metric-widget-header .icon{opacity:.8;font-size:14px}.metric-value-container{justify-content:space-between;align-items:baseline;display:flex}.metric-val{font-size:20px;font-weight:700;font-family:var(--heading)}.metric-change{align-items:center;gap:2px;font-size:11px;font-weight:600;display:flex}.metric-change.up{color:var(--success)}.metric-change.down{color:var(--danger)}.live-lines-section{grid-template-columns:1fr 1fr;gap:24px;display:grid}.line-card{background-color:var(--bg-card);border:1px solid var(--border-color);border-radius:12px;overflow:hidden;box-shadow:0 2px 4px #00000008}.line-video-container{color:#fff;background-color:#222;justify-content:center;align-items:center;height:200px;display:flex;position:relative}.line-placeholder-img{object-fit:cover;opacity:.8;width:100%;height:100%}.live-badge{text-transform:uppercase;letter-spacing:1px;color:#fff;background-color:#000000b3;border-radius:4px;align-items:center;gap:6px;padding:4px 8px;font-size:10px;font-weight:700;display:flex;position:absolute;top:16px;left:16px}.live-dot{background-color:var(--danger);border-radius:50%;width:6px;height:6px;animation:1s infinite blink}@keyframes blink{50%{opacity:0}}.line-info-overlay{color:#fff;background:linear-gradient(#0000,#000000d9);padding:20px 16px 12px;position:absolute;bottom:0;left:0;right:0}.line-title{font-size:16px;font-weight:600;font-family:var(--heading);margin-bottom:2px}.line-status-text{opacity:.9;align-items:center;gap:6px;font-size:12px;display:flex}.line-status-indicator{background-color:var(--success);border-radius:50%;width:6px;height:6px}.line-card-footer{border-top:1px solid var(--border-color);background-color:#fafafa;justify-content:space-between;align-items:center;padding:16px;font-size:13px;display:flex}.line-stat-item{flex-direction:column;display:flex}.line-stat-label{color:var(--text-muted);text-transform:uppercase;margin-bottom:2px;font-size:11px}.line-stat-value{font-weight:600}.dashboard-details-grid{grid-template-columns:2fr 1fr 1fr;gap:24px;display:grid}@media (width<=1200px){.dashboard-details-grid,.live-lines-section{grid-template-columns:1fr}}.details-card{background-color:var(--bg-card);border:1px solid var(--border-color);border-radius:12px;flex-direction:column;padding:20px;display:flex;box-shadow:0 1px 3px #00000005}.details-card-header{justify-content:space-between;align-items:center;margin-bottom:16px;display:flex}.details-card-title{margin:0;font-size:16px;font-weight:600}.table-responsive{width:100%;overflow-x:auto}.custom-table{border-collapse:collapse;text-align:left;width:100%;font-size:13px}.custom-table th{border-bottom:1px solid var(--border-color);color:var(--text-muted);text-transform:uppercase;letter-spacing:.5px;padding:12px;font-size:10px;font-weight:500}.custom-table td{border-bottom:1px solid var(--border-color);vertical-align:middle;padding:12px}.custom-table tbody tr:hover{background-color:#fafafa}.badge{border-radius:6px;align-items:center;padding:4px 8px;font-size:11px;font-weight:600;display:inline-flex}.badge-completed{color:var(--success);background-color:#10b9811a}.badge-progress{color:var(--info);background-color:#3b82f61a}.badge-cancelled{color:var(--text-muted);background-color:#9ca3af1a}.badge-qc{color:var(--warning);background-color:#f59e0b1a}.badge-danger{color:var(--danger);background-color:#ef44441a}.view-btn{color:var(--text-muted);cursor:pointer;background:0 0;border:none;border-radius:4px;padding:4px;font-size:16px;transition:all .2s}.view-btn:hover{color:var(--accent);background-color:#f59e0b1a}.donut-chart-container{flex-direction:column;flex-grow:1;justify-content:center;align-items:center;padding:16px 0;display:flex;position:relative}.donut-center-text{text-align:center;position:absolute;top:50%;left:50%;transform:translate(-50%,-50%)}.donut-label{color:var(--text-muted);text-transform:uppercase;font-size:10px}.donut-val{color:var(--text-heading);font-size:18px;font-weight:700}.donut-unit{color:var(--text-muted);font-size:11px}.chart-legend{flex-direction:column;gap:8px;width:100%;margin-top:16px;display:flex}.legend-item{justify-content:space-between;align-items:center;font-size:12px;display:flex}.legend-color-label{align-items:center;gap:8px;display:flex}.legend-dot{border-radius:50%;width:8px;height:8px}.legend-value{font-weight:600}.trend-chart-wrapper{flex-direction:column;flex-grow:1;justify-content:space-between;height:100%;display:flex}.chart-select{border:1px solid var(--border-color);cursor:pointer;background:0 0;border-radius:6px;outline:none;padding:4px 8px;font-size:11px;font-weight:500}.bar-chart-visual{border-bottom:1px solid var(--border-color);justify-content:space-between;align-items:flex-end;height:120px;padding:10px 0;display:flex}.bar-column{flex-direction:column;align-items:center;gap:6px;width:10%;display:flex}.bar-fill-wrapper{background-color:#f3f4f6;border-radius:3px;align-items:flex-end;width:14px;height:90px;display:flex;position:relative}.bar-fill-wrapper:hover:after{content:attr(data-tooltip);color:#fff;white-space:nowrap;background-color:#111;border-radius:3px;padding:2px 4px;font-size:9px;position:absolute;top:-24px;left:50%;transform:translate(-50%)}.bar-fill{background:linear-gradient(#f59e0b,#d97706);border-radius:3px;width:100%}.bar-label{color:var(--text-muted);font-size:10px}.wo-tab-container{flex-direction:column;gap:24px;padding:24px 32px;display:flex}.wo-tab-header{justify-content:space-between;align-items:center;display:flex}.tab-title-desc h2{margin-bottom:4px;font-size:22px;font-weight:600}.tab-title-desc p{color:var(--text-muted);font-size:14px}.primary-btn{background-color:var(--accent);color:#111;cursor:pointer;border:none;border-radius:8px;align-items:center;gap:8px;padding:10px 18px;font-size:13px;font-weight:600;transition:all .2s;display:flex}.primary-btn:hover{background-color:var(--accent-hover)}.secondary-btn{border:1px solid var(--border-color);color:var(--text-main);cursor:pointer;background-color:#fff;border-radius:8px;padding:8px 14px;font-size:13px;font-weight:500;transition:all .2s}.secondary-btn:hover{background-color:#f9fafb;border-color:#d1d5db}.wo-grid{grid-template-columns:1fr;gap:20px;display:grid}.wo-card-container{background-color:var(--bg-card);border:1px solid var(--border-color);border-radius:12px;flex-direction:column;gap:16px;padding:20px;display:flex;box-shadow:0 1px 3px #00000005}.wo-card-header{border-bottom:1px solid var(--border-color);justify-content:space-between;align-items:flex-start;padding-bottom:14px;display:flex}.wo-card-title-block{align-items:center;gap:12px;display:flex}.wo-card-icon{width:40px;height:40px;color:var(--text-muted);background-color:#f3f4f6;border-radius:8px;justify-content:center;align-items:center;font-size:20px;display:flex}.wo-card-id-block h3{font-size:15px;font-weight:600;font-family:var(--sans);margin:0}.wo-card-id-block p{color:var(--text-muted);font-size:12px}.wo-metadata-grid{grid-template-columns:repeat(4,1fr);gap:16px;font-size:13px;display:grid}.metadata-item{flex-direction:column;display:flex}.metadata-label{color:var(--text-muted);text-transform:uppercase;margin-bottom:4px;font-size:11px}.metadata-value{font-weight:600}.wo-progress-section{flex-direction:column;gap:6px;font-size:12px;display:flex}.progress-info{justify-content:space-between;font-weight:500;display:flex}.progress-bar-bg{background-color:#f3f4f6;border-radius:4px;height:8px;overflow:hidden}.progress-bar-fill{background-color:var(--accent);border-radius:4px;height:100%;transition:width .4s cubic-bezier(.4,0,.2,1)}.job-cards-section{border-top:1px solid var(--border-color);padding-top:16px}.section-subtitle{margin-bottom:12px;font-size:14px;font-weight:600}.jc-item-row{border-bottom:1px solid var(--border-color);grid-template-columns:50px 2fr 1.5fr 1fr 1.2fr;align-items:center;padding:12px;font-size:13px;display:grid}.jc-item-row:hover{background-color:#fafafa}.jc-index{color:#fff;background-color:#111;border-radius:4px;justify-content:center;align-items:center;width:24px;height:24px;font-size:11px;font-weight:700;display:flex}.jc-op-details h4{font-size:13px;font-weight:600;font-family:var(--sans);margin-bottom:2px}.jc-op-details p{color:var(--text-muted);font-size:11px}.jc-status-badge{justify-self:start}.jc-actions{justify-content:flex-end;gap:8px;display:flex}.action-btn-small{cursor:pointer;border:1px solid #0000;border-radius:6px;padding:6px 12px;font-size:12px;font-weight:600;transition:all .2s}.action-btn-small.start{background-color:var(--accent);color:#111}.action-btn-small.complete{color:var(--success);background-color:#10b98126;border-color:#10b9814d}.action-btn-small.complete:hover{background-color:var(--success);color:#fff}.action-btn-small.remarks{border-color:var(--border-color);color:var(--text-muted);background-color:#0000}.action-btn-small.remarks:hover{color:var(--text-main);background-color:#f3f4f6}.inv-tab-container{flex-direction:column;gap:24px;padding:24px 32px;display:flex}.inv-summary-grid{grid-template-columns:repeat(3,1fr);gap:24px;display:grid}.inv-summary-card{background-color:var(--bg-card);border:1px solid var(--border-color);border-radius:12px;align-items:center;gap:16px;padding:20px;display:flex;box-shadow:0 1px 3px #00000005}.inv-card-icon{border-radius:10px;justify-content:center;align-items:center;width:48px;height:48px;font-size:22px;display:flex}.inv-card-icon.rm{color:var(--info);background-color:#3b82f61a}.inv-card-icon.pk{color:var(--accent);background-color:#f59e0b1a}.inv-card-icon.fg{color:var(--success);background-color:#10b9811a}.inv-card-info h3{color:var(--text-muted);text-transform:uppercase;margin-bottom:2px;font-size:13px;font-weight:500}.inv-card-info p{font-size:22px;font-weight:700;font-family:var(--heading)}.inv-search-bar{justify-content:space-between;align-items:center;gap:16px;display:flex}.inv-filters{gap:8px;display:flex}.filter-btn{border:1px solid var(--border-color);cursor:pointer;background-color:#fff;border-radius:6px;padding:6px 12px;font-size:12px;font-weight:500;transition:all .2s}.filter-btn.active{background-color:var(--accent);border-color:var(--accent);color:#111;font-weight:600}.stock-bar-container{align-items:center;gap:10px;width:140px;display:flex}.stock-bar-bg{background-color:#f3f4f6;border-radius:3px;flex-grow:1;height:6px}.stock-bar-fill{border-radius:3px;height:100%}.stock-bar-fill.normal{background-color:var(--success)}.stock-bar-fill.warning{background-color:var(--warning)}.stock-bar-fill.low{background-color:var(--danger)}.stock-alert-text{font-size:11px;font-weight:600}.stock-alert-text.low{color:var(--danger)}.stock-alert-text.warning{color:var(--warning)}.stock-alert-text.normal{color:var(--success)}.bom-tab-container{flex-direction:column;gap:24px;padding:24px 32px;display:flex}.bom-explorer-grid{grid-template-columns:1fr 2fr;gap:24px;display:grid}.bom-list{background-color:var(--bg-card);border:1px solid var(--border-color);border-radius:12px;overflow:hidden;box-shadow:0 1px 3px #00000005}.bom-list-header{border-bottom:1px solid var(--border-color);background-color:#fafafa;padding:16px 20px;font-weight:600}.bom-list-item{border-bottom:1px solid var(--border-color);cursor:pointer;padding:16px 20px;transition:all .2s}.bom-list-item:hover{background-color:#f9fafb}.bom-list-item.active{border-left:4px solid var(--accent);background-color:#f59e0b14;padding-left:16px}.bom-list-item-title{margin-bottom:4px;font-size:14px;font-weight:600}.bom-list-item-code{color:var(--text-muted);font-size:12px}.bom-recipe-panel{background-color:var(--bg-card);border:1px solid var(--border-color);border-radius:12px;padding:20px;box-shadow:0 1px 3px #00000005}.drawer-backdrop{z-index:1000;background-color:#0006;justify-content:flex-end;display:flex;position:fixed;inset:0}.drawer-panel{background-color:var(--bg-card);flex-direction:column;width:460px;height:100%;animation:.3s cubic-bezier(.4,0,.2,1) slideIn;display:flex;box-shadow:-4px 0 12px #00000026}@keyframes slideIn{0%{transform:translate(100%)}to{transform:translate(0)}}.drawer-header{border-bottom:1px solid var(--border-color);justify-content:space-between;align-items:center;padding:20px;display:flex}.drawer-header h3{margin:0;font-size:18px;font-weight:600}.drawer-close-btn{cursor:pointer;color:var(--text-muted);background:0 0;border:none;font-size:20px}.drawer-close-btn:hover{color:var(--text-heading)}.drawer-content{flex-grow:1;padding:20px;overflow-y:auto}.drawer-footer{border-top:1px solid var(--border-color);justify-content:flex-end;gap:12px;padding:20px;display:flex}.form-group{flex-direction:column;gap:6px;margin-bottom:18px;display:flex}.form-group label{color:var(--text-main);text-transform:uppercase;font-size:12px;font-weight:600}.form-input{border:1px solid var(--border-color);border-radius:8px;outline:none;padding:10px 12px;font-size:13px;transition:all .2s}.form-input:focus{border-color:var(--accent);box-shadow:0 0 0 3px #f59e0b26}.modal-backdrop{z-index:1001;background-color:#00000080;justify-content:center;align-items:center;display:flex;position:fixed;inset:0}.modal-panel{background-color:var(--bg-card);border-radius:12px;width:500px;animation:.2s ease-out fadeIn;overflow:hidden;box-shadow:0 4px 12px #00000026}@keyframes fadeIn{0%{opacity:0;transform:scale(.95)}to{opacity:1;transform:scale(1)}}.modal-header{border-bottom:1px solid var(--border-color);justify-content:space-between;align-items:center;padding:16px 20px;font-weight:600;display:flex}.modal-content{padding:20px}.modal-footer{border-top:1px solid var(--border-color);justify-content:flex-end;gap:12px;padding:16px 20px;display:flex}.workflow-steps-scroll{gap:12px;margin-top:12px;padding-bottom:8px;display:flex;overflow-x:auto}.workflow-step-card{background-color:var(--bg-card);border:1px solid var(--border-color);border-radius:8px;flex:0 0 160px;padding:10px;font-size:11px}.workflow-step-card-header{justify-content:space-between;align-items:center;margin-bottom:6px;font-weight:600;display:flex}.workflow-step-num{background-color:#f3f4f6;border-radius:50%;justify-content:center;align-items:center;width:18px;height:18px;display:flex}.login-page{z-index:1000;background:linear-gradient(135deg,#f8fafc 0%,#e2e8f0 50%,#cbd5e1 100%);justify-content:center;align-items:center;display:flex;position:fixed;inset:0;overflow:hidden}.login-bg-decorations{pointer-events:none;position:absolute;inset:0}.login-blob{filter:blur(100px);opacity:.15;border-radius:50%;animation:25s infinite alternate float-blob;position:absolute}.login-blob-1{background:#f59e0b;width:600px;height:600px;top:-15%;left:-15%}.login-blob-2{background:#3b82f6;width:500px;height:500px;animation-delay:6s;bottom:-15%;right:-15%}@keyframes float-blob{0%{transform:translate(0)scale(1)}50%{transform:translate(40px,-50px)scale(1.05)}to{transform:translate(0)scale(1)}}.login-card{-webkit-backdrop-filter:blur(16px);z-index:10;width:100%;max-width:440px;color:var(--text-main);background:#ffffffd9;border:1px solid #f59e0b26;border-radius:20px;flex-direction:column;gap:20px;padding:36px;animation:.5s cubic-bezier(.16,1,.3,1) slide-up;display:flex;position:relative;box-shadow:0 20px 40px -15px #0000001a}@keyframes slide-up{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.login-logo{align-items:center;gap:12px;font-size:24px;font-weight:800;display:flex}.login-header h2{letter-spacing:-.5px;margin-top:6px;margin-bottom:2px;font-size:22px;font-weight:700}.login-header p{color:var(--text-muted);margin-top:4px;margin-bottom:0;font-size:13px}.login-form{flex-direction:column;gap:16px;display:flex}.input-wrapper{align-items:center;display:flex;position:relative}.input-icon{color:var(--accent);pointer-events:none;position:absolute;left:14px}.form-input-icon{width:100%;color:var(--text-main);background:#ffffffb3;border:1px solid #cbd5e1;border-radius:8px;outline:none;padding:10px 12px 10px 40px;font-size:14px;transition:all .2s}.form-input-icon:focus{border-color:var(--accent);background:#fff;box-shadow:0 0 0 3px #f59e0b26}.advanced-settings-toggle{color:var(--text-muted);cursor:pointer;justify-content:space-between;align-items:center;padding:8px 0;font-size:12px;font-weight:700;transition:color .2s;display:flex}.advanced-settings-toggle:hover{color:var(--accent-hover)}.advanced-settings-panel{background:#00000005;border:1px solid #cbd5e1;border-radius:8px;flex-direction:column;gap:12px;padding:14px;animation:.3s cubic-bezier(.16,1,.3,1) expand;display:flex}@keyframes expand{0%{opacity:0;transform:translateY(-8px)}to{opacity:1;transform:translateY(0)}}.btn-primary-login{color:#fff;text-align:center;background:#111;border-radius:9999px;justify-content:center;align-items:center;gap:8px;padding:10px 20px;font-weight:600;transition:all .2s;display:flex}.btn-primary-login:hover{background:#2a2a2a}.btn-secondary-login{border:1px solid var(--border-color);color:var(--text-main);text-align:center;background:0 0;border-radius:9999px;padding:9px 18px;font-weight:600;transition:all .2s}.btn-secondary-login:hover{background:#00000005}.totp-icon-header{margin:0 auto 12px}.totp-error-alert{color:#ef4444;borderRadius:12px;fontSize:13px;background-color:#ef44441a;border:1px solid #ef444433;align-items:center;gap:8px;padding:12px;display:flex}.qr-container{background-color:#fff;border-radius:8px;justify-content:center;margin-bottom:12px;padding:12px;display:flex}.qr-code-img{width:160px;height:160px}.secret-display-box{background-color:#f3f4f6;border-radius:6px;margin-bottom:16px;padding:10px;font-size:12px}.secret-key-wrapper{justify-content:space-between;align-items:center;margin-top:4px;display:flex}.secret-key-text{font-family:var(--mono);font-weight:700}.btn-copy{cursor:pointer;background:0 0;border:none;font-size:14px}.btn-back{color:var(--text-muted);cursor:pointer;background:0 0;border:none;align-self:flex-start;align-items:center;gap:4px;font-size:12px;display:flex}.btn-back:hover{color:var(--text-heading)}.text-center{text-align:center}.letter-spacing-lg{letter-spacing:4px;font-size:20px;font-weight:700}.employee-dropdown-item:hover{color:#111!important;background-color:#f3f4f6!important}@media (width<=768px){.app-container{flex-direction:column}.sidebar{z-index:2000;width:280px;transition:transform .3s cubic-bezier(.4,0,.2,1);top:0;bottom:0;left:0;transform:translate(-100%);box-shadow:4px 0 24px #0006;position:fixed!important}.sidebar.mobile-open{transform:translate(0)!important}.main-workspace{min-height:calc(100vh - 60px);padding-top:60px;height:auto!important}.app-header{flex-direction:column;align-items:flex-start;gap:12px;padding:12px 16px!important}.header-welcome h1{font-size:18px!important}.metrics-grid,.dashboard-grid,.bom-explorer-grid,.wo-grid{grid-template-columns:1fr!important}.jc-item-row{grid-template-columns:30px 1.5fr 1fr 1.2fr!important;padding:8px 4px!important;font-size:11px!important}.jc-actions{flex-wrap:wrap;justify-content:flex-start;gap:4px}.action-btn-small{padding:4px 8px!important;font-size:10px!important}.modal-panel{max-height:90vh;margin:10px auto;overflow-y:auto;width:95%!important;max-width:95%!important;padding:16px!important}.modal-content{max-height:70vh!important}.custom-table{font-size:11px!important}.mobile-header-bar{background-color:var(--bg-sidebar);z-index:1999;border-bottom:1px solid #222;justify-content:space-between;align-items:center;height:60px;padding:0 16px;position:fixed;top:0;left:0;right:0;display:flex!important}.mobile-menu-btn{color:#fff;cursor:pointer;background:0 0;border:none;justify-content:center;align-items:center;padding:8px;font-size:24px;display:flex}.sidebar-backdrop{z-index:1998;background-color:#00000080;position:fixed;inset:0;display:block!important}}.mobile-header-bar,.sidebar-backdrop{display:none}.dash-animation{stroke-linecap:round;stroke-dasharray:8 12;animation:.8s linear infinite dash-flow}@keyframes dash-flow{0%{stroke-dashoffset:20px}to{stroke-dashoffset:0}}.workflow-node-card.passed{opacity:.85;background-color:#0f172a59!important;border-color:#ffffff26!important}.workflow-diagram-board{background-color:#090d16;background-image:linear-gradient(#ffffff05 1px,#0000 1px),linear-gradient(90deg,#ffffff05 1px,#0000 1px);background-size:30px 30px;border:1px solid #ffffff14;border-radius:16px;width:100%;margin:24px 0;padding:48px 24px;position:relative;overflow:hidden;box-shadow:inset 0 0 45px #000c}.workflow-pipelines-svg{pointer-events:none;z-index:1;width:100%;height:100%;position:absolute;top:0;left:0}.workflow-grid-container{z-index:2;grid-template-rows:repeat(3,140px);grid-template-columns:repeat(4,1fr);gap:36px 24px;display:grid;position:relative}.workflow-node-pod{cursor:pointer;justify-content:center;align-items:center;transition:all .3s cubic-bezier(.4,0,.2,1);display:flex;position:relative;box-shadow:0 4px 15px #0006}.workflow-node-capsule:hover .workflow-node-pod{transform:scale(1.1)translateY(-3px);box-shadow:0 10px 25px #ffffff26;border-color:#fff6!important}.workflow-pointer-tag{color:#0b0f19;letter-spacing:.8px;text-transform:uppercase;white-space:nowrap;border-radius:12px;padding:3px 10px;font-size:8px;font-weight:800;animation:1.2s ease-in-out infinite alternate float-tag;position:absolute;box-shadow:0 3px 8px #0006}@keyframes float-tag{0%{transform:translate(-50%)}to{transform:translate(-50%,-4px)}}@keyframes pulse-glow{0%{opacity:.5;transform:scale(.9)}to{opacity:.9;transform:scale(1.15)}}@media (width<=900px){.workflow-pipelines-svg{display:none}.workflow-grid-container{flex-direction:column;align-items:center;gap:30px;display:flex}.workflow-node-capsule{background-color:#0f172a4d;border:1px solid #ffffff0d;border-radius:14px;gap:20px;width:100%;padding:12px 20px;flex-direction:row!important;grid-area:auto!important;justify-content:flex-start!important;transform:none!important}.workflow-node-label{text-align:left!important;margin-top:0!important}.workflow-diagram-board{background-size:20px 20px;padding:24px 16px}.workflow-pointer-tag{margin-left:auto;animation:none!important;position:relative!important;bottom:auto!important;left:auto!important;transform:none!important}}.feed-scanline{opacity:.85;z-index:5;pointer-events:none;background:linear-gradient(90deg,#0000,#0f0c,#0000);height:2px;animation:4s linear infinite cctv-scan;position:absolute;top:0;left:0;right:0;box-shadow:0 0 10px #00ff00e6}@keyframes cctv-scan{0%{top:0%}50%{top:100%}to{top:0%}}.feed-noise{pointer-events:none;z-index:4;opacity:.7;background:repeating-linear-gradient(0deg,#ffffff08,#ffffff08 1px,#0000 1px 3px);position:absolute;inset:0}.feed-hud{pointer-events:none;z-index:6;position:absolute;inset:0}.hud-box{border:1.5px solid #00ff00b3;animation:1.5s infinite alternate pulse-hud;position:absolute;box-shadow:0 0 6px #00ff004d}@keyframes pulse-hud{0%{border-color:#0f06;box-shadow:0 0 3px #0f03}to{border-color:#00ff00e6;box-shadow:0 0 8px #00ff0080}}.hud-label{color:#000;white-space:nowrap;background-color:#00ff00d9;border-radius:2px;padding:1px 4px;font-family:monospace;font-size:8px;font-weight:800;position:absolute;top:-16px;left:-1px;box-shadow:0 1px 3px #00000080}.inv-explorer-grid{grid-template-columns:2fr 1fr;gap:24px;display:grid}@media (width<=900px){.inv-explorer-grid{grid-template-columns:1fr!important}}.fullscreen-modal-panel{box-shadow:0 20px 25px -5px #00000080,0 10px 10px -5px #0006}.maintenance-tab-container{flex-direction:column;gap:24px;padding:24px 32px;display:flex}@media print{body *{visibility:hidden!important}.print-report-container,.print-report-container *{visibility:visible!important}.print-report-container{color:#000!important;width:100%!important;height:auto!important;max-height:none!important;box-shadow:none!important;background:#fff!important;border:none!important;margin:0!important;padding:10px!important;position:absolute!important;top:0!important;left:0!important;overflow:visible!important}.no-print{display:none!important}}.notification-dropdown{background-color:var(--bg-card);border:1px solid var(--border-color);z-index:1000;border-radius:12px;width:320px;position:absolute;top:45px;right:0;overflow:hidden;box-shadow:0 10px 25px -5px #0000001a,0 8px 10px -6px #0000001a}.notification-header{border-bottom:1px solid var(--border-color);background-color:#fafafa;justify-content:space-between;align-items:center;padding:12px 16px;display:flex}.notification-header h3{color:var(--text-heading);margin:0;font-size:14px;font-weight:600}.notification-header button{color:var(--text-muted);cursor:pointer;background:0 0;border:none;border-radius:4px;padding:4px;font-size:14px;transition:all .2s}.notification-header button:hover{color:var(--text-heading);background-color:#f3f4f6}.notification-body{max-height:350px;overflow-y:auto}.notification-item{border-bottom:1px solid var(--border-color);cursor:pointer;gap:12px;padding:12px 16px;transition:background-color .2s;display:flex}.notification-item:hover{background-color:#fafafa}.notification-item:last-child{border-bottom:none}.notification-icon{flex-shrink:0;margin-top:2px;font-size:18px}.notification-info{flex-direction:column;gap:2px;display:flex}.notification-title{color:var(--text-main);font-size:12.5px;font-weight:600}.notification-text{color:var(--text-muted);font-size:11.5px;line-height:1.4}.notification-item.warning{border-left:4px solid var(--warning)}.notification-item.danger{border-left:4px solid var(--danger)}.notification-item.info{border-left:4px solid var(--info)}.notification-item.success{border-left:4px solid var(--success)}.hrms-tabs{background:var(--bg-card);border:1px solid var(--border-color);border-radius:8px;gap:8px;width:fit-content;margin-bottom:8px;padding:6px;display:flex}.hrms-tab-btn{color:var(--text-muted);cursor:pointer;background:0 0;border:none;border-radius:6px;align-items:center;gap:8px;padding:10px 20px;font-size:13.5px;font-weight:600;transition:all .2s;display:flex}.hrms-tab-btn:hover{color:var(--text-main);background-color:#f3f4f6}.hrms-tab-btn.active{color:var(--accent);background-color:#f59e0b26;box-shadow:0 2px 4px #f59e0b0d}.hrms-chart-row{grid-template-columns:1fr 1.2fr;gap:24px;display:grid}@media (width<=1024px){.hrms-chart-row{grid-template-columns:1fr}}.donut-chart-container{flex-wrap:wrap;justify-content:space-around;align-items:center;gap:20px;padding:16px 8px;display:flex}.donut-svg-wrapper{width:140px;height:140px;position:relative}.donut-label-center{flex-direction:column;justify-content:center;align-items:center;display:flex;position:absolute;top:50%;left:50%;transform:translate(-50%,-50%)}.donut-label-val{color:var(--text-main);font-size:22px;font-weight:800}.donut-label-lbl{text-transform:uppercase;letter-spacing:.5px;color:var(--text-muted);font-size:10px}.donut-legend{flex-direction:column;gap:10px;display:flex}.legend-item{color:var(--text-muted);align-items:center;gap:8px;font-size:12.5px;font-weight:500;display:flex}.legend-color-dot{border-radius:4px;width:12px;height:12px}.bar-chart-container{flex-direction:column;gap:16px;padding:10px 0;display:flex}.bar-chart-row{align-items:center;gap:12px;display:flex}.bar-chart-label{width:90px;color:var(--text-muted);white-space:nowrap;text-overflow:ellipsis;font-size:12px;font-weight:600;overflow:hidden}.bar-chart-progress-wrapper{background-color:#f3f4f6;border-radius:9px;flex:1;height:18px;position:relative;overflow:hidden}.bar-chart-progress-fill{background:linear-gradient(90deg, var(--accent) 0%, #fef08a 100%);border-radius:9px;height:100%;transition:width .8s cubic-bezier(.4,0,.2,1)}.bar-chart-value{text-align:right;width:80px;color:var(--text-main);font-size:12px;font-weight:700}.employees-grid{grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:20px;display:grid}.employee-card{background:var(--bg-card);border:1px solid var(--border-color);cursor:pointer;border-radius:8px;flex-direction:column;gap:16px;padding:20px;transition:all .2s;display:flex;position:relative;overflow:hidden;box-shadow:0 1px 3px #0000000d}.employee-card:hover{transform:translateY(-3px);box-shadow:0 4px 6px #0000000d}.employee-card:before{content:"";background-color:var(--info);opacity:.8;width:4px;height:100%;position:absolute;top:0;left:0}.employee-card.Management:before{background-color:var(--danger)}.employee-card.Engineering:before{background-color:var(--info)}.employee-card.Operations:before{background-color:var(--warning)}.employee-card.Quality.Control:before{background-color:var(--success)}.emp-card-header{align-items:center;gap:12px;display:flex}.emp-card-avatar{color:#fff;background:linear-gradient(135deg, var(--info) 0%, #ec4899 100%);border-radius:50%;justify-content:center;align-items:center;width:46px;height:46px;font-size:16px;font-weight:700;display:flex}.emp-card-meta{flex-direction:column;display:flex}.emp-card-name{color:var(--text-heading);font-size:15px;font-weight:700}.emp-card-role{color:var(--text-muted);font-size:12px;font-weight:500}.emp-card-body{border-top:1px solid var(--border-color);border-bottom:1px solid var(--border-color);grid-template-columns:1fr 1fr;gap:12px;padding:12px 0;font-size:12px;display:grid}.emp-info-label{color:var(--text-muted);margin-bottom:2px}.emp-info-value{color:var(--text-main);font-weight:600}.emp-performance-badge{text-transform:uppercase;border-radius:4px;padding:2px 6px;font-size:9px;font-weight:700;display:inline-block}.emp-performance-badge.outperforming{color:var(--success);background-color:#10b9811a}.emp-performance-badge.standard{color:var(--info);background-color:#3b82f61a}.emp-performance-badge.underperforming{color:var(--danger);background-color:#ef44441a}.bpmn-workspace{background-color:var(--bg-card);border:1px solid var(--border-color);border-radius:12px;gap:20px;height:640px;display:flex;position:relative;overflow:hidden;box-shadow:0 4px 6px #00000005}.bpmn-palette{border-right:1px solid var(--border-color);background:#f9fafb;flex-direction:column;flex-shrink:0;gap:20px;width:240px;padding:16px;display:flex;overflow-y:auto}.palette-section-title{text-transform:uppercase;letter-spacing:.5px;color:var(--text-muted);margin-bottom:10px;font-size:11px;font-weight:800}.palette-items{flex-direction:column;gap:10px;display:flex}.palette-item{border:1px solid var(--border-color);cursor:grab;-webkit-user-select:none;user-select:none;color:var(--text-main);white-space:nowrap;background:#fff;border-radius:6px;align-items:center;gap:12px;padding:10px 14px;font-size:12.5px;font-weight:600;transition:all .2s;display:flex}.palette-item:hover{border-color:var(--text-muted);background:#f3f4f6}.palette-item:active{cursor:grabbing}.palette-icon-box{width:28px;height:28px;color:var(--info);border:1px solid var(--border-color);background:#eff6ff;border-radius:6px;justify-content:center;align-items:center;display:flex;box-shadow:0 1px 2px #00000005}.bpmn-canvas-wrapper{background-color:#fafafa;background-image:radial-gradient(#00000014 1px,#0000 1px);background-size:20px 20px;outline:none;flex:1;min-width:0;height:100%;display:flex;position:relative;overflow:auto}.bpmn-svg-canvas{-webkit-user-select:none;user-select:none;width:1200px;min-width:100%;height:800px;min-height:100%;position:relative}.bpmn-swimlane{fill:none;stroke:var(--border-color);stroke-width:1.5px}.bpmn-swimlane-header{stroke:var(--border-color);stroke-width:1.5px}.bpmn-swimlane-text{font-family:var(--sans);fill:var(--text-muted);text-anchor:middle;font-size:12px;font-weight:700}.bpmn-role-node{cursor:move}.bpmn-role-card-bg{fill:#fff;stroke:var(--border-color);stroke-width:1.5px;rx:8px;ry:8px;filter:drop-shadow(0 2px 4px #00000008)}.bpmn-role-node:hover .bpmn-role-card-bg{stroke:var(--info)}.bpmn-role-node.selected .bpmn-role-card-bg{stroke:var(--info);stroke-width:2.5px}.bpmn-node-title{font-family:var(--sans);fill:var(--text-heading);font-size:11.5px;font-weight:700}.bpmn-node-emp{font-family:var(--sans);fill:var(--text-main);font-size:11px;font-weight:500}.bpmn-node-dept{font-family:var(--sans);fill:var(--text-muted);text-transform:uppercase;letter-spacing:.3px;font-size:9px;font-weight:700}.bpmn-gateway-node{cursor:move}.bpmn-gateway-bg{fill:#fffbeb;stroke:var(--warning);stroke-width:2px}.bpmn-gateway-node.selected .bpmn-gateway-bg{stroke:var(--info);stroke-width:3px}.bpmn-conn-point{fill:#fff;stroke:var(--info);stroke-width:2px;cursor:crosshair}.bpmn-conn-point:hover{fill:var(--info);transform:scale(1.3)}.bpmn-preview-line{stroke:var(--info);stroke-width:2px;stroke-dasharray:4 4;pointer-events:none}.bpmn-flow-line{fill:none;stroke:var(--text-main);stroke-width:1.8px;stroke-linejoin:round}.bpmn-flow-line.sequence{stroke:#334155}.bpmn-flow-wrapper:hover .bpmn-flow-line,.bpmn-flow-wrapper.selected .bpmn-flow-line{stroke:var(--info);stroke-width:2.5px}.bpmn-flow-label{font-family:var(--sans);fill:var(--text-muted);font-size:10px;font-weight:600}.bpmn-inspector{border-left:1px solid var(--border-color);background:#f9fafb;flex-direction:column;flex-shrink:0;gap:16px;width:280px;padding:16px;display:flex;overflow-y:auto}.inspector-empty{text-align:center;color:var(--text-muted);flex-direction:column;flex:1;justify-content:center;align-items:center;gap:12px;padding:24px;display:flex}.inspector-empty-icon{opacity:.4;width:32px;height:32px;color:var(--text-muted)}.bpmn-controls-header{border-bottom:1px solid var(--border-color);z-index:10;background-color:#fff;justify-content:space-between;align-items:center;height:48px;padding:10px 16px;display:flex;position:absolute;top:0;left:0;right:0}.bpmn-canvas-area{width:100%;height:100%;padding-top:48px}.canvas-control-btn{border:1px solid var(--border-color);cursor:pointer;white-space:nowrap;background:#fff;border-radius:4px;align-items:center;gap:6px;padding:6px 12px;font-size:11.5px;font-weight:700;transition:all .2s;display:flex}.canvas-control-btn:hover{border-color:var(--text-muted);background:#f3f4f6}.canvas-control-btn.danger:hover{color:var(--danger);border-color:var(--danger);background-color:#ef44441a}.canvas-mode-indicator{color:var(--info);background-color:#3b82f626;border-radius:20px;align-items:center;gap:6px;padding:4px 10px;font-size:11.5px;font-weight:700;display:flex}.bpmn-help-banner{background:linear-gradient(135deg,#fffbeb 0%,#fff7ed 100%);border:1px solid #fef3c7;border-radius:6px;align-items:flex-start;gap:12px;margin-bottom:4px;padding:12px 16px;display:flex}.bpmn-help-banner-icon{color:#d97706;flex-shrink:0;margin-top:2px}.bpmn-help-banner-content h4{color:#92400e;margin-bottom:2px;font-size:13px;font-weight:700}.bpmn-help-banner-content p{color:#b45309;font-size:12px;line-height:1.4}.module-header{border-bottom:1px solid var(--border-color);justify-content:space-between;align-items:center;margin-bottom:16px;padding-bottom:16px;display:flex}.module-title h2{color:var(--text-heading);margin-bottom:4px;font-size:20px;font-weight:700}.module-title p{color:var(--text-muted);margin:0;font-size:13px}.leave-request-list{flex-direction:column;gap:12px;display:flex}.leave-request-card{background:var(--bg-card);border:1px solid var(--border-color);border-radius:8px;grid-template-columns:1.5fr 1fr 1fr 1fr 1fr;align-items:center;gap:16px;padding:16px;display:grid;box-shadow:0 1px 3px #0000000d}@media (width<=768px){.leave-request-card{grid-template-columns:1fr;gap:12px}}.leave-emp-name{color:var(--text-heading);font-size:14px;font-weight:700}.leave-emp-dept{color:var(--text-muted);margin-top:2px;font-size:11px}.leave-type-pill{color:var(--text-main);background:#f3f4f6;border-radius:20px;width:fit-content;padding:4px 10px;font-size:11px;font-weight:600;display:inline-block}.leave-duration{color:var(--text-main);font-size:12.5px;font-weight:500}.leave-reason{color:var(--text-muted);white-space:nowrap;text-overflow:ellipsis;max-width:250px;font-size:12px;font-style:italic;overflow:hidden}
