:root{font-family:system-ui,Avenir,Helvetica,Arial,sans-serif;line-height:1.5;font-weight:400;color-scheme:light dark;color:#ffffffde;background-color:#242424;font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}:root *,:root :before,:root :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: }:root ::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: }:root *,:root :before,:root :after{box-sizing:border-box;border-width:0;border-style:solid;border-color:#e5e7eb}:root :before,:root :after{--tw-content: ""}:root html,:root :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}:root body{margin:0;line-height:inherit}:root hr{height:0;color:inherit;border-top-width:1px}:root abbr:where([title]){-webkit-text-decoration:underline dotted;text-decoration:underline dotted}:root h1,:root h2,:root h3,:root h4,:root h5,:root h6{font-size:inherit;font-weight:inherit}:root a{color:inherit;text-decoration:inherit}:root b,:root strong{font-weight:bolder}:root code,:root kbd,:root samp,:root 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}:root small{font-size:80%}:root sub,:root sup{font-size:75%;line-height:0;position:relative;vertical-align:baseline}:root sub{bottom:-.25em}:root sup{top:-.5em}:root table{text-indent:0;border-color:inherit;border-collapse:collapse}:root button,:root input,:root optgroup,:root select,:root 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}:root button,:root select{text-transform:none}:root button,:root input:where([type=button]),:root input:where([type=reset]),:root input:where([type=submit]){-webkit-appearance:button;background-color:transparent;background-image:none}:root :-moz-focusring{outline:auto}:root :-moz-ui-invalid{box-shadow:none}:root progress{vertical-align:baseline}:root ::-webkit-inner-spin-button,:root ::-webkit-outer-spin-button{height:auto}:root [type=search]{-webkit-appearance:textfield;outline-offset:-2px}:root ::-webkit-search-decoration{-webkit-appearance:none}:root ::-webkit-file-upload-button{-webkit-appearance:button;font:inherit}:root summary{display:list-item}:root blockquote,:root dl,:root dd,:root h1,:root h2,:root h3,:root h4,:root h5,:root h6,:root hr,:root figure,:root p,:root pre{margin:0}:root fieldset{margin:0;padding:0}:root legend{padding:0}:root ol,:root ul,:root menu{list-style:none;margin:0;padding:0}:root dialog{padding:0}:root textarea{resize:vertical}:root input::-moz-placeholder,:root textarea::-moz-placeholder{opacity:1;color:#9ca3af}:root input::placeholder,:root textarea::placeholder{opacity:1;color:#9ca3af}:root button,:root [role=button]{cursor:pointer}:root :disabled{cursor:default}:root img,:root svg,:root video,:root canvas,:root audio,:root iframe,:root embed,:root object{display:block;vertical-align:middle}:root img,:root video{max-width:100%;height:auto}:root [hidden]:where(:not([hidden=until-found])){display:none}:root .visible{visibility:visible}:root .table{display:table}:root .border{border-width:1px}:root .italic{font-style:italic}:root .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)}a{font-weight:500;color:#646cff;text-decoration:inherit}a:hover{color:#535bf2}body{margin:0;display:flex;place-items:center;min-width:320px;min-height:100vh}h1{font-size:3.2em;line-height:1.1}button{border-radius:8px;border:1px solid transparent;padding:.6em 1.2em;font-size:1em;font-weight:500;font-family:inherit;background-color:#1a1a1a;cursor:pointer;transition:border-color .25s}button:hover{border-color:#646cff}button:focus,button:focus-visible{outline:4px auto -webkit-focus-ring-color}@media (prefers-color-scheme: light){:root{color:#213547;background-color:#fff}a:hover{color:#747bff}button{background-color:#f9f9f9}}:root{color-scheme:light!important}html{background:#fff!important;color:#000!important}html,body{margin:0;padding:0;width:100%;height:100%;overflow:hidden;font-family:Segoe UI,Arial,sans-serif;background:linear-gradient(135deg,#4a90e2,#005f99);display:flex;align-items:center;justify-content:center}.login-container{width:100%;height:100%;display:flex;align-items:center;justify-content:center}.login-box{background:#fff;padding:40px 30px;border-radius:12px;box-shadow:0 4px 20px #00000026;width:320px;text-align:center;animation:fadeIn .5s ease-in-out}.login-box h2{margin-bottom:20px;color:#005f99;font-weight:500}.login-box input,.login-box select{width:100%;padding:10px;margin:8px 0;border:1px solid #ccc;border-radius:6px;font-size:14px;outline:none}.login-box input:focus,.login-box select:focus{border-color:#4a90e2}.login-box button{width:100%;background:#2c73d2;color:#fff;border:none;padding:10px;border-radius:6px;margin-top:10px;cursor:pointer;font-size:15px;transition:.3s}.login-box button:hover{background:#1f5ba6}.toggle{margin-top:15px;color:#2c73d2;cursor:pointer;text-decoration:underline;font-size:13px}.toast-container{position:fixed;top:25px;right:25px;display:flex;flex-direction:column;gap:12px;z-index:2000}.toast{padding:14px 22px;border-radius:10px;color:#fff;font-weight:600;font-size:1rem;box-shadow:0 3px 12px #0003;animation:slideIn .3s ease,fadeOut .5s ease 3.5s forwards;min-width:280px;max-width:400px;text-align:left;letter-spacing:.3px}.toast.info{background-color:#3174ad}.toast.success{background-color:#4caf50}.toast.error{background-color:#e53935}.toast.warning{background-color:#ffb347;color:#222}@keyframes slideIn{0%{opacity:0;transform:translate(40px)}to{opacity:1;transform:translate(0)}}@keyframes fadeOut{to{opacity:0;transform:translate(40px)}}@media (max-width: 768px){.toast-container{top:25px;right:50%;transform:translate(50%);align-items:center}.toast{font-size:.9rem;padding:10px 16px;min-width:240px;max-width:280px;border-radius:8px}}.app{display:flex;flex-direction:column;align-items:center;justify-content:flex-start;min-height:100vh;box-sizing:content-box;background-color:#f5f5f5;height:auto!important;padding-bottom:40px}.app h1{margin-bottom:20px;font-size:20px}body{margin:0;padding:0;font-family:Arial,sans-serif;background-color:#f5f5f5}html,body{height:auto!important;min-height:100vh;overflow-y:auto!important;overflow-x:hidden}.day-name{text-align:center;font-weight:700;padding:2px 0;background:#f3f3f3;border-radius:2px;grid-row:1}.calendar{display:grid;grid-template-columns:repeat(7,minmax(180px,1fr));grid-auto-rows:auto;gap:5px;width:auto;margin:5px auto;padding:20px;background:#fff;border-radius:12px;box-shadow:0 4px 12px #0000001a}.day-cell{border:1px solid #ddd;padding:4px;background:#fff;cursor:pointer;position:relative;border-radius:4px;min-height:100px;height:auto!important;overflow:visible!important}.day-cell:hover{background:#f0f8ff}.day-cell.empty{background:transparent;border:none}.date-label{font-weight:700;font-size:14px;margin-bottom:4px;color:#222}.event-pill{white-space:normal!important;line-height:1.3;text-align:left;padding:2px 4px;margin-top:2px;border-radius:4px;color:#fff;font-size:12px;word-break:break-word;text-align:center;overflow:visible!important;text-overflow:unset!important;white-space:nowrap}.install-event{font-weight:700;color:#000;border:1px solid #333}.popup{position:fixed;inset:0;background:#00000080;display:flex;align-items:center;justify-content:center;z-index:1000}.popup-content{background:#fff;padding:20px;border-radius:10px;width:350px;max-width:90%;display:flex;flex-direction:column;gap:10px}.popup-content input,.popup-content button{padding:8px;font-size:14px}.popup-content button{margin-top:6px;border:none;border-radius:4px;cursor:pointer}.popup-content button:first-of-type{background:#28a745;color:#fff}.popup-content button:last-of-type{background:#dc3545;color:#fff}.calendar-header-box{display:flex;justify-content:center;align-items:center;gap:15px;background:#3174ad;padding:22px 30px;border-radius:10px;box-shadow:0 3px 8px #0000001a;margin-bottom:10px;top:auto}.month-label{font-size:18px;font-weight:700;color:#fff;padding:0 10px}.month-select,.year-select{padding:6px 10px;border-radius:6px;border:1px solid #ccc;background:#f9f9f9;font-size:14px;cursor:pointer;transition:border .2s}.month-select:hover,.year-select:hover{border-color:#3174ad}.confirm-overlay{position:fixed;inset:0;background:#00000080;display:flex;align-items:center;justify-content:center;z-index:2000}.confirm-box{background:#fff;padding:20px 30px;border-radius:10px;text-align:center;width:320px;max-width:90%;box-shadow:0 4px 12px #0003}.confirm-warning{font-size:18px;font-weight:700;color:#b71c1c;margin-bottom:10px}.confirm-actions{display:flex;justify-content:space-around;margin-top:15px}.confirm-actions .delete-btn{background:#dc3545;color:#fff}.confirm-actions .cancel-btn{background:#6c757d;color:#fff;border:none;border-radius:4px;padding:8px 12px;cursor:pointer}.event-pill:hover{transform:scale(1.05);box-shadow:0 2px 6px #0003;opacity:.95;z-index:10;transition:all .2s ease-in-out}.install-event:hover{background:gold!important;border-color:#555;transform:scale(1.05);box-shadow:0 2px 6px #0000004d}.form-section{flex:1;display:flex;flex-direction:column;gap:8px}.team-section{flex:1;border-left:1px solid #ddd;padding-left:15px;max-height:400px;overflow-y:auto}.team-section h3{margin:0 0 10px;font-size:16px;color:#333}.team-checkboxes{display:flex;flex-direction:column;gap:6px}.team-checkboxes label{display:flex;align-items:center;gap:6px;font-size:14px;cursor:pointer}.team-checkboxes input[type=checkbox]{transform:scale(1.1);cursor:pointer}.team-label{font-size:11px;color:#f0f0f0;margin-top:2px;text-align:center}.popup-grid{display:flex;justify-content:space-between;gap:20px}.right-side{background:#f9f9f9;border-radius:8px;padding:10px;flex:1;min-width:150px}.right-side h3{font-size:14px;margin-bottom:8px}.right-side label{display:block;font-size:13px;margin:4px 0}.right-side input[type=checkbox]{margin-right:6px}.top-bar{position:fixed;top:0;left:0;width:100vw;height:60px;background-color:#3174ad;color:#fff;display:flex;align-items:center;justify-content:space-between;padding:0 40px;box-sizing:border-box;z-index:1000;box-shadow:0 2px 6px #0000001a}.top-bar .left h2{font-size:20px;color:#fff;margin:0;font-weight:600}.top-bar .right{display:flex;align-items:center;gap:12px}.nav-btn-link,.logout-btn{background:transparent;color:#fff;border:2px solid #fff;border-radius:8px;padding:6px 16px;font-weight:600;cursor:pointer;transition:all .25s ease}.nav-btn-link:hover,.logout-btn:hover,.nav-btn-link.active{background:#fff;color:#3174ad}.logout-btn{border-color:#ffb347;color:#ffb347}.logout-btn:hover{background:#ffb347;color:#fff}.fade-in{animation:fadeIn .8s ease-in-out}@keyframes fadeIn{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}.day-cell.faded{opacity:.6;background-color:#f5f5f5}.day-cell.faded:hover{opacity:1;background-color:#eaeaea}.day-cell.other-month{background-color:#f0f0f0;color:#999;opacity:.9}.day-cell.other-month .date-label{color:#888}.day-cell.other-month:hover{background-color:#e0e0e0}.day-cell.other-month .event-pill{opacity:.6;filter:grayscale(.4)}.day-cell.other-month .install-event{opacity:.7;filter:grayscale(.3)}.popup-content.three-columns{display:grid;grid-template-columns:1fr 1fr 1fr;gap:16px;max-width:980px;width:auto}.popup-content.three-columns .column{display:flex;flex-direction:column;gap:8px}button.pdf-btn{background-color:#3174ad!important;color:#fff!important;border:none!important;border-radius:6px;padding:6px 12px;cursor:pointer;transition:background .2s ease}button.pdf-btn:hover{background-color:#4a6a84!important}.month-label{font-weight:700;font-size:1.1em;text-transform:capitalize}.menu-toggle{display:none;background:none;border:none;font-size:24px;color:#fff;cursor:pointer}.connected-user{font-size:.9em;font-weight:500;color:#fff;margin-left:8px;opacity:.9}.dropdown{position:relative;display:inline-block}.dropdown-content{position:absolute;background-color:#fff;min-width:200px;box-shadow:0 4px 10px #00000026;border-radius:8px;z-index:999;top:45px;right:0;overflow:hidden;animation:fadeIn .2s ease-in-out}.dropdown-content button{display:block;width:100%;text-align:left;background:none;border:none;padding:10px 14px;cursor:pointer;font-size:14px;color:#333;transition:background .2s}.dropdown-content button:hover{background-color:#f0f0f0}@media (max-width: 768px){.event-pill{font-size:1.05rem!important;padding:6px 8px}}@media (max-width: 900px){.popup-content.three-columns{grid-template-columns:1fr}.calendar{gap:3px;transform:scale(.9);transform-origin:top center}.day-cell{min-height:70px;padding:2px;font-size:11px}.date-label{font-size:12px}.event-pill{font-size:10px;padding:1px 3px}.calendar-header-box{margin-top:8px;padding:8px 10px;width:95%;flex-wrap:wrap;justify-content:center}.month-label{font-size:14px;color:#fff}.nav-btn{width:28px;height:28px;font-size:14px;background:#fff;color:#3174ad}.nav-btn:hover{background:#ffb347;color:#fff}.app{padding-top:70px}}@media (max-width: 768px){.top-bar{flex-wrap:wrap;height:auto;padding:10px 15px}.top-bar .left h2{font-size:16px}.top-bar .right{display:none;flex-direction:column;width:100%;background:#3174ad;padding:10px 0;margin-top:8px;border-top:1px solid rgba(255,255,255,.2)}.top-bar.open .right{display:flex}.menu-toggle{display:inline-block;background:transparent;border:2px solid #fff;color:#fff;border-radius:6px;padding:6px 12px;font-size:18px;cursor:pointer}.calendar-header-box{order:2;margin-top:5px;flex-wrap:wrap;background:#fff;box-shadow:0 2px 6px #0000001a}.month-label{color:#3174ad}.calendar{grid-template-columns:repeat(7,250px);grid-auto-rows:auto;overflow-x:auto;overflow-y:visible;-webkit-overflow-scrolling:touch;padding:10px 10px 20px;width:100%;max-width:105vw}.day-cell{min-width:220px;min-height:120px;padding:8px}.date-label{font-size:1.1rem}.day-name{font-size:1rem;padding:5px 0}.app{overflow-x:hidden;overflow-y:auto;padding-top:140px}.calendar-header-box{z-index:1000;background:#3174ad;padding:10px;border-radius:8px;width:95%;margin:0 auto 10px;justify-content:center;align-items:center;gap:12px;color:#fff}.calendar-header-box .month-label{color:#fff;font-weight:700;font-size:1.1em}.calendar-header-box .nav-btn{background:#fff;color:#3174ad;border:none;border-radius:50%;width:36px;height:36px;font-size:16px;font-weight:700}.calendar-header-box .nav-btn:hover{background:#ffb347;color:#fff}.popup-content.three-columns{grid-template-columns:1fr;max-height:90vh;overflow-y:auto;width:90%}.popup-content{width:90%;height:auto;overflow-y:auto;max-height:90vh}.mobile-actions{display:flex;justify-content:space-between;gap:8px;margin-top:16px;padding-top:10px;border-top:1px solid #ddd}.mobile-actions button{flex:1;padding:10px;font-size:14px;border-radius:6px;border:none;cursor:pointer;font-weight:600}.mobile-actions .save-btn{background-color:#28a745;color:#fff}.mobile-actions .delete-btn{background-color:#dc3545;color:#fff}.mobile-actions .cancel-btn{background-color:#6c757d;color:#fff}.mobile-actions button:hover{opacity:.9}.popup-content .column .action-buttons{display:none}.menu-toggle{display:block}.top-bar{justify-content:space-between;padding:0 20px}.top-bar .right{position:absolute;top:20px;right:10px;background:#3174ad;border-radius:10px;box-shadow:0 4px 12px #0003;flex-direction:column;align-items:stretch;padding:20px;display:none;z-index:2000}.top-bar .right.open{display:flex}.top-bar .right button{margin:8px 0;text-align:left;width:100%}}@media (max-width: 600px){.day-cell{min-height:60px}.event-pill{font-size:9px}.calendar-header-box{flex-direction:row;gap:8px}}@media (min-width: 901px){.mobile-actions{display:none}}.meeting-pill{padding:4px;margin-top:4px;border-radius:4px;color:#fff;cursor:pointer}.calendar-header-box{position:relative;z-index:5}.popup{z-index:1000!important}.confirm-overlay{z-index:1100!important}.app{padding-top:80px}.vacation-popup{position:fixed;inset:0;background:#00000080;display:flex;justify-content:center;align-items:center;z-index:2000}.vacation-content{background:#fff;padding:24px;border-radius:12px;width:350px;max-width:90%;width:auto;display:flex;flex-direction:column;gap:10px;animation:slideDown .3s ease}@keyframes slideDown{0%{transform:translateY(-10px);opacity:0}to{transform:translateY(0);opacity:1}}.vacation-content h2{text-align:center;color:#3174ad;margin-bottom:10px}.vacation-content label{font-size:14px;color:#333}.vacation-content input,.vacation-content textarea{padding:8px;border:1px solid #ccc;border-radius:6px;font-size:14px;width:100%;box-sizing:border-box}.vacation-actions{display:flex;justify-content:space-between;margin-top:12px}.btn-send{background:#3174ad;color:#fff;border:none;border-radius:6px;padding:8px 14px;cursor:pointer}.btn-send:hover{background:#255a8a}.btn-cancel{background:#dc3545;color:#fff;border:none;border-radius:6px;padding:8px 14px;cursor:pointer}.btn-cancel:hover{background:#b52b38}.vacation-table{width:100%;border-collapse:collapse;margin-top:10px;font-size:15px}.vacation-table th,.vacation-table td{border:1px solid #ddd;padding:10px 8px;text-align:left}.vacation-table th{background-color:#3174ad;color:#fff}.vacation-actions{display:flex;justify-content:space-between;gap:10px;margin-top:10px}.btn-view{background-color:#3174ad;color:#fff;border:none;border-radius:6px;padding:8px 12px;cursor:pointer}.btn-view:hover{background-color:#255a8a}.btn-close{background:#555;color:#fff;border:none;border-radius:6px;padding:8px 12px;cursor:pointer}.vacation-list{display:flex;flex-direction:column;gap:10px;max-height:400px;overflow-y:auto}.vacation-item{background:#fafafa;border:1px solid #ddd;border-radius:8px;padding:10px}.vacation-item.pending{border-left:4px solid #ffb347}.vacation-item.approved{border-left:4px solid #4caf50}.vacation-item.rejected{border-left:4px solid #f44336}.status-label{font-weight:700;padding:2px 6px;border-radius:4px}.status-approved{color:#fff;background:#4caf50}.status-rejected{color:#fff;background:#f44336}.status-pending{color:#fff;background:#ffb347}.vacation-actions{display:flex;gap:8px;margin-top:8px}.btn-approve{background:#4caf50;color:#fff;border:none;padding:6px 10px;border-radius:6px;cursor:pointer}.btn-reject{background:#f44336;color:#fff;border:none;padding:6px 10px;border-radius:6px;cursor:pointer}.pagination{display:flex;justify-content:center;align-items:center;gap:12px;margin-top:20px;padding-top:10px;border-top:1px solid #ddd}.pagination button{background:#3174ad;color:#fff;border:none;border-radius:6px;padding:6px 12px;font-size:14px;cursor:pointer;transition:background .2s ease}.pagination button:hover{background:#255a8a}.pagination button:disabled{background:#ccc;cursor:not-allowed;color:#666}.pagination span{font-weight:700;color:#333}.status-label{padding:2px 8px;border-radius:6px;font-weight:600;font-size:13px}.status-approved{background:#4caf50;color:#fff}.status-rejected{background:#e53935;color:#fff}.status-pending{background:#ffb347;color:#fff}.vacation-list{display:flex;flex-direction:column;gap:12px;max-height:60vh;overflow-y:auto;padding-right:8px}.vacation-item{border:1px solid #ddd;border-radius:10px;padding:10px 14px;background:#fff;transition:box-shadow .2s ease}.vacation-item:hover{box-shadow:0 2px 6px #0000001a}.vacation-actions{margin-top:10px;display:flex;justify-content:flex-end;gap:8px;flex-wrap:wrap}.vacation-actions button{padding:6px 12px;border:none;border-radius:6px;font-weight:600;cursor:pointer;transition:opacity .2s ease}.vacation-actions button:hover{opacity:.9}.btn-approve{background:#4caf50;color:#fff}.btn-reject{background:#e53935;color:#fff}.btn-cancel{background:#6c757d;color:#fff}.delete-btn{background:#b02a37;color:#fff}.user-popup{position:fixed;inset:0;background:#00000080;display:flex;justify-content:center;align-items:center;z-index:2000}.user-popup-content{background:#fff;border-radius:10px;padding:20px;width:90%;max-width:800px;max-height:80vh;overflow-y:auto;box-shadow:0 4px 10px #0003}.user-table{width:100%;border-collapse:collapse}.user-table th,.user-table td{border:1px solid #ddd;padding:8px;text-align:center}.user-table th{background:#3174ad;color:#fff}.btn-small{border:none;padding:6px 8px;margin:2px;border-radius:5px;cursor:pointer;color:#fff}.btn-small.reset{background:#2196f3}.btn-small.role{background:#ff9800}.btn-small.delete{background:#f44336}.btn-small:hover{opacity:.85}.admin-users-grid{display:flex;flex-wrap:wrap;gap:14px}.user-card{width:160px;padding:10px;border-radius:8px;background:#fff;box-shadow:0 2px 8px #0000000f;display:flex;flex-direction:column;align-items:center}.user-photo{width:40px;height:40px;border-radius:50%;-o-object-fit:cover;object-fit:cover}.password-popup{position:fixed;inset:0;background:#00000080;display:flex;justify-content:center;align-items:center;z-index:2000}.password-popup-content{background:#fff;border-radius:10px;padding:20px;width:90%;max-width:400px;box-shadow:0 4px 10px #0003}.password-popup-content input{width:100%;padding:8px;margin-bottom:10px;border-radius:6px;border:1px solid #ccc}.password-actions{display:flex;justify-content:space-between}.btn-save{background:#3174ad;color:#fff;border:none;padding:8px 12px;border-radius:6px;cursor:pointer}.btn-cancel{background:#dc3545;color:#fff;border:none;padding:8px 12px;border-radius:6px;cursor:pointer}.profile-popup{position:fixed;inset:0;background:#0009;display:flex;justify-content:center;align-items:center;z-index:2000}.profile-content{background:#fff;padding:25px;border-radius:16px;width:95%;max-width:420px;display:flex;flex-direction:column;gap:10px;animation:fadeIn .3s ease}.profile-content h2{text-align:center;color:#333}.photo-section{text-align:center}.profile-photo{width:120px;height:120px;border-radius:50%;-o-object-fit:cover;object-fit:cover;border:3px solid #4caf50;margin-bottom:10px}.profile-actions{display:flex;justify-content:space-between;margin-top:10px}.btn-save{background:#4caf50;color:#fff;border:none;padding:8px 12px;border-radius:8px}.btn-cancel{background:#f44336;color:#fff;border:none;padding:8px 12px;border-radius:8px}.btn-password{background:#2196f3;color:#fff;padding:8px 12px;border:none;border-radius:8px;margin-top:10px;width:100%}
