@tailwind utilities;:root{--bg: #f3f5f8;--bg-gradient-start: #eef3fb;--bg-gradient-end: #f3f5f8;--panel: #ffffff;--surface-subtle: #f8fbff;--surface-muted: #edf3ff;--surface-strong: #e6efff;--header-bg-start: #ffffff;--header-bg-end: #f7faff;--sidebar-bg-start: #ffffff;--sidebar-bg-end: #f8fbff;--sidebar-radial: rgba(15, 107, 255, .13);--ink: #17233a;--ink-strong: #0f1c31;--muted: #6d7585;--muted-strong: #5f6f88;--primary: #0f6bff;--primary-contrast: #ffffff;--primary-soft: #eaf2ff;--primary-soft-border: #bdd2f8;--primary-soft-ink: #133f86;--info: #1f5ccf;--success: #12744d;--warning: #9c5a00;--danger: #c32737;--border: #d9deea;--border-strong: #cfd9ee;--divider: #e6ecf8;--ring: #0f6bff;--shadow-soft: 0 2px 10px rgba(17, 35, 67, .05);--shadow-pop: 0 12px 26px rgba(15, 28, 51, .14);--overlay: rgba(15, 23, 42, .45);--tooltip-bg: #1d2b42;--tooltip-ink: #ffffff;--input-bg: #ffffff;--input-placeholder: #8a95a9}:root[data-theme=dark]{--bg: #111722;--bg-gradient-start: #151d2b;--bg-gradient-end: #101722;--panel: #162132;--surface-subtle: #1b273a;--surface-muted: #203149;--surface-strong: #233a59;--header-bg-start: #152033;--header-bg-end: #111a2a;--sidebar-bg-start: #131f31;--sidebar-bg-end: #111a29;--sidebar-radial: rgba(67, 150, 255, .18);--ink: #e6edfb;--ink-strong: #f1f5ff;--muted: #9baac2;--muted-strong: #b3c0d5;--primary: #69acff;--primary-contrast: #0b1b30;--primary-soft: #23395a;--primary-soft-border: #37598a;--primary-soft-ink: #b9d7ff;--info: #8bc3ff;--success: #43c98a;--warning: #f0bd70;--danger: #ff8392;--border: #2d3e56;--border-strong: #354b68;--divider: #26354a;--ring: #84beff;--shadow-soft: 0 8px 20px rgba(2, 8, 18, .38);--shadow-pop: 0 16px 36px rgba(2, 8, 18, .54);--overlay: rgba(6, 12, 20, .68);--tooltip-bg: #0f1928;--tooltip-ink: #e8f0ff;--input-bg: #182638;--input-placeholder: #8090a8}.app-shell.role-ingenieur{--primary: #0f8578;--primary-contrast: #ffffff;--primary-soft: #e5fbf7;--primary-soft-border: #b5e6df;--primary-soft-ink: #0d5d57;--info: #1c7cc7;--sidebar-radial: rgba(15, 133, 120, .16)}:root[data-theme=dark] .app-shell.role-ingenieur{--primary: #63dbc9;--primary-contrast: #0a1d24;--primary-soft: #19373b;--primary-soft-border: #2a5d63;--primary-soft-ink: #b8f3ea;--info: #9ed7ff;--header-bg-start: #10232d;--header-bg-end: #0d1c24;--sidebar-bg-start: #0e2328;--sidebar-bg-end: #0b1b21;--sidebar-radial: rgba(99, 219, 201, .18)}*{box-sizing:border-box}html,body,#root{min-height:100%;height:100%}body{margin:0;font-family:Poppins,Segoe UI,Tahoma,Geneva,Verdana,sans-serif;background:linear-gradient(180deg,var(--bg-gradient-start) 0%,var(--bg-gradient-end) 100%);color:var(--ink);transition:background-color .2s ease,color .2s ease;min-width:0}a{color:inherit;text-decoration:none}.filter-field{display:grid;gap:5px;min-width:0;align-self:stretch}.filter-field-label{color:var(--muted-strong);font-size:11px;font-weight:800;line-height:1.2;text-transform:uppercase;letter-spacing:.04em;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.filter-field :is(input,select,textarea,button){width:100%;min-width:0;max-width:100%}.filter-field select{padding-right:36px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.filter-field-action{align-content:end}.filter-field-action .filter-field-label{visibility:hidden}.ui-icon{width:20px;height:20px;display:block;flex-shrink:0}.ui-icon.icon-18{width:18px;height:18px}.ui-icon.icon-16{width:16px;height:16px}.ui-icon *{vector-effect:non-scaling-stroke;stroke-linecap:round;stroke-linejoin:round}.app-shell{min-height:100vh;min-height:100dvh;width:100%;min-width:0;--layout-gap: 16px;--sidebar-width: 280px;--sidebar-collapsed-width: 96px;--sidebar-transition-duration: .22s;--sidebar-transition-easing: cubic-bezier(.22, 1, .36, 1);--app-main-shell-max-width: 1560px;--app-main-shell-inline-padding: clamp(12px, 1.6vw, 24px);--app-main-section-gap: 12px;background:linear-gradient(180deg,var(--bg-gradient-start) 0%,var(--bg-gradient-end) 100%)}.app-body{display:grid;grid-template-columns:var(--sidebar-width) minmax(0,1fr);gap:12px;padding:var(--layout-gap);align-items:stretch;min-width:0;min-height:100vh;min-height:100dvh;width:100%;transition:grid-template-columns var(--sidebar-transition-duration) var(--sidebar-transition-easing)}.app-body.app-body-collapsed{grid-template-columns:var(--sidebar-collapsed-width) minmax(0,1fr)}.app-body>*{min-width:0}.content{min-width:0;width:100%}.app-main{min-width:0;width:100%;position:relative;display:flex;flex-direction:column;gap:var(--app-main-section-gap);min-height:100%;overflow-x:hidden;overflow-y:visible}.app-navbar-shell{position:sticky;top:0;z-index:40;width:min(100%,var(--app-main-shell-max-width));margin-inline:auto;padding-inline:var(--app-main-shell-inline-padding);min-width:0;container-type:inline-size;container-name:navbar-shell}.app-page-shell{width:min(100%,var(--app-main-shell-max-width));margin-inline:auto;padding:0 var(--app-main-shell-inline-padding) var(--app-main-shell-inline-padding);min-width:0;min-height:0;flex:1 1 auto}.app-page-shell>*{min-width:0}.app-page-shell :is(.table-wrap,[class*=table-wrap],[class*=table-wrapper]){max-width:100%;overflow-x:auto;overflow-y:visible;-webkit-overflow-scrolling:touch}.app-main>*,.content>*{min-width:0;max-width:100%}:is(.dashboard-page,.projects-page,.users-page,.equipment-page,.compliance-page,.docs-page,.install-page,.tasks-page,.profile-page,.engineer-dashboard-page,.engineer-assigned-equipments-page,.engineer-compliance-page,.engineer-placeholder-page,.engineer-installation-pilotage-page){width:100%;min-width:0}:is(.dashboard-page,.projects-page,.users-page,.equipment-page,.compliance-page,.docs-page,.install-page,.tasks-page,.profile-page,.engineer-dashboard-page,.engineer-assigned-equipments-page,.engineer-compliance-page,.engineer-placeholder-page,.engineer-installation-pilotage-page)>*{min-width:0}.panel-main{border:1px solid var(--border);background:var(--panel);border-radius:16px;padding:0;min-height:0;width:100%}:root .app-shell .app-main>.content.panel-main{flex:1 1 auto;display:flex;flex-direction:column;overflow:visible}.panel-main>*{min-width:0}.navbar{border:1px solid var(--border);border-radius:16px;box-shadow:var(--shadow-soft);background:radial-gradient(circle at top center,rgba(15,107,255,.09),transparent 34%),linear-gradient(180deg,var(--header-bg-start) 0%,var(--header-bg-end) 100%);min-height:64px;padding:14px 18px;display:flex;align-items:center;justify-content:space-between;gap:18px;flex-wrap:nowrap;width:100%;min-width:0;position:relative;top:auto;z-index:auto;-webkit-backdrop-filter:blur(16px);backdrop-filter:blur(16px)}.navbar-left{display:flex;align-items:center;gap:16px;min-width:0;flex:1 1 auto}.navbar-context{display:flex;align-items:center;min-width:0;flex:1 1 280px;overflow-x:hidden;overflow-y:visible}.navbar-breadcrumbs{display:flex;align-items:center;flex-wrap:wrap;gap:4px;min-width:0}.navbar-breadcrumb-item{display:inline-flex;align-items:center;gap:4px;min-width:0}.navbar-breadcrumb-link,.navbar-breadcrumb-current{color:var(--muted);font-size:11px;line-height:1.2;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.navbar-breadcrumb-link:hover{color:var(--primary-soft-ink)}.navbar-breadcrumb-separator{color:var(--divider);font-size:11px}.navbar-title-row{display:flex;align-items:center;gap:14px;min-width:0;flex-wrap:nowrap;overflow-x:hidden;overflow-y:visible;padding-block:2px}.navbar-logo-link{flex-shrink:0;display:inline-flex;align-items:center}.app-logo{--app-logo-shadow: 0 14px 28px rgba(33, 146, 255, .16);--app-logo-filter: none;--app-logo-scale: 1.34;position:relative;display:inline-flex;align-items:center;justify-content:center;width:100%;height:100%;border-radius:inherit;overflow:hidden;background:transparent;box-shadow:var(--app-logo-shadow);flex-shrink:0;isolation:isolate}.app-logo-image{width:100%;height:100%;display:block;background:transparent;border-radius:inherit;object-fit:cover;object-position:center;transform:translateZ(0) scale(var(--app-logo-scale));transform-origin:center;backface-visibility:hidden;filter:var(--app-logo-filter);-webkit-user-select:none;user-select:none;pointer-events:none}.app-logo-fallback{display:inline-flex;align-items:center;justify-content:center;width:100%;height:100%;border-radius:inherit;background:linear-gradient(145deg,#24d59a,#2698f0);color:#fff;font-size:.78rem;font-weight:800;letter-spacing:.06em}.app-logo-tone-default{--app-logo-shadow: 0 14px 28px rgba(33, 146, 255, .16);--app-logo-filter: saturate(1.04) contrast(1.01)}.app-logo-tone-ingenieur{--app-logo-shadow: 0 14px 28px rgba(15, 133, 120, .16);--app-logo-filter: hue-rotate(-22deg) saturate(1.12) brightness(1.03)}.app-logo-tone-responsable{--app-logo-shadow: 0 14px 28px rgba(15, 107, 255, .18);--app-logo-filter: hue-rotate(8deg) saturate(1.08) brightness(1.01)}.app-logo-tone-client{--app-logo-shadow: 0 14px 28px rgba(199, 75, 92, .18);--app-logo-filter: hue-rotate(118deg) saturate(1.18) brightness(1.04)}.navbar-logo-shell{display:inline-flex;align-items:center;gap:12px;min-width:0}.navbar-logo-mark{width:42px;height:42px;border-radius:14px;display:inline-flex;flex-shrink:0}.navbar-logo-mark-image{width:100%;height:100%}.navbar-logo-wordmark{display:grid;gap:2px;min-width:0}.navbar-logo-wordmark strong{font-size:15px;font-weight:700;line-height:1.1;letter-spacing:-.01em;color:var(--ink-strong);white-space:nowrap}.navbar-left-divider{width:1px;height:42px;background:var(--divider);flex-shrink:0}.navbar-page-label{color:var(--muted);font-size:11px;line-height:1.15;letter-spacing:.02em;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.navbar-page-title{margin:0;font-size:26px;font-weight:700;line-height:1.26;letter-spacing:-.03em;white-space:nowrap;overflow-x:hidden;overflow-y:visible;text-overflow:ellipsis;max-width:100%;min-width:0;flex:1 1 auto;display:block;padding-block:2px}.navbar p{margin:0;color:var(--muted-strong);font-size:12px;line-height:1.35}.navbar-role-badge{display:inline-flex;align-items:center;gap:8px;border-radius:999px;border:1px solid var(--primary-soft-border);background:var(--primary-soft);color:var(--primary-soft-ink);font-size:14px;font-weight:600;line-height:1.2;padding:10px 16px;white-space:nowrap;box-shadow:0 10px 24px #0f1c330f;max-width:100%;flex-shrink:0}.navbar-right{display:flex;align-items:center;gap:12px;margin-left:auto;flex-shrink:0;min-width:0;flex-wrap:nowrap;justify-content:flex-end}.navbar-icon-button{width:52px;height:52px;border-radius:999px;border:1px solid var(--border-strong);background:#ffffffdb;color:var(--primary-soft-ink);display:inline-flex;align-items:center;justify-content:center;cursor:pointer;box-shadow:0 10px 24px #0f1c330f;transition:background-color .16s ease,border-color .16s ease,color .16s ease,transform .16s ease}.navbar-icon-button:hover{background:var(--surface-muted);transform:translateY(-1px)}.navbar-notification-button{position:relative}.navbar-notification-dot{position:absolute;top:12px;right:12px;width:9px;height:9px;border-radius:999px;background:var(--danger);box-shadow:0 0 0 3px #ffffffe6}.navbar-theme-toggle.active{border-color:var(--primary-soft-border);color:var(--primary);background:var(--primary-soft)}.navbar-profile{position:relative;min-width:0;max-width:100%}.navbar-profile-trigger{min-height:52px;border-radius:999px;border:1px solid transparent;background:transparent;color:var(--ink);display:inline-flex;align-items:center;gap:12px;padding:4px 0 4px 4px;cursor:pointer;transition:background-color .16s ease,border-color .16s ease;max-width:100%;min-width:0}.navbar-profile.open .navbar-profile-trigger{background:#ffffff8f;border-color:var(--primary-soft-border)}.navbar-avatar{width:44px;height:44px;border-radius:999px;background:var(--primary-soft);color:var(--primary);font-size:14px;font-weight:700;display:inline-flex;align-items:center;justify-content:center;overflow:hidden;box-shadow:0 10px 24px #0f1c3314}.navbar-profile-meta{text-align:left;display:flex;align-items:center;min-width:0;overflow:hidden}.navbar-profile-meta strong{display:block;max-width:220px;font-size:15px;font-weight:600;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.navbar-profile-chevron{flex-shrink:0}.navbar-profile-menu{position:absolute;top:calc(100% + 8px);right:0;min-width:196px;border:1px solid var(--border);border-radius:12px;box-shadow:var(--shadow-pop);background:var(--panel);padding:6px;display:grid;gap:3px;z-index:40}.navbar-profile-menu-link,.navbar-profile-menu-button{border:none;border-radius:8px;background:transparent;color:var(--ink);font:inherit;text-align:left;padding:8px 9px;font-size:13px;cursor:pointer}.navbar-profile-menu-link:hover,.navbar-profile-menu-button:hover{background:var(--surface-muted);color:var(--primary-soft-ink)}.navbar-profile-menu-button{color:var(--danger)}.navbar-menu-button{width:52px;height:52px;border-radius:999px;border:1px solid var(--border-strong);background:#ffffffdb;color:var(--primary-soft-ink);display:inline-flex;align-items:center;justify-content:center;cursor:pointer;box-shadow:0 10px 24px #0f1c330f;transition:background-color .16s ease,border-color .16s ease,color .16s ease,transform .16s ease}.navbar-menu-button:hover{background:var(--surface-muted);transform:translateY(-1px)}@container navbar-shell (max-width: 1240px){.navbar-role-badge{display:none}}@container navbar-shell (max-width: 1020px){.navbar{padding:14px 18px}.navbar-context,.navbar-left-divider{display:none}.navbar-logo-mark{width:38px;height:38px}.navbar-logo-wordmark strong{font-size:14px}}@container navbar-shell (max-width: 820px){.navbar-profile-meta{display:none}.navbar-profile-trigger{gap:8px;padding-right:0}.navbar-profile-meta strong{max-width:140px;font-size:14px}.navbar-icon-button,.navbar-menu-button{width:44px;height:44px}.navbar-avatar{width:38px;height:38px}}@container navbar-shell (max-width: 620px){.navbar{padding:10px 12px;gap:10px}.navbar-left{gap:10px}.navbar-right{gap:8px}.navbar-logo-wordmark{display:none}.navbar-logo-mark{width:34px;height:34px}.navbar-profile-trigger{min-height:40px;gap:6px}.navbar-icon-button,.navbar-menu-button{width:40px;height:40px}.navbar-avatar{width:34px;height:34px}.navbar-notification-dot{top:9px;right:9px;width:8px;height:8px;box-shadow:0 0 0 2px #ffffffe6}}@container navbar-shell (max-width: 460px){.navbar{padding:8px 10px}.navbar-left{gap:8px}.navbar-right{gap:6px}.navbar-logo-mark{width:32px;height:32px}.navbar-icon-button,.navbar-menu-button{width:36px;height:36px}.navbar-avatar{width:32px;height:32px}.navbar-profile-trigger{min-height:36px;padding-left:2px}.navbar-profile-menu{min-width:180px}.navbar-notification-dot{top:8px;right:8px;width:7px;height:7px}}.sidebar{position:sticky;top:var(--layout-gap);align-self:start;border:1px solid var(--border);border-right-color:var(--border-strong);border-radius:18px;background:radial-gradient(circle at right top,var(--sidebar-radial),transparent 32%),linear-gradient(180deg,var(--sidebar-bg-start) 0%,var(--sidebar-bg-end) 100%);box-shadow:0 20px 38px #0f1c3314;display:flex;flex-direction:column;width:100%;min-width:0;max-width:100%;height:calc(100vh - (var(--layout-gap) * 2));height:calc(100dvh - (var(--layout-gap) * 2));min-height:calc(100vh - (var(--layout-gap) * 2));min-height:calc(100dvh - (var(--layout-gap) * 2));max-height:calc(100vh - (var(--layout-gap) * 2));max-height:calc(100dvh - (var(--layout-gap) * 2));overflow:hidden;isolation:isolate;transition:border-color var(--sidebar-transition-duration) var(--sidebar-transition-easing),box-shadow var(--sidebar-transition-duration) var(--sidebar-transition-easing),transform var(--sidebar-transition-duration) var(--sidebar-transition-easing)}.sidebar-top{padding:16px 14px 12px;transition:padding var(--sidebar-transition-duration) var(--sidebar-transition-easing)}.sidebar-brand{display:flex;align-items:center;justify-content:space-between;gap:12px;min-width:0;transition:gap var(--sidebar-transition-duration) var(--sidebar-transition-easing)}.sidebar-brand-link{flex:1 1 auto;display:flex;align-items:center;gap:12px;width:100%;min-width:0;overflow:visible;padding:2px 0;border:none;background:transparent;color:inherit;font:inherit;text-align:left;text-decoration:none;appearance:none;-webkit-appearance:none;cursor:pointer;position:relative;isolation:isolate;transition:margin var(--sidebar-transition-duration) var(--sidebar-transition-easing)}.sidebar-brand-logo{width:44px;height:44px;border-radius:14px;display:inline-flex;align-items:center;justify-content:center;flex-shrink:0;position:relative;overflow:visible;transition:transform .18s ease}.sidebar-brand-logo-image{width:100%;height:100%;border-radius:inherit;transition:opacity .18s ease,transform .18s ease}.sidebar-brand-logo-art{width:100%;height:100%;display:block;background:transparent}.sidebar-brand-reopen-card{position:absolute;inset:0;display:inline-flex;align-items:center;justify-content:center;border-radius:inherit;border:1px solid rgba(215,222,234,.96);background:#fffffffa;color:var(--primary-soft-ink);box-shadow:0 12px 24px #0f1c331f;opacity:0;transform:translate(-2px) scale(.94);transition:opacity .18s ease,transform .18s ease;pointer-events:none}.sidebar-brand-text{display:flex;flex-direction:column;flex:1 1 auto;gap:6px;min-width:0;max-width:100%;overflow:hidden;background:transparent;opacity:1;transform:translate(0);transition:max-width var(--sidebar-transition-duration) var(--sidebar-transition-easing),opacity calc(var(--sidebar-transition-duration) * .7) ease,transform var(--sidebar-transition-duration) var(--sidebar-transition-easing)}.sidebar-brand-text strong{display:block;font-size:15px;line-height:1.22;letter-spacing:-.01em;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;padding-bottom:.08em}.sidebar-brand-meta{display:flex;align-items:center;gap:8px;min-width:0;flex-wrap:wrap;overflow:hidden;background:transparent;transition:gap var(--sidebar-transition-duration) var(--sidebar-transition-easing),opacity calc(var(--sidebar-transition-duration) * .7) ease}.sidebar-brand-text small{display:block;color:var(--muted-strong);font-size:11px;line-height:1.3;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;background:transparent;padding-bottom:.08em}.sidebar-brand-link:hover .sidebar-brand-logo,.sidebar-brand-link:focus-visible .sidebar-brand-logo{transform:translateY(-1px)}.sidebar-context-badge{display:inline-flex;align-items:center;justify-content:center;border-radius:999px;border:1px solid var(--primary-soft-border);background:var(--primary-soft);color:var(--primary-soft-ink);font-size:9px;font-weight:700;letter-spacing:.08em;padding:4px 7px;text-transform:uppercase;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:100%;line-height:1}.sidebar-icon-button{width:40px;height:40px;border-radius:12px;border:1px solid var(--border);background:var(--surface-subtle);color:var(--muted);display:inline-flex;align-items:center;justify-content:center;cursor:pointer;flex-shrink:0;box-shadow:0 8px 18px #0f1c330f;transition:background-color .16s ease,border-color .16s ease,color .16s ease,transform .16s ease}.sidebar-icon-button .ui-icon{width:20px;height:20px;flex-shrink:0}.sidebar-icon-button:hover{background:var(--surface-muted);color:var(--primary-soft-ink);transform:translateY(-1px)}.sidebar-nav{flex:1 1 auto;min-height:0;display:flex;flex-direction:column;gap:16px;padding:4px 12px 12px;overflow-y:auto;overflow-x:hidden;overscroll-behavior:contain;scrollbar-gutter:stable;min-width:0;transition:padding var(--sidebar-transition-duration) var(--sidebar-transition-easing),gap var(--sidebar-transition-duration) var(--sidebar-transition-easing)}.sidebar-nav::-webkit-scrollbar{width:8px}.sidebar-nav::-webkit-scrollbar-track{background:transparent}.sidebar-nav::-webkit-scrollbar-thumb{background:var(--surface-strong);border-radius:999px}.sidebar-group{display:grid;gap:6px;min-width:0;transition:gap var(--sidebar-transition-duration) var(--sidebar-transition-easing)}.sidebar-group+.sidebar-group{padding-top:14px;border-top:1px solid var(--divider)}.sidebar-group-title{margin:0 10px 4px;max-height:20px;color:var(--muted);font-size:11px;text-transform:uppercase;letter-spacing:.09em;font-weight:700;overflow:hidden;opacity:1;transform:translateY(0);transition:max-height var(--sidebar-transition-duration) var(--sidebar-transition-easing),margin var(--sidebar-transition-duration) var(--sidebar-transition-easing),opacity calc(var(--sidebar-transition-duration) * .6) ease,transform var(--sidebar-transition-duration) var(--sidebar-transition-easing)}.nav-link{position:relative;width:100%;min-width:0;max-width:100%;border-radius:14px;border:1px solid transparent;padding:10px 12px;color:var(--muted-strong);transition:background-color .2s ease,border-color .2s ease,color .2s ease,box-shadow .2s ease,padding var(--sidebar-transition-duration) var(--sidebar-transition-easing);display:flex;align-items:center;min-height:52px;overflow:hidden}.nav-link-main{display:flex;align-items:center;gap:12px;width:100%;min-width:0}.nav-link-icon{width:40px;height:40px;border-radius:12px;display:inline-flex;align-items:center;justify-content:center;line-height:0;flex-shrink:0;border:1px solid var(--divider);background:var(--panel);transition:border-color .2s ease,background-color .2s ease,color .2s ease,box-shadow .2s ease}.nav-link-icon .ui-icon,.nav-link-icon svg{width:20px;height:20px;flex-shrink:0}.nav-link-label{display:block;font-size:13px;line-height:1.2;font-weight:600;white-space:normal;overflow-wrap:anywhere}.nav-link-content{display:flex;align-items:center;flex:1 1 auto;min-width:0;overflow:hidden;max-width:100%;opacity:1;transform:translate(0);transition:max-width var(--sidebar-transition-duration) var(--sidebar-transition-easing),opacity calc(var(--sidebar-transition-duration) * .6) ease,transform var(--sidebar-transition-duration) var(--sidebar-transition-easing)}.nav-link:hover{color:var(--primary-soft-ink);border-color:var(--border-strong);background:var(--surface-muted)}.nav-link:hover .nav-link-icon{border-color:var(--border-strong);background:var(--panel)}.nav-link.active{color:var(--primary-soft-ink);border-color:var(--primary-soft-border);background:var(--primary-soft);font-weight:600;box-shadow:inset 3px 0 0 var(--primary),0 10px 24px #0f1c330f}.nav-link.active .nav-link-icon{border-color:var(--primary-soft-border);background:var(--panel);color:var(--primary)}.nav-link:focus-visible,.sidebar-brand-link:focus-visible,.sidebar-icon-button:focus-visible,.navbar-menu-button:focus-visible,.navbar-icon-button:focus-visible,.navbar-profile-trigger:focus-visible,.navbar-profile-menu-link:focus-visible,.navbar-profile-menu-button:focus-visible{outline:2px solid var(--ring);outline-offset:1px}.sidebar-collapsed .sidebar-top{padding:14px 10px 10px}.sidebar-collapsed .sidebar-brand{justify-content:center;gap:0}.sidebar-collapsed .sidebar-brand-link{flex:0 0 auto;width:44px;margin-inline:auto;overflow:visible}.sidebar-collapsed .sidebar-brand-text{max-width:0;opacity:0;transform:translate(-10px);pointer-events:none}.sidebar-collapsed .sidebar-brand-logo{width:44px;height:44px}.sidebar-collapsed .sidebar-brand-toggle:hover .sidebar-brand-logo,.sidebar-collapsed .sidebar-brand-toggle:focus-visible .sidebar-brand-logo{transform:translate(1px)}.sidebar-collapsed .sidebar-brand-toggle:hover .sidebar-brand-logo-image,.sidebar-collapsed .sidebar-brand-toggle:focus-visible .sidebar-brand-logo-image{opacity:0;transform:scale(.92)}.sidebar-collapsed .sidebar-brand-toggle:hover .sidebar-brand-reopen-card,.sidebar-collapsed .sidebar-brand-toggle:focus-visible .sidebar-brand-reopen-card{opacity:1;transform:translate(0) scale(1)}:root[data-theme=dark] .sidebar-brand-reopen-card{background:#fffffff5;border-color:#ffffffdb;color:#142134}.sidebar-collapsed .sidebar-nav{padding:6px 10px 10px;gap:8px}.sidebar-collapsed .sidebar-group{gap:6px}.sidebar-collapsed .sidebar-group+.sidebar-group{padding-top:10px}.sidebar-collapsed .sidebar-group-title{max-height:0;margin:0;opacity:0;transform:translateY(-4px);pointer-events:none}.sidebar-collapsed .nav-link{padding:10px 8px;justify-content:center;height:52px;min-height:52px;flex:0 0 52px}.sidebar-collapsed .nav-link-main{flex:0 0 40px;width:40px;gap:0;margin-inline:auto}.sidebar-collapsed .nav-link-icon{width:40px;height:40px}.sidebar-collapsed .nav-link-content{flex:0 0 0;width:0;max-width:0;height:0;max-height:0;opacity:0;transform:translate(-8px);pointer-events:none}.sidebar-collapsed .nav-link-label{white-space:nowrap}.sidebar-collapsed .nav-link.active{box-shadow:inset 0 0 0 1px var(--primary-soft-border),0 10px 24px #0f1c330f}.sidebar-footer{border-top:1px solid var(--divider);padding:12px;display:grid;gap:10px;transition:padding var(--sidebar-transition-duration) var(--sidebar-transition-easing),gap var(--sidebar-transition-duration) var(--sidebar-transition-easing);min-width:0}.sidebar-profile{display:flex;align-items:center;gap:10px;border:1px solid var(--border);border-radius:14px;background:var(--surface-subtle);padding:10px;min-width:0;overflow:hidden;transition:padding var(--sidebar-transition-duration) var(--sidebar-transition-easing),border-color var(--sidebar-transition-duration) var(--sidebar-transition-easing),background-color var(--sidebar-transition-duration) var(--sidebar-transition-easing)}.sidebar-profile-main{display:flex;align-items:center;gap:10px;width:100%;min-width:0;transition:width var(--sidebar-transition-duration) var(--sidebar-transition-easing),margin var(--sidebar-transition-duration) var(--sidebar-transition-easing)}.sidebar-profile.collapsed{padding:10px}.sidebar-profile.collapsed .sidebar-profile-main{width:36px;gap:0;margin-inline:auto}.sidebar-avatar{width:36px;height:36px;border-radius:12px;background:var(--primary-soft);color:var(--primary);font-size:12px;font-weight:700;flex-shrink:0;display:inline-flex;align-items:center;justify-content:center;overflow:hidden;transition:transform var(--sidebar-transition-duration) var(--sidebar-transition-easing)}.user-avatar-image{width:100%;height:100%;object-fit:cover;display:block}.user-avatar-initials{display:inline-flex;align-items:center;justify-content:center;width:100%;height:100%}.sidebar-profile-meta{display:grid;gap:2px;flex:1 1 auto;min-width:0;overflow:hidden;max-width:100%;opacity:1;transform:translate(0);transition:max-width var(--sidebar-transition-duration) var(--sidebar-transition-easing),opacity calc(var(--sidebar-transition-duration) * .6) ease,transform var(--sidebar-transition-duration) var(--sidebar-transition-easing)}.sidebar-profile-meta strong{font-size:12px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.sidebar-profile-meta small{color:var(--muted);font-size:11px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.sidebar-footer-note{margin:0;max-height:20px;color:var(--muted);font-size:11px;text-align:center;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;opacity:1;transform:translateY(0);transition:max-height var(--sidebar-transition-duration) var(--sidebar-transition-easing),opacity calc(var(--sidebar-transition-duration) * .6) ease,transform var(--sidebar-transition-duration) var(--sidebar-transition-easing)}.sidebar-profile.collapsed .sidebar-profile-meta{max-width:0;opacity:0;transform:translate(-8px);pointer-events:none}.sidebar-collapsed .sidebar-footer-note{max-height:0;opacity:0;transform:translateY(4px);pointer-events:none}.sidebar-floating-tooltip{position:fixed;transform:translateY(-50%);z-index:80;pointer-events:none;max-width:240px;border-radius:10px;background:var(--tooltip-bg);color:var(--tooltip-ink);padding:8px 10px;font-size:12px;font-weight:600;line-height:1.2;white-space:nowrap;box-shadow:var(--shadow-pop)}.sidebar-overlay{display:none}@media(prefers-reduced-motion:reduce){.app-body,.sidebar,.sidebar-top,.sidebar-brand,.sidebar-brand-link,.sidebar-brand-logo,.sidebar-brand-logo-image,.sidebar-brand-reopen-card,.sidebar-brand-text,.sidebar-brand-meta,.sidebar-nav,.sidebar-group,.sidebar-group-title,.nav-link,.nav-link-main,.nav-link-icon,.nav-link-content,.sidebar-footer,.sidebar-profile,.sidebar-profile-main,.sidebar-avatar,.sidebar-profile-meta,.sidebar-footer-note{transition:none!important}}.page-grid{display:grid;gap:16px}.panel{border:1px solid var(--border);border-radius:12px;background:var(--panel);padding:16px}.loading,.error{text-align:center}.spinner{width:32px;height:32px;margin:0 auto 8px;border:3px solid var(--surface-strong);border-top-color:var(--primary);border-radius:50%;animation:spin .9s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.btn{border:1px solid transparent;border-radius:8px;padding:8px 12px;cursor:pointer;font-weight:600;font-size:13px}.btn:disabled{opacity:.6;cursor:not-allowed}.btn-primary{background:var(--primary);color:var(--primary-contrast)}.btn-secondary{border-color:var(--border);background:var(--surface-subtle);color:var(--ink)}.btn-link{border:none;background:none;color:var(--primary);padding:0}.btn-link.danger{color:var(--danger)}.auth-page{min-height:100vh;display:grid;place-items:center;padding:20px}.auth-card{width:100%;max-width:460px;display:grid;gap:10px}.auth-card h2{margin:0}label{font-size:14px;font-weight:600}input,select,textarea{border:1px solid var(--border);border-radius:8px;padding:8px 10px;font:inherit;background:var(--input-bg);color:var(--ink);transition:background-color .16s ease,border-color .16s ease,color .16s ease}select{min-width:0;max-width:100%;padding-right:36px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}input::placeholder,textarea::placeholder{color:var(--input-placeholder)}.field-error{margin:0;color:var(--danger);font-size:12px}.stats-grid{display:grid;grid-template-columns:repeat(2,minmax(180px,1fr));gap:10px}.stats-grid article{border:1px solid var(--border);border-radius:10px;padding:10px;background:var(--surface-subtle)}.stats-grid span{display:block;color:var(--muted);font-size:13px}.stats-grid strong{font-size:22px}.simple-list{margin:0;padding:0;list-style:none}.simple-list li{display:flex;justify-content:space-between;align-items:center;gap:10px;padding:10px 0;border-bottom:1px solid var(--divider)}.simple-list.compact li{display:block;padding:8px 0}.section-header{display:flex;justify-content:space-between;gap:8px;align-items:center;margin-bottom:10px}.page-header{align-items:flex-start}.page-subtitle{margin:2px 0 0;color:var(--muted);font-size:13px}.meta-line{margin-top:-4px;color:var(--muted);font-size:12px}.route-chip{display:inline-flex;align-items:center;border:1px solid var(--primary-soft-border);border-radius:999px;background:var(--primary-soft);color:var(--primary-soft-ink);font-size:12px;padding:6px 10px}.filters{display:grid;grid-template-columns:1.2fr 1fr 1fr;gap:8px;margin-bottom:12px}.table-wrap{overflow:auto}table{width:100%;border-collapse:collapse}th,td{border-bottom:1px solid var(--divider);padding:9px 8px;text-align:left;vertical-align:top}th{color:var(--muted);font-weight:600;font-size:13px}.pagination{margin-top:12px;display:flex;align-items:center;justify-content:flex-end;gap:8px}.tabs{display:flex;gap:8px}.tab{border:1px solid var(--border);background:var(--surface-subtle);border-radius:8px;padding:8px 10px;cursor:pointer}.tab.active{background:var(--primary-soft);border-color:var(--primary-soft-border)}.card-block{border:1px solid var(--border);border-radius:10px;padding:10px;margin-bottom:12px;background:var(--surface-subtle)}.step-list,.substep-list{list-style:none;margin:0;padding:0;display:grid;gap:8px}.substep-list{padding-left:18px;margin-top:8px}.step-row{display:flex;justify-content:space-between;gap:8px;align-items:center}.compliance-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(260px,1fr));gap:10px}.compliance-card{border:1px solid var(--border);border-radius:8px;padding:10px;display:grid;gap:6px;background:var(--surface-subtle)}.inline-row{display:flex;align-items:center;gap:8px}.inline-row.wrap{flex-wrap:wrap}.upload-form{display:grid;grid-template-columns:1.5fr 1fr 1fr auto;gap:8px;margin-bottom:12px}.top-gap{margin-top:12px}.profile-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:10px}.profile-grid article{border:1px solid var(--border);border-radius:10px;padding:12px;background:var(--surface-subtle)}.profile-grid span{color:var(--muted);font-size:12px}.profile-grid strong{display:block;margin-top:4px}@media(max-width:1200px){.navbar{padding:14px 18px}.navbar-role-badge{display:none}}@media(max-width:960px){.app-shell{--layout-gap: 12px;--app-main-shell-inline-padding: 12px}.app-body,.app-body.app-body-collapsed{grid-template-columns:1fr}.sidebar{position:fixed;inset:0 auto 0 0;width:min(286px,calc(100vw - 52px));height:100vh;height:100dvh;min-height:100vh;min-height:100dvh;max-height:100vh;max-height:100dvh;border-radius:0 20px 20px 0;z-index:60;transform:translate(-104%);transition:transform var(--sidebar-transition-duration) var(--sidebar-transition-easing)}.sidebar.sidebar-drawer-open{transform:translate(0)}.sidebar-overlay{position:fixed;inset:0;border:none;background:var(--overlay);padding:0;z-index:55;opacity:0;pointer-events:none;transition:opacity .2s ease;display:block;cursor:pointer}.sidebar-overlay.visible{opacity:1;pointer-events:auto}.filters,.upload-form{grid-template-columns:1fr}.section-header{flex-direction:column;align-items:flex-start}.stats-grid{grid-template-columns:1fr}.navbar{padding:12px 14px;align-items:center}.navbar-left{gap:10px;align-items:center}.navbar-logo-shell{gap:10px}.navbar-logo-mark{width:36px;height:36px}.navbar-logo-wordmark strong{font-size:14px}.navbar-left-divider,.navbar-context{display:none}.navbar-profile-meta strong{max-width:140px;font-size:14px}.navbar-icon-button,.navbar-menu-button{width:44px;height:44px}.navbar-avatar{width:38px;height:38px}}@media(max-width:620px){.navbar{gap:10px}.navbar-logo-shell{gap:8px}.navbar-logo-wordmark{display:none}.navbar-logo-mark{width:34px;height:34px}.navbar-profile-meta{display:none}.navbar-profile-trigger{padding-right:0}.navbar-icon-button,.navbar-menu-button{width:40px;height:40px}.navbar-avatar{width:34px;height:34px}}:root[data-theme=dark] .page-header h2,:root[data-theme=dark] .dashboard-panel h3,:root[data-theme=dark] .docs-section-head h4,:root[data-theme=dark] .install-step-card-head h3{color:var(--ink-strong)}:root[data-theme=dark] .sidebar-overlay,:root[data-theme=dark] .project-modal-backdrop,:root[data-theme=dark] .users-modal-backdrop,:root[data-theme=dark] .compliance-modal-backdrop,:root[data-theme=dark] .docs-modal-backdrop,:root[data-theme=dark] .equipment-modal-backdrop,:root[data-theme=dark] .install-modal-backdrop{background:var(--overlay)}:root[data-theme=dark] .dashboard-hero,:root[data-theme=dark] .projects-hero,:root[data-theme=dark] .projects-detail-hero,:root[data-theme=dark] .users-hero,:root[data-theme=dark] .compliance-hero,:root[data-theme=dark] .docs-hero,:root[data-theme=dark] .equipment-hero,:root[data-theme=dark] .install-hero{border-color:var(--border);background:radial-gradient(circle at top right,rgba(107,168,255,.2),transparent 44%),radial-gradient(circle at 10% 108%,rgba(65,188,155,.18),transparent 52%),linear-gradient(145deg,#1a283c,#142134)}:root[data-theme=dark] .dashboard-panel,:root[data-theme=dark] .dashboard-kpi-card,:root[data-theme=dark] .dashboard-breakdown-card,:root[data-theme=dark] .projects-panel,:root[data-theme=dark] .projects-stat-card,:root[data-theme=dark] .users-panel,:root[data-theme=dark] .users-stat-card,:root[data-theme=dark] .compliance-panel,:root[data-theme=dark] .compliance-stat-card,:root[data-theme=dark] .docs-panel,:root[data-theme=dark] .docs-stat-card,:root[data-theme=dark] .docs-equipment-group,:root[data-theme=dark] .docs-section,:root[data-theme=dark] .equipment-panel,:root[data-theme=dark] .equipment-stat-card,:root[data-theme=dark] .install-panel,:root[data-theme=dark] .install-stat-card,:root[data-theme=dark] .install-step-card,:root[data-theme=dark] .project-form-section,:root[data-theme=dark] .project-user-card,:root[data-theme=dark] .project-task-summary article,:root[data-theme=dark] .equipment-form-section,:root[data-theme=dark] .project-definition-list div,:root[data-theme=dark] .project-participants article,:root[data-theme=dark] .project-engineer-chip,:root[data-theme=dark] .project-modal,:root[data-theme=dark] .users-modal,:root[data-theme=dark] .compliance-modal,:root[data-theme=dark] .docs-modal,:root[data-theme=dark] .equipment-modal,:root[data-theme=dark] .install-modal{border-color:var(--border);background:var(--panel)}:root[data-theme=dark] .dashboard-period-switch,:root[data-theme=dark] .dashboard-quick-filters,:root[data-theme=dark] .compliance-group-header,:root[data-theme=dark] .docs-count-chip,:root[data-theme=dark] .install-chip,:root[data-theme=dark] .project-status,:root[data-theme=dark] .dashboard-badge,:root[data-theme=dark] .users-chip,:root[data-theme=dark] .compliance-target,:root[data-theme=dark] .equipment-count-badge,:root[data-theme=dark] .install-count-badge,:root[data-theme=dark] .docs-action-link,:root[data-theme=dark] .dashboard-chip,:root[data-theme=dark] .dashboard-chip-empty,:root[data-theme=dark] .projects-active-filter,:root[data-theme=dark] .users-active-filter,:root[data-theme=dark] .compliance-active-filter,:root[data-theme=dark] .docs-active-filter,:root[data-theme=dark] .equipment-active-filter,:root[data-theme=dark] .install-active-filter,:root[data-theme=dark] .project-engineer-chip.active,:root[data-theme=dark] .project-user-card.active,:root[data-theme=dark] .project-user-card.manager.active{border-color:var(--border-strong);background:var(--surface-muted);color:var(--ink)}:root[data-theme=dark] .dashboard-period-switch button,:root[data-theme=dark] .dashboard-quick-filters button{background:transparent;color:var(--ink)}:root[data-theme=dark] .dashboard-period-switch button:hover,:root[data-theme=dark] .dashboard-quick-filters button:hover{background:#ffffff0a}:root[data-theme=dark] .dashboard-period-switch button.active,:root[data-theme=dark] .dashboard-quick-filters button.active{background:var(--primary);color:#0b1b30}:root[data-theme=dark] .dashboard-projects-table th,:root[data-theme=dark] .projects-table thead th,:root[data-theme=dark] .opportunities-table thead th,:root[data-theme=dark] .users-table thead th,:root[data-theme=dark] .compliance-table thead th,:root[data-theme=dark] .docs-table thead th,:root[data-theme=dark] .equipment-table thead th,:root[data-theme=dark] .install-table thead th{background:var(--responsable-table-head-bg);color:var(--responsable-table-head-ink)}:root[data-theme=dark] .dashboard-projects-table th,:root[data-theme=dark] .dashboard-projects-table td,:root[data-theme=dark] .projects-table th,:root[data-theme=dark] .projects-table td,:root[data-theme=dark] .opportunities-table th,:root[data-theme=dark] .opportunities-table td,:root[data-theme=dark] .users-table th,:root[data-theme=dark] .users-table td,:root[data-theme=dark] .compliance-table th,:root[data-theme=dark] .compliance-table td,:root[data-theme=dark] .docs-table th,:root[data-theme=dark] .docs-table td,:root[data-theme=dark] .equipment-table th,:root[data-theme=dark] .equipment-table td,:root[data-theme=dark] .install-table th,:root[data-theme=dark] .install-table td,:root[data-theme=dark] .project-participants li,:root[data-theme=dark] .simple-list li{border-color:var(--divider)}:root[data-theme=dark] .dashboard-projects-table tbody tr:nth-child(2n),:root[data-theme=dark] .projects-table tbody tr:nth-child(2n),:root[data-theme=dark] .opportunities-table tbody tr:nth-child(2n),:root[data-theme=dark] .users-table tbody tr:nth-child(2n),:root[data-theme=dark] .compliance-table tbody tr:nth-child(2n),:root[data-theme=dark] .docs-table tbody tr:nth-child(2n),:root[data-theme=dark] .equipment-table tbody tr:nth-child(2n),:root[data-theme=dark] .install-table tbody tr:nth-child(2n){background:#ffffff05}:root[data-theme=dark] .projects-table tbody tr:hover,:root[data-theme=dark] .opportunities-table tbody tr:hover,:root[data-theme=dark] .users-table tbody tr:hover,:root[data-theme=dark] .compliance-table tbody tr:hover,:root[data-theme=dark] .equipment-table tbody tr:hover,:root[data-theme=dark] .install-table tbody tr:hover{background:#6ba8ff14}:root[data-theme=dark] .dashboard-progress-track,:root[data-theme=dark] .project-progress-track,:root[data-theme=dark] .dashboard-breakdown-bar,:root[data-theme=dark] .docs-upload-progress-track{background:#29405f}:root[data-theme=dark] .dashboard-open-link,:root[data-theme=dark] .projects-close-button,:root[data-theme=dark] .projects-icon-link,:root[data-theme=dark] .projects-icon-button,:root[data-theme=dark] .users-icon-button,:root[data-theme=dark] .compliance-manage-link,:root[data-theme=dark] .compliance-icon-button,:root[data-theme=dark] .docs-action-delete,:root[data-theme=dark] .docs-upload-trigger,:root[data-theme=dark] .equipment-icon-link,:root[data-theme=dark] .equipment-icon-button,:root[data-theme=dark] .install-manage-link,:root[data-theme=dark] .install-icon-button,:root[data-theme=dark] .install-inline-edit,:root[data-theme=dark] .install-inline-delete{border-color:var(--border-strong);background:var(--surface-subtle);color:var(--ink)}:root[data-theme=dark] .dashboard-open-link:hover,:root[data-theme=dark] .projects-close-button.active,:root[data-theme=dark] .projects-icon-link:hover,:root[data-theme=dark] .projects-icon-button:hover:not(:disabled),:root[data-theme=dark] .users-icon-button:hover:not(:disabled),:root[data-theme=dark] .compliance-manage-link:hover,:root[data-theme=dark] .compliance-icon-button:hover:not(:disabled),:root[data-theme=dark] .docs-action-delete:hover,:root[data-theme=dark] .equipment-icon-link:hover,:root[data-theme=dark] .equipment-icon-button:hover:not(:disabled),:root[data-theme=dark] .install-manage-link:hover,:root[data-theme=dark] .install-icon-button:hover,:root[data-theme=dark] .install-inline-edit:hover,:root[data-theme=dark] .install-inline-delete:hover{background:var(--surface-muted)}:root[data-theme=dark] .projects-icon-button.danger,:root[data-theme=dark] .users-icon-button,:root[data-theme=dark] .compliance-icon-button,:root[data-theme=dark] .equipment-icon-button.danger,:root[data-theme=dark] .install-icon-button.danger,:root[data-theme=dark] .install-inline-delete,:root[data-theme=dark] .docs-action-delete{border-color:#6e3a48;background:#34212b;color:#ffb8c4}:root[data-theme=dark] .project-map-overlay,:root[data-theme=dark] .docs-dropzone,:root[data-theme=dark] .equipment-image-preview-wrap,:root[data-theme=dark] .compliance-rule-targets{background:var(--surface-subtle);border-color:var(--border-strong);color:var(--muted)}:root[data-theme=dark] .project-modal p,:root[data-theme=dark] .users-modal p,:root[data-theme=dark] .compliance-modal p,:root[data-theme=dark] .docs-modal p,:root[data-theme=dark] .equipment-modal p,:root[data-theme=dark] .install-modal p,:root[data-theme=dark] .project-engineer-chip small,:root[data-theme=dark] .project-user-main small,:root[data-theme=dark] .project-user-card em,:root[data-theme=dark] .project-form-hint,:root[data-theme=dark] .project-participants small,:root[data-theme=dark] .dashboard-muted,:root[data-theme=dark] .projects-no-filter,:root[data-theme=dark] .users-no-filter,:root[data-theme=dark] .compliance-no-filter,:root[data-theme=dark] .docs-no-filter,:root[data-theme=dark] .equipment-no-filter,:root[data-theme=dark] .install-no-filter,:root[data-theme=dark] .dashboard-empty-state p,:root[data-theme=dark] .projects-empty-state p,:root[data-theme=dark] .users-empty-state p,:root[data-theme=dark] .compliance-empty-state p,:root[data-theme=dark] .docs-empty-state p,:root[data-theme=dark] .equipment-empty-state p,:root[data-theme=dark] .install-empty-state p{color:var(--muted)}:root[data-theme=dark] .projects-breadcrumb,:root[data-theme=dark] .users-breadcrumb,:root[data-theme=dark] .compliance-breadcrumb,:root[data-theme=dark] .docs-breadcrumb,:root[data-theme=dark] .equipment-breadcrumb,:root[data-theme=dark] .install-breadcrumb,:root[data-theme=dark] .project-progress-large span,:root[data-theme=dark] .dashboard-kpi-content span,:root[data-theme=dark] .dashboard-kpi-content small,:root[data-theme=dark] .dashboard-project-title span,:root[data-theme=dark] .users-filter-summary p,:root[data-theme=dark] .users-user-cell p,:root[data-theme=dark] .docs-section-empty,:root[data-theme=dark] .docs-section-head span,:root[data-theme=dark] .install-step-card-head p,:root[data-theme=dark] .install-substep-content span,:root[data-theme=dark] .install-no-substeps,:root[data-theme=dark] .equipment-file-meta,:root[data-theme=dark] .compliance-group-header span{color:var(--muted)}:root[data-theme=dark] .projects-hero-subtitle,:root[data-theme=dark] .users-hero-subtitle,:root[data-theme=dark] .compliance-hero-subtitle,:root[data-theme=dark] .docs-hero-subtitle,:root[data-theme=dark] .equipment-hero-subtitle,:root[data-theme=dark] .install-hero-subtitle,:root[data-theme=dark] .projects-detail-hero p{color:var(--muted-strong)}:root[data-theme=dark] .project-modal pre,:root[data-theme=dark] .equipment-modal pre{background:var(--surface-subtle);border-color:var(--border);color:var(--ink)}:root[data-theme=dark] .equipment-model-thumb{border-color:var(--border-strong);background:var(--surface-subtle)}:root[data-theme=dark] .dashboard-toast,:root[data-theme=dark] .project-toast,:root[data-theme=dark] .users-toast,:root[data-theme=dark] .compliance-toast,:root[data-theme=dark] .docs-toast,:root[data-theme=dark] .equipment-toast,:root[data-theme=dark] .install-toast{box-shadow:var(--shadow-pop)}:root[data-theme=dark] .dashboard-toast-success,:root[data-theme=dark] .project-toast-success,:root[data-theme=dark] .users-toast-success,:root[data-theme=dark] .compliance-toast-success,:root[data-theme=dark] .docs-toast-success,:root[data-theme=dark] .equipment-toast-success,:root[data-theme=dark] .install-toast-success{color:#9fefce;background:#19382c;border-color:#2c664f}:root[data-theme=dark] .dashboard-toast-error,:root[data-theme=dark] .project-toast-error,:root[data-theme=dark] .users-toast-error,:root[data-theme=dark] .compliance-toast-error,:root[data-theme=dark] .docs-toast-error,:root[data-theme=dark] .equipment-toast-error,:root[data-theme=dark] .install-toast-error{color:pink;background:#3a2129;border-color:#774050}:root[data-theme=dark] .dashboard-skeleton-card,:root[data-theme=dark] .project-skeleton,:root[data-theme=dark] .users-skeleton,:root[data-theme=dark] .compliance-skeleton,:root[data-theme=dark] .docs-skeleton,:root[data-theme=dark] .docs-group-skeleton,:root[data-theme=dark] .equipment-skeleton,:root[data-theme=dark] .install-skeleton{background:linear-gradient(90deg,#1a293d 25%,#21334a 37%,#1a293d 63%);background-size:400% 100%}:root[data-theme=dark] input:disabled,:root[data-theme=dark] select:disabled,:root[data-theme=dark] textarea:disabled,:root[data-theme=dark] button:disabled{opacity:.5}:root[data-theme=dark] .equipment-link-title{color:#a9cdff}.app-shell.role-ingenieur{--bg: #eef7f6;--bg-gradient-start: #eefaf8;--bg-gradient-end: #f5f8fb;--panel: rgba(255, 255, 255, .88);--surface-subtle: #f7fcfb;--surface-muted: #e9f6f4;--surface-strong: #d8eee9;--border: #d6e7e5;--border-strong: #bfd9d6;--divider: #e2eeed;background:radial-gradient(circle at 8% 0%,rgba(15,133,120,.12),transparent 32%),radial-gradient(circle at 100% 12%,rgba(28,124,199,.1),transparent 30%),linear-gradient(180deg,var(--bg-gradient-start) 0%,var(--bg-gradient-end) 100%)}.app-shell.role-ingenieur .app-body{gap:14px}.app-shell.role-ingenieur .panel-main{border-color:#0f857821;border-radius:22px;background:#ffffff94;box-shadow:inset 0 1px #ffffffd6;-webkit-backdrop-filter:blur(18px);backdrop-filter:blur(18px);padding:clamp(12px,1.6vw,18px);overflow:visible}.app-shell.role-ingenieur .navbar{min-height:62px;padding:8px 14px;border-color:#0f857829;border-radius:20px;background:radial-gradient(circle at 14% 0%,rgba(15,133,120,.1),transparent 36%),linear-gradient(180deg,#ffffffe0,#f7fdfcd1)}.app-shell.role-ingenieur .navbar-page-title{font-size:clamp(18px,2.1vw,23px);letter-spacing:0}.app-shell.role-ingenieur .navbar-role-badge{padding:8px 12px;font-size:12px}.app-shell.role-ingenieur .navbar-icon-button,.app-shell.role-ingenieur .navbar-menu-button{width:44px;height:44px;border-color:#0f85782b;background:#ffffffc2}.app-shell.role-ingenieur .navbar-profile-trigger{min-height:44px}.app-shell.role-ingenieur .navbar-avatar{width:38px;height:38px}.app-shell.role-ingenieur .sidebar{border-color:#0f857829;box-shadow:0 22px 48px #0f1c3317}.app-shell.role-ingenieur .sidebar-brand-reopen-card{color:#0f8578}.app-shell.role-ingenieur .nav-link{border-radius:13px}.app-shell.role-ingenieur .nav-link-icon{border-radius:12px}.app-shell.role-ingenieur .nav-link.active{box-shadow:inset 3px 0 0 var(--primary),0 12px 24px #0f85781a}html,body{overflow-x:hidden}.app-shell,.app-body,.app-main,.content,.app-page-shell{max-width:100%}:is(.dashboard-page,.dashboard-grid-two,.dashboard-panel,.dashboard-panel-header,.dashboard-project-controls,.dashboard-breakdown-panel,.dashboard-breakdown-card,.projects-page,.projects-panel,.projects-filters,.projects-detail-grid,.project-participants-layout,.project-team-toolbar,.users-page,.users-panel,.users-filter-row,.users-filter-inputs,.docs-page,.docs-panel,.docs-filters,.install-page,.install-panel,.install-filters,.engineer-dashboard-page,.engineer-dashboard-main-grid,.engineer-dashboard-side-grid,.engineer-dashboard-panel,.engineer-project-card-grid,.engineer-assigned-equipments-page,.engineer-assigned-filters,.engineer-assigned-grid,.responsable-ui-hero,.engineer-ui-hero,.client-ui-hero,.responsable-ui-filter-bar,.engineer-ui-filter-bar,.client-ui-filter-bar,.responsable-ui-data-card,.engineer-ui-data-card,.client-ui-data-card,.responsable-ui-table-wrapper,.engineer-ui-table-wrapper,.client-ui-table-wrapper){min-width:0;max-width:100%}:is(.dashboard-grid-two,.dashboard-panel-header,.dashboard-project-controls,.projects-filters,.projects-detail-grid,.project-participants-layout,.project-team-toolbar,.users-filter-row,.users-filter-inputs,.docs-filters,.install-filters,.engineer-dashboard-main-grid,.engineer-dashboard-side-grid,.engineer-project-card-grid,.engineer-assigned-filters,.responsable-ui-filter-bar,.engineer-ui-filter-bar,.client-ui-filter-bar)>*{min-width:0;max-width:100%}input,select,textarea,button{font-family:inherit}.btn{min-height:40px;border-radius:12px;transition:transform .16s ease,box-shadow .16s ease,border-color .16s ease,background-color .16s ease}.btn:hover{transform:translateY(-1px)}.btn:active{transform:translateY(0)}:root[data-theme=dark] .app-shell.role-ingenieur{--bg: #0d171d;--bg-gradient-start: #0f2127;--bg-gradient-end: #101722;--panel: rgba(22, 33, 50, .9);--surface-subtle: #162431;--surface-muted: #1e3440;--surface-strong: #28515a;--border: #29434c;--border-strong: #37626b;--divider: #243943;background:radial-gradient(circle at 8% 0%,rgba(99,219,201,.13),transparent 32%),radial-gradient(circle at 100% 12%,rgba(77,160,222,.12),transparent 30%),linear-gradient(180deg,var(--bg-gradient-start) 0%,var(--bg-gradient-end) 100%)}:root[data-theme=dark] .app-shell.role-ingenieur .panel-main{border-color:#63dbc91f;background:#09121975;box-shadow:inset 0 1px #ffffff0a}:root[data-theme=dark] .app-shell.role-ingenieur .navbar{border-color:#63dbc924;background:radial-gradient(circle at 14% 0%,rgba(99,219,201,.12),transparent 36%),linear-gradient(180deg,#10232de6,#0d1c24d6)}:root[data-theme=dark] .app-shell.role-ingenieur .navbar-icon-button,:root[data-theme=dark] .app-shell.role-ingenieur .navbar-menu-button,:root[data-theme=dark] .app-shell.role-ingenieur .navbar-profile.open .navbar-profile-trigger{background:#162132c7}.app-shell.role-ingenieur .loading{min-height:220px;border-radius:20px;border-color:#0f857829;background:radial-gradient(circle at top right,rgba(15,133,120,.1),transparent 34%),#ffffffd1;box-shadow:0 14px 30px #0f1c330e;display:grid;place-items:center;align-content:center;gap:10px}.app-shell.role-ingenieur .loading p{margin:0;color:var(--muted-strong);font-weight:700}:root[data-theme=dark] .app-shell.role-ingenieur .loading{border-color:#63dbc924;background:radial-gradient(circle at top right,rgba(99,219,201,.11),transparent 34%),#162132d1}.app-shell.role-client{--bg: #fbf1f2;--bg-gradient-start: #fff4f3;--bg-gradient-end: #faf6f4;--panel: rgba(255, 255, 255, .92);--surface-subtle: #fff9f8;--surface-muted: #fff0f1;--surface-strong: #ffe2e6;--border: #ecd7db;--border-strong: #e2c7cd;--divider: #f0dde1;--primary: #c74b5c;--primary-contrast: #ffffff;--primary-soft: #fff0f2;--primary-soft-border: #efc4cc;--primary-soft-ink: #8f2636;--info: #c9604f;--sidebar-radial: rgba(199, 75, 92, .15);--client-table-surface: rgba(255, 255, 255, .72);--client-table-head-bg: rgba(255, 248, 247, .95);--client-table-head-ink: var(--muted-strong);--client-table-row-even-bg: rgba(255, 251, 251, .92);--client-table-row-hover-bg: rgba(199, 75, 92, .06);background:radial-gradient(circle at 8% 0%,rgba(199,75,92,.12),transparent 32%),radial-gradient(circle at 100% 14%,rgba(208,139,105,.1),transparent 30%),linear-gradient(180deg,var(--bg-gradient-start) 0%,var(--bg-gradient-end) 100%)}.app-shell.role-client .app-body{gap:14px}.app-shell.role-client .panel-main{border-color:#c74b5c1f;border-radius:22px;background:#ffffff9e;box-shadow:inset 0 1px #ffffffe0;-webkit-backdrop-filter:blur(18px);backdrop-filter:blur(18px);padding:clamp(12px,1.6vw,18px);overflow:visible}.app-shell.role-client .navbar{min-height:62px;padding:8px 14px;border-color:#c74b5c24;border-radius:20px;background:radial-gradient(circle at 14% 0%,rgba(199,75,92,.11),transparent 36%),linear-gradient(180deg,#ffffffeb,#fff8f7db)}.app-shell.role-client .navbar-page-title{font-size:clamp(18px,2.1vw,23px);letter-spacing:0}.app-shell.role-client .navbar-role-badge{padding:8px 12px;font-size:12px}.app-shell.role-client .navbar-icon-button,.app-shell.role-client .navbar-menu-button{width:44px;height:44px;border-color:#c74b5c29;background:#fffc}.app-shell.role-client .navbar-profile-trigger{min-height:44px}.app-shell.role-client .navbar-avatar{width:38px;height:38px}.app-shell.role-client .sidebar{border-color:#c74b5c24;box-shadow:0 22px 48px #23101414}.app-shell.role-client .sidebar-brand-reopen-card{color:#c74b5c}.app-shell.role-client .nav-link{border-radius:13px}.app-shell.role-client .nav-link-icon{border-radius:12px}.app-shell.role-client .nav-link.active{box-shadow:inset 3px 0 0 var(--primary),0 12px 24px #c74b5c1f}.app-shell.role-client :is(.dashboard-hero,.profile-hero-card){border-color:#c74b5c29;border-radius:22px;background:radial-gradient(circle at 86% 0%,rgba(199,75,92,.14),transparent 32%),radial-gradient(circle at 0% 100%,rgba(208,139,105,.1),transparent 34%),linear-gradient(145deg,#fffffff7,#fff7f5f0);box-shadow:0 18px 45px #23101412;-webkit-backdrop-filter:blur(14px);backdrop-filter:blur(14px)}.app-shell.role-client :is(.dashboard-panel,.dashboard-kpi-card,.dashboard-breakdown-card,.profile-section-card,.profile-hero-meta div,.profile-hero-stats article,.profile-activity-grid article,.profile-strength-card,.profile-sessions-card,.profile-danger-card,.profile-inline-success,.profile-empty-state,.profile-toggle-card){border-color:var(--border);background:#ffffffdb;box-shadow:0 14px 30px #2310140e;-webkit-backdrop-filter:blur(14px);backdrop-filter:blur(14px)}.app-shell.role-client :is(.page-grid,.panel,.card-block,.compliance-card){min-width:0}.app-shell.role-client .page-grid{display:grid;gap:16px}.app-shell.role-client :is(.panel,.card-block,.compliance-card){border:1px solid var(--border);border-radius:18px;background:#ffffffdb;box-shadow:0 14px 30px #2310140e;-webkit-backdrop-filter:blur(14px);backdrop-filter:blur(14px)}.app-shell.role-client .panel{padding:16px}.app-shell.role-client .section-header.page-header,.app-shell.role-client .section-header{display:flex;justify-content:space-between;align-items:flex-start;gap:14px;min-width:0;flex-wrap:wrap}.app-shell.role-client .section-header h2{margin:0;color:var(--ink-strong);font-size:clamp(24px,3vw,34px);line-height:1.12;letter-spacing:0}.app-shell.role-client :is(.page-subtitle,.section-header p,.meta-line){color:var(--muted-strong)}.app-shell.role-client :is(.filters,.upload-form){display:grid;grid-template-columns:repeat(auto-fit,minmax(170px,1fr));gap:10px;border:1px solid var(--border);border-radius:18px;background:#ffffffbd;padding:12px}.app-shell.role-client :is(.filters input,.filters select,.upload-form input,.upload-form select,.upload-form textarea){min-height:42px;border:1px solid var(--border);border-radius:13px;background:var(--input-bg);color:var(--ink);padding:10px 12px}.app-shell.role-client :is(.filters input,.filters select,.upload-form input,.upload-form select,.upload-form textarea):focus{border-color:var(--primary-soft-border);box-shadow:0 0 0 3px #c74b5c1f;outline:none}.app-shell.role-client :is(.table-wrap,.tabs,.simple-list,.step-list,.substep-list){min-width:0}.app-shell.role-client .table-wrap{border:1px solid var(--border);border-radius:16px;background:var(--client-table-surface);overflow-x:auto;overflow-y:visible;-webkit-overflow-scrolling:touch}.app-shell.role-client .table-wrap table{min-width:760px;width:100%;border-collapse:separate;border-spacing:0}.app-shell.role-client .table-wrap th,.app-shell.role-client .table-wrap td{border-bottom:1px solid var(--divider);padding:12px 10px;text-align:left}.app-shell.role-client .table-wrap th{background:var(--client-table-head-bg);color:var(--client-table-head-ink);font-size:12px;font-weight:800;text-transform:uppercase;letter-spacing:.04em}.app-shell.role-client .tabs{margin-top:14px;display:flex;gap:6px;flex-wrap:wrap;border:1px solid var(--border);border-radius:16px;background:#ffffffb8;padding:5px}.app-shell.role-client .tab{min-height:36px;border:none;border-radius:12px;background:transparent;color:var(--muted-strong);font:inherit;font-size:12px;font-weight:800;padding:8px 12px;cursor:pointer}.app-shell.role-client .tab.active,.app-shell.role-client .tab:hover{background:var(--primary-soft);color:var(--primary-soft-ink)}.app-shell.role-client .card-block{padding:14px;display:grid;gap:12px}.app-shell.role-client .compliance-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(260px,1fr));gap:12px}.app-shell.role-client .compliance-card{padding:14px;display:grid;gap:8px}.app-shell.role-client .simple-list{margin:0;padding:0;list-style:none;display:grid;gap:8px}.app-shell.role-client .simple-list li{border:1px solid var(--border);border-radius:14px;background:#ffffffb3;padding:12px}.app-shell.role-client .btn-link{color:var(--primary-soft-ink);font-weight:700}.app-shell.role-client .route-chip,.app-shell.role-client .profile-role-badge{border-color:var(--primary-soft-border);background:var(--primary-soft);color:var(--primary-soft-ink)}.app-shell.role-client .profile-status-badge.pending{border-color:#c74b5c38;background:#fff0f2e6;color:#a91f32}.app-shell.role-client .dashboard-kpi-card{border-radius:18px}.app-shell.role-client :is(.dashboard-period-switch,.dashboard-quick-filters){border-color:var(--border-strong);background:#ffffffd1}.app-shell.role-client .dashboard-period-switch button.active,.app-shell.role-client .dashboard-quick-filters button.active{background:var(--primary);color:var(--primary-contrast)}.app-shell.role-client :is(.dashboard-kpi-icon-blue,.dashboard-kpi-icon-indigo,.dashboard-kpi-icon-rose){background:#fff0f2;color:#b12d40}.app-shell.role-client .dashboard-kpi-icon-amber{background:#fff4e8;color:#a56016}.app-shell.role-client .dashboard-kpi-icon-green{background:#eef8f0;color:#1a7b52}.app-shell.role-client .dashboard-progress-fill,.app-shell.role-client .dashboard-breakdown-bar div,.app-shell.role-client .dashboard-breakdown-bar.status div{background:linear-gradient(90deg,var(--primary) 0%,#d8917b 100%)}.app-shell.role-client .dashboard-open-link{border-color:var(--primary-soft-border);background:var(--primary-soft);color:var(--primary-soft-ink)}.app-shell.role-client :is(.dashboard-projects-table-wrap,.profile-sessions-table-wrap){border:1px solid var(--border);border-radius:16px;background:var(--client-table-surface);overflow-x:auto;overflow-y:visible;-webkit-overflow-scrolling:touch}.app-shell.role-client :is(.dashboard-projects-table,.profile-sessions-table) thead th{background:var(--client-table-head-bg);color:var(--client-table-head-ink);font-size:12px;font-weight:800;text-transform:uppercase;letter-spacing:.04em}.app-shell.role-client :is(.dashboard-projects-table,.profile-sessions-table) tbody tr:nth-child(2n){background:var(--client-table-row-even-bg)}.app-shell.role-client :is(.dashboard-projects-table,.profile-sessions-table) tbody tr:hover{background:var(--client-table-row-hover-bg)}.app-shell.role-client :is(.dashboard-empty-state,.profile-empty-state){border:1px dashed var(--border-strong);border-radius:18px;background:#fffafad1;padding:28px 18px}.app-shell.role-client .loading{min-height:220px;border-radius:20px;border-color:#c74b5c24;background:radial-gradient(circle at top right,rgba(199,75,92,.1),transparent 34%),#ffffffd1;box-shadow:0 14px 30px #2310140e;display:grid;place-items:center;align-content:center;gap:10px}.app-shell.role-client .loading p{margin:0;color:var(--muted-strong);font-weight:700}:root[data-theme=dark] .app-shell.role-client{--bg: #1b1215;--bg-gradient-start: #24161a;--bg-gradient-end: #171115;--panel: rgba(34, 24, 28, .92);--surface-subtle: #291a1f;--surface-muted: #362028;--surface-strong: #4c2d37;--border: #503740;--border-strong: #62434d;--divider: #433038;--primary: #ff8a99;--primary-contrast: #2d1218;--primary-soft: #432029;--primary-soft-border: #7d404d;--primary-soft-ink: #ffc4cd;--client-table-surface: rgba(34, 24, 28, .78);--client-table-head-bg: #311e24;--client-table-head-ink: var(--ink);--client-table-row-even-bg: rgba(49, 30, 36, .7);--client-table-row-hover-bg: rgba(74, 40, 50, .72);background:radial-gradient(circle at 8% 0%,rgba(255,138,153,.12),transparent 32%),radial-gradient(circle at 100% 14%,rgba(224,146,90,.12),transparent 30%),linear-gradient(180deg,var(--bg-gradient-start) 0%,var(--bg-gradient-end) 100%)}:root[data-theme=dark] .app-shell.role-client .panel-main{border-color:#ff8a991f;background:#140c0f7a;box-shadow:inset 0 1px #ffffff0a}:root[data-theme=dark] .app-shell.role-client .navbar{border-color:#ff8a9924;background:radial-gradient(circle at 14% 0%,rgba(255,138,153,.12),transparent 36%),linear-gradient(180deg,#2c181eeb,#1b1115db)}:root[data-theme=dark] .app-shell.role-client .navbar-icon-button,:root[data-theme=dark] .app-shell.role-client .navbar-menu-button,:root[data-theme=dark] .app-shell.role-client .navbar-profile.open .navbar-profile-trigger{background:#22181ccc}:root[data-theme=dark] .app-shell.role-client :is(.dashboard-hero,.profile-hero-card){border-color:#ff8a9929;background:radial-gradient(circle at 86% 0%,rgba(255,138,153,.13),transparent 34%),radial-gradient(circle at 0% 100%,rgba(224,146,90,.1),transparent 34%),linear-gradient(145deg,#2e181ef5,#1c1216eb)}:root[data-theme=dark] .app-shell.role-client :is(.dashboard-panel,.dashboard-kpi-card,.dashboard-breakdown-card,.profile-section-card,.profile-hero-meta div,.profile-hero-stats article,.profile-activity-grid article,.profile-strength-card,.profile-sessions-card,.profile-danger-card,.profile-inline-success,.profile-empty-state,.profile-toggle-card){background:#22181cd6;border-color:var(--border)}:root[data-theme=dark] .app-shell.role-client :is(.panel,.card-block,.compliance-card,.filters,.upload-form,.table-wrap,.tabs,.simple-list li,.dashboard-projects-table-wrap,.profile-sessions-table-wrap,.dashboard-empty-state){background:var(--client-table-surface);border-color:var(--border)}:root[data-theme=dark] .app-shell.role-client .table-wrap th,:root[data-theme=dark] .app-shell.role-client :is(.dashboard-projects-table,.profile-sessions-table) thead th{background:var(--client-table-head-bg);color:var(--client-table-head-ink)}:root[data-theme=dark] .app-shell.role-client .dashboard-open-link{background:var(--primary-soft);color:var(--primary-soft-ink);border-color:var(--primary-soft-border)}:root[data-theme=dark] .app-shell.role-client .loading{border-color:#ff8a9924;background:radial-gradient(circle at top right,rgba(255,138,153,.11),transparent 34%),#22181cd6}.app-shell.role-responsable{--bg: #eef4fb;--bg-gradient-start: #edf5ff;--bg-gradient-end: #f5f8fb;--panel: rgba(255, 255, 255, .9);--surface-subtle: #f7fbff;--surface-muted: #eaf2ff;--surface-strong: #dbeaff;--border: #d6e1ef;--border-strong: #bfd0e7;--divider: #e2eaf5;--sidebar-radial: rgba(15, 107, 255, .14);--responsable-table-surface: rgba(255, 255, 255, .68);--responsable-table-head-bg: rgba(247, 251, 255, .95);--responsable-table-head-ink: var(--muted-strong);--responsable-table-row-even-bg: rgba(251, 252, 255, .92);--responsable-table-row-hover-bg: rgba(15, 107, 255, .055);background:radial-gradient(circle at 8% 0%,rgba(15,107,255,.11),transparent 32%),radial-gradient(circle at 100% 12%,rgba(15,133,120,.1),transparent 30%),linear-gradient(180deg,var(--bg-gradient-start) 0%,var(--bg-gradient-end) 100%)}.app-shell.role-responsable .app-body{gap:14px}.app-shell.role-responsable .panel-main{border-color:#0f6bff1f;border-radius:22px;background:#fff9;box-shadow:inset 0 1px #ffffffdb;-webkit-backdrop-filter:blur(18px);backdrop-filter:blur(18px);padding:clamp(12px,1.6vw,18px);overflow:visible}.app-shell.role-responsable .navbar{min-height:62px;padding:8px 14px;border-color:#0f6bff24;border-radius:20px;background:radial-gradient(circle at 14% 0%,rgba(15,107,255,.1),transparent 36%),linear-gradient(180deg,#ffffffe6,#f7fbffd6)}.app-shell.role-responsable .navbar-page-title{font-size:clamp(18px,2.1vw,23px);letter-spacing:0}.app-shell.role-responsable .navbar-role-badge{padding:8px 12px;font-size:12px}.app-shell.role-responsable .navbar-icon-button,.app-shell.role-responsable .navbar-menu-button{width:44px;height:44px;border-color:#0f6bff29;background:#ffffffc7}.app-shell.role-responsable .navbar-profile-trigger{min-height:44px}.app-shell.role-responsable .navbar-avatar{width:38px;height:38px}.app-shell.role-responsable .sidebar{border-color:#0f6bff24;box-shadow:0 22px 48px #0f1c3317}.app-shell.role-responsable .sidebar-brand-reopen-card{color:#0f6bff}.app-shell.role-responsable .nav-link{border-radius:13px}.app-shell.role-responsable .nav-link-icon{border-radius:12px}.app-shell.role-responsable .nav-link.active{box-shadow:inset 3px 0 0 var(--primary),0 12px 24px #0f6bff1a}.app-shell.role-responsable :is(.responsable-ui-hero,.dashboard-hero,.projects-hero,.projects-detail-hero,.users-hero,.compliance-hero,.docs-hero,.equipment-hero,.install-hero,.profile-hero-card){border-color:#0f6bff29;border-radius:22px;background:radial-gradient(circle at 86% 0%,rgba(15,107,255,.13),transparent 32%),radial-gradient(circle at 0% 100%,rgba(15,133,120,.12),transparent 34%),linear-gradient(145deg,#fffffff5,#f7fbffeb);box-shadow:0 18px 45px #0f1c3312;-webkit-backdrop-filter:blur(14px);backdrop-filter:blur(14px)}.app-shell.role-responsable :is(.responsable-ui-panel,.responsable-ui-hero-metric,.responsable-ui-data-card,.responsable-ui-form-section,.responsable-ui-filter-bar,.dashboard-panel,.dashboard-kpi-card,.dashboard-breakdown-card,.projects-panel,.projects-stat-card,.project-form-section,.project-participant-block,.project-member-card,.project-equipment-card,.project-definition-list div,.project-participants article,.project-task-summary article,.users-panel,.users-stat-card,.user-create-panel,.user-create-card,.compliance-panel,.compliance-stat-card,.compliance-form-section,.compliance-rule-targets,.compliance-checklist-item,.docs-panel,.docs-stat-card,.docs-equipment-group,.docs-section,.docs-group-skeleton,.equipment-panel,.equipment-stat-card,.equipment-form-section,.equipment-image-preview-wrap,.install-panel,.install-stat-card,.install-step-card,.install-substep-row,.doc-tracking-panel,.budget-project-card,.profile-section-card,.profile-hero-meta div,.profile-hero-stats article,.profile-activity-grid article,.profile-strength-card,.profile-sessions-card,.profile-danger-card,.profile-inline-success,.profile-empty-state,.profile-toggle-card){border-color:var(--border);background:#ffffffd6;box-shadow:0 14px 30px #0f1c330e;-webkit-backdrop-filter:blur(14px);backdrop-filter:blur(14px)}.app-shell.role-responsable :is(.page-grid,.panel,.card-block,.compliance-card){min-width:0}.app-shell.role-responsable .page-grid{display:grid;gap:16px}.app-shell.role-responsable :is(.panel,.card-block,.compliance-card){border:1px solid var(--border);border-radius:18px;background:#ffffffd6;box-shadow:0 14px 30px #0f1c330e;-webkit-backdrop-filter:blur(14px);backdrop-filter:blur(14px)}.app-shell.role-responsable .panel{padding:16px}.app-shell.role-responsable .section-header.page-header,.app-shell.role-responsable .section-header{display:flex;justify-content:space-between;align-items:flex-start;gap:14px;min-width:0;flex-wrap:wrap}.app-shell.role-responsable .section-header h2{margin:0;color:var(--ink-strong);font-size:clamp(24px,3vw,34px);line-height:1.12;letter-spacing:0}.app-shell.role-responsable :is(.page-subtitle,.section-header p,.meta-line){color:var(--muted-strong)}.app-shell.role-responsable :is(.filters,.upload-form){display:grid;grid-template-columns:repeat(auto-fit,minmax(170px,1fr));gap:10px;border:1px solid var(--border);border-radius:18px;background:#ffffffb8;padding:12px}.app-shell.role-responsable :is(.filters input,.filters select,.upload-form input,.upload-form select,.upload-form textarea){min-height:42px;border:1px solid var(--border);border-radius:13px;background:var(--input-bg);color:var(--ink);padding:10px 12px}.app-shell.role-responsable :is(.filters input,.filters select,.upload-form input,.upload-form select,.upload-form textarea):focus{border-color:var(--primary-soft-border);box-shadow:0 0 0 3px #0f6bff1f;outline:none}.app-shell.role-responsable :is(.table-wrap,.tabs,.simple-list,.step-list,.substep-list){min-width:0}.app-shell.role-responsable .table-wrap{border:1px solid var(--border);border-radius:16px;background:var(--responsable-table-surface);overflow-x:auto;overflow-y:visible;-webkit-overflow-scrolling:touch}.app-shell.role-responsable .table-wrap table{min-width:760px;width:100%;border-collapse:separate;border-spacing:0}.app-shell.role-responsable .table-wrap th,.app-shell.role-responsable .table-wrap td{border-bottom:1px solid var(--divider);padding:12px 10px;text-align:left}.app-shell.role-responsable .table-wrap th{background:var(--responsable-table-head-bg);color:var(--responsable-table-head-ink);font-size:12px;font-weight:800;text-transform:uppercase;letter-spacing:.04em}.app-shell.role-responsable .tabs{margin-top:14px;display:flex;gap:6px;flex-wrap:wrap;border:1px solid var(--border);border-radius:16px;background:#ffffffb3;padding:5px}.app-shell.role-responsable .tab{min-height:36px;border:none;border-radius:12px;background:transparent;color:var(--muted-strong);font:inherit;font-size:12px;font-weight:800;padding:8px 12px;cursor:pointer}.app-shell.role-responsable .tab.active,.app-shell.role-responsable .tab:hover{background:var(--primary-soft);color:var(--primary-soft-ink)}.app-shell.role-responsable .card-block{padding:14px;display:grid;gap:12px}.app-shell.role-responsable .compliance-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(260px,1fr));gap:12px}.app-shell.role-responsable .compliance-card{padding:14px;display:grid;gap:8px}.app-shell.role-responsable .simple-list{margin:0;padding:0;list-style:none;display:grid;gap:8px}.app-shell.role-responsable .simple-list li{border:1px solid var(--border);border-radius:14px;background:#ffffffa8;padding:12px}.app-shell.role-responsable :is(.responsable-ui-panel,.projects-panel,.users-panel,.compliance-panel,.docs-panel,.equipment-panel,.install-panel,.doc-tracking-panel,.budget-project-card,.dashboard-panel,.profile-section-card){border:1px solid var(--border);border-radius:20px;background:radial-gradient(circle at 92% 0%,rgba(15,107,255,.05),transparent 34%),#ffffffd6;box-shadow:0 14px 30px #0f1c330e;-webkit-backdrop-filter:blur(14px);backdrop-filter:blur(14px);min-width:0}.app-shell.role-responsable :is(.projects-panel,.users-panel,.compliance-panel,.docs-panel,.equipment-panel,.install-panel,.doc-tracking-panel){padding:14px}.app-shell.role-responsable :is(.projects-filters,.users-filter-row,.compliance-filters,.docs-filters,.equipment-filters,.install-filters,.doc-tracking-filters,.task-filters,.responsable-ui-filter-bar,.dashboard-project-controls){gap:10px;align-items:end}.app-shell.role-responsable :is(.projects-filters,.compliance-filters,.docs-filters,.equipment-filters,.install-filters,.doc-tracking-filters,.task-filters,.responsable-ui-filter-bar)>*{min-width:0}.app-shell.role-responsable .filter-field[class*=filter-search]{grid-column:1 / -1}.app-shell.role-responsable :is(.projects-filter-summary,.users-filter-summary,.compliance-filter-summary,.docs-filter-summary,.equipment-filter-summary,.install-filter-summary,.task-filter-summary,.doc-tracking-summary){margin-top:12px;border-top:1px dashed var(--border-strong);padding-top:12px;color:var(--muted-strong)}.app-shell.role-responsable :is(.projects-filter-summary p,.users-filter-summary p,.compliance-filter-summary p,.docs-filter-summary p,.equipment-filter-summary p,.install-filter-summary p,.task-filter-summary p,.doc-tracking-summary p){color:var(--ink);font-weight:700}.app-shell.role-responsable :is(.projects-active-filter,.users-active-filter,.compliance-active-filter,.docs-active-filter,.equipment-active-filter,.install-active-filter,.task-active-filter,.doc-tracking-active-filter){border:1px solid var(--border-strong);background:var(--surface-subtle);color:var(--muted-strong);border-radius:999px;font-size:12px;font-weight:700;padding:5px 9px}.app-shell.role-responsable :is(.projects-no-filter,.users-no-filter,.compliance-no-filter,.docs-no-filter,.equipment-no-filter,.install-no-filter,.task-no-filter,.doc-tracking-no-filter){color:var(--muted-strong);font-size:13px}.app-shell.role-responsable :is(.projects-filters input,.projects-filters select,.users-filter-inputs input,.users-filter-inputs select,.compliance-filters input,.compliance-filters select,.docs-filters input,.docs-filters select,.equipment-filters input,.equipment-filters select,.install-filters input,.install-filters select,.doc-tracking-filters input,.doc-tracking-filters select,.task-filters input,.task-filters select,.budget-form-grid input,.budget-form-grid select,.budget-form-grid textarea,.budget-reason textarea,.budget-select,.budget-report-actions select,.user-create-form input,.user-create-form select,.project-form input,.project-form select,.project-form textarea,.project-location-field input,.equipment-form input,.equipment-form select,.equipment-form textarea,.compliance-field input,.compliance-field select,.compliance-field textarea,.docs-form-grid input,.docs-form-grid select,.profile-form input,.profile-form select,.profile-form textarea){border:1px solid var(--border);border-radius:13px;background:var(--input-bg);color:var(--ink);min-height:42px;outline:none;transition:border-color .16s ease,box-shadow .16s ease,background-color .16s ease}.app-shell.role-responsable :is(.projects-filters input,.projects-filters select,.users-filter-inputs input,.users-filter-inputs select,.compliance-filters input,.compliance-filters select,.docs-filters input,.docs-filters select,.equipment-filters input,.equipment-filters select,.install-filters input,.install-filters select,.doc-tracking-filters input,.doc-tracking-filters select,.budget-form-grid input,.budget-form-grid select,.budget-form-grid textarea,.budget-reason textarea,.budget-select,.budget-report-actions select,.user-create-form input,.user-create-form select,.project-form input,.project-form select,.project-form textarea,.project-location-field input,.equipment-form input,.equipment-form select,.equipment-form textarea,.compliance-field input,.compliance-field select,.compliance-field textarea,.docs-form-grid input,.docs-form-grid select,.profile-form input,.profile-form select,.profile-form textarea):focus{border-color:var(--primary-soft-border);box-shadow:0 0 0 3px #0f6bff1f}.app-shell.role-responsable :is(.projects-table-wrap,.opportunities-table-wrap,.users-table-wrap,.compliance-table-wrap,.docs-table-wrap,.equipment-table-wrap,.install-table-wrap,.doc-tracking-table-wrap,.responsable-ui-table-wrapper,.dashboard-projects-table-wrap,.profile-sessions-table-wrap){border:1px solid var(--border);border-radius:16px;background:#ffffffad;overflow-x:auto;overflow-y:visible;-webkit-overflow-scrolling:touch}.app-shell.role-responsable :is(.projects-table,.opportunities-table,.users-table,.compliance-table,.docs-table,.equipment-table,.install-table,.doc-tracking-table,.budget-table,.dashboard-projects-table,.profile-sessions-table) thead th{background:var(--responsable-table-head-bg);color:var(--responsable-table-head-ink);font-size:12px;font-weight:800;text-transform:uppercase;letter-spacing:.04em}.app-shell.role-responsable :is(.projects-table,.opportunities-table,.users-table,.compliance-table,.docs-table,.equipment-table,.install-table,.doc-tracking-table,.budget-table,.dashboard-projects-table,.profile-sessions-table) tbody tr:nth-child(2n){background:var(--responsable-table-row-even-bg)}.app-shell.role-responsable :is(.projects-table,.opportunities-table,.users-table,.compliance-table,.docs-table,.equipment-table,.install-table,.doc-tracking-table,.budget-table,.dashboard-projects-table,.profile-sessions-table) tbody tr{transition:background-color .16s ease}.app-shell.role-responsable :is(.projects-table,.opportunities-table,.users-table,.compliance-table,.docs-table,.equipment-table,.install-table,.doc-tracking-table,.budget-table,.dashboard-projects-table) tbody tr:hover{background:var(--responsable-table-row-hover-bg)}.app-shell.role-responsable :is(.projects-table,.opportunities-table,.users-table,.compliance-table,.docs-table,.equipment-table,.install-table,.doc-tracking-table,.budget-table,.dashboard-projects-table,.profile-sessions-table) :is(th,td):last-child{padding-right:16px}.app-shell.role-responsable :is(.projects-empty-state,.users-empty-state,.compliance-empty-state,.docs-empty-state,.equipment-empty-state,.install-empty-state,.dashboard-empty-state){border:1px dashed var(--border-strong);border-radius:18px;background:#f7fbffc2;padding:28px 18px}.app-shell.role-responsable :is(.project-toast,.users-toast,.compliance-toast,.docs-toast,.equipment-toast,.install-toast,.dashboard-toast,.profile-toast){border-radius:16px;box-shadow:var(--shadow-pop);-webkit-backdrop-filter:blur(14px);backdrop-filter:blur(14px)}.app-shell.role-responsable .loading{min-height:220px;border-radius:20px;border-color:#0f6bff24;background:radial-gradient(circle at top right,rgba(15,107,255,.1),transparent 34%),#ffffffd1;box-shadow:0 14px 30px #0f1c330e;display:grid;place-items:center;align-content:center;gap:10px}.app-shell.role-responsable .loading p{margin:0;color:var(--muted-strong);font-weight:700}:root[data-theme=dark] .app-shell.role-responsable{--bg: #0f1724;--bg-gradient-start: #121f31;--bg-gradient-end: #101722;--panel: rgba(22, 33, 50, .9);--surface-subtle: #172439;--surface-muted: #203149;--surface-strong: #2a4365;--border: #2d3e56;--border-strong: #354b68;--divider: #26354a;--responsable-table-surface: rgba(22, 33, 50, .72);--responsable-table-head-bg: #1b273a;--responsable-table-head-ink: var(--ink);--responsable-table-row-even-bg: rgba(27, 39, 58, .72);--responsable-table-row-hover-bg: rgba(34, 52, 79, .72);background:radial-gradient(circle at 8% 0%,rgba(105,172,255,.12),transparent 32%),radial-gradient(circle at 100% 12%,rgba(99,219,201,.1),transparent 30%),linear-gradient(180deg,var(--bg-gradient-start) 0%,var(--bg-gradient-end) 100%)}:root[data-theme=dark] .app-shell.role-responsable .panel-main{border-color:#69acff1f;background:#09121975;box-shadow:inset 0 1px #ffffff0a}:root[data-theme=dark] .app-shell.role-responsable .navbar{border-color:#69acff24;background:radial-gradient(circle at 14% 0%,rgba(105,172,255,.12),transparent 36%),linear-gradient(180deg,#142234e6,#0f1a2ad6)}:root[data-theme=dark] .app-shell.role-responsable .navbar-icon-button,:root[data-theme=dark] .app-shell.role-responsable .navbar-menu-button,:root[data-theme=dark] .app-shell.role-responsable .navbar-profile.open .navbar-profile-trigger{background:#162132c7}:root[data-theme=dark] .app-shell.role-responsable :is(.responsable-ui-hero,.dashboard-hero,.projects-hero,.projects-detail-hero,.users-hero,.compliance-hero,.docs-hero,.equipment-hero,.install-hero,.profile-hero-card){border-color:#69acff29;background:radial-gradient(circle at 86% 0%,rgba(105,172,255,.13),transparent 34%),radial-gradient(circle at 0% 100%,rgba(99,219,201,.09),transparent 34%),linear-gradient(145deg,#142234f5,#0f1a2aeb)}:root[data-theme=dark] .app-shell.role-responsable :is(.responsable-ui-panel,.responsable-ui-hero-metric,.responsable-ui-data-card,.responsable-ui-form-section,.responsable-ui-filter-bar,.dashboard-panel,.dashboard-kpi-card,.dashboard-breakdown-card,.projects-panel,.projects-stat-card,.project-form-section,.project-participant-block,.project-member-card,.project-equipment-card,.project-definition-list div,.project-participants article,.project-task-summary article,.users-panel,.users-stat-card,.user-create-panel,.user-create-card,.compliance-panel,.compliance-stat-card,.compliance-form-section,.compliance-rule-targets,.compliance-checklist-item,.docs-panel,.docs-stat-card,.docs-equipment-group,.docs-section,.docs-group-skeleton,.equipment-panel,.equipment-stat-card,.equipment-form-section,.equipment-image-preview-wrap,.install-panel,.install-stat-card,.install-step-card,.install-substep-row,.doc-tracking-panel,.budget-project-card,.profile-section-card,.profile-hero-meta div,.profile-hero-stats article,.profile-activity-grid article,.profile-strength-card,.profile-sessions-card,.profile-danger-card,.profile-inline-success,.profile-empty-state,.profile-toggle-card){background:#162132d1;border-color:var(--border)}:root[data-theme=dark] .app-shell.role-responsable :is(.panel,.card-block,.compliance-card,.filters,.upload-form,.table-wrap,.tabs,.simple-list li){background:#162132d1;border-color:var(--border)}:root[data-theme=dark] .app-shell.role-responsable .table-wrap th{background:var(--responsable-table-head-bg);color:var(--responsable-table-head-ink)}:root[data-theme=dark] .app-shell.role-responsable :is(.projects-table-wrap,.opportunities-table-wrap,.users-table-wrap,.compliance-table-wrap,.docs-table-wrap,.equipment-table-wrap,.install-table-wrap,.doc-tracking-table-wrap,.responsable-ui-table-wrapper,.dashboard-projects-table-wrap,.profile-sessions-table-wrap,.projects-empty-state,.users-empty-state,.compliance-empty-state,.docs-empty-state,.equipment-empty-state,.install-empty-state,.dashboard-empty-state){background:var(--responsable-table-surface);border-color:var(--border)}:root[data-theme=dark] .app-shell.role-responsable .loading{border-color:#69acff24;background:radial-gradient(circle at top right,rgba(105,172,255,.11),transparent 34%),#162132d1}@media(max-width:960px){.app-shell.role-ingenieur .app-body{gap:10px}.app-shell.role-ingenieur .panel-main{border-radius:18px;padding:12px}.app-shell.role-responsable .app-body{gap:10px}.app-shell.role-responsable .panel-main{border-radius:18px;padding:12px}.app-shell.role-client .app-body{gap:10px}.app-shell.role-client .panel-main{border-radius:18px;padding:12px}}:root .app-shell:is(.role-ingenieur,.role-responsable,.role-client) .panel-main{border:none;border-radius:0;background:transparent;box-shadow:none;-webkit-backdrop-filter:none;backdrop-filter:none;padding:0}:root[data-theme=dark] .app-shell:is(.role-ingenieur,.role-responsable,.role-client) .panel-main{background:transparent;box-shadow:none}:root[data-theme=dark] .app-shell :is(.dashboard-kpi-card,.projects-kpi-card,.users-kpi-card,.equipment-kpi-card,.docs-kpi-card,.compliance-kpi-card,.install-kpi-card,.opportunities-kpi-card,.tasks-kpi-card,.projects-stat-card,.users-stat-card,.equipment-stat-card,.docs-stat-card,.compliance-stat-card,.install-stat-card,.dashboard-alert,.project-follow-summary-tile,.budget-project-card,.client-ui-stat-card,.engineer-ui-stat-card,.responsable-ui-stat-card,.client-ui-hero-metric,.engineer-ui-hero-metric,.responsable-ui-hero-metric){background:radial-gradient(circle at 98% 100%,rgba(var(--kpi-accent-rgb, 105, 172, 255),.16),transparent 44%),linear-gradient(145deg,#162132eb,#0f1a2af5)!important;border-color:var(--border)!important;color:var(--ink)!important}:root[data-theme=dark] .app-shell :is(.projects-kpi-card,.projects-stat-card){--kpi-accent-rgb: var(--projects-kpi-rgb, 105, 172, 255)}:root[data-theme=dark] .app-shell :is(.users-kpi-card,.users-stat-card){--kpi-accent-rgb: var(--users-kpi-rgb, 105, 172, 255)}:root[data-theme=dark] .app-shell :is(.equipment-kpi-card,.equipment-stat-card){--kpi-accent-rgb: var(--equipment-kpi-rgb, 99, 219, 201)}:root[data-theme=dark] .app-shell :is(.docs-kpi-card,.docs-stat-card){--kpi-accent-rgb: var(--docs-kpi-rgb, 105, 172, 255)}:root[data-theme=dark] .app-shell :is(.compliance-kpi-card,.compliance-stat-card){--kpi-accent-rgb: var(--compliance-kpi-rgb, 105, 172, 255)}:root[data-theme=dark] .app-shell :is(.install-kpi-card,.install-stat-card){--kpi-accent-rgb: var(--install-kpi-rgb, 105, 172, 255)}:root[data-theme=dark] .app-shell :is(.opportunities-kpi-card,.tasks-kpi-card){--kpi-accent-rgb: var(--opportunities-kpi-rgb, var(--tasks-kpi-rgb, 105, 172, 255))}:root[data-theme=dark] .app-shell :is(.dashboard-kpi-content strong,.dashboard-alert strong,.projects-stat-card strong,.users-stat-card strong,.equipment-stat-card strong,.docs-stat-card strong,.compliance-stat-card strong,.install-stat-card strong,.project-follow-summary-tile strong,.budget-project-card strong,.client-ui-stat-card strong,.engineer-ui-stat-card strong,.responsable-ui-stat-card strong,.client-ui-hero-metric strong,.engineer-ui-hero-metric strong,.responsable-ui-hero-metric strong,.responsable-ui-hero-metric-copy strong){color:var(--ink-strong)!important;text-shadow:0 1px 12px rgba(105,172,255,.12)}:root[data-theme=dark] .app-shell :is(.dashboard-kpi-content span,.dashboard-kpi-content small,.projects-stat-card span,.users-stat-card span,.equipment-stat-card span,.docs-stat-card span,.compliance-stat-card span,.install-stat-card span,.client-ui-stat-card span:not(.client-ui-stat-icon),.engineer-ui-stat-card span:not(.engineer-ui-stat-icon),.responsable-ui-stat-card span:not(.responsable-ui-stat-icon),.client-ui-hero-metric span,.engineer-ui-hero-metric span,.responsable-ui-hero-metric span,.responsable-ui-hero-metric-copy span,.client-ui-stat-card small,.engineer-ui-stat-card small,.responsable-ui-stat-card small){color:var(--muted-strong)!important}:root[data-theme=dark] .app-shell :is(.projects-management-hero,.project-details-header,.users-management-hero,.equipment-management-hero,.docs-management-hero,.compliance-management-hero,.install-management-hero,.opportunities-management-hero,.opportunity-details-header,.tasks-hero) :is(.responsable-ui-hero-metric-icon,.responsable-ui-hero-metric-helper){background:#162132c7!important;border-color:rgba(var(--kpi-accent-rgb, 105, 172, 255),.24)!important;box-shadow:0 12px 26px #02081242!important}
