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)}}:root{--color-orange:#ff6b35;--color-green:#2ed573}*{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}.tasks-container,body{background-color:#000;background-color:var(--color-black)}.tasks-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;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}.nav-text{font-size:14px;font-weight:500}.main-content{background-color:#000;background-color:var(--color-black);flex:1 1;overflow-y:auto;padding:24px}.header{justify-content:space-between;margin-bottom:32px}.header,.header-left{align-items:center;display:flex}.header-left{gap:16px}.header-left h1{font-size:28px;font-weight:700}.header-left h1,.period-filter{color:#fff;color:var(--color-white)}.period-filter{background-color:#22252d;background-color:var(--color-dark-gray);border:1px solid #2a2b32;border:1px solid var(--color-border);border-radius:6px;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}.header-right,.new-task-btn{align-items:center;display:flex}.new-task-btn{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;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);border:1px solid #2a2b32;border:1px solid var(--color-border);border-radius:12px;display:flex;gap:20px;height:200px;margin-bottom:20px;padding: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{align-items:center;background-color:#5fa8ff;background-color:var(--color-blue);border-radius:50%;color:#fff;color:var(--color-white);display:flex;flex-shrink:0;font-size:18px;height:40px;justify-content:center;width:40px}.operator-info{display:flex;flex:1 1;flex-direction:column;gap:4px}.operator-name{color:#fff;color:var(--color-white);font-size:14px;font-weight:600}.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}.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}@keyframes spin{0%{transform:rotate(0deg)}to{transform:rotate(1turn)}}.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}:root{--color-black:#000;--color-dark-gray:#22252d;--color-darker-gray:#18181a;--color-white:#fff;--color-blue:#5fa8ff;--color-blue-2:#318cff;--color-red:#ff4757;--color-yellow:#ffa502;--color-light-gray:#b0b8d0;--color-border:#2a2b32}.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: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{align-items:center;color:#cbd3ea;display:flex;font-size:12px;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{overflow:hidden}.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;border-radius:999px;display:inline-flex;font-size:12px;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{border-radius:8px;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{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{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: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;padding:6px 10px;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;cursor:pointer;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;display:flex;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}
/*# sourceMappingURL=main.23b6ac3d.css.map*/