:root{--c-bg: #f4f6f9;--c-surface: #ffffff;--c-sidebar: #1e293b;--c-sidebar-hover: #334155;--c-sidebar-active: #2563eb;--c-border: #e2e8f0;--c-text: #1e293b;--c-muted: #64748b;--c-primary: #2563eb;--c-primary-hover: #1d4ed8;--c-danger: #dc2626;--sidebar-w: 240px;--sidebar-w-collapsed: 60px;--header-h: 56px;--panel-w: 320px}*{box-sizing:border-box}html,body,#root{height:100%;margin:0}body{font-family:system-ui,-apple-system,Segoe UI,Roboto,sans-serif;color:var(--c-text);background:var(--c-bg);font-size:14px}.login{min-height:100%;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,#1e293b,#2563eb);padding:24px}.login__card{background:var(--c-surface);width:100%;max-width:380px;padding:32px;border-radius:12px;box-shadow:0 20px 40px #00000040;display:flex;flex-direction:column;gap:16px}.login__brand{font-size:20px;font-weight:700;color:var(--c-text)}.login__subtitle{margin:-8px 0 0;color:var(--c-muted)}.login__submit{margin-top:8px}.login__note{margin:0;font-size:12px;color:var(--c-muted);line-height:1.4}.login__error{margin:-4px 0 0;padding:8px 10px;font-size:13px;color:#b91c1c;background:#fef2f2;border:1px solid #fecaca;border-radius:6px}.shell--loading{display:flex;align-items:center;justify-content:center;min-height:100vh;color:var(--c-muted)}.field{display:flex;flex-direction:column;gap:6px}.field__label{font-size:12px;font-weight:600;color:var(--c-muted)}.field__input{padding:10px 12px;border:1px solid var(--c-border);border-radius:8px;font-size:14px;background:#fff;color:var(--c-text)}.field__input:focus{outline:none;border-color:var(--c-primary);box-shadow:0 0 0 3px #2563eb26}.btn{padding:10px 14px;border:none;border-radius:8px;font-size:14px;font-weight:600;cursor:pointer}.btn--primary{background:var(--c-primary);color:#fff}.btn--primary:hover{background:var(--c-primary-hover)}.shell{display:flex;height:100%}.shell__main{flex:1;display:flex;flex-direction:column;min-width:0}.shell__body{flex:1;display:flex;min-height:0}.shell__body--withpanel .workspace{border-right:1px solid var(--c-border)}.sidebar{width:var(--sidebar-w);background:var(--c-sidebar);color:#cbd5e1;display:flex;flex-direction:column;transition:width .15s ease;flex-shrink:0}.sidebar--collapsed{width:var(--sidebar-w-collapsed)}.sidebar__head{height:var(--header-h);display:flex;align-items:center;justify-content:space-between;padding:0 12px;border-bottom:1px solid var(--c-sidebar-hover)}.sidebar__brand{font-weight:700;color:#fff;font-size:14px;white-space:nowrap;overflow:hidden}.sidebar__toggle{background:transparent;border:none;color:#cbd5e1;cursor:pointer;font-size:16px;padding:4px 8px;border-radius:6px}.sidebar__toggle:hover{background:var(--c-sidebar-hover)}.sidebar__nav{padding:8px;display:flex;flex-direction:column;gap:4px;overflow-y:auto}.sidebar__item{display:flex;align-items:center;gap:12px;padding:10px 12px;border-radius:8px;color:#cbd5e1;text-decoration:none;white-space:nowrap;overflow:hidden}.sidebar__item:hover{background:var(--c-sidebar-hover);color:#fff}.sidebar__item--active{background:var(--c-sidebar-active);color:#fff}.sidebar__icon{display:inline-flex;align-items:center;justify-content:center;width:22px;height:22px;border-radius:6px;background:#ffffff1f;font-size:12px;font-weight:700;flex-shrink:0}.sidebar__label{overflow:hidden;text-overflow:ellipsis}.header{height:var(--header-h);background:var(--c-surface);border-bottom:1px solid var(--c-border);display:flex;align-items:center;justify-content:space-between;padding:0 16px;flex-shrink:0}.header__title{font-weight:700;font-size:16px}.header__actions{display:flex;align-items:center;gap:12px}.header__search{padding:8px 12px;border:1px solid var(--c-border);border-radius:8px;width:220px;font-size:13px}.header__search:focus{outline:none;border-color:var(--c-primary)}.header__searchbox{position:relative}.header__searchresults{position:absolute;top:calc(100% + 6px);left:0;background:var(--c-surface);border:1px solid var(--c-border);border-radius:10px;box-shadow:0 12px 28px #00000026;width:340px;max-height:70vh;overflow-y:auto;padding:6px;z-index:30}.header__searchstate{padding:10px 12px;font-size:13px;color:var(--c-muted)}.header__searchgroup{padding:4px 0}.header__searchgroup+.header__searchgroup{border-top:1px solid var(--c-border)}.header__searchgrouplabel{font-size:11px;text-transform:uppercase;letter-spacing:.04em;color:var(--c-muted);padding:6px 10px 2px}.header__searchitem{display:flex;flex-direction:column;gap:2px;width:100%;text-align:left;background:transparent;border:none;padding:7px 10px;border-radius:6px;cursor:pointer}.header__searchitem:hover{background:var(--c-bg)}.header__searchitem--static{cursor:default}.header__searchitemtitle{font-size:13px;color:var(--c-text)}.header__searchitemmeta{font-size:12px;color:var(--c-muted)}.header__searchtag{display:inline-block;font-size:10px;font-weight:600;text-transform:uppercase;background:var(--c-primary);color:#fff;border-radius:4px;padding:1px 5px}.header__bell{position:relative;background:transparent;border:none;cursor:pointer;font-size:18px;padding:4px}.header__dot{position:absolute;top:2px;right:2px;width:8px;height:8px;background:var(--c-danger);border-radius:50%;border:1px solid #fff}.header__user{position:relative}.header__userbtn{display:flex;align-items:center;gap:8px;background:transparent;border:1px solid transparent;cursor:pointer;padding:4px 8px;border-radius:8px}.header__userbtn:hover{background:var(--c-bg)}.header__avatar{width:32px;height:32px;border-radius:50%;background:var(--c-primary);color:#fff;display:inline-flex;align-items:center;justify-content:center;font-weight:700}.header__userinfo{display:flex;flex-direction:column;align-items:flex-start;line-height:1.2}.header__username{font-weight:600}.header__userrole{font-size:11px;color:var(--c-muted)}.header__menu{position:absolute;top:calc(100% + 6px);right:0;background:var(--c-surface);border:1px solid var(--c-border);border-radius:10px;box-shadow:0 12px 28px #00000026;min-width:220px;padding:8px;z-index:20}.header__menuhead{display:flex;flex-direction:column;gap:2px;padding:8px 10px;border-bottom:1px solid var(--c-border);margin-bottom:6px}.header__menuhead span{font-size:12px;color:var(--c-muted)}.header__menurole{color:var(--c-primary)!important;font-weight:600}.header__menuitem{display:block;width:100%;text-align:left;background:transparent;border:none;padding:8px 10px;border-radius:6px;cursor:pointer;font-size:13px;color:var(--c-text)}.header__menuitem:hover:not(:disabled){background:var(--c-bg)}.header__menuitem:disabled{color:var(--c-muted);cursor:default}.header__menuitem--danger{color:var(--c-danger)}.workspace{flex:1;padding:24px;overflow-y:auto;min-width:0}.workspace--full{width:100%}.placeholder__title,.dashboard__title{margin:0 0 4px;font-size:22px}.placeholder__msg{color:var(--c-muted);font-size:15px}.placeholder__desc{color:var(--c-muted)}.dashboard__subtitle{margin:0 0 20px;color:var(--c-muted)}.kpi-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(160px,1fr));gap:16px}.kpi-card{background:var(--c-surface);border:1px solid var(--c-border);border-radius:12px;padding:16px;font:inherit;text-align:left;color:inherit;width:100%}.kpi-card--link{cursor:pointer;transition:border-color .12s ease,box-shadow .12s ease}.kpi-card--link:hover{border-color:var(--c-primary);box-shadow:0 1px 6px #00000014}.kpi-card:disabled{cursor:default}.kpi-card__label{font-weight:600;color:var(--c-muted);font-size:13px}.kpi-card__total{font-size:28px;font-weight:700;margin:8px 0}.kpi-card__overdue{font-size:12px;color:var(--c-muted);display:flex;align-items:center;gap:6px}.kpi-card__dot{width:8px;height:8px;border-radius:50%;background:var(--c-danger);display:inline-block}.kpi-card__overdue--alert{color:var(--c-danger);font-weight:600}.kpi-card__overdue--na{color:var(--c-muted);font-style:italic}.analytics{width:var(--panel-w);flex-shrink:0;background:var(--c-surface);padding:20px;overflow-y:auto;display:flex;flex-direction:column;gap:24px}.analytics__widget{border:1px solid var(--c-border);border-radius:12px;padding:16px}.analytics__title{margin:0 0 8px;font-size:14px}.analytics__placeholder{margin:0 0 12px;font-size:12px;color:var(--c-muted)}.analytics__list{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:10px}.analytics__row{display:flex;flex-direction:column;gap:4px;font-size:12px}.analytics__bar{height:8px;border-radius:4px;background:var(--c-primary);display:block}.analytics__hint{margin:-4px 0 12px;font-size:11px;color:var(--c-muted)}.analytics__rowhead{display:flex;align-items:baseline;gap:6px}.analytics__rank{color:var(--c-muted);font-variant-numeric:tabular-nums}.analytics__name{flex:1;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.analytics__value{font-weight:600;font-variant-numeric:tabular-nums}.analytics__track{display:block;height:8px;border-radius:4px;background:var(--c-border);overflow:hidden}.analytics__track .analytics__bar{transition:width .4s ease}.analytics__feed{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:12px}.analytics__event{border-left:2px solid var(--c-border);padding-left:10px}.analytics__event-main{font-size:13px}.analytics__event-action{font-weight:600;text-transform:capitalize}.analytics__event-entity{color:var(--c-muted)}.analytics__event-meta{font-size:11px;color:var(--c-muted);margin-top:2px}.btn--ghost{background:var(--c-surface);color:var(--c-text);border:1px solid var(--c-border)}.btn--ghost:hover:not(:disabled){background:var(--c-bg)}.btn--danger{background:#fef2f2;color:var(--c-danger);border:1px solid #fecaca}.btn--danger:hover:not(:disabled){background:#fee2e2}.btn:disabled{opacity:.55;cursor:not-allowed}.admin-shell{display:flex;flex-direction:column;gap:16px}.admin-tabs{display:flex;gap:4px;border-bottom:1px solid var(--c-border);flex-wrap:wrap}.admin-tab{background:transparent;border:none;border-bottom:2px solid transparent;padding:8px 14px;font-size:14px;font-weight:600;color:var(--c-muted);cursor:pointer}.admin-tab:hover{color:var(--c-text)}.admin-tab--active{color:var(--c-primary);border-bottom-color:var(--c-primary)}.admin{display:flex;flex-direction:column;gap:14px}.admin__head{display:flex;align-items:flex-start;justify-content:space-between;gap:16px}.admin__subtitle{margin:4px 0 0;color:var(--c-muted);font-size:13px}.admin__filter{max-width:360px}.admin__table{width:100%;border-collapse:collapse;background:var(--c-surface);border:1px solid var(--c-border);border-radius:12px;overflow:hidden}.admin__table th,.admin__table td{text-align:left;padding:10px 12px;border-bottom:1px solid var(--c-border);font-size:13px;vertical-align:middle}.admin__table th{background:var(--c-bg);color:var(--c-muted);font-weight:600;font-size:12px}.admin__table tr:last-child td{border-bottom:none}.admin__actionscol{width:1%;white-space:nowrap}.admin__actions{display:flex;gap:6px;white-space:nowrap}.admin__actions .btn{padding:6px 10px;font-size:12px}.admin__statecell{text-align:center;color:var(--c-muted);padding:24px}.badge{display:inline-block;padding:2px 8px;border-radius:999px;font-size:11px;font-weight:600;text-transform:capitalize}.badge--active{background:#dcfce7;color:#166534}.badge--inactive{background:#f1f5f9;color:var(--c-muted)}.admin__pager{display:flex;align-items:center;justify-content:space-between;gap:12px}.admin__pagerinfo{font-size:12px;color:var(--c-muted)}.admin__pagerbtns{display:flex;gap:8px}.admin__pagerbtns .btn{padding:6px 12px;font-size:13px}.modal__backdrop{position:fixed;top:0;right:0;bottom:0;left:0;background:#0f172a73;display:flex;align-items:flex-start;justify-content:center;padding:48px 16px;z-index:50;overflow-y:auto}.modal__card{background:var(--c-surface);width:100%;max-width:480px;border-radius:12px;box-shadow:0 20px 50px #0000004d}.modal__head{display:flex;align-items:center;justify-content:space-between;padding:16px 20px;border-bottom:1px solid var(--c-border)}.modal__title{margin:0;font-size:16px}.modal__close{background:transparent;border:none;font-size:22px;line-height:1;cursor:pointer;color:var(--c-muted)}.modal__body{padding:20px}.admin__form{display:flex;flex-direction:column;gap:14px}.admin__formrow{display:grid;grid-template-columns:1fr 1fr;gap:12px}.admin__checkfield{flex-direction:row;align-items:center;gap:8px}.admin__formactions{display:flex;justify-content:flex-end;gap:8px;margin-top:4px}.admin__panel{display:flex;flex-direction:column;gap:14px}.admin__assignrow{display:flex;gap:8px}.admin__assignrow .field__input{flex:1}.admin__chiplist{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:8px}.admin__chip{display:flex;align-items:center;justify-content:space-between;gap:8px;padding:8px 12px;border:1px solid var(--c-border);border-radius:8px;font-size:13px}.admin__chipx{background:transparent;border:none;color:var(--c-danger);font-size:18px;line-height:1;cursor:pointer}@media (max-width: 900px){.analytics{display:none}.header__search{width:120px}}.badge--draft{background:#f1f5f9;color:var(--c-muted)}.badge--submitted{background:#dbeafe;color:#1e40af}.badge--inspected{background:#fef9c3;color:#854d0e}.badge--approved{background:#dcfce7;color:#166534}.badge--rejected{background:#fee2e2;color:#991b1b}.badge--overdue{background:#dc2626;color:#fff}.admin .admin__filter{max-width:none;display:flex;flex-wrap:wrap;gap:12px;margin-bottom:12px}.admin .admin__filter .field{min-width:160px}.admin__rowlink{cursor:pointer}.admin__rowlink:hover{background:var(--c-bg)}.nfi-detail{padding:4px}.nfi-detail__grid{display:grid;grid-template-columns:1fr var(--panel-w);gap:20px;align-items:start}@media (max-width: 900px){.nfi-detail__grid{grid-template-columns:1fr}}.nfi-detail__main{background:var(--c-surface);border:1px solid var(--c-border);border-radius:12px;padding:16px}.nfi-detail__fields{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:8px 16px;margin:0 0 16px}@media (max-width: 640px){.nfi-detail__fields{grid-template-columns:1fr}}.nfi-detail__field dt{font-size:11px;text-transform:uppercase;letter-spacing:.04em;color:var(--c-muted);margin-bottom:2px}.nfi-detail__field dd{margin:0;font-size:13px}.nfi-detail__upload{border-top:1px solid var(--c-border);padding-top:12px;margin-top:4px}.nfi-detail__actions{display:flex;flex-wrap:wrap;gap:8px;border-top:1px solid var(--c-border);margin-top:16px;padding-top:16px}.nfi-detail__chat{position:sticky;top:0}.chat{background:var(--c-surface);border:1px solid var(--c-border);border-radius:12px;padding:12px;display:flex;flex-direction:column;max-height:70vh}.chat__title{margin:0 0 8px;font-size:14px}.chat__feed{flex:1;overflow-y:auto;display:flex;flex-direction:column;gap:8px;min-height:120px}.chat__item{border:1px solid var(--c-border);border-radius:8px;padding:6px 8px;font-size:13px}.chat__item--change{background:#f8fafc;border-style:dashed}.chat__meta{display:flex;justify-content:space-between;gap:8px;font-size:11px;color:var(--c-muted);margin-bottom:2px}.chat__comment{color:var(--c-muted);font-style:italic;margin-top:2px}.chat__composer{display:flex;gap:8px;margin-top:8px}.chat__composer .field__input{flex:1}.header__notif{position:relative}.header__notifmenu{position:absolute;top:calc(100% + 6px);right:0;background:var(--c-surface);border:1px solid var(--c-border);border-radius:10px;box-shadow:0 12px 28px #00000026;width:320px;max-height:420px;overflow:hidden;display:flex;flex-direction:column;z-index:20}.header__notifhead{display:flex;justify-content:space-between;align-items:center;padding:10px 12px;border-bottom:1px solid var(--c-border)}.header__notifcount{font-size:11px;color:var(--c-danger);font-weight:600}.header__notiflist{overflow-y:auto;padding:4px}.header__notifitem{display:flex;flex-direction:column;gap:2px;width:100%;text-align:left;background:transparent;border:none;border-radius:8px;padding:8px 10px;cursor:pointer}.header__notifitem:hover{background:var(--c-bg)}.header__notifitem--unread{background:#eff6ff}.header__notiftitle{font-weight:600;font-size:13px}.header__notifmsg{font-size:12px;color:var(--c-muted)}.header__notiftime{font-size:11px;color:var(--c-muted)}.workflows__tabs{display:flex;gap:4px;border-bottom:1px solid var(--c-border);margin-bottom:16px}.workflows__tab{-webkit-appearance:none;-moz-appearance:none;appearance:none;background:transparent;border:none;border-bottom:2px solid transparent;padding:10px 16px;font-size:14px;font-weight:600;color:var(--c-muted);cursor:pointer}.workflows__tab:hover{color:var(--c-text, #111)}.workflows__tab--active{color:var(--c-primary, #2563eb);border-bottom-color:var(--c-primary, #2563eb)}.admin__linklist{margin:0;padding-left:0;list-style:none}.admin__linklist li{padding:4px 0;font-size:13px}.drawing__stage{position:relative;width:100%;height:70vh;min-height:420px;border:1px solid var(--c-border);border-radius:8px;overflow:hidden;background:#f8fafc}.drawing__pdf{position:absolute;top:0;right:0;bottom:0;left:0;width:100%;height:100%;border:none}.drawing__overlay{position:absolute;top:0;right:0;bottom:0;left:0;pointer-events:none}.drawing__overlay--active{pointer-events:auto;cursor:crosshair;background:#2563eb0a}.drawing__pin{position:absolute;transform:translate(-50%,-50%);width:24px;height:24px;border-radius:50% 50% 50% 0;border:2px solid #fff;box-shadow:0 1px 4px #0006;color:#fff;font-size:11px;font-weight:700;line-height:1;cursor:pointer;pointer-events:auto;display:flex;align-items:center;justify-content:center}.drawing__pin--ncr{background:#dc2626}.drawing__pin--nfi{background:#2563eb}.field__hint{display:block;margin-top:4px;font-size:12px;color:var(--c-muted)}.forms-detail__tracker{margin:16px 0}.forms-stages{list-style:none;margin:8px 0 0;padding:0}.forms-stage{border:1px solid var(--c-border, #e2e8f0);border-left-width:4px;border-radius:6px;padding:8px 10px;margin-bottom:6px;background:#fff}.forms-stage--done{border-left-color:#16a34a}.forms-stage--active{border-left-color:#2563eb;background:#eff6ff}.forms-stage--pending{border-left-color:#cbd5e1}.forms-stage--locked{border-left-color:#cbd5e1;opacity:.55}.forms-stage__head{display:flex;align-items:center;gap:8px;flex-wrap:wrap}.forms-stage__num{display:inline-flex;align-items:center;justify-content:center;width:22px;height:22px;border-radius:50%;background:#f1f5f9;color:var(--c-muted);font-size:12px;font-weight:600}.forms-stage--done .forms-stage__num{background:#16a34a;color:#fff}.forms-stage--active .forms-stage__num{background:#2563eb;color:#fff}.forms-stage__name{font-weight:600;font-size:13px}.forms-stage__type{font-size:11px;color:var(--c-muted);text-transform:uppercase}.forms-stage__state{margin-left:auto;font-size:11px}.forms-stage__state--done{background:#dcfce7;color:#166534}.forms-stage__state--active{background:#dbeafe;color:#1e40af}.forms-stage__state--locked{background:#f1f5f9;color:var(--c-muted)}.forms-stage__roles{margin-top:6px;font-size:12px}.forms-stage__progress{color:var(--c-muted)}.forms-stage__role{display:inline-block;margin-right:6px;padding:1px 6px;border-radius:4px;background:#f1f5f9;color:var(--c-muted);font-size:12px}.forms-stage__role--done{background:#dcfce7;color:#166534}.forms-stage__role--rejected{background:#fee2e2;color:#991b1b}.forms-stage__role--pending{background:#f1f5f9;color:var(--c-muted)}.forms-stage__history{list-style:none;margin:6px 0 0;padding:6px 0 0;border-top:1px dashed var(--c-border, #e2e8f0)}.forms-stage__historyrow{font-size:12px;padding:2px 0}.progress-header{margin:12px 0 16px;font-size:15px;display:flex;align-items:center;gap:12px;flex-wrap:wrap}.progress-header__code{color:var(--c-muted);font-size:13px}.progress-header__warn{color:#b45309;font-size:13px}.progress-kpis{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:16px;margin-bottom:24px}.progress-card{background:var(--c-surface);border:1px solid var(--c-border);border-radius:10px;padding:16px;display:flex;flex-direction:column;gap:10px;align-items:center;text-align:center}.progress-card--primary{grid-column:span 1}.progress-card__title{margin:0;font-size:14px;color:var(--c-text);align-self:flex-start}.progress-card__big{font-size:32px;font-weight:700;color:var(--c-primary)}.progress-card__sub{margin:0;font-size:12px;color:var(--c-muted)}.donut{width:130px;height:130px}.donut__track{fill:none;stroke:var(--c-border);stroke-width:12}.donut__fill{fill:none;stroke:var(--c-primary);stroke-width:12;stroke-linecap:round;transition:stroke-dasharray .4s ease}.donut__label{font-size:20px;font-weight:700;fill:var(--c-text)}.progress-bar{width:100%;height:8px;background:var(--c-border);border-radius:4px;overflow:hidden}.progress-bar__fill{height:100%;background:var(--c-primary);border-radius:4px;transition:width .4s ease}.progress-section{margin-bottom:28px}.progress-cell{display:flex;align-items:center;gap:8px;min-width:140px}.progress-cell .progress-bar{flex:1}.progress-cell span{font-size:12px;white-space:nowrap}.progress-status{font-size:12px;padding:2px 8px;border-radius:999px}.progress-status--not_started{background:#f1f5f9;color:var(--c-muted)}.progress-status--in_progress{background:#dbeafe;color:#1e40af}.progress-status--completed{background:#dcfce7;color:#166534}.link-button{background:none;border:none;color:var(--c-primary);cursor:pointer;padding:0;font-size:13px;text-decoration:underline}.link-button:hover{color:var(--c-primary-hover)}.schedule-status--delayed{background:#fee2e2;color:#991b1b}.schedule-status--ahead{background:#dcfce7;color:#166534}.schedule-status--on-schedule{background:#e2e8f0;color:var(--c-text)}.schedule-band{display:flex;flex-wrap:wrap;gap:24px;padding:14px 18px;background:var(--c-surface);border:1px solid var(--c-border);border-radius:8px;margin:12px 0}.schedule-band__item{display:flex;flex-direction:column;gap:2px}.schedule-band__k{font-size:11px;text-transform:uppercase;letter-spacing:.04em;color:var(--c-muted)}.schedule-band__v{font-size:15px;font-weight:600;color:var(--c-text)}.schedule-band__warn{color:#b45309;font-weight:500;font-size:13px}.schedule-band__chip{padding:2px 10px;border-radius:999px;font-size:13px}.schedule-legend{display:flex;flex-wrap:wrap;gap:18px;font-size:12px;color:var(--c-muted);margin:8px 0 14px}.schedule-legend span{display:inline-flex;align-items:center;gap:6px}.schedule-swatch{width:14px;height:12px;border-radius:3px;display:inline-block}.schedule-swatch--on-schedule{background:var(--c-primary)}.schedule-swatch--delayed{background:var(--c-danger)}.schedule-swatch--ahead{background:#16a34a}.schedule-swatch--planned{background:#0f172a;width:3px;border-radius:0}.schedule-swatch--today{background:#f59e0b;width:3px;border-radius:0}.gantt{display:flex;flex-direction:column;gap:10px}.gantt__row{display:grid;grid-template-columns:220px 1fr 150px;align-items:center;gap:12px}.gantt__label{display:flex;flex-direction:column;gap:2px;min-width:0}.gantt__name{font-weight:600;color:var(--c-text);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.gantt__dates{font-size:11px;color:var(--c-muted)}.gantt__track{position:relative;height:28px;background:#f1f5f9;border-radius:6px;overflow:hidden}.gantt__today{position:absolute;top:0;bottom:0;width:2px;background:#f59e0b;z-index:3}.gantt__bar{position:absolute;top:3px;bottom:3px;border-radius:4px;overflow:hidden;display:flex;align-items:center}.gantt__bar--on-schedule{background:#2563eb2e}.gantt__bar--delayed{background:#dc26262e}.gantt__bar--ahead{background:#16a34a2e}.gantt__fill{position:absolute;left:0;top:0;bottom:0;border-radius:4px}.gantt__bar--on-schedule .gantt__fill{background:var(--c-primary)}.gantt__bar--delayed .gantt__fill{background:var(--c-danger)}.gantt__bar--ahead .gantt__fill{background:#16a34a}.gantt__planned{position:absolute;top:-3px;bottom:-3px;width:2px;background:#0f172a;z-index:2}.gantt__barlabel{position:relative;z-index:2;margin-left:6px;font-size:11px;font-weight:600;color:var(--c-text);mix-blend-mode:luminosity}.gantt__unscheduled{position:absolute;top:0;right:0;bottom:0;left:0;display:flex;align-items:center;justify-content:center;font-size:12px;color:var(--c-muted);font-style:italic}.gantt__meta{display:flex;flex-direction:column;align-items:flex-start;gap:4px}.gantt__dev{font-size:12px;color:var(--c-muted)}:root{--fin-dark-blue: #1e3a8a;--fin-light-grey: #d1d5db;--fin-green: #16a34a;--fin-red: #dc2626;--fin-light-blue: #38bdf8;--fin-purple: #7c3aed}.financial-grid{display:grid;grid-template-columns:1.4fr 1fr 1fr;gap:20px;margin-bottom:28px}.financial-card--primary{grid-column:1 / -1;display:grid;grid-template-columns:minmax(220px,320px) 1fr;gap:24px;align-items:center}.financial-card{border:1px solid var(--c-border);border-radius:10px;padding:18px;background:var(--c-surface, #fff);display:flex;flex-direction:column;gap:12px}.financial-card__title{margin:0;font-size:14px;color:var(--c-text)}.financial-card__pct{font-size:34px;font-weight:700}.fin-donut{width:100%;max-width:240px;height:auto}.fin-donut--primary{max-width:300px}.fin-donut__hole-pct{font-size:22px;font-weight:700;fill:var(--c-text)}.fin-donut__hole-sub{font-size:10px;fill:var(--c-muted)}.fin-legend{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:8px}.fin-legend__item{display:flex;align-items:center;gap:8px;font-size:13px}.fin-legend__swatch{width:14px;height:14px;border-radius:3px;flex:none}.fin-legend__label{color:var(--c-text);flex:1}.fin-legend__value{color:var(--c-muted);font-variant-numeric:tabular-nums}.fin-kpis{display:flex;gap:16px;flex-wrap:wrap}.fin-kpi{display:flex;flex-direction:column;gap:2px}.fin-kpi__label{font-size:12px;color:var(--c-muted)}.fin-kpi__value{font-size:18px;font-weight:600}.monitoring-layout{display:grid;grid-template-columns:280px 1fr;gap:16px;min-height:500px}.monitoring-list{border:1px solid var(--c-border);border-radius:8px;padding:12px;background:var(--c-surface, #fff);overflow-y:auto}.monitoring-list__title{margin:0 0 10px;font-size:14px;font-weight:600}.monitoring-list__group{font-size:11px;text-transform:uppercase;letter-spacing:.06em;color:var(--c-muted);margin:10px 0 4px}.monitoring-list__item{display:flex;align-items:center;justify-content:space-between;width:100%;padding:8px 10px;margin-bottom:4px;border:1px solid transparent;border-radius:6px;background:transparent;cursor:pointer;font-size:13px;text-align:left;color:var(--c-text);gap:8px}.monitoring-list__item:hover{background:var(--c-hover, #f5f5f5)}.monitoring-list__item--active{border-color:var(--c-primary, #2563eb);background:var(--c-primary-light, #eff6ff)}.monitoring-list__item--inactive{opacity:.6}.monitoring-list__name{flex:1;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.monitoring-viewer{border:1px solid var(--c-border);border-radius:8px;background:var(--c-surface, #fff);overflow:hidden;display:flex;flex-direction:column}.monitoring-viewer__empty{display:flex;align-items:center;justify-content:center;flex:1;padding:40px;color:var(--c-muted);font-size:14px}.monitoring-feed{display:flex;flex-direction:column;height:100%}.monitoring-feed__header{display:flex;align-items:center;justify-content:space-between;padding:10px 14px;border-bottom:1px solid var(--c-border);background:var(--c-surface, #fff);gap:10px}.monitoring-feed__name{margin:0;font-size:14px;font-weight:600}.monitoring-feed__iframe{flex:1;width:100%;min-height:420px;border:none;background:#111}.btn--sm{padding:3px 8px;font-size:12px}.btn--danger{background:var(--c-danger, #dc2626);color:#fff;border-color:var(--c-danger, #dc2626)}.btn--danger:hover{background:#b91c1c}.btn--ghost{background:transparent;color:var(--c-primary, #2563eb);border:1px solid var(--c-primary, #2563eb)}.lang-switcher{display:flex;gap:2px;border:1px solid var(--c-border);border-radius:6px;overflow:hidden;flex-shrink:0}.lang-switcher__btn{background:transparent;border:none;padding:4px 8px;font-size:12px;font-weight:600;color:var(--c-muted);cursor:pointer;line-height:1}.lang-switcher__btn:hover{background:var(--c-bg);color:var(--c-text)}.lang-switcher__btn--active{background:var(--c-primary);color:#fff}.profile-page{max-width:780px}.profile-sections{display:flex;flex-direction:column;gap:32px}.profile-section{background:var(--c-surface);border:1px solid var(--c-border);border-radius:12px;padding:20px 24px;display:flex;flex-direction:column;gap:14px}.profile-section__title{margin:0;font-size:15px;font-weight:700}.profile-banner{padding:8px 12px;border-radius:6px;font-size:13px}.profile-banner--ok{background:#dcfce7;color:#166534;border:1px solid #bbf7d0}.profile-banner--err{background:#fef2f2;color:#b91c1c;border:1px solid #fecaca}.profile-prefs__hint{margin:0;font-size:13px;color:var(--c-muted)}.profile-prefs__loading{margin:0;color:var(--c-muted);font-size:13px}.profile-prefs__table-wrap{overflow-x:auto}.profile-prefs__table{width:100%;border-collapse:collapse;min-width:400px}.profile-prefs__th{text-align:center;padding:8px 12px;font-size:12px;font-weight:600;color:var(--c-muted);text-transform:uppercase;letter-spacing:.04em;border-bottom:1px solid var(--c-border)}.profile-prefs__th--cat{text-align:left;min-width:180px}.profile-prefs__row:hover{background:var(--c-bg)}.profile-prefs__cat{font-size:13px;font-weight:500;color:var(--c-text);text-align:left;padding:10px 12px 10px 0;border-bottom:1px solid var(--c-border);white-space:nowrap}.profile-prefs__cell{text-align:center;padding:10px 12px;border-bottom:1px solid var(--c-border)}.profile-toggle{display:inline-flex;align-items:center;width:42px;height:24px;border-radius:12px;background:var(--c-border);border:none;cursor:pointer;padding:2px;transition:background .15s ease;position:relative}.profile-toggle--on{background:var(--c-primary)}.profile-toggle:disabled{opacity:.5;cursor:not-allowed}.profile-toggle__knob{display:block;width:20px;height:20px;border-radius:50%;background:#fff;box-shadow:0 1px 3px #0003;transition:transform .15s ease;transform:translate(0);flex-shrink:0}.profile-toggle--on .profile-toggle__knob{transform:translate(18px)}@media (max-width: 600px){.profile-page{max-width:100%}.profile-section{padding:14px 16px}}
