:root,[data-theme=light]{--bg-app: #F5F5F7;--bg-surface: #FFFFFF;--bg-surface-secondary: #F0F0F2;--bg-surface-tertiary: #E8E8ED;--bg-hover-theme: rgba(0,0,0,.04);--bg-active-theme: rgba(0,0,0,.08);--text-primary-theme: #1D1D1F;--text-secondary-theme: #6E6E73;--text-tertiary-theme: #AEAEB2;--text-inverse: #FFFFFF;--border-primary-theme: #D2D2D7;--border-secondary-theme: #E5E5EA;--border-focus: #007AFF;--sidebar-bg: #1E1E2E;--shadow-sm-theme: 0 1px 2px rgba(0,0,0,.05);--shadow-md-theme: 0 4px 12px rgba(0,0,0,.08);--shadow-lg-theme: 0 8px 24px rgba(0,0,0,.12);--accent: #007AFF;--accent-hover: #0056CC;--accent-bg: rgba(0,122,255,.08);--input-bg: #FFFFFF;--input-border: #D2D2D7;--card-bg: #FFFFFF;--modal-overlay: rgba(0,0,0,.4);--glass-theme: rgba(255,255,255,.72);--glass-dark-theme: rgba(248,248,250,.9);--separator-theme: rgba(60,60,67,.18);--separator-soft-theme: rgba(60,60,67,.08);color-scheme:light}[data-theme=dark]{--bg-app: #0D0D0F;--bg-surface: #1C1C1E;--bg-surface-secondary: #2C2C2E;--bg-surface-tertiary: #3A3A3C;--bg-hover-theme: rgba(255,255,255,.06);--bg-active-theme: rgba(255,255,255,.1);--text-primary-theme: #F5F5F7;--text-secondary-theme: #98989D;--text-tertiary-theme: #636366;--text-inverse: #1D1D1F;--border-primary-theme: #3A3A3C;--border-secondary-theme: #2C2C2E;--border-focus: #0A84FF;--sidebar-bg: #0D0D0F;--shadow-sm-theme: 0 1px 2px rgba(0,0,0,.3);--shadow-md-theme: 0 4px 12px rgba(0,0,0,.4);--shadow-lg-theme: 0 8px 24px rgba(0,0,0,.5);--accent: #0A84FF;--accent-hover: #409CFF;--accent-bg: rgba(10,132,255,.15);--input-bg: #2C2C2E;--input-border: #3A3A3C;--card-bg: #1C1C1E;--modal-overlay: rgba(0,0,0,.7);--glass-theme: rgba(28,28,30,.72);--glass-dark-theme: rgba(20,20,22,.9);--separator-theme: rgba(255,255,255,.15);--separator-soft-theme: rgba(255,255,255,.06);color-scheme:dark}[data-theme] *,[data-theme] *:before,[data-theme] *:after{transition:background-color .15s ease,color .15s ease,border-color .15s ease}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}:root{--blue: var(--accent, #0066CC);--blue-light: rgba(0,102,204,.1);--blue-mid: rgba(0,102,204,.18);--green: #28A745;--green-bg: rgba(40,167,69,.1);--orange: #FF9500;--orange-bg: rgba(255,149,0,.1);--red: #FF3B30;--red-bg: rgba(255,59,48,.1);--cyan: #32ADE6;--cyan-bg: rgba(50,173,230,.1);--purple: #AF52DE;--purple-bg: rgba(175,82,222,.1);--indigo: #5856D6;--indigo-bg: rgba(88,86,214,.1);--bg: var(--bg-app);--bg-secondary: var(--bg-surface-secondary);--surface: var(--glass-theme);--surface-solid: var(--bg-surface);--glass: var(--glass-theme);--glass-dark: var(--glass-dark-theme);--label: var(--text-primary-theme);--label-2: var(--text-secondary-theme);--label-3: var(--text-tertiary-theme);--label-4: var(--text-tertiary-theme);--separator: var(--separator-theme);--separator-soft: var(--separator-soft-theme);--r-sm: 8px;--r-md: 12px;--r-lg: 16px;--r-xl: 20px;--shadow-xs: var(--shadow-sm-theme);--shadow-sm: var(--shadow-sm-theme);--shadow-md: var(--shadow-md-theme);--shadow-lg: var(--shadow-lg-theme)}:root{--bg-card: var(--card-bg);--bg-subtle: var(--bg-surface-secondary);--bg-subtle-hover: var(--bg-hover-theme);--bg-subtle-active: var(--bg-active-theme);--bg-dark: var(--glass-dark-theme);--bg-hover: var(--bg-hover-theme);--bg-input: var(--input-bg);--bg-overlay: var(--modal-overlay);--text-primary: var(--text-primary-theme);--text-secondary: var(--text-secondary-theme);--text-tertiary: var(--text-tertiary-theme);--border-color: var(--separator-theme);--primary: var(--accent);--primary-light: #3384d6;--primary-bg: var(--accent-bg);--primary-bg-hover: var(--blue-mid);--info: var(--cyan);--info-bg: var(--cyan-bg);--warning: var(--orange);--warning-bg: var(--orange-bg);--error: var(--red);--error-bg: var(--red-bg);--shadow-color: rgba(0,0,0,.12);--spacing-xs: 4px;--spacing-sm: 8px;--spacing-md: 16px;--spacing-lg: 24px;--spacing-xl: 32px;--radius-xs: 4px;--radius-sm: 6px;--radius-md: 8px;--radius-lg: 12px;--text-xs: 11px;--text-sm: 12px;--text-md: 14px;--text-lg: 16px;--text-xl: 20px;--font-regular: 400;--font-medium: 500;--font-semibold: 600;--font-bold: 700;--bg-tertiary: var(--bg-surface-tertiary);--bg-success: rgba(52,199,89,.1);--bg-danger: rgba(255,59,48,.1);--success: var(--green);--danger: var(--red)}html,body{height:100%;overflow:hidden;font-family:-apple-system,SF Pro Text,Helvetica Neue,sans-serif;background:var(--bg);color:var(--label);-webkit-font-smoothing:antialiased}#root{height:100%}.app{display:flex;height:100vh}.main{flex:1;display:flex;flex-direction:column;overflow:hidden;min-width:0}.sidebar{width:240px;flex-shrink:0;background:var(--sidebar-bg);display:flex;flex-direction:column;padding:0;overflow-y:auto;transition:width .2s ease;position:relative;z-index:10}.sidebar.collapsed{width:56px}.sidebar::-webkit-scrollbar{width:0}.sidebar-top{height:56px;display:flex;align-items:center;padding:0 14px;gap:10px;border-bottom:1px solid rgba(255,255,255,.08);flex-shrink:0;justify-content:space-between}.sidebar-logo{font-size:16px;font-weight:700;color:#fff;letter-spacing:-.03em;white-space:nowrap;overflow:hidden}.sidebar-logo-icon{font-size:18px;font-weight:800;color:#fff;width:28px;text-align:center}.sidebar-toggle{width:26px;height:26px;border-radius:6px;display:flex;align-items:center;justify-content:center;background:none;border:none;cursor:pointer;color:#ffffff59;transition:all .12s;flex-shrink:0}.sidebar-toggle:hover{background:#ffffff1a;color:#ffffffb3}.sidebar-nav{flex:1;padding:8px 0;overflow-y:auto}.nav-section-label{padding:20px 18px 6px;font-size:10.5px;font-weight:600;color:#ffffff59;text-transform:uppercase;letter-spacing:.08em}.nav-item{display:flex;align-items:center;gap:12px;padding:9px 18px;margin:1px 0;cursor:pointer;font-size:13.5px;font-weight:400;color:#fff9;transition:all .12s;position:relative;white-space:nowrap;overflow:hidden}.sidebar.collapsed .nav-item{justify-content:center;padding:9px 0}.nav-item:hover{background:#ffffff0f;color:#ffffffd9}.nav-item.active{background:var(--blue);color:#fff;font-weight:500}.nav-icon{width:20px;height:20px;display:flex;align-items:center;justify-content:center;flex-shrink:0}.nav-item.active .nav-icon{color:#fff}.nav-item:not(.active) .nav-icon{color:#ffffff73}.nav-badge{margin-left:auto;font-size:11px;font-weight:600;background:#ffffff26;color:#ffffffb3;padding:1px 6px;border-radius:10px;min-width:18px;text-align:center}.nav-badge.accent{background:var(--orange);color:#fff}.nav-separator{margin:8px 18px;height:1px;background:#ffffff14}.nav-item.nav-sub{padding-left:50px;font-size:13px;color:#ffffff73}.nav-item.nav-sub:hover{color:#ffffffb3}.nav-item.nav-sub.active{color:#fff}.nav-chevron{margin-left:auto;color:#ffffff4d;display:flex;align-items:center}.sidebar-bottom{margin-top:auto;padding:12px 14px;border-top:1px solid rgba(255,255,255,.08)}.sidebar-sync{padding:8px 14px 12px;border-top:1px solid rgba(255,255,255,.08)}.sync-btn{display:flex;align-items:center;gap:8px;background:none;border:none;color:#ffffff80;font-size:11px;cursor:pointer;padding:6px 8px;border-radius:6px;width:100%;transition:all .12s}.sync-btn:hover{background:#ffffff0f;color:#ffffffb3}.sync-dot{width:8px;height:8px;border-radius:50%;flex-shrink:0}.sync-dot-ok{background:#34c759}.sync-dot-syncing{background:#007aff;animation:pulse 1.5s infinite}.sync-dot-offline{background:#8e8e93}.sync-dot-error{background:#ff3b30}@keyframes pulse{0%,to{opacity:1}50%{opacity:.4}}.sync-label{white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.sync-conflict-badge{background:#ff3b30;color:#fff;font-size:9px;font-weight:700;padding:1px 5px;border-radius:8px;margin-left:auto}.sync-popover-overlay{position:fixed;inset:0;z-index:999}.sync-popover{position:absolute;bottom:100%;left:8px;width:260px;background:var(--bg-surface, #fff);border-radius:12px;box-shadow:0 8px 30px #0000002e;z-index:1000;padding:12px;margin-bottom:8px}.sync-popover-header{display:flex;align-items:center;gap:8px;font-size:13px;font-weight:600;color:var(--text-primary, #1d1d1f);margin-bottom:10px;padding-bottom:8px;border-bottom:1px solid var(--border-color, rgba(60,60,67,.12))}.sync-popover-status{display:flex;align-items:center;gap:6px;font-size:12px;margin-bottom:8px}.sync-popover-row{display:flex;justify-content:space-between;align-items:center;font-size:11px;color:var(--text-secondary, #6e6e73);padding:3px 0}.sync-popover-label{color:var(--text-tertiary, #8e8e93)}.sync-popover-value{font-weight:500}.sync-pending{color:#ff9500}.sync-popover-error{font-size:11px;color:#ff3b30;background:#ff3b3014;padding:6px 8px;border-radius:6px;margin:6px 0}.sync-popover-conflicts{background:#ff3b300f;border-radius:8px;padding:8px;margin:8px 0}.sync-popover-conflict-title{display:flex;align-items:center;gap:6px;font-size:12px;font-weight:600;color:#ff3b30}.sync-popover-conflict-desc{font-size:11px;color:var(--text-secondary, #6e6e73);margin:4px 0}.sync-popover-dismiss{background:none;border:none;color:#007aff;font-size:11px;font-weight:500;cursor:pointer;padding:0}.sync-popover-action{display:flex;align-items:center;justify-content:center;gap:6px;width:100%;padding:8px;margin-top:8px;background:var(--accent, #007AFF);color:#fff;border:none;border-radius:8px;font-size:12px;font-weight:600;cursor:pointer;transition:opacity .12s}.sync-popover-action:hover{opacity:.85}.sync-popover-action:disabled{opacity:.5;cursor:not-allowed}.user-cell{display:flex;align-items:center;gap:10px;padding:8px;border-radius:var(--r-sm);cursor:pointer;transition:background .12s}.user-cell:hover{background:#ffffff0f}.user-av{width:32px;height:32px;border-radius:50%;flex-shrink:0;background:linear-gradient(135deg,var(--blue),var(--indigo));display:flex;align-items:center;justify-content:center;font-size:12px;font-weight:600;color:#fff}.user-name{font-size:13px;font-weight:500;color:#ffffffd9}.user-role{font-size:11.5px;color:#fff6;margin-top:1px}.sync-row{display:flex;align-items:center;gap:6px;padding:6px 8px;font-size:11.5px;color:#ffffff59}.sync-dot{width:6px;height:6px;border-radius:50%;background:var(--green);flex-shrink:0}.titlebar{height:52px;background:var(--glass);border-bottom:1px solid var(--separator);backdrop-filter:blur(20px) saturate(180%);-webkit-backdrop-filter:blur(20px) saturate(180%);display:flex;align-items:center;padding:0 20px;gap:10px;flex-shrink:0}.titlebar-title{font-size:15px;font-weight:600;color:var(--label);letter-spacing:-.02em}.titlebar-right{margin-left:auto;display:flex;align-items:center;gap:8px}.search-field{display:flex;align-items:center;gap:7px;background:#7878801f;border-radius:8px;padding:5px 10px;min-width:200px;transition:all .15s}.search-field:focus-within{background:var(--surface-solid);box-shadow:var(--shadow-sm);outline:2px solid var(--blue);outline-offset:0}.search-field input{border:none;background:none;outline:none;font-family:inherit;font-size:13px;color:var(--label);width:100%}.search-field input::placeholder{color:var(--label-4)}.btn{display:inline-flex;align-items:center;gap:5px;padding:6px 13px;border-radius:var(--r-sm);font-family:inherit;font-size:13px;font-weight:500;cursor:pointer;transition:all .13s;border:none;white-space:nowrap}.btn-primary{background:var(--blue);color:#fff;box-shadow:0 1px 3px #0066cc59}.btn-primary:hover{background:#0055ab}.btn-secondary{background:#78788024;color:var(--label)}.btn-secondary:hover{background:#78788033}.btn-danger{background:var(--red-bg);color:var(--red)}.btn-danger:hover{background:#ff3b302e}.icon-btn{width:30px;height:30px;border-radius:var(--r-sm);display:flex;align-items:center;justify-content:center;background:none;border:none;cursor:pointer;color:var(--label-3);transition:all .12s;position:relative}.icon-btn:hover{background:#00000012;color:var(--label)}.notif-badge{position:absolute;top:4px;right:4px;width:7px;height:7px;border-radius:50%;background:var(--orange);border:1.5px solid var(--bg)}.content{flex:1;min-height:0;overflow-y:auto;padding:20px 24px;display:flex;flex-direction:column;gap:20px}.content::-webkit-scrollbar{width:8px}.content::-webkit-scrollbar-thumb{background:#00000026;border-radius:4px;border:2px solid var(--bg)}.page-header{display:flex;align-items:flex-end;justify-content:space-between}.ph-title{font-size:26px;font-weight:700;color:var(--label);letter-spacing:-.03em;line-height:1}.ph-sub{font-size:13px;color:var(--label-4);margin-top:4px}.ph-actions{display:flex;gap:8px}.kpi-grid{display:grid;grid-template-columns:repeat(5,1fr);gap:12px}.kpi{background:var(--surface-solid);border-radius:var(--r-lg);padding:16px;box-shadow:var(--shadow-sm);border:1px solid rgba(255,255,255,.6);cursor:pointer;transition:all .15s}.kpi:hover{transform:translateY(-2px);box-shadow:var(--shadow-md)}.kpi-top{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:12px}.kpi-ico{width:34px;height:34px;border-radius:9px;display:flex;align-items:center;justify-content:center}.kpi-ico.blue{background:var(--blue-light);color:var(--blue)}.kpi-ico.green{background:var(--green-bg);color:var(--green)}.kpi-ico.orange{background:var(--orange-bg);color:var(--orange)}.kpi-ico.red{background:var(--red-bg);color:var(--red)}.kpi-ico.indigo{background:var(--indigo-bg);color:var(--indigo)}.kpi-pill{font-size:11px;font-weight:600;padding:3px 7px;border-radius:20px}.kp-up{background:var(--green-bg);color:var(--green)}.kp-warn{background:var(--orange-bg);color:var(--orange)}.kp-down{background:var(--red-bg);color:var(--red)}.kpi-val{font-size:24px;font-weight:700;color:var(--label);letter-spacing:-.04em;line-height:1}.kpi-lbl{font-size:12px;color:var(--label-4);margin-top:5px;font-weight:400}.section-hd{display:flex;align-items:center;gap:8px;margin-bottom:14px}.section-name{font-size:17px;font-weight:600;color:var(--label);letter-spacing:-.02em}.section-pill{background:#78788024;color:var(--label-3);font-size:12px;font-weight:500;padding:2px 8px;border-radius:20px}.section-right{margin-left:auto;display:flex;gap:8px;align-items:center}.filter-bar{display:flex;align-items:center;gap:8px;flex-wrap:wrap}.toolbar-bar{display:flex;align-items:center;gap:10px}.filter-pills{display:flex;gap:6px}.fpill{padding:5px 13px;border-radius:20px;font-size:13px;font-weight:400;cursor:pointer;border:none;background:#7878801f;color:var(--label-3);transition:all .12s;font-family:inherit}.fpill:hover{background:#7878802e;color:var(--label-2)}.fpill.active{background:var(--blue);color:#fff;font-weight:500}.filter-btn{display:inline-flex;align-items:center;gap:6px;padding:6px 12px;border-radius:8px;font-size:13px;font-family:inherit;font-weight:500;color:var(--label-2);background:var(--surface-solid);border:1px solid var(--separator);cursor:pointer;transition:all .12s;white-space:nowrap;appearance:none;-webkit-appearance:none}.filter-btn:hover{border-color:var(--label-4);color:var(--label)}.filter-btn.active{border-color:var(--blue);color:var(--blue);background:#007aff0f}.filter-btn .filter-btn-icon{color:var(--label-4);flex-shrink:0}.filter-btn.active .filter-btn-icon{color:var(--blue)}.filter-btn .filter-btn-chevron{color:var(--label-4);flex-shrink:0;margin-left:-2px}.filter-btn .filter-btn-clear{display:inline-flex;align-items:center;justify-content:center;width:16px;height:16px;border-radius:50%;background:var(--label-4);color:#fff;font-size:10px;font-weight:700;margin-left:2px;cursor:pointer;line-height:1}.filter-btn.active .filter-btn-clear{background:var(--blue)}select.filter-btn{padding-right:28px;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 24 24' fill='none' stroke='%23999' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='m6 9 6 6 6-6'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 10px center}select.filter-btn:focus{outline:none;box-shadow:0 0 0 2px #007aff4d}input[type=date].filter-btn{width:145px}input[type=date].filter-btn::-webkit-calendar-picker-indicator{opacity:.5;cursor:pointer}.filter-bar-sep{width:1px;height:20px;background:var(--separator);flex-shrink:0}.drp{position:relative}.drp-dropdown{position:absolute;top:calc(100% + 6px);left:0;z-index:100;display:flex;background:var(--surface-solid);border:1px solid var(--separator);border-radius:12px;box-shadow:0 8px 32px #0000001f,0 2px 8px #0000000f;overflow:hidden;animation:fadeIn .12s ease}.drp-presets{display:flex;flex-direction:column;gap:2px;padding:8px;border-right:1px solid var(--separator);min-width:150px}.drp-preset{padding:7px 14px;border-radius:6px;border:none;background:none;font-family:inherit;font-size:13px;color:var(--label-2);cursor:pointer;text-align:left;transition:all .1s;white-space:nowrap}.drp-preset:hover{background:#007aff14;color:var(--blue)}.drp-preset.active{background:#007aff1a;color:var(--blue);font-weight:500}.drp-calendar{padding:12px 16px;min-width:310px}.drp-cal-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:12px}.drp-cal-month{font-size:14px;font-weight:600;color:var(--label)}.drp-cal-nav{display:flex;gap:4px}.drp-cal-nav button{width:28px;height:28px;border-radius:6px;border:none;background:none;cursor:pointer;color:var(--label-3);display:flex;align-items:center;justify-content:center}.drp-cal-nav button:hover{background:#0000000f;color:var(--label)}.drp-cal-grid{display:grid;grid-template-columns:36px repeat(7,1fr);gap:0}.drp-cal-wh{font-size:11px;font-weight:500;color:var(--label-4);text-align:center;padding:4px 0}.drp-cal-weeknum{font-size:11px;color:var(--label-4);text-align:center;display:flex;align-items:center;justify-content:center}.drp-cal-day{font-size:13px;text-align:center;padding:6px 0;cursor:pointer;border-radius:0;color:var(--label);transition:background .08s}.drp-cal-day:hover{background:#007aff1a}.drp-cal-day.drp-out{color:var(--label-4)}.drp-cal-day.drp-today{font-weight:700;color:var(--blue)}.drp-cal-day.drp-in-range{background:#007aff1f}.drp-cal-day.drp-range-start{background:var(--blue);color:#fff;border-radius:50% 0 0 50%}.drp-cal-day.drp-range-end{background:var(--blue);color:#fff;border-radius:0 50% 50% 0}.drp-cal-day.drp-range-start.drp-range-end{border-radius:50%}.drp-cal-footer{text-align:right;margin-top:8px}.drp-cal-today-btn{border:none;background:none;font-family:inherit;font-size:12px;font-weight:600;color:var(--blue);cursor:pointer;letter-spacing:.03em}.drp-cal-today-btn:hover{text-decoration:underline}.msel{position:relative}.msel-dropdown{position:absolute;top:calc(100% + 6px);left:0;z-index:100;background:var(--surface-solid);border:1px solid var(--separator);border-radius:10px;box-shadow:0 8px 32px #0000001f,0 2px 8px #0000000f;min-width:200px;max-height:280px;overflow-y:auto;padding:6px;animation:fadeIn .12s ease}.msel-option{display:flex;align-items:center;gap:8px;padding:7px 10px;border-radius:6px;cursor:pointer;font-size:13px;color:var(--label-2);transition:background .08s}.msel-option:hover{background:#007aff0f}.msel-option input[type=checkbox]{width:15px;height:15px;accent-color:var(--blue);cursor:pointer}.msel-empty{padding:12px;text-align:center;color:var(--label-4);font-size:13px}.msel-footer{border-top:1px solid var(--separator);padding:6px 10px;margin-top:4px}.msel-footer button{border:none;background:none;font-family:inherit;font-size:12px;color:var(--blue);cursor:pointer}.msel-footer button:hover{text-decoration:underline}.filter-select{padding:5px 28px 5px 12px;border-radius:20px;font-size:13px;font-family:inherit;font-weight:400;color:var(--label-2);background:#7878801f;border:none;cursor:pointer;appearance:none;-webkit-appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 24 24' fill='none' stroke='%23999' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='m6 9 6 6 6-6'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 8px center;transition:all .12s}.filter-select:hover{background-color:#7878802e;color:var(--label)}.filter-select:focus{outline:none;box-shadow:0 0 0 2px var(--blue)}.table{width:100%;border-collapse:collapse}.table th{text-align:left;font-size:11px;font-weight:600;color:var(--label-4);text-transform:uppercase;letter-spacing:.04em;padding:10px 14px;border-bottom:1px solid var(--separator);position:sticky;top:0;background:var(--surface-solid);z-index:2}.table td{padding:11px 14px;border-bottom:1px solid var(--separator-soft);font-size:13px;color:var(--label-2)}.table tr:hover td{background:#0066cc08}.table-wrap{overflow:auto;flex:1;min-height:0}.col-resize-handle{position:absolute;right:0;top:0;bottom:0;width:6px;cursor:col-resize;z-index:3;-webkit-user-select:none;user-select:none}.col-resize-handle:after{content:"";position:absolute;right:0;top:25%;bottom:25%;width:2px;border-radius:1px;background:transparent;transition:background .15s}.col-resize-handle:hover:after,.col-resize-handle:active:after{background:var(--blue)}.pagination-bar{display:flex;align-items:center;justify-content:space-between;padding:10px 14px;border-bottom:1px solid var(--separator-soft);background:var(--surface-solid);font-size:13px}.pagination-info{color:var(--label-3)}.pagination-controls{display:flex;align-items:center;gap:8px}.pagination-controls .btn{display:inline-flex;align-items:center;gap:4px}.pagination-page{color:var(--label-2);font-weight:500;white-space:nowrap}.pagination-size select{font-size:12px}.preset-dropdown-wrap{position:relative}.preset-active{border-color:var(--blue)!important;color:var(--blue)!important}.preset-active-name{font-weight:500;font-size:11px;color:var(--blue);max-width:120px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.preset-dropdown{position:absolute;top:calc(100% + 4px);right:0;z-index:100;min-width:240px;max-width:320px;background:var(--surface-solid);border:1px solid var(--separator);border-radius:8px;box-shadow:var(--shadow-md);overflow:hidden;animation:fadeIn .12s ease}.preset-item{display:flex;align-items:center;gap:8px;width:100%;padding:8px 12px;border:none;background:none;font-size:13px;color:var(--label);cursor:pointer;text-align:left;transition:background .1s}.preset-item:hover{background:var(--blue-light)}.preset-item.active{font-weight:600}.preset-item.preset-action{color:var(--blue);font-weight:500}.preset-item-name{flex:1;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.preset-icon-lock{color:var(--label-4);flex-shrink:0}.preset-icon-default{color:var(--orange);flex-shrink:0}.preset-check{color:var(--blue);flex-shrink:0;margin-left:auto}.preset-separator{height:1px;background:var(--separator-soft);margin:4px 0}.preset-empty{padding:12px;color:var(--label-4);font-size:13px;text-align:center}.preset-save-modal,.preset-manager-modal{background:var(--surface-solid);border-radius:12px;box-shadow:var(--shadow-lg);width:400px;max-width:90vw;animation:slideUp .2s ease}.preset-manager-modal{width:480px}.preset-save-header{display:flex;align-items:center;justify-content:space-between;padding:16px 20px;border-bottom:1px solid var(--separator-soft)}.preset-save-header h3{font-size:15px;font-weight:600}.preset-save-body{padding:16px 20px}.preset-save-body label{display:block;font-size:12px;font-weight:500;color:var(--label-3);margin-bottom:6px}.preset-save-body input{width:100%;padding:8px 12px;border:1px solid var(--separator);border-radius:6px;font-size:13px;outline:none;transition:border-color .15s}.preset-save-body input:focus{border-color:var(--blue)}.preset-save-footer{display:flex;justify-content:flex-end;gap:8px;padding:12px 20px;border-top:1px solid var(--separator-soft)}.preset-manager-body{padding:8px 0;max-height:400px;overflow-y:auto}.preset-manager-row{display:flex;align-items:center;gap:8px;padding:8px 20px;transition:background .1s}.preset-manager-row:hover{background:var(--bg-secondary)}.preset-manager-row.system{opacity:.7}.preset-manager-name{flex:1;font-size:13px;display:flex;align-items:center;gap:6px}.preset-manager-actions{display:flex;gap:4px;opacity:0;transition:opacity .15s}.preset-manager-row:hover .preset-manager-actions{opacity:1}.preset-btn-icon{display:inline-flex;align-items:center;justify-content:center;width:28px;height:28px;border:none;background:none;border-radius:6px;cursor:pointer;color:var(--label-3);transition:all .12s}.preset-btn-icon:hover{background:var(--bg-secondary);color:var(--label)}.preset-btn-icon.danger:hover{background:var(--red-bg);color:var(--red)}.preset-rename-input{flex:1;padding:4px 8px;border:1px solid var(--blue);border-radius:4px;font-size:13px;outline:none}.link-cell{display:flex;align-items:center;position:relative;overflow:hidden}.link-cell-text{overflow:hidden;text-overflow:ellipsis;white-space:nowrap;flex:1;min-width:0}.btn-apercu{display:none;align-items:center;gap:3px;padding:2px 8px;border-radius:4px;border:1px solid var(--separator);background:var(--surface-solid);color:var(--label-3);font-size:11px;font-weight:500;cursor:pointer;white-space:nowrap;transition:all .12s;flex-shrink:0;margin-left:auto;box-shadow:-12px 0 8px var(--surface-solid)}.btn-apercu:hover{background:var(--blue);color:#fff;border-color:var(--blue);box-shadow:none}.table tr:hover .btn-apercu{display:inline-flex}.badge{display:inline-flex;align-items:center;gap:4px;padding:2px 10px;border-radius:20px;font-size:12px;font-weight:500}.badge-prospect{background:var(--blue-light);color:var(--blue)}.badge-devis{background:var(--orange-bg);color:var(--orange)}.badge-confirme{background:var(--green-bg);color:var(--green)}.badge-sur_site{background:var(--cyan-bg);color:#0070a8}.badge-termine{background:var(--green-bg);color:var(--green)}.badge-annule{background:var(--red-bg);color:var(--red)}.top-bar{height:42px;background:var(--surface-solid);border-bottom:1px solid var(--separator);display:flex;align-items:center;padding:0;flex-shrink:0}.top-bar-tabs{flex:1;display:flex;align-items:flex-end;height:100%;padding:0 8px;gap:0;overflow-x:auto;overflow-y:hidden}.top-bar-tabs::-webkit-scrollbar{height:0}.top-bar-actions{display:flex;align-items:center;gap:4px;padding:0 12px;flex-shrink:0;height:100%}.top-btn{width:32px;height:32px;border-radius:var(--r-sm);display:flex;align-items:center;justify-content:center;background:none;border:none;cursor:pointer;color:var(--label-3);transition:all .12s;position:relative}.top-btn:hover{background:#0000000f;color:var(--label)}.tab-item{display:flex;align-items:center;gap:6px;padding:0 14px;font-size:13px;font-weight:400;color:var(--label-3);cursor:pointer;white-space:nowrap;transition:all .15s;max-width:200px;height:100%;border-right:1px solid var(--separator-soft);position:relative}.tab-item:hover{background:#00000008;color:var(--label)}.tab-item.active{color:var(--blue);font-weight:500;background:none}.tab-item.active:after{content:"";position:absolute;bottom:0;left:0;right:0;height:2px;background:var(--blue)}.tab-label{overflow:hidden;text-overflow:ellipsis}.tab-close{display:flex;align-items:center;justify-content:center;width:18px;height:18px;border-radius:4px;border:none;background:none;color:var(--label-4);cursor:pointer;opacity:1;transition:all .12s;flex-shrink:0}.tab-close:hover{background:#0000001a;color:var(--label)}.top-notif-dot{position:absolute;top:5px;right:5px;width:7px;height:7px;border-radius:50%;background:var(--red);border:1.5px solid var(--surface-solid)}.top-separator{width:1px;height:20px;background:var(--separator);margin:0 4px}.top-user{display:flex;align-items:center;gap:8px;padding:4px 8px;border-radius:var(--r-sm);cursor:pointer;transition:background .12s}.top-user:hover{background:#0000000d}.top-user-av{width:28px;height:28px;border-radius:50%;background:linear-gradient(135deg,var(--blue),var(--indigo));display:flex;align-items:center;justify-content:center;font-size:11px;font-weight:600;color:#fff}.top-user-name{font-size:13px;font-weight:500;color:var(--label-2)}.proj-bar{height:52px;background:var(--glass);border-bottom:1px solid var(--separator);-webkit-backdrop-filter:blur(20px) saturate(180%);backdrop-filter:blur(20px) saturate(180%);display:flex;align-items:center;padding:0 20px;gap:12px;flex-shrink:0}.proj-bar-ref{font-size:12px;font-weight:500;color:var(--label-4);font-variant-numeric:tabular-nums}.proj-bar-sep{color:var(--separator);font-size:18px}.proj-bar-name{font-size:15px;font-weight:600;color:var(--label);letter-spacing:-.02em}.proj-bar-right{margin-left:auto;display:flex;align-items:center;gap:8px}.status-pill{display:inline-flex;align-items:center;gap:5px;padding:3px 9px;border-radius:20px;font-size:12px;font-weight:500}.status-confirme{background:var(--green-bg);color:var(--green)}.status-devis{background:var(--blue-light);color:var(--blue)}.status-sur_site{background:var(--cyan-bg);color:#0070a8}.status-annule{background:var(--red-bg);color:var(--red)}.status-prospect{background:#7878801a;color:var(--label-3)}.status-termine{background:#28a74514;color:#6b7280}.tabs-bar{height:40px;background:var(--glass-dark);border-bottom:1px solid var(--separator);display:flex;align-items:flex-end;padding:0 20px;gap:0;flex-shrink:0}.tab{padding:0 16px 10px;font-size:13px;font-weight:400;color:var(--label-3);cursor:pointer;position:relative;transition:color .13s;white-space:nowrap}.tab:hover{color:var(--label-2)}.tab.active{color:var(--blue);font-weight:500}.tab.active:after{content:"";position:absolute;bottom:0;left:16px;right:16px;height:2px;background:var(--blue);border-radius:2px 2px 0 0}.grid-2{display:grid;grid-template-columns:1fr 1fr;gap:16px}.card{background:var(--surface-solid);border:1px solid var(--separator);border-radius:var(--r-lg);box-shadow:var(--shadow-sm);overflow:hidden}.card-head{padding:14px 18px 12px;border-bottom:1px solid var(--separator-soft);display:flex;align-items:center;justify-content:space-between}.card-title{font-size:12px;font-weight:600;color:var(--label-3);text-transform:uppercase;letter-spacing:.06em}.card-action{font-size:12.5px;font-weight:500;color:var(--blue);cursor:pointer}.card-action:hover{text-decoration:underline}.card-body{padding:4px 0}.kv{display:flex;align-items:center;padding:9px 18px;gap:12px;transition:background .1s}.kv:hover{background:#00000006}.kv-key{font-size:12.5px;color:var(--label-3);flex-shrink:0;min-width:130px}.kv-val{font-size:13px;font-weight:500;color:var(--label);margin-left:auto;text-align:right}.kv-sep{margin:4px 18px;height:1px;background:var(--separator-soft)}.fin-grid{display:grid;grid-template-columns:1fr 1fr;gap:0}.fin-cell{padding:12px 18px;border-bottom:1px solid var(--separator-soft)}.fin-cell:nth-child(odd){border-right:1px solid var(--separator-soft)}.fin-cell:nth-last-child(-n+2){border-bottom:none}.fin-label{font-size:11.5px;color:var(--label-4);margin-bottom:3px}.fin-val{font-size:16px;font-weight:700;color:var(--label);letter-spacing:-.02em;font-variant-numeric:tabular-nums}.fin-val.highlight{color:var(--blue)}.gen-scroll{flex:1;overflow-y:auto;padding:20px;display:flex;gap:20px;align-items:flex-start}.gen-left{flex:1;min-width:0;display:flex;flex-direction:column;gap:16px}.gen-right{width:270px;flex-shrink:0;display:flex;flex-direction:column;gap:16px}.g-card{background:var(--surface-solid);border:1px solid var(--separator);border-radius:var(--r-lg);box-shadow:var(--shadow-sm);overflow:hidden}.g-card-head{padding:11px 16px;border-bottom:1px solid var(--separator-soft);display:flex;align-items:center;gap:8px}.g-card-icon{width:26px;height:26px;border-radius:7px;display:flex;align-items:center;justify-content:center;flex-shrink:0}.g-card-title{font-size:11px;font-weight:700;color:var(--label-3);text-transform:uppercase;letter-spacing:.06em;flex:1}.g-card-action{font-size:12px;font-weight:500;color:var(--blue);cursor:pointer;white-space:nowrap}.g-card-action:hover{text-decoration:underline}.form-grid-2{display:grid;grid-template-columns:1fr 1fr;gap:12px;padding:14px 16px}.form-grid-4{display:grid;grid-template-columns:1fr 1fr 1fr 1fr;gap:10px;padding:0 16px 14px}.form-group{display:flex;flex-direction:column;gap:4px}.form-label{font-size:11px;font-weight:600;color:var(--label-4);text-transform:uppercase;letter-spacing:.05em}.form-input{border:1px solid var(--separator);border-radius:var(--r-sm);padding:7px 10px;font-size:13px;font-family:inherit;color:var(--label);background:var(--bg);outline:none;transition:border-color .12s}.form-input:focus{border-color:var(--blue);background:var(--input-bg)}.form-input::placeholder{color:var(--label-4)}.form-select{border:1px solid var(--separator);border-radius:var(--r-sm);padding:7px 10px;font-size:13px;font-family:inherit;color:var(--label);background:var(--bg);outline:none;cursor:pointer}.form-select:focus{border-color:var(--blue)}.entity-block{display:flex;align-items:flex-start;gap:12px;padding:14px 16px}.entity-avatar{width:38px;height:38px;border-radius:var(--r-md);flex-shrink:0;display:flex;align-items:center;justify-content:center;font-size:13px;font-weight:800;color:#fff}.entity-info{flex:1;min-width:0}.entity-name{font-size:14px;font-weight:700;color:var(--label);line-height:1.2}.entity-code{font-size:11.5px;color:var(--label-4);margin-bottom:6px}.entity-detail{display:flex;flex-direction:column;gap:3px;font-size:12.5px;color:var(--label-3);margin-top:6px}.entity-detail span{display:flex;align-items:center;gap:5px}.lieu-fields{padding:8px 16px 14px;display:flex;flex-direction:column;gap:8px}.lieu-row2{display:grid;grid-template-columns:100px 1fr;gap:8px}.notes-area{width:100%;border:none;outline:none;resize:none;font-family:-apple-system,SF Pro Text,Helvetica Neue,sans-serif;font-size:13px;color:var(--label-2);line-height:1.6;background:transparent;padding:12px 16px;min-height:80px}.notes-area::placeholder{color:var(--label-4);font-style:italic}.cal-nav{display:flex;align-items:center;justify-content:space-between;padding:10px 14px 8px}.cal-month{font-size:13px;font-weight:700;color:var(--label)}.cal-arrow{width:22px;height:22px;border-radius:5px;border:none;background:none;cursor:pointer;display:flex;align-items:center;justify-content:center;color:var(--label-3)}.cal-arrow:hover{background:#00000012}.cal-table{width:100%;border-collapse:collapse;padding:0 6px;table-layout:fixed}.cal-th{font-size:10px;text-align:center;color:var(--label-4);padding:2px 0 4px;font-weight:600}.cal-th-wk{width:22px;font-size:9px;color:var(--label-4)}.cal-td{text-align:center;padding:0;vertical-align:top;position:relative}.cal-td-wk{width:22px;font-size:9px;color:var(--label-4);vertical-align:middle}.cal-td-other .cal-num{color:var(--label-4)}.cal-num{font-size:11.5px;color:var(--label-2);padding:3px 0 1px;line-height:1}.cal-td-today .cal-num{background:var(--blue);color:#fff;font-weight:700;border-radius:50%;width:22px;height:22px;line-height:22px;margin:0 auto;padding:0}.cal-bars{display:flex;flex-direction:column;gap:1px;padding:1px 0 2px}.cal-bar-slot{height:3px;width:100%;border-radius:0}.cal-bar-active{opacity:.85}.cal-bar-start{border-radius:3px 0 0 3px;margin-left:2px;width:calc(100% - 2px)}.cal-bar-end{border-radius:0 3px 3px 0;margin-right:2px;width:calc(100% - 2px)}.cal-bar-single{border-radius:3px;margin:0 2px;width:calc(100% - 4px)}.cal-legend{padding:6px 14px 10px;display:flex;flex-direction:column;gap:4px}.cal-legend-item{display:flex;align-items:center;gap:5px;font-size:11px;color:var(--label-2)}.cal-legend-dot{width:8px;height:8px;border-radius:50%;flex-shrink:0}.cal-grid{padding:0 10px 10px;display:grid;grid-template-columns:repeat(7,1fr);gap:1px}.cal-dh{font-size:10.5px;text-align:center;color:var(--label-4);padding:3px 0;font-weight:600}.cal-day{font-size:12px;text-align:center;padding:4px 2px;border-radius:5px;cursor:pointer;color:var(--label-2)}.cal-day:hover{background:#0000000f}.cal-day.other{color:var(--label-4)}.cal-day.today{background:var(--blue);color:#fff;font-weight:700;border-radius:50%}.cal-day.event{color:var(--blue);font-weight:700;border-bottom:2px solid var(--blue)}.avancee-row{display:flex;align-items:center;padding:9px 14px;gap:10px;cursor:pointer;transition:background .1s}.avancee-row:hover{background:#00000006}.avancee-row:not(:last-child){border-bottom:1px solid var(--separator-soft)}.avancee-icon{width:30px;height:30px;border-radius:8px;display:flex;align-items:center;justify-content:center;flex-shrink:0}.avancee-label{font-size:13px;font-weight:500;color:var(--label)}.avancee-sub{font-size:11.5px;margin-top:1px}.avancee-sub.warn{color:var(--red)}.avancee-sub.muted{color:var(--label-4)}.alert{display:flex;align-items:center;gap:12px;padding:11px 16px;border-radius:var(--r-md);font-size:13px}.alert.warn{background:var(--orange-bg);color:#965700;border:1px solid rgba(255,149,0,.2)}.alert.info{background:var(--blue-light);color:#004a99;border:1px solid rgba(0,102,204,.15)}.alert.danger{background:var(--red-bg);color:#c0392b;border:1px solid rgba(255,59,48,.2)}.ai-callout{display:flex;align-items:center;gap:14px;background:linear-gradient(135deg,#5856d612,#af52de12);border:1px solid rgba(88,86,214,.2);border-radius:var(--r-lg);padding:14px 16px;box-shadow:var(--shadow-xs)}.ai-ico{width:36px;height:36px;border-radius:10px;flex-shrink:0;background:linear-gradient(135deg,var(--indigo),var(--purple));display:flex;align-items:center;justify-content:center;box-shadow:0 2px 6px #5856d659}.ai-body{flex:1;min-width:0}.ai-tag{font-size:11px;font-weight:600;color:var(--indigo);margin-bottom:2px;text-transform:uppercase;letter-spacing:.05em}.ai-msg{font-size:13px;color:var(--label-2);line-height:1.45}.prog-header{background:var(--surface-solid);border:1px solid var(--separator);border-radius:var(--r-lg);padding:16px 20px;box-shadow:var(--shadow-sm)}.prog-top{display:flex;align-items:center;justify-content:space-between;margin-bottom:12px}.prog-title{font-size:12px;font-weight:600;color:var(--label-3);text-transform:uppercase;letter-spacing:.06em}.prog-pct{font-size:13px;font-weight:600;color:var(--label-3)}.indicators{display:flex;gap:8px;margin-bottom:6px}.ind{flex:1;height:6px;border-radius:3px;cursor:pointer;transition:height .15s}.ind:hover{height:8px}.ind.ok{background:var(--green)}.ind.warn{background:var(--orange)}.ind.ko{background:var(--red)}.ind.empty{background:var(--bg-secondary)}.ai-dismiss{background:none;border:none;color:var(--label-4);cursor:pointer;font-size:16px;padding:4px;border-radius:6px;line-height:1;flex-shrink:0}.ai-dismiss:hover{background:#00000012}.dashboard-page{padding-bottom:20px}.dash-toolbar{display:flex;align-items:center;justify-content:space-between;padding:16px 20px 8px}.dash-toolbar .ph-title{font-size:20px;font-weight:600;margin:0}.dash-toolbar .ph-sub{font-size:13px;color:var(--label-3);margin-top:2px}.btn-ghost{background:var(--surface-solid);border:1px solid var(--separator);color:var(--label);padding:6px 14px;border-radius:6px;font-size:13px;cursor:pointer}.btn-ghost:hover{background:var(--bg-hover, rgba(0,0,0,.04))}.react-grid-item{border-radius:var(--r-lg, 12px);overflow:hidden}.react-grid-item.react-draggable-dragging{box-shadow:var(--shadow-lg);opacity:.92;z-index:100}.react-grid-placeholder{background:#007aff0f!important;border:2px dashed var(--blue, #007aff)!important;border-radius:var(--r-lg, 12px)!important}.react-grid-item>.react-resizable-handle:after{border-color:var(--label-4)!important}.dashboard-page{padding:0}.dash-toolbar{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:16px;gap:16px}.dash-grid{display:grid;grid-template-columns:repeat(12,1fr);gap:16px}.dash-grid>.dash-wide{grid-column:span 12}.dash-grid>.dash-card:not(.dash-wide){grid-column:span 6}.dash-grid>.dash-card:nth-child(2){grid-column:span 8}.dash-grid>.dash-card:nth-child(3){grid-column:span 4}.btn-ghost{background:none;border:1px solid var(--separator);border-radius:6px;padding:6px 14px;font-size:13px;cursor:pointer;color:var(--label)}.btn-ghost:hover{background:var(--bg-hover)}.dash-card{background:var(--card-bg, var(--surface-solid));border:1px solid var(--separator);border-radius:var(--r-lg);box-shadow:var(--shadow-sm);overflow:hidden;display:flex;flex-direction:column;min-height:0}.dash-card-head{display:flex;align-items:center;gap:8px;padding:12px 16px 10px;flex-shrink:0;border-bottom:1px solid var(--separator-soft);cursor:default}.dash-card-title{font-size:13px;font-weight:600;color:var(--label)}.dash-card-body{flex:1;overflow-y:auto;max-height:380px}.dash-card-remove{background:none;border:none;font-size:18px;line-height:1;cursor:pointer;color:var(--label-4);padding:0 4px;flex-shrink:0}.dash-card-remove:hover{color:var(--red, #ff3b30)}.dash-row{display:flex;align-items:center;gap:10px;padding:9px 16px;border-bottom:1px solid var(--separator-soft)}.dash-row:last-child{border-bottom:none}.dash-row-main{font-size:13px;font-weight:500;color:var(--label)}.dash-row-sub{font-size:11.5px;color:var(--label-4);margin-top:1px}.tab-loading{padding:40px 20px;text-align:center;font-size:13px;color:var(--label-3)}.tab-error{padding:20px;font-size:13px;color:var(--red);background:var(--red-bg);border-radius:var(--r-md)}.tab-empty{display:flex;flex-direction:column;align-items:center;gap:8px;padding:48px 20px;text-align:center;font-size:14px;color:var(--label-3)}.tab-empty svg{color:var(--label-4);margin-bottom:4px}.planning-row{display:flex;align-items:flex-start;gap:12px;padding:12px 18px;border-bottom:1px solid var(--separator-soft);transition:background .1s}.planning-row:last-child{border-bottom:none}.planning-row:hover{background:#00000005}.planning-row-icon{width:28px;height:28px;border-radius:8px;background:var(--blue-light);color:var(--blue);display:flex;align-items:center;justify-content:center;flex-shrink:0;margin-top:1px}.mat-layout{display:flex;flex:1;min-height:0;overflow:hidden}.content>.mat-layout{margin:-20px -24px}.mat-sidebar{width:280px;flex-shrink:0;border-right:1px solid var(--separator);background:var(--surface-solid);display:flex;flex-direction:column;overflow:hidden}.mat-sidebar-search{display:flex;align-items:center;gap:7px;padding:10px 14px;border-bottom:1px solid var(--separator-soft);color:var(--label-4)}.mat-sidebar-search input{border:none;background:none;outline:none;font-family:inherit;font-size:13px;color:var(--label);width:100%}.mat-sidebar-search input::placeholder{color:var(--label-4)}.mat-sidebar-title{padding:12px 14px 6px;font-size:10.5px;font-weight:600;color:var(--label-4);text-transform:uppercase;letter-spacing:.06em}.mat-sidebar-list{flex:1;overflow-y:auto;padding-bottom:12px}.mat-cat-item{display:flex;align-items:center;gap:8px;padding:7px 14px;font-size:13px;color:var(--label-2);cursor:pointer;transition:background .1s}.mat-cat-item:hover{background:#00000008}.mat-cat-item.active{background:var(--blue-light);color:var(--blue);font-weight:500}.mat-cat-chevron{color:var(--label-4);flex-shrink:0}.mat-cat-icon{font-size:14px}.mat-main{flex:1;display:flex;flex-direction:column;min-width:0;overflow:hidden}.mat-toolbar{display:flex;align-items:center;gap:8px;padding:8px 14px;border-bottom:1px solid var(--separator-soft);background:var(--surface-solid);flex-shrink:0}.mat-toolbar-btn{width:32px;height:32px;border-radius:var(--r-sm);display:flex;align-items:center;justify-content:center;background:none;border:1px solid var(--separator);cursor:pointer;color:var(--label-3);transition:all .12s}.mat-toolbar-btn:hover{background:#0000000a;color:var(--label)}.mat-toolbar-search{display:flex;align-items:center;gap:6px;background:#78788014;border-radius:8px;padding:6px 10px;min-width:200px;color:var(--label-4)}.mat-toolbar-search input{border:none;background:none;outline:none;font-family:inherit;font-size:13px;color:var(--label);width:100%}.mat-toolbar-search input::placeholder{color:var(--label-4)}.mat-table{flex:1;overflow:auto}.mat-thead{display:flex;align-items:center;padding:0;border-bottom:1px solid var(--separator);background:var(--surface-solid);position:sticky;top:0;z-index:1}.mat-th{font-size:10.5px;font-weight:600;color:var(--label-4);text-transform:uppercase;letter-spacing:.04em;padding:8px 10px}.mat-col-drag{width:30px;flex-shrink:0;display:flex;align-items:center;justify-content:center}.mat-col-code{width:120px;flex-shrink:0}.mat-col-nom{flex:1;min-width:180px}.mat-col-statut{width:130px;flex-shrink:0}.mat-col-num{width:80px;flex-shrink:0;text-align:right}.mat-col-montant{width:120px;flex-shrink:0;text-align:right}.mat-groupe-header{display:flex;align-items:center;background:#ff950014;border-bottom:1px solid rgba(255,149,0,.15);padding:8px 0;min-height:40px}.mat-groupe-info{flex:1;display:flex;align-items:baseline;gap:10px;padding:0 10px}.mat-groupe-nom{font-size:14px;font-weight:600;color:var(--label)}.mat-groupe-dates{font-size:12px;color:var(--label-4)}.mat-groupe-total{width:120px;flex-shrink:0;text-align:right;padding-right:10px;font-size:14px;font-weight:700;color:var(--green);font-variant-numeric:tabular-nums}.mat-row{display:flex;align-items:center;border-bottom:1px solid var(--separator-soft);transition:background .1s;min-height:40px}.mat-row:hover{background:#00000005}.mat-row-add{cursor:pointer}.mat-row-add:hover{background:#0066cc08}.mat-td{font-size:13px;color:var(--label-2);padding:8px 10px;font-variant-numeric:tabular-nums}.mat-col-montant .mat-td,.mat-td.mat-col-montant,div.mat-td.mat-col-montant{font-weight:600;color:var(--label)}.drag-handle{color:var(--label-4);opacity:0;cursor:grab;transition:opacity .15s}.mat-row:hover .drag-handle,.mat-groupe-header:hover .drag-handle{opacity:.5}.drag-handle:hover{opacity:1!important}.mat-stock-badge{display:inline-flex;align-items:center;gap:4px;padding:2px 8px;border-radius:12px;font-size:11.5px;font-weight:500;white-space:nowrap}.mat-stock-badge.stock-ok{background:var(--green-bg);color:var(--green)}.mat-stock-badge.stock-warn{background:var(--orange-bg);color:var(--orange)}.eq-sidebar-header{display:flex;justify-content:space-between;padding:10px 14px 6px;font-size:10.5px;font-weight:600;color:var(--label-4);text-transform:uppercase;letter-spacing:.04em;border-bottom:1px solid var(--separator-soft)}.eq-cat-item{display:flex;align-items:center;gap:8px;padding:8px 14px;font-size:13.5px;font-weight:500;color:var(--label);cursor:pointer;transition:background .1s}.eq-cat-item:hover{background:#00000008}.eq-cat-name{flex:1}.eq-cat-count{font-size:12px;color:var(--label-4);font-weight:400;min-width:20px;text-align:right}.eq-cat-child{display:flex;align-items:center;gap:8px;padding:5px 14px 5px 36px;font-size:13px;color:var(--label-2);cursor:pointer;transition:background .1s}.eq-cat-child:hover{background:#00000008}.eq-cat-child-check{font-size:14px;color:var(--label-4);width:18px}.eq-cat-child-name{flex:1}.eq-cat-child-tarif{font-size:12px;color:var(--green);font-weight:500;font-variant-numeric:tabular-nums}.eq-type-icon{width:26px;height:26px;border-radius:6px;display:flex;align-items:center;justify-content:center}.timeline-row{display:flex;gap:12px;padding:0 18px}.timeline-row:first-child{padding-top:14px}.timeline-row:last-child{padding-bottom:14px}.timeline-line-wrap{display:flex;flex-direction:column;align-items:center;width:24px;flex-shrink:0}.timeline-dot{width:24px;height:24px;border-radius:50%;display:flex;align-items:center;justify-content:center;flex-shrink:0}.timeline-line{width:2px;flex:1;background:var(--separator-soft);margin:4px 0}.badge-invite{background:var(--orange-bg);color:var(--orange)}.badge-accepte{background:var(--green-bg);color:var(--green)}.badge-refuse{background:var(--red-bg);color:var(--red)}.mat-editable{cursor:pointer;padding:2px 6px;border-radius:4px;transition:background .12s;font-variant-numeric:tabular-nums}.mat-editable:hover{background:#0066cc14}.mat-inline-input{width:64px;padding:2px 4px;border:1.5px solid var(--blue);border-radius:4px;font-size:13px;font-family:inherit;font-variant-numeric:tabular-nums;outline:none;background:var(--input-bg);color:var(--label);box-shadow:0 0 0 3px #0066cc1f}.mat-delete-btn{width:24px;height:24px;border-radius:6px;display:flex;align-items:center;justify-content:center;border:none;background:none;cursor:pointer;color:var(--label-4);opacity:0;transition:all .12s}.mat-row:hover .mat-delete-btn{opacity:1}.mat-delete-btn:hover{background:var(--red-bg);color:var(--red)}.st-action-btn{width:28px;height:28px;border-radius:6px;display:flex;align-items:center;justify-content:center;border:none;background:none;cursor:pointer;color:var(--label-3);opacity:0;transition:all .12s}.st-row:hover .st-action-btn{opacity:1}.st-action-btn:hover{background:#007aff1a;color:var(--cyan)}.st-action-btn-danger:hover{background:var(--red-bg);color:var(--red)}.mat-row-add{cursor:pointer;border-bottom:1px solid var(--separator-soft)}.mat-row-add:hover{background:#0066cc0a}.mat-cat-child{display:flex;align-items:center;gap:6px;padding:5px 14px 5px 32px;font-size:12.5px;color:var(--label-2);cursor:pointer;transition:background .1s}.mat-cat-child:hover{background:#00000008}.mat-cat-child-code{font-size:11px;color:var(--label-4);font-weight:500;min-width:50px;font-variant-numeric:tabular-nums}.mat-cat-child-name{flex:1;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.mat-cat-child-stock{font-size:11px;color:var(--label-4);font-weight:500;min-width:20px;text-align:right}.inline-search-container{position:relative;width:100%}.inline-search-row{display:flex;align-items:center;gap:6px;padding:4px 8px}.inline-search-input{flex:1;border:none;outline:none;background:none;font-size:13px;font-family:inherit;color:var(--label-3);border-bottom:1px dashed var(--separator);padding:3px 0}.inline-search-input::placeholder{color:var(--label-4);font-style:italic}.inline-search-input:focus{border-bottom-color:var(--blue);color:var(--label)}.inline-suggestions{position:absolute;top:100%;left:0;right:0;z-index:100;background:var(--surface-solid);border:1px solid var(--separator);border-radius:8px;box-shadow:var(--shadow-md);max-height:260px;overflow-y:auto}.inline-suggestion{display:flex;align-items:center;gap:8px;padding:7px 12px;font-size:13px;cursor:pointer;transition:background .08s}.inline-suggestion:hover,.inline-suggestion.selected{background:var(--blue-light)}.sugg-code{font-size:11.5px;color:var(--label-4);font-weight:500;min-width:60px;font-variant-numeric:tabular-nums}.sugg-nom{flex:1;color:var(--label)}.sugg-stock{font-size:11px;color:var(--label-4);min-width:24px;text-align:right}.mat-groupe-count{font-size:11.5px;color:var(--label-4);font-weight:400;margin-left:8px}.mat-groupe-badge{font-size:10.5px;font-weight:600;padding:1px 6px;border-radius:4px;margin-left:6px;background:var(--blue-light);color:var(--blue)}.mat-groupe-actions{display:flex;align-items:center;gap:2px;width:auto;margin-left:8px}.mat-row-texte{background:#00000004;border-bottom:1px solid var(--separator-soft)}.mat-row-sous-total{background:#28a74508;border-bottom:1px solid var(--separator-soft)}.add-line-menu-container{position:relative}.add-line-menu-btn{width:24px;height:24px;border-radius:6px;display:flex;align-items:center;justify-content:center;border:1px dashed var(--separator);background:none;cursor:pointer;color:var(--label-4);transition:all .12s}.add-line-menu-btn:hover{border-color:var(--blue);color:var(--blue);background:var(--blue-light)}.add-line-dropdown{position:absolute;top:100%;right:0;z-index:100;background:var(--surface-solid);border:1px solid var(--separator);border-radius:8px;box-shadow:var(--shadow-md);min-width:160px;padding:4px 0;margin-top:4px}.add-line-option{display:flex;align-items:center;gap:8px;padding:7px 12px;font-size:13px;cursor:pointer;color:var(--label);transition:background .08s}.add-line-option:hover{background:var(--blue-light)}.context-menu{position:fixed;z-index:1000;background:var(--surface-solid);border:1px solid var(--separator);border-radius:8px;box-shadow:var(--shadow-lg);min-width:160px;padding:4px 0}.context-menu-item{display:flex;align-items:center;gap:8px;padding:7px 12px;font-size:13px;cursor:pointer;color:var(--label);transition:background .08s}.context-menu-item:hover{background:var(--blue-light)}.context-menu-item.danger{color:var(--red)}.context-menu-item.danger:hover{background:var(--red-bg)}.context-menu-separator{height:1px;background:var(--separator-soft);margin:3px 8px}.col-editor-overlay{position:fixed;inset:0;z-index:1000;background:#00000073;display:flex;align-items:center;justify-content:center;animation:fadeIn .12s ease}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.col-editor{width:700px;max-width:90vw;max-height:80vh;background:var(--surface-solid);border-radius:var(--r-xl);box-shadow:var(--shadow-lg);display:flex;flex-direction:column;overflow:hidden;animation:slideUp .15s ease}@keyframes slideUp{0%{transform:translateY(12px);opacity:0}to{transform:translateY(0);opacity:1}}.col-editor-header{display:flex;align-items:center;justify-content:space-between;padding:16px 20px 14px;border-bottom:1px solid var(--separator);flex-shrink:0}.col-editor-title{font-size:16px;font-weight:600;color:var(--label)}.col-editor-close{width:28px;height:28px;border-radius:6px;display:flex;align-items:center;justify-content:center;border:none;background:none;cursor:pointer;color:var(--label-3);transition:all .12s}.col-editor-close:hover{background:#00000012;color:var(--label)}.col-editor-body{flex:1;display:flex;min-height:0;overflow:hidden}.col-editor-available{flex:1;display:flex;flex-direction:column;border-right:1px solid var(--separator-soft);min-width:0}.col-editor-search{display:flex;align-items:center;gap:7px;padding:10px 16px;border-bottom:1px solid var(--separator-soft)}.col-editor-search input{border:none;background:none;outline:none;font-family:inherit;font-size:13px;color:var(--label);width:100%}.col-editor-search input::placeholder{color:var(--label-4)}.col-editor-list{flex:1;overflow-y:auto;padding:8px 0}.col-editor-list::-webkit-scrollbar{width:6px}.col-editor-list::-webkit-scrollbar-thumb{background:#0000001f;border-radius:3px}.col-editor-category{margin-bottom:4px}.col-editor-cat-label{padding:10px 16px 4px;font-size:10.5px;font-weight:600;color:var(--label-4);text-transform:uppercase;letter-spacing:.06em}.col-editor-item{display:flex;align-items:center;gap:10px;padding:7px 16px;cursor:pointer;transition:background .08s;font-size:13px;color:var(--label)}.col-editor-item:hover{background:#00000008}.col-editor-item input[type=checkbox]{width:16px;height:16px;accent-color:var(--blue);cursor:pointer;flex-shrink:0}.col-editor-item-label{flex:1}.col-editor-item-format{font-size:10.5px;color:var(--label-4);font-weight:500;padding:1px 5px;border-radius:4px;background:#78788014}.col-editor-selected{width:260px;flex-shrink:0;display:flex;flex-direction:column}.col-editor-selected-header{display:flex;align-items:center;justify-content:space-between;padding:10px 14px;border-bottom:1px solid var(--separator-soft);font-size:12px;font-weight:600;color:var(--label-3);text-transform:uppercase;letter-spacing:.04em}.col-editor-reset{display:inline-flex;align-items:center;gap:4px;padding:3px 8px;border-radius:6px;border:none;background:none;cursor:pointer;font-size:11.5px;font-weight:500;color:var(--blue);font-family:inherit;transition:background .12s}.col-editor-reset:hover{background:var(--blue-light)}.col-editor-selected-list{flex:1;overflow-y:auto;padding:4px 0}.col-editor-selected-list::-webkit-scrollbar{width:4px}.col-editor-selected-list::-webkit-scrollbar-thumb{background:#0000001a;border-radius:2px}.col-editor-selected-item{display:flex;align-items:center;gap:6px;padding:7px 14px;font-size:13px;color:var(--label);cursor:grab;transition:background .08s}.col-editor-selected-item:hover{background:#00000008}.col-editor-grip{color:var(--label-4);opacity:.4;flex-shrink:0;cursor:grab}.col-editor-selected-item:hover .col-editor-grip{opacity:.8}.col-editor-selected-label{flex:1;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.col-editor-remove{width:20px;height:20px;border-radius:4px;display:flex;align-items:center;justify-content:center;border:none;background:none;cursor:pointer;color:var(--label-4);opacity:0;transition:all .12s;flex-shrink:0}.col-editor-selected-item:hover .col-editor-remove{opacity:1}.col-editor-remove:hover{background:var(--red-bg);color:var(--red)}.col-editor-empty{padding:20px 14px;text-align:center;font-size:12.5px;color:var(--label-4)}.col-editor-footer{display:flex;justify-content:flex-end;gap:8px;padding:14px 20px;border-top:1px solid var(--separator);flex-shrink:0}.content-with-panel{position:relative}.content .table-area{display:contents}.detail-panel{position:absolute;top:0;right:0;bottom:0;width:400px;background:var(--surface-solid);border-left:1px solid var(--separator);box-shadow:-4px 0 16px #00000014;display:flex;flex-direction:column;overflow-y:auto;z-index:20;animation:slideInRight .2s ease}@keyframes slideInRight{0%{transform:translate(20px);opacity:0}to{transform:translate(0);opacity:1}}.detail-panel::-webkit-scrollbar{width:6px}.detail-panel::-webkit-scrollbar-thumb{background:#0000001a;border-radius:3px}.detail-panel-header{display:flex;align-items:flex-start;justify-content:space-between;padding:20px 20px 12px;gap:12px;border-bottom:1px solid var(--separator-soft)}.detail-panel-title-area{flex:1;min-width:0}.detail-panel-subtitle{font-size:11.5px;font-weight:600;color:var(--label-4);letter-spacing:.3px;text-transform:uppercase;margin-bottom:4px}.detail-panel-title{font-size:17px;font-weight:700;color:var(--label);line-height:1.3;margin-bottom:8px}.detail-panel-actions{display:flex;align-items:center;gap:6px;flex-shrink:0}.detail-panel-close{width:28px;height:28px;border-radius:6px;display:flex;align-items:center;justify-content:center;border:none;background:none;cursor:pointer;color:var(--label-4);transition:all .12s}.detail-panel-close:hover{background:#0000000f;color:var(--label)}.detail-panel-quick{padding:12px 20px;display:flex;flex-direction:column;gap:6px;border-bottom:1px solid var(--separator-soft)}.detail-panel-quick-item{display:flex;align-items:center;gap:8px;font-size:12.5px;color:var(--blue);text-decoration:none;transition:opacity .12s}.detail-panel-quick-item:hover{opacity:.7}div.detail-panel-quick-item{color:var(--label-3)}.detail-panel-body{padding:8px 0 20px}.detail-panel-section{padding:8px 0}.detail-panel-section-label{font-size:10.5px;font-weight:700;color:var(--label-4);text-transform:uppercase;letter-spacing:.5px;padding:6px 20px;margin-bottom:2px}.detail-panel-fields{display:flex;flex-direction:column}.detail-panel-field{display:flex;align-items:baseline;gap:12px;padding:5px 20px;min-height:28px}.detail-panel-field:hover{background:#00000005}.detail-panel-field-label{width:110px;flex-shrink:0;font-size:12px;color:var(--label-4);font-weight:500}.detail-panel-field-value{flex:1;font-size:13px;color:var(--label);word-break:break-word}.btn-sm{font-size:12px!important;padding:4px 10px!important;height:28px!important}.table tbody tr.row-selected{background:var(--blue-light)!important}.table tbody tr.row-selected:hover{background:var(--blue-mid)!important}.table tbody tr.row-detail-active{background:#0066cc0f!important;box-shadow:inset 3px 0 0 var(--blue)}.batch-bar{display:flex;align-items:center;gap:16px;padding:10px 16px;background:var(--blue);border-radius:var(--r-sm);color:#fff;animation:fadeIn .15s ease}.batch-count{font-size:13px;font-weight:600;white-space:nowrap}.batch-actions{display:flex;align-items:center;gap:6px;flex:1;justify-content:flex-end}.batch-bar .btn-secondary{background:#ffffff26!important;color:#fff!important;border:1px solid rgba(255,255,255,.2)!important}.batch-bar .btn-secondary:hover{background:#ffffff40!important}.table input[type=checkbox]{width:15px;height:15px;cursor:pointer;accent-color:var(--blue)}.neo-modal-overlay{position:fixed;inset:0;z-index:9999;background:#0006;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);display:flex;align-items:center;justify-content:center;animation:neo-fade-in .15s ease-out}@keyframes neo-fade-in{0%{opacity:0}to{opacity:1}}@keyframes neo-modal-in{0%{opacity:0;transform:scale(.96) translateY(6px)}to{opacity:1;transform:scale(1) translateY(0)}}.neo-modal{background:var(--surface-solid, #fff);border:1px solid var(--separator, rgba(60,60,67,.18));border-radius:14px;box-shadow:0 20px 60px #0003,0 0 0 .5px #0000000d;min-width:340px;max-width:440px;width:90%;padding:24px;animation:neo-modal-in .2s cubic-bezier(.32,.72,0,1)}.neo-modal-title{font-size:16px;font-weight:700;color:var(--label, #1D1D1F);margin-bottom:6px;letter-spacing:-.02em}.neo-modal-message{font-size:13.5px;color:var(--label-2, #3A3A3C);line-height:1.5;margin-bottom:18px}.neo-modal-input{width:100%;padding:9px 12px;border:1px solid var(--separator, rgba(60,60,67,.18));border-radius:8px;font-size:14px;font-family:inherit;color:var(--label, #1D1D1F);background:var(--bg, #F5F5F7);outline:none;margin-bottom:18px;transition:border-color .12s}.neo-modal-input:focus{border-color:var(--blue, #0066CC);background:var(--input-bg);box-shadow:0 0 0 3px #0066cc1f}.neo-modal-input::placeholder{color:var(--label-4, #8E8E93)}.neo-modal-actions{display:flex;gap:8px;justify-content:flex-end}.neo-modal-btn{padding:8px 18px;border-radius:8px;font-size:13.5px;font-weight:500;font-family:inherit;border:none;cursor:pointer;transition:all .12s}.neo-modal-btn-cancel{background:#78788024;color:var(--label, #1D1D1F)}.neo-modal-btn-cancel:hover{background:#78788038}.neo-modal-btn-confirm{background:var(--blue, #0066CC);color:#fff}.neo-modal-btn-confirm:hover{background:#0055ab}.neo-modal-btn-confirm.danger{background:var(--red, #FF3B30)}.neo-modal-btn-confirm.danger:hover{background:#e0332b}.login-page{min-height:100vh;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,var(--bg-app) 0%,var(--bg-surface-tertiary) 100%)}.login-card{width:380px;background:var(--card-bg);border-radius:16px;box-shadow:0 4px 24px #00000014,0 1px 3px #0000000a;padding:40px 36px;text-align:center}.login-logo{display:flex;flex-direction:column;align-items:center;gap:8px;margin-bottom:24px}.login-logo-icon{width:48px;height:48px;border-radius:12px;background:linear-gradient(135deg,#007aff,#5856d6);color:#fff;font-size:24px;font-weight:700;display:flex;align-items:center;justify-content:center}.login-logo-text{font-size:18px;font-weight:700;color:var(--label, #1d1d1f)}.login-title{font-size:22px;font-weight:700;color:var(--label);margin:0 0 4px}.login-subtitle{font-size:13px;color:var(--label-4, #98989D);margin:0 0 20px}.login-error{display:flex;align-items:center;gap:6px;justify-content:center;padding:10px 14px;margin-bottom:16px;font-size:13px;background:#ff3b3014;color:var(--red, #FF3B30);border-radius:8px;border:1px solid rgba(255,59,48,.15)}.login-form{display:flex;flex-direction:column;gap:12px}.login-field{position:relative;display:flex;align-items:center}.login-field-icon{position:absolute;left:12px;color:var(--label-4);pointer-events:none}.login-field input{width:100%;padding:12px 12px 12px 38px;font-size:14px;border:1px solid var(--separator, rgba(60,60,67,.12));border-radius:10px;background:var(--bg-tertiary, #f5f5f7);color:var(--label);transition:all .15s}.login-field input:focus{outline:none;border-color:var(--blue, #007AFF);box-shadow:0 0 0 3px #007aff1f;background:var(--input-bg)}.login-btn{width:100%;padding:12px;font-size:15px;font-weight:600;color:#fff;background:var(--blue, #007AFF);border:none;border-radius:10px;cursor:pointer;transition:all .15s;margin-top:4px;display:flex;align-items:center;justify-content:center;gap:6px}.login-btn:hover{filter:brightness(1.05)}.login-btn:disabled{opacity:.6;cursor:not-allowed}.login-footer{margin-top:24px;font-size:11px;color:var(--label-4)}.signup-card{width:480px;background:var(--card-bg);border-radius:16px;box-shadow:0 4px 24px #00000014,0 1px 3px #0000000a;padding:36px 32px;text-align:center}.signup-stepper{display:flex;align-items:center;justify-content:center;gap:0;margin:20px 0}.signup-step{display:flex;align-items:center;gap:6px;font-size:12px;color:var(--label-4);font-weight:500}.signup-step.active{color:var(--blue)}.signup-step-dot{width:24px;height:24px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:12px;font-weight:700;background:var(--bg-tertiary);color:var(--label-4)}.signup-step.active .signup-step-dot{background:var(--blue);color:#fff}.signup-step-line{width:40px;height:2px;background:var(--separator);margin:0 8px}.signup-form{display:flex;flex-direction:column;gap:12px;text-align:left}.signup-slug-field{display:flex;align-items:center;gap:0;border:1px solid var(--separator);border-radius:10px;background:var(--bg-tertiary);overflow:hidden;transition:all .15s}.signup-slug-field:focus-within{border-color:var(--blue);box-shadow:0 0 0 3px #007aff1f}.signup-slug-prefix{font-size:13px;color:var(--label-4);padding:12px 0 12px 12px;white-space:nowrap}.signup-slug-field input{border:none;background:none;font-size:14px;color:var(--label);outline:none;padding:12px 4px;font-weight:600}.signup-slug-status{padding:0 10px;display:flex;align-items:center}.signup-hint{font-size:11px;color:var(--label-4);margin-top:-6px;padding-left:4px}.signup-hint.error{color:var(--red)}.signup-select-group{display:flex;flex-direction:column;gap:4px}.signup-select-group label{font-size:11px;font-weight:600;color:var(--label-4)}.signup-select-group select{padding:10px 12px;font-size:13px;border:1px solid var(--separator);border-radius:10px;background:var(--bg-tertiary);color:var(--label)}.signup-pw-strength{display:flex;align-items:center;gap:8px;margin-top:-6px}.signup-pw-bar{flex:1;height:4px;background:var(--separator);border-radius:3px;overflow:hidden}.signup-cgu{display:flex;align-items:flex-start;gap:8px;font-size:12px;color:var(--label-3);cursor:pointer}.signup-cgu input{margin-top:2px;accent-color:var(--blue)}.signup-cgu a{color:var(--blue)}.top-user-menu{position:absolute;top:100%;right:0;margin-top:6px;background:var(--surface-solid, #fff);border:1px solid var(--separator);border-radius:10px;box-shadow:0 6px 20px #00000024;min-width:220px;z-index:9999;overflow:hidden}.top-user-menu-header{padding:12px 14px}.top-user-menu-sep{height:1px;background:var(--separator)}.top-user-menu-item{display:flex;align-items:center;gap:8px;width:100%;padding:10px 14px;font-size:13px;color:var(--label);background:none;border:none;cursor:pointer;text-align:left}.top-user-menu-item:hover{background:var(--bg-hover, rgba(0,0,0,.04))}.top-user-menu-item.danger{color:var(--red, #FF3B30)}.top-user-menu-item.danger:hover{background:#ff3b3014}.top-user-menu-theme{padding:2px 0}.top-user-menu-item.theme-active{color:var(--accent)}.top-user-menu-item .theme-check{margin-left:auto;font-size:13px;color:var(--accent)}.top-btn.active{background:#007aff1a;color:var(--blue)}.top-panel{position:fixed;top:48px;background:var(--surface-solid, #fff);border:1px solid var(--separator);border-radius:12px;box-shadow:0 8px 30px #00000026;z-index:9999;overflow:hidden}.top-panel-search{width:420px;right:220px}.top-panel-dispo{width:440px;right:180px}.top-panel-notifs{width:360px;right:140px}.top-panel-input{display:flex;align-items:center;gap:8px;padding:10px 14px;border-bottom:1px solid var(--separator)}.top-panel-input input{flex:1;border:none;outline:none;font-size:14px;color:var(--label);background:none}.top-panel-input button{background:none;border:none;color:var(--label-4);cursor:pointer}.top-panel-results{max-height:340px;overflow-y:auto}.top-panel-result{display:flex;align-items:center;gap:10px;padding:10px 14px;cursor:pointer;transition:background .1s}.top-panel-result:hover{background:#007aff0a}.top-panel-result:not(:last-child){border-bottom:1px solid rgba(60,60,67,.04)}.trial-banner{display:flex;align-items:center;justify-content:center;gap:12px;height:36px;font-size:13px;font-weight:500;flex-shrink:0}.trial-banner-btn{color:#fff;font-size:11px;font-weight:600;padding:3px 12px;border-radius:4px;text-decoration:none;transition:filter .15s}.trial-banner-btn:hover{filter:brightness(1.1)}.tfa-card{border:1px solid var(--separator, #e5e7eb);border-radius:10px;padding:18px 20px;display:flex;flex-direction:column;gap:14px}.tfa-card.tfa-active{border-color:#22c55e4d;background:#22c55e08}.tfa-header{display:flex;align-items:flex-start;gap:12px}.tfa-title{font-size:14px;font-weight:600;color:var(--label, #1d1d1f)}.tfa-desc{font-size:12px;color:var(--label-4, #888);margin-top:2px}.tfa-qr{display:flex;justify-content:center;padding:8px 0}.tfa-secret{font-size:12px;color:var(--label-3);text-align:center}.tfa-secret code{display:block;margin-top:4px;font-size:13px;font-weight:600;color:var(--label);letter-spacing:.5px;word-break:break-all;background:var(--bg-tertiary, #f5f5f7);padding:6px 10px;border-radius:6px}.tfa-verify{display:flex;flex-direction:column;gap:8px}.tfa-code-input{display:flex;gap:8px;align-items:center;justify-content:center}.tfa-code-input input{border:1px solid var(--separator);border-radius:8px;font-family:monospace;color:var(--label)}.tfa-code-input input:focus{outline:none;border-color:var(--blue);box-shadow:0 0 0 2px #007aff1f}.tfa-error{font-size:12px;color:var(--red, #FF3B30);text-align:center}.tfa-btn{display:inline-flex;align-items:center;gap:6px;justify-content:center;padding:8px 16px;font-size:13px;font-weight:500;border:1px solid var(--separator);border-radius:8px;background:var(--surface-solid, #fff);color:var(--label-3);cursor:pointer}.tfa-btn:hover{background:var(--bg-hover, rgba(0,0,0,.04))}.tfa-btn.primary{background:var(--blue, #007AFF);color:#fff;border-color:var(--blue)}.tfa-btn.primary:hover{filter:brightness(1.05)}.tfa-btn.primary:disabled{opacity:.5}.tfa-btn.danger{color:var(--red, #FF3B30);border-color:#ff3b304d}.tfa-btn.danger:hover{background:#ff3b3014}.mobile-hamburger{display:none!important}.mobile-overlay{display:none}@media(max-width:1024px){.sidebar{width:56px}.sidebar .sidebar-logo,.sidebar .nav-sub,.sidebar .nav-chevron{display:none}.sidebar .sidebar-logo-icon{display:block}.sidebar .nav-item{justify-content:center;padding:10px 0}.sidebar .nav-icon{margin:0}.content{padding:16px}.kpi-grid{grid-template-columns:repeat(3,1fr)}.dash-grid>.dash-card:nth-child(2),.dash-grid>.dash-card:nth-child(3){grid-column:span 6}}@media(max-width:768px){.sidebar{position:fixed;left:-280px;top:0;bottom:0;width:280px;z-index:10000;transition:left .25s ease;overflow-y:auto}.sidebar.mobile-open{left:0}.sidebar.collapsed{width:280px;left:-280px}.sidebar.collapsed.mobile-open{left:0}.sidebar .sidebar-logo{display:block}.sidebar .sidebar-logo-icon{display:none}.sidebar .nav-item{justify-content:flex-start;padding:12px 16px}.sidebar .nav-sub,.sidebar .nav-chevron{display:block}.sidebar .sidebar-toggle{display:none}.mobile-overlay{display:block;position:fixed;inset:0;background:#0006;z-index:9999}.mobile-hamburger{display:flex!important}.top-bar{padding:0 8px}.top-bar-tabs{overflow-x:auto;flex-shrink:1;min-width:0}.top-bar-tabs::-webkit-scrollbar{display:none}.tab-item{white-space:nowrap;padding:0 10px;font-size:12px}.top-user-name,.top-separator{display:none}.top-panel-search,.top-panel-dispo,.top-panel-notifs{left:8px;right:8px;width:auto}.main{min-width:0}.content{padding:12px;gap:12px}.kpi-grid{grid-template-columns:repeat(2,1fr);gap:8px}.dash-grid>.dash-card{grid-column:span 12!important}.kpi{padding:12px}.kpi-val{font-size:18px}.page-header{flex-direction:column;gap:8px;align-items:flex-start}.table-wrap{overflow-x:auto;-webkit-overflow-scrolling:touch}.table{min-width:600px}.proj-bar{flex-wrap:wrap;gap:4px;padding:8px 12px}.proj-bar-name{font-size:14px;max-width:200px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.proj-tabs{overflow-x:auto;flex-wrap:nowrap;-webkit-overflow-scrolling:touch}.proj-tabs::-webkit-scrollbar{display:none}.fin-two-cols,.admin-grid-2,.form-grid,.infos-grid{grid-template-columns:1fr}.fin-header-bar{flex-direction:column;gap:12px;align-items:flex-start}.fin-header-circles{flex-wrap:wrap}.modal,.catalogue-modal,.edit-modal,.share-modal,.preview-modal{max-width:100vw;width:100vw;max-height:100vh;height:100vh;border-radius:0;margin:0}.modal-overlay{align-items:flex-end}.documents-grid{grid-template-columns:repeat(2,1fr)}.documents-layout{flex-direction:column}.documents-sidebar{width:100%;min-width:0;border-right:none;border-bottom:1px solid var(--separator)}.proj-tabs{gap:0;padding:0 8px}.proj-tabs button{padding:8px 12px;font-size:12px;white-space:nowrap}.grid-2{grid-template-columns:1fr!important}.fiche-general-layout{flex-direction:column!important}.fiche-general-layout>*{width:100%!important;min-width:0!important}.mini-calendar{display:none}.mat-layout{flex-direction:column}.mat-layout .mat-sidebar{display:none}.mat-layout .mat-main{width:100%}.planning-container{overflow-x:auto;-webkit-overflow-scrolling:touch}.fin-header-bar{padding:12px}.calcul-layout{grid-template-columns:1fr}.calcul-left{border-right:none;border-bottom:1px solid var(--separator)}.editor-body{font-size:12px}.lignes-table{font-size:11px;min-width:500px}.editor-header{flex-wrap:wrap;gap:6px}.editor-header-actions{flex-wrap:wrap}.apercu-financier{font-size:12px}.ap-table{min-width:400px}.btn,.btn-primary,.btn-secondary,.btn-add,.card-action-btn,.icon-btn{min-height:44px}.mobile-card-list{display:flex;flex-direction:column;gap:8px}.mobile-card{background:var(--surface-solid, #fff);border:1px solid var(--separator);border-radius:10px;padding:14px 16px;cursor:pointer;transition:border-color .15s}.mobile-card:active{border-color:var(--blue)}.mobile-card-top{display:flex;justify-content:space-between;align-items:center;margin-bottom:6px}.mobile-card-title{font-size:15px;font-weight:600;color:var(--label)}.mobile-card-details{display:flex;flex-wrap:wrap;gap:8px;font-size:12px;color:var(--label-3)}.toolbar-bar .icon-btn[title=Colonnes]{display:none}.login-card,.signup-card{width:100%;max-width:100%;border-radius:0;min-height:100vh;padding:24px 20px}.reglages-layout{flex-direction:column}.reglages-sidebar{width:100%;border-right:none;border-bottom:1px solid var(--separator);flex-direction:row;overflow-x:auto}.reglages-content{padding:12px}@media(hover:none){.nav-item:hover{background:none}.doc-card:hover,.devis-card:hover{border-color:var(--separator);box-shadow:none}.mobile-card:hover{border-color:var(--separator)}}}.tab-historique{padding:20px;max-width:800px}.audit-filters{display:flex;align-items:center;gap:6px;padding-bottom:16px;border-bottom:1px solid var(--separator);margin-bottom:20px;flex-wrap:wrap}.audit-filter-pill{padding:4px 10px;border-radius:12px;font-size:12px;border:1px solid var(--separator);background:var(--surface-solid);color:var(--label-secondary);cursor:pointer;transition:all .15s}.audit-filter-pill:hover{border-color:var(--blue);color:var(--blue)}.audit-filter-pill.active{background:var(--blue);color:#fff;border-color:var(--blue)}.audit-loading,.audit-empty{text-align:center;padding:60px 20px;color:var(--label-tertiary)}.audit-empty svg{margin-bottom:12px;opacity:.3}.audit-timeline{position:relative}.audit-entry{position:relative;display:flex;gap:12px;padding:12px 0 12px 8px}.audit-entry-line{position:absolute;left:20px;top:36px;bottom:-12px;width:1px;background:var(--separator)}.audit-entry:last-child .audit-entry-line{display:none}.audit-entry-icon{flex-shrink:0;width:28px;height:28px;border-radius:50%;display:flex;align-items:center;justify-content:center}.audit-entry-content{flex:1;min-width:0}.audit-entry-header{display:flex;align-items:flex-start;gap:8px}.audit-entry-avatar{flex-shrink:0;width:24px;height:24px;border-radius:50%;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;font-size:9px;font-weight:600;display:flex;align-items:center;justify-content:center}.audit-entry-info{flex:1;min-width:0;line-height:1.4}.audit-entry-user{font-weight:500;font-size:13px;color:var(--label);margin-right:6px}.audit-entry-summary{font-size:13px;color:var(--label-secondary)}.audit-entry-time{flex-shrink:0;font-size:11px;color:var(--label-tertiary);white-space:nowrap;margin-top:2px}.audit-entry-toggle{display:inline-flex;align-items:center;gap:4px;font-size:11px;color:var(--blue);cursor:pointer;border:none;background:none;padding:4px 0;margin-top:4px}.audit-entry-toggle:hover{text-decoration:underline}.audit-changes{margin-top:8px;padding:8px 12px;background:var(--bg-secondary, #f5f5f7);border-radius:8px;font-size:12px;font-family:SF Mono,monospace}.audit-change-row{display:flex;align-items:center;gap:8px;padding:3px 0;border-bottom:1px solid var(--separator)}.audit-change-row:last-child{border-bottom:none}.audit-change-field{font-weight:500;color:var(--label-secondary);min-width:120px}.audit-change-old{color:#ff3b30;text-decoration:line-through}.audit-change-arrow{color:var(--label-tertiary)}.audit-change-new{color:#34c759;font-weight:500}.audit-pagination{display:flex;align-items:center;justify-content:center;gap:12px;padding:16px 0;margin-top:12px;border-top:1px solid var(--separator);font-size:13px;color:var(--label-secondary)}.audit-pagination button{padding:6px 12px;border-radius:6px;border:1px solid var(--separator);background:var(--surface-solid);font-size:12px;cursor:pointer}.audit-pagination button:disabled{opacity:.4;cursor:default}.audit-pagination button:not(:disabled):hover{border-color:var(--blue);color:var(--blue)}.agenda-page{display:flex;flex-direction:column;height:100%;background:var(--surface-solid);overflow:hidden}.agenda-toolbar{display:flex;align-items:center;justify-content:space-between;padding:12px 20px;border-bottom:1px solid var(--separator);gap:12px;flex-shrink:0;flex-wrap:wrap}.agenda-toolbar-left{display:flex;align-items:center;gap:8px}.agenda-toolbar-right{display:flex;align-items:center;gap:12px}.agenda-title{font-size:17px;font-weight:600;color:var(--label);margin:0;text-transform:capitalize}.agenda-btn{padding:6px 14px;border-radius:6px;border:1px solid var(--separator);background:var(--surface-solid);font-size:13px;cursor:pointer;color:var(--label);transition:all .15s}.agenda-btn:hover{border-color:var(--blue);color:var(--blue)}.agenda-btn.icon{padding:6px 8px}.agenda-toggle{display:flex;align-items:center;gap:6px;font-size:12px;color:var(--label-secondary);cursor:pointer}.agenda-toggle input{accent-color:var(--blue)}.agenda-view-btns{display:flex;gap:0}.agenda-view-btn{display:flex;align-items:center;gap:4px;padding:6px 12px;border:1px solid var(--separator);background:var(--surface-solid);font-size:12px;cursor:pointer;color:var(--label-secondary);transition:all .15s}.agenda-view-btn:first-child{border-radius:6px 0 0 6px}.agenda-view-btn:last-child{border-radius:0 6px 6px 0}.agenda-view-btn:not(:first-child){margin-left:-1px}.agenda-view-btn.active{background:var(--blue);color:#fff;border-color:var(--blue);z-index:1}.agenda-view-btn:not(.active):hover{border-color:var(--blue);color:var(--blue)}.agenda-calendar{flex:1;min-height:0;padding:0 20px 20px;overflow:hidden}.agenda-calendar .fc{font-family:-apple-system,BlinkMacSystemFont,SF Pro Text,system-ui,sans-serif;font-size:12px;height:100%}.agenda-calendar .fc .fc-scrollgrid{border-color:var(--separator)}.agenda-calendar .fc th{font-weight:500;color:var(--label-secondary);font-size:11px;text-transform:uppercase}.agenda-calendar .fc td{border-color:var(--separator)}.agenda-calendar .fc .fc-daygrid-day-number{font-size:13px;color:var(--label);padding:4px 8px}.agenda-calendar .fc .fc-day-today{background:#007aff0a!important}.agenda-calendar .fc .fc-day-today .fc-daygrid-day-number{color:var(--blue);font-weight:600}.agenda-calendar .fc .fc-event{border:none;border-radius:4px;padding:1px 4px;font-size:11px;cursor:pointer}.agenda-calendar .fc .fc-event:hover{filter:brightness(.9)}.agenda-calendar .fc .fc-daygrid-more-link{font-size:11px;color:var(--blue)}.agenda-calendar .fc .fc-col-header-cell{padding:8px 0}.agenda-calendar .fc .fc-week-number{font-size:10px;color:var(--label-tertiary)}.agenda-calendar .fc .fc-timegrid-slot{height:40px}.agenda-calendar .fc .fc-timegrid-slot-label{font-size:11px;color:var(--label-tertiary)}.agenda-calendar .fc .fc-list-event-title{font-size:13px}.agenda-calendar .fc .fc-list-day-cushion{background:var(--bg-secondary, #f5f5f7);font-size:12px;font-weight:600}.agenda-calendar .fc .fc-button{display:none}.custom-fields-section{margin-top:20px;padding:16px;background:var(--surface-solid);border-radius:10px;border:1px solid var(--separator)}.custom-fields-title{display:flex;align-items:center;gap:6px;font-size:13px;font-weight:600;color:var(--label-secondary);text-transform:uppercase;letter-spacing:.5px;margin:0 0 12px}.custom-fields-grid{display:grid;grid-template-columns:1fr 1fr;gap:12px}.custom-field-item{display:flex;flex-direction:column;gap:4px}.custom-field-label{font-size:11px;font-weight:500;color:var(--label-secondary);text-transform:uppercase;letter-spacing:.3px}.required-star{color:#ff3b30;margin-left:2px}.custom-field-help{font-size:11px;color:var(--label-tertiary);margin-top:-2px}.custom-field-input{padding:7px 10px;border-radius:6px;border:1px solid var(--separator);background:var(--surface-solid);font-size:13px;color:var(--label);width:100%;font-family:inherit;transition:border-color .15s}.custom-field-input:focus{border-color:var(--blue);outline:none}textarea.custom-field-input{resize:vertical}select.custom-field-input{cursor:pointer}.custom-field-color{width:40px;height:32px;padding:2px;cursor:pointer;border-radius:6px;border:1px solid var(--separator)}.custom-field-checkbox{display:flex;align-items:center;gap:6px;font-size:13px;cursor:pointer}.custom-field-checkbox input{accent-color:var(--blue)}.custom-field-multiselect{display:flex;flex-wrap:wrap;gap:8px}.custom-field-checkbox-item{display:flex;align-items:center;gap:4px;font-size:12px;cursor:pointer}.custom-field-checkbox-item input{accent-color:var(--blue)}.help-tooltip-wrapper{position:relative;display:inline-flex;align-items:center;cursor:help;vertical-align:middle;margin-left:4px}.help-tooltip-icon{color:var(--label-tertiary);opacity:.5;transition:opacity .15s}.help-tooltip-wrapper:hover .help-tooltip-icon{opacity:1;color:var(--blue)}.help-tooltip-bubble{position:absolute;z-index:9999;background:#1e293b;color:#fff;font-size:12px;line-height:1.5;padding:8px 12px;border-radius:8px;max-width:280px;min-width:160px;box-shadow:0 4px 12px #00000026;pointer-events:none;animation:fadeIn .15s ease}.help-tooltip-top{bottom:calc(100% + 8px);left:50%;transform:translate(-50%)}.help-tooltip-bottom{top:calc(100% + 8px);left:50%;transform:translate(-50%)}.help-tooltip-right{left:calc(100% + 8px);top:50%;transform:translateY(-50%)}.help-tooltip-left{right:calc(100% + 8px);top:50%;transform:translateY(-50%)}.help-tooltip-arrow{position:absolute;width:8px;height:8px;background:#1e293b;transform:rotate(45deg)}.help-tooltip-top .help-tooltip-arrow{bottom:-4px;left:50%;margin-left:-4px}.help-tooltip-bottom .help-tooltip-arrow{top:-4px;left:50%;margin-left:-4px}.help-tooltip-right .help-tooltip-arrow{left:-4px;top:50%;margin-top:-4px}.help-tooltip-left .help-tooltip-arrow{right:-4px;top:50%;margin-top:-4px}.aide-page{padding:24px 32px;max-width:900px;margin:0 auto;width:100%}.aide-header{display:flex;align-items:center;gap:10px;margin-bottom:20px}.aide-header h1{font-size:22px;font-weight:600;margin:0}.aide-search{display:flex;align-items:center;gap:8px;padding:10px 14px;border-radius:10px;border:1px solid var(--separator);background:var(--surface-solid);margin-bottom:24px}.aide-search input{flex:1;border:none;background:none;font-size:14px;color:var(--label);outline:none}.aide-search svg{color:var(--label-tertiary);flex-shrink:0}.aide-section{margin-bottom:4px}.aide-section-header{display:flex;align-items:center;gap:10px;width:100%;padding:12px 14px;border-radius:8px;border:none;background:var(--surface-solid);font-size:15px;font-weight:600;color:var(--label);cursor:pointer;transition:background .15s}.aide-section-header:hover{background:var(--bg-secondary, #f5f5f7)}.aide-section-count{margin-left:auto;font-size:11px;font-weight:400;color:var(--label-tertiary);background:var(--bg-secondary, #f0f0f0);padding:1px 6px;border-radius:8px}.aide-section-header svg:last-child{margin-left:4px;color:var(--label-tertiary)}.aide-section-items{padding:4px 0 8px 28px}.aide-item{border-bottom:1px solid var(--separator)}.aide-item:last-child{border-bottom:none}.aide-item-header{display:flex;align-items:center;gap:6px;width:100%;padding:10px 8px;border:none;background:none;font-size:13px;font-weight:500;color:var(--label);cursor:pointer}.aide-item-header:hover{color:var(--blue)}.aide-item-content{padding:4px 8px 12px 24px;font-size:13px;line-height:1.6;color:var(--label-secondary)}.stats-page{padding:24px;overflow-y:auto;height:100%}.stats-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:20px}.stats-header h1{display:flex;align-items:center;gap:8px;font-size:20px;font-weight:600;margin:0}.stats-year-select{padding:6px 12px;border-radius:6px;border:1px solid var(--separator);font-size:13px;background:var(--surface-solid);cursor:pointer}.stats-grid{display:grid;grid-template-columns:1fr 1fr;gap:16px}.stats-card{background:var(--surface-solid);border-radius:12px;border:1px solid var(--separator);padding:16px}.stats-card h3{display:flex;align-items:center;gap:6px;font-size:14px;font-weight:600;margin:0 0 12px;color:var(--label)}.stats-wide{grid-column:span 2}.stats-list{display:flex;flex-direction:column;gap:2px}.stats-list-row{display:flex;align-items:center;gap:8px;padding:6px 8px;border-radius:6px;font-size:13px}.stats-list-row:nth-child(odd){background:var(--bg-secondary, #f8f8fa)}.stats-rank{width:22px;height:22px;border-radius:50%;background:var(--bg-secondary, #eee);text-align:center;line-height:22px;font-size:11px;font-weight:600;flex-shrink:0}.stats-name{flex:1;color:var(--label)}.stats-value{font-weight:500;color:var(--blue);white-space:nowrap}
