:root{--bg:#f8f8f8;--bg-elev:#fff;--bg-soft:#f3f4f6;--border:#e5e7eb;--border-strong:#d1d5db;--text:#111827;--text-muted:#6b7280;--text-subtle:#9ca3af;--primary:#111827;--primary-hover:#1f2937;--accent:#2563eb;--success:#16a34a;--warning:#d97706;--danger:#dc2626;--radius:10px;--radius-lg:14px;--shadow-sm:0 1px 3px #0000000f;--shadow:0 2px 8px #00000012,0 1px 3px #0000000d;--shadow-lg:0 8px 24px #00000017,0 2px 8px #0000000f;--shadow-xl:0 20px 48px #0000001f,0 4px 12px #00000014}*{box-sizing:border-box;margin:0;padding:0}body,html{-webkit-font-smoothing:antialiased;background:#f8f8f8;background:var(--bg);color:#111827;color:var(--text);font-family:Sarabun,Inter,-apple-system,BlinkMacSystemFont,sans-serif;font-size:14px;line-height:1.5}button{background:none;border:none;cursor:pointer;font-family:inherit}input,select,textarea{font-family:inherit;font-size:14px}a{color:inherit;text-decoration:none}.app-layout{display:flex;min-height:100vh}.sidebar{background:#fff;background:var(--bg-elev);border-right:1px solid #e5e7eb;border-right:1px solid var(--border);height:100vh;overflow-y:auto;padding:24px 16px;position:fixed;width:240px}.main-content{background:#f8f8f8;background:var(--bg);flex:1 1;margin-left:240px;max-width:100%;min-height:100vh;padding:32px 40px}.sidebar-brand{align-items:center;background:linear-gradient(135deg,#c81c1c,#dc2626 60%,#b91c1c);border-radius:0;display:flex;gap:10px;margin:-24px -16px 16px;padding:20px 16px 18px;position:relative}.sidebar-brand:after{background:#fff;background:var(--bg-elev);border-radius:12px 12px 0 0;bottom:-10px;content:"";height:12px;left:0;position:absolute;right:0}.sidebar-logo-wrap{align-items:center;display:flex;flex-shrink:0;height:42px;justify-content:center;width:42px}.sidebar-logo-wrap img{filter:drop-shadow(0 1px 4px rgba(0,0,0,.18));height:100%;object-fit:contain;width:100%}.sidebar-brand-text{display:flex;flex-direction:column;gap:1px;min-width:0}.sidebar-brand-name{color:#fff;font-size:13px;font-weight:800;letter-spacing:-.01em;line-height:1.2;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.sidebar-brand-sub{color:#ffffffb3;font-size:10px;font-weight:500;letter-spacing:.04em;text-transform:uppercase}.sidebar-nav{display:flex;flex-direction:column;gap:2px}.nav-item{align-items:center;border-radius:10px;color:#6b7280;color:var(--text-muted);cursor:pointer;display:flex;font-size:13.5px;font-weight:500;gap:12px;padding:10px 13px;position:relative;transition:all .15s}.nav-item:hover{background:#f3f4f6;background:var(--bg-soft);color:#111827;color:var(--text)}.nav-item.active{background:linear-gradient(135deg,#dc2626,#b91c1c);box-shadow:0 2px 8px #dc26264d;color:#fff}.sidebar-footer{border-top:1px solid #e5e7eb;border-top:1px solid var(--border);bottom:16px;left:16px;padding-top:16px;position:absolute;right:16px}.user-card{border-radius:10px;border-radius:var(--radius);gap:10px;padding:8px}.avatar,.user-card{align-items:center;display:flex}.avatar{background:#111827;background:var(--primary);border-radius:50%;color:#fff;flex-shrink:0;font-size:13px;font-weight:600;height:36px;justify-content:center;width:36px}.user-info{flex:1 1;min-width:0}.user-name{font-size:13px;font-weight:600;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.user-role{color:#6b7280;color:var(--text-muted);font-size:11px;letter-spacing:.04em;text-transform:uppercase}.page-header{align-items:center;display:flex;gap:16px;justify-content:space-between;margin-bottom:24px}.page-title{color:#111827;color:var(--text);font-size:22px;font-weight:800;letter-spacing:-.03em;margin-bottom:3px}.page-subtitle{color:#6b7280;color:var(--text-muted);font-size:13px}.card{background:#fff;background:var(--bg-elev);border:1px solid #e5e7eb;border:1px solid var(--border);border-radius:14px;border-radius:var(--radius-lg);box-shadow:0 1px 3px #0000000f;box-shadow:var(--shadow-sm);padding:20px;transition:box-shadow .2s,border-color .2s}.card:hover{border-color:#d1d5db;border-color:var(--border-strong);box-shadow:0 2px 8px #00000012,0 1px 3px #0000000d;box-shadow:var(--shadow)}.stat-card{background:#fff;background:var(--bg-elev);border:1px solid #e5e7eb;border:1px solid var(--border);border-radius:14px;border-radius:var(--radius-lg);padding:20px}.stat-label{align-items:center;color:#6b7280;color:var(--text-muted);display:flex;font-size:13px;gap:6px;margin-bottom:8px}.stat-value{font-size:28px;font-weight:700;letter-spacing:-.02em}.stat-change{color:#6b7280;color:var(--text-muted);font-size:12px;margin-top:6px}.grid{grid-gap:16px;display:grid;gap:16px}.grid-cols-2{grid-template-columns:repeat(2,1fr)}.grid-cols-3{grid-template-columns:repeat(3,1fr)}.grid-cols-4{grid-template-columns:repeat(4,1fr)}@media (max-width:1024px){.main-content{padding:24px}.grid-cols-3,.grid-cols-4{grid-template-columns:repeat(2,1fr)}}@media (max-width:768px){.grid-cols-2,.grid-cols-3,.grid-cols-4{grid-template-columns:1fr}.sidebar{box-shadow:4px 0 24px #0000002e;max-width:320px;transform:translateX(-100%);transition:transform .28s cubic-bezier(.4,0,.2,1);width:100vw!important;z-index:600}.sidebar.open{transform:translateX(0)}.mobile-header,.sidebar-close-btn{display:flex!important}.main-content{margin-left:0!important;padding:76px 14px 28px}.modal{animation:slideUp .28s cubic-bezier(.4,0,.2,1);border:none;border-radius:22px 22px 0 0;border-top:1px solid #e5e7eb;border-top:1px solid var(--border);bottom:0;left:0;margin:0;max-height:94vh;max-width:100%!important;overflow-y:auto;position:fixed;right:0;width:100%}@keyframes slideUp{0%{transform:translateY(100%)}to{transform:translateY(0)}}.modal-header{border-radius:22px 22px 0 0}.modal-overlay{align-items:flex-end;padding:0}.modal:before{background:#d1d5db;background:var(--border-strong);border-radius:2px;content:"";display:block;height:4px;margin:10px auto 2px;width:40px}.table-wrap{-webkit-overflow-scrolling:touch;overflow-x:auto}.page-header{align-items:flex-start;flex-direction:column;gap:10px;margin-bottom:18px}.page-header>:last-child{width:100%}.page-header .btn{justify-content:center;width:100%}.card{padding:16px}.btn{min-height:44px}.btn-sm{min-height:36px}.nav-item{min-height:48px;padding:13px 14px}.form-input,.form-select,.form-textarea{font-size:16px;padding:12px 13px}.search-bar input{font-size:16px}}.mobile-header{align-items:center;background:#fff;border-bottom:1px solid #e5e7eb;box-shadow:0 1px 6px #00000012;display:none;gap:8px;height:58px;left:0;padding:0 14px;position:fixed;right:0;top:0;z-index:500}.mobile-menu-btn{-webkit-tap-highlight-color:transparent;align-items:center;background:#f3f4f6;border:1px solid #e5e7eb;border-radius:12px;cursor:pointer;display:flex;flex-shrink:0;height:42px;justify-content:center;padding:0;transition:background .15s;width:42px}.mobile-menu-btn:active{background:#e5e7eb;transform:scale(.95)}.sidebar-close-btn{align-items:center;background:#ffffff26;border:none;border-radius:50%;color:#fff;cursor:pointer;display:none;height:36px;justify-content:center;position:absolute;right:14px;top:14px;transition:background .15s;width:36px;z-index:10}.sidebar-close-btn:hover{background:#ffffff40}.sidebar-overlay{-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px);background:#0000007a;display:none;inset:0;position:fixed;z-index:599}@media (max-width:768px){.sidebar-overlay.active{display:block}}.desktop-bell{display:flex}@media (max-width:768px){.desktop-bell{display:none}}.btn{align-items:center;border:1px solid #0000;border-radius:10px;border-radius:var(--radius);display:inline-flex;font-size:14px;font-weight:600;gap:6px;justify-content:center;letter-spacing:-.01em;padding:9px 16px;transition:all .15s}.btn-primary{background:linear-gradient(135deg,#1f2937,#111827);box-shadow:0 1px 4px #0000002e;color:#fff}.btn-primary:hover{background:linear-gradient(135deg,#374151,#1f2937);box-shadow:0 2px 8px #00000038;transform:translateY(-1px)}.btn-primary:active{transform:translateY(0)}.btn-secondary{background:#fff;background:var(--bg-elev);border-color:#e5e7eb;border-color:var(--border);box-shadow:0 1px 3px #0000000f;box-shadow:var(--shadow-sm);color:#111827;color:var(--text)}.btn-secondary:hover{background:#f3f4f6;background:var(--bg-soft);border-color:#d1d5db;border-color:var(--border-strong)}.btn-danger{background:linear-gradient(135deg,#dc2626,#b91c1c);box-shadow:0 1px 4px #dc262640;color:#fff}.btn-danger:hover{background:linear-gradient(135deg,#b91c1c,#991b1b);box-shadow:0 2px 8px #dc26264d;transform:translateY(-1px)}.btn-ghost{background:#0000;border-color:#0000;color:#6b7280;color:var(--text-muted)}.btn-ghost:hover{background:#f3f4f6;background:var(--bg-soft);border-color:#e5e7eb;border-color:var(--border);color:#111827;color:var(--text)}.btn-sm{font-size:12px;padding:6px 11px}.form-group{display:flex;flex-direction:column;gap:6px;margin-bottom:16px}.form-label{color:#111827;color:var(--text);font-size:12.5px;font-weight:600;letter-spacing:.01em}.form-input,.form-select,.form-textarea{background:#fff;background:var(--bg-elev);border:1.5px solid #e5e7eb;border:1.5px solid var(--border);border-radius:10px;border-radius:var(--radius);color:#111827;color:var(--text);font-size:14px;padding:10px 13px;transition:border .15s,box-shadow .15s;width:100%}.form-input:focus,.form-select:focus,.form-textarea:focus{border-color:#2563eb;box-shadow:0 0 0 3px #2563eb1a;outline:none}.form-input::placeholder{color:#9ca3af;color:var(--text-subtle)}.form-textarea{min-height:80px;resize:vertical}.form-error{color:#dc2626;color:var(--danger);font-size:12px;margin-top:4px}.table-wrap{background:#fff;background:var(--bg-elev);border:1px solid #e5e7eb;border:1px solid var(--border);border-radius:14px;border-radius:var(--radius-lg);overflow:hidden}.table{border-collapse:collapse;width:100%}.table th{background:#f3f4f6;background:var(--bg-soft);border-bottom:1.5px solid #e5e7eb;border-bottom:1.5px solid var(--border);color:#6b7280;color:var(--text-muted);font-size:11px;font-weight:700;letter-spacing:.06em;padding:11px 16px;text-align:left;text-transform:uppercase}.table td{border-bottom:1px solid #e5e7eb;border-bottom:1px solid var(--border);font-size:13.5px;padding:13px 16px}.table tr:last-child td{border-bottom:none}.table tr:hover td{background:#fafafa;transition:background .1s}.badge{align-items:center;border-radius:999px;display:inline-flex;font-size:11px;font-weight:700;letter-spacing:.03em;padding:3px 10px}.badge-lead{background:#dbeafe;color:#1d4ed8}.badge-prospect{background:#fef3c7;color:#92400e}.badge-customer{background:#dcfce7;color:#15803d}.badge-inactive{background:#f3f4f6;color:#4b5563}.search-bar{max-width:320px;position:relative}.search-bar input{background:#fff;background:var(--bg-elev);border:1.5px solid #e5e7eb;border:1.5px solid var(--border);border-radius:10px;border-radius:var(--radius);font-size:13.5px;padding:9px 12px 9px 38px;transition:border .15s,box-shadow .15s;width:100%}.search-bar input:focus{border-color:#2563eb;box-shadow:0 0 0 3px #2563eb1a;outline:none}.search-bar svg{color:#6b7280;color:var(--text-muted);left:12px;position:absolute;top:50%;transform:translateY(-50%)}.modal-overlay{align-items:center;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);background:#00000073;display:flex;inset:0;justify-content:center;padding:20px;position:fixed;z-index:50}.modal{background:#fff;background:var(--bg-elev);border:1px solid #e5e7eb;border:1px solid var(--border);border-radius:18px;box-shadow:0 20px 48px #0000001f,0 4px 12px #00000014;box-shadow:var(--shadow-xl);max-height:90vh;max-width:600px;overflow-y:auto;width:100%}.modal-header{align-items:center;background:#f3f4f6;background:var(--bg-soft);border-bottom:1px solid #e5e7eb;border-bottom:1px solid var(--border);border-radius:18px 18px 0 0;display:flex;justify-content:space-between;padding:20px 24px}.modal-title{font-size:16px;font-weight:700;letter-spacing:-.01em}.modal-body{padding:24px}.modal-footer{border-top:1px solid #e5e7eb;border-top:1px solid var(--border);display:flex;gap:8px;justify-content:flex-end;padding:16px 24px}.auth-page{align-items:center;background:linear-gradient(135deg,#bfdbfe,#dbeafe 50%,#eff6ff);display:flex;justify-content:center;min-height:100vh;padding:20px}.auth-card{background:#fff;border-radius:16px;box-shadow:0 8px 32px #2563eb1f,0 2px 8px #00000014;max-width:420px;overflow:hidden;width:100%}.auth-header{align-items:center;background:linear-gradient(135deg,#c81c1c,#dc2626 60%,#b91c1c);display:flex;flex-direction:column;gap:14px;padding:28px 32px 24px;position:relative}.auth-header:after{background:#fff;border-radius:20px 20px 0 0;bottom:-1px;content:"";height:20px;left:0;position:absolute;right:0}.auth-logo-wrap{align-items:center;display:flex;height:110px;justify-content:center;width:110px}.auth-logo-wrap img{filter:drop-shadow(0 2px 8px rgba(0,0,0,.18));height:100%;object-fit:contain;width:100%}.auth-logo-placeholder{color:#ffffffb3;height:36px;width:36px}.auth-header-title{color:#fff;font-size:22px;font-weight:900;letter-spacing:.02em;text-align:center;text-transform:uppercase;white-space:nowrap}.auth-body{padding:28px 32px 32px}.auth-title{color:#111827;color:var(--text);font-size:17px;font-weight:700;margin-bottom:2px}.auth-subtitle{color:#6b7280;color:var(--text-muted);font-size:13px;margin-bottom:22px}.auth-divider{border:none;border-top:1px solid #e5e7eb;border-top:1px solid var(--border);margin:20px 0}.btn-auth{align-items:center;background:linear-gradient(135deg,#dc2626,#b91c1c);border:none;border-radius:10px;border-radius:var(--radius);box-shadow:0 2px 8px #dc26264d;color:#fff;cursor:pointer;display:inline-flex;font-size:14px;font-weight:600;gap:6px;justify-content:center;margin-top:8px;padding:11px 14px;transition:all .15s;width:100%}.btn-auth:hover{background:linear-gradient(135deg,#b91c1c,#991b1b);box-shadow:0 4px 12px #dc262666}.btn-auth:disabled{cursor:not-allowed;opacity:.6}.auth-link-row{color:#6b7280;color:var(--text-muted);font-size:13px;margin-top:18px;text-align:center}.auth-link-row a{color:#dc2626;font-weight:600}.auth-link-row a:hover{color:#b91c1c;text-decoration:underline}.auth-demo-box{background:#eff6ff;border:1px solid #bfdbfe;border-radius:10px;border-radius:var(--radius);color:#1e40af;font-size:12px;margin-top:16px;padding:12px 14px}.auth-demo-box .demo-title{color:#1d4ed8;font-weight:700;margin-bottom:4px}.auth-body .form-input:focus,.auth-body .form-select:focus,.auth-body .form-textarea:focus{border-color:#dc2626;box-shadow:0 0 0 3px #dc26261a;outline:none}.notif-bell{border-radius:10px;border-radius:var(--radius);color:#6b7280;color:var(--text-muted);cursor:pointer;padding:8px;position:relative}.notif-bell:hover{background:#f3f4f6;background:var(--bg-soft);color:#111827;color:var(--text)}.notif-badge{align-items:center;background:#dc2626;background:var(--danger);border-radius:999px;color:#fff;display:flex;font-size:10px;font-weight:700;height:16px;justify-content:center;min-width:16px;padding:0 4px;position:absolute;right:4px;top:4px}.notif-dropdown{background:#fff;background:var(--bg-elev);border:1px solid #e5e7eb;border:1px solid var(--border);border-radius:14px;border-radius:var(--radius-lg);box-shadow:0 8px 24px #00000017,0 2px 8px #0000000f;box-shadow:var(--shadow-lg);max-height:480px;overflow-y:auto;position:absolute;right:0;top:calc(100% + 8px);width:360px;z-index:40}.notif-item{border-bottom:1px solid #e5e7eb;border-bottom:1px solid var(--border);cursor:pointer;padding:14px 16px;transition:background .15s}.notif-item:hover{background:#f3f4f6;background:var(--bg-soft)}.notif-item.unread{background:#eff6ff}.notif-item:last-child{border-bottom:none}.notif-item-title{font-size:13px;font-weight:600;margin-bottom:2px}.notif-item-msg{color:#6b7280;color:var(--text-muted);font-size:13px}.notif-item-time{color:#9ca3af;color:var(--text-subtle);font-size:11px;margin-top:4px}.customer-card{background:#fff;background:var(--bg-elev);border:1.5px solid #e5e7eb;border:1.5px solid var(--border);border-radius:14px;border-radius:var(--radius-lg);cursor:pointer;display:flex;flex-direction:column;height:300px;overflow:hidden;transition:all .2s}.customer-card:hover{border-color:#dc2626;box-shadow:0 4px 20px #dc26261f,0 2px 8px #00000012,0 1px 3px #0000000d;box-shadow:0 4px 20px #dc26261f,var(--shadow);transform:translateY(-2px)}.customer-card-img{object-fit:cover}.customer-card-img,.customer-card-img-placeholder{background:#f3f4f6;background:var(--bg-soft);flex-shrink:0;height:120px;width:100%}.customer-card-img-placeholder{align-items:center;color:#9ca3af;color:var(--text-subtle);display:flex;justify-content:center}.customer-card-body{display:flex;flex:1 1;flex-direction:column;min-height:0;overflow:hidden;padding:14px}.customer-card-title{font-size:15px;font-weight:600;margin-bottom:4px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.customer-card-meta{align-items:center;display:flex;font-size:12px;gap:6px;margin-bottom:4px}.customer-card-meta,.empty-state{color:#6b7280;color:var(--text-muted)}.empty-state{padding:64px 24px;text-align:center}.empty-state-icon{align-items:center;background:#f3f4f6;background:var(--bg-soft);border-radius:50%;color:#9ca3af;color:var(--text-subtle);display:flex;height:56px;justify-content:center;margin:0 auto 16px;width:56px}.map-container{border:1px solid #e5e7eb;border:1px solid var(--border);border-radius:10px;border-radius:var(--radius);height:320px;overflow:hidden}.toast{animation:slideIn .25s cubic-bezier(.34,1.56,.64,1);background:#111827;background:var(--text);border-radius:12px;box-shadow:0 20px 48px #0000001f,0 4px 12px #00000014;box-shadow:var(--shadow-xl);color:#fff;font-size:14px;font-weight:500;min-width:200px;padding:13px 18px;position:fixed;right:20px;top:20px;z-index:1000}.toast-success{background:linear-gradient(135deg,#16a34a,#15803d)}.toast-error{background:linear-gradient(135deg,#dc2626,#b91c1c)}@keyframes slideIn{0%{opacity:0;transform:translateX(24px) scale(.95)}to{opacity:1;transform:translateX(0) scale(1)}}.spinner{animation:spin .6s linear infinite;border:2px solid #e5e7eb;border-top-color:#111827;border:2px solid var(--border);border-radius:50%;border-top-color:var(--primary);height:24px;width:24px}@keyframes spin{to{transform:rotate(1turn)}}.loading-page{justify-content:center;min-height:100vh}.loading-page,.topbar{align-items:center;display:flex}.topbar{justify-content:space-between;margin-bottom:28px;position:relative}.topbar-actions{align-items:center;display:flex;gap:8px}.timeline{padding-left:24px;position:relative}.timeline:before{background:#e5e7eb;background:var(--border);bottom:4px;content:"";left:7px;position:absolute;top:4px;width:1px}.timeline-item{padding-bottom:20px;position:relative}.timeline-item:before{background:#fff;background:var(--bg-elev);border:2px solid #111827;border:2px solid var(--primary);border-radius:50%;content:"";height:12px;left:-21px;position:absolute;top:4px;width:12px}.timeline-date{color:#6b7280;color:var(--text-muted);font-size:12px;margin-bottom:4px}.timeline-content{font-size:14px}.flex{display:flex}.flex-between{align-items:center;display:flex;justify-content:space-between}.gap-2{gap:8px}.gap-3{gap:12px}.gap-4{gap:16px}.mb-3{margin-bottom:12px}.mb-4{margin-bottom:16px}.mb-6{margin-bottom:24px}.text-muted{color:#6b7280;color:var(--text-muted)}.text-sm{font-size:13px}.font-semibold{font-weight:600}.scan-two-col{display:flex;flex:1 1;overflow:hidden}@media (max-width:900px){.scan-two-col{flex-direction:column;overflow:auto}.scan-two-col>*{border-right:none!important;flex:0 0 auto!important;max-width:100%!important}.scan-two-col>:first-child{border-bottom:1px solid #e5e7eb;border-bottom:1px solid var(--border);max-height:45vh}}.items-scroll{-webkit-overflow-scrolling:touch;overflow-x:auto}.items-scroll>*{min-width:720px}@media (max-width:640px){.invoice-row{flex-wrap:wrap!important;row-gap:6px}}