*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}html{-webkit-text-size-adjust:100%;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}body{margin:0;padding:0;min-height:100vh;font-family:neue-haas-unica,pragmatica-web,Helvetica Neue,Helvetica,Arial,sans-serif;font-size:14px;line-height:1.5;color:#111827;background-color:#f9fafb}#root{width:100%;min-height:100vh}.page-container{padding:20px;max-width:100%;margin:0 auto}.page-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:24px;padding:16px 20px;background:#fff;border-radius:12px;box-shadow:0 1px 3px #0000001a}.page-title{font-size:24px;font-weight:700;color:#111827;margin:0}.suspense-fallback{min-height:100vh;display:flex;align-items:center;justify-content:center}button{font-family:inherit;cursor:pointer}input,select,textarea{font-family:inherit}.lazy-loading{opacity:0;transition:opacity .2s ease-in}.lazy-loaded{opacity:1}.loading-overlay{position:fixed;inset:0;background:#f9fafbe6;display:flex;align-items:center;justify-content:center;z-index:9999}.loading-spinner{position:relative;width:50px;height:50px}.spinner-ring{position:absolute;width:100%;height:100%;border-radius:50%;border:3px solid transparent}.spinner-ring:nth-child(1){border-top-color:#667eea;animation:spin 1s linear infinite}.spinner-ring:nth-child(2){border-right-color:#764ba2;animation:spin 1s linear infinite .15s}.spinner-ring:nth-child(3){border-bottom-color:#667eea;animation:spin 1s linear infinite .3s}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.toast-container{position:fixed;top:20px;right:20px;z-index:99999;display:flex;flex-direction:column;gap:12px;pointer-events:none}.toast{display:flex;align-items:center;gap:12px;min-width:320px;max-width:500px;padding:16px 20px;background:#fff;border-radius:12px;box-shadow:0 8px 24px #00000026;border-left:4px solid;pointer-events:auto;cursor:pointer;animation:slideIn .3s ease-out;transition:all .2s ease-out}.toast:hover{transform:translate(-4px);box-shadow:0 12px 32px #0003}.toast-success{border-left-color:#10b981;background:linear-gradient(to right,#ecfdf5,#fff)}.toast-error{border-left-color:#ef4444;background:linear-gradient(to right,#fef2f2,#fff)}.toast-warning{border-left-color:#f59e0b;background:linear-gradient(to right,#fffbeb,#fff)}.toast-info{border-left-color:#3b82f6;background:linear-gradient(to right,#eff6ff,#fff)}.toast-icon{width:32px;height:32px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:18px;font-weight:700;flex-shrink:0}.toast-success .toast-icon{background:#10b981;color:#fff}.toast-error .toast-icon{background:#ef4444;color:#fff}.toast-warning .toast-icon{background:#f59e0b;color:#fff}.toast-info .toast-icon{background:#3b82f6;color:#fff}.toast-message{flex:1;font-size:14px;font-weight:500;color:#111827;line-height:1.5;word-break:break-word}.toast-close{width:24px;height:24px;border-radius:50%;border:none;background:#0000000d;color:#6b7280;font-size:20px;font-weight:400;line-height:1;cursor:pointer;display:flex;align-items:center;justify-content:center;flex-shrink:0;transition:all .15s ease-out}.toast-close:hover{background:#0000001a;color:#111827;transform:scale(1.1)}@keyframes slideIn{0%{transform:translate(400px);opacity:0}to{transform:translate(0);opacity:1}}@media(max-width:640px){.toast-container{top:10px;right:10px;left:10px}.toast{min-width:auto;max-width:none;padding:14px 16px}.toast-icon{width:28px;height:28px;font-size:16px}.toast-message{font-size:13px}}@media(prefers-reduced-motion:reduce){.toast{animation:none}.toast:hover{transform:none}}.floating-chat-button{position:fixed;bottom:24px;right:24px;width:60px;height:60px;border-radius:50%;background:linear-gradient(135deg,#667eea,#764ba2);border:none;box-shadow:0 8px 24px #667eea66;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .3s cubic-bezier(.4,0,.2,1);z-index:9998}.floating-chat-button:hover{transform:translateY(-4px) scale(1.05);box-shadow:0 12px 32px #667eea80}.floating-chat-button svg{width:28px;height:28px;color:#fff}.chat-badge{position:absolute;top:-4px;right:-4px;background:#ef4444;color:#fff;font-size:11px;font-weight:700;padding:2px 6px;border-radius:12px;min-width:20px;text-align:center;box-shadow:0 2px 8px #ef444466;animation:pulse 2s infinite}.floating-chatbox{position:fixed;bottom:100px;right:24px;width:380px;height:600px;background:#fff;border-radius:16px;box-shadow:0 12px 48px #00000026;display:flex;flex-direction:column;overflow:hidden;z-index:9999;animation:slideUp .3s ease-out}@keyframes slideUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.chatbox-header{background:linear-gradient(135deg,#667eea,#764ba2);padding:16px 20px;display:flex;justify-content:space-between;align-items:center;flex-shrink:0}.header-left{display:flex;align-items:center;gap:12px}.btn-back-chat{width:32px;height:32px;border-radius:50%;background:#fff3;border:none;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all .2s}.btn-back-chat:hover{background:#ffffff4d}.btn-back-chat svg{width:18px;height:18px;color:#fff}.chatbox-header h3{color:#fff;font-size:18px;font-weight:700;margin:0}.btn-close-chat{width:32px;height:32px;border-radius:50%;background:#fff3;border:none;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all .2s}.btn-close-chat:hover{background:#ffffff4d}.btn-close-chat svg{width:18px;height:18px;color:#fff}.chatbox-body{flex:1;overflow-y:auto;background:#f8f9fa;min-height:0}.chatbox-body::-webkit-scrollbar{width:6px}.chatbox-body::-webkit-scrollbar-track{background:transparent}.chatbox-body::-webkit-scrollbar-thumb{background:#cbd5e0;border-radius:3px}.ticket-list{padding:12px;display:flex;flex-direction:column;gap:8px}.empty-state{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:60px 20px;color:#a0aec0}.empty-state svg{width:64px;height:64px;margin-bottom:16px;opacity:.5}.empty-state p{font-size:15px;margin:0}.ticket-item{background:#fff;padding:14px;border-radius:12px;cursor:pointer;transition:all .2s;border:2px solid transparent}.ticket-item:hover{border-color:#667eea;transform:translateY(-2px);box-shadow:0 4px 12px #667eea26}.ticket-item-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:8px}.ticket-item-id{font-weight:700;color:#667eea;font-size:13px}.ticket-item-time{font-size:11px;color:#a0aec0}.ticket-item-subject{font-size:14px;color:#2d3748;margin:0 0 8px;font-weight:500;overflow:hidden;text-overflow:ellipsis;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical}.ticket-item-order{display:inline-block;font-size:11px;color:#718096;background:#edf2f7;padding:4px 8px;border-radius:6px}.chat-messages-mini{padding:16px;display:flex;flex-direction:column;gap:16px;min-height:400px}.chat-msg{display:flex;gap:10px;max-width:85%;animation:fadeIn .3s ease-out}.chat-msg.msg-mine{align-self:flex-end;flex-direction:row-reverse}.msg-avatar{width:32px;height:32px;border-radius:50%;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;display:flex;align-items:center;justify-content:center;font-weight:700;font-size:13px;flex-shrink:0}.msg-content{flex:1;display:flex;flex-direction:column;gap:4px}.msg-header{display:flex;align-items:center;gap:8px}.msg-mine .msg-header{flex-direction:row-reverse}.msg-author{font-weight:600;font-size:12px;color:#2d3748}.msg-time{font-size:10px;color:#a0aec0}.msg-body{padding:10px 14px;border-radius:12px;font-size:14px;line-height:1.5;word-wrap:break-word}.msg-mine .msg-body{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;border-bottom-right-radius:4px}.msg-other .msg-body{background:#fff;color:#2d3748;border-bottom-left-radius:4px;box-shadow:0 2px 8px #00000014}.chat-input-mini{display:flex;align-items:flex-end;gap:8px;padding:12px 16px;background:#fff;border-top:1px solid #e2e8f0;box-sizing:border-box;width:100%;overflow:hidden}.chat-input-mini textarea{flex:1;min-width:0;padding:10px 14px;border:2px solid #e2e8f0;border-radius:20px;font-size:14px;outline:none;resize:none;min-height:40px;max-height:80px;font-family:inherit;transition:border-color .2s;box-sizing:border-box}.chat-input-mini textarea:focus{border-color:#667eea}.chat-input-mini button{width:40px;height:40px;border-radius:50%;background:linear-gradient(135deg,#667eea,#764ba2);border:none;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all .2s;flex-shrink:0}.chat-input-mini button:hover:not(:disabled){transform:scale(1.05)}.chat-input-mini button:disabled{opacity:.5;cursor:not-allowed}.chat-input-mini button svg{width:18px;height:18px;color:#fff}.chatbox-footer{padding:12px 16px;background:#fff;border-top:1px solid #e2e8f0;flex-shrink:0}.btn-view-full{width:100%;padding:10px;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;border:none;border-radius:8px;font-size:14px;font-weight:600;cursor:pointer;transition:all .2s}.btn-view-full:hover{transform:translateY(-1px);box-shadow:0 4px 12px #667eea4d}.chat-loading{display:flex;align-items:center;justify-content:center;padding:60px 20px}.spinner{width:40px;height:40px;border:3px solid #e2e8f0;border-top-color:#667eea;border-radius:50%;animation:spin .8s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}@media(max-width:768px){.floating-chat-button,.floating-chatbox{display:none!important}}*{font-family:neue-haas-unica,pragmatica-web,Helvetica Neue,Helvetica,Arial,sans-serif}html,body{font-family:neue-haas-unica,pragmatica-web,Helvetica Neue,Helvetica,Arial,sans-serif;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}#root{width:100%;min-height:100vh;font-family:neue-haas-unica,pragmatica-web,Helvetica Neue,Helvetica,Arial,sans-serif}.login-container{height:100vh;width:100vw;display:flex;align-items:center;justify-content:center;position:fixed;top:0;left:0;overflow:hidden;background:linear-gradient(135deg,#667eea,#764ba2);padding:20px;box-sizing:border-box}.login-background{position:absolute;width:100%;height:100%;overflow:hidden}.gradient-orb{position:absolute;border-radius:50%;filter:blur(80px);opacity:.5;animation:float 20s infinite ease-in-out}.orb-1{width:500px;height:500px;background:#9333ea66;top:-10%;left:-10%;animation-delay:0s}.orb-2{width:400px;height:400px;background:#a855f766;bottom:-10%;right:-10%;animation-delay:7s}.orb-3{width:350px;height:350px;background:#c084fc4d;top:50%;left:50%;transform:translate(-50%,-50%);animation-delay:14s}@keyframes float{0%,to{transform:translate(0) scale(1)}33%{transform:translate(30px,-30px) scale(1.1)}66%{transform:translate(-20px,20px) scale(.9)}}.login-card{position:relative;z-index:10;background:#fffffff2;-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);border-radius:24px;padding:40px 36px;width:100%;max-width:420px;max-height:calc(100vh - 40px);overflow-y:auto;box-shadow:0 20px 60px #0000004d;animation:slideUp .6s ease-out;box-sizing:border-box}.login-card::-webkit-scrollbar{width:6px}.login-card::-webkit-scrollbar-track{background:#0000000d;border-radius:10px}.login-card::-webkit-scrollbar-thumb{background:#8b5cf64d;border-radius:10px}.login-card::-webkit-scrollbar-thumb:hover{background:#8b5cf680}.login-header{text-align:center;margin-bottom:32px}.logo{width:100px;height:auto;margin-bottom:20px;animation:fadeIn .8s ease-out}@keyframes fadeIn{0%{opacity:0;transform:scale(.8)}to{opacity:1;transform:scale(1)}}.login-header h1{font-size:24px;font-weight:700;color:#1f2937;margin:0 0 6px;background:linear-gradient(135deg,#667eea,#764ba2);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.login-header p{font-size:13px;color:#6b7280;margin:0}.login-form{display:flex;flex-direction:column;gap:20px}.form-group{display:flex;flex-direction:column;gap:6px}.form-group label{font-size:14px;font-weight:600;color:#374151}.input-wrapper{position:relative;width:100%}.input-icon{position:absolute!important;left:16px!important;top:50%!important;transform:translateY(-50%)!important;width:20px!important;height:20px!important;color:#9ca3af!important;pointer-events:none!important;z-index:10!important}.login-form .input-wrapper input{width:100%!important;padding:14px 16px 14px 48px!important;font-size:15px!important;border:2px solid #e5e7eb!important;border-radius:12px!important;outline:none!important;transition:all .3s ease!important;background:#fff!important;box-sizing:border-box!important}.login-form .input-wrapper input:focus{border-color:#8b5cf6!important;box-shadow:0 0 0 4px #8b5cf61a!important}.login-form .input-wrapper input:disabled{background:#f9fafb!important;cursor:not-allowed!important;opacity:.6!important}.login-form .input-wrapper input::placeholder{color:#9ca3af!important}.form-options{display:flex;justify-content:space-between;align-items:center;margin-top:-8px}.checkbox-label{display:flex;align-items:center;gap:8px;font-size:14px;color:#4b5563;cursor:pointer;-webkit-user-select:none;user-select:none}.checkbox-label input[type=checkbox]{width:18px;height:18px;cursor:pointer;accent-color:#8b5cf6}.forgot-password{font-size:14px;color:#8b5cf6;text-decoration:none;font-weight:600;transition:color .2s ease}.forgot-password:hover{color:#7c3aed}.login-button{width:100%;padding:16px;font-size:16px;font-weight:600;color:#fff;background:linear-gradient(135deg,#667eea,#764ba2);border:none;border-radius:12px;cursor:pointer;transition:all .3s ease;box-shadow:0 4px 12px #667eea66}.login-button:hover{transform:translateY(-2px);box-shadow:0 6px 20px #667eea80}.login-button:active{transform:translateY(0)}.login-button:disabled{opacity:.7;cursor:not-allowed;transform:none}.error-message{display:flex;align-items:center;gap:12px;padding:12px 16px;background:#fef2f2;border:1px solid #fecaca;border-radius:8px;color:#991b1b;font-size:14px;animation:shake .4s ease-in-out}@keyframes shake{0%,to{transform:translate(0)}25%{transform:translate(-10px)}75%{transform:translate(10px)}}.error-icon{width:20px;height:20px;flex-shrink:0;color:#dc2626}.login-footer{margin-top:32px;text-align:center}.login-footer p{font-size:12px;color:#9ca3af;margin:0}@media(max-width:768px){.login-container{padding:16px}.login-card{padding:32px 28px;max-width:100%;border-radius:20px}.login-header{margin-bottom:28px}.login-header h1{font-size:22px}.logo{width:90px;margin-bottom:16px}.gradient-orb{filter:blur(60px)}.login-form{gap:18px}}@media(max-width:480px){.login-container{padding:12px}.login-card{padding:28px 24px;border-radius:18px}.login-header{margin-bottom:24px}.login-header h1{font-size:20px}.login-header p{font-size:12px}.logo{width:80px;margin-bottom:14px}.login-form{gap:16px}.login-form .input-wrapper input{padding:12px 14px 12px 44px!important;font-size:14px!important}.input-icon{left:14px!important;width:18px!important;height:18px!important}.login-button{padding:14px;font-size:15px}.form-options{flex-direction:column;align-items:flex-start;gap:12px}.login-footer{margin-top:24px}.gradient-orb{filter:blur(50px)}.orb-1{width:300px;height:300px}.orb-2{width:250px;height:250px}.orb-3{width:200px;height:200px}}@media(max-width:360px){.login-card{padding:24px 20px}.login-header h1{font-size:18px}.logo{width:70px}}.forbidden-container{min-height:100vh;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,#6366f1,#a855f7);padding:20px}.forbidden-content{text-align:center;background:#fff;padding:60px 40px;border-radius:24px;box-shadow:0 20px 60px #0000004d;max-width:500px;width:100%;animation:slideUp .5s ease-out}@keyframes pulse{0%,to{transform:scale(1)}50%{transform:scale(1.1)}}.forbidden-title{font-size:72px;font-weight:700;background:linear-gradient(135deg,#6366f1,#a855f7);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;margin:0 0 10px}.forbidden-subtitle{font-size:28px;font-weight:600;color:#1f2937;margin:0 0 16px}.forbidden-message{font-size:16px;color:#6b7280;margin:0 0 32px;line-height:1.6}.forbidden-actions{display:flex;gap:12px;justify-content:center;flex-wrap:wrap}.btn-primary{background:linear-gradient(135deg,#6366f1,#a855f7);color:#fff;box-shadow:0 4px 12px #6366f166}.btn-primary:hover{transform:translateY(-2px);box-shadow:0 6px 20px #6366f180}.btn-secondary:hover{background:#f9fafb;border-color:#6366f1;color:#6366f1}@media(max-width:640px){.forbidden-content{padding:40px 30px}.forbidden-title{font-size:56px}.forbidden-subtitle{font-size:24px}.forbidden-message{font-size:14px}.forbidden-actions{flex-direction:column}.btn{width:100%}}.notfound-container{min-height:100vh;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,#f59e0b,#d97706);padding:20px}.notfound-content{text-align:center;background:#fff;padding:60px 40px;border-radius:24px;box-shadow:0 20px 60px #0000004d;max-width:500px;width:100%;animation:slideUp .5s ease-out}@keyframes slideUp{0%{opacity:0;transform:translateY(30px)}to{opacity:1;transform:translateY(0)}}.notfound-icon{font-size:80px;margin-bottom:20px;animation:float 3s ease-in-out infinite}@keyframes float{0%,to{transform:translateY(0)}50%{transform:translateY(-20px)}}.notfound-title{font-size:72px;font-weight:700;background:linear-gradient(135deg,#f59e0b,#d97706);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;margin:0 0 10px}.notfound-subtitle{font-size:28px;font-weight:600;color:#1f2937;margin:0 0 16px}.notfound-message{font-size:16px;color:#6b7280;margin:0 0 32px;line-height:1.6}.notfound-actions{display:flex;gap:12px;justify-content:center;flex-wrap:wrap}.btn{padding:12px 24px;border-radius:12px;font-size:15px;font-weight:600;cursor:pointer;transition:all .3s ease;border:none;outline:none}.btn-primary{background:linear-gradient(135deg,#f59e0b,#d97706);color:#fff;box-shadow:0 4px 12px #f59e0b66}.btn-primary:hover{transform:translateY(-2px);box-shadow:0 6px 20px #f59e0b80}.btn-secondary{background:#fff;color:#374151;border:2px solid #e5e7eb}.btn-secondary:hover{background:#f9fafb;border-color:#f59e0b;color:#f59e0b}@media(max-width:640px){.notfound-content{padding:40px 30px}.notfound-icon{font-size:60px}.notfound-title{font-size:56px}.notfound-subtitle{font-size:24px}.notfound-message{font-size:14px}.notfound-actions{flex-direction:column}.btn{width:100%}}
