@import "https://fonts.googleapis.com/css2?family=Inter:wght@300;400;500;600;700&display=swap";:root{--primary:#2563eb;--primary-hover:#1d4ed8;--bg-app:#f8fafc;--bg-sidebar:#fff;--bg-card:#fff;--text-main:#1e293b;--text-muted:#64748b;--border:#e2e8f0;--sidebar-width:260px;--topbar-height:64px;--radius:12px;--shadow-sm:0 1px 2px 0 #0000000d;--shadow:0 4px 6px -1px #0000001a, 0 2px 4px -2px #0000001a;--sans:"Inter", system-ui, -apple-system, sans-serif}*{box-sizing:border-box}body{font-family:var(--sans);background-color:var(--bg-app);color:var(--text-main);height:100vh;margin:0;overflow:hidden}#app{width:100vw;height:100vh;display:flex}.sidebar{width:var(--sidebar-width);background-color:var(--bg-sidebar);border-right:1px solid var(--border);z-index:20;flex-direction:column;flex-shrink:0;display:flex}.sidebar-header{height:var(--topbar-height);border-bottom:1px solid var(--border);align-items:center;padding:0 24px;display:flex}.logo-text{color:var(--primary);letter-spacing:-.5px;font-size:20px;font-weight:700}.sidebar-nav{flex-direction:column;flex:1;gap:4px;padding:20px 12px;display:flex;overflow-y:auto}.sidebar-nav::-webkit-scrollbar{width:5px}.sidebar-nav::-webkit-scrollbar-track{background:0 0}.sidebar-nav::-webkit-scrollbar-thumb{background:#e2e8f0;border-radius:10px}.sidebar-nav::-webkit-scrollbar-thumb:hover{background:#cbd5e1}.nav-group{margin-bottom:24px}.nav-group-title{text-transform:uppercase;letter-spacing:.05em;color:var(--text-muted);margin-bottom:8px;padding:0 12px;font-size:11px;font-weight:600}.nav-item{border-radius:var(--radius);color:var(--text-muted);cursor:pointer;align-items:center;gap:12px;padding:10px 12px;font-size:14px;font-weight:500;text-decoration:none;transition:all .2s;display:flex}.nav-item:hover{color:var(--text-main);background-color:#f1f5f9}.nav-item.active{color:var(--primary);background-color:#eff6ff}.nav-item .icon{justify-content:center;align-items:center;width:20px;height:20px;display:flex}.sub-nav{border-left:1px solid var(--border);flex-direction:column;gap:2px;margin-top:4px;margin-left:32px;padding-left:8px;display:flex}.sub-item{color:var(--text-muted);cursor:pointer;border-radius:6px;padding:6px 12px;font-size:13px}.sub-item:hover{color:var(--primary)}.sub-item.active{color:var(--primary);font-weight:600}.tab-btn{color:var(--text-muted);transition:all .2s}.tab-btn.active{box-shadow:inset 0 -2px 0 var(--primary);color:var(--primary)!important;background:#fff!important}.main-wrapper{flex-direction:column;flex:1;min-width:0;display:flex}.topbar{height:var(--topbar-height);background-color:var(--bg-sidebar);border-bottom:1px solid var(--border);flex-shrink:0;justify-content:space-between;align-items:center;padding:0 32px;display:flex}.page-title{font-size:18px;font-weight:600}.content-area{flex:1;padding:32px;overflow-y:auto}.grid{grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:24px;display:grid}.card{background-color:var(--bg-card);border-radius:var(--radius);border:1px solid var(--border);box-shadow:var(--shadow-sm);padding:24px}.card-title{color:var(--text-muted);margin-bottom:20px;font-size:14px;font-weight:600}.dashboard-grid{grid-template-columns:repeat(3,1fr);gap:24px;display:grid}.stat-card{align-items:center;gap:20px;padding:24px;display:flex;position:relative;overflow:hidden}.stat-card .card-icon{width:56px;height:56px;color:var(--primary);background:#2563eb1a;border-radius:14px;justify-content:center;align-items:center;display:flex}.stat-card.success .card-icon{color:#16a34a;background:#16a34a1a}.stat-card.warning .card-icon{color:#ea580c;background:#ea580c1a}.stat-value{margin:4px 0;font-size:26px;font-weight:800}.stat-trend{color:var(--text-muted);font-size:12px;font-weight:500}.stat-trend.positive{color:#16a34a}.stat-trend.negative{color:#ef4444}.chart-container{flex-direction:column;height:200px;margin-top:10px;display:flex}.mini-chart{filter:drop-shadow(0 4px 8px #2563eb26);width:100%;height:100%}.chart-labels{color:var(--text-muted);justify-content:space-between;margin-top:10px;padding:0 10px;font-size:11px;display:flex}.activity-list{flex-direction:column;gap:20px;display:flex}.activity-item{gap:16px;display:flex;position:relative}.activity-item .dot{border-radius:50%;flex-shrink:0;width:10px;height:10px;margin-top:6px}.activity-text{font-size:14px;line-height:1.4}.activity-time{color:var(--text-muted);margin-top:2px;font-size:11px}.table-container{border-radius:var(--radius);border:1px solid var(--border);box-shadow:var(--shadow-sm);background:#fff;margin-top:24px;overflow:hidden}table{border-collapse:collapse;text-align:left;width:100%}th{color:#64748b;text-transform:uppercase;letter-spacing:.05em;border-bottom:1px solid var(--border);background:#f8fafc;padding:16px 24px;font-size:11px;font-weight:700}td{border-bottom:1px solid var(--border);vertical-align:middle;padding:16px 24px;font-size:14px}tr:hover td{background-color:#f8fafc}tr:last-child td{border-bottom:none}.product-cell{align-items:center;gap:16px;display:flex}.product-icon{width:44px;height:44px;color:var(--primary);background:#f1f5f9;border-radius:10px;justify-content:center;align-items:center;display:flex}.product-info{flex-direction:column;gap:2px;display:flex}.product-name{color:var(--text-main);font-size:14px;font-weight:600}.product-desc{color:var(--text-muted);font-size:12px}.badge{border-radius:9999px;padding:4px 8px;font-size:11px;font-weight:600}.badge-success{color:#166534;background:#dcfce7}.row-alert{background-color:#fff1f2!important}.row-alert:hover{background-color:#ffe4e6!important}.badge-danger{color:#991b1b;background:#fee2e2}.product-img{object-fit:cover;border:1px solid var(--border);background:#f1f5f9;border-radius:8px;width:40px;height:40px}.row-alert td{background-color:#fff1f2!important}.filters-wrapper{border-radius:var(--radius);border:1px solid var(--border);box-shadow:var(--shadow-sm);background:#fff;align-items:center;gap:16px;margin-bottom:24px;padding:16px 24px;display:flex}.filter-input{flex:1;transition:all .3s;position:relative}.filter-input input{border:1px solid var(--border);background:#f8fafc;border-radius:10px;width:100%;padding:12px 16px 12px 44px;font-size:14px;transition:all .3s cubic-bezier(.4,0,.2,1);box-shadow:inset 0 2px 4px #00000005}.filter-input input:focus{border-color:var(--primary);background:#fff;outline:none;box-shadow:0 0 0 4px #2563eb1a,0 4px 6px -1px #0000000d}.filter-input .icon{color:var(--text-muted);transition:color .3s;position:absolute;top:50%;left:16px;transform:translateY(-50%)}.filter-input input:focus+.icon{color:var(--primary)}.filter-select{border:1px solid var(--border);background:#fff;border-radius:8px;width:180px;padding:10px 12px;font-size:14px}.export-group{gap:8px;margin-left:auto;display:flex}.fiche-grid{grid-template-columns:280px 1fr;gap:32px;display:grid}.fiche-sidebar{flex-direction:column;gap:20px;display:flex}.fiche-main-img{aspect-ratio:1;object-fit:cover;border:1px solid var(--border);border-radius:12px;width:100%}.history-card{border:1px solid var(--border);background:#f8fafc;border-radius:12px;padding:20px}.history-item{border-bottom:1px solid var(--border);justify-content:space-between;padding:12px 0;display:flex}.history-item:last-child{border-bottom:none}.history-type{text-transform:uppercase;font-size:11px;font-weight:700}.history-type.in{color:#16a34a}.history-type.out{color:#dc2626}.btn{cursor:pointer;letter-spacing:.01em;border:1px solid #0000;border-radius:10px;justify-content:center;align-items:center;gap:8px;padding:10px 20px;font-size:13px;font-weight:600;transition:all .2s cubic-bezier(.4,0,.2,1);display:inline-flex}.btn:active{transform:scale(.98)}.btn-primary{background-color:var(--primary);color:#fff}.btn-primary:hover{background-color:var(--primary-hover)}.btn-secondary{border-color:var(--border);color:var(--text-main);background-color:#fff}.btn-secondary:hover{background-color:#f8fafc}.modal-overlay{z-index:1000;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);background-color:#0f172a66;display:none;position:fixed;inset:0;overflow:hidden auto}.modal-overlay.active{display:block}.modal{background:#fff;border-radius:16px;width:100%;max-width:500px;margin:40px auto;animation:.3s ease-out modalIn;overflow:visible;box-shadow:0 20px 25px -5px #0000001a}@keyframes modalIn{0%{opacity:0;transform:scale(.95)translateY(10px)}to{opacity:1;transform:scale(1)translateY(0)}}.modal-header{border-bottom:1px solid var(--border);justify-content:space-between;align-items:center;padding:20px 24px;display:flex}.modal-body{padding:24px}.modal-footer{border-top:1px solid var(--border);background-color:#f8fafc;justify-content:flex-end;gap:12px;padding:16px 24px;display:flex}.form-group{margin-bottom:20px}.form-group:last-child{margin-bottom:0}.label{color:var(--text-muted);margin-bottom:6px;font-size:13px;font-weight:500;display:block}.input{border:1px solid var(--border);border-radius:8px;width:100%;padding:10px 12px;font-family:inherit;font-size:14px;transition:border-color .2s}.input:focus{border-color:var(--primary);outline:none;box-shadow:0 0 0 3px #2563eb1a}.input-row{grid-template-columns:1fr 1fr;gap:16px;display:grid}.view-enter{animation:.3s ease-out fadeIn}@keyframes fadeIn{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}.kpi-card{background:#fff;border-radius:16px;padding:24px;transition:transform .2s,box-shadow .2s;box-shadow:0 4px 6px -1px #0000001a,0 2px 4px -2px #0000001a}.kpi-card:hover{transform:translateY(-4px);box-shadow:0 10px 15px -3px #0000001a,0 4px 6px -4px #0000001a}.chart-card{box-shadow:var(--shadow);background:#fff;border-radius:16px;padding:24px}
