:root{--toastify-color-light: #fff;--toastify-color-dark: #121212;--toastify-color-info: #3498db;--toastify-color-success: #07bc0c;--toastify-color-warning: #f1c40f;--toastify-color-error: hsl(6, 78%, 57%);--toastify-color-transparent: rgba(255, 255, 255, .7);--toastify-icon-color-info: var(--toastify-color-info);--toastify-icon-color-success: var(--toastify-color-success);--toastify-icon-color-warning: var(--toastify-color-warning);--toastify-icon-color-error: var(--toastify-color-error);--toastify-container-width: fit-content;--toastify-toast-width: 320px;--toastify-toast-offset: 16px;--toastify-toast-top: max(var(--toastify-toast-offset), env(safe-area-inset-top));--toastify-toast-right: max(var(--toastify-toast-offset), env(safe-area-inset-right));--toastify-toast-left: max(var(--toastify-toast-offset), env(safe-area-inset-left));--toastify-toast-bottom: max(var(--toastify-toast-offset), env(safe-area-inset-bottom));--toastify-toast-background: #fff;--toastify-toast-padding: 14px;--toastify-toast-min-height: 64px;--toastify-toast-max-height: 800px;--toastify-toast-bd-radius: 6px;--toastify-toast-shadow: 0px 4px 12px rgba(0, 0, 0, .1);--toastify-font-family: sans-serif;--toastify-z-index: 9999;--toastify-text-color-light: #757575;--toastify-text-color-dark: #fff;--toastify-text-color-info: #fff;--toastify-text-color-success: #fff;--toastify-text-color-warning: #fff;--toastify-text-color-error: #fff;--toastify-spinner-color: #616161;--toastify-spinner-color-empty-area: #e0e0e0;--toastify-color-progress-light: linear-gradient(to right, #4cd964, #5ac8fa, #007aff, #34aadc, #5856d6, #ff2d55);--toastify-color-progress-dark: #bb86fc;--toastify-color-progress-info: var(--toastify-color-info);--toastify-color-progress-success: var(--toastify-color-success);--toastify-color-progress-warning: var(--toastify-color-warning);--toastify-color-progress-error: var(--toastify-color-error);--toastify-color-progress-bgo: .2}.Toastify__toast-container{z-index:var(--toastify-z-index);-webkit-transform:translate3d(0,0,var(--toastify-z-index));position:fixed;width:var(--toastify-container-width);box-sizing:border-box;color:#fff;display:flex;flex-direction:column}.Toastify__toast-container--top-left{top:var(--toastify-toast-top);left:var(--toastify-toast-left)}.Toastify__toast-container--top-center{top:var(--toastify-toast-top);left:50%;transform:translate(-50%);align-items:center}.Toastify__toast-container--top-right{top:var(--toastify-toast-top);right:var(--toastify-toast-right);align-items:end}.Toastify__toast-container--bottom-left{bottom:var(--toastify-toast-bottom);left:var(--toastify-toast-left)}.Toastify__toast-container--bottom-center{bottom:var(--toastify-toast-bottom);left:50%;transform:translate(-50%);align-items:center}.Toastify__toast-container--bottom-right{bottom:var(--toastify-toast-bottom);right:var(--toastify-toast-right);align-items:end}.Toastify__toast{--y: 0;position:relative;touch-action:none;width:var(--toastify-toast-width);min-height:var(--toastify-toast-min-height);box-sizing:border-box;margin-bottom:1rem;padding:var(--toastify-toast-padding);border-radius:var(--toastify-toast-bd-radius);box-shadow:var(--toastify-toast-shadow);max-height:var(--toastify-toast-max-height);font-family:var(--toastify-font-family);z-index:0;display:flex;flex:1 auto;align-items:center;word-break:break-word}@media only screen and (max-width: 480px){.Toastify__toast-container{width:100vw;left:env(safe-area-inset-left);margin:0}.Toastify__toast-container--top-left,.Toastify__toast-container--top-center,.Toastify__toast-container--top-right{top:env(safe-area-inset-top);transform:translate(0)}.Toastify__toast-container--bottom-left,.Toastify__toast-container--bottom-center,.Toastify__toast-container--bottom-right{bottom:env(safe-area-inset-bottom);transform:translate(0)}.Toastify__toast-container--rtl{right:env(safe-area-inset-right);left:initial}.Toastify__toast{--toastify-toast-width: 100%;margin-bottom:0;border-radius:0}}.Toastify__toast-container[data-stacked=true]{width:var(--toastify-toast-width)}.Toastify__toast--stacked{position:absolute;width:100%;transform:translate3d(0,var(--y),0) scale(var(--s));transition:transform .3s}.Toastify__toast--stacked[data-collapsed] .Toastify__toast-body,.Toastify__toast--stacked[data-collapsed] .Toastify__close-button{transition:opacity .1s}.Toastify__toast--stacked[data-collapsed=false]{overflow:visible}.Toastify__toast--stacked[data-collapsed=true]:not(:last-child)>*{opacity:0}.Toastify__toast--stacked:after{content:"";position:absolute;left:0;right:0;height:calc(var(--g) * 1px);bottom:100%}.Toastify__toast--stacked[data-pos=top]{top:0}.Toastify__toast--stacked[data-pos=bot]{bottom:0}.Toastify__toast--stacked[data-pos=bot].Toastify__toast--stacked:before{transform-origin:top}.Toastify__toast--stacked[data-pos=top].Toastify__toast--stacked:before{transform-origin:bottom}.Toastify__toast--stacked:before{content:"";position:absolute;left:0;right:0;bottom:0;height:100%;transform:scaleY(3);z-index:-1}.Toastify__toast--rtl{direction:rtl}.Toastify__toast--close-on-click{cursor:pointer}.Toastify__toast-icon{margin-inline-end:10px;width:22px;flex-shrink:0;display:flex}.Toastify--animate{animation-fill-mode:both;animation-duration:.5s}.Toastify--animate-icon{animation-fill-mode:both;animation-duration:.3s}.Toastify__toast-theme--dark{background:var(--toastify-color-dark);color:var(--toastify-text-color-dark)}.Toastify__toast-theme--light,.Toastify__toast-theme--colored.Toastify__toast--default{background:var(--toastify-color-light);color:var(--toastify-text-color-light)}.Toastify__toast-theme--colored.Toastify__toast--info{color:var(--toastify-text-color-info);background:var(--toastify-color-info)}.Toastify__toast-theme--colored.Toastify__toast--success{color:var(--toastify-text-color-success);background:var(--toastify-color-success)}.Toastify__toast-theme--colored.Toastify__toast--warning{color:var(--toastify-text-color-warning);background:var(--toastify-color-warning)}.Toastify__toast-theme--colored.Toastify__toast--error{color:var(--toastify-text-color-error);background:var(--toastify-color-error)}.Toastify__progress-bar-theme--light{background:var(--toastify-color-progress-light)}.Toastify__progress-bar-theme--dark{background:var(--toastify-color-progress-dark)}.Toastify__progress-bar--info{background:var(--toastify-color-progress-info)}.Toastify__progress-bar--success{background:var(--toastify-color-progress-success)}.Toastify__progress-bar--warning{background:var(--toastify-color-progress-warning)}.Toastify__progress-bar--error{background:var(--toastify-color-progress-error)}.Toastify__progress-bar-theme--colored.Toastify__progress-bar--info,.Toastify__progress-bar-theme--colored.Toastify__progress-bar--success,.Toastify__progress-bar-theme--colored.Toastify__progress-bar--warning,.Toastify__progress-bar-theme--colored.Toastify__progress-bar--error{background:var(--toastify-color-transparent)}.Toastify__close-button{color:#fff;position:absolute;top:6px;right:6px;background:transparent;outline:none;border:none;padding:0;cursor:pointer;opacity:.7;transition:.3s ease;z-index:1}.Toastify__toast--rtl .Toastify__close-button{left:6px;right:unset}.Toastify__close-button--light{color:#000;opacity:.3}.Toastify__close-button>svg{fill:currentColor;height:16px;width:14px}.Toastify__close-button:hover,.Toastify__close-button:focus{opacity:1}@keyframes Toastify__trackProgress{0%{transform:scaleX(1)}to{transform:scaleX(0)}}.Toastify__progress-bar{position:absolute;bottom:0;left:0;width:100%;height:100%;z-index:1;opacity:.7;transform-origin:left}.Toastify__progress-bar--animated{animation:Toastify__trackProgress linear 1 forwards}.Toastify__progress-bar--controlled{transition:transform .2s}.Toastify__progress-bar--rtl{right:0;left:initial;transform-origin:right;border-bottom-left-radius:initial}.Toastify__progress-bar--wrp{position:absolute;overflow:hidden;bottom:0;left:0;width:100%;height:5px;border-bottom-left-radius:var(--toastify-toast-bd-radius);border-bottom-right-radius:var(--toastify-toast-bd-radius)}.Toastify__progress-bar--wrp[data-hidden=true]{opacity:0}.Toastify__progress-bar--bg{opacity:var(--toastify-color-progress-bgo);width:100%;height:100%}.Toastify__spinner{width:20px;height:20px;box-sizing:border-box;border:2px solid;border-radius:100%;border-color:var(--toastify-spinner-color-empty-area);border-right-color:var(--toastify-spinner-color);animation:Toastify__spin .65s linear infinite}@keyframes Toastify__bounceInRight{0%,60%,75%,90%,to{animation-timing-function:cubic-bezier(.215,.61,.355,1)}0%{opacity:0;transform:translate3d(3000px,0,0)}60%{opacity:1;transform:translate3d(-25px,0,0)}75%{transform:translate3d(10px,0,0)}90%{transform:translate3d(-5px,0,0)}to{transform:none}}@keyframes Toastify__bounceOutRight{20%{opacity:1;transform:translate3d(-20px,var(--y),0)}to{opacity:0;transform:translate3d(2000px,var(--y),0)}}@keyframes Toastify__bounceInLeft{0%,60%,75%,90%,to{animation-timing-function:cubic-bezier(.215,.61,.355,1)}0%{opacity:0;transform:translate3d(-3000px,0,0)}60%{opacity:1;transform:translate3d(25px,0,0)}75%{transform:translate3d(-10px,0,0)}90%{transform:translate3d(5px,0,0)}to{transform:none}}@keyframes Toastify__bounceOutLeft{20%{opacity:1;transform:translate3d(20px,var(--y),0)}to{opacity:0;transform:translate3d(-2000px,var(--y),0)}}@keyframes Toastify__bounceInUp{0%,60%,75%,90%,to{animation-timing-function:cubic-bezier(.215,.61,.355,1)}0%{opacity:0;transform:translate3d(0,3000px,0)}60%{opacity:1;transform:translate3d(0,-20px,0)}75%{transform:translate3d(0,10px,0)}90%{transform:translate3d(0,-5px,0)}to{transform:translateZ(0)}}@keyframes Toastify__bounceOutUp{20%{transform:translate3d(0,calc(var(--y) - 10px),0)}40%,45%{opacity:1;transform:translate3d(0,calc(var(--y) + 20px),0)}to{opacity:0;transform:translate3d(0,-2000px,0)}}@keyframes Toastify__bounceInDown{0%,60%,75%,90%,to{animation-timing-function:cubic-bezier(.215,.61,.355,1)}0%{opacity:0;transform:translate3d(0,-3000px,0)}60%{opacity:1;transform:translate3d(0,25px,0)}75%{transform:translate3d(0,-10px,0)}90%{transform:translate3d(0,5px,0)}to{transform:none}}@keyframes Toastify__bounceOutDown{20%{transform:translate3d(0,calc(var(--y) - 10px),0)}40%,45%{opacity:1;transform:translate3d(0,calc(var(--y) + 20px),0)}to{opacity:0;transform:translate3d(0,2000px,0)}}.Toastify__bounce-enter--top-left,.Toastify__bounce-enter--bottom-left{animation-name:Toastify__bounceInLeft}.Toastify__bounce-enter--top-right,.Toastify__bounce-enter--bottom-right{animation-name:Toastify__bounceInRight}.Toastify__bounce-enter--top-center{animation-name:Toastify__bounceInDown}.Toastify__bounce-enter--bottom-center{animation-name:Toastify__bounceInUp}.Toastify__bounce-exit--top-left,.Toastify__bounce-exit--bottom-left{animation-name:Toastify__bounceOutLeft}.Toastify__bounce-exit--top-right,.Toastify__bounce-exit--bottom-right{animation-name:Toastify__bounceOutRight}.Toastify__bounce-exit--top-center{animation-name:Toastify__bounceOutUp}.Toastify__bounce-exit--bottom-center{animation-name:Toastify__bounceOutDown}@keyframes Toastify__zoomIn{0%{opacity:0;transform:scale3d(.3,.3,.3)}50%{opacity:1}}@keyframes Toastify__zoomOut{0%{opacity:1}50%{opacity:0;transform:translate3d(0,var(--y),0) scale3d(.3,.3,.3)}to{opacity:0}}.Toastify__zoom-enter{animation-name:Toastify__zoomIn}.Toastify__zoom-exit{animation-name:Toastify__zoomOut}@keyframes Toastify__flipIn{0%{transform:perspective(400px) rotateX(90deg);animation-timing-function:ease-in;opacity:0}40%{transform:perspective(400px) rotateX(-20deg);animation-timing-function:ease-in}60%{transform:perspective(400px) rotateX(10deg);opacity:1}80%{transform:perspective(400px) rotateX(-5deg)}to{transform:perspective(400px)}}@keyframes Toastify__flipOut{0%{transform:translate3d(0,var(--y),0) perspective(400px)}30%{transform:translate3d(0,var(--y),0) perspective(400px) rotateX(-20deg);opacity:1}to{transform:translate3d(0,var(--y),0) perspective(400px) rotateX(90deg);opacity:0}}.Toastify__flip-enter{animation-name:Toastify__flipIn}.Toastify__flip-exit{animation-name:Toastify__flipOut}@keyframes Toastify__slideInRight{0%{transform:translate3d(110%,0,0);visibility:visible}to{transform:translate3d(0,var(--y),0)}}@keyframes Toastify__slideInLeft{0%{transform:translate3d(-110%,0,0);visibility:visible}to{transform:translate3d(0,var(--y),0)}}@keyframes Toastify__slideInUp{0%{transform:translate3d(0,110%,0);visibility:visible}to{transform:translate3d(0,var(--y),0)}}@keyframes Toastify__slideInDown{0%{transform:translate3d(0,-110%,0);visibility:visible}to{transform:translate3d(0,var(--y),0)}}@keyframes Toastify__slideOutRight{0%{transform:translate3d(0,var(--y),0)}to{visibility:hidden;transform:translate3d(110%,var(--y),0)}}@keyframes Toastify__slideOutLeft{0%{transform:translate3d(0,var(--y),0)}to{visibility:hidden;transform:translate3d(-110%,var(--y),0)}}@keyframes Toastify__slideOutDown{0%{transform:translate3d(0,var(--y),0)}to{visibility:hidden;transform:translate3d(0,500px,0)}}@keyframes Toastify__slideOutUp{0%{transform:translate3d(0,var(--y),0)}to{visibility:hidden;transform:translate3d(0,-500px,0)}}.Toastify__slide-enter--top-left,.Toastify__slide-enter--bottom-left{animation-name:Toastify__slideInLeft}.Toastify__slide-enter--top-right,.Toastify__slide-enter--bottom-right{animation-name:Toastify__slideInRight}.Toastify__slide-enter--top-center{animation-name:Toastify__slideInDown}.Toastify__slide-enter--bottom-center{animation-name:Toastify__slideInUp}.Toastify__slide-exit--top-left,.Toastify__slide-exit--bottom-left{animation-name:Toastify__slideOutLeft;animation-timing-function:ease-in;animation-duration:.3s}.Toastify__slide-exit--top-right,.Toastify__slide-exit--bottom-right{animation-name:Toastify__slideOutRight;animation-timing-function:ease-in;animation-duration:.3s}.Toastify__slide-exit--top-center{animation-name:Toastify__slideOutUp;animation-timing-function:ease-in;animation-duration:.3s}.Toastify__slide-exit--bottom-center{animation-name:Toastify__slideOutDown;animation-timing-function:ease-in;animation-duration:.3s}@keyframes Toastify__spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.sidebar{width:250px;height:100vh;background-color:var(--color-dark);color:#fff;position:fixed;left:0;top:0;z-index:100;transition:transform .3s ease;display:flex;flex-direction:column}.sidebar.closed{transform:translate(-250px)}.sidebar-header{padding:1.5rem;border-bottom:1px solid rgba(255,255,255,.1)}.logo h2{font-size:1.5rem;margin:0;color:#fff}.logo p{font-size:.8rem;margin:0;color:#ffffffb3}.sidebar-user{padding:1rem 1.5rem;border-bottom:1px solid rgba(255,255,255,.1)}.user-info{display:flex;flex-direction:column}.username{font-weight:600;font-size:1rem}.role{font-size:.8rem;color:#ffffffb3}.sidebar-nav{flex:1;overflow-y:auto;padding:1rem 0}.sidebar-nav ul{list-style:none;padding:0;margin:0}.sidebar-nav li{margin-bottom:.5rem}.sidebar-nav a{display:flex;align-items:center;padding:.75rem 1.5rem;color:#fffc;text-decoration:none;transition:all .2s}.sidebar-nav a:hover{background-color:#ffffff1a;color:#fff}.sidebar-nav a.active{background-color:var(--color-primary);color:#fff;border-left:4px solid white}.nav-icon{margin-right:.75rem;font-size:1.25rem;width:1.5rem;text-align:center}.sidebar-footer{padding:1rem 1.5rem;font-size:.8rem;color:#fff9;border-top:1px solid rgba(255,255,255,.1);text-align:center}.auth-layout{display:flex;min-height:100vh;position:relative;overflow:hidden}.auth-background{position:fixed;top:0;left:0;right:0;bottom:0;background:linear-gradient(135deg,#06f,#8338ec);opacity:.9;z-index:-1}.auth-content{width:100%;max-width:500px;margin:auto;padding:2rem 1rem;z-index:1;display:flex;flex-direction:column;min-height:100vh}.auth-branding{text-align:center;margin-bottom:2rem}.auth-branding h1{font-size:2.5rem;font-weight:700;color:#fff;margin:0;text-shadow:0 2px 4px rgba(0,0,0,.1)}.auth-branding p{font-size:1.1rem;color:#fffc;margin:0}.auth-footer{margin-top:auto;text-align:center;padding-top:2rem}.auth-footer p{font-size:.85rem;color:#fff9}@media (min-width: 768px){.auth-content{padding:2rem}}.dashboard{padding:1rem;background-color:var(--color-light);min-height:calc(100vh - 64px);width:100%;box-sizing:border-box}.page-title{font-size:1.75rem;margin-bottom:1.8rem;color:var(--color-gray-900);font-weight:700;position:relative;padding-bottom:.8rem}.page-title:after{content:"";position:absolute;bottom:0;left:0;width:60px;height:3px;background:linear-gradient(90deg,var(--color-primary),var(--color-accent));border-radius:var(--border-radius-full)}.stats-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:16px;width:100%;margin-bottom:2rem;padding:0}@media (max-width: 1200px){.stats-grid{grid-template-columns:repeat(auto-fit,minmax(260px,1fr));gap:16px}}@media (max-width: 992px){.stats-grid{grid-template-columns:repeat(auto-fit,minmax(240px,1fr));gap:16px}}@media (max-width: 768px){.stats-grid{grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:12px}}@media (max-width: 480px){.stats-grid{grid-template-columns:1fr;gap:12px}}.stat-card{height:160px!important;transition:transform .3s ease,box-shadow .3s ease;border:1px solid var(--color-gray-100)!important;border-radius:var(--border-radius)!important;overflow:hidden;-webkit-backdrop-filter:blur(5px);backdrop-filter:blur(5px);background-color:#ffffffe6!important;box-shadow:var(--shadow-md)!important;margin:0!important;width:100%!important;flex:1}.stat-card:hover{transform:translateY(-3px);box-shadow:var(--shadow-lg)!important;border-color:var(--color-primary-light)!important}.stat-icon{min-width:56px;width:56px;height:56px;border-radius:var(--border-radius);display:flex;align-items:center;justify-content:center;transition:all .3s ease;box-shadow:var(--shadow-sm)}.stat-icon-conversations{background:linear-gradient(135deg,#9966ff1a,#96f3);color:#96f}.stat-icon-messages{background:linear-gradient(135deg,#ff9f401a,#ff9f4033);color:#ff9f40}.stat-label{text-transform:uppercase;letter-spacing:.5px;color:var(--color-gray-500);font-weight:500!important;font-size:.8rem!important;margin-bottom:5px!important}.stat-value{font-weight:700!important;color:var(--color-gray-900)!important;margin:.35rem 0!important;font-size:2.2rem!important;white-space:nowrap}.stat-detail{margin-top:.5rem;min-height:24px}.stat-new{color:var(--color-success)!important;font-weight:500!important;font-size:.9rem!important}.stat-percent{color:var(--color-primary)!important;font-weight:500!important;font-size:.8125rem!important}.chart-card,.activity-card{border-radius:var(--border-radius-lg)!important;box-shadow:var(--shadow-md)!important;border:1px solid var(--color-gray-100);overflow:hidden;background-color:#ffffffe6!important;-webkit-backdrop-filter:blur(5px);backdrop-filter:blur(5px);transition:all .3s ease}.chart-card:hover,.activity-card:hover{box-shadow:var(--shadow-lg)!important;border-color:var(--color-gray-200)}.placeholder-chart{width:100%;height:350px;background:linear-gradient(135deg,var(--color-gray-100) 25%,var(--color-light) 25%,var(--color-light) 50%,var(--color-gray-100) 50%,var(--color-gray-100) 75%,var(--color-light) 75%);background-size:20px 20px;border-radius:var(--border-radius);display:flex;align-items:center;justify-content:center;color:var(--color-gray-400);font-weight:500}.activity-section h2{font-size:1.25rem;margin-bottom:1.5rem;color:var(--color-gray-800);font-weight:600}.activity-empty{background-color:#fff;border-radius:var(--border-radius);box-shadow:var(--shadow-sm);padding:3rem 1.8rem;text-align:center;color:var(--color-gray-400);border:1px solid var(--color-gray-100);font-weight:500}.loading{display:flex;align-items:center;justify-content:center;height:300px;font-size:1.125rem;color:var(--color-gray-500);background-color:#fff;border-radius:var(--border-radius);box-shadow:var(--shadow-sm)}.error-message{background-color:#ff006e0d;color:var(--color-danger);padding:1.5rem;border-radius:var(--border-radius);margin:1.5rem 0;border-left:4px solid var(--color-danger);font-weight:500}.login-container{display:flex;align-items:center;justify-content:center;min-height:100vh;width:100vw;margin:0;padding:0;background-color:#000;background-image:url(/hinh-nen-may-tinh-4k-190.jpg);background-size:cover;background-position:center;background-repeat:no-repeat;position:fixed;top:0;left:0;right:0;bottom:0;overflow:hidden}.login-container input:-webkit-autofill,.login-container input:-webkit-autofill:hover,.login-container input:-webkit-autofill:focus,.login-container input:-webkit-autofill:active{-webkit-text-fill-color:white!important;-webkit-box-shadow:0 0 0 30px rgba(0,0,0,.6) inset!important;transition:background-color 5000s ease-in-out 0s;caret-color:#fff;background-clip:content-box!important}.login-container input{background-color:transparent!important;color:#fff!important}@media (prefers-color-scheme: dark){.login-container{background-color:#000;background-image:url(/hinh-nen-may-tinh-4k-190.jpg);background-size:cover;background-position:center;background-repeat:no-repeat}}.login-box{width:100%;max-width:400px;background:#fff;border-radius:8px;box-shadow:var(--shadow-lg);padding:2rem}.login-header{text-align:center;margin-bottom:2rem}.login-header h2{color:var(--color-primary);margin-bottom:.5rem;font-size:1.8rem}.login-header p{color:#666;font-size:.9rem}.login-form{display:flex;flex-direction:column}.error-message{background-color:#ff006e1a;color:var(--color-danger);padding:.75rem;border-radius:4px;margin-bottom:1rem;text-align:center;font-size:.9rem}.form-group{margin-bottom:1.5rem}.form-label{display:block;margin-bottom:.5rem;font-weight:500;color:#333}.form-control{width:100%;padding:.75rem;border:1px solid #ddd;border-radius:4px;font-size:1rem;transition:border-color .2s}.form-control:focus{outline:none;border-color:var(--color-primary);box-shadow:0 0 0 2px #06f3}.password-field{position:relative}.password-toggle{position:absolute;right:10px;top:50%;transform:translateY(-50%);background:transparent;border:none;color:#666;cursor:pointer;font-size:.8rem}.password-toggle:hover{color:var(--color-primary)}.login-button{background-color:var(--color-primary);color:#fff;border:none;border-radius:4px;padding:.75rem;font-size:1rem;font-weight:500;cursor:pointer;transition:background-color .2s}.login-button:hover{background-color:#0052cc}.login-button:disabled{background-color:#7cb0ff;cursor:not-allowed}.list-container{padding:20px}.list-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:20px;flex-wrap:wrap;gap:15px}.list-header h1{margin:0;font-size:1.5rem}.header-controls{display:flex;gap:10px;align-items:center;flex-wrap:wrap}.search-container{flex:1;min-width:300px}.search-container form{display:flex;width:100%}.search-input-wrapper{position:relative;display:flex;align-items:center;width:100%;gap:10px}.search-icon{position:absolute;left:10px;color:var(--color-gray-500, #adb5bd);font-size:1.2rem}.search-info-icon{position:absolute;right:120px;color:var(--color-gray-500, #adb5bd);font-size:1.2rem;cursor:help}.search-container input{padding:8px 36px 8px 12px;border:1px solid #ddd;border-radius:8px;flex:1;min-width:200px}.search-container button{background-color:#2196f3;color:#fff;border:none;border-radius:8px;padding:8px 15px;cursor:pointer;font-weight:500;white-space:nowrap;min-width:100px}.search-container button:hover{background-color:#0b7dda}.filter-container{position:relative;margin-left:10px}.filter-toggle{display:flex;align-items:center;gap:6px;background-color:#f0f0f0;border:1px solid #ddd;border-radius:8px;padding:8px 12px;cursor:pointer;font-weight:500;white-space:nowrap;min-width:100px;justify-content:center}.filter-toggle.active{background-color:#e3f2fd;color:#2196f3;border-color:#2196f3}.filter-options{position:absolute;top:100%;right:0;margin-top:5px;background-color:#fff;border:1px solid #ddd;border-radius:8px;box-shadow:0 4px 12px #0000001a;z-index:100;min-width:180px}.filter-option{display:block;width:100%;text-align:left;padding:10px 15px;border:none;background:none;cursor:pointer;transition:all .2s}.filter-option:hover{background-color:#f5f5f5}.filter-option.active{background-color:#e3f2fd;color:#2196f3;font-weight:500}.table-container{background-color:#fff;border-radius:8px;box-shadow:0 2px 4px #0000001a;overflow:hidden;margin-bottom:20px}table{width:100%;border-collapse:collapse}th,td{padding:12px 15px;text-align:left;border-bottom:1px solid #eee}th{background-color:#f5f5f5;font-weight:500;color:#555}tr:hover{background-color:#f9f9f9}.no-data{text-align:center;padding:30px;color:#666;font-style:italic}.action-buttons{display:flex;gap:8px}.view-button,.edit-button,.delete-button{padding:5px 10px;border:none;border-radius:4px;cursor:pointer;font-size:.85rem;text-decoration:none;display:inline-block;text-align:center}.view-button{background-color:#2196f3;color:#fff}.edit-button{background-color:#ff9800;color:#fff}.edit-button:hover{background-color:#e68a00}.delete-button{background-color:#f44336;color:#fff}.delete-button:hover{background-color:#d32f2f}.pagination-button:hover:not(.active){background-color:#e0e0e0}.loading-container{display:flex;flex-direction:column;justify-content:center;align-items:center;padding:50px;gap:15px}.loader{width:40px;height:40px;border:3px solid #f3f3f3;border-top:3px solid #2196f3;border-radius:50%;animation:spin 1s linear infinite}.error-message{background-color:#ffebee;color:#d32f2f;padding:15px;border-radius:4px;margin-bottom:20px;text-align:center}.modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background-color:#00000080;display:flex;justify-content:center;align-items:center;z-index:1000}.confirm-modal{background-color:#fff;border-radius:8px;padding:20px;width:400px;max-width:90%;box-shadow:0 4px 8px #0003}.confirm-modal h3{margin-top:0;color:#333}.modal-actions{display:flex;justify-content:flex-end;gap:10px;margin-top:20px}.cancel-button{background-color:#f0f0f0;border:none;border-radius:4px;padding:8px 16px;cursor:pointer}.cancel-button:hover{background-color:#e0e0e0}.id-column{width:100px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.user-column{width:200px}.title-column{min-width:200px}.date-column,.update-column{width:150px;white-space:nowrap}.message-column,.actions-column{width:100px;text-align:center}@media (max-width: 768px){.list-header{flex-direction:column;align-items:flex-start}.header-controls{width:100%;flex-direction:column;align-items:flex-start}.search-container{width:100%;min-width:100%}.search-container form,.search-input-wrapper,.search-container input{width:100%}.filter-container{width:100%;margin-top:10px;margin-left:0}.filter-toggle{width:100%;justify-content:space-between}.pagination{flex-direction:column;align-items:center}.search-info-icon{right:110px}.table-container{overflow-x:auto}table{min-width:800px}}.user-list-container{padding:1.5rem;background-color:var(--color-light, #f8f9fa);min-height:calc(100vh - 64px);width:100%;box-sizing:border-box}.user-list-container .page-title{font-size:1.75rem;margin-bottom:1.8rem;color:var(--color-gray-900, #212529);font-weight:700;position:relative;padding-bottom:.8rem}.user-list-container .page-title:after{content:"";position:absolute;bottom:0;left:0;width:60px;height:3px;background:linear-gradient(90deg,var(--color-primary, #2196f3),var(--color-accent, #1976d2));border-radius:var(--border-radius-full, 50px)}.stats-grid{margin-bottom:2rem;display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:20px;width:100%}.stat-card{background-color:#ffffffe6;border-radius:16px;padding:1.5rem;box-shadow:0 4px 16px #00000014;border:1px solid rgba(0,0,0,.05);display:flex;align-items:center;gap:1.25rem;transition:all .3s ease}.stat-card:hover{transform:translateY(-5px);box-shadow:0 8px 24px #0000001f}.stat-icon{width:64px;height:64px;border-radius:16px;display:flex;align-items:center;justify-content:center;transition:all .3s ease;box-shadow:0 4px 8px #00000014}.stat-icon-users{background:linear-gradient(135deg,#36a2eb1a,#36a2eb33);color:#36a2eb}.stat-icon-premium{background:linear-gradient(135deg,#4bc0c01a,#4bc0c033);color:#4bc0c0}.stat-icon-new{background:linear-gradient(135deg,#9966ff1a,#96f3);color:#96f}.stat-icon-free{background:linear-gradient(135deg,#ff9f401a,#ff9f4033);color:#ff9f40}.stat-content{flex-grow:1}.stat-value{font-weight:700;color:var(--color-gray-900, #212529);font-size:2.25rem;line-height:1.2}.stat-label{color:var(--color-gray-600, #6c757d);font-size:.875rem;font-weight:500;text-transform:uppercase;letter-spacing:.5px;margin-top:.25rem}.list-controls{display:flex;flex-wrap:wrap;gap:1rem;margin-bottom:1.5rem;justify-content:space-between;align-items:center;background-color:#fff;padding:16px;border-radius:16px;box-shadow:0 4px 16px #0000000d;border:1px solid var(--color-gray-100, #f8f9fa)}.search-container{flex-grow:1;max-width:500px}.search-container form{display:flex;gap:.5rem}.search-input-wrapper{position:relative;flex-grow:1}.search-icon{position:absolute;top:50%;left:12px;transform:translateY(-50%);color:var(--color-gray-400, #ced4da);font-size:1.2rem}.search-input{width:100%;padding:12px 12px 12px 40px;border:1px solid var(--color-gray-200, #e9ecef);border-radius:12px;font-size:1rem;box-shadow:0 2px 5px #00000008;transition:all .2s ease}.search-input:focus{outline:none;border-color:var(--color-primary, #2196f3);box-shadow:0 0 0 3px #2196f326}.search-button{background-color:var(--color-primary, #2196f3);color:#fff;border:none;border-radius:12px;padding:12px 20px;font-weight:500;cursor:pointer;transition:all .2s ease}.search-button:hover{background-color:var(--color-primary-dark, #1976d2);transform:translateY(-2px);box-shadow:0 4px 8px #2196f340}.search-button:disabled{background-color:var(--color-gray-400, #ced4da);cursor:not-allowed;transform:none;box-shadow:none}.filter-container{position:relative;z-index:100}.filter-toggle{display:flex;align-items:center;gap:8px;background-color:#fff;border:1px solid var(--color-gray-200, #e9ecef);border-radius:12px;padding:12px 20px;font-weight:500;cursor:pointer;transition:all .2s ease}.filter-toggle.active{background-color:var(--color-primary-light, #e3f2fd);color:var(--color-primary, #2196f3);border-color:var(--color-primary, #2196f3);font-weight:600;box-shadow:0 4px 8px #2196f340;animation:pulse 2s infinite}@keyframes pulse{0%{box-shadow:0 0 #2196f366}70%{box-shadow:0 0 0 6px #2196f300}to{box-shadow:0 0 #2196f300}}.filter-toggle:hover{background-color:var(--color-gray-100, #f8f9fa);border-color:var(--color-gray-300, #dee2e6);transform:translateY(-2px);box-shadow:0 4px 8px #0000000d}.filter-options{position:absolute;top:calc(100% + 8px);right:0;z-index:1000;background-color:#fff;border-radius:12px;box-shadow:0 8px 24px #0000001f;padding:12px;min-width:200px;display:flex;flex-direction:column;gap:8px;border:1px solid var(--color-gray-100, #f8f9fa);animation:fadeIn .2s ease}@keyframes fadeIn{0%{opacity:0;transform:translateY(-10px)}to{opacity:1;transform:translateY(0)}}.filter-option{background-color:transparent;border:none;border-radius:8px;padding:10px 16px;text-align:left;cursor:pointer;transition:all .2s ease;font-weight:500}.filter-option:hover{background-color:var(--color-gray-100, #f8f9fa)}.filter-option.active{background-color:var(--color-primary-light, #e3f2fd);color:var(--color-primary, #2196f3);font-weight:600}.table-container{background-color:#fff;border-radius:16px;box-shadow:0 4px 16px #00000014;overflow:hidden;margin-bottom:20px;border:1px solid var(--color-gray-100, #f8f9fa);transition:all .3s ease}.table-container:hover{box-shadow:0 8px 24px #0000001f;transform:translateY(-2px)}.user-table{border-collapse:separate;border-spacing:0;width:100%}.user-table th{background-color:var(--color-gray-50, #f9fafb);color:var(--color-gray-700, #495057);font-weight:600;text-transform:uppercase;letter-spacing:.5px;font-size:.75rem;padding:16px;border-bottom:1px solid var(--color-gray-200, #e9ecef)}.user-table th:first-child{padding-left:24px}.user-table th:last-child{padding-right:24px}.user-table td{padding:16px;border-bottom:1px solid var(--color-gray-100, #f8f9fa);vertical-align:middle}.user-table td:first-child{padding-left:24px;border-top-left-radius:0;border-bottom-left-radius:0}.user-table td:last-child{padding-right:24px;border-top-right-radius:0;border-bottom-right-radius:0}.user-table tbody tr{transition:all .2s ease}.user-table tbody tr:hover{background-color:var(--color-gray-50, #f9fafb)}.user-table tbody tr:last-child td{border-bottom:none}.user-email{font-weight:500;color:var(--color-gray-800, #343a40)}.user-table td:first-child{font-family:monospace;font-size:.85rem;color:var(--color-gray-600, #6c757d);max-width:240px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.status-badge{display:inline-flex;align-items:center;justify-content:center;padding:6px 14px;border-radius:50px;font-size:.75rem;font-weight:600;letter-spacing:.5px;text-transform:uppercase}.status-badge.premium{background-color:#4caf501f;color:#2e7d32}.status-badge.free{background-color:#2196f31f;color:#1565c0}.action-buttons{display:flex;gap:10px}.view-button,.delete-button{padding:8px 16px;border-radius:8px;font-size:.8125rem;font-weight:500;text-decoration:none;border:none;cursor:pointer;transition:all .2s ease}.view-button{background-color:var(--color-primary, #2196f3);color:#fff}.view-button:hover{background-color:var(--color-primary-dark, #1976d2);transform:translateY(-2px);box-shadow:0 4px 8px #2196f340}.delete-button{background-color:var(--color-danger, #f44336);color:#fff}.delete-button:hover{background-color:var(--color-danger-dark, #d32f2f);transform:translateY(-2px);box-shadow:0 4px 8px #f4433640}.settings-button{display:flex;align-items:center;gap:8px;background-color:#fff;color:var(--color-gray-700, #495057);border:1px solid var(--color-gray-200, #e9ecef);border-radius:8px;padding:8px 16px;font-weight:500;text-decoration:none;transition:all .2s ease}.settings-button:hover{background-color:var(--color-gray-100, #f8f9fa);border-color:var(--color-gray-300, #dee2e6)}.pagination{margin-top:2rem;display:flex;flex-wrap:wrap;justify-content:space-between;align-items:center;gap:1rem;background-color:#fff;padding:16px;border-radius:16px;box-shadow:0 4px 16px #0000000d;border:1px solid var(--color-gray-100, #f8f9fa)}.pagination-info{color:var(--color-gray-600, #6c757d);font-size:.875rem;font-weight:500}.pagination-controls{display:flex;gap:8px;align-items:center}.pagination-button{min-width:40px;height:40px;padding:0 12px;display:flex;align-items:center;justify-content:center;background-color:#fff;color:var(--color-gray-700, #495057);border:1px solid var(--color-gray-200, #e9ecef);border-radius:8px;cursor:pointer;transition:all .2s ease;font-weight:500}.pagination-button.pagination-nav{background-color:var(--color-gray-50, #f9fafb)}.pagination-button:hover:not(.active):not(:disabled){background-color:var(--color-gray-100, #f8f9fa);border-color:var(--color-gray-300, #dee2e6);transform:translateY(-2px);box-shadow:0 4px 8px #0000000d}.pagination-button.active{background-color:var(--color-primary, #2196f3);color:#fff;border-color:var(--color-primary, #2196f3)}.pagination-button:disabled{opacity:.5;cursor:not-allowed}.pagination-ellipsis{color:var(--color-gray-400, #ced4da);padding:0 8px}.limit-control{display:flex;align-items:center;gap:10px;color:var(--color-gray-600, #6c757d);font-size:.875rem;font-weight:500}.limit-control select{padding:10px 16px;border:1px solid var(--color-gray-200, #e9ecef);border-radius:8px;background-color:#fff;color:var(--color-gray-700, #495057);font-weight:500;transition:all .2s ease;cursor:pointer}.limit-control select:hover{border-color:var(--color-primary, #2196f3);box-shadow:0 0 0 3px #2196f31a}.loading-container{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:4rem 0;gap:1rem}.loader{width:40px;height:40px;border:3px solid var(--color-gray-100, #f8f9fa);border-radius:50%;border-top:3px solid var(--color-primary, #2196f3);animation:spin 1s linear infinite}.modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background-color:#00000080;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);display:flex;justify-content:center;align-items:center;z-index:1000}.confirm-modal{background-color:#fff;border-radius:16px;padding:1.5rem;width:400px;max-width:90%;box-shadow:0 10px 25px #0000001a}.confirm-modal h3{margin-top:0;color:var(--color-gray-900, #212529);font-size:1.25rem;font-weight:600}.modal-error{margin:15px 0;padding:10px;border-radius:8px;font-size:.9rem;background-color:#f443361a;border-left:4px solid #f44336}.modal-actions{display:flex;justify-content:flex-end;gap:12px;margin-top:1.5rem}.cancel-button{background-color:var(--color-gray-100, #f8f9fa);color:var(--color-gray-700, #495057);border:none;border-radius:8px;padding:10px 16px;font-weight:500;cursor:pointer;transition:all .2s ease}.cancel-button:hover{background-color:var(--color-gray-200, #e9ecef)}@media (max-width: 1024px){.stats-grid{grid-template-columns:repeat(2,1fr)}}@media (max-width: 768px){.list-controls{flex-direction:column;align-items:stretch}.search-container{max-width:none}.pagination{flex-direction:column;align-items:center}}@media (max-width: 576px){.stats-grid{grid-template-columns:1fr}.action-buttons{flex-direction:column;gap:6px}.view-button,.delete-button{width:100%;text-align:center}}.user-detail-container{padding:20px}.action-bar{margin-bottom:20px}.back-button{background-color:#f0f0f0;border:none;border-radius:4px;padding:8px 16px;cursor:pointer;font-weight:500;display:inline-flex;align-items:center}.back-button:hover{background-color:#e0e0e0}.user-info-card,.stats-card,.recent-conversations-card{background-color:#fff;border-radius:8px;box-shadow:0 2px 4px #0000001a;padding:20px;margin-bottom:20px}.user-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:20px;padding-bottom:15px;border-bottom:1px solid #eee}.user-header h1{margin:0;font-size:1.5rem}.premium-toggle-container{display:flex;align-items:center;gap:10px}.premium-toggle{background-color:#f0f0f0;border:1px solid #ddd;border-radius:20px;padding:6px 12px;cursor:pointer;transition:all .3s ease}.premium-toggle.premium-active{background-color:#4caf50;color:#fff;border-color:#4caf50}.user-details-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(250px,1fr));gap:15px}.detail-item{margin-bottom:10px}.label{font-weight:500;color:#666;margin-right:8px}.value{color:#333}.stats-card h2,.recent-conversations-card h2{font-size:1.2rem;margin-top:0;margin-bottom:20px;padding-bottom:10px;border-bottom:1px solid #eee}.stats-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:20px}.stat-item{display:flex;flex-direction:column;align-items:center;padding:15px;background-color:#f9f9f9;border-radius:8px;text-align:center}.stat-value{font-size:1.5rem;font-weight:600;color:#333;margin-bottom:5px}.stat-label{font-size:.85rem;color:#666}.conversations-list table{width:100%;border-collapse:collapse;margin-bottom:15px}.conversations-list th,.conversations-list td{padding:10px;text-align:left;border-bottom:1px solid #eee}.conversations-list th{font-weight:500;color:#555;background-color:#f5f5f5}.view-button{background-color:#2196f3;color:#fff;border:none;border-radius:4px;padding:5px 10px;cursor:pointer;font-size:.85rem}.view-button:hover{background-color:#0b7dda}.view-all-link{margin-top:15px;text-align:center}.view-all-button{background-color:transparent;color:#2196f3;border:1px solid #2196f3;border-radius:4px;padding:8px 16px;cursor:pointer;font-size:.9rem}.view-all-button:hover{background-color:#f0f7fe}.no-conversations{color:#666;font-style:italic;text-align:center;padding:20px}.loading-container{display:flex;justify-content:center;align-items:center;min-height:200px;font-size:1.1rem;color:#666}.error-container{padding:40px 20px;text-align:center;background-color:#fff;border-radius:12px;box-shadow:0 4px 12px #0000001a;max-width:600px;margin:40px auto}.error-container h2{color:#f44336;margin-bottom:20px}.error-message{color:#f44336;margin-bottom:25px;font-size:1.1rem;padding:15px;background-color:#f4433614;border-radius:8px;white-space:pre-wrap;word-break:break-word}.error-actions{display:flex;justify-content:center;gap:15px;margin-top:20px}.retry-button{background-color:#2196f3;color:#fff;border:none;border-radius:8px;padding:10px 20px;font-weight:500;cursor:pointer;transition:background-color .2s ease}.retry-button:hover{background-color:#1976d2}.loading-spinner{width:50px;height:50px;border:5px solid rgba(33,150,243,.2);border-radius:50%;border-top:5px solid #2196f3;animation:spin 1s linear infinite;margin-bottom:15px}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.not-found-container{text-align:center;padding:20px}.image-limit-card{background-color:#fff;border-radius:8px;box-shadow:0 2px 4px #0000001a;padding:20px;margin-bottom:20px}.limit-stats{display:grid;grid-template-columns:repeat(2,1fr);gap:15px;margin-top:15px}.limit-stat-item{display:flex;align-items:center;padding:10px;background-color:#f9f9f9;border-radius:6px;position:relative}.limit-label{font-weight:500;color:#555;margin-right:10px}.limit-value{font-weight:600;font-size:1.1em;color:#333;margin-left:auto}.limit-value.highlight{color:#2c7be5;font-size:1.2em}.increase-button{margin-left:10px;background-color:#4caf50;color:#fff;border:none;border-radius:4px;padding:4px 8px;cursor:pointer;font-size:.8em;transition:background-color .2s}.increase-button:hover{background-color:#388e3c}.limit-form{margin-top:20px;padding:15px;background-color:#f5f5f5;border-radius:6px;border-left:4px solid #2c7be5}.limit-form h3{margin-top:0;color:#333;font-size:1.1em}.form-actions{display:flex;justify-content:flex-end;gap:10px;margin-top:15px}.cancel-button{background-color:#f1f1f1;color:#333;border:1px solid #ddd;padding:8px 15px;border-radius:4px;cursor:pointer;transition:background-color .2s}.cancel-button:hover{background-color:#e5e5e5}.submit-button{background-color:#2c7be5;color:#fff;border:none;padding:8px 15px;border-radius:4px;cursor:pointer;transition:background-color .2s}.submit-button:hover{background-color:#1a68d1}.submit-button:disabled{background-color:#b0c4de;cursor:not-allowed}.no-limit-data{padding:15px;text-align:center;color:#666;font-style:italic;background-color:#f9f9f9;border-radius:6px}.settings-card{background-color:#fff;border-radius:8px;box-shadow:0 2px 4px #0000001a;padding:20px;margin-bottom:20px}.settings-description{color:#555;margin-bottom:20px}.settings-info{margin-top:30px;padding:15px;background-color:#f8f9fa;border-radius:6px;border-left:4px solid #ffc107}.settings-info h3{margin-top:0;color:#333;font-size:1.1em}.settings-info ul{padding-left:20px}.settings-info li{margin-bottom:8px;color:#555}.warning-text{color:#e53935;font-weight:500}.primary-button{background-color:#2c7be5;color:#fff;border:none;padding:10px 15px;border-radius:4px;cursor:pointer;transition:background-color .2s}.primary-button:hover{background-color:#1a68d1}.warning-button{background-color:#ff9800;color:#fff;border:none;padding:10px 15px;border-radius:4px;cursor:pointer;transition:background-color .2s;margin-left:10px}.warning-button:hover{background-color:#f57c00}.confirm-button{background-color:#4caf50;color:#fff;border:none;padding:8px 15px;border-radius:4px;cursor:pointer;transition:background-color .2s}.confirm-button:hover{background-color:#388e3c}:root{--primary-color: #0d6efd;--secondary-color: #6c757d;--success-color: #198754;--warning-color: #ffc107;--danger-color: #dc3545;--info-color: #0dcaf0;--light-color: #f8f9fa;--dark-color: #212529;--border-radius: 4px;--box-shadow: 0 1px 2px rgba(0, 0, 0, .1);--user-color: #0d6efd;--ai-color: #6f42c1;--param-color: #e83e8c;--id-color: #fd7e14;--time-color: #20c997}body{background-color:#f8f9fa}.log-viewer-container{background-color:#fff;border-radius:var(--border-radius);box-shadow:var(--box-shadow);padding:15px;margin-bottom:15px;max-width:100%}.form-label{font-weight:500;margin-bottom:5px;font-size:14px;display:block}.form-select,.form-control{font-size:14px;padding:6px 10px;border-radius:var(--border-radius);border:1px solid #ced4da;margin-bottom:15px;width:100%;max-width:300px}.log-controls{display:flex;flex-wrap:wrap;gap:15px;margin-bottom:15px}.log-control-item{flex:1;min-width:200px;max-width:300px}.log-container{border-radius:var(--border-radius);background-color:#fff;border:1px solid #dee2e6;height:calc(100vh - 250px);min-height:500px;overflow:auto;position:relative;margin-bottom:15px;width:100%}.log-viewer{font-family:Consolas,Monaco,monospace;white-space:pre-wrap;padding:10px;overflow-x:auto;font-size:14px;line-height:1.5;width:100%}.log-line{padding:12px;border-bottom:1px solid #f0f0f0;margin-bottom:8px;background-color:#fff;transition:background-color .2s;border-radius:6px;width:100%}.log-line:hover{background-color:#f8f9fa}.log-header{display:flex;flex-wrap:wrap;gap:10px;margin-bottom:8px;font-size:14px;color:#333;align-items:center}.log-timestamp{color:#6c757d;font-style:italic;white-space:nowrap;background-color:#f8f9fa;padding:3px 6px;border-radius:3px;font-size:12px}.log-user,.log-ai{font-weight:400;max-width:100%;overflow:hidden;text-overflow:ellipsis}.log-user{color:#0d6efd}.log-ai{color:#6f42c1}.log-user strong,.log-ai strong{font-weight:700;max-width:100%;display:inline-block;overflow:hidden;text-overflow:ellipsis}.log-ids{color:#6c757d;font-size:12px;background-color:#f8f9fa;padding:3px 6px;border-radius:3px;white-space:nowrap}.param-id{color:var(--id-color);font-weight:500;background-color:#fd7e141a;padding:2px 4px;border-radius:3px}.param-time{color:var(--time-color);font-weight:500;background-color:#20c9971a;padding:2px 4px;border-radius:3px}.param-conv{color:var(--param-color);font-weight:500;background-color:#e83e8c1a;padding:2px 4px;border-radius:3px}.log-actions{margin-top:8px;margin-bottom:8px}.btn-detail{background-color:#e9ecef;border:1px solid #ced4da;border-radius:3px;padding:4px 12px;font-size:13px;cursor:pointer;color:#495057;transition:all .2s}.btn-detail:hover{background-color:#0d6efd;color:#fff;border-color:#0d6efd}.log-details{margin-top:10px;padding:15px;background-color:#f8f9fa;border-radius:6px;border:1px solid #e9ecef;font-size:13px;max-height:500px;overflow:auto;box-shadow:0 2px 5px #0000000d}.log-details pre{margin:0;white-space:pre-wrap;font-family:Consolas,Monaco,monospace;font-size:13px}.json-key{color:var(--param-color);font-weight:500}.json-string{color:var(--success-color)}.json-number{color:var(--info-color)}.json-boolean{color:var(--warning-color)}.json-null{color:var(--secondary-color)}.user-message{border-left:4px solid #0d6efd;background-color:#f0f8ff;box-shadow:0 1px 3px #0d6efd1a}.ai-response{border-left:4px solid #6f42c1;background-color:#f8f0ff;box-shadow:0 1px 3px #6f42c11a}.websocket-client{border-left:4px solid #20c997;background-color:#f0fff8;box-shadow:0 1px 3px #20c9971a}.websocket-ai{border-left:4px solid #fd7e14;background-color:#fff8f0;box-shadow:0 1px 3px #fd7e141a}.log-websocket-event{font-weight:500;padding:3px 6px;border-radius:4px;margin-right:5px}.websocket-event{background-color:#0dcaf01a}.websocket-error{background-color:#dc35451a;color:#dc3545}.websocket-connected{background-color:#1987541a;color:#198754}.websocket-disconnect{background-color:#6c757d1a;color:#6c757d}.websocket-message{background-color:#0d6efd1a;color:#0d6efd}.log-user-id,.log-conv-id,.log-conn-id{background-color:#6c757d1a;padding:2px 5px;border-radius:3px;font-size:12px;white-space:nowrap}.log-status{padding:2px 5px;border-radius:3px;font-size:12px;font-weight:500;margin-left:auto}.status-error{background-color:#dc35451a;color:#dc3545}.status-warning{background-color:#ffc1071a;color:#ffc107}.filter-buttons{display:flex;flex-wrap:wrap;gap:8px;margin-bottom:15px}.filter-btn{flex:0 0 auto;padding:6px 12px;font-size:13px;border-radius:4px;cursor:pointer;transition:all .2s}@media (max-width: 768px){.log-control-item{flex:0 0 100%;max-width:100%}.log-container{height:calc(100vh - 300px)}.log-header{flex-direction:column;align-items:flex-start;gap:5px}.log-ids{margin-top:5px}}.hiển-thị-chi-tiết{color:var(--primary-color);cursor:pointer;text-decoration:underline;font-size:13px;display:inline-block;margin-top:5px}.hiển-thị-chi-tiết:hover{color:var(--primary-color);opacity:.8}.log-viewer-header{margin-bottom:20px;display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap}.log-viewer-title{font-size:24px;font-weight:600;color:var(--dark-color);margin-bottom:10px}.log-viewer-actions{display:flex;gap:10px;flex-wrap:wrap}.pagination{display:flex;justify-content:center;margin-top:20px;flex-wrap:wrap}.pagination .page-item{margin:0 2px}.pagination .page-link{padding:8px 14px;font-size:14px;border-radius:4px;color:var(--primary-color);background-color:#fff;border:1px solid #dee2e6}.pagination .page-link:hover{background-color:#e9ecef}.pagination .page-item.active .page-link{background-color:var(--primary-color);border-color:var(--primary-color);color:#fff}.pagination .page-item.disabled .page-link{color:#6c757d;pointer-events:none;background-color:#fff;border-color:#dee2e6}.spinner-overlay{position:absolute;top:0;left:0;right:0;bottom:0;background:#ffffffb3;display:flex;justify-content:center;align-items:center;z-index:100}.highlight-text{background-color:#fff3cd;padding:0 2px;border-radius:2px}.btn{padding:6px 12px;font-size:14px;border-radius:4px;cursor:pointer;transition:all .2s}.btn:hover{opacity:.9}.controls-row{background-color:#f8f9fa;border-radius:6px;padding:8px;margin-bottom:8px}.filters-row{background-color:#f8f9fa;border-radius:6px;padding:6px}.control-item{margin-right:5px}.form-label{font-weight:500;margin-bottom:3px;font-size:12px;display:block}.form-select,.form-control{font-size:13px;padding:4px 8px;border-radius:var(--border-radius);border:1px solid #ced4da;margin-bottom:0;width:100%;height:32px}.btn{padding:4px 10px;font-size:13px;border-radius:4px;cursor:pointer;transition:all .2s;height:32px;display:inline-flex;align-items:center;justify-content:center}.btn svg{margin-right:4px}.action-buttons{display:flex;flex-wrap:wrap;gap:6px;margin-bottom:10px}.single-row-controls{display:flex;align-items:center;background-color:#f8f9fa;border-radius:6px;padding:8px;margin-bottom:10px;gap:8px;flex-wrap:nowrap;overflow-x:auto}.file-select{width:200px;flex-shrink:0}.lines-select{width:100px;flex-shrink:0}.search-container{display:flex;width:200px;flex-shrink:0}.search-container .form-control{border-top-right-radius:0;border-bottom-right-radius:0;border-right:none}.search-container .btn{border-top-left-radius:0;border-bottom-left-radius:0;padding-left:8px;padding-right:8px}.date-picker{width:180px;font-size:13px;padding:4px 8px;border-radius:var(--border-radius);border:1px solid #ced4da;height:32px;flex-shrink:0}.filter-buttons{display:flex;gap:4px;margin:0 4px;flex-shrink:0}.filter-btn{width:32px;height:32px;padding:0;font-size:12px;border-radius:4px;border:1px solid #dee2e6;background-color:#fff;cursor:pointer;display:flex;align-items:center;justify-content:center}.action-buttons{display:flex;gap:4px;margin-left:auto;flex-shrink:0}.action-buttons .btn{width:32px;height:32px;padding:0;display:flex;align-items:center;justify-content:center}.btn{font-size:13px;border-radius:4px;cursor:pointer;transition:all .2s}.log-viewer-header{margin-bottom:10px;padding-bottom:8px;border-bottom:1px solid #e9ecef}.log-viewer-title{font-size:20px;font-weight:600;color:var(--dark-color);margin-bottom:0}.time-filter-compact{display:flex;flex-direction:column;gap:5px}.time-filter-row{display:flex;gap:5px;align-items:center}.time-filter-label{font-size:12px;white-space:nowrap}.filter-btn-group{display:flex;flex-wrap:wrap;gap:5px;margin-bottom:0}.filter-btn{padding:3px 8px;font-size:12px;border-radius:3px;border:1px solid #dee2e6;background-color:#fff;cursor:pointer;transition:all .2s;display:inline-flex;align-items:center}.filter-btn.active{background-color:#0d6efd;color:#fff;border-color:#0d6efd}.filter-btn svg{margin-right:3px;font-size:10px}.log-container{height:calc(100vh - 140px);overflow-y:auto;border:1px solid #dee2e6;border-radius:var(--border-radius);background-color:#f8f9fa;position:relative}.log-viewer{padding:10px;font-family:Consolas,Courier New,monospace;font-size:14px;line-height:1.4}.log-line{padding:2px 5px;border-bottom:1px solid #f0f0f0;white-space:pre-wrap;word-break:break-word}.log-line:hover{background-color:#007bff0d}.spinner-overlay{position:absolute;top:0;left:0;right:0;bottom:0;background-color:#ffffffb3;display:flex;justify-content:center;align-items:center;z-index:10}.log-stats{margin-top:8px;text-align:right;color:#6c757d}.pagination-no-bullets{list-style-type:none;padding-left:0}.pagination-no-bullets .page-item{margin:0 2px}.pagination-no-bullets .page-link{border-radius:4px;padding:5px 10px;font-size:14px}.tooltip{font-size:12px;opacity:.9!important}.tooltip .tooltip-inner{padding:4px 8px;max-width:200px;box-shadow:0 2px 5px #00000026}@media (max-width: 992px){.single-row-controls{flex-wrap:wrap}.action-buttons{margin-left:0;margin-top:8px}.log-container{height:calc(100vh - 200px)}}.message-flow{border-left:4px solid #5e72e4;background-color:#f7faff}.message-flow .log-header{display:flex;flex-wrap:wrap;align-items:center;gap:8px}.log-stage{display:inline-block;padding:2px 8px;border-radius:4px;font-weight:600;margin-right:8px}.stage-client{background-color:#e3f2fd;color:#1565c0}.stage-backend{background-color:#e8f5e9;color:#2e7d32}.stage-ai{background-color:#f3e5f5;color:#7b1fa2}.log-step{background-color:#eceff1;color:#455a64;border-radius:12px;padding:1px 8px;font-size:.85em}.log-duration{color:#ff6d00;font-weight:600;margin-right:8px}.pagination{display:flex;justify-content:space-between;align-items:center;margin-top:20px;flex-wrap:wrap;gap:15px}.pagination-controls{display:flex;gap:5px;flex-wrap:wrap}.pagination-button{background-color:#f5f5f5;border:1px solid #ddd;border-radius:4px;padding:5px 10px;cursor:pointer;min-width:30px;text-align:center}.pagination-button.active{background-color:#2196f3;color:#fff;border-color:#2196f3}.pagination-button:hover:not(.active):not([disabled]){background-color:#e0e0e0}.pagination-ellipsis{display:flex;align-items:center;justify-content:center;padding:5px}.pagination-nav{display:flex;align-items:center;justify-content:center}.pagination-nav[disabled]{opacity:.5;cursor:not-allowed}.pagination-info{color:#666;font-size:.9rem}.limit-control{display:flex;align-items:center}.limit-control select{margin-left:8px;padding:5px;border:1px solid #ddd;border-radius:4px}.flatpickr-calendar{background:transparent;opacity:0;display:none;text-align:center;visibility:hidden;padding:0;-webkit-animation:none;animation:none;direction:ltr;border:0;font-size:14px;line-height:24px;border-radius:5px;position:absolute;width:307.875px;-webkit-box-sizing:border-box;box-sizing:border-box;-ms-touch-action:manipulation;touch-action:manipulation;-webkit-box-shadow:0 3px 13px rgba(0,0,0,.08);box-shadow:0 3px 13px #00000014}.flatpickr-calendar.open,.flatpickr-calendar.inline{opacity:1;max-height:640px;visibility:visible}.flatpickr-calendar.open{display:inline-block;z-index:99999}.flatpickr-calendar.animate.open{-webkit-animation:fpFadeInDown .3s cubic-bezier(.23,1,.32,1);animation:fpFadeInDown .3s cubic-bezier(.23,1,.32,1)}.flatpickr-calendar.inline{display:block;position:relative;top:2px}.flatpickr-calendar.static{position:absolute;top:calc(100% + 2px)}.flatpickr-calendar.static.open{z-index:999;display:block}.flatpickr-calendar.multiMonth .flatpickr-days .dayContainer:nth-child(n+1) .flatpickr-day.inRange:nth-child(7n+7){-webkit-box-shadow:none!important;box-shadow:none!important}.flatpickr-calendar.multiMonth .flatpickr-days .dayContainer:nth-child(n+2) .flatpickr-day.inRange:nth-child(7n+1){-webkit-box-shadow:-2px 0 0 #e6e6e6,5px 0 0 #e6e6e6;box-shadow:-2px 0 #e6e6e6,5px 0 #e6e6e6}.flatpickr-calendar .hasWeeks .dayContainer,.flatpickr-calendar .hasTime .dayContainer{border-bottom:0;border-bottom-right-radius:0;border-bottom-left-radius:0}.flatpickr-calendar .hasWeeks .dayContainer{border-left:0}.flatpickr-calendar.hasTime .flatpickr-time{height:40px;border-top:1px solid #eceef1}.flatpickr-calendar.hasTime .flatpickr-innerContainer{border-bottom:0}.flatpickr-calendar.hasTime .flatpickr-time{border:1px solid #eceef1}.flatpickr-calendar.noCalendar.hasTime .flatpickr-time{height:auto}.flatpickr-calendar:before,.flatpickr-calendar:after{position:absolute;display:block;pointer-events:none;border:solid transparent;content:"";height:0;width:0;left:22px}.flatpickr-calendar.rightMost:before,.flatpickr-calendar.arrowRight:before,.flatpickr-calendar.rightMost:after,.flatpickr-calendar.arrowRight:after{left:auto;right:22px}.flatpickr-calendar.arrowCenter:before,.flatpickr-calendar.arrowCenter:after{left:50%;right:50%}.flatpickr-calendar:before{border-width:5px;margin:0 -5px}.flatpickr-calendar:after{border-width:4px;margin:0 -4px}.flatpickr-calendar.arrowTop:before,.flatpickr-calendar.arrowTop:after{bottom:100%}.flatpickr-calendar.arrowTop:before{border-bottom-color:#eceef1}.flatpickr-calendar.arrowTop:after{border-bottom-color:#eceef1}.flatpickr-calendar.arrowBottom:before,.flatpickr-calendar.arrowBottom:after{top:100%}.flatpickr-calendar.arrowBottom:before{border-top-color:#eceef1}.flatpickr-calendar.arrowBottom:after{border-top-color:#eceef1}.flatpickr-calendar:focus{outline:0}.flatpickr-wrapper{position:relative;display:inline-block}.flatpickr-months{display:-webkit-box;display:-webkit-flex;display:-ms-flexbox;display:flex}.flatpickr-months .flatpickr-month{border-radius:5px 5px 0 0;background:#eceef1;color:#5a6171;fill:#5a6171;height:34px;line-height:1;text-align:center;position:relative;-webkit-user-select:none;-moz-user-select:none;-ms-user-select:none;user-select:none;overflow:hidden;-webkit-box-flex:1;-webkit-flex:1;-ms-flex:1;flex:1}.flatpickr-months .flatpickr-prev-month,.flatpickr-months .flatpickr-next-month{-webkit-user-select:none;-moz-user-select:none;-ms-user-select:none;user-select:none;text-decoration:none;cursor:pointer;position:absolute;top:0;height:34px;padding:10px;z-index:3;color:#5a6171;fill:#5a6171}.flatpickr-months .flatpickr-prev-month.flatpickr-disabled,.flatpickr-months .flatpickr-next-month.flatpickr-disabled{display:none}.flatpickr-months .flatpickr-prev-month i,.flatpickr-months .flatpickr-next-month i{position:relative}.flatpickr-months .flatpickr-prev-month.flatpickr-prev-month,.flatpickr-months .flatpickr-next-month.flatpickr-prev-month{left:0}.flatpickr-months .flatpickr-prev-month.flatpickr-next-month,.flatpickr-months .flatpickr-next-month.flatpickr-next-month{right:0}.flatpickr-months .flatpickr-prev-month:hover,.flatpickr-months .flatpickr-next-month:hover{color:#bbb}.flatpickr-months .flatpickr-prev-month:hover svg,.flatpickr-months .flatpickr-next-month:hover svg{fill:#f64747}.flatpickr-months .flatpickr-prev-month svg,.flatpickr-months .flatpickr-next-month svg{width:14px;height:14px}.flatpickr-months .flatpickr-prev-month svg path,.flatpickr-months .flatpickr-next-month svg path{-webkit-transition:fill .1s;transition:fill .1s;fill:inherit}.numInputWrapper{position:relative;height:auto}.numInputWrapper input,.numInputWrapper span{display:inline-block}.numInputWrapper input{width:100%}.numInputWrapper input::-ms-clear{display:none}.numInputWrapper input::-webkit-outer-spin-button,.numInputWrapper input::-webkit-inner-spin-button{margin:0;-webkit-appearance:none}.numInputWrapper span{position:absolute;right:0;width:14px;padding:0 4px 0 2px;height:50%;line-height:50%;opacity:0;cursor:pointer;border:1px solid rgba(72,72,72,.15);-webkit-box-sizing:border-box;box-sizing:border-box}.numInputWrapper span:hover{background:#0000001a}.numInputWrapper span:active{background:#0003}.numInputWrapper span:after{display:block;content:"";position:absolute}.numInputWrapper span.arrowUp{top:0;border-bottom:0}.numInputWrapper span.arrowUp:after{border-left:4px solid transparent;border-right:4px solid transparent;border-bottom:4px solid rgba(72,72,72,.6);top:26%}.numInputWrapper span.arrowDown{top:50%}.numInputWrapper span.arrowDown:after{border-left:4px solid transparent;border-right:4px solid transparent;border-top:4px solid rgba(72,72,72,.6);top:40%}.numInputWrapper span svg{width:inherit;height:auto}.numInputWrapper span svg path{fill:#5a617180}.numInputWrapper:hover{background:#0000000d}.numInputWrapper:hover span{opacity:1}.flatpickr-current-month{font-size:135%;line-height:inherit;font-weight:300;color:inherit;position:absolute;width:75%;left:12.5%;padding:7.48px 0 0;line-height:1;height:34px;display:inline-block;text-align:center;-webkit-transform:translate3d(0px,0px,0px);transform:translateZ(0)}.flatpickr-current-month span.cur-month{font-family:inherit;font-weight:700;color:inherit;display:inline-block;margin-left:.5ch;padding:0}.flatpickr-current-month span.cur-month:hover{background:#0000000d}.flatpickr-current-month .numInputWrapper{width:6ch;width:7ch�;display:inline-block}.flatpickr-current-month .numInputWrapper span.arrowUp:after{border-bottom-color:#5a6171}.flatpickr-current-month .numInputWrapper span.arrowDown:after{border-top-color:#5a6171}.flatpickr-current-month input.cur-year{background:transparent;-webkit-box-sizing:border-box;box-sizing:border-box;color:inherit;cursor:text;padding:0 0 0 .5ch;margin:0;display:inline-block;font-size:inherit;font-family:inherit;font-weight:300;line-height:inherit;height:auto;border:0;border-radius:0;vertical-align:initial;-webkit-appearance:textfield;-moz-appearance:textfield;appearance:textfield}.flatpickr-current-month input.cur-year:focus{outline:0}.flatpickr-current-month input.cur-year[disabled],.flatpickr-current-month input.cur-year[disabled]:hover{font-size:100%;color:#5a617180;background:transparent;pointer-events:none}.flatpickr-current-month .flatpickr-monthDropdown-months{appearance:menulist;background:#eceef1;border:none;border-radius:0;box-sizing:border-box;color:inherit;cursor:pointer;font-size:inherit;font-family:inherit;font-weight:300;height:auto;line-height:inherit;margin:-1px 0 0;outline:none;padding:0 0 0 .5ch;position:relative;vertical-align:initial;-webkit-box-sizing:border-box;-webkit-appearance:menulist;-moz-appearance:menulist;width:auto}.flatpickr-current-month .flatpickr-monthDropdown-months:focus,.flatpickr-current-month .flatpickr-monthDropdown-months:active{outline:none}.flatpickr-current-month .flatpickr-monthDropdown-months:hover{background:#0000000d}.flatpickr-current-month .flatpickr-monthDropdown-months .flatpickr-monthDropdown-month{background-color:#eceef1;outline:none;padding:0}.flatpickr-weekdays{background:#eceef1;text-align:center;overflow:hidden;width:100%;display:-webkit-box;display:-webkit-flex;display:-ms-flexbox;display:flex;-webkit-box-align:center;-webkit-align-items:center;-ms-flex-align:center;align-items:center;height:28px}.flatpickr-weekdays .flatpickr-weekdaycontainer{display:-webkit-box;display:-webkit-flex;display:-ms-flexbox;display:flex;-webkit-box-flex:1;-webkit-flex:1;-ms-flex:1;flex:1}span.flatpickr-weekday{cursor:default;font-size:90%;background:#eceef1;color:#5a6171;line-height:1;margin:0;text-align:center;display:block;-webkit-box-flex:1;-webkit-flex:1;-ms-flex:1;flex:1;font-weight:bolder}.dayContainer,.flatpickr-weeks{padding:1px 0 0}.flatpickr-days{position:relative;overflow:hidden;display:-webkit-box;display:-webkit-flex;display:-ms-flexbox;display:flex;-webkit-box-align:start;-webkit-align-items:flex-start;-ms-flex-align:start;align-items:flex-start;width:307.875px;border-left:1px solid #eceef1;border-right:1px solid #eceef1}.flatpickr-days:focus{outline:0}.dayContainer{padding:0;outline:0;text-align:left;width:307.875px;min-width:307.875px;max-width:307.875px;-webkit-box-sizing:border-box;box-sizing:border-box;display:inline-block;display:-ms-flexbox;display:-webkit-box;display:-webkit-flex;display:flex;-webkit-flex-wrap:wrap;flex-wrap:wrap;-ms-flex-wrap:wrap;-ms-flex-pack:justify;-webkit-justify-content:space-around;justify-content:space-around;-webkit-transform:translate3d(0px,0px,0px);transform:translateZ(0);opacity:1}.dayContainer+.dayContainer{-webkit-box-shadow:-1px 0 0 #eceef1;box-shadow:-1px 0 #eceef1}.flatpickr-day{background:none;border:1px solid transparent;border-radius:150px;-webkit-box-sizing:border-box;box-sizing:border-box;color:#484848;cursor:pointer;font-weight:400;width:14.2857143%;-webkit-flex-basis:14.2857143%;-ms-flex-preferred-size:14.2857143%;flex-basis:14.2857143%;max-width:39px;height:39px;line-height:39px;margin:0;display:inline-block;position:relative;-webkit-box-pack:center;-webkit-justify-content:center;-ms-flex-pack:center;justify-content:center;text-align:center}.flatpickr-day.inRange,.flatpickr-day.prevMonthDay.inRange,.flatpickr-day.nextMonthDay.inRange,.flatpickr-day.today.inRange,.flatpickr-day.prevMonthDay.today.inRange,.flatpickr-day.nextMonthDay.today.inRange,.flatpickr-day:hover,.flatpickr-day.prevMonthDay:hover,.flatpickr-day.nextMonthDay:hover,.flatpickr-day:focus,.flatpickr-day.prevMonthDay:focus,.flatpickr-day.nextMonthDay:focus{cursor:pointer;outline:0;background:#e2e2e2;border-color:#e2e2e2}.flatpickr-day.today{border-color:#bbb}.flatpickr-day.today:hover,.flatpickr-day.today:focus{border-color:#bbb;background:#bbb;color:#fff}.flatpickr-day.selected,.flatpickr-day.startRange,.flatpickr-day.endRange,.flatpickr-day.selected.inRange,.flatpickr-day.startRange.inRange,.flatpickr-day.endRange.inRange,.flatpickr-day.selected:focus,.flatpickr-day.startRange:focus,.flatpickr-day.endRange:focus,.flatpickr-day.selected:hover,.flatpickr-day.startRange:hover,.flatpickr-day.endRange:hover,.flatpickr-day.selected.prevMonthDay,.flatpickr-day.startRange.prevMonthDay,.flatpickr-day.endRange.prevMonthDay,.flatpickr-day.selected.nextMonthDay,.flatpickr-day.startRange.nextMonthDay,.flatpickr-day.endRange.nextMonthDay{background:#ff5a5f;-webkit-box-shadow:none;box-shadow:none;color:#fff;border-color:#ff5a5f}.flatpickr-day.selected.startRange,.flatpickr-day.startRange.startRange,.flatpickr-day.endRange.startRange{border-radius:50px 0 0 50px}.flatpickr-day.selected.endRange,.flatpickr-day.startRange.endRange,.flatpickr-day.endRange.endRange{border-radius:0 50px 50px 0}.flatpickr-day.selected.startRange+.endRange:not(:nth-child(7n+1)),.flatpickr-day.startRange.startRange+.endRange:not(:nth-child(7n+1)),.flatpickr-day.endRange.startRange+.endRange:not(:nth-child(7n+1)){-webkit-box-shadow:-10px 0 0 #ff5a5f;box-shadow:-10px 0 #ff5a5f}.flatpickr-day.selected.startRange.endRange,.flatpickr-day.startRange.startRange.endRange,.flatpickr-day.endRange.startRange.endRange{border-radius:50px}.flatpickr-day.inRange{border-radius:0;-webkit-box-shadow:-5px 0 0 #e2e2e2,5px 0 0 #e2e2e2;box-shadow:-5px 0 #e2e2e2,5px 0 #e2e2e2}.flatpickr-day.flatpickr-disabled,.flatpickr-day.flatpickr-disabled:hover,.flatpickr-day.prevMonthDay,.flatpickr-day.nextMonthDay,.flatpickr-day.notAllowed,.flatpickr-day.notAllowed.prevMonthDay,.flatpickr-day.notAllowed.nextMonthDay{color:#4848484d;background:transparent;border-color:transparent;cursor:default}.flatpickr-day.flatpickr-disabled,.flatpickr-day.flatpickr-disabled:hover{cursor:not-allowed;color:#4848481a}.flatpickr-day.week.selected{border-radius:0;-webkit-box-shadow:-5px 0 0 #ff5a5f,5px 0 0 #ff5a5f;box-shadow:-5px 0 #ff5a5f,5px 0 #ff5a5f}.flatpickr-day.hidden{visibility:hidden}.rangeMode .flatpickr-day{margin-top:1px}.flatpickr-weekwrapper{float:left}.flatpickr-weekwrapper .flatpickr-weeks{padding:0 12px;border-left:1px solid #eceef1}.flatpickr-weekwrapper .flatpickr-weekday{float:none;width:100%;line-height:28px}.flatpickr-weekwrapper span.flatpickr-day,.flatpickr-weekwrapper span.flatpickr-day:hover{display:block;width:100%;max-width:none;color:#4848484d;background:transparent;cursor:default;border:none}.flatpickr-innerContainer{display:block;display:-webkit-box;display:-webkit-flex;display:-ms-flexbox;display:flex;-webkit-box-sizing:border-box;box-sizing:border-box;overflow:hidden;background:#fff;border-bottom:1px solid #eceef1}.flatpickr-rContainer{display:inline-block;padding:0;-webkit-box-sizing:border-box;box-sizing:border-box}.flatpickr-time{text-align:center;outline:0;display:block;height:0;line-height:40px;max-height:40px;-webkit-box-sizing:border-box;box-sizing:border-box;overflow:hidden;display:-webkit-box;display:-webkit-flex;display:-ms-flexbox;display:flex;background:#fff;border-radius:0 0 5px 5px}.flatpickr-time:after{content:"";display:table;clear:both}.flatpickr-time .numInputWrapper{-webkit-box-flex:1;-webkit-flex:1;-ms-flex:1;flex:1;width:40%;height:40px;float:left}.flatpickr-time .numInputWrapper span.arrowUp:after{border-bottom-color:#484848}.flatpickr-time .numInputWrapper span.arrowDown:after{border-top-color:#484848}.flatpickr-time.hasSeconds .numInputWrapper{width:26%}.flatpickr-time.time24hr .numInputWrapper{width:49%}.flatpickr-time input{background:transparent;-webkit-box-shadow:none;box-shadow:none;border:0;border-radius:0;text-align:center;margin:0;padding:0;height:inherit;line-height:inherit;color:#484848;font-size:14px;position:relative;-webkit-box-sizing:border-box;box-sizing:border-box;-webkit-appearance:textfield;-moz-appearance:textfield;appearance:textfield}.flatpickr-time input.flatpickr-hour{font-weight:700}.flatpickr-time input.flatpickr-minute,.flatpickr-time input.flatpickr-second{font-weight:400}.flatpickr-time input:focus{outline:0;border:0}.flatpickr-time .flatpickr-time-separator,.flatpickr-time .flatpickr-am-pm{height:inherit;float:left;line-height:inherit;color:#484848;font-weight:700;width:2%;-webkit-user-select:none;-moz-user-select:none;-ms-user-select:none;user-select:none;-webkit-align-self:center;-ms-flex-item-align:center;align-self:center}.flatpickr-time .flatpickr-am-pm{outline:0;width:18%;cursor:pointer;text-align:center;font-weight:400}.flatpickr-time input:hover,.flatpickr-time .flatpickr-am-pm:hover,.flatpickr-time input:focus,.flatpickr-time .flatpickr-am-pm:focus{background:#eaeaea}.flatpickr-input[readonly]{cursor:pointer}@-webkit-keyframes fpFadeInDown{0%{opacity:0;-webkit-transform:translate3d(0,-20px,0);transform:translate3d(0,-20px,0)}to{opacity:1;-webkit-transform:translate3d(0,0,0);transform:translateZ(0)}}@keyframes fpFadeInDown{0%{opacity:0;-webkit-transform:translate3d(0,-20px,0);transform:translate3d(0,-20px,0)}to{opacity:1;-webkit-transform:translate3d(0,0,0);transform:translateZ(0)}}span.flatpickr-day.selected{font-weight:700}:root{--primary-color: #0d6efd;--secondary-color: #6c757d;--success-color: #198754;--warning-color: #ffc107;--danger-color: #dc3545;--info-color: #0dcaf0;--light-color: #f8f9fa;--dark-color: #212529;--border-radius: 4px;--box-shadow: 0 1px 2px rgba(0, 0, 0, .1)}.flow-log-container{display:flex;flex-direction:column;height:calc(100vh - 60px);width:100%;padding:0;margin:0;overflow:hidden;background-color:#f5f5f5}.flow-log-header{display:flex;flex-direction:column;padding:15px;background-color:#fff;border-bottom:1px solid #e0e0e0;box-shadow:0 2px 4px #0000000d;z-index:10}.flow-log-header h2{margin-bottom:15px;font-size:1.5rem;font-weight:600;color:#333}.flow-log-controls{width:100%}.single-row-controls{display:flex;flex-wrap:nowrap;align-items:center;gap:10px;padding:10px 0;margin-bottom:15px;border-bottom:1px solid #eee;width:100%}.single-row-controls form{flex-grow:1;margin-right:10px}.single-row-controls .input-group{width:100%}.line-limit-dropdown{position:absolute;top:100%;right:0;z-index:1000;margin-top:2px;background-color:#fff;border:1px solid #dee2e6;border-radius:4px;box-shadow:0 2px 5px #00000026;min-width:150px;overflow:hidden;display:flex;flex-direction:column}.line-limit-dropdown button{border-radius:0;border:none;text-align:left;padding:8px 12px;border-bottom:1px solid #f1f1f1}.line-limit-dropdown button:last-child{border-bottom:none}.line-limit-dropdown button:hover{background-color:#f8f9fa}.line-limit-options{display:flex;flex-wrap:wrap;gap:6px;margin-bottom:10px;background-color:#f8f9fa;padding:8px 12px;border-radius:4px;border:1px solid #e9ecef}.line-limit-options-label{display:flex;align-items:center;color:#555;font-weight:500;margin-right:10px;font-size:14px}.line-limit-option{cursor:pointer;transition:all .2s ease;padding:5px 10px;border-radius:4px;font-size:.85rem;font-weight:500;background-color:#e9ecef;color:#495057;border:none;text-decoration:none}.line-limit-option:hover{background-color:#dee2e6}.line-limit-option.active{background-color:#007bff;color:#fff}.filter-section{background-color:#f9f9f9;border-radius:4px;padding:10px;margin-bottom:10px;border:1px solid #e0e0e0}.date-filters{display:flex;flex-wrap:wrap;gap:10px;margin-top:10px}.log-stats{padding:8px 12px;background-color:#ffffff0d;border-radius:4px;margin-bottom:10px;display:flex;justify-content:space-between;align-items:center}.log-stats small{color:#aaa!important}.filter-badges{display:flex;flex-wrap:wrap;align-items:center;margin-bottom:10px;gap:6px;background-color:#f8f9fa;padding:8px 12px;border-radius:4px;border:1px solid #e9ecef}.filter-badges-label{display:flex;align-items:center;color:#555;font-weight:500;margin-right:10px;font-size:14px}.filter-badge{cursor:pointer;transition:all .2s ease;padding:5px 10px;border-radius:4px;font-size:.85rem;font-weight:500;border:none}.filter-badge:hover{opacity:.9;transform:translateY(-1px)}.active-filters{display:flex;flex-wrap:wrap;gap:6px;margin-bottom:10px}.search-input{border-radius:4px 0 0 4px!important;padding-left:10px!important;font-size:14px!important}.search-button{border-radius:0 4px 4px 0!important}.control-button{border-radius:4px;padding:6px 12px;font-weight:500;display:flex;align-items:center;gap:5px;font-size:14px;white-space:nowrap}.flow-log-content{flex:1;overflow-y:auto;padding:15px;font-family:Consolas,Monaco,Courier New,monospace;font-size:13px;line-height:1.5;white-space:pre-wrap;word-break:break-all;background-color:#1e1e1e;color:#d4d4d4;border-radius:4px;margin:10px;box-shadow:inset 0 0 5px #0003}.log-entry-repeated{background-color:#f8f9fa;border-left:3px solid #6c757d;padding:8px 12px;margin-bottom:6px}.repeated-content-info{font-size:12px;color:#6c757d;margin-bottom:5px;border-bottom:1px dashed #dee2e6;padding-bottom:3px}.repeated-line{display:flex;align-items:flex-start;margin-bottom:3px}.repeated-line-count{background-color:#e9ecef;color:#495057;font-weight:600;border-radius:3px;padding:1px 5px;font-size:12px;margin-right:8px;min-width:36px;text-align:center}.repeated-line-content{font-family:Consolas,Monaco,Courier New,monospace;font-size:13px}.flow-log-content pre{white-space:pre-wrap;word-break:break-word;margin:0;font-family:Consolas,Monaco,Courier New,monospace;font-size:13px;line-height:1.5;width:100%;overflow:auto;background:transparent;border:none;padding:0;color:inherit;max-width:100%;display:block}.log-entry,.log-section-divider,.log-session-start,.log-session-end,.log-sent-to-client,.log-sent-to-backend,.log-ai-response,.log-client-input,.log-backend-ai-event{padding:8px 10px;margin-bottom:4px;border-radius:3px;overflow:visible;width:100%;max-width:100%;display:block;box-sizing:border-box}.log-sent-to-client{background-color:#1987541a;border-left:4px solid #198754}pre .json-property{color:#a6e22e;font-weight:700}.flow-log-content pre:not(:has(>div)){display:block!important;width:100%!important}.log-entry{margin-bottom:3px;padding:2px 0}.log-section-divider{color:#6c757d;margin:8px 0;border-top:1px dashed rgba(108,117,125,.3);padding-top:5px}.log-session-start{font-weight:700;color:#00b7ff;margin:15px 0 5px;padding:8px;background-color:#00b7ff1a;border-radius:4px;border-left:4px solid #00b7ff}.log-session-end{font-weight:700;color:#ff6b6b;margin:5px 0 15px;padding:8px;background-color:#ff6b6b1a;border-radius:4px;border-left:4px solid #ff6b6b}.log-sent-to-client{color:#4caf50;padding-left:5px;border-left:2px solid #4caf50}.log-sent-to-backend{color:#ff9800;padding-left:5px;border-left:2px solid #ff9800}.log-ai-response{color:#9c27b0;padding-left:5px;border-left:2px solid #9c27b0}.log-client-input{color:#2196f3;font-weight:500;padding-left:5px;border-left:2px solid #2196f3}.log-backend-ai-event{color:#e91e63;padding-left:5px;border-left:2px solid #e91e63}.mr-1{margin-right:4px!important}.mr-2{margin-right:8px!important}.ml-2{margin-left:8px!important}.mt-2{margin-top:8px!important}.mb-2{margin-bottom:8px!important}.mb-3{margin-bottom:16px!important}.flow-log-content::-webkit-scrollbar{width:8px}.flow-log-content::-webkit-scrollbar-track{background:#2e2e2e;border-radius:4px}.flow-log-content::-webkit-scrollbar-thumb{background:#555;border-radius:4px}.flow-log-content::-webkit-scrollbar-thumb:hover{background:#777}@media (max-width: 768px){.flow-log-header{padding:12px}.flow-log-controls{width:100%}.single-row-controls{flex-wrap:wrap}.single-row-controls form{flex:1 0 100%;margin-bottom:10px;margin-right:0}.single-row-controls .control-button{flex:1;justify-content:center}.filter-badges{flex-direction:column;align-items:flex-start}.filter-badges span{margin-bottom:5px}.date-filters{flex-direction:column}.line-limit-options{flex-direction:column;align-items:flex-start}}.flow-log-container.fullscreen{position:fixed;top:0;left:0;width:100vw;height:100vh;z-index:9999;background-color:#f5f5f5;border:none;border-radius:0;padding:0;margin:0}.flow-log-container.fullscreen .flow-log-header{border-radius:0;padding:10px 15px;background-color:#222;color:#fff}.flow-log-container.fullscreen .flow-log-header h2{color:#fff;margin-bottom:0;font-size:1.25rem}.flow-log-container.fullscreen .flow-log-content{max-height:none;height:calc(100vh - 60px);padding-top:5px}.flow-log-container.fullscreen .control-button{background-color:transparent;border-color:#555;color:#ddd}.flow-log-container.fullscreen .control-button:hover{background-color:#ffffff1a;border-color:#777;color:#fff}@media (max-width: 768px){.flow-log-container.fullscreen .flow-log-content{height:calc(100vh - 60px)}}.notification-container{position:fixed;top:20px;right:20px;z-index:9999;max-width:350px}.notification-container .toast{box-shadow:0 4px 12px #00000026;border:none}.notification-container .toast-header{border-bottom:1px solid rgba(255,255,255,.2);color:#fff;background-color:#ffffff1a}.notification-container .toast-header .close{color:#fff;opacity:.8;text-shadow:none}.notification-container .toast-header .close:hover{opacity:1}.alert{margin-bottom:15px}.alert-danger{background-color:#dc35451a;border-color:#dc354533;color:#dc3545}.alert-warning{background-color:#ffc1071a;border-color:#ffc10733;color:#856404}.dropdown-menu{box-shadow:0 2px 8px #00000026;border:1px solid rgba(0,0,0,.1)}.dropdown-item{padding:8px 15px;font-size:14px}.dropdown-item .svg-inline--fa{width:16px;text-align:center}.dropdown-item.text-danger:hover{background-color:#dc35451a}.dropdown-divider{margin:4px 0}.alert-danger{margin-bottom:15px}.control-button.btn-outline-danger:hover{background-color:#dc3545;color:#fff}.mr-2{margin-right:.5rem!important}.success-filter-badges{display:flex;margin-left:10px;gap:6px}.success-filter-true.badge{cursor:pointer;border:1px solid #198754}.success-filter-true.badge.bg-secondary{border:1px solid #198754;color:#198754;background-color:#19875426!important}.success-filter-false.badge{cursor:pointer;border:1px solid #dc3545}.success-filter-false.badge.bg-secondary{border:1px solid #dc3545;color:#dc3545;background-color:#dc354526!important}.file-dropdown-container{position:relative;display:inline-block}.file-dropdown-menu{position:absolute;top:100%;right:0;z-index:1100;max-height:300px;overflow-y:auto;width:auto;min-width:270px;margin-top:5px;box-shadow:0 6px 16px #00000026;background-color:#fff;border:1px solid rgba(0,0,0,.1);border-radius:6px;padding:8px 0;animation:fadeInDropdown .2s ease}@keyframes fadeInDropdown{0%{opacity:0;transform:translateY(-5px)}to{opacity:1;transform:translateY(0)}}.file-dropdown-menu .dropdown-item{white-space:nowrap;overflow:hidden;text-overflow:ellipsis;padding:10px 15px;font-size:14px;cursor:pointer;display:block;width:100%;text-align:left;clear:both;font-weight:400;line-height:1.5;color:#212529;background-color:transparent;transition:background-color .15s ease-in-out}.file-dropdown-menu .dropdown-item:hover{background-color:#f0f7ff;color:#0d6efd;text-decoration:none}.file-dropdown-menu .dropdown-item.active{background-color:#0d6efd;color:#fff;font-weight:500}.file-dropdown-menu .dropdown-item.disabled{color:#adb5bd;pointer-events:none;background-color:transparent;cursor:default;font-style:italic}.file-dropdown-menu .dropdown-divider{height:0;margin:.5rem 0;overflow:hidden;border-top:1px solid #e9ecef}#log-file-dropdown{position:relative;z-index:1;border-color:#0dcaf0;min-width:60px;transition:all .2s ease}#log-file-dropdown:hover,#log-file-dropdown:focus{background-color:#e6f7fa;border-color:#0dcaf0;color:#0aa2c0;box-shadow:0 0 0 .2rem #0dcaf040}#log-file-dropdown:active{background-color:#d0f2f7}.file-dropdown-menu::-webkit-scrollbar{width:8px}.file-dropdown-menu::-webkit-scrollbar-track{background:#f1f1f1;border-radius:4px}.file-dropdown-menu::-webkit-scrollbar-thumb{background:#c1c1c1;border-radius:4px}.file-dropdown-menu::-webkit-scrollbar-thumb:hover{background:#a8a8a8}.line-limit-dropdown-container{position:relative;display:inline-block}.line-limit-dropdown-menu{position:absolute;top:100%;right:0;z-index:1100;max-height:300px;overflow-y:auto;width:auto;min-width:200px;margin-top:5px;box-shadow:0 6px 16px #00000026;background-color:#fff;border:1px solid rgba(0,0,0,.1);border-radius:6px;padding:8px 0;animation:fadeInDropdown .2s ease}.line-limit-dropdown-menu .dropdown-item{white-space:nowrap;overflow:hidden;text-overflow:ellipsis;padding:10px 15px;font-size:14px;cursor:pointer;display:block;width:100%;text-align:left;clear:both;font-weight:400;line-height:1.5;color:#212529;background-color:transparent;transition:background-color .15s ease-in-out}.line-limit-dropdown-menu .dropdown-item:hover{background-color:#f0f7ff;color:#0d6efd;text-decoration:none}.line-limit-dropdown-menu .dropdown-item.active{background-color:#0d6efd;color:#fff;font-weight:500}#line-limit-dropdown{position:relative;z-index:1;min-width:60px;transition:all .2s ease}#line-limit-dropdown:hover,#line-limit-dropdown:focus{background-color:#f1f1f1;border-color:#6c757d;box-shadow:0 0 0 .2rem #6c757d40}#line-limit-dropdown:active{background-color:#e2e6ea}.line-limit-dropdown-menu::-webkit-scrollbar{width:8px}.line-limit-dropdown-menu::-webkit-scrollbar-track{background:#f1f1f1;border-radius:4px}.line-limit-dropdown-menu::-webkit-scrollbar-thumb{background:#c1c1c1;border-radius:4px}.line-limit-dropdown-menu::-webkit-scrollbar-thumb:hover{background:#a8a8a8}.log-pagination{display:flex;justify-content:space-between;align-items:center;margin:20px 0;padding:10px;background-color:#f8f9fa;border-radius:5px}.pagination-info{color:#6c757d;font-size:.9rem}.pagination{margin:0}.pagination .page-link{display:flex;align-items:center;justify-content:center;min-width:36px}.pagination-bottom-container{margin-top:20px;padding-bottom:20px;border-top:1px solid #dee2e6}.line-limit-dropdown-menu,.file-dropdown-menu{position:absolute;top:100%;left:0;z-index:1000;min-width:10rem;padding:.5rem 0;font-size:.875rem;color:#212529;background-color:#fff;border:1px solid rgba(0,0,0,.15);border-radius:.25rem;box-shadow:0 .5rem 1rem #00000026}.dropdown-item{display:block;width:100%;padding:.25rem 1.5rem;clear:both;font-weight:400;color:#212529;text-align:inherit;white-space:nowrap;background-color:transparent;border:0;cursor:pointer}.dropdown-item:hover,.dropdown-item:focus{color:#16181b;text-decoration:none;background-color:#f8f9fa}.dropdown-item.active{color:#fff;text-decoration:none;background-color:#007bff}.spinner-container{display:flex;align-items:center;margin-left:10px}.spinner-container .spinner-border{width:1rem;height:1rem;margin-right:5px}@media (max-width: 768px){.log-pagination{flex-direction:column;gap:10px}.pagination{margin-bottom:10px}.pagination .page-link{min-width:32px;padding:.25rem .5rem}}.loading-overlay{position:fixed;bottom:20px;right:20px;z-index:1000;padding:10px 20px;background-color:#000000b3;color:#fff;border-radius:5px;box-shadow:0 2px 10px #0000004d}.loading-container{display:flex;align-items:center;justify-content:center}.loading-container .spinner-border{width:1.2rem;height:1.2rem;margin-right:10px}.log-stats{display:flex;justify-content:space-between;padding:8px 10px;background-color:#f8f9fa;border-radius:5px;margin-bottom:15px;font-size:.9rem;color:#6c757d}@media (max-width: 768px){.log-stats{flex-direction:column;gap:5px}.loading-overlay{bottom:10px;right:10px;padding:8px 15px;font-size:.9rem}}:root{--color-primary: #0099ff;--color-primary-light: #33b1ff;--color-primary-dark: #0077cc;--color-secondary: #3a86ff;--color-accent: #00c8ff;--color-warning: #ffbe0b;--color-danger: #ff006e;--color-success: #06d6a0;--color-dark: #1e293b;--color-light: #f8fafc;--color-dark-blue: #172554;--color-light-blue: #bfdbfe;--color-gray-100: #f1f5f9;--color-gray-200: #e2e8f0;--color-gray-300: #cbd5e1;--color-gray-400: #94a3b8;--color-gray-500: #64748b;--color-gray-600: #475569;--color-gray-700: #334155;--color-gray-800: #1e293b;--color-gray-900: #0f172a;--font-primary: "Inter", "Roboto", "Helvetica Neue", Arial, sans-serif;--shadow-sm: 0 1px 3px rgba(0, 0, 0, .05);--shadow-md: 0 4px 6px rgba(0, 0, 0, .07), 0 1px 3px rgba(0, 0, 0, .1);--shadow-lg: 0 10px 15px -3px rgba(0, 0, 0, .08), 0 4px 6px -2px rgba(0, 0, 0, .05);--shadow-xl: 0 20px 25px -5px rgba(0, 0, 0, .1), 0 10px 10px -5px rgba(0, 0, 0, .04);--border-radius-sm: 4px;--border-radius: 8px;--border-radius-lg: 12px;--border-radius-xl: 16px;--border-radius-full: 9999px}*{margin:0;padding:0;box-sizing:border-box}body{font-family:var(--font-primary);color:var(--color-gray-800);line-height:1.5;background-color:var(--color-light);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}input:-webkit-autofill,input:-webkit-autofill:hover,input:-webkit-autofill:focus,input:-webkit-autofill:active{transition:background-color 5000s ease-in-out 0s!important;-webkit-text-fill-color:inherit!important;caret-color:inherit}::-webkit-scrollbar{width:8px;height:8px}::-webkit-scrollbar-track{background:var(--color-gray-100);border-radius:var(--border-radius)}::-webkit-scrollbar-thumb{background:var(--color-gray-300);border-radius:var(--border-radius)}::-webkit-scrollbar-thumb:hover{background:var(--color-gray-400)}.container{width:100%;max-width:1200px;margin:0 auto;padding:0 15px}.flex{display:flex}.flex-col{flex-direction:column}.items-center{align-items:center}.justify-between{justify-content:space-between}.p-2{padding:.5rem}.p-4{padding:1rem}.m-2{margin:.5rem}.m-4{margin:1rem}.mt-4{margin-top:1rem}.mb-4{margin-bottom:1rem}.text-center{text-align:center}.text-right{text-align:right}.text-primary{color:var(--color-primary)}.text-danger{color:var(--color-danger)}.app-container{display:flex;min-height:100vh}.main-content{flex-grow:1;padding:1.5rem}.form-group{margin-bottom:1rem}.form-label{display:block;margin-bottom:.5rem;font-weight:500;color:var(--color-gray-700)}.card{background-color:#fff;border-radius:var(--border-radius-lg);box-shadow:var(--shadow-md);padding:1.5rem;margin-bottom:1.5rem;border:1px solid var(--color-gray-100);transition:all .3s ease}.card:hover{box-shadow:var(--shadow-lg)}.btn{display:inline-flex;align-items:center;justify-content:center;padding:.5rem 1rem;border-radius:var(--border-radius);font-weight:500;transition:all .2s ease;cursor:pointer;border:none}.btn-primary{background-color:var(--color-primary);color:#fff}.btn-primary:hover{background-color:var(--color-primary-dark)}.btn-secondary{background-color:var(--color-gray-200);color:var(--color-gray-800)}.btn-secondary:hover{background-color:var(--color-gray-300)}.fade-enter{opacity:0}.fade-enter-active{opacity:1;transition:opacity .3s}.fade-exit{opacity:1}.fade-exit-active{opacity:0;transition:opacity .3s}
