:root{--color-primary:#b1241a;--color-primary-bright:#e74c3c;--color-primary-dim:#d43e30;--color-on-primary:#fff;--color-froid:#006497;--color-froid-light:#77c2ff;--color-chauffage:#f39c12;--color-chauffage-dim:#a46700;--color-economies:#27ae60;--color-bg:#ececec;--color-surface:#fff;--color-nav:#1a1a1a;--color-surface-low:#f6f3f2;--color-surface-high:#eae7e7;--color-text:#1c1b1b;--color-text-muted:#5a413d;--color-text-faint:#8e706b;--color-border:#dedede;--color-border-strong:#e2beb9;--shadow-card:0px 4px 12px #0000000d;--shadow-card-hover:0px 8px 24px #0000001a;--color-badge-ok-bg:#dcfce7;--color-badge-ok-text:#166534;--color-badge-warn-bg:#fef9c3;--color-badge-warn-text:#854d0e;--color-error-bg:#fef2f2;--color-error-border:#fecaca;--color-error-text:#991b1b;--color-eco-pos:#16a34a;--color-eco-pos-bg:#16a34a12;--color-eco-neg-bg:#b1241a12;--color-pill-active-bg:#fef2f2;--color-focus-ring:#b1241a1f;--color-action-ok:#16a34a;--color-action-ok-hover:#15803d;--color-warn-bg:#fff7ed;--color-warn-border:#fed7aa;--color-warn-text:#92400e;--color-row-update-bg:#fffbeb;--color-row-update-hover:#fef3c7;--radius-sm:4px;--radius-md:8px;--radius-full:9999px;--space-2xs:4px;--space-xs:8px;--space-sm:12px;--space-md:16px;--space-lg:24px;--space-xl:32px;--space-xxl:48px;--space-container:24px;--font:"Inter", sans-serif;--font-mono:ui-monospace, "Cascadia Code", "JetBrains Mono", monospace;--text-xs:12px;--text-sm:14px;--text-md:16px;--text-lg:18px;--text-xl:24px;--text-2xl:36px;--leading-tight:1.2;--leading-snug:1.375;--leading-normal:1.5;--leading-relaxed:1.625;--fw-normal:400;--fw-medium:500;--fw-semibold:600;--fw-bold:700;--duration-fast:.1s;--duration-base:.15s;--duration-slow:.25s}[data-theme=dark]{--color-bg:#111113;--color-surface:#1e1e22;--color-surface-low:#17171a;--color-surface-high:#2a2a30;--color-text:#ede9e8;--color-text-muted:#a89490;--color-text-faint:#6b605d;--color-border:#2b2b30;--color-border-strong:#3b2f2d;--shadow-card:0px 4px 12px #0006;--shadow-card-hover:0px 8px 24px #0009;--color-primary:#e8433a;--color-primary-bright:#ff6155;--color-primary-dim:#e8433a;--color-froid:#4aacde;--color-froid-light:#93d4f3;--color-chauffage:#f5a623;--color-economies:#34c974;--color-badge-ok-bg:#34c97426;--color-badge-ok-text:#86efac;--color-badge-warn-bg:#f5a62326;--color-badge-warn-text:#fcd34d;--color-error-bg:#e8433a1f;--color-error-border:#e8433a4d;--color-error-text:#fca5a5;--color-eco-pos:#34c974;--color-eco-pos-bg:#34c9741a;--color-eco-neg-bg:#e8433a1a;--color-pill-active-bg:#e8433a1f;--color-focus-ring:#e8433a33;--color-action-ok:#22c55e;--color-action-ok-hover:#16a34a;--color-warn-bg:#f59e0b1a;--color-warn-border:#f59e0b40;--color-warn-text:#fcd34d;--color-row-update-bg:#f59e0b14;--color-row-update-hover:#f59e0b26}.material-symbols-outlined{font-variation-settings:"FILL" 0, "wght" 400, "GRAD" 0, "opsz" 24;vertical-align:middle;-webkit-user-select:none;user-select:none}*,:before,:after{box-sizing:border-box;margin:0;padding:0}html{font-size:16px}body{font-family:var(--font);font-size:var(--text-sm);color:var(--color-text);background:var(--color-bg);-webkit-font-smoothing:antialiased;line-height:1.5}a{color:inherit;text-decoration:none}button{font-family:var(--font);cursor:pointer;background:0 0;border:none}:focus{outline:none}:focus-visible{outline:2px solid var(--color-primary);outline-offset:2px}input:focus-visible,select:focus-visible,textarea:focus-visible{outline:none}table tbody tr td{transition:background var(--duration-base)}#root{flex-direction:column;min-height:100vh;display:flex}.page-content{padding:var(--space-lg);flex:1;width:100%;max-width:1600px;margin:0 auto}.sp-backdrop{-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px);z-index:200;background:#0006;animation:.18s sp-fade-in;position:fixed;inset:0}@keyframes sp-fade-in{0%{opacity:0}to{opacity:1}}.sp-panel{background:var(--color-surface);border-left:1px solid var(--color-border);z-index:201;flex-direction:column;width:300px;transition:transform .24s cubic-bezier(.4,0,.2,1);display:flex;position:fixed;top:0;bottom:0;right:0;transform:translate(100%);box-shadow:-6px 0 32px #0000002e}.sp-panel--open{transform:translate(0)}.sp-header{padding:var(--space-md) var(--space-lg);border-bottom:1px solid var(--color-border);flex-shrink:0;justify-content:space-between;align-items:center;display:flex}.sp-header-title{font-size:var(--text-md);color:var(--color-text);font-weight:600}.sp-close{border-radius:var(--radius-sm);width:32px;height:32px;color:var(--color-text-faint);cursor:pointer;background:0 0;border:none;justify-content:center;align-items:center;transition:background .12s,color .12s;display:flex}.sp-close:hover{background:var(--color-surface-high);color:var(--color-text-muted)}.sp-close .material-symbols-outlined{font-size:20px}.sp-body{padding:var(--space-md) var(--space-lg);gap:var(--space-xl);flex-direction:column;flex:1;display:flex;overflow-y:auto}.sp-section{gap:var(--space-sm);flex-direction:column;display:flex}.sp-section-label{font-size:var(--text-xs);letter-spacing:.07em;text-transform:uppercase;color:var(--color-text-faint);font-weight:700}.sp-theme-row{gap:var(--space-sm);display:flex}.sp-theme-btn{padding:var(--space-sm) var(--space-xs);border-radius:var(--radius-md);border:1px solid var(--color-border);background:var(--color-surface-low);color:var(--color-text-muted);cursor:pointer;font-family:var(--font);flex-direction:column;flex:1;align-items:center;gap:6px;transition:background .15s,border-color .15s,color .15s;display:flex}.sp-theme-btn:hover{background:var(--color-surface-high);border-color:var(--color-border-strong);color:var(--color-text)}.sp-theme-btn--active{background:var(--color-pill-active-bg);border-color:var(--color-primary);color:var(--color-primary)}.sp-theme-icon{font-size:22px!important}.sp-theme-label{font-size:var(--text-xs);font-weight:600}.sp-about{padding:var(--space-sm) var(--space-lg);border-top:1px solid var(--color-border);flex-shrink:0;justify-content:space-between;align-items:center;display:flex}.sp-about-btn{font-family:var(--font);font-size:var(--text-sm);color:var(--color-text-muted);cursor:pointer;border-radius:var(--radius-sm);background:0 0;border:none;align-items:center;gap:6px;padding:6px 8px;font-weight:500;transition:background .12s,color .12s;display:flex}.sp-about-btn:hover{background:var(--color-surface-high);color:var(--color-text)}.sp-about-btn .material-symbols-outlined{font-size:18px}.sp-about-version{font-size:var(--text-xs);color:var(--color-text-faint);font-weight:500}.sp-section--soon .sp-section-label{opacity:.55}.sp-soon{font-size:var(--text-sm);color:var(--color-text-faint);font-style:italic}.navbar{background:var(--color-nav);color:#fff;width:100%;height:64px;padding:0 var(--space-lg);z-index:50;flex-shrink:0;justify-content:space-between;align-items:center;display:flex;position:sticky;top:0}.navbar-brand{align-items:center;gap:var(--space-sm);color:#fff;flex-shrink:0;text-decoration:none;display:flex}.navbar-logo{object-fit:contain;border-radius:var(--radius-sm);background:#fff;width:auto;height:36px;padding:3px 6px}.navbar-app-name{font-size:var(--text-sm);letter-spacing:.01em;white-space:nowrap;font-weight:600}.navbar-links{align-items:center;gap:var(--space-xs);display:flex}.navbar-link{color:#ffffffbf;font-size:var(--text-sm);padding:6px var(--space-md);border-radius:var(--radius-full);white-space:nowrap;transition:color .15s,background .15s}.navbar-link:hover{color:#fff;background:#ffffff1a}.navbar-link:focus-visible{color:#fff;background:#ffffff26;outline:none;box-shadow:0 0 0 2px #ffffff80}.navbar-link--active{color:#fff;background:#ffffff1f}.navbar-actions{align-items:center;gap:var(--space-xs);flex-shrink:0;display:flex}.navbar-icon-btn{color:#ffffffbf;border-radius:var(--radius-full);justify-content:center;align-items:center;width:36px;height:36px;font-size:22px;transition:color .15s,background .15s;display:flex}.navbar-icon-btn:hover{color:#fff;background:#ffffff1a}.navbar-icon-btn:focus-visible{color:#fff;background:#ffffff1a;outline:none;box-shadow:0 0 0 2px #ffffff80}.navbar-user-menu{margin-left:var(--space-xs);position:relative}.navbar-avatar{border-radius:var(--radius-full);background:var(--color-primary);width:32px;height:32px;color:var(--color-on-primary);font-size:var(--text-xs);letter-spacing:.03em;cursor:pointer;justify-content:center;align-items:center;font-weight:700;transition:filter .15s;display:flex}.navbar-avatar:hover{filter:brightness(1.15)}.navbar-avatar:focus-visible{outline:none;box-shadow:0 0 0 3px #ffffff80}.navbar-dropdown{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-md);box-shadow:var(--shadow-card-hover);z-index:100;min-width:220px;position:absolute;top:calc(100% + 8px);right:0;overflow:hidden}.navbar-dropdown-info{padding:var(--space-md)}.navbar-dropdown-email{font-size:var(--text-sm);color:var(--color-text);white-space:nowrap;text-overflow:ellipsis;font-weight:500;overflow:hidden}.navbar-dropdown-role{font-size:var(--text-xs);color:var(--color-text-faint);margin-top:2px}.navbar-dropdown-divider{background:var(--color-surface-high);height:1px}.navbar-dropdown-logout{align-items:center;gap:var(--space-sm);width:100%;padding:var(--space-md);font-family:var(--font);font-size:var(--text-sm);color:var(--color-primary);transition:background .15s;display:flex}.navbar-dropdown-logout:hover{background:#fef2f2}.navbar-dropdown-logout .material-symbols-outlined{font-size:18px}@media (width<=768px){.navbar-links,.navbar-app-name{display:none}}.app-footer{background:var(--color-nav);padding:14px var(--space-lg);border-top:1px solid #ffffff0f;margin-top:auto}.app-footer-inner{justify-content:center;align-items:center;gap:var(--space-sm);font-family:var(--font);font-size:var(--text-xs);color:#ffffff61;letter-spacing:.01em;flex-wrap:wrap;display:flex}.app-footer-brand{color:#ffffff8c;font-weight:600}.app-footer-sep{color:#ffffff2e;font-size:10px}.app-footer-copy,.app-footer-version,.app-footer-dev{color:#ffffff61}.login-page{grid-template-columns:1fr 1fr;min-height:100vh;display:grid}.login-brand{padding:var(--space-xxl) var(--space-xl);background:radial-gradient(at 18% 82%,#b1241a24 0%,#0000 52%),radial-gradient(at 82% 15%,#00649714 0%,#0000 48%),#1a1a1a;justify-content:center;align-items:center;display:flex;position:relative;overflow:hidden}.login-brand:before{content:"";background:var(--color-primary);height:3px;position:absolute;top:0;left:0;right:0}.login-brand-inner{gap:var(--space-xl);flex-direction:column;width:100%;max-width:380px;display:flex}.login-brand-logo-wrap{display:inline-flex}.login-brand-logo{object-fit:contain;width:auto;height:52px}.login-brand-copy{gap:var(--space-sm);flex-direction:column;display:flex}.login-brand-eyebrow{font-size:var(--text-xs);letter-spacing:.1em;text-transform:uppercase;color:#ffffff61;font-weight:600}.login-brand-headline{color:#fff;letter-spacing:-.02em;margin:0;font-size:38px;font-weight:700;line-height:1.15}.login-brand-tagline{font-size:var(--text-sm);color:#ffffff7a;line-height:var(--leading-relaxed);margin-top:var(--space-xs);max-width:320px}.login-brand-deco{gap:var(--space-sm);padding-top:var(--space-lg);border-top:1px solid #ffffff12;flex-direction:column;display:flex}.login-deco-item{align-items:center;gap:var(--space-sm);letter-spacing:.07em;text-transform:uppercase;color:#ffffff4d;font-size:11px;font-weight:500;display:flex}.login-deco-bar{border-radius:var(--radius-full);flex-shrink:0;height:3px}.login-deco-bar--froid{background:#006497;width:40px}.login-deco-bar--chauffage{background:#f39c12;width:28px}.login-deco-bar--eco{background:#27ae60;width:52px}.login-panel{background:var(--color-surface);border-left:1px solid var(--color-border);padding:var(--space-xl);justify-content:center;align-items:center;display:flex}.login-panel-inner{gap:var(--space-lg);flex-direction:column;width:100%;max-width:380px;display:flex}.login-mobile-logo{justify-content:center;display:none}.login-mobile-logo img{width:auto;height:44px;padding:var(--space-xs) var(--space-md);background:var(--color-nav);border-radius:var(--radius-sm)}.login-form-header{flex-direction:column;gap:5px;display:flex}.login-form-title{font-size:var(--text-xl);color:var(--color-text);letter-spacing:-.01em;font-weight:700;line-height:var(--leading-tight);margin:0}.login-form-subtitle{font-size:var(--text-sm);color:var(--color-text-muted);margin:0}.login-error{background:var(--color-error-bg);border:1px solid var(--color-error-border);border-left:3px solid var(--color-primary);border-radius:var(--radius-sm);color:var(--color-error-text);font-size:var(--text-sm);padding:var(--space-sm) var(--space-md);align-items:flex-start;gap:var(--space-xs);font-weight:500;animation:.42s cubic-bezier(.36,.07,.19,.97) login-shake;display:flex}.login-error .material-symbols-outlined{color:var(--color-primary);flex-shrink:0;margin-top:1px;font-size:17px}@keyframes login-shake{10%,90%{transform:translate(-2px)}20%,80%{transform:translate(4px)}30%,70%{transform:translate(-5px)}40%,60%{transform:translate(5px)}50%{transform:translate(-3px)}}.login-form{gap:var(--space-md);flex-direction:column;display:flex}.form-group{flex-direction:column;gap:6px;display:flex}.form-label{font-size:var(--text-xs);letter-spacing:.05em;text-transform:uppercase;color:var(--color-text-faint);font-weight:600}.form-input-wrap{position:relative}.form-input{border:1px solid var(--color-border-strong);border-radius:var(--radius-sm);width:100%;padding:11px var(--space-md);font-family:var(--font);font-size:var(--text-sm);color:var(--color-text);background:var(--color-surface);transition:border-color var(--duration-base), box-shadow var(--duration-base);box-sizing:border-box;outline:none}.form-input-wrap .form-input{padding-right:44px}.form-input:focus{border-color:var(--color-primary);box-shadow:0 0 0 3px var(--color-focus-ring)}.form-input:disabled{background:var(--color-surface-low);color:var(--color-text-faint);cursor:not-allowed}.form-input-toggle{color:var(--color-text-faint);border-radius:var(--radius-sm);transition:color var(--duration-base);align-items:center;padding:3px;display:flex;position:absolute;top:50%;right:10px;transform:translateY(-50%)}.form-input-toggle:hover{color:var(--color-text-muted)}.form-input-toggle .material-symbols-outlined{font-size:18px}.login-submit{background:var(--color-primary);width:100%;color:var(--color-on-primary);font-family:var(--font);font-size:var(--text-sm);padding:13px var(--space-md);border-radius:var(--radius-sm);justify-content:center;align-items:center;gap:var(--space-xs);transition:filter var(--duration-base), box-shadow var(--duration-base);margin-top:var(--space-xs);font-weight:600;display:flex;box-shadow:0 1px 4px #0000002e}.login-submit:hover:not(:disabled){filter:brightness(1.08)}.login-submit:focus-visible{box-shadow:0 0 0 3px var(--color-focus-ring), 0 1px 4px #0000001f;outline:none}.login-submit:disabled{opacity:.5;cursor:not-allowed;filter:none}.login-submit .material-symbols-outlined{font-size:18px}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.login-footer{font-size:var(--text-xs);color:var(--color-text-faint);text-align:center;margin-top:var(--space-xs)}[data-theme=dark] .form-input{background:var(--color-surface-low)}@media (width<=768px){.login-page{grid-template-columns:1fr}.login-brand{display:none}.login-mobile-logo{display:flex}.login-panel{min-height:100vh;padding:var(--space-xl) var(--space-lg);background:var(--color-bg);border-left:none}.login-panel-inner{max-width:420px}}@media (width<=480px){.login-panel{padding:var(--space-xxl) var(--space-md) var(--space-lg);align-items:flex-start}}@media (width>=1400px){.login-page{grid-template-columns:520px 1fr}}.cat-chip--fixed{cursor:default;pointer-events:none}.cat-chip--froid{background:#e8f4fa;border-color:#006497}.cat-chip--froid .cat-chip-icon{color:#006497}.cat-chip--chauffage{background:#fef9ec;border-color:#f39c12}.cat-chip--chauffage .cat-chip-icon{color:#f39c12}.cat-chip--economies{background:#edfaf3;border-color:#27ae60}.cat-chip--economies .cat-chip-icon{color:#27ae60}.dash-header-hint{font-size:var(--text-sm);color:var(--color-text-faint);margin-top:var(--space-xs)}.cat-body{gap:var(--space-md);flex-direction:column;display:flex}.cat-inline-error{align-items:center;gap:var(--space-xs);border-radius:var(--radius-sm);color:var(--color-primary);font-size:var(--text-sm);padding:var(--space-sm) var(--space-md);background:#fef2f2;border:1px solid #fecaca;display:flex}.cat-inline-error .material-symbols-outlined{flex-shrink:0;font-size:16px}.cat-inline-error-close{color:var(--color-primary);opacity:.7;margin-left:auto;display:flex}.cat-inline-error-close .material-symbols-outlined{font-size:16px}.cat-chips-row{gap:var(--space-sm);flex-wrap:wrap;align-items:center;display:flex}.cat-chip-wrap{display:contents}.cat-chip{background:var(--color-surface-low);border:1px solid var(--color-border);border-radius:var(--radius-full);padding:6px var(--space-sm);font-size:var(--text-sm);align-items:center;gap:6px;transition:border-color .15s;display:inline-flex}.cat-chip:hover{border-color:var(--color-border-strong)}.cat-chip--editing,.cat-chip--new{background:var(--color-surface);border-color:var(--color-primary);border-radius:var(--radius-sm);box-shadow:0 0 0 2px #b1241a14}.cat-chip--confirm{border-radius:var(--radius-sm);background:#fff7ed;border-color:#fed7aa}.cat-chip-icon{color:var(--color-froid);font-size:14px}.cat-chip-name{color:var(--color-text);text-overflow:ellipsis;white-space:nowrap;max-width:180px;font-weight:500;overflow:hidden}.cat-chip-count{font-size:var(--text-xs);background:var(--color-surface-high);border-radius:var(--radius-full);color:var(--color-text-faint);text-align:center;min-width:20px;padding:1px 7px;font-weight:600}.cat-chip-confirm-text{font-size:var(--text-sm);color:#92400e;max-width:320px}.cat-chip-input{font-family:var(--font);font-size:var(--text-sm);color:var(--color-text);background:0 0;border:none;outline:none;width:160px;padding:0}.cat-chip-btn{color:var(--color-text-faint);border-radius:var(--radius-full);flex-shrink:0;justify-content:center;align-items:center;width:22px;height:22px;transition:background .12s,color .12s;display:flex}.cat-chip-btn .material-symbols-outlined{font-size:15px}.cat-chip-btn:hover{background:var(--color-surface-high);color:var(--color-text)}.cat-chip-btn--save:hover{color:#166534;background:#dcfce7}.cat-chip-btn--danger,.cat-chip-btn--delete:hover{color:#991b1b;background:#fee2e2}.cat-add-btn{font-family:var(--font);font-size:var(--text-sm);color:var(--color-primary);border:1px dashed var(--color-border-strong);border-radius:var(--radius-full);padding:6px var(--space-md);align-items:center;gap:4px;font-weight:600;transition:background .15s,border-color .15s;display:inline-flex}.cat-add-btn:hover{border-color:var(--color-primary);background:#fef2f2}.cat-add-btn .material-symbols-outlined{font-size:16px}.widget-badge--warn{color:#92400e;border-radius:var(--radius-full);padding:2px var(--space-sm);font-size:var(--text-xs);letter-spacing:.04em;background:#fff7ed;border:1px solid #fed7aa;font-weight:600}.row-unassigned td{background:#fffbeb}.row-unassigned:hover td{background:#fef3c7!important}.td-assign{align-items:center;gap:var(--space-xs);min-width:200px;display:flex}.cat-assign-select{font-family:var(--font);font-size:var(--text-sm);color:var(--color-text);background:var(--color-surface);border:1px solid var(--color-border-strong);border-radius:var(--radius-sm);padding:5px var(--space-sm);cursor:pointer;outline:none;flex:1;transition:border-color .15s}.cat-assign-select--unassigned{color:var(--color-text-faint);border-style:dashed}.cat-assign-select:focus{border-color:var(--color-primary);box-shadow:0 0 0 2px #b1241a14}.cat-saving-spin{color:var(--color-text-faint);font-size:16px;animation:.8s linear infinite spin}.doublon-banner{align-items:flex-start;gap:var(--space-sm);border-radius:var(--radius-sm);color:#92400e;font-size:var(--text-sm);padding:var(--space-sm) var(--space-md);background:#fff7ed;border:1px solid #fed7aa;line-height:1.4;display:flex}.doublon-banner>.material-symbols-outlined{color:#d97706;flex-shrink:0;margin-top:1px;font-size:16px}.doublon-row-icon{color:#d97706;vertical-align:middle;cursor:help;margin-left:5px;font-size:14px!important}.doublon-overlay{z-index:200;padding:var(--space-md);background:#00000073;justify-content:center;align-items:center;display:flex;position:fixed;inset:0}.doublon-modal{background:var(--color-surface);border-radius:var(--radius-md);gap:var(--space-md);width:100%;max-width:480px;padding:var(--space-xl);flex-direction:column;display:flex;box-shadow:0 20px 60px #00000040}.doublon-modal-header{align-items:center;gap:var(--space-sm);display:flex}.doublon-modal-icon{color:#d97706;font-size:24px!important}.doublon-modal-header h3{font-size:var(--text-lg);color:var(--color-text);margin:0;font-weight:600}.doublon-modal-intro{font-size:var(--text-sm);color:var(--color-text);margin:0;line-height:1.5}.doublon-path{font-family:var(--font-mono,"Courier New", monospace);background:var(--color-surface-high);color:var(--color-text);border-radius:3px;padding:1px 5px;font-size:.82em;font-style:normal}.doublon-modal-list{padding:var(--space-sm) var(--space-md);border-radius:var(--radius-sm);background:#fff7ed;border:1px solid #fed7aa;flex-direction:column;gap:6px;margin:0;list-style:none;display:flex}.doublon-modal-list li{align-items:center;gap:var(--space-xs);font-size:var(--text-sm);color:#92400e;flex-wrap:wrap;display:flex}.doublon-rel-icon{flex-shrink:0;font-size:14px!important}.doublon-rel-label{color:var(--color-text-faint);font-size:var(--text-xs)}.doublon-modal-explain{font-size:var(--text-sm);color:var(--color-text-faint);margin:0;line-height:1.5}.doublon-modal-actions{gap:var(--space-sm);justify-content:flex-end;display:flex}.btn-warn{font-family:var(--font);font-size:var(--text-sm);color:#fff;border-radius:var(--radius-sm);padding:var(--space-xs) var(--space-md);cursor:pointer;background:#d97706;border:none;font-weight:600;transition:background .15s}.btn-warn:hover{background:#b45309}.helptip{vertical-align:middle;flex-shrink:0;align-items:center;margin-left:5px;display:inline-flex;position:relative}.helptip-btn{border:1.5px solid var(--color-border-strong);width:15px;height:15px;color:var(--color-text-faint);font-family:var(--font);letter-spacing:0;cursor:default;-webkit-user-select:none;user-select:none;transition:border-color var(--duration-base), color var(--duration-base), background var(--duration-base);background:0 0;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;font-size:9px;font-weight:800;line-height:1;display:inline-flex}.helptip:hover .helptip-btn,.helptip:focus-within .helptip-btn{border-color:var(--color-text-muted);color:var(--color-text-muted);background:var(--color-surface-high)}.helptip-bubble{color:#ffffffe0;z-index:200;width:230px;font-family:var(--font);border-radius:var(--radius-md);word-wrap:break-word;white-space:normal;pointer-events:none;opacity:0;transition:opacity var(--duration-base);background:#1c1b1b;padding:9px 12px;font-size:12px;font-weight:400;line-height:1.55;position:absolute;box-shadow:0 4px 20px #00000047}.helptip:hover .helptip-bubble,.helptip:focus-within .helptip-bubble{opacity:1;pointer-events:auto}.helptip-bubble:after{content:"";border:5px solid #0000;position:absolute}.helptip--top .helptip-bubble{bottom:calc(100% + 8px);left:50%;transform:translate(-50%)}.helptip--top .helptip-bubble:after{border-top-color:#1c1b1b;top:100%;left:50%;transform:translate(-50%)}.helptip--bottom .helptip-bubble{top:calc(100% + 8px);left:50%;transform:translate(-50%)}.helptip--bottom .helptip-bubble:after{border-bottom-color:#1c1b1b;bottom:100%;left:50%;transform:translate(-50%)}.helptip--left .helptip-bubble{top:50%;left:auto;right:calc(100% + 8px);transform:translateY(-50%)}.helptip--left .helptip-bubble:after{border-left-color:#1c1b1b;top:50%;left:100%;transform:translateY(-50%)}.dash-fullstate{justify-content:center;align-items:center;gap:var(--space-md);min-height:400px;color:var(--color-text-muted);text-align:center;padding:var(--space-xl);flex-direction:column;display:flex}.dash-fullstate .material-symbols-outlined{color:var(--color-border-strong);font-size:48px}.dash-fullstate--error .material-symbols-outlined{color:var(--color-primary)}.dash-back-link{font-size:var(--text-sm);color:var(--color-primary);margin-top:var(--space-sm);font-weight:600;text-decoration:none}.dash-back-link:hover{text-decoration:underline}.dash-header{background:var(--color-surface);border-bottom:1px solid var(--color-border-strong);padding:var(--space-sm) var(--space-lg);flex-shrink:0}.dash-header-inner{max-width:1600px;margin:0 auto}.dash-breadcrumb{font-size:var(--text-xs);letter-spacing:.05em;text-transform:uppercase;color:var(--color-text-faint);margin-bottom:var(--space-sm);align-items:center;gap:4px;font-weight:600;display:flex}.dash-breadcrumb a{color:var(--color-primary);text-decoration:none;transition:opacity .15s}.dash-breadcrumb a:hover{opacity:.75}.dash-breadcrumb .material-symbols-outlined{font-size:14px}.dash-header-row{align-items:center;gap:var(--space-sm);flex-wrap:wrap;display:flex}.dash-site-name{font-size:var(--text-2xl);letter-spacing:-.02em;color:var(--color-text);font-weight:700;line-height:var(--leading-tight)}.dash-badge-actif{font-size:var(--text-xs);letter-spacing:.05em;text-transform:uppercase;padding:3px var(--space-sm);border-radius:var(--radius-full);background:var(--color-badge-ok-bg);color:var(--color-badge-ok-text);white-space:nowrap;font-weight:600}.dash-config-link{font-size:var(--text-xs);letter-spacing:.04em;text-transform:uppercase;color:var(--color-text-faint);border:1px solid var(--color-border);border-radius:var(--radius-sm);padding:4px var(--space-sm);margin-left:var(--space-sm);align-items:center;gap:4px;font-weight:600;text-decoration:none;transition:background .15s,color .15s,border-color .15s;display:inline-flex}.dash-config-link:hover{background:var(--color-surface-low);color:var(--color-text-muted);border-color:var(--color-border-strong)}.dash-config-link .material-symbols-outlined{font-size:14px}.dash-header-meta{align-items:center;gap:var(--space-lg);margin-top:var(--space-sm);color:var(--color-text-muted);font-size:var(--text-sm);display:flex}.dash-header-meta span{align-items:center;gap:6px;display:flex}.dash-header-meta .material-symbols-outlined{color:var(--color-text-faint);font-size:16px}.dash-body{max-width:1600px;padding:var(--space-md) var(--space-lg) var(--space-xl);gap:var(--space-md);flex-direction:column;margin:0 auto;display:flex}.cockpit-top{align-items:stretch;gap:var(--space-md);flex-shrink:0;display:flex}.cockpit-top .period-bar{flex:1;min-width:0}.cockpit-kpis{gap:var(--space-sm);flex-shrink:0;display:flex}.cockpit-kpi{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-md);box-shadow:var(--shadow-card);padding:var(--space-xs) var(--space-md);flex-direction:column;justify-content:center;min-width:130px;display:flex}.dash-content{max-width:1600px;padding:var(--space-lg);gap:var(--space-md);flex-direction:column;margin:0 auto;display:flex}.kpi-row{gap:var(--space-md);grid-template-columns:repeat(auto-fill,minmax(200px,1fr));display:grid}.kpi-card{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-md);box-shadow:var(--shadow-card);padding:var(--space-lg)}.kpi-label{font-size:var(--text-xs);letter-spacing:.05em;text-transform:uppercase;color:var(--color-text-faint);margin-bottom:var(--space-xs);font-weight:600}.kpi-value{font-size:var(--text-xl);letter-spacing:-.01em;color:var(--color-text);font-weight:700;line-height:var(--leading-tight)}.kpi-value--sm{font-size:var(--text-md);letter-spacing:0;font-weight:500}.widget{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-md);box-shadow:var(--shadow-card);overflow:hidden}.widget-header{padding:var(--space-md) var(--space-lg);border-bottom:1px solid var(--color-surface-high);justify-content:space-between;align-items:center;gap:var(--space-md);flex-wrap:wrap;display:flex}.widget-title{font-size:var(--text-lg);color:var(--color-text);align-items:center;gap:var(--space-xs);font-weight:600;display:flex}.widget-title .material-symbols-outlined{color:var(--color-text-faint);font-size:20px}.widget-badge{font-size:var(--text-xs);letter-spacing:.05em;text-transform:uppercase;color:var(--color-text-faint);font-weight:600}.widget-body{padding:var(--space-lg)}.widget-body--table{max-height:340px;padding:0;overflow:auto}.widget-header-controls{align-items:center;gap:var(--space-sm);flex-wrap:wrap;display:flex}.gran-pills{gap:2px;display:flex}.gran-pill{font-family:var(--font);font-size:var(--text-xs);color:var(--color-text-faint);border-radius:var(--radius-full);cursor:pointer;white-space:nowrap;background:0 0;border:1px solid #0000;padding:3px 10px;font-weight:500;line-height:1.5;transition:background .12s,color .12s,border-color .12s}.gran-pill:hover{background:var(--color-surface-low);color:var(--color-text-muted);border-color:var(--color-border)}.gran-pill--active{background:var(--color-surface-low);color:var(--color-primary);border-color:var(--color-primary);font-weight:600}.gran-pill:focus-visible{box-shadow:0 0 0 2px var(--color-focus-ring);border-color:var(--color-primary);outline:none}.gran-pill--auto:not(.gran-pill--active):after{content:"•";color:var(--color-text-faint);vertical-align:middle;margin-left:3px;font-size:8px}.compteur-select{font-family:var(--font);font-size:var(--text-sm);color:var(--color-text);background:var(--color-surface);border:1px solid var(--color-border-strong);border-radius:var(--radius-sm);padding:6px var(--space-sm);cursor:pointer;outline:none;min-width:220px;transition:border-color .15s,box-shadow .15s}.compteur-select:focus{border-color:var(--color-primary);box-shadow:0 0 0 2px var(--color-focus-ring)}.chart-state{justify-content:center;align-items:center;gap:var(--space-sm);min-height:200px;color:var(--color-text-muted);text-align:center;flex-direction:column;display:flex}.chart-state .material-symbols-outlined{color:var(--color-border-strong);font-size:40px}.chart-state--error .material-symbols-outlined{color:var(--color-primary)}.chart-tooltip{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-sm);box-shadow:var(--shadow-card-hover);padding:var(--space-sm) var(--space-md)}.chart-tooltip-date{font-size:var(--text-xs);color:var(--color-text-faint);margin-bottom:2px}.chart-tooltip-value{font-size:var(--text-md);color:var(--color-froid);font-weight:600}.compteurs-table{border-collapse:collapse;width:100%}.compteurs-table thead tr{border-bottom:2px solid var(--color-surface-high)}.compteurs-table th{font-size:var(--text-xs);letter-spacing:.05em;text-transform:uppercase;color:var(--color-text-faint);padding:var(--space-sm) var(--space-md);text-align:left;white-space:nowrap;background:var(--color-surface);z-index:1;font-weight:600;position:sticky;top:0}.compteurs-table td{font-size:var(--text-sm);color:var(--color-text);padding:var(--space-sm) var(--space-md);border-bottom:1px solid var(--color-surface-high);white-space:nowrap}.compteurs-table tbody tr:last-child td{border-bottom:none}.compteurs-table tbody tr:hover td{background:var(--color-surface-low)}.tree-icon{color:var(--color-text-faint);vertical-align:middle;margin-right:4px;font-size:14px!important}.td-mono{font-size:var(--text-xs);color:var(--color-text-faint);font-family:var(--font-mono)}.td-center{text-align:center;color:var(--color-text-muted)}.spin-icon{animation:.9s linear infinite spin;display:inline-block}.widget-icon-btn{border-radius:var(--radius-sm);width:30px;height:30px;color:var(--color-text-faint);border:1px solid var(--color-border);cursor:pointer;background:0 0;flex-shrink:0;justify-content:center;align-items:center;transition:background .12s,color .12s,border-color .12s;display:flex}.widget-icon-btn:hover:not(:disabled){background:var(--color-surface-low);color:var(--color-text-muted);border-color:var(--color-border-strong)}.widget-icon-btn:disabled{opacity:.4;cursor:not-allowed}.widget-icon-btn:focus-visible{box-shadow:0 0 0 2px var(--color-focus-ring);border-color:var(--color-primary);outline:none}.perf-summary{align-items:center;gap:var(--space-xs);font-size:var(--text-sm);padding:6px var(--space-sm);border-radius:var(--radius-sm);margin-bottom:var(--space-sm);font-weight:600;display:flex}.perf-summary .material-symbols-outlined{flex-shrink:0;font-size:18px!important}.perf-summary--ok{color:var(--color-eco-pos,#16a34a);background:#16a34a14}.perf-summary--ko{color:var(--color-primary);background:#b1241a14}.perf-cat-pct{font-size:var(--text-xs);opacity:.8;font-variant-numeric:tabular-nums;margin-left:auto;font-weight:400}.perf-no-objectif{align-items:flex-start;gap:var(--space-xs);padding:var(--space-sm) var(--space-md);background:var(--color-surface-low);border-radius:var(--radius-sm);font-size:var(--text-sm);color:var(--color-text-muted);margin:var(--space-sm) 0;line-height:1.5;display:flex}.perf-no-objectif .material-symbols-outlined{color:var(--color-text-faint);flex-shrink:0;margin-top:1px;font-size:18px!important}.perf-admin-link{color:var(--color-primary);font-weight:500;text-decoration:none}.perf-admin-link:hover{text-decoration:underline}.perf-chip{white-space:nowrap;letter-spacing:.01em;border-radius:4px;align-items:center;gap:3px;padding:2px 8px;font-size:11px;font-weight:700;display:inline-flex}.perf-chip--ok{color:var(--color-eco-pos,#16a34a);background:#16a34a1a}.perf-chip--ko{color:var(--color-primary);background:#b1241a17}.perf-chip--nd{color:var(--color-text-faint)}.jours-alerte{align-items:flex-start;gap:var(--space-xs);padding:8px var(--space-md);border-radius:var(--radius-sm);font-size:var(--text-sm);color:#92400e;background:#b4530912;border:1px solid #b4530938;display:flex}.jours-alerte-icon{color:#b45309;flex-shrink:0;margin-top:1px;font-size:18px!important}.jours-alerte-body{flex:1;min-width:0;line-height:1.5}.jours-alerte-dates{font-size:var(--text-xs);opacity:.85}.jours-alerte-more{font-family:var(--font);font-size:var(--text-xs);color:#b45309;cursor:pointer;text-underline-offset:2px;background:0 0;border:none;padding:0 0 0 4px;font-weight:600;text-decoration:underline}.jours-alerte-more:hover{opacity:.75}[data-theme=dark] .jours-alerte{color:#fcd34d;background:#fbbf2414;border-color:#fbbf2433}[data-theme=dark] .jours-alerte-icon,[data-theme=dark] .jours-alerte-more{color:#fbbf24}.widget-icon-btn .material-symbols-outlined{font-size:16px}.period-bar{align-items:center;gap:var(--space-md);background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-md);padding:var(--space-sm) var(--space-md);box-shadow:var(--shadow-card);flex-wrap:wrap;display:flex}.period-bar-label{font-size:var(--text-xs);letter-spacing:.05em;text-transform:uppercase;color:var(--color-text-faint);white-space:nowrap;flex-shrink:0;align-items:center;gap:5px;font-weight:600;display:flex}.period-bar-label .material-symbols-outlined{font-size:14px}.period-pills{flex-wrap:wrap;gap:3px;display:flex}.period-pill{font-family:var(--font);font-size:var(--text-sm);color:var(--color-text-muted);border-radius:var(--radius-full);padding:4px var(--space-sm);cursor:pointer;white-space:nowrap;background:0 0;border:1px solid #0000;font-weight:500;line-height:1.4;transition:background .12s,color .12s,border-color .12s}.period-pill:hover{background:var(--color-surface-low);color:var(--color-text);border-color:var(--color-border)}.period-pill--active{background:var(--color-pill-active-bg);color:var(--color-primary);border-color:var(--color-primary);font-weight:600}.period-pill:focus-visible{box-shadow:0 0 0 2px var(--color-focus-ring);border-color:var(--color-primary);outline:none}.period-custom{align-items:center;gap:var(--space-sm);flex-wrap:wrap;display:flex}.period-date-input{font-family:var(--font);font-size:var(--text-sm);color:var(--color-text);background:var(--color-surface);border:1px solid var(--color-border-strong);border-radius:var(--radius-sm);padding:4px var(--space-sm);outline:none;transition:border-color .15s,box-shadow .15s}.period-date-input:focus{border-color:var(--color-primary);box-shadow:0 0 0 2px var(--color-focus-ring)}.period-custom-sep{color:var(--color-text-faint);font-size:var(--text-sm)}.cmp-blocks{gap:var(--space-md);grid-template-columns:repeat(auto-fit,minmax(260px,1fr));align-items:start;display:grid}.cmp-block{border:1px solid var(--color-border);border-radius:var(--radius-sm);overflow:hidden}.cmp-cat-header{align-items:center;gap:var(--space-xs);padding:var(--space-sm) var(--space-md);font-size:var(--text-sm);letter-spacing:.02em;color:#fff;font-weight:700;display:flex}.cmp-cat-header .material-symbols-outlined{font-size:18px}.cmp-cat-header--froid{background:var(--color-froid)}.cmp-cat-header--chauffage{background:var(--color-chauffage)}.cmp-cat-header--economies{background:var(--color-economies)}.cmp-table{border-collapse:collapse;width:100%}.cmp-table th{font-size:var(--text-xs);letter-spacing:.05em;text-transform:uppercase;color:var(--color-text-faint);padding:var(--space-xs) var(--space-md);text-align:left;background:var(--color-surface-low);white-space:nowrap;border-bottom:1px solid var(--color-border);font-weight:600}.th-right{text-align:right}.cmp-table th:nth-child(3),.cmp-table td.cmp-td-simule{border-right:1px solid var(--color-border)}.cmp-table td{font-size:var(--text-sm);color:var(--color-text);padding:8px var(--space-md);border-top:1px solid var(--color-surface-high)}.cmp-td-mois{color:var(--color-text-muted);width:80px;font-weight:500}.cmp-td-value{text-align:right;font-variant-numeric:tabular-nums;white-space:nowrap}.cmp-td-reel{cursor:help;-webkit-text-decoration:underline dotted var(--color-border-strong);text-decoration:underline dotted var(--color-border-strong);text-underline-offset:3px}.cmp-td-reel:hover{background:var(--color-surface-low)}.cmp-td-simule{color:var(--color-text-faint);border-right:1px solid var(--color-surface-high)}.cmp-td-eco{text-align:right;white-space:nowrap;font-weight:600}.cmp-td-eco--pos{color:var(--color-eco-pos)}.cmp-td-eco--neg{color:var(--color-primary)}.eco-badge{justify-content:flex-end;align-items:center;gap:3px;width:100%;display:inline-flex}.eco-icon{opacity:.85;flex-shrink:0;font-size:15px!important}.eco-num{font-variant-numeric:tabular-nums}.cmp-pct{font-size:var(--text-xs);opacity:.75;margin-left:5px}.cmp-tr-empty{opacity:.38;pointer-events:none}.cmp-tr-total td{border-top:2px solid var(--color-border);background:var(--color-surface-low);padding-top:10px;padding-bottom:10px;font-weight:700}.cmp-td-eco-total.cmp-td-eco--pos{background:var(--color-eco-pos-bg)}.cmp-td-eco-total.cmp-td-eco--neg{background:var(--color-eco-neg-bg)}.cmp-empty{padding:var(--space-md);font-size:var(--text-sm);color:var(--color-text-faint);text-align:center}.cmp-no-data{justify-content:center;align-items:center;gap:var(--space-sm);padding:var(--space-xl);color:var(--color-text-faint);font-size:var(--text-sm);text-align:center;flex-direction:column;display:flex}.cmp-no-data .material-symbols-outlined{color:var(--color-border-strong);font-size:36px}.cmp-detail-tooltip{z-index:300;background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-md);padding:var(--space-sm) var(--space-md);pointer-events:auto;min-width:200px;max-width:320px;position:fixed;transform:translate(-50%)translateY(-100%);box-shadow:0 8px 24px #0000001f}.cmp-detail-title{font-size:var(--text-xs);letter-spacing:.04em;text-transform:uppercase;color:var(--color-text-faint);margin-bottom:var(--space-xs);white-space:nowrap;font-weight:600}.cmp-detail-empty{font-size:var(--text-sm);color:var(--color-text-faint);align-items:center;gap:4px;display:flex}.cmp-detail-table{border-collapse:collapse;width:100%}.cmp-detail-nom{font-size:var(--text-sm);color:var(--color-text-muted);padding:3px 0;padding-right:var(--space-md);text-overflow:ellipsis;white-space:nowrap;max-width:180px;overflow:hidden}.cmp-detail-val{font-size:var(--text-sm);color:var(--color-text);text-align:right;font-variant-numeric:tabular-nums;white-space:nowrap;font-weight:600}.chart-type-pills{border-left:1px solid var(--color-border);padding-left:var(--space-sm);margin-left:2px}@media (width<=900px){.cockpit-top{flex-direction:column;align-items:stretch}.cockpit-kpis{grid-template-columns:repeat(3,1fr);display:grid}}@media (width<=640px){.dash-header{padding:var(--space-lg) var(--space-md)}.dash-content{padding:var(--space-md)}.kpi-row{grid-template-columns:1fr 1fr}.dash-site-name{font-size:var(--text-xl)}.compteur-select{min-width:160px}.period-bar{gap:var(--space-sm)}.period-bar-label{display:none}}.site-card{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-md);box-shadow:var(--shadow-card);padding:var(--space-lg);gap:var(--space-xs);cursor:pointer;flex-direction:column;transition:box-shadow .2s,transform .2s;display:flex}.site-card:hover{box-shadow:var(--shadow-card-hover);transform:translateY(-2px)}.site-card-header{justify-content:space-between;align-items:flex-start;gap:var(--space-sm);display:flex}.site-card-name{font-size:var(--text-lg);color:var(--color-text);font-weight:600;line-height:1.3}.site-card-badge{font-size:var(--text-xs);letter-spacing:.05em;text-transform:uppercase;padding:3px var(--space-sm);border-radius:var(--radius-full);white-space:nowrap;flex-shrink:0;font-weight:600}.site-card-badge--actif{background:var(--color-badge-ok-bg);color:var(--color-badge-ok-text)}.site-card-meta{flex-direction:column;gap:4px;display:flex}.site-card-meta-item{align-items:center;gap:var(--space-xs);font-size:var(--text-sm);color:var(--color-text-muted);display:flex}.site-card-meta-item .material-symbols-outlined{color:var(--color-text-faint);font-size:16px}.site-card-footer{padding-top:var(--space-sm);border-top:1px solid var(--color-surface-high);justify-content:space-between;align-items:center;margin-top:auto;display:flex}.site-card-link{font-size:var(--text-sm);color:var(--color-primary);align-items:center;gap:4px;font-weight:600;transition:gap .15s;display:flex}.site-card-link:hover{gap:var(--space-xs)}.site-card-link .material-symbols-outlined{font-size:16px}.site-card-name-row{align-items:center;gap:6px;min-width:0;display:flex}.site-card-rename-btn{border-radius:var(--radius-sm);color:var(--color-text-faint);cursor:pointer;opacity:0;background:0 0;border:none;flex-shrink:0;align-items:center;padding:2px;transition:opacity .15s,color .15s;display:inline-flex}.site-card:hover .site-card-rename-btn,.site-card-name-row:focus-within .site-card-rename-btn{opacity:1}.site-card-rename-btn:hover{color:var(--color-text-muted)}.site-card-rename-btn .material-symbols-outlined{font-size:15px!important}.site-card-edit-form{flex:1;align-items:center;gap:4px;min-width:0;display:flex}.site-card-edit-input{font-family:var(--font);font-size:var(--text-md);color:var(--color-text);background:var(--color-surface-low);border:1px solid var(--color-primary);border-radius:var(--radius-sm);padding:3px var(--space-xs);min-width:0;box-shadow:0 0 0 2px var(--color-focus-ring);outline:none;flex:1;font-weight:600}.site-card-edit-btn{border-radius:var(--radius-sm);cursor:pointer;border:1px solid;flex-shrink:0;justify-content:center;align-items:center;width:26px;height:26px;transition:background .12s,color .12s;display:inline-flex}.site-card-edit-btn .material-symbols-outlined{font-size:15px!important}.site-card-edit-btn--ok{background:var(--color-eco-pos-bg,#16a34a14);border-color:var(--color-eco-pos,#16a34a);color:var(--color-eco-pos,#16a34a)}.site-card-edit-btn--ok:hover:not(:disabled){background:var(--color-eco-pos,#16a34a);color:#fff}.site-card-edit-btn--cancel{background:var(--color-surface);border-color:var(--color-border-strong);color:var(--color-text-faint)}.site-card-edit-btn--cancel:hover:not(:disabled){background:var(--color-surface-low)}.site-card-edit-btn:disabled{opacity:.4;cursor:not-allowed}.site-card-edit-error{font-size:var(--text-xs);color:var(--color-primary);margin:0}.site-card-sante{padding-top:var(--space-xs);border-top:1px solid var(--color-surface-high);flex-direction:column;gap:5px;display:flex}.sante-badge{font-size:var(--text-xs);letter-spacing:.02em;padding:3px var(--space-sm);border-radius:var(--radius-full);align-items:center;gap:4px;width:fit-content;font-weight:600;display:inline-flex}.sante-badge .material-symbols-outlined{font-size:14px!important}.sante-badge--ok{background:var(--color-badge-ok-bg);color:var(--color-badge-ok-text)}.sante-badge--derive{background:var(--color-eco-neg-bg);color:var(--color-primary)}.sante-badge--neutre{background:var(--color-surface-high);color:var(--color-text-faint)}.sante-detail{color:var(--color-text-faint);flex-wrap:wrap;align-items:center;gap:2px;font-size:11px;line-height:1.4;display:flex}.sante-detail-sep{color:var(--color-border-strong)}.sante-detail-cat{white-space:nowrap;align-items:center;gap:2px;display:inline-flex}.sante-detail-cat .material-symbols-outlined{font-size:12px!important}.sante-detail-cat--ok{color:var(--color-eco-pos)}.sante-detail-cat--derive{color:var(--color-primary);font-weight:600}.sante-detail-pct{font-variant-numeric:tabular-nums}.sites-header{background:var(--color-surface);border-bottom:1px solid var(--color-border-strong);padding:var(--space-xl) var(--space-lg)}.sites-header-inner{max-width:1600px;margin:0 auto}.sites-header-text h1{font-size:var(--text-xl);color:var(--color-text);font-weight:600}.sites-header-text p{font-size:var(--text-sm);color:var(--color-text-muted);margin-top:4px}.sites-header-actions{gap:var(--space-sm);flex-shrink:0;display:flex}.btn-primary{background:var(--color-primary);color:var(--color-on-primary);font-size:var(--text-xs);letter-spacing:.05em;text-transform:uppercase;padding:var(--space-sm) var(--space-lg);border-radius:var(--radius-sm);align-items:center;gap:var(--space-xs);font-weight:600;transition:filter .15s;display:flex;box-shadow:0 1px 4px #0000001f}.btn-primary:hover{filter:brightness(1.1)}.btn-primary:focus-visible{box-shadow:0 0 0 3px var(--color-focus-ring), 0 1px 4px #0000001f;outline:none}.btn-secondary{background:var(--color-surface);color:var(--color-text);border:1px solid var(--color-border-strong);font-size:var(--text-xs);letter-spacing:.05em;text-transform:uppercase;padding:var(--space-sm) var(--space-lg);border-radius:var(--radius-sm);align-items:center;gap:var(--space-xs);font-weight:600;transition:background .15s;display:flex}.btn-secondary:hover{background:var(--color-surface-low)}.btn-secondary:focus-visible{box-shadow:0 0 0 3px var(--color-focus-ring);outline:none}.sites-grid-wrapper{padding:var(--space-lg);max-width:1600px;margin:0 auto}.sites-count{font-size:var(--text-xs);letter-spacing:.05em;text-transform:uppercase;color:var(--color-text-faint);margin-bottom:var(--space-md);font-weight:600}.sites-grid{gap:var(--space-md);grid-template-columns:repeat(auto-fill,minmax(240px,340px));display:grid}.sites-state{padding:var(--space-xl) var(--space-lg);justify-content:center;align-items:center;gap:var(--space-md);color:var(--color-text-muted);text-align:center;flex-direction:column;display:flex}.sites-state .material-symbols-outlined{color:var(--color-border-strong);font-size:48px}.sites-state p{font-size:var(--text-md)}.sites-state--error .material-symbols-outlined{color:var(--color-primary)}.parc-synthese{max-width:1600px;padding:var(--space-lg);gap:var(--space-md);flex-direction:column;margin:0 auto;padding-bottom:0;display:flex}.parc-kpi-row{gap:var(--space-md);grid-template-columns:repeat(4,1fr);display:grid}.parc-kpi-card{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-md);box-shadow:var(--shadow-card);padding:var(--space-lg);gap:var(--space-2xs);border-left-width:1px;flex-direction:column;display:flex}.parc-kpi-card--ok{border-left:3px solid var(--color-eco-pos)}.parc-kpi-card--danger{border-left:3px solid var(--color-primary)}.parc-kpi-label{font-size:var(--text-xs);letter-spacing:.05em;text-transform:uppercase;color:var(--color-text-faint);margin-bottom:var(--space-xs);align-items:center;gap:5px;font-weight:600;display:flex}.parc-kpi-label .material-symbols-outlined{font-size:14px!important}.parc-kpi-value{font-size:var(--text-2xl);letter-spacing:-.02em;color:var(--color-text);font-weight:700;line-height:var(--leading-tight)}.parc-kpi-sub{font-size:var(--text-sm);color:var(--color-text-faint);margin-top:2px}.parc-kpi-eco{font-size:var(--text-sm);align-items:center;gap:3px;margin-top:2px;font-weight:600;display:inline-flex}.parc-kpi-eco .material-symbols-outlined{font-size:16px!important}.parc-kpi-eco--pos{color:var(--color-eco-pos)}.parc-kpi-eco--neg{color:var(--color-primary)}.parc-kpi-skeleton{background:var(--color-surface-high);border-radius:var(--radius-sm);width:90px;height:40px;margin-top:var(--space-xs);animation:1.4s ease-in-out infinite parc-pulse;display:inline-block}@keyframes parc-pulse{0%,to{opacity:1}50%{opacity:.35}}.parc-alerte{align-items:flex-start;gap:var(--space-sm);background:var(--color-warn-bg);border:1px solid var(--color-warn-border);border-radius:var(--radius-md);padding:var(--space-md);display:flex}.parc-alerte-icon{color:#b45309;flex-shrink:0;margin-top:1px;font-size:20px!important}.parc-alerte-body{flex:1;min-width:0}.parc-alerte-title{font-size:var(--text-sm);color:var(--color-warn-text);font-weight:700}.parc-alerte-list{gap:var(--space-xs);margin-top:var(--space-xs);flex-wrap:wrap;display:flex}.parc-alerte-site{border-radius:var(--radius-sm);padding:4px var(--space-sm);background:#b4530914;border:1px solid #b453092e;align-items:center;gap:4px;display:inline-flex}.parc-alerte-site-name{font-size:var(--text-xs);color:var(--color-warn-text);white-space:nowrap;font-weight:700;text-decoration:none}.parc-alerte-site-name:hover{text-decoration:underline}.parc-alerte-cat{font-size:var(--text-xs);color:var(--color-primary);white-space:nowrap;font-weight:500}.parc-sites-heading{align-items:center;gap:var(--space-xs);font-size:var(--text-xs);letter-spacing:.06em;text-transform:uppercase;color:var(--color-text-faint);margin-bottom:var(--space-md);font-weight:600;display:flex}.parc-sites-heading .material-symbols-outlined{font-size:14px!important}.parc-sites-heading:after{content:"";background:var(--color-border);flex:1;height:1px}.parc-sites-heading-note{font-size:var(--text-xs);letter-spacing:0;text-transform:none;color:var(--color-text-faint);font-style:italic;font-weight:500}[data-theme=dark] .parc-alerte-site{background:#fbbf2412;border-color:#fbbf242e}[data-theme=dark] .parc-alerte-icon{color:#fbbf24}@media (width<=900px){.parc-kpi-row{grid-template-columns:repeat(2,1fr)}}@media (width<=480px){.parc-kpi-row{grid-template-columns:1fr 1fr}.parc-kpi-value{font-size:var(--text-xl)}.parc-synthese{padding:var(--space-md)}}.modal-overlay{z-index:200;padding:var(--space-lg);background:#00000073;justify-content:center;align-items:center;display:flex;position:fixed;inset:0}.modal-card{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-md);box-shadow:var(--shadow-card-hover);flex-direction:column;width:100%;max-width:480px;max-height:90vh;display:flex;overflow-y:auto}.modal-header{padding:var(--space-lg);border-bottom:1px solid var(--color-surface-high);background:var(--color-surface);z-index:1;justify-content:space-between;align-items:center;display:flex;position:sticky;top:0}.modal-title{font-size:var(--text-lg);color:var(--color-text);font-weight:600}.modal-close{color:var(--color-text-faint);border-radius:var(--radius-full);justify-content:center;align-items:center;width:32px;height:32px;transition:background .15s,color .15s;display:flex}.modal-close:hover{background:var(--color-surface-high);color:var(--color-text)}.modal-error{margin:var(--space-md) var(--space-lg) 0;border-radius:var(--radius-sm);color:var(--color-primary);font-size:var(--text-sm);padding:var(--space-sm) var(--space-md);align-items:center;gap:var(--space-xs);background:#fef2f2;border:1px solid #fecaca;display:flex}.modal-form{padding:var(--space-lg);gap:var(--space-md);flex-direction:column;display:flex}.form-select{width:100%;font-family:var(--font);font-size:var(--text-sm);color:var(--color-text);background:var(--color-surface);border:1px solid var(--color-border-strong);border-radius:var(--radius-sm);padding:10px var(--space-md);cursor:pointer;outline:none;transition:border-color .15s,box-shadow .15s}.form-select:focus{border-color:var(--color-primary);box-shadow:0 0 0 2px #b1241a1a}.form-label{font-size:var(--text-xs);letter-spacing:.05em;text-transform:uppercase;color:var(--color-text-faint);justify-content:space-between;align-items:center;font-weight:600;display:flex}.form-label-hint{letter-spacing:0;text-transform:none;color:var(--color-primary);font-weight:400}.site-checkboxes{border:1px solid var(--color-border-strong);border-radius:var(--radius-sm);padding:var(--space-sm);flex-direction:column;gap:6px;max-height:180px;display:flex;overflow-y:auto}.site-checkbox-item{align-items:center;gap:var(--space-sm);padding:6px var(--space-sm);border-radius:var(--radius-sm);cursor:pointer;transition:background .1s;display:flex}.site-checkbox-item:hover{background:var(--color-surface-low)}.site-checkbox-item input[type=checkbox]{accent-color:var(--color-primary);cursor:pointer;flex-shrink:0;width:16px;height:16px}.site-checkbox-name{font-size:var(--text-sm);color:var(--color-text);font-weight:500}.site-checkbox-loc{font-size:var(--text-xs);color:var(--color-text-faint);margin-left:auto}.modal-subtitle{font-size:var(--text-sm);color:var(--color-text-faint);margin-top:2px}.status-toggle{align-items:center;gap:var(--space-sm);cursor:pointer;padding:10px var(--space-md);border:1px solid var(--color-border-strong);border-radius:var(--radius-sm);transition:background .15s;display:flex}.status-toggle:hover{background:var(--color-surface-low)}.status-toggle input[type=checkbox]{accent-color:var(--color-primary);cursor:pointer;flex-shrink:0;width:16px;height:16px}.status-toggle-label{align-items:center;gap:var(--space-xs);font-size:var(--text-sm);color:var(--color-text);cursor:pointer;font-weight:500;display:flex}.status-dot{border-radius:var(--radius-full);flex-shrink:0;width:8px;height:8px}.status-dot--actif{background:#22c55e}.status-dot--inactif{background:var(--color-border-strong)}.modal-no-sites{font-size:var(--text-sm);color:var(--color-text-muted);padding:var(--space-sm)}.modal-footer{justify-content:flex-end;gap:var(--space-sm);padding-top:var(--space-xs);display:flex}.login-spin{animation:1s linear infinite spin;display:inline-block}.users-table-wrap{border:1px solid var(--color-border);border-radius:var(--radius-md);box-shadow:var(--shadow-card);background:var(--color-surface);overflow-x:auto}.users-table{border-collapse:collapse;width:100%}.users-table thead tr{border-bottom:2px solid var(--color-surface-high)}.users-table th{font-size:var(--text-xs);letter-spacing:.05em;text-transform:uppercase;color:var(--color-text-faint);padding:var(--space-sm) var(--space-md);text-align:left;white-space:nowrap;background:var(--color-surface);font-weight:600}.users-table td{font-size:var(--text-sm);color:var(--color-text);padding:var(--space-sm) var(--space-md);border-bottom:1px solid var(--color-surface-high);vertical-align:middle}.users-table tbody tr:last-child td{border-bottom:none}.users-table tbody tr:hover td{background:var(--color-surface-low)}.users-table .row--inactive td{opacity:.5}.td-email{align-items:center;gap:var(--space-xs);white-space:nowrap;display:flex}.td-icon{color:var(--color-text-faint);font-size:16px}.role-badge{font-size:var(--text-xs);letter-spacing:.05em;text-transform:uppercase;padding:3px var(--space-sm);border-radius:var(--radius-full);white-space:nowrap;font-weight:600}.role-badge--admin{color:#991b1b;background:#fee2e2}.role-badge--client{color:#1e40af;background:#dbeafe}.status-badge{font-size:var(--text-xs);letter-spacing:.05em;text-transform:uppercase;padding:3px var(--space-sm);border-radius:var(--radius-full);white-space:nowrap;font-weight:600}.status-badge--actif{color:#166534;background:#dcfce7}.status-badge--inactif{background:var(--color-surface-high);color:var(--color-text-faint)}.td-sites{max-width:300px}.sites-chips{flex-wrap:wrap;gap:4px;display:flex}.site-chip{font-size:var(--text-xs);background:var(--color-surface-low);border:1px solid var(--color-border);border-radius:var(--radius-full);padding:2px var(--space-sm);color:var(--color-text-muted);white-space:nowrap;font-weight:500}.sites-all-label{font-size:var(--text-xs);color:var(--color-text-faint);font-style:italic}.sites-none-label{font-size:var(--text-xs);color:var(--color-text-faint)}.edit-btn{font-family:var(--font);font-size:var(--text-xs);letter-spacing:.03em;padding:5px var(--space-sm);border-radius:var(--radius-sm);color:var(--color-text-muted);background:var(--color-surface-high);white-space:nowrap;align-items:center;gap:4px;font-weight:600;transition:background .15s,color .15s;display:inline-flex}.edit-btn .material-symbols-outlined{font-size:15px}.edit-btn:hover{color:#1e40af;background:#dbeafe}.edit-btn:focus-visible{box-shadow:0 0 0 2px var(--color-focus-ring);outline:none}.simule-form{gap:var(--space-lg);flex-direction:column;max-width:600px;display:flex}.simule-field{gap:var(--space-xs);flex-direction:column;display:flex}.simule-label{font-size:var(--text-sm);color:var(--color-text-muted);letter-spacing:.02em;font-weight:600}.simule-select{font-family:var(--font);font-size:var(--text-sm);color:var(--color-text);background:var(--color-surface);border:1px solid var(--color-border-strong);border-radius:var(--radius-sm);padding:8px var(--space-sm);cursor:pointer;outline:none;transition:border-color .15s,box-shadow .15s}.simule-select:focus{border-color:var(--color-primary);box-shadow:0 0 0 2px var(--color-focus-ring)}.simule-file-row{align-items:center;gap:var(--space-sm);flex-wrap:wrap;display:flex}.simule-file-input{font-family:var(--font);font-size:var(--text-sm);color:var(--color-text)}.simule-file-input:disabled{opacity:.4;cursor:not-allowed}.simule-file-name{font-size:var(--text-sm);color:var(--color-text-muted);align-items:center;gap:4px;display:inline-flex}.simule-file-name .material-symbols-outlined{color:var(--color-text-faint);font-size:16px}.simule-hint{font-size:var(--text-xs);color:var(--color-text-faint);line-height:1.5}.simule-actions{gap:var(--space-sm);flex-wrap:wrap;align-items:center;display:flex}.simule-btn{font-family:var(--font);font-size:var(--text-sm);padding:8px var(--space-md);border-radius:var(--radius-sm);cursor:pointer;white-space:nowrap;align-items:center;gap:6px;font-weight:600;transition:background .15s,border-color .15s,opacity .15s;display:inline-flex}.simule-btn:disabled{opacity:.45;cursor:not-allowed}.simule-btn:focus-visible{box-shadow:0 0 0 2px var(--color-focus-ring);outline:none}.simule-btn .material-symbols-outlined{font-size:17px}.simule-btn--apercu{background:var(--color-surface);border:1px solid var(--color-border-strong);color:var(--color-text)}.simule-btn--apercu:not(:disabled):hover{background:var(--color-surface-low);border-color:var(--color-text-faint)}.simule-btn--confirm{background:var(--color-action-ok);border:1px solid var(--color-action-ok-hover);color:#fff}.simule-btn--confirm:not(:disabled):hover{background:var(--color-action-ok-hover)}.simule-btn--reset{color:var(--color-text-faint);background:0 0;border:1px solid #0000}.simule-btn--reset:not(:disabled):hover{color:var(--color-text-muted);border-color:var(--color-border)}@keyframes simule-spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.simule-spin{animation:.8s linear infinite simule-spin}.simule-error{align-items:center;gap:var(--space-xs);background:var(--color-error-bg);border:1px solid var(--color-error-border);border-radius:var(--radius-sm);color:var(--color-primary);font-size:var(--text-sm);padding:var(--space-sm) var(--space-md);display:flex}.simule-error .material-symbols-outlined{flex-shrink:0;font-size:16px}.simule-error-close{color:var(--color-primary);opacity:.7;margin-left:auto;display:flex}.simule-error-close .material-symbols-outlined{font-size:16px}.simule-result-widget{border-color:var(--color-badge-ok-text)}.simule-success{align-items:flex-start;gap:var(--space-md);display:flex}.simule-success>.material-symbols-outlined{color:var(--color-action-ok);flex-shrink:0;margin-top:2px;font-size:28px}.simule-success-title{color:var(--color-text);font-weight:700;font-size:var(--text-md)}.simule-success-detail{font-size:var(--text-sm);color:var(--color-text-muted);margin-top:4px}.simule-warn{font-size:var(--text-xs);color:var(--color-warn-text);margin-top:4px}.simule-apercu-actions{align-items:center;gap:var(--space-md);display:flex}.simule-apercu-stats{font-size:var(--text-sm);color:var(--color-text-faint)}.simule-warn-banner{align-items:center;gap:var(--space-xs);background:var(--color-warn-bg);border-bottom:1px solid var(--color-warn-border);padding:var(--space-sm) var(--space-lg);font-size:var(--text-sm);color:var(--color-warn-text);display:flex}.simule-warn-banner .material-symbols-outlined{font-size:16px}.simule-apercu-table{border-collapse:collapse;width:100%}.simule-apercu-table th{font-size:var(--text-xs);letter-spacing:.05em;text-transform:uppercase;color:var(--color-text-faint);padding:var(--space-sm) var(--space-md);text-align:left;background:var(--color-surface);white-space:nowrap;font-weight:600}.simule-apercu-table td{font-size:var(--text-sm);color:var(--color-text);padding:8px var(--space-md);border-top:1px solid var(--color-surface-high)}.simule-row--update td{background:var(--color-row-update-bg)}.simule-row--update:hover td{background:var(--color-row-update-hover)!important}.simule-apercu-table tbody tr:hover td{background:var(--color-surface-low)}.simule-td-mois{color:var(--color-text-muted);width:120px;font-weight:500}.simule-td-value{text-align:right;font-variant-numeric:tabular-nums}.simule-badge{font-size:var(--text-xs);letter-spacing:.04em;padding:2px var(--space-sm);border-radius:var(--radius-full);white-space:nowrap;font-weight:600;display:inline-block}.simule-badge--new{background:var(--color-badge-ok-bg);color:var(--color-badge-ok-text)}.simule-badge--update{background:var(--color-badge-warn-bg);color:var(--color-badge-warn-text)}.simule-status-body{padding:var(--space-md) var(--space-lg)}.simule-status-grid{gap:var(--space-sm);grid-template-columns:repeat(auto-fill,minmax(200px,1fr));display:grid}.simule-status-card{border-radius:var(--radius-sm);border:1px solid var(--color-border);padding:var(--space-sm) var(--space-md);flex-direction:column;gap:5px;display:flex}.simule-status-card--ok{border-color:var(--color-badge-ok-text);background:var(--color-badge-ok-bg)}.simule-status-card--none{background:var(--color-surface-low);opacity:.7}.simule-status-name{font-size:var(--text-sm);color:var(--color-text);white-space:nowrap;text-overflow:ellipsis;font-weight:600;overflow:hidden}.simule-status-cats{flex-wrap:wrap;gap:4px;display:flex}.simule-status-cat{font-size:var(--text-xs);background:var(--color-badge-ok-bg);color:var(--color-badge-ok-text);border-radius:var(--radius-full);white-space:nowrap;padding:2px 8px;font-weight:500}.simule-status-empty{font-size:var(--text-xs);color:var(--color-text-faint)}.obj-desc{font-size:var(--text-sm);color:var(--color-text-muted);line-height:var(--leading-relaxed);margin-bottom:var(--space-lg);max-width:640px}.obj-desc strong{color:var(--color-text);font-weight:600}.obj-site-field{max-width:360px;margin-bottom:var(--space-lg)}.obj-list{gap:var(--space-sm);flex-direction:column;max-width:600px;display:flex}.obj-row{align-items:center;gap:var(--space-md);padding:var(--space-md);background:var(--color-surface-low);border:1px solid var(--color-border);border-radius:var(--radius-md);grid-template-columns:1fr 160px auto;transition:border-color .15s;display:grid}.obj-row:hover{border-color:var(--color-border-strong)}.obj-cat-name{align-items:center;gap:var(--space-xs);font-size:var(--text-sm);color:var(--color-text);font-weight:600;display:flex}.obj-cat-icon{color:var(--color-text-faint);font-size:18px!important}.obj-input-wrap{align-items:center;gap:6px;display:flex}.obj-input{font-family:var(--font);font-size:var(--text-sm);font-variant-numeric:tabular-nums;color:var(--color-text);background:var(--color-surface);border:1px solid var(--color-border-strong);border-radius:var(--radius-sm);padding:6px var(--space-sm);text-align:right;-moz-appearance:textfield;outline:none;width:90px;transition:border-color .15s,box-shadow .15s}.obj-input::-webkit-outer-spin-button{-webkit-appearance:none;margin:0}.obj-input::-webkit-inner-spin-button{-webkit-appearance:none;margin:0}.obj-input:focus{border-color:var(--color-primary);box-shadow:0 0 0 2px var(--color-focus-ring)}.obj-input--error{border-color:var(--color-primary);background:var(--color-error-bg)}.obj-unit{font-size:var(--text-sm);color:var(--color-text-faint);font-weight:600}.obj-actions{align-items:center;gap:var(--space-sm);flex-wrap:wrap;display:flex}.obj-save-btn{font-family:var(--font);font-size:var(--text-xs);padding:6px var(--space-sm);border-radius:var(--radius-sm);border:1px solid var(--color-border-strong);background:var(--color-surface);color:var(--color-text-muted);cursor:pointer;white-space:nowrap;align-items:center;gap:5px;font-weight:600;transition:background .15s,border-color .15s,color .15s,opacity .15s;display:inline-flex}.obj-save-btn:not(:disabled):hover{background:var(--color-primary);border-color:var(--color-primary);color:#fff}.obj-save-btn:disabled{opacity:.4;cursor:not-allowed}.obj-save-btn:focus-visible{box-shadow:0 0 0 2px var(--color-focus-ring);outline:none}.obj-save-btn--saved{background:var(--color-action-ok);border-color:var(--color-action-ok);color:#fff}.obj-save-btn .material-symbols-outlined{font-size:15px!important}.obj-error{font-size:var(--text-xs);color:var(--color-error-text);white-space:nowrap}.obj-loading{align-items:center;gap:var(--space-sm);font-size:var(--text-sm);color:var(--color-text-faint);margin-top:var(--space-md);display:flex}.obj-loading .material-symbols-outlined{font-size:18px}.obj-empty{font-size:var(--text-sm);color:var(--color-text-faint);margin-top:var(--space-md);font-style:italic}.bilan-fullstate{justify-content:center;align-items:center;gap:var(--space-md);min-height:400px;color:var(--color-text-muted);text-align:center;padding:var(--space-xl);flex-direction:column;display:flex}.bilan-fullstate .material-symbols-outlined{color:var(--color-border-strong);font-size:48px}.bilan-fullstate--error .material-symbols-outlined{color:var(--color-primary)}@keyframes bilan-spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.bilan-spin{animation:.9s linear infinite bilan-spin;display:inline-block}.bilan-nav{padding:var(--space-sm) var(--space-xl);background:var(--color-surface);border-bottom:1px solid var(--color-border-strong);justify-content:space-between;align-items:center;gap:var(--space-md);flex-shrink:0;display:flex}.bilan-back-link{font-size:var(--text-sm);color:var(--color-primary);align-items:center;gap:6px;font-weight:600;text-decoration:none;transition:opacity .15s;display:inline-flex}.bilan-back-link:hover{opacity:.75}.bilan-back-link .material-symbols-outlined{font-size:18px!important}.bilan-nav-right{align-items:center;gap:var(--space-sm);display:flex}.bilan-year-select{font-family:var(--font);font-size:var(--text-sm);color:var(--color-text);background:var(--color-surface);border:1px solid var(--color-border-strong);border-radius:var(--radius-sm);padding:6px var(--space-sm);cursor:pointer;outline:none;font-weight:600}.bilan-year-select:focus{border-color:var(--color-primary);box-shadow:0 0 0 2px var(--color-focus-ring)}.bilan-print-btn{font-family:var(--font);font-size:var(--text-sm);padding:7px var(--space-md);background:var(--color-primary);color:#fff;border-radius:var(--radius-sm);cursor:pointer;white-space:nowrap;border:none;align-items:center;gap:6px;font-weight:600;transition:opacity .15s;display:inline-flex}.bilan-print-btn:hover{opacity:.85}.bilan-print-btn .material-symbols-outlined{font-size:18px!important}.bilan-page{flex-direction:column;display:flex}.bilan-main{max-width:880px;padding:var(--space-xl) var(--space-lg);gap:var(--space-xl);flex-direction:column;width:100%;margin:0 auto;display:flex}.bilan-title-block{padding-bottom:var(--space-md);border-bottom:2px solid var(--color-border-strong)}.bilan-title{color:var(--color-text);letter-spacing:-.01em;margin:0;font-size:28px;font-weight:700}.bilan-subtitle{margin:var(--space-xs) 0 0;font-size:var(--text-md);color:var(--color-text-muted)}.bilan-subtitle-year{color:var(--color-text);font-weight:700}.bilan-card{border:1px solid var(--color-border);border-radius:var(--radius-md);background:var(--color-surface);overflow:hidden}.bilan-card-header{align-items:center;gap:var(--space-sm);padding:var(--space-sm) var(--space-md);color:#fff;display:flex}.bilan-card-header .material-symbols-outlined{flex-shrink:0;font-size:20px!important}.bilan-card-title{font-size:var(--text-sm);text-transform:uppercase;letter-spacing:.06em;font-weight:700}.bilan-card-badge{font-size:var(--text-xs);text-transform:none;letter-spacing:0;border-radius:var(--radius-sm);background:#ffffff2e;margin-left:auto;padding:2px 8px;font-weight:500}.bilan-card-badge--warn{background:#ffc8004d}.bilan-card-header--froid{background:var(--color-froid)}.bilan-card-header--chauffage{background:var(--color-chauffage)}.bilan-card-header--economies{background:var(--color-economies)}.bilan-card-header--synthese{background:var(--color-nav,#1a1a1a)}.bilan-card-body{padding:var(--space-md) var(--space-lg);gap:var(--space-md);flex-direction:column;display:flex}.bilan-kpi-row{gap:var(--space-sm);grid-template-columns:repeat(3,1fr);display:grid}.bilan-kpi{padding:var(--space-sm) var(--space-md);background:var(--color-surface-low);border-radius:var(--radius-md);border:1px solid var(--color-border);flex-direction:column;gap:4px;display:flex}.bilan-kpi-label{font-size:var(--text-xs);text-transform:uppercase;letter-spacing:.05em;color:var(--color-text-faint);margin:0;font-weight:600}.bilan-kpi-value{color:var(--color-text);font-variant-numeric:tabular-nums;margin:0;font-size:22px;font-weight:700;line-height:1.2}.bilan-kpi-value--simule{color:var(--color-froid)}.bilan-kpi-value--objectif{color:var(--color-chauffage)}.bilan-kpi-nd{font-size:var(--text-sm);color:var(--color-text-faint);margin:0;padding-top:4px;font-style:italic}.bilan-kpi-partial{color:var(--color-text-faint);margin:0;font-size:10px;font-style:italic}.bilan-ecarts{gap:var(--space-xs);padding-top:var(--space-sm);border-top:1px solid var(--color-border);flex-direction:column;display:flex}.bilan-ecart-row{align-items:center;gap:var(--space-md);flex-wrap:wrap;display:flex}.bilan-ecart-label{font-size:var(--text-sm);color:var(--color-text-muted);flex-shrink:0;min-width:130px;font-weight:500}.bilan-ecart-badge{align-items:center;gap:var(--space-xs);flex-wrap:wrap;display:inline-flex}.bilan-ecart-icon{font-size:18px!important}.bilan-ecart-num{font-size:var(--text-sm);font-variant-numeric:tabular-nums;font-weight:700}.bilan-ecart-pct{opacity:.9;font-weight:600}.bilan-ecart-badge--pos .bilan-ecart-icon,.bilan-ecart-badge--pos .bilan-ecart-num{color:var(--color-eco-pos,#16a34a)}.bilan-ecart-badge--neg .bilan-ecart-icon,.bilan-ecart-badge--neg .bilan-ecart-num{color:var(--color-primary)}.bilan-verdict{font-size:var(--text-xs);border-radius:var(--radius-sm);white-space:nowrap;padding:2px 8px;font-weight:700}.bilan-verdict--ok{background:var(--color-eco-pos-bg,#16a34a14);color:var(--color-eco-pos,#16a34a)}.bilan-verdict--ko{color:var(--color-primary);background:#b1241a17}.bilan-nd{font-size:var(--text-sm);color:var(--color-text-faint);font-style:italic}.bilan-conformite{align-items:flex-start;gap:var(--space-xs);padding:var(--space-sm) var(--space-md);border-radius:var(--radius-sm);font-size:var(--text-sm);font-weight:600;line-height:1.5;display:flex}.bilan-conformite .material-symbols-outlined{flex-shrink:0;margin-top:1px;font-size:20px!important}.bilan-conformite--ok{background:var(--color-eco-pos-bg,#16a34a14);color:var(--color-eco-pos,#16a34a)}.bilan-conformite--ko{color:var(--color-primary);background:#b1241a14}.bilan-notice{font-size:var(--text-xs);color:var(--color-text-faint);align-items:center;gap:6px;margin:0;font-style:italic;display:flex}.bilan-notice .material-symbols-outlined{flex-shrink:0;font-size:15px!important}.bilan-empty{align-items:center;gap:var(--space-md);padding:var(--space-xl) 0;color:var(--color-text-faint);text-align:center;flex-direction:column;display:flex}.bilan-empty .material-symbols-outlined{font-size:48px}.bilan-print-header{display:none}@media print{.no-print,.bilan-nav,.navbar,.app-footer{display:none!important}.bilan-print-header{padding-bottom:var(--space-md);margin-bottom:var(--space-md);border-bottom:2px solid #1a1a1a;display:block}.bilan-print-brand{color:#1a1a1a;letter-spacing:.02em;margin:0;font-size:15px;font-weight:700}.bilan-print-meta{color:#5a413d;margin:4px 0 0;font-size:12px}.bilan-page{min-height:unset}.bilan-main{gap:16px;max-width:100%;padding:0}.bilan-title{font-size:22px}.bilan-card{break-inside:avoid;page-break-inside:avoid;border:1px solid #ccc;margin-bottom:0}.bilan-card-header--froid{-webkit-print-color-adjust:exact;print-color-adjust:exact;background-color:#006497!important}.bilan-card-header--chauffage{-webkit-print-color-adjust:exact;print-color-adjust:exact;background-color:#f39c12!important}.bilan-card-header--economies{-webkit-print-color-adjust:exact;print-color-adjust:exact;background-color:#27ae60!important}.bilan-card-header--synthese{-webkit-print-color-adjust:exact;print-color-adjust:exact;background-color:#1a1a1a!important}.bilan-conformite--ok,.bilan-conformite--ko,.bilan-kpi,.bilan-verdict--ok,.bilan-verdict--ko{-webkit-print-color-adjust:exact;print-color-adjust:exact}.bilan-kpi{background-color:#f6f3f2!important}}.about-page{background:var(--color-bg);min-height:calc(100vh - 64px);padding:var(--space-xl) var(--space-lg);justify-content:center;align-items:flex-start;display:flex}.about-card{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-md);box-shadow:var(--shadow-card);padding:var(--space-xl);gap:var(--space-lg);flex-direction:column;width:100%;max-width:560px;display:flex}.about-back{align-items:center;gap:var(--space-xs);font-family:var(--font);font-size:var(--text-sm);color:var(--color-text-muted);cursor:pointer;background:0 0;border:none;align-self:flex-start;padding:0;font-weight:500;transition:color .12s;display:inline-flex}.about-back:hover{color:var(--color-primary)}.about-back .material-symbols-outlined{font-size:18px}.about-header{align-items:center;gap:var(--space-md);padding-bottom:var(--space-lg);border-bottom:1px solid var(--color-border);display:flex}.about-logo-wrap{background:var(--color-primary);border-radius:var(--radius-md);flex-shrink:0;justify-content:center;align-items:center;width:52px;height:52px;display:flex}.about-logo-icon{color:#fff;font-variation-settings:"FILL" 1, "wght" 400, "GRAD" 0, "opsz" 24;font-size:28px!important}.about-title{font-size:var(--text-xl);color:var(--color-text);margin:0;font-weight:700;line-height:1.2}.about-subtitle{font-size:var(--text-sm);color:var(--color-text-faint);margin:4px 0 0}.about-desc{font-size:var(--text-sm);color:var(--color-text-muted);margin:0;line-height:1.65}.about-meta-grid{gap:var(--space-md);padding:var(--space-md);background:var(--color-surface-low);border-radius:var(--radius-md);border:1px solid var(--color-border);grid-template-columns:1fr 1fr;display:grid}.about-meta-item{flex-direction:column;gap:4px;display:flex}.about-meta-label{font-size:var(--text-xs);letter-spacing:.07em;text-transform:uppercase;color:var(--color-text-faint);font-weight:700}.about-meta-value{font-size:var(--text-sm);color:var(--color-text);font-weight:600}.about-stack{gap:var(--space-xs);flex-direction:column;display:flex}.about-tags{flex-wrap:wrap;gap:8px;margin-top:4px;display:flex}.about-tag{font-size:var(--text-xs);border-radius:var(--radius-full);background:var(--color-pill-active-bg);color:var(--color-primary);border:1px solid var(--color-border-strong);padding:4px 10px;font-weight:600}.about-footer-note{font-size:var(--text-xs);color:var(--color-text-faint);text-align:center;padding-top:var(--space-md);border-top:1px solid var(--color-border)}.config-tabs{border-bottom:1px solid var(--color-border);margin-bottom:var(--space-xl);scrollbar-width:none;gap:0;display:flex;overflow-x:auto}.config-tabs::-webkit-scrollbar{display:none}.config-tab{align-items:center;gap:var(--space-xs);padding:var(--space-sm) var(--space-lg);font-family:var(--font);font-size:var(--text-sm);color:var(--color-text-faint);cursor:pointer;white-space:nowrap;border-radius:var(--radius-sm) var(--radius-sm) 0 0;background:0 0;border:none;border-bottom:2px solid #0000;margin-bottom:-1px;font-weight:500;transition:color .15s,border-color .15s,background .15s;display:inline-flex}.config-tab .material-symbols-outlined{flex-shrink:0;font-size:18px}.config-tab:hover{color:var(--color-text);background:var(--color-surface-high)}.config-tab--active{color:var(--color-primary);border-bottom-color:var(--color-primary);font-weight:600}.config-tab:focus-visible{background:var(--color-surface-high);box-shadow:inset 0 0 0 2px var(--color-focus-ring);outline:none}.config-tab--active .material-symbols-outlined{color:var(--color-primary)}.config-panel{gap:var(--space-xl);flex-direction:column;display:flex}.users-topbar{justify-content:space-between;align-items:center;gap:var(--space-md);margin-bottom:var(--space-md);display:flex}.config-empty-state{justify-content:center;align-items:center;gap:var(--space-md);padding:var(--space-xxl) var(--space-xl);color:var(--color-text-faint);text-align:center;background:var(--color-surface-low);border:1px dashed var(--color-border);border-radius:var(--radius-md);flex-direction:column;display:flex}.config-empty-state .material-symbols-outlined{opacity:.35;font-size:48px}.config-empty-state p{font-size:var(--text-sm);max-width:380px;line-height:1.6}[data-theme=dark] .config-tab:hover{background:var(--color-surface-high)}[data-theme=dark] .config-empty-state{background:var(--color-surface-low);border-color:var(--color-border)}.toaster{bottom:var(--space-xl);right:var(--space-xl);z-index:9999;gap:var(--space-sm);pointer-events:none;flex-direction:column;display:flex;position:fixed}.toast{align-items:center;gap:var(--space-sm);padding:var(--space-sm) var(--space-md);border-radius:var(--radius-sm);font-family:var(--font);font-size:var(--text-sm);pointer-events:all;min-width:260px;max-width:380px;font-weight:500;animation:.18s ease-out toast-in;display:flex;box-shadow:0 4px 16px #0000001f}@keyframes toast-in{0%{opacity:0;transform:translateY(6px)scale(.98)}to{opacity:1;transform:translateY(0)scale(1)}}.toast--success{background:var(--color-badge-ok-bg);border:1px solid var(--color-badge-ok-text);color:var(--color-badge-ok-text)}.toast--error{background:var(--color-error-bg);border:1px solid var(--color-error-border);color:var(--color-error-text)}.toast--info{background:var(--color-surface);border:1px solid var(--color-border-strong);color:var(--color-text-muted)}.toast-icon{flex-shrink:0;font-size:17px}.toast-msg{line-height:1.4}
