:root{--primary-50: #f0fdf4;--primary-400: #4ade80;--primary-500: #22c55e;--primary-600: #16a34a;--primary-900: #14532d;--accent-blue: #3b82f6;--accent-orange: #f97316;--accent-red: #ef4444;--accent-yellow: #eab308;--gray-50: #f8fafc;--gray-100: #f1f5f9;--gray-200: #e2e8f0;--gray-300: #cbd5e1;--gray-500: #64748b;--gray-800: #1e293b;--gray-900: #0f172a;--bg-primary: #f4f6f9;--bg-secondary: #eef1f6;--bg-card: #ffffff;--bg-muted: #f8fafc;--bg-input: #ffffff;--bg-sidebar: #111827;--text-primary: #0f172a;--text-secondary: #475569;--text-muted: #64748b;--text-white: #ffffff;--text-white-muted: rgba(255, 255, 255, .65);--border-color: #e2e8f0;--border-light: #eef2f6;--success-color: #22c55e;--warning-color: #eab308;--error-color: #ef4444;--info-color: #3b82f6;--glass-bg: rgba(255, 255, 255, .88);--glass-border: rgba(255, 255, 255, .6);--shadow-xs: 0 1px 2px rgba(15, 23, 42, .04);--shadow-sm: 0 1px 3px rgba(15, 23, 42, .06), 0 1px 2px rgba(15, 23, 42, .04);--shadow-md: 0 4px 12px rgba(15, 23, 42, .06), 0 2px 4px rgba(15, 23, 42, .04);--shadow-lg: 0 12px 32px rgba(15, 23, 42, .08), 0 4px 8px rgba(15, 23, 42, .04);--shadow-glow: 0 0 0 1px rgba(34, 197, 94, .08), 0 8px 24px rgba(34, 197, 94, .12);--radius-sm: 8px;--radius-md: 10px;--radius-lg: 14px;--radius-xl: 18px;--sidebar-width: 260px;--transition-base: .2s cubic-bezier(.4, 0, .2, 1);--table-stripe-odd: #ffffff;--table-stripe-even: #f8fafc;--table-stripe-hover: #f0fdf4}*{margin:0;padding:0;box-sizing:border-box}body{font-family:Inter,-apple-system,BlinkMacSystemFont,sans-serif;background:var(--bg-primary);color:var(--text-primary);line-height:1.6;-webkit-font-smoothing:antialiased}.loading-screen{display:flex;align-items:center;justify-content:center;min-height:100vh;color:var(--text-muted)}.login-page{min-height:100vh;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,var(--gray-900) 0%,#1a3a2a 50%,var(--primary-900) 100%);position:relative}.login-page:before{content:"";position:absolute;top:0;right:0;bottom:0;left:0;background:radial-gradient(circle at 30% 50%,rgba(34,197,94,.15),transparent 60%)}.login-box{position:relative;z-index:1;background:var(--glass-bg);-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);border:1px solid var(--glass-border);border-radius:var(--radius-xl);padding:48px 40px;width:100%;max-width:420px;box-shadow:var(--shadow-lg),var(--shadow-glow)}.login-header{text-align:center;margin-bottom:32px}.login-logo-wrap{width:108px;height:108px;margin:0 auto 18px;border-radius:50%;overflow:hidden;background:var(--primary-900);box-shadow:0 10px 28px #14532d61,0 0 0 1px #22c55e47,0 0 32px #22c55e2e}.login-logo{display:block;width:100%;height:100%;object-fit:cover;transform:scale(1.04)}.login-header h1{font-size:24px;font-weight:600}.login-header p{color:var(--text-muted);font-size:14px}.app-shell{display:flex;min-height:100vh;background:var(--bg-primary)}.global-bg{position:fixed;top:0;right:0;bottom:0;left:0;z-index:0;background:radial-gradient(ellipse 80% 50% at 100% 0%,rgba(34,197,94,.07),transparent 55%),radial-gradient(ellipse 60% 40% at 0% 100%,rgba(59,130,246,.05),transparent 50%),linear-gradient(180deg,#f8fafc 0%,var(--bg-primary) 100%);pointer-events:none}.sidebar{width:var(--sidebar-width);background:linear-gradient(180deg,#111827,#0f172a);color:var(--text-white);display:flex;flex-direction:column;position:fixed;top:0;left:0;bottom:0;z-index:100;border-right:1px solid rgba(255,255,255,.06);box-shadow:4px 0 24px #0f172a14}.sidebar-header{padding:20px 16px;border-bottom:1px solid rgba(255,255,255,.06)}.sidebar-brand-row{display:flex;align-items:center;gap:10px;margin-bottom:16px}.sidebar-brand-logo{width:36px;height:36px;border-radius:50%;object-fit:cover;flex-shrink:0;box-shadow:0 0 0 2px #22c55e59}.sidebar-brand{font-size:16px;font-weight:600;letter-spacing:-.02em;line-height:1.2}.sidebar-brand-sub{font-size:11px;color:var(--text-white-muted);font-weight:400;margin-top:2px}.user-info{display:flex;align-items:center;gap:10px;padding:10px;border-radius:var(--radius-md);cursor:pointer;transition:background var(--transition-base);background:#ffffff0a;border:1px solid rgba(255,255,255,.06)}.user-info:hover{background:#ffffff14}.user-avatar{width:34px;height:34px;border-radius:10px;background:linear-gradient(135deg,var(--primary-600),var(--primary-900));display:flex;align-items:center;justify-content:center;font-weight:600;font-size:13px}.user-name{font-size:13px;font-weight:500;display:block}.user-role{font-size:11px;color:var(--text-white-muted)}.sidebar-nav{flex:1;overflow-y:auto;padding:12px 10px 20px}.nav-section{margin-bottom:18px}.nav-label{font-size:10px;text-transform:uppercase;letter-spacing:.08em;color:#fff6;padding:0 10px 6px;font-weight:600}.nav-item{display:flex;align-items:center;gap:10px;padding:9px 10px;border-radius:var(--radius-md);color:var(--text-white-muted);text-decoration:none;font-size:13px;font-weight:500;transition:all var(--transition-base);margin-bottom:2px}.nav-item:hover{background:#ffffff12;color:var(--text-white)}.nav-item.active{background:#22c55e2e;color:#86efac;box-shadow:inset 0 0 0 1px #22c55e40}.nav-icon{display:inline-flex;align-items:center;justify-content:center;width:20px;height:20px;flex-shrink:0;opacity:.72;transition:opacity var(--transition-base)}.nav-item:hover .nav-icon,.nav-item.active .nav-icon{opacity:1}.nav-icon svg{width:18px;height:18px;display:block}.sidebar-footer{padding:12px 10px 16px;border-top:1px solid rgba(255,255,255,.06);margin-top:auto}.main-area{flex:1;margin-left:var(--sidebar-width);display:flex;flex-direction:column;position:relative;z-index:1;min-width:0}.topbar{height:60px;display:flex;align-items:center;justify-content:space-between;padding:0 28px;background:#ffffffeb;-webkit-backdrop-filter:blur(16px) saturate(1.2);backdrop-filter:blur(16px) saturate(1.2);border-bottom:1px solid var(--border-light);box-shadow:var(--shadow-xs);position:sticky;top:0;z-index:50}.topbar-title{font-size:15px;font-weight:600;color:var(--text-primary);letter-spacing:-.01em}.topbar-actions{display:flex;align-items:center;gap:10px}.topbar-version{font-size:11px;color:var(--text-muted);padding:4px 10px;background:var(--bg-muted);border-radius:999px;border:1px solid var(--border-light)}.page-content{padding:28px;flex:1;max-width:1600px}.page-header{display:flex;align-items:flex-start;justify-content:space-between;gap:16px;margin-bottom:24px}.page-header-text{min-width:0}.page-header-title{font-size:22px;font-weight:700;letter-spacing:-.03em;color:var(--text-primary);line-height:1.25;margin:0}.page-header-desc{font-size:13px;color:var(--text-muted);margin:6px 0 0;line-height:1.5}.kpi-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:14px;margin-bottom:24px}.kpi-card{background:var(--bg-card);border:1px solid var(--border-light);border-radius:var(--radius-lg);padding:18px 18px 16px;box-shadow:var(--shadow-sm);transition:box-shadow var(--transition-base),transform var(--transition-base);position:relative;overflow:hidden}.kpi-card:before{content:"";position:absolute;left:0;top:0;bottom:0;width:3px;background:var(--kpi-accent, var(--primary-500));border-radius:3px 0 0 3px}.kpi-card:hover{box-shadow:var(--shadow-md);transform:translateY(-1px)}.kpi-card-accent-blue{--kpi-accent: var(--accent-blue)}.kpi-card-accent-orange{--kpi-accent: var(--accent-orange)}.kpi-card-accent-purple{--kpi-accent: #8b5cf6}.kpi-value{font-size:28px;font-weight:700;color:var(--text-primary);letter-spacing:-.03em;font-variant-numeric:tabular-nums}.kpi-label{font-size:12px;color:var(--text-muted);margin-top:4px;font-weight:500}.card{background:var(--bg-card);border:1px solid var(--border-light);border-radius:var(--radius-lg);padding:20px;box-shadow:var(--shadow-sm);margin-bottom:16px}.card-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:16px}.card-title{font-size:15px;font-weight:600;letter-spacing:-.01em;color:var(--text-primary)}.card-section-title{font-size:13px;font-weight:600;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.04em;margin-bottom:12px}.form-group{margin-bottom:16px}.form-group label{display:block;font-size:13px;font-weight:500;margin-bottom:6px;color:var(--text-secondary)}.form-input,.form-select,.form-textarea{width:100%;padding:10px 14px;border:1px solid var(--border-color);border-radius:var(--radius-md);background:var(--bg-input);font-size:14px;transition:border-color var(--transition-base),box-shadow var(--transition-base);box-shadow:var(--shadow-xs)}.form-input:focus,.form-select:focus,.form-textarea:focus{outline:none;border-color:var(--primary-500);box-shadow:0 0 0 3px #22c55e1f}.btn{display:inline-flex;align-items:center;justify-content:center;gap:6px;padding:9px 16px;border-radius:var(--radius-md);font-size:13px;font-weight:600;cursor:pointer;border:none;transition:all var(--transition-base);letter-spacing:-.01em}.btn-primary{background:linear-gradient(180deg,var(--primary-500) 0%,var(--primary-600) 100%);color:#fff;box-shadow:0 1px 2px #16a34a4d}.btn-primary:hover{filter:brightness(1.05);box-shadow:0 2px 8px #16a34a59}.btn-secondary{background:var(--bg-card);color:var(--text-primary);border:1px solid var(--border-color);box-shadow:var(--shadow-xs)}.btn-secondary:hover{background:var(--bg-muted);border-color:var(--gray-300)}.btn-danger{background:var(--error-color);color:#fff}.btn-sm{padding:6px 12px;font-size:13px}.btn-block{width:100%}.data-table{width:100%;border-collapse:collapse;font-size:13px}.data-table th{text-align:left;padding:11px 16px;background:var(--bg-muted);font-weight:600;font-size:11px;color:var(--text-muted);border-bottom:1px solid var(--border-color);text-transform:uppercase;letter-spacing:.04em}.data-table td{padding:12px 16px;border-bottom:1px solid var(--border-light);transition:background-color var(--transition-base);color:var(--text-primary)}.data-table tbody tr:nth-child(odd):not(.order-progress-detail-row) td{background-color:var(--table-stripe-odd)}.data-table tbody tr:nth-child(2n):not(.order-progress-detail-row) td{background-color:var(--table-stripe-even)}.data-table tbody tr.row-stripe-odd td{background-color:var(--table-stripe-odd)}.data-table tbody tr.row-stripe-even td{background-color:var(--table-stripe-even)}.data-table tbody tr:hover:not(.order-progress-detail-row) td{background-color:var(--table-stripe-hover)}.card>.data-table tbody tr:first-child td,.card .data-table tbody tr:first-child td{border-top:1px solid var(--border-light)}.badge{display:inline-block;padding:2px 10px;border-radius:999px;font-size:12px;font-weight:500}.badge-success{background:#22c55e26;color:var(--success-color)}.badge-warning{background:#eab30826;color:var(--warning-color)}.badge-error{background:#ef444426;color:var(--error-color)}.badge-info{background:#3b82f626;color:var(--info-color)}.badge-muted{background:var(--bg-muted);color:var(--text-muted)}.filter-bar{display:flex;flex-wrap:wrap;gap:10px;align-items:center;margin-bottom:16px;padding:14px 16px;background:var(--bg-muted);border-radius:var(--radius-md);border:1px solid var(--border-light)}.category-filter-bar{display:flex;flex-wrap:wrap;gap:8px;margin-bottom:16px;padding:12px 14px;background:var(--glass-bg);border:1px solid var(--glass-border);border-radius:var(--radius-md);-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px)}.category-pill{padding:6px 14px;border-radius:999px;font-size:13px;font-weight:500;border:1px solid var(--border-color);background:var(--bg-input);color:var(--text-secondary);cursor:pointer;transition:background .15s,color .15s,border-color .15s}.category-pill:hover{border-color:var(--primary-500);color:var(--primary-600)}.category-pill.is-active{background:var(--primary-500);border-color:var(--primary-600);color:var(--text-white)}.drawer-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#0000004d;z-index:200}.drawer{position:fixed;top:0;right:0;bottom:0;width:480px;max-width:90vw;background:#fff;z-index:201;padding:24px;box-shadow:var(--shadow-lg);overflow-y:auto;animation:slideIn .25s ease}@keyframes slideIn{0%{transform:translate(100%)}to{transform:translate(0)}}.toast{position:fixed;bottom:24px;right:24px;z-index:300;padding:12px 20px;border-radius:var(--radius-md);background:var(--gray-900);color:#fff;font-size:14px;box-shadow:var(--shadow-lg);animation:fadeIn .3s}@keyframes fadeIn{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}.error-text{color:var(--error-color);font-size:13px;margin-top:8px}.progress-bar{height:8px;background:var(--gray-200);border-radius:999px;overflow:hidden}.progress-fill{height:100%;background:var(--primary-500);border-radius:999px;transition:width .3s}.priority-badge{display:inline-block;padding:4px 12px;border-radius:999px;font-size:12px;font-weight:600}.priority-green{background:#22c55e26;color:#16a34a}.priority-orange{background:#f9731626;color:#ea580c}.priority-purple{background:#8b5cf626;color:#7c3aed}.priority-blue{background:#3b82f626;color:#2563eb}.priority-progress{height:10px;margin:12px 0}.priority-fill-green{background:linear-gradient(90deg,#22c55e,#16a34a)}.priority-fill-orange{background:linear-gradient(90deg,#fb923c,#ea580c)}.priority-fill-purple{background:linear-gradient(90deg,#a78bfa,#7c3aed)}.priority-fill-blue{background:linear-gradient(90deg,#60a5fa,#2563eb)}.stage-timeline{display:flex;flex-direction:column;gap:12px}.stage-item{display:flex;gap:12px;padding:12px;border-radius:var(--radius-md);background:var(--bg-muted);border-left:4px solid var(--gray-300)}.stage-item.stage-completed{border-left-color:var(--success-color)}.stage-item.stage-in_progress{border-left-color:var(--info-color)}.stage-index{width:28px;height:28px;border-radius:50%;background:var(--primary-600);color:#fff;display:flex;align-items:center;justify-content:center;font-size:13px;font-weight:600;flex-shrink:0}.stage-body{flex:1}.stage-name{font-weight:600;margin-bottom:4px}.inspection-stage-panel{margin-top:10px;padding:12px;border-radius:var(--radius-md);background:#3b82f60f;border:1px dashed rgba(59,130,246,.35)}.inspection-stage-panel-compact{padding:10px}.inspection-stage-panel-head{display:flex;align-items:center;justify-content:space-between;margin-bottom:6px;font-size:13px}.inspection-photo-count{font-size:12px;color:var(--info-color);font-weight:600}.inspection-stage-hint{font-size:12px;color:var(--text-muted);margin:0 0 10px;line-height:1.5}.inspection-photos{display:flex;flex-wrap:wrap;gap:12px;margin-top:4px}.photo-slot{display:flex;flex-direction:column;align-items:center;gap:6px;font-size:12px;min-width:88px}.photo-slot-filled{display:flex;flex-direction:column;align-items:center;gap:6px}.photo-thumb{width:80px;height:80px;object-fit:cover;border-radius:var(--radius-sm);border:1px solid var(--border-color)}.photo-upload-btn{cursor:pointer}.photo-upload-primary{min-width:88px}.order-progress-card{margin-bottom:16px}.order-progress-list{padding:0;overflow:hidden}.order-progress-list-header{padding:12px 16px;border-bottom:1px solid var(--border-color)}.order-progress-table-wrap{overflow-x:auto}.order-progress-compact-table{margin:0;font-size:13px}.order-progress-compact-table th,.order-progress-compact-table td{padding:8px 10px;vertical-align:middle}.order-progress-row{cursor:pointer}.order-progress-row.is-expanded>td{background:#3b82f614!important}.order-progress-detail-row td{padding:0!important;background:var(--bg-muted);border-top:none}.order-progress-detail{padding:12px 16px 16px}.mini-progress-cell{display:flex;align-items:center;gap:8px;min-width:100px}.mini-progress-text{font-size:12px;color:var(--text-muted);white-space:nowrap}.priority-progress-mini{height:6px;margin:0;flex:1;min-width:56px}.stage-dots{display:flex;gap:4px;align-items:center}.stage-dot{width:8px;height:8px;border-radius:50%;background:var(--gray-300);flex-shrink:0}.stage-dot-completed{background:var(--success-color)}.stage-dot-in_progress{background:var(--info-color)}.stage-dot-pending{background:var(--gray-300)}.stage-timeline-compact{gap:8px}.stage-timeline-compact .stage-item{padding:8px 10px}.stage-timeline-compact .stage-index{width:22px;height:22px;font-size:11px}.stage-timeline-compact .inspection-photos .photo-thumb{width:64px;height:64px}.master-detail{display:grid;grid-template-columns:1fr 1.2fr;gap:16px}.photo-thumb-btn{padding:0;border:none;background:none;cursor:pointer;border-radius:var(--radius-sm)}.inspection-thumb-row{display:flex;align-items:center;gap:4px;flex-wrap:wrap}.inspection-thumb-btn{padding:0;border:1px solid var(--border-color);border-radius:4px;overflow:hidden;cursor:pointer;background:#fff}.inspection-thumb-mini{width:36px;height:36px;object-fit:cover;display:block}.inspection-thumb-empty{width:36px;height:36px;border-radius:4px;border:1px dashed var(--border-color);background:var(--bg-muted)}.order-progress-inspection>td{background:#3b82f60f!important}.order-progress-rejected>td{background:#ef44440f!important}.inspection-stage-panel-rejected{border:1px solid rgba(239,68,68,.35);border-radius:8px;padding:12px}.photo-lightbox-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;z-index:2000;background:#0f172abf;display:flex;align-items:center;justify-content:center;padding:16px}.photo-lightbox-panel{max-width:min(92vw,720px);max-height:90vh;background:var(--bg-card);border-radius:var(--radius-lg);padding:16px;display:flex;flex-direction:column;align-items:center;gap:12px}.photo-lightbox-title{margin:0;font-size:14px;color:var(--text-secondary)}.photo-lightbox-img{max-width:100%;max-height:70vh;object-fit:contain;border-radius:var(--radius-md)}.dashboard-quick-links{display:grid;grid-template-columns:repeat(auto-fill,minmax(140px,1fr));gap:10px}.dashboard-quick-link{display:flex;flex-direction:column;align-items:flex-start;gap:8px;padding:14px 16px;border-radius:var(--radius-md);background:var(--bg-card);color:var(--text-primary);text-decoration:none;font-size:13px;font-weight:600;border:1px solid var(--border-light);box-shadow:var(--shadow-xs);transition:all var(--transition-base)}.dashboard-quick-link:hover{border-color:#22c55e73;color:var(--primary-600);box-shadow:var(--shadow-md);transform:translateY(-1px)}.dashboard-quick-badge{min-width:20px;height:20px;padding:0 6px;border-radius:999px;background:linear-gradient(180deg,#ef4444,#dc2626);color:#fff;font-size:11px;font-weight:700;display:inline-flex;align-items:center;justify-content:center;box-shadow:0 1px 3px #ef444459}.bind-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:16px;margin-bottom:16px}.bind-card{background:var(--bg-card);border:1px solid var(--border-light);border-radius:var(--radius-lg);padding:18px 20px;box-shadow:var(--shadow-sm)}.bind-card-head{display:flex;align-items:flex-start;justify-content:space-between;gap:12px;margin-bottom:14px}.bind-card-title{font-size:15px;font-weight:600;margin:0 0 4px;color:var(--text-primary)}.bind-card-hint{font-size:12px;color:var(--text-muted);margin:0;line-height:1.45}.bind-card-bound{display:flex;align-items:center;justify-content:space-between;gap:12px;padding:12px 14px;background:var(--bg-muted);border-radius:var(--radius-md);border:1px solid var(--border-light)}.bind-card-value{font-size:14px;font-weight:600;color:var(--text-primary)}.bind-card-time{font-size:11px;color:var(--text-muted);margin-top:4px}.form-input:disabled{background:var(--bg-muted);color:var(--text-muted);cursor:not-allowed}.sidebar-toggle{display:none}.sidebar-backdrop{display:none;position:fixed;top:0;right:0;bottom:0;left:0;z-index:90;border:none;background:#0f172a73;cursor:pointer}@media(max-width:1024px){.sidebar-toggle{display:inline-flex}.sidebar-backdrop{display:block}.sidebar{transform:translate(-100%);transition:transform var(--transition-base);z-index:100}.app-shell.sidebar-open .sidebar{transform:translate(0)}.main-area{margin-left:0}.master-detail{grid-template-columns:1fr}.topbar{gap:8px}.topbar-title{font-size:15px}}
