:root{--sidebar-w:240px;--topbar-h:60px;--content-px:28px;--content-py:24px;--r-sm:4px;--r-md:6px;--r-lg:10px;--r-xl:16px;--r-full:9999px;--shadow-xs:0 1px 2px #1018280d;--shadow-sm:0 1px 3px #1018281a, 0 1px 2px #1018280f;--indigo-50:#eef2ff;--indigo-100:#e0e7ff;--indigo-600:#4f46e5;--indigo-700:#4338ca;--gray-50:#f9fafb;--gray-100:#f3f4f6;--gray-200:#e5e7eb;--gray-300:#d1d5db;--gray-400:#9ca3af;--gray-500:#6b7280;--gray-600:#4b5563;--gray-700:#374151;--gray-800:#1f2937;--gray-900:#111827;--c-bg:#f8fafc;--c-surface:#fff;--c-border:#e4e7ec;--c-text:#101828;--c-text-sub:#475467;--c-text-muted:#98a2b3;--c-primary:var(--indigo-600);--c-primary-hov:var(--indigo-700);--c-primary-50:var(--indigo-50);--c-primary-100:var(--indigo-100);--c-success-text:#027a48;--c-success-bg:#ecfdf3;--c-warning-text:#b54708;--c-warning-bg:#fffaeb;--c-danger-text:#b42318;--c-danger-bg:#fef3f2;--c-neutral-text:var(--gray-600);--c-neutral-bg:var(--gray-100);--font:"Inter", -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif}*,:before,:after{box-sizing:border-box;margin:0;padding:0}html{font-size:14px}body{font-family:var(--font);color:var(--c-text);background:var(--c-bg);-webkit-font-smoothing:antialiased;font-size:14px;line-height:1.5}a{color:inherit;text-decoration:none}button{font-family:var(--font);cursor:pointer}input,textarea,select{font-family:var(--font)}img{max-width:100%;display:block}.shell{height:100dvh;min-height:100vh;display:flex;overflow:hidden}.sidebar{width:var(--sidebar-w);min-width:var(--sidebar-w);background:var(--c-surface);border-right:1px solid var(--c-border);flex-direction:column;height:100vh;transition:transform .18s,width .18s,min-width .18s;display:flex;overflow:hidden auto}.sidebar-backdrop{display:none}.sidebar__brand{height:var(--topbar-h);border-bottom:1px solid var(--c-border);flex-shrink:0;align-items:center;gap:10px;padding:0 16px;display:flex}.brand-mark{border-radius:var(--r-md);background:var(--c-primary);color:#fff;flex-shrink:0;justify-content:center;align-items:center;width:28px;height:28px;font-size:13px;font-weight:700;display:flex}.brand-name{color:var(--c-text);letter-spacing:-.3px;font-size:15px;font-weight:600}.sidebar__nav{flex:1;padding:8px 0}.nav-section{text-transform:uppercase;letter-spacing:.06em;color:var(--c-text-muted);padding:16px 16px 4px;font-size:11px;font-weight:600}.nav-link{border-radius:var(--r-md);height:36px;color:var(--c-text-sub);align-items:center;gap:9px;margin:1px 8px;padding:0 12px;font-size:13.5px;font-weight:500;transition:background .1s,color .1s;display:flex}.nav-link:hover{background:var(--gray-100);color:var(--c-text)}.nav-link.active{background:var(--c-primary-50);color:var(--c-primary)}.nav-link__icon{opacity:.7;flex-shrink:0}.nav-link.active .nav-link__icon{opacity:1}.sidebar__footer{border-top:1px solid var(--c-border);flex-shrink:0;align-items:center;gap:8px;padding:12px 16px;display:flex}.user-avatar{border-radius:var(--r-full);background:var(--c-primary-100);width:32px;height:32px;color:var(--c-primary);flex-shrink:0;justify-content:center;align-items:center;font-size:12px;font-weight:600;display:flex}.user-meta{flex:1;min-width:0}.user-fullname{color:var(--c-text);white-space:nowrap;text-overflow:ellipsis;font-size:13px;font-weight:500;overflow:hidden}.user-email-text{color:var(--c-text-muted);white-space:nowrap;text-overflow:ellipsis;font-size:11px;overflow:hidden}.logout-btn{border-radius:var(--r-md);width:30px;height:30px;color:var(--c-text-muted);background:0 0;border:none;flex-shrink:0;justify-content:center;align-items:center;transition:background .1s,color .1s;display:flex}.logout-btn:hover{background:var(--gray-100);color:var(--c-text)}.main-wrapper{flex-direction:column;flex:1;min-width:0;display:flex;overflow:hidden}.topbar{height:var(--topbar-h);padding:0 var(--content-px);background:var(--c-surface);border-bottom:1px solid var(--c-border);flex-shrink:0;align-items:center;gap:12px;display:flex}.topbar__title{color:var(--c-text);flex:1;font-size:15px;font-weight:600}.content{padding:var(--content-py) var(--content-px);flex:1;overflow-y:auto}@media (width<=900px){:root{--content-px:16px;--content-py:16px}.sidebar{z-index:60;width:min(82vw,304px);min-width:0;position:fixed;inset:0 auto 0 0;transform:translate(-102%);box-shadow:0 18px 48px #0f172a2e}.sidebar--open{transform:translate(0)}.sidebar--collapsed{width:min(82vw,304px);min-width:0}.sidebar--collapsed .sidebar__brand-name,.sidebar--collapsed .sidebar__link span,.sidebar--collapsed .sidebar__footer span{display:inline}.sidebar--collapsed .sidebar__brand{justify-content:flex-start}.sidebar--collapsed .sidebar__link{justify-content:flex-start;width:calc(100% - 16px);margin:1px 8px}.sidebar-backdrop{z-index:55;-webkit-backdrop-filter:blur(1px);backdrop-filter:blur(1px);background:#0f172a57;display:block;position:fixed;inset:0}.topbar{height:auto;min-height:var(--topbar-h);flex-wrap:wrap;gap:8px;padding:8px 14px}.topbar__title{white-space:nowrap;text-overflow:ellipsis;order:1;min-width:0;font-size:14px;overflow:hidden}.topbar__workplace{flex:100%;order:3;min-width:0}.topbar__wp-select{width:100%;min-width:0;max-width:none}.topbar__wp-chip{justify-content:center;width:100%}.topbar__email{display:none}.topbar__user{order:2;margin-left:auto}.content{padding:16px 16px 20px}.page-header{flex-direction:column;align-items:stretch;gap:10px;margin-bottom:16px}.page-header__actions{flex-wrap:wrap;width:100%}.page-header__actions .btn{justify-content:center;width:100%}.card{padding:16px}.card__header{flex-wrap:wrap;align-items:flex-start;gap:8px}.table-card{border-radius:var(--r-md)}.data-table thead th,.data-table td{padding:10px 12px}}@media (width<=640px){.topbar{padding:0 12px}.topbar__wp-select{max-width:132px}.topbar__avatar{width:30px;height:30px}.page-header__title{font-size:18px}.page-header__subtitle{line-height:1.4}.empty-state{padding:36px 16px}.toolbar{padding:10px 12px}}.btn{border-radius:var(--r-md);cursor:pointer;white-space:nowrap;border:none;outline:none;align-items:center;gap:6px;height:36px;padding:0 14px;font-size:13.5px;font-weight:500;line-height:1;transition:background .15s,box-shadow .15s,border-color .15s;display:inline-flex}.btn:focus-visible{box-shadow:0 0 0 3px var(--c-primary-100)}.btn:disabled{opacity:.5;cursor:not-allowed}.btn--primary{background:var(--c-primary);color:#fff}.btn--primary:hover:not(:disabled){background:var(--c-primary-hov)}.btn--secondary{color:var(--gray-700);border:1px solid var(--gray-300);background:#fff}.btn--secondary:hover:not(:disabled){background:var(--gray-50)}.btn--ghost{color:var(--c-text-sub);background:0 0}.btn--ghost:hover:not(:disabled){background:var(--gray-100);color:var(--c-text)}.btn--danger-ghost{color:var(--c-danger-text);background:0 0}.btn--danger-ghost:hover:not(:disabled){background:var(--c-danger-bg);color:var(--c-danger-text)}.btn--sm{gap:4px;height:30px;padding:0 10px;font-size:12.5px}.btn--full{justify-content:center;width:100%}.form-group{flex-direction:column;gap:5px;display:flex}.form-label{color:var(--gray-700);font-size:13px;font-weight:500}.form-input{border:1px solid var(--gray-300);border-radius:var(--r-md);height:40px;color:var(--c-text);background:#fff;outline:none;width:100%;padding:0 12px;font-size:14px;transition:border-color .15s,box-shadow .15s}.form-input::placeholder{color:var(--gray-400)}.form-input:focus{border-color:var(--c-primary);box-shadow:0 0 0 3px var(--c-primary-50)}.form-input--error{border-color:#f04438}.form-input--error:focus{box-shadow:0 0 0 3px #fee4e2}.form-error{color:var(--c-danger-text);font-size:12px}.form-help{color:var(--c-text-muted);font-size:12px}.card{background:var(--c-surface);border:1px solid var(--c-border);border-radius:var(--r-lg);padding:20px}.stats-grid{grid-template-columns:repeat(4,1fr);gap:16px;margin-bottom:28px;display:grid}@media (width<=1100px){.stats-grid{grid-template-columns:repeat(2,1fr)}}.stat-card{background:var(--c-surface);border:1px solid var(--c-border);border-radius:var(--r-lg);padding:20px 24px}.stat-card__label{color:var(--c-text-sub);margin-bottom:8px;font-size:12.5px;font-weight:500}.stat-card__value{color:var(--c-text);margin-bottom:8px;font-size:30px;font-weight:700;line-height:1}.stat-card__sub{color:var(--c-text-muted);font-size:12px}.page-header{justify-content:space-between;align-items:flex-start;gap:16px;margin-bottom:20px;display:flex}.page-header__title{color:var(--c-text);margin-bottom:3px;font-size:20px;font-weight:600;line-height:1.25}.page-header__subtitle,.page-header__sub{color:var(--c-text-sub);font-size:13px;line-height:1.45}.page-header__actions{flex-shrink:0;align-items:center;gap:8px;display:flex}.toolbar{flex-wrap:wrap;align-items:center;gap:10px;margin-bottom:12px;display:flex}.toolbar__main{flex:260px;align-items:center;min-width:0;display:flex}.toolbar__filters,.toolbar__actions{flex-wrap:wrap;align-items:center;gap:8px;display:flex}.toolbar__filters{flex:auto;min-width:0}.toolbar__actions{margin-left:auto}.search-wrap{flex:1;max-width:300px;position:relative}.search-icon{color:var(--c-text-muted);pointer-events:none;position:absolute;top:50%;left:10px;transform:translateY(-50%)}.search-input{border:1px solid var(--gray-300);border-radius:var(--r-md);width:100%;height:36px;color:var(--c-text);background:#fff;outline:none;padding:0 12px 0 34px;font-size:13.5px;transition:border-color .15s,box-shadow .15s}.search-input::placeholder{color:var(--gray-400)}.search-input:focus{border-color:var(--c-primary);box-shadow:0 0 0 3px var(--c-primary-50)}.table-card{background:var(--c-surface);border:1px solid var(--c-border);border-radius:var(--r-lg);overflow:hidden}.data-table{border-collapse:collapse;width:100%}.data-table thead th{background:var(--gray-50);border-bottom:1px solid var(--c-border);text-align:left;color:var(--c-text-muted);text-transform:uppercase;letter-spacing:.05em;white-space:nowrap;padding:10px 16px;font-size:11.5px;font-weight:600}.data-table tbody tr{border-bottom:1px solid var(--gray-100);transition:background .1s}.data-table tbody tr:last-child{border-bottom:none}.data-table tbody tr:hover{background:var(--gray-50)}.data-table td{color:var(--c-text);vertical-align:middle;padding:13px 16px;font-size:13.5px}.cell-name{font-weight:500}.cell-sub{color:var(--c-text-sub);margin-top:2px;font-size:12px}.badge{border-radius:var(--r-full);white-space:nowrap;align-items:center;height:22px;padding:0 8px;font-size:11.5px;font-weight:500;display:inline-flex}.badge--sm{height:18px;padding:0 6px;font-size:10.5px}.badge--success{background:var(--c-success-bg);color:var(--c-success-text)}.badge--warning{background:var(--c-warning-bg);color:var(--c-warning-text)}.badge--danger{background:var(--c-danger-bg);color:var(--c-danger-text)}.badge--neutral{background:var(--c-neutral-bg);color:var(--c-neutral-text)}.badge--primary{background:var(--c-primary-50);color:var(--c-primary)}.empty-state{text-align:center;flex-direction:column;justify-content:center;align-items:center;gap:4px;max-width:520px;margin:0 auto;padding:56px 24px;display:flex}.empty-state__icon{color:var(--gray-300);margin-bottom:14px}.empty-state__title{color:var(--c-text-sub);margin-bottom:4px;font-size:14px;font-weight:500}.empty-state__text{color:var(--c-text-muted);font-size:13px}.spinner{border:2px solid var(--c-border);border-top-color:var(--c-primary);border-radius:50%;width:20px;height:20px;animation:.7s linear infinite spin}@keyframes spin{to{transform:rotate(360deg)}}.loading-row td{text-align:center;color:var(--c-text-muted);padding:20px;font-size:13px}.roles-grid{grid-template-columns:repeat(auto-fill,minmax(220px,1fr));gap:16px;display:grid}.role-card{background:var(--c-surface);border:1px solid var(--c-border);border-radius:var(--r-lg);transition:box-shadow .15s;overflow:hidden}.role-card:hover{box-shadow:var(--shadow-sm)}.role-card__bar{height:4px}.role-card__body{padding:16px 18px}.role-card__name{color:var(--c-text);margin-bottom:4px;font-size:14px;font-weight:600}.role-card__count{color:var(--c-text-sub);font-size:12.5px}.schedule-wrap{background:var(--c-surface);border:1px solid var(--c-border);border-radius:var(--r-lg);overflow:hidden}.schedule-table{border-collapse:collapse;width:100%}.schedule-table th{background:var(--gray-50);border-bottom:1px solid var(--c-border);border-right:1px solid var(--gray-100);color:var(--c-text-muted);text-align:center;padding:10px 12px;font-size:12px;font-weight:600}.schedule-table th:first-child{text-align:left;border-right-color:var(--c-border);width:140px}.schedule-table td{border-bottom:1px solid var(--gray-100);border-right:1px solid var(--gray-100);vertical-align:top;color:var(--c-text-sub);padding:10px 12px;font-size:13px}.schedule-table tr:last-child td{border-bottom:none}.schedule-table td:first-child{background:var(--gray-50);color:var(--c-text);border-right-color:var(--c-border);font-weight:500}.schedule-shift{background:var(--c-primary-50);color:var(--c-primary);border-radius:var(--r-sm);padding:2px 7px;font-size:11.5px;font-weight:500;display:inline-block}.auth-layout{background:var(--c-bg);justify-content:center;align-items:center;min-height:100vh;padding:24px;display:flex}.auth-card{background:var(--c-surface);border:1px solid var(--c-border);border-radius:var(--r-xl);width:100%;max-width:400px;box-shadow:var(--shadow-sm);padding:36px}.auth-brand{align-items:center;gap:10px;margin-bottom:28px;display:flex}.auth-heading{color:var(--c-text);margin-bottom:4px;font-size:20px;font-weight:600}.auth-subheading{color:var(--c-text-sub);margin-bottom:24px;font-size:13.5px}.auth-form{flex-direction:column;gap:16px;display:flex}.auth-footer{color:var(--c-text-sub);text-align:center;margin-top:20px;font-size:13px}.auth-link{color:var(--c-primary);font-weight:500}.auth-link:hover{color:var(--c-primary-hov)}.auth-divider{align-items:center;gap:12px;margin:4px 0;display:flex}.auth-divider:before,.auth-divider:after{content:"";background:var(--c-border);flex:1;height:1px}.auth-divider span{color:var(--c-text-muted);font-size:12px}.alert{border-radius:var(--r-md);padding:10px 12px;font-size:13px}.alert--error{background:var(--c-danger-bg);color:var(--c-danger-text);border:1px solid #fecdca}.alert--success{background:var(--c-success-bg);color:var(--c-success-text);border:1px solid #abefc6}.section{margin-bottom:28px}.section-title{color:var(--c-text);margin-bottom:8px;font-size:14px;font-weight:600;line-height:1.25}.section-kicker{color:var(--c-text-muted);text-transform:uppercase;letter-spacing:.06em;margin-bottom:4px;font-size:11px;font-weight:700}.section-subtitle{color:var(--c-text-sub);max-width:68ch;font-size:12.5px;line-height:1.45}:root{--sp-1:4px;--sp-2:8px;--sp-3:12px;--sp-4:16px;--sp-5:20px;--sp-6:24px;--text-xs:11px;--text-sm:12.5px;--text-base:14px}.sidebar__brand-name{color:var(--c-text);letter-spacing:-.3px;font-size:15px;font-weight:600}.sidebar__link{border-radius:var(--r-md);height:36px;color:var(--c-text-sub);cursor:pointer;background:0 0;border:none;align-items:center;gap:9px;width:calc(100% - 16px);margin:1px 8px;padding:0 12px;font-size:13.5px;font-weight:500;transition:background .1s,color .1s;display:flex}.sidebar__link:hover{background:var(--gray-100);color:var(--c-text)}.sidebar__link--active{background:var(--c-primary-50);color:var(--c-primary)}.sidebar__link--logout{color:var(--c-text-muted)}.sidebar--collapsed{width:60px;min-width:60px}.sidebar--collapsed .sidebar__brand-name,.sidebar--collapsed .sidebar__link span,.sidebar--collapsed .sidebar__footer span{display:none}.sidebar--collapsed .sidebar__brand{justify-content:center}.sidebar--collapsed .sidebar__link{justify-content:center;width:calc(100% - 12px);margin:1px 6px}.topbar__toggle{margin-right:4px}.topbar__user{align-items:center;gap:var(--sp-2);margin-left:auto;display:flex}.topbar__avatar{border-radius:var(--r-full);background:var(--c-primary-100);width:34px;height:34px;color:var(--c-primary);flex-shrink:0;justify-content:center;align-items:center;font-size:12px;font-weight:600;display:flex}.topbar__email{color:var(--c-text-sub);font-size:13px}.topbar__workplace{align-items:center;display:flex}.topbar__wp-select{min-width:150px;max-width:220px;height:32px;padding:0 8px;font-size:13px}.topbar__wp-chip{color:var(--c-primary);background:var(--c-primary-50);border:1px solid var(--c-primary-100);border-radius:var(--r-md);white-space:nowrap;align-items:center;gap:5px;padding:4px 10px;font-size:13px;font-weight:500;display:flex}.page-header__subtitle{color:var(--c-text-sub);font-size:13px}.stat-grid{grid-template-columns:repeat(4,1fr);gap:16px;margin-bottom:28px;display:grid}@media (width<=1100px){.stat-grid{grid-template-columns:repeat(2,1fr)}}.stat-card__delta{color:var(--c-text-muted);margin-top:4px;font-size:12px}.stat-card__delta--up{color:var(--c-success-text)}.card__header{justify-content:space-between;align-items:flex-start;gap:var(--sp-2);flex-wrap:wrap;margin-bottom:16px;display:flex}.card__title{color:var(--c-text);font-size:14px;font-weight:600;line-height:1.25}.empty-state__hint{color:var(--c-text-muted);margin-top:4px;font-size:12px}.toolbar{border-bottom:1px solid var(--gray-100);padding:12px 16px}.toolbar__search{max-width:300px;position:relative}.toolbar__search-icon{color:var(--c-text-muted);pointer-events:none;position:absolute;top:50%;left:10px;transform:translateY(-50%)}.toolbar__search-input{background:var(--gray-50);border:1px solid var(--gray-200);border-radius:var(--r-md);width:100%;height:34px;color:var(--c-text);outline:none;padding:0 12px 0 34px;font-size:13.5px;transition:border-color .15s,box-shadow .15s}.toolbar__search-input::placeholder{color:var(--gray-400)}.toolbar__search-input:focus{border-color:var(--c-primary);box-shadow:0 0 0 3px var(--c-primary-50)}.toolbar__filters>*,.toolbar__actions>*{min-width:0}@media (width<=720px){.toolbar{align-items:stretch}.toolbar__main,.toolbar__filters,.toolbar__actions{width:100%}.toolbar__actions{justify-content:flex-start;margin-left:0}.toolbar__search{width:100%;max-width:none}}.list-pagination{justify-content:space-between;align-items:center;gap:var(--sp-3);margin-top:var(--sp-4);border:1px solid var(--c-border);border-radius:var(--r-lg);background:var(--c-surface);flex-wrap:wrap;padding:12px 16px;display:flex}.list-pagination__summary{color:var(--c-text-sub);min-width:0;font-size:12.5px}.list-pagination__controls{align-items:center;gap:var(--sp-3);flex-wrap:wrap;margin-left:auto;display:flex}.list-pagination__page-size{color:var(--c-text-sub);align-items:center;gap:6px;font-size:12.5px;display:flex}.list-pagination__select{border:1px solid var(--gray-300);border-radius:var(--r-md);min-width:88px;height:32px;color:var(--c-text);background:#fff;padding:0 10px;font-size:13px}.list-pagination__nav{align-items:center;gap:6px;display:flex}.list-pagination__page-info{color:var(--c-text-sub);text-align:center;min-width:72px;font-size:12.5px}@media (width<=720px){.list-pagination{align-items:stretch}.list-pagination__controls{justify-content:space-between;width:100%;margin-left:0}.list-pagination__page-size,.list-pagination__nav{justify-content:space-between;width:100%}}.role-card__accent{height:4px}.role-card__meta{color:var(--c-text-sub);margin-bottom:8px;font-size:12.5px}.role-card__desc{color:var(--c-text-muted);font-size:13px}.auth-card__title{color:var(--c-text);margin-bottom:24px;font-size:20px;font-weight:600}.auth-card__links{color:var(--c-text-sub);text-align:center;margin-top:20px;font-size:13px}.auth-card__links a{color:var(--c-primary);font-weight:500}.alert--danger{background:var(--c-danger-bg);color:var(--c-danger-text);border:1px solid #fecdca}.skill-toggle{cursor:pointer;align-items:center;display:inline-flex;position:relative}.skill-toggle input{opacity:0;width:0;height:0;position:absolute}.skill-toggle__track{border-radius:var(--r-full);background:var(--gray-300);flex-shrink:0;width:36px;height:20px;transition:background .15s;position:relative}.skill-toggle__track:after{content:"";background:#fff;border-radius:50%;width:14px;height:14px;transition:transform .15s;position:absolute;top:3px;left:3px}.skill-toggle input:checked+.skill-toggle__track{background:var(--c-primary)}.skill-toggle input:checked+.skill-toggle__track:after{transform:translate(16px)}.toolbar-switch{border:1px solid var(--gray-200);border-radius:var(--r-full);min-height:36px;color:var(--c-text-sub);white-space:nowrap;cursor:pointer;background:#fff;align-items:center;gap:10px;padding:0 12px;font-size:13px;font-weight:500;transition:border-color .15s,background .15s,color .15s,box-shadow .15s;display:inline-flex}.toolbar-switch:hover{border-color:var(--gray-300)}.toolbar-switch--checked{background:var(--c-primary-50);border-color:var(--c-primary-100);color:var(--c-primary)}.toolbar-switch__label{line-height:1}.flex{display:flex}.items-center{align-items:center}.justify-between{justify-content:space-between}.gap-2{gap:8px}.gap-3{gap:12px}.mt-1{margin-top:4px}.mt-4{margin-top:16px}.truncate{white-space:nowrap;text-overflow:ellipsis;overflow:hidden}
