body{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Fira Sans,Droid Sans,Helvetica Neue,sans-serif;margin:0}code{font-family:source-code-pro,Menlo,Monaco,Consolas,Courier New,monospace}.App{text-align:center}.App-logo{height:40vmin;pointer-events:none}@media (prefers-reduced-motion:no-preference){.App-logo{animation:App-logo-spin 20s linear infinite}}.App-header{align-items:center;background-color:#282c34;color:#fff;display:flex;flex-direction:column;font-size:calc(10px + 2vmin);justify-content:center;min-height:100vh}.App-link{color:#61dafb}@keyframes App-logo-spin{0%{transform:rotate(0deg)}to{transform:rotate(1turn)}}.login-container{background:#181a20;color:#fff;display:flex;font-family:SF Pro Display,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Arial,sans-serif;height:100vh}.login-left{align-items:center;box-sizing:border-box;display:flex;flex:1 1;flex-direction:column;height:100vh;justify-content:center;max-width:50vw;min-width:0;padding:0;width:50vw}.logo-box{color:#5fa8ff;font-size:56px;font-weight:700;margin-bottom:12px}.login-left h1{font-size:32px;font-weight:800;letter-spacing:-.5px;line-height:1.05;margin:4px 0 8px;text-align:center}.login-left .subtitle{color:#b0b8d0;font-size:14px;margin-bottom:14px;text-align:center}.login-form{align-items:center;display:flex;flex-direction:column;max-width:320px;width:100%}.login-form input{background:#181a20;border:2px solid #5fa8ff33;border-radius:8px;color:#fff;font-size:14px;font-weight:600;height:42px;margin-bottom:10px;outline:none;padding:10px 12px;transition:border .2s;width:100%}.login-form input:focus{border:2px solid #5fa8ff}.login-form button[type=submit]{background:linear-gradient(90deg,#5fa8ff,#5472ff);border:none;border-radius:8px;box-shadow:0 8px 24px 0 #2766ff21,0 2px 10px #7b9bd81c;color:#fff;cursor:pointer;font-size:15px;font-weight:700;height:44px;margin-top:4px;padding:12px 0;transition:filter .19s;width:100%}.login-form button[type=submit]:hover{filter:brightness(1.1)}.login-links{color:#90b6ff;font-size:13px;margin:10px 0 0;text-align:center;width:100%}.login-links a{color:#57a3ff;font-weight:600;text-decoration:underline}.register-btn{background:linear-gradient(90deg,#5fa8ff,#5472ff);border:none;border-radius:8px;box-shadow:0 8px 24px 0 #2766ff21,0 2px 10px #7b9bd81c;color:#fff;cursor:pointer;font-size:15px;font-weight:700;margin-top:clamp(40px,10vh,100px);max-width:320px;padding:12px 0;transition:filter .18s;width:100%}.register-btn:hover{filter:brightness(1.07)}.login-right{align-items:stretch;background:#23242b;box-sizing:border-box;display:flex;flex:1 1;justify-content:flex-end;max-width:50vw;overflow:hidden;position:relative;width:50vw}.login-right,.login-right img{border-radius:0;box-shadow:none;height:100vh;min-width:0}.login-right img{display:block;max-width:100vw;object-fit:cover;width:100%}.login-loading-overlay{align-items:center;-webkit-backdrop-filter:blur(3px);backdrop-filter:blur(3px);background:#181a208c;display:flex;flex-direction:column;inset:0;justify-content:center;position:fixed;z-index:9999}.login-spinner{animation:login-spin .9s linear infinite;background:conic-gradient(from 0turn,#5fa8ff,#5472ff,#5fa8ff);border-radius:50%;box-shadow:0 8px 24px #2766ff40;height:72px;-webkit-mask:radial-gradient(farthest-side,#0000 calc(100% - 6px),#000 0);mask:radial-gradient(farthest-side,#0000 calc(100% - 6px),#000 0);position:relative;width:72px}.login-spinner-inner{background:#1d1f27eb;border-radius:50%;inset:6px;position:absolute}.login-loading-text{color:#d9e6ff;font-size:14px;letter-spacing:.3px;margin-top:12px}@keyframes login-spin{to{transform:rotate(1turn)}}.tasks-container{background-color:#000;background-color:var(--color-black);display:flex;min-height:100vh}.nav-text{font-size:14px;font-weight:500}.main-content{background-color:var(--color-black)}.header{align-items:center;display:flex;justify-content:space-between;margin-bottom:32px}.header-left{gap:16px}.header-left h1{font-size:28px;font-weight:700}.period-filter{background-color:#22252d;background-color:var(--color-dark-gray);border:1px solid #2a2b32;border:1px solid var(--color-border);border-radius:6px;color:#fff;color:var(--color-white);cursor:pointer;font-size:14px;padding:8px 16px;transition:all .2s ease}.period-filter:hover{background-color:#18181a;background-color:var(--color-darker-gray)}.header-right{gap:16px}.new-task-btn{align-items:center;background:linear-gradient(135deg,#5fa8ff,#5472ff);background:linear-gradient(135deg,var(--color-blue) 0,#5472ff 100%);border:none;border-radius:8px;box-shadow:0 4px 12px #5fa8ff4d;color:#fff;color:var(--color-white);cursor:pointer;display:flex;font-size:14px;font-weight:600;gap:8px;padding:12px 24px;transition:all .2s ease}.new-task-btn:hover{box-shadow:0 6px 16px #5fa8ff66;transform:translateY(-2px)}.new-task-btn span{font-size:18px;font-weight:700}.quick-actions{display:flex;gap:12px}.action-item{align-items:center;background-color:#22252d;background-color:var(--color-dark-gray);border:1px solid #2a2b32;border:1px solid var(--color-border);border-radius:6px;color:#b0b8d0;color:var(--color-light-gray);cursor:pointer;display:flex;font-size:12px;gap:8px;padding:8px 12px;transition:all .2s ease}.action-item:hover{background-color:#18181a;background-color:var(--color-darker-gray);color:#fff;color:var(--color-white)}.action-icon{font-size:14px}.action-icon.warning{color:#ffa502;color:var(--color-yellow)}.action-text{font-weight:500}.key-indicators{grid-gap:20px;display:grid;gap:20px;grid-template-columns:repeat(4,1fr);margin-bottom:32px}.indicator-card{background-color:#22252d;background-color:var(--color-dark-gray);border:1px solid #2a2b32;border:1px solid var(--color-border);border-radius:12px;display:flex;flex-direction:column;gap:12px;padding:24px}.indicator-card h3{color:#b0b8d0;color:var(--color-light-gray);font-size:14px;font-weight:600;letter-spacing:.5px;text-transform:uppercase}.indicator-value{color:#fff;color:var(--color-white);font-size:32px;font-weight:700}.progress-container{align-items:center;display:flex;gap:12px}.progress-bar{background-color:#18181a;background-color:var(--color-darker-gray);border-radius:4px;flex:1 1;height:8px;overflow:hidden}.progress-fill{border-radius:4px;height:100%;transition:width .3s ease}.progress-fill.blue{background:linear-gradient(90deg,#5fa8ff,#5472ff);background:linear-gradient(90deg,var(--color-blue) 0,#5472ff 100%)}.progress-fill.red{background:linear-gradient(90deg,#ff4757,#ff6b35);background:linear-gradient(90deg,var(--color-red) 0,var(--color-orange) 100%)}.progress-text{color:#5fa8ff;color:var(--color-blue);font-size:16px;font-weight:600;min-width:50px}.progress-text.red{color:#ff4757;color:var(--color-red)}.content-grid{grid-gap:24px;display:grid;gap:24px;grid-template-columns:1fr 400px;height:auto;min-height:0}.tasks-list{background-color:#22252d;background-color:var(--color-dark-gray);border:1px solid #2a2b32;border:1px solid var(--color-border);border-radius:12px;display:flex;flex-direction:column;overflow:visible}.tasks-list h2{background-color:#18181a;background-color:var(--color-darker-gray);border-bottom:1px solid #2a2b32;border-bottom:1px solid var(--color-border);color:#fff;color:var(--color-white);font-size:18px;font-weight:600;padding:20px 24px}.tasks-table{--col-title:1fr;--col-op:200px;--col-date:120px;--col-status:140px;display:flex;flex:1 1;flex-direction:column;overflow:hidden}.tasks-table .table-header,.tasks-table .table-row{grid-column-gap:12px;align-items:center;column-gap:12px;display:grid;grid-template-columns:var(--col-title) var(--col-op) var(--col-date) var(--col-status);min-width:0;width:100%}.table-header{background-color:#18181a;background-color:var(--color-darker-gray);border-bottom:1px solid #2a2b32;border-bottom:1px solid var(--color-border);padding:16px 24px}.header-cell{color:#b0b8d0;color:var(--color-light-gray);font-size:12px;font-weight:600;letter-spacing:.5px;text-transform:uppercase}.table-body{overflow:visible}.table-row{border-bottom:1px solid #2a2b32;border-bottom:1px solid var(--color-border);padding:16px 24px;transition:background-color .2s ease}.table-row:hover{background-color:#18181a;background-color:var(--color-darker-gray)}.header-cell,.table-cell{padding:14px 18px;text-align:left}.cell-title{-webkit-hyphens:auto;hyphens:auto;line-height:1.25;white-space:normal;word-break:break-word}.cell-date,.cell-operator,.cell-title{display:block}.cell-status{justify-content:flex-start}.table-row+.table-row{border-top:1px solid #ffffff0f}.table-cell{color:#fff;color:var(--color-white);font-size:14px}.status{align-items:center;display:flex;font-weight:500;gap:8px}.status-icon{font-size:16px}.status-completed{color:#2ed573;color:var(--color-green)}.status-late{color:#ff6b35;color:var(--color-orange)}.status-pending{color:#ffa502;color:var(--color-yellow)}.status-not-done{color:#ff4757;color:var(--color-red)}.status-failed{background:#0000;border-color:#0000;color:#9aa0a6}.status-failed .status-icon{color:inherit;filter:none}.status-ongoing{color:#5fa8ff;color:var(--color-blue)}.status-incident{color:#f59e0b;font-weight:600}.status-default{color:#b0b8d0;color:var(--color-light-gray)}.cell-status{align-items:center;display:flex;gap:8px}.cell-status .status-icon{color:currentColor;line-height:1}.cell-status .status-label{line-height:1}.status-dot{border-radius:9999px;display:inline-block;flex:none;height:8px;width:8px}.dot-orange{background:#ffb020}.dot-green{background:#22c55e}.dot-red{background:#ff6b6b}.dot-grey{background:#9aa0a6}.dot-blue{background:#3ba5ff}.tasks-table.compact .table-row{min-height:44px}.separator-16{height:16px}.right-panel{display:flex;flex-direction:column;gap:24px}.stats-chart{background-color:#22252d;background-color:var(--color-dark-gray);border:1px solid #2a2b32;border:1px solid var(--color-border);border-radius:12px;padding:24px}.chart-head{align-items:center;display:flex;justify-content:space-between;margin-bottom:8px}.chart-period{background:#111827;border:1px solid #374151;border-radius:8px;color:#e5e7eb;font-size:14px;padding:6px 10px}.chart-container.taller{min-height:260px;position:relative}.chart-bars{align-items:flex-end;gap:14px}.stats-chart h3{color:#fff;color:var(--color-white);font-size:16px;font-weight:600;margin-bottom:20px}.chart-container{align-items:end;background-color:#18181a;background-color:var(--color-darker-gray);gap:20px;height:200px;margin-bottom:20px}.chart-y-axis{color:#b0b8d0;color:var(--color-light-gray);flex-direction:column;font-size:12px;min-width:20px}.chart-bars,.chart-y-axis{display:flex;height:100%;justify-content:space-between}.chart-bars{align-items:end;flex:1 1;gap:8px}.chart-bar-group{align-items:center;display:flex;flex:1 1;flex-direction:column;gap:8px;position:relative}.chart-bar{align-items:stretch;background:#0000;border-radius:8px;cursor:pointer;display:flex;flex-direction:column;height:100%;justify-content:flex-end;overflow:hidden;transition:all .2s ease;width:22px}.bar-segment{width:100%}.bar-segment.completed{background:#60a5fa;background:var(--blue-500,#60a5fa)}.bar-segment.late{background:#f59e0b;background:var(--orange-500,#f59e0b)}.bar-segment.not-done{background:#ef4444;background:var(--red-500,#ef4444)}.chart-bar .bar-segment:first-child{border-top-left-radius:8px;border-top-right-radius:8px}.chart-tooltip.floating{background:#0b1220;border:1px solid #334155;border-radius:8px;box-shadow:0 10px 25px #00000059;color:#e5e7eb;padding:8px 10px;pointer-events:none;position:absolute;transform:translate(-50%,-100%);white-space:nowrap;z-index:5}.chart-tooltip.floating:after{border:6px solid #0000;border-top-color:#0b1220;bottom:-6px;content:"";left:50%;position:absolute;transform:translateX(-50%)}.tt-row{align-items:center;display:flex;font-size:12px;gap:8px;line-height:1.2}.dot{border-radius:50%;display:inline-block;height:10px;width:10px}.dot.blue{background:#60a5fa}.dot.orange{background:#f59e0b}.dot.red{background:#ef4444}.chart-bar:hover{transform:scale(1.05)}.bar-label{color:#b0b8d0;color:var(--color-light-gray);font-size:12px;text-align:center;white-space:nowrap}.chart-tooltip{background-color:#18181a;background-color:var(--color-darker-gray);border:1px solid #2a2b32;border:1px solid var(--color-border);border-radius:6px;bottom:100%;box-shadow:0 4px 12px #0000004d;color:#fff;color:var(--color-white);font-size:12px;opacity:0;padding:8px 12px;transition:all .2s ease;visibility:hidden;white-space:nowrap;z-index:10}.chart-tooltip,.chart-tooltip:after{left:50%;position:absolute;transform:translateX(-50%)}.chart-tooltip:after{border:4px solid #0000;border-top:4px solid var(--color-darker-gray);content:"";top:100%}.chart-bar-group:hover .chart-tooltip{opacity:1;visibility:visible}.chart-legend{display:flex;flex-direction:row;gap:8px;justify-content:space-between;margin-top:16px;padding:0 20px;width:100%}.legend-item{color:#b0b8d0;color:var(--color-light-gray);flex:1 1;font-size:10px;gap:6px;justify-content:center}.legend-item span:last-child{-webkit-line-clamp:2;-webkit-box-orient:vertical;display:-webkit-box;line-height:1.2;max-height:2.4em;overflow:hidden}.legend-color{border-radius:2px;height:12px;width:12px}.legend-color.red{background-color:#ff4757;background-color:var(--color-red)}.legend-color.orange{background-color:#ff6b35;background-color:var(--color-orange)}.legend-color.blue{background-color:#5fa8ff;background-color:var(--color-blue)}.operators-section{background-color:#22252d;background-color:var(--color-dark-gray);border:1px solid #2a2b32;border:1px solid var(--color-border);border-radius:12px;flex:1 1;padding:24px}.section-header{align-items:center;display:flex;justify-content:space-between;margin-bottom:20px}.section-header h3{color:#fff;color:var(--color-white);font-size:16px;font-weight:600}.period-selector{background-color:#18181a;background-color:var(--color-darker-gray);border:1px solid #2a2b32;border:1px solid var(--color-border);border-radius:6px;color:#fff;color:var(--color-white);cursor:pointer;font-size:12px;padding:6px 12px;transition:all .2s ease}.period-selector:hover{background-color:#22252d;background-color:var(--color-dark-gray)}.period-selector:focus{border-color:#5fa8ff;border-color:var(--color-blue);outline:none}.operators-list{display:flex;flex-direction:column;gap:12px;max-height:300px;overflow-y:auto}.operator-card{align-items:center;background-color:#18181a;background-color:var(--color-darker-gray);border:1px solid #2a2b32;border:1px solid var(--color-border);border-radius:8px;display:flex;gap:12px;padding:16px;position:relative;transition:all .2s ease}.operator-card:hover{background-color:#22252d;background-color:var(--color-dark-gray);box-shadow:0 4px 12px #0000004d;transform:translateY(-2px)}.operator-rank{background-color:#5fa8ff;background-color:var(--color-blue);border-radius:4px;color:#fff;color:var(--color-white);font-size:10px;font-weight:700;min-width:20px;padding:2px 6px;position:absolute;right:8px;text-align:center;top:8px}.operator-card:first-child .operator-rank{background-color:gold;color:#000;color:var(--color-black)}.operator-card:nth-child(2) .operator-rank{background-color:silver;color:#000;color:var(--color-black)}.operator-card:nth-child(3) .operator-rank{background-color:#cd7f32;color:#fff;color:var(--color-white)}.operator-avatar{background-color:#5fa8ff;background-color:var(--color-blue);color:var(--color-white);font-size:18px;height:40px;width:40px}.operator-info{flex:1 1;flex-direction:column;gap:4px}.operator-name{color:var(--color-white)}.operator-stats{align-items:center;display:flex;gap:8px}.tasks-count{color:#5fa8ff;color:var(--color-blue);font-size:16px;font-weight:700}.tasks-label{color:#b0b8d0;color:var(--color-light-gray);font-size:12px}.performance-indicator{font-size:16px;margin-left:auto}.no-operators{color:#b0b8d0;color:var(--color-light-gray);padding:40px 20px;text-align:center}.no-operators p{font-size:14px}@media (max-width:1200px){.content-grid{grid-template-columns:1fr}.right-panel{order:-1}}@media (max-width:768px){.sidebar{width:200px}.key-indicators{grid-template-columns:repeat(2,1fr)}.header{align-items:flex-start;flex-direction:column;gap:16px}.header-right{justify-content:space-between;width:100%}}.error-container,.loading-container{align-items:center;color:#b0b8d0;color:var(--color-light-gray);display:flex;flex-direction:column;gap:16px;height:400px;justify-content:center}.error-container h2{color:#ff4757;color:var(--color-red);font-size:20px}.error-container button{background-color:#5fa8ff;background-color:var(--color-blue);border:none;border-radius:6px;color:#fff;color:var(--color-white);cursor:pointer;font-size:14px;padding:8px 16px;transition:all .2s ease}.error-container button:hover{background-color:#4a8fdf}.chart-tooltip.floating{bottom:auto!important;left:auto!important;opacity:1!important;visibility:visible!important}.sterilization-page{background:#000;background:var(--color-black);color:#fff;color:var(--color-white);display:flex;min-height:100vh}.sterilization-page .sidebar{background:#18181a;background:var(--color-darker-gray);border-right:1px solid #2a2b32;border-right:1px solid var(--color-border);display:flex;flex-direction:column;padding:24px 0;width:250px}.sterilization-page .logo{color:#5fa8ff;color:var(--color-blue);font-size:24px;font-weight:800;margin-bottom:40px;text-align:center}.sterilization-page .nav-menu{display:flex;flex-direction:column;gap:8px;padding:0 16px}.sterilization-page .nav-item{align-items:center;border-radius:8px;color:#b0b8d0;color:var(--color-light-gray);cursor:pointer;display:flex;gap:12px;padding:12px 16px;transition:.2s}.sterilization-page .nav-item:hover{background:#22252d;background:var(--color-dark-gray);color:#fff}.sterilization-page .nav-item.active{background:#5fa8ff;background:var(--color-blue);color:#fff}.sterilization-page .nav-icon{font-size:18px}.sterilization-page .sterilization-content{flex:1 1;overflow:auto;padding:24px}.sterilization-page .header{align-items:center;background:#1f2127;border:1px solid #2a2b32;border:1px solid var(--color-border);border-radius:16px;display:flex;justify-content:space-between;margin:0 0 20px;padding:20px 24px}.sterilization-page .widgets-grid{grid-gap:20px;align-items:stretch;display:grid;gap:20px;grid-template-columns:1.5fr 1fr;margin-bottom:20px}.sterilization-page .operators-categories-stack{display:flex;flex-direction:column;gap:20px}.sterilization-page .widgets-grid .chart-widget{margin:0}.sterilization-page .header-left{align-items:center;display:flex;gap:16px}.sterilization-page .header-left h1{font-size:26px;font-weight:800;letter-spacing:normal}.sterilization-page .period-filter{background:#22252d;background:var(--color-dark-gray);border:1px solid #2a2b32;border:1px solid var(--color-border);border-radius:8px;color:#fff;padding:8px 14px}.sterilization-page .header-right{align-items:center;display:flex;gap:12px}.sterilization-page .new-sterilization-btn{align-items:center;background:linear-gradient(135deg,#5fa8ff,#318cff);background:linear-gradient(135deg,var(--color-blue),var(--color-blue-2));border:0;border-radius:10px;box-shadow:0 6px 18px #5fa8ff40;color:#fff;cursor:pointer;display:inline-flex;font-weight:700;gap:8px;padding:10px 16px}.sterilization-page .quick-actions{display:inline-flex;gap:10px}.sterilization-page .action-item{align-items:center;background:#22252d;background:var(--color-dark-gray);border:1px solid #2a2b32;border:1px solid var(--color-border);border-radius:8px;color:#b0b8d0;color:var(--color-light-gray);display:flex;font-size:12px;gap:6px;padding:8px 12px}.sterilization-page .action-icon.warning{color:#ffa502;color:var(--color-yellow)}.sterilization-page .chart-widget{background:#22252d;background:var(--color-dark-gray);border:1px solid #2a2b32;border:1px solid var(--color-border);border-radius:14px;height:-webkit-fit-content;height:fit-content;margin:18px 8px;padding:18px}.sterilization-page .widgets-grid>.chart-widget:first-child{align-self:stretch;display:flex;flex-direction:column;height:auto;min-height:520px}.sterilization-page .chart-header{align-items:center;display:flex;justify-content:space-between;margin-bottom:14px}.sterilization-page .chart-header h3{font-size:14px;font-weight:700}.sterilization-page .segment-control{background:#121318;border:1px solid #2a2b32;border:1px solid var(--color-border);border-radius:12px;display:flex;gap:10px;padding:6px}.sterilization-page .segment-btn{background:#0000;border:0;border-radius:10px;color:#cbd3ea;cursor:pointer;font-size:13px;font-weight:600;padding:8px 16px}.sterilization-page .segment-btn.active{background:#272a33;box-shadow:inset 0 0 0 1px #ffffff14;color:#fff}.sterilization-page .chart-content{grid-gap:20px;align-items:end;display:grid;gap:20px;grid-template-columns:160px 1fr}.sterilization-page .chart-widget .chart-content{flex:1 1;min-height:0}.sterilization-page .chart-side{display:flex;flex-direction:column;gap:12px;justify-content:center;margin-top:140px!important;min-width:160px;padding-top:180px}.sterilization-page .chart-area{align-items:flex-end;align-self:end;display:flex;min-width:0}.sterilization-page .mini-kpi{background:#2b2e37;border:1px solid #2a2b32;border:1px solid var(--color-border);border-radius:10px;padding:12px}.sterilization-page .mini-kpi-title{color:#d7def3;font-size:10px;line-height:1.25;margin-bottom:6px}.sterilization-page .mini-kpi-value{font-size:28px;font-weight:800;margin-bottom:8px}.sterilization-page .mini-kpi-footer{align-items:center;display:flex;font-size:10px;font-weight:700;gap:5px}.sterilization-page .mini-kpi-footer .dot{border-radius:999px;display:inline-block;height:8px;width:8px}.sterilization-page .mini-kpi-footer.positive{color:#7de392}.sterilization-page .mini-kpi-footer.positive .dot{background:#7de392}.sterilization-page .mini-kpi-footer.negative{color:#ff6b6b}.sterilization-page .mini-kpi-footer.negative .dot{background:#ff6b6b}.sterilization-page .chart-container{align-items:flex-end;background:#18181a;background:var(--color-darker-gray);border:1px solid #2a2b32;border:1px solid var(--color-border);border-radius:12px;display:flex;gap:14px;height:340px;margin-top:0!important;overflow:visible;padding:16px 16px 48px;position:relative}.sterilization-page .chart-container:before{background:linear-gradient(0deg,#ffffff1f 0 1px,#0000 1px calc(25% - 1px)),linear-gradient(0deg,#ffffff1f 0 1px,#0000 1px calc(50% - 1px)),linear-gradient(0deg,#ffffff1f 0 1px,#0000 1px calc(75% - 1px)),linear-gradient(0deg,#ffffff1f 0 1px,#0000 1px 100%);background-repeat:no-repeat;background-size:100% 25%,100% 50%,100% 75%,100% 100%;bottom:48px;content:"";left:18px;pointer-events:none;position:absolute;right:18px;top:18px}.sterilization-page .chart-y-axis{color:#9aa6c4;display:flex;flex-direction:column;font-size:11px;height:100%;justify-content:space-between;min-width:24px;z-index:1}.sterilization-page .chart-bars{align-items:flex-end;display:flex;flex:1 1;gap:12px;height:100%;position:relative;z-index:1}.sterilization-page .chart-bar-group{align-items:center;display:flex;flex:1 1;flex-direction:column;height:100%;position:relative}.sterilization-page .chart-bar{background:#0000;border:none;border-radius:8px;cursor:pointer;display:flex;flex-direction:column;height:100%;justify-content:flex-end;overflow:hidden;transition:transform .2s ease;width:24px}.sterilization-page .chart-bar:hover{transform:scale(1.04)}.sterilization-page .bar-segment{border-radius:6px 6px 0 0;margin-top:auto;min-height:2px;width:100%;will-change:height}.sterilization-page .bar-label{bottom:-28px;color:#9aa6c4;font-size:11px}.sterilization-page .bar-label,.sterilization-page .chart-tooltip{left:50%;position:absolute;transform:translateX(-50%);white-space:nowrap}.sterilization-page .chart-tooltip{background:#18181a;background:var(--color-darker-gray);border:1px solid #2a2b32;border:1px solid var(--color-border);border-radius:8px;bottom:100%;color:#fff;font-size:12px;opacity:0;padding:6px 8px;transition:.2s;visibility:hidden}.sterilization-page .chart-bar-group:hover .chart-tooltip{opacity:1;visibility:visible}.sterilization-page .period-selector{background:#18181a;background:var(--color-darker-gray);border:1px solid #2a2b32;border:1px solid var(--color-border);border-radius:8px;color:#fff;font-size:12px;padding:6px 10px}.sterilization-page .donut-chart-container{align-items:center;display:flex;gap:16px;justify-content:center;padding:20px 0}.sterilization-page .donut-chart{background:conic-gradient(#5fa8ff 0 46%,#2e7dd9 46% 69%,#38bdf8 69% 87%,#89c2ff 87% 100%);border-radius:50%;flex-shrink:0;height:150px;position:relative;width:150px}.sterilization-page .donut-chart:after{background:#22252d;background:var(--color-dark-gray);border-radius:50%;content:"";inset:20px;position:absolute}.sterilization-page .donut-legend{display:flex;flex-direction:column;gap:10px}.sterilization-page .legend-item{align-items:center;color:#cbd3ea;display:flex;font-size:12px;gap:10px}.sterilization-page .legend-color{background:#5fa8ff;border-radius:2px;height:12px;width:12px}.sterilization-page .operators-pie-container{align-items:center;display:flex;gap:16px;justify-content:center;padding:20px 0}.sterilization-page .operators-legend{display:flex;flex-direction:column;gap:10px}.op-pie-wrap{flex-shrink:0;height:200px;position:relative;width:180px}.operators-pie-svg{display:block;height:180px;width:180px}.op-slice{cursor:pointer;transition:transform .18s ease,filter .18s ease}.op-slice:hover{filter:brightness(1.06) drop-shadow(0 4px 14px rgba(95,168,255,.25))}.op-foot{color:#cbd3ea;font-size:12px;margin-top:6px;opacity:.85;text-align:center}.op-tooltip{background:#18181a;background:var(--color-darker-gray);border:1px solid #2a2b32;border:1px solid var(--color-border);border-radius:8px;box-shadow:0 10px 28px #00000059;color:#fff;font-size:12px;line-height:1.25;padding:8px 10px;pointer-events:none;position:absolute;transform:translate(-50%,calc(-100% - 10px));white-space:nowrap;z-index:3}.op-tooltip:after{border:6px solid #0000;border-top:6px solid var(--color-border);content:"";left:50%;position:absolute;top:100%;transform:translateX(-50%)}.op-tooltip-title{color:#cbd3ea;font-weight:700;margin-bottom:2px}.op-tooltip-meta{color:#e6ecff;opacity:.9}.donut-card,.operators-pie-container{align-items:center;display:flex;gap:16px;justify-content:center;padding:20px 0}.donut-wrap{flex-shrink:0;height:220px;position:relative;width:220px}.donut-svg{display:block;height:200px;width:220px}.donut-slice{cursor:pointer;transition:transform .18s ease,filter .18s ease}.donut-slice:hover{filter:brightness(1.06) drop-shadow(0 4px 14px rgba(95,168,255,.25))}.donut-foot{color:#cbd3ea;font-size:12px;margin-top:2px;opacity:.85;text-align:center}.donut-legend,.operators-legend{align-items:flex-start;display:flex;flex-direction:column;gap:12px}.legend-item{gap:10px;justify-content:flex-start;text-align:left;width:100%}.legend-item.no-data{color:#9aa6c4;justify-content:flex-start}.legend-color{border-radius:4px;flex:0 0 16px;height:16px;opacity:.95;width:16px}.legend-text-one{overflow:hidden;text-overflow:ellipsis}.donut-tooltip,.legend-text-one{max-width:320px;white-space:nowrap}.donut-tooltip{background:#18181a;background:var(--color-darker-gray);border:1px solid #2a2b32;border:1px solid var(--color-border);border-radius:10px;box-shadow:0 10px 28px #00000059;color:#fff;font-size:12px;line-height:1.25;padding:10px 12px;pointer-events:none;position:absolute;transform:translate(-50%,calc(-100% - 12px));z-index:3}.donut-tooltip:after{border:6px solid #0000;border-top:6px solid var(--color-border);content:"";left:50%;position:absolute;top:100%;transform:translateX(-50%)}.donut-tooltip-title{color:#cbd3ea;font-weight:700;margin-bottom:4px}.chart-tooltip .tt-title{color:#5fa8ff;font-weight:600}.donut-tooltip-meta{color:#e6ecff;margin-bottom:6px;opacity:.9}.donut-tooltip-list{display:flex;flex-direction:column;gap:4px;max-height:180px;overflow:auto}.donut-tooltip-row{display:flex;gap:12px;justify-content:space-between}.donut-tooltip-row .name{color:#cbd3ea}.donut-tooltip-row .qty{color:#e6ecff;opacity:.9}.donut-tooltip-more{color:#9aa6c4;font-style:italic;margin-top:4px}.sterilization-page .instruments-section{background:#22252d;background:var(--color-dark-gray);border:1px solid #2a2b32;border:1px solid var(--color-border);border-radius:14px;flex:0 0 auto;height:auto;margin:0;max-height:none;overflow:visible;padding:18px}.sterilization-page .instruments-header h3{font-size:14px;font-weight:700;margin-bottom:16px}.sterilization-page .instruments-table{background:#18181a;background:var(--color-darker-gray);border:1px solid #2a2b32;border:1px solid var(--color-border);border-radius:12px;height:auto;max-height:none;overflow:hidden;overflow:visible}.sterilization-page .instruments-table .table-header{grid-gap:16px;background:#18181a;background:var(--color-darker-gray);border-bottom:1px solid #2a2b32;border-bottom:1px solid var(--color-border);display:grid;gap:16px;grid-template-columns:2fr 1fr 100px 140px;padding:14px 16px;position:static}.sterilization-page .header-cell{color:#9aa6c4;font-size:12px;font-weight:700;text-transform:uppercase}.sterilization-page .table-body{height:auto;max-height:none;overflow:visible}.sterilization-page .table-row{grid-gap:16px;background:#22252d;background:var(--color-dark-gray);border-bottom:1px solid #2a2b32;border-bottom:1px solid var(--color-border);display:grid;gap:16px;grid-template-columns:2fr 1fr 100px 140px;padding:16px}.sterilization-page .table-row:last-child{border-bottom:none}.sterilization-page .table-cell{align-items:center;color:#e6ecff;display:flex;font-size:14px}.sterilization-page .category-select{background:#18181a;background:var(--color-darker-gray);border:1px solid #2a2b32;border:1px solid var(--color-border);border-radius:8px;color:#fff;font-size:12px;padding:8px 10px;width:120px}.sterilization-page .status-pill{align-items:center;border:1px solid #0000;display:inline-flex;font-size:12px;font-weight:700;justify-content:center;min-width:100px;padding:8px 12px}.sterilization-page .status-pill.red{background:#2b0d12;border-color:#441821;color:#ff8b96}.sterilization-page .status-pill.orange{background:#2c1a09;border-color:#4b2a12;color:#ffb378}.sterilization-page .status-pill.blue{background:#0c1b2b;border-color:#19344f;color:#8bc4ff}.sterilization-page .status-pill.gray{background:#20222a;border-color:#2c2f38;color:#cbd3ea}.sterilization-page .instruments-table .table-header,.sterilization-page .instruments-table .table-row{grid-column-gap:20px!important;column-gap:20px!important;grid-template-columns:minmax(220px,1fr) 200px 1fr 120px 220px!important}.sterilization-page .instruments-table .table-header .header-cell:nth-child(4),.sterilization-page .instruments-table .table-row .table-cell:nth-child(4){grid-column:5}@media (max-width:1280px){.sterilization-page .instruments-table .table-header,.sterilization-page .instruments-table .table-row{grid-template-columns:minmax(220px,1fr) 170px 1fr 110px 200px!important}}.sterilization-page .instruments-table .table-header,.sterilization-page .instruments-table .table-row{grid-column-gap:12px!important;align-items:center;column-gap:12px!important;display:grid!important;grid-template-columns:minmax(360px,1fr) 180px 1fr 110px 1fr 210px!important}.sterilization-page .instruments-table .table-header .header-cell:first-child,.sterilization-page .instruments-table .table-row .table-cell:first-child{grid-column:1}.sterilization-page .instruments-table .table-header .header-cell:nth-child(3),.sterilization-page .instruments-table .table-row .table-cell:nth-child(3){justify-self:end}.sterilization-page .instruments-table .table-header .header-cell:nth-child(4),.sterilization-page .instruments-table .table-row .table-cell:nth-child(4){grid-column:6}.sterilization-page .category-select{max-width:150px}@media (max-width:1280px){.sterilization-page .instruments-table .table-header,.sterilization-page .instruments-table .table-row{grid-template-columns:minmax(320px,1fr) 170px 1fr 100px 1fr 190px!important}}.sterilization-page .stock-input{background:#18181a;background:var(--color-darker-gray);border:1px solid #2a2b32;border:1px solid var(--color-border);border-radius:8px;color:#fff;color:var(--color-white);font-size:13px;outline:none;padding:8px 10px;width:110px}.sterilization-page .stock-input:focus{border-color:#318cff;border-color:var(--color-blue-2);box-shadow:0 0 0 2px #318cff26}.sterilization-page .instruments-table .table-header .header-cell:nth-child(2),.sterilization-page .instruments-table .table-row .table-cell:nth-child(2){grid-column:2;justify-self:center!important;text-align:center!important}.sterilization-page .instruments-table .table-header .header-cell:nth-child(3),.sterilization-page .instruments-table .table-row .table-cell:nth-child(3){grid-column:4;justify-self:center!important;text-align:center!important}.sterilization-page .category-select{margin:0 auto}.sterilization-page .stock-input{margin:0 auto;text-align:right}.sterilization-page .instruments-table .table-header{font-weight:600;padding:14px 20px}.sterilization-page .instruments-table .table-row{border-bottom:1px solid #ffffff0f;padding:18px 20px}.sterilization-page .instruments-table .table-header .header-cell:first-child,.sterilization-page .instruments-table .table-row .table-cell:first-child{justify-self:start;text-align:left}.sterilization-page .instruments-table .table-header .header-cell:nth-child(2),.sterilization-page .instruments-table .table-row .table-cell:nth-child(2){justify-self:start}.sterilization-page .instruments-table .table-header .header-cell:nth-child(3),.sterilization-page .instruments-table .table-row .table-cell:nth-child(3){text-align:right}.sterilization-page .instruments-table .table-header .header-cell:nth-child(4),.sterilization-page .instruments-table .table-row .table-cell:nth-child(4){justify-self:end;text-align:right}.sterilization-page .category-select{max-width:200px;width:100%}.sterilization-page .status-pill{background:#ffffff0f;border-radius:999px;display:inline-block;padding:8px 14px}@media (max-width:1280px){.sterilization-page .instruments-table .table-header,.sterilization-page .instruments-table .table-row{column-gap:20px;grid-template-columns:minmax(200px,1fr) 190px 100px 180px}}@media (max-width:900px){.sterilization-page .instruments-table .table-header,.sterilization-page .instruments-table .table-row{column-gap:16px;grid-template-columns:minmax(170px,1fr) 200px 90px 160px}}@media (max-width:1200px){.sterilization-page .widgets-grid{gap:16px;grid-template-columns:1fr}.sterilization-page .operators-categories-stack{flex-direction:row;gap:16px}.sterilization-page .chart-content{grid-template-columns:1fr}.sterilization-page .chart-side{flex-direction:row;gap:16px;min-width:0}.sterilization-page .mini-kpi{flex:1 1;min-width:180px}}@media (max-width:900px){.sterilization-page .widgets-grid{gap:16px;grid-template-columns:1fr}.sterilization-page .operators-categories-stack{flex-direction:column;gap:16px}}@media (max-width:800px){.sterilization-page .sidebar{width:210px}.sterilization-page .chart-side{flex-direction:column;gap:12px}.sterilization-page .mini-kpi{flex:none;min-width:auto}}@media (max-width:1200px){.sterilization-page .chart-side{margin-top:90px!important}}.sterilization-page .chart-container{height:400px!important}.sterilization-page .widgets-grid>.chart-widget:first-child{align-self:stretch!important;display:grid!important;grid-template-rows:auto 1fr!important}.sterilization-page .chart-widget .chart-content{grid-gap:20px!important;align-items:end!important;display:grid!important;gap:20px!important;grid-template-columns:160px minmax(0,1fr)!important;min-height:0!important}.sterilization-page .chart-side{align-self:stretch!important;display:flex!important;flex-direction:column!important;gap:12px!important;justify-content:flex-end!important;margin-top:0!important;padding-top:0!important}.sterilization-page .chart-area{align-self:stretch!important;display:flex!important;min-width:0!important}.sterilization-page .chart-container{--x-label-space:48px;flex:1 1 auto!important;height:100%!important;margin:0!important;max-width:100%!important;min-height:0!important;padding-bottom:var(--x-label-space)!important;width:100%!important}.sterilization-page .chart-container:before{bottom:var(--x-label-space)!important}.sterilization-page .bar-label{bottom:-22px!important}.sterilization-page .chart-container[style*=height]{height:100%!important}@media (max-width:1200px){.sterilization-page .chart-container{height:100%!important}}.sterilization-page .chart-widget .chart-content{margin-top:100px!important}.operators-page{background:#0f1115;color:#e5e7eb;contain:content;display:flex;min-height:100vh}.operators-page .sidebar{background-color:#18181a;border-right:1px solid #2a2b32;display:flex;flex-direction:column;padding:24px 0;width:250px}.operators-page .logo{color:#5fa8ff;font-size:24px;font-weight:700;margin-bottom:40px;padding:0 24px;text-align:center}.operators-page .nav-menu{display:flex;flex-direction:column;gap:8px;padding:0 16px}.operators-page .nav-item{align-items:center;border-radius:8px;color:#b0b8d0;cursor:pointer;display:flex;gap:12px;padding:12px 16px;transition:all .2s ease}.operators-page .nav-item:hover{background-color:#22252d;color:#fff}.operators-page .nav-item.active{background-color:#5fa8ff;color:#fff}.operators-page .nav-icon{font-size:18px}.operators-page .main-content{background-color:#0f1115;flex:1 1;overflow-y:auto;padding:24px}.operators-page .header{align-items:center;display:flex;justify-content:space-between;margin-bottom:24px}.operators-page .header h1{color:#e5e7eb;font-size:24px;font-weight:600}.operators-page .header-right{display:flex;gap:12px}.operators-select{align-items:center;display:flex;gap:8px}.operators-select label{color:#cbd5e1;font-size:14px}.operators-select select{background:#1e2128;border:1px solid #2a2f3a;border-radius:8px;color:#e5e7eb;padding:6px 10px}.operators-error{background:#2a1515;border:1px solid #7f1d1d;border-radius:8px;color:#fecaca;margin-bottom:12px;padding:8px 12px}.operators-grid{grid-gap:16px;display:grid;gap:16px;grid-auto-rows:minmax(80px,auto);grid-template-areas:"panel  chart" "tasks  pie" "tasks  incidents";grid-template-columns:1.2fr 1.8fr}.panel-card{grid-area:panel}.chart-card{grid-area:chart}.pie-card{grid-area:pie}.incidents-card{grid-area:incidents}.tasks-card{grid-area:tasks}@media (max-width:1200px){.operators-grid{grid-template-areas:none;grid-template-columns:1fr}.chart-card,.incidents-card,.panel-card,.pie-card,.tasks-card{grid-area:auto}}.operators-card{background:#1e2128;border:1px solid #2a2f3a;border-radius:12px;box-shadow:0 6px 20px #00000040;contain-intrinsic-size:300px;content-visibility:auto;padding:20px}.operators-card-title{align-items:center;display:flex;font-size:15px;font-weight:600;justify-content:space-between;margin-bottom:10px}.operators-card-title.with-tabs{gap:8px}.operators-tabs{background:#2a2f3a;border-radius:999px;display:inline-flex;gap:6px;padding:4px}.operators-tabs button{background:#0000;border:none;border-radius:999px;color:#cbd5e1;cursor:pointer;padding:6px 10px}.operators-tabs button.active{background:#318cff;color:#fff}.operators-week{grid-gap:8px;display:grid;gap:8px;grid-template-columns:1fr}.operators-week-row{grid-gap:8px;align-items:center;background:#161a20;border:1px solid #232833;border-radius:8px;display:grid;gap:8px;grid-template-columns:24px 1fr auto;padding:8px 10px}.operators-week-row.active .dot{color:#318cff}.operators-week-row:not(.active) .dot{color:#374151}.operators-week-row.active .label{color:#fff}.operators-week-row:not(.active) .label{color:#9ca3af}.operators-week-row .time{font-feature-settings:"tnum";color:#e5e7eb;font-variant-numeric:tabular-nums}.chart-card{display:flex;flex-direction:column;min-height:420px}.operators-chart-wrap{flex:1 1;height:100%;min-height:300px}@media (max-width:1200px){.chart-card{min-height:360px}.operators-chart-wrap{min-height:260px;will-change:transform}}.operators-pie-wrap{grid-gap:16px;align-items:center;display:grid;gap:16px;grid-template-columns:1fr auto}.operators-legend .legend-row{align-items:center;display:flex;gap:8px;margin:6px 0}.operators-legend .legend-dot{border-radius:50%;display:inline-block;height:10px;width:10px}.operators-history{grid-gap:8px;display:grid;gap:8px}.operators-history-row{grid-gap:8px;align-items:center;background:#161a20;border:1px solid #232833;border-radius:8px;display:grid;gap:8px;grid-template-columns:120px 1fr auto;padding:8px 10px}.operators-history-row .date{font-feature-settings:"tnum";color:#93a3b8;font-variant-numeric:tabular-nums}.operators-history-row .title{color:#e5e7eb;justify-self:start;text-align:left}.operators-see-more{color:#93c5fd;cursor:pointer;margin-top:8px;text-align:center}.operators-table .tbody{display:flex;flex-direction:column;gap:10px;max-height:420px;overflow:auto}.operators-table .td.title{color:#e5e7eb}.chip{align-items:center;border:1px solid #0000;display:inline-flex;gap:6px;padding:2px 8px}.chip-blue{background:#0b2a52;border-color:#1d4ed8;color:#bfdbfe}.chip-orange{background:#2f2410;border-color:#b45309;color:#fbbf24}.chip-red{background:#2b1313;border-color:#b91c1c;color:#fecaca}.chip-gray{background:#20242a;border-color:#374151;color:#cbd5e1}.operators-skeleton{grid-gap:8px;display:grid;gap:8px}.operators-skeleton .bar{animation:operators-shine 1.2s linear infinite;background:linear-gradient(90deg,#20242a,#2a2f3a,#20242a);background-size:200% 100%;border-radius:8px;width:100%}@keyframes operators-shine{0%{background-position:0 50%}to{background-position:200% 50%}}.operators-empty{color:#93a3b8;font-style:italic;padding:12px 0}.operators-week-editor{align-items:center;display:inline-flex;gap:10px}.time-input{padding:6px 8px;width:92px}.inactive{color:#0000}.row-actions{align-items:center;display:flex;gap:8px;justify-content:flex-end;margin-top:24px}.btn{background:#161a20;border:1px solid #2a2f3a;border-radius:8px;color:#e5e7eb;cursor:pointer;padding:6px 12px}.btn-primary{background:#318cff;border-color:#318cff;color:#fff}.btn-ghost{background:#0000}.btn-danger{background:#dc2626;border-color:#dc2626;color:#fff}.btn:disabled{cursor:not-allowed;opacity:.6}.operators-hint{color:#93a3b8;font-size:12px;margin-right:auto}.switch input{-webkit-appearance:none;appearance:none;background:#2a2f3a;border-radius:999px;cursor:pointer;height:20px;outline:none;position:relative;transition:background .2s;width:36px}.switch input:checked{background:#318cff}.switch input:after{background:#fff;border-radius:50%;content:"";height:16px;left:2px;position:absolute;top:2px;transition:transform .2s;width:16px}.switch input:checked:after{transform:translateX(16px)}.blue-picker{align-items:center;background:#318cff;border-radius:10px;color:#fff;display:inline-flex;gap:6px;margin-top:8px;padding:4px 10px;position:relative}.blue-picker select{-webkit-appearance:none;appearance:none;background:#0000;border:none;color:#fff;cursor:pointer;font-weight:600;outline:none;padding-right:20px}.blue-picker .chevron{font-size:12px;opacity:.9;pointer-events:none}.op-header{align-items:center;display:flex;gap:10px;margin-bottom:24px}.op-name{color:#e5e7eb;font-size:18px;font-weight:600}.op-role-chip{background:#1f3a65;border:1px solid #3b82f6;border-radius:999px;color:#dbeafe;font-size:12px;padding:2px 8px}.mode-switch-centered{background:#2a2f3a;border-radius:999px;display:flex;gap:8px;justify-content:center;margin:20px auto 32px;padding:4px;width:-webkit-fit-content;width:fit-content}.mode-switch-centered .mode-pill{background:#0000;border:none;border-radius:999px;color:#cbd5e1;cursor:pointer;padding:6px 12px}.mode-switch-centered .mode-pill.active{background:#318cff;color:#fff}.op-week{gap:6px}.op-week-row{grid-gap:12px;align-items:center;background:none;border:none;display:grid;gap:12px;grid-template-columns:1fr auto;padding:4px 0}.check-and-day{align-items:center;display:inline-flex;gap:6px}.op-check{accent-color:#318cff;height:16px;width:16px}.op-day{color:#e5e7eb;font-weight:500}.op-times{align-items:center;display:inline-flex;gap:8px}.op-times .arrow{color:#9ca3af}.time-input-wrap{display:inline-flex}.time-input{font-feature-settings:"tnum";background:#1e2128;border:1px solid #2a2f3a;border-radius:10px;color:#e5e7eb;font-size:14px;font-variant-numeric:tabular-nums;width:104px}.time-input:disabled{cursor:pointer;filter:grayscale(100%);opacity:.45}.form-info,.form-success{background:#318cff1f;border:1px solid #318cff;border-radius:8px;color:#cfe3ff}.form-error,.form-info,.form-success{font-size:14px;margin-top:10px;padding:10px 12px}.form-error{background:#2a1515;border:1px solid #7f1d1d;border-radius:8px;color:#fecaca}.time-input.invalid{border-color:#b91c1c;box-shadow:0 0 0 2px #b91c1c26}.abs-planner{display:flex;flex-direction:column;gap:12px}.abs-toolbar{align-items:center;display:flex;flex-wrap:wrap;gap:12px}.abs-title{font-weight:600}.abs-range{opacity:.7}.abs-form{grid-gap:10px;display:grid;gap:10px}.abs-row{align-items:center;display:flex;gap:10px}.abs-row>span{color:#cbd5e1;width:160px}.abs-hours{align-items:center;display:flex;gap:8px}.abs-hours input[type=time]{width:120px}.abs-grid{grid-gap:8px;display:grid;gap:8px;grid-template-columns:repeat(7,minmax(0,1fr))}.abs-day{background:#0f172a;border:1px dashed #334155;border-radius:10px;cursor:pointer;padding:8px;-webkit-user-select:none;user-select:none}.abs-day:hover{border-color:#64748b}.abs-day.selected{outline:2px solid #318cff}.abs-day.has-off{background:#1f1322;border-color:#ef4444;color:#fecaca}.abs-day.has-open{background:#0f1f19;border-color:#22c55e;color:#86efac}.abs-day-date{font-weight:600;margin-bottom:4px}.abs-day-badge,.abs-day-empty{font-size:12px;opacity:.9}.abs-msg{border-radius:8px;padding:8px 10px}.abs-msg.ok{background:#052e1a;border:1px solid #14532d;color:#86efac}.abs-msg.err{background:#2b1111;border:1px solid #7f1d1d;color:#fecaca}.abs-legend{align-items:center;display:flex;font-size:12px;gap:14px;opacity:.8}.abs-legend .dot{border-radius:999px;display:inline-block;height:10px;margin-right:6px;width:10px}.abs-legend .dot.off{background:#ef4444}.abs-legend .dot.open{background:#22c55e}.abs-legend .dot.sel{background:#318cff}.abs2{display:flex;flex-direction:column;gap:14px}.abs2-head{align-items:center;display:flex;gap:12px}.abs2-head .title{font-weight:700;letter-spacing:.2px}.abs2-head .hint{font-size:12px;opacity:.6;padding-top:2px}.abs2-controls{align-items:center;display:flex;flex-wrap:wrap;gap:16px}.segmented{-webkit-backdrop-filter:saturate(180%) blur(14px);backdrop-filter:saturate(180%) blur(14px);background:#ffffff0f;border:1px solid #ffffff14;border-radius:14px;display:inline-flex;padding:4px}.segmented button{all:unset;border-radius:10px;color:#cbd5e1;cursor:pointer;font-weight:600;padding:6px 12px}.segmented button.active{background:linear-gradient(180deg,#0a84ff,#0666d7);box-shadow:0 6px 16px #0a84ff40,inset 0 1px 0 #ffffff26;color:#fff}.hours{align-items:center;display:flex;gap:8px}.hours .arrow{opacity:.6}input[type=time].cupertino{appearance:none;-webkit-appearance:none;background:#ffffff0f;border:1px solid #ffffff1a;border-radius:12px;box-shadow:inset 0 1px 0 #ffffff0f;color:#e5e7eb;font-weight:600;padding:8px 10px;width:120px}.abs2-grid{grid-gap:10px;align-items:start;display:grid;gap:10px;grid-template-columns:repeat(7,minmax(0,1fr))}.month-break{color:#8b95a7;font-size:11px;grid-column:1/-1;letter-spacing:.12em;margin-bottom:-2px;margin-top:6px;opacity:.8}.day{align-items:flex-start;-webkit-backdrop-filter:saturate(180%) blur(12px);backdrop-filter:saturate(180%) blur(12px);background:linear-gradient(180deg,#ffffff0f,#0000000f);border:1px solid #ffffff14;border-radius:16px;box-shadow:0 1px 0 #ffffff0d,inset 0 0 0 0 #0a84ff00;color:#e6e9ef;cursor:pointer;display:flex;flex-direction:column;gap:2px;padding:10px;position:relative;text-align:left;transition:border-color .15s ease,box-shadow .15s ease,transform .06s ease}.day:hover{border-color:#ffffff26;transform:translateY(-1px)}.day .dow{font-size:11px;opacity:.65}.day .num{font-size:20px;font-weight:700;letter-spacing:.2px}.day .dash{font-size:12px;opacity:.4;padding-top:4px}.badge{border-radius:999px;font-size:11px;font-weight:700;margin-top:4px;padding:2px 8px}.badge-off{background:#ff453a29;border:1px solid #ff453a47;color:#ffb3ae}.badge-open{background:#30d15829;border:1px solid #30d15847;color:#b6f6c6}.day.is-off{background:linear-gradient(180deg,#ff453a1f,#0000000f);border-color:#ff453a47}.day.is-open{background:linear-gradient(180deg,#30d1581f,#0000000f);border-color:#30d15847}.day.is-selected{border-color:#0a84ff;box-shadow:0 0 0 1px #0a84ff,0 8px 20px #0a84ff2e}.day.is-end:before,.day.is-start:before{border-radius:16px;box-shadow:inset 0 0 0 2px #0a84ff;content:"";inset:-1px;pointer-events:none;position:absolute}.day.is-selected:not(.is-start):not(.is-end){background:linear-gradient(180deg,#0a84ff1f,#0a84ff1a),linear-gradient(180deg,#ffffff0f,#0000000f)}.abs2-msg{border-radius:12px;font-weight:600;padding:10px 12px}.abs2-msg.ok{background:#30d1581f;border:1px solid #30d15847;color:#b6f6c6}.abs2-msg.err{background:#ff453a1f;border:1px solid #ff453a47;color:#ffb3ae}.abs2-actions{align-items:center;display:flex;gap:10px}.abs2-actions .spacer{flex:1 1}.btn-ghost{background:#ffffff0f;border:1px solid #ffffff1a;border-radius:12px;color:#e5e7eb;padding:10px 14px}.abs2 .btn-primary{background:linear-gradient(180deg,#0a84ff,#0666d7);border:1px solid #0a84ff;border-radius:12px;box-shadow:0 8px 18px #0a84ff47,inset 0 1px 0 #ffffff2e}.abs2 .btn-danger,.abs2 .btn-primary{color:#fff;font-weight:700;padding:10px 16px}.abs2 .btn-danger{background:linear-gradient(180deg,#ff453a,#d22d23);border:1px solid #ff453a;border-radius:12px;box-shadow:0 8px 18px #ff453a40,inset 0 1px 0 #ffffff1f}.abs2 .btn-danger:disabled,.abs2 .btn-primary:disabled{cursor:not-allowed;filter:saturate(.6);opacity:.6}.abs2-legend{align-items:center;display:flex;font-size:12px;gap:14px;opacity:.8}.abs2-legend .dot{border-radius:999px;display:inline-block;height:10px;margin-right:6px;width:10px}.abs2-legend .dot.off{background:#ff453a}.abs2-legend .dot.open{background:#30d158}.abs2-legend .dot.sel{background:#0a84ff}.abs2.compact{--cell:70px;--gap:8px;--radius:12px;--fs-num:16px;--fs-dow:10px}.abs2.compact .abs2-grid{grid-gap:var(--gap);display:grid;gap:var(--gap);grid-template-columns:repeat(7,var(--cell));margin:2px auto 0;width:calc(var(--cell)*7 + var(--gap)*6)}.abs2.compact .day{border-radius:var(--radius);height:calc(var(--cell) + 6px);padding:8px;width:var(--cell)}.abs2.compact .day .num{font-size:var(--fs-num)}.abs2.compact .day .dow{font-size:var(--fs-dow);opacity:.62}.abs2.compact .badge{font-size:10px;padding:2px 6px}.abs2.compact .month-break{font-size:10px;letter-spacing:.1em;margin-bottom:-4px;margin-top:2px}@media (max-width:1400px){.abs2.compact{--cell:64px}}@media (max-width:1200px){.abs2.compact{--cell:60px}}.btn-add-op{align-items:center;display:inline-flex;gap:8px}.btn-add-op .plus{font-size:18px;line-height:1}.modal-backdrop{align-items:center;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px);background:#0000008c;display:flex;inset:0;justify-content:center;position:fixed;z-index:70}.modal-card{background:#1e2128;border:1px solid #2a2f3a;border-radius:16px;box-shadow:0 18px 50px #00000073;max-width:calc(100vw - 28px);width:400px}.modal-head{align-items:center;border-bottom:1px solid #2a2f3a;display:flex;justify-content:space-between;padding:14px 16px}.modal-head .title{color:#e5e7eb;font-weight:700}.modal-close{all:unset;border-radius:8px;color:#cbd5e1;padding:4px 8px}.modal-close:hover{background:#2a2f3a}.modal-body{align-items:center;display:flex;flex-direction:column;gap:16px;padding:16px}.name-fields{gap:12px}.field,.name-fields{display:flex;flex-direction:column;max-width:280px;width:100%}.field{gap:6px}.field>span{color:#cbd5e1;font-size:13px}.input{background:#0f1115;border:1px solid #2a2f3a;border-radius:10px;color:#e5e7eb;outline:none;padding:10px 12px}.input:focus{border-color:#318cff;box-shadow:0 0 0 2px #318cff2e}.modal-actions{align-items:center;gap:10px;justify-content:flex-end;margin-top:20px;width:100%}.switch-container{background:#0f1115;border:1px solid #2a2f3a;border-radius:10px;display:flex;gap:2px;margin-left:12px;padding:2px;width:120px}.switch-option{background:#0000;border:none;border-radius:8px;color:#cbd5e1;cursor:pointer;flex:1 1;font-size:14px;font-weight:500;padding:10px 16px;transition:all .2s ease}.switch-option:hover{background:#ffffff0d}.switch-option.active{background:#318cff;color:#fff;font-weight:600}.pagination{display:flex;gap:8px;justify-content:center;margin-top:10px}.page-btn{background:#161a20;border:1px solid #2a2f3a;border-radius:8px;color:#cbd5e1;cursor:pointer;font-size:13px;padding:4px 10px}.page-btn.active{background:#318cff;border-color:#318cff;color:#fff}.page-btn:hover{border-color:#3b4250}.recharts-pie-sector{stroke:none!important}.operators-table .task-row{align-items:center;background:#0000;border:1px solid #ffffff0f;border-radius:12px;cursor:pointer;display:flex;gap:12px;padding:10px 12px}.operators-table .task-row+.task-row{margin-top:10px}.operators-table .task-row:hover{border-color:#ffffff29}.operators-table .row-check{margin:0}.operators-table .one-line{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.operators-table .thead{display:none}.pref-chip{border-radius:10px;font-size:12px;margin-left:8px;opacity:.85;padding:2px 6px}.pref-chip.include{background:#dcfce7;color:#14532d}.pref-chip.exclude{background:#fee2e2;color:#7f1d1d}.sidebar{background-color:var(--color-darker-gray,#18181a);border-right:1px solid var(--color-border,#2a2b32);flex-shrink:0}.logo{color:var(--color-blue,#5fa8ff)}.nav-item{color:var(--color-light-gray,#b0b8d0);font-weight:500}.nav-item:hover{background-color:var(--color-dark-gray,#22252d);color:var(--color-white,#fff)}.nav-item.active{background-color:var(--color-blue,#5fa8ff);color:var(--color-white,#fff)}.main-content{background-color:#000;background-color:var(--color-black,#000);color:#fff;color:var(--color-white,#fff);flex:1 1;overflow-y:auto;padding:24px}.activity-header{margin-bottom:2rem}.activity-header h1{color:#fff;color:var(--color-white,#fff);font-size:1.8rem;font-weight:600;text-align:center}.card{background-color:#22252d;background-color:var(--color-dark-gray,#22252d);border:1px solid var(--color-border,#2a2b32);border-radius:12px;margin-bottom:2rem;overflow:hidden}.card-header{background-color:#18181a;background-color:var(--color-darker-gray,#18181a);border-bottom:1px solid var(--color-border,#2a2b32);padding:1.5rem}.card-header h3{color:#fff;color:var(--color-white,#fff);font-size:1.2rem;font-weight:600}.card-body{padding:1.5rem}.card-header .chart-month-navigation{align-items:center!important;display:flex!important;flex-direction:row!important;flex-wrap:nowrap!important;gap:.75rem!important;overflow:visible!important;white-space:nowrap!important}.card-header .chart-month-navigation .arrow-btn{align-items:center!important;background:linear-gradient(135deg,#1e2029,#16171f)!important;border:1px solid #5fa8ff33!important;border-radius:8px!important;clear:none!important;color:#cbd3ea!important;cursor:pointer!important;display:flex!important;flex-shrink:0!important;float:none!important;font-size:18px!important;font-weight:700!important;height:36px!important;justify-content:center!important;position:relative!important;transition:all .3s cubic-bezier(.4,0,.2,1)!important;width:36px!important}.card-header .chart-month-navigation .arrow-btn:hover{background:linear-gradient(135deg,#272a33,#1e2029)!important;border-color:#5fa8ff!important;border-color:var(--color-blue,#5fa8ff)!important;box-shadow:0 4px 12px #5fa8ff40!important;color:#5fa8ff!important;transform:translateY(-1px)!important}.card-header .chart-month-navigation .current-month{clear:none!important;color:#fff!important;color:var(--color-white,#fff)!important;display:inline-block!important;flex-shrink:0!important;float:none!important;font-size:16px!important;font-weight:600!important;line-height:1!important;min-width:140px!important;position:relative!important;text-align:center!important;text-transform:capitalize!important;white-space:nowrap!important}.filters-section{background-color:#22252d;background-color:var(--color-dark-gray,#22252d);border:1px solid #2a2b32;border:1px solid var(--color-border,#2a2b32);border-radius:8px;box-shadow:0 2px 8px #0000004d;margin-bottom:2rem;padding:1.5rem;position:-webkit-sticky;position:sticky;top:1rem;z-index:100}.filters-row{flex-wrap:wrap;gap:2rem}.date-range-picker,.filters-row{align-items:flex-end;display:flex}.date-range-picker{gap:1rem}.date-label{color:#b0b8d0;color:var(--color-light-gray,#b0b8d0);display:flex;flex-direction:column;font-size:.9rem;font-weight:500;gap:.5rem}.date-input{background-color:#18181a;background-color:var(--color-darker-gray,#18181a);border:1px solid #2a2b32;border:1px solid var(--color-border,#2a2b32);border-radius:4px;color:#fff;color:var(--color-white,#fff);font-size:.9rem;min-width:140px;padding:.5rem}.date-input:focus{border-color:#5fa8ff;border-color:var(--color-blue,#5fa8ff);box-shadow:0 0 0 2px #5fa8ff40;outline:none}.operator-selector{flex:1 1;min-width:300px}.operator-selector-header{align-items:center;display:flex;justify-content:space-between;margin-bottom:.5rem}.operator-selector-label{color:#b0b8d0;color:var(--color-light-gray,#b0b8d0);font-size:.9rem;font-weight:500}.select-all-btn{background-color:#18181a;background-color:var(--color-darker-gray,#18181a);border:1px solid #2a2b32;border:1px solid var(--color-border,#2a2b32);border-radius:4px;color:#fff;color:var(--color-white,#fff);cursor:pointer;font-size:.8rem;padding:.25rem .5rem;transition:all .2s ease}.select-all-btn:hover{background-color:#22252d;background-color:var(--color-dark-gray,#22252d);border-color:#5fa8ff;border-color:var(--color-blue,#5fa8ff)}.operator-checkboxes{grid-gap:.5rem;background-color:#18181a;background-color:var(--color-darker-gray,#18181a);border:1px solid #2a2b32;border:1px solid var(--color-border,#2a2b32);border-radius:4px;display:grid;gap:.5rem;grid-template-columns:repeat(auto-fill,minmax(200px,1fr));max-height:120px;overflow-y:auto;padding:.5rem}.operator-checkbox{align-items:center;border-radius:4px;color:#fff;color:var(--color-white,#fff);cursor:pointer;display:flex;font-size:.85rem;gap:.5rem;padding:.25rem;transition:background-color .2s ease}.operator-checkbox:hover{background-color:#22252d;background-color:var(--color-dark-gray,#22252d)}.operator-checkbox input[type=checkbox]{margin:0}.filter-actions{align-items:flex-end;display:flex}.refresh-btn{background-color:#5fa8ff;background-color:var(--color-blue,#5fa8ff);border:1px solid #5fa8ff;border:1px solid var(--color-blue,#5fa8ff);border-radius:4px;color:var(--color-white,#fff);font-size:.9rem;font-weight:500;padding:.75rem 1.5rem;transition:all .2s ease;white-space:nowrap}.refresh-btn:hover:not(:disabled){background-color:#22252d;background-color:var(--color-dark-gray,#22252d);border-color:#5fa8ff;border-color:var(--color-blue,#5fa8ff)}.refresh-btn:disabled{cursor:not-allowed;opacity:.6}.table-section{margin-top:2rem}.table-filters{margin-bottom:1rem}.table-operator-filter,.table-operator-filter label{align-items:center;display:flex;gap:.5rem}.table-operator-filter label{color:#666;color:var(--text-secondary,#666);font-size:.9rem;font-weight:500}.operator-select{background:#fff;background:var(--input-bg,#fff);border:1px solid #e0e0e0;border:1px solid var(--border-color,#e0e0e0);border-radius:4px;color:#333;color:var(--text-primary,#333);font-size:.9rem;min-width:200px;padding:.5rem}.operator-select:focus{border-color:#007bff;border-color:var(--primary-color,#007bff);box-shadow:0 0 0 2px #007bff40;outline:none}.error-message{background:#f8d7da;border:1px solid #f5c6cb;color:#721c24;margin:2rem 0;padding:1.5rem;text-align:center}.retry-btn{background:#721c24;border:1px solid #721c24;border-radius:4px;color:#fff;font-size:.9rem;font-weight:500;margin-top:1rem;padding:.75rem 1.5rem;transition:all .2s ease}.retry-btn:hover{background:#5a1a1a;border-color:#5a1a1a}@media (max-width:1024px){.sidebar{width:200px}.filters-row{align-items:stretch;flex-direction:column}.date-range-picker{justify-content:center}.operator-selector{min-width:auto}.operator-checkboxes{grid-template-columns:repeat(auto-fill,minmax(150px,1fr))}}@media (max-width:768px){.activity-page{flex-direction:column}.sidebar{order:2;width:100%}.main-content{order:1;padding:1rem}.activity-header h1{font-size:1.5rem}.card-header{align-items:flex-start;flex-direction:column;gap:1rem}.chart-month-navigation{align-self:flex-end!important;gap:.5rem!important}.chart-month-navigation .current-month{font-size:14px!important;min-width:120px!important}.chart-month-navigation .arrow-btn{font-size:16px!important;height:32px!important;width:32px!important}.filters-section{padding:1rem}.date-range-picker{flex-direction:column;gap:.5rem}.date-input{min-width:auto;width:100%}.operator-checkboxes{grid-template-columns:1fr;max-height:100px}.filter-actions{justify-content:center}}@media (prefers-color-scheme:dark){.activity-page{background:#1a1a1a;background:var(--page-bg,#1a1a1a)}.activity-header h1{color:#fff;color:var(--text-primary,#fff)}.filters-section{background:#2a2a2a;background:var(--panel-bg,#2a2a2a);border-color:#404040;border-color:var(--border-color,#404040)}.date-label{color:#999;color:var(--text-secondary,#999)}.date-input,.operator-select{color:#fff;color:var(--text-primary,#fff)}.date-input,.operator-checkboxes,.operator-select{background:#404040;background:var(--input-bg,#404040);border-color:#555;border-color:var(--border-color,#555)}.operator-checkbox{color:#fff;color:var(--text-primary,#fff)}.operator-checkbox:hover{background:#333;background:var(--hover-bg,#333)}.select-all-btn{background:#404040;background:var(--button-bg,#404040);border-color:#555;border-color:var(--border-color,#555);color:#fff;color:var(--text-primary,#fff)}.select-all-btn:hover{background:#333;background:var(--button-hover-bg,#333);border-color:#007bff;border-color:var(--primary-color,#007bff)}}.refreshing-indicator{align-items:center;animation:pulse 1.5s ease-in-out infinite;display:inline-flex;font-size:14px;font-weight:500;gap:6px}@keyframes pulse{0%,to{opacity:1}50%{opacity:.5}}.refreshing-indicator:before{animation:spin 1s linear infinite;content:"⟳";display:inline-block}.chart-container{transition:opacity .3s ease}.chart-loading:before{animation:shimmer 2s infinite;background:linear-gradient(90deg,#0000,#5fa8ff1a 20%,#5fa8ff4d 50%,#5fa8ff1a 80%,#0000);content:"";height:100%;left:-100%;pointer-events:none;position:absolute;top:0;width:100%;z-index:1}.chart-container svg rect{animation:barRise .6s cubic-bezier(.34,1.56,.64,1) forwards;transform-origin:bottom}@keyframes barRise{0%{opacity:0;transform:scaleY(0)}to{opacity:1;transform:scaleY(1)}}.chart-container svg text.bar-value{animation:fadeInValue .4s ease forwards;animation-delay:.5s;opacity:0}@keyframes fadeInValue{0%{opacity:0;transform:translateY(-5px)}to{opacity:1;transform:translateY(0)}}.chart-container.chart-refreshing svg rect{opacity:.7;transition:opacity .3s ease}.chart-container.chart-refreshing:before{display:none}.activity-page{background:#000;background:var(--color-black);color:#fff;color:var(--color-white);display:flex;min-height:100vh}.activity-content{background-color:#000;background-color:var(--color-black);flex:1 1;overflow-y:auto;padding:24px}.activity-header{align-items:center;background:#1f2127;border:1px solid #2a2b32;border:1px solid var(--color-border);border-radius:16px;display:flex;justify-content:space-between;margin:0 0 20px;padding:16px 20px}.activity-header h1{font-size:24px;font-weight:800;margin:0}.activity-actions{align-items:center;display:flex;gap:10px}.month-navigation{background:#22252d;background:var(--color-dark-gray);border:1px solid #2a2b32;border:1px solid var(--color-border);border-radius:10px;gap:12px;padding:6px 12px}.current-month{font-size:14px;font-weight:600;min-width:120px}.refresh-btn{background:linear-gradient(135deg,#5fa8ff,#318cff);background:linear-gradient(135deg,var(--color-blue),var(--color-blue-2));border:0;border-radius:10px;box-shadow:0 6px 18px #5fa8ff40;color:#fff;cursor:pointer;font-weight:700;padding:8px 12px}.filters-card{background:#22252d;background:var(--color-dark-gray);border:1px solid #2a2b32;border:1px solid var(--color-border);border-radius:14px;margin-bottom:18px;padding:16px}.filter-row{align-items:flex-end;display:flex;flex-wrap:wrap;gap:16px}.filter-group{flex-direction:column;gap:6px}.filter-group label{color:#cbd3ea;font-size:12px}.filter-group input{background:#18181a;background:var(--color-darker-gray);border:1px solid #2a2b32;border:1px solid var(--color-border);border-radius:8px;color:#fff;padding:8px 10px}.chip{font-size:12px;padding:6px 10px}.chip.muted{opacity:.6}.card{background:#22252d;background:var(--color-dark-gray);border:1px solid #2a2b32;border:1px solid var(--color-border);border-radius:14px}.card-header{align-items:center;border-bottom:1px solid #2a2b32;border-bottom:1px solid var(--color-border);display:flex;justify-content:space-between;padding:14px 16px}.card-header h3{font-size:14px;font-weight:700;margin:0}.card-body{padding:18px}.nav-arrows{display:flex;gap:6px}.arrow-btn{align-items:center;background:linear-gradient(135deg,#1e2029,#16171f);border:1px solid #5fa8ff33;border-radius:10px;color:#cbd3ea;cursor:pointer;display:flex;font-size:18px;font-weight:700;height:36px;justify-content:center;overflow:hidden;position:relative;transition:all .3s cubic-bezier(.4,0,.2,1);width:36px}.arrow-btn:before{background:linear-gradient(135deg,#5fa8ff1a,#0000);bottom:0;content:"";left:0;opacity:0;position:absolute;right:0;top:0;transition:opacity .3s ease}.arrow-btn:hover{background:linear-gradient(135deg,#272a33,#1e2029);border-color:#5fa8ff;border-color:var(--color-blue);box-shadow:0 6px 20px #5fa8ff40;color:#5fa8ff;transform:translateY(-2px)}.arrow-btn:hover:before{opacity:1}.arrow-btn:active{box-shadow:0 2px 8px #5fa8ff33;transform:translateY(0)}.skeleton{animation:sk 1.4s linear infinite;background:linear-gradient(90deg,#20222a,#242732,#20222a);background-size:200% 100%;border-radius:12px;height:160px}@keyframes sk{0%{background-position:0 0}to{background-position:200% 0}}.error{background:#2b0d12;border:1px solid #441821;border-radius:12px;color:#ff8b96;display:flex;flex-direction:column;gap:8px;padding:12px}.retry-btn{align-self:flex-start;background:#441821;border:1px solid #6b2430;border-radius:8px;color:#ff8b96;cursor:pointer;padding:6px 10px}.chart-wrap{display:flex;flex-direction:column;gap:10px}.wh-svg{max-width:100%;width:100%}.grid{stroke:#ffffff1a;stroke-width:1}.y-label{text-anchor:end;dominant-baseline:middle}.x-label,.y-label{fill:#9aa6c4;font-size:11px}.bar-value,.x-label{text-anchor:middle}.bar-value{fill:#e6ecff;font-size:11px}.legend{display:flex;flex-wrap:wrap;gap:12px;margin-top:6px}.legend-item{align-items:center;background:#2b2e37;border:1px solid #2a2b32;border:1px solid var(--color-border);border-radius:999px;color:#cbd3ea;display:flex;font-size:12px;gap:8px;padding:6px 10px}.legend-item.muted{opacity:.7}.legend-swatch{background:#5fa8ff;background:var(--color-blue);border-radius:3px;height:12px;width:12px}.legend-text{white-space:nowrap}.toast-info{border-color:#5fa8ff66}.toast-info .toast-icon{color:#5fa8ff;color:var(--color-blue)}.monthly-summary-section{margin:20px 0}.monthly-summary-container{align-items:stretch;display:flex;gap:0;min-height:400px}.operators-summary,.salary-summary{display:flex;flex-direction:column;height:100%}@media (max-width:768px){.monthly-summary-container{flex-direction:column;gap:8px}.operators-summary,.salary-summary{margin:0}}.attendance-table-container{background:var(--color-dark-gray);border:1px solid var(--color-border);border-radius:14px;margin-top:24px;overflow:hidden}.table-header-section{align-items:center;background:#5fa8ff0d;border-bottom:1px solid var(--color-border);display:flex;justify-content:space-between;padding:14px 16px}.table-header-left{align-items:center;display:flex;gap:16px}.table-header-section h4{color:#e6ecff;font-size:14px;font-weight:700;margin:0}.operator-filter{background:var(--color-darker-gray);border:1px solid var(--color-border);border-radius:8px;color:#e6ecff;cursor:pointer;font-size:13px;font-weight:500;min-width:180px;outline:none;padding:6px 12px;transition:all .2s ease}.operator-filter:hover{background:#272a33;border-color:var(--color-blue)}.operator-filter:focus{border-color:var(--color-blue);box-shadow:0 0 0 3px #5fa8ff1a}.operator-filter option{background:var(--color-darker-gray);color:#e6ecff;padding:8px}.table-count{background:var(--color-darker-gray);border:1px solid var(--color-border);border-radius:999px;color:#9aa6c4;font-size:12px;padding:4px 10px}.btn-add-attendance{background:linear-gradient(135deg,var(--color-blue),var(--color-blue-2));border:none;border-radius:10px;box-shadow:0 4px 12px #5fa8ff33;color:#fff;cursor:pointer;font-size:13px;font-weight:700;padding:8px 16px;transition:all .2s ease}.btn-add-attendance:hover{box-shadow:0 6px 18px #5fa8ff59;transform:translateY(-2px)}.attendance-table-wrapper{overflow-x:auto;padding:0}.attendance-table{border-collapse:collapse;font-size:13px;width:100%}.attendance-table thead{background:var(--color-darker-gray);border-bottom:1px solid var(--color-border)}.attendance-table th{color:#9aa6c4;font-size:12px;font-weight:600;letter-spacing:.5px;padding:12px 16px;text-align:center;text-transform:uppercase}.attendance-table th:first-child{text-align:left}.attendance-table th:nth-child(2){padding-left:52px;text-align:left}@media (max-width:900px){.attendance-table th:nth-child(2){padding-left:10px}}.attendance-table tbody tr{border-bottom:1px solid #2a2b3280;transition:background .2s ease}.attendance-table tbody tr:hover{background:#5fa8ff08}.attendance-table tbody tr:last-child{border-bottom:none}.attendance-table td{color:#cbd3ea;padding:14px 16px;text-align:center}.attendance-table td:first-child{text-align:left}.attendance-table td:nth-child(2){padding-left:10px;text-align:left}.date-cell,.date-text{font-weight:500}.date-text{color:#cbd3ea;display:inline-block;font-size:13px}.operator-cell{padding-left:10px!important}.operator-info{align-items:center;display:flex;gap:10px}.operator-avatar{align-items:center;background:linear-gradient(135deg,var(--color-blue),var(--color-blue-2));border-radius:50%;color:#fff;display:flex;flex-shrink:0;font-size:14px;font-weight:700;height:32px;justify-content:center;text-transform:uppercase;width:32px}.operator-name{color:#e6ecff;font-weight:600;margin-left:0}.pagination-container{align-items:center;border-top:1px solid var(--color-border);display:flex;justify-content:space-between;margin-top:20px;padding:15px 0}.pagination-info{color:var(--color-text-secondary);font-size:14px}.pagination-controls{align-items:center;display:flex;gap:15px}.pagination-btn{background:var(--color-darker-gray);border:1px solid var(--color-border);border-radius:6px;color:var(--color-text);cursor:pointer;font-size:14px;padding:8px 16px;transition:all .2s ease}.pagination-btn:hover:not(:disabled){background:#272a33;border-color:var(--color-blue)}.pagination-btn:disabled{cursor:not-allowed;opacity:.5}.pagination-page{color:var(--color-text);font-size:14px;font-weight:500}@media (max-width:900px){.operator-info{align-items:flex-start;flex-direction:column;gap:6px}.operator-avatar{font-size:12px;height:28px;width:28px}.pagination-container{flex-direction:column;gap:10px;text-align:center}}.duration-cell,.time-cell{min-width:110px;text-align:center;transition:all .3s ease}.duration-cell.editing,.time-cell.editing{background:#5fa8ff08;padding:20px 16px}.duration-display,.time-display{align-items:center;background:var(--color-darker-gray);border:1px solid var(--color-border);border-radius:8px;cursor:pointer;display:inline-flex;gap:6px;justify-content:center;min-width:80px;padding:6px 10px;transition:all .2s ease}.duration-display:hover,.time-display:hover{background:#272a33;border-color:var(--color-blue);box-shadow:0 4px 12px #5fa8ff26;transform:translateY(-1px)}.pause-icon,.time-icon{font-size:14px}.edit-cell-container{align-items:center;display:flex;flex-direction:column;gap:8px}.time-input{border:2px solid var(--color-blue);box-shadow:0 0 0 3px #5fa8ff1a;font-size:13px;font-weight:500;min-width:80px;outline:none;padding:6px 10px;text-align:center}.edit-actions{gap:6px}.edit-actions,.edit-btn{align-items:center;display:flex}.edit-btn{border:1px solid var(--color-border);border-radius:6px;cursor:pointer;font-size:14px;font-weight:700;height:28px;justify-content:center;transition:all .2s ease;width:32px}.validate-btn{background:linear-gradient(135deg,#4ade80,#22c55e);border-color:#22c55e;color:#fff}.validate-btn:hover{background:linear-gradient(135deg,#22c55e,#16a34a);box-shadow:0 4px 12px #22c55e4d;transform:scale(1.05)}.cancel-btn{background:linear-gradient(135deg,#ef4444,#dc2626);border-color:#dc2626;color:#fff}.cancel-btn:hover{background:linear-gradient(135deg,#dc2626,#b91c1c);box-shadow:0 4px 12px #dc26264d;transform:scale(1.05)}.total-badge,.total-cell{text-align:center}.total-badge{background:linear-gradient(135deg,#5fa8ff26,#318cff26);border:1px solid #5fa8ff4d;border-radius:8px;color:var(--color-blue);display:inline-block;font-size:13px;font-weight:700;min-width:70px;padding:6px 12px}.actions-cell{text-align:center}.action-btn{align-items:center;background:#0000;border:1px solid var(--color-border);border-radius:6px;color:#9aa6c4;cursor:pointer;display:inline-flex;height:32px;justify-content:center;transition:all .2s ease;width:32px}.action-btn:hover{background:var(--color-blue);border-color:var(--color-blue);color:#fff;transform:scale(1.05)}.delete-btn:hover{background:var(--color-red);border-color:var(--color-red);color:#fff}.attendance-table-empty{align-items:center;color:#9aa6c4;display:flex;flex-direction:column;justify-content:center;padding:48px 24px;text-align:center}.empty-icon{font-size:48px;margin-bottom:16px;opacity:.5}.attendance-table-empty p{font-size:14px;margin:0}@media (max-width:768px){.attendance-table{font-size:12px}.attendance-table td,.attendance-table th{padding:10px 12px}.operator-avatar{font-size:12px;height:28px;width:28px}}.modal-overlay{align-items:center;animation:fadeInOverlay .2s ease;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);background:#000000bf;bottom:0;display:flex;justify-content:center;left:0;position:fixed;right:0;top:0;z-index:3000}@keyframes fadeInOverlay{0%{opacity:0}to{opacity:1}}.modal-content{animation:slideInModal .3s cubic-bezier(.4,0,.2,1);background:linear-gradient(135deg,#22252d,#1a1d25);border:1px solid #5fa8ff33;border-radius:16px;box-shadow:0 20px 60px #00000080,0 0 0 1px #5fa8ff1a;max-height:90vh;max-width:500px;overflow-y:auto;width:90%}@keyframes slideInModal{0%{opacity:0;transform:translateY(-20px) scale(.95)}to{opacity:1;transform:translateY(0) scale(1)}}.modal-header{align-items:center;background:#5fa8ff0d;border-bottom:1px solid #2a2b32cc;display:flex;justify-content:space-between;padding:20px 24px}.modal-header h3{color:#e6ecff;font-size:18px;font-weight:700;margin:0}.modal-close{align-items:center;background:#0000;border:none;border-radius:6px;color:#9aa6c4;cursor:pointer;display:flex;font-size:24px;height:32px;justify-content:center;transition:all .2s ease;width:32px}.modal-close:hover{background:#ff475726;color:var(--color-red)}.modal-form{padding:24px}.form-group{margin-bottom:20px}.form-group label{color:#cbd3ea;font-size:13px;margin-bottom:8px}.form-input,.form-select{background:var(--color-darker-gray);border:1px solid var(--color-border);border-radius:8px;color:#e6ecff;font-size:14px;font-weight:500;outline:none;padding:10px 14px;transition:all .2s ease;width:100%}.form-input:hover,.form-select:hover{border-color:#5fa8ff66}.form-input:focus,.form-select:focus{border-color:var(--color-blue);box-shadow:0 0 0 3px #5fa8ff1a}.form-select{cursor:pointer}.form-select option{background:var(--color-darker-gray);color:#e6ecff;padding:10px}.form-row{grid-gap:16px;gap:16px}.form-hint{color:#9aa6c4;display:block;font-size:11px;font-style:italic;margin-top:6px}.modal-actions{border-top:1px solid #2a2b3280;display:flex;gap:12px;margin-top:28px;padding-top:20px}.btn-cancel,.btn-submit{border:none;border-radius:10px;cursor:pointer;flex:1 1;font-size:14px;font-weight:700;padding:12px 20px;transition:all .2s ease}.btn-cancel{color:#cbd3ea}.btn-cancel:hover{background:#272a33}.btn-submit{background:linear-gradient(135deg,var(--color-blue),var(--color-blue-2));box-shadow:0 6px 18px #5fa8ff40;color:#fff}.btn-submit:hover{box-shadow:0 8px 24px #5fa8ff59;transform:translateY(-2px)}.btn-submit:active{transform:translateY(0)}.btn-cancel:disabled,.btn-submit:disabled{cursor:not-allowed;opacity:.6;pointer-events:none}.spinner{display:inline-block;height:14px;margin-right:8px;width:14px}@media (max-width:600px){.modal-content{max-height:95vh;width:95%}.form-row{grid-template-columns:1fr}}.operators-summary{background:#22252d;background:var(--color-dark-gray,#22252d);border:1px solid #2a2b32;border:1px solid var(--color-border,#2a2b32);border-radius:14px;display:flex;flex:0.75 1;flex-direction:column;margin-right:8px;min-height:400px;padding:16px}.detail-title{color:#fff;color:var(--color-white,#fff);font-size:18px;font-weight:700;margin:0}.operators-table-wrapper{flex:1 1;overflow:auto}.operators-table{background:#22252d;background:var(--color-dark-gray,#22252d);border-collapse:initial;border-radius:8px;border-spacing:0;overflow:hidden;table-layout:fixed;width:100%}.operators-table thead{background:#18181a;background:var(--color-darker-gray,#18181a)}.operators-table th{border-bottom:1px solid #2a2b32;border-bottom:1px solid var(--color-border,#2a2b32);color:#b0b8d0;color:var(--color-light-gray,#b0b8d0);font-size:12px;font-weight:700;height:48px;letter-spacing:.5px;padding:12px 8px;text-align:left;text-transform:uppercase;vertical-align:middle;white-space:nowrap}.operators-table th:nth-child(4){padding-left:40px!important;text-align:left}.operators-table tbody tr{border-bottom:1px solid #2a2b32;border-bottom:1px solid var(--color-border,#2a2b32);height:48px;transition:background-color .2s ease}.operators-table tbody tr:hover{background:#5fa8ff0d}.operators-table tbody tr:last-child{border-bottom:none}.operators-table td{color:#fff;color:var(--color-white,#fff);font-size:14px;padding:12px 8px;vertical-align:middle}.zero-hours{color:#666!important}.overtime-hours{color:#ffa502!important}.operators-table td:first-child,.operators-table th:first-child{width:35%}.operator-cell{font-weight:600;padding-right:32px!important;text-align:left}.operator-name{color:#fff;color:var(--color-white,#fff);font-size:14px}.operators-table td:nth-child(2),.operators-table td:nth-child(3),.operators-table th:nth-child(2),.operators-table th:nth-child(3){width:15%}.hours-cell{padding-left:20px!important;padding-right:20px!important;text-align:center}.hours-value{color:#5fa8ff;color:var(--color-blue,#5fa8ff);font-size:14px;font-weight:700}.operators-table td:nth-child(4),.operators-table th:nth-child(4){width:35%}.punctuality-cell{padding-left:40px!important;padding-right:20px!important;text-align:left}.punctuality-gauge{align-items:center;display:flex;flex-direction:row;gap:12px;justify-content:flex-start;width:100%}.gauge-bar{background:#ffffff14;border-radius:4px;flex:1 1;height:8px;max-width:180px;overflow:hidden;position:relative}.gauge-fill{background:linear-gradient(90deg,#5fa8ff,#318cff);border-radius:4px;height:100%;transition:width .3s ease}.gauge-value{color:#5fa8ff;flex-shrink:0;font-size:12px;font-weight:600;min-width:42px;text-align:left}@media (max-width:1200px){.operators-table td,.operators-table th{font-size:12px;padding:8px 4px}.current-month{font-size:16px;min-width:160px}}.training-badge{color:#ff69b4;font-size:13px;font-style:italic;font-weight:600}.training-hours-inline{color:#ff69b4;font-size:14px;font-weight:700;margin-left:4px}@media (max-width:768px){.operators-summary{margin-bottom:8px;margin-right:0}.operators-table{font-size:12px}.operators-table td,.operators-table th{padding:6px 4px}.month-navigation{gap:12px}.current-month{font-size:14px;min-width:120px}}.salary-summary{background:#22252d;background:var(--color-dark-gray,#22252d);border:1px solid #2a2b32;border:1px solid var(--color-border,#2a2b32);border-radius:14px;display:flex;flex:0.25 1;flex-direction:column;margin-left:8px;min-height:400px;padding:16px}.summary-header{align-items:center;border-bottom:1px solid #2a2b32;border-bottom:1px solid var(--color-border,#2a2b32);display:flex;height:48px;margin-bottom:16px;padding-bottom:12px}.month-navigation{gap:16px}.month-arrow,.month-navigation{align-items:center;display:flex;justify-content:center}.month-arrow{background:linear-gradient(135deg,#1e2029,#16171f);border:1px solid #5fa8ff33;border-radius:8px;color:#cbd3ea;cursor:pointer;font-size:16px;font-weight:700;height:32px;transition:all .3s cubic-bezier(.4,0,.2,1);width:32px}.month-arrow:hover{background:linear-gradient(135deg,#272a33,#1e2029);border-color:#5fa8ff;border-color:var(--color-blue,#5fa8ff);box-shadow:0 4px 12px #5fa8ff40;color:#5fa8ff;transform:translateY(-1px)}.current-month{color:#fff;color:var(--color-white,#fff);font-size:18px;font-weight:700;min-width:200px;text-align:center;text-transform:capitalize}.salary-table-wrapper{flex:1 1;overflow:auto}.salary-table{background:#22252d;background:var(--color-dark-gray,#22252d);border-collapse:collapse;border-radius:8px;overflow:hidden;width:100%}.salary-table thead{background:#18181a;background:var(--color-darker-gray,#18181a)}.salary-table th{color:#b0b8d0;color:var(--color-light-gray,#b0b8d0);font-size:12px;font-weight:700;letter-spacing:.5px;padding:12px 8px;text-align:left;text-transform:uppercase;vertical-align:middle;white-space:nowrap}.salary-table tbody tr,.salary-table th{border-bottom:1px solid #2a2b32;border-bottom:1px solid var(--color-border,#2a2b32);height:48px}.salary-table tbody tr{transition:background-color .2s ease}.salary-table tbody tr:hover{background:#5fa8ff0d}.salary-table tbody tr:last-child{border-bottom:none}.salary-table td{color:#fff;color:var(--color-white,#fff);font-size:14px;padding:12px 8px;vertical-align:middle}.salary-cell{text-align:center}.salary-loading{color:#999;font-style:italic}.salary-computed{color:#5fa8ff;font-weight:500}.salary-in-progress{color:#4caf50;font-style:italic;font-weight:600}.salary-value{color:#4caf50;font-size:14px;font-weight:700}.status-cell{text-align:left}.status-badge{background:linear-gradient(135deg,#5fa8ff26,#318cff26);border:1px solid #5fa8ff4d;border-radius:8px;color:var(--color-blue);display:inline-block;font-size:13px;font-weight:700;min-width:70px;padding:6px 12px;text-align:center;white-space:nowrap}.status-badge.status-envoyé{background:linear-gradient(135deg,#4caf5026,#388e3c26);border:1px solid #4caf504d;color:#4caf50}.status-badge.status-en-cours-d-envoi{background:linear-gradient(135deg,#ff980026,#ff8f0026);border:1px solid #ff98004d;color:#ff9800}.status-badge.status-pas-envoyé{background:linear-gradient(135deg,#f4433626,#c6282826);border:1px solid #f443364d;color:#f44336}.status-badge.status-informations-requises{background:linear-gradient(135deg,#ff980026,#ff8f0026);border:1px solid #ff98004d;color:#ff9800}.status-badge.clickable{background:inherit;border:none;cursor:pointer;font-family:inherit;font-size:inherit;font-weight:inherit;transition:all .2s ease}.status-badge.clickable:hover{box-shadow:0 2px 8px #00000026;filter:brightness(1.1);transform:translateY(-1px)}.status-badge.clickable:active{transform:translateY(0)}.generate-payslip-button{background:linear-gradient(135deg,#5fa8ff,#318cff);border:none;border-radius:8px;box-shadow:0 2px 8px #5fa8ff33;color:#fff;cursor:pointer;display:inline-block;font-size:13px;font-weight:600;padding:8px 16px;transition:all .2s ease;white-space:nowrap}.generate-payslip-button:hover{background:linear-gradient(135deg,#4a9eff,#2077e5);box-shadow:0 4px 12px #5fa8ff59;transform:translateY(-1px)}.generate-payslip-button:active{box-shadow:0 2px 6px #5fa8ff33;transform:translateY(0)}.view-payslip-button{background:linear-gradient(135deg,#fff,#f5f5f5);border:1px solid #fff3;border-radius:8px;box-shadow:0 2px 8px #ffffff1a;color:#1a1d28;cursor:pointer;display:inline-block;font-size:13px;font-weight:600;padding:8px 16px;transition:all .2s ease;white-space:nowrap}.view-payslip-button:hover{background:linear-gradient(135deg,#fff,#e8e8e8);border-color:#ffffff4d;box-shadow:0 4px 12px #fff3;transform:translateY(-1px)}.view-payslip-button:active{box-shadow:0 2px 6px #ffffff1a;transform:translateY(0)}@media (max-width:1200px){.salary-table td,.salary-table th{font-size:12px;padding:8px 4px}.current-month{font-size:16px;min-width:160px}}@media (max-width:768px){.salary-summary{margin-left:0;margin-top:8px}.salary-table{font-size:12px}.salary-table td,.salary-table th{padding:6px 4px}.month-navigation{gap:12px}.current-month{font-size:14px;min-width:120px}}.cabinet-empty-state{align-items:center;display:flex;flex-direction:column;height:100%;justify-content:center;min-height:300px;padding:40px 20px;text-align:center}.cabinet-icon{font-size:48px;margin-bottom:20px;opacity:.8}.cabinet-empty-title{color:#fff;color:var(--color-white,#fff);font-size:18px;font-weight:600;line-height:1.3;margin-bottom:12px}.cabinet-empty-description{color:#b0b8d0;color:var(--color-light-gray,#b0b8d0);font-size:14px;line-height:1.4;margin-bottom:24px;max-width:280px}.cabinet-complete-button{background-color:#5fa8ff;background-color:var(--color-blue,#5fa8ff);border:none;border-radius:8px;color:#fff;cursor:pointer;display:inline-block;font-size:14px;font-weight:500;padding:12px 24px;text-decoration:none;transition:all .2s ease}.cabinet-complete-button:hover{background-color:#4a9eff;box-shadow:0 4px 12px #5fa8ff4d;transform:translateY(-1px)}.cabinet-error-state{align-items:center;display:flex;flex-direction:column;height:100%;justify-content:center;min-height:300px;padding:40px 20px;text-align:center}.cabinet-error-title{color:#f44336;font-size:16px;font-weight:600;margin-bottom:8px}.cabinet-error-message{color:#b0b8d0;color:var(--color-light-gray,#b0b8d0);font-size:14px;margin-bottom:16px}.retry-button{background-color:#f44336;border:none;border-radius:6px;color:#fff;cursor:pointer;font-size:12px;font-weight:500;padding:8px 16px;transition:all .2s ease}.retry-button:hover{background-color:#d32f2f;transform:translateY(-1px)}.cabinet-loading-state{align-items:center;display:flex;flex-direction:column;height:100%;justify-content:center;min-height:300px;padding:40px 20px}.loading-spinner{border:3px solid #2a2b32;border-top:3px solid #5fa8ff;border:3px solid var(--color-border,#2a2b32);border-top-color:var(--color-blue,#5fa8ff);height:32px;margin-bottom:16px;width:32px}.loading-text{color:#b0b8d0;color:var(--color-light-gray,#b0b8d0);font-size:14px}.cabinet-modal-backdrop{animation:fadeIn .3s ease;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);background:#000000b3;z-index:1000}.cabinet-modal,.cabinet-modal-backdrop{bottom:0;left:0;position:fixed;right:0;top:0}.cabinet-modal{align-items:center;animation:slideIn .3s ease;display:flex;justify-content:center;padding:20px;z-index:1001}.cabinet-modal-content{-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);background:#fffffff2;border:1px solid #fff3;border-radius:24px;box-shadow:0 25px 50px #00000040;display:flex;flex-direction:column;max-height:90vh;max-width:800px;overflow:hidden;width:100%}@media (prefers-color-scheme:dark){.cabinet-modal-content{background:#1e1e1ef2;border:1px solid #ffffff1a}}.cabinet-modal-header{border-bottom:1px solid #0000001a;padding:32px 32px 24px;position:relative}.cabinet-modal-title{color:#1a1a1a;font-size:28px;font-weight:700;line-height:1.2;margin:0 0 8px}.cabinet-modal-subtitle{color:#666;font-size:16px;line-height:1.4;margin:0}.cabinet-modal-close{align-items:center;background:#0000001a;border:none;border-radius:50%;color:#666;cursor:pointer;display:flex;font-size:24px;font-weight:300;height:40px;justify-content:center;position:absolute;right:24px;top:24px;transition:all .2s ease;width:40px}.cabinet-modal-close:hover{background:#0003;color:#333}@media (prefers-color-scheme:dark){.cabinet-modal-title{color:#fff}.cabinet-modal-subtitle{color:#b0b0b0}.cabinet-modal-close{background:#ffffff1a;color:#b0b0b0}.cabinet-modal-close:hover{background:#fff3;color:#fff}}.cabinet-modal-body{flex:1 1;overflow-y:auto;padding:32px}.cabinet-section{margin-bottom:32px}.cabinet-section:last-child{margin-bottom:0}.cabinet-section-title{border-bottom:2px solid #e5e7eb;color:#1a1a1a;font-size:18px;font-weight:600;margin:0 0 20px;padding-bottom:8px}.cabinet-subsection{margin-bottom:24px}.cabinet-subsection:last-child{margin-bottom:0}.cabinet-subsection-title{color:#1a1a1a;font-size:14px;font-weight:600;margin:0 0 12px;opacity:.9}.cabinet-hint{color:#6b7280;font-size:12px;line-height:1.3;margin-top:2px;opacity:.85}@media (prefers-color-scheme:dark){.cabinet-section-title{border-bottom-color:#374151;color:#fff}.cabinet-subsection-title{color:#f3f4f6}.cabinet-hint{color:#9ca3af}}.cabinet-grid{grid-gap:20px;display:grid;gap:20px;grid-template-columns:repeat(auto-fit,minmax(300px,1fr))}@media (max-width:768px){.cabinet-grid{gap:16px;grid-template-columns:1fr}}.cabinet-info-banner{background:#6b72801a;border:1px solid #6b728033;border-radius:8px;color:#6b7280;font-size:13px;line-height:1.4;margin:0 32px 20px;padding:12px 16px}.cabinet-warning-banner{align-items:flex-start;animation:slideDown .3s ease;background:linear-gradient(135deg,#fef3c7,#fde68a);border:1px solid #f59e0b;border-radius:12px;display:flex;gap:12px;margin:0 32px 24px;padding:16px}.warning-icon{flex-shrink:0;font-size:20px;margin-top:2px}.warning-content h4{color:#92400e;font-size:14px;font-weight:600;margin:0 0 4px}.warning-content p{color:#92400e;font-size:13px;line-height:1.4;margin:0}@media (prefers-color-scheme:dark){.cabinet-warning-banner{background:linear-gradient(135deg,#451a03,#78350f);border-color:#f59e0b}.warning-content h4,.warning-content p{color:#fbbf24}}.cabinet-field{display:flex;flex-direction:column;gap:6px}.cabinet-label{align-items:center;color:#374151;display:flex;font-size:14px;font-weight:600;gap:8px}.required{color:#ef4444;font-weight:700}.tooltip-trigger{cursor:help;font-size:12px;opacity:.7}.cabinet-input{background:#fffc;border:2px solid #e5e7eb;border-radius:12px;color:#1a1a1a;font-size:14px;min-height:44px;padding:12px 16px;resize:vertical;transition:all .2s ease}.cabinet-input:focus{background:#fffffff2;border-color:#3b82f6;box-shadow:0 0 0 3px #3b82f61a;outline:none}.cabinet-input.error{border-color:#ef4444;box-shadow:0 0 0 3px #ef44441a}.cabinet-input::placeholder{color:#9ca3af}.cabinet-select{-webkit-appearance:none;appearance:none;background-image:url("data:image/svg+xml;charset=utf-8,%3Csvg xmlns='http://www.w3.org/2000/svg' fill='none' viewBox='0 0 20 20'%3E%3Cpath stroke='%236b7280' stroke-linecap='round' stroke-linejoin='round' stroke-width='1.5' d='m6 8 4 4 4-4'/%3E%3C/svg%3E");background-position:right 12px center;background-repeat:no-repeat;background-size:16px;padding-right:40px}.cabinet-idcc-container{display:flex;flex-direction:column;gap:12px}.cabinet-idcc-suggestions{background:#3b82f60d;border:1px solid #3b82f633;border-radius:8px;padding:12px}.suggestions-label{color:#3b82f6;display:block;font-size:12px;font-weight:500;margin-bottom:8px}.suggestions-buttons{display:flex;flex-wrap:wrap;gap:8px}.suggestion-btn{background:#fffc;border:1px solid #3b82f64d;border-radius:6px;color:#3b82f6;cursor:pointer;font-size:12px;font-weight:500;padding:6px 12px;transition:all .2s ease}.suggestion-btn:hover{background:#3b82f61a;border-color:#3b82f6}.suggestion-btn.active{background:#3b82f6;border-color:#3b82f6;color:#fff}.error-message{color:#ef4444;font-size:12px}@media (prefers-color-scheme:dark){.cabinet-label{color:#d1d5db}.cabinet-input{background:#1e1e1ecc;border-color:#4b5563;color:#fff}.cabinet-input:focus{background:#1e1e1ef2;border-color:#3b82f6}.cabinet-input::placeholder{color:#6b7280}.cabinet-idcc-suggestions{background:#3b82f61a;border-color:#3b82f64d}.suggestion-btn{background:#1e1e1ecc;border-color:#3b82f666}.suggestion-btn:hover{background:#3b82f633}}.organisme-alert{background:linear-gradient(135deg,#fef3c7,#fde68a);border:1px solid #f59e0b;border-radius:6px;color:#92400e;display:inline-block;font-size:11px;font-weight:500;margin-left:8px;max-width:200px;overflow:hidden;padding:4px 8px;text-overflow:ellipsis;white-space:nowrap}@media (prefers-color-scheme:dark){.organisme-alert{background:linear-gradient(135deg,#451a03,#78350f);border-color:#f59e0b;color:#fbbf24}}.cabinet-organismes-help{background:#3b82f60d;border:1px solid #3b82f633;border-radius:8px;color:#3b82f6;font-size:13px;line-height:1.4;margin-top:16px;padding:12px}@media (prefers-color-scheme:dark){.cabinet-organismes-help{background:#3b82f61a;border-color:#3b82f64d}}.cabinet-banking-help{background:#6b72800d;border:1px solid #6b728033;border-radius:8px;color:#6b7280;font-size:13px;line-height:1.4;margin-bottom:16px;padding:12px}@media (prefers-color-scheme:dark){.cabinet-banking-help{background:#6b72801a;border-color:#6b72804d}}.atmp-badge-confirm{background:linear-gradient(135deg,#fef3c7,#fde68a);border:1px solid #f59e0b;border-radius:6px;color:#92400e;display:inline-block;font-size:11px;font-weight:600;margin-left:8px;padding:3px 8px;white-space:nowrap}@media (prefers-color-scheme:dark){.atmp-badge-confirm{background:linear-gradient(135deg,#451a03,#78350f);border-color:#f59e0b;color:#fbbf24}}.cabinet-atmp-help{background:#3b82f60d;border:1px solid #3b82f633;border-radius:8px;color:#374151;font-size:13px;line-height:1.5;margin-top:8px;padding:12px}.cabinet-atmp-help strong{color:#1f2937;font-weight:600}.cabinet-atmp-help p{margin:8px 0}.cabinet-atmp-help ul{list-style:disc;margin:8px 0;padding-left:20px}.cabinet-atmp-help li{margin:6px 0}.cabinet-atmp-help .help-link{color:#3b82f6;font-weight:500;text-decoration:none}.cabinet-atmp-help .help-link:hover{color:#1d4ed8;text-decoration:underline}@media (prefers-color-scheme:dark){.cabinet-atmp-help{background:#3b82f61a;border-color:#3b82f64d;color:#d1d5db}.cabinet-atmp-help strong{color:#f3f4f6}.cabinet-atmp-help .help-link{color:#60a5fa}.cabinet-atmp-help .help-link:hover{color:#93c5fd}}.cabinet-separator{background:linear-gradient(90deg,#0000,#e5e7eb,#0000);height:1px;margin:24px 0}@media (prefers-color-scheme:dark){.cabinet-separator{background:linear-gradient(90deg,#0000,#4b5563,#0000)}}.cabinet-advanced{background:#00000005;border:1px solid #0000001a;border-radius:12px;margin-top:16px;padding:20px}.cabinet-advanced-summary{align-items:center;color:#374151;cursor:pointer;display:flex;font-weight:600;gap:8px;list-style:none;margin-bottom:16px}.cabinet-advanced-summary:before{content:"▶";font-size:12px;transition:transform .2s ease}.cabinet-advanced[open] .cabinet-advanced-summary:before{transform:rotate(90deg)}@media (prefers-color-scheme:dark){.cabinet-advanced{background:#ffffff05;border-color:#ffffff1a}.cabinet-advanced-summary{color:#d1d5db}}.cabinet-modal-footer{border-top:1px solid #0000001a;display:flex;gap:16px;justify-content:flex-end;padding:24px 32px}@media (prefers-color-scheme:dark){.cabinet-modal-footer{border-top-color:#ffffff1a}}.cabinet-btn{border:none;border-radius:12px;cursor:pointer;font-size:14px;font-weight:600;min-width:120px;padding:12px 24px;transition:all .2s ease}.cabinet-btn:disabled{cursor:not-allowed;opacity:.6}.cabinet-btn-secondary{background:#0000000d;border:1px solid #0000001a;color:#374151}.cabinet-btn-secondary:hover:not(:disabled){background:#0000001a}.cabinet-btn-primary{background:linear-gradient(135deg,#3b82f6,#1d4ed8);box-shadow:0 4px 12px #3b82f64d;color:#fff}.cabinet-btn-primary:hover:not(:disabled){background:linear-gradient(135deg,#2563eb,#1e40af);box-shadow:0 6px 16px #3b82f666;transform:translateY(-1px)}@media (prefers-color-scheme:dark){.cabinet-btn-secondary{background:#ffffff0d;border-color:#ffffff1a;color:#d1d5db}.cabinet-btn-secondary:hover:not(:disabled){background:#ffffff1a}}.cabinet-toast{border-radius:12px;color:#fff;font-weight:600;opacity:0;padding:16px 20px;position:fixed;right:20px;top:20px;transform:translateX(100%);transition:all .3s ease;z-index:2000}.cabinet-toast.show{opacity:1;transform:translateX(0)}.cabinet-toast-success{background:linear-gradient(135deg,#10b981,#059669);box-shadow:0 4px 12px #10b9814d}.cabinet-toast-error{background:linear-gradient(135deg,#ef4444,#dc2626);box-shadow:0 4px 12px #ef44444d}.cabinet-toast-info{background:linear-gradient(135deg,#3b82f6,#1d4ed8);box-shadow:0 4px 12px #3b82f64d}@media (max-width:640px){.cabinet-modal{padding:10px}.cabinet-modal-content{border-radius:16px}.cabinet-modal-header{padding:24px 20px 16px}.cabinet-modal-title{font-size:24px}.cabinet-modal-body{padding:20px}.cabinet-modal-footer{flex-direction:column-reverse;padding:16px 20px}.cabinet-btn{width:100%}}.employee-modal-overlay{align-items:center;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);background:#0009;bottom:0;display:flex;justify-content:center;left:0;padding:20px;position:fixed;right:0;top:0;z-index:1000}.employee-modal-container{animation:slideDown .3s ease-out;background:#22252d;border:1px solid #ffffff1a;border-radius:16px;box-shadow:0 25px 50px #00000040;display:flex;flex-direction:column;max-height:90vh;max-width:800px;overflow:hidden;width:100%}.employee-modal-header{align-items:center;background:#22252d;border-bottom:1px solid #ffffff1a;display:flex;justify-content:space-between;padding:24px 32px}.employee-modal-title{color:#fff;font-size:20px;font-weight:600;margin:0}.employee-modal-close{background:none;border:none;border-radius:4px;color:#999;cursor:pointer;font-size:24px;padding:4px;transition:all .2s ease}.employee-modal-close:hover{background:#ffffff1a;color:#ccc}.employee-modal-form{display:flex;flex-direction:column;height:100%}.employee-modal-body{background:#22252d;flex:1 1;max-height:calc(90vh - 140px);overflow-y:auto;padding:24px 32px}.employee-alert-warning{align-items:flex-start;background:#ff98001a;border:1px solid #ff98004d;border-radius:8px;display:flex;gap:12px;margin-bottom:24px;padding:16px}.employee-alert-icon{flex-shrink:0;font-size:18px}.employee-alert-content{color:#e65100;font-size:14px;line-height:1.4}.dark .employee-alert-warning{background:#ff980026;border-color:#ff980066}.dark .employee-alert-content{color:#ffb74d}.employee-section{margin-bottom:32px}.employee-section:last-child{margin-bottom:0}.employee-section-title{border-bottom:2px solid #fff3;color:#fff;font-size:16px;font-weight:600;margin:0 0 16px;padding-bottom:8px}.employee-form-grid{grid-gap:16px;align-items:start;display:grid;gap:16px;grid-template-columns:repeat(auto-fit,minmax(250px,1fr))}.employee-form-field-full{grid-column:1/-1}.employee-form-field{display:flex;flex-direction:column;gap:6px}.employee-field-label{color:#d1d5db;font-size:14px;font-weight:500;margin:0}.employee-input,.employee-textarea{background:#18181a;border:1px solid #fff3;border-radius:8px;color:#fff;font-family:inherit;font-size:14px;padding:12px 16px;transition:all .2s ease}.employee-input:focus,.employee-textarea:focus{border-color:#3b82f6;box-shadow:0 0 0 3px #3b82f633;outline:none}.employee-input-error{border-color:#f87171!important;box-shadow:0 0 0 3px #f8717133!important}.employee-textarea{min-height:80px;resize:vertical}.employee-checkbox-label{align-items:center;color:#d1d5db;cursor:pointer;display:flex;font-size:14px;font-weight:500;gap:8px;margin-top:6px}.employee-checkbox{accent-color:#3b82f6;height:16px;width:16px}.employee-field-error{color:#ef4444;font-size:12px;margin-top:4px}.dark .employee-field-error{color:#f87171}.employee-field-help{color:#9ca3af;font-size:12px;font-style:italic;margin-top:4px}.employee-subtle-hint{color:#6b7280;display:block;font-size:11px;line-height:1.3;margin-top:4px;opacity:.85}.employee-organismes-help{background:#3b82f626;border:1px solid #3b82f64d;border-radius:6px;color:#93c5fd;font-size:13px;line-height:1.4;margin-top:16px;padding:12px}.employee-modal-footer{align-items:center;background:#22252d;border-top:1px solid #ffffff1a;display:flex;gap:12px;justify-content:flex-end;padding:20px 32px}.employee-btn{border:none;border-radius:8px;cursor:pointer;font-family:inherit;font-size:14px;font-weight:500;min-width:100px;padding:12px 24px;transition:all .2s ease}.employee-btn:disabled{cursor:not-allowed;opacity:.6}.employee-btn-cancel{background:#374151cc;border:1px solid #fff3;color:#d1d5db}.employee-btn-cancel:hover:not(:disabled){background:#374151;border-color:#ffffff4d}.employee-btn-primary{background:#1d4ed8;border:1px solid #1d4ed8;color:#fff}.employee-btn-primary:hover:not(:disabled){background:#1e40af;border-color:#1e40af}@media (max-width:768px){.employee-modal-overlay{padding:10px}.employee-modal-container{max-height:95vh;max-width:100%}.employee-modal-body,.employee-modal-footer,.employee-modal-header{padding-left:20px;padding-right:20px}.employee-form-grid{gap:12px;grid-template-columns:1fr}.employee-modal-footer{flex-direction:column-reverse;gap:8px}.employee-btn{width:100%}}.employee-modal-body::-webkit-scrollbar{width:6px}.employee-modal-body::-webkit-scrollbar-track{background:#0000001a;border-radius:3px}.employee-modal-body::-webkit-scrollbar-thumb{background:#0000004d;border-radius:3px}.employee-modal-body::-webkit-scrollbar-thumb:hover{background:#00000080}.dark .employee-modal-body::-webkit-scrollbar-track{background:#ffffff1a}.dark .employee-modal-body::-webkit-scrollbar-thumb{background:#ffffff4d}.dark .employee-modal-body::-webkit-scrollbar-thumb:hover{background:#ffffff80}.agenda-container{display:flex;min-height:100vh}.agenda-container,.agenda-content{background-color:#000;background-color:var(--color-black)}.agenda-content{flex:1 1;overflow-y:auto;padding:24px}.agenda-header{align-items:center;background:#1f2127;border:1px solid #2a2b32;border:1px solid var(--color-border);border-radius:16px;display:flex;justify-content:space-between;margin:0 0 20px;padding:16px 20px}.view-toggle{background:#18181a;background:var(--color-darker-gray);border:1px solid #2a2b32;border:1px solid var(--color-border);border-radius:10px;display:flex;gap:8px;padding:4px}.toggle-btn{background:#0000;border:none;border-radius:8px;color:#b0b8d0;color:var(--color-light-gray);cursor:pointer;font-size:14px;font-weight:600;padding:8px 16px;transition:all .2s ease}.toggle-btn.active,.toggle-btn:hover{color:#fff;color:var(--color-white)}.toggle-btn.active{background:#5fa8ff;background:var(--color-blue);box-shadow:0 2px 8px #5fa8ff4d}.header-right{gap:8px}.header-right,.nav-btn{align-items:center;display:flex}.nav-btn{background:linear-gradient(135deg,#1e2029,#16171f);border:1px solid #5fa8ff33;border-radius:10px;color:#b0b8d0;color:var(--color-light-gray);cursor:pointer;font-size:18px;font-weight:700;height:40px;justify-content:center;transition:all .3s cubic-bezier(.4,0,.2,1);width:40px}.nav-btn:hover{background:linear-gradient(135deg,#272a33,#1e2029);border-color:#5fa8ff;border-color:var(--color-blue);box-shadow:0 6px 20px #5fa8ff40;color:#5fa8ff;color:var(--color-blue);transform:translateY(-2px)}.nav-btn:active{transform:translateY(0)}.today-btn{background:linear-gradient(135deg,#5fa8ff,#318cff);background:linear-gradient(135deg,var(--color-blue) 0,var(--color-blue-2) 100%);border:none;border-radius:10px;box-shadow:0 4px 12px #5fa8ff4d;color:#fff;color:var(--color-white);cursor:pointer;font-size:14px;font-weight:700;padding:10px 20px;transition:all .2s ease}.today-btn:hover{box-shadow:0 6px 16px #5fa8ff66;transform:translateY(-2px)}.period-title{color:#fff;color:var(--color-white);font-size:18px;font-weight:700;margin-bottom:20px;text-align:center}.filters-bar{background:#22252d;background:var(--color-dark-gray);border:1px solid #2a2b32;border:1px solid var(--color-border);border-radius:14px;display:flex;flex-direction:column;gap:16px;margin-bottom:20px;padding:16px}.filter-group{align-items:center;display:flex;flex-wrap:wrap;gap:12px}.filter-label{color:#b0b8d0;color:var(--color-light-gray);font-size:14px;font-weight:600;min-width:100px}.op-chips{display:flex;flex:1 1;flex-wrap:wrap;gap:8px}.chip{background:#2b2e37;border:1px solid #2a2b32;border:1px solid var(--color-border);border-radius:999px;color:#e6ecff;cursor:pointer;font-size:13px;font-weight:600;padding:8px 14px;transition:all .2s ease}.chip:hover{background:#32353f;transform:translateY(-1px)}.chip.active{background:#5fa8ff26;border-color:#5fa8ff;border-color:var(--color-blue);box-shadow:0 0 0 2px #5fa8ff1a;color:#5fa8ff;color:var(--color-blue)}.checkbox-label{align-items:center;color:#b0b8d0;color:var(--color-light-gray);display:flex;font-size:14px;gap:8px}.checkbox-label input[type=checkbox]{accent-color:#5fa8ff;accent-color:var(--color-blue);cursor:pointer;height:18px;width:18px}.agenda-grid{background:#22252d;background:var(--color-dark-gray);border:1px solid #2a2b32;border:1px solid var(--color-border);border-radius:14px;overflow:hidden;position:relative}.agenda-grid.agenda-loading:before{animation:shimmer 1.5s infinite;background:linear-gradient(90deg,#0000,#5fa8ff33 50%,#0000);content:"";height:100%;left:-100%;pointer-events:none;position:absolute;top:0;width:100%;z-index:999}@keyframes shimmer{0%{left:-100%}to{left:100%}}.grid-header{background:#18181a;background:var(--color-darker-gray);border-bottom:1px solid #2a2b32;border-bottom:1px solid var(--color-border);display:grid;grid-template-columns:200px repeat(auto-fit,minmax(120px,1fr))}.corner-cell{padding:16px}.corner-cell,.day-header{border-right:1px solid #2a2b32;border-right:1px solid var(--color-border)}.day-header{padding:12px 8px;text-align:center}.day-header:last-child{border-right:none}.day-name{color:#5fa8ff;color:var(--color-blue);font-size:12px;font-weight:700;letter-spacing:.5px;margin-bottom:4px;text-transform:uppercase}.day-num{color:#fff;color:var(--color-white);font-size:18px;font-weight:700}.grid-row{border-bottom:1px solid #2a2b32;border-bottom:1px solid var(--color-border);display:grid;grid-template-columns:200px repeat(auto-fit,minmax(120px,1fr));transition:background-color .2s ease}.grid-row:hover{background:#5fa8ff0d}.grid-row:last-child{border-bottom:none}.op-label{align-items:center;background:#0003;border-left:3px solid #5fa8ff;border-left:3px solid var(--color-blue);color:#fff;color:var(--color-white);font-size:14px;font-weight:600;padding:16px}.agenda-cell,.op-label{border-right:1px solid #2a2b32;border-right:1px solid var(--color-border);display:flex}.agenda-cell{cursor:pointer;flex-direction:column;justify-content:center;min-height:80px;padding:12px 8px;transition:all .2s ease}.agenda-cell:hover{background:#5fa8ff1a;border-color:#5fa8ff;border-color:var(--color-blue)}.agenda-cell:last-child{border-right:none}.cell-empty{color:#b0b8d0;color:var(--color-light-gray);font-size:18px;opacity:.5;text-align:center}.cell-shifts{display:flex;flex-direction:column;gap:6px}.shift-tag{border-radius:6px;font-size:12px;font-weight:600;overflow:hidden;padding:6px 10px;text-align:center;text-overflow:ellipsis;transition:all .2s ease;white-space:nowrap}.shift-recurring{background:linear-gradient(135deg,#5fa8ff33,#5fa8ff1a);border:1px solid #5fa8ff4d;color:#5fa8ff;color:var(--color-blue)}.shift-recurring:hover{background:linear-gradient(135deg,#5fa8ff4d,#5fa8ff33);border-color:#5fa8ff;border-color:var(--color-blue)}.shift-exception{background:linear-gradient(135deg,#2ed57333,#2ed5731a);border:1px solid #2ed5734d;color:#2ed573;color:var(--color-green)}.shift-exception:hover{background:linear-gradient(135deg,#2ed5734d,#2ed57333);border-color:#2ed573;border-color:var(--color-green)}.shift-off{background:linear-gradient(135deg,#ff475726,#ff47570d);border:1px solid #ff47574d;color:#ff4757;color:var(--color-red);opacity:.7}.shift-off:hover{background:linear-gradient(135deg,#ff475733,#ff47571a);border-color:#ff4757;border-color:var(--color-red)}.shift-school{background:linear-gradient(135deg,#ff69b440,#ffb6c126);border:1px solid #ff69b466;color:#ff69b4;cursor:pointer;font-weight:600;transition:all .2s ease}.shift-school:hover{background:linear-gradient(135deg,#ff69b459,#ffb6c140);border-color:#ff69b4}.cell-school{cursor:pointer}.cell-off{background:#ff47570d}.cell-exception{background:#2ed5730d}.shift-overflow{background:linear-gradient(135deg,#ffa50233,#ffa5021a);border-color:#ffa5024d;color:#ffa502;color:var(--color-yellow);cursor:help}.shift-overflow:hover{background:linear-gradient(135deg,#ffa5024d,#ffa50233);border-color:#ffa502;border-color:var(--color-yellow)}.empty-state{color:#b0b8d0;color:var(--color-light-gray);font-size:16px;padding:60px 20px;text-align:center}.popup-overlay{align-items:center;animation:fadeIn .2s ease;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);background:#000000bf;bottom:0;display:flex;justify-content:center;left:0;position:fixed;right:0;top:0;z-index:3000}.popup-content{animation:popIn .4s cubic-bezier(.68,-.55,.265,1.55);background:linear-gradient(135deg,#22252d,#1a1d26);background:linear-gradient(135deg,var(--color-dark-gray) 0,#1a1d26 100%);border:1px solid #2a2b32;border:1px solid var(--color-border);border-radius:16px;box-shadow:0 20px 60px #0009;max-width:440px;overflow:hidden;width:90%}@keyframes popIn{0%{opacity:0;transform:scale(.7) translateY(-40px) rotateX(15deg)}50%{transform:scale(1.02) translateY(0) rotateX(0)}to{opacity:1;transform:scale(1) translateY(0) rotateX(0)}}.popup-header{align-items:center;background:linear-gradient(135deg,#18181a,#0f1117);background:linear-gradient(135deg,var(--color-darker-gray) 0,#0f1117 100%);border-bottom:1px solid #2a2b32;border-bottom:1px solid var(--color-border);display:flex;justify-content:space-between;padding:16px 20px}.popup-header h3{color:#fff;color:var(--color-white);font-size:18px;font-weight:700;margin:0}.popup-close{align-items:center;background:#0000;border:none;border-radius:6px;color:#b0b8d0;color:var(--color-light-gray);cursor:pointer;display:flex;font-size:24px;height:32px;justify-content:center;transition:all .2s ease;width:32px}.popup-close:hover{background:#ffffff1a;color:#fff;color:var(--color-white)}.popup-body{padding:20px}.popup-info{background:#5fa8ff14;border:1px solid #5fa8ff33;border-radius:10px;margin-bottom:28px;padding:12px 14px}.info-alert{background:#ff69b426;border:1px solid #ff69b44d;border-radius:8px;color:#ff69b4;font-size:13px;line-height:1.5;margin-top:12px;padding:10px 12px}.info-alert strong{font-weight:700}.error-message{background:#ff475726;border:1px solid #ff47574d;border-radius:8px;color:#ff4757;color:var(--color-red);font-size:13px;font-weight:500;line-height:1.6;margin-bottom:20px;padding:12px 14px}.info-row{align-items:center;display:flex;justify-content:space-between;padding:6px 0}.info-row:not(:last-child){border-bottom:1px solid #ffffff0d}.info-label{color:#b0b8d0;color:var(--color-light-gray);font-size:12px;font-weight:600}.info-value{color:#fff;color:var(--color-white);font-size:14px;font-weight:600}.info-badge{border-radius:5px;font-size:12px;font-weight:700;padding:4px 10px}.badge-recurring{background:#5fa8ff33;border:1px solid #5fa8ff4d;color:#5fa8ff;color:var(--color-blue)}.badge-exception{background:#2ed57333;border:1px solid #2ed5734d;color:#2ed573;color:var(--color-green)}.badge-off{background:#ff475733;border:1px solid #ff47574d;color:#ff4757;color:var(--color-red)}.badge-school{background:#ff69b433;border:1px solid #ff69b44d;color:#ff69b4}.form-group{margin-bottom:28px}.form-group label{color:#b0b8d0;color:var(--color-light-gray);display:block;font-size:12px;font-weight:600;margin-bottom:6px}.section-label{color:#fff;color:var(--color-white);font-size:13px;font-weight:700;margin-bottom:16px}.form-row{grid-gap:20px;display:grid;gap:20px;grid-template-columns:1fr 1fr}.time-input{background:#18181a;background:var(--color-darker-gray);border:1px solid #2a2b32;border:1px solid var(--color-border);border-radius:8px;color:#fff;color:var(--color-white);font-size:15px;font-weight:600;padding:10px 14px;transition:all .2s ease;width:100%}.time-input:focus{border-color:#5fa8ff;border-color:var(--color-blue);box-shadow:0 0 0 3px #5fa8ff1a;outline:none}.time-input:disabled{cursor:not-allowed;opacity:.5}.checkbox-container{align-items:center;background:#18181a;background:var(--color-darker-gray);border:1px solid #2a2b32;border:1px solid var(--color-border);border-radius:8px;cursor:pointer;display:flex;gap:10px;padding:10px 12px;transition:all .2s ease}.checkbox-container:hover{background:#ffffff08;border-color:#5fa8ff;border-color:var(--color-blue)}.checkbox-container input[type=checkbox]{display:none}.checkbox-container:has(input:checked){background:#5fa8ff1f;border-color:#5fa8ff;border-color:var(--color-blue);box-shadow:0 0 0 3px #5fa8ff26}.checkbox-label{color:#fff;color:var(--color-white);cursor:pointer;font-size:13px;font-weight:600}.radio-group{grid-gap:10px;display:grid;gap:10px;grid-template-columns:1fr 1fr}.radio-container{align-items:center;background:#18181a;background:var(--color-darker-gray);border:2px solid #2a2b32;border:2px solid var(--color-border);border-radius:10px;cursor:pointer;display:flex;flex-direction:column;gap:8px;justify-content:center;padding:12px 10px;text-align:center;transition:all .2s ease}.radio-container:hover{background:#ffffff08;border-color:#5fa8ff4d;transform:translateY(-2px)}.radio-container:has(input:checked){background:#5fa8ff1f;border-color:#5fa8ff;border-color:var(--color-blue);box-shadow:0 0 0 3px #5fa8ff26}.radio-container input[type=radio]{display:none}.radio-content{display:flex;flex-direction:column;gap:4px}.radio-title{color:#fff;color:var(--color-white);font-size:14px;font-weight:700}.radio-desc{color:#b0b8d0;color:var(--color-light-gray);font-size:11px;line-height:1.3}.popup-actions{border-top:1px solid #2a2b32;border-top:1px solid var(--color-border);display:flex;gap:10px;margin-top:32px;padding-top:24px}.btn-cancel{background:#18181a;background:var(--color-darker-gray);border:1px solid #2a2b32;border:1px solid var(--color-border);border-radius:8px;color:#b0b8d0;color:var(--color-light-gray);cursor:pointer;flex:1 1;font-size:14px;font-weight:700;padding:12px 20px;transition:all .2s ease}.btn-cancel:hover{background:#22252d;background:var(--color-dark-gray);border-color:#fff3;transform:translateY(-1px)}.btn-cancel:hover,.btn-save{color:#fff;color:var(--color-white)}.btn-save{background:linear-gradient(135deg,#5fa8ff,#318cff);background:linear-gradient(135deg,var(--color-blue) 0,var(--color-blue-2) 100%);border:none;border-radius:8px;box-shadow:0 4px 16px #5fa8ff4d;cursor:pointer;flex:1 1;font-size:14px;font-weight:700;padding:12px 20px;transition:all .2s ease}.btn-save:hover{box-shadow:0 6px 20px #5fa8ff66;transform:translateY(-2px)}.btn-save:active{box-shadow:0 2px 8px #5fa8ff4d;transform:translateY(0)}.btn-save:disabled{cursor:not-allowed;opacity:.7;transform:none}.btn-save-content{align-items:center;display:flex;gap:8px;justify-content:center}.spinner{animation:spin .6s linear infinite;border:2px solid #ffffff4d;border-radius:50%;border-top-color:#fff;border-top:2px solid var(--color-white);height:16px;width:16px}.month-calendar{background:#22252d;background:var(--color-dark-gray);border-radius:12px;margin-top:20px;padding:16px}.month-header{grid-gap:8px;border-bottom:1px solid #2a2b32;border-bottom:1px solid var(--color-border);display:grid;gap:8px;grid-template-columns:repeat(7,1fr);margin-bottom:12px;padding-bottom:12px}.month-day-name{color:#b0b8d0;color:var(--color-light-gray);font-size:13px;font-weight:600;letter-spacing:.5px;text-align:center;text-transform:uppercase}.month-grid{grid-gap:8px;display:grid;gap:8px;grid-template-columns:repeat(7,1fr)}.month-cell{background:#18181a;background:var(--color-darker-gray);border:1px solid #2a2b32;border:1px solid var(--color-border);border-radius:8px;display:flex;flex-direction:column;min-height:120px;padding:8px;position:relative;transition:all .2s ease}.month-cell:hover{box-shadow:0 0 0 1px #5fa8ff;box-shadow:0 0 0 1px var(--color-blue)}.month-cell.today,.month-cell:hover{border-color:#5fa8ff;border-color:var(--color-blue)}.month-cell.today{background:#5fa8ff14}.month-cell.other-month{opacity:.4}.month-cell-date{color:#fff;color:var(--color-white);font-size:14px;font-weight:600;margin-bottom:8px}.month-cell.today .month-cell-date{color:#5fa8ff;color:var(--color-blue)}.month-cell-operators{display:flex;flex:1 1;flex-direction:column;gap:4px}.op-badge{-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border:1.5px solid;border-radius:6px;cursor:pointer;font-size:11px;font-weight:600;padding:6px 8px;position:relative;text-align:center;transition:all .2s ease}.op-badge:hover{box-shadow:0 4px 12px #0000004d;filter:brightness(1.2);transform:translateY(-2px)}.op-badge-recurring:before{content:"🔄";font-size:10px;margin-right:4px}.op-badge-exception:before{content:"⚡";font-size:10px;margin-right:4px}.op-badge-off{background-color:#ff475726!important;border-color:#ff4757!important;border-color:var(--color-red)!important;color:#ff4757!important;color:var(--color-red)!important;text-decoration:line-through}.op-badge-off:before{content:"🚫";font-size:10px;margin-right:4px}.op-badge-school{background-color:#ff69b433!important;border-color:#ff69b4!important;color:#ff69b4!important}.op-badge-school:before{content:"🎓";font-size:10px;margin-right:4px}@media (max-width:1200px){.grid-header,.grid-row{grid-template-columns:150px repeat(auto-fit,minmax(100px,1fr))}.op-label{font-size:13px;padding:12px}.month-cell{min-height:100px}.op-badge{font-size:10px;padding:4px 6px}}@media (max-width:768px){.sidebar{width:200px}.agenda-header{gap:16px}.agenda-header,.header-left{align-items:stretch;flex-direction:column}.header-left{gap:12px}.header-right{justify-content:center}.filters-bar{padding:12px}.filter-group{align-items:stretch;flex-direction:column}.filter-label{min-width:auto}.grid-header,.grid-row{grid-template-columns:120px repeat(auto-fit,minmax(80px,1fr))}.op-label{font-size:12px;padding:10px}.day-name{font-size:10px}.day-num{font-size:14px}.agenda-cell{min-height:60px;padding:8px 4px}.shift-tag{font-size:10px;padding:4px 6px}.month-cell{min-height:80px;padding:6px}.month-cell-date{font-size:12px}.op-badge{font-size:9px;padding:3px 4px}.month-day-name{font-size:11px}}.payroll-page{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;background:#f5f5f7;font-family:-apple-system,BlinkMacSystemFont,SF Pro Display,SF Pro Text,Segoe UI,sans-serif;min-height:100vh;padding:20px}.payroll-page-header{align-items:center;background:#fff;border:1px solid #0000000a;border-radius:14px;box-shadow:0 2px 16px #0000000f;display:flex;gap:20px;margin-bottom:20px;padding:16px 24px}.payroll-page-title{flex:1 1}.payroll-page-title h1{color:#1d1d1f;font-size:21px;font-weight:600;letter-spacing:-.3px;margin:0 0 2px}.payroll-page-subtitle{color:#86868b;font-size:14px;font-weight:400;margin:0}.payroll-page-actions{display:flex;gap:12px}.payroll-btn{border:none;border-radius:10px;cursor:pointer;font-size:14px;font-weight:500;letter-spacing:-.2px;padding:9px 20px;transition:all .2s cubic-bezier(.4,0,.2,1);white-space:nowrap}.payroll-btn-primary{background:#0071e3;box-shadow:0 1px 4px #0071e34d;color:#fff}.payroll-btn-primary:hover{background:#0077ed;box-shadow:0 3px 8px #0071e359;transform:translateY(-1px)}.payroll-btn-primary:active{transform:translateY(0)}.payroll-btn-secondary{background:#fff;border:1px solid #0000001a;color:#1d1d1f}.payroll-btn-secondary:hover{background:#f5f5f7;border-color:#00000026}.payroll-alert{animation:slideDown .3s cubic-bezier(.4,0,.2,1);background:#fff;border:1px solid #00000014;border-radius:12px;box-shadow:0 2px 12px #0000000a;display:flex;gap:14px;margin-bottom:20px;padding:16px 20px}.payroll-alert-warning{border-left:3px solid #ff9500}.payroll-alert-error{border-left:3px solid #ff3b30}.payroll-alert-icon{flex-shrink:0;font-size:18px}.payroll-alert-content strong{color:#1d1d1f;display:block;font-size:14px;font-weight:600;letter-spacing:-.2px;margin-bottom:4px}.payroll-alert-content p{color:#6e6e73;font-size:13px;line-height:1.4;margin:0}.payroll-layout{grid-gap:20px;align-items:start;display:grid;gap:20px;grid-template-columns:1fr 360px}.payroll-left-column{display:flex;flex-direction:column;gap:20px;margin-bottom:50px}.payroll-summary-card-left{padding:24px 32px}.payroll-sheet,.payroll-summary-card-left{background:#1d1d1f;border:1px solid #ffffff1a;border-radius:14px;box-shadow:0 4px 24px #0000004d;width:100%}.payroll-sheet{overflow:hidden;padding:32px 36px}.payroll-header{align-items:flex-start;border-bottom:1px solid #ffffff1a;display:flex;justify-content:space-between;margin-bottom:24px;padding-bottom:20px}.payroll-employer-info{flex:1 1}.payroll-employer-name{color:#fff;font-size:17px;font-weight:600;letter-spacing:-.4px;margin:0 0 12px}.payroll-employer-details{display:flex;flex-direction:column;gap:4px;margin-bottom:10px}.payroll-detail-line{color:#86868b;display:flex;font-size:11px;gap:8px;line-height:1.4}.payroll-label{color:#86868b;font-weight:500;min-width:120px}.payroll-value{color:#1d1d1f;font-weight:500}.payroll-employer-address{color:#86868b;font-size:11px;font-weight:400;line-height:1.5}.payroll-title-block{text-align:right}.payroll-document-title{color:#fff;font-size:28px;font-weight:700;letter-spacing:-.8px;margin:0}.payroll-employee-block{background:#f5f5f7;border-radius:10px;margin-bottom:16px;padding:16px 18px}.payroll-employee-row{grid-gap:12px;display:grid;gap:12px;grid-template-columns:1fr 1fr}.payroll-employee-col{display:flex;flex-direction:column;gap:4px}.payroll-apprentice-badge{background:#ff9500;border-radius:6px;color:#fff;display:inline-block;font-size:9px;font-weight:600;letter-spacing:.3px;margin-left:8px;padding:2px 8px;text-transform:uppercase;vertical-align:middle}.payroll-period-block{background:#f5f5f7;border-left:3px solid #0071e3;border-radius:10px;margin-bottom:16px;padding:12px 18px}.payroll-period-info{display:flex;flex-wrap:wrap;gap:28px}.payroll-period-item{align-items:baseline;display:flex;font-size:12px;gap:8px}.payroll-period-item .payroll-label{color:#86868b;font-weight:500}.payroll-period-item .payroll-value{color:#1d1d1f;font-weight:600;letter-spacing:-.2px}.payroll-separator{background:#d2d2d7;height:1px;margin:16px 0}.payroll-table-container{margin:16px 0}.payroll-table{border-collapse:initial;border-spacing:0;font-size:10px;width:100%}.payroll-table thead th{background:#1d1d1f;border:none;color:#fff;font-size:9px;font-weight:600;letter-spacing:.5px;padding:8px 10px;text-align:left;text-transform:uppercase}.payroll-table thead th:first-child{border-top-left-radius:8px}.payroll-table thead th:last-child{border-top-right-radius:8px}.payroll-table tbody td{border-bottom:1px solid #f5f5f7;color:#1d1d1f;font-weight:400;padding:6px 10px}.payroll-table tbody tr:last-child td{border-bottom:none}.payroll-table tbody tr:nth-child(2n){background:#fafafa}.payroll-table-label{color:#1d1d1f;font-weight:500}.payroll-table-base,.payroll-table-rate{font-feature-settings:"tnum";color:#86868b;font-variant-numeric:tabular-nums;text-align:right}.payroll-table-employee,.payroll-table-employer{font-feature-settings:"tnum";font-variant-numeric:tabular-nums;font-weight:600;text-align:right}.payroll-table-employee{color:#ff3b30}.payroll-table-employer{color:#34c759}.payroll-totals-block{background:#f5f5f7;border-radius:10px;margin-top:16px;padding:18px 20px}.payroll-totals-grid{grid-gap:8px;display:grid;gap:8px;grid-template-columns:1fr 1fr}.payroll-total-line{display:flex;font-size:12px;justify-content:space-between;padding:6px 0}.payroll-total-label{color:#6e6e73;font-weight:500;letter-spacing:-.1px}.payroll-total-value{font-feature-settings:"tnum";color:#1d1d1f;font-variant-numeric:tabular-nums;font-weight:600;letter-spacing:-.2px}.payroll-total-negative{color:#ff3b30}.payroll-total-main{background:#0071e3;border-radius:10px;box-shadow:0 2px 8px #0071e340;color:#fff;grid-column:1/-1;margin:8px 0;padding:14px 18px}.payroll-total-main .payroll-total-label{color:#fff;font-size:15px;font-weight:600;letter-spacing:-.3px}.payroll-total-main .payroll-total-value{color:#fff;font-size:24px;font-weight:700;letter-spacing:-.5px}.payroll-total-separator{background:#d2d2d7;grid-column:1/-1;height:1px;margin:4px 0}.payroll-total-cost,.payroll-total-employer{color:#86868b;font-size:11px}.payroll-footer{border-top:1px solid #d2d2d7;margin-top:20px;padding-top:16px}.payroll-legal{color:#86868b;font-size:9px;font-weight:400;line-height:1.4;margin:0 0 6px}.payroll-legal-small{color:#a1a1a6;font-size:8px;margin:0}.payroll-right-column{min-height:calc(100vh - 40px);padding-bottom:20px;position:relative}.payroll-summary-title{color:#fff;font-size:17px;font-weight:600;letter-spacing:-.3px;margin:0 0 16px}.payroll-summary-grid{grid-gap:16px 24px;display:grid;gap:16px 24px;grid-template-columns:repeat(auto-fit,minmax(220px,1fr))}.payroll-summary-item{display:flex;flex-direction:column;gap:4px}.payroll-summary-label{color:#86868b;font-size:12px;font-weight:500;letter-spacing:.5px;text-transform:uppercase}.payroll-summary-value{color:#fff;font-size:20px;font-weight:600;letter-spacing:-.4px}.payroll-summary-value.negative{color:#ff3b30}.payroll-summary-value.highlight{color:#0071e3;font-size:24px}.payroll-summary-divider{background:#ffffff1a;grid-column:1/-1;height:1px;margin:8px 0}.payroll-right-panel{background:#1d1d1f;border:1px solid #ffffff1a;border-radius:14px;box-shadow:0 4px 24px #0000004d}.payroll-panel-sticky{margin-bottom:20px;max-height:calc(100vh - 300px);overflow-x:hidden;overflow-y:auto;padding:24px 24px 20px;position:-webkit-sticky;position:sticky;top:20px}.payroll-panel-title{color:#fff;font-size:19px;font-weight:600;letter-spacing:-.4px;margin:0 0 20px}.payroll-panel-section{margin-bottom:20px}.payroll-panel-subtitle{color:#fff;font-size:13px;font-weight:600;letter-spacing:-.2px;margin:0 0 12px}.payroll-panel-row{grid-gap:12px;display:grid;gap:12px;grid-template-columns:1fr 1fr}.payroll-panel-field{margin-bottom:12px}.payroll-panel-label{color:#86868b;display:block;font-size:12px;font-weight:500;letter-spacing:-.1px;margin-bottom:6px}.payroll-panel-hint{color:#a1a1a6;display:block;font-size:10px;font-weight:400;margin-top:4px}.payroll-panel-input{font-feature-settings:"tnum";background:#2c2c2e;border:1px solid #fff3;border-radius:8px;color:#fff;font-size:14px;font-variant-numeric:tabular-nums;padding:10px 12px;transition:all .2s cubic-bezier(.4,0,.2,1);width:100%}.payroll-panel-input:focus{border-color:#0071e3;box-shadow:0 0 0 4px #0071e333;outline:none}.payroll-panel-btn{border:none;border-radius:10px;cursor:pointer;font-size:14px;font-weight:600;letter-spacing:-.2px;padding:12px;transition:all .2s cubic-bezier(.4,0,.2,1);width:100%}.payroll-panel-btn-primary{background:#0071e3;box-shadow:0 2px 8px #0071e34d;color:#fff}.payroll-panel-btn-primary:hover{background:#0077ed;transform:translateY(-1px)}.payroll-panel-info{background:#f5f5f7;border-radius:8px;display:flex;font-size:11px;gap:10px;line-height:1.4;padding:12px}.payroll-panel-info-icon{color:#0071e3;flex-shrink:0;font-size:14px}.payroll-panel-info-text{color:#6e6e73;font-weight:400}.payroll-info-bubble{background:#e3f2fd;border-left:3px solid #2196f3;border-radius:6px;color:#1565c0;font-size:12px;font-weight:500;line-height:1.4;margin-top:10px;padding:10px 12px}.payroll-fixed-actions{align-items:center;bottom:30px;display:flex;flex-direction:column;gap:12px;pointer-events:auto;position:fixed;right:30px;z-index:9999}.payroll-recalc-btn,.payroll-validate-btn{align-items:center;border:none;border-radius:14px!important;cursor:pointer;display:flex;font-size:17px!important;font-weight:600!important;gap:10px;justify-content:center;padding:16px 40px!important;transition:all .3s cubic-bezier(.4,0,.2,1);white-space:nowrap}.payroll-recalc-btn{background:#0071e3;color:#fff}.payroll-validate-btn{background:#34c759;color:#fff}.payroll-recalc-btn:hover,.payroll-validate-btn:hover{transform:translateY(-1px)}.payroll-recalc-btn:hover{background:#0077ed}.payroll-validate-btn:hover{background:#30d158}.payroll-recalc-btn:active,.payroll-validate-btn:active{transform:translateY(0)}.payroll-error,.payroll-loading{align-items:center;background:#fff;border-radius:14px;box-shadow:0 4px 24px #00000014;display:flex;flex-direction:column;justify-content:center;min-height:400px;padding:40px}.payroll-spinner{animation:spin .8s linear infinite;border:3px solid #f5f5f7;border-radius:50%;border-top-color:#0071e3;height:40px;width:40px}@keyframes slideDown{0%{opacity:0;transform:translateY(-10px)}to{opacity:1;transform:translateY(0)}}@media print{*{-webkit-print-color-adjust:exact;print-color-adjust:exact}body{background:#fff!important}.payroll-page{background:#fff;padding:0}.no-print{display:none!important}.payroll-layout{display:block}.payroll-left-column{border:none;border-radius:0;box-shadow:none}.payroll-sheet{max-width:100%;padding:0}.payroll-header{margin-bottom:12px;padding-bottom:10px}.payroll-employer-name{font-size:14px;margin-bottom:8px}.payroll-document-title{font-size:22px}.payroll-detail-line,.payroll-employer-address{font-size:9px}.payroll-employee-block{margin-bottom:10px;padding:10px 12px;page-break-inside:avoid}.payroll-period-block{margin-bottom:10px;padding:8px 12px;page-break-inside:avoid}.payroll-period-item{font-size:10px}.payroll-table-container{margin:10px 0}.payroll-table{font-size:8.5px}.payroll-table thead th{font-size:8px;padding:5px 7px}.payroll-table tbody td{padding:4px 7px}.payroll-totals-block{margin-top:10px;padding:12px 14px;page-break-inside:avoid}.payroll-totals-grid{gap:4px}.payroll-total-line{font-size:10px;padding:4px 0}.payroll-total-main{margin:6px 0;padding:10px 12px}.payroll-total-main .payroll-total-label{font-size:12px}.payroll-total-main .payroll-total-value{font-size:18px}.payroll-footer{margin-top:10px;padding-top:10px}.payroll-legal{font-size:7px;margin-bottom:4px}.payroll-legal-small{font-size:6.5px}.payroll-separator{margin:8px 0}.payroll-apprentice-badge{font-size:8px;padding:1px 6px}@page{size:A4 portrait;margin:15mm 12mm}}@media (max-width:1200px){.payroll-layout{grid-template-columns:1fr}.payroll-right-column{order:-1}.payroll-panel-sticky{max-height:none;position:relative;top:0}}@media (max-width:768px){.payroll-page{padding:12px}.payroll-page-header{align-items:stretch;flex-direction:column;padding:16px}.payroll-sheet{padding:20px}.payroll-header{flex-direction:column}.payroll-title-block{margin-top:12px;text-align:left}.payroll-employee-row,.payroll-panel-row,.payroll-totals-grid{grid-template-columns:1fr}.payroll-period-info{flex-direction:column;gap:6px}}@media screen and (prefers-color-scheme:dark){.payroll-page{background:#000}.payroll-left-column,.payroll-page-header,.payroll-right-panel{background:#1c1c1e;border-color:#ffffff14}.payroll-document-title,.payroll-employer-name,.payroll-page-title h1,.payroll-table-label,.payroll-total-value,.payroll-value{color:#f5f5f7}.payroll-employer-address,.payroll-label,.payroll-page-subtitle,.payroll-panel-label,.payroll-total-label{color:#98989d}.payroll-employee-block,.payroll-panel-info,.payroll-period-block,.payroll-totals-block{background:#2c2c2e}.payroll-period-block{border-left-color:#0a84ff}.payroll-table thead th{background:#2c2c2e}.payroll-table tbody td{border-bottom-color:#2c2c2e;color:#f5f5f7}.payroll-table tbody tr:nth-child(2n){background:#1c1c1e}.payroll-separator{background:#3a3a3c}.payroll-total-main{background:#0a84ff}.payroll-panel-input{background:#2c2c2e;border-color:#3a3a3c;color:#f5f5f7}.payroll-panel-input:focus{border-color:#0a84ff}.payroll-btn-secondary{background:#2c2c2e;border-color:#3a3a3c;color:#f5f5f7}.payroll-btn-secondary:hover{background:#3a3a3c}.payroll-alert{background:#1c1c1e;border-color:#ffffff14}.payroll-alert-content strong{color:#f5f5f7}.payroll-alert-content p{color:#98989d}}:root{--color-black:#000;--color-dark-gray:#22252d;--color-darker-gray:#18181a;--color-white:#fff;--color-blue:#5fa8ff;--color-blue-2:#318cff;--color-orange:#ff6b35;--color-red:#ff4757;--color-green:#2ed573;--color-yellow:#ffa502;--color-light-gray:#b0b8d0;--color-border:#2a2b32}*{box-sizing:border-box;margin:0;padding:0}body{color:#fff;color:var(--color-white);font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif}.orders-container,body{background-color:#000;background-color:var(--color-black)}.orders-container{display:flex;min-height:100vh}.sidebar{background-color:#18181a;background-color:var(--color-darker-gray);border-right:1px solid #2a2b32;border-right:1px solid var(--color-border);display:flex;flex-direction:column;padding:24px 0;width:250px}.logo{color:#5fa8ff;color:var(--color-blue);font-size:24px;font-weight:700;margin-bottom:40px;padding:0 24px;text-align:center}.nav-menu{display:flex;flex-direction:column;gap:8px;padding:0 16px}.nav-item{align-items:center;border-radius:8px;color:#b0b8d0;color:var(--color-light-gray);cursor:pointer;display:flex;font-size:14px;font-weight:600;gap:12px;padding:12px 16px;transition:all .2s ease}.nav-item:hover{background-color:#22252d;background-color:var(--color-dark-gray)}.nav-item.active,.nav-item:hover{color:#fff;color:var(--color-white)}.nav-item.active{background-color:#5fa8ff;background-color:var(--color-blue)}.nav-icon{font-size:18px}.orders-content{background-color:#000;background-color:var(--color-black);flex:1 1;overflow-y:auto;padding:24px}.orders-header{background:#1f2127;border:1px solid #2a2b32;border:1px solid var(--color-border);border-radius:16px;justify-content:space-between;margin:0 0 20px;padding:16px 20px}.header-left,.orders-header{align-items:center;display:flex}.header-left{gap:20px}.header-left h1{font-size:24px;font-weight:800;margin:0}.header-left h1,.new-order-btn{color:#fff;color:var(--color-white)}.new-order-btn{align-items:center;background:linear-gradient(135deg,#5fa8ff,#318cff);background:linear-gradient(135deg,var(--color-blue),var(--color-blue-2));border:none;border-radius:10px;box-shadow:0 4px 12px #5fa8ff4d;cursor:pointer;display:inline-flex;font-size:14px;font-weight:700;gap:8px;padding:10px 20px;transition:all .2s ease}.new-order-btn:hover{box-shadow:0 6px 16px #5fa8ff66;transform:translateY(-2px)}.new-order-btn span{font-size:18px;font-weight:700}.header-right-buttons{align-items:center;display:flex;gap:12px}.upload-invoice-btn{align-items:center;background:#0000;border:1px solid #5fa8ff;border:1px solid var(--color-blue);border-radius:10px;color:#5fa8ff;color:var(--color-blue);cursor:pointer;display:inline-flex;font-size:14px;font-weight:700;gap:8px;padding:10px 20px;transition:all .2s ease}.upload-invoice-btn:hover{background:#5fa8ff;background:var(--color-blue);color:#fff;color:var(--color-white)}.budget-chart-card{background:#22252d;background:var(--color-dark-gray);border:1px solid #2a2b32;border:1px solid var(--color-border);border-radius:14px;margin-bottom:20px;padding:20px}.chart-header{align-items:center;display:flex;justify-content:space-between;margin-bottom:20px}.chart-header h2{color:#fff;color:var(--color-white);font-size:18px;font-weight:700;margin:0}.chart-container{background:#18181a;background:var(--color-darker-gray);border:1px solid #2a2b32;border:1px solid var(--color-border);border-radius:12px;min-height:400px;padding:20px;position:relative}.chart-container,.chart-empty-state{align-items:center;display:flex;justify-content:center}.chart-empty-state{flex-direction:column;gap:20px;padding:60px 20px;text-align:center}.empty-state-icon{font-size:64px;margin-bottom:16px;opacity:.5}.empty-state-icon,.empty-state-text{color:#b0b8d0;color:var(--color-light-gray)}.empty-state-text{font-size:18px;font-weight:600;margin-bottom:8px}.empty-state-subtext{color:#b0b8d0;color:var(--color-light-gray);font-size:14px;margin-bottom:24px;opacity:.7}.drop-zone{align-items:center;background:#5fa8ff0d;border:2px dashed #2a2b32;border:2px dashed var(--color-border);border-radius:12px;bottom:0;cursor:pointer;display:flex;justify-content:center;left:0;position:absolute;right:0;top:0;transition:all .3s ease;z-index:10}.drop-zone.overlay{pointer-events:auto;z-index:20}.drop-zone:hover{background:#5fa8ff1a}.drop-zone.active,.drop-zone:hover{border-color:#5fa8ff;border-color:var(--color-blue)}.drop-zone.active{background:#5fa8ff40;border-width:3px;opacity:1!important;pointer-events:auto!important;z-index:30}.drop-zone-content{align-items:center;display:flex;flex-direction:column;gap:16px;padding:40px}.drop-zone-icon{color:#5fa8ff;color:var(--color-blue);font-size:48px}.drop-zone-text{color:#fff;color:var(--color-white);font-size:16px;font-weight:600}.drop-zone-subtext{color:#b0b8d0;color:var(--color-light-gray);font-size:14px}.file-input{display:none}.upload-btn{background:linear-gradient(135deg,#5fa8ff,#318cff);background:linear-gradient(135deg,var(--color-blue),var(--color-blue-2));border:none;border-radius:8px;box-shadow:0 4px 12px #5fa8ff4d;color:#fff;color:var(--color-white);cursor:pointer;font-size:14px;font-weight:600;padding:12px 24px;transition:all .2s ease}.upload-btn:hover{box-shadow:0 6px 16px #5fa8ff66;transform:translateY(-2px)}.upload-btn:disabled{cursor:not-allowed;opacity:.5;transform:none}.chart-displayed{height:100%;position:relative;width:100%;z-index:1}.orders-list-section{background:#22252d;background:var(--color-dark-gray);border:1px solid #2a2b32;border:1px solid var(--color-border);border-radius:14px;padding:20px}.orders-list-header{align-items:center;display:flex;justify-content:space-between;margin-bottom:20px}.orders-list-header h2{color:#fff;color:var(--color-white);font-size:18px;font-weight:700;margin:0}@media (max-width:768px){.sidebar{width:200px}.orders-header{gap:16px}.header-left,.orders-header{align-items:stretch;flex-direction:column}.header-left{gap:12px}}.loading-spinner{animation:spin 1s linear infinite;border:4px solid #2a2b32;border-top:4px solid #5fa8ff;border:4px solid var(--color-border);border-radius:50%;border-top-color:var(--color-blue);height:40px;width:40px}.toast{align-items:center;animation:slideIn .3s ease;background:linear-gradient(135deg,#2d3142,#1a1d2e);border:1px solid #2a2b32;border:1px solid var(--color-border);border-radius:12px;bottom:24px;box-shadow:0 8px 24px #0006;color:#fff;color:var(--color-white);display:flex;font-size:14px;font-weight:600;gap:10px;padding:12px 20px;position:fixed;right:24px;z-index:2000}.toast-success{background:linear-gradient(135deg,#1e3a2e,#152a20);border-color:#7de39266}.toast-error{background:linear-gradient(135deg,#3a1e1e,#2a1515);border-color:#ff475766}.toast-icon{font-size:18px;font-weight:700}.toast-success .toast-icon{color:#7de392}.toast-error .toast-icon{color:#ff4757;color:var(--color-red)}@keyframes slideIn{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.product-search-overlay{align-items:center;animation:fadeIn .3s ease;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);background:#000000d9;bottom:0;display:flex;justify-content:center;left:0;position:fixed;right:0;top:0;z-index:10000}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.product-search-modal{animation:slideUp .4s cubic-bezier(.68,-.55,.265,1.55);background:linear-gradient(135deg,#0f172a,#1e293b 50%,#0f172a);border:1px solid #94a3b833;border-radius:24px;box-shadow:0 25px 50px -12px #00000080;display:flex;flex-direction:column;max-height:90vh;max-width:1200px;overflow:hidden;width:90%}@keyframes slideUp{0%{opacity:0;transform:translateY(40px) scale(.9)}to{opacity:1;transform:translateY(0) scale(1)}}.product-search-header{align-items:center;background:#1e293b80;border-bottom:1px solid #94a3b833;display:flex;justify-content:space-between;padding:24px 32px}.product-search-title-group{align-items:center;display:flex;gap:16px}.product-search-logo{align-items:center;background:linear-gradient(135deg,#06b6d4,#3b82f6);border-radius:12px;box-shadow:0 4px 16px #06b6d44d;display:flex;height:48px;justify-content:center;width:48px}.product-search-title{-webkit-text-fill-color:#0000;background:linear-gradient(135deg,#fff,#cbd5e1);-webkit-background-clip:text;background-clip:text;font-size:24px;font-weight:700;margin:0}.product-search-subtitle{color:#94a3b8;font-size:14px;margin:0}.product-search-close{align-items:center;background:#94a3b81a;border:none;border-radius:8px;color:#cbd5e1;cursor:pointer;display:flex;font-size:20px;height:36px;justify-content:center;transition:all .2s ease;width:36px}.product-search-close:hover{background:#94a3b833;color:#fff}.product-search-box{background:#0f172a4d;border-bottom:1px solid #94a3b81a;padding:24px 32px}.product-search-input-wrapper{align-items:center;background:#ffffff1a;border:1px solid #94a3b833;border-radius:16px;display:flex;gap:12px;padding:16px 20px;position:relative;transition:all .3s ease}.product-search-input-wrapper:focus-within{border-color:#06b6d4;box-shadow:0 0 0 3px #06b6d41a}.product-search-icon{color:#06b6d4;flex-shrink:0;height:20px;width:20px}.product-search-input{background:#0000;border:none;color:#fff;flex:1 1;font-size:18px;font-weight:500;outline:none}.product-search-input::placeholder{color:#64748b}.product-search-clear{align-items:center;background:#0000;border:none;border-radius:6px;color:#64748b;cursor:pointer;display:flex;font-size:18px;height:28px;justify-content:center;padding:4px;transition:all .2s ease;width:28px}.product-search-clear:hover{background:#94a3b81a;color:#fff}.product-search-filters{display:flex;gap:12px;margin-top:16px}.product-search-filter-group{position:relative}.product-search-dropdown-btn{align-items:center;background:#ffffff1a;border:1px solid #94a3b833;border-radius:12px;box-sizing:border-box;color:#fff;cursor:pointer;display:flex;font-size:14px;font-weight:600;gap:8px;height:48px;min-width:200px;padding:12px 20px;transition:all .2s ease}.product-search-dropdown-btn:hover{background:#ffffff26;border-color:#06b6d4}.product-search-chevron{height:16px;transition:transform .3s ease;width:16px}.product-search-chevron.open{transform:rotate(180deg)}.product-search-dropdown-menu{animation:dropdownSlide .2s ease;background:#1e293bf2;border:1px solid #94a3b833;border-radius:12px;box-shadow:0 10px 30px #00000080;left:0;max-height:300px;overflow-y:auto;position:absolute;right:0;top:calc(100% + 8px);z-index:1000}@keyframes dropdownSlide{0%{opacity:0;transform:translateY(-10px)}to{opacity:1;transform:translateY(0)}}.product-search-dropdown-item{align-items:center;background:#0000;border:none;color:#cbd5e1;cursor:pointer;display:flex;font-size:14px;gap:8px;padding:12px 20px;text-align:left;transition:all .2s ease;width:100%}.product-search-dropdown-item:hover{background:#ffffff0d;color:#fff}.product-search-dropdown-item.active{background:linear-gradient(90deg,#06b6d433,#3b82f633);color:#fff;font-weight:600}.product-search-check{color:#06b6d4;font-weight:700}.product-search-main-content{display:flex;flex:1 1;gap:0;overflow:hidden}.product-search-results{flex:1 1;min-width:0;overflow-y:auto;padding:24px 32px}.product-search-list{display:flex;flex-direction:column;gap:16px;list-style:none;margin:0;padding:0}.product-search-item{background:#1e293b80;border:1px solid #94a3b833;border-radius:16px;cursor:pointer;padding:24px;position:relative;transition:all .2s ease}.product-search-item:hover{background:#1e293bcc;border-color:#06b6d4;box-shadow:0 8px 24px #06b6d433;transform:translateY(-2px)}.product-search-item.active{background:linear-gradient(135deg,#06b6d426,#3b82f626);border-color:#06b6d4;box-shadow:0 0 0 2px #06b6d44d}.product-search-item.cheapest{border-color:#22c55e;border-width:2px}.product-search-item.cheapest:hover{border-color:#22c55e}.product-search-badge-cheapest{background:linear-gradient(135deg,#22c55e,#16a34a);border-radius:999px;box-shadow:0 4px 12px #22c55e66;color:#fff;font-size:12px;font-weight:700;left:20px;padding:4px 16px;position:absolute;top:-12px;z-index:10}.product-search-item-content{display:flex;flex-direction:column}.product-search-item-header-flex{align-items:flex-start;display:flex;gap:12px;justify-content:space-between;margin-bottom:8px}.product-search-item-inner{padding:16px 24px}.product-search-item-header-left{flex:1 1}.product-search-item-header-right{align-items:center;display:flex;flex-shrink:0;gap:8px}.product-search-item-title{color:#fff;font-size:18px;font-weight:700;line-height:1.4;margin:0 0 8px;text-align:left}@media (min-width:1024px){.product-search-item-title{font-size:20px}}.product-search-item-meta{align-items:center;display:flex;flex-wrap:wrap;gap:8px}.product-search-item-brand{background:linear-gradient(135deg,#3b82f6,#2563eb);border-radius:999px;color:#fff;display:inline-block;font-size:12px;font-weight:600;padding:4px 12px}.product-search-item-category{color:#94a3b8;font-size:12px}.product-search-price-amount{color:#06b6d4;font-size:20px;font-weight:700}@media (min-width:1024px){.product-search-price-amount{font-size:24px}}.product-search-url-btn{align-items:center;background:linear-gradient(135deg,#06b6d4,#10b981);border-radius:8px;box-shadow:0 2px 8px #06b6d44d;color:#fff;cursor:pointer;display:inline-flex;flex-shrink:0;height:32px;justify-content:center;text-decoration:none;transition:all .2s ease;width:32px}.product-search-url-btn:hover{box-shadow:0 4px 12px #06b6d466;transform:scale(1.1)}.product-search-url-btn svg{height:16px;width:16px}.product-search-price-na{color:#64748b;font-size:14px;font-style:italic}.product-search-item-image{border:1px solid #94a3b833;border-radius:12px;height:120px;overflow:hidden;width:120px}.product-search-item-image img{height:100%;object-fit:cover;width:100%}.product-search-item-description{color:#cbd5e1;font-size:14px;line-height:1.6;margin:0}.product-search-separator{border-top:1px solid #94a3b833;margin:8px 0}.product-search-options-container{display:flex;flex-direction:column;gap:12px}.product-search-options-row{align-items:center;display:flex;flex-wrap:wrap;gap:8px}.product-search-options-label{color:#cbd5e1;font-size:13px;font-weight:700}.product-search-options-buttons{display:flex;flex-wrap:wrap;gap:8px}.product-search-option-btn{background:#ffffff0d;border:none;border-radius:8px;color:#cbd5e1;cursor:pointer;font-size:13px;font-weight:600;padding:6px 12px;transition:all .2s ease}.product-search-option-btn:hover{background:#ffffff1a;color:#fff}.product-search-option-btn.selected{background:#2563eb;box-shadow:0 2px 8px #2563eb4d;color:#fff}.product-search-variants-loading{color:#94a3b8;font-size:12px;font-style:italic;margin-top:12px}.product-search-add-to-cart-btn{background:linear-gradient(135deg,#06b6d4,#3b82f6);border:none;border-radius:12px;box-shadow:0 4px 12px #06b6d433;color:#fff;cursor:pointer;font-size:14px;font-weight:600;margin-top:16px;padding:12px 20px;transition:all .2s ease;width:100%}.product-search-add-to-cart-btn:hover{box-shadow:0 6px 20px #06b6d44d;transform:translateY(-2px)}.product-search-add-to-cart-btn:active{transform:translateY(0)}.highlight{background:#fbbf24;border-radius:4px;color:#1e293b;font-weight:700;padding:2px 4px}.product-search-loading{align-items:center;color:#94a3b8;display:flex;flex-direction:column;gap:10px;justify-content:center;padding:30px 20px}.product-search-spinner{animation:spin 1s linear infinite;border:2px solid #94a3b833;border-radius:50%;border-top-color:#06b6d4;height:20px;opacity:.6;width:20px}@keyframes spin{to{transform:rotate(1turn)}}.product-search-empty{align-items:center;color:#94a3b8;display:flex;flex-direction:column;justify-content:center;padding:60px 20px;text-align:center}.product-search-empty-icon{font-size:64px;margin-bottom:16px;opacity:.5}.product-search-cart-sidebar{background:#1e293bb3;border-left:1px solid #94a3b833;display:flex;flex-direction:column;min-width:380px;overflow:hidden;width:380px}.product-search-cart-sidebar-header{align-items:center;background:#0f172a80;border-bottom:1px solid #94a3b833;color:#fff;display:flex;font-size:18px;font-weight:700;gap:12px;padding:20px 24px}.product-search-cart-icon{font-size:24px}.product-search-cart-total{-webkit-text-fill-color:#0000;background:linear-gradient(135deg,#06b6d4,#3b82f6);-webkit-background-clip:text;background-clip:text;font-size:20px;font-weight:700;margin-left:auto}.product-search-cart-items{display:flex;flex:1 1;flex-direction:column;gap:12px;overflow-y:auto;padding:16px}.product-search-cart-item{background:#0f172a66;border:1px solid #94a3b833;border-radius:12px;display:flex;gap:12px;padding:16px;transition:all .2s ease}.product-search-cart-item:hover{background:#0f172a99;border-color:#06b6d4}.product-search-cart-item-info{display:flex;flex:1 1;flex-direction:column;gap:6px}.product-search-cart-item-title{color:#fff;font-size:14px;font-weight:600;line-height:1.4}.product-search-cart-item-variants{display:flex;flex-direction:column;gap:4px}.product-search-cart-item-variant{color:#94a3b8;font-size:12px;font-weight:500}.product-search-cart-item-price{color:#06b6d4;font-size:14px;font-weight:700;margin-top:4px}.product-search-cart-item-actions{align-items:flex-start;display:flex}.product-search-cart-item-remove{align-items:center;background:linear-gradient(135deg,#ef4444,#dc2626);border:none;border-radius:50%;color:#fff;cursor:pointer;display:flex;flex-shrink:0;font-size:18px;font-weight:700;height:28px;justify-content:center;transition:all .2s ease;width:28px}.product-search-cart-item-remove:hover{background:linear-gradient(135deg,#dc2626,#b91c1c);transform:scale(1.1)}.product-search-cart-sidebar-footer{background:#0f172a80;border-top:1px solid #94a3b833;display:flex;flex-direction:column;gap:16px;padding:20px 24px}.product-search-cart-sidebar-total{align-items:center;color:#fff;display:flex;font-size:18px;font-weight:700;justify-content:space-between}.product-search-cart-total-amount{-webkit-text-fill-color:#0000;background:linear-gradient(135deg,#06b6d4,#3b82f6);-webkit-background-clip:text;background-clip:text;font-size:24px}.product-search-cart-sidebar-btn{background:linear-gradient(135deg,#06b6d4,#3b82f6);border:none;border-radius:12px;box-shadow:0 4px 16px #06b6d44d;color:#fff;cursor:pointer;font-size:16px;font-weight:700;padding:16px;transition:all .2s ease;width:100%}.product-search-cart-sidebar-btn:hover{box-shadow:0 8px 24px #06b6d466;transform:translateY(-2px)}.product-search-cart-sidebar-btn:active{box-shadow:0 2px 4px #2563eb33;transform:translateY(0)}.product-search-email-form{background:#0f172ab3;border-radius:12px;display:flex;flex:1 1;flex-direction:column;margin-right:24px;min-height:600px;overflow:hidden;padding:24px}.product-search-email-form-header{align-items:center;border-bottom:1px solid #94a3b833;display:flex;justify-content:space-between;margin-bottom:24px;padding-bottom:16px}.product-search-email-form-header h3{color:#fff;font-size:20px;font-weight:700;margin:0}.product-search-email-form-close{align-items:center;background:#ef444433;border:none;border-radius:8px;color:#fff;cursor:pointer;display:flex;font-size:18px;font-weight:700;height:32px;justify-content:center;transition:all .2s ease;width:32px}.product-search-email-form-close:hover{background:#ef444466;transform:scale(1.1)}.product-search-email-form-loading{color:#cbd5e1;font-size:14px;padding:24px;text-align:center}.product-search-email-form-content{display:flex;flex:1 1;flex-direction:column;gap:10px;min-height:0;overflow:hidden}.product-search-email-form-field{display:flex;flex-direction:column;gap:4px}.product-search-email-form-field label{color:#cbd5e1;font-size:14px;font-weight:600}.product-search-email-form-input,.product-search-email-form-textarea{background:#1e293b80;border:1px solid #94a3b84d;border-radius:8px;color:#fff;font-family:inherit;font-size:14px;padding:12px 16px;transition:all .2s ease}.product-search-email-form-input:focus,.product-search-email-form-textarea:focus{border-color:#06b6d4;box-shadow:0 0 0 3px #06b6d41a;outline:none}.product-search-email-form-input-disabled{background:#1e293b4d;cursor:not-allowed;opacity:.6}.product-search-email-form-message{display:flex;flex:1 1;flex-direction:column;gap:8px;min-height:0;overflow:hidden}.product-search-email-form-message label{color:#cbd5e1;font-size:14px;font-weight:600}.product-search-email-form-textarea{flex:1 1;line-height:1.6;min-height:200px;overflow-y:auto;resize:none}.product-search-email-form-section{background:#1e293b4d;border:1px solid #94a3b833;border-radius:12px;display:flex;flex-direction:column;gap:16px;padding:20px}.product-search-email-form-section h4{border-bottom:1px solid #94a3b833;color:#fff;font-size:16px;font-weight:700;margin:0 0 8px;padding-bottom:8px}.product-search-email-form-row{grid-gap:10px;display:grid;gap:10px;grid-template-columns:1fr 1fr}.product-search-email-form-actions{border-top:1px solid #94a3b833;display:flex;gap:12px;justify-content:flex-end;margin-top:auto;padding-top:20px}.product-search-email-form-btn{border:none;border-radius:8px;cursor:pointer;font-size:14px;font-weight:600;padding:12px 24px;transition:all .2s ease}.product-search-email-form-btn-secondary{background:#94a3b833;color:#cbd5e1}.product-search-email-form-btn-secondary:hover{background:#94a3b84d;color:#fff}.product-search-email-form-btn-primary{background:linear-gradient(135deg,#06b6d4,#3b82f6);box-shadow:0 2px 8px #06b6d44d;color:#fff}.product-search-email-form-btn-primary:hover:not(:disabled){background:linear-gradient(135deg,#0891b2,#2563eb);box-shadow:0 4px 12px #06b6d466;transform:translateY(-1px)}.product-search-email-form-btn-primary:disabled{cursor:not-allowed;opacity:.5}.product-search-toast{background:linear-gradient(135deg,#2d3142,#1a1d2e);border:1px solid #94a3b833;border-left:4px solid #22c55e;border-radius:12px;bottom:32px;box-shadow:0 8px 24px #0006;color:#fff;font-size:14px;font-weight:600;opacity:0;padding:16px 24px;position:fixed;right:32px;transform:translateY(20px);transition:all .3s ease;z-index:20000}.product-search-toast.show{opacity:1;transform:translateY(0)}.product-search-results::-webkit-scrollbar{width:8px}.product-search-results::-webkit-scrollbar-track{background:#0f172a80}.product-search-results::-webkit-scrollbar-thumb{background:#94a3b84d;border-radius:4px}.product-search-results::-webkit-scrollbar-thumb:hover{background:#94a3b880}.product-search-subcategories-badges-container{align-items:center;display:flex;flex-direction:row;flex-wrap:nowrap;gap:8px;overflow-x:hidden}.product-search-subcategories-measure{align-items:center;display:flex;flex-direction:row;flex-wrap:nowrap;gap:8px;left:-9999px;max-width:calc(100vw - 600px);position:absolute;top:-9999px;visibility:hidden;width:100%}.product-search-subcategory-badge{align-items:center;background:#ffffff0d;border:1px solid #94a3b84d;border-radius:12px;box-sizing:border-box;color:#cbd5e1;cursor:pointer;display:flex;flex-shrink:0;font-size:13px;font-weight:600;height:48px;padding:12px 16px;transition:all .2s ease;white-space:nowrap}.product-search-subcategory-badge:hover{background:#ffffff1a;box-shadow:0 2px 8px #06b6d433;color:#fff}.product-search-subcategory-badge.selected{background:linear-gradient(135deg,#06b6d4,#3b82f6);border-color:#06b6d4;box-shadow:0 2px 8px #06b6d44d;color:#fff}.product-search-selections-container{display:flex;flex-direction:column;gap:8px;margin-top:12px}.product-search-selection-item{align-items:center;background:linear-gradient(135deg,#3b82f61a,#06b6d41a);border-radius:8px;border-top:1px solid #94a3b833;display:flex;justify-content:space-between;padding:8px 12px}.product-search-selection-info{align-items:center;display:flex;flex-wrap:wrap;gap:8px}.product-search-selection-color,.product-search-selection-label,.product-search-selection-size{color:#fff;font-size:12px;font-weight:700}.product-search-selection-controls{align-items:center;display:flex;gap:8px}.product-search-qty-btn{align-items:center;border:none;border-radius:50%;cursor:pointer;display:flex;flex-shrink:0;font-size:14px;font-weight:700;height:24px;justify-content:center;transition:all .2s ease;width:24px}.product-search-qty-btn-minus{background:linear-gradient(135deg,#3b82f6,#2563eb,#9333ea);color:#fff}.product-search-qty-btn-minus:hover:not(:disabled){background:linear-gradient(135deg,#2563eb,#1d4ed8,#7e22ce);transform:scale(1.1)}.product-search-qty-btn-minus:disabled{cursor:not-allowed;opacity:.5}.product-search-qty-btn-plus{background:linear-gradient(135deg,#06b6d4,#3b82f6,#2563eb);color:#fff}.product-search-qty-btn-plus:hover{background:linear-gradient(135deg,#0891b2,#2563eb,#1d4ed8);transform:scale(1.1)}.product-search-qty-btn-remove{background:linear-gradient(135deg,#ef4444,#dc2626);color:#fff}.product-search-qty-btn-remove:hover{background:linear-gradient(135deg,#dc2626,#b91c1c);transform:scale(1.1)}.product-search-qty-display{color:#2563eb;font-size:12px;font-weight:700;text-align:center;width:32px}@media (max-width:768px){.product-search-modal{max-height:95vh;width:95%}.product-search-box,.product-search-header,.product-search-results{padding:16px}.product-search-title{font-size:20px}.product-search-item-header{flex-direction:column}.product-search-item-price{text-align:left}}
/*# sourceMappingURL=main.fcb27b32.css.map*/