:root{font-family:system-ui,Avenir,Helvetica,Arial,sans-serif;line-height:1.5;font-weight:400;color-scheme:light;color:var(--color-text);background-color:var(--color-page-bg);font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;--color-page-bg: #f9fbf9;--color-card-bg: #ffffff;--color-sidebar-bg: #173622;--color-sidebar-text: #e8f3e8;--color-sidebar-active: #253f2e;--color-sidebar-accent: #77b34d;--color-primary: #2e6b44;--color-primary-hover: #3d8a58;--color-primary-text: #ffffff;--color-secondary: #cde4d1;--color-accent: #e4f0db;--color-muted-bg: #edf5ed;--color-muted-text: #5a7a61;--color-text: #163622;--color-border: #ccddd3;--color-focus: #2e6b44;--color-error: #cc3333;--color-success: #2e6b44;--color-warning: #d4a017;--color-chart-1: #2e6b44;--color-chart-2: #5c8a36;--color-chart-3: #7ab870;--color-chart-4: #3d7a60;--color-chart-5: #4d8080}a{font-weight:500;color:var(--color-primary);text-decoration:inherit}a:hover{color:var(--color-primary-hover)}body{margin:0;display:flex;place-items:center;min-width:320px;min-height:100vh;background-color:var(--color-page-bg);color:var(--color-text);overflow-x:hidden}h1{font-size:3.2em;line-height:1.1}button{border-radius:8px;border:1px solid var(--color-border);padding:.6em 1.2em;font-size:1em;font-weight:500;font-family:inherit;background-color:#fff;color:var(--color-text);cursor:pointer;transition:border-color .25s}button:hover{border-color:var(--color-primary)}button:focus,button:focus-visible{outline:4px auto var(--color-primary)}:root{--sidebar-width: 260px}*{box-sizing:border-box}.app{min-height:100vh;display:flex;flex-direction:row;overflow-x:hidden}.sidebar{width:var(--sidebar-width);min-height:100vh;background:var(--color-sidebar-bg);display:flex;flex-direction:column;border-right:1px solid var(--color-sidebar-active);position:fixed;left:0;top:0;bottom:0;transition:width .2s ease}.sidebar.collapsed{width:70px}.sidebar-header{display:flex;align-items:center;justify-content:space-between;padding:1rem;border-bottom:1px solid var(--color-sidebar-active);gap:.5rem}.sidebar-brand{padding:0;border-bottom:none;overflow:hidden;flex:1;min-width:0}.sidebar-brand a{font-size:1.2rem;font-weight:700;color:var(--color-sidebar-text);text-decoration:none;display:flex;align-items:center;gap:.5rem;white-space:nowrap}.sidebar-brand .brand-icon{font-size:1.4rem;flex-shrink:0}.sidebar-brand .brand-text{transition:opacity .2s ease}.sidebar.collapsed .sidebar-brand .brand-text{opacity:0;width:0;overflow:hidden}.sidebar-toggle{display:flex;flex-direction:column;justify-content:center;align-items:center;gap:4px;width:32px;height:32px;background:transparent;border:none;cursor:pointer;padding:6px;border-radius:6px;transition:background .2s;flex-shrink:0}.sidebar-toggle:hover{background:#2e6b444d}.sidebar-toggle .toggle-line{display:block;width:18px;height:2px;background:var(--color-sidebar-text);border-radius:1px;transition:background .2s}.sidebar-toggle:hover .toggle-line{background:#fff}.sidebar-nav{flex:1;list-style:none;margin:0;padding:1rem 0;overflow-y:auto}.sidebar-nav li{margin:.25rem .75rem}.sidebar.collapsed .sidebar-nav li{margin:.25rem .5rem}.sidebar-nav a{display:flex;align-items:center;gap:.75rem;color:var(--color-sidebar-text);text-decoration:none;padding:.75rem 1rem;border-radius:8px;transition:all .2s;font-size:.95rem;overflow:hidden}.sidebar.collapsed .sidebar-nav a{justify-content:center;padding:.75rem}.sidebar-nav a:hover{color:#fff;background:#77b34d26}.sidebar-nav a.active{color:#fff;background:var(--color-sidebar-active)}.sidebar-nav .nav-icon{font-size:1.1rem;width:24px;text-align:center;flex-shrink:0}.sidebar-nav .nav-label{flex:1;white-space:nowrap;transition:opacity .2s ease}.sidebar.collapsed .sidebar-nav .nav-label{opacity:0;width:0;overflow:hidden}.sidebar-user{padding:1rem;border-top:1px solid var(--color-sidebar-active);background:var(--color-sidebar-bg)}.sidebar.collapsed .sidebar-user{padding:.75rem .5rem}.sidebar-user .user-info{display:flex;flex-direction:column;gap:.25rem;margin-bottom:.75rem;overflow:hidden}.sidebar.collapsed .sidebar-user .user-info{display:none}.sidebar-user .user-name{color:var(--color-sidebar-text);font-weight:500;font-size:.95rem;white-space:nowrap}.sidebar-user .user-role{color:var(--color-sidebar-text);font-size:.8rem;background:var(--color-sidebar-active);padding:.2rem .5rem;border-radius:4px;width:fit-content}.sidebar-user .btn-logout{width:100%;background:transparent!important;border:1px solid #77b34d!important;color:var(--color-sidebar-text)!important;padding:.5rem!important;font-size:.85rem;border-radius:6px;cursor:pointer;transition:all .2s}.sidebar.collapsed .sidebar-user .btn-logout{padding:.5rem .25rem!important;font-size:.75rem}.sidebar-user .btn-logout:hover{background:var(--color-sidebar-active)!important;color:#fff!important}.main-content{flex:1;padding:2rem;margin-left:var(--sidebar-width);max-width:calc(100% - var(--sidebar-width));width:calc(100vw - var(--sidebar-width));overflow-x:hidden;transition:margin-left .2s ease,max-width .2s ease}.roster-view{padding-top:72px;padding-bottom:52px;overflow-x:hidden}.page-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:2rem;flex-wrap:wrap;gap:1rem}.page-header h1{margin:0}.loading{text-align:center;padding:3rem;color:var(--color-muted-text);font-size:1.2rem}.error-container{background:#fef2f2;border:1px solid var(--color-error);border-radius:8px;padding:2rem;text-align:center;color:var(--color-error)}.error-container h2{margin-top:0}.error-message{background:#fee2e2;border:1px solid var(--color-error);color:var(--color-error);padding:1rem;border-radius:4px;margin:1rem 0}.success-message{background:var(--color-accent);border:1px solid var(--color-primary);color:#fff;padding:1rem;border-radius:4px;margin:1rem 0}.dashboard-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1.5rem}.dashboard-header h1{margin:0}.dashboard .status-badge{font-size:.85rem;background:var(--color-muted-bg);padding:.5rem 1rem;border-radius:6px}.status-ok{color:var(--color-muted-text);font-weight:700}.status-error{color:var(--color-error);font-weight:700}.dashboard-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(300px,1fr));gap:1rem;margin-bottom:1.5rem}.dashboard-card{background:#fff;border-radius:8px;padding:1rem 1.25rem;border:1px solid var(--color-border)}.dashboard-card h3{margin:0 0 .75rem;font-size:.9rem;color:var(--color-muted-text);text-transform:uppercase;letter-spacing:.5px;display:flex;align-items:center;gap:.4rem}.dashboard-card.absences-card{min-width:200px}.no-absences{display:flex;align-items:center;gap:.5rem;color:var(--color-muted-text);font-size:.85rem;padding:.5rem 0}.no-absences svg{color:var(--color-primary)}.absences-list{display:flex;flex-direction:column;gap:.4rem;max-height:150px;overflow-y:auto}.absence-item-compact{display:flex;justify-content:space-between;align-items:center;gap:.5rem;padding:.35rem .5rem;background:var(--color-muted-bg);border-radius:4px;font-size:.8rem}.absence-employee{color:var(--color-text);font-weight:500}.absence-type-tag{padding:.15rem .4rem;border-radius:3px;font-size:.7rem;text-transform:uppercase;font-weight:600}.absence-type-tag.sick{background:#e76f51;color:var(--color-text)}.absence-type-tag.no_show{background:#9b2226;color:var(--color-text)}.absence-type-tag.late{background:#f4a261;color:var(--color-page-bg)}.absence-type-tag.left_early{background:#e9c46a;color:var(--color-page-bg)}.absence-type-tag.other{background:#6c757d;color:var(--color-text)}.absences-total{margin-top:.5rem;padding-top:.5rem;border-top:1px solid var(--color-border);font-size:.75rem;color:var(--color-muted-text);text-align:right}.mini-stats{display:flex;gap:1.5rem;flex-wrap:wrap}.mini-stat{display:flex;flex-direction:column;align-items:center}.mini-stat-value{font-size:1.5rem;font-weight:700;color:var(--color-text);line-height:1.2}.mini-stat-value.optimal{color:var(--color-primary)}.mini-stat-value.under{color:var(--color-error)}.mini-stat-value.over{color:#4d8080}.mini-stat-target{font-size:1rem;color:var(--color-muted-text);font-weight:400}.mini-stat-label{font-size:.75rem;color:var(--color-muted-text);text-transform:uppercase;margin-top:.25rem}.manning-table-section{background:#fff;border-radius:8px;padding:1rem;border:1px solid var(--color-border)}.manning-table-section h2{margin:0 0 1rem;font-size:1rem;color:var(--color-text)}.manning-table-container{max-height:400px;overflow-y:auto}.manning-table{width:100%;border-collapse:collapse;font-size:.9rem}.manning-table th{background:var(--color-muted-bg);padding:.6rem .75rem;text-align:left;font-size:.75rem;text-transform:uppercase;color:var(--color-muted-text);position:sticky;top:0;z-index:1}.manning-table th.center,.manning-table td.center{text-align:center}.manning-table td{padding:.5rem .75rem;border-bottom:1px solid var(--color-border)}.manning-table .area-name{font-weight:500;color:var(--color-text)}.manning-table .shift-name{color:var(--color-muted-text);font-size:.85rem}.manning-table .scheduled{font-weight:700;color:var(--color-text)}.manning-table .target,.manning-row.manning-optimal .scheduled{color:var(--color-muted-text)}.manning-row.manning-under .scheduled{color:var(--color-error)}.manning-row.manning-over .scheduled{color:#4d8080}.status-pill{display:inline-flex;align-items:center;gap:.25rem;padding:.2rem .5rem;border-radius:4px;font-size:.75rem;font-weight:600}.status-pill.optimal{background:var(--color-accent);color:var(--color-primary)}.status-pill.under{background:#fef2f2;color:var(--color-error)}.status-pill.over{background:#e8f4f4;color:#4d8080}.stats-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(150px,1fr));gap:1rem;margin-bottom:2rem}.stat-card{background:#fff;border-radius:8px;padding:1.5rem;text-align:center;border:1px solid var(--color-border)}.stat-card h3{margin:0 0 .5rem;font-size:.9rem;color:var(--color-muted-text);text-transform:uppercase}.stat-number{font-size:2rem;font-weight:700;color:var(--color-text);margin:0}.manning-section{margin-bottom:2rem}.manning-section h2{margin:0 0 1rem;font-size:1.25rem}.manning-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:1rem}.manning-card{background:#fff;border-radius:8px;padding:1.25rem;text-align:center;border:2px solid var(--color-border);transition:all .2s}.manning-card h3{margin:0 0 .75rem;font-size:1rem;color:var(--color-text)}.manning-numbers{font-size:1.75rem;font-weight:700;margin-bottom:.5rem}.manning-scheduled{color:var(--color-text)}.manning-separator{color:var(--color-muted-text);margin:0 .25rem}.manning-target{color:var(--color-muted-text)}.manning-status{font-size:.85rem;font-weight:500}.manning-card.manning-optimal{border-color:var(--color-primary);background:var(--color-accent)}.manning-card.manning-optimal .manning-status{color:var(--color-primary)}.manning-card.manning-under{border-color:var(--color-error);background:#fef2f2}.manning-card.manning-under .manning-status,.manning-card.manning-under .manning-scheduled{color:var(--color-error)}.manning-card.manning-over{border-color:#4d8080;background:#e8f4f4}.manning-card.manning-over .manning-status,.manning-card.manning-over .manning-scheduled{color:#4d8080}table,.data-table{width:100%;border-collapse:collapse;background:#fff;border-radius:8px;overflow:hidden}th,td{padding:1rem;text-align:left;border-bottom:1px solid var(--color-border)}th{background:var(--color-muted-bg);font-weight:600;text-transform:uppercase;font-size:.85rem;color:var(--color-muted-text)}tbody tr:hover{background:#2e6b441a}.badge{display:inline-block;padding:.25rem .75rem;border-radius:20px;font-size:.8rem;font-weight:500}.badge-fulltime{background:var(--color-secondary);color:var(--color-text)}.badge-parttime{background:#dde0f7;color:#363660}.badge-casual{background:#f5d5e5;color:#5a2a40}.status-active,.status-inactive{color:var(--color-muted-text)}.filter-buttons button,.view-toggle button{padding:.5rem 1rem;background:#fff;border:none;border-radius:4px;color:var(--color-muted-text);cursor:pointer;transition:all .2s}.filter-buttons button:hover,.view-toggle button:hover,.filter-buttons button.active,.view-toggle button.active{background:var(--color-primary);color:#fff}.controls-panel{background:#fff;border-radius:8px;padding:1.5rem;margin-bottom:2rem}.date-range{display:flex;gap:1rem;align-items:center;flex-wrap:wrap;margin-bottom:1.5rem;padding-bottom:1.5rem;border-bottom:1px solid var(--color-border)}.date-range label,.generate-form label{display:flex;align-items:center;gap:.5rem;color:var(--color-muted-text)}.date-range input,.generate-form input{padding:.5rem;background:var(--color-muted-bg);border:1px solid var(--color-border);border-radius:4px;color:var(--color-text)}.generate-controls h3{margin:0 0 1rem;font-size:1rem}.skill-targets-section{background:var(--color-muted-bg);border-radius:8px;padding:1rem 1.25rem;margin-bottom:1rem}.skill-targets-section h3{margin:0 0 .25rem;font-size:1rem;color:var(--color-text)}.skill-targets-desc{margin:0 0 .75rem;font-size:.8rem;color:var(--color-muted-text)}.skill-targets-list{display:flex;flex-wrap:wrap;gap:.5rem;margin-bottom:.75rem}.skill-target-item{display:flex;align-items:center;gap:.4rem;background:var(--color-muted-bg);border:1px solid var(--color-border);border-radius:6px;padding:.35rem .6rem;font-size:.85rem}.skill-target-label{font-weight:600;color:var(--color-text)}.skill-target-count{color:var(--color-muted-text);font-size:.8rem}.skill-target-remove{background:none;border:none;color:var(--color-muted-text);cursor:pointer;padding:0;display:flex;align-items:center;transition:color .15s}.skill-target-remove:hover{color:#e74c3c}.skill-target-add{display:flex;gap:.5rem;align-items:center}.skill-target-add select{padding:.4rem .6rem;border-radius:4px;border:1px solid var(--color-border);background:#fff;color:var(--color-text);font-size:.85rem}.skill-count-input{width:55px;padding:.4rem;text-align:center;border-radius:4px;border:1px solid var(--color-border);background:#fff;color:var(--color-text);font-size:.85rem}.skill-add-btn{padding:.4rem .8rem!important;font-size:.85rem!important}.generate-form{display:flex;gap:1rem;align-items:center;flex-wrap:wrap}.generate-form input[type=number]{width:80px}button{padding:.5rem 1rem;background:#fff;border:none;border-radius:4px;color:var(--color-text);cursor:pointer;transition:all .2s}button:hover:not(:disabled){background:var(--color-primary);color:#fff}button:disabled{opacity:.5;cursor:not-allowed}.btn-primary{background:var(--color-primary);color:#fff}.btn-primary:hover:not(:disabled){background:var(--color-primary-hover)}.generate-all-section{background:var(--color-muted-bg);border:1px solid var(--color-border);border-radius:8px;padding:1rem;margin-bottom:1rem}.generate-all-controls{display:flex;flex-wrap:wrap;gap:1rem;align-items:center}.generate-all-controls label{display:flex;align-items:center;gap:.5rem;font-size:.9rem;color:var(--color-text)}.generate-all-controls input[type=date],.generate-all-controls select{padding:.4rem .6rem;border-radius:4px;border:1px solid var(--color-border);background:var(--color-muted-bg);color:var(--color-text);font-size:.85rem}.btn-generate-all{display:flex;align-items:center;gap:.5rem;padding:.6rem 1.2rem;background:linear-gradient(135deg,var(--color-primary) 0%,#1f5233 100%);color:#fff;border:none;border-radius:6px;font-weight:600;font-size:.9rem;cursor:pointer;transition:all .2s ease;box-shadow:0 2px 4px #0000001a}.btn-generate-all:hover:not(:disabled){background:linear-gradient(135deg,var(--color-primary-hover) 0%,var(--color-primary) 100%);transform:translateY(-1px);box-shadow:0 4px 8px #00000026}.btn-generate-all:disabled{opacity:.6;cursor:not-allowed}.btn-publish-all{display:flex;align-items:center;gap:.5rem;padding:.6rem 1.2rem;background:linear-gradient(135deg,#2196f3,#1565c0);color:#fff;border:none;border-radius:6px;font-weight:600;font-size:.9rem;cursor:pointer;transition:all .2s ease;box-shadow:0 2px 4px #0003}.btn-publish-all:hover:not(:disabled){background:linear-gradient(135deg,#42a5f5,#2196f3);transform:translateY(-1px);box-shadow:0 4px 8px #0000004d}.btn-publish-all:disabled{opacity:.6;cursor:not-allowed}.generate-all-hint{margin:.75rem 0 0;font-size:.8rem;color:#9db4a0;font-style:italic}.areas-grid{display:flex;flex-direction:column;gap:1.25rem;margin-top:1rem}.areas-row{display:flex;gap:1.25rem}.areas-row .area-card{flex:1;min-width:0}@media(max-width:1200px){.areas-row{flex-wrap:wrap}.areas-row .area-card{flex:1 1 calc(50% - .625rem);min-width:200px}}@media(max-width:800px){.areas-grid,.areas-row{gap:1rem}.areas-row .area-card{flex:1 1 100%;min-width:0}}.area-card{position:relative;background:#fff;border:1px solid #e2e8e4;border-radius:8px;padding:1.5rem;cursor:pointer;transition:all .2s ease;display:flex;flex-direction:column;gap:1rem}.area-card:hover{border-color:var(--color-primary);box-shadow:0 2px 8px #2e6b441f;transform:translateY(-2px)}.area-card-name{font-weight:600;font-size:1.1rem;color:var(--color-text);line-height:1.3}.area-card-details{display:flex;justify-content:space-between;align-items:center;gap:.5rem}.area-start-time{font-size:.9rem;color:#7a8a7e;font-weight:500}.area-manning-badge{display:inline-flex;align-items:center;gap:.3rem;padding:.4rem .75rem;background:var(--color-muted-bg);color:var(--color-primary);border-radius:6px;font-weight:600;font-size:.9rem}.manning-edit-inline{display:flex;align-items:center;gap:.35rem;flex:1}.manning-edit-inline input{width:46px;padding:.15rem .3rem;font-size:.85rem;background:var(--color-muted-bg);border:1px solid var(--color-border);border-radius:3px;color:var(--color-text);text-align:center}.btn-save-small{background:var(--color-primary);border:none;color:#fff;padding:.2rem .4rem;border-radius:3px;cursor:pointer;display:flex;align-items:center}.btn-save-small:hover{background:var(--color-primary-hover)}.btn-cancel-small{background:transparent;border:1px solid #a05a5a;color:var(--color-error);padding:.2rem .4rem;border-radius:3px;cursor:pointer;font-size:.8rem}.btn-cancel-small:hover{background:#c333}.roster-header{display:flex;align-items:center;gap:1rem;margin-bottom:1.5rem;flex-wrap:wrap}.roster-sticky-header{position:fixed;top:0;left:var(--sidebar-width);right:0;background:#fff;border-bottom:1px solid var(--color-border);z-index:100;box-shadow:0 1px 6px #00000012}.rh-bar{display:flex;align-items:center;justify-content:space-between;gap:.75rem;padding:0 1rem;height:56px}.rh-section{display:flex;align-items:center;gap:.5rem;min-width:0}.rh-left{flex:0 0 auto;gap:.5rem}.rh-center{flex:1;justify-content:center;gap:.5rem}.rh-right{flex:0 0 auto;gap:.4rem}.rh-back-btn{display:flex;align-items:center;justify-content:center;width:32px;height:32px;border-radius:7px;border:1px solid var(--color-border);background:#fff;color:var(--color-text);cursor:pointer;transition:background .15s,border-color .15s;flex-shrink:0}.rh-back-btn:hover{background:var(--color-muted-bg);border-color:var(--color-primary)}.rh-area-pill{display:flex;align-items:center;gap:8px;padding:7px 14px 7px 12px;background:#f0f4f1;border:1.5px solid rgba(46,107,68,.25);border-radius:24px;cursor:pointer;font-size:1.3rem;font-weight:600;color:var(--color-primary);white-space:nowrap;transition:background .15s,border-color .15s,box-shadow .15s}.rh-area-pill:hover{background:#e6efe9;border-color:var(--color-primary)}.rh-area-pill.open{background:#e6efe9;border-color:var(--color-primary);box-shadow:0 0 0 3px #2e6b441f}.rh-area-dot{width:10px;height:10px;border-radius:50%;background:#22c55e;flex-shrink:0}.rh-nav-btn{display:flex;align-items:center;justify-content:center;width:28px;height:28px;border-radius:6px;border:1px solid #ccddd3;background:#fff;color:#374151;cursor:pointer;transition:background .12s;flex-shrink:0}.rh-nav-btn:hover{background:#edf5ed;color:#374151}.rh-nav-btn svg{display:block;stroke:currentColor}.rh-week-display{display:flex;flex-direction:column;align-items:center;min-width:180px}.rh-week-range{font-size:.88rem;font-weight:600;color:var(--color-text);white-space:nowrap}.rh-fy-label{font-size:.7rem;color:var(--color-muted-text);white-space:nowrap}.rh-today-btn{padding:4px 10px;border-radius:6px;border:1px solid var(--color-border);background:#fff;font-size:.82rem;font-weight:600;color:var(--color-text);cursor:pointer;transition:background .12s;white-space:nowrap}.rh-today-btn:hover{background:var(--color-muted-bg)}.rh-period-select{appearance:none;-webkit-appearance:none;padding:5px 28px 5px 12px;border:1.5px solid rgba(46,107,68,.25);border-radius:20px;background:#f0f4f1;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='13' height='13' viewBox='0 0 24 24' fill='none' stroke='%232e6b44' stroke-width='2.5' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpolyline points='6 9 12 15 18 9'%3E%3C/polyline%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 9px center;font-size:.85rem;font-weight:600;color:var(--color-primary);cursor:pointer;transition:background-color .15s,border-color .15s}.rh-period-select:hover{background-color:#e6efe9;border-color:var(--color-primary)}.rh-period-select:focus{outline:none;border-color:var(--color-primary);box-shadow:0 0 0 3px #2e6b441f}.rh-icon-btn{display:flex;align-items:center;gap:3px;padding:5px 8px;border-radius:7px;border:1px solid var(--color-border);background:#fff;color:var(--color-muted-text);cursor:pointer;transition:background .12s,color .12s;font-size:.8rem}.rh-icon-btn:hover{background:var(--color-muted-bg);color:var(--color-text)}.rh-options-btn{gap:2px}.rh-auto-btn{display:flex;align-items:center;gap:5px;padding:5px 12px;border-radius:7px;border:none;background:var(--color-primary);color:#fff;font-size:.85rem;font-weight:600;cursor:pointer;transition:background .15s,transform .1s;white-space:nowrap}.rh-auto-btn:hover:not(:disabled){background:#1f4a2e;transform:translateY(-1px)}.rh-auto-btn:disabled{opacity:.65;cursor:not-allowed}.rh-edit-btn{display:flex;align-items:center;gap:5px;padding:5px 11px;border-radius:7px;border:1px solid var(--color-border);background:#fff;font-size:.83rem;font-weight:600;color:var(--color-text);cursor:pointer;transition:background .12s,color .12s,border-color .12s;white-space:nowrap}.rh-edit-btn:hover{background:var(--color-muted-bg);border-color:#0284c7;color:#0284c7}.rh-edit-btn.active{background:#dc2626;border-color:#dc2626;color:#fff}.rh-edit-btn.active:hover{background:#b91c1c}.rh-publish-btn{display:flex;align-items:center;gap:6px;padding:6px 14px;border-radius:7px;border:none;background:#d1d5db;color:#6b7280;font-size:.85rem;font-weight:700;cursor:not-allowed;transition:background .15s,color .15s,transform .1s;white-space:nowrap}.rh-publish-btn.has-drafts{background:#16a34a;color:#fff;cursor:pointer}.rh-publish-btn.has-drafts:hover:not(:disabled){background:#15803d;transform:translateY(-1px)}.rh-publish-btn:disabled{opacity:.65;cursor:not-allowed}.rh-badge{display:inline-flex;align-items:center;justify-content:center;min-width:18px;height:18px;padding:0 5px;border-radius:9px;background:#ffffff4d;font-size:.7rem;font-weight:700}.rh-dropdown-wrap{position:relative}@keyframes rhDropIn{0%{opacity:0;transform:translateY(-6px) scale(.97)}to{opacity:1;transform:translateY(0) scale(1)}}.rh-dropdown-panel{position:absolute;top:calc(100% + 6px);left:0;min-width:190px;background:#fff;border:1px solid var(--color-border);border-radius:10px;box-shadow:0 10px 30px #00000026;padding:6px;z-index:2000;animation:rhDropIn .14s ease}.rh-dropdown-panel.rh-dropdown-right{left:auto;right:0}.rh-dropdown-section-label{padding:5px 10px 4px;font-size:.68rem;font-weight:700;text-transform:uppercase;letter-spacing:.07em;color:var(--color-muted-text)}.rh-dropdown-divider{height:1px;background:var(--color-border);margin:4px 6px}.rh-dropdown-item{display:flex;align-items:center;gap:8px;width:100%;padding:8px 10px;border:none;background:transparent;border-radius:7px;cursor:pointer;font-size:.86rem;font-weight:500;color:var(--color-text);text-align:left;transition:background .1s}.rh-dropdown-item:hover{background:#0000000d}.rh-dropdown-danger{color:#dc2626}.rh-dropdown-danger:hover{background:#fee2e2}.roster-status-bar{position:fixed;bottom:0;left:var(--sidebar-width);right:0;height:44px;background:#fff;border-top:1px solid var(--color-border);display:flex;align-items:center;justify-content:space-between;padding:0 1.25rem;z-index:99;box-shadow:0 -2px 8px #0000000d;gap:1rem}.rsb-stats{display:flex;align-items:center;gap:.6rem;font-size:.8rem;color:var(--color-muted-text);flex-shrink:0}.rsb-stat{display:flex;align-items:center;gap:5px;font-weight:500;color:var(--color-text)}.rsb-dot{display:inline-block;width:10px;height:10px;border-radius:50%;flex-shrink:0}.rsb-sep{color:var(--color-border)}.rsb-legend{display:flex;align-items:center;gap:.75rem;flex-wrap:wrap;overflow:hidden}.rsb-legend-item{display:flex;align-items:center;gap:4px;font-size:.72rem;color:var(--color-muted-text);white-space:nowrap}.rsb-legend-pill{display:inline-block;width:22px;height:10px;border-radius:3px;flex-shrink:0}.rh-left .area-select{flex:none;max-width:none;min-width:auto}.rh-left .area-select-panel{min-width:270px;width:270px;right:auto;top:calc(100% + 8px)}@media(max-width:1200px){.rh-week-display{min-width:140px}.rh-week-range{font-size:.8rem}.rh-auto-btn,.rh-publish-btn{padding:5px 9px;font-size:.8rem}}@media(max-width:992px){.roster-sticky-header,.roster-status-bar{left:0}.rh-fy-label{display:none}}@media(max-width:768px){.rh-today-btn,.rh-period-select{display:none}.rh-week-display{min-width:110px}.rsb-legend{display:none}}.work-area-shortcuts{display:flex;gap:.6rem;row-gap:.5rem;flex-wrap:wrap;flex:1;max-width:60%;overflow:visible;padding:.25rem 0;align-content:flex-start}.area-shortcut{position:relative;display:flex;flex-direction:row;align-items:center;justify-content:center;min-width:auto;padding:.65rem 1rem;background:#f8f9fa;border:1px solid #e2e8e4;border-radius:6px;cursor:pointer;transition:all .2s ease;white-space:nowrap}.area-shortcut:hover{background:var(--color-muted-bg);border-color:var(--color-primary);transform:translateY(-1px)}.area-shortcut.active{background:var(--color-primary);border-color:var(--color-primary);color:#fff}.shortcut-name{font-weight:600;font-size:.85rem;letter-spacing:.02em;color:var(--color-primary)}.area-shortcut.active .shortcut-name{color:#fff}.area-select{position:relative;flex:1;max-width:320px;min-width:180px}.area-select-trigger{display:flex;align-items:center;justify-content:space-between;gap:8px;width:100%;padding:10px 14px;background:#fff;border:1px solid var(--color-border);border-radius:9px;cursor:pointer;transition:border-color .15s ease,box-shadow .15s ease;font-size:.95rem;font-weight:600;color:var(--color-text)}.area-select-trigger:hover{border-color:var(--color-primary)}.area-select-trigger.open{border-color:var(--color-primary);box-shadow:0 0 0 3px #1665341f}.area-select-current{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.area-select-chevron{flex-shrink:0;color:var(--color-muted-text);transition:transform .2s ease}.area-select-trigger.open .area-select-chevron{transform:rotate(180deg)}@keyframes areaPanelIn{0%{opacity:0;transform:translateY(-6px)}to{opacity:1;transform:translateY(0)}}.area-select-panel{position:absolute;top:calc(100% + 6px);left:0;right:0;z-index:1000;background:#fff;border:1px solid var(--color-border);border-radius:10px;box-shadow:0 10px 30px #00000024;padding:6px;max-height:420px;overflow-y:auto;animation:areaPanelIn .16s ease}.area-select-option{display:flex;align-items:center;gap:8px;width:100%;padding:9px 12px;border:none;background:transparent;border-radius:7px;cursor:pointer;text-align:left;transition:background .12s ease}.area-select-option:hover{background:#16653412}.area-select-option.active{background:#1665341f}.area-select-option-name{flex:1;font-size:.9rem;font-weight:600;color:var(--color-text)}.area-select-option.active .area-select-option-name{color:var(--color-primary)}.area-select-option-meta{display:inline-flex;align-items:center;gap:4px;font-size:.72rem;color:var(--color-muted-text)}.area-select-check{color:var(--color-primary);flex-shrink:0}@keyframes ctxMenuIn{0%{opacity:0;transform:scale(.94) translateY(-4px)}to{opacity:1;transform:scale(1) translateY(0)}}.ctx-menu{position:fixed;z-index:10000;min-width:200px;background:#fff;border:1px solid var(--color-border);border-radius:11px;box-shadow:0 12px 32px #0000002e;padding:6px;transform-origin:top left;animation:ctxMenuIn .13s cubic-bezier(.34,1.4,.64,1)}.ctx-menu-header{padding:7px 12px 8px;font-size:.72rem;font-weight:700;text-transform:uppercase;letter-spacing:.05em;color:var(--color-muted-text)}.ctx-divider{height:1px;background:var(--color-border);margin:5px 6px}.ctx-item{display:flex;align-items:center;gap:10px;width:100%;padding:9px 12px;border:none;background:transparent;border-radius:7px;cursor:pointer;font-size:.88rem;font-weight:500;color:var(--color-text);text-align:left;transition:background .1s ease,color .1s ease}.ctx-item svg{flex-shrink:0;color:var(--color-muted-text);transition:color .1s ease}.ctx-item:hover{background:#0000000d}.ctx-item:hover svg{color:var(--color-text)}.ctx-item-add{color:#16a34a}.ctx-item-add svg{color:#16a34a}.ctx-item-add:hover{background:#dcfce7}.ctx-item-add:hover svg{color:#16a34a}.ctx-item-info{color:#0284c7}.ctx-item-info svg{color:#0284c7}.ctx-item-info:hover{background:#e0f2fe}.ctx-item-info:hover svg{color:#0284c7}.ctx-item-warn{color:#ea580c}.ctx-item-warn svg{color:#ea580c}.ctx-item-warn:hover{background:#ffedd5}.ctx-item-warn:hover svg{color:#ea580c}.ctx-item-danger{color:#dc2626}.ctx-item-danger svg{color:#dc2626}.ctx-item-danger:hover{background:#fee2e2}.ctx-item-danger:hover svg{color:#dc2626}.ctx-item-expandable{justify-content:space-between}.ctx-item-expandable>span:first-of-type{flex:1}.ctx-chevron{flex-shrink:0;color:var(--color-muted-text)!important;margin-left:auto}.ctx-item-open{background:#0000000a}.ctx-submenu{padding:2px 0 4px 28px}.ctx-sub-item{display:flex;align-items:center;gap:7px;width:100%;padding:6px 10px;border:none;background:transparent;border-radius:6px;cursor:pointer;font-size:.83rem;font-weight:500;color:var(--color-text);text-align:left;transition:background .1s ease}.ctx-sub-item:hover{background:#0000000d}.ctx-sub-item-muted{color:var(--color-muted-text);font-style:italic}.ctx-sub-item-time{justify-content:flex-start}.ctx-sub-time-label{flex:1}.ctx-sub-time-value{font-family:monospace;font-size:.8rem;color:var(--color-muted-text);margin-left:auto}.ctx-sub-swatch{width:9px;height:9px;border-radius:50%;flex-shrink:0;background:transparent}.ctx-sub-swatch-empty{border:1.5px solid var(--color-muted-text)}.ctx-sub-divider{height:1px;background:var(--color-border);margin:3px 4px}.ctx-manual-time-row{display:flex;align-items:center;gap:4px;padding:4px 8px 6px}.ctx-manual-time-input{flex:1;min-width:0;padding:3px 6px;font-size:.72rem;border:1px solid var(--color-border);border-radius:4px;background:var(--color-bg);color:var(--color-text);outline:none;font-family:inherit}.ctx-manual-time-input:focus{border-color:var(--color-primary)}.ctx-manual-time-set{padding:3px 8px;font-size:.72rem;font-weight:600;border:none;border-radius:4px;background:var(--color-primary);color:#fff;cursor:pointer;white-space:nowrap}.ctx-manual-time-set:hover{opacity:.85}.roster-kbd-hint{font-size:.67rem;color:var(--color-muted-text);padding:.25rem .5rem;margin-bottom:.35rem;letter-spacing:.01em;opacity:.75}.sticky-work-area-info{min-width:200px;max-width:300px;padding-top:.5rem}.sticky-area-name{font-size:1.1rem;font-weight:700;color:var(--color-text);display:flex;align-items:center;gap:.5rem;margin-bottom:.25rem}.sticky-area-meta{display:flex;gap:1rem;font-size:.85rem;color:var(--color-muted-text);margin-bottom:.35rem}.sticky-area-meta span{display:flex;align-items:center;gap:.35rem}.sticky-week-info{display:flex;gap:.75rem;font-size:.8rem;color:#7a8a7e;align-items:center}.sticky-week-range{font-weight:500}.sticky-fy-week{padding:.15rem .5rem;background:#f0f4f1;border-radius:4px;font-weight:600;color:var(--color-primary);font-size:.75rem}.sticky-actions{display:flex;gap:.75rem;align-items:center;padding-top:.5rem}.btn-generate-sticky,.btn-publish-sticky,.btn-edit-sticky{display:flex;align-items:center;gap:.5rem;padding:.6rem 1rem;border-radius:6px;border:none;font-weight:600;cursor:pointer;transition:all .2s ease;font-size:.9rem;white-space:nowrap}.btn-generate-sticky{background:var(--color-primary);color:#fff}.btn-generate-sticky:hover:not(:disabled){background:#1f4a2e}.btn-generate-sticky:disabled{opacity:.6;cursor:not-allowed}.btn-publish-sticky{background:#16a34a;color:#fff}.btn-publish-sticky:hover:not(:disabled){background:#15803d}.btn-publish-sticky:disabled{opacity:.6;cursor:not-allowed}.btn-edit-sticky{background:#0284c7;color:#fff}.btn-edit-sticky:hover:not(:disabled){background:#0369a1}.btn-edit-sticky.active{background:#dc2626}.btn-edit-sticky.active:hover{background:#b91c1c}@media(max-width:1200px){.work-area-shortcuts{max-width:65%}.sticky-area-name{font-size:1rem}.sticky-area-meta{font-size:.8rem}.btn-generate-sticky,.btn-publish-sticky,.btn-edit-sticky{padding:.5rem .8rem;font-size:.85rem}}@media(max-width:992px){.roster-sticky-header{left:0}.sticky-header-content{flex-wrap:wrap;max-height:none;padding:.5rem 1rem}.sticky-work-area-info{order:1;max-width:100%;width:100%}.sticky-week-info{flex-direction:column;gap:.35rem;align-items:flex-start}.work-area-shortcuts{order:2;max-width:100%;width:100%;justify-content:flex-start}.sticky-actions{order:3;width:100%;justify-content:flex-start}.roster-view{padding-top:160px}}@media(max-width:768px){.area-shortcut{padding:.5rem .75rem}.shortcut-name{font-size:.75rem}.btn-generate-sticky,.btn-publish-sticky,.btn-edit-sticky{padding:.4rem .6rem;font-size:.8rem;gap:.3rem}}.btn-back{display:flex;align-items:center;gap:.5rem;background:transparent;border:1px solid var(--color-border);color:var(--color-muted-text);padding:.5rem 1rem;border-radius:6px;cursor:pointer;font-size:.9rem}.btn-back:hover{background:var(--color-primary);color:#fff}.work-area-info-header{flex:1}.work-area-info-header h1{margin:0 0 .25rem}.work-area-meta{display:flex;gap:1rem;color:var(--color-muted-text);font-size:.9rem}.work-area-meta span{display:flex;align-items:center;gap:.35rem}.roster-week-view{display:flex;flex-direction:column;gap:1rem}.week-nav{display:flex;align-items:center;gap:.75rem;background:#fff;padding:.75rem 1rem;border-radius:8px;border:1px solid var(--color-border)}.week-nav .nav-btn{background:var(--color-muted-bg);border:1px solid var(--color-border);color:var(--color-text);padding:.5rem .75rem;border-radius:6px;cursor:pointer;display:flex;align-items:center;transition:background .2s}.week-nav .nav-btn:hover{background:var(--color-primary);color:#fff}.week-nav-label{flex:1;text-align:center;display:flex;flex-direction:column;align-items:center;gap:2px}.week-range{font-weight:600;font-size:1rem}.week-grid-container{display:flex;border-radius:8px;border:2px solid var(--color-primary);overflow:hidden;background:#d6e4da}.week-grid-employees-fixed{flex-shrink:0;background:#d6e4da;overflow:hidden;width:160px;min-width:160px;max-width:160px}.week-grid-table-employees{border-collapse:separate;border-spacing:5px;font-size:.9rem;background:#d6e4da;table-layout:fixed}.wg-employee-header-fixed{background:var(--color-muted-bg);font-weight:600;font-size:.8rem;white-space:nowrap;padding:.5rem;text-align:left;border:1px solid rgba(46,107,68,.12);border-radius:4px;min-width:150px;width:150px;max-width:150px;height:32px;box-sizing:border-box;vertical-align:top}.wg-employee-cell-fixed{text-align:left!important;background:#fff;white-space:nowrap;padding:2px 4px!important;min-height:44px;height:44px!important;max-height:44px;min-width:150px;width:150px;max-width:150px;vertical-align:middle!important;box-sizing:border-box!important;border:1px solid rgba(46,107,68,.12);border-radius:4px;line-height:1.1!important;overflow:hidden!important}.week-fy-label{font-size:.75rem;color:var(--color-muted-text);font-weight:500;letter-spacing:.3px}.week-nav .today-btn{background:var(--color-primary);border:none;color:#fff;padding:.5rem 1rem;border-radius:6px;cursor:pointer;font-size:.85rem;transition:background .2s}.week-nav .today-btn:hover{background:var(--color-muted-text);color:var(--color-page-bg)}.period-toggle{display:flex;background:var(--color-surface-raised, #f3f4f6);border:1px solid var(--color-border, #d1d5db);border-radius:6px;padding:3px;gap:2px;margin-left:4px}.period-btn{padding:4px 12px;border:none;background:transparent;border-radius:4px;font-size:.8rem;font-weight:500;cursor:pointer;color:var(--color-muted-text, #6b7280);transition:background .15s,color .15s;white-space:nowrap}.period-btn.active{background:var(--color-primary, #166534);color:#fff}.period-btn:hover:not(.active){background:#0000000f;color:var(--color-text, #111827)}.week-grid-table.week-view .wg-day-col,.week-grid-table.week-view thead th.wg-day-col,.week-grid-table.week-view tbody td.wg-day-cell{width:110px!important;min-width:110px!important}.week-grid-wrapper{flex:1;min-width:0;overflow-x:auto;overflow-y:hidden;position:relative;-webkit-overflow-scrolling:touch;scroll-behavior:smooth;background:#d6e4da}.week-grid-table tbody tr,.week-grid-table-employees tbody tr{height:44px!important;max-height:44px!important;min-height:44px!important;line-height:1!important}.week-grid-table tbody td,.week-grid-table-employees tbody td{height:44px!important;max-height:44px!important;min-height:44px!important;overflow:hidden!important;vertical-align:middle!important;box-sizing:border-box!important}.week-grid-table{border-collapse:separate;border-spacing:5px;font-size:.9rem;background:#d6e4da}.week-grid-table th,.week-grid-table td,.week-grid-table-employees th,.week-grid-table-employees td{padding:.5rem;text-align:center;border:1px solid rgba(46,107,68,.12);border-radius:4px;box-sizing:border-box}.week-grid-table thead th,.week-grid-table-employees thead th{background:var(--color-muted-bg);font-weight:600;font-size:.8rem;white-space:nowrap;vertical-align:middle;padding:.5rem!important;height:32px!important;max-height:32px!important;min-height:32px!important;line-height:1!important}.week-grid-table thead tr,.week-grid-table-employees thead tr{height:32px!important;max-height:32px!important;min-height:32px!important}.week-grid-table thead th{background:var(--color-muted-bg);font-weight:600;font-size:.8rem;white-space:nowrap}.wg-day-col{width:75px!important;height:32px!important;max-height:32px!important;min-height:32px!important;padding:1px 4px!important;overflow:hidden!important;box-sizing:border-box!important;vertical-align:middle!important}.wg-day-col .wg-day-name{display:block;font-size:.6rem!important;font-weight:700!important;text-transform:uppercase;letter-spacing:.06em;color:var(--color-muted-text);line-height:1.2!important;margin:0 0 1px!important}.wg-day-col .wg-day-num{display:block;font-size:.95rem!important;font-weight:700!important;line-height:1!important;margin:0!important;color:var(--color-text)}.wg-day-col.today{background:var(--color-primary)!important;color:#fff!important;box-shadow:inset 0 -2px #0000002e}.wg-day-col.today .wg-day-name,.wg-day-col.today .wg-day-num{color:#fff!important}.wg-day-col.weekend .wg-day-num,.wg-day-col.weekend{color:var(--color-muted-text)}.wg-day-col.public-holiday{background:#9796f22e!important;border-top:none!important;color:#5250b8}.wg-day-col.public-holiday .wg-day-name{color:#5250b8}.ph-badge{display:inline-block;margin-top:3px;font-size:.6rem;font-weight:700;letter-spacing:.04em;color:#fff;background:#9796f2;border-radius:3px;padding:1px 4px;line-height:1.4}.wg-day-col.closed-day{background:#dc354526!important;color:var(--color-error)}.wg-day-col .holiday-indicator{font-size:.6rem;margin-left:2px}.wg-total-col{width:50px;background:var(--color-muted-bg)}.wg-emp-info{display:flex;flex-direction:column;gap:2px;max-height:38px;overflow:hidden}.wg-emp-name{font-weight:600;font-size:.85rem;display:flex;align-items:center;gap:.4rem;overflow:hidden}.wg-emp-meta{display:flex;align-items:center;gap:.3rem;font-size:.65rem;color:var(--color-muted-text)}.wg-emp-badge{padding:1px 4px;border-radius:3px;font-weight:600;font-size:.6rem;margin-right:2px}.wg-emp-badge.role-team-leader{background:#1e3a5f;color:#bfdbfe}.wg-emp-badge.role-step-up{background:#4a4a2a;color:#c9c97a}.wg-emp-badge.skill{background:var(--color-primary);color:#fff}.wg-emp-role{display:block;font-size:.7rem;color:var(--color-muted-text);margin-top:1px}.wg-emp-role.role-team-lead,.wg-emp-role.role-team-leader{color:var(--color-text)}.wg-emp-role.role-step-up{color:var(--color-muted-text)}.wg-day-cell{vertical-align:middle;min-width:60px;width:60px;max-width:60px;min-height:44px;height:44px!important;max-height:44px;overflow:hidden;padding:2px 4px!important;box-sizing:border-box;line-height:1.2;transition:background-color .2s ease,border-color .2s ease,box-shadow .15s ease}.wg-day-cell.working{color:var(--color-text);font-weight:600}@keyframes shiftPopIn{0%{opacity:0;transform:scale(.5)}60%{opacity:1;transform:scale(1.08)}to{opacity:1;transform:scale(1)}}.wg-day-cell .start-time-display{display:flex;flex-direction:column;align-items:center;justify-content:center;font-size:.7rem;font-weight:600;color:var(--color-text);gap:2px;max-height:40px;overflow:hidden;animation:shiftPopIn .22s cubic-bezier(.34,1.56,.64,1)}@keyframes addHintIn{0%{opacity:0;transform:scale(.6)}to{opacity:1;transform:scale(1)}}.wg-day-cell.has-absence{background:#ffabfbb3!important;color:#333;position:relative}.absence-label{font-weight:700;font-size:.7rem;text-transform:uppercase;position:relative;z-index:1}.wg-day-cell.off{background:#fff;color:#5a7a614d}.wg-day-cell.today{background:#2e6b4433}.wg-day-cell.today.working{background:#2e6b448c}.wg-total-cell{font-weight:700;font-size:.9rem;background:var(--color-muted-bg)}.wg-total-cell.low{background:#fdd458;color:#1d1500;opacity:.99}.wg-total-cell.high{background:#ff5654;color:#fff;opacity:.85}.wg-totals-row td{background:var(--color-muted-bg)!important;font-weight:600;font-size:.85rem;border-top:2px solid var(--color-border);color:#000!important}.wg-totals-row .wg-day-cell.under,.wg-totals-row .wg-day-cell.total{color:#000!important}.wg-day-cell.editable{cursor:pointer;transition:all .15s}.wg-day-cell.editable *{pointer-events:none}.wg-day-cell.editable:hover{background:#2e6b444d!important;transform:scale(1.05)}.wg-day-cell.editable.working:hover{background:#e76f514d!important}.wg-day-cell .add-hint{color:#5a7a614d;transition:color .15s ease,transform .15s ease}.wg-day-cell.editable:hover .add-hint{color:var(--color-primary);transform:scale(1.35)}.wg-day-cell.cell-selected{box-shadow:inset 0 0 0 3px var(--color-primary)!important;background:#2e6b4426!important;position:relative}.wg-day-cell.cell-selected:after{content:"✓";position:absolute;top:2px;right:4px;color:var(--color-primary);font-size:12px;font-weight:700;z-index:1}.wg-add-row{background:#2e6b441a}.wg-add-row td{padding:.5rem}.wg-add-row em{color:var(--color-muted-text);font-size:.85rem}.add-to-day-btn{background:var(--color-primary);border:none;color:#fff;width:24px;height:24px;border-radius:50%;cursor:pointer;display:flex;align-items:center;justify-content:center;padding:0;opacity:.7;transition:all .2s;margin:0 auto}.add-to-day-btn:hover{opacity:1;transform:scale(1.15)}.wg-day-cell.public-holiday{background:#9796f226;border-top:1px solid rgba(151,150,242,.55)!important;border-right:1px solid rgba(151,150,242,.55)!important;border-bottom:1px solid rgba(151,150,242,.55)!important}.wg-day-cell.public-holiday.working{background:#9796f247;border-top:1px solid rgba(151,150,242,.7)!important;border-right:1px solid rgba(151,150,242,.7)!important;border-bottom:1px solid rgba(151,150,242,.7)!important}.wg-day-cell.closed-day{background:#dc354540!important;position:relative}.wg-day-cell.closed-day:before{content:"";position:absolute;inset:0;background:repeating-linear-gradient(45deg,transparent,transparent 3px,rgba(220,53,69,.15) 3px,rgba(220,53,69,.15) 6px);pointer-events:none}.add-cell{text-align:center}.is-me-row td{background:#16362214!important}.is-me-row .wg-employee-cell{border-left:3px solid var(--color-text);background:#16362214!important}.roster-list{display:flex;flex-direction:column;gap:1.5rem}.shift-count{margin-left:auto;background:var(--color-primary);padding:.25rem .75rem;border-radius:20px;font-size:.8rem}.employee-name{font-weight:600}.employee-role{font-size:.85rem;color:var(--color-text)}.shift-name{font-size:.8rem;color:var(--color-text)}.settings-section{background:#fff;border-radius:8px;padding:1.5rem;margin-bottom:2rem}.settings-section h2{margin:0 0 .5rem}.section-description{color:var(--color-muted-text);margin-bottom:1.5rem}.working-days-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(140px,1fr));gap:1rem}.day-card{background:var(--color-primary);padding:1rem;border-radius:8px;text-align:center;display:flex;flex-direction:column;gap:.75rem}.day-card.active{border:2px solid var(--color-text)}.day-card.inactive{border:2px solid var(--color-page-bg);opacity:.6}.day-card .day-name{font-weight:600;color:var(--color-text)}.btn-active{background:var(--color-muted-bg)!important;color:var(--color-text)!important}.btn-inactive{background:var(--color-muted-bg)!important;color:var(--color-muted-text)!important}.work-area-days-list{display:flex;flex-direction:column;gap:2px}.work-area-days-row{display:flex;align-items:center;padding:5px 8px;background:#00000005;border:1px solid transparent;border-radius:6px;gap:8px;transition:background .1s}.work-area-days-row:hover{background:#0000000a;border-color:var(--color-border)}.work-area-label{display:flex;align-items:center;gap:5px;min-width:130px;flex-shrink:0}.work-area-name{font-weight:500;font-size:.8rem;color:var(--color-text);white-space:nowrap}.work-area-count{font-size:.65rem;color:var(--color-muted-text);background:var(--color-muted-bg);padding:1px 5px;border-radius:8px;flex-shrink:0}.work-area-days{display:flex;gap:3px;flex-shrink:0}.day-toggle-btn{width:28px;height:28px;border-radius:4px;border:1px solid transparent;cursor:pointer;font-size:.7rem;font-weight:600;transition:all .15s;display:flex;align-items:center;justify-content:center}.day-toggle-btn.active{background:var(--color-primary);color:#fff;border-color:var(--color-border)}.day-toggle-btn.active:hover:not(:disabled){background:#fff;border-color:var(--color-border)}.day-toggle-btn.inactive{background:var(--color-muted-bg);color:var(--color-muted-text);border-color:var(--color-border)}.day-toggle-btn.inactive:hover:not(:disabled){background:var(--color-muted-bg);color:var(--color-muted-text)}.day-toggle-btn:disabled{opacity:.5;cursor:not-allowed}.department-groups{display:flex;flex-direction:column;gap:.5rem}.department-group{background:#fff;border:1px solid var(--color-border);border-radius:8px;overflow:hidden;transition:border-color .2s}.department-group.expanded{border-color:var(--color-border)}.department-group-header{width:100%;display:flex;align-items:center;justify-content:space-between;padding:.85rem 1rem;background:transparent;border:none;color:var(--color-text);cursor:pointer;font-size:1rem;text-align:left;transition:background .15s}.department-group-header:hover{background:#2e6b4426}.department-group-info{display:flex;align-items:center;gap:.6rem}.department-group-info>div{display:flex;flex-direction:column;gap:.1rem}.department-group-label{font-weight:600;font-size:.95rem}.department-group-desc{font-size:.8rem;color:var(--color-muted-text)}.department-group-badge{background:var(--color-muted-bg);color:var(--color-muted-text);padding:.25rem .65rem;border-radius:12px;font-size:.8rem;font-weight:500;white-space:nowrap}.department-group.expanded .department-group-badge{background:#2e6b444d;color:var(--color-text)}.department-days-grid{display:flex;gap:.4rem;padding:0 1rem 1rem;flex-wrap:wrap}.department-day-btn{display:flex;flex-direction:column;align-items:center;gap:.3rem;padding:.6rem .75rem;border-radius:6px;border:1px solid transparent;cursor:pointer;font-size:.85rem;font-weight:500;min-width:56px;transition:all .15s}.department-day-btn.active{background:var(--color-muted-bg);border-color:var(--color-border);color:var(--color-text)}.department-day-btn.active:hover:not(:disabled){background:#fff}.department-day-btn.inactive{background:var(--color-muted-bg);border-color:var(--color-border);color:var(--color-muted-text)}.department-day-btn.inactive:hover:not(:disabled){background:var(--color-muted-bg);border-color:var(--color-muted-text)}.department-day-name{font-weight:600;font-size:.8rem}.settings-section.danger-zone{background:#fef2f2;border:1px solid #992222}.settings-section.danger-zone h2{color:var(--color-error)}.danger-action{display:flex;justify-content:space-between;align-items:center;gap:2rem;padding:1rem;background:#0003;border-radius:8px}.danger-info h3{margin:0 0 .5rem;font-size:1rem;color:var(--color-text)}.danger-info p{margin:0;color:#a89090;font-size:.9rem}.btn-danger{background:#5a3a3a!important;color:var(--color-error)!important;border:1px solid #992222!important;padding:.75rem 1.5rem!important;white-space:nowrap}.btn-danger:hover:not(:disabled){background:#6a4a4a!important;color:#e99a9a!important}.confirm-actions{display:flex;flex-direction:column;align-items:flex-end;gap:.5rem}.confirm-warning{color:var(--color-error);font-weight:600;margin:0;font-size:.9rem}.btn-danger-confirm{background:#922!important;color:var(--color-text)!important;padding:.75rem 1.5rem!important;white-space:nowrap}.btn-danger-confirm:hover:not(:disabled){background:#a55a5a!important}.btn-cancel{background:transparent!important;color:var(--color-muted-text)!important;border:1px solid var(--color-border)!important}.btn-cancel:hover:not(:disabled){background:#fff!important;color:var(--color-text)!important}.danger-actions-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:1rem}.danger-actions-grid .danger-action{flex-direction:column;align-items:flex-start;gap:1rem}.danger-actions-grid .danger-info h3{display:flex;align-items:center;gap:.5rem;font-size:.95rem}.danger-actions-grid .danger-info p{font-size:.85rem;line-height:1.4}.danger-actions-grid .btn-danger{width:100%;text-align:center}.confirm-dialog{background:#8b4a4a4d;border:1px solid #992222;border-radius:8px;padding:1rem;margin-bottom:1rem}.confirm-dialog .confirm-warning{display:flex;align-items:center;gap:.5rem;margin-bottom:1rem}.confirm-buttons{display:flex;gap:.75rem;justify-content:flex-end}.rules-list{list-style:none;padding:0;margin:0}.rules-list li{padding:.5rem 0;color:var(--color-muted-text)}.closed-days-section h2{display:flex;align-items:center;gap:.5rem;color:#dc3545}.closed-days-list{display:flex;flex-direction:column;gap:.75rem;margin:1rem 0}.closed-day-item{display:flex;align-items:center;gap:1rem;background:#dc354526;border-left:4px solid #dc3545;padding:.75rem 1rem;border-radius:0 8px 8px 0}.closed-day-icon{font-size:1.2rem}.closed-day-info{display:flex;flex-direction:column;gap:.2rem}.closed-day-info strong{color:var(--color-error);font-size:1rem}.closed-day-desc{font-size:.8rem;color:var(--color-muted-text)}.closed-days-upcoming{margin-top:1.5rem;padding-top:1rem;border-top:1px solid #444}.closed-days-upcoming h4{color:var(--color-muted-text);font-size:.9rem;margin-bottom:.75rem}.upcoming-closed-list{display:flex;flex-direction:column;gap:.5rem}.upcoming-closed-item{display:flex;justify-content:space-between;align-items:center;padding:.5rem .75rem;background:#fff;border-radius:6px;font-size:.85rem}.upcoming-date{color:var(--color-error);font-weight:500}.upcoming-name{color:var(--color-muted-text)}.five-days-settings{display:flex;flex-direction:column;gap:.75rem}.five-days-item{background:var(--color-muted-bg);border-radius:8px;padding:.75rem 1rem}.five-days-item .toggle-label{display:flex;align-items:center;gap:.75rem;cursor:pointer}.five-days-item input[type=checkbox]{width:18px;height:18px;accent-color:var(--color-primary);cursor:pointer}.five-days-item .toggle-text{display:flex;flex-direction:column;gap:.2rem}.five-days-item .toggle-text strong{color:var(--color-text);font-size:.95rem}.five-days-item .toggle-status{font-size:.8rem;color:var(--color-muted-text)}.no-shifts{color:var(--color-muted-text);font-style:italic}.daily-manning-controls{display:flex;align-items:center;gap:1rem;margin-bottom:1.5rem}.daily-manning-controls label{font-weight:600;color:var(--color-text)}.daily-manning-controls select{padding:.5rem 1rem;border-radius:6px;border:1px solid var(--color-border);background:var(--color-muted-bg);color:var(--color-text);font-size:.95rem;cursor:pointer;min-width:200px}.daily-manning-controls select:focus{outline:none;border-color:var(--color-muted-text)}.daily-manning-info{margin-bottom:1rem;padding:.75rem 1rem;background:var(--color-muted-bg);border-radius:6px;color:var(--color-muted-text);font-size:.9rem}.daily-manning-info strong{color:var(--color-text)}.daily-manning-grid{display:flex;gap:.75rem;flex-wrap:wrap;margin-bottom:1.5rem}.daily-manning-day{display:flex;flex-direction:column;align-items:center;gap:.4rem;padding:.75rem;background:var(--color-muted-bg);border-radius:8px;border:2px solid var(--color-page-bg);min-width:70px;position:relative}.daily-manning-day.custom{border-color:var(--color-border);background:var(--color-muted-bg)}.daily-manning-day .day-label{font-weight:600;font-size:.85rem;color:var(--color-text)}.daily-manning-day .manning-input{width:55px;padding:.4rem;text-align:center;border-radius:4px;border:1px solid var(--color-border);background:#fff;color:var(--color-text);font-size:1rem;font-weight:600}.daily-manning-day .manning-input:focus{outline:none;border-color:var(--color-muted-text);background:var(--color-muted-bg)}.daily-manning-day .custom-badge{position:absolute;top:-8px;right:-8px;background:var(--color-primary);color:#fff;font-size:.65rem;padding:.15rem .4rem;border-radius:8px;font-weight:600}.daily-manning-actions{display:flex;gap:1rem}.daily-manning-actions .btn-primary{background:var(--color-primary);color:#fff;border:none;padding:.75rem 1.5rem;border-radius:6px;font-weight:600;cursor:pointer;transition:background .15s}.daily-manning-actions .btn-primary:hover:not(:disabled){background:#6a9c6b}.daily-manning-actions .btn-primary:disabled{opacity:.6;cursor:not-allowed}.daily-manning-actions .btn-secondary{background:transparent;color:var(--color-muted-text);border:1px solid var(--color-border);padding:.75rem 1.5rem;border-radius:6px;font-weight:500;cursor:pointer;transition:all .15s}.daily-manning-actions .btn-secondary:hover:not(:disabled){background:var(--color-muted-bg);color:var(--color-text)}.loading-inline{color:var(--color-muted-text);font-style:italic;padding:1rem 0}.start-times-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:1rem;margin-bottom:1.5rem}.start-time-input-group{display:flex;flex-direction:column;gap:.5rem;padding:1rem;background:var(--color-muted-bg);border-radius:8px;border:2px solid var(--color-page-bg)}.start-time-input-group:first-child{border-color:var(--color-border);background:var(--color-muted-bg)}.start-time-label{font-weight:600;font-size:.85rem;color:var(--color-text)}.start-time-input{padding:.6rem;border-radius:4px;border:1px solid var(--color-border);background:#fff;color:var(--color-text);font-size:1rem;font-weight:500}.start-time-input:focus{outline:none;border-color:var(--color-muted-text);background:var(--color-muted-bg)}.roster-patterns{padding:1rem}.roster-patterns .page-header{margin-bottom:1.5rem}.roster-patterns .page-header h1{display:flex;align-items:center;gap:.75rem;color:var(--color-text);margin-bottom:.5rem}.roster-patterns .page-description{color:var(--color-muted-text);font-size:.95rem}.patterns-controls{margin-bottom:1rem}.patterns-controls .search-input{max-width:300px}.patterns-info{background:var(--color-muted-bg);border-radius:8px;padding:1rem;margin-bottom:1.5rem;border-left:4px solid var(--color-border)}.patterns-info p{margin:0;color:var(--color-text);font-size:.9rem}.contract-groups{display:flex;flex-direction:column;gap:1rem}.contract-group{background:var(--color-muted-bg);border-radius:8px;overflow:hidden}.contract-group-header{width:100%;display:flex;align-items:center;justify-content:space-between;padding:1rem;background:transparent;border:none;color:var(--color-text);cursor:pointer;font-size:1rem;text-align:left;transition:background .15s}.contract-group-header:hover{background:#2e6b4426}.contract-group-info{display:flex;align-items:center;gap:.75rem}.contract-group-info>div{display:flex;flex-direction:column;gap:.15rem}.contract-group-label{font-weight:600;font-size:1rem}.contract-group-desc{font-size:.8rem;color:var(--color-muted-text)}.contract-group-badge{background:var(--color-muted-bg);color:var(--color-muted-text);padding:.3rem .75rem;border-radius:12px;font-size:.8rem;font-weight:500}.patterns-list{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:.75rem;padding:0 1rem 1rem}.pattern-card{background:var(--color-muted-bg);border-radius:8px;padding:1rem;border:1px solid transparent;transition:border-color .2s}.pattern-card.editing{border-color:var(--color-border)}.pattern-card-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:.75rem}.employee-name{font-weight:600;color:var(--color-text);font-size:.95rem}.has-pattern-badge{display:flex;align-items:center;gap:.3rem;background:#2e6b444d;color:var(--color-muted-text);padding:.2rem .5rem;border-radius:10px;font-size:.7rem}.pattern-display{display:flex;flex-direction:column;gap:.5rem}.pattern-row{display:flex;justify-content:space-between;align-items:center;font-size:.85rem}.pattern-label{color:var(--color-muted-text)}.pattern-value{color:var(--color-text);font-family:monospace;letter-spacing:2px}.pattern-value.not-set{color:var(--color-muted-text);font-style:italic;letter-spacing:normal;font-family:inherit}.pattern-editor{display:flex;flex-direction:column;gap:.75rem}.pattern-week{display:flex;flex-direction:column;gap:.4rem}.pattern-week label{font-size:.8rem;color:var(--color-muted-text);font-weight:500}.day-buttons{display:flex;gap:.25rem}.day-btn{width:32px;height:32px;border-radius:4px;border:1px solid var(--color-border);background:var(--color-muted-bg);color:var(--color-muted-text);font-size:.75rem;font-weight:600;cursor:pointer;transition:all .15s}.day-btn:hover{border-color:var(--color-border);background:#fff}.day-btn.selected{background:var(--color-primary);border-color:var(--color-border);color:#fff}.day-count{font-size:.75rem;color:var(--color-muted-text)}.pattern-actions{display:flex;gap:.5rem;margin-top:.5rem}.btn-edit-small{background:#fff;border:1px solid var(--color-border);color:var(--color-text);padding:.35rem .75rem;border-radius:4px;font-size:.8rem;cursor:pointer;transition:background .15s}.btn-edit-small:hover{background:var(--color-primary)}.btn-primary-small{background:var(--color-primary);border:none;color:#fff;padding:.35rem .75rem;border-radius:4px;font-size:.8rem;cursor:pointer;transition:background .15s}.btn-primary-small:hover{background:#6b9b6b}.btn-secondary-small{background:transparent;border:1px solid var(--color-border);color:var(--color-muted-text);padding:.35rem .75rem;border-radius:4px;font-size:.8rem;cursor:pointer;transition:all .15s}.btn-secondary-small:hover{border-color:var(--color-primary);color:#fff}.settings-header{margin-bottom:1.5rem}.settings-header h1{margin:0 0 .25rem}.settings-subtitle{margin:0;color:var(--color-muted-text);font-size:.9rem}.settings-tabs{display:flex;gap:4px;margin-bottom:1.5rem;background:#0000000a;border-radius:10px;padding:4px;flex-wrap:wrap}.stab{display:flex;align-items:center;gap:6px;padding:8px 14px;border:none;background:transparent;border-radius:7px;font-size:.85rem;font-weight:500;color:var(--color-muted-text);cursor:pointer;transition:background .15s,color .15s;white-space:nowrap}.stab:hover{background:#ffffffb3;color:var(--color-text)}.stab-active{background:var(--color-primary)!important;color:#fff!important}.stab-danger{color:#b91c1c}.stab-danger.stab-active{background:#b91c1c!important}.stab-danger:hover:not(.stab-active){background:#b91c1c14!important;color:#b91c1c!important}.scard{background:#fff;border:1px solid var(--color-border);border-radius:12px;padding:1.5rem;margin-bottom:1.25rem}.scard-danger{border-color:#b91c1c40;background:#fff8f8}.scard-header{margin-bottom:1.25rem}.scard-header h2{margin:0 0 .35rem;font-size:1rem;font-weight:600;color:var(--color-text);display:flex;align-items:center;gap:6px}.scard-header p{margin:0;font-size:.85rem;color:var(--color-muted-text)}.ssubcard{background:#00000006;border:1px solid var(--color-border);border-radius:8px;padding:1rem 1.25rem;margin-bottom:1rem}.ssubcard-title{font-size:.85rem;font-weight:600;color:var(--color-text);margin-bottom:.35rem;display:flex;align-items:center;gap:6px}.ssubcard-optional{font-weight:400;font-size:.75rem;color:var(--color-muted-text)}.ssubcard-desc{font-size:.8rem;color:var(--color-muted-text);margin:0 0 .75rem}.sfield-row{display:flex;align-items:center;gap:.75rem;margin-bottom:1rem;flex-wrap:wrap}.sfield-row-inline{gap:.75rem}.sfield-col{display:flex;flex-direction:column;gap:4px}.sfield-label{font-size:.8rem;font-weight:600;color:var(--color-muted-text);white-space:nowrap}.sfield-label-inline{font-size:.8rem;font-weight:500;color:var(--color-muted-text);white-space:nowrap}.sselect{padding:7px 10px;border:1px solid var(--color-border);border-radius:6px;background:#fff;color:var(--color-text);font-size:.875rem;cursor:pointer;transition:border-color .15s}.sselect:focus{outline:none;border-color:var(--color-primary)}.sselect-sm{flex:1;min-width:0;font-size:.8rem}.sinput{padding:7px 10px;border:1px solid var(--color-border);border-radius:6px;background:#fff;color:var(--color-text);font-size:.875rem;transition:border-color .15s}.sinput:focus{outline:none;border-color:var(--color-primary)}.sinput-number{width:80px;text-align:center;font-weight:600}.sinput-xs{width:52px;text-align:center;padding:5px 6px;font-size:.8rem}.sactions{display:flex;gap:.5rem;margin-top:.75rem;flex-wrap:wrap}.sbtn-ghost{display:inline-flex;align-items:center;gap:4px;padding:3px 8px;background:transparent;border:1px solid var(--color-border);border-radius:5px;font-size:.72rem;font-weight:500;color:var(--color-muted-text);cursor:pointer;transition:all .15s;white-space:nowrap;flex-shrink:0}.sbtn-ghost:hover:not(:disabled){background:#0000000a;color:var(--color-text);border-color:var(--color-muted-text)}.sbtn-ghost:disabled{opacity:.5;cursor:not-allowed}.sbtn-icon-danger{display:inline-flex;align-items:center;justify-content:center;width:24px;height:24px;background:transparent;border:none;border-radius:4px;color:var(--color-muted-text);cursor:pointer;transition:color .15s,background .15s;flex-shrink:0}.sbtn-icon-danger:hover:not(:disabled){color:#dc2626;background:#dc262614}.sbtn-icon-danger:disabled{opacity:.4;cursor:not-allowed}.stoggle{position:relative;width:40px;height:22px;border-radius:11px;background:#d1d5db;border:none;cursor:pointer;transition:background .2s;flex-shrink:0}.stoggle-on{background:var(--color-primary)}.stoggle:disabled{opacity:.5;cursor:not-allowed}.stoggle-thumb{position:absolute;top:3px;left:3px;width:16px;height:16px;border-radius:50%;background:#fff;transition:left .2s}.stoggle-on .stoggle-thumb{left:21px}.day-dot{width:24px;height:24px;border-radius:50%;border:none;font-size:.65rem;font-weight:700;cursor:pointer;transition:background .15s,color .15s;display:flex;align-items:center;justify-content:center;flex-shrink:0}.day-dot-on{background:var(--color-primary);color:#fff}.day-dot-off{background:#00000012;color:var(--color-muted-text)}.day-dot:hover:not(:disabled){opacity:.8}.day-dot:disabled{opacity:.6;cursor:not-allowed}.btn-sm{padding:6px 14px!important;font-size:.8rem!important}.scheduled-changes{display:flex;flex-wrap:wrap;gap:3px;flex:1;min-width:0}.scheduled-week{display:inline-flex;align-items:center;gap:3px;background:#16653412;border:1px solid rgba(22,101,52,.18);border-radius:10px;padding:1px 6px 1px 5px;font-size:.7rem;white-space:nowrap}.week-badge{font-weight:700;color:var(--color-primary)}.week-days{color:var(--color-muted-text)}.pattern-list{display:flex;flex-direction:column;gap:6px}.pattern-item{border:1px solid var(--color-border);border-radius:8px;overflow:hidden;background:#fafafa}.pattern-item-active{border-color:#16653459;background:#fff}.pattern-item-head{display:flex;align-items:center;gap:.75rem;padding:10px 14px}.pattern-item-name{font-size:.875rem;font-weight:600;color:var(--color-text);flex:1}.pattern-item-summary{font-size:.78rem;color:var(--color-primary);font-weight:500}.pattern-item-body{padding:10px 14px 14px;border-top:1px solid var(--color-border);background:#16653405}.pattern-fields{display:flex;gap:1rem;flex-wrap:wrap;margin-bottom:.75rem}.skill-config-list{display:flex;flex-direction:column;gap:6px;margin-bottom:.75rem}.skill-config-row{display:flex;align-items:center;gap:8px;padding:6px 10px;background:#00000006;border:1px solid var(--color-border);border-radius:6px;flex-wrap:wrap}.skill-config-add{display:flex;gap:8px;align-items:center;flex-wrap:wrap}.five-days-list{display:flex;flex-direction:column;gap:6px}.five-days-item{display:flex;align-items:center;justify-content:space-between;padding:10px 14px;border:1px solid var(--color-border);border-radius:8px;background:#00000005;gap:1rem;transition:border-color .15s}.five-days-on{border-color:#16653459;background:#1665340a}.five-days-info{display:flex;flex-direction:column;gap:2px}.five-days-info strong{font-size:.875rem;color:var(--color-text)}.five-days-info span{font-size:.75rem;color:var(--color-muted-text)}.five-days-right{display:flex;align-items:center;gap:10px}.five-days-label{font-size:.78rem;font-weight:500;color:var(--color-muted-text)}.five-days-on .five-days-label{color:var(--color-primary)}.scard-danger .scard-header h2{color:#b91c1c}.sdanger-confirm{display:flex;align-items:center;gap:10px;padding:12px 16px;background:#b91c1c0f;border:1px solid rgba(185,28,28,.25);border-radius:8px;margin-bottom:1.25rem;font-size:.875rem;color:#b91c1c;flex-wrap:wrap}.sdanger-confirm span{flex:1}.settings-tabs-legacy{display:flex;gap:.5rem;margin-bottom:1.5rem;border-bottom:2px solid var(--color-border);padding-bottom:.5rem}.tab-btn{background:transparent;border:none;padding:.75rem 1.25rem;color:var(--color-muted-text);font-size:1rem;cursor:pointer;border-radius:4px 4px 0 0;transition:all .2s}.tab-btn:hover{background:#fff;color:var(--color-text)}.tab-btn.active{background:var(--color-primary);color:#fff;border-bottom:2px solid var(--color-text);margin-bottom:-2px}.employee-controls{margin-bottom:1.5rem}.search-filter-row{display:flex;gap:1rem;flex-wrap:wrap;align-items:center}.search-input{flex:1;min-width:200px;padding:.75rem 1rem;border-radius:4px;border:1px solid var(--color-border);background:var(--color-muted-bg);color:var(--color-text);font-size:1rem}.search-input::placeholder{color:var(--color-primary)}.filter-select{padding:.75rem 1rem;border-radius:4px;border:1px solid var(--color-border);background:var(--color-muted-bg);color:var(--color-text);font-size:1rem;min-width:150px}.employee-form{background:#fff;border-radius:8px;padding:1.5rem;margin-bottom:1.5rem}.employee-form h3{margin:0 0 1rem;color:var(--color-text)}.form-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:1rem;margin-bottom:1rem}.form-group label{font-weight:500;color:var(--color-muted-text);font-size:.9rem}.form-group input,.form-group select{padding:.75rem;border-radius:4px;border:1px solid var(--color-border);background:var(--color-muted-bg);color:var(--color-text);font-size:1rem}.form-group.checkbox-group label{flex-direction:row;display:flex;align-items:center;gap:.5rem;cursor:pointer}.form-group.checkbox-group input[type=checkbox]{width:18px;height:18px}.form-actions{display:flex;gap:1rem;margin-top:1rem}.btn-primary{background:var(--color-primary)!important;color:#fff!important;border:none!important;padding:.75rem 1.5rem!important;border-radius:4px!important;cursor:pointer!important;font-weight:500!important}.btn-primary:hover:not(:disabled){background:var(--color-primary-hover)!important}.btn-secondary{background:transparent!important;color:var(--color-muted-text)!important;border:1px solid var(--color-border)!important;padding:.75rem 1.5rem!important;border-radius:4px!important;cursor:pointer!important}.btn-secondary:hover:not(:disabled){background:#fff!important;color:var(--color-text)!important}.employee-list-table{overflow-x:auto}.employee-list-table table{width:100%;border-collapse:collapse;font-size:.95rem}.employee-list-table th,.employee-list-table td{padding:.75rem 1rem;text-align:left;border-bottom:1px solid var(--color-border)}.employee-list-table th{background:#fff;color:var(--color-muted-text);font-weight:600;text-transform:uppercase;font-size:.8rem}.employee-list-table tbody tr:hover{background:#ffffff0d}.employee-list-table .inactive-row{opacity:.5}.employee-list-table .no-results{text-align:center;color:var(--color-muted-text);padding:2rem!important}.contract-badge{padding:.25rem .5rem;border-radius:4px;font-size:.8rem;font-weight:500}.contract-badge.full_time{background:var(--color-muted-bg);color:var(--color-text)}.contract-badge.part_time{background:#4a4a2a;color:#c9c97a}.status-badge{padding:.25rem .5rem;border-radius:4px;font-size:.8rem;font-weight:500}.status-badge.active{background:var(--color-muted-bg);color:var(--color-text)}.status-badge.inactive{background:#fef2f2;color:var(--color-error)}.actions-cell{white-space:nowrap}.btn-edit,.btn-delete,.btn-transfer{background:transparent;border:none;padding:.5rem;cursor:pointer;font-size:1rem;opacity:.7;transition:opacity .2s}.btn-edit:hover,.btn-delete:hover,.btn-transfer:hover{opacity:1}.btn-transfer{color:var(--color-primary)}.btn-transfer:disabled{opacity:.3;cursor:not-allowed}.delete-confirm{display:flex;align-items:center;gap:.5rem;font-size:.85rem}.delete-confirm span{color:var(--color-error)}.btn-danger-small{background:#922!important;color:var(--color-text)!important;border:none!important;padding:.25rem .5rem!important;border-radius:4px!important;font-size:.8rem!important;cursor:pointer!important}.btn-secondary-small{background:transparent!important;color:var(--color-muted-text)!important;border:1px solid var(--color-border)!important;padding:.25rem .5rem!important;border-radius:4px!important;font-size:.8rem!important;cursor:pointer!important}.employee-count{margin-top:1rem;color:var(--color-muted-text);font-size:.9rem;text-align:right}.no-data{text-align:center;color:var(--color-muted-text);padding:2rem}.today-roster{background:#fff;border-radius:8px;padding:1.5rem}.today-roster h2{margin:0 0 1rem}.roster-calendar{background:#fff;border-radius:8px;padding:1.5rem}.calendar-controls{display:flex;flex-direction:column;gap:1rem;margin-bottom:1.5rem}.employee-select{display:flex;align-items:center;gap:1rem}.employee-select label{display:flex;align-items:center;gap:.75rem;font-weight:500}.employee-select select{padding:.75rem 1rem;background:var(--color-muted-bg);border:1px solid var(--color-border);border-radius:4px;color:var(--color-text);font-size:1rem;min-width:250px;cursor:pointer}.employee-select select:focus{outline:none;border-color:var(--color-border)}.employee-select optgroup{font-weight:700;color:var(--color-muted-text)}.employee-select option{padding:.5rem}.employee-info-card{display:flex;align-items:center;gap:1rem;background:var(--color-muted-bg);padding:1rem 1.5rem;border-radius:8px;border-left:4px solid var(--color-border)}.employee-avatar{width:50px;height:50px;background:var(--color-primary);margin:0;font-size:1.25rem;min-width:200px;text-align:center}.employee-avatar .employee-details h3{margin:0 0 .25rem;font-size:1.1rem}.employee-avatar .employee-meta{display:flex;gap:.5rem;margin:0 0 .25rem}.employee-avatar .role-badge{background:var(--color-muted-bg);padding:.2rem .5rem;border-radius:4px;font-size:.75rem}.employee-avatar .contract-badge{padding:.2rem .5rem;border-radius:4px;font-size:.75rem;text-transform:capitalize}.employee-avatar .contract-full_time{background:var(--color-muted-bg);color:var(--color-text)}.employee-avatar .contract-part_time{background:#363660;color:#a8a8e8}.employee-avatar .contract-casual{background:#5a2a40;color:#e07494}.employee-avatar .shift-summary{margin:0;color:var(--color-muted-text);font-size:.85rem}.employee-avatar .shift-summary strong{color:var(--color-text);font-size:1.1rem}.employee-avatar .month-navigation{display:flex;align-items:center;gap:1rem;padding:1rem 0;border-top:1px solid var(--color-border);border-bottom:1px solid var(--color-border)}.nav-btn{padding:.5rem 1rem;background:var(--color-muted-bg);border:none;border-radius:4px;color:var(--color-text);cursor:pointer;transition:background .2s}.nav-btn:hover{background:var(--color-primary)}.today-btn{margin-left:auto;padding:.5rem 1rem;background:var(--color-primary);border:none;border-radius:4px;color:#fff;cursor:pointer}.calendar-grid{margin-top:1rem}.calendar-header{display:grid;grid-template-columns:repeat(7,1fr);gap:4px;margin-bottom:4px}.weekday{text-align:center;padding:.4rem;background:var(--color-muted-bg);font-weight:600;font-size:.7rem;color:var(--color-muted-text);border-radius:4px}.weekday.weekend{color:var(--color-error)}.calendar-body{display:grid;grid-template-columns:repeat(7,1fr);gap:4px}.calendar-day{min-height:70px;background:var(--color-muted-bg);border-radius:3px;padding:.35rem;display:flex;flex-direction:column;transition:all .2s}.calendar-day.empty{background:transparent}.calendar-day:not(.empty):hover{background:#fff;transform:scale(1.02)}.calendar-day.today{border:2px solid var(--color-border);background:#2e6b4433}.calendar-day.weekend{background:var(--color-muted-bg)}.calendar-day.has-shifts{background:#fff}.day-number{font-weight:600;font-size:.75rem;margin-bottom:.25rem;color:var(--color-muted-text)}.calendar-day.today .day-number{color:var(--color-text);font-weight:700}.calendar-day.weekend .day-number{color:var(--color-error)}.calendar-day.public-holiday{background:#dc354526!important;border-left:3px solid #dc3545}.calendar-day.public-holiday .day-number{color:var(--color-error)}.calendar-day.closed-day{background:#dc354540!important;border-left:3px solid #dc3545}.calendar-day.closed-day:before{content:"";position:absolute;inset:0;background:repeating-linear-gradient(45deg,transparent,transparent 4px,rgba(220,53,69,.1) 4px,rgba(220,53,69,.1) 8px);pointer-events:none;z-index:0}.calendar-day .holiday-badge{font-size:.65rem;margin-left:4px}.day-shifts{flex:1;display:flex;flex-direction:column;gap:2px;overflow:hidden}.shift-chip{background:var(--color-primary);padding:.15rem .35rem;border-radius:2px;font-size:.6rem;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.shift-chip.highlighted{background:var(--color-muted-text);color:var(--color-page-bg);font-weight:600}.shift-chip.has-absence{background:linear-gradient(135deg,#9b59b6,#8e44ad);position:relative}.shift-chip.has-absence:after{content:"";position:absolute;inset:0;background:repeating-linear-gradient(45deg,transparent,transparent 2px,rgba(0,0,0,.15) 2px,rgba(0,0,0,.15) 4px);border-radius:inherit;pointer-events:none}.shift-chip.has-absence .absence-reason{font-size:.55rem;text-transform:uppercase;font-weight:600;letter-spacing:.02em}.absence-indicator{color:#ffd60a;flex-shrink:0}.shift-employee{font-weight:500}.shift-time-badge{font-size:.5rem;font-weight:600;background:#0003;padding:.05rem .15rem;border-radius:2px;margin-left:.15rem}.shift-time{font-weight:600}.more-shifts{font-size:.55rem;color:var(--color-muted-text);text-align:center;padding:.15rem}.edit-mode-btn{margin-left:auto;background:transparent;border:1px solid var(--color-border);color:var(--color-muted-text);padding:.25rem .5rem;border-radius:4px;cursor:pointer;display:flex;align-items:center;gap:.25rem;font-size:.65rem;transition:all .2s}.edit-mode-btn:hover{background:var(--color-primary);color:#fff}.edit-mode-btn.active{background:var(--color-primary);color:#fff;border-color:var(--color-border)}.edit-mode-banner{background:linear-gradient(90deg,var(--color-primary) 0%,var(--color-border) 100%);color:#fff;padding:.35rem .7rem;border-radius:4px;margin-bottom:.5rem;display:flex;align-items:center;gap:.35rem;font-size:.65rem}.calendar-grid.edit-mode .calendar-day{transition:all .2s}.calendar-day.drag-over{background:#2e6b444d!important;border:2px dashed var(--color-primary)}.day-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:.15rem}.add-shift-btn{background:var(--color-primary);border:none;color:#fff;width:12px;height:12px;border-radius:50%;cursor:pointer;display:flex;align-items:center;justify-content:center;padding:0;opacity:.7;transition:all .2s}.add-shift-btn:hover{opacity:1;transform:scale(1.1)}.shift-chip.draggable{cursor:grab;display:flex;align-items:center;gap:.1rem}.shift-chip.draggable:active{cursor:grabbing}.shift-chip.dragging{opacity:.5;transform:scale(.95)}.drag-handle{color:#ffffff80;flex-shrink:0}.remove-shift-btn{background:#0000004d;border:none;color:var(--color-text);width:10px;height:10px;border-radius:50%;cursor:pointer;display:flex;align-items:center;justify-content:center;padding:0;margin-left:auto;opacity:.7;transition:all .2s;flex-shrink:0}.remove-shift-btn:hover{opacity:1;background:#c1121f}.modal-overlay{position:fixed;inset:0;background:#0000004d;display:flex;align-items:center;justify-content:center;z-index:1000}.modal-content{background:#fff;border-radius:12px;padding:1.5rem;min-width:320px;max-width:90vw;box-shadow:0 10px 40px #00000026;border:1px solid var(--color-border)}.modal-content h3{margin:0 0 1rem;color:var(--color-text)}.shift-action-modal{min-width:280px;max-width:360px;padding:1.1rem}.shift-action-subtitle{margin:-.35rem 0 1rem;color:var(--color-muted-text);font-size:.9rem}.shift-action-buttons{justify-content:flex-end;flex-wrap:wrap}.modal-body{margin-bottom:1.5rem}.employee-select-dropdown{width:100%;padding:.75rem;border-radius:6px;border:1px solid var(--color-border);background:#fff;color:var(--color-text);font-size:1rem}.employee-select-dropdown:focus{outline:none;border-color:var(--color-muted-text)}.cross-area-modal{min-width:420px;max-width:520px}.cross-area-tabs{display:flex;gap:0;margin-bottom:1rem;border-bottom:2px solid #e0e0e0}.cross-area-tabs .tab-btn{flex:1;padding:.6rem 1rem;border:none;background:transparent;color:var(--color-muted-text);font-size:.9rem;font-weight:500;cursor:pointer;border-bottom:2px solid transparent;margin-bottom:-2px;transition:all .2s}.cross-area-tabs .tab-btn.active{color:var(--color-primary);border-bottom-color:var(--color-primary);font-weight:600}.cross-area-tabs .tab-btn:hover:not(.active){color:var(--color-text);background:#2e6b440d}.cross-area-body{min-height:200px}.cross-area-loading{text-align:center;color:var(--color-muted-text);padding:2rem}.cross-area-grid{display:grid;grid-template-columns:1fr 1fr;gap:.5rem;max-height:400px;overflow-y:auto}.cross-area-card{padding:.6rem .75rem;border-radius:8px;border:1px solid #ddd;background:#fff;cursor:pointer;transition:all .15s}.cross-area-card:hover{border-color:var(--color-primary);background:#2e6b440a}.cross-area-card.manning-under-3{border-color:#d97706;background:#d9770614}.cross-area-card.manning-under-2{border-color:#eab308;background:#eab3080f}.cross-area-card.manning-under-1{border-color:#fde047;background:#fde0470a}.cross-area-card.manning-at-target{border-color:#22c55e;background:#22c55e0a}.cross-area-card.manning-over-1{border-color:#60a5fa;background:#60a5fa0a}.cross-area-card.manning-over-2{border-color:#3b82f6;background:#3b82f60f}.cross-area-card.manning-over-3{border-color:#2563eb;background:#2563eb14}.cross-area-card.over{border-color:var(--color-primary)}.cross-area-card.under{border-color:#ddd}.cross-area-card-name{font-weight:600;font-size:.85rem;color:var(--color-text);margin-bottom:2px}.cross-area-card-time{font-size:.7rem;color:var(--color-muted-text);margin-bottom:4px}.cross-area-card-manning{font-weight:700;font-size:.9rem;color:var(--color-text)}.cross-area-card-manning.manning-under-3{color:#92400e}.cross-area-card-manning.manning-under-2{color:#a16207}.cross-area-card-manning.manning-under-1{color:#ca8a04}.cross-area-card-manning.manning-at-target{color:#16a34a}.cross-area-card-manning.manning-over-1{color:#2563eb}.cross-area-card-manning.manning-over-2{color:#1d4ed8}.cross-area-card-manning.manning-over-3{color:#1e40af}.cross-area-card-manning.over{color:var(--color-primary)}.cross-area-card-manning.under{color:var(--color-error)}.cross-area-card-manning.at{color:var(--color-muted-text)}.manning-indicator{font-size:.75rem;font-weight:600}.cross-area-back{display:flex;align-items:center;gap:.3rem;border:none;background:none;color:var(--color-muted-text);cursor:pointer;padding:.3rem 0;margin-bottom:.5rem;font-size:.85rem}.cross-area-back:hover{color:var(--color-primary)}.cross-area-selected-header{font-weight:600;font-size:1rem;color:var(--color-text);padding:.3rem 0 .5rem;display:flex;align-items:center;gap:.5rem}.cross-area-selected-manning{font-size:.85rem;font-weight:500;color:var(--color-muted-text)}.cross-area-employees{max-height:300px;overflow-y:auto;border:1px solid #e0e0e0;border-radius:8px;margin-bottom:1rem}.cross-area-emp-row{padding:.6rem .75rem;border-bottom:1px solid #f0f0f0;cursor:pointer;display:flex;justify-content:space-between;align-items:center;transition:background .1s}.cross-area-emp-row:last-child{border-bottom:none}.cross-area-emp-row:hover{background:#2e6b440f}.cross-area-emp-row.selected{background:#2e6b4426;border-left:3px solid var(--color-primary)}.cross-area-emp-name{font-weight:600;font-size:.9rem;color:var(--color-text)}.cross-area-emp-meta{font-size:.75rem;color:var(--color-muted-text);display:flex;align-items:center;gap:.4rem}.cross-area-emp-skill{background:#2e6b441a;color:var(--color-primary);padding:1px 5px;border-radius:3px;font-size:.65rem;font-weight:600}.cross-area-badge{display:inline-flex;align-items:center;gap:2px;background:#3b82f61f;color:#2563eb;font-size:.55rem;font-weight:600;padding:1px 4px;border-radius:3px;margin-left:.25rem;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:5rem;flex-shrink:1}.relevant-area-group{margin-bottom:.25rem}.relevant-area-header{font-size:.7rem;font-weight:700;text-transform:uppercase;letter-spacing:.5px;color:var(--color-muted-text);padding:.5rem .75rem .25rem;background:#2e6b440a;border-bottom:1px solid #e8efe8}.relevant-emp-row{cursor:default}.relevant-emp-info{display:flex;flex-direction:column;gap:.15rem;flex:1;min-width:0}.relevant-emp-actions{display:flex;gap:.35rem;flex-shrink:0}.btn-sm{padding:.25rem .5rem;font-size:.7rem;border-radius:4px;display:inline-flex;align-items:center;gap:.25rem;cursor:pointer;border:none;font-weight:600;transition:background .15s,opacity .15s}.btn-sm.btn-primary{background:var(--color-primary);color:#fff}.btn-sm.btn-primary:hover{background:#245536}.btn-sm.btn-secondary{background:transparent;border:1px solid #8aa690;color:var(--color-primary);padding:.2rem .45rem}.btn-sm.btn-secondary:hover{background:#2e6b4414}.btn-sm:disabled{opacity:.4;cursor:not-allowed}.modal-actions{display:flex;gap:.75rem;justify-content:flex-end}.btn-secondary{background:transparent;border:1px solid #666;color:var(--color-muted-text);padding:.5rem 1rem;border-radius:6px;cursor:pointer;transition:all .2s}.btn-secondary .transfer-modal{min-width:360px;max-width:450px}.btn-secondary .transfer-employee-name{font-size:1.1rem;font-weight:600;color:var(--color-text);margin:0 0 1.5rem}.btn-secondary .transfer-details{background:#fff;border-radius:8px;padding:1rem;margin-bottom:1.5rem}.btn-secondary .transfer-row{display:flex;justify-content:space-between;align-items:center;padding:.5rem 0}.btn-secondary .transfer-label{color:var(--color-muted-text);font-size:.9rem}.btn-secondary .transfer-value{color:var(--color-text);font-weight:500}.btn-secondary .transfer-value.highlight{color:var(--color-primary);font-weight:600}.btn-secondary .transfer-arrow{text-align:center;font-size:1.5rem;color:var(--color-primary);padding:.5rem 0}.btn-secondary .transfer-details .form-group{margin:.5rem 0}.btn-secondary .transfer-details .form-group label{display:block;color:var(--color-muted-text);font-size:.9rem;margin-bottom:.35rem}.btn-secondary .transfer-details .form-group select,.btn-secondary .transfer-details .form-group input{width:100%;padding:.6rem;border-radius:6px;border:1px solid var(--color-border);background:var(--color-muted-bg);color:var(--color-text);font-size:.95rem}.btn-secondary .transfer-details .form-group select:focus,.btn-secondary .transfer-details .form-group input:focus{outline:none;border-color:var(--color-muted-text)}.btn-secondary .transfer-actions{display:flex;gap:.75rem;justify-content:flex-end}.btn-secondary .pending-transfer-info,.btn-secondary .new-transfer-form{text-align:left}.btn-secondary:hover{background:#ffffff1a}.btn-primary{background:var(--color-primary);border:none;color:#fff;padding:.5rem 1rem;border-radius:6px;cursor:pointer;transition:all .2s}.btn-primary:hover{background:var(--color-primary-hover)}.btn-primary:disabled{background:var(--color-border);cursor:not-allowed;opacity:.6}.upcoming-shifts{margin-top:2rem;padding-top:1.5rem;border-top:1px solid var(--color-border)}.upcoming-shifts h3{margin:0 0 1rem;font-size:1.1rem}.shifts-list{display:grid;grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:.75rem}.upcoming-shift-item{display:flex;align-items:center;gap:1rem;background:var(--color-muted-bg);padding:.75rem 1rem;border-radius:8px;transition:transform .2s}.upcoming-shift-item:hover{transform:translate(4px)}.shift-date{display:flex;flex-direction:column;align-items:center;background:var(--color-primary);padding:.5rem .75rem;border-radius:6px;min-width:50px}.shift-date .day{font-size:1.25rem;font-weight:700;line-height:1}.shift-date .month{font-size:.7rem;text-transform:uppercase}.shift-info{display:flex;flex-direction:column}.shift-info .weekday{font-weight:500;font-size:.9rem;background:transparent;padding:0;text-align:left}.shift-info .shift-type{font-size:.8rem;color:var(--color-muted-text)}.work-area-tabs{display:flex;gap:.5rem;margin-bottom:1.5rem;border-bottom:2px solid var(--color-border);padding-bottom:0;overflow-x:auto;flex-wrap:wrap;max-height:180px}.work-area-tab{display:flex;flex-direction:column;align-items:center;padding:.5rem .75rem;background:var(--color-muted-bg);border:1px solid var(--color-border);border-bottom:none;border-radius:8px 8px 0 0;cursor:pointer;transition:all .2s;position:relative;bottom:-2px;min-width:fit-content;flex-shrink:0}.work-area-tab:hover{background:#fff}.work-area-tab.active{background:var(--color-primary);border-color:var(--color-border)}.work-area-tab .tab-name{font-size:.85rem;font-weight:600;color:var(--color-text);white-space:nowrap}.work-area-tab .tab-info{display:none}.work-area-tab.active .tab-info{color:#fffc}.work-area-selector{display:flex;align-items:center;gap:1rem;margin-bottom:1.5rem;flex-wrap:wrap}.work-area-selector label{font-weight:600;color:var(--color-muted-text)}.work-area-selector select{padding:.75rem 1rem;border-radius:4px;border:1px solid var(--color-border);background:var(--color-muted-bg);color:var(--color-text);font-size:1rem;min-width:200px}.work-area-info{display:flex;gap:1.5rem;color:var(--color-muted-text);font-size:.9rem}.work-area-info span{display:flex;align-items:center;gap:.5rem}.login-page{min-height:100vh;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,var(--color-page-bg) 0%,var(--color-accent) 50%,var(--color-secondary) 100%);padding:2rem}.login-container{width:100%;max-width:400px}.login-header{text-align:center;margin-bottom:2rem}.login-header h1{font-size:2.5rem;margin:0;color:var(--color-text)}.login-header p{color:var(--color-muted-text);margin:.5rem 0 0}.login-form{background:#fff;padding:2rem;border-radius:12px;box-shadow:0 8px 32px #0000001a;border:1px solid var(--color-border)}.login-form h2{margin:0 0 1.5rem;text-align:center;color:var(--color-text)}.login-error{background:#fef2f2;border:1px solid #992222;color:var(--color-error);padding:.75rem 1rem;border-radius:6px;margin-bottom:1rem;text-align:center;font-size:.9rem}.form-group{margin-bottom:1.25rem}.form-group label{display:block;margin-bottom:.5rem;color:var(--color-muted-text);font-size:.9rem}.form-group input{width:100%;padding:.75rem 1rem;background:#fff;border:1px solid var(--color-border);border-radius:6px;color:var(--color-text);font-size:1rem;transition:border-color .2s}.form-group input:focus{outline:none;border-color:var(--color-primary)}.form-group input::placeholder{color:var(--color-muted-text)}.btn-login{width:100%;padding:.875rem;background:var(--color-primary)!important;border:none;border-radius:6px;color:#fff;font-size:1rem;font-weight:600;cursor:pointer;transition:background .2s}.btn-login:hover:not(:disabled){background:var(--color-primary-hover)!important}.btn-login:disabled{opacity:.7;cursor:not-allowed}.login-help{margin-top:1.5rem;padding-top:1rem;border-top:1px solid var(--color-border);text-align:center}.login-help p{margin:.25rem 0;font-size:.8rem;color:var(--color-muted-text)}.employee-roster{max-width:1000px;margin:0 auto}.employee-header{display:flex;align-items:center;gap:1rem;margin-bottom:2rem}.employee-header h1{margin:0}.work-area-badge{background:var(--color-primary);padding:.5rem 1rem;border-radius:20px;font-size:.9rem;font-weight:500}.roster-tabs{display:flex;gap:.5rem;margin-bottom:2rem;border-bottom:2px solid var(--color-border)}.roster-tab{padding:1rem 1.5rem;background:#fff;border:1px solid var(--color-border);border-bottom:none;border-radius:8px 8px 0 0;cursor:pointer;transition:all .2s;position:relative;bottom:-2px;color:var(--color-muted-text)}.roster-tab:hover{background:var(--color-primary);color:#fff}.roster-tab.active{background:var(--color-primary);border-color:var(--color-border);color:#fff}.my-roster-section h2,.team-roster-section h2{margin:0 0 .5rem}.shifts-list-employee{display:grid;grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:1rem}.shift-card{background:#fff;border-radius:8px;overflow:hidden;border:1px solid var(--color-border)}.shift-card-date{background:var(--color-primary);padding:.75rem 1rem;font-weight:600}.shift-card-info{padding:1rem}.shift-card-shift{color:var(--color-muted-text);font-size:.9rem}.roster-entry.is-me{background:var(--color-primary);border-left:3px solid var(--color-text)}.me-badge{background:var(--color-text);color:var(--color-page-bg);font-size:.7rem;padding:.15rem .4rem;border-radius:4px;margin-left:.5rem;font-weight:600}.calendar-section{background:#fff;border-radius:12px;padding:1.5rem;border:1px solid var(--color-border)}.calendar-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:1.5rem}.calendar-nav-btn{background:var(--color-muted-bg);border:1px solid var(--color-border);color:var(--color-text);padding:.75rem 1.25rem;border-radius:8px;cursor:pointer;font-size:1.25rem;transition:all .2s}.calendar-nav-btn:hover{background:var(--color-primary)}.calendar-title{text-align:center;display:flex;flex-direction:column;align-items:center;gap:.5rem}.calendar-title h2{margin:0;font-size:1.5rem}.today-btn{background:var(--color-primary);border:none;color:#fff;padding:.35rem .75rem;border-radius:4px;cursor:pointer;font-size:.85rem;transition:all .2s}.today-btn:hover{background:var(--color-primary-hover)}.calendar-grid{background:var(--color-muted-bg);border-radius:8px;overflow:hidden}.calendar-weekdays{display:grid;grid-template-columns:repeat(7,1fr);background:#fff}.weekday-label{padding:.75rem;text-align:center;font-weight:600;color:var(--color-muted-text);font-size:.85rem}.calendar-days{display:grid;grid-template-columns:repeat(7,1fr)}.calendar-day{aspect-ratio:1;padding:.5rem;border:1px solid var(--color-border);display:flex;flex-direction:column;align-items:center;justify-content:flex-start;gap:.25rem;min-height:60px;transition:all .2s}.calendar-day:hover{background:#fff}.calendar-day.other-month{opacity:.3}.calendar-day.today{background:#fff;border-color:var(--color-border)}.calendar-day.today .day-number{background:var(--color-primary);color:#fff;border-radius:50%;width:28px;height:28px;display:flex;align-items:center;justify-content:center}.calendar-day.has-shift{background:#2e6b4440}.day-number{font-size:.9rem;font-weight:500;color:var(--color-text)}.calendar-shifts{display:flex;gap:.25rem;flex-wrap:wrap;justify-content:center}.calendar-shift-dot{background:var(--color-muted-text);color:var(--color-page-bg);font-size:.65rem;font-weight:700;min-width:20px;height:20px;border-radius:10px;display:flex;align-items:center;justify-content:center;gap:.15rem;padding:0 .35rem}.shift-time-label{font-size:.6rem;font-weight:600}.calendar-legend{display:flex;gap:2rem;margin-top:1.5rem;justify-content:center}.legend-item{display:flex;align-items:center;gap:.5rem;color:var(--color-muted-text);font-size:.9rem}.legend-dot{width:20px;height:20px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:.7rem;font-weight:700}.legend-dot.has-shift{background:var(--color-muted-text);color:var(--color-page-bg)}.legend-dot.today-marker{background:var(--color-primary);border:2px solid var(--color-muted-text)}.availability-section{background:#fff;border-radius:12px;padding:1.5rem;border:1px solid var(--color-border)}.availability-section h2{margin:0 0 .5rem}.availability-section .section-description{color:var(--color-muted-text);margin:0 0 1.5rem}.availability-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(140px,1fr));gap:1rem}.availability-day{background:var(--color-muted-bg);border:2px solid var(--color-border);border-radius:12px;padding:1.25rem;cursor:pointer;transition:all .2s;text-align:center;display:flex;flex-direction:column;gap:.5rem}.availability-day:hover{border-color:var(--color-muted-text);transform:translateY(-2px)}.availability-day.available{background:#2e6b4433;border-color:var(--color-border)}.availability-day.unavailable{background:#b4505026;border-color:var(--color-error)}.availability-day.saving{opacity:.6;cursor:wait}.availability-day .day-name{font-weight:600;font-size:1.1rem}.availability-day .availability-status{font-size:.85rem;color:var(--color-muted-text)}.availability-day.available .availability-status{color:var(--color-text)}.availability-day.unavailable .availability-status{color:var(--color-error)}.availability-info{margin-top:1.5rem;text-align:center;color:var(--color-muted-text);font-size:.9rem}.availability-info p{margin:0}.set-roster-section{max-width:640px}.ra-pending-banner{display:flex;flex-wrap:wrap;align-items:center;gap:.5rem;padding:.75rem 1rem;background:#d4a01726;border:1px solid rgba(212,160,23,.3);border-radius:8px;margin-bottom:1rem;font-size:.85rem;color:var(--color-warning)}.ra-pending-detail{display:flex;align-items:center;gap:.5rem;width:100%;margin-top:.25rem}.ra-cancel-btn{display:inline-flex;align-items:center;gap:3px;padding:.2rem .5rem;border:1px solid rgba(212,160,23,.4);border-radius:4px;background:transparent;color:var(--color-warning);font-size:.75rem;cursor:pointer}.ra-cancel-btn:hover{background:#d4a01726}.ra-form{display:flex;flex-direction:column;gap:1.25rem;background:var(--color-muted-bg);border-radius:8px;padding:1.5rem}.ra-form .form-group label{font-weight:500;color:var(--color-text);display:block;margin-bottom:.35rem}.ra-form select{padding:.6rem .75rem;border:1px solid var(--color-border);border-radius:6px;background:#fff;color:var(--color-text);font-size:.95rem;width:100%}.ra-quarter-display{padding:.6rem .75rem;border:1px solid var(--color-border);border-radius:6px;background:var(--color-muted-bg);color:var(--color-text);font-size:.95rem;font-weight:600}.ra-grid-section h3{margin:0 0 .15rem;font-size:.95rem;color:var(--color-text)}.ra-week-hint{font-weight:400;font-size:.75rem;color:var(--color-muted-text)}.ra-grid-hint{font-size:.8rem;color:var(--color-muted-text);margin:0 0 .5rem}.ra-day-grid{display:flex;gap:6px}.ra-day-cell{flex:1;display:flex;flex-direction:column;align-items:center;gap:4px;padding:.6rem 0;border-radius:6px;cursor:pointer;transition:all .15s;-webkit-user-select:none;user-select:none}.ra-day-cell.active{background:var(--color-primary);color:#fff}.ra-day-cell.inactive{background:#2e6b444d;color:var(--color-muted-text)}.ra-day-cell.disabled{opacity:.35;pointer-events:none}.ra-day-cell:hover:not(.disabled){transform:translateY(-1px);box-shadow:0 2px 6px #0003}.ra-day-short{font-size:.75rem;font-weight:600;letter-spacing:.3px}.ra-day-indicator{font-size:.8rem}.ra-consecutive{display:flex;flex-direction:column;gap:.25rem}.ra-checkbox-label{display:flex;align-items:center;gap:.5rem;cursor:pointer;font-size:.9rem;color:var(--color-text)}.ra-checkbox-label input[type=checkbox]{accent-color:var(--color-primary);width:16px;height:16px}.ra-history{margin-top:2rem}.ra-history h3{margin:0 0 .75rem;font-size:1rem}.ra-locked-banner{display:flex;align-items:center;gap:.5rem;flex-wrap:wrap;background:#2e6b4433;border:1px solid var(--color-border);border-radius:8px;padding:.75rem 1rem;margin-bottom:1rem;color:var(--color-muted-text);font-size:.85rem}.ra-locked-banner svg{color:var(--color-primary);flex-shrink:0}.ra-change-request-btn{margin-left:auto;padding:.4rem .9rem;background:var(--color-primary);color:#fff;border:none;border-radius:6px;cursor:pointer;font-size:.8rem;font-weight:600;transition:background .2s}.ra-change-request-btn:hover{background:#fff}.ra-change-banner{display:flex;align-items:center;gap:.5rem;flex-wrap:wrap;background:#d9770626;border:1px solid rgba(217,119,6,.4);border-radius:8px;padding:.75rem 1rem;margin-bottom:1rem;color:#fbbf24;font-size:.85rem}.ra-change-banner svg{color:#f59e0b;flex-shrink:0}.ra-change-badge{display:inline-flex;align-items:center;background:#d9770640;color:#fbbf24;font-size:.7rem;font-weight:600;padding:.15rem .5rem;border-radius:4px;margin-left:.4rem;text-transform:uppercase;letter-spacing:.03em}.ra-superseded-badge{display:inline-flex;align-items:center;background:#64748b40;color:#94a3b8;font-size:.7rem;font-weight:600;padding:.15rem .5rem;border-radius:4px;margin-left:.4rem;text-transform:uppercase;letter-spacing:.03em}.ra-alternating-badge{display:inline-flex;align-items:center;background:#6366f133;color:#a5b4fc;font-size:.7rem;font-weight:600;padding:.15rem .5rem;border-radius:4px;margin-left:.4rem;text-transform:uppercase;letter-spacing:.03em}.leave-card.superseded,.agreement-card.superseded{opacity:.55}.ra-alternating-toggle{margin:.75rem 0 .5rem}.ra-toggle-btn{display:inline-flex;align-items:center;gap:.5rem;padding:.6rem 1rem;background:var(--color-muted-bg);border:1px solid var(--color-border);border-radius:8px;color:var(--color-muted-text);cursor:pointer;font-size:.85rem;font-weight:500;transition:all .2s}.ra-toggle-btn:hover{background:#fff}.ra-toggle-btn.active{background:#6366f126;border-color:#6366f180;color:#a5b4fc}.ra-toggle-btn.active:hover{background:#6366f140}.ra-pdf-btn{display:inline-flex;align-items:center;gap:.35rem;margin-top:.5rem;padding:.35rem .75rem;background:#2e6b4433;border:1px solid var(--color-border);border-radius:6px;color:var(--color-muted-text);cursor:pointer;font-size:.78rem;font-weight:500;transition:all .2s}.ra-pdf-btn:hover{background:#2e6b4459;color:var(--color-text)}.ra-pdf-btn:disabled{opacity:.5;cursor:not-allowed}.leave-section{background:#fff;border-radius:12px;padding:1.5rem;border:1px solid var(--color-border)}.leave-section h2{margin:0 0 .5rem}.leave-section .section-description{color:var(--color-muted-text);margin:0 0 1.5rem}.leave-form{background:var(--color-muted-bg);border-radius:8px;padding:1.5rem;margin-bottom:2rem}.leave-form .form-row{display:grid;grid-template-columns:1fr 1fr;gap:1rem;margin-bottom:1rem}.leave-form .form-group{display:flex;flex-direction:column;gap:.5rem}.leave-form .form-group label{font-weight:500;color:var(--color-text)}.leave-form input[type=date],.leave-form textarea{padding:.75rem;border:1px solid var(--color-border);border-radius:6px;background:#fff;color:var(--color-text);font-size:1rem}.leave-form input[type=date]:focus,.leave-form textarea:focus{outline:none;border-color:var(--color-border)}.leave-form textarea{resize:vertical;min-height:80px}.leave-form .submit-btn{background:var(--color-primary);color:#fff;border:none;padding:.875rem 1.5rem;border-radius:6px;font-size:1rem;font-weight:500;cursor:pointer;transition:all .2s;margin-top:.5rem}.leave-form .submit-btn:hover:not(:disabled){background:var(--color-primary-hover)}.leave-form .submit-btn:disabled{opacity:.6;cursor:not-allowed}.leave-history{margin-top:2rem}.leave-history h3{margin:0 0 1rem;font-size:1.1rem}.leave-list{display:flex;flex-direction:column;gap:.75rem}.leave-card{background:var(--color-muted-bg);border-radius:8px;padding:1rem;border-left:4px solid var(--color-border)}.leave-card.leave-pending{border-left-color:var(--color-warning)}.leave-card.leave-approved{border-left-color:var(--color-primary)}.leave-card.leave-rejected{border-left-color:var(--color-error)}.leave-card .leave-dates{font-weight:600;margin-bottom:.5rem}.leave-card .leave-info{display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:.5rem}.leave-card .leave-reason{color:var(--color-muted-text);font-size:.9rem}.leave-card .leave-status{font-size:.85rem;font-weight:500;padding:.25rem .75rem;border-radius:20px}.leave-card .status-pending{background:#d4a01733;color:var(--color-warning)}.leave-card .status-approved{background:#2e6b4433;color:var(--color-muted-text)}.leave-card .status-rejected{background:#c333;color:var(--color-error)}.leave-card .leave-notes{margin-top:.5rem;font-size:.85rem;color:var(--color-muted-text);font-style:italic}.agreement-card{border-left-color:var(--color-border)!important}.agreement-card.status-pending{border-left-color:var(--color-warning)!important}.agreement-card.status-approved{border-left-color:var(--color-primary)!important}.agreement-card.status-rejected{border-left-color:var(--color-error)!important}.leave-card-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:.75rem}.leave-card-employee strong{display:block;font-size:1rem}.leave-card-meta{font-size:.8rem;color:var(--color-muted-text)}.leave-card-status .status-badge{font-size:.75rem;font-weight:600;padding:.2rem .6rem;border-radius:12px;text-transform:capitalize}.status-badge.pending{background:#d4a01733;color:var(--color-warning)}.status-badge.approved{background:#2e6b4433;color:var(--color-muted-text)}.status-badge.rejected{background:#c333;color:var(--color-error)}.agreement-patterns{display:grid;grid-template-columns:1fr 1fr;gap:1rem;margin-bottom:.75rem}.agreement-section{background:#2e6b4480;border-radius:6px;padding:.75rem}.agreement-section-current{opacity:.7}.agreement-section-title{font-size:.75rem;font-weight:600;text-transform:uppercase;letter-spacing:.5px;color:var(--color-muted-text);margin:0 0 .5rem}.agreement-day-row{display:flex;align-items:center;gap:.5rem;margin-bottom:.35rem}.agreement-day-label{font-size:.7rem;color:var(--color-muted-text);min-width:55px;font-weight:500}.agreement-day-pills{display:flex;gap:2px}.day-pill{width:28px;height:20px;font-size:.6rem;display:flex;align-items:center;justify-content:center;border-radius:3px;font-weight:500}.day-pill.active{background:var(--color-primary);color:#fff}.day-pill.inactive{background:#2e6b444d;color:var(--color-muted-text)}.day-selector{margin-bottom:1rem}.day-selector-label{display:block;margin-bottom:.5rem;font-weight:600;font-size:.9rem;color:var(--color-text)}.day-pills{display:flex;gap:6px;flex-wrap:wrap}.day-pill{padding:.5rem .75rem;min-width:48px;height:auto;font-size:.85rem;display:inline-flex;align-items:center;justify-content:center;border-radius:6px;font-weight:600;cursor:pointer;border:2px solid transparent;transition:all .2s ease;-webkit-user-select:none;user-select:none}.day-pill:not(.readonly):hover{transform:translateY(-2px);box-shadow:0 2px 8px #2e6b4433}.day-pill.active{background:var(--color-primary);color:#fff;border-color:var(--color-primary)}.day-pill.inactive{background:#f0f4f2;color:var(--color-muted-text);border-color:var(--color-border)}.day-pill.readonly{cursor:default;opacity:.8}.day-pill.disabled{cursor:not-allowed;opacity:.5}.agreement-consec{font-size:.7rem;color:var(--color-muted-text);margin-top:.25rem}.leave-card-actions{display:flex;flex-direction:column;gap:.5rem;margin-top:.5rem;padding-top:.75rem;border-top:1px solid rgba(46,107,68,.2)}.admin-notes-input{padding:.5rem .75rem;border:1px solid var(--color-border);border-radius:6px;background:#fff;color:var(--color-text);font-size:.85rem;width:100%}.admin-notes-input::placeholder{color:var(--color-muted-text)}.action-buttons{display:flex;gap:.5rem}.btn-approve{display:flex;align-items:center;gap:4px;padding:.5rem 1rem;border:none;border-radius:6px;background:var(--color-primary);color:#fff;font-size:.85rem;font-weight:500;cursor:pointer;transition:background .2s}.btn-approve:hover:not(:disabled){background:var(--color-primary-hover)}.btn-reject{display:flex;align-items:center;gap:4px;padding:.5rem 1rem;border:none;border-radius:6px;background:var(--color-error);color:#fff;font-size:.85rem;font-weight:500;cursor:pointer;transition:background .2s}.btn-reject:hover:not(:disabled){background:#c06060}.btn-approve:disabled,.btn-reject:disabled{opacity:.6;cursor:not-allowed}.leave-card-notes{font-size:.8rem;color:var(--color-muted-text);margin-top:.5rem;font-style:italic}.agreement-pdf-row{display:flex;align-items:center;justify-content:space-between;margin-top:.5rem;padding-top:.5rem;border-top:1px solid rgba(46,107,68,.15)}.btn-pdf{display:flex;align-items:center;gap:4px;padding:.4rem .8rem;border:1px solid var(--color-border);border-radius:6px;background:transparent;color:var(--color-muted-text);font-size:.8rem;cursor:pointer;transition:all .2s}.btn-pdf:hover:not(:disabled){background:#2e6b4433;color:var(--color-text)}.btn-pdf:disabled{opacity:.5;cursor:not-allowed}.agreement-date{font-size:.75rem;color:var(--color-muted-text)}.swaps-section{background:#fff;border-radius:12px;padding:1.5rem;border:1px solid var(--color-border)}.swaps-section h2{margin:0 0 .5rem}.swaps-section h3{margin:0 0 1rem;font-size:1.1rem}.swaps-section .section-description{color:var(--color-muted-text);margin:0 0 1.5rem}.swap-form-container{background:var(--color-muted-bg);border-radius:8px;padding:1.5rem;margin-bottom:2rem}.swap-form{display:flex;flex-direction:column;gap:1rem}.swap-form .form-group{display:flex;flex-direction:column;gap:.5rem}.swap-form .form-group label{font-weight:500;color:var(--color-text)}.swap-form select{padding:.75rem;border:1px solid var(--color-border);border-radius:6px;background:#fff;color:var(--color-text);font-size:1rem}.swap-form select:focus{outline:none;border-color:var(--color-border)}.swap-form select:disabled{opacity:.6;cursor:not-allowed}.swap-requests-container{background:var(--color-muted-bg);border-radius:8px;padding:1.5rem;margin-bottom:1.5rem}.swap-list{display:flex;flex-direction:column;gap:.75rem}.swap-card{background:#fff;border-radius:8px;padding:1rem;border-left:4px solid var(--color-border)}.swap-card.incoming{border-left-color:var(--color-warning);background:#fff}.swap-card.status-pending_partner,.swap-card.status-pending_admin{border-left-color:var(--color-warning)}.swap-card.status-approved{border-left-color:var(--color-primary)}.swap-card.status-rejected,.swap-card.status-cancelled{border-left-color:var(--color-error)}.swap-card .swap-info{font-size:1rem;margin-bottom:.75rem}.swap-card .swap-details{display:flex;flex-direction:column;gap:.5rem;margin-bottom:.75rem}.swap-card .swap-shift{display:flex;flex-direction:column;gap:.25rem;padding:.5rem;background:var(--color-muted-bg);border-radius:4px;font-size:.9rem}.swap-card .swap-shift .label{color:var(--color-muted-text);font-size:.8rem}.swap-card .swap-actions{display:flex;gap:.75rem;margin-top:.5rem}.swap-card .swap-status-info{margin-bottom:.5rem}.swap-card .swap-status-info .status{font-size:.85rem;font-weight:500;padding:.25rem .75rem;border-radius:20px}.swap-card .swap-status-info .status.pending{background:#d4a01733;color:var(--color-warning)}.swap-card .swap-status-info .status.approved{background:#2e6b4433;color:var(--color-muted-text)}.swap-card .swap-status-info .status.rejected{background:#c333;color:var(--color-error)}.swap-card .swap-status-info .status.cancelled{background:#78787833;color:var(--color-muted-text)}.swap-card .swap-notes{margin-top:.5rem;font-size:.85rem;color:var(--color-muted-text);font-style:italic}.btn-success{background:var(--color-primary);color:#fff;border:none;padding:.5rem 1rem;border-radius:6px;font-size:.9rem;font-weight:500;cursor:pointer;transition:all .2s}.btn-success:hover{background:var(--color-primary-hover)}.btn-danger{background:var(--color-error);color:var(--color-text);border:none;padding:.5rem 1rem;border-radius:6px;font-size:.9rem;font-weight:500;cursor:pointer;transition:all .2s}.btn-danger:hover{background:var(--color-error)}.btn-secondary{background:#fff;color:var(--color-text);border:none;padding:.5rem 1rem;border-radius:6px;font-size:.9rem;font-weight:500;cursor:pointer;transition:all .2s}.btn-secondary:hover{background:var(--color-primary)}.leave-requests-admin{max-width:1200px;margin:0 auto}.leave-requests-admin .page-header{display:flex;align-items:center;gap:1rem;margin-bottom:1.5rem}.leave-requests-admin .page-header h1{margin:0}.pending-badge{background:var(--color-warning);color:var(--color-page-bg);padding:.35rem .75rem;border-radius:20px;font-size:.9rem;font-weight:600}.filter-bar{display:flex;align-items:center;gap:1rem;margin-bottom:2rem;padding:1rem;background:#fff;border-radius:8px}.filter-bar label{font-weight:500;color:var(--color-muted-text)}.filter-buttons{display:flex;gap:.5rem}.filter-btn{padding:.5rem 1rem;background:var(--color-muted-bg);border:1px solid var(--color-border);color:var(--color-muted-text);border-radius:6px;cursor:pointer;transition:all .2s}.filter-btn:hover{border-color:var(--color-muted-text);color:var(--color-text)}.filter-btn.active{background:var(--color-primary);border-color:var(--color-border);color:#fff}.work-area-groups{display:flex;flex-direction:column;gap:2rem}.work-area-group{background:#fff;border-radius:12px;padding:1.5rem;border:1px solid var(--color-border)}.work-area-title{margin:0 0 1rem;font-size:1.25rem;display:flex;align-items:center;gap:.5rem}.work-area-title .count{font-size:.9rem;color:var(--color-muted-text);font-weight:400}.requests-list{display:flex;flex-direction:column;gap:1rem}.request-card{background:var(--color-muted-bg);border-radius:8px;padding:1.25rem;border:1px solid var(--color-border)}.request-card.request-pending{border-color:var(--color-warning)}.request-card.request-approved{border-color:var(--color-border)}.request-card.request-rejected{border-color:var(--color-error)}.request-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:1rem}.employee-info{display:flex;flex-direction:column;gap:.25rem}.employee-info .employee-name{font-weight:600;font-size:1.1rem}.employee-info .employee-email{color:var(--color-muted-text);font-size:.85rem}.status-badge{padding:.35rem .75rem;border-radius:20px;font-size:.85rem;font-weight:500;text-transform:capitalize}.status-badge.status-pending{background:#d4a01733;color:var(--color-warning)}.status-badge.status-approved{background:#2e6b4433;color:var(--color-muted-text)}.status-badge.status-rejected{background:#c333;color:var(--color-error)}.request-details{display:flex;flex-direction:column;gap:.5rem;margin-bottom:1rem}.request-details .date-range{display:flex;align-items:center;gap:.5rem;font-weight:500}.request-details .days-count{color:var(--color-muted-text);font-weight:400}.request-details .reason{color:var(--color-text)}.request-details .reason .label{color:var(--color-muted-text)}.request-details .submitted{font-size:.85rem;color:var(--color-muted-text)}.request-actions{display:flex;flex-direction:column;gap:.75rem;padding-top:1rem;border-top:1px solid var(--color-border)}.request-actions .notes-input input{width:100%;padding:.6rem .75rem;background:#fff;border:1px solid var(--color-border);border-radius:6px;color:var(--color-text)}.request-actions .notes-input input:focus{outline:none;border-color:var(--color-muted-text)}.action-buttons{display:flex;gap:.75rem}.approve-btn,.reject-btn{padding:.6rem 1.25rem;border-radius:6px;font-weight:500;cursor:pointer;transition:all .2s;border:none}.approve-btn{background:var(--color-primary);color:#fff}.approve-btn:hover:not(:disabled){background:var(--color-primary-hover)}.reject-btn{background:var(--color-error);color:var(--color-text)}.reject-btn:hover:not(:disabled){background:var(--color-error)}.approve-btn:disabled,.reject-btn:disabled{opacity:.6;cursor:not-allowed}.admin-notes{margin-top:.75rem;padding-top:.75rem;border-top:1px solid var(--color-border);font-size:.9rem;color:var(--color-muted-text);font-style:italic}.admin-notes .label{font-style:normal;font-weight:500}.success-message{background:#2e6b4433;border:1px solid var(--color-border);color:var(--color-text);padding:1rem;border-radius:8px;margin-bottom:1rem}.shift-swaps-admin{max-width:1200px;margin:0 auto}.shift-swaps-admin .page-header{display:flex;align-items:center;gap:1rem;margin-bottom:1.5rem}.shift-swaps-admin .page-header h1{margin:0}.swaps-list{display:flex;flex-direction:column;gap:1rem}.swap-admin-card{background:#fff;border-radius:12px;padding:1.5rem;border:1px solid var(--color-border);border-left:4px solid var(--color-border)}.swap-admin-card.status-pending_admin{border-left-color:var(--color-warning)}.swap-admin-card.status-pending_partner{border-left-color:#6aa0c0}.swap-admin-card.status-approved{border-left-color:var(--color-primary)}.swap-admin-card.status-rejected{border-left-color:var(--color-error)}.swap-admin-card.status-cancelled{border-left-color:var(--color-muted-text)}.swap-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1rem}.swap-employees{display:flex;align-items:center;gap:.75rem;font-size:1.1rem}.swap-employees .employee-name{font-weight:600}.swap-employees .swap-arrow{color:var(--color-primary);font-size:1.2rem}.swap-work-area{background:var(--color-muted-bg);padding:.35rem .75rem;border-radius:20px;font-size:.85rem;color:var(--color-muted-text)}.swap-shifts{display:grid;grid-template-columns:1fr 1fr;gap:1rem;margin-bottom:1rem}.swap-shift-card{background:var(--color-muted-bg);border-radius:8px;padding:1rem}.swap-shift-card .shift-owner{font-size:.85rem;color:var(--color-muted-text);margin-bottom:.5rem}.swap-shift-card .shift-date{font-weight:600;margin-bottom:.25rem}.swap-shift-card .shift-time{color:var(--color-primary)}.swap-meta{display:flex;align-items:center;gap:1rem;flex-wrap:wrap}.swap-status-badge{font-size:.85rem;font-weight:500;padding:.35rem .75rem;border-radius:20px}.swap-status-badge.pending_admin{background:#d4a01733;color:var(--color-warning)}.swap-status-badge.pending_partner{background:#6aa0c033;color:#8ec4e8}.swap-status-badge.approved{background:#2e6b4433;color:var(--color-muted-text)}.swap-status-badge.rejected{background:#c333;color:var(--color-error)}.swap-status-badge.cancelled{background:#78787833;color:var(--color-muted-text)}.partner-accepted,.swap-date{font-size:.85rem;color:var(--color-muted-text)}.swap-admin-notes{margin-top:.75rem;padding:.75rem;background:var(--color-muted-bg);border-radius:6px;font-size:.9rem;color:var(--color-muted-text)}.swap-actions{margin-top:1rem;padding-top:1rem;border-top:1px solid var(--color-border)}.swap-actions .admin-notes-input{margin-bottom:.75rem}.swap-actions .admin-notes-input input{width:100%;padding:.75rem;border:1px solid var(--color-border);border-radius:6px;background:var(--color-muted-bg);color:var(--color-text);font-size:.95rem}.swap-actions .admin-notes-input input:focus{outline:none;border-color:var(--color-muted-text)}.swap-actions .action-buttons{display:flex;gap:.75rem}.absence-stats{display:flex;gap:1rem;flex-wrap:wrap}.stat-item{background:var(--color-muted-bg);padding:.75rem 1rem;border-radius:8px;border-left:3px solid var(--color-border);display:flex;flex-direction:column;min-width:80px}.stat-value{font-size:1.5rem;font-weight:700;color:var(--color-text)}.stat-label{font-size:.75rem;color:var(--color-muted-text)}.absence-list{display:flex;flex-direction:column;gap:1rem}.absence-day-card{background:var(--color-muted-bg);border-radius:8px;overflow:hidden}.absence-day-card.today{border:2px solid var(--color-border)}.absence-day-card.weekend{background:#2a3832}.absence-day-header{display:flex;align-items:center;gap:1rem;padding:.75rem 1rem;background:var(--color-muted-bg)}.absence-day-date{display:flex;flex-direction:column;align-items:center;min-width:60px}.absence-day-date .day-name{font-size:.7rem;color:var(--color-muted-text);text-transform:uppercase}.absence-day-date .day-num{font-size:1.5rem;font-weight:700;color:var(--color-text)}.absence-day-date .month-name{font-size:.7rem;color:var(--color-muted-text)}.absence-day-stats{display:flex;gap:1rem;flex:1}.absence-day-stats .roster-count{color:var(--color-muted-text);font-size:.85rem}.absence-day-stats .absence-count{color:#e76f51;font-size:.85rem;font-weight:600}.add-absence-btn{background:var(--color-primary);border:none;color:#fff;padding:.4rem .75rem;border-radius:6px;cursor:pointer;display:flex;align-items:center;gap:.3rem;font-size:.8rem;transition:all .2s}.add-absence-btn:hover{background:#fff}.absence-day-list{padding:.75rem 1rem;display:flex;flex-direction:column;gap:.5rem}.absence-item{display:flex;align-items:center;gap:.75rem;padding:.5rem .75rem;background:#0003;border-radius:6px;border-left:3px solid #e76f51}.absence-type-badge{display:flex;align-items:center;gap:.3rem;padding:.2rem .5rem;border-radius:4px;font-size:.7rem;font-weight:600;color:var(--color-text)}.absence-employee{flex:1;font-weight:500;color:var(--color-text)}.absence-reason{font-size:.8rem;color:var(--color-muted-text);font-style:italic}.delete-absence-btn{background:transparent;border:none;color:var(--color-muted-text);cursor:pointer;padding:.25rem;border-radius:4px;transition:all .2s}.delete-absence-btn:hover{background:#c1121f;color:var(--color-text)}.no-absences{padding:1rem;text-align:center;color:var(--color-muted-text);font-size:.85rem}.absence-chip{padding:.15rem .35rem;border-radius:2px;font-size:.6rem;color:var(--color-text);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.calendar-day.has-absences{background:#e76f5126}.roster-badge{background:var(--color-primary);color:#fff;font-size:.55rem;padding:.1rem .3rem;border-radius:8px;font-weight:600}.add-absence-modal{min-width:400px}.add-absence-modal .form-group{margin-bottom:1rem}.add-absence-modal .form-group label{display:block;margin-bottom:.5rem;color:var(--color-muted-text);font-size:.85rem}.add-absence-modal select,.add-absence-modal textarea{width:100%;padding:.6rem;border-radius:6px;border:1px solid var(--color-border);background:#fff;color:var(--color-text);font-size:.9rem}.add-absence-modal select:focus,.add-absence-modal textarea:focus{outline:none;border-color:var(--color-muted-text)}.add-absence-modal textarea{resize:vertical;min-height:60px}.absence-type-selector{display:flex;flex-wrap:wrap;gap:.5rem}.absence-type-btn{display:flex;align-items:center;gap:.3rem;padding:.4rem .75rem;border:2px solid;border-radius:6px;background:transparent;cursor:pointer;font-size:.8rem;transition:all .2s}.absence-type-btn:hover{transform:translateY(-1px)}.absence-type-btn.selected{transform:translateY(-1px);box-shadow:0 2px 8px #0000004d}.quick-add-section{margin-bottom:1rem}.btn-quick-add{display:flex;align-items:center;gap:.4rem;padding:.6rem 1.25rem;background:linear-gradient(135deg,#e76f51,#f4a261);color:var(--color-text);border:none;border-radius:6px;cursor:pointer;font-weight:600;font-size:.9rem;transition:all .2s}.btn-quick-add:hover{transform:translateY(-1px);box-shadow:0 4px 12px #e76f5166}.quick-add-modal{max-width:500px;width:90%}.quick-add-modal .modal-header{display:flex;justify-content:space-between;align-items:center;padding-bottom:1rem;border-bottom:1px solid var(--color-border);margin-bottom:1rem}.quick-add-modal .modal-header h3{display:flex;align-items:center;gap:.5rem;color:#f4a261;margin:0}.quick-add-modal .close-btn{background:transparent;border:none;color:var(--color-muted-text);cursor:pointer;padding:.25rem;display:flex;align-items:center;justify-content:center}.quick-add-modal .close-btn:hover{color:var(--color-text)}.quick-add-row{display:flex;gap:1rem;margin-bottom:1rem}.quick-add-row .form-group{flex:1}.quick-add-row .form-group:first-child{flex:0 0 140px}.quick-add-modal .form-group{margin-bottom:1rem}.quick-add-modal .form-group label{display:block;color:var(--color-muted-text);font-size:.8rem;margin-bottom:.4rem;text-transform:uppercase;letter-spacing:.03em}.quick-add-modal input[type=date],.quick-add-modal select{width:100%;padding:.5rem;background:var(--color-muted-bg);border:1px solid var(--color-border);border-radius:4px;color:var(--color-text);font-size:.9rem}.quick-add-modal input[type=date]:focus,.quick-add-modal select:focus{outline:none;border-color:var(--color-muted-text)}.search-input-wrapper{display:flex;align-items:center;gap:.5rem;padding:.5rem .75rem;background:var(--color-muted-bg);border:1px solid var(--color-border);border-radius:4px}.search-input-wrapper svg{color:var(--color-muted-text);flex-shrink:0}.search-input-wrapper input{flex:1;background:transparent;border:none;color:var(--color-text);font-size:.9rem}.search-input-wrapper input::placeholder{color:#6b8a7a}.search-input-wrapper input:focus{outline:none}.search-input-wrapper:focus-within{border-color:var(--color-muted-text)}.absence-type-selector.compact{gap:.35rem}.absence-type-selector.compact .absence-type-btn{padding:.4rem .5rem;min-width:auto}.absence-type-selector.compact .absence-type-btn span{display:none}.employee-grid{display:flex;flex-wrap:wrap;gap:.4rem;max-height:250px;overflow-y:auto;padding:.5rem;background:var(--color-muted-bg);border-radius:6px;border:1px solid var(--color-border)}.employee-chip{display:flex;align-items:center;gap:.3rem;padding:.35rem .6rem;background:var(--color-muted-bg);border:1px solid var(--color-border);border-radius:4px;color:var(--color-muted-text);font-size:.8rem;cursor:pointer;transition:all .15s}.employee-chip:hover{border-color:var(--color-muted-text);color:var(--color-text)}.employee-chip.selected{background:var(--color-primary);border-color:var(--color-muted-text);color:#fff}.employee-chip.selected svg{color:var(--color-muted-text)}.loading-small{color:var(--color-muted-text);font-size:.85rem;padding:1rem;text-align:center}.no-employees{color:var(--color-muted-text);font-size:.85rem;padding:1rem;text-align:center;width:100%}.areas-list{display:grid;grid-template-columns:repeat(2,1fr);gap:.5rem;max-width:800px}.area-list-item{display:flex;align-items:center;gap:1rem;padding:.75rem 1rem;background:var(--color-muted-bg);border-radius:6px;cursor:pointer;transition:all .15s;border:1px solid transparent}.area-list-item:hover{background:#d4e5d7;border-color:var(--color-primary)}.area-list-name{flex:1;font-weight:500;color:var(--color-text)}.area-list-time{color:var(--color-muted-text);font-size:.85rem;min-width:50px}.area-list-manning{display:flex;align-items:center;gap:.3rem;color:var(--color-muted-text);font-size:.85rem;min-width:40px}.fy-label{display:flex;align-items:center;gap:.5rem;padding:.5rem 1rem;background:#d4e5d7;border-radius:6px;color:var(--color-text);font-weight:600;font-size:.9rem}.fy-label svg{color:var(--color-muted-text)}.employee-absence-list{background:var(--color-muted-bg);border-radius:8px;overflow:hidden;margin-bottom:1rem}.employee-absence-header{display:grid;grid-template-columns:2fr 1fr repeat(5,.7fr) .8fr;gap:.5rem;padding:.75rem 1rem;background:#d4e5d7;font-size:.75rem;font-weight:600;color:#3d5945;text-transform:uppercase;letter-spacing:.03em}.employee-absence-row{display:grid;grid-template-columns:2fr 1fr repeat(5,.7fr) .8fr;gap:.5rem;padding:.6rem 1rem;border-bottom:1px solid #d4e5d7;font-size:.9rem;color:var(--color-text);transition:background .15s}.employee-absence-row:hover{background:#dfe9e1}.employee-absence-row:last-child{border-bottom:none}.employee-absence-row.has-absences{background:#e76f510d}.employee-absence-row.has-absences:hover{background:#e76f511a}.employee-absence-row .col-name{font-weight:500}.employee-absence-row .col-role{color:var(--color-muted-text);font-size:.85rem}.employee-absence-row .col-stat{text-align:center;color:var(--color-muted-text)}.employee-absence-row .col-stat.sick{color:#e76f51;font-weight:600}.employee-absence-row .col-stat.no-show{color:#9b2226;font-weight:600}.employee-absence-row .col-stat.late{color:#f4a261;font-weight:600}.employee-absence-row .col-stat.left-early{color:#e9c46a;font-weight:600}.employee-absence-row .col-stat.other{color:#6c757d;font-weight:600}.employee-absence-row .col-total{text-align:center;font-weight:600;color:var(--color-muted-text)}.employee-absence-row .col-total.highlight{color:#e76f51}.employee-absence-header .col-stat,.employee-absence-header .col-total{text-align:center}.employee-absence-row.clickable{cursor:pointer}.employee-absence-row.clickable:hover{background:#2e6b441a}.employee-absence-row.clickable.has-absences:hover{background:#e76f5126}.employee-absence-modal{max-width:500px;width:95%}.employee-absence-modal h3{margin:0 0 1rem;color:var(--color-text);font-size:1.1rem}.employee-absence-summary{display:flex;flex-wrap:wrap;gap:.5rem;margin-bottom:1.25rem;padding-bottom:1rem;border-bottom:1px solid #d4e5d7}.summary-stat{display:flex;align-items:center;gap:.35rem;padding:.35rem .75rem;background:var(--color-muted-bg);border-radius:6px;font-size:.85rem;color:var(--color-text)}.summary-stat span:first-child{font-weight:500}.summary-stat.sick{background:#e76f5126;color:#e76f51}.summary-stat.no-show{background:#9b22261a;color:#9b2226}.summary-stat.late{background:#f4a26126;color:#d68a3d}.summary-stat.left-early{background:#e9c46a33;color:#b89830}.summary-stat.other{background:#6c757d1a;color:#6c757d}.employee-absence-dates h4{margin:0 0 .75rem;font-size:.95rem;color:var(--color-text)}.absence-date-list{max-height:300px;overflow-y:auto;display:flex;flex-direction:column;gap:.5rem}.absence-date-item{display:flex;justify-content:space-between;align-items:center;padding:.6rem .85rem;background:#f5f9f5;border-radius:6px;border:1px solid #d4e5d7}.absence-date-item .date-info{display:flex;flex-direction:column;gap:.15rem}.absence-date-item .date{font-weight:500;color:var(--color-text);font-size:.9rem}.absence-date-item .type{font-size:.8rem;color:var(--color-muted-text)}.absence-date-item .delete-btn{padding:.3rem .5rem;background:transparent;border:none;color:#9b2226;cursor:pointer;border-radius:4px;transition:all .15s}.absence-date-item .delete-btn:hover{background:#9b22261a}.absence-date-item{display:flex;align-items:center;gap:.75rem;padding:.75rem 1rem;background:#f5f9f5;border-radius:8px;border:1px solid #d4e5d7;border-left:3px solid var(--color-muted-text)}.absence-date-info{display:flex;flex-direction:column;gap:.35rem;flex:1}.absence-date{font-weight:500;color:var(--color-text);font-size:.9rem}.absence-type-badge{display:inline-flex;align-items:center;gap:.3rem;padding:.2rem .5rem;border-radius:4px;font-size:.75rem;color:#fff;width:fit-content}.absence-reason{font-size:.8rem;color:var(--color-muted-text);font-style:italic;max-width:150px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.delete-absence-btn{padding:.3rem;background:transparent;border:none;color:#9b2226;cursor:pointer;border-radius:4px;transition:all .15s;display:flex;align-items:center;justify-content:center}.delete-absence-btn:hover{background:#9b22261a}.no-absences,.no-absences-yet{padding:1.5rem;text-align:center;color:var(--color-muted-text);font-size:.9rem}.no-employees-message{padding:2rem;text-align:center;color:var(--color-muted-text);font-size:.9rem}.action-buttons{display:flex;gap:.75rem;justify-content:flex-end;padding:1rem 0}.action-buttons .btn-secondary,.action-buttons .btn-primary{display:flex;align-items:center;gap:.4rem;padding:.6rem 1.25rem;border-radius:6px;cursor:pointer;font-weight:500;font-size:.9rem;transition:all .2s}.action-buttons .btn-secondary{background:var(--color-muted-bg);border:1px solid var(--color-border);color:var(--color-text)}.action-buttons .btn-secondary:hover{background:#d4e5d7;border-color:var(--color-muted-text)}.action-buttons .btn-primary{background:var(--color-primary);border:none;color:#fff}.action-buttons .btn-primary:hover{background:#3d8a56}.stat-item.total{background:#d4e5d7;border-left-color:var(--color-primary)}.view-toggle .add-btn{background:var(--color-primary);color:#fff;padding:.4rem .75rem;font-size:.8rem}.view-toggle .add-btn:hover{background:#3d8a56}.employee-management{padding:1.5rem}.employee-management .page-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1.5rem}.employee-management .page-header h1{margin:0;color:var(--color-text);font-size:1.5rem}.employee-search{position:relative;margin-bottom:1.5rem;max-width:400px}.employee-search .search-icon{position:absolute;left:12px;top:50%;transform:translateY(-50%);color:var(--color-muted-text)}.employee-search input{width:100%;padding:.75rem 2.5rem .75rem 40px;background:var(--color-muted-bg);border:1px solid var(--color-border);border-radius:8px;color:var(--color-text);font-size:.95rem}.employee-search input:focus{outline:none;border-color:var(--color-border)}.employee-search input::placeholder{color:var(--color-muted-text)}.employee-search .clear-search{position:absolute;right:8px;top:50%;transform:translateY(-50%);background:transparent;border:none;color:var(--color-muted-text);cursor:pointer;padding:4px;display:flex;align-items:center;justify-content:center;border-radius:4px}.employee-search .clear-search:hover{color:var(--color-text);background:#ffffff1a}.work-area-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(500px,1fr));gap:1rem}.work-area-category{display:flex;flex-direction:column;gap:.5rem}.category-title{color:var(--color-muted-text);font-size:.85rem;font-weight:600;text-transform:uppercase;letter-spacing:.05em;margin:0 0 .15rem;padding-bottom:.2rem;border-bottom:1px solid var(--color-border)}.work-area-box{background:var(--color-muted-bg);border:1px solid var(--color-border);border-radius:8px;overflow:hidden}.work-area-box.collapsed{border-radius:8px}.work-area-header{display:flex;justify-content:space-between;align-items:center;padding:.4rem .75rem;background:var(--color-muted-bg);cursor:pointer;transition:background .15s}.work-area-header:hover{background:#fff}.work-area-header .header-left{display:flex;align-items:center;gap:.5rem;color:var(--color-text)}.work-area-header h3{margin:0;font-size:.85rem;font-weight:600}.work-area-header .employee-count{color:var(--color-muted-text);font-size:.75rem;margin:0}.work-area-content{padding:0}.employee-table{width:100%;border-collapse:collapse;font-size:.78rem;line-height:1.3}.employee-table th{padding:.25rem .5rem;text-align:left;background:var(--color-muted-bg);color:var(--color-muted-text);font-weight:600;font-size:.65rem;text-transform:uppercase;letter-spacing:.03em;border-bottom:1px solid var(--color-border)}.employee-table td{padding:.2rem .5rem;color:var(--color-text);vertical-align:middle}.employee-table tbody tr{border-bottom:none}.employee-table tbody tr:last-child{border-bottom:none}.employee-table tbody tr:hover{background:#2e6b440f}.employee-table .inactive-row{opacity:.5}.employee-table .employee-name{font-weight:500}.employee-table .employee-name .name-inner{display:flex;align-items:center;gap:.35rem}.employee-table .inactive-badge{font-size:.6rem;padding:.1rem .3rem;background:#fef2f2;color:var(--color-error);border-radius:3px}.employee-table .empty-value{color:var(--color-muted-text)}.employee-table .actions-col{width:90px;text-align:center}.level-badge{display:inline-block;padding:.1rem .35rem;background:#3d5a50;color:var(--color-muted-text);border-radius:3px;font-size:.68rem;font-weight:600}.contract-badge{display:inline-block;padding:.1rem .35rem;border-radius:3px;font-size:.68rem;font-weight:600}.contract-badge.full-time{background:var(--color-muted-bg);color:var(--color-muted-text)}.contract-badge.part-time{background:#4a4a2a;color:#c9c97a}.contract-badge.casual{background:var(--color-muted-bg);color:#7ac9c9}.role-badge{display:inline-block;padding:.1rem .35rem;border-radius:3px;font-size:.68rem;font-weight:600}.role-badge.team-leader{background:#1e3a5f;color:#bfdbfe}.role-badge.step-up{background:#4a4a2a;color:#c9c97a}.skill-badge{display:inline-block;padding:.1rem .35rem;border-radius:3px}.holistic-roster-view{display:flex;flex-direction:column;height:100vh;overflow-y:auto;overflow-x:hidden}.holistic-nav-bar{position:sticky;top:0;z-index:100;background:#fff;border-bottom:2px solid #e0e0e0;box-shadow:0 2px 8px #0000001a}.holistic-nav-header{display:flex;align-items:center;justify-content:space-between;padding:1rem 1.5rem;border-bottom:1px solid #e0e0e0}.holistic-nav-header h2{margin:0;display:flex;align-items:center;gap:.5rem;font-size:1.25rem;color:var(--color-sidebar-bg)}.holistic-nav-cards{display:flex;gap:.75rem;padding:1rem 1.5rem;overflow-x:auto;scrollbar-width:thin}.holistic-nav-cards::-webkit-scrollbar{height:6px}.holistic-nav-cards::-webkit-scrollbar-thumb{background:#888;border-radius:3px}.holistic-nav-card{min-width:140px;padding:.75rem 1rem;background:#f5f5f5;border:1px solid #ddd;border-radius:6px;cursor:pointer;transition:all .2s;display:flex;flex-direction:column;gap:.25rem}.holistic-nav-card:hover{background:var(--color-sidebar-text);border-color:var(--color-primary);transform:translateY(-2px);box-shadow:0 2px 6px #2e6b4433}.nav-card-name{font-size:.85rem;font-weight:600;color:var(--color-sidebar-bg)}.nav-card-manning{font-size:1.1rem;font-weight:700;color:var(--color-primary)}.nav-card-warnings{display:flex;align-items:center;gap:.25rem;font-size:.75rem;color:#d97706;margin-top:.25rem}.holistic-content{flex:1;overflow:visible;background:#fafafa}.holistic-areas-container{display:flex;flex-direction:column;gap:40px;padding:1.5rem}.holistic-area-section{background:#fff;border-radius:8px;box-shadow:0 2px 6px #00000014;overflow:hidden}.holistic-area-header{background:var(--color-sidebar-bg);color:#fff;padding:.75rem 1rem;border-bottom:2px solid var(--color-primary);position:sticky;left:0;z-index:10}.holistic-area-header h3{margin:0;font-size:1.1rem;font-weight:600}.holistic-area-wrapper{overflow-x:auto;overflow-y:visible}.holistic-area-wrapper::-webkit-scrollbar{height:10px}.holistic-area-wrapper::-webkit-scrollbar-track{background:#f1f1f1}.holistic-area-wrapper::-webkit-scrollbar-thumb{background:#888;border-radius:5px}.holistic-area-wrapper::-webkit-scrollbar-thumb:hover{background:#555}.week-grid-table.holistic-grid{min-width:max-content}.week-header-row .week-header-cell{background:var(--color-primary);color:#fff;text-align:center;font-size:.9rem;font-weight:600;padding:.5rem;border-left:2px solid #1a5c30}.week-header-row .week-header-cell.current-week{background:#1a5c30;font-weight:700}.week-header-row .week-header-cell:first-child{border-left:none}.week-header-row .week-date-subheader{font-size:.8rem;font-weight:400;opacity:.9;margin-top:.25rem}.week-grid-table .sticky-employee-header,.week-grid-table .sticky-employee-col{position:sticky!important;left:0!important;z-index:20!important;box-shadow:2px 0 4px #0000001a}.week-grid-table thead .sticky-employee-header{z-index:25!important;background:#3d805a!important}.week-grid-table .wg-totals-row .sticky-employee-col{background:#f9fafb!important;z-index:21!important}.day-header-row{background:#3d805a}.day-header-row .wg-day-col{background:#3d805a;color:#fff}.holistic-view-loading,.holistic-view-error{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:400px;padding:2rem;gap:1rem}.holistic-view-loading p,.holistic-view-error p{font-size:1.1rem;color:#666}.holistic-view-loading .spinner{animation:spin 1s linear infinite}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.holistic-view-error{color:#dc2626}.message-banner{padding:.75rem 1rem;border-radius:4px;margin-bottom:.5rem;font-size:.95rem}.message-banner.success{background:#d1fae5;color:#065f46;border:1px solid #34d399}.message-banner.error{background:#fee2e2;color:#991b1b;border:1px solid #f87171}.status-summary-inline{display:flex;gap:.5rem;align-items:center;flex-wrap:wrap}.status-count{display:inline-flex;align-items:center;gap:.25rem;padding:.25rem .5rem;border-radius:4px;font-size:.85rem;font-weight:600}.status-count.draft{background:#fef3c7;color:#92400e}.status-count.pending{background:#dbeafe;color:#1e3a8a}.status-count.published,.status-count.confirmed{background:#d1fae5;color:#065f46}.area-action-bar{padding:.75rem 1rem;background:#f5f5f5;border-bottom:1px solid #e0e0e0;display:flex;justify-content:space-between;align-items:center}.holistic-nav-card.has-error{border-color:#dc2626;background:#fee2e2}.holistic-nav-card.has-error:hover{background:#fecaca}.wg-day-cell.editable{position:relative}.wg-day-cell.editable:hover{box-shadow:inset 0 0 0 2px #3b82f6}.delete-entry-btn{position:absolute;top:2px;right:2px;width:16px;height:16px;padding:0;border:none;background:#dc2626;color:#fff;border-radius:3px;cursor:pointer;font-size:10px;line-height:16px;display:flex;align-items:center;justify-content:center;opacity:.8;transition:opacity .15s}.delete-entry-btn:hover{opacity:1}.action-buttons{display:flex;justify-content:center;gap:.25rem}.btn-icon{background:transparent;border:none;padding:.25rem;cursor:pointer;color:var(--color-muted-text);border-radius:4px;transition:all .15s}.holistic-top-nav-bar{position:sticky;top:0;z-index:999;background:#fff;border-bottom:2px solid #e0e0e0;box-shadow:0 2px 8px #0000001a;display:flex;align-items:center;gap:1rem;padding:.75rem 1rem;overflow-x:auto;white-space:nowrap}.holistic-nav-title{display:flex;align-items:center;gap:.5rem;font-weight:700;font-size:1rem;color:#1e293b;flex-shrink:0}.holistic-nav-shortcuts{display:flex;gap:.5rem;flex-grow:1;overflow-x:auto;padding:.25rem 0}.holistic-nav-shortcuts::-webkit-scrollbar{height:4px}.holistic-nav-shortcuts::-webkit-scrollbar-track{background:#f1f1f1}.holistic-nav-shortcuts::-webkit-scrollbar-thumb{background:#cbd5e1;border-radius:2px}.holistic-nav-shortcut{flex-shrink:0;min-width:100px;padding:.5rem .75rem;background:#f8fafc;border:1px solid #e2e8f0;border-radius:6px;cursor:pointer;transition:all .2s}.holistic-nav-shortcut:hover{background:#e0f2fe;border-color:#0ea5e9;transform:translateY(-1px);box-shadow:0 2px 6px #0000001a}.holistic-nav-shortcut.has-error{border-color:#dc2626;background:#fee2e2}.nav-shortcut-name{font-size:.75rem;font-weight:600;color:#1e293b;margin-bottom:.15rem}.nav-shortcut-manning{font-size:.7rem;color:#64748b}.holistic-nav-actions{display:flex;gap:.5rem;align-items:center;flex-shrink:0;margin-left:auto}.area-action-bar-sticky{position:relative;padding:.5rem 1rem;background:#f5f5f5f2;border-bottom:1px solid #e0e0e0;display:flex;justify-content:space-between;align-items:center}.wg-total-col{background:#f0f4f8!important;font-weight:700;font-size:.75rem;text-transform:uppercase;letter-spacing:.05em;color:#475569;padding:.5rem!important;text-align:center;border-left:3px solid #cbd5e1!important;position:sticky!important;z-index:15}.wg-total-cell{background:#f8fafc!important;font-weight:700;font-size:.9rem;text-align:center;padding:.5rem!important;color:#334155;border-left:3px solid #cbd5e1!important}.wg-total-cell.low{background:#fef3c7!important;color:#92400e}.wg-total-cell.high{background:#d1fae5!important;color:#065f46}.week-grid-table .sticky-employee-col{position:sticky!important;left:0!important;z-index:20!important;background:#fff!important;box-shadow:2px 0 4px #00000014!important}.week-grid-table .sticky-employee-header{position:sticky!important;left:0!important;top:0!important;z-index:25!important;background:#fff!important;box-shadow:2px 2px 4px #0000001a!important}.holistic-area-placeholder{min-height:400px;display:flex;align-items:center;justify-content:center;background:#f9f9f9;color:#888}.holistic-roster-view{overflow-y:auto;overflow-x:hidden;height:100vh}.holistic-content{overflow:visible;padding-bottom:2rem}.holistic-area-section{margin-bottom:3rem;border:1px solid #e0e0e0;border-radius:8px;overflow:hidden;background:#fff}.holistic-area-header{display:flex;align-items:center;gap:1rem;padding:1rem;background:#f8fafc;border-bottom:2px solid #e2e8f0}.holistic-area-header h3{margin:0;font-size:1.1rem;color:#1e293b}.holistic-area-header .area-meta{display:flex;align-items:center;gap:.5rem;color:#64748b;font-size:.85rem}.holistic-area-actions{display:flex;gap:.5rem;margin-left:auto}.btn-generate-small,.btn-publish-small,.btn-refresh-area{display:flex;align-items:center;gap:.25rem;padding:.4rem .75rem;font-size:.85rem;border:none;border-radius:6px;cursor:pointer;transition:all .2s}.btn-generate-small{background:#fbbf24;color:#78350f}.btn-generate-small:hover:not(:disabled){background:#f59e0b}.btn-publish-small{background:#10b981;color:#fff}.work-area-patterns-list{display:flex;flex-direction:column;gap:1rem;margin-top:1rem}.pattern-card{background:#fff;border:1px solid #e5e7eb;border-radius:8px;padding:1rem;box-shadow:0 1px 2px #0000000d}.pattern-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:.75rem;padding-bottom:.75rem;border-bottom:1px solid #e5e7eb}.pattern-header h3{margin:0;font-size:1rem;font-weight:600;color:#1f2937}.pattern-toggle{display:flex;align-items:center;gap:.5rem;font-size:.875rem;cursor:pointer;-webkit-user-select:none;user-select:none}.pattern-toggle input[type=checkbox]{cursor:pointer;width:1rem;height:1rem}.pattern-toggle input[type=checkbox]:checked{accent-color:#10b981}.pattern-config{display:flex;flex-direction:column;gap:.75rem}.pattern-row{display:flex;gap:1rem;flex-wrap:wrap}.pattern-input-group{display:flex;flex-direction:column;gap:.25rem;flex:1;min-width:120px}.pattern-input-group label{font-size:.75rem;font-weight:500;color:#6b7280;text-transform:uppercase;letter-spacing:.025em}.pattern-input-group input[type=number]{padding:.5rem;border:1px solid #d1d5db;border-radius:6px;font-size:.875rem;transition:border-color .2s}.pattern-input-group input[type=number]:focus{outline:none;border-color:#10b981;box-shadow:0 0 0 3px #10b9811a}.pattern-input-group input[type=number]:disabled{background:#f3f4f6;cursor:not-allowed}.pattern-preview{display:flex;align-items:center;gap:.5rem;padding:.75rem;background:#f9fafb;border-radius:6px;font-size:.875rem}.pattern-preview .preview-label{font-weight:600;color:#6b7280}.pattern-preview .preview-text{color:#1f2937;font-family:Courier New,monospace}.loading-inline{padding:2rem;text-align:center;color:#6b7280;font-size:.875rem}.btn-delete-schedule{display:flex;align-items:center;justify-content:center;padding:.25rem;background:transparent;border:none;color:#ef4444;cursor:pointer;border-radius:4px;transition:all .2s}.btn-delete-schedule:hover:not(:disabled){background:#fee2e2}.btn-delete-schedule:disabled{cursor:not-allowed;opacity:.4}.modal-overlay{position:fixed;inset:0;background:#00000080;display:flex;align-items:center;justify-content:center;z-index:1000}.modal-content{background:#fff;border-radius:12px;box-shadow:0 20px 25px -5px #0000001a,0 10px 10px -5px #0000000a;max-width:500px;width:90%;max-height:80vh;overflow-y:auto}.modal-header{display:flex;justify-content:space-between;align-items:center;padding:1.25rem;border-bottom:1px solid #e5e7eb}.modal-header h3{margin:0;font-size:1.125rem;font-weight:600;color:#1f2937}.modal-close{background:transparent;border:none;color:#6b7280;cursor:pointer;padding:.25rem;border-radius:4px;transition:all .2s}.modal-close:hover{background:#f3f4f6;color:#1f2937}.modal-body{padding:1.25rem;display:flex;flex-direction:column;gap:1rem}.modal-description{margin:0;font-size:.875rem;color:#6b7280}.form-group{display:flex;flex-direction:column;gap:.5rem}.form-group label{font-size:.875rem;font-weight:500;color:#374151}.form-group input[type=number]{padding:.5rem;border:1px solid #d1d5db;border-radius:6px;font-size:.875rem}.form-group input[type=number]:focus{outline:none;border-color:#10b981;box-shadow:0 0 0 3px #10b9811a}.day-toggles{display:flex;gap:.5rem;flex-wrap:wrap}.preview-box{padding:.75rem;background:#f9fafb;border-radius:6px;border:1px solid #e5e7eb;font-size:.875rem;color:#1f2937}.modal-footer{display:flex;justify-content:flex-end;gap:.75rem;padding:1rem 1.25rem;border-top:1px solid #e5e7eb}.btn-secondary{padding:.5rem 1rem;font-size:.875rem;background:#fff;border:1px solid #d1d5db;border-radius:6px;cursor:pointer;transition:all .2s}.btn-secondary:hover:not(:disabled){background:#f3f4f6}.btn-secondary:disabled{cursor:not-allowed;opacity:.5}.btn-publish-small:hover:not(:disabled){background:#059669}.btn-refresh-area{background:#e2e8f0;color:#475569}.btn-refresh-area:hover:not(:disabled){background:#cbd5e1}.btn-generate-small:disabled,.btn-publish-small:disabled,.btn-refresh-area:disabled{opacity:.5;cursor:not-allowed}.holistic-week-table-wrapper{overflow-x:auto;overflow-y:visible;position:relative}.week-group-header{background:#166534!important;color:#fff!important;font-weight:700!important;font-size:.85rem!important;padding:.5rem!important;text-align:center!important;border-bottom:2px solid #14532d!important}.week-total-header{background:#dcfce7!important;font-weight:700!important;font-size:.7rem!important;padding:.5rem!important;text-align:center!important;border-left:3px solid #16a34a!important;color:#065f46!important}.week-total-cell{background:var(--color-muted-bg)!important;font-weight:700!important;font-size:.85rem!important;text-align:center!important;padding:.5rem!important;border-left:3px solid #16a34a!important;min-width:45px!important}.week-total-cell.low{background:#fdd458!important;color:#1d1500!important}.week-total-cell.high{background:#ff5654!important;color:#fff!important}.wg-day-col.week-start{border-left:4px solid #16a34a!important;position:relative}.week-separator-header{position:absolute;top:-20px;left:0;right:0;background:#16a34a;color:#fff;font-size:.7rem;font-weight:700;text-align:center;padding:2px 4px;border-radius:4px 4px 0 0;letter-spacing:.03em}.wg-day-cell.week-start{border-left:4px solid #16a34a!important}.holistic-week-table .wg-employee-col{position:sticky!important;left:0!important;z-index:25!important;background:#fff!important;box-shadow:2px 0 4px #00000014!important}.holistic-week-table .wg-employee-cell{position:sticky!important;left:0!important;z-index:20!important;background:#fff!important;box-shadow:2px 0 4px #00000014!important}.holistic-week-table{width:max-content;min-width:100%;border-collapse:collapse}.holistic-week-table thead th{position:sticky;top:0;z-index:15;background:#fff;padding-top:24px}.holistic-day{min-width:70px;font-size:.75rem}.error-text{color:#dc2626;font-size:.85rem}.btn-icon:hover{background:#2e6b4433;color:var(--color-text)}.btn-icon.danger:hover{background:#e0747433;color:var(--color-error)}.btn-icon:disabled{opacity:.3;cursor:not-allowed}.employee-form-modal{max-width:600px;width:90%;max-height:85vh;overflow-y:auto}.employee-form-modal h3{margin:0 0 1rem;color:var(--color-text);font-size:1.15rem}.employee-form-modal .form-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:.6rem}.employee-form-modal .form-group{display:flex;flex-direction:column;gap:.2rem}.employee-form-modal .form-group label{color:var(--color-muted-text);font-size:.75rem;font-weight:500}.employee-form-modal .form-group input,.employee-form-modal .form-group select{padding:.4rem .6rem;background:var(--color-muted-bg);border:1px solid var(--color-border);border-radius:5px;color:var(--color-text);font-size:.85rem}.employee-form-modal .form-group input:focus,.employee-form-modal .form-group select:focus{outline:none;border-color:var(--color-border)}.form-hint{display:block;margin-top:.25rem;font-size:.72rem;color:#7a9a82;line-height:1.4}.employee-form-modal .checkbox-group{flex-direction:row;align-items:center}.employee-form-modal .checkbox-group label{display:flex;align-items:center;gap:.5rem;cursor:pointer}.employee-form-modal .checkbox-group input[type=checkbox]{width:16px;height:16px;accent-color:var(--color-primary)}.toast-container{position:fixed;bottom:1.5rem;right:1.5rem;z-index:99999;display:flex;flex-direction:column;gap:.5rem;pointer-events:none;max-width:380px;width:calc(100vw - 3rem)}.toast{display:flex;align-items:flex-start;gap:.6rem;padding:.75rem .9rem;border-radius:8px;font-size:.875rem;font-weight:500;line-height:1.4;box-shadow:0 4px 16px #0000002e;animation:toast-in .18s ease forwards;pointer-events:all}.toast-success{background:var(--color-primary);color:#fff}.toast-error{background:var(--color-error);color:#fff}.toast-info{background:var(--color-sidebar-bg);color:var(--color-sidebar-text)}.toast-icon{flex-shrink:0;margin-top:1px;opacity:.9}.toast-message{flex:1}.toast-dismiss{flex-shrink:0;background:none;border:none;color:inherit;opacity:.65;cursor:pointer;padding:0;line-height:1;margin-left:auto;transition:opacity .15s;border-radius:4px}.toast-dismiss:hover{opacity:1;border-color:transparent}@keyframes toast-in{0%{opacity:0;transform:translateY(6px)}to{opacity:1;transform:translateY(0)}}@keyframes skeleton-pulse{0%,to{opacity:1}50%{opacity:.45}}.skeleton{background:var(--color-muted-bg);border-radius:4px;animation:skeleton-pulse 1.4s ease-in-out infinite}.skeleton-row{display:flex;align-items:center;gap:.75rem;padding:.65rem 1rem;border-bottom:1px solid var(--color-border)}.skeleton-avatar{width:32px;height:32px;border-radius:50%;flex-shrink:0}.skeleton-lines{flex:1;display:flex;flex-direction:column;gap:.35rem}.skeleton-line{height:10px;border-radius:4px}.skeleton-line-short{width:40%}.skeleton-line-med{width:65%}.skeleton-line-long{width:85%}.skeleton-badge{width:52px;height:20px;border-radius:10px;flex-shrink:0}.skeleton-section-header{display:flex;align-items:center;gap:.75rem;padding:.6rem 1rem;background:var(--color-muted-bg);border-bottom:1px solid var(--color-border)}.skeleton-section-label{height:12px;width:120px;border-radius:4px}.skeleton-cell{height:44px;border-radius:4px;flex:1}.skeleton-roster-row{display:flex;gap:.5rem;padding:.4rem;border-bottom:1px solid var(--color-border)}.skeleton-name-col{width:160px;height:36px;border-radius:4px;flex-shrink:0}.skeleton-day-col{flex:1;height:36px;border-radius:4px}.employee-form-modal .form-actions{display:flex;justify-content:flex-end;gap:.75rem;margin-top:1rem;padding-top:.75rem;border-top:1px solid var(--color-border)}.employee-table .delete-confirm{display:flex;justify-content:center;gap:.25rem}@media(max-width:1200px){.work-area-grid{grid-template-columns:1fr}}@media(max-width:600px){.employee-form-modal .form-grid{grid-template-columns:1fr}.employee-table{font-size:.8rem}.employee-table th,.employee-table td{padding:.4rem .5rem}}.emp-page-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:1rem;gap:1rem;flex-wrap:wrap}.emp-page-title{display:flex;align-items:baseline;gap:.75rem}.emp-page-title h1{margin:0}.emp-total-count{font-size:.8rem;color:var(--color-muted-text);font-weight:400}.emp-pending-badges{display:flex;gap:6px}.emp-pending-badge{display:inline-flex;align-items:center;gap:5px;padding:5px 12px;border-radius:20px;font-size:.78rem;font-weight:500;cursor:pointer;border:1px solid;transition:opacity .15s}.emp-pending-badge:disabled{opacity:.5;cursor:not-allowed}.emp-pending-badge.transfers{background:#3b82f614;border-color:#3b82f64d;color:#2563eb}.emp-pending-badge.transfers:hover:not(:disabled){background:#3b82f624}.emp-pending-badge.removals{background:#ef444412;border-color:#ef444440;color:#dc2626}.emp-pending-badge.removals:hover:not(:disabled){background:#ef444421}.emp-toolbar{display:flex;align-items:center;gap:8px;margin-bottom:1rem;flex-wrap:wrap}.emp-toolbar-spacer{flex:1;min-width:8px}.emp-search-wrap{position:relative;display:flex;align-items:center;min-width:220px;flex:1;max-width:340px}.emp-search-icon{position:absolute;left:10px;color:var(--color-muted-text);pointer-events:none;flex-shrink:0}.emp-search-input{width:100%;padding:10px 36px;border:1px solid var(--color-border);border-radius:7px;background:#fff;font-size:.9rem;color:var(--color-text);transition:border-color .15s}.emp-search-input:focus{outline:none;border-color:var(--color-primary)}.emp-search-clear{position:absolute;right:8px;background:transparent;border:none;cursor:pointer;color:var(--color-muted-text);display:flex;padding:2px;border-radius:3px}.emp-search-clear:hover{color:var(--color-text)}.emp-filter-select{padding:9px 12px;border:1px solid var(--color-border);border-radius:7px;background:#fff;color:var(--color-text);font-size:.9rem;cursor:pointer;min-width:150px;transition:border-color .15s}.emp-filter-select:focus{outline:none;border-color:var(--color-primary)}.emp-contract-pills{display:flex;gap:3px;background:#0000000a;border-radius:7px;padding:3px}.emp-cpill{padding:6px 14px;border:none;background:transparent;border-radius:5px;font-size:.85rem;font-weight:500;color:var(--color-muted-text);cursor:pointer;transition:background .12s,color .12s;white-space:nowrap}.emp-cpill.active{background:#fff;color:var(--color-text);box-shadow:0 1px 3px #0000001a}.emp-cpill:hover:not(.active){color:var(--color-text)}.emp-actions{display:flex;gap:6px}.emp-action-btn{display:inline-flex;align-items:center;gap:6px;padding:9px 18px;border:none;border-radius:7px;font-size:.9rem;font-weight:600;cursor:pointer;transition:opacity .15s,transform .1s;color:#fff;white-space:nowrap}.emp-action-btn:hover{opacity:.88;transform:translateY(-1px)}.emp-action-btn:active{transform:translateY(0)}.emp-action-btn.add{background:var(--color-primary)}.emp-action-btn.remove{background:#dc2626}.emp-action-btn.transfer{background:#2563eb}.emp-empty{padding:3rem;text-align:center;color:var(--color-muted-text);font-size:.9rem}.emp-list{display:flex;flex-direction:column;gap:0}.emp-category{margin-bottom:1.25rem}.emp-category-label{font-size:.7rem;font-weight:700;text-transform:uppercase;letter-spacing:.06em;color:var(--color-muted-text);padding:0 4px;margin-bottom:4px}.emp-area-section{background:#fff;border:1px solid var(--color-border);border-radius:8px;margin-bottom:4px;overflow:hidden}.emp-area-heading{display:flex;align-items:center;gap:8px;padding:8px 12px;cursor:pointer;-webkit-user-select:none;user-select:none;transition:background .1s}.emp-area-heading:hover{background:#00000006}.emp-area-chevron{color:var(--color-muted-text);display:flex;flex-shrink:0}.emp-area-name{font-size:.875rem;font-weight:600;color:var(--color-text);flex:1}.emp-area-count{font-size:.72rem;font-weight:600;color:var(--color-muted-text);background:var(--color-muted-bg);padding:2px 7px;border-radius:10px}.emp-table-wrap{background:#fff;border:1px solid var(--color-border);border-radius:10px;overflow:hidden;overflow-x:auto}.emp-sheet{width:100%;border-collapse:collapse;font-size:1rem;min-width:1000px}.emp-sheet thead{position:sticky;top:0;z-index:2}.emp-th{padding:13px 16px;text-align:left;font-size:.73rem;font-weight:700;text-transform:uppercase;letter-spacing:.05em;color:var(--color-muted-text);background:#f6f7f8;border-bottom:1px solid var(--color-border);white-space:nowrap}.emp-th-sm{width:100px}.emp-th-actions{width:130px}.emp-row{border-bottom:1px solid rgba(0,0,0,.045);transition:background .08s}.emp-row:last-child{border-bottom:none}.emp-row:hover{background:#16653408}.emp-row-inactive{opacity:.48}.emp-td{padding:14px 16px;vertical-align:middle;color:var(--color-text);font-size:.925rem}.emp-td-name{font-weight:600;white-space:nowrap;min-width:160px;font-size:.95rem}.emp-td-trunc{max-width:200px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.emp-email-text{font-size:.875rem;color:var(--color-muted-text)}.emp-area-pill{font-size:.875rem;color:var(--color-text);white-space:nowrap}.emp-skills{display:flex;flex-wrap:wrap;gap:4px;min-width:90px}.emp-dash{color:var(--color-muted-text);opacity:.4}.emp-status-badge{display:inline-block;padding:4px 11px;border-radius:12px;font-size:.8rem;font-weight:600;white-space:nowrap}.emp-status-badge.active{background:#1665341a;color:#166534}.emp-status-badge.inactive{background:#0000000f;color:var(--color-muted-text)}.emp-td-actions-cell{white-space:nowrap}.emp-sheet .btn-icon{width:30px;height:30px;font-size:.85rem}.emp-empty-row{padding:3rem;text-align:center;color:var(--color-muted-text);font-size:.9rem}.view-modal{max-width:800px;width:95%}.absences-page{display:flex;flex-direction:column;gap:1rem}.abs-header{display:flex;align-items:flex-start;justify-content:space-between;gap:1rem;flex-wrap:wrap}.abs-header h1{margin:0 0 2px}.abs-fy-label{display:inline-flex;align-items:center;gap:4px;font-size:.8rem;color:var(--color-muted-text)}.abs-quick-add-btn{display:inline-flex;align-items:center;gap:6px;padding:9px 18px;background:var(--color-primary);color:#fff;border:none;border-radius:8px;font-size:.9rem;font-weight:600;cursor:pointer;transition:opacity .15s;white-space:nowrap;flex-shrink:0}.abs-quick-add-btn:hover{opacity:.88}.abs-toolbar{display:flex;align-items:center;gap:8px;flex-wrap:wrap}.abs-search-wrap{position:relative;display:flex;align-items:center;flex:1;min-width:200px;max-width:340px}.abs-search-icon{position:absolute;left:10px;color:var(--color-muted-text);pointer-events:none}.abs-search-input{width:100%;padding:9px 34px;border:1px solid var(--color-border);border-radius:7px;background:#fff;font-size:.9rem;color:var(--color-text)}.abs-search-input:focus{outline:none;border-color:var(--color-primary)}.abs-search-clear{position:absolute;right:8px;background:transparent;border:none;cursor:pointer;color:var(--color-muted-text);display:flex;padding:2px}.abs-search-clear:hover{color:var(--color-text)}.abs-search-btn{padding:9px 16px;background:var(--color-primary);color:#fff;border:none;border-radius:7px;font-size:.875rem;font-weight:600;cursor:pointer;transition:opacity .15s;white-space:nowrap}.abs-search-btn:hover{opacity:.88}.abs-area-drop{position:relative}.abs-area-btn{display:inline-flex;align-items:center;gap:6px;padding:9px 13px;border:1px solid var(--color-border);border-radius:7px;background:#fff;color:var(--color-text);font-size:.875rem;font-weight:500;cursor:pointer;transition:border-color .15s;white-space:nowrap}.abs-area-btn:hover{border-color:var(--color-primary)}.abs-area-btn.has-selection{border-color:var(--color-primary);color:var(--color-primary);background:#1665340d}.abs-area-panel{position:absolute;top:calc(100% + 4px);left:0;z-index:100;background:#fff;border:1px solid var(--color-border);border-radius:10px;box-shadow:0 8px 24px #0000001f;min-width:220px;max-height:380px;overflow-y:auto;padding:8px 0}.abs-area-panel-head{display:flex;align-items:center;justify-content:space-between;padding:6px 14px 8px;font-size:.75rem;font-weight:700;text-transform:uppercase;letter-spacing:.05em;color:var(--color-muted-text);border-bottom:1px solid var(--color-border);margin-bottom:4px}.abs-area-clear{background:transparent;border:none;font-size:.75rem;color:var(--color-primary);cursor:pointer;font-weight:600}.abs-area-group{padding:4px 0}.abs-area-group-label{display:flex;align-items:center;gap:7px;padding:5px 14px;font-size:.8rem;font-weight:700;color:var(--color-text);cursor:pointer;-webkit-user-select:none;user-select:none}.abs-area-group-label:hover{background:#00000008}.abs-area-item{display:flex;align-items:center;gap:7px;padding:4px 14px 4px 28px;font-size:.82rem;color:var(--color-text);cursor:pointer;-webkit-user-select:none;user-select:none}.abs-area-item:hover{background:#00000006}.abs-area-item input,.abs-area-group-label input{accent-color:var(--color-primary);cursor:pointer}.abs-stats-row{display:flex;gap:10px;flex-wrap:wrap}.abs-stat-card{background:#fff;border:1px solid var(--color-border);border-radius:10px;padding:14px 18px;min-width:140px;flex:1}.abs-stat-primary{border-color:#1665344d;background:#16653408}.abs-stat-value{font-size:1.6rem;font-weight:800;color:var(--color-text);line-height:1;margin-bottom:4px;display:flex;align-items:center;gap:5px}.abs-stat-primary .abs-stat-value{color:var(--color-primary)}.abs-stat-label{font-size:.72rem;font-weight:700;text-transform:uppercase;letter-spacing:.05em;color:var(--color-muted-text);margin-bottom:4px}.abs-stat-sub{font-size:.75rem;color:var(--color-muted-text)}.abs-stat-type-pills{display:flex;flex-wrap:wrap;gap:4px;margin-top:6px}.abs-type-pill{display:inline-flex;align-items:center;gap:3px;padding:2px 7px;border-radius:10px;border:1px solid;font-size:.72rem;font-weight:600}.abs-table-wrap{background:#fff;border:1px solid var(--color-border);border-radius:10px;overflow:hidden;overflow-x:auto}.abs-sheet{width:100%;border-collapse:collapse;font-size:.9rem;min-width:800px}.abs-sheet thead{position:sticky;top:0;z-index:2}.abs-th{padding:11px 14px;text-align:left;font-size:.7rem;font-weight:700;text-transform:uppercase;letter-spacing:.05em;color:var(--color-muted-text);background:#f6f7f8;border-bottom:1px solid var(--color-border);white-space:nowrap}.abs-th-type{width:70px;text-align:center}.abs-th-total{width:65px;text-align:center}.abs-th-add{width:44px}.abs-row{border-bottom:1px solid rgba(0,0,0,.04);transition:background .08s}.abs-row:last-child{border-bottom:none}.abs-row:hover{background:#00000005}.abs-row-has:hover{background:#1665340a}.abs-row-repeat{background:#dc262605}.abs-row-repeat:hover{background:#dc26260d}.abs-td{padding:12px 14px;vertical-align:middle;color:var(--color-text)}.abs-td-name{font-weight:600;white-space:nowrap;display:flex;align-items:center;gap:5px}.abs-td-area{font-size:.82rem;color:var(--color-muted-text);white-space:nowrap}.abs-td-num{text-align:center;font-size:.9rem;font-weight:500;color:var(--color-muted-text)}.abs-td-total{text-align:center}.abs-td-date{font-size:.82rem;color:var(--color-muted-text);white-space:nowrap}.abs-total-badge{display:inline-block;min-width:24px;padding:2px 8px;background:#1665341a;color:var(--color-primary);border-radius:10px;font-size:.82rem;font-weight:700;text-align:center}.abs-row-repeat .abs-total-badge{background:#dc26261a;color:#dc2626}.abs-repeat-flag{color:#dc2626;display:flex;flex-shrink:0}.abs-add-row-btn{display:flex;align-items:center;justify-content:center;width:26px;height:26px;border-radius:5px;border:1px solid var(--color-border);background:transparent;color:var(--color-muted-text);cursor:pointer;transition:all .12s}.abs-add-row-btn:hover{background:var(--color-primary);color:#fff;border-color:var(--color-primary)}.abs-empty-row{padding:3rem;text-align:center;color:var(--color-muted-text)}.abs-toolbar-spacer{flex:1;min-width:8px}.abs-period-toggle{display:flex;gap:3px;background:#0000000d;border-radius:8px;padding:3px}.abs-period-btn{padding:5px 12px;border:none;background:transparent;border-radius:5px;font-size:.8rem;font-weight:500;color:var(--color-muted-text);cursor:pointer;transition:background .12s,color .12s;white-space:nowrap}.abs-period-btn.active{background:var(--color-primary);color:#fff}.abs-period-btn:hover:not(.active){background:#0000000f;color:var(--color-text)}.abs-gauges-section{background:#fff;border:1px solid var(--color-border);border-radius:12px;padding:1.25rem 1.5rem}.abs-gauges-header{display:flex;align-items:baseline;gap:12px;margin-bottom:1.25rem;flex-wrap:wrap}.abs-gauges-title{font-size:.95rem;font-weight:700;color:var(--color-text)}.abs-gauges-period{font-size:.78rem;color:var(--color-muted-text)}.abs-gauges-note{font-size:.75rem;color:var(--color-muted-text);font-style:italic}.abs-gauges-row{display:flex;gap:1rem;flex-wrap:wrap;justify-content:space-around}.abs-gauge{display:flex;flex-direction:column;align-items:center;gap:6px;flex:1;min-width:110px;max-width:160px}.abs-gauge-svg-wrap{position:relative;display:inline-flex;align-items:center;justify-content:center}.abs-gauge-center{position:absolute;inset:0;display:flex;align-items:center;justify-content:center}.abs-gauge-pct{font-size:1rem;font-weight:800;line-height:1}.abs-gauge-label{font-size:.78rem;font-weight:600;color:var(--color-text);text-align:center}.abs-gauge-sub{font-size:.68rem;color:var(--color-muted-text);text-align:center;line-height:1.3}.abs-insights-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1rem}@media(max-width:1100px){.abs-insights-grid{grid-template-columns:1fr 1fr}}@media(max-width:700px){.abs-insights-grid{grid-template-columns:1fr}}.abs-insight-card{background:#fff;border:1px solid var(--color-border);border-radius:12px;padding:1.1rem 1.25rem;display:flex;flex-direction:column;gap:6px}.abs-insight-title{font-size:.875rem;font-weight:700;color:var(--color-text)}.abs-insight-sub{font-size:.75rem;color:var(--color-muted-text);margin-bottom:8px}.abs-insight-empty{font-size:.82rem;color:var(--color-muted-text);padding:1rem 0;text-align:center}.abs-cal-wrap{display:flex;flex-direction:column;gap:10px}.abs-cal-months{display:flex;flex-direction:column;gap:14px}.abs-cal-months-grid{display:grid;grid-template-columns:1fr 1fr;gap:12px}.abs-cal-nav{display:flex;align-items:center;justify-content:space-between;margin-bottom:8px}.abs-cal-nav-btn{background:transparent;border:1px solid var(--color-border);border-radius:5px;width:26px;height:26px;display:flex;align-items:center;justify-content:center;cursor:pointer;font-size:1rem;color:var(--color-muted-text);line-height:1;transition:background .12s,color .12s}.abs-cal-nav-btn:hover:not(:disabled){background:var(--color-muted-bg);color:var(--color-text)}.abs-cal-nav-btn:disabled{opacity:.3;cursor:not-allowed}.abs-cal-month-label{font-size:.75rem;font-weight:700;text-align:center;color:var(--color-text);letter-spacing:.06em;flex:1}.abs-cal-grid{display:grid;grid-template-columns:repeat(7,1fr);gap:3px}.abs-cal-hdr{text-align:center;font-size:.65rem;font-weight:700;color:var(--color-muted-text);padding-bottom:3px}.abs-cal-cell{aspect-ratio:1;display:flex;align-items:center;justify-content:center;font-size:.72rem;font-weight:500;border-radius:50%;color:var(--color-text);cursor:default;transition:background .15s,color .15s;line-height:1}.abs-cal-cell:hover:not(.abs-cal-empty):not(.abs-cal-out){outline:2px solid rgba(0,0,0,.15);outline-offset:1px}.abs-cal-out{color:#d1d5db;font-weight:400}.abs-cal-hot{font-weight:700;cursor:help}.abs-cal-today{outline:2px solid var(--color-primary);outline-offset:1px}.abs-cal-months-grid .abs-cal-cell{font-size:.62rem}.abs-cal-months-grid .abs-cal-hdr{font-size:.58rem}.abs-cal-months-grid .abs-cal-month-label{font-size:.62rem}.abs-cal-legend{display:flex;align-items:center;gap:4px;font-size:.65rem;color:var(--color-muted-text)}.abs-cal-legend-swatch{width:11px;height:11px;border-radius:50%;flex-shrink:0}.abs-area-bars{display:flex;flex-direction:column;gap:7px;flex:1}.abs-area-bar-row{display:flex;align-items:center;gap:8px}.abs-area-bar-label{font-size:.75rem;font-weight:600;color:var(--color-text);width:100px;flex-shrink:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.abs-area-bar-track{flex:1;height:8px;background:#f3f4f6;border-radius:4px;overflow:hidden}.abs-area-bar-fill{height:100%;border-radius:4px;transition:width .4s ease}.abs-area-bar-pct{font-size:.75rem;font-weight:700;color:var(--color-text);width:38px;text-align:right;flex-shrink:0}.abs-offenders-list{display:flex;flex-direction:column;gap:8px;flex:1}.abs-offender-row{display:flex;align-items:center;gap:8px;cursor:pointer;padding:4px 6px;border-radius:6px;transition:background .1s}.abs-offender-row:hover{background:#0000000a}.abs-offender-rank{font-size:.72rem;font-weight:700;color:var(--color-muted-text);width:16px;flex-shrink:0}.abs-offender-info{flex:1;min-width:0}.abs-offender-name{display:block;font-size:.82rem;font-weight:600;color:var(--color-text);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.abs-offender-area{display:block;font-size:.7rem;color:var(--color-muted-text)}.abs-offender-bar-wrap{height:5px;background:#f3f4f6;border-radius:3px;margin-top:4px;overflow:hidden}.abs-offender-bar{height:100%;border-radius:3px;transition:width .4s ease}.abs-offender-count{font-size:.8rem;font-weight:800;color:var(--color-text);flex-shrink:0;min-width:20px;text-align:right}.abs-offender-count.high{color:#dc2626}.abs-table-header{display:flex;align-items:center;justify-content:space-between;padding:12px 16px;border-bottom:1px solid var(--color-border)}.abs-table-title{font-size:.875rem;font-weight:700;color:var(--color-text)}.abs-table-meta{font-size:.78rem;color:var(--color-muted-text)}.view-table{width:100%;border-collapse:collapse;margin-top:1rem}.view-table th,.view-table td{padding:.75rem;text-align:left;border-bottom:1px solid #444}.view-table th{background:var(--color-muted-bg);font-weight:600;color:var(--color-muted-text)}.view-table tbody tr:hover{background:var(--color-muted-bg)}.view-table .reason-termination{color:var(--color-error);font-weight:500}.week-grid-table thead th.wg-day-col,thead th.wg-day-col{width:75px!important;min-width:75px!important;max-width:75px!important;height:32px!important;max-height:32px!important;min-height:32px!important;padding:1px 2px!important;box-sizing:border-box!important;overflow:hidden!important;vertical-align:middle!important}thead th.wg-day-col .wg-day-name,thead th.wg-day-col .wg-day-num{font-size:.65rem!important;line-height:1.1!important;margin:0!important;padding:0!important;display:block!important}.view-table .reason-resigned{color:#e0b674;font-weight:500}.btn-cancel-action{padding:.375rem .75rem;font-size:.8rem;border:1px solid var(--color-error);border-radius:4px;background:transparent;color:var(--color-error);cursor:pointer;transition:all .2s}.btn-cancel-action:hover{background:#b5464633}.no-data{text-align:center;color:var(--color-muted-text);padding:2rem;font-style:italic}.bulk-modal{max-width:900px;width:95%}.bulk-modal h3{display:flex;align-items:center;gap:.75rem;margin:0 0 1rem;color:var(--color-text);font-size:1.25rem}.bulk-warning{background:#b5464626;border:1px solid rgba(181,70,70,.3);color:var(--color-error);padding:.75rem 1rem;border-radius:6px;margin-bottom:1rem;font-size:.9rem}.bulk-info{background:#4a7ab526;border:1px solid rgba(74,122,181,.3);color:#7ab5e0;padding:.75rem 1rem;border-radius:6px;margin-bottom:1rem;font-size:.9rem}.bulk-table-container{overflow-x:auto;margin-bottom:1rem;border:1px solid var(--color-border);border-radius:8px}.bulk-table{width:100%;border-collapse:collapse;font-size:.9rem}.bulk-table th{padding:.75rem;text-align:left;background:var(--color-muted-bg);color:var(--color-muted-text);font-weight:600;font-size:.8rem;text-transform:uppercase;letter-spacing:.03em;border-bottom:1px solid var(--color-border);white-space:nowrap}.bulk-table td{padding:.5rem;border-bottom:3px solid var(--color-muted-bg);color:var(--color-text);vertical-align:middle}.bulk-table tbody tr:last-child td{border-bottom:none}.bulk-table tbody tr:hover{background:#2e6b4414}.bulk-table .row-number{color:var(--color-muted-text);font-weight:600;width:30px;text-align:center}.bulk-table input,.bulk-table select{width:100%;padding:.5rem .6rem;background:var(--color-muted-bg);border:1px solid var(--color-border);border-radius:4px;color:var(--color-text);font-size:.85rem}.bulk-table input:focus,.bulk-table select:focus{outline:none;border-color:var(--color-border);background:#fff}.bulk-table input::placeholder{color:var(--color-muted-text)}.bulk-table input[type=date]{min-width:140px}.bulk-remove-modal{max-width:500px}.bulk-remove-modal .bulk-table select{min-width:300px}.bulk-modal .form-actions{display:flex;justify-content:flex-end;gap:.75rem;margin-top:1rem;padding-top:1rem;border-top:1px solid var(--color-border)}.btn-danger{background:linear-gradient(135deg,var(--color-error),#992222);color:var(--color-text);border:none;padding:.65rem 1.25rem;border-radius:6px;font-size:.9rem;font-weight:500;cursor:pointer;transition:all .15s}.btn-danger:hover{background:linear-gradient(135deg,var(--color-error),#b33333)}.btn-danger:disabled{opacity:.6;cursor:not-allowed}.no-employees{padding:.75rem;text-align:center;color:var(--color-muted-text);font-style:italic;font-size:.8rem}.draft-badge{display:inline-flex;align-items:center;gap:.25rem;padding:.2rem .6rem;background:#fef3cd;color:#856404;border:1px solid #ffc107;border-radius:12px;font-size:.75rem;font-weight:600;text-transform:uppercase;letter-spacing:.5px;margin-left:.5rem;vertical-align:middle}.btn-publish{display:inline-flex;align-items:center;gap:.4rem;padding:.5rem 1rem;background:#28a745;color:var(--color-text);border:none;border-radius:6px;font-size:.85rem;font-weight:600;cursor:pointer;transition:background .2s}.btn-publish:hover{background:#218838}.btn-publish:disabled{opacity:.6;cursor:not-allowed}.status-summary-inline{display:flex;gap:.75rem;align-items:center;flex-wrap:wrap}.status-count{display:inline-flex;align-items:center;gap:.25rem;font-size:.75rem;padding:.15rem .5rem;border-radius:10px;font-weight:500}.status-count.draft,.status-count.pending{background:#fff3cd;color:#856404}.status-count.published{background:#cce5ff;color:#004085}.status-count.confirmed{background:#d4edda;color:#155724}.status-count.declined{background:#f8d7da;color:#721c24}.status-count.awaiting-reoffer{background:#ffe5cc;color:#854d0e}.status-count.unfilled{background:#e2e3e5;color:#383d41}.status-draft{font-weight:600}.status-pending{background-color:#ffc10726!important;border-left:3px solid #ffc107!important}.status-declined{background-color:#dc354514!important}.status-awaiting-reoffer{background-color:#fd7e1414!important}.status-unfilled{background-color:#6c757d14!important}.status-confirmed{background-color:#28a7450f!important}.status-call-in-pending{background-color:#ffc1071f!important;border-left:3px solid #ffc107!important}.cell-status-dot{display:inline-block;font-size:.6rem;margin-left:.25rem;vertical-align:middle;line-height:1}.cell-status-dot.draft,.cell-status-dot.pending{color:#ffc107}.cell-status-dot.confirmed{color:#28a745}.cell-status-dot.declined{color:#dc3545}.cell-status-dot.awaiting-reoffer{color:#fd7e14}.cell-status-dot.unfilled{color:#6c757d}.cell-status-dot.call-in-pending{color:#ffc107;font-size:.55rem}.start-time-display.draft,.start-time-display.pending{opacity:.65}.start-time-display.call-in-pending{opacity:.7}.train-label{font-weight:700;font-size:.65rem;letter-spacing:.06em;color:#7a3200;line-height:1;text-align:center}.call-in-label{font-size:.5rem;font-weight:700;letter-spacing:.04em;color:#e67e22;line-height:1;margin-top:1px}.sent-away-label{font-size:.7rem;font-weight:700;color:var(--color-text);line-height:1;text-align:center;cursor:default;letter-spacing:.02em;white-space:nowrap}.wg-day-cell.sent-away{background:#1636220f;border:1px dashed rgba(22,54,34,.25)}.start-time-display.declined{opacity:.45;text-decoration:line-through;color:var(--color-muted-text)}.pending-offers-banner{background:linear-gradient(135deg,#e8f5e9,#f1f8e9);border:1px solid #81c784;border-radius:10px;padding:1rem 1.25rem;margin-bottom:1.25rem}.pending-offers-header{display:flex;align-items:center;gap:.5rem;color:#2e7d32;margin-bottom:.25rem}.pending-offers-header h3{margin:0;font-size:1rem;font-weight:600}.pending-offers-desc{font-size:.82rem;color:#558b2f;margin:0 0 .75rem}.pending-offers-list{display:flex;flex-direction:column;gap:.5rem}.offer-card{display:flex;align-items:center;justify-content:space-between;background:#fff;border:1px solid #c8e6c9;border-radius:8px;padding:.6rem .85rem;gap:.75rem}.offer-info{display:flex;align-items:center;gap:.6rem;flex-wrap:wrap}.offer-date{font-weight:600;font-size:.88rem;color:#333}.offer-time{font-size:.82rem;color:var(--color-muted-text);background:#f0f0f0;padding:.1rem .4rem;border-radius:4px}.offer-area{font-size:.78rem;color:#777}.offer-actions{display:flex;gap:.4rem;flex-shrink:0}.btn-accept{display:inline-flex;align-items:center;gap:.25rem;padding:.35rem .7rem;background:#28a745;color:var(--color-text);border:none;border-radius:5px;font-size:.8rem;font-weight:500;cursor:pointer;transition:background .15s}.btn-accept:hover{background:#218838}.btn-accept:disabled{opacity:.6;cursor:not-allowed}.btn-decline{display:inline-flex;align-items:center;gap:.25rem;padding:.35rem .7rem;background:#dc3545;color:var(--color-text);border:none;border-radius:5px;font-size:.8rem;font-weight:500;cursor:pointer;transition:background .15s}.btn-decline:hover{background:#c82333}.btn-decline:disabled{opacity:.6;cursor:not-allowed}.btn-sms{display:inline-flex;align-items:center;gap:.3rem;padding:.4rem .75rem;background:#17a2b8;color:var(--color-text);border:none;border-radius:5px;font-size:.82rem;font-weight:500;cursor:pointer;transition:background .15s}.btn-sms:hover{background:#138496}.btn-sms:disabled{opacity:.6;cursor:not-allowed}.analytics-range-picker{display:flex;gap:.4rem}.analytics-range-picker button{padding:.4rem .8rem;border:1px solid var(--color-border);border-radius:6px;background:#fff;color:var(--color-text);font-size:.8rem;cursor:pointer;transition:all .15s}.analytics-range-picker button:hover{background:var(--color-muted-bg)}.analytics-range-picker button.active{background:var(--color-primary);color:#fff;border-color:var(--color-primary)}.analytics-summary-cards{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:.75rem;margin-bottom:1.25rem}.analytics-card{display:flex;align-items:flex-start;gap:.75rem;background:#fff;border:1px solid var(--color-border);border-radius:8px;padding:.9rem 1rem}.analytics-card.warning{border-left:3px solid #f4a261}.analytics-card.alert{border-left:3px solid var(--color-error)}.analytics-card.info{border-left:3px solid #3b82f6}.analytics-card.success{border-left:3px solid var(--color-primary)}.analytics-card-icon{width:36px;height:36px;display:flex;align-items:center;justify-content:center;border-radius:8px;background:var(--color-muted-bg);color:var(--color-primary);flex-shrink:0}.analytics-card-icon.confirmed{background:var(--color-accent);color:var(--color-primary)}.analytics-card-icon.warning{background:#fef3e2;color:#d97706}.analytics-card-icon.alert{background:#fef2f2;color:var(--color-error)}.analytics-card-icon.info{background:#eff6ff;color:#3b82f6}.analytics-card-icon.success{background:var(--color-accent);color:var(--color-primary)}.analytics-card-body{flex:1;min-width:0}.analytics-card-value{font-size:1.5rem;font-weight:700;color:var(--color-text);line-height:1.2}.analytics-card-target{font-size:1rem;color:var(--color-muted-text);font-weight:400}.analytics-card-label{font-size:.75rem;text-transform:uppercase;color:var(--color-muted-text);letter-spacing:.3px;margin-top:.15rem}.analytics-card-sub{font-size:.72rem;color:#8a9e8f;margin-top:.1rem}.analytics-chart-section,.analytics-area-health,.analytics-area-detail{background:#fff;border:1px solid var(--color-border);border-radius:8px;padding:1rem 1.25rem;margin-bottom:1.25rem}.analytics-chart-section h2,.analytics-area-health h2,.analytics-area-detail h2{margin:0 0 .75rem;font-size:1rem;color:var(--color-text)}.analytics-chart-container{width:100%;margin-bottom:.5rem}.analytics-back-btn{display:inline-flex;align-items:center;gap:.3rem;background:none;border:1px solid var(--color-border);border-radius:6px;padding:.35rem .7rem;font-size:.8rem;color:var(--color-text);cursor:pointer;margin-bottom:.75rem}.analytics-back-btn:hover{background:var(--color-muted-bg)}.analytics-health-table-wrap,.analytics-detail-table-wrap{overflow-x:auto}.analytics-health-table,.analytics-detail-table{width:100%;border-collapse:collapse;font-size:.85rem}.analytics-health-table th,.analytics-detail-table th{background:var(--color-muted-bg);padding:.55rem .75rem;text-align:left;font-size:.72rem;text-transform:uppercase;color:var(--color-muted-text);letter-spacing:.3px;position:sticky;top:0;z-index:1}.analytics-health-table th.center,.analytics-health-table td.center,.analytics-detail-table th.center,.analytics-detail-table td.center{text-align:center}.analytics-health-table td,.analytics-detail-table td{padding:.5rem .75rem;border-bottom:1px solid #e8efe8}.analytics-health-row.clickable{cursor:pointer;transition:background .12s}.analytics-health-row.clickable:hover{background:#f5faf5}.analytics-area-name{font-weight:500;color:var(--color-text)}.analytics-detail-date{font-weight:500;color:var(--color-text);white-space:nowrap}.analytics-fill-pct{font-weight:600}.analytics-fill-pct.green{color:var(--color-primary)}.analytics-fill-pct.amber{color:#d97706}.analytics-fill-pct.red{color:var(--color-error)}.analytics-status-pill{display:inline-block;padding:.15rem .5rem;border-radius:4px;font-size:.72rem;font-weight:600}.analytics-status-pill.green{background:var(--color-accent);color:var(--color-primary)}.analytics-status-pill.amber{background:#fef3e2;color:#d97706}.analytics-status-pill.red{background:#fef2f2;color:var(--color-error)}.analytics-worst-day{font-size:.78rem;color:var(--color-error);white-space:nowrap}.analytics-detail-row.red td:first-child{border-left:3px solid var(--color-error)}.analytics-detail-row.amber td:first-child{border-left:3px solid #d97706}.analytics-detail-row.green td:first-child{border-left:3px solid var(--color-primary)}.dashboard-callin-section{background:#f8faf9;border:1px solid #e0e8e3;border-radius:8px;padding:1rem 1.2rem;margin-bottom:1.2rem}.dashboard-callin-section h2{font-size:.95rem;color:var(--color-text);margin:0 0 .8rem;display:flex;align-items:center;gap:.4rem}.dashboard-callin-empty{color:#888;font-size:.85rem;padding:.5rem 0}.dashboard-callin-list{display:flex;flex-direction:column;gap:.5rem}.dashboard-callin-item{display:flex;align-items:center;gap:.8rem;padding:.5rem .8rem;background:#fff;border-radius:6px;border:1px solid #e0e8e3;font-size:.85rem}.dashboard-callin-item.call_in{border-left:3px solid var(--color-primary)}.dashboard-callin-item.call_off{border-left:3px solid #e74c3c}.dashboard-callin-icon{color:#666}.dashboard-callin-info{display:flex;flex-direction:column;flex:1}.dashboard-callin-name{font-weight:600;color:var(--color-text)}.dashboard-callin-area{font-size:.78rem;color:#888}.dashboard-callin-type{font-size:.78rem;font-weight:600;padding:.2rem .5rem;border-radius:4px}.dashboard-callin-type.call_in{background:#e8f5e9;color:var(--color-primary)}.dashboard-callin-type.call_off{background:#fde8e8;color:#c0392b}.dashboard-callin-status{font-size:.75rem;text-transform:capitalize;color:#888}.dashboard-callin-status.accepted{color:var(--color-primary)}.dashboard-callin-status.declined{color:#c0392b}.dashboard-absences-today{background:#fff;border:1px solid #e0e8e3;border-radius:8px;padding:1rem 1.2rem;margin-bottom:1.2rem}.dashboard-absences-today h2{font-size:.95rem;color:var(--color-text);margin:0 0 .8rem;display:flex;align-items:center;gap:.4rem}.dashboard-absences-day{margin-bottom:1rem}.dashboard-absences-day:last-child{margin-bottom:0}.dashboard-absences-day h3{font-size:.85rem;font-weight:600;color:#3d5a45;margin:0 0 .5rem;padding-bottom:.3rem;border-bottom:1px solid #e8f0eb}.dashboard-absences-empty{color:#888;font-size:.85rem;padding:.5rem 0}.dashboard-absences-table{width:100%;border-collapse:collapse;font-size:.85rem}.dashboard-absences-table th{text-align:left;padding:.5rem .8rem;border-bottom:2px solid #e0e8e3;color:#666;font-weight:600;font-size:.78rem;text-transform:uppercase}.dashboard-absences-table td{padding:.5rem .8rem;border-bottom:1px solid #f0f0f0}.dashboard-absence-name{font-weight:600;color:var(--color-text)}.dashboard-absence-type{font-weight:600}.dashboard-absence-reason{color:#888;font-size:.82rem}.analytics-range-label{font-size:.9rem;color:#666}.print-roster-header{display:none}@media print{@page{size:A4 landscape;margin:8mm 6mm}*{-webkit-print-color-adjust:exact!important;print-color-adjust:exact!important}.sidebar,.roster-sticky-header,.roster-status-bar,.edit-mode-banner,.rh-dropdown-panel,.rh-dropdown-wrap,.area-select-panel,.toast-container,.modal-overlay,.modal-backdrop,.context-menu,.page-header,.no-data,.skeleton-roster-table,.rh-bar{display:none!important}body,html{background:#fff!important;overflow:visible!important}.main-content{margin-left:0!important;max-width:100%!important;width:100%!important;padding:0!important;overflow:visible!important}.roster-view{padding-top:0!important;padding-bottom:0!important;overflow:visible!important}.roster-week-view{overflow:visible!important;gap:0!important}.print-roster-header{display:block!important;margin-bottom:5mm;padding-bottom:4mm;border-bottom:2px solid #2e6b44;font-family:sans-serif}.print-roster-header-inner{display:flex;justify-content:space-between;align-items:flex-end}.print-roster-label{display:block;font-size:.65rem;text-transform:uppercase;letter-spacing:.08em;color:#5a7a61;margin-bottom:1mm}.print-roster-area{margin:0;font-size:1.2rem;font-weight:700;color:#163622}.print-roster-meta{text-align:right;font-size:.72rem;color:#555}.print-roster-range{font-weight:600;font-size:.8rem;color:#163622}.print-roster-fy{color:#5a7a61;margin-top:1mm}.print-roster-generated{color:#999;margin-top:1mm}.week-grid-container{display:flex!important;overflow:visible!important;break-inside:auto;page-break-inside:auto;border:2px solid #2e6b44!important;border-radius:0!important}.week-grid-employees-fixed{overflow:visible!important;flex-shrink:0!important;max-height:none!important;height:auto!important}.week-grid-wrapper{overflow:visible!important;flex:1!important;width:auto!important;min-width:0!important;max-height:none!important;height:auto!important}.week-grid-table,.week-grid-table-employees{overflow:visible!important;height:auto!important;max-height:none!important}.week-grid-table,.week-grid-table-employees{font-size:.68rem!important}.week-grid-table th,.week-grid-table td,.week-grid-table-employees th,.week-grid-table-employees td{padding:2px 3px!important}.week-grid-table tbody td,.week-grid-table-employees tbody td,.week-grid-table tbody tr,.week-grid-table-employees tbody tr{height:34px!important;min-height:34px!important;max-height:34px!important}.wg-day-cell{border-radius:3px!important}.week-grid-table tr,.week-grid-table-employees tr{break-inside:avoid;page-break-inside:avoid}.week-group-header-row{break-after:avoid;page-break-after:avoid}.skill-tag,.role-badge,.wg-role-badge{font-size:.55rem!important;padding:1px 3px!important}}
