*,:before,:after{box-sizing:border-box;margin:0;padding:0}:root{--primary:#1e40af;--primary-light:#3b82f6;--primary-dark:#1e3a8a;--success:#16a34a;--warning:#d97706;--danger:#dc2626;--gray-50:#f8fafc;--gray-100:#f1f5f9;--gray-200:#e2e8f0;--gray-300:#cbd5e1;--gray-400:#94a3b8;--gray-500:#64748b;--gray-600:#475569;--gray-700:#334155;--gray-800:#1e293b;--gray-900:#0f172a;--radius:10px;--shadow:0 1px 3px #0000001a, 0 1px 2px #0000000f;--shadow-md:0 4px 6px #00000012, 0 2px 4px #0000000d;--shadow-lg:0 10px 25px #0000001f, 0 4px 6px #0000000d}body{background:var(--gray-100);color:var(--gray-900);-webkit-tap-highlight-color:transparent;min-height:100vh;font-family:Segoe UI,Yu Gothic UI,Hiragino Sans,sans-serif;font-size:14px}.page{flex-direction:column;min-height:100vh;display:flex}.main{flex:1;width:100%;max-width:1200px;margin:0 auto;padding:16px}.header{background:linear-gradient(135deg, var(--primary-dark), var(--primary));color:#fff;height:56px;box-shadow:var(--shadow-md);z-index:50;justify-content:space-between;align-items:center;padding:0 16px;display:flex;position:sticky;top:0}.header-left{align-items:center;gap:10px;display:flex}.header-back{color:#fff;cursor:pointer;background:0 0;border:none;border-radius:6px;align-items:center;padding:6px;font-size:20px;line-height:1;display:flex}.header-back:hover{background:#ffffff26}.header-title{letter-spacing:.3px;font-size:17px;font-weight:700}.header-right{align-items:center;gap:8px;display:flex}.btn{border-radius:var(--radius);cursor:pointer;white-space:nowrap;border:none;justify-content:center;align-items:center;gap:6px;min-height:44px;padding:9px 18px;font-family:inherit;font-size:14px;font-weight:600;transition:all .15s;display:inline-flex}.btn:active{transform:scale(.97)}.btn-primary{background:var(--primary-light);color:#fff}.btn-primary:hover{background:var(--primary)}.btn-success{background:var(--success);color:#fff}.btn-success:hover{filter:brightness(1.08)}.btn-danger{background:var(--danger);color:#fff}.btn-danger:hover{filter:brightness(1.08)}.btn-ghost{color:var(--gray-700);border:1.5px solid var(--gray-300);background:0 0}.btn-ghost:hover{background:var(--gray-100)}.btn-white{color:#fff;background:#ffffff26;border:1px solid #ffffff4d}.btn-white:hover{background:#ffffff40}.btn-sm{min-height:34px;padding:5px 12px;font-size:12px}.btn-block{width:100%}.fab{background:var(--primary-light);color:#fff;cursor:pointer;z-index:40;border:none;border-radius:50%;justify-content:center;align-items:center;width:56px;height:56px;font-size:26px;transition:all .2s;display:flex;position:fixed;bottom:24px;right:20px;box-shadow:0 4px 12px #3b82f680}.fab:hover{background:var(--primary);transform:scale(1.08)}.fab:active{transform:scale(.95)}.card{border-radius:var(--radius);box-shadow:var(--shadow);background:#fff;overflow:hidden}.card-header{border-bottom:1px solid var(--gray-200);justify-content:space-between;align-items:center;padding:14px 16px;display:flex}.card-title{font-size:15px;font-weight:700}.stats-grid{grid-template-columns:repeat(2,1fr);gap:10px;margin-bottom:16px;display:grid}@media (width>=640px){.stats-grid{grid-template-columns:repeat(4,1fr)}}.stat-card{border-radius:var(--radius);box-shadow:var(--shadow);background:#fff;border-top:3px solid #0000;padding:14px 16px}.stat-card.total{border-color:var(--primary-light)}.stat-card.wip{border-color:var(--warning)}.stat-card.done{border-color:var(--success)}.stat-card.late{border-color:var(--danger)}.stat-label{color:var(--gray-500);text-transform:uppercase;letter-spacing:.5px;font-size:11px;font-weight:700}.stat-value{margin-top:2px;font-size:28px;font-weight:800}.stat-card.total .stat-value{color:var(--primary-light)}.stat-card.wip .stat-value{color:var(--warning)}.stat-card.done .stat-value{color:var(--success)}.stat-card.late .stat-value{color:var(--danger)}.order-list{flex-direction:column;gap:10px;display:flex}.order-card{border-radius:var(--radius);box-shadow:var(--shadow);cursor:pointer;background:#fff;border-left:4px solid #0000;flex-direction:column;gap:6px;padding:14px 16px;transition:box-shadow .15s,transform .1s;display:flex}.order-card:hover{box-shadow:var(--shadow-md);transform:translateY(-1px)}.order-card.overdue{border-color:var(--danger)}.order-card.done{border-color:var(--success)}.order-card.wip{border-color:var(--warning)}.order-card.pending{border-color:var(--gray-300)}.order-card-top{justify-content:space-between;align-items:center;display:flex}.order-number{color:var(--gray-500);font-size:12px;font-weight:600}.order-customer{font-size:15px;font-weight:700}.order-product{color:var(--gray-600);font-size:13px}.order-bottom{justify-content:space-between;align-items:center;gap:8px;display:flex}.order-delivery{color:var(--gray-500);font-size:12px}.order-delivery.warn{color:var(--danger);font-weight:700}.progress-wrap{align-items:center;gap:6px;display:flex}.progress-bar{background:var(--gray-200);border-radius:3px;flex:1;max-width:100px;height:7px;overflow:hidden}.progress-fill{border-radius:3px;height:100%;transition:width .4s}.progress-label{color:var(--gray-500);white-space:nowrap;font-size:11px}.badge{white-space:nowrap;border-radius:999px;align-items:center;padding:3px 10px;font-size:11px;font-weight:700;display:inline-flex}.badge-blue{color:#1e40af;background:#dbeafe}.badge-green{color:#166534;background:#dcfce7}.badge-yellow{color:#92400e;background:#fef3c7}.badge-red{color:#991b1b;background:#fee2e2}.badge-gray{background:var(--gray-100);color:var(--gray-600)}.order-info-grid{grid-template-columns:repeat(2,1fr);gap:8px;margin-bottom:16px;display:grid}@media (width>=640px){.order-info-grid{grid-template-columns:repeat(4,1fr)}}.info-tile{border-radius:var(--radius);box-shadow:var(--shadow);background:#fff;padding:12px 14px}.info-tile-label{color:var(--gray-400);text-transform:uppercase;letter-spacing:.5px;margin-bottom:4px;font-size:10px;font-weight:700}.info-tile-value{color:var(--gray-900);font-size:14px;font-weight:700}.info-tile-value.warn{color:var(--danger)}.process-list{flex-direction:column;display:flex}.process-row{border-bottom:1px solid var(--gray-100);cursor:pointer;align-items:center;gap:12px;padding:13px 16px;transition:background .1s;display:flex}.process-row:last-child{border-bottom:none}.process-row:hover{background:var(--gray-50)}.process-row.completed{background:#f0fdf4}.process-row.overdue-row{background:#fff7f7}.complete-btn{border:2.5px solid var(--gray-300);cursor:pointer;background:#fff;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:36px;height:36px;transition:all .15s;display:flex}.complete-btn:hover{border-color:var(--success)}.complete-btn.done{border-color:var(--success);background:var(--success)}.complete-btn svg{width:16px;height:16px;stroke:var(--gray-300);fill:none;stroke-width:2.5px;stroke-linecap:round;stroke-linejoin:round}.complete-btn.done svg{stroke:#fff}.complete-btn:not(.done):hover svg{stroke:var(--success)}.process-info{flex:1;min-width:0}.process-num{color:var(--gray-400);font-size:11px;font-weight:700}.process-name-text{color:var(--gray-800);font-size:14px;font-weight:600}.process-meta{color:var(--gray-500);flex-wrap:wrap;gap:10px;margin-top:2px;font-size:12px;display:flex}.process-meta .warn{color:var(--danger);font-weight:600}.process-chevron{color:var(--gray-300);flex-shrink:0;font-size:18px}.form-group{margin-bottom:16px}.form-label{color:var(--gray-600);text-transform:uppercase;letter-spacing:.5px;margin-bottom:6px;font-size:12px;font-weight:700;display:block}.form-input{border:1.5px solid var(--gray-300);width:100%;color:var(--gray-900);-webkit-appearance:none;background:#fff;border-radius:8px;min-height:44px;padding:10px 12px;font-family:inherit;font-size:15px;transition:border-color .15s,box-shadow .15s;display:block}.form-input:focus{border-color:var(--primary-light);outline:none;box-shadow:0 0 0 3px #3b82f61f}.form-input::placeholder{color:var(--gray-400)}.form-row{grid-template-columns:1fr 1fr;gap:12px;display:grid}textarea.form-input{resize:vertical;min-height:80px}.complete-toggle{border-radius:var(--radius);border:2px solid var(--gray-300);cursor:pointer;color:var(--gray-600);background:#fff;justify-content:center;align-items:center;gap:10px;width:100%;min-height:52px;padding:14px;font-family:inherit;font-size:15px;font-weight:700;transition:all .15s;display:flex}.complete-toggle.active{border-color:var(--success);color:var(--success);background:#f0fdf4}.complete-toggle:hover{border-color:var(--success)}.modal-backdrop{z-index:100;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px);background:#00000080;justify-content:center;align-items:flex-end;display:none;position:fixed;inset:0}.modal-backdrop.open{display:flex}.modal{width:100%;max-width:600px;max-height:92vh;box-shadow:var(--shadow-lg);background:#fff;border-radius:16px 16px 0 0;animation:.25s slideUp;overflow-y:auto}@keyframes slideUp{0%{opacity:0;transform:translateY(40px)}to{opacity:1;transform:translateY(0)}}@media (width>=640px){.modal-backdrop{align-items:center}.modal{border-radius:16px;max-height:85vh}}.modal-handle{background:var(--gray-300);border-radius:2px;width:40px;height:4px;margin:10px auto 0}.modal-header{border-bottom:1px solid var(--gray-200);justify-content:space-between;align-items:center;padding:16px 20px 14px;display:flex}.modal-title{font-size:16px;font-weight:700}.modal-close{cursor:pointer;color:var(--gray-400);background:0 0;border:none;border-radius:6px;padding:4px;font-size:22px;line-height:1}.modal-close:hover{color:var(--gray-700);background:var(--gray-100)}.modal-body{padding:20px}.modal-footer{border-top:1px solid var(--gray-200);justify-content:flex-end;gap:10px;padding:16px 20px;display:flex}.login-page{background:linear-gradient(135deg, var(--primary-dark) 0%, var(--primary-light) 100%);justify-content:center;align-items:center;min-height:100vh;padding:20px;display:flex}.login-card{width:100%;max-width:380px;box-shadow:var(--shadow-lg);background:#fff;border-radius:16px;padding:32px 28px}.login-icon{text-align:center;margin-bottom:8px;font-size:40px}.login-title{text-align:center;margin-bottom:4px;font-size:20px;font-weight:800}.login-sub{text-align:center;color:var(--gray-500);margin-bottom:24px;font-size:13px}.login-error{color:#991b1b;background:#fee2e2;border-radius:8px;margin-bottom:14px;padding:10px 14px;font-size:13px}.toast{background:var(--gray-900);color:#fff;box-shadow:var(--shadow-lg);z-index:200;white-space:nowrap;border-radius:999px;padding:12px 20px;font-size:13px;font-weight:600;animation:.3s toastIn,.3s 2.5s forwards toastOut;position:fixed;bottom:24px;left:50%;transform:translate(-50%)}.toast-success{background:var(--success)}.toast-error{background:var(--danger)}@keyframes toastIn{0%{opacity:0;transform:translate(-50%)translateY(12px)}to{opacity:1;transform:translate(-50%)translateY(0)}}@keyframes toastOut{0%{opacity:1;transform:translate(-50%)translateY(0)}to{opacity:0;transform:translate(-50%)translateY(4px)}}.empty{text-align:center;color:var(--gray-400);padding:48px 20px}.empty-icon{margin-bottom:10px;font-size:44px}.empty-title{color:var(--gray-500);margin-bottom:4px;font-size:15px;font-weight:600}.empty-sub{font-size:13px}.section-title{justify-content:space-between;align-items:center;margin-bottom:12px;display:flex}.section-title h2{font-size:15px;font-weight:700}::-webkit-scrollbar{width:6px}::-webkit-scrollbar-track{background:0 0}::-webkit-scrollbar-thumb{background:var(--gray-300);border-radius:3px}.app-logo{align-items:center;gap:10px;display:flex}.app-logo-circle{object-fit:cover;border:2px solid #fff6;border-radius:50%;flex-shrink:0;width:36px;height:36px;display:block}.app-logo-text{color:#fff;letter-spacing:.5px;white-space:nowrap;font-size:15px;font-weight:800}.login-brand-wrap{justify-content:center;align-items:center;gap:14px;margin-bottom:16px;display:flex}.login-logo-circle{object-fit:cover;border:3px solid var(--gray-200);border-radius:50%;flex-shrink:0;width:64px;height:64px;display:block;box-shadow:0 2px 8px #0000001f}.login-brand-text{color:var(--gray-900);letter-spacing:.3px;font-size:20px;font-weight:800;line-height:1.2}.btn-icon{color:#fff;cursor:pointer;background:#ffffff26;border:1px solid #ffffff4d;border-radius:8px;justify-content:center;align-items:center;width:34px;height:34px;font-size:16px;transition:background .15s;display:flex}.btn-icon:hover{background:#ffffff47}.form-section-label{color:var(--primary-light);text-transform:uppercase;letter-spacing:1.5px;border-bottom:1.5px solid #e0eaff;margin:20px 0 10px;padding-bottom:6px;font-size:10px;font-weight:800}.form-section-label:first-child{margin-top:0}.form-select{cursor:pointer}.template-preview{background:var(--gray-50);border-radius:8px;margin-top:-4px;margin-bottom:8px;padding:8px}.template-preview-row{background:#fff;border-radius:6px;align-items:center;gap:8px;margin-bottom:3px;padding:5px 6px;font-size:12px;display:flex}.template-preview-row:last-child{margin-bottom:0}.template-preview-num{color:var(--gray-400);min-width:40px;font-weight:700}.template-preview-name{color:var(--gray-800);flex:1;font-weight:600}.template-preview-days{color:var(--gray-500);text-align:right;min-width:30px}.template-preview-deadline{color:var(--primary-light);text-align:right;min-width:48px;font-weight:700}.settings-tabs{border-bottom:2px solid var(--gray-200);margin-bottom:20px;display:flex}.settings-tab-btn{cursor:pointer;color:var(--gray-500);background:0 0;border:none;border-bottom:2px solid #0000;margin-bottom:-2px;padding:10px 14px;font-family:inherit;font-size:13px;font-weight:700;transition:all .15s}.settings-tab-btn.active{color:var(--primary-light);border-bottom-color:var(--primary-light)}.settings-tab-btn:hover:not(.active){color:var(--gray-700)}.settings-list{flex-direction:column;display:flex}.settings-item{border-bottom:1px solid var(--gray-100);background:#fff;align-items:center;gap:10px;padding:12px 16px;display:flex}.settings-item:last-child{border-bottom:none}.settings-item-name{flex:1;font-size:14px;font-weight:600}.proc-tmpl-header{color:var(--gray-400);text-transform:uppercase;letter-spacing:.5px;gap:8px;padding:2px 4px 8px 30px;font-size:10px;font-weight:700;display:flex}.proc-tmpl-row{align-items:center;gap:8px;padding:3px 0;display:flex}.proc-tmpl-num{color:var(--gray-400);text-align:center;flex-shrink:0;min-width:28px;font-size:12px;font-weight:700}.proc-tmpl-name{flex:1}.proc-tmpl-days{text-align:center;flex-shrink:0;width:72px}.proc-tmpl-del{cursor:pointer;width:32px;height:32px;color:var(--gray-300);background:0 0;border:none;border-radius:6px;flex-shrink:0;justify-content:center;align-items:center;font-size:18px;transition:all .1s;display:flex}.proc-tmpl-del:hover:not(:disabled){color:var(--danger);background:#fee2e2}.proc-tmpl-del:disabled{opacity:.3;cursor:not-allowed}.proc-tmpl-total{color:var(--gray-500);text-align:right;padding:8px 4px 0;font-size:12px}.holiday-list{flex-direction:column;gap:6px;display:flex}.holiday-row{box-shadow:var(--shadow);background:#fff;border-radius:8px;align-items:center;gap:10px;padding:8px 12px;display:flex}.holiday-date{color:var(--gray-700);min-width:110px;font-size:13px;font-weight:700}.holiday-day{min-width:20px;font-size:12px;font-weight:700}.holiday-desc{color:var(--gray-500);flex:1;font-size:13px}.holiday-del{cursor:pointer;color:var(--gray-400);background:0 0;border:none;border-radius:4px;padding:2px 6px;font-size:18px;transition:all .1s}.holiday-del:hover{color:var(--danger);background:#fee2e2}.csv-btn{cursor:pointer;background:var(--gray-100);border:1.5px dashed var(--gray-300);color:var(--gray-600);border-radius:8px;align-items:center;gap:6px;padding:7px 12px;font-size:12px;font-weight:600;transition:all .15s;display:inline-flex}.csv-btn:hover{border-color:var(--primary-light);color:var(--primary);background:#dbeafe}.admin-badge{color:#fff;letter-spacing:.5px;white-space:nowrap;background:#ffffff2e;border:1px solid #fff6;border-radius:999px;padding:3px 9px;font-size:10px;font-weight:800}.progress-bar-wide{max-width:120px!important}.order-nums{flex-wrap:wrap;gap:5px;display:flex}.order-num-chip{color:var(--gray-500);background:var(--gray-100);white-space:nowrap;border-radius:4px;padding:2px 7px;font-size:10px;font-weight:700}.order-num-chip.primary{color:var(--primary);background:#dbeafe}.order-customer-wrap{flex-direction:column;gap:1px;margin-top:2px;display:flex}.order-customer-main{font-size:15px;font-weight:700}.order-customer-end{color:var(--gray-500);font-size:12px}.order-tab-group{background:var(--gray-200);border-radius:10px;gap:3px;margin-bottom:16px;padding:3px;display:flex}.order-tab-btn{cursor:pointer;color:var(--gray-500);background:0 0;border:none;border-radius:8px;flex:1;justify-content:center;align-items:center;gap:6px;padding:9px 12px;font-family:inherit;font-size:13px;font-weight:700;transition:all .15s;display:flex}.order-tab-btn.active{color:var(--primary);background:#fff;box-shadow:0 1px 3px #0000001a}.tab-count{background:var(--gray-300);min-width:20px;height:20px;color:var(--gray-600);border-radius:10px;justify-content:center;align-items:center;padding:0 6px;font-size:11px;font-weight:700;display:inline-flex}.order-tab-btn.active .tab-count{background:var(--primary-light);color:#fff}.excel-btn{font-size:12px}.excel-btn:disabled{opacity:.4;cursor:not-allowed}.drag-handle{cursor:grab;color:var(--gray-300);-webkit-user-select:none;user-select:none;touch-action:none;background:0 0;border:none;border-radius:4px;flex-shrink:0;align-items:center;padding:4px 2px;font-family:inherit;font-size:16px;line-height:1;display:inline-flex}.drag-handle:hover{color:var(--gray-500);background:var(--gray-100)}.drag-handle:active{cursor:grabbing}.proc-tmpl-drag{min-width:22px;font-size:14px}.order-info-grid-6{grid-template-columns:repeat(2,1fr);gap:8px;margin-bottom:8px;display:grid}@media (width>=640px){.order-info-grid-6{grid-template-columns:repeat(3,1fr)}}
