*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}:root{--primary: #2563eb;--primary-dark: #1d4ed8;--error: #dc2626;--success: #16a34a;--bg: #f1f5f9;--surface: #ffffff;--border: #e2e8f0;--text: #1e293b;--text-muted: #64748b;--radius: 8px;--sidebar-w: 220px}body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;background:var(--bg);color:var(--text);line-height:1.5;min-height:100vh;-webkit-font-smoothing:antialiased}.login-container{display:flex;align-items:center;justify-content:center;min-height:100vh;padding:1rem}.login-card{background:var(--surface);border-radius:var(--radius);border:1px solid var(--border);padding:2rem;width:100%;max-width:380px;box-shadow:0 1px 3px #00000012}.login-card h1{font-size:1.5rem;font-weight:700;margin-bottom:1.75rem;text-align:center}.app-shell{display:flex;min-height:100vh}.sidebar{display:none}.mobile-header{position:fixed;top:0;left:0;right:0;height:52px;background:var(--surface);border-bottom:1px solid var(--border);display:flex;align-items:center;gap:.75rem;padding:0 1rem;z-index:20}.mobile-title{font-weight:700;font-size:1rem;flex:1}.hamburger{background:none;border:none;font-size:1.25rem;cursor:pointer;color:var(--text);padding:.25rem}.mobile-menu-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#0006;z-index:30}.mobile-menu{position:absolute;top:0;left:0;bottom:0;width:260px;background:var(--surface);padding:1.25rem 0;display:flex;flex-direction:column}.mobile-menu ul{list-style:none;flex:1}.mobile-menu-footer{padding:1rem 1.25rem;border-top:1px solid var(--border);display:flex;align-items:center;justify-content:space-between;font-size:.875rem}.page-content{flex:1;padding:1rem;margin-top:52px}@media (min-width: 768px){.mobile-header{display:none}.sidebar{display:flex;flex-direction:column;width:var(--sidebar-w);background:var(--surface);border-right:1px solid var(--border);position:fixed;top:0;left:0;bottom:0;z-index:10}.sidebar-logo{padding:1.25rem 1.25rem 1rem;font-weight:700;font-size:1.125rem;border-bottom:1px solid var(--border)}.sidebar-nav{list-style:none;flex:1;padding:.5rem 0;overflow-y:auto}.sidebar-footer{padding:1rem 1.25rem;border-top:1px solid var(--border);display:flex;flex-direction:column;gap:.5rem;font-size:.875rem}.sidebar-user{font-weight:500}.page-content{margin-left:var(--sidebar-w);margin-top:0;padding:2rem;max-width:calc(1200px + var(--sidebar-w))}}.nav-link{display:block;padding:.6rem 1.25rem;color:var(--text-muted);text-decoration:none;font-size:.9rem;transition:background .1s,color .1s}.nav-link:hover{background:var(--bg);color:var(--text)}.nav-link.active{background:#eff6ff;color:var(--primary);font-weight:500}.page-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:1.25rem}.page-title{font-size:1.375rem;font-weight:700}.card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:1.25rem}.table-wrapper{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);overflow-x:auto}.table{width:100%;border-collapse:collapse;font-size:.875rem}.table th{padding:.625rem 1rem;text-align:left;font-weight:600;color:var(--text-muted);font-size:.8rem;text-transform:uppercase;letter-spacing:.03em;border-bottom:1px solid var(--border);background:var(--bg)}.table td{padding:.75rem 1rem;border-bottom:1px solid var(--border)}.table tbody tr:last-child td{border-bottom:none}.table tbody tr:hover{background:#f8fafc}.actions{display:flex;gap:.5rem;justify-content:flex-end;white-space:nowrap}.btn-primary{display:block;width:100%;padding:.75rem;background:var(--primary);color:#fff;border:none;border-radius:var(--radius);font-size:1rem;font-weight:500;cursor:pointer;margin-top:.5rem;transition:background .15s}.btn-primary:hover{background:var(--primary-dark)}.btn-primary:disabled{opacity:.6;cursor:not-allowed}.btn-primary-sm{padding:.5rem 1rem;background:var(--primary);color:#fff;border:none;border-radius:var(--radius);font-size:.875rem;font-weight:500;cursor:pointer;transition:background .15s}.btn-primary-sm:hover{background:var(--primary-dark)}.btn-primary-sm:disabled{opacity:.6;cursor:not-allowed}.btn-secondary{padding:.4rem .875rem;background:transparent;color:var(--text);border:1px solid var(--border);border-radius:var(--radius);font-size:.875rem;cursor:pointer;transition:background .15s}.btn-secondary:hover{background:var(--bg)}.btn-link{background:none;border:none;padding:0;font-size:inherit;color:var(--primary);cursor:pointer;text-decoration:none;font-weight:500}.btn-link:hover{color:var(--primary-dark);text-decoration:underline}.btn-danger{padding:.4rem .875rem;background:transparent;color:var(--error);border:1px solid var(--error);border-radius:var(--radius);font-size:.875rem;cursor:pointer;transition:background .15s,color .15s}.btn-danger:hover{background:var(--error);color:#fff}.btn-danger:disabled{opacity:.6;cursor:not-allowed}.field{margin-bottom:1rem}.field label{display:block;font-size:.875rem;font-weight:500;margin-bottom:.3rem}.field input,.field select,.field textarea{width:100%;padding:.6rem .75rem;border:1px solid var(--border);border-radius:var(--radius);font-size:.9375rem;outline:none;transition:border-color .15s;background:var(--surface);color:var(--text)}.field input:focus,.field select:focus,.field textarea:focus{border-color:var(--primary);box-shadow:0 0 0 3px #2563eb1f}.field.field-check label{display:flex;align-items:center;gap:.5rem;cursor:pointer}.field.field-check input{width:auto}.input-readonly{background:var(--bg)!important;color:var(--text-muted)!important;cursor:not-allowed}.form-grid{display:grid;grid-template-columns:1fr;gap:0}@media (min-width: 480px){.form-grid{grid-template-columns:1fr 1fr;gap:0 1rem}}.modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#00000073;display:flex;align-items:center;justify-content:center;z-index:50;padding:1rem}.modal{background:var(--surface);border-radius:var(--radius);width:100%;max-width:560px;max-height:90vh;overflow-y:auto;box-shadow:0 8px 32px #0000002e}.modal-header{display:flex;align-items:center;justify-content:space-between;padding:1.25rem 1.5rem .75rem;border-bottom:1px solid var(--border)}.modal-header h2{font-size:1.125rem;font-weight:600}.modal-close{background:none;border:none;font-size:1rem;cursor:pointer;color:var(--text-muted);padding:.25rem}.modal-body{padding:1.25rem 1.5rem}.modal-actions{display:flex;justify-content:flex-end;gap:.75rem;margin-top:1.25rem;padding-top:1rem;border-top:1px solid var(--border)}.badge{display:inline-block;padding:.125rem .5rem;background:var(--bg);border:1px solid var(--border);border-radius:9999px;font-size:.75rem;color:var(--text-muted)}.role-badge{display:inline-block;padding:.125rem .5rem;background:#eff6ff;border:1px solid #bfdbfe;border-radius:9999px;font-size:.75rem;color:var(--primary)}.text-muted{color:var(--text-muted);font-size:.875rem}.error-msg{color:var(--error);font-size:.875rem;margin-bottom:.75rem}.success-msg{color:var(--success);font-size:.875rem;margin-bottom:.75rem}code{font-family:SF Mono,Fira Code,monospace;font-size:.875em;background:var(--bg);padding:.1em .35em;border-radius:4px}.week-nav{display:flex;align-items:center;gap:.5rem;margin-bottom:1rem}.week-label{font-weight:600;font-size:.9375rem;min-width:160px;text-align:center}.week-grid{display:grid;grid-template-columns:1fr;gap:.5rem}@media (min-width: 640px){.week-grid{grid-template-columns:repeat(7,1fr);gap:.375rem}}.template-week-grid{display:grid;grid-template-columns:1fr;gap:.5rem}@media (min-width: 700px){.template-week-grid{grid-template-columns:repeat(8,1fr);gap:.375rem}}.week-day{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);min-height:100px}.week-day.today{border-color:var(--primary)}.week-day.weekend-day{border-color:#eab308}.week-day.holiday-day{border-color:#f97316}.week-day-header{display:flex;align-items:center;gap:.25rem;padding:.4rem .5rem;border-bottom:1px solid var(--border);background:var(--bg);border-radius:var(--radius) var(--radius) 0 0}.weekday-name{font-weight:600;font-size:.8125rem}.weekday-date{color:var(--text-muted);font-size:.75rem;flex:1}.btn-add-shift{background:none;border:1px dashed var(--border);border-radius:4px;width:20px;height:20px;font-size:.875rem;cursor:pointer;color:var(--text-muted);display:flex;align-items:center;justify-content:center;padding:0;line-height:1}.btn-add-shift:hover{border-color:var(--primary);color:var(--primary)}.week-day-shifts{padding:.375rem;display:flex;flex-direction:column;gap:.25rem}.no-shifts{color:var(--text-muted);font-size:.75rem;text-align:center;padding:.5rem}.shift-card{background:var(--bg);border:1px solid var(--border);border-left:4px solid var(--border);border-radius:4px;padding:.375rem .5rem;cursor:pointer;position:relative;transition:box-shadow .1s}.shift-card:hover{box-shadow:0 1px 4px #0000001a}.shift-card.has-warning{border-top-color:#f59e0b}.shift-name{font-weight:600;font-size:.75rem}.shift-time{font-size:.75rem;color:var(--text-muted)}.shift-activity{font-size:.7rem;color:var(--text-muted);margin-top:.125rem}.shift-employee{font-size:.75rem;margin-top:.125rem}.shift-employee .assigned{color:#15803d}.shift-employee .unassigned{color:var(--text-muted);font-style:italic}.shift-warning{position:absolute;top:2px;right:4px;font-size:.75rem;color:#f59e0b}.availability-btns{display:flex;gap:.375rem;margin-top:.375rem;align-items:center;min-height:1.75rem}.shift-card.avail-loading{opacity:.6;pointer-events:none}.avail-spinner{display:inline-block;width:14px;height:14px;border:2px solid var(--border);border-top-color:var(--primary);border-radius:50%;animation:avail-spin .6s linear infinite;margin:0 auto}.avail-btn{flex:1;padding:.25rem 0;border-radius:4px;border:1.5px solid;font-size:.8rem;font-weight:600;cursor:pointer;transition:background .1s,color .1s;background:transparent}.avail-btn.avail-yes{border-color:#16a34a;color:#16a34a}.avail-btn.avail-yes.active,.avail-btn.avail-yes:hover{background:#16a34a;color:#fff}.avail-btn.avail-no{border-color:#dc2626;color:#dc2626}.avail-btn.avail-no.active,.avail-btn.avail-no:hover{background:#dc2626;color:#fff}.shift-detail .detail-row{display:flex;justify-content:space-between;padding:.375rem 0;border-bottom:1px solid var(--border);font-size:.875rem}.shift-detail .detail-row span:first-child{color:var(--text-muted)}.warning-line{color:#92400e;background:#fef3c7;border-radius:4px;padding:.375rem .5rem;font-size:.8125rem;margin-top:.5rem}.slot-row{background:var(--bg);border-radius:var(--radius);padding:.75rem;margin-bottom:.5rem}.weekday-picker{display:flex;gap:.3rem;flex-wrap:wrap}.wd-btn{padding:.25rem .5rem;border:1px solid var(--border);border-radius:var(--radius);background:var(--surface);color:var(--text-muted);font-size:.8125rem;font-weight:500;cursor:pointer;transition:background .1s,color .1s,border-color .1s;min-width:36px;text-align:center}.wd-btn:hover{border-color:var(--primary);color:var(--primary)}.wd-btn.active{background:var(--primary);border-color:var(--primary);color:#fff}.wd-btn-holiday{border-color:#f97316;color:#c2410c}.wd-btn-holiday:hover{border-color:#ea580c;color:#ea580c;background:#fff7ed}.wd-btn-holiday.active{background:#f97316;border-color:#f97316;color:#fff}.color-swatch{display:inline-block;width:18px;height:18px;border-radius:4px;border:1px solid rgb(0 0 0 / .12);vertical-align:middle}.filter-select{padding:.3rem .5rem;border:1px solid var(--border);border-radius:var(--radius);background:var(--surface);color:var(--text);font-size:.8125rem;cursor:pointer;margin-left:auto}.view-toggle{display:flex;border:1px solid var(--border);border-radius:var(--radius);overflow:hidden}.view-btn{padding:.3rem .75rem;background:var(--surface);border:none;cursor:pointer;font-size:.8125rem;color:var(--text-muted);transition:background .1s,color .1s}.view-btn+.view-btn{border-left:1px solid var(--border)}.view-btn.active{background:var(--primary);color:#fff}.day-grid{display:flex;gap:8px;overflow-x:auto;align-items:flex-start}.day-column{min-width:200px;flex:1;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);overflow:hidden}.day-column-header{display:flex;align-items:center;gap:.5rem;padding:.5rem .75rem;font-weight:600;font-size:.875rem;background:var(--bg);border-bottom:3px solid transparent}.day-column-shifts{padding:.5rem;min-height:60px;display:flex;flex-direction:column;gap:.375rem}.month-view{overflow-x:auto}.month-header-row{display:grid;grid-template-columns:repeat(7,1fr);gap:4px;margin-bottom:4px}.month-day-name{text-align:center;font-size:.75rem;font-weight:600;color:var(--text-muted);padding:.25rem 0}.month-week-row{margin-bottom:4px}.week-day.other-month{opacity:.45}.shift-card.compact{padding:.2rem .35rem}.shift-card.compact .shift-name{font-size:.7rem}.shift-card.compact .shift-time,.shift-card.compact .shift-employee{font-size:.65rem}.status-badge{display:inline-block;padding:.15rem .5rem;border-radius:12px;font-size:.75rem;font-weight:500;white-space:nowrap}.holiday-badge{font-size:.7rem;color:#92400e;background:#fde68a;border-radius:4px;padding:.1rem .35rem;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:120px}.holiday-override-btns{display:flex;gap:.25rem}.override-btn{padding:.2rem .5rem;border:1px solid var(--border);border-radius:4px;background:#fff;font-size:.78rem;cursor:pointer;color:var(--text)}.override-btn.active{background:#e2e8f0;border-color:#94a3b8;font-weight:600}.override-btn.override-yes.active{background:#dcfce7;border-color:#16a34a;color:#15803d}.override-btn.override-no.active{background:#fee2e2;border-color:#dc2626;color:#b91c1c}.toggle-label{display:flex;align-items:center;gap:.4rem;font-size:.85rem;cursor:pointer}@keyframes avail-spin{to{transform:rotate(360deg)}}
