.login-page{min-height:100vh;background:linear-gradient(135deg,var(--primary-dark) 0%,#001a33 100%);display:flex;align-items:center;justify-content:center;padding:2rem}.login-container{background:#fff;border-radius:12px;box-shadow:var(--shadow-lg);width:100%;max-width:420px;overflow:hidden}.login-header{background:var(--primary-dark);color:#fff;padding:2rem;text-align:center}.login-logo svg{width:64px;height:64px;margin-bottom:1rem}.login-header h1{font-size:1.5rem;margin:0;letter-spacing:1px}.login-header p{margin:.25rem 0 0;opacity:.8;font-size:.875rem}.login-body{padding:2rem}.login-body h2{text-align:center;margin-bottom:1.5rem;color:var(--text-dark);font-size:1.25rem}.login-error{background:#dc35451a;color:var(--danger);padding:.75rem;border-radius:6px;margin-bottom:1rem;font-size:.875rem;text-align:center}.input-icon{position:relative}.input-icon>svg{position:absolute;left:.875rem;top:50%;transform:translateY(-50%);color:var(--text-muted)}.input-icon .form-control{padding-left:2.75rem;padding-right:2.75rem}.toggle-password{position:absolute;right:.75rem;top:50%;transform:translateY(-50%);background:none;border:none;cursor:pointer;color:var(--text-muted);padding:0}.toggle-password:hover{color:var(--text-dark)}.btn-login{width:100%;justify-content:center;padding:.875rem;font-size:1rem;margin-top:.5rem}.btn-login:disabled{opacity:.7;cursor:not-allowed}.login-help{text-align:center;margin-top:1.5rem}.help-link{display:inline-flex;align-items:center;gap:.375rem;background:none;border:none;color:var(--primary-dark);font-size:.875rem;cursor:pointer}.help-link:hover{text-decoration:underline}.login-footer{padding:1rem 2rem;background:var(--bg-light);display:flex;justify-content:center;gap:2rem;border-top:1px solid var(--border-color)}.login-footer span{font-size:.75rem;color:var(--text-muted);cursor:pointer}.login-footer span:hover{color:var(--primary-dark)}.modal-content h3{margin:0 0 1rem;color:var(--text-dark)}.modal-content ul{margin:.5rem 0 1rem 1.25rem}.modal-content li{margin:.25rem 0}.select-profile-page{min-height:100vh;background:linear-gradient(135deg,var(--primary-dark) 0%,#001a33 100%);display:flex;align-items:center;justify-content:center;padding:2rem}.select-profile-container{background:#fff;border-radius:12px;box-shadow:var(--shadow-lg);width:100%;max-width:600px;overflow:hidden}.select-profile-header{background:var(--primary-dark);color:#fff;padding:2rem;text-align:center}.header-logo{display:flex;align-items:center;justify-content:center;gap:.75rem;margin-bottom:1.5rem}.logo-icon svg{width:48px;height:48px}.logo-text{display:flex;flex-direction:column;text-align:left}.logo-title{font-size:1.25rem;font-weight:700}.logo-subtitle{font-size:.75rem;opacity:.8}.select-profile-header h1{font-size:1.5rem;margin:0 0 .5rem}.select-profile-header p{margin:0;opacity:.8;font-size:.9rem}.profile-filters{padding:1.5rem;background:var(--bg-light);border-bottom:1px solid var(--border-color)}.search-box{position:relative;margin-bottom:1rem}.search-box svg{position:absolute;left:1rem;top:50%;transform:translateY(-50%);color:var(--text-muted)}.search-box input{width:100%;padding:.75rem 1rem .75rem 2.75rem;border:1px solid var(--border-color);border-radius:8px;font-size:.875rem}.search-box input:focus{outline:none;border-color:var(--primary-dark)}.type-filters{display:flex;gap:.5rem;flex-wrap:wrap}.profiles-list{padding:1rem;display:flex;flex-direction:column;gap:.75rem;max-height:400px;overflow-y:auto}.profile-card{display:flex;align-items:center;gap:1rem;padding:1rem;background:#fff;border:2px solid var(--border-color);border-radius:10px;cursor:pointer;text-align:left;width:100%;transition:all .2s}.profile-card:hover{border-color:var(--primary-dark);background:var(--bg-light)}.profile-icon{width:56px;height:56px;border-radius:12px;display:flex;align-items:center;justify-content:center;flex-shrink:0}.profile-icon.primary{background:#0033661a;color:var(--primary-dark)}.profile-icon.orange{background:#f5a62326;color:var(--accent-orange)}.profile-icon.success{background:#28a7451a;color:var(--success)}.profile-info{flex:1;min-width:0}.profile-type{font-size:.7rem;font-weight:600;text-transform:uppercase;padding:.125rem .5rem;border-radius:4px}.profile-type.primary{background:#0033661a;color:var(--primary-dark)}.profile-type.orange{background:#f5a62326;color:#d68a00}.profile-type.success{background:#28a7451a;color:var(--success)}.profile-name{font-size:1rem;font-weight:600;color:var(--text-dark);margin:.375rem 0 .25rem}.profile-address{display:flex;align-items:center;gap:.25rem;font-size:.8rem;color:var(--text-muted);margin:0 0 .25rem}.profile-sites{font-size:.75rem;color:var(--text-muted)}.profile-arrow{color:var(--text-muted);flex-shrink:0}.profile-card:hover .profile-arrow{transform:translate(4px);color:var(--primary-dark)}.no-profiles{text-align:center;padding:3rem 2rem;color:var(--text-muted)}.no-profiles svg{margin-bottom:1rem;opacity:.5}.no-profiles h3{margin:0 0 .5rem;color:var(--text-dark)}.no-profiles p{margin:0}.dashboard{display:flex;flex-direction:column;gap:1.5rem}.welcome-banner{background:linear-gradient(135deg,var(--primary-dark),#004080);color:#fff;padding:1.5rem 2rem;border-radius:12px;display:flex;justify-content:space-between;align-items:center}.welcome-text h2{font-size:1.25rem;margin:0 0 .25rem}.welcome-text p{margin:0;opacity:.85;font-size:.9rem}.date-info{display:flex;align-items:center;gap:.5rem;font-size:.85rem;opacity:.9}.stats-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:1rem}.stat-card{background:#fff;border-radius:10px;padding:1.25rem;display:flex;gap:1rem;border-left:4px solid;box-shadow:var(--shadow-sm)}.stat-card.gaz{border-left-color:var(--primary-dark)}.stat-card.elec{border-left-color:var(--accent-orange)}.stat-card.sites{border-left-color:var(--success)}.stat-card.invoices{border-left-color:#6c5ce7}.stat-icon{width:48px;height:48px;border-radius:10px;display:flex;align-items:center;justify-content:center}.stat-card.gaz .stat-icon{background:#0033661a;color:var(--primary-dark)}.stat-card.elec .stat-icon{background:#f5a62326;color:var(--accent-orange)}.stat-card.sites .stat-icon{background:#28a7451a;color:var(--success)}.stat-card.invoices .stat-icon{background:#6c5ce71a;color:#6c5ce7}.stat-content{display:flex;flex-direction:column}.stat-label{font-size:.75rem;color:var(--text-muted);text-transform:uppercase;letter-spacing:.5px}.stat-value{font-size:1.5rem;font-weight:700;color:var(--text-dark);margin:.25rem 0}.stat-trend,.stat-info{font-size:.75rem;display:flex;align-items:center;gap:.25rem}.stat-trend.up{color:var(--success)}.stat-trend.down{color:var(--danger)}.stat-info{color:var(--text-muted)}.charts-section{display:grid;grid-template-columns:2fr 1fr;gap:1rem}.chart-card{background:#fff;border-radius:10px;box-shadow:var(--shadow-sm);overflow:hidden}.chart-header{display:flex;justify-content:space-between;align-items:center;padding:1rem 1.25rem;border-bottom:1px solid var(--border-color)}.chart-legend{display:flex;gap:1rem;font-size:.75rem}.chart-legend span{display:flex;align-items:center;gap:.375rem;color:var(--text-muted)}.legend-gaz span,.legend-elec span{width:10px;height:10px;border-radius:2px}.chart-body{padding:1rem}.pie-container{display:flex;align-items:center}.pie-legend{display:flex;flex-direction:column;gap:.75rem}.pie-legend-item{display:flex;align-items:center;gap:.5rem;font-size:.8rem}.pie-legend-item .color{width:12px;height:12px;border-radius:3px}.pie-legend-item strong{margin-left:auto;color:var(--text-dark)}.alerts-section{background:#fff;border-radius:10px;box-shadow:var(--shadow-sm)}.section-header{padding:1rem 1.25rem;border-bottom:1px solid var(--border-color)}.section-header h3{margin:0;font-size:1rem;display:flex;align-items:center;gap:.5rem;color:var(--text-dark)}.alerts-list{padding:.5rem}.alert-item{display:flex;align-items:flex-start;gap:.75rem;padding:1rem;border-radius:8px;margin:.5rem}.alert-item.warning{background:#f5a62314}.alert-item.info{background:#0033660a}.alert-dot{width:10px;height:10px;border-radius:50%;flex-shrink:0;margin-top:4px}.alert-item.warning .alert-dot{background:var(--accent-orange)}.alert-item.info .alert-dot{background:var(--primary-dark)}.alert-content{flex:1}.alert-content strong{display:block;font-size:.9rem;margin-bottom:.25rem;color:var(--text-dark)}.alert-content p{margin:0;font-size:.8rem;color:var(--text-muted)}.alert-date{font-size:.7rem;color:var(--text-muted);white-space:nowrap}.quick-actions h3{font-size:1rem;margin:0 0 1rem;color:var(--text-dark)}.actions-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1rem}.action-card{display:flex;align-items:center;gap:.75rem;background:#fff;border:2px solid var(--border-color);padding:1rem 1.25rem;border-radius:10px;cursor:pointer;transition:all .2s}.action-card:hover{border-color:var(--primary-dark);background:#00336605}.action-card svg:first-child{color:var(--primary-dark)}.action-card span{flex:1;text-align:left;font-weight:500;color:var(--text-dark)}.action-card svg:last-child{color:var(--text-muted)}.action-card:hover svg:last-child{transform:translate(4px);color:var(--primary-dark)}@media (max-width: 1200px){.stats-grid{grid-template-columns:repeat(2,1fr)}.charts-section{grid-template-columns:1fr}}@media (max-width: 768px){.welcome-banner{flex-direction:column;text-align:center;gap:1rem}.stats-grid,.actions-grid{grid-template-columns:1fr}}.delivery-points{display:flex;flex-direction:column;gap:1rem}.page-header-bar{background:linear-gradient(135deg,var(--primary-dark),#004080);color:#fff;padding:1.25rem 1.5rem;border-radius:10px}.header-stats{display:flex;gap:2rem}.header-stat{display:flex;flex-direction:column}.header-stat .stat-num{font-size:1.5rem;font-weight:700}.header-stat .stat-label{font-size:.8rem;opacity:.85;display:flex;align-items:center;gap:.375rem}.filters-panel{background:#fff;border:1px solid var(--border-color);border-radius:10px;padding:1.25rem;display:flex;gap:2rem}.results-info{font-size:.85rem;color:var(--text-muted)}.points-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(320px,1fr));gap:1rem}.point-card{background:#fff;border:1px solid var(--border-color);border-radius:10px;padding:1.25rem;cursor:pointer;position:relative;transition:all .2s}.point-card:hover{border-color:var(--primary-dark);box-shadow:var(--shadow-md)}.point-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1rem}.point-type{display:flex;align-items:center;gap:.375rem;font-size:.75rem;font-weight:600;padding:.25rem .625rem;border-radius:4px}.point-type.gaz{background:#0033661a;color:var(--primary-dark)}.point-type.electricite{background:#f5a62326;color:#d68a00}.point-type.mixte{background:#28a7451a;color:var(--success)}.point-body{display:flex;gap:1rem;margin-bottom:1rem}.point-icon{width:48px;height:48px;background:var(--bg-light);border-radius:10px;display:flex;align-items:center;justify-content:center;color:var(--text-muted)}.point-info{display:flex;flex-direction:column;gap:.25rem}.point-ref{font-weight:600;color:var(--text-dark)}.point-address{display:flex;align-items:center;gap:.25rem;font-size:.85rem;color:var(--text-muted)}.point-city{font-size:.8rem;color:var(--text-muted)}.point-footer{display:flex;justify-content:space-between;padding-top:1rem;border-top:1px solid var(--border-color)}.conso-label{font-size:.75rem;color:var(--text-muted)}.conso-value{font-weight:600;color:var(--primary-dark)}.point-arrow{position:absolute;right:1rem;top:50%;transform:translateY(-50%);color:var(--text-muted);transition:all .2s}.point-card:hover .point-arrow{color:var(--primary-dark);transform:translateY(-50%) translate(4px)}@media (max-width: 768px){.header-stats{flex-wrap:wrap;gap:1rem}.filters-panel{flex-direction:column;gap:1rem}.points-grid{grid-template-columns:1fr}}.point-detail{display:flex;flex-direction:column;gap:1.25rem}.back-link{display:inline-flex;align-items:center;gap:.5rem;background:none;border:none;color:var(--primary-dark);font-size:.9rem;cursor:pointer;padding:0}.back-link:hover{text-decoration:underline}.detail-header{background:#fff;border-radius:10px;padding:1.5rem;display:flex;justify-content:space-between;align-items:flex-start;gap:2rem;box-shadow:var(--shadow-sm)}.type-badge{display:inline-flex;align-items:center;gap:.375rem;padding:.375rem .75rem;border-radius:6px;font-size:.8rem;font-weight:600;margin-bottom:.5rem}.type-badge.gaz{background:#0033661a;color:var(--primary-dark)}.type-badge.electricite{background:#f5a62326;color:#d68a00}.header-main h1{font-size:1.5rem;margin:0 0 .5rem;color:var(--text-dark)}.address{display:flex;align-items:center;gap:.375rem;color:var(--text-muted);font-size:.9rem;margin:0}.header-stats{display:flex;gap:1.5rem}.stat-box{text-align:center;padding:.75rem 1.25rem;background:var(--bg-light);border-radius:8px}.stat-box .stat-value{display:block;font-size:1.25rem;font-weight:700;color:var(--primary-dark)}.stat-box .stat-label{font-size:.7rem;color:var(--text-muted);text-transform:uppercase}.stat-box.status{display:flex;align-items:center}.tabs{display:flex;background:#fff;border-radius:10px;padding:.375rem;gap:.25rem;box-shadow:var(--shadow-sm)}.tabs button{display:flex;align-items:center;gap:.5rem;padding:.75rem 1.25rem;background:none;border:none;border-radius:8px;cursor:pointer;color:var(--text-muted);font-weight:500;font-size:.9rem;transition:all .2s}.tabs button:hover{background:var(--bg-light);color:var(--text-dark)}.tabs button.active{background:var(--primary-dark);color:#fff}.tab-content{background:#fff;border-radius:10px;padding:1.5rem;box-shadow:var(--shadow-sm)}.info-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:1.5rem;margin-bottom:1.5rem}.info-card h3{margin:0 0 1rem;font-size:1rem;color:var(--text-dark);padding-bottom:.75rem;border-bottom:1px solid var(--border-color)}.info-rows{display:flex;flex-direction:column;gap:.75rem}.info-row{display:flex;justify-content:space-between}.info-row span{color:var(--text-muted);font-size:.875rem}.info-row strong{color:var(--text-dark);font-size:.875rem}.mini-chart-section h3{margin:0 0 1rem;font-size:1rem;color:var(--text-dark)}.chart-full{margin-bottom:1.5rem}.chart-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1rem}.period-selector{display:flex;gap:.375rem}.period-selector button{padding:.375rem .75rem;border:1px solid var(--border-color);background:#fff;border-radius:6px;font-size:.8rem;cursor:pointer}.period-selector button:hover{border-color:var(--primary-dark)}.period-selector button.active{background:var(--primary-dark);border-color:var(--primary-dark);color:#fff}.consumption-stats{display:flex;gap:2rem;padding-top:1rem;border-top:1px solid var(--border-color)}.cstat{display:flex;flex-direction:column}.cstat-label{font-size:.75rem;color:var(--text-muted)}.cstat-value{font-size:1.125rem;font-weight:600;color:var(--text-dark)}.invoices-table{overflow-x:auto}.invoices-table table{width:100%;border-collapse:collapse}.invoices-table th{background:var(--primary-dark);color:#fff;padding:.875rem 1rem;text-align:left;font-size:.8rem;text-transform:uppercase}.invoices-table td{padding:1rem;border-bottom:1px solid var(--border-color)}.btn-sm{padding:.375rem .625rem}.timeline{padding-left:1.5rem;border-left:2px solid var(--border-color)}.timeline-item{position:relative;padding:0 0 1.5rem 1.5rem}.timeline-dot{position:absolute;left:-1.5rem;top:.25rem;width:12px;height:12px;background:var(--primary-dark);border-radius:50%;transform:translate(-50%)}.timeline-content{display:flex;flex-direction:column;gap:.25rem}.timeline-date{font-size:.75rem;color:var(--text-muted)}.timeline-content strong{color:var(--text-dark)}.timeline-content p{margin:0;font-size:.875rem;color:var(--text-muted)}@media (max-width: 768px){.detail-header{flex-direction:column}.header-stats{width:100%;justify-content:space-between}.info-grid{grid-template-columns:1fr}.tabs{overflow-x:auto}.consumption-stats{flex-direction:column;gap:1rem}}.invoices-page{display:flex;flex-direction:column;gap:1rem}.invoices-header{background:linear-gradient(135deg,var(--primary-dark),#004080);color:#fff;padding:1.25rem 1.5rem;border-radius:10px}.header-stats{display:flex;gap:3rem}.hstat{display:flex;flex-direction:column}.hstat-value{font-size:1.5rem;font-weight:700}.hstat-label{font-size:.8rem;opacity:.85}.filters-bar{display:flex;gap:1rem;align-items:center}.search-input{flex:1;position:relative}.filter-toggle.active{background:var(--primary-dark);color:#fff;border-color:var(--primary-dark)}.filters-panel{background:#fff;border:1px solid var(--border-color);border-radius:10px;padding:1.25rem}.filter-group label{display:block;font-size:.75rem;font-weight:600;color:var(--text-muted);text-transform:uppercase;margin-bottom:.5rem}.filter-buttons{display:flex;gap:.5rem}.filter-btn{padding:.5rem 1rem;border:1px solid var(--border-color);background:#fff;border-radius:6px;font-size:.8rem;cursor:pointer}.filter-btn:hover{border-color:var(--primary-dark)}.filter-btn.active{background:var(--primary-dark);border-color:var(--primary-dark);color:#fff}.selection-bar{display:flex;justify-content:space-between;align-items:center;background:#0033660d;border:1px solid var(--primary-dark);border-radius:8px;padding:.875rem 1.25rem}.selection-bar span{font-size:.9rem;color:var(--text-dark)}.selection-actions{display:flex;gap:.75rem}.btn-sm{padding:.5rem 1rem;font-size:.8rem}.invoices-table-container{background:#fff;border-radius:10px;overflow:hidden;box-shadow:var(--shadow-sm)}.invoices-table{width:100%;border-collapse:collapse}.invoices-table th{background:var(--primary-dark);color:#fff;padding:.875rem 1rem;text-align:left;font-size:.75rem;font-weight:600;text-transform:uppercase;letter-spacing:.5px}.invoices-table td{padding:1rem;border-bottom:1px solid var(--border-color);font-size:.875rem}.invoices-table tr:hover{background:var(--bg-light)}.invoices-table tr.selected{background:#0033660a}.col-check{width:48px;text-align:center}.check-btn{background:none;border:none;cursor:pointer;color:var(--text-muted);padding:0;display:flex;align-items:center;justify-content:center}.check-btn:hover,tr.selected .check-btn{color:var(--primary-dark)}.pdl-badge{font-size:.75rem;background:var(--bg-light);padding:.25rem .5rem;border-radius:4px;font-family:monospace}.amount-ttc{color:var(--primary-dark)}.action-btn{background:none;border:1px solid var(--border-color);border-radius:6px;padding:.375rem;cursor:pointer;color:var(--text-muted);display:flex;align-items:center;justify-content:center}.invoice-modal{max-width:500px}.invoice-preview{padding:1rem}.preview-header{display:flex;justify-content:space-between;padding-bottom:1.25rem;border-bottom:2px solid var(--primary-dark);margin-bottom:1.25rem}.company-info h2{margin:0;color:var(--primary-dark);font-size:1.25rem}.company-info p{margin:.25rem 0 0;font-size:.85rem;color:var(--text-muted)}.invoice-info{text-align:right}.inv-number{display:block;font-weight:700;font-size:1.125rem;color:var(--text-dark)}.inv-date{font-size:.8rem;color:var(--text-muted)}.preview-details{margin-bottom:1.5rem}.detail-row{display:flex;justify-content:space-between;padding:.5rem 0;border-bottom:1px solid var(--border-color);font-size:.875rem}.detail-row span{color:var(--text-muted)}.preview-amounts{background:var(--bg-light);border-radius:8px;padding:1rem;margin-bottom:1.5rem}.amount-row{display:flex;justify-content:space-between;padding:.375rem 0;font-size:.875rem}.amount-row.total{border-top:1px solid var(--border-color);margin-top:.5rem;padding-top:.75rem;font-weight:700;font-size:1rem;color:var(--primary-dark)}.preview-actions{display:flex;gap:1rem;justify-content:flex-end}@media (max-width: 768px){.header-stats{flex-wrap:wrap;gap:1rem}.filters-bar{flex-wrap:wrap}.invoices-table{font-size:.8rem}.invoices-table th,.invoices-table td{padding:.75rem .5rem}}.consumption-page{display:flex;flex-direction:column;gap:1.25rem}.consumption-header{margin-bottom:.5rem}.header-cards{display:grid;grid-template-columns:repeat(2,1fr);gap:1rem}.energy-card{background:#fff;border:2px solid var(--border-color);border-radius:12px;padding:1.25rem;display:flex;gap:1rem;cursor:pointer;transition:all .2s}.energy-card:hover{border-color:var(--primary-dark)}.energy-card.active{border-color:var(--primary-dark);box-shadow:0 0 0 3px #0033661a}.energy-card.gaz .card-icon{background:#0033661a;color:var(--primary-dark)}.energy-card.elec .card-icon{background:#f5a62326;color:var(--accent-orange)}.card-icon{width:56px;height:56px;border-radius:12px;display:flex;align-items:center;justify-content:center}.card-content{display:flex;flex-direction:column}.card-label{font-size:.75rem;color:var(--text-muted);text-transform:uppercase;letter-spacing:.5px}.card-value{font-size:1.5rem;font-weight:700;color:var(--text-dark);margin:.25rem 0}.card-trend{display:flex;align-items:center;gap:.25rem;font-size:.8rem}.card-trend.up{color:var(--danger)}.card-trend.down{color:var(--success)}.chart-controls{display:flex;align-items:center;gap:1rem}.period-selector{display:flex;align-items:center;gap:.25rem;background:#fff;border:1px solid var(--border-color);border-radius:8px;padding:.25rem}.period-selector svg{margin:0 .5rem;color:var(--text-muted)}.period-selector button{padding:.5rem 1rem;border:none;background:none;border-radius:6px;font-size:.8rem;cursor:pointer;color:var(--text-muted)}.period-selector button:hover{background:var(--bg-light)}.period-selector button.active{background:var(--primary-dark);color:#fff}.view-selector{display:flex;background:#fff;border:1px solid var(--border-color);border-radius:8px;overflow:hidden}.view-selector button{padding:.5rem .75rem;border:none;background:none;cursor:pointer;color:var(--text-muted);border-right:1px solid var(--border-color)}.view-selector button:last-child{border-right:none}.view-selector button:hover{background:var(--bg-light)}.view-selector button.active{background:var(--primary-dark);color:#fff}.chart-controls .btn{margin-left:auto}.main-chart{background:#fff;border-radius:12px;box-shadow:var(--shadow-sm);overflow:hidden}.chart-header{display:flex;justify-content:space-between;align-items:center;padding:1rem 1.5rem;border-bottom:1px solid var(--border-color)}.chart-header h3{margin:0;font-size:1rem;color:var(--text-dark)}.chart-legend{display:flex;gap:1.5rem}.chart-legend span{display:flex;align-items:center;gap:.5rem;font-size:.8rem;color:var(--text-muted)}.legend-gaz span,.legend-elec span{width:12px;height:12px;border-radius:3px}.legend-gaz span{background:var(--primary-dark)}.legend-elec span{background:var(--accent-orange)}.chart-body{padding:1rem 1rem 1rem 0}.stats-row{display:grid;grid-template-columns:repeat(3,1fr);gap:1rem}.stat-card{background:#fff;border-radius:10px;padding:1.25rem;box-shadow:var(--shadow-sm)}.stat-card h4{margin:0 0 1rem;font-size:.85rem;color:var(--text-muted);font-weight:500}.stat-values{display:flex;flex-direction:column;gap:.75rem}.stat-item{display:flex;align-items:center;gap:.5rem;font-weight:600}.stat-item.gaz{color:var(--primary-dark)}.stat-item.elec{color:var(--accent-orange)}@media (max-width: 1024px){.header-cards,.stats-row{grid-template-columns:1fr}}@media (max-width: 768px){.chart-controls{flex-wrap:wrap}.period-selector{width:100%;justify-content:center}.chart-controls .btn{margin-left:0;width:100%}}.news-page{display:flex;flex-direction:column;gap:1.25rem}.news-header{background:linear-gradient(135deg,var(--primary-dark),#004080);color:#fff;padding:1.5rem 2rem;border-radius:12px}.news-header h2{display:flex;align-items:center;gap:.75rem;margin:0 0 .5rem;font-size:1.25rem}.news-header p{margin:0;opacity:.85;font-size:.9rem}.news-filters{display:flex;gap:1rem;align-items:center;flex-wrap:wrap}.search-input{flex:1;min-width:250px;position:relative}.search-input svg{position:absolute;left:1rem;top:50%;transform:translateY(-50%);color:var(--text-muted)}.search-input input{width:100%;padding:.75rem 1rem .75rem 2.75rem;border:1px solid var(--border-color);border-radius:8px;font-size:.9rem;background:#fff}.search-input input:focus{outline:none;border-color:var(--primary-dark)}.category-filters{display:flex;gap:.5rem}.filter-chip{padding:.5rem 1rem;border:1px solid var(--border-color);background:#fff;border-radius:20px;font-size:.8rem;font-weight:500;color:var(--text-muted);cursor:pointer}.filter-chip:hover{border-color:var(--primary-dark);color:var(--primary-dark)}.filter-chip.active{background:var(--primary-dark);border-color:var(--primary-dark);color:#fff}.news-list{display:grid;grid-template-columns:repeat(auto-fill,minmax(350px,1fr));gap:1rem}.news-card{background:#fff;border:1px solid var(--border-color);border-radius:12px;padding:1.5rem;cursor:pointer;transition:all .2s}.news-card:hover{border-color:var(--primary-dark);box-shadow:var(--shadow-md)}.news-card-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:.75rem}.category-badge{display:inline-flex;align-items:center;gap:.375rem;padding:.25rem .625rem;border-radius:4px;font-size:.7rem;font-weight:600;text-transform:uppercase}.category-badge.primary{background:#0033661a;color:var(--primary-dark)}.category-badge.warning{background:#f5a62326;color:#d68a00}.category-badge.success{background:#28a7451a;color:var(--success)}.news-date{display:flex;align-items:center;gap:.375rem;font-size:.75rem;color:var(--text-muted)}.news-title{font-size:1rem;font-weight:600;color:var(--text-dark);margin:0 0 .75rem;line-height:1.4}.news-excerpt{font-size:.875rem;color:var(--text-muted);margin:0 0 1rem;line-height:1.5}.read-more{display:inline-flex;align-items:center;gap:.25rem;font-size:.85rem;color:var(--primary-dark);font-weight:500}.news-card:hover .read-more svg{transform:translate(4px)}.news-modal{max-width:600px}.news-detail{padding:.5rem}.news-detail-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1rem}.news-detail h2{font-size:1.25rem;margin:0 0 1.25rem;color:var(--text-dark);line-height:1.4}.news-content{font-size:.9rem;line-height:1.7;color:var(--text-dark)}.news-content p{margin:0 0 1rem}.news-content p:last-child{margin-bottom:0}.news-actions{margin-top:1.5rem;padding-top:1rem;border-top:1px solid var(--border-color)}@media (max-width: 768px){.news-list{grid-template-columns:1fr}.category-filters{width:100%;overflow-x:auto}}.user-admin-page{display:flex;flex-direction:column;gap:1.25rem}.admin-header{display:flex;justify-content:space-between;align-items:flex-start;background:linear-gradient(135deg,var(--primary-dark),#004080);color:#fff;padding:1.5rem 2rem;border-radius:12px}.header-info h2{display:flex;align-items:center;gap:.75rem;margin:0 0 .5rem;font-size:1.25rem}.header-info p{margin:0;opacity:.85;font-size:.9rem}.admin-header .btn{background:#fff;color:var(--primary-dark)}.admin-header .btn:hover{background:var(--bg-light)}.admin-stats{display:flex;gap:1rem}.astat{background:#fff;border-radius:10px;padding:1rem 1.5rem;display:flex;flex-direction:column;box-shadow:var(--shadow-sm);min-width:140px}.astat-value{font-size:1.5rem;font-weight:700;color:var(--primary-dark)}.astat-label{font-size:.8rem;color:var(--text-muted)}.search-bar{position:relative;max-width:400px}.search-bar svg{position:absolute;left:1rem;top:50%;transform:translateY(-50%);color:var(--text-muted)}.search-bar input{width:100%;padding:.75rem 1rem .75rem 2.75rem;border:1px solid var(--border-color);border-radius:8px;font-size:.9rem;background:#fff}.search-bar input:focus{outline:none;border-color:var(--primary-dark)}.users-table-container{background:#fff;border-radius:12px;overflow:hidden;box-shadow:var(--shadow-sm)}.users-table{width:100%;border-collapse:collapse}.users-table th{background:var(--primary-dark);color:#fff;padding:.875rem 1rem;text-align:left;font-size:.75rem;font-weight:600;text-transform:uppercase;letter-spacing:.5px}.users-table td{padding:1rem;border-bottom:1px solid var(--border-color);vertical-align:middle}.users-table tr:hover{background:var(--bg-light)}.user-cell{display:flex;align-items:center;gap:.75rem}.user-avatar{width:40px;height:40px;border-radius:50%;background:var(--primary-dark);color:#fff;display:flex;align-items:center;justify-content:center;font-weight:600;font-size:.85rem}.user-info strong{display:block;color:var(--text-dark)}.contact-info{display:flex;flex-direction:column;gap:.25rem;font-size:.8rem}.contact-info span{display:flex;align-items:center;gap:.375rem;color:var(--text-muted)}.role-badge{display:inline-flex;padding:.375rem .75rem;border-radius:6px;font-size:.75rem;font-weight:600}.role-badge.primary{background:#0033661a;color:var(--primary-dark)}.role-badge.warning{background:#f5a62326;color:#d68a00}.role-badge.muted{background:var(--bg-light);color:var(--text-muted)}.status-toggle{display:inline-flex;align-items:center;gap:.375rem;padding:.375rem .75rem;border:1px solid;border-radius:20px;font-size:.8rem;font-weight:500;cursor:pointer;background:#fff}.status-toggle.actif{color:var(--success);border-color:var(--success)}.status-toggle.inactif{color:var(--text-muted);border-color:var(--border-color)}.status-toggle:hover{opacity:.8}.actions-cell{display:flex;gap:.5rem}.action-btn{background:none;border:1px solid var(--border-color);border-radius:6px;padding:.5rem;cursor:pointer;color:var(--text-muted);display:flex;align-items:center;justify-content:center}.action-btn:hover{border-color:var(--primary-dark);color:var(--primary-dark)}.action-btn.danger:hover{border-color:var(--danger);color:var(--danger)}.no-results{text-align:center;padding:4rem 2rem;color:var(--text-muted)}.no-results svg{margin-bottom:1rem;opacity:.4}.no-results h3{margin:0 0 .5rem;color:var(--text-dark)}.no-results p{margin:0}.user-modal{max-width:500px}.user-modal h3{margin:0 0 1.5rem;color:var(--text-dark)}.form-row{display:grid;grid-template-columns:1fr 1fr;gap:1rem}.form-actions{display:flex;justify-content:flex-end;gap:.75rem;margin-top:1.5rem;padding-top:1rem;border-top:1px solid var(--border-color)}@media (max-width: 768px){.admin-header{flex-direction:column;gap:1rem}.admin-stats{flex-wrap:wrap}.astat{flex:1;min-width:100px}.form-row{grid-template-columns:1fr}}.app-layout{min-height:100vh;display:flex;flex-direction:column}.alert-banner{background:var(--accent-orange);color:#fff;padding:.5rem 1rem;display:flex;justify-content:center;align-items:center;gap:1rem}.alert-banner-content{display:flex;align-items:center;gap:.5rem;font-size:.875rem}.alert-banner button{background:none;border:none;color:#fff;cursor:pointer;padding:.25rem}.main-header{background:#fff;border-bottom:1px solid var(--border-color);padding:.75rem 0}.header-container{max-width:1400px;margin:0 auto;padding:0 1.5rem;display:flex;align-items:center;justify-content:space-between;gap:2rem}.logo{display:flex;align-items:center;gap:.75rem;text-decoration:none}.logo-icon svg{width:44px;height:44px}.logo-text{display:flex;flex-direction:column}.logo-title{font-size:1.125rem;font-weight:700;color:var(--primary-dark);letter-spacing:.5px}.logo-subtitle{font-size:.7rem;color:var(--text-muted);text-transform:uppercase}.header-contacts{display:flex;gap:1.5rem}.contact-item{display:flex;align-items:center;gap:.375rem;font-size:.8rem;color:var(--text-muted);text-decoration:none}.contact-item:hover{color:var(--primary-dark)}.header-user{display:flex;align-items:center;gap:1rem}.user-info{text-align:right}.user-name{display:block;font-weight:600;font-size:.875rem;color:var(--text-dark)}.user-profile{font-size:.75rem;color:var(--text-muted)}.admin-btn{width:36px;height:36px;border-radius:8px;background:var(--bg-light);color:var(--primary-dark);display:flex;align-items:center;justify-content:center;text-decoration:none;transition:background .2s}.admin-btn:hover{background:var(--primary-dark);color:#fff}.logout-btn{display:flex;align-items:center;gap:.5rem;padding:.5rem 1rem;background:none;border:1px solid var(--border-color);border-radius:6px;font-size:.8rem;color:var(--text-muted);cursor:pointer;transition:all .2s}.logout-btn:hover{border-color:var(--danger);color:var(--danger)}.main-nav{background:var(--primary-dark)}.nav-container{max-width:1400px;margin:0 auto;padding:0 1.5rem;display:flex;gap:.25rem}.nav-link{display:flex;align-items:center;gap:.5rem;padding:1rem 1.25rem;color:#fffc;text-decoration:none;font-size:.875rem;font-weight:500;transition:all .2s;position:relative}.nav-link:hover{color:#fff;background:#ffffff1a}.nav-link.active{color:#fff;background:#ffffff26}.nav-link.active:after{content:"";position:absolute;bottom:0;left:0;right:0;height:3px;background:var(--accent-orange)}.breadcrumb-bar{background:#fff;border-bottom:1px solid var(--border-color);padding:.75rem 0}.breadcrumb-container{max-width:1400px;margin:0 auto;padding:0 1.5rem;display:flex;align-items:center;gap:.5rem;font-size:.8rem}.breadcrumb-item{color:var(--primary-dark);text-decoration:none}.breadcrumb-item:hover{text-decoration:underline}.breadcrumb-current{color:var(--text-muted)}.main-content{flex:1;padding:1.5rem 0}.content-container{max-width:1400px;margin:0 auto;padding:0 1.5rem}.main-footer{background:var(--primary-dark);color:#fff;padding:1.5rem 0;margin-top:auto}.footer-container{max-width:1400px;margin:0 auto;padding:0 1.5rem;display:flex;justify-content:space-between;align-items:center}.footer-links{display:flex;gap:2rem}.footer-links span{font-size:.8rem;opacity:.8;cursor:pointer}.footer-links span:hover{opacity:1}.footer-copyright{font-size:.75rem;opacity:.6}@media (max-width: 768px){.header-contacts{display:none}.nav-container{overflow-x:auto}.nav-link span{display:none}.nav-link{padding:1rem}.logout-btn span{display:none}.footer-container{flex-direction:column;gap:1rem;text-align:center}.footer-links{flex-wrap:wrap;justify-content:center;gap:1rem}}:root{--primary-dark: #003366;--primary-light: #004d99;--accent-orange: #f5a623;--success: #28a745;--danger: #dc3545;--warning: #ffc107;--info: #17a2b8;--text-dark: #1a1a2e;--text-muted: #6c757d;--bg-light: #f8f9fa;--bg-body: #eef1f5;--border-color: #dee2e6;--shadow: 0 2px 4px rgba(0,0,0,.08);--shadow-lg: 0 4px 12px rgba(0,0,0,.12)}*{margin:0;padding:0;box-sizing:border-box}body{font-family:Segoe UI,system-ui,-apple-system,sans-serif;background:var(--bg-body);color:var(--text-dark);line-height:1.5}.btn{display:inline-flex;align-items:center;gap:.5rem;padding:.625rem 1.25rem;border:none;border-radius:6px;font-size:.875rem;font-weight:500;cursor:pointer;transition:all .2s;text-decoration:none}.btn-primary{background:var(--primary-dark);color:#fff}.btn-primary:hover{background:var(--primary-light)}.btn-secondary{background:var(--bg-light);color:var(--text-dark);border:1px solid var(--border-color)}.btn-secondary:hover{background:var(--border-color)}.btn-outline{background:#fff;color:var(--primary-dark);border:1px solid var(--primary-dark)}.btn-outline:hover{background:var(--primary-dark);color:#fff}.btn-sm{padding:.375rem .75rem;font-size:.8rem}.form-control{width:100%;padding:.625rem .875rem;border:1px solid var(--border-color);border-radius:6px;font-size:.875rem;transition:border-color .2s,box-shadow .2s}.form-control:focus{outline:none;border-color:var(--primary-dark);box-shadow:0 0 0 3px #0033661a}.form-group{margin-bottom:1rem}.form-group label{display:block;margin-bottom:.375rem;font-size:.875rem;font-weight:500;color:var(--text-dark)}.card{background:#fff;border-radius:8px;border:1px solid var(--border-color);overflow:hidden}.card-header{padding:1rem 1.25rem;background:var(--bg-light);border-bottom:1px solid var(--border-color);display:flex;justify-content:space-between;align-items:center}.card-header h3{margin:0;font-size:1rem;color:var(--text-dark)}.card-body{padding:1.25rem}.stat-card{background:#fff;border-radius:8px;border:1px solid var(--border-color);border-left:4px solid var(--accent-orange);padding:1.25rem;display:flex;align-items:center;gap:1rem}.stat-card.danger{border-left-color:var(--danger)}.stat-card.success{border-left-color:var(--success)}.stat-card.primary{border-left-color:var(--primary-dark)}.stat-icon{width:48px;height:48px;border-radius:10px;display:flex;align-items:center;justify-content:center;background:#f5a62326;color:var(--accent-orange)}.stat-card.danger .stat-icon{background:#dc35451a;color:var(--danger)}.stat-card.success .stat-icon{background:#28a7451a;color:var(--success)}.stat-card.primary .stat-icon{background:#0033661a;color:var(--primary-dark)}.stat-info{flex:1}.stat-value{font-size:1.75rem;font-weight:700;color:var(--text-dark);line-height:1}.stat-label{font-size:.8rem;color:var(--text-muted);margin-top:.25rem}.data-table{width:100%;border-collapse:collapse}.data-table thead{background:var(--primary-dark);color:#fff}.data-table th{padding:.875rem 1rem;text-align:left;font-weight:600;font-size:.8rem;text-transform:uppercase}.data-table td{padding:.875rem 1rem;border-bottom:1px solid var(--border-color);font-size:.875rem}.data-table tbody tr:hover{background:var(--bg-light)}.badge{display:inline-flex;align-items:center;gap:.25rem;padding:.25rem .625rem;font-size:.75rem;font-weight:500;border-radius:4px}.badge-success{background:#28a7451a;color:var(--success)}.badge-danger{background:#dc35451a;color:var(--danger)}.badge-warning{background:#ffc10726;color:#d68a00}.badge-info{background:#0033661a;color:var(--primary-dark)}.filter-bar{background:#fff;padding:1rem 1.25rem;border-radius:8px;border:1px solid var(--border-color)}.filter-row{display:flex;gap:1rem;align-items:flex-end;flex-wrap:wrap}.filter-group{display:flex;flex-direction:column;gap:.375rem}.filter-group label{font-size:.75rem;font-weight:600;color:var(--text-muted);text-transform:uppercase}.search-group{flex:1;min-width:200px}.search-input{position:relative}.search-input svg{position:absolute;left:.75rem;top:50%;transform:translateY(-50%);color:var(--text-muted)}.search-input .form-control{padding-left:2.5rem}.pagination{display:flex;justify-content:center;gap:.5rem;padding:1rem}.pagination-btn{padding:.5rem 1rem;border:1px solid var(--border-color);background:#fff;border-radius:6px;font-size:.875rem;cursor:pointer;transition:all .2s}.pagination-btn:hover:not(:disabled){background:var(--bg-light)}.pagination-btn.active{background:var(--primary-dark);color:#fff;border-color:var(--primary-dark)}.pagination-btn:disabled{opacity:.5;cursor:not-allowed}.modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:#00000080;display:flex;align-items:center;justify-content:center;z-index:1000;padding:1rem}.modal-content{background:#fff;border-radius:12px;max-width:500px;width:100%;max-height:90vh;overflow-y:auto;padding:1.5rem;position:relative}.modal-close{position:absolute;top:1rem;right:1rem;background:none;border:none;cursor:pointer;color:var(--text-muted);padding:.25rem}.modal-close:hover{color:var(--text-dark)}.fade-in{animation:fadeIn .3s ease-out}@keyframes fadeIn{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}.text-muted{color:var(--text-muted)}.text-success{color:var(--success)}.text-danger{color:var(--danger)}
