:root{--lightningcss-light: ;--lightningcss-dark:initial;color-scheme:dark;--bg-deep:#0b0f14;--bg-surface:#121922;--bg-elevated:#1a2330;--border:#ffffff14;--text:#e8edf5;--muted:#8b98ab;--accent:#3dd4c0;--accent-dim:#3dd4c026;--danger:#f07178;--warn:#ebc06d;--ok:#7ee0a3;--radius:12px;--radius-sm:8px;--font:"DM Sans", system-ui, sans-serif;--font-brand:"Outfit", "DM Sans", system-ui, sans-serif;--shadow:0 24px 48px #00000073}*,:before,:after{box-sizing:border-box}html,body{min-height:100%;font-family:var(--font);background:var(--bg-deep);color:var(--text);-webkit-font-smoothing:antialiased;margin:0}#root{min-height:100vh}button,input,select{font:inherit;color:inherit}.sr-only{clip:rect(0, 0, 0, 0);border:0;width:1px;height:1px;margin:-1px;padding:0;position:absolute;overflow:hidden}.app-shell{grid-template-columns:260px 1fr;min-height:100vh;display:grid}.sidebar{border-right:1px solid var(--border);background:linear-gradient(#0f141c 0%,#0b0f14 100%);flex-direction:column;gap:1.5rem;padding:1.25rem 1rem;display:flex;position:relative}.sidebar__brand{padding:.35rem .25rem}.sidebar__titles{min-width:0}.brand-block{text-align:center}.brand-block__title{font-family:var(--font-brand);letter-spacing:-.035em;background-image:linear-gradient(118deg, #fff 0%, #c5fff2 38%, var(--accent) 52%, #7eb8ff 100%);color:var(--text);filter:drop-shadow(0 2px 20px #3dd4c059);-webkit-background-clip:text;background-clip:text;margin:0;font-size:1.85rem;font-weight:700;line-height:1.15;display:block}@supports ((-webkit-background-clip:text) or (background-clip:text)){.brand-block__title{color:#0000}}.brand-block__tagline{font-family:var(--font-brand);letter-spacing:.32em;text-transform:uppercase;color:#8b98abeb;text-shadow:0 0 32px #3dd4c033;margin:.55rem 0 0;font-size:.8rem;font-weight:600;display:block}.brand-block--compact .brand-block__title{font-size:1.28rem}.brand-block--compact .brand-block__tagline{letter-spacing:.22em;margin-top:.4rem;font-size:.68rem}.sidebar__nav{flex-direction:column;flex:1;gap:.25rem;display:flex}.nav-link--sub{padding:.45rem .75rem;font-size:.82rem}.nav-link{border-radius:var(--radius-sm);color:var(--muted);padding:.65rem .85rem;font-size:.92rem;font-weight:500;text-decoration:none;transition:background .15s,color .15s;display:block}.nav-link:hover{color:var(--text);background:#ffffff0a}.nav-link--active{color:var(--text);background:var(--accent-dim);box-shadow:inset 0 0 0 1px #3dd4c040}.sidebar__footer{border-top:1px solid var(--border);margin-top:auto;padding-top:1rem}.sidebar__hint{color:var(--muted);margin:0 0 .5rem;font-size:.72rem;line-height:1.35}.main-area{background:radial-gradient(1200px 600px at 10% -10%, #3dd4c014, transparent), radial-gradient(800px 400px at 90% 0%, #2a8fe60f, transparent), var(--bg-deep);flex-direction:column;min-width:0;display:flex}.topbar{border-bottom:1px solid var(--border);-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);background:#0b0f14a6;align-items:flex-start;gap:1rem 1.25rem;padding:1.25rem 2rem .65rem;display:flex}.topbar__titles{text-align:left;flex:12rem;min-width:0}.menu-toggle{border:1px solid var(--border);border-radius:var(--radius-sm);color:var(--text);font:inherit;cursor:pointer;touch-action:manipulation;background:#ffffff0a;flex-shrink:0;align-items:center;gap:.5rem;padding:.45rem .65rem;font-size:.82rem;font-weight:600;line-height:1.2;display:none}.menu-toggle:hover{background:#ffffff12;border-color:#ffffff1f}.menu-toggle__bars{flex-direction:column;flex-shrink:0;justify-content:center;gap:3px;width:18px;display:flex}.menu-toggle__bar{background:currentColor;border-radius:1px;height:2px;transition:transform .2s,opacity .2s;display:block}.menu-toggle--open .menu-toggle__bar:first-child{transform:translateY(5px)rotate(45deg)}.menu-toggle--open .menu-toggle__bar:nth-child(2){opacity:0}.menu-toggle--open .menu-toggle__bar:nth-child(3){transform:translateY(-5px)rotate(-45deg)}.menu-toggle__label{letter-spacing:.02em}.mobile-nav-backdrop{z-index:1000;-webkit-backdrop-filter:blur(3px);backdrop-filter:blur(3px);cursor:pointer;background:#02060c8c;border:0;margin:0;padding:0;position:fixed;inset:0}.app-shell--block-main-pointer .main-area{pointer-events:none}.sidebar__close-mobile{z-index:2;border:1px solid var(--border);border-radius:var(--radius-sm);width:2.25rem;height:2.25rem;color:var(--text);cursor:pointer;touch-action:manipulation;background:#ffffff0f;justify-content:center;align-items:center;padding:0;font-size:1.35rem;line-height:1;display:none;position:absolute;top:.65rem;right:.65rem}.sidebar__close-mobile:hover{background:#ffffff1a}.topbar__page{letter-spacing:-.03em;margin:0;font-size:1.35rem;font-weight:700}.topbar__crumb{color:var(--muted);margin:.35rem 0 0;font-size:.88rem}.topbar__crumb strong{color:var(--text);font-weight:600}.topbar__actions{flex-shrink:0;align-self:flex-start;align-items:center;gap:.5rem;margin-left:auto;display:flex}.dot:before{content:"·";opacity:.5;margin:0 .4rem}.content{flex:1;padding:1.5rem 2rem 2.5rem}.stack{flex-direction:column;gap:1.5rem;display:flex}.hero-strip{background:var(--bg-surface);border:1px solid var(--border);border-radius:var(--radius);box-shadow:var(--shadow);flex-wrap:wrap;justify-content:space-between;align-items:flex-end;gap:1.25rem;padding:1.25rem 1.5rem;display:flex}.hero-strip__title{margin:0 0 .35rem;font-size:1.1rem;font-weight:600}.hero-strip__text{max-width:52ch;color:var(--muted);margin:0;font-size:.92rem;line-height:1.5}.hero-strip__stats{gap:1rem;display:flex}.mini-stat{background:var(--bg-elevated);border:1px solid var(--border);border-radius:var(--radius-sm);min-width:120px;padding:.65rem 1rem}.mini-stat__label{color:var(--muted);text-transform:uppercase;letter-spacing:.06em;font-size:.72rem;display:block}.mini-stat__value{margin-top:.2rem;font-size:1.05rem;font-weight:700}.kpi-grid{grid-template-columns:repeat(auto-fill,minmax(240px,1fr));gap:1rem;display:grid}.kpi-card{background:var(--bg-surface);border:1px solid var(--border);border-radius:var(--radius);padding:1.1rem 1.2rem;transition:transform .15s,border-color .15s;box-shadow:0 8px 24px #0003}.kpi-card:hover{border-color:#3dd4c040;transform:translateY(-2px)}.kpi-card__top{justify-content:space-between;align-items:flex-start;gap:.5rem;display:flex}.kpi-card__label{color:var(--muted);text-transform:uppercase;letter-spacing:.05em;margin:0;font-size:.82rem;font-weight:600}.kpi-card__delta{border-radius:999px;padding:.2rem .45rem;font-size:.78rem;font-weight:600}.kpi-card__delta--up{color:var(--ok);background:#7ee0a326}.kpi-card__delta--down{color:var(--danger);background:#f071781f}.kpi-card__value{letter-spacing:-.03em;margin:.65rem 0 .25rem;font-size:1.65rem;font-weight:700}.kpi-card__period{color:var(--muted);margin:0;font-size:.8rem}.kpi-card__hint{color:var(--muted);opacity:.9;margin:.65rem 0 0;font-size:.78rem}.panel{background:var(--bg-surface);border:1px solid var(--border);border-radius:var(--radius);box-shadow:var(--shadow);padding:1.25rem 1.5rem}.panel__header{flex-wrap:wrap;justify-content:space-between;align-items:flex-end;gap:1rem;margin-bottom:1rem;display:flex}.panel__header--split{align-items:flex-start}.panel__title{margin:0 0 .25rem;font-size:1.15rem}.panel__subtitle{color:var(--muted);margin:0;font-size:.88rem}.segmented{background:var(--bg-elevated);border-radius:var(--radius-sm);border:1px solid var(--border);padding:3px;display:inline-flex}.segmented--lg .segmented__btn{padding:.55rem 1.1rem}.segmented__btn{color:var(--muted);cursor:pointer;background:0 0;border:none;border-radius:6px;padding:.4rem .75rem;font-size:.82rem;font-weight:500;transition:background .15s,color .15s}.segmented__btn--active{background:var(--bg-surface);color:var(--text);box-shadow:0 1px 4px #0003}.task-form{flex-wrap:wrap;gap:.5rem;margin-bottom:1rem;display:flex}.task-form__input{flex:200px}.input,.select{background:var(--bg-elevated);border:1px solid var(--border);border-radius:var(--radius-sm);padding:.55rem .75rem;font-size:.9rem}.input:focus,.select:focus{outline-offset:1px;outline:2px solid #3dd4c059}.select--full{width:100%}.btn{border:1px solid var(--border);background:var(--bg-elevated);border-radius:var(--radius-sm);cursor:pointer;padding:.5rem .9rem;font-size:.88rem;font-weight:600;transition:background .15s,border-color .15s}.btn:hover{background:#ffffff0f}.btn:disabled{opacity:.45;cursor:not-allowed}.btn--primary{background:linear-gradient(135deg, #2a9d8f, var(--accent));color:#04120f;border-color:#0000}.btn--primary:hover{filter:brightness(1.06)}.btn--secondary{color:var(--text);background:0 0}.btn--ghost{color:var(--muted);background:0 0;border-color:#0000}.btn--ghost:hover{color:var(--text)}.btn--block{width:100%}.btn--icon{padding:.25rem .5rem;font-size:1.1rem;line-height:1}.btn--small{padding:.35rem .65rem;font-size:.8rem}.btn--danger{color:#ffc9cc;background:#f071782e;border-color:#f0717873}.btn--danger:hover{color:#fff;background:#f0717847;border-color:#f071788c}.confirm-dialog{z-index:2000;pointer-events:none;justify-content:center;align-items:center;padding:1.25rem;display:flex;position:fixed;inset:0}.confirm-dialog__backdrop{pointer-events:auto;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);background:#05080cc7;position:absolute;inset:0}.confirm-dialog__panel{z-index:1;pointer-events:auto;background:var(--bg-surface);border:1px solid var(--border);border-radius:var(--radius);width:100%;max-width:420px;box-shadow:var(--shadow), 0 0 0 1px #3dd4c00f;padding:1.35rem 1.4rem 1.25rem;position:relative}.confirm-dialog__title{letter-spacing:-.02em;margin:0 0 .75rem;font-size:1.1rem;font-weight:700;line-height:1.3}.confirm-dialog__body{color:var(--muted);margin:0 0 1.25rem;font-size:.92rem;line-height:1.55}.confirm-dialog__body strong{color:var(--text);font-weight:600}.confirm-dialog__actions{flex-wrap:wrap;justify-content:flex-end;gap:.6rem;display:flex}.confirm-dialog__actions--alert{justify-content:stretch}.confirm-dialog__actions--alert .btn{justify-content:center;width:100%}.confirm-dialog__message{white-space:pre-wrap;margin:0}.employee-form{border-top:1px solid var(--border);margin-top:.25rem;padding-top:.5rem}.employee-form__heading{margin:0 0 .75rem;font-size:.95rem;font-weight:600}.employee-form__grid{grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:.75rem 1rem;margin-bottom:.75rem;display:grid}.field--span2{grid-column:span 2}@media (width<=520px){.field--span2{grid-column:span 1}}.task-list{flex-direction:column;gap:.35rem;margin:0;padding:0;list-style:none;display:flex}.task-list__empty{text-align:center;color:var(--muted);border:1px dashed var(--border);border-radius:var(--radius-sm);padding:1.5rem}.task-row{background:var(--bg-elevated);border-radius:var(--radius-sm);border:1px solid var(--border);grid-template-columns:minmax(0,1.4fr) auto auto minmax(7rem,.85fr) minmax(7rem,1fr) auto auto;align-items:center;gap:.5rem .65rem;padding:.65rem .75rem;display:grid}.select--compact{min-width:0;max-width:100%;padding:.35rem .4rem;font-size:.78rem}@media (width<=900px){.task-row{grid-template-rows:auto auto;grid-template-columns:1fr auto}.task-row__meta,.task-row__due{grid-column:1/-1}}.task-row--done{opacity:.55}.task-row__check{cursor:pointer;align-items:center;gap:.6rem;min-width:0;display:flex}.task-row__title{text-overflow:ellipsis;white-space:nowrap;font-weight:500;overflow:hidden}.task-row__meta,.task-row__due{color:var(--muted);font-size:.8rem}.pill{text-transform:uppercase;letter-spacing:.04em;border-radius:999px;padding:.2rem .45rem;font-size:.72rem;font-weight:600}.pill--high{color:var(--danger);background:#f0717833}.pill--medium{color:var(--warn);background:#ebc06d2e}.pill--low{color:var(--muted);background:#8b98ab33}.pill--ghost{color:var(--muted);background:#ffffff0f}.banner{border-radius:var(--radius-sm);padding:.65rem .85rem;font-size:.86rem}.banner--muted{border:1px solid var(--border);color:var(--muted);background:#8b98ab1a}.report-block{background:var(--bg-surface);border:1px solid var(--border);border-radius:var(--radius);box-shadow:var(--shadow);padding:1.25rem 1.5rem 1.5rem}.report-block__head{flex-wrap:wrap;justify-content:space-between;align-items:flex-start;gap:1rem;display:flex}.report-block__title{margin:0 0 .25rem;font-size:1.15rem}.report-block__range{color:var(--muted);margin:0;font-size:.88rem}.report-block__summary{color:var(--muted);max-width:75ch;margin:1rem 0 1.25rem;line-height:1.55}.table-wrap{border-radius:var(--radius-sm);border:1px solid var(--border);overflow-x:auto}.data-table{border-collapse:collapse;width:100%;font-size:.88rem}.data-table th,.data-table td{text-align:left;border-bottom:1px solid var(--border);padding:.75rem 1rem}.data-table th{background:var(--bg-elevated);color:var(--muted);text-transform:uppercase;letter-spacing:.06em;font-size:.72rem;font-weight:600}.data-table tr:last-child td{border-bottom:none}.data-table__row--overdue{background:#f071780f}.data-table__row--overdue td:first-child{box-shadow:inset 3px 0 0 var(--danger)}.table-wrap--mt{margin-top:1rem}.catalog-filters{flex-flow:wrap;flex:18rem;align-items:flex-end;gap:.75rem 1rem;min-width:min(100%,28rem);max-width:100%;display:flex}.catalog-filters .field{flex:10rem;min-width:0;margin:0}.reports-toolbar{flex-wrap:wrap;align-items:flex-end;gap:1rem 1.25rem;margin-bottom:1rem;display:flex}.field.field--inline{flex-direction:row;align-items:center;gap:.5rem}.field.field--inline .field__label{white-space:nowrap;margin:0}.report-block__hint{max-width:56ch;margin:.35rem 0 0;font-size:.86rem;line-height:1.45}.report-block--records{margin-bottom:.25rem}.reports-toolbar--wrap{align-items:flex-end}.report-block__total-footer{border-top:1px solid var(--border);flex-wrap:wrap;align-items:baseline;gap:.5rem 1rem;margin-top:1rem;padding-top:1rem;display:flex}.report-block__total-footer-label{text-transform:uppercase;letter-spacing:.05em;color:var(--muted);font-size:.8rem;font-weight:600}.report-block__total-footer-value{font-variant-numeric:tabular-nums;font-size:1.25rem;font-weight:700}.report-block__total-footer-value--muted{color:var(--muted);font-size:1rem;font-weight:600}.report-block__total-footer-meta{margin-left:auto;font-size:.88rem}.data-table--project-subtasks{table-layout:fixed}.data-table--project-subtasks thead th:first-child,.data-table--project-subtasks tbody>tr:not(.subtask-stages-row) td:first-child{word-break:break-word;width:26%}.data-table--project-subtasks tbody>tr:not(.subtask-stages-row) td{vertical-align:middle}.data-table--project-subtasks tbody>tr:not(.subtask-stages-row) td .select--inline,.data-table--project-subtasks tbody>tr:not(.subtask-stages-row) td .input--compact{min-width:0;max-width:100%}.logs-toolbar{flex-wrap:wrap;justify-content:space-between;align-items:center;gap:.75rem;margin-bottom:.75rem;display:flex}.logs-toolbar__meta{margin:0;font-size:.88rem}.logs-toolbar__pager{gap:.35rem;display:flex}.select--inline{min-width:8.5rem;padding:.35rem .5rem;font-size:.82rem}.input--compact{min-width:7.5rem;padding:.35rem .5rem;font-size:.82rem}.project-grid{grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:1rem;display:grid}.project-card{background:var(--bg-surface);border:1px solid var(--border);border-radius:var(--radius);transition:border-color .15s;position:relative;overflow:hidden;box-shadow:0 8px 24px #0003}.project-card:hover{border-color:#3dd4c040}.project-card__link{color:inherit;padding:1.1rem 4.5rem 1.1rem 1.2rem;text-decoration:none;display:block}.project-card__title{margin:0 0 .35rem;font-size:1.05rem;font-weight:600}.project-card__desc{color:var(--muted);margin:0 0 .65rem;font-size:.86rem;line-height:1.45}.project-card__meta{color:var(--muted);flex-direction:column;gap:.25rem;font-size:.78rem;display:flex}.project-card__progress{color:var(--text);opacity:.85}.project-card__badge{text-transform:uppercase;letter-spacing:.04em;border-radius:999px;margin-top:.65rem;padding:.25rem .5rem;font-size:.72rem;font-weight:700;display:inline-block}.project-card__badge--overdue{color:var(--danger);background:#f071782e}.project-card__delete{position:absolute;top:.65rem;right:.65rem}.back-row{margin:0}.link-back{color:var(--accent);font-size:.9rem;font-weight:600;text-decoration:none}.link-back:hover{text-decoration:underline}.link-inline{color:var(--accent);font-weight:600;text-decoration:none}.link-inline:hover{text-decoration:underline}.workload-summary{grid-template-columns:repeat(auto-fill,minmax(140px,1fr));gap:.75rem;display:grid}.workload-summary--5-cols{grid-template-columns:repeat(2,minmax(0,1fr))}@media (width>=720px){.workload-summary--5-cols{grid-template-columns:repeat(3,minmax(0,1fr))}}@media (width>=1100px){.workload-summary--5-cols{grid-template-columns:repeat(5,minmax(0,1fr))}}.workload-stat{background:var(--bg-surface);border:1px solid var(--border);border-radius:var(--radius-sm);flex-direction:column;gap:.25rem;padding:.85rem 1rem;display:flex}.workload-stat__label{text-transform:uppercase;letter-spacing:.05em;color:var(--muted);font-size:.72rem;font-weight:600}.workload-stat__value{font-size:1.35rem;font-weight:700}.workload-stat--done .workload-stat__value{color:var(--ok)}.workload-stat--progress .workload-stat__value{color:#5b9dff}.workload-stat--overdue .workload-stat__value{color:var(--danger)}.workload-stat--other .workload-stat__value{color:var(--warn)}.workload-block{margin-bottom:1.25rem}.workload-block:last-child{margin-bottom:0}.workload-block__title{margin:0 0 .5rem;font-size:.92rem}.workload-items{flex-direction:column;gap:.35rem;margin:0;padding:0;list-style:none;display:flex}.workload-items__row{background:var(--bg-elevated);border-radius:var(--radius-sm);border:1px solid var(--border);grid-template-columns:auto auto minmax(0,1fr) auto auto;align-items:center;gap:.5rem .65rem;padding:.45rem .55rem;font-size:.86rem;display:grid}.workload-items__bucket{text-transform:uppercase;letter-spacing:.04em;border-radius:999px;padding:.15rem .4rem;font-size:.65rem;font-weight:700}.workload-items__bucket--done{color:var(--ok);background:#7ee0a326}.workload-items__bucket--in_progress{color:#5b9dff;background:#5b9dff26}.workload-items__bucket--overdue{color:var(--danger);background:#f0717826}.workload-items__bucket--other{color:var(--warn);background:#ebc06d1f}.workload-items__type{color:var(--muted);font-size:.72rem}.workload-items__title{text-overflow:ellipsis;white-space:nowrap;min-width:0;overflow:hidden}.workload-badge--done{color:var(--ok);background:#7ee0a326}.workload-badge--in_progress{color:#5b9dff;background:#5b9dff26}.workload-badge--overdue{color:var(--danger);background:#f0717826}.workload-badge--other{color:var(--warn);background:#ebc06d1f}.project-readonly__name{margin:0 0 .35rem;font-size:1.15rem}.subtask-stages-row td{border-bottom:1px solid var(--border);vertical-align:top;background:#0000001f;padding:.85rem 1rem 1rem}.subtask-stages{max-width:720px}.subtask-stages__head{justify-content:space-between;align-items:baseline;gap:.75rem;margin-bottom:.5rem;display:flex}.subtask-stages__title{text-transform:uppercase;letter-spacing:.05em;color:var(--muted);margin:0;font-size:.82rem;font-weight:600}.subtask-stages__progress{font-size:.78rem}.subtask-stages__list{flex-direction:column;gap:.35rem;margin:0 0 .65rem;padding:0;list-style:none;display:flex}.subtask-stages__item{background:var(--bg-elevated);border:1px solid var(--border);border-radius:var(--radius-sm);grid-template-columns:auto auto 1fr auto;align-items:center;gap:.5rem .65rem;padding:.45rem .55rem;display:grid}.subtask-stages__item--done{opacity:.75}.subtask-stages__item--done .subtask-stages__name{color:var(--muted);text-decoration:line-through}.subtask-stages__index{color:var(--muted);text-align:center;width:1.25rem;font-size:.72rem;font-weight:700}.subtask-stages__check{margin:0;display:flex}.subtask-stages__check input{width:1rem;height:1rem;accent-color:var(--accent);cursor:pointer}.subtask-stages__name{font-size:.88rem;font-weight:500}.input--stage-name{width:100%;min-width:0;padding:.35rem .5rem;font-size:.86rem}.subtask-stages__remove{flex-shrink:0}.subtask-stages__add{margin-top:.15rem}.overdue-tag{text-transform:uppercase;letter-spacing:.06em;color:var(--danger);vertical-align:middle;background:#f0717833;border-radius:999px;margin-left:.5rem;padding:.15rem .4rem;font-size:.65rem;font-weight:700;display:inline-block}.notif-bell-wrap{position:relative}.notif-bell{border:1px solid var(--border);border-radius:var(--radius-sm);background:var(--bg-elevated);cursor:pointer;justify-content:center;align-items:center;width:40px;height:40px;padding:0;transition:border-color .15s,background .15s;display:flex;position:relative}.notif-bell:hover{background:#ffffff0f}.notif-bell--active{background:#f0717814;border-color:#f0717873}.notif-bell__svg{color:var(--text);opacity:.9}.notif-bell__count{text-align:center;color:#fff;background:var(--danger);border-radius:999px;min-width:1.15rem;height:1.15rem;padding:0 4px;font-size:.65rem;font-weight:700;line-height:1.15rem;position:absolute;top:-4px;right:-4px}.notif-panel-backdrop{z-index:1190;-webkit-backdrop-filter:blur(3px);backdrop-filter:blur(3px);cursor:pointer;background:#02060c80;border:0;margin:0;padding:0;position:fixed;inset:0}.notif-panel{background:var(--bg-surface);border:1px solid var(--border);border-radius:var(--radius);width:min(380px,100vw - 1.5rem);max-height:min(72vh,440px);box-shadow:var(--shadow), 0 24px 64px #00000059;z-index:1200;padding:.85rem 1rem 1rem;position:fixed;top:50%;left:50%;right:auto;overflow:auto;transform:translate(-50%,-50%)}.notif-panel__head{border-bottom:1px solid var(--border);text-align:center;flex-direction:column;align-items:center;gap:.2rem;margin-bottom:.65rem;padding:0 2.25rem .65rem;display:flex;position:relative}.notif-panel__close{border-radius:var(--radius-sm);width:2rem;height:2rem;color:var(--muted);cursor:pointer;touch-action:manipulation;background:0 0;border:1px solid #0000;justify-content:center;align-items:center;padding:0;font-size:1.35rem;line-height:1;display:flex;position:absolute;top:0;right:0}.notif-panel__close:hover{color:var(--text);border-color:var(--border);background:#ffffff0f}.notif-panel__perm{text-align:center;width:100%;max-width:16rem;margin:0 auto .65rem;display:block}.notif-panel__hint{margin:0 0 .65rem;font-size:.78rem;line-height:1.4}.notif-panel__empty{text-align:center;margin:0;padding:.5rem 0 .25rem;font-size:.88rem}.notif-panel__list{flex-direction:column;gap:.35rem;margin:0;padding:0;list-style:none;display:flex}.notif-panel__link{border-radius:var(--radius-sm);color:inherit;text-align:center;border:1px solid #0000;padding:.55rem .65rem;text-decoration:none;transition:background .15s,border-color .15s;display:block}.notif-panel__link:hover{background:var(--bg-elevated);border-color:var(--border)}.notif-panel__title{text-align:center;font-size:.88rem;font-weight:600;display:block}.notif-panel__meta{color:var(--muted);text-align:center;margin-top:.2rem;font-size:.75rem;line-height:1.4;display:block}.toast-stack{z-index:1210;pointer-events:none;flex-direction:column;align-items:center;gap:.5rem;width:min(420px,100vw - 1.5rem);max-width:min(420px,100vw - 1.5rem);display:flex;position:fixed;bottom:1.25rem;left:50%;right:auto;transform:translate(-50%)}.toast-stack--assign{bottom:5.75rem}.toast--assignment{border-color:#3dd4c073}.toast--assignment .toast__text{min-width:0}.toast--assignment .btn{align-self:center;margin-top:.15rem}.toast{background:var(--bg-surface);border-radius:var(--radius-sm);width:100%;box-shadow:var(--shadow);pointer-events:auto;border:1px solid #f0717859;flex-direction:column;align-items:stretch;gap:.35rem;padding:2rem 1rem .75rem;animation:.25s toast-in;display:flex;position:relative}@keyframes toast-in{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}.toast__text{text-align:center;flex:1;width:100%;font-size:.86rem;line-height:1.45}.toast__close{color:var(--muted);cursor:pointer;background:0 0;border:none;flex-shrink:0;padding:.2rem .35rem;font-size:1.1rem;line-height:1;position:absolute;top:.4rem;right:.4rem}.toast__close:hover{color:var(--text)}.badge{border-radius:999px;padding:.25rem .5rem;font-size:.72rem;font-weight:600}.badge--ok{color:var(--ok);background:#7ee0a326}.badge--warn{color:var(--warn);background:#ebc06d26}.badge--neutral{color:var(--muted);background:#ffffff0f}.accounts-panel-error{margin:-.25rem 0 .75rem}.account-actions{flex-wrap:wrap;align-items:center;gap:.35rem;display:flex}.account-status{text-transform:uppercase;letter-spacing:.04em;align-items:center;gap:.45rem;font-size:.72rem;font-weight:600;display:inline-flex}.account-status__shape{border-radius:50%;flex-shrink:0;width:.55rem;height:.55rem}.account-status--active .account-status__shape{background:var(--ok);box-shadow:0 0 0 2px #7ee0a359}.account-status--inactive .account-status__shape{background:var(--danger);box-shadow:0 0 0 2px #eb575759}.account-status--active{color:var(--ok)}.account-status--inactive{color:var(--danger)}.account-status-cell{vertical-align:middle;position:relative}.account-status-cell__row{flex-wrap:nowrap;align-items:center;gap:.5rem;display:flex}.account-status-menu{position:relative}.account-status-menu__trigger{border:1px solid var(--border);border-radius:var(--radius-sm);background:var(--bg-elevated);min-width:2.25rem;height:1.75rem;color:var(--muted);letter-spacing:.06em;cursor:pointer;-webkit-user-select:none;user-select:none;justify-content:center;align-items:center;padding:0 .4rem;font-size:.85rem;font-weight:700;line-height:1;list-style:none;display:inline-flex}.account-status-menu__trigger::-webkit-details-marker{display:none}.account-status-menu__panel{background:var(--bg-surface);border:1px solid var(--border);border-radius:var(--radius-sm);min-width:10.5rem;box-shadow:var(--shadow);z-index:30;padding:.35rem;position:absolute;top:calc(100% + .2rem);right:0}.account-status-menu__item{border-radius:var(--radius-sm);width:100%;color:var(--text);font:inherit;text-align:left;cursor:pointer;background:0 0;border:none;margin:0;padding:.45rem .55rem;font-size:.88rem;display:block}.account-status-menu__item:hover{background:#ffffff0f}.chart-card{background:var(--bg-elevated);border-radius:var(--radius-sm);border:1px solid var(--border);margin-top:.5rem;padding:1rem}.chart-card__title{margin:0 0 1rem;font-size:.95rem}.chart{align-items:flex-end;gap:.65rem;height:200px;padding:0 .25rem;display:flex}.chart__group{flex-direction:column;flex:1;align-items:center;gap:.5rem;min-width:0;display:flex}.chart__bars{flex:1;justify-content:center;align-items:flex-end;gap:4px;width:100%;display:flex}.chart__bar{border-radius:4px 4px 0 0;width:42%;max-width:16px;min-height:4px;transition:height .3s}.chart__bar--a{background:linear-gradient(180deg, var(--accent), #237a6f)}.chart__bar--b{background:linear-gradient(#5b9dff,#2a5fbf)}.chart__label{color:var(--muted);font-size:.72rem}.chart__legend{color:var(--muted);gap:1.25rem;margin-top:.75rem;font-size:.8rem;display:flex}.chart__legend-item{align-items:center;gap:.35rem;display:inline-flex}.chart__swatch{border-radius:2px;width:10px;height:10px}.chart__swatch--a{background:var(--accent)}.chart__swatch--b{background:#5b9dff}.breakdown{margin-top:1.5rem}.breakdown__title{margin:0 0 .75rem;font-size:.95rem}.breakdown__row{grid-template-columns:100px 1fr 40px;align-items:center;gap:.75rem;margin-bottom:.5rem;font-size:.86rem;display:grid}.breakdown__track{background:#ffffff0f;border-radius:999px;height:8px;overflow:hidden}.breakdown__fill{background:linear-gradient(90deg, var(--accent), #2a8fe6);border-radius:999px;height:100%}.breakdown__pct{text-align:right;color:var(--muted)}.muted{color:var(--muted)}.auth-screen{background:radial-gradient(800px 400px at 50% -20%, #3dd4c01f, transparent), var(--bg-deep);place-items:center;min-height:100vh;padding:2rem;display:grid}.auth-card{background:var(--bg-surface);border:1px solid var(--border);border-radius:var(--radius);width:100%;max-width:420px;box-shadow:var(--shadow);padding:2rem}.auth-card__brand{margin-bottom:1.75rem}.auth-form{flex-direction:column;gap:.75rem;display:flex}.field{flex-direction:column;gap:.35rem;display:flex}.field__label{color:var(--muted);font-size:.82rem;font-weight:600}.field-error{color:var(--danger);margin:0;font-size:.82rem}.auth-demo{border-top:1px solid var(--border);margin-top:1.5rem;padding-top:1.25rem}.auth-demo__title{text-transform:uppercase;letter-spacing:.08em;color:var(--muted);margin:0 0 .5rem;font-size:.78rem}.auth-demo__list{color:var(--text);margin:0;padding-left:1.1rem;font-size:.86rem}.link-btn{color:var(--accent);cursor:pointer;text-underline-offset:2px;background:0 0;border:none;padding:0;font-weight:600;text-decoration:underline}@media (width<=840px){.app-shell{grid-template-columns:1fr}.menu-toggle{display:inline-flex}.sidebar{z-index:1001;flex-flow:column;align-items:stretch;width:min(280px,88vw);transition:transform .22s;position:fixed;top:0;bottom:0;left:0;overflow-y:auto;transform:translate(-100%);box-shadow:8px 0 40px #00000073}.app-shell--nav-open .sidebar{transform:translate(0)}.sidebar__close-mobile{display:flex}.sidebar__nav{flex-flow:column;flex:1}.sidebar__footer{border-top:1px solid var(--border);width:100%;margin-top:auto;padding-top:1rem}.topbar{grid-template-rows:auto auto;grid-template-columns:auto 1fr;align-items:center;gap:.55rem .75rem;padding:1rem 1.1rem .65rem;display:grid}.menu-toggle{grid-area:1/1;justify-self:start}.topbar__actions{grid-area:1/2;place-self:center end;margin-left:0}.topbar__titles{flex:unset;grid-area:2/1/auto/-1;min-width:0;padding-top:.1rem}.topbar__page{font-size:1.15rem;line-height:1.25}.topbar__crumb{margin-top:.2rem;font-size:.8rem;line-height:1.35}.content{padding:1rem 1.1rem 2rem}}.rbac-toolbar{flex-wrap:wrap;justify-content:space-between;align-items:flex-end;gap:.75rem 1rem;margin-bottom:1rem;display:flex}.field--inline{flex-direction:column;gap:.25rem;margin:0;display:flex}.rbac-matrix-wrap{overflow-x:auto}.rbac-matrix{min-width:640px}.rbac-matrix th,.rbac-matrix td{vertical-align:middle}.rbac-matrix__action{text-align:center;white-space:nowrap;text-transform:uppercase;letter-spacing:.04em;color:var(--muted);font-size:.72rem}.rbac-matrix__cell{text-align:center}.rbac-matrix__checkbox{cursor:pointer;width:1.1rem;height:1.1rem;accent-color:var(--accent)}.rbac-matrix__checkbox:disabled{cursor:not-allowed;opacity:.45}.rbac-cap-cell{max-width:14rem;font-size:.82rem}.employee-form__grid--inline{flex-wrap:wrap;align-items:flex-end;gap:.75rem 1rem;display:flex}.employee-form__grid--inline .field--grow{flex:16rem;min-width:0}.employee-form__grid--inline .field--actions{flex:none}
