*,:before,:after{--tw-border-spacing-x: 0;--tw-border-spacing-y: 0;--tw-translate-x: 0;--tw-translate-y: 0;--tw-rotate: 0;--tw-skew-x: 0;--tw-skew-y: 0;--tw-scale-x: 1;--tw-scale-y: 1;--tw-pan-x: ;--tw-pan-y: ;--tw-pinch-zoom: ;--tw-scroll-snap-strictness: proximity;--tw-gradient-from-position: ;--tw-gradient-via-position: ;--tw-gradient-to-position: ;--tw-ordinal: ;--tw-slashed-zero: ;--tw-numeric-figure: ;--tw-numeric-spacing: ;--tw-numeric-fraction: ;--tw-ring-inset: ;--tw-ring-offset-width: 0px;--tw-ring-offset-color: #fff;--tw-ring-color: rgb(59 130 246 / .5);--tw-ring-offset-shadow: 0 0 #0000;--tw-ring-shadow: 0 0 #0000;--tw-shadow: 0 0 #0000;--tw-shadow-colored: 0 0 #0000;--tw-blur: ;--tw-brightness: ;--tw-contrast: ;--tw-grayscale: ;--tw-hue-rotate: ;--tw-invert: ;--tw-saturate: ;--tw-sepia: ;--tw-drop-shadow: ;--tw-backdrop-blur: ;--tw-backdrop-brightness: ;--tw-backdrop-contrast: ;--tw-backdrop-grayscale: ;--tw-backdrop-hue-rotate: ;--tw-backdrop-invert: ;--tw-backdrop-opacity: ;--tw-backdrop-saturate: ;--tw-backdrop-sepia: ;--tw-contain-size: ;--tw-contain-layout: ;--tw-contain-paint: ;--tw-contain-style: }::backdrop{--tw-border-spacing-x: 0;--tw-border-spacing-y: 0;--tw-translate-x: 0;--tw-translate-y: 0;--tw-rotate: 0;--tw-skew-x: 0;--tw-skew-y: 0;--tw-scale-x: 1;--tw-scale-y: 1;--tw-pan-x: ;--tw-pan-y: ;--tw-pinch-zoom: ;--tw-scroll-snap-strictness: proximity;--tw-gradient-from-position: ;--tw-gradient-via-position: ;--tw-gradient-to-position: ;--tw-ordinal: ;--tw-slashed-zero: ;--tw-numeric-figure: ;--tw-numeric-spacing: ;--tw-numeric-fraction: ;--tw-ring-inset: ;--tw-ring-offset-width: 0px;--tw-ring-offset-color: #fff;--tw-ring-color: rgb(59 130 246 / .5);--tw-ring-offset-shadow: 0 0 #0000;--tw-ring-shadow: 0 0 #0000;--tw-shadow: 0 0 #0000;--tw-shadow-colored: 0 0 #0000;--tw-blur: ;--tw-brightness: ;--tw-contrast: ;--tw-grayscale: ;--tw-hue-rotate: ;--tw-invert: ;--tw-saturate: ;--tw-sepia: ;--tw-drop-shadow: ;--tw-backdrop-blur: ;--tw-backdrop-brightness: ;--tw-backdrop-contrast: ;--tw-backdrop-grayscale: ;--tw-backdrop-hue-rotate: ;--tw-backdrop-invert: ;--tw-backdrop-opacity: ;--tw-backdrop-saturate: ;--tw-backdrop-sepia: ;--tw-contain-size: ;--tw-contain-layout: ;--tw-contain-paint: ;--tw-contain-style: }*,:before,:after{box-sizing:border-box;border-width:0;border-style:solid;border-color:#e5e7eb}:before,:after{--tw-content: ""}html,:host{line-height:1.5;-webkit-text-size-adjust:100%;-moz-tab-size:4;-o-tab-size:4;tab-size:4;font-family:ui-sans-serif,system-ui,sans-serif,"Apple Color Emoji","Segoe UI Emoji",Segoe UI Symbol,"Noto Color Emoji";font-feature-settings:normal;font-variation-settings:normal;-webkit-tap-highlight-color:transparent}body{margin:0;line-height:inherit}hr{height:0;color:inherit;border-top-width:1px}abbr:where([title]){-webkit-text-decoration:underline dotted;text-decoration:underline dotted}h1,h2,h3,h4,h5,h6{font-size:inherit;font-weight:inherit}a{color:inherit;text-decoration:inherit}b,strong{font-weight:bolder}code,kbd,samp,pre{font-family:ui-monospace,SFMono-Regular,Menlo,Monaco,Consolas,Liberation Mono,Courier New,monospace;font-feature-settings:normal;font-variation-settings:normal;font-size:1em}small{font-size:80%}sub,sup{font-size:75%;line-height:0;position:relative;vertical-align:baseline}sub{bottom:-.25em}sup{top:-.5em}table{text-indent:0;border-color:inherit;border-collapse:collapse}button,input,optgroup,select,textarea{font-family:inherit;font-feature-settings:inherit;font-variation-settings:inherit;font-size:100%;font-weight:inherit;line-height:inherit;letter-spacing:inherit;color:inherit;margin:0;padding:0}button,select{text-transform:none}button,input:where([type=button]),input:where([type=reset]),input:where([type=submit]){-webkit-appearance:button;background-color:transparent;background-image:none}:-moz-focusring{outline:auto}:-moz-ui-invalid{box-shadow:none}progress{vertical-align:baseline}::-webkit-inner-spin-button,::-webkit-outer-spin-button{height:auto}[type=search]{-webkit-appearance:textfield;outline-offset:-2px}::-webkit-search-decoration{-webkit-appearance:none}::-webkit-file-upload-button{-webkit-appearance:button;font:inherit}summary{display:list-item}blockquote,dl,dd,h1,h2,h3,h4,h5,h6,hr,figure,p,pre{margin:0}fieldset{margin:0;padding:0}legend{padding:0}ol,ul,menu{list-style:none;margin:0;padding:0}dialog{padding:0}textarea{resize:vertical}input::-moz-placeholder,textarea::-moz-placeholder{opacity:1;color:#9ca3af}input::placeholder,textarea::placeholder{opacity:1;color:#9ca3af}button,[role=button]{cursor:pointer}:disabled{cursor:default}img,svg,video,canvas,audio,iframe,embed,object{display:block;vertical-align:middle}img,video{max-width:100%;height:auto}[hidden]:where(:not([hidden=until-found])){display:none}:root{--background: 0 0% 100%;--foreground: 222.2 84% 4.9%;--card: 0 0% 100%;--card-foreground: 222.2 84% 4.9%;--popover: 0 0% 100%;--popover-foreground: 222.2 84% 4.9%;--primary: 222.2 47.4% 11.2%;--primary-foreground: 210 40% 98%;--secondary: 210 40% 96.1%;--secondary-foreground: 222.2 47.4% 11.2%;--muted: 210 40% 96.1%;--muted-foreground: 215.4 16.3% 46.9%;--accent: 210 40% 96.1%;--accent-foreground: 222.2 47.4% 11.2%;--destructive: 0 84.2% 60.2%;--destructive-foreground: 210 40% 98%;--border: 214.3 31.8% 91.4%;--input: 214.3 31.8% 91.4%;--ring: 222.2 84% 4.9%;--radius: .5rem}*{border-color:hsl(var(--border))}body{background-color:hsl(var(--background));color:hsl(var(--foreground))}.container{width:100%}@media(min-width:640px){.container{max-width:640px}}@media(min-width:768px){.container{max-width:768px}}@media(min-width:1024px){.container{max-width:1024px}}@media(min-width:1280px){.container{max-width:1280px}}@media(min-width:1536px){.container{max-width:1536px}}.collapse{visibility:collapse}.absolute{position:absolute}.relative{position:relative}.block{display:block}.inline-block{display:inline-block}.flex{display:flex}.table{display:table}.grid{display:grid}.hidden{display:none}.transform{transform:translate(var(--tw-translate-x),var(--tw-translate-y)) rotate(var(--tw-rotate)) skew(var(--tw-skew-x)) skewY(var(--tw-skew-y)) scaleX(var(--tw-scale-x)) scaleY(var(--tw-scale-y))}.border{border-width:1px}.underline{text-decoration-line:underline}.filter{filter:var(--tw-blur) var(--tw-brightness) var(--tw-contrast) var(--tw-grayscale) var(--tw-hue-rotate) var(--tw-invert) var(--tw-saturate) var(--tw-sepia) var(--tw-drop-shadow)}.transition{transition-property:color,background-color,border-color,text-decoration-color,fill,stroke,opacity,box-shadow,transform,filter,backdrop-filter;transition-timing-function:cubic-bezier(.4,0,.2,1);transition-duration:.15s}@keyframes enter{0%{opacity:var(--tw-enter-opacity, 1);transform:translate3d(var(--tw-enter-translate-x, 0),var(--tw-enter-translate-y, 0),0) scale3d(var(--tw-enter-scale, 1),var(--tw-enter-scale, 1),var(--tw-enter-scale, 1)) rotate(var(--tw-enter-rotate, 0))}}@keyframes exit{to{opacity:var(--tw-exit-opacity, 1);transform:translate3d(var(--tw-exit-translate-x, 0),var(--tw-exit-translate-y, 0),0) scale3d(var(--tw-exit-scale, 1),var(--tw-exit-scale, 1),var(--tw-exit-scale, 1)) rotate(var(--tw-exit-rotate, 0))}}.login-page-wrapper{height:100vh;width:100vw;display:flex;align-items:center;justify-content:center;background-color:#eef2f5;font-family:Segoe UI,Arial,sans-serif;overflow:hidden;margin:0;padding:0}.login-container{display:flex;width:1200px;max-width:90vw;height:650px;max-height:90vh;background:#fff;border-radius:20px;box-shadow:0 15px 40px #00000014;overflow:hidden}.left-panel{flex:1.1;background:linear-gradient(#b2222266,#ff4d4d33),url(/red_background.jpg);background-size:cover;background-position:center;background-repeat:no-repeat;display:flex;align-items:center;justify-content:center;color:#fff;flex-direction:column;box-shadow:4px 0 25px #0000000d;z-index:2}.left-panel h1{font-size:2.8rem;font-weight:800;letter-spacing:2px;text-align:center;padding:0 20px;margin:0;text-shadow:0 4px 15px rgba(0,0,0,.15)}.left-panel p{font-size:1.25rem;margin-top:15px;opacity:.95;letter-spacing:1px}.right-panel{flex:1;display:flex;align-items:center;justify-content:center;padding:40px;background:#fff}.login-form-wrapper{width:100%;max-width:380px}.form-header h2{color:#333;font-size:2rem;margin:0 0 8px;font-weight:700}.form-header p{color:#777;margin:0 0 35px;font-size:1rem}.form-group{margin-bottom:24px;position:relative}.form-group label{display:block;margin-bottom:8px;color:#4a5568;font-weight:600;font-size:.95rem}.form-group input{width:100%;padding:15px 16px;border:1px solid #cbd5e1;background-color:#f8fafc;border-radius:10px;box-sizing:border-box;font-size:15px;color:#333;transition:all .3s ease}.form-group input:focus{background-color:#fff;border-color:#ff4d4d;outline:none;box-shadow:0 0 0 4px #ff4d4d26}.btn-login{width:100%;padding:15px;background:#ff4d4d;color:#fff;border:none;border-radius:10px;font-size:16px;font-weight:700;text-transform:uppercase;letter-spacing:1px;cursor:pointer;transition:all .3s ease;margin-top:15px;box-shadow:0 4px 14px #ff4d4d4d}.btn-login:hover{background:#fc3a3a;transform:translateY(-2px);box-shadow:0 6px 20px #ff4d4d66}.extra-links{margin-top:30px;font-size:.95rem;color:#718096;display:flex;justify-content:space-between;align-items:center}.btn-admin{background:#2d3748;color:#fff;padding:8px 14px;text-decoration:none;border-radius:6px;font-size:.85rem;font-weight:500;cursor:pointer;transition:background .3s}.btn-admin:hover{background:#1a202c}.message-box{margin-top:20px;padding:12px;border-radius:8px;font-size:14px;text-align:center}.error{background:#ffe5e5;color:#e53e3e;border:1px solid #feb2b2}.success{background:#e6fffa;color:#38a169;border:1px solid #9ae6b4}@media(max-width:768px),(max-height:500px)and (orientation:landscape){.login-page-wrapper{height:auto;min-height:100vh;overflow-y:auto;background-color:#f8f9fa;align-items:flex-start}.login-container{flex-direction:column;border-radius:0;box-shadow:none;height:100vh;width:100%;max-width:100%;max-height:100vh}.left-panel{flex:0 0 25vh;min-height:180px;width:100%;border-bottom-left-radius:40px;border-bottom-right-radius:40px;box-shadow:0 4px 15px #ff4d4d4d;z-index:10;padding:20px;background:linear-gradient(#b2222266,#ff4d4d33),url(/red_background.jpg);background-size:cover;background-position:center}.left-panel h1{font-size:1.8rem}.left-panel p{display:none}.right-panel{flex:1;padding:20px;align-items:flex-start;background:transparent}.login-form-wrapper{background:#fff;padding:30px!important;border-radius:16px;box-shadow:0 8px 25px #00000014;margin-top:-40px;z-index:15;position:relative;max-width:100%}.btn-admin{display:none}.extra-links{justify-content:center}}.create-body{margin:0;font-family:Segoe UI,Arial,sans-serif;height:100vh;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,#ff4d4d,#ff9a9e);width:100%}.create-card{background:#fff;padding:40px;border-radius:10px;box-shadow:0 10px 25px #0003;width:400px}.create-h1{color:#b22222;text-align:center;margin-bottom:30px;font-size:24px;margin-top:0}.form-group{margin-bottom:20px}.form-group label{display:block;margin-bottom:8px;color:#555;font-weight:700}.form-group input,.form-group select{width:100%;padding:10px;border:1px solid #ddd;border-radius:5px;box-sizing:border-box;font-size:14px}.create-btn{width:100%;padding:12px;background:#b22222;color:#fff;border:none;border-radius:5px;font-size:16px;cursor:pointer;font-weight:700;transition:background .3s}.create-btn:hover{background:#8b0000}.note{text-align:center;margin-top:15px;font-size:.9em;color:#666}.msg-error{color:red;text-align:center;margin-bottom:15px;display:block}.msg-success{color:green;text-align:center;margin-bottom:15px;display:block}.dashboard-body{margin:0;font-family:Segoe UI,Arial,sans-serif;background:#f4f7f6;height:100vh;display:flex;flex-direction:column;overflow:hidden}.dash-header{background-color:#b22222;color:#fff;padding:10px 20px;display:flex;justify-content:space-between;align-items:center;box-shadow:0 2px 5px #0000001a;height:50px;box-sizing:border-box}.dash-header h1{margin:0;font-size:1.1rem;text-transform:uppercase;letter-spacing:1px}.user-menu{cursor:pointer;position:relative;font-weight:700;font-size:.95rem}.user-dropdown{position:absolute;top:100%;right:0;background:#fff;border:1px solid #ddd;border-radius:4px;box-shadow:0 4px 8px #0000001a;min-width:150px;z-index:100;color:#333}.user-dropdown button{width:100%;padding:10px;text-align:left;background:none;border:none;cursor:pointer;color:#333}.user-dropdown button:hover{background:#f0f0f0}.dash-container{flex:1;display:flex;padding:15px;gap:15px;overflow:hidden}.main-panel{flex:3;background:#fff;border-radius:8px;padding:15px;display:flex;flex-direction:column;box-shadow:0 1px 3px #0000000d;border:1px solid #e0e0e0}.admin-panel{flex:1;background:#fff;border-radius:8px;padding:15px;display:flex;flex-direction:column;gap:12px;box-shadow:0 1px 3px #0000000d;border:1px solid #e0e0e0;overflow-y:auto;max-width:350px}.date-nav{display:flex;justify-content:space-between;align-items:center;margin-bottom:15px;border-bottom:2px solid #f0f0f0;padding-bottom:10px}.btn-nav{background:#eee;border:none;padding:5px 12px;border-radius:4px;cursor:pointer;font-weight:500}.task-list{flex:1;overflow-y:auto;border:1px solid #eee;position:relative;background:#fafafa;border-radius:4px}.time-slot{border-bottom:1px solid #f0f0f0;height:50px;position:relative}.time-label{position:absolute;top:-10px;left:5px;font-size:11px;color:#999}.btn-add{background:#b22222;color:#fff;padding:12px 40px;border-radius:30px;border:none;font-size:16px;cursor:pointer;box-shadow:0 4px 6px #b222224d;font-weight:700;margin:15px auto;display:block}.btn-add:hover{transform:translateY(-2px);background:#a51b1b}.admin-input{width:100%;padding:12px;margin-bottom:10px;border:1px solid #ccc;border-radius:4px;box-sizing:border-box;font-size:15px}.btn-action{width:100%;padding:12px;background:#b22222;color:#fff;border:none;border-radius:4px;cursor:pointer;font-weight:700;margin-bottom:5px;font-size:14px}.btn-feedback{position:fixed;bottom:30px;left:30px;width:60px;height:60px;background:linear-gradient(135deg,#ff9800,#f57c00);color:#fff;border-radius:50%;box-shadow:0 4px 15px #f57c0066;display:flex;align-items:center;justify-content:center;text-decoration:none;font-size:24px;z-index:3000;transition:transform .2s;border:3px solid white}.btn-feedback:hover{transform:scale(1.1);box-shadow:0 6px 20px #f57c0099}.btn-feedback:after{content:"Báo lỗi";position:absolute;bottom:-25px;font-size:12px;color:#333;font-weight:700;white-space:nowrap}.modal-overlay{position:fixed;top:0;left:0;width:100%;height:100%;background:#00000080;z-index:2000;display:flex;justify-content:center;align-items:center}.modal-content{background:#fff;width:500px;padding:20px;border-radius:8px;box-shadow:0 10px 25px #0003;max-height:90vh;overflow-y:auto}.form-group{margin-bottom:15px}.form-group label{display:block;margin-bottom:6px;font-weight:600;font-size:.95rem}.form-group input:not([type=checkbox]):not([type=radio]),.form-group select,.form-group textarea{width:100%;padding:10px;border:1px solid #ddd;border-radius:4px;box-sizing:border-box}.form-group input[type=checkbox]{width:16px;height:16px;margin:0;padding:0;cursor:pointer;accent-color:#b22222;flex-shrink:0}.job-manage-item{display:flex;justify-content:space-between;align-items:center;padding:8px;border-bottom:1px solid #f0f0f0;background:#fff}.job-manage-item:hover{background:#fafafa}.btn-del-job{color:#fff;background:#d32f2f;border:none;padding:5px 10px;border-radius:4px;cursor:pointer;font-size:12px;font-weight:700}.job-table{width:100%;border-collapse:collapse;margin-top:5px;font-size:13px}.job-table th,.job-table td{padding:8px;border-bottom:1px solid #eee;text-align:left}.selected-row{background-color:#e8f5e9}.auth-body{font-family:Segoe UI,Arial,sans-serif;display:flex;justify-content:center;align-items:center;height:100vh;background:#f0f2f5;margin:0}.auth-card{background:#fff;padding:30px;border-radius:8px;box-shadow:0 4px 10px #0000001a;width:350px;text-align:center}.auth-h2{color:#b22222;margin-bottom:20px}.auth-input{width:100%;padding:10px;margin-bottom:15px;border:1px solid #ddd;border-radius:4px;box-sizing:border-box}.auth-btn{width:100%;padding:10px;background:#b22222;color:#fff;border:none;border-radius:4px;cursor:pointer;font-weight:700}.auth-btn:hover{background:#8b0000}.auth-error{color:red;margin-top:10px;font-size:.9em;display:block}.auth-back-link{display:block;margin-top:15px;text-decoration:none;color:#666;font-size:.9em}.desktop-timeline{display:block;height:100%}.mobile-agenda{display:none}@media(max-width:768px),(max-height:500px)and (orientation:landscape){.dashboard-body{height:auto!important;min-height:100vh;overflow-y:auto!important;overflow-x:hidden}.dash-container{flex-direction:column;overflow:visible!important;padding:10px}.main-panel,.admin-panel{max-width:100%;width:100%;flex:none;box-sizing:border-box}.admin-panel{margin-top:10px}.task-list{overflow-y:visible!important;height:auto;border:none;background:transparent}.desktop-timeline{display:none!important}.mobile-agenda{display:block!important}}.agenda-item{display:flex;padding:15px 10px;margin-bottom:10px;background:#fff;border-radius:8px;border:1px solid #eee;box-shadow:0 2px 4px #00000008;align-items:flex-start;cursor:pointer;transition:transform .1s,box-shadow .1s}.agenda-item:active{transform:scale(.98);background-color:#fafafa}.agenda-time{flex:0 0 75px;font-size:.9rem;display:flex;flex-direction:column;gap:2px}.agenda-time-dot{display:inline-block;width:8px;height:8px;border-radius:50%;background-color:#b22222;margin-right:6px;box-shadow:0 0 0 3px #ffebeb}.agenda-content{flex:1;padding-left:15px;border-left:2px solid #ffebeb}.agenda-title{font-weight:700;color:#b22222;font-size:1rem;margin-bottom:4px}.agenda-desc{font-size:.85rem;color:#555;line-height:1.4;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}.empty-agenda{padding:40px 15px;text-align:center;color:#888;font-style:italic;background:#fff;border-radius:8px;border:1px dashed #ccc}@media(max-width:768px),(max-height:500px)and (orientation:landscape){.admin-container{width:100%;overflow-x:hidden;box-sizing:border-box}.create-card{width:100%!important;max-width:100%!important;margin:0!important;padding:20px 15px!important;box-sizing:border-box!important;border-radius:8px!important}.responsive-user-table,.responsive-user-table tbody{display:block;width:100%;box-sizing:border-box}.responsive-user-table thead{display:none}.responsive-user-table tr{background:#fff;border:1px solid #ddd;border-radius:8px;margin-bottom:15px;padding:15px;box-shadow:0 2px 4px #0000000d;display:grid;grid-template-columns:1fr auto;gap:10px;align-items:center}.responsive-user-table td{border:none!important;padding:0!important;text-align:left!important}.td-username{grid-column:1 / 2;font-size:1.15rem;color:#b22222!important;font-weight:700;word-wrap:break-word}.td-role{grid-column:2 / 3;text-align:right}.td-dept{grid-column:1 / 3;margin-top:5px}.td-action{grid-column:1 / 3;border-top:1px dashed #eee!important;margin-top:5px;padding-top:12px!important;display:flex;justify-content:flex-end}}
