.App{max-width:100vw;overflow-x:hidden;text-align:left;width:100vw}.app-main-content{min-height:100vh;overflow-x:hidden;overflow-y:auto;transition:margin-left .3s ease,width .3s ease}@media (max-width:768px){.app-main-content{margin-left:0!important;max-width:100vw;overflow-x:hidden;width:100vw!important}}.App-logo{height:40vmin;pointer-events:none}@media (prefers-reduced-motion:no-preference){.App-logo{animation:App-logo-spin 20s linear infinite}}.App-header{background-color:#282c34;color:#fff;padding:20px}.App-link{color:#61dafb}@keyframes App-logo-spin{0%{transform:rotate(0deg)}to{transform:rotate(1turn)}}.topbar{background:#fff;border-bottom:1px solid #e2e8f0;box-shadow:0 1px 3px #0000000d;justify-content:space-between;padding:16px 32px;position:-webkit-sticky;position:sticky;top:0;z-index:40}.topbar,.topbar-left{align-items:center;display:flex}.topbar-left{gap:16px}.menu-button{align-items:center;background:#0000;border:none;border-radius:8px;color:#475569;cursor:pointer;display:flex;justify-content:center;padding:8px;transition:all .2s ease}.menu-button:hover{background:#f1f5f9;color:#16a34a}.menu-button.mobile-only{display:none}@media (max-width:768px){.menu-button.mobile-only{display:flex}}.topbar-logo{height:24px;object-fit:contain;width:auto}.topbar-title{color:#16a34a;font-size:24px;font-weight:600;margin:0}.topbar-actions{gap:16px}.topbar-actions,.user-badge{align-items:center;display:flex}.user-badge{background:#f1f5f9;border-radius:8px;gap:8px;padding:6px 12px;transition:all .2s ease}.user-badge:hover{background:#e2e8f0;box-shadow:0 2px 4px #0000000d;transform:translateY(-1px)}.user-avatar{font-size:18px}.user-name{color:#475569}.btn-logout,.user-name{font-size:14px;font-weight:500}.btn-logout{background:#ef4444;border:none;border-radius:6px;color:#fff;cursor:pointer;padding:8px 16px;transition:all .2s}.btn-logout:hover{background:#dc2626;box-shadow:0 4px 12px #ef44444d;transform:translateY(-1px)}@media (max-width:768px){.topbar{padding:12px 16px}.menu-toggle{align-items:center;display:flex;justify-content:center}.topbar-title{flex:1 1;font-size:18px}.user-badge{display:none}.btn-logout{font-size:13px;padding:8px 12px}}.profil-overlay{animation:fadeIn .15s ease;background:#0006;bottom:0;left:0;position:fixed;right:0;top:0;z-index:9998}.profil-dialog{animation:slideUp .15s ease;background:#fff;border-radius:16px;box-shadow:0 20px 25px -5px #0000001a,0 10px 10px -5px #0000000a;display:flex;flex-direction:column;left:50%;max-height:90vh;max-width:500px;overflow:hidden;position:fixed;top:50%;transform:translate(-50%,-50%);width:90%;z-index:9999}.profil-header{align-items:center;background:linear-gradient(135deg,#f8fafc,#f1f5f9);border-bottom:1px solid #e5e7eb;display:flex;justify-content:space-between;padding:24px}.profil-header-content{align-items:center;display:flex;gap:16px}.profil-avatar{align-items:center;background:linear-gradient(135deg,#16a34a,#15803d);border-radius:12px;box-shadow:0 4px 6px -1px #16a34a4d;color:#fff;display:flex;height:56px;justify-content:center;width:56px}.profil-header-text h2{color:#0f172a;font-size:20px;font-weight:700;margin:0}.profil-header-text p{color:#64748b;font-size:14px;margin:4px 0 0}.profil-close-btn{align-items:center;background:#0000;border:none;border-radius:8px;color:#64748b;cursor:pointer;display:flex;height:36px;justify-content:center;transition:all .2s ease;width:36px}.profil-close-btn:hover{background:#f1f5f9;color:#0f172a}.profil-body{flex:1 1;overflow-y:auto;padding:24px}.profil-section{display:flex;flex-direction:column;gap:20px}.profil-field{align-items:flex-start;display:flex;gap:12px}.profil-field-icon{align-items:center;background:#f1f5f9;border-radius:10px;color:#16a34a;display:flex;flex-shrink:0;height:40px;justify-content:center;width:40px}.profil-field-content{display:flex;flex:1 1;flex-direction:column;gap:4px}.profil-field-content label{color:#64748b;font-size:13px;font-weight:600;letter-spacing:.5px;text-transform:uppercase}.profil-field-content span{color:#0f172a;font-size:15px;font-weight:500}.profil-role-badge{background:linear-gradient(135deg,#16a34a,#15803d);border-radius:6px;box-shadow:0 2px 4px #16a34a33;color:#fff;display:inline-block;font-size:13px;font-weight:600;padding:6px 12px;text-transform:capitalize}.profil-sites-list{display:flex;flex-wrap:wrap;gap:8px}.profil-site-badge{background:#f1f5f9;border:1px solid #e2e8f0;border-radius:6px;color:#0f172a;font-size:13px;font-weight:500;padding:6px 12px}.profil-no-data{color:#94a3b8;font-style:italic}.profil-footer{background:#fafafa;border-top:1px solid #e5e7eb;display:flex;justify-content:flex-end;padding:16px 24px}.profil-btn-close{background:#f1f5f9;border:none;border-radius:8px;color:#0f172a;cursor:pointer;font-size:14px;font-weight:600;padding:10px 24px;transition:all .2s ease}.profil-btn-close:hover{background:#e2e8f0}@media (max-width:640px){.profil-dialog{max-height:85vh;width:95%}.profil-body,.profil-header{padding:20px}.profil-avatar{height:48px;width:48px}.profil-header-text h2{font-size:18px}}.overview-page{background:linear-gradient(135deg,#f5f7fa,#e9ecef);font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;height:100vh}.overview-main,.overview-page{display:flex;flex:1 1;flex-direction:column}.overview-main{gap:20px;overflow-y:auto;padding:24px}.ov-toolbar{align-items:center;display:flex;justify-content:space-between}.ov-heading{color:#1e293b;font-size:1.35rem;font-weight:700;margin:0}.ov-subheading{color:#64748b;font-size:.85rem;margin:4px 0 0}.ov-year-select{-webkit-appearance:none;appearance:none;background:#fff;border:1px solid #e2e8f0;border-radius:8px;box-shadow:0 1px 3px #0000000f;color:#334155;cursor:pointer;font-size:.9rem;padding:8px 20px 8px 12px;transition:border-color .15s}.ov-year-select:focus{border-color:#059669;outline:none}.ov-kpi-row{grid-gap:16px;display:grid;gap:16px;grid-template-columns:repeat(3,1fr)}.ov-kpi-card{align-items:center;background:#fff;border:1px solid #e2e8f0;border-radius:14px;box-shadow:0 2px 8px #0000000f;cursor:pointer;display:flex;gap:16px;outline:none;padding:20px;transition:all .2s ease}.ov-kpi-card:hover{box-shadow:0 6px 20px #0000001a;transform:translateY(-2px)}.ov-kpi-card:focus-visible{box-shadow:0 0 0 3px #05966940}.ov-kpi-icon{align-items:center;border-radius:12px;display:flex;flex-shrink:0;height:52px;justify-content:center;width:52px}.ov-kpi-carbon .ov-kpi-icon{background:#d1fae5;color:#059669}.ov-kpi-energy .ov-kpi-icon{background:#fef3c7;color:#d97706}.ov-kpi-water .ov-kpi-icon{background:#dbeafe;color:#2563eb}.ov-kpi-content{flex:1 1;min-width:0}.ov-kpi-module{color:#94a3b8;font-size:.7rem;font-weight:700;letter-spacing:.06em;margin-bottom:2px;text-transform:uppercase}.ov-kpi-label{color:#64748b;font-size:.8rem;margin-bottom:4px}.ov-kpi-value{color:#1e293b;font-size:1.5rem;font-weight:700;line-height:1.2}.ov-kpi-unit{color:#64748b;font-size:.78rem;font-weight:500}.ov-kpi-carbon .ov-kpi-value{color:#059669}.ov-kpi-energy .ov-kpi-value{color:#d97706}.ov-kpi-water .ov-kpi-value{color:#2563eb}.ov-kpi-arrow{color:#cbd5e1;flex-shrink:0;transition:transform .15s,color .15s}.ov-kpi-card:hover .ov-kpi-arrow{color:#475569;transform:translateX(3px)}.ov-section{background:#fff;border:1px solid #e2e8f0;border-radius:14px;box-shadow:0 2px 8px #0000000f;padding:24px}.ov-section-featured{border-left:4px solid #059669}.ov-section-header{align-items:center;display:flex;justify-content:space-between;margin-bottom:20px}.ov-section-title-row{align-items:center;display:flex;gap:8px}.ov-section-title{color:#1e293b;font-size:1rem;font-weight:700}.ov-icon-carbon{color:#059669}.ov-icon-energy{color:#d97706}.ov-icon-water{color:#2563eb}.ov-badge-featured{background:#d1fae5;border-radius:999px;color:#059669;font-size:.68rem;font-weight:700;letter-spacing:.05em;padding:2px 8px;text-transform:uppercase}.ov-btn-detail{align-items:center;background:#0000;border:1px solid #e2e8f0;border-radius:8px;color:#475569;cursor:pointer;display:flex;font-size:.82rem;gap:5px;padding:6px 12px;transition:all .15s;white-space:nowrap}.ov-btn-detail:hover{background:#f8fafc;border-color:#059669;color:#059669}.ov-carbon-content{grid-gap:40px;align-items:center;display:grid;gap:40px;grid-template-columns:260px 1fr}.ov-donut-wrap{flex-shrink:0;height:260px;position:relative}.ov-donut-center{left:50%;pointer-events:none;position:absolute;text-align:center;top:50%;transform:translate(-50%,-50%)}.ov-donut-total{color:#1e293b;display:block;font-size:1.3rem;font-weight:800;line-height:1.2}.ov-donut-unit{color:#64748b;font-size:.72rem;font-weight:500}.ov-postes-list{display:flex;flex-direction:column;gap:10px}.ov-poste-row{grid-gap:10px;align-items:center;display:grid;gap:10px;grid-template-columns:10px 100px 1fr 72px 46px}.ov-poste-dot{border-radius:50%;flex-shrink:0;height:10px;width:10px}.ov-poste-name{color:#1e293b;font-size:.83rem;font-weight:600;white-space:nowrap}.ov-poste-bar{background:#f1f5f9;border-radius:999px;height:8px;overflow:hidden}.ov-poste-bar-fill{border-radius:999px;height:100%;transition:width .5s ease}.ov-poste-val{color:#334155;font-size:.82rem;font-weight:700;text-align:right}.ov-poste-pct{color:#64748b;font-size:.78rem;font-weight:600;text-align:right}.ov-modules-row{grid-gap:16px;display:grid;gap:16px;grid-template-columns:1fr 1fr}.ov-bars-list{display:flex;flex-direction:column;gap:13px}.ov-bar-row{grid-gap:10px;align-items:center;display:grid;gap:10px;grid-template-columns:72px 1fr 80px}.ov-bar-label{color:#334155;font-size:.8rem;font-weight:500;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.ov-bar-track{background:#f1f5f9;border-radius:999px;height:10px;overflow:hidden}.ov-bar-fill{border-radius:999px;height:100%;min-width:2px;transition:width .5s ease}.ov-bar-value{color:#475569;font-size:.78rem;font-weight:600;text-align:right;white-space:nowrap}.ov-module-total{border-top:1px solid #f1f5f9;color:#475569;font-size:.83rem;margin-top:4px;padding-top:10px}.ov-loading-block{align-items:center;color:#94a3b8;display:flex;justify-content:center;min-height:120px}.ov-loading-inline{align-items:center;color:#94a3b8;display:inline-flex}.ov-empty{color:#94a3b8;font-size:.85rem;padding:36px 0;text-align:center}@keyframes ov-spin{0%{transform:rotate(0deg)}to{transform:rotate(1turn)}}.ov-spin{animation:ov-spin 1s linear infinite}@media (max-width:1100px){.ov-carbon-content{grid-template-columns:1fr}.ov-donut-wrap{margin:0 auto;max-width:240px}}@media (max-width:900px){.ov-modules-row{grid-template-columns:1fr}}@media (max-width:768px){.overview-main{padding:16px}.ov-kpi-row{grid-template-columns:1fr}}.dashboard-content{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif}@media (max-width:768px){.dashboard-content{margin-left:0!important}}.main-dashboard{gap:16px;padding:20px}.dashboard-header{animation:slideDown .5s ease-out}.header-stats{grid-gap:20px;display:grid;gap:20px;grid-template-columns:repeat(4,1fr)}.stat-card{align-items:center;border-left:4px solid #0000;border-radius:16px;box-shadow:0 4px 6px -1px #0000000d,0 2px 4px -1px #00000008;gap:14px;overflow:hidden;padding:20px;position:relative;transition:all .3s cubic-bezier(.4,0,.2,1)}.stat-card:before{background:linear-gradient(135deg,#0000,#00000005);bottom:0;content:"";left:0;opacity:0;position:absolute;right:0;top:0;transition:opacity .3s ease}.stat-card:hover{box-shadow:0 20px 25px -5px #0000001a,0 10px 10px -5px #0000000a;transform:translateY(-4px)}.stat-card:hover:before{opacity:1}.stat-card-total{border-left-color:#3b82f6}.stat-card-validated{border-left-color:#10b981}.stat-card-pending{border-left-color:#f59e0b}.stat-card-rejected{border-left-color:#ef4444}.stat-icon{align-items:center;border-radius:12px;color:#fff;display:flex;flex-shrink:0;font-size:28px;height:52px;justify-content:center;width:52px}.stat-card-total .stat-icon{background:linear-gradient(135deg,#3b82f6,#2563eb);box-shadow:0 4px 12px #3b82f64d}.stat-card-validated .stat-icon{background:linear-gradient(135deg,#10b981,#059669);box-shadow:0 4px 12px #10b9814d}.stat-card-pending .stat-icon{background:linear-gradient(135deg,#f59e0b,#d97706);box-shadow:0 4px 12px #f59e0b4d}.stat-card-rejected .stat-icon{background:linear-gradient(135deg,#ef4444,#dc2626);box-shadow:0 4px 12px #ef44444d}.stat-info{flex:1 1}.stat-value{color:#1e293b;font-size:28px;line-height:1;margin-bottom:4px}.stat-label{font-size:14px;font-weight:500;margin-top:4px}.stat-percentage{background:#d1fae5;border-radius:6px;color:#10b981;display:inline-block;font-size:13px;font-weight:600;margin-top:4px;padding:2px 8px}.filters-card{animation:slideDown .5s ease-out .1s backwards;background:#fff;border-radius:16px;box-shadow:0 4px 6px -1px #0000000d,0 2px 4px -1px #00000008;padding:18px 20px}.filters-header{justify-content:space-between;margin-bottom:16px}.filters-header,.filters-title{align-items:center;display:flex}.filters-title{color:#1e293b;font-size:18px;font-weight:600;gap:8px;margin:0}.btn-reset{background:linear-gradient(135deg,#f1f5f9,#e2e8f0);border:none;border-radius:8px;color:#475569;cursor:pointer;font-size:14px;font-weight:500;padding:8px 16px;transition:all .2s ease}.btn-reset:hover{background:linear-gradient(135deg,#e2e8f0,#cbd5e1);box-shadow:0 4px 8px #0000001a;transform:translateY(-1px)}.filters-grid{grid-gap:20px;display:grid;gap:20px;grid-template-columns:repeat(2,1fr);margin-bottom:16px}.filter-label{color:#334155;font-size:14px;font-weight:600;margin-bottom:4px}.filter-select{-webkit-appearance:none;appearance:none;background:#fff;background-image:url("data:image/svg+xml;charset=utf-8,%3Csvg xmlns='http://www.w3.org/2000/svg' width='16' height='16'%3E%3Cpath fill='%23334155' d='M8 11 3 6h10z'/%3E%3C/svg%3E");background-position:right 12px center;background-repeat:no-repeat;border:2px solid #e2e8f0;border-radius:10px;color:#1e293b;cursor:pointer;font-size:14px;font-weight:500;padding:12px 40px 12px 16px;transition:all .2s ease}.filter-select:hover{background-color:#f8fafc;border-color:#cbd5e1}.filter-select:focus{border-color:#10b981;box-shadow:0 0 0 4px #10b9811a;outline:none}.filter-select:disabled{background-color:#f1f5f9;cursor:not-allowed;opacity:.6}.filter-tags{display:flex;flex-wrap:wrap;gap:8px;min-height:32px}.filter-tag{align-items:center;animation:popIn .3s cubic-bezier(.68,-.55,.265,1.55);background:linear-gradient(135deg,#10b981,#059669);border-radius:8px;color:#fff;display:inline-flex;font-size:13px;font-weight:500;gap:8px;padding:6px 12px}@keyframes popIn{0%{opacity:0;transform:scale(.5)}to{opacity:1;transform:scale(1)}}.filter-tag-remove{align-items:center;background:#fff3;border:none;border-radius:50%;color:#fff;cursor:pointer;display:flex;font-size:16px;height:20px;justify-content:center;line-height:1;padding:0;transition:all .2s ease;width:20px}.filter-tag-remove:hover{background:#ffffff4d;transform:rotate(90deg)}.calendar-card{animation:slideDown .5s ease-out .2s backwards;background:#fff;border-radius:16px;box-shadow:0 4px 6px -1px #0000000d,0 2px 4px -1px #00000008;display:flex;flex:1 1;flex-direction:column;min-height:600px;padding:24px}.calendar-header{align-items:center;border-bottom:2px solid #f1f5f9;display:flex;justify-content:space-between;margin-bottom:24px;padding-bottom:16px}.calendar-title{-webkit-text-fill-color:#0000;align-items:center;background:linear-gradient(135deg,#10b981,#059669);-webkit-background-clip:text;background-clip:text;color:#1e293b;display:flex;font-size:22px;font-weight:700;gap:8px;margin:0}.calendar-legend{align-items:center;display:flex;gap:20px}.legend-dot{border-radius:50%;box-shadow:0 2px 4px #0000001a;height:12px;width:12px}.legend-label{color:#64748b;font-size:13px;font-weight:500}.calendar-container{border:2px solid #f1f5f9;border-radius:12px;display:flex;flex:1 1;overflow:hidden}.calendar-table-wrapper{-webkit-overflow-scrolling:touch;height:100%;overflow-x:auto;overflow-y:auto;width:100%}.calendar-table{border-collapse:initial;border-spacing:0;min-width:1200px;table-layout:auto;width:100%}.calendar-table thead{background:linear-gradient(135deg,#f8fafc,#f1f5f9);position:-webkit-sticky;position:sticky;top:0;z-index:10}.calendar-header-month,.calendar-header-site{border-bottom:2px solid #e2e8f0;color:#475569;font-size:13px;font-weight:700;letter-spacing:.5px;padding:16px 12px;text-align:center;text-transform:uppercase}.calendar-header-site{background:linear-gradient(135deg,#f8fafc,#f1f5f9);left:0;max-width:140px;position:-webkit-sticky;position:sticky;text-align:left;width:140px;z-index:11}.calendar-row{transition:all .2s ease}.calendar-row:hover{background:#f8fafc}.calendar-cell-site{background:#fff;border-bottom:1px solid #f1f5f9;font-size:12px;font-weight:500;left:0;max-width:140px;padding:12px 10px;position:-webkit-sticky;position:sticky;transition:all .2s ease;width:140px;z-index:5}.calendar-row:hover .calendar-cell-site{background:#f8fafc}.calendar-cell{border-bottom:1px solid #f1f5f9;border-right:1px solid #f1f5f9;padding:10px 6px;text-align:center;transition:all .2s ease}.calendar-cell.has-data{background:linear-gradient(135deg,#fff,#f9fafb)}.calendar-cell:hover.has-data{background:linear-gradient(135deg,#f0fdf4,#dcfce7);box-shadow:0 4px 12px #10b98126;cursor:pointer;transform:scale(1.02)}.cell-content{align-items:center;display:flex;flex-direction:column;gap:8px}.status-indicators{flex-wrap:wrap;gap:4px}.status-badge,.status-indicators{display:flex;justify-content:center}.status-badge{border-radius:8px;box-shadow:0 2px 4px #0000001a;color:#fff;height:40px;transition:all .2s ease;width:40px}.status-badge:hover{box-shadow:0 4px 8px #0003;transform:scale(1.15)}.status-badge.validated{background:linear-gradient(135deg,#10b981,#059669)}.status-badge.pending{background:linear-gradient(135deg,#f59e0b,#d97706)}.status-badge.rejected{background:linear-gradient(135deg,#ef4444,#dc2626)}.cell-empty{color:#cbd5e1;font-size:16px;font-weight:300}.saisie-tooltip{animation:tooltipFadeIn .2s ease-out;background:#fff;border:2px solid #f1f5f9;border-radius:12px;box-shadow:0 20px 25px -5px #00000026,0 10px 10px -5px #0000001a;min-width:280px;padding:16px;pointer-events:none;position:fixed;z-index:1000}@keyframes tooltipFadeIn{0%{opacity:0;transform:translateY(-8px)}to{opacity:1;transform:translateY(0)}}.tooltip-header{align-items:center;border-bottom:2px solid #f1f5f9;color:#1e293b;display:flex;font-size:15px;font-weight:700;gap:8px;margin-bottom:12px;padding-bottom:12px}.tooltip-status-indicator{border-radius:50%;box-shadow:0 2px 4px #0003;height:10px;width:10px}.tooltip-content{display:flex;flex-direction:column;gap:8px}.tooltip-row{align-items:center;display:flex;gap:16px;justify-content:space-between}.tooltip-label{color:#64748b;font-size:13px;font-weight:500}.tooltip-value{color:#1e293b;font-size:13px;font-weight:600;text-align:right}.loading-state{padding:80px 20px}.spinner{animation:spin .8s linear infinite;border:4px solid #f1f5f9;border-radius:50%;border-top-color:#10b981;height:48px;width:48px}.loading-state p{color:#64748b;font-size:15px;font-weight:500}.empty-state{align-items:center;display:flex;flex-direction:column;justify-content:center;padding:80px 20px}.empty-icon{color:#94a3b8;margin-bottom:16px;opacity:.4}.empty-state h3{color:#1e293b;font-size:20px;font-weight:700;margin:0 0 8px}.empty-state p{color:#64748b;font-size:14px;line-height:1.6;margin:0}@media (max-width:1400px){.header-stats{grid-template-columns:repeat(2,1fr)}}@media (max-width:1024px){.main-dashboard{gap:12px;padding:16px}.filters-grid{gap:16px;grid-template-columns:1fr}.header-stats{gap:16px;grid-template-columns:repeat(2,1fr)}.stat-card{padding:16px}.stat-icon{height:48px;width:48px}.stat-icon,.stat-value{font-size:24px}.stat-label{font-size:13px}.calendar-header{align-items:flex-start;flex-direction:column;gap:16px}.calendar-legend{flex-wrap:wrap}.calendar-card{min-height:500px;padding:20px}.calendar-title{font-size:20px}.calendar-header-site{font-size:12px}.calendar-cell-site,.calendar-header-site{max-width:120px;width:120px}.calendar-header-month{font-size:11px;padding:12px 8px}.filters-card{padding:16px}.filters-title{font-size:16px}}@media (max-width:768px){.dashboard-content{margin-left:0}.main-dashboard{gap:12px;padding:12px}.header-stats{gap:12px;grid-template-columns:1fr}.stat-card{gap:12px;padding:14px}.stat-icon{height:44px;width:44px}.stat-icon,.stat-value{font-size:22px}.stat-label{font-size:12px}.stat-percentage{font-size:11px;padding:2px 6px}.filters-card{padding:14px}.filters-title{font-size:15px}.filters-grid,.filters-header{margin-bottom:12px}.filters-grid{gap:12px}.filter-label{font-size:13px}.filter-select{font-size:13px;padding:10px 36px 10px 14px}.btn-reset{font-size:13px;padding:7px 14px}.filter-tag{font-size:12px;padding:5px 10px}.calendar-card{max-height:70vh;min-height:auto;padding:12px}.calendar-header{align-items:flex-start;flex-direction:column;gap:12px;margin-bottom:12px;padding-bottom:10px}.calendar-title{font-size:16px}.calendar-legend{flex-wrap:wrap;gap:8px}.legend-label{font-size:11px}.legend-dot{height:8px;width:8px}.calendar-container{-webkit-overflow-scrolling:touch;overflow-x:auto}.calendar-table{min-width:800px}.calendar-header-site{font-size:10px;max-width:90px;padding:10px 6px;width:90px}.calendar-cell-site{max-width:90px;padding:8px 6px;width:90px}.calendar-header-month{font-size:9px;min-width:50px;padding:8px 4px}.calendar-cell{min-width:50px;padding:6px 3px}.status-badge{height:28px;width:28px}.cell-empty,.status-badge{font-size:12px}.saisie-tooltip{min-width:240px;padding:12px}.tooltip-header{font-size:13px;margin-bottom:10px;padding-bottom:10px}.tooltip-label,.tooltip-value{font-size:12px}.empty-state,.loading-state{padding:60px 16px}.spinner{height:40px;width:40px}.empty-state h3{font-size:18px}.empty-state p{font-size:13px}}@media (max-width:480px){.main-dashboard{gap:10px;padding:10px}.header-stats{gap:10px}.stat-card{align-items:flex-start;flex-direction:column;gap:10px;padding:12px}.stat-icon{height:40px;width:40px}.stat-icon,.stat-value{font-size:20px}.stat-label{font-size:11px}.stat-percentage{font-size:10px;padding:2px 5px}.filters-card{padding:12px}.filters-header{align-items:flex-start;flex-direction:column;gap:10px}.filters-title{font-size:14px}.btn-reset{padding:8px 12px;width:100%}.btn-reset,.filter-label{font-size:12px}.filter-select{font-size:12px;min-height:44px;padding:9px 32px 9px 12px}.filter-tag{font-size:11px;padding:4px 8px}.filter-tag-remove{font-size:14px;height:18px;width:18px}.calendar-card{max-height:60vh;min-height:auto;padding:8px}.calendar-header{align-items:flex-start;flex-direction:column;gap:8px;margin-bottom:8px;padding-bottom:8px}.calendar-title{font-size:14px}.calendar-legend{flex-wrap:wrap;gap:6px}.legend-item,.legend-label{font-size:10px}.legend-dot{height:6px;width:6px}.calendar-container{-webkit-overflow-scrolling:touch;overflow-x:auto}.calendar-table{min-width:700px}.calendar-header-site{font-size:9px;max-width:70px;padding:8px 4px;width:70px}.calendar-cell-site{max-width:70px;padding:6px 4px;width:70px}.site-name{font-size:10px}.calendar-header-month{font-size:8px;min-width:45px;padding:6px 3px}.calendar-cell{min-width:45px;padding:4px 2px}.status-badge{height:24px;width:24px}.cell-empty,.status-badge{font-size:10px}.saisie-tooltip{font-size:11px;min-width:200px;padding:10px}.tooltip-header{font-size:12px;margin-bottom:8px;padding-bottom:8px}.tooltip-label,.tooltip-value{font-size:11px}.empty-state,.loading-state{padding:40px 12px}.spinner{border-width:3px;height:36px;width:36px}.loading-state p{font-size:13px}.empty-state h3{font-size:16px}.empty-state p{font-size:12px}}.dashboard-wrapper{background:#f8fafc;display:flex;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;height:100vh;overflow:hidden}.esg-indicators-page{background:#f8fafc;flex:1 1;height:100vh;max-width:none;overflow-y:auto;padding:32px}.page-header h1{color:#0f172a;margin:0 0 8px}.score-cards-grid{grid-gap:16px;display:grid;gap:16px;grid-template-columns:repeat(3,1fr);margin-bottom:32px}.score-card{background:#fff;border-radius:12px;box-shadow:0 1px 3px #0000001a;padding:16px;transition:all .3s}.score-card:hover{box-shadow:0 8px 24px #0000001f;transform:translateY(-4px)}.score-card-header{align-items:flex-start;display:flex;justify-content:space-between;margin-bottom:16px}.score-label{color:#64748b;font-size:14px;font-weight:500}.score-icon{font-size:20px;opacity:.8}.score-value{font-size:30px;font-weight:700;line-height:1.2;margin-bottom:12px}.score-value.green{color:#16a34a}.score-value.blue{color:#3b82f6}.score-value.purple{color:#8b5cf6}.score-change{color:#64748b;font-size:12px;margin:0}.progress-bar{background-color:#e2e8f0;border-radius:4px;height:8px;overflow:hidden;width:100%}.progress-fill{background-color:#16a34a;border-radius:4px;height:100%;transition:width .3s ease}.badge{background-color:#f1f5f9;border-radius:4px;color:#475569;display:inline-block;font-size:12px;font-weight:500;padding:4px 8px}.trend-icon{font-size:16px}.trend-icon.up{color:#16a34a}.trend-icon.down{color:#ef4444}.trend-icon.stable{color:#64748b}.trend-text{color:#16a34a;font-size:12px;margin-left:4px}.esg-section{margin-bottom:32px}.section-title{align-items:center;color:#0f172a;display:flex;font-size:24px;font-weight:600;gap:8px;margin-bottom:16px}.section-icon{font-size:24px}.section-icon.green{color:#16a34a}.section-icon.blue{color:#3b82f6}.section-icon.purple{color:#8b5cf6}.expandable-card{background:#fff;border-radius:12px;box-shadow:0 1px 3px #0000001a;margin-bottom:16px;overflow:hidden}.expandable-header{align-items:center;background:none;border:none;cursor:pointer;display:flex;justify-content:space-between;padding:20px;text-align:left;transition:background-color .2s ease;width:100%}.expandable-header:hover{background-color:#f8fafc}.expandable-title{align-items:center;display:flex;gap:12px}.icon-container{align-items:center;border-radius:8px;display:flex;height:48px;justify-content:center;width:48px}.icon-container.yellow{background-color:#fef3c7}.icon-container.blue{background-color:#dbeafe}.icon-container.green{background-color:#dcfce7}.icon-container.cyan{background-color:#cffafe}.icon-container.teal{background-color:#ccfbf1}.icon-container.emerald{background-color:#d1fae5}.icon-container.lime{background-color:#f7fee7}.icon-container.indigo{background-color:#e0e7ff}.icon-container.violet{background-color:#ede9fe}.icon-container.sky{background-color:#e0f2fe}.icon-container.fuchsia{background-color:#fdf4ff}.icon-container.pink{background-color:#fdf2f8}.icon-container.purple{background-color:#f3e8ff}.icon{font-size:24px}.expandable-title h3{color:#0f172a;font-size:18px;font-weight:600;margin:0 0 4px}.expandable-title p{color:#64748b;font-size:14px;margin:0}.expandable-metrics{align-items:flex-end;display:flex;flex-direction:column;gap:4px}.metric-value{font-size:24px;font-weight:700;line-height:1.2}.metric-value.yellow{color:#d97706}.metric-value.blue{color:#2563eb}.metric-value.green{color:#16a34a}.metric-value.cyan{color:#06b6d4}.metric-value.teal{color:#14b8a6}.metric-value.emerald{color:#10b981}.metric-value.lime{color:#84cc16}.metric-value.indigo{color:#4f46e5}.metric-value.violet{color:#7c3aed}.metric-value.sky{color:#0284c7}.metric-value.fuchsia{color:#a21caf}.metric-value.pink{color:#db2777}.metric-value.purple{color:#7e22ce}.metric-label{color:#64748b;font-size:12px;margin:0}.expand-icon{color:#94a3b8;font-size:16px;margin-left:16px}.expandable-content{animation:slideDown .3s ease;border-top:1px solid #e2e8f0;padding:0 20px 20px}.metrics-grid{grid-gap:16px;display:grid;gap:16px;grid-template-columns:repeat(3,1fr);margin-bottom:24px}.metric-card{border-radius:8px;padding:16px}.metric-card.yellow{background-color:#fef3c7}.metric-card.green{background-color:#dcfce7}.metric-card.blue{background-color:#dbeafe}.metric-card.cyan{background-color:#cffafe}.metric-card.teal{background-color:#ccfbf1}.metric-card.emerald{background-color:#d1fae5}.metric-card.lime{background-color:#f7fee7}.metric-card.indigo{background-color:#e0e7ff}.metric-card.violet{background-color:#ede9fe}.metric-card.sky{background-color:#e0f2fe}.metric-card.fuchsia{background-color:#fdf4ff}.metric-card.pink{background-color:#fdf2f8}.metric-card.purple{background-color:#f3e8ff}.metric-title{color:#475569;font-size:14px;margin:0 0 8px}.metric-card .metric-value{font-size:24px;font-weight:700;margin-bottom:8px}.trend{align-items:center;display:flex}.bar-chart-container,.line-chart-container{align-items:center;display:flex;flex-direction:column;overflow-x:auto}.chart-legend{display:flex;gap:24px;justify-content:center;margin-top:16px}.legend-item{align-items:center;color:#334155;display:flex;font-size:14px;gap:8px}.legend-color{border-radius:2px;height:12px;width:12px}.legend-line{border-radius:1px;height:3px;width:24px}.governance-metrics{grid-gap:16px;display:grid;gap:16px;grid-template-columns:repeat(2,1fr);margin-top:24px}.governance-metric{border:1px solid #e2e8f0;border-radius:8px;padding:16px}.metric-header{align-items:center;display:flex;justify-content:space-between;margin-bottom:8px}@media (max-width:1440px){.metrics-grid,.score-cards-grid{grid-template-columns:repeat(2,1fr)}}@media (max-width:768px){.esg-indicators-page{padding:16px}.page-header{margin-bottom:24px}.page-header h1{font-size:24px}.page-header p{font-size:14px}.score-cards-grid{gap:14px;grid-template-columns:1fr;margin-bottom:24px}.score-card{padding:14px}.score-label{font-size:13px}.score-icon{font-size:18px}.score-value{font-size:26px;margin-bottom:10px}.badge,.score-change{font-size:11px}.badge{padding:3px 7px}.trend-icon{font-size:14px}.trend-text{font-size:11px}.section-title{font-size:20px;margin-bottom:14px}.section-icon{font-size:20px}.metrics-grid{gap:14px;grid-template-columns:1fr}.expandable-card{padding:14px}.expandable-title{font-size:15px}.expandable-subtitle{font-size:12px}.expandable-score{font-size:22px}.governance-metrics{gap:14px;grid-template-columns:1fr}.expandable-header{flex-direction:column;gap:16px}.expandable-header,.expandable-metrics{align-items:flex-start}}@media (max-width:480px){.esg-indicators-page{padding:12px}.page-header{margin-bottom:20px}.page-header h1{font-size:20px;margin-bottom:6px}.page-header p{font-size:13px}.score-cards-grid{gap:12px;margin-bottom:20px}.score-card{padding:12px}.score-label{font-size:12px}.score-icon{font-size:16px}.score-value{font-size:24px;margin-bottom:8px}.badge,.score-change{font-size:10px}.badge{padding:3px 6px}.progress-bar{height:6px}.section-title{font-size:18px;margin-bottom:12px}.section-icon{font-size:18px}.esg-section{margin-bottom:24px}.metrics-grid{gap:12px}.expandable-card{padding:12px}.expandable-title{font-size:14px}.expandable-subtitle{font-size:11px}.expandable-score{font-size:20px}.governance-metrics{gap:12px}.metric-header{margin-bottom:6px}.legend-item{font-size:12px}.legend-color{height:10px;width:10px}}.dashboard-content{background:linear-gradient(135deg,#f5f7fa,#e9ecef);box-sizing:border-box;display:flex;flex:1 1;flex-direction:column;height:100vh;margin:0!important;max-width:100%;min-width:0;overflow:hidden;padding:0!important;width:100%}.dashboard-content>.topbar{box-sizing:border-box;flex-shrink:0;margin:0;padding:16px 32px;width:100%}.main-dashboard{margin:0;max-width:100%;min-width:0;overflow-x:hidden;overflow-y:auto;padding:32px;position:relative}.main-dashboard,.organisation-page{box-sizing:border-box;display:flex;flex:1 1;flex-direction:column;width:100%}.organisation-page{gap:24px}.page-header{align-items:center;display:flex;justify-content:space-between;margin-bottom:24px}.page-header h1{color:#1e293b;font-size:28px}.page-header p{color:#64748b;margin:0}.card{background:#fff;border-radius:12px;box-shadow:0 1px 3px #0000001a;display:flex;flex-direction:column;overflow:hidden}.card-header{flex-shrink:0;padding:24px 24px 0}.card-title{color:#1e293b;font-size:18px;font-weight:600;margin:0 0 4px;text-align:left}.card-content{flex:1 1;max-height:400px;min-height:0;overflow-x:hidden;overflow-y:auto}.org-entities-card .card-content{max-height:350px}.user-management-card .card-content{flex:1 1;max-height:500px;min-height:0}.tabs-list{align-items:center;border-bottom:1px solid #e2e8f0;gap:24px;justify-content:center}.tab-button{border-bottom:2px solid #0000;color:#64748b;font-size:14px;padding:12px 16px}.tab-button:hover{color:#334155}.tab-button.active{border-bottom-color:#16a34a;color:#16a34a}.form-section{background:#f8fafc;border-radius:8px;margin-bottom:24px;padding:16px}.form-section h3{color:#1e293b;font-size:16px;font-weight:600;margin-bottom:16px}.form-grid{grid-gap:16px;align-items:center;gap:16px;grid-template-columns:repeat(3,1fr)}.form-grid-2{grid-gap:16px;display:grid;gap:16px;grid-template-columns:repeat(2,1fr)}.form-field{display:flex;flex-direction:column;gap:8px}.form-field.full-width{grid-column:span 2}.form-field label{color:#334155;font-size:14px;font-weight:500;text-align:left}.form-field input,.form-field select{background:#fff;border:1px solid #d1d5db;border-radius:6px;color:#334155;font-size:14px;padding:10px 12px;transition:all .2s}.form-field input:focus,.form-field select:focus{border-color:#16a34a;box-shadow:0 0 0 3px #16a34a1a;outline:none;text-align:left}.input-with-button{display:flex;gap:8px}.input-with-button input{flex:1 1}.btn-add{background:#16a34a;border:none;color:#fff;justify-content:center;padding:0 12px;transition:all .2s}.btn-add:hover{background:#15803d}.table-container{-webkit-overflow-scrolling:touch;border:1px solid #e2e8f0;border-radius:8px;overflow-x:auto;text-align:center;width:100%}.table-container table{border-collapse:collapse;width:100%}.table-container th{background:#f8fafc;border-bottom:1px solid #e2e8f0;color:#334155;font-size:16px;font-weight:600;padding:20px 16px;text-align:center!important}.table-container td{border-bottom:1px solid #f1f5f9;color:#334155;font-size:14px;padding:20px 16px;text-align:center}.table-container tr:last-child td{border-bottom:none}.table-container tr:hover{background:#f6fff4}.table-cell-actions{text-align:center;vertical-align:middle}.action-buttons{display:inline-flex;height:100%;justify-content:center;vertical-align:middle}.row-container,.table-row,.your-row-class{align-items:center;display:flex;justify-content:space-between}.action-buttons{gap:8px}.action-buttons,.btn-icon{align-items:center;display:flex}.btn-icon{background:none;border:none;border-radius:4px;cursor:pointer;justify-content:center;padding:6px;transition:all .2s}.btn-icon:hover{background:#f1f5f9}.btn-edit{color:#3b82f6}.btn-delete,.btn-edit{align-items:center;justify-content:center}.role-badge.agent-de-saisie{background:#dcfce7;color:#16a34a}.toolbar{align-items:center;display:flex;gap:14px;justify-content:space-between;margin-bottom:16px;margin-top:16px;width:100%}.search-bar{flex:1 1;max-width:90%;position:relative}.search-icon{color:#64748b;height:16px;left:12px;position:absolute;top:50%;transform:translateY(-50%);width:16px}.search-bar input{background:#fff;border:1px solid #d1d5db;border-radius:6px;color:#334155;font-size:14px;padding:10px 12px 10px 40px;transition:all .2s;width:100%}.search-bar input:focus{border-color:#16a34a;box-shadow:0 0 0 3px #16a34a1a;outline:none}.btn-primary{align-items:center;background:#16a34a;border:none;border-radius:5px;box-sizing:border-box;cursor:pointer;display:inline-flex;font-size:16px;font-weight:500;justify-content:center;min-width:0;padding:4px 12px;transition:all .2s;white-space:nowrap;width:auto}.btn-primary:hover{background:#15803d}.dialog-overlay{animation:fadeIn .15s ease-out;background:#00000080;z-index:100}.dialog{animation:slideUp .2s ease-out;background:#fff;border-radius:12px;box-shadow:0 10px 25px #0000001a;display:flex;flex-direction:column;max-height:95vh;max-width:600px;min-height:700px;overflow:hidden;padding:24px;width:90%}.dialog-header{align-items:center;padding:20px 24px 16px}.dialog-header h3{color:#1e293b;font-size:18px;font-weight:600;margin:0}.dialog-content{padding:20px 24px}.dialog-description{color:#64748b;font-size:14px;margin:0 0 20px}.dialog-footer{border-top:1px solid #e2e8f0;display:flex;gap:12px;justify-content:flex-end;padding:16px 24px 20px}.btn-secondary{background:#fff;border:1px solid #d1d5db;border-radius:6px;color:#334155;cursor:pointer;font-size:14px;font-weight:500;padding:8px 16px;transition:all .2s}.btn-secondary:hover{background:#f8fafc}.entitymanager-toolbar{display:flex;justify-content:space-between;margin-bottom:16px}.search-input{border:1px solid #ccc;border-radius:6px;box-sizing:border-box;height:36px;max-width:1200px;padding:6px 10px;width:85%}@media (max-width:1200px){.form-grid{grid-template-columns:repeat(2,1fr)}.org-entities-card .card-content{max-height:300px}.user-management-card .card-content{max-height:450px}}@media (max-width:768px){.page-header{align-items:flex-start;flex-direction:column;gap:16px;margin-bottom:20px}.page-header h1{font-size:24px;margin-bottom:6px}.page-header p{font-size:14px}.config-button{font-size:14px;justify-content:center;min-height:44px;padding:12px 18px;width:100%}.main-dashboard{gap:12px;padding:12px}.card-header{padding:16px 16px 0}.card-title{font-size:16px}.card-content{max-height:350px;padding:16px}.form-section h3{font-size:15px;margin-bottom:14px}.form-grid,.form-grid-2{gap:14px;grid-template-columns:1fr}.form-field.full-width{grid-column:span 1}.form-field label{font-size:13px}.form-field input,.form-field select{font-size:13px;min-height:44px;padding:10px 12px}.tabs-list{-webkit-overflow-scrolling:touch;flex-direction:row;gap:16px;overflow-x:auto}.tab-button{font-size:13px;padding:10px 14px;white-space:nowrap}.table-container th{font-size:14px;padding:14px 12px}.table-container td{font-size:13px;padding:14px 12px}.btn-add{font-size:13px;padding:0 10px}.card-header-flex{align-items:flex-start;flex-direction:column;gap:16px}.toolbar{align-items:stretch;flex-direction:column;gap:12px;width:100%}.toolbar button,.toolbar input{min-height:44px;width:100%}.toolbar button{font-size:13px}.dialog{max-height:90vh;min-height:auto;padding:20px;width:95%}.dialog h2{font-size:18px}.org-entities-card .card-content{max-height:250px}.user-management-card .card-content{max-height:350px}}@media (max-width:480px){.page-header{gap:12px;margin-bottom:16px}.page-header h1{font-size:20px;margin-bottom:4px}.page-header p{font-size:13px}.config-button{font-size:13px;gap:8px;padding:10px 16px}.main-dashboard{gap:10px;padding:10px}.card-header{padding:14px 14px 0}.card-title{font-size:15px}.card-content{max-height:300px;padding:14px}.form-section{margin-bottom:20px;padding:14px}.form-section h3{font-size:14px;margin-bottom:12px}.form-grid,.form-grid-2{gap:12px}.form-field label{font-size:12px}.form-field input,.form-field select{font-size:12px;padding:9px 10px}.tabs-list{gap:12px}.tab-button{font-size:12px;padding:9px 12px}.table-container th{font-size:13px;padding:12px 10px}.table-container td{font-size:12px;padding:12px 10px}.action-buttons{gap:6px}.toolbar input{font-size:12px;padding:9px 10px}.toolbar button{font-size:12px;padding:9px 12px}.dialog{padding:16px}.dialog h2{font-size:16px;margin-bottom:14px}.dialog label{font-size:12px}.dialog input,.dialog select{font-size:12px;padding:9px 10px}}.config-dialog-overlay{align-items:center;animation:configFadeIn .2s ease-out;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);background:#0f172a66;bottom:0;display:flex;justify-content:center;left:0;padding:20px;position:fixed;right:0;top:0;z-index:1000}@keyframes configFadeIn{0%{opacity:0}to{opacity:1}}@keyframes configSlideUp{0%{opacity:0;transform:translateY(16px) scale(.97)}to{opacity:1;transform:translateY(0) scale(1)}}.config-dialog{animation:configSlideUp .25s ease-out;background:#fff;border-radius:16px;box-shadow:0 20px 60px #00000026,0 0 0 1px #0000000d;display:flex;flex-direction:column;height:90vh;overflow:hidden;transition:all .3s ease;width:95vw}.config-dialog.compact{height:auto;max-height:400px;width:600px}.config-dialog.expanded{height:90vh;width:95vw}.config-dialog-header{align-items:center;background:linear-gradient(135deg,#6366f1,#8b5cf6);border-bottom:1px solid #f1f5f9;color:#fff;display:flex;justify-content:space-between;padding:20px 24px}.header-content{gap:12px}.header-icon{color:#fff}.config-dialog-header h2{color:#fff;font-size:17px;font-weight:600;margin:0}.config-dialog-header p{color:#fffc;font-size:13px;margin:3px 0 0}.close-button{align-items:center;background:#fff3;border:none;border-radius:8px;color:#fff;cursor:pointer;display:flex;justify-content:center;padding:6px;transition:all .2s}.close-button:hover{background:#ffffff4d}.config-dialog-body{flex:1 1;overflow-y:auto;padding:24px}.loading-state{flex-direction:column;gap:16px;padding:60px 20px}.loading-spinner{border:3px solid #e5e7eb;border-top-color:#6366f1;height:40px;width:40px}.sites-section{margin-bottom:32px}.sites-section h3{color:#111827;font-size:16px;font-weight:600;margin:0 0 16px}.site-select-wrapper{max-width:400px;position:relative}.site-select-wrapper label{align-items:center;color:#475569;display:flex;font-size:13px;font-weight:600;gap:6px;letter-spacing:.5px;margin-bottom:6px;text-transform:uppercase}.site-select{appearance:none;-webkit-appearance:none;-moz-appearance:none;background:#f8fafc;border:2px solid #e2e8f0;border-radius:10px;color:#1e293b;cursor:pointer;font-size:14px;font-weight:500;outline:none;padding:10px 14px;transition:all .2s;width:100%}.site-select:focus{background:#fff;border-color:#6366f1;box-shadow:0 0 0 3px #6366f11a}.site-select:hover{border-color:#cbd5e1}.select-icon{color:#6b7280;pointer-events:none;position:absolute;right:12px;top:50%;transform:translateY(-50%)}.selected-site-info{margin-top:16px}.site-info-card{background:#0000;border:none;border-radius:8px;max-width:400px;padding:0}.site-info-name{color:#1e293b;font-weight:600;margin-bottom:4px}.site-info-validation{background:#eef2ff;border-radius:8px;color:#6366f1;display:inline-block;font-size:13px;font-weight:600;padding:4px 10px}.postes-section{display:flex;flex-direction:column;height:100%;overflow:hidden}.postes-section h3{color:#111827;font-size:16px;font-weight:600;margin:0 0 16px}.postes-tabs{gap:6px}.poste-tab{border-radius:8px 8px 0 0;font-size:14px;padding:10px 20px}.poste-tab:hover{background:#eef2ff;color:#6366f1}.poste-tab.active{border-bottom-color:#6366f1;color:#6366f1}.poste-tab-badge{background:#eef2ff;color:#6366f1}.poste-tab.active .poste-tab-badge{background:#6366f1}.poste-content{overflow:hidden}.poste-info{align-items:center;display:flex;gap:12px}.poste-icon{color:#6b7280}.poste-name{color:#111827;font-size:15px;font-weight:600;text-transform:capitalize}.selected-count{background:#eef2ff;border-radius:12px;color:#6366f1;font-size:13px;font-weight:500;padding:4px 8px}.indicateurs-section{background:#fafbfc;border-top:2px solid #e5e7eb;margin-top:20px;max-height:500px;overflow-y:auto}.indicateurs-grid{grid-gap:14px;display:grid;gap:14px;grid-template-columns:repeat(auto-fill,minmax(220px,1fr));padding:8px}@media (max-width:1400px){.indicateurs-grid{grid-template-columns:repeat(auto-fill,minmax(200px,1fr))}}@media (max-width:1000px){.indicateurs-grid{grid-template-columns:repeat(auto-fill,minmax(180px,1fr))}}@media (max-width:768px){.indicateurs-grid{grid-template-columns:repeat(auto-fill,minmax(160px,1fr))}}.indicateur-item{display:flex;flex-direction:column;gap:8px}.indicateur-checkbox{align-items:flex-start;background:#f8fafc;border:2px solid #e2e8f0;border-radius:10px;cursor:pointer;display:flex;font-size:13px;gap:10px;min-height:60px;padding:12px 14px;transition:all .2s ease}.indicateur-checkbox:hover{background:#eef2ff;border-color:#6366f1;box-shadow:0 4px 6px -1px #6366f126;transform:translateY(-1px)}.indicateur-checkbox input[type=checkbox]{accent-color:#6366f1;cursor:pointer;flex-shrink:0;height:18px;margin-top:2px;width:18px}.obligatoire-checkbox{align-items:center;background:#fef3c7;border:2px solid #fbbf24;border-radius:8px;box-shadow:0 1px 2px 0 #0000000d;cursor:pointer;display:flex;gap:8px;margin-left:28px;padding:8px 12px;transition:all .2s ease}.obligatoire-checkbox:hover{background:#fef2e8;border-color:#f59e0b;box-shadow:0 2px 4px -1px #f59e0b33}.obligatoire-checkbox input[type=checkbox]{accent-color:#f59e0b;cursor:pointer;flex-shrink:0;height:16px;margin:0;width:16px}.obligatoire-label{color:#92400e;font-size:12px;font-weight:600}.checkbox-content{display:flex;flex:1 1;flex-direction:column;gap:4px;min-width:0}.indicateur-name{color:#1f2937;display:block;font-size:13px;font-weight:600;line-height:1.4;margin-bottom:2px}.indicateur-description{color:#6b7280;font-size:11px;line-height:1.3}.config-dialog-footer{align-items:center;background:#f8fafc;border-top:1px solid #f1f5f9;display:flex;gap:10px;justify-content:flex-end;padding:16px 24px}.btn-cancel,.btn-save{border:none;border-radius:10px;cursor:pointer;font-size:14px;font-weight:600;padding:10px 24px;transition:all .2s ease}.btn-cancel{background:#fff;border:2px solid #e2e8f0}.btn-cancel:hover{background:#f8fafc;border-color:#cbd5e1}.btn-save{background:linear-gradient(135deg,#6366f1,#8b5cf6);box-shadow:0 4px 12px #6366f140}.btn-save:hover:not(:disabled){box-shadow:0 6px 16px #6366f159}.btn-save:disabled{cursor:not-allowed;opacity:.5;transform:none}.poste-id{color:#6b7280;font-size:12px;margin-left:8px}.indicateurs-error{background:#fef2f2;border:1px solid #fecaca;border-radius:10px;color:#dc2626;margin:16px;padding:16px}.error-content{align-items:flex-start;display:flex;gap:12px}.error-icon{color:#dc2626;flex-shrink:0;margin-top:2px}.error-details{display:flex;flex:1 1;flex-direction:column;gap:4px}.error-title{font-size:14px;font-weight:600}.error-message{color:#991b1b;font-size:13px}.error-poste{color:#7f1d1d;font-size:12px;font-style:italic}.retry-button{align-items:center;background:#dc2626;border:none;border-radius:8px;color:#fff;cursor:pointer;display:flex;flex-shrink:0;font-size:12px;gap:6px;padding:6px 12px;transition:background-color .2s}.retry-button:hover{background:#b91c1c}.indicateurs-loading{align-items:center;color:#6b7280;display:flex;gap:12px;padding:24px}.loading-spinner-small{border:3px solid #e5e7eb;border-top-color:#6366f1;height:24px;width:24px}.no-indicateurs{color:#6b7280;font-size:14px;padding:24px;text-align:center}@media (max-width:768px){.config-dialog{margin:10px;max-height:calc(100vh - 20px)}.site-info-card,.site-select-wrapper{max-width:100%}.indicateurs-grid{grid-template-columns:1fr}}body,html{background:#0000;overflow:auto}.login-wrapper{height:100vh;left:0;margin:0;padding:0;position:fixed;top:0;width:100vw;z-index:1}.container,.login-wrapper{align-items:center;display:flex;justify-content:center}.container{background:#fff;border-radius:18px;box-shadow:0 12px 30px #00000026;box-sizing:border-box;flex-direction:column;max-width:450px;padding:60px 40px;position:relative;transform:scale(.9);width:100%;z-index:2}.logo{height:auto;margin-bottom:30px;margin-top:20px;object-fit:contain;width:180px}.header{align-items:center;display:flex;flex-direction:column}.text{color:#3c009d;font-size:52px;font-weight:700}.underline{animation:underlineSlide 1.5s ease-in-out infinite alternate;background:linear-gradient(90deg,#679436,#a4bd01);border-radius:2px;height:5px;width:80px}@keyframes underlineSlide{0%{opacity:.8;width:60px}to{opacity:1;width:100px}}.inputs{flex-direction:column;gap:25px;margin-top:50px}.input,.inputs{display:flex;width:100%}.input{align-items:center;background:#eaeaea;border-radius:8px;box-sizing:border-box;height:80px;padding:0 20px}.input img{margin-right:15px;width:28px}.input input{background:#0000;border:none;color:#797979;flex:1 1;font-size:20px;outline:none}.forgot-password{color:#797979;font-size:19px;margin:35px auto 0;text-align:center}.forgot-password span{color:#a4bd01;cursor:pointer;font-weight:600}.submit-container{margin:50px auto 0;width:100%}.submit,.submit-container{display:flex;justify-content:center}.submit{align-items:center;background:#679436;border-radius:50px;color:#fff;cursor:pointer;font-size:22px;font-weight:700;height:65px;transition:background .3s ease,transform .2s ease;width:85%}.submit:hover{background:#427aa1;transform:scale(1.03)}@media (max-width:1024px){.container{max-width:420px;padding:50px 35px;transform:scale(.95)}.logo{margin-bottom:25px;margin-top:18px;width:160px}.text{font-size:48px}.underline{height:4px;width:70px}.inputs{gap:22px;margin-top:45px}.input{height:75px;padding:0 18px}.input img{margin-right:14px;width:26px}.input input{font-size:19px}.forgot-password{font-size:18px;margin-top:30px}.submit-container{margin-top:45px}.submit{font-size:20px;height:60px}}@media (max-width:768px){.login-wrapper{padding:20px}.container{border-radius:16px;max-width:380px;padding:40px 30px;transform:scale(1)}.logo{margin-bottom:20px;margin-top:15px;width:140px}.text{font-size:40px}.underline{height:4px;width:60px}.inputs{gap:18px;margin-top:35px}.input{height:65px;padding:0 16px}.input img{margin-right:12px;width:24px}.input input{font-size:17px}.forgot-password{font-size:16px;margin-top:25px}.submit-container{margin-top:35px}.submit{font-size:18px;height:55px;min-height:44px;width:90%}}@media (max-width:480px){.login-wrapper{padding:15px}.container{border-radius:14px;box-shadow:0 8px 20px #0000001f;max-width:100%;padding:30px 25px}.logo{margin-bottom:18px;margin-top:10px;width:120px}.text{font-size:32px}.underline{height:3px;width:50px}.inputs{gap:16px;margin-top:30px}.input{border-radius:6px;height:56px;padding:0 14px}.input img{margin-right:10px;width:22px}.input input{font-size:15px}.forgot-password{font-size:14px;margin-top:20px}.submit-container{margin-top:30px}.submit{border-radius:40px;font-size:16px;height:50px;min-height:44px;width:100%}}.mcombo{position:relative;width:100%}.mcombo-trigger{align-items:center;background:#fff;border:2px solid #e2e8f0;border-radius:10px;cursor:text;display:flex;min-height:42px;padding:4px 10px 4px 4px;transition:border-color .2s,box-shadow .2s;width:100%}.mcombo-trigger:hover{border-color:#cbd5e1}.mcombo-tags{align-items:center;display:flex;flex:1 1;flex-wrap:nowrap;gap:4px;min-width:0;overflow:hidden;padding:2px 0}.mcombo-placeholder{color:#94a3b8;font-size:14px;padding:0 10px;pointer-events:none}.mcombo-tag{align-items:center;animation:mcomboTagIn .15s ease-out;border:1px solid;border-radius:6px;display:inline-flex;flex-shrink:0;font-size:12px;font-weight:500;gap:4px;max-width:130px;padding:2px 6px 2px 10px;white-space:nowrap}.mcombo-tag--count{flex-shrink:0;font-weight:600;max-width:none;padding:2px 8px}@keyframes mcomboTagIn{0%{opacity:0;transform:scale(.9)}to{opacity:1;transform:scale(1)}}.mcombo-tag-text{overflow:hidden;text-overflow:ellipsis}.mcombo-tag-remove{border-radius:3px;cursor:pointer;flex-shrink:0;opacity:.6;transition:opacity .15s}.mcombo-tag-remove:hover{opacity:1}.mcombo-input{background:#0000;border:none;color:#1e293b;flex:1 1;font-size:14px;min-width:60px;outline:none;padding:6px 10px}.mcombo-input::placeholder{color:#94a3b8}.mcombo-chevron{color:#94a3b8;cursor:pointer;flex-shrink:0;transition:transform .2s}.mcombo-chevron--open{transform:rotate(180deg)}.mcombo-panel{animation:mcomboSlideIn .15s ease-out;background:#fff;border:1.5px solid #e2e8f0;border-radius:10px;box-shadow:0 8px 24px #0000001f}@keyframes mcomboSlideIn{0%{opacity:0;transform:translateY(-4px)}to{opacity:1;transform:translateY(0)}}.mcombo-clear{border-bottom:1px solid #f1f5f9;color:#ef4444;cursor:pointer;font-size:12px;font-weight:500;padding:8px 14px;transition:background .1s}.mcombo-clear:hover{background:#fef2f2}.mcombo-list{max-height:240px;overflow-y:auto;padding:4px 0}.mcombo-item{align-items:center;border-radius:4px;cursor:pointer;display:flex;font-size:14px;gap:10px;margin:0 4px;padding:9px 14px;transition:background .1s}.mcombo-item--selected,.mcombo-item:hover{background:#f8fafc}.mcombo-checkbox{align-items:center;border:2px solid;border-radius:4px;display:flex;flex-shrink:0;height:18px;justify-content:center;transition:all .15s;width:18px}.mcombo-empty{color:#6b7280;font-size:13px;padding:10px 14px}.dashboard-content:has(.carbon-footprint-page){display:flex;flex-direction:column;overflow:hidden}.carbon-footprint-page{background:#f8fafc;flex:1 1;min-height:0;overflow-y:auto}.carbon-content{margin:0 auto;max-width:1440px;padding:28px 32px}.carbon-page-header{align-items:flex-start;display:flex;justify-content:space-between;margin-bottom:24px}.carbon-header-left{align-items:center;display:flex;gap:16px}.carbon-icon-wrapper{align-items:center;background:linear-gradient(135deg,#059669,#10b981);border-radius:14px;box-shadow:0 4px 12px #05966940;color:#fff;display:flex;flex-shrink:0;height:52px;justify-content:center;width:52px}.carbon-title{color:#0f172a;font-size:26px;font-weight:700;line-height:1.2;margin:0 0 2px}.carbon-subtitle{color:#64748b;font-size:14px;margin:0}.carbon-header-badge{align-items:center;background:#f0fdf4;border:1px solid #bbf7d0;border-radius:20px;color:#16a34a;display:flex;font-size:13px;font-weight:500;gap:6px;padding:6px 14px}.carbon-card{background:#fff;border:1px solid #f1f5f9;border-radius:14px;box-shadow:0 1px 3px #0000000a,0 4px 12px #00000005;margin-bottom:20px}.carbon-filter-card{padding:20px 24px}.carbon-filter-header{align-items:center;color:#0f172a;display:flex;font-size:16px;font-weight:600;gap:10px;margin-bottom:18px}.carbon-filters-grid{grid-gap:14px;display:grid;gap:14px;grid-template-columns:repeat(auto-fill,minmax(220px,1fr))}.carbon-filter-item{display:flex;flex-direction:column}.carbon-filter-label{align-items:center;color:#475569;display:flex;font-size:13px;font-weight:500;gap:6px;margin-bottom:6px}.carbon-filter-input{background:#fafbfc;border:1px solid #e2e8f0;border-radius:10px;box-sizing:border-box;color:#1e293b;cursor:pointer;font-size:14px;outline:none;padding:10px 14px;transition:border-color .2s,box-shadow .2s;width:100%}.carbon-filter-input:hover{background:#fff;border-color:#cbd5e1}.carbon-filter-input:focus{background:#fff;border-color:#059669;box-shadow:0 0 0 3px #05966914}.carbon-period-toggle{border:1px solid #e2e8f0;border-radius:8px;display:flex;height:38px;overflow:hidden}.carbon-toggle-btn{background:#0000;border:none;color:#64748b;cursor:pointer;flex:1 1;font-size:12px;font-weight:500;padding:0 10px;transition:background .15s,color .15s}.carbon-toggle-btn.active{background:#059669;color:#fff;font-weight:600}.carbon-loading{align-items:center;color:#64748b;display:flex;font-size:14px;gap:10px;padding:12px 0 20px}.carbon-loading-icon{animation:spin .9s linear infinite;color:#059669}.carbon-empty{align-items:center;color:#94a3b8;display:flex;flex-direction:column;gap:8px;padding:64px 24px;text-align:center}.carbon-empty p{color:#475569;font-size:16px;font-weight:500;margin:0}.carbon-chart-empty,.carbon-empty span{color:#94a3b8;font-size:14px}.carbon-chart-empty{align-items:center;display:flex;justify-content:center;min-height:120px}.kpi-cards-grid{grid-gap:16px;display:grid;gap:16px;grid-template-columns:repeat(4,1fr);margin-bottom:20px}.kpi-card{border-radius:14px;box-shadow:0 4px 12px #00000014;color:#fff;padding:18px 20px;transition:transform .2s,box-shadow .2s}.kpi-card:hover{box-shadow:0 6px 20px #0000001f;transform:translateY(-2px)}.kpi-card--total{background:linear-gradient(135deg,#0f172a,#1e293b)}.kpi-card--scope1{background:linear-gradient(135deg,#059669,#10b981)}.kpi-card--scope2{background:linear-gradient(135deg,#2563eb,#3b82f6)}.kpi-card--scope3{background:linear-gradient(135deg,#d97706,#f59e0b)}.kpi-card-header{align-items:center;display:flex;justify-content:space-between;margin-bottom:12px}.kpi-label{font-size:13px;font-weight:500;opacity:.85}.kpi-icon-svg{opacity:.6}.kpi-scope-badge{background:#fff3;border-radius:10px;color:#fff;font-size:11px;font-weight:600;padding:2px 8px}.kpi-value{color:#fff;font-size:28px;font-weight:700;line-height:1.2;margin-bottom:4px}.kpi-subtitle{font-size:11px;line-height:1.4;margin:0 0 10px;opacity:.75}.kpi-scope-pct{color:#ffffffe6;font-size:13px;font-weight:700;letter-spacing:.02em;margin-bottom:4px}.kpi-progress{background:#fff3;border-radius:2px;height:4px;overflow:hidden}.kpi-progress-bar{background:#ffffffb3;border-radius:2px;height:100%;transition:width .6s ease}.charts-2-col{grid-gap:16px;display:grid;gap:16px;grid-template-columns:repeat(2,1fr);margin-bottom:20px}.carbon-card-header{border-bottom:1px solid #f1f5f9;padding:20px 24px 16px}.carbon-card-header h2{color:#0f172a;font-size:16px;font-weight:600;margin:0 0 3px}.carbon-card-description{color:#64748b;font-size:13px;margin:0}.carbon-card-content{padding:20px 24px}.carbon-bar-wrapper,.carbon-donut-wrapper,.carbon-pie-wrapper,.carbon-split-bar-wrapper{height:340px;position:relative}.carbon-split-loading{align-items:center;display:flex;justify-content:center;min-height:200px}.tabs-container{width:100%}.tabs-list{border-bottom:2px solid #f1f5f9;display:flex;gap:4px;margin-bottom:24px}.tab-trigger{align-items:flex-start;background:none;border:none;border-bottom:2px solid #0000;color:#94a3b8;cursor:pointer;display:flex;flex-direction:column;font-size:14px;font-weight:600;gap:2px;margin-bottom:-2px;padding:10px 20px 12px;transition:all .2s}.tab-trigger:hover{color:#475569}.tab-trigger.active{color:#0f172a}.tab-sublabel{color:inherit;font-size:11px;font-weight:400;opacity:.7}.tab-content,.tab-pane{width:100%}.scope-intro{align-items:center;border-radius:10px;color:#475569;display:flex;font-size:14px;gap:10px;margin-bottom:24px;padding:10px 14px}.scope-dot{border-radius:50%;flex-shrink:0;height:10px;width:10px}.scope1-dot{background:#059669}.scope2-dot{background:#3b82f6}.scope3-dot{background:#f59e0b}.scope1-intro{background:#f0fdf4;border:1px solid #bbf7d0;color:#166534}.scope2-intro{background:#eff6ff;border:1px solid #bfdbfe;color:#1e40af}.scope3-intro{background:#fffbeb;border:1px solid #fde68a;color:#92400e}.scope-details-grid{grid-gap:20px;display:grid;gap:20px;grid-template-columns:repeat(auto-fill,minmax(420px,1fr));margin-bottom:24px}.poste-detail{background:#f8fafc;border:1px solid #e2e8f0;border-radius:12px;padding:16px 18px}.poste-detail-header{align-items:center;border-left:3px solid;display:flex;justify-content:space-between;margin-bottom:14px;padding-left:10px}.poste-detail-title{color:#334155;font-size:13px;font-weight:600}.poste-detail-total{font-size:13px;font-weight:700}.scope-total-banner{align-items:center;border-radius:10px;display:flex;font-size:14px;justify-content:space-between;padding:12px 18px}.scope1-banner{background:#f0fdf4;border:1px solid #bbf7d0;color:#166534}.scope2-banner{background:#eff6ff;border:1px solid #bfdbfe;color:#1e40af}.scope3-banner{background:#fffbeb;border:1px solid #fde68a;color:#92400e}.scope-total-banner strong{font-size:16px;font-weight:700}@media (max-width:1400px){.kpi-cards-grid{grid-template-columns:repeat(2,1fr)}}@media (max-width:1100px){.charts-2-col,.scope-details-grid{grid-template-columns:1fr}}@media (max-width:1024px){.carbon-content{padding:20px 24px}.carbon-title{font-size:22px}.carbon-bar-wrapper,.carbon-donut-wrapper,.carbon-pie-wrapper,.carbon-split-bar-wrapper{height:280px}}@media (max-width:768px){.carbon-content{padding:16px}.carbon-page-header{flex-direction:column;gap:12px}.carbon-title{font-size:20px}.kpi-cards-grid{gap:12px;grid-template-columns:1fr 1fr}.kpi-value{font-size:22px}.carbon-filters-grid{grid-template-columns:1fr 1fr}.tabs-list{gap:0}.tab-trigger{font-size:13px;padding:10px 14px}.carbon-bar-wrapper,.carbon-donut-wrapper,.carbon-pie-wrapper,.carbon-split-bar-wrapper{height:240px}}@media (max-width:480px){.carbon-content{padding:12px}.kpi-cards-grid{gap:10px}.carbon-filters-grid,.kpi-cards-grid{grid-template-columns:1fr}.carbon-card-header{padding:14px 16px 12px}.carbon-card-content{padding:14px 16px}.carbon-bar-wrapper,.carbon-donut-wrapper,.carbon-pie-wrapper,.carbon-split-bar-wrapper{height:200px}.tab-trigger{font-size:12px;padding:8px 10px}}*{box-sizing:border-box;margin:0;padding:0}.saisie-main{max-width:100vw;width:100%}@media (max-width:768px){.saisie-main{margin-left:0!important}}.saisie-content{max-width:100%;overflow-x:hidden}.saisie-header{box-sizing:border-box;max-width:100%;width:100%}.saisie-subtitle{font-size:.85rem}.saisie-body{max-width:100%;overflow-x:hidden}.sites-grid{grid-gap:.1rem;gap:.1rem;grid-template-columns:repeat(auto-fill,minmax(min(100%,200px),1fr));max-width:100%;width:100%}.status-badge{font-size:.75rem!important;gap:.5rem!important;min-height:32px!important;padding:.5rem 1rem!important}.page-actions{align-items:center;display:flex;flex-wrap:wrap;gap:12px;margin-top:1rem}.search-container{align-items:center;background:#fff;border:1px solid #e2e8f0;border-radius:6px;box-shadow:0 1px 2px #0000000d;display:flex;flex:1 1;gap:8px;max-width:100%;min-width:0;padding:8px 12px}.search-input{background:#0000;border:none;color:#374151;flex:1 1;font-size:14px;min-width:0;outline:none}.search-input::placeholder{color:#9ca3af}.search-icon{color:#6b7280;flex-shrink:0}.config-button{align-items:center;background:linear-gradient(135deg,#3b82f6,#1d4ed8);border:none;border-radius:10px;box-shadow:0 4px 14px #3b82f640;color:#fff;cursor:pointer;display:flex;font-size:15px;font-weight:600;gap:10px;min-height:48px;padding:14px 20px;transition:all .3s ease;white-space:nowrap}.config-button:hover{background:linear-gradient(135deg,#1d4ed8,#1e40af);box-shadow:0 8px 25px #3b82f666;transform:translateY(-2px)}.refresh-button{align-items:center;background:linear-gradient(135deg,#1d9336,#0e772e);border:none;border-radius:10px;box-shadow:0 4px 14px #3b82f640;color:#fff;cursor:pointer;display:flex;font-size:15px;font-weight:600;gap:10px;min-height:48px;padding:14px 20px;transition:all .3s ease;white-space:nowrap}.refresh-button:hover{background:linear-gradient(135deg,#106e0e,#0d601c);box-shadow:0 8px 25px #3b82f666;transform:translateY(-2px)}.refresh-button:disabled{cursor:not-allowed;opacity:.5}.category-grid{display:flex;flex-direction:row;flex-wrap:wrap;gap:16px;justify-content:center;padding:4px}.category-btn{align-items:center;background:#fff;border:2px solid #e2e8f0;border-radius:6px;color:#64748b;cursor:pointer;display:flex;flex:1 1 140px;flex-direction:column;font-size:14px;font-weight:500;max-width:200px;min-width:140px;padding:24px;transition:all .2s ease}.category-btn:hover{border-color:#cbd5e1;box-shadow:0 2px 4px #0000000d;transform:translateY(-2px)}.category-btn.active{box-shadow:0 4px 12px #0000001a;font-weight:600}.category-icon{font-size:32px;margin-bottom:12px}.category-name{text-align:center}.form-card{animation:slideIn .3s ease}@keyframes slideIn{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.card-content{align-items:center;display:flex;flex-direction:column;padding:24px}.form-grid{grid-gap:20px;display:grid;gap:20px;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));margin-bottom:24px;max-width:1200px;width:100%}.form-group{display:flex;flex-direction:column;gap:8px}.form-group label{color:#334155;font-size:14px;font-weight:500}.form-group input,.form-group select{background:#fff;border:1px solid #e2e8f0;border-radius:6px;color:#0f172a;font-size:14px;padding:10px 12px;transition:all .2s ease;width:100%}.form-group input:focus,.form-group select:focus{border-color:#3b82f6;box-shadow:0 0 0 3px #3b82f61a;outline:none}.form-group input::placeholder{color:#94a3b8}.form-actions{display:flex;gap:12px}.btn-add{align-items:center;background:#fff;border:1px solid #e2e8f0;border-radius:6px;color:#475569;cursor:pointer;display:flex;font-size:14px;font-weight:500;gap:8px;padding:10px 20px;transition:all .2s ease}.btn-add:hover{background:#f1f5f9;border-color:#cbd5e1}.btn-submit{align-items:center;background:#16a34a;border:none;border-radius:6px;color:#fff;cursor:pointer;display:flex;font-size:14px;font-weight:600;gap:8px;padding:10px 20px;transition:all .2s ease}.btn-submit:hover{background:#15803d;box-shadow:0 4px 12px #16a34a4d}.table-wrapper{-webkit-overflow-scrolling:touch;margin-bottom:16px;max-width:100%;overflow-x:auto}.data-table{border-collapse:collapse;width:100%}.data-table thead tr{border-bottom:2px solid #e2e8f0}.data-table th{color:#64748b;font-size:13px;font-weight:600;letter-spacing:.5px;padding:12px 16px;text-align:left;text-transform:uppercase}.data-table tbody tr{border-bottom:1px solid #f1f5f9;transition:background .2s ease}.data-table tbody tr:hover{background:#f8fafc}.data-table td{color:#334155;font-size:14px;padding:16px}.category-badge{align-items:center;display:inline-flex;font-weight:500;gap:6px}.details-cell{color:#64748b;font-size:13px;max-width:300px}.btn-delete{background:#0000;border:none;border-radius:6px;color:#ef4444;cursor:pointer;font-size:16px;padding:6px 12px;transition:all .2s ease}.btn-delete:hover{background:#fef2f2}.success-message{align-items:center;animation:slideIn .3s ease;background:#f0fdf4;border:1px solid #bbf7d0;border-radius:6px;color:#16a34a;display:flex;font-size:14px;font-weight:500;gap:12px;justify-content:center;margin:0 auto;max-width:-webkit-fit-content;max-width:fit-content;padding:16px}.success-message span{font-size:20px}.canvas-page{margin:0 auto;max-width:1200px;padding:20px}.canvas-page h1{color:#333;margin-bottom:20px}.canvas-content{background:#f9f9f9;border-radius:6px;box-shadow:0 2px 4px #0000001a;padding:20px}@media (max-width:768px){.saisie-header{max-width:100%;padding:1rem;width:100%}.saisie-title{word-wrap:break-word;font-size:1.5rem}.saisie-subtitle{word-wrap:break-word;font-size:.8rem}.saisie-body{max-width:100%;overflow-x:hidden;padding:1rem;width:100%}.sites-grid{gap:1rem;grid-template-columns:1fr;width:100%}.page-actions{flex-direction:column;gap:8px;max-width:100%;width:100%}.search-container{max-width:100%;min-width:100%;width:100%}.config-button,.refresh-button{justify-content:center}.config-button,.refresh-button,.site-card{box-sizing:border-box;max-width:100%;width:100%}.site-card{padding:1rem}.status-badge{word-wrap:break-word;font-size:.7rem!important;padding:.4rem .8rem!important}.site-header{align-items:flex-start}.site-actions,.site-header{flex-direction:column;gap:.5rem;width:100%}.btn{box-sizing:border-box;font-size:.875rem;justify-content:center;max-width:100%;padding:.75rem 1rem;width:100%}.filters-row{flex-direction:column;width:100%}.filter-group{max-width:100%;width:100%}.category-btn{box-sizing:border-box;flex-basis:calc(50% - 8px);flex-grow:1;flex-shrink:1;max-width:calc(50% - 8px);min-width:calc(50% - 8px);padding:16px}.category-grid{max-width:100%;width:100%}.category-icon{font-size:24px}.table-wrapper{border:1px solid #e2e8f0;border-radius:8px;max-width:100%;width:100%}.data-table{font-size:.875rem;min-width:100%}.data-table td,.data-table th{word-wrap:break-word;padding:8px}.filters-section,.saisie-item{box-sizing:border-box;max-width:100%;width:100%}.filters-section{padding:1rem}}@media (max-width:480px){.config-button{padding:18px 24px}.site-header{gap:.1rem}.site-name{font-size:1.125rem}.validators-list{gap:.125rem}.validator-item{font-size:.75rem;padding:.15rem}}.filters-section{border-radius:6px;box-shadow:0 1px 3px #0000001a}.filters-row{align-items:end;display:flex;flex-wrap:wrap;gap:20px}.filter-group{display:flex;flex-direction:column;gap:8px;min-width:150px}.filter-group label{color:#374151;font-size:14px;font-weight:500}.filter-group select{background:#fff;border:1px solid #d1d5db;border-radius:6px;color:#111827;font-size:14px;padding:12px}.filter-group select:focus{border-color:#3b82f6;box-shadow:0 0 0 3px #3b82f61a;outline:none}.site-card .site-header{align-items:flex-start;display:flex;justify-content:space-between;margin-bottom:16px}.site-card .status-badge{align-items:center!important;border-radius:6px!important;display:inline-flex!important;font-size:.875rem!important;font-weight:600!important;gap:.75rem!important;letter-spacing:.025em!important;min-height:40px!important;padding:.75rem 1.5rem!important}.site-card .site-actions{display:flex;flex-wrap:wrap;gap:8px}.btn{font-size:13px;gap:6px;padding:8px 12px}.btn-view:hover{background:#e5e7eb}.btn-validate:hover{background:#059669}.btn-validate:disabled{background:#9ca3af;cursor:not-allowed}.btn-reject:hover{background:#dc2626}.btn-reject:disabled{background:#9ca3af;cursor:not-allowed}.readonly-field{color:#374151;font-size:14px}.readonly-field,.readonly-value{background:#f9fafb;border:1px solid #e5e7eb;border-radius:6px;padding:12px}.readonly-value{align-items:center;color:#111827;display:flex;font-weight:500;min-height:44px}.empty-state,.error-state,.loading-state{align-items:center;color:#6b7280;display:flex;flex-direction:column;justify-content:center;padding:4rem 2rem;text-align:center}.loading-spinner{margin-bottom:.15rem}.error-state{border-radius:6px;margin:2rem 0}.empty-state-title,.error-state-title{color:#374151;font-size:.8rem;font-weight:600;margin-bottom:.15rem}.error-state-title{color:#dc2626}.empty-state-icon{margin-bottom:.15rem}.empty-state-message{max-width:400px}.error-state button{background:#dc2626;border:none;border-radius:6px;color:#fff;cursor:pointer;font-weight:500;margin-top:1rem;padding:.5rem 1rem;transition:background .2s}.error-state button:hover{background:#b91c1c}@media (max-width:768px){.filters-row{flex-direction:column}.filter-group{width:100%}.saisies-grid{grid-template-columns:1fr}.page-actions{flex-direction:column;width:100%}.config-button,.refresh-button{justify-content:center;width:100%}}.site-card{border-radius:6px;padding:.25rem}.site-header{margin-bottom:.15rem}.site-name{font-size:.8rem;margin:0 0 .1rem}.site-location{color:#6b7280;font-size:.8rem;line-height:1.4;margin:0}.site-status{flex-shrink:0}.status-badge{align-items:center!important;border-radius:8px!important;display:inline-flex!important;font-size:.95rem!important;font-weight:600!important;gap:.75rem!important;letter-spacing:.025em!important;min-height:40px!important;min-width:-webkit-fit-content!important;min-width:fit-content!important;padding:.75rem 1.5rem!important;white-space:nowrap!important}.site-details{margin:.15rem 0}.site-detail-item{align-items:center;color:#374151;display:flex;font-size:.8rem;gap:.1rem;margin-bottom:.15rem}.site-detail-item svg{color:#6b7280;flex-shrink:0}.validators-section{border-top:1px solid #f3f4f6;margin:.15rem 0;padding-top:.3rem}.validators-title{align-items:center;color:#374151;display:flex;font-size:.8rem;font-weight:600;gap:.1rem;margin-bottom:.15rem}.validators-list{flex-direction:column;gap:.125rem}.validator-item{align-items:center;background-color:#f9fafb;border:1px solid #e5e7eb;border-radius:4px;display:flex;font-size:.75rem;justify-content:space-between;padding:.15rem}.validator-name,.validator-role{color:#374151;font-weight:500}.validator-role{background-color:#e5e7eb;border-radius:4px;font-size:.75rem;padding:.125rem .375rem;text-transform:uppercase}.role-badge{display:inline-block;font-size:12px;padding:4px 8px}.role-badge.admin{background:#fee2e2;color:#dc2626}.role-badge.super-user{background:#f3e8ff;color:#9333ea}.role-badge.user{background:#dbeafe;color:#2563eb}.role-badge.agent{background:#dcfce7;color:#16a34a}.validator-more{color:#6b7280;font-style:italic}.site-actions{flex-wrap:wrap;gap:.1rem;padding-top:.3rem}.btn{border:none;border-radius:4px;display:flex;font-size:.75rem;padding:.15rem .3rem;white-space:nowrap}.btn:disabled{cursor:not-allowed;opacity:.5;transform:none}.btn-view{background:#f3f4f6;border:1px solid #d1d5db;color:#374151}.btn-view:hover:not(:disabled){background:#e5e7eb;border-color:#9ca3af}.btn-validate{background:#10b981;border:1px solid #10b981;color:#fff}.btn-validate:hover:not(:disabled){background:#059669;border-color:#059669;box-shadow:0 2px 4px #10b98133}.btn-reject{background:#ef4444;border:1px solid #ef4444;color:#fff}.btn-reject:hover:not(:disabled){background:#dc2626;border-color:#dc2626;box-shadow:0 2px 4px #ef444433}@media (max-width:1024px){.sites-grid{grid-template-columns:repeat(auto-fill,minmax(min(100%,350px),1fr))}}@media (max-width:768px){.site-card{padding:.25rem}.site-header{align-items:flex-start}.site-actions,.site-header{flex-direction:column;gap:.1rem}.btn{justify-content:center;width:100%}}@media (max-width:480px){.site-header{gap:.1rem}.site-name{font-size:1.125rem}.validators-list{gap:.125rem}.validator-item{font-size:.75rem;padding:.15rem}}.site-location-container{margin-bottom:.15rem}.site-location-badge{align-items:center;background:#f0f9ff;border:1px solid #e0f2fe;border-radius:4px;color:#0369a1;display:inline-flex;font-size:.75rem;font-weight:500;gap:.1rem;padding:.125rem .5rem}.site-location-badge.no-location{background:#fef3c7;border-color:#fed7aa;color:#92400e}.location-icon{font-size:.8rem}.detail-row{grid-gap:.1rem;display:grid;gap:.1rem;grid-template-columns:1fr 1fr;margin-bottom:.3rem}.site-detail-item.primary{align-items:flex-start;background:#f8fafc;border:1px solid #e2e8f0;border-radius:4px;display:flex;gap:.1rem;padding:.15rem}.site-detail-item.primary svg{color:#3b82f6;flex-shrink:0;margin-top:.125rem}.detail-content{display:flex;flex-direction:column;gap:.05rem}.detail-label{color:#6b7280;font-size:.65rem;font-weight:500;letter-spacing:.05em;text-transform:uppercase}.detail-value{color:#111827;font-size:.75rem;font-weight:600}.validation-requirement{align-items:center;background:#f0fdf4;border:1px solid #bbf7d0;border-radius:4px;color:#166534;display:flex;font-size:.7rem;font-weight:500;gap:.1rem;margin-bottom:.3rem;padding:.2rem .3rem}.validation-requirement svg{color:#16a34a;flex-shrink:0}.detail-dates{background:#fafafa;border:1px solid #e5e7eb;border-radius:4px;display:flex;flex-direction:column;gap:.1rem;padding:.15rem}.date-item{align-items:center;display:flex;font-size:.75rem;justify-content:space-between}.date-label{color:#6b7280;font-weight:500}.date-value{font-feature-settings:"tnum";color:#111827;font-variant-numeric:tabular-nums;font-weight:600}@media (max-width:768px){.detail-row{gap:.1rem;grid-template-columns:1fr}.site-detail-item.primary{gap:.1rem;padding:.5rem}.detail-dates{padding:.5rem}.date-item{font-size:.75rem}}.tab-button{gap:.1rem;padding:.35rem .5rem}.tab-content{padding:.25rem}.saisie-groups{gap:.1rem}.saisie-group{border-radius:6px;transition:all .2s ease}.saisie-group.collapsed{box-shadow:0 1px 2px 0 #0000000d}.group-header{cursor:pointer;padding:.35rem .5rem;transition:all .2s ease;-webkit-user-select:none;user-select:none}.group-header:hover{background:linear-gradient(135deg,#5a6fd8,#6a4190)}.group-header-content{align-items:center;display:flex;flex:1 1;gap:.1rem}.expand-icon{flex-shrink:0;transition:transform .2s ease}.saisie-group.collapsed .expand-icon{transform:rotate(-90deg)}.group-title{font-size:.85rem}.group-count{border-radius:6px;font-size:.75rem;min-width:20px;padding:.125rem .5rem;text-align:center}.group-content{gap:.1rem;overflow:hidden;padding:.25rem;transition:max-height .3s ease-out}.saisie-group.collapsed .group-content{max-height:0;padding-bottom:0;padding-top:0}.group-content>*{max-width:none;transition:opacity .2s ease;width:100%}.saisie-group.collapsed .group-content>*{opacity:0}.saisie-item{border-radius:6px}.saisie-item-header{margin-bottom:.15rem}.saisie-item-title{gap:.1rem}.period{font-size:.85rem}.saisie-item-status .status-badge{gap:.1rem;padding:.15rem .3rem}.saisie-item-content,.saisie-item-info{gap:.1rem}.info-row{font-size:.8rem;gap:.1rem}.validation-dates{padding:.25rem}.validation-date{font-size:.8rem;margin-bottom:.15rem}.btn{font-size:.8rem;gap:.1rem}@media (max-width:768px){.tabs-header{padding:0 1rem}.tab-button{font-size:.8rem;padding:.75rem 1rem}.tab-content{padding:.25rem}.group-header{padding:.35rem .5rem}.group-content{padding:.25rem}.search-container{max-width:none;min-width:200px;order:-1;width:100%}.page-actions{align-items:stretch;flex-direction:column}.config-button,.refresh-button{justify-content:center;width:100%}}.dialog-overlay{align-items:center;background-color:#0009;bottom:0;display:flex;justify-content:center;left:0;padding:1rem;position:fixed;right:0;top:0;z-index:1000}.dialog-container{background:#fff;border-radius:12px;box-shadow:0 20px 25px -5px #0000001a,0 10px 10px -5px #0000000a;display:flex;flex-direction:column;height:92vh;max-width:1800px;overflow:hidden;width:95vw}.dialog-header{align-items:flex-start;background:#f8fafc;border-bottom:1px solid #e2e8f0;display:flex;justify-content:space-between;padding:.75rem 1rem}.dialog-title-section{flex:1 1}.dialog-title{align-items:center;color:#1f2937;display:flex;font-size:1.25rem;font-weight:700;gap:.5rem;margin:0 0 .25rem}.dialog-subtitle{color:#6b7280;font-size:.8rem;margin:0}.saisie-status{color:#059669;font-weight:600}.dialog-close{background:none;border:none;border-radius:6px;color:#6b7280;cursor:pointer;padding:.5rem;transition:all .2s ease}.dialog-close:hover{background-color:#f3f4f6;color:#374151}.dialog-content{flex:1 1;overflow-y:auto;padding:.75rem 1rem}.date-selection{background:#f8fafc;border:1px solid #e2e8f0;border-radius:6px;display:flex;gap:.75rem;margin-bottom:.75rem;padding:.5rem .75rem}.date-field{flex:1 1}.date-field label{align-items:center;color:#374151;display:flex;font-size:.75rem;font-weight:600;gap:.35rem;margin-bottom:.25rem}.date-field select{background:#fff;border:1px solid #d1d5db;border-radius:6px;color:#374151;cursor:pointer;font-size:.875rem;padding:.75rem;transition:border-color .2s ease;width:100%}.date-field select:focus{border-color:#75aaff;box-shadow:0 0 0 3px #3b82f61a;outline:none}.indicators-section{display:flex;flex:1 1;flex-direction:column;gap:0;min-height:0;overflow:visible}.readonly-field,.readonly-value{background:#f9fafb;border:1px solid #e5e7eb;border-radius:4px;color:#374151;font-size:.75rem;padding:.35rem .5rem}.empty-indicators{color:#6b7280;font-style:italic;padding:3rem;text-align:center}.postes-tabs{border-bottom:2px solid #e5e7eb;display:flex;flex-shrink:0;gap:8px;margin-bottom:20px;overflow-x:auto;padding-bottom:0}.poste-tab{background:none;border:none;border-bottom:3px solid #0000;bottom:-2px;color:#6b7280;cursor:pointer;font-weight:500;padding:12px 24px;position:relative;transition:all .2s;white-space:nowrap}.poste-tab:hover{background:#f0f9ff;color:#3b82f6}.poste-tab.active{border-bottom-color:#3b82f6;color:#3b82f6;font-weight:600}.poste-tab-badge{background:#dbeafe;border-radius:12px;color:#3b82f6;display:inline-block;font-size:12px;font-weight:600;margin-left:8px;padding:2px 8px}.poste-tab.active .poste-tab-badge{background:#3b82f6;color:#fff}.postes-list{flex:1 1;min-height:0;overflow-x:hidden;overflow-y:auto;padding:0}.poste-panel{display:none;height:100%;min-height:0;overflow:hidden}.poste-panel.active{display:flex;flex-direction:column;min-height:0}.poste-content{border-radius:8px;flex:1 1;min-height:0;overflow:visible;padding:0}.poste-section{background:#fff;border:2px solid #e2e8f0;border-radius:12px;box-shadow:0 4px 6px -1px #0000001a,0 2px 4px -1px #0000000f;margin-bottom:1.5rem;overflow:hidden}.poste-header{background:linear-gradient(135deg,#468dff,#b7caff);border-bottom:2px solid #fff3;color:#fff;display:none;padding:1.25rem 1.5rem}.poste-title{font-size:1.25rem;font-weight:700;letter-spacing:.025em;margin:0}.poste-description{font-size:.95rem;margin:.5rem 0 0;opacity:.95}.indicators-grid{grid-gap:16px;display:grid;gap:16px;grid-template-columns:repeat(auto-fill,minmax(min(100%,320px),1fr));padding:8px}.indicator-row{background:#fff;border:2px solid #e5e7eb;border-radius:8px;box-shadow:0 1px 3px 0 #0000001a;display:flex;flex-direction:column;gap:10px;padding:14px 16px;transition:all .2s ease}.indicator-row:hover{background:#fafafa;border-color:#3b82f6;box-shadow:0 4px 6px -1px #3b82f626;transform:translateY(-1px)}.indicator-info{flex:1 1;min-width:0}.indicator-label{align-items:center;display:flex;flex-wrap:wrap;gap:8px;margin-bottom:4px}.indicator-code{background:#dbeafe;border-radius:4px;color:#1e40af;flex-shrink:0;font-family:Courier New,monospace;font-size:11px;font-weight:700;padding:4px 8px;white-space:nowrap}.indicator-name{color:#1f2937;flex:1 1;font-size:13px;font-weight:600;line-height:1.4;min-width:0}.required-badge{color:#dc2626;flex-shrink:0;font-size:14px;font-weight:700}.indicator-input-container{align-items:center;display:flex;gap:8px;width:100%}.indicator-input{background:#fff;border:2px solid #d1d5db;border-radius:6px;flex:1 1;font-size:14px;min-width:0;padding:10px 12px;transition:all .2s ease}.indicator-input:focus{border-color:#3b82f6;box-shadow:0 0 0 3px #3b82f626;outline:none}.indicator-input:disabled{background:#f3f4f6;color:#9ca3af;cursor:not-allowed;opacity:.6}.indicator-unit{background:#f3f4f6;border:2px solid #e5e7eb;border-radius:6px;color:#4b5563;flex-shrink:0;font-size:13px;font-weight:700;padding:8px 12px;white-space:nowrap}.dimensions-container{display:flex;flex-wrap:wrap;gap:12px;margin-bottom:8px;width:100%}.dimension-select{display:flex;flex:1 1;flex-direction:column;gap:4px;min-width:150px}.dimension-label{color:#6b7280;font-size:11px;font-weight:600;letter-spacing:.025em;text-transform:uppercase}.dimension-dropdown{background:#fff;border:2px solid #d1d5db;border-radius:6px;color:#374151;cursor:pointer;font-size:13px;padding:8px 10px;transition:all .2s ease}.dimension-dropdown:focus{border-color:#3b82f6;box-shadow:0 0 0 3px #3b82f626;outline:none}.dimension-dropdown:disabled{background:#f3f4f6;cursor:not-allowed;opacity:.6}.dimensions-readonly{display:flex;flex-wrap:wrap;gap:8px;margin-bottom:8px;width:100%}.dimension-readonly-item{align-items:center;background:#f0f9ff;border:1px solid #bfdbfe;border-radius:6px;display:inline-flex;font-size:12px;gap:6px;padding:6px 10px}.dimension-readonly-label{color:#1e40af;font-size:10px;font-weight:600;letter-spacing:.025em;text-transform:uppercase}.dimension-readonly-value{color:#3b82f6;font-weight:500}.dialog-actions{background:#f8fafc;border-top:1px solid #e2e8f0;display:flex;gap:.75rem;justify-content:flex-end;padding:.75rem 1rem}.dialog-actions button{align-items:center;border:none;border-radius:6px;cursor:pointer;display:inline-flex;font-size:.8rem;font-weight:600;gap:.4rem;padding:.6rem 1.25rem;transition:all .2s ease}.btn-cancel{background:#f3f4f6;color:#374151}.btn-cancel:hover:not(:disabled){background:#e5e7eb;transform:translateY(-1px)}.btn-draft{background:#fbbf24;color:#fff}.btn-draft:hover:not(:disabled){background:#f59e0b;transform:translateY(-1px)}.btn-save{background:linear-gradient(135deg,#10b981,#059669);color:#fff}.btn-save:hover:not(:disabled){box-shadow:0 8px 25px #10b9814d;transform:translateY(-1px)}.dialog-actions button:disabled{box-shadow:none!important;cursor:not-allowed;opacity:.5;transform:none!important}@media (max-width:768px){.dialog-overlay{padding:.25rem}.dialog-container{border-radius:8px;height:96vh;width:98vw}.dialog-content,.dialog-header{padding:1rem}.date-selection{flex-direction:column;gap:1rem}.indicator-row{align-items:stretch;flex-direction:column;gap:.75rem}.indicator-input-container{min-width:auto}.dialog-actions{flex-direction:column-reverse;gap:.5rem;padding:1rem}.dialog-actions button{justify-content:center;width:100%}}.indicators-loading{align-items:center;color:#6b7280;display:flex;justify-content:center;padding:3rem}.loading-spinner-small{animation:spin 1s linear infinite;border:2px solid #e5e7eb;border-radius:50%;border-top-color:#3b82f6;height:1rem;margin-right:.5rem;width:1rem}.indicator-input[type=number]{-webkit-appearance:textfield;appearance:textfield}.indicator-input[type=number]::-webkit-inner-spin-button,.indicator-input[type=number]::-webkit-outer-spin-button{-webkit-appearance:none;margin:0}.indicator-input[type=number]:focus{outline:2px solid #3b82f6;outline-offset:2px}.indicator-card{background:#fff;border:1px solid #e5e7eb;border-radius:8px;margin-bottom:12px;padding:12px;transition:box-shadow .2s}.indicator-card:hover{box-shadow:0 2px 8px #00000014}.indicator-header{align-items:center;display:flex;justify-content:space-between;margin-bottom:8px}.add-entry-btn{background:#3b82f6;border:none;border-radius:6px;color:#fff;cursor:pointer;font-size:13px;font-weight:500;padding:6px 12px;transition:all .2s;white-space:nowrap}.add-entry-btn:hover:not(:disabled){background:#2563eb;box-shadow:0 2px 4px #3b82f64d;transform:translateY(-1px)}.add-entry-btn:disabled{cursor:not-allowed;opacity:.5}.entries-container{display:flex;flex-direction:column;gap:8px;max-height:400px;overflow-x:hidden;overflow-y:auto;padding-right:4px}.empty-entry-placeholder{background:#f9fafb;border:1px dashed #d1d5db;border-radius:6px;color:#9ca3af;font-size:13px;font-style:italic;padding:20px;text-align:center}.indicator-entry{background:#f8fafc;border:1px solid #e2e8f0;border-radius:6px;padding:12px;transition:all .2s}.indicator-entry:hover{background:#f1f5f9;border-color:#cbd5e1}.entry-content{display:flex;flex-direction:column;gap:10px}.dimensions-row{display:flex;flex-wrap:wrap;gap:10px}.dimension-field{display:flex;flex:1 1;flex-direction:column;gap:4px;min-width:150px}.dimension-field .dimension-label{color:#64748b;font-size:12px;font-weight:600;letter-spacing:.3px;text-transform:uppercase}.dimension-field .dimension-dropdown{background:#fff;border:1px solid #cbd5e1;border-radius:4px;font-size:14px;padding:6px 10px;transition:all .2s}.dimension-field .dimension-dropdown:focus{border-color:#3b82f6;box-shadow:0 0 0 3px #3b82f61a;outline:none}.value-input-row{align-items:center;display:flex;gap:8px}.value-input{background:#fff;border:1px solid #cbd5e1;border-radius:6px;flex:1 1;font-size:14px;padding:8px 12px;transition:all .2s}.value-input:focus{border-color:#3b82f6;box-shadow:0 0 0 3px #3b82f61a;outline:none}.value-input:disabled{background:#f3f4f6;cursor:not-allowed}.value-unit{color:#64748b;font-size:13px;font-weight:500;min-width:40px;white-space:nowrap}.remove-entry-btn{align-items:center;background:#ef4444;border:none;border-radius:4px;color:#fff;cursor:pointer;display:flex;flex-shrink:0;font-size:20px;height:28px;justify-content:center;line-height:1;transition:all .2s;width:28px}.remove-entry-btn:hover:not(:disabled){background:#dc2626;transform:scale(1.1)}.remove-entry-btn:disabled{cursor:not-allowed;opacity:.5}.reject-dialog-overlay{align-items:center;animation:fadeIn .2s ease-out;background-color:#00000080;bottom:0;display:flex;justify-content:center;left:0;position:fixed;right:0;top:0;z-index:1000}.reject-dialog-content{animation:slideUp .3s ease-out;background:#fff;border-radius:12px;box-shadow:0 20px 25px -5px #0000001a,0 10px 10px -5px #0000000a;display:flex;flex-direction:column;max-height:90vh;max-width:500px;width:90%}@keyframes slideUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.reject-dialog-header{align-items:center;border-bottom:1px solid #e5e7eb;display:flex;justify-content:space-between;padding:20px 24px}.reject-dialog-title{color:#1f2937;font-size:20px;font-weight:700;margin:0}.reject-dialog-close{align-items:center;background:none;border:none;border-radius:6px;color:#6b7280;cursor:pointer;display:flex;justify-content:center;padding:4px;transition:all .2s ease}.reject-dialog-close:hover:not(:disabled){background-color:#f3f4f6;color:#1f2937}.reject-dialog-close:disabled{cursor:not-allowed;opacity:.5}.reject-dialog-body{flex:1 1;overflow-y:auto;padding:24px}.reject-dialog-label{color:#374151;display:block;font-size:14px;font-weight:600;margin-bottom:8px}.reject-dialog-select{-webkit-appearance:none;appearance:none;background-color:#fff;background-image:url("data:image/svg+xml;charset=utf-8,%3Csvg xmlns='http://www.w3.org/2000/svg' width='16' height='16'%3E%3Cpath fill='%23374151' d='M8 11 3 6h10z'/%3E%3C/svg%3E");background-position:right 12px center;background-repeat:no-repeat;border:2px solid #e5e7eb;border-radius:8px;color:#1f2937;cursor:pointer;font-size:14px;padding:10px 40px 10px 12px;transition:all .2s ease;width:100%}.reject-dialog-select:hover:not(:disabled){border-color:#d1d5db}.reject-dialog-select:focus{border-color:#ef4444;box-shadow:0 0 0 3px #ef44441a;outline:none}.reject-dialog-select:disabled{background-color:#f9fafb;cursor:not-allowed;opacity:.6}.reject-dialog-custom-reason{animation:slideDown .2s ease-out;margin-top:16px}.reject-dialog-textarea{border:2px solid #e5e7eb;border-radius:8px;color:#1f2937;font-family:inherit;font-size:14px;min-height:100px;padding:10px 12px;resize:vertical;transition:all .2s ease;width:100%}.reject-dialog-textarea:hover:not(:disabled){border-color:#d1d5db}.reject-dialog-textarea:focus{border-color:#ef4444;box-shadow:0 0 0 3px #ef44441a;outline:none}.reject-dialog-textarea:disabled{background-color:#f9fafb;cursor:not-allowed;opacity:.6}.reject-dialog-textarea::placeholder{color:#9ca3af}.reject-dialog-footer{border-top:1px solid #e5e7eb;display:flex;gap:12px;justify-content:flex-end;padding:20px 24px}.reject-dialog-btn{align-items:center;border:none;border-radius:8px;cursor:pointer;display:flex;font-size:14px;font-weight:600;gap:8px;padding:10px 20px;transition:all .2s ease}.reject-dialog-btn:disabled{cursor:not-allowed;opacity:.6}.reject-dialog-btn-cancel{background-color:#f3f4f6;color:#374151}.reject-dialog-btn-cancel:hover:not(:disabled){background-color:#e5e7eb}.reject-dialog-btn-confirm{background:linear-gradient(135deg,#ef4444,#dc2626);box-shadow:0 2px 4px #ef444433;color:#fff}.reject-dialog-btn-confirm:hover:not(:disabled){background:linear-gradient(135deg,#dc2626,#b91c1c);box-shadow:0 4px 8px #ef44444d;transform:translateY(-1px)}.reject-dialog-btn-confirm:active:not(:disabled){transform:translateY(0)}.combo{position:relative;width:100%}.combo-trigger{align-items:center;background:#fff;border:1.5px solid #d1d5db;border-radius:8px;cursor:text;display:flex;padding:0 10px 0 0;transition:border-color .2s,box-shadow .2s;width:100%}.combo-trigger:hover{border-color:#a3a3a3}.combo-trigger--open{border-color:#6366f1;box-shadow:0 0 0 2px #6366f11f}.combo-input{background:#0000;border:none;color:#1e293b;flex:1 1;font-size:14px;min-width:0;outline:none;padding:10px 14px}.combo-input::placeholder{color:#94a3b8}.combo-chevron{color:#94a3b8;cursor:pointer;flex-shrink:0;transition:transform .2s}.combo-chevron--open{transform:rotate(180deg)}.combo-panel{animation:comboSlideIn .15s ease-out;background:#fff;border:1.5px solid #e2e8f0;border-radius:8px;box-shadow:0 8px 24px #0000001a}@keyframes comboSlideIn{0%{opacity:0;transform:translateY(-4px)}to{opacity:1;transform:translateY(0)}}.combo-list{max-height:400px;overflow-y:auto;padding:4px 0}.combo-item{border-radius:4px;cursor:pointer;font-size:14px;margin:0 4px;padding:9px 14px;transition:background .1s}.combo-item:hover{background:#f1f5f9}.combo-item--selected{background:#eef2ff;color:#4f46e5;font-weight:500}.combo-empty{color:#6b7280;font-size:13px;padding:10px 14px}.saisie-main{background-color:#f8fafc;min-height:0}.saisie-content,.saisie-main{display:flex;flex:1 1;flex-direction:column;overflow:hidden}.saisie-header{background:#fff;border-bottom:1px solid #e2e8f0;box-shadow:0 1px 3px 0 #0000001a;flex-shrink:0;padding:1.5rem 2rem}.saisie-title{color:#1f2937;font-size:2rem;font-weight:700;margin:0}.saisie-subtitle{color:#6b7280;font-size:1.1rem;margin-top:.5rem}.fallback-notice{background-color:#fef3c7;border:1px solid #fbbf24;border-radius:6px;color:#92400e;margin-top:1rem;padding:.75rem 1rem}.fallback-notice p{font-size:.875rem;font-weight:500;margin:0}.saisie-body{flex:1 1;overflow-y:auto;padding:2rem}.sites-grid{grid-gap:1.5rem;display:grid;gap:1.5rem;grid-template-columns:repeat(auto-fill,minmax(600px,1fr))}.site-card{background:#fff;border:1px solid #e2e8f0;border-radius:12px;box-shadow:0 1px 3px 0 #0000001a;padding:1.5rem;transition:all .3s ease}.site-card:hover{box-shadow:0 4px 12px 0 #00000026;transform:translateY(-2px)}.site-header{align-items:flex-start;display:flex;justify-content:space-between;margin-bottom:1rem}.site-info{flex:1 1}.site-name{color:#1f2937;font-size:1.25rem;font-weight:600;margin:0 0 .5rem}.site-description{color:#6b7280;font-size:.9rem;line-height:1.4;margin:0}.site-badge{align-items:center;border-radius:9999px;display:inline-flex;font-size:.75rem;font-weight:500;gap:.25rem;padding:.25rem .75rem;white-space:nowrap}.site-badge.validation-simple{background-color:#dcfce7;color:#15803d}.site-badge.validation-double{background-color:#fef3c7;color:#d97706}.validators-section{margin:1rem 0}.validators-label{align-items:center;color:#374151;display:flex;font-size:.875rem;font-weight:600;gap:.5rem;margin-bottom:.5rem}.validators-list{display:flex;flex-wrap:wrap;gap:.5rem;margin-bottom:1rem}.validator-chip{align-items:center;background-color:#f3f4f6;border:1px solid #d1d5db;border-radius:6px;color:#374151;display:inline-flex;font-size:.875rem;gap:.25rem;padding:.375rem .75rem}.validator-chip.role-super_user{background-color:#fef3c7;border-color:#f59e0b;color:#92400e}.validator-chip.role-user{background-color:#ede9fe;border-color:#8b5cf6;color:#6b21a8}.validator-chip.role-admin{background-color:#fee2e2;border-color:#ef4444;color:#dc2626}.role-badge{border-radius:4px;font-size:.75rem;font-weight:500;padding:.125rem .375rem;text-transform:uppercase}.no-validators{color:#9ca3af;font-size:.875rem;font-style:italic}.agent-validator-info{margin-top:.5rem}.validator-info-text{color:#6b7280;font-size:.875rem;font-style:italic;margin:0;padding:.5rem 0}.site-actions{border-top:1px solid #f3f4f6;display:flex;gap:.75rem;justify-content:flex-end;padding-top:1rem}.btn-excel{align-items:center;background:linear-gradient(135deg,#059669,#047857);border:none;border-radius:8px;color:#fff;cursor:pointer;display:inline-flex;font-size:.875rem;font-weight:600;gap:.5rem;letter-spacing:.05em;padding:.75rem 1.5rem;text-transform:uppercase;transition:all .3s ease}.btn-excel:hover{box-shadow:0 8px 25px #0596694d;transform:translateY(-1px)}.btn-excel:active{transform:translateY(0)}.btn-saisie{align-items:center;background:linear-gradient(135deg,#3b82f6,#1d4ed8);border:none;border-radius:8px;color:#fff;cursor:pointer;display:inline-flex;font-size:.875rem;font-weight:600;gap:.5rem;letter-spacing:.05em;padding:.75rem 1.5rem;text-transform:uppercase;transition:all .3s ease}.btn-saisie:hover{box-shadow:0 8px 25px #3b82f64d;transform:translateY(-1px)}.btn-saisie:active{transform:translateY(0)}.btn-saisie:disabled{background:#9ca3af;box-shadow:none;cursor:not-allowed;transform:none}.empty-state{color:#6b7280;padding:4rem 2rem;text-align:center}.empty-state-icon{align-items:center;color:#9ca3af;display:flex;justify-content:center;margin-bottom:1rem}.empty-state-title{color:#374151;font-size:1.25rem;font-weight:600;margin-bottom:.5rem}.empty-state-message{font-size:1rem;line-height:1.5}.loading-state{align-items:center;color:#6b7280;display:flex;justify-content:center;padding:4rem 2rem}.loading-spinner{border:2px solid #e5e7eb;border-top-color:#3b82f6;height:2rem;margin-right:1rem;width:2rem}@media (max-width:768px){.saisie-header{padding:1rem}.saisie-title{font-size:1.5rem}.saisie-subtitle{font-size:.95rem}.fallback-notice p{font-size:.8rem}.saisie-body{padding:1rem}.sites-grid{gap:1rem;grid-template-columns:1fr}.site-card{padding:1rem}.site-name{font-size:1.1rem}.site-description{font-size:.85rem}.site-badge{font-size:.7rem;padding:.2rem .6rem}.validators-label{font-size:.8rem}.validator-chip{font-size:.8rem;padding:.3rem .6rem}.no-validators,.validator-info-text{font-size:.8rem}.btn-excel,.btn-saisie{font-size:.8rem;padding:.6rem 1.2rem}.empty-state{padding:3rem 1rem}.empty-state-title{font-size:1.1rem}.empty-state-message{font-size:.9rem}.file-upload-section{padding:.6rem 1rem}.upload-title{font-size:.9rem}.upload-subtitle{font-size:.75rem}.upload-text{font-size:.85rem}.upload-formats{font-size:.75rem}.file-name{font-size:.9rem}.file-size{font-size:.8rem}.btn-remove,.btn-upload{font-size:.75rem;padding:.35rem .7rem}.tabs-header{padding:0 1rem}.tab-button{padding:.75rem 1rem}.tab-button,.tab-label{font-size:.875rem}.tab-count{font-size:.7rem;padding:.15rem .4rem}.tab-content{padding:1rem}.group-header{padding:1rem 1.5rem}.group-title{font-size:1.1rem}.group-count{font-size:.8rem}.group-content,.saisie-item{padding:1rem}.period{font-size:1rem}.saisie-item-status .status-badge{font-size:.7rem;padding:.3rem .6rem}.btn,.info-row,.validation-date{font-size:.8rem}.btn{padding:.4rem .8rem}.site-header{flex-direction:column;gap:1rem}.validators-list{flex-direction:column;gap:.25rem}}@media (max-width:480px){.saisie-header{padding:.75rem}.saisie-title{font-size:1.3rem}.saisie-subtitle{font-size:.85rem}.fallback-notice{padding:.6rem .8rem}.fallback-notice p{font-size:.75rem}.saisie-body{padding:.75rem}.sites-grid{gap:.75rem}.site-card{padding:.75rem}.site-name{font-size:1rem}.site-description{font-size:.8rem}.site-badge{font-size:.65rem;padding:.2rem .5rem}.validator-chip,.validators-label{font-size:.75rem}.validator-chip{padding:.3rem .5rem}.role-badge{font-size:.7rem}.site-actions{flex-direction:column;gap:.5rem}.btn-excel,.btn-saisie{font-size:.75rem;justify-content:center;padding:.65rem 1rem;width:100%}.empty-state{padding:2.5rem .75rem}.empty-state-title{font-size:1rem}.empty-state-message{font-size:.85rem}.file-upload-section{padding:.5rem .75rem}.upload-header{margin-bottom:.5rem}.upload-title{font-size:.85rem}.upload-subtitle{font-size:.7rem}.upload-area{padding:.5rem}.upload-icon{height:32px;width:32px}.upload-text{font-size:.8rem}.upload-formats{font-size:.7rem}.file-selected{padding:.4rem .6rem}.file-icon{height:28px;width:28px}.file-name{font-size:.85rem}.file-size{font-size:.75rem}.file-actions{gap:.5rem}.btn-remove,.btn-upload{font-size:.7rem;padding:.3rem .6rem}.tabs-header{overflow-x:auto;padding:0 .75rem}.tab-button{padding:.65rem .8rem;white-space:nowrap}.tab-button,.tab-label{font-size:.8rem}.tab-count{font-size:.65rem;padding:.15rem .35rem}.tab-content{padding:.75rem}.saisie-groups{gap:1.5rem}.group-header{padding:.75rem 1rem}.group-title{font-size:1rem}.group-count{font-size:.75rem;padding:.2rem .6rem}.group-content{gap:.75rem;padding:.75rem}.saisie-item{padding:.75rem}.period{font-size:.95rem}.saisie-item-status .status-badge{font-size:.65rem;padding:.25rem .5rem}.info-row{font-size:.75rem}.validation-info{padding:.4rem}.validation-dates{padding:.6rem}.btn,.validation-date{font-size:.75rem}.btn{padding:.35rem .7rem}}.error-state{background-color:#fef2f2;border:1px solid #fecaca;border-radius:8px;color:#dc2626;margin:1rem 0;padding:1rem}.error-state-title{font-weight:600;margin-bottom:.5rem}.file-upload-section{background:#fff;border-bottom:1px solid #e2e8f0;flex-shrink:0;padding:.75rem 2rem}.upload-container{margin:0 auto;max-width:1500px}.upload-header{margin-bottom:.7rem;text-align:center}.upload-title{color:#1f2937;font-size:1rem;font-weight:600;margin:0}.upload-subtitle{color:#6b7280;font-size:.8rem;margin:0}.upload-area{border:2px dashed #d1d5db;border-radius:7px;padding:.7rem;transition:all .3s ease}.upload-area:hover{background-color:#f8fafc;border-color:#3b82f6}.upload-dropzone{text-align:center}.file-input{display:none}.upload-label{align-items:center;cursor:pointer;display:flex;flex-direction:column;gap:.3rem;padding:.3rem;transition:all .2s ease}.upload-label.disabled{cursor:not-allowed;opacity:.5}.upload-label:not(.disabled):hover{transform:translateY(-2px)}.upload-icon{align-items:center;background:#eff6ff;border-radius:50%;color:#3b82f6;display:flex;height:36px;justify-content:center;margin-bottom:.25rem;width:36px}.upload-text{color:#374151;font-size:.9rem;font-weight:600}.upload-formats{color:#6b7280;font-size:.8rem}.file-selected{background:#f8fafc;border:1px solid #e2e8f0;border-radius:8px;justify-content:space-between;padding:.5rem .75rem}.file-info,.file-selected{align-items:center;display:flex}.file-info{flex:1 1;gap:.75rem}.file-icon{align-items:center;background:#eff6ff;border-radius:6px;color:#3b82f6;display:flex;height:32px;justify-content:center;width:32px}.file-details{display:flex;flex-direction:column;gap:.25rem}.file-name{color:#1f2937;font-size:1rem;font-weight:600}.file-size{color:#6b7280;font-size:.875rem}.file-actions{display:flex;gap:.75rem}.btn-upload{align-items:center;background:linear-gradient(135deg,#10b981,#059669);border:none;border-radius:6px;color:#fff;cursor:pointer;display:inline-flex;font-size:.8rem;font-weight:600;gap:.4rem;padding:.4rem .8rem;transition:all .3s ease}.btn-upload:hover:not(:disabled){box-shadow:0 4px 15px #10b9814d;transform:translateY(-1px)}.btn-upload:disabled{background:#9ca3af;box-shadow:none;cursor:not-allowed;transform:none}.btn-remove{background:#f3f4f6;border:1px solid #d1d5db;border-radius:6px;color:#6b7280;cursor:pointer;font-size:.8rem;font-weight:600;padding:.4rem .8rem;transition:all .3s ease}.btn-remove:hover:not(:disabled){background:#e5e7eb;border-color:#9ca3af;color:#374151}.btn-remove:disabled{cursor:not-allowed;opacity:.5}.saisie-tabs{display:flex;flex:1 1;flex-direction:column;overflow:hidden}.tabs-header{background:#fff;border-bottom:2px solid #e2e8f0;display:flex;flex-shrink:0;padding:0 2rem}.tab-button{align-items:center;background:none;border:none;border-bottom:3px solid #0000;color:#6b7280;cursor:pointer;display:flex;font-size:1rem;font-weight:500;gap:.5rem;padding:1rem 1.5rem;position:relative;transition:all .2s}.tab-button:hover{background-color:#f9fafb;color:#374151}.tab-button.active{background-color:#f8fafc;border-bottom-color:#2563eb;color:#2563eb}.tab-icon{align-items:center;display:flex;justify-content:center}.tab-count,.tab-label{font-weight:600}.tab-count{background:#e5e7eb;border-radius:10px;color:#374151;font-size:.75rem;min-width:20px;padding:.2rem .5rem;text-align:center}.tab-button.active .tab-count{background:#dbeafe;color:#2563eb}.tab-content{flex:1 1;overflow-y:auto;padding:2rem}.saisie-groups{display:flex;flex-direction:column;gap:2rem}.saisie-group{background:#fff;border-radius:12px;box-shadow:0 1px 3px 0 #0000001a;overflow:hidden}.group-header{align-items:center;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;display:flex;justify-content:space-between;padding:1.5rem 2rem}.group-title{font-size:1.25rem;font-weight:600;margin:0}.group-count{background:#fff3;border-radius:20px;font-size:.875rem;font-weight:500;padding:.25rem .75rem}.group-content{display:flex;flex-direction:column;gap:1rem;padding:1.5rem}.saisie-item{background:#f8fafc;border:1px solid #e2e8f0;border-radius:8px;padding:1.25rem;transition:all .2s}.saisie-item:hover{background:#f1f5f9;border-color:#cbd5e1;box-shadow:0 4px 6px -1px #0000001a;transform:translateY(-1px)}.saisie-item-header{align-items:center;display:flex;justify-content:space-between;margin-bottom:1rem}.saisie-item-title{align-items:center;color:#374151;display:flex;gap:.5rem}.period{font-size:1.1rem;font-weight:600}.saisie-item-status .status-badge{align-items:center;border-radius:20px;display:inline-flex;font-size:.75rem;font-weight:500;gap:.25rem;padding:.375rem .75rem;white-space:nowrap}.saisie-item-content{display:flex;flex-direction:column;gap:1rem}.saisie-item-info{display:flex;flex-direction:column;gap:.5rem}.info-row{align-items:center;display:flex;font-size:.875rem;gap:.5rem}.info-label{color:#6b7280;font-weight:500}.info-value{color:#374151;font-weight:600}.validation-info{background:#fef3c7;border:1px solid #fbbf24;border-radius:6px;margin-top:.5rem;padding:.5rem}.validation-badge{color:#92400e;font-weight:500}.validation-dates{background:#f0f9ff;border:1px solid #e0f2fe;border-radius:6px;padding:.75rem}.validation-date{display:flex;font-size:.875rem;justify-content:space-between;margin-bottom:.25rem}.validation-date:last-child{margin-bottom:0}.validation-label{color:#0369a1;font-weight:500}.saisie-item-actions{display:flex;justify-content:flex-end;margin-top:.5rem}.btn{align-items:center;border:1px solid;border-radius:6px;cursor:pointer;display:inline-flex;font-size:.875rem;font-weight:500;gap:.5rem;padding:.5rem 1rem;text-decoration:none;transition:all .2s}.btn-primary{background:#2563eb;border-color:#2563eb;color:#fff}.btn-primary:hover{background:#1d4ed8;border-color:#1d4ed8}@media (max-width:768px){.tabs-header{padding:0 1rem}.tab-button{font-size:.875rem;padding:.75rem 1rem}.tab-content{padding:1rem}.group-header{padding:1rem 1.5rem}.group-content{padding:1rem}}.alignment-layout{width:100%}.alignment-content,.alignment-layout{display:flex;height:100vh;overflow:hidden}.alignment-content{flex:1 1;flex-direction:column}@media (max-width:768px){.alignment-content{margin-left:0!important}}.alignment-page{background:linear-gradient(135deg,#f5f7fa,#e8ecf1);box-sizing:border-box;flex:1 1;overflow-y:auto;padding:32px}.page-header{margin-bottom:32px}.page-header h1{color:#1a202c;font-size:32px;font-weight:700;margin-bottom:8px}.page-header p{color:#718096;font-size:16px}.referentials-section{display:flex;flex-wrap:wrap;gap:16px;margin-bottom:24px}.referential-badge{align-items:center;background:#fff;border-radius:12px;box-shadow:0 6px 16px #0000000f;cursor:pointer;display:flex;gap:10px;padding:10px 14px;transition:transform .2s ease,box-shadow .2s ease}.referential-badge:hover{box-shadow:0 10px 22px #0000001a;transform:translateY(-2px)}.referential-badge img{height:28px;object-fit:contain;width:28px}.referential-badge span{color:#1f2937;font-size:14px;font-weight:600}.filters-section{background:#fff;border-radius:16px;box-shadow:0 4px 12px #0000000d;display:flex;gap:24px;margin-bottom:32px;padding:24px}.filter{display:flex;flex-direction:column;min-width:220px}.filter label{color:#4a5568;font-size:14px;font-weight:600;margin-bottom:8px}.filter select{background:#fff;border:2px solid #e2e8f0;border-radius:12px;cursor:pointer;font-size:15px;outline:none;padding:12px 16px;transition:all .2s ease}.filter select:hover{border-color:#cbd5e0}.filter select:focus{border-color:#4299e1;box-shadow:0 0 0 3px #4299e11a}.compliance-overview{grid-gap:24px;display:grid;gap:24px;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));margin-bottom:32px}.compliance-card{align-items:center;background:#fff;border-radius:20px;box-shadow:0 8px 24px #0000000f;display:flex;flex-direction:column;padding:28px;text-align:center;transition:all .3s ease}.compliance-card:hover{box-shadow:0 12px 32px #0000001a;transform:translateY(-4px)}.compliance-card-header{align-items:center;display:flex;gap:12px;margin-bottom:24px}.compliance-card-header img{height:36px;object-fit:contain;width:36px}.compliance-card-header h3{color:#2d3748;font-size:20px;font-weight:700;margin:0}.compliance-percentage{margin-bottom:20px}.percentage-circle{height:120px;width:120px}.circular-chart{display:block;margin:0 auto;max-height:100%;max-width:100%}.circle-bg{stroke:#e2e8f0}.circle,.circle-bg{fill:none;stroke-width:3.8}.circle{stroke-linecap:round;stroke:#48bb78;animation:progress 1s ease-out forwards}@keyframes progress{0%{stroke-dasharray:0 100}}.percentage{fill:#2d3748;text-anchor:middle;font-size:10px;font-weight:700}.compliance-stats{color:#718096;font-size:14px;font-weight:500;margin-bottom:16px}.view-details-btn{background:linear-gradient(135deg,#667eea,#764ba2);border:none;border-radius:12px;color:#fff;cursor:pointer;font-size:14px;font-weight:600;padding:12px 24px;transition:all .3s ease;width:100%}.view-details-btn:hover{box-shadow:0 8px 20px #667eea66;transform:scale(1.02)}.norm-details{animation:slideDown .3s ease;background:#fff;border-radius:20px;box-shadow:0 12px 32px #00000014;padding:32px}@keyframes slideDown{0%{opacity:0;transform:translateY(-20px)}to{opacity:1;transform:translateY(0)}}.norm-details-header{align-items:center;border-bottom:2px solid #e2e8f0;display:flex;justify-content:space-between;margin-bottom:28px;padding-bottom:20px}.norm-details-title{align-items:center;display:flex;gap:16px}.norm-details-title img{height:48px;object-fit:contain;width:48px}.norm-details-title h2{color:#1a202c;font-size:24px;font-weight:700;margin:0}.close-details-btn{align-items:center;background:#f7fafc;border:none;border-radius:12px;color:#4a5568;cursor:pointer;display:flex;justify-content:center;padding:12px;transition:all .2s ease}.close-details-btn:hover{background:#edf2f7;color:#2d3748}.requirements-table{overflow-x:auto}.requirements-table table{border-collapse:initial;border-spacing:0;table-layout:fixed;width:100%}.requirements-table thead{background:linear-gradient(135deg,#667eea,#764ba2)}.requirements-table thead th{color:#fff;font-size:14px;font-weight:600;letter-spacing:.5px;padding:16px 20px;text-align:left;text-transform:uppercase;vertical-align:middle}.requirements-table thead th:first-child{border-top-left-radius:12px;width:12%}.requirements-table thead th:nth-child(2){width:45%}.requirements-table thead th:nth-child(3){width:25%}.requirements-table thead th:last-child{border-top-right-radius:12px;width:18%}.requirements-table tbody tr{background:#fff;border-bottom:1px solid #e2e8f0;transition:all .2s ease}.requirements-table tbody tr:hover{background:#f7fafc}.requirements-table tbody tr:last-child{border-bottom:none}.requirements-table tbody td{color:#2d3748;font-size:14px;padding:18px 20px;text-align:left;vertical-align:middle}.req-code{color:#667eea;font-family:Courier New,monospace;font-weight:700;white-space:nowrap}.req-description{color:#2d3748;line-height:1.6}.req-status{text-align:left}.status-badge{align-items:center;background:#f7fafc;border-radius:20px;color:#2d3748;display:inline-flex;font-size:13px;font-weight:600;gap:8px;padding:8px 14px}.status-icon{flex-shrink:0}.status-icon.compliant{color:#48bb78}.status-icon.non-compliant{color:#f56565}.status-icon.partial{color:#ed8936}.req-compliance{text-align:left}.compliance-bar{background:#e2e8f0;border-radius:10px;height:8px;max-width:120px;overflow:hidden;width:100%}.compliance-fill{border-radius:10px;height:100%;transition:width .5s ease}.compliance-fill.compliant{background:linear-gradient(90deg,#48bb78,#38a169)}.compliance-fill.partial{background:linear-gradient(90deg,#ed8936,#dd6b20)}.compliance-fill.non-compliant{background:linear-gradient(90deg,#f56565,#e53e3e)}@media (max-width:1024px){.alignment-page{padding:24px}.compliance-overview{grid-template-columns:repeat(auto-fit,minmax(240px,1fr))}.norm-details{padding:24px}.requirements-table{font-size:13px}}@media (max-width:768px){.alignment-page{padding:16px}.page-header{margin-bottom:24px}.page-header h1{font-size:24px;margin-bottom:6px}.page-header p{font-size:14px}.referentials-section{gap:14px;margin-bottom:20px}.referential-badge{padding:9px 12px}.referential-badge img{height:26px;width:26px}.referential-badge span{font-size:13px}.filters-section{flex-direction:column;gap:20px;margin-bottom:24px;padding:20px}.filter{min-width:100%}.filter label{font-size:13px}.filter select{font-size:14px;padding:11px 14px}.compliance-overview{gap:20px;grid-template-columns:1fr;margin-bottom:24px}.compliance-card{padding:20px}.compliance-card-header h3{font-size:18px}.compliance-card-header img{height:32px;width:32px}.percentage-circle{height:100px;width:100px}.view-details-btn{font-size:13px;padding:11px 20px}.norm-details{padding:20px}.norm-details-title h2{font-size:20px}.norm-details-subtitle,.requirements-table{font-size:13px}.requirements-table thead{display:none}.requirements-table tbody tr{border:1px solid #e2e8f0;border-radius:12px;display:block;margin-bottom:16px;padding:16px}.requirements-table tbody td{border:none;display:block;font-size:13px;padding:8px 0}.requirements-table tbody td:before{color:#2d3748;content:attr(data-label);display:block;font-size:12px;font-weight:600;margin-bottom:4px}}@media (max-width:480px){.alignment-page{padding:12px}.page-header{margin-bottom:20px}.page-header h1{font-size:20px;margin-bottom:4px}.page-header p{font-size:13px}.referentials-section{gap:12px;margin-bottom:16px}.referential-badge{padding:8px 12px}.referential-badge img{height:24px;width:24px}.referential-badge span{font-size:12px}.filters-section{gap:16px;margin-bottom:20px;padding:16px}.filter label{font-size:12px}.filter select{font-size:13px;padding:10px 12px}.compliance-overview{gap:16px;margin-bottom:20px}.compliance-card{padding:16px}.compliance-card-header{margin-bottom:20px}.compliance-card-header h3{font-size:16px}.compliance-card-header img{height:28px;width:28px}.percentage-circle{height:90px;width:90px}.view-details-btn{font-size:13px;padding:10px 18px}.norm-details{padding:16px}.norm-details-title h2{font-size:18px}.norm-details-subtitle{font-size:12px}.requirements-table tbody tr{margin-bottom:14px;padding:14px}.requirements-table tbody td{font-size:12px;padding:7px 0}.requirements-table tbody td:before{font-size:11px}.compliance-bar{height:6px}}.customization-layout{background:linear-gradient(135deg,#f8fafc,#f1f5f9);display:flex;min-height:100vh}.customization-content{display:flex;flex:1 1;flex-direction:column;min-height:100vh}.customization-main{flex:1 1;overflow-y:auto;padding:32px}.customization-period-filters{align-items:center;display:flex;gap:16px;margin-bottom:24px}.customization-period-filters label{align-items:center;color:#475569;display:flex;font-size:14px;font-weight:500;gap:8px}.customization-period-filters input[type=month]{background:#fff;border:1px solid #e2e8f0;border-radius:8px;color:#334155;font-size:14px;padding:6px 12px}.customization-header{margin-bottom:32px}.header-content{flex-wrap:wrap;gap:24px;justify-content:space-between}.header-content,.header-title{align-items:center;display:flex}.header-title{gap:16px}.header-title svg{color:#8b5cf6;flex-shrink:0}.header-title h1{color:#0f172a;font-size:28px;font-weight:700;line-height:1.2;margin:0 0 4px}.header-title p{color:#64748b;font-size:15px;margin:0}.add-chart-btn{align-items:center;background:linear-gradient(135deg,#16a34a,#15803d);border:none;border-radius:10px;box-shadow:0 4px 6px -1px #16a34a4d,0 2px 4px -1px #16a34a33;color:#fff;cursor:pointer;display:flex;font-size:15px;font-weight:600;gap:8px;padding:12px 24px;transition:all .2s ease}.add-chart-btn:hover{box-shadow:0 6px 12px -2px #16a34a66,0 4px 8px -2px #16a34a4d;transform:translateY(-2px)}.add-chart-btn:active{transform:translateY(0)}.charts-grid{grid-gap:24px;display:grid;gap:24px;grid-template-columns:repeat(auto-fit,minmax(min(100%,600px),1fr))}.chart-card{animation:fadeIn .4s ease;background:#fff;border:1px solid #0000000d;border-radius:16px;box-shadow:0 1px 3px #0000000d,0 10px 20px #00000005;overflow:hidden;transition:all .3s ease}.chart-card:hover{box-shadow:0 4px 6px -1px #00000014,0 20px 25px -5px #0000000d;transform:translateY(-2px)}.chart-card-header{align-items:center;background:linear-gradient(135deg,#fafafa,#fff);border-bottom:1px solid #f1f5f9;display:flex;justify-content:space-between;padding:20px 24px}.chart-card-title{align-items:center;display:flex;flex:1 1;gap:10px}.chart-card-title svg{color:#16a34a;flex-shrink:0}.chart-card-title span{color:#0f172a;font-size:16px;font-weight:600}.delete-chart-btn{align-items:center;background:#0000;border:1px solid #f1f5f9;border-radius:8px;color:#64748b;cursor:pointer;display:flex;height:36px;justify-content:center;transition:all .2s ease;width:36px}.delete-chart-btn:hover{background:#fef2f2;border-color:#fecaca;color:#dc2626}.chart-filters,.chart-series-config{background:#fafafa;border-bottom:1px solid #f1f5f9;padding:20px 24px}.chart-series-config{display:flex;flex-direction:column;gap:12px}.series-row{align-items:center;background:#fff;border:1px solid #e2e8f0;border-radius:10px;display:flex;gap:12px;padding:12px;transition:all .2s ease}.series-row:hover{border-color:#cbd5e1;box-shadow:0 2px 4px #0000000d}.series-color-indicator{border:2px solid #0000001a;border-radius:4px;flex-shrink:0;height:20px;width:20px}.series-label{color:#64748b;flex-shrink:0;font-size:13px;font-weight:600;letter-spacing:.5px;min-width:60px;text-transform:uppercase}.series-filters{display:flex;flex:1 1;gap:12px}.series-filters select{background:#fff;border:1.5px solid #e2e8f0;border-radius:8px;color:#334155;cursor:pointer;flex:1 1;font-size:14px;min-width:0;outline:none;padding:8px 12px;transition:all .2s ease}.series-filters select:hover{border-color:#cbd5e1}.series-filters select:focus{border-color:#16a34a;box-shadow:0 0 0 3px #16a34a1a}.delete-series-btn{align-items:center;background:#0000;border:1px solid #f1f5f9;border-radius:6px;color:#94a3b8;cursor:pointer;display:flex;flex-shrink:0;height:32px;justify-content:center;transition:all .2s ease;width:32px}.delete-series-btn:hover{background:#fef2f2;border-color:#fecaca;color:#dc2626}.add-series-btn{align-items:center;background:#fff;border:2px dashed #cbd5e1;border-radius:8px;color:#64748b;cursor:pointer;display:flex;font-size:14px;font-weight:600;gap:8px;justify-content:center;padding:10px 16px;transition:all .2s ease}.add-series-btn:hover{background:#16a34a0d;border-color:#16a34a;color:#16a34a}.chart-stats{grid-gap:12px;background:#fafafa;display:grid;gap:12px;grid-template-columns:repeat(auto-fit,minmax(120px,1fr));padding:20px 24px}.stat-card{background:#fff;border:1px solid #f1f5f9;border-radius:10px;display:flex;flex-direction:column;gap:4px;padding:12px;transition:all .2s ease}.stat-card:hover{border-color:#16a34a;box-shadow:0 2px 8px #16a34a1a}.stat-label{color:#64748b;font-size:12px;font-weight:600;letter-spacing:.5px;text-transform:uppercase}.stat-value{color:#16a34a;font-size:20px;font-weight:700}.chart-wrapper{padding:24px}.chart-loading{align-items:center;display:flex;flex-direction:column;gap:16px;justify-content:center;padding:80px 24px}.loading-spinner{animation:spin 1s linear infinite;border:4px solid #f1f5f9;border-radius:50%;border-top-color:#16a34a;height:48px;width:48px}@keyframes spin{to{transform:rotate(1turn)}}.chart-loading p{color:#64748b;font-size:15px;margin:0}.chart-placeholder{align-items:center;display:flex;flex-direction:column;gap:12px;justify-content:center;padding:80px 24px}.chart-placeholder svg{color:#cbd5e1}.chart-placeholder p{color:#475569;font-size:16px;font-weight:600;margin:0}.placeholder-hint{color:#94a3b8;font-size:14px;max-width:300px;text-align:center}@media (max-width:1400px){.charts-grid{grid-template-columns:1fr}}@media (max-width:768px){.customization-main{padding:16px}.customization-period-filters{flex-direction:column;gap:12px}.header-content{align-items:stretch;flex-direction:column}.header-title{align-items:flex-start;flex-direction:column;gap:12px}.add-chart-btn{justify-content:center;width:100%}.charts-grid{grid-template-columns:1fr}.chart-stats{grid-template-columns:repeat(2,1fr)}.chart-card-header,.chart-series-config{padding:16px}.series-row{align-items:stretch;gap:10px}.series-filters,.series-row{flex-direction:column}.series-label{min-width:auto}.chart-wrapper{padding:16px}}@media (max-width:480px){.header-title h1{font-size:22px}.header-title p{font-size:14px}.chart-stats{grid-template-columns:1fr}.stat-value{font-size:18px}}@keyframes fadeIn{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}.customization-main::-webkit-scrollbar{width:8px}.customization-main::-webkit-scrollbar-track{background:#f1f5f9}.customization-main::-webkit-scrollbar-thumb{background:#cbd5e1;border-radius:4px}.customization-main::-webkit-scrollbar-thumb:hover{background:#94a3b8}.recharts-tooltip-wrapper{z-index:10}.energy-page{background:#f8fafc;min-height:100vh}.energy-content{margin:0 auto;max-width:1440px;padding:28px 32px}.energy-header{margin-bottom:24px}.energy-header-left{align-items:center;display:flex;gap:16px}.energy-icon-wrapper{align-items:center;border-radius:14px;display:flex;flex-shrink:0;height:52px;justify-content:center;width:52px}.energy-title{color:#0f172a;font-size:26px;font-weight:700;line-height:1.2;margin:0 0 2px}.energy-subtitle{color:#64748b;font-size:14px;margin:0}.energy-card{background:#fff;border:1px solid #f1f5f9;border-radius:14px;box-shadow:0 1px 3px #0000000a,0 4px 12px #00000005}.energy-filters{margin-bottom:20px;padding:20px 24px}.energy-filters-header{align-items:center;color:#0f172a;display:flex;font-size:16px;font-weight:600;gap:10px;margin-bottom:18px}.energy-filters-grid{grid-gap:14px;display:grid;gap:14px;grid-template-columns:repeat(auto-fill,minmax(220px,1fr))}.energy-filter-item{display:flex;flex-direction:column}.energy-period-toggle{border:1px solid #e2e8f0;border-radius:8px;display:flex;height:38px;overflow:hidden}.energy-toggle-btn{background:#0000;border:none;color:#64748b;cursor:pointer;flex:1 1;font-size:12px;font-weight:500;padding:0 10px;transition:background .15s,color .15s;white-space:nowrap}.energy-toggle-btn.active{background:#f59e0b;color:#fff;font-weight:600}.energy-label{align-items:center;color:#475569;display:flex;font-size:13px;font-weight:500;gap:6px;margin-bottom:6px}.energy-label--required{position:relative}.energy-required-dot{background:#ef4444;border-radius:50%;display:inline-block;height:6px;margin-left:4px;width:6px}.energy-required-text{color:#ef4444;font-size:11px;margin:4px 0 0}.energy-input,.energy-select{background:#fafbfc;border:1px solid #e2e8f0;border-radius:10px;box-shadow:0 1px 2px #00000005;box-sizing:border-box;color:#1e293b;cursor:pointer;font-size:14px;outline:none;padding:10px 14px;transition:border-color .2s,box-shadow .2s,background-color .2s;width:100%}.energy-input:hover,.energy-select:hover{background:#fff;border-color:#cbd5e1}.energy-input:focus,.energy-select:focus{background:#fff;border-color:#f59e0b;box-shadow:0 0 0 3px #f59e0b14}.energy-panel{background:#fff;border:1px solid #f1f5f9;border-radius:14px;box-shadow:0 1px 3px #0000000a,0 4px 12px #00000005;margin-bottom:20px;overflow:hidden}.energy-panel-header{align-items:center;background:#0000;border:none;cursor:pointer;display:flex;justify-content:space-between;padding:16px 24px;transition:background .2s;width:100%}.energy-panel-header:hover{background:#f8fafc}.energy-panel-header-left{align-items:center;color:#0f172a;display:flex;font-size:16px;font-weight:600;gap:10px}.energy-panel-chevron{color:#94a3b8;transform:rotate(-90deg);transition:transform .25s ease}.energy-panel-chevron--open{transform:rotate(0deg)}.energy-panel-content{display:flex;flex-direction:column;gap:20px;padding:0 24px 24px}.energy-kpi-grid{grid-gap:10px;display:grid;gap:10px;grid-template-columns:repeat(auto-fit,minmax(150px,1fr));margin-bottom:20px}.energy-kpi{border-radius:12px;box-shadow:0 4px 12px #00000014;color:#fff;padding:10px 14px;transition:transform .2s,box-shadow .2s}.energy-kpi:hover{box-shadow:0 6px 20px #0000001f;transform:translateY(-2px)}.energy-kpi-content{align-items:center;display:flex;justify-content:space-between}.energy-kpi-label{font-size:11px;font-weight:500;letter-spacing:.5px;margin:0 0 2px;opacity:.9;text-transform:uppercase}.energy-kpi-value{font-size:20px;font-weight:700;line-height:1.1;margin:0 0 1px}.energy-kpi-unit{font-size:12px;margin:0;opacity:.75}.energy-kpi-icon{align-items:center;background:#fff3;border-radius:10px;display:flex;flex-shrink:0;height:32px;justify-content:center;width:32px}.energy-charts-grid{grid-gap:20px;display:grid;gap:20px;grid-template-columns:1fr 1fr}.energy-charts-grid--single{grid-template-columns:1fr}.energy-chart-card{padding:20px 24px}.energy-chart-card--full{grid-column:1/-1}.energy-chart-title{align-items:center;color:#0f172a;display:flex;font-size:16px;font-weight:600;gap:10px;margin:0 0 16px}.energy-chart-container{height:340px;position:relative}.energy-chart-container--pie{height:380px}.energy-chart-container--tall{height:420px}.energy-state-card{align-items:center;display:flex;flex-direction:column;padding:48px;text-align:center}.energy-state-title{color:#334155;font-size:17px;font-weight:600;margin:16px 0 6px}.energy-state-text{color:#64748b;font-size:14px;margin:8px 0 0}.energy-spinner{animation:energy-spin .8s linear infinite;border:3px solid #e2e8f0;border-radius:50%;height:40px;width:40px}@keyframes energy-spin{to{transform:rotate(1turn)}}.energy-error{background:#fef2f2;border:1px solid #fecaca;border-radius:14px;margin-bottom:20px;padding:18px 24px}.energy-error h3{color:#991b1b;font-size:15px;font-weight:600;margin:0 0 6px}.energy-error p{color:#b91c1c;font-size:13px;margin:0}@media (max-width:768px){.energy-content{padding:16px}.energy-charts-grid{grid-template-columns:1fr}.energy-kpi-grid{grid-template-columns:repeat(2,1fr)}.energy-filters-grid{grid-template-columns:1fr}.energy-title{font-size:20px}.energy-panel-header{padding:12px 16px}.energy-panel-content{padding:0 16px 16px}.energy-chart-card{padding:16px}.energy-chart-container{height:280px}.energy-chart-container--pie{height:300px}.energy-chart-container--tall{height:340px}}@media (max-width:480px){.energy-content{padding:12px}.energy-kpi-grid{grid-template-columns:1fr}.energy-title{font-size:18px}.energy-kpi-value{font-size:16px}}.water-page{background:#f8fafc;min-height:100vh}.water-content{margin:0 auto;max-width:1440px;padding:28px 32px}.water-header{margin-bottom:24px}.water-header-left{align-items:center;display:flex;gap:16px}.water-icon-wrapper{align-items:center;border-radius:14px;display:flex;flex-shrink:0;height:52px;justify-content:center;width:52px}.water-title{color:#0f172a;font-size:26px;font-weight:700;line-height:1.2;margin:0 0 2px}.water-subtitle{color:#64748b;font-size:14px;margin:0}.water-card{background:#fff;border:1px solid #f1f5f9;border-radius:14px;box-shadow:0 1px 3px #0000000a,0 4px 12px #00000005}.water-filters{margin-bottom:20px;padding:20px 24px}.water-filters-header{align-items:center;color:#0f172a;display:flex;font-size:16px;font-weight:600;gap:10px;margin-bottom:18px}.water-filters-grid{grid-gap:14px;display:grid;gap:14px;grid-template-columns:repeat(auto-fill,minmax(220px,1fr))}.water-filter-item{display:flex;flex-direction:column}.water-period-toggle{border:1px solid #e2e8f0;border-radius:8px;display:flex;height:38px;overflow:hidden}.water-toggle-btn{background:#0000;border:none;color:#64748b;cursor:pointer;flex:1 1;font-size:12px;font-weight:500;padding:0 10px;transition:background .15s,color .15s;white-space:nowrap}.water-toggle-btn.active{background:#3b82f6;color:#fff;font-weight:600}.water-label{align-items:center;color:#475569;display:flex;font-size:13px;font-weight:500;gap:6px;margin-bottom:6px}.water-label--required{position:relative}.water-required-dot{background:#ef4444;border-radius:50%;display:inline-block;height:6px;margin-left:4px;width:6px}.water-required-text{color:#ef4444;font-size:11px;margin:4px 0 0}.water-input,.water-select{background:#fafbfc;border:1px solid #e2e8f0;border-radius:10px;box-shadow:0 1px 2px #00000005;box-sizing:border-box;color:#1e293b;cursor:pointer;font-size:14px;outline:none;padding:10px 14px;transition:border-color .2s,box-shadow .2s,background-color .2s;width:100%}.water-input:hover,.water-select:hover{background:#fff;border-color:#cbd5e1}.water-input:focus,.water-select:focus{background:#fff;border-color:#3b82f6;box-shadow:0 0 0 3px #3b82f614}.water-tabs{background:#fff;border:1px solid #f1f5f9;border-radius:12px;box-shadow:0 1px 3px #0000000a;display:flex;gap:4px;margin-bottom:20px;padding:4px}.water-tab{align-items:center;background:#0000;border:2px solid #0000;border-radius:10px;cursor:pointer;display:flex;flex:1 1;font-size:14px;font-weight:500;gap:8px;justify-content:center;padding:10px 16px;transition:all .2s}.water-tab:hover{background:#f8fafc}.water-tab--active{background:#fff;box-shadow:0 1px 4px #0000000f}.water-tab-icon{font-size:16px}.water-kpi-grid{grid-gap:16px;display:grid;gap:16px;grid-template-columns:repeat(auto-fit,minmax(260px,1fr));margin-bottom:20px}.water-kpi{border-radius:14px;box-shadow:0 4px 12px #00000014;color:#fff;padding:14px 18px;transition:transform .2s,box-shadow .2s}.water-kpi:hover{box-shadow:0 6px 20px #0000001f;transform:translateY(-2px)}.water-kpi-content{align-items:center;display:flex;justify-content:space-between}.water-kpi-label{font-size:11px;font-weight:500;letter-spacing:.5px;margin:0 0 2px;opacity:.9;text-transform:uppercase}.water-kpi-value{font-size:24px;font-weight:700;line-height:1.1;margin:0 0 1px}.water-kpi-unit{font-size:12px;margin:0;opacity:.75}.water-kpi-icon{align-items:center;background:#fff3;border-radius:12px;display:flex;flex-shrink:0;height:40px;justify-content:center;width:40px}.water-charts-grid{grid-gap:20px;display:grid;gap:20px;grid-template-columns:1fr;margin-bottom:20px}.water-charts-grid--two{grid-template-columns:1fr 1fr}.water-charts-grid--single{grid-template-columns:1fr}.water-chart-card{padding:20px 24px}.water-chart-card--full{grid-column:1/-1}.water-chart-title{align-items:center;color:#0f172a;display:flex;font-size:16px;font-weight:600;gap:10px;margin:0 0 16px}.water-chart-container{height:340px;position:relative}.water-chart-container--pie{height:380px}.water-chart-container--tall{height:420px}.water-chart-container--extra-tall{height:520px}.water-state-card{align-items:center;display:flex;flex-direction:column;padding:48px;text-align:center}.water-state-title{color:#334155;font-size:17px;font-weight:600;margin:16px 0 6px}.water-state-text{color:#64748b;font-size:14px;margin:8px 0 0}.water-spinner{animation:water-spin .8s linear infinite;border:3px solid #e2e8f0;border-radius:50%;height:40px;width:40px}@keyframes water-spin{to{transform:rotate(1turn)}}.water-error{background:#fef2f2;border:1px solid #fecaca;border-radius:14px;margin-bottom:20px;padding:18px 24px}.water-error h3{color:#991b1b;font-size:15px;font-weight:600;margin:0 0 6px}.water-error p{color:#b91c1c;font-size:13px;margin:0}@media (max-width:1024px){.water-charts-grid--two{grid-template-columns:1fr}}@media (max-width:768px){.water-content{padding:16px}.water-charts-grid,.water-charts-grid--two,.water-filters-grid,.water-kpi-grid{grid-template-columns:1fr}.water-title{font-size:20px}.water-tabs{flex-direction:column;gap:4px}.water-chart-card{padding:16px}.water-chart-container{height:280px}.water-chart-container--pie{height:300px}.water-chart-container--tall{height:340px}.water-chart-container--extra-tall{height:420px}}@media (max-width:480px){.water-content{padding:12px}.water-title{font-size:18px}.water-kpi-value{font-size:20px}.water-kpi{padding:10px 14px}}.reports-page{background:#f8fafc;height:100%;min-height:100vh;overflow-y:auto}.reports-content{overflow-y:auto;padding:16px 24px}.reports-header{margin-bottom:32px}.reports-config-header{display:flex;flex-direction:column;gap:10px;margin-bottom:14px}.reports-header-left{align-items:center;display:flex;gap:16px}.reports-icon-wrapper{align-items:center;border-radius:11px;color:#fff;display:flex;flex-shrink:0;height:40px;justify-content:center;width:40px}.reports-title{color:#0f172a;font-size:20px;font-weight:700;line-height:1.2;margin:0 0 1px}.reports-subtitle{color:#64748b;font-size:12px;margin:0}.reports-back-btn{align-items:center;background:#fff;border:1px solid #e2e8f0;border-radius:8px;color:#475569;cursor:pointer;display:inline-flex;font-size:14px;font-weight:500;gap:6px;padding:7px 14px;transition:background .15s,color .15s,border-color .15s;width:-webkit-fit-content;width:fit-content}.reports-back-btn:hover{background:#f1f5f9;border-color:#cbd5e1;color:#1e293b}.reports-section-label{color:#94a3b8;font-size:12px;font-weight:600;letter-spacing:.06em;margin-bottom:16px;text-transform:uppercase}.reports-modules-grid{grid-gap:20px;display:grid;gap:20px;grid-template-columns:repeat(3,1fr);margin-bottom:28px;width:100%}@media (max-width:1100px){.reports-modules-grid{grid-template-columns:repeat(2,1fr)}}@media (max-width:640px){.reports-modules-grid{grid-template-columns:1fr}}.reports-module-card{background:none;border:none;border-radius:16px;cursor:pointer;padding:0;text-align:left;transition:transform .18s ease,box-shadow .18s ease;width:100%}.reports-module-card:hover{box-shadow:0 8px 24px #0000001a;transform:translateY(-3px)}.reports-module-card:hover .reports-module-arrow{transform:translateX(4px)}.reports-module-card-inner{border:1px solid #0000000f;border-radius:16px;box-sizing:border-box;display:flex;flex-direction:column;gap:16px;height:100%;padding:24px}.reports-module-icon{align-items:center;border-radius:14px;box-shadow:0 4px 12px #00000026;color:#fff;display:flex;flex-shrink:0;height:52px;justify-content:center;width:52px}.reports-module-body{flex:1 1}.reports-module-title{color:#0f172a;font-size:18px;font-weight:700;line-height:1.2;margin:0 0 6px}.reports-module-desc{color:#64748b;font-size:13px;line-height:1.5;margin:0}.reports-module-arrow{align-self:flex-end;transition:transform .18s ease}.reports-info-banner{align-items:flex-start;background:#fffbeb;border:1px solid #fde68a;border-radius:12px;display:flex;gap:12px;padding:14px 18px}.reports-info-icon{flex-shrink:0;margin-top:1px}.reports-info-text{color:#92400e;font-size:13px;line-height:1.5;margin:0}.reports-config-layout{grid-gap:14px;align-items:start;display:grid;gap:14px;grid-template-columns:1fr minmax(260px,290px);width:100%}@media (max-width:960px){.reports-config-layout,.reports-config-main{grid-template-columns:1fr}.reports-config-main>.reports-card:nth-child(3){grid-column:1}}.reports-config-main{grid-gap:10px;display:grid;gap:10px;grid-template-columns:1fr 1fr}.reports-config-main>.reports-card:nth-child(3){grid-column:1/-1}.reports-config-sidebar{position:-webkit-sticky;position:sticky;top:20px}.reports-card{background:#fff;border:1px solid #f1f5f9;border-radius:14px;box-shadow:0 1px 3px #0000000a,0 4px 12px #00000005;overflow:hidden}.reports-card-header{align-items:center;display:flex;gap:10px;margin-bottom:10px;padding:12px 16px 0}.reports-card-icon{align-items:center;border-radius:9px;display:flex;flex-shrink:0;height:34px;justify-content:center;width:34px}.reports-card-title{color:#0f172a;display:block;font-size:15px;font-weight:600;line-height:1.2;margin:0 0 2px}.reports-card-subtitle{color:#94a3b8;font-size:12px;margin:0}.reports-period-grid{grid-gap:10px;display:grid;gap:10px;grid-template-columns:1fr 1fr;padding:0 16px}@media (max-width:680px){.reports-period-grid{grid-template-columns:1fr}}.reports-period-badge{border-radius:8px;font-size:12px;font-weight:500;margin:8px 16px 12px;padding:5px 12px;width:-webkit-fit-content;width:fit-content}.reports-field{display:flex;flex-direction:column;gap:6px}.reports-label{align-items:center;color:#475569;display:flex;font-size:12px;font-weight:600;gap:5px;letter-spacing:.02em}.reports-select{-webkit-appearance:none;appearance:none;background:#fff;background-image:url("data:image/svg+xml;charset=utf-8,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 24 24' fill='none' stroke='%2394a3b8' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='m6 9 6 6 6-6'/%3E%3C/svg%3E");background-position:right 10px center;background-repeat:no-repeat;border:1.5px solid #e2e8f0;border-radius:8px;color:#1e293b;cursor:pointer;font-size:14px;height:38px;padding:0 32px 0 12px;transition:border-color .15s}.reports-select:focus{border-color:#6366f1;box-shadow:0 0 0 3px #6366f11a;outline:none}.reports-filters-toggle{align-items:center;background:none;border:none;cursor:pointer;display:flex;gap:12px;justify-content:space-between;padding:11px 16px;transition:background .15s;width:100%}.reports-filters-toggle:hover{background:#f8fafc}.reports-filters-toggle-left{align-items:center;display:flex;gap:12px}.reports-filters-toggle-right{align-items:center;display:flex;gap:10px}.reports-filter-badge{align-items:center;background:#eef2ff;border-radius:10px;color:#6366f1;display:inline-flex;font-size:11px;font-weight:600;margin-left:8px;padding:2px 8px}.reports-reset-btn{align-items:center;background:#fee2e2;border:none;border-radius:6px;color:#ef4444;cursor:pointer;display:inline-flex;font-size:12px;font-weight:500;gap:4px;padding:4px 10px;transition:background .15s}.reports-reset-btn:hover{background:#fecaca}.reports-filters-body{border-top:1px solid #f1f5f9;padding:0 16px 14px}.reports-filters-grid{grid-gap:10px;display:grid;gap:10px;grid-template-columns:1fr 1fr 1fr;margin-top:12px}@media (max-width:900px){.reports-filters-grid{grid-template-columns:1fr 1fr}}@media (max-width:640px){.reports-filters-grid{grid-template-columns:1fr}}.reports-summary-card{padding-bottom:14px}.reports-summary-section{padding:0 16px}.reports-summary-row{align-items:center;display:flex;justify-content:space-between;padding:8px 0}.reports-summary-label{color:#64748b;font-size:13px}.reports-summary-value{color:#1e293b;font-size:13px}.reports-summary-divider{background:#f1f5f9;height:1px;margin:8px 0}.reports-summary-period{display:flex;flex-direction:column;gap:8px;padding:4px 0}.reports-summary-period-item{align-items:center;display:flex;gap:10px}.reports-summary-period-tag{align-items:center;border-radius:6px;display:inline-flex;flex-shrink:0;font-size:11px;font-weight:700;height:22px;justify-content:center;width:32px}.reports-summary-period-label{color:#334155;font-size:13px;font-weight:500}.reports-generate-btn{align-items:center;background:#6366f1;background:var(--btn-color,#6366f1);border:none;border-radius:10px;box-shadow:0 2px 8px #00000026;color:#fff;cursor:pointer;display:flex;font-size:14px;font-weight:600;gap:8px;justify-content:center;margin:10px 16px 0;padding:10px 16px;transition:opacity .15s,transform .15s;width:calc(100% - 32px)}.reports-generate-btn:hover:not(:disabled){opacity:.9;transform:translateY(-1px)}.reports-generate-btn:disabled{cursor:not-allowed;opacity:.7;transform:none}.reports-spin{animation:reports-spin .8s linear infinite}@keyframes reports-spin{0%{transform:rotate(0deg)}to{transform:rotate(1turn)}}.reports-preview-banner{animation:reports-fade-in .3s ease;background:#f0fdf4;border:1px solid #86efac;border-radius:10px;display:flex;flex-direction:column;gap:10px;margin:14px 20px 0;padding:14px}@keyframes reports-fade-in{0%{opacity:0;transform:translateY(6px)}to{opacity:1;transform:translateY(0)}}.reports-preview-banner-inner{align-items:flex-start;display:flex;gap:10px}.reports-preview-check{align-items:center;background:#22c55e;border-radius:50%;color:#fff;display:flex;flex-shrink:0;font-size:12px;font-weight:700;height:22px;justify-content:center;width:22px}.reports-preview-title{color:#15803d;font-size:13px;font-weight:600;margin:0 0 2px}.reports-preview-sub{color:#166534;font-size:12px;margin:0}.reports-preview-btn{align-items:center;background:#22c55e;background:var(--btn-color,#22c55e);border:none;border-radius:8px;color:#fff;cursor:pointer;display:flex;font-size:13px;font-weight:600;gap:6px;justify-content:center;padding:9px 16px;transition:opacity .15s;width:100%}.reports-preview-btn:hover{opacity:.88}.rp-page{background:#e8edf5;display:flex;flex-direction:column;min-height:100vh}.rp-actions{background:#fff;border-bottom:1px solid #e2e8f0;box-shadow:0 2px 8px #0000000f;gap:12px;justify-content:space-between;padding:12px 32px;position:-webkit-sticky;position:sticky;top:0;z-index:10}.rp-actions,.rp-actions-right{align-items:center;display:flex}.rp-actions-right{gap:14px}.rp-actions-hint{color:#94a3b8;font-size:13px;font-style:italic}.rp-btn-back{align-items:center;background:#fff;border:1px solid #e2e8f0;border-radius:8px;color:#475569;cursor:pointer;display:inline-flex;font-size:13px;font-weight:500;gap:7px;padding:8px 16px;transition:background .15s,border-color .15s}.rp-btn-back:hover{background:#f1f5f9;border-color:#cbd5e1}.rp-btn-print{align-items:center;border:none;border-radius:8px;color:#fff;cursor:pointer;display:inline-flex;font-size:13px;font-weight:600;gap:7px;padding:9px 20px;transition:opacity .15s,transform .1s}.rp-btn-print:hover:not(:disabled){opacity:.9;transform:translateY(-1px)}.rp-btn-print:disabled{cursor:not-allowed;opacity:.7}.rp-spin{animation:rp-spin 1s linear infinite}@keyframes rp-spin{0%{transform:rotate(0deg)}to{transform:rotate(1turn)}}.rp-document-wrapper{display:flex;flex:1 1;justify-content:center;overflow-y:auto;padding:32px 24px 48px}.rp-document{background:#fff;border-radius:12px;box-shadow:0 4px 32px #0000001f;font-family:Segoe UI,Arial,sans-serif;max-width:960px;overflow:hidden;width:100%}.rp-cover{border-top:6px solid #0000;padding:36px 48px 28px}.rp-cover-top{gap:18px;margin-bottom:28px}.rp-cover-icon,.rp-cover-top{align-items:center;display:flex}.rp-cover-icon{border-radius:14px;flex-shrink:0;height:56px;justify-content:center;width:56px}.rp-cover-titles{flex:1 1}.rp-cover-title{font-size:28px;font-weight:800;line-height:1.2;margin:0 0 4px}.rp-cover-subtitle{color:#64748b;font-size:15px;font-weight:500;margin:0}.rp-cover-meta{margin-bottom:20px}.rp-cover-meta-row{align-items:baseline;color:#1e293b;display:flex;font-size:15px;font-weight:700;gap:8px}.rp-cover-meta-label{font-weight:700}.rp-cover-meta-value{color:#334155;font-weight:600}.rp-cover-desc{background:#ffffffb3;border:1px solid #00000012;border-radius:8px;padding:20px}.rp-cover-desc-title{color:#1e293b;font-size:15px;font-weight:700;margin-bottom:10px}.rp-cover-desc-item{align-items:flex-start;color:#334155;display:flex;font-size:14px;gap:10px;line-height:1.4;margin-bottom:6px}.rp-check{flex-shrink:0;font-size:15px;font-weight:700;margin-top:1px}.rp-exec-section{border-bottom:1px solid #f1f5f9;padding:32px 48px}.rp-exec-title{font-size:18px;font-weight:700;margin:0 0 12px}.rp-exec-body{border:1.5px dashed #cbd5e1;border-radius:8px;color:#334155;font-size:14px;line-height:1.7;min-height:80px;outline:none;padding:14px 16px;transition:border-color .15s,background .15s}.rp-exec-body:focus{background:#f8fafc;border-color:#94a3b8}.rp-section{border-bottom:1px solid #f1f5f9;padding:28px 48px}.rp-section:last-child{border-bottom:none}.rp-section-title{color:#1e293b;font-size:16px;font-weight:700;margin:0 0 20px}.rp-kpi-grid{grid-gap:14px;display:grid;gap:14px;grid-template-columns:repeat(auto-fill,minmax(200px,1fr))}.rp-kpi-card{background:#f8fafc;border:1px solid #e2e8f0;border-radius:10px;padding:16px 18px}.rp-kpi-label{color:#64748b;font-size:12px;font-weight:600;letter-spacing:.04em;margin-bottom:8px;text-transform:uppercase}.rp-kpi-row{align-items:center;display:flex;gap:8px;justify-content:space-between;margin-bottom:6px}.rp-kpi-main{align-items:baseline;display:flex;flex-wrap:wrap;gap:4px}.rp-kpi-value{font-size:22px;font-weight:800;line-height:1}.rp-kpi-unit{color:#64748b;font-size:12px;font-weight:600}.rp-kpi-year{color:#94a3b8;font-size:11px}.rp-kpi-badge{border-radius:999px;flex-shrink:0;font-size:12px;font-weight:700;padding:3px 8px}.rp-kpi-badge.pos{background:#dcfce7;color:#16a34a}.rp-kpi-badge.neg{background:#fee2e2;color:#dc2626}.rp-kpi-prev{color:#94a3b8;display:flex;font-size:12px;gap:4px}.rp-kpi-prev-val{font-weight:600}.rp-chart-block{background:#fafbfc;border:1px solid #e2e8f0;border-radius:10px;padding:20px 24px 24px}.rp-chart-title{border-left:4px solid #0000;color:#1e293b;font-size:15px;font-weight:700;margin-bottom:20px;padding-left:12px}.rp-pie-pair{align-items:flex-start;display:flex;gap:0}.rp-pie-side{align-items:center;display:flex;flex:1 1;flex-direction:column;gap:12px}.rp-pie-divider{align-self:stretch;background:#e2e8f0;margin:0 16px;width:1px}.rp-year-badge{border-radius:999px;color:#fff;display:inline-block;font-size:13px;font-weight:700;padding:4px 16px}.rp-pie-canvas{height:220px;position:relative;width:100%}.rp-bar-canvas{height:300px;position:relative}.rp-no-data{align-items:center;font-size:14px;font-style:italic;height:100%;justify-content:center}.rp-footer,.rp-no-data{color:#94a3b8;display:flex}.rp-footer{background:#f8fafc;border-top:1px solid #e2e8f0;font-size:12px;justify-content:space-between;padding:16px 48px}.cs-page{background:#f8fafc;min-height:100vh}.cs-content{align-items:center;display:flex;flex-direction:column;min-height:calc(100vh - 64px);padding:28px 32px}.cs-back-btn{align-items:center;align-self:flex-start;background:#fff;border:1px solid #e2e8f0;border-radius:8px;color:#475569;cursor:pointer;display:inline-flex;font-size:14px;font-weight:500;gap:6px;margin-bottom:40px;padding:7px 14px;transition:background .15s,color .15s,border-color .15s}.cs-back-btn:hover{background:#f1f5f9;border-color:#cbd5e1;color:#1e293b}.cs-card{background:#fff;border:1px solid #f1f5f9;border-radius:24px;box-shadow:0 1px 3px #0000000a,0 8px 32px #0000000f;max-width:560px;overflow:hidden;position:relative;width:100%}.cs-blob{border-radius:50%;pointer-events:none;position:absolute}.cs-blob-1{height:280px;right:-80px;top:-80px;width:280px}.cs-blob-2{bottom:-60px;height:200px;left:-60px;width:200px}.cs-card-inner{align-items:center;display:flex;flex-direction:column;padding:52px 48px;position:relative;text-align:center;z-index:1}.cs-icon-ring{border-radius:50%;height:96px;margin-bottom:24px;width:96px}.cs-icon-ring,.cs-icon-wrapper{align-items:center;display:flex;justify-content:center}.cs-icon-wrapper{border-radius:20px;box-shadow:0 6px 20px #0000002e;color:#fff;height:68px;width:68px}.cs-badge{align-items:center;background:#fef3c7;border:1px solid #fde68a;border-radius:20px;color:#92400e;display:inline-flex;font-size:12px;font-weight:600;gap:6px;margin-bottom:20px;padding:5px 14px}.cs-title{color:#0f172a;font-size:26px;font-weight:700;line-height:1.2;margin:0 0 12px}.cs-desc{color:#64748b;font-size:15px;line-height:1.6;margin:0;max-width:380px}.cs-divider{background:#f1f5f9;height:1px;margin:32px 0;width:100%}.cs-steps{text-align:left;width:100%}.cs-steps-label{color:#94a3b8;font-size:11px;font-weight:700;letter-spacing:.07em;margin:0 0 16px;text-transform:uppercase}.cs-steps-list{display:flex;flex-direction:column;gap:12px}.cs-step{align-items:center;display:flex;gap:12px}.cs-step-dot{background:#e2e8f0;border-radius:50%;flex-shrink:0;height:10px;transition:background .2s;width:10px}.cs-step-dot--active{height:12px;width:12px}.cs-step-label{color:#94a3b8;flex:1 1;font-size:14px}.cs-step-badge,.cs-step-label--active{font-weight:600}.cs-step-badge{border-radius:8px;font-size:11px;padding:2px 10px}@media (max-width:640px){.cs-content{min-height:calc(100vh - 56px);padding:20px 16px}.cs-back-btn{margin-bottom:28px}.cs-card{border-radius:18px}.cs-card-inner{padding:36px 28px}.cs-icon-ring{height:80px;margin-bottom:20px;width:80px}.cs-icon-wrapper{border-radius:16px;height:56px;width:56px}.cs-title{font-size:22px}.cs-desc{font-size:14px}.cs-divider{margin:24px 0}}@media (max-width:400px){.cs-card-inner{padding:28px 20px}.cs-title{font-size:20px}}.sidebar{background:#fff;border-right:1px solid #e2e8f0;display:flex;flex-direction:column;height:100vh;left:0;overflow:hidden;position:fixed;top:0;transition:width .3s ease;width:80px;z-index:50}.sidebar.open{width:256px}.sidebar-header{align-items:center;background:#fff;border-bottom:1px solid #e2e8f0;display:flex;gap:12px;justify-content:flex-start;padding:16px;transition:padding .3s ease}.sidebar.open .sidebar-header{padding:20px 16px}.sidebar-menu-button{align-items:center;background:#0000;border:none;border-radius:8px;color:#475569;cursor:pointer;display:flex;justify-content:center;padding:8px;transition:all .2s ease}.sidebar-menu-button:hover{background:#f1f5f9;color:#16a34a}.sidebar-logo{display:flex;height:46px;object-fit:contain;opacity:0;pointer-events:none;transition:opacity .15s ease;width:auto}.sidebar.open .sidebar-logo{opacity:1}.sidebar-nav{flex:1 1;overflow-y:auto;padding:16px}.sidebar-submenu .sub{font-size:14px;padding-left:40px}.sidebar-nav::-webkit-scrollbar{width:6px}.sidebar-nav::-webkit-scrollbar-track{background:#0000}.sidebar-nav::-webkit-scrollbar-thumb{background:#cbd5e1;border-radius:3px}.sidebar-nav::-webkit-scrollbar-thumb:hover{background:#94a3b8}.sidebar-item{align-items:center;background:#0000;border:none;border-radius:8px;color:#475569;cursor:pointer;display:flex;font-size:14px;font-weight:500;gap:12px;justify-content:flex-start;margin-bottom:8px;padding:12px 16px;text-align:left;transition:all .2s ease;white-space:nowrap;width:100%}.sidebar:not(.open) .sidebar-item{gap:0;justify-content:center;padding:12px}.sidebar:not(.open) .sidebar-item .sidebar-icon{margin:0}.sidebar-item:hover{background:#f1f5f9;transform:translateX(2px)}.sidebar-item.active{box-shadow:0 1px 3px #0000001a;font-weight:600}.sidebar-icon{align-items:center;display:flex;flex-shrink:0;height:24px;justify-content:center;width:24px}.sidebar-icon img{height:100%;object-fit:contain;width:100%}.sidebar-label{flex:1 1;opacity:1;text-align:left;transition:opacity .2s ease}.sidebar:not(.open) .sidebar-label{opacity:0;overflow:hidden;width:0}.sidebar-child{margin-left:20px}.sidebar:not(.open) .sidebar-child{margin-left:0}.sidebar-section-label{color:#94a3b8;font-size:10px;font-weight:700;letter-spacing:.1em;max-height:0;opacity:0;overflow:hidden;padding:16px 16px 4px;pointer-events:none;text-transform:uppercase;transition:opacity .2s ease,max-height .2s ease;white-space:nowrap}.sidebar.open .sidebar-section-label{max-height:40px;opacity:1}.sidebar-wip-icon{color:#f59e0b;flex-shrink:0;opacity:0;overflow:hidden;transition:opacity .2s ease,width .2s ease;width:0}.sidebar.open .sidebar-wip-icon{opacity:1;width:auto}@media (max-width:1024px){.sidebar-item{font-size:13px;padding:10px 12px}.sidebar-icon{height:20px;margin-right:12px;object-fit:contain;width:20px}}@media (max-width:768px){.sidebar{transform:translateX(-100%);z-index:60}.sidebar.open{transform:translateX(0);width:256px}.sidebar-overlay{background:#00000080;bottom:0;left:0;opacity:0;pointer-events:none;position:fixed;right:0;top:0;transition:opacity .3s ease;z-index:55}.sidebar-overlay.open{opacity:1;pointer-events:all}}body,html{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Fira Sans,Droid Sans,Helvetica Neue,sans-serif;height:100%;margin:0;max-width:100vw;overflow-x:hidden;padding:0;width:100%}*,:after,:before{box-sizing:border-box}code{font-family:source-code-pro,Menlo,Monaco,Consolas,Courier New,monospace}
/*# sourceMappingURL=main.9657223b.css.map*/