@layer properties{@supports ((-webkit-hyphens:none) and (not (margin-trim:inline))) or ((-moz-orient:inline) and (not (color:rgb(from red r g b)))){*,:before,:after,::backdrop{--tw-scale-x:1;--tw-scale-y:1;--tw-scale-z:1;--tw-rotate-x:initial;--tw-rotate-y:initial;--tw-rotate-z:initial;--tw-skew-x:initial;--tw-skew-y:initial;--tw-border-style:solid;--tw-duration:initial;--tw-shadow:0 0 #0000;--tw-shadow-color:initial;--tw-shadow-alpha:100%;--tw-inset-shadow:0 0 #0000;--tw-inset-shadow-color:initial;--tw-inset-shadow-alpha:100%;--tw-ring-color:initial;--tw-ring-shadow:0 0 #0000;--tw-inset-ring-color:initial;--tw-inset-ring-shadow:0 0 #0000;--tw-ring-inset:initial;--tw-ring-offset-width:0px;--tw-ring-offset-color:#fff;--tw-ring-offset-shadow:0 0 #0000}}}/*! tailwindcss v4.1.14 | MIT License | https://tailwindcss.com */@layer properties{@supports ((-webkit-hyphens:none) and (not (margin-trim:inline))) or ((-moz-orient:inline) and (not (color:rgb(from red r g b)))){*,:before,:after,::backdrop{--tw-scale-x:1;--tw-scale-y:1;--tw-scale-z:1;--tw-rotate-x:initial;--tw-rotate-y:initial;--tw-rotate-z:initial;--tw-skew-x:initial;--tw-skew-y:initial;--tw-border-style:solid;--tw-duration:initial;--tw-shadow:0 0 #0000;--tw-shadow-color:initial;--tw-shadow-alpha:100%;--tw-inset-shadow:0 0 #0000;--tw-inset-shadow-color:initial;--tw-inset-shadow-alpha:100%;--tw-ring-color:initial;--tw-ring-shadow:0 0 #0000;--tw-inset-ring-color:initial;--tw-inset-ring-shadow:0 0 #0000;--tw-ring-inset:initial;--tw-ring-offset-width:0px;--tw-ring-offset-color:#fff;--tw-ring-offset-shadow:0 0 #0000}}}.pointer-events-none{pointer-events:none}.absolute{position:absolute}.fixed{position:fixed}.relative{position:relative}.sticky{position:sticky}.z-50{z-index:50}.mx-auto{margin-inline:auto}.block{display:block}.flex{display:flex}.grid{display:grid}.hidden{display:none}.inline{display:inline}.inline-block{display:inline-block}.inline-flex{display:inline-flex}.table{display:table}.min-h-\[100px\]{min-height:100px}.min-h-screen{min-height:100vh}.w-full{width:100%}.flex-1{flex:1}.flex-shrink-0{flex-shrink:0}.scale-95{--tw-scale-x:95%;--tw-scale-y:95%;--tw-scale-z:95%;scale:var(--tw-scale-x)var(--tw-scale-y)}.transform{transform:var(--tw-rotate-x,)var(--tw-rotate-y,)var(--tw-rotate-z,)var(--tw-skew-x,)var(--tw-skew-y,)}.cursor-move{cursor:move}.cursor-pointer{cursor:pointer}.resize{resize:both}.grid-cols-1{grid-template-columns:repeat(1,minmax(0,1fr))}.grid-cols-2{grid-template-columns:repeat(2,minmax(0,1fr))}.grid-cols-3{grid-template-columns:repeat(3,minmax(0,1fr))}.items-center{align-items:center}.items-start{align-items:flex-start}.justify-between{justify-content:space-between}.justify-center{justify-content:center}.justify-end{justify-content:flex-end}.overflow-y-auto{overflow-y:auto}.rounded-full{border-radius:3.40282e38px}.border{border-style:var(--tw-border-style);border-width:1px}.border-2{border-style:var(--tw-border-style);border-width:2px}.border-t{border-top-style:var(--tw-border-style);border-top-width:1px}.border-b{border-bottom-style:var(--tw-border-style);border-bottom-width:1px}.border-b-2{border-bottom-style:var(--tw-border-style);border-bottom-width:2px}.border-l-2{border-left-style:var(--tw-border-style);border-left-width:2px}.border-l-4{border-left-style:var(--tw-border-style);border-left-width:4px}.border-dashed{--tw-border-style:dashed;border-style:dashed}.text-center{text-align:center}.break-all{word-break:break-all}.uppercase{text-transform:uppercase}.italic{font-style:italic}.underline{text-decoration-line:underline}.opacity-50{opacity:.5}.transition{transition-property:color,background-color,border-color,outline-color,text-decoration-color,fill,stroke,--tw-gradient-from,--tw-gradient-via,--tw-gradient-to,opacity,box-shadow,transform,translate,scale,rotate,filter,backdrop-filter,display,content-visibility,overlay,pointer-events;transition-timing-function:var(--tw-ease,ease);transition-duration:var(--tw-duration,0s)}.transition-all{transition-property:all;transition-timing-function:var(--tw-ease,ease);transition-duration:var(--tw-duration,0s)}.transition-colors{transition-property:color,background-color,border-color,outline-color,text-decoration-color,fill,stroke,--tw-gradient-from,--tw-gradient-via,--tw-gradient-to;transition-timing-function:var(--tw-ease,ease);transition-duration:var(--tw-duration,0s)}.transition-opacity{transition-property:opacity;transition-timing-function:var(--tw-ease,ease);transition-duration:var(--tw-duration,0s)}.transition-shadow{transition-property:box-shadow;transition-timing-function:var(--tw-ease,ease);transition-duration:var(--tw-duration,0s)}.duration-200{--tw-duration:.2s;transition-duration:.2s}@media (hover:hover){.hover\:scale-105:hover{--tw-scale-x:105%;--tw-scale-y:105%;--tw-scale-z:105%;scale:var(--tw-scale-x)var(--tw-scale-y)}}.focus\:border-transparent:focus{border-color:#0000}.focus\:ring-2:focus{--tw-ring-shadow:var(--tw-ring-inset,)0 0 0 calc(2px + var(--tw-ring-offset-width))var(--tw-ring-color,currentcolor);box-shadow:var(--tw-inset-shadow),var(--tw-inset-ring-shadow),var(--tw-ring-offset-shadow),var(--tw-ring-shadow),var(--tw-shadow)}.disabled\:cursor-not-allowed:disabled{cursor:not-allowed}.disabled\:opacity-50:disabled{opacity:.5}*{box-sizing:border-box;margin:0;padding:0}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}@keyframes pulse{0%,to{opacity:1}50%{opacity:.5}}@keyframes shine{0%{left:-100%}to{left:200%}}body{color:#1e293b;background-color:#f8fafc;font-family:Inter,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;line-height:1.6}.container{max-width:1200px;margin:0 auto;padding:0 20px}.layout{min-height:100vh;display:flex}.sidebar{color:#fff;z-index:1000;background:linear-gradient(135deg,#1e40af 0%,#3b82f6 100%);width:250px;height:100vh;padding:20px 0;position:fixed;overflow-y:auto}.sidebar-header{border-bottom:1px solid #ffffff1a;margin-bottom:30px;padding:0 20px 30px}.sidebar-header h1{margin-bottom:5px;font-size:1.5rem;font-weight:700}.sidebar-header p{opacity:.8;font-size:.875rem}.nav-menu{list-style:none}.nav-item{margin-bottom:5px}.nav-link{color:#fffc;border-radius:0 25px 25px 0;align-items:center;margin-right:20px;padding:12px 20px;text-decoration:none;transition:all .3s;display:flex}.nav-link:hover{color:#fff;background:#ffffff1a;transform:translate(5px)}.nav-link.active{color:#fff;background:#fff3;font-weight:600}.nav-link svg{width:20px;height:20px;margin-right:12px}.main-content{flex:1;margin-left:250px;padding:30px}.header{background:#fff;border-radius:12px;justify-content:space-between;align-items:center;margin-bottom:30px;padding:20px 30px;display:flex;box-shadow:0 1px 3px #0000001a}.header h2{color:#1e293b;font-size:1.875rem;font-weight:700}.card{background:#fff;border:1px solid #e2e8f0;border-radius:12px;padding:24px;transition:all .3s;box-shadow:0 1px 3px #0000001a}.card:hover{transform:translateY(-2px);box-shadow:0 4px 12px #00000026}.card-header{border-bottom:1px solid #e2e8f0;justify-content:space-between;align-items:center;margin-bottom:20px;padding-bottom:15px;display:flex}.card-title{color:#1e293b;font-size:1.25rem;font-weight:600}.btn{cursor:pointer;border:none;border-radius:8px;align-items:center;gap:8px;padding:10px 20px;font-size:.875rem;font-weight:500;text-decoration:none;transition:all .3s;display:inline-flex}.btn-primary{color:#fff;background:linear-gradient(135deg,#3b82f6,#1e40af)}.btn-primary:hover{background:linear-gradient(135deg,#1e40af,#1e3a8a);transform:translateY(-1px)}.btn-secondary{color:#475569;background:#f1f5f9;border:1px solid #e2e8f0}.btn-secondary:hover{background:#e2e8f0}.btn-success{color:#fff;background:linear-gradient(135deg,#10b981,#059669)}.btn-warning{color:#fff;background:linear-gradient(135deg,#f59e0b,#d97706)}.btn-danger{color:#fff;background:linear-gradient(135deg,#ef4444,#dc2626)}.table{border-collapse:collapse;width:100%;margin-top:20px}.table th,.table td{text-align:left;border-bottom:1px solid #e2e8f0;padding:12px 15px}.table th{color:#475569;text-transform:uppercase;letter-spacing:.05em;background:#f8fafc;font-size:.875rem;font-weight:600}.table tbody tr:hover{background:#f8fafc}.status-badge{text-transform:uppercase;letter-spacing:.05em;border-radius:20px;padding:4px 12px;font-size:.75rem;font-weight:500}.status-nouveau{color:#1e40af;background:#dbeafe}.status-contract{color:#166534;background:#dcfce7}.status-garantie{color:#92400e;background:#fef3c7}.status-sans-garantie{color:#991b1b;background:#fee2e2}.form-label{color:#374151;margin-bottom:8px;font-weight:500;display:block}.form-input{border:1px solid #d1d5db;border-radius:8px;width:100%;padding:12px 16px;font-size:.875rem;transition:all .3s}.form-select{background:#fff;border:1px solid #d1d5db;border-radius:8px;width:100%;padding:12px 16px;font-size:.875rem}.grid{gap:24px;display:grid}.grid-3{grid-template-columns:repeat(3,1fr)}.grid-4{grid-template-columns:repeat(4,1fr)}.stats-grid{grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:24px;margin-bottom:30px;display:grid}.stat-card{background:#fff;border-left:4px solid;border-radius:12px;padding:24px;box-shadow:0 1px 3px #0000001a}.stat-card.blue{border-left-color:#3b82f6}.stat-card.green{border-left-color:#10b981}.stat-card.yellow{border-left-color:#f59e0b}.stat-card.red{border-left-color:#ef4444}.stat-value{margin-bottom:8px;font-size:2rem;font-weight:700}.stat-label{color:#64748b;font-size:.875rem;font-weight:500}.form-section{margin-bottom:24px}.form-group{margin-bottom:16px}.form-label{color:#374151;margin-bottom:6px;font-size:.875rem;font-weight:500;display:block}.form-input{background-color:#fff;border:1px solid #d1d5db;border-radius:6px;width:100%;padding:10px 12px;font-size:.875rem;transition:all .2s}.form-input:focus{border-color:#3b82f6;outline:none;box-shadow:0 0 0 3px #3b82f61a}.form-input-error{border-color:#ef4444}.form-input-error:focus{border-color:#ef4444;box-shadow:0 0 0 3px #ef44441a}.form-input-success{border-color:#10b981}.form-input-success:focus{border-color:#10b981;box-shadow:0 0 0 3px #10b9811a}.form-input-with-icon{padding-left:40px}.form-select{cursor:pointer;background-color:#fff;border:1px solid #d1d5db;border-radius:6px;width:100%;padding:10px 12px;font-size:.875rem;transition:all .2s}.form-select:focus{border-color:#3b82f6;outline:none;box-shadow:0 0 0 3px #3b82f61a}.form-select option{padding:8px}textarea.form-input{resize:vertical;min-height:80px}.form-field-error{color:#ef4444;align-items:center;gap:4px;margin-top:4px;font-size:.875rem;display:flex}.form-field-success{color:#10b981;align-items:center;gap:4px;margin-top:4px;font-size:.875rem;display:flex}.form-field-help{color:#6b7280;margin-top:4px;font-size:.875rem}.btn-loading{opacity:.6;cursor:not-allowed}.btn-loading .btn-content{align-items:center;gap:8px;display:flex}.spinner{border:2px solid #fff;border-top-color:#0000;border-radius:50%;width:16px;height:16px;animation:1s linear infinite spin}.profile-grid{grid-template-columns:1fr;gap:.75rem;display:grid}.profile-card{text-align:left;cursor:pointer;background:#fff;border:2px solid #e5e7eb;border-radius:.5rem;padding:1rem;transition:all .2s}.profile-card:hover{background:#f9fafb;border-color:#d1d5db}.profile-card-selected{background:#eff6ff;border-color:#3b82f6}.profile-content{align-items:center;gap:.75rem;display:flex}.profile-icon{border-radius:.5rem;justify-content:center;align-items:center;padding:.5rem;display:flex}.profile-info{flex:1}.profile-name{color:#111827;margin:0 0 .25rem;font-weight:500}.profile-description{color:#6b7280;margin:0;font-size:.875rem}.profile-check{background:#3b82f6;border-radius:50%;justify-content:center;align-items:center;width:1.25rem;height:1.25rem;display:flex}.profile-check-dot{background:#fff;border-radius:50%;width:.5rem;height:.5rem}.profile-icon-red{color:#dc2626;background:#fef2f2;border:1px solid #fecaca}.profile-icon-blue{color:#2563eb;background:#eff6ff;border:1px solid #bfdbfe}.profile-icon-green{color:#16a34a;background:#f0fdf4;border:1px solid #bbf7d0}.profile-icon-purple{color:#9333ea;background:#faf5ff;border:1px solid #d8b4fe}.profile-icon-orange{color:#ea580c;background:#fff7ed;border:1px solid #fed7aa}.profile-icon-gray{color:#6b7280;background:#f9fafb;border:1px solid #d1d5db}.demo-credentials{background:#f9fafb;border-radius:.5rem;margin-top:1.5rem;padding:1rem}.demo-title{color:#374151;margin:0 0 .5rem;font-size:.875rem;font-weight:500}.demo-list{flex-direction:column;gap:.25rem;display:flex}.demo-list p{color:#6b7280;margin:0;font-size:.75rem}.profile-detection{margin-top:1rem}.profile-detection-label{color:#374151;margin-bottom:.5rem;font-size:.875rem;font-weight:500}.profile-detection-card{background:#f0f9ff;border:1px solid #bae6fd;border-radius:.5rem;padding:1rem;transition:all .2s}.profile-detection-card:hover{background:#e0f2fe;border-color:#7dd3fc}.access-denied-container{justify-content:center;align-items:center;min-height:400px;padding:2rem;display:flex}.access-denied-card{text-align:center;background:#fff;border:1px solid #e5e7eb;border-radius:.75rem;width:100%;max-width:500px;padding:3rem 2rem;box-shadow:0 10px 25px -3px #0000001a}.access-denied-icon{color:#dc2626;margin:0 auto 1.5rem;display:block}.access-denied-title{color:#111827;margin:0 0 1rem;font-size:1.5rem;font-weight:700}.access-denied-message{color:#6b7280;margin:0 0 1.5rem;font-size:1rem;line-height:1.5}.access-denied-details{color:#9ca3af;background:#f9fafb;border-left:4px solid #e5e7eb;border-radius:.5rem;margin:.5rem 0;padding:.75rem;font-size:.875rem}.navigation{z-index:1000;background:#fff;border-right:1px solid #e5e7eb;width:16rem;min-height:100vh;position:fixed;top:0;left:0;box-shadow:0 4px 6px -1px #0000001a}.navigation-header{border-bottom:1px solid #e5e7eb;padding:1.5rem}.navigation-logo{align-items:center;gap:.75rem;display:flex}.navigation-icon{background:#2563eb;border-radius:.5rem;justify-content:center;align-items:center;width:2.5rem;height:2.5rem;display:flex}.navigation-icon-svg{color:#fff;width:1.5rem;height:1.5rem}.navigation-title{color:#111827;margin:0;font-size:1.125rem;font-weight:700}.navigation-subtitle{color:#6b7280;margin:0;font-size:.875rem}.navigation-user{border-bottom:1px solid #e5e7eb;padding:1rem}.navigation-user-content{align-items:center;gap:.75rem;display:flex}.navigation-user-avatar{background:#f3f4f6;border-radius:50%;justify-content:center;align-items:center;width:2.5rem;height:2.5rem;display:flex}.navigation-user-icon{color:#6b7280;width:1.25rem;height:1.25rem}.navigation-user-info{flex:1;min-width:0}.navigation-user-email{color:#111827;text-overflow:ellipsis;white-space:nowrap;margin:0 0 .25rem;font-size:.875rem;font-weight:500;overflow:hidden}.navigation-user-profile{align-items:center;gap:.5rem;display:flex}.profile-badge{border-radius:9999px;align-items:center;padding:.25rem .5rem;font-size:.75rem;font-weight:500;display:inline-flex}.profile-badge-text{margin-left:.25rem}.navigation-items{flex-direction:column;gap:.5rem;padding:1rem;display:flex}.navigation-item{text-align:left;cursor:pointer;color:#374151;background:0 0;border:none;border-radius:.5rem;align-items:center;gap:.75rem;width:100%;padding:.75rem;transition:all .2s;display:flex}.navigation-item:hover{background:#f3f4f6}.navigation-item-active{color:#1e40af;background:linear-gradient(135deg,#dbeafe,#bfdbfe);border:1px solid #93c5fd;position:relative;transform:translate(4px);box-shadow:0 2px 4px #3b82f633}.navigation-item-active:before{content:"";background:linear-gradient(135deg,#3b82f6,#1e40af);border-radius:0 2px 2px 0;width:4px;position:absolute;top:0;bottom:0;left:-20px}.navigation-item-active .navigation-item-text{color:#1e40af;font-weight:600}.navigation-item-active:hover{color:#1e3a8a;background:linear-gradient(135deg,#bfdbfe,#93c5fd)}.navigation-item-text{font-weight:500}.navigation-logout{border-top:1px solid #e5e7eb;padding:1rem;position:absolute;bottom:0;left:0;right:0}.navigation-logout-btn{text-align:left;color:#374151;cursor:pointer;background:0 0;border:none;border-radius:.5rem;align-items:center;gap:.75rem;width:100%;padding:.75rem;transition:all .2s;display:flex}.navigation-logout-btn:hover{color:#dc2626;background:#fef2f2}.navigation-logout-text{font-weight:500}.dashboard{flex-direction:column;gap:1.5rem;display:flex}.dashboard-header{background:#fff;border-radius:.5rem;padding:1.5rem;box-shadow:0 1px 3px #0000001a}.dashboard-title{color:#111827;margin:0 0 .5rem;font-size:1.5rem;font-weight:700}.dashboard-subtitle{color:#6b7280;margin:0}.dashboard-stats{grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:1.5rem;display:grid}.dashboard-stat-card{background:#fff;border-radius:.5rem;padding:1.5rem;box-shadow:0 1px 3px #0000001a}.dashboard-stat-header{justify-content:space-between;align-items:center;margin-bottom:1rem;display:flex}.dashboard-stat-label{color:#6b7280;margin:0;font-size:.875rem;font-weight:500}.dashboard-stat-value{color:#111827;margin:0;font-size:1.5rem;font-weight:700}.dashboard-stat-icon{border-radius:50%;justify-content:center;align-items:center;padding:.75rem;display:flex}.dashboard-stat-icon-svg{width:1.5rem;height:1.5rem}.dashboard-stat-icon-blue{color:#1d4ed8;background:#dbeafe}.dashboard-stat-icon-green{color:#16a34a;background:#dcfce7}.dashboard-stat-icon-purple{color:#9333ea;background:#e9d5ff}.dashboard-stat-icon-orange{color:#ea580c;background:#fed7aa}.dashboard-stat-icon-indigo{color:#4f46e5;background:#e0e7ff}.dashboard-stat-icon-emerald{color:#059669;background:#d1fae5}.dashboard-stat-trend{align-items:center;gap:.25rem;display:flex}.dashboard-trend-icon{color:#10b981;width:1rem;height:1rem}.dashboard-trend-text{color:#10b981;font-size:.875rem;font-weight:500}.dashboard-trend-label{color:#6b7280;margin-left:.5rem;font-size:.875rem}.dashboard-activities{background:#fff;border-radius:.5rem;box-shadow:0 1px 3px #0000001a}.dashboard-activities-header{border-bottom:1px solid #e5e7eb;padding:1.5rem}.dashboard-activities-title{color:#111827;margin:0;font-size:1.125rem;font-weight:600}.dashboard-activities-content{padding:1.5rem}.dashboard-activities-list{flex-direction:column;gap:1rem;display:flex}.dashboard-activity{align-items:center;gap:1rem;display:flex}.dashboard-activity-icon{flex-shrink:0}.dashboard-activity-info{flex:1;min-width:0}.dashboard-activity-title{color:#111827;margin:0 0 .25rem;font-size:.875rem;font-weight:500}.dashboard-activity-time{color:#6b7280;margin:0;font-size:.875rem}.dashboard-activity-status{flex-shrink:0}.activity-status-badge{border-radius:9999px;align-items:center;padding:.25rem .5rem;font-size:.75rem;font-weight:500;display:inline-flex}.activity-status-text{text-transform:capitalize;margin-left:.25rem}.dashboard-activities-empty{text-align:center;padding:2rem}.dashboard-empty-icon{color:#9ca3af;width:3rem;height:3rem;margin:0 auto 1rem}.dashboard-empty-text{color:#6b7280;margin:0}.dashboard-actions{background:#fff;border-radius:.5rem;padding:1.5rem;box-shadow:0 1px 3px #0000001a}.dashboard-actions-title{color:#111827;margin:0 0 1rem;font-size:1.125rem;font-weight:600}.dashboard-actions-grid{grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:1rem;display:grid}.dashboard-action-btn{cursor:pointer;text-align:left;background:#fff;border:1px solid #e5e7eb;border-radius:.5rem;padding:1rem;transition:all .2s}.dashboard-action-btn:hover{background:#f9fafb}.dashboard-action-icon{width:1.5rem;height:1.5rem;margin-bottom:.5rem}.dashboard-action-icon-blue{color:#2563eb}.dashboard-action-icon-orange{color:#ea580c}.dashboard-action-icon-purple{color:#9333ea}.dashboard-action-icon-indigo{color:#4f46e5}.dashboard-action-text{color:#111827;margin:0;font-size:.875rem;font-weight:500}.layout{background:#f8fafc;min-height:100vh;display:flex}.main-content{flex-direction:column;flex:1;margin-left:16rem;display:flex}.main-content-inner{flex:1;padding:1.5rem}@media (max-width:768px){.sidebar{transition:transform .3s;transform:translate(-100%)}.sidebar.open{transform:translate(0)}.main-content{margin-left:0;padding:20px}.grid-2,.grid-3,.grid-4{grid-template-columns:1fr}.header{flex-direction:column;align-items:flex-start;gap:15px}.form-modal-content{max-height:calc(100vh - 20px);margin:10px}.form-modal-header,.form-modal-body,.form-modal-footer{padding:16px}}.form-tabs{background:#f8fafc;border-bottom:1px solid #e2e8f0;border-radius:8px 8px 0 0;margin-bottom:24px;padding:4px;display:flex}.form-tab{color:#6b7280;cursor:pointer;background:0 0;border:none;border-radius:6px;flex:1;justify-content:center;align-items:center;gap:8px;padding:12px 16px;font-weight:500;transition:all .2s;display:flex}.form-tab:hover{color:#374151;background:#e2e8f0}.form-tab.active{color:#1f2937;background:#fff;box-shadow:0 1px 3px #0000001a}.form-tab.has-error{position:relative}.form-tab.has-error:after{content:"";background:#ef4444;border-radius:3px 3px 0 0;height:3px;position:absolute;bottom:0;left:0;right:0}.form-tab.has-error:not(.active){background:#fef2f2;border:1px solid #fecaca}.form-tab-content{min-height:400px}.sites-header{border-bottom:1px solid #e2e8f0;justify-content:space-between;align-items:center;margin-bottom:24px;padding-bottom:16px;display:flex}.sites-title{align-items:center;gap:12px;display:flex}.sites-title h3{color:#1f2937;margin:0}.sites-count{color:#fff;background:#3b82f6;border-radius:12px;padding:4px 8px;font-size:.75rem;font-weight:500}.sites-grid{grid-template-columns:repeat(auto-fill,minmax(350px,1fr));gap:20px;display:grid}.site-card{background:#fff;border:1px solid #e2e8f0;border-radius:12px;padding:20px;transition:all .2s}.site-card:hover{border-color:#3b82f6;box-shadow:0 4px 12px #3b82f61a}.site-header{justify-content:space-between;align-items:flex-start;margin-bottom:16px;display:flex}.site-info h4{color:#1f2937;margin:0 0 8px;font-size:1.125rem}.site-actions{gap:8px;display:flex}.site-details{margin-bottom:16px}.site-address,.site-contact{color:#6b7280;align-items:center;gap:8px;margin-bottom:8px;font-size:.875rem;display:flex}.site-stats{border-top:1px solid #f3f4f6;gap:16px;padding-top:16px;display:flex}.stat{text-align:center}.stat-value{color:#1f2937;font-size:1.25rem;font-weight:600;display:block}.stat-label{color:#6b7280;text-transform:uppercase;letter-spacing:.05em;font-size:.75rem}.endroits-details{border-top:1px solid #f3f4f6;margin-top:16px;padding-top:16px}.endroits-details h5{color:#374151;margin:0 0 12px;font-size:1rem}.endroits-list{flex-direction:column;gap:12px;display:flex}.endroit-item{background:#f8fafc;border:1px solid #e2e8f0;border-radius:8px;padding:12px}.endroit-header{align-items:center;gap:12px;margin-bottom:8px;display:flex}.endroit-icon{background:#fff;border:1px solid #e2e8f0;border-radius:6px;justify-content:center;align-items:center;width:32px;height:32px;display:flex}.endroit-info h6{color:#1f2937;margin:0 0 4px;font-size:.875rem}.endroit-type{color:#6b7280;background:#f3f4f6;border-radius:4px;padding:2px 6px;font-size:.75rem}.endroit-description{color:#6b7280;margin:8px 0;font-size:.875rem;line-height:1.4}.endroit-specs{gap:12px;margin-bottom:8px;display:flex}.endroit-specs span{color:#6b7280;background:#f3f4f6;border-radius:4px;padding:2px 6px;font-size:.75rem}.endroit-equipements{margin-top:8px}.endroit-equipements strong{color:#374151;margin-bottom:4px;font-size:.75rem;display:block}.equipements-tags{flex-wrap:wrap;gap:4px;display:flex}.equipement-tag{color:#3b82f6;background:#eff6ff;border:1px solid #dbeafe;border-radius:4px;padding:2px 6px;font-size:.75rem}.site-endroit-selector{margin-bottom:16px}.selector-container{position:relative}.selector-button{cursor:pointer;background:#fff;border:1px solid #d1d5db;border-radius:8px;justify-content:space-between;align-items:center;width:100%;padding:12px 16px;transition:all .2s;display:flex}.selector-button:hover{border-color:#3b82f6}.selector-button.error{border-color:#ef4444}.selector-button.open{border-color:#3b82f6;box-shadow:0 0 0 3px #3b82f61a}.selector-content{flex:1;align-items:center;gap:8px;display:flex}.selector-text{color:#374151;font-size:.875rem}.chevron{transition:transform .2s}.chevron.open{transform:rotate(180deg)}.selector-dropdown{z-index:1000;background:#fff;border:1px solid #d1d5db;border-radius:8px;max-height:400px;position:absolute;top:100%;left:0;right:0;overflow:hidden;box-shadow:0 10px 25px #0000001a}.selector-search{background:#f8fafc;border-bottom:1px solid #e2e8f0;align-items:center;gap:8px;padding:12px 16px;display:flex}.search-input{background:0 0;border:none;outline:none;flex:1;font-size:.875rem}.selector-options{max-height:300px;overflow-y:auto}.no-results{color:#6b7280;flex-direction:column;justify-content:center;align-items:center;padding:32px;display:flex}.no-results p{margin:8px 0 0;font-size:.875rem}.site-option{border-bottom:1px solid #f3f4f6}.site-option:last-child{border-bottom:none}.site-header{cursor:pointer;justify-content:space-between;align-items:center;padding:12px 16px;transition:background .2s;display:flex}.site-header:hover{background:#f8fafc}.site-info{flex:1;align-items:center;gap:12px;display:flex}.site-name{color:#1f2937;margin-bottom:4px;font-weight:500}.site-location{color:#6b7280;align-items:center;gap:4px;font-size:.75rem;display:flex}.site-stats{color:#6b7280;background:#f3f4f6;border-radius:4px;padding:4px 8px;font-size:.75rem}.endroits-list{background:#f8fafc;border-top:1px solid #e2e8f0}.endroit-option{cursor:pointer;border-bottom:1px solid #e2e8f0;justify-content:space-between;align-items:center;padding:12px 16px 12px 32px;transition:background .2s;display:flex}.endroit-option:last-child{border-bottom:none}.endroit-option:hover{background:#eff6ff}.endroit-option.selected{color:#1e40af;background:#dbeafe}.endroit-info{flex:1;align-items:center;gap:12px;display:flex}.endroit-type-icon{background:#fff;border:1px solid #e2e8f0;border-radius:4px;justify-content:center;align-items:center;width:24px;height:24px;display:flex}.endroit-name{color:#1f2937;margin-bottom:2px;font-weight:500}.endroit-type{color:#6b7280;font-size:.75rem}.endroit-description{color:#6b7280;margin-top:2px;font-size:.75rem;line-height:1.3}.endroit-specs{color:#6b7280;gap:8px;font-size:.75rem;display:flex}.endroit-specs span{background:#f3f4f6;border-radius:4px;padding:2px 6px}.selection-summary{background:#f0f9ff;border:1px solid #bae6fd;border-radius:6px;margin-top:12px;padding:12px}.summary-item{color:#0c4a6e;margin-bottom:4px;font-size:.875rem}.summary-item:last-child{margin-bottom:0}.ligne-facture{background:#f9fafb;border:1px solid #e5e7eb;border-radius:8px;margin-bottom:16px;padding:16px}.period-selector{align-items:center;gap:12px;display:flex}.stat-card-large{background:#fff;border:1px solid #e5e7eb;border-radius:12px;align-items:center;gap:16px;padding:24px;display:flex;box-shadow:0 1px 3px #0000001a}.stat-evolution{margin-top:4px;font-size:.875rem;font-weight:500}.dashboard-grid{grid-template-columns:repeat(auto-fit,minmax(400px,1fr));gap:24px;margin-bottom:32px;display:grid}.dashboard-card{background:#fff;border:1px solid #e5e7eb;border-radius:12px;overflow:hidden;box-shadow:0 1px 3px #0000001a}.card-header{background:#f8fafc;border-bottom:1px solid #e5e7eb;padding:20px 24px}.card-body{padding:24px}.statut-distribution{flex-direction:column;gap:16px;display:flex}.statut-item{justify-content:space-between;align-items:center;gap:16px;display:flex}.progress-bar{background:#f3f4f6;border-radius:4px;flex:1;height:8px;overflow:hidden}.progress-fill{height:100%;transition:width .3s}.top-clients{flex-direction:column;gap:16px;display:flex}.client-item{border-bottom:1px solid #f3f4f6;justify-content:space-between;align-items:center;padding:12px 0;display:flex}.client-item:last-child{border-bottom:none}.client-rank{color:#fff;background:#3b82f6;border-radius:50%;justify-content:center;align-items:center;width:24px;height:24px;font-size:.75rem;font-weight:600;display:flex}.recent-factures{flex-direction:column;gap:12px;display:flex}.facture-item{border-bottom:1px solid #f3f4f6;justify-content:space-between;align-items:center;padding:12px 0;display:flex}.facture-item:last-child{border-bottom:none}.alerts{flex-direction:column;gap:12px;display:flex}.alert{border-radius:8px;align-items:center;gap:12px;padding:12px 16px;font-size:.875rem;display:flex}.alert-danger{color:#dc2626;background:#fef2f2;border:1px solid #fecaca}.alert-warning{color:#d97706;background:#fffbeb;border:1px solid #fed7aa}.alert-success{color:#16a34a;background:#f0fdf4;border:1px solid #bbf7d0}.badge{text-transform:uppercase;letter-spacing:.025em;border-radius:6px;align-items:center;padding:4px 8px;font-size:.75rem;font-weight:500;display:inline-flex}.action-buttons{align-items:center;gap:8px;display:flex}.btn-sm{min-width:auto;padding:6px 12px;font-size:.875rem}.empty-state{text-align:center;color:#6b7280;padding:48px 24px}.empty-state h3{color:#374151;margin:16px 0 8px}.empty-state p{margin:0 0 24px}.page{max-width:1400px;margin:0 auto;padding:24px}.page-header{border-bottom:1px solid #e5e7eb;justify-content:space-between;align-items:center;margin-bottom:32px;padding-bottom:24px;display:flex}.filters{background:#fff;border:1px solid #e5e7eb;border-radius:8px;margin-bottom:24px;padding:16px}.filter-group{flex-wrap:wrap;align-items:center;gap:16px;display:flex}.search-box{flex:1;min-width:300px;position:relative}.search-box input{border:1px solid #d1d5db;border-radius:8px;width:100%;padding:10px 16px 10px 40px;font-size:.875rem}.search-box svg{color:#6b7280;position:absolute;top:50%;left:12px;transform:translateY(-50%)}.filter-select{background:#fff;border:1px solid #d1d5db;border-radius:8px;min-width:150px;padding:10px 16px;font-size:.875rem}.table-container{background:#fff;border:1px solid #e5e7eb;border-radius:8px;overflow:hidden;box-shadow:0 1px 3px #0000001a}.modal{z-index:9999;opacity:0;visibility:hidden;background:#00000080;justify-content:center;align-items:center;transition:all .3s;display:flex;position:fixed;top:0;right:0;bottom:0;left:0}.modal-open{opacity:1;visibility:visible}.modal-content{background:#fff;border-radius:12px;max-width:90vw;max-height:90vh;transition:transform .3s;overflow:hidden;transform:scale(.9);box-shadow:0 25px 50px -12px #00000040}.modal-open .modal-content{transform:scale(1)}.modal-header{background:#f8fafc;border-bottom:1px solid #e5e7eb;justify-content:space-between;align-items:center;padding:24px;display:flex}.modal-header h2{color:#1f2937;margin:0}.btn-close{color:#6b7280;cursor:pointer;background:0 0;border:none;border-radius:4px;padding:4px;font-size:24px;transition:all .2s}.btn-close:hover{color:#374151;background:#f3f4f6}.modal-body{max-height:60vh;padding:24px;overflow-y:auto}.modal-footer{background:#f8fafc;border-top:1px solid #e5e7eb;justify-content:flex-end;gap:12px;padding:24px;display:flex}.modal-content.large{width:90vw;max-width:1000px}.modal-form{max-height:70vh;padding:24px;overflow-y:auto}.modal-form-compact{max-height:60vh;padding:20px;overflow-y:auto}.grid{gap:20px;margin-bottom:20px;display:grid}.modal-form-compact .grid{gap:16px;margin-bottom:16px}.modal-form-compact .form-group{margin-bottom:16px}.grid-2{grid-template-columns:1fr 1fr}@media (max-width:768px){.grid-2{grid-template-columns:1fr}.modal-content.large{width:95vw;max-width:95vw}}.form-optional{color:#6b7280;margin-left:4px;font-size:.875rem;font-weight:400}.form-checkbox-label{cursor:pointer;align-items:center;gap:8px;padding:8px 0;display:flex}.form-checkbox{accent-color:#3b82f6;width:16px;height:16px}.form-checkbox-text{color:#374151;font-size:.875rem;font-weight:500}.modal-actions{background:#f8fafc;border-top:1px solid #e5e7eb;justify-content:flex-end;gap:12px;margin:0 -24px -24px;padding:24px;display:flex}.form-help-text{color:#6b7280;margin-top:4px;font-size:.875rem}.form-error-general{color:#dc2626;background:#fef2f2;border:1px solid #fecaca;border-radius:6px;align-items:center;gap:8px;margin-bottom:16px;padding:12px 16px;font-size:.875rem;display:flex}.form-error-general:before{content:"⚠️";font-size:16px}.modal-content.medium{width:90vw;max-width:600px}.modal-content.xlarge{width:95vw;max-width:1200px}.modal-overlay{z-index:9998;background:#00000080;justify-content:center;align-items:center;display:flex;position:fixed;top:0;right:0;bottom:0;left:0}.btn-outline{color:#374151;background:#fff;border:1px solid #d1d5db}.btn-outline:hover{background:#f9fafb;border-color:#9ca3af}.btn-danger{color:#fff;background:#ef4444;border:1px solid #ef4444}.btn-danger:hover{background:#dc2626;border-color:#dc2626}.btn-warning{color:#fff;background:#f59e0b;border:1px solid #f59e0b}.btn-warning:hover{background:#d97706;border-color:#d97706}.btn-success{color:#fff;background:#10b981;border:1px solid #10b981}.btn-success:hover{background:#059669;border-color:#059669}.user-info{align-items:center;gap:12px;display:flex}.user-avatar{color:#fff;background:linear-gradient(135deg,#3b82f6,#1e40af);border-radius:50%;justify-content:center;align-items:center;width:40px;height:40px;font-weight:600;display:flex}.user-name{color:#1e293b;font-weight:600}.email-cell{color:#64748b;align-items:center;gap:8px;display:flex}.role-badge,.status-badge{border-radius:20px;align-items:center;gap:6px;padding:4px 12px;font-size:12px;font-weight:500;display:inline-flex}.status-active{color:#166534;background-color:#dcfce7}.status-inactive{color:#dc2626;background-color:#fef2f2}.date-cell{color:#64748b;align-items:center;gap:8px;font-size:14px;display:flex}.actions-cell{align-items:center;gap:8px;display:flex}.action-btn{cursor:pointer;border:none;border-radius:6px;justify-content:center;align-items:center;width:32px;height:32px;transition:all .2s;display:flex}.action-edit{color:#d97706;background-color:#fef3c7}.action-edit:hover{background-color:#fde68a}.action-delete{color:#dc2626;background-color:#fef2f2}.action-delete:hover{background-color:#fecaca}.action-activate{color:#166534;background-color:#dcfce7}.action-activate:hover{background-color:#bbf7d0}.action-deactivate{color:#dc2626;background-color:#fef2f2}.action-deactivate:hover{background-color:#fecaca}.form-optional{color:#64748b;font-size:12px;font-weight:400}.form-input-toggle{color:#64748b;cursor:pointer;background:0 0;border:none;border-radius:4px;padding:4px;transition:color .2s;position:absolute;top:50%;right:12px;transform:translateY(-50%)}.form-input-toggle:hover{color:#1e293b}.filters-panel{background:#fff;border:1px solid #e2e8f0;border-radius:8px;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:20px;margin-bottom:20px;padding:20px;display:grid}.filter-group{flex-direction:column;gap:8px;display:flex}.filter-label{color:#374151;font-size:14px;font-weight:500}.filter-select{background:#fff;border:1px solid #d1d5db;border-radius:6px;padding:8px 12px;font-size:14px;transition:border-color .2s}.filter-select:focus{border-color:#3b82f6;outline:none;box-shadow:0 0 0 3px #3b82f61a}@media (max-width:768px){.filters-panel{grid-template-columns:1fr}.actions-cell{flex-wrap:wrap}}@media (max-width:1200px){.contract-main-fields{grid-template-columns:1fr 1fr!important;gap:12px!important}}@media (max-width:768px){.contract-main-fields{grid-template-columns:1fr!important;gap:12px!important}}.modern-login-container{background:linear-gradient(135deg,#1e293b 0%,#7c3aed 50%,#1e293b 100%);justify-content:center;align-items:center;min-height:100vh;padding:1rem;display:flex;position:relative;overflow:hidden}.modern-login-container:before{content:"";opacity:.3;background:url('data:image/svg+xml,<svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 100 100"><defs><pattern id="grain" width="100" height="100" patternUnits="userSpaceOnUse"><circle cx="50" cy="50" r="1" fill="rgba(255,255,255,0.1)"/></pattern></defs><rect width="100" height="100" fill="url(\'%23grain\')"/></svg>');position:absolute;top:0;right:0;bottom:0;left:0}.modern-login-card{-webkit-backdrop-filter:blur(20px);z-index:10;background:#ffffff1a;border:1px solid #fff3;border-radius:24px;width:100%;max-width:800px;padding:3rem 2.5rem;position:relative;box-shadow:0 25px 50px -12px #00000040,0 0 0 1px #ffffff0d,inset 0 1px #ffffff1a}.modern-login-header{text-align:center;margin-bottom:2.5rem}.modern-login-logo{background:linear-gradient(135deg,#3b82f6,#8b5cf6);border-radius:50%;justify-content:center;align-items:center;width:4rem;height:4rem;margin:0 auto 1.5rem;display:flex;position:relative;box-shadow:0 10px 25px -5px #3b82f666}.modern-login-logo:before{content:"";z-index:-1;opacity:.3;filter:blur(10px);background:linear-gradient(135deg,#3b82f6,#8b5cf6);border-radius:50%;position:absolute;top:-2px;right:-2px;bottom:-2px;left:-2px}.modern-login-title{color:#fff;text-shadow:0 2px 4px #0000004d;margin:0 0 .5rem;font-size:2rem;font-weight:700}.modern-login-subtitle{color:#fffc;margin:0;font-size:.95rem}.modern-login-form{flex-direction:column;gap:1.5rem;display:flex}.modern-form-group{position:relative}.modern-form-label{color:#ffffffe6;margin-bottom:.5rem;font-size:.875rem;font-weight:500;display:block}.modern-form-input{color:#fff;-webkit-backdrop-filter:blur(10px);background:#ffffff1a;border:1px solid #fff3;border-radius:12px;width:100%;padding:.875rem 1rem .875rem 3rem;font-size:.95rem;transition:all .3s}.modern-form-input:focus{background:#ffffff26;border-color:#3b82f6;outline:none;box-shadow:0 0 0 3px #3b82f61a,0 0 0 1px #3b82f633}.modern-form-input::-moz-placeholder{color:#fff9}.modern-form-input::placeholder{color:#fff9}.modern-form-icon{color:#fff9;pointer-events:none;width:1.25rem;height:1.25rem;position:absolute;top:50%;left:1rem;transform:translateY(-50%)}.modern-form-toggle{color:#fff9;cursor:pointer;background:0 0;border:none;border-radius:4px;padding:.25rem;transition:all .2s;position:absolute;top:50%;right:1rem;transform:translateY(-50%)}.modern-form-toggle:hover{color:#ffffffe6;background:#ffffff1a}.modern-login-button{color:#fff;cursor:pointer;background:linear-gradient(135deg,#3b82f6,#8b5cf6);border:none;border-radius:12px;width:100%;padding:1rem 1.5rem;font-size:.95rem;font-weight:600;transition:all .3s;position:relative;overflow:hidden;box-shadow:0 10px 25px -5px #3b82f666}.modern-login-button:before{content:"";background:linear-gradient(90deg,#0000,#fff3,#0000);width:100%;height:100%;transition:left .5s;position:absolute;top:0;left:-100%}.modern-login-button:hover:before{left:100%}.modern-login-button:hover{transform:translateY(-2px);box-shadow:0 15px 35px -5px #3b82f699}.modern-login-button:active{transform:translateY(0)}.modern-login-button:disabled{opacity:.6;cursor:not-allowed;transform:none}.modern-error-message{-webkit-backdrop-filter:blur(10px);background:#ef44441a;border:1px solid #ef44444d;border-radius:12px;padding:1rem}.modern-demo-section{-webkit-backdrop-filter:blur(10px);background:#ffffff0d;border:1px solid #ffffff1a;border-radius:16px;margin-top:2rem;padding:1.5rem}.login-container{background:linear-gradient(135deg,#dbeafe 0%,#e0e7ff 100%);justify-content:center;align-items:center;min-height:100vh;padding:1rem;display:flex}.login-card{width:100%;max-width:28rem}.login-header{text-align:center;margin-bottom:2rem}.login-logo{background:#2563eb;border-radius:50%;justify-content:center;align-items:center;width:4rem;height:4rem;margin:0 auto 1rem;display:flex}.login-icon{color:#fff;width:2rem;height:2rem}.login-title{color:#111827;margin-bottom:.5rem;font-size:1.875rem;font-weight:700}.login-subtitle{color:#6b7280}.login-form{background:#fff;border-radius:1rem;padding:2rem;box-shadow:0 25px 50px -12px #00000040}.login-form-content{flex-direction:column;gap:1.5rem;display:flex}.input-group{position:relative}.input-icon{pointer-events:none;z-index:1;position:absolute;top:50%;left:.75rem;transform:translateY(-50%)}.input-icon-svg{color:#9ca3af;width:1.25rem;height:1.25rem}.password-toggle{cursor:pointer;background:0 0;border:none;padding:.25rem;position:absolute;top:50%;right:.75rem;transform:translateY(-50%)}.toggle-icon{color:#9ca3af;width:1.25rem;height:1.25rem;transition:color .2s}.toggle-icon:hover{color:#6b7280}.btn-full{width:100%}.error-message{background:#fef2f2;border:1px solid #fecaca;border-radius:.5rem;padding:1rem}.error-text{color:#dc2626;margin:0;font-size:.875rem}@property --tw-scale-x{syntax:"*";inherits:false;initial-value:1}@property --tw-scale-y{syntax:"*";inherits:false;initial-value:1}@property --tw-scale-z{syntax:"*";inherits:false;initial-value:1}@property --tw-rotate-x{syntax:"*";inherits:false}@property --tw-rotate-y{syntax:"*";inherits:false}@property --tw-rotate-z{syntax:"*";inherits:false}@property --tw-skew-x{syntax:"*";inherits:false}@property --tw-skew-y{syntax:"*";inherits:false}@property --tw-border-style{syntax:"*";inherits:false;initial-value:solid}@property --tw-duration{syntax:"*";inherits:false}@property --tw-shadow{syntax:"*";inherits:false;initial-value:0 0 #0000}@property --tw-shadow-color{syntax:"*";inherits:false}@property --tw-shadow-alpha{syntax:"<percentage>";inherits:false;initial-value:100%}@property --tw-inset-shadow{syntax:"*";inherits:false;initial-value:0 0 #0000}@property --tw-inset-shadow-color{syntax:"*";inherits:false}@property --tw-inset-shadow-alpha{syntax:"<percentage>";inherits:false;initial-value:100%}@property --tw-ring-color{syntax:"*";inherits:false}@property --tw-ring-shadow{syntax:"*";inherits:false;initial-value:0 0 #0000}@property --tw-inset-ring-color{syntax:"*";inherits:false}@property --tw-inset-ring-shadow{syntax:"*";inherits:false;initial-value:0 0 #0000}@property --tw-ring-inset{syntax:"*";inherits:false}@property --tw-ring-offset-width{syntax:"<length>";inherits:false;initial-value:0}@property --tw-ring-offset-color{syntax:"*";inherits:false;initial-value:#fff}@property --tw-ring-offset-shadow{syntax:"*";inherits:false;initial-value:0 0 #0000}
