@import "https://fonts.googleapis.com/css2?family=Plus+Jakarta+Sans:wght@400;500;600;700;800&display=swap";
:root{--green:#1b3d2a;--green-light:#2a5c40;--green-accent:#5ac88c;--green-accent-deep:#3a9e65;--grad-emerald:linear-gradient(135deg,#5ac88c 0%,#3a9e65 100%);--grad-emerald-soft:linear-gradient(135deg,#f0fdf4 0%,#dcfce7 100%);--grad-amber-soft:linear-gradient(135deg,#fffbeb 0%,#fef3c7 100%);--grad-blue-soft:linear-gradient(135deg,#eff6ff 0%,#dbeafe 100%);--grad-rose-soft:linear-gradient(135deg,#fef2f2 0%,#ffe4e6 100%);--grad-purple-soft:linear-gradient(135deg,#f5f3ff 0%,#ede9fe 100%);--grad-login:radial-gradient(circle at 20% 20%,#5ac88c2e,transparent 50%),radial-gradient(circle at 80% 80%,#3a9e651f,transparent 50%),linear-gradient(135deg,#f5f8f6 0%,#e8f0eb 100%);--grad-sidebar:linear-gradient(180deg,#1b3d2a 0%,#16331f 100%);--bg-page:#f5f8f6;--bg-card:#fff;--text-primary:#0a1a12;--text-secondary:#1a3025;--text-muted:#3d6050;--text-dim:#7e9e8a;--border:#e0e8e2;--border-soft:#edf2ee;--border-strong:#c7d2c9;--radius-sm:7px;--radius-md:10px;--radius-lg:12px;--radius-xl:16px;--radius-pill:999px;--shadow-xs:0 1px 2px #0a28190a;--shadow-sm:0 1px 3px #0a28190f, 0 1px 2px #0a28190a;--shadow-md:0 4px 8px -2px #0a281914, 0 2px 4px -2px #0a28190f;--shadow-lg:0 10px 24px -6px #0a28191f, 0 4px 10px -4px #0a28190f;--shadow-xl:0 24px 48px -12px #0a28192e;--shadow-focus:0 0 0 3px #5ac88c2e;--font:"Plus Jakarta Sans",-apple-system,BlinkMacSystemFont,"Segoe UI",sans-serif;--t-fast:.12s cubic-bezier(.4,0,.2,1);--t-base:.18s cubic-bezier(.4,0,.2,1)}*{box-sizing:border-box;margin:0;padding:0}body{font-family:var(--font);background:var(--bg-page);color:var(--text-primary);-webkit-font-smoothing:antialiased;font-size:14.5px;line-height:1.55}::-webkit-scrollbar{width:7px;height:7px}::-webkit-scrollbar-thumb{background:var(--border-strong);border-radius:10px}.sidebar{background:var(--grad-sidebar);color:#fff;flex-direction:column;flex-shrink:0;width:232px;min-height:100vh;display:flex}.sidebar a{color:#ffffffc7;transition:all var(--t-fast);border-left:3px solid #0000;border-radius:8px;align-items:center;gap:10px;margin:1px 8px;padding:10px 14px;font-size:14px;font-weight:500;text-decoration:none;display:flex}.sidebar a:hover{color:#fff;background:#ffffff12}.sidebar a.active{border-left-color:var(--green-accent);color:#fff;background:#5ac88c2e;padding-left:11px;font-weight:700}.card{background:var(--bg-card);border-radius:var(--radius-lg);border:1px solid var(--border);box-shadow:var(--shadow-xs);padding:18px 22px}.card-elevated{box-shadow:var(--shadow-sm)}.card-pad-sm{padding:12px 14px}.card-pad-lg{padding:24px 28px}.btn{border-radius:var(--radius-md);cursor:pointer;border:1px solid var(--border-strong);color:#1a3025;height:36px;font-size:13.5px;font-weight:600;font-family:var(--font);transition:all var(--t-fast);white-space:nowrap;background:#fff;justify-content:center;align-items:center;gap:7px;padding:0 16px;display:inline-flex}.btn:hover{background:#f8faf9;border-color:#9fb8a6}.btn:disabled{opacity:.55;cursor:not-allowed}.btn-primary{background:var(--green);color:#fff;border-color:var(--green)}.btn-primary:hover{background:#254d35;border-color:#254d35}.btn-accent{background:var(--grad-emerald);color:#fff;border-color:var(--green-accent-deep);box-shadow:var(--shadow-sm)}.btn-accent:hover{box-shadow:var(--shadow-md);transform:translateY(-1px)}.btn-danger{color:#881337;background:#ffe4e6;border-color:#fda4af}.btn-success{color:#14532d;background:#dcfce7;border-color:#86efac}.btn-ghost{background:0 0;border-color:#0000}.btn-ghost:hover{background:#f1f5f4}.btn-sm{height:30px;padding:0 12px;font-size:12.5px}.btn-lg{height:42px;padding:0 22px;font-size:14.5px}.btn-block{width:100%}.btn-icon{width:36px;padding:0}.btn:focus-visible{box-shadow:var(--shadow-focus);outline:none}input,select,textarea{border:1.5px solid var(--border-strong);border-radius:var(--radius-md);color:#1a3025;width:100%;height:36px;font-size:14px;font-family:var(--font);transition:border-color var(--t-fast), box-shadow var(--t-fast);background:#fff;outline:none;padding:0 12px}textarea{height:auto;padding:10px 12px}input:hover:not(:focus),select:hover:not(:focus),textarea:hover:not(:focus){border-color:#9fb8a6}input:focus,select:focus,textarea:focus{border-color:var(--green-accent);box-shadow:var(--shadow-focus)}input::placeholder,textarea::placeholder{color:#9fb8a6}table{border-collapse:separate;border-spacing:0;width:100%;font-size:13.5px}th{text-align:left;color:#1a3025;text-transform:uppercase;letter-spacing:.06em;border-bottom:1px solid var(--border);white-space:nowrap;background:#f2f7f4;padding:10px 14px;font-size:11.5px;font-weight:800}td{border-bottom:1px solid var(--border-soft);color:#1a3025;padding:11px 14px}tbody tr{transition:background var(--t-fast)}tbody tr:hover td{background:#f8faf9}tbody tr:last-child td{border-bottom:none}.table-wrap{border:1px solid var(--border);border-radius:var(--radius-lg);box-shadow:var(--shadow-xs);background:#fff;overflow:hidden}.table-sticky thead th{z-index:2;position:sticky;top:0}.badge{border-radius:var(--radius-pill);align-items:center;gap:4px;padding:3px 10px;font-size:11.5px;font-weight:700;line-height:1.3;display:inline-flex}.badge-green,.badge-done{color:#14532d;background:#dcfce7;border:1px solid #86efac}.badge-blue,.badge-wms{color:#1e3a8a;background:#dbeafe;border:1px solid #93c5fd}.badge-amber,.badge-progress{color:#78350f;background:#fef3c7;border:1px solid #fcd34d}.badge-red{color:#881337;background:#fee2e2;border:1px solid #fca5a5}.badge-purple,.badge-manual{color:#3b0764;background:#ede9fe;border:1px solid #c4b5fd}.badge-gray,.badge-draft{color:#1e293b;background:#f1f5f9;border:1px solid #cbd5e1}.badge-orange{color:#7c2d12;background:#ffedd5;border:1px solid #fdba74}.kpi-card{border:1px solid var(--border);border-radius:var(--radius-lg);transition:all var(--t-base);background:#fff;padding:18px 20px;position:relative;overflow:hidden}.kpi-card:hover{box-shadow:var(--shadow-md);transform:translateY(-2px)}.kpi-card:before{content:"";background:var(--grad-emerald);opacity:.7;height:3px;position:absolute;inset:0 0 auto}.kpi-card.kpi-blue:before{background:linear-gradient(90deg,#3b82f6,#1d4ed8)}.kpi-card.kpi-amber:before{background:linear-gradient(90deg,#f59e0b,#d97706)}.kpi-card.kpi-red:before{background:linear-gradient(90deg,#ef4444,#b91c1c)}.kpi-card.kpi-purple:before{background:linear-gradient(90deg,#a855f7,#7e22ce)}.kpi-label{color:#3d6050;text-transform:uppercase;letter-spacing:.06em;align-items:center;gap:8px;margin-bottom:8px;font-size:11.5px;font-weight:800;display:flex}.kpi-label-icon{background:var(--grad-emerald-soft);color:#15803d;border-radius:8px;justify-content:center;align-items:center;width:28px;height:28px;display:inline-flex}.kpi-blue .kpi-label-icon{background:var(--grad-blue-soft);color:#1e40af}.kpi-amber .kpi-label-icon{background:var(--grad-amber-soft);color:#92400e}.kpi-red .kpi-label-icon{background:var(--grad-rose-soft);color:#991b1b}.kpi-purple .kpi-label-icon{background:var(--grad-purple-soft);color:#5b21b6}.kpi-value{color:#050e08;letter-spacing:-.02em;font-size:28px;font-weight:800;line-height:1}.kpi-sub{color:var(--text-muted);margin-top:6px;font-size:12px}.page-title{color:#050e08;letter-spacing:-.02em;margin:0;font-size:22px;font-weight:800}.page-sub{color:var(--text-muted);margin-top:3px;font-size:13px;font-weight:500}.empty{text-align:center;color:var(--text-muted);padding:40px 24px}.empty-icon{background:var(--grad-emerald-soft);color:#15803d;border-radius:50%;justify-content:center;align-items:center;width:56px;height:56px;margin:0 auto 12px;display:flex}.form-label{color:#1a3025;text-transform:uppercase;letter-spacing:.06em;margin-bottom:5px;font-size:11.5px;font-weight:800;display:block}.form-row{flex-direction:column;gap:5px;display:flex}.form-hint{color:var(--text-muted);font-size:12px}.overlay{z-index:50;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px);background:#0a1a128c;justify-content:center;align-items:center;padding:16px;animation:.18s fadeIn;display:flex;position:fixed;inset:0}.modal{border-radius:var(--radius-xl);width:100%;max-width:480px;box-shadow:var(--shadow-xl);background:#fff;flex-direction:column;max-height:90vh;animation:.2s popIn;display:flex;overflow:hidden}.modal-lg{max-width:720px}.modal-header{border-bottom:1px solid var(--border);justify-content:space-between;align-items:center;padding:18px 22px;display:flex}.modal-header h2{color:#050e08;letter-spacing:-.01em;font-size:16px;font-weight:800}.modal-close{cursor:pointer;width:30px;height:30px;color:var(--text-muted);background:0 0;border:none;border-radius:7px;justify-content:center;align-items:center;display:flex}.modal-close:hover{color:#0a1a12;background:#f1f5f4}.modal-body{flex-direction:column;flex:1;gap:14px;padding:20px 22px;display:flex;overflow-y:auto}.modal-footer{border-top:1px solid var(--border);background:#fafcfa;justify-content:flex-end;gap:8px;padding:16px 22px;display:flex}@keyframes fadeIn{0%{opacity:0;transform:translateY(4px)}to{opacity:1;transform:translateY(0)}}@keyframes popIn{0%{opacity:0;transform:scale(.96)}to{opacity:1;transform:scale(1)}}@keyframes shimmer{0%{background-position:-450px 0}to{background-position:450px 0}}@keyframes spin{to{transform:rotate(360deg)}}.fade-in{animation:.22s fadeIn}.skeleton{border-radius:var(--radius-sm);background:#e8efea linear-gradient(90deg,#e8efea 0%,#f2f7f4 40%,#e8efea 80%) 0 0/900px 100%;height:14px;animation:1.4s linear infinite shimmer;display:block}.spinner{border:2.5px solid #e8efea;border-top-color:var(--green-accent);border-radius:50%;width:18px;height:18px;animation:.7s linear infinite spin}.spinner-sm{border-width:2px;width:14px;height:14px}.chip-row{flex-wrap:wrap;gap:6px;display:flex}.chip{border-radius:var(--radius-pill);border:1.5px solid var(--border);color:#1a3025;cursor:pointer;height:30px;font-size:12.5px;font-weight:600;font-family:var(--font);transition:all var(--t-fast);background:#fff;align-items:center;gap:5px;padding:0 11px;display:inline-flex}.chip:hover{border-color:#9fb8a6}.chip.chip-active{background:var(--green);color:#fff;border-color:var(--green)}.progress{border-radius:var(--radius-pill);background:#e8efea;height:7px;overflow:hidden}.progress-bar{background:var(--grad-emerald);border-radius:var(--radius-pill);height:100%;transition:width .4s}.progress-bar.amber{background:linear-gradient(90deg,#f59e0b,#d97706)}.progress-bar.red{background:linear-gradient(90deg,#ef4444,#b91c1c)}.mono{font-family:JetBrains Mono,Menlo,Consolas,monospace;font-size:.92em}.tabular{font-variant-numeric:tabular-nums}.truncate{text-overflow:ellipsis;white-space:nowrap;overflow:hidden}.text-muted{color:var(--text-muted)}.text-dim{color:var(--text-dim)}
